UNPKG

2.87 kBJavaScriptView Raw
1var __defProp = Object.defineProperty;
2var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3var __getOwnPropNames = Object.getOwnPropertyNames;
4var __hasOwnProp = Object.prototype.hasOwnProperty;
5var __export = (target, all) => {
6 for (var name2 in all)
7 __defProp(target, name2, { get: all[name2], enumerable: true });
8};
9var __copyProps = (to, from, except, desc) => {
10 if (from && typeof from === "object" || typeof from === "function") {
11 for (let key of __getOwnPropNames(from))
12 if (!__hasOwnProp.call(to, key) && key !== except)
13 __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14 }
15 return to;
16};
17var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18var stdin_exports = {};
19__export(stdin_exports, {
20 default: () => stdin_default,
21 sidebarItemProps: () => sidebarItemProps
22});
23module.exports = __toCommonJS(stdin_exports);
24var import_vue = require("vue");
25var import_utils = require("../utils");
26var import_Sidebar = require("../sidebar/Sidebar");
27var import_use = require("@vant/use");
28var import_use_route = require("../composables/use-route");
29var import_badge = require("../badge");
30const [name, bem] = (0, import_utils.createNamespace)("sidebar-item");
31const sidebarItemProps = (0, import_utils.extend)({}, import_use_route.routeProps, {
32 dot: Boolean,
33 title: String,
34 badge: import_utils.numericProp,
35 disabled: Boolean,
36 badgeProps: Object
37});
38var stdin_default = (0, import_vue.defineComponent)({
39 name,
40 props: sidebarItemProps,
41 emits: ["click"],
42 setup(props, {
43 emit,
44 slots
45 }) {
46 const route = (0, import_use_route.useRoute)();
47 const {
48 parent,
49 index
50 } = (0, import_use.useParent)(import_Sidebar.SIDEBAR_KEY);
51 if (!parent) {
52 if (process.env.NODE_ENV !== "production") {
53 console.error("[Vant] <SidebarItem> must be a child component of <Sidebar>.");
54 }
55 return;
56 }
57 const onClick = () => {
58 if (props.disabled) {
59 return;
60 }
61 emit("click", index.value);
62 parent.setActive(index.value);
63 route();
64 };
65 return () => {
66 const {
67 dot,
68 badge,
69 title,
70 disabled
71 } = props;
72 const selected = index.value === parent.getActive();
73 return (0, import_vue.createVNode)("div", {
74 "role": "tab",
75 "class": bem({
76 select: selected,
77 disabled
78 }),
79 "tabindex": disabled ? void 0 : 0,
80 "aria-selected": selected,
81 "onClick": onClick
82 }, [(0, import_vue.createVNode)(import_badge.Badge, (0, import_vue.mergeProps)({
83 "dot": dot,
84 "class": bem("text"),
85 "content": badge
86 }, props.badgeProps), {
87 default: () => [slots.title ? slots.title() : title]
88 })]);
89 };
90 }
91});