@nativescript-community/ui-material-bottomsheet 7.2.1 → 7.2.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.
- package/angular/bottomsheet.module.d.ts +10 -0
- package/angular/bottomsheet.service.d.ts +28 -0
- package/angular/esm2022/bottomsheet.module.mjs +27 -0
- package/angular/esm2022/bottomsheet.service.mjs +118 -0
- package/angular/{fesm2020 → fesm2022}/nativescript-community-ui-material-bottomsheet-angular.mjs +15 -13
- package/angular/{fesm2020 → fesm2022}/nativescript-community-ui-material-bottomsheet-angular.mjs.map +1 -1
- package/angular/index.d.ts +2 -0
- package/angular/package.json +4 -10
- package/package.json +3 -3
- package/angular/esm2020/bottomsheet.module.mjs +0 -27
- package/angular/esm2020/bottomsheet.service.mjs +0 -116
- package/angular/fesm2015/nativescript-community-ui-material-bottomsheet-angular.mjs +0 -150
- package/angular/fesm2015/nativescript-community-ui-material-bottomsheet-angular.mjs.map +0 -1
- /package/angular/{esm2020 → esm2022}/index.mjs +0 -0
- /package/angular/{esm2020 → esm2022}/nativescript-community-ui-material-bottomsheet-angular.mjs +0 -0
@@ -0,0 +1,10 @@
|
|
1
|
+
import { ModuleWithProviders } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export declare class NativeScriptMaterialBottomSheetModule {
|
4
|
+
private static initialized;
|
5
|
+
static forRoot(): ModuleWithProviders<NativeScriptMaterialBottomSheetModule>;
|
6
|
+
constructor();
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NativeScriptMaterialBottomSheetModule, never>;
|
8
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NativeScriptMaterialBottomSheetModule, never, never, never>;
|
9
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<NativeScriptMaterialBottomSheetModule>;
|
10
|
+
}
|
@@ -0,0 +1,28 @@
|
|
1
|
+
import { Type, ViewContainerRef } from '@angular/core';
|
2
|
+
import type { BottomSheetOptions as MaterialBottomSheetOptions } from '@nativescript-community/ui-material-bottomsheet';
|
3
|
+
import { Observable } from 'rxjs';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export type BaseShowBottomSheetOptions = Omit<MaterialBottomSheetOptions, 'closeCallback' | 'view'>;
|
6
|
+
export interface BottomSheetOptions extends BaseShowBottomSheetOptions {
|
7
|
+
viewContainerRef?: ViewContainerRef;
|
8
|
+
}
|
9
|
+
export declare class BottomSheetParams {
|
10
|
+
readonly context: any;
|
11
|
+
readonly closeCallback: (...args: any[]) => void;
|
12
|
+
constructor(context: any, closeCallback: (...args: any[]) => void);
|
13
|
+
}
|
14
|
+
export declare class BottomSheetService {
|
15
|
+
show<TResult = any>(type: Type<any>, options: BottomSheetOptions): Observable<TResult>;
|
16
|
+
showWithCloseCallback<TResult = any>(type: Type<any>, options: BottomSheetOptions): {
|
17
|
+
observable: Observable<TResult>;
|
18
|
+
closeCallback: () => void;
|
19
|
+
};
|
20
|
+
private getParentView;
|
21
|
+
private getFactoryResolver;
|
22
|
+
private createChildInjector;
|
23
|
+
private getBottomSheetParams;
|
24
|
+
private createDetachedLoader;
|
25
|
+
private loadComponent;
|
26
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BottomSheetService, never>;
|
27
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<BottomSheetService>;
|
28
|
+
}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { BottomSheetService } from './bottomsheet.service';
|
3
|
+
import { install } from '@nativescript-community/ui-material-bottomsheet';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export class NativeScriptMaterialBottomSheetModule {
|
6
|
+
// This flag help us to avoid problems when using the new development workflow
|
7
|
+
static initialized = false;
|
8
|
+
static forRoot() {
|
9
|
+
return {
|
10
|
+
ngModule: NativeScriptMaterialBottomSheetModule,
|
11
|
+
providers: [BottomSheetService],
|
12
|
+
};
|
13
|
+
}
|
14
|
+
constructor() {
|
15
|
+
if (!NativeScriptMaterialBottomSheetModule.initialized) {
|
16
|
+
install();
|
17
|
+
NativeScriptMaterialBottomSheetModule.initialized = true;
|
18
|
+
}
|
19
|
+
}
|
20
|
+
static ɵfac = function NativeScriptMaterialBottomSheetModule_Factory(t) { return new (t || NativeScriptMaterialBottomSheetModule)(); };
|
21
|
+
static ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: NativeScriptMaterialBottomSheetModule });
|
22
|
+
static ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({});
|
23
|
+
}
|
24
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NativeScriptMaterialBottomSheetModule, [{
|
25
|
+
type: NgModule
|
26
|
+
}], function () { return []; }, null); })();
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm90dG9tc2hlZXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2JvdHRvbXNoZWV0L2FuZ3VsYXIvYm90dG9tc2hlZXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTlELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpREFBaUQsQ0FBQzs7QUFHMUUsTUFBTSxPQUFPLHFDQUFxQztJQUM5Qyw4RUFBOEU7SUFDdEUsTUFBTSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7SUFFbkMsTUFBTSxDQUFDLE9BQU87UUFDVixPQUFPO1lBQ0gsUUFBUSxFQUFFLHFDQUFxQztZQUMvQyxTQUFTLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztTQUNsQyxDQUFDO0lBQ04sQ0FBQztJQUVEO1FBQ0ksSUFBSSxDQUFDLHFDQUFxQyxDQUFDLFdBQVcsRUFBRTtZQUNwRCxPQUFPLEVBQUUsQ0FBQztZQUNWLHFDQUFxQyxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7U0FDNUQ7SUFDTCxDQUFDOytGQWhCUSxxQ0FBcUM7NERBQXJDLHFDQUFxQzs7O3VGQUFyQyxxQ0FBcUM7Y0FEakQsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEJvdHRvbVNoZWV0U2VydmljZSB9IGZyb20gJy4vYm90dG9tc2hlZXQuc2VydmljZSc7XG5pbXBvcnQgeyBpbnN0YWxsIH0gZnJvbSAnQG5hdGl2ZXNjcmlwdC1jb21tdW5pdHkvdWktbWF0ZXJpYWwtYm90dG9tc2hlZXQnO1xuXG5ATmdNb2R1bGUoKVxuZXhwb3J0IGNsYXNzIE5hdGl2ZVNjcmlwdE1hdGVyaWFsQm90dG9tU2hlZXRNb2R1bGUge1xuICAgIC8vIFRoaXMgZmxhZyBoZWxwIHVzIHRvIGF2b2lkIHByb2JsZW1zIHdoZW4gdXNpbmcgdGhlIG5ldyBkZXZlbG9wbWVudCB3b3JrZmxvd1xuICAgIHByaXZhdGUgc3RhdGljIGluaXRpYWxpemVkID0gZmFsc2U7XG5cbiAgICBzdGF0aWMgZm9yUm9vdCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPE5hdGl2ZVNjcmlwdE1hdGVyaWFsQm90dG9tU2hlZXRNb2R1bGU+IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIG5nTW9kdWxlOiBOYXRpdmVTY3JpcHRNYXRlcmlhbEJvdHRvbVNoZWV0TW9kdWxlLFxuICAgICAgICAgICAgcHJvdmlkZXJzOiBbQm90dG9tU2hlZXRTZXJ2aWNlXSxcbiAgICAgICAgfTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGlmICghTmF0aXZlU2NyaXB0TWF0ZXJpYWxCb3R0b21TaGVldE1vZHVsZS5pbml0aWFsaXplZCkge1xuICAgICAgICAgICAgaW5zdGFsbCgpO1xuICAgICAgICAgICAgTmF0aXZlU2NyaXB0TWF0ZXJpYWxCb3R0b21TaGVldE1vZHVsZS5pbml0aWFsaXplZCA9IHRydWU7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
@@ -0,0 +1,118 @@
|
|
1
|
+
import { ComponentFactoryResolver, ComponentRef, Injectable, Injector, Type, ViewContainerRef } from '@angular/core';
|
2
|
+
import { AppHostView, DetachedLoader, once } from '@nativescript/angular';
|
3
|
+
import { LayoutBase, ProxyViewContainer, View } from '@nativescript/core';
|
4
|
+
import { Observable, Subject } from 'rxjs';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
export class BottomSheetParams {
|
7
|
+
context;
|
8
|
+
closeCallback;
|
9
|
+
constructor(context, closeCallback) {
|
10
|
+
this.context = context;
|
11
|
+
this.closeCallback = closeCallback;
|
12
|
+
}
|
13
|
+
}
|
14
|
+
export class BottomSheetService {
|
15
|
+
show(type, options) {
|
16
|
+
return this.showWithCloseCallback(type, options).observable;
|
17
|
+
}
|
18
|
+
showWithCloseCallback(type, options) {
|
19
|
+
if (!options.viewContainerRef) {
|
20
|
+
throw new Error('No viewContainerRef: Make sure you pass viewContainerRef in BottomSheetOptions.');
|
21
|
+
}
|
22
|
+
const sheetRef = {
|
23
|
+
result: new Subject()
|
24
|
+
};
|
25
|
+
const parentView = this.getParentView(options.viewContainerRef);
|
26
|
+
const factoryResolver = this.getFactoryResolver(options.viewContainerRef);
|
27
|
+
const bottomSheetParams = this.getBottomSheetParams(options.context, sheetRef);
|
28
|
+
sheetRef.detachedLoader = this.createDetachedLoader(factoryResolver, bottomSheetParams, options.viewContainerRef);
|
29
|
+
this.loadComponent(type, sheetRef).then((componentView) => {
|
30
|
+
parentView.showBottomSheet({
|
31
|
+
...options,
|
32
|
+
...bottomSheetParams,
|
33
|
+
view: componentView
|
34
|
+
});
|
35
|
+
});
|
36
|
+
return {
|
37
|
+
observable: sheetRef.result,
|
38
|
+
closeCallback: bottomSheetParams.closeCallback
|
39
|
+
};
|
40
|
+
}
|
41
|
+
getParentView(viewContainerRef) {
|
42
|
+
let parentView = viewContainerRef.element.nativeElement;
|
43
|
+
if (parentView instanceof AppHostView && parentView.ngAppRoot) {
|
44
|
+
parentView = parentView.ngAppRoot;
|
45
|
+
}
|
46
|
+
// _ngDialogRoot is the first child of the previously detached proxy.
|
47
|
+
// It should have 'viewController' (iOS) or '_dialogFragment' (Android) available for
|
48
|
+
// presenting future bottomSheets views.
|
49
|
+
if (parentView._ngDialogRoot) {
|
50
|
+
parentView = parentView._ngDialogRoot;
|
51
|
+
}
|
52
|
+
return parentView;
|
53
|
+
}
|
54
|
+
getFactoryResolver(componentContainer) {
|
55
|
+
// resolve from particular module (moduleRef)
|
56
|
+
// or from same module as parentView (viewContainerRef)
|
57
|
+
return componentContainer.injector.get(ComponentFactoryResolver);
|
58
|
+
}
|
59
|
+
createChildInjector(bottomSheetParams, containerRef) {
|
60
|
+
return Injector.create({
|
61
|
+
providers: [
|
62
|
+
{
|
63
|
+
provide: BottomSheetParams,
|
64
|
+
useValue: bottomSheetParams
|
65
|
+
}
|
66
|
+
],
|
67
|
+
parent: containerRef.injector
|
68
|
+
});
|
69
|
+
}
|
70
|
+
getBottomSheetParams(context, sheetRef) {
|
71
|
+
const closeCallback = once((args) => {
|
72
|
+
const { result, componentView, detachedLoader } = sheetRef;
|
73
|
+
result.next(args);
|
74
|
+
result.complete();
|
75
|
+
if (componentView) {
|
76
|
+
componentView.closeBottomSheet();
|
77
|
+
}
|
78
|
+
if (detachedLoader) {
|
79
|
+
detachedLoader.instance.detectChanges();
|
80
|
+
detachedLoader.destroy();
|
81
|
+
}
|
82
|
+
});
|
83
|
+
return new BottomSheetParams(context, closeCallback);
|
84
|
+
}
|
85
|
+
createDetachedLoader(factoryResolver, bottomSheetParams, viewContainerRef) {
|
86
|
+
const detachedLoaderFactory = factoryResolver.resolveComponentFactory(DetachedLoader);
|
87
|
+
const childInjector = this.createChildInjector(bottomSheetParams, viewContainerRef);
|
88
|
+
return viewContainerRef.createComponent(detachedLoaderFactory, 0, childInjector);
|
89
|
+
}
|
90
|
+
async loadComponent(type, sheetRef) {
|
91
|
+
try {
|
92
|
+
const componentRef = await sheetRef.detachedLoader.instance.loadComponent(type);
|
93
|
+
const detachedProxy = componentRef.location.nativeElement;
|
94
|
+
if (detachedProxy.getChildrenCount() > 1) {
|
95
|
+
throw new Error('BottomSheet content has more than one root view.');
|
96
|
+
}
|
97
|
+
sheetRef.componentView = detachedProxy.getChildAt(0);
|
98
|
+
if (sheetRef.componentView.parent instanceof LayoutBase) {
|
99
|
+
sheetRef.componentView.parent._ngDialogRoot = sheetRef.componentView;
|
100
|
+
sheetRef.componentView.parent.removeChild(sheetRef.componentView);
|
101
|
+
}
|
102
|
+
return sheetRef.componentView;
|
103
|
+
}
|
104
|
+
catch (err) {
|
105
|
+
console.error(err);
|
106
|
+
return null;
|
107
|
+
}
|
108
|
+
}
|
109
|
+
static ɵfac = function BottomSheetService_Factory(t) { return new (t || BottomSheetService)(); };
|
110
|
+
static ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: BottomSheetService, factory: BottomSheetService.ɵfac, providedIn: 'root' });
|
111
|
+
}
|
112
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BottomSheetService, [{
|
113
|
+
type: Injectable,
|
114
|
+
args: [{
|
115
|
+
providedIn: 'root'
|
116
|
+
}]
|
117
|
+
}], null, null); })();
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bottomsheet.service.js","sourceRoot":"","sources":["../../../../src/bottomsheet/angular/bottomsheet.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,YAAY,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAErH,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;AAQ3C,MAAM,OAAO,iBAAiB;IACS;IAA8B;IAAjE,YAAmC,OAAY,EAAkB,aAAgC;QAA9D,YAAO,GAAP,OAAO,CAAK;QAAkB,kBAAa,GAAb,aAAa,CAAmB;IAAG,CAAC;CACxG;AAaD,MAAM,OAAO,kBAAkB;IACpB,IAAI,CAAgB,IAAe,EAAE,OAA2B;QACnE,OAAO,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,UAAU,CAAC;IAChE,CAAC;IAEM,qBAAqB,CAAgB,IAAe,EAAE,OAA2B;QACpF,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,iFAAiF,CAAC,CAAC;SACtG;QAED,MAAM,QAAQ,GAAsB;YAChC,MAAM,EAAE,IAAI,OAAO,EAAE;SACxB,CAAC;QAEF,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAChE,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAC1E,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAE/E,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,oBAAoB,CAAC,eAAe,EAAE,iBAAiB,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAElH,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,EAAE;YACtD,UAAU,CAAC,eAAe,CAAC;gBACvB,GAAG,OAAO;gBACV,GAAG,iBAAiB;gBACpB,IAAI,EAAE,aAAa;aACtB,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QAEH,OAAO;YACH,UAAU,EAAE,QAAQ,CAAC,MAAM;YAC3B,aAAa,EAAE,iBAAiB,CAAC,aAAa;SACjD,CAAC;IACN,CAAC;IAEO,aAAa,CAAC,gBAAkC;QACpD,IAAI,UAAU,GAAG,gBAAgB,CAAC,OAAO,CAAC,aAAqB,CAAC;QAEhE,IAAI,UAAU,YAAY,WAAW,IAAI,UAAU,CAAC,SAAS,EAAE;YAC3D,UAAU,GAAG,UAAU,CAAC,SAAS,CAAC;SACrC;QAED,qEAAqE;QACrE,qFAAqF;QACrF,wCAAwC;QACxC,IAAK,UAAiC,CAAC,aAAa,EAAE;YAClD,UAAU,GAAI,UAAiC,CAAC,aAAa,CAAC;SACjE;QAED,OAAO,UAAU,CAAC;IACtB,CAAC;IAEO,kBAAkB,CAAC,kBAAoC;QAC3D,6CAA6C;QAC7C,uDAAuD;QACvD,OAAO,kBAAkB,CAAC,QAAQ,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;IACrE,CAAC;IAEO,mBAAmB,CAAC,iBAAoC,EAAE,YAA8B;QAC5F,OAAO,QAAQ,CAAC,MAAM,CAAC;YACnB,SAAS,EAAE;gBACP;oBACI,OAAO,EAAE,iBAAiB;oBAC1B,QAAQ,EAAE,iBAAiB;iBAC9B;aACJ;YACD,MAAM,EAAE,YAAY,CAAC,QAAQ;SAChC,CAAC,CAAC;IACP,CAAC;IAEO,oBAAoB,CAAC,OAAY,EAAE,QAAkB;QACzD,MAAM,aAAa,GAAG,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;YAChC,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,cAAc,EAAE,GAAG,QAAQ,CAAC;YAE3D,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClB,MAAM,CAAC,QAAQ,EAAE,CAAC;YAElB,IAAI,aAAa,EAAE;gBACf,aAAa,CAAC,gBAAgB,EAAE,CAAC;aACpC;YAED,IAAI,cAAc,EAAE;gBAChB,cAAc,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;gBACxC,cAAc,CAAC,OAAO,EAAE,CAAC;aAC5B;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,iBAAiB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IACzD,CAAC;IAEO,oBAAoB,CAAC,eAAyC,EAAE,iBAAoC,EAAE,gBAAkC;QAC5I,MAAM,qBAAqB,GAAG,eAAe,CAAC,uBAAuB,CAAC,cAAc,CAAC,CAAC;QACtF,MAAM,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,iBAAiB,EAAE,gBAAgB,CAAC,CAAC;QAEpF,OAAO,gBAAgB,CAAC,eAAe,CAAC,qBAAqB,EAAE,CAAC,EAAE,aAAa,CAAC,CAAC;IACrF,CAAC;IAEO,KAAK,CAAC,aAAa,CAAC,IAAe,EAAE,QAAkB;QAC3D,IAAI;YACA,MAAM,YAAY,GAAG,MAAM,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAChF,MAAM,aAAa,GAAG,YAAY,CAAC,QAAQ,CAAC,aAAmC,CAAC;YAEhF,IAAI,aAAa,CAAC,gBAAgB,EAAE,GAAG,CAAC,EAAE;gBACtC,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;aACvE;YAED,QAAQ,CAAC,aAAa,GAAG,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YAErD,IAAI,QAAQ,CAAC,aAAa,CAAC,MAAM,YAAY,UAAU,EAAE;gBACpD,QAAQ,CAAC,aAAa,CAAC,MAA6B,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;gBAC7F,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;aACrE;YAED,OAAO,QAAQ,CAAC,aAAa,CAAC;SACjC;QAAC,OAAO,GAAG,EAAE;YACV,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAEnB,OAAO,IAAI,CAAC;SACf;IACL,CAAC;4EAtHQ,kBAAkB;gEAAlB,kBAAkB,WAAlB,kBAAkB,mBAFf,MAAM;;uFAET,kBAAkB;cAH9B,UAAU;eAAC;gBACR,UAAU,EAAE,MAAM;aACrB","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Injectable, Injector, Type, ViewContainerRef } from '@angular/core';\nimport type { BottomSheetOptions as MaterialBottomSheetOptions } from '@nativescript-community/ui-material-bottomsheet';\nimport { AppHostView, DetachedLoader, once } from '@nativescript/angular';\nimport { LayoutBase, ProxyViewContainer, View } from '@nativescript/core';\nimport { Observable, Subject } from 'rxjs';\n\nexport type BaseShowBottomSheetOptions = Omit<MaterialBottomSheetOptions, 'closeCallback' | 'view'>;\n\nexport interface BottomSheetOptions extends BaseShowBottomSheetOptions {\n    viewContainerRef?: ViewContainerRef;\n}\n\nexport class BottomSheetParams {\n    public constructor(public readonly context: any, public readonly closeCallback: (...args) => void) {}\n}\n\ntype ViewWithDialogRoot = View & { _ngDialogRoot?: View };\n\ninterface SheetRef<TResult = unknown> {\n    detachedLoader?: ComponentRef<DetachedLoader>;\n    componentView?: View;\n    result: Subject<TResult>;\n}\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class BottomSheetService {\n    public show<TResult = any>(type: Type<any>, options: BottomSheetOptions): Observable<TResult> {\n        return this.showWithCloseCallback(type, options).observable;\n    }\n\n    public showWithCloseCallback<TResult = any>(type: Type<any>, options: BottomSheetOptions): { observable: Observable<TResult>; closeCallback: () => void } {\n        if (!options.viewContainerRef) {\n            throw new Error('No viewContainerRef: Make sure you pass viewContainerRef in BottomSheetOptions.');\n        }\n\n        const sheetRef: SheetRef<TResult> = {\n            result: new Subject()\n        };\n\n        const parentView = this.getParentView(options.viewContainerRef);\n        const factoryResolver = this.getFactoryResolver(options.viewContainerRef);\n        const bottomSheetParams = this.getBottomSheetParams(options.context, sheetRef);\n\n        sheetRef.detachedLoader = this.createDetachedLoader(factoryResolver, bottomSheetParams, options.viewContainerRef);\n\n        this.loadComponent(type, sheetRef).then((componentView) => {\n            parentView.showBottomSheet({\n                ...options,\n                ...bottomSheetParams,\n                view: componentView\n            });\n        });\n\n        return {\n            observable: sheetRef.result,\n            closeCallback: bottomSheetParams.closeCallback\n        };\n    }\n\n    private getParentView(viewContainerRef: ViewContainerRef): View {\n        let parentView = viewContainerRef.element.nativeElement as View;\n\n        if (parentView instanceof AppHostView && parentView.ngAppRoot) {\n            parentView = parentView.ngAppRoot;\n        }\n\n        // _ngDialogRoot is the first child of the previously detached proxy.\n        // It should have 'viewController' (iOS) or '_dialogFragment' (Android) available for\n        // presenting future bottomSheets views.\n        if ((parentView as ViewWithDialogRoot)._ngDialogRoot) {\n            parentView = (parentView as ViewWithDialogRoot)._ngDialogRoot;\n        }\n\n        return parentView;\n    }\n\n    private getFactoryResolver(componentContainer: ViewContainerRef): ComponentFactoryResolver {\n        // resolve from particular module (moduleRef)\n        // or from same module as parentView (viewContainerRef)\n        return componentContainer.injector.get(ComponentFactoryResolver);\n    }\n\n    private createChildInjector(bottomSheetParams: BottomSheetParams, containerRef: ViewContainerRef): Injector {\n        return Injector.create({\n            providers: [\n                {\n                    provide: BottomSheetParams,\n                    useValue: bottomSheetParams\n                }\n            ],\n            parent: containerRef.injector\n        });\n    }\n\n    private getBottomSheetParams(context: any, sheetRef: SheetRef): BottomSheetParams {\n        const closeCallback = once((args) => {\n            const { result, componentView, detachedLoader } = sheetRef;\n\n            result.next(args);\n            result.complete();\n\n            if (componentView) {\n                componentView.closeBottomSheet();\n            }\n\n            if (detachedLoader) {\n                detachedLoader.instance.detectChanges();\n                detachedLoader.destroy();\n            }\n        });\n\n        return new BottomSheetParams(context, closeCallback);\n    }\n\n    private createDetachedLoader(factoryResolver: ComponentFactoryResolver, bottomSheetParams: BottomSheetParams, viewContainerRef: ViewContainerRef): ComponentRef<DetachedLoader> {\n        const detachedLoaderFactory = factoryResolver.resolveComponentFactory(DetachedLoader);\n        const childInjector = this.createChildInjector(bottomSheetParams, viewContainerRef);\n\n        return viewContainerRef.createComponent(detachedLoaderFactory, 0, childInjector);\n    }\n\n    private async loadComponent(type: Type<any>, sheetRef: SheetRef): Promise<View> {\n        try {\n            const componentRef = await sheetRef.detachedLoader.instance.loadComponent(type);\n            const detachedProxy = componentRef.location.nativeElement as ProxyViewContainer;\n\n            if (detachedProxy.getChildrenCount() > 1) {\n                throw new Error('BottomSheet content has more than one root view.');\n            }\n\n            sheetRef.componentView = detachedProxy.getChildAt(0);\n\n            if (sheetRef.componentView.parent instanceof LayoutBase) {\n                (sheetRef.componentView.parent as ViewWithDialogRoot)._ngDialogRoot = sheetRef.componentView;\n                sheetRef.componentView.parent.removeChild(sheetRef.componentView);\n            }\n\n            return sheetRef.componentView;\n        } catch (err) {\n            console.error(err);\n\n            return null;\n        }\n    }\n}\n"]}
|
package/angular/{fesm2020 → fesm2022}/nativescript-community-ui-material-bottomsheet-angular.mjs
RENAMED
@@ -6,6 +6,8 @@ import { Subject } from 'rxjs';
|
|
6
6
|
import { install } from '@nativescript-community/ui-material-bottomsheet';
|
7
7
|
|
8
8
|
class BottomSheetParams {
|
9
|
+
context;
|
10
|
+
closeCallback;
|
9
11
|
constructor(context, closeCallback) {
|
10
12
|
this.context = context;
|
11
13
|
this.closeCallback = closeCallback;
|
@@ -106,9 +108,9 @@ class BottomSheetService {
|
|
106
108
|
return null;
|
107
109
|
}
|
108
110
|
}
|
111
|
+
static ɵfac = function BottomSheetService_Factory(t) { return new (t || BottomSheetService)(); };
|
112
|
+
static ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: BottomSheetService, factory: BottomSheetService.ɵfac, providedIn: 'root' });
|
109
113
|
}
|
110
|
-
BottomSheetService.ɵfac = function BottomSheetService_Factory(t) { return new (t || BottomSheetService)(); };
|
111
|
-
BottomSheetService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: BottomSheetService, factory: BottomSheetService.ɵfac, providedIn: 'root' });
|
112
114
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BottomSheetService, [{
|
113
115
|
type: Injectable,
|
114
116
|
args: [{
|
@@ -117,24 +119,24 @@ BottomSheetService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: Botto
|
|
117
119
|
}], null, null); })();
|
118
120
|
|
119
121
|
class NativeScriptMaterialBottomSheetModule {
|
120
|
-
|
121
|
-
|
122
|
-
install();
|
123
|
-
NativeScriptMaterialBottomSheetModule.initialized = true;
|
124
|
-
}
|
125
|
-
}
|
122
|
+
// This flag help us to avoid problems when using the new development workflow
|
123
|
+
static initialized = false;
|
126
124
|
static forRoot() {
|
127
125
|
return {
|
128
126
|
ngModule: NativeScriptMaterialBottomSheetModule,
|
129
127
|
providers: [BottomSheetService],
|
130
128
|
};
|
131
129
|
}
|
130
|
+
constructor() {
|
131
|
+
if (!NativeScriptMaterialBottomSheetModule.initialized) {
|
132
|
+
install();
|
133
|
+
NativeScriptMaterialBottomSheetModule.initialized = true;
|
134
|
+
}
|
135
|
+
}
|
136
|
+
static ɵfac = function NativeScriptMaterialBottomSheetModule_Factory(t) { return new (t || NativeScriptMaterialBottomSheetModule)(); };
|
137
|
+
static ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: NativeScriptMaterialBottomSheetModule });
|
138
|
+
static ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({});
|
132
139
|
}
|
133
|
-
// This flag help us to avoid problems when using the new development workflow
|
134
|
-
NativeScriptMaterialBottomSheetModule.initialized = false;
|
135
|
-
NativeScriptMaterialBottomSheetModule.ɵfac = function NativeScriptMaterialBottomSheetModule_Factory(t) { return new (t || NativeScriptMaterialBottomSheetModule)(); };
|
136
|
-
NativeScriptMaterialBottomSheetModule.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: NativeScriptMaterialBottomSheetModule });
|
137
|
-
NativeScriptMaterialBottomSheetModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({});
|
138
140
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NativeScriptMaterialBottomSheetModule, [{
|
139
141
|
type: NgModule
|
140
142
|
}], function () { return []; }, null); })();
|
package/angular/{fesm2020 → fesm2022}/nativescript-community-ui-material-bottomsheet-angular.mjs.map
RENAMED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"nativescript-community-ui-material-bottomsheet-angular.mjs","sources":["../../../../src/bottomsheet/angular/bottomsheet.service.ts","../../../../src/bottomsheet/angular/bottomsheet.module.ts","../../../../src/bottomsheet/angular/nativescript-community-ui-material-bottomsheet-angular.ts"],"sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Injectable, Injector, Type, ViewContainerRef } from '@angular/core';\nimport type { BottomSheetOptions as MaterialBottomSheetOptions } from '@nativescript-community/ui-material-bottomsheet';\nimport { AppHostView, DetachedLoader, once } from '@nativescript/angular';\nimport { LayoutBase, ProxyViewContainer, View } from '@nativescript/core';\nimport { Observable, Subject } from 'rxjs';\n\nexport type BaseShowBottomSheetOptions = Omit<MaterialBottomSheetOptions, 'closeCallback' | 'view'>;\n\nexport interface BottomSheetOptions extends BaseShowBottomSheetOptions {\n viewContainerRef?: ViewContainerRef;\n}\n\nexport class BottomSheetParams {\n public constructor(public readonly context: any, public readonly closeCallback: (...args) => void) {}\n}\n\ntype ViewWithDialogRoot = View & { _ngDialogRoot?: View };\n\ninterface SheetRef<TResult = unknown> {\n detachedLoader?: ComponentRef<DetachedLoader>;\n componentView?: View;\n result: Subject<TResult>;\n}\n\n@Injectable({\n providedIn: 'root'\n})\nexport class BottomSheetService {\n public show<TResult = any>(type: Type<any>, options: BottomSheetOptions): Observable<TResult> {\n return this.showWithCloseCallback(type, options).observable;\n }\n\n public showWithCloseCallback<TResult = any>(type: Type<any>, options: BottomSheetOptions): { observable: Observable<TResult>; closeCallback: () => void } {\n if (!options.viewContainerRef) {\n throw new Error('No viewContainerRef: Make sure you pass viewContainerRef in BottomSheetOptions.');\n }\n\n const sheetRef: SheetRef<TResult> = {\n result: new Subject()\n };\n\n const parentView = this.getParentView(options.viewContainerRef);\n const factoryResolver = this.getFactoryResolver(options.viewContainerRef);\n const bottomSheetParams = this.getBottomSheetParams(options.context, sheetRef);\n\n sheetRef.detachedLoader = this.createDetachedLoader(factoryResolver, bottomSheetParams, options.viewContainerRef);\n\n this.loadComponent(type, sheetRef).then((componentView) => {\n parentView.showBottomSheet({\n ...options,\n ...bottomSheetParams,\n view: componentView\n });\n });\n\n return {\n observable: sheetRef.result,\n closeCallback: bottomSheetParams.closeCallback\n };\n }\n\n private getParentView(viewContainerRef: ViewContainerRef): View {\n let parentView = viewContainerRef.element.nativeElement as View;\n\n if (parentView instanceof AppHostView && parentView.ngAppRoot) {\n parentView = parentView.ngAppRoot;\n }\n\n // _ngDialogRoot is the first child of the previously detached proxy.\n // It should have 'viewController' (iOS) or '_dialogFragment' (Android) available for\n // presenting future bottomSheets views.\n if ((parentView as ViewWithDialogRoot)._ngDialogRoot) {\n parentView = (parentView as ViewWithDialogRoot)._ngDialogRoot;\n }\n\n return parentView;\n }\n\n private getFactoryResolver(componentContainer: ViewContainerRef): ComponentFactoryResolver {\n // resolve from particular module (moduleRef)\n // or from same module as parentView (viewContainerRef)\n return componentContainer.injector.get(ComponentFactoryResolver);\n }\n\n private createChildInjector(bottomSheetParams: BottomSheetParams, containerRef: ViewContainerRef): Injector {\n return Injector.create({\n providers: [\n {\n provide: BottomSheetParams,\n useValue: bottomSheetParams\n }\n ],\n parent: containerRef.injector\n });\n }\n\n private getBottomSheetParams(context: any, sheetRef: SheetRef): BottomSheetParams {\n const closeCallback = once((args) => {\n const { result, componentView, detachedLoader } = sheetRef;\n\n result.next(args);\n result.complete();\n\n if (componentView) {\n componentView.closeBottomSheet();\n }\n\n if (detachedLoader) {\n detachedLoader.instance.detectChanges();\n detachedLoader.destroy();\n }\n });\n\n return new BottomSheetParams(context, closeCallback);\n }\n\n private createDetachedLoader(factoryResolver: ComponentFactoryResolver, bottomSheetParams: BottomSheetParams, viewContainerRef: ViewContainerRef): ComponentRef<DetachedLoader> {\n const detachedLoaderFactory = factoryResolver.resolveComponentFactory(DetachedLoader);\n const childInjector = this.createChildInjector(bottomSheetParams, viewContainerRef);\n\n return viewContainerRef.createComponent(detachedLoaderFactory, 0, childInjector);\n }\n\n private async loadComponent(type: Type<any>, sheetRef: SheetRef): Promise<View> {\n try {\n const componentRef = await sheetRef.detachedLoader.instance.loadComponent(type);\n const detachedProxy = componentRef.location.nativeElement as ProxyViewContainer;\n\n if (detachedProxy.getChildrenCount() > 1) {\n throw new Error('BottomSheet content has more than one root view.');\n }\n\n sheetRef.componentView = detachedProxy.getChildAt(0);\n\n if (sheetRef.componentView.parent instanceof LayoutBase) {\n (sheetRef.componentView.parent as ViewWithDialogRoot)._ngDialogRoot = sheetRef.componentView;\n sheetRef.componentView.parent.removeChild(sheetRef.componentView);\n }\n\n return sheetRef.componentView;\n } catch (err) {\n console.error(err);\n\n return null;\n }\n }\n}\n","import { ModuleWithProviders, NgModule } from '@angular/core';\n\nimport { BottomSheetService } from './bottomsheet.service';\nimport { install } from '@nativescript-community/ui-material-bottomsheet';\n\n@NgModule()\nexport class NativeScriptMaterialBottomSheetModule {\n // This flag help us to avoid problems when using the new development workflow\n private static initialized = false;\n\n static forRoot(): ModuleWithProviders<NativeScriptMaterialBottomSheetModule> {\n return {\n ngModule: NativeScriptMaterialBottomSheetModule,\n providers: [BottomSheetService],\n };\n }\n\n public constructor() {\n if (!NativeScriptMaterialBottomSheetModule.initialized) {\n install();\n NativeScriptMaterialBottomSheetModule.initialized = true;\n }\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
1
|
+
{"version":3,"file":"nativescript-community-ui-material-bottomsheet-angular.mjs","sources":["../../../../src/bottomsheet/angular/bottomsheet.service.ts","../../../../src/bottomsheet/angular/bottomsheet.module.ts","../../../../src/bottomsheet/angular/nativescript-community-ui-material-bottomsheet-angular.ts"],"sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Injectable, Injector, Type, ViewContainerRef } from '@angular/core';\nimport type { BottomSheetOptions as MaterialBottomSheetOptions } from '@nativescript-community/ui-material-bottomsheet';\nimport { AppHostView, DetachedLoader, once } from '@nativescript/angular';\nimport { LayoutBase, ProxyViewContainer, View } from '@nativescript/core';\nimport { Observable, Subject } from 'rxjs';\n\nexport type BaseShowBottomSheetOptions = Omit<MaterialBottomSheetOptions, 'closeCallback' | 'view'>;\n\nexport interface BottomSheetOptions extends BaseShowBottomSheetOptions {\n viewContainerRef?: ViewContainerRef;\n}\n\nexport class BottomSheetParams {\n public constructor(public readonly context: any, public readonly closeCallback: (...args) => void) {}\n}\n\ntype ViewWithDialogRoot = View & { _ngDialogRoot?: View };\n\ninterface SheetRef<TResult = unknown> {\n detachedLoader?: ComponentRef<DetachedLoader>;\n componentView?: View;\n result: Subject<TResult>;\n}\n\n@Injectable({\n providedIn: 'root'\n})\nexport class BottomSheetService {\n public show<TResult = any>(type: Type<any>, options: BottomSheetOptions): Observable<TResult> {\n return this.showWithCloseCallback(type, options).observable;\n }\n\n public showWithCloseCallback<TResult = any>(type: Type<any>, options: BottomSheetOptions): { observable: Observable<TResult>; closeCallback: () => void } {\n if (!options.viewContainerRef) {\n throw new Error('No viewContainerRef: Make sure you pass viewContainerRef in BottomSheetOptions.');\n }\n\n const sheetRef: SheetRef<TResult> = {\n result: new Subject()\n };\n\n const parentView = this.getParentView(options.viewContainerRef);\n const factoryResolver = this.getFactoryResolver(options.viewContainerRef);\n const bottomSheetParams = this.getBottomSheetParams(options.context, sheetRef);\n\n sheetRef.detachedLoader = this.createDetachedLoader(factoryResolver, bottomSheetParams, options.viewContainerRef);\n\n this.loadComponent(type, sheetRef).then((componentView) => {\n parentView.showBottomSheet({\n ...options,\n ...bottomSheetParams,\n view: componentView\n });\n });\n\n return {\n observable: sheetRef.result,\n closeCallback: bottomSheetParams.closeCallback\n };\n }\n\n private getParentView(viewContainerRef: ViewContainerRef): View {\n let parentView = viewContainerRef.element.nativeElement as View;\n\n if (parentView instanceof AppHostView && parentView.ngAppRoot) {\n parentView = parentView.ngAppRoot;\n }\n\n // _ngDialogRoot is the first child of the previously detached proxy.\n // It should have 'viewController' (iOS) or '_dialogFragment' (Android) available for\n // presenting future bottomSheets views.\n if ((parentView as ViewWithDialogRoot)._ngDialogRoot) {\n parentView = (parentView as ViewWithDialogRoot)._ngDialogRoot;\n }\n\n return parentView;\n }\n\n private getFactoryResolver(componentContainer: ViewContainerRef): ComponentFactoryResolver {\n // resolve from particular module (moduleRef)\n // or from same module as parentView (viewContainerRef)\n return componentContainer.injector.get(ComponentFactoryResolver);\n }\n\n private createChildInjector(bottomSheetParams: BottomSheetParams, containerRef: ViewContainerRef): Injector {\n return Injector.create({\n providers: [\n {\n provide: BottomSheetParams,\n useValue: bottomSheetParams\n }\n ],\n parent: containerRef.injector\n });\n }\n\n private getBottomSheetParams(context: any, sheetRef: SheetRef): BottomSheetParams {\n const closeCallback = once((args) => {\n const { result, componentView, detachedLoader } = sheetRef;\n\n result.next(args);\n result.complete();\n\n if (componentView) {\n componentView.closeBottomSheet();\n }\n\n if (detachedLoader) {\n detachedLoader.instance.detectChanges();\n detachedLoader.destroy();\n }\n });\n\n return new BottomSheetParams(context, closeCallback);\n }\n\n private createDetachedLoader(factoryResolver: ComponentFactoryResolver, bottomSheetParams: BottomSheetParams, viewContainerRef: ViewContainerRef): ComponentRef<DetachedLoader> {\n const detachedLoaderFactory = factoryResolver.resolveComponentFactory(DetachedLoader);\n const childInjector = this.createChildInjector(bottomSheetParams, viewContainerRef);\n\n return viewContainerRef.createComponent(detachedLoaderFactory, 0, childInjector);\n }\n\n private async loadComponent(type: Type<any>, sheetRef: SheetRef): Promise<View> {\n try {\n const componentRef = await sheetRef.detachedLoader.instance.loadComponent(type);\n const detachedProxy = componentRef.location.nativeElement as ProxyViewContainer;\n\n if (detachedProxy.getChildrenCount() > 1) {\n throw new Error('BottomSheet content has more than one root view.');\n }\n\n sheetRef.componentView = detachedProxy.getChildAt(0);\n\n if (sheetRef.componentView.parent instanceof LayoutBase) {\n (sheetRef.componentView.parent as ViewWithDialogRoot)._ngDialogRoot = sheetRef.componentView;\n sheetRef.componentView.parent.removeChild(sheetRef.componentView);\n }\n\n return sheetRef.componentView;\n } catch (err) {\n console.error(err);\n\n return null;\n }\n }\n}\n","import { ModuleWithProviders, NgModule } from '@angular/core';\n\nimport { BottomSheetService } from './bottomsheet.service';\nimport { install } from '@nativescript-community/ui-material-bottomsheet';\n\n@NgModule()\nexport class NativeScriptMaterialBottomSheetModule {\n // This flag help us to avoid problems when using the new development workflow\n private static initialized = false;\n\n static forRoot(): ModuleWithProviders<NativeScriptMaterialBottomSheetModule> {\n return {\n ngModule: NativeScriptMaterialBottomSheetModule,\n providers: [BottomSheetService],\n };\n }\n\n public constructor() {\n if (!NativeScriptMaterialBottomSheetModule.initialized) {\n install();\n NativeScriptMaterialBottomSheetModule.initialized = true;\n }\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
package/angular/package.json
CHANGED
@@ -1,11 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@nativescript-community/ui-material-bottomsheet-angular",
|
3
3
|
"main": "index.js",
|
4
|
-
"module": "
|
5
|
-
"es2020": "fesm2020/nativescript-community-ui-material-bottomsheet-angular.mjs",
|
6
|
-
"esm2020": "esm2020/nativescript-community-ui-material-bottomsheet-angular.mjs",
|
7
|
-
"fesm2020": "fesm2020/nativescript-community-ui-material-bottomsheet-angular.mjs",
|
8
|
-
"fesm2015": "fesm2015/nativescript-community-ui-material-bottomsheet-angular.mjs",
|
4
|
+
"module": "fesm2022/nativescript-community-ui-material-bottomsheet-angular.mjs",
|
9
5
|
"typings": "index.d.ts",
|
10
6
|
"exports": {
|
11
7
|
"./package.json": {
|
@@ -13,11 +9,9 @@
|
|
13
9
|
},
|
14
10
|
".": {
|
15
11
|
"types": "./index.d.ts",
|
16
|
-
"
|
17
|
-
"
|
18
|
-
"
|
19
|
-
"node": "./fesm2015/nativescript-community-ui-material-bottomsheet-angular.mjs",
|
20
|
-
"default": "./fesm2020/nativescript-community-ui-material-bottomsheet-angular.mjs"
|
12
|
+
"esm2022": "./esm2022/nativescript-community-ui-material-bottomsheet-angular.mjs",
|
13
|
+
"esm": "./esm2022/nativescript-community-ui-material-bottomsheet-angular.mjs",
|
14
|
+
"default": "./fesm2022/nativescript-community-ui-material-bottomsheet-angular.mjs"
|
21
15
|
}
|
22
16
|
},
|
23
17
|
"sideEffects": false,
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@nativescript-community/ui-material-bottomsheet",
|
3
|
-
"version": "7.2.
|
3
|
+
"version": "7.2.3",
|
4
4
|
"description": "Material Design Bottom Sheets slide up from the bottom of the screen to reveal more content. Bottom sheets integrate with the app to display supporting content or present deep-linked content from other apps.",
|
5
5
|
"main": "./bottomsheet",
|
6
6
|
"sideEffects": false,
|
@@ -46,7 +46,7 @@
|
|
46
46
|
},
|
47
47
|
"readmeFilename": "README.md",
|
48
48
|
"dependencies": {
|
49
|
-
"@nativescript-community/ui-material-core": "^7.2.
|
49
|
+
"@nativescript-community/ui-material-core": "^7.2.3"
|
50
50
|
},
|
51
|
-
"gitHead": "
|
51
|
+
"gitHead": "39a69cff4d06a9aa5f607680530c55004b8c1a54"
|
52
52
|
}
|
@@ -1,27 +0,0 @@
|
|
1
|
-
import { NgModule } from '@angular/core';
|
2
|
-
import { BottomSheetService } from './bottomsheet.service';
|
3
|
-
import { install } from '@nativescript-community/ui-material-bottomsheet';
|
4
|
-
import * as i0 from "@angular/core";
|
5
|
-
export class NativeScriptMaterialBottomSheetModule {
|
6
|
-
constructor() {
|
7
|
-
if (!NativeScriptMaterialBottomSheetModule.initialized) {
|
8
|
-
install();
|
9
|
-
NativeScriptMaterialBottomSheetModule.initialized = true;
|
10
|
-
}
|
11
|
-
}
|
12
|
-
static forRoot() {
|
13
|
-
return {
|
14
|
-
ngModule: NativeScriptMaterialBottomSheetModule,
|
15
|
-
providers: [BottomSheetService],
|
16
|
-
};
|
17
|
-
}
|
18
|
-
}
|
19
|
-
// This flag help us to avoid problems when using the new development workflow
|
20
|
-
NativeScriptMaterialBottomSheetModule.initialized = false;
|
21
|
-
NativeScriptMaterialBottomSheetModule.ɵfac = function NativeScriptMaterialBottomSheetModule_Factory(t) { return new (t || NativeScriptMaterialBottomSheetModule)(); };
|
22
|
-
NativeScriptMaterialBottomSheetModule.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: NativeScriptMaterialBottomSheetModule });
|
23
|
-
NativeScriptMaterialBottomSheetModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({});
|
24
|
-
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NativeScriptMaterialBottomSheetModule, [{
|
25
|
-
type: NgModule
|
26
|
-
}], function () { return []; }, null); })();
|
27
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm90dG9tc2hlZXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2JvdHRvbXNoZWV0L2FuZ3VsYXIvYm90dG9tc2hlZXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTlELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpREFBaUQsQ0FBQzs7QUFHMUUsTUFBTSxPQUFPLHFDQUFxQztJQVc5QztRQUNJLElBQUksQ0FBQyxxQ0FBcUMsQ0FBQyxXQUFXLEVBQUU7WUFDcEQsT0FBTyxFQUFFLENBQUM7WUFDVixxQ0FBcUMsQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1NBQzVEO0lBQ0wsQ0FBQztJQVpELE1BQU0sQ0FBQyxPQUFPO1FBQ1YsT0FBTztZQUNILFFBQVEsRUFBRSxxQ0FBcUM7WUFDL0MsU0FBUyxFQUFFLENBQUMsa0JBQWtCLENBQUM7U0FDbEMsQ0FBQztJQUNOLENBQUM7O0FBUkQsOEVBQThFO0FBQy9ELGlEQUFXLEdBQUcsS0FBSyxDQUFDOzBIQUYxQixxQ0FBcUM7dUZBQXJDLHFDQUFxQzs7dUZBQXJDLHFDQUFxQztjQURqRCxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQm90dG9tU2hlZXRTZXJ2aWNlIH0gZnJvbSAnLi9ib3R0b21zaGVldC5zZXJ2aWNlJztcbmltcG9ydCB7IGluc3RhbGwgfSBmcm9tICdAbmF0aXZlc2NyaXB0LWNvbW11bml0eS91aS1tYXRlcmlhbC1ib3R0b21zaGVldCc7XG5cbkBOZ01vZHVsZSgpXG5leHBvcnQgY2xhc3MgTmF0aXZlU2NyaXB0TWF0ZXJpYWxCb3R0b21TaGVldE1vZHVsZSB7XG4gICAgLy8gVGhpcyBmbGFnIGhlbHAgdXMgdG8gYXZvaWQgcHJvYmxlbXMgd2hlbiB1c2luZyB0aGUgbmV3IGRldmVsb3BtZW50IHdvcmtmbG93XG4gICAgcHJpdmF0ZSBzdGF0aWMgaW5pdGlhbGl6ZWQgPSBmYWxzZTtcblxuICAgIHN0YXRpYyBmb3JSb290KCk6IE1vZHVsZVdpdGhQcm92aWRlcnM8TmF0aXZlU2NyaXB0TWF0ZXJpYWxCb3R0b21TaGVldE1vZHVsZT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbmdNb2R1bGU6IE5hdGl2ZVNjcmlwdE1hdGVyaWFsQm90dG9tU2hlZXRNb2R1bGUsXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtCb3R0b21TaGVldFNlcnZpY2VdLFxuICAgICAgICB9O1xuICAgIH1cblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgaWYgKCFOYXRpdmVTY3JpcHRNYXRlcmlhbEJvdHRvbVNoZWV0TW9kdWxlLmluaXRpYWxpemVkKSB7XG4gICAgICAgICAgICBpbnN0YWxsKCk7XG4gICAgICAgICAgICBOYXRpdmVTY3JpcHRNYXRlcmlhbEJvdHRvbVNoZWV0TW9kdWxlLmluaXRpYWxpemVkID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|
@@ -1,116 +0,0 @@
|
|
1
|
-
import { ComponentFactoryResolver, ComponentRef, Injectable, Injector, Type, ViewContainerRef } from '@angular/core';
|
2
|
-
import { AppHostView, DetachedLoader, once } from '@nativescript/angular';
|
3
|
-
import { LayoutBase, ProxyViewContainer, View } from '@nativescript/core';
|
4
|
-
import { Observable, Subject } from 'rxjs';
|
5
|
-
import * as i0 from "@angular/core";
|
6
|
-
export class BottomSheetParams {
|
7
|
-
constructor(context, closeCallback) {
|
8
|
-
this.context = context;
|
9
|
-
this.closeCallback = closeCallback;
|
10
|
-
}
|
11
|
-
}
|
12
|
-
export class BottomSheetService {
|
13
|
-
show(type, options) {
|
14
|
-
return this.showWithCloseCallback(type, options).observable;
|
15
|
-
}
|
16
|
-
showWithCloseCallback(type, options) {
|
17
|
-
if (!options.viewContainerRef) {
|
18
|
-
throw new Error('No viewContainerRef: Make sure you pass viewContainerRef in BottomSheetOptions.');
|
19
|
-
}
|
20
|
-
const sheetRef = {
|
21
|
-
result: new Subject()
|
22
|
-
};
|
23
|
-
const parentView = this.getParentView(options.viewContainerRef);
|
24
|
-
const factoryResolver = this.getFactoryResolver(options.viewContainerRef);
|
25
|
-
const bottomSheetParams = this.getBottomSheetParams(options.context, sheetRef);
|
26
|
-
sheetRef.detachedLoader = this.createDetachedLoader(factoryResolver, bottomSheetParams, options.viewContainerRef);
|
27
|
-
this.loadComponent(type, sheetRef).then((componentView) => {
|
28
|
-
parentView.showBottomSheet({
|
29
|
-
...options,
|
30
|
-
...bottomSheetParams,
|
31
|
-
view: componentView
|
32
|
-
});
|
33
|
-
});
|
34
|
-
return {
|
35
|
-
observable: sheetRef.result,
|
36
|
-
closeCallback: bottomSheetParams.closeCallback
|
37
|
-
};
|
38
|
-
}
|
39
|
-
getParentView(viewContainerRef) {
|
40
|
-
let parentView = viewContainerRef.element.nativeElement;
|
41
|
-
if (parentView instanceof AppHostView && parentView.ngAppRoot) {
|
42
|
-
parentView = parentView.ngAppRoot;
|
43
|
-
}
|
44
|
-
// _ngDialogRoot is the first child of the previously detached proxy.
|
45
|
-
// It should have 'viewController' (iOS) or '_dialogFragment' (Android) available for
|
46
|
-
// presenting future bottomSheets views.
|
47
|
-
if (parentView._ngDialogRoot) {
|
48
|
-
parentView = parentView._ngDialogRoot;
|
49
|
-
}
|
50
|
-
return parentView;
|
51
|
-
}
|
52
|
-
getFactoryResolver(componentContainer) {
|
53
|
-
// resolve from particular module (moduleRef)
|
54
|
-
// or from same module as parentView (viewContainerRef)
|
55
|
-
return componentContainer.injector.get(ComponentFactoryResolver);
|
56
|
-
}
|
57
|
-
createChildInjector(bottomSheetParams, containerRef) {
|
58
|
-
return Injector.create({
|
59
|
-
providers: [
|
60
|
-
{
|
61
|
-
provide: BottomSheetParams,
|
62
|
-
useValue: bottomSheetParams
|
63
|
-
}
|
64
|
-
],
|
65
|
-
parent: containerRef.injector
|
66
|
-
});
|
67
|
-
}
|
68
|
-
getBottomSheetParams(context, sheetRef) {
|
69
|
-
const closeCallback = once((args) => {
|
70
|
-
const { result, componentView, detachedLoader } = sheetRef;
|
71
|
-
result.next(args);
|
72
|
-
result.complete();
|
73
|
-
if (componentView) {
|
74
|
-
componentView.closeBottomSheet();
|
75
|
-
}
|
76
|
-
if (detachedLoader) {
|
77
|
-
detachedLoader.instance.detectChanges();
|
78
|
-
detachedLoader.destroy();
|
79
|
-
}
|
80
|
-
});
|
81
|
-
return new BottomSheetParams(context, closeCallback);
|
82
|
-
}
|
83
|
-
createDetachedLoader(factoryResolver, bottomSheetParams, viewContainerRef) {
|
84
|
-
const detachedLoaderFactory = factoryResolver.resolveComponentFactory(DetachedLoader);
|
85
|
-
const childInjector = this.createChildInjector(bottomSheetParams, viewContainerRef);
|
86
|
-
return viewContainerRef.createComponent(detachedLoaderFactory, 0, childInjector);
|
87
|
-
}
|
88
|
-
async loadComponent(type, sheetRef) {
|
89
|
-
try {
|
90
|
-
const componentRef = await sheetRef.detachedLoader.instance.loadComponent(type);
|
91
|
-
const detachedProxy = componentRef.location.nativeElement;
|
92
|
-
if (detachedProxy.getChildrenCount() > 1) {
|
93
|
-
throw new Error('BottomSheet content has more than one root view.');
|
94
|
-
}
|
95
|
-
sheetRef.componentView = detachedProxy.getChildAt(0);
|
96
|
-
if (sheetRef.componentView.parent instanceof LayoutBase) {
|
97
|
-
sheetRef.componentView.parent._ngDialogRoot = sheetRef.componentView;
|
98
|
-
sheetRef.componentView.parent.removeChild(sheetRef.componentView);
|
99
|
-
}
|
100
|
-
return sheetRef.componentView;
|
101
|
-
}
|
102
|
-
catch (err) {
|
103
|
-
console.error(err);
|
104
|
-
return null;
|
105
|
-
}
|
106
|
-
}
|
107
|
-
}
|
108
|
-
BottomSheetService.ɵfac = function BottomSheetService_Factory(t) { return new (t || BottomSheetService)(); };
|
109
|
-
BottomSheetService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: BottomSheetService, factory: BottomSheetService.ɵfac, providedIn: 'root' });
|
110
|
-
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BottomSheetService, [{
|
111
|
-
type: Injectable,
|
112
|
-
args: [{
|
113
|
-
providedIn: 'root'
|
114
|
-
}]
|
115
|
-
}], null, null); })();
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bottomsheet.service.js","sourceRoot":"","sources":["../../../../src/bottomsheet/angular/bottomsheet.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Injectable, Injector, Type, ViewContainerRef } from '@angular/core';\nimport type { BottomSheetOptions as MaterialBottomSheetOptions } from '@nativescript-community/ui-material-bottomsheet';\nimport { AppHostView, DetachedLoader, once } from '@nativescript/angular';\nimport { LayoutBase, ProxyViewContainer, View } from '@nativescript/core';\nimport { Observable, Subject } from 'rxjs';\n\nexport type BaseShowBottomSheetOptions = Omit<MaterialBottomSheetOptions, 'closeCallback' | 'view'>;\n\nexport interface BottomSheetOptions extends BaseShowBottomSheetOptions {\n    viewContainerRef?: ViewContainerRef;\n}\n\nexport class BottomSheetParams {\n    public constructor(public readonly context: any, public readonly closeCallback: (...args) => void) {}\n}\n\ntype ViewWithDialogRoot = View & { _ngDialogRoot?: View };\n\ninterface SheetRef<TResult = unknown> {\n    detachedLoader?: ComponentRef<DetachedLoader>;\n    componentView?: View;\n    result: Subject<TResult>;\n}\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class BottomSheetService {\n    public show<TResult = any>(type: Type<any>, options: BottomSheetOptions): Observable<TResult> {\n        return this.showWithCloseCallback(type, options).observable;\n    }\n\n    public showWithCloseCallback<TResult = any>(type: Type<any>, options: BottomSheetOptions): { observable: Observable<TResult>; closeCallback: () => void } {\n        if (!options.viewContainerRef) {\n            throw new Error('No viewContainerRef: Make sure you pass viewContainerRef in BottomSheetOptions.');\n        }\n\n        const sheetRef: SheetRef<TResult> = {\n            result: new Subject()\n        };\n\n        const parentView = this.getParentView(options.viewContainerRef);\n        const factoryResolver = this.getFactoryResolver(options.viewContainerRef);\n        const bottomSheetParams = this.getBottomSheetParams(options.context, sheetRef);\n\n        sheetRef.detachedLoader = this.createDetachedLoader(factoryResolver, bottomSheetParams, options.viewContainerRef);\n\n        this.loadComponent(type, sheetRef).then((componentView) => {\n            parentView.showBottomSheet({\n                ...options,\n                ...bottomSheetParams,\n                view: componentView\n            });\n        });\n\n        return {\n            observable: sheetRef.result,\n            closeCallback: bottomSheetParams.closeCallback\n        };\n    }\n\n    private getParentView(viewContainerRef: ViewContainerRef): View {\n        let parentView = viewContainerRef.element.nativeElement as View;\n\n        if (parentView instanceof AppHostView && parentView.ngAppRoot) {\n            parentView = parentView.ngAppRoot;\n        }\n\n        // _ngDialogRoot is the first child of the previously detached proxy.\n        // It should have 'viewController' (iOS) or '_dialogFragment' (Android) available for\n        // presenting future bottomSheets views.\n        if ((parentView as ViewWithDialogRoot)._ngDialogRoot) {\n            parentView = (parentView as ViewWithDialogRoot)._ngDialogRoot;\n        }\n\n        return parentView;\n    }\n\n    private getFactoryResolver(componentContainer: ViewContainerRef): ComponentFactoryResolver {\n        // resolve from particular module (moduleRef)\n        // or from same module as parentView (viewContainerRef)\n        return componentContainer.injector.get(ComponentFactoryResolver);\n    }\n\n    private createChildInjector(bottomSheetParams: BottomSheetParams, containerRef: ViewContainerRef): Injector {\n        return Injector.create({\n            providers: [\n                {\n                    provide: BottomSheetParams,\n                    useValue: bottomSheetParams\n                }\n            ],\n            parent: containerRef.injector\n        });\n    }\n\n    private getBottomSheetParams(context: any, sheetRef: SheetRef): BottomSheetParams {\n        const closeCallback = once((args) => {\n            const { result, componentView, detachedLoader } = sheetRef;\n\n            result.next(args);\n            result.complete();\n\n            if (componentView) {\n                componentView.closeBottomSheet();\n            }\n\n            if (detachedLoader) {\n                detachedLoader.instance.detectChanges();\n                detachedLoader.destroy();\n            }\n        });\n\n        return new BottomSheetParams(context, closeCallback);\n    }\n\n    private createDetachedLoader(factoryResolver: ComponentFactoryResolver, bottomSheetParams: BottomSheetParams, viewContainerRef: ViewContainerRef): ComponentRef<DetachedLoader> {\n        const detachedLoaderFactory = factoryResolver.resolveComponentFactory(DetachedLoader);\n        const childInjector = this.createChildInjector(bottomSheetParams, viewContainerRef);\n\n        return viewContainerRef.createComponent(detachedLoaderFactory, 0, childInjector);\n    }\n\n    private async loadComponent(type: Type<any>, sheetRef: SheetRef): Promise<View> {\n        try {\n            const componentRef = await sheetRef.detachedLoader.instance.loadComponent(type);\n            const detachedProxy = componentRef.location.nativeElement as ProxyViewContainer;\n\n            if (detachedProxy.getChildrenCount() > 1) {\n                throw new Error('BottomSheet content has more than one root view.');\n            }\n\n            sheetRef.componentView = detachedProxy.getChildAt(0);\n\n            if (sheetRef.componentView.parent instanceof LayoutBase) {\n                (sheetRef.componentView.parent as ViewWithDialogRoot)._ngDialogRoot = sheetRef.componentView;\n                sheetRef.componentView.parent.removeChild(sheetRef.componentView);\n            }\n\n            return sheetRef.componentView;\n        } catch (err) {\n            console.error(err);\n\n            return null;\n        }\n    }\n}\n"]}
|
@@ -1,150 +0,0 @@
|
|
1
|
-
import * as i0 from '@angular/core';
|
2
|
-
import { ComponentFactoryResolver, Injector, Injectable, NgModule } from '@angular/core';
|
3
|
-
import { __awaiter } from 'tslib';
|
4
|
-
import { AppHostView, once, DetachedLoader } from '@nativescript/angular';
|
5
|
-
import { LayoutBase } from '@nativescript/core';
|
6
|
-
import { Subject } from 'rxjs';
|
7
|
-
import { install } from '@nativescript-community/ui-material-bottomsheet';
|
8
|
-
|
9
|
-
class BottomSheetParams {
|
10
|
-
constructor(context, closeCallback) {
|
11
|
-
this.context = context;
|
12
|
-
this.closeCallback = closeCallback;
|
13
|
-
}
|
14
|
-
}
|
15
|
-
class BottomSheetService {
|
16
|
-
show(type, options) {
|
17
|
-
return this.showWithCloseCallback(type, options).observable;
|
18
|
-
}
|
19
|
-
showWithCloseCallback(type, options) {
|
20
|
-
if (!options.viewContainerRef) {
|
21
|
-
throw new Error('No viewContainerRef: Make sure you pass viewContainerRef in BottomSheetOptions.');
|
22
|
-
}
|
23
|
-
const sheetRef = {
|
24
|
-
result: new Subject()
|
25
|
-
};
|
26
|
-
const parentView = this.getParentView(options.viewContainerRef);
|
27
|
-
const factoryResolver = this.getFactoryResolver(options.viewContainerRef);
|
28
|
-
const bottomSheetParams = this.getBottomSheetParams(options.context, sheetRef);
|
29
|
-
sheetRef.detachedLoader = this.createDetachedLoader(factoryResolver, bottomSheetParams, options.viewContainerRef);
|
30
|
-
this.loadComponent(type, sheetRef).then((componentView) => {
|
31
|
-
parentView.showBottomSheet(Object.assign(Object.assign(Object.assign({}, options), bottomSheetParams), { view: componentView }));
|
32
|
-
});
|
33
|
-
return {
|
34
|
-
observable: sheetRef.result,
|
35
|
-
closeCallback: bottomSheetParams.closeCallback
|
36
|
-
};
|
37
|
-
}
|
38
|
-
getParentView(viewContainerRef) {
|
39
|
-
let parentView = viewContainerRef.element.nativeElement;
|
40
|
-
if (parentView instanceof AppHostView && parentView.ngAppRoot) {
|
41
|
-
parentView = parentView.ngAppRoot;
|
42
|
-
}
|
43
|
-
// _ngDialogRoot is the first child of the previously detached proxy.
|
44
|
-
// It should have 'viewController' (iOS) or '_dialogFragment' (Android) available for
|
45
|
-
// presenting future bottomSheets views.
|
46
|
-
if (parentView._ngDialogRoot) {
|
47
|
-
parentView = parentView._ngDialogRoot;
|
48
|
-
}
|
49
|
-
return parentView;
|
50
|
-
}
|
51
|
-
getFactoryResolver(componentContainer) {
|
52
|
-
// resolve from particular module (moduleRef)
|
53
|
-
// or from same module as parentView (viewContainerRef)
|
54
|
-
return componentContainer.injector.get(ComponentFactoryResolver);
|
55
|
-
}
|
56
|
-
createChildInjector(bottomSheetParams, containerRef) {
|
57
|
-
return Injector.create({
|
58
|
-
providers: [
|
59
|
-
{
|
60
|
-
provide: BottomSheetParams,
|
61
|
-
useValue: bottomSheetParams
|
62
|
-
}
|
63
|
-
],
|
64
|
-
parent: containerRef.injector
|
65
|
-
});
|
66
|
-
}
|
67
|
-
getBottomSheetParams(context, sheetRef) {
|
68
|
-
const closeCallback = once((args) => {
|
69
|
-
const { result, componentView, detachedLoader } = sheetRef;
|
70
|
-
result.next(args);
|
71
|
-
result.complete();
|
72
|
-
if (componentView) {
|
73
|
-
componentView.closeBottomSheet();
|
74
|
-
}
|
75
|
-
if (detachedLoader) {
|
76
|
-
detachedLoader.instance.detectChanges();
|
77
|
-
detachedLoader.destroy();
|
78
|
-
}
|
79
|
-
});
|
80
|
-
return new BottomSheetParams(context, closeCallback);
|
81
|
-
}
|
82
|
-
createDetachedLoader(factoryResolver, bottomSheetParams, viewContainerRef) {
|
83
|
-
const detachedLoaderFactory = factoryResolver.resolveComponentFactory(DetachedLoader);
|
84
|
-
const childInjector = this.createChildInjector(bottomSheetParams, viewContainerRef);
|
85
|
-
return viewContainerRef.createComponent(detachedLoaderFactory, 0, childInjector);
|
86
|
-
}
|
87
|
-
loadComponent(type, sheetRef) {
|
88
|
-
return __awaiter(this, void 0, void 0, function* () {
|
89
|
-
try {
|
90
|
-
const componentRef = yield sheetRef.detachedLoader.instance.loadComponent(type);
|
91
|
-
const detachedProxy = componentRef.location.nativeElement;
|
92
|
-
if (detachedProxy.getChildrenCount() > 1) {
|
93
|
-
throw new Error('BottomSheet content has more than one root view.');
|
94
|
-
}
|
95
|
-
sheetRef.componentView = detachedProxy.getChildAt(0);
|
96
|
-
if (sheetRef.componentView.parent instanceof LayoutBase) {
|
97
|
-
sheetRef.componentView.parent._ngDialogRoot = sheetRef.componentView;
|
98
|
-
sheetRef.componentView.parent.removeChild(sheetRef.componentView);
|
99
|
-
}
|
100
|
-
return sheetRef.componentView;
|
101
|
-
}
|
102
|
-
catch (err) {
|
103
|
-
console.error(err);
|
104
|
-
return null;
|
105
|
-
}
|
106
|
-
});
|
107
|
-
}
|
108
|
-
}
|
109
|
-
BottomSheetService.ɵfac = function BottomSheetService_Factory(t) { return new (t || BottomSheetService)(); };
|
110
|
-
BottomSheetService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: BottomSheetService, factory: BottomSheetService.ɵfac, providedIn: 'root' });
|
111
|
-
(function () {
|
112
|
-
(typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BottomSheetService, [{
|
113
|
-
type: Injectable,
|
114
|
-
args: [{
|
115
|
-
providedIn: 'root'
|
116
|
-
}]
|
117
|
-
}], null, null);
|
118
|
-
})();
|
119
|
-
|
120
|
-
class NativeScriptMaterialBottomSheetModule {
|
121
|
-
constructor() {
|
122
|
-
if (!NativeScriptMaterialBottomSheetModule.initialized) {
|
123
|
-
install();
|
124
|
-
NativeScriptMaterialBottomSheetModule.initialized = true;
|
125
|
-
}
|
126
|
-
}
|
127
|
-
static forRoot() {
|
128
|
-
return {
|
129
|
-
ngModule: NativeScriptMaterialBottomSheetModule,
|
130
|
-
providers: [BottomSheetService],
|
131
|
-
};
|
132
|
-
}
|
133
|
-
}
|
134
|
-
// This flag help us to avoid problems when using the new development workflow
|
135
|
-
NativeScriptMaterialBottomSheetModule.initialized = false;
|
136
|
-
NativeScriptMaterialBottomSheetModule.ɵfac = function NativeScriptMaterialBottomSheetModule_Factory(t) { return new (t || NativeScriptMaterialBottomSheetModule)(); };
|
137
|
-
NativeScriptMaterialBottomSheetModule.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: NativeScriptMaterialBottomSheetModule });
|
138
|
-
NativeScriptMaterialBottomSheetModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({});
|
139
|
-
(function () {
|
140
|
-
(typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NativeScriptMaterialBottomSheetModule, [{
|
141
|
-
type: NgModule
|
142
|
-
}], function () { return []; }, null);
|
143
|
-
})();
|
144
|
-
|
145
|
-
/**
|
146
|
-
* Generated bundle index. Do not edit.
|
147
|
-
*/
|
148
|
-
|
149
|
-
export { BottomSheetParams, BottomSheetService, NativeScriptMaterialBottomSheetModule };
|
150
|
-
//# sourceMappingURL=nativescript-community-ui-material-bottomsheet-angular.mjs.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"nativescript-community-ui-material-bottomsheet-angular.mjs","sources":["../../../../src/bottomsheet/angular/bottomsheet.service.ts","../../../../src/bottomsheet/angular/bottomsheet.module.ts","../../../../src/bottomsheet/angular/nativescript-community-ui-material-bottomsheet-angular.ts"],"sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Injectable, Injector, Type, ViewContainerRef } from '@angular/core';\nimport type { BottomSheetOptions as MaterialBottomSheetOptions } from '@nativescript-community/ui-material-bottomsheet';\nimport { AppHostView, DetachedLoader, once } from '@nativescript/angular';\nimport { LayoutBase, ProxyViewContainer, View } from '@nativescript/core';\nimport { Observable, Subject } from 'rxjs';\n\nexport type BaseShowBottomSheetOptions = Omit<MaterialBottomSheetOptions, 'closeCallback' | 'view'>;\n\nexport interface BottomSheetOptions extends BaseShowBottomSheetOptions {\n viewContainerRef?: ViewContainerRef;\n}\n\nexport class BottomSheetParams {\n public constructor(public readonly context: any, public readonly closeCallback: (...args) => void) {}\n}\n\ntype ViewWithDialogRoot = View & { _ngDialogRoot?: View };\n\ninterface SheetRef<TResult = unknown> {\n detachedLoader?: ComponentRef<DetachedLoader>;\n componentView?: View;\n result: Subject<TResult>;\n}\n\n@Injectable({\n providedIn: 'root'\n})\nexport class BottomSheetService {\n public show<TResult = any>(type: Type<any>, options: BottomSheetOptions): Observable<TResult> {\n return this.showWithCloseCallback(type, options).observable;\n }\n\n public showWithCloseCallback<TResult = any>(type: Type<any>, options: BottomSheetOptions): { observable: Observable<TResult>; closeCallback: () => void } {\n if (!options.viewContainerRef) {\n throw new Error('No viewContainerRef: Make sure you pass viewContainerRef in BottomSheetOptions.');\n }\n\n const sheetRef: SheetRef<TResult> = {\n result: new Subject()\n };\n\n const parentView = this.getParentView(options.viewContainerRef);\n const factoryResolver = this.getFactoryResolver(options.viewContainerRef);\n const bottomSheetParams = this.getBottomSheetParams(options.context, sheetRef);\n\n sheetRef.detachedLoader = this.createDetachedLoader(factoryResolver, bottomSheetParams, options.viewContainerRef);\n\n this.loadComponent(type, sheetRef).then((componentView) => {\n parentView.showBottomSheet({\n ...options,\n ...bottomSheetParams,\n view: componentView\n });\n });\n\n return {\n observable: sheetRef.result,\n closeCallback: bottomSheetParams.closeCallback\n };\n }\n\n private getParentView(viewContainerRef: ViewContainerRef): View {\n let parentView = viewContainerRef.element.nativeElement as View;\n\n if (parentView instanceof AppHostView && parentView.ngAppRoot) {\n parentView = parentView.ngAppRoot;\n }\n\n // _ngDialogRoot is the first child of the previously detached proxy.\n // It should have 'viewController' (iOS) or '_dialogFragment' (Android) available for\n // presenting future bottomSheets views.\n if ((parentView as ViewWithDialogRoot)._ngDialogRoot) {\n parentView = (parentView as ViewWithDialogRoot)._ngDialogRoot;\n }\n\n return parentView;\n }\n\n private getFactoryResolver(componentContainer: ViewContainerRef): ComponentFactoryResolver {\n // resolve from particular module (moduleRef)\n // or from same module as parentView (viewContainerRef)\n return componentContainer.injector.get(ComponentFactoryResolver);\n }\n\n private createChildInjector(bottomSheetParams: BottomSheetParams, containerRef: ViewContainerRef): Injector {\n return Injector.create({\n providers: [\n {\n provide: BottomSheetParams,\n useValue: bottomSheetParams\n }\n ],\n parent: containerRef.injector\n });\n }\n\n private getBottomSheetParams(context: any, sheetRef: SheetRef): BottomSheetParams {\n const closeCallback = once((args) => {\n const { result, componentView, detachedLoader } = sheetRef;\n\n result.next(args);\n result.complete();\n\n if (componentView) {\n componentView.closeBottomSheet();\n }\n\n if (detachedLoader) {\n detachedLoader.instance.detectChanges();\n detachedLoader.destroy();\n }\n });\n\n return new BottomSheetParams(context, closeCallback);\n }\n\n private createDetachedLoader(factoryResolver: ComponentFactoryResolver, bottomSheetParams: BottomSheetParams, viewContainerRef: ViewContainerRef): ComponentRef<DetachedLoader> {\n const detachedLoaderFactory = factoryResolver.resolveComponentFactory(DetachedLoader);\n const childInjector = this.createChildInjector(bottomSheetParams, viewContainerRef);\n\n return viewContainerRef.createComponent(detachedLoaderFactory, 0, childInjector);\n }\n\n private async loadComponent(type: Type<any>, sheetRef: SheetRef): Promise<View> {\n try {\n const componentRef = await sheetRef.detachedLoader.instance.loadComponent(type);\n const detachedProxy = componentRef.location.nativeElement as ProxyViewContainer;\n\n if (detachedProxy.getChildrenCount() > 1) {\n throw new Error('BottomSheet content has more than one root view.');\n }\n\n sheetRef.componentView = detachedProxy.getChildAt(0);\n\n if (sheetRef.componentView.parent instanceof LayoutBase) {\n (sheetRef.componentView.parent as ViewWithDialogRoot)._ngDialogRoot = sheetRef.componentView;\n sheetRef.componentView.parent.removeChild(sheetRef.componentView);\n }\n\n return sheetRef.componentView;\n } catch (err) {\n console.error(err);\n\n return null;\n }\n }\n}\n","import { ModuleWithProviders, NgModule } from '@angular/core';\n\nimport { BottomSheetService } from './bottomsheet.service';\nimport { install } from '@nativescript-community/ui-material-bottomsheet';\n\n@NgModule()\nexport class NativeScriptMaterialBottomSheetModule {\n // This flag help us to avoid problems when using the new development workflow\n private static initialized = false;\n\n static forRoot(): ModuleWithProviders<NativeScriptMaterialBottomSheetModule> {\n return {\n ngModule: NativeScriptMaterialBottomSheetModule,\n providers: [BottomSheetService],\n };\n }\n\n public constructor() {\n if (!NativeScriptMaterialBottomSheetModule.initialized) {\n install();\n NativeScriptMaterialBottomSheetModule.initialized = true;\n }\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
File without changes
|
/package/angular/{esm2020 → esm2022}/nativescript-community-ui-material-bottomsheet-angular.mjs
RENAMED
File without changes
|