@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,210 +1,210 @@
1
- <script lang="ts">
2
- import type { ComboBoxItem } from '../models/ComboBoxItem.js';
3
- import FormGroup from './FormGroup.svelte';
4
-
5
- interface Props {
6
- label: string;
7
- options: ComboBoxItem[];
8
- required?: boolean;
9
- showError?: boolean;
10
- errorText?: string;
11
- class?: string;
12
- containerClass?: string;
13
- disabled?: boolean;
14
- value?: string;
15
- tooltipLocation?: 'top' | 'bottom' | 'left' | 'right';
16
- onchange?: (e: string | undefined) => void;
17
- }
18
-
19
- let {
20
- label,
21
- options,
22
- required = false,
23
- showError = false,
24
- errorText = '',
25
- class: classes = '',
26
- containerClass = '',
27
- disabled = false,
28
- tooltipLocation = 'top',
29
- value = $bindable(),
30
- onchange = undefined
31
- }: Props = $props();
32
-
33
- const nonce = Math.random().toString(36).substring(2, 15);
34
- const randomName = $derived(label + nonce);
35
-
36
- function handleChange(option: ComboBoxItem) {
37
- if (option.value === value) return;
38
-
39
- value = option.value;
40
- onchange?.(value);
41
- }
42
- </script>
43
-
44
- <div class="radio-container {containerClass}">
45
- <FormGroup {label} class={classes} {required} {tooltipLocation}>
46
- <div
47
- class="
48
- radio-options
49
- {required ? 'radio-required' : ''}
50
- {showError ? 'error' : ''}
51
- {disabled ? 'disabled' : ''}"
52
- >
53
- {#each options as option, i}
54
- {@const id = randomName + i}
55
- <div class="flex">
56
- <label class={disabled ? 'cursor-not-allowed' : ''} for={id}>
57
- <input
58
- {id}
59
- type="radio"
60
- class="disabled:cursor-not-allowed accent-accent"
61
- name={randomName}
62
- {disabled}
63
- checked={option.value === value}
64
- onchange={() => handleChange(option)}
65
- />
66
- {option.label}
67
- </label>
68
- </div>
69
- {/each}
70
- </div>
71
- {#if showError && errorText}
72
- <div class="error-text">{errorText}</div>
73
- {/if}
74
- </FormGroup>
75
- </div>
76
-
77
- <style>
78
- label {
79
- display: flex;
80
- flex-direction: row;
81
- align-items: center;
82
- user-select: none;
83
- cursor: pointer;
84
- }
85
-
86
- .disabled label,
87
- .disabled input {
88
- cursor: not-allowed;
89
- }
90
-
91
- input {
92
- position: relative !important;
93
- -webkit-appearance: none;
94
- -moz-appearance: none;
95
- appearance: none;
96
- margin: var(--pui-spacing-2);
97
- box-sizing: content-box;
98
- overflow: hidden;
99
- cursor: pointer;
100
- }
101
-
102
- input:before {
103
- content: '';
104
- display: block;
105
- box-sizing: content-box;
106
- width: 16px;
107
- height: 16px;
108
- border: 2px solid var(--pui-border-disabled);
109
- transition: var(--pui-transition-fast) border-color var(--pui-ease-out);
110
- }
111
-
112
- .radio-options {
113
- display: flex;
114
- gap: var(--pui-spacing-2);
115
- border-radius: var(--pui-radius-lg);
116
- }
117
-
118
- .radio-required {
119
- padding: var(--pui-spacing-1);
120
- }
121
-
122
- :global(.dark) input:before {
123
- border-color: var(--pui-color-gray-600);
124
- }
125
- input:checked:before {
126
- border-color: var(--pui-color-primary);
127
- transition: var(--pui-transition-slow) border-color var(--pui-ease-out);
128
- }
129
- :global(.dark) input:checked:before {
130
- border-color: var(--pui-color-primary);
131
- }
132
-
133
- input:disabled:before {
134
- border-color: var(--pui-border-disabled);
135
- background-color: var(--pui-border-disabled);
136
- opacity: 0.5;
137
- }
138
- :global(.dark) input:disabled:before {
139
- border-color: var(--pui-color-gray-600);
140
- background-color: var(--pui-color-gray-600);
141
- }
142
- input:after {
143
- content: '';
144
- display: block;
145
- position: absolute;
146
- box-sizing: content-box;
147
- top: 50%;
148
- left: 50%;
149
- transform-origin: 50% 50%;
150
- background-color: var(--pui-color-primary);
151
- width: 16px;
152
- height: 16px;
153
- border-radius: var(--pui-radius-full);
154
- transform: translate(-50%, -50%) scale(0);
155
- }
156
- input:disabled:after {
157
- opacity: 0.5;
158
- }
159
- :global(.dark) input:after {
160
- background-color: var(--pui-color-primary);
161
- }
162
- input[type='radio']:before {
163
- border-radius: var(--pui-radius-full);
164
- }
165
- input[type='radio']:after {
166
- width: 16px;
167
- height: 16px;
168
- border-radius: var(--pui-radius-full);
169
- transform: translate(-50%, -50%) scale(0);
170
- }
171
- input[type='radio']:checked:after {
172
- -webkit-animation: toggleOnRadio var(--pui-transition-fast) ease forwards;
173
- animation: toggleOnRadio var(--pui-transition-fast) ease forwards;
174
- }
175
- @-webkit-keyframes toggleOnRadio {
176
- 0% {
177
- opacity: 0;
178
- transform: translate(-50%, -50%) scale(0);
179
- }
180
- 70% {
181
- opacity: 1;
182
- transform: translate(-50%, -50%) scale(0.9);
183
- }
184
- 100% {
185
- transform: translate(-50%, -50%) scale(0.8);
186
- }
187
- }
188
- @keyframes toggleOnRadio {
189
- 0% {
190
- opacity: 0;
191
- transform: translate(-50%, -50%) scale(0);
192
- }
193
- 70% {
194
- opacity: 1;
195
- transform: translate(-50%, -50%) scale(0.9);
196
- }
197
- 100% {
198
- transform: translate(-50%, -50%) scale(0.8);
199
- }
200
- }
201
-
202
- .error {
203
- border: 1px solid var(--pui-text-danger);
204
- }
205
-
206
- .error-text {
207
- margin-top: var(--pui-spacing-1);
208
- color: var(--pui-text-danger);
209
- }
210
- </style>
1
+ <script lang="ts">
2
+ import type { ComboBoxItem } from '../models/ComboBoxItem.js';
3
+ import FormGroup from './FormGroup.svelte';
4
+
5
+ interface Props {
6
+ label: string;
7
+ options: ComboBoxItem[];
8
+ required?: boolean;
9
+ showError?: boolean;
10
+ errorText?: string;
11
+ class?: string;
12
+ containerClass?: string;
13
+ disabled?: boolean;
14
+ value?: string;
15
+ tooltipLocation?: 'top' | 'bottom' | 'left' | 'right';
16
+ onchange?: (e: string | undefined) => void;
17
+ }
18
+
19
+ let {
20
+ label,
21
+ options,
22
+ required = false,
23
+ showError = false,
24
+ errorText = '',
25
+ class: classes = '',
26
+ containerClass = '',
27
+ disabled = false,
28
+ tooltipLocation = 'top',
29
+ value = $bindable(),
30
+ onchange = undefined
31
+ }: Props = $props();
32
+
33
+ const nonce = Math.random().toString(36).substring(2, 15);
34
+ const randomName = $derived(label + nonce);
35
+
36
+ function handleChange(option: ComboBoxItem) {
37
+ if (option.value === value) return;
38
+
39
+ value = option.value;
40
+ onchange?.(value);
41
+ }
42
+ </script>
43
+
44
+ <div class="radio-container {containerClass}">
45
+ <FormGroup {label} class={classes} {required} {tooltipLocation}>
46
+ <div
47
+ class="
48
+ radio-options
49
+ {required ? 'radio-required' : ''}
50
+ {showError ? 'error' : ''}
51
+ {disabled ? 'disabled' : ''}"
52
+ >
53
+ {#each options as option, i}
54
+ {@const id = randomName + i}
55
+ <div class="flex">
56
+ <label class={disabled ? 'cursor-not-allowed' : ''} for={id}>
57
+ <input
58
+ {id}
59
+ type="radio"
60
+ class="disabled:cursor-not-allowed accent-accent"
61
+ name={randomName}
62
+ {disabled}
63
+ checked={option.value === value}
64
+ onchange={() => handleChange(option)}
65
+ />
66
+ {option.label}
67
+ </label>
68
+ </div>
69
+ {/each}
70
+ </div>
71
+ {#if showError && errorText}
72
+ <div class="error-text">{errorText}</div>
73
+ {/if}
74
+ </FormGroup>
75
+ </div>
76
+
77
+ <style>
78
+ label {
79
+ display: flex;
80
+ flex-direction: row;
81
+ align-items: center;
82
+ user-select: none;
83
+ cursor: pointer;
84
+ }
85
+
86
+ .disabled label,
87
+ .disabled input {
88
+ cursor: not-allowed;
89
+ }
90
+
91
+ input {
92
+ position: relative !important;
93
+ -webkit-appearance: none;
94
+ -moz-appearance: none;
95
+ appearance: none;
96
+ margin: var(--pui-spacing-2);
97
+ box-sizing: content-box;
98
+ overflow: hidden;
99
+ cursor: pointer;
100
+ }
101
+
102
+ input:before {
103
+ content: '';
104
+ display: block;
105
+ box-sizing: content-box;
106
+ width: 16px;
107
+ height: 16px;
108
+ border: 2px solid var(--pui-border-disabled);
109
+ transition: var(--pui-transition-fast) border-color var(--pui-ease-out);
110
+ }
111
+
112
+ .radio-options {
113
+ display: flex;
114
+ gap: var(--pui-spacing-2);
115
+ border-radius: var(--pui-radius-lg);
116
+ }
117
+
118
+ .radio-required {
119
+ padding: var(--pui-spacing-1);
120
+ }
121
+
122
+ :global(.dark) input:before {
123
+ border-color: var(--pui-color-gray-600);
124
+ }
125
+ input:checked:before {
126
+ border-color: var(--pui-color-primary);
127
+ transition: var(--pui-transition-slow) border-color var(--pui-ease-out);
128
+ }
129
+ :global(.dark) input:checked:before {
130
+ border-color: var(--pui-color-primary);
131
+ }
132
+
133
+ input:disabled:before {
134
+ border-color: var(--pui-border-disabled);
135
+ background-color: var(--pui-border-disabled);
136
+ opacity: 0.5;
137
+ }
138
+ :global(.dark) input:disabled:before {
139
+ border-color: var(--pui-color-gray-600);
140
+ background-color: var(--pui-color-gray-600);
141
+ }
142
+ input:after {
143
+ content: '';
144
+ display: block;
145
+ position: absolute;
146
+ box-sizing: content-box;
147
+ top: 50%;
148
+ left: 50%;
149
+ transform-origin: 50% 50%;
150
+ background-color: var(--pui-color-primary);
151
+ width: 16px;
152
+ height: 16px;
153
+ border-radius: var(--pui-radius-full);
154
+ transform: translate(-50%, -50%) scale(0);
155
+ }
156
+ input:disabled:after {
157
+ opacity: 0.5;
158
+ }
159
+ :global(.dark) input:after {
160
+ background-color: var(--pui-color-primary);
161
+ }
162
+ input[type='radio']:before {
163
+ border-radius: var(--pui-radius-full);
164
+ }
165
+ input[type='radio']:after {
166
+ width: 16px;
167
+ height: 16px;
168
+ border-radius: var(--pui-radius-full);
169
+ transform: translate(-50%, -50%) scale(0);
170
+ }
171
+ input[type='radio']:checked:after {
172
+ -webkit-animation: toggleOnRadio var(--pui-transition-fast) ease forwards;
173
+ animation: toggleOnRadio var(--pui-transition-fast) ease forwards;
174
+ }
175
+ @-webkit-keyframes toggleOnRadio {
176
+ 0% {
177
+ opacity: 0;
178
+ transform: translate(-50%, -50%) scale(0);
179
+ }
180
+ 70% {
181
+ opacity: 1;
182
+ transform: translate(-50%, -50%) scale(0.9);
183
+ }
184
+ 100% {
185
+ transform: translate(-50%, -50%) scale(0.8);
186
+ }
187
+ }
188
+ @keyframes toggleOnRadio {
189
+ 0% {
190
+ opacity: 0;
191
+ transform: translate(-50%, -50%) scale(0);
192
+ }
193
+ 70% {
194
+ opacity: 1;
195
+ transform: translate(-50%, -50%) scale(0.9);
196
+ }
197
+ 100% {
198
+ transform: translate(-50%, -50%) scale(0.8);
199
+ }
200
+ }
201
+
202
+ .error {
203
+ border: 1px solid var(--pui-text-danger);
204
+ }
205
+
206
+ .error-text {
207
+ margin-top: var(--pui-spacing-1);
208
+ color: var(--pui-text-danger);
209
+ }
210
+ </style>