forked from sveltejs/eslint-plugin-svelte
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathno-restricted-html-elements.ts
69 lines (68 loc) · 1.66 KB
/
no-restricted-html-elements.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
import { createRule } from "../utils"
export default createRule("no-restricted-html-elements", {
meta: {
docs: {
description: "disallow specific HTML elements",
category: "Extension Rules",
recommended: false,
},
schema: {
type: "array",
items: {
oneOf: [
{
type: "array",
items: {
type: ["string"],
},
uniqueItems: true,
minItems: 1,
},
{
type: "object",
properties: {
elements: {
type: "array",
items: {
type: ["string"],
},
uniqueItems: true,
minItems: 1,
},
message: { type: "string", minLength: 1 },
},
additionalProperties: false,
minItems: 1,
},
],
},
uniqueItems: true,
minItems: 1,
},
messages: {},
type: "suggestion",
},
create(context) {
return {
SvelteElement(node) {
if (node.kind !== "html") return
const { name } = node
if (name.type !== "SvelteName") return
for (const option of context.options) {
const message =
option.message ||
`Unexpected use of forbidden HTML element ${name.name}.`
const elements = option.elements || option
for (const element of elements) {
if (element === name.name) {
context.report({
message,
node: node.startTag,
})
}
}
}
},
}
},
})