@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.
- package/LICENSE +21 -0
- package/dist/esm/core/components/IssueCard.d.ts +10 -0
- package/dist/esm/core/components/IssueCard.js +83 -0
- package/dist/esm/core/components/IssueCard.js.map +1 -0
- package/dist/esm/core/components/IssueList.d.ts +6 -0
- package/dist/esm/core/components/IssueList.js +134 -0
- package/dist/esm/core/components/IssueList.js.map +1 -0
- package/dist/esm/core/components/Settings.d.ts +6 -0
- package/dist/esm/core/components/Settings.js +251 -0
- package/dist/esm/core/components/Settings.js.map +1 -0
- package/dist/esm/core/components/Shell.d.ts +2 -0
- package/dist/esm/core/components/Shell.js +214 -0
- package/dist/esm/core/components/Shell.js.map +1 -0
- package/dist/esm/core/components/index.d.ts +2 -0
- package/dist/esm/core/components/index.js +14 -0
- package/dist/esm/core/components/index.js.map +1 -0
- package/dist/esm/core/contexts/allyContext.d.ts +17 -0
- package/dist/esm/core/contexts/allyContext.js +66 -0
- package/dist/esm/core/contexts/allyContext.js.map +1 -0
- package/dist/esm/core/core.d.ts +19 -0
- package/dist/esm/core/core.js +8 -0
- package/dist/esm/core/core.js.map +1 -0
- package/dist/esm/core/index.d.ts +9 -0
- package/dist/esm/core/index.js +9 -0
- package/dist/esm/core/index.js.map +1 -0
- package/dist/esm/core/production.d.ts +2 -0
- package/dist/esm/core/production.js +4 -0
- package/dist/esm/core/styles/styles.d.ts +85 -0
- package/dist/esm/core/styles/styles.js +547 -0
- package/dist/esm/core/styles/styles.js.map +1 -0
- package/dist/esm/core/types/types.d.ts +141 -0
- package/dist/esm/core/utils/ally-audit.utils.d.ts +19 -0
- package/dist/esm/core/utils/ally-audit.utils.js +226 -0
- package/dist/esm/core/utils/ally-audit.utils.js.map +1 -0
- package/dist/esm/core/utils/config.utils.d.ts +17 -0
- package/dist/esm/core/utils/config.utils.js +63 -0
- package/dist/esm/core/utils/config.utils.js.map +1 -0
- package/dist/esm/core/utils/custom-audit.utils.d.ts +13 -0
- package/dist/esm/core/utils/custom-audit.utils.js +426 -0
- package/dist/esm/core/utils/custom-audit.utils.js.map +1 -0
- package/dist/esm/core/utils/export-audit.uitls.d.ts +17 -0
- package/dist/esm/core/utils/export-audit.uitls.js +83 -0
- package/dist/esm/core/utils/export-audit.uitls.js.map +1 -0
- package/dist/esm/core/utils/ui.utils.d.ts +24 -0
- package/dist/esm/core/utils/ui.utils.js +330 -0
- package/dist/esm/core/utils/ui.utils.js.map +1 -0
- package/dist/esm/react/A11yDevtools.d.ts +5 -0
- package/dist/esm/react/A11yDevtools.js +8 -0
- package/dist/esm/react/A11yDevtools.js.map +1 -0
- package/dist/esm/react/index.d.ts +8 -0
- package/dist/esm/react/index.js +11 -0
- package/dist/esm/react/index.js.map +1 -0
- package/dist/esm/react/plugin.d.ts +12 -0
- package/dist/esm/react/plugin.js +11 -0
- package/dist/esm/react/plugin.js.map +1 -0
- package/dist/esm/react/production/A11yDevtools.d.ts +5 -0
- package/dist/esm/react/production/A11yDevtools.js +8 -0
- package/dist/esm/react/production/A11yDevtools.js.map +1 -0
- package/dist/esm/react/production/plugin.d.ts +7 -0
- package/dist/esm/react/production/plugin.js +11 -0
- package/dist/esm/react/production/plugin.js.map +1 -0
- package/dist/esm/react/production.d.ts +3 -0
- package/dist/esm/react/production.js +5 -0
- package/dist/esm/solid/A11yDevtools.d.ts +5 -0
- package/dist/esm/solid/A11yDevtools.js +8 -0
- package/dist/esm/solid/A11yDevtools.js.map +1 -0
- package/dist/esm/solid/index.d.ts +8 -0
- package/dist/esm/solid/index.js +9 -0
- package/dist/esm/solid/index.js.map +1 -0
- package/dist/esm/solid/plugin.d.ts +12 -0
- package/dist/esm/solid/plugin.js +11 -0
- package/dist/esm/solid/plugin.js.map +1 -0
- package/dist/esm/solid/production/A11yDevtools.d.ts +5 -0
- package/dist/esm/solid/production/A11yDevtools.js +8 -0
- package/dist/esm/solid/production/A11yDevtools.js.map +1 -0
- package/dist/esm/solid/production/plugin.d.ts +7 -0
- package/dist/esm/solid/production/plugin.js +11 -0
- package/dist/esm/solid/production/plugin.js.map +1 -0
- package/dist/esm/solid/production.d.ts +3 -0
- package/dist/esm/solid/production.js +3 -0
- package/package.json +110 -7
- package/src/core/components/IssueCard.tsx +75 -0
- package/src/core/components/IssueList.tsx +155 -0
- package/src/core/components/Settings.tsx +221 -0
- package/src/core/components/Shell.tsx +154 -0
- package/src/core/components/index.tsx +12 -0
- package/src/core/contexts/allyContext.tsx +118 -0
- package/src/core/core.tsx +11 -0
- package/src/core/index.ts +10 -0
- package/src/core/production.ts +5 -0
- package/src/core/styles/styles.ts +556 -0
- package/src/core/types/types.ts +177 -0
- package/src/core/utils/ally-audit.utils.ts +345 -0
- package/src/core/utils/config.utils.ts +68 -0
- package/src/core/utils/custom-audit.utils.ts +643 -0
- package/src/core/utils/export-audit.uitls.ts +180 -0
- package/src/core/utils/ui.utils.ts +483 -0
- package/src/react/A11yDevtools.ts +12 -0
- package/src/react/index.ts +16 -0
- package/src/react/plugin.ts +9 -0
- package/src/react/production/A11yDevtools.ts +11 -0
- package/src/react/production/plugin.ts +9 -0
- package/src/react/production.ts +7 -0
- package/src/solid/A11yDevtools.ts +11 -0
- package/src/solid/index.ts +14 -0
- package/src/solid/plugin.ts +9 -0
- package/src/solid/production/A11yDevtools.ts +10 -0
- package/src/solid/production/plugin.ts +9 -0
- package/src/solid/production.ts +5 -0
- 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,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,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":";;;;;;;;;AAmBA,SAAgBiB,oBAAoBC,OAAiC;CACnE,MAAM,EAAEC,QAAQC,cAAcZ,gBAAgB;CAC9C,MAAMa,SAASV,WAAW;CAE1B,MAAMW,mBAAmBpB,iBAAiB,IAAIqB,IAAIJ,OAAOK,cAAc,CAAC;CACxE,MAAMC,iBAAiBvB,iBAAiBK,mBAAmB,CAAC;CAE5D,MAAM,CAACmB,cAAcC,mBAAmBxB,aAAa,GAAG;CACxD,MAAM,CAACyB,gBAAgBC,qBAAqB1B,aAA2B,MAAM;CAE7E,MAAM2B,gBAAgB5B,iBAAiB;EACrC,MAAM6B,MAAMH,gBAAgB;EAC5B,MAAMI,QAAQN,cAAc,CAACO,aAAa;AAC1C,SAAOR,gBAAgB,CAACS,QAAQC,SAAS;AACvC,OAAIJ,QAAQ,SAAS,CAACI,KAAKC,KAAKC,SAASN,IAAI,CAC3C,QAAO;AAGT,OAAI,CAACC,MAAO,QAAO;AACnB,UACEG,KAAKG,GAAGL,aAAa,CAACI,SAASL,MAAM,IACrCG,KAAKI,YAAYN,aAAa,CAACI,SAASL,MAAM;IAEhD;GACF;AAEF,eAAA;EAAA,IAAAQ,OAAAC,eAAAC,OAAA,EAAAC,QAAAH,KAAAI,YAAAC,QAAAF,MAAAC,YAAAE,QAAAD,MAAAE,aAAA,CAAAC,OAAAC,QAAAC,cAAAJ,MAAAC,YAAA,EAAAI,QAAAR,MAAAI,aAAAK,QAAAD,MAAAP,YAAAS,QAAAD,MAAAR,YAAAU,QAAAD,MAAAN,aAAAQ,QAAAD,MAAAV,YAAA,CAAAY,OAAAC,SAAAP,cAAAK,MAAAR,YAAA,EAAAW,SAAAF,MAAAT,aAAA,CAAAY,QAAAC,SAAAV,cAAAQ,OAAAX,YAAA,EAAAe,SAAAV,MAAAL,YAAAH,YAAAmB,SAAAD,OAAAlB,YAAAqB,SAAAF,OAAAnB,WAAAG,aAAA,CAAAmB,QAAAC,SAAAjB,cAAAe,OAAAlB,YAAA,EAAAsB,SAAAH,OAAAnB,YAAAA,aAAA,CAAAuB,QAAAC,SAAArB,cAAAmB,OAAAtB,YAAA;AAAAuB,SAAAvB;EAAA,IAAA0B,SAAAV,OAAAhB,aAAA2B,SAAAD,OAAA7B,YAAA,CAAA+B,QAAAC,SAAA1B,cAAAwB,OAAA3B,YAAA,EAAA8B,SAAAF,OAAA5B,aAAA,CAAA+B,QAAAC,SAAA7B,cAAA2B,OAAA9B,YAAA,EAAAiC,SAAAlB,OAAAf,aAAAkC,SAAAD,OAAApC,YAAA,CAAAsC,QAAAC,SAAAjC,cAAA+B,OAAAlC,YAAA,EAAAqC,SAAAF,OAAAnC,aAAA,CAAAsC,QAAAC,SAAApC,cAAAkC,OAAArC,YAAA,EAAAwC,SAAAP,OAAAjC;AAAAyC,SAAA7C,OAAA8C,gBAIOrF,QAAM;GAACsF,SAAO;GAAaC,SAAO;GAAA,IAACC,UAAO;AAAA,WAAE1E,MAAMF;;GAAO6E,UAAA;GAAA,CAAA,EAAA7C,OAAAC,KAAA;AAAAuC,SAAAlC,OAAAmC,gBASrDnF,QAAM;GACLwF,OAAK;GACLvD,aAAW;GAAA,IACXwD,QAAK;AAAA,WAAE5E,OAAO6E;;GACdC,SAAS;IACP;KAAEF,OAAO;KAAYD,OAAO;KAAY;IACxC;KAAEC,OAAO;KAAWD,OAAO;KAAW;IACtC;KAAEC,OAAO;KAAYD,OAAO;KAAY;IACxC;KAAEC,OAAO;KAASD,OAAO;KAAS;IACnC;GACDI,WAAWH,UAAkB;AAC3B3E,cAAU,aAAa2E,MAA2B;;GACnD,CAAA,EAAAvC,OAAAC,MAAA;AAAA+B,SAAAlC,OAAAmC,gBAEFnF,QAAM;GACLwF,OAAK;GACLvD,aAAW;GAAA,IACXwD,QAAK;AAAA,WAAE5E,OAAOgF;;GACdF,SAAS;IACP;KAAEF,OAAO;KAAUD,OAAO;KAAc;IACxC;KAAEC,OAAO;KAAWD,OAAO;KAAe;IAC1C;KAAEC,OAAO;KAAYD,OAAO;KAAe;IAC3C;KAAEC,OAAO;KAAYD,OAAO;KAAe;IAC3C;KAAEC,OAAO;KAAcD,OAAO;KAAe;IAC7C;KAAEC,OAAO;KAAiBD,OAAO;KAAiB;IAClD;KAAEC,OAAO;KAAOD,OAAO;KAAa;IACrC;GACDI,WAAWH,UAAkB;AAC3B3E,cAAU,WAAW2E,MAAuB;;GAC7C,CAAA,EAAApC,QAAAC,MAAA;AAAA4B,SAAAzB,cAQOtC,gBAAgB,CAAC2E,QAAMlC,QAAAC,MAAA;AAAAqB,SAAAzB,cAC9B5C,OAAOK,cAAc4E,QAAM9B,QAAAC,MAAA;AAAAiB,SAAAf,QAAAgB,gBAI3BrF,QAAM;GACLsF,SAAO;GACPC,SAAO;GACPC,eAAexE,UAAU,iBAAiB,EAAE,CAAC;GAAAyE,UAAA;GAAA,CAAA,EAAAlB,QAAAC,MAAA;AAAAY,SAAAf,QAAAgB,gBAK9CrF,QAAM;GACLsF,SAAO;GACPC,SAAO;GACPC,eACExE,UACE,iBACAK,gBAAgB,CAAC4E,KAAKlE,SAASA,KAAKG,GACtC,CAAC;GAAAuD,UAAA;GAAA,CAAA,EAAAf,QAAAC,MAAA;AAAAS,SAAAR,QAAAS,gBASNnF,QAAM;GACLwF,OAAK;GAAA,IACLC,QAAK;AAAA,WAAEnE,gBAAgB;;GAAA,IACvBqE,UAAO;AAAA,WAAExF,WAAW4F,KAAKtE,SAAS;KAChCgE,OAAOhE;KACP+D,OAAOpF,gBAAgBqB;KACxB,EAAE;;GACHmE,WAAWH,UACTlE,kBAAkBkE,MAAqB;GAAC,CAAA,EAAAb,QAAAC,MAAA;AAAAK,SAAAR,QAAAS,gBAI3CpF,OAAK;GACJyF,OAAK;GACLQ,aAAW;GAAA,IACXP,QAAK;AAAA,WAAErE,cAAc;;GACrBwE,WAAWH,UAAkBpE,gBAAgBoE,MAAK;GAAC,CAAA,EAAAV,QAAAC,MAAA;AAAAE,SAAAD,QAAAE,gBAKpDzF,KAAG;GAAA,IAACuG,OAAI;AAAA,WAAEzE,eAAe;;GAAA+D,WACtB1D,MAAMqE,QAAQ;IACd,MAAMC,mBAAmBnF,kBAAkB,CAACoF,IAAIvE,KAAKG,GAAG;IACxD,MAAMqE,2BACJxE,KAAKC,KAAKC,SAAS,gBAAgB,IACnC,CAACF,KAAKC,KAAKwE,MACRC,QACCA,IAAIC,WAAW,OAAO,IAAID,IAAIC,WAAW,aAC7C,CAAC;IACH,MAAMC,oBACJ5E,KAAKC,KAAK4E,MAAMH,QAAQA,IAAIC,WAAW,OAAO,CAAC;IACjD,MAAMG,kBAAkBT,KAAK,GAAG1E,eAAe,CAACsE,SAAS;AAEzD,kBAAA;KAAA,IAAAc,SAAAzE,eAAA0E,QAAA,EAAAC,SAAAF,OAAAtE,YAAAyE,SAAAD,OAAArE,aAAAuE,SAAAD,OAAAzE,YAAA2E,SAAAD,OAAA1E,YAAA4E,SAAAD,OAAAxE,aAAA,CAAA0E,QAAAC,SAAAxE,cAAAsE,OAAAzE,YAAA,EAAA4E,SAAAL,OAAAvE,aAAA6E,SAAAD,OAAA5E,aAAA,CAAA8E,QAAAC,SAAA5E,cAAA0E,OAAA7E,YAAA;AAAAqE,YAAAW,iBAAA,gBAaQ3G,UAAU,kBAAkB4G,UAAU;AACpC,UAAI1G,kBAAkB,CAACoF,IAAIvE,KAAKG,GAAG,CACjC,QAAO0F,MAAM9F,QAAQI,OAAOA,OAAOH,KAAKG,GAAG;UAE3C,QAAO,CAAC,GAAG0F,OAAO7F,KAAKG,GAAG;OAE5B,CAAA;AAAAkD,YAAA+B,cAWCpF,KAAKG,GAAE;AAAAkD,YAAA8B,QAAA7B,gBAETxF,MAAI;MAAA,IAACgI,OAAI;AAAA,cAAEtB,oBAAoB;;MAAA,IAAAd,WAAA;OAAA,IAAAqC,SAAAzF,eAAA0F,QAAA;AAAAC,oBAAAC,UAAAH,QAErB7G,QAAQ,CAACiH,QAAO,CAAA;AAAA,cAAAJ;;MAAA,CAAA,EAAAT,QAAAC,MAAA;AAAAlC,YAAAmC,cAOGxF,KAAKI,YAAW;AAAAiD,YAAA6B,QAAA5B,gBAC/CxF,MAAI;MAAA,IAACgI,OAAI;AAAA,cAAElB,aAAa;;MAAAlB,WACrBgB,eAAG;OAAA,IAAA0B,SAAA9F,eAAA+F,QAAA,EAAAC,SAAAF,OAAA3F;AAAA4C,cAAAiD,cAGE/H,gBAAgBmG,KAAK,KACpBA,KAAK,CAAC6B,QAAQ,QAAQ,GAAG,CAAA;AAAAN,eAAAO,QAAA;QAAA,IAAAC,QAHnBvH,QAAQ,CAACwH,WAASC,QACfzH,QAAQ,CAAC0H;AAAMH,kBAAAD,IAAAK,KAAAX,UAAAE,QAAAI,IAAAK,IAAAJ,MAAA;AAAAE,kBAAAH,IAAAM,KAAAZ,UAAAI,QAAAE,IAAAM,IAAAH,MAAA;AAAA,eAAAH;UAAA;QAAAK,GAAAE,KAAAA;QAAAD,GAAAC,KAAAA;QAAA,CAAA;AAAA,cAAAX;UAAA;MAK/B,CAAA,EAAAV,QAAAC,MAAA;AAAAM,aAAAO,QAAA;MAAA,IAAAQ,QAhDE9H,QAAQ,CAAC+H,SAAOC,QACZ;QACRhI,QAAQ,CAACiI,kBAAkB7C,YAAY;QACvCpF,QAAQ,CAACkI,gBAAgBtC,WAAU;OACrC,EAAAuC,QAGQnI,QAAQ,CAACoI,cAAYC,QAalBrI,QAAQ,CAACsI,UAAQC,QACfvI,QAAQ,CAACwI,SAAOC,QAEjBzI,QAAQ,CAAC0I,QAAMC,QACX,GACR3I,QAAQ,CAAC4I,iBAAiBxD,YAAW,EACvC,EAAAyD,QAaO7I,QAAQ,CAAC8I;AAAQhB,gBAAAR,IAAAK,KAAAX,UAAAnB,QAAAyB,IAAAK,IAAAG,MAAA;AAAAR,UAAAM,IAAAmB,UAAAlD,QAAAmC,OAAAV,IAAAM,EAAA;AAAAO,gBAAAb,IAAA0B,KAAAhC,UAAAjB,QAAAuB,IAAA0B,IAAAb,MAAA;AAAAE,gBAAAf,IAAA2B,KAAAjC,UAAAhB,QAAAsB,IAAA2B,IAAAZ,MAAA;AAAAE,gBAAAjB,IAAA4B,KAAAlC,UAAAf,QAAAqB,IAAA4B,IAAAX,MAAA;AAAAE,gBAAAnB,IAAA6B,KAAAnC,UAAAd,QAAAoB,IAAA6B,IAAAV,MAAA;AAAAnB,UAAA8B,IAAAL,UAAA7C,QAAAyC,OAAArB,IAAA8B,EAAA;AAAAP,gBAAAvB,IAAA+B,KAAArC,UAAAV,QAAAgB,IAAA+B,IAAAR,MAAA;AAAA,aAAAvB;QAAA;MAAAK,GAAAE,KAAAA;MAAAD,GAAAC,KAAAA;MAAAmB,GAAAnB,KAAAA;MAAAoB,GAAApB,KAAAA;MAAAqB,GAAArB,KAAAA;MAAAsB,GAAAtB,KAAAA;MAAAuB,GAAAvB,KAAAA;MAAAwB,GAAAxB,KAAAA;MAAA,CAAA;AAAAd,kBAAAuC,YAAAvD,QAAA,WA9BpB,CAACX,YAAY,CAAA,CAAA;AAAA,YAAAS;QAAA;;GA4C7B,CAAA,CAAA;AAAAkB,UAAAO,QAAA;GAAA,IAAAiC,MAvKCvJ,QAAQ,CAACwJ,iBAAeC,OACtBzJ,QAAQ,CAAC0J,gBAAcC,OACtB3J,QAAQ,CAAC4J,eAAaC,OAMvB7J,QAAQ,CAAC8J,iBAAeC,OACtB/J,QAAQ,CAACgK,iBAAeC,OACvBjK,QAAQ,CAACkK,sBAAoBC,OAC5BnK,QAAQ,CAACoK,kBAAgBC,OAoCzBrK,QAAQ,CAACsK,gBAAcC,OACtBvK,QAAQ,CAACkK,sBAAoBM,OAK5BxK,QAAQ,CAACyK,oBAAkBC,OAwB7B1K,QAAQ,CAAC2K,YAAUC,QAqBnB5K,QAAQ,CAAC6K;AAAStB,WAAAjC,IAAAK,KAAAX,UAAA7F,MAAAmG,IAAAK,IAAA4B,IAAA;AAAAE,YAAAnC,IAAAM,KAAAZ,UAAA1F,OAAAgG,IAAAM,IAAA6B,KAAA;AAAAE,YAAArC,IAAA0B,KAAAhC,UAAAxF,OAAA8F,IAAA0B,IAAAW,KAAA;AAAAE,YAAAvC,IAAA2B,KAAAjC,UAAAlF,OAAAwF,IAAA2B,IAAAY,KAAA;AAAAE,YAAAzC,IAAA4B,KAAAlC,UAAAjF,OAAAuF,IAAA4B,IAAAa,KAAA;AAAAE,YAAA3C,IAAA6B,KAAAnC,UAAAhF,OAAAsF,IAAA6B,IAAAc,KAAA;AAAAE,YAAA7C,IAAA8B,KAAApC,UAAA/E,OAAAqF,IAAA8B,IAAAe,KAAA;AAAAE,YAAA/C,IAAA+B,KAAArC,UAAAvE,QAAA6E,IAAA+B,IAAAgB,KAAA;AAAAE,YAAAjD,IAAAwD,KAAA9D,UAAAtE,QAAA4E,IAAAwD,IAAAP,KAAA;AAAAC,YAAAlD,IAAAyD,KAAA/D,UAAA5D,QAAAkE,IAAAyD,IAAAP,KAAA;AAAAE,YAAApD,IAAA0D,KAAAhE,UAAArD,QAAA2D,IAAA0D,IAAAN,KAAA;AAAAE,aAAAtD,IAAA2D,KAAAjE,UAAA9C,QAAAoD,IAAA2D,IAAAL,MAAA;AAAA,UAAAtD;KAAA;GAAAK,GAAAE,KAAAA;GAAAD,GAAAC,KAAAA;GAAAmB,GAAAnB,KAAAA;GAAAoB,GAAApB,KAAAA;GAAAqB,GAAArB,KAAAA;GAAAsB,GAAAtB,KAAAA;GAAAuB,GAAAvB,KAAAA;GAAAwB,GAAAxB,KAAAA;GAAAiD,GAAAjD,KAAAA;GAAAkD,GAAAlD,KAAAA;GAAAmD,GAAAnD,KAAAA;GAAAoD,GAAApD,KAAAA;GAAA,CAAA;AAAA,SAAA1G;KAAA"}
|