luna-plus 0.0.39 → 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.
Files changed (92) hide show
  1. package/dist/Affix/Affix.svelte +1 -1
  2. package/dist/Alert/Alert.svelte +6 -6
  3. package/dist/Autocomplete/Autocomplete.svelte +9 -9
  4. package/dist/Avatar/Avatar.svelte +5 -5
  5. package/dist/Backtop/Backtop.svelte +1 -1
  6. package/dist/Badge/Badge.svelte +4 -4
  7. package/dist/Breadcrumb/Breadcrumb.svelte +7 -7
  8. package/dist/Breadcrumb/BreadcrumbItem.svelte +6 -6
  9. package/dist/Button/Button.svelte +2 -2
  10. package/dist/Calendar/Calendar.svelte +16 -16
  11. package/dist/Card/Card.svelte +4 -4
  12. package/dist/Carousel/Carousel.svelte +6 -6
  13. package/dist/Carousel/CarouselItem.svelte +1 -1
  14. package/dist/Cascader/Cascader.svelte +12 -12
  15. package/dist/Checkbox/Checkbox.svelte +5 -5
  16. package/dist/Checkbox/CheckboxGroup.svelte +1 -1
  17. package/dist/Collapse/Collapse.svelte +1 -1
  18. package/dist/Collapse/CollapseItem.svelte +6 -6
  19. package/dist/ColorPicker/ColorPicker.svelte +13 -13
  20. package/dist/Container/Aside.svelte +1 -1
  21. package/dist/Container/Container.svelte +1 -1
  22. package/dist/Container/Footer.svelte +1 -1
  23. package/dist/Container/Header.svelte +1 -1
  24. package/dist/Container/Main.svelte +1 -1
  25. package/dist/DatePicker/DatePicker.svelte +20 -20
  26. package/dist/DateTimePicker/DateTimePicker.svelte +31 -31
  27. package/dist/Descriptions/Descriptions.svelte +6 -6
  28. package/dist/Descriptions/DescriptionsItem.svelte +6 -6
  29. package/dist/Dialog/Dialog.svelte +15 -9
  30. package/dist/Divider/Divider.svelte +6 -6
  31. package/dist/Drawer/Drawer.svelte +8 -8
  32. package/dist/Dropdown/Dropdown.svelte +8 -8
  33. package/dist/Dropdown/DropdownItem.svelte +2 -2
  34. package/dist/Dropdown/DropdownMenu.svelte +1 -1
  35. package/dist/Empty/Empty.svelte +4 -4
  36. package/dist/Form/Form.svelte +1 -1
  37. package/dist/Form/FormItem.svelte +4 -4
  38. package/dist/Icon/Icon.svelte +1 -1
  39. package/dist/Image/Image.svelte +13 -13
  40. package/dist/Input/Input.svelte +7 -7
  41. package/dist/InputNumber/InputNumber.svelte +7 -7
  42. package/dist/InputTag/InputTag.svelte +4 -4
  43. package/dist/Link/Link.svelte +1 -1
  44. package/dist/Loading/Loading.svelte +6 -6
  45. package/dist/Menu/Menu.svelte +10 -10
  46. package/dist/Message/Message.svelte +4 -4
  47. package/dist/Message/MessageQueue.svelte +4 -4
  48. package/dist/Message/message.js +1 -1
  49. package/dist/MessageBox/MessageBox.svelte +6 -6
  50. package/dist/MessageBox/messageBox.js +2 -2
  51. package/dist/Notification/Notification.svelte +8 -8
  52. package/dist/Pagination/Pagination.svelte +19 -19
  53. package/dist/PinInput/PinInput.svelte +2 -2
  54. package/dist/Popconfirm/Popconfirm.svelte +8 -8
  55. package/dist/Popover/Popover.svelte +5 -5
  56. package/dist/Progress/Progress.svelte +4 -4
  57. package/dist/Radio/Radio.svelte +5 -5
  58. package/dist/Radio/RadioGroup.svelte +1 -1
  59. package/dist/Rating/Rating.svelte +7 -7
  60. package/dist/Result/Result.svelte +6 -6
  61. package/dist/Segmented/Segmented.svelte +4 -4
  62. package/dist/Select/Option.svelte +1 -1
  63. package/dist/Select/OptionGroup.svelte +3 -3
  64. package/dist/Select/Select.svelte +13 -13
  65. package/dist/Skeleton/Skeleton.svelte +2 -2
  66. package/dist/Skeleton/SkeletonItem.svelte +1 -1
  67. package/dist/Slider/Slider.svelte +12 -12
  68. package/dist/Space/Space.svelte +5 -5
  69. package/dist/Statistic/Countdown.svelte +6 -6
  70. package/dist/Statistic/Statistic.svelte +6 -6
  71. package/dist/Steps/Step.svelte +8 -8
  72. package/dist/Steps/Steps.svelte +1 -1
  73. package/dist/Switch/Switch.svelte +7 -7
  74. package/dist/Table/Table.svelte +32 -32
  75. package/dist/Tabs/TabPane.svelte +1 -1
  76. package/dist/Tabs/Tabs.svelte +14 -14
  77. package/dist/Tabs/TabsContext.js +1 -1
  78. package/dist/Tag/Tag.svelte +2 -2
  79. package/dist/Textarea/Textarea.svelte +3 -3
  80. package/dist/TimePicker/TimePicker.svelte +19 -19
  81. package/dist/Timeline/Timeline.svelte +1 -1
  82. package/dist/Timeline/TimelineItem.svelte +7 -7
  83. package/dist/Tooltip/OverflowTooltip.svelte +5 -5
  84. package/dist/Tooltip/Tooltip.svelte +3 -3
  85. package/dist/Transfer/Transfer.svelte +30 -25
  86. package/dist/Tree/Tree.svelte +1 -1
  87. package/dist/Tree/TreeNode.svelte +6 -6
  88. package/dist/TreeSelect/TreeSelect.svelte +25 -25
  89. package/dist/Upload/Upload.svelte +32 -32
  90. package/dist/Watermark/Watermark.svelte +3 -3
  91. package/package.json +1 -1
  92. package/styles/index.css +1 -1
