UNPKG

@farris/ui-vue

Version:

Farris Vue, a Farris Design based Vue3 component library.

1,378 lines 203 kB
var Pn = Object.defineProperty; var On = (n, e, t) => e in n ? Pn(n, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : n[e] = t; var _ = (n, e, t) => On(n, typeof e != "symbol" ? e + "" : e, t); import { ref as C, computed as L, defineComponent as Be, createVNode as b, watch as Se, Fragment as at, reactive as De, createApp as Zt, onUnmounted as Ct, onMounted as Je, Transition as Jt, mergeProps as Lt, nextTick as wt, createTextVNode as Rn, inject as jt, onBeforeMount as Vn, Teleport as Nn, shallowRef as jn, render as Nt, h as Dn, cloneVNode as Hn } from "vue"; import { cloneDeep as vt, isPlainObject as _t, isUndefined as Ne } from "lodash-es"; import { resolveAppearance as Kt, getSchemaByTypeForDesigner as Ln, createPropsResolver as en } from "../dynamic-resolver/index.esm.js"; import { useI18n as St } from "vue-i18n"; import { DgControl as Xt, useDesignerComponent as $n } from "../designer-canvas/index.esm.js"; import { getCustomClass as Dt, withInstall as tn, FormSchemaEntityField$Type as gt, FormSchemaEntityFieldTypeName as Yt, FormSchemaEntityFieldType$Type as zn } from "../common/index.esm.js"; import { LocaleService as At } from "../locale/index.esm.js"; import { useResizeObserver as qn } from "@vueuse/core"; import { getHierarchyRow as Un, useIdentify as Wn, useGroupData as Gn, useFilter as Qn, useHierarchy as _n, useLoading as Xn, useDataView as Yn, useSelection as Zn, useSelectHierarchyItem as Jn, usePagination as Kn, useDataViewContainerStyle as eo, useCommandColumn as to, useSettingColumn as no, useColumn as oo, useSort as io, useGroupColumn as ro, useRow as ao, useEdit as so, useVisualDataBound as lo, useVisualDataCell as co, useVisualDataRow as uo, useVisualData as fo, useCellPosition as po, useSidebar as mo, useVirtualScroll as vo, useFitColumn as go, useFilterHistory as ho, useColumnFilter as yo, useDragColumn as bo, getColumnHeader as Co, getSidebar as wo, getDisableMask as So, getHorizontalScrollbar as Ao, getVerticalScrollbar as xo, getEmpty as To, getPagination as Eo, getSummary as Mo } from "../data-view/index.esm.js"; import "../property-panel/index.esm.js"; import "../accordion/index.esm.js"; import "../avatar/index.esm.js"; import "../../designer/button-edit/index.esm.js"; import "../button-group/index.esm.js"; import "../calendar/index.esm.js"; import "../capsule/index.esm.js"; import "../../designer/checkbox/index.esm.js"; import "../../designer/checkbox-group/index.esm.js"; import "../combo-list/index.esm.js"; import "../combo-tree/index.esm.js"; import "../component/index.esm.js"; import "../color-picker/index.esm.js"; import "../content-container/index.esm.js"; import "../date-picker/index.esm.js"; import "../../designer/data-grid/index.esm.js"; import "../dropdown/index.esm.js"; import "../dynamic-form/index.esm.js"; import "../events-editor/index.esm.js"; import "../filter-bar/index.esm.js"; import "../field-selector/index.esm.js"; import "../binding-selector/index.esm.js"; import "../image-cropper/index.esm.js"; import "../../designer/input-group/index.esm.js"; import "../layout/index.esm.js"; import "../list-nav/index.esm.js"; import "../../designer/list-view/index.esm.js"; import "../lookup/index.esm.js"; import "../mapping-editor/index.esm.js"; import "../nav/index.esm.js"; import "../number-range/index.esm.js"; import "../number-spinner/index.esm.js"; import "../order/index.esm.js"; import "../page-header/index.esm.js"; import "../page-footer/index.esm.js"; import "../pagination/index.esm.js"; import "../progress/index.esm.js"; import "../query-solution/index.esm.js"; import "../../designer/radio-group/index.esm.js"; import "../rate/index.esm.js"; import "../response-toolbar/index.esm.js"; import "../response-layout/index.esm.js"; import "../response-layout-editor/index.esm.js"; import "../search-box/index.esm.js"; import "../section/index.esm.js"; import "../smoke-detector/index.esm.js"; import "../splitter/index.esm.js"; import "../step/index.esm.js"; import "../switch/index.esm.js"; import "../tabs/index.esm.js"; import "../tags/index.esm.js"; import "../text/index.esm.js"; import "../time-picker/index.esm.js"; import "../transfer/index.esm.js"; import "../tree-view/index.esm.js"; import "../uploader/index.esm.js"; import "../verify-detail/index.esm.js"; import "../video/index.esm.js"; import "../textarea/index.esm.js"; import "../schema-selector/index.esm.js"; import "../../designer/tree-grid/index.esm.js"; import "../event-parameter/index.esm.js"; import "../filter-condition-editor/index.esm.js"; import "../fieldset/index.esm.js"; import "../sort-condition-editor/index.esm.js"; import "../menu-lookup/index.esm.js"; import "../../designer/drawer/index.esm.js"; import "../json-editor/index.esm.js"; import "../property-editor/index.esm.js"; import "../expression-editor/index.esm.js"; import "../code-editor/index.esm.js"; import "../html-template/index.esm.js"; import "../collection-property-editor/index.esm.js"; import "../modal/index.esm.js"; import "../external-container/index.esm.js"; import "../language-textbox/index.esm.js"; import "../notify/index.esm.js"; function nn(n, e) { let t; function o(s) { const { properties: m, title: d, ignore: f } = s, v = f && Array.isArray(f), S = Object.keys(m).reduce((E, F) => ((!v || !f.find(($) => $ === F)) && (E[F] = m[F].type === "object" && m[F].properties ? o(m[F]) : vt(m[F].default)), E), {}); if (d && (!v || !f.find((E) => E === "id"))) { const E = d.toLowerCase().replace(/-/g, "_"); S.id = `${E}_${Math.random().toString().slice(2, 6)}`; } return S; } function i(s) { const { properties: m, title: d, required: f } = s; if (f && Array.isArray(f)) { const v = f.reduce((S, E) => (S[E] = m[E].type === "object" && m[E].properties ? o(m[E]) : vt(m[E].default), S), {}); if (d && f.find((S) => S === "id")) { const S = d.toLowerCase().replace(/-/g, "_"); v.id = `${S}_${Math.random().toString().slice(2, 6)}`; } return v; } return { type: d }; } function a(s, m = {}, d) { const f = n[s]; if (f) { let v = i(f); const S = e[s]; return v = S ? S({ getSchemaByType: a }, v, m, d) : v, t != null && t.appendIdentifyForNewControl && t.appendIdentifyForNewControl(v), v; } return null; } function r(s, m) { const d = o(m); return Object.keys(d).reduce((f, v) => (Object.prototype.hasOwnProperty.call(s, v) && (f[v] && _t(f[v]) && _t(s[v] || !s[v]) ? Object.assign(f[v], s[v] || {}) : f[v] = s[v]), f), d), d; } function u(s, m) { return Object.keys(s).filter((f) => s[f] != null).reduce((f, v) => { if (m.has(v)) { const S = m.get(v); if (typeof S == "string") f[S] = s[v]; else { const E = S(v, s[v], s); Object.assign(f, E); } } else f[v] = s[v]; return f; }, {}); } function l(s, m, d = /* @__PURE__ */ new Map()) { const f = r(s, m); return u(f, d); } function c(s) { var d; const m = s.type; if (m) { const f = n[m]; if (!f) return s; const v = r(s, f), S = ((d = s.editor) == null ? void 0 : d.type) || ""; if (S) { const E = n[S], F = r(s.editor, E); v.editor = F; } return v; } return s; } function p(s) { t = s; } return { getSchemaByType: a, resolveSchemaWithDefaultValue: c, resolveSchemaToProps: l, mappingSchemaToProps: u, setDesignerContext: p }; } const on = {}, rn = {}, { getSchemaByType: Ds, resolveSchemaWithDefaultValue: Fo, resolveSchemaToProps: Bo, mappingSchemaToProps: ko, setDesignerContext: Hs } = nn(on, rn); function Io(n = {}) { function e(c, p, s, m) { if (typeof s == "number") return m[c].length === s; if (typeof s == "object") { const d = Object.keys(s)[0], f = s[d]; if (d === "not") return Number(m[c].length) !== Number(f); if (d === "moreThan") return Number(m[c].length) >= Number(f); if (d === "lessThan") return Number(m[c].length) <= Number(f); } return !1; } function t(c, p, s, m) { return m[c] && m[c].propertyValue && String(m[c].propertyValue.value) === String(s); } const o = /* @__PURE__ */ new Map([ ["length", e], ["getProperty", t] ]); Object.keys(n).reduce((c, p) => (c.set(p, n[p]), c), o); function i(c, p) { const s = c; return typeof p == "number" ? [{ target: s, operator: "length", param: null, value: Number(p) }] : typeof p == "boolean" ? [{ target: s, operator: "getProperty", param: c, value: !!p }] : typeof p == "object" ? Object.keys(p).map((m) => { if (m === "length") return { target: s, operator: "length", param: null, value: p[m] }; const d = m, f = p[m]; return { target: s, operator: "getProperty", param: d, value: f }; }) : []; } function a(c) { return Object.keys(c).reduce((s, m) => { const d = i(m, c[m]); return s.push(...d), s; }, []); } function r(c, p) { if (o.has(c.operator)) { const s = o.get(c.operator); return s && s(c.target, c.param, c.value, p) || !1; } return !1; } function u(c, p) { return a(c).reduce((d, f) => d && r(f, p), !0); } function l(c, p) { const s = Object.keys(c), m = s.includes("allOf"), d = s.includes("anyOf"), f = m || d, E = (f ? c[f ? m ? "allOf" : "anyOf" : "allOf"] : [c]).map(($) => u($, p)); return m ? !E.includes(!1) : E.includes(!0); } return { parseValueSchema: l }; } const Po = { convertTo: (n, e, t, o) => { n.appearance || (n.appearance = {}), n.appearance[e] = t; }, convertFrom: (n, e, t) => n.appearance ? n.appearance[e] : n[e] }, Oo = { convertFrom: (n, e, t) => n.buttons && n.buttons.length ? `共 ${n.buttons.length} 项` : "无" }, Ro = { convertTo: (n, e, t, o) => { n.editor && (n.editor[e] = t); }, convertFrom: (n, e, t) => n.editor && Object.prototype.hasOwnProperty.call(n.editor, e) ? n.editor[e] : n[e] }, j = { button: { type: "button", name: "按钮" }, "response-toolbar": { type: "response-toolbar", name: "工具栏" }, "response-toolbar-item": { type: "response-toolbar-item", name: "按钮" }, "content-container": { type: "content-container", name: "容器" }, "input-group": { type: "input-group", name: "文本" }, textarea: { type: "textarea", name: "多行文本" }, lookup: { type: "lookup", name: "帮助" }, "number-spinner": { type: "number-spinner", name: "数值" }, "date-picker": { type: "date-picker", name: "日期" }, switch: { type: "switch", name: "开关" }, "radio-group": { type: "radio-group", name: "单选组" }, "check-box": { type: "check-box", name: "复选框" }, "check-group": { type: "check-group", name: "复选框组" }, "combo-list": { type: "combo-list", name: "下拉列表" }, "response-form": { type: "response-form", name: "卡片面板" }, "response-layout": { type: "response-layout", name: "布局容器", icon: "response-layout-3" }, "response-layout-item": { type: "response-layout-item", name: "布局", icon: "response-layout-1" }, "tree-grid": { type: "tree-grid", name: "树表格" }, "tree-grid-column": { type: "tree-grid-column", name: "树表格列" }, "data-grid": { type: "data-grid", name: "表格" }, "data-grid-column": { type: "data-grid-column", name: "表格列" }, module: { type: "Module", name: "模块" }, component: { type: "component", name: "组件" }, tabs: { type: "tabs", name: "标签页" }, "tab-page": { type: "tab-page", name: "标签页项", dependentParentControl: "Tab" }, "tab-toolbar-item": { type: "tab-toolbar-item", name: "标签页工具栏按钮" }, "html-template": { type: "html-template", name: "模板容器" }, "time-picker": { type: "time-picker", name: "时间选择" }, section: { type: "section", name: "分组面板" }, "section-toolbar": { type: "section-toolbar", name: "分组面板工具栏" }, "section-toolbar-item": { type: "section-toolbar-item", name: "分组面板按钮" }, splitter: { type: "splitter", name: "分栏面板" }, "splitter-pane": { type: "splitter-pane", name: "分栏面板项", dependentParentControl: "Splitter" }, "component-ref": { type: "component-ref", name: "组件引用节点" }, uploader: { type: "uploader", name: "附件上传" }, "page-header": { type: "page-header", name: "页头" }, "page-footer": { type: "page-footer", name: "页脚" }, "tab-toolbar": { type: "tab-toolbar", name: "标签页工具栏" }, fieldset: { type: "fieldset", name: "分组" }, "query-solution": { type: "query-solution", name: "筛选方案" }, drawer: { type: "drawer", name: "抽屉" }, "external-container": { type: "external-container", name: "外部容器", icon: "content-container" }, "list-nav": { type: "list-nav", name: "列表导航" }, "list-view": { type: "list-view", name: "列表" }, "filter-bar": { type: "filter-bar", name: "筛选条" }, "language-textbox": { type: "language-textbox", name: "多语输入框" } }, Vo = { convertFrom: (n, e, t) => { var i; const o = n.editor && n.editor[e] ? n.editor[e] : n[e]; return ((i = j[o]) == null ? void 0 : i.name) || o; } }, No = { convertTo: (n, e, t, o) => { n[e] = n[e]; }, convertFrom: (n, e, t) => n.editor ? t.getRealEditorType(n.editor.type) : "" }, jo = { convertTo: (n, e, t, o) => { (n.type === "data-grid-column" || n.type === "tree-grid-column") && (n.formatter ? n.formatter[e] = t : n.formatter = { [e]: t }); }, convertFrom: (n, e, t) => { if (n.formatter) { if (e === "trueText") return n.formatter.trueText; if (e === "falseText") return n.formatter.falseText; if (e === "prefix") return n.formatter.prefix; if (e === "suffix") return n.formatter.suffix; if (e === "precision") return n.formatter.precision; if (e === "decimal") return n.formatter.decimal; if (e === "thousand") return n.formatter.thousand; if (e === "tempDateFormat") return n.formatter.dateFormat === "yyyy年MM月dd日" ? "yearMonthDay" : n.formatter.dateFormat === "yyyy-MM-dd HH:mm:ss" ? "yyyy-MM-ddTHH:mm:ss" : n.formatter.dateFormat === "yyyy/MM/dd HH:mm:ss" ? "yyyy/MM/ddTHH:mm:ss" : n.formatter.dateFormat === "yyyy年MM月dd日 HH时mm分ss秒" ? "yearMonthDayHourMinuteSecond" : n.formatter.tempDateFormat || n.formatter.dateFormat || "yyyy-MM-dd"; if (e === "customFormat") return n.formatter.customFormat; if (e === "type") return n.formatter.type || "none"; } return "none"; } }, Do = { convertTo: (n, e, t, o) => { n.command ? n.command[e] = t : n.command = { [e]: t }, e === "enable" && t && (n.command.commands || (n.command.commands = [ { text: "编辑", type: "primary", command: "edit" }, { text: "删除", type: "danger", command: "remove" } ])); }, convertFrom: (n, e, t) => n.command && e === "enable" ? n.command.enable : "" }, Ho = { convertTo: (n, e, t, o) => { n.column ? n.column[e] = t : n.column = { [e]: t }, e === "fitColumns" && t && (n.column.fitMode || (n.column.fitMode = "average")); }, convertFrom: (n, e, t) => { if (n.column) { if (e === "fitColumns") return n.column.fitColumns; if (e === "fitMode") return n.column.fitMode; } return ""; } }, Lo = { convertTo: (n, e, t, o) => { n.summary ? n.summary[e] = t : n.summary = { [e]: t }, e === "enable" && t && (n.summary ? n.summary.groupFields || (n.summary.groupFields = []) : n.summary = { enable: t, groupFields: [] }); }, convertFrom: (n, e, t) => n.summary && e === "enable" ? n.summary.enable : n.type === "data-grid-column" ? n.enableSummary === void 0 ? !1 : n.enableSummary : "" }, $o = { convertTo: (n, e, t, o) => { n.group ? n.group[e] = t : n.group = { [e]: t }, e === "enable" && t && (n.group ? n.group.groupFields || (n.group.groupFields = []) : n.group = { enable: t, groupFields: [], showSummary: !1 }); }, convertFrom: (n, e, t) => { if (n.group) { if (e === "enable") return n.group.enable; if (e === "showSummary") return n.group.showSummary; } } }, zo = { convertFrom: (n, e) => n.binding ? n.binding.path : "", convertTo: (n, e, t) => { if (t && t.length > 0) { const o = t[0]; n.binding || (n.binding = {}), n.binding.type = "Form", n.binding.path = o.bindingField, n.binding.field = o.id, n.binding.fullPath = o.path, n.path = o.bindingPath; } } }, qo = { convertTo: (n, e, t, o) => { n.pagination || (n.pagination = {}), n.pagination[e] = t; }, convertFrom: (n, e, t) => n.pagination ? n.pagination[e] : n[e] }, Uo = { convertTo: (n, e, t, o) => { n.rowNumber || (n.rowNumber = {}), n.rowNumber[e] = t; }, convertFrom: (n, e, t) => n.rowNumber ? n.rowNumber[e] : n[e] }, Wo = { convertTo: (n, e, t, o) => { n.selection || (n.selection = {}), n.selection[e] = t; }, convertFrom: (n, e, t) => n.selection ? n.selection[e] : n[e] }, Go = { convertFrom: (n, e, t) => n[e] && n[e].length ? `共 ${n[e].length} 项` : "" }, Qo = { convertFrom: (n, e) => n[e] || "", convertTo: (n, e, t) => { n[e] = t; } }, _o = { convertTo: (n, e, t, o) => { n.size || (n.size = {}), n.size[e] = t; }, convertFrom: (n, e, t) => n.size ? n.size[e] : n[e] }, Xo = { convertFrom: (n, e, t) => { var o, i; return (o = n.formatter) != null && o.data && e === "formatterEnumData" && !n.formatterEnumData ? (i = n.formatter) == null ? void 0 : i.data : n.formatterEnumData; } }, Yo = { convertTo: (n, e, t, o) => { n.sort || (n.sort = {}), n.sort[e] = t; }, convertFrom: (n, e, t) => { var o, i; if (e === "mode") return ((o = n.sort) == null ? void 0 : o.mode) || "client"; if (e === "multiSort") return !!((i = n.sort) != null && i.multiSort); } }, Zo = { convertTo: (n, e, t, o) => { n.filter || (n.filter = {}), n.filter[e] = t; }, convertFrom: (n, e, t) => { var o; if (e === "mode") return ((o = n.filter) == null ? void 0 : o.mode) || "client"; } }, Jo = { convertTo: (n, e, t, o) => { n.rowOption ? n.rowOption[e] = t : n.rowOption = { [e]: t }; }, convertFrom: (n, e, t) => { if (n.rowOption) { if (e === "customRowStyle") return n.rowOption.customRowStyle; if (e === "customCellStyle") return n.rowOption.customCellStyle; } return ""; } }; function an(n, e, t) { const o = /* @__PURE__ */ new Map([ ["/converter/appearance.converter", Po], ["/converter/buttons.converter", Oo], ["/converter/property-editor.converter", Ro], ["/converter/items-count.converter", Go], ["/converter/type.converter", Vo], ["/converter/change-editor.converter", No], ["/converter/change-formatter.converter", jo], ["/converter/column-command.converter", Do], ["/converter/column-option.converter", Ho], ["/converter/summary.converter", Lo], ["/converter/group.converter", $o], ["/converter/form-group-label.converter", Qo], ["/converter/field-selector.converter", zo], ["/converter/pagination.converter", qo], ["/converter/row-number.converter", Uo], ["/converter/grid-selection.converter", Wo], ["/converter/size.converter", _o], ["/converter/change-formatter-enum.converter", Xo], ["/converter/grid-sort.converter", Yo], ["/converter/grid-filter.converter", Zo], ["/converter/row-option.converter", Jo] ]), i = /* @__PURE__ */ new Map([ ["string", { type: "input-group", enableClear: !1 }], ["boolean", { type: "combo-list", textField: "name", valueField: "value", idField: "value", enableClear: !1, editable: !1, data: [ { value: !0, name: "是" }, { value: !1, name: "否" } ] }], ["enum", { type: "combo-list", maxHeight: 128, enableClear: !1, editable: !1 }], ["array", { type: "button-edit" }], ["number", { type: "number-spinner", placeholder: "" }], ["events-editor", { type: "events-editor", hide: !0 }] ]), a = Io(); function r(f, v) { return () => a.parseValueSchema(f, v); } function u(f, v, S) { return f.includes("visible") && v.visible !== void 0 ? typeof v.visible == "boolean" ? () => !!v.visible : v.visible === void 0 ? !0 : r(v.visible, S) : () => !0; } function l(f, v, S) { return f.includes("readonly") && v.readonly !== void 0 ? typeof v.readonly == "boolean" ? () => !!v.readonly : r(v.readonly, S) : () => !1; } function c(f, v) { const S = f.$converter || v; return typeof S == "string" && S && o.has(S) ? o.get(S) || null : S || null; } function p(f, v, S, E, F, $ = "", x = "") { return Object.keys(f).map((h) => { const M = C(1), T = h, A = f[h], I = Object.keys(A), w = A.title, B = A.type, O = i.get(B) || { type: "input-group", enableClear: !1 }, R = A.editor ? Object.assign({}, O, A.editor) : Object.assign({}, O), D = u(I, A, v), G = l(I, A, v); R.readonly = R.readonly === void 0 ? G() : R.readonly; const ee = A.type === "cascade" ? p(A.properties, v, S, E, F, $, x) : [], V = !0; let P = c(A, x); const Q = L({ get() { if (M.value) { if (["class", "style"].find((le) => le === T) && !P && (P = o.get("/converter/appearance.converter") || null), P && P.convertFrom) return P.convertFrom(S, h, F, $); const ie = S[h]; return Object.prototype.hasOwnProperty.call(A, "defaultValue") && (ie === void 0 || typeof ie == "string" && ie === "") ? A.type === "boolean" ? A.defaultValue : A.defaultValue || "" : ie; } return null; }, set(ie) { M.value += 1, P && P.convertTo ? (P.convertTo(E, h, ie, F, $), P.convertTo(S, h, ie, F, $)) : (E[h] = ie, S[h] = ie); } }), { refreshPanelAfterChanged: z, description: te, isExpand: ve, parentPropertyID: ge } = A, Y = { propertyID: T, propertyName: w, propertyType: B, propertyValue: Q, editor: R, visible: D, readonly: G, cascadeConfig: ee, hideCascadeTitle: V, refreshPanelAfterChanged: z, description: te, isExpand: ve, parentPropertyID: ge }; return v[T] = Y, Y; }); } function s(f, v, S = {}) { const E = {}, F = n[f]; return F && F.categories ? Object.keys(F.categories).map((x) => { const g = F.categories[x], h = g == null ? void 0 : g.title, M = p(g.properties || {}, E, {}, S, v); return { categoryId: x, categoryName: h, properties: M }; }) : []; } function m(f, v, S, E, F = "") { const $ = v.$ref.schema, x = v.$ref.converter, g = S[$], h = g.type, M = t(g), T = {}, A = n[h]; if (A && A.categories) { const I = A.categories[f], w = I == null ? void 0 : I.title; x && Object.keys(I.properties).forEach((R) => { I.properties[R].$converter = x; }); const B = (I == null ? void 0 : I.properties) || {}, O = p(B, T, M, g, E, F); return { categoryId: f, categoryName: w, properties: O }; } return { categoryId: f, categoryName: "", properties: [] }; } function d(f, v, S, E, F) { const $ = f.type, x = t(f), g = {}; let h = F || n[$]; if (h && Object.keys(h).length === 0 && S && S.getPropConfig && (h = S.getPropConfig(E)), h && h.categories) { const M = []; return Object.keys(h.categories).map((T) => { const A = h.categories[T]; if (A.$ref) { M.push(m(T, A, f, v, E)); return; } const I = A == null ? void 0 : A.title, w = A == null ? void 0 : A.tabId, B = A == null ? void 0 : A.tabName, O = A == null ? void 0 : A.hide, R = A == null ? void 0 : A.hideTitle, D = p(A.properties || {}, g, x, f, v, E, A.$converter), { setPropertyRelates: G } = A, ee = A == null ? void 0 : A.parentPropertyID; M.push({ categoryId: T, categoryName: I, tabId: w, tabName: B, hide: O, properties: D, hideTitle: R, setPropertyRelates: G, parentPropertyID: ee }); }), M; } return []; } return { getPropertyConfigBySchema: d, getPropertyConfigByType: s, propertyConverterMap: o }; } const sn = {}, ln = {}; an(sn, ln, Fo); const cn = {}, un = {}, { getSchemaByType: Ls, resolveSchemaWithDefaultValue: Ko, resolveSchemaToProps: $s, mappingSchemaToProps: zs, setDesignerContext: qs } = nn(cn, un), dn = {}, fn = {}; an(dn, fn, Ko); function st(n, e, t = /* @__PURE__ */ new Map(), o = (r, u, l, c) => u, i = {}, a = (r) => r) { return on[e.title] = e, rn[e.title] = o, sn[e.title] = i, ln[e.title] = a, cn[e.title] = e, un[e.title] = o, dn[e.title] = i, fn[e.title] = a, (r = {}, u = !0) => { if (!u) return ko(r, t); const l = Bo(r, e, t), c = Object.keys(n).reduce((p, s) => (p[s] = n[s].default, p), {}); return Object.assign(c, l); }; } function ei(n, e, t) { return e; } const ti = /* @__PURE__ */ new Map([ ["appearance", Kt] ]), ni = "https://json-schema.org/draft/2020-12/schema", oi = "https://farris-design.gitee.io/avatar.schema.json", ii = "avatar", ri = "A Farris Component", ai = "object", si = { id: { description: "The unique identifier for avatar", type: "string" }, type: { description: "The type string of avatar", type: "string", default: "avatar" }, appearance: { description: "", type: "object", properties: { class: { type: "string" }, style: { type: "string" } }, default: {} }, binding: { description: "", type: "object", default: {} }, disabled: { type: "boolean", default: !1 }, avatarWidth: { description: "", type: "number", default: 100 }, avatarHeight: { description: "", type: "number", default: 100 }, readonly: { description: "", type: "boolean", default: !1 }, cover: { description: "", type: "string", default: "" }, tabindex: { description: "", type: "number", default: -1 }, visible: { description: "", type: "boolean", default: !0 } }, li = [ "id", "type" ], ci = [ "id", "appearance", "binding", "visible" ], ui = { $schema: ni, $id: oi, title: ii, description: ri, type: ai, properties: si, required: li, ignore: ci }, $t = { /** * 头像宽度 */ avatarWidth: { type: Number, default: 100 }, /** * 头像高度 */ avatarHeight: { type: Number, default: 100 }, /** * 组件标识 */ cover: { type: String }, /** * 只读 */ readonly: { type: Boolean, default: !1 }, /** * 头像形状 */ shape: { type: String, default: "circle" }, /** * 头像最大尺寸, 单位MB */ maxSize: { type: Number, default: 1 }, /** * 组件值 */ modelValue: { type: String, default: "" }, /** * 头像标题 */ title: { type: String, default: "" }, /** * 支持的头像类型 */ imageType: { type: Array, default: ["jpeg"] } }, pn = st($t, ui, ti, ei); function mn(n, e, t, o) { const i = "", a = C(n.readonly); function r(d) { return d.match(/\.(jpeg|jpg|gif|png|svg|bmp|webp)$/) != null; } function u(d) { return d.indexOf("data:image/") > -1; } function l(d) { return d ? "data:image/jpeg;base64," + d : ""; } const c = L(() => { var f; if (!n.imageType || !n.imageType.length) return ""; const d = (f = n.imageType) == null ? void 0 : f.map((v) => (v === "jpg" && (v = "jpeg"), `image/${v}`)); return !d || !d.length ? "image/*" : d.join(","); }), p = L(() => { const d = o.value || n.cover || i; return r(d) || u(d) ? d : l(d); }), s = L(() => a.value ? "" : n.title); function m() { a.value || t && t.value && t.value.click(); } return { acceptTypes: c, imageSource: p, imageTitle: s, onClickImage: m }; } const ht = /* @__PURE__ */ Be({ name: "FAvatar", props: $t, emits: ["change", "update:modelValue"], setup(n, e) { St(); const t = L(() => ({ "f-avatar": !0, "f-avatar-readonly": n.readonly, "f-avatar-circle": n.shape === "circle", "f-avatar-square": n.shape === "square" })), o = C(n.modelValue), i = L(() => ({ width: n.avatarWidth + "px", height: n.avatarHeight + "px" })), a = !1; function r() { return ""; } function u() { } const l = C(null), { acceptTypes: c, imageSource: p, onClickImage: s } = mn(n, e, l, o); return () => b("div", { class: t.value, style: i.value, onClick: s }, [a, b("img", { title: n.title, class: "f-avatar-image", src: p.value, onError: r }, null), !n.readonly && b("div", { class: "f-avatar-icon" }, [b("span", { class: "f-icon f-icon-camera" }, null)]), b("input", { ref: "file", name: "file-input", type: "file", class: "f-avatar-upload", accept: c.value, onChange: u, style: "display: none;" }, null)]); } }), di = C(0); function fi() { di.value++; } const dt = C(0); function pi(n) { const { formSchemaUtils: e, formStateMachineUtils: t } = n; function o(l, c = "") { return { path: c + l.code, field: l.id, fullPath: l.code }; } function i(l, c = "") { return e.getViewModelById(l).states.map((s) => o(s, c)); } function a(l) { const c = e.getRootViewModelId(), p = i(l); if (l === c) return p; const s = i(c, "root-component."); return [...p, ...s]; } function r(l) { return l.binding && l.binding.path || l.id || ""; } function u() { return t && t.getRenderStates() || []; } return { getVariables: a, getControlName: r, getStateMachines: u }; } class vn { constructor(e) { _(this, "sessionVariables", [ { key: "CurrentSysOrgName", name: "当前组织Name", description: "当前组织Name" }, // { // key: "CurrentSysOrgCode", // name: "当前组织Code", // description: "当前组织Code" // }, { key: "CurrentSysOrgId", name: "当前组织Id", description: "当前组织Id" }, { key: "CurrentUserName", name: "当前用户Name", description: "当前用户Name" }, { key: "CurrentUserCode", name: "当前用户Code", description: "当前用户Code" }, { key: "CurrentUserId", name: "当前用户Id", description: "当前用户Id" }, { key: "CurrentLanguage", name: "当前语言编号", description: "当前登录的语言编号,例如简体中文返回'zh-CHS',英文返回'en',繁体中文'zh-CHT'" } ]); _(this, "expressionNames", { compute: "计算表达式", dependency: "依赖表达式", validate: "验证表达式", dataPicking: "帮助前表达式", visible: "可见表达式", readonly: "只读表达式", required: "必填表达式" }); _(this, "getExpressionConverter", (e, t) => ({ convertFrom: (o, i, a, r) => { const u = a.getExpressionRuleValue(e, t || i); return u && u.value || ""; }, convertTo: (o, i, a, r, u) => { var l; if (i === "dataPicking" && (a != null && a.target)) { const c = `${a.target}_dataPicking`; ((l = a.rules) == null ? void 0 : l.some( (s) => s.id === c && s.value )) ? o.dictPickingExpressionId = c : delete o.dictPickingExpressionId; } r.updateExpression(a); } })); this.formSchemaService = e; } getExpressionRule(e, t) { const o = this.formSchemaService.getExpressions(); if (!o) return ""; const i = o.find((r) => r.target === e); if (!i) return ""; const a = i.rules.find((r) => r.type === t); return a || ""; } // 获取上下文表单变量 getContextFormVariables() { const { module: e } = this.formSchemaService.getFormSchema(); if (!e.viewmodels || e.viewmodels.length === 0) return []; const t = this.formSchemaService.getRootViewModelId(), o = this.formSchemaService.getViewModelById(t); if (!o || !o.states || o.states.length === 0) return []; const i = []; return o.states.forEach((a) => { i.push({ key: a.code, name: a.name, description: a.name, category: a.category }); }), i; } createTreeNode(e, t, o = "label") { return { id: e.id, name: e.name, bindingPath: e[o], parents: t, type: "field" }; } buildEntityFieldsTreeData(e = null, t) { const o = []; return e == null || e.forEach((i) => { var u; const a = this.createTreeNode(i, t); let r = []; (u = i.type) != null && u.fields && (r = this.buildEntityFieldsTreeData(i.type.fields, [...t, i.label])), o.push({ data: a, children: r, expanded: !0 }); }), o; } buildChildEntityTreeData(e = null, t) { const o = []; return e == null || e.forEach((i) => { var l, c; const a = this.createTreeNode(i, t); a.type = "entity"; const r = this.buildEntityFieldsTreeData((l = i.type) == null ? void 0 : l.fields, [...t, i.label]), u = this.buildChildEntityTreeData((c = i.type) == null ? void 0 : c.entities, [...t, i.label]); u != null && u.length && (r == null || r.push(...u)), o.push({ data: a, children: r || [], // 空值回退 expanded: !0 }); }), o; } getEntitiesTreeData() { const e = this.formSchemaService.getSchemaEntities(); if (!(e != null && e.length)) return []; const t = e[0]; if (!(t != null && t.type)) return []; const o = this.buildEntityFieldsTreeData(t.type.fields, [t.code]), i = this.buildChildEntityTreeData(t.type.entities, [t.code]); return i != null && i.length && (o == null || o.push(...i)), { entityCode: t.code, fields: [{ data: this.createTreeNode(t, [], "code"), children: o || [] }] }; } getEntitiesAndVariables() { return { entities: this.getEntitiesTreeData(), variables: { session: { name: "系统变量", items: this.sessionVariables, visible: !1 }, forms: { name: "表单变量", items: this.getContextFormVariables(), visible: !0 } } }; } onBeforeOpenExpression(e, t, o) { const i = o === "Field" ? e.binding.field : e.id, a = this.getExpressionRule(i, t), r = this.getEntitiesAndVariables(), u = { message: ["validate", "required", "dataPicking"].includes(t) && a ? a.message : "", ...r }; return a.messageType != null && (u.messageType = a.messageType), u; } buildRule(e, t, o, i) { const { expression: a, message: r, messageType: u } = t, l = { id: `${e}_${o}`, type: o, value: a }; return (o === "validate" || o === "dataPicking" || o === "required") && (l.message = r), o === "dataPicking" && (l.messageType = u), o === "validate" && i && (l.elementId = i), l; } getExpressionData() { const { expressions: e } = this.formSchemaService.getFormSchema().module; return e || []; } updateExpression(e, t, o, i) { const a = t === "Field" ? e.binding.field : e.id, r = this.buildRule(a, o, i, e.type === "form-group" ? e.id : ""); let l = this.getExpressionData().find((p) => p.targetType === t && p.target === a); const c = (p) => p.value.trim() === ""; if (l) { const p = l.rules.find((s) => s.id === r.id); if (p) c(r) ? l.rules = l.rules.filter((s) => s.id !== r.id) : (Object.assign(p, r), i === "validate" && e.type === "form-group" && (p.elementId = e.id)); else { if (c(r)) return null; l.rules = l.rules || [], l.rules.push(r); } } else { if (c(r)) return null; l = { target: `${a}`, rules: [r], targetType: t }; } return l; } getExpressionEditorOptions(e, t, o, i) { return o.reduce((a, r) => { var l, c; const u = t === "Field" ? (l = e == null ? void 0 : e.binding) == null ? void 0 : l.field : e.id; return a[r] = { hide: t === "Field" ? !!((c = e == null ? void 0 : e.binding) != null && c.field) : !1, description: "", title: this.expressionNames[r], type: "string", $converter: this.getExpressionConverter(u), refreshPanelAfterChanged: !0, editor: { type: "expression-editor", singleExpand: !1, dialogTitle: `${this.expressionNames[r]}编辑器`, showMessage: r === "validate" || r === "dataPicking" || r === "required", showMessageType: r === "dataPicking", beforeOpen: () => this.onBeforeOpenExpression(e, r, t), onSubmitModal: (p) => { const s = this.updateExpression(e, t, p, r); if (i) { const m = this.buildRule(u, p, r); i(m); } return s; } } }, a; }, {}); } getExpressionInfo(e, t, o) { const i = t === "Field" ? e.binding.field : e.id, a = this.getExpressionRule(i, o), r = { value: a && a.value, targetId: i, targetType: t, expressionType: o }; return a && a.message && (r.message = a.message), r; } getExpressionConfig(e, t, o = ["compute", "dependency", "validate"], i) { return { description: "表达式", title: "表达式", hide: !e.binding, properties: { ...this.getExpressionEditorOptions(e, t, o, i) } }; } getExpressionOptions(e, t, o) { const i = this.getExpressionInfo(e, t, o); return { dialogTitle: `${this.expressionNames[o]}编辑器`, singleExpand: !1, showMessage: o === "required", beforeOpen: () => this.onBeforeOpenExpression(e, o, t), expressionInfo: i }; } } class mi { constructor(e, t) { _(this, "componentId"); _(this, "viewModelId"); _(this, "eventsEditorUtils"); _(this, "formSchemaUtils"); _(this, "formMetadataConverter"); _(this, "designViewModelUtils"); _(this, "designViewModelField"); _(this, "controlCreatorUtils"); _(this, "designerHostService"); _(this, "designerContext"); _(this, "schemaService", null); _(this, "metadataService", null); _(this, "propertyConfig", { type: "object", categories: {} }); var o; this.componentId = e, this.designerHostService = t, this.eventsEditorUtils = t.eventsEditorUtils, this.formSchemaUtils = t.formSchemaUtils, this.formMetadataConverter = t.formMetadataConverter, this.viewModelId = ((o = this.formSchemaUtils) == null ? void 0 : o.getViewModelIdByComponentId(e)) || "", this.designViewModelUtils = t.designViewModelUtils, this.controlCreatorUtils = t.controlCreatorUtils, this.metadataService = t.metadataService, this.schemaService = t.schemaService, this.designerContext = t.designerContext; } getFormDesignerInstance() { var e, t; return (t = (e = this.designerContext) == null ? void 0 : e.instances) == null ? void 0 : t.formDesigner.value; } getTableInfo() { var e; return (e = this.schemaService) == null ? void 0 : e.getTableInfoByViewModelId(this.viewModelId); } setDesignViewModelField(e) { var o; const t = e.binding && e.binding.type === "Form" && e.binding.field; if (t) { if (!this.designViewModelField) { const i = this.designViewModelUtils.getDgViewModel(this.viewModelId); this.designViewModelField = i.fields.find((a) => a.id === t); } e.updateOn = (o = this.designViewModelField) == null ? void 0 : o.updateOn; } } getBasicPropConfig(e) { return { description: "Basic Information", title: "基本信息", properties: { id: { description: "组件标识", title: "标识", type: "string", readonly: !0 }, type: { description: "组件类型", title: "控件类型", type: "select", editor: { type: "combo-list", textField: "name", valueField: "value", idField: "value", editable: !1, data: [{ value: e.type, name: j[e.type] && j[e.type].name }] } } } }; } getAppearanceConfig(e = null, t = {}, o) { const i = { title: "外观", description: "Appearance" }, a = { class: { title: "class样式", type: "string", description: "组件的CSS样式", $converter: "/converter/appearance.converter", parentPropertyID: "appearance" }, style: { title: "style样式", type: "string", description: "组件的样式", $converter: "/converter/appearance.converter", parentPropertyID: "appearance" } }; for (const r in t) a[r] = Object.assign(a[r] || {}, t[r]); return { ...i, properties: { ...a }, setPropertyRelates(r, u) { if (r) { switch (r && r.propertyID) { case "class": case "style": { dt.value++; break; } } o && o(r, e, u); } } }; } getPropertyEditorParams(e, t = [], o = "visible", i = {}, a = {}) { const { getVariables: r, getControlName: u, getStateMachines: l } = pi(this.designerHostService), c = this.getRealTargetType(e), p = t && t.length > 0 ? t : ["Const", "Variable", "StateMachine", "Expression"], s = { type: "property-editor", propertyTypes: p }; return p.map((m) => { switch (m) { case "Const": Object.assign(s, { constType: "enum", constEnums: [{ id: !0, name: "是" }, { id: !1, name: "否" }] }, i); break; case "Expression": s.expressionConfig = this.getExpressionOptions(e, c, o); break; case "StateMachine": s.stateMachines = l(); break; case "Variable": Object.assign(s, { controlName: u(e), newVariablePrefix: "is", newVariableType: "Boolean", variables: r(this.viewModelId), onBeforeOpenVariables: (d) => { d.value = r(this.viewModelId); } }, a); break; } }), s; } getVisibleProperty(e, t = "") { var a; let o = ["Const", "Variable", "StateMachine", "Expression"]; return t === "gridFieldEditor" ? o = ["Const", "Expression"] : t === "form-group" && !((a = e.binding) != null && a.field) && (o = ["Const", "Variable", "StateMachine"]), { visible: { title: "是否可见", type: "boolean", description: "运行时组件是否可见", editor: this.getPropertyEditorParams(e, o, "visible") } }; } /** * 获取行为 * @param propertyData * @param viewModelId * @returns */ getBehaviorConfig(e, t = "", o = {}, i) { const a = { title: "行为", description: "" }, r = this.getVisibleProperty(e, t); for (const l in o) r[l] = Object.assign(r[l] || {}, o[l]); const u = this; return { ...a, properties: { ...r }, setPropertyRelates(l, c) { if (l) { switch (l.propertyID) { case "disabled": case "readonly": case "visible": u.afterMutilEditorChanged(e, l); break; } i && i(l, c); } } }; } /** * 当多值编辑器变更时 * @param propertyData * @param changeObject */ afterMutilEditorChanged(e, t) { this.addNewVariableToViewModel(t, this.viewModelId), this.updateExpressionValue(t), this.clearExpression(t, e); } /** * * @param propertyId * @param componentInstance * @returns */ updateElementByParentContainer(e, t) { const o = t && t.parent && t.parent.schema; if (!o) return; const i = o.contents.findIndex((r) => r.id === e), a = vt(o.contents[i]); o.contents.splice(i, 1), o.contents.splice(i, 0, a), fi(); } /** * 属性编辑器,在编辑过程中会新增变量,此处需要将新增的变量追加到ViewModel中 * @param changeObject * @param viewModelId * @returns */ addNewVariableToViewModel(e, t) { const o = e.propertyValue; if (!(o && typeof o == "object") || !(o.type === "Variable" && o.isNewVariable)) return; const r = { id: o.field, category: "locale", code: o.fullPath, name: o.fullPath, type: o.newVariableType || "String" }; delete o.newVariableType, delete o.isNewVariable, this.formSchemaUtils.getVariableByCode(r.code) || this.formSchemaUtils.getViewModelById(t).states.push(r); } /** * 更新表达式到expressions节点 * @param changeObject */ updateExpressionValue(e) { const t = e.propertyValue; if (!((t && t.type) === "Expression" && t.expressionInfo)) return; const { expressionId: a, expressionInfo: r } = t, { targetId: u, targetType: l, expressionType: c, value: p, message: s } = r, m = this.formSchemaUtils.getModule(); m.expressions = m.expressions || []; const { expressions: d } = m; let f = d.find((S) => S.target === u); f || (f = { target: u, rules: [], targetType: l }, d.push(f)); const v = f.rules.find((S) => S.type === c); if (v) v.value = p, v.message = s; else { const S = { id: a, type: c, value: p, message: s }; f.rules.push(S); } delete t.expressionInfo; } /** * 属性类型切换为非表达式后,清除原表达式 * @param changeObject * @param propertyData * @returns */ clearExpression(e, t) { const o = e.propertyValue; if (o && o.type === "Expression") return; const a = e.propertyID, r = this.formSchemaUtils.getExpressions(), u = t.binding ? t.binding.field : t.id, l = r.find((c) => c.target === u); !l || !l.rules || (l.rules = l.rules.filter((c) => c.type !== a)); } getExpressionOptions(e, t, o) { return new vn(this.formSchemaUtils).getExpressionOptions(e, t, o); } getRealTargetType(e) { return ["response-toolbar-item", "tab-toolbar-item", "section-toolbar-item"].indexOf(e.type) > -1 ? "Button" : e.binding && e.binding.field ? "Field" : "Container"; } createBaseEventProperty(e) { const t = {}; return t[this.viewModelId] = { type: "events-editor", editor: { initialData: e, viewSourceHandle: (o) => { var i; ((i = o.controller) == null ? void 0 : i.label.indexOf(this.formSchemaUtils.getModule().code)) > -1 && this.eventsEditorUtils.jumpToMethod(o); } } }, t; } } const Ye = class Ye { /** * 根据绑定字段类型获取可用的输入类控件 */ static getEditorTypesByMDataType(e, t = !1, o = "") { if (t) return [{ key: j["language-textbox"].type, value: j["language-textbox"].name }]; let i = Ye.fieldControlTypeMapping[e]; if (o === "data-grid-column" && (i != null && i.lengt