ngx-edu-sharing-ui 10.0.11 → 10.0.13

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.
@@ -74,10 +74,11 @@ export class MdsViewerComponent {
74
74
  }
75
75
  // wait for angular to inflate the new binding
76
76
  setTimeout(() => {
77
- for (const widget of (this.mdsEditorInstanceService?.widgets.value.map((w) => w.definition) || this.mds.widgets)) {
77
+ for (const widget of (this.mdsEditorInstanceService?.widgets.value ||
78
+ this.mds.widgets.map(definition => { return { definition }; }))) {
78
79
  // @TODO: it would be better to filter by widgets based on template and condition, should be implemented in 5.1
79
80
  this.container.toArray().forEach((c) => {
80
- let element = c.nativeElement.getElementsByTagName(widget.id)?.[0];
81
+ let element = c.nativeElement.getElementsByTagName(widget.definition.id)?.[0];
81
82
  if (element) {
82
83
  // MdsEditorViewComponent.updateWidgetWithHTMLAttributes(element, w);
83
84
  element = replaceElementWithDiv(element);
@@ -153,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
153
154
  }], headingLevel: [{
154
155
  type: Input
155
156
  }] } });
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mds-viewer.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/mds-viewer/mds-viewer.component.ts","../../../../../projects/edu-sharing-ui/src/lib/mds-viewer/mds-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentFactoryResolver,\n    ElementRef,\n    Injector,\n    Input,\n    OnChanges,\n    QueryList,\n    SimpleChanges,\n    ViewChildren,\n    ViewContainerRef,\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { MdsWidgetComponent } from './widget/mds-widget.component';\nimport {\n    HOME_REPOSITORY,\n    MdsDefinition,\n    MdsService,\n    MdsView, MdsWidget,\n    RestConstants,\n} from 'ngx-edu-sharing-api';\nimport { Values } from '../services/search-helper.service';\nimport { replaceElementWithDiv } from './replace-element-with-div';\nimport { UIService } from '../services/ui.service';\nimport { MdsViewerService } from './mds-viewer.service';\nimport { ViewInstanceService } from './view-instance.service';\n\n@Component({\n    selector: 'es-mds-viewer',\n    templateUrl: 'mds-viewer.component.html',\n    styleUrls: ['mds-viewer.component.scss'],\n    providers: [MdsViewerService, ViewInstanceService],\n})\nexport class MdsViewerComponent implements OnChanges {\n    @ViewChildren('container') container: QueryList<ElementRef>;\n\n    @Input() mdsEditorInstanceService: any;\n    @Input() groupId: string;\n    @Input() setId: string;\n    @Input() data: Values;\n    mds: MdsDefinition;\n    templates: {\n        view: MdsView;\n        html: SafeHtml;\n    }[];\n\n    /**\n     * show group headings (+ icons) for the individual templates\n     */\n    @Input() showGroupHeadings = true;\n\n    /**\n     * The heading level from 1 to 6 to use for widget labels, equivalent to `h1` to `h6`.\n     *\n     * If not set, widget labels are not marked as headings and an invisible colon is added between\n     * labels and values, that will be read out by screen readers.\n     */\n    @Input()\n    set headingLevel(value: number | null) {\n        this.viewInstance.headingLevel = value;\n    }\n    get headingLevel() {\n        return this.viewInstance.headingLevel;\n    }\n\n    constructor(\n        private mdsService: MdsService,\n        private mdsViewerService: MdsViewerService,\n        private factoryResolver: ComponentFactoryResolver,\n        private injector: Injector,\n        private containerRef: ViewContainerRef,\n        private sanitizer: DomSanitizer,\n        private viewInstance: ViewInstanceService,\n    ) {}\n\n    getGroup() {\n        return this.mds.groups.find((g: any) => g.id == this.groupId);\n    }\n    getView(id: string) {\n        return this.mds.views.find((v: any) => v.id == id);\n    }\n\n    public async inflate() {\n        if (!this.mds) {\n            setTimeout(() => this.inflate(), 1000 / 60);\n            return;\n        }\n        try {\n            this.mdsViewerService.values$.next(this.data);\n            this.mdsViewerService.mds$.next(this.mds);\n            if(this.mdsEditorInstanceService) {\n                const editor = await this.mdsEditorInstanceService.initWithoutNodes(\n                    this.groupId,\n                    this.setId,\n                    HOME_REPOSITORY,\n                    'viewer',\n                    this.data,\n                );\n                if (!editor) {\n                    // Initialization was interrupted. Probably, this method was called again before it\n                    // could finish.\n                    return;\n                }\n            }\n        } catch (e) {\n            return;\n        }\n        this.templates = [];\n        for (const view of this.getGroup().views) {\n            const v = this.getView(view);\n            this.templates.push({\n                view: v,\n                html: this.sanitizer.bypassSecurityTrustHtml(this.prepareHTML(v.html)),\n            });\n        }\n        // wait for angular to inflate the new binding\n        setTimeout(() => {\n            for (const widget of (this.mdsEditorInstanceService?.widgets.value.map((w: any) => w.definition) || this.mds.widgets) as MdsWidget[]) {\n                // @TODO: it would be better to filter by widgets based on template and condition, should be implemented in 5.1\n                this.container.toArray().forEach((c) => {\n                    let element: HTMLElement = c.nativeElement.getElementsByTagName(\n                        widget.id,\n                    )?.[0];\n                    if (element) {\n                        // MdsEditorViewComponent.updateWidgetWithHTMLAttributes(element, w);\n                        element = replaceElementWithDiv(element);\n\n                        UIService.injectAngularComponent(\n                            this.factoryResolver,\n                            this.containerRef,\n                            MdsWidgetComponent,\n                            element,\n                            {\n                                widget,\n                            },\n                            {},\n                            this.injector,\n                        );\n                    }\n                });\n            }\n        });\n    }\n\n    /**\n     * close all custom tags inside the html which are not closed\n     * e.g. <cm:name>\n     *     -> <cm:name></cm:name>\n     * @param html\n     */\n    private prepareHTML(html: string) {\n        for (const w of this.mds.widgets) {\n            const start = html.indexOf('<' + w.id);\n            if (start == -1) {\n                continue;\n            }\n            const end = html.indexOf('>', start) + 1;\n            html = html.substring(0, end) + '</' + w.id + '>' + html.substring(end);\n        }\n        return html;\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {\n        let inflate = false;\n        if (changes.setId) {\n            this.mds = await this.mdsService\n                .getMetadataSet({ metadataSet: this.setId })\n                .toPromise();\n            inflate = true;\n        }\n        if (changes.data) {\n            if (this.data[RestConstants.CM_PROP_METADATASET_EDU_METADATASET] != null) {\n                this.mds = await this.mdsService\n                    .getMetadataSet({\n                        metadataSet:\n                            this.data[RestConstants.CM_PROP_METADATASET_EDU_METADATASET][0],\n                    })\n                    .toPromise();\n            } else if (!this.mds) {\n                this.mds = await this.mdsService.getMetadataSet({}).toPromise();\n            }\n            inflate = true;\n        }\n        if (inflate) {\n            void this.inflate();\n        }\n    }\n}\n","<div *ngFor=\"let t of templates\" #container class=\"mds-viewer\">\n  <div *ngIf=\"showGroupHeadings && t.view.caption\" class=\"card-title-element group-heading\">\n    <i [esIcon]=\"t.view.icon\" *ngIf=\"t.view.icon\"></i><span>{{ t.view.caption }}</span>\n  </div>\n  <div class=\"template\" [innerHTML]=\"t.html\"></div>\n</div>\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mds-viewer.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/mds-viewer/mds-viewer.component.ts","../../../../../projects/edu-sharing-ui/src/lib/mds-viewer/mds-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentFactoryResolver,\n    ElementRef,\n    Injector,\n    Input,\n    OnChanges,\n    QueryList,\n    SimpleChanges,\n    ViewChildren,\n    ViewContainerRef,\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { MdsWidgetComponent } from './widget/mds-widget.component';\nimport {\n    HOME_REPOSITORY,\n    MdsDefinition,\n    MdsService,\n    MdsView, MdsWidget,\n    RestConstants,\n} from 'ngx-edu-sharing-api';\nimport { Values } from '../services/search-helper.service';\nimport { replaceElementWithDiv } from './replace-element-with-div';\nimport { UIService } from '../services/ui.service';\nimport { MdsViewerService } from './mds-viewer.service';\nimport { ViewInstanceService } from './view-instance.service';\n\n@Component({\n    selector: 'es-mds-viewer',\n    templateUrl: 'mds-viewer.component.html',\n    styleUrls: ['mds-viewer.component.scss'],\n    providers: [MdsViewerService, ViewInstanceService],\n})\nexport class MdsViewerComponent implements OnChanges {\n    @ViewChildren('container') container: QueryList<ElementRef>;\n\n    @Input() mdsEditorInstanceService: any;\n    @Input() groupId: string;\n    @Input() setId: string;\n    @Input() data: Values;\n    mds: MdsDefinition;\n    templates: {\n        view: MdsView;\n        html: SafeHtml;\n    }[];\n\n    /**\n     * show group headings (+ icons) for the individual templates\n     */\n    @Input() showGroupHeadings = true;\n\n    /**\n     * The heading level from 1 to 6 to use for widget labels, equivalent to `h1` to `h6`.\n     *\n     * If not set, widget labels are not marked as headings and an invisible colon is added between\n     * labels and values, that will be read out by screen readers.\n     */\n    @Input()\n    set headingLevel(value: number | null) {\n        this.viewInstance.headingLevel = value;\n    }\n    get headingLevel() {\n        return this.viewInstance.headingLevel;\n    }\n\n    constructor(\n        private mdsService: MdsService,\n        private mdsViewerService: MdsViewerService,\n        private factoryResolver: ComponentFactoryResolver,\n        private injector: Injector,\n        private containerRef: ViewContainerRef,\n        private sanitizer: DomSanitizer,\n        private viewInstance: ViewInstanceService,\n    ) {}\n\n    getGroup() {\n        return this.mds.groups.find((g: any) => g.id == this.groupId);\n    }\n    getView(id: string) {\n        return this.mds.views.find((v: any) => v.id == id);\n    }\n\n    public async inflate() {\n        if (!this.mds) {\n            setTimeout(() => this.inflate(), 1000 / 60);\n            return;\n        }\n        try {\n            this.mdsViewerService.values$.next(this.data);\n            this.mdsViewerService.mds$.next(this.mds);\n            if(this.mdsEditorInstanceService) {\n                const editor = await this.mdsEditorInstanceService.initWithoutNodes(\n                    this.groupId,\n                    this.setId,\n                    HOME_REPOSITORY,\n                    'viewer',\n                    this.data,\n                );\n                if (!editor) {\n                    // Initialization was interrupted. Probably, this method was called again before it\n                    // could finish.\n                    return;\n                }\n            }\n        } catch (e) {\n            return;\n        }\n        this.templates = [];\n        for (const view of this.getGroup().views) {\n            const v = this.getView(view);\n            this.templates.push({\n                view: v,\n                html: this.sanitizer.bypassSecurityTrustHtml(this.prepareHTML(v.html)),\n            });\n        }\n        // wait for angular to inflate the new binding\n        setTimeout(() => {\n            for (const widget of (\n                this.mdsEditorInstanceService?.widgets.value ||\n                this.mds.widgets.map(definition => { return {definition}})\n            ) as {definition: MdsWidget}[]) {\n                // @TODO: it would be better to filter by widgets based on template and condition, should be implemented in 5.1\n                this.container.toArray().forEach((c) => {\n                    let element: HTMLElement = c.nativeElement.getElementsByTagName(\n                        widget.definition.id,\n                    )?.[0];\n                    if (element) {\n                        // MdsEditorViewComponent.updateWidgetWithHTMLAttributes(element, w);\n                        element = replaceElementWithDiv(element);\n\n                        UIService.injectAngularComponent(\n                            this.factoryResolver,\n                            this.containerRef,\n                            MdsWidgetComponent,\n                            element,\n                            {\n                                widget,\n                            },\n                            {},\n                            this.injector,\n                        );\n                    }\n                });\n            }\n        });\n    }\n\n    /**\n     * close all custom tags inside the html which are not closed\n     * e.g. <cm:name>\n     *     -> <cm:name></cm:name>\n     * @param html\n     */\n    private prepareHTML(html: string) {\n        for (const w of this.mds.widgets) {\n            const start = html.indexOf('<' + w.id);\n            if (start == -1) {\n                continue;\n            }\n            const end = html.indexOf('>', start) + 1;\n            html = html.substring(0, end) + '</' + w.id + '>' + html.substring(end);\n        }\n        return html;\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {\n        let inflate = false;\n        if (changes.setId) {\n            this.mds = await this.mdsService\n                .getMetadataSet({ metadataSet: this.setId })\n                .toPromise();\n            inflate = true;\n        }\n        if (changes.data) {\n            if (this.data[RestConstants.CM_PROP_METADATASET_EDU_METADATASET] != null) {\n                this.mds = await this.mdsService\n                    .getMetadataSet({\n                        metadataSet:\n                            this.data[RestConstants.CM_PROP_METADATASET_EDU_METADATASET][0],\n                    })\n                    .toPromise();\n            } else if (!this.mds) {\n                this.mds = await this.mdsService.getMetadataSet({}).toPromise();\n            }\n            inflate = true;\n        }\n        if (inflate) {\n            void this.inflate();\n        }\n    }\n}\n","<div *ngFor=\"let t of templates\" #container class=\"mds-viewer\">\n  <div *ngIf=\"showGroupHeadings && t.view.caption\" class=\"card-title-element group-heading\">\n    <i [esIcon]=\"t.view.icon\" *ngIf=\"t.view.icon\"></i><span>{{ t.view.caption }}</span>\n  </div>\n  <div class=\"template\" [innerHTML]=\"t.html\"></div>\n</div>\n"]}
@@ -1666,10 +1666,11 @@ class MdsViewerComponent {
1666
1666
  }
1667
1667
  // wait for angular to inflate the new binding
1668
1668
  setTimeout(() => {
1669
- for (const widget of (this.mdsEditorInstanceService?.widgets.value.map((w) => w.definition) || this.mds.widgets)) {
1669
+ for (const widget of (this.mdsEditorInstanceService?.widgets.value ||
1670
+ this.mds.widgets.map(definition => { return { definition }; }))) {
1670
1671
  // @TODO: it would be better to filter by widgets based on template and condition, should be implemented in 5.1
1671
1672
  this.container.toArray().forEach((c) => {
1672
- let element = c.nativeElement.getElementsByTagName(widget.id)?.[0];
1673
+ let element = c.nativeElement.getElementsByTagName(widget.definition.id)?.[0];
1673
1674
  if (element) {
1674
1675
  // MdsEditorViewComponent.updateWidgetWithHTMLAttributes(element, w);
1675
1676
  element = replaceElementWithDiv(element);