UNPKG

element-plus

Version:

A Component Library for Vue 3

173 lines (168 loc) 6.25 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var vue = require('vue'); var iconsVue = require('@element-plus/icons-vue'); var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js'); var index = require('../../../hooks/use-namespace/index.js'); const _sfc_main = vue.defineComponent({ ...{ name: "ElSplitterBar" }, __name: "split-bar", props: { index: { type: Number, required: true }, layout: { type: String, values: ["horizontal", "vertical"], default: "horizontal" }, resizable: { type: Boolean, default: true }, lazy: Boolean, startCollapsible: Boolean, endCollapsible: Boolean }, emits: ["moveStart", "moving", "moveEnd", "collapse"], setup(__props, { emit: __emit }) { const ns = index.useNamespace("splitter-bar"); const props = __props; const emit = __emit; const isHorizontal = vue.computed(() => props.layout === "horizontal"); const barWrapStyles = vue.computed(() => { if (isHorizontal.value) { return { width: 0 }; } return { height: 0 }; }); const draggerStyles = vue.computed(() => { return { width: isHorizontal.value ? "16px" : "100%", height: isHorizontal.value ? "100%" : "16px", cursor: !props.resizable ? "auto" : isHorizontal.value ? "ew-resize" : "ns-resize", touchAction: "none" }; }); const draggerPseudoClass = vue.computed(() => { const prefix = ns.e("dragger"); return { [`${prefix}-horizontal`]: isHorizontal.value, [`${prefix}-vertical`]: !isHorizontal.value, [`${prefix}-active`]: !!startPos.value }; }); const startPos = vue.ref(null); const onMousedown = (e) => { if (!props.resizable) return; startPos.value = [e.pageX, e.pageY]; emit("moveStart", props.index); window.addEventListener("mouseup", onMouseUp); window.addEventListener("mousemove", onMouseMove); }; const onTouchStart = (e) => { if (props.resizable && e.touches.length === 1) { e.preventDefault(); const touch = e.touches[0]; startPos.value = [touch.pageX, touch.pageY]; emit("moveStart", props.index); window.addEventListener("touchend", onTouchEnd); window.addEventListener("touchmove", onTouchMove); } }; const onMouseMove = (e) => { const { pageX, pageY } = e; const offsetX = pageX - startPos.value[0]; const offsetY = pageY - startPos.value[1]; const offset = isHorizontal.value ? offsetX : offsetY; emit("moving", props.index, offset); }; const onTouchMove = (e) => { if (e.touches.length === 1) { e.preventDefault(); const touch = e.touches[0]; const offsetX = touch.pageX - startPos.value[0]; const offsetY = touch.pageY - startPos.value[1]; const offset = isHorizontal.value ? offsetX : offsetY; emit("moving", props.index, offset); } }; const onMouseUp = () => { startPos.value = null; window.removeEventListener("mouseup", onMouseUp); window.removeEventListener("mousemove", onMouseMove); emit("moveEnd", props.index); }; const onTouchEnd = () => { startPos.value = null; window.removeEventListener("touchend", onTouchEnd); window.removeEventListener("touchmove", onTouchMove); emit("moveEnd", props.index); }; const StartIcon = vue.computed(() => isHorizontal.value ? iconsVue.ArrowLeft : iconsVue.ArrowUp); const EndIcon = vue.computed(() => isHorizontal.value ? iconsVue.ArrowRight : iconsVue.ArrowDown); return (_ctx, _cache) => { return vue.openBlock(), vue.createElementBlock( "div", { class: vue.normalizeClass([vue.unref(ns).b()]), style: vue.normalizeStyle(barWrapStyles.value) }, [ __props.startCollapsible ? (vue.openBlock(), vue.createElementBlock( "div", { key: 0, class: vue.normalizeClass([vue.unref(ns).e("collapse-icon"), vue.unref(ns).e(`${__props.layout}-collapse-icon-start`)]), onClick: _cache[0] || (_cache[0] = ($event) => emit("collapse", __props.index, "start")) }, [ vue.renderSlot(_ctx.$slots, "start-collapsible", {}, () => [ (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(StartIcon.value), { style: { "width": "12px", "height": "12px" } })) ]) ], 2 )) : vue.createCommentVNode("v-if", true), vue.createElementVNode( "div", { class: vue.normalizeClass([ vue.unref(ns).e("dragger"), draggerPseudoClass.value, vue.unref(ns).is("disabled", !__props.resizable), vue.unref(ns).is("lazy", __props.resizable && __props.lazy) ]), style: vue.normalizeStyle(draggerStyles.value), onMousedown, onTouchstart: onTouchStart }, null, 38 ), __props.endCollapsible ? (vue.openBlock(), vue.createElementBlock( "div", { key: 1, class: vue.normalizeClass([vue.unref(ns).e("collapse-icon"), vue.unref(ns).e(`${__props.layout}-collapse-icon-end`)]), onClick: _cache[1] || (_cache[1] = ($event) => emit("collapse", __props.index, "end")) }, [ vue.renderSlot(_ctx.$slots, "end-collapsible", {}, () => [ (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(EndIcon.value), { style: { "width": "12px", "height": "12px" } })) ]) ], 2 )) : vue.createCommentVNode("v-if", true) ], 6 ); }; } }); var SplitBar = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/splitter/src/split-bar.vue"]]); exports["default"] = SplitBar; //# sourceMappingURL=split-bar.js.map