@mekari/pixel3-accordion 0.0.1 → 0.0.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.
- package/dist/accordion.d.mts +44 -0
- package/dist/accordion.d.ts +44 -0
- package/dist/accordion.js +70 -49
- package/dist/accordion.mjs +5 -1
- package/dist/chunk-2MFH6MEI.mjs +56 -0
- package/dist/chunk-6FLZM2UD.mjs +69 -0
- package/dist/chunk-CJKS7PMG.mjs +61 -0
- package/dist/chunk-GSM3VVNB.mjs +37 -0
- package/dist/chunk-KJJ7ZOJB.mjs +49 -0
- package/dist/chunk-PFYTMT2T.mjs +11 -0
- package/dist/chunk-QK7KPGDG.mjs +47 -0
- package/dist/chunk-QZ7VFGWC.mjs +6 -0
- package/dist/chunk-SZIA7VIC.mjs +38 -0
- package/dist/header.d.mts +18 -0
- package/dist/header.d.ts +18 -0
- package/dist/header.js +88 -0
- package/dist/header.mjs +9 -0
- package/dist/icon.d.mts +45 -0
- package/dist/icon.d.ts +45 -0
- package/dist/icon.js +81 -0
- package/dist/icon.mjs +9 -0
- package/dist/index.d.mts +7 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +298 -52
- package/dist/index.mjs +22 -2
- package/dist/item.d.mts +48 -0
- package/dist/item.d.ts +48 -0
- package/dist/item.js +132 -0
- package/dist/item.mjs +10 -0
- package/dist/metafile-cjs.json +1 -1
- package/dist/metafile-esm.json +1 -1
- package/dist/modules/accordion.context.d.mts +26 -0
- package/dist/modules/accordion.context.d.ts +26 -0
- package/dist/modules/accordion.context.js +38 -0
- package/dist/modules/accordion.context.mjs +13 -0
- package/dist/modules/accordion.props.d.mts +67 -0
- package/dist/modules/accordion.props.d.ts +67 -0
- package/dist/modules/accordion.props.js +96 -0
- package/dist/modules/accordion.props.mjs +13 -0
- package/dist/modules/useAccordion.d.mts +16 -0
- package/dist/modules/useAccordion.d.ts +16 -0
- package/dist/modules/useAccordion.js +87 -0
- package/dist/modules/useAccordion.mjs +10 -0
- package/dist/panel.d.mts +6 -0
- package/dist/panel.d.ts +6 -0
- package/dist/panel.js +65 -0
- package/dist/panel.mjs +8 -0
- package/package.json +11 -11
- package/dist/chunk-EJFISPTU.mjs +0 -50
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import * as vue_jsx_runtime from 'vue/jsx-runtime';
|
|
2
|
+
import * as vue from 'vue';
|
|
3
|
+
|
|
4
|
+
declare const MpAccordion: vue.DefineComponent<{
|
|
5
|
+
defaultIndexOpen: {
|
|
6
|
+
type: vue.PropType<number>;
|
|
7
|
+
};
|
|
8
|
+
isAllowMultiple: {
|
|
9
|
+
type: vue.PropType<boolean>;
|
|
10
|
+
default: boolean;
|
|
11
|
+
};
|
|
12
|
+
isAllowToggle: {
|
|
13
|
+
type: vue.PropType<boolean>;
|
|
14
|
+
default: boolean;
|
|
15
|
+
};
|
|
16
|
+
isControlled: {
|
|
17
|
+
type: vue.PropType<boolean>;
|
|
18
|
+
default: boolean;
|
|
19
|
+
};
|
|
20
|
+
}, () => vue_jsx_runtime.JSX.Element, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, "change"[], "change", vue.PublicProps, Readonly<vue.ExtractPropTypes<{
|
|
21
|
+
defaultIndexOpen: {
|
|
22
|
+
type: vue.PropType<number>;
|
|
23
|
+
};
|
|
24
|
+
isAllowMultiple: {
|
|
25
|
+
type: vue.PropType<boolean>;
|
|
26
|
+
default: boolean;
|
|
27
|
+
};
|
|
28
|
+
isAllowToggle: {
|
|
29
|
+
type: vue.PropType<boolean>;
|
|
30
|
+
default: boolean;
|
|
31
|
+
};
|
|
32
|
+
isControlled: {
|
|
33
|
+
type: vue.PropType<boolean>;
|
|
34
|
+
default: boolean;
|
|
35
|
+
};
|
|
36
|
+
}>> & {
|
|
37
|
+
onChange?: ((...args: any[]) => any) | undefined;
|
|
38
|
+
}, {
|
|
39
|
+
isAllowMultiple: boolean;
|
|
40
|
+
isAllowToggle: boolean;
|
|
41
|
+
isControlled: boolean;
|
|
42
|
+
}, {}>;
|
|
43
|
+
|
|
44
|
+
export { MpAccordion };
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import * as vue_jsx_runtime from 'vue/jsx-runtime';
|
|
2
|
+
import * as vue from 'vue';
|
|
3
|
+
|
|
4
|
+
declare const MpAccordion: vue.DefineComponent<{
|
|
5
|
+
defaultIndexOpen: {
|
|
6
|
+
type: vue.PropType<number>;
|
|
7
|
+
};
|
|
8
|
+
isAllowMultiple: {
|
|
9
|
+
type: vue.PropType<boolean>;
|
|
10
|
+
default: boolean;
|
|
11
|
+
};
|
|
12
|
+
isAllowToggle: {
|
|
13
|
+
type: vue.PropType<boolean>;
|
|
14
|
+
default: boolean;
|
|
15
|
+
};
|
|
16
|
+
isControlled: {
|
|
17
|
+
type: vue.PropType<boolean>;
|
|
18
|
+
default: boolean;
|
|
19
|
+
};
|
|
20
|
+
}, () => vue_jsx_runtime.JSX.Element, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, "change"[], "change", vue.PublicProps, Readonly<vue.ExtractPropTypes<{
|
|
21
|
+
defaultIndexOpen: {
|
|
22
|
+
type: vue.PropType<number>;
|
|
23
|
+
};
|
|
24
|
+
isAllowMultiple: {
|
|
25
|
+
type: vue.PropType<boolean>;
|
|
26
|
+
default: boolean;
|
|
27
|
+
};
|
|
28
|
+
isAllowToggle: {
|
|
29
|
+
type: vue.PropType<boolean>;
|
|
30
|
+
default: boolean;
|
|
31
|
+
};
|
|
32
|
+
isControlled: {
|
|
33
|
+
type: vue.PropType<boolean>;
|
|
34
|
+
default: boolean;
|
|
35
|
+
};
|
|
36
|
+
}>> & {
|
|
37
|
+
onChange?: ((...args: any[]) => any) | undefined;
|
|
38
|
+
}, {
|
|
39
|
+
isAllowMultiple: boolean;
|
|
40
|
+
isAllowToggle: boolean;
|
|
41
|
+
isControlled: boolean;
|
|
42
|
+
}, {}>;
|
|
43
|
+
|
|
44
|
+
export { MpAccordion };
|
package/dist/accordion.js
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
2
|
var __defProp = Object.defineProperty;
|
|
4
3
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
5
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
8
7
|
var __export = (target, all) => {
|
|
9
8
|
for (var name in all)
|
|
10
9
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
@@ -17,14 +16,6 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
17
16
|
}
|
|
18
17
|
return to;
|
|
19
18
|
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
19
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
20
|
|
|
30
21
|
// src/accordion.tsx
|
|
@@ -33,48 +24,78 @@ __export(accordion_exports, {
|
|
|
33
24
|
MpAccordion: () => MpAccordion
|
|
34
25
|
});
|
|
35
26
|
module.exports = __toCommonJS(accordion_exports);
|
|
36
|
-
var
|
|
37
|
-
var accordion = __toESM(require("@zag-js/accordion"));
|
|
38
|
-
var import_vue2 = require("@zag-js/vue");
|
|
27
|
+
var import_vue2 = require("vue");
|
|
39
28
|
var import_vue3 = require("vue");
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
}
|
|
51
|
-
|
|
29
|
+
|
|
30
|
+
// src/modules/accordion.context.ts
|
|
31
|
+
var import_pixel3_utils = require("@mekari/pixel3-utils");
|
|
32
|
+
var [AccordionProvider, useAccordionContext] = (0, import_pixel3_utils.usePixelCreateContext)("AccordionContext");
|
|
33
|
+
var [AccordionItemProvider, useAccordionItemContext] = (0, import_pixel3_utils.usePixelCreateContext)("AccordionItemContext");
|
|
34
|
+
|
|
35
|
+
// src/modules/accordion.props.ts
|
|
36
|
+
var accordionProps = {
|
|
37
|
+
defaultIndexOpen: {
|
|
38
|
+
type: Number
|
|
39
|
+
},
|
|
40
|
+
isAllowMultiple: {
|
|
41
|
+
type: Boolean,
|
|
42
|
+
default: false
|
|
43
|
+
},
|
|
44
|
+
isAllowToggle: {
|
|
45
|
+
type: Boolean,
|
|
46
|
+
default: false
|
|
47
|
+
},
|
|
48
|
+
isControlled: {
|
|
49
|
+
type: Boolean,
|
|
50
|
+
default: false
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
// src/modules/useAccordion.ts
|
|
55
|
+
var import_vue = require("vue");
|
|
56
|
+
var import_pixel3_utils2 = require("@mekari/pixel3-utils");
|
|
57
|
+
function useAccordion(props, emit) {
|
|
58
|
+
const expandedIndex = (0, import_vue.ref)(props.defaultIndexOpen);
|
|
59
|
+
function onAccordionChange(index, isExpanded) {
|
|
60
|
+
emit("change", index, isExpanded);
|
|
61
|
+
expandedIndex.value = index;
|
|
62
|
+
}
|
|
63
|
+
__name(onAccordionChange, "onAccordionChange");
|
|
64
|
+
return {
|
|
65
|
+
expandedIndex,
|
|
66
|
+
onAccordionChange
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
__name(useAccordion, "useAccordion");
|
|
70
|
+
|
|
71
|
+
// src/accordion.tsx
|
|
52
72
|
var MpAccordion = (0, import_vue3.defineComponent)({
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
const
|
|
61
|
-
|
|
73
|
+
name: "MpAccordion",
|
|
74
|
+
props: accordionProps,
|
|
75
|
+
emits: ["change"],
|
|
76
|
+
setup(props, {
|
|
77
|
+
slots,
|
|
78
|
+
emit
|
|
79
|
+
}) {
|
|
80
|
+
const {
|
|
81
|
+
expandedIndex,
|
|
82
|
+
onAccordionChange
|
|
83
|
+
} = useAccordion(props, emit);
|
|
84
|
+
AccordionProvider({
|
|
85
|
+
props: (0, import_vue3.toRefs)(props),
|
|
86
|
+
expandedIndex,
|
|
87
|
+
onAccordionChange
|
|
88
|
+
});
|
|
62
89
|
return () => {
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
}
|
|
72
|
-
"class": classNames.trigger
|
|
73
|
-
}), [item.title, (0, import_vue.createVNode)("div", null, [(0, import_vue.createTextVNode)("Item Indicator")])]), (0, import_vue.createVNode)("div", (0, import_vue.mergeProps)(api.getItemContentProps({
|
|
74
|
-
value: item.title
|
|
75
|
-
}), {
|
|
76
|
-
"class": classNames.content
|
|
77
|
-
}), [(0, import_vue.createVNode)("div", null, [item.content])])]))]);
|
|
90
|
+
const children = slots.default ? slots.default() : [];
|
|
91
|
+
const clone = children.map((node, index) => {
|
|
92
|
+
return (0, import_vue3.cloneVNode)(node, {
|
|
93
|
+
index
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
return (0, import_vue2.createVNode)("div", {
|
|
97
|
+
"data-pixel-component": "MpAccordion"
|
|
98
|
+
}, [clone]);
|
|
78
99
|
};
|
|
79
100
|
}
|
|
80
101
|
});
|
package/dist/accordion.mjs
CHANGED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useAccordionItemContext
|
|
3
|
+
} from "./chunk-PFYTMT2T.mjs";
|
|
4
|
+
import {
|
|
5
|
+
accordionHeaderProps
|
|
6
|
+
} from "./chunk-6FLZM2UD.mjs";
|
|
7
|
+
|
|
8
|
+
// src/header.tsx
|
|
9
|
+
import { createVNode as _createVNode } from "vue";
|
|
10
|
+
import { defineComponent } from "vue";
|
|
11
|
+
import { css } from "@mekari/pixel3-styled-system/css";
|
|
12
|
+
var MpAccordionHeader = defineComponent({
|
|
13
|
+
name: "MpAccordionHeader",
|
|
14
|
+
props: accordionHeaderProps,
|
|
15
|
+
setup(props, {
|
|
16
|
+
slots
|
|
17
|
+
}) {
|
|
18
|
+
const {
|
|
19
|
+
isExpanded,
|
|
20
|
+
onToggle,
|
|
21
|
+
id
|
|
22
|
+
} = useAccordionItemContext();
|
|
23
|
+
return () => {
|
|
24
|
+
const headerClass = css({
|
|
25
|
+
display: "flex",
|
|
26
|
+
alignItems: "center",
|
|
27
|
+
width: "100%",
|
|
28
|
+
outline: 0,
|
|
29
|
+
gap: 4,
|
|
30
|
+
transition: "all 0.2s",
|
|
31
|
+
py: 3,
|
|
32
|
+
fontWeight: "semiBold",
|
|
33
|
+
fontSize: "md",
|
|
34
|
+
color: "dark",
|
|
35
|
+
_disabled: {
|
|
36
|
+
opacity: "0.4",
|
|
37
|
+
cursor: "not-allowed"
|
|
38
|
+
},
|
|
39
|
+
cursor: props.isClickable ? "pointer" : "default"
|
|
40
|
+
});
|
|
41
|
+
return _createVNode("button", {
|
|
42
|
+
"data-pixel-component": "MpAccordionHeader",
|
|
43
|
+
"type": "button",
|
|
44
|
+
"id": `accordion-header-${id}`,
|
|
45
|
+
"aria-expanded": isExpanded.value,
|
|
46
|
+
"aria-controls": `accordion-panel-${id}`,
|
|
47
|
+
"class": headerClass,
|
|
48
|
+
"onClick": onToggle
|
|
49
|
+
}, [slots.default()]);
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
export {
|
|
55
|
+
MpAccordionHeader
|
|
56
|
+
};
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
// src/modules/accordion.props.ts
|
|
2
|
+
var accordionProps = {
|
|
3
|
+
defaultIndexOpen: {
|
|
4
|
+
type: Number
|
|
5
|
+
},
|
|
6
|
+
isAllowMultiple: {
|
|
7
|
+
type: Boolean,
|
|
8
|
+
default: false
|
|
9
|
+
},
|
|
10
|
+
isAllowToggle: {
|
|
11
|
+
type: Boolean,
|
|
12
|
+
default: false
|
|
13
|
+
},
|
|
14
|
+
isControlled: {
|
|
15
|
+
type: Boolean,
|
|
16
|
+
default: false
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
var accordionItemProps = {
|
|
20
|
+
id: {
|
|
21
|
+
type: String
|
|
22
|
+
},
|
|
23
|
+
index: {
|
|
24
|
+
type: Number
|
|
25
|
+
},
|
|
26
|
+
isOpen: {
|
|
27
|
+
type: Boolean,
|
|
28
|
+
default: false
|
|
29
|
+
},
|
|
30
|
+
isDefaultIsOpen: {
|
|
31
|
+
type: Boolean,
|
|
32
|
+
default: false
|
|
33
|
+
},
|
|
34
|
+
isDisabled: {
|
|
35
|
+
type: Boolean,
|
|
36
|
+
default: false
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
var accordionHeaderProps = {
|
|
40
|
+
isClickable: {
|
|
41
|
+
type: Boolean,
|
|
42
|
+
default: true
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
var accordionIconProps = {
|
|
46
|
+
name: {
|
|
47
|
+
type: String,
|
|
48
|
+
default: "caret-down"
|
|
49
|
+
},
|
|
50
|
+
size: {
|
|
51
|
+
type: String,
|
|
52
|
+
default: "md"
|
|
53
|
+
},
|
|
54
|
+
color: {
|
|
55
|
+
type: String,
|
|
56
|
+
default: "gray.600"
|
|
57
|
+
},
|
|
58
|
+
variant: {
|
|
59
|
+
type: String,
|
|
60
|
+
default: "outline"
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
export {
|
|
65
|
+
accordionProps,
|
|
66
|
+
accordionItemProps,
|
|
67
|
+
accordionHeaderProps,
|
|
68
|
+
accordionIconProps
|
|
69
|
+
};
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useAccordionContext
|
|
3
|
+
} from "./chunk-PFYTMT2T.mjs";
|
|
4
|
+
import {
|
|
5
|
+
__name
|
|
6
|
+
} from "./chunk-QZ7VFGWC.mjs";
|
|
7
|
+
|
|
8
|
+
// src/modules/useAccordion.ts
|
|
9
|
+
import { ref, computed } from "vue";
|
|
10
|
+
import { useId } from "@mekari/pixel3-utils";
|
|
11
|
+
function useAccordion(props, emit) {
|
|
12
|
+
const expandedIndex = ref(props.defaultIndexOpen);
|
|
13
|
+
function onAccordionChange(index, isExpanded) {
|
|
14
|
+
emit("change", index, isExpanded);
|
|
15
|
+
expandedIndex.value = index;
|
|
16
|
+
}
|
|
17
|
+
__name(onAccordionChange, "onAccordionChange");
|
|
18
|
+
return {
|
|
19
|
+
expandedIndex,
|
|
20
|
+
onAccordionChange
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
__name(useAccordion, "useAccordion");
|
|
24
|
+
function useAccordionItem(props) {
|
|
25
|
+
const {
|
|
26
|
+
props: rootProps,
|
|
27
|
+
expandedIndex,
|
|
28
|
+
onAccordionChange
|
|
29
|
+
} = useAccordionContext();
|
|
30
|
+
const {
|
|
31
|
+
isAllowMultiple,
|
|
32
|
+
isControlled
|
|
33
|
+
} = rootProps;
|
|
34
|
+
const id = props.id || useId(4);
|
|
35
|
+
const _isExpanded = ref(props.isDefaultIsOpen);
|
|
36
|
+
const isExpanded = computed(() => {
|
|
37
|
+
if (isControlled.value)
|
|
38
|
+
return props.isOpen;
|
|
39
|
+
if (!isAllowMultiple.value)
|
|
40
|
+
return props.index === expandedIndex.value;
|
|
41
|
+
return _isExpanded.value;
|
|
42
|
+
});
|
|
43
|
+
function onToggle() {
|
|
44
|
+
if (isAllowMultiple.value) {
|
|
45
|
+
_isExpanded.value = !_isExpanded.value;
|
|
46
|
+
}
|
|
47
|
+
onAccordionChange(props.index, _isExpanded.value);
|
|
48
|
+
}
|
|
49
|
+
__name(onToggle, "onToggle");
|
|
50
|
+
return {
|
|
51
|
+
isExpanded,
|
|
52
|
+
onToggle,
|
|
53
|
+
id
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
__name(useAccordionItem, "useAccordionItem");
|
|
57
|
+
|
|
58
|
+
export {
|
|
59
|
+
useAccordion,
|
|
60
|
+
useAccordionItem
|
|
61
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useAccordionItemContext
|
|
3
|
+
} from "./chunk-PFYTMT2T.mjs";
|
|
4
|
+
import {
|
|
5
|
+
accordionIconProps
|
|
6
|
+
} from "./chunk-6FLZM2UD.mjs";
|
|
7
|
+
|
|
8
|
+
// src/icon.tsx
|
|
9
|
+
import { createVNode as _createVNode } from "vue";
|
|
10
|
+
import { defineComponent } from "vue";
|
|
11
|
+
import { MpIcon } from "@mekari/pixel3-icon";
|
|
12
|
+
var MpAccordionIcon = defineComponent({
|
|
13
|
+
name: "MpAccordionIcon",
|
|
14
|
+
props: accordionIconProps,
|
|
15
|
+
setup(props) {
|
|
16
|
+
const {
|
|
17
|
+
isExpanded
|
|
18
|
+
} = useAccordionItemContext();
|
|
19
|
+
return () => {
|
|
20
|
+
return _createVNode(MpIcon, {
|
|
21
|
+
"name": props.name,
|
|
22
|
+
"size": props.size,
|
|
23
|
+
"color": props.color,
|
|
24
|
+
"variant": props.variant,
|
|
25
|
+
"style": {
|
|
26
|
+
transform: isExpanded.value ? "rotate(-180deg)" : "rotate(0)",
|
|
27
|
+
transition: "transform 0.2s",
|
|
28
|
+
transformOrigin: "center"
|
|
29
|
+
}
|
|
30
|
+
}, null);
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
export {
|
|
36
|
+
MpAccordionIcon
|
|
37
|
+
};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useAccordionItem
|
|
3
|
+
} from "./chunk-CJKS7PMG.mjs";
|
|
4
|
+
import {
|
|
5
|
+
AccordionItemProvider
|
|
6
|
+
} from "./chunk-PFYTMT2T.mjs";
|
|
7
|
+
import {
|
|
8
|
+
accordionItemProps
|
|
9
|
+
} from "./chunk-6FLZM2UD.mjs";
|
|
10
|
+
|
|
11
|
+
// src/item.tsx
|
|
12
|
+
import { createVNode as _createVNode } from "vue";
|
|
13
|
+
import { defineComponent } from "vue";
|
|
14
|
+
import { css } from "@mekari/pixel3-styled-system/css";
|
|
15
|
+
var MpAccordionItem = defineComponent({
|
|
16
|
+
name: "MpAccordionItem",
|
|
17
|
+
props: accordionItemProps,
|
|
18
|
+
setup(props, {
|
|
19
|
+
slots
|
|
20
|
+
}) {
|
|
21
|
+
const {
|
|
22
|
+
isExpanded,
|
|
23
|
+
onToggle,
|
|
24
|
+
id
|
|
25
|
+
} = useAccordionItem(props);
|
|
26
|
+
AccordionItemProvider({
|
|
27
|
+
isExpanded,
|
|
28
|
+
onToggle,
|
|
29
|
+
id
|
|
30
|
+
});
|
|
31
|
+
return () => {
|
|
32
|
+
return _createVNode("div", {
|
|
33
|
+
"data-pixel-component": "MpAccordionItem",
|
|
34
|
+
"class": css({
|
|
35
|
+
borderBottomWidth: "1px",
|
|
36
|
+
borderColor: "gray.100",
|
|
37
|
+
_last: {
|
|
38
|
+
borderBottomWidth: "1px",
|
|
39
|
+
borderColor: "gray.100"
|
|
40
|
+
}
|
|
41
|
+
})
|
|
42
|
+
}, [slots.default()]);
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
export {
|
|
48
|
+
MpAccordionItem
|
|
49
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
// src/modules/accordion.context.ts
|
|
2
|
+
import { usePixelCreateContext } from "@mekari/pixel3-utils";
|
|
3
|
+
var [AccordionProvider, useAccordionContext] = usePixelCreateContext("AccordionContext");
|
|
4
|
+
var [AccordionItemProvider, useAccordionItemContext] = usePixelCreateContext("AccordionItemContext");
|
|
5
|
+
|
|
6
|
+
export {
|
|
7
|
+
AccordionProvider,
|
|
8
|
+
useAccordionContext,
|
|
9
|
+
AccordionItemProvider,
|
|
10
|
+
useAccordionItemContext
|
|
11
|
+
};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useAccordion
|
|
3
|
+
} from "./chunk-CJKS7PMG.mjs";
|
|
4
|
+
import {
|
|
5
|
+
AccordionProvider
|
|
6
|
+
} from "./chunk-PFYTMT2T.mjs";
|
|
7
|
+
import {
|
|
8
|
+
accordionProps
|
|
9
|
+
} from "./chunk-6FLZM2UD.mjs";
|
|
10
|
+
|
|
11
|
+
// src/accordion.tsx
|
|
12
|
+
import { createVNode as _createVNode } from "vue";
|
|
13
|
+
import { defineComponent, toRefs, cloneVNode } from "vue";
|
|
14
|
+
var MpAccordion = defineComponent({
|
|
15
|
+
name: "MpAccordion",
|
|
16
|
+
props: accordionProps,
|
|
17
|
+
emits: ["change"],
|
|
18
|
+
setup(props, {
|
|
19
|
+
slots,
|
|
20
|
+
emit
|
|
21
|
+
}) {
|
|
22
|
+
const {
|
|
23
|
+
expandedIndex,
|
|
24
|
+
onAccordionChange
|
|
25
|
+
} = useAccordion(props, emit);
|
|
26
|
+
AccordionProvider({
|
|
27
|
+
props: toRefs(props),
|
|
28
|
+
expandedIndex,
|
|
29
|
+
onAccordionChange
|
|
30
|
+
});
|
|
31
|
+
return () => {
|
|
32
|
+
const children = slots.default ? slots.default() : [];
|
|
33
|
+
const clone = children.map((node, index) => {
|
|
34
|
+
return cloneVNode(node, {
|
|
35
|
+
index
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
return _createVNode("div", {
|
|
39
|
+
"data-pixel-component": "MpAccordion"
|
|
40
|
+
}, [clone]);
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
export {
|
|
46
|
+
MpAccordion
|
|
47
|
+
};
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useAccordionItemContext
|
|
3
|
+
} from "./chunk-PFYTMT2T.mjs";
|
|
4
|
+
|
|
5
|
+
// src/panel.tsx
|
|
6
|
+
import { createVNode as _createVNode } from "vue";
|
|
7
|
+
import { defineComponent } from "vue";
|
|
8
|
+
import { MpCollapse } from "@mekari/pixel3-collapse";
|
|
9
|
+
import { css } from "@mekari/pixel3-styled-system/css";
|
|
10
|
+
var MpAccordionPanel = defineComponent({
|
|
11
|
+
name: "MpAccordionPanel",
|
|
12
|
+
setup(_props, {
|
|
13
|
+
slots
|
|
14
|
+
}) {
|
|
15
|
+
const {
|
|
16
|
+
isExpanded,
|
|
17
|
+
id
|
|
18
|
+
} = useAccordionItemContext();
|
|
19
|
+
return () => {
|
|
20
|
+
return _createVNode(MpCollapse, {
|
|
21
|
+
"isOpen": isExpanded.value
|
|
22
|
+
}, {
|
|
23
|
+
default: () => [_createVNode("div", {
|
|
24
|
+
"data-pixel-component": "MpAccordionPanel",
|
|
25
|
+
"id": `accordin-panel-${id}`,
|
|
26
|
+
"aria-labelledby": `accordion-header-${id}`,
|
|
27
|
+
"class": css({
|
|
28
|
+
py: 3
|
|
29
|
+
})
|
|
30
|
+
}, [slots.default()])]
|
|
31
|
+
});
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
export {
|
|
37
|
+
MpAccordionPanel
|
|
38
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import * as vue_jsx_runtime from 'vue/jsx-runtime';
|
|
2
|
+
import * as vue from 'vue';
|
|
3
|
+
|
|
4
|
+
declare const MpAccordionHeader: vue.DefineComponent<{
|
|
5
|
+
isClickable: {
|
|
6
|
+
type: vue.PropType<boolean>;
|
|
7
|
+
default: boolean;
|
|
8
|
+
};
|
|
9
|
+
}, () => vue_jsx_runtime.JSX.Element, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
|
|
10
|
+
isClickable: {
|
|
11
|
+
type: vue.PropType<boolean>;
|
|
12
|
+
default: boolean;
|
|
13
|
+
};
|
|
14
|
+
}>>, {
|
|
15
|
+
isClickable: boolean;
|
|
16
|
+
}, {}>;
|
|
17
|
+
|
|
18
|
+
export { MpAccordionHeader };
|
package/dist/header.d.ts
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import * as vue_jsx_runtime from 'vue/jsx-runtime';
|
|
2
|
+
import * as vue from 'vue';
|
|
3
|
+
|
|
4
|
+
declare const MpAccordionHeader: vue.DefineComponent<{
|
|
5
|
+
isClickable: {
|
|
6
|
+
type: vue.PropType<boolean>;
|
|
7
|
+
default: boolean;
|
|
8
|
+
};
|
|
9
|
+
}, () => vue_jsx_runtime.JSX.Element, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
|
|
10
|
+
isClickable: {
|
|
11
|
+
type: vue.PropType<boolean>;
|
|
12
|
+
default: boolean;
|
|
13
|
+
};
|
|
14
|
+
}>>, {
|
|
15
|
+
isClickable: boolean;
|
|
16
|
+
}, {}>;
|
|
17
|
+
|
|
18
|
+
export { MpAccordionHeader };
|