@luzmo/lucero 0.0.16 → 0.0.17

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 (119) hide show
  1. package/components/NumberFormatter-DewVDY5w.cjs +18 -0
  2. package/components/NumberFormatter-DgOUVrge.js +136 -0
  3. package/components/NumberParser-Dik4a0h-.cjs +18 -0
  4. package/components/NumberParser-ci9J5EKv.js +173 -0
  5. package/components/accordion/index.cjs +1 -1
  6. package/components/accordion/index.js +2 -2
  7. package/components/action-bar/index.cjs +1 -1
  8. package/components/action-bar/index.js +2 -2
  9. package/components/action-button/index.cjs +1 -1
  10. package/components/action-button/index.js +2 -2
  11. package/components/action-group/index.js +1 -1
  12. package/components/action-menu/index.cjs +1 -1
  13. package/components/action-menu/index.js +3 -3
  14. package/components/avatar/index.js +1 -1
  15. package/components/button/index.cjs +1 -1
  16. package/components/button/index.js +3 -3
  17. package/components/button-group/index.js +1 -1
  18. package/components/calendar/calendar.d.ts +218 -0
  19. package/components/calendar/index.cjs +18 -0
  20. package/components/calendar/index.d.ts +7 -0
  21. package/components/calendar/index.js +28 -0
  22. package/components/checkbox/index.cjs +1 -1
  23. package/components/checkbox/index.js +2 -2
  24. package/components/class-map-Buyb1CLm.cjs +22 -0
  25. package/components/class-map-CJko4aXp.js +51 -0
  26. package/components/{close-button-DOA-6eL0.cjs → close-button-BQJ2wHkM.cjs} +1 -1
  27. package/components/{close-button-DU58NTKR.js → close-button-DN2cjFRq.js} +1 -1
  28. package/components/color-area/index.js +1 -1
  29. package/components/color-field/index.cjs +1 -1
  30. package/components/color-field/index.js +2 -2
  31. package/components/color-handle/index.js +1 -1
  32. package/components/color-loupe/index.js +1 -1
  33. package/components/color-menu/index.js +1 -1
  34. package/components/color-picker/index.js +1 -1
  35. package/components/color-slider/index.js +1 -1
  36. package/components/date-time-picker/date-time-picker.d.ts +269 -0
  37. package/components/date-time-picker/helpers.d.ts +10 -0
  38. package/components/date-time-picker/index.cjs +105 -0
  39. package/components/date-time-picker/index.d.ts +7 -0
  40. package/components/date-time-picker/index.js +1126 -0
  41. package/components/date-time-picker/segments/date/day-segment.d.ts +9 -0
  42. package/components/date-time-picker/segments/date/month-segment.d.ts +9 -0
  43. package/components/date-time-picker/segments/date/year-segment.d.ts +12 -0
  44. package/components/date-time-picker/segments/date-time-segments.d.ts +35 -0
  45. package/components/date-time-picker/segments/editable-segment.d.ts +21 -0
  46. package/components/date-time-picker/segments/literal-segment.d.ts +6 -0
  47. package/components/date-time-picker/segments/modifiers/clear-modifier.d.ts +5 -0
  48. package/components/date-time-picker/segments/modifiers/decrement-modifier.d.ts +5 -0
  49. package/components/date-time-picker/segments/modifiers/increment-modifier.d.ts +5 -0
  50. package/components/date-time-picker/segments/modifiers/input-modifier.d.ts +13 -0
  51. package/components/date-time-picker/segments/modifiers/segments-modifier.d.ts +18 -0
  52. package/components/date-time-picker/segments/segments-factory.d.ts +16 -0
  53. package/components/date-time-picker/segments/segments-formatter.d.ts +17 -0
  54. package/components/date-time-picker/segments/time/day-period-segment.d.ts +18 -0
  55. package/components/date-time-picker/segments/time/hour-segment.d.ts +19 -0
  56. package/components/date-time-picker/segments/time/millisecond-segment.d.ts +7 -0
  57. package/components/date-time-picker/segments/time/minute-segment.d.ts +7 -0
  58. package/components/date-time-picker/segments/time/second-segment.d.ts +7 -0
  59. package/components/date-time-picker/types.d.ts +41 -0
  60. package/components/divider/index.js +1 -1
  61. package/components/field-group/index.js +1 -1
  62. package/components/field-label/index.js +1 -1
  63. package/components/icon/index.cjs +1 -1
  64. package/components/icon/index.js +2 -2
  65. package/components/index-BziWAe4P.cjs +113 -0
  66. package/components/index-vWdA-LXe.js +1490 -0
  67. package/components/index.cjs +1 -1
  68. package/components/index.js +135 -129
  69. package/components/infield-button/index.cjs +1 -1
  70. package/components/infield-button/index.js +2 -2
  71. package/components/label/index.js +1 -1
  72. package/components/menu/index.cjs +66 -1
  73. package/components/menu/index.js +874 -10
  74. package/components/multi-language-field/index.js +1 -1
  75. package/components/number-field/index.cjs +6 -6
  76. package/components/number-field/index.js +128 -394
  77. package/components/observe-slot-presence-CmVi0zTc.js +68 -0
  78. package/components/observe-slot-presence-bc9chhsi.cjs +18 -0
  79. package/components/overlay/index.js +1 -1
  80. package/components/picker/index.cjs +1 -1
  81. package/components/picker/index.js +3 -3
  82. package/components/{picker-C9HmjRgR.js → picker-BxEG2NdV.js} +110 -138
  83. package/components/picker-DROquiIZ.cjs +123 -0
  84. package/components/picker-button/index.cjs +37 -0
  85. package/components/picker-button/index.d.ts +7 -0
  86. package/components/picker-button/index.js +87 -0
  87. package/components/picker-button/picker-button.d.ts +21 -0
  88. package/components/popover/index.js +1 -1
  89. package/components/progress-circle/index.js +1 -1
  90. package/components/radio/index.cjs +1 -1
  91. package/components/radio/index.js +2 -2
  92. package/components/search/index.cjs +1 -1
  93. package/components/search/index.js +3 -3
  94. package/components/slider/index.js +1 -1
  95. package/components/swatch/index.cjs +1 -1
  96. package/components/swatch/index.js +2 -2
  97. package/components/switch/index.cjs +1 -1
  98. package/components/switch/index.js +2 -2
  99. package/components/tags/index.cjs +1 -1
  100. package/components/tags/index.js +2 -2
  101. package/components/text-field/index.cjs +1 -1
  102. package/components/text-field/index.js +3 -3
  103. package/components/text-field-BTnBJoP9.js +314 -0
  104. package/components/text-field-mxJCYues.cjs +85 -0
  105. package/components/text-field.module-ColtFhf_.js +21 -0
  106. package/components/text-field.module-p_VF2tC_.cjs +18 -0
  107. package/components/toast/index.cjs +1 -1
  108. package/components/toast/index.js +3 -3
  109. package/components/tooltip/index.js +1 -1
  110. package/components/unit-input/index.cjs +1 -1
  111. package/components/unit-input/index.js +2 -2
  112. package/custom-elements.json +1 -1
  113. package/index.d.ts +3 -0
  114. package/package.json +16 -1
  115. package/components/index-4SZZSkew.cjs +0 -83
  116. package/components/index-AM-58E5r.js +0 -936
  117. package/components/picker-B05XA8I1.cjs +0 -127
  118. package/components/text-field-5_ev9way.cjs +0 -85
  119. package/components/text-field-CvKSS59x.js +0 -313
