2020-10-08 15:20:54 +00:00
|
|
|
import type { TextDocument, Position } from 'vscode-languageserver'
|
2022-03-02 17:16:35 +00:00
|
|
|
import { isVueDoc, isSvelteDoc, isHtmlDoc } from './html'
|
2021-05-20 15:50:10 +00:00
|
|
|
import { isJsDoc } from './js'
|
2020-05-03 17:11:45 +00:00
|
|
|
import { State } from './state'
|
2021-06-01 11:37:15 +00:00
|
|
|
import { cssLanguages } from './languages'
|
2022-03-02 17:16:35 +00:00
|
|
|
import { getLanguageBoundaries } from './getLanguageBoundaries'
|
2020-04-11 21:20:45 +00:00
|
|
|
|
2020-05-24 17:32:25 +00:00
|
|
|
export function isCssDoc(state: State, doc: TextDocument): boolean {
|
2021-05-20 15:50:10 +00:00
|
|
|
const userCssLanguages = Object.keys(state.editor.userLanguages).filter((lang) =>
|
2021-06-01 11:37:15 +00:00
|
|
|
cssLanguages.includes(state.editor.userLanguages[lang])
|
2021-05-20 15:50:10 +00:00
|
|
|
)
|
2020-05-03 17:11:45 +00:00
|
|
|
|
2021-06-01 11:37:15 +00:00
|
|
|
return [...cssLanguages, ...userCssLanguages].indexOf(doc.languageId) !== -1
|
2020-04-11 21:20:45 +00:00
|
|
|
}
|
2020-04-11 22:34:03 +00:00
|
|
|
|
2021-05-20 15:50:10 +00:00
|
|
|
export function isCssContext(state: State, doc: TextDocument, position: Position): boolean {
|
2020-05-03 17:11:45 +00:00
|
|
|
if (isCssDoc(state, doc)) {
|
2020-04-11 22:34:03 +00:00
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2021-05-20 15:50:10 +00:00
|
|
|
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,
|
|
|
|
})
|
|
|
|
|
2022-03-02 17:16:35 +00:00
|
|
|
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
|
|
|
|
}
|