@spectrum-web-components/overlay 0.31.1-react.3 → 0.32.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/custom-elements.json +25 -13
- package/package.json +6 -6
- package/src/overlay-stack.dev.js +3 -2
- package/src/overlay-stack.dev.js.map +2 -2
- package/src/overlay-stack.js +5 -4
- package/src/overlay-stack.js.map +2 -2
- package/stories/overlay-story-components.js +18 -15
- package/stories/overlay-story-components.js.map +2 -2
- package/stories/overlay.stories.js +217 -194
- package/stories/overlay.stories.js.map +2 -2
- package/test/index.js +53 -39
- package/test/index.js.map +2 -2
- package/test/overlay-trigger-extended.test.js +3 -2
- package/test/overlay-trigger-extended.test.js.map +2 -2
- package/test/overlay.test.js +2 -3
- package/test/overlay.test.js.map +2 -2
package/test/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["index.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 { escapeEvent, isVisible } from '../../../test/testing-helpers.js';\nimport {\n aTimeout,\n elementUpdated,\n expect,\n fixture,\n html,\n nextFrame,\n oneEvent,\n waitUntil,\n} from '@open-wc/testing';\n\nimport {\n ActiveOverlay,\n OverlayTrigger,\n TriggerInteractions,\n} from '@spectrum-web-components/overlay';\nimport '@spectrum-web-components/button/sp-button.js';\nimport { Button } from '@spectrum-web-components/button';\nimport '@spectrum-web-components/popover/sp-popover.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport '@spectrum-web-components/theme/sp-theme.js';\nimport { Theme } from '@spectrum-web-components/theme';\n\nfunction pressKey(code: string): void {\n const up = new KeyboardEvent('keyup', {\n bubbles: true,\n cancelable: true,\n key: code,\n code,\n });\n document.dispatchEvent(up);\n}\n\nconst pressEscape = (): void => {\n document.dispatchEvent(escapeEvent());\n};\n\nconst pressSpace = (): void => pressKey('Space');\n\nexport const runOverlayTriggerTests = (): void => {\n describe('Overlay Trigger - sync', () => {\n describe('open/close', () => {\n let testDiv!: HTMLDivElement;\n let innerTrigger!: OverlayTrigger;\n let outerTrigger!: OverlayTrigger;\n let innerButton!: Button;\n let outerButton!: Button;\n let innerClickContent!: Popover;\n let outerClickContent!: Popover;\n let hoverContent!: HTMLDivElement;\n\n beforeEach(async () => {\n testDiv = await fixture<HTMLDivElement>(\n html`\n <div>\n <style>\n body {\n display: flex;\n align-items: center;\n justify-content: center;\n }\n </style>\n <overlay-trigger id=\"trigger\" placement=\"top\">\n <sp-button\n id=\"outer-button\"\n variant=\"primary\"\n slot=\"trigger\"\n >\n Show Popover\n </sp-button>\n <sp-popover\n id=\"outer-popover\"\n dialog\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n tabindex=\"0\"\n >\n <div class=\"options-popover-content\">\n <overlay-trigger\n id=\"inner-trigger\"\n placement=\"bottom\"\n >\n <sp-button\n id=\"inner-button\"\n slot=\"trigger\"\n >\n Press Me\n </sp-button>\n <sp-popover\n id=\"inner-popover\"\n dialog\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n tabindex=\"0\"\n >\n <div\n class=\"options-popover-content\"\n >\n Another Popover\n </div>\n </sp-popover>\n </overlay-trigger>\n </div>\n </sp-popover>\n <div\n id=\"hover-content\"\n slot=\"hover-content\"\n class=\"tooltip\"\n delay=\"100\"\n >\n Tooltip\n </div>\n </overlay-trigger>\n </div>\n `\n );\n\n innerTrigger = testDiv.querySelector(\n '#inner-trigger'\n ) as OverlayTrigger;\n outerTrigger = testDiv.querySelector(\n '#trigger'\n ) as OverlayTrigger;\n innerButton = testDiv.querySelector('#inner-button') as Button;\n outerButton = testDiv.querySelector('#outer-button') as Button;\n innerClickContent = testDiv.querySelector(\n '#inner-popover'\n ) as Popover;\n outerClickContent = testDiv.querySelector(\n '#outer-popover'\n ) as Popover;\n hoverContent = testDiv.querySelector(\n '#hover-content'\n ) as HTMLDivElement;\n });\n\n afterEach(async () => {\n if (outerTrigger.open) {\n const closed = oneEvent(outerTrigger, 'sp-closed');\n outerTrigger.open = undefined;\n await closed;\n }\n outerTrigger.removeAttribute('type');\n if (innerTrigger.open) {\n const closed = oneEvent(innerTrigger, 'sp-closed');\n innerTrigger.open = undefined;\n await closed;\n }\n innerTrigger.removeAttribute('type');\n });\n\n it('loads', async () => {\n if (!(outerClickContent instanceof Popover))\n throw new Error('popover is not an instance of Popover');\n\n expect(outerClickContent).to.exist;\n expect(outerClickContent.shadowRoot).to.exist;\n expect(outerClickContent.parentElement).to.be.an.instanceOf(\n OverlayTrigger\n );\n });\n\n it('opens a popover', async () => {\n expect(isVisible(outerClickContent)).to.be.false;\n\n expect(outerButton).to.exist;\n const open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n });\n\n it('[disabled] closes a popover', async () => {\n expect(isVisible(outerClickContent)).to.be.false;\n expect(outerTrigger.disabled).to.be.false;\n\n expect(outerButton).to.exist;\n\n const opened = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n await opened;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n\n const closed = oneEvent(outerButton, 'sp-closed');\n outerTrigger.disabled = true;\n await closed;\n\n expect(isVisible(outerClickContent)).to.be.false;\n expect(outerTrigger.disabled).to.be.true;\n });\n\n it('resizes a popover', async () => {\n expect(isVisible(outerClickContent)).to.be.false;\n\n expect(outerButton).to.exist;\n const open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n\n window.dispatchEvent(new Event('resize'));\n window.dispatchEvent(new Event('resize'));\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n });\n\n ['modal', 'replace', 'inline'].map((type: string) => {\n it(`opens a popover - [type=\"${type}\"]`, async () => {\n outerTrigger.type = type as Extract<\n TriggerInteractions,\n 'inline' | 'modal' | 'replace'\n >;\n await elementUpdated(outerTrigger);\n\n expect(isVisible(outerClickContent)).to.be.false;\n\n expect(outerButton).to.exist;\n const opened = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await opened;\n\n expect(\n outerClickContent.parentElement\n ).to.not.be.an.instanceOf(OverlayTrigger);\n expect(isVisible(outerClickContent)).to.be.true;\n });\n });\n\n it('does not open a hover popover when a click popover is open', async () => {\n expect(\n isVisible(outerClickContent),\n 'outer popover not visible'\n ).to.be.false;\n expect(isVisible(hoverContent), 'hover popover not visible').to\n .be.false;\n\n expect(outerButton).to.exist;\n const open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent), 'outer popover visible').to\n .be.true;\n expect(\n isVisible(hoverContent),\n 'hover popover still not visible'\n ).to.be.false;\n\n outerButton.dispatchEvent(\n new Event('mouseenter', {\n bubbles: true,\n composed: true,\n })\n );\n\n await nextFrame();\n expect(hoverContent.parentElement).to.be.instanceOf(\n OverlayTrigger\n );\n\n expect(\n isVisible(outerClickContent),\n 'outer popover visible again'\n ).to.be.true;\n expect(\n isVisible(hoverContent),\n 'hover popover not visible again'\n ).to.be.false;\n });\n\n it('does not open a popover when [disabled]', async () => {\n const root = outerTrigger.shadowRoot\n ? outerTrigger.shadowRoot\n : outerTrigger;\n const triggerZone = root.querySelector(\n '#trigger'\n ) as HTMLDivElement;\n\n expect(outerTrigger.disabled).to.be.false;\n let open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'active-overlay'\n );\n let closed = oneEvent(outerTrigger, 'sp-closed');\n document.body.click();\n await closed;\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'overlay-trigger'\n );\n\n outerTrigger.disabled = true;\n await elementUpdated(outerTrigger);\n\n expect(outerTrigger.disabled).to.be.true;\n expect(outerTrigger.hasAttribute('disabled')).to.be.true;\n // The overlay shouldn't open here.\n outerButton.click();\n await aTimeout(200);\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'overlay-trigger'\n );\n // The overlay shouldn't open here, either.\n triggerZone.dispatchEvent(new Event('mouseenter'));\n await aTimeout(200);\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'overlay-trigger'\n );\n\n outerTrigger.disabled = false;\n await elementUpdated(outerTrigger);\n\n expect(outerTrigger.disabled).to.be.false;\n expect(outerTrigger.hasAttribute('disabled')).to.be.false;\n open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'active-overlay'\n );\n closed = oneEvent(outerTrigger, 'sp-closed');\n outerButton.click();\n await closed;\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'overlay-trigger'\n );\n });\n\n it('opens a nested popover', async () => {\n expect(isVisible(outerClickContent)).to.be.false;\n expect(isVisible(innerClickContent)).to.be.false;\n\n expect(outerButton).to.exist;\n let open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.false;\n\n open = oneEvent(innerTrigger, 'sp-opened');\n innerButton.click();\n await open;\n expect(innerClickContent.parentElement).to.not.be.instanceOf(\n OverlayTrigger\n );\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n });\n\n it('focus previous \"modal\" when closing nested \"modal\"', async () => {\n outerTrigger.type = 'modal';\n innerTrigger.type = 'modal';\n\n expect(\n isVisible(outerClickContent),\n 'outer popover starts closed'\n ).to.be.false;\n expect(\n isVisible(innerClickContent),\n 'inner popover starts closed'\n ).to.be.false;\n\n expect(outerButton).to.exist;\n const outerOpen = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n await outerOpen;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent), 'outer popover opens').to\n .be.true;\n expect(\n isVisible(innerClickContent),\n 'inner popover stays closed'\n ).to.be.false;\n\n const innerOpen = oneEvent(innerButton, 'sp-opened');\n innerButton.click();\n await innerOpen;\n expect(innerClickContent.parentElement).to.not.be.instanceOf(\n OverlayTrigger\n );\n\n expect(isVisible(outerClickContent), 'outer popover stays open')\n .to.be.true;\n expect(isVisible(innerClickContent), 'inner popover opens').to\n .be.true;\n\n const innerClose = oneEvent(innerButton, 'sp-closed');\n pressEscape();\n await innerClose;\n expect(innerClickContent.parentElement).to.be.instanceOf(\n OverlayTrigger\n );\n\n expect(\n document.activeElement === innerButton,\n 'outer popover recieved focus'\n ).to.be.true;\n });\n\n it('escape closes an open popover', async () => {\n outerTrigger.type = 'modal';\n innerTrigger.type = 'modal';\n const outerOpen = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n await outerOpen;\n\n expect(\n outerClickContent.parentElement instanceof OverlayTrigger,\n 'outer content stolen and reparented'\n ).to.be.false;\n\n const innerOpen = oneEvent(innerButton, 'sp-opened');\n innerButton.click();\n await innerOpen;\n\n expect(\n innerClickContent.parentElement instanceof OverlayTrigger,\n 'inner content stolen and reparented'\n ).to.be.false;\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n\n pressSpace();\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n\n const innerClose = oneEvent(innerButton, 'sp-closed');\n pressEscape();\n await innerClose;\n\n expect(\n innerClickContent.parentElement instanceof OverlayTrigger,\n 'inner content returned'\n ).to.be.true;\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.false;\n\n const outerClose = oneEvent(outerButton, 'sp-closed');\n pressEscape();\n await outerClose;\n\n expect(\n outerClickContent.parentElement instanceof OverlayTrigger,\n 'outer content returned'\n ).to.be.true;\n expect(isVisible(outerClickContent)).to.be.false;\n expect(isVisible(innerClickContent)).to.be.false;\n });\n\n it('click closes an open popover', async () => {\n outerTrigger.type = 'modal';\n innerTrigger.type = 'modal';\n const outerOpen = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n await outerOpen;\n\n expect(\n outerClickContent.parentElement instanceof OverlayTrigger,\n 'outer content stolen and reparented'\n ).to.be.false;\n\n const innerOpen = oneEvent(innerButton, 'sp-opened');\n innerButton.click();\n await innerOpen;\n\n expect(\n innerClickContent.parentElement instanceof OverlayTrigger,\n 'inner content stolen and reparented'\n ).to.be.false;\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n\n // Test that clicking in the overlay content does not close the overlay\n // 200ms is slightly more than the overlay animation fade out time (130ms)\n innerClickContent.click();\n await aTimeout(200);\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n\n const innerClose = oneEvent(innerButton, 'sp-closed');\n document.body.click();\n await innerClose;\n\n expect(\n innerClickContent.parentElement instanceof OverlayTrigger,\n 'inner content returned'\n ).to.be.true;\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.false;\n\n const outerClose = oneEvent(outerButton, 'sp-closed');\n document.body.click();\n await outerClose;\n\n expect(\n outerClickContent.parentElement instanceof OverlayTrigger,\n 'outer content returned'\n ).to.be.true;\n expect(isVisible(outerClickContent)).to.be.false;\n expect(isVisible(innerClickContent)).to.be.false;\n });\n\n it('opens a hover popover', async () => {\n const root = outerTrigger.shadowRoot\n ? outerTrigger.shadowRoot\n : outerTrigger;\n const triggerZone = root.querySelector(\n '#trigger'\n ) as HTMLDivElement;\n\n expect(triggerZone).to.exist;\n if (!triggerZone) return;\n\n expect(outerButton).to.exist;\n expect(hoverContent).to.exist;\n\n expect(isVisible(hoverContent)).to.be.false;\n\n const open = oneEvent(outerTrigger, 'sp-opened');\n const mouseEnter = new MouseEvent('mouseenter');\n triggerZone.dispatchEvent(mouseEnter);\n await open;\n expect(hoverContent.parentElement).to.not.be.instanceOf(\n OverlayTrigger\n );\n\n expect(isVisible(hoverContent)).to.be.true;\n\n const close = oneEvent(outerTrigger, 'sp-closed');\n const mouseLeave = new MouseEvent('mouseleave');\n triggerZone.dispatchEvent(mouseLeave);\n await close;\n expect(hoverContent.parentElement).to.be.instanceOf(\n OverlayTrigger\n );\n\n expect(isVisible(hoverContent)).to.be.false;\n });\n\n it('closes a hover popover', async () => {\n const root = outerTrigger.shadowRoot\n ? outerTrigger.shadowRoot\n : outerTrigger;\n const triggerZone = root.querySelector(\n '#trigger'\n ) as HTMLDivElement;\n\n expect(triggerZone).to.exist;\n if (!triggerZone) return;\n\n expect(outerButton).to.exist;\n expect(hoverContent).to.exist;\n\n expect(\n isVisible(hoverContent),\n 'hoverContent should not be visible'\n ).to.be.false;\n\n const mouseEnter = new MouseEvent('mouseenter');\n const mouseLeave = new MouseEvent('mouseleave');\n triggerZone.dispatchEvent(mouseEnter);\n await nextFrame();\n triggerZone.dispatchEvent(mouseLeave);\n\n await waitUntil(\n () => isVisible(hoverContent) === false,\n 'hoverContent should still not be visible'\n );\n });\n\n it('dispatches events on open/close', async () => {\n const opened = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n const openedEvent = await opened;\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(outerTrigger.open).to.equal('click');\n\n expect(openedEvent.detail.interaction).to.equal('click');\n\n const closed = oneEvent(outerButton, 'sp-closed');\n document.body.click();\n const closedEvent = await closed;\n expect(outerClickContent.parentElement).to.be.instanceOf(\n OverlayTrigger\n );\n expect(closedEvent.detail.interaction).to.equal('click');\n\n expect(isVisible(outerClickContent)).to.be.false;\n });\n });\n describe('System interactions', () => {\n afterEach(async () => {\n const triggers = document.querySelectorAll('overlay-trigger');\n const closes: Promise<CustomEvent<unknown>>[] = [];\n triggers.forEach((trigger) => {\n if (trigger.open) {\n const close = oneEvent(trigger, 'sp-closed');\n trigger.open = undefined;\n closes.push(close);\n }\n });\n await Promise.all(closes);\n });\n it('acquires a `color` and `size` from `sp-theme`', async () => {\n const el = await fixture<Theme>(html`\n <sp-theme color=\"dark\">\n <sp-theme color=\"light\">\n <overlay-trigger id=\"trigger\" placement=\"top\">\n <sp-button\n id=\"outer-button\"\n variant=\"primary\"\n slot=\"trigger\"\n >\n Show Popover\n </sp-button>\n <sp-popover\n id=\"outer-popover\"\n dialog\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n >\n Popover content!\n </sp-popover>\n </overlay-trigger>\n </sp-theme>\n </sp-theme>\n `);\n\n await elementUpdated(el);\n\n expect(document.querySelector('active-overlay')).to.be.null;\n\n const button = el.querySelector('sp-button') as Button;\n const opened = oneEvent(button, 'sp-opened');\n button.click();\n await opened;\n\n await elementUpdated(el);\n\n const overlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n\n expect(overlay).to.exist;\n expect(overlay.theme.color).to.not.equal('dark');\n expect(overlay.theme.color).to.equal('light');\n });\n it('manages multiple layers of `type=\"modal\"', async () => {\n const el = await fixture(html`\n <overlay-trigger type=\"modal\" placement=\"none\">\n <sp-button slot=\"trigger\" variant=\"accent\">\n Toggle Dialog\n </sp-button>\n <sp-popover dialog slot=\"click-content\">\n <overlay-trigger>\n <sp-button slot=\"trigger\" variant=\"primary\">\n Toggle Dialog\n </sp-button>\n <sp-popover dialog slot=\"click-content\">\n <overlay-trigger type=\"modal\">\n <sp-button\n slot=\"trigger\"\n variant=\"secondary\"\n >\n Toggle Dialog\n </sp-button>\n <sp-popover dialog slot=\"click-content\">\n <p>\n When you get this deep, this\n ActiveOverlay should be the only\n one in [slot=\"open\"].\n </p>\n <p>\n All of the rest of the\n ActiveOverlay elements should\n have had their [slot] attribute\n removed.\n </p>\n <p>\n Closing this ActiveOverlay\n should replace them...\n </p>\n </sp-popover>\n </overlay-trigger>\n </sp-popover>\n </overlay-trigger>\n </sp-popover>\n </overlay-trigger>\n `);\n const overlayTriggers = [\n ...el.querySelectorAll('overlay-trigger'),\n ];\n let activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n const triggers = [\n ...el.querySelectorAll('sp-button[slot=\"trigger\"]'),\n ] as Button[];\n\n expect(activeOverlays.length, 'no previous overlays').to.equal(\n 0\n );\n\n let open = oneEvent(triggers[0], 'sp-opened');\n triggers[0]?.click();\n await open;\n await elementUpdated(overlayTriggers[0]);\n activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n expect(\n activeOverlays.length,\n 'The first `active-overlay` element has been added.'\n ).to.equal(1);\n expect(\n activeOverlays[0].slot,\n 'first overlay, first time'\n ).to.equal('open');\n\n open = oneEvent(triggers[1], 'sp-opened');\n triggers[1]?.click();\n await open;\n await elementUpdated(overlayTriggers[1]);\n activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n expect(\n activeOverlays.length,\n 'The second `active-overlay` element has been added.'\n ).to.equal(2);\n\n expect(\n activeOverlays[0].slot,\n 'first overlay, second time'\n ).to.equal('open');\n expect(\n activeOverlays[1].slot,\n 'second overlay, second time'\n ).to.equal('open');\n\n open = oneEvent(triggers[2], 'sp-opened');\n triggers[2]?.click();\n await open;\n await elementUpdated(overlayTriggers[2]);\n activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n expect(\n activeOverlays.length,\n 'The third `active-overlay` element has been added.'\n ).to.equal(3);\n\n expect(\n activeOverlays[0].hasAttribute('slot'),\n 'first overlay, third time'\n ).to.be.false;\n expect(\n activeOverlays[1].hasAttribute('slot'),\n 'second overlay, third time'\n ).to.be.false;\n expect(\n activeOverlays[2].slot,\n 'third overlay, third time'\n ).to.equal('open');\n\n await nextFrame();\n const closed = oneEvent(triggers[2], 'sp-closed');\n document.body.click();\n await closed;\n await elementUpdated(overlayTriggers[2]);\n activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n expect(\n activeOverlays.length,\n 'The third `active-overlay` element has been removed.'\n ).to.equal(2);\n\n await waitUntil(() => {\n return activeOverlays[0].slot === 'open';\n }, 'first overlay, last time');\n expect(\n activeOverlays[1].slot,\n 'second overlay, last time'\n ).to.equal('open');\n });\n });\n });\n};\n"],
|
|
5
|
-
"mappings": "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",
|
|
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 { escapeEvent, isVisible } from '../../../test/testing-helpers.js';\nimport {\n aTimeout,\n elementUpdated,\n expect,\n fixture,\n html,\n nextFrame,\n oneEvent,\n waitUntil,\n} from '@open-wc/testing';\n\nimport {\n ActiveOverlay,\n OverlayTrigger,\n TriggerInteractions,\n} from '@spectrum-web-components/overlay';\nimport '@spectrum-web-components/button/sp-button.js';\nimport { Button } from '@spectrum-web-components/button';\nimport '@spectrum-web-components/popover/sp-popover.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport '@spectrum-web-components/theme/sp-theme.js';\nimport { Theme } from '@spectrum-web-components/theme';\n\nfunction pressKey(code: string): void {\n const up = new KeyboardEvent('keyup', {\n bubbles: true,\n cancelable: true,\n key: code,\n code,\n });\n document.dispatchEvent(up);\n}\n\nconst pressEscape = (): void => {\n document.dispatchEvent(escapeEvent());\n};\n\nconst pressSpace = (): void => pressKey('Space');\n\nexport const runOverlayTriggerTests = (): void => {\n describe('Overlay Trigger - sync', () => {\n describe('open/close', () => {\n let testDiv!: HTMLDivElement;\n let innerTrigger!: OverlayTrigger;\n let outerTrigger!: OverlayTrigger;\n let innerButton!: Button;\n let outerButton!: Button;\n let innerClickContent!: Popover;\n let outerClickContent!: Popover;\n let hoverContent!: HTMLDivElement;\n\n beforeEach(async () => {\n testDiv = await fixture<HTMLDivElement>(\n html`\n <div>\n <style>\n body {\n display: flex;\n align-items: center;\n justify-content: center;\n }\n </style>\n <overlay-trigger id=\"trigger\" placement=\"top\">\n <sp-button\n id=\"outer-button\"\n variant=\"primary\"\n slot=\"trigger\"\n >\n Show Popover\n </sp-button>\n <sp-popover\n id=\"outer-popover\"\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n tabindex=\"0\"\n >\n <sp-dialog\n no-divider\n class=\"options-popover-content\"\n >\n <overlay-trigger\n id=\"inner-trigger\"\n placement=\"bottom\"\n >\n <sp-button\n id=\"inner-button\"\n slot=\"trigger\"\n >\n Press Me\n </sp-button>\n <sp-popover\n id=\"inner-popover\"\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n tabindex=\"0\"\n >\n <sp-dialog\n no-divider\n class=\"options-popover-content\"\n >\n Another Popover\n </sp-dialog>\n </sp-popover>\n </overlay-trigger>\n </sp-dialog>\n </sp-popover>\n <div\n id=\"hover-content\"\n slot=\"hover-content\"\n class=\"tooltip\"\n delay=\"100\"\n >\n Tooltip\n </div>\n </overlay-trigger>\n </div>\n `\n );\n\n innerTrigger = testDiv.querySelector(\n '#inner-trigger'\n ) as OverlayTrigger;\n outerTrigger = testDiv.querySelector(\n '#trigger'\n ) as OverlayTrigger;\n innerButton = testDiv.querySelector('#inner-button') as Button;\n outerButton = testDiv.querySelector('#outer-button') as Button;\n innerClickContent = testDiv.querySelector(\n '#inner-popover'\n ) as Popover;\n outerClickContent = testDiv.querySelector(\n '#outer-popover'\n ) as Popover;\n hoverContent = testDiv.querySelector(\n '#hover-content'\n ) as HTMLDivElement;\n });\n\n afterEach(async () => {\n if (outerTrigger.open) {\n const closed = oneEvent(outerTrigger, 'sp-closed');\n outerTrigger.open = undefined;\n await closed;\n }\n outerTrigger.removeAttribute('type');\n if (innerTrigger.open) {\n const closed = oneEvent(innerTrigger, 'sp-closed');\n innerTrigger.open = undefined;\n await closed;\n }\n innerTrigger.removeAttribute('type');\n });\n\n it('loads', async () => {\n if (!(outerClickContent instanceof Popover))\n throw new Error('popover is not an instance of Popover');\n\n expect(outerClickContent).to.exist;\n expect(outerClickContent.shadowRoot).to.exist;\n expect(outerClickContent.parentElement).to.be.an.instanceOf(\n OverlayTrigger\n );\n });\n\n it('opens a popover', async () => {\n expect(isVisible(outerClickContent)).to.be.false;\n\n expect(outerButton).to.exist;\n const open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n });\n\n it('[disabled] closes a popover', async () => {\n expect(isVisible(outerClickContent)).to.be.false;\n expect(outerTrigger.disabled).to.be.false;\n\n expect(outerButton).to.exist;\n\n const opened = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n await opened;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n\n const closed = oneEvent(outerButton, 'sp-closed');\n outerTrigger.disabled = true;\n await closed;\n\n expect(isVisible(outerClickContent)).to.be.false;\n expect(outerTrigger.disabled).to.be.true;\n });\n\n it('resizes a popover', async () => {\n expect(isVisible(outerClickContent)).to.be.false;\n\n expect(outerButton).to.exist;\n const open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n\n window.dispatchEvent(new Event('resize'));\n window.dispatchEvent(new Event('resize'));\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n });\n\n ['modal', 'replace', 'inline'].map((type: string) => {\n it(`opens a popover - [type=\"${type}\"]`, async () => {\n outerTrigger.type = type as Extract<\n TriggerInteractions,\n 'inline' | 'modal' | 'replace'\n >;\n await elementUpdated(outerTrigger);\n\n expect(isVisible(outerClickContent)).to.be.false;\n\n expect(outerButton).to.exist;\n const opened = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await opened;\n\n expect(\n outerClickContent.parentElement\n ).to.not.be.an.instanceOf(OverlayTrigger);\n expect(isVisible(outerClickContent)).to.be.true;\n });\n });\n\n it('does not open a hover popover when a click popover is open', async () => {\n expect(\n isVisible(outerClickContent),\n 'outer popover not visible'\n ).to.be.false;\n expect(isVisible(hoverContent), 'hover popover not visible').to\n .be.false;\n\n expect(outerButton).to.exist;\n const open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent), 'outer popover visible').to\n .be.true;\n expect(\n isVisible(hoverContent),\n 'hover popover still not visible'\n ).to.be.false;\n\n outerButton.dispatchEvent(\n new Event('mouseenter', {\n bubbles: true,\n composed: true,\n })\n );\n\n await nextFrame();\n expect(hoverContent.parentElement).to.be.instanceOf(\n OverlayTrigger\n );\n\n expect(\n isVisible(outerClickContent),\n 'outer popover visible again'\n ).to.be.true;\n expect(\n isVisible(hoverContent),\n 'hover popover not visible again'\n ).to.be.false;\n });\n\n it('does not open a popover when [disabled]', async () => {\n const root = outerTrigger.shadowRoot\n ? outerTrigger.shadowRoot\n : outerTrigger;\n const triggerZone = root.querySelector(\n '#trigger'\n ) as HTMLDivElement;\n\n expect(outerTrigger.disabled).to.be.false;\n let open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'active-overlay'\n );\n let closed = oneEvent(outerTrigger, 'sp-closed');\n document.body.click();\n await closed;\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'overlay-trigger'\n );\n\n outerTrigger.disabled = true;\n await elementUpdated(outerTrigger);\n\n expect(outerTrigger.disabled).to.be.true;\n expect(outerTrigger.hasAttribute('disabled')).to.be.true;\n // The overlay shouldn't open here.\n outerButton.click();\n await aTimeout(200);\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'overlay-trigger'\n );\n // The overlay shouldn't open here, either.\n triggerZone.dispatchEvent(new Event('mouseenter'));\n await aTimeout(200);\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'overlay-trigger'\n );\n\n outerTrigger.disabled = false;\n await elementUpdated(outerTrigger);\n\n expect(outerTrigger.disabled).to.be.false;\n expect(outerTrigger.hasAttribute('disabled')).to.be.false;\n open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'active-overlay'\n );\n closed = oneEvent(outerTrigger, 'sp-closed');\n outerButton.click();\n await closed;\n expect(outerClickContent.parentElement?.localName).to.equal(\n 'overlay-trigger'\n );\n });\n\n it('opens a nested popover', async () => {\n expect(isVisible(outerClickContent)).to.be.false;\n expect(isVisible(innerClickContent)).to.be.false;\n\n expect(outerButton).to.exist;\n let open = oneEvent(outerTrigger, 'sp-opened');\n outerButton.click();\n await open;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.false;\n\n open = oneEvent(innerTrigger, 'sp-opened');\n innerButton.click();\n await open;\n expect(innerClickContent.parentElement).to.not.be.instanceOf(\n OverlayTrigger\n );\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n });\n\n it('focus previous \"modal\" when closing nested \"modal\"', async () => {\n outerTrigger.type = 'modal';\n innerTrigger.type = 'modal';\n\n expect(\n isVisible(outerClickContent),\n 'outer popover starts closed'\n ).to.be.false;\n expect(\n isVisible(innerClickContent),\n 'inner popover starts closed'\n ).to.be.false;\n\n expect(outerButton).to.exist;\n const outerOpen = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n await outerOpen;\n\n expect(outerClickContent.parentElement).to.not.be.an.instanceOf(\n OverlayTrigger\n );\n expect(isVisible(outerClickContent), 'outer popover opens').to\n .be.true;\n expect(\n isVisible(innerClickContent),\n 'inner popover stays closed'\n ).to.be.false;\n\n const innerOpen = oneEvent(innerButton, 'sp-opened');\n innerButton.click();\n await innerOpen;\n expect(innerClickContent.parentElement).to.not.be.instanceOf(\n OverlayTrigger\n );\n\n expect(isVisible(outerClickContent), 'outer popover stays open')\n .to.be.true;\n expect(isVisible(innerClickContent), 'inner popover opens').to\n .be.true;\n\n const innerClose = oneEvent(innerButton, 'sp-closed');\n pressEscape();\n await innerClose;\n expect(innerClickContent.parentElement).to.be.instanceOf(\n OverlayTrigger\n );\n\n expect(\n document.activeElement === innerButton,\n 'outer popover recieved focus'\n ).to.be.true;\n });\n\n it('escape closes an open popover', async () => {\n outerTrigger.type = 'modal';\n innerTrigger.type = 'modal';\n const outerOpen = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n await outerOpen;\n\n expect(\n outerClickContent.parentElement instanceof OverlayTrigger,\n 'outer content stolen and reparented'\n ).to.be.false;\n\n const innerOpen = oneEvent(innerButton, 'sp-opened');\n innerButton.click();\n await innerOpen;\n\n expect(\n innerClickContent.parentElement instanceof OverlayTrigger,\n 'inner content stolen and reparented'\n ).to.be.false;\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n\n pressSpace();\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n\n const innerClose = oneEvent(innerButton, 'sp-closed');\n pressEscape();\n await innerClose;\n\n expect(\n innerClickContent.parentElement instanceof OverlayTrigger,\n 'inner content returned'\n ).to.be.true;\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.false;\n\n const outerClose = oneEvent(outerButton, 'sp-closed');\n pressEscape();\n await outerClose;\n\n expect(\n outerClickContent.parentElement instanceof OverlayTrigger,\n 'outer content returned'\n ).to.be.true;\n expect(isVisible(outerClickContent)).to.be.false;\n expect(isVisible(innerClickContent)).to.be.false;\n });\n\n it('click closes an open popover', async () => {\n outerTrigger.type = 'modal';\n innerTrigger.type = 'modal';\n const outerOpen = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n await outerOpen;\n\n expect(\n outerClickContent.parentElement instanceof OverlayTrigger,\n 'outer content stolen and reparented'\n ).to.be.false;\n\n const innerOpen = oneEvent(innerButton, 'sp-opened');\n innerButton.click();\n await innerOpen;\n\n expect(\n innerClickContent.parentElement instanceof OverlayTrigger,\n 'inner content stolen and reparented'\n ).to.be.false;\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n\n // Test that clicking in the overlay content does not close the overlay\n // 200ms is slightly more than the overlay animation fade out time (130ms)\n innerClickContent.click();\n await aTimeout(200);\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.true;\n\n const innerClose = oneEvent(innerButton, 'sp-closed');\n document.body.click();\n await innerClose;\n\n expect(\n innerClickContent.parentElement instanceof OverlayTrigger,\n 'inner content returned'\n ).to.be.true;\n expect(isVisible(outerClickContent)).to.be.true;\n expect(isVisible(innerClickContent)).to.be.false;\n\n const outerClose = oneEvent(outerButton, 'sp-closed');\n document.body.click();\n await outerClose;\n\n expect(\n outerClickContent.parentElement instanceof OverlayTrigger,\n 'outer content returned'\n ).to.be.true;\n expect(isVisible(outerClickContent)).to.be.false;\n expect(isVisible(innerClickContent)).to.be.false;\n });\n\n it('opens a hover popover', async () => {\n const root = outerTrigger.shadowRoot\n ? outerTrigger.shadowRoot\n : outerTrigger;\n const triggerZone = root.querySelector(\n '#trigger'\n ) as HTMLDivElement;\n\n expect(triggerZone).to.exist;\n if (!triggerZone) return;\n\n expect(outerButton).to.exist;\n expect(hoverContent).to.exist;\n\n expect(isVisible(hoverContent)).to.be.false;\n\n const open = oneEvent(outerTrigger, 'sp-opened');\n const mouseEnter = new MouseEvent('mouseenter');\n triggerZone.dispatchEvent(mouseEnter);\n await open;\n expect(hoverContent.parentElement).to.not.be.instanceOf(\n OverlayTrigger\n );\n\n expect(isVisible(hoverContent)).to.be.true;\n\n const close = oneEvent(outerTrigger, 'sp-closed');\n const mouseLeave = new MouseEvent('mouseleave');\n triggerZone.dispatchEvent(mouseLeave);\n await close;\n expect(hoverContent.parentElement).to.be.instanceOf(\n OverlayTrigger\n );\n\n expect(isVisible(hoverContent)).to.be.false;\n });\n\n it('closes a hover popover', async () => {\n const root = outerTrigger.shadowRoot\n ? outerTrigger.shadowRoot\n : outerTrigger;\n const triggerZone = root.querySelector(\n '#trigger'\n ) as HTMLDivElement;\n\n expect(triggerZone).to.exist;\n if (!triggerZone) return;\n\n expect(outerButton).to.exist;\n expect(hoverContent).to.exist;\n\n expect(\n isVisible(hoverContent),\n 'hoverContent should not be visible'\n ).to.be.false;\n\n const mouseEnter = new MouseEvent('mouseenter');\n const mouseLeave = new MouseEvent('mouseleave');\n triggerZone.dispatchEvent(mouseEnter);\n await nextFrame();\n triggerZone.dispatchEvent(mouseLeave);\n\n await waitUntil(\n () => isVisible(hoverContent) === false,\n 'hoverContent should still not be visible'\n );\n });\n\n it('dispatches events on open/close', async () => {\n const opened = oneEvent(outerButton, 'sp-opened');\n outerButton.click();\n const openedEvent = await opened;\n\n expect(isVisible(outerClickContent)).to.be.true;\n expect(outerTrigger.open).to.equal('click');\n\n expect(openedEvent.detail.interaction).to.equal('click');\n\n const closed = oneEvent(outerButton, 'sp-closed');\n document.body.click();\n const closedEvent = await closed;\n expect(outerClickContent.parentElement).to.be.instanceOf(\n OverlayTrigger\n );\n expect(closedEvent.detail.interaction).to.equal('click');\n\n expect(isVisible(outerClickContent)).to.be.false;\n });\n });\n describe('System interactions', () => {\n afterEach(async () => {\n const triggers = document.querySelectorAll('overlay-trigger');\n const closes: Promise<CustomEvent<unknown>>[] = [];\n triggers.forEach((trigger) => {\n if (trigger.open) {\n const close = oneEvent(trigger, 'sp-closed');\n trigger.open = undefined;\n closes.push(close);\n }\n });\n await Promise.all(closes);\n });\n it('acquires a `color` and `size` from `sp-theme`', async () => {\n const el = await fixture<Theme>(html`\n <sp-theme color=\"dark\">\n <sp-theme color=\"light\">\n <overlay-trigger id=\"trigger\" placement=\"top\">\n <sp-button\n id=\"outer-button\"\n variant=\"primary\"\n slot=\"trigger\"\n >\n Show Popover\n </sp-button>\n <sp-popover\n id=\"outer-popover\"\n dialog\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n >\n Popover content!\n </sp-popover>\n </overlay-trigger>\n </sp-theme>\n </sp-theme>\n `);\n\n await elementUpdated(el);\n\n expect(document.querySelector('active-overlay')).to.be.null;\n\n const button = el.querySelector('sp-button') as Button;\n const opened = oneEvent(button, 'sp-opened');\n button.click();\n await opened;\n\n await elementUpdated(el);\n\n const overlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n\n expect(overlay).to.exist;\n expect(overlay.theme.color).to.not.equal('dark');\n expect(overlay.theme.color).to.equal('light');\n });\n it('manages multiple layers of `type=\"modal\"', async () => {\n const el = await fixture(html`\n <overlay-trigger type=\"modal\" placement=\"none\">\n <sp-button slot=\"trigger\" variant=\"accent\">\n Toggle Dialog\n </sp-button>\n <sp-popover slot=\"click-content\">\n <sp-dialog no-divider>\n <overlay-trigger>\n <sp-button slot=\"trigger\" variant=\"primary\">\n Toggle Dialog\n </sp-button>\n <sp-popover slot=\"click-content\">\n <sp-dialog no-divider>\n <overlay-trigger type=\"modal\">\n <sp-button\n slot=\"trigger\"\n variant=\"secondary\"\n >\n Toggle Dialog\n </sp-button>\n <sp-popover\n slot=\"click-content\"\n >\n <sp-dialog no-divider>\n <p>\n When you get this\n deep, this\n ActiveOverlay should\n be the only one in\n [slot=\"open\"].\n </p>\n <p>\n All of the rest of\n the ActiveOverlay\n elements should have\n had their [slot]\n attribute removed.\n </p>\n <p>\n Closing this\n ActiveOverlay should\n replace them...\n </p>\n </sp-dialog>\n </sp-popover>\n </overlay-trigger>\n </sp-dialog>\n </sp-popover>\n </overlay-trigger>\n </sp-dialog>\n </sp-popover>\n </overlay-trigger>\n `);\n const overlayTriggers = [\n ...el.querySelectorAll('overlay-trigger'),\n ];\n let activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n const triggers = [\n ...el.querySelectorAll('sp-button[slot=\"trigger\"]'),\n ] as Button[];\n\n expect(activeOverlays.length, 'no previous overlays').to.equal(\n 0\n );\n\n let open = oneEvent(triggers[0], 'sp-opened');\n triggers[0]?.click();\n await open;\n await elementUpdated(overlayTriggers[0]);\n activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n expect(\n activeOverlays.length,\n 'The first `active-overlay` element has been added.'\n ).to.equal(1);\n expect(\n activeOverlays[0].slot,\n 'first overlay, first time'\n ).to.equal('open');\n\n open = oneEvent(triggers[1], 'sp-opened');\n triggers[1]?.click();\n await open;\n await elementUpdated(overlayTriggers[1]);\n activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n expect(\n activeOverlays.length,\n 'The second `active-overlay` element has been added.'\n ).to.equal(2);\n\n expect(\n activeOverlays[0].slot,\n 'first overlay, second time'\n ).to.equal('open');\n expect(\n activeOverlays[1].slot,\n 'second overlay, second time'\n ).to.equal('open');\n\n open = oneEvent(triggers[2], 'sp-opened');\n triggers[2]?.click();\n await open;\n await elementUpdated(overlayTriggers[2]);\n activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n expect(\n activeOverlays.length,\n 'The third `active-overlay` element has been added.'\n ).to.equal(3);\n\n expect(\n activeOverlays[0].hasAttribute('slot'),\n 'first overlay, third time'\n ).to.be.false;\n expect(\n activeOverlays[1].hasAttribute('slot'),\n 'second overlay, third time'\n ).to.be.false;\n expect(\n activeOverlays[2].slot,\n 'third overlay, third time'\n ).to.equal('open');\n\n await nextFrame();\n const closed = oneEvent(triggers[2], 'sp-closed');\n document.body.click();\n await closed;\n await elementUpdated(overlayTriggers[2]);\n activeOverlays = [\n ...document.querySelectorAll('active-overlay'),\n ];\n expect(\n activeOverlays.length,\n 'The third `active-overlay` element has been removed.'\n ).to.equal(2);\n\n await waitUntil(() => {\n return activeOverlays[0].slot === 'open';\n }, 'first overlay, last time');\n expect(\n activeOverlays[1].slot,\n 'second overlay, last time'\n ).to.equal('open');\n });\n });\n });\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -35,7 +35,6 @@ const initTest = async (styles = html``) => {
|
|
|
35
35
|
</sp-button>
|
|
36
36
|
<sp-popover
|
|
37
37
|
id="outer-popover"
|
|
38
|
-
dialog
|
|
39
38
|
slot="click-content"
|
|
40
39
|
direction="bottom"
|
|
41
40
|
tip
|
|
@@ -43,7 +42,9 @@ const initTest = async (styles = html``) => {
|
|
|
43
42
|
tabindex="0"
|
|
44
43
|
placement="top"
|
|
45
44
|
>
|
|
46
|
-
|
|
45
|
+
<sp-dialog no-divider>
|
|
46
|
+
This is the overlay content.
|
|
47
|
+
</sp-dialog>
|
|
47
48
|
</sp-popover>
|
|
48
49
|
</overlay-trigger>
|
|
49
50
|
</div>
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["overlay-trigger-extended.test.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*/\nimport {\n elementUpdated,\n expect,\n fixture,\n html,\n nextFrame,\n oneEvent,\n waitUntil,\n} from '@open-wc/testing';\n\nimport '@spectrum-web-components/overlay/overlay-trigger.js';\nimport {\n ActiveOverlay,\n OverlayTrigger,\n} from '@spectrum-web-components/overlay';\nimport '@spectrum-web-components/button/sp-button.js';\nimport { Button } from '@spectrum-web-components/button';\nimport '@spectrum-web-components/popover/sp-popover.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport '@spectrum-web-components/textfield/sp-textfield.js';\nimport { sendMouse } from '../../../test/plugins/browser.js';\n\nconst initTest = async (\n styles = html``\n): Promise<{\n overlayTrigger: OverlayTrigger;\n button: Button;\n popover: Popover;\n}> => {\n const test = await fixture<HTMLDivElement>(\n html`\n <div class=\"container\">\n <style>\n .container {\n display: flex;\n align-items: center;\n justify-content: center;\n }\n </style>\n ${styles}\n <overlay-trigger type=\"modal\" id=\"trigger\" placement=\"top\">\n <sp-button\n id=\"outer-button\"\n variant=\"primary\"\n slot=\"trigger\"\n >\n Show Popover\n </sp-button>\n <sp-popover\n id=\"outer-popover\"\n
|
|
5
|
-
"mappings": ";AAWA;AAAA,EACI;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACG;AAEP,OAAO;AAKP,OAAO;AAEP,OAAO;AAEP,OAAO;AACP,SAAS,iBAAiB;AAE1B,MAAM,WAAW,OACb,SAAS,WAKP;AACF,QAAM,OAAO,MAAM;AAAA,IACf;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBASU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,
|
|
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*/\nimport {\n elementUpdated,\n expect,\n fixture,\n html,\n nextFrame,\n oneEvent,\n waitUntil,\n} from '@open-wc/testing';\n\nimport '@spectrum-web-components/overlay/overlay-trigger.js';\nimport {\n ActiveOverlay,\n OverlayTrigger,\n} from '@spectrum-web-components/overlay';\nimport '@spectrum-web-components/button/sp-button.js';\nimport { Button } from '@spectrum-web-components/button';\nimport '@spectrum-web-components/popover/sp-popover.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport '@spectrum-web-components/textfield/sp-textfield.js';\nimport { sendMouse } from '../../../test/plugins/browser.js';\n\nconst initTest = async (\n styles = html``\n): Promise<{\n overlayTrigger: OverlayTrigger;\n button: Button;\n popover: Popover;\n}> => {\n const test = await fixture<HTMLDivElement>(\n html`\n <div class=\"container\">\n <style>\n .container {\n display: flex;\n align-items: center;\n justify-content: center;\n }\n </style>\n ${styles}\n <overlay-trigger type=\"modal\" id=\"trigger\" placement=\"top\">\n <sp-button\n id=\"outer-button\"\n variant=\"primary\"\n slot=\"trigger\"\n >\n Show Popover\n </sp-button>\n <sp-popover\n id=\"outer-popover\"\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n tabindex=\"0\"\n placement=\"top\"\n >\n <sp-dialog no-divider>\n This is the overlay content.\n </sp-dialog>\n </sp-popover>\n </overlay-trigger>\n </div>\n `\n );\n return {\n overlayTrigger: test.querySelector('overlay-trigger') as OverlayTrigger,\n button: test.querySelector('sp-button') as Button,\n popover: test.querySelector('sp-popover') as Popover,\n };\n};\n\ndescribe('Overlay Trigger - extended', () => {\n let overlayTrigger!: OverlayTrigger;\n let button!: Button;\n let popover!: Popover;\n\n afterEach(async () => {\n if (overlayTrigger.open) {\n const closed = oneEvent(overlayTrigger, 'sp-closed');\n overlayTrigger.open = undefined;\n await closed;\n }\n });\n\n it('manages `placement` on open', async () => {\n ({ overlayTrigger, button, popover } = await initTest());\n\n expect(popover.placement).to.equal('top');\n\n const open = oneEvent(overlayTrigger, 'sp-opened');\n button.click();\n await open;\n\n expect(popover.placement).to.equal('bottom');\n\n const close = oneEvent(overlayTrigger, 'sp-closed');\n overlayTrigger.open = undefined;\n await close;\n\n expect(popover.placement).to.equal('top');\n });\n\n it('manages `placement` on scroll', async () => {\n ({ overlayTrigger, button, popover } = await initTest(html`\n <style>\n sp-button {\n margin: 100vh 0;\n transform: translateY(-100%);\n }\n </style>\n `));\n\n expect(popover.placement).to.equal('top');\n\n const open = oneEvent(overlayTrigger, 'sp-opened');\n button.click();\n await open;\n\n expect(popover.placement).to.equal('top');\n\n const { scrollHeight } = document.documentElement;\n document.documentElement.scrollTop = scrollHeight / 2;\n\n // one frame for scroll to trigger\n await nextFrame();\n // one frame for the UI to update\n await nextFrame();\n // _then_ we test...\n expect(popover.placement).to.equal('bottom');\n });\n\n it('occludes content behind the overlay', async () => {\n ({ overlayTrigger, button, popover } = await initTest());\n const textfield = document.createElement('sp-textfield');\n document.body.append(textfield);\n\n const boundingRect = textfield.getBoundingClientRect();\n expect(document.activeElement).to.not.equal(textfield);\n await sendMouse({\n steps: [\n {\n type: 'click',\n position: [\n boundingRect.left + boundingRect.width / 2,\n boundingRect.top + boundingRect.height / 2,\n ],\n },\n ],\n });\n expect(document.activeElement).to.equal(textfield);\n\n expect(popover.placement).to.equal('top');\n\n const open = oneEvent(overlayTrigger, 'sp-opened');\n button.click();\n await open;\n\n expect(overlayTrigger.open).to.equal('click');\n expect(popover.placement).to.equal('bottom');\n\n const close = oneEvent(overlayTrigger, 'sp-closed');\n await sendMouse({\n steps: [\n {\n type: 'click',\n position: [\n boundingRect.left + boundingRect.width / 2,\n boundingRect.top + boundingRect.height / 2,\n ],\n },\n ],\n });\n await close;\n expect(overlayTrigger.open).to.be.null;\n expect(document.activeElement).to.not.equal(textfield);\n await sendMouse({\n steps: [\n {\n type: 'click',\n position: [\n boundingRect.left + boundingRect.width / 2,\n boundingRect.top + boundingRect.height / 2,\n ],\n },\n ],\n });\n expect(document.activeElement).to.equal(textfield);\n textfield.remove();\n });\n\n xit('occludes wheel interactions behind the overlay', async () => {\n /**\n * This test \"passes\" when tested manually in browser, but\n * not when leveraged in the automated test process.\n *\n * xit for now...\n **/\n ({ overlayTrigger, button, popover } = await initTest());\n const scrollingArea = document.createElement('div');\n Object.assign(scrollingArea.style, {\n width: '100px',\n height: '100px',\n overflow: 'auto',\n });\n const content = Array(100).fill(\n 'This is content within my box that will scroll.'\n );\n scrollingArea.textContent = content.join(' ');\n document.body.append(scrollingArea);\n await nextFrame();\n\n const boundingRect = scrollingArea.getBoundingClientRect();\n expect(scrollingArea.scrollTop).to.equal(0);\n const distance = 1;\n await sendMouse({\n steps: [\n {\n type: 'move',\n position: [\n boundingRect.left + boundingRect.width / 2,\n boundingRect.top + boundingRect.height / 2,\n ],\n },\n ],\n });\n await sendMouse({\n steps: [\n {\n type: 'wheel',\n position: [0, distance],\n },\n ],\n });\n // wait for scroll to complete\n await waitUntil(\n () => scrollingArea.scrollTop === distance,\n `scroll went to ${distance}`\n );\n expect(scrollingArea.scrollTop).to.equal(distance);\n\n expect(popover.placement).to.equal('top');\n\n const open = oneEvent(overlayTrigger, 'sp-opened');\n button.click();\n await open;\n const activeOverlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n await elementUpdated(activeOverlay);\n\n expect(overlayTrigger.open).to.equal('click');\n expect(popover.placement).to.equal('bottom');\n expect(scrollingArea.scrollTop).to.equal(distance);\n await sendMouse({\n steps: [\n {\n type: 'wheel',\n position: [0, -distance],\n },\n ],\n });\n // Awaiting here points out that this always fails in Firefox\n // and also was failing in WebKit without our knowing.\n await nextFrame();\n await nextFrame();\n await nextFrame();\n expect(\n scrollingArea.scrollTop,\n `scrollTop should be ${distance}.`\n ).to.equal(distance);\n scrollingArea.remove();\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/test/overlay.test.js
CHANGED
|
@@ -58,15 +58,14 @@ describe("Overlays", () => {
|
|
|
58
58
|
<div id="overlay-content">
|
|
59
59
|
<sp-popover
|
|
60
60
|
id="outer-popover"
|
|
61
|
-
dialog
|
|
62
61
|
slot="click-content"
|
|
63
62
|
direction="bottom"
|
|
64
63
|
tip
|
|
65
64
|
open
|
|
66
65
|
>
|
|
67
|
-
<
|
|
66
|
+
<sp-dialog class="options-popover-content">
|
|
68
67
|
A popover message
|
|
69
|
-
</
|
|
68
|
+
</sp-dialog>
|
|
70
69
|
</sp-popover>
|
|
71
70
|
<div id="hover-1" class="hover-content">
|
|
72
71
|
Hover message
|
package/test/overlay.test.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["overlay.test.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*/\nimport '@spectrum-web-components/button/sp-button.js';\nimport '@spectrum-web-components/dialog/sp-dialog.js';\nimport { Dialog } from '@spectrum-web-components/dialog';\nimport '@spectrum-web-components/popover/sp-popover.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport { setViewport } from '@web/test-runner-commands';\nimport {\n ActiveOverlay,\n Overlay,\n OverlayTrigger,\n Placement,\n} from '@spectrum-web-components/overlay';\n\nimport { isVisible } from '../../../test/testing-helpers.js';\nimport {\n elementUpdated,\n expect,\n fixture,\n html,\n nextFrame,\n oneEvent,\n waitUntil,\n} from '@open-wc/testing';\nimport { sendKeys } from '@web/test-runner-commands';\nimport {\n definedOverlayElement,\n virtualElement,\n} from '../stories/overlay.stories';\nimport { PopoverContent } from '../stories/overlay-story-components.js';\nimport { sendMouse } from '../../../test/plugins/browser.js';\n\ndescribe('Overlays', () => {\n let testDiv!: HTMLDivElement;\n let openOverlays: (() => void)[] = [];\n\n beforeEach(async () => {\n testDiv = await fixture<HTMLDivElement>(\n html`\n <div id=\"top\">\n <style>\n body {\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n #top {\n margin: 100px;\n }\n\n sp-button {\n flex: none;\n }\n\n #overlay-content {\n display: none;\n }\n </style>\n <sp-button\n id=\"first-button\"\n variant=\"primary\"\n slot=\"trigger\"\n >\n Show Popover\n </sp-button>\n <div id=\"overlay-content\">\n <sp-popover\n id=\"outer-popover\"\n dialog\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n >\n <div class=\"options-popover-content\">\n A popover message\n </div>\n </sp-popover>\n <div id=\"hover-1\" class=\"hover-content\">\n Hover message\n </div>\n <div id=\"hover-2\" class=\"hover-content\">\n Other hover message\n </div>\n </div>\n </div>\n `\n );\n await elementUpdated(testDiv);\n });\n\n afterEach(() => {\n openOverlays.map((close) => close());\n openOverlays = [];\n });\n\n [\n 'bottom',\n 'bottom-start',\n 'bottom-end',\n 'top',\n 'top-start',\n 'top-end',\n 'left',\n 'left-start',\n 'left-end',\n 'right',\n 'right-start',\n 'right-end',\n 'none',\n ].map((direction) => {\n const placement = direction as Placement;\n it(`opens a popover - ${placement}`, async () => {\n const button = testDiv.querySelector(\n '#first-button'\n ) as HTMLElement;\n const outerPopover = testDiv.querySelector(\n '#outer-popover'\n ) as Popover;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).to.equal(\n 'overlay-content'\n );\n }\n\n expect(isVisible(outerPopover)).to.be.false;\n\n expect(button).to.exist;\n\n const opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'click', outerPopover, {\n delayed: false,\n placement,\n offset: 10,\n })\n );\n await opened;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).not.to.equal(\n 'overlay-content'\n );\n }\n expect(isVisible(outerPopover)).to.be.true;\n });\n });\n\n it(`updates a popover`, async () => {\n const button = testDiv.querySelector('#first-button') as HTMLElement;\n const outerPopover = testDiv.querySelector('#outer-popover') as Popover;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).to.equal('overlay-content');\n }\n\n expect(isVisible(outerPopover)).to.be.false;\n\n expect(button).to.exist;\n\n const opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'click', outerPopover, {\n delayed: false,\n offset: 10,\n })\n );\n await opened;\n\n expect(isVisible(outerPopover)).to.be.true;\n\n Overlay.update();\n\n expect(isVisible(outerPopover)).to.be.true;\n });\n\n it(`opens a popover w/ delay`, async () => {\n const button = testDiv.querySelector('#first-button') as HTMLElement;\n const outerPopover = testDiv.querySelector('#outer-popover') as Popover;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).to.equal('overlay-content');\n }\n\n expect(isVisible(outerPopover)).to.be.false;\n\n expect(button).to.exist;\n\n const opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'click', outerPopover, {\n delayed: true,\n offset: 10,\n })\n );\n await opened;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).not.to.equal(\n 'overlay-content'\n );\n }\n expect(isVisible(outerPopover)).to.be.true;\n });\n\n it('opens hover overlay', async () => {\n const button = testDiv.querySelector('#first-button') as HTMLElement;\n const hoverOverlay = testDiv.querySelector('#hover-1') as HTMLElement;\n const clickOverlay = testDiv.querySelector(\n '#outer-popover'\n ) as HTMLElement;\n\n expect(isVisible(hoverOverlay)).to.be.false;\n expect(isVisible(clickOverlay)).to.be.false;\n\n let opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'hover', hoverOverlay, {\n delayed: false,\n placement: 'top',\n offset: 10,\n })\n );\n await opened;\n\n expect(hoverOverlay.parentElement).to.exist;\n if (hoverOverlay.parentElement) {\n expect(hoverOverlay.parentElement.id).not.to.equal(\n 'overlay-content'\n );\n }\n expect(isVisible(hoverOverlay)).to.be.true;\n\n opened = oneEvent(button, 'sp-opened');\n // Opening click overlay should close the hover overlay\n openOverlays.push(\n await Overlay.open(button, 'click', clickOverlay, {\n delayed: false,\n placement: 'bottom',\n offset: 10,\n })\n );\n await opened;\n if (hoverOverlay.parentElement) {\n expect(hoverOverlay.parentElement.id).to.equal('overlay-content');\n }\n\n expect(isVisible(hoverOverlay)).to.be.false;\n expect(isVisible(clickOverlay)).to.be.true;\n });\n\n it('opens custom overlay', async () => {\n const button = testDiv.querySelector('#first-button') as HTMLElement;\n const customOverlay = testDiv.querySelector('#hover-1') as HTMLElement;\n const clickOverlay = testDiv.querySelector(\n '#outer-popover'\n ) as HTMLElement;\n\n expect(button).to.exist;\n expect(customOverlay).to.exist;\n\n expect(isVisible(customOverlay)).to.be.false;\n expect(isVisible(clickOverlay)).to.be.false;\n\n let opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'custom', customOverlay, {\n delayed: false,\n placement: 'top',\n offset: 10,\n })\n );\n await opened;\n\n expect(customOverlay.parentElement).to.exist;\n if (customOverlay.parentElement) {\n expect(customOverlay.parentElement.id).not.to.equal(\n 'overlay-content'\n );\n }\n expect(isVisible(customOverlay)).to.be.true;\n\n opened = oneEvent(button, 'sp-opened');\n // Opening click overlay should close the hover overlay\n openOverlays.push(\n await Overlay.open(button, 'click', clickOverlay, {\n delayed: false,\n placement: 'bottom',\n offset: 10,\n })\n );\n await opened;\n\n expect(isVisible(customOverlay)).to.be.true;\n expect(isVisible(clickOverlay)).to.be.true;\n });\n\n it('closes via events', async () => {\n const el = await fixture<HTMLDivElement>(html`\n <div id=\"root\">\n <sp-dialog dismissable></sp-dialog>\n </div>\n `);\n\n const dialog = el.querySelector('sp-dialog') as Dialog;\n\n const opened = oneEvent(el, 'sp-opened');\n openOverlays.push(\n await Overlay.open(el, 'click', dialog, {\n delayed: false,\n placement: 'bottom',\n offset: 10,\n })\n );\n await opened;\n\n dialog.close();\n\n await waitUntil(\n () =>\n !!dialog.parentElement &&\n dialog.parentElement.tagName !== 'ACTIVE-OVERLAY',\n 'content is returned'\n );\n });\n\n it('closes an inline overlay when tabbing past the content', async () => {\n const el = await fixture<HTMLDivElement>(html`\n <div>\n <sp-button class=\"trigger\">Trigger</sp-button>\n <div class=\"content\">\n <input />\n </div>\n <input value=\"After\" id=\"after\" />\n </div>\n `);\n\n const trigger = el.querySelector('.trigger') as HTMLElement;\n const content = el.querySelector('.content') as HTMLElement;\n const input = el.querySelector('input') as HTMLInputElement;\n const after = el.querySelector('#after') as HTMLAnchorElement;\n\n openOverlays.push(await Overlay.open(trigger, 'inline', content, {}));\n\n trigger.focus();\n await sendKeys({\n press: 'Tab',\n });\n\n expect(document.activeElement).to.equal(input);\n expect(input.closest('active-overlay') !== null);\n\n await sendKeys({\n press: 'Shift+Tab',\n });\n\n expect(document.activeElement).to.equal(trigger);\n\n await sendKeys({\n press: 'Tab',\n });\n\n expect(document.activeElement).to.equal(input);\n\n await sendKeys({\n press: 'Tab',\n });\n\n expect(document.activeElement).to.equal(after);\n await waitUntil(\n () => document.querySelector('active-overlay') === null\n );\n });\n\n it('closes an inline overlay when tabbing before the trigger', async () => {\n const el = await fixture<HTMLDivElement>(html`\n <div>\n <input value=\"Before\" id=\"before\" />\n <sp-button class=\"trigger\">Trigger</sp-button>\n <div class=\"content\">\n <label>\n Content in an inline overlay.\n <input />\n </label>\n </div>\n </div>\n `);\n\n const trigger = el.querySelector('.trigger') as HTMLElement;\n const content = el.querySelector('.content') as HTMLElement;\n const input = el.querySelector('.content input') as HTMLInputElement;\n const before = el.querySelector('#before') as HTMLAnchorElement;\n\n openOverlays.push(await Overlay.open(trigger, 'inline', content, {}));\n\n trigger.focus();\n await sendKeys({\n press: 'Tab',\n });\n\n expect(document.activeElement).to.equal(input);\n expect(input.closest('active-overlay') !== null);\n\n await sendKeys({\n press: 'Shift+Tab',\n });\n\n expect(document.activeElement).to.equal(trigger);\n\n await sendKeys({\n press: 'Shift+Tab',\n });\n\n expect(document.activeElement).to.equal(before);\n await waitUntil(\n () => document.querySelector('active-overlay') === null\n );\n });\n\n it('opens detached content', async () => {\n const textContent = 'This is a detached element that has been overlaid';\n const el = await fixture<HTMLButtonElement>(\n html`\n <button>Trigger</button>\n `\n );\n\n const content = document.createElement('div');\n content.textContent = textContent;\n\n const opened = oneEvent(el, 'sp-opened');\n const closeOverlay = await Overlay.open(el, 'click', content, {\n placement: 'bottom',\n });\n await opened;\n\n let activeOverlay = document.querySelector('active-overlay');\n\n if (activeOverlay) {\n expect(activeOverlay.textContent).to.equal(textContent);\n } else {\n expect(activeOverlay).to.not.be.null;\n }\n\n const closed = oneEvent(el, 'sp-closed');\n closeOverlay();\n await closed;\n\n activeOverlay = document.querySelector('active-overlay');\n\n expect(activeOverlay).to.be.null;\n\n content.remove();\n });\n});\ndescribe('Overlay - type=\"modal\"', () => {\n it('closes on `contextmenu` and passes that to the underlying page', async () => {\n await fixture<HTMLDivElement>(html`\n ${virtualElement({\n ...virtualElement.args,\n offset: 6,\n })}\n `);\n const width = window.innerWidth;\n const height = window.innerHeight;\n let opened = oneEvent(document, 'sp-opened');\n // Right click to open \"context menu\" overlay.\n sendMouse({\n steps: [\n {\n type: 'move',\n position: [width / 2 + 50, height / 2],\n },\n {\n type: 'click',\n options: {\n button: 'right',\n },\n position: [width / 2 + 50, height / 2],\n },\n ],\n });\n await opened;\n const firstOverlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n const firstHeadline = firstOverlay.querySelector(\n '[slot=\"header\"]'\n ) as HTMLSpanElement;\n expect(firstOverlay, 'first overlay').to.not.be.null;\n expect(firstOverlay.isConnected).to.be.true;\n expect(firstHeadline.textContent).to.equal('Menu source: end');\n let closed = oneEvent(document, 'sp-closed');\n opened = oneEvent(document, 'sp-opened');\n // Right click to out of the \"context menu\" overlay to both close\n // the first overlay and have the event passed to the surfacing page\n // in order to open a subsequent \"context menu\" overlay.\n sendMouse({\n steps: [\n {\n type: 'move',\n position: [width / 4, height / 4],\n },\n {\n type: 'click',\n options: {\n button: 'right',\n },\n position: [width / 4, height / 4],\n },\n ],\n });\n await closed;\n await opened;\n const secondOverlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n const secondHeadline = secondOverlay.querySelector(\n '[slot=\"header\"]'\n ) as HTMLSpanElement;\n expect(secondOverlay, 'second overlay').to.not.be.null;\n expect(secondOverlay).to.not.equal(firstOverlay);\n expect(firstOverlay.isConnected).to.be.false;\n expect(secondOverlay.isConnected).to.be.true;\n expect(secondHeadline.textContent).to.equal('Menu source: start');\n closed = oneEvent(document, 'sp-closed');\n sendMouse({\n steps: [\n {\n type: 'move',\n position: [width / 8, height / 8],\n },\n {\n type: 'click',\n position: [width / 8, height / 8],\n },\n ],\n });\n await closed;\n await nextFrame();\n });\n\n it('does not open content off of the viewport', async () => {\n await fixture<HTMLDivElement>(html`\n ${virtualElement({\n ...virtualElement.args,\n offset: 6,\n })}\n `);\n\n await setViewport({ width: 360, height: 640 });\n // Allow viewport update to propagate.\n await nextFrame();\n\n const opened = oneEvent(document, 'sp-opened');\n // Right click to open \"context menu\" overlay.\n sendMouse({\n steps: [\n {\n type: 'move',\n position: [270, 10],\n },\n {\n type: 'click',\n options: {\n button: 'right',\n },\n position: [270, 10],\n },\n ],\n });\n await opened;\n\n const activeOverlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n\n expect(activeOverlay.placement).to.equal('right-start');\n expect(activeOverlay.getAttribute('actual-placement')).to.equal(\n 'bottom'\n );\n\n const closed = oneEvent(document, 'sp-closed');\n sendKeys({\n press: 'Escape',\n });\n await closed;\n await nextFrame();\n });\n\n it('opens children in the modal stack through shadow roots', async () => {\n const el = await fixture<OverlayTrigger>(definedOverlayElement());\n const trigger = el.querySelector(\n '[slot=\"trigger\"]'\n ) as HTMLButtonElement;\n let open = oneEvent(el, 'sp-opened');\n trigger.click();\n await open;\n const content = document.querySelector(\n 'popover-content'\n ) as PopoverContent;\n open = oneEvent(content, 'sp-opened');\n content.button.click();\n await open;\n const activeOverlays = document.querySelectorAll('active-overlay');\n activeOverlays.forEach((overlay) => {\n expect(overlay.slot).to.equal('open');\n });\n let close = oneEvent(content, 'sp-closed');\n content.trigger.removeAttribute('open');\n await close;\n close = oneEvent(el, 'sp-closed');\n el.removeAttribute('open');\n await close;\n });\n});\ndescribe('Overlay - timing', () => {\n it('manages multiple modals in a row without preventing them from closing', async () => {\n const test = await fixture<HTMLDivElement>(html`\n <div>\n <overlay-trigger>\n <sp-button slot=\"trigger\">Trigger 1</sp-button>\n <sp-popover slot=\"hover-content\">\n <p>Hover contentent for \"Trigger 1\".</p>\n </sp-popover>\n </overlay-trigger>\n <overlay-trigger>\n <sp-button slot=\"trigger\">Trigger 2</sp-button>\n <sp-popover slot=\"hover-content\">\n <p>Hover contentent for \"Trigger 2\".</p>\n </sp-popover>\n <sp-popover slot=\"click-content\">\n <p>Click contentent for \"Trigger 2\".</p>\n </sp-popover>\n </overlay-trigger>\n </div>\n `);\n\n const overlayTrigger1 = test.querySelector(\n 'overlay-trigger:first-child'\n ) as OverlayTrigger;\n const overlayTrigger2 = test.querySelector(\n 'overlay-trigger:last-child'\n ) as OverlayTrigger;\n const trigger1 = overlayTrigger1.querySelector(\n '[slot=\"trigger\"]'\n ) as HTMLButtonElement;\n const trigger2 = overlayTrigger2.querySelector(\n '[slot=\"trigger\"]'\n ) as HTMLButtonElement;\n\n const boundingRectTrigger1 = trigger1.getBoundingClientRect();\n const boundingRectTrigger2 = trigger2.getBoundingClientRect();\n const trigger1Position: [number, number] = [\n boundingRectTrigger1.left + boundingRectTrigger1.width / 2,\n boundingRectTrigger1.top + boundingRectTrigger1.height / 2,\n ];\n const outsideTrigger1: [number, number] = [\n boundingRectTrigger1.left + boundingRectTrigger1.width * 2,\n boundingRectTrigger1.top + boundingRectTrigger1.height * 2,\n ];\n const trigger2Position: [number, number] = [\n boundingRectTrigger2.left + boundingRectTrigger2.width / 2,\n boundingRectTrigger2.top + boundingRectTrigger2.height / 2,\n ];\n const outsideTrigger2: [number, number] = [\n boundingRectTrigger2.left + boundingRectTrigger2.width * 2,\n boundingRectTrigger2.top + boundingRectTrigger2.height / 2,\n ];\n\n await sendMouse({\n steps: [\n {\n type: 'move',\n position: trigger1Position,\n },\n ],\n });\n await nextFrame();\n await nextFrame();\n await sendMouse({\n steps: [\n {\n type: 'move',\n position: outsideTrigger1,\n },\n ],\n });\n await nextFrame();\n await nextFrame();\n await sendMouse({\n steps: [\n {\n type: 'move',\n position: trigger2Position,\n },\n ],\n });\n await nextFrame();\n await nextFrame();\n const opened = oneEvent(trigger2, 'sp-opened');\n sendMouse({\n steps: [\n {\n type: 'click',\n position: trigger2Position,\n },\n ],\n });\n await opened;\n\n expect(overlayTrigger1.hasAttribute('open')).to.be.false;\n expect(overlayTrigger2.hasAttribute('open')).to.be.true;\n expect(overlayTrigger2.getAttribute('open')).to.equal('click');\n\n const closed = oneEvent(overlayTrigger2, 'sp-closed');\n sendMouse({\n steps: [\n {\n type: 'click',\n position: outsideTrigger2,\n },\n ],\n });\n await closed;\n\n // sometimes safari needs to wait a few frames for the open attribute to update\n for (let i = 0; i < 3; i++) await nextFrame();\n\n expect(overlayTrigger1.hasAttribute('open')).to.be.false;\n expect(overlayTrigger2.hasAttribute('open'), overlayTrigger2.open).to.be\n .false;\n });\n});\n"],
|
|
5
|
-
"mappings": ";AAWA,OAAO;AACP,OAAO;AAEP,OAAO;AAEP,SAAS,mBAAmB;AAC5B;AAAA,EAEI;AAAA,OAGG;AAEP,SAAS,iBAAiB;AAC1B;AAAA,EACI;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACG;AACP,SAAS,gBAAgB;AACzB;AAAA,EACI;AAAA,EACA;AAAA,OACG;AAEP,SAAS,iBAAiB;AAE1B,SAAS,YAAY,MAAM;AACvB,MAAI;AACJ,MAAI,eAA+B,CAAC;AAEpC,aAAW,YAAY;AACnB,cAAU,MAAM;AAAA,MACZ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAkDJ;AACA,UAAM,eAAe,OAAO;AAAA,EAChC,CAAC;AAED,YAAU,MAAM;AACZ,iBAAa,IAAI,CAAC,UAAU,MAAM,CAAC;AACnC,mBAAe,CAAC;AAAA,EACpB,CAAC;AAED;AAAA,IACI;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACJ,EAAE,IAAI,CAAC,cAAc;AACjB,UAAM,YAAY;AAClB,OAAG,qBAAqB,aAAa,YAAY;AAC7C,YAAM,SAAS,QAAQ;AAAA,QACnB;AAAA,MACJ;AACA,YAAM,eAAe,QAAQ;AAAA,QACzB;AAAA,MACJ;AAEA,aAAO,aAAa,aAAa,EAAE,GAAG;AACtC,UAAI,aAAa,eAAe;AAC5B,eAAO,aAAa,cAAc,EAAE,EAAE,GAAG;AAAA,UACrC;AAAA,QACJ;AAAA,MACJ;AAEA,aAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAEtC,aAAO,MAAM,EAAE,GAAG;AAElB,YAAM,SAAS,SAAS,QAAQ,WAAW;AAC3C,mBAAa;AAAA,QACT,MAAM,QAAQ,KAAK,QAAQ,SAAS,cAAc;AAAA,UAC9C,SAAS;AAAA,UACT;AAAA,UACA,QAAQ;AAAA,QACZ,CAAC;AAAA,MACL;AACA,YAAM;AAEN,aAAO,aAAa,aAAa,EAAE,GAAG;AACtC,UAAI,aAAa,eAAe;AAC5B,eAAO,aAAa,cAAc,EAAE,EAAE,IAAI,GAAG;AAAA,UACzC;AAAA,QACJ;AAAA,MACJ;AACA,aAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAAA,IAC1C,CAAC;AAAA,EACL,CAAC;AAED,KAAG,qBAAqB,YAAY;AAChC,UAAM,SAAS,QAAQ,cAAc,eAAe;AACpD,UAAM,eAAe,QAAQ,cAAc,gBAAgB;AAE3D,WAAO,aAAa,aAAa,EAAE,GAAG;AACtC,QAAI,aAAa,eAAe;AAC5B,aAAO,aAAa,cAAc,EAAE,EAAE,GAAG,MAAM,iBAAiB;AAAA,IACpE;AAEA,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAEtC,WAAO,MAAM,EAAE,GAAG;AAElB,UAAM,SAAS,SAAS,QAAQ,WAAW;AAC3C,iBAAa;AAAA,MACT,MAAM,QAAQ,KAAK,QAAQ,SAAS,cAAc;AAAA,QAC9C,SAAS;AAAA,QACT,QAAQ;AAAA,MACZ,CAAC;AAAA,IACL;AACA,UAAM;AAEN,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAEtC,YAAQ,OAAO;AAEf,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAAA,EAC1C,CAAC;AAED,KAAG,4BAA4B,YAAY;AACvC,UAAM,SAAS,QAAQ,cAAc,eAAe;AACpD,UAAM,eAAe,QAAQ,cAAc,gBAAgB;AAE3D,WAAO,aAAa,aAAa,EAAE,GAAG;AACtC,QAAI,aAAa,eAAe;AAC5B,aAAO,aAAa,cAAc,EAAE,EAAE,GAAG,MAAM,iBAAiB;AAAA,IACpE;AAEA,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAEtC,WAAO,MAAM,EAAE,GAAG;AAElB,UAAM,SAAS,SAAS,QAAQ,WAAW;AAC3C,iBAAa;AAAA,MACT,MAAM,QAAQ,KAAK,QAAQ,SAAS,cAAc;AAAA,QAC9C,SAAS;AAAA,QACT,QAAQ;AAAA,MACZ,CAAC;AAAA,IACL;AACA,UAAM;AAEN,WAAO,aAAa,aAAa,EAAE,GAAG;AACtC,QAAI,aAAa,eAAe;AAC5B,aAAO,aAAa,cAAc,EAAE,EAAE,IAAI,GAAG;AAAA,QACzC;AAAA,MACJ;AAAA,IACJ;AACA,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAAA,EAC1C,CAAC;AAED,KAAG,uBAAuB,YAAY;AAClC,UAAM,SAAS,QAAQ,cAAc,eAAe;AACpD,UAAM,eAAe,QAAQ,cAAc,UAAU;AACrD,UAAM,eAAe,QAAQ;AAAA,MACzB;AAAA,IACJ;AAEA,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AACtC,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAEtC,QAAI,SAAS,SAAS,QAAQ,WAAW;AACzC,iBAAa;AAAA,MACT,MAAM,QAAQ,KAAK,QAAQ,SAAS,cAAc;AAAA,QAC9C,SAAS;AAAA,QACT,WAAW;AAAA,QACX,QAAQ;AAAA,MACZ,CAAC;AAAA,IACL;AACA,UAAM;AAEN,WAAO,aAAa,aAAa,EAAE,GAAG;AACtC,QAAI,aAAa,eAAe;AAC5B,aAAO,aAAa,cAAc,EAAE,EAAE,IAAI,GAAG;AAAA,QACzC;AAAA,MACJ;AAAA,IACJ;AACA,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAEtC,aAAS,SAAS,QAAQ,WAAW;AAErC,iBAAa;AAAA,MACT,MAAM,QAAQ,KAAK,QAAQ,SAAS,cAAc;AAAA,QAC9C,SAAS;AAAA,QACT,WAAW;AAAA,QACX,QAAQ;AAAA,MACZ,CAAC;AAAA,IACL;AACA,UAAM;AACN,QAAI,aAAa,eAAe;AAC5B,aAAO,aAAa,cAAc,EAAE,EAAE,GAAG,MAAM,iBAAiB;AAAA,IACpE;AAEA,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AACtC,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAAA,EAC1C,CAAC;AAED,KAAG,wBAAwB,YAAY;AACnC,UAAM,SAAS,QAAQ,cAAc,eAAe;AACpD,UAAM,gBAAgB,QAAQ,cAAc,UAAU;AACtD,UAAM,eAAe,QAAQ;AAAA,MACzB;AAAA,IACJ;AAEA,WAAO,MAAM,EAAE,GAAG;AAClB,WAAO,aAAa,EAAE,GAAG;AAEzB,WAAO,UAAU,aAAa,CAAC,EAAE,GAAG,GAAG;AACvC,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAEtC,QAAI,SAAS,SAAS,QAAQ,WAAW;AACzC,iBAAa;AAAA,MACT,MAAM,QAAQ,KAAK,QAAQ,UAAU,eAAe;AAAA,QAChD,SAAS;AAAA,QACT,WAAW;AAAA,QACX,QAAQ;AAAA,MACZ,CAAC;AAAA,IACL;AACA,UAAM;AAEN,WAAO,cAAc,aAAa,EAAE,GAAG;AACvC,QAAI,cAAc,eAAe;AAC7B,aAAO,cAAc,cAAc,EAAE,EAAE,IAAI,GAAG;AAAA,QAC1C;AAAA,MACJ;AAAA,IACJ;AACA,WAAO,UAAU,aAAa,CAAC,EAAE,GAAG,GAAG;AAEvC,aAAS,SAAS,QAAQ,WAAW;AAErC,iBAAa;AAAA,MACT,MAAM,QAAQ,KAAK,QAAQ,SAAS,cAAc;AAAA,QAC9C,SAAS;AAAA,QACT,WAAW;AAAA,QACX,QAAQ;AAAA,MACZ,CAAC;AAAA,IACL;AACA,UAAM;AAEN,WAAO,UAAU,aAAa,CAAC,EAAE,GAAG,GAAG;AACvC,WAAO,UAAU,YAAY,CAAC,EAAE,GAAG,GAAG;AAAA,EAC1C,CAAC;AAED,KAAG,qBAAqB,YAAY;AAChC,UAAM,KAAK,MAAM,QAAwB;AAAA;AAAA;AAAA;AAAA,SAIxC;AAED,UAAM,SAAS,GAAG,cAAc,WAAW;AAE3C,UAAM,SAAS,SAAS,IAAI,WAAW;AACvC,iBAAa;AAAA,MACT,MAAM,QAAQ,KAAK,IAAI,SAAS,QAAQ;AAAA,QACpC,SAAS;AAAA,QACT,WAAW;AAAA,QACX,QAAQ;AAAA,MACZ,CAAC;AAAA,IACL;AACA,UAAM;AAEN,WAAO,MAAM;AAEb,UAAM;AAAA,MACF,MACI,CAAC,CAAC,OAAO,iBACT,OAAO,cAAc,YAAY;AAAA,MACrC;AAAA,IACJ;AAAA,EACJ,CAAC;AAED,KAAG,0DAA0D,YAAY;AACrE,UAAM,KAAK,MAAM,QAAwB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAQxC;AAED,UAAM,UAAU,GAAG,cAAc,UAAU;AAC3C,UAAM,UAAU,GAAG,cAAc,UAAU;AAC3C,UAAM,QAAQ,GAAG,cAAc,OAAO;AACtC,UAAM,QAAQ,GAAG,cAAc,QAAQ;AAEvC,iBAAa,KAAK,MAAM,QAAQ,KAAK,SAAS,UAAU,SAAS,CAAC,CAAC,CAAC;AAEpE,YAAQ,MAAM;AACd,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,aAAa,EAAE,GAAG,MAAM,KAAK;AAC7C,WAAO,MAAM,QAAQ,gBAAgB,MAAM,IAAI;AAE/C,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,aAAa,EAAE,GAAG,MAAM,OAAO;AAE/C,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,aAAa,EAAE,GAAG,MAAM,KAAK;AAE7C,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,aAAa,EAAE,GAAG,MAAM,KAAK;AAC7C,UAAM;AAAA,MACF,MAAM,SAAS,cAAc,gBAAgB,MAAM;AAAA,IACvD;AAAA,EACJ,CAAC;AAED,KAAG,4DAA4D,YAAY;AACvE,UAAM,KAAK,MAAM,QAAwB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAWxC;AAED,UAAM,UAAU,GAAG,cAAc,UAAU;AAC3C,UAAM,UAAU,GAAG,cAAc,UAAU;AAC3C,UAAM,QAAQ,GAAG,cAAc,gBAAgB;AAC/C,UAAM,SAAS,GAAG,cAAc,SAAS;AAEzC,iBAAa,KAAK,MAAM,QAAQ,KAAK,SAAS,UAAU,SAAS,CAAC,CAAC,CAAC;AAEpE,YAAQ,MAAM;AACd,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,aAAa,EAAE,GAAG,MAAM,KAAK;AAC7C,WAAO,MAAM,QAAQ,gBAAgB,MAAM,IAAI;AAE/C,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,aAAa,EAAE,GAAG,MAAM,OAAO;AAE/C,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,aAAa,EAAE,GAAG,MAAM,MAAM;AAC9C,UAAM;AAAA,MACF,MAAM,SAAS,cAAc,gBAAgB,MAAM;AAAA,IACvD;AAAA,EACJ,CAAC;AAED,KAAG,0BAA0B,YAAY;AACrC,UAAM,cAAc;AACpB,UAAM,KAAK,MAAM;AAAA,MACb;AAAA;AAAA;AAAA,IAGJ;AAEA,UAAM,UAAU,SAAS,cAAc,KAAK;AAC5C,YAAQ,cAAc;AAEtB,UAAM,SAAS,SAAS,IAAI,WAAW;AACvC,UAAM,eAAe,MAAM,QAAQ,KAAK,IAAI,SAAS,SAAS;AAAA,MAC1D,WAAW;AAAA,IACf,CAAC;AACD,UAAM;AAEN,QAAI,gBAAgB,SAAS,cAAc,gBAAgB;AAE3D,QAAI,eAAe;AACf,aAAO,cAAc,WAAW,EAAE,GAAG,MAAM,WAAW;AAAA,IAC1D,OAAO;AACH,aAAO,aAAa,EAAE,GAAG,IAAI,GAAG;AAAA,IACpC;AAEA,UAAM,SAAS,SAAS,IAAI,WAAW;AACvC,iBAAa;AACb,UAAM;AAEN,oBAAgB,SAAS,cAAc,gBAAgB;AAEvD,WAAO,aAAa,EAAE,GAAG,GAAG;AAE5B,YAAQ,OAAO;AAAA,EACnB,CAAC;AACL,CAAC;AACD,SAAS,0BAA0B,MAAM;AACrC,KAAG,kEAAkE,YAAY;AAC7E,UAAM,QAAwB;AAAA,cACxB,eAAe;AAAA,MACb,GAAG,eAAe;AAAA,MAClB,QAAQ;AAAA,IACZ,CAAC;AAAA,SACJ;AACD,UAAM,QAAQ,OAAO;AACrB,UAAM,SAAS,OAAO;AACtB,QAAI,SAAS,SAAS,UAAU,WAAW;AAE3C,cAAU;AAAA,MACN,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU,CAAC,QAAQ,IAAI,IAAI,SAAS,CAAC;AAAA,QACzC;AAAA,QACA;AAAA,UACI,MAAM;AAAA,UACN,SAAS;AAAA,YACL,QAAQ;AAAA,UACZ;AAAA,UACA,UAAU,CAAC,QAAQ,IAAI,IAAI,SAAS,CAAC;AAAA,QACzC;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM;AACN,UAAM,eAAe,SAAS;AAAA,MAC1B;AAAA,IACJ;AACA,UAAM,gBAAgB,aAAa;AAAA,MAC/B;AAAA,IACJ;AACA,WAAO,cAAc,eAAe,EAAE,GAAG,IAAI,GAAG;AAChD,WAAO,aAAa,WAAW,EAAE,GAAG,GAAG;AACvC,WAAO,cAAc,WAAW,EAAE,GAAG,MAAM,kBAAkB;AAC7D,QAAI,SAAS,SAAS,UAAU,WAAW;AAC3C,aAAS,SAAS,UAAU,WAAW;AAIvC,cAAU;AAAA,MACN,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU,CAAC,QAAQ,GAAG,SAAS,CAAC;AAAA,QACpC;AAAA,QACA;AAAA,UACI,MAAM;AAAA,UACN,SAAS;AAAA,YACL,QAAQ;AAAA,UACZ;AAAA,UACA,UAAU,CAAC,QAAQ,GAAG,SAAS,CAAC;AAAA,QACpC;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM;AACN,UAAM;AACN,UAAM,gBAAgB,SAAS;AAAA,MAC3B;AAAA,IACJ;AACA,UAAM,iBAAiB,cAAc;AAAA,MACjC;AAAA,IACJ;AACA,WAAO,eAAe,gBAAgB,EAAE,GAAG,IAAI,GAAG;AAClD,WAAO,aAAa,EAAE,GAAG,IAAI,MAAM,YAAY;AAC/C,WAAO,aAAa,WAAW,EAAE,GAAG,GAAG;AACvC,WAAO,cAAc,WAAW,EAAE,GAAG,GAAG;AACxC,WAAO,eAAe,WAAW,EAAE,GAAG,MAAM,oBAAoB;AAChE,aAAS,SAAS,UAAU,WAAW;AACvC,cAAU;AAAA,MACN,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU,CAAC,QAAQ,GAAG,SAAS,CAAC;AAAA,QACpC;AAAA,QACA;AAAA,UACI,MAAM;AAAA,UACN,UAAU,CAAC,QAAQ,GAAG,SAAS,CAAC;AAAA,QACpC;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM;AACN,UAAM,UAAU;AAAA,EACpB,CAAC;AAED,KAAG,6CAA6C,YAAY;AACxD,UAAM,QAAwB;AAAA,cACxB,eAAe;AAAA,MACb,GAAG,eAAe;AAAA,MAClB,QAAQ;AAAA,IACZ,CAAC;AAAA,SACJ;AAED,UAAM,YAAY,EAAE,OAAO,KAAK,QAAQ,IAAI,CAAC;AAE7C,UAAM,UAAU;AAEhB,UAAM,SAAS,SAAS,UAAU,WAAW;AAE7C,cAAU;AAAA,MACN,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU,CAAC,KAAK,EAAE;AAAA,QACtB;AAAA,QACA;AAAA,UACI,MAAM;AAAA,UACN,SAAS;AAAA,YACL,QAAQ;AAAA,UACZ;AAAA,UACA,UAAU,CAAC,KAAK,EAAE;AAAA,QACtB;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM;AAEN,UAAM,gBAAgB,SAAS;AAAA,MAC3B;AAAA,IACJ;AAEA,WAAO,cAAc,SAAS,EAAE,GAAG,MAAM,aAAa;AACtD,WAAO,cAAc,aAAa,kBAAkB,CAAC,EAAE,GAAG;AAAA,MACtD;AAAA,IACJ;AAEA,UAAM,SAAS,SAAS,UAAU,WAAW;AAC7C,aAAS;AAAA,MACL,OAAO;AAAA,IACX,CAAC;AACD,UAAM;AACN,UAAM,UAAU;AAAA,EACpB,CAAC;AAED,KAAG,0DAA0D,YAAY;AACrE,UAAM,KAAK,MAAM,QAAwB,sBAAsB,CAAC;AAChE,UAAM,UAAU,GAAG;AAAA,MACf;AAAA,IACJ;AACA,QAAI,OAAO,SAAS,IAAI,WAAW;AACnC,YAAQ,MAAM;AACd,UAAM;AACN,UAAM,UAAU,SAAS;AAAA,MACrB;AAAA,IACJ;AACA,WAAO,SAAS,SAAS,WAAW;AACpC,YAAQ,OAAO,MAAM;AACrB,UAAM;AACN,UAAM,iBAAiB,SAAS,iBAAiB,gBAAgB;AACjE,mBAAe,QAAQ,CAAC,YAAY;AAChC,aAAO,QAAQ,IAAI,EAAE,GAAG,MAAM,MAAM;AAAA,IACxC,CAAC;AACD,QAAI,QAAQ,SAAS,SAAS,WAAW;AACzC,YAAQ,QAAQ,gBAAgB,MAAM;AACtC,UAAM;AACN,YAAQ,SAAS,IAAI,WAAW;AAChC,OAAG,gBAAgB,MAAM;AACzB,UAAM;AAAA,EACV,CAAC;AACL,CAAC;AACD,SAAS,oBAAoB,MAAM;AAC/B,KAAG,yEAAyE,YAAY;AACpF,UAAM,OAAO,MAAM,QAAwB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAkB1C;AAED,UAAM,kBAAkB,KAAK;AAAA,MACzB;AAAA,IACJ;AACA,UAAM,kBAAkB,KAAK;AAAA,MACzB;AAAA,IACJ;AACA,UAAM,WAAW,gBAAgB;AAAA,MAC7B;AAAA,IACJ;AACA,UAAM,WAAW,gBAAgB;AAAA,MAC7B;AAAA,IACJ;AAEA,UAAM,uBAAuB,SAAS,sBAAsB;AAC5D,UAAM,uBAAuB,SAAS,sBAAsB;AAC5D,UAAM,mBAAqC;AAAA,MACvC,qBAAqB,OAAO,qBAAqB,QAAQ;AAAA,MACzD,qBAAqB,MAAM,qBAAqB,SAAS;AAAA,IAC7D;AACA,UAAM,kBAAoC;AAAA,MACtC,qBAAqB,OAAO,qBAAqB,QAAQ;AAAA,MACzD,qBAAqB,MAAM,qBAAqB,SAAS;AAAA,IAC7D;AACA,UAAM,mBAAqC;AAAA,MACvC,qBAAqB,OAAO,qBAAqB,QAAQ;AAAA,MACzD,qBAAqB,MAAM,qBAAqB,SAAS;AAAA,IAC7D;AACA,UAAM,kBAAoC;AAAA,MACtC,qBAAqB,OAAO,qBAAqB,QAAQ;AAAA,MACzD,qBAAqB,MAAM,qBAAqB,SAAS;AAAA,IAC7D;AAEA,UAAM,UAAU;AAAA,MACZ,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU;AAAA,QACd;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM,UAAU;AAChB,UAAM,UAAU;AAChB,UAAM,UAAU;AAAA,MACZ,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU;AAAA,QACd;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM,UAAU;AAChB,UAAM,UAAU;AAChB,UAAM,UAAU;AAAA,MACZ,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU;AAAA,QACd;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM,UAAU;AAChB,UAAM,UAAU;AAChB,UAAM,SAAS,SAAS,UAAU,WAAW;AAC7C,cAAU;AAAA,MACN,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU;AAAA,QACd;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM;AAEN,WAAO,gBAAgB,aAAa,MAAM,CAAC,EAAE,GAAG,GAAG;AACnD,WAAO,gBAAgB,aAAa,MAAM,CAAC,EAAE,GAAG,GAAG;AACnD,WAAO,gBAAgB,aAAa,MAAM,CAAC,EAAE,GAAG,MAAM,OAAO;AAE7D,UAAM,SAAS,SAAS,iBAAiB,WAAW;AACpD,cAAU;AAAA,MACN,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU;AAAA,QACd;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,UAAM;AAGN,aAAS,IAAI,GAAG,IAAI,GAAG;AAAK,YAAM,UAAU;AAE5C,WAAO,gBAAgB,aAAa,MAAM,CAAC,EAAE,GAAG,GAAG;AACnD,WAAO,gBAAgB,aAAa,MAAM,GAAG,gBAAgB,IAAI,EAAE,GAAG,GACjE;AAAA,EACT,CAAC;AACL,CAAC;",
|
|
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*/\nimport '@spectrum-web-components/button/sp-button.js';\nimport '@spectrum-web-components/dialog/sp-dialog.js';\nimport { Dialog } from '@spectrum-web-components/dialog';\nimport '@spectrum-web-components/popover/sp-popover.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport { setViewport } from '@web/test-runner-commands';\nimport {\n ActiveOverlay,\n Overlay,\n OverlayTrigger,\n Placement,\n} from '@spectrum-web-components/overlay';\n\nimport { isVisible } from '../../../test/testing-helpers.js';\nimport {\n elementUpdated,\n expect,\n fixture,\n html,\n nextFrame,\n oneEvent,\n waitUntil,\n} from '@open-wc/testing';\nimport { sendKeys } from '@web/test-runner-commands';\nimport {\n definedOverlayElement,\n virtualElement,\n} from '../stories/overlay.stories';\nimport { PopoverContent } from '../stories/overlay-story-components.js';\nimport { sendMouse } from '../../../test/plugins/browser.js';\n\ndescribe('Overlays', () => {\n let testDiv!: HTMLDivElement;\n let openOverlays: (() => void)[] = [];\n\n beforeEach(async () => {\n testDiv = await fixture<HTMLDivElement>(\n html`\n <div id=\"top\">\n <style>\n body {\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n #top {\n margin: 100px;\n }\n\n sp-button {\n flex: none;\n }\n\n #overlay-content {\n display: none;\n }\n </style>\n <sp-button\n id=\"first-button\"\n variant=\"primary\"\n slot=\"trigger\"\n >\n Show Popover\n </sp-button>\n <div id=\"overlay-content\">\n <sp-popover\n id=\"outer-popover\"\n slot=\"click-content\"\n direction=\"bottom\"\n tip\n open\n >\n <sp-dialog class=\"options-popover-content\">\n A popover message\n </sp-dialog>\n </sp-popover>\n <div id=\"hover-1\" class=\"hover-content\">\n Hover message\n </div>\n <div id=\"hover-2\" class=\"hover-content\">\n Other hover message\n </div>\n </div>\n </div>\n `\n );\n await elementUpdated(testDiv);\n });\n\n afterEach(() => {\n openOverlays.map((close) => close());\n openOverlays = [];\n });\n\n [\n 'bottom',\n 'bottom-start',\n 'bottom-end',\n 'top',\n 'top-start',\n 'top-end',\n 'left',\n 'left-start',\n 'left-end',\n 'right',\n 'right-start',\n 'right-end',\n 'none',\n ].map((direction) => {\n const placement = direction as Placement;\n it(`opens a popover - ${placement}`, async () => {\n const button = testDiv.querySelector(\n '#first-button'\n ) as HTMLElement;\n const outerPopover = testDiv.querySelector(\n '#outer-popover'\n ) as Popover;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).to.equal(\n 'overlay-content'\n );\n }\n\n expect(isVisible(outerPopover)).to.be.false;\n\n expect(button).to.exist;\n\n const opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'click', outerPopover, {\n delayed: false,\n placement,\n offset: 10,\n })\n );\n await opened;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).not.to.equal(\n 'overlay-content'\n );\n }\n expect(isVisible(outerPopover)).to.be.true;\n });\n });\n\n it(`updates a popover`, async () => {\n const button = testDiv.querySelector('#first-button') as HTMLElement;\n const outerPopover = testDiv.querySelector('#outer-popover') as Popover;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).to.equal('overlay-content');\n }\n\n expect(isVisible(outerPopover)).to.be.false;\n\n expect(button).to.exist;\n\n const opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'click', outerPopover, {\n delayed: false,\n offset: 10,\n })\n );\n await opened;\n\n expect(isVisible(outerPopover)).to.be.true;\n\n Overlay.update();\n\n expect(isVisible(outerPopover)).to.be.true;\n });\n\n it(`opens a popover w/ delay`, async () => {\n const button = testDiv.querySelector('#first-button') as HTMLElement;\n const outerPopover = testDiv.querySelector('#outer-popover') as Popover;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).to.equal('overlay-content');\n }\n\n expect(isVisible(outerPopover)).to.be.false;\n\n expect(button).to.exist;\n\n const opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'click', outerPopover, {\n delayed: true,\n offset: 10,\n })\n );\n await opened;\n\n expect(outerPopover.parentElement).to.exist;\n if (outerPopover.parentElement) {\n expect(outerPopover.parentElement.id).not.to.equal(\n 'overlay-content'\n );\n }\n expect(isVisible(outerPopover)).to.be.true;\n });\n\n it('opens hover overlay', async () => {\n const button = testDiv.querySelector('#first-button') as HTMLElement;\n const hoverOverlay = testDiv.querySelector('#hover-1') as HTMLElement;\n const clickOverlay = testDiv.querySelector(\n '#outer-popover'\n ) as HTMLElement;\n\n expect(isVisible(hoverOverlay)).to.be.false;\n expect(isVisible(clickOverlay)).to.be.false;\n\n let opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'hover', hoverOverlay, {\n delayed: false,\n placement: 'top',\n offset: 10,\n })\n );\n await opened;\n\n expect(hoverOverlay.parentElement).to.exist;\n if (hoverOverlay.parentElement) {\n expect(hoverOverlay.parentElement.id).not.to.equal(\n 'overlay-content'\n );\n }\n expect(isVisible(hoverOverlay)).to.be.true;\n\n opened = oneEvent(button, 'sp-opened');\n // Opening click overlay should close the hover overlay\n openOverlays.push(\n await Overlay.open(button, 'click', clickOverlay, {\n delayed: false,\n placement: 'bottom',\n offset: 10,\n })\n );\n await opened;\n if (hoverOverlay.parentElement) {\n expect(hoverOverlay.parentElement.id).to.equal('overlay-content');\n }\n\n expect(isVisible(hoverOverlay)).to.be.false;\n expect(isVisible(clickOverlay)).to.be.true;\n });\n\n it('opens custom overlay', async () => {\n const button = testDiv.querySelector('#first-button') as HTMLElement;\n const customOverlay = testDiv.querySelector('#hover-1') as HTMLElement;\n const clickOverlay = testDiv.querySelector(\n '#outer-popover'\n ) as HTMLElement;\n\n expect(button).to.exist;\n expect(customOverlay).to.exist;\n\n expect(isVisible(customOverlay)).to.be.false;\n expect(isVisible(clickOverlay)).to.be.false;\n\n let opened = oneEvent(button, 'sp-opened');\n openOverlays.push(\n await Overlay.open(button, 'custom', customOverlay, {\n delayed: false,\n placement: 'top',\n offset: 10,\n })\n );\n await opened;\n\n expect(customOverlay.parentElement).to.exist;\n if (customOverlay.parentElement) {\n expect(customOverlay.parentElement.id).not.to.equal(\n 'overlay-content'\n );\n }\n expect(isVisible(customOverlay)).to.be.true;\n\n opened = oneEvent(button, 'sp-opened');\n // Opening click overlay should close the hover overlay\n openOverlays.push(\n await Overlay.open(button, 'click', clickOverlay, {\n delayed: false,\n placement: 'bottom',\n offset: 10,\n })\n );\n await opened;\n\n expect(isVisible(customOverlay)).to.be.true;\n expect(isVisible(clickOverlay)).to.be.true;\n });\n\n it('closes via events', async () => {\n const el = await fixture<HTMLDivElement>(html`\n <div id=\"root\">\n <sp-dialog dismissable></sp-dialog>\n </div>\n `);\n\n const dialog = el.querySelector('sp-dialog') as Dialog;\n\n const opened = oneEvent(el, 'sp-opened');\n openOverlays.push(\n await Overlay.open(el, 'click', dialog, {\n delayed: false,\n placement: 'bottom',\n offset: 10,\n })\n );\n await opened;\n\n dialog.close();\n\n await waitUntil(\n () =>\n !!dialog.parentElement &&\n dialog.parentElement.tagName !== 'ACTIVE-OVERLAY',\n 'content is returned'\n );\n });\n\n it('closes an inline overlay when tabbing past the content', async () => {\n const el = await fixture<HTMLDivElement>(html`\n <div>\n <sp-button class=\"trigger\">Trigger</sp-button>\n <div class=\"content\">\n <input />\n </div>\n <input value=\"After\" id=\"after\" />\n </div>\n `);\n\n const trigger = el.querySelector('.trigger') as HTMLElement;\n const content = el.querySelector('.content') as HTMLElement;\n const input = el.querySelector('input') as HTMLInputElement;\n const after = el.querySelector('#after') as HTMLAnchorElement;\n\n openOverlays.push(await Overlay.open(trigger, 'inline', content, {}));\n\n trigger.focus();\n await sendKeys({\n press: 'Tab',\n });\n\n expect(document.activeElement).to.equal(input);\n expect(input.closest('active-overlay') !== null);\n\n await sendKeys({\n press: 'Shift+Tab',\n });\n\n expect(document.activeElement).to.equal(trigger);\n\n await sendKeys({\n press: 'Tab',\n });\n\n expect(document.activeElement).to.equal(input);\n\n await sendKeys({\n press: 'Tab',\n });\n\n expect(document.activeElement).to.equal(after);\n await waitUntil(\n () => document.querySelector('active-overlay') === null\n );\n });\n\n it('closes an inline overlay when tabbing before the trigger', async () => {\n const el = await fixture<HTMLDivElement>(html`\n <div>\n <input value=\"Before\" id=\"before\" />\n <sp-button class=\"trigger\">Trigger</sp-button>\n <div class=\"content\">\n <label>\n Content in an inline overlay.\n <input />\n </label>\n </div>\n </div>\n `);\n\n const trigger = el.querySelector('.trigger') as HTMLElement;\n const content = el.querySelector('.content') as HTMLElement;\n const input = el.querySelector('.content input') as HTMLInputElement;\n const before = el.querySelector('#before') as HTMLAnchorElement;\n\n openOverlays.push(await Overlay.open(trigger, 'inline', content, {}));\n\n trigger.focus();\n await sendKeys({\n press: 'Tab',\n });\n\n expect(document.activeElement).to.equal(input);\n expect(input.closest('active-overlay') !== null);\n\n await sendKeys({\n press: 'Shift+Tab',\n });\n\n expect(document.activeElement).to.equal(trigger);\n\n await sendKeys({\n press: 'Shift+Tab',\n });\n\n expect(document.activeElement).to.equal(before);\n await waitUntil(\n () => document.querySelector('active-overlay') === null\n );\n });\n\n it('opens detached content', async () => {\n const textContent = 'This is a detached element that has been overlaid';\n const el = await fixture<HTMLButtonElement>(\n html`\n <button>Trigger</button>\n `\n );\n\n const content = document.createElement('div');\n content.textContent = textContent;\n\n const opened = oneEvent(el, 'sp-opened');\n const closeOverlay = await Overlay.open(el, 'click', content, {\n placement: 'bottom',\n });\n await opened;\n\n let activeOverlay = document.querySelector('active-overlay');\n\n if (activeOverlay) {\n expect(activeOverlay.textContent).to.equal(textContent);\n } else {\n expect(activeOverlay).to.not.be.null;\n }\n\n const closed = oneEvent(el, 'sp-closed');\n closeOverlay();\n await closed;\n\n activeOverlay = document.querySelector('active-overlay');\n\n expect(activeOverlay).to.be.null;\n\n content.remove();\n });\n});\ndescribe('Overlay - type=\"modal\"', () => {\n it('closes on `contextmenu` and passes that to the underlying page', async () => {\n await fixture<HTMLDivElement>(html`\n ${virtualElement({\n ...virtualElement.args,\n offset: 6,\n })}\n `);\n const width = window.innerWidth;\n const height = window.innerHeight;\n let opened = oneEvent(document, 'sp-opened');\n // Right click to open \"context menu\" overlay.\n sendMouse({\n steps: [\n {\n type: 'move',\n position: [width / 2 + 50, height / 2],\n },\n {\n type: 'click',\n options: {\n button: 'right',\n },\n position: [width / 2 + 50, height / 2],\n },\n ],\n });\n await opened;\n const firstOverlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n const firstHeadline = firstOverlay.querySelector(\n '[slot=\"header\"]'\n ) as HTMLSpanElement;\n expect(firstOverlay, 'first overlay').to.not.be.null;\n expect(firstOverlay.isConnected).to.be.true;\n expect(firstHeadline.textContent).to.equal('Menu source: end');\n let closed = oneEvent(document, 'sp-closed');\n opened = oneEvent(document, 'sp-opened');\n // Right click to out of the \"context menu\" overlay to both close\n // the first overlay and have the event passed to the surfacing page\n // in order to open a subsequent \"context menu\" overlay.\n sendMouse({\n steps: [\n {\n type: 'move',\n position: [width / 4, height / 4],\n },\n {\n type: 'click',\n options: {\n button: 'right',\n },\n position: [width / 4, height / 4],\n },\n ],\n });\n await closed;\n await opened;\n const secondOverlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n const secondHeadline = secondOverlay.querySelector(\n '[slot=\"header\"]'\n ) as HTMLSpanElement;\n expect(secondOverlay, 'second overlay').to.not.be.null;\n expect(secondOverlay).to.not.equal(firstOverlay);\n expect(firstOverlay.isConnected).to.be.false;\n expect(secondOverlay.isConnected).to.be.true;\n expect(secondHeadline.textContent).to.equal('Menu source: start');\n closed = oneEvent(document, 'sp-closed');\n sendMouse({\n steps: [\n {\n type: 'move',\n position: [width / 8, height / 8],\n },\n {\n type: 'click',\n position: [width / 8, height / 8],\n },\n ],\n });\n await closed;\n await nextFrame();\n });\n\n it('does not open content off of the viewport', async () => {\n await fixture<HTMLDivElement>(html`\n ${virtualElement({\n ...virtualElement.args,\n offset: 6,\n })}\n `);\n\n await setViewport({ width: 360, height: 640 });\n // Allow viewport update to propagate.\n await nextFrame();\n\n const opened = oneEvent(document, 'sp-opened');\n // Right click to open \"context menu\" overlay.\n sendMouse({\n steps: [\n {\n type: 'move',\n position: [270, 10],\n },\n {\n type: 'click',\n options: {\n button: 'right',\n },\n position: [270, 10],\n },\n ],\n });\n await opened;\n\n const activeOverlay = document.querySelector(\n 'active-overlay'\n ) as ActiveOverlay;\n\n expect(activeOverlay.placement).to.equal('right-start');\n expect(activeOverlay.getAttribute('actual-placement')).to.equal(\n 'bottom'\n );\n\n const closed = oneEvent(document, 'sp-closed');\n sendKeys({\n press: 'Escape',\n });\n await closed;\n await nextFrame();\n });\n\n it('opens children in the modal stack through shadow roots', async () => {\n const el = await fixture<OverlayTrigger>(definedOverlayElement());\n const trigger = el.querySelector(\n '[slot=\"trigger\"]'\n ) as HTMLButtonElement;\n let open = oneEvent(el, 'sp-opened');\n trigger.click();\n await open;\n const content = document.querySelector(\n 'popover-content'\n ) as PopoverContent;\n open = oneEvent(content, 'sp-opened');\n content.button.click();\n await open;\n const activeOverlays = document.querySelectorAll('active-overlay');\n activeOverlays.forEach((overlay) => {\n expect(overlay.slot).to.equal('open');\n });\n let close = oneEvent(content, 'sp-closed');\n content.trigger.removeAttribute('open');\n await close;\n close = oneEvent(el, 'sp-closed');\n el.removeAttribute('open');\n await close;\n });\n});\ndescribe('Overlay - timing', () => {\n it('manages multiple modals in a row without preventing them from closing', async () => {\n const test = await fixture<HTMLDivElement>(html`\n <div>\n <overlay-trigger>\n <sp-button slot=\"trigger\">Trigger 1</sp-button>\n <sp-popover slot=\"hover-content\">\n <p>Hover contentent for \"Trigger 1\".</p>\n </sp-popover>\n </overlay-trigger>\n <overlay-trigger>\n <sp-button slot=\"trigger\">Trigger 2</sp-button>\n <sp-popover slot=\"hover-content\">\n <p>Hover contentent for \"Trigger 2\".</p>\n </sp-popover>\n <sp-popover slot=\"click-content\">\n <p>Click contentent for \"Trigger 2\".</p>\n </sp-popover>\n </overlay-trigger>\n </div>\n `);\n\n const overlayTrigger1 = test.querySelector(\n 'overlay-trigger:first-child'\n ) as OverlayTrigger;\n const overlayTrigger2 = test.querySelector(\n 'overlay-trigger:last-child'\n ) as OverlayTrigger;\n const trigger1 = overlayTrigger1.querySelector(\n '[slot=\"trigger\"]'\n ) as HTMLButtonElement;\n const trigger2 = overlayTrigger2.querySelector(\n '[slot=\"trigger\"]'\n ) as HTMLButtonElement;\n\n const boundingRectTrigger1 = trigger1.getBoundingClientRect();\n const boundingRectTrigger2 = trigger2.getBoundingClientRect();\n const trigger1Position: [number, number] = [\n boundingRectTrigger1.left + boundingRectTrigger1.width / 2,\n boundingRectTrigger1.top + boundingRectTrigger1.height / 2,\n ];\n const outsideTrigger1: [number, number] = [\n boundingRectTrigger1.left + boundingRectTrigger1.width * 2,\n boundingRectTrigger1.top + boundingRectTrigger1.height * 2,\n ];\n const trigger2Position: [number, number] = [\n boundingRectTrigger2.left + boundingRectTrigger2.width / 2,\n boundingRectTrigger2.top + boundingRectTrigger2.height / 2,\n ];\n const outsideTrigger2: [number, number] = [\n boundingRectTrigger2.left + boundingRectTrigger2.width * 2,\n boundingRectTrigger2.top + boundingRectTrigger2.height / 2,\n ];\n\n await sendMouse({\n steps: [\n {\n type: 'move',\n position: trigger1Position,\n },\n ],\n });\n await nextFrame();\n await nextFrame();\n await sendMouse({\n steps: [\n {\n type: 'move',\n position: outsideTrigger1,\n },\n ],\n });\n await nextFrame();\n await nextFrame();\n await sendMouse({\n steps: [\n {\n type: 'move',\n position: trigger2Position,\n },\n ],\n });\n await nextFrame();\n await nextFrame();\n const opened = oneEvent(trigger2, 'sp-opened');\n sendMouse({\n steps: [\n {\n type: 'click',\n position: trigger2Position,\n },\n ],\n });\n await opened;\n\n expect(overlayTrigger1.hasAttribute('open')).to.be.false;\n expect(overlayTrigger2.hasAttribute('open')).to.be.true;\n expect(overlayTrigger2.getAttribute('open')).to.equal('click');\n\n const closed = oneEvent(overlayTrigger2, 'sp-closed');\n sendMouse({\n steps: [\n {\n type: 'click',\n position: outsideTrigger2,\n },\n ],\n });\n await closed;\n\n // sometimes safari needs to wait a few frames for the open attribute to update\n for (let i = 0; i < 3; i++) await nextFrame();\n\n expect(overlayTrigger1.hasAttribute('open')).to.be.false;\n expect(overlayTrigger2.hasAttribute('open'), overlayTrigger2.open).to.be\n .false;\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|