@limetech/lime-elements 37.11.2 → 37.11.4
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/CHANGELOG.md +18 -0
- package/dist/cjs/lime-elements.cjs.js +1 -1
- package/dist/cjs/limel-breadcrumbs_3.cjs.entry.js +14 -15
- package/dist/cjs/limel-breadcrumbs_3.cjs.entry.js.map +1 -1
- package/dist/cjs/{limel-file-dropzone.cjs.entry.js → limel-file-dropzone_2.cjs.entry.js} +97 -6
- package/dist/cjs/limel-file-dropzone_2.cjs.entry.js.map +1 -0
- package/dist/cjs/limel-file.cjs.entry.js +18 -115
- package/dist/cjs/limel-file.cjs.entry.js.map +1 -1
- package/dist/cjs/limel-picker.cjs.entry.js +218 -2
- package/dist/cjs/limel-picker.cjs.entry.js.map +1 -1
- package/dist/cjs/limel-tab-bar.cjs.entry.js +3 -0
- package/dist/cjs/limel-tab-bar.cjs.entry.js.map +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/collection/components/file/file.css +1 -5
- package/dist/collection/components/file/file.js +18 -116
- package/dist/collection/components/file/file.js.map +1 -1
- package/dist/collection/components/menu/menu.js +14 -17
- package/dist/collection/components/menu/menu.js.map +1 -1
- package/dist/collection/components/tab-bar/tab-bar.js +3 -0
- package/dist/collection/components/tab-bar/tab-bar.js.map +1 -1
- package/dist/esm/{_arrayIncludesWith-8b8a8b46.js → _arrayIncludesWith-b9a433b0.js} +2 -2
- package/dist/esm/{_arrayIncludesWith-8b8a8b46.js.map → _arrayIncludesWith-b9a433b0.js.map} +1 -1
- package/dist/esm/{_baseForOwn-3dd6837f.js → _baseForOwn-c95521ce.js} +2 -2
- package/dist/esm/{_baseForOwn-3dd6837f.js.map → _baseForOwn-c95521ce.js.map} +1 -1
- package/dist/esm/{_baseIsEqual-633b7929.js → _baseIsEqual-69d97809.js} +2 -2
- package/dist/esm/{_baseIsEqual-633b7929.js.map → _baseIsEqual-69d97809.js.map} +1 -1
- package/dist/esm/{_baseIteratee-2b2723f9.js → _baseIteratee-11a1b266.js} +2 -2
- package/dist/esm/{_baseIteratee-2b2723f9.js.map → _baseIteratee-11a1b266.js.map} +1 -1
- package/dist/esm/{isEqual-d8fb9edc.js → isEqual-8daa0ea4.js} +2 -2
- package/dist/esm/{isEqual-d8fb9edc.js.map → isEqual-8daa0ea4.js.map} +1 -1
- package/dist/esm/lime-elements.js +1 -1
- package/dist/esm/limel-breadcrumbs_3.entry.js +14 -15
- package/dist/esm/limel-breadcrumbs_3.entry.js.map +1 -1
- package/dist/esm/limel-chip_2.entry.js +2 -2
- package/dist/esm/limel-dialog.entry.js +2 -2
- package/dist/esm/{limel-file-dropzone.entry.js → limel-file-dropzone_2.entry.js} +98 -8
- package/dist/esm/limel-file-dropzone_2.entry.js.map +1 -0
- package/dist/esm/limel-file.entry.js +19 -116
- package/dist/esm/limel-file.entry.js.map +1 -1
- package/dist/esm/limel-form.entry.js +6 -6
- package/dist/esm/limel-picker.entry.js +217 -1
- package/dist/esm/limel-picker.entry.js.map +1 -1
- package/dist/esm/limel-tab-bar.entry.js +6 -3
- package/dist/esm/limel-tab-bar.entry.js.map +1 -1
- package/dist/esm/limel-table.entry.js +4 -4
- package/dist/esm/loader.js +1 -1
- package/dist/esm/{pickBy-240917e2.js → pickBy-7e02d413.js} +3 -3
- package/dist/esm/{pickBy-240917e2.js.map → pickBy-7e02d413.js.map} +1 -1
- package/dist/lime-elements/lime-elements.esm.js +1 -1
- package/dist/lime-elements/lime-elements.esm.js.map +1 -1
- package/dist/lime-elements/p-042e5620.entry.js +16 -0
- package/dist/lime-elements/p-042e5620.entry.js.map +1 -0
- package/dist/lime-elements/p-160569a4.js +2 -0
- package/dist/lime-elements/{p-00064897.entry.js → p-1d7a37ce.entry.js} +5 -5
- package/dist/lime-elements/p-1d7a37ce.entry.js.map +1 -0
- package/dist/lime-elements/p-35859f0c.entry.js +2 -0
- package/dist/lime-elements/p-35859f0c.entry.js.map +1 -0
- package/dist/lime-elements/{p-cb91d37d.js → p-48ed11c0.js} +2 -2
- package/dist/lime-elements/{p-c5db5254.entry.js → p-6b4e5f5b.entry.js} +2 -2
- package/dist/lime-elements/p-6eb17fd8.js +2 -0
- package/dist/lime-elements/{p-aaf6dada.entry.js → p-6f76bc3c.entry.js} +2 -2
- package/dist/lime-elements/{p-862f048d.entry.js → p-7b48a33b.entry.js} +3 -3
- package/dist/lime-elements/{p-862f048d.entry.js.map → p-7b48a33b.entry.js.map} +1 -1
- package/dist/lime-elements/{p-ce1c1f74.js → p-85f4296f.js} +2 -2
- package/dist/lime-elements/{p-b2439774.entry.js → p-91e67b12.entry.js} +2 -2
- package/dist/lime-elements/{p-2e9fe8fd.js → p-99f6893d.js} +2 -2
- package/dist/lime-elements/p-c5aff9c2.entry.js +2 -0
- package/dist/lime-elements/p-c5aff9c2.entry.js.map +1 -0
- package/dist/lime-elements/{p-f4d83226.js → p-cfef0bcd.js} +2 -2
- package/dist/lime-elements/{p-a20848fc.entry.js → p-fb44db4d.entry.js} +2 -2
- package/dist/lime-elements/{p-a20848fc.entry.js.map → p-fb44db4d.entry.js.map} +1 -1
- package/dist/types/components/file/file.d.ts +4 -22
- package/dist/types/components/menu/menu.d.ts +2 -4
- package/dist/types/components.d.ts +1 -1
- package/package.json +6 -6
- package/dist/cjs/files-dcef6c99.js +0 -44
- package/dist/cjs/files-dcef6c99.js.map +0 -1
- package/dist/cjs/index.es-75b5e7c4.js +0 -222
- package/dist/cjs/index.es-75b5e7c4.js.map +0 -1
- package/dist/cjs/limel-file-dropzone.cjs.entry.js.map +0 -1
- package/dist/cjs/limel-file-input.cjs.entry.js +0 -67
- package/dist/cjs/limel-file-input.cjs.entry.js.map +0 -1
- package/dist/esm/files-79d9caeb.js +0 -41
- package/dist/esm/files-79d9caeb.js.map +0 -1
- package/dist/esm/index.es-61c13ecf.js +0 -220
- package/dist/esm/index.es-61c13ecf.js.map +0 -1
- package/dist/esm/limel-file-dropzone.entry.js.map +0 -1
- package/dist/esm/limel-file-input.entry.js +0 -63
- package/dist/esm/limel-file-input.entry.js.map +0 -1
- package/dist/lime-elements/p-00064897.entry.js.map +0 -1
- package/dist/lime-elements/p-09cb3405.js +0 -2
- package/dist/lime-elements/p-09cb3405.js.map +0 -1
- package/dist/lime-elements/p-0c24c682.entry.js +0 -2
- package/dist/lime-elements/p-0c24c682.entry.js.map +0 -1
- package/dist/lime-elements/p-51ec4f02.js +0 -2
- package/dist/lime-elements/p-5def744e.js +0 -2
- package/dist/lime-elements/p-8d13a44f.entry.js +0 -2
- package/dist/lime-elements/p-8d13a44f.entry.js.map +0 -1
- package/dist/lime-elements/p-97107e34.js +0 -16
- package/dist/lime-elements/p-97107e34.js.map +0 -1
- package/dist/lime-elements/p-ec42b48f.entry.js +0 -2
- package/dist/lime-elements/p-ec42b48f.entry.js.map +0 -1
- package/dist/lime-elements/p-f358c948.entry.js +0 -2
- package/dist/lime-elements/p-f358c948.entry.js.map +0 -1
- /package/dist/lime-elements/{p-5def744e.js.map → p-160569a4.js.map} +0 -0
- /package/dist/lime-elements/{p-cb91d37d.js.map → p-48ed11c0.js.map} +0 -0
- /package/dist/lime-elements/{p-c5db5254.entry.js.map → p-6b4e5f5b.entry.js.map} +0 -0
- /package/dist/lime-elements/{p-51ec4f02.js.map → p-6eb17fd8.js.map} +0 -0
- /package/dist/lime-elements/{p-aaf6dada.entry.js.map → p-6f76bc3c.entry.js.map} +0 -0
- /package/dist/lime-elements/{p-ce1c1f74.js.map → p-85f4296f.js.map} +0 -0
- /package/dist/lime-elements/{p-b2439774.entry.js.map → p-91e67b12.entry.js.map} +0 -0
- /package/dist/lime-elements/{p-2e9fe8fd.js.map → p-99f6893d.js.map} +0 -0
- /package/dist/lime-elements/{p-f4d83226.js.map → p-cfef0bcd.js.map} +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["breadcrumbsCss","Breadcrumbs","this","renderSteps","allStepsWithoutLast","items","slice","areItemsLinks","map","renderAsLink","renderAsButton","item","tooltipId","createRandomString","h","role","id","class","onClick","handleClick","renderIcon","renderLabel","renderTooltip","href","link","title","renderLastStep","lastItem","tabindex","text","name","getIconName","icon","color","getIconColor","style","type","elementId","label","some","event","stopPropagation","select","emit","render","divider","componentWillLoad","makeEnterClickable","host","disconnectedCallback","removeEnterClickable","menuCss","SEARCH_DEBOUNCE","Menu","constructor","hostRef","renderLoader","loadingSubItems","loading","cssProperties","getCssProperties","width","display","padding","size","limeBranded","renderBreadcrumb","_a","menuBreadCrumb","length","onSelect","handleBreadcrumbsSelect","detail","menuItem","currentSubMenu","clearSearch","navigateMenu","setFocus","handleSelect","renderSearchField","searcher","ref","setSearchElement","leadingIcon","value","searchValue","onChange","handleTextInput","onKeyDown","handleInputKeyDown","renderEmptyMessage","emptyResultMessage","Array","isArray","searchResults","renderMenuList","visibleItems","gridLayout","badgeIcons","setListElement","handleMenuKeyDown","async","query","result","debouncedSearch","isForwardTab","key","TAB","keyCode","TAB_KEY_CODE","altKey","metaKey","shiftKey","isUp","ARROW_UP","ARROW_UP_KEY_CODE","isDown","ARROW_DOWN","ARROW_DOWN_KEY_CODE","list","preventDefault","listItems","shadowRoot","querySelectorAll","listElement","focus","isBackwardTab","isLeft","ARROW_LEFT","ARROW_LEFT_KEY_CODE","isRight","ARROW_RIGHT","ARROW_RIGHT_KEY_CODE","searchInput","currentItem","getCurrentItem","goForward","goBack","activeItem","_b","querySelector","attrIndex","_c","attributes","getNamedItem","dataIndex","parseInt","parent","parentItem","setTriggerAttributes","element","open","disabled","Object","entries","removeAttribute","setAttribute","String","onClose","cancel","onTriggerClick","selectOnEmptyChildren","isFunction","menuLoader","subItems","setTimeout","observer","IntersectionObserver","unobserve","window","document","activeElement","observe","focusMenuItem","blur","menuItems","filter","isMenuItem","selectedIndex","Math","max","findIndex","selected","menuElements","from","renderNotificationBadge","hasNotificationBadge","badge","undefined","setTriggerRef","elm","triggerElement","createDebouncedSearcher","bind","portalId","componentDidLoad","componentDidRender","slotElement","assignedElements","forEach","dropdownZIndex","getComputedStyle","getPropertyValue","menuSurfaceWidth","getMenuSurfaceWidth","visible","containerId","openDirection","position","containerStyle","onDismiss","assign","itemsWatcher","openWatcher","newValue","currentSubMenuWatcher","breadCrumbItems","push","reverse","AwesomeDebouncePromise","propertyNames","values","property","zipObject","customWidth","surfaceWidth","assignedTriggers","clientWidth","_d","cssClasses","MENU_SELECTED_LIST_ITEM","MENU_SELECTION_GROUP","ROOT","strings","ARIA_CHECKED_ATTR","ARIA_DISABLED_ATTR","CHECKBOX_SELECTOR","LIST_SELECTOR","SELECTED_EVENT","SKIP_RESTORE_FOCUS","numbers","FOCUS_ROOT_INDEX","DefaultFocusState","MDCMenuFoundation","_super","__extends","adapter","_this","call","__assign","defaultAdapter","closeAnimationEndTimerId","defaultFocusState","LIST_ROOT","defineProperty","get","enumerable","configurable","addClassToElementAtIndex","removeClassFromElementAtIndex","addAttributeToElementAtIndex","removeAttributeFromElementAtIndex","getAttributeFromElementAtIndex","elementContainsClass","closeSurface","getElementIndex","notifySelected","getMenuItemCount","focusItemAtIndex","focusListRoot","getSelectedSiblingOfItemAtIndex","isSelectableItemAtIndex","prototype","destroy","clearTimeout","handleKeydown","evt","isTab","handleItemAction","listItem","index","skipRestoreFocus","recomputedIndex","setSelectedIndex","MDCMenuSurfaceFoundation","TRANSITION_CLOSE_DURATION","handleMenuSurfaceOpened","FIRST_ITEM","LAST_ITEM","NONE","setDefaultFocusState","focusState","getSelectedIndex","validatedIndex","Error","prevSelectedIndex","setEnabled","isEnabled","listCssClasses","LIST_ITEM_DISABLED_CLASS","menuSize","isIndexInRange","MDCFoundation","MDCMenu","apply","arguments","attachTo","root","initialize","menuSurfaceFactory","listFactory","el","MDCMenuSurface","MDCList","initialSyncWithDOM","menuSurface","wrapFocus","foundation","listen","OPENED_EVENT","MDCListFoundation","ACTION_EVENT","unlisten","isOpen","set","close","hasTypeahead","typeaheadInProgress","typeaheadMatchItem","nextChar","startingIndex","layout","listElements","singleSelection","listConstants","UNSET_INDEX","quickOpen","setAnchorCorner","corner","setAnchorMargin","margin","getOptionByIndex","getPrimaryTextAtIndex","getPrimaryText","setFixedPosition","isFixed","setIsHoisted","isHoisted","setAbsolutePosition","x","y","setAnchorElement","anchorElement","getDefaultFoundation","className","classList","add","remove","attr","getAttribute","contains","indexOf","evtData","closest","selectionGroupEl","selectedItemEl","MDCComponent","MenuListRenderer","defaultConfig","getIndexForWhichToApplyTabIndex","i","renderMenuItem","rendertext","classNames","applyTabIndexToItemAtIndex","config","renderText","renderSubMenuIcon","renderNotification","twoLines","avatarList","renderDivider","isSimpleItem","renderCommandText","secondaryText","hasSubItems","commandText","iconColor","iconSize","classes","commandKey","hasIcons","selectable","includes","menuListCss","menuStrings","MenuList","setup","setupMenu","setupListeners","mdcMenu","teardown","MDCRipple","handleMenuSelect","handleSingleSelect","MenuItems","selectedItem","find","connectedCallback","triggerIconColorWarning","html","handleType","itemsChanged","console","warn"],"sources":["./src/components/breadcrumbs/breadcrumbs.scss?tag=limel-breadcrumbs&encapsulation=shadow","./src/components/breadcrumbs/breadcrumbs.tsx","./src/components/menu/menu.scss?tag=limel-menu&encapsulation=shadow","./src/components/menu/menu.tsx","./node_modules/@material/menu/constants.js","./node_modules/@material/menu/foundation.js","./node_modules/@material/menu/component.js","./src/components/menu-list/menu-list-renderer.tsx","./src/components/menu-list/menu-list.scss?tag=limel-menu-list&encapsulation=shadow","./src/components/menu-list/menu-list.tsx"],"sourcesContent":["@use '../../style/mixins';\n\n/**\n* @prop --breadcrumbs-item-text-color: Text color of breadcrumbs items, defaults to `--contrast-1100`.\n* @prop --breadcrumbs-item-max-width: Maximum width of a button in the breadcrumbs. Defaults to `10rem`. Keep in mind that the buttons should not appear too big.\n*/\n\n$padding: 0.5rem;\n\n:host(limel-breadcrumbs) {\n --limel-breadcrumbs-item-height: 1.5rem;\n --limel-breadcrumbs-gap: 0.75rem;\n --limel-breadcrumbs-gap: 0.75rem;\n --limel-breadcrumbs-item-text-color: var(\n --breadcrumbs-item-text-color,\n rgb(var(--contrast-1500))\n );\n @include mixins.fade-out-overflowed-content-on-edges(horizontally);\n --limel-left-edge-fade-width: #{$padding};\n --limel-right-edge-fade-width: #{$padding};\n}\n\nol,\nli,\n.step {\n all: unset;\n}\n\n* {\n box-sizing: border-box;\n}\n\nol {\n padding: $padding; // needed for the focus and hover effects, since we are using overflow\n gap: var(--limel-breadcrumbs-gap);\n}\n\n.step {\n position: relative;\n\n display: inline-flex;\n align-items: center;\n justify-content: center;\n gap: 0.25rem;\n\n max-width: var(--breadcrumbs-item-max-width, 10rem);\n height: var(--limel-breadcrumbs-item-height);\n\n color: var(--limel-breadcrumbs-item-text-color);\n border-radius: 100vw;\n font-size: 0.875rem;\n padding: 0 0.25rem;\n\n &:not(:has(.text)) {\n padding: 0 0.125rem;\n }\n\n &:not(.last) {\n @include mixins.visualize-keyboard-focus;\n\n &:after {\n content: var(--limel-breadcrumbs-divider);\n display: flex;\n align-items: center;\n justify-content: center;\n\n width: var(--limel-breadcrumbs-gap);\n\n position: absolute;\n top: 0;\n right: calc(var(--limel-breadcrumbs-gap) * -1);\n bottom: 0;\n left: auto;\n\n text-align: center;\n }\n }\n}\n\na.step {\n @include mixins.hyperlink($color: var(--limel-breadcrumbs-item-text-color));\n}\n\nbutton.step {\n &:not(.last) {\n @include mixins.is-flat-clickable(\n $color: var(--limel-breadcrumbs-item-text-color)\n );\n }\n}\n\nlimel-icon {\n flex-shrink: 0;\n width: calc(var(--limel-breadcrumbs-item-height) - 0.25rem);\n height: calc(var(--limel-breadcrumbs-item-height) - 0.25rem);\n}\n\n.text {\n @include mixins.truncate-text;\n padding: 0 0.25rem;\n}\n\n.last {\n opacity: 0.7;\n}\n\n// LAYOUT:\n// The code below makes sure that the last item is always visible,\n// and previous items overflow out of the container\n// while keeping the container scrollable.\n// All without any additional scripts in the component code.\n\n:host(limel-breadcrumbs) {\n box-sizing: border-box;\n\n display: flex;\n width: 100%;\n overflow-x: auto;\n scrollbar-width: none; // This hides the scrollbars appearing under in Firefox\n -ms-overflow-style: none; // Same as above for IE 11\n &::-webkit-scrollbar {\n display: none; // This hides the scrollbars appearing under in Chrome\n }\n\n direction: rtl;\n}\n\nol {\n display: flex;\n flex-direction: row-reverse;\n justify-content: flex-end;\n margin-right: auto;\n}\n\n.step {\n direction: ltr;\n}\n","import {\n Component,\n Element,\n h,\n Event,\n EventEmitter,\n Prop,\n} from '@stencil/core';\nimport { BreadcrumbsItem } from './breadcrumbs.types';\nimport {\n makeEnterClickable,\n removeEnterClickable,\n} from '../../util/make-enter-clickable';\nimport { createRandomString } from '../../util/random-string';\nimport { getIconColor, getIconName } from '../icon/get-icon-props';\n\n/**\n * A Breadcrumb consists of a list of distinct \"places\" that a user has gone through,\n * before ending up where they are right now, in a website or an application.\n *\n * These \"places\" can be for example _pages_ of a website, which are hierarchically\n * laid out before the current page that the user is looking at.\n * They could also be _steps_ which the user has gone through, which perhaps have no\n * hierarchical relation with each other, but has eventually led the user \"here\".\n *\n * :::note\n * - Where the user currently is, is always the last step of the breadcrumb.\n * - A breadcrumbs never shows where users can go after this place.\n * It only illustrates where user has been before ending up here.\n * If the path that a user can take is not changing and if next steps are clear,\n * you can use the [Progress flow component](#/component/limel-progress-flow) instead.\n * :::\n *\n * Breadcrumbs are often placed horizontally before the main content of the current screen.\n *\n * @exampleComponent limel-example-breadcrumbs-links\n * @exampleComponent limel-example-breadcrumbs-buttons\n * @exampleComponent limel-example-breadcrumbs-icons\n * @exampleComponent limel-example-breadcrumbs-divider\n * @exampleComponent limel-example-breadcrumbs-icon-color\n * @exampleComponent limel-example-breadcrumbs-styling\n */\n\n@Component({\n tag: 'limel-breadcrumbs',\n shadow: true,\n styleUrl: 'breadcrumbs.scss',\n})\nexport class Breadcrumbs {\n /**\n * List of items in the breadcrumbs,\n * each representing a step or a page.\n */\n @Prop()\n public items: BreadcrumbsItem[];\n\n /**\n * The visual divider that separates items.\n * It must be a single character such as `-` or `,`.\n */\n @Prop()\n public divider: string = '›';\n\n /**\n * Fired when clicking on buttons (not links!)\n * inside the breadcrumbs.\n */\n @Event()\n public select: EventEmitter<BreadcrumbsItem>;\n\n @Element()\n private host: HTMLLimelBreadcrumbsElement;\n\n public render() {\n return (\n <ol\n role=\"navigation\"\n aria-label=\"Breadcrumb\"\n style={{ '--limel-breadcrumbs-divider': `'${this.divider}'` }}\n >\n {this.renderSteps()}\n {this.renderLastStep()}\n </ol>\n );\n }\n\n public componentWillLoad() {\n makeEnterClickable(this.host);\n }\n\n public disconnectedCallback() {\n removeEnterClickable(this.host);\n }\n\n private renderSteps = () => {\n const allStepsWithoutLast = this.items.slice(0, -1);\n\n if (this.areItemsLinks(this.items)) {\n return allStepsWithoutLast.map(this.renderAsLink);\n }\n\n return allStepsWithoutLast.map(this.renderAsButton);\n };\n\n private renderAsButton = (item: BreadcrumbsItem) => {\n const tooltipId = createRandomString();\n\n return [\n <button\n role=\"listitem\"\n id={tooltipId}\n class=\"step\"\n onClick={this.handleClick(item)}\n >\n {this.renderIcon(item)}\n {this.renderLabel(item)}\n </button>,\n this.renderTooltip(item, tooltipId),\n ];\n };\n\n private renderAsLink = (item: BreadcrumbsItem) => {\n const tooltipId = createRandomString();\n\n return [\n <a\n role=\"listitem\"\n id={tooltipId}\n class=\"step\"\n href={item.link.href}\n title={item.link.title}\n >\n {this.renderIcon(item)}\n {this.renderLabel(item)}\n </a>,\n this.renderTooltip(item, tooltipId),\n ];\n };\n\n private renderLastStep = () => {\n const lastItem = this.items.slice(-1);\n\n return (\n <li\n class=\"last step\"\n tabindex=\"-1\"\n aria-current={this.areItemsLinks(this.items) ? 'page' : 'step'}\n >\n {this.renderIcon(lastItem[0])}\n <span class=\"text\">{lastItem[0].text}</span>\n </li>\n );\n };\n\n private renderIcon = (item: BreadcrumbsItem) => {\n const name = getIconName(item.icon);\n const color = getIconColor(item.icon);\n\n if (!name) {\n return;\n }\n\n return (\n <limel-icon\n style={{\n color: `${color}`,\n }}\n name={name}\n />\n );\n };\n\n private renderLabel = (item: BreadcrumbsItem) => {\n if (item.type === 'icon-only') {\n return;\n }\n\n return <span class=\"text\">{item.text}</span>;\n };\n\n private renderTooltip = (item: BreadcrumbsItem, tooltipId: string) => {\n if (item.type === 'icon-only') {\n return <limel-tooltip elementId={tooltipId} label={item.text} />;\n }\n };\n\n private areItemsLinks = (items: BreadcrumbsItem[]) => {\n return items.some((item) => 'link' in item);\n };\n\n private handleClick = (item: BreadcrumbsItem) => (event: MouseEvent) => {\n event.stopPropagation();\n this.select.emit(item);\n };\n}\n","@use '../../style/functions';\n\n// Note! The `--dropdown-z-index` property is used from `menu.tsx`.\n\n/**\n * @prop --dropdown-z-index: `z-index` of the dropdown menu.\n * @prop --menu-surface-width: Width of the menu surface. Overrides the width defined by `surfaceWidth`.\n * @prop --list-grid-item-max-width: Maximum width of items in the menu list when `gridLayout={true}`. Defaults to `10rem`.\n * @prop --list-grid-item-min-width: Minimum width of items in the menu list when `gridLayout={true}`. Defaults to `7.5rem`.\n * @prop --list-grid-gap: Distance between the items in the menu list when `gridLayout={true}`. Defaults to `0.75rem`.\n * @prop --notification-badge-text-color: Defines the text color of notification badges. Defaults to `--color-white`.\n * @prop --notification-badge-background-color: Defines the background color of notification badges. Defaults to `--color-red-default`.\n */\n\n:host(limel-menu) {\n isolation: isolate;\n position: relative;\n display: inline-block;\n --badge-background-color: var(\n --notification-badge-background-color,\n rgb(var(--color-red-default))\n );\n --badge-text-color: var(\n --notification-badge-text-color,\n rgb(var(--color-white))\n );\n}\n\n:host([hidden]) {\n display: none;\n}\n\n.menu__trigger {\n border-color: transparent;\n border-width: 1px;\n border-style: solid;\n background: none;\n color: rgb(var(--contrast-800));\n height: functions.pxToRem(36);\n\n &-enabled {\n &:hover {\n border-color: rgb(var(--contrast-800));\n color: rgb(var(--contrast-1100));\n }\n }\n}\n\n.mdc-menu-surface--anchor {\n position: relative;\n}\n\nlimel-badge {\n position: absolute;\n top: -0.25rem;\n right: -0.25rem;\n}\n","/* eslint-disable sonarjs/no-duplicate-string */\nimport {\n Component,\n Event,\n EventEmitter,\n h,\n Prop,\n Element,\n Watch,\n State,\n} from '@stencil/core';\nimport { createRandomString } from '../../util/random-string';\nimport { zipObject, isFunction } from 'lodash-es';\nimport {\n LimelBreadcrumbsCustomEvent,\n LimelInputFieldCustomEvent,\n} from '../../components';\n\nimport { BreadcrumbsItem } from '../breadcrumbs/breadcrumbs.types';\nimport { ListSeparator } from '../list/list-item.types';\nimport {\n OpenDirection,\n MenuItem,\n MenuLoader,\n SurfaceWidth,\n MenuSearcher,\n} from './menu.types';\n\nimport {\n ARROW_DOWN,\n ARROW_DOWN_KEY_CODE,\n ARROW_LEFT,\n ARROW_LEFT_KEY_CODE,\n ARROW_RIGHT,\n ARROW_RIGHT_KEY_CODE,\n ARROW_UP,\n ARROW_UP_KEY_CODE,\n TAB,\n TAB_KEY_CODE,\n} from '../../util/keycodes';\nimport AwesomeDebouncePromise from 'awesome-debounce-promise';\n\ninterface MenuCrumbItem extends BreadcrumbsItem {\n menuItem: MenuItem;\n}\n\nconst SEARCH_DEBOUNCE = 500;\n\n/**\n * @slot trigger - Element to use as a trigger for the menu.\n * @exampleComponent limel-example-menu-basic\n * @exampleComponent limel-example-menu-disabled\n * @exampleComponent limel-example-menu-open-direction\n * @exampleComponent limel-example-menu-surface-width\n * @exampleComponent limel-example-menu-separators\n * @exampleComponent limel-example-menu-icons\n * @exampleComponent limel-example-menu-badge-icons\n * @exampleComponent limel-example-menu-grid\n * @exampleComponent limel-example-menu-hotkeys\n * @exampleComponent limel-example-menu-secondary-text\n * @exampleComponent limel-example-menu-notification\n * @exampleComponent limel-example-menu-sub-menus\n * @exampleComponent limel-example-menu-sub-menu-lazy-loading\n * @exampleComponent limel-example-menu-sub-menu-lazy-loading-infinite\n * @exampleComponent limel-example-menu-searchable\n * @exampleComponent limel-example-menu-composite\n */\n@Component({\n tag: 'limel-menu',\n shadow: true,\n styleUrl: 'menu.scss',\n})\nexport class Menu {\n /**\n * A list of items and separators to show in the menu.\n */\n @Prop()\n public items: Array<MenuItem | ListSeparator> = [];\n\n /**\n * Sets the disabled state of the menu.\n */\n @Prop({ reflect: true })\n public disabled = false;\n\n /**\n * Decides the menu's location in relation to its trigger\n */\n @Prop({ reflect: true })\n public openDirection: OpenDirection = 'bottom-start';\n\n /**\n * Decides the width of menu's dropdown\n */\n @Prop({ reflect: true })\n public surfaceWidth: SurfaceWidth = 'inherit-from-items';\n\n /**\n * Sets the open state of the menu.\n */\n @Prop({ mutable: true, reflect: true })\n public open = false;\n\n /**\n * Defines whether the menu should show badges.\n */\n @Prop({ reflect: true })\n public badgeIcons = false;\n\n /**\n * Renders list items in a grid layout, rather than a vertical list\n */\n @Prop({ reflect: true })\n public gridLayout = false;\n\n /**\n * :::warning Internal Use Only\n * This property is for internal use only. We need it for now, but want to\n * find a better implementation of the functionality it currently enables.\n * If and when we do so, this property will be removed without prior\n * notice. If you use it, your code _will_ break in the future.\n * :::\n *\n * @internal\n */\n @Prop({ reflect: true })\n public loading = false;\n\n /**\n * :::warning Internal Use Only\n * This property is for internal use only. We need it for now, but want to\n * find a better implementation of the functionality it currently enables.\n * If and when we do so, this property will be removed without prior\n * notice. If you use it, your code _will_ break in the future.\n * :::\n *\n * @internal\n */\n @Prop({ mutable: true })\n public currentSubMenu: MenuItem;\n\n /**\n * Is emitted when the menu is cancelled.\n */\n @Event()\n public cancel: EventEmitter<void>;\n\n /**\n * Is emitted when a menu item is selected.\n */\n @Event()\n public select: EventEmitter<MenuItem>;\n\n /**\n * A search function that takes a search-string as an argument,\n * and returns a promise that will eventually be resolved with\n * an array of `MenuItem`:s.\n *\n * See the docs for the type `MenuSearcher` for type information on\n * the searcher function itself.\n */\n @Prop()\n public searcher: MenuSearcher;\n\n /**\n * Message to display when search returns 0 results.\n */\n @Prop()\n public emptyResultMessage?: string;\n\n /**\n * Is emitted when a menu item with a sub-menu is selected.\n */\n @Event()\n public navigateMenu: EventEmitter<MenuItem>;\n\n @Element()\n private host: HTMLLimelMenuElement;\n\n @State()\n private loadingSubItems: boolean;\n\n @State()\n private menuBreadCrumb: MenuCrumbItem[] = [];\n\n @State()\n private searchValue: string;\n\n @State()\n private searchResults: Array<MenuItem | ListSeparator>;\n\n private list: HTMLLimelMenuListElement;\n private searchInput: HTMLLimelInputFieldElement;\n private portalId: string;\n private triggerElement: HTMLSlotElement;\n private debouncedSearch: MenuSearcher;\n\n constructor() {\n this.createDebouncedSearcher = this.createDebouncedSearcher.bind(this);\n this.portalId = createRandomString();\n }\n\n public componentDidLoad() {\n this.createDebouncedSearcher(this.searcher);\n }\n\n public componentDidRender() {\n const slotElement = this.host.shadowRoot.querySelector('slot');\n slotElement.assignedElements().forEach(this.setTriggerAttributes);\n }\n\n public render() {\n const cssProperties = this.getCssProperties();\n\n const dropdownZIndex = getComputedStyle(this.host).getPropertyValue(\n '--dropdown-z-index',\n );\n\n const menuSurfaceWidth = this.getMenuSurfaceWidth(\n cssProperties['--menu-surface-width'],\n );\n\n return (\n <div class=\"mdc-menu-surface--anchor\" onClick={this.onTriggerClick}>\n <slot ref={this.setTriggerRef} name=\"trigger\" />\n {this.renderNotificationBadge()}\n <limel-portal\n visible={this.open}\n containerId={this.portalId}\n openDirection={this.openDirection}\n position=\"absolute\"\n containerStyle={{ 'z-index': dropdownZIndex }}\n >\n <limel-menu-surface\n open={this.open}\n onDismiss={this.onClose}\n style={{\n ...cssProperties,\n '--mdc-menu-min-width': menuSurfaceWidth,\n '--limel-menu-surface-display': 'flex',\n '--limel-menu-surface-flex-direction': 'column',\n }}\n class={{\n 'has-grid-layout': this.gridLayout,\n }}\n >\n {this.renderSearchField()}\n {this.renderBreadcrumb()}\n {this.renderLoader()}\n {this.renderEmptyMessage()}\n {this.renderMenuList()}\n </limel-menu-surface>\n </limel-portal>\n </div>\n );\n }\n\n @Watch('items')\n protected itemsWatcher() {\n this.clearSearch();\n this.setFocus();\n }\n\n @Watch('open')\n protected openWatcher(newValue: boolean) {\n if (newValue) {\n this.setFocus();\n } else {\n this.clearSearch();\n }\n }\n\n @Watch('currentSubMenu')\n protected currentSubMenuWatcher() {\n const breadCrumbItems: MenuCrumbItem[] = [];\n let currentItem = this.currentSubMenu;\n while (currentItem) {\n breadCrumbItems.push({\n text: currentItem.text,\n icon: currentItem.icon,\n menuItem: currentItem,\n });\n currentItem = currentItem.parentItem;\n }\n\n if (breadCrumbItems.length) {\n breadCrumbItems.push({\n text: '',\n icon: {\n name: 'home',\n },\n type: 'icon-only',\n } as MenuCrumbItem);\n }\n\n this.menuBreadCrumb = breadCrumbItems.reverse();\n }\n\n @Watch('searcher')\n protected createDebouncedSearcher(newValue: MenuSearcher) {\n if (typeof newValue !== 'function') {\n return;\n }\n\n this.debouncedSearch = AwesomeDebouncePromise(\n newValue,\n SEARCH_DEBOUNCE,\n );\n }\n\n private renderLoader = () => {\n if (!this.loadingSubItems && !this.loading) {\n return;\n }\n\n const cssProperties = this.getCssProperties();\n\n return (\n <div\n style={{\n width: cssProperties['--menu-surface-width'],\n display: 'flex',\n 'align-items': 'center',\n 'justify-content': 'center',\n padding: '0.5rem 0',\n }}\n >\n <limel-spinner size=\"mini\" limeBranded={false} />\n </div>\n );\n };\n\n private renderBreadcrumb = () => {\n if (!this.menuBreadCrumb?.length) {\n return;\n }\n\n return (\n <limel-breadcrumbs\n style={{\n 'border-bottom': 'solid 1px rgb(var(--contrast-500))',\n 'flex-shrink': '0',\n }}\n onSelect={this.handleBreadcrumbsSelect}\n items={this.menuBreadCrumb}\n />\n );\n };\n\n private handleBreadcrumbsSelect = (\n event: LimelBreadcrumbsCustomEvent<MenuCrumbItem>,\n ) => {\n if (!event.detail.menuItem) {\n this.currentSubMenu = null;\n this.clearSearch();\n this.navigateMenu.emit(null);\n\n this.setFocus();\n\n return;\n }\n\n this.handleSelect(event.detail.menuItem);\n };\n\n private renderSearchField = () => {\n if (!this.searcher) {\n return;\n }\n\n return (\n <limel-input-field\n tabindex=\"0\"\n ref={this.setSearchElement}\n type=\"search\"\n leadingIcon=\"search\"\n style={{\n padding: '0.25rem',\n 'box-sizing': 'border-box',\n }}\n value={this.searchValue}\n onChange={this.handleTextInput}\n onKeyDown={this.handleInputKeyDown}\n />\n );\n };\n\n private renderEmptyMessage = () => {\n if (\n this.loading ||\n this.loadingSubItems ||\n !this.emptyResultMessage ||\n !Array.isArray(this.searchResults) ||\n this.searchResults?.length\n ) {\n return null;\n }\n\n return (\n <p\n style={{\n padding: '0 1rem',\n 'text-align': 'center',\n }}\n >\n {this.emptyResultMessage}\n </p>\n );\n };\n\n private renderMenuList = () => {\n let items = this.visibleItems;\n\n if (this.loadingSubItems || this.loading) {\n items = [];\n }\n\n return (\n <limel-menu-list\n style={{\n 'overflow-y': 'auto',\n 'flex-grow': '1',\n }}\n class={{\n 'has-grid-layout has-interactive-items': this.gridLayout,\n }}\n items={items}\n type=\"menu\"\n badgeIcons={this.badgeIcons}\n onSelect={this.onSelect}\n ref={this.setListElement}\n onKeyDown={this.handleMenuKeyDown}\n />\n );\n };\n\n private handleTextInput = async (\n event: LimelInputFieldCustomEvent<string>,\n ) => {\n event.stopPropagation();\n\n const query = event.detail;\n this.searchValue = query;\n if (query === '') {\n this.searchResults = null;\n\n return;\n }\n\n this.loadingSubItems = true;\n\n const result = await this.debouncedSearch(query);\n\n this.searchResults = result;\n this.loadingSubItems = false;\n };\n\n // Key handler for the input search field\n // Will change focus to the first/last item in the dropdown\n // list to enable selection with the keyboard\n private handleInputKeyDown = (event: KeyboardEvent) => {\n const isForwardTab =\n (event.key === TAB || event.keyCode === TAB_KEY_CODE) &&\n !event.altKey &&\n !event.metaKey &&\n !event.shiftKey;\n const isUp =\n event.key === ARROW_UP || event.keyCode === ARROW_UP_KEY_CODE;\n const isDown =\n event.key === ARROW_DOWN || event.keyCode === ARROW_DOWN_KEY_CODE;\n\n if (!isForwardTab && !isUp && !isDown) {\n return;\n }\n\n if (!this.list) {\n return;\n }\n\n event.stopPropagation();\n event.preventDefault();\n\n if (isForwardTab || isDown) {\n const listItems =\n this.list.shadowRoot.querySelectorAll<HTMLElement>(\n '.mdc-deprecated-list-item',\n );\n const listElement = listItems[0];\n listElement?.focus();\n\n return;\n }\n\n if (isUp) {\n const listItems =\n this.list.shadowRoot.querySelectorAll<HTMLElement>(\n '.mdc-deprecated-list-item',\n );\n const listElement = listItems[listItems.length - 1];\n listElement?.focus();\n }\n };\n\n // Key handler for the menu list\n // Will change focus to the search field if using shift+tab\n // And can go forward/back with righ/left arrow keys\n private handleMenuKeyDown = (event: KeyboardEvent) => {\n const isBackwardTab =\n (event.key === TAB || event.keyCode === TAB_KEY_CODE) &&\n !event.altKey &&\n !event.metaKey &&\n event.shiftKey;\n\n const isLeft =\n event.key === ARROW_LEFT || event.keyCode === ARROW_LEFT_KEY_CODE;\n\n const isRight =\n event.key === ARROW_RIGHT || event.keyCode === ARROW_RIGHT_KEY_CODE;\n\n if (!isBackwardTab && !isLeft && !isRight) {\n return;\n }\n\n if (isBackwardTab) {\n event.stopPropagation();\n event.preventDefault();\n this.searchInput?.focus();\n } else if (!this.gridLayout) {\n const currentItem = this.getCurrentItem();\n\n event.stopPropagation();\n event.preventDefault();\n if (isRight) {\n this.goForward(currentItem);\n } else if (isLeft) {\n this.goBack();\n }\n }\n };\n\n private clearSearch = () => {\n this.searchValue = '';\n this.searchResults = null;\n };\n\n private getCurrentItem = (): MenuItem => {\n const activeItem = this.list?.shadowRoot?.querySelector(\n '[role=\"menuitem\"][tabindex=\"0\"]',\n );\n const attrIndex = activeItem?.attributes?.getNamedItem('data-index');\n const dataIndex = parseInt(attrIndex?.value || '0', 10);\n\n return this.visibleItems[dataIndex] as MenuItem;\n };\n\n private goForward = (currentItem: MenuItem) => {\n this.handleSelect(currentItem, false);\n };\n\n private goBack = () => {\n if (!this.currentSubMenu) {\n // Already in the root of the menu\n return;\n }\n\n const parent = this.currentSubMenu.parentItem;\n if (!parent) {\n // If only one step down, go to the root of the menu.\n // No need to load a sub-menu.\n this.currentSubMenu = null;\n this.clearSearch();\n this.navigateMenu.emit(null);\n\n this.setFocus();\n\n return;\n }\n\n this.handleSelect(parent);\n };\n\n private setTriggerAttributes = (element: HTMLElement) => {\n const attributes = {\n 'aria-haspopup': true,\n 'aria-expanded': this.open,\n disabled: this.disabled,\n role: 'button',\n };\n\n for (const [key, value] of Object.entries(attributes)) {\n if (!value) {\n element.removeAttribute(key);\n } else {\n element.setAttribute(key, String(value));\n }\n }\n };\n\n private onClose = () => {\n this.cancel.emit();\n this.open = false;\n this.currentSubMenu = null;\n };\n\n private onTriggerClick = (event: MouseEvent) => {\n event.stopPropagation();\n if (this.disabled) {\n return;\n }\n\n this.open = !this.open;\n };\n\n private handleSelect = async (\n menuItem: MenuItem,\n selectOnEmptyChildren: boolean = true,\n ) => {\n if (Array.isArray(menuItem?.items) && menuItem.items.length > 0) {\n this.clearSearch();\n this.currentSubMenu = menuItem;\n this.navigateMenu.emit(menuItem);\n\n this.setFocus();\n\n return;\n } else if (isFunction(menuItem?.items)) {\n const menuLoader = menuItem.items as MenuLoader;\n this.loadingSubItems = true;\n const subItems = await menuLoader(menuItem);\n menuItem.items = subItems;\n this.loadingSubItems = false;\n\n if (subItems?.length) {\n this.currentSubMenu = menuItem;\n this.clearSearch();\n this.navigateMenu.emit(menuItem);\n\n this.setFocus();\n\n return;\n }\n }\n\n if (!selectOnEmptyChildren) {\n return;\n }\n\n this.select.emit(menuItem);\n this.open = false;\n this.currentSubMenu = null;\n this.setFocus();\n };\n\n private onSelect = (event: CustomEvent<MenuItem>) => {\n event.stopPropagation();\n this.handleSelect(event.detail);\n };\n\n private getCssProperties() {\n const propertyNames = [\n '--menu-surface-width',\n '--list-grid-item-max-width',\n '--list-grid-item-min-width',\n '--list-grid-gap',\n '--notification-badge-background-color',\n '--notification-badge-text-color',\n ] as const;\n const style = getComputedStyle(this.host);\n const values = propertyNames.map((property) => {\n return style.getPropertyValue(property);\n });\n\n type PropName = (typeof propertyNames)[number];\n\n return zipObject(propertyNames, values) as Record<PropName, string>;\n }\n\n private setListElement = (element: HTMLLimelMenuListElement) => {\n this.list = element;\n };\n\n private setFocus = () => {\n setTimeout(() => {\n if (this.searchInput && this.searcher) {\n const observer = new IntersectionObserver(() => {\n observer.unobserve(this.searchInput);\n if (this.searchInput === window.document.activeElement) {\n return;\n }\n\n this.searchInput.focus();\n });\n observer.observe(this.searchInput);\n } else if (this.list) {\n const observer = new IntersectionObserver(() => {\n observer.unobserve(this.list);\n this.focusMenuItem();\n });\n observer.observe(this.list);\n }\n }, 0);\n };\n\n private setSearchElement = (element: HTMLLimelInputFieldElement) => {\n this.searchInput = element;\n };\n\n private focusMenuItem = () => {\n if (!this.list) {\n return;\n }\n\n const activeElement = this.list.shadowRoot.activeElement as HTMLElement;\n activeElement?.blur();\n\n const menuItems = this.visibleItems.filter(this.isMenuItem);\n const selectedIndex = Math.max(\n menuItems.findIndex((item) => item.selected),\n 0,\n );\n const menuElements: HTMLElement[] = Array.from(\n this.list.shadowRoot.querySelectorAll('[role=\"menuitem\"]'),\n );\n menuElements[selectedIndex]?.focus();\n };\n\n private isMenuItem(item: MenuItem | ListSeparator): item is MenuItem {\n return !('separator' in item);\n }\n\n private renderNotificationBadge = () => {\n if (this.items.some(this.hasNotificationBadge)) {\n return <limel-badge />;\n }\n };\n\n private hasNotificationBadge = (item: MenuItem | ListSeparator) =>\n this.isMenuItem(item) && item.badge !== undefined;\n\n private setTriggerRef = (elm?: HTMLSlotElement) => {\n this.triggerElement = elm;\n };\n\n private getMenuSurfaceWidth(customWidth: string): string {\n if (customWidth) {\n return customWidth;\n }\n\n if (this.surfaceWidth === 'inherit-from-trigger') {\n const assignedTriggers = this.triggerElement?.assignedElements();\n\n if (\n !assignedTriggers?.length ||\n !assignedTriggers[0]?.clientWidth\n ) {\n return '';\n }\n\n return `${assignedTriggers[0].clientWidth}px`;\n } else if (this.surfaceWidth === 'inherit-from-menu') {\n if (!this.host?.clientWidth) {\n return '';\n }\n\n return `${this.host?.clientWidth}px`;\n }\n\n return '';\n }\n\n private get visibleItems(): Array<MenuItem | ListSeparator> {\n if (Array.isArray(this.searchResults) && this.searchValue) {\n return this.searchResults;\n } else if (Array.isArray(this.currentSubMenu?.items)) {\n return this.currentSubMenu.items.map((item) => ({\n ...item,\n parentItem: this.currentSubMenu,\n }));\n }\n\n return this.items;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n MENU_SELECTED_LIST_ITEM: 'mdc-menu-item--selected',\n MENU_SELECTION_GROUP: 'mdc-menu__selection-group',\n ROOT: 'mdc-menu',\n};\nvar strings = {\n ARIA_CHECKED_ATTR: 'aria-checked',\n ARIA_DISABLED_ATTR: 'aria-disabled',\n CHECKBOX_SELECTOR: 'input[type=\"checkbox\"]',\n LIST_SELECTOR: '.mdc-list,.mdc-deprecated-list',\n SELECTED_EVENT: 'MDCMenu:selected',\n SKIP_RESTORE_FOCUS: 'data-menu-item-skip-restore-focus',\n};\nvar numbers = {\n FOCUS_ROOT_INDEX: -1,\n};\nvar DefaultFocusState;\n(function (DefaultFocusState) {\n DefaultFocusState[DefaultFocusState[\"NONE\"] = 0] = \"NONE\";\n DefaultFocusState[DefaultFocusState[\"LIST_ROOT\"] = 1] = \"LIST_ROOT\";\n DefaultFocusState[DefaultFocusState[\"FIRST_ITEM\"] = 2] = \"FIRST_ITEM\";\n DefaultFocusState[DefaultFocusState[\"LAST_ITEM\"] = 3] = \"LAST_ITEM\";\n})(DefaultFocusState || (DefaultFocusState = {}));\nexport { cssClasses, strings, numbers, DefaultFocusState };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport { __assign, __extends } from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses as listCssClasses } from '@material/list/constants';\nimport { MDCMenuSurfaceFoundation } from '@material/menu-surface/foundation';\nimport { cssClasses, DefaultFocusState, numbers, strings } from './constants';\nvar MDCMenuFoundation = /** @class */ (function (_super) {\n __extends(MDCMenuFoundation, _super);\n function MDCMenuFoundation(adapter) {\n var _this = _super.call(this, __assign(__assign({}, MDCMenuFoundation.defaultAdapter), adapter)) || this;\n _this.closeAnimationEndTimerId = 0;\n _this.defaultFocusState = DefaultFocusState.LIST_ROOT;\n _this.selectedIndex = -1;\n return _this;\n }\n Object.defineProperty(MDCMenuFoundation, \"cssClasses\", {\n get: function () {\n return cssClasses;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenuFoundation, \"strings\", {\n get: function () {\n return strings;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenuFoundation, \"numbers\", {\n get: function () {\n return numbers;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenuFoundation, \"defaultAdapter\", {\n /**\n * @see {@link MDCMenuAdapter} for typing information on parameters and return types.\n */\n get: function () {\n // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n return {\n addClassToElementAtIndex: function () { return undefined; },\n removeClassFromElementAtIndex: function () { return undefined; },\n addAttributeToElementAtIndex: function () { return undefined; },\n removeAttributeFromElementAtIndex: function () { return undefined; },\n getAttributeFromElementAtIndex: function () { return null; },\n elementContainsClass: function () { return false; },\n closeSurface: function () { return undefined; },\n getElementIndex: function () { return -1; },\n notifySelected: function () { return undefined; },\n getMenuItemCount: function () { return 0; },\n focusItemAtIndex: function () { return undefined; },\n focusListRoot: function () { return undefined; },\n getSelectedSiblingOfItemAtIndex: function () { return -1; },\n isSelectableItemAtIndex: function () { return false; },\n };\n // tslint:enable:object-literal-sort-keys\n },\n enumerable: false,\n configurable: true\n });\n MDCMenuFoundation.prototype.destroy = function () {\n if (this.closeAnimationEndTimerId) {\n clearTimeout(this.closeAnimationEndTimerId);\n }\n this.adapter.closeSurface();\n };\n MDCMenuFoundation.prototype.handleKeydown = function (evt) {\n var key = evt.key, keyCode = evt.keyCode;\n var isTab = key === 'Tab' || keyCode === 9;\n if (isTab) {\n this.adapter.closeSurface(/** skipRestoreFocus */ true);\n }\n };\n MDCMenuFoundation.prototype.handleItemAction = function (listItem) {\n var _this = this;\n var index = this.adapter.getElementIndex(listItem);\n if (index < 0) {\n return;\n }\n this.adapter.notifySelected({ index: index });\n var skipRestoreFocus = this.adapter.getAttributeFromElementAtIndex(index, strings.SKIP_RESTORE_FOCUS) === 'true';\n this.adapter.closeSurface(skipRestoreFocus);\n // Wait for the menu to close before adding/removing classes that affect styles.\n this.closeAnimationEndTimerId = setTimeout(function () {\n // Recompute the index in case the menu contents have changed.\n var recomputedIndex = _this.adapter.getElementIndex(listItem);\n if (recomputedIndex >= 0 &&\n _this.adapter.isSelectableItemAtIndex(recomputedIndex)) {\n _this.setSelectedIndex(recomputedIndex);\n }\n }, MDCMenuSurfaceFoundation.numbers.TRANSITION_CLOSE_DURATION);\n };\n MDCMenuFoundation.prototype.handleMenuSurfaceOpened = function () {\n switch (this.defaultFocusState) {\n case DefaultFocusState.FIRST_ITEM:\n this.adapter.focusItemAtIndex(0);\n break;\n case DefaultFocusState.LAST_ITEM:\n this.adapter.focusItemAtIndex(this.adapter.getMenuItemCount() - 1);\n break;\n case DefaultFocusState.NONE:\n // Do nothing.\n break;\n default:\n this.adapter.focusListRoot();\n break;\n }\n };\n /**\n * Sets default focus state where the menu should focus every time when menu\n * is opened. Focuses the list root (`DefaultFocusState.LIST_ROOT`) element by\n * default.\n */\n MDCMenuFoundation.prototype.setDefaultFocusState = function (focusState) {\n this.defaultFocusState = focusState;\n };\n /** @return Index of the currently selected list item within the menu. */\n MDCMenuFoundation.prototype.getSelectedIndex = function () {\n return this.selectedIndex;\n };\n /**\n * Selects the list item at `index` within the menu.\n * @param index Index of list item within the menu.\n */\n MDCMenuFoundation.prototype.setSelectedIndex = function (index) {\n this.validatedIndex(index);\n if (!this.adapter.isSelectableItemAtIndex(index)) {\n throw new Error('MDCMenuFoundation: No selection group at specified index.');\n }\n var prevSelectedIndex = this.adapter.getSelectedSiblingOfItemAtIndex(index);\n if (prevSelectedIndex >= 0) {\n this.adapter.removeAttributeFromElementAtIndex(prevSelectedIndex, strings.ARIA_CHECKED_ATTR);\n this.adapter.removeClassFromElementAtIndex(prevSelectedIndex, cssClasses.MENU_SELECTED_LIST_ITEM);\n }\n this.adapter.addClassToElementAtIndex(index, cssClasses.MENU_SELECTED_LIST_ITEM);\n this.adapter.addAttributeToElementAtIndex(index, strings.ARIA_CHECKED_ATTR, 'true');\n this.selectedIndex = index;\n };\n /**\n * Sets the enabled state to isEnabled for the menu item at the given index.\n * @param index Index of the menu item\n * @param isEnabled The desired enabled state of the menu item.\n */\n MDCMenuFoundation.prototype.setEnabled = function (index, isEnabled) {\n this.validatedIndex(index);\n if (isEnabled) {\n this.adapter.removeClassFromElementAtIndex(index, listCssClasses.LIST_ITEM_DISABLED_CLASS);\n this.adapter.addAttributeToElementAtIndex(index, strings.ARIA_DISABLED_ATTR, 'false');\n }\n else {\n this.adapter.addClassToElementAtIndex(index, listCssClasses.LIST_ITEM_DISABLED_CLASS);\n this.adapter.addAttributeToElementAtIndex(index, strings.ARIA_DISABLED_ATTR, 'true');\n }\n };\n MDCMenuFoundation.prototype.validatedIndex = function (index) {\n var menuSize = this.adapter.getMenuItemCount();\n var isIndexInRange = index >= 0 && index < menuSize;\n if (!isIndexInRange) {\n throw new Error('MDCMenuFoundation: No list item at specified index.');\n }\n };\n return MDCMenuFoundation;\n}(MDCFoundation));\nexport { MDCMenuFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCMenuFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport { __extends } from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { closest } from '@material/dom/ponyfill';\nimport { MDCList } from '@material/list/component';\nimport { numbers as listConstants } from '@material/list/constants';\nimport { MDCListFoundation } from '@material/list/foundation';\nimport { MDCMenuSurface } from '@material/menu-surface/component';\nimport { MDCMenuSurfaceFoundation } from '@material/menu-surface/foundation';\nimport { cssClasses, strings } from './constants';\nimport { MDCMenuFoundation } from './foundation';\nvar MDCMenu = /** @class */ (function (_super) {\n __extends(MDCMenu, _super);\n function MDCMenu() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n MDCMenu.attachTo = function (root) {\n return new MDCMenu(root);\n };\n MDCMenu.prototype.initialize = function (menuSurfaceFactory, listFactory) {\n if (menuSurfaceFactory === void 0) { menuSurfaceFactory = function (el) { return new MDCMenuSurface(el); }; }\n if (listFactory === void 0) { listFactory = function (el) { return new MDCList(el); }; }\n this.menuSurfaceFactory = menuSurfaceFactory;\n this.listFactory = listFactory;\n };\n MDCMenu.prototype.initialSyncWithDOM = function () {\n var _this = this;\n this.menuSurface = this.menuSurfaceFactory(this.root);\n var list = this.root.querySelector(strings.LIST_SELECTOR);\n if (list) {\n this.list = this.listFactory(list);\n this.list.wrapFocus = true;\n }\n else {\n this.list = null;\n }\n this.handleKeydown = function (evt) {\n _this.foundation.handleKeydown(evt);\n };\n this.handleItemAction = function (evt) {\n _this.foundation.handleItemAction(_this.items[evt.detail.index]);\n };\n this.handleMenuSurfaceOpened = function () {\n _this.foundation.handleMenuSurfaceOpened();\n };\n this.menuSurface.listen(MDCMenuSurfaceFoundation.strings.OPENED_EVENT, this.handleMenuSurfaceOpened);\n this.listen('keydown', this.handleKeydown);\n this.listen(MDCListFoundation.strings.ACTION_EVENT, this.handleItemAction);\n };\n MDCMenu.prototype.destroy = function () {\n if (this.list) {\n this.list.destroy();\n }\n this.menuSurface.destroy();\n this.menuSurface.unlisten(MDCMenuSurfaceFoundation.strings.OPENED_EVENT, this.handleMenuSurfaceOpened);\n this.unlisten('keydown', this.handleKeydown);\n this.unlisten(MDCListFoundation.strings.ACTION_EVENT, this.handleItemAction);\n _super.prototype.destroy.call(this);\n };\n Object.defineProperty(MDCMenu.prototype, \"open\", {\n get: function () {\n return this.menuSurface.isOpen();\n },\n set: function (value) {\n if (value) {\n this.menuSurface.open();\n }\n else {\n this.menuSurface.close();\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenu.prototype, \"wrapFocus\", {\n get: function () {\n return this.list ? this.list.wrapFocus : false;\n },\n set: function (value) {\n if (this.list) {\n this.list.wrapFocus = value;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenu.prototype, \"hasTypeahead\", {\n /**\n * Sets whether the menu has typeahead functionality.\n * @param value Whether typeahead is enabled.\n */\n set: function (value) {\n if (this.list) {\n this.list.hasTypeahead = value;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenu.prototype, \"typeaheadInProgress\", {\n /**\n * @return Whether typeahead logic is currently matching some user prefix.\n */\n get: function () {\n return this.list ? this.list.typeaheadInProgress : false;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * Given the next desired character from the user, adds it to the typeahead\n * buffer. Then, attempts to find the next option matching the buffer. Wraps\n * around if at the end of options.\n *\n * @param nextChar The next character to add to the prefix buffer.\n * @param startingIndex The index from which to start matching. Only relevant\n * when starting a new match sequence. To start a new match sequence,\n * clear the buffer using `clearTypeaheadBuffer`, or wait for the buffer\n * to clear after a set interval defined in list foundation. Defaults to\n * the currently focused index.\n * @return The index of the matched item, or -1 if no match.\n */\n MDCMenu.prototype.typeaheadMatchItem = function (nextChar, startingIndex) {\n if (this.list) {\n return this.list.typeaheadMatchItem(nextChar, startingIndex);\n }\n return -1;\n };\n /**\n * Layout the underlying list element in the case of any dynamic updates\n * to its structure.\n */\n MDCMenu.prototype.layout = function () {\n if (this.list) {\n this.list.layout();\n }\n };\n Object.defineProperty(MDCMenu.prototype, \"items\", {\n /**\n * Return the items within the menu. Note that this only contains the set of elements within\n * the items container that are proper list items, and not supplemental / presentational DOM\n * elements.\n */\n get: function () {\n return this.list ? this.list.listElements : [];\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenu.prototype, \"singleSelection\", {\n /**\n * Turns on/off the underlying list's single selection mode. Used mainly\n * by select menu.\n *\n * @param singleSelection Whether to enable single selection mode.\n */\n set: function (singleSelection) {\n if (this.list) {\n this.list.singleSelection = singleSelection;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenu.prototype, \"selectedIndex\", {\n /**\n * Retrieves the selected index. Only applicable to select menus.\n * @return The selected index, which is a number for single selection and\n * radio lists, and an array of numbers for checkbox lists.\n */\n get: function () {\n return this.list ? this.list.selectedIndex : listConstants.UNSET_INDEX;\n },\n /**\n * Sets the selected index of the list. Only applicable to select menus.\n * @param index The selected index, which is a number for single selection and\n * radio lists, and an array of numbers for checkbox lists.\n */\n set: function (index) {\n if (this.list) {\n this.list.selectedIndex = index;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(MDCMenu.prototype, \"quickOpen\", {\n set: function (quickOpen) {\n this.menuSurface.quickOpen = quickOpen;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * Sets default focus state where the menu should focus every time when menu\n * is opened. Focuses the list root (`DefaultFocusState.LIST_ROOT`) element by\n * default.\n * @param focusState Default focus state.\n */\n MDCMenu.prototype.setDefaultFocusState = function (focusState) {\n this.foundation.setDefaultFocusState(focusState);\n };\n /**\n * @param corner Default anchor corner alignment of top-left menu corner.\n */\n MDCMenu.prototype.setAnchorCorner = function (corner) {\n this.menuSurface.setAnchorCorner(corner);\n };\n MDCMenu.prototype.setAnchorMargin = function (margin) {\n this.menuSurface.setAnchorMargin(margin);\n };\n /**\n * Sets the list item as the selected row at the specified index.\n * @param index Index of list item within menu.\n */\n MDCMenu.prototype.setSelectedIndex = function (index) {\n this.foundation.setSelectedIndex(index);\n };\n /**\n * Sets the enabled state to isEnabled for the menu item at the given index.\n * @param index Index of the menu item\n * @param isEnabled The desired enabled state of the menu item.\n */\n MDCMenu.prototype.setEnabled = function (index, isEnabled) {\n this.foundation.setEnabled(index, isEnabled);\n };\n /**\n * @return The item within the menu at the index specified.\n */\n MDCMenu.prototype.getOptionByIndex = function (index) {\n var items = this.items;\n if (index < items.length) {\n return this.items[index];\n }\n else {\n return null;\n }\n };\n /**\n * @param index A menu item's index.\n * @return The primary text within the menu at the index specified.\n */\n MDCMenu.prototype.getPrimaryTextAtIndex = function (index) {\n var item = this.getOptionByIndex(index);\n if (item && this.list) {\n return this.list.getPrimaryText(item) || '';\n }\n return '';\n };\n MDCMenu.prototype.setFixedPosition = function (isFixed) {\n this.menuSurface.setFixedPosition(isFixed);\n };\n MDCMenu.prototype.setIsHoisted = function (isHoisted) {\n this.menuSurface.setIsHoisted(isHoisted);\n };\n MDCMenu.prototype.setAbsolutePosition = function (x, y) {\n this.menuSurface.setAbsolutePosition(x, y);\n };\n /**\n * Sets the element that the menu-surface is anchored to.\n */\n MDCMenu.prototype.setAnchorElement = function (element) {\n this.menuSurface.anchorElement = element;\n };\n MDCMenu.prototype.getDefaultFoundation = function () {\n var _this = this;\n // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n var adapter = {\n addClassToElementAtIndex: function (index, className) {\n var list = _this.items;\n list[index].classList.add(className);\n },\n removeClassFromElementAtIndex: function (index, className) {\n var list = _this.items;\n list[index].classList.remove(className);\n },\n addAttributeToElementAtIndex: function (index, attr, value) {\n var list = _this.items;\n list[index].setAttribute(attr, value);\n },\n removeAttributeFromElementAtIndex: function (index, attr) {\n var list = _this.items;\n list[index].removeAttribute(attr);\n },\n getAttributeFromElementAtIndex: function (index, attr) {\n var list = _this.items;\n return list[index].getAttribute(attr);\n },\n elementContainsClass: function (element, className) {\n return element.classList.contains(className);\n },\n closeSurface: function (skipRestoreFocus) {\n _this.menuSurface.close(skipRestoreFocus);\n },\n getElementIndex: function (element) { return _this.items.indexOf(element); },\n notifySelected: function (evtData) {\n _this.emit(strings.SELECTED_EVENT, {\n index: evtData.index,\n item: _this.items[evtData.index],\n });\n },\n getMenuItemCount: function () { return _this.items.length; },\n focusItemAtIndex: function (index) {\n _this.items[index].focus();\n },\n focusListRoot: function () {\n _this.root.querySelector(strings.LIST_SELECTOR).focus();\n },\n isSelectableItemAtIndex: function (index) {\n return !!closest(_this.items[index], \".\" + cssClasses.MENU_SELECTION_GROUP);\n },\n getSelectedSiblingOfItemAtIndex: function (index) {\n var selectionGroupEl = closest(_this.items[index], \".\" + cssClasses.MENU_SELECTION_GROUP);\n var selectedItemEl = selectionGroupEl.querySelector(\".\" + cssClasses.MENU_SELECTED_LIST_ITEM);\n return selectedItemEl ? _this.items.indexOf(selectedItemEl) : -1;\n },\n };\n // tslint:enable:object-literal-sort-keys\n return new MDCMenuFoundation(adapter);\n };\n return MDCMenu;\n}(MDCComponent));\nexport { MDCMenu };\n//# sourceMappingURL=component.js.map","import { ListSeparator } from '../list/list-item.types';\nimport { MenuItem } from '../menu/menu.types';\nimport { h } from '@stencil/core';\nimport { MenuListRendererConfig } from './menu-list-renderer-config';\nimport { getIconColor, getIconName } from '../icon/get-icon-props';\nimport { isFunction } from 'lodash-es';\n\nexport class MenuListRenderer {\n private defaultConfig: MenuListRendererConfig = {\n isOpen: true,\n badgeIcons: false,\n };\n\n private config: MenuListRendererConfig;\n\n private hasIcons: boolean;\n private twoLines: boolean;\n private avatarList: boolean;\n private commandKey: boolean;\n\n private applyTabIndexToItemAtIndex: number;\n\n public render(\n items: Array<MenuItem | ListSeparator>,\n config: MenuListRendererConfig = {},\n ) {\n items = items || [];\n this.config = { ...this.defaultConfig, ...config };\n\n this.twoLines = items.some((item) => {\n return 'secondaryText' in item && !!item.secondaryText;\n });\n\n this.commandKey = items.some((item) => {\n return 'commandText' in item && !!item.commandText;\n });\n\n this.hasIcons = items.some((item) => {\n return 'icon' in item && !!item.icon;\n });\n\n this.avatarList = this.config.badgeIcons && this.hasIcons;\n\n this.applyTabIndexToItemAtIndex =\n this.getIndexForWhichToApplyTabIndex(items);\n\n const classNames = {\n 'mdc-deprecated-list': true,\n 'mdc-deprecated-list--two-line': this.twoLines,\n selectable: true,\n 'mdc-deprecated-list--avatar-list': this.avatarList,\n 'list--compact':\n this.twoLines &&\n this.commandKey &&\n ['small', 'x-small'].includes(this.config.iconSize),\n };\n\n return (\n <ul\n class={classNames}\n aria-hidden={true}\n role=\"menu\"\n aria-orientation=\"vertical\"\n style={{ '--maxLinesSecondaryText': '2' }}\n >\n {items.map(this.renderMenuItem)}\n </ul>\n );\n }\n\n /**\n * Determine which MenuItem should have the `tab-index` attribute set,\n * and return the index at which that MenuItem is located in `items`.\n * Returns `undefined` if no item should have the attribute set.\n * See https://github.com/material-components/material-components-web/tree/e66a43a75fef4f9179e24856649518e15e279a04/packages/mdc-list#accessibility\n *\n * @param items - the items of the list, including any `ListSeparator`:s\n * @returns the index as per the description\n */\n private getIndexForWhichToApplyTabIndex = (\n items: Array<MenuItem | ListSeparator>,\n ) => {\n let result;\n for (let i = 0, max = items.length; i < max; i += 1) {\n if ('separator' in items[i]) {\n // Ignore ListSeparator\n } else {\n const item = items[i] as MenuItem<any>;\n if (item.selected) {\n result = i;\n break;\n }\n\n if (result === undefined && !item.disabled) {\n result = i;\n // Do NOT break, as any later item with\n // `selected=true` should get the tab-index instead!\n }\n }\n }\n\n return result;\n };\n\n /**\n * Render a single list item\n *\n * @param item - the item to render\n * @param index - the index the item had in the `items` array\n * @returns the list item\n */\n private renderMenuItem = (\n item: MenuItem | ListSeparator,\n index: number,\n ) => {\n if ('separator' in item) {\n return (\n <li class=\"mdc-deprecated-list-divider\" role=\"separator\">\n {this.rendertext(item)}\n <div class=\"limel-list-divider-line\" />\n </li>\n );\n }\n\n const classNames = {\n 'mdc-deprecated-list-item': true,\n 'mdc-deprecated-list-item--disabled': item.disabled,\n 'mdc-deprecated-list-item--selected': item.selected,\n };\n\n const attributes: { tabindex?: string } = {};\n if (index === this.applyTabIndexToItemAtIndex) {\n attributes.tabindex = '0';\n }\n\n return (\n <li\n class={classNames}\n role=\"menuitem\"\n aria-disabled={item.disabled ? 'true' : 'false'}\n aria-selected={item.selected ? 'true' : 'false'}\n data-index={index}\n {...attributes}\n >\n {this.renderIcon(this.config, item)}\n {this.renderText(item)}\n {this.renderSubMenuIcon(item)}\n {this.renderNotification(item)}\n {this.twoLines && this.avatarList ? this.renderDivider() : null}\n </li>\n );\n };\n\n /**\n * Render the text of the list item\n *\n * @param item - the list item\n * @returns the text for the list item\n */\n private renderText = (item: MenuItem) => {\n if (this.isSimpleItem(item)) {\n return (\n <span class=\"mdc-deprecated-list-item__text\">{item.text}</span>\n );\n }\n\n return (\n <div class=\"mdc-deprecated-list-item__text\">\n <div class=\"mdc-deprecated-list-item__primary-command-text\">\n <div class=\"mdc-deprecated-list-item__primary-text\">\n {item.text}\n </div>\n {this.renderCommandText(item)}\n </div>\n <div class=\"mdc-deprecated-list-item__secondary-text\">\n {item.secondaryText}\n </div>\n </div>\n );\n };\n\n private renderSubMenuIcon = (item: MenuItem) => {\n if (!this.hasSubItems(item)) {\n return;\n }\n\n return <limel-icon class=\"sub-menu-icon\" name=\"-lime-caret-right\" />;\n };\n\n private rendertext = (item: ListSeparator) => {\n if ('text' in item) {\n return <h2 class=\"limel-list-divider-title\">{item.text}</h2>;\n }\n };\n\n private renderCommandText = (item: MenuItem) => {\n if (!('commandText' in item)) {\n return;\n }\n\n return (\n <div class=\"mdc-deprecated-list-item__command-text\">\n {item.commandText}\n </div>\n );\n };\n\n private isSimpleItem = (item: MenuItem): boolean => {\n if ('commandText' in item) {\n return false;\n }\n\n return !('secondaryText' in item);\n };\n\n /**\n * Render an icon for a list item\n *\n * @param config - the config object, passed on from the `renderMenuItem` function\n * @param item - the list item\n * @returns the icon element\n */\n private renderIcon = (config: MenuListRendererConfig, item: MenuItem) => {\n const style: any = {};\n const name = getIconName(item.icon);\n if (!name) {\n return;\n }\n\n const color = getIconColor(item.icon, item.iconColor);\n\n if (color) {\n if (config.badgeIcons) {\n style['--icon-background-color'] = color;\n } else {\n style.color = color;\n }\n }\n\n return (\n <limel-icon\n badge={config.badgeIcons}\n class=\"mdc-deprecated-list-item__graphic\"\n name={name}\n style={style}\n size={config.iconSize}\n />\n );\n };\n\n private renderNotification = (item: MenuItem) => {\n if (item.badge !== undefined) {\n return <limel-badge label={item.badge} />;\n }\n };\n\n private renderDivider = () => {\n const classes = {\n 'mdc-deprecated-list-divider': true,\n 'mdc-deprecated-list-divider--inset': true,\n };\n if (this.config.iconSize) {\n classes[this.config.iconSize] = true;\n }\n\n return <hr class={classes} />;\n };\n\n private hasSubItems = (item: MenuItem): boolean => {\n return (\n (Array.isArray(item.items) && item.items.length > 0) ||\n isFunction(item.items)\n );\n };\n}\n","@use '../../style/functions';\n\n@import '../list/list';\n\n:host(limel-menu-list) {\n display: block;\n --badge-background-color: var(\n --notification-badge-background-color,\n rgb(var(--color-red-default))\n );\n --badge-text-color: var(\n --notification-badge-text-color,\n rgb(var(--color-white))\n );\n}\n\n.mdc-menu {\n max-height: 70vh; // force tall menus render inside the viewport when menu is at the bottom of the screen\n}\n\n.mdc-deprecated-list {\n margin: functions.pxToRem(4);\n // added space to visualize keyboard-focused items\n .mdc-deprecated-list-item[role='menuitem'] {\n font-size: functions.pxToRem(13);\n\n .mdc-deprecated-list-item__graphic {\n margin-right: functions.pxToRem(14);\n }\n }\n\n hr.mdc-deprecated-list-divider {\n &.mdc-deprecated-list-divider--inset {\n display: none;\n }\n }\n}\n\nlimel-badge {\n transform: translateX(0.75rem);\n}\n\n.sub-menu-icon {\n width: 1rem;\n transform: translateX(0.75rem);\n flex-shrink: 0;\n}\n","import { IconSize } from '../icon/icon.types';\nimport { ListSeparator } from '../list/list-item.types';\nimport { MenuItem } from '../menu/menu.types';\nimport { MenuListType } from '../menu-list/menu-list.types';\nimport { MDCMenu, MDCMenuItemEvent } from '@material/menu';\nimport { MDCRipple } from '@material/ripple';\nimport { strings as menuStrings } from '@material/menu/constants';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Prop,\n Watch,\n} from '@stencil/core';\nimport { MenuListRenderer } from './menu-list-renderer';\nimport { MenuListRendererConfig } from './menu-list-renderer-config';\n\nconst { SELECTED_EVENT } = menuStrings;\n\n/**\n * @private\n */\n@Component({\n tag: 'limel-menu-list',\n shadow: true,\n styleUrl: 'menu-list.scss',\n})\nexport class MenuList {\n /**\n * List of items to display\n */\n @Prop()\n public items: Array<MenuItem | ListSeparator>;\n\n /**\n * Set to `true` if the list should display larger icons with a background\n */\n @Prop()\n public badgeIcons: boolean;\n\n /**\n * Size of the icons in the list\n */\n @Prop()\n public iconSize: IconSize = 'small';\n\n /**\n * The type of the menu, omit to get a regular vertical menu.\n * Available types are:\n * `menu`: regular vertical menu.\n */\n @Prop()\n public type: MenuListType;\n\n /**\n * By default, lists will display 3 lines of text, and then truncate the rest.\n * Consumers can increase or decrease this number by specifying\n * `maxLinesSecondaryText`. If consumer enters zero or negative\n * numbers we default to 1; and if they type decimals we round up.\n */\n // eslint-disable-next-line no-magic-numbers\n @Prop() maxLinesSecondaryText: number = 3;\n\n @Element()\n private element: HTMLLimelMenuListElement;\n\n private config: MenuListRendererConfig;\n private MenuListRenderer = new MenuListRenderer();\n private mdcMenu: MDCMenu;\n\n /**\n * Fired when a new value has been selected from the list.\n */\n @Event()\n private select: EventEmitter<MenuItem>;\n\n public connectedCallback() {\n this.setup();\n }\n\n public disconnectedCallback() {\n this.teardown();\n }\n\n public componentDidLoad() {\n this.setup();\n this.triggerIconColorWarning();\n }\n\n public render() {\n this.config = {\n badgeIcons: this.badgeIcons,\n type: this.type,\n iconSize: this.iconSize,\n };\n\n const html = this.MenuListRenderer.render(this.items, this.config);\n\n return <div class=\"mdc-menu mdc-menu-surface\">{html}</div>;\n }\n\n @Watch('type')\n protected handleType() {\n this.setupListeners();\n }\n\n @Watch('items')\n protected itemsChanged() {\n setTimeout(() => {\n this.setup();\n }, 0);\n }\n\n private setup = () => {\n this.setupMenu();\n this.setupListeners();\n };\n\n private setupMenu = () => {\n if (this.mdcMenu) {\n this.teardown();\n this.mdcMenu = null;\n }\n\n const element = this.element.shadowRoot.querySelector('.mdc-menu');\n if (!element) {\n return;\n }\n\n this.mdcMenu = new MDCMenu(element);\n this.mdcMenu.hasTypeahead = true;\n this.mdcMenu.wrapFocus = true;\n this.mdcMenu.items.forEach((item) => new MDCRipple(item));\n };\n\n private setupListeners = () => {\n if (!this.mdcMenu) {\n return;\n }\n\n this.mdcMenu.unlisten(SELECTED_EVENT, this.handleMenuSelect);\n this.mdcMenu.listen(SELECTED_EVENT, this.handleMenuSelect);\n };\n\n private teardown = () => {\n this.mdcMenu?.unlisten(SELECTED_EVENT, this.handleMenuSelect);\n this.mdcMenu?.destroy();\n };\n\n private handleMenuSelect = (event: MDCMenuItemEvent) => {\n this.handleSingleSelect(event.detail.index);\n };\n\n private handleSingleSelect = (index: number) => {\n const MenuItems = this.items.filter(this.isMenuItem) as MenuItem[];\n if (MenuItems[index].disabled) {\n return;\n }\n\n const selectedItem: MenuItem = MenuItems.find((item: MenuItem) => {\n return !!item.selected;\n });\n\n if (selectedItem) {\n this.select.emit({ ...selectedItem, selected: false });\n }\n\n if (MenuItems[index] !== selectedItem) {\n this.select.emit({ ...MenuItems[index], selected: false });\n }\n };\n\n private isMenuItem = (item: MenuItem): boolean => {\n return !('separator' in item);\n };\n\n private triggerIconColorWarning() {\n if (this.items.some((item) => 'iconColor' in item)) {\n /* eslint-disable-next-line no-console */\n console.warn(\n \"The `iconColor` prop is deprecated now! Use the new `Icon` interface and instead of `iconColor: 'color-name'` write `icon {name: 'icon-name', color: 'color-name'}`.\",\n );\n }\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{g as n,a as t,b as r,c as e}from"./p-8bc1584b.js";function o(o){const i={id:crypto.randomUUID(),filename:o.name,contentType:o.type,size:o.size,fileContent:o};i.icon={name:n(i),title:t(i),color:r(i),backgroundColor:e(i)};return i}function i(n,t){if(t===undefined||t==="*"){return true}const r=t.split(",").map((n=>n.trim()));return r.some((t=>{if(t===n.contentType){return true}if(t.endsWith("/*")){const r=t.split("/")[0];return n.contentType.startsWith(`${r}/`)}if(t.startsWith(".")){const r=t.split(".")[1];return n.contentType.endsWith(`/${r}`)}}))}export{o as c,i};
|
|
2
|
-
//# sourceMappingURL=p-09cb3405.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["createFileInfo","file","limeFile","id","crypto","randomUUID","filename","name","contentType","type","size","fileContent","icon","getFileIcon","title","getFileExtensionTitle","color","getFileColor","backgroundColor","getFileBackgroundColor","isTypeAccepted","accept","undefined","acceptList","split","map","raw","trim","some","acceptedType","endsWith","baseType","startsWith","fileType"],"sources":["./src/util/files.ts"],"sourcesContent":["import { FileInfo } from '../global/shared-types/file.types';\nimport {\n getFileBackgroundColor,\n getFileColor,\n getFileExtensionTitle,\n getFileIcon,\n} from './file-metadata';\n\nexport function createFileInfo(file: File): FileInfo {\n const limeFile: FileInfo = {\n id: crypto.randomUUID(),\n filename: file.name,\n contentType: file.type,\n size: file.size,\n fileContent: file,\n };\n limeFile.icon = {\n name: getFileIcon(limeFile),\n title: getFileExtensionTitle(limeFile),\n color: getFileColor(limeFile),\n backgroundColor: getFileBackgroundColor(limeFile),\n };\n\n return limeFile;\n}\n\nexport function isTypeAccepted(file: FileInfo, accept?: string): boolean {\n if (accept === undefined || accept === '*') {\n return true;\n }\n\n const acceptList = accept.split(',').map((raw) => raw.trim());\n\n return acceptList.some((acceptedType: string) => {\n if (acceptedType === file.contentType) {\n return true;\n }\n\n if (acceptedType.endsWith('/*')) {\n const baseType = acceptedType.split('/')[0];\n\n return file.contentType.startsWith(`${baseType}/`);\n }\n\n if (acceptedType.startsWith('.')) {\n const fileType = acceptedType.split('.')[1];\n\n return file.contentType.endsWith(`/${fileType}`);\n }\n });\n}\n"],"mappings":"kEAQgBA,EAAeC,GAC3B,MAAMC,EAAqB,CACvBC,GAAIC,OAAOC,aACXC,SAAUL,EAAKM,KACfC,YAAaP,EAAKQ,KAClBC,KAAMT,EAAKS,KACXC,YAAaV,GAEjBC,EAASU,KAAO,CACZL,KAAMM,EAAYX,GAClBY,MAAOC,EAAsBb,GAC7Bc,MAAOC,EAAaf,GACpBgB,gBAAiBC,EAAuBjB,IAG5C,OAAOA,CACX,C,SAEgBkB,EAAenB,EAAgBoB,GAC3C,GAAIA,IAAWC,WAAaD,IAAW,IAAK,CACxC,OAAO,I,CAGX,MAAME,EAAaF,EAAOG,MAAM,KAAKC,KAAKC,GAAQA,EAAIC,SAEtD,OAAOJ,EAAWK,MAAMC,IACpB,GAAIA,IAAiB5B,EAAKO,YAAa,CACnC,OAAO,I,CAGX,GAAIqB,EAAaC,SAAS,MAAO,CAC7B,MAAMC,EAAWF,EAAaL,MAAM,KAAK,GAEzC,OAAOvB,EAAKO,YAAYwB,WAAW,GAAGD,K,CAG1C,GAAIF,EAAaG,WAAW,KAAM,CAC9B,MAAMC,EAAWJ,EAAaL,MAAM,KAAK,GAEzC,OAAOvB,EAAKO,YAAYsB,SAAS,IAAIG,I,IAGjD,Q"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{r as t,c as i,h as s,g as h}from"./p-3075aa67.js";import{t as e}from"./p-3ee3dcdc.js";import{c as n}from"./p-3ccdc4a3.js";import{g as a,a as r,b as o,c as l}from"./p-8bc1584b.js";import{M as c}from"./p-9ab3a908.js";import"./p-2f777fdb.js";import"./p-2ff3f85e.js";import"./p-11d5d44e.js";import"./p-dcc97cc2.js";import"./p-083d1db4.js";const d=":host{--icon-background-color:rgb(var(--contrast-400));--icon-color:rgb(var(--contrast-1100))}";const p="limel-chip-set";const f={id:null,text:null,removable:true};const u=class{constructor(s){t(this,s);this.change=i(this,"change",7);this.interact=i(this,"interact",7);this.fileInputId=n();this.handleDragEnter=t=>{this.isDraggingOverDropZone=true;this.preventAndStop(t)};this.handleDragLeave=()=>{this.isDraggingOverDropZone=false};this.handleFileDrop=t=>{this.preventAndStop(t);this.isDraggingOverDropZone=false;const i=t.dataTransfer;this.handleFile(i.files[0])};this.handleClick=t=>{if(t&&"Lime"in t&&t.Lime.chip){return}this.handleFileSelection(t)};this.value=undefined;this.label=undefined;this.required=false;this.disabled=false;this.readonly=false;this.invalid=false;this.accept="*";this.language="en";this.isDraggingOverDropZone=false;this.handleFileSelection=this.handleFileSelection.bind(this);this.handleFileChange=this.handleFileChange.bind(this);this.handleChipSetChange=this.handleChipSetChange.bind(this);this.handleFileDrop=this.handleFileDrop.bind(this);this.handleKeyDown=this.handleKeyDown.bind(this);this.handleKeyUp=this.handleKeyUp.bind(this);this.handleChipInteract=this.handleChipInteract.bind(this)}connectedCallback(){this.initialize()}componentDidLoad(){this.fileInput=this.element.shadowRoot.getElementById(this.fileInputId);this.chipSet=this.element.shadowRoot.querySelector(p);this.initialize()}initialize(){if(!this.chipSet){return}this.mdcTextField=new c(this.chipSet.shadowRoot.querySelector(".mdc-text-field"))}disconnectedCallback(){if(this.mdcTextField){this.mdcTextField.destroy()}}render(){return[s("input",{hidden:true,id:this.fileInputId,onChange:this.handleFileChange,type:"file",accept:this.accept,disabled:this.disabled||this.readonly}),s("limel-chip-set",{class:{"is-file-picker":true,"shows-dropzone":true,"highlight-dropzone":this.isDraggingOverDropZone},disabled:this.disabled,readonly:this.readonly,invalid:this.invalid,label:this.label,leadingIcon:"upload_to_cloud",language:this.language,onChange:this.handleChipSetChange,onClick:this.handleClick,onInteract:this.handleChipInteract,onKeyDown:this.handleKeyDown,onKeyUp:this.handleKeyUp,required:this.required,type:"input",value:this.chipArray,title:this.getTranslation("drag-and-drop-tips"),onDragEnter:this.handleDragEnter,onDragOver:this.preventAndStop,onDragLeave:this.handleDragLeave,onDrop:this.handleFileDrop})]}get chipArray(){if(!this.value){return[]}return[Object.assign(Object.assign({},f),{text:this.value.filename,id:this.value.id,icon:{name:a(this.value),title:r(this.value),color:o(this.value),backgroundColor:l(this.value)},href:this.value.href})]}handleKeyDown(t){if(t.code==="Tab"||t.code==="Backspace"||t.code==="Enter"){return}t.preventDefault();t.stopPropagation()}handleKeyUp(t){if(t.code==="Enter"&&!this.value){this.fileInput.click()}}handleFileSelection(t){t.stopPropagation();t.preventDefault();if(!this.value){this.fileInput.click()}}handleFileChange(t){if(this.fileInput.files.length>0){t.stopPropagation();this.handleFile(this.fileInput.files[0])}}handleFile(t){const i={id:n(),filename:t.name,contentType:t.type,size:t.size,fileContent:t};this.change.emit(i);this.chipSet.blur();this.mdcTextField.valid=true}handleChipSetChange(t){t.stopPropagation();const i=!t.detail.length?t.detail[0]:null;this.chipSet.blur();if(!i){this.fileInput.value="";this.change.emit(i);if(this.required){this.mdcTextField.valid=false}}}handleChipInteract(t){t.stopPropagation();t.preventDefault();this.interact.emit(t.detail.id)}preventAndStop(t){t.stopPropagation();t.preventDefault()}getTranslation(t){return e.get(`file.${t}`,this.language)}get element(){return h(this)}};u.style=d;export{u as limel_file};
|
|
2
|
-
//# sourceMappingURL=p-0c24c682.entry.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["fileCss","CHIP_SET_TAG_NAME","DEFAULT_FILE_CHIP","id","text","removable","File","constructor","hostRef","this","fileInputId","createRandomString","handleDragEnter","event","isDraggingOverDropZone","preventAndStop","handleDragLeave","handleFileDrop","dataTransfer","handleFile","files","handleClick","Lime","chip","handleFileSelection","bind","handleFileChange","handleChipSetChange","handleKeyDown","handleKeyUp","handleChipInteract","connectedCallback","initialize","componentDidLoad","fileInput","element","shadowRoot","getElementById","chipSet","querySelector","mdcTextField","MDCTextField","disconnectedCallback","destroy","render","h","hidden","onChange","type","accept","disabled","readonly","class","invalid","label","leadingIcon","language","onClick","onInteract","onKeyDown","onKeyUp","required","value","chipArray","title","getTranslation","onDragEnter","onDragOver","onDragLeave","onDrop","filename","icon","name","getFileIcon","getFileExtensionTitle","color","getFileColor","backgroundColor","getFileBackgroundColor","href","code","preventDefault","stopPropagation","click","length","file","limeFile","contentType","size","fileContent","change","emit","blur","valid","detail","interact","key","translate","get"],"sources":["./src/components/file/file.scss?tag=limel-file&encapsulation=shadow","./src/components/file/file.tsx"],"sourcesContent":["/**\n * @prop --icon-background-color: Background color of the icon. Defaults to `--contrast-400`.\n * @prop --icon-color: Color of the icon. Defaults to `--contrast-1100`.\n */\n\n:host {\n --icon-background-color: rgb(var(--contrast-400));\n --icon-color: rgb(var(--contrast-1100));\n}\n","import translate from '../../global/translations';\nimport { Chip } from '../chip-set/chip.types';\nimport { Languages } from '../date-picker/date.types';\nimport { MDCTextField } from '@material/textfield';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Prop,\n State,\n} from '@stencil/core';\nimport { createRandomString } from '../../util/random-string';\nimport {\n getFileBackgroundColor,\n getFileColor,\n getFileExtensionTitle,\n getFileIcon,\n} from '../../util/file-metadata';\nimport { FileInfo } from '../../global/shared-types/file.types';\n\nconst CHIP_SET_TAG_NAME = 'limel-chip-set';\nconst DEFAULT_FILE_CHIP: Chip = {\n id: null,\n text: null,\n removable: true,\n};\n\n/**\n * This component lets end-users select a *single* file from their device\n * storage. Regardless of the user's device or operating system, this component\n * opens up a file picker dialog that allows the user to choose a file.\n *\n * ## Using correct labels\n *\n * This file picker can be used in different contexts. The component's distinct\n * visual design including the upload icon hints end-users that this is not a\n * normal input field like other fields in the form for example.\n *\n * :::important\n * you need to use a descriptive `label` that clarifies the\n * functionality of the file picker, and/or provides users with clear\n * instructions.\n *\n * Depending on the context, you may need to avoid labels such as:\n * - File\n * - Document\n *\n * and instead consider using labels like:\n * - Attach a file\n * - Upload a file\n * - Choose a document\n * - Choose a file\n *\n * and similar phrases...\n * :::\n *\n * @exampleComponent limel-example-file\n * @exampleComponent limel-example-file-custom-icon\n * @exampleComponent limel-example-file-accepted-types\n * @exampleComponent limel-example-file-composite\n */\n@Component({\n tag: 'limel-file',\n shadow: true,\n styleUrl: 'file.scss',\n})\nexport class File {\n /**\n * The selected file.\n */\n @Prop()\n public value: FileInfo;\n\n /**\n * The input label.\n */\n @Prop({ reflect: true })\n public label: string;\n\n /**\n * Set to `true` to indicate that the field is required.\n */\n @Prop({ reflect: true })\n public required: boolean = false;\n\n /**\n * True if the input should be disabled\n */\n @Prop({ reflect: true })\n public disabled: boolean = false;\n\n /**\n * Set to `true` to disable adding and removing files, but allow interaction\n * with any already existing file.\n */\n @Prop({ reflect: true })\n public readonly: boolean = false;\n\n /**\n * Set to `true` to indicate that the current value of the chosen file is\n * invalid.\n */\n @Prop({ reflect: true })\n public invalid = false;\n\n /**\n * The [accepted file types](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#unique_file_type_specifiers)\n */\n @Prop({ reflect: true })\n public accept: string = '*';\n\n /**\n * Defines the localisation for translations.\n */\n @Prop()\n public language: Languages = 'en';\n\n /**\n * Dispatched when a file is selected/deselected\n */\n @Event()\n private change: EventEmitter<FileInfo>;\n\n /**\n * Dispatched when clicking on a chip\n */\n @Event()\n private interact: EventEmitter<number | string>;\n\n @Element()\n private element: HTMLLimelFileElement;\n\n @State()\n private isDraggingOverDropZone = false;\n\n private fileInput: HTMLInputElement;\n private fileInputId = createRandomString();\n private chipSet;\n private mdcTextField;\n\n constructor() {\n this.handleFileSelection = this.handleFileSelection.bind(this);\n this.handleFileChange = this.handleFileChange.bind(this);\n this.handleChipSetChange = this.handleChipSetChange.bind(this);\n this.handleFileDrop = this.handleFileDrop.bind(this);\n this.handleKeyDown = this.handleKeyDown.bind(this);\n this.handleKeyUp = this.handleKeyUp.bind(this);\n this.handleChipInteract = this.handleChipInteract.bind(this);\n }\n\n public connectedCallback() {\n this.initialize();\n }\n\n public componentDidLoad() {\n this.fileInput = this.element.shadowRoot.getElementById(\n this.fileInputId,\n ) as HTMLInputElement;\n this.chipSet = this.element.shadowRoot.querySelector(CHIP_SET_TAG_NAME);\n this.initialize();\n }\n\n private initialize() {\n if (!this.chipSet) {\n return;\n }\n\n this.mdcTextField = new MDCTextField(\n this.chipSet.shadowRoot.querySelector('.mdc-text-field'),\n );\n }\n\n public disconnectedCallback() {\n if (this.mdcTextField) {\n this.mdcTextField.destroy();\n }\n }\n\n public render() {\n return [\n <input\n hidden={true}\n id={this.fileInputId}\n onChange={this.handleFileChange}\n type=\"file\"\n accept={this.accept}\n disabled={this.disabled || this.readonly}\n />,\n <limel-chip-set\n class={{\n 'is-file-picker': true,\n 'shows-dropzone': true,\n 'highlight-dropzone': this.isDraggingOverDropZone,\n }}\n disabled={this.disabled}\n readonly={this.readonly}\n invalid={this.invalid}\n label={this.label}\n leadingIcon=\"upload_to_cloud\"\n language={this.language}\n onChange={this.handleChipSetChange}\n onClick={this.handleClick}\n onInteract={this.handleChipInteract}\n onKeyDown={this.handleKeyDown}\n onKeyUp={this.handleKeyUp}\n required={this.required}\n type=\"input\"\n value={this.chipArray}\n title={this.getTranslation('drag-and-drop-tips')}\n onDragEnter={this.handleDragEnter}\n onDragOver={this.preventAndStop}\n onDragLeave={this.handleDragLeave}\n onDrop={this.handleFileDrop}\n />,\n ];\n }\n\n private handleDragEnter = (event: DragEvent) => {\n this.isDraggingOverDropZone = true;\n this.preventAndStop(event);\n };\n\n private handleDragLeave = () => {\n this.isDraggingOverDropZone = false;\n };\n\n private handleFileDrop = (event: DragEvent) => {\n this.preventAndStop(event);\n this.isDraggingOverDropZone = false;\n const dataTransfer = event.dataTransfer;\n this.handleFile(dataTransfer.files[0]);\n };\n\n private get chipArray() {\n if (!this.value) {\n return [];\n }\n\n return [\n {\n ...DEFAULT_FILE_CHIP,\n text: this.value.filename,\n id: this.value.id,\n icon: {\n name: getFileIcon(this.value),\n title: getFileExtensionTitle(this.value),\n color: getFileColor(this.value),\n backgroundColor: getFileBackgroundColor(this.value),\n },\n href: this.value.href,\n },\n ];\n }\n\n private handleKeyDown(event: KeyboardEvent) {\n if (\n event.code === 'Tab' ||\n event.code === 'Backspace' ||\n event.code === 'Enter'\n ) {\n return;\n }\n\n event.preventDefault();\n event.stopPropagation();\n }\n\n private handleKeyUp(event: KeyboardEvent) {\n if (event.code === 'Enter' && !this.value) {\n this.fileInput.click();\n }\n }\n\n private handleClick = (event: Event) => {\n if (event && 'Lime' in event && (event.Lime as any).chip) {\n // This is a click on a chip, so we don't need to do anything here.\n return;\n }\n\n this.handleFileSelection(event);\n };\n\n private handleFileSelection(event: Event) {\n event.stopPropagation();\n event.preventDefault();\n if (!this.value) {\n this.fileInput.click();\n }\n }\n\n private handleFileChange(event: Event) {\n if (this.fileInput.files.length > 0) {\n event.stopPropagation();\n this.handleFile(this.fileInput.files[0]);\n }\n }\n\n private handleFile(file) {\n const limeFile: FileInfo = {\n id: createRandomString(),\n filename: file.name,\n contentType: file.type,\n size: file.size,\n fileContent: file,\n };\n this.change.emit(limeFile);\n this.chipSet.blur();\n this.mdcTextField.valid = true;\n }\n\n private handleChipSetChange(event: CustomEvent) {\n event.stopPropagation();\n const file = !event.detail.length ? event.detail[0] : null;\n this.chipSet.blur();\n if (!file) {\n this.fileInput.value = '';\n this.change.emit(file);\n if (this.required) {\n this.mdcTextField.valid = false;\n }\n }\n }\n\n private handleChipInteract(event: CustomEvent<Chip>) {\n event.stopPropagation();\n event.preventDefault();\n this.interact.emit(event.detail.id);\n }\n\n private preventAndStop(event: Event) {\n event.stopPropagation();\n event.preventDefault();\n }\n\n private getTranslation(key: string) {\n return translate.get(`file.${key}`, this.language);\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{k as r}from"./p-cb91d37d.js";function n(r){return function(n,t,e){var a=-1,f=Object(n),i=e(n),o=i.length;while(o--){var u=i[r?o:++a];if(t(f[u],u,f)===false){break}}return n}}var t=n();function e(n,e){return n&&t(n,e,r)}export{e as b};
|
|
2
|
-
//# sourceMappingURL=p-5def744e.js.map
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{r as t,c as i,h as s,g as e}from"./p-3075aa67.js";import{A as n}from"./p-97107e34.js";import{i as h}from"./p-5e7b7b03.js";import{T as r,E as o,a,b as l,c,d,A as u,e as f,f as p,g as m}from"./p-e03dfe70.js";import{c as y}from"./p-3ccdc4a3.js";import{g,c as b}from"./p-2f777fdb.js";const w=":host{position:relative;display:block}:host([hidden]){display:none}";const v=500;const D="limel-chip-set";const C=class{constructor(s){t(this,s);this.change=i(this,"change",7);this.interact=i(this,"interact",7);this.action=i(this,"action",7);this.chipSetEditMode=false;this.getValueId=t=>{const i=t.value;if(!!i&&typeof i==="object"){return i.id}return i};this.createChips=t=>{if(!t){return[]}if(this.multiple){const i=t;return i.map(this.createChip)}const i=t;return[this.createChip(i)]};this.createChip=t=>{const i=g(t.icon);const s=b(t.icon,t.iconColor);const e=this.getValueId(t);return{id:`${e}`,text:t.text,removable:true,icon:i?{name:i,color:s}:undefined,value:t}};this.disabled=false;this.readonly=false;this.label=undefined;this.searchLabel=undefined;this.helperText=undefined;this.leadingIcon=undefined;this.emptyResultMessage=undefined;this.required=false;this.invalid=false;this.value=undefined;this.searcher=undefined;this.multiple=false;this.delimiter=null;this.actions=[];this.actionPosition="bottom";this.actionScrollBehavior="sticky";this.badgeIcons=false;this.items=undefined;this.textValue="";this.loading=false;this.chips=[];this.handleTextInput=this.handleTextInput.bind(this);this.handleInputKeyDown=this.handleInputKeyDown.bind(this);this.handleDropdownKeyDown=this.handleDropdownKeyDown.bind(this);this.handleInputFieldFocus=this.handleInputFieldFocus.bind(this);this.handleChange=this.handleChange.bind(this);this.handleInteract=this.handleInteract.bind(this);this.handleListChange=this.handleListChange.bind(this);this.handleActionListChange=this.handleActionListChange.bind(this);this.handleStopEditAndBlur=this.handleStopEditAndBlur.bind(this);this.createDebouncedSearcher=this.createDebouncedSearcher.bind(this);this.handleCloseMenu=this.handleCloseMenu.bind(this);this.onListKeyDown=this.onListKeyDown.bind(this);this.portalId=y()}componentWillLoad(){this.chips=this.createChips(this.value)}componentDidLoad(){this.createDebouncedSearcher(this.searcher);this.chipSet=this.host.shadowRoot.querySelector(D)}async componentWillUpdate(){this.chipSetEditMode=false;if(this.chipSet){this.chipSetEditMode=await this.chipSet.getEditMode()}}render(){const t={};if(!this.multiple){t.maxItems=1}return[s("limel-chip-set",Object.assign({type:"input",inputType:"search",label:this.label,helperText:this.helperText,leadingIcon:this.leadingIcon,value:this.chips,disabled:this.disabled,invalid:this.invalid,delimiter:this.renderDelimiter(),readonly:this.readonly,required:this.required,searchLabel:this.searchLabel,onInput:this.handleTextInput,onKeyDown:this.handleInputKeyDown,onChange:this.handleChange,onInteract:this.handleInteract,onStartEdit:this.handleInputFieldFocus,onStopEdit:this.handleStopEditAndBlur,emptyInputOnBlur:false,clearAllButton:this.multiple&&!this.chipSetEditMode},t)),this.renderDropdown()]}onChangeValue(){this.chips=this.createChips(this.value)}createDebouncedSearcher(t){if(typeof t!=="function"){return}this.debouncedSearch=n(t,v)}renderDelimiter(){if(this.multiple){return this.delimiter}return null}renderDropdown(){const t=this.getDropdownContent();const i=[];if(this.shouldShowDropDownContent()){const s=this.getActionContent();if(this.actionPosition==="top"){i.push(s)}if(t){i.push(t)}if(this.actionPosition==="bottom"){i.push(s)}}return this.renderPortal(i)}getActionContent(){var t,i;const e=(i=(t=this.actions)===null||t===void 0?void 0:t.length)!==null&&i!==void 0?i:0;if(e===0){return null}return[s("limel-list",{class:{"static-actions-list":true,"is-on-top":this.actionPosition==="top","is-at-bottom":this.actionPosition==="bottom","has-position-sticky":this.actionScrollBehavior==="sticky"},badgeIcons:true,type:"selectable",onChange:this.handleActionListChange,items:this.actions.map(this.removeUnusedPropertiesOnAction)})]}removeUnusedPropertiesOnAction(t){return Object.assign(Object.assign({},t),{actions:[]})}shouldShowDropDownContent(){if(this.isFull()){return false}return!!this.chipSetEditMode}getDropdownContent(){if(!this.shouldShowDropDownContent()){return}if(this.loading){return this.renderSpinner()}if(!this.items||!this.items.length){return this.renderEmptyMessage()}return this.renderListResult()}isFull(){return!this.multiple&&!!this.value}renderSpinner(){return s("div",{style:{width:"100%",display:"flex","align-items":"center","justify-content":"center",padding:"1rem 0"}},s("limel-spinner",{limeBranded:false}))}renderEmptyMessage(){if(!this.emptyResultMessage){return}const t={color:"rgb(var(--contrast-1100))","text-align":"center",margin:"0.5rem 1rem"};return s("p",{style:t},this.emptyResultMessage)}renderListResult(){return s("limel-list",{badgeIcons:this.badgeIcons,onChange:this.handleListChange,onKeyDown:this.onListKeyDown,type:"selectable",items:this.items})}onListKeyDown(t){const i=[r,o,a].includes(t.key);const s=[l,c,d].includes(t.keyCode);if(i||s){this.chipSet.setFocus()}}renderPortal(t=[]){const i=getComputedStyle(this.host).getPropertyValue("--dropdown-z-index");return s("limel-portal",{visible:t.length>0,containerId:this.portalId,inheritParentWidth:true,containerStyle:{"z-index":i}},s("limel-menu-surface",{open:t.length>0,allowClicksElement:this.host,style:{"--mdc-menu-min-width":"100%","max-height":"inherit",display:"flex"},onDismiss:this.handleCloseMenu},t))}handleStopEditAndBlur(){const t=this.host.shadowRoot.activeElement||document.activeElement;const i=document.querySelector(`#${this.portalId}`);if(h(t,this.host)||h(t,i)){return}this.clearInputField()}async handleTextInput(t){t.stopPropagation();const i=t.detail;this.textValue=i;this.loading=true;const s=i===""?this.searcher:this.debouncedSearch;const e=await s(i);this.handleSearchResult(i,e)}handleListChange(t){var i;t.stopPropagation();if(!this.value||this.value!==t.detail){let i=t.detail;if(this.multiple){i=[...this.value,t.detail]}this.change.emit(i);this.items=[]}if(this.multiple){(i=this.chipSet)===null||i===void 0?void 0:i.setFocus(true)}}handleActionListChange(t){t.stopPropagation();if(!t.detail){return}this.action.emit(t.detail.value);this.items=[]}async handleInputFieldFocus(){this.loading=true;const t=this.textValue;const i=await this.searcher(t);this.handleSearchResult(t,i)}handleChange(t){t.stopPropagation();let i=null;if(this.multiple){const s=t.detail;i=s.map((t=>this.value.find((i=>{const s=this.getValueId(i);return`${s}`===t.id}))))}this.change.emit(i)}handleInteract(t){t.stopPropagation();this.interact.emit(t.detail?t.detail.value:t.detail)}handleInputKeyDown(t){const i=(t.key===r||t.keyCode===l)&&!t.altKey&&!t.metaKey&&!t.shiftKey;const s=t.key===u||t.keyCode===f;const e=t.key===p||t.keyCode===m;if(!i&&!s&&!e){return}const n=document.querySelector(` #${this.portalId} limel-list`);if(!n){return}t.preventDefault();if(i||e){const t=n.shadowRoot.querySelector(".mdc-deprecated-list-item:first-child");t.focus();return}if(s){const t=n.shadowRoot.querySelector(".mdc-deprecated-list-item:last-child");t.focus()}}handleDropdownKeyDown(t){const i=t.key===o||t.keyCode===c;if(i){t.preventDefault();this.textValue="";this.chipSet.setFocus(true)}}handleSearchResult(t,i){if(t===this.textValue){this.items=i;if(this.multiple){const t=this.value;this.items=i.filter((i=>!t.includes(i)))}this.loading=false}}handleCloseMenu(){if(this.items.length>0){return}this.clearInputField()}clearInputField(){this.chipSet.emptyInput();this.textValue="";this.handleSearchResult("",[])}get host(){return e(this)}static get watchers(){return{value:["onChangeValue"],searcher:["createDebouncedSearcher"]}}};C.style=w;export{C as limel_picker};
|
|
2
|
-
//# sourceMappingURL=p-8d13a44f.entry.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["pickerCss","SEARCH_DEBOUNCE","CHIP_SET_TAG_NAME","Picker","constructor","hostRef","this","chipSetEditMode","getValueId","item","value","id","createChips","multiple","listItems","map","createChip","listItem","name","getIconName","icon","color","getIconFillColor","iconColor","valueId","text","removable","undefined","handleTextInput","bind","handleInputKeyDown","handleDropdownKeyDown","handleInputFieldFocus","handleChange","handleInteract","handleListChange","handleActionListChange","handleStopEditAndBlur","createDebouncedSearcher","handleCloseMenu","onListKeyDown","portalId","createRandomString","componentWillLoad","chips","componentDidLoad","searcher","chipSet","host","shadowRoot","querySelector","async","getEditMode","render","props","maxItems","h","Object","assign","type","inputType","label","helperText","leadingIcon","disabled","invalid","delimiter","renderDelimiter","readonly","required","searchLabel","onInput","onKeyDown","onChange","onInteract","onStartEdit","onStopEdit","emptyInputOnBlur","clearAllButton","renderDropdown","onChangeValue","newValue","debouncedSearch","AwesomeDebouncePromise","dropDownContent","getDropdownContent","content","shouldShowDropDownContent","actionContent","getActionContent","actionPosition","push","renderPortal","actionCount","_b","_a","actions","length","class","actionScrollBehavior","badgeIcons","items","removeUnusedPropertiesOnAction","action","isFull","loading","renderSpinner","renderEmptyMessage","renderListResult","style","width","display","padding","limeBranded","emptyResultMessage","margin","event","keyFound","TAB","ESCAPE","ENTER","includes","key","keyCodeFound","TAB_KEY_CODE","ESCAPE_KEY_CODE","ENTER_KEY_CODE","keyCode","setFocus","dropdownZIndex","getComputedStyle","getPropertyValue","visible","containerId","inheritParentWidth","containerStyle","open","allowClicksElement","onDismiss","element","activeElement","document","portalElement","isDescendant","clearInputField","stopPropagation","query","detail","textValue","searchFn","result","handleSearchResult","change","emit","chip","find","interact","isForwardTab","altKey","metaKey","shiftKey","isUp","ARROW_UP","ARROW_UP_KEY_CODE","isDown","ARROW_DOWN","ARROW_DOWN_KEY_CODE","list","preventDefault","listElement","focus","isEscape","values","filter","emptyInput"],"sources":["./src/components/picker/picker.scss?tag=limel-picker&encapsulation=shadow","./src/components/picker/picker.tsx"],"sourcesContent":["// Note! The `--dropdown-z-index` property is used from `picker.tsx`.\n/**\n * @prop --dropdown-z-index: z-index of the dropdown menu.\n */\n\n:host {\n position: relative;\n display: block;\n}\n\n:host([hidden]) {\n display: none;\n}\n","import { Action } from '../collapsible-section/action';\nimport { ActionPosition, ActionScrollBehavior } from '../picker/actions.types';\nimport { Chip } from '../chip-set/chip.types';\nimport { ListItem } from '../list/list-item.types';\nimport { Searcher } from '../picker/searcher.types';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\nimport AwesomeDebouncePromise from 'awesome-debounce-promise';\nimport { isDescendant } from '../../util/dom';\nimport {\n ARROW_DOWN,\n ARROW_DOWN_KEY_CODE,\n ARROW_UP,\n ARROW_UP_KEY_CODE,\n ENTER,\n ENTER_KEY_CODE,\n ESCAPE,\n ESCAPE_KEY_CODE,\n TAB,\n TAB_KEY_CODE,\n} from '../../util/keycodes';\nimport { createRandomString } from '../../util/random-string';\nimport {\n LimelChipSetCustomEvent,\n LimelListCustomEvent,\n} from '../../components';\nimport { getIconFillColor, getIconName } from '../icon/get-icon-props';\nimport { PickerValue } from './value.types';\n\nconst SEARCH_DEBOUNCE = 500;\nconst CHIP_SET_TAG_NAME = 'limel-chip-set';\n\n/**\n * @exampleComponent limel-example-picker-single\n * @exampleComponent limel-example-picker-multiple\n * @exampleComponent limel-example-picker-icons\n * @exampleComponent limel-example-picker-value-as-object\n * @exampleComponent limel-example-picker-empty-suggestions\n * @exampleComponent limel-example-picker-leading-icon\n * @exampleComponent limel-example-picker-static-actions\n * @exampleComponent limel-example-picker-composite\n */\n@Component({\n tag: 'limel-picker',\n shadow: true,\n styleUrl: 'picker.scss',\n})\nexport class Picker {\n /**\n * True if the picker should be disabled\n */\n @Prop()\n public disabled: boolean = false;\n\n /**\n * Set to `true` to disable adding and removing items,\n * but allow interaction with existing items.\n */\n @Prop({ reflect: true })\n public readonly: boolean = false;\n\n /**\n * Text to display for the input field of the picker\n */\n @Prop()\n public label: string;\n\n /**\n * Search label to display in the input field when searching\n */\n @Prop()\n public searchLabel: string;\n\n /**\n * Optional helper text to display below the input field when it has focus\n */\n @Prop({ reflect: true })\n public helperText: string;\n\n /**\n * Leading icon to show to the far left in the text field\n */\n @Prop()\n public leadingIcon: string;\n\n /**\n * A message to display when the search returned an empty result\n */\n @Prop()\n public emptyResultMessage: string;\n\n /**\n * True if the control requires a value\n */\n @Prop()\n public required: boolean = false;\n\n /**\n * Set to `true` to indicate that the current value of the input field is\n * invalid.\n */\n @Prop({ reflect: true })\n public invalid = false;\n\n /**\n * Currently selected value or values. Where the value can be an object.\n */\n @Prop()\n public value: ListItem<PickerValue> | Array<ListItem<PickerValue>>;\n\n /**\n * A search function that takes a search-string as an argument,\n * and returns a promise that will eventually be resolved with\n * an array of `ListItem`:s.\n *\n * See the docs for the type `Searcher` for type information on\n * the searcher function itself.\n */\n @Prop()\n public searcher: Searcher;\n\n /**\n * True if multiple values are allowed\n */\n @Prop()\n public multiple: boolean = false;\n\n /**\n * Sets delimiters between chips. Works only when `multiple` is `true`.\n */\n @Prop({ reflect: true })\n public delimiter: string = null;\n\n /**\n * Static actions that can be clicked by the user.\n */\n @Prop()\n public actions: Array<ListItem<Action>> = [];\n\n /**\n * Position of the custom static actions in the picker's results dropdown.\n * Can be set to `'top'` or `'bottom'`.\n */\n @Prop()\n public actionPosition: ActionPosition = 'bottom';\n\n /**\n * Scroll behavior of the custom static actions, when user scrolls\n * in the picker's results dropdown. Can be set to `'scroll'` which means\n * the action items will scroll together with the list, or `'sticky'` which\n * retains their position at the top or bottom of the drop down while\n * scrolling.\n */\n @Prop()\n public actionScrollBehavior: ActionScrollBehavior = 'sticky';\n\n /**\n * Whether badge icons should be used in the result list or not\n */\n @Prop({ reflect: true })\n public badgeIcons: boolean = false;\n\n /**\n * Fired when a new value has been selected from the picker\n */\n @Event()\n private change: EventEmitter<\n ListItem<PickerValue> | Array<ListItem<PickerValue>>\n >;\n\n /**\n * Fired when clicking on a selected value\n */\n @Event()\n private interact: EventEmitter<ListItem<PickerValue>>;\n\n /**\n * Emitted when the user selects an action.\n */\n @Event()\n private action: EventEmitter<Action>;\n\n @State()\n private items: Array<ListItem<number | string>>;\n\n @State()\n private textValue: string = '';\n\n @State()\n private loading: boolean = false;\n\n @State()\n private chips: Chip[] = [];\n\n @Element()\n private host: HTMLLimelPickerElement;\n\n // Should NOT be decorated with State(), since this\n // should not trigger a re-render by itself.\n private chipSetEditMode = false;\n\n private debouncedSearch: Searcher;\n private chipSet: HTMLLimelChipSetElement;\n private portalId: string;\n\n constructor() {\n this.handleTextInput = this.handleTextInput.bind(this);\n this.handleInputKeyDown = this.handleInputKeyDown.bind(this);\n this.handleDropdownKeyDown = this.handleDropdownKeyDown.bind(this);\n this.handleInputFieldFocus = this.handleInputFieldFocus.bind(this);\n this.handleChange = this.handleChange.bind(this);\n this.handleInteract = this.handleInteract.bind(this);\n this.handleListChange = this.handleListChange.bind(this);\n this.handleActionListChange = this.handleActionListChange.bind(this);\n this.handleStopEditAndBlur = this.handleStopEditAndBlur.bind(this);\n this.createDebouncedSearcher = this.createDebouncedSearcher.bind(this);\n this.handleCloseMenu = this.handleCloseMenu.bind(this);\n this.onListKeyDown = this.onListKeyDown.bind(this);\n\n this.portalId = createRandomString();\n }\n\n public componentWillLoad() {\n this.chips = this.createChips(this.value);\n }\n\n public componentDidLoad() {\n this.createDebouncedSearcher(this.searcher);\n this.chipSet = this.host.shadowRoot.querySelector(CHIP_SET_TAG_NAME);\n }\n\n public async componentWillUpdate() {\n this.chipSetEditMode = false;\n if (this.chipSet) {\n this.chipSetEditMode = await this.chipSet.getEditMode();\n }\n }\n\n public render() {\n const props: {\n maxItems?: number;\n } = {};\n\n if (!this.multiple) {\n props.maxItems = 1;\n }\n\n return [\n <limel-chip-set\n type=\"input\"\n inputType=\"search\"\n label={this.label}\n helperText={this.helperText}\n leadingIcon={this.leadingIcon}\n value={this.chips}\n disabled={this.disabled}\n invalid={this.invalid}\n delimiter={this.renderDelimiter()}\n readonly={this.readonly}\n required={this.required}\n searchLabel={this.searchLabel}\n onInput={this.handleTextInput}\n onKeyDown={this.handleInputKeyDown}\n onChange={this.handleChange}\n onInteract={this.handleInteract}\n onStartEdit={this.handleInputFieldFocus}\n onStopEdit={this.handleStopEditAndBlur}\n emptyInputOnBlur={false}\n clearAllButton={this.multiple && !this.chipSetEditMode}\n {...props}\n />,\n this.renderDropdown(),\n ];\n }\n\n @Watch('value')\n protected onChangeValue() {\n this.chips = this.createChips(this.value);\n }\n\n @Watch('searcher')\n protected createDebouncedSearcher(newValue: Searcher) {\n if (typeof newValue !== 'function') {\n return;\n }\n\n this.debouncedSearch = AwesomeDebouncePromise(\n newValue,\n SEARCH_DEBOUNCE,\n );\n }\n\n private renderDelimiter() {\n if (this.multiple) {\n return this.delimiter;\n }\n\n return null;\n }\n\n private getValueId = (item: ListItem) => {\n const value = item.value;\n if (!!value && typeof value === 'object') {\n return value.id;\n }\n\n return value;\n };\n\n private createChips = (value: ListItem | ListItem[]): Chip[] => {\n if (!value) {\n return [];\n }\n\n if (this.multiple) {\n const listItems: ListItem[] = value as ListItem[];\n\n return listItems.map(this.createChip);\n }\n\n const listItem: ListItem = value as ListItem;\n\n return [this.createChip(listItem)];\n };\n\n private createChip = (listItem: ListItem): Chip => {\n const name = getIconName(listItem.icon);\n const color = getIconFillColor(listItem.icon, listItem.iconColor);\n const valueId = this.getValueId(listItem);\n\n return {\n id: `${valueId}`,\n text: listItem.text,\n removable: true,\n icon: name ? { name: name, color: color } : undefined,\n value: listItem,\n };\n };\n\n /**\n * Renders the dropdown with the items to pick from, or a spinner if the picker\n * is waiting for items to be received\n *\n * @returns picker dropdown\n */\n private renderDropdown() {\n const dropDownContent = this.getDropdownContent();\n\n const content = [];\n\n if (this.shouldShowDropDownContent()) {\n const actionContent = this.getActionContent();\n if (this.actionPosition === 'top') {\n content.push(actionContent);\n }\n\n if (dropDownContent) {\n content.push(dropDownContent);\n }\n\n if (this.actionPosition === 'bottom') {\n content.push(actionContent);\n }\n }\n\n return this.renderPortal(content);\n }\n\n private getActionContent() {\n const actionCount = this.actions?.length ?? 0;\n if (actionCount === 0) {\n return null;\n }\n\n return [\n <limel-list\n class={{\n 'static-actions-list': true,\n 'is-on-top': this.actionPosition === 'top',\n 'is-at-bottom': this.actionPosition === 'bottom',\n 'has-position-sticky':\n this.actionScrollBehavior === 'sticky',\n }}\n badgeIcons={true}\n type={'selectable'}\n onChange={this.handleActionListChange}\n items={this.actions.map(this.removeUnusedPropertiesOnAction)}\n />,\n ];\n }\n\n private removeUnusedPropertiesOnAction(\n action: ListItem<Action>,\n ): ListItem<Action> {\n return {\n ...action,\n actions: [],\n };\n }\n\n private shouldShowDropDownContent() {\n if (this.isFull()) {\n return false;\n }\n\n return !!this.chipSetEditMode;\n }\n\n private getDropdownContent() {\n if (!this.shouldShowDropDownContent()) {\n return;\n }\n\n if (this.loading) {\n return this.renderSpinner();\n }\n\n if (!this.items || !this.items.length) {\n return this.renderEmptyMessage();\n }\n\n return this.renderListResult();\n }\n\n /**\n * Returns true if the picker is \"full\"\n * The picker is considered to be full if it has a value and only one is allowed\n *\n * @returns true if the picker is full\n */\n private isFull(): boolean {\n return !this.multiple && !!this.value;\n }\n\n private renderSpinner() {\n return (\n <div\n style={{\n width: '100%',\n display: 'flex',\n 'align-items': 'center',\n 'justify-content': 'center',\n padding: '1rem 0',\n }}\n >\n <limel-spinner limeBranded={false} />\n </div>\n );\n }\n\n private renderEmptyMessage() {\n if (!this.emptyResultMessage) {\n return;\n }\n\n const style = {\n color: 'rgb(var(--contrast-1100))',\n 'text-align': 'center',\n margin: '0.5rem 1rem',\n };\n\n return <p style={style}>{this.emptyResultMessage}</p>;\n }\n\n private renderListResult() {\n return (\n <limel-list\n badgeIcons={this.badgeIcons}\n onChange={this.handleListChange}\n onKeyDown={this.onListKeyDown}\n type=\"selectable\"\n items={this.items}\n />\n );\n }\n\n private onListKeyDown(event: KeyboardEvent) {\n const keyFound = [TAB, ESCAPE, ENTER].includes(event.key);\n const keyCodeFound = [\n TAB_KEY_CODE,\n ESCAPE_KEY_CODE,\n ENTER_KEY_CODE,\n ].includes(event.keyCode);\n if (keyFound || keyCodeFound) {\n this.chipSet.setFocus();\n }\n }\n\n private renderPortal(content: any[] = []) {\n const dropdownZIndex = getComputedStyle(this.host).getPropertyValue(\n '--dropdown-z-index',\n );\n\n return (\n <limel-portal\n visible={content.length > 0}\n containerId={this.portalId}\n inheritParentWidth={true}\n containerStyle={{ 'z-index': dropdownZIndex }}\n >\n <limel-menu-surface\n open={content.length > 0}\n allowClicksElement={this.host}\n style={{\n '--mdc-menu-min-width': '100%',\n 'max-height': 'inherit',\n display: 'flex',\n }}\n onDismiss={this.handleCloseMenu}\n >\n {content}\n </limel-menu-surface>\n </limel-portal>\n );\n }\n\n /**\n * Check if a descendant still has focus. If not, reset text value and search result.\n */\n private handleStopEditAndBlur() {\n // In browsers where shadow DOM is not supported activeElement on shadowRoot will return null\n // However, document.activeElement will return the actual focused element instead of the outermost shadow host\n const element =\n this.host.shadowRoot.activeElement || document.activeElement;\n const portalElement = document.querySelector(`#${this.portalId}`);\n if (\n isDescendant(element as HTMLElement, this.host) ||\n isDescendant(element as HTMLElement, portalElement as HTMLElement)\n ) {\n return;\n }\n\n this.clearInputField();\n }\n\n /**\n * Input handler for the input field\n *\n * @param event - event\n */\n private async handleTextInput(event) {\n event.stopPropagation();\n\n const query = event.detail;\n this.textValue = query;\n this.loading = true;\n\n // If the search-query is an empty string, bypass debouncing.\n const searchFn = query === '' ? this.searcher : this.debouncedSearch;\n const result = (await searchFn(query)) as Array<ListItem<PickerValue>>;\n this.handleSearchResult(query, result);\n }\n\n /**\n * Change handler for the list\n *\n * @param event - event\n */\n private handleListChange(\n event: LimelListCustomEvent<ListItem<PickerValue>>,\n ) {\n event.stopPropagation();\n if (!this.value || this.value !== event.detail) {\n let newValue: ListItem<PickerValue> | Array<ListItem<PickerValue>> =\n event.detail;\n if (this.multiple) {\n newValue = [\n ...(this.value as Array<ListItem<PickerValue>>),\n event.detail,\n ];\n }\n\n this.change.emit(newValue);\n this.items = [];\n }\n\n if (this.multiple) {\n this.chipSet?.setFocus(true);\n }\n }\n\n /**\n * Change handler for the list\n *\n * @param event - event\n */\n private handleActionListChange(\n event: LimelListCustomEvent<ListItem<Action>>,\n ) {\n event.stopPropagation();\n if (!event.detail) {\n return;\n }\n\n this.action.emit(event.detail.value);\n this.items = [];\n }\n\n /**\n * Focus handler for the chip set\n * Prevent focus if the picker has a value and does not support multiple values\n */\n private async handleInputFieldFocus() {\n this.loading = true;\n const query = this.textValue;\n const result = (await this.searcher(query)) as Array<\n ListItem<PickerValue>\n >;\n this.handleSearchResult(query, result);\n }\n\n private handleChange(event: LimelChipSetCustomEvent<Chip | Chip[]>) {\n event.stopPropagation();\n\n let newValue = null;\n if (this.multiple) {\n const chips = event.detail as Chip[];\n newValue = chips.map((chip) => {\n return (this.value as ListItem[]).find((item) => {\n const valueId = this.getValueId(item);\n\n return `${valueId}` === chip.id;\n });\n });\n }\n\n this.change.emit(newValue);\n }\n\n private handleInteract(event: LimelChipSetCustomEvent<Chip>) {\n event.stopPropagation();\n this.interact.emit(event.detail ? event.detail.value : event.detail);\n }\n\n /**\n * Key handler for the input field\n * Will change focus to the first/last item in the dropdown list to enable selection with the keyboard\n *\n * @param event - event\n */\n private handleInputKeyDown(event: KeyboardEvent) {\n const isForwardTab =\n (event.key === TAB || event.keyCode === TAB_KEY_CODE) &&\n !event.altKey &&\n !event.metaKey &&\n !event.shiftKey;\n const isUp =\n event.key === ARROW_UP || event.keyCode === ARROW_UP_KEY_CODE;\n const isDown =\n event.key === ARROW_DOWN || event.keyCode === ARROW_DOWN_KEY_CODE;\n\n if (!isForwardTab && !isUp && !isDown) {\n return;\n }\n\n const list = document.querySelector(` #${this.portalId} limel-list`);\n if (!list) {\n return;\n }\n\n event.preventDefault();\n\n if (isForwardTab || isDown) {\n const listElement: HTMLElement = list.shadowRoot.querySelector(\n '.mdc-deprecated-list-item:first-child',\n );\n listElement.focus();\n\n return;\n }\n\n if (isUp) {\n const listElement: HTMLElement = list.shadowRoot.querySelector(\n '.mdc-deprecated-list-item:last-child',\n );\n listElement.focus();\n }\n }\n\n /**\n * Key handler for the dropdown\n *\n * @param event - event\n */\n private handleDropdownKeyDown(event: KeyboardEvent) {\n const isEscape =\n event.key === ESCAPE || event.keyCode === ESCAPE_KEY_CODE;\n\n if (isEscape) {\n event.preventDefault();\n this.textValue = '';\n this.chipSet.setFocus(true);\n }\n }\n\n private handleSearchResult(query: string, result: ListItem[]) {\n if (query === this.textValue) {\n this.items = result;\n if (this.multiple) {\n const values = this.value as ListItem[];\n this.items = result.filter((item) => {\n return !values.includes(item);\n });\n }\n\n this.loading = false;\n }\n }\n\n private handleCloseMenu() {\n if (this.items.length > 0) {\n return;\n }\n\n this.clearInputField();\n }\n\n private clearInputField() {\n this.chipSet.emptyInput();\n this.textValue = '';\n this.handleSearchResult('', []);\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
var n=function n(i){var u=arguments.length>1&&arguments[1]!==undefined?arguments[1]:0;var e=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{};var o=void 0;var f=void 0;var a=void 0;var v=[];return function n(){var c=r(u);var l=(new Date).getTime();var h=!o||l-o>c;o=l;for(var d=arguments.length,m=Array(d),p=0;p<d;p++){m[p]=arguments[p]}if(h&&e.leading){return e.accumulate?Promise.resolve(i.call(this,[m])).then((function(n){return n[0]})):Promise.resolve(i.call.apply(i,[this].concat(m)))}if(f){clearTimeout(a)}else{f=t()}v.push(m);a=setTimeout(s.bind(this),c);if(e.accumulate){var w=v.length-1;return f.promise.then((function(n){return n[w]}))}return f.promise};function s(){var n=f;clearTimeout(a);Promise.resolve(e.accumulate?i.call(this,v):i.apply(this,v[v.length-1])).then(n.resolve,n.reject);v=[];f=null}};function r(n){return typeof n==="function"?n():n}function t(){var n={};n.promise=new Promise((function(r,t){n.resolve=r;n.reject=t}));return n}function i(n){var r=null;var t=null;var i=new Promise((function(n,i){r=n;t=i}));n&&n.then((function(n){r&&r(n)}),(function(n){t&&t(n)}));return{promise:i,resolve:function(n){r&&r(n)},reject:function(n){t&&t(n)},cancel:function(){r=null;t=null}}}function u(n){var r=null;var t=function(){var t=[];for(var u=0;u<arguments.length;u++){t[u]=arguments[u]}r&&r();var e=n.apply(void 0,t);var o=i(e),f=o.promise,a=o.cancel;r=a;return f};return t}
|
|
2
|
-
/*! *****************************************************************************
|
|
3
|
-
Copyright (c) Microsoft Corporation. All rights reserved.
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
|
|
5
|
-
this file except in compliance with the License. You may obtain a copy of the
|
|
6
|
-
License at http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
-
|
|
8
|
-
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
9
|
-
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
|
|
10
|
-
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
|
|
11
|
-
MERCHANTABLITY OR NON-INFRINGEMENT.
|
|
12
|
-
|
|
13
|
-
See the Apache Version 2.0 License for specific language governing permissions
|
|
14
|
-
and limitations under the License.
|
|
15
|
-
***************************************************************************** */var e=function(){e=Object.assign||function n(r){for(var t,i=1,u=arguments.length;i<u;i++){t=arguments[i];for(var e in t)if(Object.prototype.hasOwnProperty.call(t,e))r[e]=t[e]}return r};return e.apply(this,arguments)};var o={key:function(){var n=[];for(var r=0;r<arguments.length;r++){n[r]=arguments[r]}return null},onlyResolvesLast:true};var f=function(){function r(n){this.config=n;this.debounceSingleton=null;this.debounceCache={}}r.prototype._createDebouncedFunction=function(){var r=n(this.config.func,this.config.wait,this.config.options);if(this.config.options.onlyResolvesLast){r=u(r)}return{func:r}};r.prototype.getDebouncedFunction=function(n){var r;var t=(r=this.config.options).key.apply(r,n);if(t===null||typeof t==="undefined"){if(!this.debounceSingleton){this.debounceSingleton=this._createDebouncedFunction()}return this.debounceSingleton}else{if(!this.debounceCache[t]){this.debounceCache[t]=this._createDebouncedFunction()}return this.debounceCache[t]}};return r}();function a(n,r,t){var i=e({},o,t);var u=new f({func:n,wait:r,options:i});var a=function(){var n=[];for(var r=0;r<arguments.length;r++){n[r]=arguments[r]}var t=u.getDebouncedFunction(n).func;return t.apply(void 0,n)};return a}export{a as A};
|
|
16
|
-
//# sourceMappingURL=p-97107e34.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["dist","debounce","fn","wait","arguments","length","undefined","options","lastCallAt","deferred","timer","pendingArgs","debounced","currentWait","getWait","currentTime","Date","getTime","isCold","_len","args","Array","_key","leading","accumulate","Promise","resolve","call","this","then","result","apply","concat","clearTimeout","defer","push","setTimeout","flush","bind","argsIndex","promise","results","thisDeferred","reject","createImperativePromise","promiseArg","wrappedPromise","_resolve","_reject","val","error","value","reason","cancel","onlyResolvesLast","asyncFunction","cancelPrevious","wrappedFunction","_i","initialPromise","_a","__assign","Object","assign","t","s","i","n","p","prototype","hasOwnProperty","DefaultOptions","key","_args","DebounceCache","config","debounceSingleton","debounceCache","_createDebouncedFunction","debouncedFunc","DebouncePromise","func","getDebouncedFunction","AwesomeDebouncePromise","finalOptions","AwesomeDebouncePromiseWrapper","debouncedFn"],"sources":["./node_modules/debounce-promise/dist/index.js","./node_modules/awesome-imperative-promise/dist/index.es.js","./node_modules/awesome-only-resolves-last-promise/dist/index.es.js","./node_modules/awesome-debounce-promise/dist/index.es.js"],"sourcesContent":["'use strict';\n\n/* global setTimeout, clearTimeout */\n\nmodule.exports = function debounce(fn) {\n var wait = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n var lastCallAt = void 0;\n var deferred = void 0;\n var timer = void 0;\n var pendingArgs = [];\n return function debounced() {\n var currentWait = getWait(wait);\n var currentTime = new Date().getTime();\n\n var isCold = !lastCallAt || currentTime - lastCallAt > currentWait;\n\n lastCallAt = currentTime;\n\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n if (isCold && options.leading) {\n return options.accumulate ? Promise.resolve(fn.call(this, [args])).then(function (result) {\n return result[0];\n }) : Promise.resolve(fn.call.apply(fn, [this].concat(args)));\n }\n\n if (deferred) {\n clearTimeout(timer);\n } else {\n deferred = defer();\n }\n\n pendingArgs.push(args);\n timer = setTimeout(flush.bind(this), currentWait);\n\n if (options.accumulate) {\n var argsIndex = pendingArgs.length - 1;\n return deferred.promise.then(function (results) {\n return results[argsIndex];\n });\n }\n\n return deferred.promise;\n };\n\n function flush() {\n var thisDeferred = deferred;\n clearTimeout(timer);\n\n Promise.resolve(options.accumulate ? fn.call(this, pendingArgs) : fn.apply(this, pendingArgs[pendingArgs.length - 1])).then(thisDeferred.resolve, thisDeferred.reject);\n\n pendingArgs = [];\n deferred = null;\n }\n};\n\nfunction getWait(wait) {\n return typeof wait === 'function' ? wait() : wait;\n}\n\nfunction defer() {\n var deferred = {};\n deferred.promise = new Promise(function (resolve, reject) {\n deferred.resolve = resolve;\n deferred.reject = reject;\n });\n return deferred;\n}\n//# sourceMappingURL=index.js.map","function createImperativePromise(promiseArg) {\r\n var resolve = null;\r\n var reject = null;\r\n var wrappedPromise = new Promise(function (_resolve, _reject) {\r\n resolve = _resolve;\r\n reject = _reject;\r\n });\r\n promiseArg && promiseArg.then(function (val) {\r\n resolve && resolve(val);\r\n }, function (error) {\r\n reject && reject(error);\r\n });\r\n return {\r\n promise: wrappedPromise,\r\n resolve: function (value) {\r\n resolve && resolve(value);\r\n },\r\n reject: function (reason) {\r\n reject && reject(reason);\r\n },\r\n cancel: function () {\r\n resolve = null;\r\n reject = null;\r\n }\r\n };\r\n}\n\nexport { createImperativePromise };\n//# sourceMappingURL=index.es.js.map\n","import { createImperativePromise } from 'awesome-imperative-promise';\n\n// see https://stackoverflow.com/a/54825370/82609\r\nfunction onlyResolvesLast(asyncFunction) {\r\n var cancelPrevious = null;\r\n var wrappedFunction = function () {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n cancelPrevious && cancelPrevious();\r\n var initialPromise = asyncFunction.apply(void 0, args);\r\n var _a = createImperativePromise(initialPromise), promise = _a.promise, cancel = _a.cancel;\r\n cancelPrevious = cancel;\r\n return promise;\r\n };\r\n return wrappedFunction; // TODO fix TS\r\n}\n\nexport { onlyResolvesLast };\n//# sourceMappingURL=index.es.js.map\n","import DebouncePromise from 'debounce-promise';\nimport { onlyResolvesLast } from 'awesome-only-resolves-last-promise';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n\r\nvar __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n };\r\n return __assign.apply(this, arguments);\r\n};\n\nvar DefaultOptions = {\r\n // One distinct debounced function is created per key and added to an internal cache\r\n // By default, the key is null, which means that all the calls\r\n // will share the same debounced function\r\n key: function () {\r\n var _args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n _args[_i] = arguments[_i];\r\n }\r\n return null;\r\n },\r\n // By default, a debounced function will only resolve\r\n // the last promise it returned\r\n // Former calls will stay unresolved, so that you don't have\r\n // to handle concurrency issues in your code\r\n // Setting this to false means all returned promises will resolve to the last result\r\n onlyResolvesLast: true,\r\n};\r\n// We create a debouncing function cache, because when wrapping the original function,\r\n// we may actually want to route the function call to different debounced functions depending function paameters\r\nvar DebounceCache = /** @class */ (function () {\r\n function DebounceCache(config) {\r\n this.config = config;\r\n this.debounceSingleton = null;\r\n this.debounceCache = {}; // when key feature is used\r\n }\r\n DebounceCache.prototype._createDebouncedFunction = function () {\r\n var debouncedFunc = DebouncePromise(this.config.func, this.config.wait, this.config.options); // TODO TS\r\n if (this.config.options.onlyResolvesLast) {\r\n debouncedFunc = onlyResolvesLast(debouncedFunc);\r\n }\r\n return {\r\n func: debouncedFunc,\r\n };\r\n };\r\n DebounceCache.prototype.getDebouncedFunction = function (args) {\r\n var _a;\r\n var key = (_a = this.config.options).key.apply(_a, args);\r\n if (key === null || typeof key === 'undefined') {\r\n if (!this.debounceSingleton) {\r\n this.debounceSingleton = this._createDebouncedFunction();\r\n }\r\n return this.debounceSingleton;\r\n }\r\n else {\r\n if (!this.debounceCache[key]) {\r\n this.debounceCache[key] = this._createDebouncedFunction();\r\n }\r\n return this.debounceCache[key];\r\n }\r\n };\r\n return DebounceCache;\r\n}());\r\nfunction AwesomeDebouncePromise(func, wait, options) {\r\n var finalOptions = __assign({}, DefaultOptions, options);\r\n var debounceCache = new DebounceCache({\r\n func: func,\r\n wait: wait,\r\n options: finalOptions,\r\n });\r\n var AwesomeDebouncePromiseWrapper = (function () {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n var debouncedFn = debounceCache.getDebouncedFunction(args).func;\r\n return debouncedFn.apply(void 0, args);\r\n }); // TODO fix TS\r\n /*\r\n AwesomeDebouncePromiseWrapper.cancel = (key?: string) => {\r\n \n };\r\n */\r\n return AwesomeDebouncePromiseWrapper;\r\n}\n\nexport default AwesomeDebouncePromise;\n//# sourceMappingURL=index.es.js.map\n"],"mappings":"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"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{r as t,c as r,h as e,H as i}from"./p-3075aa67.js";import{c as s,i as o}from"./p-09cb3405.js";import{b as n}from"./p-5def744e.js";import{b as a}from"./p-9acf7b5d.js";import{b as l}from"./p-2e9fe8fd.js";import{i as c}from"./p-0b1af919.js";import"./p-8bc1584b.js";import"./p-2f777fdb.js";import"./p-cb91d37d.js";import"./p-eda23c05.js";import"./p-c93050d6.js";import"./p-4c3358cb.js";import"./p-858c6b82.js";import"./p-d529bb7d.js";import"./p-669626e5.js";function p(t,r,e,i){var s=-1,o=t==null?0:t.length;while(++s<o){var n=t[s];r(i,n,e(n),t)}return i}function f(t,r){return function(e,i){if(e==null){return e}if(!a(e)){return t(e,i)}var s=e.length,o=r?s:-1,n=Object(e);while(r?o--:++o<s){if(i(n[o],o,n)===false){break}}return e}}var h=f(n);function d(t,r,e,i){h(t,(function(t,s,o){r(i,t,e(t),o)}));return i}function m(t,r){return function(e,i){var s=c(e)?p:d,o=r?r():{};return s(e,t,l(i),o)}}var u=m((function(t,r,e){t[e?0:1].push(r)}),(function(){return[[],[]]}));const b=":host(limel-file-dropzone){display:grid;position:relative}.has-file-to-drop{animation:display-drop-zone 0.6s ease forwards;box-sizing:border-box;isolation:isolate;z-index:1;position:absolute;inset:0.25rem;overflow:hidden;display:flex;justify-content:center;align-items:center;gap:0.5rem;color:rgb(var(--contrast-700));border:0.125rem dashed rgb(var(--color-cyan-light));border-radius:0.75rem}.text-helpertext{display:flex;flex-direction:column;justify-content:center;align-items:flex-start}.icon{width:clamp(2rem, 5vh, 7rem)}.text{font-size:clamp(1rem, 2vh, 1.75rem)}.helper-text{font-size:clamp(0.75rem, 1.5vh, 1rem)}@keyframes display-drop-zone{0%{background-color:rgb(var(--contrast-1100), 0);backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);scale:0.9;opacity:0}50%{scale:1;opacity:1}100%{background-color:rgb(var(--contrast-1100), 0.8);backdrop-filter:blur(0.25rem);-webkit-backdrop-filter:blur(0.25rem)}}";const j=class{constructor(i){t(this,i);this.filesSelected=r(this,"filesSelected",7);this.filesRejected=r(this,"filesRejected",7);this.renderOnDragLayout=()=>{if(this.disabled||!this.hasFileToDrop){return}return e("div",{class:"has-file-to-drop"},e("limel-icon",{class:"icon",name:"upload_2"}),e("div",{class:"text-helpertext"},this.renderText(),this.renderHelperText()))};this.renderText=()=>{if(!this.text){return}return e("span",{class:"text"},this.text)};this.renderHelperText=()=>{if(!this.helperText){return}return e("span",{class:"helper-text"},this.helperText)};this.handleDrop=t=>{t.stopPropagation();t.preventDefault();this.hasFileToDrop=false;if(this.disabled){return}const r=Array.from(t.dataTransfer.files);const e=r.map(s);const[i,n]=u(e,(t=>o(t,this.accept)));if(i.length>0){this.filesSelected.emit(i)}if(n.length>0){this.filesRejected.emit(n)}};this.handleDragOver=t=>{this.hasFileToDrop=true;t.preventDefault()};this.handleDragLeave=t=>{this.hasFileToDrop=false;t.preventDefault()};this.accept="*";this.disabled=false;this.text=undefined;this.helperText="";this.hasFileToDrop=false}render(){return e(i,{onDrop:this.handleDrop,onDragOver:this.handleDragOver,onDragLeave:this.handleDragLeave},e("slot",null),this.renderOnDragLayout())}};j.style=b;export{j as limel_file_dropzone};
|
|
2
|
-
//# sourceMappingURL=p-ec42b48f.entry.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["arrayAggregator","array","setter","iteratee","accumulator","index","length","value","createBaseEach","eachFunc","fromRight","collection","isArrayLike","iterable","Object","baseEach","baseForOwn","baseAggregator","key","createAggregator","initializer","func","isArray","baseIteratee","partition","result","push","fileDropzoneCss","FileDropzone","this","renderOnDragLayout","disabled","hasFileToDrop","h","class","name","renderText","renderHelperText","text","helperText","handleDrop","event","stopPropagation","preventDefault","files","Array","from","dataTransfer","fileInfos","map","createFileInfo","acceptedFileInfos","rejectedFileInfos","file","isTypeAccepted","accept","filesSelected","emit","filesRejected","handleDragOver","handleDragLeave","render","Host","onDrop","onDragOver","onDragLeave"],"sources":["./node_modules/lodash-es/_arrayAggregator.js","./node_modules/lodash-es/_createBaseEach.js","./node_modules/lodash-es/_baseEach.js","./node_modules/lodash-es/_baseAggregator.js","./node_modules/lodash-es/_createAggregator.js","./node_modules/lodash-es/partition.js","./src/components/file-dropzone/file-dropzone.scss?tag=limel-file-dropzone&encapsulation=shadow","./src/components/file-dropzone/file-dropzone.tsx"],"sourcesContent":["/**\n * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction arrayAggregator(array, setter, iteratee, accumulator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n var value = array[index];\n setter(accumulator, value, iteratee(value), array);\n }\n return accumulator;\n}\n\nexport default arrayAggregator;\n","import isArrayLike from './isArrayLike.js';\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n}\n\nexport default createBaseEach;\n","import baseForOwn from './_baseForOwn.js';\nimport createBaseEach from './_createBaseEach.js';\n\n/**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\nexport default baseEach;\n","import baseEach from './_baseEach.js';\n\n/**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction baseAggregator(collection, setter, iteratee, accumulator) {\n baseEach(collection, function(value, key, collection) {\n setter(accumulator, value, iteratee(value), collection);\n });\n return accumulator;\n}\n\nexport default baseAggregator;\n","import arrayAggregator from './_arrayAggregator.js';\nimport baseAggregator from './_baseAggregator.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\n\n/**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\nfunction createAggregator(setter, initializer) {\n return function(collection, iteratee) {\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\n accumulator = initializer ? initializer() : {};\n\n return func(collection, setter, baseIteratee(iteratee, 2), accumulator);\n };\n}\n\nexport default createAggregator;\n","import createAggregator from './_createAggregator.js';\n\n/**\n * Creates an array of elements split into two groups, the first of which\n * contains elements `predicate` returns truthy for, the second of which\n * contains elements `predicate` returns falsey for. The predicate is\n * invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the array of grouped elements.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true },\n * { 'user': 'pebbles', 'age': 1, 'active': false }\n * ];\n *\n * _.partition(users, function(o) { return o.active; });\n * // => objects for [['fred'], ['barney', 'pebbles']]\n *\n * // The `_.matches` iteratee shorthand.\n * _.partition(users, { 'age': 1, 'active': false });\n * // => objects for [['pebbles'], ['barney', 'fred']]\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.partition(users, ['active', false]);\n * // => objects for [['barney', 'pebbles'], ['fred']]\n *\n * // The `_.property` iteratee shorthand.\n * _.partition(users, 'active');\n * // => objects for [['fred'], ['barney', 'pebbles']]\n */\nvar partition = createAggregator(function(result, value, key) {\n result[key ? 0 : 1].push(value);\n}, function() { return [[], []]; });\n\nexport default partition;\n",":host(limel-file-dropzone) {\n display: grid;\n position: relative;\n}\n\n.has-file-to-drop {\n animation: display-drop-zone 0.6s ease forwards;\n\n box-sizing: border-box;\n isolation: isolate;\n z-index: 1;\n position: absolute;\n inset: 0.25rem;\n\n overflow: hidden;\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 0.5rem;\n\n color: rgb(var(--contrast-700));\n\n border: 0.125rem dashed rgb(var(--color-cyan-light));\n border-radius: 0.75rem;\n}\n\n.text-helpertext {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n}\n\n.icon {\n width: clamp(2rem, 5vh, 7rem);\n}\n\n.text {\n font-size: clamp(1rem, 2vh, 1.75rem);\n}\n\n.helper-text {\n font-size: clamp(0.75rem, 1.5vh, 1rem);\n}\n\n@keyframes display-drop-zone {\n 0% {\n background-color: rgb(var(--contrast-1100), 0);\n backdrop-filter: blur(0);\n -webkit-backdrop-filter: blur(0);\n scale: 0.9;\n opacity: 0;\n }\n\n 50% {\n scale: 1;\n opacity: 1;\n }\n\n 100% {\n background-color: rgb(var(--contrast-1100), 0.8);\n backdrop-filter: blur(0.25rem);\n -webkit-backdrop-filter: blur(0.25rem);\n }\n}\n","import {\n Component,\n h,\n Event,\n EventEmitter,\n Host,\n Prop,\n State,\n} from '@stencil/core';\nimport { FileInfo } from '../../global/shared-types/file.types';\nimport { createFileInfo, isTypeAccepted } from '../../util/files';\nimport { partition } from 'lodash-es';\n\n/**\n * This component enables you to seamlessly convert any region of the user interface into\n * a file dropzone area, just by wrapping it inside the `limel-file-dropzone`.\n *\n * The file dropzone can then be used to allow end-users to upload files\n * by dragging and dropping them into the specified area, for example to trigger an upload process.\n *\n * After receiving the files, the component emits a `filesSelected` event. For unsupported\n * files (specified with the `accept` prop) a `filesRejected` event will be emitted.\n *\n * The event detail would be an array of `FileInfo` objects,\n * each representing a file dropped into the dropzone.\n *\n * @exampleComponent limel-example-file-dropzone\n * @exampleComponent limel-example-file-dropzone-type-filtering\n * @private\n */\n@Component({\n tag: 'limel-file-dropzone',\n shadow: true,\n styleUrl: 'file-dropzone.scss',\n})\nexport class FileDropzone {\n /**\n * Specifies the types of files that the dropzone will accept. By default, all file types are accepted.\n *\n * For media files, formats can be specified using: `audio/*`, `video/*`, `image/*`.\n * Unique file type specifiers can also be used, for example: `.jpg`, `.pdf`.\n * A comma-separated list of file extensions or MIME types is also acceptable, e.g., `image/png, image/jpeg` or\n * `.png, .jpg, .jpeg`.\n *\n * @see [HTML attribute: accept](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/accept) for more\n * details.\n */\n @Prop({ reflect: true })\n public accept: string = '*';\n\n /**\n * Set to `true` to disable the file dropzone.\n */\n @Prop()\n public disabled: boolean = false;\n\n /**\n * Is displayed when the user is dragging a file over the dropzone.\n * A suitable text could for instance be \"Drop your files here\".\n */\n @Prop()\n public text: string;\n\n /**\n * Is displayed to provide supplementary information to the end users,\n * for instance, which filetypes or file sizes are accepted.\n */\n @Prop()\n public helperText?: string = '';\n\n /**\n * Sets to true when there is a file to drop\n */\n @State()\n private hasFileToDrop: boolean = false;\n\n /**\n * Emitted when files are selected\n */\n @Event()\n filesSelected: EventEmitter<FileInfo[]>;\n\n /**\n * Emitted when files are selected but do not conform with the `accept` property specifications.\n * This can happen when the file types or formats of the selected files are not among the ones allowed by the dropzone,\n * as defined by the `accept` property.\n *\n * @see `accept` for details on how to specify acceptable file types.\n */\n @Event()\n filesRejected: EventEmitter<FileInfo[]>;\n\n public render() {\n return (\n <Host\n onDrop={this.handleDrop}\n onDragOver={this.handleDragOver}\n onDragLeave={this.handleDragLeave}\n >\n <slot />\n {this.renderOnDragLayout()}\n </Host>\n );\n }\n\n private renderOnDragLayout = () => {\n if (this.disabled || !this.hasFileToDrop) {\n return;\n }\n\n return (\n <div class=\"has-file-to-drop\">\n <limel-icon class=\"icon\" name=\"upload_2\" />\n <div class=\"text-helpertext\">\n {this.renderText()}\n {this.renderHelperText()}\n </div>\n </div>\n );\n };\n\n private renderText = () => {\n if (!this.text) {\n return;\n }\n\n return <span class=\"text\">{this.text}</span>;\n };\n\n private renderHelperText = () => {\n if (!this.helperText) {\n return;\n }\n\n return <span class=\"helper-text\">{this.helperText}</span>;\n };\n\n private handleDrop = (event: DragEvent) => {\n event.stopPropagation();\n event.preventDefault();\n this.hasFileToDrop = false;\n\n if (this.disabled) {\n return;\n }\n\n const files: File[] = Array.from(event.dataTransfer.files);\n const fileInfos: FileInfo[] = files.map(createFileInfo);\n\n const [acceptedFileInfos, rejectedFileInfos] = partition(\n fileInfos,\n (file) => isTypeAccepted(file, this.accept),\n );\n\n if (acceptedFileInfos.length > 0) {\n this.filesSelected.emit(acceptedFileInfos);\n }\n\n if (rejectedFileInfos.length > 0) {\n this.filesRejected.emit(rejectedFileInfos);\n }\n };\n\n private handleDragOver = (event: DragEvent) => {\n this.hasFileToDrop = true;\n event.preventDefault();\n };\n\n private handleDragLeave = (event: DragEvent) => {\n this.hasFileToDrop = false;\n event.preventDefault();\n };\n}\n"],"mappings":"4cAUA,SAASA,EAAgBC,EAAOC,EAAQC,EAAUC,GAChD,IAAIC,GAAS,EACTC,EAASL,GAAS,KAAO,EAAIA,EAAMK,OAEvC,QAASD,EAAQC,EAAQ,CACvB,IAAIC,EAAQN,EAAMI,GAClBH,EAAOE,EAAaG,EAAOJ,EAASI,GAAQN,EAChD,CACE,OAAOG,CACT,CCTA,SAASI,EAAeC,EAAUC,GAChC,OAAO,SAASC,EAAYR,GAC1B,GAAIQ,GAAc,KAAM,CACtB,OAAOA,CACb,CACI,IAAKC,EAAYD,GAAa,CAC5B,OAAOF,EAASE,EAAYR,EAClC,CACI,IAAIG,EAASK,EAAWL,OACpBD,EAAQK,EAAYJ,GAAU,EAC9BO,EAAWC,OAAOH,GAEtB,MAAQD,EAAYL,MAAYA,EAAQC,EAAS,CAC/C,GAAIH,EAASU,EAASR,GAAQA,EAAOQ,KAAc,MAAO,CACxD,KACR,CACA,CACI,OAAOF,CACX,CACA,CClBA,IAAII,EAAWP,EAAeQ,GCE9B,SAASC,EAAeN,EAAYT,EAAQC,EAAUC,GACpDW,EAASJ,GAAY,SAASJ,EAAOW,EAAKP,GACxCT,EAAOE,EAAaG,EAAOJ,EAASI,GAAQI,EAChD,IACE,OAAOP,CACT,CCLA,SAASe,EAAiBjB,EAAQkB,GAChC,OAAO,SAAST,EAAYR,GAC1B,IAAIkB,EAAOC,EAAQX,GAAcX,EAAkBiB,EAC/Cb,EAAcgB,EAAcA,IAAgB,GAEhD,OAAOC,EAAKV,EAAYT,EAAQqB,EAAapB,GAAcC,EAC/D,CACA,CCkBA,IAAIoB,EAAYL,GAAiB,SAASM,EAAQlB,EAAOW,GACvDO,EAAOP,EAAM,EAAI,GAAGQ,KAAKnB,EAC3B,IAAG,WAAa,MAAO,CAAC,GAAI,GAAI,ICxChC,MAAMoB,EAAkB,u5B,MCmCXC,EAAY,M,mHAsEbC,KAAAC,mBAAqB,KACzB,GAAID,KAAKE,WAAaF,KAAKG,cAAe,CACtC,M,CAGJ,OACIC,EAAA,OAAKC,MAAM,oBACPD,EAAA,cAAYC,MAAM,OAAOC,KAAK,aAC9BF,EAAA,OAAKC,MAAM,mBACNL,KAAKO,aACLP,KAAKQ,oBAER,EAINR,KAAAO,WAAa,KACjB,IAAKP,KAAKS,KAAM,CACZ,M,CAGJ,OAAOL,EAAA,QAAMC,MAAM,QAAQL,KAAKS,KAAY,EAGxCT,KAAAQ,iBAAmB,KACvB,IAAKR,KAAKU,WAAY,CAClB,M,CAGJ,OAAON,EAAA,QAAMC,MAAM,eAAeL,KAAKU,WAAkB,EAGrDV,KAAAW,WAAcC,IAClBA,EAAMC,kBACND,EAAME,iBACNd,KAAKG,cAAgB,MAErB,GAAIH,KAAKE,SAAU,CACf,M,CAGJ,MAAMa,EAAgBC,MAAMC,KAAKL,EAAMM,aAAaH,OACpD,MAAMI,EAAwBJ,EAAMK,IAAIC,GAExC,MAAOC,EAAmBC,GAAqB5B,EAC3CwB,GACCK,GAASC,EAAeD,EAAMxB,KAAK0B,UAGxC,GAAIJ,EAAkB7C,OAAS,EAAG,CAC9BuB,KAAK2B,cAAcC,KAAKN,E,CAG5B,GAAIC,EAAkB9C,OAAS,EAAG,CAC9BuB,KAAK6B,cAAcD,KAAKL,E,GAIxBvB,KAAA8B,eAAkBlB,IACtBZ,KAAKG,cAAgB,KACrBS,EAAME,gBAAgB,EAGlBd,KAAA+B,gBAAmBnB,IACvBZ,KAAKG,cAAgB,MACrBS,EAAME,gBAAgB,E,YA1HF,I,cAMG,M,oCAcE,G,mBAMI,K,CAkB1BkB,SACH,OACI5B,EAAC6B,EAAI,CACDC,OAAQlC,KAAKW,WACbwB,WAAYnC,KAAK8B,eACjBM,YAAapC,KAAK+B,iBAElB3B,EAAA,aACCJ,KAAKC,qB"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{r as t,c as i,h as s,H as e,g as h}from"./p-3075aa67.js";import{c as r}from"./p-3ccdc4a3.js";import{c as n}from"./p-09cb3405.js";import"./p-8bc1584b.js";import"./p-2f777fdb.js";const o=class{constructor(s){t(this,s);this.filesSelected=i(this,"filesSelected",7);this.fileInputId=r();this.handleClick=t=>{if(this.disabled){t.stopPropagation();t.preventDefault();return}this.triggerFileDialog();t.stopPropagation()};this.handleKeyUp=t=>{t.stopPropagation();t.preventDefault();if(t.code==="Enter"){this.triggerFileDialog()}};this.handleFileChange=t=>{const i=Array.from(this.fileInput.files);if(i.length>0){t.stopPropagation();this.filesSelected.emit(i.map(n));this.fileInput.value=""}};this.accept="*";this.disabled=false;this.multiple=false}componentDidLoad(){this.fileInput=this.element.shadowRoot.getElementById(this.fileInputId)}render(){return s(e,{onClick:this.handleClick,onKeyUp:this.handleKeyUp,onKeyDown:this.handleKeyDown},s("input",{hidden:true,id:this.fileInputId,onChange:this.handleFileChange,type:"file",accept:this.accept,disabled:this.disabled,multiple:this.multiple}),s("slot",null))}handleKeyDown(t){if(t.code==="Tab"||t.code==="Backspace"||t.code==="Enter"){return}t.preventDefault();t.stopPropagation()}triggerFileDialog(){this.fileInput.click()}get element(){return h(this)}};export{o as limel_file_input};
|
|
2
|
-
//# sourceMappingURL=p-f358c948.entry.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["FileInput","this","fileInputId","createRandomString","handleClick","event","disabled","stopPropagation","preventDefault","triggerFileDialog","handleKeyUp","code","handleFileChange","files","Array","from","fileInput","length","filesSelected","emit","map","createFileInfo","value","componentDidLoad","element","shadowRoot","getElementById","render","h","Host","onClick","onKeyUp","onKeyDown","handleKeyDown","hidden","id","onChange","type","accept","multiple","click"],"sources":["./src/components/file-input/file-input.tsx"],"sourcesContent":["import {\n h,\n Event,\n EventEmitter,\n Host,\n Component,\n Element,\n Prop,\n} from '@stencil/core';\nimport { createRandomString } from '../../util/random-string';\nimport { FileInfo } from '../../global/shared-types/file.types';\nimport { createFileInfo } from '../../util/files';\n\n/**\n * This component enables you to seamlessly transform any other clickable component that\n * generates a `click` event into a file input selector.\n *\n * To use it, just wrap any clickable component inside the `limel-file-input` component.\n * Upon reception of the `click` event this component will open the native file selection\n * dialog.\n *\n * After receiving the files, the component emits a `filesSelected` event.\n *\n * The event detail would be an array of `FileInfo` objects,\n * each representing a file dropped into the dropzone.\n *\n * @exampleComponent limel-example-file-input\n * @exampleComponent limel-example-file-input-type-filtering\n * @private\n */\n@Component({\n tag: 'limel-file-input',\n shadow: true,\n})\nexport class FileInput {\n /**\n * Specifies the types of files that the dropzone will accept. By default, all file types are accepted.\n *\n * For media files, formats can be specified using: `audio/*`, `video/*`, `image/*`.\n * Unique file type specifiers can also be used, for example: `.jpg`, `.pdf`.\n * A comma-separated list of file extensions or MIME types is also acceptable, e.g., `image/png, image/jpeg` or\n * `.png, .jpg, .jpeg`.\n *\n * @see [HTML attribute: accept](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/accept) for more\n * details.\n */\n @Prop({ reflect: true })\n public accept: string = '*';\n\n /**\n * Set to `true` to disable file input selection.\n */\n @Prop({ reflect: true })\n public disabled: boolean = false;\n\n /**\n * Set to `true` to enable selection of multiple files\n */\n @Prop({ reflect: true })\n public multiple: boolean = false;\n\n /**\n * Emitted when files are selected\n */\n @Event()\n filesSelected: EventEmitter<FileInfo[]>;\n\n @Element()\n private element: HTMLLimelFileElement;\n\n private fileInput: HTMLInputElement;\n private fileInputId = createRandomString();\n\n public componentDidLoad() {\n this.fileInput = this.element.shadowRoot.getElementById(\n this.fileInputId,\n ) as HTMLInputElement;\n }\n\n public render() {\n return (\n <Host\n onClick={this.handleClick}\n onKeyUp={this.handleKeyUp}\n onKeyDown={this.handleKeyDown}\n >\n <input\n hidden={true}\n id={this.fileInputId}\n onChange={this.handleFileChange}\n type=\"file\"\n accept={this.accept}\n disabled={this.disabled}\n multiple={this.multiple}\n />\n <slot />\n </Host>\n );\n }\n\n private handleClick = (event: Event) => {\n if (this.disabled) {\n event.stopPropagation();\n event.preventDefault();\n\n return;\n }\n\n this.triggerFileDialog();\n\n event.stopPropagation();\n };\n\n private handleKeyUp = (event: KeyboardEvent) => {\n event.stopPropagation();\n event.preventDefault();\n\n if (event.code === 'Enter') {\n this.triggerFileDialog();\n }\n };\n\n private handleKeyDown(event: KeyboardEvent) {\n if (\n event.code === 'Tab' ||\n event.code === 'Backspace' ||\n event.code === 'Enter'\n ) {\n return;\n }\n\n event.preventDefault();\n event.stopPropagation();\n }\n\n private triggerFileDialog() {\n this.fileInput.click();\n }\n\n private handleFileChange = (event: Event) => {\n const files = Array.from(this.fileInput.files);\n if (files.length > 0) {\n event.stopPropagation();\n this.filesSelected.emit(files.map(createFileInfo));\n this.fileInput.value = '';\n }\n };\n}\n"],"mappings":"8LAkCaA,EAAS,M,sEAqCVC,KAAAC,YAAcC,IA6BdF,KAAAG,YAAeC,IACnB,GAAIJ,KAAKK,SAAU,CACfD,EAAME,kBACNF,EAAMG,iBAEN,M,CAGJP,KAAKQ,oBAELJ,EAAME,iBAAiB,EAGnBN,KAAAS,YAAeL,IACnBA,EAAME,kBACNF,EAAMG,iBAEN,GAAIH,EAAMM,OAAS,QAAS,CACxBV,KAAKQ,mB,GAqBLR,KAAAW,iBAAoBP,IACxB,MAAMQ,EAAQC,MAAMC,KAAKd,KAAKe,UAAUH,OACxC,GAAIA,EAAMI,OAAS,EAAG,CAClBZ,EAAME,kBACNN,KAAKiB,cAAcC,KAAKN,EAAMO,IAAIC,IAClCpB,KAAKe,UAAUM,MAAQ,E,eAjGP,I,cAMG,M,cAMA,K,CAcpBC,mBACHtB,KAAKe,UAAYf,KAAKuB,QAAQC,WAAWC,eACrCzB,KAAKC,Y,CAINyB,SACH,OACIC,EAACC,EAAI,CACDC,QAAS7B,KAAKG,YACd2B,QAAS9B,KAAKS,YACdsB,UAAW/B,KAAKgC,eAEhBL,EAAA,SACIM,OAAQ,KACRC,GAAIlC,KAAKC,YACTkC,SAAUnC,KAAKW,iBACfyB,KAAK,OACLC,OAAQrC,KAAKqC,OACbhC,SAAUL,KAAKK,SACfiC,SAAUtC,KAAKsC,WAEnBX,EAAA,a,CA2BJK,cAAc5B,GAClB,GACIA,EAAMM,OAAS,OACfN,EAAMM,OAAS,aACfN,EAAMM,OAAS,QACjB,CACE,M,CAGJN,EAAMG,iBACNH,EAAME,iB,CAGFE,oBACJR,KAAKe,UAAUwB,O"}
|
|
File without changes
|
|
File without changes
|