@pixpilot/shadcn-ui 0.4.0 → 0.4.2

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 (236) hide show
  1. package/dist/AbsoluteFill.cjs +24 -1
  2. package/dist/AbsoluteFill.js +21 -1
  3. package/dist/Alert.cjs +82 -1
  4. package/dist/Alert.js +77 -1
  5. package/dist/Button.cjs +84 -1
  6. package/dist/Button.d.cts +1 -1
  7. package/dist/Button.d.ts +1 -1
  8. package/dist/Button.js +79 -1
  9. package/dist/CloseButtonAbsolute.cjs +20 -1
  10. package/dist/CloseButtonAbsolute.js +16 -1
  11. package/dist/CloseButtonRounded.cjs +22 -1
  12. package/dist/CloseButtonRounded.js +17 -1
  13. package/dist/Combobox.cjs +53 -1
  14. package/dist/Combobox.js +48 -1
  15. package/dist/CommandOptionList.cjs +29 -1
  16. package/dist/CommandOptionList.js +25 -1
  17. package/dist/ContentCard.cjs +27 -1
  18. package/dist/ContentCard.d.cts +1 -1
  19. package/dist/ContentCard.js +23 -1
  20. package/dist/DatePicker.cjs +38 -1
  21. package/dist/DatePicker.d.cts +1 -1
  22. package/dist/DatePicker.js +33 -1
  23. package/dist/LoadingOverlay.cjs +65 -1
  24. package/dist/LoadingOverlay.js +60 -1
  25. package/dist/Select.cjs +27 -1
  26. package/dist/Select.d.cts +1 -1
  27. package/dist/Select.js +23 -1
  28. package/dist/Slider.cjs +19 -1
  29. package/dist/Slider.js +15 -1
  30. package/dist/ThemeToggle.cjs +98 -1
  31. package/dist/ThemeToggle.js +94 -1
  32. package/dist/_virtual/rolldown_runtime.cjs +25 -1
  33. package/dist/confirmation-dialog/ConfirmationDialog.cjs +46 -1
  34. package/dist/confirmation-dialog/ConfirmationDialog.d.cts +1 -0
  35. package/dist/confirmation-dialog/ConfirmationDialog.js +42 -1
  36. package/dist/confirmation-dialog/DialogProvider.cjs +16 -1
  37. package/dist/confirmation-dialog/DialogProvider.js +12 -1
  38. package/dist/confirmation-dialog/confirmation-dialogs.cjs +14 -1
  39. package/dist/confirmation-dialog/confirmation-dialogs.js +12 -1
  40. package/dist/confirmation-dialog/index.cjs +6 -1
  41. package/dist/confirmation-dialog/index.js +6 -1
  42. package/dist/file-upload/FileUpload.cjs +68 -1
  43. package/dist/file-upload/FileUpload.d.ts +2 -2
  44. package/dist/file-upload/FileUpload.js +63 -1
  45. package/dist/file-upload/FileUploadItems.cjs +36 -1
  46. package/dist/file-upload/FileUploadItems.js +32 -1
  47. package/dist/file-upload/FileUploadListItem.cjs +88 -1
  48. package/dist/file-upload/FileUploadListItem.js +82 -1
  49. package/dist/file-upload/hooks/index.cjs +3 -1
  50. package/dist/file-upload/hooks/index.d.cts +2 -0
  51. package/dist/file-upload/hooks/index.js +3 -1
  52. package/dist/file-upload/hooks/use-file-error.cjs +15 -1
  53. package/dist/file-upload/hooks/use-file-error.js +13 -1
  54. package/dist/file-upload/hooks/use-file-upload-progress-callbacks.cjs +34 -1
  55. package/dist/file-upload/hooks/use-file-upload-progress-callbacks.d.cts +1 -0
  56. package/dist/file-upload/hooks/use-file-upload-progress-callbacks.js +31 -1
  57. package/dist/file-upload/hooks/use-file-upload-store.cjs +77 -1
  58. package/dist/file-upload/hooks/use-file-upload-store.d.cts +2 -0
  59. package/dist/file-upload/hooks/use-file-upload-store.js +75 -1
  60. package/dist/file-upload/index.cjs +5 -1
  61. package/dist/file-upload/index.d.cts +2 -1
  62. package/dist/file-upload/index.js +5 -1
  63. package/dist/file-upload/utils/create-placeholder-file.cjs +11 -1
  64. package/dist/file-upload/utils/create-placeholder-file.js +10 -1
  65. package/dist/file-upload/utils/get-file-key.cjs +8 -1
  66. package/dist/file-upload/utils/get-file-key.d.cts +1 -0
  67. package/dist/file-upload/utils/get-file-key.js +7 -1
  68. package/dist/file-upload/utils/get-file-meta.cjs +23 -1
  69. package/dist/file-upload/utils/get-file-meta.d.cts +1 -0
  70. package/dist/file-upload/utils/get-file-meta.js +21 -1
  71. package/dist/file-upload/utils/index.d.cts +4 -0
  72. package/dist/file-upload/utils/is-file-equal.cjs +9 -1
  73. package/dist/file-upload/utils/is-file-equal.d.cts +1 -0
  74. package/dist/file-upload/utils/is-file-equal.js +8 -1
  75. package/dist/file-upload/utils/merge-file-metadata.cjs +26 -1
  76. package/dist/file-upload/utils/merge-file-metadata.d.cts +1 -0
  77. package/dist/file-upload/utils/merge-file-metadata.js +26 -1
  78. package/dist/file-upload-inline/FileUploadInline.cjs +71 -1
  79. package/dist/file-upload-inline/FileUploadInline.d.ts +2 -2
  80. package/dist/file-upload-inline/FileUploadInline.js +66 -1
  81. package/dist/file-upload-inline/FileUploadInlineItem.cjs +94 -1
  82. package/dist/file-upload-inline/FileUploadInlineItem.js +88 -1
  83. package/dist/file-upload-inline/defaults.cjs +11 -1
  84. package/dist/file-upload-inline/defaults.js +10 -1
  85. package/dist/file-upload-inline/index.cjs +1 -1
  86. package/dist/file-upload-inline/index.js +1 -1
  87. package/dist/file-upload-inline/utils.cjs +36 -1
  88. package/dist/file-upload-inline/utils.js +34 -1
  89. package/dist/hooks/index.cjs +1 -1
  90. package/dist/hooks/index.js +1 -1
  91. package/dist/hooks/use-media-query.cjs +9 -1
  92. package/dist/hooks/use-media-query.js +7 -1
  93. package/dist/icon-selector/IconPicker.cjs +93 -1
  94. package/dist/icon-selector/IconPicker.d.cts +0 -1
  95. package/dist/icon-selector/IconPicker.d.ts +0 -1
  96. package/dist/icon-selector/IconPicker.js +88 -1
  97. package/dist/icon-selector/constants.cjs +6 -1
  98. package/dist/icon-selector/constants.js +5 -0
  99. package/dist/icon-selector/icon-picker-container.cjs +35 -1
  100. package/dist/icon-selector/icon-picker-container.js +32 -1
  101. package/dist/icon-selector/icon-picker-content.cjs +146 -1
  102. package/dist/icon-selector/icon-picker-content.js +141 -1
  103. package/dist/icon-selector/index.cjs +1 -1
  104. package/dist/icon-selector/index.d.cts +2 -2
  105. package/dist/icon-selector/index.d.ts +2 -2
  106. package/dist/icon-selector/index.js +1 -1
  107. package/dist/icon-selector/use-async-providers.cjs +69 -1
  108. package/dist/icon-selector/use-async-providers.js +67 -1
  109. package/dist/icon-selector/utils/is-valid-provider.cjs +11 -1
  110. package/dist/icon-selector/utils/is-valid-provider.js +10 -1
  111. package/dist/icon-selector/virtualized-icon-grid.cjs +137 -1
  112. package/dist/icon-selector/virtualized-icon-grid.js +132 -1
  113. package/dist/index.cjs +76 -1
  114. package/dist/index.d.cts +2 -2
  115. package/dist/index.d.ts +2 -2
  116. package/dist/index.js +37 -1
  117. package/dist/node_modules/.pnpm/clsx@2.1.1/node_modules/clsx/dist/clsx.cjs +18 -0
  118. package/dist/node_modules/.pnpm/clsx@2.1.1/node_modules/clsx/dist/clsx.js +17 -0
  119. package/dist/node_modules/.pnpm/tailwind-merge@3.4.0/node_modules/tailwind-merge/dist/bundle-mjs.cjs +1894 -0
  120. package/dist/node_modules/.pnpm/tailwind-merge@3.4.0/node_modules/tailwind-merge/dist/bundle-mjs.js +1893 -0
  121. package/dist/packages/shadcn/src/lib/utils.cjs +10 -1
  122. package/dist/packages/shadcn/src/lib/utils.js +10 -1
  123. package/dist/pagination/Pagination.cjs +156 -1
  124. package/dist/pagination/Pagination.js +151 -1
  125. package/dist/pagination/index.cjs +1 -1
  126. package/dist/pagination/index.js +1 -1
  127. package/dist/rich-text-editor/RichTextEditor.cjs +132 -1
  128. package/dist/rich-text-editor/RichTextEditor.js +126 -1
  129. package/dist/rich-text-editor/index.cjs +1 -1
  130. package/dist/rich-text-editor/index.js +1 -1
  131. package/dist/rich-text-editor/predefined-toolbar-options.cjs +84 -1
  132. package/dist/rich-text-editor/predefined-toolbar-options.js +81 -1
  133. package/dist/spinner/index.cjs +1 -1
  134. package/dist/spinner/index.js +1 -1
  135. package/dist/spinner/spinner.cjs +73 -6
  136. package/dist/spinner/spinner.js +70 -6
  137. package/dist/spinner/styles.cjs +24 -12
  138. package/dist/spinner/styles.js +23 -12
  139. package/dist/tags-input.cjs +226 -1
  140. package/dist/tags-input.js +222 -1
  141. package/dist/theme-provider/ThemeProvider.cjs +27 -1
  142. package/dist/theme-provider/ThemeProvider.js +23 -1
  143. package/dist/theme-provider/index.cjs +4 -1
  144. package/dist/theme-provider/index.js +4 -1
  145. package/dist/toast/AlertToast.cjs +36 -1
  146. package/dist/toast/AlertToast.js +31 -1
  147. package/dist/toast/index.cjs +1 -1
  148. package/dist/toast/index.js +1 -1
  149. package/dist/toast/toast.cjs +75 -1
  150. package/dist/toast/toast.js +66 -1
  151. package/package.json +2 -2
  152. package/dist/_virtual/rolldown_runtime.js +0 -1
  153. package/dist/node_modules/.pnpm/@diceui_shared@0.12.0_@floating-ui_react@0.27.16_react-dom@19.2.0_react@19.2.0__react@1_2c51ffe880f01dd537d5b6a13313daf4/node_modules/@diceui/shared/dist/index.cjs +0 -1
  154. package/dist/node_modules/.pnpm/@diceui_shared@0.12.0_@floating-ui_react@0.27.16_react-dom@19.2.0_react@19.2.0__react@1_2c51ffe880f01dd537d5b6a13313daf4/node_modules/@diceui/shared/dist/index.js +0 -1
  155. package/dist/node_modules/.pnpm/@diceui_tags-input@0.7.2_@floating-ui_react@0.27.16_react-dom@19.2.0_react@19.2.0__reac_e193dc2ff0d426ed009417f8d89778fd/node_modules/@diceui/tags-input/dist/index.cjs +0 -1
  156. package/dist/node_modules/.pnpm/@diceui_tags-input@0.7.2_@floating-ui_react@0.27.16_react-dom@19.2.0_react@19.2.0__reac_e193dc2ff0d426ed009417f8d89778fd/node_modules/@diceui/tags-input/dist/index.js +0 -1
  157. package/dist/node_modules/.pnpm/@floating-ui_core@1.7.3/node_modules/@floating-ui/core/dist/floating-ui.core.cjs +0 -1
  158. package/dist/node_modules/.pnpm/@floating-ui_core@1.7.3/node_modules/@floating-ui/core/dist/floating-ui.core.js +0 -1
  159. package/dist/node_modules/.pnpm/@floating-ui_dom@1.7.4/node_modules/@floating-ui/dom/dist/floating-ui.dom.cjs +0 -1
  160. package/dist/node_modules/.pnpm/@floating-ui_dom@1.7.4/node_modules/@floating-ui/dom/dist/floating-ui.dom.js +0 -1
  161. package/dist/node_modules/.pnpm/@floating-ui_react-dom@2.1.6_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.cjs +0 -1
  162. package/dist/node_modules/.pnpm/@floating-ui_react-dom@2.1.6_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.js +0 -1
  163. package/dist/node_modules/.pnpm/@floating-ui_react@0.27.16_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@floating-ui/react/dist/floating-ui.react.esm.cjs +0 -1
  164. package/dist/node_modules/.pnpm/@floating-ui_react@0.27.16_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@floating-ui/react/dist/floating-ui.react.esm.js +0 -1
  165. package/dist/node_modules/.pnpm/@floating-ui_react@0.27.16_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@floating-ui/react/dist/floating-ui.react.utils.cjs +0 -1
  166. package/dist/node_modules/.pnpm/@floating-ui_react@0.27.16_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@floating-ui/react/dist/floating-ui.react.utils.js +0 -1
  167. package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.cjs +0 -1
  168. package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.cjs +0 -1
  169. package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js +0 -1
  170. package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.js +0 -1
  171. package/dist/node_modules/.pnpm/tabbable@6.3.0/node_modules/tabbable/dist/index.cjs +0 -1
  172. package/dist/node_modules/.pnpm/tabbable@6.3.0/node_modules/tabbable/dist/index.esm.js +0 -1
  173. package/dist/packages/shadcn/src/components/index.cjs +0 -1
  174. package/dist/packages/shadcn/src/components/index.js +0 -1
  175. package/dist/packages/shadcn/src/components/ui/OrContinueWithSeparator.cjs +0 -1
  176. package/dist/packages/shadcn/src/components/ui/OrContinueWithSeparator.js +0 -1
  177. package/dist/packages/shadcn/src/components/ui/alert-dialog.cjs +0 -1
  178. package/dist/packages/shadcn/src/components/ui/alert-dialog.js +0 -1
  179. package/dist/packages/shadcn/src/components/ui/alert.cjs +0 -1
  180. package/dist/packages/shadcn/src/components/ui/alert.js +0 -1
  181. package/dist/packages/shadcn/src/components/ui/avatar.cjs +0 -1
  182. package/dist/packages/shadcn/src/components/ui/avatar.js +0 -1
  183. package/dist/packages/shadcn/src/components/ui/badge.cjs +0 -1
  184. package/dist/packages/shadcn/src/components/ui/badge.js +0 -1
  185. package/dist/packages/shadcn/src/components/ui/button.cjs +0 -1
  186. package/dist/packages/shadcn/src/components/ui/button.js +0 -1
  187. package/dist/packages/shadcn/src/components/ui/calendar.cjs +0 -1
  188. package/dist/packages/shadcn/src/components/ui/calendar.js +0 -1
  189. package/dist/packages/shadcn/src/components/ui/card.cjs +0 -1
  190. package/dist/packages/shadcn/src/components/ui/card.js +0 -1
  191. package/dist/packages/shadcn/src/components/ui/checkbox.cjs +0 -1
  192. package/dist/packages/shadcn/src/components/ui/checkbox.js +0 -1
  193. package/dist/packages/shadcn/src/components/ui/command.cjs +0 -1
  194. package/dist/packages/shadcn/src/components/ui/command.js +0 -1
  195. package/dist/packages/shadcn/src/components/ui/dialog.cjs +0 -1
  196. package/dist/packages/shadcn/src/components/ui/dialog.js +0 -1
  197. package/dist/packages/shadcn/src/components/ui/dropdown-menu.cjs +0 -1
  198. package/dist/packages/shadcn/src/components/ui/dropdown-menu.js +0 -1
  199. package/dist/packages/shadcn/src/components/ui/file-upload.cjs +0 -1
  200. package/dist/packages/shadcn/src/components/ui/file-upload.js +0 -1
  201. package/dist/packages/shadcn/src/components/ui/form.cjs +0 -1
  202. package/dist/packages/shadcn/src/components/ui/form.js +0 -1
  203. package/dist/packages/shadcn/src/components/ui/index.cjs +0 -1
  204. package/dist/packages/shadcn/src/components/ui/index.js +0 -1
  205. package/dist/packages/shadcn/src/components/ui/input.cjs +0 -1
  206. package/dist/packages/shadcn/src/components/ui/input.js +0 -1
  207. package/dist/packages/shadcn/src/components/ui/label.cjs +0 -1
  208. package/dist/packages/shadcn/src/components/ui/label.js +0 -1
  209. package/dist/packages/shadcn/src/components/ui/pagination.cjs +0 -1
  210. package/dist/packages/shadcn/src/components/ui/pagination.js +0 -1
  211. package/dist/packages/shadcn/src/components/ui/popover.cjs +0 -1
  212. package/dist/packages/shadcn/src/components/ui/popover.js +0 -1
  213. package/dist/packages/shadcn/src/components/ui/radio-group.cjs +0 -1
  214. package/dist/packages/shadcn/src/components/ui/radio-group.js +0 -1
  215. package/dist/packages/shadcn/src/components/ui/select.cjs +0 -1
  216. package/dist/packages/shadcn/src/components/ui/select.js +0 -1
  217. package/dist/packages/shadcn/src/components/ui/separator.cjs +0 -1
  218. package/dist/packages/shadcn/src/components/ui/separator.js +0 -1
  219. package/dist/packages/shadcn/src/components/ui/shadcn-io/tags/index.cjs +0 -1
  220. package/dist/packages/shadcn/src/components/ui/shadcn-io/tags/index.js +0 -1
  221. package/dist/packages/shadcn/src/components/ui/shadcn-io/tags-input-inline/index.cjs +0 -1
  222. package/dist/packages/shadcn/src/components/ui/shadcn-io/tags-input-inline/index.js +0 -1
  223. package/dist/packages/shadcn/src/components/ui/sheet.cjs +0 -1
  224. package/dist/packages/shadcn/src/components/ui/sheet.js +0 -1
  225. package/dist/packages/shadcn/src/components/ui/slider.cjs +0 -1
  226. package/dist/packages/shadcn/src/components/ui/slider.js +0 -1
  227. package/dist/packages/shadcn/src/components/ui/switch.cjs +0 -1
  228. package/dist/packages/shadcn/src/components/ui/switch.js +0 -1
  229. package/dist/packages/shadcn/src/components/ui/tabs.cjs +0 -1
  230. package/dist/packages/shadcn/src/components/ui/tabs.js +0 -1
  231. package/dist/packages/shadcn/src/components/ui/textarea.cjs +0 -1
  232. package/dist/packages/shadcn/src/components/ui/textarea.js +0 -1
  233. package/dist/packages/shadcn/src/components/ui/tooltip.cjs +0 -1
  234. package/dist/packages/shadcn/src/components/ui/tooltip.js +0 -1
  235. package/dist/packages/shadcn/src/lib/index.cjs +0 -1
  236. package/dist/packages/shadcn/src/lib/index.js +0 -1
