nexa-ui-kit 0.7.10 → 0.8.0

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 (41) hide show
  1. package/dist/components/NAlert.js +1 -1
  2. package/dist/components/NAutocomplete.js +1 -1
  3. package/dist/components/NAvatar.js +1 -1
  4. package/dist/components/NBadge.js +1 -1
  5. package/dist/components/NBottomSheet.js +1 -1
  6. package/dist/components/NButton.js +225 -226
  7. package/dist/components/NButton.nexa +274 -275
  8. package/dist/components/NCard.js +3 -3
  9. package/dist/components/NCheckbox.js +1 -1
  10. package/dist/components/NChips.js +1 -1
  11. package/dist/components/NDataTable.js +59 -61
  12. package/dist/components/NDataTable.nexa +203 -204
  13. package/dist/components/NDatepicker.js +1 -1
  14. package/dist/components/NForm.js +1 -1
  15. package/dist/components/NFormField.js +1 -1
  16. package/dist/components/NImage.js +1 -1
  17. package/dist/components/NInput.js +1 -1
  18. package/dist/components/NInputNumber.js +17 -17
  19. package/dist/components/NInputNumber.nexa +232 -232
  20. package/dist/components/NModal.js +131 -131
  21. package/dist/components/NModal.nexa +226 -226
  22. package/dist/components/NMultiSelect.js +1 -1
  23. package/dist/components/NPaginator.js +1 -1
  24. package/dist/components/NPassword.js +1 -1
  25. package/dist/components/NProgressBar.js +1 -1
  26. package/dist/components/NRadio.js +1 -1
  27. package/dist/components/NScrollView.js +1 -1
  28. package/dist/components/NSelect.js +1 -1
  29. package/dist/components/NSkeleton.js +1 -1
  30. package/dist/components/NSwitch.js +1 -1
  31. package/dist/components/NTabs.js +1 -1
  32. package/dist/components/NTag.js +1 -1
  33. package/dist/components/NToastContainer.js +1 -1
  34. package/dist/components/NTooltip.js +1 -1
  35. package/dist/components/NTreeMenu.js +1 -1
  36. package/dist/components/NVirtualList.js +1 -1
  37. package/package.json +4 -4
  38. package/src/components/NButton.nexa +274 -275
  39. package/src/components/NDataTable.nexa +203 -204
  40. package/src/components/NInputNumber.nexa +232 -232
  41. package/src/components/NModal.nexa +226 -226
