@placeholderco/placeholder-ui 1.0.3 → 1.0.6

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 (136) hide show
  1. package/LICENSE +26 -26
  2. package/README.md +179 -179
  3. package/dist/display/Alert.svelte +179 -179
  4. package/dist/display/Avatar.svelte +166 -166
  5. package/dist/display/LinkCollection.svelte +161 -161
  6. package/dist/display/Paper.svelte +118 -118
  7. package/dist/form/Autocomplete.svelte +223 -191
  8. package/dist/form/Autocomplete.svelte.d.ts +3 -1
  9. package/dist/form/AutocompleteMulti.svelte +356 -0
  10. package/dist/form/AutocompleteMulti.svelte.d.ts +28 -0
  11. package/dist/form/Checkbox.svelte +201 -201
  12. package/dist/form/Chips.svelte +128 -128
  13. package/dist/form/ComboBox.svelte +158 -158
  14. package/dist/form/ComboBox.svelte.d.ts +1 -1
  15. package/dist/form/ComboBoxItemBuilder.svelte +460 -460
  16. package/dist/form/ComboBoxMulti.svelte +197 -197
  17. package/dist/form/ComboBoxMulti.svelte.d.ts +1 -1
  18. package/dist/form/CronBuilder.svelte +693 -693
  19. package/dist/form/DatePicker.svelte +672 -672
  20. package/dist/form/DateTimePicker.svelte +712 -712
  21. package/dist/form/FileInput.svelte +235 -235
  22. package/dist/form/FormGroup.svelte +68 -68
  23. package/dist/form/Number.svelte +238 -238
  24. package/dist/form/PasswordInput.svelte +252 -252
  25. package/dist/form/RadioGroup.svelte +210 -210
  26. package/dist/form/Rating.svelte +235 -235
  27. package/dist/form/SegmentedControl.svelte +149 -149
  28. package/dist/form/Select.svelte +590 -590
  29. package/dist/form/Select.svelte.d.ts +1 -1
  30. package/dist/form/SelectMulti.svelte +613 -613
  31. package/dist/form/SelectMulti.svelte.d.ts +1 -1
  32. package/dist/form/Slider.svelte +358 -358
  33. package/dist/form/Switch.svelte +147 -147
  34. package/dist/form/TextArea.svelte +148 -148
  35. package/dist/form/Textbox.svelte +228 -228
  36. package/dist/form/TimePicker.svelte +267 -267
  37. package/dist/icon/Icon.svelte +52 -52
  38. package/dist/icon/alert-octagon.svg +5 -5
  39. package/dist/icon/alert-triangle.svg +5 -5
  40. package/dist/icon/archive.svg +1 -1
  41. package/dist/icon/arrow-down.svg +1 -1
  42. package/dist/icon/arrow-left.svg +1 -1
  43. package/dist/icon/arrow-right.svg +1 -1
  44. package/dist/icon/arrow-up.svg +1 -1
  45. package/dist/icon/at.svg +1 -1
  46. package/dist/icon/bell.svg +1 -1
  47. package/dist/icon/bookmark.svg +1 -1
  48. package/dist/icon/calendar.svg +1 -1
  49. package/dist/icon/camera.svg +1 -1
  50. package/dist/icon/chart-bar.svg +1 -1
  51. package/dist/icon/chart-line.svg +1 -1
  52. package/dist/icon/chart-pie.svg +1 -1
  53. package/dist/icon/checkbox.svg +1 -1
  54. package/dist/icon/checklist.svg +1 -1
  55. package/dist/icon/circle-check.svg +1 -1
  56. package/dist/icon/circle-x.svg +1 -1
  57. package/dist/icon/clock.svg +1 -1
  58. package/dist/icon/credit-card.svg +1 -1
  59. package/dist/icon/dots-vertical.svg +1 -1
  60. package/dist/icon/dots.svg +1 -1
  61. package/dist/icon/external-link.svg +1 -1
  62. package/dist/icon/eye-off.svg +1 -1
  63. package/dist/icon/eye.svg +1 -1
  64. package/dist/icon/filter.svg +1 -1
  65. package/dist/icon/fingerprint.svg +1 -1
  66. package/dist/icon/flag.svg +1 -1
  67. package/dist/icon/heart.svg +1 -1
  68. package/dist/icon/home.svg +1 -1
  69. package/dist/icon/key.svg +1 -1
  70. package/dist/icon/list-check.svg +1 -1
  71. package/dist/icon/login.svg +1 -1
  72. package/dist/icon/logout.svg +1 -1
  73. package/dist/icon/map-pin.svg +1 -1
  74. package/dist/icon/maximize.svg +1 -1
  75. package/dist/icon/microphone.svg +1 -1
  76. package/dist/icon/minimize.svg +1 -1
  77. package/dist/icon/note.svg +1 -1
  78. package/dist/icon/player-pause.svg +1 -1
  79. package/dist/icon/printer.svg +1 -1
  80. package/dist/icon/qrcode.svg +1 -1
  81. package/dist/icon/send.svg +1 -1
  82. package/dist/icon/settings.svg +1 -1
  83. package/dist/icon/share.svg +1 -1
  84. package/dist/icon/shopping-cart.svg +1 -1
  85. package/dist/icon/sort-ascending.svg +1 -1
  86. package/dist/icon/sort-descending.svg +1 -1
  87. package/dist/icon/star.svg +1 -1
  88. package/dist/icon/tag.svg +1 -1
  89. package/dist/icon/trending-down.svg +1 -1
  90. package/dist/icon/trending-up.svg +1 -1
  91. package/dist/icon/upload.svg +1 -1
  92. package/dist/icon/volume-off.svg +1 -1
  93. package/dist/icon/volume.svg +1 -1
  94. package/dist/icon/world.svg +1 -1
  95. package/dist/icon/zoom-in.svg +1 -1
  96. package/dist/icon/zoom-out.svg +1 -1
  97. package/dist/index.d.ts +1 -0
  98. package/dist/index.js +1 -0
  99. package/dist/layout/AppShell.svelte +169 -169
  100. package/dist/layout/CustomNavbar.svelte +61 -61
  101. package/dist/layout/Navbar.svelte +206 -206
  102. package/dist/layout/NavbarItemDisplay.svelte +29 -29
  103. package/dist/layout/Sidenav.svelte +712 -712
  104. package/dist/styles/components.css +199 -199
  105. package/dist/styles/dark.css +146 -146
  106. package/dist/styles/index.css +116 -116
  107. package/dist/styles/reset.css +110 -110
  108. package/dist/styles/semantic.css +86 -86
  109. package/dist/styles/tokens.css +203 -197
  110. package/dist/styles/utilities.css +523 -523
  111. package/dist/ui/Accordion.svelte +289 -289
  112. package/dist/ui/ActionIcon.svelte +76 -76
  113. package/dist/ui/Badge.svelte +329 -279
  114. package/dist/ui/Breadcrumbs.svelte +131 -131
  115. package/dist/ui/Button.svelte +432 -370
  116. package/dist/ui/ButtonVariant.d.ts +1 -1
  117. package/dist/ui/Dialog.svelte +307 -307
  118. package/dist/ui/Drawer.svelte +524 -524
  119. package/dist/ui/Dropdown.svelte +97 -97
  120. package/dist/ui/Dropzone.svelte +122 -122
  121. package/dist/ui/Link.svelte +32 -32
  122. package/dist/ui/Loader.svelte +70 -70
  123. package/dist/ui/LoadingOverlay.svelte +53 -53
  124. package/dist/ui/Pagination.svelte +135 -135
  125. package/dist/ui/Popover.svelte +225 -225
  126. package/dist/ui/Progress.svelte +191 -191
  127. package/dist/ui/RingProgress.svelte +141 -141
  128. package/dist/ui/Skeleton.svelte +85 -85
  129. package/dist/ui/Stepper.svelte +355 -355
  130. package/dist/ui/Table.svelte +345 -345
  131. package/dist/ui/Tabs.svelte +146 -146
  132. package/dist/ui/ThemeSwitcher.svelte +39 -39
  133. package/dist/ui/Timeline.svelte +225 -225
  134. package/dist/ui/Toaster.svelte +6 -6
  135. package/dist/ui/Tooltip.svelte +434 -434
  136. package/package.json +14 -14
