erp-pro-ui 0.1.2 → 0.1.4

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 (198) hide show
  1. package/dist/animations.css +40 -0
  2. package/dist/calendar.cjs +1 -1
  3. package/dist/calendar.mjs +1 -1
  4. package/dist/card.cjs +1 -1
  5. package/dist/card.mjs +1 -1
  6. package/dist/carousel.cjs +1 -1
  7. package/dist/carousel.mjs +1 -1
  8. package/dist/catalog.cjs +6 -0
  9. package/dist/catalog.cjs.map +1 -1
  10. package/dist/catalog.d.ts +11 -1
  11. package/dist/catalog.d.ts.map +1 -1
  12. package/dist/catalog.mjs +6 -0
  13. package/dist/catalog.mjs.map +1 -1
  14. package/dist/charts.cjs +2 -1
  15. package/dist/charts.mjs +2 -2
  16. package/dist/checkbox.cjs +1 -1
  17. package/dist/checkbox.mjs +1 -1
  18. package/dist/chip.cjs +1 -1
  19. package/dist/chip.mjs +1 -1
  20. package/dist/chroma-grid.cjs +1 -1
  21. package/dist/chroma-grid.mjs +1 -1
  22. package/dist/chunks/{calendar-xrGmvukr.cjs → calendar-Cpp_Rc7T.cjs} +58 -17
  23. package/dist/chunks/calendar-Cpp_Rc7T.cjs.map +1 -0
  24. package/dist/chunks/{calendar-BarcG6x_.mjs → calendar-DrCgT_pj.mjs} +58 -17
  25. package/dist/chunks/calendar-DrCgT_pj.mjs.map +1 -0
  26. package/dist/chunks/{card-gt-HZh0h.cjs → card-C5_tFK6Q.cjs} +1 -1
  27. package/dist/chunks/{card-gt-HZh0h.cjs.map → card-C5_tFK6Q.cjs.map} +1 -1
  28. package/dist/chunks/{card-CcIF6z2H.mjs → card-Dh8wNv8N.mjs} +1 -1
  29. package/dist/chunks/{card-CcIF6z2H.mjs.map → card-Dh8wNv8N.mjs.map} +1 -1
  30. package/dist/chunks/{carousel-DJdqBVRK.mjs → carousel-BYwqI4cA.mjs} +1 -1
  31. package/dist/chunks/{carousel-DJdqBVRK.mjs.map → carousel-BYwqI4cA.mjs.map} +1 -1
  32. package/dist/chunks/{carousel-Cq5uwqQt.cjs → carousel-C1338X8h.cjs} +1 -1
  33. package/dist/chunks/{carousel-Cq5uwqQt.cjs.map → carousel-C1338X8h.cjs.map} +1 -1
  34. package/dist/chunks/{charts-DugYWvEf.mjs → charts-BYvM4TMG.mjs} +371 -117
  35. package/dist/chunks/charts-BYvM4TMG.mjs.map +1 -0
  36. package/dist/chunks/{charts-BpElnsoR.cjs → charts-DbxyHtlX.cjs} +375 -115
  37. package/dist/chunks/charts-DbxyHtlX.cjs.map +1 -0
  38. package/dist/chunks/{checkbox-yHuSw-hV.cjs → checkbox-CxOcjoGP.cjs} +1 -1
  39. package/dist/chunks/{checkbox-yHuSw-hV.cjs.map → checkbox-CxOcjoGP.cjs.map} +1 -1
  40. package/dist/chunks/{checkbox-DvwlGwWe.mjs → checkbox-Pr49U9F1.mjs} +1 -1
  41. package/dist/chunks/{checkbox-DvwlGwWe.mjs.map → checkbox-Pr49U9F1.mjs.map} +1 -1
  42. package/dist/chunks/{chip-DcBji__g.cjs → chip-B4ol1yPk.cjs} +1 -1
  43. package/dist/chunks/{chip-DcBji__g.cjs.map → chip-B4ol1yPk.cjs.map} +1 -1
  44. package/dist/chunks/{chip-BGSUmnlO.mjs → chip-DdnBLdpl.mjs} +1 -1
  45. package/dist/chunks/{chip-BGSUmnlO.mjs.map → chip-DdnBLdpl.mjs.map} +1 -1
  46. package/dist/chunks/{chroma-grid-Cdeql_2C.mjs → chroma-grid-BAo6V5A7.mjs} +1 -1
  47. package/dist/chunks/{chroma-grid-Cdeql_2C.mjs.map → chroma-grid-BAo6V5A7.mjs.map} +1 -1
  48. package/dist/chunks/{chroma-grid-9E9j1s9I.cjs → chroma-grid-CIk0dsNS.cjs} +1 -1
  49. package/dist/chunks/{chroma-grid-9E9j1s9I.cjs.map → chroma-grid-CIk0dsNS.cjs.map} +1 -1
  50. package/dist/chunks/{color-palette-BLvDnCOD.cjs → color-palette-2TuEMkAn.cjs} +1 -1
  51. package/dist/chunks/{color-palette-BLvDnCOD.cjs.map → color-palette-2TuEMkAn.cjs.map} +1 -1
  52. package/dist/chunks/{color-palette-CXlCDiZz.mjs → color-palette-euKQMWlV.mjs} +1 -1
  53. package/dist/chunks/{color-palette-CXlCDiZz.mjs.map → color-palette-euKQMWlV.mjs.map} +1 -1
  54. package/dist/chunks/{combobox-BXu3s0dt.cjs → combobox-CwGubKTt.cjs} +2 -2
  55. package/dist/chunks/combobox-CwGubKTt.cjs.map +1 -0
  56. package/dist/chunks/{combobox-CjK-qG4k.mjs → combobox-DrFmkI0F.mjs} +2 -2
  57. package/dist/chunks/combobox-DrFmkI0F.mjs.map +1 -0
  58. package/dist/chunks/{data-table-DyEQn9Yj.mjs → data-table-Bo80m7qV.mjs} +8 -8
  59. package/dist/chunks/{data-table-DyEQn9Yj.mjs.map → data-table-Bo80m7qV.mjs.map} +1 -1
  60. package/dist/chunks/{data-table-9HELVsYR.cjs → data-table-W1sK5tkL.cjs} +8 -8
  61. package/dist/chunks/{data-table-9HELVsYR.cjs.map → data-table-W1sK5tkL.cjs.map} +1 -1
  62. package/dist/chunks/{date-picker-D8gaaMlJ.mjs → date-picker-CNPORxhv.mjs} +87 -17
  63. package/dist/chunks/date-picker-CNPORxhv.mjs.map +1 -0
  64. package/dist/chunks/{date-picker-W9om1j7A.cjs → date-picker-CZo68Fkl.cjs} +87 -17
  65. package/dist/chunks/date-picker-CZo68Fkl.cjs.map +1 -0
  66. package/dist/chunks/input-BWM6G7jq.cjs +117 -0
  67. package/dist/chunks/input-BWM6G7jq.cjs.map +1 -0
  68. package/dist/chunks/input-Bt_r_B_c.mjs +105 -0
  69. package/dist/chunks/input-Bt_r_B_c.mjs.map +1 -0
  70. package/dist/chunks/{multi-select-combobox-ELSH_Xr4.mjs → multi-select-combobox-D46M-AN9.mjs} +2 -2
  71. package/dist/chunks/multi-select-combobox-D46M-AN9.mjs.map +1 -0
  72. package/dist/chunks/{multi-select-combobox-UW0X15W7.cjs → multi-select-combobox-dS6bJE_e.cjs} +2 -2
  73. package/dist/chunks/multi-select-combobox-dS6bJE_e.cjs.map +1 -0
  74. package/dist/chunks/{otp-input-B6zzOEqw.cjs → otp-input-DSW9Ca_D.cjs} +2 -2
  75. package/dist/chunks/otp-input-DSW9Ca_D.cjs.map +1 -0
  76. package/dist/chunks/{otp-input-Bg4nQG6x.mjs → otp-input-DeAi4nJ_.mjs} +2 -2
  77. package/dist/chunks/otp-input-DeAi4nJ_.mjs.map +1 -0
  78. package/dist/chunks/{progress-bar-C9FZDrju.mjs → progress-bar-B9sy7WBT.mjs} +1 -1
  79. package/dist/chunks/{progress-bar-C9FZDrju.mjs.map → progress-bar-B9sy7WBT.mjs.map} +1 -1
  80. package/dist/chunks/{progress-bar-C1OvQ-NI.cjs → progress-bar-BdvQtpm3.cjs} +1 -1
  81. package/dist/chunks/{progress-bar-C1OvQ-NI.cjs.map → progress-bar-BdvQtpm3.cjs.map} +1 -1
  82. package/dist/chunks/select-B8UQ6Uq5.mjs +170 -0
  83. package/dist/chunks/select-B8UQ6Uq5.mjs.map +1 -0
  84. package/dist/chunks/select-CCUSMvfS.cjs +176 -0
  85. package/dist/chunks/select-CCUSMvfS.cjs.map +1 -0
  86. package/dist/chunks/skeleton-BNea1Rcp.cjs +422 -0
  87. package/dist/chunks/skeleton-BNea1Rcp.cjs.map +1 -0
  88. package/dist/chunks/skeleton-CtLumdRw.mjs +368 -0
  89. package/dist/chunks/skeleton-CtLumdRw.mjs.map +1 -0
  90. package/dist/chunks/stepper-D6qQbZdg.cjs +642 -0
  91. package/dist/chunks/stepper-D6qQbZdg.cjs.map +1 -0
  92. package/dist/chunks/stepper-DUknuW2E.mjs +618 -0
  93. package/dist/chunks/stepper-DUknuW2E.mjs.map +1 -0
  94. package/dist/chunks/{textarea-CU5C-Zw9.mjs → textarea-Blky_fLK.mjs} +2 -2
  95. package/dist/chunks/{textarea-CU5C-Zw9.mjs.map → textarea-Blky_fLK.mjs.map} +1 -1
  96. package/dist/chunks/{textarea-CAUsyu4-.cjs → textarea-ok_NlE2p.cjs} +2 -2
  97. package/dist/chunks/textarea-ok_NlE2p.cjs.map +1 -0
  98. package/dist/color-palette.cjs +1 -1
  99. package/dist/color-palette.mjs +1 -1
  100. package/dist/colors.css +3 -0
  101. package/dist/combobox.cjs +1 -1
  102. package/dist/combobox.mjs +1 -1
  103. package/dist/components/data-display/charts/AreaChart.d.ts.map +1 -1
  104. package/dist/components/data-display/charts/BarChart.d.ts +1 -0
  105. package/dist/components/data-display/charts/BarChart.d.ts.map +1 -1
  106. package/dist/components/data-display/charts/NeonLineChart.d.ts.map +1 -1
  107. package/dist/components/data-display/charts/PieChart.d.ts +18 -2
  108. package/dist/components/data-display/charts/PieChart.d.ts.map +1 -1
  109. package/dist/components/data-display/charts/PositiveNegativeBarChart.d.ts +21 -0
  110. package/dist/components/data-display/charts/PositiveNegativeBarChart.d.ts.map +1 -0
  111. package/dist/components/data-display/charts/StackedBarChart.d.ts.map +1 -1
  112. package/dist/components/data-display/charts/ThinBreakdownBar.d.ts +3 -0
  113. package/dist/components/data-display/charts/ThinBreakdownBar.d.ts.map +1 -1
  114. package/dist/components/data-display/charts/chartStyles.d.ts +24 -0
  115. package/dist/components/data-display/charts/chartStyles.d.ts.map +1 -0
  116. package/dist/components/data-display/charts/index.d.ts +2 -0
  117. package/dist/components/data-display/charts/index.d.ts.map +1 -1
  118. package/dist/components/data-display/skeleton/Skeleton.d.ts +32 -5
  119. package/dist/components/data-display/skeleton/Skeleton.d.ts.map +1 -1
  120. package/dist/components/data-display/skeleton/index.d.ts +2 -2
  121. package/dist/components/data-display/skeleton/index.d.ts.map +1 -1
  122. package/dist/components/forms/calendar/Calendar.d.ts.map +1 -1
  123. package/dist/components/forms/date-picker/DatePicker.d.ts.map +1 -1
  124. package/dist/components/forms/input/Input.d.ts.map +1 -1
  125. package/dist/components/forms/input/types.d.ts +5 -0
  126. package/dist/components/forms/input/types.d.ts.map +1 -1
  127. package/dist/components/forms/select/Select.d.ts.map +1 -1
  128. package/dist/components/forms/select/types.d.ts +7 -1
  129. package/dist/components/forms/select/types.d.ts.map +1 -1
  130. package/dist/components/navigation/stepper/Stepper1.d.ts +4 -0
  131. package/dist/components/navigation/stepper/Stepper1.d.ts.map +1 -0
  132. package/dist/components/navigation/stepper/Stepper2.d.ts +5 -0
  133. package/dist/components/navigation/stepper/Stepper2.d.ts.map +1 -0
  134. package/dist/components/navigation/stepper/index.d.ts +4 -1
  135. package/dist/components/navigation/stepper/index.d.ts.map +1 -1
  136. package/dist/components/navigation/stepper/types.d.ts +85 -0
  137. package/dist/components/navigation/stepper/types.d.ts.map +1 -1
  138. package/dist/data-table.cjs +1 -1
  139. package/dist/data-table.mjs +1 -1
  140. package/dist/date-picker.cjs +1 -1
  141. package/dist/date-picker.mjs +1 -1
  142. package/dist/docs.cjs +12 -2
  143. package/dist/docs.cjs.map +1 -1
  144. package/dist/docs.d.ts.map +1 -1
  145. package/dist/docs.mjs +12 -2
  146. package/dist/docs.mjs.map +1 -1
  147. package/dist/foundation.css +7 -0
  148. package/dist/index.cjs +32 -19
  149. package/dist/index.d.ts +7 -4
  150. package/dist/index.d.ts.map +1 -1
  151. package/dist/index.mjs +20 -20
  152. package/dist/input.cjs +1 -1
  153. package/dist/input.mjs +1 -1
  154. package/dist/multi-select-combobox.cjs +1 -1
  155. package/dist/multi-select-combobox.mjs +1 -1
  156. package/dist/otp-input.cjs +1 -1
  157. package/dist/otp-input.mjs +1 -1
  158. package/dist/progress-bar.cjs +1 -1
  159. package/dist/progress-bar.mjs +1 -1
  160. package/dist/select.cjs +1 -1
  161. package/dist/select.mjs +1 -1
  162. package/dist/skeleton.cjs +9 -1
  163. package/dist/skeleton.mjs +2 -2
  164. package/dist/stepper.cjs +5 -1
  165. package/dist/stepper.mjs +2 -2
  166. package/dist/textarea.cjs +1 -1
  167. package/dist/textarea.mjs +1 -1
  168. package/dist/tokens.css +11 -2
  169. package/package.json +9 -9
  170. package/dist/chunks/calendar-BarcG6x_.mjs.map +0 -1
  171. package/dist/chunks/calendar-xrGmvukr.cjs.map +0 -1
  172. package/dist/chunks/charts-BpElnsoR.cjs.map +0 -1
  173. package/dist/chunks/charts-DugYWvEf.mjs.map +0 -1
  174. package/dist/chunks/combobox-BXu3s0dt.cjs.map +0 -1
  175. package/dist/chunks/combobox-CjK-qG4k.mjs.map +0 -1
  176. package/dist/chunks/date-picker-D8gaaMlJ.mjs.map +0 -1
  177. package/dist/chunks/date-picker-W9om1j7A.cjs.map +0 -1
  178. package/dist/chunks/input-D9qZNqXV.cjs +0 -99
  179. package/dist/chunks/input-D9qZNqXV.cjs.map +0 -1
  180. package/dist/chunks/input-wNqevfQ4.mjs +0 -87
  181. package/dist/chunks/input-wNqevfQ4.mjs.map +0 -1
  182. package/dist/chunks/multi-select-combobox-ELSH_Xr4.mjs.map +0 -1
  183. package/dist/chunks/multi-select-combobox-UW0X15W7.cjs.map +0 -1
  184. package/dist/chunks/otp-input-B6zzOEqw.cjs.map +0 -1
  185. package/dist/chunks/otp-input-Bg4nQG6x.mjs.map +0 -1
  186. package/dist/chunks/select-D71tk6-I.mjs +0 -152
  187. package/dist/chunks/select-D71tk6-I.mjs.map +0 -1
  188. package/dist/chunks/select-WC_kPqUP.cjs +0 -158
  189. package/dist/chunks/select-WC_kPqUP.cjs.map +0 -1
  190. package/dist/chunks/skeleton-BhYWOp0Q.mjs +0 -215
  191. package/dist/chunks/skeleton-BhYWOp0Q.mjs.map +0 -1
  192. package/dist/chunks/skeleton-DTXpHYYB.cjs +0 -221
  193. package/dist/chunks/skeleton-DTXpHYYB.cjs.map +0 -1
  194. package/dist/chunks/stepper-D4yQsQB0.mjs +0 -261
  195. package/dist/chunks/stepper-D4yQsQB0.mjs.map +0 -1
  196. package/dist/chunks/stepper-fY-Sx72k.cjs +0 -267
  197. package/dist/chunks/stepper-fY-Sx72k.cjs.map +0 -1
  198. package/dist/chunks/textarea-CAUsyu4-.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/navigation/stepper/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,YAAY,EACV,YAAY,EACZ,IAAI,EACJ,kBAAkB,EAClB,cAAc,EACd,WAAW,GACZ,MAAM,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/navigation/stepper/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,YAAY,CAAC;AACrD,OAAO,EAAE,YAAY,IAAI,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpE,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AACzE,YAAY,EACV,YAAY,EACZ,IAAI,EACJ,4BAA4B,EAC5B,kBAAkB,EAClB,cAAc,EACd,WAAW,EACX,gBAAgB,EAChB,iBAAiB,EACjB,iBAAiB,EACjB,iCAAiC,EACjC,4BAA4B,EAC5B,kBAAkB,EAClB,sBAAsB,GACvB,MAAM,SAAS,CAAC"}
@@ -3,6 +3,8 @@ export type StepStatus = "completed" | "current" | "upcoming" | "error";
3
3
  export type StepperOrientation = "horizontal" | "vertical";
4
4
  export type StepperSize = "sm" | "md" | "lg";
