@pepperi-addons/ngx-lib 0.4.0-angular14.7 → 0.4.0-beta.1
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/chips/chips.component.d.ts +93 -0
- package/chips/chips.component.theme.scss +58 -0
- package/chips/chips.model.d.ts +13 -0
- package/chips/chips.module.d.ts +20 -0
- package/chips/chips.service.d.ts +15 -0
- package/chips/index.d.ts +5 -0
- package/chips/public-api.d.ts +3 -0
- package/color/color-picker.component.d.ts +1 -1
- package/core/common/model/wapi.model.d.ts +1 -0
- package/core/common/services/addon.service.d.ts +13 -9
- package/core/common/services/utilities.service.d.ts +5 -4
- package/core/customization/customization.model.d.ts +7 -0
- package/esm2020/address/address.component.mjs +1 -1
- package/esm2020/attachment/attachment.component.mjs +1 -1
- package/esm2020/checkbox/checkbox.component.mjs +1 -1
- package/esm2020/chips/chips.component.mjs +158 -0
- package/esm2020/chips/chips.model.mjs +2 -0
- package/esm2020/chips/chips.module.mjs +81 -0
- package/esm2020/chips/chips.service.mjs +44 -0
- package/esm2020/chips/pepperi-addons-ngx-lib-chips.mjs +5 -0
- package/esm2020/chips/public-api.mjs +7 -0
- package/esm2020/color/color-picker.component.mjs +4 -4
- package/esm2020/color/color.component.mjs +1 -1
- package/esm2020/core/common/model/wapi.model.mjs +1 -1
- package/esm2020/core/common/services/addon.service.mjs +42 -38
- package/esm2020/core/common/services/utilities.service.mjs +66 -13
- package/esm2020/core/customization/customization.model.mjs +10 -1
- package/esm2020/core/http/interceptors/loader.interceptor.mjs +4 -5
- package/esm2020/core/http/services/loader.service.mjs +4 -4
- package/esm2020/date/date.component.mjs +3 -3
- package/esm2020/field-title/field-title.component.mjs +6 -3
- package/esm2020/form/field-generator.component.mjs +7 -7
- package/esm2020/form/form.component.mjs +12 -3
- package/esm2020/form/form.module.mjs +8 -3
- package/esm2020/form/internal-button.component.mjs +1 -1
- package/esm2020/form/internal-carusel.component.mjs +11 -13
- package/esm2020/form/internal-field-generator.component.mjs +3 -3
- package/esm2020/form/internal-form.component.mjs +4 -2
- package/esm2020/form/internal-list.component.mjs +5 -2
- package/esm2020/form/internal-page.component.mjs +15 -18
- package/esm2020/group-buttons/group-buttons.component.mjs +8 -4
- package/esm2020/icon/icon-generated-all.model.mjs +8 -1
- package/esm2020/icon/icon-generated.model.mjs +29 -1
- package/esm2020/image/image.component.mjs +1 -1
- package/esm2020/images-filmstrip/images-filmstrip.component.mjs +3 -91
- package/esm2020/images-filmstrip/images-filmstrip.module.mjs +1 -56
- package/esm2020/link/link.component.mjs +10 -11
- package/esm2020/list/list-pager.component.mjs +1 -1
- package/esm2020/list/list.component.mjs +5 -2
- package/esm2020/list/virtual-scroller.mjs +11 -10
- package/esm2020/menu/menu.component.mjs +11 -3
- package/esm2020/ngx-lib.module.mjs +4 -2
- package/esm2020/page-layout/page-layout.component.mjs +3 -3
- package/esm2020/profile-data-views-list/profile-data-views-list.component.mjs +1 -1
- package/esm2020/quantity-selector/quantity-selector.component.mjs +24 -4
- package/esm2020/query-builder/common/services/query-structure.service.mjs +12 -10
- package/esm2020/query-builder/query-builder-item/query-builder-item.component.mjs +1 -1
- package/esm2020/query-builder/query-builder-section/query-builder-section.component.mjs +1 -1
- package/esm2020/query-builder/query-builder.module.mjs +8 -3
- package/esm2020/remote-loader/addon-block-loader.component.mjs +23 -5
- package/esm2020/remote-loader/addon-block-loader.service.mjs +9 -8
- package/esm2020/remote-loader/public-api.mjs +2 -1
- package/esm2020/remote-loader/remote-loader-element.component.mjs +109 -0
- package/esm2020/remote-loader/remote-loader.component.mjs +40 -62
- package/esm2020/remote-loader/remote-loader.model.mjs +1 -1
- package/esm2020/remote-loader/remote-loader.module.mjs +12 -3
- package/esm2020/remote-loader/remote-loader.service.mjs +50 -26
- package/esm2020/rich-html-textarea/rich-html-textarea.component.mjs +1 -1
- package/esm2020/select/select.component.mjs +33 -7
- package/esm2020/side-bar/side-bar.component.mjs +11 -27
- package/esm2020/side-bar/side-bar.module.mjs +7 -3
- package/esm2020/signature/signature.component.mjs +1 -1
- package/esm2020/size-detector/size-detector.component.mjs +2 -2
- package/esm2020/slider/slider.component.mjs +1 -1
- package/esm2020/smart-filters/boolean-filter/boolean-filter.component.mjs +1 -1
- package/esm2020/smart-filters/common/model/base-filter-component.mjs +1 -1
- package/esm2020/smart-filters/date-filter/date-filter.component.mjs +1 -1
- package/esm2020/smart-filters/multi-select-filter/multi-select-filter.component.mjs +1 -1
- package/esm2020/smart-filters/number-filter/number-filter.component.mjs +3 -3
- package/esm2020/smart-filters/smart-filters.module.mjs +8 -3
- package/esm2020/smart-filters/text-filter/text-filter.component.mjs +1 -1
- package/esm2020/textarea/textarea.component.mjs +1 -1
- package/esm2020/textbox/textbox.component.mjs +55 -15
- package/esm2020/textbox-icon/textbox-icon.component.mjs +2 -2
- package/fesm2015/pepperi-addons-ngx-lib-address.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-address.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-attachment.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-attachment.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-checkbox.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-checkbox.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-chips.mjs +287 -0
- package/fesm2015/pepperi-addons-ngx-lib-chips.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-lib-color.mjs +4 -4
- package/fesm2015/pepperi-addons-ngx-lib-color.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-date.mjs +2 -2
- package/fesm2015/pepperi-addons-ngx-lib-date.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-field-title.mjs +5 -2
- package/fesm2015/pepperi-addons-ngx-lib-field-title.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-form.mjs +53 -40
- package/fesm2015/pepperi-addons-ngx-lib-form.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-group-buttons.mjs +7 -3
- package/fesm2015/pepperi-addons-ngx-lib-group-buttons.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-icon.mjs +36 -1
- package/fesm2015/pepperi-addons-ngx-lib-icon.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-image.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-image.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-images-filmstrip.mjs +2 -129
- package/fesm2015/pepperi-addons-ngx-lib-images-filmstrip.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-link.mjs +8 -9
- package/fesm2015/pepperi-addons-ngx-lib-link.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-list.mjs +15 -11
- package/fesm2015/pepperi-addons-ngx-lib-list.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-menu.mjs +10 -2
- package/fesm2015/pepperi-addons-ngx-lib-menu.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-page-layout.mjs +2 -2
- package/fesm2015/pepperi-addons-ngx-lib-page-layout.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-profile-data-views-list.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-profile-data-views-list.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-quantity-selector.mjs +23 -3
- package/fesm2015/pepperi-addons-ngx-lib-quantity-selector.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-query-builder.mjs +17 -10
- package/fesm2015/pepperi-addons-ngx-lib-query-builder.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-remote-loader.mjs +252 -108
- package/fesm2015/pepperi-addons-ngx-lib-remote-loader.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-rich-html-textarea.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-rich-html-textarea.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-select.mjs +32 -6
- package/fesm2015/pepperi-addons-ngx-lib-select.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-side-bar.mjs +15 -27
- package/fesm2015/pepperi-addons-ngx-lib-side-bar.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-signature.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-signature.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-size-detector.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-size-detector.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-slider.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-slider.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-smart-filters.mjs +13 -8
- package/fesm2015/pepperi-addons-ngx-lib-smart-filters.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-textarea.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-textarea.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-textbox-icon.mjs +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-textbox-icon.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib-textbox.mjs +58 -18
- package/fesm2015/pepperi-addons-ngx-lib-textbox.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-lib.mjs +130 -58
- package/fesm2015/pepperi-addons-ngx-lib.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-address.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-address.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-attachment.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-attachment.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-checkbox.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-checkbox.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-chips.mjs +287 -0
- package/fesm2020/pepperi-addons-ngx-lib-chips.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-lib-color.mjs +4 -4
- package/fesm2020/pepperi-addons-ngx-lib-color.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-date.mjs +2 -2
- package/fesm2020/pepperi-addons-ngx-lib-date.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-field-title.mjs +5 -2
- package/fesm2020/pepperi-addons-ngx-lib-field-title.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-form.mjs +56 -40
- package/fesm2020/pepperi-addons-ngx-lib-form.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-group-buttons.mjs +7 -3
- package/fesm2020/pepperi-addons-ngx-lib-group-buttons.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-icon.mjs +36 -1
- package/fesm2020/pepperi-addons-ngx-lib-icon.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-image.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-image.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-images-filmstrip.mjs +2 -129
- package/fesm2020/pepperi-addons-ngx-lib-images-filmstrip.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-link.mjs +8 -9
- package/fesm2020/pepperi-addons-ngx-lib-link.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-list.mjs +15 -11
- package/fesm2020/pepperi-addons-ngx-lib-list.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-menu.mjs +10 -2
- package/fesm2020/pepperi-addons-ngx-lib-menu.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-page-layout.mjs +2 -2
- package/fesm2020/pepperi-addons-ngx-lib-page-layout.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-profile-data-views-list.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-profile-data-views-list.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-quantity-selector.mjs +23 -3
- package/fesm2020/pepperi-addons-ngx-lib-quantity-selector.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-query-builder.mjs +17 -10
- package/fesm2020/pepperi-addons-ngx-lib-query-builder.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-remote-loader.mjs +233 -101
- package/fesm2020/pepperi-addons-ngx-lib-remote-loader.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-rich-html-textarea.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-rich-html-textarea.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-select.mjs +32 -6
- package/fesm2020/pepperi-addons-ngx-lib-select.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-side-bar.mjs +15 -27
- package/fesm2020/pepperi-addons-ngx-lib-side-bar.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-signature.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-signature.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-size-detector.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-size-detector.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-slider.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-slider.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-smart-filters.mjs +13 -8
- package/fesm2020/pepperi-addons-ngx-lib-smart-filters.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-textarea.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-textarea.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-textbox-icon.mjs +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-textbox-icon.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib-textbox.mjs +57 -18
- package/fesm2020/pepperi-addons-ngx-lib-textbox.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-lib.mjs +127 -59
- package/fesm2020/pepperi-addons-ngx-lib.mjs.map +1 -1
- package/field-title/field-title.component.d.ts +2 -1
- package/form/field-generator.component.d.ts +1 -1
- package/form/internal-carusel.component.d.ts +1 -3
- package/form/internal-page.component.d.ts +2 -4
- package/group-buttons/group-buttons.component.d.ts +2 -1
- package/icon/icon-generated-all.model.d.ts +7 -0
- package/icon/icon-generated.model.d.ts +29 -1
- package/link/link.component.d.ts +2 -3
- package/menu/menu.component.d.ts +2 -0
- package/package.json +10 -1
- package/page-layout/page-layout.component.d.ts +1 -1
- package/quantity-selector/quantity-selector.component.d.ts +7 -1
- package/query-builder/common/services/query-structure.service.d.ts +3 -4
- package/remote-loader/addon-block-loader.component.d.ts +10 -6
- package/remote-loader/addon-block-loader.service.d.ts +2 -3
- package/remote-loader/public-api.d.ts +1 -0
- package/remote-loader/remote-loader-element.component.d.ts +30 -0
- package/remote-loader/remote-loader.component.d.ts +3 -5
- package/remote-loader/remote-loader.model.d.ts +16 -11
- package/remote-loader/remote-loader.module.d.ts +8 -6
- package/remote-loader/remote-loader.service.d.ts +5 -7
- package/select/select.component.d.ts +10 -4
- package/side-bar/side-bar.component.d.ts +3 -3
- package/src/assets/i18n/en.ngx-lib.json +4 -0
- package/src/core/style/components/checkbox.scss +20 -1
- package/src/core/style/components/general.scss +5 -4
- package/textbox/textbox.component.d.ts +18 -4
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Optional, Output } from '@angular/core';
|
|
2
|
+
import { loadRemoteModule } from '@angular-architects/module-federation';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@pepperi-addons/ngx-lib";
|
|
5
|
+
import * as i2 from "./remote-loader.service";
|
|
6
|
+
import * as i3 from "@angular/router";
|
|
7
|
+
export class PepRemoteLoaderElementComponent {
|
|
8
|
+
constructor(renderer, el, pepAddonService, remoteLoaderService, route) {
|
|
9
|
+
this.renderer = renderer;
|
|
10
|
+
this.el = el;
|
|
11
|
+
this.pepAddonService = pepAddonService;
|
|
12
|
+
this.remoteLoaderService = remoteLoaderService;
|
|
13
|
+
this.route = route;
|
|
14
|
+
this.load = new EventEmitter();
|
|
15
|
+
this.element = null;
|
|
16
|
+
}
|
|
17
|
+
ngOnChanges() {
|
|
18
|
+
if (!this.element)
|
|
19
|
+
return;
|
|
20
|
+
this.populateProps();
|
|
21
|
+
}
|
|
22
|
+
populateProps() {
|
|
23
|
+
for (const prop in this.props) {
|
|
24
|
+
this.element[prop] = this.props[prop];
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
setupEvents() {
|
|
28
|
+
for (const event in this.events) {
|
|
29
|
+
this.element.addEventListener(event, this.events[event]);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async loadOptionsFromRoute() {
|
|
33
|
+
const params = this.route?.snapshot.params;
|
|
34
|
+
const data = this.route?.snapshot.data;
|
|
35
|
+
const blockType = data?.blockType || 'SettingsBlock';
|
|
36
|
+
const slugName = params?.slugName || data?.slugName;
|
|
37
|
+
const blockName = params?.blockName || data?.blockName;
|
|
38
|
+
if (blockName?.length > 0 || (slugName?.length > 0 && blockType === 'SettingsBlock')) {
|
|
39
|
+
const addonUUID = params?.addonUUID || data?.addonUUID || '';
|
|
40
|
+
const blockRemoteEntry = data?.blockRemoteEntry || '';
|
|
41
|
+
this.options = await this.remoteLoaderService.getBlockRemoteLoaderOptions({
|
|
42
|
+
name: blockName,
|
|
43
|
+
slugName,
|
|
44
|
+
blockType,
|
|
45
|
+
addonUUID,
|
|
46
|
+
blockRemoteEntry
|
|
47
|
+
});
|
|
48
|
+
const fileName = `${this.options['remoteName']}.js`;
|
|
49
|
+
if (window.location.search.indexOf('dev=true') > 0) {
|
|
50
|
+
this.options['remoteEntry'] = `http://localhost:4400/${fileName}`;
|
|
51
|
+
}
|
|
52
|
+
// Set the data into the props cause this component is loading from the route.
|
|
53
|
+
this.props = data;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
async ngAfterContentInit() {
|
|
57
|
+
try {
|
|
58
|
+
const t0 = performance.now();
|
|
59
|
+
// If the options is not supplied then we need to get it from the route.
|
|
60
|
+
if (!this.options) {
|
|
61
|
+
await this.loadOptionsFromRoute();
|
|
62
|
+
}
|
|
63
|
+
if (!this.options) {
|
|
64
|
+
throw new Error('No options supplied to the component.');
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
if (this.options?.addonId && (this.options.type === 'module' || this.options.type === 'script')) {
|
|
68
|
+
const lastSlashIndex = this.options.remoteEntry?.lastIndexOf('/') || -1;
|
|
69
|
+
if (lastSlashIndex > 0) {
|
|
70
|
+
const publicPath = this.options.remoteEntry.substring(0, lastSlashIndex + 1);
|
|
71
|
+
this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
await loadRemoteModule(this.options);
|
|
75
|
+
this.element = this.renderer.createElement(this.options.elementName);
|
|
76
|
+
this.populateProps();
|
|
77
|
+
this.setupEvents();
|
|
78
|
+
this.renderer.appendChild(this.el.nativeElement, this.element);
|
|
79
|
+
const t1 = performance.now();
|
|
80
|
+
console.log('remote module wc load performance: ' + (t1 - t0) / 1000);
|
|
81
|
+
this.load.emit();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
catch (error) {
|
|
85
|
+
console.error(error);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
PepRemoteLoaderElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderElementComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.PepAddonService }, { token: i2.PepRemoteLoaderService }, { token: i3.ActivatedRoute, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
+
PepRemoteLoaderElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: PepRemoteLoaderElementComponent, selector: "pep-remote-loader-element", inputs: { options: "options", props: "props", events: "events" }, outputs: { load: "load" }, usesOnChanges: true, ngImport: i0, template: `
|
|
91
|
+
<!--<div #vc style="height: inherit;"></div>-->
|
|
92
|
+
`, isInline: true, styles: [":host{width:100%;height:inherit}:host::ng-deep>*{height:inherit}\n"] });
|
|
93
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderElementComponent, decorators: [{
|
|
94
|
+
type: Component,
|
|
95
|
+
args: [{ selector: 'pep-remote-loader-element', template: `
|
|
96
|
+
<!--<div #vc style="height: inherit;"></div>-->
|
|
97
|
+
`, styles: [":host{width:100%;height:inherit}:host::ng-deep>*{height:inherit}\n"] }]
|
|
98
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.PepAddonService }, { type: i2.PepRemoteLoaderService }, { type: i3.ActivatedRoute, decorators: [{
|
|
99
|
+
type: Optional
|
|
100
|
+
}] }]; }, propDecorators: { options: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], props: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], events: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], load: [{
|
|
107
|
+
type: Output
|
|
108
|
+
}] } });
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"remote-loader-element.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/remote-loader/remote-loader-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ElementRef, EventEmitter, Input, OnChanges, Optional, Output, Renderer2, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { loadRemoteModule } from '@angular-architects/module-federation';\nimport { PepAddonService } from '@pepperi-addons/ngx-lib';\nimport { PepRemoteLoaderOptions } from './remote-loader.model';\nimport { PepRemoteLoaderService } from './remote-loader.service';\n\n@Component({\n    selector: 'pep-remote-loader-element',\n    template: `\n        <!--<div #vc style=\"height: inherit;\"></div>-->\n    `,\n    styles: [`\n        :host { width:100%; height: inherit }\n        :host::ng-deep > * {\n            height: inherit;\n        }\n    `],\n})\nexport class PepRemoteLoaderElementComponent implements AfterContentInit, OnChanges {\n    @Input() options: PepRemoteLoaderOptions;\n    @Input() props: { [prop: string]: unknown };\n    @Input() events: { [event: string]: (event: Event) => void };\n\n    @Output() load: EventEmitter<any> =  new EventEmitter();\n\n    element: HTMLElement = null;\n\n    constructor(\n        private renderer: Renderer2,\n        private el:ElementRef,\n        private pepAddonService: PepAddonService,\n        private remoteLoaderService: PepRemoteLoaderService,\n        @Optional() private route: ActivatedRoute\n    ) { \n\n    }\n\n    ngOnChanges(): void {\n        if (!this.element) return;\n\n        this.populateProps();\n    }\n\n    private populateProps() {\n        for (const prop in this.props) {\n            this.element[prop] = this.props[prop];\n        }\n    }\n\n    private setupEvents() {\n        for (const event in this.events) {\n            this.element.addEventListener(event, this.events[event]);\n        }\n    }\n\n    private async loadOptionsFromRoute() {\n        const params = this.route?.snapshot.params;\n        const data = this.route?.snapshot.data;\n        const blockType = data?.blockType || 'SettingsBlock';\n\n        const slugName = params?.slugName || data?.slugName;\n        const blockName = params?.blockName || data?.blockName;\n        \n        if (blockName?.length > 0 || (slugName?.length > 0 && blockType === 'SettingsBlock')) {\n            const addonUUID = params?.addonUUID || data?.addonUUID || '';\n            const blockRemoteEntry = data?.blockRemoteEntry || '';\n\n            this.options = await this.remoteLoaderService.getBlockRemoteLoaderOptions({\n                name: blockName,\n                slugName,\n                blockType,\n                addonUUID,\n                blockRemoteEntry\n            });\n\n            const fileName = `${this.options['remoteName']}.js`;\n\n            if (window.location.search.indexOf('dev=true') > 0) {\n                this.options['remoteEntry'] = `http://localhost:4400/${fileName}`;\n            }\n\n            // Set the data into the props cause this component is loading from the route.\n            this.props = data;\n        }\n    }\n\n    async ngAfterContentInit() {\n        try {\n            const t0 = performance.now();\n\n            // If the options is not supplied then we need to get it from the route.\n            if (!this.options) {\n                await this.loadOptionsFromRoute();\n            }\n\n            if (!this.options) {\n                throw new Error('No options supplied to the component.');\n            } else {\n                if (this.options?.addonId && (this.options.type === 'module' || this.options.type === 'script')) {\n                    const lastSlashIndex = this.options.remoteEntry?.lastIndexOf('/') || -1;\n                    \n                    if (lastSlashIndex > 0) {\n                        const publicPath = this.options.remoteEntry.substring(0, lastSlashIndex + 1);\n                        this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);\n                    }\n                }\n    \n                await loadRemoteModule(this.options);\n    \n                this.element = this.renderer.createElement(this.options.elementName);\n                this.populateProps();\n                this.setupEvents();\n    \n                this.renderer.appendChild(this.el.nativeElement, this.element);\n    \n                const t1 = performance.now();\n                console.log('remote module wc load performance: ' + (t1-t0)/1000);\n    \n                this.load.emit();\n            }\n        }\n        catch(error) {\n            console.error(error);\n        }\n    }\n}"]}
|
|
@@ -1,12 +1,10 @@
|
|
|
1
|
-
import { Component, Input, ViewChild, ViewContainerRef, EventEmitter, Output } from '@angular/core';
|
|
1
|
+
import { Component, Input, ViewChild, ViewContainerRef, EventEmitter, Output, createNgModuleRef } from '@angular/core';
|
|
2
2
|
import { loadRemoteModule } from '@angular-architects/module-federation';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@pepperi-addons/ngx-lib";
|
|
5
5
|
export class PepRemoteLoaderComponent {
|
|
6
|
-
constructor(injector,
|
|
6
|
+
constructor(injector, pepAddonService) {
|
|
7
7
|
this.injector = injector;
|
|
8
|
-
this.cfr = cfr;
|
|
9
|
-
this.compiler = compiler;
|
|
10
8
|
this.pepAddonService = pepAddonService;
|
|
11
9
|
this._options = null;
|
|
12
10
|
// This is the data passed by the API Design documentation.
|
|
@@ -34,73 +32,53 @@ export class PepRemoteLoaderComponent {
|
|
|
34
32
|
if (this.hostObject && this.compRef?.instance) {
|
|
35
33
|
this.compRef.instance.hostObject = this.hostObject;
|
|
36
34
|
// TODO: Check if this is needed?? if not remove this.
|
|
37
|
-
if (this.compRef?.instance?.ngOnChanges) {
|
|
38
|
-
|
|
39
|
-
}
|
|
35
|
+
// if (this.compRef?.instance?.ngOnChanges) {
|
|
36
|
+
// this.compRef.instance.ngOnChanges(this.hostObject);
|
|
37
|
+
// }
|
|
40
38
|
}
|
|
41
39
|
}
|
|
42
|
-
|
|
40
|
+
ngOnChanges(changes) {
|
|
43
41
|
// if (changes?.options?.currentValue) {
|
|
44
42
|
// this.loadModule(changes?.options?.currentValue);
|
|
45
43
|
// }
|
|
46
44
|
}
|
|
47
45
|
async loadModule() {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
if (!this.options?.update) {
|
|
46
|
+
try {
|
|
47
|
+
const t0 = performance.now();
|
|
51
48
|
this.viewContainer?.clear();
|
|
52
|
-
//
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
49
|
+
if (this.options.exposedModule?.length > 0) { // Load module
|
|
50
|
+
if (this.options?.addonId && (this.options.type === 'module' || this.options.type === 'script')) {
|
|
51
|
+
const lastSlashIndex = this.options.remoteEntry?.lastIndexOf('/') || -1;
|
|
52
|
+
if (lastSlashIndex > 0) {
|
|
53
|
+
const publicPath = this.options.remoteEntry.substring(0, lastSlashIndex + 1);
|
|
54
|
+
this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
const module = await loadRemoteModule(this.options).then(m => m);
|
|
58
|
+
const moduleRef = createNgModuleRef(module[this.options.exposedModule.replace('./', '')], this.injector);
|
|
59
|
+
this.compRef = this.viewContainer.createComponent(module[this.options.componentName], { injector: this.injector, ngModuleRef: moduleRef });
|
|
60
|
+
const t1 = performance.now();
|
|
61
|
+
console.log('remote module load performance: ' + (t1 - t0) / 1000);
|
|
58
62
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
this.
|
|
62
|
-
//
|
|
63
|
-
// this.viewContainer?.clear();
|
|
64
|
-
// // Load Component
|
|
65
|
-
// if (this.options?.noModule) {
|
|
66
|
-
// const component = await loadRemoteModule(this.options).then(m => m[this.options.componentName]);
|
|
67
|
-
// // New code
|
|
68
|
-
// // this.compRef = this.viewContainer.createComponent(component, { injector: this.injector });
|
|
69
|
-
// // Old code
|
|
70
|
-
// const componentFactory = this.cfr.resolveComponentFactory(component);
|
|
71
|
-
// this.compRef = this.viewContainer.createComponent(componentFactory, null, this.injector);
|
|
72
|
-
// }
|
|
73
|
-
// // Load Module
|
|
74
|
-
// else {
|
|
75
|
-
// // const publicPathArr = this.options.remoteEntry.split('/');
|
|
76
|
-
// // const publicPath = publicPathArr.slice(0, publicPathArr.length - 1).join('/')+'/';
|
|
77
|
-
// // __webpack_public_path__ = publicPath;
|
|
78
|
-
// // this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);
|
|
79
|
-
// const module = await loadRemoteModule(this.options).then(m => m);
|
|
80
|
-
// // New code
|
|
81
|
-
// // const moduleRef = createNgModuleRef(module, this.injector);
|
|
82
|
-
// // const component = module[this.options.componentName];
|
|
83
|
-
// // this.compRef = this.viewContainer.createComponent(component, { injector: this.injector, ngModuleRef: moduleRef });
|
|
84
|
-
// // Old code
|
|
85
|
-
// const moduleFactory: NgModuleFactory<any> = this.compiler.compileModuleSync(module[this.options.exposedModule.replace('./','')]);
|
|
86
|
-
// const moduleRef = moduleFactory.create(this.injector);
|
|
87
|
-
// const componentFactory = moduleRef?.componentFactoryResolver?.resolveComponentFactory(module[this.options.componentName]);
|
|
88
|
-
// this.compRef = this.viewContainer.createComponent(componentFactory, null, this.injector, null, moduleRef);
|
|
89
|
-
// const t1 = performance.now();
|
|
90
|
-
// console.log('remote module load performance: ' + (t1-t0)/1000);
|
|
91
|
-
// }
|
|
63
|
+
// Check if this is in use??? (comment out in Angular 14 version)
|
|
64
|
+
// else { // Load Component
|
|
65
|
+
// const componentType = await loadRemoteModule(this.options).then(m => m[this.options.componentName]);
|
|
66
|
+
// this.compRef = this.viewContainer.createComponent(componentType, { injector: this.injector });
|
|
92
67
|
// }
|
|
93
68
|
this.load.emit();
|
|
69
|
+
if (this.compRef) {
|
|
70
|
+
this.setHostComponentIntoComponentRef();
|
|
71
|
+
this.compRef?.instance['hostEvents']?.subscribe(e => {
|
|
72
|
+
// switch(e.action){
|
|
73
|
+
// case 'addon-loaded':
|
|
74
|
+
// this.showSpinner = false;
|
|
75
|
+
// }
|
|
76
|
+
this.hostEvents.emit(e);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
94
79
|
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
this.compRef?.instance['hostEvents']?.subscribe(e => {
|
|
98
|
-
// switch(e.action){
|
|
99
|
-
// case 'addon-loaded':
|
|
100
|
-
// this.showSpinner = false;
|
|
101
|
-
// }
|
|
102
|
-
this.hostEvents.emit(e);
|
|
103
|
-
});
|
|
80
|
+
catch (error) {
|
|
81
|
+
console.error(error);
|
|
104
82
|
}
|
|
105
83
|
}
|
|
106
84
|
ngOnDestroy() {
|
|
@@ -108,7 +86,7 @@ export class PepRemoteLoaderComponent {
|
|
|
108
86
|
this.viewContainer?.clear();
|
|
109
87
|
}
|
|
110
88
|
}
|
|
111
|
-
PepRemoteLoaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderComponent, deps: [{ token: i0.Injector }, { token:
|
|
89
|
+
PepRemoteLoaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderComponent, deps: [{ token: i0.Injector }, { token: i1.PepAddonService }], target: i0.ɵɵFactoryTarget.Component });
|
|
112
90
|
PepRemoteLoaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: PepRemoteLoaderComponent, selector: "pep-remote-loader", inputs: { options: "options", hostObject: "hostObject" }, outputs: { hostEvents: "hostEvents", load: "load" }, viewQueries: [{ propertyName: "viewContainer", first: true, predicate: ["placeHolder"], descendants: true, read: ViewContainerRef, static: true }], usesOnChanges: true, ngImport: i0, template: `
|
|
113
91
|
<!-- <mat-spinner *ngIf="showSpinner; else placeHolder"></mat-spinner> -->
|
|
114
92
|
<ng-template #placeHolder></ng-template>
|
|
@@ -122,7 +100,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
122
100
|
<ng-template #placeHolder></ng-template>
|
|
123
101
|
`
|
|
124
102
|
}]
|
|
125
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }, { type:
|
|
103
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.PepAddonService }]; }, propDecorators: { viewContainer: [{
|
|
126
104
|
type: ViewChild,
|
|
127
105
|
args: ['placeHolder', { read: ViewContainerRef, static: true }]
|
|
128
106
|
}], options: [{
|
|
@@ -134,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
134
112
|
}], load: [{
|
|
135
113
|
type: Output
|
|
136
114
|
}] } });
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"remote-loader.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/remote-loader/remote-loader.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { PepAddonService } from '@pepperi-addons/ngx-lib';\nimport { Component, Input, OnChanges, ViewChild, ViewContainerRef, ComponentFactoryResolver,\n  Injector, NgModuleFactory, Compiler, EventEmitter, Output, ComponentRef, SimpleChanges, NgZone, createNgModuleRef } from '@angular/core';\nimport { loadRemoteModule } from '@angular-architects/module-federation';\nimport { PepRemoteLoaderOptions } from './remote-loader.model';\ndeclare let __webpack_public_path__;\n\n@Component({\n    selector: 'pep-remote-loader',\n    template: `\n        <!-- <mat-spinner *ngIf=\"showSpinner; else placeHolder\"></mat-spinner> -->\n        <ng-template #placeHolder></ng-template>\n    `\n})\nexport class PepRemoteLoaderComponent implements OnChanges {\n    @ViewChild('placeHolder', { read: ViewContainerRef, static: true }) viewContainer: ViewContainerRef;\n    \n    private _options: PepRemoteLoaderOptions = null;\n    @Input()\n    set options(value: PepRemoteLoaderOptions) {\n        this._options = value;\n        if (value) {\n            this.loadModule();\n        }\n    }\n    get options(): PepRemoteLoaderOptions {\n        return this._options;\n    }\n    \n    // This is the data passed by the API Design documentation.\n    private _hostObject: any = null;\n    @Input()\n    set hostObject(value: any) { \n        this._hostObject = value;\n        this.setHostComponentIntoComponentRef();\n    }\n    get hostObject(): any {\n        return this._hostObject;\n    }\n\n    @Output() hostEvents: EventEmitter<any> =  new EventEmitter();\n    @Output() load: EventEmitter<any> =  new EventEmitter();\n    // showSpinner = true;\n    \n    private compRef: ComponentRef<any>;\n\n    constructor(\n        private injector: Injector,\n        private cfr: ComponentFactoryResolver,\n        private compiler: Compiler,\n        private pepAddonService: PepAddonService,\n        // private zone: NgZone,\n    ) { }\n\n    private setHostComponentIntoComponentRef() {\n        if (this.hostObject && this.compRef?.instance) {\n            this.compRef.instance.hostObject = this.hostObject;\n\n            // TODO: Check if this is needed?? if not remove this.\n            if (this.compRef?.instance?.ngOnChanges) {\n                this.compRef.instance.ngOnChanges(this.hostObject);\n            }\n        }\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {\n        // if (changes?.options?.currentValue) {\n        //     this.loadModule(changes?.options?.currentValue);\n        // }\n    }\n\n    private async loadModule() {\n        const t0 = performance.now();\n        \n        // Check if only need update\n        if (!this.options?.update) {\n            this.viewContainer?.clear();\n            \n            // try {\n                if (this.options.addonId) {\n                    const publicPathArr = this.options.remoteEntry.split('/');\n                    const publicPath = publicPathArr.slice(0, publicPathArr.length - 1).join('/')+'/';\n                    __webpack_public_path__ = publicPath;\n                    this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);\n                }\n                \n                const module =  await loadRemoteModule(this.options).then(m => m);\n                const component = module[this.options.componentName];\n                this.compRef = this.viewContainer.createComponent(component);\n\n            // } catch (e) {\n                \n            //     this.viewContainer?.clear();\n            //     // Load Component\n            //     if (this.options?.noModule) {\n            //         const component = await loadRemoteModule(this.options).then(m => m[this.options.componentName]);\n                    \n            //         // New code\n            //         // this.compRef = this.viewContainer.createComponent(component, { injector: this.injector });\n    \n            //         // Old code\n            //         const componentFactory = this.cfr.resolveComponentFactory(component);\n            //         this.compRef = this.viewContainer.createComponent(componentFactory, null, this.injector);\n            //     }\n            //     // Load Module\n            //     else {\n            //         // const publicPathArr = this.options.remoteEntry.split('/');\n            //         // const publicPath = publicPathArr.slice(0, publicPathArr.length - 1).join('/')+'/';\n            //         // __webpack_public_path__ = publicPath;\n            //         // this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);\n    \n            //         const module =  await loadRemoteModule(this.options).then(m => m);\n                    \n            //         // New code\n            //         // const moduleRef = createNgModuleRef(module, this.injector);\n            //         // const component = module[this.options.componentName];\n            //         // this.compRef = this.viewContainer.createComponent(component, { injector: this.injector, ngModuleRef: moduleRef });\n                    \n            //         // Old code\n            //         const moduleFactory: NgModuleFactory<any> = this.compiler.compileModuleSync(module[this.options.exposedModule.replace('./','')]);\n            //         const moduleRef = moduleFactory.create(this.injector);\n                    \n            //         const componentFactory = moduleRef?.componentFactoryResolver?.resolveComponentFactory(module[this.options.componentName]);\n            //         this.compRef = this.viewContainer.createComponent(componentFactory, null, this.injector, null, moduleRef);\n    \n            //         const t1 = performance.now();\n            //         console.log('remote module load performance: ' + (t1-t0)/1000);\n            //     }\n\n            // }\n\n            \n            this.load.emit();\n        }\n\n        if (this.compRef) {\n            this.setHostComponentIntoComponentRef();\n            \n            this.compRef?.instance['hostEvents']?.subscribe(e => {\n                // switch(e.action){\n                //     case 'addon-loaded':\n                //         this.showSpinner = false;\n                // }\n                this.hostEvents.emit(e)\n            });\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.compRef?.destroy();\n        this.viewContainer?.clear();\n    }\n}\n\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"remote-loader.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/remote-loader/remote-loader.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, ViewChild, ViewContainerRef, Injector, EventEmitter, Output, ComponentRef, SimpleChanges, createNgModuleRef } from '@angular/core';\nimport { loadRemoteModule } from '@angular-architects/module-federation';\nimport { PepAddonService } from '@pepperi-addons/ngx-lib';\nimport { PepRemoteLoaderOptions } from './remote-loader.model';\n\n@Component({\n    selector: 'pep-remote-loader',\n    template: `\n        <!-- <mat-spinner *ngIf=\"showSpinner; else placeHolder\"></mat-spinner> -->\n        <ng-template #placeHolder></ng-template>\n    `\n})\nexport class PepRemoteLoaderComponent implements OnChanges {\n    @ViewChild('placeHolder', { read: ViewContainerRef, static: true }) viewContainer: ViewContainerRef;\n    \n    private _options: PepRemoteLoaderOptions = null;\n    @Input()\n    set options(value: PepRemoteLoaderOptions) {\n        this._options = value;\n        if (value) {\n            this.loadModule();\n        }\n    }\n    get options(): PepRemoteLoaderOptions {\n        return this._options;\n    }\n    \n    // This is the data passed by the API Design documentation.\n    private _hostObject: any = null;\n    @Input()\n    set hostObject(value: any) { \n        this._hostObject = value;\n        this.setHostComponentIntoComponentRef();\n    }\n    get hostObject(): any {\n        return this._hostObject;\n    }\n\n    @Output() hostEvents: EventEmitter<any> =  new EventEmitter();\n    @Output() load: EventEmitter<any> =  new EventEmitter();\n    // showSpinner = true;\n    \n    private compRef: ComponentRef<any>;\n\n    constructor(\n        private injector: Injector,\n        private pepAddonService: PepAddonService\n    ) { }\n\n    private setHostComponentIntoComponentRef() {\n        if (this.hostObject && this.compRef?.instance) {\n            this.compRef.instance.hostObject = this.hostObject;\n\n            // TODO: Check if this is needed?? if not remove this.\n            // if (this.compRef?.instance?.ngOnChanges) {\n            //     this.compRef.instance.ngOnChanges(this.hostObject);\n            // }\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        // if (changes?.options?.currentValue) {\n        //     this.loadModule(changes?.options?.currentValue);\n        // }\n    }\n\n    private async loadModule() {\n        try {\n            const t0 = performance.now();\n        \n            this.viewContainer?.clear();\n            \n            if (this.options.exposedModule?.length > 0) { // Load module\n                if (this.options?.addonId && (this.options.type === 'module' || this.options.type === 'script')) {\n                    const lastSlashIndex = this.options.remoteEntry?.lastIndexOf('/') || -1;\n                    \n                    if (lastSlashIndex > 0) {\n                        const publicPath = this.options.remoteEntry.substring(0, lastSlashIndex + 1);\n                        this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);\n                    }\n                }\n\n                const module =  await loadRemoteModule(this.options).then(m => m);\n                const moduleRef = createNgModuleRef(module[this.options.exposedModule.replace('./','')], this.injector);\n                this.compRef = this.viewContainer.createComponent(module[this.options.componentName], { injector: this.injector, ngModuleRef: moduleRef });\n\n                const t1 = performance.now();\n                console.log('remote module load performance: ' + (t1-t0)/1000);\n            } \n            // Check if this is in use??? (comment out in Angular 14 version)\n            // else { // Load Component\n            //     const componentType = await loadRemoteModule(this.options).then(m => m[this.options.componentName]);\n            //     this.compRef = this.viewContainer.createComponent(componentType, { injector: this.injector });\n            // }\n\n            this.load.emit();\n\n            if (this.compRef) {\n                this.setHostComponentIntoComponentRef();\n                \n                this.compRef?.instance['hostEvents']?.subscribe(e => {\n                    // switch(e.action){\n                    //     case 'addon-loaded':\n                    //         this.showSpinner = false;\n                    // }\n                    this.hostEvents.emit(e)\n                });\n            }\n        } catch(error) {\n            console.error(error);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.compRef?.destroy();\n        this.viewContainer?.clear();\n    }\n}\n\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3RlLWxvYWRlci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1saWIvcmVtb3RlLWxvYWRlci9yZW1vdGUtbG9hZGVyLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMb2FkUmVtb3RlTW9kdWxlT3B0aW9ucyB9IGZyb20gXCJAYW5ndWxhci1hcmNoaXRlY3RzL21vZHVsZS1mZWRlcmF0aW9uXCI7XG5pbXBvcnQgeyBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1hdERpYWxvZ0NvbmZpZyB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2dcIjtcbmltcG9ydCB7IFBlcERpYWxvZ1NpemVUeXBlIH0gZnJvbSBcIkBwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL2RpYWxvZ1wiO1xuaW1wb3J0IHsgSW5zdGFsbGVkQWRkb24sIE5nQ29tcG9uZW50UmVsYXRpb24gfSBmcm9tIFwiQHBlcHBlcmktYWRkb25zL3BhcGktc2RrXCI7XG5cbnR5cGUgUGVwUmVtb3RlTG9hZGVyRGF0YSA9IHtcbiAgICBhZGRvbklkPzogc3RyaW5nO1xuICAgIGNvbXBvbmVudE5hbWU/OiBzdHJpbmc7XG4gICAgLy8gRm9yIHdlYiBjb21wb25lbnRzXG4gICAgZWxlbWVudE5hbWU/OiBzdHJpbmc7XG4gICAgXG4gICAgLy8gZGlzcGxheU5hbWU/OiBzdHJpbmc7XG4gICAgLy8gTWF5YmUgdGhvc2UgcHJvcGVydGllcyBhcmUgbm90IGluIHVzZSBzbyB3ZSBuZWVkIHRvIHJlbW92ZSB0aGVtLlxuICAgIC8vIHVwZGF0ZT86IGJvb2xlYW47XG4gICAgLy8gbm9Nb2R1bGU/OiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBQZXBSZW1vdGVMb2FkZXJPcHRpb25zID0gUGVwUmVtb3RlTG9hZGVyRGF0YSAmIExvYWRSZW1vdGVNb2R1bGVPcHRpb25zO1xuXG5leHBvcnQgaW50ZXJmYWNlIElQZXBSZW1vdGVMb2FkZXJQYXJhbXNPcHRpb25zIHtcbiAgICBuYW1lPzogc3RyaW5nLCBcbiAgICBzbHVnTmFtZT86IHN0cmluZywgXG4gICAgYmxvY2tUeXBlPzogc3RyaW5nLFxuICAgIGFkZG9uVVVJRD86IHN0cmluZyxcbiAgICBibG9ja1JlbW90ZUVudHJ5Pzogc3RyaW5nLFxuICAgIHBhZ2VzRGV2U2VydmVyPzogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUJsb2NrTG9hZGVyRGF0YSB7XG4gICAgcmVsYXRpb246IE5nQ29tcG9uZW50UmVsYXRpb24sIFxuICAgIGFkZG9uOiBJbnN0YWxsZWRBZGRvbixcbiAgICBhZGRvblB1YmxpY0Jhc2VVUkw6IHN0cmluZ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElBZGRvbkJsb2NrTG9hZGVyT3B0aW9ucyBleHRlbmRzIElQZXBSZW1vdGVMb2FkZXJQYXJhbXNPcHRpb25zIHtcbiAgICBjb250YWluZXI6IFZpZXdDb250YWluZXJSZWY7XG4gICAgaG9zdE9iamVjdD86IGFueTtcbiAgICBob3N0RXZlbnRzQ2FsbGJhY2s/OiAoZXZlbnQ6IGFueSkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQWRkb25CbG9ja0xvYWRlckRpYWxvZ09wdGlvbnMgZXh0ZW5kcyBJQWRkb25CbG9ja0xvYWRlck9wdGlvbnMge1xuICAgIGRhdGE/OiBJQWRkb25CbG9ja0xvYWRlckRpYWxvZ0RhdGFPcHRpb25zO1xuICAgIGNvbmZpZz86IE1hdERpYWxvZ0NvbmZpZztcbiAgICBzaXplPzogUGVwRGlhbG9nU2l6ZVR5cGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUFkZG9uQmxvY2tMb2FkZXJEaWFsb2dEYXRhT3B0aW9ucyB7XG4gICAgdGl0bGU/OiBzdHJpbmc7XG4gICAgc2hvd0Nsb3NlPzogYm9vbGVhbjtcbiAgICBzaG93SGVhZGVyPzogYm9vbGVhbjtcbiAgICBzaG93Rm9vdGVyPzogYm9vbGVhbjtcbn0iXX0=
|
|
@@ -4,28 +4,34 @@ import { CommonModule } from '@angular/common';
|
|
|
4
4
|
import { MatDialogModule } from '@angular/material/dialog';
|
|
5
5
|
import { PepNgxLibModule } from '@pepperi-addons/ngx-lib';
|
|
6
6
|
import { PepDialogModule } from '@pepperi-addons/ngx-lib/dialog';
|
|
7
|
+
import { ModuleFederationToolsModule } from '@angular-architects/module-federation-tools';
|
|
7
8
|
import { PepAddonBlockLoaderComponent } from './addon-block-loader.component';
|
|
8
9
|
import { PepAddonBlockLoaderService } from './addon-block-loader.service';
|
|
9
10
|
import { PepRemoteLoaderComponent } from './remote-loader.component';
|
|
10
11
|
import { PepRemoteLoaderService } from './remote-loader.service';
|
|
12
|
+
import { PepRemoteLoaderElementComponent } from './remote-loader-element.component';
|
|
11
13
|
import * as i0 from "@angular/core";
|
|
12
14
|
export class PepRemoteLoaderModule {
|
|
13
15
|
}
|
|
14
16
|
PepRemoteLoaderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
15
17
|
PepRemoteLoaderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderModule, declarations: [PepAddonBlockLoaderComponent,
|
|
16
|
-
PepRemoteLoaderComponent
|
|
18
|
+
PepRemoteLoaderComponent,
|
|
19
|
+
PepRemoteLoaderElementComponent], imports: [CommonModule,
|
|
17
20
|
HttpClientModule,
|
|
21
|
+
ModuleFederationToolsModule,
|
|
18
22
|
// Material modules,
|
|
19
23
|
MatDialogModule,
|
|
20
24
|
// ngx-lib modules
|
|
21
25
|
PepNgxLibModule,
|
|
22
26
|
PepDialogModule], exports: [PepAddonBlockLoaderComponent,
|
|
23
|
-
PepRemoteLoaderComponent
|
|
27
|
+
PepRemoteLoaderComponent,
|
|
28
|
+
PepRemoteLoaderElementComponent] });
|
|
24
29
|
PepRemoteLoaderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderModule, providers: [
|
|
25
30
|
PepAddonBlockLoaderService,
|
|
26
31
|
PepRemoteLoaderService
|
|
27
32
|
], imports: [CommonModule,
|
|
28
33
|
HttpClientModule,
|
|
34
|
+
ModuleFederationToolsModule,
|
|
29
35
|
// Material modules,
|
|
30
36
|
MatDialogModule,
|
|
31
37
|
// ngx-lib modules
|
|
@@ -37,10 +43,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
37
43
|
declarations: [
|
|
38
44
|
PepAddonBlockLoaderComponent,
|
|
39
45
|
PepRemoteLoaderComponent,
|
|
46
|
+
PepRemoteLoaderElementComponent,
|
|
40
47
|
],
|
|
41
48
|
imports: [
|
|
42
49
|
CommonModule,
|
|
43
50
|
HttpClientModule,
|
|
51
|
+
ModuleFederationToolsModule,
|
|
44
52
|
// Material modules,
|
|
45
53
|
MatDialogModule,
|
|
46
54
|
// ngx-lib modules
|
|
@@ -50,6 +58,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
50
58
|
exports: [
|
|
51
59
|
PepAddonBlockLoaderComponent,
|
|
52
60
|
PepRemoteLoaderComponent,
|
|
61
|
+
PepRemoteLoaderElementComponent
|
|
53
62
|
],
|
|
54
63
|
providers: [
|
|
55
64
|
PepAddonBlockLoaderService,
|
|
@@ -57,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
57
66
|
]
|
|
58
67
|
}]
|
|
59
68
|
}] });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3RlLWxvYWRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbGliL3JlbW90ZS1sb2FkZXIvcmVtb3RlLWxvYWRlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRTNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFFMUYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDOUUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFMUUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDckUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDakUsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBNEJwRixNQUFNLE9BQU8scUJBQXFCOztrSEFBckIscUJBQXFCO21IQUFyQixxQkFBcUIsaUJBeEIxQiw0QkFBNEI7UUFDNUIsd0JBQXdCO1FBQ3hCLCtCQUErQixhQUcvQixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixvQkFBb0I7UUFDcEIsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixlQUFlO1FBQ2YsZUFBZSxhQUdmLDRCQUE0QjtRQUM1Qix3QkFBd0I7UUFDeEIsK0JBQStCO21IQU8xQixxQkFBcUIsYUFMbkI7UUFDUCwwQkFBMEI7UUFDMUIsc0JBQXNCO0tBQ3pCLFlBakJHLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsMkJBQTJCO1FBQzNCLG9CQUFvQjtRQUNwQixlQUFlO1FBQ2Ysa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixlQUFlOzJGQVlWLHFCQUFxQjtrQkExQmpDLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFO3dCQUNWLDRCQUE0Qjt3QkFDNUIsd0JBQXdCO3dCQUN4QiwrQkFBK0I7cUJBQ2xDO29CQUNELE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsMkJBQTJCO3dCQUMzQixvQkFBb0I7d0JBQ3BCLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLGVBQWU7cUJBQ2xCO29CQUNELE9BQU8sRUFBRTt3QkFDTCw0QkFBNEI7d0JBQzVCLHdCQUF3Qjt3QkFDeEIsK0JBQStCO3FCQUNsQztvQkFDRCxTQUFTLEVBQUU7d0JBQ1AsMEJBQTBCO3dCQUMxQixzQkFBc0I7cUJBQ3pCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuXG5pbXBvcnQgeyBQZXBOZ3hMaWJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBQZXBEaWFsb2dNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9kaWFsb2cnO1xuaW1wb3J0IHsgTW9kdWxlRmVkZXJhdGlvblRvb2xzTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXItYXJjaGl0ZWN0cy9tb2R1bGUtZmVkZXJhdGlvbi10b29scyc7XG5cbmltcG9ydCB7IFBlcEFkZG9uQmxvY2tMb2FkZXJDb21wb25lbnQgfSBmcm9tICcuL2FkZG9uLWJsb2NrLWxvYWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgUGVwQWRkb25CbG9ja0xvYWRlclNlcnZpY2UgfSBmcm9tICcuL2FkZG9uLWJsb2NrLWxvYWRlci5zZXJ2aWNlJztcblxuaW1wb3J0IHsgUGVwUmVtb3RlTG9hZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9yZW1vdGUtbG9hZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQZXBSZW1vdGVMb2FkZXJTZXJ2aWNlIH0gZnJvbSAnLi9yZW1vdGUtbG9hZGVyLnNlcnZpY2UnO1xuaW1wb3J0IHsgUGVwUmVtb3RlTG9hZGVyRWxlbWVudENvbXBvbmVudCB9IGZyb20gJy4vcmVtb3RlLWxvYWRlci1lbGVtZW50LmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFBlcEFkZG9uQmxvY2tMb2FkZXJDb21wb25lbnQsXG4gICAgICAgIFBlcFJlbW90ZUxvYWRlckNvbXBvbmVudCxcbiAgICAgICAgUGVwUmVtb3RlTG9hZGVyRWxlbWVudENvbXBvbmVudCxcbiAgICBdLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBIdHRwQ2xpZW50TW9kdWxlLFxuICAgICAgICBNb2R1bGVGZWRlcmF0aW9uVG9vbHNNb2R1bGUsXG4gICAgICAgIC8vIE1hdGVyaWFsIG1vZHVsZXMsXG4gICAgICAgIE1hdERpYWxvZ01vZHVsZSxcbiAgICAgICAgLy8gbmd4LWxpYiBtb2R1bGVzXG4gICAgICAgIFBlcE5neExpYk1vZHVsZSxcbiAgICAgICAgUGVwRGlhbG9nTW9kdWxlLFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICBQZXBBZGRvbkJsb2NrTG9hZGVyQ29tcG9uZW50LFxuICAgICAgICBQZXBSZW1vdGVMb2FkZXJDb21wb25lbnQsXG4gICAgICAgIFBlcFJlbW90ZUxvYWRlckVsZW1lbnRDb21wb25lbnRcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICBQZXBBZGRvbkJsb2NrTG9hZGVyU2VydmljZSxcbiAgICAgICAgUGVwUmVtb3RlTG9hZGVyU2VydmljZVxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgUGVwUmVtb3RlTG9hZGVyTW9kdWxlIHtcblxuXG59XG4iXX0=
|
|
@@ -1,57 +1,81 @@
|
|
|
1
|
+
import { coerceNumberProperty } from '@angular/cdk/coercion';
|
|
1
2
|
import { Injectable } from '@angular/core';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
import * as i1 from "@pepperi-addons/ngx-lib";
|
|
4
|
-
import * as i2 from "@angular/router";
|
|
5
5
|
export class PepRemoteLoaderService {
|
|
6
|
-
constructor(httpService, sessionService, addonService
|
|
6
|
+
constructor(httpService, sessionService, addonService) {
|
|
7
7
|
this.httpService = httpService;
|
|
8
8
|
this.sessionService = sessionService;
|
|
9
9
|
this.addonService = addonService;
|
|
10
|
-
this.route = route;
|
|
11
10
|
//
|
|
12
11
|
}
|
|
13
|
-
getRemoteLoaderOptions(blockLoaderData,
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
12
|
+
getRemoteLoaderOptions(blockLoaderData, blockRemoteEntry = '', type = 'module') {
|
|
13
|
+
const exposedModule = blockLoaderData.relation.ElementsModule?.length > 0 ? blockLoaderData.relation.ElementsModule : blockLoaderData.relation.ModuleName;
|
|
14
|
+
const res = {
|
|
15
|
+
type: type,
|
|
16
|
+
remoteEntry: blockRemoteEntry.length > 0 ? blockRemoteEntry : `${blockLoaderData.addonPublicBaseURL}${blockLoaderData.relation.AddonRelativeURL}.js`,
|
|
17
17
|
remoteName: blockLoaderData.relation.AddonRelativeURL,
|
|
18
|
-
exposedModule: `./${
|
|
19
|
-
|
|
18
|
+
exposedModule: `./${exposedModule}`,
|
|
19
|
+
addonId: blockLoaderData.relation.AddonUUID, // For local use (adding the relative path to the assets).
|
|
20
20
|
};
|
|
21
|
+
// If it's web components
|
|
22
|
+
if (blockLoaderData.relation.ElementsModule?.length > 0) {
|
|
23
|
+
res['elementName'] = blockLoaderData.relation.ElementName;
|
|
24
|
+
}
|
|
25
|
+
else { // For load the component from the module.
|
|
26
|
+
res['componentName'] = blockLoaderData.relation.ComponentName;
|
|
27
|
+
}
|
|
28
|
+
return res;
|
|
21
29
|
}
|
|
22
|
-
|
|
30
|
+
getBlockLoaderDataUrl(options) {
|
|
31
|
+
const fileName = 'addon_blocks';
|
|
32
|
+
const pagesAddonUuid = this.addonService.getPagesAddonUUID();
|
|
33
|
+
let pagesBaseUrl;
|
|
23
34
|
// For devServer run server on localhost.
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
return `http://localhost:4500/${fileName}`;
|
|
35
|
+
if (options.pagesDevServer?.length > 0) {
|
|
36
|
+
pagesBaseUrl = `${options.pagesDevServer}/${fileName}`;
|
|
27
37
|
}
|
|
28
38
|
else {
|
|
29
39
|
const baseUrl = this.sessionService.getPapiBaseUrl();
|
|
30
|
-
|
|
40
|
+
pagesBaseUrl = `${baseUrl}/addons/api/${pagesAddonUuid}/${fileName}`;
|
|
31
41
|
}
|
|
42
|
+
const url = `${pagesBaseUrl}/get_addon_block_loader_data?name=${options.name}&slugName=${options.slugName}&blockType=${options.blockType}&addonUUID=${options.addonUUID}`;
|
|
43
|
+
return url;
|
|
32
44
|
}
|
|
33
|
-
async getBlockRemoteLoaderOptions(
|
|
45
|
+
async getBlockRemoteLoaderOptions(options) {
|
|
46
|
+
options.blockType = options.blockType ?? 'AddonBlock';
|
|
47
|
+
options.name = options.name ?? '';
|
|
48
|
+
options.slugName = options.slugName ?? '';
|
|
49
|
+
options.addonUUID = options.addonUUID ?? '';
|
|
34
50
|
return new Promise((resolve, reject) => {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
resolve(this.getRemoteLoaderOptions(data,
|
|
51
|
+
if (options.name?.length > 0 || (options.slugName?.length > 0 && options.blockType === 'SettingsBlock')) {
|
|
52
|
+
const blockLoaderDataUrl = this.getBlockLoaderDataUrl(options);
|
|
53
|
+
this.httpService.getHttpCall(blockLoaderDataUrl).toPromise().then((data) => {
|
|
54
|
+
const ngVersionNumber = coerceNumberProperty(data.relation?.SubType?.toLocaleLowerCase().replace('ng', ''), 14);
|
|
55
|
+
const type = ngVersionNumber >= 14 ? 'module' : 'script';
|
|
56
|
+
resolve(this.getRemoteLoaderOptions(data, options.blockRemoteEntry, type));
|
|
57
|
+
}).catch(err => {
|
|
58
|
+
const nameMsg = options.blockType === 'SettingsBlock' ? `slugName - ${options.slugName}` : `name - ${options.name}`;
|
|
59
|
+
reject(`Block with ${nameMsg} is not found for type - ${options.blockType}`);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
if (options.blockType === 'SettingsBlock') {
|
|
64
|
+
reject(`slugName is not supplied`);
|
|
41
65
|
}
|
|
42
66
|
else {
|
|
43
|
-
reject(`
|
|
67
|
+
reject(`name is not supplied`);
|
|
44
68
|
}
|
|
45
|
-
}
|
|
69
|
+
}
|
|
46
70
|
});
|
|
47
71
|
}
|
|
48
72
|
}
|
|
49
|
-
PepRemoteLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderService, deps: [{ token: i1.PepHttpService }, { token: i1.PepSessionService }, { token: i1.PepAddonService }
|
|
73
|
+
PepRemoteLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderService, deps: [{ token: i1.PepHttpService }, { token: i1.PepSessionService }, { token: i1.PepAddonService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
50
74
|
PepRemoteLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderService, providedIn: 'root' });
|
|
51
75
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderService, decorators: [{
|
|
52
76
|
type: Injectable,
|
|
53
77
|
args: [{
|
|
54
78
|
providedIn: 'root'
|
|
55
79
|
}]
|
|
56
|
-
}], ctorParameters: function () { return [{ type: i1.PepHttpService }, { type: i1.PepSessionService }, { type: i1.PepAddonService }
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
80
|
+
}], ctorParameters: function () { return [{ type: i1.PepHttpService }, { type: i1.PepSessionService }, { type: i1.PepAddonService }]; } });
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"remote-loader.service.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/remote-loader/remote-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceNumberProperty } from '@angular/cdk/coercion';\nimport { Injectable } from '@angular/core';\nimport { PepAddonService, PepHttpService, PepSessionService} from '@pepperi-addons/ngx-lib';\nimport { IPepRemoteLoaderParamsOptions, PepRemoteLoaderOptions } from './remote-loader.model';\nimport { IBlockLoaderData } from './remote-loader.model';\n\n@Injectable({ \n    providedIn: 'root' \n})\nexport class PepRemoteLoaderService {\n    \n    constructor(\n        private httpService: PepHttpService,\n        private sessionService: PepSessionService,\n        private addonService: PepAddonService\n    ) {\n        //\n    }\n\n    getRemoteLoaderOptions(blockLoaderData: IBlockLoaderData, blockRemoteEntry = '', type: 'script' | 'module' | 'manifest' = 'module'): PepRemoteLoaderOptions {\n        const exposedModule = blockLoaderData.relation.ElementsModule?.length > 0 ? blockLoaderData.relation.ElementsModule : blockLoaderData.relation.ModuleName;\n        const res = {\n            type: type,\n            remoteEntry: blockRemoteEntry.length > 0 ? blockRemoteEntry : `${blockLoaderData.addonPublicBaseURL}${blockLoaderData.relation.AddonRelativeURL}.js`,\n            remoteName: blockLoaderData.relation.AddonRelativeURL, // For script type, this is the name of the script.\n            exposedModule: `./${exposedModule}`,\n            addonId: blockLoaderData.relation.AddonUUID, // For local use (adding the relative path to the assets).\n        }\n        \n        // If it's web components\n        if (blockLoaderData.relation.ElementsModule?.length > 0) {\n            res['elementName'] = blockLoaderData.relation.ElementName\n        } else { // For load the component from the module.\n            res['componentName'] = blockLoaderData.relation.ComponentName; \n        }\n\n        return res;\n    }\n\n    private getBlockLoaderDataUrl(options: IPepRemoteLoaderParamsOptions): string {\n        const fileName = 'addon_blocks';\n        const pagesAddonUuid = this.addonService.getPagesAddonUUID();\n        let pagesBaseUrl;\n\n        // For devServer run server on localhost.\n        if(options.pagesDevServer?.length > 0) {\n            pagesBaseUrl = `${options.pagesDevServer}/${fileName}`;\n        } else {\n            const baseUrl = this.sessionService.getPapiBaseUrl();\n            pagesBaseUrl = `${baseUrl}/addons/api/${pagesAddonUuid}/${fileName}`;\n        }\n\n        const url = `${pagesBaseUrl}/get_addon_block_loader_data?name=${options.name}&slugName=${options.slugName}&blockType=${options.blockType}&addonUUID=${options.addonUUID}`;\n        return url;\n    }\n\n    async getBlockRemoteLoaderOptions(options: IPepRemoteLoaderParamsOptions): Promise<PepRemoteLoaderOptions> {\n        options.blockType = options.blockType ?? 'AddonBlock';\n        options.name = options.name ?? '';\n        options.slugName = options.slugName ?? '';\n        options.addonUUID = options.addonUUID ?? '';\n\n        return new Promise((resolve, reject) => {\n            if (options.name?.length > 0 || (options.slugName?.length > 0 && options.blockType === 'SettingsBlock')) {\n                const blockLoaderDataUrl = this.getBlockLoaderDataUrl(options);\n                this.httpService.getHttpCall(blockLoaderDataUrl).toPromise().then((data: IBlockLoaderData) => {\n                    const ngVersionNumber = coerceNumberProperty(data.relation?.SubType?.toLocaleLowerCase().replace('ng', ''), 14);\n                    const type = ngVersionNumber >= 14 ? 'module' : 'script';\n\n                    resolve(this.getRemoteLoaderOptions(data, options.blockRemoteEntry, type));\n                }).catch(err => {\n                    const nameMsg = options.blockType === 'SettingsBlock' ? `slugName - ${options.slugName}` : `name - ${options.name}`\n                    reject(`Block with ${nameMsg} is not found for type - ${options.blockType}`);\n                });\n            } else {\n                if (options.blockType === 'SettingsBlock') {\n                    reject(`slugName is not supplied`);\n                }\n                else {\n                    reject(`name is not supplied`);\n                }\n            }\n        });\n    }\n}\n"]}
|