@@ -1,313 +0,0 @@
1
- /*! * Lucero - The design system for Luzmo.
2
- *
3
- * Copyright © 2025 Luzmo
4
- * All rights reserved.
5
- * Lucero (“Luzmo Design System”) must be used according to the Luzmo Terms of Service.
6
- * This license allows users with a current active Luzmo account to use Lucero.
7
- * This license terminates automatically if a user no longer has an active Luzmo account.
8
- * Please view the Luzmo Terms of Service at: https://www.luzmo.com/information-pages/terms-of-use.
9
- *
10
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
11
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
12
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
13
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
14
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
15
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
16
- * SOFTWARE.
17
- * */
18
- import { T as h, E as u, r as m, x as c, n as o } from "./base-CawdqE7p.js";
19
- import { r as x } from "./state-CYxk12SV.js";
20
- import { e as g } from "./query-D_KR_GUc.js";
21
- import { o as a } from "./if-defined-BSAr_4u4.js";
22
- import { e as b, i as z, t as s } from "./directive-oAbCiebi.js";
23
- import { f as y, m as k } from "./directive-helpers-nlQRAaQt.js";
24
- import { luzmoIcon as v, luzmoAlert as w, luzmoCheck as q } from "@luzmo/icons";
25
- import { F as $ } from "./focusable-cj2QhwDT.js";
26
- import { S as T } from "./sized-mixin-BxMraZLS.js";
27
- import { M as E } from "./manage-help-text-Cozl9Sgn.js";
28
- /**
29
- * @license
30
- * Copyright 2020 Google LLC
31
- * SPDX-License-Identifier: BSD-3-Clause
32
- */
33
- const _ = b(class extends z {
34
- constructor(l) {
35
- if (super(l), l.type !== s.PROPERTY && l.type !== s.ATTRIBUTE && l.type !== s.BOOLEAN_ATTRIBUTE) throw Error("The `live` directive is not allowed on child or event bindings");
36
- if (!y(l)) throw Error("`live` bindings can only contain a single expression");
37
- }
38
- render(l) {
39
- return l;
40
- }
41
- update(l, [e]) {
42
- if (e === h || e === u) return e;
43
- const r = l.element, n = l.name;
44
- if (l.type === s.PROPERTY) {
45
- if (e === r[n]) return h;
46
- } else if (l.type === s.BOOLEAN_ATTRIBUTE) {
47
- if (!!e === r.hasAttribute(n)) return h;
48
- } else if (l.type === s.ATTRIBUTE && r.getAttribute(n) === e + "") return h;
49
- return k(l), e;
50
- }
51
- }), S = '#text-field{--luzmo-text-field-input-line-height: var( --luzmo-text-field-height, var(--text-field-height) );text-overflow:ellipsis;inline-size:var(--luzmo-text-field-width, 240px);grid-template-rows:auto auto auto;grid-template-columns:auto auto;margin:0;display:inline-grid;position:relative;overflow:visible}:host([quiet]) #text-field:after{content:"";pointer-events:none;inline-size:100%;block-size:var(--luzmo-text-field-focus-indicator-width, 2px);position:absolute;inset-block-end:calc((var(--luzmo-text-field-focus-indicator-gap, 2px) + var(--luzmo-text-field-focus-indicator-width, 2px)) * -1);inset-inline-start:0}:host([quiet][focused]) #text-field:after{background-color:var(--highcontrast-text-field-focus-indicator-color, var(--luzmo-text-field-focus-indicator-color, var(--luzmo-color-informative)))}:host([quiet][invalid]) #text-field .input{padding-inline-end:calc(var(--luzmo-text-field-icon-spacing-inline-start-invalid, var(--text-field-icon-spacing-inline-start-invalid)) + var(--luzmo-text-field-icon-size-invalid, var(--text-field-icon-size-invalid)))}:host([quiet][valid]) #text-field .input{padding-inline-end:calc(var(--luzmo-text-field-icon-spacing-inline-start-valid, var(--text-field-icon-spacing-inline-start-valid)) + var(--luzmo-text-field-icon-size-valid, var(--text-field-icon-size-valid)))}:host([invalid]) #text-field .icon,:host([valid]) #text-field .icon{pointer-events:all;grid-area:2/2;margin-inline-start:auto;position:absolute;inset-block-start:0;display:flex;align-items:center;justify-content:center}#text-field.luzmo-text-field--sideLabel .icon{grid-area:1/2/span 1/span 1}:host([valid]) #text-field .icon{font-size:var(--luzmo-text-field-icon-size-valid, var(--text-field-icon-size-valid));color:var(--highcontrast-text-field-icon-color-valid, var(--luzmo-text-field-icon-color-valid, var(--luzmo-color-positive)));inset-block-start:var(--luzmo-text-field-icon-spacing-block-valid, var(--text-field-icon-spacing-block-valid));inset-block-end:var(--luzmo-text-field-icon-spacing-block-valid, var(--text-field-icon-spacing-block-valid));inset-inline-end:var(--luzmo-text-field-icon-spacing-inline-end-valid, var(--text-field-icon-spacing-inline-end-valid))}:host([invalid]) #text-field .icon{font-size:var(--luzmo-text-field-icon-size-invalid, var(--text-field-icon-size-invalid));color:var(--highcontrast-text-field-icon-color-invalid, var(--luzmo-text-field-icon-color-invalid, var(--luzmo-color-negative)));inset-block-start:var(--luzmo-text-field-icon-spacing-block-invalid, var(--text-field-icon-spacing-block-invalid));inset-block-end:var(--luzmo-text-field-icon-spacing-block-invalid, var(--text-field-icon-spacing-block-invalid));inset-inline-end:var(--luzmo-text-field-icon-spacing-inline-end-invalid, var(--text-field-icon-spacing-inline-end-invalid))}:host([disabled]) #text-field .icon,:host([readonly]) #text-field .icon{color:#0000}:host([quiet]) .icon{padding-inline-end:0}:host([quiet][valid]) .icon{inset-inline-end:var(--luzmo-text-field-icon-spacing-inline-end-quiet-valid, 0px)}:host([quiet][invalid]) .icon{inset-inline-end:var(--luzmo-text-field-icon-spacing-inline-end-quiet-invalid, 0px)}#text-field .luzmo-field-label{grid-area:1/1/auto/span 1;margin-block-end:var(--luzmo-text-field-label-spacing-block, 0px)}:host([quiet]) .luzmo-field-label{margin-block-end:var(--luzmo-text-field-label-spacing-block-quiet, var(--text-field-label-spacing-block-quiet))}:host([disabled]) .luzmo-field-label{color:var(--luzmo-text-field-text-color-disabled, var(--luzmo-font-color-disabled))}#text-field .luzmo-help-text{grid-area:3/1/auto/span 2;margin-block-start:var(--luzmo-text-field-helptext-spacing-block, 0px)}.luzmo-text-field-characterCount{inline-size:auto;font-size:var(--luzmo-text-field-character-count-font-size, var(--text-field-character-count-font-size));font-family:var(--luzmo-text-field-character-count-font-family, var(--luzmo-font-family));font-weight:var(--luzmo-text-field-character-count-font-weight, var(--luzmo-font-weight));grid-area:1/2/auto/span 1;justify-content:flex-end;align-items:flex-end;margin-block-end:var(--luzmo-text-field-character-count-spacing-block, var(--text-field-character-count-spacing-block));margin-inline-start:var(--luzmo-text-field-character-count-spacing-inline, 12px);margin-inline-end:0;padding-inline-end:calc(var(--luzmo-text-field-corner-radius, var(--luzmo-border-radius)) / 2);display:inline-flex}:host([quiet]) .luzmo-text-field-characterCount{margin-block-end:var(--luzmo-text-field-character-count-spacing-block-quiet, var(--text-field-character-count-spacing-block-quiet))}.input{text-align:var(--luzmo-text-field-text-align, start);line-height:var(--luzmo-text-field-input-line-height);box-sizing:border-box;inline-size:100%;min-inline-size:var(--luzmo-text-field-min-width, 1.5);block-size:var(--luzmo-text-field-height, var(--text-field-height));padding-block-start:calc(var(--luzmo-text-field-spacing-block-start, var(--luzmo-spacing-3)) - var(--luzmo-text-field-border-width, var(--luzmo-border-width)));padding-block-end:calc(var(--luzmo-text-field-spacing-block-end, var(--luzmo-spacing-3)) - var(--luzmo-text-field-border-width, var(--luzmo-border-width)));padding-inline:calc(var(--luzmo-text-field-spacing-inline, var(--text-field-spacing-inline)) - var(--luzmo-text-field-border-width, var(--luzmo-border-width)));vertical-align:top;background-color:var(--luzmo-text-field-background-color, var(--luzmo-background-color));border-color:var(--highcontrast-text-field-border-color, var(--luzmo-text-field-border-color, var(--luzmo-border-color)));border-style:solid;border-width:var(--luzmo-text-field-border-width, var(--luzmo-border-width));border-radius:var(--luzmo-text-field-corner-radius, var(--luzmo-border-radius));transition:border-color var(--luzmo-text-field-animation-duration, var(--luzmo-animation-duration)) ease-in-out;font-size:var(--luzmo-text-field-placeholder-font-size, var(--text-field-placeholder-font-size));font-family:var(--luzmo-text-field-font-family, var(--luzmo-font-family));font-weight:var(--luzmo-text-field-font-weight, var(--luzmo-font-weight));color:var(--highcontrast-text-field-text-color-default, var(--luzmo-text-field-text-color-default, var(--luzmo-font-color)));text-overflow:ellipsis;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;grid-area:2/1/auto/span 2;margin:0}:host([type=number]) .input{-moz-appearance:text-field}:host([type=number]) .input::-webkit-inner-spin-button,:host([type=number]) .input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.input:-moz-ui-invalid{box-shadow:none}.input::placeholder{opacity:1;font-size:var(--luzmo-text-field-placeholder-font-size, var(--text-field-placeholder-font-size));font-family:var(--luzmo-text-field-font-family, var(--luzmo-font-family));font-weight:var(--luzmo-text-field-font-weight, var(--luzmo-font-weight));color:var(--highcontrast-text-field-text-color-default, var(--luzmo-text-field-placeholder-text-color-default, var(--luzmo-font-color-disabled)));transition:color var(--luzmo-text-field-animation-duration, var(--luzmo-animation-duration)) ease-in-out}.input:lang(ja)::placeholder,.input:lang(ko)::placeholder,.input:lang(zh)::placeholder{font-style:normal}:host([focused]) .input,.input:focus{border-color:var(--highcontrast-text-field-border-color-focus, var(--luzmo-text-field-border-color-focus, var(--luzmo-primary)));color:var(--highcontrast-text-field-text-color-focus, var(--luzmo-text-field-text-color-focus, var(--luzmo-font-color-hard)))}:host([focused]) .input::placeholder,.input:focus::placeholder{color:var(--highcontrast-text-field-text-color-focus, var(--luzmo-text-field-placeholder-text-color-focus, var(--luzmo-color-disabled)))}:host([focused]) .input{border-color:var(--highcontrast-text-field-border-color-keyboard-focus, var(--luzmo-text-field-border-color-keyboard-focus, var(--luzmo-primary)));outline:var(--luzmo-text-field-focus-indicator-width, 0) solid;outline-color:var(--highcontrast-text-field-focus-indicator-color, var(--luzmo-text-field-focus-indicator-color, var(--luzmo-color-informative)));outline-offset:var(--luzmo-text-field-focus-indicator-gap, 2px);color:var(--highcontrast-text-field-text-color-keyboard-focus, var(--luzmo-text-field-text-color-keyboard-focus, var(--luzmo-font-color-hard)))}:host([focused]) .input::placeholder{color:var(--highcontrast-text-field-text-color-keyboard-focus, var(--luzmo-text-field-placeholder-text-color-keyboard-focus, var(--luzmo-color-disabled)))}:host([valid]) .input{color:var(--highcontrast-text-field-text-color-valid, var(--luzmo-text-field-text-color-valid, var(--luzmo-font-color)));padding-inline-end:calc(var(--luzmo-text-field-icon-spacing-inline-start-valid, var(--text-field-icon-spacing-inline-start-valid)) + var(--luzmo-text-field-icon-size-valid, var(--text-field-icon-size-valid)) + var(--luzmo-text-field-icon-spacing-inline-end-valid, var(--text-field-icon-spacing-inline-end-valid)) - var(--luzmo-text-field-border-width, var(--luzmo-border-width)))}:host([invalid]) .input{color:var(--highcontrast-text-field-text-color-invalid, var(--luzmo-text-field-text-color-invalid, var(--luzmo-font-color)));border-color:var(--highcontrast-text-field-border-color-invalid-default, var(--luzmo-text-field-border-color-invalid-default, var(luzmo-danger-color)));padding-inline-end:calc(var(--luzmo-text-field-icon-spacing-inline-start-invalid, var(--text-field-icon-spacing-inline-start-invalid)) + var(--luzmo-text-field-icon-size-invalid, var(--text-field-icon-size-invalid)) + var(--luzmo-text-field-icon-spacing-inline-end-invalid, var(--text-field-icon-spacing-inline-end-invalid)) - var(--luzmo-text-field-border-width, var(--luzmo-border-width)))}:host([invalid]) .input:focus,:host([invalid][focused]) .input,:host([invalid]:focus) .input{border-color:var(--highcontrast-text-field-border-color-invalid-focus, var(--luzmo-text-field-border-color-invalid-focus, var(luzmo-danger-color)))}:host([invalid]) .input:focus-visible,:host([invalid][focused]) .input{border-color:var(--highcontrast-text-field-border-color-invalid-keyboard-focus, var(--luzmo-text-field-border-color-invalid-keyboard-focus, var(luzmo-danger-color)))}.input:disabled,:host([disabled]) #text-field .input{background-color:var(--luzmo-text-field-background-color-disabled, var(--luzmo-background-color-disabled));resize:none;opacity:1;border-color:#0000}.input:disabled,.input:disabled::placeholder,:host([disabled]) #text-field .input,:host([disabled]) #text-field .input::placeholder{color:var(--highcontrast-text-field-text-color-disabled, var(--luzmo-text-field-text-color-disabled, var(--luzmo-font-color-disabled)))}:host([border=none]) .input{border-width:0;outline:none}:host([quiet]) .input{padding-block-start:var(--luzmo-text-field-spacing-block-start, var(--luzmo-spacing-2));padding-inline:var(--luzmo-text-field-spacing-inline-quiet, 0px);background-color:initial;resize:none;border-block-start-width:0;border-inline-width:0;border-radius:0;outline:none;margin-block-end:var(--luzmo-text-field-spacing-block-quiet, 0px);overflow-y:hidden}:host([quiet][disabled]) .input,.input:disabled{background-color:initial;border-color:var(--luzmo-text-field-border-color-disabled, var(--luzmo-border-color-disabled))}:host([quiet][disabled]) .input,:host([quiet][disabled]) .input::placeholder,.input:disabled,.input:disabled::placeholder{color:var(--highcontrast-text-field-text-color-disabled, var(--luzmo-text-field-text-color-disabled, var(--luzmo-color-disabled)))}.input:read-only,:host([readonly]) #text-field .input{background-color:initial;color:var(--highcontrast-text-field-text-color-readonly, var(--luzmo-text-field-text-color-readonly, var(--luzmo-font-color)));border-color:#0000;outline:none}.input:read-only::placeholder,:host([readonly]) #text-field .input::placeholder{color:var(--highcontrast-text-field-text-color-readonly, var(--luzmo-text-field-text-color-readonly, var(--luzmo-color-disabled)));background-color:initial}@media (hover: hover){.input:hover,#text-field:hover .input{border-color:var(--highcontrast-text-field-border-color-hover, var(--luzmo-text-field-border-color-hover, rgba(var(--luzmo-primary-rgb), .3)))}.input:hover,#text-field:hover .input{color:var(--highcontrast-text-field-text-color-hover, var(--luzmo-text-field-text-color-hover, var(--luzmo-font-color-hard)))}.input:hover::placeholder,#text-field:hover .input::placeholder{color:var(--highcontrast-text-field-text-color-hover, var(--luzmo-text-field-placeholder-text-color-hover, var(--luzmo-color-disabled)))}:host([focused]) .input:hover,:host([focused]) #text-field:hover .input,.input:focus:hover{border-color:var(--highcontrast-text-field-border-color-focus-hover, var(--luzmo-text-field-border-color-focus-hover, var(--luzmo-primary)))}:host([focused]) .input:hover,.input:focus:hover{color:var(--highcontrast-text-field-text-color-focus-hover, var(--luzmo-text-field-text-color-focus-hover, var(--luzmo-font-color-hard)))}:host([focused]) .input:hover::placeholder,.input:focus:hover::placeholder{color:var(--highcontrast-text-field-text-color-focus-hover, var(--luzmo-text-field-placeholder-text-color-focus-hover, var(--luzmo-color-disabled)))}:host([invalid]) .input:hover:not(.is-disabled),:host([invalid]:hover):not(.is-disabled) .input{border-color:var(--highcontrast-text-field-border-color-invalid-hover, var(--luzmo-text-field-border-color-invalid-hover, var(luzmo-danger-color)))}:host([invalid]) .input:focus:hover,:host([invalid][focused]) .input:hover,:host([invalid]:focus) .input:hover{border-color:var(--highcontrast-text-field-border-color-invalid-focus-hover, var(--luzmo-text-field-border-color-invalid-focus-hover, var(luzmo-danger-color)))}:host([disabled]) #text-field:hover .input{background-color:var(--luzmo-text-field-background-color-disabled, var(--luzmo-background-color-disabled));resize:none;opacity:1;border-color:#0000}:host([quiet][disabled]:hover) .input,:host([disabled]) #text-field:hover .input,:host([disabled]) #text-field:hover .input::placeholder{color:var(--highcontrast-text-field-text-color-disabled, var(--luzmo-text-field-text-color-disabled, var(--luzmo-font-color-disabled)))}:host([quiet][disabled]:hover) .input{background-color:initial;border-color:var(--luzmo-text-field-border-color-disabled, var(--luzmo-border-color-disabled))}:host([quiet][disabled]:hover) .input::placeholder{color:var(--highcontrast-text-field-text-color-disabled, var(--luzmo-text-field-text-color-disabled, var(--luzmo-font-color-disabled)))}:host([readonly]) #text-field:hover .input{border-color:#0000;outline:none}:host([readonly]) #text-field:hover .input,:host([readonly]) #text-field:hover .input::placeholder{background-color:initial;color:var(--highcontrast-text-field-text-color-readonly, var(--luzmo-text-field-text-color-readonly, var(--luzmo-font-color)))}}.luzmo-text-field--sideLabel{grid-template-rows:auto auto;grid-template-columns:auto auto auto}.luzmo-text-field--sideLabel:after{grid-area:1/2/span 1/span 1}.luzmo-text-field--sideLabel .luzmo-field-label{grid-area:1/1/span 2/span 1;margin-inline-end:var(--luzmo-text-field-label-spacing-inline-side-label, var(--text-field-label-spacing-inline-side-label))}.luzmo-text-field--sideLabel .luzmo-text-field-characterCount{grid-area:1/3/auto/span 1;align-items:flex-start;margin-block-start:var(--luzmo-text-field-character-count-spacing-block-side, var(--text-field-character-count-spacing-block-side));margin-inline-start:var(--luzmo-text-field-character-count-spacing-inline-side, 12px)}.luzmo-text-field--sideLabel .luzmo-help-text{grid-area:2/2/auto/span 1}.luzmo-text-field--sideLabel .input,.luzmo-text-field--sideLabel .icon{grid-area:1/2/span 1/span 1}:host([multiline]){--luzmo-text-field-input-line-height: normal}:host([multiline]) .input{min-inline-size:var(--luzmo-text-area-min-inline-size, 112px);min-block-size:var(--luzmo-text-area-min-block-size, 56px);resize:inherit}:host([multiline][grows]) .input{grid-row:2}:host([multiline][grows]) .luzmo-text-field--sideLabel .input{grid-row:1}:host([multiline][quiet]) .input{min-block-size:var(--luzmo-text-area-min-block-size-quiet, var(--text-area-min-block-size-quiet));resize:none;overflow-y:hidden}@media (forced-colors: active){:host{--highcontrast-text-field-border-color-hover: Highlight;--highcontrast-text-field-border-color-focus: Highlight;--highcontrast-text-field-border-color-keyboard-focus: CanvasText;--highcontrast-text-field-focus-indicator-color: Highlight;--highcontrast-text-field-border-color-invalid-default: Highlight;--highcontrast-text-field-border-color-invalid-hover: Highlight;--highcontrast-text-field-border-color-invalid-focus: Highlight;--highcontrast-text-field-border-color-invalid-keyboard-focus: Highlight;--highcontrast-text-field-text-color-valid: CanvasText;--highcontrast-text-field-text-color-invalid: CanvasText}#text-field .input{--highcontrast-text-field-text-color-default: CanvasText;--highcontrast-text-field-text-color-hover: CanvasText;--highcontrast-text-field-text-color-keyboard-focus: CanvasText;--highcontrast-text-field-text-color-disabled: GrayText;--highcontrast-text-field-text-color-readonly: CanvasText}#text-field .input::placeholder{--highcontrast-text-field-text-color-default: GrayText;--highcontrast-text-field-text-color-hover: GrayText;--highcontrast-text-field-text-color-keyboard-focus: GrayText;--highcontrast-text-field-text-color-disabled: GrayText;--highcontrast-text-field-text-color-readonly: CanvasText}}:host{display:inline-flex;flex-direction:column;inline-size:var(--luzmo-text-field-width, 240px)}:host([multiline]){resize:both}:host([multiline][readonly]){resize:none}:host([disabled]:focus-visible){outline:none}#text-field{inline-size:100%}#text-field,textarea{resize:inherit}.input{min-inline-size:var(--luzmo-text-field-min-width, 1.5)}:host([focused]) .input{caret-color:var(--swc-test-caret-color);forced-color-adjust:var(--swc-test-forced-color-adjust)}#sizer{block-size:auto;word-break:break-word;opacity:0;white-space:pre-line}.icon,.icon-workflow{pointer-events:none}:host([multiline]) #text-field{display:inline-grid;--luzmo-text-field-input-line-height: normal}:host([multiline]) textarea{transition:box-shadow var(--luzmo-animation-duration) ease-in-out,border-color var(--luzmo-animation-duration) ease-in-out}:host([multiline]:not([quiet])) #text-field:after{box-shadow:none}:host([multiline][rows]) .input{block-size:auto;resize:none}:host([multiline][rows="1"]) .input{min-block-size:auto}:host([disabled][quiet]) #text-field .input,:host([disabled][quiet]) #text-field:hover .input,:host([quiet]) .input :disabled{background-color:#0000;border-color:var(--luzmo-text-field-border-color-disabled, var(--luzmo-border-color-disabled));color:var(--highcontrast-text-field-text-color-disabled, var(--luzmo-text-field-text-color-disabled, var(--luzmo-font-color-disabled)))}:host([disabled]) #text-field .icon.icon-search,:host([readonly]) #text-field .icon.icon-search{color:var(--highcontrast-text-field-text-color-disabled, var(--luzmo-text-field-text-color-disabled, var(--luzmo-font-color-disabled)))}:host([multiline][grows]:not([quiet])) #text-field:after{grid-area:unset;min-block-size:calc(var(--luzmo-text-area-min-block-size, var(--luzmo-text-area-min-block-size)) + var(--luzmo-text-field-focus-indicator-gap, 2px) * 2)}:host([multiline][grows]:not([rows])) .input:not(#sizer){position:absolute;top:0;left:0;height:100%;resize:none;overflow:hidden}:host{--text-field-height: var(--luzmo-component-height);--text-field-label-spacing-block-quiet: -8px;--text-field-label-spacing-inline-side-label: 12px;--text-field-placeholder-font-size: 14px;--text-field-spacing-inline: 12px;--text-field-icon-size-invalid: 18px;--text-field-icon-size-valid: 10px;--text-field-icon-spacing-inline-end-invalid: 12px;--text-field-icon-spacing-inline-end-valid: 15px;--text-field-icon-spacing-block-invalid: 7px;--text-field-icon-spacing-block-valid: 4px;--text-field-icon-spacing-inline-start-invalid: var(--luzmo-spacing-4);--text-field-icon-spacing-inline-start-valid: var(--luzmo-spacing-4);--text-field-character-count-font-size: var(--luzmo-font-size-s);--text-field-character-count-spacing-block: 5px;--text-field-character-count-spacing-block-quiet: -3px;--text-field-character-count-spacing-block-side: 8px;--text-area-min-block-size-quiet: var(--luzmo-component-height)}:host([size=s]){--text-field-height: var(--luzmo-component-height-s);--text-field-label-spacing-block-quiet: -8px;--text-field-label-spacing-inline-side-label: 8px;--text-field-placeholder-font-size: 12px;--text-field-spacing-inline: 9px;--text-field-icon-size-invalid: 16px;--text-field-icon-size-valid: 10px;--text-field-icon-spacing-inline-end-invalid: 9px;--text-field-icon-spacing-inline-end-valid: 11px;--text-field-icon-spacing-block-invalid: 2px;--text-field-icon-spacing-block-valid: -1px;--text-field-icon-spacing-inline-start-invalid: var(--luzmo-spacing-3);--text-field-icon-spacing-inline-start-valid: var(--luzmo-spacing-3);--text-field-character-count-font-size: var(--luzmo-font-size-xs);--text-field-character-count-spacing-block: 5px;--text-field-character-count-spacing-block-quiet: -3px;--text-field-character-count-spacing-block-side: 4px;--text-area-min-block-size-quiet: var(--luzmo-component-height-s)}:host([size=l]){--text-field-height: var(--luzmo-component-height-l);--text-field-label-spacing-block-quiet: -12px;--text-field-label-spacing-inline-side-label: 12px;--text-field-placeholder-font-size: 16px;--text-field-spacing-inline: 15px;--text-field-icon-size-invalid: 20px;--text-field-icon-size-valid: 12px;--text-field-icon-spacing-inline-end-invalid: 15px;--text-field-icon-spacing-inline-end-valid: 17px;--text-field-icon-spacing-block-invalid: 10px;--text-field-icon-spacing-block-valid: 8px;--text-field-icon-spacing-inline-start-invalid: 15px;--text-field-icon-spacing-inline-start-valid: 15px;--text-field-character-count-font-size: var(--luzmo-font-size);--text-field-character-count-spacing-block: 9px;--text-field-character-count-spacing-block-quiet: -3px;--text-field-character-count-spacing-block-side: 11px;--text-area-min-block-size-quiet: var(--luzmo-component-height-l)}:host([size=xl]){--text-field-height: var(--luzmo-component-height-xl);--text-field-label-spacing-block-quiet: -15px;--text-field-label-spacing-inline-side-label: 12px;--text-field-placeholder-font-size: 18px;--text-field-spacing-inline: 15px;--text-field-icon-size-invalid: 22px;--text-field-icon-size-valid: 14px;--text-field-icon-spacing-inline-end-invalid: 18px;--text-field-icon-spacing-inline-end-valid: 20px;--text-field-icon-spacing-block-invalid: 12px;--text-field-icon-spacing-block-valid: 13px;--text-field-icon-spacing-inline-start-invalid: 18px;--text-field-icon-spacing-inline-start-valid: 18px;--text-field-character-count-font-size: var(--luzmo-font-size-l);--text-field-character-count-spacing-block: 11px;--text-field-character-count-spacing-block-quiet: -4px;--text-field-character-count-spacing-block-side: 14px;--text-area-min-block-size-quiet: var(--luzmo-component-height-xl)}';
52
- var B = Object.defineProperty, C = Object.getOwnPropertyDescriptor, t = (l, e, r, n) => {
53
- for (var d = n > 1 ? void 0 : n ? C(e, r) : e, f = l.length - 1, p; f >= 0; f--)
54
- (p = l[f]) && (d = (n ? p(e, r, d) : p(d)) || d);
55
- return n && d && B(e, r, d), d;
56
- };
57
- const L = ["text", "url", "tel", "email", "password"];
58
- class i extends E(
59
- T($, {
60
- noDefaultSize: !0
61
- })
62
- ) {
63
- constructor() {
64
- super(...arguments), this.allowedKeys = "", this.focused = !1, this.invalid = !1, this.label = "", this.placeholder = "", this._type = "text", this.grows = !1, this.maxlength = -1, this.minlength = -1, this.multiline = !1, this.readonly = !1, this.rows = -1, this.valid = !1, this._value = "", this.quiet = !1, this.required = !1;
65
- }
66
- static get styles() {
67
- return [m(S)];
68
- }
69
- set type(e) {
70
- const r = this._type;
71
- this._type = e, this.requestUpdate("type", r);
72
- }
73
- get type() {
74
- return L.find((e) => e === this._type) ?? "text";
75
- }
76
- set value(e) {
77
- if (e === this.value)
78
- return;
79
- const r = this._value;
80
- this._value = e, this.requestUpdate("value", r);
81
- }
82
- get value() {
83
- return this._value;
84
- }
85
- get focusElement() {
86
- return this.inputElement;
87
- }
88
- /**
89
- * Sets the start and end positions of the current selection.
90
- *
91
- * @param selectionStart The 0-based index of the first selected character. An index greater than the length of the
92
- * element's value is treated as pointing to the end of the value.
93
- * @param selectionEnd The 0-based index of the character after the last selected character. An index greater than
94
- * the length of the element's value is treated as pointing to the end of the value.
95
- * @param [selectionDirection="none"] A string indicating the direction in which the selection is considered to
96
- * have been performed.
97
- */
98
- setSelectionRange(e, r, n = "none") {
99
- this.inputElement.setSelectionRange(
100
- e,
101
- r,
102
- n
103
- );
104
- }
105
- /**
106
- * Selects all the text.
107
- */
108
- select() {
109
- this.inputElement.select();
110
- }
111
- handleInput(e) {
112
- if (this.allowedKeys && this.inputElement.value && !new RegExp(`^[${this.allowedKeys}]*$`, "u").test(this.inputElement.value)) {
113
- const d = this.inputElement.selectionStart - 1;
114
- this.inputElement.value = this.value.toString(), this.inputElement.setSelectionRange(d, d);
115
- return;
116
- }
117
- this.value = this.inputElement.value;
118
- }
119
- handleChange() {
120
- this.dispatchEvent(
121
- new Event("change", {
122
- bubbles: !0,
123
- composed: !0
124
- })
125
- );
126
- }
127
- onFocus() {
128
- this.focused = !this.readonly && !0;
129
- }
130
- onBlur(e) {
131
- this.focused = !this.readonly && !1;
132
- }
133
- handleInputElementPointerdown() {
134
- }
135
- renderStateIcons() {
136
- return this.invalid ? c`
137
- <div id="invalid" class="icon">${v(w)}</div>
138
- ` : this.valid ? c`
139
- <div id="valid" class="icon">${v(q)}</div>
140
- ` : u;
141
- }
142
- get displayValue() {
143
- return this.value.toString();
144
- }
145
- // prettier-ignore
146
- get renderMultiline() {
147
- return c`
148
- ${this.multiline && this.grows && this.rows === -1 ? c`
149
- <div id="sizer" class="input" aria-hidden="true">${this.value}&#8203;
150
- </div>
151
- ` : u}
152
- <!-- @ts-ignore -->
153
- <textarea
154
- name=${a(this.name || void 0)}
155
- aria-describedby=${this.helpTextId}
156
- aria-label=${this.label || this.appliedLabel || this.placeholder}
157
- aria-invalid=${a(this.invalid || void 0)}
158
- class="input"
159
- maxlength=${a(this.maxlength > -1 ? this.maxlength : void 0)}
160
- minlength=${a(this.minlength > -1 ? this.minlength : void 0)}
161
- title=${this.invalid ? "" : u}
162
- pattern=${a(this.pattern)}
163
- placeholder=${this.placeholder}
164
- .value=${this.displayValue}
165
- @change=${this.handleChange}
166
- @input=${this.handleInput}
167
- @focus=${this.onFocus}
168
- @blur=${this.onBlur}
169
- ?disabled=${this.disabled}
170
- ?required=${this.required}
171
- ?readonly=${this.readonly}
172
- rows=${a(this.rows > -1 ? this.rows : void 0)}
173
- autocomplete=${a(this.autocomplete)}
174
- ></textarea>
175
- `;
176
- }
177
- get renderInput() {
178
- return c`
179
- <!-- @ts-ignore -->
180
- <input
181
- name=${a(this.name || void 0)}
182
- type=${this.type}
183
- aria-describedby=${this.helpTextId}
184
- aria-label=${this.label || this.appliedLabel || this.placeholder}
185
- aria-invalid=${a(this.invalid || void 0)}
186
- class="input"
187
- title=${this.invalid ? "" : u}
188
- maxlength=${a(this.maxlength > -1 ? this.maxlength : void 0)}
189
- minlength=${a(this.minlength > -1 ? this.minlength : void 0)}
190
- pattern=${a(this.pattern)}
191
- placeholder=${this.placeholder}
192
- .value=${_(this.displayValue)}
193
- @change=${this.handleChange}
194
- @input=${this.handleInput}
195
- @pointerdown=${this.handleInputElementPointerdown}
196
- @focus=${this.onFocus}
197
- @blur=${this.onBlur}
198
- ?disabled=${this.disabled}
199
- ?required=${this.required}
200
- ?readonly=${this.readonly}
201
- autocomplete=${a(this.autocomplete)}
202
- />
203
- `;
204
- }
205
- renderField() {
206
- return c`
207
- ${this.renderStateIcons()}
208
- ${this.multiline ? this.renderMultiline : this.renderInput}
209
- `;
210
- }
211
- render() {
212
- return c`
213
- <div id="text-field">${this.renderField()}</div>
214
- ${this.renderHelpText(this.invalid)}
215
- `;
216
- }
217
- update(e) {
218
- (e.has("value") || e.has("required") && this.required) && this.updateComplete.then(() => {
219
- this.checkValidity();
220
- }), super.update(e);
221
- }
222
- checkValidity() {
223
- let e = this.inputElement.checkValidity();
224
- return (this.required || this.value && this.pattern) && ((this.disabled || this.multiline) && this.pattern && (e = new RegExp(`^${this.pattern}$`, "u").test(this.value.toString())), this.minlength !== void 0 && (e = e && this.value.toString().length >= this.minlength), this.valid = e, this.invalid = !e), e;
225
- }
226
- }
227
- t([
228
- x()
229
- ], i.prototype, "appliedLabel", 2);
230
- t([
231
- o({ attribute: "allowed-keys" })
232
- ], i.prototype, "allowedKeys", 2);
233
- t([
234
- o({ type: Boolean, reflect: !0 })
235
- ], i.prototype, "focused", 2);
236
- t([
237
- g(".input:not(#sizer)")
238
- ], i.prototype, "inputElement", 2);
239
- t([
240
- o({ type: Boolean, reflect: !0 })
241
- ], i.prototype, "invalid", 2);
242
- t([
243
- o()
244
- ], i.prototype, "label", 2);
245
- t([
246
- o({ type: String, reflect: !0 })
247
- ], i.prototype, "name", 2);
248
- t([
249
- o()
250
- ], i.prototype, "placeholder", 2);
251
- t([
252
- x()
253
- ], i.prototype, "type", 1);
254
- t([
255
- o({ attribute: "type", reflect: !0 })
256
- ], i.prototype, "_type", 2);
257
- t([
258
- o()
259
- ], i.prototype, "pattern", 2);
260
- t([
261
- o({ type: Boolean, reflect: !0 })
262
- ], i.prototype, "grows", 2);
263
- t([
264
- o({ type: Number })
265
- ], i.prototype, "maxlength", 2);
266
- t([
267
- o({ type: Number })
268
- ], i.prototype, "minlength", 2);
269
- t([
270
- o({ type: Boolean, reflect: !0 })
271
- ], i.prototype, "multiline", 2);
272
- t([
273
- o({ type: Boolean, reflect: !0 })
274
- ], i.prototype, "readonly", 2);
275
- t([
276
- o({ type: Number })
277
- ], i.prototype, "rows", 2);
278
- t([
279
- o({ type: Boolean, reflect: !0 })
280
- ], i.prototype, "valid", 2);
281
- t([
282
- o({ type: String })
283
- ], i.prototype, "value", 1);
284
- t([
285
- o({ type: Boolean, reflect: !0 })
286
- ], i.prototype, "quiet", 2);
287
- t([
288
- o({ type: Boolean, reflect: !0 })
289
- ], i.prototype, "required", 2);
290
- t([
291
- o({ type: String, reflect: !0 })
292
- ], i.prototype, "autocomplete", 2);
293
- class I extends i {
294
- constructor() {
295
- super(...arguments), this._value = "";
296
- }
297
- set value(e) {
298
- if (e === this.value)
299
- return;
300
- const r = this._value;
301
- this._value = e, this.requestUpdate("value", r);
302
- }
303
- get value() {
304
- return this._value;
305
- }
306
- }
307
- t([
308
- o({ type: String })
309
- ], I.prototype, "value", 1);
310
- export {
311
- I as L,
312
- i as a
313
- };