tnx-shared 5.3.213 → 5.3.215

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.
@@ -1,21 +1,39 @@
1
1
  /* eslint-disable prefer-const */
2
- import { Component, EventEmitter, Injector, Input, Output, ViewChild } from '@angular/core';
2
+ import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
3
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
4
  import { ComponentContextService } from '../../app-context/component-context.service';
4
- import { ComponentBase } from '../../classes/base/component-base';
5
5
  import { HtmlPreviewControlSchema } from '../../classes/form-schema';
6
+ import { CommonService } from '../../services/common.service';
6
7
  import { GlobalService } from '../../services/global.service';
7
- export class HtmlPreviewComponent extends ComponentBase {
8
- constructor(_injector, gs) {
9
- super(_injector);
8
+ export class HtmlPreviewComponent {
9
+ constructor(gs, _commonService) {
10
10
  this.gs = gs;
11
- this.content = '';
11
+ this._commonService = _commonService;
12
12
  this.control = new HtmlPreviewControlSchema();
13
- this.contentChange = new EventEmitter();
13
+ this.onChanged = new EventEmitter();
14
+ this.content = '';
15
+ this.id = '';
16
+ this.id = this._commonService.guid();
14
17
  }
15
- ngOnChanges(changes) {
16
- if (changes['content']) {
17
- this.renderMath();
18
+ // ngOnChanges(changes: SimpleChanges) {
19
+ // if (changes['content']) {
20
+ // this.renderMath();
21
+ // }
22
+ // }
23
+ writeValue(obj) {
24
+ if (obj) {
25
+ this.content = obj;
26
+ }
27
+ else {
28
+ this.content = '';
18
29
  }
30
+ this.renderMath();
31
+ }
32
+ registerOnChange(fn) {
33
+ this.onChange = fn;
34
+ }
35
+ registerOnTouched(fn) {
36
+ this.onTouched = fn;
19
37
  }
20
38
  renderMath() {
21
39
  this.mathJaxObject = this.gs.nativeGlobal()['MathJax'];
@@ -24,24 +42,29 @@ export class HtmlPreviewComponent extends ComponentBase {
24
42
  }
25
43
  setTimeout(() => {
26
44
  var _a, _b;
27
- const autoScrollBottom = !!((_a = this.control) === null || _a === void 0 ? void 0 : _a.autoScrollBottom);
28
- const output = this.mathContent.nativeElement;
29
- output.innerHTML = ((_b = this.content) === null || _b === void 0 ? void 0 : _b.trim()) || '';
30
- this.mathJaxObject.texReset();
31
- this.mathJaxObject.typesetClear();
32
- this.mathJaxObject.typesetPromise([output]).catch(function (err) {
45
+ const $this = this;
46
+ const autoScrollBottom = !!((_a = $this.control) === null || _a === void 0 ? void 0 : _a.autoScrollBottom);
47
+ const output = $this.mathContent.nativeElement;
48
+ output.innerHTML = ((_b = $this.content) === null || _b === void 0 ? void 0 : _b.trim()) || '';
49
+ $this.mathJaxObject.texReset();
50
+ $this.mathJaxObject.typesetClear();
51
+ $this.mathJaxObject.typesetPromise([output]).catch(function (err) {
33
52
  output.innerHTML = '';
34
53
  output.appendChild(document.createTextNode(err.message));
35
54
  console.error(err);
36
55
  }).then(function () {
56
+ var _a, _b, _c;
37
57
  // Do something after typeset
38
58
  if (autoScrollBottom) {
39
- const box = document.querySelector('#math-preview-box');
59
+ const box = document.querySelector(`#math-preview-box-${$this.id}`);
40
60
  const elem = box.getElementsByClassName('ps--active-y')[0];
41
61
  if (elem) {
42
62
  elem.scrollTop = elem.scrollHeight;
43
63
  }
44
64
  }
65
+ 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 : '';
66
+ $this.onChange(value);
67
+ $this.onChanged.emit(value);
45
68
  });
46
69
  return this.mathJaxObject.startup.defaultPageReady();
47
70
  });
@@ -104,19 +127,25 @@ export class HtmlPreviewComponent extends ComponentBase {
104
127
  HtmlPreviewComponent.decorators = [
105
128
  { type: Component, args: [{
106
129
  selector: 'html-preview',
107
- template: "<div class=\"preview-box\" id=\"math-preview-box\" [ngStyle]=\"{'height': control.height + 'px'}\">\n <tn-custom-scrollbar [showScrollHorizontal]=\"true\">\n <!-- <span #mathContent id=\"mathPreview\" [innerHTML]=\"content | safeHtml\"></span> -->\n <div #mathContent id=\"mathPreview\"></div>\n </tn-custom-scrollbar>\n</div>",
108
- providers: [ComponentContextService],
130
+ template: "<div class=\"preview-box\" id=\"math-preview-box-{{id}}\" [ngStyle]=\"{'height': control.height + 'px'}\">\n <tn-custom-scrollbar [showScrollHorizontal]=\"true\">\n <div #mathContent id=\"mathPreview-{{id}}\"></div>\n </tn-custom-scrollbar>\n</div>",
131
+ providers: [
132
+ ComponentContextService,
133
+ {
134
+ provide: NG_VALUE_ACCESSOR,
135
+ useExisting: forwardRef(() => HtmlPreviewComponent),
136
+ multi: true
137
+ },
138
+ ],
109
139
  styles: ["::ng-deep html-preview .preview-box{border:1px solid #ced4da;padding:10px}"]
110
140
  },] }
111
141
  ];
112
142
  HtmlPreviewComponent.ctorParameters = () => [
113
- { type: Injector },
114
- { type: GlobalService }
143
+ { type: GlobalService },
144
+ { type: CommonService }
115
145
  ];
116
146
  HtmlPreviewComponent.propDecorators = {
117
147
  mathContent: [{ type: ViewChild, args: ['mathContent',] }],
118
- content: [{ type: Input }],
119
148
  control: [{ type: Input }],
120
- contentChange: [{ type: Output }]
149
+ onChanged: [{ type: Output }]
121
150
  };
122
- //# 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, Injector, Input, OnChanges, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { ComponentContextService } from '../../app-context/component-context.service';\nimport { ComponentBase } from '../../classes/base/component-base';\nimport { HtmlPreviewControlSchema } from '../../classes/form-schema';\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: [ComponentContextService]\n})\nexport class HtmlPreviewComponent extends ComponentBase implements OnChanges {\n    @ViewChild('mathContent') mathContent;\n\n    @Input() content: string = '';\n    @Input() control: HtmlPreviewControlSchema = new HtmlPreviewControlSchema();\n\n    @Output() contentChange = new EventEmitter<any>();\n    mathJaxObject;\n\n    constructor(\n        _injector: Injector,\n        public gs: GlobalService\n    ) {\n        super(_injector);\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['content']) {\n            this.renderMath();\n        }\n    }\n\n    renderMath() {\n        this.mathJaxObject = this.gs.nativeGlobal()['MathJax'];\n        if (!this.mathJaxObject && !this.mathContent) {\n            return;\n        }\n        setTimeout(() => {\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');\n                    const elem = box.getElementsByClassName('ps--active-y')[0];\n                    if (elem) {\n                        elem.scrollTop = elem.scrollHeight;\n                    }\n                }\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"]}
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":"AAAA,iCAAiC;AACjC,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU,EAAY,KAAK,EAAqB,MAAM,EAAiB,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1I,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,uBAAuB,EAAE,MAAM,6CAA6C,CAAC;AAEtF,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAe9D,MAAM,OAAO,oBAAoB;IAY7B,YACW,EAAiB,EAChB,cAA6B;QAD9B,OAAE,GAAF,EAAE,CAAe;QAChB,mBAAc,GAAd,cAAc,CAAe;QAZhC,YAAO,GAA6B,IAAI,wBAAwB,EAAE,CAAC;QAClE,cAAS,GAAG,IAAI,YAAY,EAAO,CAAC;QAG9C,YAAO,GAAW,EAAE,CAAC;QAIrB,OAAE,GAAQ,EAAE,CAAC;QAMT,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IACxC,CAAC;IAEF,wCAAwC;IACxC,gCAAgC;IAChC,6BAA6B;IAC7B,QAAQ;IACR,IAAI;IAEJ,UAAU,CAAC,GAAQ;QACf,IAAI,GAAG,EAAE;YACL,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;SACtB;aACI;YACD,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;SACrB;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IACD,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,UAAU;QACN,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC,CAAC;QACvD,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YAC1C,OAAO;SACV;QACD,UAAU,CAAC,GAAG,EAAE;;YACZ,MAAM,KAAK,GAAG,IAAI,CAAC;YACnB,MAAM,gBAAgB,GAAG,CAAC,CAAC,CAAA,MAAA,KAAK,CAAC,OAAO,0CAAE,gBAAgB,CAAA,CAAC;YAC3D,MAAM,MAAM,GAAG,KAAK,CAAC,WAAW,CAAC,aAAa,CAAC;YAC/C,MAAM,CAAC,SAAS,GAAG,CAAA,MAAA,KAAK,CAAC,OAAO,0CAAE,IAAI,EAAE,KAAI,EAAE,CAAC;YAC/C,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YAC/B,KAAK,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;YACnC,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,GAAG;gBAC5D,MAAM,CAAC,SAAS,GAAG,EAAE,CAAC;gBACtB,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;gBACzD,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC,IAAI,CAAC;;gBACJ,6BAA6B;gBAC7B,IAAI,gBAAgB,EAAE;oBAClB,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,qBAAqB,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;oBACpE,MAAM,IAAI,GAAG,GAAG,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3D,IAAI,IAAI,EAAE;wBACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC;qBACtC;iBACJ;gBACD,MAAM,KAAK,GAAG,MAAA,MAAA,MAAA,QAAQ,CAAC,cAAc,CAAC,eAAe,KAAK,CAAC,EAAE,EAAE,CAAC,0CAAE,SAAS,0CAAE,IAAI,EAAE,mCAAI,EAAE,CAAC;gBAC1F,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACtB,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAChC,CAAC,CAAC,CAAC;YACH,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;QACzD,CAAC,CAAC,CAAC;IACP,CAAC;IAED,cAAc;;QACV,MAAM,EAAE,GAAQ,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;QACvC,EAAE,CAAC,OAAO,GAAG;YACT,QAAQ,EAAE,EAAE,IAAI,EAAE,CAAC,iBAAiB,EAAE,cAAc,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,CAAC,EAAE;YAC9F,KAAK,EAAE;gBACH,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBACxC,cAAc,EAAE,IAAI;aACvB;YACD,SAAS,EAAE;gBACP,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE;aACrC;YACD,KAAK,EAAE;gBACH,KAAK,EAAE,CAAC;gBACR,QAAQ,EAAE,EAAE;aACf;YACD,SAAS,EAAE;gBACP,UAAU,EAAE,CAAC,CAAC,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,cAAc,CAAA;gBAC1C,WAAW,EAAE;oBACT,QAAQ,EAAE;wBACN,QAAQ,EAAE,IAAI;wBACd,SAAS,EAAE,KAAK;wBAChB,IAAI,EAAE,cAAc;wBACpB,MAAM,EAAE,MAAM;wBACd,QAAQ,EAAE,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,WAAW,EAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO;wBACxE,KAAK,EAAE,CAAC;wBACR,UAAU,EAAE,IAAI;wBAEhB,YAAY,EAAE,IAAI;wBAClB,WAAW,EAAE,KAAK;wBAClB,QAAQ,EAAE,KAAK,EAAE,mDAAmD;qBACvE;oBACD,eAAe,EAAE;wBACb,GAAG,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,mBAAmB,CAAC;wBAC1C,QAAQ,EAAE,CAAC,cAAc,CAAC;wBAC1B,KAAK,EAAE,CAAC,OAAO,CAAC;wBAChB,aAAa,EAAE,CAAC,gBAAgB,EAAE,gCAAgC,CAAC;wBACnE,QAAQ,EAAE,CAAC,UAAU,CAAC;qBACzB;iBACJ;aACJ;SACJ,CAAC;QACF,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAChD,IAAI,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,WAAW,KAAI,KAAK,EAAE;YACpC,MAAM,CAAC,GAAG,GAAG,sCAAsC,CAAC;SACvD;aACI;YACD,MAAM,CAAC,GAAG,GAAG,wCAAwC,CAAC;SACzD;QACD,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;QAC5C,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;;;YA9IJ,SAAS,SAAC;gBACP,QAAQ,EAAE,cAAc;gBACxB,iRAA4C;gBAE5C,SAAS,EAAE;oBACP,uBAAuB;oBACvB;wBACI,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;wBACnD,KAAK,EAAE,IAAI;qBACd;iBACJ;;aACJ;;;YAdQ,aAAa;YADb,aAAa;;;0BAiBjB,SAAS,SAAC,aAAa;sBACvB,KAAK;wBACL,MAAM","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"]}