5
5
  export type StepperVariant = "default" | "glass" | "minimal" | "outlined";
6
+ export type StepperStepsState = "untouched" | "valid" | "invalid";
7
+ export type ResponsiveStepperOrientation = StepperOrientation | "responsive";
6
8
  export interface Step {
7
9
  /** Unique identifier for the step */
8
10
  id: string;
@@ -80,4 +82,87 @@ export interface StepConnectorProps {
80
82
  className?: string;
81
83
  colors?: StepperProps["colors"];
82
84
  }
85
+ export interface StepperStepsItem {
86
+ /** Step label shown inside the step button */
87
+ label: string;
88
+ /** Optional leading icon for the step */
89
+ icon?: ReactNode;
90
+ }
91
+ export interface StepperStepsProps {
92
+ /** Ordered step labels */
93
+ steps: readonly StepperStepsItem[];
94
+ /** Current active step index (0-based) */
95
+ currentStep: number;
96
+ /** Optional click handler for interactive step navigation */
97
+ onStepClick?: (stepIndex: number) => void;
98
+ /** Optional status for each step */
99
+ stepStates?: readonly StepperStepsState[];
100
+ /** Fixed orientation or responsive mode */
101
+ orientation?: ResponsiveStepperOrientation;
102
+ /** Breakpoint used when orientation is responsive */
103
+ responsiveBreakpoint?: number;
104
+ /** Optional wrapper class name */
105
+ className?: string;
106
+ /** Optional class name applied to each step button */
107
+ stepClassName?: string;
108
+ /** Optional class name applied to connectors */
109
+ connectorClassName?: string;
110
+ }
111
+ export type StepperWizardIndicatorStatus = "active" | "inactive" | "complete";
112
+ export interface StepperWizardIndicatorRenderProps {
113
+ /** Step index (0-based) */
114
+ stepIndex: number;
115
+ /** Step label number (1-based) */
116
+ stepNumber: number;
117
+ /** Current active step index (0-based) */
118
+ currentStep: number;
119
+ /** Visual status for the indicator */
120
+ status: StepperWizardIndicatorStatus;
121
+ /** Whether the indicator can be clicked */
122
+ isClickable: boolean;
123
+ /** Navigate to a different step */
124
+ onStepClick: (stepIndex: number) => void;
125
+ }
126
+ export interface StepperWizardProps {
127
+ /** Step content panes */
128
+ children: ReactNode;
129
+ /** Initial step index for uncontrolled usage */
130
+ initialStep?: number;
131
+ /** Current step index for controlled usage */
132
+ currentStep?: number;
133
+ /** Called whenever the active step changes */
134
+ onStepChange?: (stepIndex: number) => void;
135
+ /** Called when the final action completes */
136
+ onFinalStepCompleted?: () => void;
137
+ /** Optional class name for the outer indicator shell */
138
+ stepCircleContainerClassName?: string;
139
+ /** Optional class name for the indicator row */
140
+ stepContainerClassName?: string;
141
+ /** Optional class name for the content area */
142
+ contentClassName?: string;
143
+ /** Optional class name for the footer area */
144
+ footerClassName?: string;
145
+ /** Additional props for the back button */
146
+ backButtonProps?: React.ButtonHTMLAttributes<HTMLButtonElement>;
147
+ /** Additional props for the next button */
148
+ nextButtonProps?: React.ButtonHTMLAttributes<HTMLButtonElement>;
149
+ /** Back button label */
150
+ backButtonText?: string;
151
+ /** Next button label */
152
+ nextButtonText?: string;
153
+ /** Completion button label */
154
+ completeButtonText?: string;
155
+ /** Disable step indicator navigation */
156
+ disableStepIndicators?: boolean;
157
+ /** Custom indicator renderer */
158
+ renderStepIndicator?: (props: StepperWizardIndicatorRenderProps) => ReactNode;
159
+ /** Optional wrapper class name */
160
+ className?: string;
161
+ }
162
+ export interface StepperWizardStepProps {
163
+ /** Step content */
164
+ children: ReactNode;
165
+ /** Optional class name for the content shell */
166
+ className?: string;
167
+ }
83
168
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/navigation/stepper/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/navigation/stepper/types.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
- const require_data_table = require("./chunks/data-table-9HELVsYR.cjs");
2
+ const require_data_table = require("./chunks/data-table-W1sK5tkL.cjs");
3
3
  exports.ColumnToggle = require_data_table.ColumnToggle;
4
4
  exports.DataTable = require_data_table.DataTable;
5
5
  exports.FilterButton = require_data_table.FilterButton;
@@ -1,2 +1,2 @@
1
- import { a as FilterProfile, i as FilterDropdown, n as DataTable, r as FilterButton, t as ColumnToggle } from "./chunks/data-table-DyEQn9Yj.mjs";
1
+ import { a as FilterProfile, i as FilterDropdown, n as DataTable, r as FilterButton, t as ColumnToggle } from "./chunks/data-table-Bo80m7qV.mjs";
2
2
  export { ColumnToggle, DataTable, FilterButton, FilterDropdown, FilterProfile };
@@ -1,3 +1,3 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
- const require_date_picker = require("./chunks/date-picker-W9om1j7A.cjs");
2
+ const require_date_picker = require("./chunks/date-picker-CZo68Fkl.cjs");
3
3
  exports.DatePicker = require_date_picker.DatePicker;
@@ -1,2 +1,2 @@
1
- import { t as DatePicker } from "./chunks/date-picker-D8gaaMlJ.mjs";
1
+ import { t as DatePicker } from "./chunks/date-picker-CNPORxhv.mjs";
2
2
  export { DatePicker };
package/dist/docs.cjs CHANGED
@@ -401,7 +401,7 @@ var componentDocSeeds = {
401
401
  },
402
402
  skeleton: {
403
403
  exportName: "SkeletonComponent",
404
- summary: "Placeholder block for perceived-performance states while structured content is loading.",
404
+ summary: "Theme-aware placeholder system with semantic tones, speed control, light/dark mode support, and ready-made metric, card, list, and table presets.",
405
405
  aliases: ["placeholder"],
406
406
  related: [
407
407
  "loading",
@@ -409,7 +409,7 @@ var componentDocSeeds = {
409
409
  "card"
410
410
  ],
411
411
  rootImport: "import { SkeletonComponent } from 'erp-pro-ui';",
412
- subpathImport: "import { Skeleton as SkeletonComponent } from 'erp-pro-ui/skeleton';"
412
+ subpathImport: "import { Skeleton as SkeletonComponent, SkeletonMetricCard } from 'erp-pro-ui/skeleton';"
413
413
  },
414
414
  "area-chart": {
415
415
  exportName: "AreaChart",
@@ -431,6 +431,16 @@ var componentDocSeeds = {
431
431
  "thin-breakdown-bar"
432
432
  ]
433
433
  },
434
+ "positive-negative-bar-chart": {
435
+ exportName: "PositiveNegativeBarChart",
436
+ summary: "Signed bar chart for profit-loss swings, variance reporting, and delta views that pivot around zero.",
437
+ aliases: ["variance chart", "profit loss chart"],
438
+ related: [
439
+ "bar-chart",
440
+ "stacked-bar-chart",
441
+ "area-chart"
442
+ ]
443
+ },
434
444
  "pie-chart": {
435
445
  exportName: "PieChart",
436
446
  summary: "Pie and donut chart visualizations for part-to-whole comparisons with small category sets.",
package/dist/docs.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"docs.cjs","names":[],"sources":["../src/docs.ts"],"sourcesContent":["import {\n getUiCatalogDocsRoute,\n type UiCatalogSlug,\n type UiCatalogStatus,\n uiCatalogItems,\n} from \"./catalog\";\n\nexport type LibraryDocsCodeLanguage = \"bash\" | \"css\" | \"json\" | \"tsx\";\n\nexport interface LibraryDocsCodeExample {\n readonly title: string;\n readonly language: LibraryDocsCodeLanguage;\n readonly code: string;\n readonly description?: string;\n}\n\nexport interface LibraryDocsInstallStep {\n readonly title: string;\n readonly description: string;\n readonly examples?: readonly LibraryDocsCodeExample[];\n}\n\nexport interface LibraryDocsPeerDependency {\n readonly name: string;\n readonly reason: string;\n}\n\nexport interface LibraryComponentDoc {\n readonly name: string;\n readonly slug: UiCatalogSlug;\n readonly status?: UiCatalogStatus;\n readonly category: string;\n readonly summary: string;\n readonly storybookTitle: string;\n readonly packageExportPath: string;\n readonly exportName?: string;\n readonly aliases: readonly string[];\n readonly rootImport: string;\n readonly subpathImport: string;\n readonly docsRoute: string;\n readonly docsUrl: string;\n readonly related: readonly UiCatalogSlug[];\n}\n\nexport interface LibraryDocsBundle {\n readonly packageName: \"erp-pro-ui\";\n readonly docsBaseUrl: string;\n readonly summary: string;\n readonly features: readonly string[];\n readonly installSteps: readonly LibraryDocsInstallStep[];\n readonly peerDependencies: readonly LibraryDocsPeerDependency[];\n readonly quickStartExamples: readonly LibraryDocsCodeExample[];\n readonly components: readonly LibraryComponentDoc[];\n}\n\ninterface ComponentDocSeed {\n readonly exportName?: string;\n readonly summary: string;\n readonly aliases?: readonly string[];\n readonly related?: readonly UiCatalogSlug[];\n readonly rootImport?: string;\n readonly subpathImport?: string;\n}\n\nconst DOCS_BASE_URL = \"https://daniel-heydari-dev.github.io/erp-pro-ui\";\n\nconst componentDocSeeds = {\n combobox: {\n exportName: \"Combobox\",\n summary:\n \"Searchable single-select control for long option lists and command-style pickers.\",\n aliases: [\"autocomplete\", \"search select\"],\n related: [\"select\", \"multiselect-combobox\", \"input\"],\n },\n button: {\n exportName: \"Button\",\n summary:\n \"Primary action trigger with size variants, button attributes, and support for custom children.\",\n aliases: [\"cta\", \"action\"],\n related: [\"dialog\", \"form\", \"input\"],\n },\n input: {\n exportName: \"Input\",\n summary:\n \"Text field for forms with label, validation state, helper text, and icon support.\",\n aliases: [\"text field\", \"field\"],\n related: [\"label\", \"textarea\", \"form\"],\n },\n checkbox: {\n exportName: \"Checkbox\",\n summary:\n \"Binary selection control for filters, permissions, and multi-select form fields.\",\n aliases: [\"boolean\"],\n related: [\"radio\", \"switch\", \"form\"],\n },\n radio: {\n exportName: \"Radio\",\n summary:\n \"Single-choice selection control for mutually exclusive form options.\",\n aliases: [\"radio group\"],\n related: [\"checkbox\", \"select\", \"form\"],\n },\n switch: {\n exportName: \"Switch\",\n summary:\n \"Immediate on/off toggle suited to settings panels and preference screens.\",\n aliases: [\"toggle\"],\n related: [\"checkbox\", \"sun-to-moon-button\", \"form\"],\n },\n select: {\n exportName: \"Select\",\n summary: \"Compact dropdown input for short, fixed option sets.\",\n aliases: [\"dropdown\"],\n related: [\"combobox\", \"multiselect-combobox\", \"form\"],\n },\n textarea: {\n exportName: \"Textarea\",\n summary:\n \"Multi-line text input for descriptions, notes, and longer form responses.\",\n aliases: [\"multiline input\"],\n related: [\"input\", \"label\", \"form\"],\n },\n label: {\n exportName: \"Label\",\n summary:\n \"Accessible form label primitive for pairing readable text with inputs and controls.\",\n aliases: [\"field label\"],\n related: [\"input\", \"textarea\", \"form\"],\n },\n dialog: {\n exportName: \"Dialog\",\n summary:\n \"Modal overlay for confirmations, destructive flows, and custom embedded forms.\",\n aliases: [\"modal\"],\n related: [\"drawer\", \"button\", \"toast\"],\n },\n drawer: {\n exportName: \"Drawer\",\n summary:\n \"Slide-in panel for secondary workflows, detail panes, and mobile task flows.\",\n aliases: [\"sheet\", \"side panel\"],\n related: [\"dialog\", \"card\", \"tooltip\"],\n },\n alert: {\n exportName: \"Alert\",\n summary:\n \"Inline status banner with semantic variants for success, warning, info, and destructive states.\",\n aliases: [\"message banner\"],\n related: [\"toast\", \"loading\", \"skeleton\"],\n },\n toast: {\n exportName: \"ToastProvider\",\n summary:\n \"Transient notification system exposed through ToastProvider and useToast for async feedback.\",\n aliases: [\"notification\"],\n related: [\"alert\", \"dialog\", \"loading\"],\n rootImport: \"import { ToastProvider, useToast } from 'erp-pro-ui';\",\n subpathImport:\n \"import { ToastProvider, useToast } from 'erp-pro-ui/toast';\",\n },\n tooltip: {\n exportName: \"Tooltip\",\n summary:\n \"Hover and focus overlay for concise contextual help without leaving the current view.\",\n aliases: [\"hint\"],\n related: [\"hover-card\", \"dialog\", \"drawer\"],\n },\n accordion: {\n exportName: \"Accordion\",\n summary:\n \"Expandable content container for FAQs, settings groups, and disclosure-heavy interfaces.\",\n aliases: [\"collapse\"],\n related: [\"card\", \"stepper\", \"tooltip\"],\n },\n card: {\n exportName: \"Card\",\n summary:\n \"Surface container for grouping content, actions, and stats in dashboards and forms.\",\n aliases: [\"panel\"],\n related: [\"accordion\", \"spotlight-card\", \"data-table\"],\n },\n stepper: {\n exportName: \"Stepper\",\n summary:\n \"Visual progress indicator for guided workflows, checkouts, and multi-step forms.\",\n aliases: [\"wizard steps\"],\n related: [\"form\", \"chip\", \"loading\"],\n },\n chip: {\n exportName: \"Chip\",\n summary:\n \"Compact status and taxonomy token with visual variants for tags, states, and filters.\",\n aliases: [\"tag\", \"badge\"],\n related: [\"alert\", \"color-palette\", \"stepper\"],\n },\n \"progress-bar\": {\n exportName: \"ProgressBar\",\n summary:\n \"Linear progress indicator for completion ratios, quotas, and compact operational status rows.\",\n aliases: [\"progress\", \"meter\", \"completion bar\"],\n related: [\"chip\", \"loading\", \"stepper\"],\n },\n calendar: {\n exportName: \"Calendar\",\n summary:\n \"Calendar view for scheduling surfaces, date picking UIs, and embedded planners.\",\n aliases: [\"date calendar\"],\n related: [\"datepicker\", \"input\", \"form\"],\n },\n datepicker: {\n exportName: \"DatePicker\",\n summary:\n \"Calendar-backed date input for forms that need controlled value selection and display.\",\n aliases: [\"date picker\"],\n related: [\"calendar\", \"input\", \"form\"],\n },\n \"multiselect-combobox\": {\n exportName: \"MultiSelectCombobox\",\n summary:\n \"Searchable multi-value selector for filters, assignee pickers, and label assignment flows.\",\n aliases: [\"multi select\", \"token select\"],\n related: [\"combobox\", \"select\", \"chip\"],\n },\n \"hover-card\": {\n exportName: \"HoverCard\",\n summary:\n \"Rich hover preview surface for profile cards, metadata popovers, and secondary details.\",\n aliases: [\"preview card\"],\n related: [\"tooltip\", \"card\", \"dialog\"],\n },\n \"spotlight-card\": {\n exportName: \"SpotlightCard\",\n summary:\n \"Interactive card with a cursor-reactive spotlight effect for premium landing sections.\",\n aliases: [\"interactive card\"],\n related: [\"card\", \"hover-border-gradient\", \"background-gradient\"],\n },\n \"splash-cursor\": {\n exportName: \"SplashCursor\",\n summary:\n \"Pointer effect that adds an animated splash trail for immersive visual experiences.\",\n aliases: [\"cursor effect\"],\n related: [\"chroma-grid\", \"animated-content\", \"spotlight-card\"],\n },\n \"chroma-grid\": {\n exportName: \"ChromaGrid\",\n summary:\n \"Animated chromatic grid background for showcase sections, heroes, and immersive canvases.\",\n aliases: [\"grid effect\"],\n related: [\"background-gradient\", \"splash-cursor\", \"gradual-blur\"],\n },\n \"color-palette\": {\n exportName: \"ColorPalette\",\n summary:\n \"Palette viewer for design tokens, brand colors, and handoff documentation.\",\n aliases: [\"swatches\"],\n related: [\"chip\", \"typography\", \"icons\"],\n },\n \"gradual-blur\": {\n exportName: \"GradualBlur\",\n summary:\n \"Progressive blur reveal wrapper for staged entrances and atmospheric transitions.\",\n aliases: [\"blur reveal\"],\n related: [\"animated-content\", \"background-gradient\", \"chroma-grid\"],\n },\n \"animated-content\": {\n exportName: \"AnimatedContent\",\n summary:\n \"Scroll and reveal motion wrapper for staging content entrances without custom animation plumbing.\",\n aliases: [\"reveal animation\"],\n related: [\"gradual-blur\", \"spotlight-card\", \"splash-cursor\"],\n },\n \"background-gradient\": {\n exportName: \"BackgroundGradientAnimation\",\n summary:\n \"Animated multi-stop gradient backdrop for hero sections and premium product storytelling.\",\n aliases: [\"gradient background\"],\n related: [\"chroma-grid\", \"gradual-blur\", \"spotlight-card\"],\n },\n \"hover-border-gradient\": {\n exportName: \"HoverBorderGradient\",\n summary:\n \"Gradient-border wrapper that emphasizes cards and feature callouts on hover.\",\n aliases: [\"gradient border\"],\n related: [\"button-hover-border-gradient\", \"card\", \"spotlight-card\"],\n },\n \"button-hover-border-gradient\": {\n exportName: \"ButtonHoverBorderGradient\",\n summary:\n \"CTA button variant with animated gradient edge treatment for high-emphasis surfaces.\",\n aliases: [\"gradient button\"],\n related: [\"button\", \"hover-border-gradient\", \"background-gradient\"],\n },\n \"password-strength-meter\": {\n exportName: \"PasswordStrengthMeter\",\n summary:\n \"Password quality indicator for sign-up and reset forms that need immediate feedback.\",\n aliases: [\"password meter\"],\n related: [\"input\", \"form\", \"alert\"],\n },\n \"sun-to-moon-button\": {\n exportName: \"SunToMoonButton\",\n summary:\n \"Animated theme toggle control for switching between light and dark presentation modes.\",\n aliases: [\"theme toggle\"],\n related: [\"switch\", \"typography\", \"background-gradient\"],\n },\n carousel: {\n exportName: \"Carousel\",\n summary:\n \"Content slider for galleries, testimonials, walkthroughs, and promotional sequences.\",\n aliases: [\"slider\"],\n related: [\"card\", \"animated-content\", \"spotlight-card\"],\n },\n otpinput: {\n exportName: \"OTPInput\",\n summary:\n \"One-time passcode input optimized for verification flows, MFA, and access codes.\",\n aliases: [\"otp\", \"verification code\"],\n related: [\"input\", \"password-strength-meter\", \"form\"],\n },\n form: {\n exportName: \"Form\",\n summary:\n \"Form composition surface for validation-driven layouts and grouped input sections.\",\n aliases: [\"form wrapper\"],\n related: [\"input\", \"button\", \"stepper\"],\n },\n \"data-table\": {\n exportName: \"DataTable\",\n summary:\n \"Feature-rich data grid with sorting, filtering, column toggles, and filter profiles.\",\n aliases: [\"table\", \"grid\"],\n related: [\"loading\", \"skeleton\", \"chip\"],\n },\n loading: {\n exportName: \"Loading\",\n summary:\n \"Unified loading surface exposing spinner, dots, pulse, bars, ring, bounce, wave, and skeleton variants.\",\n aliases: [\"loader\", \"progress indicator\"],\n related: [\"skeleton\", \"alert\", \"data-table\"],\n },\n skeleton: {\n exportName: \"SkeletonComponent\",\n summary:\n \"Placeholder block for perceived-performance states while structured content is loading.\",\n aliases: [\"placeholder\"],\n related: [\"loading\", \"data-table\", \"card\"],\n rootImport: \"import { SkeletonComponent } from 'erp-pro-ui';\",\n subpathImport:\n \"import { Skeleton as SkeletonComponent } from 'erp-pro-ui/skeleton';\",\n },\n \"area-chart\": {\n exportName: \"AreaChart\",\n summary:\n \"Gradient-filled area chart for trend storytelling and cumulative time-series views.\",\n aliases: [\"trend chart\"],\n related: [\"bar-chart\", \"neon-line-chart\", \"stacked-bar-chart\"],\n },\n \"bar-chart\": {\n exportName: \"BarChart\",\n summary:\n \"Bar chart for comparisons across categories, teams, or time buckets.\",\n aliases: [\"column chart\"],\n related: [\"area-chart\", \"stacked-bar-chart\", \"thin-breakdown-bar\"],\n },\n \"pie-chart\": {\n exportName: \"PieChart\",\n summary:\n \"Pie and donut chart visualizations for part-to-whole comparisons with small category sets.\",\n aliases: [\"donut chart\"],\n related: [\"bar-chart\", \"thin-breakdown-bar\", \"color-palette\"],\n },\n \"neon-line-chart\": {\n exportName: \"NeonLineChart\",\n summary:\n \"High-emphasis glowing line chart for dashboards that need a more stylized analytical treatment.\",\n aliases: [\"line chart\"],\n related: [\"area-chart\", \"bar-chart\", \"stacked-bar-chart\"],\n },\n \"stacked-bar-chart\": {\n exportName: \"StackedBarChart\",\n summary:\n \"Stacked categorical chart for comparing totals and composition inside each bar.\",\n aliases: [\"stacked chart\"],\n related: [\"bar-chart\", \"thin-breakdown-bar\", \"area-chart\"],\n },\n \"thin-breakdown-bar\": {\n exportName: \"ThinBreakdownBar\",\n summary:\n \"Compact horizontal breakdown bar for inline composition summaries and KPI cards.\",\n aliases: [\"breakdown bar\"],\n related: [\"stacked-bar-chart\", \"pie-chart\", \"chip\"],\n },\n icons: {\n summary:\n \"Collection of custom SVG icons for dashboards, navigation, commerce, and status-heavy product UIs.\",\n aliases: [\"icon pack\", \"svg icons\"],\n related: [\"typography\", \"color-palette\", \"button\"],\n rootImport:\n \"import { IconDashboard, IconSettings, IconUser } from 'erp-pro-ui';\",\n subpathImport:\n \"import { IconDashboard, IconSettings, IconUser } from 'erp-pro-ui/icons';\",\n },\n typography: {\n exportName: \"Typography\",\n summary:\n \"Semantic text component with heading, body, caption, alignment, weight, and gradient options.\",\n aliases: [\"text\"],\n related: [\"color-palette\", \"icons\", \"button\"],\n },\n} as const satisfies Record<UiCatalogSlug, ComponentDocSeed>;\n\nfunction getComponentCategory(storybookTitle: string): string {\n return storybookTitle.split(\"/\")[0] ?? \"Components\";\n}\n\nfunction getDefaultRootImport(exportName: string): string {\n return `import { ${exportName} } from 'erp-pro-ui';`;\n}\n\nfunction getDefaultSubpathImport(\n exportName: string,\n packageExportPath: string,\n): string {\n return `import { ${exportName} } from 'erp-pro-ui/${packageExportPath}';`;\n}\n\nexport const libraryPeerDependencies = [\n {\n name: \"framer-motion\",\n reason: \"Required by motion-heavy overlays and effects.\",\n },\n {\n name: \"three\",\n reason: \"Required for Three.js-based visual components.\",\n },\n {\n name: \"@react-three/fiber\",\n reason: \"React renderer used by 3D visual surfaces.\",\n },\n {\n name: \"@react-three/drei\",\n reason: \"Helper primitives used by 3D components.\",\n },\n {\n name: \"@tanstack/react-table\",\n reason: \"Required for DataTable filtering and column tooling.\",\n },\n {\n name: \"recharts\",\n reason: \"Required for chart components.\",\n },\n {\n name: \"lucide-react\",\n reason: \"Used by selected UI controls and docs examples.\",\n },\n] as const satisfies readonly LibraryDocsPeerDependency[];\n\nexport const libraryInstallSteps = [\n {\n title: \"Install the package\",\n description:\n \"Add erp-pro-ui to your React application with your preferred package manager.\",\n examples: [\n {\n title: \"pnpm\",\n language: \"bash\",\n code: \"pnpm add erp-pro-ui\",\n },\n ],\n },\n {\n title: \"Install peer dependencies\",\n description:\n \"Install only the optional peer packages used by motion, tables, and 3D visuals you actually render.\",\n examples: [\n {\n title: \"Peers\",\n language: \"bash\",\n code: \"pnpm add framer-motion three @tanstack/react-table\",\n },\n ],\n },\n {\n title: \"Import the shared styles\",\n description:\n \"Import Tailwind first, then the library stylesheet once at the app entry to load tokens, fonts, foundations, and semantic utilities with no extra Tailwind config.\",\n examples: [\n {\n title: \"Root stylesheet\",\n language: \"css\",\n code: '@import \"tailwindcss\";\\n@import \"erp-pro-ui/styles.css\";',\n },\n ],\n },\n {\n title: \"Use colors and fonts directly\",\n description:\n \"Import tokens.css for raw CSS variables without Tailwind utilities, or colors.css when you want the Tailwind v4 utility bridge generated from the shared semantic tokens. Prefer semantic utilities and --ds-* tokens in new code; the legacy --color-* aliases remain for migration.\",\n examples: [\n {\n title: \"Raw token import\",\n language: \"css\",\n code: '@import \"erp-pro-ui/tokens.css\";',\n },\n {\n title: \"Tailwind bridge import\",\n language: \"css\",\n code: '@import \"tailwindcss\";\\n@import \"erp-pro-ui/colors.css\";\\n@import \"erp-pro-ui/fonts.css\";',\n },\n {\n title: \"Theme token usage\",\n language: \"tsx\",\n code: 'import { Button } from \"erp-pro-ui\";\\n\\n<section className=\"bg-surface text-fg border border-border rounded-2xl p-6\">\\n <Button label=\"Save\" primary />\\n</section>',\n },\n {\n title: \"Chart token usage\",\n language: \"tsx\",\n code: 'import { AreaChart, getChartColorVar } from \"erp-pro-ui\";\\n\\n<AreaChart\\n data={data}\\n categories={[\\n { key: \"revenue\", color: getChartColorVar(1) },\\n { key: \"cost\", color: \"chart-6\" },\\n { key: \"forecast\", color: \"var(--color-chart-10)\" },\\n ]}\\n/>',\n description:\n \"Chart components accept raw CSS colors, theme chart variables, or the built-in chart token helper. The shared token surface includes chart slots 1 through 15.\",\n },\n ],\n },\n {\n title: \"Wrap your app with ThemeProvider\",\n description:\n \"Use ThemeProvider at the root so shared brand and mode attributes are applied as data-brand and data-mode for the token system. The older data-theme attribute is still written for compatibility, but brand and mode are the primary contract.\",\n examples: [\n {\n title: \"Root provider\",\n language: \"tsx\",\n code: \"import { ThemeProvider } from 'erp-pro-ui';\\n\\ncreateRoot(rootElement).render(\\n <ThemeProvider>\\n <App />\\n </ThemeProvider>,\\n);\",\n },\n {\n title: \"Manual attributes\",\n language: \"tsx\",\n code: '<html data-brand=\"teal\" data-mode=\"dark\"></html>',\n },\n ],\n },\n {\n title: \"Choose an import strategy\",\n description:\n \"Use root imports for convenience or subpath imports for a more explicit public contract per component.\",\n examples: [\n {\n title: \"Root imports\",\n language: \"tsx\",\n code: \"import { Button, Dialog, Input } from 'erp-pro-ui';\",\n },\n {\n title: \"Subpath imports\",\n language: \"tsx\",\n code: \"import { Button } from 'erp-pro-ui/button';\\nimport { Dialog } from 'erp-pro-ui/dialog';\",\n },\n ],\n },\n] as const satisfies readonly LibraryDocsInstallStep[];\n\nexport const libraryQuickStartExamples = [\n {\n title: \"Basic screen scaffold\",\n language: \"tsx\",\n code: 'import { Button, Input, ThemeProvider, Typography } from \\'erp-pro-ui\\';\\n\\nexport function App() {\\n return (\\n <ThemeProvider>\\n <section className=\"space-y-4 p-6\">\\n <Typography variant=\"h2\" gradient=\"ocean\">\\n Welcome to ERP Pro\\n </Typography>\\n <Input label=\"Email\" placeholder=\"you@company.com\" />\\n <Button label=\"Get Started\" primary />\\n </section>\\n </ThemeProvider>\\n );\\n}',\n },\n {\n title: \"Dialog confirmation pattern\",\n language: \"tsx\",\n code: 'import { Dialog } from \\'erp-pro-ui\\';\\n\\n<Dialog\\n open={isOpen}\\n onOpenChange={setIsOpen}\\n title=\"Confirm delete\"\\n description=\"This action cannot be undone.\"\\n variant=\"destructive\"\\n preset=\"confirm\"\\n animation=\"scale\"\\n onConfirm={handleDelete}\\n/>;',\n },\n] as const satisfies readonly LibraryDocsCodeExample[];\n\nexport const componentDocs: readonly LibraryComponentDoc[] = uiCatalogItems.map(\n (item): LibraryComponentDoc => {\n const seed: ComponentDocSeed = componentDocSeeds[item.slug];\n const docsRoute = getUiCatalogDocsRoute(item.slug);\n const rootImport =\n seed.rootImport ??\n (seed.exportName\n ? getDefaultRootImport(seed.exportName)\n : `import * as ${item.name.replace(/\\s+/g, \"\")} from 'erp-pro-ui';`);\n const subpathImport =\n seed.subpathImport ??\n (seed.exportName\n ? getDefaultSubpathImport(seed.exportName, item.packageExportPath)\n : `import * as ${item.name.replace(/\\s+/g, \"\")} from 'erp-pro-ui/${item.packageExportPath}';`);\n\n return {\n name: item.name,\n slug: item.slug,\n status: \"status\" in item ? item.status : undefined,\n category: getComponentCategory(item.storybookTitle),\n summary: seed.summary,\n storybookTitle: item.storybookTitle,\n packageExportPath: item.packageExportPath,\n exportName: seed.exportName,\n aliases: seed.aliases ?? [],\n rootImport,\n subpathImport,\n docsRoute,\n docsUrl: `${DOCS_BASE_URL}${docsRoute}`,\n related: seed.related ?? [],\n };\n },\n);\n\nexport const libraryDocs = {\n packageName: \"erp-pro-ui\",\n docsBaseUrl: DOCS_BASE_URL,\n summary:\n \"Reusable React UI library for ERP and SaaS applications with tree-shakeable subpath exports, shared styles, and first-party docs metadata.\",\n features: [\n \"50+ reusable UI components for forms, data display, overlays, charts, and visual effects.\",\n \"Root and subpath imports so consumers can choose convenience or explicit package contracts.\",\n \"Shared Tailwind v4 stylesheet with packaged fonts, tokens, and theme foundations.\",\n \"Dedicated chart color slots and helpers so consuming apps can pick theme-backed series colors directly.\",\n \"Portable docs metadata that can be consumed by other apps, CLIs, and MCP servers.\",\n ],\n installSteps: libraryInstallSteps,\n peerDependencies: libraryPeerDependencies,\n quickStartExamples: libraryQuickStartExamples,\n components: componentDocs,\n} as const satisfies LibraryDocsBundle;\n\nexport function getComponentDocBySlug(\n slug: UiCatalogSlug,\n): LibraryComponentDoc | undefined {\n return componentDocs.find((component) => component.slug === slug);\n}\n\nexport function getComponentDocByName(\n name: string,\n): LibraryComponentDoc | undefined {\n const normalizedName = name.trim().toLowerCase();\n\n return componentDocs.find((component) => {\n if (component.name.toLowerCase() === normalizedName) {\n return true;\n }\n\n if (component.slug === normalizedName) {\n return true;\n }\n\n return component.aliases.some(\n (alias) => alias.toLowerCase() === normalizedName,\n );\n });\n}\n\nexport function searchComponentDocs(query: string): LibraryComponentDoc[] {\n const normalizedQuery = query.trim().toLowerCase();\n\n if (!normalizedQuery) {\n return [...componentDocs];\n }\n\n return componentDocs.filter((component) => {\n const haystack = [\n component.name,\n component.slug,\n component.category,\n component.summary,\n component.storybookTitle,\n ...component.aliases,\n ]\n .join(\" \")\n .toLowerCase();\n\n return haystack.includes(normalizedQuery);\n });\n}\n"],"mappings":"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CN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACF;AAED,IAAa,sBAAsB;CACjC;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU;GACR;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACN,aACE;IACH;GACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,EACD;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,EACD;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACF;AAED,IAAa,4BAA4B,CACvC;CACE,OAAO;CACP,UAAU;CACV,MAAM;CACP,EACD;CACE,OAAO;CACP,UAAU;CACV,MAAM;CACP,CACF;AAED,IAAa,gBAAgD,gBAAA,eAAe,KACzE,SAA8B;CAC7B,MAAM,OAAyB,kBAAkB,KAAK;CACtD,MAAM,YAAY,gBAAA,sBAAsB,KAAK,KAAK;CAClD,MAAM,aACJ,KAAK,eACJ,KAAK,aACF,qBAAqB,KAAK,WAAW,GACrC,eAAe,KAAK,KAAK,QAAQ,QAAQ,GAAG,CAAC;CACnD,MAAM,gBACJ,KAAK,kBACJ,KAAK,aACF,wBAAwB,KAAK,YAAY,KAAK,kBAAkB,GAChE,eAAe,KAAK,KAAK,QAAQ,QAAQ,GAAG,CAAC,oBAAoB,KAAK,kBAAkB;AAE9F,QAAO;EACL,MAAM,KAAK;EACX,MAAM,KAAK;EACX,QAAQ,YAAY,OAAO,KAAK,SAAS,KAAA;EACzC,UAAU,qBAAqB,KAAK,eAAe;EACnD,SAAS,KAAK;EACd,gBAAgB,KAAK;EACrB,mBAAmB,KAAK;EACxB,YAAY,KAAK;EACjB,SAAS,KAAK,WAAW,EAAE;EAC3B;EACA;EACA;EACA,SAAS,GAAG,gBAAgB;EAC5B,SAAS,KAAK,WAAW,EAAE;EAC5B;EAEJ;AAED,IAAa,cAAc;CACzB,aAAa;CACb,aAAa;CACb,SACE;CACF,UAAU;EACR;EACA;EACA;EACA;EACA;EACD;CACD,cAAc;CACd,kBAAkB;CAClB,oBAAoB;CACpB,YAAY;CACb;AAED,SAAgB,sBACd,MACiC;AACjC,QAAO,cAAc,MAAM,cAAc,UAAU,SAAS,KAAK;;AAGnE,SAAgB,sBACd,MACiC;CACjC,MAAM,iBAAiB,KAAK,MAAM,CAAC,aAAa;AAEhD,QAAO,cAAc,MAAM,cAAc;AACvC,MAAI,UAAU,KAAK,aAAa,KAAK,eACnC,QAAO;AAGT,MAAI,UAAU,SAAS,eACrB,QAAO;AAGT,SAAO,UAAU,QAAQ,MACtB,UAAU,MAAM,aAAa,KAAK,eACpC;GACD;;AAGJ,SAAgB,oBAAoB,OAAsC;CACxE,MAAM,kBAAkB,MAAM,MAAM,CAAC,aAAa;AAElD,KAAI,CAAC,gBACH,QAAO,CAAC,GAAG,cAAc;AAG3B,QAAO,cAAc,QAAQ,cAAc;AAYzC,SAXiB;GACf,UAAU;GACV,UAAU;GACV,UAAU;GACV,UAAU;GACV,UAAU;GACV,GAAG,UAAU;GACd,CACE,KAAK,IAAI,CACT,aAAa,CAEA,SAAS,gBAAgB;GACzC"}
1
+ {"version":3,"file":"docs.cjs","names":[],"sources":["../src/docs.ts"],"sourcesContent":["import {\n getUiCatalogDocsRoute,\n type UiCatalogSlug,\n type UiCatalogStatus,\n uiCatalogItems,\n} from \"./catalog\";\n\nexport type LibraryDocsCodeLanguage = \"bash\" | \"css\" | \"json\" | \"tsx\";\n\nexport interface LibraryDocsCodeExample {\n readonly title: string;\n readonly language: LibraryDocsCodeLanguage;\n readonly code: string;\n readonly description?: string;\n}\n\nexport interface LibraryDocsInstallStep {\n readonly title: string;\n readonly description: string;\n readonly examples?: readonly LibraryDocsCodeExample[];\n}\n\nexport interface LibraryDocsPeerDependency {\n readonly name: string;\n readonly reason: string;\n}\n\nexport interface LibraryComponentDoc {\n readonly name: string;\n readonly slug: UiCatalogSlug;\n readonly status?: UiCatalogStatus;\n readonly category: string;\n readonly summary: string;\n readonly storybookTitle: string;\n readonly packageExportPath: string;\n readonly exportName?: string;\n readonly aliases: readonly string[];\n readonly rootImport: string;\n readonly subpathImport: string;\n readonly docsRoute: string;\n readonly docsUrl: string;\n readonly related: readonly UiCatalogSlug[];\n}\n\nexport interface LibraryDocsBundle {\n readonly packageName: \"erp-pro-ui\";\n readonly docsBaseUrl: string;\n readonly summary: string;\n readonly features: readonly string[];\n readonly installSteps: readonly LibraryDocsInstallStep[];\n readonly peerDependencies: readonly LibraryDocsPeerDependency[];\n readonly quickStartExamples: readonly LibraryDocsCodeExample[];\n readonly components: readonly LibraryComponentDoc[];\n}\n\ninterface ComponentDocSeed {\n readonly exportName?: string;\n readonly summary: string;\n readonly aliases?: readonly string[];\n readonly related?: readonly UiCatalogSlug[];\n readonly rootImport?: string;\n readonly subpathImport?: string;\n}\n\nconst DOCS_BASE_URL = \"https://daniel-heydari-dev.github.io/erp-pro-ui\";\n\nconst componentDocSeeds = {\n combobox: {\n exportName: \"Combobox\",\n summary:\n \"Searchable single-select control for long option lists and command-style pickers.\",\n aliases: [\"autocomplete\", \"search select\"],\n related: [\"select\", \"multiselect-combobox\", \"input\"],\n },\n button: {\n exportName: \"Button\",\n summary:\n \"Primary action trigger with size variants, button attributes, and support for custom children.\",\n aliases: [\"cta\", \"action\"],\n related: [\"dialog\", \"form\", \"input\"],\n },\n input: {\n exportName: \"Input\",\n summary:\n \"Text field for forms with label, validation state, helper text, and icon support.\",\n aliases: [\"text field\", \"field\"],\n related: [\"label\", \"textarea\", \"form\"],\n },\n checkbox: {\n exportName: \"Checkbox\",\n summary:\n \"Binary selection control for filters, permissions, and multi-select form fields.\",\n aliases: [\"boolean\"],\n related: [\"radio\", \"switch\", \"form\"],\n },\n radio: {\n exportName: \"Radio\",\n summary:\n \"Single-choice selection control for mutually exclusive form options.\",\n aliases: [\"radio group\"],\n related: [\"checkbox\", \"select\", \"form\"],\n },\n switch: {\n exportName: \"Switch\",\n summary:\n \"Immediate on/off toggle suited to settings panels and preference screens.\",\n aliases: [\"toggle\"],\n related: [\"checkbox\", \"sun-to-moon-button\", \"form\"],\n },\n select: {\n exportName: \"Select\",\n summary: \"Compact dropdown input for short, fixed option sets.\",\n aliases: [\"dropdown\"],\n related: [\"combobox\", \"multiselect-combobox\", \"form\"],\n },\n textarea: {\n exportName: \"Textarea\",\n summary:\n \"Multi-line text input for descriptions, notes, and longer form responses.\",\n aliases: [\"multiline input\"],\n related: [\"input\", \"label\", \"form\"],\n },\n label: {\n exportName: \"Label\",\n summary:\n \"Accessible form label primitive for pairing readable text with inputs and controls.\",\n aliases: [\"field label\"],\n related: [\"input\", \"textarea\", \"form\"],\n },\n dialog: {\n exportName: \"Dialog\",\n summary:\n \"Modal overlay for confirmations, destructive flows, and custom embedded forms.\",\n aliases: [\"modal\"],\n related: [\"drawer\", \"button\", \"toast\"],\n },\n drawer: {\n exportName: \"Drawer\",\n summary:\n \"Slide-in panel for secondary workflows, detail panes, and mobile task flows.\",\n aliases: [\"sheet\", \"side panel\"],\n related: [\"dialog\", \"card\", \"tooltip\"],\n },\n alert: {\n exportName: \"Alert\",\n summary:\n \"Inline status banner with semantic variants for success, warning, info, and destructive states.\",\n aliases: [\"message banner\"],\n related: [\"toast\", \"loading\", \"skeleton\"],\n },\n toast: {\n exportName: \"ToastProvider\",\n summary:\n \"Transient notification system exposed through ToastProvider and useToast for async feedback.\",\n aliases: [\"notification\"],\n related: [\"alert\", \"dialog\", \"loading\"],\n rootImport: \"import { ToastProvider, useToast } from 'erp-pro-ui';\",\n subpathImport:\n \"import { ToastProvider, useToast } from 'erp-pro-ui/toast';\",\n },\n tooltip: {\n exportName: \"Tooltip\",\n summary:\n \"Hover and focus overlay for concise contextual help without leaving the current view.\",\n aliases: [\"hint\"],\n related: [\"hover-card\", \"dialog\", \"drawer\"],\n },\n accordion: {\n exportName: \"Accordion\",\n summary:\n \"Expandable content container for FAQs, settings groups, and disclosure-heavy interfaces.\",\n aliases: [\"collapse\"],\n related: [\"card\", \"stepper\", \"tooltip\"],\n },\n card: {\n exportName: \"Card\",\n summary:\n \"Surface container for grouping content, actions, and stats in dashboards and forms.\",\n aliases: [\"panel\"],\n related: [\"accordion\", \"spotlight-card\", \"data-table\"],\n },\n stepper: {\n exportName: \"Stepper\",\n summary:\n \"Visual progress indicator for guided workflows, checkouts, and multi-step forms.\",\n aliases: [\"wizard steps\"],\n related: [\"form\", \"chip\", \"loading\"],\n },\n chip: {\n exportName: \"Chip\",\n summary:\n \"Compact status and taxonomy token with visual variants for tags, states, and filters.\",\n aliases: [\"tag\", \"badge\"],\n related: [\"alert\", \"color-palette\", \"stepper\"],\n },\n \"progress-bar\": {\n exportName: \"ProgressBar\",\n summary:\n \"Linear progress indicator for completion ratios, quotas, and compact operational status rows.\",\n aliases: [\"progress\", \"meter\", \"completion bar\"],\n related: [\"chip\", \"loading\", \"stepper\"],\n },\n calendar: {\n exportName: \"Calendar\",\n summary:\n \"Calendar view for scheduling surfaces, date picking UIs, and embedded planners.\",\n aliases: [\"date calendar\"],\n related: [\"datepicker\", \"input\", \"form\"],\n },\n datepicker: {\n exportName: \"DatePicker\",\n summary:\n \"Calendar-backed date input for forms that need controlled value selection and display.\",\n aliases: [\"date picker\"],\n related: [\"calendar\", \"input\", \"form\"],\n },\n \"multiselect-combobox\": {\n exportName: \"MultiSelectCombobox\",\n summary:\n \"Searchable multi-value selector for filters, assignee pickers, and label assignment flows.\",\n aliases: [\"multi select\", \"token select\"],\n related: [\"combobox\", \"select\", \"chip\"],\n },\n \"hover-card\": {\n exportName: \"HoverCard\",\n summary:\n \"Rich hover preview surface for profile cards, metadata popovers, and secondary details.\",\n aliases: [\"preview card\"],\n related: [\"tooltip\", \"card\", \"dialog\"],\n },\n \"spotlight-card\": {\n exportName: \"SpotlightCard\",\n summary:\n \"Interactive card with a cursor-reactive spotlight effect for premium landing sections.\",\n aliases: [\"interactive card\"],\n related: [\"card\", \"hover-border-gradient\", \"background-gradient\"],\n },\n \"splash-cursor\": {\n exportName: \"SplashCursor\",\n summary:\n \"Pointer effect that adds an animated splash trail for immersive visual experiences.\",\n aliases: [\"cursor effect\"],\n related: [\"chroma-grid\", \"animated-content\", \"spotlight-card\"],\n },\n \"chroma-grid\": {\n exportName: \"ChromaGrid\",\n summary:\n \"Animated chromatic grid background for showcase sections, heroes, and immersive canvases.\",\n aliases: [\"grid effect\"],\n related: [\"background-gradient\", \"splash-cursor\", \"gradual-blur\"],\n },\n \"color-palette\": {\n exportName: \"ColorPalette\",\n summary:\n \"Palette viewer for design tokens, brand colors, and handoff documentation.\",\n aliases: [\"swatches\"],\n related: [\"chip\", \"typography\", \"icons\"],\n },\n \"gradual-blur\": {\n exportName: \"GradualBlur\",\n summary:\n \"Progressive blur reveal wrapper for staged entrances and atmospheric transitions.\",\n aliases: [\"blur reveal\"],\n related: [\"animated-content\", \"background-gradient\", \"chroma-grid\"],\n },\n \"animated-content\": {\n exportName: \"AnimatedContent\",\n summary:\n \"Scroll and reveal motion wrapper for staging content entrances without custom animation plumbing.\",\n aliases: [\"reveal animation\"],\n related: [\"gradual-blur\", \"spotlight-card\", \"splash-cursor\"],\n },\n \"background-gradient\": {\n exportName: \"BackgroundGradientAnimation\",\n summary:\n \"Animated multi-stop gradient backdrop for hero sections and premium product storytelling.\",\n aliases: [\"gradient background\"],\n related: [\"chroma-grid\", \"gradual-blur\", \"spotlight-card\"],\n },\n \"hover-border-gradient\": {\n exportName: \"HoverBorderGradient\",\n summary:\n \"Gradient-border wrapper that emphasizes cards and feature callouts on hover.\",\n aliases: [\"gradient border\"],\n related: [\"button-hover-border-gradient\", \"card\", \"spotlight-card\"],\n },\n \"button-hover-border-gradient\": {\n exportName: \"ButtonHoverBorderGradient\",\n summary:\n \"CTA button variant with animated gradient edge treatment for high-emphasis surfaces.\",\n aliases: [\"gradient button\"],\n related: [\"button\", \"hover-border-gradient\", \"background-gradient\"],\n },\n \"password-strength-meter\": {\n exportName: \"PasswordStrengthMeter\",\n summary:\n \"Password quality indicator for sign-up and reset forms that need immediate feedback.\",\n aliases: [\"password meter\"],\n related: [\"input\", \"form\", \"alert\"],\n },\n \"sun-to-moon-button\": {\n exportName: \"SunToMoonButton\",\n summary:\n \"Animated theme toggle control for switching between light and dark presentation modes.\",\n aliases: [\"theme toggle\"],\n related: [\"switch\", \"typography\", \"background-gradient\"],\n },\n carousel: {\n exportName: \"Carousel\",\n summary:\n \"Content slider for galleries, testimonials, walkthroughs, and promotional sequences.\",\n aliases: [\"slider\"],\n related: [\"card\", \"animated-content\", \"spotlight-card\"],\n },\n otpinput: {\n exportName: \"OTPInput\",\n summary:\n \"One-time passcode input optimized for verification flows, MFA, and access codes.\",\n aliases: [\"otp\", \"verification code\"],\n related: [\"input\", \"password-strength-meter\", \"form\"],\n },\n form: {\n exportName: \"Form\",\n summary:\n \"Form composition surface for validation-driven layouts and grouped input sections.\",\n aliases: [\"form wrapper\"],\n related: [\"input\", \"button\", \"stepper\"],\n },\n \"data-table\": {\n exportName: \"DataTable\",\n summary:\n \"Feature-rich data grid with sorting, filtering, column toggles, and filter profiles.\",\n aliases: [\"table\", \"grid\"],\n related: [\"loading\", \"skeleton\", \"chip\"],\n },\n loading: {\n exportName: \"Loading\",\n summary:\n \"Unified loading surface exposing spinner, dots, pulse, bars, ring, bounce, wave, and skeleton variants.\",\n aliases: [\"loader\", \"progress indicator\"],\n related: [\"skeleton\", \"alert\", \"data-table\"],\n },\n skeleton: {\n exportName: \"SkeletonComponent\",\n summary:\n \"Theme-aware placeholder system with semantic tones, speed control, light/dark mode support, and ready-made metric, card, list, and table presets.\",\n aliases: [\"placeholder\"],\n related: [\"loading\", \"data-table\", \"card\"],\n rootImport: \"import { SkeletonComponent } from 'erp-pro-ui';\",\n subpathImport:\n \"import { Skeleton as SkeletonComponent, SkeletonMetricCard } from 'erp-pro-ui/skeleton';\",\n },\n \"area-chart\": {\n exportName: \"AreaChart\",\n summary:\n \"Gradient-filled area chart for trend storytelling and cumulative time-series views.\",\n aliases: [\"trend chart\"],\n related: [\"bar-chart\", \"neon-line-chart\", \"stacked-bar-chart\"],\n },\n \"bar-chart\": {\n exportName: \"BarChart\",\n summary:\n \"Bar chart for comparisons across categories, teams, or time buckets.\",\n aliases: [\"column chart\"],\n related: [\"area-chart\", \"stacked-bar-chart\", \"thin-breakdown-bar\"],\n },\n \"positive-negative-bar-chart\": {\n exportName: \"PositiveNegativeBarChart\",\n summary:\n \"Signed bar chart for profit-loss swings, variance reporting, and delta views that pivot around zero.\",\n aliases: [\"variance chart\", \"profit loss chart\"],\n related: [\"bar-chart\", \"stacked-bar-chart\", \"area-chart\"],\n },\n \"pie-chart\": {\n exportName: \"PieChart\",\n summary:\n \"Pie and donut chart visualizations for part-to-whole comparisons with small category sets.\",\n aliases: [\"donut chart\"],\n related: [\"bar-chart\", \"thin-breakdown-bar\", \"color-palette\"],\n },\n \"neon-line-chart\": {\n exportName: \"NeonLineChart\",\n summary:\n \"High-emphasis glowing line chart for dashboards that need a more stylized analytical treatment.\",\n aliases: [\"line chart\"],\n related: [\"area-chart\", \"bar-chart\", \"stacked-bar-chart\"],\n },\n \"stacked-bar-chart\": {\n exportName: \"StackedBarChart\",\n summary:\n \"Stacked categorical chart for comparing totals and composition inside each bar.\",\n aliases: [\"stacked chart\"],\n related: [\"bar-chart\", \"thin-breakdown-bar\", \"area-chart\"],\n },\n \"thin-breakdown-bar\": {\n exportName: \"ThinBreakdownBar\",\n summary:\n \"Compact horizontal breakdown bar for inline composition summaries and KPI cards.\",\n aliases: [\"breakdown bar\"],\n related: [\"stacked-bar-chart\", \"pie-chart\", \"chip\"],\n },\n icons: {\n summary:\n \"Collection of custom SVG icons for dashboards, navigation, commerce, and status-heavy product UIs.\",\n aliases: [\"icon pack\", \"svg icons\"],\n related: [\"typography\", \"color-palette\", \"button\"],\n rootImport:\n \"import { IconDashboard, IconSettings, IconUser } from 'erp-pro-ui';\",\n subpathImport:\n \"import { IconDashboard, IconSettings, IconUser } from 'erp-pro-ui/icons';\",\n },\n typography: {\n exportName: \"Typography\",\n summary:\n \"Semantic text component with heading, body, caption, alignment, weight, and gradient options.\",\n aliases: [\"text\"],\n related: [\"color-palette\", \"icons\", \"button\"],\n },\n} as const satisfies Record<UiCatalogSlug, ComponentDocSeed>;\n\nfunction getComponentCategory(storybookTitle: string): string {\n return storybookTitle.split(\"/\")[0] ?? \"Components\";\n}\n\nfunction getDefaultRootImport(exportName: string): string {\n return `import { ${exportName} } from 'erp-pro-ui';`;\n}\n\nfunction getDefaultSubpathImport(\n exportName: string,\n packageExportPath: string,\n): string {\n return `import { ${exportName} } from 'erp-pro-ui/${packageExportPath}';`;\n}\n\nexport const libraryPeerDependencies = [\n {\n name: \"framer-motion\",\n reason: \"Required by motion-heavy overlays and effects.\",\n },\n {\n name: \"three\",\n reason: \"Required for Three.js-based visual components.\",\n },\n {\n name: \"@react-three/fiber\",\n reason: \"React renderer used by 3D visual surfaces.\",\n },\n {\n name: \"@react-three/drei\",\n reason: \"Helper primitives used by 3D components.\",\n },\n {\n name: \"@tanstack/react-table\",\n reason: \"Required for DataTable filtering and column tooling.\",\n },\n {\n name: \"recharts\",\n reason: \"Required for chart components.\",\n },\n {\n name: \"lucide-react\",\n reason: \"Used by selected UI controls and docs examples.\",\n },\n] as const satisfies readonly LibraryDocsPeerDependency[];\n\nexport const libraryInstallSteps = [\n {\n title: \"Install the package\",\n description:\n \"Add erp-pro-ui to your React application with your preferred package manager.\",\n examples: [\n {\n title: \"pnpm\",\n language: \"bash\",\n code: \"pnpm add erp-pro-ui\",\n },\n ],\n },\n {\n title: \"Install peer dependencies\",\n description:\n \"Install only the optional peer packages used by motion, tables, and 3D visuals you actually render.\",\n examples: [\n {\n title: \"Peers\",\n language: \"bash\",\n code: \"pnpm add framer-motion three @tanstack/react-table\",\n },\n ],\n },\n {\n title: \"Import the shared styles\",\n description:\n \"Import Tailwind first, then the library stylesheet once at the app entry to load tokens, fonts, foundations, and semantic utilities with no extra Tailwind config.\",\n examples: [\n {\n title: \"Root stylesheet\",\n language: \"css\",\n code: '@import \"tailwindcss\";\\n@import \"erp-pro-ui/styles.css\";',\n },\n ],\n },\n {\n title: \"Use colors and fonts directly\",\n description:\n \"Import tokens.css for raw CSS variables without Tailwind utilities, or colors.css when you want the Tailwind v4 utility bridge generated from the shared semantic tokens. Prefer semantic utilities and --ds-* tokens in new code; the legacy --color-* aliases remain for migration.\",\n examples: [\n {\n title: \"Raw token import\",\n language: \"css\",\n code: '@import \"erp-pro-ui/tokens.css\";',\n },\n {\n title: \"Tailwind bridge import\",\n language: \"css\",\n code: '@import \"tailwindcss\";\\n@import \"erp-pro-ui/colors.css\";\\n@import \"erp-pro-ui/fonts.css\";',\n },\n {\n title: \"Theme token usage\",\n language: \"tsx\",\n code: 'import { Button } from \"erp-pro-ui\";\\n\\n<section className=\"bg-surface text-fg border border-border rounded-2xl p-6\">\\n <Button label=\"Save\" primary />\\n</section>',\n },\n {\n title: \"Chart token usage\",\n language: \"tsx\",\n code: 'import { AreaChart, getChartColorVar } from \"erp-pro-ui\";\\n\\n<AreaChart\\n data={data}\\n categories={[\\n { key: \"revenue\", color: getChartColorVar(1) },\\n { key: \"cost\", color: \"chart-6\" },\\n { key: \"forecast\", color: \"var(--color-chart-10)\" },\\n ]}\\n/>',\n description:\n \"Chart components accept raw CSS colors, theme chart variables, or the built-in chart token helper. The shared token surface includes chart slots 1 through 15.\",\n },\n ],\n },\n {\n title: \"Wrap your app with ThemeProvider\",\n description:\n \"Use ThemeProvider at the root so shared brand and mode attributes are applied as data-brand and data-mode for the token system. The older data-theme attribute is still written for compatibility, but brand and mode are the primary contract.\",\n examples: [\n {\n title: \"Root provider\",\n language: \"tsx\",\n code: \"import { ThemeProvider } from 'erp-pro-ui';\\n\\ncreateRoot(rootElement).render(\\n <ThemeProvider>\\n <App />\\n </ThemeProvider>,\\n);\",\n },\n {\n title: \"Manual attributes\",\n language: \"tsx\",\n code: '<html data-brand=\"teal\" data-mode=\"dark\"></html>',\n },\n ],\n },\n {\n title: \"Choose an import strategy\",\n description:\n \"Use root imports for convenience or subpath imports for a more explicit public contract per component.\",\n examples: [\n {\n title: \"Root imports\",\n language: \"tsx\",\n code: \"import { Button, Dialog, Input } from 'erp-pro-ui';\",\n },\n {\n title: \"Subpath imports\",\n language: \"tsx\",\n code: \"import { Button } from 'erp-pro-ui/button';\\nimport { Dialog } from 'erp-pro-ui/dialog';\",\n },\n ],\n },\n] as const satisfies readonly LibraryDocsInstallStep[];\n\nexport const libraryQuickStartExamples = [\n {\n title: \"Basic screen scaffold\",\n language: \"tsx\",\n code: 'import { Button, Input, ThemeProvider, Typography } from \\'erp-pro-ui\\';\\n\\nexport function App() {\\n return (\\n <ThemeProvider>\\n <section className=\"space-y-4 p-6\">\\n <Typography variant=\"h2\" gradient=\"ocean\">\\n Welcome to ERP Pro\\n </Typography>\\n <Input label=\"Email\" placeholder=\"you@company.com\" />\\n <Button label=\"Get Started\" primary />\\n </section>\\n </ThemeProvider>\\n );\\n}',\n },\n {\n title: \"Dialog confirmation pattern\",\n language: \"tsx\",\n code: 'import { Dialog } from \\'erp-pro-ui\\';\\n\\n<Dialog\\n open={isOpen}\\n onOpenChange={setIsOpen}\\n title=\"Confirm delete\"\\n description=\"This action cannot be undone.\"\\n variant=\"destructive\"\\n preset=\"confirm\"\\n animation=\"scale\"\\n onConfirm={handleDelete}\\n/>;',\n },\n] as const satisfies readonly LibraryDocsCodeExample[];\n\nexport const componentDocs: readonly LibraryComponentDoc[] = uiCatalogItems.map(\n (item): LibraryComponentDoc => {\n const seed: ComponentDocSeed = componentDocSeeds[item.slug];\n const docsRoute = getUiCatalogDocsRoute(item.slug);\n const rootImport =\n seed.rootImport ??\n (seed.exportName\n ? getDefaultRootImport(seed.exportName)\n : `import * as ${item.name.replace(/\\s+/g, \"\")} from 'erp-pro-ui';`);\n const subpathImport =\n seed.subpathImport ??\n (seed.exportName\n ? getDefaultSubpathImport(seed.exportName, item.packageExportPath)\n : `import * as ${item.name.replace(/\\s+/g, \"\")} from 'erp-pro-ui/${item.packageExportPath}';`);\n\n return {\n name: item.name,\n slug: item.slug,\n status: \"status\" in item ? item.status : undefined,\n category: getComponentCategory(item.storybookTitle),\n summary: seed.summary,\n storybookTitle: item.storybookTitle,\n packageExportPath: item.packageExportPath,\n exportName: seed.exportName,\n aliases: seed.aliases ?? [],\n rootImport,\n subpathImport,\n docsRoute,\n docsUrl: `${DOCS_BASE_URL}${docsRoute}`,\n related: seed.related ?? [],\n };\n },\n);\n\nexport const libraryDocs = {\n packageName: \"erp-pro-ui\",\n docsBaseUrl: DOCS_BASE_URL,\n summary:\n \"Reusable React UI library for ERP and SaaS applications with tree-shakeable subpath exports, shared styles, and first-party docs metadata.\",\n features: [\n \"50+ reusable UI components for forms, data display, overlays, charts, and visual effects.\",\n \"Root and subpath imports so consumers can choose convenience or explicit package contracts.\",\n \"Shared Tailwind v4 stylesheet with packaged fonts, tokens, and theme foundations.\",\n \"Dedicated chart color slots and helpers so consuming apps can pick theme-backed series colors directly.\",\n \"Portable docs metadata that can be consumed by other apps, CLIs, and MCP servers.\",\n ],\n installSteps: libraryInstallSteps,\n peerDependencies: libraryPeerDependencies,\n quickStartExamples: libraryQuickStartExamples,\n components: componentDocs,\n} as const satisfies LibraryDocsBundle;\n\nexport function getComponentDocBySlug(\n slug: UiCatalogSlug,\n): LibraryComponentDoc | undefined {\n return componentDocs.find((component) => component.slug === slug);\n}\n\nexport function getComponentDocByName(\n name: string,\n): LibraryComponentDoc | undefined {\n const normalizedName = name.trim().toLowerCase();\n\n return componentDocs.find((component) => {\n if (component.name.toLowerCase() === normalizedName) {\n return true;\n }\n\n if (component.slug === normalizedName) {\n return true;\n }\n\n return component.aliases.some(\n (alias) => alias.toLowerCase() === normalizedName,\n );\n });\n}\n\nexport function searchComponentDocs(query: string): LibraryComponentDoc[] {\n const normalizedQuery = query.trim().toLowerCase();\n\n if (!normalizedQuery) {\n return [...componentDocs];\n }\n\n return componentDocs.filter((component) => {\n const haystack = [\n component.name,\n component.slug,\n component.category,\n component.summary,\n component.storybookTitle,\n ...component.aliases,\n ]\n .join(\" \")\n .toLowerCase();\n\n return haystack.includes(normalizedQuery);\n });\n}\n"],"mappings":"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CE,MAAM;EACN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACF;AAED,IAAa,sBAAsB;CACjC;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU;GACR;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACN,aACE;IACH;GACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,EACD;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,EACD;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACF;AAED,IAAa,4BAA4B,CACvC;CACE,OAAO;CACP,UAAU;CACV,MAAM;CACP,EACD;CACE,OAAO;CACP,UAAU;CACV,MAAM;CACP,CACF;AAED,IAAa,gBAAgD,gBAAA,eAAe,KACzE,SAA8B;CAC7B,MAAM,OAAyB,kBAAkB,KAAK;CACtD,MAAM,YAAY,gBAAA,sBAAsB,KAAK,KAAK;CAClD,MAAM,aACJ,KAAK,eACJ,KAAK,aACF,qBAAqB,KAAK,WAAW,GACrC,eAAe,KAAK,KAAK,QAAQ,QAAQ,GAAG,CAAC;CACnD,MAAM,gBACJ,KAAK,kBACJ,KAAK,aACF,wBAAwB,KAAK,YAAY,KAAK,kBAAkB,GAChE,eAAe,KAAK,KAAK,QAAQ,QAAQ,GAAG,CAAC,oBAAoB,KAAK,kBAAkB;AAE9F,QAAO;EACL,MAAM,KAAK;EACX,MAAM,KAAK;EACX,QAAQ,YAAY,OAAO,KAAK,SAAS,KAAA;EACzC,UAAU,qBAAqB,KAAK,eAAe;EACnD,SAAS,KAAK;EACd,gBAAgB,KAAK;EACrB,mBAAmB,KAAK;EACxB,YAAY,KAAK;EACjB,SAAS,KAAK,WAAW,EAAE;EAC3B;EACA;EACA;EACA,SAAS,GAAG,gBAAgB;EAC5B,SAAS,KAAK,WAAW,EAAE;EAC5B;EAEJ;AAED,IAAa,cAAc;CACzB,aAAa;CACb,aAAa;CACb,SACE;CACF,UAAU;EACR;EACA;EACA;EACA;EACA;EACD;CACD,cAAc;CACd,kBAAkB;CAClB,oBAAoB;CACpB,YAAY;CACb;AAED,SAAgB,sBACd,MACiC;AACjC,QAAO,cAAc,MAAM,cAAc,UAAU,SAAS,KAAK;;AAGnE,SAAgB,sBACd,MACiC;CACjC,MAAM,iBAAiB,KAAK,MAAM,CAAC,aAAa;AAEhD,QAAO,cAAc,MAAM,cAAc;AACvC,MAAI,UAAU,KAAK,aAAa,KAAK,eACnC,QAAO;AAGT,MAAI,UAAU,SAAS,eACrB,QAAO;AAGT,SAAO,UAAU,QAAQ,MACtB,UAAU,MAAM,aAAa,KAAK,eACpC;GACD;;AAGJ,SAAgB,oBAAoB,OAAsC;CACxE,MAAM,kBAAkB,MAAM,MAAM,CAAC,aAAa;AAElD,KAAI,CAAC,gBACH,QAAO,CAAC,GAAG,cAAc;AAG3B,QAAO,cAAc,QAAQ,cAAc;AAYzC,SAXiB;GACf,UAAU;GACV,UAAU;GACV,UAAU;GACV,UAAU;GACV,UAAU;GACV,GAAG,UAAU;GACd,CACE,KAAK,IAAI,CACT,aAAa,CAEA,SAAS,gBAAgB;GACzC"}
@@ -1 +1 @@
1
- {"version":3,"file":"docs.d.ts","sourceRoot":"","sources":["../src/docs.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"docs.d.ts","sourceRoot":"","sources":["../src/docs.ts"],"names":[],"mappings":"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"}
package/dist/docs.mjs CHANGED
@@ -400,7 +400,7 @@ var componentDocSeeds = {
400
400
  },
401
401
  skeleton: {
402
402
  exportName: "SkeletonComponent",
403
- summary: "Placeholder block for perceived-performance states while structured content is loading.",
403
+ summary: "Theme-aware placeholder system with semantic tones, speed control, light/dark mode support, and ready-made metric, card, list, and table presets.",
404
404
  aliases: ["placeholder"],
405
405
  related: [
406
406
  "loading",
@@ -408,7 +408,7 @@ var componentDocSeeds = {
408
408
  "card"
409
409
  ],
410
410
  rootImport: "import { SkeletonComponent } from 'erp-pro-ui';",
411
- subpathImport: "import { Skeleton as SkeletonComponent } from 'erp-pro-ui/skeleton';"
411
+ subpathImport: "import { Skeleton as SkeletonComponent, SkeletonMetricCard } from 'erp-pro-ui/skeleton';"
412
412
  },
413
413
  "area-chart": {
414
414
  exportName: "AreaChart",
@@ -430,6 +430,16 @@ var componentDocSeeds = {
430
430
  "thin-breakdown-bar"
431
431
  ]
432
432
  },
433
+ "positive-negative-bar-chart": {
434
+ exportName: "PositiveNegativeBarChart",
435
+ summary: "Signed bar chart for profit-loss swings, variance reporting, and delta views that pivot around zero.",
436
+ aliases: ["variance chart", "profit loss chart"],
437
+ related: [
438
+ "bar-chart",
439
+ "stacked-bar-chart",
440
+ "area-chart"
441
+ ]
442
+ },
433
443
  "pie-chart": {
434
444
  exportName: "PieChart",
435
445
  summary: "Pie and donut chart visualizations for part-to-whole comparisons with small category sets.",
package/dist/docs.mjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"docs.mjs","names":[],"sources":["../src/docs.ts"],"sourcesContent":["import {\n getUiCatalogDocsRoute,\n type UiCatalogSlug,\n type UiCatalogStatus,\n uiCatalogItems,\n} from \"./catalog\";\n\nexport type LibraryDocsCodeLanguage = \"bash\" | \"css\" | \"json\" | \"tsx\";\n\nexport interface LibraryDocsCodeExample {\n readonly title: string;\n readonly language: LibraryDocsCodeLanguage;\n readonly code: string;\n readonly description?: string;\n}\n\nexport interface LibraryDocsInstallStep {\n readonly title: string;\n readonly description: string;\n readonly examples?: readonly LibraryDocsCodeExample[];\n}\n\nexport interface LibraryDocsPeerDependency {\n readonly name: string;\n readonly reason: string;\n}\n\nexport interface LibraryComponentDoc {\n readonly name: string;\n readonly slug: UiCatalogSlug;\n readonly status?: UiCatalogStatus;\n readonly category: string;\n readonly summary: string;\n readonly storybookTitle: string;\n readonly packageExportPath: string;\n readonly exportName?: string;\n readonly aliases: readonly string[];\n readonly rootImport: string;\n readonly subpathImport: string;\n readonly docsRoute: string;\n readonly docsUrl: string;\n readonly related: readonly UiCatalogSlug[];\n}\n\nexport interface LibraryDocsBundle {\n readonly packageName: \"erp-pro-ui\";\n readonly docsBaseUrl: string;\n readonly summary: string;\n readonly features: readonly string[];\n readonly installSteps: readonly LibraryDocsInstallStep[];\n readonly peerDependencies: readonly LibraryDocsPeerDependency[];\n readonly quickStartExamples: readonly LibraryDocsCodeExample[];\n readonly components: readonly LibraryComponentDoc[];\n}\n\ninterface ComponentDocSeed {\n readonly exportName?: string;\n readonly summary: string;\n readonly aliases?: readonly string[];\n readonly related?: readonly UiCatalogSlug[];\n readonly rootImport?: string;\n readonly subpathImport?: string;\n}\n\nconst DOCS_BASE_URL = \"https://daniel-heydari-dev.github.io/erp-pro-ui\";\n\nconst componentDocSeeds = {\n combobox: {\n exportName: \"Combobox\",\n summary:\n \"Searchable single-select control for long option lists and command-style pickers.\",\n aliases: [\"autocomplete\", \"search select\"],\n related: [\"select\", \"multiselect-combobox\", \"input\"],\n },\n button: {\n exportName: \"Button\",\n summary:\n \"Primary action trigger with size variants, button attributes, and support for custom children.\",\n aliases: [\"cta\", \"action\"],\n related: [\"dialog\", \"form\", \"input\"],\n },\n input: {\n exportName: \"Input\",\n summary:\n \"Text field for forms with label, validation state, helper text, and icon support.\",\n aliases: [\"text field\", \"field\"],\n related: [\"label\", \"textarea\", \"form\"],\n },\n checkbox: {\n exportName: \"Checkbox\",\n summary:\n \"Binary selection control for filters, permissions, and multi-select form fields.\",\n aliases: [\"boolean\"],\n related: [\"radio\", \"switch\", \"form\"],\n },\n radio: {\n exportName: \"Radio\",\n summary:\n \"Single-choice selection control for mutually exclusive form options.\",\n aliases: [\"radio group\"],\n related: [\"checkbox\", \"select\", \"form\"],\n },\n switch: {\n exportName: \"Switch\",\n summary:\n \"Immediate on/off toggle suited to settings panels and preference screens.\",\n aliases: [\"toggle\"],\n related: [\"checkbox\", \"sun-to-moon-button\", \"form\"],\n },\n select: {\n exportName: \"Select\",\n summary: \"Compact dropdown input for short, fixed option sets.\",\n aliases: [\"dropdown\"],\n related: [\"combobox\", \"multiselect-combobox\", \"form\"],\n },\n textarea: {\n exportName: \"Textarea\",\n summary:\n \"Multi-line text input for descriptions, notes, and longer form responses.\",\n aliases: [\"multiline input\"],\n related: [\"input\", \"label\", \"form\"],\n },\n label: {\n exportName: \"Label\",\n summary:\n \"Accessible form label primitive for pairing readable text with inputs and controls.\",\n aliases: [\"field label\"],\n related: [\"input\", \"textarea\", \"form\"],\n },\n dialog: {\n exportName: \"Dialog\",\n summary:\n \"Modal overlay for confirmations, destructive flows, and custom embedded forms.\",\n aliases: [\"modal\"],\n related: [\"drawer\", \"button\", \"toast\"],\n },\n drawer: {\n exportName: \"Drawer\",\n summary:\n \"Slide-in panel for secondary workflows, detail panes, and mobile task flows.\",\n aliases: [\"sheet\", \"side panel\"],\n related: [\"dialog\", \"card\", \"tooltip\"],\n },\n alert: {\n exportName: \"Alert\",\n summary:\n \"Inline status banner with semantic variants for success, warning, info, and destructive states.\",\n aliases: [\"message banner\"],\n related: [\"toast\", \"loading\", \"skeleton\"],\n },\n toast: {\n exportName: \"ToastProvider\",\n summary:\n \"Transient notification system exposed through ToastProvider and useToast for async feedback.\",\n aliases: [\"notification\"],\n related: [\"alert\", \"dialog\", \"loading\"],\n rootImport: \"import { ToastProvider, useToast } from 'erp-pro-ui';\",\n subpathImport:\n \"import { ToastProvider, useToast } from 'erp-pro-ui/toast';\",\n },\n tooltip: {\n exportName: \"Tooltip\",\n summary:\n \"Hover and focus overlay for concise contextual help without leaving the current view.\",\n aliases: [\"hint\"],\n related: [\"hover-card\", \"dialog\", \"drawer\"],\n },\n accordion: {\n exportName: \"Accordion\",\n summary:\n \"Expandable content container for FAQs, settings groups, and disclosure-heavy interfaces.\",\n aliases: [\"collapse\"],\n related: [\"card\", \"stepper\", \"tooltip\"],\n },\n card: {\n exportName: \"Card\",\n summary:\n \"Surface container for grouping content, actions, and stats in dashboards and forms.\",\n aliases: [\"panel\"],\n related: [\"accordion\", \"spotlight-card\", \"data-table\"],\n },\n stepper: {\n exportName: \"Stepper\",\n summary:\n \"Visual progress indicator for guided workflows, checkouts, and multi-step forms.\",\n aliases: [\"wizard steps\"],\n related: [\"form\", \"chip\", \"loading\"],\n },\n chip: {\n exportName: \"Chip\",\n summary:\n \"Compact status and taxonomy token with visual variants for tags, states, and filters.\",\n aliases: [\"tag\", \"badge\"],\n related: [\"alert\", \"color-palette\", \"stepper\"],\n },\n \"progress-bar\": {\n exportName: \"ProgressBar\",\n summary:\n \"Linear progress indicator for completion ratios, quotas, and compact operational status rows.\",\n aliases: [\"progress\", \"meter\", \"completion bar\"],\n related: [\"chip\", \"loading\", \"stepper\"],\n },\n calendar: {\n exportName: \"Calendar\",\n summary:\n \"Calendar view for scheduling surfaces, date picking UIs, and embedded planners.\",\n aliases: [\"date calendar\"],\n related: [\"datepicker\", \"input\", \"form\"],\n },\n datepicker: {\n exportName: \"DatePicker\",\n summary:\n \"Calendar-backed date input for forms that need controlled value selection and display.\",\n aliases: [\"date picker\"],\n related: [\"calendar\", \"input\", \"form\"],\n },\n \"multiselect-combobox\": {\n exportName: \"MultiSelectCombobox\",\n summary:\n \"Searchable multi-value selector for filters, assignee pickers, and label assignment flows.\",\n aliases: [\"multi select\", \"token select\"],\n related: [\"combobox\", \"select\", \"chip\"],\n },\n \"hover-card\": {\n exportName: \"HoverCard\",\n summary:\n \"Rich hover preview surface for profile cards, metadata popovers, and secondary details.\",\n aliases: [\"preview card\"],\n related: [\"tooltip\", \"card\", \"dialog\"],\n },\n \"spotlight-card\": {\n exportName: \"SpotlightCard\",\n summary:\n \"Interactive card with a cursor-reactive spotlight effect for premium landing sections.\",\n aliases: [\"interactive card\"],\n related: [\"card\", \"hover-border-gradient\", \"background-gradient\"],\n },\n \"splash-cursor\": {\n exportName: \"SplashCursor\",\n summary:\n \"Pointer effect that adds an animated splash trail for immersive visual experiences.\",\n aliases: [\"cursor effect\"],\n related: [\"chroma-grid\", \"animated-content\", \"spotlight-card\"],\n },\n \"chroma-grid\": {\n exportName: \"ChromaGrid\",\n summary:\n \"Animated chromatic grid background for showcase sections, heroes, and immersive canvases.\",\n aliases: [\"grid effect\"],\n related: [\"background-gradient\", \"splash-cursor\", \"gradual-blur\"],\n },\n \"color-palette\": {\n exportName: \"ColorPalette\",\n summary:\n \"Palette viewer for design tokens, brand colors, and handoff documentation.\",\n aliases: [\"swatches\"],\n related: [\"chip\", \"typography\", \"icons\"],\n },\n \"gradual-blur\": {\n exportName: \"GradualBlur\",\n summary:\n \"Progressive blur reveal wrapper for staged entrances and atmospheric transitions.\",\n aliases: [\"blur reveal\"],\n related: [\"animated-content\", \"background-gradient\", \"chroma-grid\"],\n },\n \"animated-content\": {\n exportName: \"AnimatedContent\",\n summary:\n \"Scroll and reveal motion wrapper for staging content entrances without custom animation plumbing.\",\n aliases: [\"reveal animation\"],\n related: [\"gradual-blur\", \"spotlight-card\", \"splash-cursor\"],\n },\n \"background-gradient\": {\n exportName: \"BackgroundGradientAnimation\",\n summary:\n \"Animated multi-stop gradient backdrop for hero sections and premium product storytelling.\",\n aliases: [\"gradient background\"],\n related: [\"chroma-grid\", \"gradual-blur\", \"spotlight-card\"],\n },\n \"hover-border-gradient\": {\n exportName: \"HoverBorderGradient\",\n summary:\n \"Gradient-border wrapper that emphasizes cards and feature callouts on hover.\",\n aliases: [\"gradient border\"],\n related: [\"button-hover-border-gradient\", \"card\", \"spotlight-card\"],\n },\n \"button-hover-border-gradient\": {\n exportName: \"ButtonHoverBorderGradient\",\n summary:\n \"CTA button variant with animated gradient edge treatment for high-emphasis surfaces.\",\n aliases: [\"gradient button\"],\n related: [\"button\", \"hover-border-gradient\", \"background-gradient\"],\n },\n \"password-strength-meter\": {\n exportName: \"PasswordStrengthMeter\",\n summary:\n \"Password quality indicator for sign-up and reset forms that need immediate feedback.\",\n aliases: [\"password meter\"],\n related: [\"input\", \"form\", \"alert\"],\n },\n \"sun-to-moon-button\": {\n exportName: \"SunToMoonButton\",\n summary:\n \"Animated theme toggle control for switching between light and dark presentation modes.\",\n aliases: [\"theme toggle\"],\n related: [\"switch\", \"typography\", \"background-gradient\"],\n },\n carousel: {\n exportName: \"Carousel\",\n summary:\n \"Content slider for galleries, testimonials, walkthroughs, and promotional sequences.\",\n aliases: [\"slider\"],\n related: [\"card\", \"animated-content\", \"spotlight-card\"],\n },\n otpinput: {\n exportName: \"OTPInput\",\n summary:\n \"One-time passcode input optimized for verification flows, MFA, and access codes.\",\n aliases: [\"otp\", \"verification code\"],\n related: [\"input\", \"password-strength-meter\", \"form\"],\n },\n form: {\n exportName: \"Form\",\n summary:\n \"Form composition surface for validation-driven layouts and grouped input sections.\",\n aliases: [\"form wrapper\"],\n related: [\"input\", \"button\", \"stepper\"],\n },\n \"data-table\": {\n exportName: \"DataTable\",\n summary:\n \"Feature-rich data grid with sorting, filtering, column toggles, and filter profiles.\",\n aliases: [\"table\", \"grid\"],\n related: [\"loading\", \"skeleton\", \"chip\"],\n },\n loading: {\n exportName: \"Loading\",\n summary:\n \"Unified loading surface exposing spinner, dots, pulse, bars, ring, bounce, wave, and skeleton variants.\",\n aliases: [\"loader\", \"progress indicator\"],\n related: [\"skeleton\", \"alert\", \"data-table\"],\n },\n skeleton: {\n exportName: \"SkeletonComponent\",\n summary:\n \"Placeholder block for perceived-performance states while structured content is loading.\",\n aliases: [\"placeholder\"],\n related: [\"loading\", \"data-table\", \"card\"],\n rootImport: \"import { SkeletonComponent } from 'erp-pro-ui';\",\n subpathImport:\n \"import { Skeleton as SkeletonComponent } from 'erp-pro-ui/skeleton';\",\n },\n \"area-chart\": {\n exportName: \"AreaChart\",\n summary:\n \"Gradient-filled area chart for trend storytelling and cumulative time-series views.\",\n aliases: [\"trend chart\"],\n related: [\"bar-chart\", \"neon-line-chart\", \"stacked-bar-chart\"],\n },\n \"bar-chart\": {\n exportName: \"BarChart\",\n summary:\n \"Bar chart for comparisons across categories, teams, or time buckets.\",\n aliases: [\"column chart\"],\n related: [\"area-chart\", \"stacked-bar-chart\", \"thin-breakdown-bar\"],\n },\n \"pie-chart\": {\n exportName: \"PieChart\",\n summary:\n \"Pie and donut chart visualizations for part-to-whole comparisons with small category sets.\",\n aliases: [\"donut chart\"],\n related: [\"bar-chart\", \"thin-breakdown-bar\", \"color-palette\"],\n },\n \"neon-line-chart\": {\n exportName: \"NeonLineChart\",\n summary:\n \"High-emphasis glowing line chart for dashboards that need a more stylized analytical treatment.\",\n aliases: [\"line chart\"],\n related: [\"area-chart\", \"bar-chart\", \"stacked-bar-chart\"],\n },\n \"stacked-bar-chart\": {\n exportName: \"StackedBarChart\",\n summary:\n \"Stacked categorical chart for comparing totals and composition inside each bar.\",\n aliases: [\"stacked chart\"],\n related: [\"bar-chart\", \"thin-breakdown-bar\", \"area-chart\"],\n },\n \"thin-breakdown-bar\": {\n exportName: \"ThinBreakdownBar\",\n summary:\n \"Compact horizontal breakdown bar for inline composition summaries and KPI cards.\",\n aliases: [\"breakdown bar\"],\n related: [\"stacked-bar-chart\", \"pie-chart\", \"chip\"],\n },\n icons: {\n summary:\n \"Collection of custom SVG icons for dashboards, navigation, commerce, and status-heavy product UIs.\",\n aliases: [\"icon pack\", \"svg icons\"],\n related: [\"typography\", \"color-palette\", \"button\"],\n rootImport:\n \"import { IconDashboard, IconSettings, IconUser } from 'erp-pro-ui';\",\n subpathImport:\n \"import { IconDashboard, IconSettings, IconUser } from 'erp-pro-ui/icons';\",\n },\n typography: {\n exportName: \"Typography\",\n summary:\n \"Semantic text component with heading, body, caption, alignment, weight, and gradient options.\",\n aliases: [\"text\"],\n related: [\"color-palette\", \"icons\", \"button\"],\n },\n} as const satisfies Record<UiCatalogSlug, ComponentDocSeed>;\n\nfunction getComponentCategory(storybookTitle: string): string {\n return storybookTitle.split(\"/\")[0] ?? \"Components\";\n}\n\nfunction getDefaultRootImport(exportName: string): string {\n return `import { ${exportName} } from 'erp-pro-ui';`;\n}\n\nfunction getDefaultSubpathImport(\n exportName: string,\n packageExportPath: string,\n): string {\n return `import { ${exportName} } from 'erp-pro-ui/${packageExportPath}';`;\n}\n\nexport const libraryPeerDependencies = [\n {\n name: \"framer-motion\",\n reason: \"Required by motion-heavy overlays and effects.\",\n },\n {\n name: \"three\",\n reason: \"Required for Three.js-based visual components.\",\n },\n {\n name: \"@react-three/fiber\",\n reason: \"React renderer used by 3D visual surfaces.\",\n },\n {\n name: \"@react-three/drei\",\n reason: \"Helper primitives used by 3D components.\",\n },\n {\n name: \"@tanstack/react-table\",\n reason: \"Required for DataTable filtering and column tooling.\",\n },\n {\n name: \"recharts\",\n reason: \"Required for chart components.\",\n },\n {\n name: \"lucide-react\",\n reason: \"Used by selected UI controls and docs examples.\",\n },\n] as const satisfies readonly LibraryDocsPeerDependency[];\n\nexport const libraryInstallSteps = [\n {\n title: \"Install the package\",\n description:\n \"Add erp-pro-ui to your React application with your preferred package manager.\",\n examples: [\n {\n title: \"pnpm\",\n language: \"bash\",\n code: \"pnpm add erp-pro-ui\",\n },\n ],\n },\n {\n title: \"Install peer dependencies\",\n description:\n \"Install only the optional peer packages used by motion, tables, and 3D visuals you actually render.\",\n examples: [\n {\n title: \"Peers\",\n language: \"bash\",\n code: \"pnpm add framer-motion three @tanstack/react-table\",\n },\n ],\n },\n {\n title: \"Import the shared styles\",\n description:\n \"Import Tailwind first, then the library stylesheet once at the app entry to load tokens, fonts, foundations, and semantic utilities with no extra Tailwind config.\",\n examples: [\n {\n title: \"Root stylesheet\",\n language: \"css\",\n code: '@import \"tailwindcss\";\\n@import \"erp-pro-ui/styles.css\";',\n },\n ],\n },\n {\n title: \"Use colors and fonts directly\",\n description:\n \"Import tokens.css for raw CSS variables without Tailwind utilities, or colors.css when you want the Tailwind v4 utility bridge generated from the shared semantic tokens. Prefer semantic utilities and --ds-* tokens in new code; the legacy --color-* aliases remain for migration.\",\n examples: [\n {\n title: \"Raw token import\",\n language: \"css\",\n code: '@import \"erp-pro-ui/tokens.css\";',\n },\n {\n title: \"Tailwind bridge import\",\n language: \"css\",\n code: '@import \"tailwindcss\";\\n@import \"erp-pro-ui/colors.css\";\\n@import \"erp-pro-ui/fonts.css\";',\n },\n {\n title: \"Theme token usage\",\n language: \"tsx\",\n code: 'import { Button } from \"erp-pro-ui\";\\n\\n<section className=\"bg-surface text-fg border border-border rounded-2xl p-6\">\\n <Button label=\"Save\" primary />\\n</section>',\n },\n {\n title: \"Chart token usage\",\n language: \"tsx\",\n code: 'import { AreaChart, getChartColorVar } from \"erp-pro-ui\";\\n\\n<AreaChart\\n data={data}\\n categories={[\\n { key: \"revenue\", color: getChartColorVar(1) },\\n { key: \"cost\", color: \"chart-6\" },\\n { key: \"forecast\", color: \"var(--color-chart-10)\" },\\n ]}\\n/>',\n description:\n \"Chart components accept raw CSS colors, theme chart variables, or the built-in chart token helper. The shared token surface includes chart slots 1 through 15.\",\n },\n ],\n },\n {\n title: \"Wrap your app with ThemeProvider\",\n description:\n \"Use ThemeProvider at the root so shared brand and mode attributes are applied as data-brand and data-mode for the token system. The older data-theme attribute is still written for compatibility, but brand and mode are the primary contract.\",\n examples: [\n {\n title: \"Root provider\",\n language: \"tsx\",\n code: \"import { ThemeProvider } from 'erp-pro-ui';\\n\\ncreateRoot(rootElement).render(\\n <ThemeProvider>\\n <App />\\n </ThemeProvider>,\\n);\",\n },\n {\n title: \"Manual attributes\",\n language: \"tsx\",\n code: '<html data-brand=\"teal\" data-mode=\"dark\"></html>',\n },\n ],\n },\n {\n title: \"Choose an import strategy\",\n description:\n \"Use root imports for convenience or subpath imports for a more explicit public contract per component.\",\n examples: [\n {\n title: \"Root imports\",\n language: \"tsx\",\n code: \"import { Button, Dialog, Input } from 'erp-pro-ui';\",\n },\n {\n title: \"Subpath imports\",\n language: \"tsx\",\n code: \"import { Button } from 'erp-pro-ui/button';\\nimport { Dialog } from 'erp-pro-ui/dialog';\",\n },\n ],\n },\n] as const satisfies readonly LibraryDocsInstallStep[];\n\nexport const libraryQuickStartExamples = [\n {\n title: \"Basic screen scaffold\",\n language: \"tsx\",\n code: 'import { Button, Input, ThemeProvider, Typography } from \\'erp-pro-ui\\';\\n\\nexport function App() {\\n return (\\n <ThemeProvider>\\n <section className=\"space-y-4 p-6\">\\n <Typography variant=\"h2\" gradient=\"ocean\">\\n Welcome to ERP Pro\\n </Typography>\\n <Input label=\"Email\" placeholder=\"you@company.com\" />\\n <Button label=\"Get Started\" primary />\\n </section>\\n </ThemeProvider>\\n );\\n}',\n },\n {\n title: \"Dialog confirmation pattern\",\n language: \"tsx\",\n code: 'import { Dialog } from \\'erp-pro-ui\\';\\n\\n<Dialog\\n open={isOpen}\\n onOpenChange={setIsOpen}\\n title=\"Confirm delete\"\\n description=\"This action cannot be undone.\"\\n variant=\"destructive\"\\n preset=\"confirm\"\\n animation=\"scale\"\\n onConfirm={handleDelete}\\n/>;',\n },\n] as const satisfies readonly LibraryDocsCodeExample[];\n\nexport const componentDocs: readonly LibraryComponentDoc[] = uiCatalogItems.map(\n (item): LibraryComponentDoc => {\n const seed: ComponentDocSeed = componentDocSeeds[item.slug];\n const docsRoute = getUiCatalogDocsRoute(item.slug);\n const rootImport =\n seed.rootImport ??\n (seed.exportName\n ? getDefaultRootImport(seed.exportName)\n : `import * as ${item.name.replace(/\\s+/g, \"\")} from 'erp-pro-ui';`);\n const subpathImport =\n seed.subpathImport ??\n (seed.exportName\n ? getDefaultSubpathImport(seed.exportName, item.packageExportPath)\n : `import * as ${item.name.replace(/\\s+/g, \"\")} from 'erp-pro-ui/${item.packageExportPath}';`);\n\n return {\n name: item.name,\n slug: item.slug,\n status: \"status\" in item ? item.status : undefined,\n category: getComponentCategory(item.storybookTitle),\n summary: seed.summary,\n storybookTitle: item.storybookTitle,\n packageExportPath: item.packageExportPath,\n exportName: seed.exportName,\n aliases: seed.aliases ?? [],\n rootImport,\n subpathImport,\n docsRoute,\n docsUrl: `${DOCS_BASE_URL}${docsRoute}`,\n related: seed.related ?? [],\n };\n },\n);\n\nexport const libraryDocs = {\n packageName: \"erp-pro-ui\",\n docsBaseUrl: DOCS_BASE_URL,\n summary:\n \"Reusable React UI library for ERP and SaaS applications with tree-shakeable subpath exports, shared styles, and first-party docs metadata.\",\n features: [\n \"50+ reusable UI components for forms, data display, overlays, charts, and visual effects.\",\n \"Root and subpath imports so consumers can choose convenience or explicit package contracts.\",\n \"Shared Tailwind v4 stylesheet with packaged fonts, tokens, and theme foundations.\",\n \"Dedicated chart color slots and helpers so consuming apps can pick theme-backed series colors directly.\",\n \"Portable docs metadata that can be consumed by other apps, CLIs, and MCP servers.\",\n ],\n installSteps: libraryInstallSteps,\n peerDependencies: libraryPeerDependencies,\n quickStartExamples: libraryQuickStartExamples,\n components: componentDocs,\n} as const satisfies LibraryDocsBundle;\n\nexport function getComponentDocBySlug(\n slug: UiCatalogSlug,\n): LibraryComponentDoc | undefined {\n return componentDocs.find((component) => component.slug === slug);\n}\n\nexport function getComponentDocByName(\n name: string,\n): LibraryComponentDoc | undefined {\n const normalizedName = name.trim().toLowerCase();\n\n return componentDocs.find((component) => {\n if (component.name.toLowerCase() === normalizedName) {\n return true;\n }\n\n if (component.slug === normalizedName) {\n return true;\n }\n\n return component.aliases.some(\n (alias) => alias.toLowerCase() === normalizedName,\n );\n });\n}\n\nexport function searchComponentDocs(query: string): LibraryComponentDoc[] {\n const normalizedQuery = query.trim().toLowerCase();\n\n if (!normalizedQuery) {\n return [...componentDocs];\n }\n\n return componentDocs.filter((component) => {\n const haystack = [\n component.name,\n component.slug,\n component.category,\n component.summary,\n component.storybookTitle,\n ...component.aliases,\n ]\n .join(\" \")\n .toLowerCase();\n\n return haystack.includes(normalizedQuery);\n });\n}\n"],"mappings":"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N,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACF;AAED,IAAa,sBAAsB;CACjC;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU;GACR;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACN,aACE;IACH;GACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,EACD;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,EACD;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACF;AAED,IAAa,4BAA4B,CACvC;CACE,OAAO;CACP,UAAU;CACV,MAAM;CACP,EACD;CACE,OAAO;CACP,UAAU;CACV,MAAM;CACP,CACF;AAED,IAAa,gBAAgD,eAAe,KACzE,SAA8B;CAC7B,MAAM,OAAyB,kBAAkB,KAAK;CACtD,MAAM,YAAY,sBAAsB,KAAK,KAAK;CAClD,MAAM,aACJ,KAAK,eACJ,KAAK,aACF,qBAAqB,KAAK,WAAW,GACrC,eAAe,KAAK,KAAK,QAAQ,QAAQ,GAAG,CAAC;CACnD,MAAM,gBACJ,KAAK,kBACJ,KAAK,aACF,wBAAwB,KAAK,YAAY,KAAK,kBAAkB,GAChE,eAAe,KAAK,KAAK,QAAQ,QAAQ,GAAG,CAAC,oBAAoB,KAAK,kBAAkB;AAE9F,QAAO;EACL,MAAM,KAAK;EACX,MAAM,KAAK;EACX,QAAQ,YAAY,OAAO,KAAK,SAAS,KAAA;EACzC,UAAU,qBAAqB,KAAK,eAAe;EACnD,SAAS,KAAK;EACd,gBAAgB,KAAK;EACrB,mBAAmB,KAAK;EACxB,YAAY,KAAK;EACjB,SAAS,KAAK,WAAW,EAAE;EAC3B;EACA;EACA;EACA,SAAS,GAAG,gBAAgB;EAC5B,SAAS,KAAK,WAAW,EAAE;EAC5B;EAEJ;AAED,IAAa,cAAc;CACzB,aAAa;CACb,aAAa;CACb,SACE;CACF,UAAU;EACR;EACA;EACA;EACA;EACA;EACD;CACD,cAAc;CACd,kBAAkB;CAClB,oBAAoB;CACpB,YAAY;CACb;AAED,SAAgB,sBACd,MACiC;AACjC,QAAO,cAAc,MAAM,cAAc,UAAU,SAAS,KAAK;;AAGnE,SAAgB,sBACd,MACiC;CACjC,MAAM,iBAAiB,KAAK,MAAM,CAAC,aAAa;AAEhD,QAAO,cAAc,MAAM,cAAc;AACvC,MAAI,UAAU,KAAK,aAAa,KAAK,eACnC,QAAO;AAGT,MAAI,UAAU,SAAS,eACrB,QAAO;AAGT,SAAO,UAAU,QAAQ,MACtB,UAAU,MAAM,aAAa,KAAK,eACpC;GACD;;AAGJ,SAAgB,oBAAoB,OAAsC;CACxE,MAAM,kBAAkB,MAAM,MAAM,CAAC,aAAa;AAElD,KAAI,CAAC,gBACH,QAAO,CAAC,GAAG,cAAc;AAG3B,QAAO,cAAc,QAAQ,cAAc;AAYzC,SAXiB;GACf,UAAU;GACV,UAAU;GACV,UAAU;GACV,UAAU;GACV,UAAU;GACV,GAAG,UAAU;GACd,CACE,KAAK,IAAI,CACT,aAAa,CAEA,SAAS,gBAAgB;GACzC"}
1
+ {"version":3,"file":"docs.mjs","names":[],"sources":["../src/docs.ts"],"sourcesContent":["import {\n getUiCatalogDocsRoute,\n type UiCatalogSlug,\n type UiCatalogStatus,\n uiCatalogItems,\n} from \"./catalog\";\n\nexport type LibraryDocsCodeLanguage = \"bash\" | \"css\" | \"json\" | \"tsx\";\n\nexport interface LibraryDocsCodeExample {\n readonly title: string;\n readonly language: LibraryDocsCodeLanguage;\n readonly code: string;\n readonly description?: string;\n}\n\nexport interface LibraryDocsInstallStep {\n readonly title: string;\n readonly description: string;\n readonly examples?: readonly LibraryDocsCodeExample[];\n}\n\nexport interface LibraryDocsPeerDependency {\n readonly name: string;\n readonly reason: string;\n}\n\nexport interface LibraryComponentDoc {\n readonly name: string;\n readonly slug: UiCatalogSlug;\n readonly status?: UiCatalogStatus;\n readonly category: string;\n readonly summary: string;\n readonly storybookTitle: string;\n readonly packageExportPath: string;\n readonly exportName?: string;\n readonly aliases: readonly string[];\n readonly rootImport: string;\n readonly subpathImport: string;\n readonly docsRoute: string;\n readonly docsUrl: string;\n readonly related: readonly UiCatalogSlug[];\n}\n\nexport interface LibraryDocsBundle {\n readonly packageName: \"erp-pro-ui\";\n readonly docsBaseUrl: string;\n readonly summary: string;\n readonly features: readonly string[];\n readonly installSteps: readonly LibraryDocsInstallStep[];\n readonly peerDependencies: readonly LibraryDocsPeerDependency[];\n readonly quickStartExamples: readonly LibraryDocsCodeExample[];\n readonly components: readonly LibraryComponentDoc[];\n}\n\ninterface ComponentDocSeed {\n readonly exportName?: string;\n readonly summary: string;\n readonly aliases?: readonly string[];\n readonly related?: readonly UiCatalogSlug[];\n readonly rootImport?: string;\n readonly subpathImport?: string;\n}\n\nconst DOCS_BASE_URL = \"https://daniel-heydari-dev.github.io/erp-pro-ui\";\n\nconst componentDocSeeds = {\n combobox: {\n exportName: \"Combobox\",\n summary:\n \"Searchable single-select control for long option lists and command-style pickers.\",\n aliases: [\"autocomplete\", \"search select\"],\n related: [\"select\", \"multiselect-combobox\", \"input\"],\n },\n button: {\n exportName: \"Button\",\n summary:\n \"Primary action trigger with size variants, button attributes, and support for custom children.\",\n aliases: [\"cta\", \"action\"],\n related: [\"dialog\", \"form\", \"input\"],\n },\n input: {\n exportName: \"Input\",\n summary:\n \"Text field for forms with label, validation state, helper text, and icon support.\",\n aliases: [\"text field\", \"field\"],\n related: [\"label\", \"textarea\", \"form\"],\n },\n checkbox: {\n exportName: \"Checkbox\",\n summary:\n \"Binary selection control for filters, permissions, and multi-select form fields.\",\n aliases: [\"boolean\"],\n related: [\"radio\", \"switch\", \"form\"],\n },\n radio: {\n exportName: \"Radio\",\n summary:\n \"Single-choice selection control for mutually exclusive form options.\",\n aliases: [\"radio group\"],\n related: [\"checkbox\", \"select\", \"form\"],\n },\n switch: {\n exportName: \"Switch\",\n summary:\n \"Immediate on/off toggle suited to settings panels and preference screens.\",\n aliases: [\"toggle\"],\n related: [\"checkbox\", \"sun-to-moon-button\", \"form\"],\n },\n select: {\n exportName: \"Select\",\n summary: \"Compact dropdown input for short, fixed option sets.\",\n aliases: [\"dropdown\"],\n related: [\"combobox\", \"multiselect-combobox\", \"form\"],\n },\n textarea: {\n exportName: \"Textarea\",\n summary:\n \"Multi-line text input for descriptions, notes, and longer form responses.\",\n aliases: [\"multiline input\"],\n related: [\"input\", \"label\", \"form\"],\n },\n label: {\n exportName: \"Label\",\n summary:\n \"Accessible form label primitive for pairing readable text with inputs and controls.\",\n aliases: [\"field label\"],\n related: [\"input\", \"textarea\", \"form\"],\n },\n dialog: {\n exportName: \"Dialog\",\n summary:\n \"Modal overlay for confirmations, destructive flows, and custom embedded forms.\",\n aliases: [\"modal\"],\n related: [\"drawer\", \"button\", \"toast\"],\n },\n drawer: {\n exportName: \"Drawer\",\n summary:\n \"Slide-in panel for secondary workflows, detail panes, and mobile task flows.\",\n aliases: [\"sheet\", \"side panel\"],\n related: [\"dialog\", \"card\", \"tooltip\"],\n },\n alert: {\n exportName: \"Alert\",\n summary:\n \"Inline status banner with semantic variants for success, warning, info, and destructive states.\",\n aliases: [\"message banner\"],\n related: [\"toast\", \"loading\", \"skeleton\"],\n },\n toast: {\n exportName: \"ToastProvider\",\n summary:\n \"Transient notification system exposed through ToastProvider and useToast for async feedback.\",\n aliases: [\"notification\"],\n related: [\"alert\", \"dialog\", \"loading\"],\n rootImport: \"import { ToastProvider, useToast } from 'erp-pro-ui';\",\n subpathImport:\n \"import { ToastProvider, useToast } from 'erp-pro-ui/toast';\",\n },\n tooltip: {\n exportName: \"Tooltip\",\n summary:\n \"Hover and focus overlay for concise contextual help without leaving the current view.\",\n aliases: [\"hint\"],\n related: [\"hover-card\", \"dialog\", \"drawer\"],\n },\n accordion: {\n exportName: \"Accordion\",\n summary:\n \"Expandable content container for FAQs, settings groups, and disclosure-heavy interfaces.\",\n aliases: [\"collapse\"],\n related: [\"card\", \"stepper\", \"tooltip\"],\n },\n card: {\n exportName: \"Card\",\n summary:\n \"Surface container for grouping content, actions, and stats in dashboards and forms.\",\n aliases: [\"panel\"],\n related: [\"accordion\", \"spotlight-card\", \"data-table\"],\n },\n stepper: {\n exportName: \"Stepper\",\n summary:\n \"Visual progress indicator for guided workflows, checkouts, and multi-step forms.\",\n aliases: [\"wizard steps\"],\n related: [\"form\", \"chip\", \"loading\"],\n },\n chip: {\n exportName: \"Chip\",\n summary:\n \"Compact status and taxonomy token with visual variants for tags, states, and filters.\",\n aliases: [\"tag\", \"badge\"],\n related: [\"alert\", \"color-palette\", \"stepper\"],\n },\n \"progress-bar\": {\n exportName: \"ProgressBar\",\n summary:\n \"Linear progress indicator for completion ratios, quotas, and compact operational status rows.\",\n aliases: [\"progress\", \"meter\", \"completion bar\"],\n related: [\"chip\", \"loading\", \"stepper\"],\n },\n calendar: {\n exportName: \"Calendar\",\n summary:\n \"Calendar view for scheduling surfaces, date picking UIs, and embedded planners.\",\n aliases: [\"date calendar\"],\n related: [\"datepicker\", \"input\", \"form\"],\n },\n datepicker: {\n exportName: \"DatePicker\",\n summary:\n \"Calendar-backed date input for forms that need controlled value selection and display.\",\n aliases: [\"date picker\"],\n related: [\"calendar\", \"input\", \"form\"],\n },\n \"multiselect-combobox\": {\n exportName: \"MultiSelectCombobox\",\n summary:\n \"Searchable multi-value selector for filters, assignee pickers, and label assignment flows.\",\n aliases: [\"multi select\", \"token select\"],\n related: [\"combobox\", \"select\", \"chip\"],\n },\n \"hover-card\": {\n exportName: \"HoverCard\",\n summary:\n \"Rich hover preview surface for profile cards, metadata popovers, and secondary details.\",\n aliases: [\"preview card\"],\n related: [\"tooltip\", \"card\", \"dialog\"],\n },\n \"spotlight-card\": {\n exportName: \"SpotlightCard\",\n summary:\n \"Interactive card with a cursor-reactive spotlight effect for premium landing sections.\",\n aliases: [\"interactive card\"],\n related: [\"card\", \"hover-border-gradient\", \"background-gradient\"],\n },\n \"splash-cursor\": {\n exportName: \"SplashCursor\",\n summary:\n \"Pointer effect that adds an animated splash trail for immersive visual experiences.\",\n aliases: [\"cursor effect\"],\n related: [\"chroma-grid\", \"animated-content\", \"spotlight-card\"],\n },\n \"chroma-grid\": {\n exportName: \"ChromaGrid\",\n summary:\n \"Animated chromatic grid background for showcase sections, heroes, and immersive canvases.\",\n aliases: [\"grid effect\"],\n related: [\"background-gradient\", \"splash-cursor\", \"gradual-blur\"],\n },\n \"color-palette\": {\n exportName: \"ColorPalette\",\n summary:\n \"Palette viewer for design tokens, brand colors, and handoff documentation.\",\n aliases: [\"swatches\"],\n related: [\"chip\", \"typography\", \"icons\"],\n },\n \"gradual-blur\": {\n exportName: \"GradualBlur\",\n summary:\n \"Progressive blur reveal wrapper for staged entrances and atmospheric transitions.\",\n aliases: [\"blur reveal\"],\n related: [\"animated-content\", \"background-gradient\", \"chroma-grid\"],\n },\n \"animated-content\": {\n exportName: \"AnimatedContent\",\n summary:\n \"Scroll and reveal motion wrapper for staging content entrances without custom animation plumbing.\",\n aliases: [\"reveal animation\"],\n related: [\"gradual-blur\", \"spotlight-card\", \"splash-cursor\"],\n },\n \"background-gradient\": {\n exportName: \"BackgroundGradientAnimation\",\n summary:\n \"Animated multi-stop gradient backdrop for hero sections and premium product storytelling.\",\n aliases: [\"gradient background\"],\n related: [\"chroma-grid\", \"gradual-blur\", \"spotlight-card\"],\n },\n \"hover-border-gradient\": {\n exportName: \"HoverBorderGradient\",\n summary:\n \"Gradient-border wrapper that emphasizes cards and feature callouts on hover.\",\n aliases: [\"gradient border\"],\n related: [\"button-hover-border-gradient\", \"card\", \"spotlight-card\"],\n },\n \"button-hover-border-gradient\": {\n exportName: \"ButtonHoverBorderGradient\",\n summary:\n \"CTA button variant with animated gradient edge treatment for high-emphasis surfaces.\",\n aliases: [\"gradient button\"],\n related: [\"button\", \"hover-border-gradient\", \"background-gradient\"],\n },\n \"password-strength-meter\": {\n exportName: \"PasswordStrengthMeter\",\n summary:\n \"Password quality indicator for sign-up and reset forms that need immediate feedback.\",\n aliases: [\"password meter\"],\n related: [\"input\", \"form\", \"alert\"],\n },\n \"sun-to-moon-button\": {\n exportName: \"SunToMoonButton\",\n summary:\n \"Animated theme toggle control for switching between light and dark presentation modes.\",\n aliases: [\"theme toggle\"],\n related: [\"switch\", \"typography\", \"background-gradient\"],\n },\n carousel: {\n exportName: \"Carousel\",\n summary:\n \"Content slider for galleries, testimonials, walkthroughs, and promotional sequences.\",\n aliases: [\"slider\"],\n related: [\"card\", \"animated-content\", \"spotlight-card\"],\n },\n otpinput: {\n exportName: \"OTPInput\",\n summary:\n \"One-time passcode input optimized for verification flows, MFA, and access codes.\",\n aliases: [\"otp\", \"verification code\"],\n related: [\"input\", \"password-strength-meter\", \"form\"],\n },\n form: {\n exportName: \"Form\",\n summary:\n \"Form composition surface for validation-driven layouts and grouped input sections.\",\n aliases: [\"form wrapper\"],\n related: [\"input\", \"button\", \"stepper\"],\n },\n \"data-table\": {\n exportName: \"DataTable\",\n summary:\n \"Feature-rich data grid with sorting, filtering, column toggles, and filter profiles.\",\n aliases: [\"table\", \"grid\"],\n related: [\"loading\", \"skeleton\", \"chip\"],\n },\n loading: {\n exportName: \"Loading\",\n summary:\n \"Unified loading surface exposing spinner, dots, pulse, bars, ring, bounce, wave, and skeleton variants.\",\n aliases: [\"loader\", \"progress indicator\"],\n related: [\"skeleton\", \"alert\", \"data-table\"],\n },\n skeleton: {\n exportName: \"SkeletonComponent\",\n summary:\n \"Theme-aware placeholder system with semantic tones, speed control, light/dark mode support, and ready-made metric, card, list, and table presets.\",\n aliases: [\"placeholder\"],\n related: [\"loading\", \"data-table\", \"card\"],\n rootImport: \"import { SkeletonComponent } from 'erp-pro-ui';\",\n subpathImport:\n \"import { Skeleton as SkeletonComponent, SkeletonMetricCard } from 'erp-pro-ui/skeleton';\",\n },\n \"area-chart\": {\n exportName: \"AreaChart\",\n summary:\n \"Gradient-filled area chart for trend storytelling and cumulative time-series views.\",\n aliases: [\"trend chart\"],\n related: [\"bar-chart\", \"neon-line-chart\", \"stacked-bar-chart\"],\n },\n \"bar-chart\": {\n exportName: \"BarChart\",\n summary:\n \"Bar chart for comparisons across categories, teams, or time buckets.\",\n aliases: [\"column chart\"],\n related: [\"area-chart\", \"stacked-bar-chart\", \"thin-breakdown-bar\"],\n },\n \"positive-negative-bar-chart\": {\n exportName: \"PositiveNegativeBarChart\",\n summary:\n \"Signed bar chart for profit-loss swings, variance reporting, and delta views that pivot around zero.\",\n aliases: [\"variance chart\", \"profit loss chart\"],\n related: [\"bar-chart\", \"stacked-bar-chart\", \"area-chart\"],\n },\n \"pie-chart\": {\n exportName: \"PieChart\",\n summary:\n \"Pie and donut chart visualizations for part-to-whole comparisons with small category sets.\",\n aliases: [\"donut chart\"],\n related: [\"bar-chart\", \"thin-breakdown-bar\", \"color-palette\"],\n },\n \"neon-line-chart\": {\n exportName: \"NeonLineChart\",\n summary:\n \"High-emphasis glowing line chart for dashboards that need a more stylized analytical treatment.\",\n aliases: [\"line chart\"],\n related: [\"area-chart\", \"bar-chart\", \"stacked-bar-chart\"],\n },\n \"stacked-bar-chart\": {\n exportName: \"StackedBarChart\",\n summary:\n \"Stacked categorical chart for comparing totals and composition inside each bar.\",\n aliases: [\"stacked chart\"],\n related: [\"bar-chart\", \"thin-breakdown-bar\", \"area-chart\"],\n },\n \"thin-breakdown-bar\": {\n exportName: \"ThinBreakdownBar\",\n summary:\n \"Compact horizontal breakdown bar for inline composition summaries and KPI cards.\",\n aliases: [\"breakdown bar\"],\n related: [\"stacked-bar-chart\", \"pie-chart\", \"chip\"],\n },\n icons: {\n summary:\n \"Collection of custom SVG icons for dashboards, navigation, commerce, and status-heavy product UIs.\",\n aliases: [\"icon pack\", \"svg icons\"],\n related: [\"typography\", \"color-palette\", \"button\"],\n rootImport:\n \"import { IconDashboard, IconSettings, IconUser } from 'erp-pro-ui';\",\n subpathImport:\n \"import { IconDashboard, IconSettings, IconUser } from 'erp-pro-ui/icons';\",\n },\n typography: {\n exportName: \"Typography\",\n summary:\n \"Semantic text component with heading, body, caption, alignment, weight, and gradient options.\",\n aliases: [\"text\"],\n related: [\"color-palette\", \"icons\", \"button\"],\n },\n} as const satisfies Record<UiCatalogSlug, ComponentDocSeed>;\n\nfunction getComponentCategory(storybookTitle: string): string {\n return storybookTitle.split(\"/\")[0] ?? \"Components\";\n}\n\nfunction getDefaultRootImport(exportName: string): string {\n return `import { ${exportName} } from 'erp-pro-ui';`;\n}\n\nfunction getDefaultSubpathImport(\n exportName: string,\n packageExportPath: string,\n): string {\n return `import { ${exportName} } from 'erp-pro-ui/${packageExportPath}';`;\n}\n\nexport const libraryPeerDependencies = [\n {\n name: \"framer-motion\",\n reason: \"Required by motion-heavy overlays and effects.\",\n },\n {\n name: \"three\",\n reason: \"Required for Three.js-based visual components.\",\n },\n {\n name: \"@react-three/fiber\",\n reason: \"React renderer used by 3D visual surfaces.\",\n },\n {\n name: \"@react-three/drei\",\n reason: \"Helper primitives used by 3D components.\",\n },\n {\n name: \"@tanstack/react-table\",\n reason: \"Required for DataTable filtering and column tooling.\",\n },\n {\n name: \"recharts\",\n reason: \"Required for chart components.\",\n },\n {\n name: \"lucide-react\",\n reason: \"Used by selected UI controls and docs examples.\",\n },\n] as const satisfies readonly LibraryDocsPeerDependency[];\n\nexport const libraryInstallSteps = [\n {\n title: \"Install the package\",\n description:\n \"Add erp-pro-ui to your React application with your preferred package manager.\",\n examples: [\n {\n title: \"pnpm\",\n language: \"bash\",\n code: \"pnpm add erp-pro-ui\",\n },\n ],\n },\n {\n title: \"Install peer dependencies\",\n description:\n \"Install only the optional peer packages used by motion, tables, and 3D visuals you actually render.\",\n examples: [\n {\n title: \"Peers\",\n language: \"bash\",\n code: \"pnpm add framer-motion three @tanstack/react-table\",\n },\n ],\n },\n {\n title: \"Import the shared styles\",\n description:\n \"Import Tailwind first, then the library stylesheet once at the app entry to load tokens, fonts, foundations, and semantic utilities with no extra Tailwind config.\",\n examples: [\n {\n title: \"Root stylesheet\",\n language: \"css\",\n code: '@import \"tailwindcss\";\\n@import \"erp-pro-ui/styles.css\";',\n },\n ],\n },\n {\n title: \"Use colors and fonts directly\",\n description:\n \"Import tokens.css for raw CSS variables without Tailwind utilities, or colors.css when you want the Tailwind v4 utility bridge generated from the shared semantic tokens. Prefer semantic utilities and --ds-* tokens in new code; the legacy --color-* aliases remain for migration.\",\n examples: [\n {\n title: \"Raw token import\",\n language: \"css\",\n code: '@import \"erp-pro-ui/tokens.css\";',\n },\n {\n title: \"Tailwind bridge import\",\n language: \"css\",\n code: '@import \"tailwindcss\";\\n@import \"erp-pro-ui/colors.css\";\\n@import \"erp-pro-ui/fonts.css\";',\n },\n {\n title: \"Theme token usage\",\n language: \"tsx\",\n code: 'import { Button } from \"erp-pro-ui\";\\n\\n<section className=\"bg-surface text-fg border border-border rounded-2xl p-6\">\\n <Button label=\"Save\" primary />\\n</section>',\n },\n {\n title: \"Chart token usage\",\n language: \"tsx\",\n code: 'import { AreaChart, getChartColorVar } from \"erp-pro-ui\";\\n\\n<AreaChart\\n data={data}\\n categories={[\\n { key: \"revenue\", color: getChartColorVar(1) },\\n { key: \"cost\", color: \"chart-6\" },\\n { key: \"forecast\", color: \"var(--color-chart-10)\" },\\n ]}\\n/>',\n description:\n \"Chart components accept raw CSS colors, theme chart variables, or the built-in chart token helper. The shared token surface includes chart slots 1 through 15.\",\n },\n ],\n },\n {\n title: \"Wrap your app with ThemeProvider\",\n description:\n \"Use ThemeProvider at the root so shared brand and mode attributes are applied as data-brand and data-mode for the token system. The older data-theme attribute is still written for compatibility, but brand and mode are the primary contract.\",\n examples: [\n {\n title: \"Root provider\",\n language: \"tsx\",\n code: \"import { ThemeProvider } from 'erp-pro-ui';\\n\\ncreateRoot(rootElement).render(\\n <ThemeProvider>\\n <App />\\n </ThemeProvider>,\\n);\",\n },\n {\n title: \"Manual attributes\",\n language: \"tsx\",\n code: '<html data-brand=\"teal\" data-mode=\"dark\"></html>',\n },\n ],\n },\n {\n title: \"Choose an import strategy\",\n description:\n \"Use root imports for convenience or subpath imports for a more explicit public contract per component.\",\n examples: [\n {\n title: \"Root imports\",\n language: \"tsx\",\n code: \"import { Button, Dialog, Input } from 'erp-pro-ui';\",\n },\n {\n title: \"Subpath imports\",\n language: \"tsx\",\n code: \"import { Button } from 'erp-pro-ui/button';\\nimport { Dialog } from 'erp-pro-ui/dialog';\",\n },\n ],\n },\n] as const satisfies readonly LibraryDocsInstallStep[];\n\nexport const libraryQuickStartExamples = [\n {\n title: \"Basic screen scaffold\",\n language: \"tsx\",\n code: 'import { Button, Input, ThemeProvider, Typography } from \\'erp-pro-ui\\';\\n\\nexport function App() {\\n return (\\n <ThemeProvider>\\n <section className=\"space-y-4 p-6\">\\n <Typography variant=\"h2\" gradient=\"ocean\">\\n Welcome to ERP Pro\\n </Typography>\\n <Input label=\"Email\" placeholder=\"you@company.com\" />\\n <Button label=\"Get Started\" primary />\\n </section>\\n </ThemeProvider>\\n );\\n}',\n },\n {\n title: \"Dialog confirmation pattern\",\n language: \"tsx\",\n code: 'import { Dialog } from \\'erp-pro-ui\\';\\n\\n<Dialog\\n open={isOpen}\\n onOpenChange={setIsOpen}\\n title=\"Confirm delete\"\\n description=\"This action cannot be undone.\"\\n variant=\"destructive\"\\n preset=\"confirm\"\\n animation=\"scale\"\\n onConfirm={handleDelete}\\n/>;',\n },\n] as const satisfies readonly LibraryDocsCodeExample[];\n\nexport const componentDocs: readonly LibraryComponentDoc[] = uiCatalogItems.map(\n (item): LibraryComponentDoc => {\n const seed: ComponentDocSeed = componentDocSeeds[item.slug];\n const docsRoute = getUiCatalogDocsRoute(item.slug);\n const rootImport =\n seed.rootImport ??\n (seed.exportName\n ? getDefaultRootImport(seed.exportName)\n : `import * as ${item.name.replace(/\\s+/g, \"\")} from 'erp-pro-ui';`);\n const subpathImport =\n seed.subpathImport ??\n (seed.exportName\n ? getDefaultSubpathImport(seed.exportName, item.packageExportPath)\n : `import * as ${item.name.replace(/\\s+/g, \"\")} from 'erp-pro-ui/${item.packageExportPath}';`);\n\n return {\n name: item.name,\n slug: item.slug,\n status: \"status\" in item ? item.status : undefined,\n category: getComponentCategory(item.storybookTitle),\n summary: seed.summary,\n storybookTitle: item.storybookTitle,\n packageExportPath: item.packageExportPath,\n exportName: seed.exportName,\n aliases: seed.aliases ?? [],\n rootImport,\n subpathImport,\n docsRoute,\n docsUrl: `${DOCS_BASE_URL}${docsRoute}`,\n related: seed.related ?? [],\n };\n },\n);\n\nexport const libraryDocs = {\n packageName: \"erp-pro-ui\",\n docsBaseUrl: DOCS_BASE_URL,\n summary:\n \"Reusable React UI library for ERP and SaaS applications with tree-shakeable subpath exports, shared styles, and first-party docs metadata.\",\n features: [\n \"50+ reusable UI components for forms, data display, overlays, charts, and visual effects.\",\n \"Root and subpath imports so consumers can choose convenience or explicit package contracts.\",\n \"Shared Tailwind v4 stylesheet with packaged fonts, tokens, and theme foundations.\",\n \"Dedicated chart color slots and helpers so consuming apps can pick theme-backed series colors directly.\",\n \"Portable docs metadata that can be consumed by other apps, CLIs, and MCP servers.\",\n ],\n installSteps: libraryInstallSteps,\n peerDependencies: libraryPeerDependencies,\n quickStartExamples: libraryQuickStartExamples,\n components: componentDocs,\n} as const satisfies LibraryDocsBundle;\n\nexport function getComponentDocBySlug(\n slug: UiCatalogSlug,\n): LibraryComponentDoc | undefined {\n return componentDocs.find((component) => component.slug === slug);\n}\n\nexport function getComponentDocByName(\n name: string,\n): LibraryComponentDoc | undefined {\n const normalizedName = name.trim().toLowerCase();\n\n return componentDocs.find((component) => {\n if (component.name.toLowerCase() === normalizedName) {\n return true;\n }\n\n if (component.slug === normalizedName) {\n return true;\n }\n\n return component.aliases.some(\n (alias) => alias.toLowerCase() === normalizedName,\n );\n });\n}\n\nexport function searchComponentDocs(query: string): LibraryComponentDoc[] {\n const normalizedQuery = query.trim().toLowerCase();\n\n if (!normalizedQuery) {\n return [...componentDocs];\n }\n\n return componentDocs.filter((component) => {\n const haystack = [\n component.name,\n component.slug,\n component.category,\n component.summary,\n component.storybookTitle,\n ...component.aliases,\n ]\n .join(\" \")\n .toLowerCase();\n\n return haystack.includes(normalizedQuery);\n });\n}\n"],"mappings":"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E,MAAM;EACN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACD;EACE,MAAM;EACN,QAAQ;EACT;CACF;AAED,IAAa,sBAAsB;CACjC;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU;GACR;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACP;GACD;IACE,OAAO;IACP,UAAU;IACV,MAAM;IACN,aACE;IACH;GACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,EACD;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACD;EACE,OAAO;EACP,aACE;EACF,UAAU,CACR;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,EACD;GACE,OAAO;GACP,UAAU;GACV,MAAM;GACP,CACF;EACF;CACF;AAED,IAAa,4BAA4B,CACvC;CACE,OAAO;CACP,UAAU;CACV,MAAM;CACP,EACD;CACE,OAAO;CACP,UAAU;CACV,MAAM;CACP,CACF;AAED,IAAa,gBAAgD,eAAe,KACzE,SAA8B;CAC7B,MAAM,OAAyB,kBAAkB,KAAK;CACtD,MAAM,YAAY,sBAAsB,KAAK,KAAK;CAClD,MAAM,aACJ,KAAK,eACJ,KAAK,aACF,qBAAqB,KAAK,WAAW,GACrC,eAAe,KAAK,KAAK,QAAQ,QAAQ,GAAG,CAAC;CACnD,MAAM,gBACJ,KAAK,kBACJ,KAAK,aACF,wBAAwB,KAAK,YAAY,KAAK,kBAAkB,GAChE,eAAe,KAAK,KAAK,QAAQ,QAAQ,GAAG,CAAC,oBAAoB,KAAK,kBAAkB;AAE9F,QAAO;EACL,MAAM,KAAK;EACX,MAAM,KAAK;EACX,QAAQ,YAAY,OAAO,KAAK,SAAS,KAAA;EACzC,UAAU,qBAAqB,KAAK,eAAe;EACnD,SAAS,KAAK;EACd,gBAAgB,KAAK;EACrB,mBAAmB,KAAK;EACxB,YAAY,KAAK;EACjB,SAAS,KAAK,WAAW,EAAE;EAC3B;EACA;EACA;EACA,SAAS,GAAG,gBAAgB;EAC5B,SAAS,KAAK,WAAW,EAAE;EAC5B;EAEJ;AAED,IAAa,cAAc;CACzB,aAAa;CACb,aAAa;CACb,SACE;CACF,UAAU;EACR;EACA;EACA;EACA;EACA;EACD;CACD,cAAc;CACd,kBAAkB;CAClB,oBAAoB;CACpB,YAAY;CACb;AAED,SAAgB,sBACd,MACiC;AACjC,QAAO,cAAc,MAAM,cAAc,UAAU,SAAS,KAAK;;AAGnE,SAAgB,sBACd,MACiC;CACjC,MAAM,iBAAiB,KAAK,MAAM,CAAC,aAAa;AAEhD,QAAO,cAAc,MAAM,cAAc;AACvC,MAAI,UAAU,KAAK,aAAa,KAAK,eACnC,QAAO;AAGT,MAAI,UAAU,SAAS,eACrB,QAAO;AAGT,SAAO,UAAU,QAAQ,MACtB,UAAU,MAAM,aAAa,KAAK,eACpC;GACD;;AAGJ,SAAgB,oBAAoB,OAAsC;CACxE,MAAM,kBAAkB,MAAM,MAAM,CAAC,aAAa;AAElD,KAAI,CAAC,gBACH,QAAO,CAAC,GAAG,cAAc;AAG3B,QAAO,cAAc,QAAQ,cAAc;AAYzC,SAXiB;GACf,UAAU;GACV,UAAU;GACV,UAAU;GACV,UAAU;GACV,UAAU;GACV,GAAG,UAAU;GACd,CACE,KAAK,IAAI,CACT,aAAa,CAEA,SAAS,gBAAgB;GACzC"}
@@ -28,3 +28,10 @@
28
28
  html {
29
29
  scroll-behavior: smooth;
30
30
  }
31
+
32
+ .surface-background-secondary-glass {
33
+ background-color: var(--color-background-secondary-glass);
34
+ box-shadow: 0 8px 32px 0 rgb(31 38 135 / 0.18);
35
+ -webkit-backdrop-filter: blur(160px) saturate(180%);
36
+ backdrop-filter: blur(30px) saturate(180%);
37
+ }