@@ -1 +1,24 @@
1
- const e=require(`./_virtual/rolldown_runtime.cjs`);let t=require(`react`);t=e.__toESM(t);let n=require(`react/jsx-runtime`);n=e.__toESM(n);function r(e){let{ref:t,...r}=e;return(0,n.jsx)(`div`,{ref:t,className:`absolute top-0 right-0 bottom-0 left-0`,...r})}r.displayName=`StretchedElement`,exports.AbsoluteFill=r;
1
+ const require_rolldown_runtime = require('./_virtual/rolldown_runtime.cjs');
2
+ let react = require("react");
3
+ react = require_rolldown_runtime.__toESM(react);
4
+ let react_jsx_runtime = require("react/jsx-runtime");
5
+ react_jsx_runtime = require_rolldown_runtime.__toESM(react_jsx_runtime);
6
+
7
+ //#region src/AbsoluteFill.tsx
8
+ /**
9
+ * Stretched element to enable tooltips on disabled buttons
10
+ * When a button is disabled, tooltips don't work by default.
11
+ * This element is positioned absolutely over the button to capture events.
12
+ */
13
+ function AbsoluteFill(props) {
14
+ const { ref,...rest } = props;
15
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
16
+ ref,
17
+ className: "absolute top-0 right-0 bottom-0 left-0",
18
+ ...rest
19
+ });
20
+ }
21
+ AbsoluteFill.displayName = "StretchedElement";
22
+
23
+ //#endregion
24
+ exports.AbsoluteFill = AbsoluteFill;
@@ -1 +1,21 @@
1
- import e from"react";import{jsx as t}from"react/jsx-runtime";function n(e){let{ref:n,...r}=e;return t(`div`,{ref:n,className:`absolute top-0 right-0 bottom-0 left-0`,...r})}n.displayName=`StretchedElement`;export{n as AbsoluteFill};
1
+ import React from "react";
2
+ import { jsx } from "react/jsx-runtime";
3
+
4
+ //#region src/AbsoluteFill.tsx
5
+ /**
6
+ * Stretched element to enable tooltips on disabled buttons
7
+ * When a button is disabled, tooltips don't work by default.
8
+ * This element is positioned absolutely over the button to capture events.
9
+ */
10
+ function AbsoluteFill(props) {
11
+ const { ref,...rest } = props;
12
+ return /* @__PURE__ */ jsx("div", {
13
+ ref,
14
+ className: "absolute top-0 right-0 bottom-0 left-0",
15
+ ...rest
16
+ });
17
+ }
18
+ AbsoluteFill.displayName = "StretchedElement";
19
+
20
+ //#endregion
21
+ export { AbsoluteFill };
package/dist/Alert.cjs CHANGED
@@ -1 +1,82 @@
1
- const e=require(`./_virtual/rolldown_runtime.cjs`),t=require(`./packages/shadcn/src/lib/utils.cjs`);require(`./packages/shadcn/src/lib/index.cjs`);const n=require(`./packages/shadcn/src/components/ui/alert.cjs`);let r=require(`lucide-react`);r=e.__toESM(r);let i=require(`react`);i=e.__toESM(i);let a=require(`react/jsx-runtime`);a=e.__toESM(a);const o=t.cn(`t-0 size-4`),s={error:{descClass:`text-destructive`,textClass:`text-destructive`,class:t.cn(`border-current/80!`),icon:(0,a.jsx)(r.OctagonAlertIcon,{className:o})},warning:{descClass:`text-amber-600/80 dark:text-amber-400/80`,textClass:`text-amber-600 dark:border-amber-400 dark:text-amber-400`,class:t.cn(`border-current/80!`),icon:(0,a.jsx)(r.CircleAlertIcon,{className:o})},info:{descClass:`text-sky-600/80 dark:text-sky-400/80`,textClass:`text-sky-600 dark:border-sky-400 dark:text-sky-400`,class:t.cn(`border-current/80!`),icon:(0,a.jsx)(r.CircleAlertIcon,{className:o})},success:{descClass:`text-green-600/80 dark:text-green-400/80`,textClass:`text-green-600 dark:border-green-400 dark:text-green-400`,class:t.cn(`border-current/80!`),icon:(0,a.jsx)(r.CircleCheckBigIcon,{className:o})},default:{descClass:`text-foreground/80`,textClass:`text-foreground`,class:t.cn(`border-current/60!`),icon:(0,a.jsx)(r.CircleAlertIcon,{className:o})}};function c(e,t){return e===!1?null:e===void 0||e===!0?s[t??`default`].icon:e}const l=e=>{let{description:r,variant:i=`default`,title:o,className:l,children:u,icon:d=!1,...f}=e,p=c(d,i),m=o!=null&&o.trim()!==``,h=s[i]??s.default;return(0,a.jsxs)(n.Alert,{...f,variant:`destructive`,className:t.cn(`bg-card border-accent! flex justify-between rounded-sm border-0 border-l-4`,h.class,h.textClass,l),children:[p&&(0,a.jsx)(`div`,{className:t.cn(`mr-3 flex items-start pt-0.5`),children:p}),(0,a.jsxs)(`div`,{className:`flex flex-1 flex-col gap-1`,children:[m&&(0,a.jsx)(n.AlertTitle,{className:t.cn(h.textClass,{"block!":!m}),children:o}),r!=null&&(0,a.jsx)(n.AlertDescription,{className:t.cn(h.descClass,!m&&h.textClass),children:r})]}),u]})};l.displayName=`Alert`,exports.Alert=l;
1
+ const require_rolldown_runtime = require('./_virtual/rolldown_runtime.cjs');
2
+ const require_utils = require('./packages/shadcn/src/lib/utils.cjs');
3
+ let __pixpilot_shadcn = require("@pixpilot/shadcn");
4
+ __pixpilot_shadcn = require_rolldown_runtime.__toESM(__pixpilot_shadcn);
5
+ let lucide_react = require("lucide-react");
6
+ lucide_react = require_rolldown_runtime.__toESM(lucide_react);
7
+ let react = require("react");
8
+ react = require_rolldown_runtime.__toESM(react);
9
+ let react_jsx_runtime = require("react/jsx-runtime");
10
+ react_jsx_runtime = require_rolldown_runtime.__toESM(react_jsx_runtime);
11
+
12
+ //#region src/Alert.tsx
13
+ const iconClass = require_utils.cn("t-0 size-4");
14
+ const colors = {
15
+ error: {
16
+ descClass: "text-destructive",
17
+ textClass: "text-destructive",
18
+ class: require_utils.cn("border-current/80!"),
19
+ icon: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.OctagonAlertIcon, { className: iconClass })
20
+ },
21
+ warning: {
22
+ descClass: "text-amber-600/80 dark:text-amber-400/80",
23
+ textClass: "text-amber-600 dark:border-amber-400 dark:text-amber-400",
24
+ class: require_utils.cn("border-current/80!"),
25
+ icon: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.CircleAlertIcon, { className: iconClass })
26
+ },
27
+ info: {
28
+ descClass: "text-sky-600/80 dark:text-sky-400/80",
29
+ textClass: "text-sky-600 dark:border-sky-400 dark:text-sky-400",
30
+ class: require_utils.cn("border-current/80!"),
31
+ icon: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.CircleAlertIcon, { className: iconClass })
32
+ },
33
+ success: {
34
+ descClass: "text-green-600/80 dark:text-green-400/80",
35
+ textClass: "text-green-600 dark:border-green-400 dark:text-green-400",
36
+ class: require_utils.cn("border-current/80!"),
37
+ icon: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.CircleCheckBigIcon, { className: iconClass })
38
+ },
39
+ default: {
40
+ descClass: "text-foreground/80",
41
+ textClass: "text-foreground",
42
+ class: require_utils.cn("border-current/60!"),
43
+ icon: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.CircleAlertIcon, { className: iconClass })
44
+ }
45
+ };
46
+ function getIcon(icon, variant) {
47
+ if (icon === false) return null;
48
+ if (icon === void 0 || icon === true) return colors[variant ?? "default"].icon;
49
+ return icon;
50
+ }
51
+ const Alert = (props) => {
52
+ const { description, variant = "default", title, className, children, icon = false,...rest } = props;
53
+ const msgIcon = getIcon(icon, variant);
54
+ const hasTitle = title != null && title.trim() !== "";
55
+ const variantConfig = colors[variant] ?? colors.default;
56
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(__pixpilot_shadcn.Alert, {
57
+ ...rest,
58
+ variant: "destructive",
59
+ className: require_utils.cn("bg-card border-accent! flex justify-between rounded-sm border-0 border-l-4", variantConfig.class, variantConfig.textClass, className),
60
+ children: [
61
+ msgIcon && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
62
+ className: require_utils.cn("mr-3 flex items-start pt-0.5"),
63
+ children: msgIcon
64
+ }),
65
+ /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
66
+ className: "flex flex-1 flex-col gap-1",
67
+ children: [hasTitle && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.AlertTitle, {
68
+ className: require_utils.cn(variantConfig.textClass, { "block!": !hasTitle }),
69
+ children: title
70
+ }), description != null && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.AlertDescription, {
71
+ className: require_utils.cn(variantConfig.descClass, !hasTitle && variantConfig.textClass),
72
+ children: description
73
+ })]
74
+ }),
75
+ children
76
+ ]
77
+ });
78
+ };
79
+ Alert.displayName = "Alert";
80
+
81
+ //#endregion
82
+ exports.Alert = Alert;
package/dist/Alert.js CHANGED
@@ -1 +1,77 @@
1
- import{cn as e}from"./packages/shadcn/src/lib/utils.js";import"./packages/shadcn/src/lib/index.js";import{Alert as t,AlertDescription as n,AlertTitle as r}from"./packages/shadcn/src/components/ui/alert.js";import{CircleAlertIcon as i,CircleCheckBigIcon as a,OctagonAlertIcon as o}from"lucide-react";import s from"react";import{jsx as c,jsxs as l}from"react/jsx-runtime";const u=e(`t-0 size-4`),d={error:{descClass:`text-destructive`,textClass:`text-destructive`,class:e(`border-current/80!`),icon:c(o,{className:u})},warning:{descClass:`text-amber-600/80 dark:text-amber-400/80`,textClass:`text-amber-600 dark:border-amber-400 dark:text-amber-400`,class:e(`border-current/80!`),icon:c(i,{className:u})},info:{descClass:`text-sky-600/80 dark:text-sky-400/80`,textClass:`text-sky-600 dark:border-sky-400 dark:text-sky-400`,class:e(`border-current/80!`),icon:c(i,{className:u})},success:{descClass:`text-green-600/80 dark:text-green-400/80`,textClass:`text-green-600 dark:border-green-400 dark:text-green-400`,class:e(`border-current/80!`),icon:c(a,{className:u})},default:{descClass:`text-foreground/80`,textClass:`text-foreground`,class:e(`border-current/60!`),icon:c(i,{className:u})}};function f(e,t){return e===!1?null:e===void 0||e===!0?d[t??`default`].icon:e}const p=i=>{let{description:a,variant:o=`default`,title:s,className:u,children:p,icon:m=!1,...h}=i,g=f(m,o),_=s!=null&&s.trim()!==``,v=d[o]??d.default;return l(t,{...h,variant:`destructive`,className:e(`bg-card border-accent! flex justify-between rounded-sm border-0 border-l-4`,v.class,v.textClass,u),children:[g&&c(`div`,{className:e(`mr-3 flex items-start pt-0.5`),children:g}),l(`div`,{className:`flex flex-1 flex-col gap-1`,children:[_&&c(r,{className:e(v.textClass,{"block!":!_}),children:s}),a!=null&&c(n,{className:e(v.descClass,!_&&v.textClass),children:a})]}),p]})};p.displayName=`Alert`;export{p as Alert};
1
+ import { cn as cn$1 } from "./packages/shadcn/src/lib/utils.js";
2
+ import { Alert, AlertDescription, AlertTitle } from "@pixpilot/shadcn";
3
+ import { CircleAlertIcon, CircleCheckBigIcon, OctagonAlertIcon } from "lucide-react";
4
+ import React from "react";
5
+ import { jsx, jsxs } from "react/jsx-runtime";
6
+
7
+ //#region src/Alert.tsx
8
+ const iconClass = cn$1("t-0 size-4");
9
+ const colors = {
10
+ error: {
11
+ descClass: "text-destructive",
12
+ textClass: "text-destructive",
13
+ class: cn$1("border-current/80!"),
14
+ icon: /* @__PURE__ */ jsx(OctagonAlertIcon, { className: iconClass })
15
+ },
16
+ warning: {
17
+ descClass: "text-amber-600/80 dark:text-amber-400/80",
18
+ textClass: "text-amber-600 dark:border-amber-400 dark:text-amber-400",
19
+ class: cn$1("border-current/80!"),
20
+ icon: /* @__PURE__ */ jsx(CircleAlertIcon, { className: iconClass })
21
+ },
22
+ info: {
23
+ descClass: "text-sky-600/80 dark:text-sky-400/80",
24
+ textClass: "text-sky-600 dark:border-sky-400 dark:text-sky-400",
25
+ class: cn$1("border-current/80!"),
26
+ icon: /* @__PURE__ */ jsx(CircleAlertIcon, { className: iconClass })
27
+ },
28
+ success: {
29
+ descClass: "text-green-600/80 dark:text-green-400/80",
30
+ textClass: "text-green-600 dark:border-green-400 dark:text-green-400",
31
+ class: cn$1("border-current/80!"),
32
+ icon: /* @__PURE__ */ jsx(CircleCheckBigIcon, { className: iconClass })
33
+ },
34
+ default: {
35
+ descClass: "text-foreground/80",
36
+ textClass: "text-foreground",
37
+ class: cn$1("border-current/60!"),
38
+ icon: /* @__PURE__ */ jsx(CircleAlertIcon, { className: iconClass })
39
+ }
40
+ };
41
+ function getIcon(icon, variant) {
42
+ if (icon === false) return null;
43
+ if (icon === void 0 || icon === true) return colors[variant ?? "default"].icon;
44
+ return icon;
45
+ }
46
+ const Alert$1 = (props) => {
47
+ const { description, variant = "default", title, className, children, icon = false,...rest } = props;
48
+ const msgIcon = getIcon(icon, variant);
49
+ const hasTitle = title != null && title.trim() !== "";
50
+ const variantConfig = colors[variant] ?? colors.default;
51
+ return /* @__PURE__ */ jsxs(Alert, {
52
+ ...rest,
53
+ variant: "destructive",
54
+ className: cn$1("bg-card border-accent! flex justify-between rounded-sm border-0 border-l-4", variantConfig.class, variantConfig.textClass, className),
55
+ children: [
56
+ msgIcon && /* @__PURE__ */ jsx("div", {
57
+ className: cn$1("mr-3 flex items-start pt-0.5"),
58
+ children: msgIcon
59
+ }),
60
+ /* @__PURE__ */ jsxs("div", {
61
+ className: "flex flex-1 flex-col gap-1",
62
+ children: [hasTitle && /* @__PURE__ */ jsx(AlertTitle, {
63
+ className: cn$1(variantConfig.textClass, { "block!": !hasTitle }),
64
+ children: title
65
+ }), description != null && /* @__PURE__ */ jsx(AlertDescription, {
66
+ className: cn$1(variantConfig.descClass, !hasTitle && variantConfig.textClass),
67
+ children: description
68
+ })]
69
+ }),
70
+ children
71
+ ]
72
+ });
73
+ };
74
+ Alert$1.displayName = "Alert";
75
+
76
+ //#endregion
77
+ export { Alert$1 as Alert };
package/dist/Button.cjs CHANGED
@@ -1 +1,84 @@
1
- const e=require(`./_virtual/rolldown_runtime.cjs`),t=require(`./AbsoluteFill.cjs`);let n=require(`@pixpilot/shadcn`);n=e.__toESM(n);let r=require(`lucide-react`);r=e.__toESM(r);let i=require(`react`);i=e.__toESM(i);let a=require(`react/jsx-runtime`);a=e.__toESM(a);const o=14,s=16,c=20;function l(e){return e===`sm`||e===`icon-sm`?14:e===`lg`||e===`icon-lg`?20:16}function u(e){let{children:o,disabled:s,onClick:c,disabledTooltip:u,loading:d,LoaderProps:f,onDisabledClick:p,tooltip:m,title:h,TooltipProps:g,className:_,variant:v,size:y,ref:b,...x}=e,{placement:S=`end`}=f||{},C=(0,i.useCallback)(e=>{c&&!s&&c(e)},[s,c]),w=s||d,T=!!m||!!h,E=!!u&&w,D=T||E,O=E?u??``:m??h??``,k=(0,a.jsx)(`div`,{className:(0,n.cn)(`flex items-center justify-center`,S===`center`&&`rounded-0 absolute inset-0`,S===`start`&&`mr-1`,S===`end`&&`ml-1`),children:(0,a.jsx)(r.Loader2,{className:`text-background animate-spin`,style:{height:l(y),width:l(y)}})}),A=(0,a.jsxs)(n.Button,{...x,ref:b,disabled:w,onClick:C,className:(0,n.cn)(`relative`,_),variant:v,size:y,children:[!!u&&w&&(0,a.jsxs)(n.Tooltip,{...g,children:[(0,a.jsx)(n.TooltipTrigger,{asChild:!0,children:(0,a.jsx)(t.AbsoluteFill,{onClick:p,style:{pointerEvents:`all`,cursor:`not-allowed`}})}),(0,a.jsx)(n.TooltipContent,{children:(0,a.jsx)(`p`,{children:u})})]}),d&&S===`start`&&k,o,d&&(S===`end`||S===`center`)&&k]});return D&&!(u&&w)?(0,a.jsxs)(n.Tooltip,{...g,children:[(0,a.jsx)(n.TooltipTrigger,{asChild:!0,children:A}),(0,a.jsx)(n.TooltipContent,{children:(0,a.jsx)(`p`,{children:O})})]}):A}u.displayName=`Button`,exports.Button=u;
1
+ const require_rolldown_runtime = require('./_virtual/rolldown_runtime.cjs');
2
+ const require_AbsoluteFill = require('./AbsoluteFill.cjs');
3
+ let __pixpilot_shadcn = require("@pixpilot/shadcn");
4
+ __pixpilot_shadcn = require_rolldown_runtime.__toESM(__pixpilot_shadcn);
5
+ let lucide_react = require("lucide-react");
6
+ lucide_react = require_rolldown_runtime.__toESM(lucide_react);
7
+ let react = require("react");
8
+ react = require_rolldown_runtime.__toESM(react);
9
+ let react_jsx_runtime = require("react/jsx-runtime");
10
+ react_jsx_runtime = require_rolldown_runtime.__toESM(react_jsx_runtime);
11
+
12
+ //#region src/Button.tsx
13
+ const LOADER_SIZE_SM = 14;
14
+ const LOADER_SIZE_DEFAULT = 16;
15
+ const LOADER_SIZE_LG = 20;
16
+ /**
17
+ * Get loader size based on button size
18
+ */
19
+ function getLoaderSize(size) {
20
+ if (size === "sm" || size === "icon-sm") return LOADER_SIZE_SM;
21
+ if (size === "lg" || size === "icon-lg") return LOADER_SIZE_LG;
22
+ return LOADER_SIZE_DEFAULT;
23
+ }
24
+ function Button(props) {
25
+ const { children, disabled, onClick, disabledTooltip, loading, LoaderProps, onDisabledClick, tooltip, title, TooltipProps, className, variant, size, ref,...rest } = props;
26
+ const { placement: loaderPlacement = "end" } = LoaderProps || {};
27
+ const handleClick = (0, react.useCallback)((e) => {
28
+ if (onClick && !disabled) onClick(e);
29
+ }, [disabled, onClick]);
30
+ const isDisabled = disabled || loading;
31
+ const hasTooltip = Boolean(tooltip) || Boolean(title);
32
+ const hasDisabledTooltip = Boolean(disabledTooltip) && isDisabled;
33
+ const showTooltip = hasTooltip || hasDisabledTooltip;
34
+ const tooltipContent = hasDisabledTooltip ? disabledTooltip ?? "" : tooltip ?? title ?? "";
35
+ const Loader = /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
36
+ className: (0, __pixpilot_shadcn.cn)("flex items-center justify-center", loaderPlacement === "center" && "rounded-0 absolute inset-0", loaderPlacement === "start" && "mr-1", loaderPlacement === "end" && "ml-1"),
37
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.Loader2, {
38
+ className: "text-background animate-spin",
39
+ style: {
40
+ height: getLoaderSize(size),
41
+ width: getLoaderSize(size)
42
+ }
43
+ })
44
+ });
45
+ const buttonContent = /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(__pixpilot_shadcn.Button, {
46
+ ...rest,
47
+ ref,
48
+ disabled: isDisabled,
49
+ onClick: handleClick,
50
+ className: (0, __pixpilot_shadcn.cn)("relative", className),
51
+ variant,
52
+ size,
53
+ children: [
54
+ Boolean(disabledTooltip) && isDisabled && /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(__pixpilot_shadcn.Tooltip, {
55
+ ...TooltipProps,
56
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.TooltipTrigger, {
57
+ asChild: true,
58
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_AbsoluteFill.AbsoluteFill, {
59
+ onClick: onDisabledClick,
60
+ style: {
61
+ pointerEvents: "all",
62
+ cursor: "not-allowed"
63
+ }
64
+ })
65
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.TooltipContent, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("p", { children: disabledTooltip }) })]
66
+ }),
67
+ loading && loaderPlacement === "start" && Loader,
68
+ children,
69
+ loading && (loaderPlacement === "end" || loaderPlacement === "center") && Loader
70
+ ]
71
+ });
72
+ if (showTooltip && !(Boolean(disabledTooltip) && isDisabled)) return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(__pixpilot_shadcn.Tooltip, {
73
+ ...TooltipProps,
74
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.TooltipTrigger, {
75
+ asChild: true,
76
+ children: buttonContent
77
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.TooltipContent, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("p", { children: tooltipContent }) })]
78
+ });
79
+ return buttonContent;
80
+ }
81
+ Button.displayName = "Button";
82
+
83
+ //#endregion
84
+ exports.Button = Button;
package/dist/Button.d.cts CHANGED
@@ -1,5 +1,5 @@
1
- import { Button, Tooltip, buttonVariants } from "@pixpilot/shadcn";
2
1
  import * as react_jsx_runtime0 from "react/jsx-runtime";
