@bitrix24/b24ui-nuxt 0.4.1 → 0.4.2

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 (56) hide show
  1. package/.nuxt/b24ui/button.ts +8 -0
  2. package/.nuxt/b24ui/modal.ts +22 -4
  3. package/.nuxt/b24ui/prose/blockquote.ts +5 -0
  4. package/.nuxt/b24ui/prose/em.ts +5 -0
  5. package/.nuxt/b24ui/prose/h1.ts +6 -0
  6. package/.nuxt/b24ui/prose/{prose-h2.ts → h2.ts} +1 -1
  7. package/.nuxt/b24ui/prose/{prose-h3.ts → h3.ts} +1 -1
  8. package/.nuxt/b24ui/prose/h4.ts +16 -0
  9. package/.nuxt/b24ui/prose/h5.ts +16 -0
  10. package/.nuxt/b24ui/prose/h6.ts +16 -0
  11. package/.nuxt/b24ui/prose/hr.ts +5 -0
  12. package/.nuxt/b24ui/prose/ol.ts +5 -0
  13. package/.nuxt/b24ui/prose/strong.ts +5 -0
  14. package/.nuxt/b24ui/prose/ul.ts +5 -0
  15. package/.nuxt/b24ui/slideover.ts +25 -7
  16. package/dist/meta.cjs +854 -195
  17. package/dist/meta.d.cts +854 -195
  18. package/dist/meta.d.mts +854 -195
  19. package/dist/meta.d.ts +854 -195
  20. package/dist/meta.mjs +854 -195
  21. package/dist/module.cjs +2 -2
  22. package/dist/module.json +1 -1
  23. package/dist/module.mjs +2 -2
  24. package/dist/runtime/components/Button.vue +83 -45
  25. package/dist/runtime/components/Modal.vue +13 -2
  26. package/dist/runtime/components/Slideover.vue +10 -2
  27. package/dist/runtime/composables/useComponentIcons.d.ts +2 -2
  28. package/dist/runtime/prose/Blockquote.vue +36 -0
  29. package/dist/runtime/prose/Em.vue +36 -0
  30. package/dist/runtime/prose/{ProseH1.vue → H1.vue} +1 -1
  31. package/dist/runtime/prose/{ProseH2.vue → H2.vue} +1 -1
  32. package/dist/runtime/prose/{ProseH3.vue → H3.vue} +1 -1
  33. package/dist/runtime/prose/H4.vue +36 -0
  34. package/dist/runtime/prose/H5.vue +36 -0
  35. package/dist/runtime/prose/H6.vue +36 -0
  36. package/dist/runtime/prose/Hr.vue +30 -0
  37. package/dist/runtime/prose/{ProseLi.vue → Li.vue} +1 -1
  38. package/dist/runtime/prose/{ProseOl.vue → Ol.vue} +1 -1
  39. package/dist/runtime/prose/{ProseP.vue → P.vue} +1 -1
  40. package/dist/runtime/prose/Strong.vue +36 -0
  41. package/dist/runtime/prose/{ProseUl.vue → Ul.vue} +1 -1
  42. package/dist/runtime/types/index.d.ts +14 -7
  43. package/dist/runtime/types/index.js +14 -7
  44. package/dist/runtime/vue/components/Link.vue +2 -2
  45. package/dist/shared/{b24ui-nuxt.CnMGpwQb.cjs → b24ui-nuxt.Bt28CeAD.cjs} +185 -40
  46. package/dist/shared/{b24ui-nuxt.BGGwh89R.mjs → b24ui-nuxt.Bx_-_mhu.mjs} +185 -40
  47. package/dist/unplugin.cjs +3 -3
  48. package/dist/unplugin.mjs +3 -3
  49. package/dist/vite.cjs +1 -1
  50. package/dist/vite.mjs +1 -1
  51. package/package.json +4 -4
  52. package/.nuxt/b24ui/prose/prose-h1.ts +0 -6
  53. package/.nuxt/b24ui/prose/prose-ol.ts +0 -5
  54. package/.nuxt/b24ui/prose/prose-ul.ts +0 -5
  55. /package/.nuxt/b24ui/prose/{prose-li.ts → li.ts} +0 -0
  56. /package/.nuxt/b24ui/prose/{prose-p.ts → p.ts} +0 -0
