@bauer-group/accessibility-widget 1.0.3
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/README.md +259 -0
- package/dist/accessibility-widget-core.min.js +6 -0
- package/dist/accessibility-widget-core.min.js.map +7 -0
- package/dist/accessibility-widget-loader.min.js +14 -0
- package/dist/accessibility-widget-loader.min.js.map +7 -0
- package/dist/accessibility-widget.min.css +7 -0
- package/dist/accessibility-widget.min.css.map +7 -0
- package/dist/config.d.ts +33 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/core.d.ts +31 -0
- package/dist/core.d.ts.map +1 -0
- package/dist/features/apply.d.ts +3 -0
- package/dist/features/apply.d.ts.map +1 -0
- package/dist/features/profile.d.ts +3 -0
- package/dist/features/profile.d.ts.map +1 -0
- package/dist/features/reading-guide.d.ts +2 -0
- package/dist/features/reading-guide.d.ts.map +1 -0
- package/dist/features/reading-mask.d.ts +2 -0
- package/dist/features/reading-mask.d.ts.map +1 -0
- package/dist/features/structure-nav.d.ts +2 -0
- package/dist/features/structure-nav.d.ts.map +1 -0
- package/dist/features/tts.d.ts +7 -0
- package/dist/features/tts.d.ts.map +1 -0
- package/dist/focus-trap.d.ts +6 -0
- package/dist/focus-trap.d.ts.map +1 -0
- package/dist/i18n/ar.d.ts +3 -0
- package/dist/i18n/ar.d.ts.map +1 -0
- package/dist/i18n/bn.d.ts +3 -0
- package/dist/i18n/bn.d.ts.map +1 -0
- package/dist/i18n/cs.d.ts +3 -0
- package/dist/i18n/cs.d.ts.map +1 -0
- package/dist/i18n/de.d.ts +3 -0
- package/dist/i18n/de.d.ts.map +1 -0
- package/dist/i18n/el.d.ts +3 -0
- package/dist/i18n/el.d.ts.map +1 -0
- package/dist/i18n/en.d.ts +3 -0
- package/dist/i18n/en.d.ts.map +1 -0
- package/dist/i18n/es.d.ts +3 -0
- package/dist/i18n/es.d.ts.map +1 -0
- package/dist/i18n/fa.d.ts +3 -0
- package/dist/i18n/fa.d.ts.map +1 -0
- package/dist/i18n/fr.d.ts +3 -0
- package/dist/i18n/fr.d.ts.map +1 -0
- package/dist/i18n/he.d.ts +3 -0
- package/dist/i18n/he.d.ts.map +1 -0
- package/dist/i18n/hi.d.ts +3 -0
- package/dist/i18n/hi.d.ts.map +1 -0
- package/dist/i18n/hu.d.ts +3 -0
- package/dist/i18n/hu.d.ts.map +1 -0
- package/dist/i18n/id.d.ts +3 -0
- package/dist/i18n/id.d.ts.map +1 -0
- package/dist/i18n/index.d.ts +6 -0
- package/dist/i18n/index.d.ts.map +1 -0
- package/dist/i18n/it.d.ts +3 -0
- package/dist/i18n/it.d.ts.map +1 -0
- package/dist/i18n/ja.d.ts +3 -0
- package/dist/i18n/ja.d.ts.map +1 -0
- package/dist/i18n/ko.d.ts +3 -0
- package/dist/i18n/ko.d.ts.map +1 -0
- package/dist/i18n/nl.d.ts +3 -0
- package/dist/i18n/nl.d.ts.map +1 -0
- package/dist/i18n/pl.d.ts +3 -0
- package/dist/i18n/pl.d.ts.map +1 -0
- package/dist/i18n/pt.d.ts +3 -0
- package/dist/i18n/pt.d.ts.map +1 -0
- package/dist/i18n/ro.d.ts +3 -0
- package/dist/i18n/ro.d.ts.map +1 -0
- package/dist/i18n/ru.d.ts +3 -0
- package/dist/i18n/ru.d.ts.map +1 -0
- package/dist/i18n/sv.d.ts +3 -0
- package/dist/i18n/sv.d.ts.map +1 -0
- package/dist/i18n/th.d.ts +3 -0
- package/dist/i18n/th.d.ts.map +1 -0
- package/dist/i18n/tr.d.ts +3 -0
- package/dist/i18n/tr.d.ts.map +1 -0
- package/dist/i18n/types.d.ts +44 -0
- package/dist/i18n/types.d.ts.map +1 -0
- package/dist/i18n/uk.d.ts +3 -0
- package/dist/i18n/uk.d.ts.map +1 -0
- package/dist/i18n/ur.d.ts +3 -0
- package/dist/i18n/ur.d.ts.map +1 -0
- package/dist/i18n/vi.d.ts +3 -0
- package/dist/i18n/vi.d.ts.map +1 -0
- package/dist/i18n/zh.d.ts +3 -0
- package/dist/i18n/zh.d.ts.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/integrity.json +9 -0
- package/dist/integrity.txt +12 -0
- package/dist/loader.d.ts +2 -0
- package/dist/loader.d.ts.map +1 -0
- package/dist/panel/drag.d.ts +34 -0
- package/dist/panel/drag.d.ts.map +1 -0
- package/dist/panel/panel.d.ts +23 -0
- package/dist/panel/panel.d.ts.map +1 -0
- package/dist/state.d.ts +18 -0
- package/dist/state.d.ts.map +1 -0
- package/dist/styles/critical.d.ts +16 -0
- package/dist/styles/critical.d.ts.map +1 -0
- package/dist/types/index.d.ts +3 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/locale.d.ts +11 -0
- package/dist/types/locale.d.ts.map +1 -0
- package/dist/types/widget.d.ts +207 -0
- package/dist/types/widget.d.ts.map +1 -0
- package/dist/util/debug.d.ts +8 -0
- package/dist/util/debug.d.ts.map +1 -0
- package/dist/util/dom.d.ts +19 -0
- package/dist/util/dom.d.ts.map +1 -0
- package/dist/util/events.d.ts +38 -0
- package/dist/util/events.d.ts.map +1 -0
- package/dist/util/feature-icons.d.ts +33 -0
- package/dist/util/feature-icons.d.ts.map +1 -0
- package/dist/util/language-names.d.ts +12 -0
- package/dist/util/language-names.d.ts.map +1 -0
- package/dist/util/svg.d.ts +38 -0
- package/dist/util/svg.d.ts.map +1 -0
- package/package.json +67 -0
- package/src/config.ts +213 -0
- package/src/core.ts +173 -0
- package/src/features/apply.ts +37 -0
- package/src/features/profile.ts +18 -0
- package/src/features/reading-guide.ts +25 -0
- package/src/features/reading-mask.ts +25 -0
- package/src/features/structure-nav.ts +43 -0
- package/src/features/tts.ts +73 -0
- package/src/focus-trap.ts +35 -0
- package/src/globals.d.ts +63 -0
- package/src/i18n/ar.ts +48 -0
- package/src/i18n/bn.ts +48 -0
- package/src/i18n/cs.ts +48 -0
- package/src/i18n/de.ts +65 -0
- package/src/i18n/el.ts +48 -0
- package/src/i18n/en.ts +65 -0
- package/src/i18n/es.ts +48 -0
- package/src/i18n/fa.ts +48 -0
- package/src/i18n/fr.ts +48 -0
- package/src/i18n/he.ts +48 -0
- package/src/i18n/hi.ts +48 -0
- package/src/i18n/hu.ts +48 -0
- package/src/i18n/id.ts +48 -0
- package/src/i18n/index.ts +70 -0
- package/src/i18n/it.ts +48 -0
- package/src/i18n/ja.ts +48 -0
- package/src/i18n/ko.ts +48 -0
- package/src/i18n/nl.ts +48 -0
- package/src/i18n/pl.ts +48 -0
- package/src/i18n/pt.ts +48 -0
- package/src/i18n/ro.ts +48 -0
- package/src/i18n/ru.ts +48 -0
- package/src/i18n/sv.ts +48 -0
- package/src/i18n/th.ts +48 -0
- package/src/i18n/tr.ts +48 -0
- package/src/i18n/types.ts +36 -0
- package/src/i18n/uk.ts +48 -0
- package/src/i18n/ur.ts +48 -0
- package/src/i18n/vi.ts +48 -0
- package/src/i18n/zh.ts +48 -0
- package/src/index.ts +9 -0
- package/src/loader.ts +533 -0
- package/src/panel/drag.ts +210 -0
- package/src/panel/panel.ts +617 -0
- package/src/state.ts +91 -0
- package/src/styles/critical.ts +56 -0
- package/src/styles/widget.css +739 -0
- package/src/types/index.ts +2 -0
- package/src/types/locale.ts +55 -0
- package/src/types/widget.ts +300 -0
- package/src/util/debug.ts +12 -0
- package/src/util/dom.ts +68 -0
- package/src/util/events.ts +54 -0
- package/src/util/feature-icons.ts +163 -0
- package/src/util/language-names.ts +41 -0
- package/src/util/svg.ts +93 -0
package/src/util/svg.ts
ADDED
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
const SVG_NS = 'http://www.w3.org/2000/svg';
|
|
2
|
+
|
|
3
|
+
export interface SvgPath {
|
|
4
|
+
d: string;
|
|
5
|
+
fill?: string;
|
|
6
|
+
stroke?: string;
|
|
7
|
+
strokeWidth?: number | string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export interface SvgCircle {
|
|
11
|
+
cx: number;
|
|
12
|
+
cy: number;
|
|
13
|
+
r: number;
|
|
14
|
+
fill?: string;
|
|
15
|
+
stroke?: string;
|
|
16
|
+
strokeWidth?: number | string;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export interface SvgIconOptions {
|
|
20
|
+
viewBox?: string;
|
|
21
|
+
width?: number;
|
|
22
|
+
height?: number;
|
|
23
|
+
paths?: readonly SvgPath[];
|
|
24
|
+
circles?: readonly SvgCircle[];
|
|
25
|
+
/**
|
|
26
|
+
* Lucide-style outline icon. Applies fill:none, stroke:currentColor,
|
|
27
|
+
* stroke-width:2, round caps/joins at the <svg> root, so individual
|
|
28
|
+
* paths/circles don't need to repeat these attributes.
|
|
29
|
+
*/
|
|
30
|
+
stroke?: boolean;
|
|
31
|
+
ariaHidden?: boolean;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Build an SVG element programmatically — no innerHTML, no DOMParser,
|
|
36
|
+
* so no XSS surface even if path data ever comes from config.
|
|
37
|
+
*/
|
|
38
|
+
export function buildIcon(opts: SvgIconOptions): SVGSVGElement {
|
|
39
|
+
const svg = document.createElementNS(SVG_NS, 'svg');
|
|
40
|
+
svg.setAttribute('viewBox', opts.viewBox ?? '0 0 24 24');
|
|
41
|
+
if (opts.width !== undefined) svg.setAttribute('width', String(opts.width));
|
|
42
|
+
if (opts.height !== undefined) svg.setAttribute('height', String(opts.height));
|
|
43
|
+
if (opts.ariaHidden !== false) svg.setAttribute('aria-hidden', 'true');
|
|
44
|
+
svg.setAttribute('focusable', 'false');
|
|
45
|
+
|
|
46
|
+
const strokeMode = Boolean(opts.stroke);
|
|
47
|
+
if (strokeMode) {
|
|
48
|
+
svg.setAttribute('fill', 'none');
|
|
49
|
+
svg.setAttribute('stroke', 'currentColor');
|
|
50
|
+
svg.setAttribute('stroke-width', '2');
|
|
51
|
+
svg.setAttribute('stroke-linecap', 'round');
|
|
52
|
+
svg.setAttribute('stroke-linejoin', 'round');
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
for (const p of opts.paths ?? []) {
|
|
56
|
+
const el = document.createElementNS(SVG_NS, 'path');
|
|
57
|
+
el.setAttribute('d', p.d);
|
|
58
|
+
if (p.fill !== undefined) el.setAttribute('fill', p.fill);
|
|
59
|
+
else if (!strokeMode) el.setAttribute('fill', 'currentColor');
|
|
60
|
+
if (p.stroke !== undefined) el.setAttribute('stroke', p.stroke);
|
|
61
|
+
if (p.strokeWidth !== undefined) el.setAttribute('stroke-width', String(p.strokeWidth));
|
|
62
|
+
svg.appendChild(el);
|
|
63
|
+
}
|
|
64
|
+
for (const c of opts.circles ?? []) {
|
|
65
|
+
const el = document.createElementNS(SVG_NS, 'circle');
|
|
66
|
+
el.setAttribute('cx', String(c.cx));
|
|
67
|
+
el.setAttribute('cy', String(c.cy));
|
|
68
|
+
el.setAttribute('r', String(c.r));
|
|
69
|
+
if (c.fill !== undefined) el.setAttribute('fill', c.fill);
|
|
70
|
+
else if (!strokeMode) el.setAttribute('fill', 'currentColor');
|
|
71
|
+
if (c.stroke !== undefined) el.setAttribute('stroke', c.stroke);
|
|
72
|
+
if (c.strokeWidth !== undefined) el.setAttribute('stroke-width', String(c.strokeWidth));
|
|
73
|
+
svg.appendChild(el);
|
|
74
|
+
}
|
|
75
|
+
return svg;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/** Accessibility person icon (BFSG signature icon). */
|
|
79
|
+
export const ICON_ACCESSIBILITY: SvgIconOptions = {
|
|
80
|
+
viewBox: '0 0 24 24',
|
|
81
|
+
paths: [
|
|
82
|
+
{
|
|
83
|
+
d: 'M12 2a2 2 0 1 1 0 4 2 2 0 0 1 0-4zm-6 5 6 2 6-2 .5 1.8L13 10.2v3.2l3.2 7.4-1.7.8L12 15l-2.5 6.6-1.7-.8L11 13.4V10.2L5.5 8.8 6 7z',
|
|
84
|
+
},
|
|
85
|
+
],
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
/** Close / X icon (Lucide: x). */
|
|
89
|
+
export const ICON_CLOSE: SvgIconOptions = {
|
|
90
|
+
viewBox: '0 0 24 24',
|
|
91
|
+
stroke: true,
|
|
92
|
+
paths: [{ d: 'M18 6 6 18M6 6l12 12' }],
|
|
93
|
+
};
|