2020-10-08 15:20:54 +00:00
|
|
|
import { findClassNamesInRange } from '../util/find'
|
2020-06-19 10:52:38 +00:00
|
|
|
import { InvalidApplyDiagnostic, DiagnosticKind } from './types'
|
2020-10-08 15:20:54 +00:00
|
|
|
import { Settings, State } from '../util/state'
|
|
|
|
import type { TextDocument, DiagnosticSeverity } from 'vscode-languageserver'
|
|
|
|
import { validateApply } from '../util/validateApply'
|
2020-06-19 10:52:38 +00:00
|
|
|
|
2020-12-07 15:39:44 +00:00
|
|
|
export async function getInvalidApplyDiagnostics(
|
2020-06-19 10:52:38 +00:00
|
|
|
state: State,
|
|
|
|
document: TextDocument,
|
|
|
|
settings: Settings
|
2020-12-07 15:39:44 +00:00
|
|
|
): 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) => {
|
2020-06-21 00:38:08 +00:00
|
|
|
let result = validateApply(state, className.className)
|
2020-06-19 10:52:38 +00:00
|
|
|
|
2020-06-21 00:38:08 +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'
|
2020-10-08 15:20:54 +00:00
|
|
|
? 1 /* DiagnosticSeverity.Error */
|
|
|
|
: 2 /* DiagnosticSeverity.Warning */,
|
2020-06-19 10:52:38 +00:00
|
|
|
range: className.range,
|
2020-06-21 00:38:08 +00:00
|
|
|
message: result.reason,
|
2020-06-19 10:52:38 +00:00
|
|
|
className,
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
return diagnostics.filter(Boolean)
|
|
|
|
}
|