iking-template-inset 0.0.3 → 0.0.5
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.
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* @description :
|
|
5
5
|
* @updateInfo :
|
|
6
6
|
* @Date : 2022-11-21 10:28:10
|
|
7
|
-
* @LastEditTime : 2022-11-
|
|
7
|
+
* @LastEditTime : 2022-11-28 12:09:42
|
|
8
8
|
*/
|
|
9
9
|
/// <reference types="vite/client" />
|
|
10
10
|
|
|
@@ -13,16 +13,18 @@ declare module 'iking-template-inset' {
|
|
|
13
13
|
const component: Component<{
|
|
14
14
|
width: number; // 宽度
|
|
15
15
|
height: number; // 高度
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
16
|
+
// 参数列表
|
|
17
|
+
tagList: Array<{
|
|
18
|
+
label: string;
|
|
19
|
+
value: string;
|
|
20
|
+
[key: string]: any;
|
|
21
|
+
}[]>,
|
|
22
|
+
// "1px solid #dcdfe6"
|
|
23
|
+
border: string;
|
|
24
|
+
// 排列方式
|
|
25
|
+
horizontal: Boolean
|
|
26
|
+
// placeholder
|
|
27
|
+
placeholder: string
|
|
26
28
|
}>
|
|
27
29
|
export default component
|
|
28
30
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { defineComponent as
|
|
2
|
-
const
|
|
1
|
+
import { defineComponent as k, useCssVars as x, ref as u, watch as $, openBlock as i, createElementBlock as d, normalizeStyle as m, createElementVNode as f, Fragment as y, renderList as b, renderSlot as S, createTextVNode as w, toDisplayString as I, withDirectives as V, withKeys as A, withModifiers as B, vModelText as C } from "vue";
|
|
2
|
+
const z = ["onClick"], F = ["placeholder"], K = /* @__PURE__ */ k({
|
|
3
3
|
__name: "App",
|
|
4
4
|
props: {
|
|
5
5
|
modelVlaue: {
|
|
@@ -12,75 +12,96 @@ const C = { class: "left-template-tag" }, L = ["onClick"], V = /* @__PURE__ */ b
|
|
|
12
12
|
type: Array,
|
|
13
13
|
default: () => []
|
|
14
14
|
},
|
|
15
|
-
|
|
15
|
+
border: {
|
|
16
16
|
type: String,
|
|
17
|
-
default: ""
|
|
17
|
+
default: "1px solid #dcdfe6"
|
|
18
|
+
},
|
|
19
|
+
horizontal: {
|
|
20
|
+
type: Boolean,
|
|
21
|
+
default: !0
|
|
22
|
+
},
|
|
23
|
+
placeholder: {
|
|
24
|
+
type: String,
|
|
25
|
+
default: "\u8BF7\u8F93\u5165\u6216\u70B9\u51FB\u63D2\u5165\u53C2\u6570"
|
|
18
26
|
}
|
|
19
27
|
},
|
|
20
28
|
emits: ["update:modelVlaue"],
|
|
21
|
-
setup(
|
|
22
|
-
const
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
|
|
29
|
+
setup(l, { emit: c }) {
|
|
30
|
+
const s = l;
|
|
31
|
+
x((t) => ({
|
|
32
|
+
"8d8ff372": l.border
|
|
33
|
+
}));
|
|
34
|
+
const a = u(-1), r = () => {
|
|
35
|
+
var e;
|
|
36
|
+
const t = (e = p.value) == null ? void 0 : e.selectionStart;
|
|
37
|
+
a.value = t ? t || 0 : -1;
|
|
38
|
+
}, n = u(""), h = u(""), p = u(null);
|
|
39
|
+
$(n, (t) => {
|
|
40
|
+
c("update:modelVlaue", t);
|
|
28
41
|
});
|
|
29
|
-
const
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
if (
|
|
37
|
-
|
|
38
|
-
else if (l.value === 0)
|
|
39
|
-
t.value = `${n}${t.value}`;
|
|
42
|
+
const _ = (t) => {
|
|
43
|
+
var e;
|
|
44
|
+
r(), h.value = (e = p.value) == null ? void 0 : e.selectionStart;
|
|
45
|
+
}, g = (t) => {
|
|
46
|
+
const e = `\u3010${t.label}\${${t.value}}\u3011`;
|
|
47
|
+
if (a.value === -1)
|
|
48
|
+
n.value = `${n.value}${e}`;
|
|
49
|
+
else if (a.value === 0)
|
|
50
|
+
n.value = `${e}${n.value}`;
|
|
40
51
|
else {
|
|
41
|
-
const
|
|
42
|
-
|
|
52
|
+
const o = n.value;
|
|
53
|
+
n.value = o.substring(0, a.value) + e + o.substring(a.value);
|
|
43
54
|
}
|
|
44
|
-
i.value.innerHTML = t.value;
|
|
45
55
|
};
|
|
46
|
-
return (
|
|
47
|
-
class:
|
|
56
|
+
return (t, e) => (i(), d("div", {
|
|
57
|
+
class: "msg-template",
|
|
58
|
+
style: m({
|
|
59
|
+
"flex-direction": s.horizontal ? "row" : "column",
|
|
60
|
+
height: `${s.height}px`
|
|
61
|
+
})
|
|
48
62
|
}, [
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
63
|
+
f("div", {
|
|
64
|
+
class: "left-template-tag",
|
|
65
|
+
style: m({ "margin-right": s.horizontal ? "16px" : "0" })
|
|
66
|
+
}, [
|
|
67
|
+
(i(!0), d(y, null, b(l.tagList, (o, v) => (i(), d("div", {
|
|
68
|
+
onClick: (D) => g(o),
|
|
69
|
+
key: v
|
|
53
70
|
}, [
|
|
54
|
-
|
|
71
|
+
t.$slots.item ? S(t.$slots, "item", {
|
|
55
72
|
key: 0,
|
|
56
|
-
item: { ...
|
|
57
|
-
}, void 0, !0) : (
|
|
58
|
-
|
|
73
|
+
item: { ...o, index: v }
|
|
74
|
+
}, void 0, !0) : (i(), d(y, { key: 1 }, [
|
|
75
|
+
w(I(o.label), 1)
|
|
59
76
|
], 64))
|
|
60
|
-
], 8,
|
|
61
|
-
]),
|
|
62
|
-
|
|
63
|
-
ref_key: "
|
|
64
|
-
ref:
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
77
|
+
], 8, z))), 128))
|
|
78
|
+
], 4),
|
|
79
|
+
V(f("textarea", {
|
|
80
|
+
ref_key: "refArea",
|
|
81
|
+
ref: p,
|
|
82
|
+
"onUpdate:modelValue": e[0] || (e[0] = (o) => n.value = o),
|
|
83
|
+
onKeyup: _,
|
|
84
|
+
onClick: r,
|
|
85
|
+
onKeydown: e[1] || (e[1] = A(B(() => {
|
|
68
86
|
}, ["prevent"]), ["enter"])),
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
},
|
|
72
|
-
|
|
87
|
+
class: "right-template",
|
|
88
|
+
placeholder: l.placeholder
|
|
89
|
+
}, `
|
|
90
|
+
`, 40, F), [
|
|
91
|
+
[C, n.value]
|
|
92
|
+
])
|
|
93
|
+
], 4));
|
|
73
94
|
}
|
|
74
95
|
});
|
|
75
|
-
const
|
|
76
|
-
const
|
|
77
|
-
for (const [
|
|
78
|
-
|
|
79
|
-
return
|
|
80
|
-
},
|
|
81
|
-
|
|
96
|
+
const N = (l, c) => {
|
|
97
|
+
const s = l.__vccOpts || l;
|
|
98
|
+
for (const [a, r] of c)
|
|
99
|
+
s[a] = r;
|
|
100
|
+
return s;
|
|
101
|
+
}, T = /* @__PURE__ */ N(K, [["__scopeId", "data-v-8e5e4859"]]), E = (l) => {
|
|
102
|
+
l.component("IkingTemplateInset", T);
|
|
82
103
|
};
|
|
83
104
|
export {
|
|
84
|
-
|
|
85
|
-
|
|
105
|
+
T as default,
|
|
106
|
+
E as install
|
|
86
107
|
};
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(a,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(a=typeof globalThis<"u"?globalThis:a||self,e(a.IkingTemplateInset={},a.Vue))})(this,function(a,e){"use strict";const m=["onClick"],y=["placeholder"],_=e.defineComponent({__name:"App",props:{modelVlaue:{type:String,default:""},height:{type:Number,default:300},width:{type:Number,default:600},tagList:{type:Array,default:()=>[]},border:{type:String,default:"1px solid #dcdfe6"},horizontal:{type:Boolean,default:!0},placeholder:{type:String,default:"\u8BF7\u8F93\u5165\u6216\u70B9\u51FB\u63D2\u5165\u53C2\u6570"}},emits:["update:modelVlaue"],setup(n,{emit:c}){const i=n;e.useCssVars(l=>({"8d8ff372":n.border}));const s=e.ref(-1),d=()=>{var t;const l=(t=p.value)==null?void 0:t.selectionStart;s.value=l?l||0:-1},o=e.ref(""),g=e.ref(""),p=e.ref(null);e.watch(o,l=>{c("update:modelVlaue",l)});const k=l=>{var t;d(),g.value=(t=p.value)==null?void 0:t.selectionStart},x=l=>{const t=`\u3010${l.label}\${${l.value}}\u3011`;if(s.value===-1)o.value=`${o.value}${t}`;else if(s.value===0)o.value=`${t}${o.value}`;else{const r=o.value;o.value=r.substring(0,s.value)+t+r.substring(s.value)}};return(l,t)=>(e.openBlock(),e.createElementBlock("div",{class:"msg-template",style:e.normalizeStyle({"flex-direction":i.horizontal?"row":"column",height:`${i.height}px`})},[e.createElementVNode("div",{class:"left-template-tag",style:e.normalizeStyle({"margin-right":i.horizontal?"16px":"0"})},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.tagList,(r,f)=>(e.openBlock(),e.createElementBlock("div",{onClick:b=>x(r),key:f},[l.$slots.item?e.renderSlot(l.$slots,"item",{key:0,item:{...r,index:f}},void 0,!0):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(r.label),1)],64))],8,m))),128))],4),e.withDirectives(e.createElementVNode("textarea",{ref_key:"refArea",ref:p,"onUpdate:modelValue":t[0]||(t[0]=r=>o.value=r),onKeyup:k,onClick:d,onKeydown:t[1]||(t[1]=e.withKeys(e.withModifiers(()=>{},["prevent"]),["enter"])),class:"right-template",placeholder:n.placeholder},`
|
|
2
|
+
`,40,y),[[e.vModelText,o.value]])],4))}}),B="",S="",u=((n,c)=>{const i=n.__vccOpts||n;for(const[s,d]of c)i[s]=d;return i})(_,[["__scopeId","data-v-8e5e4859"]]),h=n=>{n.component("IkingTemplateInset",u)};a.default=u,a.install=h,Object.defineProperties(a,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
|
package/dist/style.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.__templeate_param_tag{display:inline-block;padding:2px;background:#dfdfdf;font-size:13px;border-radius:4px;margin-right:2px}.msg-template[data-v-
|
|
1
|
+
.__templeate_param_tag{display:inline-block;padding:2px;background:#dfdfdf;font-size:13px;border-radius:4px;margin-right:2px}.msg-template[data-v-8e5e4859]{display:flex;width:100%;margin-bottom:8px;justify-content:space-between}.msg-template>div[data-v-8e5e4859],.msg-template textarea[data-v-8e5e4859]{flex:1;border:var(--8d8ff372);border-radius:4px;padding:8px;height:100%;min-height:50px;width:calc(100% - 16px)}.msg-template .left-template-tag div[data-v-8e5e4859]{display:inline-flex;align-items:center;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;flex-wrap:wrap;cursor:pointer;user-select:none;padding:3px 8px;width:100px;border-radius:4px;background:#edebeb;margin-right:8px;margin-bottom:8px;height:24px;color:#464646}.msg-template .right-template[data-v-8e5e4859]{background:rgba(255,255,255,0)}.msg-template .right-template[data-v-8e5e4859]:focus-visible{outline:none}
|