@spectrum-web-components/overlay 0.35.1-rc.41 → 0.36.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +150 -237
- package/active-overlay.d.ts +6 -0
- package/active-overlay.dev.js +5 -0
- package/{sp-overlay.dev.js.map → active-overlay.dev.js.map} +3 -3
- package/active-overlay.js +2 -0
- package/{sp-overlay.js.map → active-overlay.js.map} +4 -4
- package/custom-elements.json +1215 -0
- package/package.json +22 -49
- package/src/ActiveOverlay.d.ts +84 -0
- package/src/ActiveOverlay.dev.js +517 -0
- package/src/ActiveOverlay.dev.js.map +7 -0
- package/src/ActiveOverlay.js +16 -0
- package/src/ActiveOverlay.js.map +7 -0
- package/src/OverlayTrigger.d.ts +41 -24
- package/src/OverlayTrigger.dev.js +295 -133
- package/src/OverlayTrigger.dev.js.map +3 -3
- package/src/OverlayTrigger.js +22 -52
- package/src/OverlayTrigger.js.map +3 -3
- package/src/VirtualTrigger.dev.js +1 -2
- package/src/VirtualTrigger.dev.js.map +2 -2
- package/src/VirtualTrigger.js +1 -1
- package/src/VirtualTrigger.js.map +2 -2
- package/src/active-overlay.css.dev.js +13 -0
- package/src/active-overlay.css.dev.js.map +7 -0
- package/src/active-overlay.css.js +10 -0
- package/src/active-overlay.css.js.map +7 -0
- package/src/index.d.ts +3 -2
- package/src/index.dev.js +3 -2
- package/src/index.dev.js.map +2 -2
- package/src/index.js +1 -1
- package/src/index.js.map +2 -2
- package/src/loader.d.ts +2 -1
- package/src/loader.dev.js +19 -2
- package/src/loader.dev.js.map +2 -2
- package/src/loader.js +1 -1
- package/src/loader.js.map +3 -3
- package/src/overlay-stack.d.ts +50 -0
- package/src/overlay-stack.dev.js +515 -0
- package/src/overlay-stack.dev.js.map +7 -0
- package/src/overlay-stack.js +34 -0
- package/src/overlay-stack.js.map +7 -0
- package/src/overlay-timer.dev.js.map +2 -2
- package/src/overlay-timer.js.map +2 -2
- package/src/overlay-trigger.css.dev.js +1 -1
- package/src/overlay-trigger.css.dev.js.map +1 -1
- package/src/overlay-trigger.css.js +1 -1
- package/src/overlay-trigger.css.js.map +1 -1
- package/src/overlay-types.d.ts +31 -25
- package/src/overlay-types.dev.js +0 -1
- package/src/overlay-types.dev.js.map +3 -3
- package/src/overlay-types.js +1 -1
- package/src/overlay-types.js.map +3 -3
- package/src/overlay-utils.d.ts +3 -0
- package/src/overlay-utils.dev.js +31 -0
- package/src/overlay-utils.dev.js.map +7 -0
- package/src/overlay-utils.js +2 -0
- package/src/overlay-utils.js.map +7 -0
- package/src/overlay.d.ts +59 -0
- package/src/overlay.dev.js +127 -0
- package/src/overlay.dev.js.map +7 -0
- package/src/overlay.js +2 -0
- package/src/overlay.js.map +7 -0
- package/stories/overlay-story-components.js +8 -9
- package/stories/overlay-story-components.js.map +2 -2
- package/stories/overlay.stories.js +697 -825
- package/stories/overlay.stories.js.map +2 -2
- package/sync/overlay-trigger.d.ts +0 -4
- package/sync/overlay-trigger.dev.js +4 -1
- package/sync/overlay-trigger.dev.js.map +2 -2
- package/sync/overlay-trigger.js +1 -1
- package/sync/overlay-trigger.js.map +3 -3
- package/test/benchmark/basic-test.js +1 -1
- package/test/benchmark/basic-test.js.map +1 -1
- package/test/index.js +377 -408
- package/test/index.js.map +3 -3
- package/test/overlay-lifecycle.test.js +106 -34
- package/test/overlay-lifecycle.test.js.map +2 -2
- package/test/overlay-trigger-click.test.js +5 -11
- package/test/overlay-trigger-click.test.js.map +2 -2
- package/test/overlay-trigger-extended.test.js +36 -42
- package/test/overlay-trigger-extended.test.js.map +2 -2
- package/test/overlay-trigger-hover-click.test.js +24 -27
- package/test/overlay-trigger-hover-click.test.js.map +2 -2
- package/test/overlay-trigger-hover.test.js +35 -41
- package/test/overlay-trigger-hover.test.js.map +2 -2
- package/test/overlay-trigger-longpress.test.js +81 -206
- package/test/overlay-trigger-longpress.test.js.map +2 -2
- package/test/overlay-trigger-sync.test.js +1 -1
- package/test/overlay-trigger-sync.test.js.map +2 -2
- package/test/overlay-trigger.test.js +1 -1
- package/test/overlay-trigger.test.js.map +2 -2
- package/test/overlay-update.test.js +4 -4
- package/test/overlay-update.test.js.map +2 -2
- package/test/overlay.test.js +268 -386
- package/test/overlay.test.js.map +3 -3
- package/sp-overlay.d.ts +0 -6
- package/sp-overlay.dev.js +0 -5
- package/sp-overlay.js +0 -2
- package/src/AbstractOverlay.d.ts +0 -56
- package/src/AbstractOverlay.dev.js +0 -202
- package/src/AbstractOverlay.dev.js.map +0 -7
- package/src/AbstractOverlay.js +0 -2
- package/src/AbstractOverlay.js.map +0 -7
- package/src/Overlay.d.ts +0 -147
- package/src/Overlay.dev.js +0 -777
- package/src/Overlay.dev.js.map +0 -7
- package/src/Overlay.js +0 -33
- package/src/Overlay.js.map +0 -7
- package/src/OverlayDialog.d.ts +0 -4
- package/src/OverlayDialog.dev.js +0 -135
- package/src/OverlayDialog.dev.js.map +0 -7
- package/src/OverlayDialog.js +0 -2
- package/src/OverlayDialog.js.map +0 -7
- package/src/OverlayNoPopover.d.ts +0 -4
- package/src/OverlayNoPopover.dev.js +0 -110
- package/src/OverlayNoPopover.dev.js.map +0 -7
- package/src/OverlayNoPopover.js +0 -2
- package/src/OverlayNoPopover.js.map +0 -7
- package/src/OverlayPopover.d.ts +0 -4
- package/src/OverlayPopover.dev.js +0 -169
- package/src/OverlayPopover.dev.js.map +0 -7
- package/src/OverlayPopover.js +0 -2
- package/src/OverlayPopover.js.map +0 -7
- package/src/OverlayStack.d.ts +0 -43
- package/src/OverlayStack.dev.js +0 -150
- package/src/OverlayStack.dev.js.map +0 -7
- package/src/OverlayStack.js +0 -2
- package/src/OverlayStack.js.map +0 -7
- package/src/PlacementController.d.ts +0 -38
- package/src/PlacementController.dev.js +0 -199
- package/src/PlacementController.dev.js.map +0 -7
- package/src/PlacementController.js +0 -2
- package/src/PlacementController.js.map +0 -7
- package/src/fullSizePlugin.d.ts +0 -12
- package/src/fullSizePlugin.dev.js +0 -39
- package/src/fullSizePlugin.dev.js.map +0 -7
- package/src/fullSizePlugin.js +0 -2
- package/src/fullSizePlugin.js.map +0 -7
- package/src/overlay.css.dev.js +0 -9
- package/src/overlay.css.dev.js.map +0 -7
- package/src/overlay.css.js +0 -6
- package/src/overlay.css.js.map +0 -7
- package/src/topLayerOverTransforms.d.ts +0 -2
- package/src/topLayerOverTransforms.dev.js +0 -90
- package/src/topLayerOverTransforms.dev.js.map +0 -7
- package/src/topLayerOverTransforms.js +0 -2
- package/src/topLayerOverTransforms.js.map +0 -7
- package/stories/overlay-element.stories.js +0 -366
- package/stories/overlay-element.stories.js.map +0 -7
- package/test/overlay-element.test-vrt.js +0 -5
- package/test/overlay-element.test-vrt.js.map +0 -7
- package/test/overlay-element.test.js +0 -681
- package/test/overlay-element.test.js.map +0 -7
- package/test/overlay-v1.test.js +0 -651
- package/test/overlay-v1.test.js.map +0 -7
- /package/src/{overlay.css.d.ts → active-overlay.css.d.ts} +0 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["ActiveOverlay.ts"],
|
|
4
|
+
"sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport { ifDefined } from '@spectrum-web-components/base/src/directives.js';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { reparentChildren } from '@spectrum-web-components/shared/src/reparent-children.js';\nimport { firstFocusableIn } from '@spectrum-web-components/shared/src/first-focusable-in.js';\nimport type {\n Color,\n Scale,\n ThemeVariant,\n} from '@spectrum-web-components/theme/src/Theme.js';\nimport styles from './active-overlay.css.js';\nimport { parentOverlayOf } from './overlay-utils.js';\nimport {\n OverlayOpenCloseDetail,\n OverlayOpenDetail,\n Placement,\n TriggerInteractions,\n} from './overlay-types.js';\nimport type { VirtualTrigger } from './VirtualTrigger.js';\nimport {\n arrow,\n autoUpdate,\n computePosition,\n flip,\n Placement as FloatingUIPlacement,\n offset,\n shift,\n size,\n} from '@floating-ui/dom';\n\nexport interface PositionResult {\n arrowOffsetLeft: number;\n arrowOffsetTop: number;\n maxHeight: number;\n placement: string;\n positionLeft: number;\n positionTop: number;\n}\n\ntype OverlayStateType = 'idle' | 'active' | 'hiding' | 'dispose' | 'disposed';\ntype ContentAnimation = 'sp-overlay-fade-in' | 'sp-overlay-fade-out';\n\nconst stateMachine: {\n initial: OverlayStateType;\n states: {\n [stateName: string]: {\n on: {\n [transitionName: string]: OverlayStateType;\n };\n };\n };\n} = {\n initial: 'idle',\n states: {\n idle: {\n on: {\n active: 'active',\n },\n },\n active: {\n on: {\n hiding: 'hiding',\n idle: 'idle',\n },\n },\n hiding: {\n on: {\n dispose: 'dispose',\n },\n },\n dispose: {\n on: {\n disposed: 'disposed',\n },\n },\n disposed: {\n on: {},\n },\n },\n};\n\nconst stateTransition = (\n state?: OverlayStateType,\n event?: string\n): OverlayStateType => {\n if (!state) return stateMachine.initial;\n /* c8 ignore next */\n if (!event) return state;\n return stateMachine.states[state].on[event] || state;\n};\n\nconst getFallbackPlacements = (\n placement: FloatingUIPlacement\n): FloatingUIPlacement[] => {\n const fallbacks: Record<FloatingUIPlacement, FloatingUIPlacement[]> = {\n left: ['right', 'bottom', 'top'],\n 'left-start': ['right-start', 'bottom', 'top'],\n 'left-end': ['right-end', 'bottom', 'top'],\n right: ['left', 'bottom', 'top'],\n 'right-start': ['left-start', 'bottom', 'top'],\n 'right-end': ['left-end', 'bottom', 'top'],\n top: ['bottom', 'left', 'right'],\n 'top-start': ['bottom-start', 'left', 'right'],\n 'top-end': ['bottom-end', 'left', 'right'],\n bottom: ['top', 'left', 'right'],\n 'bottom-start': ['top-start', 'left', 'right'],\n 'bottom-end': ['top-end', 'left', 'right'],\n };\n return fallbacks[placement] ?? [placement];\n};\n\n/**\n * @element active-overlay\n *\n * @slot - content to display in the overlay\n */\nexport class ActiveOverlay extends SpectrumElement {\n public overlayContent!: HTMLElement;\n public overlayContentTip?: HTMLElement;\n public trigger!: HTMLElement;\n public root?: HTMLElement;\n public virtualTrigger?: VirtualTrigger;\n private cleanup?: () => void;\n\n protected contentAnimationPromise: Promise<boolean> = Promise.resolve(true);\n protected resolveContentAnimationPromise = (): void => {\n return;\n };\n\n @property()\n public _state = stateTransition();\n public get state(): OverlayStateType {\n return this._state;\n }\n public set state(state: OverlayStateType) {\n const nextState = stateTransition(this.state, state);\n if (nextState === this.state) {\n return;\n }\n this._state = nextState;\n if (this.state === 'active' || this.state === 'hiding') {\n this.setAttribute('state', this.state);\n } else {\n this.removeAttribute('state');\n }\n }\n\n @property({ reflect: true, type: Boolean })\n public animating = false;\n\n @property({ reflect: true })\n public placement?: Placement;\n @property({ attribute: false })\n public theme: {\n color?: Color;\n scale?: Scale;\n lang?: string;\n theme?: ThemeVariant;\n } = {};\n @property({ attribute: false })\n public receivesFocus?: 'auto';\n\n public tabbingAway = false;\n private originalPlacement?: Placement;\n private restoreContent?: () => Element[];\n\n public override async focus(): Promise<void> {\n const firstFocusable = firstFocusableIn(this);\n if (firstFocusable) {\n if ((firstFocusable as SpectrumElement).updateComplete) {\n await firstFocusable.updateComplete;\n }\n const activeElement = (this.getRootNode() as Document)\n .activeElement;\n if (activeElement === this || !this.contains(activeElement)) {\n firstFocusable.focus();\n }\n /* c8 ignore next 3 */\n } else {\n super.focus();\n }\n this.removeAttribute('tabindex');\n }\n\n private get hasTheme(): boolean {\n return !!this.theme.color || !!this.theme.scale || !!this.theme.lang;\n }\n\n public offset = 6;\n public skidding = 0;\n public interaction: TriggerInteractions = 'hover';\n private positionAnimationFrame = 0;\n\n private timeout?: number;\n\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n public constructor() {\n super();\n this.stealOverlayContentPromise = new Promise(\n (res) => (this.stealOverlayContentResolver = res)\n );\n }\n\n private _modalRoot?: ActiveOverlay;\n\n public get hasModalRoot(): boolean {\n return !!this._modalRoot;\n }\n\n public feature(): void {\n // eslint-disable-next-line @spectrum-web-components/document-active-element\n if (!this.contains(document.activeElement)) {\n this.tabIndex = -1;\n }\n const parentOverlay = parentOverlayOf(this.trigger);\n const parentIsModal = parentOverlay && parentOverlay.slot === 'open';\n if (parentIsModal) {\n this._modalRoot = parentOverlay._modalRoot || parentOverlay;\n }\n // If an overlay it triggered from within a \"modal\" overlay, it needs to continue\n // to act like one to get treated correctly in regards to tab trapping.\n if (this.interaction === 'modal' || this._modalRoot) {\n this.slot = 'open';\n if (this.interaction === 'modal') {\n this.setAttribute('aria-modal', 'true');\n }\n // If this isn't a modal root, walk up the overlays to the next modal root\n // and \"feature\" each on of the intervening overlays.\n if (this._modalRoot) {\n parentOverlay?.feature();\n }\n }\n }\n\n public obscure(\n nextOverlayInteraction: TriggerInteractions\n ): ActiveOverlay | undefined {\n if (this.slot && nextOverlayInteraction === 'modal') {\n this.removeAttribute('slot');\n this.removeAttribute('aria-modal');\n // Obscure upto and including the next modal root.\n if (this.interaction !== 'modal') {\n const parentOverlay = parentOverlayOf(this.trigger);\n this._modalRoot = parentOverlay?.obscure(\n nextOverlayInteraction\n );\n return this._modalRoot;\n }\n return this;\n }\n return undefined;\n }\n\n public override async willUpdate(): Promise<void> {\n if (this.hasUpdated) return;\n\n /* c8 ignore next */\n if (!this.overlayContent || !this.trigger) return;\n\n this.stealOverlayContent(\n this.overlayContent as HTMLElement & { placement: Placement }\n );\n\n this.state = 'active';\n\n this.feature();\n if (this.placement && this.placement !== 'none') {\n await this.updateOverlayPosition();\n document.addEventListener(\n 'sp-update-overlays',\n this.resetOverlayPosition\n );\n }\n if (this.placement && this.placement !== 'none') {\n this.contentAnimationPromise =\n this.applyContentAnimation('sp-overlay-fade-in');\n }\n }\n\n public async openCallback(\n lifecycleCallback: () => Promise<void> | void\n ): Promise<void> {\n await this.updateComplete;\n if (this.receivesFocus) {\n await this.focus();\n }\n\n await lifecycleCallback();\n\n this.trigger.dispatchEvent(\n new CustomEvent<OverlayOpenCloseDetail>('sp-opened', {\n bubbles: true,\n composed: true,\n cancelable: true,\n detail: {\n interaction: this.interaction,\n },\n })\n );\n }\n\n private open(openDetail: OverlayOpenDetail): void {\n this.extractDetail(openDetail);\n }\n\n private extractDetail(detail: OverlayOpenDetail): void {\n this.overlayContent = detail.content;\n this.overlayContentTip = detail.contentTip;\n this.trigger = detail.trigger;\n this.virtualTrigger = detail.virtualTrigger;\n this.placement = detail.placement;\n this.offset = detail.offset;\n this.skidding = detail.skidding || 0;\n this.interaction = detail.interaction;\n this.theme = detail.theme;\n this.receivesFocus = detail.receivesFocus;\n this.root = detail.root;\n }\n\n public dispose(): void {\n /* c8 ignore next */\n if (this.state !== 'dispose') return;\n\n /* c8 ignore next 4 */\n if (this.timeout) {\n clearTimeout(this.timeout);\n delete this.timeout;\n }\n\n this.trigger.removeEventListener(\n 'keydown',\n this.handleInlineTriggerKeydown\n );\n\n this.returnOverlayContent();\n this.state = 'disposed';\n\n if (this.willNotifyClosed) {\n this.overlayContent.dispatchEvent(new Event('sp-overlay-closed'));\n this.willNotifyClosed = false;\n }\n\n if (this.cleanup) {\n this.cleanup();\n }\n }\n\n private stealOverlayContent(\n element: HTMLElement & { placement: Placement }\n ): void {\n this.originalPlacement = element.getAttribute('placement') as Placement;\n this.restoreContent = reparentChildren([element], this, {\n position: 'beforeend',\n prepareCallback: (el) => {\n const slotName = el.slot;\n const placement = el.placement;\n el.removeAttribute('slot');\n return (el) => {\n el.slot = slotName;\n el.placement = placement;\n };\n },\n });\n this.stealOverlayContentResolver();\n }\n\n private willNotifyClosed = false;\n\n private returnOverlayContent(): void {\n /* c8 ignore next */\n if (!this.restoreContent) return;\n\n const [element] = this.restoreContent();\n this.restoreContent = undefined;\n this.willNotifyClosed = true;\n\n if (this.originalPlacement) {\n element.setAttribute('placement', this.originalPlacement);\n delete this.originalPlacement;\n }\n }\n\n private initialHeight: number | undefined;\n private isConstrained = false;\n\n public async placeOverlay(): Promise<void> {\n if (!this.placement || this.placement === 'none') {\n return;\n }\n\n this.cleanup = autoUpdate(\n this.virtualTrigger || this.trigger,\n this,\n this.updateOverlayPosition,\n {\n elementResize: false,\n }\n );\n }\n\n public updateOverlayPosition = (): void => {\n if (this.interaction !== 'modal' && this.cleanup) {\n this.dispatchEvent(new Event('close'));\n return;\n }\n this.setOverlayPosition();\n };\n\n public resetOverlayPosition = (): void => {\n this.style.removeProperty('max-height');\n this.style.removeProperty('height');\n this.initialHeight = undefined;\n this.isConstrained = false;\n // force paint\n this.offsetHeight;\n this.setOverlayPosition();\n };\n\n public setOverlayPosition = async (): Promise<void> => {\n if (!this.placement || this.placement === 'none') {\n return;\n }\n await (document.fonts ? document.fonts.ready : Promise.resolve());\n\n function roundByDPR(num: number): number {\n const dpr = window.devicePixelRatio || 1;\n return Math.round(num * dpr) / dpr || -10000;\n }\n\n // See: https://spectrum.adobe.com/page/popover/#Container-padding\n const REQUIRED_DISTANCE_TO_EDGE = 8;\n // See: https://github.com/adobe/spectrum-web-components/issues/910\n const MIN_OVERLAY_HEIGHT = 100;\n\n const flipMiddleware = this.virtualTrigger\n ? flip({\n padding: REQUIRED_DISTANCE_TO_EDGE,\n fallbackPlacements: getFallbackPlacements(this.placement),\n })\n : flip({\n padding: REQUIRED_DISTANCE_TO_EDGE,\n });\n\n const middleware = [\n offset({\n mainAxis: this.offset,\n crossAxis: this.skidding,\n }),\n shift({ padding: REQUIRED_DISTANCE_TO_EDGE }),\n flipMiddleware,\n size({\n padding: REQUIRED_DISTANCE_TO_EDGE,\n apply: ({\n availableWidth,\n availableHeight,\n rects: { floating },\n }) => {\n const maxHeight = Math.max(\n MIN_OVERLAY_HEIGHT,\n Math.floor(availableHeight)\n );\n const actualHeight = floating.height;\n this.initialHeight =\n !this.isConstrained && !this.virtualTrigger\n ? actualHeight\n : this.initialHeight || actualHeight;\n this.isConstrained =\n actualHeight < this.initialHeight ||\n maxHeight <= actualHeight;\n const appliedHeight = this.isConstrained\n ? `${maxHeight}px`\n : '';\n Object.assign(this.style, {\n maxWidth: `${Math.floor(availableWidth)}px`,\n maxHeight: appliedHeight,\n height: appliedHeight,\n });\n },\n }),\n ];\n if (this.overlayContentTip) {\n middleware.push(arrow({ element: this.overlayContentTip }));\n }\n const { x, y, placement, middlewareData } = await computePosition(\n this.virtualTrigger || this.trigger,\n this,\n {\n placement: this.placement,\n middleware,\n strategy: 'fixed',\n }\n );\n\n Object.assign(this.style, {\n top: '0px',\n left: '0px',\n transform: `translate(${roundByDPR(x)}px, ${roundByDPR(y)}px)`,\n });\n\n if (placement !== this.getAttribute('actual-placement')) {\n this.setAttribute('actual-placement', placement);\n this.overlayContent.setAttribute('placement', placement);\n }\n\n if (this.overlayContentTip && middlewareData.arrow) {\n const { x: arrowX, y: arrowY } = middlewareData.arrow;\n\n Object.assign(this.overlayContentTip.style, {\n left: arrowX != null ? `${roundByDPR(arrowX)}px` : '',\n top: arrowY != null ? `${roundByDPR(arrowY)}px` : '',\n right: '',\n bottom: '',\n });\n }\n };\n\n public async hide(animated = true): Promise<void> {\n if (this.state !== 'active') return;\n this.state = 'hiding';\n if (animated) {\n await this.applyContentAnimation('sp-overlay-fade-out');\n }\n this.state = 'dispose';\n }\n\n private schedulePositionUpdate(): void {\n // Edge needs a little time to update the DOM before computing the layout\n cancelAnimationFrame(this.positionAnimationFrame);\n this.positionAnimationFrame = requestAnimationFrame(() => {\n if (this.cleanup) {\n this.updateOverlayPosition();\n } else {\n this.placeOverlay();\n }\n });\n }\n\n private onSlotChange(): void {\n this.schedulePositionUpdate();\n }\n\n public handleInlineTriggerKeydown = (event: KeyboardEvent): void => {\n const { code, shiftKey } = event;\n /* c8 ignore next */\n if (code !== 'Tab') return;\n if (shiftKey) {\n this.tabbingAway = true;\n this.dispatchEvent(new Event('close'));\n return;\n }\n\n event.stopPropagation();\n event.preventDefault();\n this.focus();\n };\n\n public applyContentAnimation(\n animation: ContentAnimation\n ): Promise<boolean> {\n if (this.placement === 'none') {\n return Promise.resolve(true);\n }\n this.resolveContentAnimationPromise();\n return new Promise((resolve): void => {\n this.resolveContentAnimationPromise = () => {\n resolve(false);\n };\n const contents = this.shadowRoot.querySelector(\n '#contents'\n ) as HTMLElement;\n const doneHandler = (event: AnimationEvent): void => {\n if (animation !== event.animationName) return;\n contents.removeEventListener('animationend', doneHandler);\n contents.removeEventListener('animationcancel', doneHandler);\n this.animating = false;\n resolve(event.type === 'animationcancel');\n };\n contents.addEventListener('animationend', doneHandler);\n contents.addEventListener('animationcancel', doneHandler);\n\n contents.style.animationName = animation;\n this.animating = true;\n });\n }\n\n public renderTheme(content: TemplateResult): TemplateResult {\n const { color, scale, lang, theme } = this.theme;\n return html`\n <sp-theme\n theme=${ifDefined(theme)}\n color=${ifDefined(color)}\n scale=${ifDefined(scale)}\n lang=${ifDefined(lang)}\n part=\"theme\"\n >\n ${content}\n </sp-theme>\n `;\n }\n\n public override render(): TemplateResult {\n const content = html`\n <div id=\"contents\">\n <slot @slotchange=${this.onSlotChange}></slot>\n </div>\n `;\n return this.hasTheme ? this.renderTheme(content) : content;\n }\n\n public static create(details: OverlayOpenDetail): ActiveOverlay {\n const overlay = new ActiveOverlay();\n\n if (details.content) {\n overlay.open(details);\n }\n\n return overlay;\n }\n\n private stealOverlayContentPromise = Promise.resolve();\n private stealOverlayContentResolver!: () => void;\n\n protected override async getUpdateComplete(): Promise<boolean> {\n const actions: Promise<unknown>[] = [\n super.getUpdateComplete(),\n this.stealOverlayContentPromise,\n ];\n actions.push(this.contentAnimationPromise);\n if (\n typeof (this.overlayContent as SpectrumElement).updateComplete !==\n 'undefined'\n ) {\n actions.push(\n (this.overlayContent as SpectrumElement).updateComplete\n );\n }\n const [complete] = await Promise.all(actions);\n return complete as boolean;\n }\n\n override disconnectedCallback(): void {\n document.removeEventListener(\n 'sp-update-overlays',\n this.resetOverlayPosition\n );\n super.disconnectedCallback();\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["html", "SpectrumElement", "ifDefined", "property", "reparentChildren", "firstFocusableIn", "styles", "parentOverlayOf", "arrow", "autoUpdate", "computePosition", "flip", "offset", "shift", "size", "stateMachine", "stateTransition", "state", "event", "getFallbackPlacements", "placement", "_a", "_ActiveOverlay", "roundByDPR", "num", "dpr", "REQUIRED_DISTANCE_TO_EDGE", "MIN_OVERLAY_HEIGHT", "flipMiddleware", "middleware", "availableWidth", "availableHeight", "floating", "maxHeight", "actualHeight", "appliedHeight", "x", "y", "middlewareData", "arrowX", "arrowY", "code", "shiftKey", "res", "nextState", "firstFocusable", "activeElement", "parentOverlay", "nextOverlayInteraction", "lifecycleCallback", "openDetail", "detail", "element", "el", "slotName", "animated", "animation", "resolve", "contents", "doneHandler", "content", "color", "scale", "lang", "theme", "details", "overlay", "actions", "complete", "__decorateClass"]
|
|
7
|
+
}
|
package/src/OverlayTrigger.d.ts
CHANGED
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { CSSResultArray, PropertyValues, SpectrumElement, TemplateResult } from '@spectrum-web-components/base';
|
|
2
|
-
import { OverlayTriggerInteractions } from './overlay-types';
|
|
3
|
-
import '../sp-overlay.js';
|
|
4
|
-
import { Placement } from '@floating-ui/dom';
|
|
5
|
-
import type { Overlay } from './Overlay.js';
|
|
2
|
+
import { OverlayOptions, OverlayTriggerInteractions, Placement, TriggerInteractions } from './overlay-types';
|
|
6
3
|
export declare type OverlayContentTypes = 'click' | 'hover' | 'longpress';
|
|
4
|
+
export declare const LONGPRESS_INSTRUCTIONS: {
|
|
5
|
+
touch: string;
|
|
6
|
+
keyboard: string;
|
|
7
|
+
mouse: string;
|
|
8
|
+
};
|
|
7
9
|
/**
|
|
8
10
|
* @element overlay-trigger
|
|
9
11
|
*
|
|
@@ -16,35 +18,50 @@ export declare type OverlayContentTypes = 'click' | 'hover' | 'longpress';
|
|
|
16
18
|
* @fires sp-closed - Announces that the overlay has been closed
|
|
17
19
|
*/
|
|
18
20
|
export declare class OverlayTrigger extends SpectrumElement {
|
|
21
|
+
private closeClickOverlay?;
|
|
22
|
+
private closeLongpressOverlay?;
|
|
23
|
+
private closeHoverOverlay?;
|
|
19
24
|
static get styles(): CSSResultArray;
|
|
20
25
|
/**
|
|
21
|
-
* @type {"auto" | "auto-start" | "auto-end" | "top" | "bottom" | "right" | "left" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end" }
|
|
26
|
+
* @type {"auto" | "auto-start" | "auto-end" | "top" | "bottom" | "right" | "left" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end" | "none"}
|
|
22
27
|
* @attr
|
|
23
28
|
*/
|
|
24
|
-
placement
|
|
29
|
+
placement: Placement;
|
|
25
30
|
type?: OverlayTriggerInteractions;
|
|
26
31
|
offset: number;
|
|
27
32
|
open?: OverlayContentTypes;
|
|
28
33
|
disabled: boolean;
|
|
29
|
-
|
|
30
|
-
private
|
|
31
|
-
private
|
|
32
|
-
private
|
|
33
|
-
private hoverContent
|
|
34
|
-
private
|
|
35
|
-
private
|
|
36
|
-
clickOverlayElement: Overlay;
|
|
37
|
-
longpressOverlayElement: Overlay;
|
|
38
|
-
hoverOverlayElement: Overlay;
|
|
34
|
+
hasLongpressContent: boolean;
|
|
35
|
+
private longpressDescriptor?;
|
|
36
|
+
private clickContent?;
|
|
37
|
+
private longpressContent?;
|
|
38
|
+
private hoverContent?;
|
|
39
|
+
private targetContent?;
|
|
40
|
+
private overlaidContent?;
|
|
39
41
|
private _longpressId;
|
|
40
|
-
private
|
|
41
|
-
private handleTriggerContent;
|
|
42
|
-
private handleClickContent;
|
|
43
|
-
private handleLongpressContent;
|
|
44
|
-
private handleHoverContent;
|
|
45
|
-
private handleBeforetoggle;
|
|
46
|
-
protected update(changes: PropertyValues): void;
|
|
42
|
+
private handleClose;
|
|
47
43
|
protected render(): TemplateResult;
|
|
48
|
-
protected updated(changes: PropertyValues): void;
|
|
44
|
+
protected updated(changes: PropertyValues<this>): void;
|
|
45
|
+
protected manageLongpressDescriptor(): void;
|
|
46
|
+
private closeAllOverlays;
|
|
47
|
+
private manageOpen;
|
|
48
|
+
private openOverlay;
|
|
49
|
+
static openOverlay: (target: HTMLElement, interaction: TriggerInteractions, content: HTMLElement, options: OverlayOptions) => Promise<() => void>;
|
|
50
|
+
private get overlayOptions();
|
|
51
|
+
private onTrigger;
|
|
52
|
+
private prepareToFocusOverlayContent;
|
|
53
|
+
onTriggerClick(): Promise<void>;
|
|
54
|
+
private _longpressEvent?;
|
|
55
|
+
private onTriggerLongpress;
|
|
56
|
+
private abortOverlay;
|
|
57
|
+
onTriggerMouseEnter(): Promise<void>;
|
|
58
|
+
private onClickSlotChange;
|
|
59
|
+
private onLongpressSlotChange;
|
|
60
|
+
private onHoverSlotChange;
|
|
61
|
+
private onTargetSlotChange;
|
|
62
|
+
private extractSlotContentFromEvent;
|
|
63
|
+
private openStatePromise;
|
|
64
|
+
private openStateResolver;
|
|
49
65
|
protected getUpdateComplete(): Promise<boolean>;
|
|
66
|
+
disconnectedCallback(): void;
|
|
50
67
|
}
|
|
@@ -16,134 +16,69 @@ import {
|
|
|
16
16
|
} from "@spectrum-web-components/base";
|
|
17
17
|
import {
|
|
18
18
|
property,
|
|
19
|
-
query,
|
|
20
19
|
state
|
|
21
20
|
} from "@spectrum-web-components/base/src/decorators.js";
|
|
21
|
+
import { firstFocusableIn } from "@spectrum-web-components/shared/src/first-focusable-in.js";
|
|
22
|
+
import {
|
|
23
|
+
isAndroid,
|
|
24
|
+
isIOS
|
|
25
|
+
} from "@spectrum-web-components/shared/src/platform.js";
|
|
26
|
+
import { openOverlay } from "./loader.dev.js";
|
|
22
27
|
import overlayTriggerStyles from "./overlay-trigger.css.js";
|
|
23
|
-
|
|
24
|
-
|
|
28
|
+
export const LONGPRESS_INSTRUCTIONS = {
|
|
29
|
+
touch: "Double tap and long press for additional options",
|
|
30
|
+
keyboard: "Press Space or Alt+Down Arrow for additional options",
|
|
31
|
+
mouse: "Click and hold for additional options"
|
|
32
|
+
};
|
|
33
|
+
const _OverlayTrigger = class _OverlayTrigger extends SpectrumElement {
|
|
25
34
|
constructor() {
|
|
26
35
|
super(...arguments);
|
|
36
|
+
this.placement = "bottom";
|
|
27
37
|
this.offset = 6;
|
|
28
38
|
this.disabled = false;
|
|
29
|
-
this.
|
|
30
|
-
this.longpressContent = [];
|
|
31
|
-
this.hoverContent = [];
|
|
32
|
-
this.targetContent = [];
|
|
39
|
+
this.hasLongpressContent = false;
|
|
33
40
|
this._longpressId = `longpress-describedby-descriptor`;
|
|
41
|
+
this.abortOverlay = () => {
|
|
42
|
+
return;
|
|
43
|
+
};
|
|
44
|
+
this.openStatePromise = Promise.resolve();
|
|
34
45
|
}
|
|
35
46
|
static get styles() {
|
|
36
47
|
return [overlayTriggerStyles];
|
|
37
48
|
}
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
}
|
|
41
|
-
handleTriggerContent(event) {
|
|
42
|
-
this.targetContent = this.getAssignedElementsFromSlot(event.target);
|
|
43
|
-
}
|
|
44
|
-
handleClickContent(event) {
|
|
45
|
-
this.clickContent = this.getAssignedElementsFromSlot(event.target);
|
|
46
|
-
}
|
|
47
|
-
handleLongpressContent(event) {
|
|
48
|
-
this.longpressContent = this.getAssignedElementsFromSlot(event.target);
|
|
49
|
-
}
|
|
50
|
-
handleHoverContent(event) {
|
|
51
|
-
this.hoverContent = this.getAssignedElementsFromSlot(event.target);
|
|
52
|
-
}
|
|
53
|
-
handleBeforetoggle(event) {
|
|
54
|
-
const { target } = event;
|
|
55
|
-
let type;
|
|
56
|
-
if (target === this.clickOverlayElement) {
|
|
57
|
-
type = "click";
|
|
58
|
-
} else if (target === this.longpressOverlayElement) {
|
|
59
|
-
type = "longpress";
|
|
60
|
-
} else if (target === this.hoverOverlayElement) {
|
|
61
|
-
type = "hover";
|
|
62
|
-
} else {
|
|
49
|
+
handleClose(event) {
|
|
50
|
+
if (event && event.detail.interaction !== this.open && event.detail.interaction !== this.type) {
|
|
63
51
|
return;
|
|
64
52
|
}
|
|
65
|
-
|
|
66
|
-
this.open = type;
|
|
67
|
-
} else if (this.open === type) {
|
|
68
|
-
this.open = void 0;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
update(changes) {
|
|
72
|
-
var _a, _b, _c, _d, _e, _f;
|
|
73
|
-
if (changes.has("clickContent")) {
|
|
74
|
-
this.clickPlacement = ((_a = this.clickContent[0]) == null ? void 0 : _a.getAttribute("placement")) || ((_b = this.clickContent[0]) == null ? void 0 : _b.getAttribute(
|
|
75
|
-
"direction"
|
|
76
|
-
)) || void 0;
|
|
77
|
-
}
|
|
78
|
-
if (changes.has("hoverContent")) {
|
|
79
|
-
this.hoverPlacement = ((_c = this.hoverContent[0]) == null ? void 0 : _c.getAttribute("placement")) || ((_d = this.hoverContent[0]) == null ? void 0 : _d.getAttribute(
|
|
80
|
-
"direction"
|
|
81
|
-
)) || void 0;
|
|
82
|
-
}
|
|
83
|
-
if (changes.has("longpressContent")) {
|
|
84
|
-
this.longpressPlacement = ((_e = this.longpressContent[0]) == null ? void 0 : _e.getAttribute("placement")) || ((_f = this.longpressContent[0]) == null ? void 0 : _f.getAttribute(
|
|
85
|
-
"direction"
|
|
86
|
-
)) || void 0;
|
|
87
|
-
}
|
|
88
|
-
super.update(changes);
|
|
53
|
+
this.removeAttribute("open");
|
|
89
54
|
}
|
|
90
55
|
render() {
|
|
91
56
|
return html`
|
|
92
57
|
<slot
|
|
93
58
|
id="trigger"
|
|
59
|
+
@click=${this.onTrigger}
|
|
60
|
+
@longpress=${this.onTrigger}
|
|
61
|
+
@mouseenter=${this.onTrigger}
|
|
62
|
+
@mouseleave=${this.onTrigger}
|
|
63
|
+
@focusin=${this.onTrigger}
|
|
64
|
+
@focusout=${this.onTrigger}
|
|
65
|
+
@sp-closed=${this.handleClose}
|
|
66
|
+
@slotchange=${this.onTargetSlotChange}
|
|
94
67
|
name="trigger"
|
|
95
|
-
@slotchange=${this.handleTriggerContent}
|
|
96
68
|
></slot>
|
|
97
69
|
<div id="overlay-content">
|
|
98
|
-
<
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
@
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
name="click-content"
|
|
111
|
-
@slotchange=${this.handleClickContent}
|
|
112
|
-
></slot>
|
|
113
|
-
</sp-overlay>
|
|
114
|
-
<sp-overlay
|
|
115
|
-
id="longpress-overlay"
|
|
116
|
-
?disabled=${this.disabled || !this.longpressContent.length}
|
|
117
|
-
?open=${this.open === "longpress" && !!this.longpressContent.length}
|
|
118
|
-
.offset=${this.offset}
|
|
119
|
-
.placement=${this.longpressPlacement || this.placement}
|
|
120
|
-
.triggerElement=${this.targetContent[0]}
|
|
121
|
-
.triggerInteraction=${"longpress"}
|
|
122
|
-
.type=${"auto"}
|
|
123
|
-
@beforetoggle=${this.handleBeforetoggle}
|
|
124
|
-
>
|
|
125
|
-
<slot
|
|
126
|
-
name="longpress-content"
|
|
127
|
-
@slotchange=${this.handleLongpressContent}
|
|
128
|
-
></slot>
|
|
129
|
-
<slot name="longpress-describedby-descriptor"></slot>
|
|
130
|
-
</sp-overlay>
|
|
131
|
-
<sp-overlay
|
|
132
|
-
id="hover-overlay"
|
|
133
|
-
?disabled=${this.disabled || !this.hoverContent.length || !!this.open && this.open !== "hover"}
|
|
134
|
-
?open=${this.open === "hover" && !!this.hoverContent.length}
|
|
135
|
-
.offset=${this.offset}
|
|
136
|
-
.placement=${this.hoverPlacement || this.placement}
|
|
137
|
-
.triggerElement=${this.targetContent[0]}
|
|
138
|
-
.triggerInteraction=${"hover"}
|
|
139
|
-
.type=${"hint"}
|
|
140
|
-
@beforetoggle=${this.handleBeforetoggle}
|
|
141
|
-
>
|
|
142
|
-
<slot
|
|
143
|
-
name="hover-content"
|
|
144
|
-
@slotchange=${this.handleHoverContent}
|
|
145
|
-
></slot>
|
|
146
|
-
</sp-overlay>
|
|
70
|
+
<slot
|
|
71
|
+
@slotchange=${this.onClickSlotChange}
|
|
72
|
+
name="click-content"
|
|
73
|
+
></slot>
|
|
74
|
+
<slot
|
|
75
|
+
@slotchange=${this.onLongpressSlotChange}
|
|
76
|
+
name="longpress-content"
|
|
77
|
+
></slot>
|
|
78
|
+
<slot
|
|
79
|
+
@slotchange=${this.onHoverSlotChange}
|
|
80
|
+
name="hover-content"
|
|
81
|
+
></slot>
|
|
147
82
|
<slot name=${this._longpressId}></slot>
|
|
148
83
|
</div>
|
|
149
84
|
`;
|
|
@@ -151,49 +86,276 @@ export class OverlayTrigger extends SpectrumElement {
|
|
|
151
86
|
updated(changes) {
|
|
152
87
|
super.updated(changes);
|
|
153
88
|
if (this.disabled && changes.has("disabled")) {
|
|
154
|
-
this.
|
|
89
|
+
this.closeAllOverlays();
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
if (changes.has("open")) {
|
|
93
|
+
this.manageOpen();
|
|
94
|
+
}
|
|
95
|
+
if (changes.has("hasLongpressContent")) {
|
|
96
|
+
this.manageLongpressDescriptor();
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
manageLongpressDescriptor() {
|
|
100
|
+
const trigger = this.querySelector(
|
|
101
|
+
'[slot="trigger"]'
|
|
102
|
+
);
|
|
103
|
+
const ariaDescribedby = trigger.getAttribute("aria-describedby");
|
|
104
|
+
let descriptors = ariaDescribedby ? ariaDescribedby.split(/\s+/) : [];
|
|
105
|
+
if (this.hasLongpressContent) {
|
|
106
|
+
if (!this.longpressDescriptor) {
|
|
107
|
+
this.longpressDescriptor = document.createElement(
|
|
108
|
+
"div"
|
|
109
|
+
);
|
|
110
|
+
this.longpressDescriptor.id = this._longpressId;
|
|
111
|
+
this.longpressDescriptor.slot = this._longpressId;
|
|
112
|
+
}
|
|
113
|
+
const messageType = isIOS() || isAndroid() ? "touch" : "keyboard";
|
|
114
|
+
this.longpressDescriptor.textContent = LONGPRESS_INSTRUCTIONS[messageType];
|
|
115
|
+
this.appendChild(this.longpressDescriptor);
|
|
116
|
+
descriptors.push(this._longpressId);
|
|
117
|
+
} else {
|
|
118
|
+
if (this.longpressDescriptor)
|
|
119
|
+
this.longpressDescriptor.remove();
|
|
120
|
+
descriptors = descriptors.filter(
|
|
121
|
+
(descriptor) => descriptor !== this._longpressId
|
|
122
|
+
);
|
|
123
|
+
}
|
|
124
|
+
if (descriptors.length) {
|
|
125
|
+
trigger.setAttribute("aria-describedby", descriptors.join(" "));
|
|
126
|
+
} else {
|
|
127
|
+
trigger.removeAttribute("aria-describedby");
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
closeAllOverlays() {
|
|
131
|
+
if (this.abortOverlay)
|
|
132
|
+
this.abortOverlay(true);
|
|
133
|
+
[
|
|
134
|
+
"closeClickOverlay",
|
|
135
|
+
"closeHoverOverlay",
|
|
136
|
+
"closeLongpressOverlay"
|
|
137
|
+
].forEach(async (name) => {
|
|
138
|
+
const canClose = this[name];
|
|
139
|
+
if (canClose == null)
|
|
140
|
+
return;
|
|
141
|
+
delete this[name];
|
|
142
|
+
(await canClose)();
|
|
143
|
+
});
|
|
144
|
+
this.overlaidContent = void 0;
|
|
145
|
+
}
|
|
146
|
+
manageOpen() {
|
|
147
|
+
var _a;
|
|
148
|
+
const openHandlers = {
|
|
149
|
+
click: () => this.onTriggerClick(),
|
|
150
|
+
hover: () => this.onTriggerMouseEnter(),
|
|
151
|
+
longpress: () => this.onTriggerLongpress(),
|
|
152
|
+
none: () => this.closeAllOverlays()
|
|
153
|
+
};
|
|
154
|
+
openHandlers[(_a = this.open) != null ? _a : "none"]();
|
|
155
|
+
}
|
|
156
|
+
async openOverlay(target, interaction, content, options) {
|
|
157
|
+
this.openStatePromise = new Promise(
|
|
158
|
+
(res) => this.openStateResolver = res
|
|
159
|
+
);
|
|
160
|
+
this.addEventListener(
|
|
161
|
+
"sp-opened",
|
|
162
|
+
() => {
|
|
163
|
+
this.openStateResolver();
|
|
164
|
+
},
|
|
165
|
+
{ once: true }
|
|
166
|
+
);
|
|
167
|
+
this.overlaidContent = content;
|
|
168
|
+
return _OverlayTrigger.openOverlay(
|
|
169
|
+
target,
|
|
170
|
+
interaction,
|
|
171
|
+
content,
|
|
172
|
+
options
|
|
173
|
+
);
|
|
174
|
+
}
|
|
175
|
+
get overlayOptions() {
|
|
176
|
+
return {
|
|
177
|
+
offset: this.offset,
|
|
178
|
+
placement: this.placement,
|
|
179
|
+
receivesFocus: !this.type || this.type === "inline" || this.open === "hover" ? void 0 : "auto"
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
onTrigger(event) {
|
|
183
|
+
const mouseIsEnteringHoverContent = event.type === "mouseleave" && this.open === "hover" && event.relatedTarget === this.overlaidContent;
|
|
184
|
+
if (mouseIsEnteringHoverContent && this.overlaidContent) {
|
|
185
|
+
this.overlaidContent.addEventListener(
|
|
186
|
+
"mouseleave",
|
|
187
|
+
(event2) => {
|
|
188
|
+
const mouseIsEnteringTrigger = event2.relatedTarget === this.targetContent;
|
|
189
|
+
if (mouseIsEnteringTrigger) {
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
this.onTrigger(
|
|
193
|
+
event2
|
|
194
|
+
);
|
|
195
|
+
},
|
|
196
|
+
{ once: true }
|
|
197
|
+
);
|
|
198
|
+
return;
|
|
199
|
+
}
|
|
200
|
+
if (this.disabled)
|
|
201
|
+
return;
|
|
202
|
+
switch (event.type) {
|
|
203
|
+
case "mouseenter":
|
|
204
|
+
case "focusin":
|
|
205
|
+
if (!this.open && this.hoverContent) {
|
|
206
|
+
this.open = "hover";
|
|
207
|
+
}
|
|
208
|
+
return;
|
|
209
|
+
case "mouseleave":
|
|
210
|
+
case "focusout":
|
|
211
|
+
if (this.open === "hover") {
|
|
212
|
+
this.handleClose();
|
|
213
|
+
}
|
|
214
|
+
return;
|
|
215
|
+
case "click":
|
|
216
|
+
if (this.clickContent) {
|
|
217
|
+
this.open = event.type;
|
|
218
|
+
}
|
|
219
|
+
return;
|
|
220
|
+
case "longpress":
|
|
221
|
+
if (this.longpressContent) {
|
|
222
|
+
this._longpressEvent = event;
|
|
223
|
+
this.open = event.type;
|
|
224
|
+
}
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
prepareToFocusOverlayContent(overlayContent) {
|
|
229
|
+
if (this.type !== "modal") {
|
|
155
230
|
return;
|
|
156
231
|
}
|
|
232
|
+
const firstFocusable = firstFocusableIn(overlayContent);
|
|
233
|
+
if (!firstFocusable) {
|
|
234
|
+
overlayContent.tabIndex = 0;
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
async onTriggerClick() {
|
|
238
|
+
if (!this.targetContent || !this.clickContent || this.closeClickOverlay) {
|
|
239
|
+
return;
|
|
240
|
+
}
|
|
241
|
+
const { targetContent, clickContent } = this;
|
|
242
|
+
this.closeAllOverlays();
|
|
243
|
+
this.prepareToFocusOverlayContent(clickContent);
|
|
244
|
+
if (true) {
|
|
245
|
+
window.__swc.ignoreWarningLevels.deprecation = true;
|
|
246
|
+
}
|
|
247
|
+
this.closeClickOverlay = this.openOverlay(
|
|
248
|
+
targetContent,
|
|
249
|
+
this.type ? this.type : "click",
|
|
250
|
+
clickContent,
|
|
251
|
+
this.overlayOptions
|
|
252
|
+
);
|
|
253
|
+
if (true) {
|
|
254
|
+
window.__swc.ignoreWarningLevels.deprecation = false;
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
async onTriggerLongpress() {
|
|
258
|
+
var _a, _b;
|
|
259
|
+
if (!this.targetContent || !this.longpressContent || this.closeLongpressOverlay) {
|
|
260
|
+
return;
|
|
261
|
+
}
|
|
262
|
+
const { targetContent, longpressContent } = this;
|
|
263
|
+
this.closeAllOverlays();
|
|
264
|
+
this.prepareToFocusOverlayContent(longpressContent);
|
|
265
|
+
const notImmediatelyClosable = ((_b = (_a = this._longpressEvent) == null ? void 0 : _a.detail) == null ? void 0 : _b.source) !== "keyboard";
|
|
266
|
+
if (true) {
|
|
267
|
+
window.__swc.ignoreWarningLevels.deprecation = true;
|
|
268
|
+
}
|
|
269
|
+
this.closeLongpressOverlay = this.openOverlay(
|
|
270
|
+
targetContent,
|
|
271
|
+
this.type ? this.type : "longpress",
|
|
272
|
+
longpressContent,
|
|
273
|
+
{
|
|
274
|
+
...this.overlayOptions,
|
|
275
|
+
receivesFocus: "auto",
|
|
276
|
+
notImmediatelyClosable
|
|
277
|
+
}
|
|
278
|
+
);
|
|
279
|
+
if (true) {
|
|
280
|
+
window.__swc.ignoreWarningLevels.deprecation = false;
|
|
281
|
+
}
|
|
282
|
+
this._longpressEvent = void 0;
|
|
283
|
+
}
|
|
284
|
+
async onTriggerMouseEnter() {
|
|
285
|
+
if (!this.targetContent || !this.hoverContent || this.closeHoverOverlay) {
|
|
286
|
+
return;
|
|
287
|
+
}
|
|
288
|
+
const abortPromise = new Promise((res) => {
|
|
289
|
+
this.abortOverlay = res;
|
|
290
|
+
});
|
|
291
|
+
const { targetContent, hoverContent } = this;
|
|
292
|
+
if (true) {
|
|
293
|
+
window.__swc.ignoreWarningLevels.deprecation = true;
|
|
294
|
+
}
|
|
295
|
+
this.closeHoverOverlay = this.openOverlay(
|
|
296
|
+
targetContent,
|
|
297
|
+
"hover",
|
|
298
|
+
hoverContent,
|
|
299
|
+
{
|
|
300
|
+
abortPromise,
|
|
301
|
+
...this.overlayOptions
|
|
302
|
+
}
|
|
303
|
+
);
|
|
304
|
+
if (true) {
|
|
305
|
+
window.__swc.ignoreWarningLevels.deprecation = false;
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
onClickSlotChange(event) {
|
|
309
|
+
this.clickContent = this.extractSlotContentFromEvent(event);
|
|
310
|
+
this.manageOpen();
|
|
311
|
+
}
|
|
312
|
+
onLongpressSlotChange(event) {
|
|
313
|
+
this.longpressContent = this.extractSlotContentFromEvent(event);
|
|
314
|
+
this.hasLongpressContent = !!this.longpressContent || !!this.closeLongpressOverlay;
|
|
315
|
+
this.manageOpen();
|
|
316
|
+
}
|
|
317
|
+
onHoverSlotChange(event) {
|
|
318
|
+
this.hoverContent = this.extractSlotContentFromEvent(event);
|
|
319
|
+
this.manageOpen();
|
|
320
|
+
}
|
|
321
|
+
onTargetSlotChange(event) {
|
|
322
|
+
this.targetContent = this.extractSlotContentFromEvent(event);
|
|
323
|
+
}
|
|
324
|
+
extractSlotContentFromEvent(event) {
|
|
325
|
+
const slot = event.target;
|
|
326
|
+
const nodes = slot.assignedNodes({ flatten: true });
|
|
327
|
+
return nodes.find((node) => node instanceof HTMLElement);
|
|
157
328
|
}
|
|
158
329
|
async getUpdateComplete() {
|
|
159
330
|
const complete = await super.getUpdateComplete();
|
|
331
|
+
await this.openStatePromise;
|
|
160
332
|
return complete;
|
|
161
333
|
}
|
|
162
|
-
|
|
334
|
+
disconnectedCallback() {
|
|
335
|
+
this.closeAllOverlays();
|
|
336
|
+
super.disconnectedCallback();
|
|
337
|
+
}
|
|
338
|
+
};
|
|
339
|
+
_OverlayTrigger.openOverlay = async (target, interaction, content, options) => {
|
|
340
|
+
return openOverlay(target, interaction, content, options);
|
|
341
|
+
};
|
|
163
342
|
__decorateClass([
|
|
164
343
|
property({ reflect: true })
|
|
165
|
-
],
|
|
344
|
+
], _OverlayTrigger.prototype, "placement", 2);
|
|
166
345
|
__decorateClass([
|
|
167
346
|
property()
|
|
168
|
-
],
|
|
347
|
+
], _OverlayTrigger.prototype, "type", 2);
|
|
169
348
|
__decorateClass([
|
|
170
|
-
property({ type: Number })
|
|
171
|
-
],
|
|
349
|
+
property({ type: Number, reflect: true })
|
|
350
|
+
], _OverlayTrigger.prototype, "offset", 2);
|
|
172
351
|
__decorateClass([
|
|
173
352
|
property({ reflect: true })
|
|
174
|
-
],
|
|
353
|
+
], _OverlayTrigger.prototype, "open", 2);
|
|
175
354
|
__decorateClass([
|
|
176
355
|
property({ type: Boolean, reflect: true })
|
|
177
|
-
],
|
|
178
|
-
__decorateClass([
|
|
179
|
-
state()
|
|
180
|
-
], OverlayTrigger.prototype, "clickContent", 2);
|
|
181
|
-
__decorateClass([
|
|
182
|
-
state()
|
|
183
|
-
], OverlayTrigger.prototype, "longpressContent", 2);
|
|
184
|
-
__decorateClass([
|
|
185
|
-
state()
|
|
186
|
-
], OverlayTrigger.prototype, "hoverContent", 2);
|
|
356
|
+
], _OverlayTrigger.prototype, "disabled", 2);
|
|
187
357
|
__decorateClass([
|
|
188
358
|
state()
|
|
189
|
-
],
|
|
190
|
-
|
|
191
|
-
query("#click-overlay", true)
|
|
192
|
-
], OverlayTrigger.prototype, "clickOverlayElement", 2);
|
|
193
|
-
__decorateClass([
|
|
194
|
-
query("#longpress-overlay", true)
|
|
195
|
-
], OverlayTrigger.prototype, "longpressOverlayElement", 2);
|
|
196
|
-
__decorateClass([
|
|
197
|
-
query("#hover-overlay", true)
|
|
198
|
-
], OverlayTrigger.prototype, "hoverOverlayElement", 2);
|
|
359
|
+
], _OverlayTrigger.prototype, "hasLongpressContent", 2);
|
|
360
|
+
export let OverlayTrigger = _OverlayTrigger;
|
|
199
361
|
//# sourceMappingURL=OverlayTrigger.dev.js.map
|