@resee-movies/nuxt-ux 0.2.3 → 0.3.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.
- package/dist/module.json +1 -1
- package/dist/module.mjs +8 -1
- package/dist/runtime/components/Dialog.vue +7 -5
- package/dist/runtime/components/Dialog.vue.d.ts +4 -0
- package/dist/runtime/components/Icon.vue +15 -3
- package/dist/runtime/components/Menu.vue +87 -0
- package/dist/runtime/components/Menu.vue.d.ts +41 -0
- package/dist/runtime/components/ProgressSpinner.vue.d.ts +9 -0
- package/dist/runtime/theme/css/brand/anchor.css +1 -1
- package/dist/runtime/theme/css/brand/button.css +1 -1
- package/package.json +1 -1
- package/dist/runtime/components/LoadingIndicator.vue.d.ts +0 -9
- /package/dist/runtime/components/{LoadingIndicator.vue → ProgressSpinner.vue} +0 -0
package/dist/module.json
CHANGED
package/dist/module.mjs
CHANGED
|
@@ -125,6 +125,7 @@ function importModules(nuxt) {
|
|
|
125
125
|
"Dialog",
|
|
126
126
|
"Drawer",
|
|
127
127
|
"Message",
|
|
128
|
+
"Menu",
|
|
128
129
|
"ProgressBar",
|
|
129
130
|
"ProgressSpinner",
|
|
130
131
|
"Tag",
|
|
@@ -140,7 +141,13 @@ function importModules(nuxt) {
|
|
|
140
141
|
from: "#resee-movies-nuxt-ux-primevue-passthrough"
|
|
141
142
|
},
|
|
142
143
|
options: {
|
|
143
|
-
unstyled: true
|
|
144
|
+
unstyled: true,
|
|
145
|
+
zIndex: {
|
|
146
|
+
overlay: 800,
|
|
147
|
+
modal: 850,
|
|
148
|
+
menu: 900,
|
|
149
|
+
tooltip: 1e3
|
|
150
|
+
}
|
|
144
151
|
},
|
|
145
152
|
composables: {
|
|
146
153
|
include: ["usePrimeVue", "useToast"]
|
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
:footer = "props.footer"
|
|
11
11
|
:dismissable-mask = "props.dismissableMask"
|
|
12
12
|
:position = "props.position"
|
|
13
|
-
:class = "['dialog', dialogWidth]"
|
|
13
|
+
:class = "['dialog', dialogWidth, { 'dialog-styles': props.showModalStyle }]"
|
|
14
14
|
:content-class = "props.contentClass"
|
|
15
15
|
:pt = "passthroughProps"
|
|
16
16
|
:aria-labelledby = "dialogLabelledBy"
|
|
@@ -45,6 +45,8 @@ import CloseButton from "./CloseButton.vue";
|
|
|
45
45
|
const props = defineProps({
|
|
46
46
|
size: { type: String, required: false, default: "md" },
|
|
47
47
|
showHeaderText: { type: Boolean, required: false, default: true },
|
|
48
|
+
showHeaderStyle: { type: Boolean, required: false, default: true },
|
|
49
|
+
showModalStyle: { type: Boolean, required: false, default: true },
|
|
48
50
|
header: { type: null, required: false },
|
|
49
51
|
footer: { type: null, required: false },
|
|
50
52
|
visible: { type: Boolean, required: false, skipCheck: true },
|
|
@@ -100,9 +102,9 @@ const dialogLabelledBy = computed(() => {
|
|
|
100
102
|
});
|
|
101
103
|
const passthroughProps = computed(() => {
|
|
102
104
|
return {
|
|
103
|
-
header: {
|
|
104
|
-
class: "header"
|
|
105
|
-
},
|
|
105
|
+
header: () => ({
|
|
106
|
+
class: ["header", { "header-styles": props.showHeaderStyle }]
|
|
107
|
+
}),
|
|
106
108
|
content: {
|
|
107
109
|
class: "content"
|
|
108
110
|
},
|
|
@@ -117,5 +119,5 @@ const passthroughProps = computed(() => {
|
|
|
117
119
|
</script>
|
|
118
120
|
|
|
119
121
|
<style>
|
|
120
|
-
@reference "tailwindcss";.dialog{background-color:var(--color-global-background);border:1px solid var(--color-global-background-accent);border-radius:var(--radius-md);height:calc(100% - --spacing(4));
|
|
122
|
+
@reference "tailwindcss";.dialog{margin:--spacing(2);width:100%}.dialog .header{align-items:center;display:flex;gap:--spacing(3);padding-bottom:--spacing(3)}.dialog .header .title{flex-grow:1;font-size:var(--text-lg)}.dialog .content{overflow-y:auto}.dialog.dialog-styles{background-color:var(--color-global-background);border:1px solid var(--color-global-background-accent);border-radius:var(--radius-md);height:calc(100% - --spacing(4));overflow:clip;@variant sm{box-shadow:var(--shadow-heavy);height:auto}}.dialog.dialog-styles .header{margin-inline:--spacing(3);margin-top:--spacing(3)}.dialog.dialog-styles .header.header-styles{border-bottom:1px solid var(--color-global-background-accent)}.dialog.dialog-styles .content{padding:--spacing(3)}
|
|
121
123
|
</style>
|
|
@@ -2,6 +2,8 @@ import type { DialogProps as PrimeDialogProps } from 'primevue';
|
|
|
2
2
|
export interface DialogProps extends PrimeDialogProps {
|
|
3
3
|
size?: 'xxs' | 'xs' | 'sm' | 'md' | 'lg';
|
|
4
4
|
showHeaderText?: boolean;
|
|
5
|
+
showHeaderStyle?: boolean;
|
|
6
|
+
showModalStyle?: boolean;
|
|
5
7
|
}
|
|
6
8
|
declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<DialogProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
|
|
7
9
|
"update:visible": (visible: boolean) => any;
|
|
@@ -10,6 +12,8 @@ declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<Dialog
|
|
|
10
12
|
}>, {
|
|
11
13
|
size: "xxs" | "xs" | "sm" | "md" | "lg";
|
|
12
14
|
showHeaderText: boolean;
|
|
15
|
+
showHeaderStyle: boolean;
|
|
16
|
+
showModalStyle: boolean;
|
|
13
17
|
modal: boolean;
|
|
14
18
|
contentClass: any;
|
|
15
19
|
closable: boolean;
|
|
@@ -1,7 +1,17 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<Transition name="fade" mode="out-in">
|
|
3
|
-
<
|
|
4
|
-
|
|
3
|
+
<ProgressSpinner
|
|
4
|
+
v-if = "props.loading"
|
|
5
|
+
:size = "props.size"
|
|
6
|
+
class = "icon"
|
|
7
|
+
/>
|
|
8
|
+
|
|
9
|
+
<span
|
|
10
|
+
v-else
|
|
11
|
+
v-bind = "attrs"
|
|
12
|
+
role = "presentation"
|
|
13
|
+
:class = "['icon', props.name, props.size, { 'color-cycle': props.colorCycle }]"
|
|
14
|
+
/>
|
|
5
15
|
</Transition>
|
|
6
16
|
</template>
|
|
7
17
|
|
|
@@ -10,7 +20,9 @@
|
|
|
10
20
|
</script>
|
|
11
21
|
|
|
12
22
|
<script setup>
|
|
13
|
-
import
|
|
23
|
+
import { useAttrs } from "vue";
|
|
24
|
+
import ProgressSpinner from "./ProgressSpinner.vue";
|
|
25
|
+
const attrs = useAttrs();
|
|
14
26
|
const props = defineProps({
|
|
15
27
|
name: { type: String, required: false, default: void 0 },
|
|
16
28
|
loading: { type: Boolean, required: false, default: false },
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<slot
|
|
3
|
+
name = "control"
|
|
4
|
+
:toggle = "(event) => menu?.toggle(event)"
|
|
5
|
+
:menu-id = "menuId"
|
|
6
|
+
:expanded = "visible"
|
|
7
|
+
/>
|
|
8
|
+
|
|
9
|
+
<PrimeMenu
|
|
10
|
+
ref = "menu"
|
|
11
|
+
v-bind = "attrs"
|
|
12
|
+
:model = "props.model"
|
|
13
|
+
:popup = "true"
|
|
14
|
+
:id = "menuId"
|
|
15
|
+
class = "menu"
|
|
16
|
+
:pt = "passthroughProps"
|
|
17
|
+
@show = "visible = true"
|
|
18
|
+
@hide = "visible = false"
|
|
19
|
+
>
|
|
20
|
+
<template v-if="slots.prefix || props.prefixText" #start>
|
|
21
|
+
<slot name="prefix">
|
|
22
|
+
{{ props.prefixText }}
|
|
23
|
+
</slot>
|
|
24
|
+
</template>
|
|
25
|
+
|
|
26
|
+
<template #item="{ item }">
|
|
27
|
+
<slot name="item">
|
|
28
|
+
<IconTextPair
|
|
29
|
+
:text = "isString(item.label) ? item.label : item.label?.()"
|
|
30
|
+
:icon = "item.icon"
|
|
31
|
+
/>
|
|
32
|
+
</slot>
|
|
33
|
+
</template>
|
|
34
|
+
|
|
35
|
+
<template v-if="slots.suffix || props.suffixText" #end>
|
|
36
|
+
<slot name="suffix">
|
|
37
|
+
{{ props.suffixText }}
|
|
38
|
+
</slot>
|
|
39
|
+
</template>
|
|
40
|
+
</PrimeMenu>
|
|
41
|
+
</template>
|
|
42
|
+
|
|
43
|
+
<script>
|
|
44
|
+
|
|
45
|
+
</script>
|
|
46
|
+
|
|
47
|
+
<script setup>
|
|
48
|
+
import { isString } from "@resee-movies/utilities/strings/is-string";
|
|
49
|
+
import PrimeMenu, {} from "primevue/menu";
|
|
50
|
+
import { computed, ref, useAttrs, useId, useSlots } from "vue";
|
|
51
|
+
import IconTextPair from "./IconTextPair.vue";
|
|
52
|
+
defineOptions({
|
|
53
|
+
inheritAttrs: false
|
|
54
|
+
});
|
|
55
|
+
const attrs = useAttrs();
|
|
56
|
+
const slots = useSlots();
|
|
57
|
+
const menuId = useId();
|
|
58
|
+
const menu = ref();
|
|
59
|
+
const visible = ref(false);
|
|
60
|
+
const props = defineProps({
|
|
61
|
+
model: { type: Array, required: true },
|
|
62
|
+
prefixText: { type: String, required: false, default: void 0 },
|
|
63
|
+
suffixText: { type: String, required: false, default: void 0 }
|
|
64
|
+
});
|
|
65
|
+
defineExpose({
|
|
66
|
+
toggle: (event) => menu.value?.toggle(event),
|
|
67
|
+
expanded: () => visible.value,
|
|
68
|
+
menuId
|
|
69
|
+
});
|
|
70
|
+
const passthroughProps = computed(() => {
|
|
71
|
+
return {
|
|
72
|
+
start: {
|
|
73
|
+
class: "menu-prefix"
|
|
74
|
+
},
|
|
75
|
+
end: {
|
|
76
|
+
class: "menu-suffix"
|
|
77
|
+
},
|
|
78
|
+
transition: {
|
|
79
|
+
name: "fade"
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
});
|
|
83
|
+
</script>
|
|
84
|
+
|
|
85
|
+
<style>
|
|
86
|
+
@reference "tailwindcss";.menu{background-color:var(--color-global-background);border:1px solid var(--color-global-background-accent);border-radius:var(--radius-md);box-shadow:var(--shadow-heavy);margin-block:--spacing(1);max-width:--spacing(80);padding:--spacing(1)}.menu li[role=separator]{border-bottom:1px solid var(--color-global-background-accent);margin-block:--spacing(1)}.menu li[role=none]{font-weight:var(--font-weight-semibold)}.menu li[role=menuitem],.menu li[role=none]{padding:--spacing(1) --spacing(2);-webkit-user-select:none;-moz-user-select:none;user-select:none}.menu li[role=menuitem]{border-radius:var(--radius-md);cursor:pointer;transition:background-color;transition-duration:var(--default-transition-duration)}.menu li[role=menuitem][data-p-focused=true]{background-color:var(--color-background-scale-c)}.menu li[role=menuitem][aria-disabled=true]{color:var(--color-global-foreground-accent);cursor:not-allowed}.menu li[role=menuitem][aria-disabled=true][data-p-focused=true]{background-color:transparent}.menu .menu-prefix{border-bottom:1px solid var(--color-global-background-accent);margin-bottom:--spacing(1);padding:0 --spacing(2) --spacing(1)}.menu .menu-suffix{border-top:1px solid var(--color-global-background-accent);margin-top:--spacing(1);padding:--spacing(1) --spacing(2) 0}
|
|
87
|
+
</style>
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { ComputedGetter } from 'vue';
|
|
2
|
+
export interface MenuProps {
|
|
3
|
+
model: MenuItem[];
|
|
4
|
+
prefixText?: string;
|
|
5
|
+
suffixText?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface MenuItem {
|
|
8
|
+
label?: string;
|
|
9
|
+
icon?: string;
|
|
10
|
+
disabled?: boolean;
|
|
11
|
+
separator?: boolean;
|
|
12
|
+
items?: MenuItem[];
|
|
13
|
+
}
|
|
14
|
+
export interface MenuExposes {
|
|
15
|
+
toggle: (event: Event) => void;
|
|
16
|
+
menuId: string;
|
|
17
|
+
expanded: ComputedGetter<boolean>;
|
|
18
|
+
}
|
|
19
|
+
declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<MenuProps, MenuExposes, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<MenuProps> & Readonly<{}>, {
|
|
20
|
+
prefixText: string;
|
|
21
|
+
suffixText: string;
|
|
22
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, {
|
|
23
|
+
control?: (props: {
|
|
24
|
+
toggle: (event: Event) => void | undefined;
|
|
25
|
+
menuId: string;
|
|
26
|
+
expanded: boolean;
|
|
27
|
+
}) => any;
|
|
28
|
+
} & {
|
|
29
|
+
prefix?: (props: {}) => any;
|
|
30
|
+
} & {
|
|
31
|
+
item?: (props: {}) => any;
|
|
32
|
+
} & {
|
|
33
|
+
suffix?: (props: {}) => any;
|
|
34
|
+
}>;
|
|
35
|
+
declare const _default: typeof __VLS_export;
|
|
36
|
+
export default _default;
|
|
37
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
38
|
+
new (): {
|
|
39
|
+
$slots: S;
|
|
40
|
+
};
|
|
41
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { IconProps } from './Icon.vue.js';
|
|
2
|
+
export interface ProgressSpinnerProps {
|
|
3
|
+
size?: IconProps['size'];
|
|
4
|
+
}
|
|
5
|
+
declare const __VLS_export: import("vue").DefineComponent<ProgressSpinnerProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ProgressSpinnerProps> & Readonly<{}>, {
|
|
6
|
+
size: "sm" | "md" | "lg" | "xl";
|
|
7
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
8
|
+
declare const _default: typeof __VLS_export;
|
|
9
|
+
export default _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
@layer components{@property --a-underline-mask-stop{syntax:"<percentage>";inherits:false;initial-value:0%}.a,.a.default{--a-underline-mask-stop:0%;--default-underline:var(--color-background-scale-g);--default-underline-emphasis:var(--colorscale-resee-linear);--default-color:currentColor;--default-color-emphasis:currentColor;--accent-underline-base:var(--custom-accent-color,var(--default-underline));--accent-underline-mixed:color-mix(in srgb-linear,var(--accent-underline-base) 15%,var(--default-underline));--accent-underline-emphasis:var(--custom-accent-color,var(--default-underline-emphasis));--accent-color-base:var(--custom-accent-color,var(--default-color));--accent-color-mixed:color-mix(in srgb-linear,var(--accent-color-base) 30%,var(--default-color));--accent-color-emphasis-base:var(--custom-accent-color,var(--default-color-emphasis));--accent-color-emphasis-mixed:color-mix(in srgb-linear,var(--accent-color-emphasis-base) 60%,var(--default-color-emphasis));@variant dark{--default-underline-emphasis:var(--colorscale-resee-lite-linear)}background-image:linear-gradient(to right,var(--accent-underline-mixed),var(--accent-underline-mixed)),linear-gradient(to right,var(--accent-underline-emphasis),var(--accent-underline-emphasis));background-position:100% 100%,0 100%;background-repeat:no-repeat;background-size:100% 1px,100% 1px;-webkit-box-decoration-break:slice;box-decoration-break:slice;color:var(--accent-color-mixed);font-weight:var(--font-weight-semibold);transition:color,background-size,--a-underline-mask-stop;transition-duration:.3s;transition-timing-function:ease-out}.a.default.small,.a.small{font-size:.875rem;line-height:1.25rem}.a.default:focus-visible,.a:focus-visible{outline:none}.a.default:not(:disabled,.disabled,[aria-disabled=true]):focus,.a.default:not(:disabled,.disabled,[aria-disabled=true]):hover,.a:not(:disabled,.disabled,[aria-disabled=true]):focus,.a:not(:disabled,.disabled,[aria-disabled=true]):hover{--a-underline-mask-stop:100%;background-size:0 1px,100% 1px;color:var(--accent-color-emphasis-mixed)}.a.default.no-underline,.a.no-underline{font-weight:var(--font-weight-medium);-webkit-mask-image:linear-gradient(to right,#fff,#fff),linear-gradient(to right,#fff 0 var(--a-underline-mask-stop),transparent var(--a-underline-mask-stop) 100%);mask-image:linear-gradient(to right,#fff,#fff),linear-gradient(to right,#fff 0 var(--a-underline-mask-stop),transparent var(--a-underline-mask-stop) 100%);-webkit-mask-position:top left,bottom left;mask-position:top left,bottom left;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:100% calc(100% - 1px),100% 1px;mask-size:100% calc(100% - 1px),100% 1px}}
|
|
1
|
+
@layer components{@property --a-underline-mask-stop{syntax:"<percentage>";inherits:false;initial-value:0%}.a,.a.default,.prose a,.prose-container a{--a-underline-mask-stop:0%;--default-underline:var(--color-background-scale-g);--default-underline-emphasis:var(--colorscale-resee-linear);--default-color:currentColor;--default-color-emphasis:currentColor;--accent-underline-base:var(--custom-accent-color,var(--default-underline));--accent-underline-mixed:color-mix(in srgb-linear,var(--accent-underline-base) 15%,var(--default-underline));--accent-underline-emphasis:var(--custom-accent-color,var(--default-underline-emphasis));--accent-color-base:var(--custom-accent-color,var(--default-color));--accent-color-mixed:color-mix(in srgb-linear,var(--accent-color-base) 30%,var(--default-color));--accent-color-emphasis-base:var(--custom-accent-color,var(--default-color-emphasis));--accent-color-emphasis-mixed:color-mix(in srgb-linear,var(--accent-color-emphasis-base) 60%,var(--default-color-emphasis));@variant dark{--default-underline-emphasis:var(--colorscale-resee-lite-linear)}background-image:linear-gradient(to right,var(--accent-underline-mixed),var(--accent-underline-mixed)),linear-gradient(to right,var(--accent-underline-emphasis),var(--accent-underline-emphasis));background-position:100% 100%,0 100%;background-repeat:no-repeat;background-size:100% 1px,100% 1px;-webkit-box-decoration-break:slice;box-decoration-break:slice;color:var(--accent-color-mixed);font-weight:var(--font-weight-semibold);transition:color,background-size,--a-underline-mask-stop;transition-duration:.3s;transition-timing-function:ease-out}.a.default.small,.a.small,.prose a.small,.prose-container a.small{font-size:.875rem;line-height:1.25rem}.a.default:focus-visible,.a:focus-visible,.prose a:focus-visible,.prose-container a:focus-visible{outline:none}.a.default:not(:disabled,.disabled,[aria-disabled=true]):focus,.a.default:not(:disabled,.disabled,[aria-disabled=true]):hover,.a:not(:disabled,.disabled,[aria-disabled=true]):focus,.a:not(:disabled,.disabled,[aria-disabled=true]):hover,.prose a:not(:disabled,.disabled,[aria-disabled=true]):focus,.prose a:not(:disabled,.disabled,[aria-disabled=true]):hover,.prose-container a:not(:disabled,.disabled,[aria-disabled=true]):focus,.prose-container a:not(:disabled,.disabled,[aria-disabled=true]):hover{--a-underline-mask-stop:100%;background-size:0 1px,100% 1px;color:var(--accent-color-emphasis-mixed)}.a.default.no-underline,.a.no-underline,.prose a.no-underline,.prose-container a.no-underline{font-weight:var(--font-weight-medium);-webkit-mask-image:linear-gradient(to right,#fff,#fff),linear-gradient(to right,#fff 0 var(--a-underline-mask-stop),transparent var(--a-underline-mask-stop) 100%);mask-image:linear-gradient(to right,#fff,#fff),linear-gradient(to right,#fff 0 var(--a-underline-mask-stop),transparent var(--a-underline-mask-stop) 100%);-webkit-mask-position:top left,bottom left;mask-position:top left,bottom left;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:100% calc(100% - 1px),100% 1px;mask-size:100% calc(100% - 1px),100% 1px}}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
@layer components{@property --btn-background-color{syntax:"<color>";inherits:false;initial-value:transparent}.btn,.btn.default{--btn-border-width:2px;--btn-background-color:var(--color-background-scale-a);--btn-background-focus-color:var(--color-background-scale-c);--btn-border-color:var(--color-background-scale-g);--btn-bg-image-background-layer:linear-gradient(to right,var(--btn-background-color),var(--btn-background-color));--btn-bg-image-border-layer:linear-gradient(to right,var(--btn-border-color),var(--btn-border-color));--btn-bg-image-color-layer:linear-gradient(to right,var(--colorscale-resee-linear));--btn-background-image:var(--btn-bg-image-background-layer),var(--btn-bg-image-border-layer),var(--btn-bg-image-color-layer);@variant dark{--btn-bg-image-color-layer:linear-gradient(to right,var(--colorscale-resee-lite-linear))}}.btn.default.icon-only,.btn.icon-only{--btn-bg-image-color-layer:conic-gradient(from 0deg,var(--colorscale-resee-conic));@variant dark{--btn-bg-image-color-layer:conic-gradient(from 0deg,var(--colorscale-resee-lite-conic))}}.btn{background-clip:padding-box,border-box,border-box;background-image:var(--btn-background-image);background-origin:border-box;background-position:100% 100%;background-repeat:no-repeat;background-size:100%,100% 100%,100%;border:solid var(--btn-border-width) var(--btn-border-color);border-radius:var(--radius-full);cursor:pointer;display:inline-block;padding:--spacing(1) --spacing(5);text-align:center;transition:box-shadow,background-size,--btn-background-color,border-color;transition-duration:.3s;transition-timing-function:ease-in-out}.btn:focus-visible{outline:none}.btn:where(:disabled,.disabled,[aria-disabled=true]):not(.loading){cursor:not-allowed;opacity:.4}.btn.borderless{background-clip:border-box;background-image:var(--btn-bg-image-background-layer);border:2px solid transparent}.btn.icon-only{line-height:1;padding:--spacing(2)}.btn.icon-only .label{display:none}.btn.small{font-size:var(--icon-size-small)}.btn.small.icon-only{padding:--spacing(1.75)}.btn.small:not(.icon-only){padding:--spacing(.5) --spacing(4)}.btn.large{font-size:var(--icon-size-large)}.btn.large.icon-only{padding:--spacing(1.5)}.btn.large:not(.icon-only){padding:--spacing(1.5) --spacing(6)}.btn.loading{cursor:progress}.btn:not(:disabled,.disabled,[aria-disabled=true],.loading):focus-visible,.btn:not(:disabled,.disabled,[aria-disabled=true],.loading):hover{--btn-background-color:var(--btn-background-focus-color);background-size:100%,0 100%,100%;border-color:transparent}.btn:not(:disabled,.disabled,[aria-disabled=true],.loading):focus-visible:not(.borderless),.btn:not(:disabled,.disabled,[aria-disabled=true],.loading):hover:not(.borderless){box-shadow:var(--shadow)}.btn{@variant max-md{&.responsive-grow{padding:.5rem;width:100%}&.responsive-shrink{line-height:1;padding:--spacing(2)}&.responsive-shrink :not(.icon){display:none}}}}
|
|
1
|
+
@layer components{@property --btn-background-color{syntax:"<color>";inherits:false;initial-value:transparent}.btn,.btn.default,.prose button,.prose-container button{--btn-border-width:2px;--btn-background-color:var(--color-background-scale-a);--btn-background-focus-color:var(--color-background-scale-c);--btn-border-color:var(--color-background-scale-g);--btn-bg-image-background-layer:linear-gradient(to right,var(--btn-background-color),var(--btn-background-color));--btn-bg-image-border-layer:linear-gradient(to right,var(--btn-border-color),var(--btn-border-color));--btn-bg-image-color-layer:linear-gradient(to right,var(--colorscale-resee-linear));--btn-background-image:var(--btn-bg-image-background-layer),var(--btn-bg-image-border-layer),var(--btn-bg-image-color-layer);@variant dark{--btn-bg-image-color-layer:linear-gradient(to right,var(--colorscale-resee-lite-linear))}}.btn.default.icon-only,.btn.icon-only,.prose button.icon-only,.prose-container button.icon-only{--btn-bg-image-color-layer:conic-gradient(from 0deg,var(--colorscale-resee-conic));@variant dark{--btn-bg-image-color-layer:conic-gradient(from 0deg,var(--colorscale-resee-lite-conic))}}.btn,.prose button,.prose-container button{background-clip:padding-box,border-box,border-box;background-image:var(--btn-background-image);background-origin:border-box;background-position:100% 100%;background-repeat:no-repeat;background-size:100%,100% 100%,100%;border:solid var(--btn-border-width) var(--btn-border-color);border-radius:var(--radius-full);cursor:pointer;display:inline-block;padding:--spacing(1) --spacing(5);text-align:center;transition:box-shadow,background-size,--btn-background-color,border-color;transition-duration:.3s;transition-timing-function:ease-in-out}.btn:focus-visible,.prose button:focus-visible,.prose-container button:focus-visible{outline:none}.btn:where(:disabled,.disabled,[aria-disabled=true]):not(.loading),.prose button:where(:disabled,.disabled,[aria-disabled=true]):not(.loading),.prose-container button:where(:disabled,.disabled,[aria-disabled=true]):not(.loading){cursor:not-allowed;opacity:.4}.btn.borderless,.prose button.borderless,.prose-container button.borderless{background-clip:border-box;background-image:var(--btn-bg-image-background-layer);border:2px solid transparent}.btn.icon-only,.prose button.icon-only,.prose-container button.icon-only{line-height:1;padding:--spacing(2)}.btn.icon-only .label,.prose button.icon-only .label,.prose-container button.icon-only .label{display:none}.btn.small,.prose button.small,.prose-container button.small{font-size:var(--icon-size-small)}.btn.small.icon-only,.prose button.small.icon-only,.prose-container button.small.icon-only{padding:--spacing(1.75)}.btn.small:not(.icon-only),.prose button.small:not(.icon-only),.prose-container button.small:not(.icon-only){padding:--spacing(.5) --spacing(4)}.btn.large,.prose button.large,.prose-container button.large{font-size:var(--icon-size-large)}.btn.large.icon-only,.prose button.large.icon-only,.prose-container button.large.icon-only{padding:--spacing(1.5)}.btn.large:not(.icon-only),.prose button.large:not(.icon-only),.prose-container button.large:not(.icon-only){padding:--spacing(1.5) --spacing(6)}.btn.loading,.prose button.loading,.prose-container button.loading{cursor:progress}.btn:not(:disabled,.disabled,[aria-disabled=true],.loading):focus-visible,.btn:not(:disabled,.disabled,[aria-disabled=true],.loading):hover,.prose button:not(:disabled,.disabled,[aria-disabled=true],.loading):focus-visible,.prose button:not(:disabled,.disabled,[aria-disabled=true],.loading):hover,.prose-container button:not(:disabled,.disabled,[aria-disabled=true],.loading):focus-visible,.prose-container button:not(:disabled,.disabled,[aria-disabled=true],.loading):hover{--btn-background-color:var(--btn-background-focus-color);background-size:100%,0 100%,100%;border-color:transparent}.btn:not(:disabled,.disabled,[aria-disabled=true],.loading):focus-visible:not(.borderless),.btn:not(:disabled,.disabled,[aria-disabled=true],.loading):hover:not(.borderless),.prose button:not(:disabled,.disabled,[aria-disabled=true],.loading):focus-visible:not(.borderless),.prose button:not(:disabled,.disabled,[aria-disabled=true],.loading):hover:not(.borderless),.prose-container button:not(:disabled,.disabled,[aria-disabled=true],.loading):focus-visible:not(.borderless),.prose-container button:not(:disabled,.disabled,[aria-disabled=true],.loading):hover:not(.borderless){box-shadow:var(--shadow)}.btn,.prose button,.prose-container button{@variant max-md{&.responsive-grow{padding:.5rem;width:100%}&.responsive-shrink{line-height:1;padding:--spacing(2)}&.responsive-shrink :not(.icon){display:none}}}}
|
package/package.json
CHANGED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { IconProps } from './Icon.vue.js';
|
|
2
|
-
export interface LoadingIndicatorProps {
|
|
3
|
-
size?: IconProps['size'];
|
|
4
|
-
}
|
|
5
|
-
declare const __VLS_export: import("vue").DefineComponent<LoadingIndicatorProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<LoadingIndicatorProps> & Readonly<{}>, {
|
|
6
|
-
size: "sm" | "md" | "lg" | "xl";
|
|
7
|
-
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
8
|
-
declare const _default: typeof __VLS_export;
|
|
9
|
-
export default _default;
|
|
File without changes
|