@embeddable.com/remarkable-ui 0.1.51 → 1.0.1

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 (421) hide show
  1. package/dist/BarChartDefaultHorizontalPro.js +3 -3
  2. package/dist/BarChartDefaultPro.js +3 -3
  3. package/dist/BarChartGroupedHorizontalPro.js +3 -3
  4. package/dist/BarChartGroupedPro.js +3 -3
  5. package/dist/BarChartStackedHorizontalPro.js +15 -15
  6. package/dist/BarChartStackedHorizontalPro.js.map +1 -1
  7. package/dist/BarChartStackedPro.js +33 -33
  8. package/dist/BarChartStackedPro.js.map +1 -1
  9. package/dist/ChartCard-CyemTSay.js +122 -0
  10. package/dist/ChartCard-CyemTSay.js.map +1 -0
  11. package/dist/{ComparisonPeriod.type.emb-CYp3nw-9.js → ComparisonPeriod.type.emb-i3iGuRJI.js} +2 -2
  12. package/dist/{ComparisonPeriod.type.emb-CYp3nw-9.js.map → ComparisonPeriod.type.emb-i3iGuRJI.js.map} +1 -1
  13. package/dist/ComparisonPeriodSelectFieldPro.js +4 -4
  14. package/dist/DateRangeSelectFieldPro.js +2 -2
  15. package/dist/DonutChartPro.js +2 -2
  16. package/dist/DonutLabelChartPro.js +2 -2
  17. package/dist/EditorCard-BICCSvPo.js +74 -0
  18. package/dist/EditorCard-BICCSvPo.js.map +1 -0
  19. package/dist/HeatMap-BueWUQTI.js +208 -0
  20. package/dist/HeatMap-BueWUQTI.js.map +1 -0
  21. package/dist/HeatMapPro.js +4 -4
  22. package/dist/KpiChart-BxmGCIn5.js +105 -0
  23. package/dist/KpiChart-BxmGCIn5.js.map +1 -0
  24. package/dist/KpiChartNumberComparisonPro.js +21 -21
  25. package/dist/KpiChartNumberComparisonPro.js.map +1 -1
  26. package/dist/KpiChartNumberPro.js +9 -9
  27. package/dist/KpiChartNumberPro.js.map +1 -1
  28. package/dist/LineChartComparisonDefaultPro.js +46 -49
  29. package/dist/LineChartComparisonDefaultPro.js.map +1 -1
  30. package/dist/LineChartDefaultPro.js +25 -28
  31. package/dist/LineChartDefaultPro.js.map +1 -1
  32. package/dist/LineChartGroupedPro.js +47 -50
  33. package/dist/LineChartGroupedPro.js.map +1 -1
  34. package/dist/MultiSelectFieldPro.js +2 -2
  35. package/dist/PieChartPro.js +2 -2
  36. package/dist/PivotTable-DrN-dl-H.js +249 -0
  37. package/dist/PivotTable-DrN-dl-H.js.map +1 -0
  38. package/dist/PivotTablePro.js +4 -4
  39. package/dist/SingleSelectField-CSJOpQeh.js +109 -0
  40. package/dist/SingleSelectField-CSJOpQeh.js.map +1 -0
  41. package/dist/SingleSelectFieldPro.js +2 -2
  42. package/dist/TableChartPaginated.js +123 -152
  43. package/dist/TableChartPaginated.js.map +1 -1
  44. package/dist/{bars.utils-DTdoPs5N.js → bars.utils-wy9RMO2F.js} +4 -4
  45. package/dist/bars.utils-wy9RMO2F.js.map +1 -0
  46. package/dist/{charts.utils-D9TXwxGs.js → charts.utils-eHB_o46Z.js} +2633 -2773
  47. package/dist/charts.utils-eHB_o46Z.js.map +1 -0
  48. package/dist/{component.constants-DCOqCFoY.js → component.constants-CYS5-3qd.js} +3553 -3529
  49. package/dist/component.constants-CYS5-3qd.js.map +1 -0
  50. package/dist/embeddable-components.json +11 -11
  51. package/dist/embeddable-theme-2b917.js +3789 -3929
  52. package/dist/{formatter.utils-B80iNq9Q.js → formatter.utils-CaFr8SlX.js} +2 -2
  53. package/dist/{formatter.utils-B80iNq9Q.js.map → formatter.utils-CaFr8SlX.js.map} +1 -1
  54. package/dist/index-B7QvKSGz.js +204 -0
  55. package/dist/index-B7QvKSGz.js.map +1 -0
  56. package/dist/{index-CmE__sUg.js → index-BYxqGfuR.js} +15 -14
  57. package/dist/index-BYxqGfuR.js.map +1 -0
  58. package/dist/{index-D4oPbYPT.js → index-CGRZXASn.js} +16 -14
  59. package/dist/index-CGRZXASn.js.map +1 -0
  60. package/dist/{index--tdFwk_H.js → index-CwCkuHzT.js} +16 -14
  61. package/dist/index-CwCkuHzT.js.map +1 -0
  62. package/dist/{index-C3o3AQpK.js → index-DfsOzpdV.js} +9 -14
  63. package/dist/index-DfsOzpdV.js.map +1 -0
  64. package/dist/{index-DpIR-B0R.js → index-b_iMiCHA.js} +4 -4
  65. package/dist/{index-DpIR-B0R.js.map → index-b_iMiCHA.js.map} +1 -1
  66. package/dist/index.js +216 -254
  67. package/dist/index.js.map +1 -1
  68. package/dist/pies.utils-BvSC2qnJ.js +73 -0
  69. package/dist/pies.utils-BvSC2qnJ.js.map +1 -0
  70. package/dist/remarkable-pro/components/charts/bars/bars.utils.d.ts.map +1 -1
  71. package/dist/remarkable-pro/components/charts/lines/LineChartComparisonDefaultPro/LineChartComparisonDefaultPro.utils.d.ts.map +1 -1
  72. package/dist/remarkable-pro/components/charts/lines/LineChartComparisonDefaultPro/index.d.ts.map +1 -1
  73. package/dist/remarkable-pro/components/charts/lines/LineChartDefaultPro/LineChartDefaultPro.utils.d.ts.map +1 -1
  74. package/dist/remarkable-pro/components/charts/lines/LineChartDefaultPro/index.d.ts.map +1 -1
  75. package/dist/remarkable-pro/components/charts/lines/LineChartGroupedPro/LineChartGroupedPro.utils.d.ts.map +1 -1
  76. package/dist/remarkable-pro/components/charts/lines/LineChartGroupedPro/index.d.ts.map +1 -1
  77. package/dist/remarkable-pro/components/charts/pies/DonutChartPro/index.d.ts.map +1 -1
  78. package/dist/remarkable-pro/components/charts/pies/DonutLabelChartPro/index.d.ts.map +1 -1
  79. package/dist/remarkable-pro/components/charts/pies/PieChartPro/index.d.ts.map +1 -1
  80. package/dist/remarkable-pro/components/charts/pies/pies.utils.d.ts +1 -7
  81. package/dist/remarkable-pro/components/charts/pies/pies.utils.d.ts.map +1 -1
  82. package/dist/remarkable-pro/components/charts/shared/ChartCard/ChartCard.d.ts.map +1 -1
  83. package/dist/remarkable-pro/components/charts/shared/ChartCard/ChartCard.stories.d.ts.map +1 -1
  84. package/dist/remarkable-pro/components/charts/tables/TableChartPaginated/index.d.ts.map +1 -1
  85. package/dist/remarkable-pro/index.d.ts +0 -1
  86. package/dist/remarkable-pro/index.d.ts.map +1 -1
  87. package/dist/remarkable-pro/theme/theme.types.d.ts +0 -3
  88. package/dist/remarkable-pro/theme/theme.types.d.ts.map +1 -1
  89. package/dist/remarkable-ui/components/charts/bars/BarChart.d.ts.map +1 -0
  90. package/dist/remarkable-ui/components/charts/bars/BarChart.stories.d.ts +72 -0
  91. package/dist/remarkable-ui/components/charts/bars/BarChart.stories.d.ts.map +1 -0
  92. package/dist/remarkable-ui/{charts → components/charts}/bars/bars.types.d.ts +1 -1
  93. package/dist/remarkable-ui/components/charts/bars/bars.types.d.ts.map +1 -0
  94. package/dist/remarkable-ui/components/charts/bars/bars.utils.d.ts.map +1 -0
  95. package/dist/remarkable-ui/{charts → components/charts}/chartjs.cartesian.constants.d.ts +1 -0
  96. package/dist/remarkable-ui/components/charts/chartjs.cartesian.constants.d.ts.map +1 -0
  97. package/dist/remarkable-ui/components/charts/chartjs.constants.d.ts.map +1 -0
  98. package/dist/remarkable-ui/components/charts/chartjs.utils.d.ts.map +1 -0
  99. package/dist/remarkable-ui/components/charts/charts.constants.d.ts.map +1 -0
  100. package/dist/remarkable-ui/components/charts/kpis/KpiChart.d.ts.map +1 -0
  101. package/dist/remarkable-ui/components/charts/kpis/KpiChart.stories.d.ts +32 -0
  102. package/dist/remarkable-ui/components/charts/kpis/KpiChart.stories.d.ts.map +1 -0
  103. package/dist/remarkable-ui/{charts → components/charts}/kpis/KpiChart.types.d.ts +1 -1
  104. package/dist/remarkable-ui/components/charts/kpis/KpiChart.types.d.ts.map +1 -0
  105. package/dist/remarkable-ui/components/charts/kpis/components/KpiChartChange.d.ts.map +1 -0
  106. package/dist/remarkable-ui/components/charts/lines/LineChart.d.ts.map +1 -0
  107. package/dist/remarkable-ui/components/charts/lines/LineChart.stories.d.ts +35 -0
  108. package/dist/remarkable-ui/components/charts/lines/LineChart.stories.d.ts.map +1 -0
  109. package/dist/remarkable-ui/components/charts/lines/lines.types.d.ts.map +1 -0
  110. package/dist/remarkable-ui/components/charts/lines/lines.utils.d.ts.map +1 -0
  111. package/dist/remarkable-ui/{charts/pies → components/charts/pies/DonutChart}/DonutChart.d.ts +1 -1
  112. package/dist/remarkable-ui/components/charts/pies/DonutChart/DonutChart.d.ts.map +1 -0
  113. package/dist/remarkable-ui/components/charts/pies/DonutChart/DonutChart.stories.d.ts +28 -0
  114. package/dist/remarkable-ui/components/charts/pies/DonutChart/DonutChart.stories.d.ts.map +1 -0
  115. package/dist/remarkable-ui/{charts/pies → components/charts/pies/PieChart}/PieChart.d.ts +1 -1
  116. package/dist/remarkable-ui/components/charts/pies/PieChart/PieChart.d.ts.map +1 -0
  117. package/dist/remarkable-ui/components/charts/pies/PieChart/PieChart.stories.d.ts +25 -0
  118. package/dist/remarkable-ui/components/charts/pies/PieChart/PieChart.stories.d.ts.map +1 -0
  119. package/dist/remarkable-ui/components/charts/pies/pies.mock.d.ts.map +1 -0
  120. package/dist/remarkable-ui/{charts → components/charts}/pies/pies.types.d.ts +6 -1
  121. package/dist/remarkable-ui/components/charts/pies/pies.types.d.ts.map +1 -0
  122. package/dist/remarkable-ui/components/charts/pies/pies.utils.d.ts +9 -0
  123. package/dist/remarkable-ui/components/charts/pies/pies.utils.d.ts.map +1 -0
  124. package/dist/remarkable-ui/components/charts/tables/HeatMap/HeatMap.d.ts.map +1 -0
  125. package/dist/remarkable-ui/components/charts/tables/HeatMap/HeatMap.stories.d.ts +36 -0
  126. package/dist/remarkable-ui/components/charts/tables/HeatMap/HeatMap.stories.d.ts.map +1 -0
  127. package/dist/remarkable-ui/components/charts/tables/HeatMap/HeatMap.types.d.ts.map +1 -0
  128. package/dist/remarkable-ui/{charts → components/charts}/tables/HeatMap/HeatMap.utils.d.ts +1 -1
  129. package/dist/remarkable-ui/components/charts/tables/HeatMap/HeatMap.utils.d.ts.map +1 -0
  130. package/dist/remarkable-ui/components/charts/tables/PivotTable/PivotTable.d.ts.map +1 -0
  131. package/dist/remarkable-ui/components/charts/tables/PivotTable/PivotTable.stories.d.ts +43 -0
  132. package/dist/remarkable-ui/components/charts/tables/PivotTable/PivotTable.stories.d.ts.map +1 -0
  133. package/dist/remarkable-ui/components/charts/tables/PivotTable/PivotTable.types.d.ts.map +1 -0
  134. package/dist/remarkable-ui/components/charts/tables/Table/Table.hooks.d.ts.map +1 -0
  135. package/dist/remarkable-ui/components/charts/tables/Table/TablePaginated.d.ts.map +1 -0
  136. package/dist/remarkable-ui/{charts → components/charts}/tables/Table/TablePaginated.stories.d.ts +2 -1
  137. package/dist/remarkable-ui/components/charts/tables/Table/TablePaginated.stories.d.ts.map +1 -0
  138. package/dist/remarkable-ui/components/charts/tables/Table/components/TableBody/TableBody.d.ts.map +1 -0
  139. package/dist/remarkable-ui/components/charts/tables/Table/components/TableHeader/TableHeader.d.ts.map +1 -0
  140. package/dist/remarkable-ui/components/charts/tables/Table/components/TablePagination/TablePagination.d.ts.map +1 -0
  141. package/dist/remarkable-ui/{charts → components/charts}/tables/Table/components/TablePagination/TablePagination.stories.d.ts +1 -0
  142. package/dist/remarkable-ui/components/charts/tables/Table/components/TablePagination/TablePagination.stories.d.ts.map +1 -0
  143. package/dist/remarkable-ui/{charts → components/charts}/tables/Table/table.types.d.ts +1 -1
  144. package/dist/remarkable-ui/components/charts/tables/Table/table.types.d.ts.map +1 -0
  145. package/dist/remarkable-ui/components/charts/tables/tables.utils.d.ts.map +1 -0
  146. package/dist/remarkable-ui/components/editors/Switch/Switch.d.ts.map +1 -0
  147. package/dist/remarkable-ui/components/editors/Switch/Switch.stories.d.ts +27 -0
  148. package/dist/remarkable-ui/components/editors/Switch/Switch.stories.d.ts.map +1 -0
  149. package/dist/remarkable-ui/{editors → components/editors/inputs}/NumberField/NumberField.d.ts +1 -3
  150. package/dist/remarkable-ui/components/editors/inputs/NumberField/NumberField.d.ts.map +1 -0
  151. package/dist/remarkable-ui/components/editors/inputs/NumberField/NumberField.stories.d.ts +36 -0
  152. package/dist/remarkable-ui/components/editors/inputs/NumberField/NumberField.stories.d.ts.map +1 -0
  153. package/dist/remarkable-ui/{editors → components/editors/inputs}/TextField/TextField.d.ts +1 -1
  154. package/dist/remarkable-ui/components/editors/inputs/TextField/TextField.d.ts.map +1 -0
  155. package/dist/remarkable-ui/components/editors/inputs/TextField/TextField.stories.d.ts +40 -0
  156. package/dist/remarkable-ui/components/editors/inputs/TextField/TextField.stories.d.ts.map +1 -0
  157. package/dist/remarkable-ui/{editors → components/editors/inputs/shared}/InputField/InputField.d.ts +3 -2
  158. package/dist/remarkable-ui/components/editors/inputs/shared/InputField/InputField.d.ts.map +1 -0
  159. package/dist/remarkable-ui/{editors/select → components/editors/selects}/MultiSelectField/MultiSelectField.d.ts +5 -2
  160. package/dist/remarkable-ui/components/editors/selects/MultiSelectField/MultiSelectField.d.ts.map +1 -0
  161. package/dist/remarkable-ui/components/editors/selects/MultiSelectField/MultiSelectField.stories.d.ts +34 -0
  162. package/dist/remarkable-ui/components/editors/selects/MultiSelectField/MultiSelectField.stories.d.ts.map +1 -0
  163. package/dist/remarkable-ui/{editors/select → components/editors/selects}/SingleSelectField/SingleSelectField.d.ts +3 -2
  164. package/dist/remarkable-ui/components/editors/selects/SingleSelectField/SingleSelectField.d.ts.map +1 -0
  165. package/dist/remarkable-ui/components/editors/selects/SingleSelectField/SingleSelectField.stories.d.ts +34 -0
  166. package/dist/remarkable-ui/components/editors/selects/SingleSelectField/SingleSelectField.stories.d.ts.map +1 -0
  167. package/dist/remarkable-ui/components/editors/selects/shared/SelectFieldContent/SelectFieldContent.d.ts +16 -0
  168. package/dist/remarkable-ui/components/editors/selects/shared/SelectFieldContent/SelectFieldContent.d.ts.map +1 -0
  169. package/dist/remarkable-ui/{editors/select/shared/SelectList/selectList.utils.d.ts → components/editors/selects/shared/SelectFieldContent/SelectFieldContent.utils.d.ts} +2 -2
  170. package/dist/remarkable-ui/components/editors/selects/shared/SelectFieldContent/SelectFieldContent.utils.d.ts.map +1 -0
  171. package/dist/remarkable-ui/components/editors/selects/shared/SelectFieldContent/SelectListOptions/SelectFieldCategory/SelectFieldCategory.d.ts +7 -0
  172. package/dist/remarkable-ui/components/editors/selects/shared/SelectFieldContent/SelectListOptions/SelectFieldCategory/SelectFieldCategory.d.ts.map +1 -0
  173. package/dist/remarkable-ui/{editors/select/shared/SelectList/SelectListOptions/SelectListOption/SelectListOption.d.ts → components/editors/selects/shared/SelectFieldContent/SelectListOptions/SelectFieldOption/SelectFieldOption.d.ts} +1 -1
  174. package/dist/remarkable-ui/components/editors/selects/shared/SelectFieldContent/SelectListOptions/SelectFieldOption/SelectFieldOption.d.ts.map +1 -0
  175. package/dist/remarkable-ui/{editors/select/shared/SelectButton/SelectButton.d.ts → components/editors/selects/shared/SelectFieldTrigger/SelectFieldTrigger.d.ts} +2 -2
  176. package/dist/remarkable-ui/components/editors/selects/shared/SelectFieldTrigger/SelectFieldTrigger.d.ts.map +1 -0
  177. package/dist/remarkable-ui/components/editors/selects/shared/useSelectSearchFocus.hook.d.ts.map +1 -0
  178. package/dist/remarkable-ui/components/shared/ActionIcon/ActionIcon.d.ts +9 -0
  179. package/dist/remarkable-ui/components/shared/ActionIcon/ActionIcon.d.ts.map +1 -0
  180. package/dist/remarkable-ui/components/shared/ActionIcon/ActionIcon.stories.d.ts +23 -0
  181. package/dist/remarkable-ui/components/shared/ActionIcon/ActionIcon.stories.d.ts.map +1 -0
  182. package/dist/remarkable-ui/{shared → components/shared}/Button/Button.d.ts +4 -4
  183. package/dist/remarkable-ui/components/shared/Button/Button.d.ts.map +1 -0
  184. package/dist/remarkable-ui/components/shared/Button/Button.stories.d.ts +47 -0
  185. package/dist/remarkable-ui/components/shared/Button/Button.stories.d.ts.map +1 -0
  186. package/dist/remarkable-ui/components/shared/ButtonIcon/ButtonIcon.d.ts +10 -0
  187. package/dist/remarkable-ui/components/shared/ButtonIcon/ButtonIcon.d.ts.map +1 -0
  188. package/dist/remarkable-ui/components/shared/ButtonIcon/ButtonIcon.stories.d.ts +30 -0
  189. package/dist/remarkable-ui/components/shared/ButtonIcon/ButtonIcon.stories.d.ts.map +1 -0
  190. package/dist/remarkable-ui/{shared → components/shared}/Card/Card.d.ts +1 -1
  191. package/dist/remarkable-ui/components/shared/Card/Card.d.ts.map +1 -0
  192. package/dist/remarkable-ui/components/shared/Card/Card.stories.d.ts +13 -0
  193. package/dist/remarkable-ui/components/shared/Card/Card.stories.d.ts.map +1 -0
  194. package/dist/remarkable-ui/components/shared/Card/CardFeedback/CardFeedback.d.ts +11 -0
  195. package/dist/remarkable-ui/components/shared/Card/CardFeedback/CardFeedback.d.ts.map +1 -0
  196. package/dist/remarkable-ui/components/shared/Dropdown/Dropdown.d.ts.map +1 -0
  197. package/dist/remarkable-ui/components/shared/Field/FieldFeedback.d.ts +8 -0
  198. package/dist/remarkable-ui/components/shared/Field/FieldFeedback.d.ts.map +1 -0
  199. package/dist/remarkable-ui/components/shared/Field/FieldHeader.d.ts +8 -0
  200. package/dist/remarkable-ui/components/shared/Field/FieldHeader.d.ts.map +1 -0
  201. package/dist/remarkable-ui/components/shared/Foundations/BorderRadius.stories.d.ts +6 -0
  202. package/dist/remarkable-ui/components/shared/Foundations/BorderRadius.stories.d.ts.map +1 -0
  203. package/dist/remarkable-ui/{shared → components/shared}/Foundations/Colors.stories.d.ts +1 -1
  204. package/dist/remarkable-ui/components/shared/Foundations/Colors.stories.d.ts.map +1 -0
  205. package/dist/remarkable-ui/components/shared/Foundations/Size.stories.d.ts +6 -0
  206. package/dist/remarkable-ui/components/shared/Foundations/Size.stories.d.ts.map +1 -0
  207. package/dist/remarkable-ui/components/shared/Foundations/Spacing.stories.d.ts +6 -0
  208. package/dist/remarkable-ui/components/shared/Foundations/Spacing.stories.d.ts.map +1 -0
  209. package/dist/remarkable-ui/components/shared/GhostButton/GhostButton.d.ts.map +1 -0
  210. package/dist/remarkable-ui/components/shared/GhostButton/GhostButton.stories.d.ts +29 -0
  211. package/dist/remarkable-ui/components/shared/GhostButton/GhostButton.stories.d.ts.map +1 -0
  212. package/dist/remarkable-ui/components/shared/PageOverlay/PageOverlay.d.ts.map +1 -0
  213. package/dist/remarkable-ui/components/shared/PageOverlay/PageOverlay.stories.d.ts +7 -0
  214. package/dist/remarkable-ui/components/shared/PageOverlay/PageOverlay.stories.d.ts.map +1 -0
  215. package/dist/remarkable-ui/components/shared/PageOverlay/PageOverlay.types.d.ts.map +1 -0
  216. package/dist/remarkable-ui/components/shared/Skeleton/Skeleton.d.ts.map +1 -0
  217. package/dist/remarkable-ui/{shared → components/shared}/Skeleton/Skeleton.stories.d.ts +2 -0
  218. package/dist/remarkable-ui/components/shared/Skeleton/Skeleton.stories.d.ts.map +1 -0
  219. package/dist/remarkable-ui/components/shared/Typography/Typography.d.ts.map +1 -0
  220. package/dist/remarkable-ui/{shared → components/shared}/Typography/Typography.stories.d.ts +1 -0
  221. package/dist/remarkable-ui/components/shared/Typography/Typography.stories.d.ts.map +1 -0
  222. package/dist/remarkable-ui/components/shared/Typography/Typography.types.d.ts.map +1 -0
  223. package/dist/remarkable-ui/index.d.ts +41 -40
  224. package/dist/remarkable-ui/index.d.ts.map +1 -1
  225. package/dist/remarkable-ui/storybook.constants.d.ts +8 -0
  226. package/dist/remarkable-ui/storybook.constants.d.ts.map +1 -0
  227. package/dist/remarkable-ui/styles/styles.constants.d.ts +7 -603
  228. package/dist/remarkable-ui/styles/styles.constants.d.ts.map +1 -1
  229. package/dist/remarkable-ui/styles/styles.tokensComponents.constants.d.ts +347 -0
  230. package/dist/remarkable-ui/styles/styles.tokensComponents.constants.d.ts.map +1 -0
  231. package/dist/remarkable-ui/styles/styles.tokensCore.constants.d.ts +90 -0
  232. package/dist/remarkable-ui/styles/styles.tokensCore.constants.d.ts.map +1 -0
  233. package/dist/remarkable-ui/styles/styles.tokensSemantic.constants.d.ts +31 -0
  234. package/dist/remarkable-ui/styles/styles.tokensSemantic.constants.d.ts.map +1 -0
  235. package/dist/remarkable-ui/styles/styles.utils.d.ts +1 -1
  236. package/dist/remarkable-ui/styles/styles.utils.d.ts.map +1 -1
  237. package/dist/remarkable-ui.css +451 -585
  238. package/dist/tables.utils-D7KXdM2S.js.map +1 -1
  239. package/dist/{timeRange.utils-u1NZ0u7o.js → timeRange.utils-CplLUFvd.js} +2 -2
  240. package/dist/{timeRange.utils-u1NZ0u7o.js.map → timeRange.utils-CplLUFvd.js.map} +1 -1
  241. package/dist/useDebounce.hook-DxiPFcz9.js +36 -0
  242. package/dist/useDebounce.hook-DxiPFcz9.js.map +1 -0
  243. package/package.json +3 -1
  244. package/dist/ChartCard-D-0O5ugW.js +0 -117
  245. package/dist/ChartCard-D-0O5ugW.js.map +0 -1
  246. package/dist/EditorCard-BhC7oToX.js +0 -76
  247. package/dist/EditorCard-BhC7oToX.js.map +0 -1
  248. package/dist/HeatMap-By9_uzV_.js +0 -223
  249. package/dist/HeatMap-By9_uzV_.js.map +0 -1
  250. package/dist/KpiChart-CS9s8nJ4.js +0 -79
  251. package/dist/KpiChart-CS9s8nJ4.js.map +0 -1
  252. package/dist/PivotTable-Cx4WG6MV.js +0 -273
  253. package/dist/PivotTable-Cx4WG6MV.js.map +0 -1
  254. package/dist/SingleSelectField-DlVCi5Ej.js +0 -107
  255. package/dist/SingleSelectField-DlVCi5Ej.js.map +0 -1
  256. package/dist/bars.utils-DTdoPs5N.js.map +0 -1
  257. package/dist/charts.utils-D9TXwxGs.js.map +0 -1
  258. package/dist/component.constants-DCOqCFoY.js.map +0 -1
  259. package/dist/index--tdFwk_H.js.map +0 -1
  260. package/dist/index-BcPj51g3.js +0 -220
  261. package/dist/index-BcPj51g3.js.map +0 -1
  262. package/dist/index-C3o3AQpK.js.map +0 -1
  263. package/dist/index-CmE__sUg.js.map +0 -1
  264. package/dist/index-D4oPbYPT.js.map +0 -1
  265. package/dist/pies.utils-DEkgZgVk.js +0 -75
  266. package/dist/pies.utils-DEkgZgVk.js.map +0 -1
  267. package/dist/remarkable-ui/charts/bars/BarChart.d.ts.map +0 -1
  268. package/dist/remarkable-ui/charts/bars/BarChart.stories.d.ts +0 -29
  269. package/dist/remarkable-ui/charts/bars/BarChart.stories.d.ts.map +0 -1
  270. package/dist/remarkable-ui/charts/bars/bars.types.d.ts.map +0 -1
  271. package/dist/remarkable-ui/charts/bars/bars.utils.d.ts.map +0 -1
  272. package/dist/remarkable-ui/charts/chartjs.cartesian.constants.d.ts.map +0 -1
  273. package/dist/remarkable-ui/charts/chartjs.constants.d.ts.map +0 -1
  274. package/dist/remarkable-ui/charts/chartjs.utils.d.ts.map +0 -1
  275. package/dist/remarkable-ui/charts/charts.constants.d.ts.map +0 -1
  276. package/dist/remarkable-ui/charts/kpis/KpiChart.d.ts.map +0 -1
  277. package/dist/remarkable-ui/charts/kpis/KpiChart.stories.d.ts +0 -23
  278. package/dist/remarkable-ui/charts/kpis/KpiChart.stories.d.ts.map +0 -1
  279. package/dist/remarkable-ui/charts/kpis/KpiChart.types.d.ts.map +0 -1
  280. package/dist/remarkable-ui/charts/kpis/components/KpiChartChange.d.ts.map +0 -1
  281. package/dist/remarkable-ui/charts/lines/LineChart.d.ts.map +0 -1
  282. package/dist/remarkable-ui/charts/lines/LineChart.stories.d.ts +0 -8
  283. package/dist/remarkable-ui/charts/lines/LineChart.stories.d.ts.map +0 -1
  284. package/dist/remarkable-ui/charts/lines/lines.types.d.ts.map +0 -1
  285. package/dist/remarkable-ui/charts/lines/lines.utils.d.ts.map +0 -1
  286. package/dist/remarkable-ui/charts/pies/DonutChart.d.ts.map +0 -1
  287. package/dist/remarkable-ui/charts/pies/DonutChart.stories.d.ts +0 -8
  288. package/dist/remarkable-ui/charts/pies/DonutChart.stories.d.ts.map +0 -1
  289. package/dist/remarkable-ui/charts/pies/PieChart.d.ts.map +0 -1
  290. package/dist/remarkable-ui/charts/pies/PieChart.stories.d.ts +0 -9
  291. package/dist/remarkable-ui/charts/pies/PieChart.stories.d.ts.map +0 -1
  292. package/dist/remarkable-ui/charts/pies/pies.constants.d.ts +0 -5
  293. package/dist/remarkable-ui/charts/pies/pies.constants.d.ts.map +0 -1
  294. package/dist/remarkable-ui/charts/pies/pies.mock.d.ts.map +0 -1
  295. package/dist/remarkable-ui/charts/pies/pies.types.d.ts.map +0 -1
  296. package/dist/remarkable-ui/charts/pies/pies.utils.d.ts +0 -3
  297. package/dist/remarkable-ui/charts/pies/pies.utils.d.ts.map +0 -1
  298. package/dist/remarkable-ui/charts/tables/HeatMap/HeatMap.d.ts.map +0 -1
  299. package/dist/remarkable-ui/charts/tables/HeatMap/HeatMap.stories.d.ts +0 -9
  300. package/dist/remarkable-ui/charts/tables/HeatMap/HeatMap.stories.d.ts.map +0 -1
  301. package/dist/remarkable-ui/charts/tables/HeatMap/HeatMap.types.d.ts.map +0 -1
  302. package/dist/remarkable-ui/charts/tables/HeatMap/HeatMap.utils.d.ts.map +0 -1
  303. package/dist/remarkable-ui/charts/tables/PivotTable/PivotTable.d.ts.map +0 -1
  304. package/dist/remarkable-ui/charts/tables/PivotTable/PivotTable.stories.d.ts +0 -24
  305. package/dist/remarkable-ui/charts/tables/PivotTable/PivotTable.stories.d.ts.map +0 -1
  306. package/dist/remarkable-ui/charts/tables/PivotTable/PivotTable.types.d.ts.map +0 -1
  307. package/dist/remarkable-ui/charts/tables/Table/Table.hooks.d.ts.map +0 -1
  308. package/dist/remarkable-ui/charts/tables/Table/TablePaginated.d.ts.map +0 -1
  309. package/dist/remarkable-ui/charts/tables/Table/TablePaginated.stories.d.ts.map +0 -1
  310. package/dist/remarkable-ui/charts/tables/Table/components/TableBody/TableBody.d.ts.map +0 -1
  311. package/dist/remarkable-ui/charts/tables/Table/components/TableHeader/TableHeader.d.ts.map +0 -1
  312. package/dist/remarkable-ui/charts/tables/Table/components/TablePagination/TablePagination.d.ts.map +0 -1
  313. package/dist/remarkable-ui/charts/tables/Table/components/TablePagination/TablePagination.stories.d.ts.map +0 -1
  314. package/dist/remarkable-ui/charts/tables/Table/table.types.d.ts.map +0 -1
  315. package/dist/remarkable-ui/charts/tables/tables.utils.d.ts.map +0 -1
  316. package/dist/remarkable-ui/editors/InputField/InputField.d.ts.map +0 -1
  317. package/dist/remarkable-ui/editors/NumberField/NumberField.d.ts.map +0 -1
  318. package/dist/remarkable-ui/editors/NumberField/NumberField.stories.d.ts +0 -23
  319. package/dist/remarkable-ui/editors/NumberField/NumberField.stories.d.ts.map +0 -1
  320. package/dist/remarkable-ui/editors/TextField/TextField.d.ts.map +0 -1
  321. package/dist/remarkable-ui/editors/TextField/TextField.stories.d.ts +0 -28
  322. package/dist/remarkable-ui/editors/TextField/TextField.stories.d.ts.map +0 -1
  323. package/dist/remarkable-ui/editors/select/MultiSelectField/MultiSelectField.d.ts.map +0 -1
  324. package/dist/remarkable-ui/editors/select/MultiSelectField/MultiSelectField.stories.d.ts +0 -15
  325. package/dist/remarkable-ui/editors/select/MultiSelectField/MultiSelectField.stories.d.ts.map +0 -1
  326. package/dist/remarkable-ui/editors/select/SingleSelectField/SingleSelectField.d.ts.map +0 -1
  327. package/dist/remarkable-ui/editors/select/SingleSelectField/SingleSelectField.stories.d.ts +0 -18
  328. package/dist/remarkable-ui/editors/select/SingleSelectField/SingleSelectField.stories.d.ts.map +0 -1
  329. package/dist/remarkable-ui/editors/select/shared/SelectButton/SelectButton.d.ts.map +0 -1
  330. package/dist/remarkable-ui/editors/select/shared/SelectList/SelectList.d.ts +0 -8
  331. package/dist/remarkable-ui/editors/select/shared/SelectList/SelectList.d.ts.map +0 -1
  332. package/dist/remarkable-ui/editors/select/shared/SelectList/SelectListOptions/SelectListCategory/SelectListCategory.d.ts +0 -7
  333. package/dist/remarkable-ui/editors/select/shared/SelectList/SelectListOptions/SelectListCategory/SelectListCategory.d.ts.map +0 -1
  334. package/dist/remarkable-ui/editors/select/shared/SelectList/SelectListOptions/SelectListOption/SelectListOption.d.ts.map +0 -1
  335. package/dist/remarkable-ui/editors/select/shared/SelectList/SelectListOptions/SelectListOptions.d.ts +0 -7
  336. package/dist/remarkable-ui/editors/select/shared/SelectList/SelectListOptions/SelectListOptions.d.ts.map +0 -1
  337. package/dist/remarkable-ui/editors/select/shared/SelectList/selectList.utils.d.ts.map +0 -1
  338. package/dist/remarkable-ui/editors/select/shared/useSelectSearchFocus.hook.d.ts.map +0 -1
  339. package/dist/remarkable-ui/shared/BaseButton/BaseButton.d.ts +0 -8
  340. package/dist/remarkable-ui/shared/BaseButton/BaseButton.d.ts.map +0 -1
  341. package/dist/remarkable-ui/shared/BaseButton/index.d.ts +0 -2
  342. package/dist/remarkable-ui/shared/BaseButton/index.d.ts.map +0 -1
  343. package/dist/remarkable-ui/shared/Button/Button.d.ts.map +0 -1
  344. package/dist/remarkable-ui/shared/Button/Button.stories.d.ts +0 -20
  345. package/dist/remarkable-ui/shared/Button/Button.stories.d.ts.map +0 -1
  346. package/dist/remarkable-ui/shared/ButtonIcon/ButtonIcon.d.ts +0 -9
  347. package/dist/remarkable-ui/shared/ButtonIcon/ButtonIcon.d.ts.map +0 -1
  348. package/dist/remarkable-ui/shared/ButtonIcon/ButtonIcon.stories.d.ts +0 -11
  349. package/dist/remarkable-ui/shared/ButtonIcon/ButtonIcon.stories.d.ts.map +0 -1
  350. package/dist/remarkable-ui/shared/Card/Card.d.ts.map +0 -1
  351. package/dist/remarkable-ui/shared/Card/Card.stories.d.ts +0 -8
  352. package/dist/remarkable-ui/shared/Card/Card.stories.d.ts.map +0 -1
  353. package/dist/remarkable-ui/shared/Card/CardContentInfo/CardContentInfo.d.ts +0 -10
  354. package/dist/remarkable-ui/shared/Card/CardContentInfo/CardContentInfo.d.ts.map +0 -1
  355. package/dist/remarkable-ui/shared/ConfirmCancelModal/ConfirmCancelModal.d.ts +0 -4
  356. package/dist/remarkable-ui/shared/ConfirmCancelModal/ConfirmCancelModal.d.ts.map +0 -1
  357. package/dist/remarkable-ui/shared/ConfirmCancelModal/ConfirmCancelModal.stories.d.ts +0 -25
  358. package/dist/remarkable-ui/shared/ConfirmCancelModal/ConfirmCancelModal.stories.d.ts.map +0 -1
  359. package/dist/remarkable-ui/shared/ConfirmCancelModal/ConfirmCancelModal.types.d.ts +0 -10
  360. package/dist/remarkable-ui/shared/ConfirmCancelModal/ConfirmCancelModal.types.d.ts.map +0 -1
  361. package/dist/remarkable-ui/shared/ConfirmCancelModal/index.d.ts +0 -3
  362. package/dist/remarkable-ui/shared/ConfirmCancelModal/index.d.ts.map +0 -1
  363. package/dist/remarkable-ui/shared/Dropdown/Dropdown.d.ts.map +0 -1
  364. package/dist/remarkable-ui/shared/EmptyStateSkeleton/EmptyStateSkeleton.d.ts +0 -7
  365. package/dist/remarkable-ui/shared/EmptyStateSkeleton/EmptyStateSkeleton.d.ts.map +0 -1
  366. package/dist/remarkable-ui/shared/EmptyStateSkeleton/EmptyStateSkeleton.stories.d.ts +0 -6
  367. package/dist/remarkable-ui/shared/EmptyStateSkeleton/EmptyStateSkeleton.stories.d.ts.map +0 -1
  368. package/dist/remarkable-ui/shared/FieldErrorMessage/FieldErrorMessage.d.ts +0 -5
  369. package/dist/remarkable-ui/shared/FieldErrorMessage/FieldErrorMessage.d.ts.map +0 -1
  370. package/dist/remarkable-ui/shared/Foundations/Colors.stories.d.ts.map +0 -1
  371. package/dist/remarkable-ui/shared/GhostButton/GhostButton.d.ts.map +0 -1
  372. package/dist/remarkable-ui/shared/GhostButton/GhostButton.stories.d.ts +0 -44
  373. package/dist/remarkable-ui/shared/GhostButton/GhostButton.stories.d.ts.map +0 -1
  374. package/dist/remarkable-ui/shared/IconButton/IconButton.d.ts +0 -10
  375. package/dist/remarkable-ui/shared/IconButton/IconButton.d.ts.map +0 -1
  376. package/dist/remarkable-ui/shared/IconButton/IconButton.stories.d.ts +0 -11
  377. package/dist/remarkable-ui/shared/IconButton/IconButton.stories.d.ts.map +0 -1
  378. package/dist/remarkable-ui/shared/PageOverlay/PageOverlay.d.ts.map +0 -1
  379. package/dist/remarkable-ui/shared/PageOverlay/PageOverlay.stories.d.ts +0 -10
  380. package/dist/remarkable-ui/shared/PageOverlay/PageOverlay.stories.d.ts.map +0 -1
  381. package/dist/remarkable-ui/shared/PageOverlay/PageOverlay.types.d.ts.map +0 -1
  382. package/dist/remarkable-ui/shared/PageOverlay/index.d.ts +0 -3
  383. package/dist/remarkable-ui/shared/PageOverlay/index.d.ts.map +0 -1
  384. package/dist/remarkable-ui/shared/Skeleton/Skeleton.d.ts.map +0 -1
  385. package/dist/remarkable-ui/shared/Skeleton/Skeleton.stories.d.ts.map +0 -1
  386. package/dist/remarkable-ui/shared/Switch/Switch.d.ts.map +0 -1
  387. package/dist/remarkable-ui/shared/Switch/Switch.stories.d.ts +0 -36
  388. package/dist/remarkable-ui/shared/Switch/Switch.stories.d.ts.map +0 -1
  389. package/dist/remarkable-ui/shared/Typography/Typography.d.ts.map +0 -1
  390. package/dist/remarkable-ui/shared/Typography/Typography.stories.d.ts.map +0 -1
  391. package/dist/remarkable-ui/shared/Typography/Typography.types.d.ts.map +0 -1
  392. /package/dist/remarkable-ui/{charts → components/charts}/bars/BarChart.d.ts +0 -0
  393. /package/dist/remarkable-ui/{charts → components/charts}/bars/bars.utils.d.ts +0 -0
  394. /package/dist/remarkable-ui/{charts → components/charts}/chartjs.constants.d.ts +0 -0
  395. /package/dist/remarkable-ui/{charts → components/charts}/chartjs.utils.d.ts +0 -0
  396. /package/dist/remarkable-ui/{charts → components/charts}/charts.constants.d.ts +0 -0
  397. /package/dist/remarkable-ui/{charts → components/charts}/kpis/KpiChart.d.ts +0 -0
  398. /package/dist/remarkable-ui/{charts → components/charts}/kpis/components/KpiChartChange.d.ts +0 -0
  399. /package/dist/remarkable-ui/{charts → components/charts}/lines/LineChart.d.ts +0 -0
  400. /package/dist/remarkable-ui/{charts → components/charts}/lines/lines.types.d.ts +0 -0
  401. /package/dist/remarkable-ui/{charts → components/charts}/lines/lines.utils.d.ts +0 -0
  402. /package/dist/remarkable-ui/{charts → components/charts}/pies/pies.mock.d.ts +0 -0
  403. /package/dist/remarkable-ui/{charts → components/charts}/tables/HeatMap/HeatMap.d.ts +0 -0
  404. /package/dist/remarkable-ui/{charts → components/charts}/tables/HeatMap/HeatMap.types.d.ts +0 -0
  405. /package/dist/remarkable-ui/{charts → components/charts}/tables/PivotTable/PivotTable.d.ts +0 -0
  406. /package/dist/remarkable-ui/{charts → components/charts}/tables/PivotTable/PivotTable.types.d.ts +0 -0
  407. /package/dist/remarkable-ui/{charts → components/charts}/tables/Table/Table.hooks.d.ts +0 -0
  408. /package/dist/remarkable-ui/{charts → components/charts}/tables/Table/TablePaginated.d.ts +0 -0
  409. /package/dist/remarkable-ui/{charts → components/charts}/tables/Table/components/TableBody/TableBody.d.ts +0 -0
  410. /package/dist/remarkable-ui/{charts → components/charts}/tables/Table/components/TableHeader/TableHeader.d.ts +0 -0
  411. /package/dist/remarkable-ui/{charts → components/charts}/tables/Table/components/TablePagination/TablePagination.d.ts +0 -0
  412. /package/dist/remarkable-ui/{charts → components/charts}/tables/tables.utils.d.ts +0 -0
  413. /package/dist/remarkable-ui/{shared → components/editors}/Switch/Switch.d.ts +0 -0
  414. /package/dist/remarkable-ui/{editors/select → components/editors/selects}/shared/useSelectSearchFocus.hook.d.ts +0 -0
  415. /package/dist/remarkable-ui/{shared → components/shared}/Dropdown/Dropdown.d.ts +0 -0
  416. /package/dist/remarkable-ui/{shared → components/shared}/GhostButton/GhostButton.d.ts +0 -0
  417. /package/dist/remarkable-ui/{shared → components/shared}/PageOverlay/PageOverlay.d.ts +0 -0
  418. /package/dist/remarkable-ui/{shared → components/shared}/PageOverlay/PageOverlay.types.d.ts +0 -0
  419. /package/dist/remarkable-ui/{shared → components/shared}/Skeleton/Skeleton.d.ts +0 -0
  420. /package/dist/remarkable-ui/{shared → components/shared}/Typography/Typography.d.ts +0 -0
  421. /package/dist/remarkable-ui/{shared → components/shared}/Typography/Typography.types.d.ts +0 -0
