@redvars/peacock 3.3.0 → 3.3.1

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.
Files changed (105) hide show
  1. package/dist/assets/components.css +1 -1
  2. package/dist/assets/components.css.map +1 -1
  3. package/dist/assets/styles.css +1 -1
  4. package/dist/assets/styles.css.map +1 -1
  5. package/dist/button-group-DA7xoziD.js +292 -0
  6. package/dist/button-group-DA7xoziD.js.map +1 -0
  7. package/dist/button-group.js +6 -107
  8. package/dist/button-group.js.map +1 -1
  9. package/dist/{button-BGFJfbT2.js → button-trIfcqC7.js} +2 -3
  10. package/dist/{button-BGFJfbT2.js.map → button-trIfcqC7.js.map} +1 -1
  11. package/dist/button.js +2 -3
  12. package/dist/button.js.map +1 -1
  13. package/dist/{class-map-DpeNtqCn.js → class-map-hJdvjl-W.js} +9 -3
  14. package/dist/class-map-hJdvjl-W.js.map +1 -0
  15. package/dist/code-editor.js +5 -5
  16. package/dist/code-editor.js.map +1 -1
  17. package/dist/code-highlighter.js +5 -23
  18. package/dist/code-highlighter.js.map +1 -1
  19. package/dist/custom-elements-jsdocs.json +4706 -2471
  20. package/dist/custom-elements.json +3444 -1007
  21. package/dist/index.js +4 -5
  22. package/dist/index.js.map +1 -1
  23. package/dist/peacock-loader.js +26 -496
  24. package/dist/peacock-loader.js.map +1 -1
  25. package/dist/src/accordion/accordion-item.d.ts +1 -0
  26. package/dist/src/breadcrumb/breadcrumb/breadcrumb.d.ts +2 -0
  27. package/dist/src/breadcrumb/breadcrumb-item/breadcrumb-item.d.ts +1 -0
  28. package/dist/src/button/button-group/button-group.d.ts +4 -0
  29. package/dist/src/code-editor/code-editor.d.ts +4 -3
  30. package/dist/src/code-highlighter/code-highlighter.d.ts +4 -7
  31. package/dist/src/index.d.ts +4 -0
  32. package/dist/src/menu/index.d.ts +3 -0
  33. package/dist/src/menu/menu/MenuSurfaceController.d.ts +18 -0
  34. package/dist/src/menu/menu/menu.d.ts +54 -12
  35. package/dist/src/menu/menu-item/menu-item.d.ts +12 -5
  36. package/dist/src/menu/sub-menu/sub-menu.d.ts +36 -0
  37. package/dist/src/pagination/index.d.ts +1 -0
  38. package/dist/src/pagination/pagination.d.ts +38 -0
  39. package/dist/src/popover/PopoverController.d.ts +4 -1
  40. package/dist/src/table/index.d.ts +1 -0
  41. package/dist/src/table/table.d.ts +110 -0
  42. package/dist/src/tabs/tab-group.d.ts +4 -0
  43. package/dist/src/tabs/tab-panel.d.ts +1 -0
  44. package/dist/src/tabs/tab.d.ts +1 -0
  45. package/dist/src/tabs/tabs.d.ts +2 -0
  46. package/dist/src/tooltip/tooltip.d.ts +1 -3
  47. package/dist/src/tree-view/index.d.ts +2 -0
  48. package/dist/src/tree-view/tree-node.d.ts +69 -0
  49. package/dist/src/tree-view/tree-view.d.ts +40 -0
  50. package/dist/src/tree-view/wc-tree-view.d.ts +6 -0
  51. package/dist/test/icon.test.d.ts +1 -1
  52. package/dist/test/menu.test.d.ts +1 -0
  53. package/dist/test/sub-menu.test.d.ts +1 -0
  54. package/dist/test/tree-view.test.d.ts +1 -0
  55. package/dist/{slider-Dk9CFWTG.js → tree-view-CLolVlU0.js} +3317 -1180
  56. package/dist/tree-view-CLolVlU0.js.map +1 -0
  57. package/dist/tsconfig.tsbuildinfo +1 -1
  58. package/package.json +1 -1
  59. package/readme.md +40 -40
  60. package/src/accordion/accordion-item.ts +2 -1
  61. package/src/breadcrumb/breadcrumb/breadcrumb.ts +3 -0
  62. package/src/breadcrumb/breadcrumb-item/breadcrumb-item.ts +1 -0
  63. package/src/button/button-group/button-group.ts +6 -0
  64. package/src/code-editor/code-editor.ts +4 -3
  65. package/src/code-highlighter/code-highlighter.ts +4 -22
  66. package/src/divider/divider.scss +2 -2
  67. package/src/empty-state/empty-state.scss +1 -1
  68. package/src/empty-state/empty-state.ts +1 -1
  69. package/src/index.ts +6 -2
  70. package/src/menu/index.ts +3 -0
  71. package/src/menu/menu/MenuSurfaceController.ts +61 -0
  72. package/src/menu/{menu-list/menu-list.scss → menu/menu.scss} +19 -4
  73. package/src/menu/menu/menu.ts +389 -81
  74. package/src/menu/menu-item/menu-item.ts +115 -36
  75. package/src/menu/sub-menu/sub-menu.scss +7 -0
  76. package/src/menu/sub-menu/sub-menu.ts +243 -0
  77. package/src/pagination/index.ts +1 -0
  78. package/src/pagination/pagination.scss +59 -0
  79. package/src/pagination/pagination.ts +135 -0
  80. package/src/peacock-loader.ts +25 -11
  81. package/src/popover/PopoverController.ts +13 -7
  82. package/src/table/index.ts +1 -0
  83. package/src/table/table.scss +174 -0
  84. package/src/table/table.ts +475 -0
  85. package/src/tabs/tab-group.ts +12 -6
  86. package/src/tabs/tab-panel.ts +1 -0
  87. package/src/tabs/tab.ts +1 -0
  88. package/src/tabs/tabs.scss +6 -5
  89. package/src/tabs/tabs.ts +5 -3
  90. package/src/text/text.css-component.scss +6 -3
  91. package/src/tooltip/tooltip.scss +16 -13
  92. package/src/tooltip/tooltip.ts +7 -9
  93. package/src/tree-view/demo/index.html +57 -0
  94. package/src/tree-view/index.ts +2 -0
  95. package/src/tree-view/tree-node.scss +101 -0
  96. package/src/tree-view/tree-node.ts +268 -0
  97. package/src/tree-view/tree-view.scss +12 -0
  98. package/src/tree-view/tree-view.ts +182 -0
  99. package/src/tree-view/wc-tree-view.ts +9 -0
  100. package/dist/class-map-DpeNtqCn.js.map +0 -1
  101. package/dist/slider-Dk9CFWTG.js.map +0 -1
  102. package/dist/src/menu/menu-list/menu-list.d.ts +0 -22
  103. package/dist/state-8v48Exzh.js +0 -10
  104. package/dist/state-8v48Exzh.js.map +0 -1
  105. package/src/menu/menu-list/menu-list.ts +0 -48
