revotech-ui-kit 0.0.2 → 0.0.4-beta
Sign up to get free protection for your applications and to get access to all the features.
- package/.github/workflows/deploy-storybook.yml +107 -0
- package/.storybook/main.ts +3 -3
- package/assume_role.sh +18 -0
- package/dist/183c6c38.js +1 -0
- package/dist/f28fd4b1.js +1 -0
- package/dist/index.ts +1 -0
- package/dist/public/globals.css +2215 -0
- package/dist/public/tailwind-lib.css +115 -0
- package/dist/src/assets/icons/arrows.icon.js +20 -0
- package/dist/src/assets/icons/arrows.icon.js.map +1 -0
- package/dist/src/assets/icons/index.js +4 -0
- package/dist/src/assets/icons/index.js.map +1 -0
- package/dist/src/assets/icons/search.icon.js +19 -0
- package/dist/src/assets/icons/search.icon.js.map +1 -0
- package/dist/src/assets/icons/tick.icon.js +20 -0
- package/dist/src/assets/icons/tick.icon.js.map +1 -0
- package/dist/src/components/atoms/alert/alert-description.js +18 -0
- package/dist/src/components/atoms/alert/alert-description.js.map +1 -0
- package/dist/src/components/atoms/alert/alert-title.js +20 -0
- package/dist/src/components/atoms/alert/alert-title.js.map +1 -0
- package/dist/src/components/atoms/alert/alert.atom.js +55 -0
- package/dist/src/components/atoms/alert/alert.atom.js.map +1 -0
- package/dist/src/components/atoms/alert/alert.stories.js +62 -0
- package/dist/src/components/atoms/alert/alert.stories.js.map +1 -0
- package/dist/src/components/atoms/alert/alert.styles.js +21 -0
- package/dist/src/components/atoms/alert/alert.styles.js.map +1 -0
- package/dist/src/components/atoms/alert/alert.types.js +2 -0
- package/dist/src/components/atoms/alert/alert.types.js.map +1 -0
- package/dist/src/components/atoms/badge/badge.atom.js +43 -0
- package/dist/src/components/atoms/badge/badge.atom.js.map +1 -0
- package/dist/src/components/atoms/badge/badge.stories.js +110 -0
- package/dist/src/components/atoms/badge/badge.stories.js.map +1 -0
- package/dist/src/components/atoms/badge/badge.style.js +17 -0
- package/dist/src/components/atoms/badge/badge.style.js.map +1 -0
- package/dist/src/components/atoms/badge/badge.type.js +2 -0
- package/dist/src/components/atoms/badge/badge.type.js.map +1 -0
- package/dist/src/components/atoms/button/button.atom.js +67 -0
- package/dist/src/components/atoms/button/button.atom.js.map +1 -0
- package/dist/src/components/atoms/button/button.stories.js +204 -0
- package/dist/src/components/atoms/button/button.stories.js.map +1 -0
- package/dist/src/components/atoms/button/button.style.js +24 -0
- package/dist/src/components/atoms/button/button.style.js.map +1 -0
- package/dist/src/components/atoms/button/button.type.js +2 -0
- package/dist/src/components/atoms/button/button.type.js.map +1 -0
- package/dist/src/components/atoms/card/card-content.js +17 -0
- package/dist/src/components/atoms/card/card-content.js.map +1 -0
- package/dist/src/components/atoms/card/card-description.js +17 -0
- package/dist/src/components/atoms/card/card-description.js.map +1 -0
- package/dist/src/components/atoms/card/card-footer.js +17 -0
- package/dist/src/components/atoms/card/card-footer.js.map +1 -0
- package/dist/src/components/atoms/card/card-header.js +17 -0
- package/dist/src/components/atoms/card/card-header.js.map +1 -0
- package/dist/src/components/atoms/card/card-title.js +17 -0
- package/dist/src/components/atoms/card/card-title.js.map +1 -0
- package/dist/src/components/atoms/card/card.atom.js +25 -0
- package/dist/src/components/atoms/card/card.atom.js.map +1 -0
- package/dist/src/components/atoms/card/card.stories.js +136 -0
- package/dist/src/components/atoms/card/card.stories.js.map +1 -0
- package/dist/src/components/atoms/checkbox/checkbox.atom.js +87 -0
- package/dist/src/components/atoms/checkbox/checkbox.atom.js.map +1 -0
- package/dist/src/components/atoms/checkbox/checkbox.stories.js +244 -0
- package/dist/src/components/atoms/checkbox/checkbox.stories.js.map +1 -0
- package/dist/src/components/atoms/checkbox/checkbox.style.js +3 -0
- package/dist/src/components/atoms/checkbox/checkbox.style.js.map +1 -0
- package/dist/src/components/atoms/checkbox/checkbox.type.js +2 -0
- package/dist/src/components/atoms/checkbox/checkbox.type.js.map +1 -0
- package/dist/src/components/atoms/combo-box/combo-box-input.js +47 -0
- package/dist/src/components/atoms/combo-box/combo-box-input.js.map +1 -0
- package/dist/src/components/atoms/combo-box/combo-box-item.js +85 -0
- package/dist/src/components/atoms/combo-box/combo-box-item.js.map +1 -0
- package/dist/src/components/atoms/combo-box/combo-box-list.js +67 -0
- package/dist/src/components/atoms/combo-box/combo-box-list.js.map +1 -0
- package/dist/src/components/atoms/combo-box/combo-box.atom.js +199 -0
- package/dist/src/components/atoms/combo-box/combo-box.atom.js.map +1 -0
- package/dist/src/components/atoms/combo-box/combo-box.stories.js +86 -0
- package/dist/src/components/atoms/combo-box/combo-box.stories.js.map +1 -0
- package/dist/src/components/atoms/command-empty/command-empty.atom.js +54 -0
- package/dist/src/components/atoms/command-empty/command-empty.atom.js.map +1 -0
- package/dist/src/components/atoms/command-group/command-group.atom.js +71 -0
- package/dist/src/components/atoms/command-group/command-group.atom.js.map +1 -0
- package/dist/src/components/atoms/command-item/command-item.atom.js +80 -0
- package/dist/src/components/atoms/command-item/command-item.atom.js.map +1 -0
- package/dist/src/components/atoms/command-list/command-list.atom.js +36 -0
- package/dist/src/components/atoms/command-list/command-list.atom.js.map +1 -0
- package/dist/src/components/atoms/command-separator/command-separator.atom.js +52 -0
- package/dist/src/components/atoms/command-separator/command-separator.atom.js.map +1 -0
- package/dist/src/components/atoms/dialog/dialog-close.js +47 -0
- package/dist/src/components/atoms/dialog/dialog-close.js.map +1 -0
- package/dist/src/components/atoms/dialog/dialog-content.js +72 -0
- package/dist/src/components/atoms/dialog/dialog-content.js.map +1 -0
- package/dist/src/components/atoms/dialog/dialog-footer.js +22 -0
- package/dist/src/components/atoms/dialog/dialog-footer.js.map +1 -0
- package/dist/src/components/atoms/dialog/dialog-header.js +40 -0
- package/dist/src/components/atoms/dialog/dialog-header.js.map +1 -0
- package/dist/src/components/atoms/dialog/dialog-overly.js +20 -0
- package/dist/src/components/atoms/dialog/dialog-overly.js.map +1 -0
- package/dist/src/components/atoms/dialog/dialog-trigger.js +54 -0
- package/dist/src/components/atoms/dialog/dialog-trigger.js.map +1 -0
- package/dist/src/components/atoms/dialog/dialog.atom.js +79 -0
- package/dist/src/components/atoms/dialog/dialog.atom.js.map +1 -0
- package/dist/src/components/atoms/dialog/dialog.stories.js +88 -0
- package/dist/src/components/atoms/dialog/dialog.stories.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-checkbox-Item.js +117 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-checkbox-Item.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-content.js +81 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-content.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-group.js +71 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-group.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-item.js +80 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-item.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-radio-item.js +118 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-radio-item.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-seperator.js +52 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-seperator.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-shortcut.js +20 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu-shortcut.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu.atom.js +79 -0
- package/dist/src/components/atoms/dropdownMenu/dropdown-menu.atom.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdownMenu.stories.js +211 -0
- package/dist/src/components/atoms/dropdownMenu/dropdownMenu.stories.js.map +1 -0
- package/dist/src/components/atoms/dropdownMenu/dropdownMenu.style.js +4 -0
- package/dist/src/components/atoms/dropdownMenu/dropdownMenu.style.js.map +1 -0
- package/dist/src/components/atoms/index.js +14 -0
- package/dist/src/components/atoms/index.js.map +1 -0
- package/dist/src/components/atoms/input/input.atom.js +93 -0
- package/dist/src/components/atoms/input/input.atom.js.map +1 -0
- package/dist/src/components/atoms/input/input.stories.js +382 -0
- package/dist/src/components/atoms/input/input.stories.js.map +1 -0
- package/dist/src/components/atoms/input/input.styles.js +2 -0
- package/dist/src/components/atoms/input/input.styles.js.map +1 -0
- package/dist/src/components/atoms/input/input.type.js +2 -0
- package/dist/src/components/atoms/input/input.type.js.map +1 -0
- package/dist/src/components/atoms/label/label.atom.js +68 -0
- package/dist/src/components/atoms/label/label.atom.js.map +1 -0
- package/dist/src/components/atoms/label/label.stories.js +85 -0
- package/dist/src/components/atoms/label/label.stories.js.map +1 -0
- package/dist/src/components/atoms/label/label.style.js +3 -0
- package/dist/src/components/atoms/label/label.style.js.map +1 -0
- package/dist/src/components/atoms/popover/popover-content.js +64 -0
- package/dist/src/components/atoms/popover/popover-content.js.map +1 -0
- package/dist/src/components/atoms/popover/popover-trigger.js +51 -0
- package/dist/src/components/atoms/popover/popover-trigger.js.map +1 -0
- package/dist/src/components/atoms/popover/popover.atom.js +40 -0
- package/dist/src/components/atoms/popover/popover.atom.js.map +1 -0
- package/dist/src/components/atoms/popover/popover.stories.js +69 -0
- package/dist/src/components/atoms/popover/popover.stories.js.map +1 -0
- package/dist/src/components/atoms/popover/popover.style.js +21 -0
- package/dist/src/components/atoms/popover/popover.style.js.map +1 -0
- package/dist/src/components/atoms/popover/popover.types.js +4 -0
- package/dist/src/components/atoms/popover/popover.types.js.map +1 -0
- package/dist/src/components/atoms/toggle/defs.js +30 -0
- package/dist/src/components/atoms/toggle/defs.js.map +1 -0
- package/dist/src/components/atoms/toggle/toggle.atom.js +72 -0
- package/dist/src/components/atoms/toggle/toggle.atom.js.map +1 -0
- package/dist/src/components/atoms/toggle/toggle.stories.js +189 -0
- package/dist/src/components/atoms/toggle/toggle.stories.js.map +1 -0
- package/dist/src/components/atoms/toggle/toggle.style.js +19 -0
- package/dist/src/components/atoms/toggle/toggle.style.js.map +1 -0
- package/dist/src/components/command/command.js +410 -0
- package/dist/src/components/command/command.js.map +1 -0
- package/dist/src/components/command/command.stories.js +153 -0
- package/dist/src/components/command/command.stories.js.map +1 -0
- package/dist/src/components/index.js +3 -0
- package/dist/src/components/index.js.map +1 -0
- package/dist/src/components/molecules/command/command.molecules.js +27 -0
- package/dist/src/components/molecules/command/command.molecules.js.map +1 -0
- package/dist/src/components/molecules/command-input/command-input.atom.js +127 -0
- package/dist/src/components/molecules/command-input/command-input.atom.js.map +1 -0
- package/dist/src/components/molecules/dropdownMenu/dropdownMenu.molecules.js +2 -0
- package/dist/src/components/molecules/dropdownMenu/dropdownMenu.molecules.js.map +1 -0
- package/dist/src/components/molecules/index.js +2 -0
- package/dist/src/components/molecules/index.js.map +1 -0
- package/dist/src/helpers/base-element.js +64 -0
- package/dist/src/helpers/base-element.js.map +1 -0
- package/dist/src/helpers/index.js +4 -0
- package/dist/src/helpers/index.js.map +1 -0
- package/dist/src/helpers/mouse-conroller.helper.js +33 -0
- package/dist/src/helpers/mouse-conroller.helper.js.map +1 -0
- package/dist/src/helpers/style.helpers.js +6 -0
- package/dist/src/helpers/style.helpers.js.map +1 -0
- package/dist/src/index.js +2 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/interfaces/actionable.interface.js +2 -0
- package/dist/src/interfaces/actionable.interface.js.map +1 -0
- package/dist/src/interfaces/atomic.interface.js +2 -0
- package/dist/src/interfaces/atomic.interface.js.map +1 -0
- package/dist/src/interfaces/changeable.interface.js +2 -0
- package/dist/src/interfaces/changeable.interface.js.map +1 -0
- package/dist/src/interfaces/child-support-atomic.interface.js +2 -0
- package/dist/src/interfaces/child-support-atomic.interface.js.map +1 -0
- package/dist/src/interfaces/index.js +7 -0
- package/dist/src/interfaces/index.js.map +1 -0
- package/dist/src/interfaces/intractable.interface.js +2 -0
- package/dist/src/interfaces/intractable.interface.js.map +1 -0
- package/dist/src/interfaces/variant.interface.js +2 -0
- package/dist/src/interfaces/variant.interface.js.map +1 -0
- package/dist/src/lib/index.js +2 -0
- package/dist/src/lib/index.js.map +1 -0
- package/dist/src/lib/next/next.lib.js +2 -0
- package/dist/src/lib/next/next.lib.js.map +1 -0
- package/dist/src/lib/react/react.lib.js +16 -0
- package/dist/src/lib/react/react.lib.js.map +1 -0
- package/dist/src/lib/tw-styles.js +1956 -0
- package/dist/src/lib/tw-styles.js.map +1 -0
- package/dist/src/styles/index.js +2 -0
- package/dist/src/styles/index.js.map +1 -0
- package/dist/src/styles/tw.styles.js +2218 -0
- package/dist/src/styles/tw.styles.js.map +1 -0
- package/dist/src/wc-ui-app.js +88 -0
- package/dist/src/wc-ui-app.js.map +1 -0
- package/dist/sw.js +2 -0
- package/dist/sw.js.map +1 -0
- package/dist/test/wc-ui-app.test.js +18 -0
- package/dist/test/wc-ui-app.test.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/workbox-a523fd56.js +2 -0
- package/dist/workbox-a523fd56.js.map +1 -0
- package/index.html +18 -66
- package/package.json +42 -18
- package/rollup.config.js +25 -13
- package/src/assets/icons/arrows.icon.ts +20 -0
- package/src/assets/icons/index.ts +3 -0
- package/src/assets/icons/search.icon.ts +19 -0
- package/src/assets/icons/tick.icon.ts +20 -0
- package/src/chai-custom.d.ts +0 -0
- package/src/components/atoms/alert/alert-description.ts +15 -0
- package/src/components/atoms/alert/alert-title.ts +17 -0
- package/src/components/atoms/alert/alert.atom.ts +51 -0
- package/src/components/atoms/alert/alert.stories.ts +71 -0
- package/src/components/atoms/alert/alert.styles.ts +21 -0
- package/src/components/atoms/alert/alert.types.ts +1 -0
- package/src/components/atoms/badge/badge.atom.ts +40 -0
- package/src/components/atoms/badge/badge.stories.ts +118 -0
- package/src/components/atoms/badge/badge.style.ts +24 -0
- package/src/components/atoms/badge/badge.type.ts +7 -0
- package/src/components/atoms/button/button.atom.ts +22 -8
- package/src/components/atoms/button/button.stories.ts +177 -139
- package/src/components/atoms/card/card-content.ts +15 -0
- package/src/components/atoms/card/card-description.ts +15 -0
- package/src/components/atoms/card/card-footer.ts +15 -0
- package/src/components/atoms/card/card-header.ts +15 -0
- package/src/components/atoms/card/card-title.ts +15 -0
- package/src/components/atoms/card/card.atom.ts +31 -0
- package/src/components/atoms/card/card.stories.ts +149 -0
- package/src/components/atoms/checkbox/checkbox.atom.ts +30 -16
- package/src/components/atoms/checkbox/checkbox.stories.ts +292 -25
- package/src/components/atoms/checkbox/checkbox.style.ts +5 -0
- package/src/components/atoms/checkbox/checkbox.type.ts +24 -0
- package/src/components/atoms/combo-box/combo-box-input.ts +33 -0
- package/src/components/atoms/combo-box/combo-box-item.ts +59 -0
- package/src/components/atoms/combo-box/combo-box-list.ts +57 -0
- package/src/components/atoms/combo-box/combo-box.atom.ts +187 -0
- package/src/components/atoms/combo-box/combo-box.stories.ts +95 -0
- package/src/components/atoms/command-empty/command-empty.atom.ts +2 -2
- package/src/components/atoms/command-group/command-group.atom.ts +1 -1
- package/src/components/atoms/command-item/command-item.atom.ts +2 -2
- package/src/components/atoms/command-list/command-list.atom.ts +2 -2
- package/src/components/atoms/command-separator/command-separator.atom.ts +2 -2
- package/src/components/atoms/dialog/dialog-close.ts +50 -0
- package/src/components/atoms/dialog/dialog-content.ts +71 -0
- package/src/components/atoms/dialog/dialog-footer.ts +22 -0
- package/src/components/atoms/dialog/dialog-header.ts +36 -0
- package/src/components/atoms/dialog/dialog-overly.ts +20 -0
- package/src/components/atoms/dialog/dialog-trigger.ts +54 -0
- package/src/components/atoms/dialog/dialog.atom.ts +3 -226
- package/src/components/atoms/dialog/dialog.stories.ts +11 -4
- package/src/components/atoms/dropdownMenu/dropdown-menu-checkbox-Item.ts +106 -0
- package/src/components/atoms/dropdownMenu/dropdown-menu-content.ts +79 -0
- package/src/components/atoms/dropdownMenu/dropdown-menu-group.ts +60 -0
- package/src/components/atoms/dropdownMenu/dropdown-menu-item.ts +74 -0
- package/src/components/atoms/dropdownMenu/dropdown-menu-radio-item.ts +107 -0
- package/src/components/atoms/dropdownMenu/dropdown-menu-seperator.ts +44 -0
- package/src/components/atoms/dropdownMenu/dropdown-menu-shortcut.ts +17 -0
- package/src/components/atoms/dropdownMenu/dropdown-menu.atom.ts +84 -0
- package/src/components/atoms/dropdownMenu/dropdownMenu.stories.ts +220 -0
- package/src/components/atoms/dropdownMenu/dropdownMenu.style.ts +7 -0
- package/src/components/atoms/index.ts +3 -0
- package/src/components/atoms/input/input.atom.ts +64 -10
- package/src/components/atoms/input/input.stories.ts +426 -64
- package/src/components/atoms/input/input.styles.ts +2 -0
- package/src/components/atoms/input/input.type.ts +42 -8
- package/src/components/atoms/label/label.atom.ts +31 -7
- package/src/components/atoms/label/label.stories.ts +87 -3
- package/src/components/atoms/popover/popover-content.ts +58 -0
- package/src/components/atoms/popover/popover-trigger.ts +50 -0
- package/src/components/atoms/popover/popover.atom.ts +34 -0
- package/src/components/atoms/popover/popover.stories.ts +79 -0
- package/src/components/atoms/popover/popover.style.ts +25 -0
- package/src/components/atoms/popover/popover.types.ts +3 -0
- package/src/components/atoms/toggle/defs.ts +29 -0
- package/src/components/atoms/toggle/toggle.atom.ts +58 -0
- package/src/components/atoms/toggle/toggle.stories.ts +204 -0
- package/src/components/atoms/toggle/toggle.style.ts +22 -0
- package/src/components/molecules/command/command.molecules.ts +2 -2
- package/src/components/molecules/command-input/command-input.atom.ts +3 -3
- package/src/components/molecules/dropdownMenu/dropdownMenu.molecules.ts +0 -0
- package/src/globals.css +475 -66
- package/src/helpers/base-element.ts +79 -0
- package/src/helpers/index.ts +1 -0
- package/src/index.d.ts +1 -0
- package/src/index.ts +1 -0
- package/src/lib/react/react.lib.ts +18 -0
- package/src/lib/tw-styles.ts +1957 -0
- package/src/styles/tw.styles.ts +2051 -1699
- package/src/tailwind-lib.css +26 -6
- package/tailwind.config.js +174 -38
- package/tsconfig.json +6 -1
- package/src/components/popover.ts +0 -247
@@ -0,0 +1,187 @@
|
|
1
|
+
import { css, html, LitElement, PropertyValues } from 'lit';
|
2
|
+
import { customElement, property, state } from 'lit/decorators.js';
|
3
|
+
import { TWStyles } from '../../../styles';
|
4
|
+
import { arrowsIcon, searchIcon } from '../../../assets/icons';
|
5
|
+
import './combo-box-input';
|
6
|
+
import './combo-box-item';
|
7
|
+
|
8
|
+
@customElement('rtg-combo-box')
|
9
|
+
class ComboBox extends LitElement {
|
10
|
+
static styles = [css``, TWStyles];
|
11
|
+
|
12
|
+
@state() isOpen = false;
|
13
|
+
@state() selectedValue = '';
|
14
|
+
@state() searchTerm = '';
|
15
|
+
@state() focusedIndex = -1;
|
16
|
+
@state() filteredItems: string[] = [];
|
17
|
+
@property({ type: String }) label: string = 'Select an item';
|
18
|
+
@property({ type: Array }) items = [];
|
19
|
+
protected firstUpdated(_changedProperties: PropertyValues): void {
|
20
|
+
if (this.items && this.items.length > 0)
|
21
|
+
this.filteredItems = this.items.filter((item: string) =>
|
22
|
+
item.toLowerCase().includes(this.searchTerm)
|
23
|
+
);
|
24
|
+
}
|
25
|
+
toggleDropdown() {
|
26
|
+
this.isOpen = !this.isOpen;
|
27
|
+
this.focusedIndex = -1;
|
28
|
+
}
|
29
|
+
|
30
|
+
selectItem(event: Event) {
|
31
|
+
const target = event.target as EventTarget;
|
32
|
+
if (target instanceof HTMLElement) {
|
33
|
+
const closestItem = target.closest(
|
34
|
+
'combo-box-item'
|
35
|
+
) as HTMLElement | null;
|
36
|
+
if (closestItem) {
|
37
|
+
this.selectedValue =
|
38
|
+
closestItem.getAttribute('data-hs-combo-box-value') || '';
|
39
|
+
this.isOpen = false;
|
40
|
+
} else {
|
41
|
+
console.log('No valid combo-box-item found');
|
42
|
+
}
|
43
|
+
} else {
|
44
|
+
console.log('Event target is not an HTMLElement');
|
45
|
+
}
|
46
|
+
}
|
47
|
+
|
48
|
+
handleInputClick() {
|
49
|
+
this.toggleDropdown();
|
50
|
+
}
|
51
|
+
|
52
|
+
handleSearch(event: Event) {
|
53
|
+
const input = event.target as HTMLInputElement;
|
54
|
+
this.searchTerm = input.value;
|
55
|
+
this.filteredItems = this.items.filter((item: string) =>
|
56
|
+
item.toLowerCase().includes(this.searchTerm)
|
57
|
+
);
|
58
|
+
}
|
59
|
+
|
60
|
+
handleKeyDown(event: KeyboardEvent) {
|
61
|
+
const filteredLength = this.filteredItems.length;
|
62
|
+
|
63
|
+
switch (event.key) {
|
64
|
+
case 'ArrowDown':
|
65
|
+
event.preventDefault();
|
66
|
+
this.focusedIndex = (this.focusedIndex + 1) % filteredLength;
|
67
|
+
break;
|
68
|
+
case 'ArrowUp':
|
69
|
+
event.preventDefault();
|
70
|
+
this.focusedIndex =
|
71
|
+
(this.focusedIndex - 1 + filteredLength) % filteredLength;
|
72
|
+
break;
|
73
|
+
case 'Enter':
|
74
|
+
if (this.focusedIndex >= 0 && this.focusedIndex < filteredLength) {
|
75
|
+
this.selectedValue = this.filteredItems[this.focusedIndex];
|
76
|
+
this.isOpen = false;
|
77
|
+
}
|
78
|
+
break;
|
79
|
+
default:
|
80
|
+
break;
|
81
|
+
}
|
82
|
+
}
|
83
|
+
|
84
|
+
handleMouseOver(event: Event, index: number) {
|
85
|
+
event.preventDefault();
|
86
|
+
this.focusedIndex = index;
|
87
|
+
}
|
88
|
+
|
89
|
+
updateFocus() {
|
90
|
+
if (!this.shadowRoot) return;
|
91
|
+
|
92
|
+
const items =
|
93
|
+
this.shadowRoot.querySelectorAll<HTMLElement>('combo-box-item');
|
94
|
+
items.forEach((item, index) => {
|
95
|
+
if (index === this.focusedIndex) {
|
96
|
+
item.classList.add('bg-gray-100');
|
97
|
+
} else {
|
98
|
+
item.classList.remove('bg-gray-100');
|
99
|
+
}
|
100
|
+
});
|
101
|
+
}
|
102
|
+
|
103
|
+
render() {
|
104
|
+
return html`
|
105
|
+
<div class="relative" data-hs-combo-box="">
|
106
|
+
<div class="relative">
|
107
|
+
<input
|
108
|
+
class="inline-flex justify-between items-center w-full h-10 px-4 py-2 whitespace-nowrap rounded-md
|
109
|
+
text-sm font-medium border border-input cursor-pointer
|
110
|
+
ring-offset-background
|
111
|
+
transition-colors disabled:pointer-events-none
|
112
|
+
disabled:opacity-50
|
113
|
+
bg-background hover:bg-accent
|
114
|
+
hover:text-accent-foreground
|
115
|
+
outline-none"
|
116
|
+
role="combobox"
|
117
|
+
aria-expanded=${this.isOpen}
|
118
|
+
readonly
|
119
|
+
.value=${this.selectedValue || this.label}
|
120
|
+
@click="${this.handleInputClick}"
|
121
|
+
@keydown="${this.handleKeyDown}"
|
122
|
+
/>
|
123
|
+
<div
|
124
|
+
class="absolute top-1/2 end-3 -translate-y-1/2 cursor-pointer"
|
125
|
+
aria-expanded=${this.isOpen}
|
126
|
+
data-hs-combo-box-toggle=""
|
127
|
+
@click="${this.toggleDropdown}"
|
128
|
+
>
|
129
|
+
${arrowsIcon()}
|
130
|
+
</div>
|
131
|
+
</div>
|
132
|
+
<div
|
133
|
+
class="absolute z-50 w-full max-h-72 p-1 bg-white border border-gray-200 rounded-lg overflow-hidden overflow-y-auto [&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-gray-100 [&::-webkit-scrollbar-thumb]:bg-gray-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500 dark:bg-neutral-900 dark:border-neutral-700"
|
134
|
+
style="display: ${this.isOpen ? 'block' : 'none'}; top:115%"
|
135
|
+
data-hs-combo-box-output=""
|
136
|
+
@keydown="${this.handleKeyDown}"
|
137
|
+
>
|
138
|
+
<div
|
139
|
+
class="flex items-center justify-center px-3 border-b border-gray-300 mb-1"
|
140
|
+
>
|
141
|
+
${searchIcon()}
|
142
|
+
<input
|
143
|
+
type="text"
|
144
|
+
class="w-full px-2 py-2 rounded focus:outline-none"
|
145
|
+
placeholder="Search..."
|
146
|
+
autocomplete="off"
|
147
|
+
autocorrect="off"
|
148
|
+
spellcheck="false"
|
149
|
+
aria-autocomplete="list"
|
150
|
+
role="combobox"
|
151
|
+
@input="${this.handleSearch}"
|
152
|
+
@keydown="${this.handleKeyDown}"
|
153
|
+
/>
|
154
|
+
</div>
|
155
|
+
${this.filteredItems.length === 0
|
156
|
+
? html`
|
157
|
+
<div
|
158
|
+
class="py-6 text-center text-sm"
|
159
|
+
cmdk-empty=""
|
160
|
+
role="presentation"
|
161
|
+
>
|
162
|
+
No item found.
|
163
|
+
</div>
|
164
|
+
`
|
165
|
+
: html`
|
166
|
+
${this.filteredItems.map((item, index) => {
|
167
|
+
return html`
|
168
|
+
<combo-box-item
|
169
|
+
.searchText=${item}
|
170
|
+
.value=${item}
|
171
|
+
data-hs-combo-box-value=${item}
|
172
|
+
tabIndex=${index}
|
173
|
+
@click="${(event: Event) => this.selectItem(event)}"
|
174
|
+
@mouseover="${(event: Event) =>
|
175
|
+
this.handleMouseOver(event, index)}"
|
176
|
+
?isSelected=${item === this.selectedValue}
|
177
|
+
></combo-box-item>
|
178
|
+
`;
|
179
|
+
})}
|
180
|
+
`}
|
181
|
+
</div>
|
182
|
+
</div>
|
183
|
+
`;
|
184
|
+
}
|
185
|
+
}
|
186
|
+
|
187
|
+
export { ComboBox };
|
@@ -0,0 +1,95 @@
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/web-components';
|
2
|
+
import { html } from 'lit';
|
3
|
+
import { expect, within, userEvent, waitFor, fn } from '@storybook/test';
|
4
|
+
import './combo-box.atom';
|
5
|
+
import './combo-box-list';
|
6
|
+
import './combo-box-item';
|
7
|
+
|
8
|
+
const frameworks = [
|
9
|
+
{
|
10
|
+
value: 'next.js',
|
11
|
+
label: 'Next.js',
|
12
|
+
},
|
13
|
+
{
|
14
|
+
value: 'sveltekit',
|
15
|
+
label: 'SvelteKit',
|
16
|
+
},
|
17
|
+
{
|
18
|
+
value: 'nuxt.js',
|
19
|
+
label: 'Nuxt.js',
|
20
|
+
},
|
21
|
+
{
|
22
|
+
value: 'remix',
|
23
|
+
label: 'Remix',
|
24
|
+
},
|
25
|
+
{
|
26
|
+
value: 'astro',
|
27
|
+
label: 'Astro',
|
28
|
+
},
|
29
|
+
];
|
30
|
+
|
31
|
+
const meta: Meta = {
|
32
|
+
component: 'components/combo-box',
|
33
|
+
tags: ['autodocs'],
|
34
|
+
argTypes: {
|
35
|
+
items: {
|
36
|
+
control: 'select',
|
37
|
+
description:
|
38
|
+
'An array of items to display in the dropdown menu. Each item should be a string representing the option text.',
|
39
|
+
table: {
|
40
|
+
defaultValue: { summary: '["Option 1", "Option 2", "Option 3"]' },
|
41
|
+
},
|
42
|
+
},
|
43
|
+
label: {
|
44
|
+
control: 'text',
|
45
|
+
description:
|
46
|
+
'The text displayed on the dropdown. This text is shown to users when the dropdown is closed.',
|
47
|
+
type: 'string',
|
48
|
+
table: {
|
49
|
+
defaultValue: { summary: 'Select an item' },
|
50
|
+
},
|
51
|
+
},
|
52
|
+
},
|
53
|
+
};
|
54
|
+
export default meta;
|
55
|
+
type Story = StoryObj;
|
56
|
+
// Base story
|
57
|
+
export const basicComboBox: Story = {
|
58
|
+
name: 'Basic Usage',
|
59
|
+
args: {
|
60
|
+
items: ['Argentina', 'Brazil', 'China', 'USA', 'Italy', 'Iran', 'UAE'],
|
61
|
+
label: 'Select an item',
|
62
|
+
},
|
63
|
+
render: ({ label, items }) => {
|
64
|
+
return html`
|
65
|
+
<rtg-combo-box label="${label}" .items=${items}>
|
66
|
+
<combo-box-list>
|
67
|
+
${frameworks.map(
|
68
|
+
(item, index) => html`
|
69
|
+
<combo-box-item
|
70
|
+
.searchText="${item.label}"
|
71
|
+
.value="${item.value}"
|
72
|
+
data-hs-combo-box-value="${item.value}"
|
73
|
+
tabIndex="${index}"
|
74
|
+
></combo-box-item>
|
75
|
+
`
|
76
|
+
)}
|
77
|
+
</combo-box-list>
|
78
|
+
</rtg-combo-box>
|
79
|
+
`;
|
80
|
+
},
|
81
|
+
};
|
82
|
+
|
83
|
+
// Story for empty items array
|
84
|
+
export const emptyComboBox: Story = {
|
85
|
+
name: 'Empty Items',
|
86
|
+
args: {
|
87
|
+
items: [],
|
88
|
+
label: 'Select an item',
|
89
|
+
},
|
90
|
+
render: ({ label, items }) => {
|
91
|
+
return html`
|
92
|
+
<rtg-combo-box label=${label}" .items=${items}> </rtg-combo-box>
|
93
|
+
`;
|
94
|
+
},
|
95
|
+
};
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { LitElement, html, css, nothing } from 'lit';
|
2
2
|
import { property, customElement } from 'lit/decorators.js';
|
3
|
-
import { cn } from '
|
4
|
-
import { TWStyles } from '
|
3
|
+
import { cn } from '../../../helpers';
|
4
|
+
import { TWStyles } from '../../../styles';
|
5
5
|
|
6
6
|
@customElement('rtg-command-empty')
|
7
7
|
export class CommandEmpty extends LitElement {
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { LitElement, html, css, nothing } from 'lit';
|
2
2
|
import { property, customElement } from 'lit/decorators.js';
|
3
|
-
import { TWStyles } from '
|
3
|
+
import { TWStyles } from '../../../styles';
|
4
4
|
|
5
5
|
@customElement('rtg-command-group')
|
6
6
|
export class CommandGroup extends LitElement {
|
@@ -4,8 +4,8 @@ import {
|
|
4
4
|
customElement,
|
5
5
|
queryAssignedElements,
|
6
6
|
} from 'lit/decorators.js';
|
7
|
-
import { cn } from '
|
8
|
-
import { TWStyles } from '
|
7
|
+
import { cn } from '../../../helpers';
|
8
|
+
import { TWStyles } from '../../../styles';
|
9
9
|
|
10
10
|
@customElement('rtg-command-item')
|
11
11
|
export class CommandItem extends LitElement {
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { LitElement, html, css } from 'lit';
|
2
2
|
import { customElement } from 'lit/decorators.js';
|
3
|
-
import { cn } from '
|
4
|
-
import { TWStyles } from '
|
3
|
+
import { cn } from '../../../helpers';
|
4
|
+
import { TWStyles } from '../../../styles';
|
5
5
|
|
6
6
|
@customElement('rtg-command-list')
|
7
7
|
export class CommandList extends LitElement {
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { LitElement, html, css, nothing } from 'lit';
|
2
2
|
import { property, customElement } from 'lit/decorators.js';
|
3
|
-
import { cn } from '
|
4
|
-
import { TWStyles } from '
|
3
|
+
import { cn } from '../../../helpers';
|
4
|
+
import { TWStyles } from '../../../styles';
|
5
5
|
|
6
6
|
@customElement('rtg-command-separator')
|
7
7
|
export class CommandSeparator extends LitElement {
|
@@ -0,0 +1,50 @@
|
|
1
|
+
import { TWStyles } from '../../../styles';
|
2
|
+
import { css, html, LitElement, PropertyValueMap } from 'lit';
|
3
|
+
import { customElement } from 'lit/decorators.js';
|
4
|
+
import { Dialog } from './dialog.atom';
|
5
|
+
|
6
|
+
const STATE_OPEN = 'open';
|
7
|
+
const STATE_CLOSED = 'closed';
|
8
|
+
|
9
|
+
@customElement('rtg-dialog-close')
|
10
|
+
export class DialogClose extends LitElement {
|
11
|
+
static styles = [css``, TWStyles];
|
12
|
+
|
13
|
+
private get _dialog(): Dialog | null {
|
14
|
+
let parent = this.parentElement;
|
15
|
+
|
16
|
+
while (parent) {
|
17
|
+
if (parent instanceof Dialog) {
|
18
|
+
return parent;
|
19
|
+
}
|
20
|
+
parent = parent.parentElement;
|
21
|
+
}
|
22
|
+
return parent;
|
23
|
+
}
|
24
|
+
|
25
|
+
protected firstUpdated(
|
26
|
+
_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>
|
27
|
+
): void {
|
28
|
+
super.firstUpdated(_changedProperties);
|
29
|
+
const slot = this.shadowRoot?.querySelector('slot');
|
30
|
+
const children = slot?.assignedElements();
|
31
|
+
if (children && children.length > 0) {
|
32
|
+
const button = children[0];
|
33
|
+
|
34
|
+
button.addEventListener('click', () => {
|
35
|
+
const dialog = this._dialog;
|
36
|
+
if (dialog) {
|
37
|
+
dialog.dataset.state = STATE_CLOSED;
|
38
|
+
}
|
39
|
+
});
|
40
|
+
}
|
41
|
+
}
|
42
|
+
|
43
|
+
render() {
|
44
|
+
return html`
|
45
|
+
<div>
|
46
|
+
<slot></slot>
|
47
|
+
</div>
|
48
|
+
`;
|
49
|
+
}
|
50
|
+
}
|
@@ -0,0 +1,71 @@
|
|
1
|
+
import { TWStyles } from '../../../styles';
|
2
|
+
import { cn } from '../../../helpers';
|
3
|
+
import { css, html, LitElement, nothing } from 'lit';
|
4
|
+
import { customElement, property } from 'lit/decorators.js';
|
5
|
+
import { Dialog } from './dialog.atom';
|
6
|
+
|
7
|
+
const STATE_OPEN = 'open';
|
8
|
+
const STATE_CLOSED = 'closed';
|
9
|
+
|
10
|
+
@customElement('rtg-dialog-content')
|
11
|
+
export class DialogContent extends LitElement {
|
12
|
+
static styles = [css``, TWStyles];
|
13
|
+
|
14
|
+
@property({ attribute: 'data-state', type: String }) state = STATE_CLOSED;
|
15
|
+
|
16
|
+
private get _dialog(): Dialog | null {
|
17
|
+
let parent = this.parentElement;
|
18
|
+
|
19
|
+
while (parent) {
|
20
|
+
if (parent instanceof Dialog) {
|
21
|
+
return parent;
|
22
|
+
}
|
23
|
+
parent = parent.parentElement;
|
24
|
+
}
|
25
|
+
return parent;
|
26
|
+
}
|
27
|
+
|
28
|
+
private handleCloseButtonClick = () => {
|
29
|
+
const dialog = this._dialog;
|
30
|
+
if (dialog) {
|
31
|
+
dialog.dataset.state = STATE_CLOSED;
|
32
|
+
}
|
33
|
+
};
|
34
|
+
|
35
|
+
render() {
|
36
|
+
return html`${this.state === STATE_OPEN
|
37
|
+
? html`
|
38
|
+
<div
|
39
|
+
class="${cn(
|
40
|
+
'fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg',
|
41
|
+
this.className
|
42
|
+
)}"
|
43
|
+
rtgdlg-content
|
44
|
+
>
|
45
|
+
<slot></slot>
|
46
|
+
<button
|
47
|
+
type="button"
|
48
|
+
@click="${this.handleCloseButtonClick}"
|
49
|
+
class="absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground"
|
50
|
+
>
|
51
|
+
<svg
|
52
|
+
xmlns="http://www.w3.org/2000/svg"
|
53
|
+
width="24"
|
54
|
+
height="24"
|
55
|
+
viewBox="0 0 24 24"
|
56
|
+
fill="none"
|
57
|
+
stroke="currentColor"
|
58
|
+
stroke-width="2"
|
59
|
+
stroke-linecap="round"
|
60
|
+
stroke-linejoin="round"
|
61
|
+
class="h-4 w-4"
|
62
|
+
>
|
63
|
+
<path d="M18 6 6 18"></path>
|
64
|
+
<path d="m6 6 12 12"></path></svg
|
65
|
+
><span class="sr-only">Close</span>
|
66
|
+
</button>
|
67
|
+
</div>
|
68
|
+
`
|
69
|
+
: nothing}`;
|
70
|
+
}
|
71
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import { cn } from '../../../helpers';
|
2
|
+
import { TWStyles } from '../../../styles';
|
3
|
+
import { css, html, LitElement } from 'lit';
|
4
|
+
import { customElement } from 'lit/decorators.js';
|
5
|
+
|
6
|
+
@customElement('rtg-dialog-footer')
|
7
|
+
export class DialogFooter extends LitElement {
|
8
|
+
static styles = [css``, TWStyles];
|
9
|
+
|
10
|
+
render() {
|
11
|
+
return html`
|
12
|
+
<div
|
13
|
+
class="${cn(
|
14
|
+
'flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2',
|
15
|
+
this.className
|
16
|
+
)}"
|
17
|
+
>
|
18
|
+
<slot></slot>
|
19
|
+
</div>
|
20
|
+
`;
|
21
|
+
}
|
22
|
+
}
|
@@ -0,0 +1,36 @@
|
|
1
|
+
import { cn } from '../../../helpers';
|
2
|
+
import { TWStyles } from '../../../styles';
|
3
|
+
import { css, html, LitElement } from 'lit';
|
4
|
+
import { customElement, property } from 'lit/decorators.js';
|
5
|
+
|
6
|
+
@customElement('rtg-dialog-header')
|
7
|
+
export class DialogHeader extends LitElement {
|
8
|
+
static styles = [css``, TWStyles];
|
9
|
+
|
10
|
+
@property({ attribute: 'title', type: String }) _title = '';
|
11
|
+
|
12
|
+
@property({ type: String }) description = '';
|
13
|
+
|
14
|
+
render() {
|
15
|
+
return html`
|
16
|
+
<div
|
17
|
+
class="${cn(
|
18
|
+
'flex flex-col space-y-1.5 text-center sm:text-left',
|
19
|
+
this.className
|
20
|
+
)}"
|
21
|
+
>
|
22
|
+
<h2
|
23
|
+
class="${cn(
|
24
|
+
'text-lg font-semibold leading-none tracking-tight',
|
25
|
+
this.className
|
26
|
+
)}"
|
27
|
+
>
|
28
|
+
${this._title}
|
29
|
+
</h2>
|
30
|
+
<p class="${cn('text-sm text-muted-foreground', this.className)}">
|
31
|
+
${this.description}
|
32
|
+
</p>
|
33
|
+
</div>
|
34
|
+
`;
|
35
|
+
}
|
36
|
+
}
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { cn } from '../../../helpers';
|
2
|
+
import { TWStyles } from '../../../styles';
|
3
|
+
import { css, html, LitElement } from 'lit';
|
4
|
+
import { customElement, property } from 'lit/decorators.js';
|
5
|
+
|
6
|
+
@customElement('rtg-dialog-overlay')
|
7
|
+
export class DialogOverlay extends LitElement {
|
8
|
+
static styles = [css``, TWStyles];
|
9
|
+
|
10
|
+
render() {
|
11
|
+
return html`
|
12
|
+
<div
|
13
|
+
class="${cn(
|
14
|
+
'fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0',
|
15
|
+
this.className
|
16
|
+
)}"
|
17
|
+
></div>
|
18
|
+
`;
|
19
|
+
}
|
20
|
+
}
|
@@ -0,0 +1,54 @@
|
|
1
|
+
import { TWStyles } from '../../../styles';
|
2
|
+
import { css, html, LitElement, PropertyValueMap } from 'lit';
|
3
|
+
import { customElement } from 'lit/decorators.js';
|
4
|
+
import { Dialog } from './dialog.atom';
|
5
|
+
|
6
|
+
const STATE_OPEN = 'open';
|
7
|
+
const STATE_CLOSED = 'closed';
|
8
|
+
|
9
|
+
@customElement('rtg-dialog-trigger')
|
10
|
+
export class DialogTrigger extends LitElement {
|
11
|
+
static styles = [css``, TWStyles];
|
12
|
+
|
13
|
+
private get _dialog(): Dialog | null {
|
14
|
+
let parent = this.parentElement;
|
15
|
+
|
16
|
+
while (parent) {
|
17
|
+
if (parent instanceof Dialog) {
|
18
|
+
return parent;
|
19
|
+
}
|
20
|
+
parent = parent.parentElement;
|
21
|
+
}
|
22
|
+
return parent;
|
23
|
+
}
|
24
|
+
|
25
|
+
handleClick = () => {
|
26
|
+
const dialog = this._dialog;
|
27
|
+
if (dialog) {
|
28
|
+
dialog.dataset.state = STATE_OPEN;
|
29
|
+
}
|
30
|
+
};
|
31
|
+
protected firstUpdated(
|
32
|
+
_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>
|
33
|
+
): void {
|
34
|
+
super.firstUpdated(_changedProperties);
|
35
|
+
const slots = this.shadowRoot?.querySelector('slot') as HTMLSlotElement;
|
36
|
+
const assignedElements = slots?.assignedElements({ flatten: true });
|
37
|
+
if (assignedElements && assignedElements.length > 0) {
|
38
|
+
//@ts-ignore
|
39
|
+
assignedElements[0].click = this.handleClick;
|
40
|
+
}
|
41
|
+
|
42
|
+
this.shadowRoot?.addEventListener('click', e => {
|
43
|
+
e.stopPropagation();
|
44
|
+
});
|
45
|
+
}
|
46
|
+
|
47
|
+
render() {
|
48
|
+
return html`
|
49
|
+
<div>
|
50
|
+
<slot></slot>
|
51
|
+
</div>
|
52
|
+
`;
|
53
|
+
}
|
54
|
+
}
|