tnx-shared 5.3.231 → 5.3.233
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/bundles/tnx-shared.umd.js +31 -25
- package/bundles/tnx-shared.umd.js.map +1 -1
- package/bundles/tnx-shared.umd.min.js +1 -1
- package/bundles/tnx-shared.umd.min.js.map +1 -1
- package/components/html-preview/html-preview.component.d.ts.map +1 -1
- package/esm2015/classes/base/list-component-base.js +2 -2
- package/esm2015/components/html-preview/html-preview.component.js +31 -23
- package/fesm2015/tnx-shared.js +32 -24
- package/fesm2015/tnx-shared.js.map +1 -1
- package/package.json +2 -2
|
@@ -14,6 +14,7 @@ export class HtmlPreviewComponent {
|
|
|
14
14
|
this.content = '';
|
|
15
15
|
this.id = '';
|
|
16
16
|
this.id = this._commonService.guid();
|
|
17
|
+
this.loadMathConfig();
|
|
17
18
|
}
|
|
18
19
|
// ngOnChanges(changes: SimpleChanges) {
|
|
19
20
|
// if (changes['content']) {
|
|
@@ -45,28 +46,36 @@ export class HtmlPreviewComponent {
|
|
|
45
46
|
const $this = this;
|
|
46
47
|
const autoScrollBottom = !!((_a = $this.control) === null || _a === void 0 ? void 0 : _a.autoScrollBottom);
|
|
47
48
|
const output = $this.mathContent.nativeElement;
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
$this.mathJaxObject.
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
49
|
+
let content = ((_b = $this.content) === null || _b === void 0 ? void 0 : _b.trim()) || '';
|
|
50
|
+
content = content.replace(/\n/g, '<br>');
|
|
51
|
+
output.innerHTML = content;
|
|
52
|
+
if ($this.mathJaxObject.texReset) {
|
|
53
|
+
$this.mathJaxObject.texReset();
|
|
54
|
+
}
|
|
55
|
+
if ($this.mathJaxObject.typesetClear) {
|
|
56
|
+
$this.mathJaxObject.typesetClear();
|
|
57
|
+
}
|
|
58
|
+
if ($this.mathJaxObject.typesetPromise) {
|
|
59
|
+
$this.mathJaxObject.typesetPromise([output]).catch(function (err) {
|
|
60
|
+
output.innerHTML = '';
|
|
61
|
+
output.appendChild(document.createTextNode(err.message));
|
|
62
|
+
console.error(err);
|
|
63
|
+
}).then(function () {
|
|
64
|
+
var _a, _b, _c;
|
|
65
|
+
// Do something after typeset
|
|
66
|
+
if (autoScrollBottom) {
|
|
67
|
+
const box = document.querySelector(`#math-preview-box-${$this.id}`);
|
|
68
|
+
const elem = box.getElementsByClassName('ps--active-y')[0];
|
|
69
|
+
if (elem) {
|
|
70
|
+
elem.scrollTop = elem.scrollHeight;
|
|
71
|
+
}
|
|
63
72
|
}
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
}
|
|
69
|
-
return this.mathJaxObject.startup.defaultPageReady();
|
|
73
|
+
const value = (_c = (_b = (_a = document.getElementById(`mathPreview-${$this.id}`)) === null || _a === void 0 ? void 0 : _a.innerHTML) === null || _b === void 0 ? void 0 : _b.trim()) !== null && _c !== void 0 ? _c : '';
|
|
74
|
+
$this.onChange(value);
|
|
75
|
+
$this.onChanged.emit(value);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
return $this.mathJaxObject.startup.defaultPageReady ? $this.mathJaxObject.startup.defaultPageReady() : $this.mathJaxObject.startup.defaultPageReady;
|
|
70
79
|
});
|
|
71
80
|
}
|
|
72
81
|
loadMathConfig() {
|
|
@@ -121,7 +130,6 @@ export class HtmlPreviewComponent {
|
|
|
121
130
|
document.head.appendChild(script);
|
|
122
131
|
}
|
|
123
132
|
ngOnInit() {
|
|
124
|
-
this.loadMathConfig();
|
|
125
133
|
}
|
|
126
134
|
}
|
|
127
135
|
HtmlPreviewComponent.decorators = [
|
|
@@ -148,4 +156,4 @@ HtmlPreviewComponent.propDecorators = {
|
|
|
148
156
|
control: [{ type: Input }],
|
|
149
157
|
onChanged: [{ type: Output }]
|
|
150
158
|
};
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"html-preview.component.js","sourceRoot":"","sources":["../../../../../projects/tnx-shared/src/lib/components/html-preview/html-preview.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable prefer-const */\nimport { Component, EventEmitter, forwardRef, Injector, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ComponentContextService } from '../../app-context/component-context.service';\nimport { ComponentBase } from '../../classes/base/component-base';\nimport { HtmlPreviewControlSchema } from '../../classes/form-schema';\nimport { CommonService } from '../../services/common.service';\nimport { GlobalService } from '../../services/global.service';\n\n@Component({\n    selector: 'html-preview',\n    templateUrl: './html-preview.component.html',\n    styleUrls: ['./html-preview.component.scss'],\n    providers: [\n        ComponentContextService,\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => HtmlPreviewComponent),\n            multi: true\n        },\n    ]\n})\nexport class HtmlPreviewComponent implements OnInit, ControlValueAccessor {\n    @ViewChild('mathContent') mathContent;\n    @Input() control: HtmlPreviewControlSchema = new HtmlPreviewControlSchema();\n    @Output() onChanged = new EventEmitter<any>();\n\n    mathJaxObject;\n    content: string = '';\n\n    onChange: Function;\n    onTouched: Function;\n    id: any = '';\n\n    constructor(\n        public gs: GlobalService,\n        private _commonService: CommonService\n    ) {\n        this.id = this._commonService.guid();\n     }\n\n    // ngOnChanges(changes: SimpleChanges) {\n    //     if (changes['content']) {\n    //         this.renderMath();\n    //     }\n    // }\n\n    writeValue(obj: any): void {\n        if (obj) {\n            this.content = obj;\n        }\n        else {\n            this.content = '';\n        }\n        this.renderMath();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    renderMath() {\n        this.mathJaxObject = this.gs.nativeGlobal()['MathJax'];\n        if (!this.mathJaxObject && !this.mathContent) {\n            return;\n        }\n        setTimeout(() => {\n            const $this = this;\n            const autoScrollBottom = !!$this.control?.autoScrollBottom;\n            const output = $this.mathContent.nativeElement;\n            output.innerHTML = $this.content?.trim() || '';\n            $this.mathJaxObject.texReset();\n            $this.mathJaxObject.typesetClear();\n            $this.mathJaxObject.typesetPromise([output]).catch(function (err) {\n                output.innerHTML = '';\n                output.appendChild(document.createTextNode(err.message));\n                console.error(err);\n            }).then(function () {\n                // Do something after typeset\n                if (autoScrollBottom) {\n                    const box = document.querySelector(`#math-preview-box-${$this.id}`);\n                    const elem = box.getElementsByClassName('ps--active-y')[0];\n                    if (elem) {\n                        elem.scrollTop = elem.scrollHeight;\n                    }\n                }\n                const value = document.getElementById(`mathPreview-${$this.id}`)?.innerHTML?.trim() ?? '';\n                $this.onChange(value);\n                $this.onChanged.emit(value);\n            });\n            return this.mathJaxObject.startup.defaultPageReady();\n        });\n    }\n\n    loadMathConfig() {\n        const wd: any = this.gs.nativeGlobal();\n        wd.MathJax = {\n            'loader': { load: ['input/asciimath', 'output/chtml', 'ui/menu', 'output/svg', '[mml]/mml3'] },\n            'tex': {\n                inlineMath: [['$', '$'], ['\\\\(', '\\\\)']],\n                processEscapes: true\n            },\n            'startup': {\n                pageReady: () => this.renderMath()\n            },\n            'svg': {\n                scale: 1,\n                minScale: .5\n            },\n            'options': {\n                enableMenu: !!this.control?.useMathJaxMenu, // set to false to disable the menu\n                menuOptions: {\n                    settings: {\n                        texHints: true, // put TeX-related attributes on MathML\n                        semantics: false, // put original format in <semantic> tag in MathML\n                        zoom: 'Double-Click', // or 'Click' or 'DoubleClick' as zoom trigger\n                        zscale: '200%', // zoom scaling factor\n                        renderer: this.control?.mathJaxType ? this.control.mathJaxType : 'CHTML',\n                        scale: 1, // scaling factor for all math\n                        inTabOrder: true, // true if tabbing includes math\n\n                        assistiveMml: true, // true if hidden assistive MathML should be generated for screen readers\n                        collapsible: false, // true if complex math should be collapsible\n                        explorer: false, // true if the expression explorer should be active\n                    },\n                    annotationTypes: {\n                        TeX: ['TeX', 'LaTeX', 'application/x-tex'],\n                        StarMath: ['StarMath 5.0'],\n                        Maple: ['Maple'],\n                        ContentMathML: ['MathML-Content', 'application/mathml-content+xml'],\n                        OpenMath: ['OpenMath']\n                    }\n                }\n            }\n        };\n        const script = document.createElement('script');\n        if (this.control?.mathJaxType == 'SVG') {\n            script.src = 'assets/vendor/mathjax/tex-mml-svg.js';\n        }\n        else {\n            script.src = 'assets/vendor/mathjax/tex-mml-chtml.js';\n        }\n        script.setAttribute('id', 'MathJax-script');\n        document.head.appendChild(script);\n    }\n\n    ngOnInit() {\n        this.loadMathConfig();\n    }\n}\n"]}
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"html-preview.component.js","sourceRoot":"","sources":["../../../../../projects/tnx-shared/src/lib/components/html-preview/html-preview.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable prefer-const */\nimport { Component, EventEmitter, forwardRef, Injector, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ComponentContextService } from '../../app-context/component-context.service';\nimport { ComponentBase } from '../../classes/base/component-base';\nimport { HtmlPreviewControlSchema } from '../../classes/form-schema';\nimport { CommonService } from '../../services/common.service';\nimport { GlobalService } from '../../services/global.service';\n\n@Component({\n    selector: 'html-preview',\n    templateUrl: './html-preview.component.html',\n    styleUrls: ['./html-preview.component.scss'],\n    providers: [\n        ComponentContextService,\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => HtmlPreviewComponent),\n            multi: true\n        },\n    ]\n})\nexport class HtmlPreviewComponent implements OnInit, ControlValueAccessor {\n    @ViewChild('mathContent') mathContent;\n    @Input() control: HtmlPreviewControlSchema = new HtmlPreviewControlSchema();\n    @Output() onChanged = new EventEmitter<any>();\n\n    mathJaxObject;\n    content: string = '';\n\n    onChange: Function;\n    onTouched: Function;\n    id: any = '';\n\n    constructor(\n        public gs: GlobalService,\n        private _commonService: CommonService\n    ) {\n        this.id = this._commonService.guid();\n        this.loadMathConfig();\n    }\n\n    // ngOnChanges(changes: SimpleChanges) {\n    //     if (changes['content']) {\n    //         this.renderMath();\n    //     }\n    // }\n\n    writeValue(obj: any): void {\n        if (obj) {\n            this.content = obj;\n        }\n        else {\n            this.content = '';\n        }\n        this.renderMath();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    renderMath() {\n        this.mathJaxObject = this.gs.nativeGlobal()['MathJax'];\n        if (!this.mathJaxObject && !this.mathContent) {\n            return;\n        }\n        setTimeout(() => {\n            const $this = this;\n            const autoScrollBottom = !!$this.control?.autoScrollBottom;\n            const output = $this.mathContent.nativeElement;\n            let content = $this.content?.trim() || '';\n            content = content.replace(/\\n/g, '<br>');\n            output.innerHTML = content;\n            if ($this.mathJaxObject.texReset) {\n                $this.mathJaxObject.texReset();\n            }\n            if ($this.mathJaxObject.typesetClear) {\n                $this.mathJaxObject.typesetClear();\n            }\n            if ($this.mathJaxObject.typesetPromise) {\n                $this.mathJaxObject.typesetPromise([output]).catch(function (err) {\n                    output.innerHTML = '';\n                    output.appendChild(document.createTextNode(err.message));\n                    console.error(err);\n                }).then(function () {\n                    // Do something after typeset\n                    if (autoScrollBottom) {\n                        const box = document.querySelector(`#math-preview-box-${$this.id}`);\n                        const elem = box.getElementsByClassName('ps--active-y')[0];\n                        if (elem) {\n                            elem.scrollTop = elem.scrollHeight;\n                        }\n                    }\n                    const value = document.getElementById(`mathPreview-${$this.id}`)?.innerHTML?.trim() ?? '';\n                    $this.onChange(value);\n                    $this.onChanged.emit(value);\n                });\n            }\n            return $this.mathJaxObject.startup.defaultPageReady ? $this.mathJaxObject.startup.defaultPageReady() : $this.mathJaxObject.startup.defaultPageReady;\n        });\n    }\n\n    loadMathConfig() {\n        const wd: any = this.gs.nativeGlobal();\n        wd.MathJax = {\n            'loader': { load: ['input/asciimath', 'output/chtml', 'ui/menu', 'output/svg', '[mml]/mml3'] },\n            'tex': {\n                inlineMath: [['$', '$'], ['\\\\(', '\\\\)']],\n                processEscapes: true\n            },\n            'startup': {\n                pageReady: () => this.renderMath()\n            },\n            'svg': {\n                scale: 1,\n                minScale: .5\n            },\n            'options': {\n                enableMenu: !!this.control?.useMathJaxMenu, // set to false to disable the menu\n                menuOptions: {\n                    settings: {\n                        texHints: true, // put TeX-related attributes on MathML\n                        semantics: false, // put original format in <semantic> tag in MathML\n                        zoom: 'Double-Click', // or 'Click' or 'DoubleClick' as zoom trigger\n                        zscale: '200%', // zoom scaling factor\n                        renderer: this.control?.mathJaxType ? this.control.mathJaxType : 'CHTML',\n                        scale: 1, // scaling factor for all math\n                        inTabOrder: true, // true if tabbing includes math\n\n                        assistiveMml: true, // true if hidden assistive MathML should be generated for screen readers\n                        collapsible: false, // true if complex math should be collapsible\n                        explorer: false, // true if the expression explorer should be active\n                    },\n                    annotationTypes: {\n                        TeX: ['TeX', 'LaTeX', 'application/x-tex'],\n                        StarMath: ['StarMath 5.0'],\n                        Maple: ['Maple'],\n                        ContentMathML: ['MathML-Content', 'application/mathml-content+xml'],\n                        OpenMath: ['OpenMath']\n                    }\n                }\n            }\n        };\n        const script = document.createElement('script');\n        if (this.control?.mathJaxType == 'SVG') {\n            script.src = 'assets/vendor/mathjax/tex-mml-svg.js';\n        }\n        else {\n            script.src = 'assets/vendor/mathjax/tex-mml-chtml.js';\n        }\n        script.setAttribute('id', 'MathJax-script');\n        document.head.appendChild(script);\n    }\n\n    ngOnInit() {\n    }\n}\n"]}
|
package/fesm2015/tnx-shared.js
CHANGED
|
@@ -21442,7 +21442,7 @@ class ListComponentBase extends ComponentBase {
|
|
|
21442
21442
|
compRef.instance.tableName = this.workflowHistoryModel.data.tableName;
|
|
21443
21443
|
compRef.instance.item = rowData;
|
|
21444
21444
|
compRef.instance.workflowSetting = workflowSetting;
|
|
21445
|
-
compRef.instance.onCancel.subscribe(event => this.workflowHistoryModel.showEditForm = false);
|
|
21445
|
+
// compRef.instance.onCancel.subscribe(event => this.workflowHistoryModel.showEditForm = false);
|
|
21446
21446
|
});
|
|
21447
21447
|
}
|
|
21448
21448
|
handleHideHistoryWorkflow() {
|
|
@@ -47043,6 +47043,7 @@ class HtmlPreviewComponent {
|
|
|
47043
47043
|
this.content = '';
|
|
47044
47044
|
this.id = '';
|
|
47045
47045
|
this.id = this._commonService.guid();
|
|
47046
|
+
this.loadMathConfig();
|
|
47046
47047
|
}
|
|
47047
47048
|
// ngOnChanges(changes: SimpleChanges) {
|
|
47048
47049
|
// if (changes['content']) {
|
|
@@ -47074,28 +47075,36 @@ class HtmlPreviewComponent {
|
|
|
47074
47075
|
const $this = this;
|
|
47075
47076
|
const autoScrollBottom = !!((_a = $this.control) === null || _a === void 0 ? void 0 : _a.autoScrollBottom);
|
|
47076
47077
|
const output = $this.mathContent.nativeElement;
|
|
47077
|
-
|
|
47078
|
-
|
|
47079
|
-
|
|
47080
|
-
$this.mathJaxObject.
|
|
47081
|
-
|
|
47082
|
-
|
|
47083
|
-
|
|
47084
|
-
|
|
47085
|
-
|
|
47086
|
-
|
|
47087
|
-
|
|
47088
|
-
|
|
47089
|
-
|
|
47090
|
-
|
|
47091
|
-
|
|
47092
|
-
|
|
47093
|
-
|
|
47094
|
-
|
|
47095
|
-
|
|
47096
|
-
|
|
47097
|
-
|
|
47098
|
-
|
|
47078
|
+
let content = ((_b = $this.content) === null || _b === void 0 ? void 0 : _b.trim()) || '';
|
|
47079
|
+
content = content.replace(/\n/g, '<br>');
|
|
47080
|
+
output.innerHTML = content;
|
|
47081
|
+
if ($this.mathJaxObject.texReset) {
|
|
47082
|
+
$this.mathJaxObject.texReset();
|
|
47083
|
+
}
|
|
47084
|
+
if ($this.mathJaxObject.typesetClear) {
|
|
47085
|
+
$this.mathJaxObject.typesetClear();
|
|
47086
|
+
}
|
|
47087
|
+
if ($this.mathJaxObject.typesetPromise) {
|
|
47088
|
+
$this.mathJaxObject.typesetPromise([output]).catch(function (err) {
|
|
47089
|
+
output.innerHTML = '';
|
|
47090
|
+
output.appendChild(document.createTextNode(err.message));
|
|
47091
|
+
console.error(err);
|
|
47092
|
+
}).then(function () {
|
|
47093
|
+
var _a, _b, _c;
|
|
47094
|
+
// Do something after typeset
|
|
47095
|
+
if (autoScrollBottom) {
|
|
47096
|
+
const box = document.querySelector(`#math-preview-box-${$this.id}`);
|
|
47097
|
+
const elem = box.getElementsByClassName('ps--active-y')[0];
|
|
47098
|
+
if (elem) {
|
|
47099
|
+
elem.scrollTop = elem.scrollHeight;
|
|
47100
|
+
}
|
|
47101
|
+
}
|
|
47102
|
+
const value = (_c = (_b = (_a = document.getElementById(`mathPreview-${$this.id}`)) === null || _a === void 0 ? void 0 : _a.innerHTML) === null || _b === void 0 ? void 0 : _b.trim()) !== null && _c !== void 0 ? _c : '';
|
|
47103
|
+
$this.onChange(value);
|
|
47104
|
+
$this.onChanged.emit(value);
|
|
47105
|
+
});
|
|
47106
|
+
}
|
|
47107
|
+
return $this.mathJaxObject.startup.defaultPageReady ? $this.mathJaxObject.startup.defaultPageReady() : $this.mathJaxObject.startup.defaultPageReady;
|
|
47099
47108
|
});
|
|
47100
47109
|
}
|
|
47101
47110
|
loadMathConfig() {
|
|
@@ -47150,7 +47159,6 @@ class HtmlPreviewComponent {
|
|
|
47150
47159
|
document.head.appendChild(script);
|
|
47151
47160
|
}
|
|
47152
47161
|
ngOnInit() {
|
|
47153
|
-
this.loadMathConfig();
|
|
47154
47162
|
}
|
|
47155
47163
|
}
|
|
47156
47164
|
HtmlPreviewComponent.decorators = [
|