tnx-shared 5.3.240 → 5.3.241

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.
@@ -46,7 +46,9 @@ export class HtmlPreviewComponent {
46
46
  const autoScrollBottom = !!((_a = $this.control) === null || _a === void 0 ? void 0 : _a.autoScrollBottom);
47
47
  const output = $this.mathContent.nativeElement;
48
48
  let content = ((_b = $this.content) === null || _b === void 0 ? void 0 : _b.trim()) || '';
49
- content = content.replace(/\n/g, '<br>');
49
+ if (!$this.control.isHtml) {
50
+ content = content.replace(/\n/g, '<br>');
51
+ }
50
52
  output.innerHTML = content;
51
53
  if ($this.mathJaxObject.texReset) {
52
54
  $this.mathJaxObject.texReset();
@@ -156,4 +158,4 @@ HtmlPreviewComponent.propDecorators = {
156
158
  control: [{ type: Input }],
157
159
  onChanged: [{ type: Output }]
158
160
  };
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":"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;IACzC,CAAC;IAED,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,IAAI,OAAO,GAAG,CAAA,MAAA,KAAK,CAAC,OAAO,0CAAE,IAAI,EAAE,KAAI,EAAE,CAAC;YAC1C,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;YACzC,MAAM,CAAC,SAAS,GAAG,OAAO,CAAC;YAC3B,IAAI,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE;gBAC9B,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;aAClC;YACD,IAAI,KAAK,CAAC,aAAa,CAAC,YAAY,EAAE;gBAClC,KAAK,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;aACtC;YACD,IAAI,KAAK,CAAC,aAAa,CAAC,cAAc,EAAE;gBACpC,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,GAAG;oBAC5D,MAAM,CAAC,SAAS,GAAG,EAAE,CAAC;oBACtB,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;oBACzD,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACvB,CAAC,CAAC,CAAC,IAAI,CAAC;;oBACJ,6BAA6B;oBAC7B,IAAI,gBAAgB,EAAE;wBAClB,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,qBAAqB,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;wBACpE,MAAM,IAAI,GAAG,GAAG,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;wBAC3D,IAAI,IAAI,EAAE;4BACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC;yBACtC;qBACJ;oBACD,MAAM,KAAK,GAAG,MAAA,MAAA,MAAA,QAAQ,CAAC,cAAc,CAAC,eAAe,KAAK,CAAC,EAAE,EAAE,CAAC,0CAAE,SAAS,0CAAE,IAAI,EAAE,mCAAI,EAAE,CAAC;oBAC1F,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACtB,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAChC,CAAC,CAAC,CAAC;aACN;YACD,OAAO,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC;QACxJ,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;;;YAtJJ,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            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        this.loadMathConfig();\n    }\n}\n"]}
161
+ //# 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            let content = $this.content?.trim() || '';\n            if (!$this.control.isHtml) {\n                content = content.replace(/\\n/g, '<br>');\n            }\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        this.loadMathConfig();\n    }\n}\n"]}
@@ -1637,6 +1637,7 @@ class HtmlPreviewControlSchema extends FormControlBase {
1637
1637
  this.height = 250;
1638
1638
  this.useMathJaxMenu = false;
1639
1639
  this.autoScrollBottom = false;
1640
+ this.isHtml = true;
1640
1641
  for (const key in init) {
1641
1642
  this[key] = init[key];
1642
1643
  }
@@ -47094,7 +47095,9 @@ class HtmlPreviewComponent {
47094
47095
  const autoScrollBottom = !!((_a = $this.control) === null || _a === void 0 ? void 0 : _a.autoScrollBottom);
47095
47096
  const output = $this.mathContent.nativeElement;
47096
47097
  let content = ((_b = $this.content) === null || _b === void 0 ? void 0 : _b.trim()) || '';
47097
- content = content.replace(/\n/g, '<br>');
47098
+ if (!$this.control.isHtml) {
47099
+ content = content.replace(/\n/g, '<br>');
47100
+ }
47098
47101
  output.innerHTML = content;
47099
47102
  if ($this.mathJaxObject.texReset) {
47100
47103
  $this.mathJaxObject.texReset();