@public-ui/components 1.5.0-rc.13 → 1.5.0-rc.14
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/cheat-sheet.html +14 -24
- package/custom-elements.json +5 -30
- package/dist/cjs/button-link-19d8a9a8.js.map +1 -1
- package/dist/cjs/icon-71b1bd66.js.map +1 -1
- package/dist/cjs/kol-abbr.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-accordion.cjs.entry.js +1 -1
- package/dist/cjs/kol-accordion.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-button-link.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-button-wc_3.cjs.entry.js +1 -1
- package/dist/cjs/kol-button-wc_3.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-button.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-color.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-color.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-date.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-date.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-email.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-email.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-file.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-file.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-number.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-number.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-password.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-password.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-range.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-range.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-text.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-text.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-link-button.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-link-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-link.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-nav.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-pagination.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-select.cjs.entry.js +1 -1
- package/dist/cjs/kol-select.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tabs.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-textarea.cjs.entry.js +1 -1
- package/dist/cjs/kol-textarea.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tooltip.cjs.entry.js +1 -1
- package/dist/cjs/kol-tooltip.cjs.entry.js.map +1 -1
- package/dist/cjs/kolibri.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/components/component.js +1 -1
- package/dist/components/component.js.map +1 -1
- package/dist/components/component12.js +1 -1
- package/dist/components/component12.js.map +1 -1
- package/dist/components/component14.js.map +1 -1
- package/dist/components/component15.js +1 -1
- package/dist/components/component15.js.map +1 -1
- package/dist/components/component3.js.map +1 -1
- package/dist/components/component5.js +1 -1
- package/dist/components/component5.js.map +1 -1
- package/dist/components/component8.js.map +1 -1
- package/dist/components/kol-abbr.js.map +1 -1
- package/dist/components/kol-accordion.js +1 -1
- package/dist/components/kol-accordion.js.map +1 -1
- package/dist/components/kol-button-link.js.map +1 -1
- package/dist/components/kol-input-color.js +1 -1
- package/dist/components/kol-input-color.js.map +1 -1
- package/dist/components/kol-input-date.js +1 -1
- package/dist/components/kol-input-date.js.map +1 -1
- package/dist/components/kol-input-email.js +1 -1
- package/dist/components/kol-input-email.js.map +1 -1
- package/dist/components/kol-input-file.js +1 -1
- package/dist/components/kol-input-file.js.map +1 -1
- package/dist/components/kol-input-password.js +1 -1
- package/dist/components/kol-input-password.js.map +1 -1
- package/dist/components/kol-input-range.js +1 -1
- package/dist/components/kol-input-range.js.map +1 -1
- package/dist/components/kol-input-text.js +1 -1
- package/dist/components/kol-input-text.js.map +1 -1
- package/dist/components/kol-link-button.js.map +1 -1
- package/dist/components/kol-nav.js.map +1 -1
- package/dist/components/kol-tabs.js.map +1 -1
- package/dist/components/kol-textarea.js +1 -1
- package/dist/components/kol-textarea.js.map +1 -1
- package/dist/components/shadow.js.map +1 -1
- package/dist/components/shadow2.js.map +1 -1
- package/dist/esm/button-link-0f3cba87.js.map +1 -1
- package/dist/esm/icon-00018c54.js.map +1 -1
- package/dist/esm/kol-abbr.entry.js.map +1 -1
- package/dist/esm/kol-accordion.entry.js +1 -1
- package/dist/esm/kol-accordion.entry.js.map +1 -1
- package/dist/esm/kol-button-link.entry.js.map +1 -1
- package/dist/esm/kol-button-wc_3.entry.js +1 -1
- package/dist/esm/kol-button-wc_3.entry.js.map +1 -1
- package/dist/esm/kol-button.entry.js.map +1 -1
- package/dist/esm/kol-input-color.entry.js +1 -1
- package/dist/esm/kol-input-color.entry.js.map +1 -1
- package/dist/esm/kol-input-date.entry.js +1 -1
- package/dist/esm/kol-input-date.entry.js.map +1 -1
- package/dist/esm/kol-input-email.entry.js +1 -1
- package/dist/esm/kol-input-email.entry.js.map +1 -1
- package/dist/esm/kol-input-file.entry.js +1 -1
- package/dist/esm/kol-input-file.entry.js.map +1 -1
- package/dist/esm/kol-input-number.entry.js +1 -1
- package/dist/esm/kol-input-number.entry.js.map +1 -1
- package/dist/esm/kol-input-password.entry.js +1 -1
- package/dist/esm/kol-input-password.entry.js.map +1 -1
- package/dist/esm/kol-input-range.entry.js +1 -1
- package/dist/esm/kol-input-range.entry.js.map +1 -1
- package/dist/esm/kol-input-text.entry.js +1 -1
- package/dist/esm/kol-input-text.entry.js.map +1 -1
- package/dist/esm/kol-link-button.entry.js.map +1 -1
- package/dist/esm/kol-link-wc.entry.js.map +1 -1
- package/dist/esm/kol-link.entry.js.map +1 -1
- package/dist/esm/kol-nav.entry.js.map +1 -1
- package/dist/esm/kol-pagination.entry.js.map +1 -1
- package/dist/esm/kol-select.entry.js +1 -1
- package/dist/esm/kol-select.entry.js.map +1 -1
- package/dist/esm/kol-tabs.entry.js.map +1 -1
- package/dist/esm/kol-textarea.entry.js +1 -1
- package/dist/esm/kol-textarea.entry.js.map +1 -1
- package/dist/esm/kol-tooltip.entry.js +1 -1
- package/dist/esm/kol-tooltip.entry.js.map +1 -1
- package/dist/esm/kolibri.js +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/kolibri/assets/bundes/style.css +4 -4
- package/dist/kolibri/assets/tabler-icons/tabler-icons.css +0 -1
- package/dist/kolibri/assets/tabler-icons/tabler-icons.min.css +1 -1
- package/dist/kolibri/button-link-0f3cba87.js.map +1 -1
- package/dist/kolibri/icon-00018c54.js.map +1 -1
- package/dist/kolibri/kol-abbr.entry.js.map +1 -1
- package/dist/kolibri/kol-accordion.entry.js +1 -1
- package/dist/kolibri/kol-accordion.entry.js.map +1 -1
- package/dist/kolibri/kol-button-link.entry.js.map +1 -1
- package/dist/kolibri/kol-button-wc_3.entry.js +1 -1
- package/dist/kolibri/kol-button-wc_3.entry.js.map +1 -1
- package/dist/kolibri/kol-button.entry.js.map +1 -1
- package/dist/kolibri/kol-input-color.entry.js +1 -1
- package/dist/kolibri/kol-input-color.entry.js.map +1 -1
- package/dist/kolibri/kol-input-date.entry.js +1 -1
- package/dist/kolibri/kol-input-date.entry.js.map +1 -1
- package/dist/kolibri/kol-input-email.entry.js +1 -1
- package/dist/kolibri/kol-input-email.entry.js.map +1 -1
- package/dist/kolibri/kol-input-file.entry.js +1 -1
- package/dist/kolibri/kol-input-file.entry.js.map +1 -1
- package/dist/kolibri/kol-input-number.entry.js +1 -1
- package/dist/kolibri/kol-input-number.entry.js.map +1 -1
- package/dist/kolibri/kol-input-password.entry.js +1 -1
- package/dist/kolibri/kol-input-password.entry.js.map +1 -1
- package/dist/kolibri/kol-input-range.entry.js +1 -1
- package/dist/kolibri/kol-input-range.entry.js.map +1 -1
- package/dist/kolibri/kol-input-text.entry.js +1 -1
- package/dist/kolibri/kol-input-text.entry.js.map +1 -1
- package/dist/kolibri/kol-link-button.entry.js.map +1 -1
- package/dist/kolibri/kol-link-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-link.entry.js.map +1 -1
- package/dist/kolibri/kol-nav.entry.js.map +1 -1
- package/dist/kolibri/kol-pagination.entry.js.map +1 -1
- package/dist/kolibri/kol-select.entry.js +1 -1
- package/dist/kolibri/kol-select.entry.js.map +1 -1
- package/dist/kolibri/kol-tabs.entry.js.map +1 -1
- package/dist/kolibri/kol-textarea.entry.js +1 -1
- package/dist/kolibri/kol-textarea.entry.js.map +1 -1
- package/dist/kolibri/kol-tooltip.entry.js +1 -1
- package/dist/kolibri/kol-tooltip.entry.js.map +1 -1
- package/dist/kolibri/kolibri.esm.js +1 -1
- package/dist/kolibri/kolibri.esm.js.map +1 -1
- package/dist/types/components/abbr/component.d.ts +3 -3
- package/dist/types/components/abbr/types.d.ts +2 -2
- package/dist/types/components/button/component.d.ts +5 -5
- package/dist/types/components/button/shadow.d.ts +3 -3
- package/dist/types/components/button-link/component.d.ts +2 -2
- package/dist/types/components/link/component.d.ts +5 -5
- package/dist/types/components/link/shadow.d.ts +3 -3
- package/dist/types/components/link-button/component.d.ts +2 -2
- package/dist/types/components/pagination/component.d.ts +5 -5
- package/dist/types/components/tabs/component.d.ts +6 -6
- package/dist/types/components/tooltip/component.d.ts +4 -4
- package/dist/types/components.d.ts +32 -61
- package/dist/types/types/button-link.d.ts +6 -6
- package/dist/types/types/props/alignment.d.ts +1 -6
- package/dist/types/types/props/icon.d.ts +3 -3
- package/dist/types/types/props/index.d.ts +1 -1
- package/dist/types/utils/validators/alignment.d.ts +2 -2
- package/doc/badge.md +8 -8
- package/doc/breadcrumb.md +1 -1
- package/doc/button.md +12 -21
- package/doc/icon.md +1 -1
- package/doc/input-color.md +18 -18
- package/doc/input-date.md +24 -24
- package/doc/input-email.md +25 -25
- package/doc/input-file.md +19 -19
- package/doc/input-number.md +25 -25
- package/doc/input-password.md +23 -23
- package/doc/input-text.md +25 -25
- package/doc/nav.md +10 -10
- package/doc/table.md +7 -7
- package/jest-test-results.json +1 -1
- package/package.json +1 -1
- package/vscode-custom-data.json +2 -33
- package/dist/cjs/floating-ui.dom.esm-c29f07df.js +0 -4
- package/dist/cjs/floating-ui.dom.esm-c29f07df.js.map +0 -1
- package/dist/cjs/kol-popover.cjs.entry.js +0 -4
- package/dist/cjs/kol-popover.cjs.entry.js.map +0 -1
- package/dist/cjs/open-fd1ca478.js +0 -4
- package/dist/cjs/open-fd1ca478.js.map +0 -1
- package/dist/components/floating-ui.dom.esm.js +0 -4
- package/dist/components/floating-ui.dom.esm.js.map +0 -1
- package/dist/components/kol-popover.d.ts +0 -11
- package/dist/components/kol-popover.js +0 -4
- package/dist/components/kol-popover.js.map +0 -1
- package/dist/components/open.js +0 -4
- package/dist/components/open.js.map +0 -1
- package/dist/esm/floating-ui.dom.esm-7168a219.js +0 -4
- package/dist/esm/floating-ui.dom.esm-7168a219.js.map +0 -1
- package/dist/esm/kol-popover.entry.js +0 -4
- package/dist/esm/kol-popover.entry.js.map +0 -1
- package/dist/esm/open-7d64cfaf.js +0 -4
- package/dist/esm/open-7d64cfaf.js.map +0 -1
- package/dist/kolibri/assets/popover-simulation.js +0 -1
- package/dist/kolibri/floating-ui.dom.esm-7168a219.js +0 -4
- package/dist/kolibri/floating-ui.dom.esm-7168a219.js.map +0 -1
- package/dist/kolibri/kol-popover.entry.js +0 -4
- package/dist/kolibri/kol-popover.entry.js.map +0 -1
- package/dist/kolibri/open-7d64cfaf.js +0 -4
- package/dist/kolibri/open-7d64cfaf.js.map +0 -1
- package/dist/types/components/popover/shadow.d.ts +0 -35
- package/dist/types/components/popover/test/html.mock.d.ts +0 -4
- package/doc/popover.md +0 -19
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["validateAlignment","component","value","watchString","defaultStyleCss","KolPopover","this","alignPopover","callBack","processEnv","triggerElement","popoverElement","trigger","popoverEl","arrowEl","arrowElement","middleware","offset","_a","offsetHeight","flip","shift","push","arrow","element","computePosition","placement","state","_alignment","then","x","y","middlewareData","setPosition","showPopover","addListenersToBody","Object","assign","_show","hidePopoverByEscape","event","key","hidePopover","hidePopoverByClickOutside","host","contains","target","catchHostAndTriggerElement","previousElementSibling","catchPopoverElement","catchArrowElement","_open","oldPos","left","style","top","inset","translate","focus","removeListenersToBody","body","getDocument","addEventListener","document","scrollingElement","passive","removeEventListener","render","h","Host","ref","class","popover","hidden","show","validateOpen","componentWillLoad"],"sources":["./src/types/props/alignment.ts","./src/components/popover/style.css?tag=kol-popover&mode=default&encapsulation=shadow","./src/components/popover/shadow.tsx"],"sourcesContent":["import { Generic } from '@a11y-ui/core';\nimport { watchString } from '../../utils/prop.validators';\n\n/* types */\n/** de\n * Markiert das Element als ausgewähltes/aktiviertes. Kann folgende Werte annehmen: `date` | `location` | `page` | `step` | `time` | `true`.\n * (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)\n */\n\n/** en\n * Marks the element as the selected in a group of related elements. Can be one of the following: `date` | `location` | `page` | `step` | `time` | `true`.\n * (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)\n */\ntype HorizontalAlignment = 'left' | 'right';\ntype VerticalAlignment = 'top' | 'bottom';\nexport type Alignment = HorizontalAlignment | VerticalAlignment;\nexport type PropAlignment = {\n\talignment: Alignment;\n};\n\n/* validator */\nexport const validateAlignment = (component: Generic.Element.Component, value?: Alignment): void => {\n\twatchString(component, '_alignment', value);\n};\n","@import '../style.css';\n\n:host {\n\theight: 0;\n\tposition: absolute;\n}\n\n.popover {\n\tbackground-color: white;\n\tbox-sizing: border-box;\n\topacity: 0;\n\tposition: absolute;\n}\n.hidden {\n\tdisplay: none;\n}\n.show {\n\tanimation: fadeInOpacity 300ms ease-in forwards;\n}\n.disappear {\n\tanimation: fadeInOpacity 300ms ease-in backwards;\n}\n\n.arrow {\n\tbackground-color: inherit;\n\theight: var(--font-size);\n\tposition: absolute;\n\trotate: 0.125turn;\n\twidth: var(--font-size);\n\tz-index: -1;\n}\n\n@keyframes fadeInOpacity {\n\t0% {\n\t\topacity: 0;\n\t}\n\t100% {\n\t\topacity: 1;\n\t}\n}\n","import { MiddlewareData, Placement, arrow, computePosition, flip, offset, shift } from '@floating-ui/dom';\nimport { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { Generic } from '@a11y-ui/core';\nimport { getDocument } from '../../utils/dev.utils';\nimport { processEnv } from '../../utils/reuse';\nimport { Alignment, PropAlignment, PropOpen, PropShow, validateAlignment, validateOpen } from '../../types/props';\n\ntype RequiredProps = unknown;\ntype OptionalProps = PropAlignment & PropOpen;\nexport type Props = Generic.Element.Members<RequiredProps, OptionalProps>;\n\ntype RequiredStates = PropAlignment & PropOpen & PropShow;\ntype OptionalStates = unknown;\nexport type States = Generic.Element.Members<RequiredStates, OptionalStates>;\n\ntype API = Generic.Element.ComponentApi<RequiredProps, OptionalProps, RequiredStates, OptionalStates>;\n\n@Component({\n\ttag: 'kol-popover',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolPopover implements API {\n\tprivate arrowElement?: HTMLDivElement;\n\tprivate popoverElement?: HTMLDivElement;\n\tprivate triggerElement?: HTMLElement | null;\n\tprivate host?: HTMLElement;\n\n\t/* Popover functions */\n\tprivate alignPopover = (callBack?: () => unknown): void => {\n\t\tif (processEnv !== 'test' && this.triggerElement && this.popoverElement) {\n\t\t\tconst trigger = this.triggerElement;\n\t\t\tconst popoverEl = this.popoverElement;\n\t\t\tconst arrowEl = this.arrowElement;\n\n\t\t\tconst middleware = [offset(arrowEl?.offsetHeight ?? 10), flip(), shift()];\n\t\t\tif (arrowEl) {\n\t\t\t\tmiddleware.push(arrow({ element: arrowEl }));\n\t\t\t}\n\n\t\t\tvoid computePosition(trigger, popoverEl, {\n\t\t\t\tplacement: this.state._alignment,\n\t\t\t\tmiddleware: middleware,\n\t\t\t}).then(({ x, y, middlewareData, placement }) => {\n\t\t\t\tthis.setPosition(x, y, middlewareData, placement, callBack);\n\t\t\t});\n\t\t}\n\t};\n\tprivate setPosition(x: number, y: number, middlewareData: MiddlewareData, placement: Placement, callBack?: () => unknown) {\n\t\tif (this.popoverElement) {\n\t\t\tconst oldPos = {\n\t\t\t\tleft: this.popoverElement.style.left,\n\t\t\t\ttop: this.popoverElement.style.top,\n\t\t\t};\n\t\t\tObject.assign(this.popoverElement.style, {\n\t\t\t\tleft: `${x}px`,\n\t\t\t\ttop: `${y}px`,\n\t\t\t});\n\n\t\t\tif (this.arrowElement && middlewareData.arrow) {\n\t\t\t\tswitch (placement) {\n\t\t\t\t\tcase 'top':\n\t\t\t\t\t\tthis.arrowElement.style.inset = `100% auto auto ${middlewareData.arrow.x || 0}px`;\n\t\t\t\t\t\tthis.arrowElement.style.translate = '0 -50%';\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'right':\n\t\t\t\t\t\tthis.arrowElement.style.inset = `${middlewareData.arrow.y || 0}px 100% auto auto`;\n\t\t\t\t\t\tthis.arrowElement.style.translate = '50% 0';\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'bottom':\n\t\t\t\t\t\tthis.arrowElement.style.inset = `auto auto 100% ${middlewareData.arrow.x || 0}px`;\n\t\t\t\t\t\tthis.arrowElement.style.translate = '0 50%';\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'left':\n\t\t\t\t\t\tthis.arrowElement.style.inset = `${middlewareData.arrow.y || 0}px auto auto 100%`;\n\t\t\t\t\t\tthis.arrowElement.style.translate = '-50% 0';\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (oldPos.left !== this.popoverElement.style.left || oldPos.top !== this.popoverElement.style.top) {\n\t\t\t\tthis.alignPopover(callBack);\n\t\t\t} else if (typeof callBack === 'function') {\n\t\t\t\tcallBack();\n\t\t\t}\n\t\t}\n\t}\n\tprivate showPopover = (): void => {\n\t\tthis.addListenersToBody();\n\n\t\tthis.alignPopover(() => {\n\t\t\tthis.state = { ...this.state, _show: true };\n\t\t});\n\t};\n\tprivate hidePopover(): void {\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t\t_show: false,\n\t\t};\n\t\tthis._open = false;\n\t\tthis.triggerElement?.focus();\n\t\tthis.removeListenersToBody();\n\t}\n\tprivate hidePopoverByEscape = (event: KeyboardEvent): void => {\n\t\tif (event.key === 'Escape') this.hidePopover();\n\t};\n\tprivate hidePopoverByClickOutside = (event: MouseEvent): void => {\n\t\tif (this.host && !this.host.contains(event.target as HTMLElement)) {\n\t\t\tthis.hidePopover();\n\t\t}\n\t};\n\n\t/* EventListener functions */\n\tprivate addListenersToBody(): void {\n\t\tconst body = getDocument().body;\n\t\tbody.addEventListener('keyup', this.hidePopoverByEscape);\n\t\tbody.addEventListener('click', this.hidePopoverByClickOutside);\n\t\tdocument.scrollingElement?.addEventListener('scroll', this.showPopover, { passive: true });\n\t}\n\tprivate removeListenersToBody(): void {\n\t\tconst body = getDocument().body;\n\t\tbody.removeEventListener('keyup', this.hidePopoverByEscape);\n\t\tbody.removeEventListener('click', this.hidePopoverByClickOutside);\n\t\tdocument.scrollingElement?.removeEventListener('scroll', this.showPopover);\n\t}\n\n\t/* catchElement functions */\n\tprivate catchHostAndTriggerElement = (element: HTMLElement | null): void => {\n\t\tif (element) {\n\t\t\tthis.host = element;\n\t\t\tthis.triggerElement = element.previousElementSibling as HTMLElement | null;\n\t\t}\n\t};\n\tprivate catchPopoverElement = (element?: HTMLDivElement): void => {\n\t\tthis.popoverElement = element;\n\t};\n\tprivate catchArrowElement = (element?: HTMLDivElement): void => {\n\t\tthis.arrowElement = element;\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host ref={this.catchHostAndTriggerElement}>\n\t\t\t\t<div class={{ popover: true, hidden: !this.state._open, show: this.state._show }} ref={this.catchPopoverElement}>\n\t\t\t\t\t<div class={`arrow ${this.state._alignment}`} ref={this.catchArrowElement} />\n\t\t\t\t\t<slot />\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Setzt die Ausrichtung des Popovers in Relation zum Triggerelement.\n\t */\n\t@Prop() public _alignment?: Alignment = 'top';\n\n\t/**\n\t * Öffnet/schließt das Popover.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _open?: boolean = false;\n\n\t@State() public state: States = {\n\t\t_alignment: 'top',\n\t\t_open: false,\n\t\t_show: false,\n\t};\n\n\t@Watch('_alignment')\n\tpublic validateAlignment(value?: Alignment): void {\n\t\tvalidateAlignment(this, value);\n\t}\n\n\t@Watch('_open')\n\tpublic validateOpen(value?: boolean): void {\n\t\tvalidateOpen(this, value);\n\t\tif (value) this.showPopover();\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAlignment(this._alignment);\n\t\tthis.validateOpen(this._open);\n\t}\n}\n"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["validateOpen","component","value","watchBoolean"],"sources":["./src/types/props/open.ts"],"sourcesContent":["import { Generic } from '@a11y-ui/core';\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\n/** de\n * Klappt das Element auf sofern gesetzt (oder true) und klappt es zu sofern nicht gesetzt (oder false).\n */\n/** en\n * If set (to true) opens/expands the element, closes if not set (or set to false).\n */\nexport type PropOpen = {\n\topen: boolean;\n};\n\n/* validator */\nexport const validateOpen = (component: Generic.Element.Component, value?: boolean): void => {\n\twatchBoolean(component, '_open', value);\n};\n"],"mappings":";;;wDAeaA,EAAe,CAACC,EAAsCC,KAClEC,EAAaF,EAAW,QAASC,EAAM,S"}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { JSX } from '../../stencil-public-runtime';
|
|
2
|
-
import { Generic } from '@a11y-ui/core';
|
|
3
|
-
import { Alignment, PropAlignment, PropOpen, PropShow } from '../../types/props';
|
|
4
|
-
type RequiredProps = unknown;
|
|
5
|
-
type OptionalProps = PropAlignment & PropOpen;
|
|
6
|
-
export type Props = Generic.Element.Members<RequiredProps, OptionalProps>;
|
|
7
|
-
type RequiredStates = PropAlignment & PropOpen & PropShow;
|
|
8
|
-
type OptionalStates = unknown;
|
|
9
|
-
export type States = Generic.Element.Members<RequiredStates, OptionalStates>;
|
|
10
|
-
type API = Generic.Element.ComponentApi<RequiredProps, OptionalProps, RequiredStates, OptionalStates>;
|
|
11
|
-
export declare class KolPopover implements API {
|
|
12
|
-
private arrowElement?;
|
|
13
|
-
private popoverElement?;
|
|
14
|
-
private triggerElement?;
|
|
15
|
-
private host?;
|
|
16
|
-
private alignPopover;
|
|
17
|
-
private setPosition;
|
|
18
|
-
private showPopover;
|
|
19
|
-
private hidePopover;
|
|
20
|
-
private hidePopoverByEscape;
|
|
21
|
-
private hidePopoverByClickOutside;
|
|
22
|
-
private addListenersToBody;
|
|
23
|
-
private removeListenersToBody;
|
|
24
|
-
private catchHostAndTriggerElement;
|
|
25
|
-
private catchPopoverElement;
|
|
26
|
-
private catchArrowElement;
|
|
27
|
-
render(): JSX.Element;
|
|
28
|
-
_alignment?: Alignment;
|
|
29
|
-
_open?: boolean;
|
|
30
|
-
state: States;
|
|
31
|
-
validateAlignment(value?: Alignment): void;
|
|
32
|
-
validateOpen(value?: boolean): void;
|
|
33
|
-
componentWillLoad(): void;
|
|
34
|
-
}
|
|
35
|
-
export {};
|
package/doc/popover.md
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
# Popover
|
|
2
|
-
|
|
3
|
-
Die **Popover**-Komponente stellt eine Möglichkeit dar zusätzliche Inhalte in ein temporäres Element zu setzen, das, ähnlich wie <kol-link _href="" _label="Tooltip"></kol-link>, um sein Triggerelement angeordnet ist.
|
|
4
|
-
Das Triggerelement ist immer das im HTML vorangehende Element (previousSibling).
|
|
5
|
-
|
|
6
|
-
<!-- Auto Generated Below -->
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
## Properties
|
|
10
|
-
|
|
11
|
-
| Property | Attribute | Description | Type | Default |
|
|
12
|
-
| ------------ | ------------ | ------------------------------------------------------------------ | ----------------------------------------------------- | ------- |
|
|
13
|
-
| `_alignment` | `_alignment` | Setzt die Ausrichtung des Popovers in Relation zum Triggerelement. | `"bottom" \| "left" \| "right" \| "top" \| undefined` | `'top'` |
|
|
14
|
-
| `_open` | `_open` | Öffnet/schließt das Popover. | `boolean \| undefined` | `false` |
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
----------------------------------------------
|
|
18
|
-
|
|
19
|
-
|