2
+ import { Button, Tooltip, buttonVariants } from "@pixpilot/shadcn";
3
3
  import React from "react";
4
4
  import { VariantProps } from "class-variance-authority";
5
5
 
package/dist/Button.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import { Button, Tooltip, buttonVariants } from "@pixpilot/shadcn";
2
2
  import React from "react";
3
- import { VariantProps } from "class-variance-authority";
4
3
  import * as react_jsx_runtime0 from "react/jsx-runtime";
4
+ import { VariantProps } from "class-variance-authority";
5
5
 
6
6
  //#region src/Button.d.ts
7
7
  interface ButtonLoaderProps {
package/dist/Button.js CHANGED
@@ -1 +1,79 @@
1
- import{AbsoluteFill as e}from"./AbsoluteFill.js";import{Button as t,Tooltip as n,TooltipContent as r,TooltipTrigger as i,cn as a}from"@pixpilot/shadcn";import{Loader2 as o}from"lucide-react";import s,{useCallback as c}from"react";import{jsx as l,jsxs as u}from"react/jsx-runtime";function d(e){return e===`sm`||e===`icon-sm`?14:e===`lg`||e===`icon-lg`?20:16}function f(s){let{children:f,disabled:p,onClick:m,disabledTooltip:h,loading:g,LoaderProps:_,onDisabledClick:v,tooltip:y,title:b,TooltipProps:x,className:S,variant:C,size:w,ref:T,...E}=s,{placement:D=`end`}=_||{},O=c(e=>{m&&!p&&m(e)},[p,m]),k=p||g,A=!!y||!!b,j=!!h&&k,M=A||j,N=j?h??``:y??b??``,P=l(`div`,{className:a(`flex items-center justify-center`,D===`center`&&`rounded-0 absolute inset-0`,D===`start`&&`mr-1`,D===`end`&&`ml-1`),children:l(o,{className:`text-background animate-spin`,style:{height:d(w),width:d(w)}})}),F=u(t,{...E,ref:T,disabled:k,onClick:O,className:a(`relative`,S),variant:C,size:w,children:[!!h&&k&&u(n,{...x,children:[l(i,{asChild:!0,children:l(e,{onClick:v,style:{pointerEvents:`all`,cursor:`not-allowed`}})}),l(r,{children:l(`p`,{children:h})})]}),g&&D===`start`&&P,f,g&&(D===`end`||D===`center`)&&P]});return M&&!(h&&k)?u(n,{...x,children:[l(i,{asChild:!0,children:F}),l(r,{children:l(`p`,{children:N})})]}):F}f.displayName=`Button`;export{f as Button};
1
+ import { AbsoluteFill } from "./AbsoluteFill.js";
2
+ import { Button, Tooltip, TooltipContent, TooltipTrigger, cn } from "@pixpilot/shadcn";
3
+ import { Loader2 } from "lucide-react";
4
+ import React, { useCallback } from "react";
5
+ import { jsx, jsxs } from "react/jsx-runtime";
6
+
7
+ //#region src/Button.tsx
8
+ const LOADER_SIZE_SM = 14;
9
+ const LOADER_SIZE_DEFAULT = 16;
10
+ const LOADER_SIZE_LG = 20;
11
+ /**
12
+ * Get loader size based on button size
13
+ */
14
+ function getLoaderSize(size) {
15
+ if (size === "sm" || size === "icon-sm") return LOADER_SIZE_SM;
16
+ if (size === "lg" || size === "icon-lg") return LOADER_SIZE_LG;
17
+ return LOADER_SIZE_DEFAULT;
18
+ }
19
+ function Button$1(props) {
20
+ const { children, disabled, onClick, disabledTooltip, loading, LoaderProps, onDisabledClick, tooltip, title, TooltipProps, className, variant, size, ref,...rest } = props;
21
+ const { placement: loaderPlacement = "end" } = LoaderProps || {};
22
+ const handleClick = useCallback((e) => {
23
+ if (onClick && !disabled) onClick(e);
24
+ }, [disabled, onClick]);
25
+ const isDisabled = disabled || loading;
26
+ const hasTooltip = Boolean(tooltip) || Boolean(title);
27
+ const hasDisabledTooltip = Boolean(disabledTooltip) && isDisabled;
28
+ const showTooltip = hasTooltip || hasDisabledTooltip;
29
+ const tooltipContent = hasDisabledTooltip ? disabledTooltip ?? "" : tooltip ?? title ?? "";
30
+ const Loader = /* @__PURE__ */ jsx("div", {
31
+ className: cn("flex items-center justify-center", loaderPlacement === "center" && "rounded-0 absolute inset-0", loaderPlacement === "start" && "mr-1", loaderPlacement === "end" && "ml-1"),
32
+ children: /* @__PURE__ */ jsx(Loader2, {
33
+ className: "text-background animate-spin",
34
+ style: {
35
+ height: getLoaderSize(size),
36
+ width: getLoaderSize(size)
37
+ }
38
+ })
39
+ });
40
+ const buttonContent = /* @__PURE__ */ jsxs(Button, {
41
+ ...rest,
42
+ ref,
43
+ disabled: isDisabled,
44
+ onClick: handleClick,
45
+ className: cn("relative", className),
46
+ variant,
47
+ size,
48
+ children: [
49
+ Boolean(disabledTooltip) && isDisabled && /* @__PURE__ */ jsxs(Tooltip, {
50
+ ...TooltipProps,
51
+ children: [/* @__PURE__ */ jsx(TooltipTrigger, {
52
+ asChild: true,
53
+ children: /* @__PURE__ */ jsx(AbsoluteFill, {
54
+ onClick: onDisabledClick,
55
+ style: {
56
+ pointerEvents: "all",
57
+ cursor: "not-allowed"
58
+ }
59
+ })
60
+ }), /* @__PURE__ */ jsx(TooltipContent, { children: /* @__PURE__ */ jsx("p", { children: disabledTooltip }) })]
61
+ }),
62
+ loading && loaderPlacement === "start" && Loader,
63
+ children,
64
+ loading && (loaderPlacement === "end" || loaderPlacement === "center") && Loader
65
+ ]
66
+ });
67
+ if (showTooltip && !(Boolean(disabledTooltip) && isDisabled)) return /* @__PURE__ */ jsxs(Tooltip, {
68
+ ...TooltipProps,
69
+ children: [/* @__PURE__ */ jsx(TooltipTrigger, {
70
+ asChild: true,
71
+ children: buttonContent
72
+ }), /* @__PURE__ */ jsx(TooltipContent, { children: /* @__PURE__ */ jsx("p", { children: tooltipContent }) })]
73
+ });
74
+ return buttonContent;
75
+ }
76
+ Button$1.displayName = "Button";
77
+
78
+ //#endregion
79
+ export { Button$1 as Button };
@@ -1 +1,20 @@
1
- const e=require(`./_virtual/rolldown_runtime.cjs`),t=require(`./CloseButtonRounded.cjs`);let n=require(`@pixpilot/shadcn`);n=e.__toESM(n);let r=require(`react`);r=e.__toESM(r);let i=require(`react/jsx-runtime`);i=e.__toESM(i);const a=e=>(0,i.jsx)(t.CloseButtonRounded,{...e,className:(0,n.cn)(`absolute top-1 right-1`,e.className)});a.displayName=`CloseButtonAbsolute`,exports.CloseButtonAbsolute=a;
1
+ const require_rolldown_runtime = require('./_virtual/rolldown_runtime.cjs');
2
+ const require_CloseButtonRounded = require('./CloseButtonRounded.cjs');
3
+ let __pixpilot_shadcn = require("@pixpilot/shadcn");
4
+ __pixpilot_shadcn = require_rolldown_runtime.__toESM(__pixpilot_shadcn);
5
+ let react = require("react");
6
+ react = require_rolldown_runtime.__toESM(react);
7
+ let react_jsx_runtime = require("react/jsx-runtime");
8
+ react_jsx_runtime = require_rolldown_runtime.__toESM(react_jsx_runtime);
9
+
10
+ //#region src/CloseButtonAbsolute.tsx
11
+ const CloseButtonAbsolute = (props) => {
12
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_CloseButtonRounded.CloseButtonRounded, {
13
+ ...props,
14
+ className: (0, __pixpilot_shadcn.cn)("absolute top-1 right-1", props.className)
15
+ });
16
+ };
17
+ CloseButtonAbsolute.displayName = "CloseButtonAbsolute";
18
+
19
+ //#endregion
20
+ exports.CloseButtonAbsolute = CloseButtonAbsolute;
@@ -1 +1,16 @@
1
- import{CloseButtonRounded as e}from"./CloseButtonRounded.js";import{cn as t}from"@pixpilot/shadcn";import n from"react";import{jsx as r}from"react/jsx-runtime";const i=n=>r(e,{...n,className:t(`absolute top-1 right-1`,n.className)});i.displayName=`CloseButtonAbsolute`;export{i as CloseButtonAbsolute};
1
+ import { CloseButtonRounded } from "./CloseButtonRounded.js";
2
+ import { cn } from "@pixpilot/shadcn";
3
+ import React from "react";
4
+ import { jsx } from "react/jsx-runtime";
5
+
6
+ //#region src/CloseButtonAbsolute.tsx
7
+ const CloseButtonAbsolute = (props) => {
8
+ return /* @__PURE__ */ jsx(CloseButtonRounded, {
9
+ ...props,
10
+ className: cn("absolute top-1 right-1", props.className)
11
+ });
12
+ };
13
+ CloseButtonAbsolute.displayName = "CloseButtonAbsolute";
14
+
15
+ //#endregion
16
+ export { CloseButtonAbsolute };
@@ -1 +1,22 @@
1
- const e=require(`./_virtual/rolldown_runtime.cjs`);let t=require(`@pixpilot/shadcn`);t=e.__toESM(t);let n=require(`lucide-react`);n=e.__toESM(n);let r=require(`react`);r=e.__toESM(r);let i=require(`react/jsx-runtime`);i=e.__toESM(i);const a=e=>(0,i.jsx)(t.Button,{...e,className:(0,t.cn)(`flex h-8 w-8 items-center justify-center rounded-full p-0`,e.className),children:(0,i.jsx)(n.X,{className:`h-5 w-5`})});a.displayName=`CloseButtonRounded`,exports.CloseButtonRounded=a;
1
+ const require_rolldown_runtime = require('./_virtual/rolldown_runtime.cjs');
2
+ let __pixpilot_shadcn = require("@pixpilot/shadcn");
3
+ __pixpilot_shadcn = require_rolldown_runtime.__toESM(__pixpilot_shadcn);
4
+ let lucide_react = require("lucide-react");
5
+ lucide_react = require_rolldown_runtime.__toESM(lucide_react);
6
+ let react = require("react");
7
+ react = require_rolldown_runtime.__toESM(react);
8
+ let react_jsx_runtime = require("react/jsx-runtime");
9
+ react_jsx_runtime = require_rolldown_runtime.__toESM(react_jsx_runtime);
10
+
11
+ //#region src/CloseButtonRounded.tsx
12
+ const CloseButtonRounded = (props) => {
13
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.Button, {
14
+ ...props,
15
+ className: (0, __pixpilot_shadcn.cn)("flex h-8 w-8 items-center justify-center rounded-full p-0", props.className),
16
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.X, { className: "h-5 w-5" })
17
+ });
18
+ };
19
+ CloseButtonRounded.displayName = "CloseButtonRounded";
20
+
21
+ //#endregion
22
+ exports.CloseButtonRounded = CloseButtonRounded;
@@ -1 +1,17 @@
1
- import{Button as e,cn as t}from"@pixpilot/shadcn";import{X as n}from"lucide-react";import r from"react";import{jsx as i}from"react/jsx-runtime";const a=r=>i(e,{...r,className:t(`flex h-8 w-8 items-center justify-center rounded-full p-0`,r.className),children:i(n,{className:`h-5 w-5`})});a.displayName=`CloseButtonRounded`;export{a as CloseButtonRounded};
1
+ import { Button, cn } from "@pixpilot/shadcn";
2
+ import { X } from "lucide-react";
3
+ import React from "react";
4
+ import { jsx } from "react/jsx-runtime";
5
+
6
+ //#region src/CloseButtonRounded.tsx
7
+ const CloseButtonRounded = (props) => {
8
+ return /* @__PURE__ */ jsx(Button, {
9
+ ...props,
10
+ className: cn("flex h-8 w-8 items-center justify-center rounded-full p-0", props.className),
11
+ children: /* @__PURE__ */ jsx(X, { className: "h-5 w-5" })
12
+ });
13
+ };
14
+ CloseButtonRounded.displayName = "CloseButtonRounded";
15
+
16
+ //#endregion
17
+ export { CloseButtonRounded };
package/dist/Combobox.cjs CHANGED
@@ -1 +1,53 @@
1
- "use client";const e=require(`./_virtual/rolldown_runtime.cjs`),t=require(`./CommandOptionList.cjs`);let n=require(`@pixpilot/shadcn`);n=e.__toESM(n);let r=require(`lucide-react`);r=e.__toESM(r);let i=require(`react`);i=e.__toESM(i);let a=require(`react/jsx-runtime`);a=e.__toESM(a);const o=[],s=e=>{let{value:s=``,onChange:c,options:l=o,placeholder:u=`Select option...`,searchPlaceholder:d=`Search...`,emptyText:f=`No option found.`,...p}=e,[m,h]=(0,i.useState)(!1);return(0,a.jsxs)(n.Popover,{open:m,onOpenChange:h,children:[(0,a.jsx)(n.PopoverTrigger,{asChild:!0,children:(0,a.jsxs)(n.Button,{variant:`outline`,role:`combobox`,"aria-expanded":m,className:`w-full justify-between`,children:[s?l.find(e=>e.value===s)?.label:u,(0,a.jsx)(r.ChevronsUpDown,{className:`ml-2 h-4 w-4 shrink-0 opacity-50`})]})}),(0,a.jsx)(n.PopoverContent,{className:`w-full p-0`,style:{width:`var(--radix-popover-trigger-width)`},children:(0,a.jsxs)(n.Command,{...p,children:[(0,a.jsx)(n.CommandInput,{placeholder:d}),(0,a.jsx)(t.CommandOptionList,{options:l,value:s,onChange:e=>{c?.(e),h(!1)},emptyText:f})]})})]})};s.displayName=`Combobox`,exports.Combobox=s;
1
+ 'use client';
2
+
3
+
4
+ const require_rolldown_runtime = require('./_virtual/rolldown_runtime.cjs');
5
+ const require_CommandOptionList = require('./CommandOptionList.cjs');
6
+ let __pixpilot_shadcn = require("@pixpilot/shadcn");
7
+ __pixpilot_shadcn = require_rolldown_runtime.__toESM(__pixpilot_shadcn);
8
+ let lucide_react = require("lucide-react");
9
+ lucide_react = require_rolldown_runtime.__toESM(lucide_react);
10
+ let react = require("react");
11
+ react = require_rolldown_runtime.__toESM(react);
12
+ let react_jsx_runtime = require("react/jsx-runtime");
13
+ react_jsx_runtime = require_rolldown_runtime.__toESM(react_jsx_runtime);
14
+
15
+ //#region src/Combobox.tsx
16
+ const DEFAULT_OPTIONS = [];
17
+ const Combobox = (props) => {
18
+ const { value = "", onChange, options = DEFAULT_OPTIONS, placeholder = "Select option...", searchPlaceholder = "Search...", emptyText = "No option found.",...commandProps } = props;
19
+ const [open, setOpen] = (0, react.useState)(false);
20
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(__pixpilot_shadcn.Popover, {
21
+ open,
22
+ onOpenChange: setOpen,
23
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.PopoverTrigger, {
24
+ asChild: true,
25
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(__pixpilot_shadcn.Button, {
26
+ variant: "outline",
27
+ role: "combobox",
28
+ "aria-expanded": open,
29
+ className: "w-full justify-between",
30
+ children: [value ? options.find((option) => option.value === value)?.label : placeholder, /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.ChevronsUpDown, { className: "ml-2 h-4 w-4 shrink-0 opacity-50" })]
31
+ })
32
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.PopoverContent, {
33
+ className: "w-full p-0",
34
+ style: { width: "var(--radix-popover-trigger-width)" },
35
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(__pixpilot_shadcn.Command, {
36
+ ...commandProps,
37
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.CommandInput, { placeholder: searchPlaceholder }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_CommandOptionList.CommandOptionList, {
38
+ options,
39
+ value,
40
+ onChange: (val) => {
41
+ onChange?.(val);
42
+ setOpen(false);
43
+ },
44
+ emptyText
45
+ })]
46
+ })
47
+ })]
48
+ });
49
+ };
50
+ Combobox.displayName = "Combobox";
51
+
52
+ //#endregion
53
+ exports.Combobox = Combobox;
package/dist/Combobox.js CHANGED
@@ -1 +1,48 @@
1
- "use client";import{CommandOptionList as e}from"./CommandOptionList.js";import{Button as t,Command as n,CommandInput as r,Popover as i,PopoverContent as a,PopoverTrigger as o}from"@pixpilot/shadcn";import{ChevronsUpDown as s}from"lucide-react";import c,{useState as l}from"react";import{jsx as u,jsxs as d}from"react/jsx-runtime";const f=[],p=c=>{let{value:p=``,onChange:m,options:h=f,placeholder:g=`Select option...`,searchPlaceholder:_=`Search...`,emptyText:v=`No option found.`,...y}=c,[b,x]=l(!1);return d(i,{open:b,onOpenChange:x,children:[u(o,{asChild:!0,children:d(t,{variant:`outline`,role:`combobox`,"aria-expanded":b,className:`w-full justify-between`,children:[p?h.find(e=>e.value===p)?.label:g,u(s,{className:`ml-2 h-4 w-4 shrink-0 opacity-50`})]})}),u(a,{className:`w-full p-0`,style:{width:`var(--radix-popover-trigger-width)`},children:d(n,{...y,children:[u(r,{placeholder:_}),u(e,{options:h,value:p,onChange:e=>{m?.(e),x(!1)},emptyText:v})]})})]})};p.displayName=`Combobox`;export{p as Combobox};
1
+ 'use client';
2
+
3
+
4
+ import { CommandOptionList } from "./CommandOptionList.js";
5
+ import { Button, Command, CommandInput, Popover, PopoverContent, PopoverTrigger } from "@pixpilot/shadcn";
6
+ import { ChevronsUpDown } from "lucide-react";
7
+ import React, { useState } from "react";
8
+ import { jsx, jsxs } from "react/jsx-runtime";
9
+
10
+ //#region src/Combobox.tsx
11
+ const DEFAULT_OPTIONS = [];
12
+ const Combobox = (props) => {
13
+ const { value = "", onChange, options = DEFAULT_OPTIONS, placeholder = "Select option...", searchPlaceholder = "Search...", emptyText = "No option found.",...commandProps } = props;
14
+ const [open, setOpen] = useState(false);
15
+ return /* @__PURE__ */ jsxs(Popover, {
16
+ open,
17
+ onOpenChange: setOpen,
18
+ children: [/* @__PURE__ */ jsx(PopoverTrigger, {
19
+ asChild: true,
20
+ children: /* @__PURE__ */ jsxs(Button, {
21
+ variant: "outline",
22
+ role: "combobox",
23
+ "aria-expanded": open,
24
+ className: "w-full justify-between",
25
+ children: [value ? options.find((option) => option.value === value)?.label : placeholder, /* @__PURE__ */ jsx(ChevronsUpDown, { className: "ml-2 h-4 w-4 shrink-0 opacity-50" })]
26
+ })
27
+ }), /* @__PURE__ */ jsx(PopoverContent, {
28
+ className: "w-full p-0",
29
+ style: { width: "var(--radix-popover-trigger-width)" },
30
+ children: /* @__PURE__ */ jsxs(Command, {
31
+ ...commandProps,
32
+ children: [/* @__PURE__ */ jsx(CommandInput, { placeholder: searchPlaceholder }), /* @__PURE__ */ jsx(CommandOptionList, {
33
+ options,
34
+ value,
35
+ onChange: (val) => {
36
+ onChange?.(val);
37
+ setOpen(false);
38
+ },
39
+ emptyText
40
+ })]
41
+ })
42
+ })]
43
+ });
44
+ };
45
+ Combobox.displayName = "Combobox";
46
+
47
+ //#endregion
48
+ export { Combobox };
@@ -1 +1,29 @@
1
- "use client";const e=require(`./_virtual/rolldown_runtime.cjs`);let t=require(`@pixpilot/shadcn`);t=e.__toESM(t);let n=require(`lucide-react`);n=e.__toESM(n);let r=require(`react/jsx-runtime`);r=e.__toESM(r);const i=e=>{let{options:i,value:a,onChange:o,emptyText:s=`No option found.`}=e;return(0,r.jsxs)(t.CommandList,{children:[(0,r.jsx)(t.CommandEmpty,{children:s}),(0,r.jsx)(t.CommandGroup,{children:i.map(e=>(0,r.jsx)(t.CommandItem,{value:e.value,onSelect:e=>{o?.(e===a?``:e)},children:(0,r.jsxs)(`div`,{className:`w-full flex items-center justify-between`,children:[e.label,(0,r.jsx)(n.Check,{className:(0,t.cn)(`mr-2 h-4 w-4`,a===e.value?`opacity-100`:`opacity-0`)})]})},e.value))})]})};i.displayName=`CommandOptionList`,exports.CommandOptionList=i;
1
+ 'use client';
2
+
3
+
4
+ const require_rolldown_runtime = require('./_virtual/rolldown_runtime.cjs');
5
+ let __pixpilot_shadcn = require("@pixpilot/shadcn");
6
+ __pixpilot_shadcn = require_rolldown_runtime.__toESM(__pixpilot_shadcn);
7
+ let lucide_react = require("lucide-react");
8
+ lucide_react = require_rolldown_runtime.__toESM(lucide_react);
9
+ let react_jsx_runtime = require("react/jsx-runtime");
10
+ react_jsx_runtime = require_rolldown_runtime.__toESM(react_jsx_runtime);
11
+
12
+ //#region src/CommandOptionList.tsx
13
+ const CommandOptionList = (props) => {
14
+ const { options, value, onChange, emptyText = "No option found." } = props;
15
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(__pixpilot_shadcn.CommandList, { children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.CommandEmpty, { children: emptyText }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.CommandGroup, { children: options.map((option) => /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__pixpilot_shadcn.CommandItem, {
16
+ value: option.value,
17
+ onSelect: (currentValue) => {
18
+ onChange?.(currentValue === value ? "" : currentValue);
19
+ },
20
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
21
+ className: "w-full flex items-center justify-between",
22
+ children: [option.label, /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.Check, { className: (0, __pixpilot_shadcn.cn)("mr-2 h-4 w-4", value === option.value ? "opacity-100" : "opacity-0") })]
23
+ })
24
+ }, option.value)) })] });
25
+ };
26
+ CommandOptionList.displayName = "CommandOptionList";
27
+
28
+ //#endregion
29
+ exports.CommandOptionList = CommandOptionList;