@profidev/pleiades 1.7.1 → 1.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (104) hide show
  1. package/dist/components/form/form-dialog.svelte +1 -1
  2. package/dist/components/table/multiselect.svelte +2 -2
  3. package/dist/components/ui/command/command-input.svelte +6 -3
  4. package/dist/components/ui/field/field-label.svelte +1 -1
  5. package/dist/components/ui/field/field-title.svelte +1 -1
  6. package/dist/components/ui/native-select/native-select-option.svelte +8 -2
  7. package/dist/components/ui/native-select/native-select-option.svelte.d.ts +1 -1
  8. package/dist/components/ui/pagination/pagination-next.svelte +15 -9
  9. package/dist/components/ui/pagination/pagination-next.svelte.d.ts +2 -13
  10. package/dist/components/ui/pagination/pagination-previous.svelte +15 -9
  11. package/dist/components/ui/pagination/pagination-previous.svelte.d.ts +2 -13
  12. package/dist/components/ui/sidebar/constants.d.ts +1 -1
  13. package/dist/components/ui/sidebar/constants.js +1 -1
  14. package/dist/components/ui/slider/slider.svelte +1 -1
  15. package/dist/components/ui/tooltip/tooltip.svelte +1 -4
  16. package/dist/components/ui-extra/alert-dialog/alert-dialog-action.svelte +40 -0
  17. package/dist/components/ui-extra/alert-dialog/alert-dialog-action.svelte.d.ts +10 -0
  18. package/dist/components/ui-extra/alert-dialog/alert-dialog-cancel.svelte +31 -0
  19. package/dist/components/ui-extra/alert-dialog/alert-dialog-cancel.svelte.d.ts +9 -0
  20. package/dist/components/ui-extra/alert-dialog/alert-dialog-content.svelte +38 -0
  21. package/dist/components/ui-extra/alert-dialog/alert-dialog-content.svelte.d.ts +11 -0
  22. package/dist/components/ui-extra/alert-dialog/alert-dialog-description.svelte +20 -0
  23. package/dist/components/ui-extra/alert-dialog/alert-dialog-description.svelte.d.ts +4 -0
  24. package/dist/components/ui-extra/alert-dialog/alert-dialog-footer.svelte +23 -0
  25. package/dist/components/ui-extra/alert-dialog/alert-dialog-footer.svelte.d.ts +5 -0
  26. package/dist/components/ui-extra/alert-dialog/alert-dialog-header.svelte +23 -0
  27. package/dist/components/ui-extra/alert-dialog/alert-dialog-header.svelte.d.ts +5 -0
  28. package/dist/components/ui-extra/alert-dialog/alert-dialog-media.svelte +23 -0
  29. package/dist/components/ui-extra/alert-dialog/alert-dialog-media.svelte.d.ts +5 -0
  30. package/dist/components/ui-extra/alert-dialog/alert-dialog-overlay.svelte +20 -0
  31. package/dist/components/ui-extra/alert-dialog/alert-dialog-overlay.svelte.d.ts +4 -0
  32. package/dist/components/ui-extra/alert-dialog/alert-dialog-portal.svelte +7 -0
  33. package/dist/components/ui-extra/alert-dialog/alert-dialog-portal.svelte.d.ts +3 -0
  34. package/dist/components/ui-extra/alert-dialog/alert-dialog-title.svelte +20 -0
  35. package/dist/components/ui-extra/alert-dialog/alert-dialog-title.svelte.d.ts +4 -0
  36. package/dist/components/ui-extra/alert-dialog/alert-dialog-trigger.svelte +14 -0
  37. package/dist/components/ui-extra/alert-dialog/alert-dialog-trigger.svelte.d.ts +4 -0
  38. package/dist/components/ui-extra/alert-dialog/alert-dialog.svelte +10 -0
  39. package/dist/components/ui-extra/alert-dialog/alert-dialog.svelte.d.ts +3 -0
  40. package/dist/components/ui-extra/alert-dialog/index.d.ts +13 -0
  41. package/dist/components/ui-extra/alert-dialog/index.js +15 -0
  42. package/dist/components/ui-extra/button-group/button-group-separator.svelte +23 -0
  43. package/dist/components/ui-extra/button-group/button-group-separator.svelte.d.ts +13 -0
  44. package/dist/components/ui-extra/button-group/button-group-text.svelte +31 -0
  45. package/dist/components/ui-extra/button-group/button-group-text.svelte.d.ts +11 -0
  46. package/dist/components/ui-extra/button-group/button-group.svelte +48 -0
  47. package/dist/components/ui-extra/button-group/button-group.svelte.d.ts +26 -0
  48. package/dist/components/ui-extra/button-group/index.d.ts +4 -0
  49. package/dist/components/ui-extra/button-group/index.js +6 -0
  50. package/dist/components/ui-extra/confirm-delete-dialog/confirm-delete-dialog.svelte +131 -0
  51. package/dist/components/ui-extra/confirm-delete-dialog/confirm-delete-dialog.svelte.d.ts +35 -0
  52. package/dist/components/ui-extra/confirm-delete-dialog/index.d.ts +2 -0
  53. package/dist/components/ui-extra/confirm-delete-dialog/index.js +2 -0
  54. package/dist/components/ui-extra/copy-button/copy-button.svelte +12 -6
  55. package/dist/components/ui-extra/github-button/github-button.svelte +81 -0
  56. package/dist/components/ui-extra/github-button/github-button.svelte.d.ts +13 -0
  57. package/dist/components/ui-extra/github-button/index.d.ts +20 -0
  58. package/dist/components/ui-extra/github-button/index.js +27 -0
  59. package/dist/components/ui-extra/select/index.d.ts +12 -0
  60. package/dist/components/ui-extra/select/index.js +14 -0
  61. package/dist/components/ui-extra/select/select-content.svelte +45 -0
  62. package/dist/components/ui-extra/select/select-content.svelte.d.ts +11 -0
  63. package/dist/components/ui-extra/select/select-group-heading.svelte +21 -0
  64. package/dist/components/ui-extra/select/select-group-heading.svelte.d.ts +10 -0
  65. package/dist/components/ui-extra/select/select-group.svelte +17 -0
  66. package/dist/components/ui-extra/select/select-group.svelte.d.ts +4 -0
  67. package/dist/components/ui-extra/select/select-item.svelte +38 -0
  68. package/dist/components/ui-extra/select/select-item.svelte.d.ts +4 -0
  69. package/dist/components/ui-extra/select/select-label.svelte +20 -0
  70. package/dist/components/ui-extra/select/select-label.svelte.d.ts +6 -0
  71. package/dist/components/ui-extra/select/select-portal.svelte +7 -0
  72. package/dist/components/ui-extra/select/select-portal.svelte.d.ts +3 -0
  73. package/dist/components/ui-extra/select/select-scroll-down-button.svelte +23 -0
  74. package/dist/components/ui-extra/select/select-scroll-down-button.svelte.d.ts +4 -0
  75. package/dist/components/ui-extra/select/select-scroll-up-button.svelte +23 -0
  76. package/dist/components/ui-extra/select/select-scroll-up-button.svelte.d.ts +4 -0
  77. package/dist/components/ui-extra/select/select-separator.svelte +18 -0
  78. package/dist/components/ui-extra/select/select-separator.svelte.d.ts +4 -0
  79. package/dist/components/ui-extra/select/select-trigger.svelte +29 -0
  80. package/dist/components/ui-extra/select/select-trigger.svelte.d.ts +8 -0
  81. package/dist/components/ui-extra/select/select.svelte +11 -0
  82. package/dist/components/ui-extra/select/select.svelte.d.ts +3 -0
  83. package/dist/components/ui-extra/separator/index.d.ts +2 -0
  84. package/dist/components/ui-extra/separator/index.js +4 -0
  85. package/dist/components/ui-extra/separator/separator.svelte +23 -0
  86. package/dist/components/ui-extra/separator/separator.svelte.d.ts +4 -0
  87. package/dist/components/ui-extra/split-button/index.d.ts +14 -0
  88. package/dist/components/ui-extra/split-button/index.js +9 -0
  89. package/dist/components/ui-extra/split-button/split-button-action.svelte +41 -0
  90. package/dist/components/ui-extra/split-button/split-button-action.svelte.d.ts +9 -0
  91. package/dist/components/ui-extra/split-button/split-button-content.svelte +19 -0
  92. package/dist/components/ui-extra/split-button/split-button-content.svelte.d.ts +6 -0
  93. package/dist/components/ui-extra/split-button/split-button-select-action.svelte +54 -0
  94. package/dist/components/ui-extra/split-button/split-button-select-action.svelte.d.ts +6 -0
  95. package/dist/components/ui-extra/split-button/split-button-select-trigger.svelte +47 -0
  96. package/dist/components/ui-extra/split-button/split-button-select-trigger.svelte.d.ts +10 -0
  97. package/dist/components/ui-extra/split-button/split-button-select.svelte +31 -0
  98. package/dist/components/ui-extra/split-button/split-button-select.svelte.d.ts +6 -0
  99. package/dist/components/ui-extra/split-button/split-button.svelte +53 -0
  100. package/dist/components/ui-extra/split-button/split-button.svelte.d.ts +17 -0
  101. package/dist/components/ui-extra/split-button/split-button.svelte.js +82 -0
  102. package/dist/components/ui-extra/stepper/stepper-indicator.svelte +1 -0
  103. package/dist/components/ui-extra/stepper/stepper-trigger.svelte +1 -1
  104. package/package.json +49 -21