@@ -1,225 +1,225 @@
1
- <script lang="ts">
2
- import type { Snippet } from 'svelte';
3
- import Icon from '../icon/Icon.svelte';
4
-
5
- interface TimelineItem {
6
- title: string;
7
- description?: string;
8
- date?: string;
9
- icon?: string;
10
- color?: 'primary' | 'secondary' | 'accent' | 'success' | 'warning' | 'danger' | 'gray';
11
- }
12
-
13
- interface Props {
14
- items?: TimelineItem[];
15
- active?: number;
16
- bulletSize?: number;
17
- lineWidth?: number;
18
- align?: 'left' | 'right';
19
- reverseActive?: boolean;
20
- color?: 'primary' | 'secondary' | 'accent' | 'success' | 'warning' | 'danger' | 'gray';
21
- class?: string;
22
- itemContent?: Snippet<[TimelineItem, number]>;
23
- children?: Snippet;
24
- }
25
-
26
- let {
27
- items = [],
28
- active = -1,
29
- bulletSize = 20,
30
- lineWidth = 2,
31
- align = 'left',
32
- reverseActive = false,
33
- color = 'primary',
34
- class: classes = '',
35
- itemContent,
36
- children
37
- }: Props = $props();
38
-
39
- function isActive(index: number): boolean {
40
- if (active < 0) return false;
41
- return reverseActive ? index >= active : index <= active;
42
- }
43
-
44
- function getItemColor(item: TimelineItem, index: number): string {
45
- if (item.color) return item.color;
46
- return isActive(index) ? color : 'gray';
47
- }
48
- </script>
49
-
50
- <div class="timeline align-{align} {classes}" style="--bullet-size: {bulletSize}px; --line-width: {lineWidth}px;">
51
- {#if children}
52
- {@render children()}
53
- {:else}
54
- {#each items as item, index (index)}
55
- {@const itemColor = getItemColor(item, index)}
56
- {@const itemActive = isActive(index)}
57
- <div class="timeline-item color-{itemColor}" class:active={itemActive}>
58
- <div class="timeline-bullet-wrapper">
59
- <div class="timeline-bullet">
60
- {#if item.icon}
61
- <Icon svg={item.icon} size="{bulletSize * 0.6}px" />
62
- {/if}
63
- </div>
64
- {#if index < items.length - 1}
65
- <div class="timeline-line" class:active={isActive(index + 1)}></div>
66
- {/if}
67
- </div>
68
- <div class="timeline-content">
69
- {#if itemContent}
70
- {@render itemContent(item, index)}
71
- {:else}
72
- <div class="timeline-header">
73
- <div class="timeline-title">{item.title}</div>
74
- {#if item.date}
75
- <div class="timeline-date">{item.date}</div>
76
- {/if}
77
- </div>
78
- {#if item.description}
79
- <div class="timeline-description">{item.description}</div>
80
- {/if}
81
- {/if}
82
- </div>
83
- </div>
84
- {/each}
85
- {/if}
86
- </div>
87
-
88
- <style>
89
- .timeline {
90
- display: flex;
91
- flex-direction: column;
92
- position: relative;
93
- }
94
-
95
- .timeline-item {
96
- display: flex;
97
- position: relative;
98
- }
99
-
100
- .align-right .timeline-item {
101
- flex-direction: row-reverse;
102
- }
103
-
104
- .timeline-bullet-wrapper {
105
- display: flex;
106
- flex-direction: column;
107
- align-items: center;
108
- position: relative;
109
- flex-shrink: 0;
110
- }
111
-
112
- .timeline-bullet {
113
- width: var(--bullet-size);
114
- height: var(--bullet-size);
115
- border-radius: 50%;
116
- display: flex;
117
- align-items: center;
118
- justify-content: center;
119
- background-color: var(--pui-color-gray-200);
120
- border: var(--line-width) solid var(--bullet-color, var(--pui-color-gray-400));
121
- color: var(--bullet-color, var(--pui-color-gray-400));
122
- z-index: 1;
123
- transition: all var(--pui-transition-fast) var(--pui-ease-in-out);
124
- }
125
-
126
- :global(.dark) .timeline-bullet {
127
- background-color: var(--pui-color-dark-200);
128
- }
129
-
130
- .timeline-item.active .timeline-bullet {
131
- background-color: var(--bullet-color, var(--pui-color-primary));
132
- color: var(--pui-color-white);
133
- }
134
-
135
- .timeline-line {
136
- position: absolute;
137
- top: var(--bullet-size);
138
- width: var(--line-width);
139
- height: calc(100% - var(--bullet-size) + var(--pui-spacing-4));
140
- background-color: var(--pui-color-gray-300);
141
- transition: background-color var(--pui-transition-fast) var(--pui-ease-in-out);
142
- }
143
-
144
- :global(.dark) .timeline-line {
145
- background-color: var(--pui-color-dark-border);
146
- }
147
-
148
- .timeline-line.active {
149
- background-color: var(--bullet-color, var(--pui-color-primary));
150
- }
151
-
152
- .timeline-content {
153
- flex: 1;
154
- padding-bottom: var(--pui-spacing-6);
155
- }
156
-
157
- .align-left .timeline-content {
158
- padding-left: var(--pui-spacing-4);
159
- }
160
-
161
- .align-right .timeline-content {
162
- padding-right: var(--pui-spacing-4);
163
- text-align: right;
164
- }
165
-
166
- .timeline-header {
167
- display: flex;
168
- align-items: baseline;
169
- gap: var(--pui-spacing-2);
170
- flex-wrap: wrap;
171
- }
172
-
173
- .align-right .timeline-header {
174
- flex-direction: row-reverse;
175
- }
176
-
177
- .timeline-title {
178
- font-weight: var(--pui-font-weight-semibold);
179
- color: var(--pui-color-gray-900);
180
- font-size: var(--pui-font-size-base);
181
- }
182
-
183
- :global(.dark) .timeline-title {
184
- color: var(--pui-color-gray-100);
185
- }
186
-
187
- .timeline-date {
188
- font-size: var(--pui-font-size-xs);
189
- color: var(--pui-color-gray-500);
190
- }
191
-
192
- .timeline-description {
193
- margin-top: var(--pui-spacing-1);
194
- font-size: var(--pui-font-size-sm);
195
- color: var(--pui-color-gray-600);
196
- line-height: var(--pui-line-height-relaxed);
197
- }
198
-
199
- :global(.dark) .timeline-description {
200
- color: var(--pui-color-gray-400);
201
- }
202
-
203
- /* Colors */
204
- .color-primary {
205
- --bullet-color: var(--pui-color-primary);
206
- }
207
- .color-secondary {
208
- --bullet-color: var(--pui-color-secondary);
209
- }
210
- .color-accent {
211
- --bullet-color: var(--pui-color-accent);
212
- }
213
- .color-success {
214
- --bullet-color: var(--pui-color-success);
215
- }
216
- .color-warning {
217
- --bullet-color: var(--pui-color-warning);
218
- }
219
- .color-danger {
220
- --bullet-color: var(--pui-color-danger);
221
- }
222
- .color-gray {
223
- --bullet-color: var(--pui-color-gray-400);
224
- }
225
- </style>
1
+ <script lang="ts">
2
+ import type { Snippet } from 'svelte';
3
+ import Icon from '../icon/Icon.svelte';
4
+
5
+ interface TimelineItem {
6
+ title: string;
7
+ description?: string;
8
+ date?: string;
9
+ icon?: string;
10
+ color?: 'primary' | 'secondary' | 'accent' | 'success' | 'warning' | 'danger' | 'gray';
11
+ }
12
+
13
+ interface Props {
14
+ items?: TimelineItem[];
15
+ active?: number;
16
+ bulletSize?: number;
17
+ lineWidth?: number;
18
+ align?: 'left' | 'right';
19
+ reverseActive?: boolean;
20
+ color?: 'primary' | 'secondary' | 'accent' | 'success' | 'warning' | 'danger' | 'gray';
21
+ class?: string;
22
+ itemContent?: Snippet<[TimelineItem, number]>;
23
+ children?: Snippet;
24
+ }
25
+
26
+ let {
27
+ items = [],
28
+ active = -1,
29
+ bulletSize = 20,
30
+ lineWidth = 2,
31
+ align = 'left',
32
+ reverseActive = false,
33
+ color = 'primary',
34
+ class: classes = '',
35
+ itemContent,
36
+ children
37
+ }: Props = $props();
38
+
39
+ function isActive(index: number): boolean {
40
+ if (active < 0) return false;
41
+ return reverseActive ? index >= active : index <= active;
42
+ }
43
+
44
+ function getItemColor(item: TimelineItem, index: number): string {
45
+ if (item.color) return item.color;
46
+ return isActive(index) ? color : 'gray';
47
+ }
48
+ </script>
49
+
50
+ <div class="timeline align-{align} {classes}" style="--bullet-size: {bulletSize}px; --line-width: {lineWidth}px;">
51
+ {#if children}
52
+ {@render children()}
53
+ {:else}
54
+ {#each items as item, index (index)}
55
+ {@const itemColor = getItemColor(item, index)}
56
+ {@const itemActive = isActive(index)}
57
+ <div class="timeline-item color-{itemColor}" class:active={itemActive}>
58
+ <div class="timeline-bullet-wrapper">
59
+ <div class="timeline-bullet">
60
+ {#if item.icon}
61
+ <Icon svg={item.icon} size="{bulletSize * 0.6}px" />
62
+ {/if}
63
+ </div>
64
+ {#if index < items.length - 1}
65
+ <div class="timeline-line" class:active={isActive(index + 1)}></div>
66
+ {/if}
67
+ </div>
68
+ <div class="timeline-content">
69
+ {#if itemContent}
70
+ {@render itemContent(item, index)}
71
+ {:else}
72
+ <div class="timeline-header">
73
+ <div class="timeline-title">{item.title}</div>
74
+ {#if item.date}
75
+ <div class="timeline-date">{item.date}</div>
76
+ {/if}
77
+ </div>
78
+ {#if item.description}
79
+ <div class="timeline-description">{item.description}</div>
80
+ {/if}
81
+ {/if}
82
+ </div>
83
+ </div>
84
+ {/each}
85
+ {/if}
86
+ </div>
87
+
88
+ <style>
89
+ .timeline {
90
+ display: flex;
91
+ flex-direction: column;
92
+ position: relative;
93
+ }
94
+
95
+ .timeline-item {
96
+ display: flex;
97
+ position: relative;
98
+ }
99
+
100
+ .align-right .timeline-item {
101
+ flex-direction: row-reverse;
102
+ }
103
+
104
+ .timeline-bullet-wrapper {
105
+ display: flex;
106
+ flex-direction: column;
107
+ align-items: center;
108
+ position: relative;
109
+ flex-shrink: 0;
110
+ }
111
+
112
+ .timeline-bullet {
113
+ width: var(--bullet-size);
114
+ height: var(--bullet-size);
115
+ border-radius: 50%;
116
+ display: flex;
117
+ align-items: center;
118
+ justify-content: center;
119
+ background-color: var(--pui-color-gray-200);
120
+ border: var(--line-width) solid var(--bullet-color, var(--pui-color-gray-400));
121
+ color: var(--bullet-color, var(--pui-color-gray-400));
122
+ z-index: 1;
123
+ transition: all var(--pui-transition-fast) var(--pui-ease-in-out);
124
+ }
125
+
126
+ :global(.dark) .timeline-bullet {
127
+ background-color: var(--pui-color-dark-200);
128
+ }
129
+
130
+ .timeline-item.active .timeline-bullet {
131
+ background-color: var(--bullet-color, var(--pui-color-primary));
132
+ color: var(--pui-color-white);
133
+ }
134
+
135
+ .timeline-line {
136
+ position: absolute;
137
+ top: var(--bullet-size);
138
+ width: var(--line-width);
139
+ height: calc(100% - var(--bullet-size) + var(--pui-spacing-4));
140
+ background-color: var(--pui-color-gray-300);
141
+ transition: background-color var(--pui-transition-fast) var(--pui-ease-in-out);
142
+ }
143
+
144
+ :global(.dark) .timeline-line {
145
+ background-color: var(--pui-color-dark-border);
146
+ }
147
+
148
+ .timeline-line.active {
149
+ background-color: var(--bullet-color, var(--pui-color-primary));
150
+ }
151
+
152
+ .timeline-content {
153
+ flex: 1;
154
+ padding-bottom: var(--pui-spacing-6);
155
+ }
156
+
157
+ .align-left .timeline-content {
158
+ padding-left: var(--pui-spacing-4);
159
+ }
160
+
161
+ .align-right .timeline-content {
162
+ padding-right: var(--pui-spacing-4);
163
+ text-align: right;
164
+ }
165
+
166
+ .timeline-header {
167
+ display: flex;
168
+ align-items: baseline;
169
+ gap: var(--pui-spacing-2);
170
+ flex-wrap: wrap;
171
+ }
172
+
173
+ .align-right .timeline-header {
174
+ flex-direction: row-reverse;
175
+ }
176
+
177
+ .timeline-title {
178
+ font-weight: var(--pui-font-weight-semibold);
179
+ color: var(--pui-color-gray-900);
180
+ font-size: var(--pui-font-size-base);
181
+ }
182
+
183
+ :global(.dark) .timeline-title {
184
+ color: var(--pui-color-gray-100);
185
+ }
186
+
187
+ .timeline-date {
188
+ font-size: var(--pui-font-size-xs);
189
+ color: var(--pui-color-gray-500);
190
+ }
191
+
192
+ .timeline-description {
193
+ margin-top: var(--pui-spacing-1);
194
+ font-size: var(--pui-font-size-sm);
195
+ color: var(--pui-color-gray-600);
196
+ line-height: var(--pui-line-height-relaxed);
197
+ }
198
+
199
+ :global(.dark) .timeline-description {
200
+ color: var(--pui-color-gray-400);
201
+ }
202
+
203
+ /* Colors */
204
+ .color-primary {
205
+ --bullet-color: var(--pui-color-primary);
206
+ }
207
+ .color-secondary {
208
+ --bullet-color: var(--pui-color-secondary);
209
+ }
210
+ .color-accent {
211
+ --bullet-color: var(--pui-color-accent);
212
+ }
213
+ .color-success {
214
+ --bullet-color: var(--pui-color-success);
215
+ }
216
+ .color-warning {
217
+ --bullet-color: var(--pui-color-warning);
218
+ }
219
+ .color-danger {
220
+ --bullet-color: var(--pui-color-danger);
221
+ }
222
+ .color-gray {
223
+ --bullet-color: var(--pui-color-gray-400);
224
+ }
225
+ </style>
@@ -1,6 +1,6 @@
1
- <script lang="ts">
2
- import { themeState } from '../theme.svelte.js';
3
- import { Toaster } from 'svelte-sonner';
4
- </script>
5
-
6
- <Toaster theme={themeState.isDarkMode ? 'dark' : 'light'} richColors />
1
+ <script lang="ts">
2
+ import { themeState } from '../theme.svelte.js';
3
+ import { Toaster } from 'svelte-sonner';
4
+ </script>
5
+
6
+ <Toaster theme={themeState.isDarkMode ? 'dark' : 'light'} richColors />