@sentropic/design-system-vue 0.18.0 → 0.20.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.
@@ -0,0 +1,53 @@
1
+ export type AppHeaderProps = {
2
+ compact?: boolean;
3
+ menuOpen?: boolean;
4
+ menuLabel?: string;
5
+ class?: string;
6
+ };
7
+ export declare const AppHeader: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
8
+ compact: {
9
+ type: BooleanConstructor;
10
+ default: boolean;
11
+ };
12
+ menuOpen: {
13
+ type: BooleanConstructor;
14
+ default: boolean;
15
+ };
16
+ menuLabel: {
17
+ type: StringConstructor;
18
+ default: string;
19
+ };
20
+ class: {
21
+ type: StringConstructor;
22
+ default: undefined;
23
+ };
24
+ }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
25
+ [key: string]: any;
26
+ }> | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
27
+ [key: string]: any;
28
+ }>[], {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "menuToggle"[], "menuToggle", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
29
+ compact: {
30
+ type: BooleanConstructor;
31
+ default: boolean;
32
+ };
33
+ menuOpen: {
34
+ type: BooleanConstructor;
35
+ default: boolean;
36
+ };
37
+ menuLabel: {
38
+ type: StringConstructor;
39
+ default: string;
40
+ };
41
+ class: {
42
+ type: StringConstructor;
43
+ default: undefined;
44
+ };
45
+ }>> & Readonly<{
46
+ onMenuToggle?: ((...args: any[]) => any) | undefined;
47
+ }>, {
48
+ class: string;
49
+ compact: boolean;
50
+ menuOpen: boolean;
51
+ menuLabel: string;
52
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
53
+ //# sourceMappingURL=AppHeader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AppHeader.d.ts","sourceRoot":"","sources":["../src/AppHeader.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,cAAc,GAAG;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAgDF,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4EA+DpB,CAAC"}
@@ -0,0 +1,88 @@
1
+ import { defineComponent, h } from "vue";
2
+ import { classNames } from "./classNames.js";
3
+ // Icônes lucide reproduites en SVG inline (mêmes paths que @lucide/svelte) pour
4
+ // conserver une parité stricte sans dépendance lucide-vue-next.
5
+ function MenuIcon() {
6
+ return h("svg", {
7
+ width: 20,
8
+ height: 20,
9
+ viewBox: "0 0 24 24",
10
+ fill: "none",
11
+ stroke: "currentColor",
12
+ "stroke-width": 2,
13
+ "stroke-linecap": "round",
14
+ "stroke-linejoin": "round",
15
+ "aria-hidden": "true",
16
+ focusable: "false",
17
+ class: "st-appHeader__burgerIcon",
18
+ }, [
19
+ h("path", { d: "M4 5h16" }),
20
+ h("path", { d: "M4 12h16" }),
21
+ h("path", { d: "M4 19h16" }),
22
+ ]);
23
+ }
24
+ function XIcon() {
25
+ return h("svg", {
26
+ width: 20,
27
+ height: 20,
28
+ viewBox: "0 0 24 24",
29
+ fill: "none",
30
+ stroke: "currentColor",
31
+ "stroke-width": 2,
32
+ "stroke-linecap": "round",
33
+ "stroke-linejoin": "round",
34
+ "aria-hidden": "true",
35
+ focusable: "false",
36
+ class: "st-appHeader__burgerIcon",
37
+ }, [h("path", { d: "M18 6 6 18" }), h("path", { d: "m6 6 12 12" })]);
38
+ }
39
+ export const AppHeader = defineComponent({
40
+ name: "AppHeader",
41
+ props: {
42
+ compact: { type: Boolean, default: false },
43
+ menuOpen: { type: Boolean, default: false },
44
+ menuLabel: { type: String, default: "Menu" },
45
+ class: { type: String, default: undefined },
46
+ },
47
+ emits: ["menuToggle"],
48
+ setup(props, { slots, emit }) {
49
+ const onToggle = () => emit("menuToggle");
50
+ return () => {
51
+ const bar = h("div", { class: "st-appHeader__bar" }, [
52
+ props.compact
53
+ ? h("div", { class: "st-appHeader__burger" }, [
54
+ h("button", {
55
+ type: "button",
56
+ class: "st-appHeader__burgerButton",
57
+ "aria-label": props.menuLabel,
58
+ "aria-expanded": props.menuOpen ? "true" : "false",
59
+ "aria-haspopup": "menu",
60
+ onClick: onToggle,
61
+ }, [props.menuOpen ? XIcon() : MenuIcon()]),
62
+ ])
63
+ : h("nav", { class: "st-appHeader__nav", "aria-label": "Primary" }, slots.nav?.()),
64
+ slots.logo
65
+ ? h("div", { class: "st-appHeader__logo" }, slots.logo())
66
+ : null,
67
+ !props.compact
68
+ ? h("div", { class: "st-appHeader__actions" }, slots.actions?.())
69
+ : null,
70
+ ]);
71
+ const header = h("header", { class: classNames("st-appHeader", props.class) }, [bar]);
72
+ if (props.compact && props.menuOpen && slots.drawer) {
73
+ return [
74
+ header,
75
+ h("button", {
76
+ type: "button",
77
+ class: "st-appHeader__scrim",
78
+ "aria-label": props.menuLabel,
79
+ onClick: onToggle,
80
+ }),
81
+ h("aside", { class: "st-appHeader__drawer" }, slots.drawer()),
82
+ ];
83
+ }
84
+ return header;
85
+ };
86
+ },
87
+ });
88
+ //# sourceMappingURL=AppHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AppHeader.js","sourceRoot":"","sources":["../src/AppHeader.ts"],"names":[],"mappings":"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"}
package/dist/Avatar.d.ts CHANGED
@@ -77,9 +77,9 @@ export declare const Avatar: import("vue").DefineComponent<import("vue").Extract
77
77
  }>> & Readonly<{}>, {
78
78
  class: string;
79
79
  tone: AvatarTone;
80
+ size: AvatarSize;
80
81
  src: string;
81
82
  alt: string;
82
- size: AvatarSize;
83
83
  shape: AvatarShape;
84
84
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
85
85
  //# sourceMappingURL=Avatar.d.ts.map
@@ -46,8 +46,8 @@ export declare const AvatarGroup: import("vue").DefineComponent<import("vue").Ex
46
46
  };