package/dist/index.js CHANGED
@@ -1,18 +1,17 @@
1
- export { A as Accordion, a as Avatar, B as Badge, b as Breadcrumb, c as BreadcrumbItem, C as Chip, d as CircularProgress, e as Container, D as DatePicker, f as Divider, E as Elevation, g as EmptyState, F as Field, h as FocusRing, I as Icon, i as IconButton, j as Image, k as Input, L as LinearProgress, l as Link, N as NumberField, R as Ripple, S as Skeleton, m as Slider, n as Spinner, o as Switch, T as Tab, p as TabGroup, q as TabPanel, r as Tabs, s as Tag, t as Textarea, u as TimePicker, v as Tooltip } from './slider-Dk9CFWTG.js';
1
+ export { A as Accordion, a as Avatar, B as Badge, b as Breadcrumb, c as BreadcrumbItem, C as Chip, d as CircularProgress, e as Container, D as DatePicker, f as Divider, E as Elevation, g as EmptyState, F as Field, h as FocusRing, I as Icon, i as Image, j as Input, L as LinearProgress, k as Link, M as Menu, l as MenuItem, N as NumberField, P as Pagination, R as Ripple, S as Skeleton, m as Slider, n as Spinner, o as SubMenu, p as Switch, T as Tab, q as TabGroup, r as TabPanel, s as Table, t as Tabs, u as Tag, v as Textarea, w as TimePicker, x as Tooltip, y as TreeNode, z as TreeView } from './tree-view-CLolVlU0.js';
2
2
  export { Clock } from './clock.js';
