@tanstack/devtools-a11y 0.0.1 → 0.1.1

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 (110) hide show
  1. package/LICENSE +21 -0
  2. package/dist/esm/core/components/IssueCard.d.ts +10 -0
  3. package/dist/esm/core/components/IssueCard.js +83 -0
  4. package/dist/esm/core/components/IssueCard.js.map +1 -0
  5. package/dist/esm/core/components/IssueList.d.ts +6 -0
  6. package/dist/esm/core/components/IssueList.js +134 -0
  7. package/dist/esm/core/components/IssueList.js.map +1 -0
  8. package/dist/esm/core/components/Settings.d.ts +6 -0
  9. package/dist/esm/core/components/Settings.js +251 -0
  10. package/dist/esm/core/components/Settings.js.map +1 -0
  11. package/dist/esm/core/components/Shell.d.ts +2 -0
  12. package/dist/esm/core/components/Shell.js +214 -0
  13. package/dist/esm/core/components/Shell.js.map +1 -0
  14. package/dist/esm/core/components/index.d.ts +2 -0
  15. package/dist/esm/core/components/index.js +14 -0
  16. package/dist/esm/core/components/index.js.map +1 -0
  17. package/dist/esm/core/contexts/allyContext.d.ts +17 -0
  18. package/dist/esm/core/contexts/allyContext.js +66 -0
  19. package/dist/esm/core/contexts/allyContext.js.map +1 -0
  20. package/dist/esm/core/core.d.ts +19 -0
  21. package/dist/esm/core/core.js +8 -0
  22. package/dist/esm/core/core.js.map +1 -0
  23. package/dist/esm/core/index.d.ts +9 -0
  24. package/dist/esm/core/index.js +9 -0
  25. package/dist/esm/core/index.js.map +1 -0
  26. package/dist/esm/core/production.d.ts +2 -0
  27. package/dist/esm/core/production.js +4 -0
  28. package/dist/esm/core/styles/styles.d.ts +85 -0
  29. package/dist/esm/core/styles/styles.js +547 -0
  30. package/dist/esm/core/styles/styles.js.map +1 -0
  31. package/dist/esm/core/types/types.d.ts +141 -0
  32. package/dist/esm/core/utils/ally-audit.utils.d.ts +19 -0
  33. package/dist/esm/core/utils/ally-audit.utils.js +226 -0
  34. package/dist/esm/core/utils/ally-audit.utils.js.map +1 -0
  35. package/dist/esm/core/utils/config.utils.d.ts +17 -0
  36. package/dist/esm/core/utils/config.utils.js +63 -0
  37. package/dist/esm/core/utils/config.utils.js.map +1 -0
  38. package/dist/esm/core/utils/custom-audit.utils.d.ts +13 -0
  39. package/dist/esm/core/utils/custom-audit.utils.js +426 -0
  40. package/dist/esm/core/utils/custom-audit.utils.js.map +1 -0
  41. package/dist/esm/core/utils/export-audit.uitls.d.ts +17 -0
  42. package/dist/esm/core/utils/export-audit.uitls.js +83 -0
  43. package/dist/esm/core/utils/export-audit.uitls.js.map +1 -0
  44. package/dist/esm/core/utils/ui.utils.d.ts +24 -0
  45. package/dist/esm/core/utils/ui.utils.js +330 -0
  46. package/dist/esm/core/utils/ui.utils.js.map +1 -0
  47. package/dist/esm/react/A11yDevtools.d.ts +5 -0
  48. package/dist/esm/react/A11yDevtools.js +8 -0
  49. package/dist/esm/react/A11yDevtools.js.map +1 -0
  50. package/dist/esm/react/index.d.ts +8 -0
  51. package/dist/esm/react/index.js +11 -0
  52. package/dist/esm/react/index.js.map +1 -0
  53. package/dist/esm/react/plugin.d.ts +12 -0
  54. package/dist/esm/react/plugin.js +11 -0
  55. package/dist/esm/react/plugin.js.map +1 -0
  56. package/dist/esm/react/production/A11yDevtools.d.ts +5 -0
  57. package/dist/esm/react/production/A11yDevtools.js +8 -0
  58. package/dist/esm/react/production/A11yDevtools.js.map +1 -0
  59. package/dist/esm/react/production/plugin.d.ts +7 -0
  60. package/dist/esm/react/production/plugin.js +11 -0
  61. package/dist/esm/react/production/plugin.js.map +1 -0
  62. package/dist/esm/react/production.d.ts +3 -0
  63. package/dist/esm/react/production.js +5 -0
  64. package/dist/esm/solid/A11yDevtools.d.ts +5 -0
  65. package/dist/esm/solid/A11yDevtools.js +8 -0
  66. package/dist/esm/solid/A11yDevtools.js.map +1 -0
  67. package/dist/esm/solid/index.d.ts +8 -0
  68. package/dist/esm/solid/index.js +9 -0
  69. package/dist/esm/solid/index.js.map +1 -0
  70. package/dist/esm/solid/plugin.d.ts +12 -0
  71. package/dist/esm/solid/plugin.js +11 -0
  72. package/dist/esm/solid/plugin.js.map +1 -0
  73. package/dist/esm/solid/production/A11yDevtools.d.ts +5 -0
  74. package/dist/esm/solid/production/A11yDevtools.js +8 -0
  75. package/dist/esm/solid/production/A11yDevtools.js.map +1 -0
  76. package/dist/esm/solid/production/plugin.d.ts +7 -0
  77. package/dist/esm/solid/production/plugin.js +11 -0
  78. package/dist/esm/solid/production/plugin.js.map +1 -0
  79. package/dist/esm/solid/production.d.ts +3 -0
  80. package/dist/esm/solid/production.js +3 -0
  81. package/package.json +110 -7
  82. package/src/core/components/IssueCard.tsx +75 -0
  83. package/src/core/components/IssueList.tsx +155 -0
  84. package/src/core/components/Settings.tsx +221 -0
  85. package/src/core/components/Shell.tsx +154 -0
  86. package/src/core/components/index.tsx +12 -0
  87. package/src/core/contexts/allyContext.tsx +118 -0
  88. package/src/core/core.tsx +11 -0
  89. package/src/core/index.ts +10 -0
  90. package/src/core/production.ts +5 -0
  91. package/src/core/styles/styles.ts +556 -0
  92. package/src/core/types/types.ts +177 -0
  93. package/src/core/utils/ally-audit.utils.ts +345 -0
  94. package/src/core/utils/config.utils.ts +68 -0
  95. package/src/core/utils/custom-audit.utils.ts +643 -0
  96. package/src/core/utils/export-audit.uitls.ts +180 -0
  97. package/src/core/utils/ui.utils.ts +483 -0
  98. package/src/react/A11yDevtools.ts +12 -0
  99. package/src/react/index.ts +16 -0
  100. package/src/react/plugin.ts +9 -0
  101. package/src/react/production/A11yDevtools.ts +11 -0
  102. package/src/react/production/plugin.ts +9 -0
  103. package/src/react/production.ts +7 -0
  104. package/src/solid/A11yDevtools.ts +11 -0
  105. package/src/solid/index.ts +14 -0
  106. package/src/solid/plugin.ts +9 -0
  107. package/src/solid/production/A11yDevtools.ts +10 -0
  108. package/src/solid/production/plugin.ts +9 -0
  109. package/src/solid/production.ts +5 -0
  110. package/README.md +0 -45
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 TanStack
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,10 @@
1
+ import { A11yIssue, SeverityThreshold } from '../types/types.js';
2
+ interface A11yIssueCardProps {
3
+ issue: A11yIssue;
4
+ impact: SeverityThreshold;
5
+ selected: boolean;
6
+ onSelect: () => void;
7
+ onDisableRule: (ruleId: string) => void;
8
+ }
9
+ export declare function A11yIssueCard(props: A11yIssueCardProps): import("solid-js").JSX.Element;
10
+ export {};
@@ -0,0 +1,83 @@
1
+ import { useStyles } from "../styles/styles.js";
2
+ import { addEventListener, classList, className, createComponent, delegateEvents, effect, getNextElement, getNextMarker, insert, runHydrationEvents, setAttribute, template } from "solid-js/web";
3
+ import { For, Show } from "solid-js";
4
+ import { Button } from "@tanstack/devtools-ui";
5
+ //#region src/core/components/IssueCard.tsx
6
+ /** @jsxImportSource solid-js */
7
+ var _tmpl$ = /* @__PURE__ */ template(`<div>`), _tmpl$2 = /* @__PURE__ */ template(`<div><div><div><div><span></span><span></span></div><p></p><div></div></div><div><a target=_blank rel="noopener noreferrer">Learn more</a><!$><!/></div></div><!$><!/>`), _tmpl$3 = /* @__PURE__ */ template(`<span>`);
8
+ function A11yIssueCard(props) {
9
+ const selector = () => props.issue.nodes[0]?.selector || "unknown";
10
+ const styles = useStyles();
11
+ return (() => {
12
+ var _el$ = getNextElement(_tmpl$2), _el$2 = _el$.firstChild, _el$3 = _el$2.firstChild, _el$4 = _el$3.firstChild, _el$5 = _el$4.firstChild, _el$6 = _el$5.nextSibling, _el$7 = _el$4.nextSibling, _el$8 = _el$7.nextSibling, _el$9 = _el$3.nextSibling, _el$0 = _el$9.firstChild, _el$1 = _el$0.nextSibling, [_el$10, _co$] = getNextMarker(_el$1.nextSibling), _el$12 = _el$2.nextSibling, [_el$13, _co$2] = getNextMarker(_el$12.nextSibling);
13
+ addEventListener(_el$, "click", props.onSelect, true);
14
+ insert(_el$6, () => props.issue.ruleId);
15
+ insert(_el$7, () => props.issue.message);
16
+ insert(_el$8, selector);
17
+ _el$0.$$click = (event) => event.stopPropagation();
18
+ insert(_el$9, createComponent(Button, {
19
+ variant: "secondary",
20
+ ghost: true,
21
+ onClick: (event) => {
22
+ event.stopPropagation();
23
+ props.onDisableRule(props.issue.ruleId);
24
+ },
25
+ children: "Disable rule"
26
+ }), _el$10, _co$);
27
+ insert(_el$, createComponent(Show, {
28
+ get when() {
29
+ return props.issue.wcagTags.length > 0;
30
+ },
31
+ get children() {
32
+ var _el$11 = getNextElement(_tmpl$);
33
+ insert(_el$11, createComponent(For, {
34
+ get each() {
35
+ return props.issue.wcagTags.slice(0, 3);
36
+ },
37
+ children: (tag) => (() => {
38
+ var _el$14 = getNextElement(_tmpl$3);
39
+ insert(_el$14, tag);
40
+ effect(() => className(_el$14, styles().tag));
41
+ return _el$14;
42
+ })()
43
+ }));
44
+ effect(() => className(_el$11, styles().tags));
45
+ return _el$11;
46
+ }
47
+ }), _el$13, _co$2);
48
+ effect((_p$) => {
49
+ var _v$ = styles().issueCard, _v$2 = { [styles().issueCardSelected]: props.selected }, _v$3 = styles().issueRow, _v$4 = styles().issueMain, _v$5 = styles().issueTitleRow, _v$6 = styles().dot(props.impact), _v$7 = styles().issueMessage, _v$8 = styles().selector, _v$9 = styles().issueAside, _v$0 = styles().helpLink, _v$1 = props.issue.helpUrl;
50
+ _v$ !== _p$.e && className(_el$, _p$.e = _v$);
51
+ _p$.t = classList(_el$, _v$2, _p$.t);
52
+ _v$3 !== _p$.a && className(_el$2, _p$.a = _v$3);
53
+ _v$4 !== _p$.o && className(_el$3, _p$.o = _v$4);
54
+ _v$5 !== _p$.i && className(_el$4, _p$.i = _v$5);
55
+ _v$6 !== _p$.n && className(_el$5, _p$.n = _v$6);
56
+ _v$7 !== _p$.s && className(_el$7, _p$.s = _v$7);
57
+ _v$8 !== _p$.h && className(_el$8, _p$.h = _v$8);
58
+ _v$9 !== _p$.r && className(_el$9, _p$.r = _v$9);
59
+ _v$0 !== _p$.d && className(_el$0, _p$.d = _v$0);
60
+ _v$1 !== _p$.l && setAttribute(_el$0, "href", _p$.l = _v$1);
61
+ return _p$;
62
+ }, {
63
+ e: void 0,
64
+ t: void 0,
65
+ a: void 0,
66
+ o: void 0,
67
+ i: void 0,
68
+ n: void 0,
69
+ s: void 0,
70
+ h: void 0,
71
+ r: void 0,
72
+ d: void 0,
73
+ l: void 0
74
+ });
75
+ runHydrationEvents();
76
+ return _el$;
77
+ })();
78
+ }
79
+ delegateEvents(["click"]);
80
+ //#endregion
81
+ export { A11yIssueCard };
82
+
83
+ //# sourceMappingURL=IssueCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IssueCard.js","names":["For","Show","Button","useStyles","A11yIssue","SeverityThreshold","A11yIssueCardProps","issue","impact","selected","onSelect","onDisableRule","ruleId","A11yIssueCard","props","selector","nodes","styles","_el$","_$getNextElement","_tmpl$2","_el$2","firstChild","_el$3","_el$4","_el$5","_el$6","nextSibling","_el$7","_el$8","_el$9","_el$0","_el$1","_el$10","_co$","_$getNextMarker","_el$12","_el$13","_co$2","_$addEventListener","_$insert","message","$$click","event","stopPropagation","_$createComponent","variant","ghost","onClick","MouseEvent","children","when","wcagTags","length","_el$11","_tmpl$","each","slice","tag","_el$14","_tmpl$3","_$effect","_$className","tags","_p$","_v$","issueCard","_v$2","issueCardSelected","_v$3","issueRow","_v$4","issueMain","_v$5","issueTitleRow","_v$6","dot","_v$7","issueMessage","_v$8","_v$9","issueAside","_v$0","helpLink","_v$1","helpUrl","e","t","_$classList","a","o","i","n","s","h","r","d","l","_$setAttribute","undefined","_$runHydrationEvents","_$delegateEvents"],"sources":["../../../../src/core/components/IssueCard.tsx"],"sourcesContent":["/** @jsxImportSource solid-js */\n\nimport { For, Show } from 'solid-js'\nimport { Button } from '@tanstack/devtools-ui'\nimport { useStyles } from '../styles/styles'\n\n// types\nimport type { A11yIssue, SeverityThreshold } from '../types/types'\n\ninterface A11yIssueCardProps {\n issue: A11yIssue\n impact: SeverityThreshold\n selected: boolean\n onSelect: () => void\n onDisableRule: (ruleId: string) => void\n}\n\nexport function A11yIssueCard(props: A11yIssueCardProps) {\n const selector = () => props.issue.nodes[0]?.selector || 'unknown'\n const styles = useStyles()\n\n return (\n <div\n class={styles().issueCard}\n classList={{\n [styles().issueCardSelected]: props.selected,\n }}\n onClick={props.onSelect}\n >\n <div class={styles().issueRow}>\n <div class={styles().issueMain}>\n <div class={styles().issueTitleRow}>\n <span class={styles().dot(props.impact)} />\n\n <span>{props.issue.ruleId}</span>\n </div>\n <p class={styles().issueMessage}>{props.issue.message}</p>\n\n <div class={styles().selector}>{selector()}</div>\n </div>\n\n <div class={styles().issueAside}>\n <a\n class={styles().helpLink}\n href={props.issue.helpUrl}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n onClick={(event) => event.stopPropagation()}\n >\n Learn more\n </a>\n\n <Button\n variant=\"secondary\"\n ghost\n onClick={(event: MouseEvent) => {\n event.stopPropagation()\n props.onDisableRule(props.issue.ruleId)\n }}\n >\n Disable rule\n </Button>\n </div>\n </div>\n\n <Show when={props.issue.wcagTags.length > 0}>\n <div class={styles().tags}>\n <For each={props.issue.wcagTags.slice(0, 3)}>\n {(tag) => <span class={styles().tag}>{tag}</span>}\n </For>\n </div>\n </Show>\n </div>\n )\n}\n"],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { Signal } from 'solid-js';
2
+ interface A11yIssueListProps {
3
+ selectedIssueSignal: Signal<string>;
4
+ }
5
+ export declare function A11yIssueList(props: A11yIssueListProps): import("solid-js").JSX.Element;
6
+ export {};
@@ -0,0 +1,134 @@
1
+ import { SEVERITY_LABELS, clearHighlights, highlightAllIssues, highlightElement, scrollToElement } from "../utils/ui.utils.js";
2
+ import { IMPACTS } from "../utils/ally-audit.utils.js";
3
+ import { useAllyContext } from "../contexts/allyContext.js";
4
+ import { useStyles } from "../styles/styles.js";
5
+ import { A11yIssueCard } from "./IssueCard.js";
6
+ import { classList, className, createComponent, delegateEvents, effect, getNextElement, getNextMarker, insert, runHydrationEvents, template } from "solid-js/web";
7
+ import { For, Show } from "solid-js";
8
+ //#region src/core/components/IssueList.tsx
9
+ /** @jsxImportSource solid-js */
10
+ var _tmpl$ = /* @__PURE__ */ template(`<div><div></div><!$><!/>`), _tmpl$2 = /* @__PURE__ */ template(`<button><div></div><div>`), _tmpl$3 = /* @__PURE__ */ template(`<div><h3><!$><!/> (<!$><!/>)</h3><!$><!/>`);
11
+ function A11yIssueList(props) {
12
+ const [selectedIssueId, setSelectedIssueId] = props.selectedIssueSignal;
13
+ const styles = useStyles();
14
+ const ally = useAllyContext();
15
+ const handleIssueClick = (issueId) => {
16
+ if (selectedIssueId() === issueId) {
17
+ setSelectedIssueId("");
18
+ clearHighlights();
19
+ if (ally.config.showOverlays && ally.allyResult.audit && ally.filteredIssues().length > 0) highlightAllIssues(ally.filteredIssues());
20
+ return;
21
+ }
22
+ setSelectedIssueId(issueId);
23
+ clearHighlights();
24
+ const issue = ally.allyResult.audit?.issues.find((i) => i.id === issueId);
25
+ if (!issue || issue.nodes.length === 0) return;
26
+ let scrolled = false;
27
+ for (const node of issue.nodes) {
28
+ const selector = node.selector;
29
+ if (!selector) continue;
30
+ try {
31
+ if (document.querySelector(selector)) {
32
+ if (!scrolled) {
33
+ scrollToElement(selector);
34
+ scrolled = true;
35
+ }
36
+ highlightElement(selector, issue.impact, {
37
+ showTooltip: true,
38
+ ruleId: issue.ruleId
39
+ });
40
+ }
41
+ } catch (error) {
42
+ console.warn("[A11y Panel] Invalid selector:", selector, error);
43
+ }
44
+ }
45
+ };
46
+ return (() => {
47
+ var _el$ = getNextElement(_tmpl$), _el$2 = _el$.firstChild, _el$3 = _el$2.nextSibling, [_el$4, _co$] = getNextMarker(_el$3.nextSibling);
48
+ insert(_el$2, createComponent(For, {
49
+ each: IMPACTS,
50
+ children: (impact) => {
51
+ const issuesForImpact = () => ally.filteredIssues().filter((issue) => issue.impact === impact);
52
+ const count = () => issuesForImpact().length || 0;
53
+ const active = () => ally.impactKey() === impact;
54
+ return (() => {
55
+ var _el$5 = getNextElement(_tmpl$2), _el$6 = _el$5.firstChild, _el$7 = _el$6.nextSibling;
56
+ _el$5.$$click = () => {
57
+ ally.setImpactKey(ally.impactKey() === impact ? "all" : impact);
58
+ setSelectedIssueId("");
59
+ };
60
+ insert(_el$6, count);
61
+ insert(_el$7, () => SEVERITY_LABELS[impact]);
62
+ effect((_p$) => {
63
+ var _v$ = styles().summaryButton, _v$2 = { [styles().summaryButtonActive(impact)]: active() }, _v$3 = styles().summaryCount(impact), _v$4 = styles().summaryLabel;
64
+ _v$ !== _p$.e && className(_el$5, _p$.e = _v$);
65
+ _p$.t = classList(_el$5, _v$2, _p$.t);
66
+ _v$3 !== _p$.a && className(_el$6, _p$.a = _v$3);
67
+ _v$4 !== _p$.o && className(_el$7, _p$.o = _v$4);
68
+ return _p$;
69
+ }, {
70
+ e: void 0,
71
+ t: void 0,
72
+ a: void 0,
73
+ o: void 0
74
+ });
75
+ runHydrationEvents();
76
+ return _el$5;
77
+ })();
78
+ }
79
+ }));
80
+ insert(_el$, createComponent(For, {
81
+ each: IMPACTS,
82
+ children: (impact) => {
83
+ const issues = () => ally.filteredIssues().filter((issue) => issue.impact === impact);
84
+ const shouldRender = () => {
85
+ if (ally.impactKey() !== "all") return ally.impactKey() === impact;
86
+ return issues().length > 0;
87
+ };
88
+ return createComponent(Show, {
89
+ get when() {
90
+ return shouldRender();
91
+ },
92
+ get children() {
93
+ var _el$8 = getNextElement(_tmpl$3), _el$9 = _el$8.firstChild, _el$10 = _el$9.firstChild, [_el$11, _co$2] = getNextMarker(_el$10.nextSibling), _el$12 = _el$11.nextSibling.nextSibling, [_el$13, _co$3] = getNextMarker(_el$12.nextSibling);
94
+ _el$13.nextSibling;
95
+ var _el$14 = _el$9.nextSibling, [_el$15, _co$4] = getNextMarker(_el$14.nextSibling);
96
+ insert(_el$9, () => SEVERITY_LABELS[impact], _el$11, _co$2);
97
+ insert(_el$9, () => issues().length, _el$13, _co$3);
98
+ insert(_el$8, createComponent(For, {
99
+ get each() {
100
+ return issues();
101
+ },
102
+ children: (issue) => createComponent(A11yIssueCard, {
103
+ issue,
104
+ impact,
105
+ get selected() {
106
+ return selectedIssueId() === issue.id;
107
+ },
108
+ onSelect: () => handleIssueClick(issue.id),
109
+ onDisableRule: () => ally.setConfig("disabledRules", [...ally.config.disabledRules, issue.ruleId])
110
+ })
111
+ }), _el$15, _co$4);
112
+ effect((_p$) => {
113
+ var _v$5 = styles().section, _v$6 = styles().sectionTitle(impact);
114
+ _v$5 !== _p$.e && className(_el$8, _p$.e = _v$5);
115
+ _v$6 !== _p$.t && className(_el$9, _p$.t = _v$6);
116
+ return _p$;
117
+ }, {
118
+ e: void 0,
119
+ t: void 0
120
+ });
121
+ return _el$8;
122
+ }
123
+ });
124
+ }
125
+ }), _el$4, _co$);
126
+ effect(() => className(_el$2, styles().summaryGrid));
127
+ return _el$;
128
+ })();
129
+ }
130
+ delegateEvents(["click"]);
131
+ //#endregion
132
+ export { A11yIssueList };
133
+
134
+ //# sourceMappingURL=IssueList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IssueList.js","names":["For","Show","useAllyContext","SEVERITY_LABELS","clearHighlights","highlightAllIssues","highlightElement","scrollToElement","IMPACTS","useStyles","A11yIssueCard","Signal","A11yIssueListProps","selectedIssueSignal","A11yIssueList","props","selectedIssueId","setSelectedIssueId","styles","ally","handleIssueClick","issueId","config","showOverlays","allyResult","audit","filteredIssues","length","issue","issues","find","i","id","nodes","scrolled","node","selector","el","document","querySelector","impact","showTooltip","ruleId","error","console","warn","_el$","_$getNextElement","_tmpl$","_el$2","firstChild","_el$3","nextSibling","_el$4","_co$","_$getNextMarker","_$insert","_$createComponent","each","children","issuesForImpact","filter","count","active","impactKey","_el$5","_tmpl$2","_el$6","_el$7","$$click","setImpactKey","_$effect","_p$","_v$","summaryButton","_v$2","summaryButtonActive","_v$3","summaryCount","_v$4","summaryLabel","e","_$className","t","_$classList","a","o","undefined","_$runHydrationEvents","shouldRender","when","_el$8","_tmpl$3","_el$9","_el$10","_el$11","_co$2","_el$0","_el$12","_el$13","_co$3","_el$1","_el$14","_el$15","_co$4","selected","onSelect","onDisableRule","setConfig","disabledRules","_v$5","section","_v$6","sectionTitle","summaryGrid","_$delegateEvents"],"sources":["../../../../src/core/components/IssueList.tsx"],"sourcesContent":["/** @jsxImportSource solid-js */\n\nimport { For, Show } from 'solid-js'\nimport { useAllyContext } from '../contexts/allyContext'\nimport {\n SEVERITY_LABELS,\n clearHighlights,\n highlightAllIssues,\n highlightElement,\n scrollToElement,\n} from '../utils/ui.utils'\nimport { IMPACTS } from '../utils/ally-audit.utils'\nimport { useStyles } from '../styles/styles'\nimport { A11yIssueCard } from './IssueCard'\n\n// types\nimport type { Signal } from 'solid-js'\n\ninterface A11yIssueListProps {\n selectedIssueSignal: Signal<string>\n}\n\nexport function A11yIssueList(props: A11yIssueListProps) {\n const [selectedIssueId, setSelectedIssueId] = props.selectedIssueSignal\n\n // hooks\n const styles = useStyles()\n const ally = useAllyContext()\n\n // handlers\n const handleIssueClick = (issueId: string) => {\n if (selectedIssueId() === issueId) {\n setSelectedIssueId('')\n clearHighlights()\n\n if (\n ally.config.showOverlays &&\n ally.allyResult.audit &&\n ally.filteredIssues().length > 0\n ) {\n highlightAllIssues(ally.filteredIssues())\n }\n\n return\n }\n\n setSelectedIssueId(issueId)\n clearHighlights()\n\n const issue = ally.allyResult.audit?.issues.find((i) => i.id === issueId)\n if (!issue || issue.nodes.length === 0) return\n\n let scrolled = false\n for (const node of issue.nodes) {\n const selector = node.selector\n if (!selector) continue\n\n try {\n const el = document.querySelector(selector)\n if (el) {\n if (!scrolled) {\n scrollToElement(selector)\n scrolled = true\n }\n\n highlightElement(selector, issue.impact, {\n showTooltip: true,\n ruleId: issue.ruleId,\n })\n }\n } catch (error) {\n console.warn('[A11y Panel] Invalid selector:', selector, error)\n }\n }\n }\n\n return (\n <div>\n <div class={styles().summaryGrid}>\n <For each={IMPACTS}>\n {(impact) => {\n // Count issues from the reactive filteredIssues memo so counts update when config.threshold changes\n const issuesForImpact = () =>\n ally.filteredIssues().filter((issue) => issue.impact === impact)\n const count = () => issuesForImpact().length || 0\n\n const active = () => ally.impactKey() === impact\n\n return (\n <button\n class={styles().summaryButton}\n classList={{\n [styles().summaryButtonActive(impact)]: active(),\n }}\n onClick={() => {\n ally.setImpactKey(\n ally.impactKey() === impact ? 'all' : impact,\n )\n\n setSelectedIssueId('')\n }}\n >\n <div class={styles().summaryCount(impact)}>{count()}</div>\n <div class={styles().summaryLabel}>\n {SEVERITY_LABELS[impact]}\n </div>\n </button>\n )\n }}\n </For>\n </div>\n\n <For each={IMPACTS}>\n {(impact) => {\n const issues = () =>\n ally.filteredIssues().filter((issue) => issue.impact === impact)\n\n const shouldRender = () => {\n if (ally.impactKey() !== 'all') {\n return ally.impactKey() === impact\n }\n return issues().length > 0\n }\n\n return (\n <Show when={shouldRender()}>\n <div class={styles().section}>\n <h3 class={styles().sectionTitle(impact)}>\n {SEVERITY_LABELS[impact]} ({issues().length})\n </h3>\n\n <For each={issues()}>\n {(issue) => (\n <A11yIssueCard\n issue={issue}\n impact={impact}\n selected={selectedIssueId() === issue.id}\n onSelect={() => handleIssueClick(issue.id)}\n onDisableRule={() =>\n ally.setConfig('disabledRules', [\n ...ally.config.disabledRules,\n issue.ruleId,\n ])\n }\n />\n )}\n </For>\n </div>\n </Show>\n )\n }}\n </For>\n </div>\n )\n}\n"],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /** @jsxImportSource solid-js */
2
+ interface A11ySettingsOverlayProps {
3
+ onClose: () => void;
4
+ }
5
+ export declare function A11ySettingsOverlay(props: A11ySettingsOverlayProps): import("solid-js").JSX.Element;
6
+ export {};
@@ -0,0 +1,251 @@
1
+ import { getAvailableRules } from "../utils/ally-audit.utils.js";
2
+ import { useAllyContext } from "../contexts/allyContext.js";
3
+ import { CATEGORIES, CATEGORY_LABELS, useStyles } from "../styles/styles.js";
4
+ import { classList, className, createComponent, effect, getNextElement, getNextMarker, insert, setProperty, template } from "solid-js/web";
5
+ import { For, Show, createMemo, createSignal } from "solid-js";
6
+ import { Button, Input, Select } from "@tanstack/devtools-ui";
7
+ //#region src/core/components/Settings.tsx
8
+ /** @jsxImportSource solid-js */
9
+ var _tmpl$ = /* @__PURE__ */ template(`<div><div><h3>Settings</h3><!$><!/></div><div><div><h4>General</h4><div><!$><!/><!$><!/></div></div><div><div><h4>Rules (<!$><!/> total, <!$><!/> disabled)</h4><div><!$><!/><!$><!/></div></div><div><!$><!/><!$><!/></div><div>`), _tmpl$2 = /* @__PURE__ */ template(`<span title="Best Practice only">BP`), _tmpl$3 = /* @__PURE__ */ template(`<label><input type=checkbox><div><div><span></span><!$><!/></div><div></div><!$><!/>`), _tmpl$4 = /* @__PURE__ */ template(`<div><span>`);
10
+ function A11ySettingsOverlay(props) {
11
+ const { config, setConfig } = useAllyContext();
12
+ const styles = useStyles();
13
+ const disabledRulesSet = createMemo(() => new Set(config.disabledRules));
14
+ const availableRules = createMemo(() => getAvailableRules());
15
+ const [searchString, setSearchString] = createSignal("");
16
+ const [searchCategory, setSearchCategory] = createSignal("all");
17
+ const filteredRules = createMemo(() => {
18
+ const cat = searchCategory();
19
+ const query = searchString().toLowerCase();
20
+ return availableRules().filter((rule) => {
21
+ if (cat !== "all" && !rule.tags.includes(cat)) return false;
22
+ if (!query) return true;
23
+ return rule.id.toLowerCase().includes(query) || rule.description.toLowerCase().includes(query);
24
+ });
25
+ });
26
+ return (() => {
27
+ var _el$ = getNextElement(_tmpl$), _el$2 = _el$.firstChild, _el$3 = _el$2.firstChild, _el$4 = _el$3.nextSibling, [_el$5, _co$] = getNextMarker(_el$4.nextSibling), _el$6 = _el$2.nextSibling, _el$7 = _el$6.firstChild, _el$8 = _el$7.firstChild, _el$9 = _el$8.nextSibling, _el$0 = _el$9.firstChild, [_el$1, _co$2] = getNextMarker(_el$0.nextSibling), _el$10 = _el$1.nextSibling, [_el$11, _co$3] = getNextMarker(_el$10.nextSibling), _el$13 = _el$7.nextSibling.firstChild, _el$14 = _el$13.firstChild, _el$19 = _el$14.firstChild.nextSibling, [_el$20, _co$4] = getNextMarker(_el$19.nextSibling), _el$21 = _el$20.nextSibling.nextSibling, [_el$22, _co$5] = getNextMarker(_el$21.nextSibling);
28
+ _el$22.nextSibling;
29
+ var _el$23 = _el$14.nextSibling, _el$24 = _el$23.firstChild, [_el$25, _co$6] = getNextMarker(_el$24.nextSibling), _el$26 = _el$25.nextSibling, [_el$27, _co$7] = getNextMarker(_el$26.nextSibling), _el$28 = _el$13.nextSibling, _el$29 = _el$28.firstChild, [_el$30, _co$8] = getNextMarker(_el$29.nextSibling), _el$31 = _el$30.nextSibling, [_el$32, _co$9] = getNextMarker(_el$31.nextSibling), _el$33 = _el$28.nextSibling;
30
+ insert(_el$2, createComponent(Button, {
31
+ variant: "secondary",
32
+ outline: true,
33
+ get onClick() {
34
+ return props.onClose;
35
+ },
36
+ children: "Done"
37
+ }), _el$5, _co$);
38
+ insert(_el$9, createComponent(Select, {
39
+ label: "Severity Threshold",
40
+ description: "Only show issues at or above this level",
41
+ get value() {
42
+ return config.threshold;
43
+ },
44
+ options: [
45
+ {
46
+ value: "critical",
47
+ label: "Critical"
48
+ },
49
+ {
50
+ value: "serious",
51
+ label: "Serious"
52
+ },
53
+ {
54
+ value: "moderate",
55
+ label: "Moderate"
56
+ },
57
+ {
58
+ value: "minor",
59
+ label: "Minor"
60
+ }
61
+ ],
62
+ onChange: (value) => {
63
+ setConfig("threshold", value);
64
+ }
65
+ }), _el$1, _co$2);
66
+ insert(_el$9, createComponent(Select, {
67
+ label: "Rule Set",
68
+ description: "WCAG conformance level or standard",
69
+ get value() {
70
+ return config.ruleSet;
71
+ },
72
+ options: [
73
+ {
74
+ value: "wcag2a",
75
+ label: "WCAG 2.0 A"
76
+ },
77
+ {
78
+ value: "wcag2aa",
79
+ label: "WCAG 2.0 AA"
80
+ },
81
+ {
82
+ value: "wcag21aa",
83
+ label: "WCAG 2.1 AA"
84
+ },
85
+ {
86
+ value: "wcag22aa",
87
+ label: "WCAG 2.2 AA"
88
+ },
89
+ {
90
+ value: "section508",
91
+ label: "Section 508"
92
+ },
93
+ {
94
+ value: "best-practice",
95
+ label: "Best Practice"
96
+ },
97
+ {
98
+ value: "all",
99
+ label: "All Rules"
100
+ }
101
+ ],
102
+ onChange: (value) => {
103
+ setConfig("ruleSet", value);
104
+ }
105
+ }), _el$11, _co$3);
106
+ insert(_el$14, () => availableRules().length, _el$20, _co$4);
107
+ insert(_el$14, () => config.disabledRules.length, _el$22, _co$5);
108
+ insert(_el$23, createComponent(Button, {
109
+ variant: "success",
110
+ outline: true,
111
+ onClick: () => setConfig("disabledRules", []),
112
+ children: "Enable All"
113
+ }), _el$25, _co$6);
114
+ insert(_el$23, createComponent(Button, {
115
+ variant: "danger",
116
+ outline: true,
117
+ onClick: () => setConfig("disabledRules", availableRules().map((rule) => rule.id)),
118
+ children: "Disable All"
119
+ }), _el$27, _co$7);
120
+ insert(_el$28, createComponent(Select, {
121
+ label: "Category",
122
+ get value() {
123
+ return searchCategory();
124
+ },
125
+ get options() {
126
+ return CATEGORIES.map((cat) => ({
127
+ value: cat,
128
+ label: CATEGORY_LABELS[cat]
129
+ }));
130
+ },
131
+ onChange: (value) => setSearchCategory(value)
132
+ }), _el$30, _co$8);
133
+ insert(_el$28, createComponent(Input, {
134
+ label: "Search",
135
+ placeholder: "Search rules...",
136
+ get value() {
137
+ return searchString();
138
+ },
139
+ onChange: (value) => setSearchString(value)
140
+ }), _el$32, _co$9);
141
+ insert(_el$33, createComponent(For, {
142
+ get each() {
143
+ return filteredRules();
144
+ },
145
+ children: (rule, idx) => {
146
+ const isDisabled = () => disabledRulesSet().has(rule.id);
147
+ const isBestPracticeOnly = () => rule.tags.includes("best-practice") && !rule.tags.some((tag) => tag.startsWith("wcag") || tag.startsWith("section508"));
148
+ const categoryTag = () => rule.tags.find((tag) => tag.startsWith("cat."));
149
+ const hasBorder = () => idx() < filteredRules().length - 1;
150
+ return (() => {
151
+ var _el$34 = getNextElement(_tmpl$3), _el$35 = _el$34.firstChild, _el$36 = _el$35.nextSibling, _el$37 = _el$36.firstChild, _el$38 = _el$37.firstChild, _el$40 = _el$38.nextSibling, [_el$41, _co$0] = getNextMarker(_el$40.nextSibling), _el$42 = _el$37.nextSibling, _el$43 = _el$42.nextSibling, [_el$44, _co$1] = getNextMarker(_el$43.nextSibling);
152
+ _el$35.addEventListener("change", () => setConfig("disabledRules", (rules) => {
153
+ if (disabledRulesSet().has(rule.id)) return rules.filter((id) => id !== rule.id);
154
+ else return [...rules, rule.id];
155
+ }));
156
+ insert(_el$38, () => rule.id);
157
+ insert(_el$37, createComponent(Show, {
158
+ get when() {
159
+ return isBestPracticeOnly();
160
+ },
161
+ get children() {
162
+ var _el$39 = getNextElement(_tmpl$2);
163
+ effect(() => className(_el$39, styles().bpBadge));
164
+ return _el$39;
165
+ }
166
+ }), _el$41, _co$0);
167
+ insert(_el$42, () => rule.description);
168
+ insert(_el$36, createComponent(Show, {
169
+ get when() {
170
+ return categoryTag();
171
+ },
172
+ children: (tag) => (() => {
173
+ var _el$45 = getNextElement(_tmpl$4), _el$46 = _el$45.firstChild;
174
+ insert(_el$46, () => CATEGORY_LABELS[tag()] || tag().replace("cat.", ""));
175
+ effect((_p$) => {
176
+ var _v$19 = styles().catTagRow, _v$20 = styles().catTag;
177
+ _v$19 !== _p$.e && className(_el$45, _p$.e = _v$19);
178
+ _v$20 !== _p$.t && className(_el$46, _p$.t = _v$20);
179
+ return _p$;
180
+ }, {
181
+ e: void 0,
182
+ t: void 0
183
+ });
184
+ return _el$45;
185
+ })()
186
+ }), _el$44, _co$1);
187
+ effect((_p$) => {
188
+ var _v$11 = styles().ruleRow, _v$12 = {
189
+ [styles().ruleRowDisabled]: isDisabled(),
190
+ [styles().ruleRowBorder]: hasBorder()
191
+ }, _v$13 = styles().ruleCheckbox, _v$14 = styles().ruleInfo, _v$15 = styles().ruleTop, _v$16 = styles().ruleId, _v$17 = { [styles().ruleIdDisabled]: isDisabled() }, _v$18 = styles().ruleDesc;
192
+ _v$11 !== _p$.e && className(_el$34, _p$.e = _v$11);
193
+ _p$.t = classList(_el$34, _v$12, _p$.t);
194
+ _v$13 !== _p$.a && className(_el$35, _p$.a = _v$13);
195
+ _v$14 !== _p$.o && className(_el$36, _p$.o = _v$14);
196
+ _v$15 !== _p$.i && className(_el$37, _p$.i = _v$15);
197
+ _v$16 !== _p$.n && className(_el$38, _p$.n = _v$16);
198
+ _p$.s = classList(_el$38, _v$17, _p$.s);
199
+ _v$18 !== _p$.h && className(_el$42, _p$.h = _v$18);
200
+ return _p$;
201
+ }, {
202
+ e: void 0,
203
+ t: void 0,
204
+ a: void 0,
205
+ o: void 0,
206
+ i: void 0,
207
+ n: void 0,
208
+ s: void 0,
209
+ h: void 0
210
+ });
211
+ effect(() => setProperty(_el$35, "checked", !isDisabled()));
212
+ return _el$34;
213
+ })();
214
+ }
215
+ }));
216
+ effect((_p$) => {
217
+ var _v$ = styles().settingsOverlay, _v$2 = styles().settingsHeader, _v$3 = styles().settingsTitle, _v$4 = styles().settingsContent, _v$5 = styles().settingsSection, _v$6 = styles().settingsSectionLabel, _v$7 = styles().settingsRowStack, _v$8 = styles().rulesHeaderRow, _v$9 = styles().settingsSectionLabel, _v$0 = styles().rulesHeaderActions, _v$1 = styles().filtersRow, _v$10 = styles().rulesList;
218
+ _v$ !== _p$.e && className(_el$, _p$.e = _v$);
219
+ _v$2 !== _p$.t && className(_el$2, _p$.t = _v$2);
220
+ _v$3 !== _p$.a && className(_el$3, _p$.a = _v$3);
221
+ _v$4 !== _p$.o && className(_el$6, _p$.o = _v$4);
222
+ _v$5 !== _p$.i && className(_el$7, _p$.i = _v$5);
223
+ _v$6 !== _p$.n && className(_el$8, _p$.n = _v$6);
224
+ _v$7 !== _p$.s && className(_el$9, _p$.s = _v$7);
225
+ _v$8 !== _p$.h && className(_el$13, _p$.h = _v$8);
226
+ _v$9 !== _p$.r && className(_el$14, _p$.r = _v$9);
227
+ _v$0 !== _p$.d && className(_el$23, _p$.d = _v$0);
228
+ _v$1 !== _p$.l && className(_el$28, _p$.l = _v$1);
229
+ _v$10 !== _p$.u && className(_el$33, _p$.u = _v$10);
230
+ return _p$;
231
+ }, {
232
+ e: void 0,
233
+ t: void 0,
234
+ a: void 0,
235
+ o: void 0,
236
+ i: void 0,
237
+ n: void 0,
238
+ s: void 0,
239
+ h: void 0,
240
+ r: void 0,
241
+ d: void 0,
242
+ l: void 0,
243
+ u: void 0
244
+ });
245
+ return _el$;
246
+ })();
247
+ }
248
+ //#endregion
249
+ export { A11ySettingsOverlay };
250
+
251
+ //# sourceMappingURL=Settings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Settings.js","names":["For","Show","createMemo","createSignal","Button","Input","Select","getAvailableRules","useAllyContext","CATEGORIES","CATEGORY_LABELS","useStyles","RuleCategory","RuleSetPreset","SeverityThreshold","A11ySettingsOverlayProps","onClose","A11ySettingsOverlay","props","config","setConfig","styles","disabledRulesSet","Set","disabledRules","availableRules","searchString","setSearchString","searchCategory","setSearchCategory","filteredRules","cat","query","toLowerCase","filter","rule","tags","includes","id","description","_el$","_$getNextElement","_tmpl$","_el$2","firstChild","_el$3","_el$4","nextSibling","_el$5","_co$","_$getNextMarker","_el$6","_el$7","_el$8","_el$9","_el$0","_el$1","_co$2","_el$10","_el$11","_co$3","_el$12","_el$13","_el$14","_el$15","_el$19","_el$20","_co$4","_el$16","_el$21","_el$22","_co$5","_el$18","_el$23","_el$24","_el$25","_co$6","_el$26","_el$27","_co$7","_el$28","_el$29","_el$30","_co$8","_el$31","_el$32","_co$9","_el$33","_$insert","_$createComponent","variant","outline","onClick","children","label","value","threshold","options","onChange","ruleSet","length","map","placeholder","each","idx","isDisabled","has","isBestPracticeOnly","some","tag","startsWith","categoryTag","find","hasBorder","_el$34","_tmpl$3","_el$35","_el$36","_el$37","_el$38","_el$40","_el$41","_co$0","_el$42","_el$43","_el$44","_co$1","addEventListener","rules","when","_el$39","_tmpl$2","_$effect","_$className","bpBadge","_el$45","_tmpl$4","_el$46","replace","_p$","_v$19","catTagRow","_v$20","catTag","e","t","undefined","_v$11","ruleRow","_v$12","ruleRowDisabled","ruleRowBorder","_v$13","ruleCheckbox","_v$14","ruleInfo","_v$15","ruleTop","_v$16","ruleId","_v$17","ruleIdDisabled","_v$18","ruleDesc","_$classList","a","o","i","n","s","h","_$setProperty","_v$","settingsOverlay","_v$2","settingsHeader","_v$3","settingsTitle","_v$4","settingsContent","_v$5","settingsSection","_v$6","settingsSectionLabel","_v$7","settingsRowStack","_v$8","rulesHeaderRow","_v$9","_v$0","rulesHeaderActions","_v$1","filtersRow","_v$10","rulesList","r","d","l","u"],"sources":["../../../../src/core/components/Settings.tsx"],"sourcesContent":["/** @jsxImportSource solid-js */\n\nimport { For, Show, createMemo, createSignal } from 'solid-js'\nimport { Button, Input, Select } from '@tanstack/devtools-ui'\nimport { getAvailableRules } from '../utils/ally-audit.utils'\nimport { useAllyContext } from '../contexts/allyContext'\nimport { CATEGORIES, CATEGORY_LABELS, useStyles } from '../styles/styles'\n\n// types\nimport type {\n RuleCategory,\n RuleSetPreset,\n SeverityThreshold,\n} from '../types/types'\n\ninterface A11ySettingsOverlayProps {\n onClose: () => void\n}\n\nexport function A11ySettingsOverlay(props: A11ySettingsOverlayProps) {\n const { config, setConfig } = useAllyContext()\n const styles = useStyles()\n\n const disabledRulesSet = createMemo(() => new Set(config.disabledRules))\n const availableRules = createMemo(() => getAvailableRules())\n\n const [searchString, setSearchString] = createSignal('')\n const [searchCategory, setSearchCategory] = createSignal<RuleCategory>('all')\n\n const filteredRules = createMemo(() => {\n const cat = searchCategory()\n const query = searchString().toLowerCase()\n return availableRules().filter((rule) => {\n if (cat !== 'all' && !rule.tags.includes(cat)) {\n return false\n }\n\n if (!query) return true\n return (\n rule.id.toLowerCase().includes(query) ||\n rule.description.toLowerCase().includes(query)\n )\n })\n })\n\n return (\n <div class={styles().settingsOverlay}>\n <div class={styles().settingsHeader}>\n <h3 class={styles().settingsTitle}>Settings</h3>\n <Button variant=\"secondary\" outline onClick={props.onClose}>\n Done\n </Button>\n </div>\n\n <div class={styles().settingsContent}>\n <div class={styles().settingsSection}>\n <h4 class={styles().settingsSectionLabel}>General</h4>\n <div class={styles().settingsRowStack}>\n <Select<SeverityThreshold>\n label=\"Severity Threshold\"\n description=\"Only show issues at or above this level\"\n value={config.threshold}\n options={[\n { value: 'critical', label: 'Critical' },\n { value: 'serious', label: 'Serious' },\n { value: 'moderate', label: 'Moderate' },\n { value: 'minor', label: 'Minor' },\n ]}\n onChange={(value: string) => {\n setConfig('threshold', value as SeverityThreshold)\n }}\n />\n <Select<RuleSetPreset>\n label=\"Rule Set\"\n description=\"WCAG conformance level or standard\"\n value={config.ruleSet}\n options={[\n { value: 'wcag2a', label: 'WCAG 2.0 A' },\n { value: 'wcag2aa', label: 'WCAG 2.0 AA' },\n { value: 'wcag21aa', label: 'WCAG 2.1 AA' },\n { value: 'wcag22aa', label: 'WCAG 2.2 AA' },\n { value: 'section508', label: 'Section 508' },\n { value: 'best-practice', label: 'Best Practice' },\n { value: 'all', label: 'All Rules' },\n ]}\n onChange={(value: string) => {\n setConfig('ruleSet', value as RuleSetPreset)\n }}\n />\n </div>\n </div>\n\n <div>\n <div class={styles().rulesHeaderRow}>\n <h4 class={styles().settingsSectionLabel}>\n Rules ({availableRules().length} total,{' '}\n {config.disabledRules.length} disabled)\n </h4>\n\n <div class={styles().rulesHeaderActions}>\n <Button\n variant=\"success\"\n outline\n onClick={() => setConfig('disabledRules', [])}\n >\n Enable All\n </Button>\n\n <Button\n variant=\"danger\"\n outline\n onClick={() =>\n setConfig(\n 'disabledRules',\n availableRules().map((rule) => rule.id),\n )\n }\n >\n Disable All\n </Button>\n </div>\n </div>\n\n <div class={styles().filtersRow}>\n <Select<RuleCategory>\n label=\"Category\"\n value={searchCategory()}\n options={CATEGORIES.map((cat) => ({\n value: cat,\n label: CATEGORY_LABELS[cat],\n }))}\n onChange={(value: string) =>\n setSearchCategory(value as RuleCategory)\n }\n />\n\n <Input\n label=\"Search\"\n placeholder=\"Search rules...\"\n value={searchString()}\n onChange={(value: string) => setSearchString(value)}\n />\n </div>\n\n <div class={styles().rulesList}>\n <For each={filteredRules()}>\n {(rule, idx) => {\n const isDisabled = () => disabledRulesSet().has(rule.id)\n const isBestPracticeOnly = () =>\n rule.tags.includes('best-practice') &&\n !rule.tags.some(\n (tag) =>\n tag.startsWith('wcag') || tag.startsWith('section508'),\n )\n const categoryTag = () =>\n rule.tags.find((tag) => tag.startsWith('cat.'))\n const hasBorder = () => idx() < filteredRules().length - 1\n\n return (\n <label\n class={styles().ruleRow}\n classList={{\n [styles().ruleRowDisabled]: isDisabled(),\n [styles().ruleRowBorder]: hasBorder(),\n }}\n >\n <input\n class={styles().ruleCheckbox}\n type=\"checkbox\"\n checked={!isDisabled()}\n onChange={() =>\n setConfig('disabledRules', (rules) => {\n if (disabledRulesSet().has(rule.id)) {\n return rules.filter((id) => id !== rule.id)\n } else {\n return [...rules, rule.id]\n }\n })\n }\n />\n <div class={styles().ruleInfo}>\n <div class={styles().ruleTop}>\n <span\n class={styles().ruleId}\n classList={{\n [styles().ruleIdDisabled]: isDisabled(),\n }}\n >\n {rule.id}\n </span>\n <Show when={isBestPracticeOnly()}>\n <span\n class={styles().bpBadge}\n title=\"Best Practice only\"\n >\n BP\n </span>\n </Show>\n </div>\n <div class={styles().ruleDesc}>{rule.description}</div>\n <Show when={categoryTag()}>\n {(tag) => (\n <div class={styles().catTagRow}>\n <span class={styles().catTag}>\n {CATEGORY_LABELS[tag() as RuleCategory] ||\n tag().replace('cat.', '')}\n </span>\n </div>\n )}\n </Show>\n </div>\n </label>\n )\n }}\n </For>\n </div>\n </div>\n </div>\n </div>\n )\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ /** @jsxImportSource solid-js */
2
+ export declare function Shell(): import("solid-js").JSX.Element;