@myop/angular 0.0.27 → 0.0.29

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/config.d.ts ADDED
@@ -0,0 +1,38 @@
1
+ import { CloudRepository } from "@myop/sdk/helpers";
2
+ /**
3
+ * Get the current CloudRepository instance
4
+ */
5
+ export declare const getCloudRepository: () => CloudRepository;
6
+ /**
7
+ * Check if a component is already preloaded/cached
8
+ * If env/preview not provided, checks if ANY version is preloaded
9
+ */
10
+ export declare const isPreloaded: (componentId: string, env?: string, preview?: boolean) => boolean;
11
+ /**
12
+ * Get the preloaded params for a component
13
+ */
14
+ export declare const getPreloadedParams: (componentId: string) => {
15
+ env: string;
16
+ preview: boolean;
17
+ } | undefined;
18
+ /**
19
+ * Enable local development mode
20
+ */
21
+ export declare const enableLocalDev: () => void;
22
+ /**
23
+ * Set a custom CloudRepository URL
24
+ */
25
+ export declare const setCloudRepositoryUrl: (url: string) => void;
26
+ /**
27
+ * Set a custom CloudRepository instance
28
+ */
29
+ export declare const setCloudRepository: (repository: CloudRepository) => void;
30
+ /**
31
+ * Set the default environment for component loading
32
+ */
33
+ export declare const setEnvironment: (env: string) => void;
34
+ /**
35
+ * Preload components for faster rendering.
36
+ * Continues even if some components fail to load.
37
+ */
38
+ export declare const preloadComponents: (ids: string[], env?: string, preview?: boolean) => Promise<PromiseSettledResult<import("@myop/sdk/common").IComponentConfig>[]>;
@@ -1,121 +1,604 @@
1
1
  import * as i0 from '@angular/core';
2
- import { inject, EnvironmentInjector, viewChild, input, linkedSignal, output, effect, ViewContainerRef, ViewChild, Component } from '@angular/core';
3
- import { hostSDK } from '@myop/sdk/host';
2
+ import { EventEmitter, Input, ContentChild, ViewChild, Output, ChangeDetectionStrategy, Component } from '@angular/core';
3
+ import * as i1 from '@angular/common';
4
+ import { CommonModule } from '@angular/common';
5
+ import { hostSDK, LOADER_GRADIENT, FALLBACK_GRADIENT } from '@myop/sdk/host';
4
6
  import { CloudRepository } from '@myop/sdk/helpers';
5
7
 