3
- export { B as Button } from './button-BGFJfbT2.js';
4
- export { ButtonGroup } from './button-group.js';
3
+ export { B as Button } from './button-trIfcqC7.js';
4
+ export { B as ButtonGroup, I as IconButton } from './button-group-DA7xoziD.js';
5
5
  export { NumberCounter } from './number-counter.js';
6
6
  export { CodeHighlighter } from './code-highlighter.js';
7
7
  export { default as CodeEditor } from './code-editor.js';
8
8
  export { ChartDoughnut } from './chart-doughnut.js';
9
9
  export { ChartPie } from './chart-pie.js';
10
10
  import './IndividualComponent-tDnXrOLV.js';
11
- import './state-8v48Exzh.js';
11
+ import './class-map-hJdvjl-W.js';
12
12
  import './directive-Cuw6h7YA.js';
13
13
  import './unsafe-html-CV6Je6HL.js';
14
14
  import './dispatch-event-utils-B4odODQf.js';
15
- import './class-map-DpeNtqCn.js';
16
15
  import './query-QBcUV-L_.js';
17
16
  import './style-map-CfNHEkQp.js';
18
17
  import './observe-theme-change-BISF-Gl5.js';
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;"}
@@ -1,17 +1,16 @@
1
- import { A as Accordion, m as Slider, j as Image, e as Container, g as EmptyState, n as Spinner, o as Switch, c as BreadcrumbItem, b as Breadcrumb, v as Tooltip, u as TimePicker, D as DatePicker, t as Textarea, N as NumberField, k as Input, F as Field, S as Skeleton, d as CircularProgress, L as LinearProgress, s as Tag, C as Chip, l as Link, q as TabPanel, T as Tab, p as TabGroup, r as Tabs, R as Ripple, E as Elevation, f as Divider, i as IconButton, B as Badge, a as Avatar, h as FocusRing, I as Icon } from './slider-Dk9CFWTG.js';
2
- import { s as spread, B as Button } from './button-BGFJfbT2.js';
3
- import { ButtonGroup } from './button-group.js';
1
+ import { z as TreeView, A as Accordion, P as Pagination, s as Table, m as Slider, i as Image, e as Container, o as SubMenu, l as MenuItem, M as Menu, g as EmptyState, n as Spinner, p as Switch, c as BreadcrumbItem, b as Breadcrumb, x as Tooltip, w as TimePicker, D as DatePicker, v as Textarea, N as NumberField, j as Input, F as Field, S as Skeleton, d as CircularProgress, L as LinearProgress, u as Tag, C as Chip, k as Link, r as TabPanel, T as Tab, q as TabGroup, t as Tabs, R as Ripple, E as Elevation, f as Divider, B as Badge, a as Avatar, h as FocusRing, I as Icon } from './tree-view-CLolVlU0.js';
2
+ import { s as spread, B as Button } from './button-trIfcqC7.js';
3
+ import { B as ButtonGroup, I as IconButton } from './button-group-DA7xoziD.js';
4
4
  import { i, _ as __decorate, n, a as i$1, w, b } from './IndividualComponent-tDnXrOLV.js';
5
- import { r } from './state-8v48Exzh.js';
5
+ import { r, e as e$1 } from './class-map-hJdvjl-W.js';
6
6
  import { e } from './query-QBcUV-L_.js';
7
- import { e as e$1 } from './class-map-DpeNtqCn.js';
8
7
  import './directive-Cuw6h7YA.js';
9
8
  import './unsafe-html-CV6Je6HL.js';
