@new-black/lyra 1.0.31 → 1.0.32
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.
- package/dist/components/inputs/date-picker/date-picker.d.ts +2 -0
- package/dist/components/inputs/date-picker/date-picker.d.ts.map +1 -1
- package/dist/components/inputs/date-picker/date-range-picker.d.ts +4 -2
- package/dist/components/inputs/date-picker/date-range-picker.d.ts.map +1 -1
- package/dist/components/table/table.d.ts.map +1 -1
- package/dist/components/table/table.stories.d.ts.map +1 -1
- package/dist/components/table/table.styles.d.ts.map +1 -1
- package/dist/lyra16.cjs +1 -1
- package/dist/lyra16.js +1 -1
- package/dist/lyra23.cjs +1 -1
- package/dist/lyra23.cjs.map +1 -1
- package/dist/lyra23.js +146 -143
- package/dist/lyra23.js.map +1 -1
- package/dist/lyra25.cjs +1 -1
- package/dist/lyra25.cjs.map +1 -1
- package/dist/lyra25.js +207 -204
- package/dist/lyra25.js.map +1 -1
- package/dist/lyra36.cjs +1 -1
- package/dist/lyra36.js +5 -5
- package/dist/lyra37.cjs +1 -1
- package/dist/lyra37.js +5 -5
- package/dist/lyra43.cjs +1 -1
- package/dist/lyra43.js +2 -2
- package/dist/lyra452.cjs +1 -1
- package/dist/lyra452.cjs.map +1 -1
- package/dist/lyra452.js +10 -27
- package/dist/lyra452.js.map +1 -1
- package/dist/lyra453.cjs +1 -1
- package/dist/lyra453.cjs.map +1 -1
- package/dist/lyra453.js +1 -92
- package/dist/lyra453.js.map +1 -1
- package/dist/lyra454.cjs +1 -1
- package/dist/lyra454.cjs.map +1 -1
- package/dist/lyra454.js +13 -43
- package/dist/lyra454.js.map +1 -1
- package/dist/lyra455.cjs +1 -1
- package/dist/lyra455.cjs.map +1 -1
- package/dist/lyra455.js +10 -50
- package/dist/lyra455.js.map +1 -1
- package/dist/lyra456.cjs +1 -1
- package/dist/lyra456.cjs.map +1 -1
- package/dist/lyra456.js +24 -46
- package/dist/lyra456.js.map +1 -1
- package/dist/lyra457.cjs +1 -1
- package/dist/lyra457.cjs.map +1 -1
- package/dist/lyra457.js +90 -7
- package/dist/lyra457.js.map +1 -1
- package/dist/lyra458.cjs +1 -1
- package/dist/lyra458.cjs.map +1 -1
- package/dist/lyra458.js +42 -60
- package/dist/lyra458.js.map +1 -1
- package/dist/lyra459.cjs +1 -1
- package/dist/lyra459.cjs.map +1 -1
- package/dist/lyra459.js +52 -37
- package/dist/lyra459.js.map +1 -1
- package/dist/lyra460.cjs +1 -5
- package/dist/lyra460.cjs.map +1 -1
- package/dist/lyra460.js +52 -2557
- package/dist/lyra460.js.map +1 -1
- package/dist/lyra461.cjs +1 -1
- package/dist/lyra461.cjs.map +1 -1
- package/dist/lyra461.js +6 -53
- package/dist/lyra461.js.map +1 -1
- package/dist/lyra462.cjs +1 -1
- package/dist/lyra462.cjs.map +1 -1
- package/dist/lyra462.js +64 -1
- package/dist/lyra462.js.map +1 -1
- package/dist/lyra463.cjs +1 -1
- package/dist/lyra463.cjs.map +1 -1
- package/dist/lyra463.js +37 -14
- package/dist/lyra463.js.map +1 -1
- package/dist/lyra464.cjs +5 -1
- package/dist/lyra464.cjs.map +1 -1
- package/dist/lyra464.js +2557 -13
- package/dist/lyra464.js.map +1 -1
- package/dist/lyra465.cjs +1 -1
- package/dist/lyra465.cjs.map +1 -1
- package/dist/lyra465.js +53 -11
- package/dist/lyra465.js.map +1 -1
- package/dist/lyra49.cjs +1 -1
- package/dist/lyra49.js +1 -1
- package/dist/lyra50.cjs +1 -1
- package/dist/lyra50.js +2 -2
- package/dist/lyra504.cjs +1 -1
- package/dist/lyra504.js +5 -5
- package/dist/lyra505.cjs +1 -1
- package/dist/lyra505.js +5 -5
- package/dist/lyra507.cjs +1 -1
- package/dist/lyra507.cjs.map +1 -1
- package/dist/lyra507.js +9 -7
- package/dist/lyra507.js.map +1 -1
- package/dist/lyra508.cjs +1 -1
- package/dist/lyra508.cjs.map +1 -1
- package/dist/lyra508.js +2 -2
- package/dist/lyra508.js.map +1 -1
- package/dist/lyra509.cjs +1 -1
- package/dist/lyra509.cjs.map +1 -1
- package/dist/lyra509.js +6 -6
- package/dist/lyra509.js.map +1 -1
- package/dist/lyra51.cjs +1 -1
- package/dist/lyra51.js +2 -2
- package/dist/lyra510.cjs +1 -1
- package/dist/lyra510.cjs.map +1 -1
- package/dist/lyra510.js +3 -3
- package/dist/lyra510.js.map +1 -1
- package/dist/lyra511.cjs +1 -1
- package/dist/lyra511.cjs.map +1 -1
- package/dist/lyra511.js +3 -3
- package/dist/lyra511.js.map +1 -1
- package/dist/lyra512.cjs +1 -1
- package/dist/lyra512.cjs.map +1 -1
- package/dist/lyra512.js +6 -6
- package/dist/lyra512.js.map +1 -1
- package/dist/lyra513.cjs +1 -1
- package/dist/lyra513.cjs.map +1 -1
- package/dist/lyra513.js +6 -6
- package/dist/lyra513.js.map +1 -1
- package/dist/lyra514.cjs +1 -1
- package/dist/lyra514.cjs.map +1 -1
- package/dist/lyra514.js +3 -3
- package/dist/lyra514.js.map +1 -1
- package/dist/lyra515.cjs +1 -1
- package/dist/lyra515.cjs.map +1 -1
- package/dist/lyra515.js +2 -2
- package/dist/lyra515.js.map +1 -1
- package/dist/lyra516.cjs +1 -1
- package/dist/lyra516.cjs.map +1 -1
- package/dist/lyra516.js +2 -2
- package/dist/lyra516.js.map +1 -1
- package/dist/lyra517.cjs +1 -1
- package/dist/lyra517.cjs.map +1 -1
- package/dist/lyra517.js +2 -2
- package/dist/lyra517.js.map +1 -1
- package/dist/lyra518.cjs +1 -1
- package/dist/lyra518.cjs.map +1 -1
- package/dist/lyra518.js +5 -5
- package/dist/lyra518.js.map +1 -1
- package/dist/lyra519.cjs +1 -1
- package/dist/lyra519.cjs.map +1 -1
- package/dist/lyra519.js +6 -6
- package/dist/lyra519.js.map +1 -1
- package/dist/lyra520.cjs +1 -1
- package/dist/lyra520.cjs.map +1 -1
- package/dist/lyra520.js +3 -3
- package/dist/lyra520.js.map +1 -1
- package/dist/lyra521.cjs +1 -1
- package/dist/lyra521.cjs.map +1 -1
- package/dist/lyra521.js +3 -3
- package/dist/lyra521.js.map +1 -1
- package/dist/lyra522.cjs +1 -1
- package/dist/lyra522.cjs.map +1 -1
- package/dist/lyra522.js +6 -6
- package/dist/lyra522.js.map +1 -1
- package/dist/lyra523.cjs +1 -1
- package/dist/lyra523.cjs.map +1 -1
- package/dist/lyra523.js +6 -6
- package/dist/lyra523.js.map +1 -1
- package/dist/lyra524.cjs +1 -1
- package/dist/lyra524.cjs.map +1 -1
- package/dist/lyra524.js +3 -3
- package/dist/lyra524.js.map +1 -1
- package/dist/lyra525.cjs +1 -1
- package/dist/lyra525.cjs.map +1 -1
- package/dist/lyra525.js +3 -3
- package/dist/lyra525.js.map +1 -1
- package/dist/lyra526.cjs +1 -1
- package/dist/lyra526.cjs.map +1 -1
- package/dist/lyra526.js +3 -3
- package/dist/lyra526.js.map +1 -1
- package/dist/lyra527.cjs +1 -1
- package/dist/lyra527.cjs.map +1 -1
- package/dist/lyra527.js +3 -3
- package/dist/lyra527.js.map +1 -1
- package/dist/lyra528.cjs +1 -1
- package/dist/lyra528.cjs.map +1 -1
- package/dist/lyra528.js +3 -3
- package/dist/lyra528.js.map +1 -1
- package/dist/lyra529.cjs +1 -1
- package/dist/lyra529.cjs.map +1 -1
- package/dist/lyra529.js +3 -3
- package/dist/lyra529.js.map +1 -1
- package/dist/lyra530.cjs.map +1 -1
- package/dist/lyra530.js.map +1 -1
- package/dist/lyra531.cjs +1 -1
- package/dist/lyra531.cjs.map +1 -1
- package/dist/lyra531.js +3 -3
- package/dist/lyra531.js.map +1 -1
- package/dist/lyra532.cjs +1 -1
- package/dist/lyra532.cjs.map +1 -1
- package/dist/lyra532.js +6 -6
- package/dist/lyra532.js.map +1 -1
- package/dist/lyra533.cjs +1 -1
- package/dist/lyra533.cjs.map +1 -1
- package/dist/lyra533.js +5 -5
- package/dist/lyra533.js.map +1 -1
- package/dist/lyra534.cjs +1 -1
- package/dist/lyra534.cjs.map +1 -1
- package/dist/lyra534.js +2 -2
- package/dist/lyra534.js.map +1 -1
- package/dist/lyra535.cjs +1 -1
- package/dist/lyra535.cjs.map +1 -1
- package/dist/lyra535.js +2 -2
- package/dist/lyra535.js.map +1 -1
- package/dist/lyra536.cjs +1 -1
- package/dist/lyra536.cjs.map +1 -1
- package/dist/lyra536.js +2 -2
- package/dist/lyra536.js.map +1 -1
- package/dist/lyra537.cjs +1 -1
- package/dist/lyra537.cjs.map +1 -1
- package/dist/lyra537.js +3 -3
- package/dist/lyra537.js.map +1 -1
- package/dist/lyra538.cjs +1 -1
- package/dist/lyra538.cjs.map +1 -1
- package/dist/lyra538.js +6 -6
- package/dist/lyra538.js.map +1 -1
- package/dist/lyra539.cjs +1 -1
- package/dist/lyra539.cjs.map +1 -1
- package/dist/lyra539.js +3 -3
- package/dist/lyra539.js.map +1 -1
- package/dist/lyra540.cjs +1 -1
- package/dist/lyra540.cjs.map +1 -1
- package/dist/lyra540.js +6 -6
- package/dist/lyra540.js.map +1 -1
- package/dist/lyra541.cjs +1 -1
- package/dist/lyra541.cjs.map +1 -1
- package/dist/lyra541.js +7 -6
- package/dist/lyra541.js.map +1 -1
- package/dist/lyra542.cjs +1 -1
- package/dist/lyra542.cjs.map +1 -1
- package/dist/lyra542.js +6 -78
- package/dist/lyra542.js.map +1 -1
- package/dist/lyra543.cjs +1 -1
- package/dist/lyra543.cjs.map +1 -1
- package/dist/lyra543.js +74 -254
- package/dist/lyra543.js.map +1 -1
- package/dist/lyra544.cjs +1 -1
- package/dist/lyra544.cjs.map +1 -1
- package/dist/lyra544.js +255 -24
- package/dist/lyra544.js.map +1 -1
- package/dist/lyra545.cjs +1 -1
- package/dist/lyra545.cjs.map +1 -1
- package/dist/lyra545.js +23 -26
- package/dist/lyra545.js.map +1 -1
- package/dist/lyra546.cjs +1 -1
- package/dist/lyra546.cjs.map +1 -1
- package/dist/lyra546.js +28 -34
- package/dist/lyra546.js.map +1 -1
- package/dist/lyra547.cjs +1 -1
- package/dist/lyra547.cjs.map +1 -1
- package/dist/lyra547.js +30 -351
- package/dist/lyra547.js.map +1 -1
- package/dist/lyra548.cjs +1 -1
- package/dist/lyra548.cjs.map +1 -1
- package/dist/lyra548.js +348 -30
- package/dist/lyra548.js.map +1 -1
- package/dist/lyra549.cjs +1 -1
- package/dist/lyra549.cjs.map +1 -1
- package/dist/lyra549.js +36 -132
- package/dist/lyra549.js.map +1 -1
- package/dist/lyra550.cjs +1 -1
- package/dist/lyra550.cjs.map +1 -1
- package/dist/lyra550.js +120 -1136
- package/dist/lyra550.js.map +1 -1
- package/dist/lyra551.cjs +1 -1
- package/dist/lyra551.cjs.map +1 -1
- package/dist/lyra551.js +1140 -71
- package/dist/lyra551.js.map +1 -1
- package/dist/lyra552.cjs +1 -1
- package/dist/lyra552.cjs.map +1 -1
- package/dist/lyra552.js +78 -102
- package/dist/lyra552.js.map +1 -1
- package/dist/lyra553.cjs +1 -1
- package/dist/lyra553.cjs.map +1 -1
- package/dist/lyra553.js +102 -9
- package/dist/lyra553.js.map +1 -1
- package/dist/lyra554.cjs +1 -1
- package/dist/lyra554.cjs.map +1 -1
- package/dist/lyra554.js +10 -26
- package/dist/lyra554.js.map +1 -1
- package/dist/lyra555.cjs +1 -1
- package/dist/lyra555.cjs.map +1 -1
- package/dist/lyra555.js +28 -8
- package/dist/lyra555.js.map +1 -1
- package/dist/lyra59.cjs +1 -1
- package/dist/lyra59.js +8 -8
- package/dist/lyra60.cjs +1 -1
- package/dist/lyra60.js +3 -3
- package/dist/lyra606.cjs +1 -1
- package/dist/lyra606.js +1 -1
- package/dist/lyra61.cjs +1 -1
- package/dist/lyra61.js +10 -10
- package/dist/lyra611.cjs +1 -1
- package/dist/lyra611.js +5 -5
- package/dist/lyra617.cjs +1 -1
- package/dist/lyra617.js +2 -2
- package/dist/lyra67.cjs +1 -1
- package/dist/lyra67.cjs.map +1 -1
- package/dist/lyra67.js +328 -290
- package/dist/lyra67.js.map +1 -1
- package/dist/lyra68.cjs +1 -1
- package/dist/lyra68.cjs.map +1 -1
- package/dist/lyra68.js +1 -2
- package/dist/lyra68.js.map +1 -1
- package/dist/lyra682.cjs +1 -1
- package/dist/lyra682.js +2 -2
- package/dist/lyra690.cjs +1 -1
- package/dist/lyra690.js +1 -1
- package/dist/lyra692.cjs +1 -1
- package/dist/lyra692.js +1 -1
- package/dist/lyra730.cjs +1 -1
- package/dist/lyra730.js +1 -1
- package/dist/lyra731.cjs +1 -1
- package/dist/lyra731.js +1 -1
- package/dist/lyra732.cjs +1 -1
- package/dist/lyra732.js +1 -1
- package/dist/lyra75.cjs +1 -1
- package/dist/lyra75.js +2 -2
- package/dist/lyra789.cjs +1 -1
- package/dist/lyra789.js +1 -1
- package/dist/lyra790.cjs +1 -1
- package/dist/lyra790.js +2 -2
- package/dist/lyra791.cjs +1 -1
- package/dist/lyra791.js +4 -4
- package/dist/lyra792.cjs +1 -1
- package/dist/lyra792.js +2 -2
- package/dist/lyra793.cjs +1 -1
- package/dist/lyra793.js +4 -4
- package/dist/lyra794.cjs +1 -1
- package/dist/lyra794.js +2 -2
- package/dist/lyra796.cjs +1 -1
- package/dist/lyra796.cjs.map +1 -1
- package/dist/lyra796.js +371 -50
- package/dist/lyra796.js.map +1 -1
- package/dist/lyra797.cjs +1 -1
- package/dist/lyra797.cjs.map +1 -1
- package/dist/lyra797.js +54 -8
- package/dist/lyra797.js.map +1 -1
- package/dist/lyra798.cjs +1 -1
- package/dist/lyra798.cjs.map +1 -1
- package/dist/lyra798.js +8 -4
- package/dist/lyra798.js.map +1 -1
- package/dist/lyra799.cjs +1 -1
- package/dist/lyra799.cjs.map +1 -1
- package/dist/lyra799.js +4 -13
- package/dist/lyra799.js.map +1 -1
- package/dist/lyra800.cjs +1 -1
- package/dist/lyra800.cjs.map +1 -1
- package/dist/lyra800.js +13 -4
- package/dist/lyra800.js.map +1 -1
- package/dist/lyra801.cjs +1 -1
- package/dist/lyra801.cjs.map +1 -1
- package/dist/lyra801.js +3 -584
- package/dist/lyra801.js.map +1 -1
- package/dist/lyra802.cjs +1 -1
- package/dist/lyra802.cjs.map +1 -1
- package/dist/lyra802.js +585 -11
- package/dist/lyra802.js.map +1 -1
- package/dist/lyra803.cjs +1 -1
- package/dist/lyra803.cjs.map +1 -1
- package/dist/lyra803.js +11 -14
- package/dist/lyra803.js.map +1 -1
- package/dist/lyra806.cjs +1 -1
- package/dist/lyra806.js +1 -1
- package/dist/lyra808.cjs +1 -1
- package/dist/lyra808.cjs.map +1 -1
- package/dist/lyra808.js +14 -15
- package/dist/lyra808.js.map +1 -1
- package/dist/lyra809.cjs +1 -1
- package/dist/lyra809.cjs.map +1 -1
- package/dist/lyra809.js +14 -22
- package/dist/lyra809.js.map +1 -1
- package/dist/lyra810.cjs +1 -1
- package/dist/lyra810.cjs.map +1 -1
- package/dist/lyra810.js +20 -372
- package/dist/lyra810.js.map +1 -1
- package/dist/lyra811.cjs +1 -1
- package/dist/lyra811.js +1 -1
- package/dist/lyra821.cjs +1 -1
- package/dist/lyra821.js +1 -1
- package/dist/lyra823.cjs +1 -1
- package/dist/lyra823.js +2 -2
- package/dist/lyra826.cjs +1 -1
- package/dist/lyra826.js +1 -1
- package/dist/lyra832.cjs +1 -1
- package/dist/lyra832.cjs.map +1 -1
- package/dist/lyra832.js +25 -250
- package/dist/lyra832.js.map +1 -1
- package/dist/lyra833.cjs +1 -1
- package/dist/lyra833.cjs.map +1 -1
- package/dist/lyra833.js +5 -81
- package/dist/lyra833.js.map +1 -1
- package/dist/lyra834.cjs +1 -1
- package/dist/lyra834.cjs.map +1 -1
- package/dist/lyra834.js +11 -2
- package/dist/lyra834.js.map +1 -1
- package/dist/lyra835.cjs +1 -1
- package/dist/lyra835.cjs.map +1 -1
- package/dist/lyra835.js +28 -13
- package/dist/lyra835.js.map +1 -1
- package/dist/lyra836.cjs +1 -1
- package/dist/lyra836.cjs.map +1 -1
- package/dist/lyra836.js +26 -19
- package/dist/lyra836.js.map +1 -1
- package/dist/lyra837.cjs +1 -1
- package/dist/lyra837.cjs.map +1 -1
- package/dist/lyra837.js +252 -13
- package/dist/lyra837.js.map +1 -1
- package/dist/lyra838.cjs +1 -1
- package/dist/lyra838.cjs.map +1 -1
- package/dist/lyra838.js +79 -25
- package/dist/lyra838.js.map +1 -1
- package/dist/lyra839.cjs +1 -1
- package/dist/lyra839.cjs.map +1 -1
- package/dist/lyra839.js +2 -6
- package/dist/lyra839.js.map +1 -1
- package/dist/lyra840.cjs +1 -1
- package/dist/lyra840.cjs.map +1 -1
- package/dist/lyra840.js +13 -11
- package/dist/lyra840.js.map +1 -1
- package/dist/lyra841.cjs +1 -1
- package/dist/lyra841.cjs.map +1 -1
- package/dist/lyra841.js +18 -27
- package/dist/lyra841.js.map +1 -1
- package/dist/lyra842.cjs +1 -1
- package/dist/lyra842.cjs.map +1 -1
- package/dist/lyra842.js +14 -26
- package/dist/lyra842.js.map +1 -1
- package/dist/lyra843.cjs +4 -1
- package/dist/lyra843.cjs.map +1 -1
- package/dist/lyra843.js +45 -103
- package/dist/lyra843.js.map +1 -1
- package/dist/lyra844.cjs +1 -1
- package/dist/lyra844.cjs.map +1 -1
- package/dist/lyra844.js +104 -21
- package/dist/lyra844.js.map +1 -1
- package/dist/lyra845.cjs +1 -1
- package/dist/lyra845.cjs.map +1 -1
- package/dist/lyra845.js +22 -20
- package/dist/lyra845.js.map +1 -1
- package/dist/lyra846.cjs +1 -1
- package/dist/lyra846.cjs.map +1 -1
- package/dist/lyra846.js +20 -5
- package/dist/lyra846.js.map +1 -1
- package/dist/lyra847.cjs +1 -1
- package/dist/lyra847.cjs.map +1 -1
- package/dist/lyra847.js +5 -20
- package/dist/lyra847.js.map +1 -1
- package/dist/lyra848.cjs +1 -1
- package/dist/lyra848.cjs.map +1 -1
- package/dist/lyra848.js +19 -29
- package/dist/lyra848.js.map +1 -1
- package/dist/lyra849.cjs +1 -1
- package/dist/lyra849.cjs.map +1 -1
- package/dist/lyra849.js +28 -6
- package/dist/lyra849.js.map +1 -1
- package/dist/lyra850.cjs +1 -1
- package/dist/lyra850.cjs.map +1 -1
- package/dist/lyra850.js +6 -51
- package/dist/lyra850.js.map +1 -1
- package/dist/lyra851.cjs +1 -1
- package/dist/lyra851.cjs.map +1 -1
- package/dist/lyra851.js +49 -19
- package/dist/lyra851.js.map +1 -1
- package/dist/lyra852.cjs +1 -1
- package/dist/lyra852.cjs.map +1 -1
- package/dist/lyra852.js +19 -16
- package/dist/lyra852.js.map +1 -1
- package/dist/lyra853.cjs +1 -1
- package/dist/lyra853.cjs.map +1 -1
- package/dist/lyra853.js +19 -55
- package/dist/lyra853.js.map +1 -1
- package/dist/lyra854.cjs +1 -1
- package/dist/lyra854.cjs.map +1 -1
- package/dist/lyra854.js +55 -10
- package/dist/lyra854.js.map +1 -1
- package/dist/lyra855.cjs +1 -1
- package/dist/lyra855.cjs.map +1 -1
- package/dist/lyra855.js +10 -3
- package/dist/lyra855.js.map +1 -1
- package/dist/lyra856.cjs +1 -1
- package/dist/lyra856.cjs.map +1 -1
- package/dist/lyra856.js +3 -17
- package/dist/lyra856.js.map +1 -1
- package/dist/lyra857.cjs +1 -1
- package/dist/lyra857.cjs.map +1 -1
- package/dist/lyra857.js +17 -3
- package/dist/lyra857.js.map +1 -1
- package/dist/lyra858.cjs +1 -1
- package/dist/lyra858.cjs.map +1 -1
- package/dist/lyra858.js +3 -3
- package/dist/lyra858.js.map +1 -1
- package/dist/lyra859.cjs +1 -1
- package/dist/lyra859.cjs.map +1 -1
- package/dist/lyra859.js +3 -9
- package/dist/lyra859.js.map +1 -1
- package/dist/lyra860.cjs +1 -1
- package/dist/lyra860.cjs.map +1 -1
- package/dist/lyra860.js +10 -2
- package/dist/lyra860.js.map +1 -1
- package/dist/lyra861.cjs +1 -4
- package/dist/lyra861.cjs.map +1 -1
- package/dist/lyra861.js +2 -47
- package/dist/lyra861.js.map +1 -1
- package/dist/lyra869.cjs +1 -1
- package/dist/lyra869.cjs.map +1 -1
- package/dist/lyra869.js +2 -65
- package/dist/lyra869.js.map +1 -1
- package/dist/lyra871.cjs +1 -1
- package/dist/lyra871.cjs.map +1 -1
- package/dist/lyra871.js +7 -2
- package/dist/lyra871.js.map +1 -1
- package/dist/lyra872.cjs +1 -1
- package/dist/lyra872.cjs.map +1 -1
- package/dist/lyra872.js +65 -7
- package/dist/lyra872.js.map +1 -1
- package/dist/lyra89.cjs +1 -1
- package/dist/lyra89.js +48 -48
- package/package.json +1 -1
package/dist/lyra23.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lyra23.js","sources":["../src/components/inputs/date-picker/date-picker.tsx"],"sourcesContent":["import { ElementRef, ForwardedRef, KeyboardEventHandler, useContext, useMemo, useRef } from \"react\";\nimport {\n Button as AriaButton,\n Calendar,\n CalendarCell,\n CalendarGrid,\n CalendarGridBody,\n CalendarStateContext,\n DateInput,\n DatePicker as AriaDatePicker,\n DatePickerContext,\n DatePickerProps as AriaDatePickerProps,\n DatePickerStateContext,\n DateSegment,\n DateValue,\n Group,\n useContextProps,\n} from \"react-aria-components\";\n\nimport { VariantProps } from \"tailwind-variants\";\n\nimport { fixedForwardRef } from \"../../../utils/helpers\";\nimport { useDictionary } from \"../../../utils/providers/dictionary-provider\";\nimport { Popover } from \"../../overlays\";\nimport { SvgIcon } from \"../../svg-icon\";\nimport { Tooltip } from \"../../tooltip\";\nimport {\n InputFooter,\n InputFooterProps,\n InputHeader,\n InputHeaderProps,\n sharedInputStyles,\n} from \"../shared\";\nimport { shouldRenderInputFooter, shouldRenderInputHeader } from \"../shared/helpers\";\nimport { InputOuterSlotsProps } from \"../shared/types\";\n\nimport {\n dataPickerCalendarGridStyles,\n dateFieldStyles,\n datePickerHeaderStyles,\n} from \"./date-picker.styles\";\nimport { DatePickerCalendarGridHeader, MonthPicker, YearPicker } from \"./shared\";\n\nexport type DatePickerProps<T extends DateValue> = Omit<AriaDatePickerProps<T>, \"className\"> &\n Omit<\n VariantProps<typeof sharedInputStyles>,\n \"hasStartSlot\" | \"hasEndSlot\" | \"hasInputHeader\" | \"hasLabel\"\n > &\n InputHeaderProps &\n InputFooterProps &\n InputOuterSlotsProps & {\n className?: string;\n startSlot?: JSX.Element;\n };\n\nexport type { DateValue };\n\nconst _DatePicker = <T extends DateValue>(\n {\n className,\n description,\n errorMessage,\n fullWidth = true,\n granularity = \"day\",\n hideHintLabel,\n hideInputFooter,\n hideInputHeader,\n label,\n outerEndSlot,\n outerStartSlot,\n startSlot,\n ...props\n }: DatePickerProps<T>,\n ref: ForwardedRef<ElementRef<typeof AriaDatePicker>>,\n) => {\n [props, ref] = useContextProps(props, ref, DatePickerContext);\n const { isInvalid, isRequired } = props;\n\n const hasInputHeader = useMemo(\n () => shouldRenderInputHeader({ hideHintLabel, hideInputHeader, label }),\n [hideHintLabel, hideInputHeader, label],\n );\n\n const { outerSlot, outerSlotsWrapper, wrapper } = sharedInputStyles({\n fullWidth,\n hasStartSlot: !!startSlot,\n hasEndSlot: true,\n hasInputHeader,\n hasLabel: !!label,\n });\n\n return (\n <div className={outerSlotsWrapper()}>\n {outerStartSlot ? <div className={outerSlot()}>{outerStartSlot}</div> : null}\n <AriaDatePicker\n {...props}\n granularity={granularity}\n className={(renderProps) =>\n wrapper({\n className,\n isDisabled: renderProps.isDisabled,\n })\n }\n isInvalid={isInvalid}\n ref={ref}\n >\n {({ isDisabled, state }) => (\n <>\n <DatePickerInput\n description={description}\n fullWidth={fullWidth}\n errorMessage={errorMessage}\n hideHintLabel={hideHintLabel}\n hideInputFooter={hideInputFooter}\n hideInputHeader={hideInputHeader}\n isDisabled={isDisabled}\n isRequired={isRequired}\n label={label}\n startSlot={startSlot}\n onKeyDown={(e) => {\n if (e.key === \"Escape\" && state.value && !isDisabled) {\n e.preventDefault();\n state.setValue(null);\n }\n }}\n />\n <Popover disablePadding className=\"group\">\n <Calendar>\n <div className=\"flex flex-col gap-3 p-3\">\n <DatePickerHeader />\n <div className=\"flex justify-center\">\n <CalendarGrid className=\"w-full text-center\">\n <DatePickerCalendarGridHeader />\n <DatePickerCalendarGridBody />\n </CalendarGrid>\n </div>\n </div>\n </Calendar>\n </Popover>\n </>\n )}\n </AriaDatePicker>\n {outerEndSlot ? <div className={outerSlot()}>{outerEndSlot}</div> : null}\n </div>\n );\n};\n\nexport const DatePicker = fixedForwardRef(_DatePicker);\n//@ts-ignore\nDatePicker.displayName = \"DatePicker\";\ntype DatePickerInputProps = VariantProps<typeof sharedInputStyles> &\n InputHeaderProps &\n InputFooterProps & {\n startSlot?: JSX.Element;\n onKeyDown?: KeyboardEventHandler<HTMLElement>;\n };\n\nconst DatePickerInput = ({\n description,\n errorMessage,\n fullWidth,\n hideHintLabel,\n hideInputFooter,\n hideInputHeader,\n isDisabled,\n isRequired,\n label,\n onKeyDown,\n startSlot,\n}: DatePickerInputProps) => {\n const { input, segment: segmentStyles } = dateFieldStyles();\n\n const hasInputHeader = useMemo(\n () => shouldRenderInputHeader({ hideHintLabel, hideInputHeader, label }),\n [hideHintLabel, hideInputHeader, label],\n );\n\n const hasInputFooter = useMemo(\n () => shouldRenderInputFooter({ description, errorMessage, hideInputFooter }),\n [description, errorMessage, hideInputFooter],\n );\n\n const { button, buttonExcludedFromTabOrder, inputField } = sharedInputStyles({\n fullWidth,\n hasStartSlot: !!startSlot,\n hasEndSlot: true,\n });\n const { clear } = useDictionary();\n const { setValue, value } = useContext(DatePickerStateContext);\n const calendarButtonRef = useRef<HTMLButtonElement>(null);\n\n return (\n <>\n {hasInputHeader ? (\n <InputHeader label={label} hideHintLabel={hideHintLabel} isRequired={isRequired} />\n ) : null}\n <Group\n className={({ isDisabled, isFocusWithin, isHovered, isInvalid }) =>\n inputField({\n isDisabled,\n isFocused: isFocusWithin,\n isHovered,\n isInvalid,\n className: \"min-h-8\",\n })\n }\n onKeyDown={onKeyDown}\n >\n {startSlot}\n <DateInput className={input()}>\n {(segment) => (\n <DateSegment\n className={({ isFocused }) => {\n return segmentStyles({\n isFocused,\n isDisabled,\n // consider literals (separators between segments) to have a value when a full date is entered\n hasValue: segment.type === \"literal\" ? !!value : !segment.isPlaceholder,\n });\n }}\n segment={segment}\n />\n )}\n </DateInput>\n\n <div className=\"ms-auto flex gap-2\">\n {!isDisabled && value ? (\n <Tooltip tooltip={clear}>\n <AriaButton\n slot={null}\n excludeFromTabOrder\n className={buttonExcludedFromTabOrder()}\n onPress={() => {\n setValue(null);\n // focus the calendar button after clearing the value\n // this way the user can easily open the calendar again\n // plus focusing another element afterwards makes sure that the focus is moved\n // https://n6k.atlassian.net/browse/OPTR-31779\n calendarButtonRef.current?.focus();\n }}\n >\n <SvgIcon name=\"clear\" />\n </AriaButton>\n </Tooltip>\n ) : null}\n <AriaButton\n ref={calendarButtonRef}\n isDisabled={isDisabled}\n className={({ isDisabled, isFocusVisible, isHovered }) =>\n button({ isDisabled, isFocused: isFocusVisible, isHovered })\n }\n >\n <SvgIcon name=\"calendar\" />\n </AriaButton>\n </div>\n </Group>\n {hasInputFooter ? (\n <InputFooter description={description} errorMessage={errorMessage} />\n ) : null}\n </>\n );\n};\n\nconst DatePickerHeader = () => {\n const { buttons } = datePickerHeaderStyles();\n\n const { focusedDate, setFocusedDate } = useContext(CalendarStateContext);\n\n return (\n <header className=\"flex justify-between gap-3\">\n <AriaButton slot=\"previous\" className={buttons()}>\n <SvgIcon name=\"chevron-left\" />\n </AriaButton>\n\n <div className=\"flex gap-1\">\n <MonthPicker\n value={focusedDate.month}\n onChange={(value) => {\n setFocusedDate(focusedDate.copy().set({ month: value }));\n }}\n />\n <YearPicker\n value={focusedDate.year}\n onChange={(value) => {\n setFocusedDate(focusedDate.copy().set({ year: value }));\n }}\n />\n </div>\n\n <AriaButton slot=\"next\" className={buttons()}>\n <SvgIcon name=\"chevron-right\" />\n </AriaButton>\n </header>\n );\n};\n\nconst DatePickerCalendarGridBody = () => {\n const { bodyCell } = dataPickerCalendarGridStyles();\n\n return (\n <CalendarGridBody>\n {(date) => (\n <CalendarCell\n date={date}\n className={({\n isDisabled,\n isFocusVisible,\n isHovered,\n isOutsideMonth,\n isPressed,\n isSelected,\n isUnavailable,\n }) =>\n bodyCell({\n isSelected,\n isFocusVisible,\n isHovered,\n isUnavailable,\n isDisabled,\n isOutsideMonth,\n isPressed,\n })\n }\n />\n )}\n </CalendarGridBody>\n );\n};\n"],"names":["_DatePicker","className","description","errorMessage","fullWidth","granularity","hideHintLabel","hideInputFooter","hideInputHeader","label","outerEndSlot","outerStartSlot","startSlot","props","ref","useContextProps","DatePickerContext","isInvalid","isRequired","hasInputHeader","useMemo","shouldRenderInputHeader","outerSlot","outerSlotsWrapper","wrapper","sharedInputStyles","jsxs","jsx","AriaDatePicker","renderProps","isDisabled","state","Fragment","DatePickerInput","e","Popover","Calendar","DatePickerHeader","CalendarGrid","DatePickerCalendarGridHeader","DatePickerCalendarGridBody","DatePicker","fixedForwardRef","onKeyDown","input","segmentStyles","dateFieldStyles","hasInputFooter","shouldRenderInputFooter","button","buttonExcludedFromTabOrder","inputField","clear","useDictionary","setValue","value","useContext","DatePickerStateContext","calendarButtonRef","useRef","InputHeader","Group","isFocusWithin","isHovered","DateInput","segment","DateSegment","isFocused","Tooltip","AriaButton","_a","SvgIcon","isFocusVisible","InputFooter","buttons","datePickerHeaderStyles","focusedDate","setFocusedDate","CalendarStateContext","MonthPicker","YearPicker","bodyCell","dataPickerCalendarGridStyles","CalendarGridBody","date","CalendarCell","isOutsideMonth","isPressed","isSelected","isUnavailable"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"lyra23.js","sources":["../src/components/inputs/date-picker/date-picker.tsx"],"sourcesContent":["import { ElementRef, ForwardedRef, KeyboardEventHandler, useContext, useMemo, useRef } from \"react\";\nimport {\n Button as AriaButton,\n Calendar,\n CalendarCell,\n CalendarGrid,\n CalendarGridBody,\n CalendarStateContext,\n DateInput,\n DatePicker as AriaDatePicker,\n DatePickerContext,\n DatePickerProps as AriaDatePickerProps,\n DatePickerStateContext,\n DateSegment,\n DateValue,\n Group,\n useContextProps,\n} from \"react-aria-components\";\n\nimport { VariantProps } from \"tailwind-variants\";\n\nimport { fixedForwardRef } from \"../../../utils/helpers\";\nimport { useDictionary } from \"../../../utils/providers/dictionary-provider\";\nimport { Popover } from \"../../overlays\";\nimport { SvgIcon } from \"../../svg-icon\";\nimport { Tooltip } from \"../../tooltip\";\nimport {\n InputFooter,\n InputFooterProps,\n InputHeader,\n InputHeaderProps,\n sharedInputStyles,\n} from \"../shared\";\nimport { shouldRenderInputFooter, shouldRenderInputHeader } from \"../shared/helpers\";\nimport { InputOuterSlotsProps } from \"../shared/types\";\n\nimport {\n dataPickerCalendarGridStyles,\n dateFieldStyles,\n datePickerHeaderStyles,\n} from \"./date-picker.styles\";\nimport { DatePickerCalendarGridHeader, MonthPicker, YearPicker } from \"./shared\";\n\nexport type DatePickerProps<T extends DateValue> = Omit<AriaDatePickerProps<T>, \"className\"> &\n Omit<\n VariantProps<typeof sharedInputStyles>,\n \"hasStartSlot\" | \"hasEndSlot\" | \"hasInputHeader\" | \"hasLabel\"\n > &\n InputHeaderProps &\n InputFooterProps &\n InputOuterSlotsProps & {\n className?: string;\n startSlot?: JSX.Element;\n disableClearLogic?: boolean;\n };\n\nexport type { DateValue };\n\nconst _DatePicker = <T extends DateValue>(\n {\n className,\n description,\n disableClearLogic,\n errorMessage,\n fullWidth = true,\n granularity = \"day\",\n hideHintLabel,\n hideInputFooter,\n hideInputHeader,\n label,\n outerEndSlot,\n outerStartSlot,\n startSlot,\n ...props\n }: DatePickerProps<T>,\n ref: ForwardedRef<ElementRef<typeof AriaDatePicker>>,\n) => {\n [props, ref] = useContextProps(props, ref, DatePickerContext);\n const { isInvalid, isRequired } = props;\n\n const hasInputHeader = useMemo(\n () => shouldRenderInputHeader({ hideHintLabel, hideInputHeader, label }),\n [hideHintLabel, hideInputHeader, label],\n );\n\n const { outerSlot, outerSlotsWrapper, wrapper } = sharedInputStyles({\n fullWidth,\n hasStartSlot: !!startSlot,\n hasEndSlot: true,\n hasInputHeader,\n hasLabel: !!label,\n });\n\n return (\n <div className={outerSlotsWrapper()}>\n {outerStartSlot ? <div className={outerSlot()}>{outerStartSlot}</div> : null}\n <AriaDatePicker\n {...props}\n granularity={granularity}\n className={(renderProps) =>\n wrapper({\n className,\n isDisabled: renderProps.isDisabled,\n })\n }\n isInvalid={isInvalid}\n ref={ref}\n >\n {({ isDisabled, state }) => (\n <>\n <DatePickerInput\n description={description}\n fullWidth={fullWidth}\n errorMessage={errorMessage}\n hideHintLabel={hideHintLabel}\n hideInputFooter={hideInputFooter}\n hideInputHeader={hideInputHeader}\n isDisabled={isDisabled}\n isRequired={isRequired}\n label={label}\n startSlot={startSlot}\n onKeyDown={(e) => {\n if (e.key === \"Escape\" && state.value && !isDisabled && !disableClearLogic) {\n e.preventDefault();\n state.setValue(null);\n }\n }}\n disableClearLogic={disableClearLogic}\n />\n <Popover disablePadding className=\"group\">\n <Calendar>\n <div className=\"flex flex-col gap-3 p-3\">\n <DatePickerHeader />\n <div className=\"flex justify-center\">\n <CalendarGrid className=\"w-full text-center\">\n <DatePickerCalendarGridHeader />\n <DatePickerCalendarGridBody />\n </CalendarGrid>\n </div>\n </div>\n </Calendar>\n </Popover>\n </>\n )}\n </AriaDatePicker>\n {outerEndSlot ? <div className={outerSlot()}>{outerEndSlot}</div> : null}\n </div>\n );\n};\n\nexport const DatePicker = fixedForwardRef(_DatePicker);\n//@ts-ignore\nDatePicker.displayName = \"DatePicker\";\ntype DatePickerInputProps = VariantProps<typeof sharedInputStyles> &\n InputHeaderProps &\n InputFooterProps & {\n startSlot?: JSX.Element;\n onKeyDown?: KeyboardEventHandler<HTMLElement>;\n disableClearLogic?: boolean;\n };\n\nconst DatePickerInput = ({\n description,\n disableClearLogic,\n errorMessage,\n fullWidth,\n hideHintLabel,\n hideInputFooter,\n hideInputHeader,\n isDisabled,\n isRequired,\n label,\n onKeyDown,\n startSlot,\n}: DatePickerInputProps) => {\n const { input, segment: segmentStyles } = dateFieldStyles();\n\n const hasInputHeader = useMemo(\n () => shouldRenderInputHeader({ hideHintLabel, hideInputHeader, label }),\n [hideHintLabel, hideInputHeader, label],\n );\n\n const hasInputFooter = useMemo(\n () => shouldRenderInputFooter({ description, errorMessage, hideInputFooter }),\n [description, errorMessage, hideInputFooter],\n );\n\n const { button, buttonExcludedFromTabOrder, inputField } = sharedInputStyles({\n fullWidth,\n hasStartSlot: !!startSlot,\n hasEndSlot: true,\n });\n const { clear } = useDictionary();\n const { setValue, value } = useContext(DatePickerStateContext);\n const calendarButtonRef = useRef<HTMLButtonElement>(null);\n\n return (\n <>\n {hasInputHeader ? (\n <InputHeader label={label} hideHintLabel={hideHintLabel} isRequired={isRequired} />\n ) : null}\n <Group\n className={({ isDisabled, isFocusWithin, isHovered, isInvalid }) =>\n inputField({\n isDisabled,\n isFocused: isFocusWithin,\n isHovered,\n isInvalid,\n className: \"min-h-8\",\n })\n }\n onKeyDown={onKeyDown}\n >\n {startSlot}\n <DateInput className={input()}>\n {(segment) => (\n <DateSegment\n className={({ isFocused }) => {\n return segmentStyles({\n isFocused,\n isDisabled,\n // consider literals (separators between segments) to have a value when a full date is entered\n hasValue: segment.type === \"literal\" ? !!value : !segment.isPlaceholder,\n });\n }}\n segment={segment}\n />\n )}\n </DateInput>\n\n <div className=\"ms-auto flex gap-2\">\n {!isDisabled && value && !disableClearLogic ? (\n <Tooltip tooltip={clear}>\n <AriaButton\n slot={null}\n excludeFromTabOrder\n className={buttonExcludedFromTabOrder()}\n onPress={() => {\n setValue(null);\n // focus the calendar button after clearing the value\n // this way the user can easily open the calendar again\n // plus focusing another element afterwards makes sure that the focus is moved\n // https://n6k.atlassian.net/browse/OPTR-31779\n calendarButtonRef.current?.focus();\n }}\n >\n <SvgIcon name=\"clear\" />\n </AriaButton>\n </Tooltip>\n ) : null}\n <AriaButton\n ref={calendarButtonRef}\n isDisabled={isDisabled}\n className={({ isDisabled, isFocusVisible, isHovered }) =>\n button({ isDisabled, isFocused: isFocusVisible, isHovered })\n }\n >\n <SvgIcon name=\"calendar\" />\n </AriaButton>\n </div>\n </Group>\n {hasInputFooter ? (\n <InputFooter description={description} errorMessage={errorMessage} />\n ) : null}\n </>\n );\n};\n\nconst DatePickerHeader = () => {\n const { buttons } = datePickerHeaderStyles();\n\n const { focusedDate, setFocusedDate } = useContext(CalendarStateContext);\n\n return (\n <header className=\"flex justify-between gap-3\">\n <AriaButton slot=\"previous\" className={buttons()}>\n <SvgIcon name=\"chevron-left\" />\n </AriaButton>\n\n <div className=\"flex gap-1\">\n <MonthPicker\n value={focusedDate.month}\n onChange={(value) => {\n setFocusedDate(focusedDate.copy().set({ month: value }));\n }}\n />\n <YearPicker\n value={focusedDate.year}\n onChange={(value) => {\n setFocusedDate(focusedDate.copy().set({ year: value }));\n }}\n />\n </div>\n\n <AriaButton slot=\"next\" className={buttons()}>\n <SvgIcon name=\"chevron-right\" />\n </AriaButton>\n </header>\n );\n};\n\nconst DatePickerCalendarGridBody = () => {\n const { bodyCell } = dataPickerCalendarGridStyles();\n\n return (\n <CalendarGridBody>\n {(date) => (\n <CalendarCell\n date={date}\n className={({\n isDisabled,\n isFocusVisible,\n isHovered,\n isOutsideMonth,\n isPressed,\n isSelected,\n isUnavailable,\n }) =>\n bodyCell({\n isSelected,\n isFocusVisible,\n isHovered,\n isUnavailable,\n isDisabled,\n isOutsideMonth,\n isPressed,\n })\n }\n />\n )}\n </CalendarGridBody>\n );\n};\n"],"names":["_DatePicker","className","description","disableClearLogic","errorMessage","fullWidth","granularity","hideHintLabel","hideInputFooter","hideInputHeader","label","outerEndSlot","outerStartSlot","startSlot","props","ref","useContextProps","DatePickerContext","isInvalid","isRequired","hasInputHeader","useMemo","shouldRenderInputHeader","outerSlot","outerSlotsWrapper","wrapper","sharedInputStyles","jsxs","jsx","AriaDatePicker","renderProps","isDisabled","state","Fragment","DatePickerInput","e","Popover","Calendar","DatePickerHeader","CalendarGrid","DatePickerCalendarGridHeader","DatePickerCalendarGridBody","DatePicker","fixedForwardRef","onKeyDown","input","segmentStyles","dateFieldStyles","hasInputFooter","shouldRenderInputFooter","button","buttonExcludedFromTabOrder","inputField","clear","useDictionary","setValue","value","useContext","DatePickerStateContext","calendarButtonRef","useRef","InputHeader","Group","isFocusWithin","isHovered","DateInput","segment","DateSegment","isFocused","Tooltip","AriaButton","_a","SvgIcon","isFocusVisible","InputFooter","buttons","datePickerHeaderStyles","focusedDate","setFocusedDate","CalendarStateContext","MonthPicker","YearPicker","bodyCell","dataPickerCalendarGridStyles","CalendarGridBody","date","CalendarCell","isOutsideMonth","isPressed","isSelected","isUnavailable"],"mappings":"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"}
|
package/dist/lyra25.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./lyra90.cjs"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./lyra90.cjs"),y=require("react"),o=require("./lyra89.cjs"),V=require("./lyra93.cjs"),Y=require("./lyra95.cjs"),O=require("./lyra53.cjs");require("./lyra54.cjs");require("./lyra55.cjs");require("./lyra56.cjs");const b=require("./lyra57.cjs");require("./lyra58.cjs");const k=require("./lyra65.cjs"),_=require("./lyra75.cjs"),H=require("./lyra38.cjs"),K=require("./lyra39.cjs"),G=require("./lyra40.cjs"),v=require("./lyra610.cjs"),I=require("./lyra24.cjs"),P=require("./lyra611.cjs"),$=({className:j,description:p,disableClearLogic:r,errorMessage:h,fullWidth:c=!0,granularity:i="day",hideHintLabel:s,hideInputFooter:u,hideInputHeader:R,label:l,outerEndSlot:g,outerStartSlot:f,startSlot:D,...t},n)=>{[t,n]=o.useContextProps(t,n,o.DateRangePickerContext);const{isInvalid:m,isRequired:w}=t,F=y.useMemo(()=>v.shouldRenderInputHeader({hideHintLabel:s,hideInputHeader:R,label:l}),[s,R,l]),{outerSlot:C,outerSlotsWrapper:S,wrapper:q}=G.sharedInputStyles({fullWidth:c,hasStartSlot:!!D,hasEndSlot:!0,hasInputHeader:F,hasLabel:!!l});return e.jsxRuntimeExports.jsxs("div",{className:S(),children:[f?e.jsxRuntimeExports.jsx("div",{className:C(),children:f}):null,e.jsxRuntimeExports.jsx(o.DateRangePicker,{...t,granularity:i,className:a=>q({className:j,isDisabled:a.isDisabled}),isInvalid:m,ref:n,children:({isDisabled:a,state:E})=>e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(o.Group,{children:e.jsxRuntimeExports.jsx(A,{description:p,fullWidth:c,errorMessage:h,hideHintLabel:s,hideInputFooter:u,hideInputHeader:R,isDisabled:a,isRequired:w,label:l,startSlot:D,onKeyDown:x=>{var d,N;x.key==="Escape"&&((d=E.value)!=null&&d.end)&&((N=E.value)!=null&&N.start)&&!a&&!r&&(x.preventDefault(),E.setValue(null))},disableClearLogic:r})}),e.jsxRuntimeExports.jsx(O.Popover,{disablePadding:!0,className:"group",children:e.jsxRuntimeExports.jsx(o.RangeCalendar,{visibleDuration:{months:2},pageBehavior:"single",children:e.jsxRuntimeExports.jsx(z,{})})})]})}),g?e.jsxRuntimeExports.jsx("div",{className:C(),children:g}):null]})},z=()=>{const{buttons:j}=I.datePickerHeaderStyles(),{anchorDate:p,focusedDate:r,focusNextPage:h,focusPreviousPage:c,setFocusedDate:i,visibleRange:s}=y.useContext(o.RangeCalendarStateContext),u=t=>t===12?1:t+1,R=t=>t===1?12:t-1,l=y.useCallback(t=>{if(t===s.start.month-1)c();else if(t===s.start.month+1)h();else{const n=t<s.start.month?u(t):t,m=s.start.copy().set({month:n,day:r.day});i(m)}},[h,c,r.day,i,s.start]),g=y.useCallback(t=>{if(s.start.year!==s.end.year){if(t<s.start.year){const n=s.start.copy().set({year:t+1,day:r.day,month:1});i(n)}if(t>s.start.year){const n=s.start.copy().set({year:t,day:r.day,month:12});i(n)}}else{const n=t<s.start.year?u(s.start.month):s.start.month,m=s.start.copy().set({year:t,day:r.day,month:n});i(m)}},[r.day,i,s.end.year,s.start]),f=y.useCallback(t=>{if(t===s.end.month-1)c();else if(t===s.end.month+1)h();else{const n=t>s.end.month?R(t):t,m=s.end.copy().set({month:n,day:r.day});i(m)}},[h,c,r.day,i,s.end]),D=y.useCallback(t=>{if(s.start.year!==s.end.year){if(t<s.end.year){const n=s.end.copy().set({year:t,day:r.day,month:1});i(n)}if(t>s.end.year){const n=s.end.copy().set({year:t-1,day:r.day,month:12});i(n)}}else{const n=t>s.end.year?R(s.end.month):s.end.month,m=s.end.copy().set({year:t,day:r.day,month:n});i(m)}},[r.day,i,s.end,s.start.year]);return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-3 p-3 sm:flex-row",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-3",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex justify-between gap-1",children:[e.jsxRuntimeExports.jsx(o.Button,{slot:"previous",className:j(),children:e.jsxRuntimeExports.jsx(k.SvgIcon,{name:"chevron-left"})}),e.jsxRuntimeExports.jsxs("div",{className:"flex gap-1",children:[e.jsxRuntimeExports.jsx(P.MonthPicker,{value:s.start.month,isDisabled:!!p,onChange:l}),e.jsxRuntimeExports.jsx(P.YearPicker,{value:s.start.year,isDisabled:!!p,onChange:g})]}),e.jsxRuntimeExports.jsx("div",{className:"w-6"})]}),e.jsxRuntimeExports.jsxs(o.CalendarGrid,{className:"w-full text-center",children:[e.jsxRuntimeExports.jsx(P.DatePickerCalendarGridHeader,{}),e.jsxRuntimeExports.jsx(M,{})]})]}),e.jsxRuntimeExports.jsx(b.Separator,{orientation:"vertical",className:"hidden h-[unset] self-stretch sm:block"}),e.jsxRuntimeExports.jsx(b.Separator,{className:"sm:hidden"}),e.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-3",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex justify-between gap-1",children:[e.jsxRuntimeExports.jsx("div",{className:"w-6"}),e.jsxRuntimeExports.jsxs("div",{className:"flex gap-1",children:[e.jsxRuntimeExports.jsx(P.MonthPicker,{value:s.end.month,isDisabled:!!p,onChange:f}),e.jsxRuntimeExports.jsx(P.YearPicker,{value:s.end.year,isDisabled:!!p,onChange:D})]}),e.jsxRuntimeExports.jsx(o.Button,{slot:"next",className:j(),children:e.jsxRuntimeExports.jsx(k.SvgIcon,{name:"chevron-right"})})]}),e.jsxRuntimeExports.jsxs(o.CalendarGrid,{className:"w-full text-center",offset:{months:1},children:[e.jsxRuntimeExports.jsx(P.DatePickerCalendarGridHeader,{}),e.jsxRuntimeExports.jsx(M,{})]})]})]})})},B=V.fixedForwardRef($);B.displayName="DateRangePicker";const A=({description:j,disableClearLogic:p,errorMessage:r,fullWidth:h,hideHintLabel:c,hideInputFooter:i,hideInputHeader:s,isDisabled:u,isRequired:R,label:l,onKeyDown:g,startSlot:f})=>{const D=y.useMemo(()=>v.shouldRenderInputHeader({hideHintLabel:c,hideInputHeader:s,label:l}),[c,s,l]),t=y.useMemo(()=>v.shouldRenderInputFooter({description:j,errorMessage:r,hideInputFooter:i}),[j,r,i]),{input:n,segment:m}=I.dateFieldStyles(),{button:w,buttonExcludedFromTabOrder:F,inputField:C}=G.sharedInputStyles({fullWidth:h,hasStartSlot:!!f,hasEndSlot:!0}),{clear:S}=Y.useDictionary(),{setValue:q,value:a}=y.useContext(o.DateRangePickerStateContext),E=y.useRef(null);return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[D?e.jsxRuntimeExports.jsx(H.InputHeader,{label:l,hideHintLabel:c,isRequired:R}):null,e.jsxRuntimeExports.jsxs(o.Group,{className:({isDisabled:x,isFocusWithin:d,isHovered:N,isInvalid:T})=>C({isDisabled:x,isFocused:d,isHovered:N,isInvalid:T,className:"min-h-8"}),onKeyDown:g,children:[f,e.jsxRuntimeExports.jsx(o.DateInput,{className:n(),slot:"start",children:x=>e.jsxRuntimeExports.jsx(o.DateSegment,{className:({isFocused:d})=>m({isFocused:d,isDisabled:u,hasValue:x.type==="literal"?!!(a!=null&&a.start):!x.isPlaceholder}),segment:x})}),e.jsxRuntimeExports.jsx("span",{"aria-hidden":"true",className:a!=null&&a.start&&a.end&&!u?"text-primary":"text-tertiary",children:" – "}),e.jsxRuntimeExports.jsx(o.DateInput,{className:n(),slot:"end",children:x=>e.jsxRuntimeExports.jsx(o.DateSegment,{className:({isFocused:d})=>m({isFocused:d,isDisabled:u,hasValue:x.type==="literal"?!!(a!=null&&a.end):!x.isPlaceholder}),segment:x})}),e.jsxRuntimeExports.jsxs("div",{className:"ms-auto flex flex-row-reverse gap-2",children:[e.jsxRuntimeExports.jsx(o.Button,{isDisabled:u,className:({isDisabled:x,isFocusVisible:d,isHovered:N})=>w({isDisabled:x,isFocused:d,isHovered:N}),ref:E,children:e.jsxRuntimeExports.jsx(k.SvgIcon,{name:"calendar"})}),!u&&(a!=null&&a.end)&&(a!=null&&a.start)&&!p?e.jsxRuntimeExports.jsx(_.Tooltip,{tooltip:S,children:e.jsxRuntimeExports.jsx(o.Button,{slot:null,onFocus:x=>{var d;x.preventDefault(),(d=E==null?void 0:E.current)==null||d.focus()},excludeFromTabOrder:!0,className:F(),onPress:()=>{var x;q(null),(x=E.current)==null||x.focus()},children:e.jsxRuntimeExports.jsx(k.SvgIcon,{name:"clear"})})}):null]})]}),t?e.jsxRuntimeExports.jsx(K.InputFooter,{description:j,errorMessage:r}):null]})},M=()=>{const{rangeBodyCell:j}=I.dataPickerCalendarGridStyles();return e.jsxRuntimeExports.jsx(o.CalendarGridBody,{children:p=>e.jsxRuntimeExports.jsx(o.CalendarCell,{date:p,className:({isDisabled:r,isFocusVisible:h,isHovered:c,isOutsideMonth:i,isPressed:s,isSelected:u,isSelectionEnd:R,isSelectionStart:l,isUnavailable:g})=>j({isSelected:u,isSelectionStart:l,isSelectionEnd:R,isFocusVisible:h,isHovered:c,isUnavailable:g,isDisabled:r,isOutsideMonth:i,isPressed:s})})})};exports.DateRangePicker=B;
|
package/dist/lyra25.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lyra25.cjs","sources":["../src/components/inputs/date-picker/date-range-picker.tsx"],"sourcesContent":["import {\n ElementRef,\n ForwardedRef,\n KeyboardEventHandler,\n useCallback,\n useContext,\n useMemo,\n useRef,\n} from \"react\";\nimport {\n Button as AriaButton,\n CalendarCell,\n CalendarGrid,\n CalendarGridBody,\n DateInput,\n DateRangePicker as AriaDateRangePicker,\n DateRangePickerContext,\n DateRangePickerProps as AriaDateRangePickerProps,\n DateRangePickerStateContext,\n DateSegment,\n DateValue,\n Group,\n RangeCalendar,\n RangeCalendarStateContext,\n useContextProps,\n} from \"react-aria-components\";\n\nimport { VariantProps } from \"tailwind-variants\";\n\nimport { fixedForwardRef } from \"../../../utils/helpers\";\nimport { useDictionary } from \"../../../utils/providers/dictionary-provider\";\nimport { Popover } from \"../../overlays\";\nimport { Separator } from \"../../separator\";\nimport { SvgIcon } from \"../../svg-icon\";\nimport { Tooltip } from \"../../tooltip\";\nimport {\n InputFooter,\n InputFooterProps,\n InputHeader,\n InputHeaderProps,\n sharedInputStyles,\n} from \"../shared\";\nimport { shouldRenderInputFooter, shouldRenderInputHeader } from \"../shared/helpers\";\nimport { InputOuterSlotsProps } from \"../shared/types\";\n\nimport {\n dataPickerCalendarGridStyles,\n dateFieldStyles,\n datePickerHeaderStyles,\n} from \"./date-picker.styles\";\nimport { DatePickerCalendarGridHeader, MonthPicker, YearPicker } from \"./shared\";\n\nexport type DateRangePickerProps<T extends DateValue> = Omit<\n AriaDateRangePickerProps<T>,\n \"className\"\n> &\n Omit<VariantProps<typeof sharedInputStyles>, \"hasStartSlot\" | \"hasEndSlot\"> &\n InputHeaderProps &\n InputOuterSlotsProps &\n InputFooterProps & {\n className?: string;\n startSlot?: JSX.Element;\n };\n\nexport type { DateValue };\n\nconst _DateRangePicker = <T extends DateValue>(\n {\n className,\n description,\n errorMessage,\n fullWidth = true,\n granularity = \"day\",\n hideHintLabel,\n hideInputFooter,\n hideInputHeader,\n label,\n outerEndSlot,\n outerStartSlot,\n startSlot,\n ...props\n }: DateRangePickerProps<T>,\n ref: ForwardedRef<ElementRef<typeof AriaDateRangePicker>>,\n) => {\n [props, ref] = useContextProps(props, ref, DateRangePickerContext);\n const { isInvalid, isRequired } = props;\n\n const hasInputHeader = useMemo(\n () => shouldRenderInputHeader({ hideHintLabel, hideInputHeader, label }),\n [hideHintLabel, hideInputHeader, label],\n );\n\n const { outerSlot, outerSlotsWrapper, wrapper } = sharedInputStyles({\n fullWidth,\n hasStartSlot: !!startSlot,\n hasEndSlot: true,\n hasInputHeader,\n hasLabel: !!label,\n });\n\n return (\n <div className={outerSlotsWrapper()}>\n {outerStartSlot ? <div className={outerSlot()}>{outerStartSlot}</div> : null}\n <AriaDateRangePicker\n {...props}\n granularity={granularity}\n className={(renderProps) =>\n wrapper({\n className,\n isDisabled: renderProps.isDisabled,\n })\n }\n isInvalid={isInvalid}\n ref={ref}\n >\n {({ isDisabled, state }) => (\n <>\n <Group>\n <DateRangePickerInputs\n description={description}\n fullWidth={fullWidth}\n errorMessage={errorMessage}\n hideHintLabel={hideHintLabel}\n hideInputFooter={hideInputFooter}\n hideInputHeader={hideInputHeader}\n isDisabled={isDisabled}\n isRequired={isRequired}\n label={label}\n startSlot={startSlot}\n onKeyDown={(e) => {\n if (e.key === \"Escape\" && state.value?.end && state.value?.start && !isDisabled) {\n e.preventDefault();\n state.setValue(null);\n }\n }}\n />\n </Group>\n <Popover disablePadding className=\"group\">\n <RangeCalendar visibleDuration={{ months: 2 }} pageBehavior={\"single\"}>\n <PopoverCalendarGrid />\n </RangeCalendar>\n </Popover>\n </>\n )}\n </AriaDateRangePicker>\n {outerEndSlot ? <div className={outerSlot()}>{outerEndSlot}</div> : null}\n </div>\n );\n};\n\nconst PopoverCalendarGrid = () => {\n const { buttons } = datePickerHeaderStyles();\n\n const {\n anchorDate,\n focusedDate,\n focusNextPage,\n focusPreviousPage,\n setFocusedDate,\n visibleRange,\n } = useContext(RangeCalendarStateContext);\n\n const getNextMonth = (month: number) => (month === 12 ? 1 : month + 1);\n const getPreviousMonth = (month: number) => (month === 1 ? 12 : month - 1);\n\n /**\n * Visible range logic from react-aria\n * - when setting a focused date before the current start range, the focused date is set to the end of the visible range\n * - when setting a focused date after the current end range, the focused date is set to the start of the visible range\n */\n const onStartMonthChange = useCallback(\n (value: number) => {\n if (value === visibleRange.start.month - 1) {\n focusPreviousPage();\n } else if (value === visibleRange.start.month + 1) {\n focusNextPage();\n } else {\n // when going in the past we need to make sure the focused date is in the next month so the visible range starts where we want\n const newMonth = value < visibleRange.start.month ? getNextMonth(value) : value;\n const newFocusedDate = visibleRange.start.copy().set({\n month: newMonth,\n day: focusedDate.day,\n });\n setFocusedDate(newFocusedDate);\n }\n },\n [focusNextPage, focusPreviousPage, focusedDate.day, setFocusedDate, visibleRange.start],\n );\n\n const onStartYearChange = useCallback(\n (value: number): void => {\n // handle Dec-Jan visible range separately\n if (visibleRange.start.year !== visibleRange.end.year) {\n // when going in the past the focused date should be in January so the visible range starts where we want\n if (value < visibleRange.start.year) {\n const newFocusedDate = visibleRange.start.copy().set({\n year: value + 1,\n day: focusedDate.day,\n month: 1,\n });\n\n setFocusedDate(newFocusedDate);\n }\n // when going in the future the focused date should be in December so the visible range starts where we want\n if (value > visibleRange.start.year) {\n const newFocusedDate = visibleRange.start.copy().set({\n year: value,\n day: focusedDate.day,\n month: 12,\n });\n\n setFocusedDate(newFocusedDate);\n }\n } else {\n // when going in the past we need to make sure the focused date is in the next month so the visible range starts where we want\n const newMonth =\n value < visibleRange.start.year\n ? getNextMonth(visibleRange.start.month)\n : visibleRange.start.month;\n const newFocusedDate = visibleRange.start.copy().set({\n year: value,\n day: focusedDate.day,\n month: newMonth,\n });\n\n setFocusedDate(newFocusedDate);\n }\n },\n [focusedDate.day, setFocusedDate, visibleRange.end.year, visibleRange.start],\n );\n\n const onEndMonthChange = useCallback(\n (value: number): void => {\n if (value === visibleRange.end.month - 1) {\n focusPreviousPage();\n } else if (value === visibleRange.end.month + 1) {\n focusNextPage();\n } else {\n // when going in the future we need to make sure the focused date is in the previous month so the visible range starts where we want\n const newMonth = value > visibleRange.end.month ? getPreviousMonth(value) : value;\n const newFocusedDate = visibleRange.end.copy().set({\n month: newMonth,\n day: focusedDate.day,\n });\n setFocusedDate(newFocusedDate);\n }\n },\n [focusNextPage, focusPreviousPage, focusedDate.day, setFocusedDate, visibleRange.end],\n );\n\n const onEndYearChange = useCallback(\n (value: number): void => {\n // handle Dec-Jan visible range separately\n if (visibleRange.start.year !== visibleRange.end.year) {\n // when going in the past the focused date should be in January so the visible range starts where we want\n if (value < visibleRange.end.year) {\n const newFocusedDate = visibleRange.end.copy().set({\n year: value,\n day: focusedDate.day,\n month: 1,\n });\n\n setFocusedDate(newFocusedDate);\n }\n if (value > visibleRange.end.year) {\n // when going in the future the focused date should be in December so the visible range starts where we want\n const newFocusedDate = visibleRange.end.copy().set({\n year: value - 1,\n day: focusedDate.day,\n month: 12,\n });\n\n setFocusedDate(newFocusedDate);\n }\n } else {\n // when going in the future we need to make sure the focused date is in the previous month so the visible range starts where we want\n const newMonth =\n value > visibleRange.end.year\n ? getPreviousMonth(visibleRange.end.month)\n : visibleRange.end.month;\n const newFocusedDate = visibleRange.end.copy().set({\n year: value,\n day: focusedDate.day,\n month: newMonth,\n });\n\n setFocusedDate(newFocusedDate);\n }\n },\n [focusedDate.day, setFocusedDate, visibleRange.end, visibleRange.start.year],\n );\n\n return (\n <>\n <div className=\"flex flex-col gap-3 p-3 sm:flex-row\">\n <div className=\"flex flex-col gap-3\">\n <div className=\"flex justify-between gap-1\">\n <AriaButton slot=\"previous\" className={buttons()}>\n <SvgIcon name=\"chevron-left\" />\n </AriaButton>\n <div className=\"flex gap-1\">\n <MonthPicker\n value={visibleRange.start.month}\n isDisabled={!!anchorDate}\n onChange={onStartMonthChange}\n />\n <YearPicker\n value={visibleRange.start.year}\n isDisabled={!!anchorDate}\n onChange={onStartYearChange}\n />\n </div>\n <div className=\"w-6\" />\n </div>\n <CalendarGrid className=\"w-full text-center\">\n <DatePickerCalendarGridHeader />\n <DateRangePickerCalendarGridBody />\n </CalendarGrid>\n </div>\n\n <Separator orientation=\"vertical\" className=\"hidden h-[unset] self-stretch sm:block\" />\n <Separator className=\"sm:hidden\" />\n\n <div className=\"flex flex-col gap-3\">\n <div className=\"flex justify-between gap-1\">\n <div className=\"w-6\" />\n <div className=\"flex gap-1\">\n <MonthPicker\n value={visibleRange.end.month}\n isDisabled={!!anchorDate}\n onChange={onEndMonthChange}\n />\n <YearPicker\n value={visibleRange.end.year}\n isDisabled={!!anchorDate}\n onChange={onEndYearChange}\n />\n </div>\n <AriaButton slot=\"next\" className={buttons()}>\n <SvgIcon name=\"chevron-right\" />\n </AriaButton>\n </div>\n <CalendarGrid className=\"w-full text-center\" offset={{ months: 1 }}>\n <DatePickerCalendarGridHeader />\n <DateRangePickerCalendarGridBody />\n </CalendarGrid>\n </div>\n </div>\n </>\n );\n};\n\nexport const DateRangePicker = fixedForwardRef(_DateRangePicker);\n//@ts-ignore\nDateRangePicker.displayName = \"DateRangePicker\";\ntype DateRangePickerInputsProps = VariantProps<typeof sharedInputStyles> &\n InputHeaderProps &\n InputFooterProps & {\n startSlot?: JSX.Element;\n onKeyDown?: KeyboardEventHandler<HTMLElement>;\n };\n\nconst DateRangePickerInputs = ({\n description,\n errorMessage,\n fullWidth,\n hideHintLabel,\n hideInputFooter,\n hideInputHeader,\n isDisabled,\n isRequired,\n label,\n onKeyDown,\n startSlot,\n}: DateRangePickerInputsProps) => {\n const hasInputHeader = useMemo(\n () => shouldRenderInputHeader({ hideHintLabel, hideInputHeader, label }),\n [hideHintLabel, hideInputHeader, label],\n );\n\n const hasInputFooter = useMemo(\n () => shouldRenderInputFooter({ description, errorMessage, hideInputFooter }),\n [description, errorMessage, hideInputFooter],\n );\n\n const { input, segment: segmentStyles } = dateFieldStyles();\n const { button, buttonExcludedFromTabOrder, inputField } = sharedInputStyles({\n fullWidth,\n hasStartSlot: !!startSlot,\n hasEndSlot: true,\n });\n\n const { clear } = useDictionary();\n const { setValue, value } = useContext(DateRangePickerStateContext);\n\n const calendarButtonRef = useRef<HTMLButtonElement | null>(null);\n\n return (\n <>\n {hasInputHeader ? (\n <InputHeader label={label} hideHintLabel={hideHintLabel} isRequired={isRequired} />\n ) : null}\n <Group\n className={({ isDisabled, isFocusWithin, isHovered, isInvalid }) =>\n inputField({\n isDisabled,\n isFocused: isFocusWithin,\n isHovered,\n isInvalid,\n className: \"min-h-8\",\n })\n }\n onKeyDown={onKeyDown}\n >\n {startSlot}\n <DateInput className={input()} slot=\"start\">\n {(segment) => (\n <DateSegment\n className={({ isFocused }) => {\n return segmentStyles({\n isFocused,\n isDisabled,\n // consider literals (separators between segments) to have a value when a full date is entered\n hasValue: segment.type === \"literal\" ? !!value?.start : !segment.isPlaceholder,\n });\n }}\n segment={segment}\n />\n )}\n </DateInput>\n\n <span\n aria-hidden=\"true\"\n className={\n !!value?.start && !!value.end && !isDisabled ? \"text-primary\" : \"text-tertiary\"\n }\n >\n – \n </span>\n\n <DateInput className={input()} slot=\"end\">\n {(segment) => (\n <DateSegment\n className={({ isFocused }) => {\n return segmentStyles({\n isFocused,\n isDisabled,\n // consider literals (separators between segments) to have a value when a full date is entered\n hasValue: segment.type === \"literal\" ? !!value?.end : !segment.isPlaceholder,\n });\n }}\n segment={segment}\n />\n )}\n </DateInput>\n\n {/* We reverse the order so we can go back to the date input by pressing the left arrow when the calendar button is focused. \n Otherwise the clear button would be focused instead and it would move the focus back to the calendar button */}\n <div className=\"ms-auto flex flex-row-reverse gap-2\">\n <AriaButton\n isDisabled={isDisabled}\n className={({ isDisabled, isFocusVisible, isHovered }) =>\n button({ isDisabled, isFocused: isFocusVisible, isHovered })\n }\n ref={calendarButtonRef}\n >\n <SvgIcon name=\"calendar\" />\n </AriaButton>\n\n {!isDisabled && value?.end && value?.start ? (\n <Tooltip tooltip={clear}>\n <AriaButton\n slot={null}\n onFocus={(e) => {\n e.preventDefault();\n // when filling in a full value in the input this button gets focus automatically, we move focus the calendar button instead\n calendarButtonRef?.current?.focus();\n }}\n excludeFromTabOrder\n className={buttonExcludedFromTabOrder()}\n onPress={() => {\n setValue(null);\n // focus the calendar button after clearing the value\n // this way the user can easily open the calendar again\n // plus focusing another element afterwards makes sure that the focus is moved\n // https://n6k.atlassian.net/browse/OPTR-31779\n calendarButtonRef.current?.focus();\n }}\n >\n <SvgIcon name=\"clear\" />\n </AriaButton>\n </Tooltip>\n ) : null}\n </div>\n </Group>\n {hasInputFooter ? (\n <InputFooter description={description} errorMessage={errorMessage} />\n ) : null}\n </>\n );\n};\n\nconst DateRangePickerCalendarGridBody = () => {\n const { rangeBodyCell } = dataPickerCalendarGridStyles();\n\n return (\n <CalendarGridBody>\n {(date) => (\n <CalendarCell\n date={date}\n className={({\n isDisabled,\n isFocusVisible,\n isHovered,\n isOutsideMonth,\n isPressed,\n isSelected,\n isSelectionEnd,\n isSelectionStart,\n isUnavailable,\n }) =>\n rangeBodyCell({\n isSelected,\n isSelectionStart,\n isSelectionEnd,\n isFocusVisible,\n isHovered,\n isUnavailable,\n isDisabled,\n isOutsideMonth,\n isPressed,\n })\n }\n />\n )}\n </CalendarGridBody>\n );\n};\n"],"names":["_DateRangePicker","className","description","errorMessage","fullWidth","granularity","hideHintLabel","hideInputFooter","hideInputHeader","label","outerEndSlot","outerStartSlot","startSlot","props","ref","useContextProps","DateRangePickerContext","isInvalid","isRequired","hasInputHeader","useMemo","shouldRenderInputHeader","outerSlot","outerSlotsWrapper","wrapper","sharedInputStyles","jsxs","jsx","AriaDateRangePicker","renderProps","isDisabled","state","Fragment","Group","DateRangePickerInputs","e","_a","_b","Popover","RangeCalendar","PopoverCalendarGrid","buttons","datePickerHeaderStyles","anchorDate","focusedDate","focusNextPage","focusPreviousPage","setFocusedDate","visibleRange","useContext","RangeCalendarStateContext","getNextMonth","month","getPreviousMonth","onStartMonthChange","useCallback","value","newMonth","newFocusedDate","onStartYearChange","onEndMonthChange","onEndYearChange","AriaButton","SvgIcon","MonthPicker","YearPicker","CalendarGrid","DatePickerCalendarGridHeader","DateRangePickerCalendarGridBody","Separator","DateRangePicker","fixedForwardRef","onKeyDown","hasInputFooter","shouldRenderInputFooter","input","segmentStyles","dateFieldStyles","button","buttonExcludedFromTabOrder","inputField","clear","useDictionary","setValue","DateRangePickerStateContext","calendarButtonRef","useRef","InputHeader","isFocusWithin","isHovered","DateInput","segment","DateSegment","isFocused","isFocusVisible","Tooltip","InputFooter","rangeBodyCell","dataPickerCalendarGridStyles","CalendarGridBody","date","CalendarCell","isOutsideMonth","isPressed","isSelected","isSelectionEnd","isSelectionStart","isUnavailable"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"lyra25.cjs","sources":["../src/components/inputs/date-picker/date-range-picker.tsx"],"sourcesContent":["import {\n ElementRef,\n ForwardedRef,\n KeyboardEventHandler,\n useCallback,\n useContext,\n useMemo,\n useRef,\n} from \"react\";\nimport {\n Button as AriaButton,\n CalendarCell,\n CalendarGrid,\n CalendarGridBody,\n DateInput,\n DateRangePicker as AriaDateRangePicker,\n DateRangePickerContext,\n DateRangePickerProps as AriaDateRangePickerProps,\n DateRangePickerStateContext,\n DateSegment,\n DateValue,\n Group,\n RangeCalendar,\n RangeCalendarStateContext,\n useContextProps,\n} from \"react-aria-components\";\n\nimport { VariantProps } from \"tailwind-variants\";\n\nimport { fixedForwardRef } from \"../../../utils/helpers\";\nimport { useDictionary } from \"../../../utils/providers/dictionary-provider\";\nimport { Popover } from \"../../overlays\";\nimport { Separator } from \"../../separator\";\nimport { SvgIcon } from \"../../svg-icon\";\nimport { Tooltip } from \"../../tooltip\";\nimport {\n InputFooter,\n InputFooterProps,\n InputHeader,\n InputHeaderProps,\n sharedInputStyles,\n} from \"../shared\";\nimport { shouldRenderInputFooter, shouldRenderInputHeader } from \"../shared/helpers\";\nimport { InputOuterSlotsProps } from \"../shared/types\";\n\nimport {\n dataPickerCalendarGridStyles,\n dateFieldStyles,\n datePickerHeaderStyles,\n} from \"./date-picker.styles\";\nimport { DatePickerCalendarGridHeader, MonthPicker, YearPicker } from \"./shared\";\n\nexport type DateRangePickerProps<T extends DateValue> = Omit<\n AriaDateRangePickerProps<T>,\n \"className\"\n> &\n Omit<\n VariantProps<typeof sharedInputStyles>,\n \"hasStartSlot\" | \"hasEndSlot\" | \"hasInputHeader\" | \"hasLabel\"\n > &\n InputHeaderProps &\n InputOuterSlotsProps &\n InputFooterProps & {\n className?: string;\n startSlot?: JSX.Element;\n disableClearLogic?: boolean;\n };\n\nexport type { DateValue };\n\nconst _DateRangePicker = <T extends DateValue>(\n {\n className,\n description,\n disableClearLogic,\n errorMessage,\n fullWidth = true,\n granularity = \"day\",\n hideHintLabel,\n hideInputFooter,\n hideInputHeader,\n label,\n outerEndSlot,\n outerStartSlot,\n startSlot,\n ...props\n }: DateRangePickerProps<T>,\n ref: ForwardedRef<ElementRef<typeof AriaDateRangePicker>>,\n) => {\n [props, ref] = useContextProps(props, ref, DateRangePickerContext);\n const { isInvalid, isRequired } = props;\n\n const hasInputHeader = useMemo(\n () => shouldRenderInputHeader({ hideHintLabel, hideInputHeader, label }),\n [hideHintLabel, hideInputHeader, label],\n );\n\n const { outerSlot, outerSlotsWrapper, wrapper } = sharedInputStyles({\n fullWidth,\n hasStartSlot: !!startSlot,\n hasEndSlot: true,\n hasInputHeader,\n hasLabel: !!label,\n });\n\n return (\n <div className={outerSlotsWrapper()}>\n {outerStartSlot ? <div className={outerSlot()}>{outerStartSlot}</div> : null}\n <AriaDateRangePicker\n {...props}\n granularity={granularity}\n className={(renderProps) =>\n wrapper({\n className,\n isDisabled: renderProps.isDisabled,\n })\n }\n isInvalid={isInvalid}\n ref={ref}\n >\n {({ isDisabled, state }) => (\n <>\n <Group>\n <DateRangePickerInputs\n description={description}\n fullWidth={fullWidth}\n errorMessage={errorMessage}\n hideHintLabel={hideHintLabel}\n hideInputFooter={hideInputFooter}\n hideInputHeader={hideInputHeader}\n isDisabled={isDisabled}\n isRequired={isRequired}\n label={label}\n startSlot={startSlot}\n onKeyDown={(e) => {\n if (\n e.key === \"Escape\" &&\n state.value?.end &&\n state.value?.start &&\n !isDisabled &&\n !disableClearLogic\n ) {\n e.preventDefault();\n state.setValue(null);\n }\n }}\n disableClearLogic={disableClearLogic}\n />\n </Group>\n <Popover disablePadding className=\"group\">\n <RangeCalendar visibleDuration={{ months: 2 }} pageBehavior={\"single\"}>\n <PopoverCalendarGrid />\n </RangeCalendar>\n </Popover>\n </>\n )}\n </AriaDateRangePicker>\n {outerEndSlot ? <div className={outerSlot()}>{outerEndSlot}</div> : null}\n </div>\n );\n};\n\nconst PopoverCalendarGrid = () => {\n const { buttons } = datePickerHeaderStyles();\n\n const {\n anchorDate,\n focusedDate,\n focusNextPage,\n focusPreviousPage,\n setFocusedDate,\n visibleRange,\n } = useContext(RangeCalendarStateContext);\n\n const getNextMonth = (month: number) => (month === 12 ? 1 : month + 1);\n const getPreviousMonth = (month: number) => (month === 1 ? 12 : month - 1);\n\n /**\n * Visible range logic from react-aria\n * - when setting a focused date before the current start range, the focused date is set to the end of the visible range\n * - when setting a focused date after the current end range, the focused date is set to the start of the visible range\n */\n const onStartMonthChange = useCallback(\n (value: number) => {\n if (value === visibleRange.start.month - 1) {\n focusPreviousPage();\n } else if (value === visibleRange.start.month + 1) {\n focusNextPage();\n } else {\n // when going in the past we need to make sure the focused date is in the next month so the visible range starts where we want\n const newMonth = value < visibleRange.start.month ? getNextMonth(value) : value;\n const newFocusedDate = visibleRange.start.copy().set({\n month: newMonth,\n day: focusedDate.day,\n });\n setFocusedDate(newFocusedDate);\n }\n },\n [focusNextPage, focusPreviousPage, focusedDate.day, setFocusedDate, visibleRange.start],\n );\n\n const onStartYearChange = useCallback(\n (value: number): void => {\n // handle Dec-Jan visible range separately\n if (visibleRange.start.year !== visibleRange.end.year) {\n // when going in the past the focused date should be in January so the visible range starts where we want\n if (value < visibleRange.start.year) {\n const newFocusedDate = visibleRange.start.copy().set({\n year: value + 1,\n day: focusedDate.day,\n month: 1,\n });\n\n setFocusedDate(newFocusedDate);\n }\n // when going in the future the focused date should be in December so the visible range starts where we want\n if (value > visibleRange.start.year) {\n const newFocusedDate = visibleRange.start.copy().set({\n year: value,\n day: focusedDate.day,\n month: 12,\n });\n\n setFocusedDate(newFocusedDate);\n }\n } else {\n // when going in the past we need to make sure the focused date is in the next month so the visible range starts where we want\n const newMonth =\n value < visibleRange.start.year\n ? getNextMonth(visibleRange.start.month)\n : visibleRange.start.month;\n const newFocusedDate = visibleRange.start.copy().set({\n year: value,\n day: focusedDate.day,\n month: newMonth,\n });\n\n setFocusedDate(newFocusedDate);\n }\n },\n [focusedDate.day, setFocusedDate, visibleRange.end.year, visibleRange.start],\n );\n\n const onEndMonthChange = useCallback(\n (value: number): void => {\n if (value === visibleRange.end.month - 1) {\n focusPreviousPage();\n } else if (value === visibleRange.end.month + 1) {\n focusNextPage();\n } else {\n // when going in the future we need to make sure the focused date is in the previous month so the visible range starts where we want\n const newMonth = value > visibleRange.end.month ? getPreviousMonth(value) : value;\n const newFocusedDate = visibleRange.end.copy().set({\n month: newMonth,\n day: focusedDate.day,\n });\n setFocusedDate(newFocusedDate);\n }\n },\n [focusNextPage, focusPreviousPage, focusedDate.day, setFocusedDate, visibleRange.end],\n );\n\n const onEndYearChange = useCallback(\n (value: number): void => {\n // handle Dec-Jan visible range separately\n if (visibleRange.start.year !== visibleRange.end.year) {\n // when going in the past the focused date should be in January so the visible range starts where we want\n if (value < visibleRange.end.year) {\n const newFocusedDate = visibleRange.end.copy().set({\n year: value,\n day: focusedDate.day,\n month: 1,\n });\n\n setFocusedDate(newFocusedDate);\n }\n if (value > visibleRange.end.year) {\n // when going in the future the focused date should be in December so the visible range starts where we want\n const newFocusedDate = visibleRange.end.copy().set({\n year: value - 1,\n day: focusedDate.day,\n month: 12,\n });\n\n setFocusedDate(newFocusedDate);\n }\n } else {\n // when going in the future we need to make sure the focused date is in the previous month so the visible range starts where we want\n const newMonth =\n value > visibleRange.end.year\n ? getPreviousMonth(visibleRange.end.month)\n : visibleRange.end.month;\n const newFocusedDate = visibleRange.end.copy().set({\n year: value,\n day: focusedDate.day,\n month: newMonth,\n });\n\n setFocusedDate(newFocusedDate);\n }\n },\n [focusedDate.day, setFocusedDate, visibleRange.end, visibleRange.start.year],\n );\n\n return (\n <>\n <div className=\"flex flex-col gap-3 p-3 sm:flex-row\">\n <div className=\"flex flex-col gap-3\">\n <div className=\"flex justify-between gap-1\">\n <AriaButton slot=\"previous\" className={buttons()}>\n <SvgIcon name=\"chevron-left\" />\n </AriaButton>\n <div className=\"flex gap-1\">\n <MonthPicker\n value={visibleRange.start.month}\n isDisabled={!!anchorDate}\n onChange={onStartMonthChange}\n />\n <YearPicker\n value={visibleRange.start.year}\n isDisabled={!!anchorDate}\n onChange={onStartYearChange}\n />\n </div>\n <div className=\"w-6\" />\n </div>\n <CalendarGrid className=\"w-full text-center\">\n <DatePickerCalendarGridHeader />\n <DateRangePickerCalendarGridBody />\n </CalendarGrid>\n </div>\n\n <Separator orientation=\"vertical\" className=\"hidden h-[unset] self-stretch sm:block\" />\n <Separator className=\"sm:hidden\" />\n\n <div className=\"flex flex-col gap-3\">\n <div className=\"flex justify-between gap-1\">\n <div className=\"w-6\" />\n <div className=\"flex gap-1\">\n <MonthPicker\n value={visibleRange.end.month}\n isDisabled={!!anchorDate}\n onChange={onEndMonthChange}\n />\n <YearPicker\n value={visibleRange.end.year}\n isDisabled={!!anchorDate}\n onChange={onEndYearChange}\n />\n </div>\n <AriaButton slot=\"next\" className={buttons()}>\n <SvgIcon name=\"chevron-right\" />\n </AriaButton>\n </div>\n <CalendarGrid className=\"w-full text-center\" offset={{ months: 1 }}>\n <DatePickerCalendarGridHeader />\n <DateRangePickerCalendarGridBody />\n </CalendarGrid>\n </div>\n </div>\n </>\n );\n};\n\nexport const DateRangePicker = fixedForwardRef(_DateRangePicker);\n//@ts-ignore\nDateRangePicker.displayName = \"DateRangePicker\";\ntype DateRangePickerInputsProps = VariantProps<typeof sharedInputStyles> &\n InputHeaderProps &\n InputFooterProps & {\n startSlot?: JSX.Element;\n onKeyDown?: KeyboardEventHandler<HTMLElement>;\n disableClearLogic?: boolean;\n };\n\nconst DateRangePickerInputs = ({\n description,\n disableClearLogic,\n errorMessage,\n fullWidth,\n hideHintLabel,\n hideInputFooter,\n hideInputHeader,\n isDisabled,\n isRequired,\n label,\n onKeyDown,\n startSlot,\n}: DateRangePickerInputsProps) => {\n const hasInputHeader = useMemo(\n () => shouldRenderInputHeader({ hideHintLabel, hideInputHeader, label }),\n [hideHintLabel, hideInputHeader, label],\n );\n\n const hasInputFooter = useMemo(\n () => shouldRenderInputFooter({ description, errorMessage, hideInputFooter }),\n [description, errorMessage, hideInputFooter],\n );\n\n const { input, segment: segmentStyles } = dateFieldStyles();\n const { button, buttonExcludedFromTabOrder, inputField } = sharedInputStyles({\n fullWidth,\n hasStartSlot: !!startSlot,\n hasEndSlot: true,\n });\n\n const { clear } = useDictionary();\n const { setValue, value } = useContext(DateRangePickerStateContext);\n\n const calendarButtonRef = useRef<HTMLButtonElement | null>(null);\n\n return (\n <>\n {hasInputHeader ? (\n <InputHeader label={label} hideHintLabel={hideHintLabel} isRequired={isRequired} />\n ) : null}\n <Group\n className={({ isDisabled, isFocusWithin, isHovered, isInvalid }) =>\n inputField({\n isDisabled,\n isFocused: isFocusWithin,\n isHovered,\n isInvalid,\n className: \"min-h-8\",\n })\n }\n onKeyDown={onKeyDown}\n >\n {startSlot}\n <DateInput className={input()} slot=\"start\">\n {(segment) => (\n <DateSegment\n className={({ isFocused }) => {\n return segmentStyles({\n isFocused,\n isDisabled,\n // consider literals (separators between segments) to have a value when a full date is entered\n hasValue: segment.type === \"literal\" ? !!value?.start : !segment.isPlaceholder,\n });\n }}\n segment={segment}\n />\n )}\n </DateInput>\n\n <span\n aria-hidden=\"true\"\n className={\n !!value?.start && !!value.end && !isDisabled ? \"text-primary\" : \"text-tertiary\"\n }\n >\n – \n </span>\n\n <DateInput className={input()} slot=\"end\">\n {(segment) => (\n <DateSegment\n className={({ isFocused }) => {\n return segmentStyles({\n isFocused,\n isDisabled,\n // consider literals (separators between segments) to have a value when a full date is entered\n hasValue: segment.type === \"literal\" ? !!value?.end : !segment.isPlaceholder,\n });\n }}\n segment={segment}\n />\n )}\n </DateInput>\n\n {/* We reverse the order so we can go back to the date input by pressing the left arrow when the calendar button is focused. \n Otherwise the clear button would be focused instead and it would move the focus back to the calendar button */}\n <div className=\"ms-auto flex flex-row-reverse gap-2\">\n <AriaButton\n isDisabled={isDisabled}\n className={({ isDisabled, isFocusVisible, isHovered }) =>\n button({ isDisabled, isFocused: isFocusVisible, isHovered })\n }\n ref={calendarButtonRef}\n >\n <SvgIcon name=\"calendar\" />\n </AriaButton>\n\n {!isDisabled && value?.end && value?.start && !disableClearLogic ? (\n <Tooltip tooltip={clear}>\n <AriaButton\n slot={null}\n onFocus={(e) => {\n e.preventDefault();\n // when filling in a full value in the input this button gets focus automatically, we move focus the calendar button instead\n calendarButtonRef?.current?.focus();\n }}\n excludeFromTabOrder\n className={buttonExcludedFromTabOrder()}\n onPress={() => {\n setValue(null);\n // focus the calendar button after clearing the value\n // this way the user can easily open the calendar again\n // plus focusing another element afterwards makes sure that the focus is moved\n // https://n6k.atlassian.net/browse/OPTR-31779\n calendarButtonRef.current?.focus();\n }}\n >\n <SvgIcon name=\"clear\" />\n </AriaButton>\n </Tooltip>\n ) : null}\n </div>\n </Group>\n {hasInputFooter ? (\n <InputFooter description={description} errorMessage={errorMessage} />\n ) : null}\n </>\n );\n};\n\nconst DateRangePickerCalendarGridBody = () => {\n const { rangeBodyCell } = dataPickerCalendarGridStyles();\n\n return (\n <CalendarGridBody>\n {(date) => (\n <CalendarCell\n date={date}\n className={({\n isDisabled,\n isFocusVisible,\n isHovered,\n isOutsideMonth,\n isPressed,\n isSelected,\n isSelectionEnd,\n isSelectionStart,\n isUnavailable,\n }) =>\n rangeBodyCell({\n isSelected,\n isSelectionStart,\n isSelectionEnd,\n isFocusVisible,\n isHovered,\n isUnavailable,\n isDisabled,\n isOutsideMonth,\n isPressed,\n })\n }\n />\n )}\n </CalendarGridBody>\n );\n};\n"],"names":["_DateRangePicker","className","description","disableClearLogic","errorMessage","fullWidth","granularity","hideHintLabel","hideInputFooter","hideInputHeader","label","outerEndSlot","outerStartSlot","startSlot","props","ref","useContextProps","DateRangePickerContext","isInvalid","isRequired","hasInputHeader","useMemo","shouldRenderInputHeader","outerSlot","outerSlotsWrapper","wrapper","sharedInputStyles","jsxs","jsx","AriaDateRangePicker","renderProps","isDisabled","state","Fragment","Group","DateRangePickerInputs","e","_a","_b","Popover","RangeCalendar","PopoverCalendarGrid","buttons","datePickerHeaderStyles","anchorDate","focusedDate","focusNextPage","focusPreviousPage","setFocusedDate","visibleRange","useContext","RangeCalendarStateContext","getNextMonth","month","getPreviousMonth","onStartMonthChange","useCallback","value","newMonth","newFocusedDate","onStartYearChange","onEndMonthChange","onEndYearChange","AriaButton","SvgIcon","MonthPicker","YearPicker","CalendarGrid","DatePickerCalendarGridHeader","DateRangePickerCalendarGridBody","Separator","DateRangePicker","fixedForwardRef","onKeyDown","hasInputFooter","shouldRenderInputFooter","input","segmentStyles","dateFieldStyles","button","buttonExcludedFromTabOrder","inputField","clear","useDictionary","setValue","DateRangePickerStateContext","calendarButtonRef","useRef","InputHeader","isFocusWithin","isHovered","DateInput","segment","DateSegment","isFocused","isFocusVisible","Tooltip","InputFooter","rangeBodyCell","dataPickerCalendarGridStyles","CalendarGridBody","date","CalendarCell","isOutsideMonth","isPressed","isSelected","isSelectionEnd","isSelectionStart","isUnavailable"],"mappings":"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"}
|