@aurodesignsystem/auro-formkit 2.1.0-beta.2 → 2.1.0-beta.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.
Files changed (48) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/components/checkbox/README.md +1 -1
  3. package/components/checkbox/demo/readme.md +1 -1
  4. package/components/combobox/README.md +1 -1
  5. package/components/combobox/demo/api.min.js +50 -8
  6. package/components/combobox/demo/index.min.js +50 -8
  7. package/components/combobox/demo/readme.md +1 -1
  8. package/components/combobox/dist/index.js +50 -8
  9. package/components/combobox/dist/registered.js +50 -8
  10. package/components/counter/README.md +1 -1
  11. package/components/counter/demo/api.min.js +50 -8
  12. package/components/counter/demo/index.min.js +50 -8
  13. package/components/counter/demo/readme.md +1 -1
  14. package/components/counter/dist/index.js +50 -8
  15. package/components/counter/dist/registered.js +50 -8
  16. package/components/datepicker/README.md +1 -1
  17. package/components/datepicker/demo/api.md +4 -0
  18. package/components/datepicker/demo/api.min.js +86 -19
  19. package/components/datepicker/demo/index.min.js +86 -19
  20. package/components/datepicker/demo/readme.md +1 -1
  21. package/components/datepicker/dist/index.js +86 -19
  22. package/components/datepicker/dist/registered.js +86 -19
  23. package/components/datepicker/dist/utilities.d.ts +7 -0
  24. package/components/dropdown/README.md +1 -1
  25. package/components/dropdown/demo/api.md +1 -1
  26. package/components/dropdown/demo/api.min.js +50 -8
  27. package/components/dropdown/demo/index.min.js +50 -8
  28. package/components/dropdown/demo/readme.md +1 -1
  29. package/components/dropdown/dist/auro-dropdown.d.ts +17 -1
  30. package/components/dropdown/dist/index.js +50 -8
  31. package/components/dropdown/dist/registered.js +50 -8
  32. package/components/form/README.md +1 -1
  33. package/components/form/demo/readme.md +1 -1
  34. package/components/input/README.md +1 -1
  35. package/components/input/demo/readme.md +1 -1
  36. package/components/menu/README.md +1 -1
  37. package/components/menu/demo/readme.md +1 -1
  38. package/components/radio/README.md +1 -1
  39. package/components/radio/demo/readme.md +1 -1
  40. package/components/select/README.md +2 -1
  41. package/components/select/demo/api.md +22 -0
  42. package/components/select/demo/api.min.js +50 -8
  43. package/components/select/demo/index.md +14 -0
  44. package/components/select/demo/index.min.js +50 -8
  45. package/components/select/demo/readme.md +2 -1
  46. package/components/select/dist/index.js +50 -8
  47. package/components/select/dist/registered.js +50 -8
  48. package/package.json +3 -3
