UNPKG

@zhsz/cool-design-dv

Version:

140 lines (139 loc) 5.46 kB
import { defineComponent, getCurrentInstance, useAttrs, inject, computed, onMounted, onBeforeUnmount, openBlock, createBlock, unref, mergeProps, withCtx, createElementBlock, normalizeStyle, createElementVNode, createVNode, renderSlot } from "vue"; import "./style.css"; import Box from "../dv-box/index.mjs"; import BoxContent from "../dv-content/index.mjs"; import { dvPageSymbols } from "../../symbols/index.mjs"; import { addResizeListener, removeResizeListener } from "../../utils/resize-event.mjs"; import { useBorder } from "../../hooks/useBorder.mjs"; import { baseConfig } from "../../hooks/useConfig.mjs"; const _hoisted_1 = ["width", "height"]; const _hoisted_2 = ["stroke"]; const _hoisted_3 = ["stroke", "points"]; const _hoisted_4 = ["stroke", "points"]; const _hoisted_5 = ["stroke", "points"]; const _hoisted_6 = ["stroke"]; const _hoisted_7 = ["stroke", "points"]; const _hoisted_8 = ["stroke", "points"]; const _hoisted_9 = ["stroke", "points"]; const __default__ = defineComponent({ name: "DvBorder6" }); const _sfc_main = /* @__PURE__ */ defineComponent({ ...__default__, props: { fill: { type: String, default() { return "transparent"; } }, reverse: Boolean, opacity: { type: Number, default: 1 } }, emits: ["resize"], setup(__props, { emit: __emit }) { var _a, _b, _c; const instance = (_a = getCurrentInstance()) == null ? void 0 : _a.proxy; const emits = __emit; const $attrs = useAttrs(); const props = __props; const page = inject(dvPageSymbols, null); const fill = computed(() => { var _a2, _b2; return props.fill || ((_b2 = (_a2 = page == null ? void 0 : page.settings) == null ? void 0 : _a2.value) == null ? void 0 : _b2.fill); }); const { resize, classes, styles, width, height, dark, light } = useBorder( emits, ((_c = (_b = page == null ? void 0 : page.settings) == null ? void 0 : _b.value) == null ? void 0 : _c.color) ?? baseConfig.color, props, page ); const svgStyle = computed(() => { return { ...styles.value, "box-shadow": "inset 0 0 40px rgba(255,255,255,0.05)", background: fill.value }; }); onMounted(() => { resize(instance == null ? void 0 : instance.$el); addResizeListener(instance == null ? void 0 : instance.$el, () => resize(instance == null ? void 0 : instance.$el)); }); onBeforeUnmount(() => { removeResizeListener(instance == null ? void 0 : instance.$el, () => resize(instance == null ? void 0 : instance.$el)); }); return (_ctx, _cache) => { return openBlock(), createBlock(unref(Box), mergeProps({ class: ["my-dv-border-6", unref(classes)], "default-width": "400px", "default-height": "300px", padding: "0" }, { ...unref($attrs), ...props }), { default: withCtx(() => [ (openBlock(), createElementBlock("svg", { class: "my-dv-border__svg", width: unref(width), height: unref(height), style: normalizeStyle(svgStyle.value) }, [ createElementVNode("polyline", { class: "line-width-2", stroke: unref(dark), points: `0, 25 0, 0 25, 0` }, null, 8, _hoisted_2), createElementVNode("polyline", { class: "line-width-2", stroke: unref(dark), points: `${unref(width) - 25}, 0 ${unref(width)}, 0 ${unref(width)}, 25` }, null, 8, _hoisted_3), createElementVNode("polyline", { class: "line-width-2", stroke: unref(dark), points: `${unref(width) - 25}, ${unref(height)} ${unref(width)}, ${unref(height)} ${unref(width)}, ${unref(height) - 25}` }, null, 8, _hoisted_4), createElementVNode("polyline", { class: "line-width-2", stroke: unref(dark), points: `0, ${unref(height) - 25} 0, ${unref(height)} 25, ${unref(height)}` }, null, 8, _hoisted_5), createElementVNode("polyline", { class: "line-width-5", stroke: unref(light), points: `0, 10 0, 0 10, 0` }, null, 8, _hoisted_6), createElementVNode("polyline", { class: "line-width-5", stroke: unref(light), points: `${unref(width) - 10}, 0 ${unref(width)}, 0 ${unref(width)}, 10` }, null, 8, _hoisted_7), createElementVNode("polyline", { class: "line-width-5", stroke: unref(light), points: `${unref(width) - 10}, ${unref(height)} ${unref(width)}, ${unref(height)} ${unref(width)}, ${unref(height) - 10}` }, null, 8, _hoisted_8), createElementVNode("polyline", { class: "line-width-5", stroke: unref(light), points: `0, ${unref(height) - 10} 0, ${unref(height)} 10, ${unref(height)}` }, null, 8, _hoisted_9) ], 12, _hoisted_1)), createVNode(unref(BoxContent), { padding: unref($attrs).padding }, { default: withCtx(() => [ renderSlot(_ctx.$slots, "default") ]), _: 3 }, 8, ["padding"]) ]), _: 3 }, 16, ["class"]); }; } }); export { _sfc_main as default };