accessify-widget 0.2.4 → 0.2.6
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/dist/accessify.min.js +1 -1
- package/dist/accessify.min.js.map +1 -1
- package/dist/accessify.mjs +1 -1
- package/dist/{animation-stop-CA4Sz28J.js → animation-stop-BUZdA2rS.js} +133 -17
- package/dist/animation-stop-BUZdA2rS.js.map +1 -0
- package/dist/{index-D8e7_na0.js → index-B1it5VgN.js} +4 -4
- package/dist/{index-D8e7_na0.js.map → index-B1it5VgN.js.map} +1 -1
- package/dist/{keyboard-nav-kiIcwX2D.js → keyboard-nav-CZkiG72h.js} +2 -2
- package/dist/{keyboard-nav-kiIcwX2D.js.map → keyboard-nav-CZkiG72h.js.map} +1 -1
- package/dist/{page-structure-CqY3jueN.js → page-structure-BBNwb5cm.js} +2 -2
- package/dist/{page-structure-CqY3jueN.js.map → page-structure-BBNwb5cm.js.map} +1 -1
- package/dist/widget.js +1 -1
- package/dist/widget.js.map +1 -1
- package/package.json +1 -1
- package/dist/animation-stop-CA4Sz28J.js.map +0 -1
package/dist/accessify.mjs
CHANGED
|
@@ -11,6 +11,9 @@ function createAnimationStopModule() {
|
|
|
11
11
|
let rafLoopTracker = /* @__PURE__ */ new Map();
|
|
12
12
|
let blockedRAFs = /* @__PURE__ */ new Set();
|
|
13
13
|
let gifOriginals = /* @__PURE__ */ new Map();
|
|
14
|
+
let styleObserver = null;
|
|
15
|
+
let delayedTimers = [];
|
|
16
|
+
let frozenInlineElements = /* @__PURE__ */ new Map();
|
|
14
17
|
function getStyles() {
|
|
15
18
|
return `
|
|
16
19
|
/* accessify animation stop - WCAG 2.3.1 compliance */
|
|
@@ -23,7 +26,18 @@ function createAnimationStopModule() {
|
|
|
23
26
|
transition-delay: 0s !important;
|
|
24
27
|
scroll-behavior: auto !important;
|
|
25
28
|
}
|
|
29
|
+
|
|
30
|
+
/* Framer appear elements — force visible only (do NOT touch transform — it breaks layout) */
|
|
31
|
+
[data-framer-appear-id] {
|
|
32
|
+
opacity: 1 !important;
|
|
33
|
+
}
|
|
34
|
+
|
|
26
35
|
marquee { -moz-binding: none; }
|
|
36
|
+
|
|
37
|
+
/* Pause HTML5 video playback visually */
|
|
38
|
+
video {
|
|
39
|
+
animation-play-state: paused !important;
|
|
40
|
+
}
|
|
27
41
|
`;
|
|
28
42
|
}
|
|
29
43
|
function injectStyles() {
|
|
@@ -237,25 +251,24 @@ function createAnimationStopModule() {
|
|
|
237
251
|
const appearEls = document.querySelectorAll("[data-framer-appear-id]");
|
|
238
252
|
for (const el of appearEls) {
|
|
239
253
|
if (el.hasAttribute(FRAMER_FIXED_ATTR)) continue;
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
el.style
|
|
245
|
-
el.style.
|
|
254
|
+
if (el.closest("#accessify-root")) continue;
|
|
255
|
+
const computed = getComputedStyle(el);
|
|
256
|
+
const opacity = parseFloat(computed.opacity);
|
|
257
|
+
if (opacity < 0.5) {
|
|
258
|
+
framerFixedElements.push({ el, origStyle: el.getAttribute("style") || "" });
|
|
259
|
+
el.style.setProperty("opacity", "1", "important");
|
|
246
260
|
el.setAttribute(FRAMER_FIXED_ATTR, "true");
|
|
247
261
|
}
|
|
248
262
|
}
|
|
249
263
|
const allWillChange = document.querySelectorAll('[style*="will-change"]');
|
|
250
264
|
for (const el of allWillChange) {
|
|
251
265
|
if (el.hasAttribute(FRAMER_FIXED_ATTR)) continue;
|
|
266
|
+
if (el.closest("#accessify-root")) continue;
|
|
252
267
|
const computed = getComputedStyle(el);
|
|
253
268
|
const opacity = parseFloat(computed.opacity);
|
|
254
269
|
if (opacity < 0.05 && computed.willChange.includes("transform")) {
|
|
255
270
|
framerFixedElements.push({ el, origStyle: el.getAttribute("style") || "" });
|
|
256
|
-
el.style.opacity
|
|
257
|
-
el.style.transform = "none";
|
|
258
|
-
el.style.willChange = "auto";
|
|
271
|
+
el.style.setProperty("opacity", "1", "important");
|
|
259
272
|
el.setAttribute(FRAMER_FIXED_ATTR, "true");
|
|
260
273
|
}
|
|
261
274
|
}
|
|
@@ -272,15 +285,88 @@ function createAnimationStopModule() {
|
|
|
272
285
|
}
|
|
273
286
|
function forceFramerAppearVisibleSingle(el) {
|
|
274
287
|
if (el.hasAttribute(FRAMER_FIXED_ATTR)) return;
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
el.style
|
|
280
|
-
el.style.
|
|
288
|
+
if (el.closest("#accessify-root")) return;
|
|
289
|
+
const computed = getComputedStyle(el);
|
|
290
|
+
const opacity = parseFloat(computed.opacity);
|
|
291
|
+
if (opacity < 0.5) {
|
|
292
|
+
framerFixedElements.push({ el, origStyle: el.getAttribute("style") || "" });
|
|
293
|
+
el.style.setProperty("opacity", "1", "important");
|
|
281
294
|
el.setAttribute(FRAMER_FIXED_ATTR, "true");
|
|
282
295
|
}
|
|
283
296
|
}
|
|
297
|
+
function setupStyleObserver() {
|
|
298
|
+
if (styleObserver) return;
|
|
299
|
+
let isOurChange = false;
|
|
300
|
+
styleObserver = new MutationObserver((mutations) => {
|
|
301
|
+
if (!enabled || isOurChange) return;
|
|
302
|
+
isOurChange = true;
|
|
303
|
+
for (const m of mutations) {
|
|
304
|
+
if (m.type !== "attributes" || m.attributeName !== "style") continue;
|
|
305
|
+
const el = m.target;
|
|
306
|
+
if (el.closest("#accessify-root")) continue;
|
|
307
|
+
if (!el.hasAttribute("data-framer-appear-id")) continue;
|
|
308
|
+
const opacity = parseFloat(el.style.opacity);
|
|
309
|
+
if (!isNaN(opacity) && opacity < 0.5) {
|
|
310
|
+
el.style.setProperty("opacity", "1", "important");
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
isOurChange = false;
|
|
314
|
+
});
|
|
315
|
+
styleObserver.observe(document.body, {
|
|
316
|
+
attributes: true,
|
|
317
|
+
attributeFilter: ["style"],
|
|
318
|
+
subtree: true
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
function disconnectStyleObserver() {
|
|
322
|
+
styleObserver?.disconnect();
|
|
323
|
+
styleObserver = null;
|
|
324
|
+
}
|
|
325
|
+
function scheduleDelayedScans() {
|
|
326
|
+
const delays = [500, 1e3, 2e3, 4e3];
|
|
327
|
+
for (const delay of delays) {
|
|
328
|
+
const timer = setTimeout(() => {
|
|
329
|
+
if (!enabled) return;
|
|
330
|
+
forceAllHiddenVisible();
|
|
331
|
+
pauseAllWebAnimations();
|
|
332
|
+
freezeAllGifs();
|
|
333
|
+
pauseSVGAnimations();
|
|
334
|
+
stopMarquees();
|
|
335
|
+
}, delay);
|
|
336
|
+
delayedTimers.push(timer);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
function clearDelayedScans() {
|
|
340
|
+
for (const timer of delayedTimers) clearTimeout(timer);
|
|
341
|
+
delayedTimers = [];
|
|
342
|
+
}
|
|
343
|
+
function forceAllHiddenVisible() {
|
|
344
|
+
forceFramerAppearVisible();
|
|
345
|
+
const candidates = document.querySelectorAll(
|
|
346
|
+
'[data-framer-appear-id], [style*="opacity:0.0"], [style*="opacity: 0.0"]'
|
|
347
|
+
);
|
|
348
|
+
for (const el of candidates) {
|
|
349
|
+
if (el.hasAttribute(FRAMER_FIXED_ATTR)) continue;
|
|
350
|
+
if (el.closest("#accessify-root")) continue;
|
|
351
|
+
const computed = getComputedStyle(el);
|
|
352
|
+
const opacity = parseFloat(computed.opacity);
|
|
353
|
+
if (opacity < 0.05) {
|
|
354
|
+
frozenInlineElements.set(el, el.getAttribute("style") || "");
|
|
355
|
+
el.style.setProperty("opacity", "1", "important");
|
|
356
|
+
el.setAttribute(FRAMER_FIXED_ATTR, "true");
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
function restoreFrozenInlineElements() {
|
|
361
|
+
for (const [el, origStyle] of frozenInlineElements) {
|
|
362
|
+
try {
|
|
363
|
+
el.setAttribute("style", origStyle);
|
|
364
|
+
el.removeAttribute(FRAMER_FIXED_ATTR);
|
|
365
|
+
} catch {
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
frozenInlineElements.clear();
|
|
369
|
+
}
|
|
284
370
|
function stopMarquees() {
|
|
285
371
|
document.querySelectorAll("marquee").forEach((el) => {
|
|
286
372
|
try {
|
|
@@ -317,8 +403,9 @@ function createAnimationStopModule() {
|
|
|
317
403
|
}
|
|
318
404
|
});
|
|
319
405
|
}
|
|
406
|
+
let originalVideoPlay = null;
|
|
320
407
|
function pauseAutoplayVideos() {
|
|
321
|
-
const videos = document.querySelectorAll("video
|
|
408
|
+
const videos = document.querySelectorAll("video");
|
|
322
409
|
pausedVideos = [];
|
|
323
410
|
videos.forEach((video) => {
|
|
324
411
|
if (!video.paused) {
|
|
@@ -326,8 +413,31 @@ function createAnimationStopModule() {
|
|
|
326
413
|
pausedVideos.push(video);
|
|
327
414
|
}
|
|
328
415
|
});
|
|
416
|
+
videos.forEach((video) => {
|
|
417
|
+
if (video.hasAttribute("autoplay")) {
|
|
418
|
+
video.dataset.accessifyAutoplay = "true";
|
|
419
|
+
video.removeAttribute("autoplay");
|
|
420
|
+
}
|
|
421
|
+
});
|
|
422
|
+
if (!originalVideoPlay) {
|
|
423
|
+
originalVideoPlay = HTMLVideoElement.prototype.play;
|
|
424
|
+
HTMLVideoElement.prototype.play = function() {
|
|
425
|
+
if (enabled) {
|
|
426
|
+
return Promise.resolve();
|
|
427
|
+
}
|
|
428
|
+
return originalVideoPlay.call(this);
|
|
429
|
+
};
|
|
430
|
+
}
|
|
329
431
|
}
|
|
330
432
|
function resumePausedVideos() {
|
|
433
|
+
if (originalVideoPlay) {
|
|
434
|
+
HTMLVideoElement.prototype.play = originalVideoPlay;
|
|
435
|
+
originalVideoPlay = null;
|
|
436
|
+
}
|
|
437
|
+
document.querySelectorAll("video[data-accessify-autoplay]").forEach((video) => {
|
|
438
|
+
video.setAttribute("autoplay", "");
|
|
439
|
+
delete video.dataset.accessifyAutoplay;
|
|
440
|
+
});
|
|
331
441
|
pausedVideos.forEach((video) => {
|
|
332
442
|
try {
|
|
333
443
|
video.play();
|
|
@@ -349,11 +459,17 @@ function createAnimationStopModule() {
|
|
|
349
459
|
forceFramerAppearVisible();
|
|
350
460
|
stopMarquees();
|
|
351
461
|
pauseSVGAnimations();
|
|
462
|
+
setupStyleObserver();
|
|
463
|
+
scheduleDelayedScans();
|
|
352
464
|
pauseAutoplayVideos();
|
|
465
|
+
forceAllHiddenVisible();
|
|
353
466
|
localStorage.setItem(STORAGE_KEY, "true");
|
|
354
467
|
}
|
|
355
468
|
function deactivate() {
|
|
356
469
|
enabled = false;
|
|
470
|
+
clearDelayedScans();
|
|
471
|
+
disconnectStyleObserver();
|
|
472
|
+
restoreFrozenInlineElements();
|
|
357
473
|
resumePausedVideos();
|
|
358
474
|
resumeSVGAnimations();
|
|
359
475
|
startMarquees();
|
|
@@ -391,4 +507,4 @@ function createAnimationStopModule() {
|
|
|
391
507
|
export {
|
|
392
508
|
createAnimationStopModule as default
|
|
393
509
|
};
|
|
394
|
-
//# sourceMappingURL=animation-stop-
|
|
510
|
+
//# sourceMappingURL=animation-stop-BUZdA2rS.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"animation-stop-BUZdA2rS.js","sources":["../src/features/animation-stop.ts"],"sourcesContent":["import type { FeatureModule, FeatureState } from '../types';\n\nexport default function createAnimationStopModule(): FeatureModule {\n let enabled = false;\n const STYLE_ID = 'accessify-animation-stop';\n const STORAGE_KEY = 'accessify-animation-stop';\n\n // --- State for clean restore ---\n let pausedVideos: HTMLVideoElement[] = [];\n let pausedAnimations: Animation[] = [];\n let originalAnimate: typeof Element.prototype.animate | null = null;\n let originalRAF: typeof window.requestAnimationFrame | null = null;\n let originalMatchMedia: typeof window.matchMedia | null = null;\n let mutationObserver: MutationObserver | null = null;\n let rafLoopTracker = new Map<string, { count: number; lastTime: number }>();\n let blockedRAFs = new Set<number>();\n let gifOriginals = new Map<HTMLImageElement, string>();\n let reducedMotionListeners: Array<{ mql: MediaQueryList; handler: () => void }> = [];\n let styleObserver: MutationObserver | null = null;\n let delayedTimers: ReturnType<typeof setTimeout>[] = [];\n let frozenInlineElements = new Map<HTMLElement, string>();\n\n // -------------------------------------------------------------------------\n // Layer 0: CSS overrides (existing — catches pure CSS animations)\n // -------------------------------------------------------------------------\n\n function getStyles(): string {\n return `\n /* accessify animation stop - WCAG 2.3.1 compliance */\n *, *::before, *::after {\n animation-duration: 0.01s !important;\n animation-delay: 0s !important;\n animation-iteration-count: 1 !important;\n animation-play-state: paused !important;\n transition-duration: 0.01s !important;\n transition-delay: 0s !important;\n scroll-behavior: auto !important;\n }\n\n /* Framer appear elements — force visible only (do NOT touch transform — it breaks layout) */\n [data-framer-appear-id] {\n opacity: 1 !important;\n }\n\n marquee { -moz-binding: none; }\n\n /* Pause HTML5 video playback visually */\n video {\n animation-play-state: paused !important;\n }\n `;\n }\n\n function injectStyles() {\n let styleEl = document.getElementById(STYLE_ID);\n if (!styleEl) {\n styleEl = document.createElement('style');\n styleEl.id = STYLE_ID;\n document.head.appendChild(styleEl);\n }\n styleEl.textContent = getStyles();\n }\n\n function removeStyles() {\n document.getElementById(STYLE_ID)?.remove();\n }\n\n // -------------------------------------------------------------------------\n // Layer 1: Web Animations API — pause all running + intercept new\n // -------------------------------------------------------------------------\n\n function pauseAllWebAnimations() {\n try {\n const animations = document.getAnimations();\n for (const anim of animations) {\n if (anim.playState === 'running' || anim.playState === 'pending') {\n anim.pause();\n pausedAnimations.push(anim);\n }\n }\n } catch { /* getAnimations not supported */ }\n }\n\n function overrideElementAnimate() {\n if (originalAnimate) return;\n originalAnimate = Element.prototype.animate;\n\n Element.prototype.animate = function (\n this: Element,\n keyframes: Keyframe[] | PropertyIndexedKeyframes | null,\n options?: number | KeyframeAnimationOptions,\n ): Animation {\n const anim = originalAnimate!.call(this, keyframes, options);\n if (enabled) {\n anim.pause();\n pausedAnimations.push(anim);\n }\n return anim;\n };\n }\n\n function restoreElementAnimate() {\n if (originalAnimate) {\n Element.prototype.animate = originalAnimate;\n originalAnimate = null;\n }\n }\n\n function resumePausedAnimations() {\n for (const anim of pausedAnimations) {\n try { anim.play(); } catch { /* animation may be gone */ }\n }\n pausedAnimations = [];\n }\n\n // -------------------------------------------------------------------------\n // Layer 2: requestAnimationFrame loop detection\n // -------------------------------------------------------------------------\n\n function overrideRAF() {\n if (originalRAF) return;\n originalRAF = window.requestAnimationFrame;\n const origCancel = window.cancelAnimationFrame;\n\n window.requestAnimationFrame = function (callback: FrameRequestCallback): number {\n if (!enabled) return originalRAF!.call(window, callback);\n\n // Fingerprint callback to detect animation loops\n const key = callback.toString().slice(0, 200);\n const now = performance.now();\n const entry = rafLoopTracker.get(key);\n\n if (entry) {\n entry.count++;\n if (now - entry.lastTime < 100 && entry.count > 3) {\n // This callback is re-registering rapidly — animation loop detected\n const id = originalRAF!.call(window, () => {}); // no-op\n blockedRAFs.add(id);\n return id;\n }\n entry.lastTime = now;\n } else {\n rafLoopTracker.set(key, { count: 1, lastTime: now });\n }\n\n // Allow through but wrap to track re-registration\n return originalRAF!.call(window, callback);\n };\n\n window.cancelAnimationFrame = function (id: number) {\n blockedRAFs.delete(id);\n return origCancel.call(window, id);\n };\n }\n\n function restoreRAF() {\n if (originalRAF) {\n window.requestAnimationFrame = originalRAF;\n originalRAF = null;\n }\n rafLoopTracker.clear();\n blockedRAFs.clear();\n }\n\n // -------------------------------------------------------------------------\n // Layer 3: MutationObserver — catch dynamically added animated elements\n // -------------------------------------------------------------------------\n\n function setupMutationObserver() {\n if (mutationObserver) return;\n\n mutationObserver = new MutationObserver((mutations) => {\n if (!enabled) return;\n for (const mutation of mutations) {\n for (const node of mutation.addedNodes) {\n if (!(node instanceof HTMLElement)) continue;\n // Pause animations on newly added elements\n try {\n const anims = node.getAnimations({ subtree: true });\n for (const anim of anims) {\n if (anim.playState === 'running' || anim.playState === 'pending') {\n anim.pause();\n pausedAnimations.push(anim);\n }\n }\n } catch { /* not supported */ }\n\n // Pause new videos\n if (node.tagName === 'VIDEO') {\n const video = node as HTMLVideoElement;\n if (!video.paused) {\n video.pause();\n pausedVideos.push(video);\n }\n }\n node.querySelectorAll?.('video')?.forEach((video) => {\n if (!video.paused) {\n video.pause();\n pausedVideos.push(video);\n }\n });\n\n // Freeze new GIFs\n if (node.tagName === 'IMG') {\n freezeGif(node as HTMLImageElement);\n }\n node.querySelectorAll?.('img')?.forEach((img) => freezeGif(img));\n\n // Fix Framer appear elements added dynamically\n if (node.hasAttribute?.('data-framer-appear-id')) {\n forceFramerAppearVisibleSingle(node);\n }\n node.querySelectorAll?.('[data-framer-appear-id]')?.forEach((el) => {\n forceFramerAppearVisibleSingle(el as HTMLElement);\n });\n }\n }\n });\n\n mutationObserver.observe(document.body, {\n childList: true,\n subtree: true,\n });\n }\n\n function disconnectMutationObserver() {\n mutationObserver?.disconnect();\n mutationObserver = null;\n }\n\n // -------------------------------------------------------------------------\n // Layer 4: prefers-reduced-motion emulation\n // -------------------------------------------------------------------------\n\n function emulateReducedMotion() {\n if (originalMatchMedia) return;\n originalMatchMedia = window.matchMedia;\n\n window.matchMedia = function (query: string): MediaQueryList {\n const mql = originalMatchMedia!.call(window, query);\n\n if (query.includes('prefers-reduced-motion')) {\n // Return a proxy that always reports matches: true\n const proxy = Object.create(mql);\n Object.defineProperty(proxy, 'matches', { get: () => enabled, configurable: true });\n Object.defineProperty(proxy, 'media', { get: () => query, configurable: true });\n return proxy;\n }\n return mql;\n };\n\n // Trigger change event on existing reduced-motion media queries\n // so frameworks (Framer Motion, GSAP) react immediately\n try {\n const mql = originalMatchMedia.call(window, '(prefers-reduced-motion: reduce)');\n mql.dispatchEvent(new MediaQueryListEvent('change', { matches: true, media: mql.media }));\n } catch { /* older browsers */ }\n }\n\n function restoreMatchMedia() {\n if (originalMatchMedia) {\n window.matchMedia = originalMatchMedia;\n originalMatchMedia = null;\n\n // Dispatch change event to signal motion is allowed again\n try {\n const mql = window.matchMedia('(prefers-reduced-motion: reduce)');\n mql.dispatchEvent(new MediaQueryListEvent('change', { matches: mql.matches, media: mql.media }));\n } catch { /* older browsers */ }\n }\n }\n\n // -------------------------------------------------------------------------\n // Layer 5: GIF freeze — replace with static first frame\n // -------------------------------------------------------------------------\n\n function freezeGif(img: HTMLImageElement) {\n const src = img.src || img.getAttribute('src') || '';\n if (!src.toLowerCase().includes('.gif')) return;\n if (gifOriginals.has(img)) return;\n\n const freeze = () => {\n try {\n const canvas = document.createElement('canvas');\n canvas.width = img.naturalWidth || img.width;\n canvas.height = img.naturalHeight || img.height;\n if (canvas.width === 0 || canvas.height === 0) return;\n const ctx = canvas.getContext('2d');\n if (!ctx) return;\n ctx.drawImage(img, 0, 0);\n gifOriginals.set(img, src);\n img.src = canvas.toDataURL('image/png');\n } catch { /* cross-origin, skip */ }\n };\n\n if (img.complete && img.naturalWidth > 0) {\n freeze();\n } else {\n img.addEventListener('load', freeze, { once: true });\n }\n }\n\n function freezeAllGifs() {\n document.querySelectorAll<HTMLImageElement>('img').forEach(freezeGif);\n }\n\n function restoreGifs() {\n for (const [img, originalSrc] of gifOriginals) {\n try { img.src = originalSrc; } catch { /* element may be gone */ }\n }\n gifOriginals.clear();\n }\n\n // -------------------------------------------------------------------------\n // Layer 6: Framer appear animations — force visible\n // Framer renders elements with opacity:0.001 + will-change:transform and\n // animates them in via JS. When we stop animations, they stay invisible.\n // Fix: force all Framer appear elements to their final visible state.\n // -------------------------------------------------------------------------\n\n const FRAMER_FIXED_ATTR = 'data-accessify-framer-fixed';\n let framerFixedElements: Array<{ el: HTMLElement; origStyle: string }> = [];\n\n function forceFramerAppearVisible() {\n // Framer appear elements — force opacity only, NEVER touch transform (breaks layout)\n const appearEls = document.querySelectorAll<HTMLElement>('[data-framer-appear-id]');\n for (const el of appearEls) {\n if (el.hasAttribute(FRAMER_FIXED_ATTR)) continue;\n if (el.closest('#accessify-root')) continue;\n const computed = getComputedStyle(el);\n const opacity = parseFloat(computed.opacity);\n if (opacity < 0.5) {\n framerFixedElements.push({ el, origStyle: el.getAttribute('style') || '' });\n el.style.setProperty('opacity', '1', 'important');\n el.setAttribute(FRAMER_FIXED_ATTR, 'true');\n }\n }\n\n // Generic: any element with very low opacity + will-change:transform\n const allWillChange = document.querySelectorAll<HTMLElement>('[style*=\"will-change\"]');\n for (const el of allWillChange) {\n if (el.hasAttribute(FRAMER_FIXED_ATTR)) continue;\n if (el.closest('#accessify-root')) continue;\n const computed = getComputedStyle(el);\n const opacity = parseFloat(computed.opacity);\n if (opacity < 0.05 && computed.willChange.includes('transform')) {\n framerFixedElements.push({ el, origStyle: el.getAttribute('style') || '' });\n el.style.setProperty('opacity', '1', 'important');\n el.setAttribute(FRAMER_FIXED_ATTR, 'true');\n }\n }\n }\n\n function restoreFramerAppear() {\n for (const { el, origStyle } of framerFixedElements) {\n try {\n el.setAttribute('style', origStyle);\n el.removeAttribute(FRAMER_FIXED_ATTR);\n } catch { /* element may be gone */ }\n }\n framerFixedElements = [];\n }\n\n function forceFramerAppearVisibleSingle(el: HTMLElement) {\n if (el.hasAttribute(FRAMER_FIXED_ATTR)) return;\n if (el.closest('#accessify-root')) return;\n const computed = getComputedStyle(el);\n const opacity = parseFloat(computed.opacity);\n if (opacity < 0.5) {\n framerFixedElements.push({ el, origStyle: el.getAttribute('style') || '' });\n el.style.setProperty('opacity', '1', 'important');\n el.setAttribute(FRAMER_FIXED_ATTR, 'true');\n }\n }\n\n // -------------------------------------------------------------------------\n // Layer 8: Style attribute mutation observer — counter inline style animations\n // Framer, GSAP, and other JS libs set transform/opacity directly via\n // element.style on every frame. CSS !important should win, but some libs\n // use setProperty with 'important' or the style attribute gets fully\n // rewritten. This observer catches and re-forces visibility.\n // -------------------------------------------------------------------------\n\n function setupStyleObserver() {\n if (styleObserver) return;\n let isOurChange = false;\n\n styleObserver = new MutationObserver((mutations) => {\n if (!enabled || isOurChange) return;\n isOurChange = true;\n\n for (const m of mutations) {\n if (m.type !== 'attributes' || m.attributeName !== 'style') continue;\n const el = m.target as HTMLElement;\n if (el.closest('#accessify-root')) continue;\n\n // Only act on Framer appear elements\n if (!el.hasAttribute('data-framer-appear-id')) continue;\n\n const opacity = parseFloat(el.style.opacity);\n if (!isNaN(opacity) && opacity < 0.5) {\n el.style.setProperty('opacity', '1', 'important');\n }\n }\n\n isOurChange = false;\n });\n\n styleObserver.observe(document.body, {\n attributes: true,\n attributeFilter: ['style'],\n subtree: true,\n });\n }\n\n function disconnectStyleObserver() {\n styleObserver?.disconnect();\n styleObserver = null;\n }\n\n // -------------------------------------------------------------------------\n // Layer 9: Delayed re-scans — Framer loads async, elements appear late\n // -------------------------------------------------------------------------\n\n function scheduleDelayedScans() {\n const delays = [500, 1000, 2000, 4000];\n for (const delay of delays) {\n const timer = setTimeout(() => {\n if (!enabled) return;\n forceAllHiddenVisible();\n pauseAllWebAnimations();\n freezeAllGifs();\n pauseSVGAnimations();\n stopMarquees();\n }, delay);\n delayedTimers.push(timer);\n }\n }\n\n function clearDelayedScans() {\n for (const timer of delayedTimers) clearTimeout(timer);\n delayedTimers = [];\n }\n\n // -------------------------------------------------------------------------\n // Force ALL hidden animation targets visible — aggressive sweep\n // -------------------------------------------------------------------------\n\n function forceAllHiddenVisible() {\n // 1. Framer appear elements\n forceFramerAppearVisible();\n\n // 2. Targeted sweep: only elements that are clearly animation-hidden\n // (very low opacity + animation-related attributes)\n const candidates = document.querySelectorAll<HTMLElement>(\n '[data-framer-appear-id], [style*=\"opacity:0.0\"], [style*=\"opacity: 0.0\"]'\n );\n for (const el of candidates) {\n if (el.hasAttribute(FRAMER_FIXED_ATTR)) continue;\n if (el.closest('#accessify-root')) continue;\n const computed = getComputedStyle(el);\n const opacity = parseFloat(computed.opacity);\n if (opacity < 0.05) {\n frozenInlineElements.set(el, el.getAttribute('style') || '');\n el.style.setProperty('opacity', '1', 'important');\n el.setAttribute(FRAMER_FIXED_ATTR, 'true');\n }\n }\n }\n\n function restoreFrozenInlineElements() {\n for (const [el, origStyle] of frozenInlineElements) {\n try {\n el.setAttribute('style', origStyle);\n el.removeAttribute(FRAMER_FIXED_ATTR);\n } catch { /* element may be gone */ }\n }\n frozenInlineElements.clear();\n }\n\n // -------------------------------------------------------------------------\n // Layer 7: Marquee & SVG SMIL animations\n // -------------------------------------------------------------------------\n\n function stopMarquees() {\n document.querySelectorAll('marquee').forEach((el) => {\n try { (el as any).stop(); } catch { /* not supported */ }\n });\n }\n\n function startMarquees() {\n document.querySelectorAll('marquee').forEach((el) => {\n try { (el as any).start(); } catch { /* not supported */ }\n });\n }\n\n function pauseSVGAnimations() {\n document.querySelectorAll('svg').forEach((svg) => {\n try {\n if (typeof (svg as any).pauseAnimations === 'function') {\n (svg as any).pauseAnimations();\n }\n } catch { /* not supported */ }\n });\n }\n\n function resumeSVGAnimations() {\n document.querySelectorAll('svg').forEach((svg) => {\n try {\n if (typeof (svg as any).unpauseAnimations === 'function') {\n (svg as any).unpauseAnimations();\n }\n } catch { /* not supported */ }\n });\n }\n\n // -------------------------------------------------------------------------\n // Video control — pause all videos + intercept play()\n // -------------------------------------------------------------------------\n\n let originalVideoPlay: typeof HTMLVideoElement.prototype.play | null = null;\n\n function pauseAutoplayVideos() {\n const videos = document.querySelectorAll<HTMLVideoElement>('video');\n pausedVideos = [];\n videos.forEach((video) => {\n if (!video.paused) {\n video.pause();\n pausedVideos.push(video);\n }\n });\n\n // Also remove autoplay attribute to prevent re-play\n videos.forEach((video) => {\n if (video.hasAttribute('autoplay')) {\n video.dataset.accessifyAutoplay = 'true';\n video.removeAttribute('autoplay');\n }\n });\n\n // Override play() to prevent JS from starting videos\n if (!originalVideoPlay) {\n originalVideoPlay = HTMLVideoElement.prototype.play;\n HTMLVideoElement.prototype.play = function () {\n if (enabled) {\n // Block autoplay, return resolved promise to avoid errors\n return Promise.resolve();\n }\n return originalVideoPlay!.call(this);\n };\n }\n }\n\n function resumePausedVideos() {\n // Restore play()\n if (originalVideoPlay) {\n HTMLVideoElement.prototype.play = originalVideoPlay;\n originalVideoPlay = null;\n }\n\n // Restore autoplay attributes\n document.querySelectorAll<HTMLVideoElement>('video[data-accessify-autoplay]').forEach((video) => {\n video.setAttribute('autoplay', '');\n delete video.dataset.accessifyAutoplay;\n });\n\n // Resume previously paused videos\n pausedVideos.forEach((video) => {\n try { video.play(); } catch { /* removed from DOM */ }\n });\n pausedVideos = [];\n }\n\n // -------------------------------------------------------------------------\n // Lifecycle\n // -------------------------------------------------------------------------\n\n function activate() {\n if (enabled) return;\n enabled = true;\n\n // Layer 0: CSS overrides (includes Framer-specific !important rules)\n injectStyles();\n\n // Layer 1: Web Animations API\n pauseAllWebAnimations();\n overrideElementAnimate();\n\n // Layer 2: RAF loop detection\n overrideRAF();\n\n // Layer 3: MutationObserver for dynamic content\n setupMutationObserver();\n\n // Layer 4: prefers-reduced-motion emulation\n emulateReducedMotion();\n\n // Layer 5: GIF freeze\n freezeAllGifs();\n\n // Layer 6: Framer appear — force visible\n forceFramerAppearVisible();\n\n // Layer 7: Marquee & SVG SMIL\n stopMarquees();\n pauseSVGAnimations();\n\n // Layer 8: Style attribute mutation observer (counters Framer inline style updates)\n setupStyleObserver();\n\n // Layer 9: Delayed re-scans (Framer loads elements async)\n scheduleDelayedScans();\n\n // Videos\n pauseAutoplayVideos();\n\n // Aggressive sweep — force all hidden animation targets visible\n forceAllHiddenVisible();\n\n localStorage.setItem(STORAGE_KEY, 'true');\n }\n\n function deactivate() {\n enabled = false;\n\n // Reverse order for clean teardown\n clearDelayedScans();\n disconnectStyleObserver();\n restoreFrozenInlineElements();\n resumePausedVideos();\n resumeSVGAnimations();\n startMarquees();\n restoreFramerAppear();\n restoreGifs();\n restoreMatchMedia();\n disconnectMutationObserver();\n restoreRAF();\n restoreElementAnimate();\n resumePausedAnimations();\n removeStyles();\n\n localStorage.removeItem(STORAGE_KEY);\n }\n\n return {\n id: 'animation-stop',\n name: () => 'Stop Animations',\n description: 'Pause all animations, transitions, and auto-playing videos (WCAG 2.3.1)',\n icon: 'animation-stop',\n category: 'visual',\n activate,\n deactivate,\n getState: (): FeatureState => ({\n id: 'animation-stop',\n enabled,\n }),\n setState: (state: { enabled: boolean }) => {\n if (state.enabled) {\n activate();\n } else {\n deactivate();\n }\n },\n };\n}\n"],"names":[],"mappings":"AAEA,SAAwB,4BAA2C;AACjE,MAAI,UAAU;AACd,QAAM,WAAW;AACjB,QAAM,cAAc;AAGpB,MAAI,eAAmC,CAAA;AACvC,MAAI,mBAAgC,CAAA;AACpC,MAAI,kBAA2D;AAC/D,MAAI,cAA0D;AAC9D,MAAI,qBAAsD;AAC1D,MAAI,mBAA4C;AAChD,MAAI,qCAAqB,IAAA;AACzB,MAAI,kCAAkB,IAAA;AACtB,MAAI,mCAAmB,IAAA;AAEvB,MAAI,gBAAyC;AAC7C,MAAI,gBAAiD,CAAA;AACrD,MAAI,2CAA2B,IAAA;AAM/B,WAAS,YAAoB;AAC3B,WAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAwBT;AAEA,WAAS,eAAe;AACtB,QAAI,UAAU,SAAS,eAAe,QAAQ;AAC9C,QAAI,CAAC,SAAS;AACZ,gBAAU,SAAS,cAAc,OAAO;AACxC,cAAQ,KAAK;AACb,eAAS,KAAK,YAAY,OAAO;AAAA,IACnC;AACA,YAAQ,cAAc,UAAA;AAAA,EACxB;AAEA,WAAS,eAAe;AACtB,aAAS,eAAe,QAAQ,GAAG,OAAA;AAAA,EACrC;AAMA,WAAS,wBAAwB;AAC/B,QAAI;AACF,YAAM,aAAa,SAAS,cAAA;AAC5B,iBAAW,QAAQ,YAAY;AAC7B,YAAI,KAAK,cAAc,aAAa,KAAK,cAAc,WAAW;AAChE,eAAK,MAAA;AACL,2BAAiB,KAAK,IAAI;AAAA,QAC5B;AAAA,MACF;AAAA,IACF,QAAQ;AAAA,IAAoC;AAAA,EAC9C;AAEA,WAAS,yBAAyB;AAChC,QAAI,gBAAiB;AACrB,sBAAkB,QAAQ,UAAU;AAEpC,YAAQ,UAAU,UAAU,SAE1B,WACA,SACW;AACX,YAAM,OAAO,gBAAiB,KAAK,MAAM,WAAW,OAAO;AAC3D,UAAI,SAAS;AACX,aAAK,MAAA;AACL,yBAAiB,KAAK,IAAI;AAAA,MAC5B;AACA,aAAO;AAAA,IACT;AAAA,EACF;AAEA,WAAS,wBAAwB;AAC/B,QAAI,iBAAiB;AACnB,cAAQ,UAAU,UAAU;AAC5B,wBAAkB;AAAA,IACpB;AAAA,EACF;AAEA,WAAS,yBAAyB;AAChC,eAAW,QAAQ,kBAAkB;AACnC,UAAI;AAAE,aAAK,KAAA;AAAA,MAAQ,QAAQ;AAAA,MAA8B;AAAA,IAC3D;AACA,uBAAmB,CAAA;AAAA,EACrB;AAMA,WAAS,cAAc;AACrB,QAAI,YAAa;AACjB,kBAAc,OAAO;AACrB,UAAM,aAAa,OAAO;AAE1B,WAAO,wBAAwB,SAAU,UAAwC;AAC/E,UAAI,CAAC,QAAS,QAAO,YAAa,KAAK,QAAQ,QAAQ;AAGvD,YAAM,MAAM,SAAS,SAAA,EAAW,MAAM,GAAG,GAAG;AAC5C,YAAM,MAAM,YAAY,IAAA;AACxB,YAAM,QAAQ,eAAe,IAAI,GAAG;AAEpC,UAAI,OAAO;AACT,cAAM;AACN,YAAI,MAAM,MAAM,WAAW,OAAO,MAAM,QAAQ,GAAG;AAEjD,gBAAM,KAAK,YAAa,KAAK,QAAQ,MAAM;AAAA,UAAC,CAAC;AAC7C,sBAAY,IAAI,EAAE;AAClB,iBAAO;AAAA,QACT;AACA,cAAM,WAAW;AAAA,MACnB,OAAO;AACL,uBAAe,IAAI,KAAK,EAAE,OAAO,GAAG,UAAU,KAAK;AAAA,MACrD;AAGA,aAAO,YAAa,KAAK,QAAQ,QAAQ;AAAA,IAC3C;AAEA,WAAO,uBAAuB,SAAU,IAAY;AAClD,kBAAY,OAAO,EAAE;AACrB,aAAO,WAAW,KAAK,QAAQ,EAAE;AAAA,IACnC;AAAA,EACF;AAEA,WAAS,aAAa;AACpB,QAAI,aAAa;AACf,aAAO,wBAAwB;AAC/B,oBAAc;AAAA,IAChB;AACA,mBAAe,MAAA;AACf,gBAAY,MAAA;AAAA,EACd;AAMA,WAAS,wBAAwB;AAC/B,QAAI,iBAAkB;AAEtB,uBAAmB,IAAI,iBAAiB,CAAC,cAAc;AACrD,UAAI,CAAC,QAAS;AACd,iBAAW,YAAY,WAAW;AAChC,mBAAW,QAAQ,SAAS,YAAY;AACtC,cAAI,EAAE,gBAAgB,aAAc;AAEpC,cAAI;AACF,kBAAM,QAAQ,KAAK,cAAc,EAAE,SAAS,MAAM;AAClD,uBAAW,QAAQ,OAAO;AACxB,kBAAI,KAAK,cAAc,aAAa,KAAK,cAAc,WAAW;AAChE,qBAAK,MAAA;AACL,iCAAiB,KAAK,IAAI;AAAA,cAC5B;AAAA,YACF;AAAA,UACF,QAAQ;AAAA,UAAsB;AAG9B,cAAI,KAAK,YAAY,SAAS;AAC5B,kBAAM,QAAQ;AACd,gBAAI,CAAC,MAAM,QAAQ;AACjB,oBAAM,MAAA;AACN,2BAAa,KAAK,KAAK;AAAA,YACzB;AAAA,UACF;AACA,eAAK,mBAAmB,OAAO,GAAG,QAAQ,CAAC,UAAU;AACnD,gBAAI,CAAC,MAAM,QAAQ;AACjB,oBAAM,MAAA;AACN,2BAAa,KAAK,KAAK;AAAA,YACzB;AAAA,UACF,CAAC;AAGD,cAAI,KAAK,YAAY,OAAO;AAC1B,sBAAU,IAAwB;AAAA,UACpC;AACA,eAAK,mBAAmB,KAAK,GAAG,QAAQ,CAAC,QAAQ,UAAU,GAAG,CAAC;AAG/D,cAAI,KAAK,eAAe,uBAAuB,GAAG;AAChD,2CAA+B,IAAI;AAAA,UACrC;AACA,eAAK,mBAAmB,yBAAyB,GAAG,QAAQ,CAAC,OAAO;AAClE,2CAA+B,EAAiB;AAAA,UAClD,CAAC;AAAA,QACH;AAAA,MACF;AAAA,IACF,CAAC;AAED,qBAAiB,QAAQ,SAAS,MAAM;AAAA,MACtC,WAAW;AAAA,MACX,SAAS;AAAA,IAAA,CACV;AAAA,EACH;AAEA,WAAS,6BAA6B;AACpC,sBAAkB,WAAA;AAClB,uBAAmB;AAAA,EACrB;AAMA,WAAS,uBAAuB;AAC9B,QAAI,mBAAoB;AACxB,yBAAqB,OAAO;AAE5B,WAAO,aAAa,SAAU,OAA+B;AAC3D,YAAM,MAAM,mBAAoB,KAAK,QAAQ,KAAK;AAElD,UAAI,MAAM,SAAS,wBAAwB,GAAG;AAE5C,cAAM,QAAQ,OAAO,OAAO,GAAG;AAC/B,eAAO,eAAe,OAAO,WAAW,EAAE,KAAK,MAAM,SAAS,cAAc,MAAM;AAClF,eAAO,eAAe,OAAO,SAAS,EAAE,KAAK,MAAM,OAAO,cAAc,MAAM;AAC9E,eAAO;AAAA,MACT;AACA,aAAO;AAAA,IACT;AAIA,QAAI;AACF,YAAM,MAAM,mBAAmB,KAAK,QAAQ,kCAAkC;AAC9E,UAAI,cAAc,IAAI,oBAAoB,UAAU,EAAE,SAAS,MAAM,OAAO,IAAI,MAAA,CAAO,CAAC;AAAA,IAC1F,QAAQ;AAAA,IAAuB;AAAA,EACjC;AAEA,WAAS,oBAAoB;AAC3B,QAAI,oBAAoB;AACtB,aAAO,aAAa;AACpB,2BAAqB;AAGrB,UAAI;AACF,cAAM,MAAM,OAAO,WAAW,kCAAkC;AAChE,YAAI,cAAc,IAAI,oBAAoB,UAAU,EAAE,SAAS,IAAI,SAAS,OAAO,IAAI,MAAA,CAAO,CAAC;AAAA,MACjG,QAAQ;AAAA,MAAuB;AAAA,IACjC;AAAA,EACF;AAMA,WAAS,UAAU,KAAuB;AACxC,UAAM,MAAM,IAAI,OAAO,IAAI,aAAa,KAAK,KAAK;AAClD,QAAI,CAAC,IAAI,YAAA,EAAc,SAAS,MAAM,EAAG;AACzC,QAAI,aAAa,IAAI,GAAG,EAAG;AAE3B,UAAM,SAAS,MAAM;AACnB,UAAI;AACF,cAAM,SAAS,SAAS,cAAc,QAAQ;AAC9C,eAAO,QAAQ,IAAI,gBAAgB,IAAI;AACvC,eAAO,SAAS,IAAI,iBAAiB,IAAI;AACzC,YAAI,OAAO,UAAU,KAAK,OAAO,WAAW,EAAG;AAC/C,cAAM,MAAM,OAAO,WAAW,IAAI;AAClC,YAAI,CAAC,IAAK;AACV,YAAI,UAAU,KAAK,GAAG,CAAC;AACvB,qBAAa,IAAI,KAAK,GAAG;AACzB,YAAI,MAAM,OAAO,UAAU,WAAW;AAAA,MACxC,QAAQ;AAAA,MAA2B;AAAA,IACrC;AAEA,QAAI,IAAI,YAAY,IAAI,eAAe,GAAG;AACxC,aAAA;AAAA,IACF,OAAO;AACL,UAAI,iBAAiB,QAAQ,QAAQ,EAAE,MAAM,MAAM;AAAA,IACrD;AAAA,EACF;AAEA,WAAS,gBAAgB;AACvB,aAAS,iBAAmC,KAAK,EAAE,QAAQ,SAAS;AAAA,EACtE;AAEA,WAAS,cAAc;AACrB,eAAW,CAAC,KAAK,WAAW,KAAK,cAAc;AAC7C,UAAI;AAAE,YAAI,MAAM;AAAA,MAAa,QAAQ;AAAA,MAA4B;AAAA,IACnE;AACA,iBAAa,MAAA;AAAA,EACf;AASA,QAAM,oBAAoB;AAC1B,MAAI,sBAAqE,CAAA;AAEzE,WAAS,2BAA2B;AAElC,UAAM,YAAY,SAAS,iBAA8B,yBAAyB;AAClF,eAAW,MAAM,WAAW;AAC1B,UAAI,GAAG,aAAa,iBAAiB,EAAG;AACxC,UAAI,GAAG,QAAQ,iBAAiB,EAAG;AACnC,YAAM,WAAW,iBAAiB,EAAE;AACpC,YAAM,UAAU,WAAW,SAAS,OAAO;AAC3C,UAAI,UAAU,KAAK;AACjB,4BAAoB,KAAK,EAAE,IAAI,WAAW,GAAG,aAAa,OAAO,KAAK,IAAI;AAC1E,WAAG,MAAM,YAAY,WAAW,KAAK,WAAW;AAChD,WAAG,aAAa,mBAAmB,MAAM;AAAA,MAC3C;AAAA,IACF;AAGA,UAAM,gBAAgB,SAAS,iBAA8B,wBAAwB;AACrF,eAAW,MAAM,eAAe;AAC9B,UAAI,GAAG,aAAa,iBAAiB,EAAG;AACxC,UAAI,GAAG,QAAQ,iBAAiB,EAAG;AACnC,YAAM,WAAW,iBAAiB,EAAE;AACpC,YAAM,UAAU,WAAW,SAAS,OAAO;AAC3C,UAAI,UAAU,QAAQ,SAAS,WAAW,SAAS,WAAW,GAAG;AAC/D,4BAAoB,KAAK,EAAE,IAAI,WAAW,GAAG,aAAa,OAAO,KAAK,IAAI;AAC1E,WAAG,MAAM,YAAY,WAAW,KAAK,WAAW;AAChD,WAAG,aAAa,mBAAmB,MAAM;AAAA,MAC3C;AAAA,IACF;AAAA,EACF;AAEA,WAAS,sBAAsB;AAC7B,eAAW,EAAE,IAAI,UAAA,KAAe,qBAAqB;AACnD,UAAI;AACF,WAAG,aAAa,SAAS,SAAS;AAClC,WAAG,gBAAgB,iBAAiB;AAAA,MACtC,QAAQ;AAAA,MAA4B;AAAA,IACtC;AACA,0BAAsB,CAAA;AAAA,EACxB;AAEA,WAAS,+BAA+B,IAAiB;AACvD,QAAI,GAAG,aAAa,iBAAiB,EAAG;AACxC,QAAI,GAAG,QAAQ,iBAAiB,EAAG;AACnC,UAAM,WAAW,iBAAiB,EAAE;AACpC,UAAM,UAAU,WAAW,SAAS,OAAO;AAC3C,QAAI,UAAU,KAAK;AACjB,0BAAoB,KAAK,EAAE,IAAI,WAAW,GAAG,aAAa,OAAO,KAAK,IAAI;AAC1E,SAAG,MAAM,YAAY,WAAW,KAAK,WAAW;AAChD,SAAG,aAAa,mBAAmB,MAAM;AAAA,IAC3C;AAAA,EACF;AAUA,WAAS,qBAAqB;AAC5B,QAAI,cAAe;AACnB,QAAI,cAAc;AAElB,oBAAgB,IAAI,iBAAiB,CAAC,cAAc;AAClD,UAAI,CAAC,WAAW,YAAa;AAC7B,oBAAc;AAEd,iBAAW,KAAK,WAAW;AACzB,YAAI,EAAE,SAAS,gBAAgB,EAAE,kBAAkB,QAAS;AAC5D,cAAM,KAAK,EAAE;AACb,YAAI,GAAG,QAAQ,iBAAiB,EAAG;AAGnC,YAAI,CAAC,GAAG,aAAa,uBAAuB,EAAG;AAE/C,cAAM,UAAU,WAAW,GAAG,MAAM,OAAO;AAC3C,YAAI,CAAC,MAAM,OAAO,KAAK,UAAU,KAAK;AACpC,aAAG,MAAM,YAAY,WAAW,KAAK,WAAW;AAAA,QAClD;AAAA,MACF;AAEA,oBAAc;AAAA,IAChB,CAAC;AAED,kBAAc,QAAQ,SAAS,MAAM;AAAA,MACnC,YAAY;AAAA,MACZ,iBAAiB,CAAC,OAAO;AAAA,MACzB,SAAS;AAAA,IAAA,CACV;AAAA,EACH;AAEA,WAAS,0BAA0B;AACjC,mBAAe,WAAA;AACf,oBAAgB;AAAA,EAClB;AAMA,WAAS,uBAAuB;AAC9B,UAAM,SAAS,CAAC,KAAK,KAAM,KAAM,GAAI;AACrC,eAAW,SAAS,QAAQ;AAC1B,YAAM,QAAQ,WAAW,MAAM;AAC7B,YAAI,CAAC,QAAS;AACd,8BAAA;AACA,8BAAA;AACA,sBAAA;AACA,2BAAA;AACA,qBAAA;AAAA,MACF,GAAG,KAAK;AACR,oBAAc,KAAK,KAAK;AAAA,IAC1B;AAAA,EACF;AAEA,WAAS,oBAAoB;AAC3B,eAAW,SAAS,cAAe,cAAa,KAAK;AACrD,oBAAgB,CAAA;AAAA,EAClB;AAMA,WAAS,wBAAwB;AAE/B,6BAAA;AAIA,UAAM,aAAa,SAAS;AAAA,MAC1B;AAAA,IAAA;AAEF,eAAW,MAAM,YAAY;AAC3B,UAAI,GAAG,aAAa,iBAAiB,EAAG;AACxC,UAAI,GAAG,QAAQ,iBAAiB,EAAG;AACnC,YAAM,WAAW,iBAAiB,EAAE;AACpC,YAAM,UAAU,WAAW,SAAS,OAAO;AAC3C,UAAI,UAAU,MAAM;AAClB,6BAAqB,IAAI,IAAI,GAAG,aAAa,OAAO,KAAK,EAAE;AAC3D,WAAG,MAAM,YAAY,WAAW,KAAK,WAAW;AAChD,WAAG,aAAa,mBAAmB,MAAM;AAAA,MAC3C;AAAA,IACF;AAAA,EACF;AAEA,WAAS,8BAA8B;AACrC,eAAW,CAAC,IAAI,SAAS,KAAK,sBAAsB;AAClD,UAAI;AACF,WAAG,aAAa,SAAS,SAAS;AAClC,WAAG,gBAAgB,iBAAiB;AAAA,MACtC,QAAQ;AAAA,MAA4B;AAAA,IACtC;AACA,yBAAqB,MAAA;AAAA,EACvB;AAMA,WAAS,eAAe;AACtB,aAAS,iBAAiB,SAAS,EAAE,QAAQ,CAAC,OAAO;AACnD,UAAI;AAAG,WAAW,KAAA;AAAA,MAAQ,QAAQ;AAAA,MAAsB;AAAA,IAC1D,CAAC;AAAA,EACH;AAEA,WAAS,gBAAgB;AACvB,aAAS,iBAAiB,SAAS,EAAE,QAAQ,CAAC,OAAO;AACnD,UAAI;AAAG,WAAW,MAAA;AAAA,MAAS,QAAQ;AAAA,MAAsB;AAAA,IAC3D,CAAC;AAAA,EACH;AAEA,WAAS,qBAAqB;AAC5B,aAAS,iBAAiB,KAAK,EAAE,QAAQ,CAAC,QAAQ;AAChD,UAAI;AACF,YAAI,OAAQ,IAAY,oBAAoB,YAAY;AACrD,cAAY,gBAAA;AAAA,QACf;AAAA,MACF,QAAQ;AAAA,MAAsB;AAAA,IAChC,CAAC;AAAA,EACH;AAEA,WAAS,sBAAsB;AAC7B,aAAS,iBAAiB,KAAK,EAAE,QAAQ,CAAC,QAAQ;AAChD,UAAI;AACF,YAAI,OAAQ,IAAY,sBAAsB,YAAY;AACvD,cAAY,kBAAA;AAAA,QACf;AAAA,MACF,QAAQ;AAAA,MAAsB;AAAA,IAChC,CAAC;AAAA,EACH;AAMA,MAAI,oBAAmE;AAEvE,WAAS,sBAAsB;AAC7B,UAAM,SAAS,SAAS,iBAAmC,OAAO;AAClE,mBAAe,CAAA;AACf,WAAO,QAAQ,CAAC,UAAU;AACxB,UAAI,CAAC,MAAM,QAAQ;AACjB,cAAM,MAAA;AACN,qBAAa,KAAK,KAAK;AAAA,MACzB;AAAA,IACF,CAAC;AAGD,WAAO,QAAQ,CAAC,UAAU;AACxB,UAAI,MAAM,aAAa,UAAU,GAAG;AAClC,cAAM,QAAQ,oBAAoB;AAClC,cAAM,gBAAgB,UAAU;AAAA,MAClC;AAAA,IACF,CAAC;AAGD,QAAI,CAAC,mBAAmB;AACtB,0BAAoB,iBAAiB,UAAU;AAC/C,uBAAiB,UAAU,OAAO,WAAY;AAC5C,YAAI,SAAS;AAEX,iBAAO,QAAQ,QAAA;AAAA,QACjB;AACA,eAAO,kBAAmB,KAAK,IAAI;AAAA,MACrC;AAAA,IACF;AAAA,EACF;AAEA,WAAS,qBAAqB;AAE5B,QAAI,mBAAmB;AACrB,uBAAiB,UAAU,OAAO;AAClC,0BAAoB;AAAA,IACtB;AAGA,aAAS,iBAAmC,gCAAgC,EAAE,QAAQ,CAAC,UAAU;AAC/F,YAAM,aAAa,YAAY,EAAE;AACjC,aAAO,MAAM,QAAQ;AAAA,IACvB,CAAC;AAGD,iBAAa,QAAQ,CAAC,UAAU;AAC9B,UAAI;AAAE,cAAM,KAAA;AAAA,MAAQ,QAAQ;AAAA,MAAyB;AAAA,IACvD,CAAC;AACD,mBAAe,CAAA;AAAA,EACjB;AAMA,WAAS,WAAW;AAClB,QAAI,QAAS;AACb,cAAU;AAGV,iBAAA;AAGA,0BAAA;AACA,2BAAA;AAGA,gBAAA;AAGA,0BAAA;AAGA,yBAAA;AAGA,kBAAA;AAGA,6BAAA;AAGA,iBAAA;AACA,uBAAA;AAGA,uBAAA;AAGA,yBAAA;AAGA,wBAAA;AAGA,0BAAA;AAEA,iBAAa,QAAQ,aAAa,MAAM;AAAA,EAC1C;AAEA,WAAS,aAAa;AACpB,cAAU;AAGV,sBAAA;AACA,4BAAA;AACA,gCAAA;AACA,uBAAA;AACA,wBAAA;AACA,kBAAA;AACA,wBAAA;AACA,gBAAA;AACA,sBAAA;AACA,+BAAA;AACA,eAAA;AACA,0BAAA;AACA,2BAAA;AACA,iBAAA;AAEA,iBAAa,WAAW,WAAW;AAAA,EACrC;AAEA,SAAO;AAAA,IACL,IAAI;AAAA,IACJ,MAAM,MAAM;AAAA,IACZ,aAAa;AAAA,IACb,MAAM;AAAA,IACN,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA,UAAU,OAAqB;AAAA,MAC7B,IAAI;AAAA,MACJ;AAAA,IAAA;AAAA,IAEF,UAAU,CAAC,UAAgC;AACzC,UAAI,MAAM,SAAS;AACjB,iBAAA;AAAA,MACF,OAAO;AACL,mBAAA;AAAA,MACF;AAAA,IACF;AAAA,EAAA;AAEJ;"}
|
|
@@ -6310,14 +6310,14 @@ function FeatureGrid($$anchor, $$props) {
|
|
|
6310
6310
|
const FEATURE_LOADERS = {
|
|
6311
6311
|
contrast: () => import("./contrast-CqsICAkU.js"),
|
|
6312
6312
|
"text-size": () => import("./text-size-C6OFhCGi.js"),
|
|
6313
|
-
"keyboard-nav": () => import("./keyboard-nav-
|
|
6313
|
+
"keyboard-nav": () => import("./keyboard-nav-CZkiG72h.js"),
|
|
6314
6314
|
"link-highlight": () => import("./link-highlight-DBGm067Y.js"),
|
|
6315
6315
|
"reading-guide": () => import("./reading-guide-VT8NciIL.js"),
|
|
6316
6316
|
"reading-mask": () => import("./reading-mask-BABChuCz.js"),
|
|
6317
|
-
"animation-stop": () => import("./animation-stop-
|
|
6317
|
+
"animation-stop": () => import("./animation-stop-BUZdA2rS.js"),
|
|
6318
6318
|
"hide-images": () => import("./hide-images-B_LeCBcd.js"),
|
|
6319
6319
|
"big-cursor": () => import("./big-cursor-B2UKu9dQ.js"),
|
|
6320
|
-
"page-structure": () => import("./page-structure-
|
|
6320
|
+
"page-structure": () => import("./page-structure-BBNwb5cm.js"),
|
|
6321
6321
|
tts: () => import("./tts-CjszLRnb.js"),
|
|
6322
6322
|
"text-simplify": () => import("./text-simplify-B1v6Muvn.js"),
|
|
6323
6323
|
"alt-text": () => Promise.resolve().then(() => altText)
|
|
@@ -8400,4 +8400,4 @@ export {
|
|
|
8400
8400
|
init as i,
|
|
8401
8401
|
t
|
|
8402
8402
|
};
|
|
8403
|
-
//# sourceMappingURL=index-
|
|
8403
|
+
//# sourceMappingURL=index-B1it5VgN.js.map
|