@finema/core 1.4.159 → 1.4.161
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +60 -60
- package/dist/module.json +1 -1
- package/dist/module.mjs +59 -17
- package/dist/runtime/components/Alert.vue +48 -48
- package/dist/runtime/components/Avatar.vue +27 -27
- package/dist/runtime/components/Badge.vue +11 -11
- package/dist/runtime/components/Breadcrumb.vue +44 -44
- package/dist/runtime/components/Button/Group.vue +37 -37
- package/dist/runtime/components/Button/index.vue +75 -75
- package/dist/runtime/components/Card.vue +38 -38
- package/dist/runtime/components/Core.vue +45 -45
- package/dist/runtime/components/Dialog/index.vue +108 -108
- package/dist/runtime/components/Dropdown/index.vue +70 -70
- package/dist/runtime/components/FlexDeck/Base.vue +143 -143
- package/dist/runtime/components/FlexDeck/index.vue +68 -68
- package/dist/runtime/components/Form/FieldWrapper.vue +23 -23
- package/dist/runtime/components/Form/Fields.vue +230 -230
- package/dist/runtime/components/Form/InputCheckbox/index.vue +28 -28
- package/dist/runtime/components/Form/InputDateTime/index.vue +60 -60
- package/dist/runtime/components/Form/InputDateTimeRange/index.vue +83 -83
- package/dist/runtime/components/Form/InputNumber/index.vue +27 -27
- package/dist/runtime/components/Form/InputRadio/index.vue +27 -27
- package/dist/runtime/components/Form/InputSelect/index.vue +45 -45
- package/dist/runtime/components/Form/InputSelectMultiple/index.vue +54 -54
- package/dist/runtime/components/Form/InputStatic/index.vue +16 -16
- package/dist/runtime/components/Form/InputTags/index.vue +145 -145
- package/dist/runtime/components/Form/InputText/index.vue +67 -67
- package/dist/runtime/components/Form/InputTextarea/index.vue +25 -25
- package/dist/runtime/components/Form/InputToggle/index.vue +14 -14
- package/dist/runtime/components/Form/InputUploadDropzone/index.vue +206 -206
- package/dist/runtime/components/Form/InputUploadDropzoneAuto/index.vue +342 -342
- package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/ItemUpload.vue +241 -241
- package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/ItemView.vue +89 -89
- package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/index.vue +164 -164
- package/dist/runtime/components/Form/InputUploadDropzoneImageAutoMultiple/ItemUpload.vue +161 -161
- package/dist/runtime/components/Form/InputUploadDropzoneImageAutoMultiple/ItemView.vue +64 -64
- package/dist/runtime/components/Form/InputUploadDropzoneImageAutoMultiple/index.vue +172 -172
- package/dist/runtime/components/Form/InputUploadFileClassic/index.vue +95 -95
- package/dist/runtime/components/Form/InputUploadFileClassicAuto/index.vue +151 -151
- package/dist/runtime/components/Form/InputUploadImageAuto/index.vue +219 -219
- package/dist/runtime/components/Form/InputWYSIWYG/index.vue +53 -53
- package/dist/runtime/components/Form/index.vue +6 -6
- package/dist/runtime/components/Icon.vue +23 -23
- package/dist/runtime/components/Image.vue +36 -36
- package/dist/runtime/components/Loader.vue +27 -27
- package/dist/runtime/components/Modal/index.vue +146 -146
- package/dist/runtime/components/QRCode.vue +22 -22
- package/dist/runtime/components/SimplePagination.vue +96 -96
- package/dist/runtime/components/Slideover/index.vue +110 -110
- package/dist/runtime/components/Table/Base.vue +139 -139
- package/dist/runtime/components/Table/ColumnDate.vue +16 -16
- package/dist/runtime/components/Table/ColumnDateTime.vue +18 -18
- package/dist/runtime/components/Table/ColumnImage.vue +15 -15
- package/dist/runtime/components/Table/ColumnNumber.vue +14 -14
- package/dist/runtime/components/Table/ColumnText.vue +25 -25
- package/dist/runtime/components/Table/Simple.vue +69 -69
- package/dist/runtime/components/Table/index.vue +65 -65
- package/dist/runtime/components/Tabs/index.vue +64 -64
- package/dist/runtime/components/TeleportSafe.vue +40 -40
- package/dist/runtime/composables/useNotification.mjs +13 -4
- package/dist/runtime/ui.config/notification.mjs +4 -0
- package/package.json +95 -95
package/README.md
CHANGED
|
@@ -1,60 +1,60 @@
|
|
|
1
|
-
# @finema/core Nuxt Module
|
|
2
|
-
|
|
3
|
-
[✨ Release Notes](/CHANGELOG.md)
|
|
4
|
-
|
|
5
|
-
## Starter template
|
|
6
|
-
https://gitlab.finema.co/finema/nuxt3-template-with-uikit
|
|
7
|
-
|
|
8
|
-
## Remark
|
|
9
|
-
- Temporary use resolutions for vue 3.3.13 instead of ^3.4.0 due to [this issue](https://github.com/nuxt/ui/issues/1171) and planned to be fixed in the next vue 3.5 version.
|
|
10
|
-
|
|
11
|
-
## Quick Setup
|
|
12
|
-
|
|
13
|
-
1. Add `@finema/core` dependency to your project
|
|
14
|
-
|
|
15
|
-
```bash
|
|
16
|
-
# Using pnpm
|
|
17
|
-
pnpm add -D @finema/core
|
|
18
|
-
|
|
19
|
-
# Using yarn
|
|
20
|
-
yarn add --dev @finema/core
|
|
21
|
-
|
|
22
|
-
```
|
|
23
|
-
|
|
24
|
-
1. Add `@finema/core` to the `modules` section of `nuxt.config.ts`
|
|
25
|
-
|
|
26
|
-
```js
|
|
27
|
-
export default defineNuxtConfig({
|
|
28
|
-
modules: [
|
|
29
|
-
'@finema/core'
|
|
30
|
-
]
|
|
31
|
-
})
|
|
32
|
-
```
|
|
33
|
-
|
|
34
|
-
That's it! You can now use @finema/core in your Nuxt app ✨
|
|
35
|
-
|
|
36
|
-
## Development
|
|
37
|
-
|
|
38
|
-
```bash
|
|
39
|
-
# Install dependencies
|
|
40
|
-
pnpm install
|
|
41
|
-
|
|
42
|
-
# Generate type stubs
|
|
43
|
-
pnpm dev:prepare
|
|
44
|
-
|
|
45
|
-
# Develop with the playground
|
|
46
|
-
pnpm dev
|
|
47
|
-
|
|
48
|
-
# Build the playground
|
|
49
|
-
pnpm dev:build
|
|
50
|
-
|
|
51
|
-
# Run ESLint
|
|
52
|
-
pnpm lint
|
|
53
|
-
|
|
54
|
-
# Run Vitest
|
|
55
|
-
pnpm test
|
|
56
|
-
pnpm test:watch
|
|
57
|
-
|
|
58
|
-
# Release new version
|
|
59
|
-
pnpm release
|
|
60
|
-
```
|
|
1
|
+
# @finema/core Nuxt Module
|
|
2
|
+
|
|
3
|
+
[✨ Release Notes](/CHANGELOG.md)
|
|
4
|
+
|
|
5
|
+
## Starter template
|
|
6
|
+
https://gitlab.finema.co/finema/nuxt3-template-with-uikit
|
|
7
|
+
|
|
8
|
+
## Remark
|
|
9
|
+
- Temporary use resolutions for vue 3.3.13 instead of ^3.4.0 due to [this issue](https://github.com/nuxt/ui/issues/1171) and planned to be fixed in the next vue 3.5 version.
|
|
10
|
+
|
|
11
|
+
## Quick Setup
|
|
12
|
+
|
|
13
|
+
1. Add `@finema/core` dependency to your project
|
|
14
|
+
|
|
15
|
+
```bash
|
|
16
|
+
# Using pnpm
|
|
17
|
+
pnpm add -D @finema/core
|
|
18
|
+
|
|
19
|
+
# Using yarn
|
|
20
|
+
yarn add --dev @finema/core
|
|
21
|
+
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
1. Add `@finema/core` to the `modules` section of `nuxt.config.ts`
|
|
25
|
+
|
|
26
|
+
```js
|
|
27
|
+
export default defineNuxtConfig({
|
|
28
|
+
modules: [
|
|
29
|
+
'@finema/core'
|
|
30
|
+
]
|
|
31
|
+
})
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
That's it! You can now use @finema/core in your Nuxt app ✨
|
|
35
|
+
|
|
36
|
+
## Development
|
|
37
|
+
|
|
38
|
+
```bash
|
|
39
|
+
# Install dependencies
|
|
40
|
+
pnpm install
|
|
41
|
+
|
|
42
|
+
# Generate type stubs
|
|
43
|
+
pnpm dev:prepare
|
|
44
|
+
|
|
45
|
+
# Develop with the playground
|
|
46
|
+
pnpm dev
|
|
47
|
+
|
|
48
|
+
# Build the playground
|
|
49
|
+
pnpm dev:build
|
|
50
|
+
|
|
51
|
+
# Run ESLint
|
|
52
|
+
pnpm lint
|
|
53
|
+
|
|
54
|
+
# Run Vitest
|
|
55
|
+
pnpm test
|
|
56
|
+
pnpm test:watch
|
|
57
|
+
|
|
58
|
+
# Release new version
|
|
59
|
+
pnpm release
|
|
60
|
+
```
|
package/dist/module.json
CHANGED
package/dist/module.mjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { defineNuxtModule, createResolver, installModule, addPlugin, addComponentsDir, addImportsDir } from '@nuxt/kit';
|
|
2
2
|
|
|
3
3
|
const name = "@finema/core";
|
|
4
|
-
const version = "1.4.
|
|
4
|
+
const version = "1.4.161";
|
|
5
5
|
|
|
6
6
|
const colors = {
|
|
7
7
|
black: "#20243E",
|
|
@@ -37,35 +37,55 @@ const colors = {
|
|
|
37
37
|
},
|
|
38
38
|
info: {
|
|
39
39
|
DEFAULT: "#0D8CEE",
|
|
40
|
-
50: "#
|
|
41
|
-
100: "#
|
|
42
|
-
|
|
40
|
+
50: "#F3F9FE",
|
|
41
|
+
100: "#E7F4FD",
|
|
42
|
+
200: "#C3E2FB",
|
|
43
|
+
300: "#9ED1F8",
|
|
44
|
+
400: "#56AFF3",
|
|
43
45
|
500: "#0D8CEE",
|
|
44
|
-
600: "#
|
|
46
|
+
600: "#0C7ED6",
|
|
47
|
+
700: "#08548F",
|
|
48
|
+
800: "#063F6B",
|
|
49
|
+
900: "#042A47"
|
|
45
50
|
},
|
|
46
51
|
danger: {
|
|
47
52
|
DEFAULT: "#F25555",
|
|
48
|
-
50: "#
|
|
49
|
-
100: "#
|
|
50
|
-
|
|
53
|
+
50: "#FEF7F7",
|
|
54
|
+
100: "#FEEEEE",
|
|
55
|
+
200: "#FCD5D5",
|
|
56
|
+
300: "#FABBBB",
|
|
57
|
+
400: "#F68888",
|
|
51
58
|
500: "#F25555",
|
|
52
|
-
600: "#
|
|
59
|
+
600: "#DA4D4D",
|
|
60
|
+
700: "#913333",
|
|
61
|
+
800: "#6D2626",
|
|
62
|
+
900: "#491A1A"
|
|
53
63
|
},
|
|
54
64
|
success: {
|
|
55
65
|
DEFAULT: "#3FB061",
|
|
56
|
-
50: "#
|
|
57
|
-
100: "#
|
|
58
|
-
|
|
66
|
+
50: "#F5FBF7",
|
|
67
|
+
100: "#ECF7EF",
|
|
68
|
+
200: "#CFEBD8",
|
|
69
|
+
300: "#B2DFC0",
|
|
70
|
+
400: "#79C890",
|
|
59
71
|
500: "#3FB061",
|
|
60
|
-
600: "#
|
|
72
|
+
600: "#399E57",
|
|
73
|
+
700: "#266A3A",
|
|
74
|
+
800: "#1C4F2C",
|
|
75
|
+
900: "#13351D"
|
|
61
76
|
},
|
|
62
77
|
warning: {
|
|
63
78
|
DEFAULT: "#FF9A35",
|
|
64
|
-
50: "#
|
|
65
|
-
100: "#
|
|
66
|
-
|
|
79
|
+
50: "#FFFAF5",
|
|
80
|
+
100: "#FFF5EB",
|
|
81
|
+
200: "#FFE6CD",
|
|
82
|
+
300: "#FFD7AE",
|
|
83
|
+
400: "#FFB872",
|
|
67
84
|
500: "#FF9A35",
|
|
68
|
-
600: "#
|
|
85
|
+
600: "#E68B30",
|
|
86
|
+
700: "#995C20",
|
|
87
|
+
800: "#734518",
|
|
88
|
+
900: "#4D2E10"
|
|
69
89
|
}
|
|
70
90
|
};
|
|
71
91
|
|
|
@@ -227,6 +247,20 @@ const toggle = {
|
|
|
227
247
|
|
|
228
248
|
const badge = {};
|
|
229
249
|
|
|
250
|
+
const notification = {
|
|
251
|
+
ring: "ring-0",
|
|
252
|
+
progress: {
|
|
253
|
+
base: "hidden"
|
|
254
|
+
},
|
|
255
|
+
actionGroup: {
|
|
256
|
+
wrapper: "mt-5 flex justify-end space-x-4",
|
|
257
|
+
cancelColor: "primary",
|
|
258
|
+
cancelVariant: "outline",
|
|
259
|
+
confirmColor: "primary",
|
|
260
|
+
confirmVariant: "solid"
|
|
261
|
+
}
|
|
262
|
+
};
|
|
263
|
+
|
|
230
264
|
const colorModeOptions = {
|
|
231
265
|
preference: "light"
|
|
232
266
|
};
|
|
@@ -341,11 +375,18 @@ const module = defineNuxtModule({
|
|
|
341
375
|
nuxt.options.alias["#core"] = runtimeDir;
|
|
342
376
|
nuxt.options.css.push(resolve(runtimeDir, "ui.css"));
|
|
343
377
|
nuxt.hook("tailwindcss:config", (tailwindConfig) => {
|
|
378
|
+
tailwindConfig.safelist = [
|
|
379
|
+
...tailwindConfig.safelist || [],
|
|
380
|
+
{
|
|
381
|
+
pattern: /bg-(primary|info|warning|success|danger)-(200)/
|
|
382
|
+
}
|
|
383
|
+
];
|
|
344
384
|
tailwindConfig.content = {
|
|
345
385
|
...tailwindConfig.content,
|
|
346
386
|
files: [
|
|
347
387
|
...tailwindConfig.content.files || [],
|
|
348
388
|
resolve(runtimeDir, "components/**/*.{vue,mjs,ts}"),
|
|
389
|
+
resolve(runtimeDir, "composables/**/*.{vue,mjs,ts}"),
|
|
349
390
|
resolve(runtimeDir, "ui.config/**/*.{mjs,js,ts}"),
|
|
350
391
|
resolve(runtimeDir, "presets/**/*.{mjs,js,ts}")
|
|
351
392
|
]
|
|
@@ -377,6 +418,7 @@ const module = defineNuxtModule({
|
|
|
377
418
|
textarea,
|
|
378
419
|
toggle,
|
|
379
420
|
badge,
|
|
421
|
+
notification,
|
|
380
422
|
icons: {
|
|
381
423
|
dynamic: true
|
|
382
424
|
}
|
|
@@ -1,48 +1,48 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<UAlert v-bind="$props">
|
|
3
|
-
<template #title><slot name="title" :title="title" /></template>
|
|
4
|
-
<template #description><slot name="description" :description="description" /></template>
|
|
5
|
-
</UAlert>
|
|
6
|
-
</template>
|
|
7
|
-
<script lang="ts" setup>
|
|
8
|
-
import { type PropType } from 'vue'
|
|
9
|
-
import { type alert } from '#ui/ui.config'
|
|
10
|
-
import type { AlertColor, AlertVariant, Avatar, Button, Strategy } from '#ui/types'
|
|
11
|
-
|
|
12
|
-
defineProps({
|
|
13
|
-
title: {
|
|
14
|
-
type: String,
|
|
15
|
-
required: true,
|
|
16
|
-
},
|
|
17
|
-
description: {
|
|
18
|
-
type: String,
|
|
19
|
-
default: null,
|
|
20
|
-
},
|
|
21
|
-
icon: {
|
|
22
|
-
type: String,
|
|
23
|
-
},
|
|
24
|
-
avatar: {
|
|
25
|
-
type: Object as PropType<Avatar>,
|
|
26
|
-
default: null,
|
|
27
|
-
},
|
|
28
|
-
closeButton: {
|
|
29
|
-
type: Object as PropType<Button>,
|
|
30
|
-
},
|
|
31
|
-
actions: {
|
|
32
|
-
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
33
|
-
type: Array as PropType<Array<Button & { click?: Function }>>,
|
|
34
|
-
},
|
|
35
|
-
color: {
|
|
36
|
-
type: String as PropType<AlertColor>,
|
|
37
|
-
},
|
|
38
|
-
variant: {
|
|
39
|
-
type: String as PropType<AlertVariant>,
|
|
40
|
-
},
|
|
41
|
-
class: {
|
|
42
|
-
type: [String, Object, Array] as PropType<any>,
|
|
43
|
-
},
|
|
44
|
-
ui: {
|
|
45
|
-
type: Object as PropType<Partial<typeof alert> & { strategy?: Strategy }>,
|
|
46
|
-
},
|
|
47
|
-
})
|
|
48
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<UAlert v-bind="$props">
|
|
3
|
+
<template #title><slot name="title" :title="title" /></template>
|
|
4
|
+
<template #description><slot name="description" :description="description" /></template>
|
|
5
|
+
</UAlert>
|
|
6
|
+
</template>
|
|
7
|
+
<script lang="ts" setup>
|
|
8
|
+
import { type PropType } from 'vue'
|
|
9
|
+
import { type alert } from '#ui/ui.config'
|
|
10
|
+
import type { AlertColor, AlertVariant, Avatar, Button, Strategy } from '#ui/types'
|
|
11
|
+
|
|
12
|
+
defineProps({
|
|
13
|
+
title: {
|
|
14
|
+
type: String,
|
|
15
|
+
required: true,
|
|
16
|
+
},
|
|
17
|
+
description: {
|
|
18
|
+
type: String,
|
|
19
|
+
default: null,
|
|
20
|
+
},
|
|
21
|
+
icon: {
|
|
22
|
+
type: String,
|
|
23
|
+
},
|
|
24
|
+
avatar: {
|
|
25
|
+
type: Object as PropType<Avatar>,
|
|
26
|
+
default: null,
|
|
27
|
+
},
|
|
28
|
+
closeButton: {
|
|
29
|
+
type: Object as PropType<Button>,
|
|
30
|
+
},
|
|
31
|
+
actions: {
|
|
32
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
33
|
+
type: Array as PropType<Array<Button & { click?: Function }>>,
|
|
34
|
+
},
|
|
35
|
+
color: {
|
|
36
|
+
type: String as PropType<AlertColor>,
|
|
37
|
+
},
|
|
38
|
+
variant: {
|
|
39
|
+
type: String as PropType<AlertVariant>,
|
|
40
|
+
},
|
|
41
|
+
class: {
|
|
42
|
+
type: [String, Object, Array] as PropType<any>,
|
|
43
|
+
},
|
|
44
|
+
ui: {
|
|
45
|
+
type: Object as PropType<Partial<typeof alert> & { strategy?: Strategy }>,
|
|
46
|
+
},
|
|
47
|
+
})
|
|
48
|
+
</script>
|
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<UAvatar v-bind="$attrs" :src="src" :alt="alt" :size="size" />
|
|
3
|
-
</template>
|
|
4
|
-
|
|
5
|
-
<script lang="ts" setup>
|
|
6
|
-
import type { AvatarSize } from '#ui/types'
|
|
7
|
-
import type { PropType } from 'vue'
|
|
8
|
-
|
|
9
|
-
defineOptions({
|
|
10
|
-
inheritAttrs: true,
|
|
11
|
-
})
|
|
12
|
-
|
|
13
|
-
defineProps({
|
|
14
|
-
src: {
|
|
15
|
-
type: String,
|
|
16
|
-
required: true,
|
|
17
|
-
},
|
|
18
|
-
alt: {
|
|
19
|
-
type: String,
|
|
20
|
-
required: true,
|
|
21
|
-
},
|
|
22
|
-
size: {
|
|
23
|
-
type: String as PropType<AvatarSize>,
|
|
24
|
-
default: 'sm',
|
|
25
|
-
},
|
|
26
|
-
})
|
|
27
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<UAvatar v-bind="$attrs" :src="src" :alt="alt" :size="size" />
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script lang="ts" setup>
|
|
6
|
+
import type { AvatarSize } from '#ui/types'
|
|
7
|
+
import type { PropType } from 'vue'
|
|
8
|
+
|
|
9
|
+
defineOptions({
|
|
10
|
+
inheritAttrs: true,
|
|
11
|
+
})
|
|
12
|
+
|
|
13
|
+
defineProps({
|
|
14
|
+
src: {
|
|
15
|
+
type: String,
|
|
16
|
+
required: true,
|
|
17
|
+
},
|
|
18
|
+
alt: {
|
|
19
|
+
type: String,
|
|
20
|
+
required: true,
|
|
21
|
+
},
|
|
22
|
+
size: {
|
|
23
|
+
type: String as PropType<AvatarSize>,
|
|
24
|
+
default: 'sm',
|
|
25
|
+
},
|
|
26
|
+
})
|
|
27
|
+
</script>
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<UBadge v-bind="$props">
|
|
3
|
-
<slot />
|
|
4
|
-
</UBadge>
|
|
5
|
-
</template>
|
|
6
|
-
|
|
7
|
-
<script setup lang="ts">
|
|
8
|
-
import type { Badge } from '#ui/types/badge'
|
|
9
|
-
|
|
10
|
-
defineProps<Badge>()
|
|
11
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<UBadge v-bind="$props">
|
|
3
|
+
<slot />
|
|
4
|
+
</UBadge>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import type { Badge } from '#ui/types/badge'
|
|
9
|
+
|
|
10
|
+
defineProps<Badge>()
|
|
11
|
+
</script>
|
|
@@ -1,44 +1,44 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<UBreadcrumb v-bind="attrs" :class="$props.class" :links="links" :divider="divider" :ui="ui">
|
|
3
|
-
<template #default="{ link, isActive, index }">
|
|
4
|
-
<slot name="default" :link="link" :is-active="isActive" :index="index" />
|
|
5
|
-
</template>
|
|
6
|
-
|
|
7
|
-
<template #icon="{ link, index, isActive }">
|
|
8
|
-
<slot name="icon" :link="link" :is-active="isActive" :index="index" />
|
|
9
|
-
</template>
|
|
10
|
-
|
|
11
|
-
<template #divider>
|
|
12
|
-
<slot name="divider" />
|
|
13
|
-
</template>
|
|
14
|
-
</UBreadcrumb>
|
|
15
|
-
</template>
|
|
16
|
-
|
|
17
|
-
<script setup lang="ts">
|
|
18
|
-
import { useUiConfig, type PropType, useUI, toRef } from '#imports'
|
|
19
|
-
import { breadcrumb } from '#core/ui.config'
|
|
20
|
-
import type { BreadcrumbLink, Strategy } from '#ui/types'
|
|
21
|
-
|
|
22
|
-
const config = useUiConfig<typeof breadcrumb>(breadcrumb, 'breadcrumb')
|
|
23
|
-
|
|
24
|
-
const props = defineProps({
|
|
25
|
-
links: {
|
|
26
|
-
type: Array as PropType<BreadcrumbLink[]>,
|
|
27
|
-
default: () => [],
|
|
28
|
-
},
|
|
29
|
-
divider: {
|
|
30
|
-
type: String,
|
|
31
|
-
default: () => breadcrumb.default.divider,
|
|
32
|
-
},
|
|
33
|
-
class: {
|
|
34
|
-
type: [String, Object, Array] as PropType<any>,
|
|
35
|
-
default: () => '',
|
|
36
|
-
},
|
|
37
|
-
ui: {
|
|
38
|
-
type: Object as PropType<Partial<typeof config> & { strategy?: Strategy }>,
|
|
39
|
-
default: () => ({}),
|
|
40
|
-
},
|
|
41
|
-
})
|
|
42
|
-
|
|
43
|
-
const { ui, attrs } = useUI('breadcrumb', toRef(props, 'ui'), config, toRef(props, 'class'))
|
|
44
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<UBreadcrumb v-bind="attrs" :class="$props.class" :links="links" :divider="divider" :ui="ui">
|
|
3
|
+
<template #default="{ link, isActive, index }">
|
|
4
|
+
<slot name="default" :link="link" :is-active="isActive" :index="index" />
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<template #icon="{ link, index, isActive }">
|
|
8
|
+
<slot name="icon" :link="link" :is-active="isActive" :index="index" />
|
|
9
|
+
</template>
|
|
10
|
+
|
|
11
|
+
<template #divider>
|
|
12
|
+
<slot name="divider" />
|
|
13
|
+
</template>
|
|
14
|
+
</UBreadcrumb>
|
|
15
|
+
</template>
|
|
16
|
+
|
|
17
|
+
<script setup lang="ts">
|
|
18
|
+
import { useUiConfig, type PropType, useUI, toRef } from '#imports'
|
|
19
|
+
import { breadcrumb } from '#core/ui.config'
|
|
20
|
+
import type { BreadcrumbLink, Strategy } from '#ui/types'
|
|
21
|
+
|
|
22
|
+
const config = useUiConfig<typeof breadcrumb>(breadcrumb, 'breadcrumb')
|
|
23
|
+
|
|
24
|
+
const props = defineProps({
|
|
25
|
+
links: {
|
|
26
|
+
type: Array as PropType<BreadcrumbLink[]>,
|
|
27
|
+
default: () => [],
|
|
28
|
+
},
|
|
29
|
+
divider: {
|
|
30
|
+
type: String,
|
|
31
|
+
default: () => breadcrumb.default.divider,
|
|
32
|
+
},
|
|
33
|
+
class: {
|
|
34
|
+
type: [String, Object, Array] as PropType<any>,
|
|
35
|
+
default: () => '',
|
|
36
|
+
},
|
|
37
|
+
ui: {
|
|
38
|
+
type: Object as PropType<Partial<typeof config> & { strategy?: Strategy }>,
|
|
39
|
+
default: () => ({}),
|
|
40
|
+
},
|
|
41
|
+
})
|
|
42
|
+
|
|
43
|
+
const { ui, attrs } = useUI('breadcrumb', toRef(props, 'ui'), config, toRef(props, 'class'))
|
|
44
|
+
</script>
|
|
@@ -1,37 +1,37 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<UButtonGroup v-bind="$props">
|
|
3
|
-
<slot />
|
|
4
|
-
</UButtonGroup>
|
|
5
|
-
</template>
|
|
6
|
-
|
|
7
|
-
<script lang="ts" setup>
|
|
8
|
-
import type { PropType } from 'vue'
|
|
9
|
-
import type { ButtonSize } from '#ui/types/button'
|
|
10
|
-
import { button, type buttonGroup } from '#ui/ui.config'
|
|
11
|
-
import type { Strategy } from '#ui/types'
|
|
12
|
-
|
|
13
|
-
defineProps({
|
|
14
|
-
size: {
|
|
15
|
-
type: String as PropType<ButtonSize>,
|
|
16
|
-
default: () => button.default.size,
|
|
17
|
-
validator(value: string) {
|
|
18
|
-
return Object.keys(button.size).includes(value)
|
|
19
|
-
},
|
|
20
|
-
},
|
|
21
|
-
orientation: {
|
|
22
|
-
type: String as PropType<'horizontal' | 'vertical'>,
|
|
23
|
-
default: 'horizontal',
|
|
24
|
-
validator(value: string) {
|
|
25
|
-
return ['horizontal', 'vertical'].includes(value)
|
|
26
|
-
},
|
|
27
|
-
},
|
|
28
|
-
class: {
|
|
29
|
-
type: [String, Object, Array] as PropType<any>,
|
|
30
|
-
default: undefined,
|
|
31
|
-
},
|
|
32
|
-
ui: {
|
|
33
|
-
type: Object as PropType<Partial<typeof buttonGroup> & { strategy?: Strategy }>,
|
|
34
|
-
default: undefined,
|
|
35
|
-
},
|
|
36
|
-
})
|
|
37
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<UButtonGroup v-bind="$props">
|
|
3
|
+
<slot />
|
|
4
|
+
</UButtonGroup>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script lang="ts" setup>
|
|
8
|
+
import type { PropType } from 'vue'
|
|
9
|
+
import type { ButtonSize } from '#ui/types/button'
|
|
10
|
+
import { button, type buttonGroup } from '#ui/ui.config'
|
|
11
|
+
import type { Strategy } from '#ui/types'
|
|
12
|
+
|
|
13
|
+
defineProps({
|
|
14
|
+
size: {
|
|
15
|
+
type: String as PropType<ButtonSize>,
|
|
16
|
+
default: () => button.default.size,
|
|
17
|
+
validator(value: string) {
|
|
18
|
+
return Object.keys(button.size).includes(value)
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
orientation: {
|
|
22
|
+
type: String as PropType<'horizontal' | 'vertical'>,
|
|
23
|
+
default: 'horizontal',
|
|
24
|
+
validator(value: string) {
|
|
25
|
+
return ['horizontal', 'vertical'].includes(value)
|
|
26
|
+
},
|
|
27
|
+
},
|
|
28
|
+
class: {
|
|
29
|
+
type: [String, Object, Array] as PropType<any>,
|
|
30
|
+
default: undefined,
|
|
31
|
+
},
|
|
32
|
+
ui: {
|
|
33
|
+
type: Object as PropType<Partial<typeof buttonGroup> & { strategy?: Strategy }>,
|
|
34
|
+
default: undefined,
|
|
35
|
+
},
|
|
36
|
+
})
|
|
37
|
+
</script>
|