noph-ui 0.12.2 → 0.12.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md
CHANGED
|
@@ -65,7 +65,7 @@ Beta (No breaking changes expected)
|
|
|
65
65
|
- Ripple
|
|
66
66
|
- Segmented buttons
|
|
67
67
|
- Snackbar
|
|
68
|
-
- Text fields
|
|
68
|
+
- Text fields
|
|
69
69
|
|
|
70
70
|
In progress (Breaking changes expected)
|
|
71
71
|
|
|
@@ -75,8 +75,9 @@ In progress (Breaking changes expected)
|
|
|
75
75
|
- Navigation Drawer (Docs missing)
|
|
76
76
|
- Navigation Rail (Badge is missing + Docs missing)
|
|
77
77
|
- Tooltips (Positioning missing)
|
|
78
|
-
- Select (iOS issues)
|
|
78
|
+
- Select (iOS issues + Docs missing)
|
|
79
79
|
|
|
80
80
|
Pending
|
|
81
81
|
|
|
82
82
|
- Tabs
|
|
83
|
+
- Date Field
|
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
import Tooltip from '../tooltip/Tooltip.svelte'
|
|
4
4
|
import type { HTMLAnchorAttributes, HTMLButtonAttributes } from 'svelte/elements'
|
|
5
5
|
import type { ButtonProps } from './types.ts'
|
|
6
|
+
import CircularProgress from '../progress/CircularProgress.svelte'
|
|
6
7
|
|
|
7
8
|
let {
|
|
8
9
|
variant = 'outlined',
|
|
@@ -12,6 +13,7 @@
|
|
|
12
13
|
title,
|
|
13
14
|
element = $bindable(),
|
|
14
15
|
disabled = false,
|
|
16
|
+
loading = false,
|
|
15
17
|
keepTooltipOnClick,
|
|
16
18
|
...attributes
|
|
17
19
|
}: ButtonProps = $props()
|
|
@@ -27,9 +29,14 @@
|
|
|
27
29
|
</script>
|
|
28
30
|
|
|
29
31
|
{#snippet content()}
|
|
30
|
-
{#if !disabled}
|
|
32
|
+
{#if !disabled && !loading}
|
|
31
33
|
<Ripple />
|
|
32
34
|
{/if}
|
|
35
|
+
{#if loading}
|
|
36
|
+
<div class="circular-progress">
|
|
37
|
+
<CircularProgress indeterminate />
|
|
38
|
+
</div>
|
|
39
|
+
{/if}
|
|
33
40
|
<div class="button-icon">
|
|
34
41
|
{#if start}
|
|
35
42
|
{@render start()}
|
|
@@ -47,16 +54,17 @@
|
|
|
47
54
|
</div>
|
|
48
55
|
{/snippet}
|
|
49
56
|
|
|
50
|
-
{#if isButton(attributes) || disabled}
|
|
57
|
+
{#if isButton(attributes) || disabled || loading}
|
|
51
58
|
<button
|
|
52
59
|
{...attributes as HTMLButtonAttributes}
|
|
53
60
|
aria-describedby={title ? tooltipId : attributes['aria-describedby']}
|
|
54
61
|
aria-label={title || attributes['aria-label']}
|
|
55
|
-
{disabled}
|
|
62
|
+
disabled={disabled || loading}
|
|
56
63
|
bind:this={element}
|
|
57
64
|
class={[
|
|
58
65
|
'np-button',
|
|
59
|
-
|
|
66
|
+
loading ? 'np-loading' : '',
|
|
67
|
+
disabled || loading ? `${variant}-disabled disabled` : `${variant} enabled`,
|
|
60
68
|
attributes.class,
|
|
61
69
|
]}
|
|
62
70
|
>
|
|
@@ -85,6 +93,18 @@
|
|
|
85
93
|
text-overflow: ellipsis;
|
|
86
94
|
text-wrap: nowrap;
|
|
87
95
|
}
|
|
96
|
+
.circular-progress {
|
|
97
|
+
--np-circular-progress-size: calc(var(--button-height) * 0.75);
|
|
98
|
+
--np-circular-progress-color: color-mix(in srgb, var(--np-color-on-surface) 38%, transparent);
|
|
99
|
+
position: absolute;
|
|
100
|
+
top: 50%;
|
|
101
|
+
left: 50%;
|
|
102
|
+
transform: translate(-50%, -50%);
|
|
103
|
+
}
|
|
104
|
+
.np-loading .button-icon,
|
|
105
|
+
.np-loading .children-wrapper {
|
|
106
|
+
opacity: 0;
|
|
107
|
+
}
|
|
88
108
|
.np-button {
|
|
89
109
|
box-sizing: border-box;
|
|
90
110
|
font-family: inherit;
|
package/dist/button/types.d.ts
CHANGED
|
@@ -6,6 +6,7 @@ interface ButtonButtonProps extends HTMLButtonAttributes {
|
|
|
6
6
|
end?: Snippet | undefined;
|
|
7
7
|
element?: HTMLElement;
|
|
8
8
|
disabled?: boolean;
|
|
9
|
+
loading?: boolean;
|
|
9
10
|
keepTooltipOnClick?: boolean;
|
|
10
11
|
}
|
|
11
12
|
interface ButtonAnchorProps extends HTMLAnchorAttributes {
|
|
@@ -15,6 +16,7 @@ interface ButtonAnchorProps extends HTMLAnchorAttributes {
|
|
|
15
16
|
element?: HTMLElement;
|
|
16
17
|
keepTooltipOnClick?: boolean;
|
|
17
18
|
disabled?: boolean;
|
|
19
|
+
loading?: boolean;
|
|
18
20
|
}
|
|
19
21
|
interface IconButtonButtonProps extends HTMLButtonAttributes {
|
|
20
22
|
variant?: 'text' | 'filled' | 'outlined' | 'tonal';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import type { CheckboxProps } from './types.ts';
|
|
2
|
-
declare const Checkbox: import("svelte").Component<CheckboxProps, {}, "element" | "group" | "
|
|
2
|
+
declare const Checkbox: import("svelte").Component<CheckboxProps, {}, "element" | "group" | "indeterminate" | "checked">;
|
|
3
3
|
type Checkbox = ReturnType<typeof Checkbox>;
|
|
4
4
|
export default Checkbox;
|
|
@@ -204,6 +204,9 @@
|
|
|
204
204
|
--np-menu-position-area-fallback="top span-right"
|
|
205
205
|
--np-menu-position-area="bottom span-right"
|
|
206
206
|
--np-menu-margin="2px 0"
|
|
207
|
+
--np-menu-container-shape={variant === 'outlined'
|
|
208
|
+
? 'var(--np-outlined-select-text-field-container-shape)'
|
|
209
|
+
: 'var(--np-filled-select-text-field-container-shape)'}
|
|
207
210
|
anchor={element}
|
|
208
211
|
ontoggle={({ newState }) => {
|
|
209
212
|
if (newState === 'open') {
|
|
@@ -293,7 +296,7 @@
|
|
|
293
296
|
}
|
|
294
297
|
.background {
|
|
295
298
|
background: var(
|
|
296
|
-
--np-text-field-
|
|
299
|
+
--np-filled-select-text-field-container-color,
|
|
297
300
|
var(--np-color-surface-container-highest)
|
|
298
301
|
);
|
|
299
302
|
}
|
|
@@ -319,14 +322,32 @@
|
|
|
319
322
|
position: relative;
|
|
320
323
|
}
|
|
321
324
|
.outlined .container-overflow {
|
|
322
|
-
border-start-start-radius: var(
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
325
|
+
border-start-start-radius: var(
|
|
326
|
+
--np-outlined-select-text-field-container-shape,
|
|
327
|
+
var(--np-shape-corner-extra-small)
|
|
328
|
+
);
|
|
329
|
+
border-start-end-radius: var(
|
|
330
|
+
--np-outlined-select-text-field-container-shape,
|
|
331
|
+
var(--np-shape-corner-extra-small)
|
|
332
|
+
);
|
|
333
|
+
border-end-end-radius: var(
|
|
334
|
+
--np-outlined-select-text-field-container-shape,
|
|
335
|
+
var(--np-shape-corner-extra-small)
|
|
336
|
+
);
|
|
337
|
+
border-end-start-radius: var(
|
|
338
|
+
--np-outlined-select-text-field-container-shape,
|
|
339
|
+
var(--np-shape-corner-extra-small)
|
|
340
|
+
);
|
|
326
341
|
}
|
|
327
342
|
.container-overflow {
|
|
328
|
-
border-start-start-radius: var(
|
|
329
|
-
|
|
343
|
+
border-start-start-radius: var(
|
|
344
|
+
--np-filled-select-text-field-container-shape,
|
|
345
|
+
var(--np-shape-corner-extra-small)
|
|
346
|
+
);
|
|
347
|
+
border-start-end-radius: var(
|
|
348
|
+
--np-filled-select-text-field-container-shape,
|
|
349
|
+
var(--np-shape-corner-extra-small)
|
|
350
|
+
);
|
|
330
351
|
border-end-end-radius: var(--np-shape-corner-none);
|
|
331
352
|
border-end-start-radius: var(--np-shape-corner-none);
|
|
332
353
|
display: flex;
|
|
@@ -63,10 +63,10 @@
|
|
|
63
63
|
|
|
64
64
|
<label
|
|
65
65
|
style={(variant === 'outlined'
|
|
66
|
-
? '--top-space:1rem;--bottom-space:1rem;--floating-label-top:-0.5rem;--floating-label-left:-2.25rem;--_focus-outline-width:3px;'
|
|
66
|
+
? '--_label-text-color:var(--np-outlined-text-field-label-text-color);--top-space:1rem;--bottom-space:1rem;--floating-label-top:-0.5rem;--floating-label-left:-2.25rem;--_focus-outline-width:3px;'
|
|
67
67
|
: !label?.length
|
|
68
|
-
? '--top-space:1rem;--bottom-space:1rem;'
|
|
69
|
-
: '') + style}
|
|
68
|
+
? '--_label-text-color:var(--np-filled-text-field-label-text-color);--top-space:1rem;--bottom-space:1rem; '
|
|
69
|
+
: '--_label-text-color:var(--np-filled-text-field-label-text-color); ') + style}
|
|
70
70
|
class={['text-field', attributes.class]}
|
|
71
71
|
bind:this={element}
|
|
72
72
|
>
|
|
@@ -197,7 +197,10 @@
|
|
|
197
197
|
width: 100%;
|
|
198
198
|
}
|
|
199
199
|
.active-indicator::after {
|
|
200
|
-
border-bottom-color: var(
|
|
200
|
+
border-bottom-color: var(
|
|
201
|
+
--np-filled-text-field-focus-active-indicator-color,
|
|
202
|
+
var(--np-color-primary)
|
|
203
|
+
);
|
|
201
204
|
border-bottom-width: 3px;
|
|
202
205
|
}
|
|
203
206
|
.error .active-indicator::before {
|
|
@@ -213,7 +216,7 @@
|
|
|
213
216
|
}
|
|
214
217
|
.background {
|
|
215
218
|
background: var(
|
|
216
|
-
--np-text-field-
|
|
219
|
+
--np-filled-text-field-container-color,
|
|
217
220
|
var(--np-color-surface-container-highest)
|
|
218
221
|
);
|
|
219
222
|
}
|
|
@@ -239,14 +242,32 @@
|
|
|
239
242
|
position: relative;
|
|
240
243
|
}
|
|
241
244
|
.outlined .container-overflow {
|
|
242
|
-
border-start-start-radius: var(
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
245
|
+
border-start-start-radius: var(
|
|
246
|
+
--np-outlined-text-field-container-shape,
|
|
247
|
+
var(--np-shape-corner-extra-small)
|
|
248
|
+
);
|
|
249
|
+
border-start-end-radius: var(
|
|
250
|
+
--np-outlined-text-field-container-shape,
|
|
251
|
+
var(--np-shape-corner-extra-small)
|
|
252
|
+
);
|
|
253
|
+
border-end-end-radius: var(
|
|
254
|
+
--np-outlined-text-field-container-shape,
|
|
255
|
+
var(--np-shape-corner-extra-small)
|
|
256
|
+
);
|
|
257
|
+
border-end-start-radius: var(
|
|
258
|
+
--np-outlined-text-field-container-shape,
|
|
259
|
+
var(--np-shape-corner-extra-small)
|
|
260
|
+
);
|
|
246
261
|
}
|
|
247
262
|
.container-overflow {
|
|
248
|
-
border-start-start-radius: var(
|
|
249
|
-
|
|
263
|
+
border-start-start-radius: var(
|
|
264
|
+
--np-filled-text-field-container-shape,
|
|
265
|
+
var(--np-shape-corner-extra-small)
|
|
266
|
+
);
|
|
267
|
+
border-start-end-radius: var(
|
|
268
|
+
--np-filled-text-field-container-shape,
|
|
269
|
+
var(--np-shape-corner-extra-small)
|
|
270
|
+
);
|
|
250
271
|
border-end-end-radius: var(--np-shape-corner-none);
|
|
251
272
|
border-end-start-radius: var(--np-shape-corner-none);
|
|
252
273
|
display: flex;
|
|
@@ -543,7 +564,7 @@
|
|
|
543
564
|
}
|
|
544
565
|
.field:has(input:focus-visible) .label,
|
|
545
566
|
.field:has(textarea:focus-visible) .label {
|
|
546
|
-
color: var(--np-color-primary);
|
|
567
|
+
color: var(--_label-text-color, var(--np-color-primary));
|
|
547
568
|
}
|
|
548
569
|
.error .label,
|
|
549
570
|
.error:has(input:focus-visible) .label,
|
|
@@ -698,7 +719,7 @@
|
|
|
698
719
|
|
|
699
720
|
.field:has(input:focus-visible) .np-outline,
|
|
700
721
|
.field:has(textarea:focus-visible) .np-outline {
|
|
701
|
-
border-color: var(--np-color-primary);
|
|
722
|
+
border-color: var(--np-outlined-text-field-focus-outline-color, var(--np-color-primary));
|
|
702
723
|
color: var(--np-color-primary);
|
|
703
724
|
}
|
|
704
725
|
.error .np-outline,
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "noph-ui",
|
|
3
|
-
"version": "0.12.
|
|
3
|
+
"version": "0.12.4",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"homepage": "https://noph.dev",
|
|
6
6
|
"repository": {
|
|
@@ -65,8 +65,8 @@
|
|
|
65
65
|
"globals": "^15.14.0",
|
|
66
66
|
"prettier": "^3.4.2",
|
|
67
67
|
"prettier-plugin-svelte": "^3.3.3",
|
|
68
|
-
"publint": "^0.3.
|
|
69
|
-
"svelte": "^5.19.
|
|
68
|
+
"publint": "^0.3.4",
|
|
69
|
+
"svelte": "^5.19.9",
|
|
70
70
|
"svelte-check": "^4.1.4",
|
|
71
71
|
"typescript": "^5.7.3",
|
|
72
72
|
"typescript-eslint": "^8.23.0",
|