@farris/ui-vue
Version:
Farris Vue, a Farris Design based Vue3 component library.
2 lines (1 loc) • 24.4 kB
JavaScript
(function(p,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("vue"),require("../dynamic-resolver/index.umd.js"),require("../response-toolbar/index.umd.js"),require("../common/index.umd.js"),require("../../designer/response-toolbar/index.umd.js"),require("../designer-canvas/index.umd.js"),require("lodash-es")):typeof define=="function"&&define.amd?define(["exports","vue","../dynamic-resolver/index.umd.js","../response-toolbar/index.umd.js","../common/index.umd.js","../../designer/response-toolbar/index.umd.js","../designer-canvas/index.umd.js","lodash-es"],r):(p=typeof globalThis<"u"?globalThis:p||self,r(p["page-header"]={},p.Vue,p.dynamicResolver,p.FResponseToolbar,p.common,p.FResponseToolbarDesignComponent,p.designerCanvas,p.LodashES))})(this,function(p,r,b,D,x,k,P,q){"use strict";var Z=Object.defineProperty;var ee=(p,r,b)=>r in p?Z(p,r,{enumerable:!0,configurable:!0,writable:!0,value:b}):p[r]=b;var h=(p,r,b)=>ee(p,typeof r!="symbol"?r+"":r,b);const I=new Map([["appearance",b.resolveAppearance],["toolbar",b.resolveToolbar]]),S={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/page-header.schema.json",title:"page-header",description:"A Farris Container Component",type:"object",properties:{id:{description:"The unique identifier for a Page Header",type:"string"},type:{description:"The type string of Page Header component",type:"string",default:"page-header"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},showIcon:{description:"",type:"boolean",default:!0},icon:{description:"",type:"string",default:"f-icon-page-title-record"},iconClass:{description:"",type:"string",default:"f-text-orna-bill"},title:{description:"",type:"string",default:""},subTitle:{description:"",type:"string",default:""},toolbar:{description:"",type:"object",properties:{appearance:{description:"",type:"object",properties:{class:{type:"string",default:"col-6"}}},id:{description:"",type:"string"},type:{description:"",type:"string",default:"response-toolbar"},alignment:{description:"The alignment of Response Toolbar Button.",type:"string",default:"right"},buttons:{description:"The items of Response Toolbar.",type:"array",default:[]},visible:{description:"",type:"boolean",default:!0}}},titleContentClass:{description:"",type:"string",default:""},contentClass:{description:"",type:"string",default:""},downContentClass:{description:"",type:"string",default:""},showPagination:{description:"",type:"boolean",default:!1},prePaginationDisabled:{description:"",type:"boolean",default:!0},nextPaginationDisabled:{description:"",type:"boolean",default:!1},visible:{description:"",type:"boolean",default:!0},titleContentHtml:{description:"",type:"string",default:""},titleRenderFunction:{description:"",type:"function",default:null},contentHtml:{description:"",type:"string",default:""},contentRenderFunction:{description:"",type:"function",default:null},downContentHtml:{description:"",type:"string",default:""},downContentRenderFunction:{description:"",type:"function",default:null}},required:["id","type"]};function M(l,e,t){return e.title="标题",e}const E={customClass:{type:String,default:""},showIcon:{type:Boolean,default:!0},icon:{type:String,default:"f-icon-page-title-record"},iconClass:{type:String,default:"f-text-orna-bill"},title:{type:String,default:""},subTitle:{type:String,default:""},buttonClass:{type:String,default:"col-6"},toolbarId:{type:String,default:""},buttons:{type:Array,default:[]},titleContentClass:{type:String,default:""},contentClass:{type:String,default:""},downContentClass:{type:String,default:""},showPagination:{type:Boolean,default:!1},prePaginationDisabled:{type:Boolean,default:!0},nextPaginationDisabled:{type:Boolean,default:!1},visible:{type:Boolean,default:!0},buttonsVisible:{type:Boolean,default:!0},titleRenderFunction:{type:Function},contentRenderFunction:{type:Function},downContentRenderFunction:{type:Function}},R=Object.assign({},E,{componentId:{type:String,default:""},titleContentHtml:{type:String,default:""},contentHtml:{type:String,default:""},downContentHtml:{type:String,default:""}}),$=b.createPropsResolver(E,S,I,M),G=b.createPropsResolver(R,S,I,M),B=b.createPageHeaderEventHandlerResolver(),U=b.getPropsResolverGenerator(E,S,I,M),O=b.getPropsResolverGenerator(R,S,I,M),T=r.defineComponent({name:"FPageHeader",props:E,emits:["click","prePaginationClick","nextPaginationClick"],setup(l,e){const t=r.ref(l.buttons),n=(f,j)=>{e.emit("click",f,j)},i=r.computed(()=>{const f={"f-page-header":!0,"d-none":!l.visible};return x.getCustomClass(f,l.customClass)}),o=r.computed(()=>{const f={"f-title-icon":!0};return x.getCustomClass(f,l.iconClass)}),s=r.computed(()=>{const f={"f-icon":!0};return x.getCustomClass(f,l.icon)}),d=r.computed(()=>{const f={"f-title":!0};return x.getCustomClass(f,l.titleContentClass)}),a=r.computed(()=>{const f={"f-content":!0};return x.getCustomClass(f,l.contentClass)}),c=r.computed(()=>{const f={"f-page-header-extend":!0};return x.getCustomClass(f,l.downContentClass)}),u=r.computed(()=>({"f-icon f-icon-arrow-w":!0,"f-state-disabled":l.prePaginationDisabled})),g=r.computed(()=>({"f-icon f-icon-arrow-e":!0,"f-state-disabled":l.nextPaginationDisabled}));function C(f){l.prePaginationDisabled||e.emit("prePaginationClick",f)}function v(f){l.nextPaginationDisabled||e.emit("nextPaginationClick",f)}function y(){return e.slots.titleContent?r.createVNode("div",{class:d.value},[r.createTextVNode(" "),e.slots.titleContent()]):l.titleRenderFunction?r.createVNode("div",{class:d.value},[l.titleRenderFunction()]):r.createVNode("div",{class:"f-title"},[l.showIcon&&l.icon?r.createVNode("span",{class:o.value},[r.createVNode("i",{class:s.value},null)]):"",r.createVNode("h4",{class:"f-title-text"},[l.title]),l.subTitle?r.createVNode("h5",{class:"f-title-subtitle"},[l.subTitle]):"",l.showPagination?r.createVNode("div",{class:"f-title-pagination"},[r.createVNode("span",{class:u.value,onClick:C},null),r.createVNode("span",{class:g.value,onClick:v},null)]):""])}function w(){return e.slots.content?r.createVNode("div",{class:a.value},[r.createTextVNode(" "),e.slots.content()]):l.contentRenderFunction?r.createVNode("div",{class:a.value},[l.contentRenderFunction()]):null}function V(){if(l.buttons&&l.buttons.length>0)return r.createVNode(D,{id:l.toolbarId,customClass:l.buttonClass,visible:l.buttonsVisible,items:t.value,onClick:n},null)}function H(){return e.slots.downContent?r.createVNode("div",{class:c.value},[r.createTextVNode(" "),e.slots.downContent()]):l.downContentRenderFunction?r.createVNode("div",{class:c.value},[l.downContentRenderFunction()]):null}return r.watch(()=>l.buttons,f=>{t.value=f},{deep:!0}),()=>l.visible?r.createVNode("div",{class:i.value},[r.createVNode("nav",{class:"f-page-header-base"},[y(),w(),V()]),H()]):null}});function L(l){const{formSchemaUtils:e,formStateMachineUtils:t}=l;function n(a,c=""){return{path:c+a.code,field:a.id,fullPath:a.code}}function i(a,c=""){const u=e.getViewModelById(a);return u?u.states.map(g=>n(g,c)):[]}function o(a){const c=e.getRootViewModelId(),u=i(a);if(a===c)return u;const g=i(c,"root-component.");return[...u,...g]}function s(a){return a.binding&&a.binding.path||a.id||""}function d(){return t&&t.getRenderStates()||[]}return{getVariables:o,getControlName:s,getStateMachines:d}}class _{constructor(e){h(this,"sessionVariables",[{key:"CurrentSysOrgName",name:"当前组织Name",description:"当前组织Name"},{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'"}]);h(this,"expressionNames",{compute:"计算表达式",dependency:"依赖表达式",validate:"验证表达式",dataPicking:"帮助前表达式",visible:"可见表达式",readonly:"只读表达式",required:"必填表达式"});h(this,"getExpressionConverter",(e,t)=>({convertFrom:(n,i,o,s)=>{const d=o.getExpressionRuleValue(e,t||i);return d&&d.value||""},convertTo:(n,i,o,s,d)=>{var a;if(i==="dataPicking"&&(o!=null&&o.target)){const c=`${o.target}_dataPicking`;((a=o.rules)==null?void 0:a.some(g=>g.id===c&&g.value))?n.dictPickingExpressionId=c:delete n.dictPickingExpressionId}s.updateExpression(o)}}));this.formSchemaService=e}getExpressionRule(e,t){const n=this.getExpressionData();if(!n)return"";const i=n.find(s=>s.target===e);if(!i)return"";const o=i.rules.find(s=>s.type===t);return o||""}getContextFormVariables(){const{module:e}=this.formSchemaService.getFormSchema();if(!e.viewmodels||e.viewmodels.length===0)return[];const t=this.formSchemaService.getRootViewModelId(),n=this.formSchemaService.getViewModelById(t);if(!n||!n.states||n.states.length===0)return[];const i=[];return n.states.filter(o=>o.category==="remote").forEach(o=>{i.push({key:o.code,name:o.name,description:o.name,category:o.category})}),i}createTreeNode(e,t,n="label"){return{id:e.id,name:e.name,bindingPath:e[n],parents:t,type:"field"}}buildEntityFieldsTreeData(e=null,t){const n=[];return e==null||e.forEach(i=>{var d;const o=this.createTreeNode(i,t);let s=[];(d=i.type)!=null&&d.fields&&(s=this.buildEntityFieldsTreeData(i.type.fields,[...t,i.label])),n.push({data:o,children:s,expanded:!0})}),n}buildChildEntityTreeData(e=null,t){const n=[];return e==null||e.forEach(i=>{var a,c;const o=this.createTreeNode(i,t);o.type="entity";const s=this.buildEntityFieldsTreeData((a=i.type)==null?void 0:a.fields,[...t,i.label]),d=this.buildChildEntityTreeData((c=i.type)==null?void 0:c.entities,[...t,i.label]);d!=null&&d.length&&(s==null||s.push(...d)),n.push({data:o,children:s||[],expanded:!0})}),n}getEntitiesTreeData(){const e=this.formSchemaService.getSchemaEntities();if(!(e!=null&&e.length))return[];const t=e[0];if(!(t!=null&&t.type))return[];const n=this.buildEntityFieldsTreeData(t.type.fields,[t.code]),i=this.buildChildEntityTreeData(t.type.entities,[t.code]);return i!=null&&i.length&&(n==null||n.push(...i)),{entityCode:t.code,fields:[{data:this.createTreeNode(t,[],"code"),children:n||[]}]}}getEntitiesAndVariables(){return{entities:this.getEntitiesTreeData(),variables:{session:{name:"系统变量",items:this.sessionVariables,visible:!1},forms:{name:"表单变量",items:this.getContextFormVariables(),visible:!0}}}}onBeforeOpenExpression(e,t,n){const i=n==="Field"?e.binding.field:e.id,o=this.getExpressionRule(i,t),s=this.getEntitiesAndVariables(),d={message:["validate","required","dataPicking"].includes(t)&&o?o.message:"",...s};return o.messageType!=null&&(d.messageType=o.messageType),d}buildRule(e,t,n,i){const{expression:o,message:s,messageType:d}=t,a={id:`${e}_${n}`,type:n,value:o};return(n==="validate"||n==="dataPicking"||n==="required")&&(a.message=s),n==="dataPicking"&&(a.messageType=d),n==="validate"&&i&&(a.elementId=i),a}getExpressionData(){const{expressions:e}=this.formSchemaService.getFormSchema().module;return e||[]}updateExpression(e,t,n,i){const o=t==="Field"?e.binding.field:e.id,s=this.buildRule(o,n,i,e.type==="form-group"?e.id:"");let a=this.getExpressionData().find(u=>u.targetType===t&&u.target===o);const c=u=>u.value.trim()==="";if(a){const u=a.rules.find(g=>g.id===s.id);if(u)c(s)?a.rules=a.rules.filter(g=>g.id!==s.id):(Object.assign(u,s),i==="validate"&&e.type==="form-group"&&(u.elementId=e.id));else{if(c(s))return null;a.rules=a.rules||[],a.rules.push(s)}}else{if(c(s))return null;a={target:`${o}`,rules:[s],targetType:t}}return a}getExpressionEditorOptions(e,t,n,i){return n.reduce((o,s)=>{var a,c;const d=t==="Field"?(a=e==null?void 0:e.binding)==null?void 0:a.field:e.id;return o[s]={hide:t==="Field"?!!((c=e==null?void 0:e.binding)!=null&&c.field):!1,description:"",title:this.expressionNames[s],type:"string",$converter:this.getExpressionConverter(d),refreshPanelAfterChanged:!0,editor:{type:"expression-editor",singleExpand:!1,dialogTitle:`${this.expressionNames[s]}编辑器`,showMessage:s==="validate"||s==="dataPicking"||s==="required",showMessageType:s==="dataPicking",beforeOpen:()=>this.onBeforeOpenExpression(e,s,t),onSubmitModal:u=>{const g=this.updateExpression(e,t,u,s);if(i){const C=this.buildRule(d,u,s);i(C)}return g}}},o},{})}getExpressionInfo(e,t,n){const i=t==="Field"?e.binding.field:e.id,o=this.getExpressionRule(i,n),s={value:o&&o.value,targetId:i,targetType:t,expressionType:n};return o&&o.message&&(s.message=o.message),s}getExpressionConfig(e,t,n=["compute","dependency","validate"],i){return{description:"表达式",title:"表达式",hide:!e.binding,properties:{...this.getExpressionEditorOptions(e,t,n,i)}}}getExpressionOptions(e,t,n){const i=this.getExpressionInfo(e,t,n);return{dialogTitle:`${this.expressionNames[n]||"表达式"}编辑器`,singleExpand:!1,showMessage:n==="required",beforeOpen:()=>this.onBeforeOpenExpression(e,n,t),expressionInfo:i}}}class z{constructor(e,t){h(this,"componentId");h(this,"viewModelId");h(this,"eventsEditorUtils");h(this,"formSchemaUtils");h(this,"formMetadataConverter");h(this,"designViewModelUtils");h(this,"designViewModelField");h(this,"controlCreatorUtils");h(this,"designerHostService");h(this,"designerContext");h(this,"modalService",null);h(this,"formRule",null);h(this,"schemaService",null);h(this,"metadataService",null);h(this,"propertyConfig",{type:"object",categories:{}});h(this,"expressionProperty");var n;this.componentId=e,this.designerHostService=t,this.eventsEditorUtils=t.eventsEditorUtils,this.formSchemaUtils=t.formSchemaUtils,this.formMetadataConverter=t.formMetadataConverter,this.viewModelId=((n=this.formSchemaUtils)==null?void 0:n.getViewModelIdByComponentId(e))||"",this.designViewModelUtils=t.designViewModelUtils,this.controlCreatorUtils=t.controlCreatorUtils,this.metadataService=t.metadataService,this.schemaService=t.schemaService,this.designerContext=t.designerContext,this.modalService=t.modalService,this.expressionProperty=new _(this.formSchemaUtils)}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 n;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(o=>o.id===t)}e.updateOn=(n=this.designViewModelField)==null?void 0:n.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:P.DgControl[e.type]&&P.DgControl[e.type].name}]}}}}}getAppearanceConfig(e=null,t={},n){const i={title:"外观",description:"Appearance"},o={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 s in t)o[s]=Object.assign(o[s]||{},t[s]);return{...i,properties:{...o},setPropertyRelates(s,d){if(s){switch(s&&s.propertyID){case"class":case"style":{P.canvasChanged.value++;break}}n&&n(s,e,d)}}}}getPropertyEditorParams(e,t=[],n="visible",i={},o={},s=""){const{getVariables:d,getControlName:a,getStateMachines:c}=L(this.designerHostService),u=this.getRealTargetType(e),g=t&&t.length>0?t:["Const","Variable","StateMachine","Expression"],C={type:"property-editor",propertyTypes:g};return g.map(v=>{switch(v){case"Const":Object.assign(C,{constType:"enum",constEnums:[{id:!0,name:"是"},{id:!1,name:"否"}]},i);break;case"Expression":C.expressionConfig=this.getExpressionOptions(e,u,s||n);break;case"StateMachine":C.stateMachines=c();break;case"Variable":Object.assign(C,{controlName:a(e),newVariablePrefix:"is",newVariableType:"Boolean",variables:d(this.viewModelId),parentComponentId:this.componentId==="root-component"?"":"root-component",onBeforeOpenVariables:y=>{y.value=d(this.viewModelId)}},o),this.designerContext.designerMode==="PC_RTC"&&(C.newVariablePrefix="ext_"+C.newVariablePrefix);break}}),C}getVisibleProperty(e,t=""){var o;let n=["Const","Variable","StateMachine","Expression"];return t==="gridFieldEditor"?n=["Const","Expression"]:t==="form-group"&&!((o=e.binding)!=null&&o.field)&&(n=["Const","Variable","StateMachine"]),{visible:{title:"是否可见",type:"boolean",description:"运行时组件是否可见",editor:this.getPropertyEditorParams(e,n,"visible")}}}getBehaviorConfig(e,t="",n={},i){const o={title:"行为",description:""},s=this.getVisibleProperty(e,t);for(const a in n)s[a]=Object.assign(s[a]||{},n[a]);const d=this;return{...o,properties:{...s},setPropertyRelates(a,c){if(a){switch(a.propertyID){case"disabled":case"readonly":case"visible":d.afterMutilEditorChanged(e,a);break}i&&i(a,c)}}}}afterMutilEditorChanged(e,t){this.addNewVariableToViewModel(t,this.viewModelId),this.updateExpressionValue(t,e),this.clearExpression(t,e)}updateElementByParentContainer(e,t){const n=t&&t.parent&&t.parent.schema;if(!n)return;const i=n.contents.findIndex(s=>s.id===e),o=q.cloneDeep(n.contents[i]);n.contents.splice(i,1),n.contents.splice(i,0,o),P.refreshCanvas()}addNewVariableToViewModel(e,t){const n=e.propertyValue;if(!(n&&typeof n=="object")||!(n.type==="Variable"&&n.isNewVariable))return;const s={id:n.field,category:"locale",code:n.fullPath,name:n.fullPath,type:n.newVariableType||"String",isRtcVariable:this.designerContext.designerMode==="PC_RTC"?!0:void 0};delete n.newVariableType,delete n.isNewVariable,this.formSchemaUtils.getVariableByCode(s.code)||this.formSchemaUtils.getViewModelById("root-viewmodel").states.push(s)}getExpressions(){let e=[];return this.formRule?(this.formRule.expressions=this.formRule.expressions||[],e=this.formRule.expressions||[]):e=this.formSchemaUtils.getExpressions(),e}updateExpressionValue(e,t){const n=e.propertyValue;if(!((n&&n.type)==="Expression"&&n.expressionInfo))return;const{expressionId:s,expressionInfo:d}=n,{targetId:a,targetType:c,expressionType:u,value:g,message:C}=d,v=this.getExpressions();let y=v.find(V=>V.target===a);y||(y={target:a,rules:[],targetType:c},v.push(y));const w=y.rules.find(V=>V.type===u);if(w)w.value=g,w.message=C,(u==="minDate"||u==="maxDate"||u==="defaultTime")&&(w.elementId=t.id);else{const V={id:s,type:u,value:g,message:C,elementId:t.id};y.rules.push(V)}delete n.expressionInfo}clearExpression(e,t){const n=e.propertyValue;if(n&&n.type==="Expression")return;const o=e.propertyID,s=this.getExpressions(),d=t.binding?t.binding.field:t.id,a=s.find(c=>c.target===d);!a||!a.rules||(a.rules=a.rules.filter(c=>c.type!==o))}getExpressionOptions(e,t,n){return this.expressionProperty.getExpressionOptions(e,t,n)}getRealTargetType(e){return["response-toolbar-item","tab-toolbar-item","section-toolbar-item","drawer-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:n=>{var i;((i=n.controller)==null?void 0:i.label.indexOf(this.formSchemaUtils.getModule().code))>-1&&this.eventsEditorUtils.jumpToMethod(n)}}},t}}class K extends z{constructor(e,t){super(e,t)}getPropertyConfig(e){return this.propertyConfig.categories.basic=this.getBasicPropConfig(e),this.propertyConfig.categories.appearance=this.getAppearanceProperties(e),this.propertyConfig.categories.template=this.getTemplateConfig(e),this.propertyConfig.categories.behavior=this.getBehaviorConfig(e),this.propertyConfig}getAppearanceProperties(e){return{title:"外观",description:"",properties:{class:{title:"class样式",type:"string",description:"组件的CSS样式"},icon:{title:"图标",type:"string",description:"图标"},title:{title:"标题",type:"string",description:"标题"}},setPropertyRelates(t,n){if(t)switch(t&&t.propertyID){case"title":{t.needRefreshControlTree=!0;break}}}}}getTemplateConfig(e){return{title:"模板配置",description:"",properties:{titleContentClass:{title:"标题模板class",type:"string",description:"标题模板外层容器的自定义样式"},titleContentHtml:{title:"标题模板",type:"string",description:"设置标题HTML模板,替代图标和标题文字区域",refreshPanelAfterChanged:!0,editor:{type:"code-editor",language:"html"}},contentClass:{title:"内容模板class",type:"string",description:"内容模板外层容器的自定义样式"},contentHtml:{title:"内容模板",type:"string",description:"设置页头中间区域的模板",refreshPanelAfterChanged:!0,editor:{type:"code-editor",language:"html"}},downContentClass:{title:"扩展模板class",type:"string",description:"扩展模板外层容器的自定义样式"},downContentHtml:{title:"扩展模板",type:"string",description:"设置页头下方区域的模板",refreshPanelAfterChanged:!0,editor:{type:"code-editor",language:"html"}}}}}}function J(l,e){function t(d){return!1}function n(){return!1}function i(){return!1}function o(){return!0}function s(d){return new K(d,e).getPropertyConfig(l)}return{canAccepts:t,hideNestedPaddingInDesginerView:o,getPropsConfig:s,checkCanDeleteComponent:n,checkCanMoveComponent:i}}const Q=r.defineComponent({name:"FPageHeaderDesign",props:R,emits:["click"],setup(l,e){const t=r.ref(),n=r.inject("designer-host-service"),i=r.inject("design-item-context"),o=J(i.schema,n),s=P.useDesignerComponent(t,i,o),d=r.ref(i.schema.toolbar||{type:"response-toolbar",buttons:[]}),a=r.ref(k.responseToolbarResolver(d.value));r.onMounted(()=>{t.value.componentInstance=s}),r.watch(()=>i.schema.toolbar,()=>{d.value=i.schema.toolbar||{type:"response-toolbar",buttons:[]},a.value=k.responseToolbarResolver(d.value)},{deep:!0});const c=r.computed(()=>[...a.value.items]);function u(m,N,A,F){i&&i.setupContext&&i.setupContext.emit("selectionChange",m,N,A,F)}e.expose(s.value);function g(m,N){m&&N&&N.split(" ").reduce((F,Y)=>(F[Y]=!0,F),m)}const C=r.computed(()=>{const m={"f-title-icon":!0};return g(m,l.iconClass),m}),v=r.computed(()=>{const m={"f-icon":!0};return g(m,l.icon),m}),y=r.computed(()=>{const m={"text-right":!0,"col-6":!0};return g(m,l.buttonClass||""),m}),w=r.computed(()=>{const m={"f-title":!0};return x.getCustomClass(m,l.titleContentClass)}),V=r.computed(()=>{const m={"f-content":!0};return x.getCustomClass(m,l.contentClass)}),H=r.computed(()=>{const m={"f-page-header-extend":!0};return x.getCustomClass(m,l.downContentClass)});function f(){return l.titleContentHtml?r.createVNode("div",{class:w.value,innerHTML:l.titleContentHtml},null):r.createVNode("div",{class:"f-title"},[l.showIcon&&l.icon?r.createVNode("span",{class:C.value},[r.createVNode("i",{class:v.value},null)]):"",r.createVNode("h4",{class:"f-title-text"},[l.title])])}function j(){return l.contentHtml?r.createVNode("div",{class:V.value,innerHTML:l.contentHtml},null):null}function X(){return l.downContentHtml?r.createVNode("div",{class:H.value,innerHTML:l.downContentHtml},null):null}return()=>r.createVNode("div",{ref:t},[r.createVNode("nav",{class:"f-page-header-base"},[f(),j(),r.createVNode(P.FDesignerInnerItem,{class:y.value,modelValue:d.value,"onUpdate:modelValue":m=>d.value=m,canAdd:!1,childType:"response-toolbar-item",childLabel:"按钮",contentKey:"buttons",id:d.value.id,componentId:l.componentId,onSelectionChange:u},{default:()=>[r.createVNode(k,{id:d.value.id,customClass:"w-100",items:c.value,componentId:l.componentId},null)]})]),X()])}}),W={install(l){l.component(T.name,T)},register(l,e,t,n,i){l["page-header"]=T,e["page-header"]=U(i),n["page-header"]={eventHandlerResolver:B}},registerDesigner(l,e,t,n){l["page-header"]=Q,e["page-header"]=O(n)}};p.PageHeader=T,p.default=W,p.eventHandlerResolver=B,p.pageHeaderDesignerProps=R,p.pageHeaderProps=E,p.propsDesignResolver=G,p.propsDesignResolverGenerator=O,p.propsResolver=$,p.propsResolverGenerator=U,Object.defineProperties(p,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});