UNPKG

element-plus

Version:

A Component Library for Vue 3

107 lines (102 loc) 2.85 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var vue = require('vue'); var anchorLink = require('./anchor-link.js'); var constants = require('./constants.js'); var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js'); const _hoisted_1 = ["href"]; const _sfc_main = vue.defineComponent({ ...{ name: "ElAnchorLink" }, __name: "anchor-link", props: anchorLink.anchorLinkProps, setup(__props) { const props = __props; const linkRef = vue.ref(null); const { ns, direction, currentAnchor, addLink, removeLink, handleClick: contextHandleClick } = vue.inject(constants.anchorKey); const cls = vue.computed(() => [ ns.e("link"), ns.is("active", currentAnchor.value === props.href) ]); const handleClick = (e) => { contextHandleClick(e, props.href); }; vue.watch( () => props.href, (val, oldVal) => { vue.nextTick(() => { if (oldVal) removeLink(oldVal); if (val) { addLink({ href: val, el: linkRef.value }); } }); } ); vue.onMounted(() => { const { href } = props; if (href) { addLink({ href, el: linkRef.value }); } }); vue.onBeforeUnmount(() => { const { href } = props; if (href) { removeLink(href); } }); return (_ctx, _cache) => { return vue.openBlock(), vue.createElementBlock( "div", { class: vue.normalizeClass(vue.unref(ns).e("item")) }, [ vue.createElementVNode("a", { ref_key: "linkRef", ref: linkRef, class: vue.normalizeClass(cls.value), href: _ctx.href, onClick: handleClick }, [ vue.renderSlot(_ctx.$slots, "default", {}, () => [ vue.createTextVNode( vue.toDisplayString(_ctx.title), 1 ) ]) ], 10, _hoisted_1), _ctx.$slots["sub-link"] && vue.unref(direction) === "vertical" ? (vue.openBlock(), vue.createElementBlock( "div", { key: 0, class: vue.normalizeClass(vue.unref(ns).e("list")) }, [ vue.renderSlot(_ctx.$slots, "sub-link") ], 2 )) : vue.createCommentVNode("v-if", true) ], 2 ); }; } }); var AnchorLink = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/anchor/src/anchor-link.vue"]]); exports["default"] = AnchorLink; //# sourceMappingURL=anchor-link2.js.map