@luzmo/lucero 1.0.1-alpha.64 → 1.0.1-alpha.66

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 (125) hide show
  1. package/components/accordion/index.js +2 -2
  2. package/components/action-bar/index.js +5 -5
  3. package/components/action-button/index.js +1 -1
  4. package/components/action-group/index.js +1 -1
  5. package/components/{action-group-BDdRHYNo.js → action-group-CqAXlI_I.js} +1 -1
  6. package/components/action-menu/index.js +1 -1
  7. package/components/avatar/index.js +1 -1
  8. package/components/badge/index.js +1 -1
  9. package/components/{base-DA-IfpPk.js → base-BUViEg_7.js} +2 -2
  10. package/components/button/index.js +3 -3
  11. package/components/{button-base-CAXH68Sp.js → button-base-npzdrTiY.js} +1 -1
  12. package/components/button-group/index.js +1 -1
  13. package/components/calendar/calendar.d.ts +61 -0
  14. package/components/calendar/index.cjs +49 -20
  15. package/components/calendar/index.d.ts +1 -0
  16. package/components/calendar/index.js +342 -124
  17. package/components/chat-message/index.cjs +12 -12
  18. package/components/chat-message/index.js +131 -131
  19. package/components/chat-message-group/index.js +1 -1
  20. package/components/checkbox/index.js +1 -1
  21. package/components/{close-button-1l5b3LRg.js → close-button-po7k74tH.js} +1 -1
  22. package/components/color-area/index.js +4 -4
  23. package/components/color-field/index.js +1 -1
  24. package/components/color-handle/index.js +2 -2
  25. package/components/color-loupe/index.js +1 -1
  26. package/components/{color-loupe-DvrXjsKF.js → color-loupe-OvalnSmN.js} +1 -1
  27. package/components/color-menu/index.js +1 -1
  28. package/components/color-palette/index.js +1 -1
  29. package/components/color-palette-group/index.js +1 -1
  30. package/components/color-picker/index.js +1 -1
  31. package/components/color-slider/index.js +1 -1
  32. package/components/date-range-picker/date-range-picker.d.ts +184 -0
  33. package/components/date-range-picker/index.cjs +187 -0
  34. package/components/date-range-picker/index.d.ts +8 -0
  35. package/components/date-range-picker/index.js +699 -0
  36. package/components/date-range-picker/types.d.ts +16 -0
  37. package/components/date-time-picker/date-time-picker.d.ts +3 -3
  38. package/components/date-time-picker/index.cjs +16 -16
  39. package/components/date-time-picker/index.d.ts +1 -0
  40. package/components/date-time-picker/index.js +186 -667
  41. package/components/date-time-picker/{types.d.ts → shared/types.d.ts} +1 -1
  42. package/components/divider/index.js +1 -1
  43. package/components/field-group/index.js +1 -1
  44. package/components/{field-group-DIQfPlIH.js → field-group-GZLR5GAn.js} +1 -1
  45. package/components/field-label/index.js +1 -1
  46. package/components/{field-label-DWMbxMEF.js → field-label-BxW2RJMY.js} +1 -1
  47. package/components/{focusable-DMl8nuHx.js → focusable-BM1nd-dI.js} +1 -1
  48. package/components/icon/index.js +1 -1
  49. package/components/index.cjs +1 -1
  50. package/components/index.js +147 -145
  51. package/components/infield-button/index.js +1 -1
  52. package/components/label/index.js +1 -1
  53. package/components/menu/index.js +3 -3
  54. package/components/multi-language-field/index.js +1 -1
  55. package/components/number-field/index.js +2 -2
  56. package/components/options/index.js +2 -2
  57. package/components/overlay/index.js +3 -3
  58. package/components/{overlay-DMuQsYST.js → overlay-DUk7MsDe.js} +10 -10
  59. package/components/{pending-state-CkX6x_ad.js → pending-state-DEYcMdvk.js} +1 -1
  60. package/components/picker/index.js +2 -2
  61. package/components/{picker-BEvjNJ5y.js → picker-J60emx7z.js} +4 -4
  62. package/components/picker-button/index.js +1 -1
  63. package/components/{platform-BgUdNqhP.js → platform-CqwNrovd.js} +10 -10
  64. package/components/popover/index.js +1 -1
  65. package/components/{popover-3xG5ZKzr.js → popover-9RrCrbbh.js} +1 -1
  66. package/components/progress-bar/index.cjs +7 -10
  67. package/components/progress-bar/index.js +40 -32
  68. package/components/progress-circle/index.js +1 -1
  69. package/components/{progress-circle-BmbDn21M.js → progress-circle-CoyYfXBP.js} +1 -1
  70. package/components/progress-steps/index.cjs +42 -19
  71. package/components/progress-steps/index.d.ts +1 -1
  72. package/components/progress-steps/index.js +86 -33
  73. package/components/progress-steps/progress-steps.d.ts +24 -1
  74. package/components/progress-steps/types.d.ts +8 -0
  75. package/components/prompt-box/index.js +1 -1
  76. package/components/radio/index.js +2 -2
  77. package/components/search/index.js +1 -1
  78. package/components/segments-factory-BfOaZ1Hi.cjs +18 -0
  79. package/components/segments-factory-DixEDs6I.js +516 -0
  80. package/components/select/index.js +2 -2
  81. package/components/slider/index.js +1 -1
  82. package/components/status-light/index.js +1 -1
  83. package/components/swatch/index.js +2 -2
  84. package/components/switch/index.js +1 -1
  85. package/components/tabs/index.js +8 -8
  86. package/components/tags/index.js +1 -1
  87. package/components/text-field/index.js +2 -2
  88. package/components/{text-field-Crj9jTtn.js → text-field-Czie2Tyh.js} +1 -1
  89. package/components/toast/index.js +2 -2
  90. package/components/tooltip/index.js +1 -1
  91. package/components/top-nav/index.js +2 -2
  92. package/components/utils.js +3 -3
  93. package/custom-elements.json +1 -1
  94. package/index.d.ts +1 -0
  95. package/package.json +7 -2
  96. package/react/README.md +1 -0
  97. package/react/components/calendar.ts +7 -1
  98. package/react/components/date-range-picker.ts +30 -0
  99. package/react/esm/components/calendar.d.ts +3 -0
  100. package/react/esm/components/calendar.js +4 -1
  101. package/react/esm/components/date-range-picker.d.ts +14 -0
  102. package/react/esm/components/date-range-picker.js +19 -0
  103. package/react/esm/index.d.ts +3 -2
  104. package/react/esm/index.js +4 -0
  105. package/react/index.ts +4 -0
  106. package/react/luzmo-stub.d.ts +6 -0
  107. /package/components/date-time-picker/{helpers.d.ts → shared/helpers.d.ts} +0 -0
  108. /package/components/date-time-picker/{segments → shared/segments}/date/day-segment.d.ts +0 -0
  109. /package/components/date-time-picker/{segments → shared/segments}/date/month-segment.d.ts +0 -0
  110. /package/components/date-time-picker/{segments → shared/segments}/date/year-segment.d.ts +0 -0
  111. /package/components/date-time-picker/{segments → shared/segments}/date-time-segments.d.ts +0 -0
  112. /package/components/date-time-picker/{segments → shared/segments}/editable-segment.d.ts +0 -0
  113. /package/components/date-time-picker/{segments → shared/segments}/literal-segment.d.ts +0 -0
  114. /package/components/date-time-picker/{segments → shared/segments}/modifiers/clear-modifier.d.ts +0 -0
  115. /package/components/date-time-picker/{segments → shared/segments}/modifiers/decrement-modifier.d.ts +0 -0
  116. /package/components/date-time-picker/{segments → shared/segments}/modifiers/increment-modifier.d.ts +0 -0
  117. /package/components/date-time-picker/{segments → shared/segments}/modifiers/input-modifier.d.ts +0 -0
  118. /package/components/date-time-picker/{segments → shared/segments}/modifiers/segments-modifier.d.ts +0 -0
  119. /package/components/date-time-picker/{segments → shared/segments}/segments-factory.d.ts +0 -0
  120. /package/components/date-time-picker/{segments → shared/segments}/segments-formatter.d.ts +0 -0
  121. /package/components/date-time-picker/{segments → shared/segments}/time/day-period-segment.d.ts +0 -0
  122. /package/components/date-time-picker/{segments → shared/segments}/time/hour-segment.d.ts +0 -0
  123. /package/components/date-time-picker/{segments → shared/segments}/time/millisecond-segment.d.ts +0 -0
  124. /package/components/date-time-picker/{segments → shared/segments}/time/minute-segment.d.ts +0 -0
  125. /package/components/date-time-picker/{segments → shared/segments}/time/second-segment.d.ts +0 -0
@@ -17,12 +17,12 @@
17
17
  * */
18
18
  import { unsafeCSS as z, html as m } from "lit";
19
19
  import { property as a, queryAssignedNodes as v } from "lit/decorators.js";
20
- import { L as p } from "../base-DA-IfpPk.js";
20
+ import { a as p } from "../base-BUViEg_7.js";
21
21
  import { F as f } from "../focus-group-DHeTq18L.js";
22
22
  import { S as h } from "../sized-mixin-cJbo3PKR.js";
23
23
  import { luzmoIcon as b, luzmoAngleRight as x } from "@luzmo/icons";
24
24
  import { when as y } from "lit/directives/when.js";
