@dereekb/dbx-core 2.1.0 → 3.0.0
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/esm2020/lib/action/action.handler.mjs +3 -125
- package/esm2020/lib/action/action.machine.mjs +8 -7
- package/esm2020/lib/action/action.module.mjs +10 -10
- package/esm2020/lib/action/action.store.mjs +3 -3
- package/esm2020/lib/action/action.store.source.mjs +3 -3
- package/esm2020/lib/action/directive/auto/action.automodify.directive.mjs +4 -4
- package/esm2020/lib/action/directive/auto/action.autotrigger.directive.mjs +7 -6
- package/esm2020/lib/action/directive/context/action.directive.mjs +3 -3
- package/esm2020/lib/action/directive/context/action.source.directive.mjs +3 -3
- package/esm2020/lib/action/directive/debug/action.logger.directive.mjs +3 -3
- package/esm2020/lib/action/directive/map/action.map.directive.mjs +3 -3
- package/esm2020/lib/action/directive/map/action.map.key.directive.mjs +3 -3
- package/esm2020/lib/action/directive/map/action.map.source.directive.mjs +3 -3
- package/esm2020/lib/action/directive/map/action.map.working.disable.directive.mjs +3 -3
- package/esm2020/lib/action/directive/state/action.disabled.directive.mjs +5 -6
- package/esm2020/lib/action/directive/state/action.enforce.modified.directive.mjs +6 -6
- package/esm2020/lib/action/directive/state/action.handler.directive.mjs +10 -9
- package/esm2020/lib/action/directive/state/action.success.directive.mjs +23 -35
- package/esm2020/lib/action/directive/state/action.success.handler.directive.mjs +48 -0
- package/esm2020/lib/action/directive/state/action.value.directive.mjs +8 -8
- package/esm2020/lib/action/directive/state/action.value.stream.directive.mjs +3 -3
- package/esm2020/lib/action/directive/state/action.value.trigger.directive.mjs +6 -6
- package/esm2020/lib/action/directive/state/action.value.trigger.instance.mjs +2 -1
- package/esm2020/lib/action/directive/state/action.working.component.mjs +28 -22
- package/esm2020/lib/action/directive/state/index.mjs +2 -2
- package/esm2020/lib/auth/auth.module.mjs +26 -0
- package/esm2020/lib/auth/auth.role.any.directive.mjs +36 -0
- package/esm2020/lib/auth/auth.role.has.directive.mjs +36 -0
- package/esm2020/lib/auth/auth.state.module.mjs +28 -0
- package/esm2020/lib/auth/auth.state.service.mjs +23 -0
- package/esm2020/lib/auth/auth.user.mjs +11 -0
- package/esm2020/lib/auth/index.mjs +10 -0
- package/esm2020/lib/auth/router/auth.router.mjs +6 -0
- package/esm2020/lib/auth/router/auth.router.module.mjs +26 -0
- package/esm2020/lib/auth/router/auth.router.service.mjs +61 -0
- package/esm2020/lib/auth/router/index.mjs +6 -0
- package/esm2020/lib/auth/router/provider/uirouter/auth.hook.mjs +23 -0
- package/esm2020/lib/auth/router/provider/uirouter/hook.mjs +65 -0
- package/esm2020/lib/auth/router/provider/uirouter/index.mjs +6 -0
- package/esm2020/lib/auth/router/provider/uirouter/redirect.mjs +29 -0
- package/esm2020/lib/auth/router/provider/uirouter/role.hook.mjs +32 -0
- package/esm2020/lib/auth/router/provider/uirouter/state.hook.mjs +53 -0
- package/esm2020/lib/auth/router/state/auth.router.state.module.mjs +32 -0
- package/esm2020/lib/auth/router/state/effect/auth.router.state.effect.mjs +46 -0
- package/esm2020/lib/auth/router/state/effect/index.mjs +2 -0
- package/esm2020/lib/auth/router/state/index.mjs +3 -0
- package/esm2020/lib/auth/service/auth.service.mjs +6 -0
- package/esm2020/lib/auth/service/auth.service.rxjs.mjs +27 -0
- package/esm2020/lib/auth/service/index.mjs +3 -0
- package/esm2020/lib/auth/state/action/auth.action.mjs +14 -0
- package/esm2020/lib/auth/state/action/index.mjs +12 -0
- package/esm2020/lib/auth/state/action/user.action.mjs +18 -0
- package/esm2020/lib/auth/state/effect/auth.effect.mjs +44 -0
- package/esm2020/lib/auth/state/index.mjs +13 -0
- package/esm2020/lib/auth/state/reducer/index.mjs +23 -0
- package/esm2020/lib/auth/state/reducer/user.reducer.mjs +12 -0
- package/esm2020/lib/auth/state/state.mjs +2 -0
- package/esm2020/lib/button/action/action.button.directive.mjs +3 -3
- package/esm2020/lib/button/action/action.button.trigger.directive.mjs +3 -3
- package/esm2020/lib/button/button.directive.mjs +6 -6
- package/esm2020/lib/button/button.loading.directive.mjs +3 -3
- package/esm2020/lib/button/button.mjs +1 -1
- package/esm2020/lib/button/button.module.mjs +4 -4
- package/esm2020/lib/button/router/button.segue.directive.mjs +8 -4
- package/esm2020/lib/context/context.directive.mjs +41 -0
- package/esm2020/lib/context/context.mjs +22 -0
- package/esm2020/lib/context/context.module.mjs +28 -0
- package/esm2020/lib/context/context.service.mjs +29 -0
- package/esm2020/lib/context/index.mjs +6 -0
- package/esm2020/lib/context/state/action/data.action.mjs +10 -0
- package/esm2020/lib/context/state/action/index.mjs +7 -0
- package/esm2020/lib/context/state/effect/index.mjs +38 -0
- package/esm2020/lib/context/state/index.mjs +13 -0
- package/esm2020/lib/context/state/reducer/data.reducer.mjs +16 -0
- package/esm2020/lib/context/state/reducer/index.mjs +25 -0
- package/esm2020/lib/context/state/state.mjs +2 -0
- package/esm2020/lib/filter/action/action.filter.source.directive.mjs +3 -3
- package/esm2020/lib/filter/filter.abstract.connector.directive.mjs +3 -3
- package/esm2020/lib/filter/filter.abstract.source.directive.mjs +4 -4
- package/esm2020/lib/filter/filter.connector.directive.mjs +3 -3
- package/esm2020/lib/filter/filter.map.connector.directive.mjs +3 -3
- package/esm2020/lib/filter/filter.map.directive.mjs +3 -3
- package/esm2020/lib/filter/filter.map.instance.directive.mjs +3 -3
- package/esm2020/lib/filter/filter.map.source.directive.mjs +3 -3
- package/esm2020/lib/filter/filter.module.mjs +4 -4
- package/esm2020/lib/filter/filter.source.directive.mjs +3 -3
- package/esm2020/lib/index.mjs +6 -2
- package/esm2020/lib/injection/index.mjs +9 -0
- package/esm2020/lib/injection/injection.component.mjs +34 -0
- package/esm2020/lib/injection/injection.component.module.mjs +31 -0
- package/esm2020/lib/injection/injection.context.directive.mjs +124 -0
- package/esm2020/lib/injection/injection.context.forward.directive.mjs +30 -0
- package/esm2020/lib/injection/injection.context.mjs +18 -0
- package/esm2020/lib/injection/injection.directive.mjs +33 -0
- package/esm2020/lib/injection/injection.instance.mjs +116 -0
- package/esm2020/lib/injection/injection.mjs +16 -0
- package/esm2020/lib/ngrx/index.mjs +2 -0
- package/esm2020/lib/ngrx/store.lockset.mjs +64 -0
- package/esm2020/lib/pipe/date/date.pipe.module.mjs +4 -4
- package/esm2020/lib/pipe/date/datedistance.pipe.mjs +3 -3
- package/esm2020/lib/pipe/date/dateformatdistance.pipe.mjs +3 -3
- package/esm2020/lib/pipe/date/datefromtoformat.pipe.mjs +3 -3
- package/esm2020/lib/pipe/date/minutesstring.pipe.mjs +3 -3
- package/esm2020/lib/pipe/date/timedistance.pipe.mjs +6 -6
- package/esm2020/lib/pipe/date/tojsdate.pipe.mjs +13 -5
- package/esm2020/lib/pipe/date/tominutes.pipe.mjs +3 -3
- package/esm2020/lib/pipe/index.mjs +3 -1
- package/esm2020/lib/pipe/misc/index.mjs +3 -0
- package/esm2020/lib/pipe/misc/misc.pipe.module.mjs +20 -0
- package/esm2020/lib/pipe/misc/prettyjson.pipe.mjs +27 -0
- package/esm2020/lib/pipe/pipe.module.mjs +21 -0
- package/esm2020/lib/router/anchor/anchor.directive.mjs +18 -5
- package/esm2020/lib/router/anchor/anchor.mjs +1 -1
- package/esm2020/lib/router/router/provider/angular/angular.router.service.mjs +8 -5
- package/esm2020/lib/router/router/provider/angular/angular.router.service.module.mjs +4 -4
- package/esm2020/lib/router/router/provider/uirouter/uirouter.router.service.mjs +32 -10
- package/esm2020/lib/router/router/provider/uirouter/uirouter.router.service.module.mjs +4 -4
- package/esm2020/lib/router/router/service/index.mjs +2 -1
- package/esm2020/lib/router/router/service/router.go.mjs +14 -0
- package/esm2020/lib/router/router/service/router.service.mjs +1 -1
- package/esm2020/lib/router/router/transition/transition.directive.mjs +7 -7
- package/esm2020/lib/router/router/transition/transition.watcher.directive.mjs +6 -6
- package/esm2020/lib/router/segue.mjs +17 -2
- package/esm2020/lib/storage/storage.accessor.simple.factory.mjs +3 -3
- package/esm2020/lib/storage/storage.module.mjs +4 -4
- package/esm2020/lib/subscription/subscription.directive.mjs +6 -6
- package/esm2020/lib/util/view.mjs +18 -2
- package/esm2020/lib/view/if.directive.mjs +30 -0
- package/esm2020/lib/view/index.mjs +2 -0
- package/fesm2015/dereekb-dbx-core.mjs +1672 -575
- package/fesm2015/dereekb-dbx-core.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-core.mjs +1682 -585
- package/fesm2020/dereekb-dbx-core.mjs.map +1 -1
- package/lib/action/action.handler.d.ts +4 -72
- package/lib/action/action.module.d.ts +3 -3
- package/lib/action/directive/auto/action.automodify.directive.d.ts +1 -1
- package/lib/action/directive/auto/action.autotrigger.directive.d.ts +3 -3
- package/lib/action/directive/state/action.disabled.directive.d.ts +1 -1
- package/lib/action/directive/state/action.enforce.modified.directive.d.ts +3 -2
- package/lib/action/directive/state/action.success.directive.d.ts +9 -17
- package/lib/action/directive/state/action.success.handler.directive.d.ts +24 -0
- package/lib/action/directive/state/action.value.directive.d.ts +5 -5
- package/lib/action/directive/state/action.value.trigger.instance.d.ts +2 -2
- package/lib/action/directive/state/action.working.component.d.ts +11 -5
- package/lib/action/directive/state/index.d.ts +1 -1
- package/lib/auth/auth.module.d.ts +8 -0
- package/lib/auth/auth.role.any.directive.d.ts +20 -0
- package/lib/auth/auth.role.has.directive.d.ts +20 -0
- package/lib/auth/auth.state.module.d.ts +8 -0
- package/lib/auth/auth.state.service.d.ts +13 -0
- package/lib/auth/auth.user.d.ts +28 -0
- package/lib/auth/index.d.ts +9 -0
- package/lib/auth/router/auth.router.d.ts +10 -0
- package/lib/auth/router/auth.router.module.d.ts +9 -0
- package/lib/auth/router/auth.router.service.d.ts +38 -0
- package/lib/auth/router/index.d.ts +5 -0
- package/lib/auth/router/provider/uirouter/auth.hook.d.ts +18 -0
- package/lib/auth/router/provider/uirouter/hook.d.ts +46 -0
- package/lib/auth/router/provider/uirouter/index.d.ts +5 -0
- package/lib/auth/router/provider/uirouter/redirect.d.ts +9 -0
- package/lib/auth/router/provider/uirouter/role.hook.d.ts +26 -0
- package/lib/auth/router/provider/uirouter/state.hook.d.ts +31 -0
- package/lib/auth/router/state/auth.router.state.module.d.ts +14 -0
- package/lib/auth/router/state/effect/auth.router.state.effect.d.ts +32 -0
- package/lib/auth/router/state/effect/index.d.ts +1 -0
- package/lib/auth/router/state/index.d.ts +2 -0
- package/lib/auth/service/auth.service.d.ts +46 -0
- package/lib/auth/service/auth.service.rxjs.d.ts +18 -0
- package/lib/auth/service/index.d.ts +2 -0
- package/lib/auth/state/action/auth.action.d.ts +12 -0
- package/lib/auth/state/action/index.d.ts +11 -0
- package/lib/auth/state/action/user.action.d.ts +34 -0
- package/lib/auth/state/effect/auth.effect.d.ts +31 -0
- package/lib/auth/state/index.d.ts +12 -0
- package/lib/auth/state/reducer/index.d.ts +29 -0
- package/lib/auth/state/reducer/user.reducer.d.ts +11 -0
- package/lib/auth/state/state.d.ts +5 -0
- package/lib/button/button.d.ts +3 -3
- package/lib/button/router/button.segue.directive.d.ts +1 -0
- package/lib/context/context.d.ts +39 -0
- package/lib/context/context.directive.d.ts +19 -0
- package/lib/context/context.module.d.ts +8 -0
- package/lib/context/context.service.d.ts +16 -0
- package/lib/context/index.d.ts +5 -0
- package/lib/context/state/action/data.action.d.ts +13 -0
- package/lib/context/state/action/index.d.ts +6 -0
- package/lib/context/state/effect/index.d.ts +39 -0
- package/lib/context/state/index.d.ts +12 -0
- package/lib/context/state/reducer/data.reducer.d.ts +13 -0
- package/lib/context/state/reducer/index.d.ts +34 -0
- package/lib/context/state/state.d.ts +9 -0
- package/lib/filter/filter.abstract.source.directive.d.ts +2 -2
- package/lib/index.d.ts +5 -1
- package/lib/injection/index.d.ts +8 -0
- package/lib/injection/injection.component.d.ts +15 -0
- package/lib/injection/injection.component.module.d.ts +9 -0
- package/lib/injection/injection.context.d.ts +39 -0
- package/lib/injection/injection.context.directive.d.ts +25 -0
- package/lib/injection/injection.context.forward.directive.d.ts +16 -0
- package/lib/{injected/injected.d.ts → injection/injection.d.ts} +4 -4
- package/lib/injection/injection.directive.d.ts +19 -0
- package/lib/{injected/injected.instance.d.ts → injection/injection.instance.d.ts} +8 -8
- package/lib/ngrx/index.d.ts +1 -0
- package/lib/ngrx/store.lockset.d.ts +36 -0
- package/lib/pipe/index.d.ts +2 -0
- package/lib/pipe/misc/index.d.ts +2 -0
- package/lib/pipe/misc/misc.pipe.module.d.ts +7 -0
- package/lib/pipe/misc/prettyjson.pipe.d.ts +9 -0
- package/lib/pipe/pipe.module.d.ts +8 -0
- package/lib/router/anchor/anchor.d.ts +5 -1
- package/lib/router/anchor/anchor.directive.d.ts +10 -2
- package/lib/router/router/provider/angular/angular.router.service.d.ts +7 -5
- package/lib/router/router/provider/uirouter/uirouter.router.service.d.ts +11 -5
- package/lib/router/router/service/index.d.ts +1 -0
- package/lib/router/router/service/router.go.d.ts +14 -0
- package/lib/router/router/service/router.service.d.ts +10 -4
- package/lib/router/router/transition/transition.directive.d.ts +2 -2
- package/lib/router/router/transition/transition.watcher.directive.d.ts +1 -1
- package/lib/router/segue.d.ts +10 -3
- package/lib/util/view.d.ts +12 -0
- package/lib/view/if.directive.d.ts +19 -0
- package/lib/view/index.d.ts +1 -0
- package/package.json +6 -13
- package/esm2020/lib/action/directive/state/action.success.component.mjs +0 -50
- package/esm2020/lib/injected/index.mjs +0 -6
- package/esm2020/lib/injected/injected.component.mjs +0 -34
- package/esm2020/lib/injected/injected.component.module.mjs +0 -26
- package/esm2020/lib/injected/injected.directive.mjs +0 -33
- package/esm2020/lib/injected/injected.instance.mjs +0 -116
- package/esm2020/lib/injected/injected.mjs +0 -16
- package/lib/action/directive/state/action.success.component.d.ts +0 -15
- package/lib/injected/index.d.ts +0 -5
- package/lib/injected/injected.component.d.ts +0 -15
- package/lib/injected/injected.component.module.d.ts +0 -8
- package/lib/injected/injected.directive.d.ts +0 -19
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { Directive, Injector, Input, TemplateRef, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { ProvideDbxInjectionContext } from './injection.context';
|
|
3
|
+
import { DbxInjectionInstance } from './injection.instance';
|
|
4
|
+
import { makePromiseFullRef } from '@dereekb/util';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* DbxInjectedViewContext implementation. Acts similar to *ngIf, but instead switches to a different view without destroying the original child view.
|
|
8
|
+
*/
|
|
9
|
+
export class DbxInjectionContextDirective {
|
|
10
|
+
constructor(_injector, _templateRef, _viewContainer) {
|
|
11
|
+
this._injector = _injector;
|
|
12
|
+
this._templateRef = _templateRef;
|
|
13
|
+
this._viewContainer = _viewContainer;
|
|
14
|
+
this._instance = new DbxInjectionInstance(this._injector);
|
|
15
|
+
this._isDetached = false;
|
|
16
|
+
}
|
|
17
|
+
set config(config) {
|
|
18
|
+
let reattach = false;
|
|
19
|
+
if (config) {
|
|
20
|
+
if (!this._isDetached) {
|
|
21
|
+
// detach the original view before setting config.
|
|
22
|
+
this._viewContainer.detach();
|
|
23
|
+
this._isDetached = true;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
else if (this._isDetached) {
|
|
27
|
+
reattach = true;
|
|
28
|
+
}
|
|
29
|
+
this._instance.config = config;
|
|
30
|
+
if (reattach) {
|
|
31
|
+
this._viewContainer.insert(this._embeddedView);
|
|
32
|
+
this._isDetached = false;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this._instance.content = this._viewContainer;
|
|
37
|
+
this._instance.init();
|
|
38
|
+
this._embeddedView = this._viewContainer.createEmbeddedView(this._templateRef);
|
|
39
|
+
// detach the embedded view
|
|
40
|
+
this._viewContainer.detach();
|
|
41
|
+
// reattach it through the template configuration.
|
|
42
|
+
// the template configuration acts as the default.
|
|
43
|
+
this._instance.template = {
|
|
44
|
+
viewRef: this._embeddedView
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
ngOnDestroy() {
|
|
48
|
+
this._instance.destroy();
|
|
49
|
+
this._embeddedView?.destroy(); // destroy our embedded view too.
|
|
50
|
+
}
|
|
51
|
+
async showContext(config) {
|
|
52
|
+
// clear the current context before showing something new.
|
|
53
|
+
this.resetContext();
|
|
54
|
+
let promiseRef;
|
|
55
|
+
let result;
|
|
56
|
+
let error;
|
|
57
|
+
// wait for the promise to resolve and use to finish using that instance.
|
|
58
|
+
try {
|
|
59
|
+
promiseRef = makePromiseFullRef(async (resolve, reject) => {
|
|
60
|
+
const injectionConfig = {
|
|
61
|
+
...config.config,
|
|
62
|
+
init: async (instance) => {
|
|
63
|
+
// init if available in the base config.
|
|
64
|
+
if (config.config.init) {
|
|
65
|
+
config.config.init(instance);
|
|
66
|
+
}
|
|
67
|
+
try {
|
|
68
|
+
resolve(config.use(instance));
|
|
69
|
+
}
|
|
70
|
+
catch (e) {
|
|
71
|
+
reject(e);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
this.config = injectionConfig;
|
|
76
|
+
});
|
|
77
|
+
this._currentPromise = promiseRef;
|
|
78
|
+
// await the promise
|
|
79
|
+
await promiseRef.promise;
|
|
80
|
+
}
|
|
81
|
+
catch (e) {
|
|
82
|
+
error = e;
|
|
83
|
+
}
|
|
84
|
+
// if we're still using the same promiseRef
|
|
85
|
+
if (promiseRef && promiseRef === this._currentPromise) {
|
|
86
|
+
// clear the config to reshow the view
|
|
87
|
+
this.config = undefined;
|
|
88
|
+
// clear the current promise
|
|
89
|
+
this._currentPromise = undefined;
|
|
90
|
+
}
|
|
91
|
+
if (error != null) {
|
|
92
|
+
return Promise.reject(error);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
return result;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
resetContext() {
|
|
99
|
+
let clearedValue = false;
|
|
100
|
+
if (this._currentPromise) {
|
|
101
|
+
const promise = this._currentPromise;
|
|
102
|
+
// clear the current promise too
|
|
103
|
+
this._currentPromise = undefined;
|
|
104
|
+
// clear the config.
|
|
105
|
+
this.config = undefined;
|
|
106
|
+
// send a rejection signal to bail out.
|
|
107
|
+
promise.reject(new Error('dbxInjectionContext bailout'));
|
|
108
|
+
clearedValue = true;
|
|
109
|
+
}
|
|
110
|
+
return clearedValue;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
DbxInjectionContextDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxInjectionContextDirective, deps: [{ token: i0.Injector }, { token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
114
|
+
DbxInjectionContextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: DbxInjectionContextDirective, selector: "[dbxInjectionContext]", inputs: { config: "config" }, providers: ProvideDbxInjectionContext(DbxInjectionContextDirective), ngImport: i0 });
|
|
115
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxInjectionContextDirective, decorators: [{
|
|
116
|
+
type: Directive,
|
|
117
|
+
args: [{
|
|
118
|
+
selector: '[dbxInjectionContext]',
|
|
119
|
+
providers: ProvideDbxInjectionContext(DbxInjectionContextDirective)
|
|
120
|
+
}]
|
|
121
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; }, propDecorators: { config: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}] } });
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"injection.context.directive.js","sourceRoot":"","sources":["../../../../../../packages/dbx-core/src/lib/injection/injection.context.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EmbeddedViewRef, Injector, Input, TemplateRef, ViewContainerRef } from '@angular/core';\nimport { DbxInjectionContext, DbxInjectionContextConfig, ProvideDbxInjectionContext } from './injection.context';\nimport { DbxInjectionInstance } from './injection.instance';\nimport { DbxInjectionComponentConfig } from './injection';\nimport { PromiseFullRef, makePromiseFullRef, Maybe } from '@dereekb/util';\n\n/**\n * DbxInjectedViewContext implementation. Acts similar to *ngIf, but instead switches to a different view without destroying the original child view.\n */\n@Directive({\n  selector: '[dbxInjectionContext]',\n  providers: ProvideDbxInjectionContext(DbxInjectionContextDirective)\n})\nexport class DbxInjectionContextDirective<O = any> implements DbxInjectionContext {\n\n  private _currentPromise: Maybe<PromiseFullRef<any>>;\n  private _instance = new DbxInjectionInstance(this._injector);\n  private _embeddedView!: EmbeddedViewRef<O>;\n  private _isDetached = false;\n\n  constructor(\n    private readonly _injector: Injector,\n    private readonly _templateRef: TemplateRef<O>,\n    private readonly _viewContainer: ViewContainerRef\n  ) { }\n\n  @Input()\n  set config(config: Maybe<DbxInjectionComponentConfig<any>>) {\n    let reattach = false;\n\n    if (config) {\n      if (!this._isDetached) {\n\n        // detach the original view before setting config.\n        this._viewContainer.detach();\n        this._isDetached = true;\n      }\n    } else if (this._isDetached) {\n      reattach = true;\n    }\n\n    this._instance.config = config;\n\n    if (reattach) {\n      this._viewContainer.insert(this._embeddedView);\n      this._isDetached = false;\n    }\n  }\n\n  ngOnInit() {\n    this._instance.content = this._viewContainer;\n    this._instance.init();\n    this._embeddedView = this._viewContainer.createEmbeddedView(this._templateRef);\n\n    // detach the embedded view\n    this._viewContainer.detach();\n\n    // reattach it through the template configuration.\n    // the template configuration acts as the default.\n    this._instance.template = {\n      viewRef: this._embeddedView\n    };\n  }\n\n  ngOnDestroy(): void {\n    this._instance.destroy();\n    this._embeddedView?.destroy(); // destroy our embedded view too.\n  }\n\n  async showContext<T, O>(config: DbxInjectionContextConfig<T>): Promise<O> {\n\n    // clear the current context before showing something new.\n    this.resetContext();\n\n    let promiseRef: PromiseFullRef<O>;\n\n    let result: O;\n    let error: any;\n\n    // wait for the promise to resolve and use to finish using that instance.\n    try {\n      promiseRef = makePromiseFullRef(async (resolve, reject) => {\n        const injectionConfig: DbxInjectionComponentConfig<T> = {\n          ...config.config,\n          init: async (instance: T) => {\n\n            // init if available in the base config.\n            if (config.config.init) {\n              config.config.init(instance);\n            }\n\n            try {\n              resolve(config.use(instance));\n            } catch (e) {\n              reject(e);\n            }\n          }\n        };\n\n        this.config = injectionConfig as any;\n      });\n\n      this._currentPromise = promiseRef;\n\n      // await the promise\n      await promiseRef.promise;\n    } catch (e) {\n      error = e;\n    }\n\n    // if we're still using the same promiseRef\n    if (promiseRef! && promiseRef! === this._currentPromise) {\n      // clear the config to reshow the view\n      this.config = undefined;\n\n      // clear the current promise\n      this._currentPromise = undefined;\n    }\n\n    if (error != null) {\n      return Promise.reject(error);\n    } else {\n      return result!;\n    }\n  }\n\n  resetContext(): boolean {\n    let clearedValue = false;\n\n    if (this._currentPromise) {\n      const promise = this._currentPromise;\n\n      // clear the current promise too\n      this._currentPromise = undefined;\n\n      // clear the config.\n      this.config = undefined;\n\n      // send a rejection signal to bail out.\n      promise.reject(new Error('dbxInjectionContext bailout'));\n\n      clearedValue = true;\n    }\n\n    return clearedValue;\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Directive, Host } from "@angular/core";
|
|
2
|
+
import { DbxInjectionContext } from "./injection.context";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./injection.context";
|
|
5
|
+
/**
|
|
6
|
+
* Abstract DbxInjectionContext implementation that forwards commands to a host DbxInjectionContext.
|
|
7
|
+
*
|
|
8
|
+
* This abstract type is used by related types for dependency injection purposes, so that those types
|
|
9
|
+
* can be injected instead of just any DbxInjectionContext.
|
|
10
|
+
*/
|
|
11
|
+
export class AbstractForwardDbxInjectionContextDirective {
|
|
12
|
+
constructor(dbxInjectionContext) {
|
|
13
|
+
this.dbxInjectionContext = dbxInjectionContext;
|
|
14
|
+
}
|
|
15
|
+
// MARK: DbxInjectionContext
|
|
16
|
+
showContext(config) {
|
|
17
|
+
return this.dbxInjectionContext.showContext(config);
|
|
18
|
+
}
|
|
19
|
+
resetContext() {
|
|
20
|
+
return this.dbxInjectionContext.resetContext();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
AbstractForwardDbxInjectionContextDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AbstractForwardDbxInjectionContextDirective, deps: [{ token: i1.DbxInjectionContext, host: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
24
|
+
AbstractForwardDbxInjectionContextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: AbstractForwardDbxInjectionContextDirective, ngImport: i0 });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AbstractForwardDbxInjectionContextDirective, decorators: [{
|
|
26
|
+
type: Directive
|
|
27
|
+
}], ctorParameters: function () { return [{ type: i1.DbxInjectionContext, decorators: [{
|
|
28
|
+
type: Host
|
|
29
|
+
}] }]; } });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0aW9uLmNvbnRleHQuZm9yd2FyZC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtY29yZS9zcmMvbGliL2luamVjdGlvbi9pbmplY3Rpb24uY29udGV4dC5mb3J3YXJkLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsbUJBQW1CLEVBQTZCLE1BQU0scUJBQXFCLENBQUM7OztBQUVyRjs7Ozs7R0FLRztBQUVILE1BQU0sT0FBZ0IsMkNBQTJDO0lBRS9ELFlBQTZCLG1CQUF3QztRQUF4Qyx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXFCO0lBQUksQ0FBQztJQUUxRSw0QkFBNEI7SUFDNUIsV0FBVyxDQUFtQixNQUF5QztRQUNyRSxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELFlBQVk7UUFDVixPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUNqRCxDQUFDOzt3SUFYbUIsMkNBQTJDOzRIQUEzQywyQ0FBMkM7MkZBQTNDLDJDQUEyQztrQkFEaEUsU0FBUzs7MEJBR0ssSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db250ZXh0LCBEYnhJbmplY3Rpb25Db250ZXh0Q29uZmlnIH0gZnJvbSBcIi4vaW5qZWN0aW9uLmNvbnRleHRcIjtcblxuLyoqXG4gKiBBYnN0cmFjdCBEYnhJbmplY3Rpb25Db250ZXh0IGltcGxlbWVudGF0aW9uIHRoYXQgZm9yd2FyZHMgY29tbWFuZHMgdG8gYSBob3N0IERieEluamVjdGlvbkNvbnRleHQuXG4gKiBcbiAqIFRoaXMgYWJzdHJhY3QgdHlwZSBpcyB1c2VkIGJ5IHJlbGF0ZWQgdHlwZXMgZm9yIGRlcGVuZGVuY3kgaW5qZWN0aW9uIHB1cnBvc2VzLCBzbyB0aGF0IHRob3NlIHR5cGVzXG4gKiBjYW4gYmUgaW5qZWN0ZWQgaW5zdGVhZCBvZiBqdXN0IGFueSBEYnhJbmplY3Rpb25Db250ZXh0LlxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdEZvcndhcmREYnhJbmplY3Rpb25Db250ZXh0RGlyZWN0aXZlIGltcGxlbWVudHMgRGJ4SW5qZWN0aW9uQ29udGV4dCB7XG5cbiAgY29uc3RydWN0b3IoQEhvc3QoKSByZWFkb25seSBkYnhJbmplY3Rpb25Db250ZXh0OiBEYnhJbmplY3Rpb25Db250ZXh0KSB7IH1cblxuICAvLyBNQVJLOiBEYnhJbmplY3Rpb25Db250ZXh0XG4gIHNob3dDb250ZXh0PFQgPSBhbnksIE8gPSBhbnk+KGNvbmZpZzogRGJ4SW5qZWN0aW9uQ29udGV4dENvbmZpZzxULCBhbnk+KTogUHJvbWlzZTxPPiB7XG4gICAgcmV0dXJuIHRoaXMuZGJ4SW5qZWN0aW9uQ29udGV4dC5zaG93Q29udGV4dChjb25maWcpO1xuICB9XG5cbiAgcmVzZXRDb250ZXh0KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmRieEluamVjdGlvbkNvbnRleHQucmVzZXRDb250ZXh0KCk7XG4gIH1cblxufVxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* View that can switch to show another arbitrary view, then switch back when the promise ends.
|
|
3
|
+
*
|
|
4
|
+
* It is similar to *ngIf/*ngSwitch, but the original child content is retained instead of discarded,
|
|
5
|
+
* and returns once the special context is done being used.
|
|
6
|
+
*/
|
|
7
|
+
export class DbxInjectionContext {
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Allows a directive to provide a formly context and form.
|
|
11
|
+
*/
|
|
12
|
+
export function ProvideDbxInjectionContext(type) {
|
|
13
|
+
return [{
|
|
14
|
+
provide: DbxInjectionContext,
|
|
15
|
+
useExisting: type
|
|
16
|
+
}];
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0aW9uLmNvbnRleHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtY29yZS9zcmMvbGliL2luamVjdGlvbi9pbmplY3Rpb24uY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQkE7Ozs7O0dBS0c7QUFDSCxNQUFNLE9BQWdCLG1CQUFtQjtDQWdCeEM7QUFFRDs7R0FFRztBQUNILE1BQU0sVUFBVSwwQkFBMEIsQ0FBZ0MsSUFBYTtJQUNyRixPQUFPLENBQUM7WUFDTixPQUFPLEVBQUUsbUJBQW1CO1lBQzVCLFdBQVcsRUFBRSxJQUFJO1NBQ2xCLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm92aWRlciwgVHlwZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWcgfSBmcm9tIFwiLi9pbmplY3Rpb25cIjtcblxuLyoqXG4gKiBEYnhJbmplY3RlZFZpZXdDb250ZXh0IHNob3dDb250ZXh0KCkgY29uZmlndXJhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEYnhJbmplY3Rpb25Db250ZXh0Q29uZmlnPFQgPSBhbnksIE8gPSBhbnk+IHtcbiAgLyoqXG4gICAqIEluamVjdGVkIGNvbmZpZy5cbiAgICovXG4gIGNvbmZpZzogRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPFQ+O1xuICAvKipcbiAgICogUHJvbWlzZSB1c2VkIHRvIHJldHJpZXZlIGRhdGEgZnJvbSB0aGUgZ2l2ZW4gaW5zdGFuY2UuXG4gICAqL1xuICB1c2U6IChpbnN0YW5jZTogVCkgPT4gUHJvbWlzZTxPPjtcbn1cblxuLyoqXG4gKiBWaWV3IHRoYXQgY2FuIHN3aXRjaCB0byBzaG93IGFub3RoZXIgYXJiaXRyYXJ5IHZpZXcsIHRoZW4gc3dpdGNoIGJhY2sgd2hlbiB0aGUgcHJvbWlzZSBlbmRzLlxuICogXG4gKiBJdCBpcyBzaW1pbGFyIHRvICpuZ0lmLypuZ1N3aXRjaCwgYnV0IHRoZSBvcmlnaW5hbCBjaGlsZCBjb250ZW50IGlzIHJldGFpbmVkIGluc3RlYWQgb2YgZGlzY2FyZGVkLCBcbiAqIGFuZCByZXR1cm5zIG9uY2UgdGhlIHNwZWNpYWwgY29udGV4dCBpcyBkb25lIGJlaW5nIHVzZWQuXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBEYnhJbmplY3Rpb25Db250ZXh0IHtcblxuICAvKipcbiAgICogU2hvd3MgdGhlIGdpdmVuIGNvbnRleHQgdW50aWwgdGhlIHByb21pc2UgZW5kcywgdGhlbiBkaXNwbGF5cyB0aGUgb3JpZ2luYWwgY29udGVudC5cbiAgICogXG4gICAqIFRoZSBvcmlnaW5hbCBjb250ZW50IGlzIGhpZGRlbiBpbnN0ZWFkIG9mIHJlbW92ZWQgZnJvbSB0aGUgY29udGV4dCB0byBhdm9pZCBkZXN0cnVjdGlvbiBvZiBjaGlsZHJlbiBlbGVtZW50cy5cbiAgICovXG4gIGFic3RyYWN0IHNob3dDb250ZXh0PFQgPSBhbnksIE8gPSBhbnk+KGNvbmZpZzogRGJ4SW5qZWN0aW9uQ29udGV4dENvbmZpZzxUPik6IFByb21pc2U8Tz47XG5cbiAgLyoqXG4gICAqIEJhaWxzIG91dCBvZiBhbnkgY3VycmVudCBwcm9taXNlLCBpZiBvbmUgaXMgc2V0LlxuICAgKiBcbiAgICogUmV0dXJucyB0cnVlIGlmIHRoZSBiYWlsIHNpZ25hbCBoYXMgYmVlbiBzZW50LlxuICAgKi9cbiAgYWJzdHJhY3QgcmVzZXRDb250ZXh0KCk6IGJvb2xlYW47XG5cbn1cblxuLyoqXG4gKiBBbGxvd3MgYSBkaXJlY3RpdmUgdG8gcHJvdmlkZSBhIGZvcm1seSBjb250ZXh0IGFuZCBmb3JtLlxuICovXG5leHBvcnQgZnVuY3Rpb24gUHJvdmlkZURieEluamVjdGlvbkNvbnRleHQ8VCBleHRlbmRzIERieEluamVjdGlvbkNvbnRleHQ+KHR5cGU6IFR5cGU8VD4pOiBQcm92aWRlcltdIHtcbiAgcmV0dXJuIFt7XG4gICAgcHJvdmlkZTogRGJ4SW5qZWN0aW9uQ29udGV4dCxcbiAgICB1c2VFeGlzdGluZzogdHlwZVxuICB9XTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Directive, Injector } from '@angular/core';
|
|
2
|
+
import { DbxInjectionInstance as DbxInjectionInstance } from './injection.instance';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* Abstract directive that injects content based on the configuration into the view.
|
|
6
|
+
*/
|
|
7
|
+
export class AbstractDbxInjectionDirective {
|
|
8
|
+
constructor(_injector) {
|
|
9
|
+
this._injector = _injector;
|
|
10
|
+
this._instance = new DbxInjectionInstance(this._injector);
|
|
11
|
+
}
|
|
12
|
+
ngOnInit() {
|
|
13
|
+
this._instance.init();
|
|
14
|
+
}
|
|
15
|
+
ngOnDestroy() {
|
|
16
|
+
this._instance.destroy();
|
|
17
|
+
}
|
|
18
|
+
setConfig(config) {
|
|
19
|
+
this._instance.config = config;
|
|
20
|
+
}
|
|
21
|
+
setTemplate(template) {
|
|
22
|
+
this._instance.template = template;
|
|
23
|
+
}
|
|
24
|
+
setContent(content) {
|
|
25
|
+
this._instance.content = content;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
AbstractDbxInjectionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AbstractDbxInjectionDirective, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
|
|
29
|
+
AbstractDbxInjectionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: AbstractDbxInjectionDirective, ngImport: i0 });
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AbstractDbxInjectionDirective, decorators: [{
|
|
31
|
+
type: Directive
|
|
32
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }]; } });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0aW9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1jb3JlL3NyYy9saWIvaW5qZWN0aW9uL2luamVjdGlvbi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF1QyxTQUFTLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3pGLE9BQU8sRUFBRSxvQkFBb0IsSUFBSSxvQkFBb0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQUVwRjs7R0FFRztBQUVILE1BQU0sT0FBZ0IsNkJBQTZCO0lBSWpELFlBQTZCLFNBQW1CO1FBQW5CLGNBQVMsR0FBVCxTQUFTLENBQVU7UUFGeEMsY0FBUyxHQUFHLElBQUksb0JBQW9CLENBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBRVosQ0FBQztJQUVyRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFNBQVMsQ0FBQyxNQUEwQztRQUNsRCxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDakMsQ0FBQztJQUVELFdBQVcsQ0FBQyxRQUEyQztRQUNyRCxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFDckMsQ0FBQztJQUVELFVBQVUsQ0FBQyxPQUFnQztRQUN6QyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDbkMsQ0FBQzs7MEhBeEJtQiw2QkFBNkI7OEdBQTdCLDZCQUE2QjsyRkFBN0IsNkJBQTZCO2tCQURsRCxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmlld0NvbnRhaW5lclJlZiwgT25Jbml0LCBPbkRlc3Ryb3ksIERpcmVjdGl2ZSwgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWcsIERieEluamVjdGlvblRlbXBsYXRlQ29uZmlnIH0gZnJvbSAnLi9pbmplY3Rpb24nO1xuaW1wb3J0IHsgRGJ4SW5qZWN0aW9uSW5zdGFuY2UgYXMgRGJ4SW5qZWN0aW9uSW5zdGFuY2UgfSBmcm9tICcuL2luamVjdGlvbi5pbnN0YW5jZSc7XG5cbi8qKlxuICogQWJzdHJhY3QgZGlyZWN0aXZlIHRoYXQgaW5qZWN0cyBjb250ZW50IGJhc2VkIG9uIHRoZSBjb25maWd1cmF0aW9uIGludG8gdGhlIHZpZXcuXG4gKi9cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0RGJ4SW5qZWN0aW9uRGlyZWN0aXZlPFQ+IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuXG4gIHByaXZhdGUgX2luc3RhbmNlID0gbmV3IERieEluamVjdGlvbkluc3RhbmNlPFQ+KHRoaXMuX2luamVjdG9yKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IF9pbmplY3RvcjogSW5qZWN0b3IpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuX2luc3RhbmNlLmluaXQoKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuX2luc3RhbmNlLmRlc3Ryb3koKTtcbiAgfVxuXG4gIHNldENvbmZpZyhjb25maWc6IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZz4pIHtcbiAgICB0aGlzLl9pbnN0YW5jZS5jb25maWcgPSBjb25maWc7XG4gIH1cblxuICBzZXRUZW1wbGF0ZSh0ZW1wbGF0ZTogTWF5YmU8RGJ4SW5qZWN0aW9uVGVtcGxhdGVDb25maWc+KSB7XG4gICAgdGhpcy5faW5zdGFuY2UudGVtcGxhdGUgPSB0ZW1wbGF0ZTtcbiAgfVxuXG4gIHNldENvbnRlbnQoY29udGVudDogTWF5YmU8Vmlld0NvbnRhaW5lclJlZj4pIHtcbiAgICB0aGlzLl9pbnN0YW5jZS5jb250ZW50ID0gY29udGVudDtcbiAgfVxuXG59XG4iXX0=
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { Injector } from '@angular/core';
|
|
2
|
+
import { distinctUntilChanged, map, shareReplay } from 'rxjs/operators';
|
|
3
|
+
import { BehaviorSubject, combineLatest } from 'rxjs';
|
|
4
|
+
import { DBX_INJECTION_COMPONENT_DATA } from './injection';
|
|
5
|
+
import { mergeArrayOrValueIntoArray } from '@dereekb/util';
|
|
6
|
+
import { SubscriptionObject, filterMaybe, skipFirstMaybe } from '@dereekb/rxjs';
|
|
7
|
+
/**
|
|
8
|
+
* Instance used by components to inject content based on the configuration into the view.
|
|
9
|
+
*/
|
|
10
|
+
export class DbxInjectionInstance {
|
|
11
|
+
constructor(_injector) {
|
|
12
|
+
this._injector = _injector;
|
|
13
|
+
this._subscriptionObject = new SubscriptionObject();
|
|
14
|
+
this._config = new BehaviorSubject(undefined);
|
|
15
|
+
this._template = new BehaviorSubject(undefined);
|
|
16
|
+
this._content = new BehaviorSubject(undefined);
|
|
17
|
+
this._componentRef = new BehaviorSubject(undefined);
|
|
18
|
+
this.config$ = this._config.pipe(distinctUntilChanged());
|
|
19
|
+
this.template$ = this._template.pipe(distinctUntilChanged());
|
|
20
|
+
this.content$ = this._content.pipe(filterMaybe(), distinctUntilChanged(), shareReplay(1));
|
|
21
|
+
}
|
|
22
|
+
get config() {
|
|
23
|
+
return this._config.value;
|
|
24
|
+
}
|
|
25
|
+
set config(config) {
|
|
26
|
+
this._config.next(config);
|
|
27
|
+
}
|
|
28
|
+
get template() {
|
|
29
|
+
return this._template.value;
|
|
30
|
+
}
|
|
31
|
+
set template(template) {
|
|
32
|
+
this._template.next(template);
|
|
33
|
+
}
|
|
34
|
+
get content() {
|
|
35
|
+
return this._content.value;
|
|
36
|
+
}
|
|
37
|
+
set content(content) {
|
|
38
|
+
this._content.next(content);
|
|
39
|
+
}
|
|
40
|
+
get componentRef() {
|
|
41
|
+
return this._componentRef.value;
|
|
42
|
+
}
|
|
43
|
+
set componentRef(componentRef) {
|
|
44
|
+
this._componentRef.next(componentRef);
|
|
45
|
+
}
|
|
46
|
+
init() {
|
|
47
|
+
// Wait until the first of either of the two inputs comes in as not defined, and then emit.
|
|
48
|
+
// We filter the first maybe here between the two items.
|
|
49
|
+
const configTemplateObs = combineLatest([this.config$, this.template$]).pipe(map(([config, template]) => {
|
|
50
|
+
if (config || template) {
|
|
51
|
+
return {
|
|
52
|
+
config,
|
|
53
|
+
template
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
return undefined;
|
|
58
|
+
}
|
|
59
|
+
}), skipFirstMaybe());
|
|
60
|
+
this._subscriptionObject.subscription = combineLatest([configTemplateObs, this.content$]).subscribe(([inputConfig, content]) => {
|
|
61
|
+
const { config, template } = inputConfig ?? {};
|
|
62
|
+
this._reset(content);
|
|
63
|
+
if (config) {
|
|
64
|
+
this._initComponent(config, content);
|
|
65
|
+
}
|
|
66
|
+
else if (template) {
|
|
67
|
+
this._initTemplate(template, content);
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
destroy() {
|
|
72
|
+
this._config.complete();
|
|
73
|
+
this._template.complete();
|
|
74
|
+
this._content.complete();
|
|
75
|
+
this._componentRef.complete();
|
|
76
|
+
}
|
|
77
|
+
_initComponent(config, content) {
|
|
78
|
+
content.clear();
|
|
79
|
+
const { init, injector: inputInjector, providers, ngModuleRef, componentClass, data } = config;
|
|
80
|
+
let injector;
|
|
81
|
+
const parentInjector = inputInjector ?? this._injector;
|
|
82
|
+
if (Boolean(providers || data)) {
|
|
83
|
+
injector = Injector.create({
|
|
84
|
+
parent: parentInjector,
|
|
85
|
+
providers: mergeArrayOrValueIntoArray([{
|
|
86
|
+
provide: DBX_INJECTION_COMPONENT_DATA,
|
|
87
|
+
useValue: data
|
|
88
|
+
}], providers ?? [])
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
const componentRef = content.createComponent(componentClass, { injector, ngModuleRef });
|
|
92
|
+
const instance = componentRef.instance;
|
|
93
|
+
if (init) {
|
|
94
|
+
init(instance);
|
|
95
|
+
}
|
|
96
|
+
this.componentRef = componentRef;
|
|
97
|
+
}
|
|
98
|
+
_initTemplate(config, content) {
|
|
99
|
+
content.clear();
|
|
100
|
+
const { templateRef, viewRef } = config;
|
|
101
|
+
if (templateRef) {
|
|
102
|
+
content.createEmbeddedView(templateRef);
|
|
103
|
+
// TODO: Figure out if these items need to be destroyed or not when this item is destroyed. If so, we need a reference to destroy.
|
|
104
|
+
}
|
|
105
|
+
else if (viewRef) {
|
|
106
|
+
content.insert(viewRef);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
_reset(content) {
|
|
110
|
+
if (this.componentRef) {
|
|
111
|
+
content.clear();
|
|
112
|
+
this.componentRef = undefined;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"injection.instance.js","sourceRoot":"","sources":["../../../../../../packages/dbx-core/src/lib/injection/injection.instance.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, Injector, ViewContainerRef } from '@angular/core';\nimport { distinctUntilChanged, map, shareReplay } from 'rxjs/operators';\nimport { BehaviorSubject, combineLatest } from 'rxjs';\nimport { DbxInjectionComponentConfig, DbxInjectionTemplateConfig, DBX_INJECTION_COMPONENT_DATA } from './injection';\nimport { Initialized, Destroyable, Maybe, mergeArrayOrValueIntoArray } from '@dereekb/util';\nimport { SubscriptionObject, filterMaybe, skipFirstMaybe } from '@dereekb/rxjs';\n\n/**\n * Instance used by components to inject content based on the configuration into the view.\n */\nexport class DbxInjectionInstance<T> implements Initialized, Destroyable {\n\n  private _subscriptionObject = new SubscriptionObject();\n\n  private _config = new BehaviorSubject<Maybe<DbxInjectionComponentConfig<T>>>(undefined);\n  private _template = new BehaviorSubject<Maybe<DbxInjectionTemplateConfig<T>>>(undefined);\n\n  private _content = new BehaviorSubject<Maybe<ViewContainerRef>>(undefined);\n  private _componentRef = new BehaviorSubject<Maybe<ComponentRef<T>>>(undefined);\n\n  readonly config$ = this._config.pipe(distinctUntilChanged());\n  readonly template$ = this._template.pipe(distinctUntilChanged());\n  readonly content$ = this._content.pipe(filterMaybe(), distinctUntilChanged(), shareReplay(1));\n\n  get config(): Maybe<DbxInjectionComponentConfig<T>> {\n    return this._config.value;\n  }\n\n  set config(config: Maybe<DbxInjectionComponentConfig<T>>) {\n    this._config.next(config);\n  }\n\n  get template(): Maybe<DbxInjectionTemplateConfig<T>> {\n    return this._template.value;\n  }\n\n  set template(template: Maybe<DbxInjectionTemplateConfig<T>>) {\n    this._template.next(template);\n  }\n\n  get content(): Maybe<Maybe<ViewContainerRef>> {\n    return this._content.value;\n  }\n\n  set content(content: Maybe<Maybe<ViewContainerRef>>) {\n    this._content.next(content);\n  }\n\n  get componentRef(): Maybe<ComponentRef<T>> {\n    return this._componentRef.value;\n  }\n\n  set componentRef(componentRef: Maybe<ComponentRef<T>>) {\n    this._componentRef.next(componentRef);\n  }\n\n  constructor(private readonly _injector: Injector) { }\n\n  init(): void {\n\n    // Wait until the first of either of the two inputs comes in as not defined, and then emit.\n    // We filter the first maybe here between the two items.\n    const configTemplateObs = combineLatest([this.config$, this.template$]).pipe(\n      map(([config, template]) => {\n        if (config || template) {\n          return {\n            config,\n            template\n          };\n        } else {\n          return undefined;\n        }\n      }),\n      skipFirstMaybe()\n    );\n\n    this._subscriptionObject.subscription = combineLatest([configTemplateObs, this.content$]).subscribe(([inputConfig, content]) => {\n      const { config, template } = inputConfig ?? {};\n      this._reset(content);\n\n      if (config) {\n        this._initComponent(config, content);\n      } else if (template) {\n        this._initTemplate(template, content);\n      }\n    });\n  }\n\n  destroy(): void {\n    this._config.complete();\n    this._template.complete();\n    this._content.complete();\n    this._componentRef.complete();\n  }\n\n  private _initComponent(config: DbxInjectionComponentConfig<T>, content: ViewContainerRef): void {\n    content.clear();\n\n    const { init, injector: inputInjector, providers, ngModuleRef, componentClass, data } = config;\n\n    let injector: Injector | undefined;\n    const parentInjector = inputInjector ?? this._injector;\n\n    if (Boolean(providers || data)) {\n      injector = Injector.create({\n        parent: parentInjector,\n        providers: mergeArrayOrValueIntoArray([{\n          provide: DBX_INJECTION_COMPONENT_DATA,\n          useValue: data\n        }], providers ?? [])\n      });\n    }\n\n    const componentRef: ComponentRef<T> = content.createComponent(componentClass, { injector, ngModuleRef });\n\n    const instance = componentRef.instance;\n\n    if (init) {\n      init(instance);\n    }\n\n    this.componentRef = componentRef;\n  }\n\n  private _initTemplate(config: DbxInjectionTemplateConfig<T>, content: ViewContainerRef): void {\n    content.clear();\n\n    const { templateRef, viewRef } = config;\n\n    if (templateRef) {\n      content.createEmbeddedView(templateRef);\n\n      // TODO: Figure out if these items need to be destroyed or not when this item is destroyed. If so, we need a reference to destroy.\n\n    } else if (viewRef) {\n      content.insert(viewRef)\n    }\n  }\n\n  private _reset(content: ViewContainerRef): void {\n    if (this.componentRef) {\n      content.clear();\n      this.componentRef = undefined;\n    }\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { InjectionToken } from "@angular/core";
|
|
2
|
+
import { filterMaybeValues, mergeArrays, mergeObjects } from "@dereekb/util";
|
|
3
|
+
export const DBX_INJECTION_COMPONENT_DATA = new InjectionToken('DbxInjectionComponentConfigData');
|
|
4
|
+
/**
|
|
5
|
+
* Merges multiple configurations into a single configuration.
|
|
6
|
+
*
|
|
7
|
+
* @param configs
|
|
8
|
+
* @returns
|
|
9
|
+
*/
|
|
10
|
+
export function mergeDbxInjectionComponentConfigs(configs) {
|
|
11
|
+
const providers = mergeArrays(filterMaybeValues(configs).map(x => x.providers));
|
|
12
|
+
const result = mergeObjects(configs);
|
|
13
|
+
result.providers = providers;
|
|
14
|
+
return result;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWNvcmUvc3JjL2xpYi9pbmplY3Rpb24vaW5qZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQXFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xILE9BQU8sRUFBRSxpQkFBaUIsRUFBUyxXQUFXLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXBGLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLElBQUksY0FBYyxDQUFDLGlDQUFpQyxDQUFDLENBQUM7QUF3Q2xHOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLGlDQUFpQyxDQUFDLE9BQXNEO0lBQ3RHLE1BQU0sU0FBUyxHQUFHLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztJQUNoRixNQUFNLE1BQU0sR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDckMsTUFBTSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDN0IsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuLCBJbmplY3RvciwgTmdNb2R1bGVSZWYsIFN0YXRpY1Byb3ZpZGVyLCBUZW1wbGF0ZVJlZiwgVHlwZSwgVmlld1JlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBmaWx0ZXJNYXliZVZhbHVlcywgTWF5YmUsIG1lcmdlQXJyYXlzLCBtZXJnZU9iamVjdHMgfSBmcm9tIFwiQGRlcmVla2IvdXRpbFwiO1xuXG5leHBvcnQgY29uc3QgREJYX0lOSkVDVElPTl9DT01QT05FTlRfREFUQSA9IG5ldyBJbmplY3Rpb25Ub2tlbignRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnRGF0YScpO1xuXG5leHBvcnQgaW50ZXJmYWNlIERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZzxUID0gYW55PiB7XG4gIC8qKlxuICAgKiBUeXBlIG9mIENvbXBvbmVudCB0byBpbml0aWFsaXplLlxuICAgKi9cbiAgY29tcG9uZW50Q2xhc3M6IFR5cGU8VD47XG4gIC8qKlxuICAgKiAoT3B0aW9uYWwpIHByb3ZpZGVycyB0byBwcm92aWRlIHRvIHRoZSBleGlzdGluZyBpbmplY3Rvci5cbiAgICovXG4gIHByb3ZpZGVycz86IFN0YXRpY1Byb3ZpZGVyW107XG4gIC8qKlxuICAgKiAoT3B0aW9uYWwpIEN1c3RvbSBJbmplY3RvciB0byB1c2Ugd2hlbiBjcmVhdGluZyB0aGUgY29tcG9uZW50LiBJZiBwcm92aWRlZCwgcHJvdmlkZXJzIGlzIGlnbm9yZWQuXG4gICAqL1xuICBpbmplY3Rvcj86IEluamVjdG9yO1xuICAvKipcbiAgICogKE9wdGlvbmFsKSBNb2R1bGUgcmVmIHRvIHVzZSB3aGVuIGNyZWF0aW5nIHRoZSBjb21wb25lbnQuXG4gICAqL1xuICBuZ01vZHVsZVJlZj86IE5nTW9kdWxlUmVmPHVua25vd24+O1xuICAvKipcbiAgICogKE9wdGlvbmFsKSBDdXN0b20gaW5pdGlhbGl6YXRpb24gY29kZSB3aGVuIGFuIGluc3RhbmNlIGlzIGNyZWF0ZWQuXG4gICAqL1xuICBpbml0PzogKGluc3RhbmNlOiBUKSA9PiB2b2lkO1xuICAvKipcbiAgICogQW55IG9wdGlvbmFsIGRhdGEgdG8gaW5qZWN0IGludG8gdGhlIGNvbXBvbmVudC5cbiAgICovXG4gIGRhdGE/OiBhbnk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4SW5qZWN0aW9uVGVtcGxhdGVDb25maWc8VCA9IGFueT4ge1xuICAvKipcbiAgICogVGVtcGxhdGUgcmVmIHRvIGRpc3BsYXkuXG4gICAqL1xuICB0ZW1wbGF0ZVJlZj86IE1heWJlPFRlbXBsYXRlUmVmPFQ+PjtcbiAgLyoqXG4gICAqIFZpZXcgcmVmIHRvIGluamVjdC5cbiAgICovXG4gIHZpZXdSZWY/OiBNYXliZTxWaWV3UmVmPjtcbn1cblxuLyoqXG4gKiBNZXJnZXMgbXVsdGlwbGUgY29uZmlndXJhdGlvbnMgaW50byBhIHNpbmdsZSBjb25maWd1cmF0aW9uLlxuICogXG4gKiBAcGFyYW0gY29uZmlncyBcbiAqIEByZXR1cm5zIFxuICovXG5leHBvcnQgZnVuY3Rpb24gbWVyZ2VEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWdzKGNvbmZpZ3M6IE1heWJlPFBhcnRpYWw8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPj5bXSk6IFBhcnRpYWw8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPiB7XG4gIGNvbnN0IHByb3ZpZGVycyA9IG1lcmdlQXJyYXlzKGZpbHRlck1heWJlVmFsdWVzKGNvbmZpZ3MpLm1hcCh4ID0+IHgucHJvdmlkZXJzKSk7XG4gIGNvbnN0IHJlc3VsdCA9IG1lcmdlT2JqZWN0cyhjb25maWdzKTtcbiAgcmVzdWx0LnByb3ZpZGVycyA9IHByb3ZpZGVycztcbiAgcmV0dXJuIHJlc3VsdDtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './store.lockset';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtY29yZS9zcmMvbGliL25ncngvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3RvcmUubG9ja3NldCc7XG4iXX0=
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { map } from 'rxjs';
|
|
2
|
+
import { ComponentStore } from '@ngrx/component-store';
|
|
3
|
+
import { Inject, Optional, Injectable } from '@angular/core';
|
|
4
|
+
import { LockSet, asObservable } from '@dereekb/rxjs';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* Abstract ComponentStore extension that provides a LockSet and OnDestroy delaying/cleanup.
|
|
8
|
+
*/
|
|
9
|
+
export class LockSetComponentStore extends ComponentStore {
|
|
10
|
+
constructor(initialState) {
|
|
11
|
+
super(initialState);
|
|
12
|
+
this.initialState = initialState;
|
|
13
|
+
this.lockSet = new LockSet();
|
|
14
|
+
this.lockSetDestroyDelayMs = 2000;
|
|
15
|
+
// MARK: State Changes
|
|
16
|
+
this.resetStore = this.updater(() => ({ ...this.initialState }));
|
|
17
|
+
}
|
|
18
|
+
// MARK: Locks
|
|
19
|
+
setupLockSet({ parent, locks }) {
|
|
20
|
+
if (parent) {
|
|
21
|
+
this.setParentLockSet(parent);
|
|
22
|
+
}
|
|
23
|
+
if (locks) {
|
|
24
|
+
for (const key in locks) {
|
|
25
|
+
if (locks[key]) {
|
|
26
|
+
this.addLock(key, locks[key]);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
setParentLockSet(obs) {
|
|
32
|
+
this.lockSet.setParentLockSet(asObservable(obs).pipe(map(x => x?.lockSet)));
|
|
33
|
+
}
|
|
34
|
+
addLock(key, obs) {
|
|
35
|
+
this.lockSet.addLock(key, obs);
|
|
36
|
+
}
|
|
37
|
+
// MARK: Cleanup
|
|
38
|
+
ngOnDestroy() {
|
|
39
|
+
// Wait for any actions to complete before destroying.
|
|
40
|
+
this.lockSet.destroyOnNextUnlock({
|
|
41
|
+
fn: () => {
|
|
42
|
+
this._destroyNow();
|
|
43
|
+
},
|
|
44
|
+
timeout: this.lockSetDestroyTimeoutMs,
|
|
45
|
+
}, this.lockSetDestroyDelayMs);
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Completes the cleanup of the object.
|
|
49
|
+
*/
|
|
50
|
+
_destroyNow() {
|
|
51
|
+
this.lockSet.destroy();
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
LockSetComponentStore.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: LockSetComponentStore, deps: [{ token: null, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
55
|
+
LockSetComponentStore.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: LockSetComponentStore });
|
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: LockSetComponentStore, decorators: [{
|
|
57
|
+
type: Injectable
|
|
58
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
59
|
+
type: Inject,
|
|
60
|
+
args: [null]
|
|
61
|
+
}, {
|
|
62
|
+
type: Optional
|
|
63
|
+
}] }]; } });
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmUubG9ja3NldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1jb3JlL3NyYy9saWIvbmdyeC9zdG9yZS5sb2Nrc2V0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxHQUFHLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDdkMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQUUsT0FBTyxFQUF5QyxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBYzdGOztHQUVHO0FBRUgsTUFBTSxPQUFnQixxQkFBd0MsU0FBUSxjQUFpQjtJQU9yRixZQUFtRSxZQUFnQjtRQUNqRixLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7UUFENkMsaUJBQVksR0FBWixZQUFZLENBQUk7UUFMMUUsWUFBTyxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7UUFFdkIsMEJBQXFCLEdBQUcsSUFBSSxDQUFDO1FBT3ZDLHNCQUFzQjtRQUNiLGVBQVUsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxZQUFZLEVBQVEsQ0FBQSxDQUFDLENBQUM7SUFIMUUsQ0FBQztJQUtELGNBQWM7SUFDSixZQUFZLENBQUMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUErQjtRQUNuRSxJQUFJLE1BQU0sRUFBRTtZQUNWLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUMvQjtRQUVELElBQUksS0FBSyxFQUFFO1lBQ1QsS0FBSyxNQUFNLEdBQUcsSUFBSSxLQUFLLEVBQUU7Z0JBQ3ZCLElBQUksS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUFFO29CQUNkLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2lCQUMvQjthQUNGO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsR0FBK0M7UUFDOUQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDOUUsQ0FBQztJQUVELE9BQU8sQ0FBQyxHQUFXLEVBQUUsR0FBd0I7UUFDM0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFFRCxnQkFBZ0I7SUFDUCxXQUFXO1FBRWxCLHNEQUFzRDtRQUN0RCxJQUFJLENBQUMsT0FBTyxDQUFDLG1CQUFtQixDQUFDO1lBQy9CLEVBQUUsRUFBRSxHQUFHLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3JCLENBQUM7WUFDRCxPQUFPLEVBQUUsSUFBSSxDQUFDLHVCQUF1QjtTQUN0QyxFQUFFLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFFRDs7T0FFRztJQUNILFdBQVc7UUFDVCxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ3pCLENBQUM7O2tIQXREbUIscUJBQXFCLGtCQU9YLElBQUk7c0hBUGQscUJBQXFCOzJGQUFyQixxQkFBcUI7a0JBRDFDLFVBQVU7OzBCQVFjLE1BQU07MkJBQUMsSUFBSTs7MEJBQUcsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG1hcCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQ29tcG9uZW50U3RvcmUgfSBmcm9tICdAbmdyeC9jb21wb25lbnQtc3RvcmUnO1xuaW1wb3J0IHsgSW5qZWN0LCBPcHRpb25hbCwgSW5qZWN0YWJsZSwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBMb2NrU2V0LCBTdWJzY3JpcHRpb25PYmplY3QsIE9ic2VydmFibGVPclZhbHVlLCBhc09ic2VydmFibGUgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9ja1NldENvbXBvbmVudCB7XG4gIHJlYWRvbmx5IGxvY2tTZXQ6IExvY2tTZXQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG9ja1NldENvbXBvbmVudFN0b3JlQ29uZmlnIHtcbiAgcGFyZW50PzogTWF5YmU8T2JzZXJ2YWJsZTxMb2NrU2V0Q29tcG9uZW50Pj47XG4gIGxvY2tzPzoge1xuICAgIFtrZXk6IHN0cmluZ106IE9ic2VydmFibGU8Ym9vbGVhbj5cbiAgfTtcbn1cblxuLyoqXG4gKiBBYnN0cmFjdCBDb21wb25lbnRTdG9yZSBleHRlbnNpb24gdGhhdCBwcm92aWRlcyBhIExvY2tTZXQgYW5kIE9uRGVzdHJveSBkZWxheWluZy9jbGVhbnVwLlxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTG9ja1NldENvbXBvbmVudFN0b3JlPFMgZXh0ZW5kcyBvYmplY3Q+IGV4dGVuZHMgQ29tcG9uZW50U3RvcmU8Uz4gaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuXG4gIHJlYWRvbmx5IGxvY2tTZXQgPSBuZXcgTG9ja1NldCgpO1xuXG4gIHByb3RlY3RlZCBsb2NrU2V0RGVzdHJveURlbGF5TXMgPSAyMDAwO1xuICBwcm90ZWN0ZWQgbG9ja1NldERlc3Ryb3lUaW1lb3V0TXM6IE1heWJlPG51bWJlcj47XG5cbiAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKEBJbmplY3QobnVsbCkgQE9wdGlvbmFsKCkgcHJvdGVjdGVkIHJlYWRvbmx5IGluaXRpYWxTdGF0ZT86IFMpIHtcbiAgICBzdXBlcihpbml0aWFsU3RhdGUpO1xuICB9XG5cbiAgLy8gTUFSSzogU3RhdGUgQ2hhbmdlc1xuICByZWFkb25seSByZXNldFN0b3JlID0gdGhpcy51cGRhdGVyKCgpID0+ICh7IC4uLnRoaXMuaW5pdGlhbFN0YXRlIH0gYXMgUykpO1xuXG4gIC8vIE1BUks6IExvY2tzXG4gIHByb3RlY3RlZCBzZXR1cExvY2tTZXQoeyBwYXJlbnQsIGxvY2tzIH06IExvY2tTZXRDb21wb25lbnRTdG9yZUNvbmZpZyk6IHZvaWQge1xuICAgIGlmIChwYXJlbnQpIHtcbiAgICAgIHRoaXMuc2V0UGFyZW50TG9ja1NldChwYXJlbnQpO1xuICAgIH1cblxuICAgIGlmIChsb2Nrcykge1xuICAgICAgZm9yIChjb25zdCBrZXkgaW4gbG9ja3MpIHtcbiAgICAgICAgaWYgKGxvY2tzW2tleV0pIHtcbiAgICAgICAgICB0aGlzLmFkZExvY2soa2V5LCBsb2Nrc1trZXldKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHNldFBhcmVudExvY2tTZXQob2JzOiBPYnNlcnZhYmxlT3JWYWx1ZTxNYXliZTxMb2NrU2V0Q29tcG9uZW50Pj4pOiB2b2lkIHtcbiAgICB0aGlzLmxvY2tTZXQuc2V0UGFyZW50TG9ja1NldChhc09ic2VydmFibGUob2JzKS5waXBlKG1hcCh4ID0+IHg/LmxvY2tTZXQpKSk7XG4gIH1cblxuICBhZGRMb2NrKGtleTogc3RyaW5nLCBvYnM6IE9ic2VydmFibGU8Ym9vbGVhbj4pOiB2b2lkIHtcbiAgICB0aGlzLmxvY2tTZXQuYWRkTG9jayhrZXksIG9icyk7XG4gIH1cblxuICAvLyBNQVJLOiBDbGVhbnVwXG4gIG92ZXJyaWRlIG5nT25EZXN0cm95KCk6IHZvaWQge1xuXG4gICAgLy8gV2FpdCBmb3IgYW55IGFjdGlvbnMgdG8gY29tcGxldGUgYmVmb3JlIGRlc3Ryb3lpbmcuXG4gICAgdGhpcy5sb2NrU2V0LmRlc3Ryb3lPbk5leHRVbmxvY2soe1xuICAgICAgZm46ICgpID0+IHtcbiAgICAgICAgdGhpcy5fZGVzdHJveU5vdygpO1xuICAgICAgfSxcbiAgICAgIHRpbWVvdXQ6IHRoaXMubG9ja1NldERlc3Ryb3lUaW1lb3V0TXMsXG4gICAgfSwgdGhpcy5sb2NrU2V0RGVzdHJveURlbGF5TXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIENvbXBsZXRlcyB0aGUgY2xlYW51cCBvZiB0aGUgb2JqZWN0LlxuICAgKi9cbiAgX2Rlc3Ryb3lOb3coKSB7XG4gICAgdGhpcy5sb2NrU2V0LmRlc3Ryb3koKTtcbiAgfVxuXG59XG4iXX0=
|
|
@@ -9,8 +9,8 @@ import { DateDistancePipe } from './datedistance.pipe';
|
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
export class DbxDatePipeModule {
|
|
11
11
|
}
|
|
12
|
-
DbxDatePipeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2
|
|
13
|
-
DbxDatePipeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2
|
|
12
|
+
DbxDatePipeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxDatePipeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
DbxDatePipeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxDatePipeModule, declarations: [DateFromToTimePipe,
|
|
14
14
|
DateFormatDistancePipe,
|
|
15
15
|
MinutesStringPipe,
|
|
16
16
|
TimeDistanceCountdownPipe,
|
|
@@ -25,8 +25,8 @@ DbxDatePipeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versi
|
|
|
25
25
|
DateDistancePipe,
|
|
26
26
|
ToJsDatePipe,
|
|
27
27
|
ToMinutesPipe] });
|
|
28
|
-
DbxDatePipeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2
|
|
28
|
+
DbxDatePipeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxDatePipeModule });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxDatePipeModule, decorators: [{
|
|
30
30
|
type: NgModule,
|
|
31
31
|
args: [{
|
|
32
32
|
exports: [
|
|
@@ -33,9 +33,9 @@ export class DateDistancePipe {
|
|
|
33
33
|
}
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
|
-
DateDistancePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2
|
|
37
|
-
DateDistancePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.2
|
|
38
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2
|
|
36
|
+
DateDistancePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateDistancePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
37
|
+
DateDistancePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateDistancePipe, name: "dateDistance", pure: false });
|
|
38
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateDistancePipe, decorators: [{
|
|
39
39
|
type: Pipe,
|
|
40
40
|
args: [{ name: 'dateDistance', pure: false }]
|
|
41
41
|
}] });
|
|
@@ -25,9 +25,9 @@ export class DateFormatDistancePipe {
|
|
|
25
25
|
return undefined;
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
|
-
DateFormatDistancePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2
|
|
29
|
-
DateFormatDistancePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.2
|
|
30
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2
|
|
28
|
+
DateFormatDistancePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateFormatDistancePipe, deps: [{ token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
29
|
+
DateFormatDistancePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateFormatDistancePipe, name: "dateFormatDistance", pure: false });
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateFormatDistancePipe, decorators: [{
|
|
31
31
|
type: Pipe,
|
|
32
32
|
args: [{ name: 'dateFormatDistance', pure: false }]
|
|
33
33
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
@@ -23,9 +23,9 @@ export class DateFromToTimePipe {
|
|
|
23
23
|
return undefined;
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
|
-
DateFromToTimePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2
|
|
27
|
-
DateFromToTimePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.2
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2
|
|
26
|
+
DateFromToTimePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateFromToTimePipe, deps: [{ token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
27
|
+
DateFromToTimePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateFromToTimePipe, name: "dateFromPlusTo" });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DateFromToTimePipe, decorators: [{
|
|
29
29
|
type: Pipe,
|
|
30
30
|
args: [{ name: 'dateFromPlusTo' }]
|
|
31
31
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
@@ -23,9 +23,9 @@ export class MinutesStringPipe {
|
|
|
23
23
|
}
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
|
-
MinutesStringPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2
|
|
27
|
-
MinutesStringPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.2
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2
|
|
26
|
+
MinutesStringPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: MinutesStringPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
27
|
+
MinutesStringPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: MinutesStringPipe, name: "minutesString", pure: false });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: MinutesStringPipe, decorators: [{
|
|
29
29
|
type: Pipe,
|
|
30
30
|
args: [{ name: 'minutesString', pure: false }]
|
|
31
31
|
}] });
|
|
@@ -21,9 +21,9 @@ export class TimeDistanceCountdownPipe {
|
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
|
-
TimeDistanceCountdownPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2
|
|
25
|
-
TimeDistanceCountdownPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.2
|
|
26
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2
|
|
24
|
+
TimeDistanceCountdownPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: TimeDistanceCountdownPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
25
|
+
TimeDistanceCountdownPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: TimeDistanceCountdownPipe, name: "timeCountdownDistance", pure: false });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: TimeDistanceCountdownPipe, decorators: [{
|
|
27
27
|
type: Pipe,
|
|
28
28
|
args: [{ name: 'timeCountdownDistance', pure: false }]
|
|
29
29
|
}] });
|
|
@@ -40,9 +40,9 @@ export class TimeDistancePipe {
|
|
|
40
40
|
}
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
|
-
TimeDistancePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2
|
|
44
|
-
TimeDistancePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.2
|
|
45
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2
|
|
43
|
+
TimeDistancePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: TimeDistancePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
44
|
+
TimeDistancePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: TimeDistancePipe, name: "timeDistance", pure: false });
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: TimeDistancePipe, decorators: [{
|
|
46
46
|
type: Pipe,
|
|
47
47
|
args: [{ name: 'timeDistance', pure: false }]
|
|
48
48
|
}] });
|
|
@@ -1,18 +1,26 @@
|
|
|
1
|
+
import { isValid } from 'date-fns';
|
|
1
2
|
import { Pipe } from '@angular/core';
|
|
2
3
|
import { toJsDate } from '@dereekb/date';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export class ToJsDatePipe {
|
|
5
6
|
static toJsDate(input) {
|
|
6
|
-
|
|
7
|
+
let date;
|
|
8
|
+
if (input != null) {
|
|
9
|
+
date = toJsDate(input);
|
|
10
|
+
if (!isValid(date)) {
|
|
11
|
+
date = undefined;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
return date;
|
|
7
15
|
}
|
|
8
16
|
transform(input) {
|
|
9
17
|
return ToJsDatePipe.toJsDate(input);
|
|
10
18
|
}
|
|
11
19
|
}
|
|
12
|
-
ToJsDatePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2
|
|
13
|
-
ToJsDatePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.2
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2
|
|
20
|
+
ToJsDatePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: ToJsDatePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
21
|
+
ToJsDatePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: ToJsDatePipe, name: "toJsDate" });
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: ToJsDatePipe, decorators: [{
|
|
15
23
|
type: Pipe,
|
|
16
24
|
args: [{ name: 'toJsDate' }]
|
|
17
25
|
}] });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9qc2RhdGUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1jb3JlL3NyYy9saWIvcGlwZS9kYXRlL3RvanNkYXRlLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUNuQyxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUl6QyxNQUFNLE9BQU8sWUFBWTtJQUVoQixNQUFNLENBQUMsUUFBUSxDQUFDLEtBQThCO1FBQ25ELElBQUksSUFBaUIsQ0FBQztRQUV0QixJQUFJLEtBQUssSUFBSSxJQUFJLEVBQUU7WUFDakIsSUFBSSxHQUFHLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUV2QixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFO2dCQUNsQixJQUFJLEdBQUcsU0FBUyxDQUFDO2FBQ2xCO1NBQ0Y7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxTQUFTLENBQUMsS0FBOEI7UUFDdEMsT0FBTyxZQUFZLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3RDLENBQUM7O3lHQWxCVSxZQUFZO3VHQUFaLFlBQVk7MkZBQVosWUFBWTtrQkFEeEIsSUFBSTttQkFBQyxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1ZhbGlkIH0gZnJvbSAnZGF0ZS1mbnMnO1xuaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdG9Kc0RhdGUgfSBmcm9tICdAZGVyZWVrYi9kYXRlJztcbmltcG9ydCB7IERhdGVPckRhdGVTdHJpbmcsIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbkBQaXBlKHsgbmFtZTogJ3RvSnNEYXRlJyB9KVxuZXhwb3J0IGNsYXNzIFRvSnNEYXRlUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuXG4gIHB1YmxpYyBzdGF0aWMgdG9Kc0RhdGUoaW5wdXQ6IE1heWJlPERhdGVPckRhdGVTdHJpbmc+KTogTWF5YmU8RGF0ZT4ge1xuICAgIGxldCBkYXRlOiBNYXliZTxEYXRlPjtcbiAgICBcbiAgICBpZiAoaW5wdXQgIT0gbnVsbCkge1xuICAgICAgZGF0ZSA9IHRvSnNEYXRlKGlucHV0KTtcblxuICAgICAgaWYgKCFpc1ZhbGlkKGRhdGUpKSB7XG4gICAgICAgIGRhdGUgPSB1bmRlZmluZWQ7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGRhdGU7XG4gIH1cblxuICB0cmFuc2Zvcm0oaW5wdXQ6IE1heWJlPERhdGVPckRhdGVTdHJpbmc+KTogTWF5YmU8RGF0ZT4ge1xuICAgIHJldHVybiBUb0pzRGF0ZVBpcGUudG9Kc0RhdGUoaW5wdXQpO1xuICB9XG5cbn1cbiJdfQ==
|