@@ -0,0 +1,53 @@
1
+ <script lang="ts" module>
2
+ import type { ButtonGroupOrientation } from '../button-group';
3
+ import type { HTMLAttributes } from 'svelte/elements';
4
+ import type { WithChildren, WithoutChildren } from 'bits-ui';
5
+ import type { SplitButtonClickEvent } from './split-button.svelte.js';
6
+
7
+ export type SplitButtonPropsWithoutHTML = WithChildren<{
8
+ ref?: HTMLDivElement | null;
9
+ orientation?: ButtonGroupOrientation;
10
+ value?: string;
11
+ disabled?: boolean;
12
+ onclick?: (event: SplitButtonClickEvent) => void;
13
+ onClickPromise?: (event: SplitButtonClickEvent) => Promise<void>;
14
+ onActionSelect?: (value: string) => void;
15
+ }>;
16
+
17
+ export type SplitButtonProps = SplitButtonPropsWithoutHTML &
18
+ WithoutChildren<Omit<HTMLAttributes<HTMLDivElement>, 'onclick'>>;
19
+ </script>
20
+
21
+ <script lang="ts">
22
+ import ButtonGroup from '../button-group/button-group.svelte';
23
+ import { useSplitButtonRoot } from './split-button.svelte.js';
24
+ import { box } from 'svelte-toolbelt';
25
+
26
+ let {
27
+ ref = $bindable(null),
28
+ class: className,
29
+ orientation = 'horizontal',
30
+ value = $bindable(undefined),
31
+ disabled,
32
+ onclick,
33
+ onClickPromise,
34
+ onActionSelect,
35
+ children,
36
+ ...rest
37
+ }: SplitButtonProps = $props();
38
+
39
+ useSplitButtonRoot({
40
+ value: box.with(
41
+ () => value,
42
+ (v) => (value = v)
43
+ ),
44
+ disabled: box.with(() => disabled),
45
+ onclick: box.with(() => onclick),
46
+ onClickPromise: box.with(() => onClickPromise),
47
+ onActionSelect: box.with(() => onActionSelect)
48
+ });
49
+ </script>
50
+
51
+ <ButtonGroup bind:ref class={className} {orientation} {...rest}>
52
+ {@render children?.()}
53
+ </ButtonGroup>
@@ -0,0 +1,17 @@
1
+ import type { ButtonGroupOrientation } from '../button-group';
2
+ import type { HTMLAttributes } from 'svelte/elements';
3
+ import type { WithChildren, WithoutChildren } from 'bits-ui';
4
+ import type { SplitButtonClickEvent } from './split-button.svelte.js';
5
+ export type SplitButtonPropsWithoutHTML = WithChildren<{
6
+ ref?: HTMLDivElement | null;
7
+ orientation?: ButtonGroupOrientation;
8
+ value?: string;
9
+ disabled?: boolean;
10
+ onclick?: (event: SplitButtonClickEvent) => void;
11
+ onClickPromise?: (event: SplitButtonClickEvent) => Promise<void>;
12
+ onActionSelect?: (value: string) => void;
13
+ }>;
14
+ export type SplitButtonProps = SplitButtonPropsWithoutHTML & WithoutChildren<Omit<HTMLAttributes<HTMLDivElement>, 'onclick'>>;
15
+ declare const SplitButton: import("svelte").Component<SplitButtonProps, {}, "value" | "ref">;
16
+ type SplitButton = ReturnType<typeof SplitButton>;
17
+ export default SplitButton;
@@ -0,0 +1,82 @@
1
+ import { Context } from 'runed';
2
+ class SplitButtonRootState {
3
+ opts;
4
+ pending = $state(false);
5
+ constructor(opts) {
6
+ this.opts = opts;
7
+ }
8
+ seed(value) {
9
+ if (this.opts.value.current === undefined) {
10
+ this.opts.value.current = value;
11
+ }
12
+ }
13
+ get action() {
14
+ return this.opts.value.current ?? '';
15
+ }
16
+ set action(value) {
17
+ this.opts.value.current = value;
18
+ }
19
+ get disabled() {
20
+ return this.opts.disabled.current === true || this.pending;
21
+ }
22
+ get loading() {
23
+ return this.pending;
24
+ }
25
+ onSelect(value) {
26
+ this.opts.onActionSelect.current?.(value);
27
+ }
28
+ async onclick(event) {
29
+ const action = this.opts.value.current;
30
+ if (action === undefined)
31
+ return;
32
+ const payload = { action, originalEvent: event };
33
+ this.opts.onclick.current?.(payload);
34
+ const promiseFn = this.opts.onClickPromise.current;
35
+ if (promiseFn) {
36
+ this.pending = true;
37
+ try {
38
+ await promiseFn(payload);
39
+ }
40
+ finally {
41
+ this.pending = false;
42
+ }
43
+ }
44
+ }
45
+ }
46
+ class SplitButtonActionState {
47
+ opts;
48
+ rootState;
49
+ constructor(opts, rootState) {
50
+ this.opts = opts;
51
+ this.rootState = rootState;
52
+ this.rootState.seed(this.opts.value.current);
53
+ }
54
+ isActive = $derived.by(() => this.opts.value.current === this.rootState.opts.value.current);
55
+ onclick(event) {
56
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
57
+ this.opts.onclick.current?.(event);
58
+ this.rootState.onclick(event);
59
+ }
60
+ }
61
+ class SplitButtonSelectActionState {
62
+ opts;
63
+ rootState;
64
+ constructor(opts, rootState) {
65
+ this.opts = opts;
66
+ this.rootState = rootState;
67
+ this.rootState.seed(this.opts.value.current);
68
+ }
69
+ }
70
+ const SplitButtonCtx = new Context('split-button-root');
71
+ export function useSplitButtonRoot(props) {
72
+ return SplitButtonCtx.set(new SplitButtonRootState(props));
73
+ }
74
+ export function useSplitButtonAction(props) {
75
+ return new SplitButtonActionState(props, SplitButtonCtx.get());
76
+ }
77
+ export function useSplitButtonSelectAction(props) {
78
+ return new SplitButtonSelectActionState(props, SplitButtonCtx.get());
79
+ }
80
+ export function useSplitButtonRootCtx() {
81
+ return SplitButtonCtx.get();
82
+ }
@@ -14,6 +14,7 @@
14
14
  class={cn(
15
15
  'bg-primary text-primary-foreground z-1 flex size-7 shrink-0 items-center justify-center rounded-full ring-3 transition-colors select-none [&_svg]:size-4',
16
16
  'group-data-[state=inactive]/stepper-trigger:text-muted-foreground group-data-[state=inactive]/stepper-trigger:bg-muted ring-background',
17
+ 'group-focus-visible/stepper-trigger:ring-ring/50',
17
18
  className
18
19
  )}
