@jenesei-software/jenesei-kit-react 1.3.30 → 1.3.32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (144) hide show
  1. package/build/area-preview.cjs.js +1 -1
  2. package/build/area-preview.es.js +1 -1
  3. package/build/area-skeleton.cjs.js +1 -1
  4. package/build/area-skeleton.es.js +1 -1
  5. package/build/build-info.txt +3 -3
  6. package/build/{component-qRPasLxk.cjs → component-B8kWtTfs.cjs} +2 -2
  7. package/build/{component-qRPasLxk.cjs.map → component-B8kWtTfs.cjs.map} +1 -1
  8. package/build/{component-DXZrlFCa.js → component-BD3FCIT8.js} +3 -3
  9. package/build/{component-DXZrlFCa.js.map → component-BD3FCIT8.js.map} +1 -1
  10. package/build/{component-DjIZRLtN.js → component-BybwN9H4.js} +2 -2
  11. package/build/{component-DjIZRLtN.js.map → component-BybwN9H4.js.map} +1 -1
  12. package/build/{component-BHINcJGw.cjs → component-BzWpboBU.cjs} +2 -2
  13. package/build/{component-BHINcJGw.cjs.map → component-BzWpboBU.cjs.map} +1 -1
  14. package/build/{component-Ud_GRMAS.js → component-C0354Xwu.js} +3 -3
  15. package/build/{component-Ud_GRMAS.js.map → component-C0354Xwu.js.map} +1 -1
  16. package/build/{component-CQmuGUIt.cjs → component-C8ueaiSO.cjs} +2 -2
  17. package/build/{component-CQmuGUIt.cjs.map → component-C8ueaiSO.cjs.map} +1 -1
  18. package/build/{component-COVO0g4K.cjs → component-CANbSEA3.cjs} +2 -2
  19. package/build/{component-COVO0g4K.cjs.map → component-CANbSEA3.cjs.map} +1 -1
  20. package/build/{component-BJxTgP87.js → component-CATlnN8o.js} +2 -2
  21. package/build/{component-BJxTgP87.js.map → component-CATlnN8o.js.map} +1 -1
  22. package/build/{component-CJ_IYmXp.js → component-CGPZf0Mx.js} +2 -2
  23. package/build/{component-CJ_IYmXp.js.map → component-CGPZf0Mx.js.map} +1 -1
  24. package/build/{component-BkAJZ9bN.cjs → component-CM4bf3RV.cjs} +2 -2
  25. package/build/{component-BkAJZ9bN.cjs.map → component-CM4bf3RV.cjs.map} +1 -1
  26. package/build/{component-CVODnsK7.js → component-DAocGHCP.js} +2 -2
  27. package/build/{component-CVODnsK7.js.map → component-DAocGHCP.js.map} +1 -1
  28. package/build/{component-CQ4haQho.cjs → component-DHXjnBNp.cjs} +2 -2
  29. package/build/{component-CQ4haQho.cjs.map → component-DHXjnBNp.cjs.map} +1 -1
  30. package/build/{component-BnqGhIYn.js → component-DIA35EVR.js} +2 -2
  31. package/build/{component-BnqGhIYn.js.map → component-DIA35EVR.js.map} +1 -1
  32. package/build/{component-DxjC5ZDY.cjs → component-DIk87lHF.cjs} +2 -2
  33. package/build/{component-DxjC5ZDY.cjs.map → component-DIk87lHF.cjs.map} +1 -1
  34. package/build/{component-Cy1LF62n.js → component-DJDXAzlq.js} +3 -3
  35. package/build/{component-Cy1LF62n.js.map → component-DJDXAzlq.js.map} +1 -1
  36. package/build/{component-B0KY9CML.cjs → component-DNVmU44U.cjs} +2 -2
  37. package/build/{component-B0KY9CML.cjs.map → component-DNVmU44U.cjs.map} +1 -1
  38. package/build/{component-AtGU3rIh.cjs → component-DbRG0dzX.cjs} +2 -2
  39. package/build/{component-AtGU3rIh.cjs.map → component-DbRG0dzX.cjs.map} +1 -1
  40. package/build/{component-JqUoQ-8S.js → component-DpX5Qw3i.js} +2 -2
  41. package/build/{component-JqUoQ-8S.js.map → component-DpX5Qw3i.js.map} +1 -1
  42. package/build/{component-Ch9eF_4H.js → component-DrTBbu8u.js} +4 -4
  43. package/build/{component-Ch9eF_4H.js.map → component-DrTBbu8u.js.map} +1 -1
  44. package/build/{component-BI6fe9pl.js → component-Duwta9MT.js} +2 -2
  45. package/build/{component-BI6fe9pl.js.map → component-Duwta9MT.js.map} +1 -1
  46. package/build/{component-DAtaP1gP.cjs → component-DwVvs3yX.cjs} +2 -2
  47. package/build/{component-DAtaP1gP.cjs.map → component-DwVvs3yX.cjs.map} +1 -1
  48. package/build/component-accordion.cjs.js +1 -1
  49. package/build/component-accordion.es.js +2 -2
  50. package/build/component-button-group.cjs.js +1 -1
  51. package/build/component-button-group.es.js +2 -2
  52. package/build/component-button.cjs.js +1 -1
  53. package/build/component-button.es.js +1 -1
  54. package/build/component-checkbox-group.cjs.js +1 -1
  55. package/build/component-checkbox-group.es.js +2 -2
  56. package/build/component-checkbox.cjs.js +1 -1
  57. package/build/component-checkbox.es.js +2 -2
  58. package/build/component-date-picker.cjs.js +1 -1
  59. package/build/component-date-picker.d.ts +1 -0
  60. package/build/component-date-picker.es.js +2 -2
  61. package/build/component-icon.cjs.js +1 -1
  62. package/build/component-icon.es.js +1 -1
  63. package/build/component-image-button.cjs.js +1 -1
  64. package/build/component-image-button.es.js +1 -1
  65. package/build/component-image-select.cjs.js +1 -1
  66. package/build/component-image-select.es.js +2 -2
  67. package/build/component-image-slider.cjs.js +1 -1
  68. package/build/component-image-slider.es.js +2 -2
  69. package/build/component-image.cjs.js +1 -1
  70. package/build/component-image.es.js +2 -2
  71. package/build/component-input-otp.cjs.js +1 -1
  72. package/build/component-input-otp.es.js +2 -2
  73. package/build/component-input.cjs.js +1 -1
  74. package/build/component-input.es.js +2 -2
  75. package/build/component-map.cjs.js +1 -1
  76. package/build/component-map.es.js +2 -2
  77. package/build/component-pagination.cjs.js +1 -1
  78. package/build/component-pagination.es.js +1 -1
  79. package/build/component-range.cjs.js +1 -1
  80. package/build/component-range.es.js +2 -2
  81. package/build/component-select.cjs.js +1 -1
  82. package/build/component-select.d.ts +1 -0
  83. package/build/component-select.es.js +1 -1
  84. package/build/{component-D5Bg68Aq.cjs → component-skAuX4C8.cjs} +2 -2
  85. package/build/{component-D5Bg68Aq.cjs.map → component-skAuX4C8.cjs.map} +1 -1
  86. package/build/component-textarea.cjs.js +1 -1
  87. package/build/component-textarea.d.ts +3 -0
  88. package/build/component-textarea.es.js +1 -1
  89. package/build/component-toggle.cjs.js +1 -1
  90. package/build/component-toggle.es.js +2 -2
  91. package/build/component-tooltip.cjs.js +1 -1
  92. package/build/component-tooltip.d.ts +107 -0
  93. package/build/component-tooltip.es.js +1 -1
  94. package/build/component-typography.cjs.js +1 -1
  95. package/build/component-typography.d.ts +107 -0
  96. package/build/component-typography.es.js +1 -1
  97. package/build/{component.components-BJ1nh728.js → component.components-83DbC_hw.js} +2 -2
  98. package/build/{component.components-BJ1nh728.js.map → component.components-83DbC_hw.js.map} +1 -1
  99. package/build/{component.components-0OAiJjsR.cjs → component.components-BjdoMO5R.cjs} +2 -2
  100. package/build/{component.components-0OAiJjsR.cjs.map → component.components-BjdoMO5R.cjs.map} +1 -1
  101. package/build/{component.constants-ASMqRXmH.js → component.constants-Be7PPP03.js} +2 -2
  102. package/build/{component.constants-ASMqRXmH.js.map → component.constants-Be7PPP03.js.map} +1 -1
  103. package/build/{component.constants-DLrolRBs.cjs → component.constants-BgV35uxo.cjs} +2 -2
  104. package/build/{component.constants-DLrolRBs.cjs.map → component.constants-BgV35uxo.cjs.map} +1 -1
  105. package/build/{component.constants-B1XT0pqP.cjs → component.constants-C4Du7oRP.cjs} +2 -2
  106. package/build/{component.constants-B1XT0pqP.cjs.map → component.constants-C4Du7oRP.cjs.map} +1 -1
  107. package/build/{component.constants-4Zuzymaj.js → component.constants-DbWj5l8e.js} +3 -3
  108. package/build/{component.constants-4Zuzymaj.js.map → component.constants-DbWj5l8e.js.map} +1 -1
  109. package/build/{component.types-BXYLxQWv.js → component.types-B3IQzYHq.js} +2 -2
  110. package/build/{component.types-BXYLxQWv.js.map → component.types-B3IQzYHq.js.map} +1 -1
  111. package/build/{component.types-haccSZSq.cjs → component.types-C6Zrax1A.cjs} +2 -2
  112. package/build/{component.types-haccSZSq.cjs.map → component.types-C6Zrax1A.cjs.map} +1 -1
  113. package/build/consts.cjs.js +1 -1
  114. package/build/consts.es.js +1 -1
  115. package/build/context-app.cjs.js +1 -1
  116. package/build/context-app.es.js +2 -2
  117. package/build/context-sonner.cjs.js +1 -1
  118. package/build/context-sonner.es.js +2 -2
  119. package/build/{context.constants-p2bRkgM3.cjs → context.constants-BMJ3rLa_.cjs} +259 -258
  120. package/build/context.constants-BMJ3rLa_.cjs.map +1 -0
  121. package/build/{context.constants-Dop398a2.js → context.constants-YlWOZAd7.js} +120 -12
  122. package/build/context.constants-YlWOZAd7.js.map +1 -0
  123. package/build/{context.hooks-Spdhsa4j.cjs → context.hooks-B1QdI16d.cjs} +2 -2
  124. package/build/{context.hooks-Spdhsa4j.cjs.map → context.hooks-B1QdI16d.cjs.map} +1 -1
  125. package/build/{context.hooks-b1w6_aK9.js → context.hooks-Bl4gTFVP.js} +2 -2
  126. package/build/{context.hooks-b1w6_aK9.js.map → context.hooks-Bl4gTFVP.js.map} +1 -1
  127. package/build/{context.hooks-CUlqrzfP.js → context.hooks-CnqRriMa.js} +2 -2
  128. package/build/{context.hooks-CUlqrzfP.js.map → context.hooks-CnqRriMa.js.map} +1 -1
  129. package/build/{context.hooks-BFjFm8iR.cjs → context.hooks-D23gzlbO.cjs} +2 -2
  130. package/build/{context.hooks-BFjFm8iR.cjs.map → context.hooks-D23gzlbO.cjs.map} +1 -1
  131. package/build/index.cjs.js +1 -1
  132. package/build/index.d.ts +111 -0
  133. package/build/index.es.js +18 -18
  134. package/build/style-error.cjs.js +1 -1
  135. package/build/style-error.es.js +1 -1
  136. package/build/style-theme.cjs.js +1 -1
  137. package/build/style-theme.es.js +1 -1
  138. package/build/{use-CHyIgo-M.cjs → use-DZU4NdpU.cjs} +2 -2
  139. package/build/{use-CHyIgo-M.cjs.map → use-DZU4NdpU.cjs.map} +1 -1
  140. package/build/{use-DLn-Y7_0.js → use-JWHe9gP5.js} +3 -3
  141. package/build/{use-DLn-Y7_0.js.map → use-JWHe9gP5.js.map} +1 -1
  142. package/package.json +2 -2
  143. package/build/context.constants-Dop398a2.js.map +0 -1
  144. package/build/context.constants-p2bRkgM3.cjs.map +0 -1
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./area.hooks-C_UKZzcb.cjs"),r=require("./context.constants-p2bRkgM3.cjs");exports.useRemovePreviewLoader=e.useRemovePreviewLoader,exports.Preview=r.Preview;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./area.hooks-C_UKZzcb.cjs"),r=require("./context.constants-BMJ3rLa_.cjs");exports.useRemovePreviewLoader=e.useRemovePreviewLoader,exports.Preview=r.Preview;
2
2
  //# sourceMappingURL=area-preview.cjs.js.map
@@ -1,5 +1,5 @@
1
1
  import { u } from "./area.hooks-Bk04M7mk.js";
2
- import { P } from "./context.constants-Dop398a2.js";
2
+ import { P } from "./context.constants-YlWOZAd7.js";
3
3
  export {
4
4
  P as Preview,
5
5
  u as useRemovePreviewLoader
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./context.constants-p2bRkgM3.cjs");exports.Skeleton=e.Skeleton,exports.StyledSkeleton=e.StyledSkeleton;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./context.constants-BMJ3rLa_.cjs");exports.Skeleton=e.Skeleton,exports.StyledSkeleton=e.StyledSkeleton;
2
2
  //# sourceMappingURL=area-skeleton.cjs.js.map
