@micropermit/client-angular 0.2.9-beta.2 → 0.2.9-beta.3

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.
@@ -2,7 +2,7 @@
2
2
  * @fileoverview added by tsickle
3
3
  * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
4
  */
5
- import { Directive, Input, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef, Output, EventEmitter } from '@angular/core';
5
+ import { Directive, Input, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef } from '@angular/core';
6
6
  import { LinkField } from '../links/linkfield';
7
7
  import { MicroClientLoadingIndicatorComponent } from '../components/loadingindicator.component';
8
8
  import { MicroClientErrorIndicatorComponent } from '../components/errorindicator.component';
@@ -28,7 +28,6 @@ export class LinkFieldDirective {
28
28
  this.hasResult = false;
29
29
  this.subscription = null;
30
30
  this.linkFieldDefaultErrorHandling = false;
31
- this.linkLoaded = new EventEmitter();
32
31
  this._defaultLoadingComponent = componentResolver.resolveComponentFactory(MicroClientLoadingIndicatorComponent);
33
32
  this._defaultErrorComponent = componentResolver.resolveComponentFactory(MicroClientErrorIndicatorComponent);
34
33
  }
@@ -78,7 +77,7 @@ export class LinkFieldDirective {
78
77
  if (this._from) {
79
78
  if (this._from instanceof LinkField) {
80
79
  this.setLoading(true);
81
- this.lastObs = this._from.getObs();
80
+ this.lastObs = this._from.listenObs();
82
81
  this.subscription = this.lastObs.pipe(finalize((/**
83
82
  * @return {?}
84
83
  */
@@ -90,7 +89,9 @@ export class LinkFieldDirective {
90
89
  */
91
90
  (loadedResult) => {
92
91
  this.setLoadedResult(loadedResult);
93
- this.linkLoaded.emit(loadedResult);
92
+ if (this.linkFieldValueChange) {
93
+ this.linkFieldValueChange(loadedResult);
94
+ }
94
95
  }), (/**
95
96
  * @param {?} loadError
96
97
  * @return {?}
@@ -170,15 +171,22 @@ export class LinkFieldDirective {
170
171
  setLoadedResult(result) {
171
172
  this.hasResult = true;
172
173
  this.loadedResult = result;
173
- if (this._viewContainer && this._template) {
174
- /** @type {?} */
175
- const currentContext = new LinkFieldContext(result);
176
- this._viewContainer.remove();
177
- this._viewContainer.createEmbeddedView(this._template, currentContext);
174
+ if (this.currentContext == null) {
175
+ this.currentContext = new LinkFieldContext(result);
176
+ this.isDirty = true;
178
177
  }
179
178
  else {
179
+ this.currentContext.$implicit = result;
180
+ }
181
+ if (!this._viewContainer || !this._template) {
180
182
  this.isDirty = true;
181
183
  }
184
+ else {
185
+ if (this.isDirty) {
186
+ this._viewContainer.remove();
187
+ this._viewContainer.createEmbeddedView(this._template, this.currentContext);
188
+ }
189
+ }
182
190
  }
183
191
  /**
184
192
  * @private
@@ -226,7 +234,7 @@ LinkFieldDirective.propDecorators = {
226
234
  linkFieldErrorTemplate: [{ type: Input }],
227
235
  linkFieldTemplate: [{ type: Input }],
228
236
  linkFieldDefaultErrorHandling: [{ type: Input }],
229
- linkLoaded: [{ type: Output }]
237
+ linkFieldValueChange: [{ type: Input }]
230
238
  };
231
239
  if (false) {
232
240
  /**
@@ -284,10 +292,15 @@ if (false) {
284
292
  * @private
285
293
  */
286
294
  LinkFieldDirective.prototype.subscription;
295
+ /**
296
+ * @type {?}
297
+ * @private
298
+ */
299
+ LinkFieldDirective.prototype.currentContext;
287
300
  /** @type {?} */
288
301
  LinkFieldDirective.prototype.linkFieldDefaultErrorHandling;
289
302
  /** @type {?} */
290
- LinkFieldDirective.prototype.linkLoaded;
303
+ LinkFieldDirective.prototype.linkFieldValueChange;
291
304
  /**
292
305
  * @type {?}
293
306
  * @private
@@ -324,4 +337,4 @@ if (false) {
324
337
  /** @type {?} */
325
338
  LinkFieldContext.prototype.$implicit;
326
339
  }
327
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linkfield.directive.js","sourceRoot":"ng://@micropermit/client-angular/","sources":["lib/directives/linkfield.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    Input,\n    TemplateRef,\n    ViewContainerRef,\n    ComponentFactoryResolver,\n    ComponentFactory,\n    DoCheck,\n    OnDestroy, ChangeDetectorRef, Output, EventEmitter\n} from '@angular/core';\nimport {LinkField} from '../links/linkfield';\nimport {MicroObject} from '../microobject';\nimport {Observable, Subscription} from 'rxjs';\nimport {MicroClientLoadingIndicatorComponent} from '../components/loadingindicator.component';\nimport {MicroClientErrorIndicatorComponent} from '../components/errorindicator.component';\nimport {finalize} from 'rxjs/operators';\nimport {MicroClientLoadError} from '../microclient.service';\n\n@Directive({\n    selector: '[linkField][linkFieldFrom]'\n})\nexport class LinkFieldDirective<T extends (object | object[])> implements DoCheck, OnDestroy {\n\n    private _from: LinkField<T> | T;\n    private _loadingTemplate: TemplateRef<any>;\n    private _errorTemplate: TemplateRef<any>;\n    private _defaultLoadingComponent: ComponentFactory<MicroClientLoadingIndicatorComponent>;\n    private _defaultErrorComponent: ComponentFactory<MicroClientErrorIndicatorComponent>;\n\n    private isDirty = true;\n    private isLoading = false;\n    private loadedResult: T = null;\n    private hasResult = false;\n\n    private lastObs: Observable<T>;\n    private subscription: Subscription = null;\n\n    constructor(\n        private _viewContainer: ViewContainerRef,\n        private _template: TemplateRef<LinkFieldContext<T>>,\n        private componentResolver: ComponentFactoryResolver,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {\n        this._defaultLoadingComponent = componentResolver.resolveComponentFactory(MicroClientLoadingIndicatorComponent);\n        this._defaultErrorComponent = componentResolver.resolveComponentFactory(MicroClientErrorIndicatorComponent);\n    }\n\n    @Input()\n    set linkFieldFrom(from: LinkField<T>) {\n        this._from = from;\n        this.clear();\n        this.load();\n    }\n\n    @Input()\n    set linkFieldLoadingTemplate(loadingTemplate: TemplateRef<any>) {\n        if (loadingTemplate) {\n            this._loadingTemplate = loadingTemplate;\n        }\n        this.updateIfDirty(true);\n    }\n\n    @Input()\n    set linkFieldErrorTemplate(errorTemplate: TemplateRef<any>) {\n        if (errorTemplate) {\n            this._errorTemplate = errorTemplate;\n        }\n        this.updateIfDirty(true);\n    }\n\n    @Input()\n    set linkFieldTemplate(value: TemplateRef<LinkFieldContext<T>>) {\n        if (value) {\n            this._template = value;\n        }\n    }\n\n    @Input()\n    linkFieldDefaultErrorHandling = false;\n\n    @Output()\n    linkLoaded = new EventEmitter<T>();\n\n    private load() {\n        if (this._from) {\n            if (this._from instanceof LinkField) {\n                this.setLoading(true);\n                this.lastObs = this._from.getObs();\n                this.subscription = this.lastObs.pipe(\n                    finalize(() => {\n                        this.setLoading(false);\n                    })\n                ).subscribe((loadedResult: T) => {\n                    this.setLoadedResult(loadedResult);\n                    this.linkLoaded.emit(loadedResult);\n                }, (loadError: MicroClientLoadError) => {\n                    if(!this.linkFieldDefaultErrorHandling){\n                        loadError.preventDefault();\n                    }\n                    this.setError(loadError);\n                });\n            } else {\n                this.setLoadedResult(this._from);\n                // this.setLoadedResult(this._from);\n                // throw new Error('Can\\'t use the linkField directive with a from value which isn\\'t an instance of LinkField');\n            }\n        }\n    }\n\n\n    ngDoCheck() {\n        this.updateIfDirty();\n        if (this._from) {\n            if (this._from instanceof LinkField && this.lastObs !== this._from.getObs()) {\n                this.load();\n            }\n        }\n    }\n\n    ngOnDestroy() {\n        this.clear();\n    }\n\n    private setError(error: MicroClientLoadError) {\n        this._viewContainer.remove();\n        if (this._errorTemplate) {\n            this._viewContainer.createEmbeddedView(this._errorTemplate, {\n                $implicit: error\n            });\n        } else {\n            let errorComponentInstance = this._viewContainer.createComponent(this._defaultErrorComponent);\n            errorComponentInstance.instance['error'] = error;\n        }\n    }\n\n\n    private setLoading(loading: boolean) {\n        this.isLoading = loading;\n        if (this.isLoading) {\n            if (this._loadingTemplate) {\n                this._viewContainer.remove();\n                this._viewContainer.createEmbeddedView(this._loadingTemplate);\n            } else {\n                this._viewContainer.remove();\n                this._viewContainer.createComponent(this._defaultLoadingComponent);\n            }\n        }\n    }\n\n    private setLoadedResult(result: T) {\n        this.hasResult = true;\n        this.loadedResult = result;\n        if (this._viewContainer && this._template) {\n            const currentContext = new LinkFieldContext(result);\n            this._viewContainer.remove();\n            this._viewContainer.createEmbeddedView(this._template, currentContext);\n        } else {\n            this.isDirty = true;\n        }\n\n    }\n\n    private updateIfDirty(ignoreDirty: boolean = false) {\n        if ((this.isDirty || ignoreDirty) && this._loadingTemplate && this._from && this._template && this._viewContainer) {\n            if (this.hasResult) {\n                this.setLoadedResult(this.loadedResult);\n            }\n            this.isDirty = false;\n        }\n    }\n\n    private clear() {\n        this.hasResult = false;\n        this.loadedResult = null;\n        this.isDirty = false;\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n            this.subscription = null;\n        }\n        this.lastObs = null;\n    }\n}\n\nexport class LinkFieldContext<T extends (object | object[])> {\n\n    constructor(public $implicit: T) {\n    }\n}\n"]}
340
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linkfield.directive.js","sourceRoot":"ng://@micropermit/client-angular/","sources":["lib/directives/linkfield.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    Input,\n    TemplateRef,\n    ViewContainerRef,\n    ComponentFactoryResolver,\n    ComponentFactory,\n    DoCheck,\n    OnDestroy, ChangeDetectorRef, Output, EventEmitter\n} from '@angular/core';\nimport {LinkField} from '../links/linkfield';\nimport {MicroObject} from '../microobject';\nimport {Observable, Subscription} from 'rxjs';\nimport {MicroClientLoadingIndicatorComponent} from '../components/loadingindicator.component';\nimport {MicroClientErrorIndicatorComponent} from '../components/errorindicator.component';\nimport {finalize} from 'rxjs/operators';\nimport {MicroClientLoadError} from '../microclient.service';\n\n@Directive({\n    selector: '[linkField][linkFieldFrom]'\n})\nexport class LinkFieldDirective<T> implements DoCheck, OnDestroy {\n\n    private _from: LinkField<T> | T;\n    private _loadingTemplate: TemplateRef<any>;\n    private _errorTemplate: TemplateRef<any>;\n    private _defaultLoadingComponent: ComponentFactory<MicroClientLoadingIndicatorComponent>;\n    private _defaultErrorComponent: ComponentFactory<MicroClientErrorIndicatorComponent>;\n\n    private isDirty = true;\n    private isLoading = false;\n    private loadedResult: T = null;\n    private hasResult = false;\n\n    private lastObs: Observable<T>;\n    private subscription: Subscription = null;\n\n    private currentContext: LinkFieldContext<T>;\n\n    constructor(\n        private _viewContainer: ViewContainerRef,\n        private _template: TemplateRef<LinkFieldContext<T>>,\n        private componentResolver: ComponentFactoryResolver,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {\n        this._defaultLoadingComponent = componentResolver.resolveComponentFactory(MicroClientLoadingIndicatorComponent);\n        this._defaultErrorComponent = componentResolver.resolveComponentFactory(MicroClientErrorIndicatorComponent);\n    }\n\n    @Input()\n    set linkFieldFrom(from: LinkField<T>) {\n        this._from = from;\n        this.clear();\n        this.load();\n    }\n\n    @Input()\n    set linkFieldLoadingTemplate(loadingTemplate: TemplateRef<any>) {\n        if (loadingTemplate) {\n            this._loadingTemplate = loadingTemplate;\n        }\n        this.updateIfDirty(true);\n    }\n\n    @Input()\n    set linkFieldErrorTemplate(errorTemplate: TemplateRef<any>) {\n        if (errorTemplate) {\n            this._errorTemplate = errorTemplate;\n        }\n        this.updateIfDirty(true);\n    }\n\n    @Input()\n    set linkFieldTemplate(value: TemplateRef<LinkFieldContext<T>>) {\n        if (value) {\n            this._template = value;\n        }\n    }\n\n    @Input()\n    linkFieldDefaultErrorHandling = false;\n\n    @Input()\n    linkFieldValueChange: (T) => void;\n\n    private load() {\n        if (this._from) {\n            if (this._from instanceof LinkField) {\n                this.setLoading(true);\n                this.lastObs = this._from.listenObs();\n                this.subscription = this.lastObs.pipe(\n                    finalize(() => {\n                        this.setLoading(false);\n                    })\n                ).subscribe((loadedResult: T) => {\n                    this.setLoadedResult(loadedResult);\n                    if (this.linkFieldValueChange) {\n                        this.linkFieldValueChange(loadedResult);\n                    }\n                }, (loadError: MicroClientLoadError) => {\n                    if (!this.linkFieldDefaultErrorHandling) {\n                        loadError.preventDefault();\n                    }\n                    this.setError(loadError);\n                });\n            } else {\n                this.setLoadedResult(this._from);\n                // this.setLoadedResult(this._from);\n                // throw new Error('Can\\'t use the linkField directive with a from value which isn\\'t an instance of LinkField');\n            }\n        }\n    }\n\n\n    ngDoCheck() {\n        this.updateIfDirty();\n        if (this._from) {\n            if (this._from instanceof LinkField && this.lastObs !== this._from.getObs()) {\n                this.load();\n            }\n        }\n    }\n\n    ngOnDestroy() {\n        this.clear();\n    }\n\n    private setError(error: MicroClientLoadError) {\n        this._viewContainer.remove();\n        if (this._errorTemplate) {\n            this._viewContainer.createEmbeddedView(this._errorTemplate, {\n                $implicit: error\n            });\n        } else {\n            let errorComponentInstance = this._viewContainer.createComponent(this._defaultErrorComponent);\n            errorComponentInstance.instance['error'] = error;\n        }\n    }\n\n\n    private setLoading(loading: boolean) {\n        this.isLoading = loading;\n        if (this.isLoading) {\n            if (this._loadingTemplate) {\n                this._viewContainer.remove();\n                this._viewContainer.createEmbeddedView(this._loadingTemplate);\n            } else {\n                this._viewContainer.remove();\n                this._viewContainer.createComponent(this._defaultLoadingComponent);\n            }\n        }\n    }\n\n    private setLoadedResult(result: T) {\n        this.hasResult = true;\n        this.loadedResult = result;\n        if (this.currentContext == null) {\n            this.currentContext = new LinkFieldContext<T>(result);\n            this.isDirty = true;\n        } else {\n            this.currentContext.$implicit = result;\n        }\n        if (!this._viewContainer || !this._template) {\n            this.isDirty = true;\n        } else {\n            if (this.isDirty) {\n                this._viewContainer.remove();\n                this._viewContainer.createEmbeddedView(this._template, this.currentContext);\n            }\n        }\n    }\n\n    private updateIfDirty(ignoreDirty: boolean = false) {\n        if ((this.isDirty || ignoreDirty) && this._loadingTemplate && this._from && this._template && this._viewContainer) {\n            if (this.hasResult) {\n                this.setLoadedResult(this.loadedResult);\n            }\n            this.isDirty = false;\n        }\n    }\n\n    private clear() {\n        this.hasResult = false;\n        this.loadedResult = null;\n        this.isDirty = false;\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n            this.subscription = null;\n        }\n        this.lastObs = null;\n    }\n}\n\nexport class LinkFieldContext<T> {\n\n    constructor(public $implicit: T) {\n    }\n}\n"]}
@@ -2,7 +2,7 @@
2
2
  * @fileoverview added by tsickle
3
3
  * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
4
  */
5
- import { Directive, Input, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef, Output, EventEmitter } from '@angular/core';
5
+ import { Directive, Input, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef } from '@angular/core';
6
6
  import { LinkField } from '../links/linkfield';
7
7
  import { MicroClientLoadingIndicatorComponent } from '../components/loadingindicator.component';
8
8
  import { MicroClientErrorIndicatorComponent } from '../components/errorindicator.component';
@@ -22,7 +22,6 @@ var LinkFieldDirective = /** @class */ (function () {
22
22
  this.hasResult = false;
23
23
  this.subscription = null;
24
24
  this.linkFieldDefaultErrorHandling = false;
25
- this.linkLoaded = new EventEmitter();
26
25
  this._defaultLoadingComponent = componentResolver.resolveComponentFactory(MicroClientLoadingIndicatorComponent);
27
26
  this._defaultErrorComponent = componentResolver.resolveComponentFactory(MicroClientErrorIndicatorComponent);
28
27
  }
@@ -93,7 +92,7 @@ var LinkFieldDirective = /** @class */ (function () {
93
92
  if (this._from) {
94
93
  if (this._from instanceof LinkField) {
95
94
  this.setLoading(true);
96
- this.lastObs = this._from.getObs();
95
+ this.lastObs = this._from.listenObs();
97
96
  this.subscription = this.lastObs.pipe(finalize((/**
98
97
  * @return {?}
99
98
  */
@@ -105,7 +104,9 @@ var LinkFieldDirective = /** @class */ (function () {
105
104
  */
106
105
  function (loadedResult) {
107
106
  _this.setLoadedResult(loadedResult);
108
- _this.linkLoaded.emit(loadedResult);
107
+ if (_this.linkFieldValueChange) {
108
+ _this.linkFieldValueChange(loadedResult);
109
+ }
109
110
  }), (/**
110
111
  * @param {?} loadError
111
112
  * @return {?}
@@ -206,15 +207,22 @@ var LinkFieldDirective = /** @class */ (function () {
206
207
  function (result) {
207
208
  this.hasResult = true;
208
209
  this.loadedResult = result;
209
- if (this._viewContainer && this._template) {
210
- /** @type {?} */
211
- var currentContext = new LinkFieldContext(result);
212
- this._viewContainer.remove();
213
- this._viewContainer.createEmbeddedView(this._template, currentContext);
210
+ if (this.currentContext == null) {
211
+ this.currentContext = new LinkFieldContext(result);
212
+ this.isDirty = true;
214
213
  }
215
214
  else {
215
+ this.currentContext.$implicit = result;
216
+ }
217
+ if (!this._viewContainer || !this._template) {
216
218
  this.isDirty = true;
217
219
  }
220
+ else {
221
+ if (this.isDirty) {
222
+ this._viewContainer.remove();
223
+ this._viewContainer.createEmbeddedView(this._template, this.currentContext);
224
+ }
225
+ }
218
226
  };
219
227
  /**
220
228
  * @private
@@ -271,7 +279,7 @@ var LinkFieldDirective = /** @class */ (function () {
271
279
  linkFieldErrorTemplate: [{ type: Input }],
272
280
  linkFieldTemplate: [{ type: Input }],
273
281
  linkFieldDefaultErrorHandling: [{ type: Input }],
274
- linkLoaded: [{ type: Output }]
282
+ linkFieldValueChange: [{ type: Input }]
275
283
  };
276
284
  return LinkFieldDirective;
277
285
  }());
@@ -332,10 +340,15 @@ if (false) {
332
340
  * @private
333
341
  */
334
342
  LinkFieldDirective.prototype.subscription;
343
+ /**
344
+ * @type {?}
345
+ * @private
346
+ */
347
+ LinkFieldDirective.prototype.currentContext;
335
348
  /** @type {?} */
336
349
  LinkFieldDirective.prototype.linkFieldDefaultErrorHandling;
337
350
  /** @type {?} */
338
- LinkFieldDirective.prototype.linkLoaded;
351
+ LinkFieldDirective.prototype.linkFieldValueChange;
339
352
  /**
340
353
  * @type {?}
341
354
  * @private
@@ -377,4 +390,4 @@ if (false) {
377
390
  /** @type {?} */
378
391
  LinkFieldContext.prototype.$implicit;
379
392
  }
380
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linkfield.directive.js","sourceRoot":"ng://@micropermit/client-angular/","sources":["lib/directives/linkfield.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    Input,\n    TemplateRef,\n    ViewContainerRef,\n    ComponentFactoryResolver,\n    ComponentFactory,\n    DoCheck,\n    OnDestroy, ChangeDetectorRef, Output, EventEmitter\n} from '@angular/core';\nimport {LinkField} from '../links/linkfield';\nimport {MicroObject} from '../microobject';\nimport {Observable, Subscription} from 'rxjs';\nimport {MicroClientLoadingIndicatorComponent} from '../components/loadingindicator.component';\nimport {MicroClientErrorIndicatorComponent} from '../components/errorindicator.component';\nimport {finalize} from 'rxjs/operators';\nimport {MicroClientLoadError} from '../microclient.service';\n\n@Directive({\n    selector: '[linkField][linkFieldFrom]'\n})\nexport class LinkFieldDirective<T extends (object | object[])> implements DoCheck, OnDestroy {\n\n    private _from: LinkField<T> | T;\n    private _loadingTemplate: TemplateRef<any>;\n    private _errorTemplate: TemplateRef<any>;\n    private _defaultLoadingComponent: ComponentFactory<MicroClientLoadingIndicatorComponent>;\n    private _defaultErrorComponent: ComponentFactory<MicroClientErrorIndicatorComponent>;\n\n    private isDirty = true;\n    private isLoading = false;\n    private loadedResult: T = null;\n    private hasResult = false;\n\n    private lastObs: Observable<T>;\n    private subscription: Subscription = null;\n\n    constructor(\n        private _viewContainer: ViewContainerRef,\n        private _template: TemplateRef<LinkFieldContext<T>>,\n        private componentResolver: ComponentFactoryResolver,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {\n        this._defaultLoadingComponent = componentResolver.resolveComponentFactory(MicroClientLoadingIndicatorComponent);\n        this._defaultErrorComponent = componentResolver.resolveComponentFactory(MicroClientErrorIndicatorComponent);\n    }\n\n    @Input()\n    set linkFieldFrom(from: LinkField<T>) {\n        this._from = from;\n        this.clear();\n        this.load();\n    }\n\n    @Input()\n    set linkFieldLoadingTemplate(loadingTemplate: TemplateRef<any>) {\n        if (loadingTemplate) {\n            this._loadingTemplate = loadingTemplate;\n        }\n        this.updateIfDirty(true);\n    }\n\n    @Input()\n    set linkFieldErrorTemplate(errorTemplate: TemplateRef<any>) {\n        if (errorTemplate) {\n            this._errorTemplate = errorTemplate;\n        }\n        this.updateIfDirty(true);\n    }\n\n    @Input()\n    set linkFieldTemplate(value: TemplateRef<LinkFieldContext<T>>) {\n        if (value) {\n            this._template = value;\n        }\n    }\n\n    @Input()\n    linkFieldDefaultErrorHandling = false;\n\n    @Output()\n    linkLoaded = new EventEmitter<T>();\n\n    private load() {\n        if (this._from) {\n            if (this._from instanceof LinkField) {\n                this.setLoading(true);\n                this.lastObs = this._from.getObs();\n                this.subscription = this.lastObs.pipe(\n                    finalize(() => {\n                        this.setLoading(false);\n                    })\n                ).subscribe((loadedResult: T) => {\n                    this.setLoadedResult(loadedResult);\n                    this.linkLoaded.emit(loadedResult);\n                }, (loadError: MicroClientLoadError) => {\n                    if(!this.linkFieldDefaultErrorHandling){\n                        loadError.preventDefault();\n                    }\n                    this.setError(loadError);\n                });\n            } else {\n                this.setLoadedResult(this._from);\n                // this.setLoadedResult(this._from);\n                // throw new Error('Can\\'t use the linkField directive with a from value which isn\\'t an instance of LinkField');\n            }\n        }\n    }\n\n\n    ngDoCheck() {\n        this.updateIfDirty();\n        if (this._from) {\n            if (this._from instanceof LinkField && this.lastObs !== this._from.getObs()) {\n                this.load();\n            }\n        }\n    }\n\n    ngOnDestroy() {\n        this.clear();\n    }\n\n    private setError(error: MicroClientLoadError) {\n        this._viewContainer.remove();\n        if (this._errorTemplate) {\n            this._viewContainer.createEmbeddedView(this._errorTemplate, {\n                $implicit: error\n            });\n        } else {\n            let errorComponentInstance = this._viewContainer.createComponent(this._defaultErrorComponent);\n            errorComponentInstance.instance['error'] = error;\n        }\n    }\n\n\n    private setLoading(loading: boolean) {\n        this.isLoading = loading;\n        if (this.isLoading) {\n            if (this._loadingTemplate) {\n                this._viewContainer.remove();\n                this._viewContainer.createEmbeddedView(this._loadingTemplate);\n            } else {\n                this._viewContainer.remove();\n                this._viewContainer.createComponent(this._defaultLoadingComponent);\n            }\n        }\n    }\n\n    private setLoadedResult(result: T) {\n        this.hasResult = true;\n        this.loadedResult = result;\n        if (this._viewContainer && this._template) {\n            const currentContext = new LinkFieldContext(result);\n            this._viewContainer.remove();\n            this._viewContainer.createEmbeddedView(this._template, currentContext);\n        } else {\n            this.isDirty = true;\n        }\n\n    }\n\n    private updateIfDirty(ignoreDirty: boolean = false) {\n        if ((this.isDirty || ignoreDirty) && this._loadingTemplate && this._from && this._template && this._viewContainer) {\n            if (this.hasResult) {\n                this.setLoadedResult(this.loadedResult);\n            }\n            this.isDirty = false;\n        }\n    }\n\n    private clear() {\n        this.hasResult = false;\n        this.loadedResult = null;\n        this.isDirty = false;\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n            this.subscription = null;\n        }\n        this.lastObs = null;\n    }\n}\n\nexport class LinkFieldContext<T extends (object | object[])> {\n\n    constructor(public $implicit: T) {\n    }\n}\n"]}
393
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linkfield.directive.js","sourceRoot":"ng://@micropermit/client-angular/","sources":["lib/directives/linkfield.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    Input,\n    TemplateRef,\n    ViewContainerRef,\n    ComponentFactoryResolver,\n    ComponentFactory,\n    DoCheck,\n    OnDestroy, ChangeDetectorRef, Output, EventEmitter\n} from '@angular/core';\nimport {LinkField} from '../links/linkfield';\nimport {MicroObject} from '../microobject';\nimport {Observable, Subscription} from 'rxjs';\nimport {MicroClientLoadingIndicatorComponent} from '../components/loadingindicator.component';\nimport {MicroClientErrorIndicatorComponent} from '../components/errorindicator.component';\nimport {finalize} from 'rxjs/operators';\nimport {MicroClientLoadError} from '../microclient.service';\n\n@Directive({\n    selector: '[linkField][linkFieldFrom]'\n})\nexport class LinkFieldDirective<T> implements DoCheck, OnDestroy {\n\n    private _from: LinkField<T> | T;\n    private _loadingTemplate: TemplateRef<any>;\n    private _errorTemplate: TemplateRef<any>;\n    private _defaultLoadingComponent: ComponentFactory<MicroClientLoadingIndicatorComponent>;\n    private _defaultErrorComponent: ComponentFactory<MicroClientErrorIndicatorComponent>;\n\n    private isDirty = true;\n    private isLoading = false;\n    private loadedResult: T = null;\n    private hasResult = false;\n\n    private lastObs: Observable<T>;\n    private subscription: Subscription = null;\n\n    private currentContext: LinkFieldContext<T>;\n\n    constructor(\n        private _viewContainer: ViewContainerRef,\n        private _template: TemplateRef<LinkFieldContext<T>>,\n        private componentResolver: ComponentFactoryResolver,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {\n        this._defaultLoadingComponent = componentResolver.resolveComponentFactory(MicroClientLoadingIndicatorComponent);\n        this._defaultErrorComponent = componentResolver.resolveComponentFactory(MicroClientErrorIndicatorComponent);\n    }\n\n    @Input()\n    set linkFieldFrom(from: LinkField<T>) {\n        this._from = from;\n        this.clear();\n        this.load();\n    }\n\n    @Input()\n    set linkFieldLoadingTemplate(loadingTemplate: TemplateRef<any>) {\n        if (loadingTemplate) {\n            this._loadingTemplate = loadingTemplate;\n        }\n        this.updateIfDirty(true);\n    }\n\n    @Input()\n    set linkFieldErrorTemplate(errorTemplate: TemplateRef<any>) {\n        if (errorTemplate) {\n            this._errorTemplate = errorTemplate;\n        }\n        this.updateIfDirty(true);\n    }\n\n    @Input()\n    set linkFieldTemplate(value: TemplateRef<LinkFieldContext<T>>) {\n        if (value) {\n            this._template = value;\n        }\n    }\n\n    @Input()\n    linkFieldDefaultErrorHandling = false;\n\n    @Input()\n    linkFieldValueChange: (T) => void;\n\n    private load() {\n        if (this._from) {\n            if (this._from instanceof LinkField) {\n                this.setLoading(true);\n                this.lastObs = this._from.listenObs();\n                this.subscription = this.lastObs.pipe(\n                    finalize(() => {\n                        this.setLoading(false);\n                    })\n                ).subscribe((loadedResult: T) => {\n                    this.setLoadedResult(loadedResult);\n                    if (this.linkFieldValueChange) {\n                        this.linkFieldValueChange(loadedResult);\n                    }\n                }, (loadError: MicroClientLoadError) => {\n                    if (!this.linkFieldDefaultErrorHandling) {\n                        loadError.preventDefault();\n                    }\n                    this.setError(loadError);\n                });\n            } else {\n                this.setLoadedResult(this._from);\n                // this.setLoadedResult(this._from);\n                // throw new Error('Can\\'t use the linkField directive with a from value which isn\\'t an instance of LinkField');\n            }\n        }\n    }\n\n\n    ngDoCheck() {\n        this.updateIfDirty();\n        if (this._from) {\n            if (this._from instanceof LinkField && this.lastObs !== this._from.getObs()) {\n                this.load();\n            }\n        }\n    }\n\n    ngOnDestroy() {\n        this.clear();\n    }\n\n    private setError(error: MicroClientLoadError) {\n        this._viewContainer.remove();\n        if (this._errorTemplate) {\n            this._viewContainer.createEmbeddedView(this._errorTemplate, {\n                $implicit: error\n            });\n        } else {\n            let errorComponentInstance = this._viewContainer.createComponent(this._defaultErrorComponent);\n            errorComponentInstance.instance['error'] = error;\n        }\n    }\n\n\n    private setLoading(loading: boolean) {\n        this.isLoading = loading;\n        if (this.isLoading) {\n            if (this._loadingTemplate) {\n                this._viewContainer.remove();\n                this._viewContainer.createEmbeddedView(this._loadingTemplate);\n            } else {\n                this._viewContainer.remove();\n                this._viewContainer.createComponent(this._defaultLoadingComponent);\n            }\n        }\n    }\n\n    private setLoadedResult(result: T) {\n        this.hasResult = true;\n        this.loadedResult = result;\n        if (this.currentContext == null) {\n            this.currentContext = new LinkFieldContext<T>(result);\n            this.isDirty = true;\n        } else {\n            this.currentContext.$implicit = result;\n        }\n        if (!this._viewContainer || !this._template) {\n            this.isDirty = true;\n        } else {\n            if (this.isDirty) {\n                this._viewContainer.remove();\n                this._viewContainer.createEmbeddedView(this._template, this.currentContext);\n            }\n        }\n    }\n\n    private updateIfDirty(ignoreDirty: boolean = false) {\n        if ((this.isDirty || ignoreDirty) && this._loadingTemplate && this._from && this._template && this._viewContainer) {\n            if (this.hasResult) {\n                this.setLoadedResult(this.loadedResult);\n            }\n            this.isDirty = false;\n        }\n    }\n\n    private clear() {\n        this.hasResult = false;\n        this.loadedResult = null;\n        this.isDirty = false;\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n            this.subscription = null;\n        }\n        this.lastObs = null;\n    }\n}\n\nexport class LinkFieldContext<T> {\n\n    constructor(public $implicit: T) {\n    }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Injectable, Component, Pipe, ChangeDetectorRef, Input, EventEmitter, Directive, ViewContainerRef, TemplateRef, ComponentFactoryResolver, Output, HostListener, forwardRef, NgModule } from '@angular/core';
1
+ import { Injectable, Component, Pipe, ChangeDetectorRef, Input, Directive, ViewContainerRef, TemplateRef, ComponentFactoryResolver, EventEmitter, Output, HostListener, forwardRef, NgModule } from '@angular/core';
2
2
  import { HttpHeaders, HttpClient, HttpClientModule } from '@angular/common/http';
3
3
  import { ReplaySubject, defer, throwError, timer, of } from 'rxjs';
4
4
  import { take, map, catchError, finalize, switchMap, delay } from 'rxjs/operators';
@@ -1577,7 +1577,6 @@ class LinkFieldDirective {
1577
1577
  this.hasResult = false;
1578
1578
  this.subscription = null;
1579
1579
  this.linkFieldDefaultErrorHandling = false;
1580
- this.linkLoaded = new EventEmitter();
1581
1580
  this._defaultLoadingComponent = componentResolver.resolveComponentFactory(MicroClientLoadingIndicatorComponent);
1582
1581
  this._defaultErrorComponent = componentResolver.resolveComponentFactory(MicroClientErrorIndicatorComponent);
1583
1582
  }
@@ -1627,7 +1626,7 @@ class LinkFieldDirective {
1627
1626
  if (this._from) {
1628
1627
  if (this._from instanceof LinkField) {
1629
1628
  this.setLoading(true);
1630
- this.lastObs = this._from.getObs();
1629
+ this.lastObs = this._from.listenObs();
1631
1630
  this.subscription = this.lastObs.pipe(finalize((/**
1632
1631
  * @return {?}
1633
1632
  */
@@ -1639,7 +1638,9 @@ class LinkFieldDirective {
1639
1638
  */
1640
1639
  (loadedResult) => {
1641
1640
  this.setLoadedResult(loadedResult);
1642
- this.linkLoaded.emit(loadedResult);
1641
+ if (this.linkFieldValueChange) {
1642
+ this.linkFieldValueChange(loadedResult);
1643
+ }
1643
1644
  }), (/**
1644
1645
  * @param {?} loadError
1645
1646
  * @return {?}
@@ -1719,15 +1720,22 @@ class LinkFieldDirective {
1719
1720
  setLoadedResult(result) {
1720
1721
  this.hasResult = true;
1721
1722
  this.loadedResult = result;
1722
- if (this._viewContainer && this._template) {
1723
- /** @type {?} */
1724
- const currentContext = new LinkFieldContext(result);
1725
- this._viewContainer.remove();
1726
- this._viewContainer.createEmbeddedView(this._template, currentContext);
1723
+ if (this.currentContext == null) {
1724
+ this.currentContext = new LinkFieldContext(result);
1725
+ this.isDirty = true;
1727
1726
  }
1728
1727
  else {
1728
+ this.currentContext.$implicit = result;
1729
+ }
1730
+ if (!this._viewContainer || !this._template) {
1729
1731
  this.isDirty = true;
1730
1732
  }
1733
+ else {
1734
+ if (this.isDirty) {
1735
+ this._viewContainer.remove();
1736
+ this._viewContainer.createEmbeddedView(this._template, this.currentContext);
1737
+ }
1738
+ }
1731
1739
  }
1732
1740
  /**
1733
1741
  * @private
@@ -1775,7 +1783,7 @@ LinkFieldDirective.propDecorators = {
1775
1783
  linkFieldErrorTemplate: [{ type: Input }],
1776
1784
  linkFieldTemplate: [{ type: Input }],
1777
1785
  linkFieldDefaultErrorHandling: [{ type: Input }],
1778
- linkLoaded: [{ type: Output }]
1786
+ linkFieldValueChange: [{ type: Input }]
1779
1787
  };
1780
1788
  if (false) {
1781
1789
  /**
@@ -1833,10 +1841,15 @@ if (false) {
1833
1841
  * @private
1834
1842
  */
1835
1843
  LinkFieldDirective.prototype.subscription;
1844
+ /**
1845
+ * @type {?}
1846
+ * @private
1847
+ */
1848
+ LinkFieldDirective.prototype.currentContext;
1836
1849
  /** @type {?} */
1837
1850
  LinkFieldDirective.prototype.linkFieldDefaultErrorHandling;
1838
1851
  /** @type {?} */
1839
- LinkFieldDirective.prototype.linkLoaded;
1852
+ LinkFieldDirective.prototype.linkFieldValueChange;
1840
1853
  /**
1841
1854
  * @type {?}
1842
1855
  * @private