next 15.1.1-canary.11 → 15.1.1-canary.12
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.
Potentially problematic release.
This version of next might be problematic. Click here for more details.
- package/dist/bin/next +1 -1
- package/dist/build/index.d.ts +5 -0
- package/dist/build/index.js +5 -2
- package/dist/build/index.js.map +1 -1
- package/dist/build/swc/index.js +1 -1
- package/dist/build/webpack-config.js +2 -2
- package/dist/client/app-bootstrap.js +1 -1
- package/dist/client/components/react-dev-overlay/_experimental/app/ReactDevOverlay.d.ts +18 -0
- package/dist/client/components/react-dev-overlay/_experimental/app/ReactDevOverlay.js +92 -0
- package/dist/client/components/react-dev-overlay/_experimental/app/ReactDevOverlay.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/CodeFrame.d.ts +7 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/CodeFrame.js +120 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/CodeFrame.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/index.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/index.js +19 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/styles.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/styles.js +30 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/styles.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/Dialog.d.ts +10 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/Dialog.js +86 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/Dialog.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogBody.d.ts +7 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogBody.js +29 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogBody.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogContent.d.ts +7 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogContent.js +29 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogContent.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogHeader.d.ts +7 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogHeader.js +29 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogHeader.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/index.d.ts +5 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/index.js +47 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/styles.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/styles.js +30 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Dialog/styles.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/LeftRightDialogHeader.d.ts +10 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/LeftRightDialogHeader.js +178 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/LeftRightDialogHeader.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/index.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/index.js +32 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/styles.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/styles.js +30 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/styles.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/Overlay.d.ts +8 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/Overlay.js +62 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/Overlay.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/body-locker.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/body-locker.js +62 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/body-locker.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/index.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/index.js +19 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/maintain--tab-focus.d.ts +3 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/maintain--tab-focus.js +2749 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/maintain--tab-focus.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/styles.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/styles.js +30 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Overlay/styles.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/ShadowPortal.d.ts +4 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/ShadowPortal.js +42 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/ShadowPortal.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/EditorLink.d.ts +10 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/EditorLink.js +67 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/EditorLink.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/Terminal.d.ts +5 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/Terminal.js +108 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/Terminal.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/index.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/index.js +19 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/styles.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/styles.js +30 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Terminal/styles.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/Toast.d.ts +7 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/Toast.js +36 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/Toast.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/index.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/index.js +32 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/styles.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/styles.js +30 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/Toast/styles.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/VersionStalenessInfo.d.ts +9 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/VersionStalenessInfo.js +103 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/VersionStalenessInfo.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/index.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/index.js +32 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/styles.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/styles.js +30 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/styles.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/copy-button/index.d.ts +7 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/copy-button/index.js +230 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/copy-button/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/hot-linked-text/index.d.ts +5 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/hot-linked-text/index.js +74 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/hot-linked-text/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/nodejs-inspector.d.ts +3 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/nodejs-inspector.js +119 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/components/nodejs-inspector.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/BuildError.d.ts +8 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/BuildError.js +100 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/BuildError.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/Errors.d.ts +19 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/Errors.js +392 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/Errors.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/CallStackFrame.d.ts +4 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/CallStackFrame.js +91 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/CallStackFrame.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/ComponentStackFrameRow.d.ts +4 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/ComponentStackFrameRow.js +116 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/ComponentStackFrameRow.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/component-stack-pseudo-html.d.ts +56 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/component-stack-pseudo-html.js +243 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/component-stack-pseudo-html.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/index.d.ts +6 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/index.js +92 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/index.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/StaticIndicator.d.ts +4 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/StaticIndicator.js +56 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/StaticIndicator.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/root-layout-missing-tags-error.d.ts +8 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/root-layout-missing-tags-error.js +59 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/container/root-layout-missing-tags-error.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/attach-hydration-error-state.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/attach-hydration-error-state.js +51 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/attach-hydration-error-state.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/console-error.d.ts +10 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/console-error.js +52 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/console-error.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/enqueue-client-error.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/enqueue-client-error.js +35 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/enqueue-client-error.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/format-webpack-messages.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/format-webpack-messages.js +164 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/format-webpack-messages.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-error-by-type.d.ts +11 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-error-by-type.js +50 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-error-by-type.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-socket-url.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-socket-url.js +38 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-socket-url.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-from-file.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-from-file.js +83 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-from-file.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-url.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-url.js +33 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-url.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/hydration-error-info.d.ts +20 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/hydration-error-info.js +104 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/hydration-error-info.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/launchEditor.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/launchEditor.js +407 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/launchEditor.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/node-stack-frames.d.ts +4 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/node-stack-frames.js +88 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/node-stack-frames.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/noop-template.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/noop-template.js +25 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/noop-template.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/parse-component-stack.d.ts +8 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/parse-component-stack.js +99 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/parse-component-stack.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/parse-stack.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/parse-stack.js +54 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/parse-stack.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/runtime-error-handler.d.ts +3 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/runtime-error-handler.js +21 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/runtime-error-handler.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/stack-frame.d.ts +11 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/stack-frame.js +140 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/stack-frame.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/stitched-error.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/stitched-error.js +57 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/stitched-error.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-error-handler.d.ts +4 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-error-handler.js +121 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-error-handler.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-open-in-editor.d.ts +5 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-open-in-editor.js +37 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-open-in-editor.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-websocket.d.ts +5 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-websocket.js +129 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/use-websocket.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/webpack-module-path.d.ts +12 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/webpack-module-path.js +50 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/webpack-module-path.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/helpers/webpack-module-path.test.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/hooks/use-on-click-outside.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/hooks/use-on-click-outside.js +46 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/hooks/use-on-click-outside.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/CloseIcon.d.ts +2 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/CloseIcon.js +46 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/CloseIcon.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/CollapseIcon.d.ts +3 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/CollapseIcon.js +43 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/CollapseIcon.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/LightningBolt.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/LightningBolt.js +34 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/icons/LightningBolt.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/Base.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/Base.js +37 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/Base.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/ComponentStyles.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/ComponentStyles.js +55 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/ComponentStyles.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/CssReset.d.ts +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/CssReset.js +37 -0
- package/dist/client/components/react-dev-overlay/_experimental/internal/styles/CssReset.js.map +1 -0
- package/dist/client/components/react-dev-overlay/_experimental/pages/ReactDevOverlay.d.ts +9 -0
- package/dist/client/components/react-dev-overlay/_experimental/pages/ReactDevOverlay.js +59 -0
- package/dist/client/components/react-dev-overlay/_experimental/pages/ReactDevOverlay.js.map +1 -0
- package/dist/client/components/react-dev-overlay/app/OldReactDevOverlay.d.ts +18 -0
- package/dist/client/components/react-dev-overlay/app/OldReactDevOverlay.js +92 -0
- package/dist/client/components/react-dev-overlay/app/OldReactDevOverlay.js.map +1 -0
- package/dist/client/components/react-dev-overlay/app/ReactDevOverlay.d.ts +3 -18
- package/dist/client/components/react-dev-overlay/app/ReactDevOverlay.js +4 -74
- package/dist/client/components/react-dev-overlay/app/ReactDevOverlay.js.map +1 -1
- package/dist/client/components/react-dev-overlay/pages/OldReactDevOverlay.d.ts +9 -0
- package/dist/client/components/react-dev-overlay/pages/OldReactDevOverlay.js +59 -0
- package/dist/client/components/react-dev-overlay/pages/OldReactDevOverlay.js.map +1 -0
- package/dist/client/components/react-dev-overlay/pages/ReactDevOverlay.d.ts +3 -9
- package/dist/client/components/react-dev-overlay/pages/ReactDevOverlay.js +5 -42
- package/dist/client/components/react-dev-overlay/pages/ReactDevOverlay.js.map +1 -1
- package/dist/client/components/react-dev-overlay/pages/hooks.d.ts +1 -1
- package/dist/client/components/react-dev-overlay/pages/hooks.js.map +1 -1
- package/dist/client/index.js +1 -1
- package/dist/compiled/next-server/app-page-experimental.runtime.dev.js +2 -2
- package/dist/compiled/next-server/app-page-experimental.runtime.dev.js.map +1 -1
- package/dist/compiled/next-server/app-page.runtime.dev.js +2 -2
- package/dist/compiled/next-server/app-page.runtime.dev.js.map +1 -1
- package/dist/esm/build/index.js +5 -2
- package/dist/esm/build/index.js.map +1 -1
- package/dist/esm/build/swc/index.js +1 -1
- package/dist/esm/build/webpack-config.js +2 -2
- package/dist/esm/client/app-bootstrap.js +1 -1
- package/dist/esm/client/components/react-dev-overlay/_experimental/app/ReactDevOverlay.js +76 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/app/ReactDevOverlay.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/CodeFrame.js +102 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/CodeFrame.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/index.js +3 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/styles.js +15 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/CodeFrame/styles.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/Dialog.js +70 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/Dialog.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogBody.js +13 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogBody.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogContent.js +13 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogContent.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogHeader.js +13 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/DialogHeader.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/index.js +7 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/styles.js +15 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Dialog/styles.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/LeftRightDialogHeader.js +162 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/LeftRightDialogHeader.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/index.js +4 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/styles.js +15 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/LeftRightDialogHeader/styles.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/Overlay.js +45 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/Overlay.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/body-locker.js +34 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/body-locker.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/index.js +3 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/maintain--tab-focus.js +2732 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/maintain--tab-focus.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/styles.js +15 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Overlay/styles.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/ShadowPortal.js +25 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/ShadowPortal.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Terminal/EditorLink.js +50 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Terminal/EditorLink.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Terminal/Terminal.js +90 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Terminal/Terminal.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Terminal/index.js +3 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Terminal/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Terminal/styles.js +15 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Terminal/styles.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Toast/Toast.js +19 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Toast/Toast.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Toast/index.js +4 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Toast/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Toast/styles.js +15 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/Toast/styles.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/VersionStalenessInfo.js +75 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/VersionStalenessInfo.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/index.js +4 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/styles.js +15 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/VersionStalenessInfo/styles.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/copy-button/index.js +213 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/copy-button/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/hot-linked-text/index.js +57 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/hot-linked-text/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/nodejs-inspector.js +103 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/components/nodejs-inspector.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/BuildError.js +71 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/BuildError.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/Errors.js +364 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/Errors.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/CallStackFrame.js +75 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/CallStackFrame.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/ComponentStackFrameRow.js +99 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/ComponentStackFrameRow.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/component-stack-pseudo-html.js +275 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/component-stack-pseudo-html.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/index.js +63 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/RuntimeError/index.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/StaticIndicator.js +39 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/StaticIndicator.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/root-layout-missing-tags-error.js +42 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/container/root-layout-missing-tags-error.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/attach-hydration-error-state.js +35 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/attach-hydration-error-state.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/console-error.js +20 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/console-error.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/enqueue-client-error.js +20 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/enqueue-client-error.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/format-webpack-messages.js +147 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/format-webpack-messages.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/get-error-by-type.js +34 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/get-error-by-type.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/get-socket-url.js +22 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/get-socket-url.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-from-file.js +66 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-from-file.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-url.js +17 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/get-source-map-url.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/hydration-error-info.js +73 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/hydration-error-info.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/launchEditor.js +391 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/launchEditor.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/node-stack-frames.js +60 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/node-stack-frames.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/noop-template.js +9 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/noop-template.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/parse-component-stack.js +83 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/parse-component-stack.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/parse-stack.js +38 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/parse-stack.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/runtime-error-handler.js +5 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/runtime-error-handler.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/stack-frame.js +112 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/stack-frame.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/stitched-error.js +40 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/stitched-error.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/use-error-handler.js +88 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/use-error-handler.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/use-open-in-editor.js +21 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/use-open-in-editor.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/use-websocket.js +93 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/use-websocket.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/webpack-module-path.js +31 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/helpers/webpack-module-path.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/hooks/use-on-click-outside.js +29 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/hooks/use-on-click-outside.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/icons/CloseIcon.js +30 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/icons/CloseIcon.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/icons/CollapseIcon.js +27 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/icons/CollapseIcon.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/icons/LightningBolt.js +18 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/icons/LightningBolt.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/styles/Base.js +20 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/styles/Base.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/styles/ComponentStyles.js +39 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/styles/ComponentStyles.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/styles/CssReset.js +20 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/internal/styles/CssReset.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/pages/ReactDevOverlay.js +42 -0
- package/dist/esm/client/components/react-dev-overlay/_experimental/pages/ReactDevOverlay.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/app/OldReactDevOverlay.js +76 -0
- package/dist/esm/client/components/react-dev-overlay/app/OldReactDevOverlay.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/app/ReactDevOverlay.js +3 -74
- package/dist/esm/client/components/react-dev-overlay/app/ReactDevOverlay.js.map +1 -1
- package/dist/esm/client/components/react-dev-overlay/pages/OldReactDevOverlay.js +42 -0
- package/dist/esm/client/components/react-dev-overlay/pages/OldReactDevOverlay.js.map +1 -0
- package/dist/esm/client/components/react-dev-overlay/pages/ReactDevOverlay.js +3 -40
- package/dist/esm/client/components/react-dev-overlay/pages/ReactDevOverlay.js.map +1 -1
- package/dist/esm/client/components/react-dev-overlay/pages/hooks.js.map +1 -1
- package/dist/esm/client/index.js +1 -1
- package/dist/esm/server/config.js +1 -1
- package/dist/esm/server/dev/hot-reloader-turbopack.js +1 -1
- package/dist/esm/server/dev/hot-reloader-webpack.js +1 -1
- package/dist/esm/server/lib/app-info-log.js +1 -1
- package/dist/esm/server/lib/start-server.js +1 -1
- package/dist/server/config.js +1 -1
- package/dist/server/dev/hot-reloader-turbopack.js +1 -1
- package/dist/server/dev/hot-reloader-webpack.js +1 -1
- package/dist/server/lib/app-info-log.js +1 -1
- package/dist/server/lib/start-server.js +1 -1
- package/dist/telemetry/anonymous-meta.js +1 -1
- package/dist/telemetry/events/session-stopped.js +2 -2
- package/dist/telemetry/events/version.js +2 -2
- package/package.json +15 -15
|
@@ -0,0 +1,2749 @@
|
|
|
1
|
+
/* eslint-disable */ // @ts-nocheck
|
|
2
|
+
// Copied from https://github.com/medialize/ally.js
|
|
3
|
+
// License: MIT
|
|
4
|
+
// Copyright (c) 2015 Rodney Rehm
|
|
5
|
+
//
|
|
6
|
+
// Entrypoint: ally.js/maintain/tab-focus
|
|
7
|
+
"use strict";
|
|
8
|
+
Object.defineProperty(exports, "__esModule", {
|
|
9
|
+
value: true
|
|
10
|
+
});
|
|
11
|
+
Object.defineProperty(exports, "default", {
|
|
12
|
+
enumerable: true,
|
|
13
|
+
get: function() {
|
|
14
|
+
return _default;
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
const _interop_require_default = require("@swc/helpers/_/_interop_require_default");
|
|
18
|
+
const _platform = /*#__PURE__*/ _interop_require_default._(require("next/dist/compiled/platform"));
|
|
19
|
+
const _cssescape = /*#__PURE__*/ _interop_require_default._(require("next/dist/compiled/css.escape"));
|
|
20
|
+
// input may be undefined, selector-tring, Node, NodeList, HTMLCollection, array of Nodes
|
|
21
|
+
// yes, to some extent this is a bad replica of jQuery's constructor function
|
|
22
|
+
function nodeArray(input) {
|
|
23
|
+
if (!input) {
|
|
24
|
+
return [];
|
|
25
|
+
}
|
|
26
|
+
if (Array.isArray(input)) {
|
|
27
|
+
return input;
|
|
28
|
+
}
|
|
29
|
+
// instanceof Node - does not work with iframes
|
|
30
|
+
if (input.nodeType !== undefined) {
|
|
31
|
+
return [
|
|
32
|
+
input
|
|
33
|
+
];
|
|
34
|
+
}
|
|
35
|
+
if (typeof input === 'string') {
|
|
36
|
+
input = document.querySelectorAll(input);
|
|
37
|
+
}
|
|
38
|
+
if (input.length !== undefined) {
|
|
39
|
+
return [].slice.call(input, 0);
|
|
40
|
+
}
|
|
41
|
+
throw Object.defineProperty(new TypeError('unexpected input ' + String(input)), "__NEXT_ERROR_CODE", {
|
|
42
|
+
value: "E545",
|
|
43
|
+
enumerable: false
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
function contextToElement(_ref) {
|
|
47
|
+
var context = _ref.context, _ref$label = _ref.label, label = _ref$label === undefined ? 'context-to-element' : _ref$label, resolveDocument = _ref.resolveDocument, defaultToDocument = _ref.defaultToDocument;
|
|
48
|
+
var element = nodeArray(context)[0];
|
|
49
|
+
if (resolveDocument && element && element.nodeType === Node.DOCUMENT_NODE) {
|
|
50
|
+
element = element.documentElement;
|
|
51
|
+
}
|
|
52
|
+
if (!element && defaultToDocument) {
|
|
53
|
+
return document.documentElement;
|
|
54
|
+
}
|
|
55
|
+
if (!element) {
|
|
56
|
+
throw Object.defineProperty(new TypeError(label + ' requires valid options.context'), "__NEXT_ERROR_CODE", {
|
|
57
|
+
value: "E604",
|
|
58
|
+
enumerable: false
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
if (element.nodeType !== Node.ELEMENT_NODE && element.nodeType !== Node.DOCUMENT_FRAGMENT_NODE) {
|
|
62
|
+
throw Object.defineProperty(new TypeError(label + ' requires options.context to be an Element'), "__NEXT_ERROR_CODE", {
|
|
63
|
+
value: "E554",
|
|
64
|
+
enumerable: false
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
return element;
|
|
68
|
+
}
|
|
69
|
+
function getShadowHost() {
|
|
70
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context;
|
|
71
|
+
var element = contextToElement({
|
|
72
|
+
label: 'get/shadow-host',
|
|
73
|
+
context: context
|
|
74
|
+
});
|
|
75
|
+
// walk up to the root
|
|
76
|
+
var container = null;
|
|
77
|
+
while(element){
|
|
78
|
+
container = element;
|
|
79
|
+
element = element.parentNode;
|
|
80
|
+
}
|
|
81
|
+
// https://developer.mozilla.org/docs/Web/API/Node.nodeType
|
|
82
|
+
// NOTE: Firefox 34 does not expose ShadowRoot.host (but 37 does)
|
|
83
|
+
if (container.nodeType === container.DOCUMENT_FRAGMENT_NODE && container.host) {
|
|
84
|
+
// the root is attached to a fragment node that has a host
|
|
85
|
+
return container.host;
|
|
86
|
+
}
|
|
87
|
+
return null;
|
|
88
|
+
}
|
|
89
|
+
function getDocument(node) {
|
|
90
|
+
if (!node) {
|
|
91
|
+
return document;
|
|
92
|
+
}
|
|
93
|
+
if (node.nodeType === Node.DOCUMENT_NODE) {
|
|
94
|
+
return node;
|
|
95
|
+
}
|
|
96
|
+
return node.ownerDocument || document;
|
|
97
|
+
}
|
|
98
|
+
function isActiveElement(context) {
|
|
99
|
+
var element = contextToElement({
|
|
100
|
+
label: 'is/active-element',
|
|
101
|
+
resolveDocument: true,
|
|
102
|
+
context: context
|
|
103
|
+
});
|
|
104
|
+
var _document = getDocument(element);
|
|
105
|
+
if (_document.activeElement === element) {
|
|
106
|
+
return true;
|
|
107
|
+
}
|
|
108
|
+
var shadowHost = getShadowHost({
|
|
109
|
+
context: element
|
|
110
|
+
});
|
|
111
|
+
if (shadowHost && shadowHost.shadowRoot.activeElement === element) {
|
|
112
|
+
return true;
|
|
113
|
+
}
|
|
114
|
+
return false;
|
|
115
|
+
}
|
|
116
|
+
// [elem, elem.parent, elem.parent.parent, …, html]
|
|
117
|
+
// will not contain the shadowRoot (DOCUMENT_FRAGMENT_NODE) and shadowHost
|
|
118
|
+
function getParents() {
|
|
119
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context;
|
|
120
|
+
var list = [];
|
|
121
|
+
var element = contextToElement({
|
|
122
|
+
label: 'get/parents',
|
|
123
|
+
context: context
|
|
124
|
+
});
|
|
125
|
+
while(element){
|
|
126
|
+
list.push(element);
|
|
127
|
+
// IE does know support parentElement on SVGElement
|
|
128
|
+
element = element.parentNode;
|
|
129
|
+
if (element && element.nodeType !== Node.ELEMENT_NODE) {
|
|
130
|
+
element = null;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
return list;
|
|
134
|
+
}
|
|
135
|
+
// Element.prototype.matches may be available at a different name
|
|
136
|
+
// https://developer.mozilla.org/en/docs/Web/API/Element/matches
|
|
137
|
+
var names = [
|
|
138
|
+
'matches',
|
|
139
|
+
'webkitMatchesSelector',
|
|
140
|
+
'mozMatchesSelector',
|
|
141
|
+
'msMatchesSelector'
|
|
142
|
+
];
|
|
143
|
+
var name = null;
|
|
144
|
+
function findMethodName(element) {
|
|
145
|
+
names.some(function(_name) {
|
|
146
|
+
if (!element[_name]) {
|
|
147
|
+
return false;
|
|
148
|
+
}
|
|
149
|
+
name = _name;
|
|
150
|
+
return true;
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
function elementMatches(element, selector) {
|
|
154
|
+
if (!name) {
|
|
155
|
+
findMethodName(element);
|
|
156
|
+
}
|
|
157
|
+
return element[name](selector);
|
|
158
|
+
}
|
|
159
|
+
// deep clone of original platform
|
|
160
|
+
var platform = JSON.parse(JSON.stringify(_platform.default));
|
|
161
|
+
// operating system
|
|
162
|
+
var os = platform.os.family || '';
|
|
163
|
+
var ANDROID = os === 'Android';
|
|
164
|
+
var WINDOWS = os.slice(0, 7) === 'Windows';
|
|
165
|
+
var OSX = os === 'OS X';
|
|
166
|
+
var IOS = os === 'iOS';
|
|
167
|
+
// layout
|
|
168
|
+
var BLINK = platform.layout === 'Blink';
|
|
169
|
+
var GECKO = platform.layout === 'Gecko';
|
|
170
|
+
var TRIDENT = platform.layout === 'Trident';
|
|
171
|
+
var EDGE = platform.layout === 'EdgeHTML';
|
|
172
|
+
var WEBKIT = platform.layout === 'WebKit';
|
|
173
|
+
// browser version (not layout engine version!)
|
|
174
|
+
var version = parseFloat(platform.version);
|
|
175
|
+
var majorVersion = Math.floor(version);
|
|
176
|
+
platform.majorVersion = majorVersion;
|
|
177
|
+
platform.is = {
|
|
178
|
+
// operating system
|
|
179
|
+
ANDROID: ANDROID,
|
|
180
|
+
WINDOWS: WINDOWS,
|
|
181
|
+
OSX: OSX,
|
|
182
|
+
IOS: IOS,
|
|
183
|
+
// layout
|
|
184
|
+
BLINK: BLINK,
|
|
185
|
+
GECKO: GECKO,
|
|
186
|
+
TRIDENT: TRIDENT,
|
|
187
|
+
EDGE: EDGE,
|
|
188
|
+
WEBKIT: WEBKIT,
|
|
189
|
+
// INTERNET EXPLORERS
|
|
190
|
+
IE9: TRIDENT && majorVersion === 9,
|
|
191
|
+
IE10: TRIDENT && majorVersion === 10,
|
|
192
|
+
IE11: TRIDENT && majorVersion === 11
|
|
193
|
+
};
|
|
194
|
+
function before() {
|
|
195
|
+
var data = {
|
|
196
|
+
// remember what had focus to restore after test
|
|
197
|
+
activeElement: document.activeElement,
|
|
198
|
+
// remember scroll positions to restore after test
|
|
199
|
+
windowScrollTop: window.scrollTop,
|
|
200
|
+
windowScrollLeft: window.scrollLeft,
|
|
201
|
+
bodyScrollTop: document.body.scrollTop,
|
|
202
|
+
bodyScrollLeft: document.body.scrollLeft
|
|
203
|
+
};
|
|
204
|
+
// wrap tests in an element hidden from screen readers to prevent them
|
|
205
|
+
// from announcing focus, which can be quite irritating to the user
|
|
206
|
+
var iframe = document.createElement('iframe');
|
|
207
|
+
iframe.setAttribute('style', 'position:absolute; position:fixed; top:0; left:-2px; width:1px; height:1px; overflow:hidden;');
|
|
208
|
+
iframe.setAttribute('aria-live', 'off');
|
|
209
|
+
iframe.setAttribute('aria-busy', 'true');
|
|
210
|
+
iframe.setAttribute('aria-hidden', 'true');
|
|
211
|
+
document.body.appendChild(iframe);
|
|
212
|
+
var _window = iframe.contentWindow;
|
|
213
|
+
var _document = _window.document;
|
|
214
|
+
_document.open();
|
|
215
|
+
_document.close();
|
|
216
|
+
var wrapper = _document.createElement('div');
|
|
217
|
+
_document.body.appendChild(wrapper);
|
|
218
|
+
data.iframe = iframe;
|
|
219
|
+
data.wrapper = wrapper;
|
|
220
|
+
data.window = _window;
|
|
221
|
+
data.document = _document;
|
|
222
|
+
return data;
|
|
223
|
+
}
|
|
224
|
+
// options.element:
|
|
225
|
+
// {string} element name
|
|
226
|
+
// {function} callback(wrapper, document) to generate an element
|
|
227
|
+
// options.mutate: (optional)
|
|
228
|
+
// {function} callback(element, wrapper, document) to manipulate element prior to focus-test.
|
|
229
|
+
// Can return DOMElement to define focus target (default: element)
|
|
230
|
+
// options.validate: (optional)
|
|
231
|
+
// {function} callback(element, focusTarget, document) to manipulate test-result
|
|
232
|
+
function test(data, options) {
|
|
233
|
+
// make sure we operate on a clean slate
|
|
234
|
+
data.wrapper.innerHTML = '';
|
|
235
|
+
// create dummy element to test focusability of
|
|
236
|
+
var element = typeof options.element === 'string' ? data.document.createElement(options.element) : options.element(data.wrapper, data.document);
|
|
237
|
+
// allow callback to further specify dummy element
|
|
238
|
+
// and optionally define element to focus
|
|
239
|
+
var focus = options.mutate && options.mutate(element, data.wrapper, data.document);
|
|
240
|
+
if (!focus && focus !== false) {
|
|
241
|
+
focus = element;
|
|
242
|
+
}
|
|
243
|
+
// element needs to be part of the DOM to be focusable
|
|
244
|
+
!element.parentNode && data.wrapper.appendChild(element);
|
|
245
|
+
// test if the element with invalid tabindex can be focused
|
|
246
|
+
focus && focus.focus && focus.focus();
|
|
247
|
+
// validate test's result
|
|
248
|
+
return options.validate ? options.validate(element, focus, data.document) : data.document.activeElement === focus;
|
|
249
|
+
}
|
|
250
|
+
function after(data) {
|
|
251
|
+
// restore focus to what it was before test and cleanup
|
|
252
|
+
if (data.activeElement === document.body) {
|
|
253
|
+
document.activeElement && document.activeElement.blur && document.activeElement.blur();
|
|
254
|
+
if (platform.is.IE10) {
|
|
255
|
+
// IE10 does not redirect focus to <body> when the activeElement is removed
|
|
256
|
+
document.body.focus();
|
|
257
|
+
}
|
|
258
|
+
} else {
|
|
259
|
+
data.activeElement && data.activeElement.focus && data.activeElement.focus();
|
|
260
|
+
}
|
|
261
|
+
document.body.removeChild(data.iframe);
|
|
262
|
+
// restore scroll position
|
|
263
|
+
window.scrollTop = data.windowScrollTop;
|
|
264
|
+
window.scrollLeft = data.windowScrollLeft;
|
|
265
|
+
document.body.scrollTop = data.bodyScrollTop;
|
|
266
|
+
document.body.scrollLeft = data.bodyScrollLeft;
|
|
267
|
+
}
|
|
268
|
+
function detectFocus(tests) {
|
|
269
|
+
var data = before();
|
|
270
|
+
var results = {};
|
|
271
|
+
Object.keys(tests).map(function(key) {
|
|
272
|
+
results[key] = test(data, tests[key]);
|
|
273
|
+
});
|
|
274
|
+
after(data);
|
|
275
|
+
return results;
|
|
276
|
+
}
|
|
277
|
+
// this file is overwritten by `npm run build:pre`
|
|
278
|
+
var version$1 = '1.4.1';
|
|
279
|
+
/*
|
|
280
|
+
Facility to cache test results in localStorage.
|
|
281
|
+
|
|
282
|
+
USAGE:
|
|
283
|
+
cache.get('key');
|
|
284
|
+
cache.set('key', 'value');
|
|
285
|
+
*/ function readLocalStorage(key) {
|
|
286
|
+
// allow reading from storage to retrieve previous support results
|
|
287
|
+
// even while the document does not have focus
|
|
288
|
+
var data = void 0;
|
|
289
|
+
try {
|
|
290
|
+
data = window.localStorage && window.localStorage.getItem(key);
|
|
291
|
+
data = data ? JSON.parse(data) : {};
|
|
292
|
+
} catch (e) {
|
|
293
|
+
data = {};
|
|
294
|
+
}
|
|
295
|
+
return data;
|
|
296
|
+
}
|
|
297
|
+
function writeLocalStorage(key, value) {
|
|
298
|
+
if (!document.hasFocus()) {
|
|
299
|
+
// if the document does not have focus when tests are executed, focus() may
|
|
300
|
+
// not be handled properly and events may not be dispatched immediately.
|
|
301
|
+
// This can happen when a document is reloaded while Developer Tools have focus.
|
|
302
|
+
try {
|
|
303
|
+
window.localStorage && window.localStorage.removeItem(key);
|
|
304
|
+
} catch (e) {
|
|
305
|
+
// ignore
|
|
306
|
+
}
|
|
307
|
+
return;
|
|
308
|
+
}
|
|
309
|
+
try {
|
|
310
|
+
window.localStorage && window.localStorage.setItem(key, JSON.stringify(value));
|
|
311
|
+
} catch (e) {
|
|
312
|
+
// ignore
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
var userAgent = typeof window !== 'undefined' && window.navigator.userAgent || '';
|
|
316
|
+
var cacheKey = 'ally-supports-cache';
|
|
317
|
+
var cache = readLocalStorage(cacheKey);
|
|
318
|
+
// update the cache if ally or the user agent changed (newer version, etc)
|
|
319
|
+
if (cache.userAgent !== userAgent || cache.version !== version$1) {
|
|
320
|
+
cache = {};
|
|
321
|
+
}
|
|
322
|
+
cache.userAgent = userAgent;
|
|
323
|
+
cache.version = version$1;
|
|
324
|
+
var cache$1 = {
|
|
325
|
+
get: function get() {
|
|
326
|
+
return cache;
|
|
327
|
+
},
|
|
328
|
+
set: function set(values) {
|
|
329
|
+
Object.keys(values).forEach(function(key) {
|
|
330
|
+
cache[key] = values[key];
|
|
331
|
+
});
|
|
332
|
+
cache.time = new Date().toISOString();
|
|
333
|
+
writeLocalStorage(cacheKey, cache);
|
|
334
|
+
}
|
|
335
|
+
};
|
|
336
|
+
function cssShadowPiercingDeepCombinator() {
|
|
337
|
+
var combinator = void 0;
|
|
338
|
+
// see https://dev.w3.org/csswg/css-scoping-1/#deep-combinator
|
|
339
|
+
// https://bugzilla.mozilla.org/show_bug.cgi?id=1117572
|
|
340
|
+
// https://code.google.com/p/chromium/issues/detail?id=446051
|
|
341
|
+
try {
|
|
342
|
+
document.querySelector('html >>> :first-child');
|
|
343
|
+
combinator = '>>>';
|
|
344
|
+
} catch (noArrowArrowArrow) {
|
|
345
|
+
try {
|
|
346
|
+
// old syntax supported at least up to Chrome 41
|
|
347
|
+
// https://code.google.com/p/chromium/issues/detail?id=446051
|
|
348
|
+
document.querySelector('html /deep/ :first-child');
|
|
349
|
+
combinator = '/deep/';
|
|
350
|
+
} catch (noDeep) {
|
|
351
|
+
combinator = '';
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
return combinator;
|
|
355
|
+
}
|
|
356
|
+
var gif = 'data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7';
|
|
357
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/img#attr-usemap
|
|
358
|
+
var focusAreaImgTabindex = {
|
|
359
|
+
element: 'div',
|
|
360
|
+
mutate: function mutate(element) {
|
|
361
|
+
element.innerHTML = '<map name="image-map-tabindex-test">' + '<area shape="rect" coords="63,19,144,45"></map>' + '<img usemap="#image-map-tabindex-test" tabindex="-1" alt="" src="' + gif + '">';
|
|
362
|
+
return element.querySelector('area');
|
|
363
|
+
}
|
|
364
|
+
};
|
|
365
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/img#attr-usemap
|
|
366
|
+
var focusAreaTabindex = {
|
|
367
|
+
element: 'div',
|
|
368
|
+
mutate: function mutate(element) {
|
|
369
|
+
element.innerHTML = '<map name="image-map-tabindex-test">' + '<area href="#void" tabindex="-1" shape="rect" coords="63,19,144,45"></map>' + '<img usemap="#image-map-tabindex-test" alt="" src="' + gif + '">';
|
|
370
|
+
return false;
|
|
371
|
+
},
|
|
372
|
+
validate: function validate(element, focusTarget, _document) {
|
|
373
|
+
if (platform.is.GECKO) {
|
|
374
|
+
// fixes https://github.com/medialize/ally.js/issues/35
|
|
375
|
+
// Firefox loads the DataURI asynchronously, causing a false-negative
|
|
376
|
+
return true;
|
|
377
|
+
}
|
|
378
|
+
var focus = element.querySelector('area');
|
|
379
|
+
focus.focus();
|
|
380
|
+
return _document.activeElement === focus;
|
|
381
|
+
}
|
|
382
|
+
};
|
|
383
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/img#attr-usemap
|
|
384
|
+
var focusAreaWithoutHref = {
|
|
385
|
+
element: 'div',
|
|
386
|
+
mutate: function mutate(element) {
|
|
387
|
+
element.innerHTML = '<map name="image-map-area-href-test">' + '<area shape="rect" coords="63,19,144,45"></map>' + '<img usemap="#image-map-area-href-test" alt="" src="' + gif + '">';
|
|
388
|
+
return element.querySelector('area');
|
|
389
|
+
},
|
|
390
|
+
validate: function validate(element, focusTarget, _document) {
|
|
391
|
+
if (platform.is.GECKO) {
|
|
392
|
+
// fixes https://github.com/medialize/ally.js/issues/35
|
|
393
|
+
// Firefox loads the DataURI asynchronously, causing a false-negative
|
|
394
|
+
return true;
|
|
395
|
+
}
|
|
396
|
+
return _document.activeElement === focusTarget;
|
|
397
|
+
}
|
|
398
|
+
};
|
|
399
|
+
var focusAudioWithoutControls = {
|
|
400
|
+
name: 'can-focus-audio-without-controls',
|
|
401
|
+
element: 'audio',
|
|
402
|
+
mutate: function mutate(element) {
|
|
403
|
+
try {
|
|
404
|
+
// invalid media file can trigger warning in console, data-uri to prevent HTTP request
|
|
405
|
+
element.setAttribute('src', gif);
|
|
406
|
+
} catch (e) {
|
|
407
|
+
// IE9 may throw "Error: Not implemented"
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
};
|
|
411
|
+
var invalidGif = 'data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ';
|
|
412
|
+
// NOTE: https://github.com/medialize/ally.js/issues/35
|
|
413
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/img#attr-usemap
|
|
414
|
+
var focusBrokenImageMap = {
|
|
415
|
+
element: 'div',
|
|
416
|
+
mutate: function mutate(element) {
|
|
417
|
+
element.innerHTML = '<map name="broken-image-map-test"><area href="#void" shape="rect" coords="63,19,144,45"></map>' + '<img usemap="#broken-image-map-test" alt="" src="' + invalidGif + '">';
|
|
418
|
+
return element.querySelector('area');
|
|
419
|
+
}
|
|
420
|
+
};
|
|
421
|
+
// Children of focusable elements with display:flex are focusable in IE10-11
|
|
422
|
+
var focusChildrenOfFocusableFlexbox = {
|
|
423
|
+
element: 'div',
|
|
424
|
+
mutate: function mutate(element) {
|
|
425
|
+
element.setAttribute('tabindex', '-1');
|
|
426
|
+
element.setAttribute('style', 'display: -webkit-flex; display: -ms-flexbox; display: flex;');
|
|
427
|
+
element.innerHTML = '<span style="display: block;">hello</span>';
|
|
428
|
+
return element.querySelector('span');
|
|
429
|
+
}
|
|
430
|
+
};
|
|
431
|
+
// fieldset[tabindex=0][disabled] should not be focusable, but Blink and WebKit disagree
|
|
432
|
+
// @specification https://www.w3.org/TR/html5/disabled-elements.html#concept-element-disabled
|
|
433
|
+
// @browser-issue Chromium https://crbug.com/453847
|
|
434
|
+
// @browser-issue WebKit https://bugs.webkit.org/show_bug.cgi?id=141086
|
|
435
|
+
var focusFieldsetDisabled = {
|
|
436
|
+
element: 'fieldset',
|
|
437
|
+
mutate: function mutate(element) {
|
|
438
|
+
element.setAttribute('tabindex', 0);
|
|
439
|
+
element.setAttribute('disabled', 'disabled');
|
|
440
|
+
}
|
|
441
|
+
};
|
|
442
|
+
var focusFieldset = {
|
|
443
|
+
element: 'fieldset',
|
|
444
|
+
mutate: function mutate(element) {
|
|
445
|
+
element.innerHTML = '<legend>legend</legend><p>content</p>';
|
|
446
|
+
}
|
|
447
|
+
};
|
|
448
|
+
// elements with display:flex are focusable in IE10-11
|
|
449
|
+
var focusFlexboxContainer = {
|
|
450
|
+
element: 'span',
|
|
451
|
+
mutate: function mutate(element) {
|
|
452
|
+
element.setAttribute('style', 'display: -webkit-flex; display: -ms-flexbox; display: flex;');
|
|
453
|
+
element.innerHTML = '<span style="display: block;">hello</span>';
|
|
454
|
+
}
|
|
455
|
+
};
|
|
456
|
+
// form[tabindex=0][disabled] should be focusable as the
|
|
457
|
+
// specification doesn't know the disabled attribute on the form element
|
|
458
|
+
// @specification https://www.w3.org/TR/html5/forms.html#the-form-element
|
|
459
|
+
var focusFormDisabled = {
|
|
460
|
+
element: 'form',
|
|
461
|
+
mutate: function mutate(element) {
|
|
462
|
+
element.setAttribute('tabindex', 0);
|
|
463
|
+
element.setAttribute('disabled', 'disabled');
|
|
464
|
+
}
|
|
465
|
+
};
|
|
466
|
+
// NOTE: https://github.com/medialize/ally.js/issues/35
|
|
467
|
+
// fixes https://github.com/medialize/ally.js/issues/20
|
|
468
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/img#attr-ismap
|
|
469
|
+
var focusImgIsmap = {
|
|
470
|
+
element: 'a',
|
|
471
|
+
mutate: function mutate(element) {
|
|
472
|
+
element.href = '#void';
|
|
473
|
+
element.innerHTML = '<img ismap src="' + gif + '" alt="">';
|
|
474
|
+
return element.querySelector('img');
|
|
475
|
+
}
|
|
476
|
+
};
|
|
477
|
+
// NOTE: https://github.com/medialize/ally.js/issues/35
|
|
478
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/img#attr-usemap
|
|
479
|
+
var focusImgUsemapTabindex = {
|
|
480
|
+
element: 'div',
|
|
481
|
+
mutate: function mutate(element) {
|
|
482
|
+
element.innerHTML = '<map name="image-map-tabindex-test"><area href="#void" shape="rect" coords="63,19,144,45"></map>' + '<img usemap="#image-map-tabindex-test" tabindex="-1" alt="" ' + 'src="' + gif + '">';
|
|
483
|
+
return element.querySelector('img');
|
|
484
|
+
}
|
|
485
|
+
};
|
|
486
|
+
var focusInHiddenIframe = {
|
|
487
|
+
element: function element(wrapper, _document) {
|
|
488
|
+
var iframe = _document.createElement('iframe');
|
|
489
|
+
// iframe must be part of the DOM before accessing the contentWindow is possible
|
|
490
|
+
wrapper.appendChild(iframe);
|
|
491
|
+
// create the iframe's default document (<html><head></head><body></body></html>)
|
|
492
|
+
var iframeDocument = iframe.contentWindow.document;
|
|
493
|
+
iframeDocument.open();
|
|
494
|
+
iframeDocument.close();
|
|
495
|
+
return iframe;
|
|
496
|
+
},
|
|
497
|
+
mutate: function mutate(iframe) {
|
|
498
|
+
iframe.style.visibility = 'hidden';
|
|
499
|
+
var iframeDocument = iframe.contentWindow.document;
|
|
500
|
+
var input = iframeDocument.createElement('input');
|
|
501
|
+
iframeDocument.body.appendChild(input);
|
|
502
|
+
return input;
|
|
503
|
+
},
|
|
504
|
+
validate: function validate(iframe) {
|
|
505
|
+
var iframeDocument = iframe.contentWindow.document;
|
|
506
|
+
var focus = iframeDocument.querySelector('input');
|
|
507
|
+
return iframeDocument.activeElement === focus;
|
|
508
|
+
}
|
|
509
|
+
};
|
|
510
|
+
var result = !platform.is.WEBKIT;
|
|
511
|
+
function focusInZeroDimensionObject() {
|
|
512
|
+
return result;
|
|
513
|
+
}
|
|
514
|
+
// Firefox allows *any* value and treats invalid values like tabindex="-1"
|
|
515
|
+
// @browser-issue Gecko https://bugzilla.mozilla.org/show_bug.cgi?id=1128054
|
|
516
|
+
var focusInvalidTabindex = {
|
|
517
|
+
element: 'div',
|
|
518
|
+
mutate: function mutate(element) {
|
|
519
|
+
element.setAttribute('tabindex', 'invalid-value');
|
|
520
|
+
}
|
|
521
|
+
};
|
|
522
|
+
var focusLabelTabindex = {
|
|
523
|
+
element: 'label',
|
|
524
|
+
mutate: function mutate(element) {
|
|
525
|
+
element.setAttribute('tabindex', '-1');
|
|
526
|
+
},
|
|
527
|
+
validate: function validate(element, focusTarget, _document) {
|
|
528
|
+
// force layout in Chrome 49, otherwise the element won't be focusable
|
|
529
|
+
/* eslint-disable no-unused-vars */ var variableToPreventDeadCodeElimination = element.offsetHeight;
|
|
530
|
+
/* eslint-enable no-unused-vars */ element.focus();
|
|
531
|
+
return _document.activeElement === element;
|
|
532
|
+
}
|
|
533
|
+
};
|
|
534
|
+
var svg = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtb' + 'G5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiBpZD0ic3ZnIj48dGV4dCB4PSIxMCIgeT0iMjAiIGlkPSJ' + 'zdmctbGluay10ZXh0Ij50ZXh0PC90ZXh0Pjwvc3ZnPg==';
|
|
535
|
+
// Note: IE10 on BrowserStack does not like this test
|
|
536
|
+
var focusObjectSvgHidden = {
|
|
537
|
+
element: 'object',
|
|
538
|
+
mutate: function mutate(element) {
|
|
539
|
+
element.setAttribute('type', 'image/svg+xml');
|
|
540
|
+
element.setAttribute('data', svg);
|
|
541
|
+
element.setAttribute('width', '200');
|
|
542
|
+
element.setAttribute('height', '50');
|
|
543
|
+
element.style.visibility = 'hidden';
|
|
544
|
+
}
|
|
545
|
+
};
|
|
546
|
+
// Note: IE10 on BrowserStack does not like this test
|
|
547
|
+
var focusObjectSvg = {
|
|
548
|
+
name: 'can-focus-object-svg',
|
|
549
|
+
element: 'object',
|
|
550
|
+
mutate: function mutate(element) {
|
|
551
|
+
element.setAttribute('type', 'image/svg+xml');
|
|
552
|
+
element.setAttribute('data', svg);
|
|
553
|
+
element.setAttribute('width', '200');
|
|
554
|
+
element.setAttribute('height', '50');
|
|
555
|
+
},
|
|
556
|
+
validate: function validate(element, focusTarget, _document) {
|
|
557
|
+
if (platform.is.GECKO) {
|
|
558
|
+
// Firefox seems to be handling the object creation asynchronously and thereby produces a false negative test result.
|
|
559
|
+
// Because we know Firefox is able to focus object elements referencing SVGs, we simply cheat by sniffing the user agent string
|
|
560
|
+
return true;
|
|
561
|
+
}
|
|
562
|
+
return _document.activeElement === element;
|
|
563
|
+
}
|
|
564
|
+
};
|
|
565
|
+
// Every Environment except IE9 considers SWF objects focusable
|
|
566
|
+
var result$1 = !platform.is.IE9;
|
|
567
|
+
function focusObjectSwf() {
|
|
568
|
+
return result$1;
|
|
569
|
+
}
|
|
570
|
+
var focusRedirectImgUsemap = {
|
|
571
|
+
element: 'div',
|
|
572
|
+
mutate: function mutate(element) {
|
|
573
|
+
element.innerHTML = '<map name="focus-redirect-img-usemap"><area href="#void" shape="rect" coords="63,19,144,45"></map>' + '<img usemap="#focus-redirect-img-usemap" alt="" ' + 'src="' + gif + '">';
|
|
574
|
+
// focus the <img>, not the <div>
|
|
575
|
+
return element.querySelector('img');
|
|
576
|
+
},
|
|
577
|
+
validate: function validate(element, focusTarget, _document) {
|
|
578
|
+
var target = element.querySelector('area');
|
|
579
|
+
return _document.activeElement === target;
|
|
580
|
+
}
|
|
581
|
+
};
|
|
582
|
+
// see https://jsbin.com/nenirisage/edit?html,js,console,output
|
|
583
|
+
var focusRedirectLegend = {
|
|
584
|
+
element: 'fieldset',
|
|
585
|
+
mutate: function mutate(element) {
|
|
586
|
+
element.innerHTML = '<legend>legend</legend><input tabindex="-1"><input tabindex="0">';
|
|
587
|
+
// take care of focus in validate();
|
|
588
|
+
return false;
|
|
589
|
+
},
|
|
590
|
+
validate: function validate(element, focusTarget, _document) {
|
|
591
|
+
var focusable = element.querySelector('input[tabindex="-1"]');
|
|
592
|
+
var tabbable = element.querySelector('input[tabindex="0"]');
|
|
593
|
+
// Firefox requires this test to focus the <fieldset> first, while this is not necessary in
|
|
594
|
+
// https://jsbin.com/nenirisage/edit?html,js,console,output
|
|
595
|
+
element.focus();
|
|
596
|
+
element.querySelector('legend').focus();
|
|
597
|
+
return _document.activeElement === focusable && 'focusable' || _document.activeElement === tabbable && 'tabbable' || '';
|
|
598
|
+
}
|
|
599
|
+
};
|
|
600
|
+
// https://github.com/medialize/ally.js/issues/21
|
|
601
|
+
var focusScrollBody = {
|
|
602
|
+
element: 'div',
|
|
603
|
+
mutate: function mutate(element) {
|
|
604
|
+
element.setAttribute('style', 'width: 100px; height: 50px; overflow: auto;');
|
|
605
|
+
element.innerHTML = '<div style="width: 500px; height: 40px;">scrollable content</div>';
|
|
606
|
+
return element.querySelector('div');
|
|
607
|
+
}
|
|
608
|
+
};
|
|
609
|
+
// https://github.com/medialize/ally.js/issues/21
|
|
610
|
+
var focusScrollContainerWithoutOverflow = {
|
|
611
|
+
element: 'div',
|
|
612
|
+
mutate: function mutate(element) {
|
|
613
|
+
element.setAttribute('style', 'width: 100px; height: 50px;');
|
|
614
|
+
element.innerHTML = '<div style="width: 500px; height: 40px;">scrollable content</div>';
|
|
615
|
+
}
|
|
616
|
+
};
|
|
617
|
+
// https://github.com/medialize/ally.js/issues/21
|
|
618
|
+
var focusScrollContainer = {
|
|
619
|
+
element: 'div',
|
|
620
|
+
mutate: function mutate(element) {
|
|
621
|
+
element.setAttribute('style', 'width: 100px; height: 50px; overflow: auto;');
|
|
622
|
+
element.innerHTML = '<div style="width: 500px; height: 40px;">scrollable content</div>';
|
|
623
|
+
}
|
|
624
|
+
};
|
|
625
|
+
var focusSummary = {
|
|
626
|
+
element: 'details',
|
|
627
|
+
mutate: function mutate(element) {
|
|
628
|
+
element.innerHTML = '<summary>foo</summary><p>content</p>';
|
|
629
|
+
return element.firstElementChild;
|
|
630
|
+
}
|
|
631
|
+
};
|
|
632
|
+
function makeFocusableForeignObject() {
|
|
633
|
+
// Constructs <foreignObject width="30" height="30"><input type="text"/></foreignObject>
|
|
634
|
+
// without raising a Trusted Types violation
|
|
635
|
+
var foreignObject = document.createElementNS('http://www.w3.org/2000/svg', 'foreignObject');
|
|
636
|
+
foreignObject.width.baseVal.value = 30;
|
|
637
|
+
foreignObject.height.baseVal.value = 30;
|
|
638
|
+
foreignObject.appendChild(document.createElement('input'));
|
|
639
|
+
foreignObject.lastChild.type = 'text';
|
|
640
|
+
return foreignObject;
|
|
641
|
+
}
|
|
642
|
+
function focusSvgForeignObjectHack(element) {
|
|
643
|
+
// Edge13, Edge14: foreignObject focus hack
|
|
644
|
+
// https://jsbin.com/kunehinugi/edit?html,js,output
|
|
645
|
+
// https://jsbin.com/fajagi/3/edit?html,js,output
|
|
646
|
+
var isSvgElement = element.ownerSVGElement || element.nodeName.toLowerCase() === 'svg';
|
|
647
|
+
if (!isSvgElement) {
|
|
648
|
+
return false;
|
|
649
|
+
}
|
|
650
|
+
// inject and focus an <input> element into the SVG element to receive focus
|
|
651
|
+
var foreignObject = makeFocusableForeignObject();
|
|
652
|
+
element.appendChild(foreignObject);
|
|
653
|
+
var input = foreignObject.querySelector('input');
|
|
654
|
+
input.focus();
|
|
655
|
+
// upon disabling the activeElement, IE and Edge
|
|
656
|
+
// will not shift focus to <body> like all the other
|
|
657
|
+
// browsers, but instead find the first focusable
|
|
658
|
+
// ancestor and shift focus to that
|
|
659
|
+
input.disabled = true;
|
|
660
|
+
// clean up
|
|
661
|
+
element.removeChild(foreignObject);
|
|
662
|
+
return true;
|
|
663
|
+
}
|
|
664
|
+
function generate(element) {
|
|
665
|
+
return '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">' + element + '</svg>';
|
|
666
|
+
}
|
|
667
|
+
function focus(element) {
|
|
668
|
+
if (element.focus) {
|
|
669
|
+
return;
|
|
670
|
+
}
|
|
671
|
+
try {
|
|
672
|
+
HTMLElement.prototype.focus.call(element);
|
|
673
|
+
} catch (e) {
|
|
674
|
+
focusSvgForeignObjectHack(element);
|
|
675
|
+
}
|
|
676
|
+
}
|
|
677
|
+
function validate(element, focusTarget, _document) {
|
|
678
|
+
focus(focusTarget);
|
|
679
|
+
return _document.activeElement === focusTarget;
|
|
680
|
+
}
|
|
681
|
+
var focusSvgFocusableAttribute = {
|
|
682
|
+
element: 'div',
|
|
683
|
+
mutate: function mutate(element) {
|
|
684
|
+
element.innerHTML = generate('<text focusable="true">a</text>');
|
|
685
|
+
return element.querySelector('text');
|
|
686
|
+
},
|
|
687
|
+
validate: validate
|
|
688
|
+
};
|
|
689
|
+
var focusSvgTabindexAttribute = {
|
|
690
|
+
element: 'div',
|
|
691
|
+
mutate: function mutate(element) {
|
|
692
|
+
element.innerHTML = generate('<text tabindex="0">a</text>');
|
|
693
|
+
return element.querySelector('text');
|
|
694
|
+
},
|
|
695
|
+
validate: validate
|
|
696
|
+
};
|
|
697
|
+
var focusSvgNegativeTabindexAttribute = {
|
|
698
|
+
element: 'div',
|
|
699
|
+
mutate: function mutate(element) {
|
|
700
|
+
element.innerHTML = generate('<text tabindex="-1">a</text>');
|
|
701
|
+
return element.querySelector('text');
|
|
702
|
+
},
|
|
703
|
+
validate: validate
|
|
704
|
+
};
|
|
705
|
+
var focusSvgUseTabindex = {
|
|
706
|
+
element: 'div',
|
|
707
|
+
mutate: function mutate(element) {
|
|
708
|
+
element.innerHTML = generate([
|
|
709
|
+
'<g id="ally-test-target"><a xlink:href="#void"><text>link</text></a></g>',
|
|
710
|
+
'<use xlink:href="#ally-test-target" x="0" y="0" tabindex="-1" />'
|
|
711
|
+
].join(''));
|
|
712
|
+
return element.querySelector('use');
|
|
713
|
+
},
|
|
714
|
+
validate: validate
|
|
715
|
+
};
|
|
716
|
+
var focusSvgForeignobjectTabindex = {
|
|
717
|
+
element: 'div',
|
|
718
|
+
mutate: function mutate(element) {
|
|
719
|
+
element.innerHTML = generate('<foreignObject tabindex="-1"><input type="text" /></foreignObject>');
|
|
720
|
+
// Safari 8's querySelector() can't identify foreignObject, but getElementsByTagName() can
|
|
721
|
+
return element.querySelector('foreignObject') || element.getElementsByTagName('foreignObject')[0];
|
|
722
|
+
},
|
|
723
|
+
validate: validate
|
|
724
|
+
};
|
|
725
|
+
// Firefox seems to be handling the SVG-document-in-iframe creation asynchronously
|
|
726
|
+
// and thereby produces a false negative test result. Thus the test is pointless
|
|
727
|
+
// and we resort to UA sniffing once again.
|
|
728
|
+
// see http://jsbin.com/vunadohoko/1/edit?js,console,output
|
|
729
|
+
var result$2 = Boolean(platform.is.GECKO && typeof SVGElement !== 'undefined' && SVGElement.prototype.focus);
|
|
730
|
+
function focusSvgInIframe() {
|
|
731
|
+
return result$2;
|
|
732
|
+
}
|
|
733
|
+
var focusSvg = {
|
|
734
|
+
element: 'div',
|
|
735
|
+
mutate: function mutate(element) {
|
|
736
|
+
element.innerHTML = generate('');
|
|
737
|
+
return element.firstChild;
|
|
738
|
+
},
|
|
739
|
+
validate: validate
|
|
740
|
+
};
|
|
741
|
+
// Firefox allows *any* value and treats invalid values like tabindex="-1"
|
|
742
|
+
// @browser-issue Gecko https://bugzilla.mozilla.org/show_bug.cgi?id=1128054
|
|
743
|
+
var focusTabindexTrailingCharacters = {
|
|
744
|
+
element: 'div',
|
|
745
|
+
mutate: function mutate(element) {
|
|
746
|
+
element.setAttribute('tabindex', '3x');
|
|
747
|
+
}
|
|
748
|
+
};
|
|
749
|
+
var focusTable = {
|
|
750
|
+
element: 'table',
|
|
751
|
+
mutate: function mutate(element, wrapper, _document) {
|
|
752
|
+
// IE9 has a problem replacing TBODY contents with innerHTML.
|
|
753
|
+
// https://stackoverflow.com/a/8097055/515124
|
|
754
|
+
// element.innerHTML = '<tr><td>cell</td></tr>';
|
|
755
|
+
var fragment = _document.createDocumentFragment();
|
|
756
|
+
fragment.innerHTML = '<tr><td>cell</td></tr>';
|
|
757
|
+
element.appendChild(fragment);
|
|
758
|
+
}
|
|
759
|
+
};
|
|
760
|
+
var focusVideoWithoutControls = {
|
|
761
|
+
element: 'video',
|
|
762
|
+
mutate: function mutate(element) {
|
|
763
|
+
try {
|
|
764
|
+
// invalid media file can trigger warning in console, data-uri to prevent HTTP request
|
|
765
|
+
element.setAttribute('src', gif);
|
|
766
|
+
} catch (e) {
|
|
767
|
+
// IE9 may throw "Error: Not implemented"
|
|
768
|
+
}
|
|
769
|
+
}
|
|
770
|
+
};
|
|
771
|
+
// https://jsbin.com/vafaba/3/edit?html,js,console,output
|
|
772
|
+
var result$3 = platform.is.GECKO || platform.is.TRIDENT || platform.is.EDGE;
|
|
773
|
+
function tabsequenceAreaAtImgPosition() {
|
|
774
|
+
return result$3;
|
|
775
|
+
}
|
|
776
|
+
var testCallbacks = {
|
|
777
|
+
cssShadowPiercingDeepCombinator: cssShadowPiercingDeepCombinator,
|
|
778
|
+
focusInZeroDimensionObject: focusInZeroDimensionObject,
|
|
779
|
+
focusObjectSwf: focusObjectSwf,
|
|
780
|
+
focusSvgInIframe: focusSvgInIframe,
|
|
781
|
+
tabsequenceAreaAtImgPosition: tabsequenceAreaAtImgPosition
|
|
782
|
+
};
|
|
783
|
+
var testDescriptions = {
|
|
784
|
+
focusAreaImgTabindex: focusAreaImgTabindex,
|
|
785
|
+
focusAreaTabindex: focusAreaTabindex,
|
|
786
|
+
focusAreaWithoutHref: focusAreaWithoutHref,
|
|
787
|
+
focusAudioWithoutControls: focusAudioWithoutControls,
|
|
788
|
+
focusBrokenImageMap: focusBrokenImageMap,
|
|
789
|
+
focusChildrenOfFocusableFlexbox: focusChildrenOfFocusableFlexbox,
|
|
790
|
+
focusFieldsetDisabled: focusFieldsetDisabled,
|
|
791
|
+
focusFieldset: focusFieldset,
|
|
792
|
+
focusFlexboxContainer: focusFlexboxContainer,
|
|
793
|
+
focusFormDisabled: focusFormDisabled,
|
|
794
|
+
focusImgIsmap: focusImgIsmap,
|
|
795
|
+
focusImgUsemapTabindex: focusImgUsemapTabindex,
|
|
796
|
+
focusInHiddenIframe: focusInHiddenIframe,
|
|
797
|
+
focusInvalidTabindex: focusInvalidTabindex,
|
|
798
|
+
focusLabelTabindex: focusLabelTabindex,
|
|
799
|
+
focusObjectSvg: focusObjectSvg,
|
|
800
|
+
focusObjectSvgHidden: focusObjectSvgHidden,
|
|
801
|
+
focusRedirectImgUsemap: focusRedirectImgUsemap,
|
|
802
|
+
focusRedirectLegend: focusRedirectLegend,
|
|
803
|
+
focusScrollBody: focusScrollBody,
|
|
804
|
+
focusScrollContainerWithoutOverflow: focusScrollContainerWithoutOverflow,
|
|
805
|
+
focusScrollContainer: focusScrollContainer,
|
|
806
|
+
focusSummary: focusSummary,
|
|
807
|
+
focusSvgFocusableAttribute: focusSvgFocusableAttribute,
|
|
808
|
+
focusSvgTabindexAttribute: focusSvgTabindexAttribute,
|
|
809
|
+
focusSvgNegativeTabindexAttribute: focusSvgNegativeTabindexAttribute,
|
|
810
|
+
focusSvgUseTabindex: focusSvgUseTabindex,
|
|
811
|
+
focusSvgForeignobjectTabindex: focusSvgForeignobjectTabindex,
|
|
812
|
+
focusSvg: focusSvg,
|
|
813
|
+
focusTabindexTrailingCharacters: focusTabindexTrailingCharacters,
|
|
814
|
+
focusTable: focusTable,
|
|
815
|
+
focusVideoWithoutControls: focusVideoWithoutControls
|
|
816
|
+
};
|
|
817
|
+
function executeTests() {
|
|
818
|
+
var results = detectFocus(testDescriptions);
|
|
819
|
+
Object.keys(testCallbacks).forEach(function(key) {
|
|
820
|
+
results[key] = testCallbacks[key]();
|
|
821
|
+
});
|
|
822
|
+
return results;
|
|
823
|
+
}
|
|
824
|
+
var supportsCache = null;
|
|
825
|
+
function _supports() {
|
|
826
|
+
if (supportsCache) {
|
|
827
|
+
return supportsCache;
|
|
828
|
+
}
|
|
829
|
+
supportsCache = cache$1.get();
|
|
830
|
+
if (!supportsCache.time) {
|
|
831
|
+
cache$1.set(executeTests());
|
|
832
|
+
supportsCache = cache$1.get();
|
|
833
|
+
}
|
|
834
|
+
return supportsCache;
|
|
835
|
+
}
|
|
836
|
+
var supports = void 0;
|
|
837
|
+
// https://www.w3.org/TR/html5/infrastructure.html#rules-for-parsing-integers
|
|
838
|
+
// NOTE: all browsers agree to allow trailing spaces as well
|
|
839
|
+
var validIntegerPatternNoTrailing = /^\s*(-|\+)?[0-9]+\s*$/;
|
|
840
|
+
var validIntegerPatternWithTrailing = /^\s*(-|\+)?[0-9]+.*$/;
|
|
841
|
+
function isValidTabindex(context) {
|
|
842
|
+
if (!supports) {
|
|
843
|
+
supports = _supports();
|
|
844
|
+
}
|
|
845
|
+
var validIntegerPattern = supports.focusTabindexTrailingCharacters ? validIntegerPatternWithTrailing : validIntegerPatternNoTrailing;
|
|
846
|
+
var element = contextToElement({
|
|
847
|
+
label: 'is/valid-tabindex',
|
|
848
|
+
resolveDocument: true,
|
|
849
|
+
context: context
|
|
850
|
+
});
|
|
851
|
+
// Edge 14 has a capitalization problem on SVG elements,
|
|
852
|
+
// see https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/9282058/
|
|
853
|
+
var hasTabindex = element.hasAttribute('tabindex');
|
|
854
|
+
var hasTabIndex = element.hasAttribute('tabIndex');
|
|
855
|
+
if (!hasTabindex && !hasTabIndex) {
|
|
856
|
+
return false;
|
|
857
|
+
}
|
|
858
|
+
// older Firefox and Internet Explorer don't support tabindex on SVG elements
|
|
859
|
+
var isSvgElement = element.ownerSVGElement || element.nodeName.toLowerCase() === 'svg';
|
|
860
|
+
if (isSvgElement && !supports.focusSvgTabindexAttribute) {
|
|
861
|
+
return false;
|
|
862
|
+
}
|
|
863
|
+
// @browser-issue Gecko https://bugzilla.mozilla.org/show_bug.cgi?id=1128054
|
|
864
|
+
if (supports.focusInvalidTabindex) {
|
|
865
|
+
return true;
|
|
866
|
+
}
|
|
867
|
+
// an element matches the tabindex selector even if its value is invalid
|
|
868
|
+
var tabindex = element.getAttribute(hasTabindex ? 'tabindex' : 'tabIndex');
|
|
869
|
+
// IE11 parses tabindex="" as the value "-32768"
|
|
870
|
+
// @browser-issue Trident https://connect.microsoft.com/IE/feedback/details/1072965
|
|
871
|
+
if (tabindex === '-32768') {
|
|
872
|
+
return false;
|
|
873
|
+
}
|
|
874
|
+
return Boolean(tabindex && validIntegerPattern.test(tabindex));
|
|
875
|
+
}
|
|
876
|
+
function tabindexValue(element) {
|
|
877
|
+
if (!isValidTabindex(element)) {
|
|
878
|
+
return null;
|
|
879
|
+
}
|
|
880
|
+
// Edge 14 has a capitalization problem on SVG elements,
|
|
881
|
+
// see https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/9282058/
|
|
882
|
+
var hasTabindex = element.hasAttribute('tabindex');
|
|
883
|
+
var attributeName = hasTabindex ? 'tabindex' : 'tabIndex';
|
|
884
|
+
// @browser-issue Gecko https://bugzilla.mozilla.org/show_bug.cgi?id=1128054
|
|
885
|
+
var tabindex = parseInt(element.getAttribute(attributeName), 10);
|
|
886
|
+
return isNaN(tabindex) ? -1 : tabindex;
|
|
887
|
+
}
|
|
888
|
+
// this is a shared utility file for focus-relevant.js and tabbable.js
|
|
889
|
+
// separate testing of this file's functions is not necessary,
|
|
890
|
+
// as they're implicitly tested by way of the consumers
|
|
891
|
+
function isUserModifyWritable(style) {
|
|
892
|
+
// https://www.w3.org/TR/1999/WD-css3-userint-19990916#user-modify
|
|
893
|
+
// https://github.com/medialize/ally.js/issues/17
|
|
894
|
+
var userModify = style.webkitUserModify || '';
|
|
895
|
+
return Boolean(userModify && userModify.indexOf('write') !== -1);
|
|
896
|
+
}
|
|
897
|
+
function hasCssOverflowScroll(style) {
|
|
898
|
+
return [
|
|
899
|
+
style.getPropertyValue('overflow'),
|
|
900
|
+
style.getPropertyValue('overflow-x'),
|
|
901
|
+
style.getPropertyValue('overflow-y')
|
|
902
|
+
].some(function(overflow) {
|
|
903
|
+
return overflow === 'auto' || overflow === 'scroll';
|
|
904
|
+
});
|
|
905
|
+
}
|
|
906
|
+
function hasCssDisplayFlex(style) {
|
|
907
|
+
return style.display.indexOf('flex') > -1;
|
|
908
|
+
}
|
|
909
|
+
function isScrollableContainer(element, nodeName, parentNodeName, parentStyle) {
|
|
910
|
+
if (nodeName !== 'div' && nodeName !== 'span') {
|
|
911
|
+
// Internet Explorer advances scrollable containers and bodies to focusable
|
|
912
|
+
// only if the scrollable container is <div> or <span> - this does *not*
|
|
913
|
+
// happen for <section>, <article>, …
|
|
914
|
+
return false;
|
|
915
|
+
}
|
|
916
|
+
if (parentNodeName && parentNodeName !== 'div' && parentNodeName !== 'span' && !hasCssOverflowScroll(parentStyle)) {
|
|
917
|
+
return false;
|
|
918
|
+
}
|
|
919
|
+
return element.offsetHeight < element.scrollHeight || element.offsetWidth < element.scrollWidth;
|
|
920
|
+
}
|
|
921
|
+
var supports$1 = void 0;
|
|
922
|
+
function isFocusRelevantRules() {
|
|
923
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, _ref$except = _ref.except, except = _ref$except === undefined ? {
|
|
924
|
+
flexbox: false,
|
|
925
|
+
scrollable: false,
|
|
926
|
+
shadow: false
|
|
927
|
+
} : _ref$except;
|
|
928
|
+
if (!supports$1) {
|
|
929
|
+
supports$1 = _supports();
|
|
930
|
+
}
|
|
931
|
+
var element = contextToElement({
|
|
932
|
+
label: 'is/focus-relevant',
|
|
933
|
+
resolveDocument: true,
|
|
934
|
+
context: context
|
|
935
|
+
});
|
|
936
|
+
if (!except.shadow && element.shadowRoot) {
|
|
937
|
+
// a ShadowDOM host receives focus when the focus moves to its content
|
|
938
|
+
return true;
|
|
939
|
+
}
|
|
940
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
941
|
+
if (nodeName === 'input' && element.type === 'hidden') {
|
|
942
|
+
// input[type="hidden"] supports.cannot be focused
|
|
943
|
+
return false;
|
|
944
|
+
}
|
|
945
|
+
if (nodeName === 'input' || nodeName === 'select' || nodeName === 'button' || nodeName === 'textarea') {
|
|
946
|
+
return true;
|
|
947
|
+
}
|
|
948
|
+
if (nodeName === 'legend' && supports$1.focusRedirectLegend) {
|
|
949
|
+
// specifics filtered in is/focusable
|
|
950
|
+
return true;
|
|
951
|
+
}
|
|
952
|
+
if (nodeName === 'label') {
|
|
953
|
+
// specifics filtered in is/focusable
|
|
954
|
+
return true;
|
|
955
|
+
}
|
|
956
|
+
if (nodeName === 'area') {
|
|
957
|
+
// specifics filtered in is/focusable
|
|
958
|
+
return true;
|
|
959
|
+
}
|
|
960
|
+
if (nodeName === 'a' && element.hasAttribute('href')) {
|
|
961
|
+
return true;
|
|
962
|
+
}
|
|
963
|
+
if (nodeName === 'object' && element.hasAttribute('usemap')) {
|
|
964
|
+
// object[usemap] is not focusable in any browser
|
|
965
|
+
return false;
|
|
966
|
+
}
|
|
967
|
+
if (nodeName === 'object') {
|
|
968
|
+
var svgType = element.getAttribute('type');
|
|
969
|
+
if (!supports$1.focusObjectSvg && svgType === 'image/svg+xml') {
|
|
970
|
+
// object[type="image/svg+xml"] is not focusable in Internet Explorer
|
|
971
|
+
return false;
|
|
972
|
+
} else if (!supports$1.focusObjectSwf && svgType === 'application/x-shockwave-flash') {
|
|
973
|
+
// object[type="application/x-shockwave-flash"] is not focusable in Internet Explorer 9
|
|
974
|
+
return false;
|
|
975
|
+
}
|
|
976
|
+
}
|
|
977
|
+
if (nodeName === 'iframe' || nodeName === 'object') {
|
|
978
|
+
// browsing context containers
|
|
979
|
+
return true;
|
|
980
|
+
}
|
|
981
|
+
if (nodeName === 'embed' || nodeName === 'keygen') {
|
|
982
|
+
// embed is considered focus-relevant but not focusable
|
|
983
|
+
// see https://github.com/medialize/ally.js/issues/82
|
|
984
|
+
return true;
|
|
985
|
+
}
|
|
986
|
+
if (element.hasAttribute('contenteditable')) {
|
|
987
|
+
// also see CSS property user-modify below
|
|
988
|
+
return true;
|
|
989
|
+
}
|
|
990
|
+
if (nodeName === 'audio' && (supports$1.focusAudioWithoutControls || element.hasAttribute('controls'))) {
|
|
991
|
+
return true;
|
|
992
|
+
}
|
|
993
|
+
if (nodeName === 'video' && (supports$1.focusVideoWithoutControls || element.hasAttribute('controls'))) {
|
|
994
|
+
return true;
|
|
995
|
+
}
|
|
996
|
+
if (supports$1.focusSummary && nodeName === 'summary') {
|
|
997
|
+
return true;
|
|
998
|
+
}
|
|
999
|
+
var validTabindex = isValidTabindex(element);
|
|
1000
|
+
if (nodeName === 'img' && element.hasAttribute('usemap')) {
|
|
1001
|
+
// Gecko, Trident and Edge do not allow an image with an image map and tabindex to be focused,
|
|
1002
|
+
// it appears the tabindex is overruled so focus is still forwarded to the <map>
|
|
1003
|
+
return validTabindex && supports$1.focusImgUsemapTabindex || supports$1.focusRedirectImgUsemap;
|
|
1004
|
+
}
|
|
1005
|
+
if (supports$1.focusTable && (nodeName === 'table' || nodeName === 'td')) {
|
|
1006
|
+
// IE10-11 supports.can focus <table> and <td>
|
|
1007
|
+
return true;
|
|
1008
|
+
}
|
|
1009
|
+
if (supports$1.focusFieldset && nodeName === 'fieldset') {
|
|
1010
|
+
// IE10-11 supports.can focus <fieldset>
|
|
1011
|
+
return true;
|
|
1012
|
+
}
|
|
1013
|
+
var isSvgElement = nodeName === 'svg';
|
|
1014
|
+
var isSvgContent = element.ownerSVGElement;
|
|
1015
|
+
var focusableAttribute = element.getAttribute('focusable');
|
|
1016
|
+
var tabindex = tabindexValue(element);
|
|
1017
|
+
if (nodeName === 'use' && tabindex !== null && !supports$1.focusSvgUseTabindex) {
|
|
1018
|
+
// <use> cannot be made focusable by adding a tabindex attribute anywhere but Blink and WebKit
|
|
1019
|
+
return false;
|
|
1020
|
+
}
|
|
1021
|
+
if (nodeName === 'foreignobject') {
|
|
1022
|
+
// <use> can only be made focusable in Blink and WebKit
|
|
1023
|
+
return tabindex !== null && supports$1.focusSvgForeignobjectTabindex;
|
|
1024
|
+
}
|
|
1025
|
+
if (elementMatches(element, 'svg a') && element.hasAttribute('xlink:href')) {
|
|
1026
|
+
return true;
|
|
1027
|
+
}
|
|
1028
|
+
if ((isSvgElement || isSvgContent) && element.focus && !supports$1.focusSvgNegativeTabindexAttribute && tabindex < 0) {
|
|
1029
|
+
// Firefox 51 and 52 treat any natively tabbable SVG element with
|
|
1030
|
+
// tabindex="-1" as tabbable and everything else as inert
|
|
1031
|
+
// see https://bugzilla.mozilla.org/show_bug.cgi?id=1302340
|
|
1032
|
+
return false;
|
|
1033
|
+
}
|
|
1034
|
+
if (isSvgElement) {
|
|
1035
|
+
return validTabindex || supports$1.focusSvg || supports$1.focusSvgInIframe || // Internet Explorer understands the focusable attribute introduced in SVG Tiny 1.2
|
|
1036
|
+
Boolean(supports$1.focusSvgFocusableAttribute && focusableAttribute && focusableAttribute === 'true');
|
|
1037
|
+
}
|
|
1038
|
+
if (isSvgContent) {
|
|
1039
|
+
if (supports$1.focusSvgTabindexAttribute && validTabindex) {
|
|
1040
|
+
return true;
|
|
1041
|
+
}
|
|
1042
|
+
if (supports$1.focusSvgFocusableAttribute) {
|
|
1043
|
+
// Internet Explorer understands the focusable attribute introduced in SVG Tiny 1.2
|
|
1044
|
+
return focusableAttribute === 'true';
|
|
1045
|
+
}
|
|
1046
|
+
}
|
|
1047
|
+
// https://www.w3.org/TR/html5/editing.html#sequential-focus-navigation-and-the-tabindex-attribute
|
|
1048
|
+
if (validTabindex) {
|
|
1049
|
+
return true;
|
|
1050
|
+
}
|
|
1051
|
+
var style = window.getComputedStyle(element, null);
|
|
1052
|
+
if (isUserModifyWritable(style)) {
|
|
1053
|
+
return true;
|
|
1054
|
+
}
|
|
1055
|
+
if (supports$1.focusImgIsmap && nodeName === 'img' && element.hasAttribute('ismap')) {
|
|
1056
|
+
// IE10-11 considers the <img> in <a href><img ismap> focusable
|
|
1057
|
+
// https://github.com/medialize/ally.js/issues/20
|
|
1058
|
+
var hasLinkParent = getParents({
|
|
1059
|
+
context: element
|
|
1060
|
+
}).some(function(parent) {
|
|
1061
|
+
return parent.nodeName.toLowerCase() === 'a' && parent.hasAttribute('href');
|
|
1062
|
+
});
|
|
1063
|
+
if (hasLinkParent) {
|
|
1064
|
+
return true;
|
|
1065
|
+
}
|
|
1066
|
+
}
|
|
1067
|
+
// https://github.com/medialize/ally.js/issues/21
|
|
1068
|
+
if (!except.scrollable && supports$1.focusScrollContainer) {
|
|
1069
|
+
if (supports$1.focusScrollContainerWithoutOverflow) {
|
|
1070
|
+
// Internet Explorer does will consider the scrollable area focusable
|
|
1071
|
+
// if the element is a <div> or a <span> and it is in fact scrollable,
|
|
1072
|
+
// regardless of the CSS overflow property
|
|
1073
|
+
if (isScrollableContainer(element, nodeName)) {
|
|
1074
|
+
return true;
|
|
1075
|
+
}
|
|
1076
|
+
} else if (hasCssOverflowScroll(style)) {
|
|
1077
|
+
// Firefox requires proper overflow setting, IE does not necessarily
|
|
1078
|
+
// https://developer.mozilla.org/docs/Web/CSS/overflow
|
|
1079
|
+
return true;
|
|
1080
|
+
}
|
|
1081
|
+
}
|
|
1082
|
+
if (!except.flexbox && supports$1.focusFlexboxContainer && hasCssDisplayFlex(style)) {
|
|
1083
|
+
// elements with display:flex are focusable in IE10-11
|
|
1084
|
+
return true;
|
|
1085
|
+
}
|
|
1086
|
+
var parent = element.parentElement;
|
|
1087
|
+
if (!except.scrollable && parent) {
|
|
1088
|
+
var parentNodeName = parent.nodeName.toLowerCase();
|
|
1089
|
+
var parentStyle = window.getComputedStyle(parent, null);
|
|
1090
|
+
if (supports$1.focusScrollBody && isScrollableContainer(parent, nodeName, parentNodeName, parentStyle)) {
|
|
1091
|
+
// scrollable bodies are focusable Internet Explorer
|
|
1092
|
+
// https://github.com/medialize/ally.js/issues/21
|
|
1093
|
+
return true;
|
|
1094
|
+
}
|
|
1095
|
+
// Children of focusable elements with display:flex are focusable in IE10-11
|
|
1096
|
+
if (supports$1.focusChildrenOfFocusableFlexbox) {
|
|
1097
|
+
if (hasCssDisplayFlex(parentStyle)) {
|
|
1098
|
+
return true;
|
|
1099
|
+
}
|
|
1100
|
+
}
|
|
1101
|
+
}
|
|
1102
|
+
// NOTE: elements marked as inert are not focusable,
|
|
1103
|
+
// but that property is not exposed to the DOM
|
|
1104
|
+
// https://www.w3.org/TR/html5/editing.html#inert
|
|
1105
|
+
return false;
|
|
1106
|
+
}
|
|
1107
|
+
// bind exceptions to an iterator callback
|
|
1108
|
+
isFocusRelevantRules.except = function() {
|
|
1109
|
+
var except = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
1110
|
+
var isFocusRelevant = function isFocusRelevant(context) {
|
|
1111
|
+
return isFocusRelevantRules({
|
|
1112
|
+
context: context,
|
|
1113
|
+
except: except
|
|
1114
|
+
});
|
|
1115
|
+
};
|
|
1116
|
+
isFocusRelevant.rules = isFocusRelevantRules;
|
|
1117
|
+
return isFocusRelevant;
|
|
1118
|
+
};
|
|
1119
|
+
// provide isFocusRelevant(context) as default iterator callback
|
|
1120
|
+
var isFocusRelevant = isFocusRelevantRules.except({});
|
|
1121
|
+
function findIndex(array, callback) {
|
|
1122
|
+
// attempt to use native or polyfilled Array#findIndex first
|
|
1123
|
+
if (array.findIndex) {
|
|
1124
|
+
return array.findIndex(callback);
|
|
1125
|
+
}
|
|
1126
|
+
var length = array.length;
|
|
1127
|
+
// shortcut if the array is empty
|
|
1128
|
+
if (length === 0) {
|
|
1129
|
+
return -1;
|
|
1130
|
+
}
|
|
1131
|
+
// otherwise loop over array
|
|
1132
|
+
for(var i = 0; i < length; i++){
|
|
1133
|
+
if (callback(array[i], i, array)) {
|
|
1134
|
+
return i;
|
|
1135
|
+
}
|
|
1136
|
+
}
|
|
1137
|
+
return -1;
|
|
1138
|
+
}
|
|
1139
|
+
function getContentDocument(node) {
|
|
1140
|
+
try {
|
|
1141
|
+
// works on <object> and <iframe>
|
|
1142
|
+
return node.contentDocument || // works on <object> and <iframe>
|
|
1143
|
+
node.contentWindow && node.contentWindow.document || // works on <object> and <iframe> that contain SVG
|
|
1144
|
+
node.getSVGDocument && node.getSVGDocument() || null;
|
|
1145
|
+
} catch (e) {
|
|
1146
|
+
// SecurityError: Failed to read the 'contentDocument' property from 'HTMLObjectElement'
|
|
1147
|
+
// also IE may throw member not found exception e.g. on <object type="image/png">
|
|
1148
|
+
return null;
|
|
1149
|
+
}
|
|
1150
|
+
}
|
|
1151
|
+
function getWindow(node) {
|
|
1152
|
+
var _document = getDocument(node);
|
|
1153
|
+
return _document.defaultView || window;
|
|
1154
|
+
}
|
|
1155
|
+
var shadowPrefix = void 0;
|
|
1156
|
+
function selectInShadows(selector) {
|
|
1157
|
+
if (typeof shadowPrefix !== 'string') {
|
|
1158
|
+
var operator = cssShadowPiercingDeepCombinator();
|
|
1159
|
+
if (operator) {
|
|
1160
|
+
shadowPrefix = ', html ' + operator + ' ';
|
|
1161
|
+
}
|
|
1162
|
+
}
|
|
1163
|
+
if (!shadowPrefix) {
|
|
1164
|
+
return selector;
|
|
1165
|
+
}
|
|
1166
|
+
return selector + shadowPrefix + selector.replace(/\s*,\s*/g, ',').split(',').join(shadowPrefix);
|
|
1167
|
+
}
|
|
1168
|
+
var selector = void 0;
|
|
1169
|
+
function findDocumentHostElement(_window) {
|
|
1170
|
+
if (!selector) {
|
|
1171
|
+
selector = selectInShadows('object, iframe');
|
|
1172
|
+
}
|
|
1173
|
+
if (_window._frameElement !== undefined) {
|
|
1174
|
+
return _window._frameElement;
|
|
1175
|
+
}
|
|
1176
|
+
_window._frameElement = null;
|
|
1177
|
+
var potentialHosts = _window.parent.document.querySelectorAll(selector);
|
|
1178
|
+
[].some.call(potentialHosts, function(element) {
|
|
1179
|
+
var _document = getContentDocument(element);
|
|
1180
|
+
if (_document !== _window.document) {
|
|
1181
|
+
return false;
|
|
1182
|
+
}
|
|
1183
|
+
_window._frameElement = element;
|
|
1184
|
+
return true;
|
|
1185
|
+
});
|
|
1186
|
+
return _window._frameElement;
|
|
1187
|
+
}
|
|
1188
|
+
function getFrameElement(element) {
|
|
1189
|
+
var _window = getWindow(element);
|
|
1190
|
+
if (!_window.parent || _window.parent === _window) {
|
|
1191
|
+
// if there is no parent browsing context,
|
|
1192
|
+
// we're not going to get a frameElement either way
|
|
1193
|
+
return null;
|
|
1194
|
+
}
|
|
1195
|
+
try {
|
|
1196
|
+
// see https://developer.mozilla.org/docs/Web/API/Window/frameElement
|
|
1197
|
+
// does not work within <embed> anywhere, and not within in <object> in IE
|
|
1198
|
+
return _window.frameElement || findDocumentHostElement(_window);
|
|
1199
|
+
} catch (e) {
|
|
1200
|
+
return null;
|
|
1201
|
+
}
|
|
1202
|
+
}
|
|
1203
|
+
// https://www.w3.org/TR/html5/rendering.html#being-rendered
|
|
1204
|
+
// <area> is not rendered, but we *consider* it visible to simplfiy this function's usage
|
|
1205
|
+
var notRenderedElementsPattern = /^(area)$/;
|
|
1206
|
+
function computedStyle(element, property) {
|
|
1207
|
+
return window.getComputedStyle(element, null).getPropertyValue(property);
|
|
1208
|
+
}
|
|
1209
|
+
function notDisplayed(_path) {
|
|
1210
|
+
return _path.some(function(element) {
|
|
1211
|
+
// display:none is not visible (optimized away at layout)
|
|
1212
|
+
return computedStyle(element, 'display') === 'none';
|
|
1213
|
+
});
|
|
1214
|
+
}
|
|
1215
|
+
function notVisible(_path) {
|
|
1216
|
+
// https://github.com/jquery/jquery-ui/blob/master/ui/core.js#L109-L114
|
|
1217
|
+
// NOTE: a nested element can reverse visibility:hidden|collapse by explicitly setting visibility:visible
|
|
1218
|
+
// NOTE: visibility can be ["", "visible", "hidden", "collapse"]
|
|
1219
|
+
var hidden = findIndex(_path, function(element) {
|
|
1220
|
+
var visibility = computedStyle(element, 'visibility');
|
|
1221
|
+
return visibility === 'hidden' || visibility === 'collapse';
|
|
1222
|
+
});
|
|
1223
|
+
if (hidden === -1) {
|
|
1224
|
+
// there is no hidden element
|
|
1225
|
+
return false;
|
|
1226
|
+
}
|
|
1227
|
+
var visible = findIndex(_path, function(element) {
|
|
1228
|
+
return computedStyle(element, 'visibility') === 'visible';
|
|
1229
|
+
});
|
|
1230
|
+
if (visible === -1) {
|
|
1231
|
+
// there is no visible element (but a hidden element)
|
|
1232
|
+
return true;
|
|
1233
|
+
}
|
|
1234
|
+
if (hidden < visible) {
|
|
1235
|
+
// there is a hidden element and it's closer than the first visible element
|
|
1236
|
+
return true;
|
|
1237
|
+
}
|
|
1238
|
+
// there may be a hidden element, but the closest element is visible
|
|
1239
|
+
return false;
|
|
1240
|
+
}
|
|
1241
|
+
function collapsedParent(_path) {
|
|
1242
|
+
var offset = 1;
|
|
1243
|
+
if (_path[0].nodeName.toLowerCase() === 'summary') {
|
|
1244
|
+
offset = 2;
|
|
1245
|
+
}
|
|
1246
|
+
return _path.slice(offset).some(function(element) {
|
|
1247
|
+
// "content children" of a closed details element are not visible
|
|
1248
|
+
return element.nodeName.toLowerCase() === 'details' && element.open === false;
|
|
1249
|
+
});
|
|
1250
|
+
}
|
|
1251
|
+
function isVisibleRules() {
|
|
1252
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, _ref$except = _ref.except, except = _ref$except === undefined ? {
|
|
1253
|
+
notRendered: false,
|
|
1254
|
+
cssDisplay: false,
|
|
1255
|
+
cssVisibility: false,
|
|
1256
|
+
detailsElement: false,
|
|
1257
|
+
browsingContext: false
|
|
1258
|
+
} : _ref$except;
|
|
1259
|
+
var element = contextToElement({
|
|
1260
|
+
label: 'is/visible',
|
|
1261
|
+
resolveDocument: true,
|
|
1262
|
+
context: context
|
|
1263
|
+
});
|
|
1264
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1265
|
+
if (!except.notRendered && notRenderedElementsPattern.test(nodeName)) {
|
|
1266
|
+
return true;
|
|
1267
|
+
}
|
|
1268
|
+
var _path = getParents({
|
|
1269
|
+
context: element
|
|
1270
|
+
});
|
|
1271
|
+
// in Internet Explorer <audio> has a default display: none, where others have display: inline
|
|
1272
|
+
// but IE allows focusing <audio style="display:none">, but not <div display:none><audio>
|
|
1273
|
+
// this is irrelevant to other browsers, as the controls attribute is required to make <audio> focusable
|
|
1274
|
+
var isAudioWithoutControls = nodeName === 'audio' && !element.hasAttribute('controls');
|
|
1275
|
+
if (!except.cssDisplay && notDisplayed(isAudioWithoutControls ? _path.slice(1) : _path)) {
|
|
1276
|
+
return false;
|
|
1277
|
+
}
|
|
1278
|
+
if (!except.cssVisibility && notVisible(_path)) {
|
|
1279
|
+
return false;
|
|
1280
|
+
}
|
|
1281
|
+
if (!except.detailsElement && collapsedParent(_path)) {
|
|
1282
|
+
return false;
|
|
1283
|
+
}
|
|
1284
|
+
if (!except.browsingContext) {
|
|
1285
|
+
// elements within a browsing context are affected by the
|
|
1286
|
+
// browsing context host element's visibility and tabindex
|
|
1287
|
+
var frameElement = getFrameElement(element);
|
|
1288
|
+
var _isVisible = isVisibleRules.except(except);
|
|
1289
|
+
if (frameElement && !_isVisible(frameElement)) {
|
|
1290
|
+
return false;
|
|
1291
|
+
}
|
|
1292
|
+
}
|
|
1293
|
+
return true;
|
|
1294
|
+
}
|
|
1295
|
+
// bind exceptions to an iterator callback
|
|
1296
|
+
isVisibleRules.except = function() {
|
|
1297
|
+
var except = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
1298
|
+
var isVisible = function isVisible(context) {
|
|
1299
|
+
return isVisibleRules({
|
|
1300
|
+
context: context,
|
|
1301
|
+
except: except
|
|
1302
|
+
});
|
|
1303
|
+
};
|
|
1304
|
+
isVisible.rules = isVisibleRules;
|
|
1305
|
+
return isVisible;
|
|
1306
|
+
};
|
|
1307
|
+
// provide isVisible(context) as default iterator callback
|
|
1308
|
+
var isVisible = isVisibleRules.except({});
|
|
1309
|
+
function getMapByName(name, _document) {
|
|
1310
|
+
// apparently getElementsByName() also considers id attribute in IE & opera
|
|
1311
|
+
// https://developer.mozilla.org/docs/Web/API/Document/getElementsByName
|
|
1312
|
+
var map = _document.querySelector('map[name="' + (0, _cssescape.default)(name) + '"]');
|
|
1313
|
+
return map || null;
|
|
1314
|
+
}
|
|
1315
|
+
function getImageOfArea(element) {
|
|
1316
|
+
var map = element.parentElement;
|
|
1317
|
+
if (!map.name || map.nodeName.toLowerCase() !== 'map') {
|
|
1318
|
+
return null;
|
|
1319
|
+
}
|
|
1320
|
+
// NOTE: image maps can also be applied to <object> with image content,
|
|
1321
|
+
// but no browser supports this at the moment
|
|
1322
|
+
// HTML5 specifies HTMLMapElement.images to be an HTMLCollection of all
|
|
1323
|
+
// <img> and <object> referencing the <map> element, but no browser implements this
|
|
1324
|
+
// https://www.w3.org/TR/html5/embedded-content-0.html#the-map-element
|
|
1325
|
+
// https://developer.mozilla.org/docs/Web/API/HTMLMapElement
|
|
1326
|
+
// the image must be valid and loaded for the map to take effect
|
|
1327
|
+
var _document = getDocument(element);
|
|
1328
|
+
return _document.querySelector('img[usemap="#' + (0, _cssescape.default)(map.name) + '"]') || null;
|
|
1329
|
+
}
|
|
1330
|
+
var supports$2 = void 0;
|
|
1331
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/map
|
|
1332
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/img#attr-usemap
|
|
1333
|
+
// https://github.com/jquery/jquery-ui/blob/master/ui/core.js#L88-L107
|
|
1334
|
+
function isValidArea(context) {
|
|
1335
|
+
if (!supports$2) {
|
|
1336
|
+
supports$2 = _supports();
|
|
1337
|
+
}
|
|
1338
|
+
var element = contextToElement({
|
|
1339
|
+
label: 'is/valid-area',
|
|
1340
|
+
context: context
|
|
1341
|
+
});
|
|
1342
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1343
|
+
if (nodeName !== 'area') {
|
|
1344
|
+
return false;
|
|
1345
|
+
}
|
|
1346
|
+
var hasTabindex = element.hasAttribute('tabindex');
|
|
1347
|
+
if (!supports$2.focusAreaTabindex && hasTabindex) {
|
|
1348
|
+
// Blink and WebKit do not consider <area tabindex="-1" href="#void"> focusable
|
|
1349
|
+
return false;
|
|
1350
|
+
}
|
|
1351
|
+
var img = getImageOfArea(element);
|
|
1352
|
+
if (!img || !isVisible(img)) {
|
|
1353
|
+
return false;
|
|
1354
|
+
}
|
|
1355
|
+
// Firefox only allows fully loaded images to reference image maps
|
|
1356
|
+
// https://stereochro.me/ideas/detecting-broken-images-js
|
|
1357
|
+
if (!supports$2.focusBrokenImageMap && (!img.complete || !img.naturalHeight || img.offsetWidth <= 0 || img.offsetHeight <= 0)) {
|
|
1358
|
+
return false;
|
|
1359
|
+
}
|
|
1360
|
+
// Firefox supports.can focus area elements even if they don't have an href attribute
|
|
1361
|
+
if (!supports$2.focusAreaWithoutHref && !element.href) {
|
|
1362
|
+
// Internet explorer supports.can focus area elements without href if either
|
|
1363
|
+
// the area element or the image element has a tabindex attribute
|
|
1364
|
+
return supports$2.focusAreaTabindex && hasTabindex || supports$2.focusAreaImgTabindex && img.hasAttribute('tabindex');
|
|
1365
|
+
}
|
|
1366
|
+
// https://developer.mozilla.org/docs/Web/HTML/Element/img#attr-usemap
|
|
1367
|
+
var childOfInteractive = getParents({
|
|
1368
|
+
context: img
|
|
1369
|
+
}).slice(1).some(function(_element) {
|
|
1370
|
+
var name = _element.nodeName.toLowerCase();
|
|
1371
|
+
return name === 'button' || name === 'a';
|
|
1372
|
+
});
|
|
1373
|
+
if (childOfInteractive) {
|
|
1374
|
+
return false;
|
|
1375
|
+
}
|
|
1376
|
+
return true;
|
|
1377
|
+
}
|
|
1378
|
+
var supports$3 = void 0;
|
|
1379
|
+
// https://www.w3.org/TR/html5/disabled-elements.html#concept-element-disabled
|
|
1380
|
+
var disabledElementsPattern = void 0;
|
|
1381
|
+
var disabledElements = {
|
|
1382
|
+
input: true,
|
|
1383
|
+
select: true,
|
|
1384
|
+
textarea: true,
|
|
1385
|
+
button: true,
|
|
1386
|
+
fieldset: true,
|
|
1387
|
+
form: true
|
|
1388
|
+
};
|
|
1389
|
+
function isNativeDisabledSupported(context) {
|
|
1390
|
+
if (!supports$3) {
|
|
1391
|
+
supports$3 = _supports();
|
|
1392
|
+
if (supports$3.focusFieldsetDisabled) {
|
|
1393
|
+
delete disabledElements.fieldset;
|
|
1394
|
+
}
|
|
1395
|
+
if (supports$3.focusFormDisabled) {
|
|
1396
|
+
delete disabledElements.form;
|
|
1397
|
+
}
|
|
1398
|
+
disabledElementsPattern = new RegExp('^(' + Object.keys(disabledElements).join('|') + ')$');
|
|
1399
|
+
}
|
|
1400
|
+
var element = contextToElement({
|
|
1401
|
+
label: 'is/native-disabled-supported',
|
|
1402
|
+
context: context
|
|
1403
|
+
});
|
|
1404
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1405
|
+
return Boolean(disabledElementsPattern.test(nodeName));
|
|
1406
|
+
}
|
|
1407
|
+
var supports$4 = void 0;
|
|
1408
|
+
function isDisabledFieldset(element) {
|
|
1409
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1410
|
+
return nodeName === 'fieldset' && element.disabled;
|
|
1411
|
+
}
|
|
1412
|
+
function isDisabledForm(element) {
|
|
1413
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1414
|
+
return nodeName === 'form' && element.disabled;
|
|
1415
|
+
}
|
|
1416
|
+
function isDisabled(context) {
|
|
1417
|
+
if (!supports$4) {
|
|
1418
|
+
supports$4 = _supports();
|
|
1419
|
+
}
|
|
1420
|
+
var element = contextToElement({
|
|
1421
|
+
label: 'is/disabled',
|
|
1422
|
+
context: context
|
|
1423
|
+
});
|
|
1424
|
+
if (element.hasAttribute('data-ally-disabled')) {
|
|
1425
|
+
// treat ally's element/disabled like the DOM native element.disabled
|
|
1426
|
+
return true;
|
|
1427
|
+
}
|
|
1428
|
+
if (!isNativeDisabledSupported(element)) {
|
|
1429
|
+
// non-form elements do not support the disabled attribute
|
|
1430
|
+
return false;
|
|
1431
|
+
}
|
|
1432
|
+
if (element.disabled) {
|
|
1433
|
+
// the element itself is disabled
|
|
1434
|
+
return true;
|
|
1435
|
+
}
|
|
1436
|
+
var parents = getParents({
|
|
1437
|
+
context: element
|
|
1438
|
+
});
|
|
1439
|
+
if (parents.some(isDisabledFieldset)) {
|
|
1440
|
+
// a parental <fieldset> is disabld and inherits the state onto this element
|
|
1441
|
+
return true;
|
|
1442
|
+
}
|
|
1443
|
+
if (!supports$4.focusFormDisabled && parents.some(isDisabledForm)) {
|
|
1444
|
+
// a parental <form> is disabld and inherits the state onto this element
|
|
1445
|
+
return true;
|
|
1446
|
+
}
|
|
1447
|
+
return false;
|
|
1448
|
+
}
|
|
1449
|
+
function isOnlyTabbableRules() {
|
|
1450
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, _ref$except = _ref.except, except = _ref$except === undefined ? {
|
|
1451
|
+
onlyFocusableBrowsingContext: false,
|
|
1452
|
+
visible: false
|
|
1453
|
+
} : _ref$except;
|
|
1454
|
+
var element = contextToElement({
|
|
1455
|
+
label: 'is/only-tabbable',
|
|
1456
|
+
resolveDocument: true,
|
|
1457
|
+
context: context
|
|
1458
|
+
});
|
|
1459
|
+
if (!except.visible && !isVisible(element)) {
|
|
1460
|
+
return false;
|
|
1461
|
+
}
|
|
1462
|
+
if (!except.onlyFocusableBrowsingContext && (platform.is.GECKO || platform.is.TRIDENT || platform.is.EDGE)) {
|
|
1463
|
+
var frameElement = getFrameElement(element);
|
|
1464
|
+
if (frameElement) {
|
|
1465
|
+
if (tabindexValue(frameElement) < 0) {
|
|
1466
|
+
// iframe[tabindex="-1"] and object[tabindex="-1"] inherit the
|
|
1467
|
+
// tabbable demotion onto elements of their browsing contexts
|
|
1468
|
+
return false;
|
|
1469
|
+
}
|
|
1470
|
+
}
|
|
1471
|
+
}
|
|
1472
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1473
|
+
var tabindex = tabindexValue(element);
|
|
1474
|
+
if (nodeName === 'label' && platform.is.GECKO) {
|
|
1475
|
+
// Firefox cannot focus, but tab to: label[tabindex=0]
|
|
1476
|
+
return tabindex !== null && tabindex >= 0;
|
|
1477
|
+
}
|
|
1478
|
+
// SVG Elements were keyboard focusable but not script focusable before Firefox 51.
|
|
1479
|
+
// Firefox 51 added the focus management DOM API (.focus and .blur) to SVGElement,
|
|
1480
|
+
// see https://bugzilla.mozilla.org/show_bug.cgi?id=778654
|
|
1481
|
+
if (platform.is.GECKO && element.ownerSVGElement && !element.focus) {
|
|
1482
|
+
if (nodeName === 'a' && element.hasAttribute('xlink:href')) {
|
|
1483
|
+
// any focusable child of <svg> cannot be focused, but tabbed to
|
|
1484
|
+
if (platform.is.GECKO) {
|
|
1485
|
+
return true;
|
|
1486
|
+
}
|
|
1487
|
+
}
|
|
1488
|
+
}
|
|
1489
|
+
return false;
|
|
1490
|
+
}
|
|
1491
|
+
// bind exceptions to an iterator callback
|
|
1492
|
+
isOnlyTabbableRules.except = function() {
|
|
1493
|
+
var except = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
1494
|
+
var isOnlyTabbable = function isOnlyTabbable(context) {
|
|
1495
|
+
return isOnlyTabbableRules({
|
|
1496
|
+
context: context,
|
|
1497
|
+
except: except
|
|
1498
|
+
});
|
|
1499
|
+
};
|
|
1500
|
+
isOnlyTabbable.rules = isOnlyTabbableRules;
|
|
1501
|
+
return isOnlyTabbable;
|
|
1502
|
+
};
|
|
1503
|
+
// provide isOnlyTabbable(context) as default iterator callback
|
|
1504
|
+
var isOnlyTabbable = isOnlyTabbableRules.except({});
|
|
1505
|
+
var supports$5 = void 0;
|
|
1506
|
+
function isOnlyFocusRelevant(element) {
|
|
1507
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1508
|
+
if (nodeName === 'embed' || nodeName === 'keygen') {
|
|
1509
|
+
// embed is considered focus-relevant but not focusable
|
|
1510
|
+
// see https://github.com/medialize/ally.js/issues/82
|
|
1511
|
+
return true;
|
|
1512
|
+
}
|
|
1513
|
+
var _tabindex = tabindexValue(element);
|
|
1514
|
+
if (element.shadowRoot && _tabindex === null) {
|
|
1515
|
+
// ShadowDOM host elements *may* receive focus
|
|
1516
|
+
// even though they are not considered focuable
|
|
1517
|
+
return true;
|
|
1518
|
+
}
|
|
1519
|
+
if (nodeName === 'label') {
|
|
1520
|
+
// <label tabindex="0"> is only tabbable in Firefox, not script-focusable
|
|
1521
|
+
// there's no way to make an element focusable other than by adding a tabindex,
|
|
1522
|
+
// and focus behavior of the label element seems hard-wired to ignore tabindex
|
|
1523
|
+
// in some browsers (like Gecko, Blink and WebKit)
|
|
1524
|
+
return !supports$5.focusLabelTabindex || _tabindex === null;
|
|
1525
|
+
}
|
|
1526
|
+
if (nodeName === 'legend') {
|
|
1527
|
+
return _tabindex === null;
|
|
1528
|
+
}
|
|
1529
|
+
if (supports$5.focusSvgFocusableAttribute && (element.ownerSVGElement || nodeName === 'svg')) {
|
|
1530
|
+
// Internet Explorer understands the focusable attribute introduced in SVG Tiny 1.2
|
|
1531
|
+
var focusableAttribute = element.getAttribute('focusable');
|
|
1532
|
+
return focusableAttribute && focusableAttribute === 'false';
|
|
1533
|
+
}
|
|
1534
|
+
if (nodeName === 'img' && element.hasAttribute('usemap')) {
|
|
1535
|
+
// Gecko, Trident and Edge do not allow an image with an image map and tabindex to be focused,
|
|
1536
|
+
// it appears the tabindex is overruled so focus is still forwarded to the <map>
|
|
1537
|
+
return _tabindex === null || !supports$5.focusImgUsemapTabindex;
|
|
1538
|
+
}
|
|
1539
|
+
if (nodeName === 'area') {
|
|
1540
|
+
// all <area>s are considered relevant,
|
|
1541
|
+
// but only the valid <area>s are focusable
|
|
1542
|
+
return !isValidArea(element);
|
|
1543
|
+
}
|
|
1544
|
+
return false;
|
|
1545
|
+
}
|
|
1546
|
+
function isFocusableRules() {
|
|
1547
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, _ref$except = _ref.except, except = _ref$except === undefined ? {
|
|
1548
|
+
disabled: false,
|
|
1549
|
+
visible: false,
|
|
1550
|
+
onlyTabbable: false
|
|
1551
|
+
} : _ref$except;
|
|
1552
|
+
if (!supports$5) {
|
|
1553
|
+
supports$5 = _supports();
|
|
1554
|
+
}
|
|
1555
|
+
var _isOnlyTabbable = isOnlyTabbable.rules.except({
|
|
1556
|
+
onlyFocusableBrowsingContext: true,
|
|
1557
|
+
visible: except.visible
|
|
1558
|
+
});
|
|
1559
|
+
var element = contextToElement({
|
|
1560
|
+
label: 'is/focusable',
|
|
1561
|
+
resolveDocument: true,
|
|
1562
|
+
context: context
|
|
1563
|
+
});
|
|
1564
|
+
var focusRelevant = isFocusRelevant.rules({
|
|
1565
|
+
context: element,
|
|
1566
|
+
except: except
|
|
1567
|
+
});
|
|
1568
|
+
if (!focusRelevant || isOnlyFocusRelevant(element)) {
|
|
1569
|
+
return false;
|
|
1570
|
+
}
|
|
1571
|
+
if (!except.disabled && isDisabled(element)) {
|
|
1572
|
+
return false;
|
|
1573
|
+
}
|
|
1574
|
+
if (!except.onlyTabbable && _isOnlyTabbable(element)) {
|
|
1575
|
+
// some elements may be keyboard focusable, but not script focusable
|
|
1576
|
+
return false;
|
|
1577
|
+
}
|
|
1578
|
+
// elements that are not rendered, cannot be focused
|
|
1579
|
+
if (!except.visible) {
|
|
1580
|
+
var visibilityOptions = {
|
|
1581
|
+
context: element,
|
|
1582
|
+
except: {}
|
|
1583
|
+
};
|
|
1584
|
+
if (supports$5.focusInHiddenIframe) {
|
|
1585
|
+
// WebKit and Blink can focus content in hidden <iframe> and <object>
|
|
1586
|
+
visibilityOptions.except.browsingContext = true;
|
|
1587
|
+
}
|
|
1588
|
+
if (supports$5.focusObjectSvgHidden) {
|
|
1589
|
+
// Blink allows focusing the object element, even if it has visibility: hidden;
|
|
1590
|
+
// @browser-issue Blink https://code.google.com/p/chromium/issues/detail?id=586191
|
|
1591
|
+
var _nodeName2 = element.nodeName.toLowerCase();
|
|
1592
|
+
if (_nodeName2 === 'object') {
|
|
1593
|
+
visibilityOptions.except.cssVisibility = true;
|
|
1594
|
+
}
|
|
1595
|
+
}
|
|
1596
|
+
if (!isVisible.rules(visibilityOptions)) {
|
|
1597
|
+
return false;
|
|
1598
|
+
}
|
|
1599
|
+
}
|
|
1600
|
+
var frameElement = getFrameElement(element);
|
|
1601
|
+
if (frameElement) {
|
|
1602
|
+
var _nodeName = frameElement.nodeName.toLowerCase();
|
|
1603
|
+
if (_nodeName === 'object' && !supports$5.focusInZeroDimensionObject) {
|
|
1604
|
+
if (!frameElement.offsetWidth || !frameElement.offsetHeight) {
|
|
1605
|
+
// WebKit can not focus content in <object> if it doesn't have dimensions
|
|
1606
|
+
return false;
|
|
1607
|
+
}
|
|
1608
|
+
}
|
|
1609
|
+
}
|
|
1610
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1611
|
+
if (nodeName === 'svg' && supports$5.focusSvgInIframe && !frameElement && element.getAttribute('tabindex') === null) {
|
|
1612
|
+
return false;
|
|
1613
|
+
}
|
|
1614
|
+
return true;
|
|
1615
|
+
}
|
|
1616
|
+
// bind exceptions to an iterator callback
|
|
1617
|
+
isFocusableRules.except = function() {
|
|
1618
|
+
var except = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
1619
|
+
var isFocusable = function isFocusable(context) {
|
|
1620
|
+
return isFocusableRules({
|
|
1621
|
+
context: context,
|
|
1622
|
+
except: except
|
|
1623
|
+
});
|
|
1624
|
+
};
|
|
1625
|
+
isFocusable.rules = isFocusableRules;
|
|
1626
|
+
return isFocusable;
|
|
1627
|
+
};
|
|
1628
|
+
// provide isFocusRelevant(context) as default iterator callback
|
|
1629
|
+
var isFocusable = isFocusableRules.except({});
|
|
1630
|
+
function createFilter(condition) {
|
|
1631
|
+
// see https://developer.mozilla.org/docs/Web/API/NodeFilter
|
|
1632
|
+
var filter = function filter(node) {
|
|
1633
|
+
if (node.shadowRoot) {
|
|
1634
|
+
// return ShadowRoot elements regardless of them being focusable,
|
|
1635
|
+
// so they can be walked recursively later
|
|
1636
|
+
return NodeFilter.FILTER_ACCEPT;
|
|
1637
|
+
}
|
|
1638
|
+
if (condition(node)) {
|
|
1639
|
+
// finds elements that could have been found by document.querySelectorAll()
|
|
1640
|
+
return NodeFilter.FILTER_ACCEPT;
|
|
1641
|
+
}
|
|
1642
|
+
return NodeFilter.FILTER_SKIP;
|
|
1643
|
+
};
|
|
1644
|
+
// IE requires a function, Browsers require {acceptNode: function}
|
|
1645
|
+
// see http://www.bennadel.com/blog/2607-finding-html-comment-nodes-in-the-dom-using-treewalker.htm
|
|
1646
|
+
filter.acceptNode = filter;
|
|
1647
|
+
return filter;
|
|
1648
|
+
}
|
|
1649
|
+
var PossiblyFocusableFilter = createFilter(isFocusRelevant);
|
|
1650
|
+
function queryFocusableStrict() {
|
|
1651
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, includeContext = _ref.includeContext, includeOnlyTabbable = _ref.includeOnlyTabbable, strategy = _ref.strategy;
|
|
1652
|
+
if (!context) {
|
|
1653
|
+
context = document.documentElement;
|
|
1654
|
+
}
|
|
1655
|
+
var _isFocusable = isFocusable.rules.except({
|
|
1656
|
+
onlyTabbable: includeOnlyTabbable
|
|
1657
|
+
});
|
|
1658
|
+
var _document = getDocument(context);
|
|
1659
|
+
// see https://developer.mozilla.org/docs/Web/API/Document/createTreeWalker
|
|
1660
|
+
var walker = _document.createTreeWalker(// root element to start search in
|
|
1661
|
+
context, // element type filter
|
|
1662
|
+
NodeFilter.SHOW_ELEMENT, // custom NodeFilter filter
|
|
1663
|
+
strategy === 'all' ? PossiblyFocusableFilter : createFilter(_isFocusable), // deprecated, but IE requires it
|
|
1664
|
+
false);
|
|
1665
|
+
var list = [];
|
|
1666
|
+
while(walker.nextNode()){
|
|
1667
|
+
if (walker.currentNode.shadowRoot) {
|
|
1668
|
+
if (_isFocusable(walker.currentNode)) {
|
|
1669
|
+
list.push(walker.currentNode);
|
|
1670
|
+
}
|
|
1671
|
+
list = list.concat(queryFocusableStrict({
|
|
1672
|
+
context: walker.currentNode.shadowRoot,
|
|
1673
|
+
includeOnlyTabbable: includeOnlyTabbable,
|
|
1674
|
+
strategy: strategy
|
|
1675
|
+
}));
|
|
1676
|
+
} else {
|
|
1677
|
+
list.push(walker.currentNode);
|
|
1678
|
+
}
|
|
1679
|
+
}
|
|
1680
|
+
// add context if requested and focusable
|
|
1681
|
+
if (includeContext) {
|
|
1682
|
+
if (strategy === 'all') {
|
|
1683
|
+
if (isFocusRelevant(context)) {
|
|
1684
|
+
list.unshift(context);
|
|
1685
|
+
}
|
|
1686
|
+
} else if (_isFocusable(context)) {
|
|
1687
|
+
list.unshift(context);
|
|
1688
|
+
}
|
|
1689
|
+
}
|
|
1690
|
+
return list;
|
|
1691
|
+
}
|
|
1692
|
+
// NOTE: this selector MUST *never* be used directly,
|
|
1693
|
+
var supports$6 = void 0;
|
|
1694
|
+
var selector$1 = void 0;
|
|
1695
|
+
function selector$2() {
|
|
1696
|
+
if (!supports$6) {
|
|
1697
|
+
supports$6 = _supports();
|
|
1698
|
+
}
|
|
1699
|
+
if (typeof selector$1 === 'string') {
|
|
1700
|
+
return selector$1;
|
|
1701
|
+
}
|
|
1702
|
+
// https://www.w3.org/TR/html5/editing.html#sequential-focus-navigation-and-the-tabindex-attribute
|
|
1703
|
+
selector$1 = '' + // IE11 supports.can focus <table> and <td>
|
|
1704
|
+
(supports$6.focusTable ? 'table, td,' : '') + // IE11 supports.can focus <fieldset>
|
|
1705
|
+
(supports$6.focusFieldset ? 'fieldset,' : '') + // Namespace problems of [xlink:href] explained in https://stackoverflow.com/a/23047888/515124
|
|
1706
|
+
// svg a[*|href] does not match in IE9, but since we're filtering
|
|
1707
|
+
// through is/focusable we can include all <a> from SVG
|
|
1708
|
+
'svg a,' + // may behave as 'svg, svg *,' in chrome as *every* svg element with a focus event listener is focusable
|
|
1709
|
+
// navigational elements
|
|
1710
|
+
'a[href],' + // validity determined by is/valid-area.js
|
|
1711
|
+
'area[href],' + // validity determined by is/disabled.js
|
|
1712
|
+
'input, select, textarea, button,' + // browsing context containers
|
|
1713
|
+
'iframe, object, embed,' + // interactive content
|
|
1714
|
+
'keygen,' + (supports$6.focusAudioWithoutControls ? 'audio,' : 'audio[controls],') + (supports$6.focusVideoWithoutControls ? 'video,' : 'video[controls],') + (supports$6.focusSummary ? 'summary,' : '') + // validity determined by is/valid-tabindex.js
|
|
1715
|
+
'[tabindex],' + // editing hosts
|
|
1716
|
+
'[contenteditable]';
|
|
1717
|
+
// where ShadowDOM is supported, we also want the shadowed focusable elements (via ">>>" or "/deep/")
|
|
1718
|
+
selector$1 = selectInShadows(selector$1);
|
|
1719
|
+
return selector$1;
|
|
1720
|
+
}
|
|
1721
|
+
function queryFocusableQuick() {
|
|
1722
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, includeContext = _ref.includeContext, includeOnlyTabbable = _ref.includeOnlyTabbable;
|
|
1723
|
+
var _selector = selector$2();
|
|
1724
|
+
var elements = context.querySelectorAll(_selector);
|
|
1725
|
+
// the selector potentially matches more than really is focusable
|
|
1726
|
+
var _isFocusable = isFocusable.rules.except({
|
|
1727
|
+
onlyTabbable: includeOnlyTabbable
|
|
1728
|
+
});
|
|
1729
|
+
var result = [].filter.call(elements, _isFocusable);
|
|
1730
|
+
// add context if requested and focusable
|
|
1731
|
+
if (includeContext && _isFocusable(context)) {
|
|
1732
|
+
result.unshift(context);
|
|
1733
|
+
}
|
|
1734
|
+
return result;
|
|
1735
|
+
}
|
|
1736
|
+
function queryFocusable() {
|
|
1737
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, includeContext = _ref.includeContext, includeOnlyTabbable = _ref.includeOnlyTabbable, _ref$strategy = _ref.strategy, strategy = _ref$strategy === undefined ? 'quick' : _ref$strategy;
|
|
1738
|
+
var element = contextToElement({
|
|
1739
|
+
label: 'query/focusable',
|
|
1740
|
+
resolveDocument: true,
|
|
1741
|
+
defaultToDocument: true,
|
|
1742
|
+
context: context
|
|
1743
|
+
});
|
|
1744
|
+
var options = {
|
|
1745
|
+
context: element,
|
|
1746
|
+
includeContext: includeContext,
|
|
1747
|
+
includeOnlyTabbable: includeOnlyTabbable,
|
|
1748
|
+
strategy: strategy
|
|
1749
|
+
};
|
|
1750
|
+
if (strategy === 'quick') {
|
|
1751
|
+
return queryFocusableQuick(options);
|
|
1752
|
+
} else if (strategy === 'strict' || strategy === 'all') {
|
|
1753
|
+
return queryFocusableStrict(options);
|
|
1754
|
+
}
|
|
1755
|
+
throw Object.defineProperty(new TypeError('query/focusable requires option.strategy to be one of ["quick", "strict", "all"]'), "__NEXT_ERROR_CODE", {
|
|
1756
|
+
value: "E594",
|
|
1757
|
+
enumerable: false
|
|
1758
|
+
});
|
|
1759
|
+
}
|
|
1760
|
+
var supports$7 = void 0;
|
|
1761
|
+
// Internet Explorer 11 considers fieldset, table, td focusable, but not tabbable
|
|
1762
|
+
// Internet Explorer 11 considers body to have [tabindex=0], but does not allow tabbing to it
|
|
1763
|
+
var focusableElementsPattern = /^(fieldset|table|td|body)$/;
|
|
1764
|
+
function isTabbableRules() {
|
|
1765
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, _ref$except = _ref.except, except = _ref$except === undefined ? {
|
|
1766
|
+
flexbox: false,
|
|
1767
|
+
scrollable: false,
|
|
1768
|
+
shadow: false,
|
|
1769
|
+
visible: false,
|
|
1770
|
+
onlyTabbable: false
|
|
1771
|
+
} : _ref$except;
|
|
1772
|
+
if (!supports$7) {
|
|
1773
|
+
supports$7 = _supports();
|
|
1774
|
+
}
|
|
1775
|
+
var element = contextToElement({
|
|
1776
|
+
label: 'is/tabbable',
|
|
1777
|
+
resolveDocument: true,
|
|
1778
|
+
context: context
|
|
1779
|
+
});
|
|
1780
|
+
if (platform.is.BLINK && platform.is.ANDROID && platform.majorVersion > 42) {
|
|
1781
|
+
// External keyboard support worked fine in CHrome 42, but stopped working in Chrome 45.
|
|
1782
|
+
// The on-screen keyboard does not provide a way to focus the next input element (like iOS does).
|
|
1783
|
+
// That leaves us with no option to advance focus by keyboard, ergo nothing is tabbable (keyboard focusable).
|
|
1784
|
+
return false;
|
|
1785
|
+
}
|
|
1786
|
+
var frameElement = getFrameElement(element);
|
|
1787
|
+
if (frameElement) {
|
|
1788
|
+
if (platform.is.WEBKIT && platform.is.IOS) {
|
|
1789
|
+
// iOS only does not consider anything from another browsing context keyboard focusable
|
|
1790
|
+
return false;
|
|
1791
|
+
}
|
|
1792
|
+
// iframe[tabindex="-1"] and object[tabindex="-1"] inherit the
|
|
1793
|
+
// tabbable demotion onto elements of their browsing contexts
|
|
1794
|
+
if (tabindexValue(frameElement) < 0) {
|
|
1795
|
+
return false;
|
|
1796
|
+
}
|
|
1797
|
+
if (!except.visible && (platform.is.BLINK || platform.is.WEBKIT) && !isVisible(frameElement)) {
|
|
1798
|
+
// Blink and WebKit consider elements in hidden browsing contexts focusable, but not tabbable
|
|
1799
|
+
return false;
|
|
1800
|
+
}
|
|
1801
|
+
// Webkit and Blink don't consider anything in <object> tabbable
|
|
1802
|
+
// Blink fixed that fixed in Chrome 54, Opera 41
|
|
1803
|
+
var frameNodeName = frameElement.nodeName.toLowerCase();
|
|
1804
|
+
if (frameNodeName === 'object') {
|
|
1805
|
+
var isFixedBlink = platform.name === 'Chrome' && platform.majorVersion >= 54 || platform.name === 'Opera' && platform.majorVersion >= 41;
|
|
1806
|
+
if (platform.is.WEBKIT || platform.is.BLINK && !isFixedBlink) {
|
|
1807
|
+
return false;
|
|
1808
|
+
}
|
|
1809
|
+
}
|
|
1810
|
+
}
|
|
1811
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
1812
|
+
var _tabindex = tabindexValue(element);
|
|
1813
|
+
var tabindex = _tabindex === null ? null : _tabindex >= 0;
|
|
1814
|
+
if (platform.is.EDGE && platform.majorVersion >= 14 && frameElement && element.ownerSVGElement && _tabindex < 0) {
|
|
1815
|
+
// Edge 14+ considers <a xlink:href="…" tabindex="-1"> keyboard focusable
|
|
1816
|
+
// if the element is in a nested browsing context
|
|
1817
|
+
return true;
|
|
1818
|
+
}
|
|
1819
|
+
var hasTabbableTabindexOrNone = tabindex !== false;
|
|
1820
|
+
var hasTabbableTabindex = _tabindex !== null && _tabindex >= 0;
|
|
1821
|
+
// NOTE: Firefox 31 considers [contenteditable] to have [tabindex=-1], but allows tabbing to it
|
|
1822
|
+
// fixed in Firefox 40 the latest - https://bugzilla.mozilla.org/show_bug.cgi?id=1185657
|
|
1823
|
+
if (element.hasAttribute('contenteditable')) {
|
|
1824
|
+
// tabbing can still be disabled by explicitly providing [tabindex="-1"]
|
|
1825
|
+
return hasTabbableTabindexOrNone;
|
|
1826
|
+
}
|
|
1827
|
+
if (focusableElementsPattern.test(nodeName) && tabindex !== true) {
|
|
1828
|
+
return false;
|
|
1829
|
+
}
|
|
1830
|
+
if (platform.is.WEBKIT && platform.is.IOS) {
|
|
1831
|
+
// iOS only considers a hand full of elements tabbable (keyboard focusable)
|
|
1832
|
+
// this holds true even with external keyboards
|
|
1833
|
+
var potentiallyTabbable = nodeName === 'input' && element.type === 'text' || element.type === 'password' || nodeName === 'select' || nodeName === 'textarea' || element.hasAttribute('contenteditable');
|
|
1834
|
+
if (!potentiallyTabbable) {
|
|
1835
|
+
var style = window.getComputedStyle(element, null);
|
|
1836
|
+
potentiallyTabbable = isUserModifyWritable(style);
|
|
1837
|
+
}
|
|
1838
|
+
if (!potentiallyTabbable) {
|
|
1839
|
+
return false;
|
|
1840
|
+
}
|
|
1841
|
+
}
|
|
1842
|
+
if (nodeName === 'use' && _tabindex !== null) {
|
|
1843
|
+
if (platform.is.BLINK || platform.is.WEBKIT && platform.majorVersion === 9) {
|
|
1844
|
+
// In Chrome and Safari 9 the <use> element is keyboard focusable even for tabindex="-1"
|
|
1845
|
+
return true;
|
|
1846
|
+
}
|
|
1847
|
+
}
|
|
1848
|
+
if (elementMatches(element, 'svg a') && element.hasAttribute('xlink:href')) {
|
|
1849
|
+
if (hasTabbableTabindexOrNone) {
|
|
1850
|
+
// in Trident and Gecko SVGElement does not handle the tabIndex property properly
|
|
1851
|
+
return true;
|
|
1852
|
+
}
|
|
1853
|
+
if (element.focus && !supports$7.focusSvgNegativeTabindexAttribute) {
|
|
1854
|
+
// Firefox 51 and 52 treat any natively tabbable SVG element with
|
|
1855
|
+
// tabindex="-1" as tabbable and everything else as inert
|
|
1856
|
+
// see https://bugzilla.mozilla.org/show_bug.cgi?id=1302340
|
|
1857
|
+
return true;
|
|
1858
|
+
}
|
|
1859
|
+
}
|
|
1860
|
+
if (nodeName === 'svg' && supports$7.focusSvgInIframe && hasTabbableTabindexOrNone) {
|
|
1861
|
+
return true;
|
|
1862
|
+
}
|
|
1863
|
+
if (platform.is.TRIDENT || platform.is.EDGE) {
|
|
1864
|
+
if (nodeName === 'svg') {
|
|
1865
|
+
if (supports$7.focusSvg) {
|
|
1866
|
+
// older Internet Explorers consider <svg> keyboard focusable
|
|
1867
|
+
// unless they have focsable="false", but then they wouldn't
|
|
1868
|
+
// be focusable and thus not even reach this filter
|
|
1869
|
+
return true;
|
|
1870
|
+
}
|
|
1871
|
+
// elements that have [focusable] are automatically keyboard focusable regardless of the attribute's value
|
|
1872
|
+
return element.hasAttribute('focusable') || hasTabbableTabindex;
|
|
1873
|
+
}
|
|
1874
|
+
if (element.ownerSVGElement) {
|
|
1875
|
+
if (supports$7.focusSvgTabindexAttribute && hasTabbableTabindex) {
|
|
1876
|
+
return true;
|
|
1877
|
+
}
|
|
1878
|
+
// elements that have [focusable] are automatically keyboard focusable regardless of the attribute's value
|
|
1879
|
+
return element.hasAttribute('focusable');
|
|
1880
|
+
}
|
|
1881
|
+
}
|
|
1882
|
+
if (element.tabIndex === undefined) {
|
|
1883
|
+
return Boolean(except.onlyTabbable);
|
|
1884
|
+
}
|
|
1885
|
+
if (nodeName === 'audio') {
|
|
1886
|
+
if (!element.hasAttribute('controls')) {
|
|
1887
|
+
// In Internet Explorer the <audio> element is focusable, but not tabbable, and tabIndex property is wrong
|
|
1888
|
+
return false;
|
|
1889
|
+
} else if (platform.is.BLINK) {
|
|
1890
|
+
// In Chrome <audio controls tabindex="-1"> remains keyboard focusable
|
|
1891
|
+
return true;
|
|
1892
|
+
}
|
|
1893
|
+
}
|
|
1894
|
+
if (nodeName === 'video') {
|
|
1895
|
+
if (!element.hasAttribute('controls')) {
|
|
1896
|
+
if (platform.is.TRIDENT || platform.is.EDGE) {
|
|
1897
|
+
// In Internet Explorer and Edge the <video> element is focusable, but not tabbable, and tabIndex property is wrong
|
|
1898
|
+
return false;
|
|
1899
|
+
}
|
|
1900
|
+
} else if (platform.is.BLINK || platform.is.GECKO) {
|
|
1901
|
+
// In Chrome and Firefox <video controls tabindex="-1"> remains keyboard focusable
|
|
1902
|
+
return true;
|
|
1903
|
+
}
|
|
1904
|
+
}
|
|
1905
|
+
if (nodeName === 'object') {
|
|
1906
|
+
if (platform.is.BLINK || platform.is.WEBKIT) {
|
|
1907
|
+
// In all Blink and WebKit based browsers <embed> and <object> are never keyboard focusable, even with tabindex="0" set
|
|
1908
|
+
return false;
|
|
1909
|
+
}
|
|
1910
|
+
}
|
|
1911
|
+
if (nodeName === 'iframe') {
|
|
1912
|
+
// In Internet Explorer all iframes are only focusable
|
|
1913
|
+
// In WebKit, Blink and Gecko iframes may be tabbable depending on content.
|
|
1914
|
+
// Since we can't reliably investigate iframe documents because of the
|
|
1915
|
+
// SameOriginPolicy, we're declaring everything only focusable.
|
|
1916
|
+
return false;
|
|
1917
|
+
}
|
|
1918
|
+
if (!except.scrollable && platform.is.GECKO) {
|
|
1919
|
+
// Firefox considers scrollable containers keyboard focusable,
|
|
1920
|
+
// even though their tabIndex property is -1
|
|
1921
|
+
var _style = window.getComputedStyle(element, null);
|
|
1922
|
+
if (hasCssOverflowScroll(_style)) {
|
|
1923
|
+
return hasTabbableTabindexOrNone;
|
|
1924
|
+
}
|
|
1925
|
+
}
|
|
1926
|
+
if (platform.is.TRIDENT || platform.is.EDGE) {
|
|
1927
|
+
// IE and Edge degrade <area> to script focusable, if the image
|
|
1928
|
+
// using the <map> has been given tabindex="-1"
|
|
1929
|
+
if (nodeName === 'area') {
|
|
1930
|
+
var img = getImageOfArea(element);
|
|
1931
|
+
if (img && tabindexValue(img) < 0) {
|
|
1932
|
+
return false;
|
|
1933
|
+
}
|
|
1934
|
+
}
|
|
1935
|
+
var _style2 = window.getComputedStyle(element, null);
|
|
1936
|
+
if (isUserModifyWritable(_style2)) {
|
|
1937
|
+
// prevent being swallowed by the overzealous isScrollableContainer() below
|
|
1938
|
+
return element.tabIndex >= 0;
|
|
1939
|
+
}
|
|
1940
|
+
if (!except.flexbox && hasCssDisplayFlex(_style2)) {
|
|
1941
|
+
if (_tabindex !== null) {
|
|
1942
|
+
return hasTabbableTabindex;
|
|
1943
|
+
}
|
|
1944
|
+
return isFocusRelevantWithoutFlexbox(element) && isTabbableWithoutFlexbox(element);
|
|
1945
|
+
}
|
|
1946
|
+
// IE considers scrollable containers script focusable only,
|
|
1947
|
+
// even though their tabIndex property is 0
|
|
1948
|
+
if (isScrollableContainer(element, nodeName)) {
|
|
1949
|
+
return false;
|
|
1950
|
+
}
|
|
1951
|
+
var parent = element.parentElement;
|
|
1952
|
+
if (parent) {
|
|
1953
|
+
var parentNodeName = parent.nodeName.toLowerCase();
|
|
1954
|
+
var parentStyle = window.getComputedStyle(parent, null);
|
|
1955
|
+
// IE considers scrollable bodies script focusable only,
|
|
1956
|
+
if (isScrollableContainer(parent, nodeName, parentNodeName, parentStyle)) {
|
|
1957
|
+
return false;
|
|
1958
|
+
}
|
|
1959
|
+
// Children of focusable elements with display:flex are focusable in IE10-11,
|
|
1960
|
+
// even though their tabIndex property suggests otherwise
|
|
1961
|
+
if (hasCssDisplayFlex(parentStyle)) {
|
|
1962
|
+
// value of tabindex takes precedence
|
|
1963
|
+
return hasTabbableTabindex;
|
|
1964
|
+
}
|
|
1965
|
+
}
|
|
1966
|
+
}
|
|
1967
|
+
// https://www.w3.org/WAI/PF/aria-practices/#focus_tabindex
|
|
1968
|
+
return element.tabIndex >= 0;
|
|
1969
|
+
}
|
|
1970
|
+
// bind exceptions to an iterator callback
|
|
1971
|
+
isTabbableRules.except = function() {
|
|
1972
|
+
var except = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
1973
|
+
var isTabbable = function isTabbable(context) {
|
|
1974
|
+
return isTabbableRules({
|
|
1975
|
+
context: context,
|
|
1976
|
+
except: except
|
|
1977
|
+
});
|
|
1978
|
+
};
|
|
1979
|
+
isTabbable.rules = isTabbableRules;
|
|
1980
|
+
return isTabbable;
|
|
1981
|
+
};
|
|
1982
|
+
var isFocusRelevantWithoutFlexbox = isFocusRelevant.rules.except({
|
|
1983
|
+
flexbox: true
|
|
1984
|
+
});
|
|
1985
|
+
var isTabbableWithoutFlexbox = isTabbableRules.except({
|
|
1986
|
+
flexbox: true
|
|
1987
|
+
});
|
|
1988
|
+
// provide isTabbable(context) as default iterator callback
|
|
1989
|
+
var isTabbable = isTabbableRules.except({});
|
|
1990
|
+
function queryTabbable() {
|
|
1991
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, includeContext = _ref.includeContext, includeOnlyTabbable = _ref.includeOnlyTabbable, strategy = _ref.strategy;
|
|
1992
|
+
var _isTabbable = isTabbable.rules.except({
|
|
1993
|
+
onlyTabbable: includeOnlyTabbable
|
|
1994
|
+
});
|
|
1995
|
+
return queryFocusable({
|
|
1996
|
+
context: context,
|
|
1997
|
+
includeContext: includeContext,
|
|
1998
|
+
includeOnlyTabbable: includeOnlyTabbable,
|
|
1999
|
+
strategy: strategy
|
|
2000
|
+
}).filter(_isTabbable);
|
|
2001
|
+
}
|
|
2002
|
+
// sorts a list of elements according to their order in the DOM
|
|
2003
|
+
function compareDomPosition(a, b) {
|
|
2004
|
+
return a.compareDocumentPosition(b) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1;
|
|
2005
|
+
}
|
|
2006
|
+
function sortDomOrder(elements) {
|
|
2007
|
+
return elements.sort(compareDomPosition);
|
|
2008
|
+
}
|
|
2009
|
+
function getFirstSuccessorOffset(list, target) {
|
|
2010
|
+
// find the first element that comes AFTER the target element
|
|
2011
|
+
return findIndex(list, function(element) {
|
|
2012
|
+
return target.compareDocumentPosition(element) & Node.DOCUMENT_POSITION_FOLLOWING;
|
|
2013
|
+
});
|
|
2014
|
+
}
|
|
2015
|
+
function findInsertionOffsets(list, elements, resolveElement) {
|
|
2016
|
+
// instead of mutating the elements list directly, remember position and map
|
|
2017
|
+
// to inject later, when we can do this more efficiently
|
|
2018
|
+
var insertions = [];
|
|
2019
|
+
elements.forEach(function(element) {
|
|
2020
|
+
var replace = true;
|
|
2021
|
+
var offset = list.indexOf(element);
|
|
2022
|
+
if (offset === -1) {
|
|
2023
|
+
// element is not in target list
|
|
2024
|
+
offset = getFirstSuccessorOffset(list, element);
|
|
2025
|
+
replace = false;
|
|
2026
|
+
}
|
|
2027
|
+
if (offset === -1) {
|
|
2028
|
+
// there is no successor in the tabsequence,
|
|
2029
|
+
// meaning the image must be the last element
|
|
2030
|
+
offset = list.length;
|
|
2031
|
+
}
|
|
2032
|
+
// allow the consumer to replace the injected element
|
|
2033
|
+
var injections = nodeArray(resolveElement ? resolveElement(element) : element);
|
|
2034
|
+
if (!injections.length) {
|
|
2035
|
+
// we can't inject zero elements
|
|
2036
|
+
return;
|
|
2037
|
+
}
|
|
2038
|
+
insertions.push({
|
|
2039
|
+
offset: offset,
|
|
2040
|
+
replace: replace,
|
|
2041
|
+
elements: injections
|
|
2042
|
+
});
|
|
2043
|
+
});
|
|
2044
|
+
return insertions;
|
|
2045
|
+
}
|
|
2046
|
+
function insertElementsAtOffsets(list, insertions) {
|
|
2047
|
+
// remember the number of elements we have already injected
|
|
2048
|
+
// so we account for the caused index offset
|
|
2049
|
+
var inserted = 0;
|
|
2050
|
+
// make sure that we insert the elements in sequence,
|
|
2051
|
+
// otherwise the offset compensation won't work
|
|
2052
|
+
insertions.sort(function(a, b) {
|
|
2053
|
+
return a.offset - b.offset;
|
|
2054
|
+
});
|
|
2055
|
+
insertions.forEach(function(insertion) {
|
|
2056
|
+
// array.splice has an annoying function signature :(
|
|
2057
|
+
var remove = insertion.replace ? 1 : 0;
|
|
2058
|
+
var args = [
|
|
2059
|
+
insertion.offset + inserted,
|
|
2060
|
+
remove
|
|
2061
|
+
].concat(insertion.elements);
|
|
2062
|
+
list.splice.apply(list, args);
|
|
2063
|
+
inserted += insertion.elements.length - remove;
|
|
2064
|
+
});
|
|
2065
|
+
}
|
|
2066
|
+
function mergeInDomOrder() {
|
|
2067
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, list = _ref.list, elements = _ref.elements, resolveElement = _ref.resolveElement;
|
|
2068
|
+
// operate on a copy so we don't mutate the original array
|
|
2069
|
+
var _list = list.slice(0);
|
|
2070
|
+
// make sure the elements we're injecting are provided in DOM order
|
|
2071
|
+
var _elements = nodeArray(elements).slice(0);
|
|
2072
|
+
sortDomOrder(_elements);
|
|
2073
|
+
// find the offsets within the target array (list) at which to inject
|
|
2074
|
+
// each individual element (from elements)
|
|
2075
|
+
var insertions = findInsertionOffsets(_list, _elements, resolveElement);
|
|
2076
|
+
// actually inject the elements into the target array at the identified positions
|
|
2077
|
+
insertElementsAtOffsets(_list, insertions);
|
|
2078
|
+
return _list;
|
|
2079
|
+
}
|
|
2080
|
+
var _createClass = function() {
|
|
2081
|
+
function defineProperties(target, props) {
|
|
2082
|
+
for(var i = 0; i < props.length; i++){
|
|
2083
|
+
var descriptor = props[i];
|
|
2084
|
+
descriptor.enumerable = descriptor.enumerable || false;
|
|
2085
|
+
descriptor.configurable = true;
|
|
2086
|
+
if ('value' in descriptor) descriptor.writable = true;
|
|
2087
|
+
Object.defineProperty(target, descriptor.key, descriptor);
|
|
2088
|
+
}
|
|
2089
|
+
}
|
|
2090
|
+
return function(Constructor, protoProps, staticProps) {
|
|
2091
|
+
if (protoProps) defineProperties(Constructor.prototype, protoProps);
|
|
2092
|
+
if (staticProps) defineProperties(Constructor, staticProps);
|
|
2093
|
+
return Constructor;
|
|
2094
|
+
};
|
|
2095
|
+
}();
|
|
2096
|
+
function _classCallCheck(instance, Constructor) {
|
|
2097
|
+
if (!(instance instanceof Constructor)) {
|
|
2098
|
+
throw Object.defineProperty(new TypeError('Cannot call a class as a function'), "__NEXT_ERROR_CODE", {
|
|
2099
|
+
value: "E601",
|
|
2100
|
+
enumerable: false
|
|
2101
|
+
});
|
|
2102
|
+
}
|
|
2103
|
+
}
|
|
2104
|
+
var Maps = function() {
|
|
2105
|
+
function Maps(context) {
|
|
2106
|
+
_classCallCheck(this, Maps);
|
|
2107
|
+
this._document = getDocument(context);
|
|
2108
|
+
this.maps = {};
|
|
2109
|
+
}
|
|
2110
|
+
_createClass(Maps, [
|
|
2111
|
+
{
|
|
2112
|
+
key: 'getAreasFor',
|
|
2113
|
+
value: function getAreasFor(name) {
|
|
2114
|
+
if (!this.maps[name]) {
|
|
2115
|
+
// the map is not defined within the context, so we
|
|
2116
|
+
// have to go find it elsewhere in the document
|
|
2117
|
+
this.addMapByName(name);
|
|
2118
|
+
}
|
|
2119
|
+
return this.maps[name];
|
|
2120
|
+
}
|
|
2121
|
+
},
|
|
2122
|
+
{
|
|
2123
|
+
key: 'addMapByName',
|
|
2124
|
+
value: function addMapByName(name) {
|
|
2125
|
+
var map = getMapByName(name, this._document);
|
|
2126
|
+
if (!map) {
|
|
2127
|
+
// if there is no map, the img[usemap] wasn't doing anything anyway
|
|
2128
|
+
return;
|
|
2129
|
+
}
|
|
2130
|
+
this.maps[map.name] = queryTabbable({
|
|
2131
|
+
context: map
|
|
2132
|
+
});
|
|
2133
|
+
}
|
|
2134
|
+
},
|
|
2135
|
+
{
|
|
2136
|
+
key: 'extractAreasFromList',
|
|
2137
|
+
value: function extractAreasFromList(elements) {
|
|
2138
|
+
// remove all <area> elements from the elements list,
|
|
2139
|
+
// but put them the map for later retrieval
|
|
2140
|
+
return elements.filter(function(element) {
|
|
2141
|
+
var nodeName = element.nodeName.toLowerCase();
|
|
2142
|
+
if (nodeName !== 'area') {
|
|
2143
|
+
return true;
|
|
2144
|
+
}
|
|
2145
|
+
var map = element.parentNode;
|
|
2146
|
+
if (!this.maps[map.name]) {
|
|
2147
|
+
this.maps[map.name] = [];
|
|
2148
|
+
}
|
|
2149
|
+
this.maps[map.name].push(element);
|
|
2150
|
+
return false;
|
|
2151
|
+
}, this);
|
|
2152
|
+
}
|
|
2153
|
+
}
|
|
2154
|
+
]);
|
|
2155
|
+
return Maps;
|
|
2156
|
+
}();
|
|
2157
|
+
function sortArea(elements, context) {
|
|
2158
|
+
// images - unless they are focusable themselves, likely not
|
|
2159
|
+
// part of the elements list, so we'll have to find them and
|
|
2160
|
+
// sort them into the elements list manually
|
|
2161
|
+
var usemaps = context.querySelectorAll('img[usemap]');
|
|
2162
|
+
var maps = new Maps(context);
|
|
2163
|
+
// remove all <area> elements from the elements list,
|
|
2164
|
+
// but put them the map for later retrieval
|
|
2165
|
+
var _elements = maps.extractAreasFromList(elements);
|
|
2166
|
+
if (!usemaps.length) {
|
|
2167
|
+
// the context does not contain any <area>s so no need
|
|
2168
|
+
// to replace anything, just remove any maps
|
|
2169
|
+
return _elements;
|
|
2170
|
+
}
|
|
2171
|
+
return mergeInDomOrder({
|
|
2172
|
+
list: _elements,
|
|
2173
|
+
elements: usemaps,
|
|
2174
|
+
resolveElement: function resolveElement(image) {
|
|
2175
|
+
var name = image.getAttribute('usemap').slice(1);
|
|
2176
|
+
return maps.getAreasFor(name);
|
|
2177
|
+
}
|
|
2178
|
+
});
|
|
2179
|
+
}
|
|
2180
|
+
var _createClass$1 = function() {
|
|
2181
|
+
function defineProperties(target, props) {
|
|
2182
|
+
for(var i = 0; i < props.length; i++){
|
|
2183
|
+
var descriptor = props[i];
|
|
2184
|
+
descriptor.enumerable = descriptor.enumerable || false;
|
|
2185
|
+
descriptor.configurable = true;
|
|
2186
|
+
if ('value' in descriptor) descriptor.writable = true;
|
|
2187
|
+
Object.defineProperty(target, descriptor.key, descriptor);
|
|
2188
|
+
}
|
|
2189
|
+
}
|
|
2190
|
+
return function(Constructor, protoProps, staticProps) {
|
|
2191
|
+
if (protoProps) defineProperties(Constructor.prototype, protoProps);
|
|
2192
|
+
if (staticProps) defineProperties(Constructor, staticProps);
|
|
2193
|
+
return Constructor;
|
|
2194
|
+
};
|
|
2195
|
+
}();
|
|
2196
|
+
function _classCallCheck$1(instance, Constructor) {
|
|
2197
|
+
if (!(instance instanceof Constructor)) {
|
|
2198
|
+
throw Object.defineProperty(new TypeError('Cannot call a class as a function'), "__NEXT_ERROR_CODE", {
|
|
2199
|
+
value: "E601",
|
|
2200
|
+
enumerable: false
|
|
2201
|
+
});
|
|
2202
|
+
}
|
|
2203
|
+
}
|
|
2204
|
+
var Shadows = function() {
|
|
2205
|
+
function Shadows(context, sortElements) {
|
|
2206
|
+
_classCallCheck$1(this, Shadows);
|
|
2207
|
+
// document context we're working with
|
|
2208
|
+
this.context = context;
|
|
2209
|
+
// callback that sorts an array of elements
|
|
2210
|
+
this.sortElements = sortElements;
|
|
2211
|
+
// reference to create unique IDs for each ShadowHost
|
|
2212
|
+
this.hostCounter = 1;
|
|
2213
|
+
// reference map for child-ShadowHosts of a ShadowHost
|
|
2214
|
+
this.inHost = {};
|
|
2215
|
+
// reference map for child-ShadowHost of the document
|
|
2216
|
+
this.inDocument = [];
|
|
2217
|
+
// reference map for ShadowHosts
|
|
2218
|
+
this.hosts = {};
|
|
2219
|
+
// reference map for tabbable elements of a ShadowHost
|
|
2220
|
+
this.elements = {};
|
|
2221
|
+
}
|
|
2222
|
+
// remember which hosts we have to sort within later
|
|
2223
|
+
_createClass$1(Shadows, [
|
|
2224
|
+
{
|
|
2225
|
+
key: '_registerHost',
|
|
2226
|
+
value: function _registerHost(host) {
|
|
2227
|
+
if (host._sortingId) {
|
|
2228
|
+
return;
|
|
2229
|
+
}
|
|
2230
|
+
// make the ShadowHost identifiable (see cleanup() for undo)
|
|
2231
|
+
host._sortingId = 'shadow-' + this.hostCounter++;
|
|
2232
|
+
this.hosts[host._sortingId] = host;
|
|
2233
|
+
// hosts may contain other hosts
|
|
2234
|
+
var parentHost = getShadowHost({
|
|
2235
|
+
context: host
|
|
2236
|
+
});
|
|
2237
|
+
if (parentHost) {
|
|
2238
|
+
this._registerHost(parentHost);
|
|
2239
|
+
this._registerHostParent(host, parentHost);
|
|
2240
|
+
} else {
|
|
2241
|
+
this.inDocument.push(host);
|
|
2242
|
+
}
|
|
2243
|
+
}
|
|
2244
|
+
},
|
|
2245
|
+
{
|
|
2246
|
+
key: '_registerHostParent',
|
|
2247
|
+
value: function _registerHostParent(host, parent) {
|
|
2248
|
+
if (!this.inHost[parent._sortingId]) {
|
|
2249
|
+
this.inHost[parent._sortingId] = [];
|
|
2250
|
+
}
|
|
2251
|
+
this.inHost[parent._sortingId].push(host);
|
|
2252
|
+
}
|
|
2253
|
+
},
|
|
2254
|
+
{
|
|
2255
|
+
key: '_registerElement',
|
|
2256
|
+
value: function _registerElement(element, host) {
|
|
2257
|
+
if (!this.elements[host._sortingId]) {
|
|
2258
|
+
this.elements[host._sortingId] = [];
|
|
2259
|
+
}
|
|
2260
|
+
this.elements[host._sortingId].push(element);
|
|
2261
|
+
}
|
|
2262
|
+
},
|
|
2263
|
+
{
|
|
2264
|
+
key: 'extractElements',
|
|
2265
|
+
value: function extractElements(elements) {
|
|
2266
|
+
return elements.filter(function(element) {
|
|
2267
|
+
var host = getShadowHost({
|
|
2268
|
+
context: element
|
|
2269
|
+
});
|
|
2270
|
+
if (!host) {
|
|
2271
|
+
return true;
|
|
2272
|
+
}
|
|
2273
|
+
this._registerHost(host);
|
|
2274
|
+
this._registerElement(element, host);
|
|
2275
|
+
return false;
|
|
2276
|
+
}, this);
|
|
2277
|
+
}
|
|
2278
|
+
},
|
|
2279
|
+
{
|
|
2280
|
+
key: 'sort',
|
|
2281
|
+
value: function sort(elements) {
|
|
2282
|
+
var _elements = this._injectHosts(elements);
|
|
2283
|
+
_elements = this._replaceHosts(_elements);
|
|
2284
|
+
this._cleanup();
|
|
2285
|
+
return _elements;
|
|
2286
|
+
}
|
|
2287
|
+
},
|
|
2288
|
+
{
|
|
2289
|
+
key: '_injectHosts',
|
|
2290
|
+
value: function _injectHosts(elements) {
|
|
2291
|
+
Object.keys(this.hosts).forEach(function(_sortingId) {
|
|
2292
|
+
var _list = this.elements[_sortingId];
|
|
2293
|
+
var _elements = this.inHost[_sortingId];
|
|
2294
|
+
var _context = this.hosts[_sortingId].shadowRoot;
|
|
2295
|
+
this.elements[_sortingId] = this._merge(_list, _elements, _context);
|
|
2296
|
+
}, this);
|
|
2297
|
+
return this._merge(elements, this.inDocument, this.context);
|
|
2298
|
+
}
|
|
2299
|
+
},
|
|
2300
|
+
{
|
|
2301
|
+
key: '_merge',
|
|
2302
|
+
value: function _merge(list, elements, context) {
|
|
2303
|
+
var merged = mergeInDomOrder({
|
|
2304
|
+
list: list,
|
|
2305
|
+
elements: elements
|
|
2306
|
+
});
|
|
2307
|
+
return this.sortElements(merged, context);
|
|
2308
|
+
}
|
|
2309
|
+
},
|
|
2310
|
+
{
|
|
2311
|
+
key: '_replaceHosts',
|
|
2312
|
+
value: function _replaceHosts(elements) {
|
|
2313
|
+
return mergeInDomOrder({
|
|
2314
|
+
list: elements,
|
|
2315
|
+
elements: this.inDocument,
|
|
2316
|
+
resolveElement: this._resolveHostElement.bind(this)
|
|
2317
|
+
});
|
|
2318
|
+
}
|
|
2319
|
+
},
|
|
2320
|
+
{
|
|
2321
|
+
key: '_resolveHostElement',
|
|
2322
|
+
value: function _resolveHostElement(host) {
|
|
2323
|
+
var merged = mergeInDomOrder({
|
|
2324
|
+
list: this.elements[host._sortingId],
|
|
2325
|
+
elements: this.inHost[host._sortingId],
|
|
2326
|
+
resolveElement: this._resolveHostElement.bind(this)
|
|
2327
|
+
});
|
|
2328
|
+
var _tabindex = tabindexValue(host);
|
|
2329
|
+
if (_tabindex !== null && _tabindex > -1) {
|
|
2330
|
+
return [
|
|
2331
|
+
host
|
|
2332
|
+
].concat(merged);
|
|
2333
|
+
}
|
|
2334
|
+
return merged;
|
|
2335
|
+
}
|
|
2336
|
+
},
|
|
2337
|
+
{
|
|
2338
|
+
key: '_cleanup',
|
|
2339
|
+
value: function _cleanup() {
|
|
2340
|
+
// remove those identifers we put on the ShadowHost to avoid using Map()
|
|
2341
|
+
Object.keys(this.hosts).forEach(function(key) {
|
|
2342
|
+
delete this.hosts[key]._sortingId;
|
|
2343
|
+
}, this);
|
|
2344
|
+
}
|
|
2345
|
+
}
|
|
2346
|
+
]);
|
|
2347
|
+
return Shadows;
|
|
2348
|
+
}();
|
|
2349
|
+
function sortShadowed(elements, context, sortElements) {
|
|
2350
|
+
var shadows = new Shadows(context, sortElements);
|
|
2351
|
+
var _elements = shadows.extractElements(elements);
|
|
2352
|
+
if (_elements.length === elements.length) {
|
|
2353
|
+
// no shadowed content found, no need to continue
|
|
2354
|
+
return sortElements(elements);
|
|
2355
|
+
}
|
|
2356
|
+
return shadows.sort(_elements);
|
|
2357
|
+
}
|
|
2358
|
+
function sortTabindex(elements) {
|
|
2359
|
+
// https://developer.mozilla.org/docs/Web/API/HTMLElement.tabIndex
|
|
2360
|
+
// elements with tabIndex "0" (including tabbableElements without tabIndex) should be navigated in the order they appear.
|
|
2361
|
+
// elements with a positive tabIndex:
|
|
2362
|
+
// Elements that have identical tabIndexes should be navigated in the order they appear.
|
|
2363
|
+
// Navigation proceeds from the lowest tabIndex to the highest tabIndex.
|
|
2364
|
+
// NOTE: sort implementation may be unstable and thus mess up DOM order,
|
|
2365
|
+
// that's why we build a map that's being sorted instead. If we were able to rely
|
|
2366
|
+
// on a stable sorting algorithm, sortTabindex() could be as simple as
|
|
2367
|
+
// elements.sort(function(a, b) { return a.tabIndex - b.tabIndex; });
|
|
2368
|
+
// at this time Chrome does not use a stable sorting algorithm
|
|
2369
|
+
// see http://blog.rodneyrehm.de/archives/14-Sorting-Were-Doing-It-Wrong.html#stability
|
|
2370
|
+
// NOTE: compareDocumentPosition seemed like more overhead than just sorting this with buckets
|
|
2371
|
+
// https://developer.mozilla.org/docs/Web/API/Node.compareDocumentPosition
|
|
2372
|
+
var map = {};
|
|
2373
|
+
var indexes = [];
|
|
2374
|
+
var normal = elements.filter(function(element) {
|
|
2375
|
+
// in Trident and Gecko SVGElement does not know about the tabIndex property
|
|
2376
|
+
var tabIndex = element.tabIndex;
|
|
2377
|
+
if (tabIndex === undefined) {
|
|
2378
|
+
tabIndex = tabindexValue(element);
|
|
2379
|
+
}
|
|
2380
|
+
// extract elements that don't need sorting
|
|
2381
|
+
if (tabIndex <= 0 || tabIndex === null || tabIndex === undefined) {
|
|
2382
|
+
return true;
|
|
2383
|
+
}
|
|
2384
|
+
if (!map[tabIndex]) {
|
|
2385
|
+
// create sortable bucket for dom-order-preservation of elements with the same tabIndex
|
|
2386
|
+
map[tabIndex] = [];
|
|
2387
|
+
// maintain a list of unique tabIndexes
|
|
2388
|
+
indexes.push(tabIndex);
|
|
2389
|
+
}
|
|
2390
|
+
// sort element into the proper bucket
|
|
2391
|
+
map[tabIndex].push(element);
|
|
2392
|
+
// element moved to sorting map, so not "normal" anymore
|
|
2393
|
+
return false;
|
|
2394
|
+
});
|
|
2395
|
+
// sort the tabindex ascending,
|
|
2396
|
+
// then resolve them to their appropriate buckets,
|
|
2397
|
+
// then flatten the array of arrays to an array
|
|
2398
|
+
var _elements = indexes.sort().map(function(tabIndex) {
|
|
2399
|
+
return map[tabIndex];
|
|
2400
|
+
}).reduceRight(function(previous, current) {
|
|
2401
|
+
return current.concat(previous);
|
|
2402
|
+
}, normal);
|
|
2403
|
+
return _elements;
|
|
2404
|
+
}
|
|
2405
|
+
var supports$8 = void 0;
|
|
2406
|
+
function moveContextToBeginning(elements, context) {
|
|
2407
|
+
var pos = elements.indexOf(context);
|
|
2408
|
+
if (pos > 0) {
|
|
2409
|
+
var tmp = elements.splice(pos, 1);
|
|
2410
|
+
return tmp.concat(elements);
|
|
2411
|
+
}
|
|
2412
|
+
return elements;
|
|
2413
|
+
}
|
|
2414
|
+
function sortElements(elements, _context) {
|
|
2415
|
+
if (supports$8.tabsequenceAreaAtImgPosition) {
|
|
2416
|
+
// Some browsers sort <area> in DOM order, some place the <area>s
|
|
2417
|
+
// where the <img> referecing them would've been in DOM order.
|
|
2418
|
+
// https://github.com/medialize/ally.js/issues/5
|
|
2419
|
+
elements = sortArea(elements, _context);
|
|
2420
|
+
}
|
|
2421
|
+
elements = sortTabindex(elements);
|
|
2422
|
+
return elements;
|
|
2423
|
+
}
|
|
2424
|
+
function queryTabsequence() {
|
|
2425
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, context = _ref.context, includeContext = _ref.includeContext, includeOnlyTabbable = _ref.includeOnlyTabbable, strategy = _ref.strategy;
|
|
2426
|
+
if (!supports$8) {
|
|
2427
|
+
supports$8 = _supports();
|
|
2428
|
+
}
|
|
2429
|
+
var _context = nodeArray(context)[0] || document.documentElement;
|
|
2430
|
+
var elements = queryTabbable({
|
|
2431
|
+
context: _context,
|
|
2432
|
+
includeContext: includeContext,
|
|
2433
|
+
includeOnlyTabbable: includeOnlyTabbable,
|
|
2434
|
+
strategy: strategy
|
|
2435
|
+
});
|
|
2436
|
+
if (document.body.createShadowRoot && platform.is.BLINK) {
|
|
2437
|
+
// sort tabindex localized to shadow dom
|
|
2438
|
+
// see https://github.com/medialize/ally.js/issues/6
|
|
2439
|
+
elements = sortShadowed(elements, _context, sortElements);
|
|
2440
|
+
} else {
|
|
2441
|
+
elements = sortElements(elements, _context);
|
|
2442
|
+
}
|
|
2443
|
+
if (includeContext) {
|
|
2444
|
+
// if we include the context itself, it has to be the first
|
|
2445
|
+
// element of the sequence
|
|
2446
|
+
elements = moveContextToBeginning(elements, _context);
|
|
2447
|
+
}
|
|
2448
|
+
return elements;
|
|
2449
|
+
}
|
|
2450
|
+
// codes mostly cloned from https://github.com/keithamus/jwerty/blob/master/jwerty.js
|
|
2451
|
+
// deliberately not exposing characters like <,.-#* because they vary *wildly*
|
|
2452
|
+
// across keyboard layouts and may cause various problems
|
|
2453
|
+
// (e.g. "*" is "Shift +" on a German Mac keyboard)
|
|
2454
|
+
// (e.g. "@" is "Alt L" on a German Mac keyboard)
|
|
2455
|
+
var keycode = {
|
|
2456
|
+
// Element Focus
|
|
2457
|
+
tab: 9,
|
|
2458
|
+
// Navigation
|
|
2459
|
+
left: 37,
|
|
2460
|
+
up: 38,
|
|
2461
|
+
right: 39,
|
|
2462
|
+
down: 40,
|
|
2463
|
+
pageUp: 33,
|
|
2464
|
+
'page-up': 33,
|
|
2465
|
+
pageDown: 34,
|
|
2466
|
+
'page-down': 34,
|
|
2467
|
+
end: 35,
|
|
2468
|
+
home: 36,
|
|
2469
|
+
// Action
|
|
2470
|
+
enter: 13,
|
|
2471
|
+
escape: 27,
|
|
2472
|
+
space: 32,
|
|
2473
|
+
// Modifier
|
|
2474
|
+
shift: 16,
|
|
2475
|
+
capsLock: 20,
|
|
2476
|
+
'caps-lock': 20,
|
|
2477
|
+
ctrl: 17,
|
|
2478
|
+
alt: 18,
|
|
2479
|
+
meta: 91,
|
|
2480
|
+
// in firefox: 224
|
|
2481
|
+
// on mac (chrome): meta-left=91, meta-right=93
|
|
2482
|
+
// on win (IE11): meta-left=91, meta-right=92
|
|
2483
|
+
pause: 19,
|
|
2484
|
+
// Content Manipulation
|
|
2485
|
+
insert: 45,
|
|
2486
|
+
delete: 46,
|
|
2487
|
+
backspace: 8,
|
|
2488
|
+
// the same logical key may be identified through different keyCodes
|
|
2489
|
+
_alias: {
|
|
2490
|
+
91: [
|
|
2491
|
+
92,
|
|
2492
|
+
93,
|
|
2493
|
+
224
|
|
2494
|
+
]
|
|
2495
|
+
}
|
|
2496
|
+
};
|
|
2497
|
+
// Function keys (112 - 137)
|
|
2498
|
+
// NOTE: not every keyboard knows F13+
|
|
2499
|
+
for(var n = 1; n < 26; n++){
|
|
2500
|
+
keycode['f' + n] = n + 111;
|
|
2501
|
+
}
|
|
2502
|
+
// Number keys (48-57, numpad 96-105)
|
|
2503
|
+
// NOTE: not every keyboard knows num-0+
|
|
2504
|
+
for(var _n = 0; _n < 10; _n++){
|
|
2505
|
+
var code = _n + 48;
|
|
2506
|
+
var numCode = _n + 96;
|
|
2507
|
+
keycode[_n] = code;
|
|
2508
|
+
keycode['num-' + _n] = numCode;
|
|
2509
|
+
keycode._alias[code] = [
|
|
2510
|
+
numCode
|
|
2511
|
+
];
|
|
2512
|
+
}
|
|
2513
|
+
// Latin characters (65 - 90)
|
|
2514
|
+
for(var _n2 = 0; _n2 < 26; _n2++){
|
|
2515
|
+
var _code = _n2 + 65;
|
|
2516
|
+
var name$1 = String.fromCharCode(_code).toLowerCase();
|
|
2517
|
+
keycode[name$1] = _code;
|
|
2518
|
+
}
|
|
2519
|
+
var modifier = {
|
|
2520
|
+
alt: 'altKey',
|
|
2521
|
+
ctrl: 'ctrlKey',
|
|
2522
|
+
meta: 'metaKey',
|
|
2523
|
+
shift: 'shiftKey'
|
|
2524
|
+
};
|
|
2525
|
+
var modifierSequence = Object.keys(modifier).map(function(name) {
|
|
2526
|
+
return modifier[name];
|
|
2527
|
+
});
|
|
2528
|
+
function createExpectedModifiers(ignoreModifiers) {
|
|
2529
|
+
var value = ignoreModifiers ? null : false;
|
|
2530
|
+
return {
|
|
2531
|
+
altKey: value,
|
|
2532
|
+
ctrlKey: value,
|
|
2533
|
+
metaKey: value,
|
|
2534
|
+
shiftKey: value
|
|
2535
|
+
};
|
|
2536
|
+
}
|
|
2537
|
+
function resolveModifiers(modifiers) {
|
|
2538
|
+
var ignoreModifiers = modifiers.indexOf('*') !== -1;
|
|
2539
|
+
var expected = createExpectedModifiers(ignoreModifiers);
|
|
2540
|
+
modifiers.forEach(function(token) {
|
|
2541
|
+
if (token === '*') {
|
|
2542
|
+
// we've already covered the all-in operator
|
|
2543
|
+
return;
|
|
2544
|
+
}
|
|
2545
|
+
// we want the modifier pressed
|
|
2546
|
+
var value = true;
|
|
2547
|
+
var operator = token.slice(0, 1);
|
|
2548
|
+
if (operator === '?') {
|
|
2549
|
+
// we don't care if the modifier is pressed
|
|
2550
|
+
value = null;
|
|
2551
|
+
} else if (operator === '!') {
|
|
2552
|
+
// we do not want the modifier pressed
|
|
2553
|
+
value = false;
|
|
2554
|
+
}
|
|
2555
|
+
if (value !== true) {
|
|
2556
|
+
// compensate for the modifier's operator
|
|
2557
|
+
token = token.slice(1);
|
|
2558
|
+
}
|
|
2559
|
+
var propertyName = modifier[token];
|
|
2560
|
+
if (!propertyName) {
|
|
2561
|
+
throw Object.defineProperty(new TypeError('Unknown modifier "' + token + '"'), "__NEXT_ERROR_CODE", {
|
|
2562
|
+
value: "E530",
|
|
2563
|
+
enumerable: false
|
|
2564
|
+
});
|
|
2565
|
+
}
|
|
2566
|
+
expected[propertyName] = value;
|
|
2567
|
+
});
|
|
2568
|
+
return expected;
|
|
2569
|
+
}
|
|
2570
|
+
function resolveKey(key) {
|
|
2571
|
+
var code = keycode[key] || parseInt(key, 10);
|
|
2572
|
+
if (!code || typeof code !== 'number' || isNaN(code)) {
|
|
2573
|
+
throw Object.defineProperty(new TypeError('Unknown key "' + key + '"'), "__NEXT_ERROR_CODE", {
|
|
2574
|
+
value: "E536",
|
|
2575
|
+
enumerable: false
|
|
2576
|
+
});
|
|
2577
|
+
}
|
|
2578
|
+
return [
|
|
2579
|
+
code
|
|
2580
|
+
].concat(keycode._alias[code] || []);
|
|
2581
|
+
}
|
|
2582
|
+
function matchModifiers(expected, event) {
|
|
2583
|
+
// returns true on match
|
|
2584
|
+
return !modifierSequence.some(function(prop) {
|
|
2585
|
+
// returns true on mismatch
|
|
2586
|
+
return typeof expected[prop] === 'boolean' && Boolean(event[prop]) !== expected[prop];
|
|
2587
|
+
});
|
|
2588
|
+
}
|
|
2589
|
+
function keyBinding(text) {
|
|
2590
|
+
return text.split(/\s+/).map(function(_text) {
|
|
2591
|
+
var tokens = _text.split('+');
|
|
2592
|
+
var _modifiers = resolveModifiers(tokens.slice(0, -1));
|
|
2593
|
+
var _keyCodes = resolveKey(tokens.slice(-1));
|
|
2594
|
+
return {
|
|
2595
|
+
keyCodes: _keyCodes,
|
|
2596
|
+
modifiers: _modifiers,
|
|
2597
|
+
matchModifiers: matchModifiers.bind(null, _modifiers)
|
|
2598
|
+
};
|
|
2599
|
+
});
|
|
2600
|
+
}
|
|
2601
|
+
// Node.compareDocumentPosition is available since IE9
|
|
2602
|
+
// see https://developer.mozilla.org/docs/Web/API/Node.compareDocumentPosition
|
|
2603
|
+
// callback returns true when element is contained by parent or is the parent suited for use with Array.some()
|
|
2604
|
+
/*
|
|
2605
|
+
USAGE:
|
|
2606
|
+
var isChildOf = getParentComparator({parent: someNode});
|
|
2607
|
+
listOfElements.some(isChildOf)
|
|
2608
|
+
*/ function getParentComparator() {
|
|
2609
|
+
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, parent = _ref.parent, element = _ref.element, includeSelf = _ref.includeSelf;
|
|
2610
|
+
if (parent) {
|
|
2611
|
+
return function isChildOf(node) {
|
|
2612
|
+
return Boolean(includeSelf && node === parent || parent.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_CONTAINED_BY);
|
|
2613
|
+
};
|
|
2614
|
+
} else if (element) {
|
|
2615
|
+
return function isParentOf(node) {
|
|
2616
|
+
return Boolean(includeSelf && element === node || node.compareDocumentPosition(element) & Node.DOCUMENT_POSITION_CONTAINED_BY);
|
|
2617
|
+
};
|
|
2618
|
+
}
|
|
2619
|
+
throw Object.defineProperty(new TypeError('util/compare-position#getParentComparator required either options.parent or options.element'), "__NEXT_ERROR_CODE", {
|
|
2620
|
+
value: "E578",
|
|
2621
|
+
enumerable: false
|
|
2622
|
+
});
|
|
2623
|
+
}
|
|
2624
|
+
// Bug 286933 - Key events in the autocomplete popup should be hidden from page scripts
|
|
2625
|
+
// @browser-issue Gecko https://bugzilla.mozilla.org/show_bug.cgi?id=286933
|
|
2626
|
+
function whenKey() {
|
|
2627
|
+
var map = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
2628
|
+
var bindings = {};
|
|
2629
|
+
var context = nodeArray(map.context)[0] || document.documentElement;
|
|
2630
|
+
delete map.context;
|
|
2631
|
+
var filter = nodeArray(map.filter);
|
|
2632
|
+
delete map.filter;
|
|
2633
|
+
var mapKeys = Object.keys(map);
|
|
2634
|
+
if (!mapKeys.length) {
|
|
2635
|
+
throw Object.defineProperty(new TypeError('when/key requires at least one option key'), "__NEXT_ERROR_CODE", {
|
|
2636
|
+
value: "E566",
|
|
2637
|
+
enumerable: false
|
|
2638
|
+
});
|
|
2639
|
+
}
|
|
2640
|
+
var registerBinding = function registerBinding(event) {
|
|
2641
|
+
event.keyCodes.forEach(function(code) {
|
|
2642
|
+
if (!bindings[code]) {
|
|
2643
|
+
bindings[code] = [];
|
|
2644
|
+
}
|
|
2645
|
+
bindings[code].push(event);
|
|
2646
|
+
});
|
|
2647
|
+
};
|
|
2648
|
+
mapKeys.forEach(function(text) {
|
|
2649
|
+
if (typeof map[text] !== 'function') {
|
|
2650
|
+
throw Object.defineProperty(new TypeError('when/key requires option["' + text + '"] to be a function'), "__NEXT_ERROR_CODE", {
|
|
2651
|
+
value: "E595",
|
|
2652
|
+
enumerable: false
|
|
2653
|
+
});
|
|
2654
|
+
}
|
|
2655
|
+
var addCallback = function addCallback(event) {
|
|
2656
|
+
event.callback = map[text];
|
|
2657
|
+
return event;
|
|
2658
|
+
};
|
|
2659
|
+
keyBinding(text).map(addCallback).forEach(registerBinding);
|
|
2660
|
+
});
|
|
2661
|
+
var handleKeyDown = function handleKeyDown(event) {
|
|
2662
|
+
if (event.defaultPrevented) {
|
|
2663
|
+
return;
|
|
2664
|
+
}
|
|
2665
|
+
if (filter.length) {
|
|
2666
|
+
// ignore elements within the exempted sub-trees
|
|
2667
|
+
var isParentOfElement = getParentComparator({
|
|
2668
|
+
element: event.target,
|
|
2669
|
+
includeSelf: true
|
|
2670
|
+
});
|
|
2671
|
+
if (filter.some(isParentOfElement)) {
|
|
2672
|
+
return;
|
|
2673
|
+
}
|
|
2674
|
+
}
|
|
2675
|
+
var key = event.keyCode || event.which;
|
|
2676
|
+
if (!bindings[key]) {
|
|
2677
|
+
return;
|
|
2678
|
+
}
|
|
2679
|
+
bindings[key].forEach(function(_event) {
|
|
2680
|
+
if (!_event.matchModifiers(event)) {
|
|
2681
|
+
return;
|
|
2682
|
+
}
|
|
2683
|
+
_event.callback.call(context, event, disengage);
|
|
2684
|
+
});
|
|
2685
|
+
};
|
|
2686
|
+
context.addEventListener('keydown', handleKeyDown, false);
|
|
2687
|
+
var disengage = function disengage() {
|
|
2688
|
+
context.removeEventListener('keydown', handleKeyDown, false);
|
|
2689
|
+
};
|
|
2690
|
+
return {
|
|
2691
|
+
disengage: disengage
|
|
2692
|
+
};
|
|
2693
|
+
}
|
|
2694
|
+
function _default(param) {
|
|
2695
|
+
let { context } = param === void 0 ? {} : param;
|
|
2696
|
+
if (!context) {
|
|
2697
|
+
context = document.documentElement;
|
|
2698
|
+
}
|
|
2699
|
+
// Make sure the supports tests are run before intercepting the Tab key,
|
|
2700
|
+
// or IE10 and IE11 will fail to process the first Tab key event. Not
|
|
2701
|
+
// limiting this warm-up to IE because it may be a problem elsewhere, too.
|
|
2702
|
+
queryTabsequence();
|
|
2703
|
+
return whenKey({
|
|
2704
|
+
// Safari on OSX may require ALT+TAB to reach links,
|
|
2705
|
+
// see https://github.com/medialize/ally.js/issues/146
|
|
2706
|
+
'?alt+?shift+tab': function altShiftTab(event) {
|
|
2707
|
+
// we're completely taking over the Tab key handling
|
|
2708
|
+
event.preventDefault();
|
|
2709
|
+
var sequence = queryTabsequence({
|
|
2710
|
+
context: context
|
|
2711
|
+
});
|
|
2712
|
+
var backward = event.shiftKey;
|
|
2713
|
+
var first = sequence[0];
|
|
2714
|
+
var last = sequence[sequence.length - 1];
|
|
2715
|
+
// wrap around first to last, last to first
|
|
2716
|
+
var source = backward ? first : last;
|
|
2717
|
+
var target = backward ? last : first;
|
|
2718
|
+
if (isActiveElement(source)) {
|
|
2719
|
+
target.focus();
|
|
2720
|
+
return;
|
|
2721
|
+
}
|
|
2722
|
+
// find current position in tabsequence
|
|
2723
|
+
var currentIndex = void 0;
|
|
2724
|
+
var found = sequence.some(function(element, index) {
|
|
2725
|
+
if (!isActiveElement(element)) {
|
|
2726
|
+
return false;
|
|
2727
|
+
}
|
|
2728
|
+
currentIndex = index;
|
|
2729
|
+
return true;
|
|
2730
|
+
});
|
|
2731
|
+
if (!found) {
|
|
2732
|
+
// redirect to first as we're not in our tabsequence
|
|
2733
|
+
first.focus();
|
|
2734
|
+
return;
|
|
2735
|
+
}
|
|
2736
|
+
// shift focus to previous/next element in the sequence
|
|
2737
|
+
var offset = backward ? -1 : 1;
|
|
2738
|
+
sequence[currentIndex + offset].focus();
|
|
2739
|
+
}
|
|
2740
|
+
});
|
|
2741
|
+
}
|
|
2742
|
+
|
|
2743
|
+
if ((typeof exports.default === 'function' || (typeof exports.default === 'object' && exports.default !== null)) && typeof exports.default.__esModule === 'undefined') {
|
|
2744
|
+
Object.defineProperty(exports.default, '__esModule', { value: true });
|
|
2745
|
+
Object.assign(exports.default, exports);
|
|
2746
|
+
module.exports = exports.default;
|
|
2747
|
+
}
|
|
2748
|
+
|
|
2749
|
+
//# sourceMappingURL=maintain--tab-focus.js.map
|