luna-plus 0.0.40 → 0.0.42
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/dist/Affix/Affix.svelte +1 -1
- package/dist/Alert/Alert.svelte +6 -6
- package/dist/Autocomplete/Autocomplete.svelte +9 -9
- package/dist/Avatar/Avatar.svelte +5 -5
- package/dist/Backtop/Backtop.svelte +1 -1
- package/dist/Badge/Badge.svelte +4 -4
- package/dist/Breadcrumb/Breadcrumb.svelte +7 -7
- package/dist/Breadcrumb/BreadcrumbItem.svelte +6 -6
- package/dist/Button/Button.svelte +2 -2
- package/dist/Calendar/Calendar.svelte +16 -16
- package/dist/Card/Card.svelte +4 -4
- package/dist/Carousel/Carousel.svelte +6 -6
- package/dist/Carousel/CarouselItem.svelte +1 -1
- package/dist/Cascader/Cascader.svelte +12 -12
- package/dist/Checkbox/Checkbox.svelte +5 -5
- package/dist/Checkbox/CheckboxGroup.svelte +1 -1
- package/dist/Collapse/Collapse.svelte +1 -1
- package/dist/Collapse/CollapseItem.svelte +6 -6
- package/dist/ColorPicker/ColorPicker.svelte +13 -13
- package/dist/Container/Aside.svelte +1 -1
- package/dist/Container/Container.svelte +1 -1
- package/dist/Container/Footer.svelte +1 -1
- package/dist/Container/Header.svelte +1 -1
- package/dist/Container/Main.svelte +1 -1
- package/dist/DatePicker/DatePicker.svelte +20 -20
- package/dist/DateTimePicker/DateTimePicker.svelte +31 -31
- package/dist/Descriptions/Descriptions.svelte +6 -6
- package/dist/Descriptions/DescriptionsItem.svelte +6 -6
- package/dist/Dialog/Dialog.svelte +8 -8
- package/dist/Divider/Divider.svelte +6 -6
- package/dist/Drawer/Drawer.svelte +8 -8
- package/dist/Dropdown/Dropdown.svelte +8 -8
- package/dist/Dropdown/DropdownItem.svelte +2 -2
- package/dist/Dropdown/DropdownMenu.svelte +1 -1
- package/dist/Empty/Empty.svelte +4 -4
- package/dist/Form/Form.svelte +1 -1
- package/dist/Form/FormItem.svelte +4 -4
- package/dist/Icon/Icon.svelte +1 -1
- package/dist/Image/Image.svelte +13 -13
- package/dist/Input/Input.svelte +7 -7
- package/dist/InputNumber/InputNumber.svelte +7 -7
- package/dist/InputTag/InputTag.svelte +4 -4
- package/dist/Link/Link.svelte +1 -1
- package/dist/Loading/Loading.svelte +6 -6
- package/dist/Menu/Menu.svelte +10 -10
- package/dist/Message/Message.svelte +4 -4
- package/dist/Message/MessageQueue.svelte +4 -4
- package/dist/Message/message.js +1 -1
- package/dist/MessageBox/MessageBox.svelte +6 -6
- package/dist/MessageBox/messageBox.js +2 -2
- package/dist/Notification/Notification.svelte +8 -8
- package/dist/Pagination/Pagination.svelte +19 -19
- package/dist/PinInput/PinInput.svelte +2 -2
- package/dist/Popconfirm/Popconfirm.svelte +8 -8
- package/dist/Popover/Popover.svelte +5 -5
- package/dist/Progress/Progress.svelte +4 -4
- package/dist/Radio/Radio.svelte +5 -5
- package/dist/Radio/RadioGroup.svelte +1 -1
- package/dist/Rating/Rating.svelte +7 -7
- package/dist/Result/Result.svelte +6 -6
- package/dist/Segmented/Segmented.svelte +4 -4
- package/dist/Select/Option.svelte +1 -1
- package/dist/Select/OptionGroup.svelte +3 -3
- package/dist/Select/Select.svelte +13 -13
- package/dist/Skeleton/Skeleton.svelte +2 -2
- package/dist/Skeleton/SkeletonItem.svelte +1 -1
- package/dist/Slider/Slider.svelte +12 -12
- package/dist/Space/Space.svelte +5 -5
- package/dist/Statistic/Countdown.svelte +6 -6
- package/dist/Statistic/Statistic.svelte +6 -6
- package/dist/Steps/Step.svelte +8 -8
- package/dist/Steps/Steps.svelte +1 -1
- package/dist/Switch/Switch.svelte +7 -7
- package/dist/Table/Table.svelte +32 -32
- package/dist/Tabs/TabPane.svelte +1 -1
- package/dist/Tabs/Tabs.svelte +14 -14
- package/dist/Tabs/TabsContext.js +1 -1
- package/dist/Tag/Tag.svelte +2 -2
- package/dist/Textarea/Textarea.svelte +3 -3
- package/dist/TimePicker/TimePicker.svelte +19 -19
- package/dist/Timeline/Timeline.svelte +1 -1
- package/dist/Timeline/TimelineItem.svelte +7 -7
- package/dist/Tooltip/OverflowTooltip.svelte +5 -5
- package/dist/Tooltip/Tooltip.svelte +3 -3
- package/dist/Transfer/Transfer.svelte +28 -24
- package/dist/Tree/Tree.svelte +1 -1
- package/dist/Tree/TreeNode.svelte +6 -6
- package/dist/TreeSelect/TreeSelect.svelte +25 -25
- package/dist/Upload/Upload.svelte +32 -32
- package/dist/Watermark/Watermark.svelte +3 -3
- package/package.json +1 -1
- package/styles/index.css +1 -1
package/dist/Affix/Affix.svelte
CHANGED
|
@@ -75,7 +75,7 @@
|
|
|
75
75
|
window.removeEventListener('resize', updateFixed)
|
|
76
76
|
})
|
|
77
77
|
|
|
78
|
-
const classes = $derived(`
|
|
78
|
+
const classes = $derived(`ln-affix${fixed ? ' is-fixed' : ''}${cls ? ` ${cls}` : ''}`)
|
|
79
79
|
|
|
80
80
|
const affixStyle = $derived.by(() => {
|
|
81
81
|
if (!fixed) return undefined
|
package/dist/Alert/Alert.svelte
CHANGED
|
@@ -44,7 +44,7 @@
|
|
|
44
44
|
let timer: ReturnType<typeof setTimeout> | null = null;
|
|
45
45
|
|
|
46
46
|
const classes = $derived(
|
|
47
|
-
`
|
|
47
|
+
`ln-alert ln-alert--${type}${!visible ? " is-hidden" : ""}${center ? " is-center" : ""}${cls ? ` ${cls}` : ""}`,
|
|
48
48
|
);
|
|
49
49
|
|
|
50
50
|
const handleClose = (): void => {
|
|
@@ -65,16 +65,16 @@
|
|
|
65
65
|
{#if visible}
|
|
66
66
|
<div {...attrs} class={classes} role="alert">
|
|
67
67
|
{#if showIcon}
|
|
68
|
-
<div class="
|
|
68
|
+
<div class="ln-alert__icon">
|
|
69
69
|
<Icon icon={ICON_MAP[type]} size={20} />
|
|
70
70
|
</div>
|
|
71
71
|
{/if}
|
|
72
|
-
<div class="
|
|
72
|
+
<div class="ln-alert__content">
|
|
73
73
|
{#if title}
|
|
74
|
-
<div class="
|
|
74
|
+
<div class="ln-alert__title">{title}</div>
|
|
75
75
|
{/if}
|
|
76
76
|
{#if children}
|
|
77
|
-
<div class="
|
|
77
|
+
<div class="ln-alert__description">
|
|
78
78
|
{@render children()}
|
|
79
79
|
</div>
|
|
80
80
|
{/if}
|
|
@@ -82,7 +82,7 @@
|
|
|
82
82
|
{#if closable}
|
|
83
83
|
<button
|
|
84
84
|
type="button"
|
|
85
|
-
class="
|
|
85
|
+
class="ln-alert__close"
|
|
86
86
|
onclick={handleClose}
|
|
87
87
|
aria-label="Close"
|
|
88
88
|
>
|
|
@@ -105,11 +105,11 @@
|
|
|
105
105
|
return () => document.removeEventListener('click', handleClickOutside)
|
|
106
106
|
})
|
|
107
107
|
|
|
108
|
-
const classes = $derived(['
|
|
108
|
+
const classes = $derived(['ln-autocomplete', disabled && 'is-disabled', size !== 'default' && `ln-autocomplete--${size}`, cls].filter(Boolean).join(' '))
|
|
109
109
|
</script>
|
|
110
110
|
|
|
111
111
|
<div bind:this={inputRef} class={classes} {...attrs}>
|
|
112
|
-
<div class="
|
|
112
|
+
<div class="ln-autocomplete__input" class:is-focus={visible}>
|
|
113
113
|
<input
|
|
114
114
|
type="text"
|
|
115
115
|
value={modelValue}
|
|
@@ -124,30 +124,30 @@
|
|
|
124
124
|
onkeydown={handleKeydown}
|
|
125
125
|
/>
|
|
126
126
|
{#if loading}
|
|
127
|
-
<span class="
|
|
127
|
+
<span class="ln-autocomplete__loading" aria-label="加载中">
|
|
128
128
|
<Icon icon={Loader2} size={14} />
|
|
129
129
|
</span>
|
|
130
130
|
{:else if clearable && modelValue && !disabled}
|
|
131
|
-
<button type="button" class="
|
|
131
|
+
<button type="button" class="ln-autocomplete__clear" onclick={handleClear} aria-label="清除">
|
|
132
132
|
<Icon icon={X} size={14} />
|
|
133
133
|
</button>
|
|
134
134
|
{:else}
|
|
135
|
-
<span class="
|
|
135
|
+
<span class="ln-autocomplete__arrow" class:is-open={visible} aria-hidden="true">
|
|
136
136
|
<Icon icon={ChevronDown} size={14} />
|
|
137
137
|
</span>
|
|
138
138
|
{/if}
|
|
139
139
|
</div>
|
|
140
140
|
|
|
141
141
|
{#if visible && suggestions.length > 0}
|
|
142
|
-
<div class="
|
|
142
|
+
<div class="ln-autocomplete__dropdown" role="listbox" id="autocomplete-listbox">
|
|
143
143
|
{#if showMenuArrow}
|
|
144
|
-
<div class="
|
|
144
|
+
<div class="ln-autocomplete__menu-arrow" aria-hidden="true"></div>
|
|
145
145
|
{/if}
|
|
146
146
|
|
|
147
|
-
<ul class="
|
|
147
|
+
<ul class="ln-autocomplete__menu" role="group">
|
|
148
148
|
{#each suggestions as item, index (item[valueKey])}
|
|
149
149
|
<li
|
|
150
|
-
class="
|
|
150
|
+
class="ln-autocomplete__item"
|
|
151
151
|
class:is-highlighted={index === highlightIndex}
|
|
152
152
|
role="option"
|
|
153
153
|
aria-selected={index === highlightIndex}
|
|
@@ -53,11 +53,11 @@
|
|
|
53
53
|
|
|
54
54
|
const sizeClass = $derived(
|
|
55
55
|
typeof normalizedSize === "number"
|
|
56
|
-
? "
|
|
57
|
-
: `
|
|
56
|
+
? "ln-avatar--custom"
|
|
57
|
+
: `ln-avatar--${normalizedSize}`,
|
|
58
58
|
);
|
|
59
59
|
const classes = $derived(
|
|
60
|
-
`
|
|
60
|
+
`ln-avatar ${sizeClass} ln-avatar--${shape}${cls ? ` ${cls}` : ""}`,
|
|
61
61
|
);
|
|
62
62
|
|
|
63
63
|
const styleAttr = $derived.by(() => {
|
|
@@ -79,14 +79,14 @@
|
|
|
79
79
|
<span {...attrs} class={classes} style={styleAttr} aria-label={alt} role="img">
|
|
80
80
|
{#if src && !hasError}
|
|
81
81
|
<img
|
|
82
|
-
class="
|
|
82
|
+
class="ln-avatar__img"
|
|
83
83
|
{src}
|
|
84
84
|
{alt}
|
|
85
85
|
style={`object-fit:${fit};`}
|
|
86
86
|
onerror={handleError}
|
|
87
87
|
/>
|
|
88
88
|
{:else}
|
|
89
|
-
<span class="
|
|
89
|
+
<span class="ln-avatar__placeholder">
|
|
90
90
|
{#if children}
|
|
91
91
|
{@render children()}
|
|
92
92
|
{:else}
|
|
@@ -45,7 +45,7 @@
|
|
|
45
45
|
scrollEl.removeEventListener('scroll', handleScroll)
|
|
46
46
|
})
|
|
47
47
|
|
|
48
|
-
const classes = $derived(`
|
|
48
|
+
const classes = $derived(`ln-backtop${visible ? ' is-visible' : ''}${cls ? ` ${cls}` : ''}`)
|
|
49
49
|
const style = $derived(`right: ${right}px; bottom: ${bottom}px`)
|
|
50
50
|
</script>
|
|
51
51
|
|
package/dist/Badge/Badge.svelte
CHANGED
|
@@ -22,12 +22,12 @@
|
|
|
22
22
|
...attrs
|
|
23
23
|
}: BadgeProps = $props();
|
|
24
24
|
|
|
25
|
-
const classes = $derived(cls ? `
|
|
25
|
+
const classes = $derived(cls ? `ln-badge ${cls}` : "ln-badge");
|
|
26
26
|
|
|
27
27
|
const contentClasses = $derived(
|
|
28
28
|
isDot
|
|
29
|
-
? `
|
|
30
|
-
: `
|
|
29
|
+
? `ln-badge__content ln-badge__content--${type} is-dot`
|
|
30
|
+
: `ln-badge__content ln-badge__content--${type}`,
|
|
31
31
|
);
|
|
32
32
|
|
|
33
33
|
const displayValue = $derived.by(() => {
|
|
@@ -52,7 +52,7 @@
|
|
|
52
52
|
</script>
|
|
53
53
|
|
|
54
54
|
<div {...attrs} class={classes}>
|
|
55
|
-
<div class="
|
|
55
|
+
<div class="ln-badge__base">
|
|
56
56
|
{#if children}
|
|
57
57
|
{@render children()}
|
|
58
58
|
{/if}
|
|
@@ -30,7 +30,7 @@
|
|
|
30
30
|
},
|
|
31
31
|
});
|
|
32
32
|
|
|
33
|
-
const classes = $derived(`
|
|
33
|
+
const classes = $derived(`ln-breadcrumb${cls ? ` ${cls}` : ""}`);
|
|
34
34
|
</script>
|
|
35
35
|
|
|
36
36
|
<ul class={classes} {...attrs}>
|
|
@@ -38,25 +38,25 @@
|
|
|
38
38
|
{@render children()}
|
|
39
39
|
{:else if items}
|
|
40
40
|
{#each items as item, index}
|
|
41
|
-
<li class="
|
|
41
|
+
<li class="ln-breadcrumb__item">
|
|
42
42
|
{#if item.href}
|
|
43
|
-
<a href={item.href} class="
|
|
43
|
+
<a href={item.href} class="ln-breadcrumb__link">
|
|
44
44
|
{#if item.icon}
|
|
45
|
-
<Icon icon={item.icon} class="
|
|
45
|
+
<Icon icon={item.icon} class="ln-breadcrumb__icon" />
|
|
46
46
|
{/if}
|
|
47
47
|
{item.label}
|
|
48
48
|
</a>
|
|
49
49
|
{:else}
|
|
50
|
-
<span class="
|
|
50
|
+
<span class="ln-breadcrumb__text">
|
|
51
51
|
{#if item.icon}
|
|
52
|
-
<Icon icon={item.icon} class="
|
|
52
|
+
<Icon icon={item.icon} class="ln-breadcrumb__icon" />
|
|
53
53
|
{/if}
|
|
54
54
|
{item.label}
|
|
55
55
|
</span>
|
|
56
56
|
{/if}
|
|
57
57
|
</li>
|
|
58
58
|
{#if index < items.length - 1}
|
|
59
|
-
<li class="
|
|
59
|
+
<li class="ln-breadcrumb__separator">{separator}</li>
|
|
60
60
|
{/if}
|
|
61
61
|
{/each}
|
|
62
62
|
{/if}
|
|
@@ -29,23 +29,23 @@
|
|
|
29
29
|
const separator = $derived(context?.separator ?? "/");
|
|
30
30
|
const link = $derived(href || to);
|
|
31
31
|
|
|
32
|
-
const classes = $derived(`
|
|
32
|
+
const classes = $derived(`ln-breadcrumb__item${cls ? ` ${cls}` : ""}`);
|
|
33
33
|
</script>
|
|
34
34
|
|
|
35
35
|
<li class={classes} {...attrs}>
|
|
36
36
|
{#if link}
|
|
37
|
-
<a href={link} class="
|
|
37
|
+
<a href={link} class="ln-breadcrumb__link">
|
|
38
38
|
{#if icon}
|
|
39
|
-
<Icon {icon} class="
|
|
39
|
+
<Icon {icon} class="ln-breadcrumb__icon" />
|
|
40
40
|
{/if}
|
|
41
41
|
{#if children}
|
|
42
42
|
{@render children()}
|
|
43
43
|
{/if}
|
|
44
44
|
</a>
|
|
45
45
|
{:else}
|
|
46
|
-
<span class="
|
|
46
|
+
<span class="ln-breadcrumb__text">
|
|
47
47
|
{#if icon}
|
|
48
|
-
<Icon {icon} class="
|
|
48
|
+
<Icon {icon} class="ln-breadcrumb__icon" />
|
|
49
49
|
{/if}
|
|
50
50
|
{#if children}
|
|
51
51
|
{@render children()}
|
|
@@ -53,4 +53,4 @@
|
|
|
53
53
|
</span>
|
|
54
54
|
{/if}
|
|
55
55
|
</li>
|
|
56
|
-
<li class="
|
|
56
|
+
<li class="ln-breadcrumb__separator">{separator}</li>
|
|
@@ -23,7 +23,7 @@
|
|
|
23
23
|
}: ButtonProps = $props()
|
|
24
24
|
|
|
25
25
|
const classes = $derived(
|
|
26
|
-
`
|
|
26
|
+
`ln-button ln-button--${type} ln-button--${size}${disabled ? ' is-disabled' : ''}${loading ? ' is-loading' : ''}${plain ? ' is-plain' : ''}${round ? ' is-round' : ''}${circle ? ' is-circle' : ''}${cls ? ` ${cls}` : ''}`
|
|
27
27
|
)
|
|
28
28
|
|
|
29
29
|
const handleClick = (e: MouseEvent): void => {
|
|
@@ -50,7 +50,7 @@
|
|
|
50
50
|
onclick={handleClick}
|
|
51
51
|
>
|
|
52
52
|
{#if loading}
|
|
53
|
-
<span class="
|
|
53
|
+
<span class="ln-button__loading" aria-hidden="true">
|
|
54
54
|
<Icon icon={LoaderCircle} size={16} />
|
|
55
55
|
</span>
|
|
56
56
|
{/if}
|
|
@@ -60,43 +60,43 @@
|
|
|
60
60
|
currentDate = new Date(t)
|
|
61
61
|
}
|
|
62
62
|
|
|
63
|
-
const classes = $derived(`
|
|
63
|
+
const classes = $derived(`ln-calendar${cls ? ` ${cls}` : ''}`)
|
|
64
64
|
</script>
|
|
65
65
|
|
|
66
66
|
<div class={classes} {...attrs}>
|
|
67
|
-
<div class="
|
|
68
|
-
<div class="
|
|
69
|
-
<button class="
|
|
67
|
+
<div class="ln-calendar__header">
|
|
68
|
+
<div class="ln-calendar__nav">
|
|
69
|
+
<button class="ln-calendar__btn" onclick={() => (currentDate = new Date(year - 1, month, 1))} aria-label="上一年">
|
|
70
70
|
<Icon icon={ChevronsLeft} size={16} />
|
|
71
71
|
</button>
|
|
72
|
-
<button class="
|
|
72
|
+
<button class="ln-calendar__btn" onclick={() => (currentDate = new Date(year, month - 1, 1))} aria-label="上个月">
|
|
73
73
|
<Icon icon={ChevronLeft} size={14} />
|
|
74
74
|
</button>
|
|
75
75
|
</div>
|
|
76
|
-
<div class="
|
|
76
|
+
<div class="ln-calendar__title">
|
|
77
77
|
{year}年 {month + 1}月
|
|
78
78
|
</div>
|
|
79
|
-
<div class="
|
|
80
|
-
<button class="
|
|
79
|
+
<div class="ln-calendar__nav">
|
|
80
|
+
<button class="ln-calendar__btn" onclick={() => (currentDate = new Date(year, month + 1, 1))} aria-label="下个月">
|
|
81
81
|
<Icon icon={ChevronRight} size={14} />
|
|
82
82
|
</button>
|
|
83
|
-
<button class="
|
|
83
|
+
<button class="ln-calendar__btn" onclick={() => (currentDate = new Date(year + 1, month, 1))} aria-label="下一年">
|
|
84
84
|
<Icon icon={ChevronsRight} size={16} />
|
|
85
85
|
</button>
|
|
86
86
|
</div>
|
|
87
87
|
</div>
|
|
88
88
|
|
|
89
|
-
<div class="
|
|
90
|
-
<div class="
|
|
89
|
+
<div class="ln-calendar__body">
|
|
90
|
+
<div class="ln-calendar__weekdays">
|
|
91
91
|
{#each weekDays as day}
|
|
92
|
-
<div class="
|
|
92
|
+
<div class="ln-calendar__weekday">{day}</div>
|
|
93
93
|
{/each}
|
|
94
94
|
</div>
|
|
95
|
-
<div class="
|
|
95
|
+
<div class="ln-calendar__days" role="grid">
|
|
96
96
|
{#each calendarDays as day}
|
|
97
97
|
<button
|
|
98
98
|
type="button"
|
|
99
|
-
class="
|
|
99
|
+
class="ln-calendar__day"
|
|
100
100
|
class:is-other-month={day.month !== 'current'}
|
|
101
101
|
class:is-today={isToday(day.fullDate)}
|
|
102
102
|
class:is-selected={isSelected(day.fullDate)}
|
|
@@ -109,7 +109,7 @@
|
|
|
109
109
|
</div>
|
|
110
110
|
</div>
|
|
111
111
|
|
|
112
|
-
<div class="
|
|
113
|
-
<button class="
|
|
112
|
+
<div class="ln-calendar__footer">
|
|
113
|
+
<button class="ln-calendar__today" onclick={goToToday}>今天</button>
|
|
114
114
|
</div>
|
|
115
115
|
</div>
|
package/dist/Card/Card.svelte
CHANGED
|
@@ -23,10 +23,10 @@
|
|
|
23
23
|
}: CardProps = $props()
|
|
24
24
|
|
|
25
25
|
const shadowClass = $derived(shadow !== 'always' ? ` is-${shadow}-shadow` : '')
|
|
26
|
-
const cardClasses = $derived(`
|
|
27
|
-
const headerClasses = $derived(`
|
|
28
|
-
const bodyClasses = $derived(`
|
|
29
|
-
const footerClasses = $derived(`
|
|
26
|
+
const cardClasses = $derived(`ln-card${shadowClass}${cls ? ` ${cls}` : ''}`)
|
|
27
|
+
const headerClasses = $derived(`ln-card__header${headerClass ? ` ${headerClass}` : ''}`)
|
|
28
|
+
const bodyClasses = $derived(`ln-card__body${bodyClass ? ` ${bodyClass}` : ''}`)
|
|
29
|
+
const footerClasses = $derived(`ln-card__footer${footerClass ? ` ${footerClass}` : ''}`)
|
|
30
30
|
const bodyStyleText = $derived(styleToString(bodyStyle))
|
|
31
31
|
</script>
|
|
32
32
|
|
|
@@ -138,7 +138,7 @@
|
|
|
138
138
|
arrow === "always" || (arrow === "hover" && isHovering),
|
|
139
139
|
);
|
|
140
140
|
const classes = $derived(
|
|
141
|
-
`
|
|
141
|
+
`ln-carousel ln-carousel--${direction}${indicatorPosition === "outside" ? " ln-carousel--indicator-outside" : ""}${cls ? ` ${cls}` : ""}`,
|
|
142
142
|
);
|
|
143
143
|
|
|
144
144
|
/** 指示器索引数组(缓存避免重复创建) */
|
|
@@ -155,7 +155,7 @@
|
|
|
155
155
|
{...attrs}
|
|
156
156
|
>
|
|
157
157
|
<div
|
|
158
|
-
class="
|
|
158
|
+
class="ln-carousel__container"
|
|
159
159
|
style="transform:{direction === 'horizontal'
|
|
160
160
|
? `translateX(-${activeIndex * 100}%)`
|
|
161
161
|
: `translateY(-${activeIndex * 100}%)`}"
|
|
@@ -168,7 +168,7 @@
|
|
|
168
168
|
{#if showArrow && itemCount > 1}
|
|
169
169
|
<button
|
|
170
170
|
type="button"
|
|
171
|
-
class="
|
|
171
|
+
class="ln-carousel__arrow ln-carousel__arrow--prev"
|
|
172
172
|
onclick={prev}
|
|
173
173
|
aria-label="Previous slide"
|
|
174
174
|
>
|
|
@@ -179,7 +179,7 @@
|
|
|
179
179
|
</button>
|
|
180
180
|
<button
|
|
181
181
|
type="button"
|
|
182
|
-
class="
|
|
182
|
+
class="ln-carousel__arrow ln-carousel__arrow--next"
|
|
183
183
|
onclick={next}
|
|
184
184
|
aria-label="Next slide"
|
|
185
185
|
>
|
|
@@ -191,11 +191,11 @@
|
|
|
191
191
|
{/if}
|
|
192
192
|
|
|
193
193
|
{#if indicatorPosition !== "none" && itemCount > 1}
|
|
194
|
-
<div class="
|
|
194
|
+
<div class="ln-carousel__indicators">
|
|
195
195
|
{#each indicatorIndices as i (i)}
|
|
196
196
|
<button
|
|
197
197
|
type="button"
|
|
198
|
-
class="
|
|
198
|
+
class="ln-carousel__indicator{activeIndex === i ? ' is-active' : ''}"
|
|
199
199
|
onclick={() => handleIndicator(i, "click")}
|
|
200
200
|
onmouseenter={() => handleIndicator(i, "hover")}
|
|
201
201
|
aria-label="Go to slide {i + 1}"
|
|
@@ -31,7 +31,7 @@
|
|
|
31
31
|
|
|
32
32
|
const isActive = $derived(itemIndex === carousel?.activeIndex);
|
|
33
33
|
const classes = $derived(
|
|
34
|
-
`
|
|
34
|
+
`ln-carousel__item${isActive ? " is-active" : ""}${cls ? ` ${cls}` : ""}`,
|
|
35
35
|
);
|
|
36
36
|
</script>
|
|
37
37
|
|
|
@@ -139,9 +139,9 @@
|
|
|
139
139
|
|
|
140
140
|
const classes = $derived(
|
|
141
141
|
[
|
|
142
|
-
"
|
|
142
|
+
"ln-cascader",
|
|
143
143
|
disabled && "is-disabled",
|
|
144
|
-
size !== "default" && `
|
|
144
|
+
size !== "default" && `ln-cascader--${size}`,
|
|
145
145
|
cls,
|
|
146
146
|
]
|
|
147
147
|
.filter(Boolean)
|
|
@@ -151,7 +151,7 @@
|
|
|
151
151
|
|
|
152
152
|
<div bind:this={inputRef} class={classes} {...attrs}>
|
|
153
153
|
<div
|
|
154
|
-
class="
|
|
154
|
+
class="ln-cascader__input"
|
|
155
155
|
class:is-focus={visible}
|
|
156
156
|
role="combobox"
|
|
157
157
|
tabindex={disabled ? -1 : 0}
|
|
@@ -161,20 +161,20 @@
|
|
|
161
161
|
onclick={handleToggle}
|
|
162
162
|
onkeydown={handleKeydown}
|
|
163
163
|
>
|
|
164
|
-
<span class="
|
|
164
|
+
<span class="ln-cascader__value" class:is-placeholder={!displayValue}>
|
|
165
165
|
{displayValue || placeholder}
|
|
166
166
|
</span>
|
|
167
167
|
{#if clearable && modelValue.length > 0 && !disabled}
|
|
168
168
|
<button
|
|
169
169
|
type="button"
|
|
170
|
-
class="
|
|
170
|
+
class="ln-cascader__clear"
|
|
171
171
|
onclick={handleClear}
|
|
172
172
|
aria-label="清除"
|
|
173
173
|
>
|
|
174
174
|
<Icon icon={X} size={14} />
|
|
175
175
|
</button>
|
|
176
176
|
{:else}
|
|
177
|
-
<span class="
|
|
177
|
+
<span class="ln-cascader__arrow" class:is-open={visible}>
|
|
178
178
|
<Icon icon={ChevronDown} size={14} />
|
|
179
179
|
</span>
|
|
180
180
|
{/if}
|
|
@@ -182,19 +182,19 @@
|
|
|
182
182
|
|
|
183
183
|
{#if visible}
|
|
184
184
|
<div
|
|
185
|
-
class="
|
|
185
|
+
class="ln-cascader__dropdown"
|
|
186
186
|
role="listbox"
|
|
187
187
|
id="cascader-dropdown"
|
|
188
188
|
transition:dropdownTransition
|
|
189
189
|
>
|
|
190
190
|
{#if showMenuArrow}
|
|
191
|
-
<div class="
|
|
191
|
+
<div class="ln-cascader__menu-arrow" aria-hidden="true"></div>
|
|
192
192
|
{/if}
|
|
193
193
|
{#each menus as menu, level}
|
|
194
|
-
<ul class="
|
|
194
|
+
<ul class="ln-cascader__menu" role="group">
|
|
195
195
|
{#each menu as option (option.value)}
|
|
196
196
|
<li
|
|
197
|
-
class="
|
|
197
|
+
class="ln-cascader__option"
|
|
198
198
|
class:is-active={isActive(option, level)}
|
|
199
199
|
class:is-disabled={option.disabled}
|
|
200
200
|
role="option"
|
|
@@ -202,8 +202,8 @@
|
|
|
202
202
|
onmousedown={() => handleOptionClick(option, level)}
|
|
203
203
|
onmouseenter={() => handleOptionHover(option, level)}
|
|
204
204
|
>
|
|
205
|
-
<span class="
|
|
206
|
-
<span class="
|
|
205
|
+
<span class="ln-cascader__option-label">{option.label}</span>
|
|
206
|
+
<span class="ln-cascader__option-suffix" aria-hidden="true">
|
|
207
207
|
{#if option.children?.length}
|
|
208
208
|
<Icon icon={ChevronRight} size={14} />
|
|
209
209
|
{:else if isActive(option, level) && level === menus.length - 1}
|
|
@@ -19,7 +19,7 @@
|
|
|
19
19
|
|
|
20
20
|
let inputRef: HTMLInputElement | null = $state(null)
|
|
21
21
|
|
|
22
|
-
const classes = $derived(`
|
|
22
|
+
const classes = $derived(`ln-checkbox ln-checkbox--${size}${checked ? ' is-checked' : ''}${disabled ? ' is-disabled' : ''}${indeterminate ? ' is-indeterminate' : ''}${cls ? ` ${cls}` : ''}`)
|
|
23
23
|
|
|
24
24
|
const handleChange = (e: Event): void => {
|
|
25
25
|
checked = (e.currentTarget as HTMLInputElement).checked
|
|
@@ -32,9 +32,9 @@
|
|
|
32
32
|
</script>
|
|
33
33
|
|
|
34
34
|
<label class={classes}>
|
|
35
|
-
<span class="
|
|
36
|
-
<input bind:this={inputRef} bind:checked {...attrs} type="checkbox" class="
|
|
37
|
-
<span class="
|
|
35
|
+
<span class="ln-checkbox__input">
|
|
36
|
+
<input bind:this={inputRef} bind:checked {...attrs} type="checkbox" class="ln-checkbox__original" {value} {disabled} onchange={handleChange} />
|
|
37
|
+
<span class="ln-checkbox__inner">
|
|
38
38
|
{#if checked}
|
|
39
39
|
<Icon icon={Check} size={12} />
|
|
40
40
|
{:else if indeterminate}
|
|
@@ -44,7 +44,7 @@
|
|
|
44
44
|
</span>
|
|
45
45
|
|
|
46
46
|
{#if children || label}
|
|
47
|
-
<span class="
|
|
47
|
+
<span class="ln-checkbox__label">
|
|
48
48
|
{#if children}
|
|
49
49
|
{@render children()}
|
|
50
50
|
{:else if label}
|
|
@@ -21,7 +21,7 @@
|
|
|
21
21
|
}: CheckboxGroupProps = $props();
|
|
22
22
|
|
|
23
23
|
const classes = $derived(
|
|
24
|
-
`
|
|
24
|
+
`ln-checkbox-group ln-checkbox-group--${size}${disabled ? " is-disabled" : ""}${cls ? ` ${cls}` : ""}`,
|
|
25
25
|
);
|
|
26
26
|
|
|
27
27
|
const toggle = (value: string | number): void => {
|
|
@@ -52,7 +52,7 @@
|
|
|
52
52
|
|
|
53
53
|
setContext(COLLAPSE_CONTEXT_KEY, context);
|
|
54
54
|
|
|
55
|
-
const classes = $derived(cls ? `
|
|
55
|
+
const classes = $derived(cls ? `ln-collapse ${cls}` : "ln-collapse");
|
|
56
56
|
</script>
|
|
57
57
|
|
|
58
58
|
<div class={classes} role="tablist" {...attrs}>
|
|
@@ -124,13 +124,13 @@
|
|
|
124
124
|
};
|
|
125
125
|
|
|
126
126
|
const classes = $derived(
|
|
127
|
-
`
|
|
127
|
+
`ln-collapse-item ln-collapse__item${isActive ? " is-active" : ""}${disabled ? " is-disabled" : ""}${cls ? ` ${cls}` : ""}`,
|
|
128
128
|
);
|
|
129
129
|
</script>
|
|
130
130
|
|
|
131
131
|
<div class={classes} {...attrs}>
|
|
132
132
|
<div
|
|
133
|
-
class="
|
|
133
|
+
class="ln-collapse-item__header ln-collapse__header"
|
|
134
134
|
role="tab"
|
|
135
135
|
tabindex={disabled ? -1 : 0}
|
|
136
136
|
aria-expanded={isActive}
|
|
@@ -138,7 +138,7 @@
|
|
|
138
138
|
onclick={handleClick}
|
|
139
139
|
onkeydown={handleKeydown}
|
|
140
140
|
>
|
|
141
|
-
<span class="
|
|
141
|
+
<span class="ln-collapse-item__title ln-collapse__title">
|
|
142
142
|
{#if typeof title === "string"}
|
|
143
143
|
{title}
|
|
144
144
|
{:else if title}
|
|
@@ -146,7 +146,7 @@
|
|
|
146
146
|
{/if}
|
|
147
147
|
</span>
|
|
148
148
|
<span
|
|
149
|
-
class="
|
|
149
|
+
class="ln-collapse-item__arrow ln-collapse__arrow"
|
|
150
150
|
class:is-active={isActive}
|
|
151
151
|
>
|
|
152
152
|
<Icon icon={ChevronRight} size={16} />
|
|
@@ -154,7 +154,7 @@
|
|
|
154
154
|
</div>
|
|
155
155
|
|
|
156
156
|
<div
|
|
157
|
-
class="
|
|
157
|
+
class="ln-collapse-item__wrap ln-collapse__wrap"
|
|
158
158
|
class:is-active={isActive}
|
|
159
159
|
class:is-disabled={disabled}
|
|
160
160
|
role="tabpanel"
|
|
@@ -164,7 +164,7 @@
|
|
|
164
164
|
style:overflow="hidden"
|
|
165
165
|
>
|
|
166
166
|
<div
|
|
167
|
-
class="
|
|
167
|
+
class="ln-collapse-item__content ln-collapse__content"
|
|
168
168
|
bind:this={contentEl}
|
|
169
169
|
>
|
|
170
170
|
{#if children}
|