@anoki/fse-ui 1.0.548 → 1.0.549
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/index.cjs.js.map +1 -1
- package/dist/index.cjs10.js +1 -1
- package/dist/index.cjs10.js.map +1 -1
- package/dist/index.cjs101.js.map +1 -1
- package/dist/index.cjs103.js.map +1 -1
- package/dist/index.cjs104.js.map +1 -1
- package/dist/index.cjs105.js.map +1 -1
- package/dist/index.cjs106.js.map +1 -1
- package/dist/index.cjs109.js.map +1 -1
- package/dist/index.cjs11.js.map +1 -1
- package/dist/index.cjs112.js.map +1 -1
- package/dist/index.cjs114.js.map +1 -1
- package/dist/index.cjs115.js +1 -1
- package/dist/index.cjs115.js.map +1 -1
- package/dist/index.cjs116.js +1 -1
- package/dist/index.cjs116.js.map +1 -1
- package/dist/index.cjs117.js +1 -1
- package/dist/index.cjs117.js.map +1 -1
- package/dist/index.cjs118.js +1 -1
- package/dist/index.cjs118.js.map +1 -1
- package/dist/index.cjs119.js +1 -1
- package/dist/index.cjs119.js.map +1 -1
- package/dist/index.cjs12.js.map +1 -1
- package/dist/index.cjs120.js +1 -1
- package/dist/index.cjs120.js.map +1 -1
- package/dist/index.cjs121.js +1 -1
- package/dist/index.cjs121.js.map +1 -1
- package/dist/index.cjs122.js +1 -1
- package/dist/index.cjs122.js.map +1 -1
- package/dist/index.cjs123.js +1 -1
- package/dist/index.cjs123.js.map +1 -1
- package/dist/index.cjs124.js +1 -1
- package/dist/index.cjs124.js.map +1 -1
- package/dist/index.cjs125.js +1 -1
- package/dist/index.cjs125.js.map +1 -1
- package/dist/index.cjs126.js +1 -1
- package/dist/index.cjs126.js.map +1 -1
- package/dist/index.cjs127.js +1 -1
- package/dist/index.cjs127.js.map +1 -1
- package/dist/index.cjs128.js +1 -1
- package/dist/index.cjs128.js.map +1 -1
- package/dist/index.cjs129.js +1 -1
- package/dist/index.cjs129.js.map +1 -1
- package/dist/index.cjs13.js.map +1 -1
- package/dist/index.cjs130.js +1 -1
- package/dist/index.cjs130.js.map +1 -1
- package/dist/index.cjs131.js +1 -1
- package/dist/index.cjs131.js.map +1 -1
- package/dist/index.cjs132.js +1 -1
- package/dist/index.cjs132.js.map +1 -1
- package/dist/index.cjs133.js +1 -1
- package/dist/index.cjs133.js.map +1 -1
- package/dist/index.cjs134.js +1 -1
- package/dist/index.cjs134.js.map +1 -1
- package/dist/index.cjs135.js +1 -1
- package/dist/index.cjs135.js.map +1 -1
- package/dist/index.cjs136.js +1 -1
- package/dist/index.cjs136.js.map +1 -1
- package/dist/index.cjs137.js.map +1 -1
- package/dist/index.cjs138.js.map +1 -1
- package/dist/index.cjs139.js +1 -1
- package/dist/index.cjs139.js.map +1 -1
- package/dist/index.cjs14.js.map +1 -1
- package/dist/index.cjs140.js +1 -1
- package/dist/index.cjs140.js.map +1 -1
- package/dist/index.cjs141.js +1 -1
- package/dist/index.cjs141.js.map +1 -1
- package/dist/index.cjs142.js.map +1 -1
- package/dist/index.cjs143.js +1 -1
- package/dist/index.cjs143.js.map +1 -1
- package/dist/index.cjs144.js +1 -1
- package/dist/index.cjs144.js.map +1 -1
- package/dist/index.cjs145.js +1 -1
- package/dist/index.cjs145.js.map +1 -1
- package/dist/index.cjs146.js +1 -1
- package/dist/index.cjs146.js.map +1 -1
- package/dist/index.cjs147.js +1 -1
- package/dist/index.cjs147.js.map +1 -1
- package/dist/index.cjs148.js +1 -1
- package/dist/index.cjs148.js.map +1 -1
- package/dist/index.cjs149.js +1 -1
- package/dist/index.cjs149.js.map +1 -1
- package/dist/index.cjs15.js.map +1 -1
- package/dist/index.cjs150.js +1 -1
- package/dist/index.cjs150.js.map +1 -1
- package/dist/index.cjs151.js +1 -1
- package/dist/index.cjs151.js.map +1 -1
- package/dist/index.cjs152.js.map +1 -1
- package/dist/index.cjs153.js +1 -1
- package/dist/index.cjs153.js.map +1 -1
- package/dist/index.cjs154.js +1 -1
- package/dist/index.cjs154.js.map +1 -1
- package/dist/index.cjs155.js +1 -1
- package/dist/index.cjs155.js.map +1 -1
- package/dist/index.cjs156.js +1 -1
- package/dist/index.cjs156.js.map +1 -1
- package/dist/index.cjs157.js +1 -1
- package/dist/index.cjs157.js.map +1 -1
- package/dist/index.cjs158.js +1 -1
- package/dist/index.cjs158.js.map +1 -1
- package/dist/index.cjs159.js +1 -1
- package/dist/index.cjs159.js.map +1 -1
- package/dist/index.cjs16.js.map +1 -1
- package/dist/index.cjs160.js.map +1 -1
- package/dist/index.cjs161.js +1 -1
- package/dist/index.cjs162.js +1 -1
- package/dist/index.cjs163.js +1 -1
- package/dist/index.cjs164.js +1 -1
- package/dist/index.cjs165.js +1 -1
- package/dist/index.cjs166.js +1 -1
- package/dist/index.cjs166.js.map +1 -1
- package/dist/index.cjs167.js +1 -1
- package/dist/index.cjs167.js.map +1 -1
- package/dist/index.cjs17.js.map +1 -1
- package/dist/index.cjs171.js +1 -1
- package/dist/index.cjs171.js.map +1 -1
- package/dist/index.cjs18.js.map +1 -1
- package/dist/index.cjs180.js +1 -1
- package/dist/index.cjs180.js.map +1 -1
- package/dist/index.cjs184.js +1 -1
- package/dist/index.cjs184.js.map +1 -1
- package/dist/index.cjs19.js.map +1 -1
- package/dist/index.cjs196.js +1 -1
- package/dist/index.cjs196.js.map +1 -1
- package/dist/index.cjs197.js +2 -0
- package/dist/index.cjs197.js.map +1 -0
- package/dist/index.cjs199.js.map +1 -1
- package/dist/index.cjs20.js.map +1 -1
- package/dist/index.cjs203.js.map +1 -1
- package/dist/index.cjs207.js +1 -1
- package/dist/index.cjs207.js.map +1 -1
- package/dist/index.cjs21.js.map +1 -1
- package/dist/index.cjs210.js.map +1 -1
- package/dist/index.cjs213.js +1 -1
- package/dist/index.cjs216.js +1 -1
- package/dist/index.cjs216.js.map +1 -1
- package/dist/index.cjs217.js +1 -1
- package/dist/index.cjs217.js.map +1 -1
- package/dist/index.cjs22.js +1 -1
- package/dist/index.cjs22.js.map +1 -1
- package/dist/index.cjs224.js +1 -1
- package/dist/index.cjs225.js.map +1 -1
- package/dist/index.cjs228.js.map +1 -1
- package/dist/index.cjs23.js.map +1 -1
- package/dist/index.cjs233.js +1 -1
- package/dist/index.cjs233.js.map +1 -1
- package/dist/index.cjs235.js +1 -1
- package/dist/index.cjs236.js.map +1 -1
- package/dist/index.cjs237.js.map +1 -1
- package/dist/index.cjs238.js.map +1 -1
- package/dist/index.cjs239.js.map +1 -1
- package/dist/index.cjs241.js.map +1 -1
- package/dist/index.cjs242.js +1 -1
- package/dist/index.cjs242.js.map +1 -1
- package/dist/index.cjs243.js.map +1 -1
- package/dist/index.cjs246.js.map +1 -1
- package/dist/index.cjs247.js +1 -1
- package/dist/index.cjs247.js.map +1 -1
- package/dist/index.cjs25.js +1 -1
- package/dist/index.cjs25.js.map +1 -1
- package/dist/index.cjs252.js.map +1 -1
- package/dist/index.cjs253.js.map +1 -1
- package/dist/index.cjs254.js +1 -1
- package/dist/index.cjs254.js.map +1 -1
- package/dist/index.cjs256.js.map +1 -1
- package/dist/index.cjs257.js.map +1 -1
- package/dist/index.cjs258.js.map +1 -1
- package/dist/index.cjs260.js +1 -1
- package/dist/index.cjs261.js +1 -1
- package/dist/index.cjs261.js.map +1 -1
- package/dist/index.cjs262.js +1 -1
- package/dist/index.cjs27.js.map +1 -1
- package/dist/index.cjs28.js.map +1 -1
- package/dist/index.cjs30.js.map +1 -1
- package/dist/index.cjs301.js +1 -1
- package/dist/index.cjs309.js.map +1 -1
- package/dist/index.cjs31.js.map +1 -1
- package/dist/index.cjs314.js +1 -1
- package/dist/index.cjs32.js.map +1 -1
- package/dist/index.cjs320.js.map +1 -1
- package/dist/index.cjs322.js.map +1 -1
- package/dist/index.cjs326.js +1 -1
- package/dist/index.cjs327.js +3 -12
- package/dist/index.cjs327.js.map +1 -1
- package/dist/index.cjs33.js.map +1 -1
- package/dist/index.cjs331.js +2 -0
- package/dist/index.cjs331.js.map +1 -0
- package/dist/index.cjs332.js +1 -1
- package/dist/index.cjs332.js.map +1 -1
- package/dist/index.cjs333.js +2 -0
- package/dist/index.cjs333.js.map +1 -0
- package/dist/index.cjs334.js +2 -0
- package/dist/index.cjs334.js.map +1 -0
- package/dist/index.cjs335.js +1 -1
- package/dist/index.cjs335.js.map +1 -1
- package/dist/index.cjs336.js +1 -1
- package/dist/index.cjs336.js.map +1 -1
- package/dist/index.cjs337.js +1 -1
- package/dist/index.cjs337.js.map +1 -1
- package/dist/index.cjs338.js +1 -1
- package/dist/index.cjs338.js.map +1 -1
- package/dist/index.cjs34.js.map +1 -1
- package/dist/index.cjs343.js +1 -1
- package/dist/index.cjs344.js +1 -1
- package/dist/index.cjs35.js.map +1 -1
- package/dist/{index.cjs345.js → index.cjs357.js} +2 -2
- package/dist/{index.cjs345.js.map → index.cjs357.js.map} +1 -1
- package/dist/index.cjs358.js +1 -1
- package/dist/index.cjs358.js.map +1 -1
- package/dist/index.cjs359.js +1 -1
- package/dist/index.cjs359.js.map +1 -1
- package/dist/index.cjs36.js.map +1 -1
- package/dist/{index.cjs348.js → index.cjs360.js} +1 -1
- package/dist/{index.cjs348.js.map → index.cjs360.js.map} +1 -1
- package/dist/{index.cjs349.js → index.cjs361.js} +2 -2
- package/dist/{index.cjs349.js.map → index.cjs361.js.map} +1 -1
- package/dist/{index.cjs350.js → index.cjs362.js} +1 -1
- package/dist/{index.cjs350.js.map → index.cjs362.js.map} +1 -1
- package/dist/{index.cjs351.js → index.cjs363.js} +2 -2
- package/dist/{index.cjs351.js.map → index.cjs363.js.map} +1 -1
- package/dist/index.cjs369.js +1 -1
- package/dist/index.cjs369.js.map +1 -1
- package/dist/index.cjs37.js.map +1 -1
- package/dist/index.cjs370.js +1 -1
- package/dist/index.cjs370.js.map +1 -1
- package/dist/index.cjs371.js +1 -1
- package/dist/index.cjs371.js.map +1 -1
- package/dist/index.cjs372.js +1 -1
- package/dist/index.cjs372.js.map +1 -1
- package/dist/index.cjs373.js +1 -1
- package/dist/index.cjs373.js.map +1 -1
- package/dist/index.cjs374.js +1 -1
- package/dist/index.cjs374.js.map +1 -1
- package/dist/index.cjs375.js +1 -1
- package/dist/index.cjs375.js.map +1 -1
- package/dist/index.cjs376.js +1 -1
- package/dist/index.cjs376.js.map +1 -1
- package/dist/index.cjs377.js +1 -1
- package/dist/index.cjs377.js.map +1 -1
- package/dist/index.cjs378.js +1 -1
- package/dist/index.cjs378.js.map +1 -1
- package/dist/index.cjs379.js +1 -1
- package/dist/index.cjs379.js.map +1 -1
- package/dist/index.cjs38.js.map +1 -1
- package/dist/index.cjs380.js +1 -1
- package/dist/index.cjs380.js.map +1 -1
- package/dist/index.cjs381.js +1 -1
- package/dist/index.cjs381.js.map +1 -1
- package/dist/index.cjs382.js +1 -1
- package/dist/index.cjs382.js.map +1 -1
- package/dist/index.cjs383.js +1 -1
- package/dist/index.cjs383.js.map +1 -1
- package/dist/index.cjs384.js +1 -1
- package/dist/index.cjs384.js.map +1 -1
- package/dist/index.cjs385.js +1 -4
- package/dist/index.cjs385.js.map +1 -1
- package/dist/index.cjs386.js +1 -1
- package/dist/index.cjs386.js.map +1 -1
- package/dist/index.cjs387.js +1 -1
- package/dist/index.cjs387.js.map +1 -1
- package/dist/index.cjs388.js +1 -38
- package/dist/index.cjs388.js.map +1 -1
- package/dist/index.cjs389.js +1 -1
- package/dist/index.cjs389.js.map +1 -1
- package/dist/index.cjs39.js.map +1 -1
- package/dist/index.cjs390.js +1 -1
- package/dist/index.cjs390.js.map +1 -1
- package/dist/index.cjs391.js +1 -1
- package/dist/index.cjs391.js.map +1 -1
- package/dist/index.cjs392.js +1 -1
- package/dist/index.cjs392.js.map +1 -1
- package/dist/index.cjs393.js +1 -1
- package/dist/index.cjs393.js.map +1 -1
- package/dist/index.cjs394.js +1 -1
- package/dist/index.cjs394.js.map +1 -1
- package/dist/index.cjs395.js +4 -1
- package/dist/index.cjs395.js.map +1 -1
- package/dist/index.cjs396.js +1 -1
- package/dist/index.cjs396.js.map +1 -1
- package/dist/index.cjs397.js +6 -0
- package/dist/index.cjs397.js.map +1 -0
- package/dist/index.cjs398.js +2 -0
- package/dist/index.cjs398.js.map +1 -0
- package/dist/index.cjs399.js +1 -1
- package/dist/index.cjs399.js.map +1 -1
- package/dist/index.cjs40.js.map +1 -1
- package/dist/index.cjs400.js +1 -1
- package/dist/index.cjs400.js.map +1 -1
- package/dist/index.cjs401.js +1 -1
- package/dist/index.cjs401.js.map +1 -1
- package/dist/index.cjs402.js +1 -1
- package/dist/index.cjs402.js.map +1 -1
- package/dist/index.cjs403.js +1 -1
- package/dist/index.cjs403.js.map +1 -1
- package/dist/index.cjs404.js +1 -1
- package/dist/index.cjs404.js.map +1 -1
- package/dist/index.cjs405.js +1 -1
- package/dist/index.cjs405.js.map +1 -1
- package/dist/index.cjs406.js +1 -1
- package/dist/index.cjs406.js.map +1 -1
- package/dist/index.cjs407.js +1 -1
- package/dist/index.cjs407.js.map +1 -1
- package/dist/index.cjs408.js +1 -1
- package/dist/index.cjs408.js.map +1 -1
- package/dist/index.cjs409.js +38 -1
- package/dist/index.cjs409.js.map +1 -1
- package/dist/index.cjs41.js.map +1 -1
- package/dist/index.cjs410.js +1 -1
- package/dist/index.cjs410.js.map +1 -1
- package/dist/index.cjs411.js +1 -5
- package/dist/index.cjs411.js.map +1 -1
- package/dist/index.cjs412.js +1 -1
- package/dist/index.cjs412.js.map +1 -1
- package/dist/index.cjs413.js +1 -1
- package/dist/index.cjs413.js.map +1 -1
- package/dist/index.cjs414.js +1 -1
- package/dist/index.cjs414.js.map +1 -1
- package/dist/index.cjs415.js +1 -1
- package/dist/index.cjs415.js.map +1 -1
- package/dist/index.cjs416.js +1 -1
- package/dist/index.cjs416.js.map +1 -1
- package/dist/index.cjs417.js +1 -1
- package/dist/index.cjs417.js.map +1 -1
- package/dist/index.cjs418.js +1 -1
- package/dist/index.cjs418.js.map +1 -1
- package/dist/index.cjs419.js +1 -1
- package/dist/index.cjs419.js.map +1 -1
- package/dist/index.cjs42.js.map +1 -1
- package/dist/index.cjs43.js.map +1 -1
- package/dist/index.cjs44.js.map +1 -1
- package/dist/index.cjs45.js.map +1 -1
- package/dist/index.cjs46.js.map +1 -1
- package/dist/index.cjs47.js.map +1 -1
- package/dist/index.cjs48.js.map +1 -1
- package/dist/index.cjs49.js.map +1 -1
- package/dist/index.cjs50.js.map +1 -1
- package/dist/index.cjs51.js.map +1 -1
- package/dist/index.cjs52.js.map +1 -1
- package/dist/index.cjs53.js.map +1 -1
- package/dist/index.cjs54.js.map +1 -1
- package/dist/index.cjs56.js +1 -1
- package/dist/index.cjs56.js.map +1 -1
- package/dist/index.cjs57.js.map +1 -1
- package/dist/index.cjs58.js.map +1 -1
- package/dist/index.cjs6.js +1 -1
- package/dist/index.cjs6.js.map +1 -1
- package/dist/index.cjs60.js.map +1 -1
- package/dist/index.cjs61.js.map +1 -1
- package/dist/index.cjs62.js.map +1 -1
- package/dist/index.cjs63.js.map +1 -1
- package/dist/index.cjs64.js.map +1 -1
- package/dist/index.cjs65.js +1 -1
- package/dist/index.cjs65.js.map +1 -1
- package/dist/index.cjs67.js.map +1 -1
- package/dist/index.cjs68.js.map +1 -1
- package/dist/index.cjs69.js.map +1 -1
- package/dist/index.cjs7.js +1 -1
- package/dist/index.cjs7.js.map +1 -1
- package/dist/index.cjs71.js.map +1 -1
- package/dist/index.cjs72.js.map +1 -1
- package/dist/index.cjs73.js.map +1 -1
- package/dist/index.cjs74.js.map +1 -1
- package/dist/index.cjs75.js.map +1 -1
- package/dist/index.cjs76.js.map +1 -1
- package/dist/index.cjs77.js.map +1 -1
- package/dist/index.cjs78.js.map +1 -1
- package/dist/index.cjs79.js.map +1 -1
- package/dist/index.cjs8.js +1 -1
- package/dist/index.cjs8.js.map +1 -1
- package/dist/index.cjs80.js.map +1 -1
- package/dist/index.cjs81.js.map +1 -1
- package/dist/index.cjs82.js.map +1 -1
- package/dist/index.cjs83.js.map +1 -1
- package/dist/index.cjs84.js.map +1 -1
- package/dist/index.cjs85.js.map +1 -1
- package/dist/index.cjs86.js.map +1 -1
- package/dist/index.cjs87.js.map +1 -1
- package/dist/index.cjs88.js.map +1 -1
- package/dist/index.cjs9.js +1 -1
- package/dist/index.cjs90.js.map +1 -1
- package/dist/index.cjs91.js.map +1 -1
- package/dist/index.cjs94.js.map +1 -1
- package/dist/index.cjs95.js.map +1 -1
- package/dist/index.cjs96.js.map +1 -1
- package/dist/index.cjs97.js.map +1 -1
- package/dist/index.cjs98.js.map +1 -1
- package/dist/index.cjs99.js.map +1 -1
- package/dist/index.d.ts +8 -0
- package/dist/index.es.js.map +1 -1
- package/dist/index.es10.js +2 -2
- package/dist/index.es10.js.map +1 -1
- package/dist/index.es101.js.map +1 -1
- package/dist/index.es103.js.map +1 -1
- package/dist/index.es104.js.map +1 -1
- package/dist/index.es105.js.map +1 -1
- package/dist/index.es106.js.map +1 -1
- package/dist/index.es109.js.map +1 -1
- package/dist/index.es11.js.map +1 -1
- package/dist/index.es112.js.map +1 -1
- package/dist/index.es114.js.map +1 -1
- package/dist/index.es115.js +1 -1
- package/dist/index.es115.js.map +1 -1
- package/dist/index.es116.js +1 -1
- package/dist/index.es116.js.map +1 -1
- package/dist/index.es117.js +1 -1
- package/dist/index.es117.js.map +1 -1
- package/dist/index.es118.js +1 -1
- package/dist/index.es118.js.map +1 -1
- package/dist/index.es119.js +1 -1
- package/dist/index.es119.js.map +1 -1
- package/dist/index.es12.js.map +1 -1
- package/dist/index.es120.js +1 -1
- package/dist/index.es120.js.map +1 -1
- package/dist/index.es121.js +1 -1
- package/dist/index.es121.js.map +1 -1
- package/dist/index.es122.js +1 -1
- package/dist/index.es122.js.map +1 -1
- package/dist/index.es123.js +1 -1
- package/dist/index.es123.js.map +1 -1
- package/dist/index.es124.js +1 -1
- package/dist/index.es124.js.map +1 -1
- package/dist/index.es125.js +1 -1
- package/dist/index.es125.js.map +1 -1
- package/dist/index.es126.js +1 -1
- package/dist/index.es126.js.map +1 -1
- package/dist/index.es127.js +1 -1
- package/dist/index.es127.js.map +1 -1
- package/dist/index.es128.js +1 -1
- package/dist/index.es128.js.map +1 -1
- package/dist/index.es129.js +1 -1
- package/dist/index.es129.js.map +1 -1
- package/dist/index.es13.js.map +1 -1
- package/dist/index.es130.js +1 -1
- package/dist/index.es130.js.map +1 -1
- package/dist/index.es131.js +1 -1
- package/dist/index.es131.js.map +1 -1
- package/dist/index.es132.js +1 -1
- package/dist/index.es132.js.map +1 -1
- package/dist/index.es133.js +1 -1
- package/dist/index.es133.js.map +1 -1
- package/dist/index.es134.js +1 -1
- package/dist/index.es134.js.map +1 -1
- package/dist/index.es135.js +1 -1
- package/dist/index.es135.js.map +1 -1
- package/dist/index.es136.js +1 -1
- package/dist/index.es136.js.map +1 -1
- package/dist/index.es137.js.map +1 -1
- package/dist/index.es138.js.map +1 -1
- package/dist/index.es139.js +1 -1
- package/dist/index.es139.js.map +1 -1
- package/dist/index.es14.js.map +1 -1
- package/dist/index.es140.js +1 -1
- package/dist/index.es140.js.map +1 -1
- package/dist/index.es141.js +1 -1
- package/dist/index.es141.js.map +1 -1
- package/dist/index.es142.js.map +1 -1
- package/dist/index.es143.js +1 -1
- package/dist/index.es143.js.map +1 -1
- package/dist/index.es144.js +1 -1
- package/dist/index.es144.js.map +1 -1
- package/dist/index.es145.js +1 -1
- package/dist/index.es145.js.map +1 -1
- package/dist/index.es146.js +1 -1
- package/dist/index.es146.js.map +1 -1
- package/dist/index.es147.js +1 -1
- package/dist/index.es147.js.map +1 -1
- package/dist/index.es148.js +1 -1
- package/dist/index.es148.js.map +1 -1
- package/dist/index.es149.js +1 -1
- package/dist/index.es149.js.map +1 -1
- package/dist/index.es15.js.map +1 -1
- package/dist/index.es150.js +1 -1
- package/dist/index.es150.js.map +1 -1
- package/dist/index.es151.js +1 -1
- package/dist/index.es151.js.map +1 -1
- package/dist/index.es152.js.map +1 -1
- package/dist/index.es153.js +1 -1
- package/dist/index.es153.js.map +1 -1
- package/dist/index.es154.js +1 -1
- package/dist/index.es154.js.map +1 -1
- package/dist/index.es155.js +1 -1
- package/dist/index.es155.js.map +1 -1
- package/dist/index.es156.js +1 -1
- package/dist/index.es156.js.map +1 -1
- package/dist/index.es157.js +1 -1
- package/dist/index.es157.js.map +1 -1
- package/dist/index.es158.js +1 -1
- package/dist/index.es158.js.map +1 -1
- package/dist/index.es159.js +1 -1
- package/dist/index.es159.js.map +1 -1
- package/dist/index.es16.js.map +1 -1
- package/dist/index.es160.js.map +1 -1
- package/dist/index.es161.js +1 -1
- package/dist/index.es162.js +1 -1
- package/dist/index.es163.js +1 -1
- package/dist/index.es164.js +1 -1
- package/dist/index.es165.js +1 -1
- package/dist/index.es166.js +76 -71
- package/dist/index.es166.js.map +1 -1
- package/dist/index.es167.js +11 -1
- package/dist/index.es167.js.map +1 -1
- package/dist/index.es17.js.map +1 -1
- package/dist/index.es171.js +63 -58
- package/dist/index.es171.js.map +1 -1
- package/dist/index.es18.js.map +1 -1
- package/dist/index.es180.js +29 -26
- package/dist/index.es180.js.map +1 -1
- package/dist/index.es184.js +18 -15
- package/dist/index.es184.js.map +1 -1
- package/dist/index.es19.js.map +1 -1
- package/dist/index.es196.js +2 -27
- package/dist/index.es196.js.map +1 -1
- package/dist/index.es197.js +30 -0
- package/dist/index.es197.js.map +1 -0
- package/dist/index.es199.js.map +1 -1
- package/dist/index.es20.js.map +1 -1
- package/dist/index.es203.js.map +1 -1
- package/dist/index.es207.js +1 -1
- package/dist/index.es207.js.map +1 -1
- package/dist/index.es21.js.map +1 -1
- package/dist/index.es210.js.map +1 -1
- package/dist/index.es213.js +7 -7
- package/dist/index.es216.js +1 -1
- package/dist/index.es216.js.map +1 -1
- package/dist/index.es217.js +1 -1
- package/dist/index.es217.js.map +1 -1
- package/dist/index.es22.js +1 -1
- package/dist/index.es22.js.map +1 -1
- package/dist/index.es224.js +5 -5
- package/dist/index.es225.js.map +1 -1
- package/dist/index.es228.js.map +1 -1
- package/dist/index.es23.js.map +1 -1
- package/dist/index.es233.js +1 -1
- package/dist/index.es233.js.map +1 -1
- package/dist/index.es235.js +13 -13
- package/dist/index.es236.js.map +1 -1
- package/dist/index.es237.js.map +1 -1
- package/dist/index.es238.js.map +1 -1
- package/dist/index.es239.js.map +1 -1
- package/dist/index.es241.js.map +1 -1
- package/dist/index.es242.js +1 -1
- package/dist/index.es242.js.map +1 -1
- package/dist/index.es243.js.map +1 -1
- package/dist/index.es246.js.map +1 -1
- package/dist/index.es247.js +1 -1
- package/dist/index.es247.js.map +1 -1
- package/dist/index.es25.js +1 -1
- package/dist/index.es25.js.map +1 -1
- package/dist/index.es252.js.map +1 -1
- package/dist/index.es253.js.map +1 -1
- package/dist/index.es254.js +1 -1
- package/dist/index.es254.js.map +1 -1
- package/dist/index.es256.js.map +1 -1
- package/dist/index.es257.js.map +1 -1
- package/dist/index.es258.js.map +1 -1
- package/dist/index.es260.js +1 -1
- package/dist/index.es261.js +1 -1
- package/dist/index.es261.js.map +1 -1
- package/dist/index.es262.js +5 -5
- package/dist/index.es27.js.map +1 -1
- package/dist/index.es28.js.map +1 -1
- package/dist/index.es30.js.map +1 -1
- package/dist/index.es301.js +4 -4
- package/dist/index.es309.js.map +1 -1
- package/dist/index.es31.js.map +1 -1
- package/dist/index.es314.js +8 -8
- package/dist/index.es32.js.map +1 -1
- package/dist/index.es320.js.map +1 -1
- package/dist/index.es322.js.map +1 -1
- package/dist/index.es326.js +1 -1
- package/dist/index.es327.js +146 -307
- package/dist/index.es327.js.map +1 -1
- package/dist/index.es33.js.map +1 -1
- package/dist/index.es331.js +10 -0
- package/dist/index.es331.js.map +1 -0
- package/dist/index.es332.js +27 -15
- package/dist/index.es332.js.map +1 -1
- package/dist/index.es333.js +71 -0
- package/dist/index.es333.js.map +1 -0
- package/dist/index.es334.js +33 -0
- package/dist/index.es334.js.map +1 -0
- package/dist/index.es335.js +32 -6
- package/dist/index.es335.js.map +1 -1
- package/dist/index.es336.js +618 -23
- package/dist/index.es336.js.map +1 -1
- package/dist/index.es337.js +10 -67
- package/dist/index.es337.js.map +1 -1
- package/dist/index.es338.js +15 -30
- package/dist/index.es338.js.map +1 -1
- package/dist/index.es34.js.map +1 -1
- package/dist/index.es343.js +1 -1
- package/dist/index.es344.js +2 -2
- package/dist/index.es35.js.map +1 -1
- package/dist/{index.es345.js → index.es357.js} +6 -6
- package/dist/{index.es345.js.map → index.es357.js.map} +1 -1
- package/dist/index.es358.js +135 -2
- package/dist/index.es358.js.map +1 -1
- package/dist/index.es359.js +14 -2
- package/dist/index.es359.js.map +1 -1
- package/dist/index.es36.js.map +1 -1
- package/dist/{index.es348.js → index.es360.js} +1 -1
- package/dist/{index.es348.js.map → index.es360.js.map} +1 -1
- package/dist/{index.es349.js → index.es361.js} +4 -4
- package/dist/{index.es349.js.map → index.es361.js.map} +1 -1
- package/dist/{index.es350.js → index.es362.js} +1 -1
- package/dist/{index.es350.js.map → index.es362.js.map} +1 -1
- package/dist/{index.es351.js → index.es363.js} +2 -2
- package/dist/{index.es351.js.map → index.es363.js.map} +1 -1
- package/dist/index.es369.js +2 -11
- package/dist/index.es369.js.map +1 -1
- package/dist/index.es37.js.map +1 -1
- package/dist/index.es370.js +2 -46
- package/dist/index.es370.js.map +1 -1
- package/dist/index.es371.js +10 -7
- package/dist/index.es371.js.map +1 -1
- package/dist/index.es372.js +43 -215
- package/dist/index.es372.js.map +1 -1
- package/dist/index.es373.js +7 -177
- package/dist/index.es373.js.map +1 -1
- package/dist/index.es374.js +217 -3
- package/dist/index.es374.js.map +1 -1
- package/dist/index.es375.js +177 -11
- package/dist/index.es375.js.map +1 -1
- package/dist/index.es376.js +4 -205
- package/dist/index.es376.js.map +1 -1
- package/dist/index.es377.js +12 -22
- package/dist/index.es377.js.map +1 -1
- package/dist/index.es378.js +193 -381
- package/dist/index.es378.js.map +1 -1
- package/dist/index.es379.js +21 -24
- package/dist/index.es379.js.map +1 -1
- package/dist/index.es38.js.map +1 -1
- package/dist/index.es380.js +391 -27
- package/dist/index.es380.js.map +1 -1
- package/dist/index.es381.js +25 -5
- package/dist/index.es381.js.map +1 -1
- package/dist/index.es382.js +29 -5
- package/dist/index.es382.js.map +1 -1
- package/dist/index.es383.js +5 -3
- package/dist/index.es383.js.map +1 -1
- package/dist/index.es384.js +5 -24
- package/dist/index.es384.js.map +1 -1
- package/dist/index.es385.js +4 -110
- package/dist/index.es385.js.map +1 -1
- package/dist/index.es386.js +4 -15
- package/dist/index.es386.js.map +1 -1
- package/dist/index.es387.js +9 -64
- package/dist/index.es387.js.map +1 -1
- package/dist/index.es388.js +54 -67
- package/dist/index.es388.js.map +1 -1
- package/dist/index.es389.js +8 -9
- package/dist/index.es389.js.map +1 -1
- package/dist/index.es39.js.map +1 -1
- package/dist/index.es390.js +6 -14
- package/dist/index.es390.js.map +1 -1
- package/dist/index.es391.js +530 -59
- package/dist/index.es391.js.map +1 -1
- package/dist/index.es392.js +5 -523
- package/dist/index.es392.js.map +1 -1
- package/dist/index.es393.js +3 -127
- package/dist/index.es393.js.map +1 -1
- package/dist/index.es394.js +22 -127
- package/dist/index.es394.js.map +1 -1
- package/dist/index.es395.js +109 -3
- package/dist/index.es395.js.map +1 -1
- package/dist/index.es396.js +15 -22
- package/dist/index.es396.js.map +1 -1
- package/dist/index.es397.js +43 -0
- package/dist/index.es397.js.map +1 -0
- package/dist/index.es398.js +5 -0
- package/dist/index.es398.js.map +1 -0
- package/dist/index.es399.js +2 -23
- package/dist/index.es399.js.map +1 -1
- package/dist/index.es40.js.map +1 -1
- package/dist/index.es400.js +2 -13
- package/dist/index.es400.js.map +1 -1
- package/dist/index.es401.js +3 -28
- package/dist/index.es401.js.map +1 -1
- package/dist/index.es402.js +2 -5
- package/dist/index.es402.js.map +1 -1
- package/dist/index.es403.js +4 -5
- package/dist/index.es403.js.map +1 -1
- package/dist/index.es404.js +5 -4
- package/dist/index.es404.js.map +1 -1
- package/dist/index.es405.js +522 -4
- package/dist/index.es405.js.map +1 -1
- package/dist/index.es406.js +126 -9
- package/dist/index.es406.js.map +1 -1
- package/dist/index.es407.js +124 -51
- package/dist/index.es407.js.map +1 -1
- package/dist/index.es408.js +64 -7
- package/dist/index.es408.js.map +1 -1
- package/dist/index.es409.js +69 -6
- package/dist/index.es409.js.map +1 -1
- package/dist/index.es41.js.map +1 -1
- package/dist/index.es410.js +7 -531
- package/dist/index.es410.js.map +1 -1
- package/dist/index.es411.js +13 -39
- package/dist/index.es411.js.map +1 -1
- package/dist/index.es412.js +62 -2
- package/dist/index.es412.js.map +1 -1
- package/dist/index.es413.js +4 -2
- package/dist/index.es413.js.map +1 -1
- package/dist/index.es414.js +4 -2
- package/dist/index.es414.js.map +1 -1
- package/dist/index.es415.js +23 -3
- package/dist/index.es415.js.map +1 -1
- package/dist/index.es416.js +23 -2
- package/dist/index.es416.js.map +1 -1
- package/dist/index.es417.js +13 -4
- package/dist/index.es417.js.map +1 -1
- package/dist/index.es418.js +27 -4
- package/dist/index.es418.js.map +1 -1
- package/dist/index.es419.js +5 -4
- package/dist/index.es419.js.map +1 -1
- package/dist/index.es42.js.map +1 -1
- package/dist/index.es43.js.map +1 -1
- package/dist/index.es44.js.map +1 -1
- package/dist/index.es45.js.map +1 -1
- package/dist/index.es46.js.map +1 -1
- package/dist/index.es47.js.map +1 -1
- package/dist/index.es48.js.map +1 -1
- package/dist/index.es49.js.map +1 -1
- package/dist/index.es50.js.map +1 -1
- package/dist/index.es51.js.map +1 -1
- package/dist/index.es52.js.map +1 -1
- package/dist/index.es53.js.map +1 -1
- package/dist/index.es54.js.map +1 -1
- package/dist/index.es56.js +1 -1
- package/dist/index.es56.js.map +1 -1
- package/dist/index.es57.js.map +1 -1
- package/dist/index.es58.js.map +1 -1
- package/dist/index.es6.js +1 -1
- package/dist/index.es6.js.map +1 -1
- package/dist/index.es60.js.map +1 -1
- package/dist/index.es61.js.map +1 -1
- package/dist/index.es62.js.map +1 -1
- package/dist/index.es63.js.map +1 -1
- package/dist/index.es64.js.map +1 -1
- package/dist/index.es65.js +109 -99
- package/dist/index.es65.js.map +1 -1
- package/dist/index.es67.js.map +1 -1
- package/dist/index.es68.js.map +1 -1
- package/dist/index.es69.js.map +1 -1
- package/dist/index.es7.js +1 -1
- package/dist/index.es7.js.map +1 -1
- package/dist/index.es71.js.map +1 -1
- package/dist/index.es72.js.map +1 -1
- package/dist/index.es73.js.map +1 -1
- package/dist/index.es74.js.map +1 -1
- package/dist/index.es75.js.map +1 -1
- package/dist/index.es76.js.map +1 -1
- package/dist/index.es77.js.map +1 -1
- package/dist/index.es78.js.map +1 -1
- package/dist/index.es79.js.map +1 -1
- package/dist/index.es8.js +1 -1
- package/dist/index.es8.js.map +1 -1
- package/dist/index.es80.js.map +1 -1
- package/dist/index.es81.js.map +1 -1
- package/dist/index.es82.js.map +1 -1
- package/dist/index.es83.js.map +1 -1
- package/dist/index.es84.js.map +1 -1
- package/dist/index.es85.js.map +1 -1
- package/dist/index.es86.js.map +1 -1
- package/dist/index.es87.js.map +1 -1
- package/dist/index.es88.js.map +1 -1
- package/dist/index.es9.js +2 -2
- package/dist/index.es90.js.map +1 -1
- package/dist/index.es91.js.map +1 -1
- package/dist/index.es94.js.map +1 -1
- package/dist/index.es95.js.map +1 -1
- package/dist/index.es96.js.map +1 -1
- package/dist/index.es97.js.map +1 -1
- package/dist/index.es98.js.map +1 -1
- package/dist/index.es99.js.map +1 -1
- package/package.json +109 -109
- package/readme.md +42 -42
- package/dist/index.cjs198.js +0 -2
- package/dist/index.cjs198.js.map +0 -1
- package/dist/index.cjs339.js +0 -2
- package/dist/index.cjs339.js.map +0 -1
- package/dist/index.cjs340.js +0 -2
- package/dist/index.cjs340.js.map +0 -1
- package/dist/index.cjs341.js +0 -2
- package/dist/index.cjs341.js.map +0 -1
- package/dist/index.cjs346.js +0 -2
- package/dist/index.cjs346.js.map +0 -1
- package/dist/index.cjs347.js +0 -2
- package/dist/index.cjs347.js.map +0 -1
- package/dist/index.es198.js +0 -5
- package/dist/index.es198.js.map +0 -1
- package/dist/index.es339.js +0 -36
- package/dist/index.es339.js.map +0 -1
- package/dist/index.es340.js +0 -625
- package/dist/index.es340.js.map +0 -1
- package/dist/index.es341.js +0 -14
- package/dist/index.es341.js.map +0 -1
- package/dist/index.es346.js +0 -138
- package/dist/index.es346.js.map +0 -1
- package/dist/index.es347.js +0 -17
- package/dist/index.es347.js.map +0 -1
- /package/dist/components/ui/{DoctorConfirmModal/DoctorConfirmModalFooter/DoctorConfirmModalFooter.css → DoctorModal/DoctorModalFooter/DoctorModalFooter.css} +0 -0
package/dist/index.es65.js
CHANGED
@@ -1,101 +1,111 @@
|
|
1
1
|
import { j as a } from "./index.es185.js";
|
2
2
|
import * as _ from "react";
|
3
|
+
import { useEffect as J } from "react";
|
3
4
|
import { clsx as c } from "./index.es187.js";
|
4
5
|
import './components/ui/Table/Table.css';/* empty css */
|
5
|
-
import { ActionIconText as
|
6
|
-
import { TriangleUp as
|
7
|
-
import { TriangleDown as
|
8
|
-
import { Info as
|
9
|
-
import { Download as
|
10
|
-
const
|
6
|
+
import { ActionIconText as Q } from "./index.es59.js";
|
7
|
+
import { TriangleUp as W } from "./index.es154.js";
|
8
|
+
import { TriangleDown as X } from "./index.es155.js";
|
9
|
+
import { Info as Y } from "./index.es156.js";
|
10
|
+
import { Download as Z } from "./index.es147.js";
|
11
|
+
const K = _.forwardRef(
|
11
12
|
({
|
12
13
|
className: e,
|
13
14
|
columns: t,
|
14
15
|
data: s,
|
15
16
|
pagination: i,
|
16
|
-
initialCurrentPage:
|
17
|
-
resultsPerPage:
|
18
|
-
defaultSortDirection:
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
17
|
+
initialCurrentPage: j = 1,
|
18
|
+
resultsPerPage: p = 10,
|
19
|
+
defaultSortDirection: l = "desc",
|
20
|
+
setSelectedSort: b,
|
21
|
+
initialSortConfig: u,
|
22
|
+
...g
|
23
|
+
}, N) => {
|
24
|
+
const [d, L] = _.useState(
|
25
|
+
u || {
|
26
|
+
key: t[0].key || t[0].label,
|
27
|
+
direction: l
|
28
|
+
}
|
29
|
+
), [v, I] = _.useState(j);
|
30
|
+
J(() => {
|
31
|
+
u && L(u);
|
32
|
+
}, [u]);
|
33
|
+
const y = _.useMemo(() => [...s].sort((o, x) => {
|
34
|
+
const r = o[d.key], n = x[d.key], m = t.find(
|
35
|
+
(f) => (f.key || f.label) === d.key
|
27
36
|
);
|
28
|
-
if (typeof r == "string" && typeof
|
29
|
-
if ((
|
30
|
-
const
|
31
|
-
const [
|
32
|
-
return new Date(
|
33
|
-
}, h =
|
34
|
-
return d.direction === "asc" ? h.getTime() -
|
37
|
+
if (typeof r == "string" && typeof n == "string") {
|
38
|
+
if ((m == null ? void 0 : m.type) === "date") {
|
39
|
+
const f = (S) => {
|
40
|
+
const [V, z] = S.split(" - "), [E, O, U] = V.split("/").map(Number), [q, G] = z.split(":").map(Number);
|
41
|
+
return new Date(U, O - 1, E, q, G);
|
42
|
+
}, h = f(r), D = f(n);
|
43
|
+
return d.direction === "asc" ? h.getTime() - D.getTime() : D.getTime() - h.getTime();
|
35
44
|
}
|
36
|
-
if ((
|
37
|
-
const
|
38
|
-
return d.direction === "asc" ?
|
45
|
+
if ((m == null ? void 0 : m.type) === "number") {
|
46
|
+
const f = parseFloat(r), h = parseFloat(n);
|
47
|
+
return d.direction === "asc" ? f - h : h - f;
|
39
48
|
}
|
40
|
-
return d.direction === "asc" ? r.localeCompare(
|
49
|
+
return d.direction === "asc" ? r.localeCompare(n) : n.localeCompare(r);
|
41
50
|
}
|
42
|
-
return
|
43
|
-
}), [s, d, t]),
|
44
|
-
|
51
|
+
return w(r) && w(n) ? d.direction === "asc" ? r.firstLine.localeCompare(n.firstLine) : n.firstLine.localeCompare(r.firstLine) : 0;
|
52
|
+
}), [s, d, t]), M = (o) => {
|
53
|
+
const x = {
|
45
54
|
key: o,
|
46
|
-
direction:
|
47
|
-
}
|
48
|
-
|
55
|
+
direction: d.key === o && d.direction === "asc" ? "desc" : "asc"
|
56
|
+
};
|
57
|
+
L(x), b && b(x);
|
58
|
+
}, C = i ? (v - 1) * p : 0, F = i ? Math.min(C + p, y.length) : y.length, H = y.slice(C, F);
|
49
59
|
return /* @__PURE__ */ a.jsxs("div", { className: "position-relative w-full", children: [
|
50
60
|
/* @__PURE__ */ a.jsxs(
|
51
61
|
"table",
|
52
62
|
{
|
53
|
-
ref:
|
63
|
+
ref: N,
|
54
64
|
className: c("table", e),
|
55
65
|
role: "table",
|
56
|
-
...
|
66
|
+
...g,
|
57
67
|
children: [
|
58
|
-
/* @__PURE__ */ a.jsx(
|
59
|
-
|
68
|
+
/* @__PURE__ */ a.jsx(R, { className: "table__header", children: /* @__PURE__ */ a.jsx(k, { children: t.map((o, x) => /* @__PURE__ */ a.jsx(
|
69
|
+
$,
|
60
70
|
{
|
61
71
|
config: o,
|
62
72
|
sortConfig: d,
|
63
|
-
onSort: () => o.sortable &&
|
73
|
+
onSort: () => o.sortable && M(o.key || o.label)
|
64
74
|
},
|
65
75
|
`${o.label}-${x}`
|
66
76
|
)) }) }),
|
67
|
-
/* @__PURE__ */ a.jsx(
|
77
|
+
/* @__PURE__ */ a.jsx(A, { className: "table__body", children: H.map((o, x) => /* @__PURE__ */ a.jsx(k, { className: "table__row", children: Object.entries(o).map(([r, n], m) => n ? r === "actionData" && B(n) ? /* @__PURE__ */ a.jsx(
|
68
78
|
T,
|
69
79
|
{
|
70
|
-
content:
|
80
|
+
content: n,
|
71
81
|
type: "action"
|
72
82
|
},
|
73
|
-
`${r}-${
|
74
|
-
) :
|
83
|
+
`${r}-${m}`
|
84
|
+
) : w(n) ? /* @__PURE__ */ a.jsx(
|
75
85
|
T,
|
76
86
|
{
|
77
|
-
content:
|
87
|
+
content: n,
|
78
88
|
type: "double-line"
|
79
89
|
},
|
80
|
-
`${r}-${
|
81
|
-
) : typeof
|
90
|
+
`${r}-${m}`
|
91
|
+
) : typeof n == "string" ? /* @__PURE__ */ a.jsx(T, { content: n }, `${r}-${m}`) : null : null) }, x)) })
|
82
92
|
]
|
83
93
|
}
|
84
94
|
),
|
85
95
|
i && /* @__PURE__ */ a.jsx(
|
86
|
-
|
96
|
+
te,
|
87
97
|
{
|
88
|
-
currentPage:
|
89
|
-
totalResults:
|
90
|
-
resultsPerPage:
|
91
|
-
setCurrentPage:
|
98
|
+
currentPage: v,
|
99
|
+
totalResults: y.length,
|
100
|
+
resultsPerPage: p,
|
101
|
+
setCurrentPage: I
|
92
102
|
}
|
93
103
|
)
|
94
104
|
] });
|
95
105
|
}
|
96
106
|
);
|
97
|
-
|
98
|
-
const
|
107
|
+
K.displayName = "Table";
|
108
|
+
const R = _.forwardRef(
|
99
109
|
({ className: e, children: t, ...s }, i) => /* @__PURE__ */ a.jsx(
|
100
110
|
"thead",
|
101
111
|
{
|
@@ -106,8 +116,8 @@ const C = _.forwardRef(
|
|
106
116
|
}
|
107
117
|
)
|
108
118
|
);
|
109
|
-
|
110
|
-
const
|
119
|
+
R.displayName = "TableHeader";
|
120
|
+
const A = _.forwardRef(
|
111
121
|
({ className: e, children: t, ...s }, i) => /* @__PURE__ */ a.jsx(
|
112
122
|
"tbody",
|
113
123
|
{
|
@@ -118,8 +128,8 @@ const D = _.forwardRef(
|
|
118
128
|
}
|
119
129
|
)
|
120
130
|
);
|
121
|
-
|
122
|
-
const
|
131
|
+
A.displayName = "TableBody";
|
132
|
+
const k = _.forwardRef(
|
123
133
|
({ className: e, children: t, ...s }, i) => /* @__PURE__ */ a.jsx(
|
124
134
|
"tr",
|
125
135
|
{
|
@@ -133,22 +143,22 @@ const w = _.forwardRef(
|
|
133
143
|
}
|
134
144
|
)
|
135
145
|
);
|
136
|
-
|
137
|
-
const
|
138
|
-
const
|
139
|
-
switch (
|
146
|
+
k.displayName = "TableRow";
|
147
|
+
const $ = _.forwardRef(({ className: e, config: t, sortConfig: s, onSort: i, ...j }, p) => {
|
148
|
+
const l = s.key === (t.key || t.label), b = l ? s.direction : null, u = () => b === "asc" ? "ascending" : "descending", g = (N) => {
|
149
|
+
switch (N) {
|
140
150
|
case "info":
|
141
|
-
return /* @__PURE__ */ a.jsx(
|
151
|
+
return /* @__PURE__ */ a.jsx(Y, {});
|
142
152
|
case "download":
|
143
|
-
return /* @__PURE__ */ a.jsx(
|
153
|
+
return /* @__PURE__ */ a.jsx(Z, {});
|
144
154
|
default:
|
145
|
-
return
|
155
|
+
return N;
|
146
156
|
}
|
147
157
|
};
|
148
158
|
return /* @__PURE__ */ a.jsx(
|
149
159
|
"th",
|
150
160
|
{
|
151
|
-
ref:
|
161
|
+
ref: p,
|
152
162
|
className: c(
|
153
163
|
"table__cell table__cell--header",
|
154
164
|
{
|
@@ -159,13 +169,13 @@ const R = _.forwardRef(({ className: e, config: t, sortConfig: s, onSort: i, ...
|
|
159
169
|
),
|
160
170
|
onClick: t.sortable ? i : t.action,
|
161
171
|
"aria-label": t.ariaLabel,
|
162
|
-
"aria-sort":
|
163
|
-
...
|
172
|
+
"aria-sort": l ? u() : void 0,
|
173
|
+
...j,
|
164
174
|
children: /* @__PURE__ */ a.jsxs("div", { className: "table__cell--header--content", children: [
|
165
175
|
/* @__PURE__ */ a.jsx("div", { children: /* @__PURE__ */ a.jsx(
|
166
|
-
|
176
|
+
Q,
|
167
177
|
{
|
168
|
-
icon:
|
178
|
+
icon: g(t.icon),
|
169
179
|
textLabel: t.label,
|
170
180
|
iconPosition: t.iconPosition,
|
171
181
|
handleIconAction: () => {
|
@@ -176,20 +186,20 @@ const R = _.forwardRef(({ className: e, config: t, sortConfig: s, onSort: i, ...
|
|
176
186
|
) }),
|
177
187
|
t.sortable && /* @__PURE__ */ a.jsxs("span", { className: "sort-indicator", children: [
|
178
188
|
/* @__PURE__ */ a.jsx(
|
179
|
-
|
189
|
+
W,
|
180
190
|
{
|
181
|
-
filled:
|
191
|
+
filled: l && b === "desc",
|
182
192
|
className: c("sort-indicator__triangle", {
|
183
|
-
active:
|
193
|
+
active: l && b === "desc"
|
184
194
|
})
|
185
195
|
}
|
186
196
|
),
|
187
197
|
/* @__PURE__ */ a.jsx(
|
188
|
-
|
198
|
+
X,
|
189
199
|
{
|
190
|
-
filled:
|
200
|
+
filled: l && b === "asc",
|
191
201
|
className: c("sort-indicator__triangle", {
|
192
|
-
active:
|
202
|
+
active: l && b === "asc"
|
193
203
|
})
|
194
204
|
}
|
195
205
|
)
|
@@ -198,17 +208,17 @@ const R = _.forwardRef(({ className: e, config: t, sortConfig: s, onSort: i, ...
|
|
198
208
|
}
|
199
209
|
);
|
200
210
|
});
|
201
|
-
|
202
|
-
const
|
211
|
+
$.displayName = "TableHead";
|
212
|
+
const P = ({ data: e }) => /* @__PURE__ */ a.jsxs(a.Fragment, { children: [
|
203
213
|
/* @__PURE__ */ a.jsx("div", { className: "table__cell--firstLine", children: e.firstLine }),
|
204
214
|
/* @__PURE__ */ a.jsx("div", { className: "table__cell--secondLine", children: e.secondLine })
|
205
|
-
] }),
|
215
|
+
] }), ee = ({ data: e }) => e.type === "link" && e.link ? /* @__PURE__ */ a.jsx("a", { href: e.link, "aria-label": e.ariaLabel, children: e.label }) : /* @__PURE__ */ a.jsx("button", { onClick: e.action, "aria-label": e.ariaLabel, children: e.label }), w = (e) => typeof e == "object" && e !== null && "firstLine" in e && "secondLine" in e, B = (e) => typeof e == "object" && e !== null && "label" in e && "type" in e, ae = ({
|
206
216
|
content: e
|
207
|
-
}) => typeof e == "string" ? /* @__PURE__ */ a.jsx(a.Fragment, { children: e }) :
|
208
|
-
({ className: e, content: t, type: s, ...i },
|
217
|
+
}) => typeof e == "string" ? /* @__PURE__ */ a.jsx(a.Fragment, { children: e }) : w(e) ? /* @__PURE__ */ a.jsx(P, { data: e }) : B(e) ? /* @__PURE__ */ a.jsx(ee, { data: e }) : null, T = _.forwardRef(
|
218
|
+
({ className: e, content: t, type: s, ...i }, j) => /* @__PURE__ */ a.jsx(
|
209
219
|
"td",
|
210
220
|
{
|
211
|
-
ref:
|
221
|
+
ref: j,
|
212
222
|
className: c(
|
213
223
|
"table__cell",
|
214
224
|
{
|
@@ -218,20 +228,20 @@ const Y = ({ data: e }) => /* @__PURE__ */ a.jsxs(a.Fragment, { children: [
|
|
218
228
|
e
|
219
229
|
),
|
220
230
|
...i,
|
221
|
-
children: /* @__PURE__ */ a.jsx(
|
231
|
+
children: /* @__PURE__ */ a.jsx(ae, { content: t })
|
222
232
|
}
|
223
233
|
)
|
224
234
|
);
|
225
235
|
T.displayName = "TableCell";
|
226
|
-
const
|
236
|
+
const te = ({
|
227
237
|
currentPage: e = 1,
|
228
238
|
totalResults: t,
|
229
239
|
resultsPerPage: s,
|
230
240
|
setCurrentPage: i,
|
231
|
-
className:
|
241
|
+
className: j
|
232
242
|
}) => {
|
233
|
-
const
|
234
|
-
return /* @__PURE__ */ a.jsxs("div", { className: c("pagination",
|
243
|
+
const p = Math.ceil(t / s);
|
244
|
+
return /* @__PURE__ */ a.jsxs("div", { className: c("pagination", j), children: [
|
235
245
|
/* @__PURE__ */ a.jsxs("div", { className: "pagination__info", children: [
|
236
246
|
"Stai visualizzando",
|
237
247
|
" ",
|
@@ -255,27 +265,27 @@ const P = ({
|
|
255
265
|
children: /* @__PURE__ */ a.jsx("svg", { className: "pagination__button-arrow", viewBox: "0 0 24 24", children: /* @__PURE__ */ a.jsx("path", { d: "M15 18l-6-6 6-6" }) })
|
256
266
|
}
|
257
267
|
),
|
258
|
-
Array.from({ length:
|
268
|
+
Array.from({ length: p }, (l, b) => b + 1).map((l) => /* @__PURE__ */ a.jsx(
|
259
269
|
"button",
|
260
270
|
{
|
261
271
|
className: c(
|
262
272
|
"pagination__button",
|
263
|
-
e ===
|
273
|
+
e === l && "pagination__button--active"
|
264
274
|
),
|
265
|
-
onClick: () => i(
|
266
|
-
children:
|
275
|
+
onClick: () => i(l),
|
276
|
+
children: l
|
267
277
|
},
|
268
|
-
|
278
|
+
l
|
269
279
|
)),
|
270
280
|
/* @__PURE__ */ a.jsx(
|
271
281
|
"button",
|
272
282
|
{
|
273
283
|
className: c(
|
274
284
|
"pagination__button",
|
275
|
-
e ===
|
285
|
+
e === p && "pagination__button--disabled"
|
276
286
|
),
|
277
287
|
onClick: () => i(e + 1),
|
278
|
-
disabled: e ===
|
288
|
+
disabled: e === p,
|
279
289
|
"aria-label": "Next page",
|
280
290
|
children: /* @__PURE__ */ a.jsx("svg", { className: "pagination__button-arrow", viewBox: "0 0 24 24", children: /* @__PURE__ */ a.jsx("path", { d: "M9 6l6 6-6 6" }) })
|
281
291
|
}
|
@@ -284,12 +294,12 @@ const P = ({
|
|
284
294
|
] });
|
285
295
|
};
|
286
296
|
export {
|
287
|
-
|
288
|
-
|
289
|
-
|
297
|
+
te as Pagination,
|
298
|
+
K as Table,
|
299
|
+
A as TableBody,
|
290
300
|
T as TableCell,
|
291
|
-
|
292
|
-
|
293
|
-
|
301
|
+
$ as TableHead,
|
302
|
+
R as TableHeader,
|
303
|
+
k as TableRow
|
294
304
|
};
|
295
305
|
//# sourceMappingURL=index.es65.js.map
|
package/dist/index.es65.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.es65.js","sources":["../src/components/ui/Table/index.tsx"],"sourcesContent":["import * as React from \"react\";\nimport clsx from \"clsx\";\nimport \"./Table.scss\";\nimport { Download, Info, TriangleDown, TriangleUp } from \"@/icons\";\nimport { ActionIconText } from \"../ActionIconText\";\nimport { CommonIconsType } from \"@/types/icons\";\nimport { InfoPopupProps } from \"../InfoPopup\";\n\n// per le celle che vanno renderizzate su due righe\nexport interface DoubleLineData {\n firstLine: string;\n secondLine: string;\n}\n\n//per le celle che renderizzano un link o un bottone\nexport interface ActionData {\n label: string | React.ReactNode;\n ariaLabel: string;\n type: \"link\" | \"button\";\n link?: string;\n action?: () => void;\n}\n\nexport interface ColumnConfig {\n label: string;\n ariaLabel: string;\n sortable: boolean;\n action?: () => void;\n iconAction?: () => void;\n popupInfo?: InfoPopupProps;\n icon?: React.ReactNode | CommonIconsType;\n iconPosition?: \"left\" | \"right\";\n key?: string;\n type?: \"string\" | \"date\" | \"number\";\n}\n\nexport interface TableRowData {\n [key: string]: string | DoubleLineData | ActionData;\n}\n\nexport interface TableHeaderProps\n extends React.HTMLAttributes<HTMLTableSectionElement> {\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableBodyProps\n extends React.HTMLAttributes<HTMLTableSectionElement> {\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableRowProps\n extends React.HTMLAttributes<HTMLTableRowElement> {\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableHeadProps\n extends React.ThHTMLAttributes<HTMLTableCellElement> {\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableCellBaseProps\n extends Omit<React.TdHTMLAttributes<HTMLTableCellElement>, \"content\"> {\n type?: \"double-line\" | \"action\";\n}\n\nexport interface TableCellProps extends TableCellBaseProps {\n content: string | DoubleLineData | ActionData;\n}\n\nexport interface PaginationProps {\n currentPage: number;\n totalResults: number;\n resultsPerPage: number;\n setCurrentPage: (page: number) => void;\n onPageChange?: (page: number) => void;\n className?: string;\n}\n\nexport interface TableProps\n extends React.TableHTMLAttributes<HTMLTableElement> {\n className?: string;\n columns: ColumnConfig[];\n data: TableRowData[];\n pagination?: boolean;\n initialCurrentPage?: number;\n resultsPerPage?: number;\n defaultSortDirection?: \"asc\" | \"desc\";\n}\n\nconst Table = React.forwardRef<HTMLTableElement, TableProps>(\n (\n {\n className,\n columns,\n data,\n pagination,\n initialCurrentPage = 1,\n resultsPerPage = 10,\n defaultSortDirection = \"desc\",\n ...props\n },\n ref,\n ) => {\n const [sortConfig, setSortConfig] = React.useState<{\n key: string;\n direction: \"asc\" | \"desc\";\n }>({\n key: columns[0].key || columns[0].label,\n direction: defaultSortDirection,\n });\n const [currentPage, setCurrentPage] = React.useState(initialCurrentPage);\n\n const sortedData = React.useMemo(() => {\n return [...data].sort((a, b) => {\n const aValue = a[sortConfig.key];\n const bValue = b[sortConfig.key];\n const column = columns.find(\n (col) => (col.key || col.label) === sortConfig.key,\n );\n\n if (typeof aValue === \"string\" && typeof bValue === \"string\") {\n if (column?.type === \"date\") {\n // Convert Italian date format (DD/MM/YYYY - HH:mm) to Date object\n const parseDate = (dateStr: string) => {\n const [datePart, timePart] = dateStr.split(\" - \");\n const [day, month, year] = datePart.split(\"/\").map(Number);\n const [hours, minutes] = timePart.split(\":\").map(Number);\n return new Date(year, month - 1, day, hours, minutes);\n };\n\n const dateA = parseDate(aValue);\n const dateB = parseDate(bValue);\n return sortConfig.direction === \"asc\"\n ? dateA.getTime() - dateB.getTime()\n : dateB.getTime() - dateA.getTime();\n }\n\n if (column?.type === \"number\") {\n const numA = parseFloat(aValue);\n const numB = parseFloat(bValue);\n return sortConfig.direction === \"asc\" ? numA - numB : numB - numA;\n }\n\n return sortConfig.direction === \"asc\"\n ? aValue.localeCompare(bValue)\n : bValue.localeCompare(aValue);\n }\n\n if (isDoubleLineData(aValue) && isDoubleLineData(bValue)) {\n return sortConfig.direction === \"asc\"\n ? aValue.firstLine.localeCompare(bValue.firstLine)\n : bValue.firstLine.localeCompare(aValue.firstLine);\n }\n\n return 0;\n });\n }, [data, sortConfig, columns]);\n\n const handleSort = (columnKey: string) => {\n setSortConfig((currentSort) => ({\n key: columnKey,\n direction:\n currentSort.key === columnKey && currentSort.direction === \"asc\"\n ? \"desc\"\n : \"asc\",\n }));\n };\n\n const startIndex = pagination ? (currentPage - 1) * resultsPerPage : 0;\n const endIndex = pagination\n ? Math.min(startIndex + resultsPerPage, sortedData.length)\n : sortedData.length;\n const currentPageData = sortedData.slice(startIndex, endIndex);\n\n return (\n <div className=\"position-relative w-full\">\n <table\n ref={ref}\n className={clsx(\"table\", className)}\n role=\"table\"\n {...props}\n >\n <TableHeader className=\"table__header\">\n <TableRow>\n {columns.map((column, index) => (\n <TableHead\n key={`${column.label}-${index}`}\n config={column}\n sortConfig={sortConfig}\n onSort={() =>\n column.sortable && handleSort(column.key || column.label)\n }\n />\n ))}\n </TableRow>\n </TableHeader>\n <TableBody className=\"table__body\">\n {currentPageData.map((row, rowIndex) => (\n <TableRow key={rowIndex} className=\"table__row\">\n {Object.entries(row).map(([key, value], cellIndex) => {\n if (!value) return null;\n\n if (key === \"actionData\" && isActionData(value)) {\n return (\n <TableCell\n key={`${key}-${cellIndex}`}\n content={value}\n type=\"action\"\n />\n );\n }\n if (isDoubleLineData(value)) {\n return (\n <TableCell\n key={`${key}-${cellIndex}`}\n content={value}\n type=\"double-line\"\n />\n );\n }\n if (typeof value === \"string\") {\n return (\n <TableCell key={`${key}-${cellIndex}`} content={value} />\n );\n }\n return null;\n })}\n </TableRow>\n ))}\n </TableBody>\n </table>\n {pagination && (\n <Pagination\n currentPage={currentPage}\n totalResults={sortedData.length}\n resultsPerPage={resultsPerPage}\n setCurrentPage={setCurrentPage}\n />\n )}\n </div>\n );\n },\n);\nTable.displayName = \"Table\";\n\nconst TableHeader = React.forwardRef<HTMLTableSectionElement, TableHeaderProps>(\n ({ className, children, ...props }, ref) => (\n <thead\n ref={ref}\n className={clsx(\"[&_tr]:border-b-0\", className)}\n {...props}\n >\n {children}\n </thead>\n ),\n);\nTableHeader.displayName = \"TableHeader\";\n\nconst TableBody = React.forwardRef<HTMLTableSectionElement, TableBodyProps>(\n ({ className, children, ...props }, ref) => (\n <tbody\n ref={ref}\n className={clsx(\"[&_tr:last-child]:border-0\", className)}\n {...props}\n >\n {children}\n </tbody>\n ),\n);\nTableBody.displayName = \"TableBody\";\n\nconst TableRow = React.forwardRef<HTMLTableRowElement, TableRowProps>(\n ({ className, children, ...props }, ref) => (\n <tr\n ref={ref}\n className={clsx(\n \"border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted\",\n className,\n )}\n {...props}\n >\n {children}\n </tr>\n ),\n);\nTableRow.displayName = \"TableRow\";\n\nconst TableHead = React.forwardRef<\n HTMLTableCellElement,\n TableHeadProps & {\n config: ColumnConfig;\n sortConfig: { key: string; direction: \"asc\" | \"desc\" };\n onSort?: () => void;\n }\n>(({ className, config, sortConfig, onSort, ...props }, ref) => {\n const isSorted = sortConfig.key === (config.key || config.label);\n const sortDirection = isSorted ? sortConfig.direction : null;\n\n const getAriaSortValue = (): \"ascending\" | \"descending\" => {\n return sortDirection === \"asc\" ? \"ascending\" : \"descending\";\n };\n\n const renderIcon = (icon: React.ReactNode | CommonIconsType) => {\n switch (icon) {\n case \"info\":\n return <Info />;\n case \"download\":\n return <Download />;\n default:\n return icon;\n }\n };\n\n return (\n <th\n ref={ref}\n className={clsx(\n \"table__cell table__cell--header\",\n {\n \"table__cell--sortable\": config.sortable,\n \"table__cell--action\": config.action,\n },\n className,\n )}\n onClick={config.sortable ? onSort : config.action}\n aria-label={config.ariaLabel}\n aria-sort={isSorted ? getAriaSortValue() : undefined}\n {...props}\n >\n <div className=\"table__cell--header--content\">\n <div>\n <ActionIconText\n icon={renderIcon(config.icon)}\n textLabel={config.label}\n iconPosition={config.iconPosition}\n handleIconAction={() => {\n config.iconAction;\n }}\n popupInfo={config.popupInfo}\n />\n </div>\n {config.sortable && (\n <span className=\"sort-indicator\">\n <TriangleUp\n filled={isSorted && sortDirection === \"desc\"}\n className={clsx(\"sort-indicator__triangle\", {\n active: isSorted && sortDirection === \"desc\",\n })}\n />\n <TriangleDown\n filled={isSorted && sortDirection === \"asc\"}\n className={clsx(\"sort-indicator__triangle\", {\n active: isSorted && sortDirection === \"asc\",\n })}\n />\n </span>\n )}\n </div>\n </th>\n );\n});\nTableHead.displayName = \"TableHead\";\n\nconst DoubleLineContent: React.FC<{ data: DoubleLineData }> = ({ data }) => (\n <>\n <div className=\"table__cell--firstLine\">{data.firstLine}</div>\n <div className=\"table__cell--secondLine\">{data.secondLine}</div>\n </>\n);\n\nconst ActionContent: React.FC<{ data: ActionData }> = ({ data }) => {\n if (data.type === \"link\" && data.link) {\n return (\n <a href={data.link} aria-label={data.ariaLabel}>\n {data.label}\n </a>\n );\n }\n return (\n <button onClick={data.action} aria-label={data.ariaLabel}>\n {data.label}\n </button>\n );\n};\n\n// check if we are rendering a double line data\nconst isDoubleLineData = (\n content: TableCellProps[\"content\"],\n): content is DoubleLineData => {\n return (\n typeof content === \"object\" &&\n content !== null &&\n \"firstLine\" in content &&\n \"secondLine\" in content\n );\n};\n\n// check if we are rendering an action data\nconst isActionData = (\n content: TableCellProps[\"content\"],\n): content is ActionData => {\n return (\n typeof content === \"object\" &&\n content !== null &&\n \"label\" in content &&\n \"type\" in content\n );\n};\n\nconst TableCellContent: React.FC<{ content: TableCellProps[\"content\"] }> = ({\n content,\n}) => {\n if (typeof content === \"string\") {\n return <>{content}</>;\n }\n if (isDoubleLineData(content)) {\n return <DoubleLineContent data={content} />;\n }\n if (isActionData(content)) {\n return <ActionContent data={content} />;\n }\n return null;\n};\n\nconst TableCell = React.forwardRef<HTMLTableCellElement, TableCellProps>(\n ({ className, content, type, ...props }, ref) => (\n <td\n ref={ref}\n className={clsx(\n \"table__cell\",\n {\n \"table__cell--double-line\": type === \"double-line\",\n \"table__cell--action\": type === \"action\",\n },\n className,\n )}\n {...props}\n >\n <TableCellContent content={content} />\n </td>\n ),\n);\nTableCell.displayName = \"TableCell\";\n\nconst Pagination: React.FC<PaginationProps> = ({\n currentPage = 1,\n totalResults,\n resultsPerPage,\n setCurrentPage,\n className,\n}) => {\n const totalPages = Math.ceil(totalResults / resultsPerPage);\n\n return (\n <div className={clsx(\"pagination\", className)}>\n <div className=\"pagination__info\">\n Stai visualizzando{\" \"}\n <span className=\"pagination__info__resultsPerPage\">\n {resultsPerPage}\n </span>{\" \"}\n di {totalResults} risultati\n </div>\n <div className=\"pagination__nav\">\n <button\n className={clsx(\n \"pagination__button\",\n currentPage === 1 && \"pagination__button--disabled\",\n )}\n onClick={() => setCurrentPage(currentPage - 1)}\n disabled={currentPage === 1}\n aria-label=\"Previous page\"\n >\n <svg className=\"pagination__button-arrow\" viewBox=\"0 0 24 24\">\n <path d=\"M15 18l-6-6 6-6\" />\n </svg>\n </button>\n {Array.from({ length: totalPages }, (_, i) => i + 1).map((page) => (\n <button\n key={page}\n className={clsx(\n \"pagination__button\",\n currentPage === page && \"pagination__button--active\",\n )}\n onClick={() => setCurrentPage(page)}\n >\n {page}\n </button>\n ))}\n <button\n className={clsx(\n \"pagination__button\",\n currentPage === totalPages && \"pagination__button--disabled\",\n )}\n onClick={() => setCurrentPage(currentPage + 1)}\n disabled={currentPage === totalPages}\n aria-label=\"Next page\"\n >\n <svg className=\"pagination__button-arrow\" viewBox=\"0 0 24 24\">\n <path d=\"M9 6l6 6-6 6\" />\n </svg>\n </button>\n </div>\n </div>\n );\n};\n\nexport {\n Table,\n TableHeader,\n TableBody,\n TableHead,\n TableRow,\n TableCell,\n Pagination,\n};\n"],"names":["Table","React","className","columns","data","pagination","initialCurrentPage","resultsPerPage","defaultSortDirection","props","ref","sortConfig","setSortConfig","currentPage","setCurrentPage","sortedData","a","b","aValue","bValue","column","col","parseDate","dateStr","datePart","timePart","day","month","year","hours","minutes","dateA","dateB","numA","numB","isDoubleLineData","handleSort","columnKey","currentSort","startIndex","endIndex","currentPageData","jsxs","clsx","jsx","TableHeader","TableRow","index","TableHead","TableBody","row","rowIndex","key","value","cellIndex","isActionData","TableCell","Pagination","children","config","onSort","isSorted","sortDirection","getAriaSortValue","renderIcon","icon","Info","Download","ActionIconText","TriangleUp","TriangleDown","DoubleLineContent","Fragment","ActionContent","content","TableCellContent","type","totalResults","totalPages","_","i","page"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"index.es65.js","sources":["../src/components/ui/Table/index.tsx"],"sourcesContent":["import * as React from \"react\";\nimport clsx from \"clsx\";\nimport \"./Table.scss\";\nimport { Download, Info, TriangleDown, TriangleUp } from \"@/icons\";\nimport { ActionIconText } from \"../ActionIconText\";\nimport { CommonIconsType } from \"@/types/icons\";\nimport { InfoPopupProps } from \"../InfoPopup\";\nimport { useEffect } from \"react\";\n\n// per le celle che vanno renderizzate su due righe\nexport interface DoubleLineData {\n firstLine: string;\n secondLine: string;\n}\n\n//per le celle che renderizzano un link o un bottone\nexport interface ActionData {\n label: string | React.ReactNode;\n ariaLabel: string;\n type: \"link\" | \"button\";\n link?: string;\n action?: () => void;\n}\n\nexport interface ColumnConfig {\n label: string;\n ariaLabel: string;\n sortable: boolean;\n action?: () => void;\n iconAction?: () => void;\n popupInfo?: InfoPopupProps;\n icon?: React.ReactNode | CommonIconsType;\n iconPosition?: \"left\" | \"right\";\n key?: string;\n type?: \"string\" | \"date\" | \"number\";\n}\n\nexport interface TableRowData {\n [key: string]: string | DoubleLineData | ActionData;\n}\n\nexport interface TableHeaderProps\n extends React.HTMLAttributes<HTMLTableSectionElement> {\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableBodyProps\n extends React.HTMLAttributes<HTMLTableSectionElement> {\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableRowProps\n extends React.HTMLAttributes<HTMLTableRowElement> {\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableHeadProps\n extends React.ThHTMLAttributes<HTMLTableCellElement> {\n className?: string;\n children?: React.ReactNode;\n}\n\nexport interface TableCellBaseProps\n extends Omit<React.TdHTMLAttributes<HTMLTableCellElement>, \"content\"> {\n type?: \"double-line\" | \"action\";\n}\n\nexport interface TableCellProps extends TableCellBaseProps {\n content: string | DoubleLineData | ActionData;\n}\n\nexport interface PaginationProps {\n currentPage: number;\n totalResults: number;\n resultsPerPage: number;\n setCurrentPage: (page: number) => void;\n onPageChange?: (page: number) => void;\n className?: string;\n}\n\nexport interface TableProps\n extends React.TableHTMLAttributes<HTMLTableElement> {\n className?: string;\n columns: ColumnConfig[];\n data: TableRowData[];\n pagination?: boolean;\n initialCurrentPage?: number;\n resultsPerPage?: number;\n defaultSortDirection?: \"asc\" | \"desc\";\n setSelectedSort?: (sortConfig: {\n key: string;\n direction: \"asc\" | \"desc\";\n }) => void;\n initialSortConfig?: { key: string; direction: \"asc\" | \"desc\" };\n}\n\nconst Table = React.forwardRef<HTMLTableElement, TableProps>(\n (\n {\n className,\n columns,\n data,\n pagination,\n initialCurrentPage = 1,\n resultsPerPage = 10,\n defaultSortDirection = \"desc\",\n setSelectedSort,\n initialSortConfig,\n ...props\n },\n ref,\n ) => {\n const [sortConfig, setSortConfig] = React.useState<{\n key: string;\n direction: \"asc\" | \"desc\";\n }>(\n initialSortConfig || {\n key: columns[0].key || columns[0].label,\n direction: defaultSortDirection,\n },\n );\n const [currentPage, setCurrentPage] = React.useState(initialCurrentPage);\n\n useEffect(() => {\n if (initialSortConfig) {\n setSortConfig(initialSortConfig);\n }\n }, [initialSortConfig]);\n\n const sortedData = React.useMemo(() => {\n return [...data].sort((a, b) => {\n const aValue = a[sortConfig.key];\n const bValue = b[sortConfig.key];\n const column = columns.find(\n (col) => (col.key || col.label) === sortConfig.key,\n );\n\n if (typeof aValue === \"string\" && typeof bValue === \"string\") {\n if (column?.type === \"date\") {\n // Convert Italian date format (DD/MM/YYYY - HH:mm) to Date object\n const parseDate = (dateStr: string) => {\n const [datePart, timePart] = dateStr.split(\" - \");\n const [day, month, year] = datePart.split(\"/\").map(Number);\n const [hours, minutes] = timePart.split(\":\").map(Number);\n return new Date(year, month - 1, day, hours, minutes);\n };\n\n const dateA = parseDate(aValue);\n const dateB = parseDate(bValue);\n return sortConfig.direction === \"asc\"\n ? dateA.getTime() - dateB.getTime()\n : dateB.getTime() - dateA.getTime();\n }\n\n if (column?.type === \"number\") {\n const numA = parseFloat(aValue);\n const numB = parseFloat(bValue);\n return sortConfig.direction === \"asc\" ? numA - numB : numB - numA;\n }\n\n return sortConfig.direction === \"asc\"\n ? aValue.localeCompare(bValue)\n : bValue.localeCompare(aValue);\n }\n\n if (isDoubleLineData(aValue) && isDoubleLineData(bValue)) {\n return sortConfig.direction === \"asc\"\n ? aValue.firstLine.localeCompare(bValue.firstLine)\n : bValue.firstLine.localeCompare(aValue.firstLine);\n }\n\n return 0;\n });\n }, [data, sortConfig, columns]);\n\n const handleSort = (columnKey: string) => {\n const newSortConfig = {\n key: columnKey,\n direction:\n sortConfig.key === columnKey && sortConfig.direction === \"asc\"\n ? \"desc\"\n : \"asc\",\n } as { key: string; direction: \"asc\" | \"desc\" };\n\n setSortConfig(newSortConfig);\n if (setSelectedSort) {\n setSelectedSort(newSortConfig);\n }\n };\n\n const startIndex = pagination ? (currentPage - 1) * resultsPerPage : 0;\n const endIndex = pagination\n ? Math.min(startIndex + resultsPerPage, sortedData.length)\n : sortedData.length;\n const currentPageData = sortedData.slice(startIndex, endIndex);\n\n return (\n <div className=\"position-relative w-full\">\n <table\n ref={ref}\n className={clsx(\"table\", className)}\n role=\"table\"\n {...props}\n >\n <TableHeader className=\"table__header\">\n <TableRow>\n {columns.map((column, index) => (\n <TableHead\n key={`${column.label}-${index}`}\n config={column}\n sortConfig={sortConfig}\n onSort={() =>\n column.sortable && handleSort(column.key || column.label)\n }\n />\n ))}\n </TableRow>\n </TableHeader>\n <TableBody className=\"table__body\">\n {currentPageData.map((row, rowIndex) => (\n <TableRow key={rowIndex} className=\"table__row\">\n {Object.entries(row).map(([key, value], cellIndex) => {\n if (!value) return null;\n\n if (key === \"actionData\" && isActionData(value)) {\n return (\n <TableCell\n key={`${key}-${cellIndex}`}\n content={value}\n type=\"action\"\n />\n );\n }\n if (isDoubleLineData(value)) {\n return (\n <TableCell\n key={`${key}-${cellIndex}`}\n content={value}\n type=\"double-line\"\n />\n );\n }\n if (typeof value === \"string\") {\n return (\n <TableCell key={`${key}-${cellIndex}`} content={value} />\n );\n }\n return null;\n })}\n </TableRow>\n ))}\n </TableBody>\n </table>\n {pagination && (\n <Pagination\n currentPage={currentPage}\n totalResults={sortedData.length}\n resultsPerPage={resultsPerPage}\n setCurrentPage={setCurrentPage}\n />\n )}\n </div>\n );\n },\n);\nTable.displayName = \"Table\";\n\nconst TableHeader = React.forwardRef<HTMLTableSectionElement, TableHeaderProps>(\n ({ className, children, ...props }, ref) => (\n <thead\n ref={ref}\n className={clsx(\"[&_tr]:border-b-0\", className)}\n {...props}\n >\n {children}\n </thead>\n ),\n);\nTableHeader.displayName = \"TableHeader\";\n\nconst TableBody = React.forwardRef<HTMLTableSectionElement, TableBodyProps>(\n ({ className, children, ...props }, ref) => (\n <tbody\n ref={ref}\n className={clsx(\"[&_tr:last-child]:border-0\", className)}\n {...props}\n >\n {children}\n </tbody>\n ),\n);\nTableBody.displayName = \"TableBody\";\n\nconst TableRow = React.forwardRef<HTMLTableRowElement, TableRowProps>(\n ({ className, children, ...props }, ref) => (\n <tr\n ref={ref}\n className={clsx(\n \"border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted\",\n className,\n )}\n {...props}\n >\n {children}\n </tr>\n ),\n);\nTableRow.displayName = \"TableRow\";\n\nconst TableHead = React.forwardRef<\n HTMLTableCellElement,\n TableHeadProps & {\n config: ColumnConfig;\n sortConfig: { key: string; direction: \"asc\" | \"desc\" };\n onSort?: () => void;\n }\n>(({ className, config, sortConfig, onSort, ...props }, ref) => {\n const isSorted = sortConfig.key === (config.key || config.label);\n const sortDirection = isSorted ? sortConfig.direction : null;\n\n const getAriaSortValue = (): \"ascending\" | \"descending\" => {\n return sortDirection === \"asc\" ? \"ascending\" : \"descending\";\n };\n\n const renderIcon = (icon: React.ReactNode | CommonIconsType) => {\n switch (icon) {\n case \"info\":\n return <Info />;\n case \"download\":\n return <Download />;\n default:\n return icon;\n }\n };\n\n return (\n <th\n ref={ref}\n className={clsx(\n \"table__cell table__cell--header\",\n {\n \"table__cell--sortable\": config.sortable,\n \"table__cell--action\": config.action,\n },\n className,\n )}\n onClick={config.sortable ? onSort : config.action}\n aria-label={config.ariaLabel}\n aria-sort={isSorted ? getAriaSortValue() : undefined}\n {...props}\n >\n <div className=\"table__cell--header--content\">\n <div>\n <ActionIconText\n icon={renderIcon(config.icon)}\n textLabel={config.label}\n iconPosition={config.iconPosition}\n handleIconAction={() => {\n config.iconAction;\n }}\n popupInfo={config.popupInfo}\n />\n </div>\n {config.sortable && (\n <span className=\"sort-indicator\">\n <TriangleUp\n filled={isSorted && sortDirection === \"desc\"}\n className={clsx(\"sort-indicator__triangle\", {\n active: isSorted && sortDirection === \"desc\",\n })}\n />\n <TriangleDown\n filled={isSorted && sortDirection === \"asc\"}\n className={clsx(\"sort-indicator__triangle\", {\n active: isSorted && sortDirection === \"asc\",\n })}\n />\n </span>\n )}\n </div>\n </th>\n );\n});\nTableHead.displayName = \"TableHead\";\n\nconst DoubleLineContent: React.FC<{ data: DoubleLineData }> = ({ data }) => (\n <>\n <div className=\"table__cell--firstLine\">{data.firstLine}</div>\n <div className=\"table__cell--secondLine\">{data.secondLine}</div>\n </>\n);\n\nconst ActionContent: React.FC<{ data: ActionData }> = ({ data }) => {\n if (data.type === \"link\" && data.link) {\n return (\n <a href={data.link} aria-label={data.ariaLabel}>\n {data.label}\n </a>\n );\n }\n return (\n <button onClick={data.action} aria-label={data.ariaLabel}>\n {data.label}\n </button>\n );\n};\n\n// check if we are rendering a double line data\nconst isDoubleLineData = (\n content: TableCellProps[\"content\"],\n): content is DoubleLineData => {\n return (\n typeof content === \"object\" &&\n content !== null &&\n \"firstLine\" in content &&\n \"secondLine\" in content\n );\n};\n\n// check if we are rendering an action data\nconst isActionData = (\n content: TableCellProps[\"content\"],\n): content is ActionData => {\n return (\n typeof content === \"object\" &&\n content !== null &&\n \"label\" in content &&\n \"type\" in content\n );\n};\n\nconst TableCellContent: React.FC<{ content: TableCellProps[\"content\"] }> = ({\n content,\n}) => {\n if (typeof content === \"string\") {\n return <>{content}</>;\n }\n if (isDoubleLineData(content)) {\n return <DoubleLineContent data={content} />;\n }\n if (isActionData(content)) {\n return <ActionContent data={content} />;\n }\n return null;\n};\n\nconst TableCell = React.forwardRef<HTMLTableCellElement, TableCellProps>(\n ({ className, content, type, ...props }, ref) => (\n <td\n ref={ref}\n className={clsx(\n \"table__cell\",\n {\n \"table__cell--double-line\": type === \"double-line\",\n \"table__cell--action\": type === \"action\",\n },\n className,\n )}\n {...props}\n >\n <TableCellContent content={content} />\n </td>\n ),\n);\nTableCell.displayName = \"TableCell\";\n\nconst Pagination: React.FC<PaginationProps> = ({\n currentPage = 1,\n totalResults,\n resultsPerPage,\n setCurrentPage,\n className,\n}) => {\n const totalPages = Math.ceil(totalResults / resultsPerPage);\n\n return (\n <div className={clsx(\"pagination\", className)}>\n <div className=\"pagination__info\">\n Stai visualizzando{\" \"}\n <span className=\"pagination__info__resultsPerPage\">\n {resultsPerPage}\n </span>{\" \"}\n di {totalResults} risultati\n </div>\n <div className=\"pagination__nav\">\n <button\n className={clsx(\n \"pagination__button\",\n currentPage === 1 && \"pagination__button--disabled\",\n )}\n onClick={() => setCurrentPage(currentPage - 1)}\n disabled={currentPage === 1}\n aria-label=\"Previous page\"\n >\n <svg className=\"pagination__button-arrow\" viewBox=\"0 0 24 24\">\n <path d=\"M15 18l-6-6 6-6\" />\n </svg>\n </button>\n {Array.from({ length: totalPages }, (_, i) => i + 1).map((page) => (\n <button\n key={page}\n className={clsx(\n \"pagination__button\",\n currentPage === page && \"pagination__button--active\",\n )}\n onClick={() => setCurrentPage(page)}\n >\n {page}\n </button>\n ))}\n <button\n className={clsx(\n \"pagination__button\",\n currentPage === totalPages && \"pagination__button--disabled\",\n )}\n onClick={() => setCurrentPage(currentPage + 1)}\n disabled={currentPage === totalPages}\n aria-label=\"Next page\"\n >\n <svg className=\"pagination__button-arrow\" viewBox=\"0 0 24 24\">\n <path d=\"M9 6l6 6-6 6\" />\n </svg>\n </button>\n </div>\n </div>\n );\n};\n\nexport {\n Table,\n TableHeader,\n TableBody,\n TableHead,\n TableRow,\n TableCell,\n Pagination,\n};\n"],"names":["Table","React","className","columns","data","pagination","initialCurrentPage","resultsPerPage","defaultSortDirection","setSelectedSort","initialSortConfig","props","ref","sortConfig","setSortConfig","currentPage","setCurrentPage","useEffect","sortedData","a","b","aValue","bValue","column","col","parseDate","dateStr","datePart","timePart","day","month","year","hours","minutes","dateA","dateB","numA","numB","isDoubleLineData","handleSort","columnKey","newSortConfig","startIndex","endIndex","currentPageData","jsxs","clsx","jsx","TableHeader","TableRow","index","TableHead","TableBody","row","rowIndex","key","value","cellIndex","isActionData","TableCell","Pagination","children","config","onSort","isSorted","sortDirection","getAriaSortValue","renderIcon","icon","Info","Download","ActionIconText","TriangleUp","TriangleDown","DoubleLineContent","Fragment","ActionContent","content","TableCellContent","type","totalResults","totalPages","_","i","page"],"mappings":"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"}
|
package/dist/index.es67.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.es67.js","sources":["../src/components/ui/CardNotification/index.tsx"],"sourcesContent":["import \"./CardNotification.scss\";\nimport { useMemo } from \"react\";\nimport { Actions, Calendar } from \"@/icons\";\nimport { Button, Row } from \"@/components\";\n\ntype Variant = \"primary\" | \"secondary\";\n\ntype NotificationIcon = \"calendar\" | \"actions\";\n\ntype CardNotificationProps = {\n type: string;\n date: string;\n icon: NotificationIcon;\n showBadge?: boolean;\n title: string;\n text: string;\n variant?: Variant;\n onClickEdit?: () => void;\n onClickManage?: () => void;\n onClickGoToDetails?: () => void;\n showExpired?: boolean;\n buttonMaxWidth?: boolean;\n onClickRightManage?: () => void;\n};\n\nexport const CardNotification = ({\n type,\n onClickEdit,\n onClickRightManage,\n showExpired = false,\n buttonMaxWidth,\n onClickGoToDetails,\n icon = \"calendar\",\n variant = \"primary\",\n onClickManage,\n date,\n title,\n showBadge = false,\n text,\n}: CardNotificationProps) => {\n const isSecondary = variant === \"secondary\";\n\n const iconToRender = useMemo(() => {\n if (icon === \"calendar\") {\n return <Calendar width={24} height={26} color=\"slate-28\" />;\n }\n if (icon === \"actions\") {\n return <Actions width={24} height={26} color=\"slate-28\" />;\n }\n }, [icon]);\n\n const cardClasses = ` ${\n isSecondary\n ? \"bg-lightblue-a03 ui-card-notifications-secondary\"\n : \"bg-white\"\n } shadow br-x4 `;\n\n const iconContainer = ` ui-card-notifications-icon base-row ${\n isSecondary ? \"bg-white\" : \"bg-lightblue-a03\"\n } `;\n\n const manageButtonClasses = ` ${\n buttonMaxWidth ? \"w-full\" : \"ui-card-notifications-button\"\n } `;\n\n return (\n <div className={cardClasses}>\n <Row px={\"x24\"} py={\"x8\"} justifyContent={\"space-between\"}>\n <p className={\"fs-7 fw-semibold\"}> {type}</p>\n <p className={\"fs-7 fw-semibold\"}>{date}</p>\n </Row>\n <div className={\"ui-card-notifications-divider \"} />\n <Row pt={\"x16\"} px={\"x24\"} pb={\"x24\"} gap={\"x16\"}>\n <div className={iconContainer}>\n {showBadge && (\n <div className={\"ui-card-notifications-badge-container\"}>\n <div className={\"ui-card-notifications-badge\"} />\n </div>\n )}\n {iconToRender}\n </div>\n <div className={\"w-full\"}>\n <div className={\"mb-x24\"}>\n <p className={\"my-x8 fs-5 fw-semibold\"}>{title}</p>\n {showExpired && (\n <Row mb={\"x8\"}>\n <div\n className={\n \"py-x4 px-x16 bg-status-error text-white rounded fw-semibold fs-7\"\n }\n >\n SCADUTO\n </div>\n </Row>\n )}\n <p>{text}</p>\n </div>\n\n {onClickManage && (\n <div className={\"base-row justify-content-center\"}>\n <Button className={manageButtonClasses} onClick={onClickManage}>\n Gestisci\n </Button>\n </div>\n )}\n\n <Row justifyContent={\"flex-end\"} className={\"w-full gap-x16\"}>\n {onClickRightManage && (\n <div className={\"base-row justify-content-center\"}>\n <Button onClick={onClickRightManage}>Gestisci</Button>\n </div>\n )}\n\n {!!onClickEdit && (\n <Button\n onClick={onClickEdit}\n bg=\"transparent\"\n textColor=\"primary\"\n >\n Modifica\n </Button>\n )}\n {!!onClickGoToDetails && (\n <Button onClick={onClickGoToDetails} variant={\"secondary\"}>\n Più dettagli\n </Button>\n )}\n </Row>\n </div>\n </Row>\n </div>\n );\n};\n"],"names":["CardNotification","type","onClickEdit","onClickRightManage","showExpired","buttonMaxWidth","onClickGoToDetails","icon","variant","onClickManage","date","title","showBadge","text","isSecondary","iconToRender","useMemo","Calendar","Actions","cardClasses","iconContainer","manageButtonClasses","jsxs","Row","jsx","Button"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"index.es67.js","sources":["../src/components/ui/CardNotification/index.tsx"],"sourcesContent":["import \"./CardNotification.scss\";\r\nimport { useMemo } from \"react\";\r\nimport { Actions, Calendar } from \"@/icons\";\r\nimport { Button, Row } from \"@/components\";\r\n\r\ntype Variant = \"primary\" | \"secondary\";\r\n\r\ntype NotificationIcon = \"calendar\" | \"actions\";\r\n\r\ntype CardNotificationProps = {\r\n type: string;\r\n date: string;\r\n icon: NotificationIcon;\r\n showBadge?: boolean;\r\n title: string;\r\n text: string;\r\n variant?: Variant;\r\n onClickEdit?: () => void;\r\n onClickManage?: () => void;\r\n onClickGoToDetails?: () => void;\r\n showExpired?: boolean;\r\n buttonMaxWidth?: boolean;\r\n onClickRightManage?: () => void;\r\n};\r\n\r\nexport const CardNotification = ({\r\n type,\r\n onClickEdit,\r\n onClickRightManage,\r\n showExpired = false,\r\n buttonMaxWidth,\r\n onClickGoToDetails,\r\n icon = \"calendar\",\r\n variant = \"primary\",\r\n onClickManage,\r\n date,\r\n title,\r\n showBadge = false,\r\n text,\r\n}: CardNotificationProps) => {\r\n const isSecondary = variant === \"secondary\";\r\n\r\n const iconToRender = useMemo(() => {\r\n if (icon === \"calendar\") {\r\n return <Calendar width={24} height={26} color=\"slate-28\" />;\r\n }\r\n if (icon === \"actions\") {\r\n return <Actions width={24} height={26} color=\"slate-28\" />;\r\n }\r\n }, [icon]);\r\n\r\n const cardClasses = ` ${\r\n isSecondary\r\n ? \"bg-lightblue-a03 ui-card-notifications-secondary\"\r\n : \"bg-white\"\r\n } shadow br-x4 `;\r\n\r\n const iconContainer = ` ui-card-notifications-icon base-row ${\r\n isSecondary ? \"bg-white\" : \"bg-lightblue-a03\"\r\n } `;\r\n\r\n const manageButtonClasses = ` ${\r\n buttonMaxWidth ? \"w-full\" : \"ui-card-notifications-button\"\r\n } `;\r\n\r\n return (\r\n <div className={cardClasses}>\r\n <Row px={\"x24\"} py={\"x8\"} justifyContent={\"space-between\"}>\r\n <p className={\"fs-7 fw-semibold\"}> {type}</p>\r\n <p className={\"fs-7 fw-semibold\"}>{date}</p>\r\n </Row>\r\n <div className={\"ui-card-notifications-divider \"} />\r\n <Row pt={\"x16\"} px={\"x24\"} pb={\"x24\"} gap={\"x16\"}>\r\n <div className={iconContainer}>\r\n {showBadge && (\r\n <div className={\"ui-card-notifications-badge-container\"}>\r\n <div className={\"ui-card-notifications-badge\"} />\r\n </div>\r\n )}\r\n {iconToRender}\r\n </div>\r\n <div className={\"w-full\"}>\r\n <div className={\"mb-x24\"}>\r\n <p className={\"my-x8 fs-5 fw-semibold\"}>{title}</p>\r\n {showExpired && (\r\n <Row mb={\"x8\"}>\r\n <div\r\n className={\r\n \"py-x4 px-x16 bg-status-error text-white rounded fw-semibold fs-7\"\r\n }\r\n >\r\n SCADUTO\r\n </div>\r\n </Row>\r\n )}\r\n <p>{text}</p>\r\n </div>\r\n\r\n {onClickManage && (\r\n <div className={\"base-row justify-content-center\"}>\r\n <Button className={manageButtonClasses} onClick={onClickManage}>\r\n Gestisci\r\n </Button>\r\n </div>\r\n )}\r\n\r\n <Row justifyContent={\"flex-end\"} className={\"w-full gap-x16\"}>\r\n {onClickRightManage && (\r\n <div className={\"base-row justify-content-center\"}>\r\n <Button onClick={onClickRightManage}>Gestisci</Button>\r\n </div>\r\n )}\r\n\r\n {!!onClickEdit && (\r\n <Button\r\n onClick={onClickEdit}\r\n bg=\"transparent\"\r\n textColor=\"primary\"\r\n >\r\n Modifica\r\n </Button>\r\n )}\r\n {!!onClickGoToDetails && (\r\n <Button onClick={onClickGoToDetails} variant={\"secondary\"}>\r\n Più dettagli\r\n </Button>\r\n )}\r\n </Row>\r\n </div>\r\n </Row>\r\n </div>\r\n );\r\n};\r\n"],"names":["CardNotification","type","onClickEdit","onClickRightManage","showExpired","buttonMaxWidth","onClickGoToDetails","icon","variant","onClickManage","date","title","showBadge","text","isSecondary","iconToRender","useMemo","Calendar","Actions","cardClasses","iconContainer","manageButtonClasses","jsxs","Row","jsx","Button"],"mappings":"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"}
|
package/dist/index.es68.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.es68.js","sources":["../src/components/ui/DatePicker/index.tsx"],"sourcesContent":["// src/components/ui/Button/index.tsx\nimport { DateTime } from \"luxon\";\nimport \"./DatePicker.scss\";\nimport clsx from \"clsx\";\nimport { useEffect, useRef } from \"react\";\n\ntype DatePickerProps = {\n label: string;\n value?: Date | null;\n maxValue?: Date;\n minValue?: Date;\n className?: string;\n disabled?: boolean;\n onClick?: () => void;\n onChange: (date: Date) => void;\n error?: string;\n required?: boolean;\n id?: string;\n};\n\nexport const DatePicker = ({\n label,\n value,\n maxValue,\n minValue,\n className,\n disabled,\n onClick,\n onChange,\n error,\n required = false,\n id,\n}: DatePickerProps) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const inputId =\n id || `datepicker-${label.toLowerCase().replace(/\\s+/g, \"-\")}`;\n\n useEffect(() => {\n if (error && inputRef.current) {\n inputRef.current.setAttribute(\"aria-invalid\", \"true\");\n inputRef.current.setAttribute(\"aria-describedby\", `${inputId}-error`);\n } else if (inputRef.current) {\n inputRef.current.setAttribute(\"aria-invalid\", \"false\");\n inputRef.current.removeAttribute(\"aria-describedby\");\n }\n }, [error, inputId]);\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === \"Enter\" && !disabled) {\n onClick?.();\n }\n };\n\n const formattedValue = value\n ? DateTime.fromJSDate(value).toFormat(\"yyyy-MM-dd\")\n : \"\";\n\n return (\n <div\n className={clsx(\"datepicker-container\", className)}\n role=\"group\"\n aria-labelledby={`${inputId}-label`}\n aria-describedby={error ? `${inputId}-error` : undefined}\n >\n <label\n id={`${inputId}-label`}\n htmlFor={inputId}\n className=\"datepicker-label fs-7\"\n >\n {label}\n {required && (\n <span className=\"text-error ml-1\" aria-hidden=\"true\">\n *\n </span>\n )}\n </label>\n <input\n ref={inputRef}\n id={inputId}\n type=\"date\"\n className=\"datepicker-input fs-6\"\n disabled={disabled}\n value={formattedValue}\n max={\n maxValue\n ? DateTime.fromJSDate(maxValue).toFormat(\"yyyy-MM-dd\")\n : undefined\n }\n min={\n minValue\n ? DateTime.fromJSDate(minValue).toFormat(\"yyyy-MM-dd\")\n : undefined\n }\n onClick={() => onClick?.()}\n onChange={(e) => {\n const newDate = new Date(e.target.value);\n if (!isNaN(newDate.getTime())) {\n onChange(newDate);\n }\n }}\n onKeyDown={handleKeyDown}\n aria-required={required}\n aria-disabled={disabled}\n aria-label={label}\n aria-invalid={!!error}\n aria-describedby={error ? `${inputId}-error` : undefined}\n />\n {error && (\n <div\n id={`${inputId}-error`}\n className=\"datepicker-error\"\n role=\"alert\"\n aria-live=\"polite\"\n >\n {error}\n </div>\n )}\n </div>\n );\n};\n"],"names":["DatePicker","label","value","maxValue","minValue","className","disabled","onClick","onChange","error","required","id","inputRef","useRef","inputId","useEffect","handleKeyDown","e","formattedValue","DateTime","jsxs","clsx","jsx","newDate"],"mappings":";;;;;;AAoBO,MAAMA,IAAa,CAAC;AAAA,EACzB,OAAAC;AAAA,EACA,OAAAC;AAAA,EACA,UAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,UAAAC;AAAA,EACA,SAAAC;AAAA,EACA,UAAAC;AAAA,EACA,OAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,IAAAC;AACF,MAAuB;AACf,QAAAC,IAAWC,EAAyB,IAAI,GACxCC,IACJH,KAAM,cAAcV,EAAM,YAAc,EAAA,QAAQ,QAAQ,GAAG,CAAC;AAE9D,EAAAc,EAAU,MAAM;AACV,IAAAN,KAASG,EAAS,WACXA,EAAA,QAAQ,aAAa,gBAAgB,MAAM,GACpDA,EAAS,QAAQ,aAAa,oBAAoB,GAAGE,CAAO,QAAQ,KAC3DF,EAAS,YACTA,EAAA,QAAQ,aAAa,gBAAgB,OAAO,GAC5CA,EAAA,QAAQ,gBAAgB,kBAAkB;AAAA,EACrD,GACC,CAACH,GAAOK,CAAO,CAAC;AAEb,QAAAE,IAAgB,CAACC,MAA6C;AAClE,IAAIA,EAAE,QAAQ,WAAW,CAACX,MACdC,KAAA,QAAAA;AAAA,EAEd,GAEMW,IAAiBhB,IACnBiB,EAAS,WAAWjB,CAAK,EAAE,SAAS,YAAY,IAChD;AAGF,SAAAkB,gBAAAA,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWC,EAAK,wBAAwBhB,CAAS;AAAA,MACjD,MAAK;AAAA,MACL,mBAAiB,GAAGS,CAAO;AAAA,MAC3B,oBAAkBL,IAAQ,GAAGK,CAAO,WAAW;AAAA,MAE/C,UAAA;AAAA,QAAAM,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,IAAI,GAAGN,CAAO;AAAA,YACd,SAASA;AAAA,YACT,WAAU;AAAA,YAET,UAAA;AAAA,cAAAb;AAAA,cACAS,KACEY,gBAAAA,EAAAA,IAAA,QAAA,EAAK,WAAU,mBAAkB,eAAY,QAAO,UAErD,IAAA,CAAA;AAAA,YAAA;AAAA,UAAA;AAAA,QAEJ;AAAA,QACAA,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAKV;AAAA,YACL,IAAIE;AAAA,YACJ,MAAK;AAAA,YACL,WAAU;AAAA,YACV,UAAAR;AAAA,YACA,OAAOY;AAAA,YACP,KACEf,IACIgB,EAAS,WAAWhB,CAAQ,EAAE,SAAS,YAAY,IACnD;AAAA,YAEN,KACEC,IACIe,EAAS,WAAWf,CAAQ,EAAE,SAAS,YAAY,IACnD;AAAA,YAEN,SAAS,MAAMG,KAAA,gBAAAA;AAAA,YACf,UAAU,CAACU,MAAM;AACf,oBAAMM,IAAU,IAAI,KAAKN,EAAE,OAAO,KAAK;AACvC,cAAK,MAAMM,EAAQ,QAAS,CAAA,KAC1Bf,EAASe,CAAO;AAAA,YAEpB;AAAA,YACA,WAAWP;AAAA,YACX,iBAAeN;AAAA,YACf,iBAAeJ;AAAA,YACf,cAAYL;AAAA,YACZ,gBAAc,CAAC,CAACQ;AAAA,YAChB,oBAAkBA,IAAQ,GAAGK,CAAO,WAAW;AAAA,UAAA;AAAA,QACjD;AAAA,QACCL,KACCa,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,IAAI,GAAGR,CAAO;AAAA,YACd,WAAU;AAAA,YACV,MAAK;AAAA,YACL,aAAU;AAAA,YAET,UAAAL;AAAA,UAAA;AAAA,QAAA;AAAA,MACH;AAAA,IAAA;AAAA,EAEJ;AAEJ;"}
|
1
|
+
{"version":3,"file":"index.es68.js","sources":["../src/components/ui/DatePicker/index.tsx"],"sourcesContent":["// src/components/ui/Button/index.tsx\r\nimport { DateTime } from \"luxon\";\r\nimport \"./DatePicker.scss\";\r\nimport clsx from \"clsx\";\r\nimport { useEffect, useRef } from \"react\";\r\n\r\ntype DatePickerProps = {\r\n label: string;\r\n value?: Date | null;\r\n maxValue?: Date;\r\n minValue?: Date;\r\n className?: string;\r\n disabled?: boolean;\r\n onClick?: () => void;\r\n onChange: (date: Date) => void;\r\n error?: string;\r\n required?: boolean;\r\n id?: string;\r\n};\r\n\r\nexport const DatePicker = ({\r\n label,\r\n value,\r\n maxValue,\r\n minValue,\r\n className,\r\n disabled,\r\n onClick,\r\n onChange,\r\n error,\r\n required = false,\r\n id,\r\n}: DatePickerProps) => {\r\n const inputRef = useRef<HTMLInputElement>(null);\r\n const inputId =\r\n id || `datepicker-${label.toLowerCase().replace(/\\s+/g, \"-\")}`;\r\n\r\n useEffect(() => {\r\n if (error && inputRef.current) {\r\n inputRef.current.setAttribute(\"aria-invalid\", \"true\");\r\n inputRef.current.setAttribute(\"aria-describedby\", `${inputId}-error`);\r\n } else if (inputRef.current) {\r\n inputRef.current.setAttribute(\"aria-invalid\", \"false\");\r\n inputRef.current.removeAttribute(\"aria-describedby\");\r\n }\r\n }, [error, inputId]);\r\n\r\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\r\n if (e.key === \"Enter\" && !disabled) {\r\n onClick?.();\r\n }\r\n };\r\n\r\n const formattedValue = value\r\n ? DateTime.fromJSDate(value).toFormat(\"yyyy-MM-dd\")\r\n : \"\";\r\n\r\n return (\r\n <div\r\n className={clsx(\"datepicker-container\", className)}\r\n role=\"group\"\r\n aria-labelledby={`${inputId}-label`}\r\n aria-describedby={error ? `${inputId}-error` : undefined}\r\n >\r\n <label\r\n id={`${inputId}-label`}\r\n htmlFor={inputId}\r\n className=\"datepicker-label fs-7\"\r\n >\r\n {label}\r\n {required && (\r\n <span className=\"text-error ml-1\" aria-hidden=\"true\">\r\n *\r\n </span>\r\n )}\r\n </label>\r\n <input\r\n ref={inputRef}\r\n id={inputId}\r\n type=\"date\"\r\n className=\"datepicker-input fs-6\"\r\n disabled={disabled}\r\n value={formattedValue}\r\n max={\r\n maxValue\r\n ? DateTime.fromJSDate(maxValue).toFormat(\"yyyy-MM-dd\")\r\n : undefined\r\n }\r\n min={\r\n minValue\r\n ? DateTime.fromJSDate(minValue).toFormat(\"yyyy-MM-dd\")\r\n : undefined\r\n }\r\n onClick={() => onClick?.()}\r\n onChange={(e) => {\r\n const newDate = new Date(e.target.value);\r\n if (!isNaN(newDate.getTime())) {\r\n onChange(newDate);\r\n }\r\n }}\r\n onKeyDown={handleKeyDown}\r\n aria-required={required}\r\n aria-disabled={disabled}\r\n aria-label={label}\r\n aria-invalid={!!error}\r\n aria-describedby={error ? `${inputId}-error` : undefined}\r\n />\r\n {error && (\r\n <div\r\n id={`${inputId}-error`}\r\n className=\"datepicker-error\"\r\n role=\"alert\"\r\n aria-live=\"polite\"\r\n >\r\n {error}\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n"],"names":["DatePicker","label","value","maxValue","minValue","className","disabled","onClick","onChange","error","required","id","inputRef","useRef","inputId","useEffect","handleKeyDown","e","formattedValue","DateTime","jsxs","clsx","jsx","newDate"],"mappings":";;;;;;AAoBO,MAAMA,IAAa,CAAC;AAAA,EACzB,OAAAC;AAAA,EACA,OAAAC;AAAA,EACA,UAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,UAAAC;AAAA,EACA,SAAAC;AAAA,EACA,UAAAC;AAAA,EACA,OAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,IAAAC;AACF,MAAuB;AACf,QAAAC,IAAWC,EAAyB,IAAI,GACxCC,IACJH,KAAM,cAAcV,EAAM,YAAc,EAAA,QAAQ,QAAQ,GAAG,CAAC;AAE9D,EAAAc,EAAU,MAAM;AACV,IAAAN,KAASG,EAAS,WACXA,EAAA,QAAQ,aAAa,gBAAgB,MAAM,GACpDA,EAAS,QAAQ,aAAa,oBAAoB,GAAGE,CAAO,QAAQ,KAC3DF,EAAS,YACTA,EAAA,QAAQ,aAAa,gBAAgB,OAAO,GAC5CA,EAAA,QAAQ,gBAAgB,kBAAkB;AAAA,EACrD,GACC,CAACH,GAAOK,CAAO,CAAC;AAEb,QAAAE,IAAgB,CAACC,MAA6C;AAClE,IAAIA,EAAE,QAAQ,WAAW,CAACX,MACdC,KAAA,QAAAA;AAAA,EAEd,GAEMW,IAAiBhB,IACnBiB,EAAS,WAAWjB,CAAK,EAAE,SAAS,YAAY,IAChD;AAGF,SAAAkB,gBAAAA,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWC,EAAK,wBAAwBhB,CAAS;AAAA,MACjD,MAAK;AAAA,MACL,mBAAiB,GAAGS,CAAO;AAAA,MAC3B,oBAAkBL,IAAQ,GAAGK,CAAO,WAAW;AAAA,MAE/C,UAAA;AAAA,QAAAM,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,IAAI,GAAGN,CAAO;AAAA,YACd,SAASA;AAAA,YACT,WAAU;AAAA,YAET,UAAA;AAAA,cAAAb;AAAA,cACAS,KACEY,gBAAAA,EAAAA,IAAA,QAAA,EAAK,WAAU,mBAAkB,eAAY,QAAO,UAErD,IAAA,CAAA;AAAA,YAAA;AAAA,UAAA;AAAA,QAEJ;AAAA,QACAA,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAKV;AAAA,YACL,IAAIE;AAAA,YACJ,MAAK;AAAA,YACL,WAAU;AAAA,YACV,UAAAR;AAAA,YACA,OAAOY;AAAA,YACP,KACEf,IACIgB,EAAS,WAAWhB,CAAQ,EAAE,SAAS,YAAY,IACnD;AAAA,YAEN,KACEC,IACIe,EAAS,WAAWf,CAAQ,EAAE,SAAS,YAAY,IACnD;AAAA,YAEN,SAAS,MAAMG,KAAA,gBAAAA;AAAA,YACf,UAAU,CAACU,MAAM;AACf,oBAAMM,IAAU,IAAI,KAAKN,EAAE,OAAO,KAAK;AACvC,cAAK,MAAMM,EAAQ,QAAS,CAAA,KAC1Bf,EAASe,CAAO;AAAA,YAEpB;AAAA,YACA,WAAWP;AAAA,YACX,iBAAeN;AAAA,YACf,iBAAeJ;AAAA,YACf,cAAYL;AAAA,YACZ,gBAAc,CAAC,CAACQ;AAAA,YAChB,oBAAkBA,IAAQ,GAAGK,CAAO,WAAW;AAAA,UAAA;AAAA,QACjD;AAAA,QACCL,KACCa,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,IAAI,GAAGR,CAAO;AAAA,YACd,WAAU;AAAA,YACV,MAAK;AAAA,YACL,aAAU;AAAA,YAET,UAAAL;AAAA,UAAA;AAAA,QAAA;AAAA,MACH;AAAA,IAAA;AAAA,EAEJ;AAEJ;"}
|
package/dist/index.es69.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.es69.js","sources":["../src/components/ui/DatePickerRange/index.tsx"],"sourcesContent":["// src/components/ui/Button/index.tsx\nimport clsx from \"clsx\";\nimport { useEffect, useRef } from \"react\";\nimport { DatePicker } from \"../DatePicker\";\nimport { Row } from \"@/components\";\n\ntype DatePickerRangeProps = {\n label?: string;\n startDateLabel?: string;\n endDateLabel?: string;\n startDate?: Date;\n endDate?: Date;\n className?: string;\n disabled?: boolean;\n required?: boolean;\n error?: string;\n onStartDateChange: (date: Date) => void;\n onEndDateChange: (date: Date) => void;\n onStartDateClick?: () => void;\n onEndDateClick?: () => void;\n};\n\nexport const DatePickerRange = ({\n label,\n startDateLabel = \"Start Date\",\n endDateLabel = \"End Date\",\n startDate,\n endDate,\n className,\n disabled = false,\n required = false,\n error,\n onStartDateChange,\n onEndDateChange,\n onStartDateClick,\n onEndDateClick,\n}: DatePickerRangeProps) => {\n const containerRef = useRef<HTMLDivElement>(null);\n // we need to generate a unique id for the container and manage errors\n const containerId = label\n ? `datepicker-range-${label.toLowerCase().replace(/\\s+/g, \"-\")}`\n : \"datepicker-range\";\n\n useEffect(() => {\n if (error && containerRef.current) {\n containerRef.current.setAttribute(\"aria-invalid\", \"true\");\n containerRef.current.setAttribute(\n \"aria-describedby\",\n `${containerId}-error`,\n );\n } else if (containerRef.current) {\n containerRef.current.setAttribute(\"aria-invalid\", \"false\");\n containerRef.current.removeAttribute(\"aria-describedby\");\n }\n }, [error, containerId]);\n\n const handleStartDateChange = (date: Date) => {\n // Ensure end date is not before start date\n if (endDate && date > endDate) {\n onStartDateChange(date);\n onEndDateChange(date);\n } else {\n onStartDateChange(date);\n }\n };\n\n const handleEndDateChange = (date: Date) => {\n // Ensure start date is not after end date\n if (startDate && date < startDate) {\n onStartDateChange(date);\n onEndDateChange(date);\n } else {\n onEndDateChange(date);\n }\n };\n\n return (\n <div\n ref={containerRef}\n className={clsx(\"base-col gap-x8\", className)}\n role=\"group\"\n aria-labelledby={label ? `${containerId}-label` : undefined}\n aria-describedby={error ? `${containerId}-error` : undefined}\n >\n {label && (\n <label id={`${containerId}-label`} className=\"text-sm text-dark\">\n {label}\n {required && (\n <span className=\"text-error ml-1\" aria-hidden=\"true\">\n *\n </span>\n )}\n </label>\n )}\n\n <Row gap={\"x16\"} role=\"group\">\n <DatePicker\n label={startDateLabel}\n value={startDate}\n maxValue={endDate}\n disabled={disabled}\n required={required}\n onChange={handleStartDateChange}\n onClick={onStartDateClick}\n className=\"flex-1\"\n />\n\n <DatePicker\n label={endDateLabel}\n value={endDate}\n minValue={startDate}\n disabled={disabled}\n required={required}\n onChange={handleEndDateChange}\n onClick={onEndDateClick}\n className=\"flex-1\"\n />\n </Row>\n\n {error && (\n <div\n id={`${containerId}-error`}\n className=\"text-sm text-error\"\n role=\"alert\"\n aria-live=\"polite\"\n >\n {error}\n </div>\n )}\n </div>\n );\n};\n"],"names":["DatePickerRange","label","startDateLabel","endDateLabel","startDate","endDate","className","disabled","required","error","onStartDateChange","onEndDateChange","onStartDateClick","onEndDateClick","containerRef","useRef","containerId","useEffect","handleStartDateChange","date","handleEndDateChange","jsxs","clsx","jsx","Row","DatePicker"],"mappings":";;;;;AAsBO,MAAMA,IAAkB,CAAC;AAAA,EAC9B,OAAAC;AAAA,EACA,gBAAAC,IAAiB;AAAA,EACjB,cAAAC,IAAe;AAAA,EACf,WAAAC;AAAA,EACA,SAAAC;AAAA,EACA,WAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,UAAAC,IAAW;AAAA,EACX,OAAAC;AAAA,EACA,mBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,gBAAAC;AACF,MAA4B;AACpB,QAAAC,IAAeC,EAAuB,IAAI,GAE1CC,IAAcf,IAChB,oBAAoBA,EAAM,cAAc,QAAQ,QAAQ,GAAG,CAAC,KAC5D;AAEJ,EAAAgB,EAAU,MAAM;AACV,IAAAR,KAASK,EAAa,WACXA,EAAA,QAAQ,aAAa,gBAAgB,MAAM,GACxDA,EAAa,QAAQ;AAAA,MACnB;AAAA,MACA,GAAGE,CAAW;AAAA,IAChB,KACSF,EAAa,YACTA,EAAA,QAAQ,aAAa,gBAAgB,OAAO,GAC5CA,EAAA,QAAQ,gBAAgB,kBAAkB;AAAA,EACzD,GACC,CAACL,GAAOO,CAAW,CAAC;AAEjB,QAAAE,IAAwB,CAACC,MAAe;AAExC,IAAAd,KAAWc,IAAOd,KACpBK,EAAkBS,CAAI,GACtBR,EAAgBQ,CAAI,KAEpBT,EAAkBS,CAAI;AAAA,EAE1B,GAEMC,IAAsB,CAACD,MAAe;AAEtC,IAAAf,KAAae,IAAOf,KACtBM,EAAkBS,CAAI,GACtBR,EAAgBQ,CAAI;AAAA,EAIxB;AAGE,SAAAE,gBAAAA,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAKP;AAAA,MACL,WAAWQ,EAAK,mBAAmBhB,CAAS;AAAA,MAC5C,MAAK;AAAA,MACL,mBAAiBL,IAAQ,GAAGe,CAAW,WAAW;AAAA,MAClD,oBAAkBP,IAAQ,GAAGO,CAAW,WAAW;AAAA,MAElD,UAAA;AAAA,QAAAf,4BACE,SAAM,EAAA,IAAI,GAAGe,CAAW,UAAU,WAAU,qBAC1C,UAAA;AAAA,UAAAf;AAAA,UACAO,KACEe,gBAAAA,EAAAA,IAAA,QAAA,EAAK,WAAU,mBAAkB,eAAY,QAAO,UAErD,IAAA,CAAA;AAAA,QAAA,GAEJ;AAAA,QAGDF,gBAAAA,EAAA,KAAAG,GAAA,EAAI,KAAK,OAAO,MAAK,SACpB,UAAA;AAAA,UAAAD,gBAAAA,EAAA;AAAA,YAACE;AAAA,YAAA;AAAA,cACC,OAAOvB;AAAA,cACP,OAAOE;AAAA,cACP,UAAUC;AAAA,cACV,UAAAE;AAAA,cACA,UAAAC;AAAA,cACA,UAAUU;AAAA,cACV,SAASN;AAAA,cACT,WAAU;AAAA,YAAA;AAAA,UACZ;AAAA,UAEAW,gBAAAA,EAAA;AAAA,YAACE;AAAA,YAAA;AAAA,cACC,OAAOtB;AAAA,cACP,OAAOE;AAAA,cACP,UAAUD;AAAA,cACV,UAAAG;AAAA,cACA,UAAAC;AAAA,cACA,UAAUY;AAAA,cACV,SAASP;AAAA,cACT,WAAU;AAAA,YAAA;AAAA,UAAA;AAAA,QACZ,GACF;AAAA,QAECJ,KACCc,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,IAAI,GAAGP,CAAW;AAAA,YAClB,WAAU;AAAA,YACV,MAAK;AAAA,YACL,aAAU;AAAA,YAET,UAAAP;AAAA,UAAA;AAAA,QAAA;AAAA,MACH;AAAA,IAAA;AAAA,EAEJ;AAEJ;"}
|
1
|
+
{"version":3,"file":"index.es69.js","sources":["../src/components/ui/DatePickerRange/index.tsx"],"sourcesContent":["// src/components/ui/Button/index.tsx\r\nimport clsx from \"clsx\";\r\nimport { useEffect, useRef } from \"react\";\r\nimport { DatePicker } from \"../DatePicker\";\r\nimport { Row } from \"@/components\";\r\n\r\ntype DatePickerRangeProps = {\r\n label?: string;\r\n startDateLabel?: string;\r\n endDateLabel?: string;\r\n startDate?: Date;\r\n endDate?: Date;\r\n className?: string;\r\n disabled?: boolean;\r\n required?: boolean;\r\n error?: string;\r\n onStartDateChange: (date: Date) => void;\r\n onEndDateChange: (date: Date) => void;\r\n onStartDateClick?: () => void;\r\n onEndDateClick?: () => void;\r\n};\r\n\r\nexport const DatePickerRange = ({\r\n label,\r\n startDateLabel = \"Start Date\",\r\n endDateLabel = \"End Date\",\r\n startDate,\r\n endDate,\r\n className,\r\n disabled = false,\r\n required = false,\r\n error,\r\n onStartDateChange,\r\n onEndDateChange,\r\n onStartDateClick,\r\n onEndDateClick,\r\n}: DatePickerRangeProps) => {\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n // we need to generate a unique id for the container and manage errors\r\n const containerId = label\r\n ? `datepicker-range-${label.toLowerCase().replace(/\\s+/g, \"-\")}`\r\n : \"datepicker-range\";\r\n\r\n useEffect(() => {\r\n if (error && containerRef.current) {\r\n containerRef.current.setAttribute(\"aria-invalid\", \"true\");\r\n containerRef.current.setAttribute(\r\n \"aria-describedby\",\r\n `${containerId}-error`,\r\n );\r\n } else if (containerRef.current) {\r\n containerRef.current.setAttribute(\"aria-invalid\", \"false\");\r\n containerRef.current.removeAttribute(\"aria-describedby\");\r\n }\r\n }, [error, containerId]);\r\n\r\n const handleStartDateChange = (date: Date) => {\r\n // Ensure end date is not before start date\r\n if (endDate && date > endDate) {\r\n onStartDateChange(date);\r\n onEndDateChange(date);\r\n } else {\r\n onStartDateChange(date);\r\n }\r\n };\r\n\r\n const handleEndDateChange = (date: Date) => {\r\n // Ensure start date is not after end date\r\n if (startDate && date < startDate) {\r\n onStartDateChange(date);\r\n onEndDateChange(date);\r\n } else {\r\n onEndDateChange(date);\r\n }\r\n };\r\n\r\n return (\r\n <div\r\n ref={containerRef}\r\n className={clsx(\"base-col gap-x8\", className)}\r\n role=\"group\"\r\n aria-labelledby={label ? `${containerId}-label` : undefined}\r\n aria-describedby={error ? `${containerId}-error` : undefined}\r\n >\r\n {label && (\r\n <label id={`${containerId}-label`} className=\"text-sm text-dark\">\r\n {label}\r\n {required && (\r\n <span className=\"text-error ml-1\" aria-hidden=\"true\">\r\n *\r\n </span>\r\n )}\r\n </label>\r\n )}\r\n\r\n <Row gap={\"x16\"} role=\"group\">\r\n <DatePicker\r\n label={startDateLabel}\r\n value={startDate}\r\n maxValue={endDate}\r\n disabled={disabled}\r\n required={required}\r\n onChange={handleStartDateChange}\r\n onClick={onStartDateClick}\r\n className=\"flex-1\"\r\n />\r\n\r\n <DatePicker\r\n label={endDateLabel}\r\n value={endDate}\r\n minValue={startDate}\r\n disabled={disabled}\r\n required={required}\r\n onChange={handleEndDateChange}\r\n onClick={onEndDateClick}\r\n className=\"flex-1\"\r\n />\r\n </Row>\r\n\r\n {error && (\r\n <div\r\n id={`${containerId}-error`}\r\n className=\"text-sm text-error\"\r\n role=\"alert\"\r\n aria-live=\"polite\"\r\n >\r\n {error}\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n"],"names":["DatePickerRange","label","startDateLabel","endDateLabel","startDate","endDate","className","disabled","required","error","onStartDateChange","onEndDateChange","onStartDateClick","onEndDateClick","containerRef","useRef","containerId","useEffect","handleStartDateChange","date","handleEndDateChange","jsxs","clsx","jsx","Row","DatePicker"],"mappings":";;;;;AAsBO,MAAMA,IAAkB,CAAC;AAAA,EAC9B,OAAAC;AAAA,EACA,gBAAAC,IAAiB;AAAA,EACjB,cAAAC,IAAe;AAAA,EACf,WAAAC;AAAA,EACA,SAAAC;AAAA,EACA,WAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,UAAAC,IAAW;AAAA,EACX,OAAAC;AAAA,EACA,mBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,gBAAAC;AACF,MAA4B;AACpB,QAAAC,IAAeC,EAAuB,IAAI,GAE1CC,IAAcf,IAChB,oBAAoBA,EAAM,cAAc,QAAQ,QAAQ,GAAG,CAAC,KAC5D;AAEJ,EAAAgB,EAAU,MAAM;AACV,IAAAR,KAASK,EAAa,WACXA,EAAA,QAAQ,aAAa,gBAAgB,MAAM,GACxDA,EAAa,QAAQ;AAAA,MACnB;AAAA,MACA,GAAGE,CAAW;AAAA,IAChB,KACSF,EAAa,YACTA,EAAA,QAAQ,aAAa,gBAAgB,OAAO,GAC5CA,EAAA,QAAQ,gBAAgB,kBAAkB;AAAA,EACzD,GACC,CAACL,GAAOO,CAAW,CAAC;AAEjB,QAAAE,IAAwB,CAACC,MAAe;AAExC,IAAAd,KAAWc,IAAOd,KACpBK,EAAkBS,CAAI,GACtBR,EAAgBQ,CAAI,KAEpBT,EAAkBS,CAAI;AAAA,EAE1B,GAEMC,IAAsB,CAACD,MAAe;AAEtC,IAAAf,KAAae,IAAOf,KACtBM,EAAkBS,CAAI,GACtBR,EAAgBQ,CAAI;AAAA,EAIxB;AAGE,SAAAE,gBAAAA,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAKP;AAAA,MACL,WAAWQ,EAAK,mBAAmBhB,CAAS;AAAA,MAC5C,MAAK;AAAA,MACL,mBAAiBL,IAAQ,GAAGe,CAAW,WAAW;AAAA,MAClD,oBAAkBP,IAAQ,GAAGO,CAAW,WAAW;AAAA,MAElD,UAAA;AAAA,QAAAf,4BACE,SAAM,EAAA,IAAI,GAAGe,CAAW,UAAU,WAAU,qBAC1C,UAAA;AAAA,UAAAf;AAAA,UACAO,KACEe,gBAAAA,EAAAA,IAAA,QAAA,EAAK,WAAU,mBAAkB,eAAY,QAAO,UAErD,IAAA,CAAA;AAAA,QAAA,GAEJ;AAAA,QAGDF,gBAAAA,EAAA,KAAAG,GAAA,EAAI,KAAK,OAAO,MAAK,SACpB,UAAA;AAAA,UAAAD,gBAAAA,EAAA;AAAA,YAACE;AAAA,YAAA;AAAA,cACC,OAAOvB;AAAA,cACP,OAAOE;AAAA,cACP,UAAUC;AAAA,cACV,UAAAE;AAAA,cACA,UAAAC;AAAA,cACA,UAAUU;AAAA,cACV,SAASN;AAAA,cACT,WAAU;AAAA,YAAA;AAAA,UACZ;AAAA,UAEAW,gBAAAA,EAAA;AAAA,YAACE;AAAA,YAAA;AAAA,cACC,OAAOtB;AAAA,cACP,OAAOE;AAAA,cACP,UAAUD;AAAA,cACV,UAAAG;AAAA,cACA,UAAAC;AAAA,cACA,UAAUY;AAAA,cACV,SAASP;AAAA,cACT,WAAU;AAAA,YAAA;AAAA,UAAA;AAAA,QACZ,GACF;AAAA,QAECJ,KACCc,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,IAAI,GAAGP,CAAW;AAAA,YAClB,WAAU;AAAA,YACV,MAAK;AAAA,YACL,aAAU;AAAA,YAET,UAAAP;AAAA,UAAA;AAAA,QAAA;AAAA,MACH;AAAA,IAAA;AAAA,EAEJ;AAEJ;"}
|
package/dist/index.es7.js
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
import { j as a } from "./index.es185.js";
|
2
2
|
import { useMemo as i } from "react";
|
3
3
|
import { clsx as m } from "./index.es187.js";
|
4
|
-
import { createSpacingClasses as c } from "./index.
|
4
|
+
import { createSpacingClasses as c } from "./index.es197.js";
|
5
5
|
const g = ({
|
6
6
|
as: o,
|
7
7
|
className: r,
|