10
9
  import './dispatch-event-utils-B4odODQf.js';
11
10
  import './style-map-CfNHEkQp.js';
12
11
  import './observe-theme-change-BISF-Gl5.js';
13
12
 
14
- var css_248z$3 = i`* {
13
+ var css_248z = i`* {
15
14
  box-sizing: border-box;
16
15
  }
17
16
 
@@ -481,7 +480,7 @@ class Checkbox extends i$1 {
481
480
  `;
482
481
  }
483
482
  }
484
- Checkbox.styles = [css_248z$3];
483
+ Checkbox.styles = [css_248z];
485
484
  __decorate([
486
485
  n({ type: String })
487
486
  ], Checkbox.prototype, "name", void 0);
@@ -528,487 +527,6 @@ __decorate([
528
527
  e('.input-native')
529
528
  ], Checkbox.prototype, "nativeElement", void 0);
530
529
 
531
- /**
532
- * @label Menu
533
- * @tag wc-menu
534
- * @rawTag menu
535
- * @summary A dropdown menu component.
536
- * @tags navigation
537
- *
538
- * @example
539
- * ```html
540
- * <wc-menu>
541
- * <wc-menu-list>
542
- * <wc-menu-item>Item 1</wc-menu-item>
543
- * </wc-menu-list>
544
- * </wc-menu>
545
- * ```
546
- */
547
- class Menu extends i$1 {
548
- constructor() {
549
- super();
550
- this.open = false;
551
- // Position: 'bottom-start' | 'bottom-end' | etc. (Simplified here to generic dropdown)
552
- this.align = 'start';
553
- this._boundClickOutside = this._handleClickOutside.bind(this);
554
- }
555
- connectedCallback() {
556
- // eslint-disable-next-line wc/guard-super-call
557
- super.connectedCallback();
558
- window.addEventListener('click', this._boundClickOutside);
559
- // Listen for menu-item clicks bubbling up
560
- this.addEventListener('click', this._handleItemClick);
561
- }
562
- disconnectedCallback() {
563
- // eslint-disable-next-line wc/guard-super-call
564
- super.disconnectedCallback();
565
- window.removeEventListener('click', this._boundClickOutside);
566
- this.removeEventListener('click', this._handleItemClick);
567
- }
568
- _handleClickOutside(e) {
569
- if (!this.open)
570
- return;
571
- const path = e.composedPath();
572
- if (!path.includes(this)) {
573
- this.open = false;
574
- }
575
- }
576
- _handleItemClick(e) {
577
- const target = e.target;
578
- // Check if the clicked element is a menu-item
579
- if (target.tagName.toLowerCase() === 'menu-item') {
580
- // Dispatch custom event with value
581
- const value = target.value;
582
- this.dispatchEvent(new CustomEvent('menu-selected', {
583
- detail: { value },
584
- bubbles: true,
585
- composed: true,
586
- }));
587
- this.open = false;
588
- }
589
- }
590
- _toggleMenu(e) {
591
- e.stopPropagation(); // Prevent immediate closing via window listener
592
- this.open = !this.open;
593
- }
594
- render() {
595
- return b `
596
- <div class="trigger" @click="${this._toggleMenu}">
597
- <slot name="trigger"></slot>
598
- </div>
599
-
600
- <div class="menu-wrapper">
601
- <!-- We expect a menu-list to be passed here -->
602
- <slot></slot>
603
- </div>
604
- `;
605
- }
606
- }
607
- Menu.styles = i `
608
- :host {
609
- display: inline-block;
610
- position: relative;
611
- }
612
-
613
- .trigger {
614
- cursor: pointer;
615
- display: inline-block;
616
- }
617
-
618
- .menu-wrapper {
619
- position: absolute;
620
- top: 100%;
621
- z-index: 10;
622
- opacity: 0;
623
- transform: scale(0.95);
624
- transform-origin: top left;
625
- transition:
626
- opacity 0.1s ease-out,
627
- transform 0.1s ease-out;
628
- pointer-events: none; /* Prevent clicking when hidden */
629
- margin-top: 4px; /* Slight gap */
630
- }
631
-
632
- :host([open]) .menu-wrapper {
633
- opacity: 1;
634
- transform: scale(1);
635
- pointer-events: auto;
636
- }
637
-
638
- /* Alignment logic */
639
- :host([align='end']) .menu-wrapper {
640
- right: 0;
641
- transform-origin: top right;
642
- }
643
- :host([align='start']) .menu-wrapper {
644
- left: 0;
645
- transform-origin: top left;
646
- }
647
- `;
648
- __decorate([
649
- n({ type: Boolean, reflect: true })
650
- ], Menu.prototype, "open", void 0);
651
- __decorate([
652
- n({ type: String })
653
- ], Menu.prototype, "align", void 0);
654
- __decorate([
655
- e('.menu-wrapper')
656
- ], Menu.prototype, "menuWrapper", void 0);
657
-
658
- var css_248z$2 = i`* {
659
- box-sizing: border-box;
660
- }
661
-
662
- .screen-reader-only {
663
- display: none !important;
664
- }
665
-
666
- :host {
667
- padding-inline: var(--spacing-050);
668
- }
669
-
670
- .menu-item {
671
- position: relative;
672
- height: 3rem;
673
- display: flex;
674
- align-items: center;
675
- padding-inline: 0.75rem;
676
- outline: 0;
677
- text-decoration: none;
678
- font-family: var(--typography-label-large-font-family) !important;
679
- font-size: var(--typography-label-large-font-size) !important;
680
- font-weight: var(--typography-label-large-font-weight) !important;
681
- line-height: var(--typography-label-large-line-height) !important;
682
- letter-spacing: var(--typography-label-large-letter-spacing) !important;
683
- }
684
- .menu-item .menu-item-content {
685
- display: flex;
686
- align-items: center;
687
- z-index: 1;
688
- width: 100%;
689
- gap: var(--spacing-100);
690
- color: var(--_label-text-color);
691
- opacity: var(--_label-text-opacity, 1);
692
- --icon-size: var(--button-icon-size, var(--_button-icon-size));
693
- --icon-color: var(--_label-text-color);
694
- }
695
- .menu-item .menu-item-content .slot-container {
696
- flex: 1;
697
- }
698
- .menu-item .background {
699
- display: block;
700
- position: absolute;
701
- left: 0;
702
- top: 0;
703
- width: 100%;
704
- height: 100%;
705
- background-color: var(--_container-color);
706
- opacity: var(--_container-opacity, 1);
707
- border-start-start-radius: var(--_container-shape-start-start);
708
- border-start-end-radius: var(--_container-shape-start-end);
709
- border-end-start-radius: var(--_container-shape-end-start);
710
- border-end-end-radius: var(--_container-shape-end-end);
711
- corner-shape: var(--_container-corner-shape-variant);
712
- pointer-events: none;
713
- }
714
- .menu-item {
715
- /*
716
- Background layers
717
- */
718
- }
719
- .menu-item .focus-ring {
720
- z-index: 2;
721
- --focus-ring-container-shape-start-start: var(--_container-shape-start-start);
722
- --focus-ring-container-shape-start-end: var(--_container-shape-start-end);
723
- --focus-ring-container-shape-end-start: var(--_container-shape-end-start);
724
- --focus-ring-container-shape-end-end: var(--_container-shape-end-end);
725
- --focus-ring-container-shape-variant: var(--_container-corner-shape-variant);
726
- }
727
- .menu-item .ripple {
728
- --ripple-state-opacity: var(--_container-state-opacity, 0);
729
- --ripple-pressed-color: var(--_container-state-color);
730
- border-start-start-radius: var(--_container-shape-start-start);
731
- border-start-end-radius: var(--_container-shape-start-end);
732
- border-end-start-radius: var(--_container-shape-end-start);
733
- border-end-end-radius: var(--_container-shape-end-end);
734
- corner-shape: var(--_container-corner-shape-variant);
735
- }
736
-
737
- .menu-item {
738
- --_container-shape-start-start: var(--menu-item-container-shape-start-start, var(--shape-corner-extra-small));
739
- --_container-shape-start-end: var(--menu-item-container-shape-start-end, var(--shape-corner-extra-small));
740
- --_container-shape-end-start: var(--menu-item-container-shape-end-start, var(--shape-corner-extra-small));
741
- --_container-shape-end-end: var(--menu-item-container-shape-end-end, var(--shape-corner-extra-small));
742
- --_container-corner-shape-variant: none;
743
- --_label-text-color: var(--menu-item-label-color);
744
- --_container-state-color: var(--_label-text-color);
745
- }
746
- .menu-item:hover:not(:where(.disabled, .selected)) {
747
- --_container-state-opacity: 0.08;
748
- }
749
- .menu-item.selected {
750
- --_container-color: var(--menu-item-container-selected-color);
751
- --_label-text-color: var(--menu-item-label-selected-color);
752
- --_container-shape-start-start: var(--shape-corner-large);
753
- --_container-shape-start-end: var(--shape-corner-large);
754
- --_container-shape-end-start: var(--shape-corner-large);
755
- --_container-shape-end-end: var(--shape-corner-large);
756
- --_container-corner-shape-variant: none;
757
- }
758
- .menu-item.disabled {
759
- cursor: not-allowed;
760
- --_container-color: var(--color-on-surface);
761
- --_container-opacity: 0.1;
762
- --_label-text-color: var(--color-on-surface);
763
- --_label-text-opacity: 0.38;
764
- }
765
- .menu-item.disabled .ripple {
766
- display: none;
767
- }`;
768
-
769
- var css_248z$1 = i`:host-context([variant=standard]) {
770
- --menu-item-label-color: var(--color-on-surface-variant);
771
- --menu-item-label-selected-color: var(--color-on-tertiary-container);
772
- --menu-item-container-selected-color: var(--color-tertiary-container);
773
- }
774
-
775
- :host-context([variant=vibrant]) {
776
- --menu-item-label-color: var(--color-on-tertiary-container);
777
- --menu-item-label-selected-color: var(--color-on-tertiary);
778
- --menu-item-container-selected-color: var(--color-tertiary);
779
- }`;
780
-
781
- /**
782
- * @label Menu Item
783
- * @tag wc-menu-item
784
- * @rawTag menu-item
785
- * @summary An item in a menu list.
786
- * @tags navigation
787
- *
788
- * @example
789
- * ```html
790
- * <wc-menu-item>Menu Item</wc-menu-item>
791
- * ```
792
- */
793
- class MenuItem extends i$1 {
794
- constructor() {
795
- super(...arguments);
796
- this.disabled = false;
797
- this.value = '';
798
- this.selected = false;
799
- /**
800
- * Sets or retrieves the window or frame at which to target content.
801
- */
802
- this.target = '_self';
803
- this.variant = 'standard';
804
- }
805
- connectedCallback() {
806
- // eslint-disable-next-line wc/guard-super-call
807
- super.connectedCallback();
808
- if (!this.hasAttribute('role')) {
809
- this.setAttribute('role', 'menuitem');
810
- }
811
- }
812
- // Handle keyboard activation (Enter/Space)
813
- _handleKeyDown(e) {
814
- if (e.key === 'Enter' || e.key === ' ') {
815
- e.preventDefault();
816
- this.click();
817
- }
818
- }
819
- __isLink() {
820
- return !!this.href;
821
- }
822
- focus() {
823
- this.menuItemElement?.focus();
824
- }
825
- blur() {
826
- this.menuItemElement?.blur();
827
- }
828
- render() {
829
- const isLink = this.__isLink();
830
- const cssClasses = {
831
- 'menu-item': true,
832
- disabled: this.disabled,
833
- selected: this.selected,
834
- };
835
- if (isLink) {
836
- return b `<a
837
- class=${e$1(cssClasses)}
838
- href=${this.href}
839
- target=${this.target}
840
- >
841
- ${this.renderContent()}
842
- </a>
843
- `;
844
- }
845
- return b `<div
846
- class=${e$1(cssClasses)}
847
- tabindex=${!this.disabled ? 0 : -1}
848
- @keydown="${this._handleKeyDown}"
849
- >
850
- ${this.renderContent()}
851
- </div>
852
- `;
853
- }
854
- renderContent() {
855
- return b `
856
- <wc-focus-ring class="focus-ring" .control=${this} element="menuItemElement"></wc-focus-ring>
857
- <div class="background"></div>
858
- <wc-ripple class="ripple"></wc-ripple>
859
-
860
- <div class="menu-item-content">
861
- <slot name="leading-icon"></slot>
862
- <div class="slot-container">
863
- <slot></slot>
864
- </div>
865
- <slot
866
- name="trailing-supporting-text"
867
- ></slot>
868
- </div>
869
- `;
870
- }
871
- }
872
- MenuItem.styles = [css_248z$2, css_248z$1];
873
- __decorate([
874
- n({ type: Boolean, reflect: true })
875
- ], MenuItem.prototype, "disabled", void 0);
876
- __decorate([
877
- n({ type: String })
878
- ], MenuItem.prototype, "value", void 0);
879
- __decorate([
880
- n({ type: Boolean })
881
- ], MenuItem.prototype, "selected", void 0);
882
- __decorate([
883
- n({ reflect: true })
884
- ], MenuItem.prototype, "href", void 0);
885
- __decorate([
886
- n()
887
- ], MenuItem.prototype, "target", void 0);
888
- __decorate([
889
- n({ type: String, reflect: true })
890
- ], MenuItem.prototype, "variant", void 0);
891
- __decorate([
892
- e('.menu-item')
893
- ], MenuItem.prototype, "menuItemElement", void 0);
894
-
895
- var css_248z = i`* {
896
- box-sizing: border-box;
897
- }
898
-
899
- .screen-reader-only {
900
- display: none !important;
901
- }
902
-
903
- .menu-list {
904
- display: flex;
905
- position: relative;
906
- min-width: 112px;
907
- padding-block: var(--spacing-050);
908
- }
909
- .menu-list .menu-list-content {
910
- display: flex;
911
- flex-direction: column;
912
- gap: var(--spacing-050);
913
- z-index: 1;
914
- width: 100%;
915
- }
916
- .menu-list .menu-list-content ::slotted(:first-child) {
917
- --menu-item-container-shape-start-start: var(--shape-corner-medium);
918
- --menu-item-container-shape-start-end: var(--shape-corner-medium);
919
- }
920
- .menu-list .menu-list-content ::slotted(:last-child) {
921
- --menu-item-container-shape-end-start: var(--shape-corner-medium);
922
- --menu-item-container-shape-end-end: var(--shape-corner-medium);
923
- }
924
- .menu-list .menu-list-content ::slotted(base-divider) {
925
- --divider-spacing: var(--spacing-100);
926
- padding-inline: var(--spacing-050);
927
- }
928
- .menu-list .background {
929
- display: block;
930
- position: absolute;
931
- left: 0;
932
- top: 0;
933
- width: 100%;
934
- height: 100%;
935
- background-color: var(--_container-color);
936
- opacity: var(--_container-opacity, 1);
937
- border-start-start-radius: var(--_container-shape-start-start);
938
- border-start-end-radius: var(--_container-shape-start-end);
939
- border-end-start-radius: var(--_container-shape-end-start);
940
- border-end-end-radius: var(--_container-shape-end-end);
941
- pointer-events: none;
942
- }
943
- .menu-list .elevation {
944
- --elevation-level: 2;
945
- transition-duration: 280ms;
946
- --elevation-container-shape-start-start: var(--_container-shape-start-start);
947
- --elevation-container-shape-start-end: var(--_container-shape-start-end);
948
- --elevation-container-shape-end-start: var(--_container-shape-end-start);
949
- --elevation-container-shape-end-end: var(--_container-shape-end-end);
950
- --elevation-container-shape-variant: var(--_container-corner-shape-variant);
951
- }
952
-
953
- .menu-list {
954
- --_container-shape-start-start: var(--shape-corner-large);
955
- --_container-shape-start-end: var(--shape-corner-large);
956
- --_container-shape-end-start: var(--shape-corner-large);
957
- --_container-shape-end-end: var(--shape-corner-large);
958
- }
959
- .menu-list.variant-standard {
960
- --_container-color: var(--color-surface-container);
961
- }
962
- .menu-list.variant-vibrant {
963
- --_container-color: var(--color-tertiary-container);
964
- }`;
965
-
966
- /**
967
- * @label Menu List
968
- * @tag wc-menu-list
969
- * @rawTag menu-list
970
- * @summary A list of menu items.
971
- * @tags navigation
972
- *
973
- * @example
974
- * ```html
975
- * <wc-menu-list>
976
- * <wc-menu-item>Item 1</wc-menu-item>
977
- * <wc-menu-item>Item 2</wc-menu-item>
978
- * </wc-menu-list>
979
- * ```
980
- */
981
- class MenuList extends i$1 {
982
- constructor() {
983
- super(...arguments);
984
- this.variant = 'standard';
985
- }
986
- connectedCallback() {
987
- // eslint-disable-next-line wc/guard-super-call
988
- super.connectedCallback();
989
- this.setAttribute('role', 'menu');
990
- }
991
- render() {
992
- return b `<div
993
- class=${e$1({
994
- 'menu-list': true,
995
- [`variant-${this.variant}`]: true,
996
- })}
997
- >
998
- <div class="background"></div>
999
- <wc-elevation class="elevation"></wc-elevation>
1000
-
1001
- <div class="menu-list-content">
1002
- <slot></slot>
1003
- </div>
1004
- </div>`;
1005
- }
1006
- }
1007
- MenuList.styles = [css_248z];
1008
- __decorate([
1009
- n({ type: String, reflect: true })
1010
- ], MenuList.prototype, "variant", void 0);
1011
-
1012
530
  class LoaderUtils {
1013
531
  constructor(loaderConfig) {
1014
532
  this._loaderConfig = loaderConfig;
@@ -1182,7 +700,7 @@ const loaderConfig = {
1182
700
  CustomElementClass: TabGroup,
1183
701
  },
1184
702
  'wc-tab': {
1185
- CustomElementClass: Tab
703
+ CustomElementClass: Tab,
1186
704
  },
1187
705
  'wc-tab-panel': {
1188
706
  CustomElementClass: TabPanel,
@@ -1253,30 +771,42 @@ const loaderConfig = {
1253
771
  'wc-empty-state': {
1254
772
  CustomElementClass: EmptyState,
1255
773
  },
1256
- 'wc-base-menu': {
774
+ 'wc-menu': {
1257
775
  CustomElementClass: Menu,
1258
776
  },
1259
777
  'wc-menu-item': {
1260
778
  CustomElementClass: MenuItem,
1261
779
  },
1262
- 'wc-menu-list': {
1263
- CustomElementClass: MenuList,
780
+ 'wc-sub-menu': {
781
+ CustomElementClass: SubMenu,
1264
782
  },
1265
783
  'wc-container': {
1266
- CustomElementClass: Container
784
+ CustomElementClass: Container,
1267
785
  },
1268
786
  'wc-image': {
1269
- CustomElementClass: Image
787
+ CustomElementClass: Image,
1270
788
  },
1271
789
  'wc-slider': {
1272
- CustomElementClass: Slider
790
+ CustomElementClass: Slider,
791
+ },
792
+ 'wc-table': {
793
+ CustomElementClass: Table,
794
+ },
795
+ 'wc-pagination': {
796
+ CustomElementClass: Pagination,
797
+ },
798
+ 'wc-tree-view': {
799
+ CustomElementClass: TreeView,
800
+ },
801
+ 'wc-tree-node': {
802
+ CustomElementClass: TreeView.Node,
1273
803
  },
1274
804
  'wc-chart-doughnut': {
1275
805
  importPath: `${distDirectory}/chart-doughnut.js`,
1276
806
  },
1277
807
  'wc-chart-pie': {
1278
808
  importPath: `${distDirectory}/chart-pie.js`,
1279
- }
809
+ },
1280
810
  },
1281
811
  };
1282
812
  new LoaderUtils(loaderConfig).start();