@@ -3127,7 +3127,7 @@ class AuroDropdownBib extends r {
3127
3127
 
3128
3128
  var dropdownVersion$1 = '3.0.0';
3129
3129
 
3130
- var styleCss$1$2 = i$5`:host{position:relative;display:inline-block;max-width:100%}:host([fluid]){display:block}#bibSizer{position:absolute;z-index:-1;opacity:0;pointer-events:none}.label{font-size:var(--ds-text-body-size-xs, 0.75rem);line-height:var(--ds-text-body-size-default, 1rem);transition:font-size .3s cubic-bezier(0.215, 0.61, 0.355, 1);white-space:normal}.label[hasTrigger=false]{font-size:var(--ds-text-body-size-default, 1rem)}.trigger{position:relative;display:flex;align-items:center}.trigger[showBorder]{border-width:1px;border-style:solid;cursor:pointer;outline-style:solid;outline-width:1px}@media(hover: hover){.trigger:hover{cursor:pointer}}.triggerContentWrapper{overflow:hidden;flex:1;text-overflow:ellipsis;white-space:nowrap}#showStateIcon{display:flex;overflow:hidden;height:100%;align-items:center;margin-left:var(--ds-size-100, 0.5rem)}#showStateIcon [auro-icon]{height:var(--ds-size-300, 1.5rem);line-height:var(--ds-size-300, 1.5rem)}#showStateIcon[data-expanded=true] [auro-icon]{transform:rotate(-180deg)}:host([matchwidth]) #bibSizer{width:100%}:host([disabled]){pointer-events:none}:host([inset]) .trigger{padding:var(--ds-size-150, 0.75rem) var(--ds-size-200, 1rem)}:host([common]) .trigger,:host([inset][bordered]) .trigger{padding:var(--ds-size-200, 1rem) var(--ds-size-150, 0.75rem)}:host([common]) .trigger,:host([rounded]) .trigger{border-radius:var(--ds-border-radius, 0.375rem)}`;
3130
+ var styleCss$1$2 = i$5`:host{position:relative;display:inline-block;max-width:100%}:host([fluid]){display:block}#bibSizer{position:absolute;z-index:-1;opacity:0;pointer-events:none}.label{font-size:var(--ds-text-body-size-xs, 0.75rem);line-height:var(--ds-text-body-size-default, 1rem);transition:font-size .3s cubic-bezier(0.215, 0.61, 0.355, 1);white-space:normal}.label[hasTrigger=false]{font-size:var(--ds-text-body-size-default, 1rem)}.trigger{position:relative;display:flex;align-items:center}.trigger[showBorder]{border-width:1px;border-style:solid;cursor:pointer;outline-style:solid;outline-width:1px}@media(hover: hover){.trigger:hover{cursor:pointer}}.triggerContentWrapper{overflow:hidden;flex:1;text-overflow:ellipsis;white-space:nowrap}#showStateIcon{display:flex;overflow:hidden;height:100%;align-items:center;margin-left:var(--ds-size-100, 0.5rem)}#showStateIcon [auro-icon]{height:var(--ds-size-300, 1.5rem);line-height:var(--ds-size-300, 1.5rem)}#showStateIcon[data-expanded=true] [auro-icon]{transform:rotate(-180deg)}:host([matchwidth]) #bibSizer{width:100%}:host([disabled]){pointer-events:none}:host([inset]) .trigger{padding:var(--ds-size-150, 0.75rem) var(--ds-size-200, 1rem)}:host([common]) .trigger,:host([inset][bordered]) .trigger{padding:var(--ds-size-200, 1rem) var(--ds-size-150, 0.75rem)}:host([inset][bordered][labeled]) .trigger{padding:var(--ds-size-100, 0.5rem) var(--ds-size-150, 0.75rem)}:host([common]) .trigger,:host([rounded]) .trigger{border-radius:var(--ds-border-radius, 0.375rem)}`;
3131
3131
 
3132
3132
  var colorCss$1$2 = i$5`.label{color:var(--ds-auro-dropdown-label-text-color)}.trigger{border-color:var(--ds-auro-dropdown-trigger-border-color);background-color:var(--ds-auro-dropdown-trigger-container-color);color:var(--ds-auro-dropdown-trigger-text-color);outline-color:var(--ds-auro-dropdown-trigger-outline-color)}.trigger:focus-within,.trigger:active{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-active-default, #0074c8);--ds-auro-dropdown-trigger-outline-color: var(--ds-color-border-active-default, #0074c8)}.trigger:focus-within:not(:active){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-focus-default, #2c67b5);--ds-auro-dropdown-trigger-outline-color: var(--ds-color-border-ui-focus-default, #2c67b5)}.trigger:hover{--ds-auro-dropdown-trigger-container-color: var(--ds-color-container-ui-secondary-hover-default, rgba(0, 0, 0, 0.03))}:host([disabled]){--ds-auro-dropdown-trigger-text-color: var(--ds-color-text-ui-disabled-default, #adadad);--ds-auro-dropdown-label-text-color: var(--ds-color-text-ui-disabled-default, #adadad)}:host([common]),:host([bordered]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-primary-default, #585e67)}:host([common]) .trigger:active,:host([common]) .trigger:focus-within,:host([bordered]) .trigger:active,:host([bordered]) .trigger:focus-within{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-focus-default, #2c67b5)}:host([error]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-error-default, #cc1816)}:host([error]) .trigger{outline:solid 1px var(--ds-auro-dropdown-trigger-border-color)}:host([error]) .trigger:focus-within,:host([error]) .trigger:active{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-active-default, #0074c8)}:host([error]) .trigger:active{box-shadow:none;outline:none}:host([disabled][common]),:host([disabled][bordered]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-disabled-default, #adadad)}`;
3133
3133
 
@@ -3391,6 +3391,7 @@ class AuroDropdown extends r {
3391
3391
  this.rounded = false;
3392
3392
  this.tabIndex = 0;
3393
3393
  this.noToggle = false;
3394
+ this.labeled = true;
3394
3395
 
3395
3396
  /**
3396
3397
  * @private
@@ -3543,7 +3544,7 @@ class AuroDropdown extends r {
3543
3544
  },
3544
3545
 
3545
3546
  /**
3546
- * If true, the dropdown bib is taking the fullscreen when it's open
3547
+ * If true, the dropdown bib is taking the fullscreen when it's open.
3547
3548
  */
3548
3549
  isBibFullscreen: {
3549
3550
  type: Boolean,
@@ -3573,6 +3574,15 @@ class AuroDropdown extends r {
3573
3574
  reflect: true
3574
3575
  },
3575
3576
 
3577
+ /**
3578
+ * Defines if there is a label preset.
3579
+ * @private
3580
+ */
3581
+ labeled: {
3582
+ type: Boolean,
3583
+ reflect: true
3584
+ },
3585
+
3576
3586
  /**
3577
3587
  * If declared, the popover and trigger will be set to the same width.
3578
3588
  */
@@ -3652,6 +3662,7 @@ class AuroDropdown extends r {
3652
3662
 
3653
3663
  disconnectedCallback() {
3654
3664
  super.disconnectedCallback();
3665
+ this.floater.disconnect();
3655
3666
  }
3656
3667
 
3657
3668
  updated(changedProperties) {
@@ -3781,13 +3792,21 @@ class AuroDropdown extends r {
3781
3792
  handleTriggerContentSlotChange(event) {
3782
3793
  this.floater.handleTriggerTabIndex();
3783
3794
 
3784
- const triggerContentNodes = this.shadowRoot.querySelector('.triggerContent slot').assignedNodes();
3795
+ const triggerSlot = this.shadowRoot.querySelector('.triggerContent slot');
3785
3796
 
3786
- triggerContentNodes.forEach((node) => {
3787
- if (!this.triggerContentFocusable) {
3788
- this.triggerContentFocusable = this.containsFocusableElement(node);
3797
+ if (triggerSlot) {
3798
+
3799
+ const triggerContentNodes = triggerSlot.assignedNodes();
3800
+
3801
+ if (triggerContentNodes) {
3802
+
3803
+ triggerContentNodes.forEach((node) => {
3804
+ if (!this.triggerContentFocusable) {
3805
+ this.triggerContentFocusable = this.containsFocusableElement(node);
3806
+ }
3807
+ });
3789
3808
  }
3790
- });
3809
+ }
3791
3810
 
3792
3811
  const trigger = this.shadowRoot.querySelector('#trigger');
3793
3812
 
@@ -3841,6 +3860,29 @@ class AuroDropdown extends r {
3841
3860
  }
3842
3861
  }
3843
3862
 
3863
+ /**
3864
+ * @private
3865
+ * @method handleLabelSlotChange
3866
+ * @param {event} event - The event object representing the slot change.
3867
+ * @description Handles the slot change event for the label slot.
3868
+ */
3869
+ handleLabelSlotChange (event) {
3870
+
3871
+ // Get the nodes from the event
3872
+ const nodes = event.target.assignedNodes();
3873
+
3874
+ // Guard clause for no nodes
3875
+ if (!nodes) {
3876
+ return;
3877
+ }
3878
+
3879
+ // Convert the nodes to a measurable array so we can get the length
3880
+ const nodesArr = Array.from(nodes);
3881
+
3882
+ // If the nodes array has a length, the dropdown is labeled
3883
+ this.labeled = nodesArr.length > 0;
3884
+ }
3885
+
3844
3886
  // function that renders the HTML and CSS into the scope of the component
3845
3887
  render() {
3846
3888
  return u`
@@ -3855,7 +3897,7 @@ class AuroDropdown extends r {
3855
3897
  >
3856
3898
  <div class="triggerContentWrapper">
3857
3899
  <label class="label" id="triggerLabel" hasTrigger=${this.hasTriggerContent}>
3858
- <slot name="label"></slot>
3900
+ <slot name="label" @slotchange="${this.handleLabelSlotChange}"></slot>
3859
3901
  </label>
3860
3902
  <div class="triggerContent">
3861
3903
  <slot
@@ -85,6 +85,7 @@ This configuration enables proper module resolution for the component's TypeScri
85
85
  ```html
86
86
  <auro-select>
87
87
  <span slot="bib.fullscreen.headline">Bib Headline</span>
88
+ <span slot="label">Select Example</span>
88
89
  <auro-menu>
89
90
  <auro-menuoption value="stops">Stops</auro-menuoption>
90
91
  <auro-menuoption value="price">Price</auro-menuoption>
@@ -110,7 +111,7 @@ The use of any Auro custom element has a dependency on the [Auro Design Tokens](
110
111
  In cases where the project is not able to process JS assets, there are pre-processed assets available for use. Legacy browsers such as IE11 are no longer supported.
111
112
 
112
113
  ```html
113
- <script type="module "src="https://cdn.jsdelivr.net/npm/@aurodesignsystem/auro-formkit@2.1.0-beta.1/auro-select/+esm"></script>
114
+ <script type="module "src="https://cdn.jsdelivr.net/npm/@aurodesignsystem/auro-formkit@2.1.0-beta.3/auro-select/+esm"></script>
114
115
  ```
115
116
  <!-- AURO-GENERATED-CONTENT:END -->
116
117
 
@@ -3080,7 +3080,7 @@ class AuroDropdownBib extends LitElement {
3080
3080
 
3081
3081
  var dropdownVersion$1 = '3.0.0';
3082
3082
 
3083
- var styleCss$1$1 = css`:host{position:relative;display:inline-block;max-width:100%}:host([fluid]){display:block}#bibSizer{position:absolute;z-index:-1;opacity:0;pointer-events:none}.label{font-size:var(--ds-text-body-size-xs, 0.75rem);line-height:var(--ds-text-body-size-default, 1rem);transition:font-size .3s cubic-bezier(0.215, 0.61, 0.355, 1);white-space:normal}.label[hasTrigger=false]{font-size:var(--ds-text-body-size-default, 1rem)}.trigger{position:relative;display:flex;align-items:center}.trigger[showBorder]{border-width:1px;border-style:solid;cursor:pointer;outline-style:solid;outline-width:1px}@media(hover: hover){.trigger:hover{cursor:pointer}}.triggerContentWrapper{overflow:hidden;flex:1;text-overflow:ellipsis;white-space:nowrap}#showStateIcon{display:flex;overflow:hidden;height:100%;align-items:center;margin-left:var(--ds-size-100, 0.5rem)}#showStateIcon [auro-icon]{height:var(--ds-size-300, 1.5rem);line-height:var(--ds-size-300, 1.5rem)}#showStateIcon[data-expanded=true] [auro-icon]{transform:rotate(-180deg)}:host([matchwidth]) #bibSizer{width:100%}:host([disabled]){pointer-events:none}:host([inset]) .trigger{padding:var(--ds-size-150, 0.75rem) var(--ds-size-200, 1rem)}:host([common]) .trigger,:host([inset][bordered]) .trigger{padding:var(--ds-size-200, 1rem) var(--ds-size-150, 0.75rem)}:host([common]) .trigger,:host([rounded]) .trigger{border-radius:var(--ds-border-radius, 0.375rem)}`;
3083
+ var styleCss$1$1 = css`:host{position:relative;display:inline-block;max-width:100%}:host([fluid]){display:block}#bibSizer{position:absolute;z-index:-1;opacity:0;pointer-events:none}.label{font-size:var(--ds-text-body-size-xs, 0.75rem);line-height:var(--ds-text-body-size-default, 1rem);transition:font-size .3s cubic-bezier(0.215, 0.61, 0.355, 1);white-space:normal}.label[hasTrigger=false]{font-size:var(--ds-text-body-size-default, 1rem)}.trigger{position:relative;display:flex;align-items:center}.trigger[showBorder]{border-width:1px;border-style:solid;cursor:pointer;outline-style:solid;outline-width:1px}@media(hover: hover){.trigger:hover{cursor:pointer}}.triggerContentWrapper{overflow:hidden;flex:1;text-overflow:ellipsis;white-space:nowrap}#showStateIcon{display:flex;overflow:hidden;height:100%;align-items:center;margin-left:var(--ds-size-100, 0.5rem)}#showStateIcon [auro-icon]{height:var(--ds-size-300, 1.5rem);line-height:var(--ds-size-300, 1.5rem)}#showStateIcon[data-expanded=true] [auro-icon]{transform:rotate(-180deg)}:host([matchwidth]) #bibSizer{width:100%}:host([disabled]){pointer-events:none}:host([inset]) .trigger{padding:var(--ds-size-150, 0.75rem) var(--ds-size-200, 1rem)}:host([common]) .trigger,:host([inset][bordered]) .trigger{padding:var(--ds-size-200, 1rem) var(--ds-size-150, 0.75rem)}:host([inset][bordered][labeled]) .trigger{padding:var(--ds-size-100, 0.5rem) var(--ds-size-150, 0.75rem)}:host([common]) .trigger,:host([rounded]) .trigger{border-radius:var(--ds-border-radius, 0.375rem)}`;
3084
3084
 
3085
3085
  var colorCss$1$1 = css`.label{color:var(--ds-auro-dropdown-label-text-color)}.trigger{border-color:var(--ds-auro-dropdown-trigger-border-color);background-color:var(--ds-auro-dropdown-trigger-container-color);color:var(--ds-auro-dropdown-trigger-text-color);outline-color:var(--ds-auro-dropdown-trigger-outline-color)}.trigger:focus-within,.trigger:active{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-active-default, #0074c8);--ds-auro-dropdown-trigger-outline-color: var(--ds-color-border-active-default, #0074c8)}.trigger:focus-within:not(:active){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-focus-default, #2c67b5);--ds-auro-dropdown-trigger-outline-color: var(--ds-color-border-ui-focus-default, #2c67b5)}.trigger:hover{--ds-auro-dropdown-trigger-container-color: var(--ds-color-container-ui-secondary-hover-default, rgba(0, 0, 0, 0.03))}:host([disabled]){--ds-auro-dropdown-trigger-text-color: var(--ds-color-text-ui-disabled-default, #adadad);--ds-auro-dropdown-label-text-color: var(--ds-color-text-ui-disabled-default, #adadad)}:host([common]),:host([bordered]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-primary-default, #585e67)}:host([common]) .trigger:active,:host([common]) .trigger:focus-within,:host([bordered]) .trigger:active,:host([bordered]) .trigger:focus-within{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-focus-default, #2c67b5)}:host([error]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-error-default, #cc1816)}:host([error]) .trigger{outline:solid 1px var(--ds-auro-dropdown-trigger-border-color)}:host([error]) .trigger:focus-within,:host([error]) .trigger:active{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-active-default, #0074c8)}:host([error]) .trigger:active{box-shadow:none;outline:none}:host([disabled][common]),:host([disabled][bordered]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-disabled-default, #adadad)}`;
3086
3086
 
@@ -3344,6 +3344,7 @@ class AuroDropdown extends LitElement {
3344
3344
  this.rounded = false;
3345
3345
  this.tabIndex = 0;
3346
3346
  this.noToggle = false;
3347
+ this.labeled = true;
3347
3348
 
3348
3349
  /**
3349
3350
  * @private
@@ -3496,7 +3497,7 @@ class AuroDropdown extends LitElement {
3496
3497
  },
3497
3498
 
3498
3499
  /**
3499
- * If true, the dropdown bib is taking the fullscreen when it's open
3500
+ * If true, the dropdown bib is taking the fullscreen when it's open.
3500
3501
  */
3501
3502
  isBibFullscreen: {
3502
3503
  type: Boolean,
@@ -3526,6 +3527,15 @@ class AuroDropdown extends LitElement {
3526
3527
  reflect: true
3527
3528
  },
3528
3529
 
3530
+ /**
3531
+ * Defines if there is a label preset.
3532
+ * @private
3533
+ */
3534
+ labeled: {
3535
+ type: Boolean,
3536
+ reflect: true
3537
+ },
3538
+
3529
3539
  /**
3530
3540
  * If declared, the popover and trigger will be set to the same width.
3531
3541
  */
@@ -3605,6 +3615,7 @@ class AuroDropdown extends LitElement {
3605
3615
 
3606
3616
  disconnectedCallback() {
3607
3617
  super.disconnectedCallback();
3618
+ this.floater.disconnect();
3608
3619
  }
3609
3620
 
3610
3621
  updated(changedProperties) {
@@ -3734,13 +3745,21 @@ class AuroDropdown extends LitElement {
3734
3745
  handleTriggerContentSlotChange(event) {
3735
3746
  this.floater.handleTriggerTabIndex();
3736
3747
 
3737
- const triggerContentNodes = this.shadowRoot.querySelector('.triggerContent slot').assignedNodes();
3748
+ const triggerSlot = this.shadowRoot.querySelector('.triggerContent slot');
3738
3749
 
3739
- triggerContentNodes.forEach((node) => {
3740
- if (!this.triggerContentFocusable) {
3741
- this.triggerContentFocusable = this.containsFocusableElement(node);
3750
+ if (triggerSlot) {
3751
+
3752
+ const triggerContentNodes = triggerSlot.assignedNodes();
3753
+
3754
+ if (triggerContentNodes) {
3755
+
3756
+ triggerContentNodes.forEach((node) => {
3757
+ if (!this.triggerContentFocusable) {
3758
+ this.triggerContentFocusable = this.containsFocusableElement(node);
3759
+ }
3760
+ });
3742
3761
  }
3743
- });
3762
+ }
3744
3763
 
3745
3764
  const trigger = this.shadowRoot.querySelector('#trigger');
3746
3765
 
@@ -3794,6 +3813,29 @@ class AuroDropdown extends LitElement {
3794
3813
  }
3795
3814
  }
3796
3815
 
3816
+ /**
3817
+ * @private
3818
+ * @method handleLabelSlotChange
3819
+ * @param {event} event - The event object representing the slot change.
3820
+ * @description Handles the slot change event for the label slot.
3821
+ */
3822
+ handleLabelSlotChange (event) {
3823
+
3824
+ // Get the nodes from the event
3825
+ const nodes = event.target.assignedNodes();
3826
+
3827
+ // Guard clause for no nodes
3828
+ if (!nodes) {
3829
+ return;
3830
+ }
3831
+
3832
+ // Convert the nodes to a measurable array so we can get the length
3833
+ const nodesArr = Array.from(nodes);
3834
+
3835
+ // If the nodes array has a length, the dropdown is labeled
3836
+ this.labeled = nodesArr.length > 0;
3837
+ }
3838
+
3797
3839
  // function that renders the HTML and CSS into the scope of the component
3798
3840
  render() {
3799
3841
  return html`
@@ -3808,7 +3850,7 @@ class AuroDropdown extends LitElement {
3808
3850
  >
3809
3851
  <div class="triggerContentWrapper">
3810
3852
  <label class="label" id="triggerLabel" hasTrigger=${this.hasTriggerContent}>
3811
- <slot name="label"></slot>
3853
+ <slot name="label" @slotchange="${this.handleLabelSlotChange}"></slot>
3812
3854
  </label>
3813
3855
  <div class="triggerContent">
3814
3856
  <slot
@@ -3080,7 +3080,7 @@ class AuroDropdownBib extends LitElement {
3080
3080
 
3081
3081
  var dropdownVersion$1 = '3.0.0';
3082
3082
 
3083
- var styleCss$1$1 = css`:host{position:relative;display:inline-block;max-width:100%}:host([fluid]){display:block}#bibSizer{position:absolute;z-index:-1;opacity:0;pointer-events:none}.label{font-size:var(--ds-text-body-size-xs, 0.75rem);line-height:var(--ds-text-body-size-default, 1rem);transition:font-size .3s cubic-bezier(0.215, 0.61, 0.355, 1);white-space:normal}.label[hasTrigger=false]{font-size:var(--ds-text-body-size-default, 1rem)}.trigger{position:relative;display:flex;align-items:center}.trigger[showBorder]{border-width:1px;border-style:solid;cursor:pointer;outline-style:solid;outline-width:1px}@media(hover: hover){.trigger:hover{cursor:pointer}}.triggerContentWrapper{overflow:hidden;flex:1;text-overflow:ellipsis;white-space:nowrap}#showStateIcon{display:flex;overflow:hidden;height:100%;align-items:center;margin-left:var(--ds-size-100, 0.5rem)}#showStateIcon [auro-icon]{height:var(--ds-size-300, 1.5rem);line-height:var(--ds-size-300, 1.5rem)}#showStateIcon[data-expanded=true] [auro-icon]{transform:rotate(-180deg)}:host([matchwidth]) #bibSizer{width:100%}:host([disabled]){pointer-events:none}:host([inset]) .trigger{padding:var(--ds-size-150, 0.75rem) var(--ds-size-200, 1rem)}:host([common]) .trigger,:host([inset][bordered]) .trigger{padding:var(--ds-size-200, 1rem) var(--ds-size-150, 0.75rem)}:host([common]) .trigger,:host([rounded]) .trigger{border-radius:var(--ds-border-radius, 0.375rem)}`;
3083
+ var styleCss$1$1 = css`:host{position:relative;display:inline-block;max-width:100%}:host([fluid]){display:block}#bibSizer{position:absolute;z-index:-1;opacity:0;pointer-events:none}.label{font-size:var(--ds-text-body-size-xs, 0.75rem);line-height:var(--ds-text-body-size-default, 1rem);transition:font-size .3s cubic-bezier(0.215, 0.61, 0.355, 1);white-space:normal}.label[hasTrigger=false]{font-size:var(--ds-text-body-size-default, 1rem)}.trigger{position:relative;display:flex;align-items:center}.trigger[showBorder]{border-width:1px;border-style:solid;cursor:pointer;outline-style:solid;outline-width:1px}@media(hover: hover){.trigger:hover{cursor:pointer}}.triggerContentWrapper{overflow:hidden;flex:1;text-overflow:ellipsis;white-space:nowrap}#showStateIcon{display:flex;overflow:hidden;height:100%;align-items:center;margin-left:var(--ds-size-100, 0.5rem)}#showStateIcon [auro-icon]{height:var(--ds-size-300, 1.5rem);line-height:var(--ds-size-300, 1.5rem)}#showStateIcon[data-expanded=true] [auro-icon]{transform:rotate(-180deg)}:host([matchwidth]) #bibSizer{width:100%}:host([disabled]){pointer-events:none}:host([inset]) .trigger{padding:var(--ds-size-150, 0.75rem) var(--ds-size-200, 1rem)}:host([common]) .trigger,:host([inset][bordered]) .trigger{padding:var(--ds-size-200, 1rem) var(--ds-size-150, 0.75rem)}:host([inset][bordered][labeled]) .trigger{padding:var(--ds-size-100, 0.5rem) var(--ds-size-150, 0.75rem)}:host([common]) .trigger,:host([rounded]) .trigger{border-radius:var(--ds-border-radius, 0.375rem)}`;
3084
3084
 
3085
3085
  var colorCss$1$1 = css`.label{color:var(--ds-auro-dropdown-label-text-color)}.trigger{border-color:var(--ds-auro-dropdown-trigger-border-color);background-color:var(--ds-auro-dropdown-trigger-container-color);color:var(--ds-auro-dropdown-trigger-text-color);outline-color:var(--ds-auro-dropdown-trigger-outline-color)}.trigger:focus-within,.trigger:active{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-active-default, #0074c8);--ds-auro-dropdown-trigger-outline-color: var(--ds-color-border-active-default, #0074c8)}.trigger:focus-within:not(:active){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-focus-default, #2c67b5);--ds-auro-dropdown-trigger-outline-color: var(--ds-color-border-ui-focus-default, #2c67b5)}.trigger:hover{--ds-auro-dropdown-trigger-container-color: var(--ds-color-container-ui-secondary-hover-default, rgba(0, 0, 0, 0.03))}:host([disabled]){--ds-auro-dropdown-trigger-text-color: var(--ds-color-text-ui-disabled-default, #adadad);--ds-auro-dropdown-label-text-color: var(--ds-color-text-ui-disabled-default, #adadad)}:host([common]),:host([bordered]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-primary-default, #585e67)}:host([common]) .trigger:active,:host([common]) .trigger:focus-within,:host([bordered]) .trigger:active,:host([bordered]) .trigger:focus-within{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-focus-default, #2c67b5)}:host([error]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-error-default, #cc1816)}:host([error]) .trigger{outline:solid 1px var(--ds-auro-dropdown-trigger-border-color)}:host([error]) .trigger:focus-within,:host([error]) .trigger:active{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-active-default, #0074c8)}:host([error]) .trigger:active{box-shadow:none;outline:none}:host([disabled][common]),:host([disabled][bordered]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-disabled-default, #adadad)}`;
3086
3086
 
@@ -3344,6 +3344,7 @@ class AuroDropdown extends LitElement {
3344
3344
  this.rounded = false;
3345
3345
  this.tabIndex = 0;
3346
3346
  this.noToggle = false;
3347
+ this.labeled = true;
3347
3348
 
3348
3349
  /**
3349
3350
  * @private
@@ -3496,7 +3497,7 @@ class AuroDropdown extends LitElement {
3496
3497
  },
3497
3498
 
3498
3499
  /**
3499
- * If true, the dropdown bib is taking the fullscreen when it's open
3500
+ * If true, the dropdown bib is taking the fullscreen when it's open.
3500
3501
  */
3501
3502
  isBibFullscreen: {
3502
3503
  type: Boolean,
@@ -3526,6 +3527,15 @@ class AuroDropdown extends LitElement {
3526
3527
  reflect: true
3527
3528
  },
3528
3529
 
3530
+ /**
3531
+ * Defines if there is a label preset.
3532
+ * @private
3533
+ */
3534
+ labeled: {
3535
+ type: Boolean,
3536
+ reflect: true
3537
+ },
3538
+
3529
3539
  /**
3530
3540
  * If declared, the popover and trigger will be set to the same width.
3531
3541
  */
@@ -3605,6 +3615,7 @@ class AuroDropdown extends LitElement {
3605
3615
 
3606
3616
  disconnectedCallback() {
3607
3617
  super.disconnectedCallback();
3618
+ this.floater.disconnect();
3608
3619
  }
3609
3620
 
3610
3621
  updated(changedProperties) {
@@ -3734,13 +3745,21 @@ class AuroDropdown extends LitElement {
3734
3745
  handleTriggerContentSlotChange(event) {
3735
3746
  this.floater.handleTriggerTabIndex();
3736
3747
 
3737
- const triggerContentNodes = this.shadowRoot.querySelector('.triggerContent slot').assignedNodes();
3748
+ const triggerSlot = this.shadowRoot.querySelector('.triggerContent slot');
3738
3749
 
3739
- triggerContentNodes.forEach((node) => {
3740
- if (!this.triggerContentFocusable) {
3741
- this.triggerContentFocusable = this.containsFocusableElement(node);
3750
+ if (triggerSlot) {
3751
+
3752
+ const triggerContentNodes = triggerSlot.assignedNodes();
3753
+
3754
+ if (triggerContentNodes) {
3755
+
3756
+ triggerContentNodes.forEach((node) => {
3757
+ if (!this.triggerContentFocusable) {
3758
+ this.triggerContentFocusable = this.containsFocusableElement(node);
3759
+ }
3760
+ });
3742
3761
  }
3743
- });
3762
+ }
3744
3763
 
3745
3764
  const trigger = this.shadowRoot.querySelector('#trigger');
3746
3765
 
@@ -3794,6 +3813,29 @@ class AuroDropdown extends LitElement {
3794
3813
  }
3795
3814
  }
3796
3815
 
3816
+ /**
3817
+ * @private
3818
+ * @method handleLabelSlotChange
3819
+ * @param {event} event - The event object representing the slot change.
3820
+ * @description Handles the slot change event for the label slot.
3821
+ */
3822
+ handleLabelSlotChange (event) {
3823
+
3824
+ // Get the nodes from the event
3825
+ const nodes = event.target.assignedNodes();
3826
+
3827
+ // Guard clause for no nodes
3828
+ if (!nodes) {
3829
+ return;
3830
+ }
3831
+
3832
+ // Convert the nodes to a measurable array so we can get the length
3833
+ const nodesArr = Array.from(nodes);
3834
+
3835
+ // If the nodes array has a length, the dropdown is labeled
3836
+ this.labeled = nodesArr.length > 0;
3837
+ }
3838
+
3797
3839
  // function that renders the HTML and CSS into the scope of the component
3798
3840
  render() {
3799
3841
  return html`
@@ -3808,7 +3850,7 @@ class AuroDropdown extends LitElement {
3808
3850
  >
3809
3851
  <div class="triggerContentWrapper">
3810
3852
  <label class="label" id="triggerLabel" hasTrigger=${this.hasTriggerContent}>
3811
- <slot name="label"></slot>
3853
+ <slot name="label" @slotchange="${this.handleLabelSlotChange}"></slot>
3812
3854
  </label>
3813
3855
  <div class="triggerContent">
3814
3856
  <slot
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aurodesignsystem/auro-formkit",
3
- "version": "2.1.0-beta.2",
3
+ "version": "2.1.0-beta.4",
4
4
  "description": "A collection of web components used to build forms.",
5
5
  "homepage": "https://github.com/AlaskaAirlines/auro-formkit#readme",
6
6
  "bugs": {
@@ -53,13 +53,13 @@
53
53
  },
54
54
  "dependencies": {
55
55
  "lit": "^3.2.1",
56
- "@lit/reactive-element": "^2.0.4"
56
+ "@lit/reactive-element": "^2.0.4",
57
+ "@aurodesignsystem/auro-library": "^3.0.13"
57
58
  },
58
59
  "optionalDependencies": {
59
60
  "@rollup/rollup-linux-x64-gnu": "*"
60
61
  },
61
62
  "devDependencies": {
62
- "@aurodesignsystem/auro-library": "^3.0.13",
63
63
  "@aurodesignsystem/eslint-config": "^1.3.3",
64
64
  "@commitlint/cli": "^19.6.1",
65
65
  "@commitlint/config-conventional": "^19.6.0",