UNPKG

@kre-form/ionic

Version:

1 lines 71.3 kB
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("moment"),require("@angular/common"),require("@angular/forms"),require("@kre-form/core"),require("lodash"),require("@angular/core"),require("@ionic/angular")):"function"==typeof define&&define.amd?define("@kre-form/ionic",["exports","moment","@angular/common","@angular/forms","@kre-form/core","lodash","@angular/core","@ionic/angular"],t):t((e["kre-form"]=e["kre-form"]||{},e["kre-form"].ionic={}),e.moment_,e.ng.common,e.ng.forms,e.core,e._,e.ng.core,e.angular)}(this,function(e,t,n,o,i,l,r,a){"use strict";var s=function(e,t){return(s=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])})(e,t)};function c(e,t){function n(){this.constructor=e}s(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var d=function(){return(d=Object.assign||function d(e){for(var t,n=1,o=arguments.length;n<o;n++)for(var i in t=arguments[n])Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i]);return e}).apply(this,arguments)};function p(e,t,a,s){return new(a=a||Promise)(function(n,o){function i(e){try{l(s.next(e))}catch(t){o(t)}}function r(e){try{l(s["throw"](e))}catch(t){o(t)}}function l(e){var t;e.done?n(e.value):((t=e.value)instanceof a?t:new a(function(e){e(t)})).then(i,r)}l((s=s.apply(e,t||[])).next())})}function u(n,o){var i,r,l,a={label:0,sent:function(){if(1&l[0])throw l[1];return l[1]},trys:[],ops:[]},e={next:t(0),"throw":t(1),"return":t(2)};return"function"==typeof Symbol&&(e[Symbol.iterator]=function(){return this}),e;function t(t){return function(e){return s([t,e])}}function s(e){if(i)throw new TypeError("Generator is already executing.");for(;a;)try{if(i=1,r&&(l=2&e[0]?r["return"]:e[0]?r["throw"]||((l=r["return"])&&l.call(r),0):r.next)&&!(l=l.call(r,e[1])).done)return l;switch(r=0,(e=l?[2&e[0],l.value]:e)[0]){case 0:case 1:l=e;break;case 4:return a.label++,{value:e[1],done:!1};case 5:a.label++,r=e[1],e=[0];continue;case 7:e=a.ops.pop(),a.trys.pop();continue;default:if(!(l=0<(l=a.trys).length&&l[l.length-1])&&(6===e[0]||2===e[0])){a=0;continue}if(3===e[0]&&(!l||e[1]>l[0]&&e[1]<l[3])){a.label=e[1];break}if(6===e[0]&&a.label<l[1]){a.label=l[1],l=e;break}if(l&&a.label<l[2]){a.label=l[2],a.ops.push(e);break}l[2]&&a.ops.pop(),a.trys.pop();continue}e=o.call(n,a)}catch(t){e=[6,t],r=0}finally{i=l=0}if(5&e[0])throw e[1];return{value:e[0]?e[1]:void 0,done:!0}}}function f(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var o,i,r=n.call(e),l=[];try{for(;(void 0===t||0<t--)&&!(o=r.next()).done;)l.push(o.value)}catch(a){i={error:a}}finally{try{o&&!o.done&&(n=r["return"])&&n.call(r)}finally{if(i)throw i.error}}return l}function m(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(f(arguments[t]));return e}var A,g=(c(h,A=i.FieldType),h.prototype.ngOnInit=function(){},h.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-text",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-input\n [maxlength]="to.maxLength || 200"\n [minlength]="to.minLength || 0"\n [formControl]="formControl"\n [ionKreFormAttributes]="field"\n ></ion-input>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{ text }}</div>\n </ng-template>\n '}]}],h.ctorParameters=function(){return[]},h);function h(){return A.call(this)||this}var y,v=(c(I,y=i.FieldType),I.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-textarea",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-textarea\n [formControl]="formControl"\n [ionKreFormAttributes]="field"\n [rows]="to.rows ? to.rows : 4"\n [maxlength]="to.maxLength || 500"\n [minlength]="to.minLength || 0"\n >\n </ion-textarea>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{ text }}</div>\n </ng-template>\n '}]}],I);function I(){return null!==y&&y.apply(this,arguments)||this}var b,C=(c(k,b=i.FieldType),Object.defineProperty(k.prototype,"value",{get:function(){return this.model&&this.model[this.key]!==undefined&&null!==this.model[this.key]&&""!==this.model[this.key]?this.model[this.key]:null},set:function(e){this._value=e},enumerable:!0,configurable:!0}),k.prototype.changeValue=function(e){this.model[this.key]=e},k.prototype.inputBlur=function(e){var t;e.target&&e.target.value&&this.model?(t=e.target.value,this.model[this.key]=t,this.formControl.patchValue(t)):(null!=e.target.value&&""!=e.target.value||this.model[this.key]!=undefined&&null!=this.model[this.key]&&(this.model[this.key]=null),this.formControl.patchValue(null)),this.formControl.markAsTouched()},Object.defineProperty(k.prototype,"number",{get:function(){var e=this.text;return this.to!=undefined&&null!=this.to&&this.to.precision!=undefined&&null!=this.to.precision&&(!e&&0!==e||(e=l.round(e,this.to.precision),!l.isEmpty(this.model)&&this.model.hasOwnProperty(this.key)&&(this.model[this.key]=e))),e},enumerable:!0,configurable:!0}),k.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-number",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-input\n type="input"\n ionKreFormFloat\n [decimalNumber]="to.precision"\n [ionKreFormAttributes]="field"\n [max]="to.max || 999999"\n [min]="to.min || -999999"\n [(ngModel)]="value"\n (ngModelChange)="changeValue($event)"\n (ionBlur)="inputBlur($event)"\n ></ion-input>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{ number }}</div>\n </ng-template>\n '}]}],k);function k(){return null!==b&&b.apply(this,arguments)||this}var E,B=(c(q,E=i.FieldType),q.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-radio",template:'\n <ng-container>\n <ion-radio-group\n [formControl]="formControl"\n [ionKreFormAttributes]="field"\n >\n <ion-item>\n <ion-label [position]="to.labelPosition" class="">\n <span *ngIf="to.required" class="required-icon">*</span\n >{{ to.label }} </ion-label\n ><ion-radio\n slot="end"\n [disabled]="!editor"\n [value]="to.value"\n mode="md"\n ></ion-radio\n ></ion-item>\n </ion-radio-group>\n </ng-container>\n '}]}],q);function q(){return null!==E&&E.apply(this,arguments)||this}var F=(Object.defineProperty(Q.prototype,"options",{get:function(){return this._options},set:function(e){this._options=l.cloneDeep(e),this._options_old=e},enumerable:!0,configurable:!0}),Q.prototype.checkAll=function(e){1==this.isAllChecked?this.options.forEach(function(e){e.checked=!0}):this.selectedNum===this.options.length&&this.options.forEach(function(e){e.checked=!1}),this.setSelectNum()},Q.prototype.setSelectNum=function(){this.selectedNum=this.options.filter(function(e){return e.checked}).length,this.isAllChecked=0<this.options.length&&this.selectedNum===this.options.length},Q.prototype.singleCheck=function(t){this.options.map(function(e){return e.checked=e.value===t,e})},Q.prototype.dismissModel=function(e){var t;e?(t=this.options.filter(function(e){return e.checked}).map(function(e){return{label:e.label,value:e.value}}),this.modalController.dismiss(t)):this.modalController.dismiss()},Q.prototype.ngOnInit=function(){},Q.prototype.ngAfterViewInit=function(){},Q.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-select",template:'\n <div class="multi">\n <div class="multi_head">\n <ng-container *ngIf="selectType == \'multiple\'; else other">\n <ion-item>\n <ion-checkbox\n [(ngModel)]="isAllChecked"\n (ionChange)="checkAll($event)"\n ></ion-checkbox>\n <ion-label>\n 全选\n <span>({{ selectedNum }}/{{ options.length }})</span></ion-label\n >\n </ion-item>\n <div>\n <ion-button size="small" fill="clear" (click)="dismissModel(false)"\n >取消</ion-button\n >\n <ion-button size="small" fill="clear" (click)="dismissModel(true)"\n >确定</ion-button\n >\n </div>\n </ng-container>\n <ng-template #other>\n <ion-button size="small" fill="clear" (click)="dismissModel(false)"\n >取消</ion-button\n >\n <ion-button size="small" fill="clear" (click)="dismissModel(true)"\n >确定</ion-button\n >\n </ng-template>\n </div>\n <div class="multi_scroll">\n <ion-item\n class="multi_scroll_item hairlines-bottom"\n *ngFor="let row of options"\n (click)="selectType == \'single\' ? singleCheck(row.value) : \'\'"\n >\n <ion-checkbox\n [(ngModel)]="row.checked"\n (ionChange)="selectType == \'multiple\' ? setSelectNum() : \'\'"\n ></ion-checkbox>\n <ion-label>{{ row.label }}</ion-label>\n </ion-item>\n </div>\n </div>\n '}]}],Q.ctorParameters=function(){return[{type:a.ModalController}]},Q.propDecorators={selectType:[{type:r.Input}],options:[{type:r.Input}]},Q);function Q(e){this.modalController=e,this.isAllChecked=!1,this.selectedNum=0,this.selectType="multiple"}var P=(O.prototype.CreateModelDialog=function(o,i,r){return p(this,void 0,void 0,function(){var t,n;return u(this,function(e){switch(e.label){case 0:return[4,this.modalController.create({component:o.content,cssClass:o["class"],componentProps:d({},i),mode:"ios"})];case 1:return[4,(t=e.sent()).present()];case 2:return e.sent(),[4,t.onDidDismiss()];case 3:return n=e.sent().data,r(n,t),[2]}})})},O.decorators=[{type:r.Injectable}],O.ctorParameters=function(){return[{type:a.ModalController}]},O);function O(e){this.modalController=e}var M,x=(c(T,M=i.FieldType),T.prototype.openPicker=function(){var t=this,n=[];this.to.options.forEach(function(e){n.push({value:e.value,label:e.label,checked:t.isOptionChecked(e.value)})}),this.dialogService.CreateModelDialog({content:F,"class":"part-page"},{options:n,selectType:"single"},function(e){e&&(t.formControl.patchValue(e),t.formControl.markAsTouched())})},T.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-radiogroup",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-item detail="true" (click)="openPicker()">\n <div>{{ textLookUp }}</div>\n </ion-item>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{ textLookUp }}</div>\n </ng-template>\n '}]}],T.ctorParameters=function(){return[{type:P}]},T);function T(e){var t=M.call(this)||this;return t.dialogService=e,t}var w,D=(c(N,w=i.FieldType),N.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-checkbox",template:'\n <ion-item>\n <ion-label [position]="to.labelPosition">\n <span *ngIf="to.required" class="required-icon">*</span>{{ to.label }}\n </ion-label>\n <ion-checkbox\n slot="end"\n mode="ios"\n [formControl]="formControl"\n [ionKreFormAttributes]="field"\n [disabled]="!editor"\n ></ion-checkbox>\n </ion-item>\n '}]}],N);function N(){return null!==w&&w.apply(this,arguments)||this}var X,G=(c(L,X=i.FieldType),L.prototype.openPicker=function(){var t=this,n=[];this.to.options.forEach(function(e){n.push({value:e.value,label:e.label,checked:t.isOptionChecked(e.value)})}),this.dialogService.CreateModelDialog({content:F,"class":"part-page"},{options:n,selectType:"multiple"},function(e){e&&(t.formControl.patchValue(e),t.formControl.markAsTouched())})},L.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-checkboxgroup",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-item detail="true" (click)="openPicker()">\n <div>{{ textLookUp }}</div>\n </ion-item>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{ textLookUp }}</div>\n </ng-template>\n '}]}],L.ctorParameters=function(){return[{type:P}]},L);function L(e){var t=X.call(this)||this;return t.dialogService=e,t}var j,Y=(c(R,j=i.FieldType),R.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-image",template:'\n <ion-thumbnail>\n <img [src]="formControl.value" [ionKreFormAttributes]="field" />\n </ion-thumbnail>\n '}]}],R);function R(){return null!==j&&j.apply(this,arguments)||this}var J,H=t,V=(c(S,J=i.FieldType),Object.defineProperty(S.prototype,"maxDate",{get:function(){var e=this.to.maxDate?H(this.to.maxDate).format("YYYY-MM-DDTHH:mm"):"2050-12-31T23:59";return e=e.split("T")[1]?e:e+"T23:59"},enumerable:!0,configurable:!0}),Object.defineProperty(S.prototype,"minDate",{get:function(){var e=(this.to.minDate?H(this.to.minDate):H().subtract(100,"years").startOf("year")).format("YYYY-MM-DDTHH:mm");return e=e.split("T")[1]?e:e+"T00:00"},enumerable:!0,configurable:!0}),Object.defineProperty(S.prototype,"format",{get:function(){var e="YYYY/MM/DD HH:mm";if(this.to.type!==undefined&&null!==this.to.type)switch(this.to.type.toLowerCase()){case"datetime":break;case"date":e="YYYY/MM/DD";break;case"year":e="YYYY";break;case"month":e="YYYY/MM";break;case"time":e="HH:mm"}return e},enumerable:!0,configurable:!0}),Object.defineProperty(S.prototype,"getText",{get:function(){var e="";if(this.to.type!==undefined&&null!==this.to.type&&""!==this.to.type||(this.to.type="datetime"),this.model!=undefined&&null!=this.model&&this.field!=undefined&&null!=this.field&&this.field.key!=undefined&&null!=this.field.key&&this.model[this.field.key]!=undefined&&null!=this.model[this.field.key]&&""!=this.model[this.field.key]&&H(this.model[this.field.key]).isValid())switch(this.to.type){case"datetime":e=H(this.model[this.field.key]).format("YYYY/MM/DD HH:mm");break;case"date":e=H(this.model[this.field.key]).format("YYYY/MM/DD");break;case"year":e=H(this.model[this.field.key]).format("YYYY");break;case"month":e=H(this.model[this.field.key]).format("YYYY/MM");break;case"time":e=H(this.model[this.field.key]).format("HH:mm")}return e},enumerable:!0,configurable:!0}),S.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-datetime",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-item detail="true">\n <ion-datetime\n [displayFormat]="format"\n [pickerFormat]="format"\n [formControl]="formControl"\n [ionKreFormAttributes]="field"\n doneText="确认"\n cancelText="取消"\n mode="ios"\n [min]="minDate"\n [max]="maxDate"\n ></ion-datetime>\n </ion-item>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{ getText }}</div>\n </ng-template>\n '}]}],S);function S(){return null!==J&&J.apply(this,arguments)||this}var W=(K.prototype.presentToast=function(t,n,o){return p(this,void 0,void 0,function(){return u(this,function(e){switch(e.label){case 0:return n=n||"bottom",o=o||1500,[4,this.toastCtrl.create({color:"dark",message:t,position:n,duration:o,animated:!0})];case 1:return e.sent().present(),[2]}})})},K.decorators=[{type:r.Injectable}],K.ctorParameters=function(){return[{type:a.ToastController}]},K);function K(e){this.toastCtrl=e}var U=(Object.defineProperty(Z.prototype,"languageList",{get:function(){return this._languageList},set:function(e){this._languageList=l.cloneDeep(e),this._languageList_old=e},enumerable:!0,configurable:!0}),Z.prototype.dismissModel=function(e){var t;if(e){if(t=this.languageList,1==this.required){e=t.filter(function(e){if(null==e.value||""==e.value)return e});if(null!=e&&0<e.length)return void this.toastService.presentToast("多语言字段不能为空!")}this.modalController.dismiss(t)}else this.modalController.dismiss()},Z.prototype.ngOnInit=function(){},Z.prototype.ngAfterViewInit=function(){},Z.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-i18",template:'\n <ion-header class="contactHeader">\n <ion-toolbar>\n <ion-title> 多语言设置</ion-title>\n </ion-toolbar>\n </ion-header>\n <ion-content>\n <ng-container *ngIf="editor == true; else other">\n <div *ngFor="let item of languageList">\n <ion-label>\n <span *ngIf="required == true" class="required-icon">*</span>\n {{ item.label }}</ion-label\n >\n <ion-item>\n <ion-input [(ngModel)]="item.value"></ion-input>\n </ion-item>\n </div>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">\n <div *ngFor="let item of languageList">\n <ion-label>{{ item.label }}</ion-label>\n <ion-item>\n {{ item.value }}\n </ion-item>\n </div>\n </div>\n </ng-template>\n <div class="selection-buttons">\n <div class="buttons-between">\n <ion-button size="small" (click)="dismissModel(false)"\n >取消</ion-button\n >\n <ion-button\n [disabled]="!editor"\n size="small"\n (click)="dismissModel(true)"\n >确定</ion-button\n >\n </div>\n </div>\n </ion-content>\n '}]}],Z.ctorParameters=function(){return[{type:a.ModalController},{type:W}]},Z.propDecorators={editor:[{type:r.Input}],required:[{type:r.Input}],languageList:[{type:r.Input}]},Z);function Z(e,t){this.modalController=e,this.toastService=t,this.editor=!0,this.required=!1}var z,_=(c($,z=i.FieldType),Object.defineProperty($.prototype,"textlanguage",{get:function(){var t="";return this.model&&this.model[this.key]&&Array.isArray(this.model[this.key])&&this.model[this.key].forEach(function(e){"chinese"==e.language&&(t=e.value)}),t},enumerable:!0,configurable:!0}),$.prototype.openPicker=function(){var n=this,t=[];this.languageList.forEach(function(e){t.push({language:e.language,label:e.label,value:n.getLanguageValue(e.language)})});var e={languageList:t,required:this.to.required!=undefined&&this.to.required,editor:this.editor};this.dialogService.CreateModelDialog({content:U,"class":"full-page"},e,function(e,t){e&&(n.formControl.patchValue(e),n.formControl.markAsTouched())})},$.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-texti18n",template:'\n <ng-container>\n <ion-item detail="true" (click)="openPicker()">\n <div>{{ textlanguage }}</div>\n </ion-item>\n </ng-container>\n '}]}],$.ctorParameters=function(){return[{type:P}]},$);function $(e){var t=z.call(this)||this;return t.dialogService=e,t.languageList=[{language:"chinese",label:"中",value:""},{language:"english",label:"英",value:""}],t}var ee,te=(c(ne,ee=i.FieldType),Object.defineProperty(ne.prototype,"newTextLookUp",{get:function(){var e=this,n=[];return this.model&&null!=this.model&&this.model.hasOwnProperty(this.key)&&this.model[this.key]!==undefined&&null!=this.model[this.key]&&0<this.model[this.key].length&&this.to.options&&0<this.to.options.length&&this.model[this.key].forEach(function(t){e.to.options.some(function(e){return e.value===t.value})&&n.push(t.label)}),n.join("、")},enumerable:!0,configurable:!0}),ne.prototype.openPicker=function(){var n=this,t=[],e="single";this.to.selectType&&"multiple"==this.to.selectType&&(e="multiple"),this.to.options.forEach(function(e){t.push({value:e.value,label:e.label,checked:n.isOptionChecked(e.value)})}),this.dialogService.CreateModelDialog({content:F,"class":"part-page"},{options:t,selectType:e},function(e,t){e&&(n.formControl.patchValue(e),n.formControl.markAsTouched())})},ne.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-select",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-item detail="true" (click)="openPicker()">\n <div>{{ newTextLookUp }}</div>\n </ion-item>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{ textLookUp }}</div>\n </ng-template>\n '}]}],ne.ctorParameters=function(){return[{type:P}]},ne);function ne(e){var t=ee.call(this)||this;return t.dialogService=e,t}var oe,ie=(c(re,oe=i.FieldType),re.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-line",template:" <div><hr /></div>"}]}],re);function re(){return null!==oe&&oe.apply(this,arguments)||this}var le,ae=(c(se,le=i.FieldType),se.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-password",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-input\n [type]="showPwd ? \'text\' : \'password\'"\n [formControl]="formControl"\n [ionKreFormAttributes]="field"\n >\n </ion-input>\n <ion-icon\n [name]="showPwd ? \'eye-outline\' : \'eye-off-outline\'"\n (click)="showPwd = !showPwd"\n ></ion-icon>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{ text }}</div>\n </ng-template>\n '}]}],se.ctorParameters=function(){return[]},se);function se(){var e=le.call(this)||this;return e.showPwd=!1,e}var ce,de=(c(pe,ce=i.FieldType),pe.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-html",template:" <div [ngStyle]=\"{\n color: fontProperty.color,\n 'font-size': fontProperty.fontSize + 'px',\n 'font-style': fontProperty.fontStyle ? 'italic' : 'normal',\n 'font-weight': fontProperty.fontWeight ? 'bold' : 'normal'\n }\" [innerHtml]=\"to.description | safeHtml\"></div>"}]}],pe);function pe(){return null!==ce&&ce.apply(this,arguments)||this}var ue,fe=(c(me,ue=i.FieldType),me.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-table",template:'\n <ng-container>\n <ion-item>table 暂不支持</ion-item>\n \x3c!-- 不太确定展示哪些字段\n <div *ngFor="let item of to.options">\n <ion-label>{{ item.label }}</ion-label>\n <ion-item>\n <div>{{ item.value }}</div></ion-item\n >\n </div> --\x3e\n </ng-container>\n '}]}],me);function me(){return null!==ue&&ue.apply(this,arguments)||this}var Ae,ge=(c(he,Ae=i.FieldType),he.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-editor",template:"\n <ng-container>\n <ion-item>Editor 暂不支持</ion-item>\n </ng-container>\n "}]}],he);function he(){return null!==Ae&&Ae.apply(this,arguments)||this}var ye,ve=(c(Ie,ye=i.FieldType),Ie.prototype.switchValue=function(){return this.model[this.field.key]?"是":"否"},Ie.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-switch",template:'\n <ng-container *ngIf="!!editor; else other">\n <ion-toggle\n [formControl]="formControl"\n [ionKreFormAttributes]="field"\n ></ion-toggle>\n </ng-container>\n <ng-template #other>\n <div class="fieldtext">{{text }}</div>\n </ng-template>\n '}]}],Ie.ctorParameters=function(){return[]},Ie);function Ie(){return ye.call(this)||this}var be=(Ce.prototype.ngOnInit=function(){},Ce.prototype.ngAfterViewInit=function(){},Ce.decorators=[{type:r.Component,args:[{selector:"kreform-field-ion-tags",template:'\n <div [innerHtml]="content | safeHtml"></div>\n '}]}],Ce.ctorParameters=function(){return[{type:a.ModalController}]},Ce.propDecorators={content:[{type:r.Input}]},Ce);function Ce(e){this.modalController=e}var ke,Ee=(c(Be,ke=i.FieldWrapper),Be.prototype.onBadge=function(n){return p(this,void 0,void 0,function(){var t;return u(this,function(e){switch(e.label){case 0:switch(t="",n.mark){case"add":t="新增";break;case"modify":t="修改";break;case"remove":t="删除"}return[4,this.popoverController.create({component:be,cssClass:"field-popover",componentProps:{content:this.tags.content||"数据已被"+t},translucent:!0,mode:"ios"})];case 1:return[4,e.sent().present()];case 2:return e.sent(),[2]}})})},Be.prototype.buttonClick=function(){this.globalService.notifyDataChanged("FieldWrapperClick",{rdm:Math.random(),config:this.field})},Be.decorators=[{type:r.Component,args:[{selector:"kreform-wrapper-ion-form-field",template:'\n <ng-container *ngIf="field.type != \'html\'">\n <div class="item-box">\n <ng-container\n *ngIf="\n field.type != \'line\' &&\n field.type != \'htmlcontent\' &&\n field.type != \'image\' &&\n field.type != \'label\' &&\n field.type != \'upload\' &&\n field.type != \'radio\' &&\n field.type != \'checkbox\'\n "\n >\n <ion-label\n [position]="to.labelPosition"\n [ngStyle]="{\n color: fontProperty.color,\n \'font-size\': fontProperty.fontSize + \'px\',\n \'font-style\': fontProperty.fontStyle ? \'italic\' : \'normal\',\n \'font-weight\': fontProperty.fontWeight ? \'bold\' : \'normal\'\n }"\n >\n <span *ngIf="to.required" class="required-icon">*</span\n >{{ to.label }}\n </ion-label>\n </ng-container>\n <div class="field-content-box">\n <ng-template #fieldComponent></ng-template>\n <div\n class="field-unit"\n *ngIf="to.unit && to.unit != null && to.unit != \'\'"\n >\n <span [innerHtml]="to.unit | safeHtml"></span>\n </div>\n <div\n class="field-button"\n *ngIf="to.button && to.button != null && to.button?.show == true"\n >\n <span\n [innerHtml]="to.button.label | safeHtml"\n (click)="buttonClick()"\n ></span>\n </div>\n </div>\n </div>\n\n <div class="item-error" *ngIf="showError">\n <kreform-validation-message [field]="field">\n </kreform-validation-message>\n </div>\n <ng-container *ngIf="tags.mark">\n <ion-badge class="field-tags" (click)="onBadge(tags)">\n {{ tags.mark | tags }}\n </ion-badge>\n </ng-container>\n </ng-container>\n '}]}],Be.ctorParameters=function(){return[{type:a.PopoverController},{type:i.FormGlobalService}]},Be);function Be(e,t){var n=ke.call(this)||this;return n.popoverController=e,n.globalService=t,n}var qe,Fe=(c(Qe,qe=i.FieldType),Qe.decorators=[{type:r.Component,args:[{selector:"group",template:'\n <div [class]="\'fieldGroup \' + field.className">\n <kreform-field\n *ngFor="let f of field.fieldGroup"\n [field]="f"\n ></kreform-field>\n <ng-content></ng-content>\n </div>\n ',host:{"[class]":'field.className || ""'}}]}],Qe);function Qe(){return null!==qe&&qe.apply(this,arguments)||this}var Pe,Oe=(c(Me,Pe=i.FieldArrayType),Me.prototype.ngOnInit=function(){var i=this;this.formControl&&this.formControl.valueChanges.subscribe(function(e){e.length!==i.length&&(i.length=e.length,i.to.enableInterface&&i.globalService.notifyDataChanged("repeatLengthChange",{rdm:Math.random(),config:i.field}))}),this.length=this.field.fieldGroup.length,this.field.repeatRole&&Object.keys(this.field.repeatRole).forEach(function(n){var o=Number(n.substr(n.lastIndexOf("$")+1));i.field.fieldGroup&&i.field.fieldGroup.forEach(function(e,t){o===t&&e.fieldGroup.forEach(function(e){i.field.repeatRole[n][e.key]&&(e.templateOptions!==undefined&&null!==e.templateOptions||(e.templateOptions={}),e.editProperty!==undefined&&null!==e.editProperty||(e.editProperty={}),e.templateOptions=Object.assign(e.templateOptions,i.field.repeatRole[n][e.key].templateOptions),!1!==i.field.repeatRole[n][e.key].editor&&!0!==i.field.repeatRole[n][e.key].editor||(e.editor=i.field.repeatRole[n][e.key].editor),!1!==i.field.repeatRole[n][e.key].show&&!0!==i.field.repeatRole[n][e.key].show||(e.show=i.field.repeatRole[n][e.key].show),e.editProperty=Object.assign(e.editProperty,i.field.repeatRole[n][e.key].editProperty))})})}),this.field.fieldGroup&&this.field.fieldGroup.forEach(function(e,t){e.fieldGroup.forEach(function(e){e.templateOptions.index=t})})},Me.prototype.isRemoved=function(e){var t=!0;return!1===this.editor&&(t=!1),t=e.fieldGroup.filter(function(e){return"line"!==e.type&&"htmlcontent"!==e.type}).every(function(e){return!!e.editProperty&&!!e.editProperty["delete"]})?!1:t},Me.prototype.addIndex=function(){var n=this;this.field.fieldGroup.forEach(function(e,t){e.fieldGroup.forEach(function(e){e.templateOptions.index=t,n.field&&n.field.templateOptions&&(n.field.templateOptions.index||0===n.field.templateOptions.index)&&(e.templateOptions.pIndex=n.field.templateOptions.index)})})},Me.prototype.removed=function(e,t){this.remove(e),this.operationProperty&&this.operationProperty.deleteEvent&&this.globalService.notifyDataChanged("FieldWrapperClick",{rdm:Math.random(),config:this.field,type:"repeat"}),this.globalService.notifyDataChanged("repeatDelete",{rdm:Math.random(),index:e,config:this.field}),this.addIndex()},Me.decorators=[{type:r.Component,args:[{selector:"kreform-repeat",template:'\n <ng-container\n *ngIf="\n field.fieldGroup !== undefined &&\n field.fieldGroup !== null &&\n field.fieldGroup.length > 0;\n else cardEmpty\n "\n >\n <div *ngFor="let field of field.fieldGroup; let i = index" class="row">\n <kreform-field class="col" [field]="field"></kreform-field>\n <div\n class="repeatDel"\n (click)="removed(i, isRemoved(field))"\n *ngIf="isRemoved(field)"\n >\n <span class="del">删除</span>\n </div>\n </div>\n </ng-container>\n <ng-template #cardEmpty>\n <div class="repeat-card-empty">\n <div class="ant-empty-image">\n <img\n alt="empty"\n class="ng-star-inserted"\n src=""\n />\n </div>\n <p class="ant-empty-description">暂无数据</p>\n </div>\n </ng-template>\n\n <div class="repeatAdd" (click)="add(); addIndex()" *ngIf="isAdd">\n <span>新增</span>\n </div>\n ',host:{"[class]":'field.className || ""',cdkDrag:""}}]}],Me.ctorParameters=function(){return[{type:i.FormGlobalService}]},Me);function Me(e){var t=Pe.call(this)||this;return t.globalService=e,t.length=0,t}var xe,Te=(c(we,xe=i.FieldArrayType),we.prototype.ngOnInit=function(){var i=this;this.field.repeatRole&&Object.keys(this.field.repeatRole).forEach(function(n){var o=Number(n.substr(n.lastIndexOf("$")+1));i.field.fieldGroup&&i.field.fieldGroup.forEach(function(e,t){o===t&&e.fieldGroup.forEach(function(e){i.field.repeatRole[n][e.key]&&(e.templateOptions!==undefined&&null!==e.templateOptions||(e.templateOptions={}),e.editProperty!==undefined&&null!==e.editProperty||(e.editProperty={}),e.templateOptions=Object.assign(e.templateOptions,i.field.repeatRole[n][e.key].templateOptions),!1!==i.field.repeatRole[n][e.key].editor&&!0!==i.field.repeatRole[n][e.key].editor||(e.editor=i.field.repeatRole[n][e.key].editor),e.editProperty=Object.assign(e.editProperty,i.field.repeatRole[n][e.key].editProperty))})})}),this.field.fieldGroup&&this.field.fieldGroup.forEach(function(e,t){e.fieldGroup.forEach(function(e){e.templateOptions.index=t})})},we.prototype.isRemoved=function(e){var t=!0;return!1===this.editor&&(t=!1),t=e.fieldGroup.filter(function(e){return"line"!==e.type&&"htmlcontent"!==e.type}).every(function(e){return!!e.editProperty&&!!e.editProperty["delete"]})?!1:t},we.prototype.addIndex=function(){this.field.fieldGroup.forEach(function(e,t){e.fieldGroup.forEach(function(e){e.templateOptions.index=t})})},we.prototype.removed=function(e,t){this.remove(e),this.operationProperty&&this.operationProperty.deleteEvent&&this.globalService.notifyDataChanged("FieldWrapperClick",{rdm:Math.random(),config:this.field,type:"repeat"})},we.decorators=[{type:r.Component,args:[{selector:"kreform-overtime",template:'\n <ng-container\n *ngIf="\n field.fieldGroup !== undefined &&\n field.fieldGroup !== null &&\n field.fieldGroup.length > 0;\n else cardEmpty\n "\n >\n <div *ngFor="let field of field.fieldGroup; let i = index" class="row">\n <kreform-field class="col" [field]="field"></kreform-field>\n <div\n class="repeatDel"\n (click)="removed(i, isRemoved(field))"\n *ngIf="isRemoved(field)"\n >\n <span class="del">删除</span>\n </div>\n </div>\n </ng-container>\n <ng-template #cardEmpty>\n <div class="repeat-card-empty">\n <div class="ant-empty-image">\n <img\n alt="empty"\n class="ng-star-inserted"\n src="