@@ -1,79 +0,0 @@
1
- import { a0 as j, j as n, a3 as x, a4 as d } from "./component.constants-DCOqCFoY.js";
2
- /**
3
- * @license @tabler/icons-react v3.35.0 - MIT
4
- *
5
- * This source code is licensed under the MIT license.
6
- * See the LICENSE file in the root directory of this source tree.
7
- */
8
- const v = [["path", { d: "M3 7l6 6l4 -4l8 8", key: "svg-0" }], ["path", { d: "M21 10l0 7l-7 0", key: "svg-1" }]], y = j("outline", "trending-down", "TrendingDown", v);
9
- /**
10
- * @license @tabler/icons-react v3.35.0 - MIT
11
- *
12
- * This source code is licensed under the MIT license.
13
- * See the LICENSE file in the root directory of this source tree.
14
- */
15
- const m = [["path", { d: "M3 17l6 -6l4 4l8 -8", key: "svg-0" }], ["path", { d: "M14 7l7 0l0 7", key: "svg-1" }]], f = j("outline", "trending-up", "TrendingUp", m), N = "_kpiChartContainer_joxtc_1", T = "_kpiComparisonContainer_joxtc_26", $ = "_kpiChangeHidden_joxtc_47", k = {
16
- kpiChartContainer: N,
17
- kpiComparisonContainer: T,
18
- kpiChangeHidden: $
19
- }, B = "_kpiChartChangeContainer_13m4l_1", H = "_kpiChangeBadge_13m4l_13", M = "_positive_13m4l_36", w = "_negative_13m4l_41", o = {
20
- kpiChartChangeContainer: B,
21
- kpiChangeBadge: H,
22
- positive: M,
23
- negative: w
24
- }, I = (e, i) => e ? i ? o.negative : o.positive : i ? o.positive : o.negative, K = ({
25
- value: e,
26
- comparisonValue: i = 0,
27
- showChangeAsPercentage: r,
28
- invertChangeColors: C = !1,
29
- comparisonLabel: c,
30
- valueFormatter: p,
31
- percentageDecimalPlaces: g = 1,
32
- className: h
33
- }) => {
34
- const s = e - i, t = s > 0;
35
- let a;
36
- r ? a = `${(i === 0 ? 0 : s / i * 100).toFixed(g)}%` : a = p ? p(s) : s.toString();
37
- const l = `${t ? "+" : ""}${a}`, _ = t ? f : y;
38
- return /* @__PURE__ */ n.jsxs("div", { className: x(h, o.kpiChartChangeContainer), children: [
39
- /* @__PURE__ */ n.jsxs("div", { className: x(o.kpiChangeBadge, I(t, C)), children: [
40
- /* @__PURE__ */ n.jsx(_, {}),
41
- /* @__PURE__ */ n.jsx(d, { children: l })
42
- ] }),
43
- c && /* @__PURE__ */ n.jsx(d, { children: c })
44
- ] });
45
- }, S = ({
46
- value: e,
47
- changeFontSize: i,
48
- comparisonValue: r,
49
- comparisonLabel: C,
50
- invertChangeColors: c,
51
- showChangeAsPercentage: p,
52
- percentageDecimalPlaces: g = 1,
53
- equalComparisonLabel: h = "No change",
54
- valueFontSize: s,
55
- valueFormatter: t
56
- }) => {
57
- const a = r !== void 0, l = a && r === e, _ = e === void 0 ? "" : t ? t(e) : e;
58
- return /* @__PURE__ */ n.jsxs("div", { className: k.kpiChartContainer, children: [
59
- /* @__PURE__ */ n.jsx(d, { style: { fontSize: s }, children: _ }),
60
- /* @__PURE__ */ n.jsx("div", { className: k.kpiComparisonContainer, style: { fontSize: i }, children: l ? /* @__PURE__ */ n.jsx(d, { children: h }) : /* @__PURE__ */ n.jsx(
61
- K,
62
- {
63
- changeFontSize: i,
64
- className: x(!a && k.kpiChangeHidden),
65
- comparisonLabel: C,
66
- comparisonValue: r,
67
- invertChangeColors: c,
68
- percentageDecimalPlaces: g,
69
- showChangeAsPercentage: p,
70
- value: e,
71
- valueFormatter: t
72
- }
73
- ) })
74
- ] });
75
- };
76
- export {
77
- S as K
78
- };
79
- //# sourceMappingURL=KpiChart-CS9s8nJ4.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KpiChart-CS9s8nJ4.js","sources":["../node_modules/@tabler/icons-react/dist/esm/icons/IconTrendingDown.mjs","../node_modules/@tabler/icons-react/dist/esm/icons/IconTrendingUp.mjs","../src/remarkable-ui/charts/kpis/components/KpiChartChange.tsx","../src/remarkable-ui/charts/kpis/KpiChart.tsx"],"sourcesContent":["/**\n * @license @tabler/icons-react v3.35.0 - MIT\n *\n * This source code is licensed under the MIT license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createReactComponent from '../createReactComponent.mjs';\n\nconst __iconNode = [[\"path\", { \"d\": \"M3 7l6 6l4 -4l8 8\", \"key\": \"svg-0\" }], [\"path\", { \"d\": \"M21 10l0 7l-7 0\", \"key\": \"svg-1\" }]];\nconst IconTrendingDown = createReactComponent(\"outline\", \"trending-down\", \"TrendingDown\", __iconNode);\n\nexport { __iconNode, IconTrendingDown as default };\n//# sourceMappingURL=IconTrendingDown.mjs.map\n","/**\n * @license @tabler/icons-react v3.35.0 - MIT\n *\n * This source code is licensed under the MIT license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createReactComponent from '../createReactComponent.mjs';\n\nconst __iconNode = [[\"path\", { \"d\": \"M3 17l6 -6l4 4l8 -8\", \"key\": \"svg-0\" }], [\"path\", { \"d\": \"M14 7l7 0l0 7\", \"key\": \"svg-1\" }]];\nconst IconTrendingUp = createReactComponent(\"outline\", \"trending-up\", \"TrendingUp\", __iconNode);\n\nexport { __iconNode, IconTrendingUp as default };\n//# sourceMappingURL=IconTrendingUp.mjs.map\n","import { FC } from 'react';\nimport styles from './KpiChartChange.module.css';\nimport clsx from 'clsx';\nimport { Typography } from '../../../shared/Typography/Typography';\nimport { IconTrendingDown, IconTrendingUp } from '@tabler/icons-react';\nimport { KpiChartProps } from '../KpiChart.types';\n\nconst getChangeClass = (isPositive: boolean, invertChangeColors: boolean) => {\n if (isPositive) return invertChangeColors ? styles.negative : styles.positive;\n return invertChangeColors ? styles.positive : styles.negative;\n};\n\ntype KpiChartChangeProps = KpiChartProps & { className?: string };\n\nexport const KpiChartChange: FC<KpiChartChangeProps> = ({\n value,\n comparisonValue = 0,\n showChangeAsPercentage,\n invertChangeColors = false,\n comparisonLabel,\n valueFormatter,\n percentageDecimalPlaces = 1,\n className,\n}) => {\n const difference = value - comparisonValue;\n const isPositive = difference > 0;\n\n let differenceLabel: string;\n\n if (showChangeAsPercentage) {\n const percentage = comparisonValue === 0 ? 0 : (difference / comparisonValue) * 100;\n differenceLabel = `${percentage.toFixed(percentageDecimalPlaces)}%`;\n } else {\n differenceLabel = valueFormatter ? valueFormatter(difference) : difference.toString();\n }\n\n const displayValue = `${isPositive ? '+' : ''}${differenceLabel}`;\n\n const Icon = isPositive ? IconTrendingUp : IconTrendingDown;\n\n return (\n <div className={clsx(className, styles.kpiChartChangeContainer)}>\n <div className={clsx(styles.kpiChangeBadge, getChangeClass(isPositive, invertChangeColors))}>\n <Icon />\n <Typography>{displayValue}</Typography>\n </div>\n {comparisonLabel && <Typography>{comparisonLabel}</Typography>}\n </div>\n );\n};\n","import { FC } from 'react';\nimport { Typography } from '../../shared/Typography/Typography';\nimport styles from './KpiChart.module.css';\nimport { KpiChartChange } from './components/KpiChartChange';\nimport { KpiChartProps } from './KpiChart.types';\nimport clsx from 'clsx';\n\nexport const KpiChart: FC<KpiChartProps> = ({\n value,\n changeFontSize,\n comparisonValue,\n comparisonLabel,\n invertChangeColors,\n showChangeAsPercentage,\n percentageDecimalPlaces = 1,\n equalComparisonLabel = 'No change',\n valueFontSize,\n valueFormatter,\n}) => {\n const hasComparisonValue = comparisonValue !== undefined;\n const equalComparison = hasComparisonValue && comparisonValue === value;\n\n const displayValue = value === undefined ? '' : valueFormatter ? valueFormatter(value) : value;\n\n return (\n <div className={styles.kpiChartContainer}>\n <Typography style={{ fontSize: valueFontSize }}>{displayValue}</Typography>\n <div className={styles.kpiComparisonContainer} style={{ fontSize: changeFontSize }}>\n {equalComparison ? (\n <Typography>{equalComparisonLabel}</Typography>\n ) : (\n <KpiChartChange\n changeFontSize={changeFontSize}\n className={clsx(!hasComparisonValue && styles.kpiChangeHidden)}\n comparisonLabel={comparisonLabel}\n comparisonValue={comparisonValue}\n invertChangeColors={invertChangeColors}\n percentageDecimalPlaces={percentageDecimalPlaces}\n showChangeAsPercentage={showChangeAsPercentage}\n value={value}\n valueFormatter={valueFormatter}\n />\n )}\n </div>\n </div>\n );\n};\n"],"names":["__iconNode","IconTrendingDown","createReactComponent","IconTrendingUp","getChangeClass","isPositive","invertChangeColors","styles","KpiChartChange","value","comparisonValue","showChangeAsPercentage","comparisonLabel","valueFormatter","percentageDecimalPlaces","className","difference","differenceLabel","displayValue","Icon","clsx","jsxs","jsx","Typography","KpiChart","changeFontSize","equalComparisonLabel","valueFontSize","hasComparisonValue","equalComparison"],"mappings":"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","x_google_ignoreList":[0,1]}
@@ -1,273 +0,0 @@
1
- import { j as c, a3 as i, a4 as d } from "./component.constants-DCOqCFoY.js";
2
- import { useMemo as N, useState as Y, useEffect as Z } from "react";
3
- import { g as I } from "./tables.utils-D7KXdM2S.js";
4
- const L = "_pivotTableContainer_1tysn_2", D = "_tableContainer_1tysn_7", m = "_fullWidth_1tysn_23", tt = "_table_1tysn_7", lt = "_cell_1tysn_87", et = "_header_1tysn_112", ct = "_bold_1tysn_117", n = {
5
- pivotTableContainer: L,
6
- tableContainer: D,
7
- fullWidth: m,
8
- table: tt,
9
- cell: lt,
10
- header: et,
11
- bold: ct
12
- }, z = (j) => typeof j == "number" && !Number.isNaN(j), E = (j, _) => `${j.toFixed(_)}%`, it = ({
13
- columnWidth: j,
14
- firstColumnWidth: _,
15
- data: b,
16
- measures: o,
17
- rowDimension: y,
18
- columnDimension: p,
19
- progressive: P = !0,
20
- batchSize: v = 100,
21
- batchDelayMs: A = 0,
22
- rowTotalsFor: R = [],
23
- columnTotalsFor: F = [],
24
- totalLabel: C = "Total",
25
- className: G
26
- }) => {
27
- const x = N(() => {
28
- const t = /* @__PURE__ */ new Set();
29
- for (const l of b) {
30
- const e = l[y.key];
31
- e && t.add(e);
32
- }
33
- return Array.from(t);
34
- }, [b, y.key]), w = N(() => {
35
- const t = /* @__PURE__ */ new Set();
36
- for (const l of b) {
37
- const e = l[p.key];
38
- e && t.add(e);
39
- }
40
- return Array.from(t);
41
- }, [b, p.key]), H = N(() => {
42
- const t = /* @__PURE__ */ new Map();
43
- for (const l of b) {
44
- const e = String(l[y.key]), s = String(l[p.key]);
45
- t.has(e) || t.set(e, /* @__PURE__ */ new Map()), t.get(e).set(s, l);
46
- }
47
- return t;
48
- }, [b, y.key, p.key]), $ = N(() => new Set(R), [R]), W = N(() => new Set(F), [F]), V = $.size > 0, J = W.size > 0, B = N(() => {
49
- const t = /* @__PURE__ */ new Map();
50
- return o.forEach((l, e) => t.set(String(l.key), e)), t;
51
- }, [o]), { colTotals: K, rowTotals: O, grandTotals: q } = N(() => {
52
- const t = /* @__PURE__ */ new Map(), l = /* @__PURE__ */ new Map(), e = o.map(() => 0);
53
- for (const s of b) {
54
- const r = String(s[y.key]), a = String(s[p.key]), h = t.get(a) ?? o.map(() => 0), g = l.get(r) ?? o.map(() => 0);
55
- o.forEach((f, k) => {
56
- const T = s == null ? void 0 : s[f.key], S = Number(T);
57
- Number.isNaN(S) || (h[k] += S, g[k] += S, e[k] += S);
58
- }), t.set(a, h), l.set(r, g);
59
- }
60
- for (const s of w)
61
- t.has(String(s)) || t.set(
62
- String(s),
63
- o.map(() => 0)
64
- );
65
- for (const s of x)
66
- l.has(String(s)) || l.set(
67
- String(s),
68
- o.map(() => 0)
69
- );
70
- return { colTotals: t, rowTotals: l, grandTotals: e };
71
- }, [b, o, y.key, p.key, w, x]), [Q, M] = Y(
72
- () => P ? Math.min(v, x.length) : x.length
73
- );
74
- Z(() => {
75
- if (!P) {
76
- M(x.length);
77
- return;
78
- }
79
- let t = !1, l = null;
80
- M(0);
81
- const e = () => {
82
- M((s) => {
83
- const r = Math.min(s + v, x.length);
84
- return r < x.length && !t && (l = window.setTimeout(e, A)), r;
85
- });
86
- };
87
- return l = window.setTimeout(e, A), () => {
88
- t = !0, l !== null && window.clearTimeout(l);
89
- };
90
- }, [P, v, A, x.length, b]);
91
- const U = P ? x.slice(0, Q) : x;
92
- return /* @__PURE__ */ c.jsx("div", { className: i(n.pivotTableContainer, G), children: /* @__PURE__ */ c.jsx(
93
- "div",
94
- {
95
- className: i(
96
- n.tableContainer,
97
- (!j || !_) && n.fullWidth
98
- ),
99
- children: /* @__PURE__ */ c.jsxs(
100
- "table",
101
- {
102
- className: n.table,
103
- "aria-label": `${y.label} by ${p.label}`,
104
- children: [
105
- /* @__PURE__ */ c.jsxs("thead", { children: [
106
- /* @__PURE__ */ c.jsxs("tr", { children: [
107
- /* @__PURE__ */ c.jsx(
108
- "th",
109
- {
110
- scope: "col",
111
- rowSpan: 1,
112
- className: i(n.cell, n.header),
113
- title: p.label,
114
- children: /* @__PURE__ */ c.jsx(d, { children: p.label })
115
- }
116
- ),
117
- w.map((t) => {
118
- const l = p.formatValue ? p.formatValue(t) : t;
119
- return /* @__PURE__ */ c.jsx(
120
- "th",
121
- {
122
- scope: "colgroup",
123
- colSpan: o.length,
124
- className: i(n.cell, n.header),
125
- title: l,
126
- children: /* @__PURE__ */ c.jsx(d, { children: l })
127
- },
128
- `col-${t}`
129
- );
130
- }),
131
- V && /* @__PURE__ */ c.jsx(
132
- "th",
133
- {
134
- scope: "colgroup",
135
- colSpan: Array.from($).length,
136
- className: i(n.cell, n.bold),
137
- title: C,
138
- children: /* @__PURE__ */ c.jsx(d, { children: C })
139
- },
140
- "col-total-group"
141
- )
142
- ] }),
143
- /* @__PURE__ */ c.jsxs("tr", { children: [
144
- /* @__PURE__ */ c.jsx(
145
- "th",
146
- {
147
- scope: "col",
148
- rowSpan: 1,
149
- className: i(n.cell, n.header),
150
- title: y.label,
151
- style: I(_),
152
- children: /* @__PURE__ */ c.jsx(d, { children: y.label })
153
- }
154
- ),
155
- w.flatMap(
156
- (t) => o.map((l, e) => /* @__PURE__ */ c.jsx(
157
- "th",
158
- {
159
- scope: "col",
160
- className: i(n.cell, n.header),
161
- title: l.label,
162
- style: I(j),
163
- children: /* @__PURE__ */ c.jsx(d, { children: l.label })
164
- },
165
- `sub-${String(t)}-${l.key}-${e}`
166
- ))
167
- ),
168
- V && o.filter((t) => $.has(t.key)).map((t, l) => /* @__PURE__ */ c.jsx(
169
- "th",
170
- {
171
- scope: "col",
172
- className: i(n.cell, n.bold),
173
- title: t.label,
174
- style: I(j),
175
- children: /* @__PURE__ */ c.jsx(d, { children: t.label })
176
- },
177
- `sub-total-${t.key}-${l}`
178
- ))
179
- ] })
180
- ] }),
181
- /* @__PURE__ */ c.jsx("tbody", { children: U.map((t) => {
182
- const l = y.formatValue ? y.formatValue(t) : t;
183
- return /* @__PURE__ */ c.jsxs("tr", { children: [
184
- /* @__PURE__ */ c.jsx(
185
- "th",
186
- {
187
- scope: "row",
188
- className: i(n.cell, n.header),
189
- title: l,
190
- children: /* @__PURE__ */ c.jsx(d, { children: l })
191
- }
192
- ),
193
- w.flatMap(
194
- (e) => o.map((s, r) => {
195
- var T;
196
- const a = ((T = H.get(t)) == null ? void 0 : T.get(e)) ?? {}, h = a == null ? void 0 : a[s.key], g = `cell-${t}-${e}-${s.key}-${r}`, k = (() => {
197
- if (s.showAsPercentage) {
198
- const S = B.get(String(s.key)) ?? -1, X = K.get(String(e)) ?? o.map(() => 0), u = S >= 0 ? X[S] ?? 0 : 0;
199
- if (s.showAsPercentage && z(Number(h)) && z(u) && u > 0)
200
- return `${(h / u * 100).toFixed(s.percentageDecimalPlaces ?? 0)}%`;
201
- }
202
- return s.accessor ? s.accessor(a) : h;
203
- })();
204
- return /* @__PURE__ */ c.jsx("td", { className: i(n.cell), title: k, children: /* @__PURE__ */ c.jsx(d, { children: k }) }, g);
205
- })
206
- ),
207
- V && o.filter((e) => $.has(e.key)).map((e, s) => {
208
- const r = O.get(t) ?? o.map(() => 0), a = B.get(e.key) ?? -1, h = `row-total-${String(t)}-${e.key}-${s}`, g = a >= 0 ? r[a] ?? 0 : 0;
209
- let f = g;
210
- return e.showAsPercentage ? f = E(
211
- g / (q[a] || 1) * 100,
212
- e.percentageDecimalPlaces ?? 0
213
- ) : e.accessor && (f = e.accessor({ [e.key]: g })), /* @__PURE__ */ c.jsx(
214
- "td",
215
- {
216
- className: i(n.cell, n.bold),
217
- title: f,
218
- children: /* @__PURE__ */ c.jsx(d, { children: f })
219
- },
220
- h
221
- );
222
- })
223
- ] }, `row-${t}`);
224
- }) }),
225
- /* @__PURE__ */ c.jsx("tfoot", { children: J && /* @__PURE__ */ c.jsxs("tr", { children: [
226
- /* @__PURE__ */ c.jsx("th", { scope: "row", className: i(n.cell, n.bold), title: C, children: /* @__PURE__ */ c.jsx(d, { children: C }) }),
227
- w.flatMap(
228
- (t) => o.map((l, e) => {
229
- const s = W.has(String(l.key)), r = K.get(String(t)) ?? o.map(() => 0), a = o.findIndex((T) => String(T.key) === String(l.key)), h = `col-total-${String(t)}-${l.key}-${e}`, g = r[a] ?? 0;
230
- let f = g;
231
- l.showAsPercentage ? f = E(
232
- 100,
233
- l.percentageDecimalPlaces ?? 0
234
- ) : l.accessor && (f = l.accessor({ [l.key]: g }));
235
- const k = s ? f : "";
236
- return /* @__PURE__ */ c.jsx(
237
- "td",
238
- {
239
- className: i(n.cell, n.bold),
240
- title: k,
241
- children: /* @__PURE__ */ c.jsx(d, { children: k })
242
- },
243
- h
244
- );
245
- })
246
- ),
247
- V && o.filter((t) => $.has(t.key)).map((t, l) => {
248
- const e = o.findIndex((h) => String(h.key) === t.key), s = `grand-total-${t.key}-${l}`, r = q[e] ?? 0;
249
- let a = r;
250
- return t.showAsPercentage ? a = E(
251
- 100,
252
- t.percentageDecimalPlaces ?? 0
253
- ) : t.accessor && (a = t.accessor({ [t.key]: r })), /* @__PURE__ */ c.jsx(
254
- "td",
255
- {
256
- className: i(n.cell, n.bold),
257
- title: a,
258
- children: /* @__PURE__ */ c.jsx(d, { children: a })
259
- },
260
- s
261
- );
262
- })
263
- ] }, "totals-row") })
264
- ]
265
- }
266
- )
267
- }
268
- ) });
269
- };
270
- export {
271
- it as P
272
- };
273
- //# sourceMappingURL=PivotTable-Cx4WG6MV.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"PivotTable-Cx4WG6MV.js","sources":["../src/remarkable-ui/charts/tables/PivotTable/PivotTable.tsx"],"sourcesContent":["import { FC, useEffect, useMemo, useState } from 'react';\nimport styles from './PivotTable.module.css';\nimport clsx from 'clsx';\nimport { PivotTableProps } from './PivotTable.types';\nimport { Typography } from '../../../shared/Typography/Typography';\nimport { getTableCellWidthStyle } from '../tables.utils';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nconst isNumber = (v: any) => typeof v === 'number' && !Number.isNaN(v);\n\nconst getPercentageDisplay = (percentage: number, percentageDecimalPlaces: number) => {\n return `${percentage.toFixed(percentageDecimalPlaces)}%`;\n};\n\nexport const PivotTable: FC<PivotTableProps<any>> = ({\n columnWidth,\n firstColumnWidth,\n data,\n measures,\n rowDimension,\n columnDimension,\n progressive = true,\n batchSize = 100,\n batchDelayMs = 0,\n rowTotalsFor = [],\n columnTotalsFor = [],\n totalLabel = 'Total',\n className,\n}) => {\n const rowValues = useMemo(() => {\n const s = new Set<string>();\n for (const d of data) {\n const rowValue = d[rowDimension.key];\n if (rowValue) s.add(rowValue);\n }\n return Array.from(s);\n }, [data, rowDimension.key]);\n\n const columnValues = useMemo(() => {\n const s = new Set<string>();\n for (const d of data) {\n const columnValue = d[columnDimension.key];\n if (columnValue) s.add(columnValue as string);\n }\n return Array.from(s);\n }, [data, columnDimension.key]);\n\n const cellMap = useMemo(() => {\n const map = new Map<string, Map<string, Record<string, any>>>();\n for (const d of data) {\n const r = String(d[rowDimension.key]);\n const c = String(d[columnDimension.key]);\n if (!map.has(r)) map.set(r, new Map());\n map.get(r)!.set(c, d as Record<string, any>);\n }\n return map;\n }, [data, rowDimension.key, columnDimension.key]);\n\n const rowTotalsSet = useMemo(() => new Set<string>(rowTotalsFor), [rowTotalsFor]);\n const columnTotalsSet = useMemo(() => new Set<string>(columnTotalsFor), [columnTotalsFor]);\n const hasRowTotals = rowTotalsSet.size > 0;\n const hasColumnTotals = columnTotalsSet.size > 0;\n\n const measureIndexByKey = useMemo(() => {\n const map = new Map<string, number>();\n measures.forEach((m, i) => map.set(String(m.key), i));\n return map;\n }, [measures]);\n\n const { colTotals, rowTotals, grandTotals } = useMemo(() => {\n const cTotals = new Map<string, number[]>();\n const rTotals = new Map<string, number[]>();\n const gTotals = measures.map(() => 0);\n\n for (const d of data) {\n const r = String(d[rowDimension.key]);\n const c = String(d[columnDimension.key]);\n const cArr = cTotals.get(c) ?? measures.map(() => 0);\n const rArr = rTotals.get(r) ?? measures.map(() => 0);\n\n measures.forEach((m, i) => {\n const raw = (d as any)?.[m.key];\n const v = Number(raw);\n if (!Number.isNaN(v)) {\n cArr[i]! += v;\n rArr[i]! += v;\n gTotals[i]! += v;\n }\n });\n\n cTotals.set(c, cArr);\n rTotals.set(r, rArr);\n }\n\n for (const c of columnValues) {\n if (!cTotals.has(String(c)))\n cTotals.set(\n String(c),\n measures.map(() => 0),\n );\n }\n for (const r of rowValues) {\n if (!rTotals.has(String(r)))\n rTotals.set(\n String(r),\n measures.map(() => 0),\n );\n }\n\n return { colTotals: cTotals, rowTotals: rTotals, grandTotals: gTotals };\n }, [data, measures, rowDimension.key, columnDimension.key, columnValues, rowValues]);\n\n const [visibleCount, setVisibleCount] = useState(() =>\n progressive ? Math.min(batchSize, rowValues.length) : rowValues.length,\n );\n\n useEffect(() => {\n if (!progressive) {\n setVisibleCount(rowValues.length);\n return;\n }\n let cancelled = false;\n let t: number | null = null;\n setVisibleCount(0);\n\n const tick = () => {\n setVisibleCount((prev) => {\n const next = Math.min(prev + batchSize, rowValues.length);\n if (next < rowValues.length && !cancelled) {\n t = window.setTimeout(tick, batchDelayMs);\n }\n return next;\n });\n };\n\n t = window.setTimeout(tick, batchDelayMs);\n\n return () => {\n cancelled = true;\n if (t !== null) window.clearTimeout(t);\n };\n }, [progressive, batchSize, batchDelayMs, rowValues.length, data]);\n\n const visibleRows = progressive ? rowValues.slice(0, visibleCount) : rowValues;\n\n return (\n <div className={clsx(styles.pivotTableContainer, className)}>\n <div\n className={clsx(\n styles.tableContainer,\n (!columnWidth || !firstColumnWidth) && styles.fullWidth,\n )}\n >\n <table\n className={styles.table}\n aria-label={`${rowDimension.label} by ${columnDimension.label}`}\n >\n <thead>\n <tr>\n <th\n scope=\"col\"\n rowSpan={1}\n className={clsx(styles.cell, styles.header)}\n title={columnDimension.label}\n >\n <Typography>{columnDimension.label}</Typography>\n </th>\n {columnValues.map((columnValue) => {\n const columnValueDisplay = columnDimension.formatValue\n ? columnDimension.formatValue(columnValue)\n : columnValue;\n return (\n <th\n key={`col-${columnValue}`}\n scope=\"colgroup\"\n colSpan={measures.length}\n className={clsx(styles.cell, styles.header)}\n title={columnValueDisplay}\n >\n <Typography>{columnValueDisplay}</Typography>\n </th>\n );\n })}\n {hasRowTotals && (\n <th\n key=\"col-total-group\"\n scope=\"colgroup\"\n colSpan={Array.from(rowTotalsSet).length}\n className={clsx(styles.cell, styles.bold)}\n title={totalLabel}\n >\n <Typography>{totalLabel}</Typography>\n </th>\n )}\n </tr>\n <tr>\n <th\n scope=\"col\"\n rowSpan={1}\n className={clsx(styles.cell, styles.header)}\n title={rowDimension.label}\n style={getTableCellWidthStyle(firstColumnWidth)}\n >\n <Typography>{rowDimension.label}</Typography>\n </th>\n {columnValues.flatMap((col) =>\n measures.map((measure, idx) => (\n <th\n key={`sub-${String(col)}-${measure.key}-${idx}`}\n scope=\"col\"\n className={clsx(styles.cell, styles.header)}\n title={measure.label}\n style={getTableCellWidthStyle(columnWidth)}\n >\n <Typography>{measure.label}</Typography>\n </th>\n )),\n )}\n {hasRowTotals &&\n measures\n .filter((measure) => rowTotalsSet.has(measure.key))\n .map((measure, idx) => (\n <th\n key={`sub-total-${measure.key}-${idx}`}\n scope=\"col\"\n className={clsx(styles.cell, styles.bold)}\n title={measure.label}\n style={getTableCellWidthStyle(columnWidth)}\n >\n <Typography>{measure.label}</Typography>\n </th>\n ))}\n </tr>\n </thead>\n <tbody>\n {visibleRows.map((row) => {\n const rowDimensionValue = rowDimension.formatValue\n ? rowDimension.formatValue(row)\n : row;\n return (\n <tr key={`row-${row}`}>\n <th\n scope=\"row\"\n className={clsx(styles.cell, styles.header)}\n title={rowDimensionValue}\n >\n <Typography>{rowDimensionValue}</Typography>\n </th>\n\n {columnValues.flatMap((columnValue) =>\n measures.map((measure, idx) => {\n const object = cellMap.get(row)?.get(columnValue) ?? {};\n const value = object?.[measure.key];\n\n const key = `cell-${row}-${columnValue}-${measure.key}-${idx}`;\n const getDisplayValue = () => {\n if (measure.showAsPercentage) {\n const mi = measureIndexByKey.get(String(measure.key)) ?? -1;\n const totalsForCol =\n colTotals.get(String(columnValue)) ?? measures.map(() => 0);\n const colTotal = mi >= 0 ? (totalsForCol[mi] ?? 0) : 0;\n\n const shouldShowPct =\n measure.showAsPercentage &&\n isNumber(Number(value)) &&\n isNumber(colTotal) &&\n colTotal > 0;\n\n if (shouldShowPct) {\n const percentage = (value / colTotal) * 100;\n return `${percentage.toFixed(measure.percentageDecimalPlaces ?? 0)}%`;\n }\n }\n\n return measure.accessor ? measure.accessor(object) : value;\n };\n\n const columnValueDisplay = getDisplayValue();\n\n return (\n <td key={key} className={clsx(styles.cell)} title={columnValueDisplay}>\n <Typography>{columnValueDisplay}</Typography>\n </td>\n );\n }),\n )}\n\n {hasRowTotals &&\n measures\n .filter((measure) => rowTotalsSet.has(measure.key))\n .map((measure, idx) => {\n const totalsForRow = rowTotals.get(row) ?? measures.map(() => 0);\n const measureIndex = measureIndexByKey.get(measure.key) ?? -1;\n const key = `row-total-${String(row)}-${measure.key}-${idx}`;\n const value: number =\n measureIndex >= 0 ? (totalsForRow[measureIndex] ?? 0) : 0;\n let displayValue: any = value;\n\n if (measure.showAsPercentage) {\n displayValue = getPercentageDisplay(\n (value / (grandTotals[measureIndex] || 1)) * 100,\n measure.percentageDecimalPlaces ?? 0,\n );\n } else if (measure.accessor) {\n displayValue = measure.accessor({ [measure.key]: value });\n }\n\n return (\n <td\n key={key}\n className={clsx(styles.cell, styles.bold)}\n title={displayValue}\n >\n <Typography>{displayValue}</Typography>\n </td>\n );\n })}\n </tr>\n );\n })}\n </tbody>\n <tfoot>\n {hasColumnTotals && (\n <tr key=\"totals-row\">\n <th scope=\"row\" className={clsx(styles.cell, styles.bold)} title={totalLabel}>\n <Typography>{totalLabel}</Typography>\n </th>\n\n {columnValues.flatMap((columnValue) =>\n measures.map((measure, idx) => {\n const show = columnTotalsSet.has(String(measure.key));\n const totalsForCol =\n colTotals.get(String(columnValue)) ?? measures.map(() => 0);\n const mi = measures.findIndex((mm) => String(mm.key) === String(measure.key));\n const key = `col-total-${String(columnValue)}-${measure.key}-${idx}`;\n const value: number = totalsForCol[mi] ?? 0;\n let displayValue: any = value;\n\n if (measure.showAsPercentage) {\n displayValue = getPercentageDisplay(\n 100,\n measure.percentageDecimalPlaces ?? 0,\n );\n } else if (measure.accessor) {\n displayValue = measure.accessor({ [measure.key]: value });\n }\n const columnValueDisplay = show ? displayValue : '';\n\n return (\n <td\n key={key}\n className={clsx(styles.cell, styles.bold)}\n title={columnValueDisplay}\n >\n <Typography>{columnValueDisplay}</Typography>\n </td>\n );\n }),\n )}\n\n {hasRowTotals &&\n measures\n .filter((measure) => rowTotalsSet.has(measure.key))\n .map((measure, idx) => {\n const measureIndex = measures.findIndex((m) => String(m.key) === measure.key);\n const key = `grand-total-${measure.key}-${idx}`;\n const value: number = grandTotals[measureIndex] ?? 0;\n let displayValue: any = value;\n\n if (measure.showAsPercentage) {\n displayValue = getPercentageDisplay(\n 100,\n measure.percentageDecimalPlaces ?? 0,\n );\n } else if (measure.accessor) {\n displayValue = measure.accessor({ [measure.key]: value });\n }\n\n return (\n <td\n key={key}\n className={clsx(styles.cell, styles.bold)}\n title={displayValue}\n >\n <Typography>{displayValue}</Typography>\n </td>\n );\n })}\n </tr>\n )}\n </tfoot>\n </table>\n </div>\n </div>\n );\n};\n"],"names":["isNumber","v","getPercentageDisplay","percentage","percentageDecimalPlaces","PivotTable","columnWidth","firstColumnWidth","data","measures","rowDimension","columnDimension","progressive","batchSize","batchDelayMs","rowTotalsFor","columnTotalsFor","totalLabel","className","rowValues","useMemo","s","d","rowValue","columnValues","columnValue","cellMap","map","r","c","rowTotalsSet","columnTotalsSet","hasRowTotals","hasColumnTotals","measureIndexByKey","m","i","colTotals","rowTotals","grandTotals","cTotals","rTotals","gTotals","cArr","rArr","raw","visibleCount","setVisibleCount","useState","useEffect","cancelled","t","tick","prev","next","visibleRows","clsx","styles","jsx","jsxs","Typography","columnValueDisplay","getTableCellWidthStyle","col","measure","idx","row","rowDimensionValue","object","_a","value","key","mi","totalsForCol","colTotal","totalsForRow","measureIndex","displayValue","show","mm"],"mappings":"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"}
@@ -1,107 +0,0 @@
1
- import { j as s, ac as D, af as N, ag as w, ad as x, ae as K, ab as P } from "./component.constants-DCOqCFoY.js";
2
- import { useState as b, useRef as T, useEffect as q, useMemo as O } from "react";
3
- import { u as z, d as A, g as G, I as H, S as J, a as M } from "./EditorCard-BhC7oToX.js";
4
- const Q = "_selectField_73cni_1", U = {
5
- selectField: Q
6
- }, Y = ({
7
- value: t = "",
8
- startIcon: L,
9
- options: c,
10
- disabled: j,
11
- placeholder: y,
12
- isSearchable: m,
13
- isClearable: o,
14
- isLoading: g,
15
- noOptionsMessage: E = "No options available",
16
- onChange: I,
17
- onSearch: a,
18
- error: R = !1,
19
- errorMessage: i
20
- }) => {
21
- const [h, _] = b(!1), [C, v] = b(""), [k, d] = b(t), S = T(null);
22
- z(h, S), q(() => {
23
- if (!t) {
24
- d("");
25
- return;
26
- }
27
- const e = c.find((r) => r.value === t);
28
- e && d(e.label);
29
- }, [t, c]);
30
- const n = O(() => a ? A(a) : void 0, [a]), u = m && !a ? c.filter((e) => e.label.toLowerCase().includes(C.toLowerCase())) : c, F = O(() => G(u), [u]), f = (e) => {
31
- if (v(""), I(e ?? ""), a == null || a(""), e === "")
32
- d("");
33
- else {
34
- const r = c.find((l) => l.value === e);
35
- r && d(r.label);
36
- }
37
- }, p = (e) => {
38
- v(e), n == null || n(e);
39
- }, B = R || !!i;
40
- return /* @__PURE__ */ s.jsxs("div", { className: U.selectField, children: [
41
- /* @__PURE__ */ s.jsx(
42
- D,
43
- {
44
- open: h,
45
- onOpenChange: _,
46
- disabled: j,
47
- triggerComponent: /* @__PURE__ */ s.jsx(
48
- K,
49
- {
50
- startIcon: L,
51
- "aria-label": "Select option",
52
- placeholder: y,
53
- disabled: j,
54
- valueLabel: k,
55
- onClear: () => f(""),
56
- isClearable: o,
57
- isLoading: g,
58
- error: B
59
- }
60
- ),
61
- children: /* @__PURE__ */ s.jsxs(N, { children: [
62
- m && /* @__PURE__ */ s.jsx(
63
- w,
64
- {
65
- ref: S,
66
- startIcon: H,
67
- "aria-label": "Search options",
68
- placeholder: "Search…",
69
- role: "searchbox",
70
- value: C,
71
- onKeyDown: (e) => e.stopPropagation(),
72
- onChange: p
73
- }
74
- ),
75
- /* @__PURE__ */ s.jsxs(J, { disabled: g, children: [
76
- F ? Object.entries(F).map(([e, r]) => /* @__PURE__ */ s.jsxs("div", { children: [
77
- /* @__PURE__ */ s.jsx(M, { label: e }),
78
- r.map((l) => /* @__PURE__ */ s.jsx(
79
- x,
80
- {
81
- onClick: () => f(l == null ? void 0 : l.value),
82
- isSelected: l.value === t,
83
- ...l
84
- },
85
- (l == null ? void 0 : l.value) ?? l.label
86
- ))
87
- ] }, e)) : u.map((e) => /* @__PURE__ */ s.jsx(
88
- x,
89
- {
90
- onClick: () => f(e == null ? void 0 : e.value),
91
- isSelected: e.value === t,
92
- ...e
93
- },
94
- (e == null ? void 0 : e.value) ?? e.label
95
- )),
96
- c.length === 0 && /* @__PURE__ */ s.jsx(x, { disabled: !0, value: "empty", label: E })
97
- ] })
98
- ] })
99
- }
100
- ),
101
- i && /* @__PURE__ */ s.jsx(P, { message: i })
102
- ] });
103
- };
104
- export {
105
- Y as S
106
- };
107
- //# sourceMappingURL=SingleSelectField-DlVCi5Ej.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SingleSelectField-DlVCi5Ej.js","sources":["../src/remarkable-ui/editors/select/SingleSelectField/SingleSelectField.tsx"],"sourcesContent":["import { FC, useEffect, useMemo, useRef, useState } from 'react';\nimport { TextField } from '../../TextField/TextField';\nimport { SelectButton } from '../shared/SelectButton/SelectButton';\nimport { Dropdown } from '../../../shared/Dropdown/Dropdown';\nimport { SelectList } from '../shared/SelectList/SelectList';\nimport { SelectListOptions } from '../shared/SelectList/SelectListOptions/SelectListOptions';\nimport {\n SelectListOption,\n SelectListOptionProps,\n SelectListOptionPropsWithCategory,\n} from '../shared/SelectList/SelectListOptions/SelectListOption/SelectListOption';\nimport { SelectListCategory } from '../shared/SelectList/SelectListOptions/SelectListCategory/SelectListCategory';\nimport { groupOptionsByCategory } from '../shared/SelectList/selectList.utils';\nimport { debounce } from '../../../utils/debounce.utils';\nimport { IconSearch, TablerIcon } from '@tabler/icons-react';\nimport { useSelectSearchFocus } from '../shared/useSelectSearchFocus.hook';\nimport styles from './SingleSelectField.module.css';\nimport { FieldErrorMessage } from '../../../shared/FieldErrorMessage/FieldErrorMessage';\n\nexport type SingleSelectFieldProps = {\n options: (SelectListOptionProps | SelectListOptionPropsWithCategory)[];\n startIcon?: TablerIcon;\n value?: string;\n disabled?: boolean;\n placeholder?: string;\n isSearchable?: boolean;\n isClearable?: boolean;\n isLoading?: boolean;\n noOptionsMessage?: string;\n onChange: (value: string) => void;\n onSearch?: (search: string) => void;\n error?: boolean;\n errorMessage?: string;\n};\n\nexport const SingleSelectField: FC<SingleSelectFieldProps> = ({\n value = '',\n startIcon,\n options,\n disabled,\n placeholder,\n isSearchable,\n isClearable,\n isLoading,\n noOptionsMessage = 'No options available',\n onChange,\n onSearch,\n error = false,\n errorMessage,\n}) => {\n const [isOpen, setIsOpen] = useState(false);\n const [searchValue, setSearchValue] = useState<string>('');\n const [selectedLabel, setSelectedLabel] = useState<string>(value);\n\n const searchFieldRef = useRef<HTMLInputElement>(null);\n useSelectSearchFocus(isOpen, searchFieldRef);\n\n useEffect(() => {\n if (!value) {\n setSelectedLabel('');\n return;\n }\n\n const option = options.find((opt) => opt.value === value);\n if (option) {\n setSelectedLabel(option.label);\n }\n }, [value, options]);\n\n const debouncedSearch = useMemo(() => (onSearch ? debounce(onSearch) : undefined), [onSearch]);\n\n const displayOptions =\n isSearchable && !onSearch\n ? options.filter((option) => option.label.toLowerCase().includes(searchValue.toLowerCase()))\n : options;\n\n const groupedOptions = useMemo(() => groupOptionsByCategory(displayOptions), [displayOptions]);\n\n const handleChange = (newValue?: string) => {\n setSearchValue('');\n onChange(newValue ?? '');\n onSearch?.('');\n\n if (newValue === '') {\n setSelectedLabel('');\n } else {\n const option = options.find((opt) => opt.value === newValue);\n if (option) setSelectedLabel(option.label);\n }\n };\n\n const handleSearch = (newSearch: string) => {\n setSearchValue(newSearch);\n debouncedSearch?.(newSearch);\n };\n\n const hasError = error || !!errorMessage;\n\n return (\n <div className={styles.selectField}>\n <Dropdown\n open={isOpen}\n onOpenChange={setIsOpen}\n disabled={disabled}\n triggerComponent={\n <SelectButton\n startIcon={startIcon}\n aria-label=\"Select option\"\n placeholder={placeholder}\n disabled={disabled}\n valueLabel={selectedLabel}\n onClear={() => handleChange('')}\n isClearable={isClearable}\n isLoading={isLoading}\n error={hasError}\n />\n }\n >\n <SelectList>\n {isSearchable && (\n <TextField\n ref={searchFieldRef}\n startIcon={IconSearch}\n aria-label=\"Search options\"\n placeholder=\"Search…\"\n role=\"searchbox\"\n value={searchValue}\n onKeyDown={(e) => e.stopPropagation()}\n onChange={handleSearch}\n />\n )}\n <SelectListOptions disabled={isLoading}>\n {groupedOptions\n ? Object.entries(groupedOptions).map(([category, categoryOptions]) => (\n <div key={category}>\n <SelectListCategory label={category} />\n {categoryOptions.map((option) => (\n <SelectListOption\n key={option?.value ?? option.label}\n onClick={() => handleChange(option?.value)}\n isSelected={option.value === value}\n {...option}\n />\n ))}\n </div>\n ))\n : displayOptions.map((option) => (\n <SelectListOption\n key={option?.value ?? option.label}\n onClick={() => handleChange(option?.value)}\n isSelected={option.value === value}\n {...option}\n />\n ))}\n {options.length === 0 && (\n <SelectListOption disabled value=\"empty\" label={noOptionsMessage} />\n )}\n </SelectListOptions>\n </SelectList>\n </Dropdown>\n {errorMessage && <FieldErrorMessage message={errorMessage} />}\n </div>\n );\n};\n"],"names":["SingleSelectField","value","startIcon","options","disabled","placeholder","isSearchable","isClearable","isLoading","noOptionsMessage","onChange","onSearch","error","errorMessage","isOpen","setIsOpen","useState","searchValue","setSearchValue","selectedLabel","setSelectedLabel","searchFieldRef","useRef","useSelectSearchFocus","useEffect","option","opt","debouncedSearch","useMemo","debounce","displayOptions","groupedOptions","groupOptionsByCategory","handleChange","newValue","handleSearch","newSearch","hasError","jsxs","styles","jsx","Dropdown","SelectButton","SelectList","TextField","IconSearch","SelectListOptions","category","categoryOptions","SelectListCategory","SelectListOption","FieldErrorMessage"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"bars.utils-DTdoPs5N.js","sources":["../src/remarkable-pro/components/charts/bars/bars.utils.ts"],"sourcesContent":["import { DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { Theme } from '../../../theme/theme.types';\nimport { remarkableTheme } from '../../../theme/theme.constants';\nimport { ChartData, ChartOptions } from 'chart.js';\nimport { getThemeFormatter } from '../../../theme/formatter/formatter.utils';\nimport { groupTailAsOther } from '../charts.utils';\nimport { getColor } from '../../../theme/styles/styles.utils';\nimport { chartColors } from '../../../../remarkable-ui';\nimport { getObjectStableKey } from '../../../utils.ts/object.utils';\nimport { chartContrastColors } from '../../../../remarkable-ui/charts/charts.constants';\nimport { Context } from 'chartjs-plugin-datalabels';\n\nexport const getBarStackedChartProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n groupDimension: Dimension;\n measure: Measure;\n },\n theme: Theme,\n): ChartData<'bar'> => {\n const themeFormatter = getThemeFormatter(theme);\n const { data = [], dimension, groupDimension, measure } = props;\n\n const axis = [...new Set(data.map((d) => d[dimension.name]).filter(Boolean))].sort();\n const groupDimensionName = `${groupDimension.name}${groupDimension.inputs?.granularity ? `.${groupDimension.inputs.granularity}` : ''}`;\n const groupBy = [...new Set(data.map((d) => d[groupDimensionName]))].filter(Boolean);\n\n const themeKey = getObjectStableKey(theme);\n\n const datasets = groupBy.map((groupByItem, index) => {\n const backgroundColor = getColor(\n `${themeKey}.charts.backgroundColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.backgroundColors ?? chartContrastColors,\n index,\n );\n\n const borderColor = getColor(\n `${themeKey}.charts.borderColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.borderColors ?? chartContrastColors,\n index,\n );\n\n return {\n label: themeFormatter.data(groupDimension, groupByItem),\n rawLabel: groupByItem,\n backgroundColor,\n borderColor,\n data: axis.map((axisItem) => {\n const record = data.find(\n (d) => d[groupDimensionName] === groupByItem && d[dimension.name] === axisItem,\n );\n return record ? Number(record[measure.name]) : 0;\n }),\n };\n });\n\n return {\n labels: axis,\n datasets,\n };\n};\n\nexport const getBarChartProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n measures: Measure[];\n maxItems?: number;\n },\n theme: Theme = remarkableTheme,\n): ChartData<'bar'> => {\n if (!props.data) {\n return {\n labels: [],\n datasets: [{ data: [] }],\n };\n }\n\n const themeFormatter = getThemeFormatter(theme);\n const themeKey = getObjectStableKey(theme);\n const groupedData = groupTailAsOther(props.data, props.dimension, props.measures, props.maxItems);\n\n return {\n labels: groupedData.map((item) => {\n return item[props.dimension.name];\n }),\n datasets: props.measures.map((measure, index) => {\n const backgroundColor = getColor(\n `${themeKey}.charts.backgroundColors`,\n measure.name,\n theme.charts.backgroundColors ?? chartColors,\n index,\n );\n\n const borderColor = getColor(\n `${themeKey}.charts.borderColors`,\n measure.name,\n theme.charts.borderColors ?? chartColors,\n index,\n );\n\n return {\n label: themeFormatter.dimensionOrMeasureTitle(measure),\n data: groupedData.map((item) => item[measure.name] ?? 0),\n backgroundColor,\n borderColor,\n };\n }),\n };\n};\n\nconst getBarChartProDatalabelTotalFormatter = (\n context: Context,\n formatter: (value: number) => string,\n) => {\n const { datasets } = context.chart.data;\n const i = context.dataIndex;\n\n const total = datasets.reduce((sum, ds) => {\n const val = ds.data[i] as number;\n return sum + (val || 0);\n }, 0);\n\n return formatter(total);\n};\n\nexport const getBarChartProOptions = (\n options: {\n onBarClicked: (args: {\n axisDimensionValue: string | null;\n groupingDimensionValue: string | null;\n }) => void;\n measures: Measure[];\n dimension: Dimension;\n horizontal: boolean;\n data: ChartData<'bar'>;\n },\n theme: Theme,\n): Partial<ChartOptions<'bar'>> => {\n const { onBarClicked, measures, dimension, horizontal, data } = options;\n\n const themeFormatter = getThemeFormatter(theme);\n return {\n plugins: {\n legend: { position: theme.charts.legendPosition ?? 'bottom' },\n datalabels: {\n labels: {\n total: {\n formatter: (_value: string | number, context: Context) =>\n getBarChartProDatalabelTotalFormatter(context, (value: number) =>\n themeFormatter.data(measures[0]!, value),\n ),\n },\n value: {\n formatter: (value: string | number, context) => {\n const measure = measures[context.datasetIndex % measures.length]!;\n return themeFormatter.data(measure, value);\n },\n },\n },\n },\n tooltip: {\n callbacks: {\n title: (context) => {\n const label = context[0]?.label;\n return themeFormatter.data(dimension, label);\n },\n label: (context) => {\n const measure = measures[context.datasetIndex % measures.length]!;\n const raw = context.raw as number;\n return `${themeFormatter.data(dimension, context.dataset.label) || ''}: ${themeFormatter.data(measure, raw)}`;\n },\n },\n },\n },\n scales: {\n x: {\n ticks: {\n callback: (value) => {\n if (horizontal) {\n return themeFormatter.data(measures[0]!, value);\n }\n\n if (!data || !data.labels) return undefined;\n\n const label = data.labels[Number(value)] as string;\n\n return themeFormatter.data(dimension, label);\n },\n },\n },\n y: {\n ticks: {\n callback: (value) => {\n if (!horizontal) {\n return themeFormatter.data(measures[0]!, value);\n }\n if (!data || !data.labels) return undefined;\n const label = data.labels[Number(value)] as string;\n return themeFormatter.data(dimension, label);\n },\n },\n },\n },\n onClick: (_event, elements, chart) => {\n const element = elements[0];\n const axisDimensionValue = (element ? chart.data.labels![element.index] : null) as\n | string\n | null;\n const groupingDimensionValue = (\n element\n ? (chart.data.datasets[element.datasetIndex] as { rawLabel?: string | null })?.rawLabel\n : null\n ) as string | null;\n\n onBarClicked({\n axisDimensionValue,\n groupingDimensionValue,\n });\n },\n };\n};\n"],"names":["getBarStackedChartProData","props","theme","themeFormatter","getThemeFormatter","data","dimension","groupDimension","measure","axis","d","groupDimensionName","_a","groupBy","themeKey","getObjectStableKey","datasets","groupByItem","index","backgroundColor","getColor","chartContrastColors","borderColor","axisItem","record","getBarChartProData","remarkableTheme","groupedData","groupTailAsOther","item","chartColors","getBarChartProDatalabelTotalFormatter","context","formatter","i","total","sum","ds","val","getBarChartProOptions","options","onBarClicked","measures","horizontal","_value","value","label","raw","_event","elements","chart","element","axisDimensionValue","groupingDimensionValue"],"mappings":"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"}