47
47
  }>> & Readonly<{}>, {
48
48
  class: string;
49
- max: number;
50
49
  size: AvatarSize;
50
+ max: number;
51
51
  total: number;
52
52
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
53
53
  //# sourceMappingURL=AvatarGroup.d.ts.map
@@ -64,8 +64,8 @@ export declare const CopyButton: import("vue").DefineComponent<import("vue").Ext
64
64
  }>, {
65
65
  class: string;
66
66
  label: string;
67
- text: string;
68
67
  size: CopyButtonSize;
68
+ text: string;
69
69
  value: string;
70
70
  copiedLabel: string;
71
71
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
@@ -121,9 +121,9 @@ export declare const GaugeChart: import("vue").DefineComponent<import("vue").Ext
121
121
  }>> & Readonly<{}>, {
122
122
  class: string;
123
123
  label: string;
124
+ size: number;
124
125
  min: number;
125
126
  max: number;
126
- size: number;
127
127
  thickness: number;
128
128
  thresholds: GaugeChartThreshold[];
129
129
  format: GaugeChartFormat;
@@ -0,0 +1,119 @@
1
+ export type IdentityUser = {
2
+ displayName: string;
3
+ email?: string;
4
+ id?: string;
5
+ };
6
+ export type IdentityMenuProps = {
7
+ user?: IdentityUser | null;
8
+ isAuthenticated?: boolean;
9
+ devicesHref?: string;
10
+ settingsHref?: string;
11
+ loginLabel?: string;
12
+ devicesLabel?: string;
13
+ settingsLabel?: string;
14
+ logoutLabel?: string;
15
+ variant?: "dropdown" | "accordion";
16
+ class?: string;
17
+ };
18
+ /** Première lettre du displayName, en majuscule (calque de la source). */
19
+ export declare function identityInitial(user: IdentityUser | null | undefined): string;
20
+ export declare const IdentityMenu: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
21
+ user: {
22
+ type: () => IdentityUser | null;
23
+ default: null;
24
+ };
25
+ isAuthenticated: {
26
+ type: BooleanConstructor;
27
+ default: boolean;
28
+ };
29
+ devicesHref: {
30
+ type: StringConstructor;
31
+ default: string;
32
+ };
33
+ settingsHref: {
34
+ type: StringConstructor;
35
+ default: string;
36
+ };
37
+ loginLabel: {
38
+ type: StringConstructor;
39
+ default: string;
40
+ };
41
+ devicesLabel: {
42
+ type: StringConstructor;
43
+ default: string;
44
+ };
45
+ settingsLabel: {
46
+ type: StringConstructor;
47
+ default: string;
48
+ };
49
+ logoutLabel: {
50
+ type: StringConstructor;
51
+ default: string;
52
+ };
53
+ variant: {
54
+ type: () => "dropdown" | "accordion";
55
+ default: string;
56
+ };
57
+ class: {
58
+ type: StringConstructor;
59
+ default: undefined;
60
+ };
61
+ }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
62
+ [key: string]: any;
63
+ }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("login" | "logout")[], "login" | "logout", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
64
+ user: {
65
+ type: () => IdentityUser | null;
66
+ default: null;
67
+ };
68
+ isAuthenticated: {
69
+ type: BooleanConstructor;
70
+ default: boolean;
71
+ };
72
+ devicesHref: {
73
+ type: StringConstructor;
74
+ default: string;
75
+ };
76
+ settingsHref: {
77
+ type: StringConstructor;
78
+ default: string;
79
+ };
80
+ loginLabel: {
81
+ type: StringConstructor;
82
+ default: string;
83
+ };
84
+ devicesLabel: {
85
+ type: StringConstructor;
86
+ default: string;
87
+ };
88
+ settingsLabel: {
89
+ type: StringConstructor;
90
+ default: string;
91
+ };
92
+ logoutLabel: {
93
+ type: StringConstructor;
94
+ default: string;
95
+ };
96
+ variant: {
97
+ type: () => "dropdown" | "accordion";
98
+ default: string;
99
+ };
100
+ class: {
101
+ type: StringConstructor;
102
+ default: undefined;
103
+ };
104
+ }>> & Readonly<{
105
+ onLogin?: ((...args: any[]) => any) | undefined;
106
+ onLogout?: ((...args: any[]) => any) | undefined;
107
+ }>, {
108
+ class: string;
109
+ variant: "accordion" | "dropdown";
110
+ user: IdentityUser | null;
111
+ isAuthenticated: boolean;
112
+ devicesHref: string;
113
+ settingsHref: string;
114
+ loginLabel: string;
115
+ devicesLabel: string;
116
+ settingsLabel: string;
117
+ logoutLabel: string;
118
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
119
+ //# sourceMappingURL=IdentityMenu.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IdentityMenu.d.ts","sourceRoot":"","sources":["../src/IdentityMenu.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,YAAY,GAAG;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,EAAE,CAAC,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,IAAI,CAAC,EAAE,YAAY,GAAG,IAAI,CAAC;IAC3B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,UAAU,GAAG,WAAW,CAAC;IACnC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,0EAA0E;AAC1E,wBAAgB,eAAe,CAAC,IAAI,EAAE,YAAY,GAAG,IAAI,GAAG,SAAS,GAAG,MAAM,CAG7E;AAyBD,eAAO,MAAM,YAAY;;cAGG,MAAM,YAAY,GAAG,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAQtB,MAAM,UAAU,GAAG,WAAW;;;;;;;;;;;cARjC,MAAM,YAAY,GAAG,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAQtB,MAAM,UAAU,GAAG,WAAW;;;;;;;;;;;;;;;;;;;;;4EA6L3D,CAAC"}
@@ -0,0 +1,181 @@
1
+ import { defineComponent, h, onBeforeUnmount, ref, watch } from "vue";
2
+ import { classNames } from "./classNames.js";
3
+ /** Première lettre du displayName, en majuscule (calque de la source). */
4
+ export function identityInitial(user) {
5
+ const source = user?.displayName || user?.email || "U";
6
+ return source.charAt(0).toUpperCase();
7
+ }
8
+ function ChevronDownIcon(open) {
9
+ return h("svg", {
10
+ width: 16,
11
+ height: 16,
12
+ viewBox: "0 0 24 24",
13
+ fill: "none",
14
+ stroke: "currentColor",
15
+ "stroke-width": 2,
16
+ "stroke-linecap": "round",
17
+ "stroke-linejoin": "round",
18
+ "aria-hidden": "true",
19
+ focusable: "false",
20
+ class: classNames("st-identityMenu__chevron", open && "st-identityMenu__chevron--open"),
21
+ }, [h("path", { d: "m6 9 6 6 6-6" })]);
22
+ }
23
+ export const IdentityMenu = defineComponent({
24
+ name: "IdentityMenu",
25
+ props: {
26
+ user: { type: Object, default: null },
27
+ isAuthenticated: { type: Boolean, default: false },
28
+ devicesHref: { type: String, default: "#" },
29
+ settingsHref: { type: String, default: "#" },
30
+ loginLabel: { type: String, default: "Se connecter" },
31
+ devicesLabel: { type: String, default: "Appareils" },
32
+ settingsLabel: { type: String, default: "Paramètres" },
33
+ logoutLabel: { type: String, default: "Se déconnecter" },
34
+ variant: { type: String, default: "dropdown" },
35
+ class: { type: String, default: undefined },
36
+ },
37
+ emits: ["login", "logout"],
38
+ setup(props, { emit }) {
39
+ const open = ref(false);
40
+ const rootEl = ref(null);
41
+ const triggerEl = ref(null);
42
+ const onPointerDown = (event) => {
43
+ const target = event.target;
44
+ if (open.value && rootEl.value && target && !rootEl.value.contains(target)) {
45
+ open.value = false;
46
+ }
47
+ };
48
+ watch(open, (value) => {
49
+ if (value) {
50
+ document.addEventListener("pointerdown", onPointerDown);
51
+ }
52
+ else {
53
+ document.removeEventListener("pointerdown", onPointerDown);
54
+ }
55
+ });
56
+ onBeforeUnmount(() => document.removeEventListener("pointerdown", onPointerDown));
57
+ const getItems = () => Array.from(rootEl.value?.querySelectorAll('[role="menuitem"]') ?? []);
58
+ const focusItem = (index) => {
59
+ const items = getItems();
60
+ if (!items.length)
61
+ return;
62
+ const len = items.length;
63
+ items[((index % len) + len) % len]?.focus();
64
+ };
65
+ const closeAndFocusTrigger = () => {
66
+ open.value = false;
67
+ triggerEl.value?.focus();
68
+ };
69
+ const onTriggerKeyDown = (event) => {
70
+ if (event.key === "ArrowDown" || event.key === "Enter" || event.key === " ") {
71
+ event.preventDefault();
72
+ open.value = true;
73
+ queueMicrotask(() => focusItem(0));
74
+ }
75
+ else if (event.key === "ArrowUp") {
76
+ event.preventDefault();
77
+ open.value = true;
78
+ queueMicrotask(() => focusItem(-1));
79
+ }
80
+ };
81
+ const onMenuKeyDown = (event) => {
82
+ const items = getItems();
83
+ const current = items.indexOf(document.activeElement);
84
+ if (event.key === "ArrowDown") {
85
+ event.preventDefault();
86
+ focusItem(current + 1);
87
+ }
88
+ else if (event.key === "ArrowUp") {
89
+ event.preventDefault();
90
+ focusItem(current - 1);
91
+ }
92
+ else if (event.key === "Home") {
93
+ event.preventDefault();
94
+ focusItem(0);
95
+ }
96
+ else if (event.key === "End") {
97
+ event.preventDefault();
98
+ focusItem(items.length - 1);
99
+ }
100
+ else if (event.key === "Escape") {
101
+ event.preventDefault();
102
+ closeAndFocusTrigger();
103
+ }
104
+ };
105
+ return () => {
106
+ const user = props.user;
107
+ if (!(props.isAuthenticated && user)) {
108
+ return h("button", {
109
+ type: "button",
110
+ class: classNames("st-identityMenu__login", props.variant === "accordion" && "st-identityMenu__login--accordion", props.class),
111
+ onClick: () => emit("login"),
112
+ }, props.loginLabel);
113
+ }
114
+ const displayName = user.displayName || user.email || "User";
115
+ return h("div", {
116
+ ref: rootEl,
117
+ class: classNames("st-identityMenu", props.variant === "accordion" && "st-identityMenu--accordion", props.class),
118
+ }, [
119
+ h("button", {
120
+ type: "button",
121
+ ref: triggerEl,
122
+ class: "st-identityMenu__trigger",
123
+ "aria-haspopup": "menu",
124
+ "aria-expanded": open.value ? "true" : "false",
125
+ "aria-label": `Compte de ${displayName}`,
126
+ onClick: () => (open.value = !open.value),
127
+ onKeydown: onTriggerKeyDown,
128
+ }, [
129
+ h("span", { class: "st-identityMenu__avatar", "aria-hidden": "true" }, identityInitial(user)),
130
+ h("span", { class: "st-identityMenu__meta" }, [
131
+ h("span", { class: "st-identityMenu__name" }, displayName),
132
+ props.variant === "accordion" && user.email
133
+ ? h("span", { class: "st-identityMenu__email" }, user.email)
134
+ : null,
135
+ ]),
136
+ ChevronDownIcon(open.value),
137
+ ]),
138
+ open.value
139
+ ? h("div", {
140
+ class: "st-identityMenu__menu",
141
+ role: "menu",
142
+ tabindex: "-1",
143
+ "aria-label": `Menu de ${displayName}`,
144
+ onKeydown: onMenuKeyDown,
145
+ }, [
146
+ h("a", {
147
+ href: props.devicesHref,
148
+ class: "st-identityMenu__item",
149
+ role: "menuitem",
150
+ tabindex: "-1",
151
+ onClick: () => (open.value = false),
152
+ }, props.devicesLabel),
153
+ h("a", {
154
+ href: props.settingsHref,
155
+ class: "st-identityMenu__item",
156
+ role: "menuitem",
157
+ tabindex: "-1",
158
+ onClick: () => (open.value = false),
159
+ }, props.settingsLabel),
160
+ h("div", {
161
+ class: "st-identityMenu__divider",
162
+ role: "separator",
163
+ "aria-hidden": "true",
164
+ }),
165
+ h("button", {
166
+ type: "button",
167
+ class: "st-identityMenu__item st-identityMenu__item--danger",
168
+ role: "menuitem",
169
+ tabindex: "-1",
170
+ onClick: () => {
171
+ open.value = false;
172
+ emit("logout");
173
+ },
174
+ }, props.logoutLabel),
175
+ ])
176
+ : null,
177
+ ]);
178
+ };
179
+ },
180
+ });
181
+ //# sourceMappingURL=IdentityMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IdentityMenu.js","sourceRoot":"","sources":["../src/IdentityMenu.ts"],"names":[],"mappings":"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"}
package/dist/KpiCard.d.ts CHANGED
@@ -138,8 +138,8 @@ export declare const KpiCard: import("vue").DefineComponent<import("vue").Extrac
138
138
  }>> & Readonly<{}>, {
139
139
  class: string;
140
140
  tone: KpiCardTone;
141
- locale: string;
142
141
  size: KpiCardSize;
142
+ locale: string;
143
143
  format: KpiCardFormat;
144
144
  unit: string;
145
145
  currency: string;
@@ -0,0 +1,82 @@
1
+ export type LanguageToggleLocale = "fr" | "en";
2
+ export type LanguageToggleProps = {
3
+ locale?: LanguageToggleLocale;
4
+ frLabel?: string;
5
+ enLabel?: string;
6
+ label?: string;
7
+ variant?: "select" | "accordion";
8
+ accordionLabel?: string;
9
+ class?: string;
10
+ };
11
+ export declare const LanguageToggle: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
12
+ locale: {
13
+ type: () => LanguageToggleLocale;
14
+ default: string;
15
+ };
16
+ frLabel: {
17
+ type: StringConstructor;
18
+ default: string;
19
+ };
20
+ enLabel: {
21
+ type: StringConstructor;
22
+ default: string;
23
+ };
24
+ label: {
25
+ type: StringConstructor;
26
+ default: string;
27
+ };
28
+ variant: {
29
+ type: () => "select" | "accordion";
30
+ default: string;
31
+ };
32
+ accordionLabel: {
33
+ type: StringConstructor;
34
+ default: string;
35
+ };
36
+ class: {
37
+ type: StringConstructor;
38
+ default: undefined;
39
+ };
40
+ }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
41
+ [key: string]: any;
42
+ }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "localeChange"[], "localeChange", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
43
+ locale: {
44
+ type: () => LanguageToggleLocale;
45
+ default: string;
46
+ };
47
+ frLabel: {
48
+ type: StringConstructor;
49
+ default: string;
50
+ };
51
+ enLabel: {
52
+ type: StringConstructor;
53
+ default: string;
54
+ };
55
+ label: {
56
+ type: StringConstructor;
57
+ default: string;
58
+ };
59
+ variant: {
60
+ type: () => "select" | "accordion";
61
+ default: string;
62
+ };
63
+ accordionLabel: {
64
+ type: StringConstructor;
65
+ default: string;
66
+ };
67
+ class: {
68
+ type: StringConstructor;
69
+ default: undefined;
70
+ };
71
+ }>> & Readonly<{
72
+ onLocaleChange?: ((...args: any[]) => any) | undefined;
73
+ }>, {
74
+ class: string;
75
+ label: string;
76
+ locale: LanguageToggleLocale;
77
+ variant: "select" | "accordion";
78
+ frLabel: string;
79
+ enLabel: string;
80
+ accordionLabel: string;
81
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
82
+ //# sourceMappingURL=LanguageToggle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LanguageToggle.d.ts","sourceRoot":"","sources":["../src/LanguageToggle.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,oBAAoB,GAAG,IAAI,GAAG,IAAI,CAAC;AAE/C,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,CAAC,EAAE,oBAAoB,CAAC;IAC9B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,QAAQ,GAAG,WAAW,CAAC;IACjC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAyBF,eAAO,MAAM,cAAc;;cAGG,MAAM,oBAAoB;;;;;;;;;;;;;;;;cAIzB,MAAM,QAAQ,GAAG,WAAW;;;;;;;;;;;;;;;cAJ7B,MAAM,oBAAoB;;;;;;;;;;;;;;;;cAIzB,MAAM,QAAQ,GAAG,WAAW;;;;;;;;;;;;;;;;;;;;;4EAuEzD,CAAC"}