@@ -1,226 +1,226 @@
1
- <script setup>
2
- import { signal, effect, onMounted, onUnmounted } from 'nexa-framework'
3
-
4
- const props = defineProps({
5
- show: { type: Boolean, default: false },
6
- title: { type: String, default: '' },
7
- size: { type: String, default: 'md' },
8
- closable: { type: Boolean, default: true },
9
- closeLeft: { type: Boolean, default: false }
10
- })
11
-
12
- const emit = defineEmits(['close'])
13
-
14
- const isVisible = signal(false)
15
- let modalEl = null
16
- let previousFocus = null
17
- const bodyOverflow = signal('')
18
-
19
- const setModalRef = (el) => { modalEl = el }
20
-
21
- const sizeMap = { sm: '400px', md: '500px', lg: '640px', xl: '800px', full: '96%' }
22
-
23
- effect(() => {
24
- if (props.show) {
25
- previousFocus = document.activeElement
26
- isVisible.value = true
27
- bodyOverflow.value = document.body.style.overflow
28
- document.body.style.overflow = 'hidden'
29
- requestAnimationFrame(() => {
30
- if (modalEl) modalEl.focus()
31
- })
32
- } else {
33
- setTimeout(() => {
34
- isVisible.value = false
35
- document.body.style.overflow = bodyOverflow.value
36
- if (previousFocus && previousFocus.focus) {
37
- try { previousFocus.focus() } catch {}
38
- }
39
- }, 250)
40
- }
41
- })
42
-
43
- const close = () => {
44
- if (!props.closable) return
45
- emit('close')
46
- }
47
-
48
- const handleEsc = (e) => {
49
- if (e.key === 'Escape' && props.show) close()
50
- }
51
-
52
- const handleOverlayClick = (e) => {
53
- if (e.target === e.currentTarget) close()
54
- }
55
-
56
- const focusableSelector = 'a[href], button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled]), [tabindex]:not([tabindex="-1"])'
57
-
58
- const handleKeydown = (e) => {
59
- if (e.key !== 'Tab' || !modalEl) return
60
- const focusable = modalEl.querySelectorAll(focusableSelector)
61
- if (focusable.length === 0) {
62
- e.preventDefault()
63
- return
64
- }
65
- const first = focusable[0]
66
- const last = focusable[focusable.length - 1]
67
- if (e.shiftKey && document.activeElement === first) {
68
- e.preventDefault()
69
- last.focus()
70
- } else if (!e.shiftKey && document.activeElement === last) {
71
- e.preventDefault()
72
- first.focus()
73
- }
74
- }
75
-
76
- onMounted(() => {
77
- window.addEventListener('keydown', handleEsc)
78
- })
79
-
80
- onUnmounted(() => {
81
- window.removeEventListener('keydown', handleEsc)
82
- document.body.style.overflow = ''
83
- })
84
- </script>
85
-
86
- <template>
87
- <Teleport to="body">
88
- <div v-if="isVisible.value" class="n-modal-root">
89
- <div
90
- class="n-modal-overlay"
91
- :class="{ 'is-active': show }"
92
- @click="handleOverlayClick"
93
- ></div>
94
- <div
95
- :ref="setModalRef"
96
- class="n-modal-container"
97
- :class="{ 'is-active': show }"
98
- :style="{ maxWidth: sizeMap[size] || size }"
99
- tabindex="-1"
100
- @keydown="handleKeydown"
101
- >
102
- <div v-if="title || $slots.header" class="n-modal-header" :class="{ 'close-left': closeLeft }">
103
- <button v-if="closable && closeLeft" class="n-modal-close" @click="close" aria-label="Close">&times;</button>
104
- <slot name="header">
105
- <h3>{{ title }}</h3>
106
- </slot>
107
- <button v-if="closable && !closeLeft" class="n-modal-close" @click="close" aria-label="Close">&times;</button>
108
- </div>
109
- <div class="n-modal-content">
110
- <slot />
111
- </div>
112
- <div v-if="$slots.footer" class="n-modal-footer">
113
- <slot name="footer" />
114
- </div>
115
- </div>
116
- </div>
117
- </Teleport>
118
- </template>
119
-
120
- <style scoped>
121
- .n-modal-root {
122
- position: fixed;
123
- top: 0;
124
- left: 0;
125
- width: 100vw;
126
- height: 100vh;
127
- display: flex;
128
- align-items: center;
129
- justify-content: center;
130
- z-index: var(--n-z-modal);
131
- }
132
-
133
- .n-modal-overlay {
134
- position: absolute;
135
- top: 0;
136
- left: 0;
137
- width: 100%;
138
- height: 100%;
139
- background: var(--n-color-overlay);
140
- backdrop-filter: blur(8px);
141
- opacity: 0;
142
- transition: opacity 0.25s ease;
143
- }
144
-
145
- .n-modal-overlay.is-active {
146
- opacity: 1;
147
- }
148
-
149
- .n-modal-container {
150
- position: relative;
151
- width: 90%;
152
- background: var(--n-color-surface);
153
- border: 1px solid var(--n-color-border);
154
- border-radius: var(--n-radius-2xl);
155
- box-shadow: var(--n-shadow-xl);
156
- transform: scale(0.9) translateY(20px);
157
- opacity: 0;
158
- transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
159
- overflow: hidden;
160
- outline: none;
161
- max-height: 85vh;
162
- display: flex;
163
- flex-direction: column;
164
- }
165
-
166
- .n-modal-container.is-active {
167
- transform: scale(1) translateY(0);
168
- opacity: 1;
169
- }
170
-
171
- .n-modal-header {
172
- padding: var(--n-space-6) var(--n-space-8);
173
- border-bottom: 1px solid var(--n-color-border);
174
- display: flex;
175
- justify-content: space-between;
176
- align-items: center;
177
- flex-shrink: 0;
178
- }
179
-
180
- .n-modal-header h3 {
181
- margin: 0;
182
- font-size: var(--n-text-xl);
183
- font-weight: var(--n-weight-bold);
184
- color: var(--n-color-text);
185
- }
186
-
187
- .n-modal-close {
188
- background: transparent;
189
- border: none;
190
- color: var(--n-color-text-secondary);
191
- font-size: 1.75rem;
192
- cursor: pointer;
193
- transition: color var(--n-transition-fast);
194
- padding: 0;
195
- line-height: 1;
196
- width: 36px;
197
- height: 36px;
198
- display: flex;
199
- align-items: center;
200
- justify-content: center;
201
- border-radius: var(--n-radius-sm);
202
- }
203
-
204
- .n-modal-close:hover {
205
- color: var(--n-color-text);
206
- background: var(--n-color-glass);
207
- }
208
-
209
- .n-modal-content {
210
- padding: var(--n-space-8);
211
- color: var(--n-color-text-secondary);
212
- overflow-y: auto;
213
- overflow-x: hidden;
214
- flex: 1;
215
- }
216
-
217
- .n-modal-footer {
218
- padding: var(--n-space-5) var(--n-space-8);
219
- background: rgba(0, 0, 0, 0.15);
220
- border-top: 1px solid var(--n-color-border);
221
- display: flex;
222
- justify-content: flex-end;
223
- gap: var(--n-space-4);
224
- flex-shrink: 0;
225
- }
226
- </style>
1
+ <script setup>
2
+ import { signal, effect, onMounted, onUnmounted } from 'nexa-framework'
3
+
4
+ const props = defineProps({
5
+ show: { type: Boolean, default: false },
6
+ title: { type: String, default: '' },
7
+ size: { type: String, default: 'md' },
8
+ closable: { type: Boolean, default: true },
9
+ closeLeft: { type: Boolean, default: false }
10
+ })
11
+
12
+ const emit = defineEmits(['close'])
13
+
14
+ const isVisible = signal(false)
15
+ let modalEl = null
16
+ let previousFocus = null
17
+ const bodyOverflow = signal('')
18
+
19
+ const setModalRef = (el) => { modalEl = el }
20
+
21
+ const sizeMap = { sm: '400px', md: '500px', lg: '640px', xl: '800px', full: '96%' }
22
+
23
+ effect(() => {
24
+ if (props.show) {
25
+ previousFocus = document.activeElement
26
+ isVisible.value = true
27
+ bodyOverflow.value = document.body.style.overflow
28
+ document.body.style.overflow = 'hidden'
29
+ requestAnimationFrame(() => {
30
+ if (modalEl) modalEl.focus()
31
+ })
32
+ } else {
33
+ setTimeout(() => {
34
+ isVisible.value = false
35
+ document.body.style.overflow = bodyOverflow.value
36
+ if (previousFocus && previousFocus.focus) {
37
+ try { previousFocus.focus() } catch {}
38
+ }
39
+ }, 250)
40
+ }
41
+ })
42
+
43
+ const close = () => {
44
+ if (!props.closable) return
45
+ emit('close')
46
+ }
47
+
48
+ const handleEsc = (e) => {
49
+ if (e.key === 'Escape' && props.show) close()
50
+ }
51
+
52
+ const handleOverlayClick = (e) => {
53
+ if (e.target === e.currentTarget) close()
54
+ }
55
+
56
+ const focusableSelector = 'a[href], button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled]), [tabindex]:not([tabindex="-1"])'
57
+
58
+ const handleKeydown = (e) => {
59
+ if (e.key !== 'Tab' || !modalEl) return
60
+ const focusable = modalEl.querySelectorAll(focusableSelector)
61
+ if (focusable.length === 0) {
62
+ e.preventDefault()
63
+ return
64
+ }
65
+ const first = focusable[0]
66
+ const last = focusable[focusable.length - 1]
67
+ if (e.shiftKey && document.activeElement === first) {
68
+ e.preventDefault()
69
+ last.focus()
70
+ } else if (!e.shiftKey && document.activeElement === last) {
71
+ e.preventDefault()
72
+ first.focus()
73
+ }
74
+ }
75
+
76
+ onMounted(() => {
77
+ window.addEventListener('keydown', handleEsc)
78
+ })
79
+
80
+ onUnmounted(() => {
81
+ window.removeEventListener('keydown', handleEsc)
82
+ document.body.style.overflow = ''
83
+ })
84
+ </script>
85
+
86
+ <template>
87
+ <Teleport to="body">
88
+ <div v-if="isVisible.value" class="n-modal-root">
89
+ <div
90
+ class="n-modal-overlay"
91
+ :class="{ 'is-active': show }"
92
+ @click="handleOverlayClick"
93
+ ></div>
94
+ <div
95
+ :ref="setModalRef"
96
+ class="n-modal-container"
97
+ :class="{ 'is-active': show }"
98
+ :style="{ maxWidth: sizeMap[size] || size }"
99
+ tabindex="-1"
100
+ @keydown="handleKeydown"
101
+ >
102
+ <div v-if="title || $slots.header" class="n-modal-header" :class="{ 'close-left': closeLeft }">
103
+ <button v-if="closable && closeLeft" class="n-modal-close" @click="close" aria-label="Close">&times;</button>
104
+ <slot name="header">
105
+ <h3>{{ title }}</h3>
106
+ </slot>
107
+ <button v-if="closable && !closeLeft" class="n-modal-close" @click="close" aria-label="Close">&times;</button>
108
+ </div>
109
+ <div class="n-modal-content">
110
+ <slot />
111
+ </div>
112
+ <div v-if="$slots.footer" class="n-modal-footer">
113
+ <slot name="footer" />
114
+ </div>
115
+ </div>
116
+ </div>
117
+ </Teleport>
118
+ </template>
119
+
120
+ <style scoped>
121
+ .n-modal-root {
122
+ position: fixed;
123
+ top: 0;
124
+ left: 0;
125
+ width: 100vw;
126
+ height: 100vh;
127
+ display: flex;
128
+ align-items: center;
129
+ justify-content: center;
130
+ z-index: var(--n-z-modal);
131
+ }
132
+
133
+ .n-modal-overlay {
134
+ position: absolute;
135
+ top: 0;
136
+ left: 0;
137
+ width: 100%;
138
+ height: 100%;
139
+ background: var(--n-color-overlay);
140
+ backdrop-filter: blur(8px);
141
+ opacity: 0;
142
+ transition: opacity 0.25s ease;
143
+ }
144
+
145
+ .n-modal-overlay.is-active {
146
+ opacity: 1;
147
+ }
148
+
149
+ .n-modal-container {
150
+ position: relative;
151
+ width: 90%;
152
+ background: var(--n-color-surface);
153
+ border: 1px solid var(--n-color-border);
154
+ border-radius: var(--n-radius-2xl);
155
+ box-shadow: var(--n-shadow-xl);
156
+ transform: scale(0.9) translateY(20px);
157
+ opacity: 0;
158
+ transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
159
+ overflow: hidden;
160
+ outline: none;
161
+ max-height: 85vh;
162
+ display: flex;
163
+ flex-direction: column;
164
+ }
165
+
166
+ .n-modal-container.is-active {
167
+ transform: scale(1) translateY(0);
168
+ opacity: 1;
169
+ }
170
+
171
+ .n-modal-header {
172
+ padding: var(--n-space-6) var(--n-space-8);
173
+ border-bottom: 1px solid var(--n-color-border);
174
+ display: flex;
175
+ justify-content: space-between;
176
+ align-items: center;
177
+ flex-shrink: 0;
178
+ }
179
+
180
+ .n-modal-header h3 {
181
+ margin: 0;
182
+ font-size: var(--n-text-xl);
183
+ font-weight: var(--n-weight-bold);
184
+ color: var(--n-color-text);
185
+ }
186
+
187
+ .n-modal-close {
188
+ background: transparent;
189
+ border: none;
190
+ color: var(--n-color-text-secondary);
191
+ font-size: 1.75rem;
192
+ cursor: pointer;
193
+ transition: color var(--n-transition-fast);
194
+ padding: 0;
195
+ line-height: 1;
196
+ width: 36px;
197
+ height: 36px;
198
+ display: flex;
199
+ align-items: center;
200
+ justify-content: center;
201
+ border-radius: var(--n-radius-sm);
202
+ }
203
+
204
+ .n-modal-close:hover {
205
+ color: var(--n-color-text);
206
+ background: var(--n-color-glass);
207
+ }
208
+
209
+ .n-modal-content {
210
+ padding: var(--n-space-8);
211
+ color: var(--n-color-text-secondary);
212
+ overflow-y: auto;
213
+ overflow-x: hidden;
214
+ flex: 1;
215
+ }
216
+
217
+ .n-modal-footer {
218
+ padding: var(--n-space-5) var(--n-space-8);
219
+ background: rgba(0, 0, 0, 0.15);
220
+ border-top: 1px solid var(--n-color-border);
221
+ display: flex;
222
+ justify-content: flex-end;
223
+ gap: var(--n-space-4);
224
+ flex-shrink: 0;
225
+ }
226
+ </style>
@@ -64,7 +64,7 @@ const _sfc_main = defineComponent({
64
64
  })
