tailwind-ctp-intellisense/packages/tailwindcss-language-service/src/util/css.ts

34 lines
1.1 KiB
TypeScript
Raw Normal View History

import type { TextDocument, Position } from 'vscode-languageserver'
import { isVueDoc, isSvelteDoc, isHtmlDoc } from './html'
import { isJsDoc } from './js'
import { State } from './state'
import { cssLanguages } from './languages'
import { getLanguageBoundaries } from './getLanguageBoundaries'
2020-04-11 21:20:45 +00:00
export function isCssDoc(state: State, doc: TextDocument): boolean {
const userCssLanguages = Object.keys(state.editor.userLanguages).filter((lang) =>
cssLanguages.includes(state.editor.userLanguages[lang])
)
return [...cssLanguages, ...userCssLanguages].indexOf(doc.languageId) !== -1
2020-04-11 21:20:45 +00:00
}
2020-04-11 22:34:03 +00:00
export function isCssContext(state: State, doc: TextDocument, position: Position): boolean {
if (isCssDoc(state, doc)) {
2020-04-11 22:34:03 +00:00
return true
}
if (isHtmlDoc(state, doc) || isVueDoc(doc) || isSvelteDoc(doc) || isJsDoc(state, doc)) {
2020-04-11 22:34:03 +00:00
let str = doc.getText({
start: { line: 0, character: 0 },
end: position,
})
let boundaries = getLanguageBoundaries(state, doc, str)
return boundaries ? boundaries[boundaries.length - 1].type === 'css' : false
2020-04-11 22:34:03 +00:00
}
return false
}