25
- import { F as k } from "../focusable-DMl8nuHx.js";
25
+ import { F as k } from "../focusable-BM1nd-dI.js";
26
26
  const g = () => {
27
27
  if (typeof document < "u" && !document.querySelector("style[data-luzmo-vars]")) {
28
28
  const r = document.createElement("style");
@@ -18,12 +18,12 @@
18
18
  import { unsafeCSS as b, html as z } from "lit";
19
19
  import { property as t } from "lit/decorators.js";
20
20
  import { ifDefined as m } from "lit/directives/if-defined.js";
21
- import { L as p } from "../base-DA-IfpPk.js";
21
+ import { a as p } from "../base-BUViEg_7.js";
22
22
  import { F as d } from "../focus-visible-BvScGDCE.js";
23
- import "../action-group-BDdRHYNo.js";
24
- import "../close-button-1l5b3LRg.js";
25
- import "../field-label-DWMbxMEF.js";
26
- import "../popover-3xG5ZKzr.js";
23
+ import "../action-group-CqAXlI_I.js";
24
+ import "../close-button-po7k74tH.js";
25
+ import "../field-label-BxW2RJMY.js";
26
+ import "../popover-9RrCrbbh.js";
27
27
  const s = () => {
28
28
  if (typeof document < "u" && !document.querySelector("style[data-luzmo-vars]")) {
29
29
  const r = document.createElement("style");
@@ -19,7 +19,7 @@ import { luzmoIcon as s, luzmoCornerTriangle as g } from "@luzmo/icons";
19
19
  import { unsafeCSS as m, html as h } from "lit";
20
20
  import { property as a } from "lit/decorators.js";
21
21
  import { S as v } from "../sized-mixin-cJbo3PKR.js";
22
- import { L as z } from "../button-base-CAXH68Sp.js";
22
+ import { L as z } from "../button-base-npzdrTiY.js";
23
23
  const d = () => {
24
24
  if (typeof document < "u" && !document.querySelector("style[data-luzmo-vars]")) {
25
25
  const c = document.createElement("style");
@@ -15,7 +15,7 @@
15
15
  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
16
16
  * SOFTWARE.
17
17
  * */
18
- import { L as r } from "../action-group-BDdRHYNo.js";
18
+ import { L as r } from "../action-group-CqAXlI_I.js";
19
19
  const l = () => {
20
20
  if (typeof document < "u" && !document.querySelector("style[data-luzmo-vars]")) {
21
21
  const o = document.createElement("style");
@@ -18,7 +18,7 @@
18
18
  import { unsafeCSS as d, html as p } from "lit";
19
19
  import { MutationController as g } from "@lit-labs/observers/mutation-controller.js";
20
20
  import { property as c, query as h } from "lit/decorators.js";
21
- import { L as b } from "./base-DA-IfpPk.js";
21
+ import { a as b } from "./base-BUViEg_7.js";
22
22
  import { R as m } from "./roving-tabindex-DOg4z6ZU.js";
23
23
  import { S as v } from "./sized-mixin-cJbo3PKR.js";
24
24
  const z = ":host{gap:var(--luzmo-action-group-horizontal-spacing-regular, var(--action-group-horizontal-spacing-regular));flex-wrap:wrap;display:flex}::slotted(*){flex-shrink:0}::slotted(:focus-visible){z-index:3}:host(:not([vertical]):not([compact])) ::slotted(*){flex-shrink:0}:host([vertical]){gap:var(--luzmo-action-group-vertical-spacing-regular, var(--action-group-vertical-spacing-regular));flex-direction:column;display:inline-flex}:host([compact]){gap:var(--luzmo-action-group-gap-size-compact, var(--action-group-gap-size-compact))}:host([compact]:not([quiet])){flex-wrap:nowrap}:host([compact]:not([quiet])) ::slotted(*){border-radius:var(--luzmo-action-group-border-radius-reset, var(--action-group-border-radius-reset));z-index:0;position:relative}:host([compact]:not([quiet])) ::slotted(:first-child){--luzmo-actionbutton-focus-indicator-border-radius: var( --luzmo-action-group-border-radius, var(--action-group-border-radius) ) 0px 0px var(--luzmo-action-group-border-radius, var(--action-group-border-radius));border-start-start-radius:var(--luzmo-action-group-border-radius, var(--action-group-border-radius));border-end-start-radius:var(--luzmo-action-group-border-radius, var(--action-group-border-radius));margin-inline-start:var(--luzmo-action-group-button-spacing-reset, var(--action-group-button-spacing-reset))}:host([compact]:not([quiet])) ::slotted(:not(:first-child)){--luzmo-actionbutton-focus-indicator-border-radius: 0px;margin-inline-start:var(--luzmo-action-group-horizontal-spacing-compact, var(--action-group-horizontal-spacing-compact));margin-inline-end:var(--luzmo-action-group-horizontal-spacing-compact, var(--action-group-horizontal-spacing-compact))}:host([compact]:not([quiet])) ::slotted(:last-child){--luzmo-actionbutton-focus-indicator-border-radius: 0px var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) 0px;border-start-end-radius:var(--luzmo-action-group-border-radius, var(--action-group-border-radius));border-end-end-radius:var(--luzmo-action-group-border-radius, var(--action-group-border-radius));margin-inline-start:var(--luzmo-action-group-horizontal-spacing-compact, var(--action-group-horizontal-spacing-compact));margin-inline-end:var(--luzmo-action-group-border-radius-reset, var(--action-group-border-radius-reset))}:host([compact]:not([quiet])) ::slotted([selected]){z-index:1}@media (hover: hover){:host([compact]:not([quiet])) ::slotted(:hover){z-index:2}}:host([compact]:not([quiet])) ::slotted(:focus-visible){z-index:3}:host([compact]:not([quiet])[vertical]){gap:var(--luzmo-action-group-gap-size-compact, var(--action-group-gap-size-compact))}:host([compact][vertical]:not([quiet])) ::slotted(*){border-radius:var(--luzmo-action-group-border-radius-reset, var(--action-group-border-radius-reset))}:host([compact][vertical]:not([quiet])) ::slotted(:first-child){--luzmo-actionbutton-focus-indicator-border-radius: var( --luzmo-action-group-border-radius, var(--action-group-border-radius) ) var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) 0px 0px;border-start-start-radius:var(--luzmo-action-group-border-radius, var(--action-group-border-radius));border-start-end-radius:var(--luzmo-action-group-border-radius, var(--action-group-border-radius));margin-block-start:var(--luzmo-action-group-vertical-spacing-compact, var(--action-group-vertical-spacing-compact));margin-block-end:var(--luzmo-action-group-vertical-spacing-compact, var(--action-group-vertical-spacing-compact));margin-inline-end:var(--luzmo-action-group-button-spacing-reset, var(--action-group-button-spacing-reset))}:host([compact][vertical]:not([quiet])) ::slotted(:not(:first-child)){margin-block-start:var(--luzmo-action-group-button-spacing-reset, var(--action-group-button-spacing-reset));margin-block-end:var(--luzmo-action-group-vertical-spacing-compact, var(--action-group-vertical-spacing-compact));margin-inline-start:var(--luzmo-action-group-button-spacing-reset, var(--action-group-button-spacing-reset));margin-inline-end:var(--luzmo-action-group-button-spacing-reset, var(--action-group-button-spacing-reset))}:host([compact][vertical]:not([quiet])) ::slotted(:last-child){--luzmo-actionbutton-focus-indicator-border-radius: 0px 0px var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) var(--luzmo-action-group-border-radius, var(--action-group-border-radius));border-end-end-radius:var(--luzmo-action-group-border-radius, var(--action-group-border-radius));border-end-start-radius:var(--luzmo-action-group-border-radius, var(--action-group-border-radius));margin-block-start:var(--luzmo-action-group-vertical-spacing-compact, var(--action-group-vertical-spacing-compact));margin-block-end:var(--luzmo-action-group-button-spacing-reset, var(--action-group-button-spacing-reset))}:host([justified]) ::slotted(*){flex:1}:host{--action-group-gap-size-compact: 0px;--action-group-horizontal-spacing-compact: -1px;--action-group-vertical-spacing-compact: -1px;--action-group-button-spacing-reset: 0px;--action-group-border-radius-reset: 0px;--action-group-border-radius: var(--luzmo-border-radius);--action-group-horizontal-spacing-regular: var(--luzmo-spacing-3);--action-group-vertical-spacing-regular: var(--luzmo-spacing-3)}:host([size=xs]),:host([size=s]){--action-group-horizontal-spacing-regular: var(--luzmo-spacing-2);--action-group-vertical-spacing-regular: var(--luzmo-spacing-2)}:host,:host([size=l]),:host([size=xl]){--action-group-horizontal-spacing-regular: var(--luzmo-spacing-3);--action-group-vertical-spacing-regular: var(--luzmo-spacing-3)}:host([dir][compact][vertical]) ::slotted(:nth-child(n)){margin-right:0;margin-left:0}:host([justified]) ::slotted(:not([role])),:host([vertical]) ::slotted(:not([role])){display:flex;flex-direction:column;align-items:stretch}:host([compact]:not([quiet])) ::slotted(:not([role])){--overriden-border-radius: 0;--luzmo-action-button-border-radius: var(--overriden-border-radius)}:host([compact][vertical]:not([quiet])) ::slotted(:not([role]):first-child){--overriden-border-radius: var( --luzmo-action-group-border-radius, var(--action-group-border-radius) ) var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) 0 0}:host([compact][vertical]:not([quiet])) ::slotted(:not([role]):last-child){--overriden-border-radius: 0 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) var(--luzmo-action-group-border-radius, var(--action-group-border-radius))}:host([dir=ltr][compact]:not([quiet],[vertical])) ::slotted(:not([role]):first-child){--overriden-border-radius: var( --luzmo-action-group-border-radius, var(--action-group-border-radius) ) 0 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius))}:host([dir=rtl][compact]:not([quiet],[vertical])) ::slotted(:not([role]):first-child){--overriden-border-radius: 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) 0}:host([dir=ltr][compact]:not([quiet],[vertical])) ::slotted(:not([role]):last-child){--overriden-border-radius: 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) 0}:host([dir=rtl][compact]:not([quiet],[vertical])) ::slotted(:not([role]):last-child){--overriden-border-radius: var( --luzmo-action-group-border-radius, var(--action-group-border-radius) ) 0 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius))}:host([compact]:not([quiet])) ::slotted(*){--luzmo-action-button-focus-ring-border-radius: 0}:host([compact][vertical]:not([quiet])) ::slotted(:first-child){--luzmo-action-button-focus-ring-border-radius: var(--luzmo-border-radius) var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) 0 0}:host([compact][vertical]:not([quiet])) ::slotted(:last-child){--luzmo-action-button-focus-ring-border-radius: 0 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) var(--luzmo-action-group-border-radius, var(--action-group-border-radius))}:host([dir=ltr][compact]:not([quiet],[vertical])) ::slotted(:first-child){--luzmo-action-button-focus-ring-border-radius: var(--luzmo-border-radius) 0 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius))}:host([dir=rtl][compact]:not([quiet],[vertical])) ::slotted(:first-child){--luzmo-action-button-focus-ring-border-radius: 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) 0}:host([dir=ltr][compact]:not([quiet],[vertical])) ::slotted(:last-child){--luzmo-action-button-focus-ring-border-radius: 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) var(--luzmo-action-group-border-radius, var(--action-group-border-radius)) 0}:host([dir=rtl][compact]:not([quiet],[vertical])) ::slotted(:last-child){--luzmo-action-button-focus-ring-border-radius: var(--luzmo-border-radius) 0 0 var(--luzmo-action-group-border-radius, var(--action-group-border-radius))}";
@@ -22,7 +22,7 @@ import { ifDefined as a } from "lit/directives/if-defined.js";
22
22
  import { O as p } from "../observe-slot-presence-DFi6GE3H.js";
23
23
  import { O as h } from "../observe-slot-text-DorVpCL4.js";
24
24
  import { S as f } from "../slottable-request-event-DggLA4Rx.js";
25
- import { a as x, D as v } from "../picker-BEvjNJ5y.js";
25
+ import { L as x, D as v } from "../picker-J60emx7z.js";
26
26
  import "../action-button/index.js";
27
27
  import "../icon/index.js";
28
28
  import "../overlay/index.js";
@@ -18,7 +18,7 @@
18
18
  import { unsafeCSS as n, html as m } from "lit";
19
19
  import { property as i, query as d } from "lit/decorators.js";
20
20
  import { ifDefined as z } from "lit/directives/if-defined.js";
21
- import { F as v } from "../focusable-DMl8nuHx.js";
21
+ import { F as v } from "../focusable-BM1nd-dI.js";
22
22
  import { L as b } from "../like-anchor-CgqCU210.js";
23
23
  import { S as g, E as f } from "../sized-mixin-cJbo3PKR.js";
24
24
  const s = () => {
@@ -17,7 +17,7 @@
17
17
  * */
18
18
  import { unsafeCSS as u, html as b } from "lit";
19
19
  import { property as c } from "lit/decorators.js";
20
- import { L as s } from "../base-DA-IfpPk.js";
20
+ import { a as s } from "../base-BUViEg_7.js";
21
21
  import { O as m } from "../observe-slot-text-DorVpCL4.js";
22
22
  import { S as z } from "../sized-mixin-cJbo3PKR.js";
23
23
  const g = () => {
@@ -91,6 +91,6 @@ function f(i) {
91
91
  class b extends f(u) {
92
92
  }
93
93
  export {
94
- b as L,
95
- f as a
94
+ f as L,
95
+ b as a
96
96
  };
@@ -17,11 +17,11 @@
17
17
  * */
18
18
  import { unsafeCSS as d, html as i } from "lit";
19
19
  import { property as n } from "lit/decorators.js";
20
- import { P as h } from "../pending-state-CkX6x_ad.js";
20
+ import { P as h } from "../pending-state-DEYcMdvk.js";
21
21
  import { S as s } from "../sized-mixin-cJbo3PKR.js";
22
- import { L as v } from "../button-base-CAXH68Sp.js";
22
+ import { L as v } from "../button-base-npzdrTiY.js";
23
23
  import { luzmoIcon as f, luzmoClear12 as z, luzmoClear as p, luzmoClear14 as k } from "@luzmo/icons";
24
- import { L as w } from "../close-button-1l5b3LRg.js";
24
+ import { L as w } from "../close-button-po7k74tH.js";
25
25
  const m = () => {
26
26
  if (typeof document < "u" && !document.querySelector("style[data-luzmo-vars]")) {
27
27
  const t = document.createElement("style");
@@ -17,7 +17,7 @@
17
17
  * */
18
18
  import { unsafeCSS as c, html as i } from "lit";
19
19
  import { property as h, query as u } from "lit/decorators.js";
20
- import { F as p } from "./focusable-DMl8nuHx.js";
20
+ import { F as p } from "./focusable-BM1nd-dI.js";
21
21
  import { L as d } from "./like-anchor-CgqCU210.js";
22
22
  import { O as b } from "./observe-slot-text-DorVpCL4.js";
23
23
  const f = ":host{display:inline-flex;vertical-align:top;--parent-element-progress-circle-size: 18px;--icon-size: 16px}:host([dir]){-webkit-appearance:none}:host([disabled]){pointer-events:none;cursor:auto}#button{position:absolute;top:0;right:0;bottom:0;left:0}::slotted(luzmo-overlay),::slotted(luzmo-tooltip){position:absolute}:host:after{pointer-events:none}::slotted(*){pointer-events:none}::slotted([slot=icon]){--luzmo-icon-vertical-align: 0}slot[name=icon]::slotted(svg),slot[name=icon]::slotted(img){fill:currentcolor;stroke:currentcolor;block-size:var(--luzmo-button-icon-size, var(--icon-size));inline-size:var(--luzmo-button-icon-size, var(--icon-size))}[icon-only]+#label{display:contents}:host([size=s]){--parent-element-progress-circle-size: 16px;--icon-size: 14px}:host([size=l]){--parent-element-progress-circle-size: 20px;--icon-size: 18px}:host([size=xl]){--parent-element-progress-circle-size: 22px;--icon-size: 20px}";
@@ -17,7 +17,7 @@
17
17
  * */
18
18
  import { unsafeCSS as i, html as a } from "lit";
19
19
  import { property as s } from "lit/decorators.js";
20
- import { L as z } from "../base-DA-IfpPk.js";
20
+ import { a as z } from "../base-BUViEg_7.js";
21
21
  import { S as g } from "../sized-mixin-cJbo3PKR.js";
22
22
  const c = () => {
23
23
  if (typeof document < "u" && !document.querySelector("style[data-luzmo-vars]")) {
@@ -13,7 +13,15 @@ export interface DateCellProperties {
13
13
  isSelected: boolean;
14
14
  isDisabled: boolean;
15
15
  isTabbable: boolean;
16
+ isRangeSelection: boolean;
17
+ isRangeStart: boolean;
18
+ isRangeEnd: boolean;
19
+ isSelectionStart: boolean;
20
+ isSelectionEnd: boolean;
16
21
  }
22
+ export type CalendarSelectionMode = 'single' | 'range';
23
+ export type CalendarViewMode = 'days' | 'years';
24
+ export declare const YEARS_PER_PAGE = 16;
17
25
  export interface CalendarLabels {
18
26
  previous: string;
19
27
  next: string;
@@ -60,6 +68,20 @@ export declare class LuzmoCalendar extends LuzmoCalendar_base {
60
68
  * and can be overridden to localize the content.
61
69
  */
62
70
  labels: CalendarLabels;
71
+ /**
72
+ * Selection mode: 'single' for a single date, 'range' for start/end date selection.
73
+ */
74
+ selectionMode: CalendarSelectionMode;
75
+ /**
76
+ * The start date of the range selection (ISO date string, e.g. '2024-01-15').
77
+ * Only used when selectionMode is 'range'.
78
+ */
79
+ startDate?: string;
80
+ /**
81
+ * The end date of the range selection (ISO date string, e.g. '2024-01-20').
82
+ * Only used when selectionMode is 'range'.
83
+ */
84
+ endDate?: string;
63
85
  /**
64
86
  * The date that indicates the current position in the calendar.
65
87
  * @internal
@@ -95,6 +117,32 @@ export declare class LuzmoCalendar extends LuzmoCalendar_base {
95
117
  * @internal
96
118
  */
97
119
  private _max?;
120
+ /**
121
+ * Parsed start date for range selection
122
+ * @internal
123
+ */
124
+ private _startDate?;
125
+ /**
126
+ * Parsed end date for range selection
127
+ * @internal
128
+ */
129
+ private _endDate?;
130
+ /**
131
+ * The date being hovered, used for range preview between start and end
132
+ * during range selection. Can be set externally to synchronize hover
133
+ * previews across multiple calendar instances.
134
+ */
135
+ hoveredDate?: CalendarDate;
136
+ /**
137
+ * Current view mode: 'days' shows month grid, 'years' shows year grid
138
+ * @internal
139
+ */
140
+ private viewMode;
141
+ /**
142
+ * The base year for the year grid view (start of the displayed range)
143
+ * @internal
144
+ */
145
+ private yearGridStart;
98
146
  /**
99
147
  * The weekdays of the calendar, narrow and long
100
148
  * @internal
@@ -133,7 +181,9 @@ export declare class LuzmoCalendar extends LuzmoCalendar_base {
133
181
  * Useful while navigating through the calendar as the focus might be lost when the month changes.
134
182
  */
135
183
  private focusCurrentDate;
184
+ private parseDateOnly;
136
185
  private convertToCalendarDates;
186
+ private convertRangeDates;
137
187
  /**
138
188
  * Validates the component's date properties (min, max and value) compliance with one another.
139
189
  * If the [min, max] constraint interval is invalid, both properties are reset.
@@ -174,9 +224,18 @@ export declare class LuzmoCalendar extends LuzmoCalendar_base {
174
224
  private renderCalendarWeeks;
175
225
  private renderDatesInWeek;
176
226
  private parseDateCellProperties;
227
+ private computeRangeFlags;
177
228
  protected renderCalendarTableCell(calendarDate: CalendarDate): TemplateResult;
178
229
  private handleKeydown;
179
230
  private handleDaySelect;
231
+ private handleRangeSelect;
232
+ private handleDayHover;
233
+ private toggleViewMode;
234
+ private handlePreviousYearPage;
235
+ private handleNextYearPage;
236
+ private handleYearSelect;
237
+ private renderYearGrid;
238
+ private handleYearGridKeydown;
180
239
  private moveToPreviousDay;
181
240
  private moveToNextDay;
182
241
  private moveToPreviousWeek;
@@ -212,7 +271,9 @@ export declare class LuzmoCalendar extends LuzmoCalendar_base {
212
271
  * @internal
213
272
  */
214
273
  private numberFormatter;
274
+ private yearFormatter;
215
275
  private setNumberFormatter;
216
276
  private formatNumber;
277
+ private formatYear;
217
278
  }
218
279
  export {};
@@ -15,15 +15,23 @@
15
15
  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
16
16
  * SOFTWARE.
17
17
  * */
18
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("@internationalized/date"),v=require("@internationalized/number"),s=require("lit"),p=require("lit/directives/class-map.js"),z=require("lit/directives/if-defined.js"),f=require("../base-DxRGeCrb.cjs"),x=require("../sized-mixin-DcvJLFeo.cjs");require("../action-button/index.cjs");require("../icon/index.cjs");const m=require("@luzmo/icons"),d=require("lit/decorators.js"),w=':host{inline-size:var(--luzmo-calendar-width, var(--calendar-width));display:inline-block}.header{inline-size:100%;align-items:center;display:flex}.title{color:var(--highcontrast-calendar-date-text-color, var(--luzmo-calendar-date-text-color, var(--calendar-date-text-color)));font-size:var(--luzmo-calendar-title-text-size, var(--calendar-title-text-size));font-weight:var(--luzmo-calendar-title-font-weight, var(--calendar-title-font-weight));line-height:var(--luzmo-calendar-title-height, var(--calendar-title-height));text-align:center;white-space:nowrap;text-overflow:ellipsis;flex-grow:1;order:1;margin:0;overflow:hidden}.nextMonth,.prevMonth{transform:var(--logical-rotation)}.nextMonth:not([disabled]),.prevMonth:not([disabled]){color:var(--highcontrast-calendar-button-icon-color, var(--luzmo-calendar-button-icon-color, var(--calendar-button-icon-color)))}.prevMonth{order:0}.nextMonth{order:2}.dayOfWeek{inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));color:var(--highcontrast-calendar-day-title-text-color, var(--luzmo-calendar-day-title-text-color, var(--calendar-day-title-text-color)));font-size:var(--luzmo-calendar-day-title-text-size, var(--calendar-day-title-text-size));font-weight:var(--luzmo-calendar-day-title-text-font-weight, var(--calendar-day-title-text-font-weight));text-transform:uppercase;cursor:default;flex-direction:column;justify-content:flex-end;display:flex;border-block-end:none!important;-webkit-text-decoration:none!important;text-decoration:none!important}:host([title]) .dayOfWeek{text-decoration:underline;letter-spacing:var(--luzmo-calendar-title-text-letter-spacing, var(--calendar-title-text-letter-spacing));border-block-end:none;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.body{outline:none}.table{table-layout:fixed;border-collapse:collapse;border-spacing:0;-webkit-user-select:none;user-select:none}.table-cell{text-align:center;box-sizing:initial;block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));padding:var(--luzmo-calendar-day-padding, var(--calendar-day-padding));position:relative}.table-cell:focus{outline:0}.date{box-sizing:border-box;block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));margin:var(--luzmo-calendar-day-padding, var(--calendar-day-padding));border-radius:var(--luzmo-calendar-day-border-radius, var(--calendar-day-border-radius));border:var(--luzmo-calendar-day-border-size, var(--calendar-day-border-size)) solid transparent;font-size:var(--luzmo-calendar-day-text-size, var(--calendar-day-text-size));line-height:calc(var(--luzmo-calendar-day-width, var(--calendar-day-width)) - var(--luzmo-calendar-day-border-size, var(--calendar-day-border-size)) * 2);white-space:nowrap;cursor:pointer;display:block;position:absolute;inset-block-start:0;inset-inline-start:0}.date:lang(ja),.date:lang(ko),.date:lang(zh){font-size:var(--luzmo-calendar-day-text-size-han, var(--calendar-day-text-size-han))}.date.is-disabled{cursor:default;pointer-events:none}.date.is-outsideMonth{display:none}.date:before{content:"";box-sizing:border-box;inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));border-radius:var(--luzmo-calendar-day-border-radius, var(--calendar-day-border-radius));border:var(--luzmo-calendar-day-border-size, var(--calendar-day-border-size)) solid transparent;position:absolute;inset-block-start:calc(50% - var(--luzmo-calendar-day-width, var(--calendar-day-width)) / 2);inset-inline-start:calc(50% - var(--luzmo-calendar-day-width, var(--calendar-day-width)) / 2)}.date.is-selected:not(.is-range-selection){font-weight:var(--luzmo-calendar-day-text-font-weight-selected, var(--calendar-day-text-font-weight-selected))}.date.is-selected:not(.is-range-selection):before{display:none}.date.is-today{font-weight:var(--luzmo-calendar-day-today-text-font-weight, var(--calendar-day-today-text-font-weight))}.date.is-range-selection{margin:var(--luzmo-calendar-day-padding, var(--calendar-day-padding)) 0;border-width:var(--luzmo-calendar-border-width-reset, var(--calendar-border-width-reset));line-height:var(--luzmo-calendar-day-height, var(--calendar-day-height));border-radius:var(--luzmo-calendar-border-radius-reset, var(--calendar-border-radius-reset));inline-size:calc(var(--luzmo-calendar-day-width, var(--calendar-day-width)) + var(--luzmo-calendar-day-padding, var(--calendar-day-padding)) * 2)}.date.is-range-selection.is-range-end,.date.is-range-selection.is-range-start,.date.is-range-selection.is-selection-end,.date.is-range-selection.is-selection-start{inline-size:calc(var(--luzmo-calendar-day-width, var(--calendar-day-width)) + var(--luzmo-calendar-day-padding, var(--calendar-day-padding)))}.date.is-range-selection.is-selection-end,.date.is-range-selection.is-selection-start{font-weight:var(--luzmo-calendar-day-text-font-weight-cap-selected, var(--calendar-day-text-font-weight-cap-selected))}.date.is-range-selection.is-selection-end:after,.date.is-range-selection.is-selection-start:after{block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));border-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));content:"";display:block;position:absolute;inset-block-start:0}.date.is-range-selection.is-range-start,.date.is-range-selection.is-selection-start{border-start-start-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));border-end-start-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));margin-inline-start:var(--luzmo-calendar-day-padding, var(--calendar-day-padding));padding-inline-end:var(--luzmo-calendar-day-padding, var(--calendar-day-padding))}.date.is-range-selection.is-range-start:after,.date.is-range-selection.is-range-start:before,.date.is-range-selection.is-selection-start:after,.date.is-range-selection.is-selection-start:before{inset-inline-start:0}.date.is-range-selection.is-range-end,.date.is-range-selection.is-selection-end{border-start-end-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));border-end-end-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));margin-inline-end:var(--luzmo-calendar-day-padding, var(--calendar-day-padding));padding-inline-start:var(--luzmo-calendar-day-padding, var(--calendar-day-padding))}.date.is-range-selection.is-range-end:after,.date.is-range-selection.is-range-end:before,.date.is-range-selection.is-selection-end:after,.date.is-range-selection.is-selection-end:before{inset-inline:auto 0}.date.is-range-selection.is-range-start.is-range-end,.date.is-range-selection.is-selection-end.is-range-start,.date.is-range-selection.is-selection-start.is-range-end,.date.is-range-selection.is-selection-start.is-selection-end{inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));border-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width))}.date{color:var(--highcontrast-calendar-day-text-color, var(--luzmo-calendar-day-text-color, var(--calendar-day-text-color)))}.date:active{background-color:var(--highcontrast-calendar-day-background-color-down, var(--luzmo-calendar-day-background-color-down, var(--calendar-day-background-color-down)))}.date.is-selected{color:var(--highcontrast-calendar-day-text-color-selected, var(--luzmo-calendar-day-text-color-selected, var(--calendar-day-text-color-selected)));background:var(--highcontrast-calendar-day-background-color-selected, var(--luzmo-calendar-day-background-color-selected, var(--calendar-day-background-color-selected)))}.date.is-selected:not(.is-range-selection){background:var(--highcontrast-calendar-day-background-color-cap-selected, var(--luzmo-calendar-day-background-color-cap-selected, var(--calendar-day-background-color-cap-selected)));color:var(--highcontrast-calendar-day-text-color-cap-selected, var(--luzmo-calendar-day-text-color-cap-selected, var(--calendar-day-text-color-cap-selected)));border-color:var(--highcontrast-calendar-day-border-color-cap-selected, var(--luzmo-calendar-day-border-color-cap-selected, var(--calendar-day-border-color-cap-selected)))}.date.is-today{color:var(--highcontrast-calendar-day-today-text-color, var(--luzmo-calendar-day-today-text-color, var(--calendar-day-today-text-color)));background-color:var(--highcontrast-calendar-day-today-background-color, var(--luzmo-calendar-day-today-background-color, var(--calendar-day-today-background-color)))}.date.is-today,.date.is-today:before{border-color:var(--highcontrast-calendar-day-today-border-color, var(--luzmo-calendar-day-today-border-color, var(--calendar-day-today-border-color)))}@media (hover: hover){.date:hover{color:var(--highcontrast-calendar-day-text-color-hover, var(--luzmo-calendar-day-text-color-hover, var(--calendar-day-text-color-hover)))}.date:hover:not(.is-selection-end,.is-selection-start):before{background:var(--highcontrast-calendar-day-background-color-hover, var(--luzmo-calendar-day-background-color-hover, var(--calendar-day-background-color-hover)))}.date.is-range-selection:hover:before,.date.is-selected:hover:not(.is-selection-end,.is-selection-start):before{background:var(--highcontrast-calendar-day-background-color-selected-hover, var(--luzmo-calendar-day-background-color-selected-hover, var(--calendar-day-background-color-selected-hover)))}.date.is-today.is-selected:not(.is-range-selection):hover:before{background:var(--highcontrast-calendar-day-today-background-color-selected-hover, var(--luzmo-calendar-day-today-background-color-selected-hover, var(--calendar-day-today-background-color-selected-hover)))}}.date.is-today.is-disabled{color:var(--highcontrast-calendar-day-today-text-color-disabled, var(--luzmo-calendar-day-today-text-color-disabled, var(--calendar-day-today-text-color-disabled)))}.date.is-today.is-disabled,.date.is-today.is-disabled:before{border-color:var(--highcontrast-calendar-day-today-border-color-disabled, var(--luzmo-calendar-day-today-border-color-disabled, var(--calendar-day-today-border-color-disabled)))}.table-cell:focus-within .date:not(.is-range-selection){background:var(--highcontrast-calendar-day-background-color-key-focus, var(--luzmo-calendar-day-background-color-key-focus, var(--calendar-day-background-color-key-focus)));color:var(--highcontrast-calendar-day-text-color-key-focus, var(--luzmo-calendar-day-text-color-key-focus, var(--calendar-day-text-color-key-focus)))}.table-cell:focus-within .date.is-selected:not(.is-range-selection),.table-cell:focus-within .date.is-today:not(.is-range-selection),.table-cell:focus-within .date:not(.is-range-selection),.table-cell:focus-within .date:not(.is-range-selection):active{border-color:var(--highcontrast-calendar-day-border-color-key-focus, var(--luzmo-calendar-day-border-color-key-focus, var(--calendar-day-border-color-key-focus)))}.table-cell:focus-within .date.is-selected:not(.is-range-selection),.table-cell:focus-within .date:not(.is-range-selection):active{color:var(--highcontrast-calendar-day-text-color-selected, var(--luzmo-calendar-day-text-color-selected, var(--calendar-day-text-color-selected)));background:var(--highcontrast-calendar-day-background-color-cap-selected, var(--luzmo-calendar-day-background-color-cap-selected, var(--calendar-day-background-color-cap-selected)));border-color:var(--highcontrast-calendar-day-border-color-key-focus, var(--luzmo-calendar-day-border-color-cap-selected-focus, var(--calendar-day-border-color-cap-selected-focus)))}.table-cell:focus-within .date.is-range-selection:before,.table-cell:focus-within .date.is-selected:before{background:var(--highcontrast-calendar-day-background-color-selected-hover, var(--luzmo-calendar-day-background-color-selected-hover, var(--calendar-day-background-color-selected-hover)))}.table-cell:focus-within .date:before{border-color:var(--highcontrast-calendar-day-border-color-key-focus, var(--luzmo-calendar-day-border-color-key-focus, var(--calendar-day-border-color-key-focus)))}.date.is-disabled{color:var(--highcontrast-calendar-day-text-color-disabled, var(--luzmo-calendar-day-text-color-disabled, var(--calendar-day-text-color-disabled)))}.date.is-selection-end,.date.is-selection-start{color:var(--highcontrast-calendar-day-text-color-cap-selected, var(--luzmo-calendar-day-text-color-cap-selected, var(--calendar-day-text-color-cap-selected)))}.date.is-selection-end:after,.date.is-selection-start:after{background-color:var(--highcontrast-calendar-day-background-color-selected, var(--luzmo-calendar-day-background-color-selected, var(--calendar-day-background-color-selected)))}.date.is-selection-end.is-disabled,.date.is-selection-start.is-disabled{color:var(--highcontrast-calendar-day-text-color-disabled, var(--luzmo-calendar-day-text-color-disabled, var(--calendar-day-text-color-disabled)))}@media (forced-colors: active){.nextMonth,.prevMonth{--highcontrast-calendar-button-icon-color: ButtonText}.date{--highcontrast-calendar-day-background-color-cap-selected: Highlight;--highcontrast-calendar-day-background-color-down: ButtonFace;--highcontrast-calendar-day-background-color-hover: Transparent;--highcontrast-calendar-day-background-color-key-focus: ButtonFace;--highcontrast-calendar-day-background-color-selected-hover: Transparent;--highcontrast-calendar-day-background-color-selected: Highlight;--highcontrast-calendar-day-border-color-key-focus: ButtonText;--highcontrast-calendar-day-text-color-cap-selected: HighlightText;--highcontrast-calendar-day-text-color-disabled: GrayText;--highcontrast-calendar-day-text-color-hover: ButtonText;--highcontrast-calendar-day-text-color-key-focus: ButtonText;--highcontrast-calendar-day-text-color-selected: HighlightText;--highcontrast-calendar-day-text-color: CanvasText;--highcontrast-calendar-date-text-color: CanvasText;--highcontrast-calendar-day-title-text-color: CanvasText;--highcontrast-calendar-day-today-background-color-selected-hover: Highlight;--highcontrast-calendar-day-today-border-color-disabled: GrayText;--highcontrast-calendar-day-today-border-color: ButtonText;--highcontrast-calendar-day-today-text-color-disabled: GrayText;--highcontrast-calendar-day-today-text-color: ButtonText;forced-color-adjust:none}.date.is-range-selection.is-today{color:HighlightText}.date.is-range-selection.is-selection-end:after,.date.is-range-selection.is-selection-start:after{content:none}.date.is-disabled.is-range-selection,.date.is-disabled.is-selected{background:Highlight;color:HighlightText}}:host{--calendar-background-color: var(--luzmo-background-color-white)}:host{font-family:var(--luzmo-font-family);--calendar-day-width: var(--luzmo-component-height);--calendar-day-height: var(--luzmo-component-height);--calendar-border-radius-reset: 0;--calendar-border-width-reset: 0;--calendar-day-border-size: var(--luzmo-border-width);--calendar-margin-y: calc(var(--luzmo-spacing) * 3);--calendar-margin-x: var(--luzmo-component-height);--calendar-day-padding: var(--luzmo-spacing-2);--calendar-width: calc( (var(--calendar-day-width) + var(--calendar-day-padding) * 2) * 7 );--calendar-title-text-letter-spacing: .06em;--calendar-day-title-text-font-weight: bold;--calendar-day-title-text-color: var(--luzmo-font-color-disabled);--calendar-title-height: var(--luzmo-component-height);--calendar-title-font-weight: bold;--calendar-title-text-size: var(--luzmo-font-size);--calendar-day-title-text-size: var(--luzmo-font-size);--calendar-day-text-size-han: var(--luzmo-font-size);--calendar-date-text-color: var(--luzmo-font-color);--calendar-day-text-color: var(--luzmo-font-color);--calendar-day-text-size: var(--luzmo-font-size);--calendar-day-border-radius: var(--luzmo-border-radius);--calendar-day-text-color-selected: var(--luzmo-primary-inverse-color);--calendar-day-text-color-hover: var(--luzmo-font-color-hover);--calendar-day-text-color-cap-selected: var(--luzmo-primary-inverse-color);--calendar-day-border-color-cap-selected: var(--luzmo-primary);--calendar-day-border-color-cap-selected-focus: var(--luzmo-primary-focus);--calendar-day-text-font-weight-selected: var(--bold-font-weight);--calendar-day-text-font-weight-cap-selected: var(--bold-font-weight);--calendar-day-today-text-color: var(--luzmo-primary);--calendar-day-today-background-color: var(--luzmo-background-color-hover);--calendar-day-today-text-font-weight: normal;--calendar-day-today-border-color: transparent;--calendar-day-today-text-color-disabled: var(--luzmo-font-color-disabled);--calendar-day-today-border-color-disabled: transparent;--calendar-day-text-color-disabled: var(--luzmo-font-color-disabled);--calendar-day-text-color-key-focus: var(--luzmo-primary-down);--calendar-day-background-color-cap-selected: var(--luzmo-primary);--calendar-button-icon-color: var(--luzmo-font-color)}:host:dir(rtl),:host([dir=rtl]){--logical-rotation: matrix(-1, 0, 0, 1, 0, 0)}:host([size=s]){--calendar-day-width: var(--luzmo-component-height-s);--calendar-day-height: var(--luzmo-component-height-s);--calendar-day-border-radius: var(--luzmo-border-radius-s);--calendar-title-height: var(--luzmo-component-height-s);--calendar-title-text-size: var(--luzmo-font-size-s);--calendar-day-title-text-size: var(--luzmo-font-size-s);--calendar-day-text-size-han: var(--luzmo-font-size-s);--calendar-day-text-size: var(--luzmo-font-size-s)}:host([size=l]){--calendar-day-width: var(--luzmo-component-height-l);--calendar-day-height: var(--luzmo-component-height-l);--calendar-day-border-radius: var(--luzmo-border-radius-l);--calendar-title-height: var(--luzmo-component-height-l);--calendar-title-text-size: var(--luzmo-font-size-l);--calendar-day-title-text-size: var(--luzmo-font-size-l);--calendar-day-text-size-han: var(--luzmo-font-size-l);--calendar-day-text-size: var(--luzmo-font-size-l)}:host([size=xl]){--calendar-day-width: var(--luzmo-component-height-xl);--calendar-day-height: var(--luzmo-component-height-xl);--calendar-day-border-radius: var(--luzmo-border-radius-xl);--calendar-title-height: var(--luzmo-component-height-xl);--calendar-title-text-size: var(--luzmo-font-size-xl);--calendar-day-title-text-size: var(--luzmo-font-size-xl);--calendar-day-text-size-han: var(--luzmo-font-size-xl);--calendar-day-text-size: var(--luzmo-font-size-xl)}.table-cell span[role=button]{border-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width))}';var k=Object.defineProperty,D=Object.getOwnPropertyDescriptor,l=(h,e,a,r)=>{for(var o=r>1?void 0:r?D(e,a):e,i=h.length-1,c;i>=0;i--)(c=h[i])&&(o=(r?c(e,a,o):c(o))||o);return r&&o&&k(e,a,o),o};const g=7;class n extends x.SizedMixin(f.LuzmoElement,{validSizes:["s","m","l","xl"],noDefaultSize:!0}){constructor(){super(),this.disabled=!1,this.labels={previous:"Previous",next:"Next",today:"Today",selected:"Selected"},this.currentDate=this.today,this.timeZone=t.getLocalTimeZone(),this.weekdays=[],this.currentMonthDates=[],this._isDateFocusIntent=!1,this.numberFormatter=new v.NumberFormatter(this._language),this.setNumberFormatter(),this.setWeekdays(),this.setCurrentMonthDates()}static get styles(){return[s.unsafeCSS(w)]}get _language(){try{return this.language?new Intl.Locale(this.language).language:"en"}catch{return"en"}}get today(){return t.today(this.timeZone)}set isDateFocusIntent(e){this._isDateFocusIntent!==e&&(this._isDateFocusIntent=e,this.requestUpdate("isDateFocusIntent",!e))}get isDateFocusIntent(){return this._isDateFocusIntent}setDateFocusIntent(){this.isDateFocusIntent=!0}resetDateFocusIntent(){this.isDateFocusIntent=!1}connectedCallback(){super.connectedCallback(),document.addEventListener("mousedown",this.resetDateFocusIntent)}disconnectedCallback(){super.disconnectedCallback(),document.removeEventListener("mousedown",this.resetDateFocusIntent)}clear(){this._value=void 0}willUpdate(e){e.has("language")&&(this.setNumberFormatter(),this.setWeekdays(),this.setCurrentMonthDates());const a=e.has("min"),r=e.has("max"),o=e.has("value");(a||r||o)&&(this.convertToCalendarDates(),this.checkDatePropsCompliance(a||r),this.updateCurrentDate());const c=e.get("currentDate");e.has("currentDate")&&(!c||!t.isSameMonth(c,this.currentDate))&&(this.setCurrentMonthDates(),this.setAttribute("aria-label",this.monthAndYear))}updated(e){e.has("currentDate")&&this.isDateFocusIntent&&this.focusCurrentDate()}focusCurrentDate(){var a;const e=(a=this.shadowRoot)==null?void 0:a.querySelector('td span[tabindex="0"]');e&&e.focus()}convertToCalendarDates(){this._min=this.min?t.parseDate(this.min):void 0,this._max=this.max?t.parseDate(this.max):void 0,this._value=this.value?t.parseDate(this.value):void 0;const e="AD";this._min=this._min&&t.toCalendarDate(this._min).set({era:e}),this._max=this._max&&t.toCalendarDate(this._max).set({era:e}),this._value=this._value&&t.toCalendarDate(this._value).set({era:e})}checkDatePropsCompliance(e){e&&this._min&&this._max&&(this._min.compare(this._max)<0||(console.warn&&console.warn(this,`<${this.localName}> expects the 'min' to be less than 'max'. Please ensure that 'min' property's date is earlier than 'max' property's date.`),this._min=void 0,this._max=void 0)),this._value&&this.isNonCompliantDate(this._value)&&(console.warn&&console.warn(this,`<${this.localName}> expects the preselected value to comply with the min and max constraints. Please ensure that 'value' property's date is in between the dates for the 'min' and 'max' properties.`),this._value=void 0)}updateCurrentDate(){if(this._value){this.currentDate=this._value;return}this.isNonCompliantDate(this.today)?this._min?this.currentDate=this._min:this._max&&(this.currentDate=this._max):this.currentDate=this.today}isNonCompliantDate(e){return!!(this._min&&e.compare(this._min)<0||this._max&&e.compare(this._max)>0)}render(){return s.html` ${this.renderCalendarHeader()}${this.renderCalendarGrid()} `}get monthAndYear(){return this.formatDate(this.currentDate,{month:"long",year:"numeric"})}renderCalendarHeader(){return s.html`
18
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("@internationalized/date"),g=require("@internationalized/number"),c=require("lit"),f=require("lit/directives/class-map.js"),M=require("lit/directives/if-defined.js"),_=require("../base-DxRGeCrb.cjs"),C=require("../sized-mixin-DcvJLFeo.cjs");require("../action-button/index.cjs");require("../icon/index.cjs");const z=require("@luzmo/icons"),i=require("lit/decorators.js"),T=':host{inline-size:var(--luzmo-calendar-width, var(--calendar-width));display:inline-block}.header{inline-size:100%;align-items:center;display:flex}.title{color:var(--highcontrast-calendar-date-text-color, var(--luzmo-calendar-date-text-color, var(--calendar-date-text-color)));font-size:var(--luzmo-calendar-title-text-size, var(--calendar-title-text-size));font-weight:var(--luzmo-calendar-title-font-weight, var(--calendar-title-font-weight));line-height:var(--luzmo-calendar-title-height, var(--calendar-title-height));text-align:center;white-space:nowrap;text-overflow:ellipsis;flex-grow:1;order:1;margin:0;overflow:hidden}.nextMonth,.prevMonth{transform:var(--logical-rotation)}.nextMonth:not([disabled]),.prevMonth:not([disabled]){color:var(--highcontrast-calendar-button-icon-color, var(--luzmo-calendar-button-icon-color, var(--calendar-button-icon-color)))}.prevMonth{order:0}.nextMonth{order:2}.dayOfWeek{inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));color:var(--highcontrast-calendar-day-title-text-color, var(--luzmo-calendar-day-title-text-color, var(--calendar-day-title-text-color)));font-size:var(--luzmo-calendar-day-title-text-size, var(--calendar-day-title-text-size));font-weight:var(--luzmo-calendar-day-title-text-font-weight, var(--calendar-day-title-text-font-weight));text-transform:uppercase;cursor:default;flex-direction:column;justify-content:flex-end;display:flex;border-block-end:none!important;-webkit-text-decoration:none!important;text-decoration:none!important}:host([title]) .dayOfWeek{text-decoration:underline;letter-spacing:var(--luzmo-calendar-title-text-letter-spacing, var(--calendar-title-text-letter-spacing));border-block-end:none;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.body{outline:none}.table{table-layout:fixed;border-collapse:collapse;border-spacing:0;-webkit-user-select:none;user-select:none}.table-cell{text-align:center;box-sizing:initial;block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));padding:var(--luzmo-calendar-day-padding, var(--calendar-day-padding));position:relative}.table-cell:focus{outline:0}.date{box-sizing:border-box;block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));margin:var(--luzmo-calendar-day-padding, var(--calendar-day-padding));border-radius:var(--luzmo-calendar-day-border-radius, var(--calendar-day-border-radius));border:var(--luzmo-calendar-day-border-size, var(--calendar-day-border-size)) solid transparent;font-size:var(--luzmo-calendar-day-text-size, var(--calendar-day-text-size));line-height:calc(var(--luzmo-calendar-day-width, var(--calendar-day-width)) - var(--luzmo-calendar-day-border-size, var(--calendar-day-border-size)) * 2);white-space:nowrap;cursor:pointer;display:block;position:absolute;inset-block-start:0;inset-inline-start:0}.date:lang(ja),.date:lang(ko),.date:lang(zh){font-size:var(--luzmo-calendar-day-text-size-han, var(--calendar-day-text-size-han))}.date.is-disabled{cursor:default;pointer-events:none}.date.is-outsideMonth{display:none}.date:before{content:"";box-sizing:border-box;inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));border-radius:var(--luzmo-calendar-day-border-radius, var(--calendar-day-border-radius));border:var(--luzmo-calendar-day-border-size, var(--calendar-day-border-size)) solid transparent;position:absolute;inset-block-start:calc(50% - var(--luzmo-calendar-day-width, var(--calendar-day-width)) / 2);inset-inline-start:calc(50% - var(--luzmo-calendar-day-width, var(--calendar-day-width)) / 2)}.date.is-selected:not(.is-range-selection){font-weight:var(--luzmo-calendar-day-text-font-weight-selected, var(--calendar-day-text-font-weight-selected))}.date.is-selected:not(.is-range-selection):before{display:none}.date.is-today{font-weight:var(--luzmo-calendar-day-today-text-font-weight, var(--calendar-day-today-text-font-weight))}.date.is-range-selection{margin:var(--luzmo-calendar-day-padding, var(--calendar-day-padding)) 0;border-width:var(--luzmo-calendar-border-width-reset, var(--calendar-border-width-reset));line-height:var(--luzmo-calendar-day-height, var(--calendar-day-height));border-radius:var(--luzmo-calendar-border-radius-reset, var(--calendar-border-radius-reset));inline-size:calc(var(--luzmo-calendar-day-width, var(--calendar-day-width)) + var(--luzmo-calendar-day-padding, var(--calendar-day-padding)) * 2)}.date.is-range-selection.is-range-end,.date.is-range-selection.is-range-start,.date.is-range-selection.is-selection-end,.date.is-range-selection.is-selection-start{inline-size:calc(var(--luzmo-calendar-day-width, var(--calendar-day-width)) + var(--luzmo-calendar-day-padding, var(--calendar-day-padding)))}.date.is-range-selection.is-selection-end,.date.is-range-selection.is-selection-start{font-weight:var(--luzmo-calendar-day-text-font-weight-cap-selected, var(--calendar-day-text-font-weight-cap-selected))}.date.is-range-selection.is-selection-end,.date.is-range-selection.is-selection-start{z-index:0}.date.is-range-selection.is-selection-end:after,.date.is-range-selection.is-selection-start:after{block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));border-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));content:"";display:block;position:absolute;inset-block-start:0;z-index:-1}.date.is-range-selection.is-range-start,.date.is-range-selection.is-selection-start{border-start-start-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));border-end-start-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));margin-inline-start:var(--luzmo-calendar-day-padding, var(--calendar-day-padding));padding-inline-end:var(--luzmo-calendar-day-padding, var(--calendar-day-padding))}.date.is-range-selection.is-range-start:after,.date.is-range-selection.is-range-start:before,.date.is-range-selection.is-selection-start:after,.date.is-range-selection.is-selection-start:before{inset-inline-start:0}.date.is-range-selection.is-range-end,.date.is-range-selection.is-selection-end{border-start-end-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));border-end-end-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width));margin-inline-end:var(--luzmo-calendar-day-padding, var(--calendar-day-padding));padding-inline-start:var(--luzmo-calendar-day-padding, var(--calendar-day-padding))}.date.is-range-selection.is-range-end:after,.date.is-range-selection.is-range-end:before,.date.is-range-selection.is-selection-end:after,.date.is-range-selection.is-selection-end:before{inset-inline:auto 0}.date.is-range-selection.is-range-start.is-range-end,.date.is-range-selection.is-selection-end.is-range-start,.date.is-range-selection.is-selection-start.is-range-end,.date.is-range-selection.is-selection-start.is-selection-end{inline-size:var(--luzmo-calendar-day-width, var(--calendar-day-width));border-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width))}.date{color:var(--highcontrast-calendar-day-text-color, var(--luzmo-calendar-day-text-color, var(--calendar-day-text-color)))}.date:active{background-color:var(--highcontrast-calendar-day-background-color-down, var(--luzmo-calendar-day-background-color-down, var(--calendar-day-background-color-down)))}.date.is-selected{color:var(--highcontrast-calendar-day-text-color-selected, var(--luzmo-calendar-day-text-color-selected, var(--calendar-day-text-color-selected)));background:var(--highcontrast-calendar-day-background-color-selected, var(--luzmo-calendar-day-background-color-selected, var(--calendar-day-background-color-selected)))}.date.is-selected:not(.is-range-selection){background:var(--highcontrast-calendar-day-background-color-cap-selected, var(--luzmo-calendar-day-background-color-cap-selected, var(--calendar-day-background-color-cap-selected)));color:var(--highcontrast-calendar-day-text-color-cap-selected, var(--luzmo-calendar-day-text-color-cap-selected, var(--calendar-day-text-color-cap-selected)));border-color:var(--highcontrast-calendar-day-border-color-cap-selected, var(--luzmo-calendar-day-border-color-cap-selected, var(--calendar-day-border-color-cap-selected)))}.date.is-today{color:var(--highcontrast-calendar-day-today-text-color, var(--luzmo-calendar-day-today-text-color, var(--calendar-day-today-text-color)));background-color:var(--highcontrast-calendar-day-today-background-color, var(--luzmo-calendar-day-today-background-color, var(--calendar-day-today-background-color)))}.date.is-today,.date.is-today:before{border-color:var(--highcontrast-calendar-day-today-border-color, var(--luzmo-calendar-day-today-border-color, var(--calendar-day-today-border-color)))}@media (hover: hover){.date:hover{color:var(--highcontrast-calendar-day-text-color-hover, var(--luzmo-calendar-day-text-color-hover, var(--calendar-day-text-color-hover)))}.date:hover:not(.is-selection-end,.is-selection-start):before{background:var(--highcontrast-calendar-day-background-color-hover, var(--luzmo-calendar-day-background-color-hover, var(--calendar-day-background-color-hover)))}.date.is-range-selection:hover:before,.date.is-selected:hover:not(.is-selection-end,.is-selection-start):before{background:var(--highcontrast-calendar-day-background-color-selected-hover, var(--luzmo-calendar-day-background-color-selected-hover, var(--calendar-day-background-color-selected-hover)))}.date.is-today.is-selected:not(.is-range-selection):hover:before{background:var(--highcontrast-calendar-day-today-background-color-selected-hover, var(--luzmo-calendar-day-today-background-color-selected-hover, var(--calendar-day-today-background-color-selected-hover)))}}.date.is-today.is-disabled{color:var(--highcontrast-calendar-day-today-text-color-disabled, var(--luzmo-calendar-day-today-text-color-disabled, var(--calendar-day-today-text-color-disabled)))}.date.is-today.is-disabled,.date.is-today.is-disabled:before{border-color:var(--highcontrast-calendar-day-today-border-color-disabled, var(--luzmo-calendar-day-today-border-color-disabled, var(--calendar-day-today-border-color-disabled)))}.table-cell:focus-within .date:not(.is-range-selection){background:var(--highcontrast-calendar-day-background-color-key-focus, var(--luzmo-calendar-day-background-color-key-focus, var(--calendar-day-background-color-key-focus)));color:var(--highcontrast-calendar-day-text-color-key-focus, var(--luzmo-calendar-day-text-color-key-focus, var(--calendar-day-text-color-key-focus)))}.table-cell:focus-within .date.is-selected:not(.is-range-selection),.table-cell:focus-within .date.is-today:not(.is-range-selection),.table-cell:focus-within .date:not(.is-range-selection),.table-cell:focus-within .date:not(.is-range-selection):active{border-color:var(--highcontrast-calendar-day-border-color-key-focus, var(--luzmo-calendar-day-border-color-key-focus, var(--calendar-day-border-color-key-focus)))}.table-cell:focus-within .date.is-selected:not(.is-range-selection),.table-cell:focus-within .date:not(.is-range-selection):active{color:var(--highcontrast-calendar-day-text-color-selected, var(--luzmo-calendar-day-text-color-selected, var(--calendar-day-text-color-selected)));background:var(--highcontrast-calendar-day-background-color-cap-selected, var(--luzmo-calendar-day-background-color-cap-selected, var(--calendar-day-background-color-cap-selected)));border-color:var(--highcontrast-calendar-day-border-color-key-focus, var(--luzmo-calendar-day-border-color-cap-selected-focus, var(--calendar-day-border-color-cap-selected-focus)))}.table-cell:focus-within .date.is-range-selection:before,.table-cell:focus-within .date.is-selected:before{background:var(--highcontrast-calendar-day-background-color-selected-hover, var(--luzmo-calendar-day-background-color-selected-hover, var(--calendar-day-background-color-selected-hover)))}.table-cell:focus-within .date:before{border-color:var(--highcontrast-calendar-day-border-color-key-focus, var(--luzmo-calendar-day-border-color-key-focus, var(--calendar-day-border-color-key-focus)))}.date.is-disabled{color:var(--highcontrast-calendar-day-text-color-disabled, var(--luzmo-calendar-day-text-color-disabled, var(--calendar-day-text-color-disabled)))}.date.is-selection-end,.date.is-selection-start{color:var(--highcontrast-calendar-day-text-color-cap-selected, var(--luzmo-calendar-day-text-color-cap-selected, var(--calendar-day-text-color-cap-selected)))}.date.is-range-selection:not(.is-selection-start):not(.is-selection-end){color:var(--highcontrast-calendar-day-text-color, var(--luzmo-calendar-day-text-color-range-selection, var(--calendar-day-text-color-range-selection, var(--calendar-day-text-color))))}.date.is-selection-end:after,.date.is-selection-start:after{background-color:var(--highcontrast-calendar-day-background-color-cap-selected, var(--luzmo-calendar-day-background-color-cap-selected, var(--calendar-day-background-color-cap-selected)))}.date.is-selection-end.is-disabled,.date.is-selection-start.is-disabled{color:var(--highcontrast-calendar-day-text-color-disabled, var(--luzmo-calendar-day-text-color-disabled, var(--calendar-day-text-color-disabled)))}@media (forced-colors: active){.nextMonth,.prevMonth{--highcontrast-calendar-button-icon-color: ButtonText}.date{--highcontrast-calendar-day-background-color-cap-selected: Highlight;--highcontrast-calendar-day-background-color-down: ButtonFace;--highcontrast-calendar-day-background-color-hover: Transparent;--highcontrast-calendar-day-background-color-key-focus: ButtonFace;--highcontrast-calendar-day-background-color-selected-hover: Transparent;--highcontrast-calendar-day-background-color-selected: Highlight;--highcontrast-calendar-day-border-color-key-focus: ButtonText;--highcontrast-calendar-day-text-color-cap-selected: HighlightText;--highcontrast-calendar-day-text-color-disabled: GrayText;--highcontrast-calendar-day-text-color-hover: ButtonText;--highcontrast-calendar-day-text-color-key-focus: ButtonText;--highcontrast-calendar-day-text-color-selected: HighlightText;--highcontrast-calendar-day-text-color: CanvasText;--highcontrast-calendar-date-text-color: CanvasText;--highcontrast-calendar-day-title-text-color: CanvasText;--highcontrast-calendar-day-today-background-color-selected-hover: Highlight;--highcontrast-calendar-day-today-border-color-disabled: GrayText;--highcontrast-calendar-day-today-border-color: ButtonText;--highcontrast-calendar-day-today-text-color-disabled: GrayText;--highcontrast-calendar-day-today-text-color: ButtonText;forced-color-adjust:none}.date.is-range-selection.is-today{color:HighlightText}.date.is-range-selection.is-selection-end:after,.date.is-range-selection.is-selection-start:after{content:none}.date.is-disabled.is-range-selection,.date.is-disabled.is-selected{background:Highlight;color:HighlightText}}:host{--calendar-background-color: var(--luzmo-background-color-white)}:host{font-family:var(--luzmo-font-family);--calendar-day-width: var(--luzmo-component-height);--calendar-day-height: var(--luzmo-component-height);--calendar-border-radius-reset: 0;--calendar-border-width-reset: 0;--calendar-day-border-size: var(--luzmo-border-width);--calendar-margin-y: calc(var(--luzmo-spacing) * 3);--calendar-margin-x: var(--luzmo-component-height);--calendar-day-padding: var(--luzmo-spacing-2);--calendar-width: calc( (var(--calendar-day-width) + var(--calendar-day-padding) * 2) * 7 );--calendar-title-text-letter-spacing: .06em;--calendar-day-title-text-font-weight: bold;--calendar-day-title-text-color: var(--luzmo-font-color-disabled);--calendar-title-height: var(--luzmo-component-height);--calendar-title-font-weight: bold;--calendar-title-text-size: var(--luzmo-font-size);--calendar-day-title-text-size: var(--luzmo-font-size);--calendar-day-text-size-han: var(--luzmo-font-size);--calendar-date-text-color: var(--luzmo-font-color);--calendar-day-text-color: var(--luzmo-font-color);--calendar-day-text-size: var(--luzmo-font-size);--calendar-day-border-radius: var(--luzmo-border-radius);--calendar-day-text-color-selected: var(--luzmo-primary-inverse-color);--calendar-day-text-color-hover: var(--luzmo-font-color-hover);--calendar-day-text-color-cap-selected: var(--luzmo-primary-inverse-color);--calendar-day-border-color-cap-selected: var(--luzmo-primary);--calendar-day-border-color-cap-selected-focus: var(--luzmo-primary-focus);--calendar-day-text-font-weight-selected: var(--bold-font-weight);--calendar-day-text-font-weight-cap-selected: var(--bold-font-weight);--calendar-day-today-text-color: var(--luzmo-primary);--calendar-day-today-background-color: var(--luzmo-background-color-hover);--calendar-day-today-text-font-weight: normal;--calendar-day-today-border-color: transparent;--calendar-day-today-text-color-disabled: var(--luzmo-font-color-disabled);--calendar-day-today-border-color-disabled: transparent;--calendar-day-text-color-disabled: var(--luzmo-font-color-disabled);--calendar-day-text-color-key-focus: var(--luzmo-primary-down);--calendar-day-background-color-selected: rgba(var(--luzmo-primary-rgb), .1);--calendar-day-text-color-range-selection: var(--luzmo-font-color);--calendar-day-background-color-cap-selected: var(--luzmo-primary);--calendar-button-icon-color: var(--luzmo-font-color)}:host:dir(rtl),:host([dir=rtl]){--logical-rotation: matrix(-1, 0, 0, 1, 0, 0)}:host([size=s]){--calendar-day-width: var(--luzmo-component-height-s);--calendar-day-height: var(--luzmo-component-height-s);--calendar-day-border-radius: var(--luzmo-border-radius-s);--calendar-title-height: var(--luzmo-component-height-s);--calendar-title-text-size: var(--luzmo-font-size-s);--calendar-day-title-text-size: var(--luzmo-font-size-s);--calendar-day-text-size-han: var(--luzmo-font-size-s);--calendar-day-text-size: var(--luzmo-font-size-s)}:host([size=l]){--calendar-day-width: var(--luzmo-component-height-l);--calendar-day-height: var(--luzmo-component-height-l);--calendar-day-border-radius: var(--luzmo-border-radius-l);--calendar-title-height: var(--luzmo-component-height-l);--calendar-title-text-size: var(--luzmo-font-size-l);--calendar-day-title-text-size: var(--luzmo-font-size-l);--calendar-day-text-size-han: var(--luzmo-font-size-l);--calendar-day-text-size: var(--luzmo-font-size-l)}:host([size=xl]){--calendar-day-width: var(--luzmo-component-height-xl);--calendar-day-height: var(--luzmo-component-height-xl);--calendar-day-border-radius: var(--luzmo-border-radius-xl);--calendar-title-height: var(--luzmo-component-height-xl);--calendar-title-text-size: var(--luzmo-font-size-xl);--calendar-day-title-text-size: var(--luzmo-font-size-xl);--calendar-day-text-size-han: var(--luzmo-font-size-xl);--calendar-day-text-size: var(--luzmo-font-size-xl)}.table-cell span[role=button]{border-radius:var(--luzmo-calendar-day-width, var(--calendar-day-width))}.title-clickable{all:unset;cursor:pointer;-webkit-user-select:none;user-select:none;font:inherit;color:inherit;border-radius:var(--luzmo-border-radius, 4px);padding-inline:var(--luzmo-spacing-2, 4px);transition:background-color var(--luzmo-animation-duration, .13s) ease}.title-clickable:hover{background-color:var(--luzmo-calendar-title-background-color-hover, var(--luzmo-background-color-hover, rgba(0, 0, 0, .05)))}.title-clickable:focus-visible{outline:var(--luzmo-indicator-width, 2px) solid var(--luzmo-indicator-color, var(--luzmo-primary));outline-offset:var(--luzmo-indicator-gap, 2px)}.year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--luzmo-spacing-2, 4px);padding:var(--luzmo-spacing-2, 4px) 0}.year-cell{display:flex;align-items:center;justify-content:center;block-size:var(--luzmo-calendar-day-height, var(--calendar-day-height));border:var(--luzmo-border-width, 1px) solid transparent;border-radius:var(--luzmo-calendar-day-border-radius, var(--calendar-day-border-radius));background:none;color:var(--luzmo-calendar-day-text-color, var(--calendar-day-text-color));font-family:var(--luzmo-font-family, inherit);font-size:var(--luzmo-calendar-day-text-size, var(--calendar-day-text-size));cursor:pointer;padding:0;transition:background-color var(--luzmo-animation-duration, .13s) ease}.year-cell:hover{background-color:var(--luzmo-calendar-day-background-color-hover, var(--luzmo-background-color-hover, rgba(0, 0, 0, .05)));color:var(--luzmo-calendar-day-text-color-hover, var(--calendar-day-text-color-hover))}.year-cell:focus-visible{outline:var(--luzmo-indicator-width, 2px) solid var(--luzmo-indicator-color, var(--luzmo-primary));outline-offset:var(--luzmo-indicator-gap, 2px)}.year-cell.is-selected{background-color:var(--luzmo-calendar-day-background-color-cap-selected, var(--calendar-day-background-color-cap-selected));color:var(--luzmo-calendar-day-text-color-cap-selected, var(--calendar-day-text-color-cap-selected));font-weight:var(--luzmo-calendar-day-text-font-weight-cap-selected, var(--calendar-day-text-font-weight-cap-selected, bold))}.year-cell.is-current-year:not(.is-selected){color:var(--luzmo-calendar-day-today-text-color, var(--calendar-day-today-text-color));font-weight:var(--bold-font-weight, bold)}';var $=Object.defineProperty,F=Object.getOwnPropertyDescriptor,s=(m,e,a,t)=>{for(var r=t>1?void 0:t?F(e,a):e,n=m.length-1,l;n>=0;n--)(l=m[n])&&(r=(t?l(e,a,r):l(r))||r);return t&&r&&$(e,a,r),r};const h=16,x=7;class d extends C.SizedMixin(_.LuzmoElement,{validSizes:["s","m","l","xl"],noDefaultSize:!0}){constructor(){super(),this.disabled=!1,this.labels={previous:"Previous",next:"Next",today:"Today",selected:"Selected"},this.selectionMode="single",this.currentDate=this.today,this.timeZone=o.getLocalTimeZone(),this.viewMode="days",this.yearGridStart=this.today.year-this.today.year%h,this.weekdays=[],this.currentMonthDates=[],this._isDateFocusIntent=!1,this.numberFormatter=new g.NumberFormatter(this._language),this.yearFormatter=new g.NumberFormatter(this._language,{useGrouping:!1}),this.setNumberFormatter(),this.setWeekdays(),this.setCurrentMonthDates()}static get styles(){return[c.unsafeCSS(T)]}get _language(){try{return this.language?new Intl.Locale(this.language).language:"en"}catch{return"en"}}get today(){return o.today(this.timeZone)}set isDateFocusIntent(e){this._isDateFocusIntent!==e&&(this._isDateFocusIntent=e,this.requestUpdate("isDateFocusIntent",!e))}get isDateFocusIntent(){return this._isDateFocusIntent}setDateFocusIntent(){this.isDateFocusIntent=!0}resetDateFocusIntent(){this.isDateFocusIntent=!1}connectedCallback(){super.connectedCallback(),document.addEventListener("mousedown",this.resetDateFocusIntent)}disconnectedCallback(){super.disconnectedCallback(),document.removeEventListener("mousedown",this.resetDateFocusIntent)}clear(){this._value=void 0}willUpdate(e){e.has("language")&&(this.setNumberFormatter(),this.setWeekdays(),this.setCurrentMonthDates());const a=e.has("min"),t=e.has("max"),r=e.has("value"),n=e.has("startDate"),l=e.has("endDate"),u=a||t||r,v=n||l;u&&(this.convertToCalendarDates(),this.checkDatePropsCompliance(a||t),this.updateCurrentDate()),v&&(this.convertRangeDates(),this._startDate&&!e.has("value")&&!this.value&&(this.currentDate=this._startDate));const y=e.get("currentDate");e.has("currentDate")&&(!y||!o.isSameMonth(y,this.currentDate))&&(this.setCurrentMonthDates(),this.setAttribute("aria-label",this.monthAndYear))}updated(e){if(e.has("currentDate")&&this.isDateFocusIntent&&this.focusCurrentDate(),e.has("currentDate")){const a=e.get("currentDate"),t=e.has("value")||e.has("startDate")||e.has("endDate");a&&!o.isSameMonth(a,this.currentDate)&&!t&&this.dispatchEvent(new CustomEvent("month-change",{bubbles:!0,composed:!0,detail:{date:o.startOfMonth(this.currentDate).toString()}}))}}focusCurrentDate(){var a;const e=(a=this.shadowRoot)==null?void 0:a.querySelector('td span[tabindex="0"]');e&&e.focus()}parseDateOnly(e){const a=e.includes("T")?e.split("T")[0]:e;return o.parseDate(a)}convertToCalendarDates(){this._min=this.min?this.parseDateOnly(this.min):void 0,this._max=this.max?this.parseDateOnly(this.max):void 0,this._value=this.value?this.parseDateOnly(this.value):void 0;const e="AD";this._min=this._min&&o.toCalendarDate(this._min).set({era:e}),this._max=this._max&&o.toCalendarDate(this._max).set({era:e}),this._value=this._value&&o.toCalendarDate(this._value).set({era:e})}convertRangeDates(){const e="AD";this._startDate=this.startDate?o.toCalendarDate(this.parseDateOnly(this.startDate)).set({era:e}):void 0,this._endDate=this.endDate?o.toCalendarDate(this.parseDateOnly(this.endDate)).set({era:e}):void 0}checkDatePropsCompliance(e){e&&this._min&&this._max&&(this._min.compare(this._max)<0||(console.warn&&console.warn(this,`<${this.localName}> expects the 'min' to be less than 'max'. Please ensure that 'min' property's date is earlier than 'max' property's date.`),this._min=void 0,this._max=void 0)),this._value&&this.isNonCompliantDate(this._value)&&(console.warn&&console.warn(this,`<${this.localName}> expects the preselected value to comply with the min and max constraints. Please ensure that 'value' property's date is in between the dates for the 'min' and 'max' properties.`),this._value=void 0)}updateCurrentDate(){if(this._value){this.currentDate=this._value;return}this.isNonCompliantDate(this.today)?this._min?this.currentDate=this._min:this._max&&(this.currentDate=this._max):this.currentDate=this.today}isNonCompliantDate(e){return!!(this._min&&e.compare(this._min)<0||this._max&&e.compare(this._max)>0)}render(){return c.html`
19
+ ${this.renderCalendarHeader()}
20
+ ${this.viewMode==="years"?this.renderYearGrid():this.renderCalendarGrid()}
21
+ `}get monthAndYear(){return this.formatDate(this.currentDate,{month:"long",year:"numeric"})}renderCalendarHeader(){const e=this.viewMode==="years"?`${this.formatYear(this.yearGridStart)} – ${this.formatYear(this.yearGridStart+h-1)}`:this.monthAndYear,a=this.viewMode==="years"?this.disabled:this.isPreviousMonthDisabled,t=this.viewMode==="years"?this.disabled:this.isNextMonthDisabled,r=this.viewMode==="years"?this.handlePreviousYearPage:this.handlePreviousMonth,n=this.viewMode==="years"?this.handleNextYearPage:this.handleNextMonth;return c.html`
19
22
  <div class="header" @focusin=${this.resetDateFocusIntent}>
20
23
  <h2
21
24
  class="title"
22
25
  aria-live="polite"
23
26
  aria-atomic="true"
24
- data-test-id="calendar-title"
25
27
  >
26
- ${this.monthAndYear}
28
+ <button
29
+ class="title-clickable"
30
+ data-test-id="calendar-title"
31
+ @click=${this.toggleViewMode}
32
+ >
33
+ ${e}
34
+ </button>
27
35
  </h2>
28
36
 
29
37
  <luzmo-action-button
@@ -32,15 +40,15 @@
32
40
  label=${this.labels.previous}
33
41
  class="prevMonth"
34
42
  data-test-id="prev-btn"
35
- ?disabled=${this.isPreviousMonthDisabled}
36
- @click=${this.handlePreviousMonth}
43
+ ?disabled=${a}
44
+ @click=${r}
37
45
  >
38
46
  <div slot="icon">
39
47
  <slot name="prev-icon">
40
48
  <luzmo-icon
41
49
  block
42
50
  .size=${this.size}
43
- .icon=${m.luzmoAngleLeft}
51
+ .icon=${z.luzmoAngleLeft}
44
52
  ></luzmo-icon>
45
53
  </slot>
46
54
  </div>
@@ -52,21 +60,21 @@
52
60
  label=${this.labels.next}
53
61
  class="nextMonth"
54
62
  data-test-id="next-btn"
55
- ?disabled=${this.isNextMonthDisabled}
56
- @click=${this.handleNextMonth}
63
+ ?disabled=${t}
64
+ @click=${n}
57
65
  >
58
66
  <div slot="icon">
59
67
  <slot name="next-icon">
60
68
  <luzmo-icon
61
69
  block
62
70
  .size=${this.size}
63
- .icon=${m.luzmoAngleRight}
71
+ .icon=${z.luzmoAngleRight}
64
72
  ></luzmo-icon>
65
73
  </slot>
66
74
  </div>
67
75
  </luzmo-action-button>
68
76
  </div>
69
- `}get isPreviousMonthDisabled(){if(this.disabled)return!0;const e=t.startOfMonth(this.currentDate),a=e.subtract({months:1});return e.era!==a.era||t.isSameDay(e,a)}get isNextMonthDisabled(){if(this.disabled)return!0;const e=t.endOfMonth(this.currentDate),a=e.add({months:1});return e.era!==a.era||t.isSameDay(e,a)}handlePreviousMonth(){let e=t.startOfMonth(this.currentDate).subtract({months:1});this._value&&t.isSameMonth(e,this._value)?e=this._value:t.isSameMonth(e,this.today)&&(e=this.today),this.currentDate=e}handleNextMonth(){let e=t.startOfMonth(this.currentDate).add({months:1});this._value&&t.isSameMonth(e,this._value)?e=this._value:t.isSameMonth(e,this.today)&&(e=this.today),this.currentDate=e}renderCalendarGrid(){return s.html`
77
+ `}get isPreviousMonthDisabled(){if(this.disabled)return!0;const e=o.startOfMonth(this.currentDate),a=e.subtract({months:1});return e.era!==a.era||o.isSameDay(e,a)}get isNextMonthDisabled(){if(this.disabled)return!0;const e=o.endOfMonth(this.currentDate),a=e.add({months:1});return e.era!==a.era||o.isSameDay(e,a)}handlePreviousMonth(){let e=o.startOfMonth(this.currentDate).subtract({months:1});this._value&&o.isSameMonth(e,this._value)?e=this._value:o.isSameMonth(e,this.today)&&(e=this.today),this.currentDate=e}handleNextMonth(){let e=o.startOfMonth(this.currentDate).add({months:1});this._value&&o.isSameMonth(e,this._value)?e=this._value:o.isSameMonth(e,this.today)&&(e=this.today),this.currentDate=e}renderCalendarGrid(){return c.html`
70
78
  <table
71
79
  role="grid"
72
80
  aria-readonly="true"
@@ -77,37 +85,58 @@
77
85
  >
78
86
  ${this.renderCalendarTableHead()} ${this.renderCalendarTableBody()}
79
87
  </table>
80
- `}renderCalendarTableHead(){return s.html`
88
+ `}renderCalendarTableHead(){return c.html`
81
89
  <thead role="presentation">
82
90
  <tr role="row">
83
91
  ${this.renderWeekdayColumns()}
84
92
  </tr>
85
93
  </thead>
86
- `}renderWeekdayColumns(){return this.weekdays.map(e=>this.renderWeekdayColumn(e))}renderWeekdayColumn(e){return s.html`
94
+ `}renderWeekdayColumns(){return this.weekdays.map(e=>this.renderWeekdayColumn(e))}renderWeekdayColumn(e){return c.html`
87
95
  <th role="columnheader" scope="col" class="table-cell">
88
96
  <abbr class="dayOfWeek" title=${e.long}> ${e.narrow} </abbr>
89
97
  </th>
90
- `}renderCalendarTableBody(){return s.html`
98
+ `}renderCalendarTableBody(){return c.html`
91
99
  <tbody role="presentation">
92
100
  ${this.renderCalendarWeeks()}
93
101
  </tbody>
94
- `}renderCalendarWeeks(){return this.currentMonthDates.map(e=>s.html`
102
+ `}renderCalendarWeeks(){return this.currentMonthDates.map(e=>c.html`
95
103
  <tr role="row">
96
104
  ${this.renderDatesInWeek(e)}
97
105
  </tr>
98
- `)}renderDatesInWeek(e){return e.map(a=>this.renderCalendarTableCell(a))}parseDateCellProperties(e){const a={isOutsideMonth:!1,isSelected:!1,isToday:!1,isDisabled:!1,isTabbable:!1};return a.isOutsideMonth=e.month!==this.currentDate.month,a.isOutsideMonth||(a.isDisabled=this.disabled||this.isMinLimitReached(e)||this.isMaxLimitReached(e),a.isToday=t.isSameDay(e,this.today),a.isDisabled)||(a.isTabbable=t.isSameDay(e,this.currentDate),a.isSelected=!!(this._value&&t.isSameDay(this._value,e))),a}renderCalendarTableCell(e){const{isOutsideMonth:a,isSelected:r,isToday:o,isDisabled:i,isTabbable:c}=this.parseDateCellProperties(e),y={date:!0,"is-outsideMonth":a,"is-selected":r,"is-today":o,"is-disabled":i};let u="";o?u=`${this.labels.today}, `:r&&(u=`${this.labels.selected}, `);const b=u+this.formatDate(e,{weekday:"long",year:"numeric",month:"long",day:"numeric"});return s.html`
106
+ `)}renderDatesInWeek(e){return e.map(a=>this.renderCalendarTableCell(a))}parseDateCellProperties(e){const a={isOutsideMonth:!1,isSelected:!1,isToday:!1,isDisabled:!1,isTabbable:!1,isRangeSelection:!1,isRangeStart:!1,isRangeEnd:!1,isSelectionStart:!1,isSelectionEnd:!1};return a.isOutsideMonth=e.month!==this.currentDate.month,a.isOutsideMonth||(a.isDisabled=this.disabled||this.isMinLimitReached(e)||this.isMaxLimitReached(e),a.isToday=o.isSameDay(e,this.today),a.isDisabled)||(a.isTabbable=o.isSameDay(e,this.currentDate),this.selectionMode==="range"?this.computeRangeFlags(e,a):a.isSelected=!!(this._value&&o.isSameDay(this._value,e))),a}computeRangeFlags(e,a){const t=this._startDate,r=this._endDate??this.hoveredDate;if(!t)return;const n=o.isSameDay(e,t);if(a.isSelectionStart=n,a.isSelected=n,!r){n&&(a.isRangeStart=!0,a.isRangeEnd=!0);return}let l=t,u=r;l.compare(u)>0&&(l=r,u=t);const v=e.compare(l)>=0,y=e.compare(u)<=0;v&&y&&(a.isRangeSelection=!0,a.isSelected=!0),a.isRangeStart=o.isSameDay(e,l),a.isRangeEnd=o.isSameDay(e,u),a.isSelectionStart=a.isRangeStart,a.isSelectionEnd=a.isRangeEnd}renderCalendarTableCell(e){const a=this.parseDateCellProperties(e),{isOutsideMonth:t,isSelected:r,isToday:n,isDisabled:l,isTabbable:u,isRangeSelection:v,isRangeStart:y,isRangeEnd:b,isSelectionStart:D,isSelectionEnd:w}=a,k={date:!0,"is-outsideMonth":t,"is-selected":r,"is-today":n,"is-disabled":l,"is-range-selection":v,"is-range-start":y,"is-range-end":b,"is-selection-start":D,"is-selection-end":w};let p="";n?p=`${this.labels.today}, `:r&&(p=`${this.labels.selected}, `);const S=p+this.formatDate(e,{weekday:"long",year:"numeric",month:"long",day:"numeric"});return c.html`
99
107
  <td role="gridcell" class="table-cell">
100
108
  <span
101
109
  role="button"
102
- tabindex=${z.ifDefined(a?void 0:c?"0":"-1")}
103
- aria-label=${b}
104
- aria-disabled=${a||i}
110
+ tabindex=${M.ifDefined(t?void 0:u?"0":"-1")}
111
+ aria-label=${S}
112
+ aria-disabled=${t||l}
105
113
  data-value=${e.toString()}
106
114
  @mousedown=${this.handleDaySelect}
115
+ @mouseenter=${this.handleDayHover}
107
116
  >
108
- <span role="presentation" class=${p.classMap(y)}>
117
+ <span role="presentation" class=${f.classMap(k)}>
109
118
  ${this.formatNumber(e.day)}
110
119
  </span>
111
120
  </span>
112
121
  </td>
113
- `}handleKeydown(e){switch(this.setDateFocusIntent(),e.code){case"ArrowLeft":{this.moveToPreviousDay();break}case"ArrowDown":{this.moveToNextWeek();break}case"ArrowRight":{this.moveToNextDay();break}case"ArrowUp":{this.moveToPreviousWeek();break}case"Space":case"Enter":{this.handleDaySelect(e);break}}}handleDaySelect(e){if(this.disabled){e.preventDefault();return}const a=e.target.closest('span[role="button"]'),r=a&&a.dataset.value;if(!r)return;const o=t.parseDate(r);if(this._value&&t.isSameDay(this._value,o)||this.isMinLimitReached(o)||this.isMaxLimitReached(o)){e.preventDefault();return}this._value=o,this.value=o.toString(),this.dispatchEvent(new CustomEvent("change",{bubbles:!0,composed:!0,cancelable:!0,detail:{value:this.value}}))}moveToPreviousDay(){const e=this.currentDate.subtract({days:1});this.canMoveBackToDate(e)&&(this.currentDate=e)}moveToNextDay(){const e=this.currentDate.add({days:1});this.canMoveForwardToDate(e)&&(this.currentDate=e)}moveToPreviousWeek(){const e=this.currentDate.subtract({weeks:1});if(this.canMoveBackToDate(e)){this.currentDate=e;return}let a=e.add({days:1});for(;!this.canMoveBackToDate(a);)a=a.add({days:1});this.currentDate=a}moveToNextWeek(){const e=this.currentDate.add({weeks:1});if(this.canMoveForwardToDate(e)){this.currentDate=e;return}let a=e.subtract({days:1});for(;!this.canMoveForwardToDate(a);)a=a.subtract({days:1});this.currentDate=a}canMoveBackToDate(e){return this.isMinLimitReached(e)?!1:t.isSameMonth(this.currentDate,e)||!this.isPreviousMonthDisabled}canMoveForwardToDate(e){return this.isMaxLimitReached(e)?!1:t.isSameMonth(this.currentDate,e)||!this.isNextMonthDisabled}setWeekdays(){const e=t.startOfWeek(this.currentDate,this._language);this.weekdays=[...Array.from({length:g}).keys()].map(a=>{const r=e.add({days:a});return{narrow:this.formatDate(r,{weekday:"narrow"}),long:this.formatDate(r,{weekday:"long"})}})}setCurrentMonthDates(){const e=t.getWeeksInMonth(this.currentDate,this._language),a=Array.from({length:e});for(const r of Array.from({length:e}).keys())a[r]=this.getDatesInWeek(this.currentDate,r);this.currentMonthDates=a}getDatesInWeek(e,a){const r=[];let o=t.startOfWeek(t.startOfMonth(e).add({weeks:a}),this._language);for(;r.length<g;){r.push(o);const i=o.add({days:1});if(t.isSameDay(o,i))break;o=i}return r}isMinLimitReached(e){return!!(this._min&&e.compare(this._min)<0)}isMaxLimitReached(e){return!!(this._max&&e.compare(this._max)>0)}formatDate(e,a){return new t.DateFormatter(this._language,a).format(e.toDate(this.timeZone))}setNumberFormatter(){this.numberFormatter=new v.NumberFormatter(this._language)}formatNumber(e){return this.numberFormatter.format(e)}}l([d.property({type:String})],n.prototype,"value",2);l([d.property({type:String})],n.prototype,"min",2);l([d.property({type:String})],n.prototype,"max",2);l([d.property({type:Boolean,reflect:!0})],n.prototype,"disabled",2);l([d.property({type:String,reflect:!0})],n.prototype,"language",2);l([d.property({type:Object})],n.prototype,"labels",2);l([d.state()],n.prototype,"currentDate",2);l([d.state()],n.prototype,"_value",2);l([d.state()],n.prototype,"_min",2);l([d.state()],n.prototype,"_max",2);l([d.state()],n.prototype,"weekdays",2);l([d.state()],n.prototype,"currentMonthDates",2);l([d.state()],n.prototype,"isDateFocusIntent",1);customElements.get("luzmo-calendar")||customElements.define("luzmo-calendar",n);exports.LuzmoCalendar=n;
122
+ `}handleKeydown(e){switch(this.setDateFocusIntent(),e.code){case"ArrowLeft":{this.moveToPreviousDay();break}case"ArrowDown":{this.moveToNextWeek();break}case"ArrowRight":{this.moveToNextDay();break}case"ArrowUp":{this.moveToPreviousWeek();break}case"Space":case"Enter":{this.handleDaySelect(e);break}}}handleDaySelect(e){if(this.disabled){e.preventDefault();return}const a=e.target.closest('span[role="button"]'),t=a&&a.dataset.value;if(!t)return;const r=o.parseDate(t);if(this.isMinLimitReached(r)||this.isMaxLimitReached(r)){e.preventDefault();return}if(this.selectionMode==="range"){this.handleRangeSelect(r);return}if(this._value&&o.isSameDay(this._value,r)){e.preventDefault();return}this._value=r,this.value=r.toString(),this.dispatchEvent(new CustomEvent("change",{bubbles:!0,composed:!0,cancelable:!0,detail:{value:this.value}}))}handleRangeSelect(e){if(!this._startDate||this._endDate){this._startDate=e,this._endDate=void 0,this.hoveredDate=void 0,this.startDate=e.toString(),this.endDate=void 0,this.dispatchEvent(new CustomEvent("range-select",{bubbles:!0,composed:!0,cancelable:!0,detail:{startDate:this.startDate,endDate:void 0}}));return}let a=this._startDate,t=e;a.compare(t)>0&&(t=a,a=e),this._startDate=a,this._endDate=t,this.hoveredDate=void 0,this.startDate=a.toString(),this.endDate=t.toString(),this.dispatchEvent(new CustomEvent("range-select",{bubbles:!0,composed:!0,cancelable:!0,detail:{startDate:this.startDate,endDate:this.endDate}}))}handleDayHover(e){if(this.selectionMode!=="range"||!this._startDate||this._endDate)return;const a=e.target.closest('span[role="button"]'),t=a&&a.dataset.value;t&&(this.hoveredDate=o.parseDate(t),this.dispatchEvent(new CustomEvent("hover-date",{bubbles:!0,composed:!0,detail:{date:t}})))}toggleViewMode(){this.disabled||(this.viewMode==="days"?(this.yearGridStart=this.currentDate.year-this.currentDate.year%h,this.viewMode="years"):this.viewMode="days")}handlePreviousYearPage(){this.yearGridStart-=h}handleNextYearPage(){this.yearGridStart+=h}handleYearSelect(e){this.currentDate=this.currentDate.set({year:e,month:1,day:1}),this.setCurrentMonthDates(),this.viewMode="days"}renderYearGrid(){const e=Array.from({length:h},(t,r)=>this.yearGridStart+r),a=this.today.year;return c.html`
123
+ <div
124
+ class="year-grid"
125
+ role="grid"
126
+ aria-label="${this.formatYear(this.yearGridStart)} – ${this.formatYear(this.yearGridStart+h-1)}"
127
+ @keydown=${this.handleYearGridKeydown}
128
+ >
129
+ ${e.map(t=>{const r=this.currentDate.year===t,l={"year-cell":!0,"is-selected":r,"is-current-year":a===t};return c.html`
130
+ <button
131
+ class=${f.classMap(l)}
132
+ tabindex=${r?"0":"-1"}
133
+ data-year=${t}
134
+ aria-label=${t.toString()}
135
+ aria-selected=${r}
136
+ @click=${()=>this.handleYearSelect(t)}
137
+ >
138
+ ${this.formatYear(t)}
139
+ </button>
140
+ `})}
141
+ </div>
142
+ `}handleYearGridKeydown(e){const a=e.target,t=Number(a.dataset.year);if(!t)return;let r;switch(e.code){case"ArrowLeft":r=t-1;break;case"ArrowRight":r=t+1;break;case"ArrowUp":r=t-4;break;case"ArrowDown":r=t+4;break;case"Enter":case"Space":e.preventDefault(),this.handleYearSelect(t);return}r!==void 0&&(e.preventDefault(),r<this.yearGridStart?this.yearGridStart-=h:r>=this.yearGridStart+h&&(this.yearGridStart+=h),this.updateComplete.then(()=>{var l;const n=(l=this.shadowRoot)==null?void 0:l.querySelector(`button[data-year="${r}"]`);n==null||n.focus()}))}moveToPreviousDay(){const e=this.currentDate.subtract({days:1});this.canMoveBackToDate(e)&&(this.currentDate=e)}moveToNextDay(){const e=this.currentDate.add({days:1});this.canMoveForwardToDate(e)&&(this.currentDate=e)}moveToPreviousWeek(){const e=this.currentDate.subtract({weeks:1});if(this.canMoveBackToDate(e)){this.currentDate=e;return}let a=e.add({days:1});for(;!this.canMoveBackToDate(a);)a=a.add({days:1});this.currentDate=a}moveToNextWeek(){const e=this.currentDate.add({weeks:1});if(this.canMoveForwardToDate(e)){this.currentDate=e;return}let a=e.subtract({days:1});for(;!this.canMoveForwardToDate(a);)a=a.subtract({days:1});this.currentDate=a}canMoveBackToDate(e){return this.isMinLimitReached(e)?!1:o.isSameMonth(this.currentDate,e)||!this.isPreviousMonthDisabled}canMoveForwardToDate(e){return this.isMaxLimitReached(e)?!1:o.isSameMonth(this.currentDate,e)||!this.isNextMonthDisabled}setWeekdays(){const e=o.startOfWeek(this.currentDate,this._language);this.weekdays=[...Array.from({length:x}).keys()].map(a=>{const t=e.add({days:a});return{narrow:this.formatDate(t,{weekday:"narrow"}),long:this.formatDate(t,{weekday:"long"})}})}setCurrentMonthDates(){const e=o.getWeeksInMonth(this.currentDate,this._language),a=Array.from({length:e});for(const t of Array.from({length:e}).keys())a[t]=this.getDatesInWeek(this.currentDate,t);this.currentMonthDates=a}getDatesInWeek(e,a){const t=[];let r=o.startOfWeek(o.startOfMonth(e).add({weeks:a}),this._language);for(;t.length<x;){t.push(r);const n=r.add({days:1});if(o.isSameDay(r,n))break;r=n}return t}isMinLimitReached(e){return!!(this._min&&e.compare(this._min)<0)}isMaxLimitReached(e){return!!(this._max&&e.compare(this._max)>0)}formatDate(e,a){return new o.DateFormatter(this._language,a).format(e.toDate(this.timeZone))}setNumberFormatter(){this.numberFormatter=new g.NumberFormatter(this._language),this.yearFormatter=new g.NumberFormatter(this._language,{useGrouping:!1})}formatNumber(e){return this.numberFormatter.format(e)}formatYear(e){return this.yearFormatter.format(e)}}s([i.property({type:String})],d.prototype,"value",2);s([i.property({type:String})],d.prototype,"min",2);s([i.property({type:String})],d.prototype,"max",2);s([i.property({type:Boolean,reflect:!0})],d.prototype,"disabled",2);s([i.property({type:String,reflect:!0})],d.prototype,"language",2);s([i.property({type:Object})],d.prototype,"labels",2);s([i.property({type:String,attribute:"selection-mode",reflect:!0})],d.prototype,"selectionMode",2);s([i.property({type:String,attribute:"start-date"})],d.prototype,"startDate",2);s([i.property({type:String,attribute:"end-date"})],d.prototype,"endDate",2);s([i.state()],d.prototype,"currentDate",2);s([i.state()],d.prototype,"_value",2);s([i.state()],d.prototype,"_min",2);s([i.state()],d.prototype,"_max",2);s([i.state()],d.prototype,"_startDate",2);s([i.state()],d.prototype,"_endDate",2);s([i.state()],d.prototype,"hoveredDate",2);s([i.state()],d.prototype,"viewMode",2);s([i.state()],d.prototype,"yearGridStart",2);s([i.state()],d.prototype,"weekdays",2);s([i.state()],d.prototype,"currentMonthDates",2);s([i.state()],d.prototype,"isDateFocusIntent",1);customElements.get("luzmo-calendar")||customElements.define("luzmo-calendar",d);exports.LuzmoCalendar=d;
@@ -5,3 +5,4 @@ declare global {
5
5
  }
6
6
  }
7
7
  export { LuzmoCalendar } from './calendar';
8
+ export type { CalendarLabels, CalendarSelectionMode, CalendarViewMode, CalendarWeekday, DateCellProperties } from './calendar';