tailwind-ctp-intellisense/packages/tailwindcss-language-service/src/diagnostics/getInvalidApplyDiagnostics.ts

39 lines
1.2 KiB
TypeScript
Raw Normal View History

import type { TextDocument } from 'vscode-languageserver-textdocument'
import { findClassNamesInRange } from '../util/find'
2020-06-19 10:52:38 +00:00
import { InvalidApplyDiagnostic, DiagnosticKind } from './types'
import { Settings, State } from '../util/state'
import type { DiagnosticSeverity } from 'vscode-languageserver'
import { validateApply } from '../util/validateApply'
2020-06-19 10:52:38 +00:00
export async function getInvalidApplyDiagnostics(
2020-06-19 10:52:38 +00:00
state: State,
document: TextDocument,
settings: Settings
): Promise<InvalidApplyDiagnostic[]> {
2021-05-04 11:40:50 +00:00
let severity = settings.tailwindCSS.lint.invalidApply
2020-06-19 10:52:38 +00:00
if (severity === 'ignore') return []
2021-05-04 11:40:50 +00:00
const classNames = await findClassNamesInRange(state, document, undefined, 'css', false)
2020-06-19 10:52:38 +00:00
let diagnostics: InvalidApplyDiagnostic[] = classNames.map((className) => {
let result = validateApply(state, className.className)
2020-06-19 10:52:38 +00:00
if (result === null || result.isApplyable === true) {
return null
2020-06-19 10:52:38 +00:00
}
return {
code: DiagnosticKind.InvalidApply,
severity:
severity === 'error'
? 1 /* DiagnosticSeverity.Error */
: 2 /* DiagnosticSeverity.Warning */,
2020-06-19 10:52:38 +00:00
range: className.range,
message: result.reason,
2020-06-19 10:52:38 +00:00
className,
}
})
return diagnostics.filter(Boolean)
}