@@ -1,4 +1,4 @@
1
- import { a, S } from "./context.constants-Dop398a2.js";
1
+ import { a, S } from "./context.constants-YlWOZAd7.js";
2
2
  export {
3
3
  a as Skeleton,
4
4
  S as StyledSkeleton
@@ -1,3 +1,3 @@
1
- version: 1.3.30
2
- commit: a521f7c
3
- date: 2025-09-26T16:50:03Z
1
+ version: 1.3.32
2
+ commit: 1724f42
3
+ date: 2025-10-08T15:19:11Z
@@ -1,2 +1,2 @@
1
- "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),i=require("./context.constants-p2bRkgM3.cjs"),s=require("react");exports.Toggle=a=>{const n=s.useMemo(()=>({tap:{width:i.KEY_SIZE_DATA_TOGGLE[a.size].thumb+4,translateX:a.value?i.KEY_SIZE_DATA_TOGGLE[a.size].width-i.KEY_SIZE_DATA_TOGGLE[a.size].thumb-3*i.KEY_SIZE_DATA_TOGGLE[a.size].padding-4:0,transition:{duration:.05}},checked:{translateX:i.KEY_SIZE_DATA_TOGGLE[a.size].width-i.KEY_SIZE_DATA_TOGGLE[a.size].thumb-3*i.KEY_SIZE_DATA_TOGGLE[a.size].padding,transition:{ease:"circInOut",duration:.05}},unchecked:{translateX:0,transition:{ease:"circInOut",duration:.05}}}),[a.size,a.value]);return e.jsxRuntimeExports.jsx(i.ToggleWrapper,{$genre:a.genre,$isDisabled:a.isDisabled,$isDisabledOutline:a.isDisabled??a.isDisabledOutline,$isOutlineBoxShadow:a.isOutlineBoxShadow,$isReadOnly:a.isReadOnly,$value:a.value,$size:a.size,$error:a.error,tabIndex:0,onClick:()=>{var e;return null==(e=a.onChange)?void 0:e.call(a,!a.value)},whileTap:"tap",animate:a.value?"checked":"unchecked",onKeyDown:e=>{var i;"Enter"===e.key&&(null==(i=a.onChange)||i.call(a,!a.value))},children:e.jsxRuntimeExports.jsx(i.ToggleCenter,{variants:n,$genre:a.genre,$isDisabled:a.isDisabled,$value:a.value,$size:a.size,$error:a.error})})};
2
- //# sourceMappingURL=component-qRPasLxk.cjs.map
1
+ "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),i=require("./context.constants-BMJ3rLa_.cjs"),s=require("react");exports.Toggle=a=>{const n=s.useMemo(()=>({tap:{width:i.KEY_SIZE_DATA_TOGGLE[a.size].thumb+4,translateX:a.value?i.KEY_SIZE_DATA_TOGGLE[a.size].width-i.KEY_SIZE_DATA_TOGGLE[a.size].thumb-3*i.KEY_SIZE_DATA_TOGGLE[a.size].padding-4:0,transition:{duration:.05}},checked:{translateX:i.KEY_SIZE_DATA_TOGGLE[a.size].width-i.KEY_SIZE_DATA_TOGGLE[a.size].thumb-3*i.KEY_SIZE_DATA_TOGGLE[a.size].padding,transition:{ease:"circInOut",duration:.05}},unchecked:{translateX:0,transition:{ease:"circInOut",duration:.05}}}),[a.size,a.value]);return e.jsxRuntimeExports.jsx(i.ToggleWrapper,{$genre:a.genre,$isDisabled:a.isDisabled,$isDisabledOutline:a.isDisabled??a.isDisabledOutline,$isOutlineBoxShadow:a.isOutlineBoxShadow,$isReadOnly:a.isReadOnly,$value:a.value,$size:a.size,$error:a.error,tabIndex:0,onClick:()=>{var e;return null==(e=a.onChange)?void 0:e.call(a,!a.value)},whileTap:"tap",animate:a.value?"checked":"unchecked",onKeyDown:e=>{var i;"Enter"===e.key&&(null==(i=a.onChange)||i.call(a,!a.value))},children:e.jsxRuntimeExports.jsx(i.ToggleCenter,{variants:n,$genre:a.genre,$isDisabled:a.isDisabled,$value:a.value,$size:a.size,$error:a.error})})};
2
+ //# sourceMappingURL=component-B8kWtTfs.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-qRPasLxk.cjs","sources":["../src/components/toggle/component.tsx"],"sourcesContent":["import { KEY_SIZE_DATA_TOGGLE } from '@local/theme';\n\nimport { useMemo } from 'react';\n\nimport { ToggleCenter, ToggleProps, ToggleWrapper } from '.';\n\nexport const Toggle = (props: ToggleProps) => {\n const toggleVariants = useMemo(\n () => ({\n tap: {\n width: KEY_SIZE_DATA_TOGGLE[props.size].thumb + 4,\n translateX: props.value\n ? KEY_SIZE_DATA_TOGGLE[props.size].width -\n KEY_SIZE_DATA_TOGGLE[props.size].thumb -\n KEY_SIZE_DATA_TOGGLE[props.size].padding * 3 -\n 4\n : 0,\n transition: {\n duration: 0.05,\n },\n },\n checked: {\n translateX:\n KEY_SIZE_DATA_TOGGLE[props.size].width -\n KEY_SIZE_DATA_TOGGLE[props.size].thumb -\n KEY_SIZE_DATA_TOGGLE[props.size].padding * 3,\n transition: { ease: 'circInOut', duration: 0.05 },\n },\n unchecked: {\n translateX: 0,\n transition: { ease: 'circInOut', duration: 0.05 },\n },\n }),\n [props.size, props.value],\n );\n\n return (\n <ToggleWrapper\n $genre={props.genre}\n $isDisabled={props.isDisabled}\n $isDisabledOutline={props.isDisabled ?? props.isDisabledOutline}\n $isOutlineBoxShadow={props.isOutlineBoxShadow}\n $isReadOnly={props.isReadOnly}\n $value={props.value}\n $size={props.size}\n $error={props.error}\n tabIndex={0}\n onClick={() => props.onChange?.(!props.value)}\n whileTap='tap'\n animate={props.value ? 'checked' : 'unchecked'}\n onKeyDown={(e) => {\n if (e.key === 'Enter') props.onChange?.(!props.value);\n }}\n >\n <ToggleCenter\n variants={toggleVariants}\n $genre={props.genre}\n $isDisabled={props.isDisabled}\n $value={props.value}\n $size={props.size}\n $error={props.error}\n />\n </ToggleWrapper>\n );\n};\n"],"names":["props","toggleVariants","useMemo","tap","width","KEY_SIZE_DATA_TOGGLE","size","thumb","translateX","value","padding","transition","duration","checked","ease","unchecked","jsx","ToggleWrapper","$genre","genre","$isDisabled","isDisabled","$isDisabledOutline","isDisabledOutline","$isOutlineBoxShadow","isOutlineBoxShadow","$isReadOnly","isReadOnly","$value","$size","$error","error","tabIndex","onClick","_a","onChange","call","whileTap","animate","onKeyDown","e","key","children","ToggleCenter","variants"],"mappings":"2IAMuBA,IACrB,MAAMC,EAAiBC,EAAAA,QACrB,KAAA,CACEC,IAAK,CACHC,MAAOC,EAAAA,qBAAqBL,EAAMM,MAAMC,MAAQ,EAChDC,WAAYR,EAAMS,MACdJ,EAAAA,qBAAqBL,EAAMM,MAAMF,MACjCC,uBAAqBL,EAAMM,MAAMC,MACU,EAA3CF,EAAAA,qBAAqBL,EAAMM,MAAMI,QACjC,EACA,EACJC,WAAY,CACVC,SAAU,MAGdC,QAAS,CACPL,WACEH,EAAAA,qBAAqBL,EAAMM,MAAMF,MACjCC,EAAAA,qBAAqBL,EAAMM,MAAMC,MACU,EAA3CF,EAAAA,qBAAqBL,EAAMM,MAAMI,QACnCC,WAAY,CAAEG,KAAM,YAAaF,SAAU,MAE7CG,UAAW,CACTP,WAAY,EACZG,WAAY,CAAEG,KAAM,YAAaF,SAAU,QAG/C,CAACZ,EAAMM,KAAMN,EAAMS,QAGrB,SACEO,kBAAAA,IAACC,EAAAA,cAAA,CACCC,OAAQlB,EAAMmB,MACdC,YAAapB,EAAMqB,WACnBC,mBAAoBtB,EAAMqB,YAAcrB,EAAMuB,kBAC9CC,oBAAqBxB,EAAMyB,mBAC3BC,YAAa1B,EAAM2B,WACnBC,OAAQ5B,EAAMS,MACdoB,MAAO7B,EAAMM,KACbwB,OAAQ9B,EAAM+B,MACdC,SAAU,EACVC,QAAS,WAAM,OAAA,OAAAC,EAAAlC,EAAMmC,eAAN,EAAAD,EAAAE,KAAApC,GAAkBA,EAAMS,QACvC4B,SAAS,MACTC,QAAStC,EAAMS,MAAQ,UAAY,YACnC8B,UAAYC,UACI,UAAVA,EAAEC,iBAAuBN,qBAAYnC,EAAMS,SAGjDiC,WAAA1B,kBAAAA,IAAC2B,EAAAA,aAAA,CACCC,SAAU3C,EACViB,OAAQlB,EAAMmB,MACdC,YAAapB,EAAMqB,WACnBO,OAAQ5B,EAAMS,MACdoB,MAAO7B,EAAMM,KACbwB,OAAQ9B,EAAM+B"}
1
+ {"version":3,"file":"component-B8kWtTfs.cjs","sources":["../src/components/toggle/component.tsx"],"sourcesContent":["import { KEY_SIZE_DATA_TOGGLE } from '@local/theme';\n\nimport { useMemo } from 'react';\n\nimport { ToggleCenter, ToggleProps, ToggleWrapper } from '.';\n\nexport const Toggle = (props: ToggleProps) => {\n const toggleVariants = useMemo(\n () => ({\n tap: {\n width: KEY_SIZE_DATA_TOGGLE[props.size].thumb + 4,\n translateX: props.value\n ? KEY_SIZE_DATA_TOGGLE[props.size].width -\n KEY_SIZE_DATA_TOGGLE[props.size].thumb -\n KEY_SIZE_DATA_TOGGLE[props.size].padding * 3 -\n 4\n : 0,\n transition: {\n duration: 0.05,\n },\n },\n checked: {\n translateX:\n KEY_SIZE_DATA_TOGGLE[props.size].width -\n KEY_SIZE_DATA_TOGGLE[props.size].thumb -\n KEY_SIZE_DATA_TOGGLE[props.size].padding * 3,\n transition: { ease: 'circInOut', duration: 0.05 },\n },\n unchecked: {\n translateX: 0,\n transition: { ease: 'circInOut', duration: 0.05 },\n },\n }),\n [props.size, props.value],\n );\n\n return (\n <ToggleWrapper\n $genre={props.genre}\n $isDisabled={props.isDisabled}\n $isDisabledOutline={props.isDisabled ?? props.isDisabledOutline}\n $isOutlineBoxShadow={props.isOutlineBoxShadow}\n $isReadOnly={props.isReadOnly}\n $value={props.value}\n $size={props.size}\n $error={props.error}\n tabIndex={0}\n onClick={() => props.onChange?.(!props.value)}\n whileTap='tap'\n animate={props.value ? 'checked' : 'unchecked'}\n onKeyDown={(e) => {\n if (e.key === 'Enter') props.onChange?.(!props.value);\n }}\n >\n <ToggleCenter\n variants={toggleVariants}\n $genre={props.genre}\n $isDisabled={props.isDisabled}\n $value={props.value}\n $size={props.size}\n $error={props.error}\n />\n </ToggleWrapper>\n );\n};\n"],"names":["props","toggleVariants","useMemo","tap","width","KEY_SIZE_DATA_TOGGLE","size","thumb","translateX","value","padding","transition","duration","checked","ease","unchecked","jsx","ToggleWrapper","$genre","genre","$isDisabled","isDisabled","$isDisabledOutline","isDisabledOutline","$isOutlineBoxShadow","isOutlineBoxShadow","$isReadOnly","isReadOnly","$value","$size","$error","error","tabIndex","onClick","_a","onChange","call","whileTap","animate","onKeyDown","e","key","children","ToggleCenter","variants"],"mappings":"2IAMuBA,IACrB,MAAMC,EAAiBC,EAAAA,QACrB,KAAA,CACEC,IAAK,CACHC,MAAOC,EAAAA,qBAAqBL,EAAMM,MAAMC,MAAQ,EAChDC,WAAYR,EAAMS,MACdJ,EAAAA,qBAAqBL,EAAMM,MAAMF,MACjCC,uBAAqBL,EAAMM,MAAMC,MACU,EAA3CF,EAAAA,qBAAqBL,EAAMM,MAAMI,QACjC,EACA,EACJC,WAAY,CACVC,SAAU,MAGdC,QAAS,CACPL,WACEH,EAAAA,qBAAqBL,EAAMM,MAAMF,MACjCC,EAAAA,qBAAqBL,EAAMM,MAAMC,MACU,EAA3CF,EAAAA,qBAAqBL,EAAMM,MAAMI,QACnCC,WAAY,CAAEG,KAAM,YAAaF,SAAU,MAE7CG,UAAW,CACTP,WAAY,EACZG,WAAY,CAAEG,KAAM,YAAaF,SAAU,QAG/C,CAACZ,EAAMM,KAAMN,EAAMS,QAGrB,SACEO,kBAAAA,IAACC,EAAAA,cAAA,CACCC,OAAQlB,EAAMmB,MACdC,YAAapB,EAAMqB,WACnBC,mBAAoBtB,EAAMqB,YAAcrB,EAAMuB,kBAC9CC,oBAAqBxB,EAAMyB,mBAC3BC,YAAa1B,EAAM2B,WACnBC,OAAQ5B,EAAMS,MACdoB,MAAO7B,EAAMM,KACbwB,OAAQ9B,EAAM+B,MACdC,SAAU,EACVC,QAAS,WAAM,OAAA,OAAAC,EAAAlC,EAAMmC,eAAN,EAAAD,EAAAE,KAAApC,GAAkBA,EAAMS,QACvC4B,SAAS,MACTC,QAAStC,EAAMS,MAAQ,UAAY,YACnC8B,UAAYC,UACI,UAAVA,EAAEC,iBAAuBN,qBAAYnC,EAAMS,SAGjDiC,WAAA1B,kBAAAA,IAAC2B,EAAAA,aAAA,CACCC,SAAU3C,EACViB,OAAQlB,EAAMmB,MACdC,YAAapB,EAAMqB,WACnBO,OAAQ5B,EAAMS,MACdoB,MAAO7B,EAAMM,KACbwB,OAAQ9B,EAAM+B"}
@@ -1,7 +1,7 @@
1
1
  import { j as jsxRuntimeExports } from "./jsx-runtime-BrDlu8eK.js";
2
- import { ac as InputOTPWrapper, br as ErrorMessage } from "./context.constants-Dop398a2.js";
2
+ import { ac as InputOTPWrapper, br as ErrorMessage } from "./context.constants-YlWOZAd7.js";
3
3
  import { useState, useRef, useCallback } from "react";
4
- import { I as Input } from "./component-CVODnsK7.js";
4
+ import { I as Input } from "./component-DAocGHCP.js";
5
5
  const InputOTP = (props) => {
6
6
  var _a;
7
7
  const [otp, setOtp] = useState(new Array(props.length).fill(""));
@@ -167,4 +167,4 @@ const InputOTP = (props) => {
167
167
  export {
168
168
  InputOTP as I
169
169
  };
170
- //# sourceMappingURL=component-DXZrlFCa.js.map
170
+ //# sourceMappingURL=component-BD3FCIT8.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-DXZrlFCa.js","sources":["../src/components/input-otp/component.tsx"],"sourcesContent":["import { ErrorMessage } from '@local/styles/error';\n\nimport { ClipboardEvent, FocusEvent, KeyboardEvent, useCallback, useRef, useState } from 'react';\n\nimport { Input } from '../input';\nimport { InputOTPProps, InputOTPWrapper } from '.';\n\nexport const InputOTP = (props: InputOTPProps) => {\n const [otp, setOtp] = useState<string[]>(new Array(props.length).fill(''));\n const inputsRef = useRef<(HTMLInputElement | null)[]>([]);\n const wrapperRef = useRef<HTMLDivElement | null>(null);\n\n const handlePaste = useCallback(\n (index: number, e: ClipboardEvent<HTMLInputElement>) => {\n e.preventDefault();\n\n const pasteData = e.clipboardData.getData('Text');\n const digits = pasteData.replace(/\\D/g, '').split('');\n\n if (!digits.length) return;\n\n setOtp((prevOtp) => {\n const newOtp = [...prevOtp];\n let currentIndex = index;\n\n for (let i = 0; i < digits.length && currentIndex < newOtp.length; i++) {\n newOtp[currentIndex] = digits[i];\n currentIndex++;\n }\n\n const joined = newOtp.join('');\n\n props.onChange?.(joined);\n\n if (newOtp.every((char) => char !== '')) {\n props.onComplete?.(joined);\n }\n\n setTimeout(() => {\n const firstEmpty = newOtp.findIndex((char) => char === '');\n if (firstEmpty !== -1) {\n inputsRef.current[firstEmpty]?.focus();\n } else if (currentIndex < newOtp.length) {\n inputsRef.current[currentIndex]?.focus();\n }\n }, 0);\n\n return newOtp;\n });\n },\n [props],\n );\n\n const handleChange = useCallback(\n (index: number, value: string) => {\n if (!/^\\d*$/.test(value)) return;\n\n setOtp((prevOtp) => {\n const newOtp = [...prevOtp];\n newOtp[index] = value.slice(-1);\n\n if (props.onChange) {\n props.onChange(newOtp.join(''));\n }\n\n if (newOtp.every((char) => char !== '')) {\n props.onComplete?.(newOtp.join(''));\n }\n\n if (value && index < prevOtp.length - 1) {\n setTimeout(() => {\n inputsRef.current[index + 1]?.focus();\n }, 0);\n }\n\n return newOtp;\n });\n },\n [props],\n );\n\n const handleKeyDown = (index: number, e: KeyboardEvent<HTMLInputElement>) => {\n const input = inputsRef.current[index];\n\n if (!input) return;\n\n if (e.key === 'ArrowRight') {\n const nextIndex = index < otp.length - 1 ? index + 1 : 0;\n const nextInput = inputsRef.current[nextIndex];\n\n if (nextInput) {\n nextInput.focus();\n setTimeout(() => nextInput.setSelectionRange(0, nextInput.value.length), 0);\n }\n }\n\n if (e.key === 'ArrowLeft') {\n const prevIndex = index > 0 ? index - 1 : otp.length - 1;\n const prevInput = inputsRef.current[prevIndex];\n\n if (prevInput) {\n prevInput.focus();\n setTimeout(() => prevInput.setSelectionRange(0, prevInput.value.length), 0);\n }\n }\n\n if (e.key === 'Backspace') {\n if (input.value) {\n setTimeout(() => input.setSelectionRange(0, input.value.length), 0);\n } else if (index > 0) {\n setTimeout(() => {\n const prevInput = inputsRef.current[index - 1];\n if (prevInput) {\n prevInput.focus();\n prevInput.setSelectionRange(0, prevInput.value.length);\n }\n }, 0);\n }\n }\n };\n\n const handleFocusInput = useCallback((e: FocusEvent<HTMLInputElement>) => {\n setTimeout(() => e.target.setSelectionRange(0, e.target.value.length), 0);\n }, []);\n return (\n <>\n <InputOTPWrapper\n $error={props.error}\n $size={props.size}\n id={props.id}\n ref={wrapperRef}\n onBlur={(e) => {\n setTimeout(() => {\n if (wrapperRef.current && !wrapperRef.current.contains(document.activeElement)) {\n props.onBlur?.(e);\n }\n }, 0);\n }}\n onFocus={(e) => {\n setTimeout(() => {\n if (wrapperRef.current?.contains(document.activeElement)) {\n props.onFocus?.(e);\n }\n }, 0);\n }}\n $sx={props.sx}\n >\n {otp.map((digit, index) => (\n <Input\n isWidthAsHeight\n key={index}\n tabIndex={index + 1}\n ref={(el) => {\n inputsRef.current[index] = el;\n }}\n variety='standard'\n type='text'\n inputMode='numeric'\n maxLength={1}\n value={digit}\n onFocus={handleFocusInput}\n onPaste={(e) => handlePaste(index, e)}\n onChange={(value) => handleChange(index, value)}\n onKeyDown={(e) => handleKeyDown(index, e)}\n genre={props.genre}\n size={props.size}\n font={props.font}\n />\n ))}\n </InputOTPWrapper>\n {props?.error ? (\n <ErrorMessage\n {...props.error}\n size={props?.error.size ?? props.size}\n font={{\n size: 12,\n weight: 400,\n family: props.font?.family,\n }}\n />\n ) : null}\n </>\n );\n};\n"],"names":["_a","_b","jsxs","Fragment","jsx"],"mappings":"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"}
1
+ {"version":3,"file":"component-BD3FCIT8.js","sources":["../src/components/input-otp/component.tsx"],"sourcesContent":["import { ErrorMessage } from '@local/styles/error';\n\nimport { ClipboardEvent, FocusEvent, KeyboardEvent, useCallback, useRef, useState } from 'react';\n\nimport { Input } from '../input';\nimport { InputOTPProps, InputOTPWrapper } from '.';\n\nexport const InputOTP = (props: InputOTPProps) => {\n const [otp, setOtp] = useState<string[]>(new Array(props.length).fill(''));\n const inputsRef = useRef<(HTMLInputElement | null)[]>([]);\n const wrapperRef = useRef<HTMLDivElement | null>(null);\n\n const handlePaste = useCallback(\n (index: number, e: ClipboardEvent<HTMLInputElement>) => {\n e.preventDefault();\n\n const pasteData = e.clipboardData.getData('Text');\n const digits = pasteData.replace(/\\D/g, '').split('');\n\n if (!digits.length) return;\n\n setOtp((prevOtp) => {\n const newOtp = [...prevOtp];\n let currentIndex = index;\n\n for (let i = 0; i < digits.length && currentIndex < newOtp.length; i++) {\n newOtp[currentIndex] = digits[i];\n currentIndex++;\n }\n\n const joined = newOtp.join('');\n\n props.onChange?.(joined);\n\n if (newOtp.every((char) => char !== '')) {\n props.onComplete?.(joined);\n }\n\n setTimeout(() => {\n const firstEmpty = newOtp.findIndex((char) => char === '');\n if (firstEmpty !== -1) {\n inputsRef.current[firstEmpty]?.focus();\n } else if (currentIndex < newOtp.length) {\n inputsRef.current[currentIndex]?.focus();\n }\n }, 0);\n\n return newOtp;\n });\n },\n [props],\n );\n\n const handleChange = useCallback(\n (index: number, value: string) => {\n if (!/^\\d*$/.test(value)) return;\n\n setOtp((prevOtp) => {\n const newOtp = [...prevOtp];\n newOtp[index] = value.slice(-1);\n\n if (props.onChange) {\n props.onChange(newOtp.join(''));\n }\n\n if (newOtp.every((char) => char !== '')) {\n props.onComplete?.(newOtp.join(''));\n }\n\n if (value && index < prevOtp.length - 1) {\n setTimeout(() => {\n inputsRef.current[index + 1]?.focus();\n }, 0);\n }\n\n return newOtp;\n });\n },\n [props],\n );\n\n const handleKeyDown = (index: number, e: KeyboardEvent<HTMLInputElement>) => {\n const input = inputsRef.current[index];\n\n if (!input) return;\n\n if (e.key === 'ArrowRight') {\n const nextIndex = index < otp.length - 1 ? index + 1 : 0;\n const nextInput = inputsRef.current[nextIndex];\n\n if (nextInput) {\n nextInput.focus();\n setTimeout(() => nextInput.setSelectionRange(0, nextInput.value.length), 0);\n }\n }\n\n if (e.key === 'ArrowLeft') {\n const prevIndex = index > 0 ? index - 1 : otp.length - 1;\n const prevInput = inputsRef.current[prevIndex];\n\n if (prevInput) {\n prevInput.focus();\n setTimeout(() => prevInput.setSelectionRange(0, prevInput.value.length), 0);\n }\n }\n\n if (e.key === 'Backspace') {\n if (input.value) {\n setTimeout(() => input.setSelectionRange(0, input.value.length), 0);\n } else if (index > 0) {\n setTimeout(() => {\n const prevInput = inputsRef.current[index - 1];\n if (prevInput) {\n prevInput.focus();\n prevInput.setSelectionRange(0, prevInput.value.length);\n }\n }, 0);\n }\n }\n };\n\n const handleFocusInput = useCallback((e: FocusEvent<HTMLInputElement>) => {\n setTimeout(() => e.target.setSelectionRange(0, e.target.value.length), 0);\n }, []);\n return (\n <>\n <InputOTPWrapper\n $error={props.error}\n $size={props.size}\n id={props.id}\n ref={wrapperRef}\n onBlur={(e) => {\n setTimeout(() => {\n if (wrapperRef.current && !wrapperRef.current.contains(document.activeElement)) {\n props.onBlur?.(e);\n }\n }, 0);\n }}\n onFocus={(e) => {\n setTimeout(() => {\n if (wrapperRef.current?.contains(document.activeElement)) {\n props.onFocus?.(e);\n }\n }, 0);\n }}\n $sx={props.sx}\n >\n {otp.map((digit, index) => (\n <Input\n isWidthAsHeight\n key={index}\n tabIndex={index + 1}\n ref={(el) => {\n inputsRef.current[index] = el;\n }}\n variety='standard'\n type='text'\n inputMode='numeric'\n maxLength={1}\n value={digit}\n onFocus={handleFocusInput}\n onPaste={(e) => handlePaste(index, e)}\n onChange={(value) => handleChange(index, value)}\n onKeyDown={(e) => handleKeyDown(index, e)}\n genre={props.genre}\n size={props.size}\n font={props.font}\n />\n ))}\n </InputOTPWrapper>\n {props?.error ? (\n <ErrorMessage\n {...props.error}\n size={props?.error.size ?? props.size}\n font={{\n size: 12,\n weight: 400,\n family: props.font?.family,\n }}\n />\n ) : null}\n </>\n );\n};\n"],"names":["_a","_b","jsxs","Fragment","jsx"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import { j as jsxRuntimeExports } from "./jsx-runtime-BrDlu8eK.js";
2
- import { a as Skeleton, O as ImageIMG } from "./context.constants-Dop398a2.js";
2
+ import { a as Skeleton, O as ImageIMG } from "./context.constants-YlWOZAd7.js";
3
3
  import { b as Stack } from "./component-DEZX8aBs.js";
4
4
  import { useState, useEffect } from "react";
5
5
  import { useTheme } from "styled-components";
@@ -85,4 +85,4 @@ const Image = (props) => {
85
85
  export {
86
86
  Image as I
87
87
  };
88
- //# sourceMappingURL=component-DjIZRLtN.js.map
88
+ //# sourceMappingURL=component-BybwN9H4.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-DjIZRLtN.js","sources":["../src/components/image/component.tsx"],"sourcesContent":["import { Skeleton } from '@local/areas/skeleton';\nimport { Stack } from '@local/components/stack';\n\nimport { FC, useEffect, useState } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { ImageIMG, ImageProps } from '.';\n\nexport const Image: FC<ImageProps> = (props) => {\n const [isPending, setIsPending] = useState(true);\n const [isError, setIsError] = useState(false);\n\n useEffect(() => {\n if (!props.src) return;\n\n const img = new (window.Image as { new (width?: number, height?: number): HTMLImageElement })();\n\n img.onload = () => {\n setIsPending(false);\n setIsError(false);\n };\n\n img.onerror = () => {\n setIsPending(false);\n setIsError(true);\n };\n\n img.src = props.src;\n\n if (img.complete) {\n if (img.naturalWidth > 0) {\n setIsPending(false);\n setIsError(false);\n } else {\n setIsPending(false);\n setIsError(true);\n }\n }\n\n return () => {\n img.onload = null;\n img.onerror = null;\n setIsPending(true);\n setIsError(false);\n };\n }, [props.src]);\n const theme = useTheme();\n const { default: defaultSx, ...rest } = props?.sxStack\n ? typeof props?.sxStack === 'function'\n ? props.sxStack(theme)\n : props.sxStack\n : {};\n\n return (\n <Stack\n sx={{\n default: {\n position: 'relative',\n overflow: 'hidden',\n ...(props.isShowBeforeImage\n ? {\n '&::before': {\n width: '100%',\n height: '100%',\n content: '\"\"',\n position: 'absolute',\n inset: 0,\n backgroundImage: `url(${props.src})`,\n backgroundRepeat: 'no-repeat',\n backgroundSize: 'cover',\n backgroundPosition: 'center',\n filter: 'blur(20px)',\n transform: 'scale(1.1)',\n zIndex: 0,\n },\n }\n : {}),\n ...defaultSx,\n },\n ...rest,\n }}\n >\n {!isError ? (\n props.componentLoading || isPending ? (\n <Skeleton\n visible\n sx={{\n default: {\n width: '100%',\n height: '100%',\n },\n }}\n />\n ) : null\n ) : null}\n {!isError && (\n <ImageIMG loading='lazy' $isPending={isPending} src={props.src} alt={props.alt} $sx={props.sxImage} />\n )}\n {isError ? props.componentFallback || null : null}\n </Stack>\n );\n};\n"],"names":["jsxs","jsx"],"mappings":";;;;;AAQO,MAAM,QAAwB,CAAC,UAAU;AAC9C,QAAM,CAAC,WAAW,YAAY,IAAI,SAAS,IAAI;AAC/C,QAAM,CAAC,SAAS,UAAU,IAAI,SAAS,KAAK;AAE5C,YAAU,MAAM;AACd,QAAI,CAAC,MAAM,IAAK;AAEhB,UAAM,MAAM,IAAK,OAAO,MAAA;AAExB,QAAI,SAAS,MAAM;AACjB,mBAAa,KAAK;AAClB,iBAAW,KAAK;AAAA,IAAA;AAGlB,QAAI,UAAU,MAAM;AAClB,mBAAa,KAAK;AAClB,iBAAW,IAAI;AAAA,IAAA;AAGjB,QAAI,MAAM,MAAM;AAEhB,QAAI,IAAI,UAAU;AAChB,UAAI,IAAI,eAAe,GAAG;AACxB,qBAAa,KAAK;AAClB,mBAAW,KAAK;AAAA,MAAA,OACX;AACL,qBAAa,KAAK;AAClB,mBAAW,IAAI;AAAA,MAAA;AAAA,IACjB;AAGF,WAAO,MAAM;AACX,UAAI,SAAS;AACb,UAAI,UAAU;AACd,mBAAa,IAAI;AACjB,iBAAW,KAAK;AAAA,IAAA;AAAA,EAClB,GACC,CAAC,MAAM,GAAG,CAAC;AACd,QAAM,QAAQ,SAAA;AACd,QAAM,EAAE,SAAS,WAAW,GAAG,KAAA,KAAS,+BAAO,WAC3C,QAAO,+BAAO,aAAY,aACxB,MAAM,QAAQ,KAAK,IACnB,MAAM,UACR,CAAA;AAEJ,SACEA,kCAAAA;AAAAA,IAAC;AAAA,IAAA;AAAA,MACC,IAAI;AAAA,QACF,SAAS;AAAA,UACP,UAAU;AAAA,UACV,UAAU;AAAA,UACV,GAAI,MAAM,oBACN;AAAA,YACE,aAAa;AAAA,cACX,OAAO;AAAA,cACP,QAAQ;AAAA,cACR,SAAS;AAAA,cACT,UAAU;AAAA,cACV,OAAO;AAAA,cACP,iBAAiB,OAAO,MAAM,GAAG;AAAA,cACjC,kBAAkB;AAAA,cAClB,gBAAgB;AAAA,cAChB,oBAAoB;AAAA,cACpB,QAAQ;AAAA,cACR,WAAW;AAAA,cACX,QAAQ;AAAA,YAAA;AAAA,UACV,IAEF,CAAA;AAAA,UACJ,GAAG;AAAA,QAAA;AAAA,QAEL,GAAG;AAAA,MAAA;AAAA,MAGJ,UAAA;AAAA,QAAA,CAAC,UACA,MAAM,oBAAoB,YACxBC,kCAAAA;AAAAA,UAAC;AAAA,UAAA;AAAA,YACC,SAAO;AAAA,YACP,IAAI;AAAA,cACF,SAAS;AAAA,gBACP,OAAO;AAAA,gBACP,QAAQ;AAAA,cAAA;AAAA,YACV;AAAA,UACF;AAAA,QAAA,IAEA,OACF;AAAA,QACH,CAAC,WACAA,kCAAAA,IAAC,UAAA,EAAS,SAAQ,QAAO,YAAY,WAAW,KAAK,MAAM,KAAK,KAAK,MAAM,KAAK,KAAK,MAAM,SAAS;AAAA,QAErG,UAAU,MAAM,qBAAqB,OAAO;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGnD;"}
1
+ {"version":3,"file":"component-BybwN9H4.js","sources":["../src/components/image/component.tsx"],"sourcesContent":["import { Skeleton } from '@local/areas/skeleton';\nimport { Stack } from '@local/components/stack';\n\nimport { FC, useEffect, useState } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { ImageIMG, ImageProps } from '.';\n\nexport const Image: FC<ImageProps> = (props) => {\n const [isPending, setIsPending] = useState(true);\n const [isError, setIsError] = useState(false);\n\n useEffect(() => {\n if (!props.src) return;\n\n const img = new (window.Image as { new (width?: number, height?: number): HTMLImageElement })();\n\n img.onload = () => {\n setIsPending(false);\n setIsError(false);\n };\n\n img.onerror = () => {\n setIsPending(false);\n setIsError(true);\n };\n\n img.src = props.src;\n\n if (img.complete) {\n if (img.naturalWidth > 0) {\n setIsPending(false);\n setIsError(false);\n } else {\n setIsPending(false);\n setIsError(true);\n }\n }\n\n return () => {\n img.onload = null;\n img.onerror = null;\n setIsPending(true);\n setIsError(false);\n };\n }, [props.src]);\n const theme = useTheme();\n const { default: defaultSx, ...rest } = props?.sxStack\n ? typeof props?.sxStack === 'function'\n ? props.sxStack(theme)\n : props.sxStack\n : {};\n\n return (\n <Stack\n sx={{\n default: {\n position: 'relative',\n overflow: 'hidden',\n ...(props.isShowBeforeImage\n ? {\n '&::before': {\n width: '100%',\n height: '100%',\n content: '\"\"',\n position: 'absolute',\n inset: 0,\n backgroundImage: `url(${props.src})`,\n backgroundRepeat: 'no-repeat',\n backgroundSize: 'cover',\n backgroundPosition: 'center',\n filter: 'blur(20px)',\n transform: 'scale(1.1)',\n zIndex: 0,\n },\n }\n : {}),\n ...defaultSx,\n },\n ...rest,\n }}\n >\n {!isError ? (\n props.componentLoading || isPending ? (\n <Skeleton\n visible\n sx={{\n default: {\n width: '100%',\n height: '100%',\n },\n }}\n />\n ) : null\n ) : null}\n {!isError && (\n <ImageIMG loading='lazy' $isPending={isPending} src={props.src} alt={props.alt} $sx={props.sxImage} />\n )}\n {isError ? props.componentFallback || null : null}\n </Stack>\n );\n};\n"],"names":["jsxs","jsx"],"mappings":";;;;;AAQO,MAAM,QAAwB,CAAC,UAAU;AAC9C,QAAM,CAAC,WAAW,YAAY,IAAI,SAAS,IAAI;AAC/C,QAAM,CAAC,SAAS,UAAU,IAAI,SAAS,KAAK;AAE5C,YAAU,MAAM;AACd,QAAI,CAAC,MAAM,IAAK;AAEhB,UAAM,MAAM,IAAK,OAAO,MAAA;AAExB,QAAI,SAAS,MAAM;AACjB,mBAAa,KAAK;AAClB,iBAAW,KAAK;AAAA,IAAA;AAGlB,QAAI,UAAU,MAAM;AAClB,mBAAa,KAAK;AAClB,iBAAW,IAAI;AAAA,IAAA;AAGjB,QAAI,MAAM,MAAM;AAEhB,QAAI,IAAI,UAAU;AAChB,UAAI,IAAI,eAAe,GAAG;AACxB,qBAAa,KAAK;AAClB,mBAAW,KAAK;AAAA,MAAA,OACX;AACL,qBAAa,KAAK;AAClB,mBAAW,IAAI;AAAA,MAAA;AAAA,IACjB;AAGF,WAAO,MAAM;AACX,UAAI,SAAS;AACb,UAAI,UAAU;AACd,mBAAa,IAAI;AACjB,iBAAW,KAAK;AAAA,IAAA;AAAA,EAClB,GACC,CAAC,MAAM,GAAG,CAAC;AACd,QAAM,QAAQ,SAAA;AACd,QAAM,EAAE,SAAS,WAAW,GAAG,KAAA,KAAS,+BAAO,WAC3C,QAAO,+BAAO,aAAY,aACxB,MAAM,QAAQ,KAAK,IACnB,MAAM,UACR,CAAA;AAEJ,SACEA,kCAAAA;AAAAA,IAAC;AAAA,IAAA;AAAA,MACC,IAAI;AAAA,QACF,SAAS;AAAA,UACP,UAAU;AAAA,UACV,UAAU;AAAA,UACV,GAAI,MAAM,oBACN;AAAA,YACE,aAAa;AAAA,cACX,OAAO;AAAA,cACP,QAAQ;AAAA,cACR,SAAS;AAAA,cACT,UAAU;AAAA,cACV,OAAO;AAAA,cACP,iBAAiB,OAAO,MAAM,GAAG;AAAA,cACjC,kBAAkB;AAAA,cAClB,gBAAgB;AAAA,cAChB,oBAAoB;AAAA,cACpB,QAAQ;AAAA,cACR,WAAW;AAAA,cACX,QAAQ;AAAA,YAAA;AAAA,UACV,IAEF,CAAA;AAAA,UACJ,GAAG;AAAA,QAAA;AAAA,QAEL,GAAG;AAAA,MAAA;AAAA,MAGJ,UAAA;AAAA,QAAA,CAAC,UACA,MAAM,oBAAoB,YACxBC,kCAAAA;AAAAA,UAAC;AAAA,UAAA;AAAA,YACC,SAAO;AAAA,YACP,IAAI;AAAA,cACF,SAAS;AAAA,gBACP,OAAO;AAAA,gBACP,QAAQ;AAAA,cAAA;AAAA,YACV;AAAA,UACF;AAAA,QAAA,IAEA,OACF;AAAA,QACH,CAAC,WACAA,kCAAAA,IAAC,UAAA,EAAS,SAAQ,QAAO,YAAY,WAAW,KAAK,MAAM,KAAK,KAAK,MAAM,KAAK,KAAK,MAAM,SAAS;AAAA,QAErG,UAAU,MAAM,qBAAqB,OAAO;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGnD;"}
@@ -1,2 +1,2 @@
1
- "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),t=require("./consts.cjs.js"),i=require("./use-CHyIgo-M.cjs"),s=require("./context.constants-p2bRkgM3.cjs"),n=require("./component-AtGU3rIh.cjs"),r=require("./component-5Utdcc2G.cjs"),o=require("styled-components");require("./context.constants-wztrdG5Q.cjs");const a=require("./context.hooks-DDtUqE34.cjs"),l=require("react"),u=require("framer-motion");exports.ImageSelect=d=>{const{onChange:c}=d,g=l.useMemo(()=>s.KEY_SIZE_DATA[d.size],[d.size]),[p,x]=l.useState(d.images||[]),[m,h]=l.useState(!1),j=l.useRef(null),f=o.useTheme(),S=l.useCallback(e=>{e&&x(t=>{const i=e.map((e,i)=>({...e,index:t.length+i})),s=[...t,...i];return null==c||c(s),s})},[c]),b=()=>{var e;null==(e=j.current)||e.click()},{handleAddFiles:v}=i.useImageCrop({onSave:S,locale:d.locale,dialog:{button:{genre:d.propsButton.default.genre,size:d.propsButton.default.size},buttonDelete:{genre:d.propsButton.delete.genre,size:d.propsButton.delete.size}},imageSettings:{maxSize:d.imageSettings.maxSize,maxCount:d.imageSettings.maxCount-p.length,aspect:d.imageSettings.aspect},refInput:j}),{handleAdd:R}=(t=>{const i=l.useMemo(()=>s.KEY_SIZE_DATA[t.size],[t.size]),o=l.useMemo(()=>`${i.radius}px`,[i.radius]),{add:u}=a.useDialog({br:o,propsDialog:{borderRadius:o,padding:"0",background:"whiteStandard"}});return{handleAdd:l.useCallback(i=>{u({content:(o,a)=>e.jsxRuntimeExports.jsxs(r.Stack,{sx:{default:{position:"relative",overflow:"hidden",aspectRatio:2*t.imageSettings.aspect+" / 2",width:"auto",maxWidth:"70dvw",height:"85dvh",borderRadius:null==o?void 0:o.br},tablet:{maxWidth:"95dvw"}},children:[e.jsxRuntimeExports.jsx(n.Image,{sxStack:e=>({default:{width:"100%",height:"100%",alignItems:"center",justifyContent:"center",backgroundColor:e.palette.black10,position:"absolute",pointerEvents:"none"}}),isShowBeforeImage:!0,sxImage:{default:{objectFit:"contain"}},alt:null==i?void 0:i.imageSrc,src:null==i?void 0:i.imageSrc,componentFallback:e.jsxRuntimeExports.jsx(s.Typography,{sx:{default:{variant:"h6"}},children:t.locale.imageFallback})}),e.jsxRuntimeExports.jsx(s.Button,{sx:{default:{position:"absolute",bottom:15,right:15}},genre:"realebail-white",size:"small",icons:[{type:"id",name:"Arrow4"}],isWidthAsHeight:!0,isHiddenBorder:!0,isRadius:!0,onClick:()=>null==a?void 0:a()})]})})},[u,t.imageSettings.aspect,t.locale.imageFallback])}})({size:d.size,locale:d.locale,imageSettings:d.imageSettings,genre:d.genre});return l.useEffect(()=>{x(d.images||[])},[d.images]),e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs(s.ImageSelectWrapper,{$genre:d.genre,$size:d.size,id:d.id,$sx:d.sx,$error:d.error,children:[e.jsxRuntimeExports.jsxs(s.ImageSelectListWrapper,{onDrop:e=>{(e=>{var t;e.preventDefault(),(null==(t=e.dataTransfer.files)?void 0:t.length)&&v(e.dataTransfer.files)})(e),h(!1)},onDragOver:e=>e.preventDefault(),onDragEnter:()=>h(!0),onDragLeave:()=>h(!1),animate:{borderColor:m?f.colors.imageSelect[d.genre].border.hover:f.colors.imageSelect[d.genre].border.rest},transition:{duration:.3},$genre:d.genre,$size:d.size,children:[e.jsxRuntimeExports.jsxs(u.motion.div,{transition:{layout:{duration:.3,ease:"easeInOut",type:"spring"}},layout:!0,style:{display:"flex",flexWrap:"wrap",gap:g.padding-2+"px"},children:[p.map(t=>t.url&&e.jsxRuntimeExports.jsxs(u.motion.div,{style:{position:"relative",width:`${d.imageSettings.width}px`,height:`${d.imageSettings.height}px`,userSelect:"none",overflow:"hidden",borderRadius:`${g.radius}px`,flexGrow:1},layout:!0,transition:{layout:{duration:.3,ease:"easeInOut",type:"spring"}},children:[e.jsxRuntimeExports.jsx(n.Image,{sxStack:e=>({default:{width:"100%",height:"100%",alignItems:"center",justifyContent:"center",backgroundColor:e.palette.black10,position:"absolute",pointerEvents:"none"}}),isShowBeforeImage:d.isContain,sxImage:{default:{objectFit:d.isContain?"contain":"cover"}},alt:t.name||"image",src:t.url,componentFallback:e.jsxRuntimeExports.jsx(s.Typography,{sx:{default:{variant:"h6"}},children:d.locale.imageFallback})}),e.jsxRuntimeExports.jsx(s.Button,{sx:{default:{position:"absolute",top:5,right:5}},genre:d.genre,size:"small",icons:[{type:"id",name:"Close"}],isWidthAsHeight:!0,isHiddenBorder:!0,isRadius:!0,onClick:()=>{return e=t.id,void x(t=>{const i=t.filter(t=>t.id!==e);return null==c||c(i),i});var e}}),e.jsxRuntimeExports.jsx(s.Button,{sx:{default:{position:"absolute",bottom:5,right:5}},genre:d.genre,size:"small",icons:[{type:"id",name:"Activity"}],isWidthAsHeight:!0,isHiddenBorder:!0,isRadius:!0,onClick:()=>t.url&&R({id:t.id,imageSrc:t.url})})]},t.id)),0===p.length?e.jsxRuntimeExports.jsx("div",{onClick:b,style:{position:"relative",width:`${d.imageSettings.width}px`,height:`${d.imageSettings.height}px`,userSelect:"none",overflow:"hidden",borderRadius:`${g.radius}px`,flexGrow:1,display:"flex",alignItems:"center",justifyContent:"center",textAlign:"center",cursor:"pointer"},children:e.jsxRuntimeExports.jsx(s.Typography,{style:{color:f.colors.imageSelect[d.genre].color.rest},sx:{default:{}},children:d.locale.dragAndDrop})},"empty"):null]}),e.jsxRuntimeExports.jsx("input",{ref:j,type:"file",accept:t.LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT,multiple:!0,style:{display:"none"},onChange:e=>{e.target.files&&v(e.target.files)}})]}),e.jsxRuntimeExports.jsxs(r.Stack,{sx:{default:{flexGrow:1,gap:g.padding-2+"px"}},children:[e.jsxRuntimeExports.jsx(s.Button,{type:"button",genre:d.genre,size:d.size,sx:{default:{flexGrow:3}},isRadius:!0,onClick:b,children:d.locale.buttonAdd}),e.jsxRuntimeExports.jsx(s.Button,{isRadius:!0,type:"button",sx:{default:{flexGrow:1}},onClick:()=>{x(d.defaultImages||[]),null==c||c(d.defaultImages||[])},genre:d.genre,size:d.size,children:d.locale.buttonReset})]})]}),(null==d?void 0:d.error)?e.jsxRuntimeExports.jsx(s.ErrorMessage,{...d.error,size:(null==d?void 0:d.error.size)??d.size,font:{size:12,weight:400,family:f.font.family}}):null]})};
2
- //# sourceMappingURL=component-BHINcJGw.cjs.map
1
+ "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),t=require("./consts.cjs.js"),i=require("./use-DZU4NdpU.cjs"),s=require("./context.constants-BMJ3rLa_.cjs"),n=require("./component-DbRG0dzX.cjs"),r=require("./component-5Utdcc2G.cjs"),o=require("styled-components");require("./context.constants-wztrdG5Q.cjs");const a=require("./context.hooks-DDtUqE34.cjs"),l=require("react"),u=require("framer-motion");exports.ImageSelect=d=>{const{onChange:c}=d,g=l.useMemo(()=>s.KEY_SIZE_DATA[d.size],[d.size]),[p,x]=l.useState(d.images||[]),[m,h]=l.useState(!1),j=l.useRef(null),f=o.useTheme(),S=l.useCallback(e=>{e&&x(t=>{const i=e.map((e,i)=>({...e,index:t.length+i})),s=[...t,...i];return null==c||c(s),s})},[c]),b=()=>{var e;null==(e=j.current)||e.click()},{handleAddFiles:v}=i.useImageCrop({onSave:S,locale:d.locale,dialog:{button:{genre:d.propsButton.default.genre,size:d.propsButton.default.size},buttonDelete:{genre:d.propsButton.delete.genre,size:d.propsButton.delete.size}},imageSettings:{maxSize:d.imageSettings.maxSize,maxCount:d.imageSettings.maxCount-p.length,aspect:d.imageSettings.aspect},refInput:j}),{handleAdd:R}=(t=>{const i=l.useMemo(()=>s.KEY_SIZE_DATA[t.size],[t.size]),o=l.useMemo(()=>`${i.radius}px`,[i.radius]),{add:u}=a.useDialog({br:o,propsDialog:{borderRadius:o,padding:"0",background:"whiteStandard"}});return{handleAdd:l.useCallback(i=>{u({content:(o,a)=>e.jsxRuntimeExports.jsxs(r.Stack,{sx:{default:{position:"relative",overflow:"hidden",aspectRatio:2*t.imageSettings.aspect+" / 2",width:"auto",maxWidth:"70dvw",height:"85dvh",borderRadius:null==o?void 0:o.br},tablet:{maxWidth:"95dvw"}},children:[e.jsxRuntimeExports.jsx(n.Image,{sxStack:e=>({default:{width:"100%",height:"100%",alignItems:"center",justifyContent:"center",backgroundColor:e.palette.black10,position:"absolute",pointerEvents:"none"}}),isShowBeforeImage:!0,sxImage:{default:{objectFit:"contain"}},alt:null==i?void 0:i.imageSrc,src:null==i?void 0:i.imageSrc,componentFallback:e.jsxRuntimeExports.jsx(s.Typography,{sx:{default:{variant:"h6"}},children:t.locale.imageFallback})}),e.jsxRuntimeExports.jsx(s.Button,{sx:{default:{position:"absolute",bottom:15,right:15}},genre:"realebail-white",size:"small",icons:[{type:"id",name:"Arrow4"}],isWidthAsHeight:!0,isHiddenBorder:!0,isRadius:!0,onClick:()=>null==a?void 0:a()})]})})},[u,t.imageSettings.aspect,t.locale.imageFallback])}})({size:d.size,locale:d.locale,imageSettings:d.imageSettings,genre:d.genre});return l.useEffect(()=>{x(d.images||[])},[d.images]),e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs(s.ImageSelectWrapper,{$genre:d.genre,$size:d.size,id:d.id,$sx:d.sx,$error:d.error,children:[e.jsxRuntimeExports.jsxs(s.ImageSelectListWrapper,{onDrop:e=>{(e=>{var t;e.preventDefault(),(null==(t=e.dataTransfer.files)?void 0:t.length)&&v(e.dataTransfer.files)})(e),h(!1)},onDragOver:e=>e.preventDefault(),onDragEnter:()=>h(!0),onDragLeave:()=>h(!1),animate:{borderColor:m?f.colors.imageSelect[d.genre].border.hover:f.colors.imageSelect[d.genre].border.rest},transition:{duration:.3},$genre:d.genre,$size:d.size,children:[e.jsxRuntimeExports.jsxs(u.motion.div,{transition:{layout:{duration:.3,ease:"easeInOut",type:"spring"}},layout:!0,style:{display:"flex",flexWrap:"wrap",gap:g.padding-2+"px"},children:[p.map(t=>t.url&&e.jsxRuntimeExports.jsxs(u.motion.div,{style:{position:"relative",width:`${d.imageSettings.width}px`,height:`${d.imageSettings.height}px`,userSelect:"none",overflow:"hidden",borderRadius:`${g.radius}px`,flexGrow:1},layout:!0,transition:{layout:{duration:.3,ease:"easeInOut",type:"spring"}},children:[e.jsxRuntimeExports.jsx(n.Image,{sxStack:e=>({default:{width:"100%",height:"100%",alignItems:"center",justifyContent:"center",backgroundColor:e.palette.black10,position:"absolute",pointerEvents:"none"}}),isShowBeforeImage:d.isContain,sxImage:{default:{objectFit:d.isContain?"contain":"cover"}},alt:t.name||"image",src:t.url,componentFallback:e.jsxRuntimeExports.jsx(s.Typography,{sx:{default:{variant:"h6"}},children:d.locale.imageFallback})}),e.jsxRuntimeExports.jsx(s.Button,{sx:{default:{position:"absolute",top:5,right:5}},genre:d.genre,size:"small",icons:[{type:"id",name:"Close"}],isWidthAsHeight:!0,isHiddenBorder:!0,isRadius:!0,onClick:()=>{return e=t.id,void x(t=>{const i=t.filter(t=>t.id!==e);return null==c||c(i),i});var e}}),e.jsxRuntimeExports.jsx(s.Button,{sx:{default:{position:"absolute",bottom:5,right:5}},genre:d.genre,size:"small",icons:[{type:"id",name:"Activity"}],isWidthAsHeight:!0,isHiddenBorder:!0,isRadius:!0,onClick:()=>t.url&&R({id:t.id,imageSrc:t.url})})]},t.id)),0===p.length?e.jsxRuntimeExports.jsx("div",{onClick:b,style:{position:"relative",width:`${d.imageSettings.width}px`,height:`${d.imageSettings.height}px`,userSelect:"none",overflow:"hidden",borderRadius:`${g.radius}px`,flexGrow:1,display:"flex",alignItems:"center",justifyContent:"center",textAlign:"center",cursor:"pointer"},children:e.jsxRuntimeExports.jsx(s.Typography,{style:{color:f.colors.imageSelect[d.genre].color.rest},sx:{default:{}},children:d.locale.dragAndDrop})},"empty"):null]}),e.jsxRuntimeExports.jsx("input",{ref:j,type:"file",accept:t.LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT,multiple:!0,style:{display:"none"},onChange:e=>{e.target.files&&v(e.target.files)}})]}),e.jsxRuntimeExports.jsxs(r.Stack,{sx:{default:{flexGrow:1,gap:g.padding-2+"px"}},children:[e.jsxRuntimeExports.jsx(s.Button,{type:"button",genre:d.genre,size:d.size,sx:{default:{flexGrow:3}},isRadius:!0,onClick:b,children:d.locale.buttonAdd}),e.jsxRuntimeExports.jsx(s.Button,{isRadius:!0,type:"button",sx:{default:{flexGrow:1}},onClick:()=>{x(d.defaultImages||[]),null==c||c(d.defaultImages||[])},genre:d.genre,size:d.size,children:d.locale.buttonReset})]})]}),(null==d?void 0:d.error)?e.jsxRuntimeExports.jsx(s.ErrorMessage,{...d.error,size:(null==d?void 0:d.error.size)??d.size,font:{size:12,weight:400,family:f.font.family}}):null]})};
2
+ //# sourceMappingURL=component-BzWpboBU.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-BHINcJGw.cjs","sources":["../src/components/image-select/component.tsx","../src/hooks/use-image-view/use.tsx"],"sourcesContent":["import { LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT } from '@local/consts';\nimport { useImageCrop } from '@local/hooks/use-image-crop';\nimport { useImageView } from '@local/hooks/use-image-view';\nimport { ErrorMessage } from '@local/styles/error';\nimport { KEY_SIZE_DATA } from '@local/theme';\n\nimport { motion } from 'framer-motion';\nimport { DragEvent, useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { Button } from '../button';\nimport { Image } from '../image';\nimport { Stack } from '../stack';\nimport { Typography } from '../typography';\nimport { ImageSelectItemProps, ImageSelectListWrapper, ImageSelectProps, ImageSelectWrapper } from '.';\n\nexport const ImageSelect = (props: ImageSelectProps) => {\n const { onChange } = props;\n\n const size = useMemo(() => KEY_SIZE_DATA[props.size], [props.size]);\n\n const [images, setImages] = useState<ImageSelectItemProps[]>(props.images || []);\n\n const [isDraggingOver, setIsDraggingOver] = useState(false);\n\n const refInput = useRef<HTMLInputElement | null>(null);\n\n const theme = useTheme();\n\n const handleDrop = (e: DragEvent<HTMLDivElement>) => {\n e.preventDefault();\n if (e.dataTransfer.files?.length) {\n handleAddFilesCrop(e.dataTransfer.files);\n }\n };\n\n const handleDelete = (id: number) => {\n setImages((prev) => {\n const finalImages = prev.filter((img) => img.id !== id);\n onChange?.(finalImages);\n return finalImages;\n });\n };\n\n const handleOnSave = useCallback(\n (files: ImageSelectItemProps[] | null) => {\n if (files) {\n setImages((prev) => {\n const newImages = files.map((file, idx) => ({\n ...file,\n index: prev.length + idx,\n }));\n const finalImages = [...prev, ...newImages];\n onChange?.(finalImages);\n return finalImages;\n });\n }\n },\n [onChange],\n );\n\n const openFileDialog = () => {\n refInput.current?.click();\n };\n\n const resetImages = () => {\n setImages(props.defaultImages || []);\n onChange?.(props.defaultImages || []);\n };\n\n const { handleAddFiles: handleAddFilesCrop } = useImageCrop({\n onSave: handleOnSave,\n locale: props.locale,\n dialog: {\n button: {\n genre: props.propsButton.default.genre,\n size: props.propsButton.default.size,\n },\n buttonDelete: {\n genre: props.propsButton.delete.genre,\n size: props.propsButton.delete.size,\n },\n },\n imageSettings: {\n maxSize: props.imageSettings.maxSize,\n maxCount: props.imageSettings.maxCount - images.length,\n aspect: props.imageSettings.aspect,\n },\n refInput: refInput,\n });\n\n const { handleAdd } = useImageView({\n size: props.size,\n locale: props.locale,\n imageSettings: props.imageSettings,\n genre: props.genre,\n });\n\n useEffect(() => {\n setImages(props.images || []);\n }, [props.images]);\n\n return (\n <>\n <ImageSelectWrapper $genre={props.genre} $size={props.size} id={props.id} $sx={props.sx} $error={props.error}>\n <ImageSelectListWrapper\n onDrop={(e) => {\n handleDrop(e);\n setIsDraggingOver(false);\n }}\n onDragOver={(e) => e.preventDefault()}\n onDragEnter={() => setIsDraggingOver(true)}\n onDragLeave={() => setIsDraggingOver(false)}\n animate={{\n borderColor: isDraggingOver\n ? theme.colors.imageSelect[props.genre].border.hover\n : theme.colors.imageSelect[props.genre].border.rest,\n }}\n transition={{ duration: 0.3 }}\n $genre={props.genre}\n $size={props.size}\n >\n <motion.div\n transition={{\n layout: {\n duration: 0.3,\n ease: 'easeInOut',\n type: 'spring',\n },\n }}\n layout\n style={{ display: 'flex', flexWrap: 'wrap', gap: `${size.padding - 2}px` }}\n >\n {images.map(\n (img) =>\n img.url && (\n <motion.div\n key={img.id}\n style={{\n position: 'relative',\n width: `${props.imageSettings.width}px`,\n height: `${props.imageSettings.height}px`,\n userSelect: 'none',\n overflow: 'hidden',\n borderRadius: `${size.radius}px`,\n flexGrow: 1,\n }}\n layout\n transition={{\n layout: {\n duration: 0.3,\n ease: 'easeInOut',\n type: 'spring',\n },\n }}\n >\n <Image\n sxStack={(theme) => ({\n default: {\n width: '100%',\n height: '100%',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: theme.palette.black10,\n position: 'absolute',\n pointerEvents: 'none',\n },\n })}\n isShowBeforeImage={props.isContain}\n sxImage={{\n default: {\n objectFit: props.isContain ? 'contain' : 'cover',\n },\n }}\n alt={img.name || 'image'}\n src={img.url}\n componentFallback={\n <Typography\n sx={{\n default: {\n variant: 'h6',\n },\n }}\n >\n {props.locale.imageFallback}\n </Typography>\n }\n />\n <Button\n sx={{\n default: {\n position: 'absolute',\n top: 5,\n right: 5,\n },\n }}\n genre={props.genre}\n size='small'\n icons={[\n {\n type: 'id',\n name: 'Close',\n },\n ]}\n isWidthAsHeight\n isHiddenBorder\n isRadius\n onClick={() => handleDelete(img.id)}\n />\n <Button\n sx={{\n default: {\n position: 'absolute',\n bottom: 5,\n right: 5,\n },\n }}\n genre={props.genre}\n size='small'\n icons={[\n {\n type: 'id',\n name: 'Activity',\n },\n ]}\n isWidthAsHeight\n isHiddenBorder\n isRadius\n onClick={() => img.url && handleAdd({ id: img.id, imageSrc: img.url })}\n />\n </motion.div>\n ),\n )}\n {images.length === 0 ? (\n <div\n onClick={openFileDialog}\n key='empty'\n style={{\n position: 'relative',\n width: `${props.imageSettings.width}px`,\n height: `${props.imageSettings.height}px`,\n userSelect: 'none',\n overflow: 'hidden',\n borderRadius: `${size.radius}px`,\n flexGrow: 1,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n textAlign: 'center',\n cursor: 'pointer',\n }}\n >\n <Typography\n style={{\n color: theme.colors.imageSelect[props.genre].color.rest,\n }}\n sx={{\n default: {},\n }}\n >\n {props.locale.dragAndDrop}\n </Typography>\n </div>\n ) : null}\n </motion.div>\n\n <input\n ref={refInput}\n type='file'\n accept={LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT}\n multiple\n style={{ display: 'none' }}\n onChange={(e) => {\n if (e.target.files) handleAddFilesCrop(e.target.files);\n }}\n />\n </ImageSelectListWrapper>\n <Stack sx={{ default: { flexGrow: 1, gap: `${size.padding - 2}px` } }}>\n <Button\n type='button'\n genre={props.genre}\n size={props.size}\n sx={{\n default: {\n flexGrow: 3,\n },\n }}\n isRadius\n onClick={openFileDialog}\n >\n {props.locale.buttonAdd}\n </Button>\n <Button\n isRadius\n type='button'\n sx={{\n default: {\n flexGrow: 1,\n },\n }}\n onClick={resetImages}\n genre={props.genre}\n size={props.size}\n >\n {props.locale.buttonReset}\n </Button>\n </Stack>\n </ImageSelectWrapper>\n {props?.error ? (\n <ErrorMessage\n {...props.error}\n size={props?.error.size ?? props.size}\n font={{\n size: 12,\n weight: 400,\n family: theme.font.family,\n }}\n />\n ) : null}\n </>\n );\n};\n","import { Button } from '@local/components/button';\nimport { Image } from '@local/components/image';\nimport { SliderImageProps } from '@local/components/image-slider';\nimport { Stack } from '@local/components/stack';\nimport { Typography } from '@local/components/typography';\nimport { useDialog } from '@local/contexts/context-dialog';\nimport { KEY_SIZE_DATA } from '@local/theme';\n\nimport { useCallback, useMemo } from 'react';\n\nimport { useImageViewProps } from '.';\n\nexport const useImageView = (props: useImageViewProps) => {\n const size = useMemo(() => KEY_SIZE_DATA[props.size], [props.size]);\n const br = useMemo(() => `${size.radius}px`, [size.radius]);\n\n const { add } = useDialog<{\n br?: string;\n }>({\n br: br,\n propsDialog: {\n borderRadius: br,\n padding: '0',\n background: 'whiteStandard',\n },\n });\n const handleAdd = useCallback(\n (image: SliderImageProps) => {\n add({\n content: (params, remove) => (\n <Stack\n sx={{\n default: {\n position: 'relative',\n overflow: 'hidden',\n aspectRatio: `${props.imageSettings.aspect * 2} / 2`,\n width: 'auto',\n maxWidth: '70dvw',\n height: '85dvh',\n borderRadius: params?.br,\n },\n tablet: {\n maxWidth: '95dvw',\n },\n }}\n >\n <Image\n sxStack={(theme) => ({\n default: {\n width: '100%',\n height: '100%',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: theme.palette.black10,\n position: 'absolute',\n pointerEvents: 'none',\n },\n })}\n isShowBeforeImage\n sxImage={{\n default: {\n objectFit: 'contain',\n },\n }}\n alt={image?.imageSrc}\n src={image?.imageSrc}\n componentFallback={\n <Typography\n sx={{\n default: {\n variant: 'h6',\n },\n }}\n >\n {props.locale.imageFallback}\n </Typography>\n }\n />\n <Button\n sx={{\n default: {\n position: 'absolute',\n bottom: 15,\n right: 15,\n },\n }}\n genre='realebail-white'\n size='small'\n icons={[\n {\n type: 'id',\n name: 'Arrow4',\n },\n ]}\n isWidthAsHeight\n isHiddenBorder\n isRadius\n onClick={() => remove?.()}\n />\n </Stack>\n ),\n });\n },\n [add, props.imageSettings.aspect, props.locale.imageFallback],\n );\n return { handleAdd };\n};\n"],"names":["props","onChange","size","useMemo","KEY_SIZE_DATA","images","setImages","useState","isDraggingOver","setIsDraggingOver","refInput","useRef","theme","useTheme","handleOnSave","useCallback","files","prev","newImages","map","file","idx","index","length","finalImages","openFileDialog","_a","current","click","handleAddFiles","handleAddFilesCrop","useImageCrop","onSave","locale","dialog","button","genre","propsButton","default","buttonDelete","delete","imageSettings","maxSize","maxCount","aspect","handleAdd","br","radius","add","useDialog","propsDialog","borderRadius","padding","background","image","content","params","remove","jsxs","Stack","sx","position","overflow","aspectRatio","width","maxWidth","height","tablet","children","jsx","Image","sxStack","alignItems","justifyContent","backgroundColor","palette","black10","pointerEvents","isShowBeforeImage","sxImage","objectFit","alt","imageSrc","src","componentFallback","Typography","variant","imageFallback","Button","bottom","right","icons","type","name","isWidthAsHeight","isHiddenBorder","isRadius","onClick","useImageView","useEffect","Fragment","ImageSelectWrapper","$genre","$size","id","$sx","$error","error","ImageSelectListWrapper","onDrop","e","preventDefault","dataTransfer","handleDrop","onDragOver","onDragEnter","onDragLeave","animate","borderColor","colors","imageSelect","border","hover","rest","transition","duration","motion","div","layout","ease","style","display","flexWrap","gap","img","url","userSelect","flexGrow","isContain","top","handleDelete","filter","textAlign","cursor","color","dragAndDrop","ref","accept","LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT","multiple","target","buttonAdd","defaultImages","buttonReset","ErrorMessage","font","weight","family"],"mappings":"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"}
1
+ {"version":3,"file":"component-BzWpboBU.cjs","sources":["../src/components/image-select/component.tsx","../src/hooks/use-image-view/use.tsx"],"sourcesContent":["import { LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT } from '@local/consts';\nimport { useImageCrop } from '@local/hooks/use-image-crop';\nimport { useImageView } from '@local/hooks/use-image-view';\nimport { ErrorMessage } from '@local/styles/error';\nimport { KEY_SIZE_DATA } from '@local/theme';\n\nimport { motion } from 'framer-motion';\nimport { DragEvent, useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { Button } from '../button';\nimport { Image } from '../image';\nimport { Stack } from '../stack';\nimport { Typography } from '../typography';\nimport { ImageSelectItemProps, ImageSelectListWrapper, ImageSelectProps, ImageSelectWrapper } from '.';\n\nexport const ImageSelect = (props: ImageSelectProps) => {\n const { onChange } = props;\n\n const size = useMemo(() => KEY_SIZE_DATA[props.size], [props.size]);\n\n const [images, setImages] = useState<ImageSelectItemProps[]>(props.images || []);\n\n const [isDraggingOver, setIsDraggingOver] = useState(false);\n\n const refInput = useRef<HTMLInputElement | null>(null);\n\n const theme = useTheme();\n\n const handleDrop = (e: DragEvent<HTMLDivElement>) => {\n e.preventDefault();\n if (e.dataTransfer.files?.length) {\n handleAddFilesCrop(e.dataTransfer.files);\n }\n };\n\n const handleDelete = (id: number) => {\n setImages((prev) => {\n const finalImages = prev.filter((img) => img.id !== id);\n onChange?.(finalImages);\n return finalImages;\n });\n };\n\n const handleOnSave = useCallback(\n (files: ImageSelectItemProps[] | null) => {\n if (files) {\n setImages((prev) => {\n const newImages = files.map((file, idx) => ({\n ...file,\n index: prev.length + idx,\n }));\n const finalImages = [...prev, ...newImages];\n onChange?.(finalImages);\n return finalImages;\n });\n }\n },\n [onChange],\n );\n\n const openFileDialog = () => {\n refInput.current?.click();\n };\n\n const resetImages = () => {\n setImages(props.defaultImages || []);\n onChange?.(props.defaultImages || []);\n };\n\n const { handleAddFiles: handleAddFilesCrop } = useImageCrop({\n onSave: handleOnSave,\n locale: props.locale,\n dialog: {\n button: {\n genre: props.propsButton.default.genre,\n size: props.propsButton.default.size,\n },\n buttonDelete: {\n genre: props.propsButton.delete.genre,\n size: props.propsButton.delete.size,\n },\n },\n imageSettings: {\n maxSize: props.imageSettings.maxSize,\n maxCount: props.imageSettings.maxCount - images.length,\n aspect: props.imageSettings.aspect,\n },\n refInput: refInput,\n });\n\n const { handleAdd } = useImageView({\n size: props.size,\n locale: props.locale,\n imageSettings: props.imageSettings,\n genre: props.genre,\n });\n\n useEffect(() => {\n setImages(props.images || []);\n }, [props.images]);\n\n return (\n <>\n <ImageSelectWrapper $genre={props.genre} $size={props.size} id={props.id} $sx={props.sx} $error={props.error}>\n <ImageSelectListWrapper\n onDrop={(e) => {\n handleDrop(e);\n setIsDraggingOver(false);\n }}\n onDragOver={(e) => e.preventDefault()}\n onDragEnter={() => setIsDraggingOver(true)}\n onDragLeave={() => setIsDraggingOver(false)}\n animate={{\n borderColor: isDraggingOver\n ? theme.colors.imageSelect[props.genre].border.hover\n : theme.colors.imageSelect[props.genre].border.rest,\n }}\n transition={{ duration: 0.3 }}\n $genre={props.genre}\n $size={props.size}\n >\n <motion.div\n transition={{\n layout: {\n duration: 0.3,\n ease: 'easeInOut',\n type: 'spring',\n },\n }}\n layout\n style={{ display: 'flex', flexWrap: 'wrap', gap: `${size.padding - 2}px` }}\n >\n {images.map(\n (img) =>\n img.url && (\n <motion.div\n key={img.id}\n style={{\n position: 'relative',\n width: `${props.imageSettings.width}px`,\n height: `${props.imageSettings.height}px`,\n userSelect: 'none',\n overflow: 'hidden',\n borderRadius: `${size.radius}px`,\n flexGrow: 1,\n }}\n layout\n transition={{\n layout: {\n duration: 0.3,\n ease: 'easeInOut',\n type: 'spring',\n },\n }}\n >\n <Image\n sxStack={(theme) => ({\n default: {\n width: '100%',\n height: '100%',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: theme.palette.black10,\n position: 'absolute',\n pointerEvents: 'none',\n },\n })}\n isShowBeforeImage={props.isContain}\n sxImage={{\n default: {\n objectFit: props.isContain ? 'contain' : 'cover',\n },\n }}\n alt={img.name || 'image'}\n src={img.url}\n componentFallback={\n <Typography\n sx={{\n default: {\n variant: 'h6',\n },\n }}\n >\n {props.locale.imageFallback}\n </Typography>\n }\n />\n <Button\n sx={{\n default: {\n position: 'absolute',\n top: 5,\n right: 5,\n },\n }}\n genre={props.genre}\n size='small'\n icons={[\n {\n type: 'id',\n name: 'Close',\n },\n ]}\n isWidthAsHeight\n isHiddenBorder\n isRadius\n onClick={() => handleDelete(img.id)}\n />\n <Button\n sx={{\n default: {\n position: 'absolute',\n bottom: 5,\n right: 5,\n },\n }}\n genre={props.genre}\n size='small'\n icons={[\n {\n type: 'id',\n name: 'Activity',\n },\n ]}\n isWidthAsHeight\n isHiddenBorder\n isRadius\n onClick={() => img.url && handleAdd({ id: img.id, imageSrc: img.url })}\n />\n </motion.div>\n ),\n )}\n {images.length === 0 ? (\n <div\n onClick={openFileDialog}\n key='empty'\n style={{\n position: 'relative',\n width: `${props.imageSettings.width}px`,\n height: `${props.imageSettings.height}px`,\n userSelect: 'none',\n overflow: 'hidden',\n borderRadius: `${size.radius}px`,\n flexGrow: 1,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n textAlign: 'center',\n cursor: 'pointer',\n }}\n >\n <Typography\n style={{\n color: theme.colors.imageSelect[props.genre].color.rest,\n }}\n sx={{\n default: {},\n }}\n >\n {props.locale.dragAndDrop}\n </Typography>\n </div>\n ) : null}\n </motion.div>\n\n <input\n ref={refInput}\n type='file'\n accept={LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT}\n multiple\n style={{ display: 'none' }}\n onChange={(e) => {\n if (e.target.files) handleAddFilesCrop(e.target.files);\n }}\n />\n </ImageSelectListWrapper>\n <Stack sx={{ default: { flexGrow: 1, gap: `${size.padding - 2}px` } }}>\n <Button\n type='button'\n genre={props.genre}\n size={props.size}\n sx={{\n default: {\n flexGrow: 3,\n },\n }}\n isRadius\n onClick={openFileDialog}\n >\n {props.locale.buttonAdd}\n </Button>\n <Button\n isRadius\n type='button'\n sx={{\n default: {\n flexGrow: 1,\n },\n }}\n onClick={resetImages}\n genre={props.genre}\n size={props.size}\n >\n {props.locale.buttonReset}\n </Button>\n </Stack>\n </ImageSelectWrapper>\n {props?.error ? (\n <ErrorMessage\n {...props.error}\n size={props?.error.size ?? props.size}\n font={{\n size: 12,\n weight: 400,\n family: theme.font.family,\n }}\n />\n ) : null}\n </>\n );\n};\n","import { Button } from '@local/components/button';\nimport { Image } from '@local/components/image';\nimport { SliderImageProps } from '@local/components/image-slider';\nimport { Stack } from '@local/components/stack';\nimport { Typography } from '@local/components/typography';\nimport { useDialog } from '@local/contexts/context-dialog';\nimport { KEY_SIZE_DATA } from '@local/theme';\n\nimport { useCallback, useMemo } from 'react';\n\nimport { useImageViewProps } from '.';\n\nexport const useImageView = (props: useImageViewProps) => {\n const size = useMemo(() => KEY_SIZE_DATA[props.size], [props.size]);\n const br = useMemo(() => `${size.radius}px`, [size.radius]);\n\n const { add } = useDialog<{\n br?: string;\n }>({\n br: br,\n propsDialog: {\n borderRadius: br,\n padding: '0',\n background: 'whiteStandard',\n },\n });\n const handleAdd = useCallback(\n (image: SliderImageProps) => {\n add({\n content: (params, remove) => (\n <Stack\n sx={{\n default: {\n position: 'relative',\n overflow: 'hidden',\n aspectRatio: `${props.imageSettings.aspect * 2} / 2`,\n width: 'auto',\n maxWidth: '70dvw',\n height: '85dvh',\n borderRadius: params?.br,\n },\n tablet: {\n maxWidth: '95dvw',\n },\n }}\n >\n <Image\n sxStack={(theme) => ({\n default: {\n width: '100%',\n height: '100%',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: theme.palette.black10,\n position: 'absolute',\n pointerEvents: 'none',\n },\n })}\n isShowBeforeImage\n sxImage={{\n default: {\n objectFit: 'contain',\n },\n }}\n alt={image?.imageSrc}\n src={image?.imageSrc}\n componentFallback={\n <Typography\n sx={{\n default: {\n variant: 'h6',\n },\n }}\n >\n {props.locale.imageFallback}\n </Typography>\n }\n />\n <Button\n sx={{\n default: {\n position: 'absolute',\n bottom: 15,\n right: 15,\n },\n }}\n genre='realebail-white'\n size='small'\n icons={[\n {\n type: 'id',\n name: 'Arrow4',\n },\n ]}\n isWidthAsHeight\n isHiddenBorder\n isRadius\n onClick={() => remove?.()}\n />\n </Stack>\n ),\n });\n },\n [add, props.imageSettings.aspect, props.locale.imageFallback],\n );\n return { handleAdd };\n};\n"],"names":["props","onChange","size","useMemo","KEY_SIZE_DATA","images","setImages","useState","isDraggingOver","setIsDraggingOver","refInput","useRef","theme","useTheme","handleOnSave","useCallback","files","prev","newImages","map","file","idx","index","length","finalImages","openFileDialog","_a","current","click","handleAddFiles","handleAddFilesCrop","useImageCrop","onSave","locale","dialog","button","genre","propsButton","default","buttonDelete","delete","imageSettings","maxSize","maxCount","aspect","handleAdd","br","radius","add","useDialog","propsDialog","borderRadius","padding","background","image","content","params","remove","jsxs","Stack","sx","position","overflow","aspectRatio","width","maxWidth","height","tablet","children","jsx","Image","sxStack","alignItems","justifyContent","backgroundColor","palette","black10","pointerEvents","isShowBeforeImage","sxImage","objectFit","alt","imageSrc","src","componentFallback","Typography","variant","imageFallback","Button","bottom","right","icons","type","name","isWidthAsHeight","isHiddenBorder","isRadius","onClick","useImageView","useEffect","Fragment","ImageSelectWrapper","$genre","$size","id","$sx","$error","error","ImageSelectListWrapper","onDrop","e","preventDefault","dataTransfer","handleDrop","onDragOver","onDragEnter","onDragLeave","animate","borderColor","colors","imageSelect","border","hover","rest","transition","duration","motion","div","layout","ease","style","display","flexWrap","gap","img","url","userSelect","flexGrow","isContain","top","handleDelete","filter","textAlign","cursor","color","dragAndDrop","ref","accept","LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT","multiple","target","buttonAdd","defaultImages","buttonReset","ErrorMessage","font","weight","family"],"mappings":"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"}
@@ -1,8 +1,8 @@
1
1
  import { j as jsxRuntimeExports } from "./jsx-runtime-BrDlu8eK.js";
2
2
  import { LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT } from "./consts.es.js";
3
- import { u as useImageCrop } from "./use-DLn-Y7_0.js";
3
+ import { u as useImageCrop } from "./use-JWHe9gP5.js";
4
4
  import { useRef, useCallback } from "react";
5
- import { B as Button } from "./context.constants-Dop398a2.js";
5
+ import { B as Button } from "./context.constants-YlWOZAd7.js";
6
6
  const ImageButton = (props) => {
7
7
  const refInput = useRef(null);
8
8
  const handleOpenFileDialog = useCallback(() => {
@@ -47,4 +47,4 @@ const ImageButton = (props) => {
47
47
  export {
48
48
  ImageButton as I
49
49
  };
50
- //# sourceMappingURL=component-Ud_GRMAS.js.map
50
+ //# sourceMappingURL=component-C0354Xwu.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-Ud_GRMAS.js","sources":["../src/components/image-button/component.tsx"],"sourcesContent":["import { LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT } from '@local/consts';\nimport { useImageCrop } from '@local/hooks/use-image-crop';\n\nimport { FC, useCallback, useRef } from 'react';\n\nimport { Button } from '../button';\nimport { ImageButtonProps } from '.';\n\nexport const ImageButton: FC<ImageButtonProps> = (props) => {\n const refInput = useRef<HTMLInputElement | null>(null);\n\n const handleOpenFileDialog = useCallback(() => {\n refInput.current?.click();\n }, []);\n\n const { handleAddFiles } = useImageCrop({\n onSave: props.onSave,\n locale: props.locale,\n dialog: props.dialog,\n imageSettings: props.imageSettings,\n refInput: refInput,\n });\n\n return (\n <>\n <Button\n {...props.button}\n onClick={(e) => {\n props.button.onClick?.(e);\n handleOpenFileDialog();\n }}\n >\n {props.button.children || props.locale.buttonAdd}\n </Button>\n <input\n ref={refInput}\n type='file'\n accept={LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT}\n multiple\n style={{ display: 'none' }}\n onChange={(e) => {\n if (e.target.files) handleAddFiles(e.target.files);\n }}\n />\n </>\n );\n};\n"],"names":["jsxs","Fragment","jsx"],"mappings":";;;;;AAQO,MAAM,cAAoC,CAAC,UAAU;AAC1D,QAAM,WAAW,OAAgC,IAAI;AAErD,QAAM,uBAAuB,YAAY,MAAM;;AAC7C,mBAAS,YAAT,mBAAkB;AAAA,EAAM,GACvB,EAAE;AAEL,QAAM,EAAE,eAAA,IAAmB,aAAa;AAAA,IACtC,QAAQ,MAAM;AAAA,IACd,QAAQ,MAAM;AAAA,IACd,QAAQ,MAAM;AAAA,IACd,eAAe,MAAM;AAAA,IACrB;AAAA,EAAA,CACD;AAED,SACEA,kCAAAA,KAAAC,4BAAA,EACE,UAAA;AAAA,IAAAC,kCAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACE,GAAG,MAAM;AAAA,QACV,SAAS,CAAC,MAAM;;AACd,4BAAM,QAAO,YAAb,4BAAuB;AACvB,+BAAA;AAAA,QAAqB;AAAA,QAGtB,UAAA,MAAM,OAAO,YAAY,MAAM,OAAO;AAAA,MAAA;AAAA,IAAA;AAAA,IAEzCA,kCAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAK;AAAA,QACL,MAAK;AAAA,QACL,QAAQ;AAAA,QACR,UAAQ;AAAA,QACR,OAAO,EAAE,SAAS,OAAA;AAAA,QAClB,UAAU,CAAC,MAAM;AACf,cAAI,EAAE,OAAO,MAAO,gBAAe,EAAE,OAAO,KAAK;AAAA,QAAA;AAAA,MACnD;AAAA,IAAA;AAAA,EACF,GACF;AAEJ;"}
1
+ {"version":3,"file":"component-C0354Xwu.js","sources":["../src/components/image-button/component.tsx"],"sourcesContent":["import { LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT } from '@local/consts';\nimport { useImageCrop } from '@local/hooks/use-image-crop';\n\nimport { FC, useCallback, useRef } from 'react';\n\nimport { Button } from '../button';\nimport { ImageButtonProps } from '.';\n\nexport const ImageButton: FC<ImageButtonProps> = (props) => {\n const refInput = useRef<HTMLInputElement | null>(null);\n\n const handleOpenFileDialog = useCallback(() => {\n refInput.current?.click();\n }, []);\n\n const { handleAddFiles } = useImageCrop({\n onSave: props.onSave,\n locale: props.locale,\n dialog: props.dialog,\n imageSettings: props.imageSettings,\n refInput: refInput,\n });\n\n return (\n <>\n <Button\n {...props.button}\n onClick={(e) => {\n props.button.onClick?.(e);\n handleOpenFileDialog();\n }}\n >\n {props.button.children || props.locale.buttonAdd}\n </Button>\n <input\n ref={refInput}\n type='file'\n accept={LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT}\n multiple\n style={{ display: 'none' }}\n onChange={(e) => {\n if (e.target.files) handleAddFiles(e.target.files);\n }}\n />\n </>\n );\n};\n"],"names":["jsxs","Fragment","jsx"],"mappings":";;;;;AAQO,MAAM,cAAoC,CAAC,UAAU;AAC1D,QAAM,WAAW,OAAgC,IAAI;AAErD,QAAM,uBAAuB,YAAY,MAAM;;AAC7C,mBAAS,YAAT,mBAAkB;AAAA,EAAM,GACvB,EAAE;AAEL,QAAM,EAAE,eAAA,IAAmB,aAAa;AAAA,IACtC,QAAQ,MAAM;AAAA,IACd,QAAQ,MAAM;AAAA,IACd,QAAQ,MAAM;AAAA,IACd,eAAe,MAAM;AAAA,IACrB;AAAA,EAAA,CACD;AAED,SACEA,kCAAAA,KAAAC,4BAAA,EACE,UAAA;AAAA,IAAAC,kCAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACE,GAAG,MAAM;AAAA,QACV,SAAS,CAAC,MAAM;;AACd,4BAAM,QAAO,YAAb,4BAAuB;AACvB,+BAAA;AAAA,QAAqB;AAAA,QAGtB,UAAA,MAAM,OAAO,YAAY,MAAM,OAAO;AAAA,MAAA;AAAA,IAAA;AAAA,IAEzCA,kCAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAK;AAAA,QACL,MAAK;AAAA,QACL,QAAQ;AAAA,QACR,UAAQ;AAAA,QACR,OAAO,EAAE,SAAS,OAAA;AAAA,QAClB,UAAU,CAAC,MAAM;AACf,cAAI,EAAE,OAAO,MAAO,gBAAe,EAAE,OAAO,KAAK;AAAA,QAAA;AAAA,MACnD;AAAA,IAAA;AAAA,EACF,GACF;AAEJ;"}
@@ -1,2 +1,2 @@
1
- "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),i=require("./component-D5Bg68Aq.cjs"),l=require("./context.constants-p2bRkgM3.cjs"),o=require("react"),n=require("styled-components");exports.CheckboxGroup=s=>{var t,r;const c=o.useCallback(e=>{const i=s.value.some(i=>i[s.valueField]===e[s.valueField])?s.value.filter(i=>i[s.valueField]!==e[s.valueField]):s.multiple?[...s.value,e]:[e];s.onChange&&s.onChange(i)},[s]),u=n.useTheme();return e.jsxRuntimeExports.jsx(l.CheckboxGroupWrapper,{className:s.className,$sx:s.sx,$size:s.size,$font:{...s.font,size:(null==(t=s.font)?void 0:t.size)??l.KEY_SIZE_DATA[s.size].font,weight:(null==(r=s.font)?void 0:r.weight)??700},children:s.options.map((o,n)=>{var t,r,d,a;const h=s.value.some(e=>e[s.valueField]===o[s.valueField]);return e.jsxRuntimeExports.jsxs(l.CheckboxGroupItem,{onClick:()=>!s.isClickOnlyIcon&&c(o),children:[e.jsxRuntimeExports.jsx(i.Checkbox,{genre:s.checkboxGenre,isHiddenBorder:s.checkboxIsHiddenBorder,view:s.checkBoxView,sx:s.checkboxSX,size:s.size,checked:h,font:{size:(null==(t=s.font)?void 0:t.size)??l.KEY_SIZE_DATA[s.size].font,weight:(null==(r=s.font)?void 0:r.weight)??700,family:(null==(d=s.font)?void 0:d.family)??u.font.family,height:null==(a=s.font)?void 0:a.height},children:s.labelField&&void 0!==(null==o?void 0:o[s.labelField])&&e.jsxRuntimeExports.jsx(l.CheckboxGroupLabel,{dangerouslySetInnerHTML:(x=o[s.labelField],{__html:x})})}),s.childrenField&&void 0!==(null==o?void 0:o[s.childrenField])&&e.jsxRuntimeExports.jsx(l.CheckboxChildren,{children:o[s.childrenField]})]},n);var x})})};
2
- //# sourceMappingURL=component-CQmuGUIt.cjs.map
1
+ "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),i=require("./component-skAuX4C8.cjs"),l=require("./context.constants-BMJ3rLa_.cjs"),o=require("react"),n=require("styled-components");exports.CheckboxGroup=s=>{var t,r;const c=o.useCallback(e=>{const i=s.value.some(i=>i[s.valueField]===e[s.valueField])?s.value.filter(i=>i[s.valueField]!==e[s.valueField]):s.multiple?[...s.value,e]:[e];s.onChange&&s.onChange(i)},[s]),u=n.useTheme();return e.jsxRuntimeExports.jsx(l.CheckboxGroupWrapper,{className:s.className,$sx:s.sx,$size:s.size,$font:{...s.font,size:(null==(t=s.font)?void 0:t.size)??l.KEY_SIZE_DATA[s.size].font,weight:(null==(r=s.font)?void 0:r.weight)??700},children:s.options.map((o,n)=>{var t,r,d,a;const h=s.value.some(e=>e[s.valueField]===o[s.valueField]);return e.jsxRuntimeExports.jsxs(l.CheckboxGroupItem,{onClick:()=>!s.isClickOnlyIcon&&c(o),children:[e.jsxRuntimeExports.jsx(i.Checkbox,{genre:s.checkboxGenre,isHiddenBorder:s.checkboxIsHiddenBorder,view:s.checkBoxView,sx:s.checkboxSX,size:s.size,checked:h,font:{size:(null==(t=s.font)?void 0:t.size)??l.KEY_SIZE_DATA[s.size].font,weight:(null==(r=s.font)?void 0:r.weight)??700,family:(null==(d=s.font)?void 0:d.family)??u.font.family,height:null==(a=s.font)?void 0:a.height},children:s.labelField&&void 0!==(null==o?void 0:o[s.labelField])&&e.jsxRuntimeExports.jsx(l.CheckboxGroupLabel,{dangerouslySetInnerHTML:(x=o[s.labelField],{__html:x})})}),s.childrenField&&void 0!==(null==o?void 0:o[s.childrenField])&&e.jsxRuntimeExports.jsx(l.CheckboxChildren,{children:o[s.childrenField]})]},n);var x})})};
2
+ //# sourceMappingURL=component-C8ueaiSO.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-CQmuGUIt.cjs","sources":["../src/components/checkbox-group/component.tsx"],"sourcesContent":["import { Checkbox } from '@local/components/checkbox';\nimport { KEY_SIZE_DATA } from '@local/theme';\n\nimport { ReactNode, useCallback } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport {\n CheckboxChildren,\n CheckboxGroupItem,\n CheckboxGroupLabel,\n CheckboxGroupProps,\n CheckboxGroupWrapper,\n ICheckboxValue,\n} from '.';\n\nexport const CheckboxGroup = <T extends ICheckboxValue>(props: CheckboxGroupProps<T>) => {\n const createMarkup = (html: string) => ({ __html: html });\n\n const handleCheckboxChange = useCallback(\n (item: T) => {\n const isSelected = props.value.some((selectedItem) => selectedItem[props.valueField] === item[props.valueField]);\n\n const updatedSelectedItems = isSelected\n ? props.value.filter((selectedItem) => selectedItem[props.valueField] !== item[props.valueField])\n : props.multiple\n ? [...props.value, item]\n : [item];\n if (props.onChange) props.onChange(updatedSelectedItems);\n },\n [props],\n );\n\n const theme = useTheme();\n return (\n <CheckboxGroupWrapper\n className={props.className}\n $sx={props.sx}\n $size={props.size}\n $font={{\n ...props.font,\n size: props.font?.size ?? KEY_SIZE_DATA[props.size].font,\n weight: props.font?.weight ?? 700,\n }}\n >\n {props.options.map((e, index) => {\n const isChecked = props.value.some((selectedItem) => selectedItem[props.valueField] === e[props.valueField]);\n return (\n <CheckboxGroupItem key={index} onClick={() => !props.isClickOnlyIcon && handleCheckboxChange(e)}>\n <Checkbox\n genre={props.checkboxGenre}\n isHiddenBorder={props.checkboxIsHiddenBorder}\n view={props.checkBoxView}\n sx={props.checkboxSX}\n size={props.size}\n checked={isChecked}\n font={{\n size: props.font?.size ?? KEY_SIZE_DATA[props.size].font,\n weight: props.font?.weight ?? 700,\n family: props.font?.family ?? theme.font.family,\n height: props.font?.height,\n }}\n >\n {props.labelField && e?.[props.labelField] !== undefined && (\n <CheckboxGroupLabel dangerouslySetInnerHTML={createMarkup(e[props.labelField] as string)} />\n )}\n </Checkbox>\n {props.childrenField && e?.[props.childrenField] !== undefined && (\n <CheckboxChildren>{e[props.childrenField] as ReactNode}</CheckboxChildren>\n )}\n </CheckboxGroupItem>\n );\n })}\n </CheckboxGroupWrapper>\n );\n};\n"],"names":["props","handleCheckboxChange","useCallback","item","updatedSelectedItems","value","some","selectedItem","valueField","filter","multiple","onChange","theme","useTheme","jsx","CheckboxGroupWrapper","className","$sx","sx","$size","size","$font","font","_a","KEY_SIZE_DATA","weight","_b","children","options","map","e","index","isChecked","jsxs","CheckboxGroupItem","onClick","isClickOnlyIcon","Checkbox","genre","checkboxGenre","isHiddenBorder","checkboxIsHiddenBorder","view","checkBoxView","checkboxSX","checked","family","_c","height","_d","labelField","CheckboxGroupLabel","dangerouslySetInnerHTML","html","__html","childrenField","CheckboxChildren"],"mappings":"uNAewDA,YACtD,MAEMC,EAAuBC,EAAAA,YAC1BC,IACC,MAEMC,EAFaJ,EAAMK,MAAMC,KAAMC,GAAiBA,EAAaP,EAAMQ,cAAgBL,EAAKH,EAAMQ,aAGhGR,EAAMK,MAAMI,OAAQF,GAAiBA,EAAaP,EAAMQ,cAAgBL,EAAKH,EAAMQ,aACnFR,EAAMU,SACJ,IAAIV,EAAMK,MAAOF,GACjB,CAACA,GACHH,EAAMW,UAAUX,EAAMW,SAASP,IAErC,CAACJ,IAGGY,EAAQC,EAAAA,WACd,SACEC,kBAAAA,IAACC,EAAAA,qBAAA,CACCC,UAAWhB,EAAMgB,UACjBC,IAAKjB,EAAMkB,GACXC,MAAOnB,EAAMoB,KACbC,MAAO,IACFrB,EAAMsB,KACTF,MAAM,OAAAG,IAAMD,WAAN,EAAAC,EAAYH,OAAQI,EAAAA,cAAcxB,EAAMoB,MAAME,KACpDG,QAAQ,OAAAC,EAAA1B,EAAMsB,WAAN,EAAAI,EAAYD,SAAU,KAG/BE,SAAA3B,EAAM4B,QAAQC,IAAI,CAACC,EAAGC,iBACrB,MAAMC,EAAYhC,EAAMK,MAAMC,KAAMC,GAAiBA,EAAaP,EAAMQ,cAAgBsB,EAAE9B,EAAMQ,aAChG,OACEyB,yBAACC,EAAAA,mBAA8BC,QAAS,KAAOnC,EAAMoC,iBAAmBnC,EAAqB6B,GAC3FH,SAAA,GAAAb,kBAAAA,IAACuB,EAAAA,SAAA,CACCC,MAAOtC,EAAMuC,cACbC,eAAgBxC,EAAMyC,uBACtBC,KAAM1C,EAAM2C,aACZzB,GAAIlB,EAAM4C,WACVxB,KAAMpB,EAAMoB,KACZyB,QAASb,EACTV,KAAM,CACJF,MAAM,OAAAG,EAAAvB,EAAMsB,WAAN,EAAAC,EAAYH,OAAQI,EAAAA,cAAcxB,EAAMoB,MAAME,KACpDG,QAAQ,OAAAC,EAAA1B,EAAMsB,WAAN,EAAAI,EAAYD,SAAU,IAC9BqB,QAAQ,OAAAC,EAAA/C,EAAMsB,WAAN,EAAAyB,EAAYD,SAAUlC,EAAMU,KAAKwB,OACzCE,OAAQ,OAAAC,EAAAjD,EAAMsB,WAAN,EAAA2B,EAAYD,QAGrBrB,SAAA3B,EAAMkD,iBAAwC,KAA1B,MAAApB,OAAA,EAAAA,EAAI9B,EAAMkD,gBAC7BpC,kBAAAA,IAACqC,EAAAA,mBAAA,CAAmBC,yBA/CZC,EA+CkDvB,EAAE9B,EAAMkD,YA/C1D,CAAoBI,OAAQD,QAkDvCrD,EAAMuD,oBAA8C,KAA7B,MAAAzB,OAAA,EAAAA,EAAI9B,EAAMuD,iBAChCzC,wBAAC0C,EAAAA,iBAAA,CAAkB7B,SAAAG,EAAE9B,EAAMuD,mBApBPxB,GA/BX,IAACsB"}
1
+ {"version":3,"file":"component-C8ueaiSO.cjs","sources":["../src/components/checkbox-group/component.tsx"],"sourcesContent":["import { Checkbox } from '@local/components/checkbox';\nimport { KEY_SIZE_DATA } from '@local/theme';\n\nimport { ReactNode, useCallback } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport {\n CheckboxChildren,\n CheckboxGroupItem,\n CheckboxGroupLabel,\n CheckboxGroupProps,\n CheckboxGroupWrapper,\n ICheckboxValue,\n} from '.';\n\nexport const CheckboxGroup = <T extends ICheckboxValue>(props: CheckboxGroupProps<T>) => {\n const createMarkup = (html: string) => ({ __html: html });\n\n const handleCheckboxChange = useCallback(\n (item: T) => {\n const isSelected = props.value.some((selectedItem) => selectedItem[props.valueField] === item[props.valueField]);\n\n const updatedSelectedItems = isSelected\n ? props.value.filter((selectedItem) => selectedItem[props.valueField] !== item[props.valueField])\n : props.multiple\n ? [...props.value, item]\n : [item];\n if (props.onChange) props.onChange(updatedSelectedItems);\n },\n [props],\n );\n\n const theme = useTheme();\n return (\n <CheckboxGroupWrapper\n className={props.className}\n $sx={props.sx}\n $size={props.size}\n $font={{\n ...props.font,\n size: props.font?.size ?? KEY_SIZE_DATA[props.size].font,\n weight: props.font?.weight ?? 700,\n }}\n >\n {props.options.map((e, index) => {\n const isChecked = props.value.some((selectedItem) => selectedItem[props.valueField] === e[props.valueField]);\n return (\n <CheckboxGroupItem key={index} onClick={() => !props.isClickOnlyIcon && handleCheckboxChange(e)}>\n <Checkbox\n genre={props.checkboxGenre}\n isHiddenBorder={props.checkboxIsHiddenBorder}\n view={props.checkBoxView}\n sx={props.checkboxSX}\n size={props.size}\n checked={isChecked}\n font={{\n size: props.font?.size ?? KEY_SIZE_DATA[props.size].font,\n weight: props.font?.weight ?? 700,\n family: props.font?.family ?? theme.font.family,\n height: props.font?.height,\n }}\n >\n {props.labelField && e?.[props.labelField] !== undefined && (\n <CheckboxGroupLabel dangerouslySetInnerHTML={createMarkup(e[props.labelField] as string)} />\n )}\n </Checkbox>\n {props.childrenField && e?.[props.childrenField] !== undefined && (\n <CheckboxChildren>{e[props.childrenField] as ReactNode}</CheckboxChildren>\n )}\n </CheckboxGroupItem>\n );\n })}\n </CheckboxGroupWrapper>\n );\n};\n"],"names":["props","handleCheckboxChange","useCallback","item","updatedSelectedItems","value","some","selectedItem","valueField","filter","multiple","onChange","theme","useTheme","jsx","CheckboxGroupWrapper","className","$sx","sx","$size","size","$font","font","_a","KEY_SIZE_DATA","weight","_b","children","options","map","e","index","isChecked","jsxs","CheckboxGroupItem","onClick","isClickOnlyIcon","Checkbox","genre","checkboxGenre","isHiddenBorder","checkboxIsHiddenBorder","view","checkBoxView","checkboxSX","checked","family","_c","height","_d","labelField","CheckboxGroupLabel","dangerouslySetInnerHTML","html","__html","childrenField","CheckboxChildren"],"mappings":"uNAewDA,YACtD,MAEMC,EAAuBC,EAAAA,YAC1BC,IACC,MAEMC,EAFaJ,EAAMK,MAAMC,KAAMC,GAAiBA,EAAaP,EAAMQ,cAAgBL,EAAKH,EAAMQ,aAGhGR,EAAMK,MAAMI,OAAQF,GAAiBA,EAAaP,EAAMQ,cAAgBL,EAAKH,EAAMQ,aACnFR,EAAMU,SACJ,IAAIV,EAAMK,MAAOF,GACjB,CAACA,GACHH,EAAMW,UAAUX,EAAMW,SAASP,IAErC,CAACJ,IAGGY,EAAQC,EAAAA,WACd,SACEC,kBAAAA,IAACC,EAAAA,qBAAA,CACCC,UAAWhB,EAAMgB,UACjBC,IAAKjB,EAAMkB,GACXC,MAAOnB,EAAMoB,KACbC,MAAO,IACFrB,EAAMsB,KACTF,MAAM,OAAAG,IAAMD,WAAN,EAAAC,EAAYH,OAAQI,EAAAA,cAAcxB,EAAMoB,MAAME,KACpDG,QAAQ,OAAAC,EAAA1B,EAAMsB,WAAN,EAAAI,EAAYD,SAAU,KAG/BE,SAAA3B,EAAM4B,QAAQC,IAAI,CAACC,EAAGC,iBACrB,MAAMC,EAAYhC,EAAMK,MAAMC,KAAMC,GAAiBA,EAAaP,EAAMQ,cAAgBsB,EAAE9B,EAAMQ,aAChG,OACEyB,yBAACC,EAAAA,mBAA8BC,QAAS,KAAOnC,EAAMoC,iBAAmBnC,EAAqB6B,GAC3FH,SAAA,GAAAb,kBAAAA,IAACuB,EAAAA,SAAA,CACCC,MAAOtC,EAAMuC,cACbC,eAAgBxC,EAAMyC,uBACtBC,KAAM1C,EAAM2C,aACZzB,GAAIlB,EAAM4C,WACVxB,KAAMpB,EAAMoB,KACZyB,QAASb,EACTV,KAAM,CACJF,MAAM,OAAAG,EAAAvB,EAAMsB,WAAN,EAAAC,EAAYH,OAAQI,EAAAA,cAAcxB,EAAMoB,MAAME,KACpDG,QAAQ,OAAAC,EAAA1B,EAAMsB,WAAN,EAAAI,EAAYD,SAAU,IAC9BqB,QAAQ,OAAAC,EAAA/C,EAAMsB,WAAN,EAAAyB,EAAYD,SAAUlC,EAAMU,KAAKwB,OACzCE,OAAQ,OAAAC,EAAAjD,EAAMsB,WAAN,EAAA2B,EAAYD,QAGrBrB,SAAA3B,EAAMkD,iBAAwC,KAA1B,MAAApB,OAAA,EAAAA,EAAI9B,EAAMkD,gBAC7BpC,kBAAAA,IAACqC,EAAAA,mBAAA,CAAmBC,yBA/CZC,EA+CkDvB,EAAE9B,EAAMkD,YA/C1D,CAAoBI,OAAQD,QAkDvCrD,EAAMuD,oBAA8C,KAA7B,MAAAzB,OAAA,EAAAA,EAAI9B,EAAMuD,iBAChCzC,wBAAC0C,EAAAA,iBAAA,CAAkB7B,SAAAG,EAAE9B,EAAMuD,mBApBPxB,GA/BX,IAACsB"}
@@ -1,2 +1,2 @@
1
- "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),r=require("react"),n=require("styled-components"),s=require("./context.constants-p2bRkgM3.cjs");exports.Range=a=>{const{onChange:t}=a,o=r.useCallback((e,r)=>{const n=[...a.values];n[e]=Math.min(a.max,Math.max(a.min,r)),t(n.sort((e,r)=>e-r))},[t,a.max,a.min,a.values]),u=r.useCallback(e=>(e-a.min)/(a.max-a.min)*100,[a.max,a.min]),m=r.useMemo(()=>a.values.map(e=>u(e)),[u,a.values]),i=n.useTheme(),g=i.colors.range[a.genre].track.background.rest,c=i.colors.range[a.genre].track.gradient.rest,l=i.colors.range[a.genre].thumb.border.rest,x=i.colors.range[a.genre].thumb.background.rest,$=r.useMemo(()=>m.map((e,r)=>{const n=0===r,s=r===m.length-1;return n?`${g} 0%, ${g} ${e}%, ${c} ${e}%`:s?`${c} ${e}%, ${g} ${e}%, ${g} 100%`:`${c} ${e}%`}).join(", "),[c,g,m]),p=r.useMemo(()=>`linear-gradient(to right, ${$})`,[$]);return e.jsxRuntimeExports.jsxs(s.RangeWrapper,{$size:a.size,$sx:a.sx,$error:a.error,onBlur:a.onBlur,children:[a.values.map((r,n)=>e.jsxRuntimeExports.jsx(s.RangeThumb,{type:"range",$size:a.size,$genre:a.genre,min:a.min,max:a.max,step:a.step,value:r,onChange:e=>o(n,parseFloat(e.target.value)),style:{zIndex:100+n},$colorBackground:x,$colorBorder:l},n)),e.jsxRuntimeExports.jsx(s.RangeTrack,{$size:a.size,$genre:a.genre,style:{background:p}})]})};
2
- //# sourceMappingURL=component-COVO0g4K.cjs.map
1
+ "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),r=require("react"),n=require("styled-components"),s=require("./context.constants-BMJ3rLa_.cjs");exports.Range=a=>{const{onChange:t}=a,o=r.useCallback((e,r)=>{const n=[...a.values];n[e]=Math.min(a.max,Math.max(a.min,r)),t(n.sort((e,r)=>e-r))},[t,a.max,a.min,a.values]),u=r.useCallback(e=>(e-a.min)/(a.max-a.min)*100,[a.max,a.min]),m=r.useMemo(()=>a.values.map(e=>u(e)),[u,a.values]),i=n.useTheme(),g=i.colors.range[a.genre].track.background.rest,c=i.colors.range[a.genre].track.gradient.rest,l=i.colors.range[a.genre].thumb.border.rest,x=i.colors.range[a.genre].thumb.background.rest,$=r.useMemo(()=>m.map((e,r)=>{const n=0===r,s=r===m.length-1;return n?`${g} 0%, ${g} ${e}%, ${c} ${e}%`:s?`${c} ${e}%, ${g} ${e}%, ${g} 100%`:`${c} ${e}%`}).join(", "),[c,g,m]),p=r.useMemo(()=>`linear-gradient(to right, ${$})`,[$]);return e.jsxRuntimeExports.jsxs(s.RangeWrapper,{$size:a.size,$sx:a.sx,$error:a.error,onBlur:a.onBlur,children:[a.values.map((r,n)=>e.jsxRuntimeExports.jsx(s.RangeThumb,{type:"range",$size:a.size,$genre:a.genre,min:a.min,max:a.max,step:a.step,value:r,onChange:e=>o(n,parseFloat(e.target.value)),style:{zIndex:100+n},$colorBackground:x,$colorBorder:l},n)),e.jsxRuntimeExports.jsx(s.RangeTrack,{$size:a.size,$genre:a.genre,style:{background:p}})]})};
2
+ //# sourceMappingURL=component-CANbSEA3.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-COVO0g4K.cjs","sources":["../src/components/range/component.tsx"],"sourcesContent":["import { useCallback, useMemo } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { RangeProps, RangeThumb, RangeTrack, RangeWrapper } from '.';\n\nexport const Range = (props: RangeProps) => {\n const { onChange } = props;\n const handleChange = useCallback(\n (index: number, newValue: number) => {\n const newValues = [...props.values];\n newValues[index] = Math.min(props.max, Math.max(props.min, newValue));\n onChange(newValues.sort((a, b) => a - b));\n },\n [onChange, props.max, props.min, props.values],\n );\n const getThumbPositionPercent = useCallback(\n (val: number) => ((val - props.min) / (props.max - props.min)) * 100,\n [props.max, props.min],\n );\n const positions = useMemo(\n () => props.values.map((val) => getThumbPositionPercent(val)),\n [getThumbPositionPercent, props.values],\n );\n const theme = useTheme();\n\n const colorTrackBackground = theme.colors.range[props.genre].track.background.rest;\n const colorTrackGradient = theme.colors.range[props.genre].track.gradient.rest;\n const colorThumbBorder = theme.colors.range[props.genre].thumb.border.rest;\n const colorThumbBackground = theme.colors.range[props.genre].thumb.background.rest;\n\n const trackGradient = useMemo(\n () =>\n positions\n .map((position, idx) => {\n const isFirst = idx === 0;\n const isLast = idx === positions.length - 1;\n\n if (isFirst)\n return `${colorTrackBackground} 0%, ${colorTrackBackground} ${position}%, ${colorTrackGradient} ${position}%`;\n if (isLast)\n return `${colorTrackGradient} ${position}%, ${colorTrackBackground} ${position}%, ${colorTrackBackground} 100%`;\n return `${colorTrackGradient} ${position}%`;\n })\n .join(', '),\n [colorTrackGradient, colorTrackBackground, positions],\n );\n const gradient = useMemo(() => `linear-gradient(to right, ${trackGradient})`, [trackGradient]);\n\n return (\n <RangeWrapper $size={props.size} $sx={props.sx} $error={props.error} onBlur={props.onBlur}>\n {props.values.map((val, idx) => (\n <RangeThumb\n key={idx}\n type='range'\n $size={props.size}\n $genre={props.genre}\n min={props.min}\n max={props.max}\n step={props.step}\n value={val}\n onChange={(e) => handleChange(idx, parseFloat(e.target.value))}\n style={{ zIndex: 100 + idx }}\n $colorBackground={colorThumbBackground}\n $colorBorder={colorThumbBorder}\n />\n ))}\n <RangeTrack\n $size={props.size}\n $genre={props.genre}\n style={{\n background: gradient,\n }}\n />\n </RangeWrapper>\n );\n};\n"],"names":["props","onChange","handleChange","useCallback","index","newValue","newValues","values","Math","min","max","sort","a","b","getThumbPositionPercent","val","positions","useMemo","map","theme","useTheme","colorTrackBackground","colors","range","genre","track","background","rest","colorTrackGradient","gradient","colorThumbBorder","thumb","border","colorThumbBackground","trackGradient","position","idx","isFirst","isLast","length","join","jsxs","RangeWrapper","$size","size","$sx","sx","$error","error","onBlur","children","jsx","RangeThumb","type","$genre","step","value","e","parseFloat","target","style","zIndex","$colorBackground","$colorBorder","RangeTrack"],"mappings":"yKAKsBA,IACpB,MAAMC,SAAEA,GAAaD,EACfE,EAAeC,EAAAA,YACnB,CAACC,EAAeC,KACd,MAAMC,EAAY,IAAIN,EAAMO,QAC5BD,EAAUF,GAASI,KAAKC,IAAIT,EAAMU,IAAKF,KAAKE,IAAIV,EAAMS,IAAKJ,IAC3DJ,EAASK,EAAUK,KAAK,CAACC,EAAGC,IAAMD,EAAIC,KAExC,CAACZ,EAAUD,EAAMU,IAAKV,EAAMS,IAAKT,EAAMO,SAEnCO,EAA0BX,EAAAA,YAC7BY,IAAkBA,EAAMf,EAAMS,MAAQT,EAAMU,IAAMV,EAAMS,KAAQ,IACjE,CAACT,EAAMU,IAAKV,EAAMS,MAEdO,EAAYC,EAAAA,QAChB,IAAMjB,EAAMO,OAAOW,IAAKH,GAAQD,EAAwBC,IACxD,CAACD,EAAyBd,EAAMO,SAE5BY,EAAQC,EAAAA,WAERC,EAAuBF,EAAMG,OAAOC,MAAMvB,EAAMwB,OAAOC,MAAMC,WAAWC,KACxEC,EAAqBT,EAAMG,OAAOC,MAAMvB,EAAMwB,OAAOC,MAAMI,SAASF,KACpEG,EAAmBX,EAAMG,OAAOC,MAAMvB,EAAMwB,OAAOO,MAAMC,OAAOL,KAChEM,EAAuBd,EAAMG,OAAOC,MAAMvB,EAAMwB,OAAOO,MAAML,WAAWC,KAExEO,EAAgBjB,EAAAA,QACpB,IACED,EACGE,IAAI,CAACiB,EAAUC,KACd,MAAMC,EAAkB,IAARD,EACVE,EAASF,IAAQpB,EAAUuB,OAAS,EAE1C,OAAIF,EACK,GAAGhB,SAA4BA,KAAwBc,OAAcP,KAAsBO,KAChGG,EACK,GAAGV,KAAsBO,OAAcd,KAAwBc,OAAcd,SAC/E,GAAGO,KAAsBO,OAEjCK,KAAK,MACV,CAACZ,EAAoBP,EAAsBL,IAEvCa,EAAWZ,EAAAA,QAAQ,IAAM,6BAA6BiB,KAAkB,CAACA,IAE/E,SACEO,kBAAAA,KAACC,EAAAA,aAAA,CAAaC,MAAO3C,EAAM4C,KAAMC,IAAK7C,EAAM8C,GAAIC,OAAQ/C,EAAMgD,MAAOC,OAAQjD,EAAMiD,OAChFC,SAAA,CAAAlD,EAAMO,OAAOW,IAAI,CAACH,EAAKqB,MACtBe,kBAAAA,IAACC,EAAAA,WAAA,CAECC,KAAK,QACLV,MAAO3C,EAAM4C,KACbU,OAAQtD,EAAMwB,MACdf,IAAKT,EAAMS,IACXC,IAAKV,EAAMU,IACX6C,KAAMvD,EAAMuD,KACZC,MAAOzC,EACPd,SAAWwD,GAAMvD,EAAakC,EAAKsB,WAAWD,EAAEE,OAAOH,QACvDI,MAAO,CAAEC,OAAQ,IAAMzB,GACvB0B,iBAAkB7B,EAClB8B,aAAcjC,GAXTM,MAcTe,kBAAAA,IAACa,EAAAA,WAAA,CACCrB,MAAO3C,EAAM4C,KACbU,OAAQtD,EAAMwB,MACdoC,MAAO,CACLlC,WAAYG"}
1
+ {"version":3,"file":"component-CANbSEA3.cjs","sources":["../src/components/range/component.tsx"],"sourcesContent":["import { useCallback, useMemo } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { RangeProps, RangeThumb, RangeTrack, RangeWrapper } from '.';\n\nexport const Range = (props: RangeProps) => {\n const { onChange } = props;\n const handleChange = useCallback(\n (index: number, newValue: number) => {\n const newValues = [...props.values];\n newValues[index] = Math.min(props.max, Math.max(props.min, newValue));\n onChange(newValues.sort((a, b) => a - b));\n },\n [onChange, props.max, props.min, props.values],\n );\n const getThumbPositionPercent = useCallback(\n (val: number) => ((val - props.min) / (props.max - props.min)) * 100,\n [props.max, props.min],\n );\n const positions = useMemo(\n () => props.values.map((val) => getThumbPositionPercent(val)),\n [getThumbPositionPercent, props.values],\n );\n const theme = useTheme();\n\n const colorTrackBackground = theme.colors.range[props.genre].track.background.rest;\n const colorTrackGradient = theme.colors.range[props.genre].track.gradient.rest;\n const colorThumbBorder = theme.colors.range[props.genre].thumb.border.rest;\n const colorThumbBackground = theme.colors.range[props.genre].thumb.background.rest;\n\n const trackGradient = useMemo(\n () =>\n positions\n .map((position, idx) => {\n const isFirst = idx === 0;\n const isLast = idx === positions.length - 1;\n\n if (isFirst)\n return `${colorTrackBackground} 0%, ${colorTrackBackground} ${position}%, ${colorTrackGradient} ${position}%`;\n if (isLast)\n return `${colorTrackGradient} ${position}%, ${colorTrackBackground} ${position}%, ${colorTrackBackground} 100%`;\n return `${colorTrackGradient} ${position}%`;\n })\n .join(', '),\n [colorTrackGradient, colorTrackBackground, positions],\n );\n const gradient = useMemo(() => `linear-gradient(to right, ${trackGradient})`, [trackGradient]);\n\n return (\n <RangeWrapper $size={props.size} $sx={props.sx} $error={props.error} onBlur={props.onBlur}>\n {props.values.map((val, idx) => (\n <RangeThumb\n key={idx}\n type='range'\n $size={props.size}\n $genre={props.genre}\n min={props.min}\n max={props.max}\n step={props.step}\n value={val}\n onChange={(e) => handleChange(idx, parseFloat(e.target.value))}\n style={{ zIndex: 100 + idx }}\n $colorBackground={colorThumbBackground}\n $colorBorder={colorThumbBorder}\n />\n ))}\n <RangeTrack\n $size={props.size}\n $genre={props.genre}\n style={{\n background: gradient,\n }}\n />\n </RangeWrapper>\n );\n};\n"],"names":["props","onChange","handleChange","useCallback","index","newValue","newValues","values","Math","min","max","sort","a","b","getThumbPositionPercent","val","positions","useMemo","map","theme","useTheme","colorTrackBackground","colors","range","genre","track","background","rest","colorTrackGradient","gradient","colorThumbBorder","thumb","border","colorThumbBackground","trackGradient","position","idx","isFirst","isLast","length","join","jsxs","RangeWrapper","$size","size","$sx","sx","$error","error","onBlur","children","jsx","RangeThumb","type","$genre","step","value","e","parseFloat","target","style","zIndex","$colorBackground","$colorBorder","RangeTrack"],"mappings":"yKAKsBA,IACpB,MAAMC,SAAEA,GAAaD,EACfE,EAAeC,EAAAA,YACnB,CAACC,EAAeC,KACd,MAAMC,EAAY,IAAIN,EAAMO,QAC5BD,EAAUF,GAASI,KAAKC,IAAIT,EAAMU,IAAKF,KAAKE,IAAIV,EAAMS,IAAKJ,IAC3DJ,EAASK,EAAUK,KAAK,CAACC,EAAGC,IAAMD,EAAIC,KAExC,CAACZ,EAAUD,EAAMU,IAAKV,EAAMS,IAAKT,EAAMO,SAEnCO,EAA0BX,EAAAA,YAC7BY,IAAkBA,EAAMf,EAAMS,MAAQT,EAAMU,IAAMV,EAAMS,KAAQ,IACjE,CAACT,EAAMU,IAAKV,EAAMS,MAEdO,EAAYC,EAAAA,QAChB,IAAMjB,EAAMO,OAAOW,IAAKH,GAAQD,EAAwBC,IACxD,CAACD,EAAyBd,EAAMO,SAE5BY,EAAQC,EAAAA,WAERC,EAAuBF,EAAMG,OAAOC,MAAMvB,EAAMwB,OAAOC,MAAMC,WAAWC,KACxEC,EAAqBT,EAAMG,OAAOC,MAAMvB,EAAMwB,OAAOC,MAAMI,SAASF,KACpEG,EAAmBX,EAAMG,OAAOC,MAAMvB,EAAMwB,OAAOO,MAAMC,OAAOL,KAChEM,EAAuBd,EAAMG,OAAOC,MAAMvB,EAAMwB,OAAOO,MAAML,WAAWC,KAExEO,EAAgBjB,EAAAA,QACpB,IACED,EACGE,IAAI,CAACiB,EAAUC,KACd,MAAMC,EAAkB,IAARD,EACVE,EAASF,IAAQpB,EAAUuB,OAAS,EAE1C,OAAIF,EACK,GAAGhB,SAA4BA,KAAwBc,OAAcP,KAAsBO,KAChGG,EACK,GAAGV,KAAsBO,OAAcd,KAAwBc,OAAcd,SAC/E,GAAGO,KAAsBO,OAEjCK,KAAK,MACV,CAACZ,EAAoBP,EAAsBL,IAEvCa,EAAWZ,EAAAA,QAAQ,IAAM,6BAA6BiB,KAAkB,CAACA,IAE/E,SACEO,kBAAAA,KAACC,EAAAA,aAAA,CAAaC,MAAO3C,EAAM4C,KAAMC,IAAK7C,EAAM8C,GAAIC,OAAQ/C,EAAMgD,MAAOC,OAAQjD,EAAMiD,OAChFC,SAAA,CAAAlD,EAAMO,OAAOW,IAAI,CAACH,EAAKqB,MACtBe,kBAAAA,IAACC,EAAAA,WAAA,CAECC,KAAK,QACLV,MAAO3C,EAAM4C,KACbU,OAAQtD,EAAMwB,MACdf,IAAKT,EAAMS,IACXC,IAAKV,EAAMU,IACX6C,KAAMvD,EAAMuD,KACZC,MAAOzC,EACPd,SAAWwD,GAAMvD,EAAakC,EAAKsB,WAAWD,EAAEE,OAAOH,QACvDI,MAAO,CAAEC,OAAQ,IAAMzB,GACvB0B,iBAAkB7B,EAClB8B,aAAcjC,GAXTM,MAcTe,kBAAAA,IAACa,EAAAA,WAAA,CACCrB,MAAO3C,EAAM4C,KACbU,OAAQtD,EAAMwB,MACdoC,MAAO,CACLlC,WAAYG"}
@@ -1,7 +1,7 @@
1
1
  import { j as jsxRuntimeExports } from "./jsx-runtime-BrDlu8eK.js";
2
2
  import { b as Stack } from "./component-DEZX8aBs.js";
3
3
  import { useCallback } from "react";
4
- import { A as AccordionWrapper, b as AccordionSummary, c as AccordionSummaryContent, e as AccordionStyledIcon, d as AccordionDetails } from "./context.constants-Dop398a2.js";
4
+ import { A as AccordionWrapper, b as AccordionSummary, c as AccordionSummaryContent, e as AccordionStyledIcon, d as AccordionDetails } from "./context.constants-YlWOZAd7.js";
5
5
  const Accordion = (props) => {
6
6
  const onClickSummary = useCallback(() => {
7
7
  if (props.onClickSummary) props.onClickSummary();
@@ -36,4 +36,4 @@ const Accordion = (props) => {
36
36
  export {
37
37
  Accordion as A
38
38
  };
39
- //# sourceMappingURL=component-BJxTgP87.js.map
39
+ //# sourceMappingURL=component-CATlnN8o.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-BJxTgP87.js","sources":["../src/components/accordion/component.tsx"],"sourcesContent":["import { Stack } from '@local/components/stack';\n\nimport React, { FC, useCallback } from 'react';\n\nimport {\n AccordionDetails,\n AccordionProps,\n AccordionStyledIcon,\n AccordionSummary,\n AccordionSummaryContent,\n AccordionWrapper,\n} from '.';\n\nexport const Accordion: FC<AccordionProps> = (props) => {\n const onClickSummary = useCallback(() => {\n if (props.onClickSummary) props.onClickSummary();\n }, [props]);\n\n const onClickIcon = useCallback(\n (event: React.MouseEvent<SVGSVGElement>) => {\n if (props.onClickIcon) {\n event.stopPropagation();\n\n props.onClickIcon();\n }\n },\n [props],\n );\n\n return (\n <Stack {...props.wrapperProps}>\n <AccordionWrapper>\n <AccordionSummary onClick={onClickSummary}>\n <AccordionSummaryContent $isAccordionIcon={props.isAccordionIcon}>\n {props.accordionSummary}\n </AccordionSummaryContent>\n {props.isAccordionIcon && (\n <AccordionStyledIcon\n $expanded={props.expanded}\n onClick={onClickIcon}\n name='Arrow1'\n color='black100'\n type='id'\n size='large'\n />\n )}\n </AccordionSummary>\n <AccordionDetails $expanded={props.expanded}>{props.accordionDetails}</AccordionDetails>\n </AccordionWrapper>\n </Stack>\n );\n};\n"],"names":["jsxs","jsx"],"mappings":";;;;AAaO,MAAM,YAAgC,CAAC,UAAU;AACtD,QAAM,iBAAiB,YAAY,MAAM;AACvC,QAAI,MAAM,eAAgB,OAAM,eAAA;AAAA,EAAe,GAC9C,CAAC,KAAK,CAAC;AAEV,QAAM,cAAc;AAAA,IAClB,CAAC,UAA2C;AAC1C,UAAI,MAAM,aAAa;AACrB,cAAM,gBAAA;AAEN,cAAM,YAAA;AAAA,MAAY;AAAA,IACpB;AAAA,IAEF,CAAC,KAAK;AAAA,EAAA;AAGR,+CACG,OAAA,EAAO,GAAG,MAAM,cACf,iDAAC,kBAAA,EACC,UAAA;AAAA,IAAAA,kCAAAA,KAAC,kBAAA,EAAiB,SAAS,gBACzB,UAAA;AAAA,MAAAC,sCAAC,yBAAA,EAAwB,kBAAkB,MAAM,iBAC9C,gBAAM,kBACT;AAAA,MACC,MAAM,mBACLA,kCAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAW,MAAM;AAAA,UACjB,SAAS;AAAA,UACT,MAAK;AAAA,UACL,OAAM;AAAA,UACN,MAAK;AAAA,UACL,MAAK;AAAA,QAAA;AAAA,MAAA;AAAA,IACP,GAEJ;AAAA,0CACC,kBAAA,EAAiB,WAAW,MAAM,UAAW,gBAAM,iBAAA,CAAiB;AAAA,EAAA,EAAA,CACvE,EAAA,CACF;AAEJ;"}
1
+ {"version":3,"file":"component-CATlnN8o.js","sources":["../src/components/accordion/component.tsx"],"sourcesContent":["import { Stack } from '@local/components/stack';\n\nimport React, { FC, useCallback } from 'react';\n\nimport {\n AccordionDetails,\n AccordionProps,\n AccordionStyledIcon,\n AccordionSummary,\n AccordionSummaryContent,\n AccordionWrapper,\n} from '.';\n\nexport const Accordion: FC<AccordionProps> = (props) => {\n const onClickSummary = useCallback(() => {\n if (props.onClickSummary) props.onClickSummary();\n }, [props]);\n\n const onClickIcon = useCallback(\n (event: React.MouseEvent<SVGSVGElement>) => {\n if (props.onClickIcon) {\n event.stopPropagation();\n\n props.onClickIcon();\n }\n },\n [props],\n );\n\n return (\n <Stack {...props.wrapperProps}>\n <AccordionWrapper>\n <AccordionSummary onClick={onClickSummary}>\n <AccordionSummaryContent $isAccordionIcon={props.isAccordionIcon}>\n {props.accordionSummary}\n </AccordionSummaryContent>\n {props.isAccordionIcon && (\n <AccordionStyledIcon\n $expanded={props.expanded}\n onClick={onClickIcon}\n name='Arrow1'\n color='black100'\n type='id'\n size='large'\n />\n )}\n </AccordionSummary>\n <AccordionDetails $expanded={props.expanded}>{props.accordionDetails}</AccordionDetails>\n </AccordionWrapper>\n </Stack>\n );\n};\n"],"names":["jsxs","jsx"],"mappings":";;;;AAaO,MAAM,YAAgC,CAAC,UAAU;AACtD,QAAM,iBAAiB,YAAY,MAAM;AACvC,QAAI,MAAM,eAAgB,OAAM,eAAA;AAAA,EAAe,GAC9C,CAAC,KAAK,CAAC;AAEV,QAAM,cAAc;AAAA,IAClB,CAAC,UAA2C;AAC1C,UAAI,MAAM,aAAa;AACrB,cAAM,gBAAA;AAEN,cAAM,YAAA;AAAA,MAAY;AAAA,IACpB;AAAA,IAEF,CAAC,KAAK;AAAA,EAAA;AAGR,+CACG,OAAA,EAAO,GAAG,MAAM,cACf,iDAAC,kBAAA,EACC,UAAA;AAAA,IAAAA,kCAAAA,KAAC,kBAAA,EAAiB,SAAS,gBACzB,UAAA;AAAA,MAAAC,sCAAC,yBAAA,EAAwB,kBAAkB,MAAM,iBAC9C,gBAAM,kBACT;AAAA,MACC,MAAM,mBACLA,kCAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAW,MAAM;AAAA,UACjB,SAAS;AAAA,UACT,MAAK;AAAA,UACL,OAAM;AAAA,UACN,MAAK;AAAA,UACL,MAAK;AAAA,QAAA;AAAA,MAAA;AAAA,IACP,GAEJ;AAAA,0CACC,kBAAA,EAAiB,WAAW,MAAM,UAAW,gBAAM,iBAAA,CAAiB;AAAA,EAAA,EAAA,CACvE,EAAA,CACF;AAEJ;"}
@@ -1,7 +1,7 @@
1
1
  import { j as jsxRuntimeExports } from "./jsx-runtime-BrDlu8eK.js";
2
2
  import { useCallback, useMemo } from "react";
3
3
  import { useTheme } from "styled-components";
4
- import { aj as RangeWrapper, al as RangeThumb, ak as RangeTrack } from "./context.constants-Dop398a2.js";
4
+ import { aj as RangeWrapper, al as RangeThumb, ak as RangeTrack } from "./context.constants-YlWOZAd7.js";
5
5
  const Range = (props) => {
6
6
  const { onChange } = props;
7
7
  const handleChange = useCallback(
@@ -71,4 +71,4 @@ const Range = (props) => {
71
71
  export {
72
72
  Range as R
73
73
  };
74
- //# sourceMappingURL=component-CJ_IYmXp.js.map
74
+ //# sourceMappingURL=component-CGPZf0Mx.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-CJ_IYmXp.js","sources":["../src/components/range/component.tsx"],"sourcesContent":["import { useCallback, useMemo } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { RangeProps, RangeThumb, RangeTrack, RangeWrapper } from '.';\n\nexport const Range = (props: RangeProps) => {\n const { onChange } = props;\n const handleChange = useCallback(\n (index: number, newValue: number) => {\n const newValues = [...props.values];\n newValues[index] = Math.min(props.max, Math.max(props.min, newValue));\n onChange(newValues.sort((a, b) => a - b));\n },\n [onChange, props.max, props.min, props.values],\n );\n const getThumbPositionPercent = useCallback(\n (val: number) => ((val - props.min) / (props.max - props.min)) * 100,\n [props.max, props.min],\n );\n const positions = useMemo(\n () => props.values.map((val) => getThumbPositionPercent(val)),\n [getThumbPositionPercent, props.values],\n );\n const theme = useTheme();\n\n const colorTrackBackground = theme.colors.range[props.genre].track.background.rest;\n const colorTrackGradient = theme.colors.range[props.genre].track.gradient.rest;\n const colorThumbBorder = theme.colors.range[props.genre].thumb.border.rest;\n const colorThumbBackground = theme.colors.range[props.genre].thumb.background.rest;\n\n const trackGradient = useMemo(\n () =>\n positions\n .map((position, idx) => {\n const isFirst = idx === 0;\n const isLast = idx === positions.length - 1;\n\n if (isFirst)\n return `${colorTrackBackground} 0%, ${colorTrackBackground} ${position}%, ${colorTrackGradient} ${position}%`;\n if (isLast)\n return `${colorTrackGradient} ${position}%, ${colorTrackBackground} ${position}%, ${colorTrackBackground} 100%`;\n return `${colorTrackGradient} ${position}%`;\n })\n .join(', '),\n [colorTrackGradient, colorTrackBackground, positions],\n );\n const gradient = useMemo(() => `linear-gradient(to right, ${trackGradient})`, [trackGradient]);\n\n return (\n <RangeWrapper $size={props.size} $sx={props.sx} $error={props.error} onBlur={props.onBlur}>\n {props.values.map((val, idx) => (\n <RangeThumb\n key={idx}\n type='range'\n $size={props.size}\n $genre={props.genre}\n min={props.min}\n max={props.max}\n step={props.step}\n value={val}\n onChange={(e) => handleChange(idx, parseFloat(e.target.value))}\n style={{ zIndex: 100 + idx }}\n $colorBackground={colorThumbBackground}\n $colorBorder={colorThumbBorder}\n />\n ))}\n <RangeTrack\n $size={props.size}\n $genre={props.genre}\n style={{\n background: gradient,\n }}\n />\n </RangeWrapper>\n );\n};\n"],"names":["jsxs","jsx"],"mappings":";;;;AAKO,MAAM,QAAQ,CAAC,UAAsB;AAC1C,QAAM,EAAE,aAAa;AACrB,QAAM,eAAe;AAAA,IACnB,CAAC,OAAe,aAAqB;AACnC,YAAM,YAAY,CAAC,GAAG,MAAM,MAAM;AAClC,gBAAU,KAAK,IAAI,KAAK,IAAI,MAAM,KAAK,KAAK,IAAI,MAAM,KAAK,QAAQ,CAAC;AACpE,eAAS,UAAU,KAAK,CAAC,GAAG,MAAM,IAAI,CAAC,CAAC;AAAA,IAAA;AAAA,IAE1C,CAAC,UAAU,MAAM,KAAK,MAAM,KAAK,MAAM,MAAM;AAAA,EAAA;AAE/C,QAAM,0BAA0B;AAAA,IAC9B,CAAC,SAAkB,MAAM,MAAM,QAAQ,MAAM,MAAM,MAAM,OAAQ;AAAA,IACjE,CAAC,MAAM,KAAK,MAAM,GAAG;AAAA,EAAA;AAEvB,QAAM,YAAY;AAAA,IAChB,MAAM,MAAM,OAAO,IAAI,CAAC,QAAQ,wBAAwB,GAAG,CAAC;AAAA,IAC5D,CAAC,yBAAyB,MAAM,MAAM;AAAA,EAAA;AAExC,QAAM,QAAQ,SAAA;AAEd,QAAM,uBAAuB,MAAM,OAAO,MAAM,MAAM,KAAK,EAAE,MAAM,WAAW;AAC9E,QAAM,qBAAqB,MAAM,OAAO,MAAM,MAAM,KAAK,EAAE,MAAM,SAAS;AAC1E,QAAM,mBAAmB,MAAM,OAAO,MAAM,MAAM,KAAK,EAAE,MAAM,OAAO;AACtE,QAAM,uBAAuB,MAAM,OAAO,MAAM,MAAM,KAAK,EAAE,MAAM,WAAW;AAE9E,QAAM,gBAAgB;AAAA,IACpB,MACE,UACG,IAAI,CAAC,UAAU,QAAQ;AACtB,YAAM,UAAU,QAAQ;AACxB,YAAM,SAAS,QAAQ,UAAU,SAAS;AAE1C,UAAI;AACF,eAAO,GAAG,oBAAoB,QAAQ,oBAAoB,IAAI,QAAQ,MAAM,kBAAkB,IAAI,QAAQ;AAC5G,UAAI;AACF,eAAO,GAAG,kBAAkB,IAAI,QAAQ,MAAM,oBAAoB,IAAI,QAAQ,MAAM,oBAAoB;AAC1G,aAAO,GAAG,kBAAkB,IAAI,QAAQ;AAAA,IAAA,CACzC,EACA,KAAK,IAAI;AAAA,IACd,CAAC,oBAAoB,sBAAsB,SAAS;AAAA,EAAA;AAEtD,QAAM,WAAW,QAAQ,MAAM,6BAA6B,aAAa,KAAK,CAAC,aAAa,CAAC;AAE7F,SACEA,kCAAAA,KAAC,cAAA,EAAa,OAAO,MAAM,MAAM,KAAK,MAAM,IAAI,QAAQ,MAAM,OAAO,QAAQ,MAAM,QAChF,UAAA;AAAA,IAAA,MAAM,OAAO,IAAI,CAAC,KAAK,QACtBC,kCAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QAEC,MAAK;AAAA,QACL,OAAO,MAAM;AAAA,QACb,QAAQ,MAAM;AAAA,QACd,KAAK,MAAM;AAAA,QACX,KAAK,MAAM;AAAA,QACX,MAAM,MAAM;AAAA,QACZ,OAAO;AAAA,QACP,UAAU,CAAC,MAAM,aAAa,KAAK,WAAW,EAAE,OAAO,KAAK,CAAC;AAAA,QAC7D,OAAO,EAAE,QAAQ,MAAM,IAAA;AAAA,QACvB,kBAAkB;AAAA,QAClB,cAAc;AAAA,MAAA;AAAA,MAXT;AAAA,IAAA,CAaR;AAAA,IACDA,kCAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACC,OAAO,MAAM;AAAA,QACb,QAAQ,MAAM;AAAA,QACd,OAAO;AAAA,UACL,YAAY;AAAA,QAAA;AAAA,MACd;AAAA,IAAA;AAAA,EACF,GACF;AAEJ;"}
1
+ {"version":3,"file":"component-CGPZf0Mx.js","sources":["../src/components/range/component.tsx"],"sourcesContent":["import { useCallback, useMemo } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { RangeProps, RangeThumb, RangeTrack, RangeWrapper } from '.';\n\nexport const Range = (props: RangeProps) => {\n const { onChange } = props;\n const handleChange = useCallback(\n (index: number, newValue: number) => {\n const newValues = [...props.values];\n newValues[index] = Math.min(props.max, Math.max(props.min, newValue));\n onChange(newValues.sort((a, b) => a - b));\n },\n [onChange, props.max, props.min, props.values],\n );\n const getThumbPositionPercent = useCallback(\n (val: number) => ((val - props.min) / (props.max - props.min)) * 100,\n [props.max, props.min],\n );\n const positions = useMemo(\n () => props.values.map((val) => getThumbPositionPercent(val)),\n [getThumbPositionPercent, props.values],\n );\n const theme = useTheme();\n\n const colorTrackBackground = theme.colors.range[props.genre].track.background.rest;\n const colorTrackGradient = theme.colors.range[props.genre].track.gradient.rest;\n const colorThumbBorder = theme.colors.range[props.genre].thumb.border.rest;\n const colorThumbBackground = theme.colors.range[props.genre].thumb.background.rest;\n\n const trackGradient = useMemo(\n () =>\n positions\n .map((position, idx) => {\n const isFirst = idx === 0;\n const isLast = idx === positions.length - 1;\n\n if (isFirst)\n return `${colorTrackBackground} 0%, ${colorTrackBackground} ${position}%, ${colorTrackGradient} ${position}%`;\n if (isLast)\n return `${colorTrackGradient} ${position}%, ${colorTrackBackground} ${position}%, ${colorTrackBackground} 100%`;\n return `${colorTrackGradient} ${position}%`;\n })\n .join(', '),\n [colorTrackGradient, colorTrackBackground, positions],\n );\n const gradient = useMemo(() => `linear-gradient(to right, ${trackGradient})`, [trackGradient]);\n\n return (\n <RangeWrapper $size={props.size} $sx={props.sx} $error={props.error} onBlur={props.onBlur}>\n {props.values.map((val, idx) => (\n <RangeThumb\n key={idx}\n type='range'\n $size={props.size}\n $genre={props.genre}\n min={props.min}\n max={props.max}\n step={props.step}\n value={val}\n onChange={(e) => handleChange(idx, parseFloat(e.target.value))}\n style={{ zIndex: 100 + idx }}\n $colorBackground={colorThumbBackground}\n $colorBorder={colorThumbBorder}\n />\n ))}\n <RangeTrack\n $size={props.size}\n $genre={props.genre}\n style={{\n background: gradient,\n }}\n />\n </RangeWrapper>\n );\n};\n"],"names":["jsxs","jsx"],"mappings":";;;;AAKO,MAAM,QAAQ,CAAC,UAAsB;AAC1C,QAAM,EAAE,aAAa;AACrB,QAAM,eAAe;AAAA,IACnB,CAAC,OAAe,aAAqB;AACnC,YAAM,YAAY,CAAC,GAAG,MAAM,MAAM;AAClC,gBAAU,KAAK,IAAI,KAAK,IAAI,MAAM,KAAK,KAAK,IAAI,MAAM,KAAK,QAAQ,CAAC;AACpE,eAAS,UAAU,KAAK,CAAC,GAAG,MAAM,IAAI,CAAC,CAAC;AAAA,IAAA;AAAA,IAE1C,CAAC,UAAU,MAAM,KAAK,MAAM,KAAK,MAAM,MAAM;AAAA,EAAA;AAE/C,QAAM,0BAA0B;AAAA,IAC9B,CAAC,SAAkB,MAAM,MAAM,QAAQ,MAAM,MAAM,MAAM,OAAQ;AAAA,IACjE,CAAC,MAAM,KAAK,MAAM,GAAG;AAAA,EAAA;AAEvB,QAAM,YAAY;AAAA,IAChB,MAAM,MAAM,OAAO,IAAI,CAAC,QAAQ,wBAAwB,GAAG,CAAC;AAAA,IAC5D,CAAC,yBAAyB,MAAM,MAAM;AAAA,EAAA;AAExC,QAAM,QAAQ,SAAA;AAEd,QAAM,uBAAuB,MAAM,OAAO,MAAM,MAAM,KAAK,EAAE,MAAM,WAAW;AAC9E,QAAM,qBAAqB,MAAM,OAAO,MAAM,MAAM,KAAK,EAAE,MAAM,SAAS;AAC1E,QAAM,mBAAmB,MAAM,OAAO,MAAM,MAAM,KAAK,EAAE,MAAM,OAAO;AACtE,QAAM,uBAAuB,MAAM,OAAO,MAAM,MAAM,KAAK,EAAE,MAAM,WAAW;AAE9E,QAAM,gBAAgB;AAAA,IACpB,MACE,UACG,IAAI,CAAC,UAAU,QAAQ;AACtB,YAAM,UAAU,QAAQ;AACxB,YAAM,SAAS,QAAQ,UAAU,SAAS;AAE1C,UAAI;AACF,eAAO,GAAG,oBAAoB,QAAQ,oBAAoB,IAAI,QAAQ,MAAM,kBAAkB,IAAI,QAAQ;AAC5G,UAAI;AACF,eAAO,GAAG,kBAAkB,IAAI,QAAQ,MAAM,oBAAoB,IAAI,QAAQ,MAAM,oBAAoB;AAC1G,aAAO,GAAG,kBAAkB,IAAI,QAAQ;AAAA,IAAA,CACzC,EACA,KAAK,IAAI;AAAA,IACd,CAAC,oBAAoB,sBAAsB,SAAS;AAAA,EAAA;AAEtD,QAAM,WAAW,QAAQ,MAAM,6BAA6B,aAAa,KAAK,CAAC,aAAa,CAAC;AAE7F,SACEA,kCAAAA,KAAC,cAAA,EAAa,OAAO,MAAM,MAAM,KAAK,MAAM,IAAI,QAAQ,MAAM,OAAO,QAAQ,MAAM,QAChF,UAAA;AAAA,IAAA,MAAM,OAAO,IAAI,CAAC,KAAK,QACtBC,kCAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QAEC,MAAK;AAAA,QACL,OAAO,MAAM;AAAA,QACb,QAAQ,MAAM;AAAA,QACd,KAAK,MAAM;AAAA,QACX,KAAK,MAAM;AAAA,QACX,MAAM,MAAM;AAAA,QACZ,OAAO;AAAA,QACP,UAAU,CAAC,MAAM,aAAa,KAAK,WAAW,EAAE,OAAO,KAAK,CAAC;AAAA,QAC7D,OAAO,EAAE,QAAQ,MAAM,IAAA;AAAA,QACvB,kBAAkB;AAAA,QAClB,cAAc;AAAA,MAAA;AAAA,MAXT;AAAA,IAAA,CAaR;AAAA,IACDA,kCAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACC,OAAO,MAAM;AAAA,QACb,QAAQ,MAAM;AAAA,QACd,OAAO;AAAA,UACL,YAAY;AAAA,QAAA;AAAA,MACd;AAAA,IAAA;AAAA,EACF,GACF;AAEJ;"}
@@ -1,2 +1,2 @@
1
- "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),t=require("./consts.cjs.js"),n=require("./use-CHyIgo-M.cjs"),s=require("react"),l=require("./context.constants-p2bRkgM3.cjs");exports.ImageButton=r=>{const i=s.useRef(null),u=s.useCallback(()=>{var e;null==(e=i.current)||e.click()},[]),{handleAddFiles:o}=n.useImageCrop({onSave:r.onSave,locale:r.locale,dialog:r.dialog,imageSettings:r.imageSettings,refInput:i});return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(l.Button,{...r.button,onClick:e=>{var t,n;null==(n=(t=r.button).onClick)||n.call(t,e),u()},children:r.button.children||r.locale.buttonAdd}),e.jsxRuntimeExports.jsx("input",{ref:i,type:"file",accept:t.LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT,multiple:!0,style:{display:"none"},onChange:e=>{e.target.files&&o(e.target.files)}})]})};
2
- //# sourceMappingURL=component-BkAJZ9bN.cjs.map
1
+ "use strict";const e=require("./jsx-runtime-BcGej2Kr.cjs"),t=require("./consts.cjs.js"),n=require("./use-DZU4NdpU.cjs"),s=require("react"),l=require("./context.constants-BMJ3rLa_.cjs");exports.ImageButton=r=>{const i=s.useRef(null),u=s.useCallback(()=>{var e;null==(e=i.current)||e.click()},[]),{handleAddFiles:o}=n.useImageCrop({onSave:r.onSave,locale:r.locale,dialog:r.dialog,imageSettings:r.imageSettings,refInput:i});return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(l.Button,{...r.button,onClick:e=>{var t,n;null==(n=(t=r.button).onClick)||n.call(t,e),u()},children:r.button.children||r.locale.buttonAdd}),e.jsxRuntimeExports.jsx("input",{ref:i,type:"file",accept:t.LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT,multiple:!0,style:{display:"none"},onChange:e=>{e.target.files&&o(e.target.files)}})]})};
2
+ //# sourceMappingURL=component-CM4bf3RV.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"component-BkAJZ9bN.cjs","sources":["../src/components/image-button/component.tsx"],"sourcesContent":["import { LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT } from '@local/consts';\nimport { useImageCrop } from '@local/hooks/use-image-crop';\n\nimport { FC, useCallback, useRef } from 'react';\n\nimport { Button } from '../button';\nimport { ImageButtonProps } from '.';\n\nexport const ImageButton: FC<ImageButtonProps> = (props) => {\n const refInput = useRef<HTMLInputElement | null>(null);\n\n const handleOpenFileDialog = useCallback(() => {\n refInput.current?.click();\n }, []);\n\n const { handleAddFiles } = useImageCrop({\n onSave: props.onSave,\n locale: props.locale,\n dialog: props.dialog,\n imageSettings: props.imageSettings,\n refInput: refInput,\n });\n\n return (\n <>\n <Button\n {...props.button}\n onClick={(e) => {\n props.button.onClick?.(e);\n handleOpenFileDialog();\n }}\n >\n {props.button.children || props.locale.buttonAdd}\n </Button>\n <input\n ref={refInput}\n type='file'\n accept={LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT}\n multiple\n style={{ display: 'none' }}\n onChange={(e) => {\n if (e.target.files) handleAddFiles(e.target.files);\n }}\n />\n </>\n );\n};\n"],"names":["props","refInput","useRef","handleOpenFileDialog","useCallback","_a","current","click","handleAddFiles","useImageCrop","onSave","locale","dialog","imageSettings","jsxs","Fragment","children","jsx","Button","button","onClick","e","_b","call","buttonAdd","ref","type","accept","LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT","multiple","style","display","onChange","target","files"],"mappings":"6MAQkDA,IAChD,MAAMC,EAAWC,EAAAA,OAAgC,MAE3CC,EAAuBC,EAAAA,YAAY,WACvC,OAAAC,EAAAJ,EAASK,UAATD,EAAkBE,SACjB,KAEGC,eAAEA,GAAmBC,eAAa,CACtCC,OAAQV,EAAMU,OACdC,OAAQX,EAAMW,OACdC,OAAQZ,EAAMY,OACdC,cAAeb,EAAMa,cACrBZ,aAGF,SACEa,kBAAAA,KAAAC,6BAAA,CACEC,SAAA,GAAAC,kBAAAA,IAACC,EAAAA,OAAA,IACKlB,EAAMmB,OACVC,QAAUC,YACR,OAAAC,GAAAjB,EAAAL,EAAMmB,QAAOC,UAAbE,EAAAC,KAAAlB,EAAuBgB,GACvBlB,KAGDa,SAAAhB,EAAMmB,OAAOH,UAAYhB,EAAMW,OAAOa,cAEzCP,kBAAAA,IAAC,QAAA,CACCQ,IAAKxB,EACLyB,KAAK,OACLC,OAAQC,EAAAA,sCACRC,UAAQ,EACRC,MAAO,CAAEC,QAAS,QAClBC,SAAWX,IACLA,EAAEY,OAAOC,OAAO1B,EAAea,EAAEY,OAAOC"}
1
+ {"version":3,"file":"component-CM4bf3RV.cjs","sources":["../src/components/image-button/component.tsx"],"sourcesContent":["import { LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT } from '@local/consts';\nimport { useImageCrop } from '@local/hooks/use-image-crop';\n\nimport { FC, useCallback, useRef } from 'react';\n\nimport { Button } from '../button';\nimport { ImageButtonProps } from '.';\n\nexport const ImageButton: FC<ImageButtonProps> = (props) => {\n const refInput = useRef<HTMLInputElement | null>(null);\n\n const handleOpenFileDialog = useCallback(() => {\n refInput.current?.click();\n }, []);\n\n const { handleAddFiles } = useImageCrop({\n onSave: props.onSave,\n locale: props.locale,\n dialog: props.dialog,\n imageSettings: props.imageSettings,\n refInput: refInput,\n });\n\n return (\n <>\n <Button\n {...props.button}\n onClick={(e) => {\n props.button.onClick?.(e);\n handleOpenFileDialog();\n }}\n >\n {props.button.children || props.locale.buttonAdd}\n </Button>\n <input\n ref={refInput}\n type='file'\n accept={LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT}\n multiple\n style={{ display: 'none' }}\n onChange={(e) => {\n if (e.target.files) handleAddFiles(e.target.files);\n }}\n />\n </>\n );\n};\n"],"names":["props","refInput","useRef","handleOpenFileDialog","useCallback","_a","current","click","handleAddFiles","useImageCrop","onSave","locale","dialog","imageSettings","jsxs","Fragment","children","jsx","Button","button","onClick","e","_b","call","buttonAdd","ref","type","accept","LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT","multiple","style","display","onChange","target","files"],"mappings":"6MAQkDA,IAChD,MAAMC,EAAWC,EAAAA,OAAgC,MAE3CC,EAAuBC,EAAAA,YAAY,WACvC,OAAAC,EAAAJ,EAASK,UAATD,EAAkBE,SACjB,KAEGC,eAAEA,GAAmBC,eAAa,CACtCC,OAAQV,EAAMU,OACdC,OAAQX,EAAMW,OACdC,OAAQZ,EAAMY,OACdC,cAAeb,EAAMa,cACrBZ,aAGF,SACEa,kBAAAA,KAAAC,6BAAA,CACEC,SAAA,GAAAC,kBAAAA,IAACC,EAAAA,OAAA,IACKlB,EAAMmB,OACVC,QAAUC,YACR,OAAAC,GAAAjB,EAAAL,EAAMmB,QAAOC,UAAbE,EAAAC,KAAAlB,EAAuBgB,GACvBlB,KAGDa,SAAAhB,EAAMmB,OAAOH,UAAYhB,EAAMW,OAAOa,cAEzCP,kBAAAA,IAAC,QAAA,CACCQ,IAAKxB,EACLyB,KAAK,OACLC,OAAQC,EAAAA,sCACRC,UAAQ,EACRC,MAAO,CAAEC,QAAS,QAClBC,SAAWX,IACLA,EAAEY,OAAOC,OAAO1B,EAAea,EAAEY,OAAOC"}
@@ -1,5 +1,5 @@
1
1
  import { j as jsxRuntimeExports } from "./jsx-runtime-BrDlu8eK.js";
2
- import { Z as StyledInputWrapper, a8 as InputPrefixChildren, a6 as StyledInputPattern, a7 as StyledInputNumeric, a4 as StyledInput, a9 as InputPostfixChildren, br as ErrorMessage } from "./context.constants-Dop398a2.js";
2
+ import { Z as StyledInputWrapper, a8 as InputPrefixChildren, a6 as StyledInputPattern, a7 as StyledInputNumeric, a4 as StyledInput, a9 as InputPostfixChildren, br as ErrorMessage } from "./context.constants-YlWOZAd7.js";
3
3
  import { useCallback } from "react";
4
4
  import { useTheme } from "styled-components";
5
5
  const Input = (props) => {
@@ -245,4 +245,4 @@ export {
245
245
  Input as I,
246
246
  formatPhoneNumber as f
247
247
  };
248
- //# sourceMappingURL=component-CVODnsK7.js.map
248
+ //# sourceMappingURL=component-DAocGHCP.js.map