package/dist/module.cjs CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  const defu = require('defu');
4
4
  const kit = require('@nuxt/kit');
5
- const templates = require('./shared/b24ui-nuxt.CnMGpwQb.cjs');
5
+ const templates = require('./shared/b24ui-nuxt.Bt28CeAD.cjs');
6
6
  require('node:url');
7
7
  require('scule');
8
8
 
@@ -48,7 +48,7 @@ const module$1 = kit.defineNuxtModule({
48
48
  });
49
49
  kit.addComponentsDir({
50
50
  path: resolve("./runtime/prose"),
51
- prefix: "",
51
+ prefix: "Prose",
52
52
  pathPrefix: false
53
53
  });
54
54
  kit.addImportsDir(resolve("./runtime/composables"));
package/dist/module.json CHANGED
@@ -5,7 +5,7 @@
5
5
  "nuxt": ">=3.13.1"
6
6
  },
7
7
  "docs": "https://bitrix24.github.io/b24ui/guide/installation-nuxt-app.html",
8
- "version": "0.4.1",
8
+ "version": "0.4.2",
9
9
  "builder": {
10
10
  "@nuxt/module-builder": "0.8.4",
11
11
  "unbuild": "2.0.0"
package/dist/module.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  import { defu } from 'defu';
2
2
  import { defineNuxtModule, createResolver, addVitePlugin, addPlugin, addComponentsDir, addImportsDir, hasNuxtModule, installModule } from '@nuxt/kit';
3
- import { d as defaultOptions, a as getDefaultUiConfig, b as addTemplates } from './shared/b24ui-nuxt.BGGwh89R.mjs';
3
+ import { d as defaultOptions, a as getDefaultUiConfig, b as addTemplates } from './shared/b24ui-nuxt.Bx_-_mhu.mjs';
4
4
  import 'node:url';
5
5
  import 'scule';
6
6
 
@@ -45,7 +45,7 @@ const module = defineNuxtModule({
45
45
  });
46
46
  addComponentsDir({
47
47
  path: resolve("./runtime/prose"),
48
- prefix: "",
48
+ prefix: "Prose",
49
49
  pathPrefix: false
50
50
  });
51
51
  addImportsDir(resolve("./runtime/composables"));
@@ -21,10 +21,12 @@ export interface ButtonProps extends Omit<UseComponentIconsProps, 'trailing' | '
21
21
  * @defaultValue 'default'
22
22
  */
23
23
  color?: ButtonVariants['color']
24
+ activeColor?: ButtonVariants['color']
24
25
  /**
25
26
  * @defaultValue 'normal'
26
27
  */
27
28
  depth?: ButtonVariants['depth']
29
+ activeDepth?: ButtonVariants['depth']
28
30
  /**
29
31
  * @defaultValue 'md'
30
32
  */
@@ -66,6 +68,16 @@ export interface ButtonProps extends Omit<UseComponentIconsProps, 'trailing' | '
66
68
  useDropdown?: boolean
67
69
  onClick?: ((event: MouseEvent) => void | Promise<void>) | Array<((event: MouseEvent) => void | Promise<void>)>
68
70
  class?: any
71
+ /**
72
+ * The class to apply when the link is active
73
+ * @defaultValue ''
74
+ */
75
+ activeClass?: string
76
+ /**
77
+ * The class to apply when the link is inactive
78
+ * @defaultValue ''
79
+ */
80
+ inactiveClass?: string
69
81
  b24ui?: PartialString<typeof button.slots>
70
82
  }
71
83
 
@@ -92,7 +104,10 @@ import LoaderClockIcon from '@bitrix24/b24icons-vue/animated/LoaderClockIcon'
92
104
  import SpinnerIcon from '@bitrix24/b24icons-vue/specialized/SpinnerIcon'
93
105
 