6
- class MyopContainerComponent {
7
- injector;
8
- elementRef;
9
- environmentInjector = inject(EnvironmentInjector);
10
- // protected router = inject(Router,{optional : true });
11
- // protected injector = inject(Injector);
12
- //protected ComponentFactoryResolver2 = inject(ComponentFactoryResolver);
13
- // protected route = inject(ActivatedRoute);
14
- // routeData = toSignal<{ flowId: string, componentId: string }>(this.route.data as any);
15
- //// View children
16
- myopContainer = viewChild('myopContainer');
17
- // lazyComponent = viewChild<ElementRef<HTMLDivElement>>('lazyComponent');
18
- // @ViewChild('lazyComponent', {read: ViewContainerRef}) lazyComponent?: ViewContainerRef;
19
- //lazyComponent?: ViewContainerRef;
20
- myopContainerRef;
21
- //// INPUTS
22
- _flowId = input(undefined, { alias: 'flowId' });
23
- flowId = linkedSignal(() => this._flowId() || undefined);
24
- _componentId = input('', { alias: 'componentId' });
25
- componentId = linkedSignal(() => this._componentId() || '');
26
- //_inputs = input<{ [key: string]: any }>();
27
- _inputs = input({}, { alias: 'inputs' });
28
- inputs = linkedSignal(() => this._inputs() || {});
29
- //// Outputs
30
- componentReady = output();
31
- constructor(appRef, injector, elementRef) {
32
- this.injector = injector;
33
- this.elementRef = elementRef;
34
- effect(async () => {
35
- // console.log(this.ComponentFactoryResolver2, this.environmentInjector);
36
- if (this.componentId()) {
37
- if (this.myopContainer()?.nativeElement) {
38
- const componentConfig = await CloudRepository.Main.fetchComponent(this.componentId(), this.flowId());
39
- const component = await hostSDK.loadComponent(componentConfig, this.myopContainer()?.nativeElement, {
40
- // @ts-ignore
41
- _environment: {
42
- inputs: this._inputs,
43
- //TODO: fix that (angular in angular mode)
44
- _angularContainerRef: this.myopContainerRef,
45
- //environmentInjector: this.environmentInjector,
46
- //appRef: appRef,
47
- doIt: (LazyLoadedComponent) => {
48
- // console.log('init into : ', LazyLoadedComponent, this.myopContainerRef);
49
- // this.myopContainerRef?.createComponent(LazyLoadedComponent);
50
- return;
51
- }
8
+ let _cloudRepository = CloudRepository.Main;
9
+ /**
10
+ * Get the current CloudRepository instance
11
+ */
12
+ const getCloudRepository = () => _cloudRepository;
13
+ /**
14
+ * Check if a component is already preloaded/cached
15
+ * If env/preview not provided, checks if ANY version is preloaded
16
+ */
17
+ const isPreloaded = (componentId, env, preview) => {
18
+ return _cloudRepository.isPreloaded(componentId, env, preview);
19
+ };
20
+ /**
21
+ * Get the preloaded params for a component
22
+ */
23
+ const getPreloadedParams = (componentId) => {
24
+ return _cloudRepository.getPreloadedParams(componentId);
25
+ };
26
+ /**
27
+ * Enable local development mode
28
+ */
29
+ const enableLocalDev = () => {
30
+ _cloudRepository = new CloudRepository("http://localhost:9292");
31
+ };
32
+ /**
33
+ * Set a custom CloudRepository URL
34
+ */
35
+ const setCloudRepositoryUrl = (url) => {
36
+ _cloudRepository = new CloudRepository(url);
37
+ };
38
+ /**
39
+ * Set a custom CloudRepository instance
40
+ */
41
+ const setCloudRepository = (repository) => {
42
+ _cloudRepository = repository;
43
+ };
44
+ /**
45
+ * Set the default environment for component loading
46
+ */
47
+ const setEnvironment = (env) => {
48
+ _cloudRepository.setEnvironment(env);
49
+ };
50
+ /**
51
+ * Preload components for faster rendering.
52
+ * Continues even if some components fail to load.
53
+ */
54
+ const preloadComponents = async (ids, env, preview) => {
55
+ return Promise.allSettled(ids.map((id) => _cloudRepository.fetchComponentV2(id, env, preview)));
56
+ };
57
+
58
+ // Myop Logo SVG path (shared with SDK)
59
+ const MYOP_LOGO_PATH$2 = "M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z";
60
+ class MyopComponentV2 {
61
+ cdr;
62
+ ngZone;
63
+ // Inputs
64
+ componentId;
65
+ componentConfig;
66
+ data;
67
+ fadeDuration = 200;
68
+ autoSize = false;
69
+ environment;
70
+ preview;
71
+ on;
72
+ // Outputs
73
+ load = new EventEmitter();
74
+ error = new EventEmitter();
75
+ sizeChange = new EventEmitter();
76
+ cta = new EventEmitter();
77
+ // View refs
78
+ myopContainer;
79
+ // Content projection refs (for ng-template approach)
80
+ customLoader;
81
+ customFallback;
82
+ // Input refs (for component approach - e.g., [loader]="loaderTemplate")
83
+ loader;
84
+ fallback;
85
+ // Internal state
86
+ showLoader = true;
87
+ loaderOpacity = 1;
88
+ showFallback = false;
89
+ isComponentLoaded = false;
90
+ autoSizeResult;
91
+ // Logo path for template
92
+ logoPath = MYOP_LOGO_PATH$2;
93
+ // Private state
94
+ myopComponent = null;
95
+ isLoading = false;
96
+ pendingLoad = false;
97
+ autoSizeCleanup = null;
98
+ isCancelled = false;
99
+ constructor(cdr, ngZone) {
100
+ this.cdr = cdr;
101
+ this.ngZone = ngZone;
102
+ }
103
+ ngOnInit() {
104
+ // Check if preloaded to skip loader
105
+ if (this.componentId && isPreloaded(this.componentId)) {
106
+ this.showLoader = false;
107
+ }
108
+ if (this.componentId || this.componentConfig) {
109
+ this.renderComponent();
110
+ }
111
+ }
112
+ ngOnChanges(changes) {
113
+ // Handle componentId change - reload component
114
+ if (changes["componentId"] && !changes["componentId"].firstChange) {
115
+ this.reloadComponent();
116
+ }
117
+ // Handle data change - call myop_init_interface
118
+ if (changes["data"] && !changes["data"].firstChange) {
119
+ this.updateData(changes["data"].currentValue);
120
+ }
121
+ }
122
+ ngOnDestroy() {
123
+ this.isCancelled = true;
124
+ this.cleanup();
125
+ }
126
+ cleanup() {
127
+ if (this.autoSizeCleanup) {
128
+ this.autoSizeCleanup();
129
+ this.autoSizeCleanup = null;
130
+ }
131
+ if (this.myopComponent) {
132
+ this.myopComponent.dispose();
133
+ this.myopComponent = null;
134
+ }
135
+ }
136
+ async reloadComponent() {
137
+ // Reset state
138
+ this.isComponentLoaded = false;
139
+ this.showFallback = false;
140
+ this.showLoader = true;
141
+ this.loaderOpacity = 1;
142
+ // Cleanup old component
143
+ this.cleanup();
144
+ if (this.isLoading) {
145
+ this.pendingLoad = true;
146
+ }
147
+ else {
148
+ await this.renderComponent();
149
+ }
150
+ this.cdr.markForCheck();
151
+ }
152
+ async renderComponent() {
153
+ this.isLoading = true;
154
+ this.isCancelled = false;
155
+ try {
156
+ if (!this.componentId && !this.componentConfig) {
157
+ this.handleError("No component configuration provided");
158
+ return;
159
+ }
160
+ // Only pass preview if explicitly true (Angular may default undefined to falsy)
161
+ const previewParam = this.preview === true ? true : undefined;
162
+ const componentConfig = (this.componentConfig
163
+ ? this.componentConfig
164
+ : await getCloudRepository().fetchComponentV2(this.componentId, this.environment, previewParam));
165
+ if (this.isCancelled)
166
+ return;
167
+ if (!this.myopContainer?.nativeElement) {
168
+ this.handleError("Container element not found");
169
+ return;
170
+ }
171
+ const loadedComponent = await hostSDK.loadComponent(componentConfig, this.myopContainer.nativeElement, {
172
+ data: this.data,
173
+ _environment: {
174
+ props: {
175
+ componentId: this.componentId,
176
+ data: this.data,
177
+ environment: this.environment,
178
+ preview: this.preview,
179
+ autoSize: this.autoSize,
180
+ },
181
+ },
182
+ });
183
+ if (this.isCancelled) {
184
+ loadedComponent.dispose();
185
+ return;
186
+ }
187
+ this.myopComponent = loadedComponent;
188
+ // Wait for component to be fully initiated
189
+ await this.myopComponent.initiated();
190
+ if (this.isCancelled) {
191
+ this.myopComponent?.dispose();
192
+ return;
193
+ }
194
+ // Wait for browser paint
195
+ await new Promise((resolve) => requestAnimationFrame(resolve));
196
+ if (this.isCancelled ||
197
+ !this.myopComponent ||
198
+ this.myopComponent.markedForDisposed) {
199
+ if (this.myopComponent && !this.myopComponent.markedForDisposed) {
200
+ this.myopComponent.dispose();
201
+ }
202
+ return;
203
+ }
204
+ this.isComponentLoaded = true;
205
+ // For non-autoSize mode, hide loader immediately
206
+ if (!this.autoSize) {
207
+ this.hideLoader();
208
+ }
209
+ else {
210
+ this.setupAutoSize();
211
+ }
212
+ // Setup CTA handler
213
+ if (this.myopComponent?.props) {
214
+ this.myopComponent.props.myop_cta_handler = (action, payload) => {
215
+ // Run in Angular zone to trigger change detection
216
+ this.ngZone.run(() => {
217
+ // Call generic `on` handler if provided
218
+ if (this.on) {
219
+ this.on(action, payload);
52
220
  }
221
+ this.cta.emit({ action, payload });
53
222
  });
54
- this.componentReady.emit(component);
55
- }
223
+ };
224
+ }
225
+ this.ngZone.run(() => {
226
+ this.load.emit(this.myopComponent);
227
+ this.cdr.markForCheck();
228
+ });
229
+ }
230
+ catch (err) {
231
+ if (!this.isCancelled) {
232
+ this.handleError(err?.message || "Unknown error");
233
+ }
234
+ }
235
+ finally {
236
+ this.isLoading = false;
237
+ // Handle pending load
238
+ if (this.pendingLoad && !this.isCancelled) {
239
+ this.pendingLoad = false;
240
+ await this.renderComponent();
56
241
  }
242
+ }
243
+ }
244
+ updateData(newData) {
245
+ if (!this.isComponentLoaded || !this.myopComponent) {
246
+ return;
247
+ }
248
+ // Call myop_init_interface to update the component with new data
249
+ const initInterface = this.myopComponent.props?.myop_init_interface;
250
+ if (initInterface) {
251
+ initInterface(newData);
252
+ }
253
+ }
254
+ setupAutoSize() {
255
+ if (!this.isComponentLoaded || !this.myopComponent?.observeAutoSize) {
256
+ return;
257
+ }
258
+ let isFirstMeasurement = true;
259
+ this.autoSizeCleanup = this.myopComponent.observeAutoSize({
260
+ explicitWidth: undefined,
261
+ explicitHeight: undefined,
262
+ forceAutoSize: this.autoSize,
263
+ loaderMinHeight: 50,
264
+ onSizeChange: (result) => {
265
+ this.ngZone.run(() => {
266
+ this.sizeChange.emit(result);
267
+ this.autoSizeResult = result;
268
+ // Hide loader after first measurement
269
+ if (isFirstMeasurement) {
270
+ isFirstMeasurement = false;
271
+ this.hideLoader();
272
+ }
273
+ this.cdr.markForCheck();
274
+ });
275
+ },
57
276
  });
58
277
  }
59
- ngOnChanges(changes) {
60
- if (changes['dynamicInput']) {
61
- //console.log('Dynamic input changed:', this.dynamicInput);
62
- // Handle the input dynamically here
63
- }
64
- }
65
- ngAfterViewInit() {
66
- // const viewContainer = this.elementRef.nativeElement.querySelector('#lazyComponent');
67
- // if (viewContainer) {
68
- // this.lazyComponent = this.injector.get(ViewContainerRef);
69
- // }
70
- }
71
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: MyopContainerComponent, deps: [{ token: i0.ApplicationRef }, { token: i0.Injector }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
72
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "19.2.14", type: MyopContainerComponent, isStandalone: true, selector: "myop-container", inputs: { _flowId: { classPropertyName: "_flowId", publicName: "flowId", isSignal: true, isRequired: false, transformFunction: null }, _componentId: { classPropertyName: "_componentId", publicName: "componentId", isSignal: true, isRequired: false, transformFunction: null }, _inputs: { classPropertyName: "_inputs", publicName: "inputs", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { componentReady: "componentReady" }, viewQueries: [{ propertyName: "myopContainer", first: true, predicate: ["myopContainer"], descendants: true, isSignal: true }, { propertyName: "myopContainerRef", first: true, predicate: ["myopContainer"], descendants: true, read: ViewContainerRef }], usesOnChanges: true, ngImport: i0, template: `
73
- <div #myopContainer>
74
- <ng-content>
75
- <!-- Not Loaded-->
76
- </ng-content>
77
- <ng-content select="[error]">
78
- </ng-content>
278
+ hideLoader() {
279
+ this.loaderOpacity = 0;
280
+ this.cdr.markForCheck();
281
+ setTimeout(() => {
282
+ this.showLoader = false;
283
+ this.cdr.markForCheck();
284
+ }, this.fadeDuration);
285
+ }
286
+ handleError(errorMsg) {
287
+ console.error("[MyopComponent] Error:", errorMsg);
288
+ this.hideLoader();
289
+ this.showFallback = true;
290
+ this.error.emit(errorMsg);
291
+ this.cdr.markForCheck();
292
+ }
293
+ // Computed styles
294
+ get shouldAutoSize() {
295
+ return !!(this.autoSizeResult?.autoSizingWidth ||
296
+ this.autoSizeResult?.autoSizingHeight);
297
+ }
298
+ get loaderMinHeight() {
299
+ return this.showLoader ? "50px" : undefined;
300
+ }
301
+ get outerStyle() {
302
+ return {
303
+ position: "relative",
304
+ width: this.autoSizeResult?.autoSizingWidth
305
+ ? `${this.autoSizeResult.width}px`
306
+ : "100%",
307
+ height: this.autoSizeResult?.autoSizingHeight
308
+ ? `${this.autoSizeResult.height}px`
309
+ : "100%",
310
+ minHeight: this.loaderMinHeight || "",
311
+ overflow: this.shouldAutoSize ? "hidden" : "inherit",
312
+ };
313
+ }
314
+ get innerStyle() {
315
+ return {
316
+ position: "absolute",
317
+ inset: "0",
318
+ overflow: this.shouldAutoSize ? "hidden" : "",
319
+ };
320
+ }
321
+ // Loader styles using SDK gradient
322
+ get loaderStyle() {
323
+ return {
324
+ position: "absolute",
325
+ top: "0",
326
+ left: "0",
327
+ right: "0",
328
+ bottom: "0",
329
+ zIndex: "1",
330
+ background: LOADER_GRADIENT,
331
+ display: "flex",
332
+ justifyContent: "center",
333
+ alignItems: "center",
334
+ opacity: String(this.loaderOpacity),
335
+ transition: `opacity ${this.fadeDuration}ms ease-out`,
336
+ };
337
+ }
338
+ // Fallback styles using SDK gradient (kept for backwards compatibility)
339
+ get fallbackStyle() {
340
+ return {
341
+ position: "absolute",
342
+ top: "0",
343
+ left: "0",
344
+ right: "0",
345
+ bottom: "0",
346
+ background: FALLBACK_GRADIENT,
347
+ display: "flex",
348
+ justifyContent: "center",
349
+ alignItems: "center",
350
+ };
351
+ }
352
+ // Resolved loader template (input takes precedence over content projection)
353
+ get resolvedLoader() {
354
+ return this.loader || this.customLoader;
355
+ }
356
+ // Resolved fallback template (input takes precedence over content projection)
357
+ get resolvedFallback() {
358
+ return this.fallback || this.customFallback;
359
+ }
360
+ // Container style for loader (no background - let the template handle styling)
361
+ get loaderContainerStyle() {
362
+ return {
363
+ position: "absolute",
364
+ top: "0",
365
+ left: "0",
366
+ right: "0",
367
+ bottom: "0",
368
+ zIndex: "1",
369
+ opacity: String(this.loaderOpacity),
370
+ transition: `opacity ${this.fadeDuration}ms ease-out`,
371
+ };
372
+ }
373
+ // Container style for fallback (no background - let the template handle styling)
374
+ get fallbackContainerStyle() {
375
+ return {
376
+ position: "absolute",
377
+ top: "0",
378
+ left: "0",
379
+ right: "0",
380
+ bottom: "0",
381
+ };
382
+ }
383
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: MyopComponentV2, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
384
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.18", type: MyopComponentV2, isStandalone: true, selector: "myop-component", inputs: { componentId: "componentId", componentConfig: "componentConfig", data: "data", fadeDuration: "fadeDuration", autoSize: "autoSize", environment: "environment", preview: "preview", on: "on", loader: "loader", fallback: "fallback" }, outputs: { load: "load", error: "error", sizeChange: "sizeChange", cta: "cta" }, queries: [{ propertyName: "customLoader", first: true, predicate: ["loader"], descendants: true }, { propertyName: "customFallback", first: true, predicate: ["fallback"], descendants: true }], viewQueries: [{ propertyName: "myopContainer", first: true, predicate: ["myopContainer"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: `
385
+ <div [ngStyle]="outerStyle">
386
+ <div #myopContainer [ngStyle]="innerStyle"></div>
387
+ @if (showLoader && resolvedLoader) {
388
+ <div [ngStyle]="loaderContainerStyle">
389
+ <ng-container *ngTemplateOutlet="resolvedLoader"></ng-container>
390
+ </div>
391
+ }
392
+ @if (showFallback) {
393
+ @if (resolvedFallback) {
394
+ <div [ngStyle]="fallbackContainerStyle">
395
+ <ng-container *ngTemplateOutlet="resolvedFallback"></ng-container>
396
+ </div>
397
+ } @else {
398
+ <div [ngStyle]="fallbackStyle">
399
+ <svg
400
+ width="80"
401
+ viewBox="0 0 525 243"
402
+ fill="none"
403
+ xmlns="http://www.w3.org/2000/svg"
404
+ >
405
+ <path [attr.d]="logoPath" fill="white" />
406
+ </svg>
407
+ </div>
408
+ }
409
+ }
79
410
  </div>
80
-
81
- <!-- <div #lazyComponent>-->
82
-
83
- <!-- </div> -->
84
- `, isInline: true });
411
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
85
412
  }
86
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: MyopContainerComponent, decorators: [{
413
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: MyopComponentV2, decorators: [{
87
414
  type: Component,
88
415
  args: [{
89
- // eslint-disable-next-line @angular-eslint/component-selector
90
- selector: 'myop-container',
416
+ selector: "myop-component",
91
417
  standalone: true,
418
+ imports: [CommonModule],
419
+ changeDetection: ChangeDetectionStrategy.OnPush,
92
420
  template: `
93
- <div #myopContainer>
94
- <ng-content>
95
- <!-- Not Loaded-->
96
- </ng-content>
97
- <ng-content select="[error]">
98
- </ng-content>
421
+ <div [ngStyle]="outerStyle">
422
+ <div #myopContainer [ngStyle]="innerStyle"></div>
423
+ @if (showLoader && resolvedLoader) {
424
+ <div [ngStyle]="loaderContainerStyle">
425
+ <ng-container *ngTemplateOutlet="resolvedLoader"></ng-container>
426
+ </div>
427
+ }
428
+ @if (showFallback) {
429
+ @if (resolvedFallback) {
430
+ <div [ngStyle]="fallbackContainerStyle">
431
+ <ng-container *ngTemplateOutlet="resolvedFallback"></ng-container>
432
+ </div>
433
+ } @else {
434
+ <div [ngStyle]="fallbackStyle">
435
+ <svg
436
+ width="80"
437
+ viewBox="0 0 525 243"
438
+ fill="none"
439
+ xmlns="http://www.w3.org/2000/svg"
440
+ >
441
+ <path [attr.d]="logoPath" fill="white" />
442
+ </svg>
443
+ </div>
444
+ }
445
+ }
99
446
  </div>
100
-
101
- <!-- <div #lazyComponent>-->
102
-
103
- <!-- </div> -->
104
- `
447
+ `,
105
448
  }]
106
- }], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.Injector }, { type: i0.ElementRef }], propDecorators: { myopContainerRef: [{
449
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.NgZone }], propDecorators: { componentId: [{
450
+ type: Input
451
+ }], componentConfig: [{
452
+ type: Input
453
+ }], data: [{
454
+ type: Input
455
+ }], fadeDuration: [{
456
+ type: Input
457
+ }], autoSize: [{
458
+ type: Input
459
+ }], environment: [{
460
+ type: Input
461
+ }], preview: [{
462
+ type: Input
463
+ }], on: [{
464
+ type: Input
465
+ }], load: [{
466
+ type: Output
467
+ }], error: [{
468
+ type: Output
469
+ }], sizeChange: [{
470
+ type: Output
471
+ }], cta: [{
472
+ type: Output
473
+ }], myopContainer: [{
107
474
  type: ViewChild,
108
- args: ['myopContainer', { read: ViewContainerRef }]
475
+ args: ["myopContainer", { static: true }]
476
+ }], customLoader: [{
477
+ type: ContentChild,
478
+ args: ["loader"]
479
+ }], customFallback: [{
480
+ type: ContentChild,
481
+ args: ["fallback"]
482
+ }], loader: [{
483
+ type: Input
484
+ }], fallback: [{
485
+ type: Input
109
486
  }] } });
110
487
 
488
+ // Myop Logo SVG path
489
+ const MYOP_LOGO_PATH$1 = "M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z";
490
+ class MyopLoaderComponent {
491
+ logoPath = MYOP_LOGO_PATH$1;
492
+ get loaderStyle() {
493
+ return {
494
+ position: "absolute",
495
+ top: "0",
496
+ left: "0",
497
+ right: "0",
498
+ bottom: "0",
499
+ background: LOADER_GRADIENT,
500
+ display: "flex",
501
+ justifyContent: "center",
502
+ alignItems: "center",
503
+ };
504
+ }
505
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: MyopLoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
506
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.18", type: MyopLoaderComponent, isStandalone: true, selector: "myop-loader", ngImport: i0, template: `
507
+ <div [ngStyle]="loaderStyle">
508
+ <svg
509
+ width="80"
510
+ viewBox="0 0 525 243"
511
+ fill="none"
512
+ xmlns="http://www.w3.org/2000/svg"
513
+ >
514
+ <path [attr.d]="logoPath" fill="white" />
515
+ </svg>
516
+ </div>
517
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
518
+ }
519
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: MyopLoaderComponent, decorators: [{
520
+ type: Component,
521
+ args: [{
522
+ selector: "myop-loader",
523
+ standalone: true,
524
+ imports: [CommonModule],
525
+ changeDetection: ChangeDetectionStrategy.OnPush,
526
+ template: `
527
+ <div [ngStyle]="loaderStyle">
528
+ <svg
529
+ width="80"
530
+ viewBox="0 0 525 243"
531
+ fill="none"
532
+ xmlns="http://www.w3.org/2000/svg"
533
+ >
534
+ <path [attr.d]="logoPath" fill="white" />
535
+ </svg>
536
+ </div>
537
+ `,
538
+ }]
539
+ }] });
540
+
541
+ // Myop Logo SVG path
542
+ const MYOP_LOGO_PATH = "M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z";
543
+ class MyopFallbackComponent {
544
+ logoPath = MYOP_LOGO_PATH;
545
+ get fallbackStyle() {
546
+ return {
547
+ position: "absolute",
548
+ top: "0",
549
+ left: "0",
550
+ right: "0",
551
+ bottom: "0",
552
+ background: FALLBACK_GRADIENT,
553
+ display: "flex",
554
+ justifyContent: "center",
555
+ alignItems: "center",
556
+ };
557
+ }
558
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: MyopFallbackComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
559
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.18", type: MyopFallbackComponent, isStandalone: true, selector: "myop-fallback", ngImport: i0, template: `
560
+ <div [ngStyle]="fallbackStyle">
561
+ <svg
562
+ width="80"
563
+ viewBox="0 0 525 243"
564
+ fill="none"
565
+ xmlns="http://www.w3.org/2000/svg"
566
+ >
567
+ <path [attr.d]="logoPath" fill="white" />
568
+ </svg>
569
+ </div>
570
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
571
+ }
572
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: MyopFallbackComponent, decorators: [{
573
+ type: Component,
574
+ args: [{
575
+ selector: "myop-fallback",
576
+ standalone: true,
577
+ imports: [CommonModule],
578
+ changeDetection: ChangeDetectionStrategy.OnPush,
579
+ template: `
580
+ <div [ngStyle]="fallbackStyle">
581
+ <svg
582
+ width="80"
583
+ viewBox="0 0 525 243"
584
+ fill="none"
585
+ xmlns="http://www.w3.org/2000/svg"
586
+ >
587
+ <path [attr.d]="logoPath" fill="white" />
588
+ </svg>
589
+ </div>
590
+ `,
591
+ }]
592
+ }] });
593
+
111
594
  /*
112
- * Public API
595
+ * Public API Surface of @myop/angular
113
596
  */
114
- //export * from './lib/exposeAngularComponent';
597
+ // Main component
115
598
 
116
599
  /**
117
600
  * Generated bundle index. Do not edit.
118
601
  */
119
602
 
120
- export { MyopContainerComponent };
603
+ export { MyopComponentV2 as MyopComponent, MyopFallbackComponent as MyopFallback, MyopFallbackComponent, MyopLoaderComponent as MyopLoader, MyopLoaderComponent, enableLocalDev, getCloudRepository, getPreloadedParams, isPreloaded, preloadComponents, setCloudRepository, setCloudRepositoryUrl, setEnvironment };
121
604
  //# sourceMappingURL=myop-angular.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"myop-angular.mjs","sources":["../../../projects/components/src/lib/myop-container.component.ts","../../../projects/components/src/public-api.ts","../../../projects/components/src/myop-angular.ts"],"sourcesContent":["import {\n Component,\n EnvironmentInjector,\n effect,\n ElementRef,\n inject,\n input,\n linkedSignal,\n output,\n viewChild,\n ViewChild,\n ViewContainerRef,\n Type,\n ApplicationRef,\n Injector, SimpleChanges, OnChanges\n} from '@angular/core';\nimport {hostSDK, IMyopComponent} from '@myop/sdk/host';\nimport {CloudRepository} from '@myop/sdk/helpers';\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'myop-container',\n standalone: true,\n template: `\n <div #myopContainer>\n <ng-content>\n <!-- Not Loaded-->\n </ng-content>\n <ng-content select=\"[error]\">\n </ng-content>\n </div>\n\n <!-- <div #lazyComponent>-->\n\n <!-- </div> -->\n `\n})\nexport class MyopContainerComponent implements OnChanges {\n\n protected environmentInjector = inject(EnvironmentInjector);\n // protected router = inject(Router,{optional : true });\n // protected injector = inject(Injector);\n\n //protected ComponentFactoryResolver2 = inject(ComponentFactoryResolver);\n\n // protected route = inject(ActivatedRoute);\n // routeData = toSignal<{ flowId: string, componentId: string }>(this.route.data as any);\n\n //// View children\n myopContainer = viewChild<ElementRef<HTMLDivElement>>('myopContainer');\n // lazyComponent = viewChild<ElementRef<HTMLDivElement>>('lazyComponent');\n\n // @ViewChild('lazyComponent', {read: ViewContainerRef}) lazyComponent?: ViewContainerRef;\n //lazyComponent?: ViewContainerRef;\n\n @ViewChild('myopContainer', {read: ViewContainerRef})\n myopContainerRef!: ViewContainerRef;\n\n //// INPUTS\n _flowId = input<string | undefined>(undefined, {alias: 'flowId'});\n flowId = linkedSignal(() => this._flowId() || undefined);\n\n _componentId = input<string>('', {alias: 'componentId'});\n componentId = linkedSignal(() => this._componentId() || '');\n\n //_inputs = input<{ [key: string]: any }>();\n _inputs = input<{ [key: string]: any }>({}, {alias: 'inputs'});\n\n inputs = linkedSignal(() => this._inputs() || {});\n\n //// Outputs\n componentReady = output<IMyopComponent>()\n\n constructor(appRef: ApplicationRef, private injector: Injector, private elementRef: ElementRef) {\n\n effect(async () => {\n // console.log(this.ComponentFactoryResolver2, this.environmentInjector);\n if (this.componentId()) {\n if (this.myopContainer()?.nativeElement) {\n\n const componentConfig = await CloudRepository.Main.fetchComponent(this.componentId(), this.flowId());\n const component = await hostSDK.loadComponent(\n componentConfig,\n this.myopContainer()?.nativeElement as any,\n {\n // @ts-ignore\n _environment: {\n inputs: this._inputs,\n //TODO: fix that (angular in angular mode)\n _angularContainerRef : this.myopContainerRef,\n //environmentInjector: this.environmentInjector,\n //appRef: appRef,\n doIt: (LazyLoadedComponent: Type<any>) => {\n\n // console.log('init into : ', LazyLoadedComponent, this.myopContainerRef);\n // this.myopContainerRef?.createComponent(LazyLoadedComponent);\n\n return;\n }\n }\n });\n\n this.componentReady.emit(component);\n }\n }\n });\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n if (changes['dynamicInput']) {\n //console.log('Dynamic input changed:', this.dynamicInput);\n // Handle the input dynamically here\n }\n }\n\n ngAfterViewInit(): void {\n // const viewContainer = this.elementRef.nativeElement.querySelector('#lazyComponent');\n // if (viewContainer) {\n // this.lazyComponent = this.injector.get(ViewContainerRef);\n // }\n }\n}\n","/*\n * Public API\n */\n\nexport * from './lib/myop-container.component';\n//export * from './lib/exposeAngularComponent';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"myop-angular.mjs","sources":["../../../projects/components/src/config.ts","../../../projects/components/src/lib/myop.component.ts","../../../projects/components/src/lib/myop-loader.component.ts","../../../projects/components/src/lib/myop-fallback.component.ts","../../../projects/components/src/public-api.ts","../../../projects/components/src/myop-angular.ts"],"sourcesContent":["import { CloudRepository } from \"@myop/sdk/helpers\";\n\nlet _cloudRepository = CloudRepository.Main;\n\n/**\n * Get the current CloudRepository instance\n */\nexport const getCloudRepository = () => _cloudRepository;\n\n/**\n * Check if a component is already preloaded/cached\n * If env/preview not provided, checks if ANY version is preloaded\n */\nexport const isPreloaded = (\n componentId: string,\n env?: string,\n preview?: boolean\n): boolean => {\n return _cloudRepository.isPreloaded(componentId, env, preview);\n};\n\n/**\n * Get the preloaded params for a component\n */\nexport const getPreloadedParams = (componentId: string) => {\n return _cloudRepository.getPreloadedParams(componentId);\n};\n\n/**\n * Enable local development mode\n */\nexport const enableLocalDev = () => {\n _cloudRepository = new CloudRepository(\"http://localhost:9292\");\n};\n\n/**\n * Set a custom CloudRepository URL\n */\nexport const setCloudRepositoryUrl = (url: string) => {\n _cloudRepository = new CloudRepository(url);\n};\n\n/**\n * Set a custom CloudRepository instance\n */\nexport const setCloudRepository = (repository: CloudRepository) => {\n _cloudRepository = repository;\n};\n\n/**\n * Set the default environment for component loading\n */\nexport const setEnvironment = (env: string) => {\n _cloudRepository.setEnvironment(env);\n};\n\n/**\n * Preload components for faster rendering.\n * Continues even if some components fail to load.\n */\nexport const preloadComponents = async (\n ids: string[],\n env?: string,\n preview?: boolean\n) => {\n return Promise.allSettled(\n ids.map((id) => _cloudRepository.fetchComponentV2(id, env, preview))\n );\n};\n","import {\n Component,\n ElementRef,\n Input,\n Output,\n EventEmitter,\n OnInit,\n OnChanges,\n OnDestroy,\n SimpleChanges,\n ViewChild,\n TemplateRef,\n ContentChild,\n ChangeDetectionStrategy,\n ChangeDetectorRef,\n NgZone,\n} from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\nimport {\n hostSDK,\n type IMyopComponent,\n LOADER_GRADIENT,\n FALLBACK_GRADIENT,\n} from \"@myop/sdk/host\";\nimport { getCloudRepository, isPreloaded } from \"../config\";\n\n// Myop Logo SVG path (shared with SDK)\nconst MYOP_LOGO_PATH =\n \"M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z\";\n\nexport interface IComponentInstanceConfig {\n id: string;\n componentId: string;\n componentName: string;\n skinSelector: { [key: string]: any };\n nestedComponents?: IComponentInstanceConfig[];\n resolvedExperiences?: { [key: string]: any }[];\n resolvedNestedComponents?: { [key: string]: any }[];\n [key: string]: any;\n}\n\nexport interface SizeInfo {\n width: number;\n height: number;\n autoSizingWidth: boolean;\n autoSizingHeight: boolean;\n}\n\nexport interface CtaEvent<TCtaPayloads extends Record<string, any> = Record<string, any>> {\n action: keyof TCtaPayloads | string;\n payload: TCtaPayloads[keyof TCtaPayloads] | any;\n}\n\n/**\n * Converts kebab-case string to PascalCase\n * e.g., 'column-reordered' -> 'ColumnReordered'\n */\nexport type KebabToPascal<S extends string> =\n S extends `${infer First}-${infer Rest}`\n ? `${Capitalize<First>}${KebabToPascal<Rest>}`\n : Capitalize<S>;\n\n/**\n * Generates typed event handler props from CTA payloads.\n * e.g., `{ 'row-clicked': { rowIndex: number } }` -> `{ onRowClicked?: (payload: { rowIndex: number }) => void }`\n */\nexport type EventHandlerProps<TPayloads extends Record<string, any>> =\n string extends keyof TPayloads\n ? {}\n : {\n [K in keyof TPayloads as `on${KebabToPascal<K & string>}`]?: (\n payload: TPayloads[K]\n ) => void;\n };\n\n/**\n * Type for the `on` callback prop.\n */\ntype OnCallback<TPayloads extends Record<string, any>> =\n string extends keyof TPayloads\n ? (action: string, payload: any) => void\n : <K extends keyof TPayloads>(action: K, payload: TPayloads[K]) => void;\n\n/**\n * Typed props interface for accessing component.props with autocomplete.\n * Contains myop_init_interface and myop_cta_handler with proper types.\n */\nexport interface IMyopComponentProps<\n TData = any,\n TCtaPayloads extends Record<string, any> = Record<string, any>\n> {\n /** Initialize the component with data */\n myop_init_interface?: (data: TData) => void;\n /** Handle CTA events from the component */\n myop_cta_handler?: <K extends keyof TCtaPayloads>(action: K, payload: TCtaPayloads[K]) => void;\n}\n\n/**\n * Typed Myop component interface with typed props.\n * Use this type for the component returned in load event.\n */\nexport type ITypedMyopComponent<\n TData = any,\n TCtaPayloads extends Record<string, any> = Record<string, any>\n> = Omit<IMyopComponent, 'props'> & {\n /** Typed props for the component */\n props: IMyopComponentProps<TData, TCtaPayloads> | null;\n};\n\n/**\n * Base props interface for MyopComponent\n */\ninterface IBaseProps<\n TData = any,\n TCtaPayloads extends Record<string, any> = Record<string, any>\n> {\n componentId?: string;\n componentConfig?: IComponentInstanceConfig;\n data?: TData;\n fadeDuration?: number;\n autoSize?: boolean;\n environment?: string;\n preview?: boolean;\n on?: OnCallback<TCtaPayloads>;\n}\n\n/**\n * Full props type including generated event handlers.\n * Supports both generic `on` callback and individual typed handlers like `onRowClicked`.\n */\nexport type IPropTypes<\n TData = any,\n TCtaPayloads extends Record<string, any> = Record<string, any>\n> = IBaseProps<TData, TCtaPayloads> & EventHandlerProps<TCtaPayloads>;\n\n@Component({\n selector: \"myop-component\",\n standalone: true,\n imports: [CommonModule],\n changeDetection: ChangeDetectionStrategy.OnPush,\n template: `\n <div [ngStyle]=\"outerStyle\">\n <div #myopContainer [ngStyle]=\"innerStyle\"></div>\n @if (showLoader && resolvedLoader) {\n <div [ngStyle]=\"loaderContainerStyle\">\n <ng-container *ngTemplateOutlet=\"resolvedLoader\"></ng-container>\n </div>\n }\n @if (showFallback) {\n @if (resolvedFallback) {\n <div [ngStyle]=\"fallbackContainerStyle\">\n <ng-container *ngTemplateOutlet=\"resolvedFallback\"></ng-container>\n </div>\n } @else {\n <div [ngStyle]=\"fallbackStyle\">\n <svg\n width=\"80\"\n viewBox=\"0 0 525 243\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path [attr.d]=\"logoPath\" fill=\"white\" />\n </svg>\n </div>\n }\n }\n </div>\n `,\n})\nexport class MyopComponentV2<TData = any, TCtaPayloads extends Record<string, any> = Record<string, any>>\n implements OnInit, OnChanges, OnDestroy\n{\n // Inputs\n @Input() componentId?: string;\n @Input() componentConfig?: IComponentInstanceConfig;\n @Input() data?: TData;\n @Input() fadeDuration: number = 200;\n @Input() autoSize: boolean = false;\n @Input() environment?: string;\n @Input() preview?: boolean;\n @Input() on?: (action: string, payload: any) => void;\n\n // Outputs\n @Output() load = new EventEmitter<ITypedMyopComponent<TData, TCtaPayloads>>();\n @Output() error = new EventEmitter<string>();\n @Output() sizeChange = new EventEmitter<SizeInfo>();\n @Output() cta = new EventEmitter<CtaEvent<TCtaPayloads>>();\n\n // View refs\n @ViewChild(\"myopContainer\", { static: true })\n myopContainer!: ElementRef<HTMLDivElement>;\n\n // Content projection refs (for ng-template approach)\n @ContentChild(\"loader\") customLoader?: TemplateRef<any>;\n @ContentChild(\"fallback\") customFallback?: TemplateRef<any>;\n\n // Input refs (for component approach - e.g., [loader]=\"loaderTemplate\")\n @Input() loader?: TemplateRef<any>;\n @Input() fallback?: TemplateRef<any>;\n\n // Internal state\n showLoader: boolean = true;\n loaderOpacity: number = 1;\n showFallback: boolean = false;\n isComponentLoaded: boolean = false;\n autoSizeResult?: SizeInfo;\n\n // Logo path for template\n readonly logoPath = MYOP_LOGO_PATH;\n\n // Private state\n private myopComponent: IMyopComponent | null = null;\n private isLoading: boolean = false;\n private pendingLoad: boolean = false;\n private autoSizeCleanup: (() => void) | null = null;\n private isCancelled: boolean = false;\n\n constructor(\n private cdr: ChangeDetectorRef,\n private ngZone: NgZone\n ) {}\n\n ngOnInit(): void {\n // Check if preloaded to skip loader\n if (this.componentId && isPreloaded(this.componentId)) {\n this.showLoader = false;\n }\n\n if (this.componentId || this.componentConfig) {\n this.renderComponent();\n }\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n // Handle componentId change - reload component\n if (changes[\"componentId\"] && !changes[\"componentId\"].firstChange) {\n this.reloadComponent();\n }\n\n // Handle data change - call myop_init_interface\n if (changes[\"data\"] && !changes[\"data\"].firstChange) {\n this.updateData(changes[\"data\"].currentValue);\n }\n }\n\n ngOnDestroy(): void {\n this.isCancelled = true;\n this.cleanup();\n }\n\n private cleanup(): void {\n if (this.autoSizeCleanup) {\n this.autoSizeCleanup();\n this.autoSizeCleanup = null;\n }\n if (this.myopComponent) {\n this.myopComponent.dispose();\n this.myopComponent = null;\n }\n }\n\n private async reloadComponent(): Promise<void> {\n // Reset state\n this.isComponentLoaded = false;\n this.showFallback = false;\n this.showLoader = true;\n this.loaderOpacity = 1;\n\n // Cleanup old component\n this.cleanup();\n\n if (this.isLoading) {\n this.pendingLoad = true;\n } else {\n await this.renderComponent();\n }\n\n this.cdr.markForCheck();\n }\n\n private async renderComponent(): Promise<void> {\n this.isLoading = true;\n this.isCancelled = false;\n\n try {\n if (!this.componentId && !this.componentConfig) {\n this.handleError(\"No component configuration provided\");\n return;\n }\n\n // Only pass preview if explicitly true (Angular may default undefined to falsy)\n const previewParam = this.preview === true ? true : undefined;\n\n const componentConfig = (this.componentConfig\n ? this.componentConfig\n : await getCloudRepository().fetchComponentV2(\n this.componentId!,\n this.environment,\n previewParam\n )) as any;\n\n if (this.isCancelled) return;\n\n if (!this.myopContainer?.nativeElement) {\n this.handleError(\"Container element not found\");\n return;\n }\n\n const loadedComponent = await hostSDK.loadComponent(\n componentConfig,\n this.myopContainer.nativeElement,\n {\n data: this.data,\n _environment: {\n props: {\n componentId: this.componentId,\n data: this.data,\n environment: this.environment,\n preview: this.preview,\n autoSize: this.autoSize,\n },\n },\n }\n );\n\n if (this.isCancelled) {\n loadedComponent.dispose();\n return;\n }\n\n this.myopComponent = loadedComponent;\n\n // Wait for component to be fully initiated\n await this.myopComponent.initiated();\n\n if (this.isCancelled) {\n this.myopComponent?.dispose();\n return;\n }\n\n // Wait for browser paint\n await new Promise((resolve) => requestAnimationFrame(resolve));\n\n if (\n this.isCancelled ||\n !this.myopComponent ||\n this.myopComponent.markedForDisposed\n ) {\n if (this.myopComponent && !this.myopComponent.markedForDisposed) {\n this.myopComponent.dispose();\n }\n return;\n }\n\n this.isComponentLoaded = true;\n\n // For non-autoSize mode, hide loader immediately\n if (!this.autoSize) {\n this.hideLoader();\n } else {\n this.setupAutoSize();\n }\n\n // Setup CTA handler\n if (this.myopComponent?.props) {\n this.myopComponent.props.myop_cta_handler = (\n action: string,\n payload?: any\n ) => {\n // Run in Angular zone to trigger change detection\n this.ngZone.run(() => {\n // Call generic `on` handler if provided\n if (this.on) {\n this.on(action, payload);\n }\n\n this.cta.emit({ action, payload });\n });\n };\n }\n\n this.ngZone.run(() => {\n this.load.emit(this.myopComponent!);\n this.cdr.markForCheck();\n });\n } catch (err: any) {\n if (!this.isCancelled) {\n this.handleError(err?.message || \"Unknown error\");\n }\n } finally {\n this.isLoading = false;\n\n // Handle pending load\n if (this.pendingLoad && !this.isCancelled) {\n this.pendingLoad = false;\n await this.renderComponent();\n }\n }\n }\n\n private updateData(newData: TData): void {\n if (!this.isComponentLoaded || !this.myopComponent) {\n return;\n }\n\n // Call myop_init_interface to update the component with new data\n const initInterface = this.myopComponent.props?.myop_init_interface;\n if (initInterface) {\n initInterface(newData);\n }\n }\n\n private setupAutoSize(): void {\n if (!this.isComponentLoaded || !this.myopComponent?.observeAutoSize) {\n return;\n }\n\n let isFirstMeasurement = true;\n\n this.autoSizeCleanup = this.myopComponent.observeAutoSize({\n explicitWidth: undefined,\n explicitHeight: undefined,\n forceAutoSize: this.autoSize,\n loaderMinHeight: 50,\n onSizeChange: (result: SizeInfo) => {\n this.ngZone.run(() => {\n this.sizeChange.emit(result);\n this.autoSizeResult = result;\n\n // Hide loader after first measurement\n if (isFirstMeasurement) {\n isFirstMeasurement = false;\n this.hideLoader();\n }\n\n this.cdr.markForCheck();\n });\n },\n });\n }\n\n private hideLoader(): void {\n this.loaderOpacity = 0;\n this.cdr.markForCheck();\n\n setTimeout(() => {\n this.showLoader = false;\n this.cdr.markForCheck();\n }, this.fadeDuration);\n }\n\n private handleError(errorMsg: string): void {\n console.error(\"[MyopComponent] Error:\", errorMsg);\n this.hideLoader();\n this.showFallback = true;\n this.error.emit(errorMsg);\n this.cdr.markForCheck();\n }\n\n // Computed styles\n get shouldAutoSize(): boolean {\n return !!(\n this.autoSizeResult?.autoSizingWidth ||\n this.autoSizeResult?.autoSizingHeight\n );\n }\n\n get loaderMinHeight(): string | undefined {\n return this.showLoader ? \"50px\" : undefined;\n }\n\n get outerStyle(): { [key: string]: string } {\n return {\n position: \"relative\",\n width: this.autoSizeResult?.autoSizingWidth\n ? `${this.autoSizeResult.width}px`\n : \"100%\",\n height: this.autoSizeResult?.autoSizingHeight\n ? `${this.autoSizeResult.height}px`\n : \"100%\",\n minHeight: this.loaderMinHeight || \"\",\n overflow: this.shouldAutoSize ? \"hidden\" : \"inherit\",\n };\n }\n\n get innerStyle(): { [key: string]: string } {\n return {\n position: \"absolute\",\n inset: \"0\",\n overflow: this.shouldAutoSize ? \"hidden\" : \"\",\n };\n }\n\n // Loader styles using SDK gradient\n get loaderStyle(): { [key: string]: string } {\n return {\n position: \"absolute\",\n top: \"0\",\n left: \"0\",\n right: \"0\",\n bottom: \"0\",\n zIndex: \"1\",\n background: LOADER_GRADIENT,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n opacity: String(this.loaderOpacity),\n transition: `opacity ${this.fadeDuration}ms ease-out`,\n };\n }\n\n // Fallback styles using SDK gradient (kept for backwards compatibility)\n get fallbackStyle(): { [key: string]: string } {\n return {\n position: \"absolute\",\n top: \"0\",\n left: \"0\",\n right: \"0\",\n bottom: \"0\",\n background: FALLBACK_GRADIENT,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n };\n }\n\n // Resolved loader template (input takes precedence over content projection)\n get resolvedLoader(): TemplateRef<any> | undefined {\n return this.loader || this.customLoader;\n }\n\n // Resolved fallback template (input takes precedence over content projection)\n get resolvedFallback(): TemplateRef<any> | undefined {\n return this.fallback || this.customFallback;\n }\n\n // Container style for loader (no background - let the template handle styling)\n get loaderContainerStyle(): { [key: string]: string } {\n return {\n position: \"absolute\",\n top: \"0\",\n left: \"0\",\n right: \"0\",\n bottom: \"0\",\n zIndex: \"1\",\n opacity: String(this.loaderOpacity),\n transition: `opacity ${this.fadeDuration}ms ease-out`,\n };\n }\n\n // Container style for fallback (no background - let the template handle styling)\n get fallbackContainerStyle(): { [key: string]: string } {\n return {\n position: \"absolute\",\n top: \"0\",\n left: \"0\",\n right: \"0\",\n bottom: \"0\",\n };\n }\n}\n","import {\n Component,\n ChangeDetectionStrategy,\n} from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\nimport { LOADER_GRADIENT } from \"@myop/sdk/host\";\n\n// Myop Logo SVG path\nconst MYOP_LOGO_PATH =\n \"M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z\";\n\n@Component({\n selector: \"myop-loader\",\n standalone: true,\n imports: [CommonModule],\n changeDetection: ChangeDetectionStrategy.OnPush,\n template: `\n <div [ngStyle]=\"loaderStyle\">\n <svg\n width=\"80\"\n viewBox=\"0 0 525 243\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path [attr.d]=\"logoPath\" fill=\"white\" />\n </svg>\n </div>\n `,\n})\nexport class MyopLoaderComponent {\n readonly logoPath = MYOP_LOGO_PATH;\n\n get loaderStyle(): { [key: string]: string } {\n return {\n position: \"absolute\",\n top: \"0\",\n left: \"0\",\n right: \"0\",\n bottom: \"0\",\n background: LOADER_GRADIENT,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n };\n }\n}\n","import {\n Component,\n ChangeDetectionStrategy,\n} from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\nimport { FALLBACK_GRADIENT } from \"@myop/sdk/host\";\n\n// Myop Logo SVG path\nconst MYOP_LOGO_PATH =\n \"M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z\";\n\n@Component({\n selector: \"myop-fallback\",\n standalone: true,\n imports: [CommonModule],\n changeDetection: ChangeDetectionStrategy.OnPush,\n template: `\n <div [ngStyle]=\"fallbackStyle\">\n <svg\n width=\"80\"\n viewBox=\"0 0 525 243\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path [attr.d]=\"logoPath\" fill=\"white\" />\n </svg>\n </div>\n `,\n})\nexport class MyopFallbackComponent {\n readonly logoPath = MYOP_LOGO_PATH;\n\n get fallbackStyle(): { [key: string]: string } {\n return {\n position: \"absolute\",\n top: \"0\",\n left: \"0\",\n right: \"0\",\n bottom: \"0\",\n background: FALLBACK_GRADIENT,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n };\n }\n}\n","/*\n * Public API Surface of @myop/angular\n */\n\n// Main component\nexport { MyopComponentV2 as MyopComponent } from \"./lib/myop.component\";\nexport type {\n IComponentInstanceConfig,\n SizeInfo,\n CtaEvent,\n IPropTypes,\n KebabToPascal,\n EventHandlerProps,\n IMyopComponentProps,\n ITypedMyopComponent,\n} from \"./lib/myop.component\";\n\n// Loader and Fallback components (for opt-in usage)\nexport { MyopLoaderComponent, MyopLoaderComponent as MyopLoader } from \"./lib/myop-loader.component\";\nexport { MyopFallbackComponent, MyopFallbackComponent as MyopFallback } from \"./lib/myop-fallback.component\";\n\n// Configuration utilities\nexport {\n getCloudRepository,\n isPreloaded,\n getPreloadedParams,\n enableLocalDev,\n setCloudRepositoryUrl,\n setCloudRepository,\n setEnvironment,\n preloadComponents,\n} from \"./config\";\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["MYOP_LOGO_PATH"],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class MyopFallbackComponent {
3
+ readonly logoPath = "M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z";
4
+ get fallbackStyle(): {
5
+ [key: string]: string;
6
+ };
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<MyopFallbackComponent, never>;
8
+ static ɵcmp: i0.ɵɵComponentDeclaration<MyopFallbackComponent, "myop-fallback", never, {}, {}, never, never, true, never>;
9
+ }
@@ -0,0 +1,9 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class MyopLoaderComponent {
3
+ readonly logoPath = "M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z";
4
+ get loaderStyle(): {
5
+ [key: string]: string;
6
+ };
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<MyopLoaderComponent, never>;
8
+ static ɵcmp: i0.ɵɵComponentDeclaration<MyopLoaderComponent, "myop-loader", never, {}, {}, never, never, true, never>;
9
+ }
@@ -0,0 +1,149 @@
1
+ import { ElementRef, EventEmitter, OnInit, OnChanges, OnDestroy, SimpleChanges, TemplateRef, ChangeDetectorRef, NgZone } from "@angular/core";
2
+ import { type IMyopComponent } from "@myop/sdk/host";
3
+ import * as i0 from "@angular/core";
4
+ export interface IComponentInstanceConfig {
5
+ id: string;
6
+ componentId: string;
7
+ componentName: string;
8
+ skinSelector: {
9
+ [key: string]: any;
10
+ };
11
+ nestedComponents?: IComponentInstanceConfig[];
12
+ resolvedExperiences?: {
13
+ [key: string]: any;
14
+ }[];
15
+ resolvedNestedComponents?: {
16
+ [key: string]: any;
17
+ }[];
18
+ [key: string]: any;
19
+ }
20
+ export interface SizeInfo {
21
+ width: number;
22
+ height: number;
23
+ autoSizingWidth: boolean;
24
+ autoSizingHeight: boolean;
25
+ }
26
+ export interface CtaEvent<TCtaPayloads extends Record<string, any> = Record<string, any>> {
27
+ action: keyof TCtaPayloads | string;
28
+ payload: TCtaPayloads[keyof TCtaPayloads] | any;
29
+ }
30
+ /**
31
+ * Converts kebab-case string to PascalCase
32
+ * e.g., 'column-reordered' -> 'ColumnReordered'
33
+ */
34
+ export type KebabToPascal<S extends string> = S extends `${infer First}-${infer Rest}` ? `${Capitalize<First>}${KebabToPascal<Rest>}` : Capitalize<S>;
35
+ /**
36
+ * Generates typed event handler props from CTA payloads.
37
+ * e.g., `{ 'row-clicked': { rowIndex: number } }` -> `{ onRowClicked?: (payload: { rowIndex: number }) => void }`
38
+ */
39
+ export type EventHandlerProps<TPayloads extends Record<string, any>> = string extends keyof TPayloads ? {} : {
40
+ [K in keyof TPayloads as `on${KebabToPascal<K & string>}`]?: (payload: TPayloads[K]) => void;
41
+ };
42
+ /**
43
+ * Type for the `on` callback prop.
44
+ */
45
+ type OnCallback<TPayloads extends Record<string, any>> = string extends keyof TPayloads ? (action: string, payload: any) => void : <K extends keyof TPayloads>(action: K, payload: TPayloads[K]) => void;
46
+ /**
47
+ * Typed props interface for accessing component.props with autocomplete.
48
+ * Contains myop_init_interface and myop_cta_handler with proper types.
49
+ */
50
+ export interface IMyopComponentProps<TData = any, TCtaPayloads extends Record<string, any> = Record<string, any>> {
51
+ /** Initialize the component with data */
52
+ myop_init_interface?: (data: TData) => void;
53
+ /** Handle CTA events from the component */
54
+ myop_cta_handler?: <K extends keyof TCtaPayloads>(action: K, payload: TCtaPayloads[K]) => void;
55
+ }
56
+ /**
57
+ * Typed Myop component interface with typed props.
58
+ * Use this type for the component returned in load event.
59
+ */
60
+ export type ITypedMyopComponent<TData = any, TCtaPayloads extends Record<string, any> = Record<string, any>> = Omit<IMyopComponent, 'props'> & {
61
+ /** Typed props for the component */
62
+ props: IMyopComponentProps<TData, TCtaPayloads> | null;
63
+ };
64
+ /**
65
+ * Base props interface for MyopComponent
66
+ */
67
+ interface IBaseProps<TData = any, TCtaPayloads extends Record<string, any> = Record<string, any>> {
68
+ componentId?: string;
69
+ componentConfig?: IComponentInstanceConfig;
70
+ data?: TData;
71
+ fadeDuration?: number;
72
+ autoSize?: boolean;
73
+ environment?: string;
74
+ preview?: boolean;
75
+ on?: OnCallback<TCtaPayloads>;
76
+ }
77
+ /**
78
+ * Full props type including generated event handlers.
79
+ * Supports both generic `on` callback and individual typed handlers like `onRowClicked`.
80
+ */
81
+ export type IPropTypes<TData = any, TCtaPayloads extends Record<string, any> = Record<string, any>> = IBaseProps<TData, TCtaPayloads> & EventHandlerProps<TCtaPayloads>;
82
+ export declare class MyopComponentV2<TData = any, TCtaPayloads extends Record<string, any> = Record<string, any>> implements OnInit, OnChanges, OnDestroy {
83
+ private cdr;
84
+ private ngZone;
85
+ componentId?: string;
86
+ componentConfig?: IComponentInstanceConfig;
87
+ data?: TData;
88
+ fadeDuration: number;
89
+ autoSize: boolean;
90
+ environment?: string;
91
+ preview?: boolean;
92
+ on?: (action: string, payload: any) => void;
93
+ load: EventEmitter<ITypedMyopComponent<TData, TCtaPayloads>>;
94
+ error: EventEmitter<string>;
95
+ sizeChange: EventEmitter<SizeInfo>;
96
+ cta: EventEmitter<CtaEvent<TCtaPayloads>>;
97
+ myopContainer: ElementRef<HTMLDivElement>;
98
+ customLoader?: TemplateRef<any>;
99
+ customFallback?: TemplateRef<any>;
100
+ loader?: TemplateRef<any>;
101
+ fallback?: TemplateRef<any>;
102
+ showLoader: boolean;
103
+ loaderOpacity: number;
104
+ showFallback: boolean;
105
+ isComponentLoaded: boolean;
106
+ autoSizeResult?: SizeInfo;
107
+ readonly logoPath = "M151.438 2.7168C177.625 2.76042 248.179 4.2832 300.4 56.7441C350.671 107.245 364.44 114.452 389.967 119.211C392.576 119.436 397.472 119.394 400.802 116.521C403.011 114.614 403.921 109.518 404.265 104.627V5.95996C404.265 4.85556 405.16 3.96023 406.265 3.95996H522.711C523.815 3.95996 524.711 4.85539 524.711 5.95996V122.405C524.711 123.51 523.815 124.405 522.711 124.405H421.998C418.579 124.728 413.852 125.627 410.974 128.095C407.879 130.748 407.042 137.805 406.845 142.661V240.414C406.845 241.436 406.111 242.292 405.093 242.38C366.548 245.717 277.079 228.462 235.837 173.668C202.909 129.919 173.882 122.474 151.458 122.077C150.354 122.058 149.459 121.164 149.459 120.06V4.71582C149.459 3.6114 150.334 2.71519 151.438 2.7168ZM62.2031 0C96.5566 0.000213148 124.405 27.8496 124.405 62.2031C124.405 96.5564 96.5564 124.405 62.2031 124.405C27.8496 124.405 0.000213175 96.5566 0 62.2031C0 27.8495 27.8495 0 62.2031 0Z";
108
+ private myopComponent;
109
+ private isLoading;
110
+ private pendingLoad;
111
+ private autoSizeCleanup;
112
+ private isCancelled;
113
+ constructor(cdr: ChangeDetectorRef, ngZone: NgZone);
114
+ ngOnInit(): void;
115
+ ngOnChanges(changes: SimpleChanges): void;
116
+ ngOnDestroy(): void;
117
+ private cleanup;
118
+ private reloadComponent;
119
+ private renderComponent;
120
+ private updateData;
121
+ private setupAutoSize;
122
+ private hideLoader;
123
+ private handleError;
124
+ get shouldAutoSize(): boolean;
125
+ get loaderMinHeight(): string | undefined;
126
+ get outerStyle(): {
127
+ [key: string]: string;
128
+ };
129
+ get innerStyle(): {
130
+ [key: string]: string;
131
+ };
132
+ get loaderStyle(): {
133
+ [key: string]: string;
134
+ };
135
+ get fallbackStyle(): {
136
+ [key: string]: string;
137
+ };
138
+ get resolvedLoader(): TemplateRef<any> | undefined;
139
+ get resolvedFallback(): TemplateRef<any> | undefined;
140
+ get loaderContainerStyle(): {
141
+ [key: string]: string;
142
+ };
143
+ get fallbackContainerStyle(): {
144
+ [key: string]: string;
145
+ };
146
+ static ɵfac: i0.ɵɵFactoryDeclaration<MyopComponentV2<any, any>, never>;
147
+ static ɵcmp: i0.ɵɵComponentDeclaration<MyopComponentV2<any, any>, "myop-component", never, { "componentId": { "alias": "componentId"; "required": false; }; "componentConfig": { "alias": "componentConfig"; "required": false; }; "data": { "alias": "data"; "required": false; }; "fadeDuration": { "alias": "fadeDuration"; "required": false; }; "autoSize": { "alias": "autoSize"; "required": false; }; "environment": { "alias": "environment"; "required": false; }; "preview": { "alias": "preview"; "required": false; }; "on": { "alias": "on"; "required": false; }; "loader": { "alias": "loader"; "required": false; }; "fallback": { "alias": "fallback"; "required": false; }; }, { "load": "load"; "error": "error"; "sizeChange": "sizeChange"; "cta": "cta"; }, ["customLoader", "customFallback"], never, true, never>;
148
+ }
149
+ export {};
package/package.json CHANGED
@@ -1,9 +1,10 @@
1
1
  {
2
2
  "name": "@myop/angular",
3
- "version": "0.0.27",
3
+ "version": "0.0.29",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^19.2.0",
6
- "@angular/core": "^19.2.0"
6
+ "@angular/core": "^19.2.0",
7
+ "@myop/sdk": "*"
7
8
  },