65
65
  // Injected render function
66
66
  _sfc_main.render = function(ctx) {
67
- let { field, instanceId, isOpen, query, queryDraft, focusedIndex, popupStyle, resolvedPlacement, rootEl, stopTracking, outsideHandler, normalizeOption, normalizedOptions, effectiveModelValue, effectiveDisabled, selectedSet, filteredOptions, selectedLabels, close, open, toggleOpen, setModel, toggleValue, clear, removeChip, onKeydown, onSearchInput, inject, onBeforeUnmount, batch, trackFloatingOverlay, $slots, emit, modelValue, options, placeholder, label, disabled, bindField, searchable, clearable, placement, appendTo, maxChips, Fragment: _ntc_Fragment, Teleport: _ntc_Teleport } = ctx
67
+ const { field, instanceId, isOpen, query, queryDraft, focusedIndex, popupStyle, resolvedPlacement, rootEl, stopTracking, outsideHandler, normalizeOption, normalizedOptions, effectiveModelValue, effectiveDisabled, selectedSet, filteredOptions, selectedLabels, close, open, toggleOpen, setModel, toggleValue, clear, removeChip, onKeydown, onSearchInput, inject, onBeforeUnmount, batch, trackFloatingOverlay, $slots, emit, modelValue, options, placeholder, label, disabled, bindField, searchable, clearable, placement, appendTo, maxChips, Fragment: _ntc_Fragment, Teleport: _ntc_Teleport } = ctx
68
68
  return h('div', { class: ["n-ms", { 'is-open': isOpen.value, 'is-disabled': effectiveDisabled.value }], "data-ms-root": instanceId, "data-v-12b3b8c4": "" }, [
69
69
  "\n ",
70
70
  (label) ? h('label', { class: "n-ms-label", "data-v-12b3b8c4": "" }, [
@@ -51,7 +51,7 @@ const _sfc_main = defineComponent({
51
51
  })
52
52
  // Injected render function
53
53
  _sfc_main.render = function(ctx) {
54
- let { safeFirst, safeRows, page, pageCount, canPrev, canNext, goToPage, prev, next, firstPage, lastPage, changeRows, start, end, $slots, emit, first, rows, totalRecords, rowsPerPageOptions, Fragment: _ntc_Fragment } = ctx
54
+ const { safeFirst, safeRows, page, pageCount, canPrev, canNext, goToPage, prev, next, firstPage, lastPage, changeRows, start, end, $slots, emit, first, rows, totalRecords, rowsPerPageOptions, Fragment: _ntc_Fragment } = ctx
55
55
  return h('div', { class: "n-paginator", "data-v-372b30ac": "" }, [
56
56
  "\n ",
57
57
  h('div', { class: "n-paginator-left", "data-v-372b30ac": "" }, [
@@ -98,7 +98,7 @@ const _sfc_main = defineComponent({
98
98
  })
99
99
  // Injected render function
100
100
  _sfc_main.render = function(ctx) {
101
- let { instanceId, inputId, masked, type, hasValue, requirements, strength, internalError, errorMessage, ariaInvalid, describedBy, onInput, clear, toggle, $slots, emit, modelValue, placeholder, label, error, disabled, readonly, name, autocomplete, id, clearable, toggleMask, showStrength, validate, showRequirements, minLength, requireLower, requireUpper, requireNumber, requireSpecial, Fragment: _ntc_Fragment } = ctx
101
+ const { instanceId, inputId, masked, type, hasValue, requirements, strength, internalError, errorMessage, ariaInvalid, describedBy, onInput, clear, toggle, $slots, emit, modelValue, placeholder, label, error, disabled, readonly, name, autocomplete, id, clearable, toggleMask, showStrength, validate, showRequirements, minLength, requireLower, requireUpper, requireNumber, requireSpecial, Fragment: _ntc_Fragment } = ctx
102
102
  return h('div', { class: "n-password", "data-v-7b897096": "" }, [
103
103
  "\n ",
104
104
  (label) ? h('label', { class: "n-password-label", for: inputId.value, "data-v-7b897096": "" }, [
@@ -20,7 +20,7 @@ const _sfc_main = defineComponent({
20
20
  })
21
21
  // Injected render function
22
22
  _sfc_main.render = function(ctx) {
23
- let { percentage, $slots, value, max, variant, size, showLabel, striped, animated, Fragment: _ntc_Fragment } = ctx
23
+ const { percentage, $slots, value, max, variant, size, showLabel, striped, animated, Fragment: _ntc_Fragment } = ctx
24
24
  return h('div', { class: ["n-progress", [`is-${size}`, striped ? 'is-striped' : '', animated ? 'is-animated' : '']], "data-v-daaa1d0": "" }, [
25
25
  "\n ",
26
26
  h('div', { class: "n-progress-track", "data-v-daaa1d0": "" }, [
@@ -23,7 +23,7 @@ const _sfc_main = defineComponent({
23
23
  })
24
24
  // Injected render function
25
25
  _sfc_main.render = function(ctx) {
26
- let { isChecked, select, $slots, emit, modelValue, value, label, disabled, name, Fragment: _ntc_Fragment } = ctx
26
+ const { isChecked, select, $slots, emit, modelValue, value, label, disabled, name, Fragment: _ntc_Fragment } = ctx
27
27
  return h('label', { class: ["n-radio", { 'is-checked': isChecked(), 'is-disabled': disabled }], "data-v-5c3cc2": "" }, [
28
28
  "\n ",
29
29
  h('div', { class: "n-radio-circle", onClick: select, "data-v-5c3cc2": "" }, [
@@ -63,7 +63,7 @@ const _sfc_main = defineComponent({
63
63
  })
64
64
  // Injected render function
65
65
  _sfc_main.render = function(ctx) {
66
- let { isRefreshing, pullDelta, refreshThreshold, touchStartY, startScrollTop, pullProgress, spinnerScale, onTouchStart, onTouchMove, onTouchEnd, onScroll, $slots, onRefresh, onEndReached, endReachedThreshold, horizontal, Fragment: _ntc_Fragment } = ctx
66
+ const { isRefreshing, pullDelta, refreshThreshold, touchStartY, startScrollTop, pullProgress, spinnerScale, onTouchStart, onTouchMove, onTouchEnd, onScroll, $slots, onRefresh, onEndReached, endReachedThreshold, horizontal, Fragment: _ntc_Fragment } = ctx
67
67
  return h('div', { class: ["n-scroll-view", { 'n-scroll-view--horizontal': horizontal }], onScroll: onScroll, onTouchstart: onTouchStart, onTouchmove: onTouchMove, onTouchend: onTouchEnd, "data-v-7469d561": "" }, [
68
68
  "\n ",
69
69
  (onRefresh) ? h('div', { class: ["n-scroll-view-ptr", { 'is-refreshing': isRefreshing.value }], style: { height: pullDelta.value + 'px' }, "data-v-7469d561": "" }, [
@@ -174,7 +174,7 @@ const _sfc_main = defineComponent({
174
174
  })
175
175
  // Injected render function
176
176
  _sfc_main.render = function(ctx) {
177
- let { isOpen, query, focusedIndex, instanceId, popupStyle, resolvedPlacement, rootEl, stopTracking, outsideHandler, filteredOptions, selectedOption, close, open, toggle, select, clear, handleKeydown, getFlatOptions, onBeforeUnmount, trackFloatingOverlay, $slots, emit, modelValue, options, placeholder, label, disabled, searchable, clearable, placement, appendTo, Fragment: _ntc_Fragment, Teleport: _ntc_Teleport } = ctx
177
+ const { isOpen, query, focusedIndex, instanceId, popupStyle, resolvedPlacement, rootEl, stopTracking, outsideHandler, filteredOptions, selectedOption, close, open, toggle, select, clear, handleKeydown, getFlatOptions, onBeforeUnmount, trackFloatingOverlay, $slots, emit, modelValue, options, placeholder, label, disabled, searchable, clearable, placement, appendTo, Fragment: _ntc_Fragment, Teleport: _ntc_Teleport } = ctx
178
178
  return h('div', { class: ["n-select", { 'is-open': isOpen.value, 'is-disabled': disabled }], "data-select-root": instanceId, "data-v-fef169b": "" }, [
179
179
  "\n ",
180
180
  (label) ? h('label', { class: "n-select-label", "data-v-fef169b": "" }, [
@@ -17,7 +17,7 @@ const _sfc_main = defineComponent({
17
17
  })
18
18
  // Injected render function
19
19
  _sfc_main.render = function(ctx) {
20
- let { lineArray, $slots, variant, lines, width, height, Fragment: _ntc_Fragment } = ctx
20
+ const { lineArray, $slots, variant, lines, width, height, Fragment: _ntc_Fragment } = ctx
21
21
  return h('div', { class: ["n-skeleton", `is-${variant}`], style: { width, height }, "data-v-6b9116c8": "" }, [
22
22
  "\n ",
23
23
  (variant === 'text') ? h('div', { class: "n-skeleton-lines", "data-v-6b9116c8": "" }, [
@@ -20,7 +20,7 @@ const _sfc_main = defineComponent({
20
20
  })
21
21
  // Injected render function
22
22
  _sfc_main.render = function(ctx) {
23
- let { toggle, $slots, emit, modelValue, disabled, label, Fragment: _ntc_Fragment } = ctx
23
+ const { toggle, $slots, emit, modelValue, disabled, label, Fragment: _ntc_Fragment } = ctx
24
24
  return h('label', { class: ["n-switch", { 'is-checked': modelValue, 'is-disabled': disabled }], "data-v-3cd56cb4": "" }, [
25
25
  "\n ",
26
26
  h('div', { class: "n-switch-track", onClick: toggle, "data-v-3cd56cb4": "" }, [
@@ -22,7 +22,7 @@ const _sfc_main = defineComponent({
22
22
  })
23
23
  // Injected render function
24
24
  _sfc_main.render = function(ctx) {
25
- let { activeKey, select, activeIndex, $slots, emit, tabs, modelValue, Fragment: _ntc_Fragment } = ctx
25
+ const { activeKey, select, activeIndex, $slots, emit, tabs, modelValue, Fragment: _ntc_Fragment } = ctx
26
26
  return h('div', { class: "n-tabs", "data-v-339e5ee5": "" }, [
27
27
  "\n ",
28
28
  h('div', { class: "n-tabs-header", "data-v-339e5ee5": "" }, [
@@ -17,7 +17,7 @@ const _sfc_main = defineComponent({
17
17
  })
18
18
  // Injected render function
19
19
  _sfc_main.render = function(ctx) {
20
- let { $slots, emit, variant, size, closable, rounded, Fragment: _ntc_Fragment } = ctx
20
+ const { $slots, emit, variant, size, closable, rounded, Fragment: _ntc_Fragment } = ctx
21
21
  return h('span', { class: ['n-tag', `n-tag-${variant}`, `n-tag-${size}`, rounded ? 'is-rounded' : ''], "data-v-4d63a958": "" }, [
22
22
  "\n ",
23
23
  ctx.$slots.default ? ctx.$slots.default() : null,
@@ -16,7 +16,7 @@ const _sfc_main = defineComponent({
16
16
  })
17
17
  // Injected render function
18
18
  _sfc_main.render = function(ctx) {
19
- let { toasts, remove, positionClass, useToast, $slots, position, Fragment: _ntc_Fragment, Teleport: _ntc_Teleport } = ctx
19
+ const { toasts, remove, positionClass, useToast, $slots, position, Fragment: _ntc_Fragment, Teleport: _ntc_Teleport } = ctx
20
20
  return h(_ntc_Teleport, { to: "body", "data-v-8ac4158": "" }, [
21
21
  "\n ",
22
22
  h('div', { class: ["n-toast-container", positionClass], "data-v-8ac4158": "" }, [
@@ -66,7 +66,7 @@ const _sfc_main = defineComponent({
66
66
  })
67
67
  // Injected render function
68
68
  _sfc_main.render = function(ctx) {
69
- let { isVisible, instanceId, popupStyle, resolvedPlacement, rootEl, stopTracking, showTimer, hideTimer, startTracking, stop, show, hide, trackFloatingOverlay, $slots, text, position, delay, hideDelay, Fragment: _ntc_Fragment, Teleport: _ntc_Teleport } = ctx
69
+ const { isVisible, instanceId, popupStyle, resolvedPlacement, rootEl, stopTracking, showTimer, hideTimer, startTracking, stop, show, hide, trackFloatingOverlay, $slots, text, position, delay, hideDelay, Fragment: _ntc_Fragment, Teleport: _ntc_Teleport } = ctx
70
70
  return h('div', { class: "n-tooltip-wrapper", "data-tooltip-root": instanceId, onMouseenter: show, onMouseleave: hide, onFocusin: show, onFocusout: hide, "data-v-522b965d": "" }, [
71
71
  "\n ",
72
72
  ctx.$slots.default ? ctx.$slots.default() : null,
@@ -47,7 +47,7 @@ const _sfc_main = defineComponent({
47
47
  })
48
48
  // Injected render function
49
49
  _sfc_main.render = function(ctx) {
50
- let { expanded, toggleExpand, selectItem, hasChildren, isExpanded, isSelected, flatTree, toggle, $slots, emit, items, selectable, selected, Fragment: _ntc_Fragment } = ctx
50
+ const { expanded, toggleExpand, selectItem, hasChildren, isExpanded, isSelected, flatTree, toggle, $slots, emit, items, selectable, selected, Fragment: _ntc_Fragment } = ctx
51
51
  return h('div', { class: "n-tree-menu", "data-v-44b3942a": "" }, [
52
52
  "\n ",
53
53
  (flatTree.value).map((item, index) =>
@@ -51,7 +51,7 @@ const _sfc_main = defineComponent({
51
51
  })
52
52
  // Injected render function
53
53
  _sfc_main.render = function(ctx) {
54
- let { containerRef, scrollTop, containerHeight, totalHeight, visibleRange, visibleItems, resizeObserver, onScroll, $slots, items, itemHeight, overscan, renderItem, keyFn, Fragment: _ntc_Fragment } = ctx
54
+ const { containerRef, scrollTop, containerHeight, totalHeight, visibleRange, visibleItems, resizeObserver, onScroll, $slots, items, itemHeight, overscan, renderItem, keyFn, Fragment: _ntc_Fragment } = ctx
55
55
  return h('div', { class: "n-virtual-list", onScroll: onScroll, ref: el => containerRef.value = el, "data-v-2d5f09ed": "" }, [
56
56
  "\n ",
57
57
  h('div', { class: "n-virtual-list-spacer", style: { height: totalHeight.value + 'px', position: 'relative' }, "data-v-2d5f09ed": "" }, [
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nexa-ui-kit",
3
- "version": "0.7.10",
3
+ "version": "0.8.0",
4
4
  "description": "Premium component library for Nexa Framework",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -22,12 +22,12 @@
22
22
  "src"
23
23
  ],
24
24
  "dependencies": {
25
- "nexa-framework": "0.7.10",
26
- "nexa-mobile": "0.7.10"
25
+ "nexa-mobile": "0.8.0",
26
+ "nexa-framework": "0.8.0"
27
27
  },
28
28
  "devDependencies": {
29
29
  "cpx": "^1.5.0",
30
- "nexa-compiler": "0.7.10"
30
+ "nexa-compiler": "0.8.0"
31
31
  },
32
32
  "scripts": {
33
33
  "build": "tsc && node scripts/compile-nexa.js && node scripts/patch-imports.js && cpx \"src/**/*.nexa\" dist && cpx \"src/styles/*.css\" dist/styles",