94
106
  const props = withDefaults(defineProps<ButtonProps>(), {
95
- type: 'button'
107
+ type: 'button',
108
+ active: undefined,
109
+ activeClass: '',
110
+ inactiveClass: ''
96
111
  })
97
112
 
98
113
  const slots = defineSlots<ButtonSlots>()
@@ -132,7 +147,19 @@ const isLabel = computed(() => {
132
147
  return (props?.label || '').length > 0 || isUseSlot
133
148
  })
134
149
 
135
- const b24ui = computed(() => button({
150
+ const b24ui = computed(() => tv({
151
+ extend: button,
152
+ variants: {
153
+ active: {
154
+ true: {
155
+ base: props.activeClass
156
+ },
157
+ false: {
158
+ base: props.inactiveClass
159
+ }
160
+ }
161
+ }
162
+ })({
136
163
  color: props.color,
137
164
  depth: props.depth,
138
165
  size: buttonSize.value,
@@ -152,54 +179,65 @@ const b24ui = computed(() => button({
152
179
 
153
180
  <template>
154
181
  <B24Link
182
+ v-slot="{ active, ...slotProps }"
155
183
  :type="type"
156
184
  :disabled="disabled || isLoading"
157
185
  :class="b24ui.base({ class: [props.class, props.b24ui?.base] })"
158
186
  v-bind="omit(linkProps, ['type', 'disabled'])"
159
- raw
160
- @click="onClickWrapper"
187
+ custom
161
188
  >
162
- <div
163
- v-if="isLoading"
164
- class="h-full w-full absolute inset-0 flex flex-row flex-nowrap items-center justify-center"
165
- >
166
- <LoaderWaitIcon v-if="useWait" class="w-[28px] h-[28px]" aria-hidden="true" />
167
- <LoaderClockIcon v-else-if="useClock" class="w-[28px] h-[28px]" aria-hidden="true" />
168
- <SpinnerIcon v-else class="size-lg animate-spin stroke-2" aria-hidden="true" />
169
- </div>
170
- <div
171
- :class="[
172
- b24ui.baseLine({ class: [props.b24ui?.baseLine] }),
173
- isLoading ? 'invisible' : ''
174
- ]"
189
+ <B24LinkBase
190
+ v-bind="slotProps"
191
+ :class="b24ui.base({
192
+ class: [props.class, props.b24ui?.base],
193
+ active,
194
+ ...(active && activeDepth ? { depth: activeDepth } : {}),
195
+ ...(active && activeColor ? { color: activeColor } : {})
196
+ })"
197
+ @click="onClickWrapper"
175
198
  >
176
- <slot name="leading">
177
- <Component
178
- :is="leadingIconName"
179
- v-if="isLeading && (typeof leadingIconName !== 'undefined')"
180
- :class="b24ui.leadingIcon({ class: props.b24ui?.leadingIcon })"
181
- />
182
- <B24Avatar
183
- v-else-if="!!avatar"
184
- :size="((props.b24ui?.leadingAvatarSize || b24ui.leadingAvatarSize()) as AvatarProps['size'])"
185
- v-bind="avatar"
186
- :class="b24ui.leadingAvatar({ class: props.b24ui?.leadingAvatar })"
187
- />
188
- </slot>
189
-
190
- <slot>
191
- <span v-if="label" :class="b24ui.label({ class: props.b24ui?.label })">
192
- {{ label }}
193
- </span>
194
- </slot>
195
-
196
- <slot name="trailing">
197
- <ChevronDownIcon
198
- v-if="useDropdown"
199
- :class="b24ui.trailingIcon({ class: props.b24ui?.trailingIcon })"
200
- aria-hidden="true"
201
- />
202
- </slot>
203
- </div>
199
+ <div
200
+ v-if="isLoading"
201
+ class="h-full w-full absolute inset-0 flex flex-row flex-nowrap items-center justify-center"
202
+ >
203
+ <LoaderWaitIcon v-if="useWait" class="w-[28px] h-[28px]" aria-hidden="true" />
204
+ <LoaderClockIcon v-else-if="useClock" class="w-[28px] h-[28px]" aria-hidden="true" />
205
+ <SpinnerIcon v-else class="size-lg animate-spin stroke-2" aria-hidden="true" />
206
+ </div>
207
+ <div
208
+ :class="[
209
+ b24ui.baseLine({ class: [props.b24ui?.baseLine] }),
210
+ isLoading ? 'invisible' : ''
211
+ ]"
212
+ >
213
+ <slot name="leading">
214
+ <Component
215
+ :is="leadingIconName"
216
+ v-if="isLeading && (typeof leadingIconName !== 'undefined')"
217
+ :class="b24ui.leadingIcon({ class: props.b24ui?.leadingIcon })"
218
+ />
219
+ <B24Avatar
220
+ v-else-if="!!avatar"
221
+ :size="((props.b24ui?.leadingAvatarSize || b24ui.leadingAvatarSize()) as AvatarProps['size'])"
222
+ v-bind="avatar"
223
+ :class="b24ui.leadingAvatar({ class: props.b24ui?.leadingAvatar })"
224
+ />
225
+ </slot>
226
+
227
+ <slot>
228
+ <span v-if="label" :class="b24ui.label({ class: props.b24ui?.label, active })">
229
+ {{ label }}
230
+ </span>
231
+ </slot>
232
+
233
+ <slot name="trailing">
234
+ <ChevronDownIcon
235
+ v-if="useDropdown"
236
+ :class="b24ui.trailingIcon({ class: props.b24ui?.trailingIcon })"
237
+ aria-hidden="true"
238
+ />
239
+ </slot>
240
+ </div>
241
+ </B24LinkBase>
204
242
  </B24Link>
205
243
  </template>
@@ -1,5 +1,6 @@
1
1
  <script lang="ts">
2
2
  import type { DialogRootProps, DialogRootEmits, DialogContentProps } from 'reka-ui'
3
+ import type { VariantProps } from 'tailwind-variants'
3
4
  import type { AppConfig } from '@nuxt/schema'
4
5
  import _appConfig from '#build/app.config'
5
6
  import theme from '#build/b24ui/modal'
@@ -10,6 +11,8 @@ const appConfigModal = _appConfig as AppConfig & { b24ui: { modal: Partial<typeo
10
11
 
11
12
  const modal = tv({ extend: tv(theme), ...(appConfigModal.b24ui?.modal || {}) })
12
13
 
14
+ type ModalVariants = VariantProps<typeof modal>
15
+
13
16
  export interface ModalProps extends DialogRootProps {
14
17
  title?: string
15
18
  description?: string
@@ -22,6 +25,12 @@ export interface ModalProps extends DialogRootProps {
22
25
  * @defaultValue true
23
26
  */
24
27
  overlay?: boolean
28
+ /**
29
+ * Render an overlay blur behind the modal.
30
+ * `auto` use `motion-safe`.
31
+ * @defaultValue 'auto'
32
+ */
33
+ overlayBlur?: ModalVariants['overlayBlur']
25
34
  /**
26
35
  * Animate the modal when opening or closing.
27
36
  * @defaultValue true
@@ -93,7 +102,8 @@ const props = withDefaults(defineProps<ModalProps>(), {
93
102
  transition: true,
94
103
  modal: true,
95
104
  dismissible: true,
96
- scrollbarThin: true
105
+ scrollbarThin: true,
106
+ overlayBlur: 'auto'
97
107
  })
98
108
  const emits = defineEmits<ModalEmits>()
99
109
  const slots = defineSlots<ModalSlots>()
@@ -119,7 +129,8 @@ const contentEvents = computed(() => {
119
129
 
120
130
  const b24ui = computed(() => modal({
121
131
  transition: props.transition,
122
- fullscreen: props.fullscreen
132
+ fullscreen: props.fullscreen,
133
+ overlayBlur: props.overlayBlur
123
134
  }))
124
135
  </script>
125
136
 
@@ -25,6 +25,12 @@ export interface SlideoverProps extends DialogRootProps {
25
25
  * @defaultValue true
26
26
  */
27
27
  overlay?: boolean
28
+ /**
29
+ * Render an overlay blur behind the slideover.
30
+ * `auto` use `motion-safe`.
31
+ * @defaultValue 'auto'
32
+ */
33
+ overlayBlur?: SlideoverVariants['overlayBlur']
28
34
  /**
29
35
  * Animate the slideover when opening or closing.
30
36
  * @defaultValue true
@@ -98,7 +104,8 @@ const props = withDefaults(defineProps<SlideoverProps>(), {
98
104
  modal: true,
99
105
  dismissible: true,
100
106
  side: 'right',
101
- scrollbarThin: true
107
+ scrollbarThin: true,
108
+ overlayBlur: 'auto'
102
109
  })
103
110
  const emits = defineEmits<SlideoverEmits>()
104
111
  const slots = defineSlots<SlideoverSlots>()
@@ -124,7 +131,8 @@ const contentEvents = computed(() => {
124
131
 
125
132
  const b24ui = computed(() => slideover({
126
133
  transition: props.transition,
127
- side: props.side
134
+ side: props.side,
135
+ overlayBlur: props.overlayBlur
128
136
  }))
129
137
  </script>
130
138
 
@@ -22,6 +22,6 @@ export interface UseComponentIconsProps {
22
22
  export declare function useComponentIcons(componentProps: MaybeRefOrGetter<UseComponentIconsProps>): {
23
23
  isLeading: import("vue").ComputedRef<any>;
24
24
  isTrailing: import("vue").ComputedRef<boolean>;
25
- leadingIconName: import("vue").ComputedRef<import("vue").FunctionalComponent<import("vue").HTMLAttributes & import("vue").VNodeProps, {}, any, {}> | undefined>;
26
- trailingIconName: import("vue").ComputedRef<import("vue").FunctionalComponent<import("vue").HTMLAttributes & import("vue").VNodeProps, {}, any, {}> | undefined>;
25
+ leadingIconName: import("vue").ComputedRef<IconComponent | undefined>;
26
+ trailingIconName: import("vue").ComputedRef<IconComponent | undefined>;
27
27
  };
@@ -0,0 +1,36 @@
1
+ <script lang="ts">
2
+ import type { AppConfig } from '@nuxt/schema'
3
+ import _appConfig from '#build/app.config'
4
+ import theme from '#build/b24ui/prose/blockquote'
5
+ import { tv } from '../utils/tv'
6
+
7
+ const appConfigProseBlockquote = _appConfig as AppConfig & { b24ui: { prose: { blockquote: Partial<typeof theme> } } }
8
+
9
+ const proseBlockquote = tv({ extend: tv(theme), ...(appConfigProseBlockquote.b24ui?.prose?.blockquote || {}) })
10
+
11
+ export interface proseBlockquoteProps {
12
+ class?: any
13
+ b24ui?: Partial<typeof proseBlockquote.slots>
14
+ }
15
+
16
+ export interface proseBlockquoteSlots {
17
+ default(props?: {}): any
18
+ }
19
+ </script>
20
+
21
+ <script setup lang="ts">
22
+ defineOptions({ inheritAttrs: false })
23
+
24
+ const props = defineProps<proseBlockquoteProps>()
25
+
26
+ // eslint-disable-next-line vue/no-dupe-keys
27
+ const b24ui = proseBlockquote({})
28
+ </script>
29
+
30
+ <template>
31
+ <blockquote
32
+ :class="b24ui.base({ class: [props.class, props.b24ui?.base] })"
33
+ >
34
+ <slot />
35
+ </blockquote>
36
+ </template>
@@ -0,0 +1,36 @@
1
+ <script lang="ts">
2
+ import type { AppConfig } from '@nuxt/schema'
3
+ import _appConfig from '#build/app.config'
4
+ import theme from '#build/b24ui/prose/em'
5
+ import { tv } from '../utils/tv'
6
+
7
+ const appConfigPproseEm = _appConfig as AppConfig & { b24ui: { prose: { em: Partial<typeof theme> } } }
8
+
9
+ const pproseEm = tv({ extend: tv(theme), ...(appConfigPproseEm.b24ui?.prose?.em || {}) })
10
+
11
+ export interface pproseEmProps {
12
+ class?: any
13
+ b24ui?: Partial<typeof pproseEm.slots>
14
+ }
15
+
16
+ export interface pproseEmSlots {
17
+ default(props?: {}): any
18
+ }
19
+ </script>
20
+
21
+ <script setup lang="ts">
22
+ defineOptions({ inheritAttrs: false })
23
+
24
+ const props = defineProps<pproseEmProps>()
25
+
26
+ // eslint-disable-next-line vue/no-dupe-keys
27
+ const b24ui = pproseEm({})
28
+ </script>
29
+
30
+ <template>
31
+ <em
32
+ :class="b24ui.base({ class: [props.class, props.b24ui?.base] })"
33
+ >
34
+ <slot />
35
+ </em>
36
+ </template>
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import type { AppConfig } from '@nuxt/schema'
3
3
  import _appConfig from '#build/app.config'
4
- import theme from '#build/b24ui/prose/prose-h1'
4
+ import theme from '#build/b24ui/prose/h1'
5
5
  import { tv } from '../utils/tv'
6
6
 
7
7
  const appConfigProseH1 = _appConfig as AppConfig & { b24ui: { prose: { h1: Partial<typeof theme> } } }
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import type { AppConfig } from '@nuxt/schema'
3
3
  import _appConfig from '#build/app.config'
4
- import theme from '#build/b24ui/prose/prose-h2'
4
+ import theme from '#build/b24ui/prose/h2'
5
5
  import { tv } from '../utils/tv'
6
6
 
7
7
  const appConfigProseH2 = _appConfig as AppConfig & { b24ui: { prose: { h2: Partial<typeof theme> } } }
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import type { AppConfig } from '@nuxt/schema'
3
3
  import _appConfig from '#build/app.config'
4
- import theme from '#build/b24ui/prose/prose-h3'
4
+ import theme from '#build/b24ui/prose/h3'
5
5
  import { tv } from '../utils/tv'
6
6
 
7
7
  const appConfigProseH3 = _appConfig as AppConfig & { b24ui: { prose: { h3: Partial<typeof theme> } } }
@@ -0,0 +1,36 @@
1
+ <script lang="ts">
2
+ import type { AppConfig } from '@nuxt/schema'
3
+ import _appConfig from '#build/app.config'
4
+ import theme from '#build/b24ui/prose/h4'
5
+ import { tv } from '../utils/tv'
6
+
7
+ const appConfigProseH4 = _appConfig as AppConfig & { b24ui: { prose: { h4: Partial<typeof theme> } } }
8
+
9
+ const proseH4 = tv({ extend: tv(theme), ...(appConfigProseH4.b24ui?.prose?.h4 || {}) })
10
+
11
+ export interface proseH4Props {
12
+ class?: any
13
+ b24ui?: Partial<typeof proseH4.slots>
14
+ }
15
+
16
+ export interface proseH4Slots {
17
+ default(props?: {}): any
18
+ }
19
+ </script>
20
+
21
+ <script setup lang="ts">
22
+ defineOptions({ inheritAttrs: false })
23
+
24
+ const props = defineProps<proseH4Props>()
25
+
26
+ // eslint-disable-next-line vue/no-dupe-keys
27
+ const b24ui = proseH4({})
28
+ </script>
29
+
30
+ <template>
31
+ <h4
32
+ :class="b24ui.base({ class: [props.class, props.b24ui?.base] })"
33
+ >
34
+ <slot />
35
+ </h4>
36
+ </template>
@@ -0,0 +1,36 @@
1
+ <script lang="ts">
2
+ import type { AppConfig } from '@nuxt/schema'
3
+ import _appConfig from '#build/app.config'
4
+ import theme from '#build/b24ui/prose/h5'
5
+ import { tv } from '../utils/tv'
6
+
7
+ const appConfigProseH5 = _appConfig as AppConfig & { b24ui: { prose: { h5: Partial<typeof theme> } } }
8
+
9
+ const proseH5 = tv({ extend: tv(theme), ...(appConfigProseH5.b24ui?.prose?.h5 || {}) })
10
+
11
+ export interface proseH5Props {
12
+ class?: any
13
+ b24ui?: Partial<typeof proseH5.slots>
14
+ }
15
+
16
+ export interface proseH5Slots {
17
+ default(props?: {}): any
18
+ }
19
+ </script>
20
+
21
+ <script setup lang="ts">
22
+ defineOptions({ inheritAttrs: false })
23
+
24
+ const props = defineProps<proseH5Props>()
25
+
26
+ // eslint-disable-next-line vue/no-dupe-keys
27
+ const b24ui = proseH5({})
28
+ </script>
29
+
30
+ <template>
31
+ <h5
32
+ :class="b24ui.base({ class: [props.class, props.b24ui?.base] })"
33
+ >
34
+ <slot />
35
+ </h5>
36
+ </template>
@@ -0,0 +1,36 @@
1
+ <script lang="ts">
2
+ import type { AppConfig } from '@nuxt/schema'
3
+ import _appConfig from '#build/app.config'
4
+ import theme from '#build/b24ui/prose/h6'
5
+ import { tv } from '../utils/tv'
6
+
7
+ const appConfigProseH6 = _appConfig as AppConfig & { b24ui: { prose: { h6: Partial<typeof theme> } } }
8
+
9
+ const proseH6 = tv({ extend: tv(theme), ...(appConfigProseH6.b24ui?.prose?.h6 || {}) })
10
+
11
+ export interface proseH6Props {
12
+ class?: any
13
+ b24ui?: Partial<typeof proseH6.slots>
14
+ }
15
+
16
+ export interface proseH6Slots {
17
+ default(props?: {}): any
18
+ }
19
+ </script>
20
+
21
+ <script setup lang="ts">
22
+ defineOptions({ inheritAttrs: false })
23
+
24
+ const props = defineProps<proseH6Props>()
25
+
26
+ // eslint-disable-next-line vue/no-dupe-keys
27
+ const b24ui = proseH6({})
28
+ </script>
29
+
30
+ <template>
31
+ <h6
32
+ :class="b24ui.base({ class: [props.class, props.b24ui?.base] })"
33
+ >
34
+ <slot />
35
+ </h6>
36
+ </template>
@@ -0,0 +1,30 @@
1
+ <script lang="ts">
2
+ import type { AppConfig } from '@nuxt/schema'
3
+ import _appConfig from '#build/app.config'
4
+ import theme from '#build/b24ui/prose/hr'
5
+ import { tv } from '../utils/tv'
6
+
7
+ const appConfigProseHr = _appConfig as AppConfig & { b24ui: { prose: { hr: Partial<typeof theme> } } }
8
+
9
+ const proseHr = tv({ extend: tv(theme), ...(appConfigProseHr.b24ui?.prose?.hr || {}) })
10
+
11
+ export interface proseHrProps {
12
+ class?: any
13
+ b24ui?: Partial<typeof proseHr.slots>
14
+ }
15
+ </script>
16
+
17
+ <script setup lang="ts">
18
+ defineOptions({ inheritAttrs: false })
19
+
20
+ const props = defineProps<proseHrProps>()
21
+
22
+ // eslint-disable-next-line vue/no-dupe-keys
23
+ const b24ui = proseHr({})
24
+ </script>
25
+
26
+ <template>
27
+ <hr
28
+ :class="b24ui.base({ class: [props.class, props.b24ui?.base] })"
29
+ >
30
+ </template>
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import type { AppConfig } from '@nuxt/schema'
3
3
  import _appConfig from '#build/app.config'
4
- import theme from '#build/b24ui/prose/prose-li'
4
+ import theme from '#build/b24ui/prose/li'
5
5
  import { tv } from '../utils/tv'
6
6
 
7
7
  const appConfigProseLi = _appConfig as AppConfig & { b24ui: { prose: { li: Partial<typeof theme> } } }
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import type { AppConfig } from '@nuxt/schema'
3
3
  import _appConfig from '#build/app.config'
4
- import theme from '#build/b24ui/prose/prose-ol'
4
+ import theme from '#build/b24ui/prose/ol'
5
5
  import { tv } from '../utils/tv'
6
6
 
7
7
  const appConfigProseOl = _appConfig as AppConfig & { b24ui: { prose: { ol: Partial<typeof theme> } } }
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import type { AppConfig } from '@nuxt/schema'
3
3
  import _appConfig from '#build/app.config'
4
- import theme from '#build/b24ui/prose/prose-p'
4
+ import theme from '#build/b24ui/prose/p'
5
5
  import { tv } from '../utils/tv'
6
6
 
7
7
  const appConfigProseP = _appConfig as AppConfig & { b24ui: { prose: { p: Partial<typeof theme> } } }
@@ -0,0 +1,36 @@
1
+ <script lang="ts">
2
+ import type { AppConfig } from '@nuxt/schema'
3
+ import _appConfig from '#build/app.config'
4
+ import theme from '#build/b24ui/prose/strong'
5
+ import { tv } from '../utils/tv'
6
+
7
+ const appConfigProseStrong = _appConfig as AppConfig & { b24ui: { prose: { strong: Partial<typeof theme> } } }
8
+
9
+ const proseStrong = tv({ extend: tv(theme), ...(appConfigProseStrong.b24ui?.prose?.strong || {}) })
10
+
11
+ export interface proseStrongProps {
12
+ class?: any
13
+ b24ui?: Partial<typeof proseStrong.slots>
14
+ }
15
+
16
+ export interface proseStrongSlots {
17
+ default(props?: {}): any
18
+ }
19
+ </script>
20
+
21
+ <script setup lang="ts">
22
+ defineOptions({ inheritAttrs: false })
23
+
24
+ const props = defineProps<proseStrongProps>()
25
+
26
+ // eslint-disable-next-line vue/no-dupe-keys
27
+ const b24ui = proseStrong({})
28
+ </script>
29
+
30
+ <template>
31
+ <strong
32
+ :class="b24ui.base({ class: [props.class, props.b24ui?.base] })"
33
+ >
34
+ <slot />
35
+ </strong>
36
+ </template>
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import type { AppConfig } from '@nuxt/schema'
3
3
  import _appConfig from '#build/app.config'
4
- import theme from '#build/b24ui/prose/prose-ul'
4
+ import theme from '#build/b24ui/prose/ul'
5
5
  import { tv } from '../utils/tv'
6
6
 
7
7
  const appConfigProseUl = _appConfig as AppConfig & { b24ui: { prose: { ul: Partial<typeof theme> } } }
@@ -36,13 +36,20 @@ export * from '../components/Toast.vue';
36
36
  export * from '../components/Toaster.vue';
37
37
  export * from '../components/Tooltip.vue';
38
38
  export * from '../components/content/TableWrapper.vue';
39
- export * from '../prose/ProseH1.vue';
40
- export * from '../prose/ProseH2.vue';
41
- export * from '../prose/ProseH3.vue';
42
- export * from '../prose/ProseLi.vue';
43
- export * from '../prose/ProseOl.vue';
44
- export * from '../prose/ProseP.vue';
45
- export * from '../prose/ProseUl.vue';
39
+ export * from '../prose/H1.vue';
40
+ export * from '../prose/H2.vue';
41
+ export * from '../prose/H3.vue';
42
+ export * from '../prose/H3.vue';
43
+ export * from '../prose/H4.vue';
44
+ export * from '../prose/H5.vue';
45
+ export * from '../prose/H6.vue';
46
+ export * from '../prose/P.vue';
47
+ export * from '../prose/Blockquote.vue';
48
+ export * from '../prose/Strong.vue';
49
+ export * from '../prose/Ol.vue';
50
+ export * from '../prose/Ul.vue';
51
+ export * from '../prose/Li.vue';
52
+ export * from '../prose/Hr.vue';
46
53
  export * from './form';
47
54
  export * from './icons';
48
55
  export * from './locale';