@angular-eslint/eslint-plugin-template 16.2.1-alpha.36 → 16.2.1-alpha.38

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/dist/index.d.ts +149 -0
  2. package/dist/processors.d.ts +37 -0
  3. package/dist/rules/alt-text.d.ts +4 -0
  4. package/dist/rules/attributes-order.d.ts +18 -0
  5. package/dist/rules/banana-in-box.d.ts +4 -0
  6. package/dist/rules/button-has-type.d.ts +5 -0
  7. package/dist/rules/click-events-have-key-events.d.ts +4 -0
  8. package/dist/rules/conditional-complexity.d.ts +7 -0
  9. package/dist/rules/cyclomatic-complexity.d.ts +7 -0
  10. package/dist/rules/elements-content.d.ts +9 -0
  11. package/dist/rules/eqeqeq.d.ts +8 -0
  12. package/dist/rules/i18n.d.ts +18 -0
  13. package/dist/rules/interactive-supports-focus.d.ts +4 -0
  14. package/dist/rules/label-has-associated-control.d.ts +14 -0
  15. package/dist/rules/mouse-events-have-key-events.d.ts +5 -0
  16. package/dist/rules/no-any.d.ts +4 -0
  17. package/dist/rules/no-autofocus.d.ts +4 -0
  18. package/dist/rules/no-call-expression.d.ts +9 -0
  19. package/dist/rules/no-distracting-elements.d.ts +4 -0
  20. package/dist/rules/no-duplicate-attributes.d.ts +11 -0
  21. package/dist/rules/no-inline-styles.d.ts +10 -0
  22. package/dist/rules/no-interpolation-in-attributes.d.ts +4 -0
  23. package/dist/rules/no-negated-async.d.ts +7 -0
  24. package/dist/rules/no-positive-tabindex.d.ts +4 -0
  25. package/dist/rules/prefer-ngsrc.d.ts +4 -0
  26. package/dist/rules/prefer-self-closing-tags.d.ts +4 -0
  27. package/dist/rules/role-has-required-aria.d.ts +4 -0
  28. package/dist/rules/table-scope.d.ts +4 -0
  29. package/dist/rules/use-track-by-function.d.ts +7 -0
  30. package/dist/rules/valid-aria.d.ts +4 -0
  31. package/dist/utils/attributes-comparator.d.ts +3 -0
  32. package/dist/utils/constants.d.ts +8 -0
  33. package/dist/utils/create-eslint-rule.d.ts +2 -0
  34. package/dist/utils/get-attribute-value.d.ts +12 -0
  35. package/dist/utils/get-dom-elements.d.ts +1 -0
  36. package/dist/utils/get-nearest-node-from.d.ts +6 -0
  37. package/dist/utils/get-original-attribute-name.d.ts +13 -0
  38. package/dist/utils/is-child-node-of.d.ts +2 -0
  39. package/dist/utils/is-content-editable.d.ts +2 -0
  40. package/dist/utils/is-disabled-element.d.ts +2 -0
  41. package/dist/utils/is-hidden-from-screen-reader.d.ts +9 -0
  42. package/dist/utils/is-interactive-element/get-interactive-element-ax-object-schemas.d.ts +9 -0
  43. package/dist/utils/is-interactive-element/get-interactive-element-role-schemas.d.ts +2 -0
  44. package/dist/utils/is-interactive-element/get-non-interactive-element-role-schemas.d.ts +3 -0
  45. package/dist/utils/is-interactive-element/index.d.ts +9 -0
  46. package/dist/utils/is-presentation-role.d.ts +2 -0
  47. package/dist/utils/is-semantic-role-element.d.ts +2 -0
  48. package/dist/utils/to-pattern.d.ts +1 -0
  49. package/package.json +4 -4