@@ -75,7 +75,7 @@
75
75
  window.removeEventListener('resize', updateFixed)
76
76
  })
77
77
 
78
- const classes = $derived(`lm-affix${fixed ? ' is-fixed' : ''}${cls ? ` ${cls}` : ''}`)
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
@@ -44,7 +44,7 @@
44
44
  let timer: ReturnType<typeof setTimeout> | null = null;
45
45
 
46
46
  const classes = $derived(
47
- `lm-alert lm-alert--${type}${!visible ? " is-hidden" : ""}${center ? " is-center" : ""}${cls ? ` ${cls}` : ""}`,
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="lm-alert__icon">
68
+ <div class="ln-alert__icon">
69
69
  <Icon icon={ICON_MAP[type]} size={20} />
70
70
  </div>
71
71
  {/if}
72
- <div class="lm-alert__content">
72
+ <div class="ln-alert__content">
73
73
  {#if title}
74
- <div class="lm-alert__title">{title}</div>
74
+ <div class="ln-alert__title">{title}</div>
75
75
  {/if}
76
76
  {#if children}
77
- <div class="lm-alert__description">
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="lm-alert__close"
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(['lm-autocomplete', disabled && 'is-disabled', size !== 'default' && `lm-autocomplete--${size}`, cls].filter(Boolean).join(' '))
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="lm-autocomplete__input" class:is-focus={visible}>
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="lm-autocomplete__loading" aria-label="加载中">
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="lm-autocomplete__clear" onclick={handleClear} aria-label="清除">
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="lm-autocomplete__arrow" class:is-open={visible} aria-hidden="true">
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="lm-autocomplete__dropdown" role="listbox" id="autocomplete-listbox">
142
+ <div class="ln-autocomplete__dropdown" role="listbox" id="autocomplete-listbox">
143
143
  {#if showMenuArrow}
144
- <div class="lm-autocomplete__menu-arrow" aria-hidden="true"></div>
144
+ <div class="ln-autocomplete__menu-arrow" aria-hidden="true"></div>
145
145
  {/if}
146
146
 
147
- <ul class="lm-autocomplete__menu" role="group">
147
+ <ul class="ln-autocomplete__menu" role="group">
148
148
  {#each suggestions as item, index (item[valueKey])}
149
149
  <li
150
- class="lm-autocomplete__item"
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
- ? "lm-avatar--custom"
57
- : `lm-avatar--${normalizedSize}`,
56
+ ? "ln-avatar--custom"
57
+ : `ln-avatar--${normalizedSize}`,
58
58
  );
59
59
  const classes = $derived(
60
- `lm-avatar ${sizeClass} lm-avatar--${shape}${cls ? ` ${cls}` : ""}`,
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="lm-avatar__img"
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="lm-avatar__placeholder">
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(`lm-backtop${visible ? ' is-visible' : ''}${cls ? ` ${cls}` : ''}`)
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
 
@@ -22,12 +22,12 @@
22
22
  ...attrs
23
23
  }: BadgeProps = $props();
24
24
 
25
- const classes = $derived(cls ? `lm-badge ${cls}` : "lm-badge");
25
+ const classes = $derived(cls ? `ln-badge ${cls}` : "ln-badge");
26
26
 
27
27
  const contentClasses = $derived(
28
28
  isDot
29
- ? `lm-badge__content lm-badge__content--${type} is-dot`
30
- : `lm-badge__content lm-badge__content--${type}`,
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="lm-badge__base">
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(`lm-breadcrumb${cls ? ` ${cls}` : ""}`);
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="lm-breadcrumb__item">
41
+ <li class="ln-breadcrumb__item">
42
42
  {#if item.href}
43
- <a href={item.href} class="lm-breadcrumb__link">
43
+ <a href={item.href} class="ln-breadcrumb__link">
44
44
  {#if item.icon}
45
- <Icon icon={item.icon} class="lm-breadcrumb__icon" />
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="lm-breadcrumb__text">
50
+ <span class="ln-breadcrumb__text">
51
51
  {#if item.icon}
52
- <Icon icon={item.icon} class="lm-breadcrumb__icon" />
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="lm-breadcrumb__separator">{separator}</li>
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(`lm-breadcrumb__item${cls ? ` ${cls}` : ""}`);
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="lm-breadcrumb__link">
37
+ <a href={link} class="ln-breadcrumb__link">
38
38
  {#if icon}
39
- <Icon {icon} class="lm-breadcrumb__icon" />
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="lm-breadcrumb__text">
46
+ <span class="ln-breadcrumb__text">
47
47
  {#if icon}
48
- <Icon {icon} class="lm-breadcrumb__icon" />
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="lm-breadcrumb__separator">{separator}</li>
56
+ <li class="ln-breadcrumb__separator">{separator}</li>
@@ -23,7 +23,7 @@
23
23
  }: ButtonProps = $props()
24
24
 
25
25
  const classes = $derived(
26
- `lm-button lm-button--${type} lm-button--${size}${disabled ? ' is-disabled' : ''}${loading ? ' is-loading' : ''}${plain ? ' is-plain' : ''}${round ? ' is-round' : ''}${circle ? ' is-circle' : ''}${cls ? ` ${cls}` : ''}`
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="lm-button__loading" aria-hidden="true">
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(`lm-calendar${cls ? ` ${cls}` : ''}`)
63
+ const classes = $derived(`ln-calendar${cls ? ` ${cls}` : ''}`)
64
64
  </script>
65
65
 
66
66
  <div class={classes} {...attrs}>
67
- <div class="lm-calendar__header">
68
- <div class="lm-calendar__nav">
69
- <button class="lm-calendar__btn" onclick={() => (currentDate = new Date(year - 1, month, 1))} aria-label="上一年">
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="lm-calendar__btn" onclick={() => (currentDate = new Date(year, month - 1, 1))} aria-label="上个月">
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="lm-calendar__title">
76
+ <div class="ln-calendar__title">
77
77
  {year}年 {month + 1}月
78
78
  </div>
79
- <div class="lm-calendar__nav">
80
- <button class="lm-calendar__btn" onclick={() => (currentDate = new Date(year, month + 1, 1))} aria-label="下个月">
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="lm-calendar__btn" onclick={() => (currentDate = new Date(year + 1, month, 1))} aria-label="下一年">
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="lm-calendar__body">
90
- <div class="lm-calendar__weekdays">
89
+ <div class="ln-calendar__body">
90
+ <div class="ln-calendar__weekdays">
91
91
  {#each weekDays as day}
92
- <div class="lm-calendar__weekday">{day}</div>
92
+ <div class="ln-calendar__weekday">{day}</div>
93
93
  {/each}
94
94
  </div>
95
- <div class="lm-calendar__days" role="grid">
95
+ <div class="ln-calendar__days" role="grid">
96
96
  {#each calendarDays as day}
97
97
  <button
98
98
  type="button"
99
- class="lm-calendar__day"
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="lm-calendar__footer">
113
- <button class="lm-calendar__today" onclick={goToToday}>今天</button>
112
+ <div class="ln-calendar__footer">
113
+ <button class="ln-calendar__today" onclick={goToToday}>今天</button>
114
114
  </div>
115
115
  </div>
@@ -23,10 +23,10 @@
23
23
  }: CardProps = $props()
24
24
 
25
25
  const shadowClass = $derived(shadow !== 'always' ? ` is-${shadow}-shadow` : '')
26
- const cardClasses = $derived(`lm-card${shadowClass}${cls ? ` ${cls}` : ''}`)
27
- const headerClasses = $derived(`lm-card__header${headerClass ? ` ${headerClass}` : ''}`)
28
- const bodyClasses = $derived(`lm-card__body${bodyClass ? ` ${bodyClass}` : ''}`)
29
- const footerClasses = $derived(`lm-card__footer${footerClass ? ` ${footerClass}` : ''}`)
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
- `lm-carousel lm-carousel--${direction}${indicatorPosition === "outside" ? " lm-carousel--indicator-outside" : ""}${cls ? ` ${cls}` : ""}`,
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="lm-carousel__container"
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="lm-carousel__arrow lm-carousel__arrow--prev"
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="lm-carousel__arrow lm-carousel__arrow--next"
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="lm-carousel__indicators">
194
+ <div class="ln-carousel__indicators">
195
195
  {#each indicatorIndices as i (i)}
196
196
  <button
197
197
  type="button"
198
- class="lm-carousel__indicator{activeIndex === i ? ' is-active' : ''}"
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
- `lm-carousel__item${isActive ? " is-active" : ""}${cls ? ` ${cls}` : ""}`,
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
- "lm-cascader",
142
+ "ln-cascader",
143
143
  disabled && "is-disabled",
144
- size !== "default" && `lm-cascader--${size}`,
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="lm-cascader__input"
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="lm-cascader__value" class:is-placeholder={!displayValue}>
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="lm-cascader__clear"
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="lm-cascader__arrow" class:is-open={visible}>
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="lm-cascader__dropdown"
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="lm-cascader__menu-arrow" aria-hidden="true"></div>
191
+ <div class="ln-cascader__menu-arrow" aria-hidden="true"></div>
192
192
  {/if}
193
193
  {#each menus as menu, level}
194
- <ul class="lm-cascader__menu" role="group">
194
+ <ul class="ln-cascader__menu" role="group">
195
195
  {#each menu as option (option.value)}
196
196
  <li
197
- class="lm-cascader__option"
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="lm-cascader__option-label">{option.label}</span>
206
- <span class="lm-cascader__option-suffix" aria-hidden="true">
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(`lm-checkbox lm-checkbox--${size}${checked ? ' is-checked' : ''}${disabled ? ' is-disabled' : ''}${indeterminate ? ' is-indeterminate' : ''}${cls ? ` ${cls}` : ''}`)
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="lm-checkbox__input">
36
- <input bind:this={inputRef} bind:checked {...attrs} type="checkbox" class="lm-checkbox__original" {value} {disabled} onchange={handleChange} />
37
- <span class="lm-checkbox__inner">
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="lm-checkbox__label">
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
- `lm-checkbox-group lm-checkbox-group--${size}${disabled ? " is-disabled" : ""}${cls ? ` ${cls}` : ""}`,
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 ? `lm-collapse ${cls}` : "lm-collapse");
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
- `lm-collapse-item lm-collapse__item${isActive ? " is-active" : ""}${disabled ? " is-disabled" : ""}${cls ? ` ${cls}` : ""}`,
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="lm-collapse-item__header lm-collapse__header"
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="lm-collapse-item__title lm-collapse__title">
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="lm-collapse-item__arrow lm-collapse__arrow"
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="lm-collapse-item__wrap lm-collapse__wrap"
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="lm-collapse-item__content lm-collapse__content"
167
+ class="ln-collapse-item__content ln-collapse__content"
168
168
  bind:this={contentEl}
169
169
  >
170
170
  {#if children}