19
20
  {...rest}
@@ -26,7 +26,7 @@
26
26
  bind:this={ref}
27
27
  data-slot="stepper-trigger"
28
28
  class={cn(
29
- 'group/stepper-trigger z-1 flex',
29
+ 'group/stepper-trigger z-1 flex outline-none',
30
30
  'group-data-[orientation=horizontal]/stepper-nav:flex-col',
31
31
  'group-data-[orientation=vertical]/stepper-nav:flex-row group-data-[orientation=vertical]/stepper-nav:gap-4',
32
32
  className
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profidev/pleiades",
3
- "version": "1.7.1",
3
+ "version": "1.8.1",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "https://github.com/Profiidev/pleiades"
@@ -226,6 +226,10 @@
226
226
  "types": "./dist/components/table/table-head.svelte.d.ts",
227
227
  "svelte": "./dist/components/table/table-head.svelte"
228
228
  },
229
+ "./components/ui-extra/alert-dialog": {
230
+ "types": "./dist/components/ui-extra/alert-dialog/index.d.ts",
231
+ "svelte": "./dist/components/ui-extra/alert-dialog/index.js"
232
+ },
229
233
  "./components/ui-extra/avatar": {
230
234
  "types": "./dist/components/ui-extra/avatar/index.d.ts",
231
235
  "svelte": "./dist/components/ui-extra/avatar/index.js"
@@ -238,6 +242,10 @@
238
242
  "types": "./dist/components/ui-extra/button/index.d.ts",
239
243
  "svelte": "./dist/components/ui-extra/button/index.js"
240
244
  },
245
+ "./components/ui-extra/button-group": {
246
+ "types": "./dist/components/ui-extra/button-group/index.d.ts",
247
+ "svelte": "./dist/components/ui-extra/button-group/index.js"
248
+ },
241
249
  "./components/ui-extra/chat": {
242
250
  "types": "./dist/components/ui-extra/chat/index.d.ts",
243
251
  "svelte": "./dist/components/ui-extra/chat/index.js"
@@ -250,6 +258,10 @@
250
258
  "types": "./dist/components/ui-extra/command/index.d.ts",
251
259
  "svelte": "./dist/components/ui-extra/command/index.js"
252
260
  },
261
+ "./components/ui-extra/confirm-delete-dialog": {
262
+ "types": "./dist/components/ui-extra/confirm-delete-dialog/index.d.ts",
263
+ "svelte": "./dist/components/ui-extra/confirm-delete-dialog/index.js"
264
+ },
253
265
  "./components/ui-extra/copy-button": {
254
266
  "types": "./dist/components/ui-extra/copy-button/index.d.ts",
255
267
  "svelte": "./dist/components/ui-extra/copy-button/index.js"
@@ -278,6 +290,10 @@
278
290
  "types": "./dist/components/ui-extra/file-drop-zone/index.d.ts",
279
291
  "svelte": "./dist/components/ui-extra/file-drop-zone/index.js"
280
292
  },
293
+ "./components/ui-extra/github-button": {
294
+ "types": "./dist/components/ui-extra/github-button/index.d.ts",
295
+ "svelte": "./dist/components/ui-extra/github-button/index.js"
296
+ },
281
297
  "./components/ui-extra/image-cropper": {
282
298
  "types": "./dist/components/ui-extra/image-cropper/index.d.ts",
283
299
  "svelte": "./dist/components/ui-extra/image-cropper/index.js"
@@ -342,6 +358,14 @@
342
358
  "types": "./dist/components/ui-extra/scroll-area/index.d.ts",
343
359
  "svelte": "./dist/components/ui-extra/scroll-area/index.js"
344
360
  },
361
+ "./components/ui-extra/select": {
362
+ "types": "./dist/components/ui-extra/select/index.d.ts",
363
+ "svelte": "./dist/components/ui-extra/select/index.js"
364
+ },
365
+ "./components/ui-extra/separator": {
366
+ "types": "./dist/components/ui-extra/separator/index.d.ts",
367
+ "svelte": "./dist/components/ui-extra/separator/index.js"
368
+ },
345
369
  "./components/ui-extra/snippet": {
346
370
  "types": "./dist/components/ui-extra/snippet/index.d.ts",
347
371
  "svelte": "./dist/components/ui-extra/snippet/index.js"
@@ -350,6 +374,10 @@
350
374
  "types": "./dist/components/ui-extra/spinner/index.d.ts",
351
375
  "svelte": "./dist/components/ui-extra/spinner/index.js"
352
376
  },
377
+ "./components/ui-extra/split-button": {
378
+ "types": "./dist/components/ui-extra/split-button/index.d.ts",
379
+ "svelte": "./dist/components/ui-extra/split-button/index.js"
380
+ },
353
381
  "./components/ui-extra/star-rating": {
354
382
  "types": "./dist/components/ui-extra/star-rating/index.d.ts",
355
383
  "svelte": "./dist/components/ui-extra/star-rating/index.js"
@@ -723,8 +751,8 @@
723
751
  "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json",
724
752
  "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch",
725
753
  "dev": "vite dev",
726
- "format": "prettier --write .",
727
- "lint": "prettier --check .",
754
+ "format": "oxfmt",
755
+ "lint": "oxfmt --check",
728
756
  "prepack": "svelte-kit sync && svelte-package && publint",
729
757
  "prepare": "svelte-kit sync || echo ''",
730
758
  "preview": "vite preview",
@@ -747,6 +775,7 @@
747
775
  "country-flag-icons": "^1.0.0",
748
776
  "embla-carousel-svelte": "^8.0.0",
749
777
  "formsnap": "^2.0.0",
778
+ "jsencrypt": "^3.0.0",
750
779
  "layerchart": "^2.0.0-next.53",
751
780
  "luxon": "^3.0.0",
752
781
  "mode-watcher": "^1.0.0",
@@ -767,24 +796,23 @@
767
796
  "zod": "^4.0.0"
768
797
  },
769
798
  "devDependencies": {
770
- "@jsrepo/transform-prettier": "^7.0.0",
771
- "@sveltejs/adapter-auto": "^7.0.0",
772
- "@sveltejs/package": "^2.0.0",
773
- "@sveltejs/vite-plugin-svelte": "^7.0.0",
774
- "@tailwindcss/typography": "^0.5.0",
775
- "@types/node": "^25.6.0",
776
- "jsrepo": "^3.0.0",
777
- "oxlint": "^1.60.0",
778
- "oxlint-tsgolint": "^0.21.1",
779
- "prettier": "^3.0.0",
780
- "prettier-plugin-svelte": "^3.0.0",
781
- "prettier-plugin-tailwindcss": "^0.7.0",
782
- "publint": "^0.3.0",
783
- "svelte-check": "^4.0.0",
784
- "tailwindcss": "^4.0.0",
785
- "tw-animate-css": "^1.0.0",
786
- "typescript": "^6.0.0",
787
- "vite": "^8.0.0"
799
+ "@jsrepo/transform-oxfmt": "^7.0.0",
800
+ "@sveltejs/adapter-auto": "7.0.1",
801
+ "@sveltejs/package": "2.5.7",
802
+ "@sveltejs/vite-plugin-svelte": "7.1.2",
803
+ "@tailwindcss/typography": "0.5.19",
804
+ "@types/node": "25.9.1",
805
+ "jsrepo": "3.7.0",
806
+ "oxfmt": "0.51.0",
807
+ "oxlint": "1.66.0",
808
+ "oxlint-tsgolint": "0.23.0",
809
+ "prettier-plugin-svelte": "4.0.1",
810
+ "publint": "0.3.21",
811
+ "svelte-check": "4.4.8",
812
+ "tailwindcss": "4.3.0",
813
+ "tw-animate-css": "1.4.0",
814
+ "typescript": "6.0.3",
815
+ "vite": "8.0.14"
788
816
  },
789
817
  "peerDependencies": {
790
818
  "@sveltejs/kit": "^2.0.0",