@@ -0,0 +1,149 @@
1
+ declare const _default: {
2
+ configs: {
3
+ all: {
4
+ parser: string;
5
+ plugins: string[];
6
+ rules: {
7
+ "@angular-eslint/template/alt-text": string;
8
+ "@angular-eslint/template/attributes-order": string;
9
+ "@angular-eslint/template/banana-in-box": string;
10
+ "@angular-eslint/template/button-has-type": string;
11
+ "@angular-eslint/template/click-events-have-key-events": string;
12
+ "@angular-eslint/template/conditional-complexity": string;
13
+ "@angular-eslint/template/cyclomatic-complexity": string;
14
+ "@angular-eslint/template/elements-content": string;
15
+ "@angular-eslint/template/eqeqeq": string;
16
+ "@angular-eslint/template/i18n": string;
17
+ "@angular-eslint/template/interactive-supports-focus": string;
18
+ "@angular-eslint/template/label-has-associated-control": string;
19
+ "@angular-eslint/template/mouse-events-have-key-events": string;
20
+ "@angular-eslint/template/no-any": string;
21
+ "@angular-eslint/template/no-autofocus": string;
22
+ "@angular-eslint/template/no-call-expression": string;
23
+ "@angular-eslint/template/no-distracting-elements": string;
24
+ "@angular-eslint/template/no-duplicate-attributes": string;
25
+ "@angular-eslint/template/no-inline-styles": string;
26
+ "@angular-eslint/template/no-interpolation-in-attributes": string;
27
+ "@angular-eslint/template/no-negated-async": string;
28
+ "@angular-eslint/template/no-positive-tabindex": string;
29
+ "@angular-eslint/template/prefer-ngsrc": string;
30
+ "@angular-eslint/template/prefer-self-closing-tags": string;
31
+ "@angular-eslint/template/role-has-required-aria": string;
32
+ "@angular-eslint/template/table-scope": string;
33
+ "@angular-eslint/template/use-track-by-function": string;
34
+ "@angular-eslint/template/valid-aria": string;
35
+ };
36
+ };
37
+ recommended: {
38
+ parser: string;
39
+ plugins: string[];
40
+ rules: {
41
+ "@angular-eslint/template/banana-in-box": string;
42
+ "@angular-eslint/template/eqeqeq": string;
43
+ "@angular-eslint/template/no-negated-async": string;
44
+ };
45
+ };
46
+ accessibility: {
47
+ parser: string;
48
+ plugins: string[];
49
+ rules: {
50
+ "@angular-eslint/template/alt-text": string;
51
+ "@angular-eslint/template/click-events-have-key-events": string;
52
+ "@angular-eslint/template/elements-content": string;
53
+ "@angular-eslint/template/interactive-supports-focus": string;
54
+ "@angular-eslint/template/label-has-associated-control": string;
55
+ "@angular-eslint/template/mouse-events-have-key-events": string;
56
+ "@angular-eslint/template/no-autofocus": string;
57
+ "@angular-eslint/template/no-distracting-elements": string;
58
+ "@angular-eslint/template/role-has-required-aria": string;
59
+ "@angular-eslint/template/table-scope": string;
60
+ "@angular-eslint/template/valid-aria": string;
61
+ };
62
+ };
63
+ 'process-inline-templates': {
64
+ parser: string;
65
+ parserOptions: {
66
+ ecmaVersion: number;
67
+ sourceType: string;
68
+ };
69
+ plugins: string[];
70
+ processor: string;
71
+ };
72
+ };
73
+ processors: {
74
+ 'extract-inline-html': {
75
+ preprocess: typeof import("./processors").preprocessComponentFile;
76
+ postprocess: typeof import("./processors").postprocessComponentFile;
77
+ supportsAutofix: boolean;
78
+ };
79
+ };
80
+ rules: {
81
+ "alt-text": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"altText", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
82
+ "attributes-order": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"attributesOrder", [{
83
+ readonly alphabetical: boolean;
84
+ readonly order: readonly import("./rules/attributes-order").OrderType[];
85
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
86
+ "banana-in-box": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"bananaInBox", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
87
+ "button-has-type": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/button-has-type").MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
88
+ "click-events-have-key-events": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"clickEventsHaveKeyEvents", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
89
+ "conditional-complexity": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"conditionalComplexity", [{
90
+ maxComplexity: number;
91
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
92
+ "cyclomatic-complexity": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"cyclomaticComplexity", [{
93
+ maxComplexity: number;
94
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
95
+ "elements-content": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"elementsContent", [{
96
+ readonly allowList?: readonly string[] | undefined;
97
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
98
+ eqeqeq: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/eqeqeq").MessageIds, [{
99
+ readonly allowNullOrUndefined?: boolean | undefined;
100
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
101
+ i18n: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/i18n").MessageIds, [{
102
+ readonly boundTextAllowedPattern?: string | undefined;
103
+ readonly checkAttributes?: boolean | undefined;
104
+ readonly checkDuplicateId?: boolean | undefined;
105
+ readonly checkId?: boolean | undefined;
106
+ readonly checkText?: boolean | undefined;
107
+ readonly ignoreAttributes?: readonly string[] | undefined;
108
+ readonly ignoreTags?: readonly string[] | undefined;
109
+ readonly requireDescription?: boolean | undefined;
110
+ readonly requireMeaning?: boolean | undefined;
111
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
112
+ "interactive-supports-focus": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"interactiveSupportsFocus", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
113
+ "label-has-associated-control": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"labelHasAssociatedControl", [{
114
+ readonly controlComponents?: readonly string[] | undefined;
115
+ readonly labelComponents?: readonly {
116
+ readonly inputs?: readonly string[] | undefined;
117
+ readonly selector: string;
118
+ }[] | undefined;
119
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
120
+ "mouse-events-have-key-events": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"mouseEventsHaveKeyEvents", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
121
+ "no-any": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/no-any").MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
122
+ "no-autofocus": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noAutofocus", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
123
+ "no-call-expression": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noCallExpression", [{
124
+ readonly allowList?: readonly string[] | undefined;
125
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
126
+ "no-distracting-elements": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noDistractingElements", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
127
+ "no-duplicate-attributes": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/no-duplicate-attributes").MessageIds, [{
128
+ readonly allowTwoWayDataBinding?: boolean | undefined;
129
+ readonly allowStylePrecedenceDuplicates?: boolean | undefined;
130
+ readonly ignore?: readonly string[] | undefined;
131
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
132
+ "no-inline-styles": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noInlineStyles", [{
133
+ readonly allowNgStyle?: boolean | undefined;
134
+ readonly allowBindToStyle?: boolean | undefined;
135
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
136
+ "no-interpolation-in-attributes": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noInterpolationInAttributes", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
137
+ "no-negated-async": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/no-negated-async").MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
138
+ "no-positive-tabindex": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/no-positive-tabindex").MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
139
+ "prefer-self-closing-tags": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"preferSelfClosingTags", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
140
+ "prefer-ngsrc": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/prefer-ngsrc").MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
141
+ "role-has-required-aria": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/role-has-required-aria").MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
142
+ "table-scope": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"tableScope", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
143
+ "use-track-by-function": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"useTrackByFunction", [{
144
+ readonly alias: readonly string[];
145
+ }], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
146
+ "valid-aria": import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<import("./rules/valid-aria").MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
147
+ };
148
+ };
149
+ export = _default;
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Because ultimately a user is in control of how and when this processor gets invoked,
3
+ * we can't fully protect them against doing more work than is necessary in all cases.
4
+ *
5
+ * Therefore, before we do a full parse of a TypeScript file to try and extract one or
6
+ * more Component declarations we want to do a really quick check for whether or not
7
+ * a file is likely to contain them.
8
+ */
9
+ export declare function isFileLikelyToContainComponentDeclarations(text: string, filename: string): boolean;
10
+ type PreprocessResult = (string | {
11
+ text: string;
12
+ filename: string;
13
+ })[];
14
+ export declare function preprocessComponentFile(text: string, filename: string): PreprocessResult;
15
+ export declare function postprocessComponentFile(multiDimensionalMessages: {
16
+ ruleId: string;
17
+ severity: number;
18
+ message: string;
19
+ line: number;
20
+ column: number;
21
+ nodeType: string;
22
+ messageId: string;
23
+ endLine: number;
24
+ endColumn: number;
25
+ fix?: {
26
+ range: number[];
27
+ text: string;
28
+ };
29
+ }[][], filename: string): readonly unknown[];
30
+ declare const _default: {
31
+ 'extract-inline-html': {
32
+ preprocess: typeof preprocessComponentFile;
33
+ postprocess: typeof postprocessComponentFile;
34
+ supportsAutofix: boolean;
35
+ };
36
+ };
37
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'altText';
2
+ export declare const RULE_NAME = "alt-text";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"altText", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,18 @@
1
+ export declare const enum OrderType {
2
+ TemplateReferenceVariable = "TEMPLATE_REFERENCE",
3
+ StructuralDirective = "STRUCTURAL_DIRECTIVE",
4
+ AttributeBinding = "ATTRIBUTE_BINDING",
5
+ InputBinding = "INPUT_BINDING",
6
+ OutputBinding = "OUTPUT_BINDING",
7
+ TwoWayBinding = "TWO_WAY_BINDING"
8
+ }
9
+ type Options = [
10
+ {
11
+ readonly alphabetical: boolean;
12
+ readonly order: readonly OrderType[];
13
+ }
14
+ ];
15
+ export type MessageIds = 'attributesOrder';
16
+ export declare const RULE_NAME = "attributes-order";
17
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"attributesOrder", Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
18
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'bananaInBox';
2
+ export declare const RULE_NAME = "banana-in-box";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"bananaInBox", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,5 @@
1
+ export declare const RULE_NAME = "button-has-type";
2
+ export declare const INVALID_TYPE_DATA_KEY = "type";
3
+ export type MessageIds = 'invalidType' | 'missingType';
4
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
5
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'clickEventsHaveKeyEvents';
2
+ export declare const RULE_NAME = "click-events-have-key-events";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"clickEventsHaveKeyEvents", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,7 @@
1
+ type Options = [{
2
+ maxComplexity: number;
3
+ }];
4
+ export type MessageIds = 'conditionalComplexity';
5
+ export declare const RULE_NAME = "conditional-complexity";
6
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"conditionalComplexity", Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
7
+ export default _default;
@@ -0,0 +1,7 @@
1
+ type Options = [{
2
+ maxComplexity: number;
3
+ }];
4
+ export type MessageIds = 'cyclomaticComplexity';
5
+ export declare const RULE_NAME = "cyclomatic-complexity";
6
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"cyclomaticComplexity", Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
7
+ export default _default;
@@ -0,0 +1,9 @@
1
+ type Options = [
2
+ {
3
+ readonly allowList?: readonly string[];
4
+ }
5
+ ];
6
+ export type MessageIds = 'elementsContent';
7
+ export declare const RULE_NAME = "elements-content";
8
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"elementsContent", Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
9
+ export default _default;
@@ -0,0 +1,8 @@
1
+ import type { TSESLint } from '@typescript-eslint/utils';
2
+ type Options = [{
3
+ readonly allowNullOrUndefined?: boolean;
4
+ }];
5
+ export type MessageIds = 'eqeqeq' | 'suggestStrictEquality';
6
+ export declare const RULE_NAME = "eqeqeq";
7
+ declare const _default: TSESLint.RuleModule<MessageIds, Options, TSESLint.RuleListener>;
8
+ export default _default;
@@ -0,0 +1,18 @@
1
+ import type { TSESLint } from '@typescript-eslint/utils';
2
+ type Options = [
3
+ {
4
+ readonly boundTextAllowedPattern?: string;
5
+ readonly checkAttributes?: boolean;
6
+ readonly checkDuplicateId?: boolean;
7
+ readonly checkId?: boolean;
8
+ readonly checkText?: boolean;
9
+ readonly ignoreAttributes?: readonly string[];
10
+ readonly ignoreTags?: readonly string[];
11
+ readonly requireDescription?: boolean;
12
+ readonly requireMeaning?: boolean;
13
+ }
14
+ ];
15
+ export type MessageIds = 'i18nAttribute' | 'i18nAttributeOnIcuOrText' | 'i18nCustomIdOnAttribute' | 'i18nCustomIdOnElement' | 'i18nDuplicateCustomId' | 'suggestAddI18nAttribute' | 'i18nMissingDescription' | 'i18nMissingMeaning';
16
+ export declare const RULE_NAME = "i18n";
17
+ declare const _default: TSESLint.RuleModule<MessageIds, Options, TSESLint.RuleListener>;
18
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'interactiveSupportsFocus';
2
+ export declare const RULE_NAME = "interactive-supports-focus";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"interactiveSupportsFocus", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,14 @@
1
+ type LabelComponent = {
2
+ readonly inputs?: readonly string[];
3
+ readonly selector: string;
4
+ };
5
+ type Options = [
6
+ {
7
+ readonly controlComponents?: readonly string[];
8
+ readonly labelComponents?: readonly LabelComponent[];
9
+ }
10
+ ];
11
+ export type MessageIds = 'labelHasAssociatedControl';
12
+ export declare const RULE_NAME = "label-has-associated-control";
13
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"labelHasAssociatedControl", Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
14
+ export default _default;
@@ -0,0 +1,5 @@
1
+ import type { TSESLint } from '@typescript-eslint/utils';
2
+ export type MessageIds = 'mouseEventsHaveKeyEvents';
3
+ export declare const RULE_NAME = "mouse-events-have-key-events";
4
+ declare const _default: TSESLint.RuleModule<"mouseEventsHaveKeyEvents", [], TSESLint.RuleListener>;
5
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'noAny' | 'suggestRemoveAny';
2
+ export declare const RULE_NAME = "no-any";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'noAutofocus';
2
+ export declare const RULE_NAME = "no-autofocus";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noAutofocus", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,9 @@
1
+ type Options = [
2
+ {
3
+ readonly allowList?: readonly string[];
4
+ }
5
+ ];
6
+ export type MessageIds = 'noCallExpression';
7
+ export declare const RULE_NAME = "no-call-expression";
8
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noCallExpression", Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
9
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'noDistractingElements';
2
+ export declare const RULE_NAME = "no-distracting-elements";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noDistractingElements", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,11 @@
1
+ type Options = [
2
+ {
3
+ readonly allowTwoWayDataBinding?: boolean;
4
+ readonly allowStylePrecedenceDuplicates?: boolean;
5
+ readonly ignore?: readonly string[];
6
+ }
7
+ ];
8
+ export type MessageIds = 'noDuplicateAttributes' | 'suggestRemoveAttribute';
9
+ export declare const RULE_NAME = "no-duplicate-attributes";
10
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<MessageIds, Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
11
+ export default _default;
@@ -0,0 +1,10 @@
1
+ type Options = [
2
+ {
3
+ readonly allowNgStyle?: boolean;
4
+ readonly allowBindToStyle?: boolean;
5
+ }
6
+ ];
7
+ export type MessageIds = 'noInlineStyles';
8
+ export declare const RULE_NAME = "no-inline-styles";
9
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noInlineStyles", Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
10
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export declare const MESSAGE_ID = "noInterpolationInAttributes";
2
+ export declare const RULE_NAME = "no-interpolation-in-attributes";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"noInterpolationInAttributes", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,7 @@
1
+ export type MessageIds = 'noNegatedAsync' | 'suggestFalseComparison' | 'suggestNullComparison' | 'suggestUndefinedComparison';
2
+ export declare const RULE_NAME = "no-negated-async";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
5
+ export declare const RULE_DOCS_EXTENSION: {
6
+ rationale: string;
7
+ };
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'noPositiveTabindex' | 'suggestNonNegativeTabindex';
2
+ export declare const RULE_NAME = "no-positive-tabindex";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'missingAttribute' | 'invalidDoubleSource';
2
+ export declare const RULE_NAME = "prefer-ngsrc";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export declare const MESSAGE_ID = "preferSelfClosingTags";
2
+ export declare const RULE_NAME = "prefer-self-closing-tags";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"preferSelfClosingTags", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'roleHasRequiredAria' | 'suggestRemoveRole';
2
+ export declare const RULE_NAME = "role-has-required-aria";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'tableScope';
2
+ export declare const RULE_NAME = "table-scope";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"tableScope", [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,7 @@
1
+ type Options = [{
2
+ readonly alias: readonly string[];
3
+ }];
4
+ export type MessageIds = 'useTrackByFunction';
5
+ export declare const RULE_NAME = "use-track-by-function";
6
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"useTrackByFunction", Options, import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
7
+ export default _default;
@@ -0,0 +1,4 @@
1
+ export type MessageIds = 'validAria' | 'validAriaValue' | 'suggestRemoveInvalidAria';
2
+ export declare const RULE_NAME = "valid-aria";
3
+ declare const _default: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<MessageIds, [], import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>;
4
+ export default _default;
@@ -0,0 +1,3 @@
1
+ import type { TmplAstElement } from '@angular-eslint/bundled-angular-compiler';
2
+ import type { ARIARoleRelationConceptAttribute } from 'aria-query';
3
+ export declare function attributesComparator(ariaRoleRelationConceptAttributes: readonly ARIARoleRelationConceptAttribute[], node: TmplAstElement): boolean;
@@ -0,0 +1,8 @@
1
+ /**
2
+ * A representation of a property read.
3
+ * @example
4
+ * ```html
5
+ * <input [disabled]="disabled">
6
+ * ```
7
+ */
8
+ export declare const PROPERTY_READ: unique symbol;
@@ -0,0 +1,2 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const createESLintRule: <TOptions extends readonly unknown[], TMessageIds extends string, TRuleListener extends import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener = import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleListener>({ name, meta, ...rule }: Readonly<ESLintUtils.RuleWithMetaAndName<TOptions, TMessageIds, TRuleListener>>) => import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<TMessageIds, TOptions, TRuleListener>;
@@ -0,0 +1,12 @@
1
+ import type { TmplAstElement } from '@angular-eslint/bundled-angular-compiler';
2
+ /**
3
+ * Extracts the attribute value.
4
+ * @example
5
+ * ```ts
6
+ * getAttributeValue(Element(`<div property="test"></div>`), 'nonExistent'); // null
7
+ * getAttributeValue(Element(`<div aria-role="none"></div>`), 'role'); // 'none'
8
+ * getAttributeValue(Element(`<div [attr.aria-checked]="true"></div>`), 'aria-checked'); // true
9
+ * getAttributeValue(Element(`<button [variant]="variant"></button>`), 'variant'); // PROPERTY
10
+ * ```
11
+ */
12
+ export declare function getAttributeValue({ attributes, inputs }: TmplAstElement, attributeName: string): unknown;
@@ -0,0 +1 @@
1
+ export declare function getDomElements(): ReadonlySet<string>;
@@ -0,0 +1,6 @@
1
+ import type { AST, TmplAstNode } from '@angular-eslint/bundled-angular-compiler';
2
+ type ASTOrNodeWithParent = (AST | TmplAstNode) & {
3
+ parent?: ASTOrNodeWithParent;
4
+ };
5
+ export declare function getNearestNodeFrom<T extends ASTOrNodeWithParent>({ parent }: ASTOrNodeWithParent, predicate: (parent: ASTOrNodeWithParent) => parent is T): T | null;
6
+ export {};
@@ -0,0 +1,13 @@
1
+ import type { TmplAstBoundAttribute, TmplAstTextAttribute } from '@angular-eslint/bundled-angular-compiler';
2
+ import { TmplAstBoundEvent } from '@angular-eslint/bundled-angular-compiler';
3
+ /**
4
+ * Returns the original attribute name.
5
+ * @example
6
+ * ```html
7
+ * <div [style.display.none]="test"></div> <!-- Instead of "display", "style.display.none" -->
8
+ * <div [attr.role]="'none'"></div> <!-- Instead of "attr.role", "role" -->
9
+ * <div ([ngModel])="test"></div> <!-- Instead of "ngModel", "ngModelChange" -->
10
+ * <div (@fade.start)="handle()"></div> <!-- Instead of "fade", "@fade.start" -->
11
+ * ```
12
+ */
13
+ export declare function getOriginalAttributeName(attribute: TmplAstBoundAttribute | TmplAstBoundEvent | TmplAstTextAttribute): string;
@@ -0,0 +1,2 @@
1
+ import { TmplAstElement } from '@angular-eslint/bundled-angular-compiler';
2
+ export declare function isChildNodeOf(ast: TmplAstElement, childNodeName: string): boolean;
@@ -0,0 +1,2 @@
1
+ import type { TmplAstElement } from '@angular-eslint/bundled-angular-compiler';
2
+ export declare function isContentEditable(node: TmplAstElement): boolean;
@@ -0,0 +1,2 @@
1
+ import type { TmplAstElement } from '@angular-eslint/bundled-angular-compiler';
2
+ export declare function isDisabledElement(node: TmplAstElement): boolean;
@@ -0,0 +1,9 @@
1
+ import { TmplAstElement } from '@angular-eslint/bundled-angular-compiler';
2
+ /**
3
+ * Whether an element content cannot be read by a screen reader. It can happen in the following situations:
4
+ * - It has `display: none` or `visibility: hidden` style;
5
+ * - It has `aria-hidden` or `hidden` attribute;
6
+ * - It's an `<input type="hidden">`;
7
+ * - One of its ancestors met one of the following situations above.
8
+ */
9
+ export declare function isHiddenFromScreenReader(node: TmplAstElement): boolean;
@@ -0,0 +1,9 @@
1
+ interface AXObjectSchema {
2
+ name: string;
3
+ attributes?: {
4
+ name: string;
5
+ value?: string;
6
+ }[];
7
+ }
8
+ export declare function getInteractiveElementAXObjectSchemas(): AXObjectSchema[];
9
+ export {};
@@ -0,0 +1,2 @@
1
+ import type { ARIARoleRelationConcept } from 'aria-query';
2
+ export declare function getInteractiveElementRoleSchemas(): ARIARoleRelationConcept[];
@@ -0,0 +1,3 @@
1
+ import type { ARIARoleDefinitionKey, ARIARoleRelationConcept } from 'aria-query';
2
+ export declare function getNonInteractiveElementRoleSchemas(): ARIARoleRelationConcept[];
3
+ export declare function getNonInteractiveRoles(): Set<ARIARoleDefinitionKey>;
@@ -0,0 +1,9 @@
1
+ import type { TmplAstElement } from '@angular-eslint/bundled-angular-compiler';
2
+ /**
3
+ * Returns boolean indicating whether the given element is
4
+ * interactive on the DOM or not. Usually used when an element
5
+ * has a dynamic handler on it and we need to discern whether or not
6
+ * it's intention is to be interacted with on the DOM.
7
+ */
8
+ export declare function isInteractiveElement(node: TmplAstElement): boolean;
9
+ export declare function isNonInteractiveRole(node: TmplAstElement): boolean;
@@ -0,0 +1,2 @@
1
+ import type { TmplAstElement } from '@angular-eslint/bundled-angular-compiler';
2
+ export declare function isPresentationRole(node: TmplAstElement): boolean;
@@ -0,0 +1,2 @@
1
+ import type { TmplAstBoundAttribute, TmplAstTextAttribute } from '@angular-eslint/bundled-angular-compiler';
2
+ export declare function isSemanticRoleElement(element: string, role: string, elementAttributes: (TmplAstTextAttribute | TmplAstBoundAttribute)[]): boolean;
@@ -0,0 +1 @@
1
+ export declare function toPattern(value: readonly unknown[]): RegExp;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular-eslint/eslint-plugin-template",
3
- "version": "16.2.1-alpha.36+d4c1eaa",
3
+ "version": "16.2.1-alpha.38+f18e0d3",
4
4
  "description": "ESLint plugin for Angular Templates",
5
5
  "license": "MIT",
6
6
  "main": "dist/index.js",
@@ -17,8 +17,8 @@
17
17
  "LICENSE"
18
18
  ],
19
19
  "dependencies": {
20
- "@angular-eslint/bundled-angular-compiler": "16.2.1-alpha.36+d4c1eaa",
21
- "@angular-eslint/utils": "16.2.1-alpha.36+d4c1eaa",
20
+ "@angular-eslint/bundled-angular-compiler": "16.2.1-alpha.38+f18e0d3",
21
+ "@angular-eslint/utils": "16.2.1-alpha.38+f18e0d3",
22
22
  "@typescript-eslint/type-utils": "5.62.0",
23
23
  "@typescript-eslint/utils": "5.62.0",
24
24
  "aria-query": "5.3.0",
@@ -31,5 +31,5 @@
31
31
  "eslint": "^7.20.0 || ^8.0.0",
32
32
  "typescript": "*"
33
33
  },
34
- "gitHead": "d4c1eaa2982e190e0e8b81f3173761f0c9402c9a"
34
+ "gitHead": "f18e0d3fd38ab7e45d929099d33ac69144fd3800"
35
35
  }