ngx-rs-ant 2.2.2 → 2.2.3
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/esm2020/data-grid/data-grid.component.mjs +3 -3
- package/esm2020/data-grid/instance-link-template/instance-link-template.component.mjs +3 -3
- package/esm2020/form/form.component.mjs +4 -4
- package/esm2020/public-api.mjs +11 -1
- package/esm2020/types/component/mark-item-component-base.mjs +8 -0
- package/esm2020/types/config/mark-item-config-base.mjs +4 -0
- package/esm2020/types/config/modal-config-base.mjs +1 -1
- package/esm2020/util/utils.mjs +17 -17
- package/esm2020/word/section/color.pipe.mjs +19 -0
- package/esm2020/word/section/mark.pipe.mjs +20 -0
- package/esm2020/word/section/node/node.component.mjs +31 -0
- package/esm2020/word/section/node/paragraph/paragraph.component.mjs +44 -0
- package/esm2020/word/section/node/paragraph/run/run.component.mjs +84 -0
- package/esm2020/word/section/node/paragraph-for-input/item/item.component.mjs +64 -0
- package/esm2020/word/section/node/paragraph-for-input/paragraph-for-input.component.mjs +46 -0
- package/esm2020/word/section/pt.pipe.mjs +22 -0
- package/esm2020/word/section/section.component.mjs +44 -0
- package/esm2020/word/section/section.module.mjs +50 -0
- package/esm2020/word/section/section.service.mjs +48 -0
- package/esm2020/word/word-designer/mark-config/mark-config.component.mjs +77 -0
- package/esm2020/word/word-designer/word-designer.component.mjs +207 -0
- package/esm2020/word/word-designer/word-designer.module.mjs +35 -0
- package/esm2020/word/word-designer/word-designer.service.mjs +69 -0
- package/esm2020/word/word-editor/word-editor.component.mjs +154 -0
- package/esm2020/word/word-editor/word-editor.module.mjs +32 -0
- package/esm2020/word/word-editor/word-editor.service.mjs +67 -0
- package/fesm2015/ngx-rs-ant.mjs +1038 -22
- package/fesm2015/ngx-rs-ant.mjs.map +1 -1
- package/fesm2020/ngx-rs-ant.mjs +1031 -22
- package/fesm2020/ngx-rs-ant.mjs.map +1 -1
- package/package.json +2 -2
- package/public-api.d.ts +10 -0
- package/types/component/mark-item-component-base.d.ts +21 -0
- package/types/config/mark-item-config-base.d.ts +17 -0
- package/types/config/modal-config-base.d.ts +8 -0
- package/util/utils.d.ts +10 -10
- package/word/section/color.pipe.d.ts +7 -0
- package/word/section/mark.pipe.d.ts +10 -0
- package/word/section/node/node.component.d.ts +12 -0
- package/word/section/node/paragraph/paragraph.component.d.ts +35 -0
- package/word/section/node/paragraph/run/run.component.d.ts +21 -0
- package/word/section/node/paragraph-for-input/item/item.component.d.ts +27 -0
- package/word/section/node/paragraph-for-input/paragraph-for-input.component.d.ts +35 -0
- package/word/section/pt.pipe.d.ts +7 -0
- package/word/section/section.component.d.ts +22 -0
- package/word/section/section.module.d.ts +16 -0
- package/word/section/section.service.d.ts +24 -0
- package/word/word-designer/mark-config/mark-config.component.d.ts +21 -0
- package/word/word-designer/word-designer.component.d.ts +48 -0
- package/word/word-designer/word-designer.module.d.ts +11 -0
- package/word/word-designer/word-designer.service.d.ts +13 -0
- package/word/word-editor/word-editor.component.d.ts +41 -0
- package/word/word-editor/word-editor.module.d.ts +10 -0
- package/word/word-editor/word-editor.service.d.ts +14 -0
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { EventEmitter, Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class SectionService {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.scale = 1;
|
|
6
|
+
this.marks = [];
|
|
7
|
+
this.readonly = false;
|
|
8
|
+
this.activeMark = { name: '未定义书签' };
|
|
9
|
+
this.copiedMark = {};
|
|
10
|
+
this.readyPasteMarkNames = [];
|
|
11
|
+
this.lastClickToPasteMarkName = '';
|
|
12
|
+
this.valueUpdated = new EventEmitter();
|
|
13
|
+
}
|
|
14
|
+
switchMark(type) {
|
|
15
|
+
let index = this.marks.indexOf(this.activeMark);
|
|
16
|
+
if (index + type === -1) {
|
|
17
|
+
this.activeMark = this.marks[this.marks.length - 1];
|
|
18
|
+
}
|
|
19
|
+
else if (index + type === this.marks.length) {
|
|
20
|
+
this.activeMark = this.marks[0];
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
this.activeMark = this.marks[index + type];
|
|
24
|
+
}
|
|
25
|
+
document.getElementById('mark-setting_' + this.activeMark.name)?.scrollIntoView({
|
|
26
|
+
block: 'center',
|
|
27
|
+
inline: 'center'
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
getMark(name) {
|
|
31
|
+
if (!name) {
|
|
32
|
+
return undefined;
|
|
33
|
+
}
|
|
34
|
+
return this.marks.find(m => m.name === name);
|
|
35
|
+
}
|
|
36
|
+
getMarkIndex(name) {
|
|
37
|
+
if (!name) {
|
|
38
|
+
return -1;
|
|
39
|
+
}
|
|
40
|
+
return this.marks.findIndex(m => m.name === name);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
SectionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SectionService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
44
|
+
SectionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SectionService });
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SectionService, decorators: [{
|
|
46
|
+
type: Injectable
|
|
47
|
+
}] });
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjdGlvbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJzLWFudC9zcmMvd29yZC9zZWN0aW9uL3NlY3Rpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsWUFBWSxFQUFFLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFHdkQsTUFBTSxPQUFPLGNBQWM7SUFEM0I7UUFTRSxVQUFLLEdBQVcsQ0FBQyxDQUFDO1FBQ2xCLFVBQUssR0FBVSxFQUFFLENBQUM7UUFDbEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixlQUFVLEdBQVEsRUFBQyxJQUFJLEVBQUUsT0FBTyxFQUFDLENBQUM7UUFDbEMsZUFBVSxHQUFRLEVBQUUsQ0FBQztRQUNyQix3QkFBbUIsR0FBYSxFQUFFLENBQUM7UUFDbkMsNkJBQXdCLEdBQVcsRUFBRSxDQUFDO1FBQ3RDLGlCQUFZLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztLQThCekM7SUE1QkMsVUFBVSxDQUFDLElBQVk7UUFDckIsSUFBSSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2hELElBQUksS0FBSyxHQUFHLElBQUksS0FBSyxDQUFDLENBQUMsRUFBRTtZQUN2QixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUM7U0FDckQ7YUFBTSxJQUFJLEtBQUssR0FBRyxJQUFJLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7WUFDN0MsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2pDO2FBQU07WUFDTCxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxDQUFDO1NBQzVDO1FBQ0QsUUFBUSxDQUFDLGNBQWMsQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxjQUFjLENBQUM7WUFDOUUsS0FBSyxFQUFFLFFBQVE7WUFDZixNQUFNLEVBQUUsUUFBUTtTQUNqQixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsT0FBTyxDQUFDLElBQVM7UUFDZixJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ1QsT0FBTyxTQUFTLENBQUM7U0FDbEI7UUFDRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxJQUFJLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRUQsWUFBWSxDQUFDLElBQVM7UUFDcEIsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNULE9BQU8sQ0FBQyxDQUFDLENBQUM7U0FDWDtRQUNELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxDQUFDO0lBQ3BELENBQUM7OzRHQTVDVSxjQUFjO2dIQUFkLGNBQWM7NEZBQWQsY0FBYztrQkFEMUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RXZlbnRFbWl0dGVyLCBJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFNlY3Rpb25TZXJ2aWNlIHtcbiAgdGVuYW50OiBhbnk7XG4gIHRlbXBsYXRlQ2xhc3NOYW1lOiBhbnk7XG4gIGluc3RhbmNlQ2xhc3NOYW1lOiBhbnk7XG4gIHRlbXBsYXRlT2lkOiBhbnk7XG4gIGluc3RhbmNlT2lkOiBhbnk7XG4gIHBhcmFtczogYW55O1xuICB0YWJWaWV3Q29udGFpbmVyUmVmOiBhbnk7XG4gIHNjYWxlOiBudW1iZXIgPSAxO1xuICBtYXJrczogYW55W10gPSBbXTtcbiAgcmVhZG9ubHkgPSBmYWxzZTtcbiAgYWN0aXZlTWFyazogYW55ID0ge25hbWU6ICfmnKrlrprkuYnkuabnrb4nfTtcbiAgY29waWVkTWFyazogYW55ID0ge307XG4gIHJlYWR5UGFzdGVNYXJrTmFtZXM6IHN0cmluZ1tdID0gW107XG4gIGxhc3RDbGlja1RvUGFzdGVNYXJrTmFtZTogc3RyaW5nID0gJyc7XG4gIHZhbHVlVXBkYXRlZCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICBzd2l0Y2hNYXJrKHR5cGU6IG51bWJlcikge1xuICAgIGxldCBpbmRleCA9IHRoaXMubWFya3MuaW5kZXhPZih0aGlzLmFjdGl2ZU1hcmspO1xuICAgIGlmIChpbmRleCArIHR5cGUgPT09IC0xKSB7XG4gICAgICB0aGlzLmFjdGl2ZU1hcmsgPSB0aGlzLm1hcmtzW3RoaXMubWFya3MubGVuZ3RoIC0gMV07XG4gICAgfSBlbHNlIGlmIChpbmRleCArIHR5cGUgPT09IHRoaXMubWFya3MubGVuZ3RoKSB7XG4gICAgICB0aGlzLmFjdGl2ZU1hcmsgPSB0aGlzLm1hcmtzWzBdO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmFjdGl2ZU1hcmsgPSB0aGlzLm1hcmtzW2luZGV4ICsgdHlwZV07XG4gICAgfVxuICAgIGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdtYXJrLXNldHRpbmdfJyArIHRoaXMuYWN0aXZlTWFyay5uYW1lKT8uc2Nyb2xsSW50b1ZpZXcoe1xuICAgICAgYmxvY2s6ICdjZW50ZXInLFxuICAgICAgaW5saW5lOiAnY2VudGVyJ1xuICAgIH0pO1xuICB9XG5cbiAgZ2V0TWFyayhuYW1lOiBhbnkpIHtcbiAgICBpZiAoIW5hbWUpIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuICAgIHJldHVybiB0aGlzLm1hcmtzLmZpbmQobSA9PiBtLm5hbWUgPT09IG5hbWUpO1xuICB9XG5cbiAgZ2V0TWFya0luZGV4KG5hbWU6IGFueSkge1xuICAgIGlmICghbmFtZSkge1xuICAgICAgcmV0dXJuIC0xO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5tYXJrcy5maW5kSW5kZXgobSA9PiBtLm5hbWUgPT09IG5hbWUpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { Component, Input, ViewChild, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { MarkItemFactory } from "coast-plugin-register";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "devextreme-angular/ui/nested";
|
|
5
|
+
import * as i2 from "devextreme-angular/ui/select-box";
|
|
6
|
+
import * as i3 from "devextreme-angular/ui/text-box";
|
|
7
|
+
import * as i4 from "devextreme-angular/ui/validator";
|
|
8
|
+
export class MarkConfigComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.changeMark = false;
|
|
11
|
+
}
|
|
12
|
+
get mark() {
|
|
13
|
+
return this._mark;
|
|
14
|
+
}
|
|
15
|
+
set mark(mark) {
|
|
16
|
+
if (!mark) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
this._mark = mark;
|
|
20
|
+
this.changeMark = true;
|
|
21
|
+
this.loadMarkConfig();
|
|
22
|
+
}
|
|
23
|
+
ngOnInit() {
|
|
24
|
+
this.markTypes = MarkItemFactory.getMarkItems(...this.filterCategories || '');
|
|
25
|
+
}
|
|
26
|
+
loadMarkConfig() {
|
|
27
|
+
setTimeout(() => {
|
|
28
|
+
this.markItemConfigRef.clear();
|
|
29
|
+
let config = MarkItemFactory.getConfig(this.mark.type);
|
|
30
|
+
if (!config) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const componentRef = this.markItemConfigRef.createComponent(config.component);
|
|
34
|
+
const instance = componentRef.instance;
|
|
35
|
+
instance.tenant = this.tenant;
|
|
36
|
+
instance.templateClassName = this.templateClassName;
|
|
37
|
+
instance.templateOid = this.templateOid;
|
|
38
|
+
instance.instanceClassName = this.instanceClassName;
|
|
39
|
+
instance.mark = this.mark;
|
|
40
|
+
instance.marks = this.marks;
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
changeMarkType() {
|
|
44
|
+
if (this.changeMark) {
|
|
45
|
+
this.changeMark = false;
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
this.mark.pickerCode = null;
|
|
49
|
+
this.mark.generatorCode = null;
|
|
50
|
+
}
|
|
51
|
+
this.loadMarkConfig();
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
MarkConfigComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MarkConfigComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
55
|
+
MarkConfigComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MarkConfigComponent, selector: "rs-mark-config", inputs: { tenant: "tenant", templateClassName: "templateClassName", templateOid: "templateOid", instanceClassName: "instanceClassName", filterCategories: "filterCategories", mark: "mark", marks: "marks" }, viewQueries: [{ propertyName: "markItemConfigRef", first: true, predicate: ["markItemConfigRef"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div class=\"dx-field\">\n <div class=\"dx-field-label\">\n <span>\u4E66\u7B7E\u6807\u8BC6</span>\n <span class=\"required-mark\"> *</span>\n </div>\n <div class=\"dx-field-value\">\n <dx-text-box [(value)]=\"mark.name\" [readOnly]=\"true\">\n <dx-validator>\n <dxi-validation-rule type=\"required\" message=\"\u503C\u4E0D\u80FD\u4E3A\u7A7A\"></dxi-validation-rule>\n </dx-validator>\n </dx-text-box>\n </div>\n</div>\n<div class=\"dx-field\">\n <div class=\"dx-field-label\">\n <span>\u4E66\u7B7E\u540D\u79F0</span>\n </div>\n <div class=\"dx-field-value\">\n <dx-text-box [(value)]=\"mark.display\"></dx-text-box>\n </div>\n</div>\n<div class=\"dx-field\">\n <div class=\"dx-field-label\">\n <span>\u7EC4\u4EF6\u7C7B\u578B</span>\n <span class=\"required-mark\"> *</span>\n </div>\n <div class=\"dx-field-value\">\n <dx-select-box [dataSource]=\"markTypes\"\n valueExpr=\"name\"\n displayExpr=\"caption\"\n [(value)]=\"mark.type\"\n (onSelectionChanged)=\"changeMarkType()\">\n <dx-validator>\n <dxi-validation-rule type=\"required\" message=\"\u503C\u4E0D\u80FD\u4E3A\u7A7A\"></dxi-validation-rule>\n </dx-validator>\n </dx-select-box>\n </div>\n</div>\n<ng-container #markItemConfigRef></ng-container>\n", styles: [":host .dx-field{margin-bottom:8px;display:flex;flex-flow:row nowrap}:host .dx-field .dx-field-label{flex:0 0 80px}:host .dx-field .dx-field-value{flex:1}\n"], dependencies: [{ kind: "component", type: i1.DxiValidationRuleComponent, selector: "dxi-validation-rule", inputs: ["message", "trim", "type", "ignoreEmptyValue", "max", "min", "reevaluate", "validationCallback", "comparisonTarget", "comparisonType", "pattern"] }, { kind: "component", type: i2.DxSelectBoxComponent, selector: "dx-select-box", inputs: ["acceptCustomValue", "accessKey", "activeStateEnabled", "buttons", "customItemCreateEvent", "dataSource", "deferRendering", "disabled", "displayExpr", "displayValue", "dropDownButtonTemplate", "dropDownOptions", "elementAttr", "fieldTemplate", "focusStateEnabled", "grouped", "groupTemplate", "height", "hint", "hoverStateEnabled", "inputAttr", "isDirty", "isValid", "items", "itemTemplate", "label", "labelMode", "maxLength", "minSearchLength", "name", "noDataText", "opened", "openOnFieldClick", "placeholder", "readOnly", "rtlEnabled", "searchEnabled", "searchExpr", "searchMode", "searchTimeout", "selectedItem", "showClearButton", "showDataBeforeSearch", "showDropDownButton", "showSelectionControls", "spellcheck", "stylingMode", "tabIndex", "text", "useItemTextAsTitle", "validationError", "validationErrors", "validationMessageMode", "validationMessagePosition", "validationStatus", "value", "valueChangeEvent", "valueExpr", "visible", "width", "wrapItemText"], outputs: ["onChange", "onClosed", "onContentReady", "onCopy", "onCustomItemCreating", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onItemClick", "onKeyDown", "onKeyUp", "onOpened", "onOptionChanged", "onPaste", "onSelectionChanged", "onValueChanged", "acceptCustomValueChange", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "customItemCreateEventChange", "dataSourceChange", "deferRenderingChange", "disabledChange", "displayExprChange", "displayValueChange", "dropDownButtonTemplateChange", "dropDownOptionsChange", "elementAttrChange", "fieldTemplateChange", "focusStateEnabledChange", "groupedChange", "groupTemplateChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isDirtyChange", "isValidChange", "itemsChange", "itemTemplateChange", "labelChange", "labelModeChange", "maxLengthChange", "minSearchLengthChange", "nameChange", "noDataTextChange", "openedChange", "openOnFieldClickChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "searchEnabledChange", "searchExprChange", "searchModeChange", "searchTimeoutChange", "selectedItemChange", "showClearButtonChange", "showDataBeforeSearchChange", "showDropDownButtonChange", "showSelectionControlsChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useItemTextAsTitleChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "valueExprChange", "visibleChange", "widthChange", "wrapItemTextChange", "onBlur"] }, { kind: "component", type: i3.DxTextBoxComponent, selector: "dx-text-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "inputAttr", "isDirty", "isValid", "label", "labelMode", "mask", "maskChar", "maskInvalidMessage", "maskRules", "maxLength", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showMaskMode", "spellcheck", "stylingMode", "tabIndex", "text", "useMaskedValue", "validationError", "validationErrors", "validationMessageMode", "validationMessagePosition", "validationStatus", "value", "valueChangeEvent", "visible", "width"], outputs: ["onChange", "onContentReady", "onCopy", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onKeyDown", "onKeyUp", "onOptionChanged", "onPaste", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isDirtyChange", "isValidChange", "labelChange", "labelModeChange", "maskChange", "maskCharChange", "maskInvalidMessageChange", "maskRulesChange", "maxLengthChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showMaskModeChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useMaskedValueChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i4.DxValidatorComponent, selector: "dx-validator", inputs: ["adapter", "elementAttr", "height", "name", "validationGroup", "validationRules", "width"], outputs: ["onDisposing", "onInitialized", "onOptionChanged", "onValidated", "adapterChange", "elementAttrChange", "heightChange", "nameChange", "validationGroupChange", "validationRulesChange", "widthChange"] }] });
|
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MarkConfigComponent, decorators: [{
|
|
57
|
+
type: Component,
|
|
58
|
+
args: [{ selector: 'rs-mark-config', template: "<div class=\"dx-field\">\n <div class=\"dx-field-label\">\n <span>\u4E66\u7B7E\u6807\u8BC6</span>\n <span class=\"required-mark\"> *</span>\n </div>\n <div class=\"dx-field-value\">\n <dx-text-box [(value)]=\"mark.name\" [readOnly]=\"true\">\n <dx-validator>\n <dxi-validation-rule type=\"required\" message=\"\u503C\u4E0D\u80FD\u4E3A\u7A7A\"></dxi-validation-rule>\n </dx-validator>\n </dx-text-box>\n </div>\n</div>\n<div class=\"dx-field\">\n <div class=\"dx-field-label\">\n <span>\u4E66\u7B7E\u540D\u79F0</span>\n </div>\n <div class=\"dx-field-value\">\n <dx-text-box [(value)]=\"mark.display\"></dx-text-box>\n </div>\n</div>\n<div class=\"dx-field\">\n <div class=\"dx-field-label\">\n <span>\u7EC4\u4EF6\u7C7B\u578B</span>\n <span class=\"required-mark\"> *</span>\n </div>\n <div class=\"dx-field-value\">\n <dx-select-box [dataSource]=\"markTypes\"\n valueExpr=\"name\"\n displayExpr=\"caption\"\n [(value)]=\"mark.type\"\n (onSelectionChanged)=\"changeMarkType()\">\n <dx-validator>\n <dxi-validation-rule type=\"required\" message=\"\u503C\u4E0D\u80FD\u4E3A\u7A7A\"></dxi-validation-rule>\n </dx-validator>\n </dx-select-box>\n </div>\n</div>\n<ng-container #markItemConfigRef></ng-container>\n", styles: [":host .dx-field{margin-bottom:8px;display:flex;flex-flow:row nowrap}:host .dx-field .dx-field-label{flex:0 0 80px}:host .dx-field .dx-field-value{flex:1}\n"] }]
|
|
59
|
+
}], propDecorators: { tenant: [{
|
|
60
|
+
type: Input
|
|
61
|
+
}], templateClassName: [{
|
|
62
|
+
type: Input
|
|
63
|
+
}], templateOid: [{
|
|
64
|
+
type: Input
|
|
65
|
+
}], instanceClassName: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], filterCategories: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}], mark: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}], marks: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}], markItemConfigRef: [{
|
|
74
|
+
type: ViewChild,
|
|
75
|
+
args: ['markItemConfigRef', { static: true, read: ViewContainerRef }]
|
|
76
|
+
}] } });
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFyay1jb25maWcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJzLWFudC9zcmMvd29yZC93b3JkLWRlc2lnbmVyL21hcmstY29uZmlnL21hcmstY29uZmlnLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL3dvcmQvd29yZC1kZXNpZ25lci9tYXJrLWNvbmZpZy9tYXJrLWNvbmZpZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDNUUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHVCQUF1QixDQUFDOzs7Ozs7QUFPdEQsTUFBTSxPQUFPLG1CQUFtQjtJQUxoQztRQW1DVSxlQUFVLEdBQUcsS0FBSyxDQUFDO0tBa0M1QjtJQXBEQyxJQUNJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVELElBQUksSUFBSSxDQUFDLElBQVM7UUFDaEIsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNULE9BQU87U0FDUjtRQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBU0QsUUFBUTtRQUNOLElBQUksQ0FBQyxTQUFTLEdBQUcsZUFBZSxDQUFDLFlBQVksQ0FBQyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNoRixDQUFDO0lBRUQsY0FBYztRQUNaLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDL0IsSUFBSSxNQUFNLEdBQUcsZUFBZSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3ZELElBQUksQ0FBQyxNQUFNLEVBQUU7Z0JBQ1gsT0FBTzthQUNSO1lBQ0QsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDOUUsTUFBTSxRQUFRLEdBQVEsWUFBWSxDQUFDLFFBQVEsQ0FBQztZQUM1QyxRQUFRLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7WUFDOUIsUUFBUSxDQUFDLGlCQUFpQixHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQztZQUNwRCxRQUFRLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7WUFDeEMsUUFBUSxDQUFDLGlCQUFpQixHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQztZQUNwRCxRQUFRLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUM7WUFDMUIsUUFBUSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBQzlCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGNBQWM7UUFDWixJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7U0FDekI7YUFBTTtZQUNMLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztZQUM1QixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7U0FDaEM7UUFDRCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQzs7aUhBL0RVLG1CQUFtQjtxR0FBbkIsbUJBQW1CLHVXQStCdUIsZ0JBQWdCLDJDQ3ZDdkUsdTFDQXVDQTs0RkQvQmEsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGdCQUFnQjs4QkFNMUIsTUFBTTtzQkFETCxLQUFLO2dCQUdOLGlCQUFpQjtzQkFEaEIsS0FBSztnQkFHTixXQUFXO3NCQURWLEtBQUs7Z0JBR04saUJBQWlCO3NCQURoQixLQUFLO2dCQUdOLGdCQUFnQjtzQkFEZixLQUFLO2dCQUlGLElBQUk7c0JBRFAsS0FBSztnQkFnQk4sS0FBSztzQkFESixLQUFLO2dCQUlrRSxpQkFBaUI7c0JBQXhGLFNBQVM7dUJBQUMsbUJBQW1CLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgVmlld0NoaWxkLCBWaWV3Q29udGFpbmVyUmVmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TWFya0l0ZW1GYWN0b3J5fSBmcm9tIFwiY29hc3QtcGx1Z2luLXJlZ2lzdGVyXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3JzLW1hcmstY29uZmlnJyxcbiAgdGVtcGxhdGVVcmw6ICcuL21hcmstY29uZmlnLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbWFyay1jb25maWcuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBNYXJrQ29uZmlnQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgdGVuYW50OiBhbnk7XG4gIEBJbnB1dCgpXG4gIHRlbXBsYXRlQ2xhc3NOYW1lOiBhbnk7XG4gIEBJbnB1dCgpXG4gIHRlbXBsYXRlT2lkOiBhbnk7XG4gIEBJbnB1dCgpXG4gIGluc3RhbmNlQ2xhc3NOYW1lOiBhbnk7XG4gIEBJbnB1dCgpXG4gIGZpbHRlckNhdGVnb3JpZXM/OiBzdHJpbmdbXTtcblxuICBASW5wdXQoKVxuICBnZXQgbWFyaygpIHtcbiAgICByZXR1cm4gdGhpcy5fbWFyaztcbiAgfVxuXG4gIHNldCBtYXJrKG1hcms6IGFueSkge1xuICAgIGlmICghbWFyaykge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICB0aGlzLl9tYXJrID0gbWFyaztcbiAgICB0aGlzLmNoYW5nZU1hcmsgPSB0cnVlO1xuICAgIHRoaXMubG9hZE1hcmtDb25maWcoKTtcbiAgfVxuXG4gIHByaXZhdGUgX21hcms6IGFueTtcbiAgQElucHV0KClcbiAgbWFya3M6IGFueTtcbiAgcHJvdGVjdGVkIG1hcmtUeXBlczogYW55O1xuICBwcml2YXRlIGNoYW5nZU1hcmsgPSBmYWxzZTtcbiAgQFZpZXdDaGlsZCgnbWFya0l0ZW1Db25maWdSZWYnLCB7c3RhdGljOiB0cnVlLCByZWFkOiBWaWV3Q29udGFpbmVyUmVmfSkgbWFya0l0ZW1Db25maWdSZWYhOiBWaWV3Q29udGFpbmVyUmVmO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMubWFya1R5cGVzID0gTWFya0l0ZW1GYWN0b3J5LmdldE1hcmtJdGVtcyguLi50aGlzLmZpbHRlckNhdGVnb3JpZXMgfHwgJycpO1xuICB9XG5cbiAgbG9hZE1hcmtDb25maWcoKSB7XG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICB0aGlzLm1hcmtJdGVtQ29uZmlnUmVmLmNsZWFyKCk7XG4gICAgICBsZXQgY29uZmlnID0gTWFya0l0ZW1GYWN0b3J5LmdldENvbmZpZyh0aGlzLm1hcmsudHlwZSk7XG4gICAgICBpZiAoIWNvbmZpZykge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBjb25zdCBjb21wb25lbnRSZWYgPSB0aGlzLm1hcmtJdGVtQ29uZmlnUmVmLmNyZWF0ZUNvbXBvbmVudChjb25maWcuY29tcG9uZW50KTtcbiAgICAgIGNvbnN0IGluc3RhbmNlOiBhbnkgPSBjb21wb25lbnRSZWYuaW5zdGFuY2U7XG4gICAgICBpbnN0YW5jZS50ZW5hbnQgPSB0aGlzLnRlbmFudDtcbiAgICAgIGluc3RhbmNlLnRlbXBsYXRlQ2xhc3NOYW1lID0gdGhpcy50ZW1wbGF0ZUNsYXNzTmFtZTtcbiAgICAgIGluc3RhbmNlLnRlbXBsYXRlT2lkID0gdGhpcy50ZW1wbGF0ZU9pZDtcbiAgICAgIGluc3RhbmNlLmluc3RhbmNlQ2xhc3NOYW1lID0gdGhpcy5pbnN0YW5jZUNsYXNzTmFtZTtcbiAgICAgIGluc3RhbmNlLm1hcmsgPSB0aGlzLm1hcms7XG4gICAgICBpbnN0YW5jZS5tYXJrcyA9IHRoaXMubWFya3M7XG4gICAgfSk7XG4gIH1cblxuICBjaGFuZ2VNYXJrVHlwZSgpIHtcbiAgICBpZiAodGhpcy5jaGFuZ2VNYXJrKSB7XG4gICAgICB0aGlzLmNoYW5nZU1hcmsgPSBmYWxzZTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5tYXJrLnBpY2tlckNvZGUgPSBudWxsO1xuICAgICAgdGhpcy5tYXJrLmdlbmVyYXRvckNvZGUgPSBudWxsO1xuICAgIH1cbiAgICB0aGlzLmxvYWRNYXJrQ29uZmlnKCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJkeC1maWVsZFwiPlxuICA8ZGl2IGNsYXNzPVwiZHgtZmllbGQtbGFiZWxcIj5cbiAgICA8c3Bhbj7kuabnrb7moIfor4Y8L3NwYW4+XG4gICAgPHNwYW4gY2xhc3M9XCJyZXF1aXJlZC1tYXJrXCI+Jm5ic3A7Kjwvc3Bhbj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJkeC1maWVsZC12YWx1ZVwiPlxuICAgIDxkeC10ZXh0LWJveCBbKHZhbHVlKV09XCJtYXJrLm5hbWVcIiBbcmVhZE9ubHldPVwidHJ1ZVwiPlxuICAgICAgPGR4LXZhbGlkYXRvcj5cbiAgICAgICAgPGR4aS12YWxpZGF0aW9uLXJ1bGUgdHlwZT1cInJlcXVpcmVkXCIgbWVzc2FnZT1cIuWAvOS4jeiDveS4uuepulwiPjwvZHhpLXZhbGlkYXRpb24tcnVsZT5cbiAgICAgIDwvZHgtdmFsaWRhdG9yPlxuICAgIDwvZHgtdGV4dC1ib3g+XG4gIDwvZGl2PlxuPC9kaXY+XG48ZGl2IGNsYXNzPVwiZHgtZmllbGRcIj5cbiAgPGRpdiBjbGFzcz1cImR4LWZpZWxkLWxhYmVsXCI+XG4gICAgPHNwYW4+5Lmm562+5ZCN56ewPC9zcGFuPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImR4LWZpZWxkLXZhbHVlXCI+XG4gICAgPGR4LXRleHQtYm94IFsodmFsdWUpXT1cIm1hcmsuZGlzcGxheVwiPjwvZHgtdGV4dC1ib3g+XG4gIDwvZGl2PlxuPC9kaXY+XG48ZGl2IGNsYXNzPVwiZHgtZmllbGRcIj5cbiAgPGRpdiBjbGFzcz1cImR4LWZpZWxkLWxhYmVsXCI+XG4gICAgPHNwYW4+57uE5Lu257G75Z6LPC9zcGFuPlxuICAgIDxzcGFuIGNsYXNzPVwicmVxdWlyZWQtbWFya1wiPiZuYnNwOyo8L3NwYW4+XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwiZHgtZmllbGQtdmFsdWVcIj5cbiAgICA8ZHgtc2VsZWN0LWJveCBbZGF0YVNvdXJjZV09XCJtYXJrVHlwZXNcIlxuICAgICAgICAgICAgICAgICAgIHZhbHVlRXhwcj1cIm5hbWVcIlxuICAgICAgICAgICAgICAgICAgIGRpc3BsYXlFeHByPVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgICAgWyh2YWx1ZSldPVwibWFyay50eXBlXCJcbiAgICAgICAgICAgICAgICAgICAob25TZWxlY3Rpb25DaGFuZ2VkKT1cImNoYW5nZU1hcmtUeXBlKClcIj5cbiAgICAgIDxkeC12YWxpZGF0b3I+XG4gICAgICAgIDxkeGktdmFsaWRhdGlvbi1ydWxlIHR5cGU9XCJyZXF1aXJlZFwiIG1lc3NhZ2U9XCLlgLzkuI3og73kuLrnqbpcIj48L2R4aS12YWxpZGF0aW9uLXJ1bGU+XG4gICAgICA8L2R4LXZhbGlkYXRvcj5cbiAgICA8L2R4LXNlbGVjdC1ib3g+XG4gIDwvZGl2PlxuPC9kaXY+XG48bmctY29udGFpbmVyICNtYXJrSXRlbUNvbmZpZ1JlZj48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
import { Component, HostListener, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { WordDesignerService } from "./word-designer.service";
|
|
3
|
+
import { deepClone, notifySuccess } from "../../util/utils";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../section/section.service";
|
|
6
|
+
import * as i2 from "./word-designer.service";
|
|
7
|
+
import * as i3 from "../../modal/modal.service";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
import * as i5 from "devextreme-angular/ui/nested";
|
|
10
|
+
import * as i6 from "devextreme-angular/ui/button";
|
|
11
|
+
import * as i7 from "devextreme-angular/ui/load-panel";
|
|
12
|
+
import * as i8 from "../section/section.component";
|
|
13
|
+
import * as i9 from "./mark-config/mark-config.component";
|
|
14
|
+
export class WordDesignerComponent {
|
|
15
|
+
handleKeyDown($event) {
|
|
16
|
+
switch ($event.code) {
|
|
17
|
+
case 'ArrowUp':
|
|
18
|
+
if ($event.altKey) {
|
|
19
|
+
this.service.switchMark(-1);
|
|
20
|
+
}
|
|
21
|
+
break;
|
|
22
|
+
case 'ArrowDown':
|
|
23
|
+
if ($event.altKey) {
|
|
24
|
+
this.service.switchMark(1);
|
|
25
|
+
}
|
|
26
|
+
break;
|
|
27
|
+
case 'KeyC':
|
|
28
|
+
if ($event.ctrlKey) {
|
|
29
|
+
const selection = window.getSelection();
|
|
30
|
+
if (selection?.toString()) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
this.copyMarkConfig();
|
|
34
|
+
}
|
|
35
|
+
break;
|
|
36
|
+
case 'KeyV':
|
|
37
|
+
if ($event.ctrlKey) {
|
|
38
|
+
this.pasteMarkConfig();
|
|
39
|
+
}
|
|
40
|
+
break;
|
|
41
|
+
case 'Escape':
|
|
42
|
+
this.exitPasteMode();
|
|
43
|
+
break;
|
|
44
|
+
}
|
|
45
|
+
if (this.mouseInViewer && $event.ctrlKey && $event.key === '0') {
|
|
46
|
+
$event.preventDefault();
|
|
47
|
+
this.scale(0);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
constructor(service, wordDesignerService, viewContainerRef, modalService) {
|
|
51
|
+
this.service = service;
|
|
52
|
+
this.wordDesignerService = wordDesignerService;
|
|
53
|
+
this.viewContainerRef = viewContainerRef;
|
|
54
|
+
this.modalService = modalService;
|
|
55
|
+
this.needUpload = false;
|
|
56
|
+
this.pasteMode = false;
|
|
57
|
+
this.mouseInViewer = false;
|
|
58
|
+
this.loading = false;
|
|
59
|
+
this.retainMarkConfig = false;
|
|
60
|
+
}
|
|
61
|
+
ngOnInit() {
|
|
62
|
+
this.service.tenant = this.tenant;
|
|
63
|
+
this.service.templateClassName = this.className;
|
|
64
|
+
this.service.templateOid = this.oid;
|
|
65
|
+
this.service.instanceClassName = this.instanceClassName;
|
|
66
|
+
this.service.params = this.params;
|
|
67
|
+
this.service.tabViewContainerRef = this.tabViewContainerRef;
|
|
68
|
+
this.loading = true;
|
|
69
|
+
this.wordDesignerService.loadTemplate(this.tenant, this.className, this.oid).subscribe(response => {
|
|
70
|
+
this.loadTemplateAndConfig(response);
|
|
71
|
+
this.loading = false;
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
loadTemplateAndConfig(response) {
|
|
75
|
+
this.sections = response.sections || [];
|
|
76
|
+
if (this.sections.length === 0) {
|
|
77
|
+
this.needUpload = true;
|
|
78
|
+
this.loading = false;
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
this.needUpload = false;
|
|
82
|
+
this.service.marks = response.marks.map((mark) => {
|
|
83
|
+
mark.config = mark.config || {};
|
|
84
|
+
return mark;
|
|
85
|
+
});
|
|
86
|
+
if (this.service.marks.length > 0) {
|
|
87
|
+
this.service.activeMark = this.service.marks[0];
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
scaleByMouse($event) {
|
|
91
|
+
if ($event.ctrlKey) {
|
|
92
|
+
$event.preventDefault();
|
|
93
|
+
this.scale($event.deltaY < 0 ? 0.1 : -0.1);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
scale(type) {
|
|
97
|
+
if (type === 0) {
|
|
98
|
+
this.service.scale = 1;
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
this.service.scale += type;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
upload() {
|
|
105
|
+
this.loading = true;
|
|
106
|
+
this.wordDesignerService.uploadTemplateFile(this.tenant, this.className, this.oid, this.retainMarkConfig, this.uploadInput.nativeElement.files[0]).subscribe(response => {
|
|
107
|
+
this.uploadInput.nativeElement.value = '';
|
|
108
|
+
this.loadTemplateAndConfig(response);
|
|
109
|
+
this.loading = false;
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
openReplaceTemplateFileModal() {
|
|
113
|
+
this.replaceFileModal = this.modalService.open(this.tabViewContainerRef, '替换文件', 'default', this.replaceFileModalTemplate, {});
|
|
114
|
+
}
|
|
115
|
+
replaceTemplateFile(retainMarkConfig) {
|
|
116
|
+
this.retainMarkConfig = retainMarkConfig;
|
|
117
|
+
this.uploadInput.nativeElement.click();
|
|
118
|
+
this.replaceFileModal?.hide();
|
|
119
|
+
}
|
|
120
|
+
downloadTemplateFile() {
|
|
121
|
+
this.loading = true;
|
|
122
|
+
this.wordDesignerService.downloadTemplateFile(this.tenant, this.className, this.oid, () => {
|
|
123
|
+
this.loading = false;
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
preview() {
|
|
127
|
+
for (let mark of this.service.marks) {
|
|
128
|
+
mark.value = undefined;
|
|
129
|
+
}
|
|
130
|
+
this.previewModal = this.modalService.open(this.tabViewContainerRef, '预览', 'full', this.previewTemplate, {}, this.previewFooterTemplate);
|
|
131
|
+
}
|
|
132
|
+
saveConfig() {
|
|
133
|
+
this.loading = true;
|
|
134
|
+
this.service.marks.map(mark => {
|
|
135
|
+
delete mark.value;
|
|
136
|
+
});
|
|
137
|
+
this.wordDesignerService.save(this.tenant, this.className, this.oid, {
|
|
138
|
+
templateConfig: JSON.stringify({
|
|
139
|
+
sections: this.sections,
|
|
140
|
+
marks: this.service.marks
|
|
141
|
+
})
|
|
142
|
+
}).subscribe(response => {
|
|
143
|
+
if (response.success) {
|
|
144
|
+
notifySuccess('保存成功');
|
|
145
|
+
this.loading = false;
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
copyMarkConfig() {
|
|
150
|
+
this.service.copiedMark = deepClone(this.service.activeMark);
|
|
151
|
+
this.pasteMode = true;
|
|
152
|
+
}
|
|
153
|
+
exitPasteMode() {
|
|
154
|
+
this.service.copiedMark = {};
|
|
155
|
+
this.service.readyPasteMarkNames = [];
|
|
156
|
+
this.service.lastClickToPasteMarkName = '';
|
|
157
|
+
this.pasteMode = false;
|
|
158
|
+
}
|
|
159
|
+
pasteMarkConfig() {
|
|
160
|
+
let readyPasteMark;
|
|
161
|
+
for (let readyPasteMarkName of this.service.readyPasteMarkNames) {
|
|
162
|
+
readyPasteMark = this.service.getMark(readyPasteMarkName);
|
|
163
|
+
const display = readyPasteMark.display;
|
|
164
|
+
Object.assign(readyPasteMark, deepClone(this.service.copiedMark));
|
|
165
|
+
readyPasteMark.name = readyPasteMarkName;
|
|
166
|
+
readyPasteMark.display = display;
|
|
167
|
+
}
|
|
168
|
+
this.service.activeMark = readyPasteMark || this.service.activeMark;
|
|
169
|
+
this.exitPasteMode();
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
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 });
|
|
173
|
+
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\"></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"] }] });
|
|
174
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerComponent, decorators: [{
|
|
175
|
+
type: Component,
|
|
176
|
+
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\"></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"] }]
|
|
177
|
+
}], ctorParameters: function () { return [{ type: i1.SectionService }, { type: i2.WordDesignerService }, { type: i0.ViewContainerRef }, { type: i3.ModalService }]; }, propDecorators: { tenant: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], className: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], oid: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], instanceClassName: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}], filterCategories: [{
|
|
186
|
+
type: Input
|
|
187
|
+
}], params: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}], tabViewContainerRef: [{
|
|
190
|
+
type: Input
|
|
191
|
+
}], uploadInput: [{
|
|
192
|
+
type: ViewChild,
|
|
193
|
+
args: ['uploadInput', { static: true }]
|
|
194
|
+
}], replaceFileModalTemplate: [{
|
|
195
|
+
type: ViewChild,
|
|
196
|
+
args: ['replaceFileModalTemplate', { static: true }]
|
|
197
|
+
}], previewTemplate: [{
|
|
198
|
+
type: ViewChild,
|
|
199
|
+
args: ['previewTemplate', { static: true }]
|
|
200
|
+
}], previewFooterTemplate: [{
|
|
201
|
+
type: ViewChild,
|
|
202
|
+
args: ['previewFooterTemplate', { static: true }]
|
|
203
|
+
}], handleKeyDown: [{
|
|
204
|
+
type: HostListener,
|
|
205
|
+
args: ['window:keydown', ['$event']]
|
|
206
|
+
}] } });
|
|
207
|
+
//# 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  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    this.service.copiedMark = deepClone(this.service.activeMark);\n    this.pasteMode = true;\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\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\"></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"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { WordDesignerComponent } from './word-designer.component';
|
|
4
|
+
import { MarkConfigComponent } from "./mark-config/mark-config.component";
|
|
5
|
+
import { DevExtremeModule } from "devextreme-angular";
|
|
6
|
+
import { SectionModule } from "../section/section.module";
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class WordDesignerModule {
|
|
9
|
+
}
|
|
10
|
+
WordDesignerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
+
WordDesignerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerModule, declarations: [WordDesignerComponent,
|
|
12
|
+
MarkConfigComponent], imports: [CommonModule,
|
|
13
|
+
DevExtremeModule,
|
|
14
|
+
SectionModule], exports: [WordDesignerComponent] });
|
|
15
|
+
WordDesignerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerModule, imports: [CommonModule,
|
|
16
|
+
DevExtremeModule,
|
|
17
|
+
SectionModule] });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerModule, decorators: [{
|
|
19
|
+
type: NgModule,
|
|
20
|
+
args: [{
|
|
21
|
+
declarations: [
|
|
22
|
+
WordDesignerComponent,
|
|
23
|
+
MarkConfigComponent
|
|
24
|
+
],
|
|
25
|
+
imports: [
|
|
26
|
+
CommonModule,
|
|
27
|
+
DevExtremeModule,
|
|
28
|
+
SectionModule
|
|
29
|
+
],
|
|
30
|
+
exports: [
|
|
31
|
+
WordDesignerComponent
|
|
32
|
+
]
|
|
33
|
+
}]
|
|
34
|
+
}] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29yZC1kZXNpZ25lci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy93b3JkL3dvcmQtZGVzaWduZXIvd29yZC1kZXNpZ25lci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDaEUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDeEUsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sb0JBQW9CLENBQUM7QUFDcEQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLDJCQUEyQixDQUFDOztBQWdCeEQsTUFBTSxPQUFPLGtCQUFrQjs7Z0hBQWxCLGtCQUFrQjtpSEFBbEIsa0JBQWtCLGlCQVozQixxQkFBcUI7UUFDckIsbUJBQW1CLGFBR25CLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsYUFBYSxhQUdiLHFCQUFxQjtpSEFHWixrQkFBa0IsWUFSM0IsWUFBWTtRQUNaLGdCQUFnQjtRQUNoQixhQUFhOzRGQU1KLGtCQUFrQjtrQkFkOUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1oscUJBQXFCO3dCQUNyQixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsYUFBYTtxQkFDZDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AscUJBQXFCO3FCQUN0QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1dvcmREZXNpZ25lckNvbXBvbmVudH0gZnJvbSAnLi93b3JkLWRlc2lnbmVyLmNvbXBvbmVudCc7XG5pbXBvcnQge01hcmtDb25maWdDb21wb25lbnR9IGZyb20gXCIuL21hcmstY29uZmlnL21hcmstY29uZmlnLmNvbXBvbmVudFwiO1xuaW1wb3J0IHtEZXZFeHRyZW1lTW9kdWxlfSBmcm9tIFwiZGV2ZXh0cmVtZS1hbmd1bGFyXCI7XG5pbXBvcnQge1NlY3Rpb25Nb2R1bGV9IGZyb20gXCIuLi9zZWN0aW9uL3NlY3Rpb24ubW9kdWxlXCI7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFdvcmREZXNpZ25lckNvbXBvbmVudCxcbiAgICBNYXJrQ29uZmlnQ29tcG9uZW50XG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRGV2RXh0cmVtZU1vZHVsZSxcbiAgICBTZWN0aW9uTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBXb3JkRGVzaWduZXJDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBXb3JkRGVzaWduZXJNb2R1bGUge1xufVxuIl19
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { map } from "rxjs";
|
|
3
|
+
import { downloadFile, filenameFromDisposition } from "../../util/utils";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common/http";
|
|
6
|
+
export class WordDesignerService {
|
|
7
|
+
constructor(http) {
|
|
8
|
+
this.http = http;
|
|
9
|
+
}
|
|
10
|
+
loadTemplate(tenant, className, oid) {
|
|
11
|
+
return this.http.get('api/data/' + className + '/' + oid, {
|
|
12
|
+
params: {
|
|
13
|
+
tenant
|
|
14
|
+
}
|
|
15
|
+
}).pipe(map(response => {
|
|
16
|
+
if (response.data?.templateConfig) {
|
|
17
|
+
return JSON.parse(response.data.templateConfig);
|
|
18
|
+
}
|
|
19
|
+
return {};
|
|
20
|
+
}));
|
|
21
|
+
}
|
|
22
|
+
uploadTemplateFile(tenant, className, oid, retainMarkConfig, file) {
|
|
23
|
+
const formData = new FormData();
|
|
24
|
+
formData.append('file', file);
|
|
25
|
+
return this.http.post('api/data/custom/upload', formData, {
|
|
26
|
+
params: {
|
|
27
|
+
executor: 'com.cs.system.word.designer.UploadTemplateFile',
|
|
28
|
+
tenant,
|
|
29
|
+
className,
|
|
30
|
+
oid,
|
|
31
|
+
retainMarkConfig,
|
|
32
|
+
filename: file.name
|
|
33
|
+
}
|
|
34
|
+
}).pipe(map(response => {
|
|
35
|
+
return response.data || {};
|
|
36
|
+
}));
|
|
37
|
+
}
|
|
38
|
+
downloadTemplateFile(tenant, className, oid, callback) {
|
|
39
|
+
return this.http.get('api/data/custom/download', {
|
|
40
|
+
params: {
|
|
41
|
+
executor: 'com.cs.system.word.designer.DownloadTemplate',
|
|
42
|
+
tenant,
|
|
43
|
+
className,
|
|
44
|
+
oid
|
|
45
|
+
},
|
|
46
|
+
observe: 'response',
|
|
47
|
+
responseType: 'blob'
|
|
48
|
+
}).subscribe(response => {
|
|
49
|
+
const disposition = response.headers.get('Content-Disposition');
|
|
50
|
+
const filename = disposition && filenameFromDisposition(disposition);
|
|
51
|
+
if (response.body) {
|
|
52
|
+
downloadFile(response.body, filename || '未命名文件', callback);
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
save(tenant, className, oid, model) {
|
|
57
|
+
return this.http.post('api/data/' + className + '/' + oid, model, {
|
|
58
|
+
params: {
|
|
59
|
+
tenant
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
WordDesignerService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
65
|
+
WordDesignerService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerService });
|
|
66
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WordDesignerService, decorators: [{
|
|
67
|
+
type: Injectable
|
|
68
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29yZC1kZXNpZ25lci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJzLWFudC9zcmMvd29yZC93b3JkLWRlc2lnbmVyL3dvcmQtZGVzaWduZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBQyxHQUFHLEVBQWEsTUFBTSxNQUFNLENBQUM7QUFDckMsT0FBTyxFQUFDLFlBQVksRUFBRSx1QkFBdUIsRUFBQyxNQUFNLGtCQUFrQixDQUFDOzs7QUFHdkUsTUFBTSxPQUFPLG1CQUFtQjtJQUM5QixZQUFvQixJQUFnQjtRQUFoQixTQUFJLEdBQUosSUFBSSxDQUFZO0lBQ3BDLENBQUM7SUFFRCxZQUFZLENBQUMsTUFBVyxFQUFFLFNBQWMsRUFBRSxHQUFRO1FBQ2hELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQU0sV0FBVyxHQUFHLFNBQVMsR0FBRyxHQUFHLEdBQUcsR0FBRyxFQUFFO1lBQzdELE1BQU0sRUFBRTtnQkFDTixNQUFNO2FBQ1A7U0FDRixDQUFDLENBQUMsSUFBSSxDQUNMLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUNiLElBQUksUUFBUSxDQUFDLElBQUksRUFBRSxjQUFjLEVBQUU7Z0JBQ2pDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO2FBQ2pEO1lBQ0QsT0FBTyxFQUFFLENBQUM7UUFDWixDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQztJQUVELGtCQUFrQixDQUFDLE1BQVcsRUFBRSxTQUFjLEVBQUUsR0FBUSxFQUFFLGdCQUFxQixFQUFFLElBQVM7UUFDeEYsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLEVBQUUsQ0FBQztRQUNoQyxRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUM5QixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFNLHdCQUF3QixFQUFFLFFBQVEsRUFBRTtZQUM3RCxNQUFNLEVBQUU7Z0JBQ04sUUFBUSxFQUFFLGdEQUFnRDtnQkFDMUQsTUFBTTtnQkFDTixTQUFTO2dCQUNULEdBQUc7Z0JBQ0gsZ0JBQWdCO2dCQUNoQixRQUFRLEVBQUUsSUFBSSxDQUFDLElBQUk7YUFDcEI7U0FDRixDQUFDLENBQUMsSUFBSSxDQUNMLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUNiLE9BQU8sUUFBUSxDQUFDLElBQUksSUFBSSxFQUFFLENBQUM7UUFDN0IsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxNQUFXLEVBQUUsU0FBYyxFQUFFLEdBQVEsRUFBRSxRQUFjO1FBQ3hFLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsMEJBQTBCLEVBQUU7WUFDL0MsTUFBTSxFQUFFO2dCQUNOLFFBQVEsRUFBRSw4Q0FBOEM7Z0JBQ3hELE1BQU07Z0JBQ04sU0FBUztnQkFDVCxHQUFHO2FBQ0o7WUFDRCxPQUFPLEVBQUUsVUFBVTtZQUNuQixZQUFZLEVBQUUsTUFBTTtTQUNyQixDQUFDLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxFQUFFO1lBQ3RCLE1BQU0sV0FBVyxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLHFCQUFxQixDQUFDLENBQUM7WUFDaEUsTUFBTSxRQUFRLEdBQUcsV0FBVyxJQUFJLHVCQUF1QixDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ3JFLElBQUksUUFBUSxDQUFDLElBQUksRUFBRTtnQkFDakIsWUFBWSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsUUFBUSxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsQ0FBQzthQUM1RDtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUksQ0FBQyxNQUFXLEVBQUUsU0FBYyxFQUFFLEdBQVEsRUFBRSxLQUFVO1FBQ3BELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQU0sV0FBVyxHQUFHLFNBQVMsR0FBRyxHQUFHLEdBQUcsR0FBRyxFQUFFLEtBQUssRUFBRTtZQUNyRSxNQUFNLEVBQUU7Z0JBQ04sTUFBTTthQUNQO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7aUhBL0RVLG1CQUFtQjtxSEFBbkIsbUJBQW1COzRGQUFuQixtQkFBbUI7a0JBRC9CLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtIdHRwQ2xpZW50fSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uL2h0dHBcIjtcbmltcG9ydCB7bWFwLCBPYnNlcnZhYmxlfSBmcm9tIFwicnhqc1wiO1xuaW1wb3J0IHtkb3dubG9hZEZpbGUsIGZpbGVuYW1lRnJvbURpc3Bvc2l0aW9ufSBmcm9tIFwiLi4vLi4vdXRpbC91dGlsc1wiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgV29yZERlc2lnbmVyU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cDogSHR0cENsaWVudCkge1xuICB9XG5cbiAgbG9hZFRlbXBsYXRlKHRlbmFudDogYW55LCBjbGFzc05hbWU6IGFueSwgb2lkOiBhbnkpOiBPYnNlcnZhYmxlPGFueT4ge1xuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PGFueT4oJ2FwaS9kYXRhLycgKyBjbGFzc05hbWUgKyAnLycgKyBvaWQsIHtcbiAgICAgIHBhcmFtczoge1xuICAgICAgICB0ZW5hbnRcbiAgICAgIH1cbiAgICB9KS5waXBlKFxuICAgICAgbWFwKHJlc3BvbnNlID0+IHtcbiAgICAgICAgaWYgKHJlc3BvbnNlLmRhdGE/LnRlbXBsYXRlQ29uZmlnKSB7XG4gICAgICAgICAgcmV0dXJuIEpTT04ucGFyc2UocmVzcG9uc2UuZGF0YS50ZW1wbGF0ZUNvbmZpZyk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHt9O1xuICAgICAgfSlcbiAgICApO1xuICB9XG5cbiAgdXBsb2FkVGVtcGxhdGVGaWxlKHRlbmFudDogYW55LCBjbGFzc05hbWU6IGFueSwgb2lkOiBhbnksIHJldGFpbk1hcmtDb25maWc6IGFueSwgZmlsZTogYW55KSB7XG4gICAgY29uc3QgZm9ybURhdGEgPSBuZXcgRm9ybURhdGEoKTtcbiAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGUnLCBmaWxlKTtcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3Q8YW55PignYXBpL2RhdGEvY3VzdG9tL3VwbG9hZCcsIGZvcm1EYXRhLCB7XG4gICAgICBwYXJhbXM6IHtcbiAgICAgICAgZXhlY3V0b3I6ICdjb20uY3Muc3lzdGVtLndvcmQuZGVzaWduZXIuVXBsb2FkVGVtcGxhdGVGaWxlJyxcbiAgICAgICAgdGVuYW50LFxuICAgICAgICBjbGFzc05hbWUsXG4gICAgICAgIG9pZCxcbiAgICAgICAgcmV0YWluTWFya0NvbmZpZyxcbiAgICAgICAgZmlsZW5hbWU6IGZpbGUubmFtZVxuICAgICAgfVxuICAgIH0pLnBpcGUoXG4gICAgICBtYXAocmVzcG9uc2UgPT4ge1xuICAgICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YSB8fCB7fTtcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIGRvd25sb2FkVGVtcGxhdGVGaWxlKHRlbmFudDogYW55LCBjbGFzc05hbWU6IGFueSwgb2lkOiBhbnksIGNhbGxiYWNrPzogYW55KSB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQoJ2FwaS9kYXRhL2N1c3RvbS9kb3dubG9hZCcsIHtcbiAgICAgIHBhcmFtczoge1xuICAgICAgICBleGVjdXRvcjogJ2NvbS5jcy5zeXN0ZW0ud29yZC5kZXNpZ25lci5Eb3dubG9hZFRlbXBsYXRlJyxcbiAgICAgICAgdGVuYW50LFxuICAgICAgICBjbGFzc05hbWUsXG4gICAgICAgIG9pZFxuICAgICAgfSxcbiAgICAgIG9ic2VydmU6ICdyZXNwb25zZScsXG4gICAgICByZXNwb25zZVR5cGU6ICdibG9iJ1xuICAgIH0pLnN1YnNjcmliZShyZXNwb25zZSA9PiB7XG4gICAgICBjb25zdCBkaXNwb3NpdGlvbiA9IHJlc3BvbnNlLmhlYWRlcnMuZ2V0KCdDb250ZW50LURpc3Bvc2l0aW9uJyk7XG4gICAgICBjb25zdCBmaWxlbmFtZSA9IGRpc3Bvc2l0aW9uICYmIGZpbGVuYW1lRnJvbURpc3Bvc2l0aW9uKGRpc3Bvc2l0aW9uKTtcbiAgICAgIGlmIChyZXNwb25zZS5ib2R5KSB7XG4gICAgICAgIGRvd25sb2FkRmlsZShyZXNwb25zZS5ib2R5LCBmaWxlbmFtZSB8fCAn5pyq5ZG95ZCN5paH5Lu2JywgY2FsbGJhY2spO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgc2F2ZSh0ZW5hbnQ6IGFueSwgY2xhc3NOYW1lOiBhbnksIG9pZDogYW55LCBtb2RlbDogYW55KSB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5wb3N0PGFueT4oJ2FwaS9kYXRhLycgKyBjbGFzc05hbWUgKyAnLycgKyBvaWQsIG1vZGVsLCB7XG4gICAgICBwYXJhbXM6IHtcbiAgICAgICAgdGVuYW50XG4gICAgICB9XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|