ngx-rs-ant 2.3.2 → 2.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/data-grid/data-grid.component.d.ts +2 -2
- package/data-grid/data-grid.factory.d.ts +0 -1
- package/esm2020/box-container/PluginManager.mjs +7 -1
- package/esm2020/data-grid/data-grid.component.mjs +7 -7
- package/esm2020/data-grid/data-grid.factory.mjs +21 -2
- package/esm2020/form/form.component.mjs +5 -2
- package/esm2020/types/component/form-item-component-base.mjs +7 -3
- package/esm2020/word/word-designer/word-designer.component.mjs +7 -3
- package/fesm2015/ngx-rs-ant.mjs +48 -11
- package/fesm2015/ngx-rs-ant.mjs.map +1 -1
- package/fesm2020/ngx-rs-ant.mjs +45 -9
- package/fesm2020/ngx-rs-ant.mjs.map +1 -1
- package/form/form.component.d.ts +1 -0
- package/package.json +1 -1
- package/types/component/form-item-component-base.d.ts +8 -0
- package/word/word-designer/word-designer.component.d.ts +3 -2
|
@@ -30,6 +30,7 @@ export class FormComponent extends UniqueId {
|
|
|
30
30
|
this.loading = false;
|
|
31
31
|
this.changeFilter = new ChangeFilter();
|
|
32
32
|
this.valueChange = new Subject();
|
|
33
|
+
this.modelValueChanged = new EventEmitter();
|
|
33
34
|
this.extraValidate = this.extraValidate.bind(this);
|
|
34
35
|
}
|
|
35
36
|
ngOnInit() {
|
|
@@ -44,6 +45,7 @@ export class FormComponent extends UniqueId {
|
|
|
44
45
|
ngOnDestroy() {
|
|
45
46
|
this.changeFilter.dispose();
|
|
46
47
|
this.valueChange.unsubscribe();
|
|
48
|
+
this.modelValueChanged.unsubscribe();
|
|
47
49
|
}
|
|
48
50
|
load() {
|
|
49
51
|
this.loading = true;
|
|
@@ -58,7 +60,8 @@ export class FormComponent extends UniqueId {
|
|
|
58
60
|
},
|
|
59
61
|
__model: this.model || {},
|
|
60
62
|
__opener: this,
|
|
61
|
-
__valueChange: this.valueChange
|
|
63
|
+
__valueChange: this.valueChange,
|
|
64
|
+
__modelValueChanged: this.modelValueChanged
|
|
62
65
|
};
|
|
63
66
|
this.service.getFormTemplateConfig(this.tenant, this.className, this.template).subscribe(response => {
|
|
64
67
|
this.config = response.data.template;
|
|
@@ -202,4 +205,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
202
205
|
type: HostBinding,
|
|
203
206
|
args: ['attr.validator-group-name']
|
|
204
207
|
}] } });
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/form/form.component.ts","../../../../projects/ngx-rs-ant/src/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport {FormService} from \"./form.service\";\r\nimport {DxButtonComponent} from \"devextreme-angular\";\r\nimport {validateGroupByName} from \"../util/utils\";\r\nimport {ChangeFilter} from \"../util/change-filter\";\r\nimport {lastValueFrom, map, Subject} from \"rxjs\";\r\nimport {UniqueId} from \"../util/UniqueId\";\r\n\r\n@Component({\r\n  selector: 'rs-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.scss'],\r\n  providers: [FormService]\r\n})\r\nexport class FormComponent extends UniqueId implements OnInit, OnChanges, OnDestroy {\r\n  @Input()\r\n  tenant?: any = 'T';\r\n  @Input()\r\n  className!: any;\r\n  @Input()\r\n  oid?: any;\r\n  @Input()\r\n  copyOid?: any;\r\n  @Input()\r\n  template?: any;\r\n  @Input()\r\n  extraAttrMap?: any;\r\n  @Input()\r\n  params?: any;\r\n  @Input()\r\n  tabViewContainerRef!: ViewContainerRef;\r\n  @Input()\r\n  onlyFrontEnd: boolean = false; // 仅前端，不通过oid获取实例model\r\n  @Input()\r\n  model?: any;\r\n  @Input()\r\n  readonly: boolean = false;\r\n  config: any;\r\n  extraValidator?: string;\r\n  @ViewChild('formSubmitter') formSubmitter!: DxButtonComponent;\r\n  @Output()\r\n  onDataLoaded = new EventEmitter<{ id: string, config: any, model: any }>();\r\n  @Output()\r\n  submitCallback = new EventEmitter<any>();\r\n  loading = false;\r\n  private changeFilter = new ChangeFilter();\r\n  private valueChange = new Subject<{\r\n    field: string,\r\n    value: any\r\n    onlyInit?: boolean,\r\n  }>();\r\n  protected context: any;\r\n  protected extraValidateMessage: any;\r\n\r\n  @HostBinding('attr.validator-group-name') get _validatorGroupName() {\r\n    return this.getUniqueId();\r\n  }\r\n\r\n  constructor(protected viewContainerRef: ViewContainerRef, private service: FormService, private elementRef: ElementRef) {\r\n    super('rs-form');\r\n    this.extraValidate = this.extraValidate.bind(this);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.load();\r\n    this.changeFilter.anyNotFirst(['tenant', 'className', 'oid', 'copyOid', 'template'], () => {\r\n      this.load();\r\n    });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.changeFilter.doFilter(changes);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.changeFilter.dispose();\r\n    this.valueChange.unsubscribe();\r\n  }\r\n\r\n  load() {\r\n    this.loading = true;\r\n    this.context = {\r\n      __form: {\r\n        uniqueId: this.getUniqueId(),\r\n        tenant: this.tenant,\r\n        className: this.className,\r\n        oid: this.oid,\r\n        copyOid: this.copyOid,\r\n        template: this.template\r\n      },\r\n      __model: this.model || {},\r\n      __opener: this,\r\n      __valueChange: this.valueChange\r\n    };\r\n    this.service.getFormTemplateConfig(this.tenant, this.className, this.template).subscribe(response => {\r\n      this.config = response.data.template;\r\n      this.extraValidator = this.config.extraValidator;\r\n      if (this.onlyFrontEnd) {\r\n        this.loading = false;\r\n        this.onDataLoaded.emit({\r\n          id: this.getUniqueId(),\r\n          config: this.config,\r\n          model: this.model\r\n        });\r\n      } else if (this.copyOid || this.oid) {\r\n        this.service.getOne(this.tenant, this.className, this.copyOid || this.oid, this.template, this.copyOid)\r\n          .subscribe(response => {\r\n            this.model = response.data;\r\n            this.context.__model = this.model;\r\n            this.onDataLoaded.emit({\r\n              id: this.getUniqueId(),\r\n              config: this.config,\r\n              model: this.model\r\n            });\r\n            this.loading = false;\r\n          });\r\n      } else {\r\n        this.service.getInitModelByTemplate(this.tenant, this.className, this.template).subscribe(response => {\r\n          this.model = response.data;\r\n          this.context.__model = this.model;\r\n          this.onDataLoaded.emit({\r\n            id: this.getUniqueId(),\r\n            config: this.config,\r\n            model: this.model\r\n          });\r\n          this.loading = false;\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  protected extraValidate() {\r\n    return lastValueFrom(this.service.extraValidate(this.model, Object.assign({}, this.params, {\r\n      tenant: this.tenant,\r\n      className: this.className,\r\n      oid: this.oid,\r\n      template: this.template\r\n    }), <string>this.extraValidator).pipe(\r\n      map(response => {\r\n        if (!response.isValid) {\r\n          this.extraValidateMessage = response.message;\r\n          return response;\r\n        }\r\n      })\r\n    ));\r\n  }\r\n\r\n  protected submitForm() {\r\n    this.validate().then(isValid => {\r\n      if (isValid) {\r\n        const mergeModel: any = {...this.model};\r\n        if (this.extraAttrMap) {\r\n          for (const entry of this.extraAttrMap) {\r\n            mergeModel[entry.name] = entry.value;\r\n          }\r\n        }\r\n        this.service.createOrUpdate(this.tenant, this.className, {\r\n          oid: this.oid,\r\n          ...mergeModel\r\n        }).subscribe(response => {\r\n          this.submitCallback.emit(response);\r\n        });\r\n      } else {\r\n        this.submitCallback.emit({success: false});\r\n      }\r\n    })\r\n  }\r\n\r\n  scrollToAnchorPoint(anchorPointId: string) {\r\n    const points = this.elementRef.nativeElement.getElementsByClassName('__anchor_point_' + anchorPointId);\r\n    if (points.length > 0) {\r\n      points[0].scrollIntoView({\r\n        block: 'center',\r\n        inline: 'center'\r\n      });\r\n    }\r\n  }\r\n\r\n  validate() {\r\n    return new Promise((resolve) => {\r\n      const promises: any[] = Array.from(this.elementRef.nativeElement.querySelectorAll('rs-form')).map((item: any) => {\r\n        return validateGroupByName(item.getAttribute('validator-group-name'), this.elementRef.nativeElement);\r\n      })\r\n      // 添加顶级元素的验证 Promise\r\n      promises.push(validateGroupByName(this.getUniqueId(), this.elementRef.nativeElement));\r\n      // 使用 Promise.all 等待所有 Promise 完成\r\n      Promise.all(promises)\r\n        .then((results: any) => {\r\n          if (results.every((isValid: any) => isValid)) {\r\n            resolve(true);\r\n          } else {\r\n            resolve(false);\r\n          }\r\n        })\r\n    });\r\n  }\r\n\r\n  submit() {\r\n    this.formSubmitter.instance.element().click();\r\n  }\r\n}\r\n","<dx-load-panel [container]=\"viewContainerRef.element.nativeElement\" [showPane]=\"false\"\r\n               [visible]=\"loading\">\r\n  <dxo-position [of]=\"viewContainerRef.element.nativeElement\"></dxo-position>\r\n</dx-load-panel>\r\n<ng-container *ngIf=\"!loading\">\r\n  <rs-box-container [config]=\"config\"\r\n                    [params]=\"params\"\r\n                    [context]=\"context\"\r\n                    [tabViewContainerRef]=\"tabViewContainerRef\"\r\n                    [readonly]=\"readonly\"></rs-box-container>\r\n  <dx-text-box height=\"0\" style=\"border: none;\">\r\n    <dx-validator [validationGroup]=\"getUniqueId()\">\r\n      <dxi-validation-rule *ngIf=\"extraValidator\" type=\"async\"\r\n                           [validationCallback]=\"extraValidate\"></dxi-validation-rule>\r\n    </dx-validator>\r\n  </dx-text-box>\r\n  <div *ngIf=\"extraValidateMessage\" class=\"dx-field\">\r\n    <div class=\"dx-field-value\">\r\n      <div class=\"dx-toast-error dx-toast-content\">\r\n        <div class=\"dx-toast-message\">{{ extraValidateMessage }}</div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <dx-button #formSubmitter [visible]=\"false\" (onClick)=\"submitForm()\"></dx-button>\r\n</ng-container>\r\n"]}
|
|
208
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/form/form.component.ts","../../../../projects/ngx-rs-ant/src/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport {FormService} from \"./form.service\";\r\nimport {DxButtonComponent} from \"devextreme-angular\";\r\nimport {validateGroupByName} from \"../util/utils\";\r\nimport {ChangeFilter} from \"../util/change-filter\";\r\nimport {lastValueFrom, map, Subject} from \"rxjs\";\r\nimport {UniqueId} from \"../util/UniqueId\";\r\n\r\n@Component({\r\n  selector: 'rs-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.scss'],\r\n  providers: [FormService]\r\n})\r\nexport class FormComponent extends UniqueId implements OnInit, OnChanges, OnDestroy {\r\n  @Input()\r\n  tenant?: any = 'T';\r\n  @Input()\r\n  className!: any;\r\n  @Input()\r\n  oid?: any;\r\n  @Input()\r\n  copyOid?: any;\r\n  @Input()\r\n  template?: any;\r\n  @Input()\r\n  extraAttrMap?: any;\r\n  @Input()\r\n  params?: any;\r\n  @Input()\r\n  tabViewContainerRef!: ViewContainerRef;\r\n  @Input()\r\n  onlyFrontEnd: boolean = false; // 仅前端，不通过oid获取实例model\r\n  @Input()\r\n  model?: any;\r\n  @Input()\r\n  readonly: boolean = false;\r\n  config: any;\r\n  extraValidator?: string;\r\n  @ViewChild('formSubmitter') formSubmitter!: DxButtonComponent;\r\n  @Output()\r\n  onDataLoaded = new EventEmitter<{ id: string, config: any, model: any }>();\r\n  @Output()\r\n  submitCallback = new EventEmitter<any>();\r\n  loading = false;\r\n  private changeFilter = new ChangeFilter();\r\n  private valueChange = new Subject<{\r\n    field: string,\r\n    value: any\r\n    onlyInit?: boolean,\r\n  }>();\r\n  private modelValueChanged = new EventEmitter<{\r\n    field: string,\r\n    value: any\r\n  }>();\r\n  protected context: any;\r\n  protected extraValidateMessage: any;\r\n\r\n  @HostBinding('attr.validator-group-name') get _validatorGroupName() {\r\n    return this.getUniqueId();\r\n  }\r\n\r\n  constructor(protected viewContainerRef: ViewContainerRef, private service: FormService, private elementRef: ElementRef) {\r\n    super('rs-form');\r\n    this.extraValidate = this.extraValidate.bind(this);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.load();\r\n    this.changeFilter.anyNotFirst(['tenant', 'className', 'oid', 'copyOid', 'template'], () => {\r\n      this.load();\r\n    });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.changeFilter.doFilter(changes);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.changeFilter.dispose();\r\n    this.valueChange.unsubscribe();\r\n    this.modelValueChanged.unsubscribe();\r\n  }\r\n\r\n  load() {\r\n    this.loading = true;\r\n    this.context = {\r\n      __form: {\r\n        uniqueId: this.getUniqueId(),\r\n        tenant: this.tenant,\r\n        className: this.className,\r\n        oid: this.oid,\r\n        copyOid: this.copyOid,\r\n        template: this.template\r\n      },\r\n      __model: this.model || {},\r\n      __opener: this,\r\n      __valueChange: this.valueChange,\r\n      __modelValueChanged: this.modelValueChanged\r\n    };\r\n    this.service.getFormTemplateConfig(this.tenant, this.className, this.template).subscribe(response => {\r\n      this.config = response.data.template;\r\n      this.extraValidator = this.config.extraValidator;\r\n      if (this.onlyFrontEnd) {\r\n        this.loading = false;\r\n        this.onDataLoaded.emit({\r\n          id: this.getUniqueId(),\r\n          config: this.config,\r\n          model: this.model\r\n        });\r\n      } else if (this.copyOid || this.oid) {\r\n        this.service.getOne(this.tenant, this.className, this.copyOid || this.oid, this.template, this.copyOid)\r\n          .subscribe(response => {\r\n            this.model = response.data;\r\n            this.context.__model = this.model;\r\n            this.onDataLoaded.emit({\r\n              id: this.getUniqueId(),\r\n              config: this.config,\r\n              model: this.model\r\n            });\r\n            this.loading = false;\r\n          });\r\n      } else {\r\n        this.service.getInitModelByTemplate(this.tenant, this.className, this.template).subscribe(response => {\r\n          this.model = response.data;\r\n          this.context.__model = this.model;\r\n          this.onDataLoaded.emit({\r\n            id: this.getUniqueId(),\r\n            config: this.config,\r\n            model: this.model\r\n          });\r\n          this.loading = false;\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  protected extraValidate() {\r\n    return lastValueFrom(this.service.extraValidate(this.model, Object.assign({}, this.params, {\r\n      tenant: this.tenant,\r\n      className: this.className,\r\n      oid: this.oid,\r\n      template: this.template\r\n    }), <string>this.extraValidator).pipe(\r\n      map(response => {\r\n        if (!response.isValid) {\r\n          this.extraValidateMessage = response.message;\r\n          return response;\r\n        }\r\n      })\r\n    ));\r\n  }\r\n\r\n  protected submitForm() {\r\n    this.validate().then(isValid => {\r\n      if (isValid) {\r\n        const mergeModel: any = {...this.model};\r\n        if (this.extraAttrMap) {\r\n          for (const entry of this.extraAttrMap) {\r\n            mergeModel[entry.name] = entry.value;\r\n          }\r\n        }\r\n        this.service.createOrUpdate(this.tenant, this.className, {\r\n          oid: this.oid,\r\n          ...mergeModel\r\n        }).subscribe(response => {\r\n          this.submitCallback.emit(response);\r\n        });\r\n      } else {\r\n        this.submitCallback.emit({success: false});\r\n      }\r\n    })\r\n  }\r\n\r\n  scrollToAnchorPoint(anchorPointId: string) {\r\n    const points = this.elementRef.nativeElement.getElementsByClassName('__anchor_point_' + anchorPointId);\r\n    if (points.length > 0) {\r\n      points[0].scrollIntoView({\r\n        block: 'center',\r\n        inline: 'center'\r\n      });\r\n    }\r\n  }\r\n\r\n  validate() {\r\n    return new Promise((resolve) => {\r\n      const promises: any[] = Array.from(this.elementRef.nativeElement.querySelectorAll('rs-form')).map((item: any) => {\r\n        return validateGroupByName(item.getAttribute('validator-group-name'), this.elementRef.nativeElement);\r\n      })\r\n      // 添加顶级元素的验证 Promise\r\n      promises.push(validateGroupByName(this.getUniqueId(), this.elementRef.nativeElement));\r\n      // 使用 Promise.all 等待所有 Promise 完成\r\n      Promise.all(promises)\r\n        .then((results: any) => {\r\n          if (results.every((isValid: any) => isValid)) {\r\n            resolve(true);\r\n          } else {\r\n            resolve(false);\r\n          }\r\n        })\r\n    });\r\n  }\r\n\r\n  submit() {\r\n    this.formSubmitter.instance.element().click();\r\n  }\r\n}\r\n","<dx-load-panel [container]=\"viewContainerRef.element.nativeElement\" [showPane]=\"false\"\r\n               [visible]=\"loading\">\r\n  <dxo-position [of]=\"viewContainerRef.element.nativeElement\"></dxo-position>\r\n</dx-load-panel>\r\n<ng-container *ngIf=\"!loading\">\r\n  <rs-box-container [config]=\"config\"\r\n                    [params]=\"params\"\r\n                    [context]=\"context\"\r\n                    [tabViewContainerRef]=\"tabViewContainerRef\"\r\n                    [readonly]=\"readonly\"></rs-box-container>\r\n  <dx-text-box height=\"0\" style=\"border: none;\">\r\n    <dx-validator [validationGroup]=\"getUniqueId()\">\r\n      <dxi-validation-rule *ngIf=\"extraValidator\" type=\"async\"\r\n                           [validationCallback]=\"extraValidate\"></dxi-validation-rule>\r\n    </dx-validator>\r\n  </dx-text-box>\r\n  <div *ngIf=\"extraValidateMessage\" class=\"dx-field\">\r\n    <div class=\"dx-field-value\">\r\n      <div class=\"dx-toast-error dx-toast-content\">\r\n        <div class=\"dx-toast-message\">{{ extraValidateMessage }}</div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <dx-button #formSubmitter [visible]=\"false\" (onClick)=\"submitForm()\"></dx-button>\r\n</ng-container>\r\n"]}
|
|
@@ -12,10 +12,10 @@ export class FormItemComponentBase extends ComponentBase {
|
|
|
12
12
|
this.readonly = false;
|
|
13
13
|
}
|
|
14
14
|
defaultValueChanged(change) {
|
|
15
|
-
|
|
15
|
+
const thisField = this.field;
|
|
16
|
+
if (!thisField) {
|
|
16
17
|
return;
|
|
17
18
|
}
|
|
18
|
-
const thisField = this.field;
|
|
19
19
|
if (Array.isArray(thisField)) {
|
|
20
20
|
if (!thisField.includes(change.field)) {
|
|
21
21
|
return;
|
|
@@ -32,6 +32,10 @@ export class FormItemComponentBase extends ComponentBase {
|
|
|
32
32
|
return;
|
|
33
33
|
}
|
|
34
34
|
this.model[change.field] = change.value;
|
|
35
|
+
this.modelValueChanged?.emit({
|
|
36
|
+
field: thisField,
|
|
37
|
+
value: change.field
|
|
38
|
+
});
|
|
35
39
|
}
|
|
36
40
|
}
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1pdGVtLWNvbXBvbmVudC1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJzLWFudC9zcmMvdHlwZXMvY29tcG9uZW50L2Zvcm0taXRlbS1jb21wb25lbnQtYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFJL0MsTUFBTSxPQUFPLHFCQUFzQixTQUFRLGFBQWE7SUFBeEQ7O1FBQ0U7O1dBRUc7UUFDSCxhQUFRLEdBQVksS0FBSyxDQUFDO1FBNEMxQjs7V0FFRztRQUNILGFBQVEsR0FBWSxLQUFLLENBQUM7SUEyQjVCLENBQUM7SUF6QlcsbUJBQW1CLENBQUMsTUFBeUQ7UUFDckYsTUFBTSxTQUFTLEdBQUksSUFBWSxDQUFDLEtBQUssQ0FBQztRQUN0QyxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ2QsT0FBTztTQUNSO1FBQ0QsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQzVCLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDckMsT0FBTzthQUNSO1NBQ0Y7YUFBTSxJQUFJLFNBQVMsS0FBSyxNQUFNLENBQUMsS0FBSyxFQUFFO1lBQ3JDLE9BQU87U0FDUjtRQUNELElBQUssSUFBWSxDQUFDLGtCQUFrQixFQUFFO1lBQ25DLElBQVksQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUN6QyxPQUFPO1NBQ1I7UUFDRCxJQUFJLE1BQU0sQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDL0MsT0FBTztTQUNSO1FBQ0QsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUN4QyxJQUFJLENBQUMsaUJBQWlCLEVBQUUsSUFBSSxDQUFDO1lBQzNCLEtBQUssRUFBRSxTQUFTO1lBQ2hCLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSztTQUNwQixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudEJhc2V9IGZyb20gXCIuL2NvbXBvbmVudC1iYXNlXCI7XHJcbmltcG9ydCB7U3ViamVjdH0gZnJvbSBcInJ4anNcIjtcclxuaW1wb3J0IHtFdmVudEVtaXR0ZXJ9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgRm9ybUl0ZW1Db21wb25lbnRCYXNlIGV4dGVuZHMgQ29tcG9uZW50QmFzZSB7XHJcbiAgLyoqXHJcbiAgICog57yW6L6R5qih5byP77yM5Zyo6K6+6K6h5Zmo5Lit5Li6dHJ1Ze+8jOeUqOS6juWMuuWIhue7hOS7tuiuvuiuoeWSjOW6lOeUqOeKtuaAgVxyXG4gICAqL1xyXG4gIGVkaXRNb2RlOiBib29sZWFuID0gZmFsc2U7XHJcbiAgLyoqXHJcbiAgICog6KGo5Y2V5ZSv5LiA5qCH6K+G77yM6KGo5Y2V57uE5Lu2ZHgtdmFsaWRhdG9y55qEdmFsaWRhdGlvbkdyb3Vw5ZCN56ew77yM55So5LqO57uf5LiA5qCh6aqM6KGo5Y2VXHJcbiAgICovXHJcbiAgdmFsaWRhdGlvbkdyb3VwTmFtZSE6IHN0cmluZztcclxuICAvKipcclxuICAgKiDlvZPliY3ooajljZXlr7nlupTmlbDmja7nsbvnp5/miLdcclxuICAgKi9cclxuICB0ZW5hbnQ6IGFueTtcclxuICAvKipcclxuICAgKiDlvZPliY3ooajljZXlr7nlupTmlbDmja7nsbvlkI1cclxuICAgKi9cclxuICBjbGFzc05hbWU6IGFueTtcclxuICAvKipcclxuICAgKiDlvZPliY3ooajljZXlr7nlupTmlbDmja7lrp7kvotvaWRcclxuICAgKi9cclxuICBvaWQ/OiBhbnk7XHJcbiAgLyoqXHJcbiAgICog6KGo5Y2V5b2T5YmNbW9kZWxcclxuICAgKi9cclxuICBtb2RlbDogYW55O1xyXG4gIC8qKlxyXG4gICAqIOWxnuaAp+WAvOabtOaWsOiuoumYhe+8jOeUqOS6juWxnuaAp+aYoOWwhO+8jOihqOWNlee7hOS7tumpseWKqOabtOaWsOWFtuS7luihqOWNlee7hOS7tueahOWAvFxyXG4gICAqL1xyXG4gIHZhbHVlQ2hhbmdlPzogU3ViamVjdDx7XHJcbiAgICBmaWVsZDogc3RyaW5nLFxyXG4gICAgdmFsdWU6IGFueVxyXG4gICAgb25seUluaXQ/OiBib29sZWFuXHJcbiAgfT47XHJcbiAgLyoqXHJcbiAgICog6KGo5Y2V57uE5Lu26amx5Yqo55qE5bGe5oCn5YC85pS55Y+Y5pe25Y+R5Ye655qE5LqL5Lu2XHJcbiAgICovXHJcbiAgbW9kZWxWYWx1ZUNoYW5nZWQ/OiBFdmVudEVtaXR0ZXI8e1xyXG4gICAgZmllbGQ6IHN0cmluZyxcclxuICAgIHZhbHVlOiBhbnlcclxuICB9PjtcclxuICAvKipcclxuICAgKiDoh6rlrprkuYnlsZ7mgKflgLzmm7TmlrDlh73mlbDvvIzlnKjmlLbliLDlsZ7mgKflgLzmm7TmlrDkuovku7bml7boh6rlrprkuYnmm7TmlrDpgLvovpHvvIzlpoLovazmjaLmlbDmja7nsbvlnovkuLrmlbDnu4RcclxuICAgKi9cclxuICBjdXN0b21WYWx1ZUNoYW5nZWQ/OiAoY2hhbmdlOiB7IGZpZWxkOiBzdHJpbmcsIHZhbHVlOiBhbnksIG9ubHlJbml0PzogYm9vbGVhbiB9KSA9PiB2b2lkO1xyXG4gIC8qKlxyXG4gICAqIOaJk+W8gOihqOWNleeahOe7hOS7tu+8jOS4gOiIrOeUqOS6juWIt+aWsOS4iuWxguihqOagvFxyXG4gICAqL1xyXG4gIG9wZW5lcjogYW55O1xyXG4gIC8qKlxyXG4gICAqIOihqOWNleWPquivu+eKtuaAge+8jOeUqOS6juWMuuWIhue7hOS7tuWPquivu+eKtuaAgVxyXG4gICAqL1xyXG4gIHJlYWRvbmx5OiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIHByb3RlY3RlZCBkZWZhdWx0VmFsdWVDaGFuZ2VkKGNoYW5nZTogeyBmaWVsZDogc3RyaW5nLCB2YWx1ZTogYW55LCBvbmx5SW5pdD86IGJvb2xlYW4gfSk6IHZvaWQge1xyXG4gICAgY29uc3QgdGhpc0ZpZWxkID0gKHRoaXMgYXMgYW55KS5maWVsZDtcclxuICAgIGlmICghdGhpc0ZpZWxkKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuICAgIGlmIChBcnJheS5pc0FycmF5KHRoaXNGaWVsZCkpIHtcclxuICAgICAgaWYgKCF0aGlzRmllbGQuaW5jbHVkZXMoY2hhbmdlLmZpZWxkKSkge1xyXG4gICAgICAgIHJldHVybjtcclxuICAgICAgfVxyXG4gICAgfSBlbHNlIGlmICh0aGlzRmllbGQgIT09IGNoYW5nZS5maWVsZCkge1xyXG4gICAgICByZXR1cm47XHJcbiAgICB9XHJcbiAgICBpZiAoKHRoaXMgYXMgYW55KS5jdXN0b21WYWx1ZUNoYW5nZWQpIHtcclxuICAgICAgKHRoaXMgYXMgYW55KS5jdXN0b21WYWx1ZUNoYW5nZWQoY2hhbmdlKTtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG4gICAgaWYgKGNoYW5nZS5vbmx5SW5pdCAmJiB0aGlzLm1vZGVsW2NoYW5nZS5maWVsZF0pIHtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG4gICAgdGhpcy5tb2RlbFtjaGFuZ2UuZmllbGRdID0gY2hhbmdlLnZhbHVlO1xyXG4gICAgdGhpcy5tb2RlbFZhbHVlQ2hhbmdlZD8uZW1pdCh7XHJcbiAgICAgIGZpZWxkOiB0aGlzRmllbGQsXHJcbiAgICAgIHZhbHVlOiBjaGFuZ2UuZmllbGRcclxuICAgIH0pO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, HostListener, Input, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import { WordDesignerService } from "./word-designer.service";
|
|
3
3
|
import { deepClone, notifySuccess } from "../../util/utils";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -52,6 +52,7 @@ export class WordDesignerComponent {
|
|
|
52
52
|
this.wordDesignerService = wordDesignerService;
|
|
53
53
|
this.viewContainerRef = viewContainerRef;
|
|
54
54
|
this.modalService = modalService;
|
|
55
|
+
this.onTemplateFileUploaded = new EventEmitter();
|
|
55
56
|
this.needUpload = false;
|
|
56
57
|
this.pasteMode = false;
|
|
57
58
|
this.mouseInViewer = false;
|
|
@@ -111,6 +112,7 @@ export class WordDesignerComponent {
|
|
|
111
112
|
this.uploadInput.nativeElement.value = '';
|
|
112
113
|
this.loadTemplateAndConfig(response);
|
|
113
114
|
this.loading = false;
|
|
115
|
+
this.onTemplateFileUploaded.emit();
|
|
114
116
|
});
|
|
115
117
|
}
|
|
116
118
|
openReplaceTemplateFileModal() {
|
|
@@ -176,7 +178,7 @@ export class WordDesignerComponent {
|
|
|
176
178
|
}
|
|
177
179
|
}
|
|
178
180
|
WordDesignerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerComponent, deps: [{ token: i1.SectionService }, { token: i2.WordDesignerService }, { token: i0.ViewContainerRef }, { token: i3.ModalService }], target: i0.ɵɵFactoryTarget.Component });
|
|
179
|
-
WordDesignerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: WordDesignerComponent, selector: "rs-word-designer", inputs: { tenant: "tenant", className: "className", oid: "oid", instanceClassName: "instanceClassName", filterCategories: "filterCategories", params: "params", tabViewContainerRef: "tabViewContainerRef" }, host: { listeners: { "window:keydown": "handleKeyDown($event)" } }, providers: [WordDesignerService], viewQueries: [{ propertyName: "uploadInput", first: true, predicate: ["uploadInput"], descendants: true, static: true }, { propertyName: "replaceFileModalTemplate", first: true, predicate: ["replaceFileModalTemplate"], descendants: true, static: true }, { propertyName: "previewTemplate", first: true, predicate: ["previewTemplate"], descendants: true, static: true }, { propertyName: "previewFooterTemplate", first: true, predicate: ["previewFooterTemplate"], descendants: true, static: true }], ngImport: i0, template: "<dx-load-panel [container]=\"viewContainerRef.element.nativeElement\" [showPane]=\"false\" [visible]=\"loading\">\n <dxo-position [of]=\"viewContainerRef.element.nativeElement\"></dxo-position>\n</dx-load-panel>\n<input #uploadInput type=\"file\" name=\"file\"\n accept=\"application/vnd.openxmlformats-officedocument.wordprocessingml.document\" (change)=\"upload()\"\n style=\"display: none;\"/>\n<div class=\"coast-card\">\n <div class=\"coast-card-content\">\n <div class=\"content-main\" [class.show-upload-btn]=\"needUpload\">\n <ng-container *ngIf=\"needUpload\">\n <dx-button type=\"success\" text=\"\u4E0A\u4F20\u6587\u4EF6\" (onClick)=\"uploadInput.click()\"></dx-button>\n </ng-container>\n <div *ngIf=\"!needUpload\" class=\"left-panel\">\n <div *ngIf=\"pasteMode\" class=\"paste-mode-bar\">\n <span\n class=\"message\">\u5DF2\u8FDB\u5165\u6279\u91CF\u7C98\u8D34\u914D\u7F6E\u6A21\u5F0F\uFF0C\u652F\u6301Ctrl\u3001Shift\u952E\u5FEB\u6377\u9009\u62E9\uFF0C\u6309Ctrl+V\u7EC4\u5408\u952E\u7C98\u8D34\u914D\u7F6E\uFF0C\u6309Esc\u952E\u53D6\u6D88\u64CD\u4F5C\u5E76\u9000\u51FA\u8BE5\u6A21\u5F0F</span>\n <dx-button [width]=\"48\" text=\"\u9000\u51FA\" (onClick)=\"exitPasteMode()\"></dx-button>\n </div>\n <div class=\"content\"\n (mouseenter)=\"mouseInViewer = true;\"\n (mouseleave)=\"mouseInViewer = false;\"\n (mousewheel)=\"scaleByMouse($event)\">\n <div *ngIf=\"!needUpload\" class=\"viewer\">\n <ng-container *ngFor=\"let section of sections\">\n <rs-section [section]=\"section\" [editMode]=\"true\" [pasteMode]=\"pasteMode\"></rs-section>\n </ng-container>\n </div>\n </div>\n </div>\n <div *ngIf=\"!needUpload\" class=\"right-panel\">\n <div class=\"header\">\n <dx-button type=\"default\" text=\"\u66FF\u6362\u6587\u4EF6\" (onClick)=\"openReplaceTemplateFileModal()\"\n [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-download\" hint=\"\u4E0B\u8F7D\u6587\u4EF6\"\n (onClick)=\"downloadTemplateFile()\" [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-direction-up\" hint=\"\u4E0A\u4E00\u4E2A(Alt + \u2191)\"\n (onClick)=\"service.switchMark(-1)\" [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-direction-down\" hint=\"\u4E0B\u4E00\u4E2A(Alt + \u2193)\"\n (onClick)=\"service.switchMark(1)\" [disabled]=\"loading\"></dx-button>\n <dx-button [type]=\"pasteMode ? 'success' : 'default'\" text=\"\u590D\u5236\" hint=\"\u590D\u5236(Ctrl + c)\"\n (onClick)=\"copyMarkConfig()\"></dx-button>\n <dx-button type=\"danger\" text=\"\u7C98\u8D34\" hint=\"\u7C98\u8D34(Ctrl + v)\" (onClick)=\"pasteMarkConfig()\"\n [disabled]=\"loading || !pasteMode\"></dx-button>\n </div>\n <div class=\"config\" *ngIf=\"service.activeMark\">\n <rs-mark-config [tenant]=\"tenant\"\n [templateClassName]=\"className\"\n [templateOid]=\"oid\"\n [instanceClassName]=\"instanceClassName\"\n [filterCategories]=\"filterCategories\"\n [mark]=\"service.activeMark\"\n [marks]=\"service.marks\"\n [tabViewContainerRef]=\"tabViewContainerRef\"></rs-mark-config>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!needUpload\" class=\"footer\">\n <div class=\"left\">\n <dx-button text=\"\u653E\u5927\" (onClick)=\"scale(0.1)\"></dx-button>\n <dx-button text=\"\u8FD8\u539F\" (onClick)=\"scale(0)\"></dx-button>\n <dx-button text=\"\u7F29\u5C0F\" (onClick)=\"scale(-0.1)\"></dx-button>\n </div>\n <div class=\"right\">\n <dx-button type=\"default\" text=\"\u9884\u89C8\" (onClick)=\"preview()\" [disabled]=\"needUpload || loading\"></dx-button>\n <dx-button type=\"success\" text=\"\u4FDD\u5B58\" (onClick)=\"saveConfig()\" [disabled]=\"needUpload || loading\"></dx-button>\n </div>\n </div>\n</div>\n<ng-template #replaceFileModalTemplate>\n <div class=\"confirm-message\">\n <span>\u66FF\u6362\u6587\u4EF6\u53EF\u4EE5\u6309\u7167\u4E66\u7B7E\u6807\u8BC6\u7EE7\u627F\u5DF2\u4FDD\u5B58\u7684\u4E66\u7B7E\u914D\u7F6E\uFF0C\u8BF7\u9009\u62E9\u64CD\u4F5C\uFF1A</span>\n </div>\n <div class=\"form-buttons\">\n <div class=\"buttons-wrapper\">\n <dx-button type=\"default\" text=\"\u7EE7\u627F\u914D\u7F6E\" (onClick)=\"replaceTemplateFile(true)\"></dx-button>\n <dx-button type=\"danger\" text=\"\u6E05\u9664\u914D\u7F6E\" (onClick)=\"replaceTemplateFile(false)\"></dx-button>\n <dx-button type=\"normal\" text=\"\u53D6\u6D88\" (onClick)=\"replaceFileModal?.hide()\"></dx-button>\n </div>\n </div>\n</ng-template>\n<ng-template #previewTemplate>\n <div class=\"preview-viewer\">\n <div class=\"viewer-container\">\n <div class=\"viewer\">\n <ng-container *ngFor=\"let section of sections\">\n <rs-section [section]=\"section\"></rs-section>\n </ng-container>\n </div>\n </div>\n </div>\n</ng-template>\n<ng-template #previewFooterTemplate>\n <div class=\"form-buttons\">\n <div class=\"buttons-wrapper\">\n <dx-button type=\"normal\" text=\"\u5173\u95ED\" (onClick)=\"previewModal?.hide()\"></dx-button>\n </div>\n </div>\n</ng-template>\n", styles: [":host{flex:1;display:flex;flex-flow:column nowrap}:host .coast-card{flex:1;padding:0}:host .coast-card .content-main{display:flex;flex-flow:row nowrap;padding:16px 0 0 16px;margin:0}:host .coast-card .content-main.show-upload-btn{padding:16px;background-color:var(--coast-empty-color, rgb(229, 229, 229));align-items:center;justify-content:center}:host .coast-card .content-main .left-panel{flex:auto;width:0;overflow-x:auto;background-color:var(--coast-empty-color, rgb(229, 229, 229));display:flex;flex-flow:column nowrap}:host .coast-card .content-main .left-panel .paste-mode-bar{flex:none;padding:8px;background-color:var(--coast-base-bg-color, rgb(255, 255, 255));border:1px solid var(--coast-border-color, rgb(221, 221, 221));display:flex;flex-flow:row nowrap;justify-content:space-between;align-items:center}:host .coast-card .content-main .left-panel .paste-mode-bar .message{font-weight:700}:host .coast-card .content-main .left-panel .content{flex:auto;height:0;overflow-y:auto;padding:8px 16px 0;display:flex;flex-flow:row nowrap}:host .coast-card .content-main .left-panel .content .viewer{margin:auto;display:flex;flex-flow:column nowrap;align-items:center;z-index:0}:host .coast-card .content-main .right-panel{flex:0 0 320px;display:flex;flex-flow:column nowrap;border-left:1px solid var(--coast-border-color, rgb(221, 221, 221))}:host .coast-card .content-main .right-panel .header{flex:none;border-bottom:1px solid var(--coast-border-color, rgb(221, 221, 221));padding:0 16px 16px}:host .coast-card .content-main .right-panel .header>dx-button:not(:last-child){margin-right:8px}:host .coast-card .content-main .right-panel .config{flex:auto;height:0;overflow:auto;padding:24px;display:flex;flex-flow:column nowrap}:host .coast-card .footer{flex:none;border-top:1px solid var(--coast-border-color, rgb(221, 221, 221));padding:12px 24px;display:flex;flex-flow:row nowrap;justify-content:space-between}:host .coast-card .footer dx-button{width:80px}:host .coast-card .footer dx-button:not(:last-child){margin-right:8px}.confirm-message{padding:24px;margin-bottom:12px;border-bottom:1px solid var(--coast-border-color, rgb(221, 221, 221))}.confirm-message span{font-size:14px}.preview-viewer{flex:auto;height:0;overflow-y:auto;margin:0 16px;background-color:var(--coast-empty-color, rgb(229, 229, 229));display:flex;flex-flow:column nowrap}.preview-viewer .viewer-container{flex:auto;height:0;overflow-x:auto;padding:8px 16px 0;display:flex;flex-flow:row nowrap}.preview-viewer .viewer-container .viewer{margin:auto;display:flex;flex-flow:column nowrap;align-items:center;z-index:0}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.DxoPositionComponent, selector: "dxo-position", inputs: ["at", "boundary", "boundaryOffset", "collision", "my", "of", "offset"] }, { kind: "component", type: i6.DxButtonComponent, selector: "dx-button", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"], outputs: ["onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "templateChange", "textChange", "typeChange", "useSubmitBehaviorChange", "validationGroupChange", "visibleChange", "widthChange"] }, { kind: "component", type: i7.DxLoadPanelComponent, selector: "dx-load-panel", inputs: ["animation", "closeOnOutsideClick", "container", "copyRootClassesToWrapper", "deferRendering", "delay", "elementAttr", "focusStateEnabled", "height", "hideOnOutsideClick", "hideOnParentScroll", "hint", "hoverStateEnabled", "indicatorSrc", "maxHeight", "maxWidth", "message", "minHeight", "minWidth", "position", "rtlEnabled", "shading", "shadingColor", "showIndicator", "showPane", "visible", "width", "wrapperAttr"], outputs: ["onContentReady", "onDisposing", "onHidden", "onHiding", "onInitialized", "onOptionChanged", "onShowing", "onShown", "animationChange", "closeOnOutsideClickChange", "containerChange", "copyRootClassesToWrapperChange", "deferRenderingChange", "delayChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hideOnOutsideClickChange", "hideOnParentScrollChange", "hintChange", "hoverStateEnabledChange", "indicatorSrcChange", "maxHeightChange", "maxWidthChange", "messageChange", "minHeightChange", "minWidthChange", "positionChange", "rtlEnabledChange", "shadingChange", "shadingColorChange", "showIndicatorChange", "showPaneChange", "visibleChange", "widthChange", "wrapperAttrChange"] }, { kind: "component", type: i8.SectionComponent, selector: "rs-section", inputs: ["section", "editMode", "pasteMode", "readonly"] }, { kind: "component", type: i9.MarkConfigComponent, selector: "rs-mark-config", inputs: ["tenant", "templateClassName", "templateOid", "instanceClassName", "filterCategories", "mark", "marks", "params", "tabViewContainerRef"] }] });
|
|
181
|
+
WordDesignerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: WordDesignerComponent, selector: "rs-word-designer", inputs: { tenant: "tenant", className: "className", oid: "oid", instanceClassName: "instanceClassName", filterCategories: "filterCategories", params: "params", tabViewContainerRef: "tabViewContainerRef" }, outputs: { onTemplateFileUploaded: "onTemplateFileUploaded" }, host: { listeners: { "window:keydown": "handleKeyDown($event)" } }, providers: [WordDesignerService], viewQueries: [{ propertyName: "uploadInput", first: true, predicate: ["uploadInput"], descendants: true, static: true }, { propertyName: "replaceFileModalTemplate", first: true, predicate: ["replaceFileModalTemplate"], descendants: true, static: true }, { propertyName: "previewTemplate", first: true, predicate: ["previewTemplate"], descendants: true, static: true }, { propertyName: "previewFooterTemplate", first: true, predicate: ["previewFooterTemplate"], descendants: true, static: true }], ngImport: i0, template: "<dx-load-panel [container]=\"viewContainerRef.element.nativeElement\" [showPane]=\"false\" [visible]=\"loading\">\n <dxo-position [of]=\"viewContainerRef.element.nativeElement\"></dxo-position>\n</dx-load-panel>\n<input #uploadInput type=\"file\" name=\"file\"\n accept=\"application/vnd.openxmlformats-officedocument.wordprocessingml.document\" (change)=\"upload()\"\n style=\"display: none;\"/>\n<div class=\"coast-card\">\n <div class=\"coast-card-content\">\n <div class=\"content-main\" [class.show-upload-btn]=\"needUpload\">\n <ng-container *ngIf=\"needUpload\">\n <dx-button type=\"success\" text=\"\u4E0A\u4F20\u6587\u4EF6\" (onClick)=\"uploadInput.click()\"></dx-button>\n </ng-container>\n <div *ngIf=\"!needUpload\" class=\"left-panel\">\n <div *ngIf=\"pasteMode\" class=\"paste-mode-bar\">\n <span\n class=\"message\">\u5DF2\u8FDB\u5165\u6279\u91CF\u7C98\u8D34\u914D\u7F6E\u6A21\u5F0F\uFF0C\u652F\u6301Ctrl\u3001Shift\u952E\u5FEB\u6377\u9009\u62E9\uFF0C\u6309Ctrl+V\u7EC4\u5408\u952E\u7C98\u8D34\u914D\u7F6E\uFF0C\u6309Esc\u952E\u53D6\u6D88\u64CD\u4F5C\u5E76\u9000\u51FA\u8BE5\u6A21\u5F0F</span>\n <dx-button [width]=\"48\" text=\"\u9000\u51FA\" (onClick)=\"exitPasteMode()\"></dx-button>\n </div>\n <div class=\"content\"\n (mouseenter)=\"mouseInViewer = true;\"\n (mouseleave)=\"mouseInViewer = false;\"\n (mousewheel)=\"scaleByMouse($event)\">\n <div *ngIf=\"!needUpload\" class=\"viewer\">\n <ng-container *ngFor=\"let section of sections\">\n <rs-section [section]=\"section\" [editMode]=\"true\" [pasteMode]=\"pasteMode\"></rs-section>\n </ng-container>\n </div>\n </div>\n </div>\n <div *ngIf=\"!needUpload\" class=\"right-panel\">\n <div class=\"header\">\n <dx-button type=\"default\" text=\"\u66FF\u6362\u6587\u4EF6\" (onClick)=\"openReplaceTemplateFileModal()\"\n [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-download\" hint=\"\u4E0B\u8F7D\u6587\u4EF6\"\n (onClick)=\"downloadTemplateFile()\" [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-direction-up\" hint=\"\u4E0A\u4E00\u4E2A(Alt + \u2191)\"\n (onClick)=\"service.switchMark(-1)\" [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-direction-down\" hint=\"\u4E0B\u4E00\u4E2A(Alt + \u2193)\"\n (onClick)=\"service.switchMark(1)\" [disabled]=\"loading\"></dx-button>\n <dx-button [type]=\"pasteMode ? 'success' : 'default'\" text=\"\u590D\u5236\" hint=\"\u590D\u5236(Ctrl + c)\"\n (onClick)=\"copyMarkConfig()\"></dx-button>\n <dx-button type=\"danger\" text=\"\u7C98\u8D34\" hint=\"\u7C98\u8D34(Ctrl + v)\" (onClick)=\"pasteMarkConfig()\"\n [disabled]=\"loading || !pasteMode\"></dx-button>\n </div>\n <div class=\"config\" *ngIf=\"service.activeMark\">\n <rs-mark-config [tenant]=\"tenant\"\n [templateClassName]=\"className\"\n [templateOid]=\"oid\"\n [instanceClassName]=\"instanceClassName\"\n [filterCategories]=\"filterCategories\"\n [mark]=\"service.activeMark\"\n [marks]=\"service.marks\"\n [tabViewContainerRef]=\"tabViewContainerRef\"></rs-mark-config>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!needUpload\" class=\"footer\">\n <div class=\"left\">\n <dx-button text=\"\u653E\u5927\" (onClick)=\"scale(0.1)\"></dx-button>\n <dx-button text=\"\u8FD8\u539F\" (onClick)=\"scale(0)\"></dx-button>\n <dx-button text=\"\u7F29\u5C0F\" (onClick)=\"scale(-0.1)\"></dx-button>\n </div>\n <div class=\"right\">\n <dx-button type=\"default\" text=\"\u9884\u89C8\" (onClick)=\"preview()\" [disabled]=\"needUpload || loading\"></dx-button>\n <dx-button type=\"success\" text=\"\u4FDD\u5B58\" (onClick)=\"saveConfig()\" [disabled]=\"needUpload || loading\"></dx-button>\n </div>\n </div>\n</div>\n<ng-template #replaceFileModalTemplate>\n <div class=\"confirm-message\">\n <span>\u66FF\u6362\u6587\u4EF6\u53EF\u4EE5\u6309\u7167\u4E66\u7B7E\u6807\u8BC6\u7EE7\u627F\u5DF2\u4FDD\u5B58\u7684\u4E66\u7B7E\u914D\u7F6E\uFF0C\u8BF7\u9009\u62E9\u64CD\u4F5C\uFF1A</span>\n </div>\n <div class=\"form-buttons\">\n <div class=\"buttons-wrapper\">\n <dx-button type=\"default\" text=\"\u7EE7\u627F\u914D\u7F6E\" (onClick)=\"replaceTemplateFile(true)\"></dx-button>\n <dx-button type=\"danger\" text=\"\u6E05\u9664\u914D\u7F6E\" (onClick)=\"replaceTemplateFile(false)\"></dx-button>\n <dx-button type=\"normal\" text=\"\u53D6\u6D88\" (onClick)=\"replaceFileModal?.hide()\"></dx-button>\n </div>\n </div>\n</ng-template>\n<ng-template #previewTemplate>\n <div class=\"preview-viewer\">\n <div class=\"viewer-container\">\n <div class=\"viewer\">\n <ng-container *ngFor=\"let section of sections\">\n <rs-section [section]=\"section\"></rs-section>\n </ng-container>\n </div>\n </div>\n </div>\n</ng-template>\n<ng-template #previewFooterTemplate>\n <div class=\"form-buttons\">\n <div class=\"buttons-wrapper\">\n <dx-button type=\"normal\" text=\"\u5173\u95ED\" (onClick)=\"previewModal?.hide()\"></dx-button>\n </div>\n </div>\n</ng-template>\n", styles: [":host{flex:1;display:flex;flex-flow:column nowrap}:host .coast-card{flex:1;padding:0}:host .coast-card .content-main{display:flex;flex-flow:row nowrap;padding:16px 0 0 16px;margin:0}:host .coast-card .content-main.show-upload-btn{padding:16px;background-color:var(--coast-empty-color, rgb(229, 229, 229));align-items:center;justify-content:center}:host .coast-card .content-main .left-panel{flex:auto;width:0;overflow-x:auto;background-color:var(--coast-empty-color, rgb(229, 229, 229));display:flex;flex-flow:column nowrap}:host .coast-card .content-main .left-panel .paste-mode-bar{flex:none;padding:8px;background-color:var(--coast-base-bg-color, rgb(255, 255, 255));border:1px solid var(--coast-border-color, rgb(221, 221, 221));display:flex;flex-flow:row nowrap;justify-content:space-between;align-items:center}:host .coast-card .content-main .left-panel .paste-mode-bar .message{font-weight:700}:host .coast-card .content-main .left-panel .content{flex:auto;height:0;overflow-y:auto;padding:8px 16px 0;display:flex;flex-flow:row nowrap}:host .coast-card .content-main .left-panel .content .viewer{margin:auto;display:flex;flex-flow:column nowrap;align-items:center;z-index:0}:host .coast-card .content-main .right-panel{flex:0 0 320px;display:flex;flex-flow:column nowrap;border-left:1px solid var(--coast-border-color, rgb(221, 221, 221))}:host .coast-card .content-main .right-panel .header{flex:none;border-bottom:1px solid var(--coast-border-color, rgb(221, 221, 221));padding:0 16px 16px}:host .coast-card .content-main .right-panel .header>dx-button:not(:last-child){margin-right:8px}:host .coast-card .content-main .right-panel .config{flex:auto;height:0;overflow:auto;padding:24px;display:flex;flex-flow:column nowrap}:host .coast-card .footer{flex:none;border-top:1px solid var(--coast-border-color, rgb(221, 221, 221));padding:12px 24px;display:flex;flex-flow:row nowrap;justify-content:space-between}:host .coast-card .footer dx-button{width:80px}:host .coast-card .footer dx-button:not(:last-child){margin-right:8px}.confirm-message{padding:24px;margin-bottom:12px;border-bottom:1px solid var(--coast-border-color, rgb(221, 221, 221))}.confirm-message span{font-size:14px}.preview-viewer{flex:auto;height:0;overflow-y:auto;margin:0 16px;background-color:var(--coast-empty-color, rgb(229, 229, 229));display:flex;flex-flow:column nowrap}.preview-viewer .viewer-container{flex:auto;height:0;overflow-x:auto;padding:8px 16px 0;display:flex;flex-flow:row nowrap}.preview-viewer .viewer-container .viewer{margin:auto;display:flex;flex-flow:column nowrap;align-items:center;z-index:0}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.DxoPositionComponent, selector: "dxo-position", inputs: ["at", "boundary", "boundaryOffset", "collision", "my", "of", "offset"] }, { kind: "component", type: i6.DxButtonComponent, selector: "dx-button", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"], outputs: ["onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "templateChange", "textChange", "typeChange", "useSubmitBehaviorChange", "validationGroupChange", "visibleChange", "widthChange"] }, { kind: "component", type: i7.DxLoadPanelComponent, selector: "dx-load-panel", inputs: ["animation", "closeOnOutsideClick", "container", "copyRootClassesToWrapper", "deferRendering", "delay", "elementAttr", "focusStateEnabled", "height", "hideOnOutsideClick", "hideOnParentScroll", "hint", "hoverStateEnabled", "indicatorSrc", "maxHeight", "maxWidth", "message", "minHeight", "minWidth", "position", "rtlEnabled", "shading", "shadingColor", "showIndicator", "showPane", "visible", "width", "wrapperAttr"], outputs: ["onContentReady", "onDisposing", "onHidden", "onHiding", "onInitialized", "onOptionChanged", "onShowing", "onShown", "animationChange", "closeOnOutsideClickChange", "containerChange", "copyRootClassesToWrapperChange", "deferRenderingChange", "delayChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hideOnOutsideClickChange", "hideOnParentScrollChange", "hintChange", "hoverStateEnabledChange", "indicatorSrcChange", "maxHeightChange", "maxWidthChange", "messageChange", "minHeightChange", "minWidthChange", "positionChange", "rtlEnabledChange", "shadingChange", "shadingColorChange", "showIndicatorChange", "showPaneChange", "visibleChange", "widthChange", "wrapperAttrChange"] }, { kind: "component", type: i8.SectionComponent, selector: "rs-section", inputs: ["section", "editMode", "pasteMode", "readonly"] }, { kind: "component", type: i9.MarkConfigComponent, selector: "rs-mark-config", inputs: ["tenant", "templateClassName", "templateOid", "instanceClassName", "filterCategories", "mark", "marks", "params", "tabViewContainerRef"] }] });
|
|
180
182
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerComponent, decorators: [{
|
|
181
183
|
type: Component,
|
|
182
184
|
args: [{ selector: 'rs-word-designer', providers: [WordDesignerService], template: "<dx-load-panel [container]=\"viewContainerRef.element.nativeElement\" [showPane]=\"false\" [visible]=\"loading\">\n <dxo-position [of]=\"viewContainerRef.element.nativeElement\"></dxo-position>\n</dx-load-panel>\n<input #uploadInput type=\"file\" name=\"file\"\n accept=\"application/vnd.openxmlformats-officedocument.wordprocessingml.document\" (change)=\"upload()\"\n style=\"display: none;\"/>\n<div class=\"coast-card\">\n <div class=\"coast-card-content\">\n <div class=\"content-main\" [class.show-upload-btn]=\"needUpload\">\n <ng-container *ngIf=\"needUpload\">\n <dx-button type=\"success\" text=\"\u4E0A\u4F20\u6587\u4EF6\" (onClick)=\"uploadInput.click()\"></dx-button>\n </ng-container>\n <div *ngIf=\"!needUpload\" class=\"left-panel\">\n <div *ngIf=\"pasteMode\" class=\"paste-mode-bar\">\n <span\n class=\"message\">\u5DF2\u8FDB\u5165\u6279\u91CF\u7C98\u8D34\u914D\u7F6E\u6A21\u5F0F\uFF0C\u652F\u6301Ctrl\u3001Shift\u952E\u5FEB\u6377\u9009\u62E9\uFF0C\u6309Ctrl+V\u7EC4\u5408\u952E\u7C98\u8D34\u914D\u7F6E\uFF0C\u6309Esc\u952E\u53D6\u6D88\u64CD\u4F5C\u5E76\u9000\u51FA\u8BE5\u6A21\u5F0F</span>\n <dx-button [width]=\"48\" text=\"\u9000\u51FA\" (onClick)=\"exitPasteMode()\"></dx-button>\n </div>\n <div class=\"content\"\n (mouseenter)=\"mouseInViewer = true;\"\n (mouseleave)=\"mouseInViewer = false;\"\n (mousewheel)=\"scaleByMouse($event)\">\n <div *ngIf=\"!needUpload\" class=\"viewer\">\n <ng-container *ngFor=\"let section of sections\">\n <rs-section [section]=\"section\" [editMode]=\"true\" [pasteMode]=\"pasteMode\"></rs-section>\n </ng-container>\n </div>\n </div>\n </div>\n <div *ngIf=\"!needUpload\" class=\"right-panel\">\n <div class=\"header\">\n <dx-button type=\"default\" text=\"\u66FF\u6362\u6587\u4EF6\" (onClick)=\"openReplaceTemplateFileModal()\"\n [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-download\" hint=\"\u4E0B\u8F7D\u6587\u4EF6\"\n (onClick)=\"downloadTemplateFile()\" [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-direction-up\" hint=\"\u4E0A\u4E00\u4E2A(Alt + \u2191)\"\n (onClick)=\"service.switchMark(-1)\" [disabled]=\"loading\"></dx-button>\n <dx-button icon=\"coast-icon coast-icon-direction-down\" hint=\"\u4E0B\u4E00\u4E2A(Alt + \u2193)\"\n (onClick)=\"service.switchMark(1)\" [disabled]=\"loading\"></dx-button>\n <dx-button [type]=\"pasteMode ? 'success' : 'default'\" text=\"\u590D\u5236\" hint=\"\u590D\u5236(Ctrl + c)\"\n (onClick)=\"copyMarkConfig()\"></dx-button>\n <dx-button type=\"danger\" text=\"\u7C98\u8D34\" hint=\"\u7C98\u8D34(Ctrl + v)\" (onClick)=\"pasteMarkConfig()\"\n [disabled]=\"loading || !pasteMode\"></dx-button>\n </div>\n <div class=\"config\" *ngIf=\"service.activeMark\">\n <rs-mark-config [tenant]=\"tenant\"\n [templateClassName]=\"className\"\n [templateOid]=\"oid\"\n [instanceClassName]=\"instanceClassName\"\n [filterCategories]=\"filterCategories\"\n [mark]=\"service.activeMark\"\n [marks]=\"service.marks\"\n [tabViewContainerRef]=\"tabViewContainerRef\"></rs-mark-config>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!needUpload\" class=\"footer\">\n <div class=\"left\">\n <dx-button text=\"\u653E\u5927\" (onClick)=\"scale(0.1)\"></dx-button>\n <dx-button text=\"\u8FD8\u539F\" (onClick)=\"scale(0)\"></dx-button>\n <dx-button text=\"\u7F29\u5C0F\" (onClick)=\"scale(-0.1)\"></dx-button>\n </div>\n <div class=\"right\">\n <dx-button type=\"default\" text=\"\u9884\u89C8\" (onClick)=\"preview()\" [disabled]=\"needUpload || loading\"></dx-button>\n <dx-button type=\"success\" text=\"\u4FDD\u5B58\" (onClick)=\"saveConfig()\" [disabled]=\"needUpload || loading\"></dx-button>\n </div>\n </div>\n</div>\n<ng-template #replaceFileModalTemplate>\n <div class=\"confirm-message\">\n <span>\u66FF\u6362\u6587\u4EF6\u53EF\u4EE5\u6309\u7167\u4E66\u7B7E\u6807\u8BC6\u7EE7\u627F\u5DF2\u4FDD\u5B58\u7684\u4E66\u7B7E\u914D\u7F6E\uFF0C\u8BF7\u9009\u62E9\u64CD\u4F5C\uFF1A</span>\n </div>\n <div class=\"form-buttons\">\n <div class=\"buttons-wrapper\">\n <dx-button type=\"default\" text=\"\u7EE7\u627F\u914D\u7F6E\" (onClick)=\"replaceTemplateFile(true)\"></dx-button>\n <dx-button type=\"danger\" text=\"\u6E05\u9664\u914D\u7F6E\" (onClick)=\"replaceTemplateFile(false)\"></dx-button>\n <dx-button type=\"normal\" text=\"\u53D6\u6D88\" (onClick)=\"replaceFileModal?.hide()\"></dx-button>\n </div>\n </div>\n</ng-template>\n<ng-template #previewTemplate>\n <div class=\"preview-viewer\">\n <div class=\"viewer-container\">\n <div class=\"viewer\">\n <ng-container *ngFor=\"let section of sections\">\n <rs-section [section]=\"section\"></rs-section>\n </ng-container>\n </div>\n </div>\n </div>\n</ng-template>\n<ng-template #previewFooterTemplate>\n <div class=\"form-buttons\">\n <div class=\"buttons-wrapper\">\n <dx-button type=\"normal\" text=\"\u5173\u95ED\" (onClick)=\"previewModal?.hide()\"></dx-button>\n </div>\n </div>\n</ng-template>\n", styles: [":host{flex:1;display:flex;flex-flow:column nowrap}:host .coast-card{flex:1;padding:0}:host .coast-card .content-main{display:flex;flex-flow:row nowrap;padding:16px 0 0 16px;margin:0}:host .coast-card .content-main.show-upload-btn{padding:16px;background-color:var(--coast-empty-color, rgb(229, 229, 229));align-items:center;justify-content:center}:host .coast-card .content-main .left-panel{flex:auto;width:0;overflow-x:auto;background-color:var(--coast-empty-color, rgb(229, 229, 229));display:flex;flex-flow:column nowrap}:host .coast-card .content-main .left-panel .paste-mode-bar{flex:none;padding:8px;background-color:var(--coast-base-bg-color, rgb(255, 255, 255));border:1px solid var(--coast-border-color, rgb(221, 221, 221));display:flex;flex-flow:row nowrap;justify-content:space-between;align-items:center}:host .coast-card .content-main .left-panel .paste-mode-bar .message{font-weight:700}:host .coast-card .content-main .left-panel .content{flex:auto;height:0;overflow-y:auto;padding:8px 16px 0;display:flex;flex-flow:row nowrap}:host .coast-card .content-main .left-panel .content .viewer{margin:auto;display:flex;flex-flow:column nowrap;align-items:center;z-index:0}:host .coast-card .content-main .right-panel{flex:0 0 320px;display:flex;flex-flow:column nowrap;border-left:1px solid var(--coast-border-color, rgb(221, 221, 221))}:host .coast-card .content-main .right-panel .header{flex:none;border-bottom:1px solid var(--coast-border-color, rgb(221, 221, 221));padding:0 16px 16px}:host .coast-card .content-main .right-panel .header>dx-button:not(:last-child){margin-right:8px}:host .coast-card .content-main .right-panel .config{flex:auto;height:0;overflow:auto;padding:24px;display:flex;flex-flow:column nowrap}:host .coast-card .footer{flex:none;border-top:1px solid var(--coast-border-color, rgb(221, 221, 221));padding:12px 24px;display:flex;flex-flow:row nowrap;justify-content:space-between}:host .coast-card .footer dx-button{width:80px}:host .coast-card .footer dx-button:not(:last-child){margin-right:8px}.confirm-message{padding:24px;margin-bottom:12px;border-bottom:1px solid var(--coast-border-color, rgb(221, 221, 221))}.confirm-message span{font-size:14px}.preview-viewer{flex:auto;height:0;overflow-y:auto;margin:0 16px;background-color:var(--coast-empty-color, rgb(229, 229, 229));display:flex;flex-flow:column nowrap}.preview-viewer .viewer-container{flex:auto;height:0;overflow-x:auto;padding:8px 16px 0;display:flex;flex-flow:row nowrap}.preview-viewer .viewer-container .viewer{margin:auto;display:flex;flex-flow:column nowrap;align-items:center;z-index:0}\n"] }]
|
|
@@ -194,6 +196,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
194
196
|
type: Input
|
|
195
197
|
}], tabViewContainerRef: [{
|
|
196
198
|
type: Input
|
|
199
|
+
}], onTemplateFileUploaded: [{
|
|
200
|
+
type: Output
|
|
197
201
|
}], uploadInput: [{
|
|
198
202
|
type: ViewChild,
|
|
199
203
|
args: ['uploadInput', { static: true }]
|
|
@@ -210,4 +214,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
210
214
|
type: HostListener,
|
|
211
215
|
args: ['window:keydown', ['$event']]
|
|
212
216
|
}] } });
|
|
213
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"word-designer.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-rs-ant/src/word/word-designer/word-designer.component.ts","../../../../../projects/ngx-rs-ant/src/word/word-designer/word-designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, HostListener, Input, TemplateRef, ViewChild, ViewContainerRef} from '@angular/core';\nimport {ModalComponent} from \"../../modal/modal.component\";\nimport {WordDesignerService} from \"./word-designer.service\";\nimport {ModalService} from \"../../modal/modal.service\";\nimport {SectionService} from \"../section/section.service\";\nimport {deepClone, notifySuccess} from \"../../util/utils\";\n\n@Component({\n  selector: 'rs-word-designer',\n  templateUrl: './word-designer.component.html',\n  styleUrls: ['./word-designer.component.scss'],\n  providers: [WordDesignerService]\n})\nexport class WordDesignerComponent {\n  @Input()\n  tenant: any;\n  @Input()\n  className: any;\n  @Input()\n  oid: any;\n  @Input()\n  instanceClassName: any;\n  @Input()\n  filterCategories?: string[];\n  @Input()\n  params?: any;\n  @Input()\n  tabViewContainerRef!: any;\n  protected sections: any;\n  protected needUpload = false;\n  protected pasteMode = false;\n  protected mouseInViewer = false;\n  protected loading = false;\n  protected replaceFileModal?: ModalComponent;\n  protected retainMarkConfig = false;\n  protected previewModal?: ModalComponent;\n  @ViewChild('uploadInput', {static: true}) uploadInput!: ElementRef;\n  @ViewChild('replaceFileModalTemplate', {static: true}) replaceFileModalTemplate!: TemplateRef<any>;\n  @ViewChild('previewTemplate', {static: true}) previewTemplate!: TemplateRef<any>;\n  @ViewChild('previewFooterTemplate', {static: true}) previewFooterTemplate!: TemplateRef<any>;\n\n  @HostListener('window:keydown', ['$event'])\n  handleKeyDown($event: KeyboardEvent) {\n    switch ($event.code) {\n      case 'ArrowUp':\n        if ($event.altKey) {\n          this.service.switchMark(-1);\n        }\n        break;\n      case 'ArrowDown':\n        if ($event.altKey) {\n          this.service.switchMark(1);\n        }\n        break;\n      case 'KeyC':\n        if ($event.ctrlKey) {\n          const selection = window.getSelection();\n          if (selection?.toString()) {\n            return;\n          }\n          this.copyMarkConfig();\n        }\n        break;\n      case 'KeyV':\n        if ($event.ctrlKey) {\n          this.pasteMarkConfig();\n        }\n        break;\n      case 'Escape':\n        this.exitPasteMode();\n        break;\n    }\n    if (this.mouseInViewer && $event.ctrlKey && $event.key === '0') {\n      $event.preventDefault();\n      this.scale(0);\n    }\n  }\n\n  constructor(protected service: SectionService, private wordDesignerService: WordDesignerService,\n              protected viewContainerRef: ViewContainerRef, private modalService: ModalService) {\n  }\n\n  ngOnInit() {\n    this.service.tenant = this.tenant;\n    this.service.templateClassName = this.className;\n    this.service.templateOid = this.oid;\n    this.service.instanceClassName = this.instanceClassName;\n    this.service.params = this.params;\n    this.service.tabViewContainerRef = this.tabViewContainerRef;\n    this.loading = true;\n    this.wordDesignerService.loadTemplate(this.tenant, this.className, this.oid).subscribe(response => {\n      this.loadTemplateAndConfig(response);\n      this.loading = false;\n    });\n  }\n\n  ngOnDestroy() {\n    this.service.valueUpdated.unsubscribe();\n    this.service.valueChanged.unsubscribe();\n  }\n\n  loadTemplateAndConfig(response: any) {\n    this.sections = response.sections || [];\n    if (this.sections.length === 0) {\n      this.needUpload = true;\n      this.loading = false;\n      return;\n    }\n    this.needUpload = false;\n    this.service.marks = response.marks.map((mark: any) => {\n      mark.config = mark.config || {};\n      return mark;\n    });\n    if (this.service.marks.length > 0) {\n      this.service.activeMark = this.service.marks[0];\n    }\n  }\n\n  scaleByMouse($event: any) {\n    if ($event.ctrlKey) {\n      $event.preventDefault();\n      this.scale($event.deltaY < 0 ? 0.1 : -0.1);\n    }\n  }\n\n  scale(type: number) {\n    if (type === 0) {\n      this.service.scale = 1;\n    } else {\n      this.service.scale += type;\n    }\n  }\n\n  upload() {\n    this.loading = true;\n    this.wordDesignerService.uploadTemplateFile(this.tenant, this.className, this.oid, this.retainMarkConfig, this.uploadInput.nativeElement.files[0]).subscribe(response => {\n      this.uploadInput.nativeElement.value = '';\n      this.loadTemplateAndConfig(response);\n      this.loading = false;\n    });\n  }\n\n  openReplaceTemplateFileModal() {\n    this.replaceFileModal = this.modalService.open(this.tabViewContainerRef, '替换文件', 'default', this.replaceFileModalTemplate, {});\n  }\n\n  replaceTemplateFile(retainMarkConfig: boolean) {\n    this.retainMarkConfig = retainMarkConfig;\n    this.uploadInput.nativeElement.click();\n    this.replaceFileModal?.hide();\n  }\n\n  downloadTemplateFile() {\n    this.loading = true;\n    this.wordDesignerService.downloadTemplateFile(this.tenant, this.className, this.oid, () => {\n      this.loading = false;\n    });\n  }\n\n  preview() {\n    for (let mark of this.service.marks) {\n      mark.value = undefined;\n    }\n    this.previewModal = this.modalService.open(this.tabViewContainerRef, '预览', 'full',\n      this.previewTemplate, {}, this.previewFooterTemplate);\n  }\n\n  saveConfig() {\n    this.loading = true;\n    this.service.marks.map(mark => {\n      delete mark.value;\n    });\n    this.wordDesignerService.save(this.tenant, this.className, this.oid, {\n      templateConfig: JSON.stringify({\n        sections: this.sections,\n        marks: this.service.marks\n      })\n    }).subscribe(response => {\n      if (response.success) {\n        notifySuccess('保存成功');\n        this.loading = false;\n      }\n    });\n  }\n\n  copyMarkConfig() {\n    if (this.service.activeMark.type) {\n      this.service.copiedMark = deepClone(this.service.activeMark);\n      this.pasteMode = true;\n    }\n  }\n\n  exitPasteMode() {\n    this.service.copiedMark = {};\n    this.service.readyPasteMarkNames = [];\n    this.service.lastClickToPasteMarkName = '';\n    this.pasteMode = false;\n  }\n\n  pasteMarkConfig() {\n    let readyPasteMark;\n    for (let readyPasteMarkName of this.service.readyPasteMarkNames) {\n      readyPasteMark = this.service.getMark(readyPasteMarkName);\n      const display = readyPasteMark.display;\n      Object.assign(readyPasteMark, deepClone(this.service.copiedMark));\n      readyPasteMark.name = readyPasteMarkName;\n      readyPasteMark.display = display;\n    }\n    this.service.activeMark = readyPasteMark || this.service.activeMark;\n    this.exitPasteMode();\n  }\n}\n","<dx-load-panel [container]=\"viewContainerRef.element.nativeElement\" [showPane]=\"false\" [visible]=\"loading\">\n  <dxo-position [of]=\"viewContainerRef.element.nativeElement\"></dxo-position>\n</dx-load-panel>\n<input #uploadInput type=\"file\" name=\"file\"\n       accept=\"application/vnd.openxmlformats-officedocument.wordprocessingml.document\" (change)=\"upload()\"\n       style=\"display: none;\"/>\n<div class=\"coast-card\">\n  <div class=\"coast-card-content\">\n    <div class=\"content-main\" [class.show-upload-btn]=\"needUpload\">\n      <ng-container *ngIf=\"needUpload\">\n        <dx-button type=\"success\" text=\"上传文件\" (onClick)=\"uploadInput.click()\"></dx-button>\n      </ng-container>\n      <div *ngIf=\"!needUpload\" class=\"left-panel\">\n        <div *ngIf=\"pasteMode\" class=\"paste-mode-bar\">\n          <span\n            class=\"message\">已进入批量粘贴配置模式，支持Ctrl、Shift键快捷选择，按Ctrl+V组合键粘贴配置，按Esc键取消操作并退出该模式</span>\n          <dx-button [width]=\"48\" text=\"退出\" (onClick)=\"exitPasteMode()\"></dx-button>\n        </div>\n        <div class=\"content\"\n             (mouseenter)=\"mouseInViewer = true;\"\n             (mouseleave)=\"mouseInViewer = false;\"\n             (mousewheel)=\"scaleByMouse($event)\">\n          <div *ngIf=\"!needUpload\" class=\"viewer\">\n            <ng-container *ngFor=\"let section of sections\">\n              <rs-section [section]=\"section\" [editMode]=\"true\" [pasteMode]=\"pasteMode\"></rs-section>\n            </ng-container>\n          </div>\n        </div>\n      </div>\n      <div *ngIf=\"!needUpload\" class=\"right-panel\">\n        <div class=\"header\">\n          <dx-button type=\"default\" text=\"替换文件\" (onClick)=\"openReplaceTemplateFileModal()\"\n                     [disabled]=\"loading\"></dx-button>\n          <dx-button icon=\"coast-icon coast-icon-download\" hint=\"下载文件\"\n                     (onClick)=\"downloadTemplateFile()\" [disabled]=\"loading\"></dx-button>\n          <dx-button icon=\"coast-icon coast-icon-direction-up\" hint=\"上一个(Alt + ↑)\"\n                     (onClick)=\"service.switchMark(-1)\" [disabled]=\"loading\"></dx-button>\n          <dx-button icon=\"coast-icon coast-icon-direction-down\" hint=\"下一个(Alt + ↓)\"\n                     (onClick)=\"service.switchMark(1)\" [disabled]=\"loading\"></dx-button>\n          <dx-button [type]=\"pasteMode ? 'success' : 'default'\" text=\"复制\" hint=\"复制(Ctrl + c)\"\n                     (onClick)=\"copyMarkConfig()\"></dx-button>\n          <dx-button type=\"danger\" text=\"粘贴\" hint=\"粘贴(Ctrl + v)\" (onClick)=\"pasteMarkConfig()\"\n                     [disabled]=\"loading || !pasteMode\"></dx-button>\n        </div>\n        <div class=\"config\" *ngIf=\"service.activeMark\">\n          <rs-mark-config [tenant]=\"tenant\"\n                          [templateClassName]=\"className\"\n                          [templateOid]=\"oid\"\n                          [instanceClassName]=\"instanceClassName\"\n                          [filterCategories]=\"filterCategories\"\n                          [mark]=\"service.activeMark\"\n                          [marks]=\"service.marks\"\n                          [tabViewContainerRef]=\"tabViewContainerRef\"></rs-mark-config>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div *ngIf=\"!needUpload\" class=\"footer\">\n    <div class=\"left\">\n      <dx-button text=\"放大\" (onClick)=\"scale(0.1)\"></dx-button>\n      <dx-button text=\"还原\" (onClick)=\"scale(0)\"></dx-button>\n      <dx-button text=\"缩小\" (onClick)=\"scale(-0.1)\"></dx-button>\n    </div>\n    <div class=\"right\">\n      <dx-button type=\"default\" text=\"预览\" (onClick)=\"preview()\" [disabled]=\"needUpload || loading\"></dx-button>\n      <dx-button type=\"success\" text=\"保存\" (onClick)=\"saveConfig()\" [disabled]=\"needUpload || loading\"></dx-button>\n    </div>\n  </div>\n</div>\n<ng-template #replaceFileModalTemplate>\n  <div class=\"confirm-message\">\n    <span>替换文件可以按照书签标识继承已保存的书签配置，请选择操作：</span>\n  </div>\n  <div class=\"form-buttons\">\n    <div class=\"buttons-wrapper\">\n      <dx-button type=\"default\" text=\"继承配置\" (onClick)=\"replaceTemplateFile(true)\"></dx-button>\n      <dx-button type=\"danger\" text=\"清除配置\" (onClick)=\"replaceTemplateFile(false)\"></dx-button>\n      <dx-button type=\"normal\" text=\"取消\" (onClick)=\"replaceFileModal?.hide()\"></dx-button>\n    </div>\n  </div>\n</ng-template>\n<ng-template #previewTemplate>\n  <div class=\"preview-viewer\">\n    <div class=\"viewer-container\">\n      <div class=\"viewer\">\n        <ng-container *ngFor=\"let section of sections\">\n          <rs-section [section]=\"section\"></rs-section>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n</ng-template>\n<ng-template #previewFooterTemplate>\n  <div class=\"form-buttons\">\n    <div class=\"buttons-wrapper\">\n      <dx-button type=\"normal\" text=\"关闭\" (onClick)=\"previewModal?.hide()\"></dx-button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"word-designer.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-rs-ant/src/word/word-designer/word-designer.component.ts","../../../../../projects/ngx-rs-ant/src/word/word-designer/word-designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport {ModalComponent} from \"../../modal/modal.component\";\nimport {WordDesignerService} from \"./word-designer.service\";\nimport {ModalService} from \"../../modal/modal.service\";\nimport {SectionService} from \"../section/section.service\";\nimport {deepClone, notifySuccess} from \"../../util/utils\";\n\n@Component({\n  selector: 'rs-word-designer',\n  templateUrl: './word-designer.component.html',\n  styleUrls: ['./word-designer.component.scss'],\n  providers: [WordDesignerService]\n})\nexport class WordDesignerComponent {\n  @Input()\n  tenant: any;\n  @Input()\n  className: any;\n  @Input()\n  oid: any;\n  @Input()\n  instanceClassName: any;\n  @Input()\n  filterCategories?: string[];\n  @Input()\n  params?: any;\n  @Input()\n  tabViewContainerRef!: any;\n  @Output()\n  onTemplateFileUploaded = new EventEmitter<void>();\n  protected sections: any;\n  protected needUpload = false;\n  protected pasteMode = false;\n  protected mouseInViewer = false;\n  protected loading = false;\n  protected replaceFileModal?: ModalComponent;\n  protected retainMarkConfig = false;\n  protected previewModal?: ModalComponent;\n  @ViewChild('uploadInput', {static: true}) uploadInput!: ElementRef;\n  @ViewChild('replaceFileModalTemplate', {static: true}) replaceFileModalTemplate!: TemplateRef<any>;\n  @ViewChild('previewTemplate', {static: true}) previewTemplate!: TemplateRef<any>;\n  @ViewChild('previewFooterTemplate', {static: true}) previewFooterTemplate!: TemplateRef<any>;\n\n  @HostListener('window:keydown', ['$event'])\n  handleKeyDown($event: KeyboardEvent) {\n    switch ($event.code) {\n      case 'ArrowUp':\n        if ($event.altKey) {\n          this.service.switchMark(-1);\n        }\n        break;\n      case 'ArrowDown':\n        if ($event.altKey) {\n          this.service.switchMark(1);\n        }\n        break;\n      case 'KeyC':\n        if ($event.ctrlKey) {\n          const selection = window.getSelection();\n          if (selection?.toString()) {\n            return;\n          }\n          this.copyMarkConfig();\n        }\n        break;\n      case 'KeyV':\n        if ($event.ctrlKey) {\n          this.pasteMarkConfig();\n        }\n        break;\n      case 'Escape':\n        this.exitPasteMode();\n        break;\n    }\n    if (this.mouseInViewer && $event.ctrlKey && $event.key === '0') {\n      $event.preventDefault();\n      this.scale(0);\n    }\n  }\n\n  constructor(protected service: SectionService, private wordDesignerService: WordDesignerService,\n              protected viewContainerRef: ViewContainerRef, private modalService: ModalService) {\n  }\n\n  ngOnInit() {\n    this.service.tenant = this.tenant;\n    this.service.templateClassName = this.className;\n    this.service.templateOid = this.oid;\n    this.service.instanceClassName = this.instanceClassName;\n    this.service.params = this.params;\n    this.service.tabViewContainerRef = this.tabViewContainerRef;\n    this.loading = true;\n    this.wordDesignerService.loadTemplate(this.tenant, this.className, this.oid).subscribe(response => {\n      this.loadTemplateAndConfig(response);\n      this.loading = false;\n    });\n  }\n\n  ngOnDestroy() {\n    this.service.valueUpdated.unsubscribe();\n    this.service.valueChanged.unsubscribe();\n  }\n\n  loadTemplateAndConfig(response: any) {\n    this.sections = response.sections || [];\n    if (this.sections.length === 0) {\n      this.needUpload = true;\n      this.loading = false;\n      return;\n    }\n    this.needUpload = false;\n    this.service.marks = response.marks.map((mark: any) => {\n      mark.config = mark.config || {};\n      return mark;\n    });\n    if (this.service.marks.length > 0) {\n      this.service.activeMark = this.service.marks[0];\n    }\n  }\n\n  scaleByMouse($event: any) {\n    if ($event.ctrlKey) {\n      $event.preventDefault();\n      this.scale($event.deltaY < 0 ? 0.1 : -0.1);\n    }\n  }\n\n  scale(type: number) {\n    if (type === 0) {\n      this.service.scale = 1;\n    } else {\n      this.service.scale += type;\n    }\n  }\n\n  upload() {\n    this.loading = true;\n    this.wordDesignerService.uploadTemplateFile(this.tenant, this.className, this.oid, this.retainMarkConfig, this.uploadInput.nativeElement.files[0]).subscribe(response => {\n      this.uploadInput.nativeElement.value = '';\n      this.loadTemplateAndConfig(response);\n      this.loading = false;\n      this.onTemplateFileUploaded.emit();\n    });\n  }\n\n  openReplaceTemplateFileModal() {\n    this.replaceFileModal = this.modalService.open(this.tabViewContainerRef, '替换文件', 'default', this.replaceFileModalTemplate, {});\n  }\n\n  replaceTemplateFile(retainMarkConfig: boolean) {\n    this.retainMarkConfig = retainMarkConfig;\n    this.uploadInput.nativeElement.click();\n    this.replaceFileModal?.hide();\n  }\n\n  downloadTemplateFile() {\n    this.loading = true;\n    this.wordDesignerService.downloadTemplateFile(this.tenant, this.className, this.oid, () => {\n      this.loading = false;\n    });\n  }\n\n  preview() {\n    for (let mark of this.service.marks) {\n      mark.value = undefined;\n    }\n    this.previewModal = this.modalService.open(this.tabViewContainerRef, '预览', 'full',\n      this.previewTemplate, {}, this.previewFooterTemplate);\n  }\n\n  saveConfig() {\n    this.loading = true;\n    this.service.marks.map(mark => {\n      delete mark.value;\n    });\n    this.wordDesignerService.save(this.tenant, this.className, this.oid, {\n      templateConfig: JSON.stringify({\n        sections: this.sections,\n        marks: this.service.marks\n      })\n    }).subscribe(response => {\n      if (response.success) {\n        notifySuccess('保存成功');\n        this.loading = false;\n      }\n    });\n  }\n\n  copyMarkConfig() {\n    if (this.service.activeMark.type) {\n      this.service.copiedMark = deepClone(this.service.activeMark);\n      this.pasteMode = true;\n    }\n  }\n\n  exitPasteMode() {\n    this.service.copiedMark = {};\n    this.service.readyPasteMarkNames = [];\n    this.service.lastClickToPasteMarkName = '';\n    this.pasteMode = false;\n  }\n\n  pasteMarkConfig() {\n    let readyPasteMark;\n    for (let readyPasteMarkName of this.service.readyPasteMarkNames) {\n      readyPasteMark = this.service.getMark(readyPasteMarkName);\n      const display = readyPasteMark.display;\n      Object.assign(readyPasteMark, deepClone(this.service.copiedMark));\n      readyPasteMark.name = readyPasteMarkName;\n      readyPasteMark.display = display;\n    }\n    this.service.activeMark = readyPasteMark || this.service.activeMark;\n    this.exitPasteMode();\n  }\n}\n","<dx-load-panel [container]=\"viewContainerRef.element.nativeElement\" [showPane]=\"false\" [visible]=\"loading\">\n  <dxo-position [of]=\"viewContainerRef.element.nativeElement\"></dxo-position>\n</dx-load-panel>\n<input #uploadInput type=\"file\" name=\"file\"\n       accept=\"application/vnd.openxmlformats-officedocument.wordprocessingml.document\" (change)=\"upload()\"\n       style=\"display: none;\"/>\n<div class=\"coast-card\">\n  <div class=\"coast-card-content\">\n    <div class=\"content-main\" [class.show-upload-btn]=\"needUpload\">\n      <ng-container *ngIf=\"needUpload\">\n        <dx-button type=\"success\" text=\"上传文件\" (onClick)=\"uploadInput.click()\"></dx-button>\n      </ng-container>\n      <div *ngIf=\"!needUpload\" class=\"left-panel\">\n        <div *ngIf=\"pasteMode\" class=\"paste-mode-bar\">\n          <span\n            class=\"message\">已进入批量粘贴配置模式，支持Ctrl、Shift键快捷选择，按Ctrl+V组合键粘贴配置，按Esc键取消操作并退出该模式</span>\n          <dx-button [width]=\"48\" text=\"退出\" (onClick)=\"exitPasteMode()\"></dx-button>\n        </div>\n        <div class=\"content\"\n             (mouseenter)=\"mouseInViewer = true;\"\n             (mouseleave)=\"mouseInViewer = false;\"\n             (mousewheel)=\"scaleByMouse($event)\">\n          <div *ngIf=\"!needUpload\" class=\"viewer\">\n            <ng-container *ngFor=\"let section of sections\">\n              <rs-section [section]=\"section\" [editMode]=\"true\" [pasteMode]=\"pasteMode\"></rs-section>\n            </ng-container>\n          </div>\n        </div>\n      </div>\n      <div *ngIf=\"!needUpload\" class=\"right-panel\">\n        <div class=\"header\">\n          <dx-button type=\"default\" text=\"替换文件\" (onClick)=\"openReplaceTemplateFileModal()\"\n                     [disabled]=\"loading\"></dx-button>\n          <dx-button icon=\"coast-icon coast-icon-download\" hint=\"下载文件\"\n                     (onClick)=\"downloadTemplateFile()\" [disabled]=\"loading\"></dx-button>\n          <dx-button icon=\"coast-icon coast-icon-direction-up\" hint=\"上一个(Alt + ↑)\"\n                     (onClick)=\"service.switchMark(-1)\" [disabled]=\"loading\"></dx-button>\n          <dx-button icon=\"coast-icon coast-icon-direction-down\" hint=\"下一个(Alt + ↓)\"\n                     (onClick)=\"service.switchMark(1)\" [disabled]=\"loading\"></dx-button>\n          <dx-button [type]=\"pasteMode ? 'success' : 'default'\" text=\"复制\" hint=\"复制(Ctrl + c)\"\n                     (onClick)=\"copyMarkConfig()\"></dx-button>\n          <dx-button type=\"danger\" text=\"粘贴\" hint=\"粘贴(Ctrl + v)\" (onClick)=\"pasteMarkConfig()\"\n                     [disabled]=\"loading || !pasteMode\"></dx-button>\n        </div>\n        <div class=\"config\" *ngIf=\"service.activeMark\">\n          <rs-mark-config [tenant]=\"tenant\"\n                          [templateClassName]=\"className\"\n                          [templateOid]=\"oid\"\n                          [instanceClassName]=\"instanceClassName\"\n                          [filterCategories]=\"filterCategories\"\n                          [mark]=\"service.activeMark\"\n                          [marks]=\"service.marks\"\n                          [tabViewContainerRef]=\"tabViewContainerRef\"></rs-mark-config>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div *ngIf=\"!needUpload\" class=\"footer\">\n    <div class=\"left\">\n      <dx-button text=\"放大\" (onClick)=\"scale(0.1)\"></dx-button>\n      <dx-button text=\"还原\" (onClick)=\"scale(0)\"></dx-button>\n      <dx-button text=\"缩小\" (onClick)=\"scale(-0.1)\"></dx-button>\n    </div>\n    <div class=\"right\">\n      <dx-button type=\"default\" text=\"预览\" (onClick)=\"preview()\" [disabled]=\"needUpload || loading\"></dx-button>\n      <dx-button type=\"success\" text=\"保存\" (onClick)=\"saveConfig()\" [disabled]=\"needUpload || loading\"></dx-button>\n    </div>\n  </div>\n</div>\n<ng-template #replaceFileModalTemplate>\n  <div class=\"confirm-message\">\n    <span>替换文件可以按照书签标识继承已保存的书签配置，请选择操作：</span>\n  </div>\n  <div class=\"form-buttons\">\n    <div class=\"buttons-wrapper\">\n      <dx-button type=\"default\" text=\"继承配置\" (onClick)=\"replaceTemplateFile(true)\"></dx-button>\n      <dx-button type=\"danger\" text=\"清除配置\" (onClick)=\"replaceTemplateFile(false)\"></dx-button>\n      <dx-button type=\"normal\" text=\"取消\" (onClick)=\"replaceFileModal?.hide()\"></dx-button>\n    </div>\n  </div>\n</ng-template>\n<ng-template #previewTemplate>\n  <div class=\"preview-viewer\">\n    <div class=\"viewer-container\">\n      <div class=\"viewer\">\n        <ng-container *ngFor=\"let section of sections\">\n          <rs-section [section]=\"section\"></rs-section>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n</ng-template>\n<ng-template #previewFooterTemplate>\n  <div class=\"form-buttons\">\n    <div class=\"buttons-wrapper\">\n      <dx-button type=\"normal\" text=\"关闭\" (onClick)=\"previewModal?.hide()\"></dx-button>\n    </div>\n  </div>\n</ng-template>\n"]}
|