template-designer 0.1.2 → 0.1.4
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/README.md
CHANGED
|
@@ -67,7 +67,7 @@ app.use(TemplateDesigner)
|
|
|
67
67
|
```vue
|
|
68
68
|
<template>
|
|
69
69
|
<div>
|
|
70
|
-
<TemplateDesigner :templateData="templateData" />
|
|
70
|
+
<TemplateDesigner :templateData="templateData" :options="options" :show-graph-config="showGraphConfig" :config="config"/>
|
|
71
71
|
</div>
|
|
72
72
|
</template>
|
|
73
73
|
|
|
@@ -77,6 +77,25 @@ import TemplateDesigner from 'template-designer-lib'
|
|
|
77
77
|
const templateData = {
|
|
78
78
|
// 你的模板数据
|
|
79
79
|
}
|
|
80
|
+
|
|
81
|
+
// options传入的结构须为{[optionsKey(config下配置文件中对应optionsKey)]: [{label: xx: value: xx}, ...],因为考虑实际使用场景,就没有加自定义key支持
|
|
82
|
+
const options = {
|
|
83
|
+
// 属性选项值
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// 是否显示标签图像绘制
|
|
87
|
+
const showGraphConfig = true
|
|
88
|
+
|
|
89
|
+
// 组件配置
|
|
90
|
+
const config = {
|
|
91
|
+
text: { hidden: true }, // 隐藏文本组件
|
|
92
|
+
barcode: { hidden: true }, // 隐藏一维码组件
|
|
93
|
+
qrcode: { hidden: true }, // 隐藏二维码组件
|
|
94
|
+
image: { hidden: true, request: () => {图片上传} }, // 隐藏图片组件
|
|
95
|
+
rectangle: { hidden: true }, // 隐藏矩形框组件
|
|
96
|
+
horline: { hidden: true } // 隐藏线段组件
|
|
97
|
+
|
|
98
|
+
}
|
|
80
99
|
</script>
|
|
81
100
|
```
|
|
82
101
|
|
|
@@ -337,6 +337,16 @@ const e = {
|
|
|
337
337
|
{ label: "填充", value: 3 }
|
|
338
338
|
],
|
|
339
339
|
default: 1
|
|
340
|
+
},
|
|
341
|
+
{
|
|
342
|
+
prop: "IsPrint",
|
|
343
|
+
label: "是否打印",
|
|
344
|
+
type: "select",
|
|
345
|
+
options: [
|
|
346
|
+
{ label: "是", value: !0 },
|
|
347
|
+
{ label: "否", value: !1 }
|
|
348
|
+
],
|
|
349
|
+
default: !0
|
|
340
350
|
}
|
|
341
351
|
]
|
|
342
352
|
},
|
|
@@ -56,6 +56,38 @@ const e = {
|
|
|
56
56
|
{ prop: "margin", label: "边距", type: "number", min: 0, max: 20 },
|
|
57
57
|
{ prop: "errorCorrectionLevel", label: "纠错级别", type: "select", optionsKey: "QRCODE_ERROR_LEVELS" }
|
|
58
58
|
]
|
|
59
|
+
},
|
|
60
|
+
image: {
|
|
61
|
+
x: 0,
|
|
62
|
+
y: 0,
|
|
63
|
+
width: 12,
|
|
64
|
+
height: 12,
|
|
65
|
+
rotation: 0,
|
|
66
|
+
lockAspectRatio: !1,
|
|
67
|
+
propertyPanel: [
|
|
68
|
+
{ prop: "ImageSrc", label: "图片地址", type: "file", accept: "image/*", default: "" },
|
|
69
|
+
{
|
|
70
|
+
prop: "ScaleMode",
|
|
71
|
+
label: "图片缩放",
|
|
72
|
+
type: "select",
|
|
73
|
+
options: [
|
|
74
|
+
{ label: "原始尺寸", value: 1 },
|
|
75
|
+
{ label: "居中裁剪", value: 2 },
|
|
76
|
+
{ label: "填充", value: 3 }
|
|
77
|
+
],
|
|
78
|
+
default: 1
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
prop: "IsPrint",
|
|
82
|
+
label: "是否打印",
|
|
83
|
+
type: "select",
|
|
84
|
+
options: [
|
|
85
|
+
{ label: "是", value: !0 },
|
|
86
|
+
{ label: "否", value: !1 }
|
|
87
|
+
],
|
|
88
|
+
default: !0
|
|
89
|
+
}
|
|
90
|
+
]
|
|
59
91
|
}
|
|
60
92
|
};
|
|
61
93
|
export {
|
package/dist/style.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.td-text-component{width:100%;height:100%;position:relative;display:flex;align-items:center;overflow:hidden;box-sizing:border-box}.td-text-content{width:100%;min-width:0;box-sizing:border-box}.label[data-v-3290b48a]{display:flex;align-items:center;justify-content:flex-start}.property-item[data-v-3290b48a]{display:flex;flex-direction:column;gap:4px}.property-item label[data-v-3290b48a]{font-size:14px;color:#666}.property-item input[data-v-3290b48a],.property-item select[data-v-3290b48a]{padding:4px 8px;border:1px solid #ddd;border-radius:4px}.property-item input[type=color][data-v-3290b48a]{height:32px;padding:2px}.property-item input[type=checkbox][data-v-3290b48a]{width:16px;height:16px}.file-input-container[data-v-3290b48a]{position:relative;display:flex;align-items:center;gap:8px}.file-input-container input[data-v-3290b48a]{height:100%!important}.file-url-input[data-v-3290b48a]{flex:1;padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:12px}.file-input[data-v-3290b48a]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.file-select-btn[data-v-3290b48a]{padding:4px 12px;border:1px solid #ddd;border-radius:4px;background:var(--el-color-primary);color:#fff;cursor:pointer;font-size:12px;white-space:nowrap}.file-select-btn[data-v-3290b48a]:hover{background:var(--el-color-primary-dark-2);border-color:var(--el-color-primary-dark-2)}.file-info[data-v-3290b48a]{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background-color:#f5f5f5;border-radius:4px;margin-top:4px}.file-name[data-v-3290b48a]{font-size:12px;color:#666;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clear-btn[data-v-3290b48a]{background:none;border:none;color:#ff4d4f;cursor:pointer;font-size:12px;padding:2px 6px;border-radius:2px}.clear-btn[data-v-3290b48a]:hover{background-color:#fff2f0}.property-panel[data-v-aed193a8]{padding:16px;background:#fff;border-left:1px solid #e4e7ed;overflow-y:auto;height:100%}.property-group[data-v-aed193a8]{margin-bottom:16px}.property-group-title[data-v-aed193a8]{font-size:14px;font-weight:500;color:#303133;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid #ebeef5}.property-item[data-v-aed193a8]{margin-bottom:12px}.text-property-panel .property-item[data-v-aed193a8]:last-child,.barcode-property-panel .property-item[data-v-aed193a8]:last-child,.qrcode-property-panel .property-item[data-v-aed193a8]:last-child,.image-property-panel .property-item[data-v-aed193a8]:last-child,.rectangle-property-panel .property-item[data-v-aed193a8]:last-child,.horline-property-panel .property-item[data-v-aed193a8]:last-child,.verline-property-panel .property-item[data-v-aed193a8]:last-child{margin-bottom:0}.barcode-component{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;box-sizing:border-box}.qrcode-component[data-v-6e726fcb]{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;box-sizing:border-box}.qrcode-canvas-fixed[data-v-6e726fcb]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:0;margin:0}.qrcode-image[data-v-6e726fcb]{display:block;width:100%!important;height:100%!important;padding:0;margin:0;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:-o-crisp-edges;image-rendering:-webkit-crisp-edges;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0);-webkit-transform:translateZ(0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;filter:none;-webkit-filter:none;object-fit:cover;object-position:center}.component-selection-overlay[data-v-6e726fcb]{position:absolute;border:2px dashed #1890ff;pointer-events:none;box-sizing:border-box;z-index:1000}.qrcode-property-panel[data-v-cce393d5]{display:flex;flex-direction:column;gap:12px}.property-item[data-v-cce393d5]{display:flex;flex-direction:column;gap:4px}.property-item label[data-v-cce393d5]{font-size:14px;color:#666}.property-item input[data-v-cce393d5],.property-item select[data-v-cce393d5]{padding:4px 8px;border:1px solid #ddd;border-radius:4px}.property-item input[type=color][data-v-cce393d5]{height:32px;padding:2px}.image-component[data-v-520d1f6a]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;background-color:#fafafa}.image-placeholder[data-v-520d1f6a]{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#999;font-size:12px;gap:8px}.image-content[data-v-520d1f6a]{display:block;max-width:100%;max-height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:-o-crisp-edges;image-rendering:-webkit-crisp-edges;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0);-webkit-transform:translateZ(0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.component-selection-overlay[data-v-520d1f6a]{position:absolute;border:2px dashed #1890ff;pointer-events:none;box-sizing:border-box;z-index:1000}.image-property-panel[data-v-462c8b63]{display:flex;flex-direction:column;gap:12px}.property-item[data-v-462c8b63]{display:flex;flex-direction:column;gap:4px}.property-item label[data-v-462c8b63]{font-size:14px;color:#666}.property-item input[data-v-462c8b63],.property-item select[data-v-462c8b63]{padding:4px 8px;border:1px solid #ddd;border-radius:4px}.property-item input[type=color][data-v-462c8b63]{height:32px;padding:2px}.rectangle-component{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;box-sizing:border-box}.rectangle-content{width:100%;height:100%;box-sizing:border-box}.component-selection-overlay{position:absolute;border:2px dashed #1890ff;pointer-events:none;box-sizing:border-box;z-index:1000}.rectangle-property-panel[data-v-e06ed44e]{display:flex;flex-direction:column;gap:12px}.horline-component{position:relative;display:flex;align-items:center;justify-content:center;overflow:visible;box-sizing:border-box}.line-selection-outline{position:absolute;left:0;top:0;border:2px dashed #1890ff;pointer-events:none;box-sizing:border-box;z-index:1000}.component-list[data-v-890c563f]{background:#fff;display:flex;flex-direction:column;gap:20px}.component-group[data-v-890c563f]{display:flex;flex-direction:column;gap:8px}.group-title[data-v-890c563f]{font-size:14px;font-weight:600;color:#333;padding:8px 12px;border-left:4px solid var(--el-color-primary);background:linear-gradient(135deg,var(--el-color-primary-light-9) 0%,var(--el-color-primary-light-8) 100%);border-radius:0 6px 6px 0;margin-bottom:4px;box-shadow:0 1px 3px #0000001a}.group-content[data-v-890c563f]{display:grid;grid-template-columns:1fr 1fr;grid-row-gap:8px;grid-column-gap:8px}.component-item[data-v-890c563f]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px 0;border:1px solid #ddd;border-radius:4px;cursor:grab;font-size:13px;color:#555;transition:all .2s ease;width:100%;height:70px;background:#fff;box-shadow:0 1px 3px #0000001a}.component-item[data-v-890c563f]:hover{background-color:var(--el-color-primary-light-9);border-color:var(--el-color-primary);color:var(--el-color-primary);box-shadow:0 2px 8px #00000014}.component-item i[data-v-890c563f]{font-size:24px;margin-bottom:8px;color:var(--el-color-primary)}.component-item span[data-v-890c563f]{font-size:12px;text-align:center;color:#333}.component-item:hover i[data-v-890c563f],.component-item:hover span[data-v-890c563f]{color:var(--el-color-primary)!important}.ruler[data-v-3635eba4]{position:absolute;z-index:1}.ruler.horizontal[data-v-3635eba4]{left:20px;top:0;width:calc(100% - 40px);height:20px;border-bottom:none}.ruler.vertical[data-v-3635eba4]{top:20px;left:0;width:20px;height:calc(100% - 40px);border-right:none}.ruler-unit[data-v-3635eba4]{position:absolute}.ruler.horizontal .ruler-unit[data-v-3635eba4]{height:100%}.ruler.vertical .ruler-unit[data-v-3635eba4]{width:100%}.ruler-mark[data-v-3635eba4]{position:absolute;background:#999}.ruler.horizontal .ruler-mark[data-v-3635eba4]{bottom:0}.ruler.vertical .ruler-mark[data-v-3635eba4]{right:0}.ruler-text[data-v-3635eba4]{position:absolute;font-size:8px;color:#666;white-space:nowrap}.ruler.horizontal .ruler-text[data-v-3635eba4]{bottom:8px;transform:translate(-50%)}.ruler.vertical .ruler-text[data-v-3635eba4]{right:8px;transform:translateY(-50%) rotate(-90deg)}.add-btn[data-v-a4b90b63]{margin:10px 0}.tg-title[data-v-a4b90b63]{display:flex;align-items:center}.tg-title p[data-v-a4b90b63]{font-size:18px;font-weight:700}.tge-main[data-v-a4b90b63]{max-height:82vh;padding:0}.tge-text[data-v-a4b90b63]{font-size:14px;line-height:26px}.tge-content[data-v-a4b90b63]{display:flex;width:100%}.tge-block[data-v-a4b90b63]{display:flex;flex-direction:column;flex:1}.tge-title[data-v-a4b90b63]{padding:6px 0;font-size:14px;color:var(--el-color-primary)}.tge-img[data-v-a4b90b63]{width:100%;height:auto}.table-container[data-v-a4b90b63]{width:100%;border:1px dashed #ddd;border-radius:4px}.empty-placeholder[data-v-a4b90b63]{display:flex;align-items:center;justify-content:center;color:#999;padding:20px;border-radius:4px;min-height:80px}.graph-table[data-v-a4b90b63]{margin-top:10px}.tge-divider[data-v-a4b90b63]{width:1px;background:var(--el-border-color);margin:0 10px}.graph-table .el-table__header,.graph-table .el-table__body{width:100%!important}.graph-table .el-table__body{margin-bottom:10px!important}.graph-table .el-form-item__error{position:static!important;top:0!important}.graph-table .el-input-number{width:auto}.graph-table .el-input-number.is-without-controls .el-input__wrapper{padding-left:4px;padding-right:4px}button[data-v-82147119]{display:flex;align-items:center;justify-content:center}.label-designer[data-v-82147119]{display:flex;height:100%}.toolbar[data-v-82147119]{width:200px;background:#fff;border-right:1px solid #e0e0e0;padding:16px;display:flex;flex-direction:column;gap:16px}.zoom-controls span[data-v-82147119]{width:44px;text-align:center}.zoom-controls[data-v-82147119]{display:flex;align-items:center;gap:8px;background:#f5f5f5;border-radius:4px;padding:4px 8px}.zoom-controls button[data-v-82147119]{width:24px;height:24px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer}.zoom-controls button[data-v-82147119]:disabled{opacity:.5;cursor:not-allowed}.center-container[data-v-82147119]{display:flex;flex-direction:column;flex:1;overflow:hidden;height:100%}.center-toolbar[data-v-82147119]{display:flex;align-items:center;justify-content:flex-end;padding:16px 16px 0;background:rgba(0,0,0,.05)}.canvas-container[data-v-82147119]{width:100%;flex:1;padding:0 16px 16px;overflow:auto;background:rgba(0,0,0,.05);position:relative;display:flex;flex-direction:column}.canvas-wrapper[data-v-82147119]{position:relative;transform-origin:0 0;overflow:visible;width:fit-content;height:fit-content;margin-top:20px;transition:all .2s ease;transform:translateZ(0);will-change:transform}.ruler-horizontal[data-v-82147119]{position:absolute;left:0;top:0;right:0;height:24px;z-index:10;pointer-events:none}.ruler-vertical[data-v-82147119]{position:absolute;left:0;top:0;bottom:0;width:24px;z-index:10;pointer-events:none}.canvas[data-v-82147119]{position:relative;overflow:hidden;z-index:1;position:absolute;left:21px;top:21px}.property-panel[data-v-82147119]{width:260px;background:#fff;border-left:1px solid #ddd;padding:0 16px 16px;display:flex;flex-direction:column;gap:16px;position:relative;z-index:100;overflow-y:auto}.property-panel-title[data-v-82147119]{position:sticky;top:0;left:0;right:0;background:#fff;z-index:100;display:flex;align-items:center;justify-content:flex-start;margin:10px 0 0}.position-controls[data-v-82147119]{display:flex;flex-direction:column;gap:12px;padding:12px;background:#f5f5f5;border-radius:4px}.control-group[data-v-82147119]{display:flex;align-items:center;justify-content:space-between;gap:4px}.control-group label[data-v-82147119]{width:80px;font-size:14px;color:#666;text-align:end}.number-input[data-v-82147119]{display:flex;align-items:center;gap:4px}.number-input input[data-v-82147119]{width:90px;padding:4px;border:1px solid #ddd;border-radius:4px;text-align:center}.number-input button[data-v-82147119]{width:24px;height:24px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer}.canvas-item[data-v-82147119]{position:absolute;cursor:move;-webkit-user-select:none;user-select:none;z-index:10;transform:translateZ(0);will-change:transform;left:0;top:0}.resize-handle[data-v-82147119]{position:absolute;width:6px;height:6px;background:#1890ff;border:1px solid #fff;box-shadow:0 0 3px #0000004d;cursor:pointer;z-index:1001;transition:all .2s ease;border-radius:1px;display:block!important;visibility:visible!important;opacity:1!important;transform:translateZ(0);will-change:transform;font-size:16px!important;line-height:1!important}.resize-handle[data-v-82147119]:hover{background:#40a9ff;box-shadow:0 0 4px #0006}.resize-handle.top-left[data-v-82147119]{top:-4px;left:-4px;background:#52c41a}.resize-handle.top-left[data-v-82147119]:hover{background:#73d13d}.resize-handle.top-left[data-v-82147119]:active{background:#389e0d}.resize-handle.top[data-v-82147119]{top:-4px;left:50%;transform:translate(-50%)}.resize-handle.top[data-v-82147119]:hover,.resize-handle.top[data-v-82147119]:active{transform:translate(-50%)}.resize-handle.top-right[data-v-82147119]{top:-4px;right:-4px;background:#52c41a}.resize-handle.top-right[data-v-82147119]:hover{background:#73d13d}.resize-handle.top-right[data-v-82147119]:active{background:#389e0d}.resize-handle.right[data-v-82147119]{top:50%;right:-4px;transform:translateY(-50%)}.resize-handle.right[data-v-82147119]:hover,.resize-handle.right[data-v-82147119]:active{transform:translateY(-50%)}.resize-handle.bottom-right[data-v-82147119]{bottom:-4px;right:-4px;background:#52c41a;z-index:1001}.resize-handle.bottom-right[data-v-82147119]:hover{background:#73d13d}.resize-handle.bottom-right[data-v-82147119]:active{background:#389e0d}.resize-handle.bottom[data-v-82147119]{bottom:-4px;left:50%;transform:translate(-50%)}.resize-handle.bottom[data-v-82147119]:hover,.resize-handle.bottom[data-v-82147119]:active{transform:translate(-50%)}.resize-handle.bottom-left[data-v-82147119]{bottom:-4px;left:-4px;background:#52c41a}.resize-handle.bottom-left[data-v-82147119]:hover{background:#73d13d}.resize-handle.bottom-left[data-v-82147119]:active{background:#389e0d}.resize-handle.left[data-v-82147119]{top:50%;left:-4px;transform:translateY(-50%)}.resize-handle.left[data-v-82147119]:hover,.resize-handle.left[data-v-82147119]:active{transform:translateY(-50%)}.rotate-handle[data-v-82147119]{position:absolute;top:-5px;left:50%;transform:translate(-50%);width:10px;height:10px;background:#1890ff;color:#fff;border-radius:50%;cursor:grab;z-index:1002;display:flex;align-items:center;justify-content:center}.size-label[data-v-82147119]{display:flex;justify-content:center;flex-wrap:nowrap;white-space:nowrap;position:absolute;top:-14px;left:-4px;width:auto;min-width:70px;height:auto;background:rgba(255,34,34,.8);color:#fff;font-size:7px;border-radius:6px;z-index:20;line-height:1.2;box-shadow:0 2px 8px #00000014;pointer-events:none;padding:1px 8px 0}.delete-btn[data-v-82147119]{position:absolute;top:-5px;right:-5px;width:10px;height:10px;background:#ff4d4f;color:#fff;border:none;border-radius:50%;cursor:pointer;z-index:1003;display:flex;align-items:center;justify-content:center}.drag-extend-lines[data-v-82147119]{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.drag-extend-line[data-v-82147119]{position:absolute;pointer-events:none;z-index:998}.drag-extend-line.horizontal[data-v-82147119]{width:100%;height:0;left:0;border-top:1px dashed rgb(177,179,184)}.drag-extend-line.vertical[data-v-82147119]{width:0;height:100%;top:0;border-left:1px dashed rgb(177,179,184)}.drag-extend-line.rotated[data-v-82147119]{position:absolute;border:1px dashed #1890ff;pointer-events:none;z-index:998}.number-input input[type=number][data-v-82147119]::-webkit-inner-spin-button,.number-input input[type=number][data-v-82147119]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.switch-input[data-v-82147119]{display:flex;align-items:center}.switch-input input[type=checkbox][data-v-82147119]{width:20px;height:20px;cursor:pointer;accent-color:#1890ff}.component-selected[data-v-82147119],.component-current[data-v-82147119]{outline:1px dashed #1890ff!important;outline-offset:0!important}.component-selected[data-v-82147119],.component-current[data-v-82147119]{box-sizing:border-box}.no-outline.component-selected[data-v-82147119],.no-outline.component-current[data-v-82147119]{outline:none!important}.template-designer[data-v-9a302bda]{overflow-y:hidden}.template-designer-border-top[data-v-9a302bda]{border-top:1px solid #e0e0e0}
|
|
1
|
+
.td-text-component{width:100%;height:100%;position:relative;display:flex;align-items:center;overflow:hidden;box-sizing:border-box}.td-text-content{width:100%;min-width:0;box-sizing:border-box}.label[data-v-a7fa57c5]{display:flex;align-items:center;justify-content:flex-start}.property-item[data-v-a7fa57c5]{display:flex;flex-direction:column;gap:4px}.property-item label[data-v-a7fa57c5]{font-size:14px;color:#666}.property-item input[data-v-a7fa57c5],.property-item select[data-v-a7fa57c5]{padding:4px 8px;border:1px solid #ddd;border-radius:4px}.property-item input[type=color][data-v-a7fa57c5]{height:32px;padding:2px}.property-item input[type=checkbox][data-v-a7fa57c5]{width:16px;height:16px}.file-input-container[data-v-a7fa57c5]{position:relative;display:flex;align-items:center;gap:8px}.file-input-container input[data-v-a7fa57c5]{height:100%!important}.file-url-input[data-v-a7fa57c5]{flex:1;padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:12px}.file-url-input[data-v-a7fa57c5]:disabled{background-color:#f5f5f5;cursor:not-allowed}.file-input[data-v-a7fa57c5]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.file-select-btn[data-v-a7fa57c5]{padding:4px 12px;border:1px solid #ddd;border-radius:4px;background:var(--el-color-primary);color:#fff;cursor:pointer;font-size:12px;white-space:nowrap;display:flex;align-items:center;gap:4px}.file-select-btn[data-v-a7fa57c5]:hover:not(:disabled){background:var(--el-color-primary-dark-2);border-color:var(--el-color-primary-dark-2)}.file-select-btn[data-v-a7fa57c5]:disabled{background:#ccc;cursor:not-allowed}.file-info[data-v-a7fa57c5]{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background-color:#f5f5f5;border-radius:4px;margin-top:4px}.file-name[data-v-a7fa57c5]{font-size:12px;color:#666;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clear-btn[data-v-a7fa57c5]{background:none;border:none;color:#ff4d4f;cursor:pointer;font-size:12px;padding:2px 6px;border-radius:2px}.clear-btn[data-v-a7fa57c5]:hover{background-color:#fff2f0}.property-panel[data-v-f70859fd]{padding:16px;background:#fff;border-left:1px solid #e4e7ed;overflow-y:auto;height:100%}.property-group[data-v-f70859fd]{margin-bottom:16px}.property-group-title[data-v-f70859fd]{font-size:14px;font-weight:500;color:#303133;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid #ebeef5}.property-item[data-v-f70859fd]{margin-bottom:12px}.text-property-panel .property-item[data-v-f70859fd]:last-child,.barcode-property-panel .property-item[data-v-f70859fd]:last-child,.qrcode-property-panel .property-item[data-v-f70859fd]:last-child,.image-property-panel .property-item[data-v-f70859fd]:last-child,.rectangle-property-panel .property-item[data-v-f70859fd]:last-child,.horline-property-panel .property-item[data-v-f70859fd]:last-child,.verline-property-panel .property-item[data-v-f70859fd]:last-child{margin-bottom:0}.barcode-component{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;box-sizing:border-box}.barcode-component svg{width:100%!important;height:100%!important;max-width:100%;max-height:100%;display:block}.qrcode-component[data-v-6e726fcb]{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;box-sizing:border-box}.qrcode-canvas-fixed[data-v-6e726fcb]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:0;margin:0}.qrcode-image[data-v-6e726fcb]{display:block;width:100%!important;height:100%!important;padding:0;margin:0;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:-o-crisp-edges;image-rendering:-webkit-crisp-edges;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0);-webkit-transform:translateZ(0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;filter:none;-webkit-filter:none;object-fit:cover;object-position:center}.component-selection-overlay[data-v-6e726fcb]{position:absolute;border:2px dashed #1890ff;pointer-events:none;box-sizing:border-box;z-index:1000}.qrcode-property-panel[data-v-cce393d5]{display:flex;flex-direction:column;gap:12px}.property-item[data-v-cce393d5]{display:flex;flex-direction:column;gap:4px}.property-item label[data-v-cce393d5]{font-size:14px;color:#666}.property-item input[data-v-cce393d5],.property-item select[data-v-cce393d5]{padding:4px 8px;border:1px solid #ddd;border-radius:4px}.property-item input[type=color][data-v-cce393d5]{height:32px;padding:2px}.image-component[data-v-6edf2c8f]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;background-color:#fafafa}.image-placeholder[data-v-6edf2c8f]{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#999;font-size:12px;gap:8px}.image-loading-overlay[data-v-6edf2c8f]{position:absolute;left:0;top:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.6);z-index:5}.image-content[data-v-6edf2c8f]{display:block;max-width:100%;max-height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:-o-crisp-edges;image-rendering:-webkit-crisp-edges;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0);-webkit-transform:translateZ(0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.component-selection-overlay[data-v-6edf2c8f]{position:absolute;border:2px dashed #1890ff;pointer-events:none;box-sizing:border-box;z-index:1000}.image-property-panel[data-v-462c8b63]{display:flex;flex-direction:column;gap:12px}.property-item[data-v-462c8b63]{display:flex;flex-direction:column;gap:4px}.property-item label[data-v-462c8b63]{font-size:14px;color:#666}.property-item input[data-v-462c8b63],.property-item select[data-v-462c8b63]{padding:4px 8px;border:1px solid #ddd;border-radius:4px}.property-item input[type=color][data-v-462c8b63]{height:32px;padding:2px}.rectangle-component{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;overflow:visible;box-sizing:border-box}.rectangle-content{width:100%;height:100%;box-sizing:border-box;position:relative}.hairline-edge{position:absolute;pointer-events:none}.component-selection-overlay{position:absolute;border:2px dashed #1890ff;pointer-events:none;box-sizing:border-box;z-index:1000}.rectangle-property-panel[data-v-e06ed44e]{display:flex;flex-direction:column;gap:12px}.horline-component{position:relative;display:flex;align-items:center;justify-content:center;overflow:visible;box-sizing:border-box}.line-selection-outline{position:absolute;left:0;top:0;border:2px dashed #1890ff;pointer-events:none;box-sizing:border-box;z-index:1000}.component-list[data-v-3ab62635]{background:#fff;display:flex;flex-direction:column;gap:20px}.component-group[data-v-3ab62635]{display:flex;flex-direction:column;gap:8px}.group-title[data-v-3ab62635]{font-size:14px;font-weight:600;color:#333;padding:8px 12px;border-left:4px solid var(--el-color-primary);background:linear-gradient(135deg,var(--el-color-primary-light-9) 0%,var(--el-color-primary-light-8) 100%);border-radius:0 6px 6px 0;margin-bottom:4px;box-shadow:0 1px 3px #0000001a}.group-content[data-v-3ab62635]{display:grid;grid-template-columns:1fr 1fr;grid-row-gap:8px;grid-column-gap:8px}.component-item[data-v-3ab62635]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px 0;border:1px solid #ddd;border-radius:4px;cursor:grab;font-size:13px;color:#555;transition:all .2s ease;width:100%;height:70px;background:#fff;box-shadow:0 1px 3px #0000001a}.component-item[data-v-3ab62635]:hover{background-color:var(--el-color-primary-light-9);border-color:var(--el-color-primary);color:var(--el-color-primary);box-shadow:0 2px 8px #00000014}.component-item i[data-v-3ab62635]{font-size:24px;margin-bottom:8px;color:var(--el-color-primary)}.component-item span[data-v-3ab62635]{font-size:12px;text-align:center;color:#333}.component-item:hover i[data-v-3ab62635],.component-item:hover span[data-v-3ab62635]{color:var(--el-color-primary)!important}.ruler[data-v-3635eba4]{position:absolute;z-index:1}.ruler.horizontal[data-v-3635eba4]{left:20px;top:0;width:calc(100% - 40px);height:20px;border-bottom:none}.ruler.vertical[data-v-3635eba4]{top:20px;left:0;width:20px;height:calc(100% - 40px);border-right:none}.ruler-unit[data-v-3635eba4]{position:absolute}.ruler.horizontal .ruler-unit[data-v-3635eba4]{height:100%}.ruler.vertical .ruler-unit[data-v-3635eba4]{width:100%}.ruler-mark[data-v-3635eba4]{position:absolute;background:#999}.ruler.horizontal .ruler-mark[data-v-3635eba4]{bottom:0}.ruler.vertical .ruler-mark[data-v-3635eba4]{right:0}.ruler-text[data-v-3635eba4]{position:absolute;font-size:8px;color:#666;white-space:nowrap}.ruler.horizontal .ruler-text[data-v-3635eba4]{bottom:8px;transform:translate(-50%)}.ruler.vertical .ruler-text[data-v-3635eba4]{right:8px;transform:translateY(-50%) rotate(-90deg)}.add-btn[data-v-a4b90b63]{margin:10px 0}.tg-title[data-v-a4b90b63]{display:flex;align-items:center}.tg-title p[data-v-a4b90b63]{font-size:18px;font-weight:700}.tge-main[data-v-a4b90b63]{max-height:82vh;padding:0}.tge-text[data-v-a4b90b63]{font-size:14px;line-height:26px}.tge-content[data-v-a4b90b63]{display:flex;width:100%}.tge-block[data-v-a4b90b63]{display:flex;flex-direction:column;flex:1}.tge-title[data-v-a4b90b63]{padding:6px 0;font-size:14px;color:var(--el-color-primary)}.tge-img[data-v-a4b90b63]{width:100%;height:auto}.table-container[data-v-a4b90b63]{width:100%;border:1px dashed #ddd;border-radius:4px}.empty-placeholder[data-v-a4b90b63]{display:flex;align-items:center;justify-content:center;color:#999;padding:20px;border-radius:4px;min-height:80px}.graph-table[data-v-a4b90b63]{margin-top:10px}.tge-divider[data-v-a4b90b63]{width:1px;background:var(--el-border-color);margin:0 10px}.graph-table .el-table__header,.graph-table .el-table__body{width:100%!important}.graph-table .el-table__body{margin-bottom:10px!important}.graph-table .el-form-item__error{position:static!important;top:0!important}.graph-table .el-input-number{width:auto}.graph-table .el-input-number.is-without-controls .el-input__wrapper{padding-left:4px;padding-right:4px}button[data-v-fd4d9530]{display:flex;align-items:center;justify-content:center}.label-designer[data-v-fd4d9530]{display:flex;height:100%}.toolbar[data-v-fd4d9530]{width:200px;background:#fff;border-right:1px solid #e0e0e0;padding:16px;display:flex;flex-direction:column;gap:16px}.zoom-controls span[data-v-fd4d9530]{width:44px;text-align:center}.zoom-controls[data-v-fd4d9530]{display:flex;align-items:center;gap:8px;background:#f5f5f5;border-radius:4px;padding:4px 8px}.zoom-controls button[data-v-fd4d9530]{width:24px;height:24px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer}.zoom-controls button[data-v-fd4d9530]:disabled{opacity:.5;cursor:not-allowed}.center-container[data-v-fd4d9530]{display:flex;flex-direction:column;flex:1;overflow:hidden;height:100%}.center-toolbar[data-v-fd4d9530]{display:flex;align-items:center;justify-content:flex-end;padding:16px 16px 0;background:rgba(0,0,0,.05)}.canvas-container[data-v-fd4d9530]{width:100%;flex:1;padding:0 16px 16px;overflow:auto;background:rgba(0,0,0,.05);position:relative;display:flex;flex-direction:column}.canvas-wrapper[data-v-fd4d9530]{position:relative;transform-origin:0 0;overflow:visible;width:fit-content;height:fit-content;margin-top:20px;transition:all .2s ease;transform:translateZ(0);will-change:transform}.ruler-horizontal[data-v-fd4d9530]{position:absolute;left:0;top:0;right:0;height:24px;z-index:10;pointer-events:none}.ruler-vertical[data-v-fd4d9530]{position:absolute;left:0;top:0;bottom:0;width:24px;z-index:10;pointer-events:none}.canvas[data-v-fd4d9530]{position:relative;overflow:visible;z-index:1;position:absolute;left:21px;top:21px}.property-panel[data-v-fd4d9530]{width:260px;background:#fff;border-left:1px solid #ddd;padding:0 16px 16px;display:flex;flex-direction:column;gap:16px;position:relative;z-index:100;overflow-y:auto}.property-panel-title[data-v-fd4d9530]{position:sticky;top:0;left:0;right:0;background:#fff;z-index:100;display:flex;align-items:center;justify-content:flex-start;margin:10px 0 0}.position-controls[data-v-fd4d9530]{display:flex;flex-direction:column;gap:12px;padding:12px;background:#f5f5f5;border-radius:4px}.control-group[data-v-fd4d9530]{display:flex;align-items:center;justify-content:space-between;gap:4px}.control-group label[data-v-fd4d9530]{width:80px;font-size:14px;color:#666;text-align:end}.number-input[data-v-fd4d9530]{display:flex;align-items:center;gap:4px}.number-input input[data-v-fd4d9530]{width:90px;padding:4px;border:1px solid #ddd;border-radius:4px;text-align:center}.number-input button[data-v-fd4d9530]{width:24px;height:24px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer}.canvas-item[data-v-fd4d9530]{position:absolute;cursor:move;-webkit-user-select:none;user-select:none;z-index:10;transform:translateZ(0);will-change:transform;left:0;top:0}.resize-handle[data-v-fd4d9530]{position:absolute;width:6px;height:6px;background:#1890ff;border:1px solid #fff;box-shadow:0 0 3px #0000004d;cursor:pointer;z-index:1001;transition:all .2s ease;border-radius:1px;display:block!important;visibility:visible!important;opacity:1!important;transform:translateZ(0);will-change:transform;font-size:16px!important;line-height:1!important}.resize-handle[data-v-fd4d9530]:hover{background:#40a9ff;box-shadow:0 0 4px #0006}.resize-handle.top-left[data-v-fd4d9530]{top:-4px;left:-4px;background:#52c41a}.resize-handle.top-left[data-v-fd4d9530]:hover{background:#73d13d}.resize-handle.top-left[data-v-fd4d9530]:active{background:#389e0d}.resize-handle.top[data-v-fd4d9530]{top:-4px;left:50%;transform:translate(-50%)}.resize-handle.top[data-v-fd4d9530]:hover,.resize-handle.top[data-v-fd4d9530]:active{transform:translate(-50%)}.resize-handle.top-right[data-v-fd4d9530]{top:-4px;right:-4px;background:#52c41a}.resize-handle.top-right[data-v-fd4d9530]:hover{background:#73d13d}.resize-handle.top-right[data-v-fd4d9530]:active{background:#389e0d}.resize-handle.right[data-v-fd4d9530]{top:50%;right:-4px;transform:translateY(-50%)}.resize-handle.right[data-v-fd4d9530]:hover,.resize-handle.right[data-v-fd4d9530]:active{transform:translateY(-50%)}.resize-handle.bottom-right[data-v-fd4d9530]{bottom:-4px;right:-4px;background:#52c41a;z-index:1001}.resize-handle.bottom-right[data-v-fd4d9530]:hover{background:#73d13d}.resize-handle.bottom-right[data-v-fd4d9530]:active{background:#389e0d}.resize-handle.bottom[data-v-fd4d9530]{bottom:-4px;left:50%;transform:translate(-50%)}.resize-handle.bottom[data-v-fd4d9530]:hover,.resize-handle.bottom[data-v-fd4d9530]:active{transform:translate(-50%)}.resize-handle.bottom-left[data-v-fd4d9530]{bottom:-4px;left:-4px;background:#52c41a}.resize-handle.bottom-left[data-v-fd4d9530]:hover{background:#73d13d}.resize-handle.bottom-left[data-v-fd4d9530]:active{background:#389e0d}.resize-handle.left[data-v-fd4d9530]{top:50%;left:-4px;transform:translateY(-50%)}.resize-handle.left[data-v-fd4d9530]:hover,.resize-handle.left[data-v-fd4d9530]:active{transform:translateY(-50%)}.rotate-handle[data-v-fd4d9530]{position:absolute;top:-5px;left:50%;transform:translate(-50%);width:10px;height:10px;background:#1890ff;color:#fff;border-radius:50%;cursor:grab;z-index:1002;display:flex;align-items:center;justify-content:center}.size-label[data-v-fd4d9530]{display:flex;justify-content:center;flex-wrap:nowrap;white-space:nowrap;position:absolute;top:-14px;left:-4px;width:auto;min-width:70px;height:auto;background:rgba(255,34,34,.8);color:#fff;font-size:7px;border-radius:6px;z-index:20;line-height:1.2;box-shadow:0 2px 8px #00000014;pointer-events:none;padding:1px 8px 0}.delete-btn[data-v-fd4d9530]{position:absolute;top:-5px;right:-5px;width:10px;height:10px;background:#ff4d4f;color:#fff;border:none;border-radius:50%;cursor:pointer;z-index:1003;display:flex;align-items:center;justify-content:center}.drag-extend-lines[data-v-fd4d9530]{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.drag-extend-line[data-v-fd4d9530]{position:absolute;pointer-events:none;z-index:998}.drag-extend-line.horizontal[data-v-fd4d9530]{width:100%;height:0;left:0;border-top:1px dashed rgb(177,179,184)}.drag-extend-line.vertical[data-v-fd4d9530]{width:0;height:100%;top:0;border-left:1px dashed rgb(177,179,184)}.drag-extend-line.rotated[data-v-fd4d9530]{position:absolute;border:1px dashed #1890ff;pointer-events:none;z-index:998}.alignment-guides[data-v-fd4d9530]{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999}.alignment-guide[data-v-fd4d9530]{background-color:transparent;pointer-events:none;z-index:9999}.alignment-guide.horizontal[data-v-fd4d9530]{position:absolute;left:0;right:0;height:1px;background:linear-gradient(to right,#ff4d4f 0%,#ff4d4f 50%,transparent 50%,transparent 100%);background-size:6px 1px;background-repeat:repeat-x;transform:translateZ(0);will-change:auto}.alignment-guide.vertical[data-v-fd4d9530]{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,#ff4d4f 0%,#ff4d4f 50%,transparent 50%,transparent 100%);background-size:1px 6px;background-repeat:repeat-y;transform:translateZ(0);will-change:auto}.number-input input[type=number][data-v-fd4d9530]::-webkit-inner-spin-button,.number-input input[type=number][data-v-fd4d9530]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.switch-input[data-v-fd4d9530]{display:flex;align-items:center}.switch-input input[type=checkbox][data-v-fd4d9530]{width:20px;height:20px;cursor:pointer;accent-color:#1890ff}.component-selected[data-v-fd4d9530],.component-current[data-v-fd4d9530]{outline:1px dashed #1890ff!important;outline-offset:0!important}.component-selected[data-v-fd4d9530],.component-current[data-v-fd4d9530]{box-sizing:border-box}.no-outline.component-selected[data-v-fd4d9530],.no-outline.component-current[data-v-fd4d9530]{outline:none!important}.template-designer[data-v-82f858e6]{overflow-y:hidden}.template-designer-border-top[data-v-82f858e6]{border-top:1px solid #e0e0e0}
|