8
9
  "dependencies": {
9
10
  "tslib": "^2.3.0"
package/public-api.d.ts CHANGED
@@ -1 +1,5 @@
1
- export * from './lib/myop-container.component';
1
+ export { MyopComponentV2 as MyopComponent } from "./lib/myop.component";
2
+ export type { IComponentInstanceConfig, SizeInfo, CtaEvent, IPropTypes, KebabToPascal, EventHandlerProps, IMyopComponentProps, ITypedMyopComponent, } from "./lib/myop.component";
3
+ export { MyopLoaderComponent, MyopLoaderComponent as MyopLoader } from "./lib/myop-loader.component";
4
+ export { MyopFallbackComponent, MyopFallbackComponent as MyopFallback } from "./lib/myop-fallback.component";
5
+ export { getCloudRepository, isPreloaded, getPreloadedParams, enableLocalDev, setCloudRepositoryUrl, setCloudRepository, setEnvironment, preloadComponents, } from "./config";
@@ -1,26 +0,0 @@
1
- import { EnvironmentInjector, ElementRef, ViewContainerRef, ApplicationRef, Injector, SimpleChanges, OnChanges } from '@angular/core';
2
- import { IMyopComponent } from '@myop/sdk/host';
3
- import * as i0 from "@angular/core";
4
- export declare class MyopContainerComponent implements OnChanges {
5
- private injector;
6
- private elementRef;
7
- protected environmentInjector: EnvironmentInjector;
8
- myopContainer: import("@angular/core").Signal<ElementRef<HTMLDivElement> | undefined>;
9
- myopContainerRef: ViewContainerRef;
10
- _flowId: import("@angular/core").InputSignal<string | undefined>;
11
- flowId: import("@angular/core").WritableSignal<string | undefined>;
12
- _componentId: import("@angular/core").InputSignal<string>;
13
- componentId: import("@angular/core").WritableSignal<string>;
14
- _inputs: import("@angular/core").InputSignal<{
15
- [key: string]: any;
16
- }>;
17
- inputs: import("@angular/core").WritableSignal<{
18
- [key: string]: any;
19
- }>;
20
- componentReady: import("@angular/core").OutputEmitterRef<IMyopComponent<any, any>>;
21
- constructor(appRef: ApplicationRef, injector: Injector, elementRef: ElementRef);
22
- ngOnChanges(changes: SimpleChanges): void;
23
- ngAfterViewInit(): void;
24
- static ɵfac: i0.ɵɵFactoryDeclaration<MyopContainerComponent, never>;
25
- static ɵcmp: i0.ɵɵComponentDeclaration<MyopContainerComponent, "myop-container", never, { "_flowId": { "alias": "flowId"; "required": false; "isSignal": true; }; "_componentId": { "alias": "componentId"; "required": false; "isSignal": true; }; "_inputs": { "alias": "inputs"; "required": false; "isSignal": true; }; }, { "componentReady": "componentReady"; }, never, ["*", "[error]"], true, never>;
26
- }