@taiga-ui/addon-mobile 3.109.0 → 3.110.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/bundles/taiga-ui-addon-mobile-components-sheet-dialog.umd.js +59 -14
- package/bundles/taiga-ui-addon-mobile-components-sheet-dialog.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-mobile-components-theme-android.umd.js +1 -1
- package/bundles/taiga-ui-addon-mobile-components-theme-android.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-mobile-directives-responsive-dialog.umd.js +440 -0
- package/bundles/taiga-ui-addon-mobile-directives-responsive-dialog.umd.js.map +1 -0
- package/bundles/taiga-ui-addon-mobile-directives.umd.js +10 -4
- package/bundles/taiga-ui-addon-mobile-directives.umd.js.map +1 -1
- package/components/sheet-dialog/index.d.ts +1 -0
- package/components/sheet-dialog/sheet-dialog-close.directive.d.ts +12 -0
- package/components/sheet-dialog/sheet-dialog.module.d.ts +6 -5
- package/components/sheet-dialog/sheet-dialog.options.d.ts +2 -0
- package/directives/index.d.ts +1 -0
- package/directives/responsive-dialog/index.d.ts +3 -0
- package/directives/responsive-dialog/package.json +10 -0
- package/directives/responsive-dialog/responsive-dialog.directive.d.ts +7 -0
- package/directives/responsive-dialog/responsive-dialog.module.d.ts +7 -0
- package/directives/responsive-dialog/responsive-dialog.service.d.ts +22 -0
- package/directives/responsive-dialog/taiga-ui-addon-mobile-directives-responsive-dialog.d.ts +5 -0
- package/esm2015/components/sheet-dialog/index.js +2 -1
- package/esm2015/components/sheet-dialog/sheet-dialog-close.directive.js +28 -0
- package/esm2015/components/sheet-dialog/sheet-dialog.component.js +7 -5
- package/esm2015/components/sheet-dialog/sheet-dialog.module.js +17 -4
- package/esm2015/components/sheet-dialog/sheet-dialog.options.js +3 -1
- package/esm2015/components/theme-android/theme-android.component.js +1 -1
- package/esm2015/directives/index.js +2 -1
- package/esm2015/directives/responsive-dialog/index.js +4 -0
- package/esm2015/directives/responsive-dialog/responsive-dialog.directive.js +28 -0
- package/esm2015/directives/responsive-dialog/responsive-dialog.module.js +16 -0
- package/esm2015/directives/responsive-dialog/responsive-dialog.service.js +40 -0
- package/esm2015/directives/responsive-dialog/taiga-ui-addon-mobile-directives-responsive-dialog.js +5 -0
- package/fesm2015/taiga-ui-addon-mobile-components-sheet-dialog.js +50 -10
- package/fesm2015/taiga-ui-addon-mobile-components-sheet-dialog.js.map +1 -1
- package/fesm2015/taiga-ui-addon-mobile-components-theme-android.js +1 -1
- package/fesm2015/taiga-ui-addon-mobile-components-theme-android.js.map +1 -1
- package/fesm2015/taiga-ui-addon-mobile-directives-responsive-dialog.js +84 -0
- package/fesm2015/taiga-ui-addon-mobile-directives-responsive-dialog.js.map +1 -0
- package/fesm2015/taiga-ui-addon-mobile-directives.js +1 -0
- package/fesm2015/taiga-ui-addon-mobile-directives.js.map +1 -1
- package/package.json +4 -4
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AbstractTuiDialogDirective } from '@taiga-ui/cdk';
|
|
2
|
+
import { TuiDialogOptions } from '@taiga-ui/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class TuiResponsiveDialogDirective<T> extends AbstractTuiDialogDirective<TuiDialogOptions<T>> {
|
|
5
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiResponsiveDialogDirective<any>, never>;
|
|
6
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiResponsiveDialogDirective<any>, "ng-template[tuiResponsiveDialog]", never, { "options": "tuiResponsiveDialogOptions"; "open": "tuiResponsiveDialog"; }, { "openChange": "tuiResponsiveDialogChange"; }, never>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./responsive-dialog.directive";
|
|
3
|
+
export declare class TuiResponsiveDialogModule {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiResponsiveDialogModule, never>;
|
|
5
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiResponsiveDialogModule, [typeof i1.TuiResponsiveDialogDirective], never, [typeof i1.TuiResponsiveDialogDirective]>;
|
|
6
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<TuiResponsiveDialogModule>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { TuiSheetDialogOptions } from '@taiga-ui/addon-mobile/components/sheet-dialog';
|
|
2
|
+
import { TuiSheetDialogService } from '@taiga-ui/addon-mobile/components/sheet-dialog';
|
|
3
|
+
import { TuiDialogContext, TuiDialogOptions, TuiDialogService } from '@taiga-ui/core';
|
|
4
|
+
import type { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
5
|
+
import type { Observable } from 'rxjs';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export interface TuiResponsiveDialogOptions<I = undefined> extends Omit<TuiDialogOptions<I>, 'closeable' | 'label'>, TuiSheetDialogOptions<I> {
|
|
8
|
+
readonly label: PolymorpheusContent;
|
|
9
|
+
readonly closeable: boolean;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Same as `TuiDialogService` but automatically switches to `TuiSheetDialogService` on mobile
|
|
13
|
+
*/
|
|
14
|
+
export declare class TuiResponsiveDialogService {
|
|
15
|
+
readonly isMobile: boolean;
|
|
16
|
+
readonly dialogs: TuiDialogService;
|
|
17
|
+
readonly sheets: TuiSheetDialogService;
|
|
18
|
+
constructor(isMobile: boolean, dialogs: TuiDialogService, sheets: TuiSheetDialogService);
|
|
19
|
+
open<G = void>(content: PolymorpheusContent<TuiDialogContext<G> & TuiResponsiveDialogOptions<any>>, options?: Partial<TuiResponsiveDialogOptions<any>>): Observable<G>;
|
|
20
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiResponsiveDialogService, never>;
|
|
21
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<TuiResponsiveDialogService>;
|
|
22
|
+
}
|
|
@@ -3,4 +3,5 @@ export * from './sheet-dialog.directive';
|
|
|
3
3
|
export * from './sheet-dialog.module';
|
|
4
4
|
export * from './sheet-dialog.options';
|
|
5
5
|
export * from './sheet-dialog.service';
|
|
6
|
-
|
|
6
|
+
export * from './sheet-dialog-close.directive';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1tb2JpbGUvY29tcG9uZW50cy9zaGVldC1kaWFsb2cvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsZ0NBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NoZWV0LWRpYWxvZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaGVldC1kaWFsb2cuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vc2hlZXQtZGlhbG9nLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3NoZWV0LWRpYWxvZy5vcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vc2hlZXQtZGlhbG9nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9zaGVldC1kaWFsb2ctY2xvc2UuZGlyZWN0aXZlJztcbiJdfQ==
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Directive, ElementRef, Inject, NgZone, Output } from '@angular/core';
|
|
2
|
+
import { tuiTypedFromEvent, tuiZonefree } from '@taiga-ui/cdk';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export const TUI_SHEET_DIALOG_CLOSE = 'tui-sheet-dialog-close';
|
|
5
|
+
export class TuiSheetDialogCloseDirective {
|
|
6
|
+
constructor(zone, el) {
|
|
7
|
+
this.zone = zone;
|
|
8
|
+
this.el = el;
|
|
9
|
+
this.tuiSheetDialogClose = tuiTypedFromEvent(this.el.nativeElement, TUI_SHEET_DIALOG_CLOSE).pipe(tuiZonefree(this.zone));
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
TuiSheetDialogCloseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogCloseDirective, deps: [{ token: NgZone }, { token: ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
13
|
+
TuiSheetDialogCloseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiSheetDialogCloseDirective, selector: "[tuiSheetDialogClose]", outputs: { tuiSheetDialogClose: "tuiSheetDialogClose" }, ngImport: i0 });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogCloseDirective, decorators: [{
|
|
15
|
+
type: Directive,
|
|
16
|
+
args: [{
|
|
17
|
+
selector: '[tuiSheetDialogClose]',
|
|
18
|
+
}]
|
|
19
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone, decorators: [{
|
|
20
|
+
type: Inject,
|
|
21
|
+
args: [NgZone]
|
|
22
|
+
}] }, { type: i0.ElementRef, decorators: [{
|
|
23
|
+
type: Inject,
|
|
24
|
+
args: [ElementRef]
|
|
25
|
+
}] }]; }, propDecorators: { tuiSheetDialogClose: [{
|
|
26
|
+
type: Output
|
|
27
|
+
}] } });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hlZXQtZGlhbG9nLWNsb3NlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLW1vYmlsZS9jb21wb25lbnRzL3NoZWV0LWRpYWxvZy9zaGVldC1kaWFsb2ctY2xvc2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzVFLE9BQU8sRUFBQyxpQkFBaUIsRUFBRSxXQUFXLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBRzdELE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLHdCQUF3QixDQUFDO0FBSy9ELE1BQU0sT0FBTyw0QkFBNEI7SUFPckMsWUFDcUMsSUFBWSxFQUNSLEVBQTJCO1FBRC9CLFNBQUksR0FBSixJQUFJLENBQVE7UUFDUixPQUFFLEdBQUYsRUFBRSxDQUF5QjtRQVAzRCx3QkFBbUIsR0FBd0IsaUJBQWlCLENBQ2pFLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUNyQixzQkFBc0IsQ0FDekIsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBSzVCLENBQUM7OzBIQVZLLDRCQUE0QixrQkFRekIsTUFBTSxhQUNOLFVBQVU7OEdBVGIsNEJBQTRCOzRGQUE1Qiw0QkFBNEI7a0JBSHhDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHVCQUF1QjtpQkFDcEM7OzBCQVNRLE1BQU07MkJBQUMsTUFBTTs7MEJBQ2IsTUFBTTsyQkFBQyxVQUFVOzRDQVBiLG1CQUFtQjtzQkFEM0IsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbmplY3QsIE5nWm9uZSwgT3V0cHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7dHVpVHlwZWRGcm9tRXZlbnQsIHR1aVpvbmVmcmVlfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7T2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5cbmV4cG9ydCBjb25zdCBUVUlfU0hFRVRfRElBTE9HX0NMT1NFID0gJ3R1aS1zaGVldC1kaWFsb2ctY2xvc2UnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t0dWlTaGVldERpYWxvZ0Nsb3NlXScsXG59KVxuZXhwb3J0IGNsYXNzIFR1aVNoZWV0RGlhbG9nQ2xvc2VEaXJlY3RpdmUge1xuICAgIEBPdXRwdXQoKVxuICAgIHJlYWRvbmx5IHR1aVNoZWV0RGlhbG9nQ2xvc2U6IE9ic2VydmFibGU8dW5rbm93bj4gPSB0dWlUeXBlZEZyb21FdmVudChcbiAgICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LFxuICAgICAgICBUVUlfU0hFRVRfRElBTE9HX0NMT1NFLFxuICAgICkucGlwZSh0dWlab25lZnJlZSh0aGlzLnpvbmUpKTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KE5nWm9uZSkgcHJpdmF0ZSByZWFkb25seSB6b25lOiBOZ1pvbmUsXG4gICAgICAgIEBJbmplY3QoRWxlbWVudFJlZikgcHJpdmF0ZSByZWFkb25seSBlbDogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXG4gICAgKSB7fVxufVxuIl19
|
|
@@ -8,8 +8,9 @@ import { BehaviorSubject } from 'rxjs';
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "@angular/common";
|
|
10
10
|
import * as i2 from "@taiga-ui/cdk";
|
|
11
|
-
import * as i3 from "
|
|
12
|
-
import * as i4 from "
|
|
11
|
+
import * as i3 from "./sheet-dialog-close.directive";
|
|
12
|
+
import * as i4 from "@tinkoff/ng-polymorpheus";
|
|
13
|
+
import * as i5 from "rxjs";
|
|
13
14
|
// So we re-enter ngZone and trigger change detection
|
|
14
15
|
function isCloseable() {
|
|
15
16
|
return this.context.closeable;
|
|
@@ -74,7 +75,7 @@ export class TuiSheetDialogComponent {
|
|
|
74
75
|
}
|
|
75
76
|
}
|
|
76
77
|
TuiSheetDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogComponent, deps: [{ token: ElementRef }, { token: TUI_ANIMATIONS_DURATION }, { token: TUI_COMMON_ICONS }, { token: TUI_CLOSE_WORD }, { token: POLYMORPHEUS_CONTEXT }], target: i0.ɵɵFactoryTarget.Component });
|
|
77
|
-
TuiSheetDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiSheetDialogComponent, selector: "tui-sheet-dialog", host: { listeners: { "$.class._stuck": "stuck$", "document:touchstart.passive.silent": "onPointerChange(1)", "document:touchend.silent": "onPointerChange(-1)", "document:touchcancel.silent": "onPointerChange(-1)", "scroll.silent": "onPointerChange(0)" }, properties: { "$.class._stuck": "stuck$", "@tuiSlideInTop": "this.slideInTop", "style.top.px": "this.offset", "class._closeable": "this.closeable" } }, viewQueries: [{ propertyName: "sheet", first: true, predicate: ["sheet"], descendants: true }, { propertyName: "stopsRefs", predicate: ["stops"], descendants: true }], ngImport: i0, template: "<div class=\"t-stops\">\n <div\n *ngFor=\"let stop of context.stops\"\n #stops\n class=\"t-stop\"\n [style.margin-top]=\"stop\"\n ></div>\n</div>\n<div\n #sheet\n class=\"t-sheet\"\n [class.t-sheet_small]=\"isSmall\"\n (tuiClickOutside)=\"close()\"\n>\n <div
|
|
78
|
+
TuiSheetDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiSheetDialogComponent, selector: "tui-sheet-dialog", host: { listeners: { "$.class._stuck": "stuck$", "document:touchstart.passive.silent": "onPointerChange(1)", "document:touchend.silent": "onPointerChange(-1)", "document:touchcancel.silent": "onPointerChange(-1)", "scroll.silent": "onPointerChange(0)" }, properties: { "$.class._stuck": "stuck$", "class._fullscreen": "context.fullscreen === true", "@tuiSlideInTop": "this.slideInTop", "style.top.px": "this.offset", "class._closeable": "this.closeable" } }, viewQueries: [{ propertyName: "sheet", first: true, predicate: ["sheet"], descendants: true }, { propertyName: "stopsRefs", predicate: ["stops"], descendants: true }], ngImport: i0, template: "<div class=\"t-stops\">\n <div\n *ngFor=\"let stop of context.stops\"\n #stops\n class=\"t-stop\"\n [style.margin-top]=\"stop\"\n ></div>\n</div>\n<div\n #sheet\n class=\"t-sheet\"\n [class.t-sheet_small]=\"isSmall\"\n (tuiClickOutside)=\"close()\"\n (tuiSheetDialogClose)=\"close()\"\n>\n <div\n *ngIf=\"context.bar\"\n class=\"t-top\"\n ></div>\n <h2\n *ngIf=\"context.label\"\n class=\"t-heading\"\n [id]=\"context.id\"\n >\n <ng-container *polymorpheusOutlet=\"context.label as label; context: context\">\n {{ label }}\n </ng-container>\n </h2>\n <div\n *ngIf=\"context.content\"\n class=\"t-content\"\n >\n <ng-container *polymorpheusOutlet=\"context.content as text; context: context\">\n {{ text }}\n </ng-container>\n </div>\n</div>\n<div class=\"t-footer\"></div>\n", styles: [":host{position:fixed;top:0;left:0;bottom:0;right:0;right:-1rem;display:flex;flex-direction:column;-webkit-clip-path:inset(0 1rem 0 0 round .75rem .75rem 0 0);clip-path:inset(0 1rem 0 0 round .75rem .75rem 0 0);font:var(--tui-font-text-m);overflow-y:scroll;scroll-snap-type:y mandatory;overscroll-behavior:none;box-shadow:0 20rem var(--tui-elevation-01)}:host._closeable{display:block}:host._closeable .t-stops{display:flex}:host._fullscreen{display:block}:host._fullscreen .t-sheet{display:flex;flex-direction:column;min-block-size:calc(100% - 1rem)}:host._fullscreen .t-content{display:flex;flex-direction:column;flex-grow:1}.t-stops{display:none;height:100%;scroll-snap-stop:always;scroll-snap-align:start}.t-stop{scroll-snap-stop:normal;scroll-snap-align:start;height:1rem;width:1rem}.t-sheet{box-shadow:var(--tui-shadow);width:calc(100% - 1rem);border-radius:.75rem .75rem 0 0;padding:0 1rem;margin-top:auto;background:var(--tui-elevation-01);box-sizing:border-box;scroll-snap-stop:always;scroll-snap-align:start}@supports (-moz-appearance: none){.t-sheet_small{scroll-snap-align:end}}.t-top{position:-webkit-sticky;position:sticky;top:0;z-index:1;height:1.5rem;background:var(--tui-elevation-01)}.t-top:after{content:\"\";position:absolute;top:.5rem;left:50%;width:2rem;height:.25rem;transform:translate(-50%);background:var(--tui-base-09);opacity:.3;border-radius:1rem}.t-heading{position:-webkit-sticky;position:sticky;top:1.5rem;z-index:1;display:flex;margin:0;padding-bottom:1rem;font:var(--tui-font-heading-6);background:var(--tui-elevation-01)}.t-heading:last-child{margin-bottom:-.75rem}.t-heading:after{content:\"\";position:absolute;top:100%;left:0;right:0;height:1px;background:var(--tui-base-03);opacity:0}:host._stuck .t-heading:after{opacity:1}.t-close{right:-.25rem;flex-shrink:0;margin-left:auto}.t-content{position:relative;isolation:isolate}.t-content:nth-child(3){margin-top:1rem}.t-footer{height:1rem;scroll-snap-stop:always;scroll-snap-align:end;background:var(--tui-elevation-01)}\n"], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.TuiClickOutsideDirective, selector: "[tuiClickOutside]", outputs: ["tuiClickOutside"] }, { type: i3.TuiSheetDialogCloseDirective, selector: "[tuiSheetDialogClose]", outputs: ["tuiSheetDialogClose"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], animations: [tuiSlideInTop], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
78
79
|
__decorate([
|
|
79
80
|
shouldCall(isCloseable)
|
|
80
81
|
], TuiSheetDialogComponent.prototype, "close", null);
|
|
@@ -92,6 +93,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
92
93
|
host: {
|
|
93
94
|
'[$.class._stuck]': 'stuck$',
|
|
94
95
|
'($.class._stuck)': 'stuck$',
|
|
96
|
+
'[class._fullscreen]': 'context.fullscreen === true',
|
|
95
97
|
},
|
|
96
98
|
}]
|
|
97
99
|
}], ctorParameters: function () { return [{ type: i0.ElementRef, decorators: [{
|
|
@@ -103,7 +105,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
103
105
|
}] }, { type: undefined, decorators: [{
|
|
104
106
|
type: Inject,
|
|
105
107
|
args: [TUI_COMMON_ICONS]
|
|
106
|
-
}] }, { type:
|
|
108
|
+
}] }, { type: i5.Observable, decorators: [{
|
|
107
109
|
type: Inject,
|
|
108
110
|
args: [TUI_CLOSE_WORD]
|
|
109
111
|
}] }, { type: undefined, decorators: [{
|
|
@@ -137,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
137
139
|
type: HostListener,
|
|
138
140
|
args: ['scroll.silent', ['0']]
|
|
139
141
|
}], close: [], getStops: [] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sheet-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/addon-mobile/components/sheet-dialog/sheet-dialog.component.ts","../../../../../projects/addon-mobile/components/sheet-dialog/sheet-dialog.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    QueryList,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\nimport {EMPTY_QUERY, TuiDialog, tuiPure} from '@taiga-ui/cdk';\nimport {\n    TUI_ANIMATIONS_DURATION,\n    TUI_CLOSE_WORD,\n    TUI_COMMON_ICONS,\n    TuiCommonIcons,\n    tuiSlideInTop,\n} from '@taiga-ui/core';\nimport {shouldCall} from '@tinkoff/ng-event-plugins';\nimport {POLYMORPHEUS_CONTEXT} from '@tinkoff/ng-polymorpheus';\nimport {BehaviorSubject, Observable} from 'rxjs';\n\nimport {TuiSheetDialogOptions} from './sheet-dialog.options';\n\n// So we re-enter ngZone and trigger change detection\nfunction isCloseable(this: TuiSheetDialogComponent<unknown>): boolean {\n    return this.context.closeable;\n}\n\n@Component({\n    selector: 'tui-sheet-dialog',\n    templateUrl: './sheet-dialog.template.html',\n    styleUrls: ['./sheet-dialog.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [tuiSlideInTop],\n    host: {\n        '[$.class._stuck]': 'stuck$',\n        '($.class._stuck)': 'stuck$',\n    },\n})\nexport class TuiSheetDialogComponent<I> implements AfterViewInit {\n    @ViewChild('sheet')\n    private readonly sheet?: ElementRef<HTMLElement>;\n\n    @ViewChildren('stops')\n    private readonly stopsRefs: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    private pointers = 0;\n\n    @HostBinding('@tuiSlideInTop')\n    readonly slideInTop = {\n        value: '',\n        params: {\n            start: '100vh',\n            duration: this.duration,\n        },\n    };\n\n    stuck$ = new BehaviorSubject(false);\n\n    constructor(\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(TUI_ANIMATIONS_DURATION) private readonly duration: number,\n        @Inject(TUI_COMMON_ICONS) readonly icons: TuiCommonIcons,\n        @Inject(TUI_CLOSE_WORD) readonly closeWord$: Observable<string>,\n        @Inject(POLYMORPHEUS_CONTEXT)\n        readonly context: TuiDialog<TuiSheetDialogOptions<I>, any>,\n    ) {}\n\n    @HostBinding('style.top.px')\n    get offset(): number {\n        return this.context.offset;\n    }\n\n    @HostBinding('class._closeable')\n    get closeable(): boolean {\n        return this.context.closeable;\n    }\n\n    get isSmall(): boolean {\n        return this.sheetTop > (this.sheet?.nativeElement.clientHeight || Infinity);\n    }\n\n    @HostListener('document:touchstart.passive.silent', ['1'])\n    @HostListener('document:touchend.silent', ['-1'])\n    @HostListener('document:touchcancel.silent', ['-1'])\n    @HostListener('scroll.silent', ['0'])\n    onPointerChange(delta: number): void {\n        this.pointers = Math.max(this.pointers + delta, 0);\n\n        if (!delta) {\n            const stuck = this.el.nativeElement.scrollTop > this.sheetTop;\n\n            this.stuck$.value !== stuck && this.stuck$.next(stuck);\n        }\n\n        if (\n            this.context.closeable &&\n            !this.pointers &&\n            this.el.nativeElement.scrollTop <= 0\n        ) {\n            this.close();\n        }\n    }\n\n    @shouldCall(isCloseable)\n    close(): void {\n        // TODO: Refactor focus visible on mobile\n        this.el.nativeElement.dispatchEvent(new Event('mousedown', {bubbles: true}));\n        this.context.$implicit.complete();\n    }\n\n    ngAfterViewInit(): void {\n        this.el.nativeElement.scrollTop = [\n            ...this.getStops(this.stopsRefs),\n            this.sheetTop,\n        ][this.context.initial];\n    }\n\n    private get sheetTop(): number {\n        return this.sheet?.nativeElement.offsetTop ?? Infinity;\n    }\n\n    @tuiPure\n    private getStops(stops: QueryList<ElementRef<HTMLElement>>): readonly number[] {\n        return stops.map(\n            ({nativeElement}) => nativeElement.offsetTop + nativeElement.clientHeight,\n        );\n    }\n}\n","<div class=\"t-stops\">\n    <div\n        *ngFor=\"let stop of context.stops\"\n        #stops\n        class=\"t-stop\"\n        [style.margin-top]=\"stop\"\n    ></div>\n</div>\n<div\n    #sheet\n    class=\"t-sheet\"\n    [class.t-sheet_small]=\"isSmall\"\n    (tuiClickOutside)=\"close()\"\n>\n    <div class=\"t-top\"></div>\n    <h2\n        *ngIf=\"context.label\"\n        class=\"t-heading\"\n        [id]=\"context.id\"\n    >\n        <ng-container *polymorpheusOutlet=\"context.label as label\">\n            {{ label }}\n        </ng-container>\n    </h2>\n    <div\n        *ngIf=\"context.content\"\n        class=\"t-content\"\n    >\n        <ng-container *polymorpheusOutlet=\"context.content as text; context: context\">\n            {{ text }}\n        </ng-container>\n    </div>\n</div>\n<div class=\"t-footer\"></div>\n"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sheet-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/addon-mobile/components/sheet-dialog/sheet-dialog.component.ts","../../../../../projects/addon-mobile/components/sheet-dialog/sheet-dialog.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    QueryList,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\nimport {EMPTY_QUERY, TuiDialog, tuiPure} from '@taiga-ui/cdk';\nimport {\n    TUI_ANIMATIONS_DURATION,\n    TUI_CLOSE_WORD,\n    TUI_COMMON_ICONS,\n    TuiCommonIcons,\n    tuiSlideInTop,\n} from '@taiga-ui/core';\nimport {shouldCall} from '@tinkoff/ng-event-plugins';\nimport {POLYMORPHEUS_CONTEXT} from '@tinkoff/ng-polymorpheus';\nimport {BehaviorSubject, Observable} from 'rxjs';\n\nimport {TuiSheetDialogOptions} from './sheet-dialog.options';\n\n// So we re-enter ngZone and trigger change detection\nfunction isCloseable(this: TuiSheetDialogComponent<unknown>): boolean {\n    return this.context.closeable;\n}\n\n@Component({\n    selector: 'tui-sheet-dialog',\n    templateUrl: './sheet-dialog.template.html',\n    styleUrls: ['./sheet-dialog.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [tuiSlideInTop],\n    host: {\n        '[$.class._stuck]': 'stuck$',\n        '($.class._stuck)': 'stuck$',\n        '[class._fullscreen]': 'context.fullscreen === true',\n    },\n})\nexport class TuiSheetDialogComponent<I> implements AfterViewInit {\n    @ViewChild('sheet')\n    private readonly sheet?: ElementRef<HTMLElement>;\n\n    @ViewChildren('stops')\n    private readonly stopsRefs: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    private pointers = 0;\n\n    @HostBinding('@tuiSlideInTop')\n    readonly slideInTop = {\n        value: '',\n        params: {\n            start: '100vh',\n            duration: this.duration,\n        },\n    };\n\n    stuck$ = new BehaviorSubject(false);\n\n    constructor(\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(TUI_ANIMATIONS_DURATION) private readonly duration: number,\n        @Inject(TUI_COMMON_ICONS) readonly icons: TuiCommonIcons,\n        @Inject(TUI_CLOSE_WORD) readonly closeWord$: Observable<string>,\n        @Inject(POLYMORPHEUS_CONTEXT)\n        readonly context: TuiDialog<TuiSheetDialogOptions<I>, any>,\n    ) {}\n\n    @HostBinding('style.top.px')\n    get offset(): number {\n        return this.context.offset;\n    }\n\n    @HostBinding('class._closeable')\n    get closeable(): boolean {\n        return this.context.closeable;\n    }\n\n    get isSmall(): boolean {\n        return this.sheetTop > (this.sheet?.nativeElement.clientHeight || Infinity);\n    }\n\n    @HostListener('document:touchstart.passive.silent', ['1'])\n    @HostListener('document:touchend.silent', ['-1'])\n    @HostListener('document:touchcancel.silent', ['-1'])\n    @HostListener('scroll.silent', ['0'])\n    onPointerChange(delta: number): void {\n        this.pointers = Math.max(this.pointers + delta, 0);\n\n        if (!delta) {\n            const stuck = this.el.nativeElement.scrollTop > this.sheetTop;\n\n            this.stuck$.value !== stuck && this.stuck$.next(stuck);\n        }\n\n        if (\n            this.context.closeable &&\n            !this.pointers &&\n            this.el.nativeElement.scrollTop <= 0\n        ) {\n            this.close();\n        }\n    }\n\n    @shouldCall(isCloseable)\n    close(): void {\n        // TODO: Refactor focus visible on mobile\n        this.el.nativeElement.dispatchEvent(new Event('mousedown', {bubbles: true}));\n        this.context.$implicit.complete();\n    }\n\n    ngAfterViewInit(): void {\n        this.el.nativeElement.scrollTop = [\n            ...this.getStops(this.stopsRefs),\n            this.sheetTop,\n        ][this.context.initial];\n    }\n\n    private get sheetTop(): number {\n        return this.sheet?.nativeElement.offsetTop ?? Infinity;\n    }\n\n    @tuiPure\n    private getStops(stops: QueryList<ElementRef<HTMLElement>>): readonly number[] {\n        return stops.map(\n            ({nativeElement}) => nativeElement.offsetTop + nativeElement.clientHeight,\n        );\n    }\n}\n","<div class=\"t-stops\">\n    <div\n        *ngFor=\"let stop of context.stops\"\n        #stops\n        class=\"t-stop\"\n        [style.margin-top]=\"stop\"\n    ></div>\n</div>\n<div\n    #sheet\n    class=\"t-sheet\"\n    [class.t-sheet_small]=\"isSmall\"\n    (tuiClickOutside)=\"close()\"\n    (tuiSheetDialogClose)=\"close()\"\n>\n    <div\n        *ngIf=\"context.bar\"\n        class=\"t-top\"\n    ></div>\n    <h2\n        *ngIf=\"context.label\"\n        class=\"t-heading\"\n        [id]=\"context.id\"\n    >\n        <ng-container *polymorpheusOutlet=\"context.label as label; context: context\">\n            {{ label }}\n        </ng-container>\n    </h2>\n    <div\n        *ngIf=\"context.content\"\n        class=\"t-content\"\n    >\n        <ng-container *polymorpheusOutlet=\"context.content as text; context: context\">\n            {{ text }}\n        </ng-container>\n    </div>\n</div>\n<div class=\"t-footer\"></div>\n"]}
|
|
@@ -6,19 +6,32 @@ import { PolymorpheusModule } from '@tinkoff/ng-polymorpheus';
|
|
|
6
6
|
import { TuiSheetDialogComponent } from './sheet-dialog.component';
|
|
7
7
|
import { TuiSheetDialogDirective } from './sheet-dialog.directive';
|
|
8
8
|
import { TuiSheetDialogService } from './sheet-dialog.service';
|
|
9
|
+
import { TuiSheetDialogCloseDirective } from './sheet-dialog-close.directive';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
export class TuiSheetDialogModule {
|
|
11
12
|
}
|
|
12
13
|
TuiSheetDialogModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
-
TuiSheetDialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, declarations: [TuiSheetDialogComponent,
|
|
14
|
+
TuiSheetDialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, declarations: [TuiSheetDialogComponent,
|
|
15
|
+
TuiSheetDialogDirective,
|
|
16
|
+
TuiSheetDialogCloseDirective], imports: [CommonModule, PolymorpheusModule, TuiClickOutsideModule, TuiButtonModule], exports: [TuiSheetDialogComponent,
|
|
17
|
+
TuiSheetDialogDirective,
|
|
18
|
+
TuiSheetDialogCloseDirective] });
|
|
14
19
|
TuiSheetDialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, providers: [tuiAsDialog(TuiSheetDialogService)], imports: [[CommonModule, PolymorpheusModule, TuiClickOutsideModule, TuiButtonModule]] });
|
|
15
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, decorators: [{
|
|
16
21
|
type: NgModule,
|
|
17
22
|
args: [{
|
|
18
23
|
imports: [CommonModule, PolymorpheusModule, TuiClickOutsideModule, TuiButtonModule],
|
|
19
|
-
declarations: [
|
|
24
|
+
declarations: [
|
|
25
|
+
TuiSheetDialogComponent,
|
|
26
|
+
TuiSheetDialogDirective,
|
|
27
|
+
TuiSheetDialogCloseDirective,
|
|
28
|
+
],
|
|
20
29
|
providers: [tuiAsDialog(TuiSheetDialogService)],
|
|
21
|
-
exports: [
|
|
30
|
+
exports: [
|
|
31
|
+
TuiSheetDialogComponent,
|
|
32
|
+
TuiSheetDialogDirective,
|
|
33
|
+
TuiSheetDialogCloseDirective,
|
|
34
|
+
],
|
|
22
35
|
}]
|
|
23
36
|
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hlZXQtZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLW1vYmlsZS9jb21wb25lbnRzL3NoZWV0LWRpYWxvZy9zaGVldC1kaWFsb2cubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxXQUFXLEVBQUUscUJBQXFCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQy9DLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBRTVELE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQ2pFLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQ2pFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQzdELE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLGdDQUFnQyxDQUFDOztBQWdCNUUsTUFBTSxPQUFPLG9CQUFvQjs7a0hBQXBCLG9CQUFvQjttSEFBcEIsb0JBQW9CLGlCQVh6Qix1QkFBdUI7UUFDdkIsdUJBQXVCO1FBQ3ZCLDRCQUE0QixhQUp0QixZQUFZLEVBQUUsa0JBQWtCLEVBQUUscUJBQXFCLEVBQUUsZUFBZSxhQVE5RSx1QkFBdUI7UUFDdkIsdUJBQXVCO1FBQ3ZCLDRCQUE0QjttSEFHdkIsb0JBQW9CLGFBUGxCLENBQUMsV0FBVyxDQUFDLHFCQUFxQixDQUFDLENBQUMsWUFOdEMsQ0FBQyxZQUFZLEVBQUUsa0JBQWtCLEVBQUUscUJBQXFCLEVBQUUsZUFBZSxDQUFDOzRGQWExRSxvQkFBb0I7a0JBZGhDLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGtCQUFrQixFQUFFLHFCQUFxQixFQUFFLGVBQWUsQ0FBQztvQkFDbkYsWUFBWSxFQUFFO3dCQUNWLHVCQUF1Qjt3QkFDdkIsdUJBQXVCO3dCQUN2Qiw0QkFBNEI7cUJBQy9CO29CQUNELFNBQVMsRUFBRSxDQUFDLFdBQVcsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO29CQUMvQyxPQUFPLEVBQUU7d0JBQ0wsdUJBQXVCO3dCQUN2Qix1QkFBdUI7d0JBQ3ZCLDRCQUE0QjtxQkFDL0I7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHt0dWlBc0RpYWxvZywgVHVpQ2xpY2tPdXRzaWRlTW9kdWxlfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7VHVpQnV0dG9uTW9kdWxlfSBmcm9tICdAdGFpZ2EtdWkvY29yZSc7XG5pbXBvcnQge1BvbHltb3JwaGV1c01vZHVsZX0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcblxuaW1wb3J0IHtUdWlTaGVldERpYWxvZ0NvbXBvbmVudH0gZnJvbSAnLi9zaGVldC1kaWFsb2cuY29tcG9uZW50JztcbmltcG9ydCB7VHVpU2hlZXREaWFsb2dEaXJlY3RpdmV9IGZyb20gJy4vc2hlZXQtZGlhbG9nLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aVNoZWV0RGlhbG9nU2VydmljZX0gZnJvbSAnLi9zaGVldC1kaWFsb2cuc2VydmljZSc7XG5pbXBvcnQge1R1aVNoZWV0RGlhbG9nQ2xvc2VEaXJlY3RpdmV9IGZyb20gJy4vc2hlZXQtZGlhbG9nLWNsb3NlLmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgUG9seW1vcnBoZXVzTW9kdWxlLCBUdWlDbGlja091dHNpZGVNb2R1bGUsIFR1aUJ1dHRvbk1vZHVsZV0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFR1aVNoZWV0RGlhbG9nQ29tcG9uZW50LFxuICAgICAgICBUdWlTaGVldERpYWxvZ0RpcmVjdGl2ZSxcbiAgICAgICAgVHVpU2hlZXREaWFsb2dDbG9zZURpcmVjdGl2ZSxcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW3R1aUFzRGlhbG9nKFR1aVNoZWV0RGlhbG9nU2VydmljZSldLFxuICAgIGV4cG9ydHM6IFtcbiAgICAgICAgVHVpU2hlZXREaWFsb2dDb21wb25lbnQsXG4gICAgICAgIFR1aVNoZWV0RGlhbG9nRGlyZWN0aXZlLFxuICAgICAgICBUdWlTaGVldERpYWxvZ0Nsb3NlRGlyZWN0aXZlLFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aVNoZWV0RGlhbG9nTW9kdWxlIHt9XG4iXX0=
|
|
@@ -5,6 +5,8 @@ export const TUI_SHEET_DIALOG_DEFAULT_OPTIONS = {
|
|
|
5
5
|
initial: 0,
|
|
6
6
|
offset: 16,
|
|
7
7
|
closeable: true,
|
|
8
|
+
bar: true,
|
|
9
|
+
fullscreen: false,
|
|
8
10
|
};
|
|
9
11
|
/**
|
|
10
12
|
* Default parameters for mobile dialog component
|
|
@@ -13,4 +15,4 @@ export const TUI_SHEET_DIALOG_OPTIONS = tuiCreateToken(TUI_SHEET_DIALOG_DEFAULT_
|
|
|
13
15
|
export function tuiSheetDialogOptionsProvider(options) {
|
|
14
16
|
return tuiProvideOptions(TUI_SHEET_DIALOG_OPTIONS, options, TUI_SHEET_DIALOG_DEFAULT_OPTIONS);
|
|
15
17
|
}
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hlZXQtZGlhbG9nLm9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1tb2JpbGUvY29tcG9uZW50cy9zaGVldC1kaWFsb2cvc2hlZXQtZGlhbG9nLm9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFDLGNBQWMsRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQWdCaEUsTUFBTSxDQUFDLE1BQU0sZ0NBQWdDLEdBQWlDO0lBQzFFLEtBQUssRUFBRSxFQUFFO0lBQ1QsS0FBSyxFQUFFLEVBQUU7SUFDVCxPQUFPLEVBQUUsQ0FBQztJQUNWLE1BQU0sRUFBRSxFQUFFO0lBQ1YsU0FBUyxFQUFFLElBQUk7SUFDZixHQUFHLEVBQUUsSUFBSTtJQUNULFVBQVUsRUFBRSxLQUFLO0NBQ3BCLENBQUM7QUFFRjs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLGNBQWMsQ0FBQyxnQ0FBZ0MsQ0FBQyxDQUFDO0FBRXpGLE1BQU0sVUFBVSw2QkFBNkIsQ0FDekMsT0FBOEM7SUFFOUMsT0FBTyxpQkFBaUIsQ0FDcEIsd0JBQXdCLEVBQ3hCLE9BQU8sRUFDUCxnQ0FBZ0MsQ0FDbkMsQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1Byb3ZpZGVyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7dHVpQ3JlYXRlVG9rZW4sIHR1aVByb3ZpZGVPcHRpb25zfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7UG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcblxudHlwZSBUdWlTaGVldERpYWxvZ0RlZmF1bHRPcHRpb25zID0gT21pdDxUdWlTaGVldERpYWxvZ09wdGlvbnM8dW5rbm93bj4sICdkYXRhJz47XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHVpU2hlZXREaWFsb2dPcHRpb25zPEkgPSBuZXZlcj4ge1xuICAgIHJlYWRvbmx5IGNsb3NlYWJsZTogYm9vbGVhbjtcbiAgICByZWFkb25seSBkYXRhOiBJO1xuICAgIHJlYWRvbmx5IGluaXRpYWw6IG51bWJlcjtcbiAgICByZWFkb25seSBsYWJlbDogUG9seW1vcnBoZXVzQ29udGVudDtcbiAgICByZWFkb25seSBvZmZzZXQ6IG51bWJlcjtcbiAgICByZWFkb25seSBzdG9wczogcmVhZG9ubHkgc3RyaW5nW107XG4gICAgcmVhZG9ubHkgYmFyOiBib29sZWFuO1xuICAgIHJlYWRvbmx5IGZ1bGxzY3JlZW46IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCBUVUlfU0hFRVRfRElBTE9HX0RFRkFVTFRfT1BUSU9OUzogVHVpU2hlZXREaWFsb2dEZWZhdWx0T3B0aW9ucyA9IHtcbiAgICBsYWJlbDogJycsXG4gICAgc3RvcHM6IFtdLFxuICAgIGluaXRpYWw6IDAsXG4gICAgb2Zmc2V0OiAxNixcbiAgICBjbG9zZWFibGU6IHRydWUsXG4gICAgYmFyOiB0cnVlLFxuICAgIGZ1bGxzY3JlZW46IGZhbHNlLFxufTtcblxuLyoqXG4gKiBEZWZhdWx0IHBhcmFtZXRlcnMgZm9yIG1vYmlsZSBkaWFsb2cgY29tcG9uZW50XG4gKi9cbmV4cG9ydCBjb25zdCBUVUlfU0hFRVRfRElBTE9HX09QVElPTlMgPSB0dWlDcmVhdGVUb2tlbihUVUlfU0hFRVRfRElBTE9HX0RFRkFVTFRfT1BUSU9OUyk7XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlTaGVldERpYWxvZ09wdGlvbnNQcm92aWRlcihcbiAgICBvcHRpb25zOiBQYXJ0aWFsPFR1aVNoZWV0RGlhbG9nRGVmYXVsdE9wdGlvbnM+LFxuKTogUHJvdmlkZXIge1xuICAgIHJldHVybiB0dWlQcm92aWRlT3B0aW9ucyhcbiAgICAgICAgVFVJX1NIRUVUX0RJQUxPR19PUFRJT05TLFxuICAgICAgICBvcHRpb25zLFxuICAgICAgICBUVUlfU0hFRVRfRElBTE9HX0RFRkFVTFRfT1BUSU9OUyxcbiAgICApO1xufVxuIl19
|
|
@@ -4,7 +4,7 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
export class TuiThemeAndroidComponent extends AbstractTuiThemeSwitcher {
|
|
5
5
|
}
|
|
6
6
|
TuiThemeAndroidComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiThemeAndroidComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
7
|
-
TuiThemeAndroidComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiThemeAndroidComponent, selector: "tui-theme-android", usesInheritance: true, ngImport: i0, template: '', isInline: true, styles: ["body{overscroll-behavior:none}*{outline:none;scrollbar-width:none;-webkit-tap-highlight-color:transparent}input,textarea,[contenteditable] *{-webkit-user-select:auto!important;-moz-user-select:auto!important;user-select:auto!important}::selection{background-color:transparent}.tui-island{padding:1rem;border-radius:.125rem;box-shadow:0 0 .125rem #0003,0 .0625rem .125rem #0003}.tui-island:before{display:none}a[tuiButton],a[tuiIconButton],button[tuiButton],button[tuiIconButton]{font-size:.875rem!important;font-weight:500;
|
|
7
|
+
TuiThemeAndroidComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiThemeAndroidComponent, selector: "tui-theme-android", usesInheritance: true, ngImport: i0, template: '', isInline: true, styles: ["body{overscroll-behavior:none}*{outline:none;scrollbar-width:none;-webkit-tap-highlight-color:transparent}input,textarea,[contenteditable] *{-webkit-user-select:auto!important;-moz-user-select:auto!important;user-select:auto!important}::selection{background-color:transparent}.tui-island{padding:1rem;border-radius:.125rem;box-shadow:0 0 .125rem #0003,0 .0625rem .125rem #0003}.tui-island:before{display:none}a[tuiButton],a[tuiIconButton],button[tuiButton],button[tuiIconButton]{font-size:.875rem!important;font-weight:500;font-family:-apple-system,BlinkMacSystemFont,Roboto,\"Helvetica Neue\",sans-serif}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
8
8
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiThemeAndroidComponent, decorators: [{
|
|
9
9
|
type: Component,
|
|
10
10
|
args: [{
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
export * from '@taiga-ui/addon-mobile/directives/dropdown-mobile';
|
|
2
2
|
export * from '@taiga-ui/addon-mobile/directives/elastic-sticky';
|
|
3
3
|
export * from '@taiga-ui/addon-mobile/directives/mobile-tabs';
|
|
4
|
+
export * from '@taiga-ui/addon-mobile/directives/responsive-dialog';
|
|
4
5
|
export * from '@taiga-ui/addon-mobile/directives/ripple';
|
|
5
6
|
export * from '@taiga-ui/addon-mobile/directives/sidebar';
|
|
6
7
|
export * from '@taiga-ui/addon-mobile/directives/touchable';
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1tb2JpbGUvZGlyZWN0aXZlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2FkZG9uLW1vYmlsZS9kaXJlY3RpdmVzL2Ryb3Bkb3duLW1vYmlsZSc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkvYWRkb24tbW9iaWxlL2RpcmVjdGl2ZXMvZWxhc3RpYy1zdGlja3knO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2FkZG9uLW1vYmlsZS9kaXJlY3RpdmVzL21vYmlsZS10YWJzJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9hZGRvbi1tb2JpbGUvZGlyZWN0aXZlcy9yZXNwb25zaXZlLWRpYWxvZyc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkvYWRkb24tbW9iaWxlL2RpcmVjdGl2ZXMvcmlwcGxlJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9hZGRvbi1tb2JpbGUvZGlyZWN0aXZlcy9zaWRlYmFyJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9hZGRvbi1tb2JpbGUvZGlyZWN0aXZlcy90b3VjaGFibGUnO1xuIl19
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './responsive-dialog.directive';
|
|
2
|
+
export * from './responsive-dialog.module';
|
|
3
|
+
export * from './responsive-dialog.service';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1tb2JpbGUvZGlyZWN0aXZlcy9yZXNwb25zaXZlLWRpYWxvZy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw2QkFBNkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcmVzcG9uc2l2ZS1kaWFsb2cuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vcmVzcG9uc2l2ZS1kaWFsb2cubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vcmVzcG9uc2l2ZS1kaWFsb2cuc2VydmljZSc7XG4iXX0=
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Directive } from '@angular/core';
|
|
2
|
+
import { AbstractTuiDialogDirective, AbstractTuiDialogService } from '@taiga-ui/cdk';
|
|
3
|
+
import { TuiResponsiveDialogService } from './responsive-dialog.service';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class TuiResponsiveDialogDirective extends AbstractTuiDialogDirective {
|
|
6
|
+
}
|
|
7
|
+
TuiResponsiveDialogDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
8
|
+
TuiResponsiveDialogDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiResponsiveDialogDirective, selector: "ng-template[tuiResponsiveDialog]", inputs: { options: ["tuiResponsiveDialogOptions", "options"], open: ["tuiResponsiveDialog", "open"] }, outputs: { openChange: "tuiResponsiveDialogChange" }, providers: [
|
|
9
|
+
{
|
|
10
|
+
provide: AbstractTuiDialogService,
|
|
11
|
+
useExisting: TuiResponsiveDialogService,
|
|
12
|
+
},
|
|
13
|
+
], usesInheritance: true, ngImport: i0 });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogDirective, decorators: [{
|
|
15
|
+
type: Directive,
|
|
16
|
+
args: [{
|
|
17
|
+
selector: 'ng-template[tuiResponsiveDialog]',
|
|
18
|
+
inputs: ['options: tuiResponsiveDialogOptions', 'open: tuiResponsiveDialog'],
|
|
19
|
+
outputs: ['openChange: tuiResponsiveDialogChange'],
|
|
20
|
+
providers: [
|
|
21
|
+
{
|
|
22
|
+
provide: AbstractTuiDialogService,
|
|
23
|
+
useExisting: TuiResponsiveDialogService,
|
|
24
|
+
},
|
|
25
|
+
],
|
|
26
|
+
}]
|
|
27
|
+
}] });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2l2ZS1kaWFsb2cuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tbW9iaWxlL2RpcmVjdGl2ZXMvcmVzcG9uc2l2ZS1kaWFsb2cvcmVzcG9uc2l2ZS1kaWFsb2cuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDeEMsT0FBTyxFQUFDLDBCQUEwQixFQUFFLHdCQUF3QixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBR25GLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLDZCQUE2QixDQUFDOztBQWF2RSxNQUFNLE9BQU8sNEJBQWdDLFNBQVEsMEJBRXBEOzswSEFGWSw0QkFBNEI7OEdBQTVCLDRCQUE0Qix3TkFQMUI7UUFDUDtZQUNJLE9BQU8sRUFBRSx3QkFBd0I7WUFDakMsV0FBVyxFQUFFLDBCQUEwQjtTQUMxQztLQUNKOzRGQUVRLDRCQUE0QjtrQkFYeEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsa0NBQWtDO29CQUM1QyxNQUFNLEVBQUUsQ0FBQyxxQ0FBcUMsRUFBRSwyQkFBMkIsQ0FBQztvQkFDNUUsT0FBTyxFQUFFLENBQUMsdUNBQXVDLENBQUM7b0JBQ2xELFNBQVMsRUFBRTt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsd0JBQXdCOzRCQUNqQyxXQUFXLEVBQUUsMEJBQTBCO3lCQUMxQztxQkFDSjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7QWJzdHJhY3RUdWlEaWFsb2dEaXJlY3RpdmUsIEFic3RyYWN0VHVpRGlhbG9nU2VydmljZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aURpYWxvZ09wdGlvbnN9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcblxuaW1wb3J0IHtUdWlSZXNwb25zaXZlRGlhbG9nU2VydmljZX0gZnJvbSAnLi9yZXNwb25zaXZlLWRpYWxvZy5zZXJ2aWNlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICduZy10ZW1wbGF0ZVt0dWlSZXNwb25zaXZlRGlhbG9nXScsXG4gICAgaW5wdXRzOiBbJ29wdGlvbnM6IHR1aVJlc3BvbnNpdmVEaWFsb2dPcHRpb25zJywgJ29wZW46IHR1aVJlc3BvbnNpdmVEaWFsb2cnXSxcbiAgICBvdXRwdXRzOiBbJ29wZW5DaGFuZ2U6IHR1aVJlc3BvbnNpdmVEaWFsb2dDaGFuZ2UnXSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogQWJzdHJhY3RUdWlEaWFsb2dTZXJ2aWNlLFxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IFR1aVJlc3BvbnNpdmVEaWFsb2dTZXJ2aWNlLFxuICAgICAgICB9LFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aVJlc3BvbnNpdmVEaWFsb2dEaXJlY3RpdmU8VD4gZXh0ZW5kcyBBYnN0cmFjdFR1aURpYWxvZ0RpcmVjdGl2ZTxcbiAgICBUdWlEaWFsb2dPcHRpb25zPFQ+XG4+IHt9XG4iXX0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { TuiResponsiveDialogDirective } from './responsive-dialog.directive';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class TuiResponsiveDialogModule {
|
|
5
|
+
}
|
|
6
|
+
TuiResponsiveDialogModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
TuiResponsiveDialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogModule, declarations: [TuiResponsiveDialogDirective], exports: [TuiResponsiveDialogDirective] });
|
|
8
|
+
TuiResponsiveDialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogModule });
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
declarations: [TuiResponsiveDialogDirective],
|
|
13
|
+
exports: [TuiResponsiveDialogDirective],
|
|
14
|
+
}]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2l2ZS1kaWFsb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tbW9iaWxlL2RpcmVjdGl2ZXMvcmVzcG9uc2l2ZS1kaWFsb2cvcmVzcG9uc2l2ZS1kaWFsb2cubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFdkMsT0FBTyxFQUFDLDRCQUE0QixFQUFDLE1BQU0sK0JBQStCLENBQUM7O0FBTTNFLE1BQU0sT0FBTyx5QkFBeUI7O3VIQUF6Qix5QkFBeUI7d0hBQXpCLHlCQUF5QixpQkFIbkIsNEJBQTRCLGFBQ2pDLDRCQUE0Qjt3SEFFN0IseUJBQXlCOzRGQUF6Qix5QkFBeUI7a0JBSnJDLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsNEJBQTRCLENBQUM7b0JBQzVDLE9BQU8sRUFBRSxDQUFDLDRCQUE0QixDQUFDO2lCQUMxQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1R1aVJlc3BvbnNpdmVEaWFsb2dEaXJlY3RpdmV9IGZyb20gJy4vcmVzcG9uc2l2ZS1kaWFsb2cuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtUdWlSZXNwb25zaXZlRGlhbG9nRGlyZWN0aXZlXSxcbiAgICBleHBvcnRzOiBbVHVpUmVzcG9uc2l2ZURpYWxvZ0RpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aVJlc3BvbnNpdmVEaWFsb2dNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Inject, Injectable } from '@angular/core';
|
|
2
|
+
import { TuiSheetDialogService } from '@taiga-ui/addon-mobile/components/sheet-dialog';
|
|
3
|
+
import { TUI_IS_MOBILE, tuiIsString } from '@taiga-ui/cdk';
|
|
4
|
+
import { TuiDialogService } from '@taiga-ui/core';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@taiga-ui/core";
|
|
7
|
+
import * as i2 from "@taiga-ui/addon-mobile/components/sheet-dialog";
|
|
8
|
+
/**
|
|
9
|
+
* Same as `TuiDialogService` but automatically switches to `TuiSheetDialogService` on mobile
|
|
10
|
+
*/
|
|
11
|
+
export class TuiResponsiveDialogService {
|
|
12
|
+
constructor(isMobile, dialogs, sheets) {
|
|
13
|
+
this.isMobile = isMobile;
|
|
14
|
+
this.dialogs = dialogs;
|
|
15
|
+
this.sheets = sheets;
|
|
16
|
+
}
|
|
17
|
+
open(content, options = {}) {
|
|
18
|
+
return this.isMobile
|
|
19
|
+
? this.sheets.open(content, options)
|
|
20
|
+
: this.dialogs.open(content, Object.assign(Object.assign({}, options), { label: tuiIsString(options.label) ? options.label : '' }));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
TuiResponsiveDialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogService, deps: [{ token: TUI_IS_MOBILE }, { token: TuiDialogService }, { token: TuiSheetDialogService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
24
|
+
TuiResponsiveDialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogService, providedIn: 'root' });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiResponsiveDialogService, decorators: [{
|
|
26
|
+
type: Injectable,
|
|
27
|
+
args: [{
|
|
28
|
+
providedIn: 'root',
|
|
29
|
+
}]
|
|
30
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
31
|
+
type: Inject,
|
|
32
|
+
args: [TUI_IS_MOBILE]
|
|
33
|
+
}] }, { type: i1.TuiDialogService, decorators: [{
|
|
34
|
+
type: Inject,
|
|
35
|
+
args: [TuiDialogService]
|
|
36
|
+
}] }, { type: i2.TuiSheetDialogService, decorators: [{
|
|
37
|
+
type: Inject,
|
|
38
|
+
args: [TuiSheetDialogService]
|
|
39
|
+
}] }]; } });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2l2ZS1kaWFsb2cuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLW1vYmlsZS9kaXJlY3RpdmVzL3Jlc3BvbnNpdmUtZGlhbG9nL3Jlc3BvbnNpdmUtZGlhbG9nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sZ0RBQWdELENBQUM7QUFDckYsT0FBTyxFQUFDLGFBQWEsRUFBRSxXQUFXLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFxQyxnQkFBZ0IsRUFBQyxNQUFNLGdCQUFnQixDQUFDOzs7O0FBV3BGOztHQUVHO0FBSUgsTUFBTSxPQUFPLDBCQUEwQjtJQUNuQyxZQUNvQyxRQUFpQixFQUNkLE9BQXlCLEVBQ3BCLE1BQTZCO1FBRnJDLGFBQVEsR0FBUixRQUFRLENBQVM7UUFDZCxZQUFPLEdBQVAsT0FBTyxDQUFrQjtRQUNwQixXQUFNLEdBQU4sTUFBTSxDQUF1QjtJQUN0RSxDQUFDO0lBRUosSUFBSSxDQUNBLE9BRUMsRUFDRCxVQUFvRCxFQUFFO1FBRXRELE9BQU8sSUFBSSxDQUFDLFFBQVE7WUFDaEIsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUM7WUFDcEMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sa0NBQ2xCLE9BQU8sS0FDVixLQUFLLEVBQUUsV0FBVyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUN4RCxDQUFDO0lBQ2IsQ0FBQzs7d0hBbkJRLDBCQUEwQixrQkFFdkIsYUFBYSxhQUNiLGdCQUFnQixhQUNoQixxQkFBcUI7NEhBSnhCLDBCQUEwQixjQUZ2QixNQUFNOzRGQUVULDBCQUEwQjtrQkFIdEMsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckI7OzBCQUdRLE1BQU07MkJBQUMsYUFBYTs7MEJBQ3BCLE1BQU07MkJBQUMsZ0JBQWdCOzswQkFDdkIsTUFBTTsyQkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdCwgSW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7VHVpU2hlZXREaWFsb2dPcHRpb25zfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tbW9iaWxlL2NvbXBvbmVudHMvc2hlZXQtZGlhbG9nJztcbmltcG9ydCB7VHVpU2hlZXREaWFsb2dTZXJ2aWNlfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tbW9iaWxlL2NvbXBvbmVudHMvc2hlZXQtZGlhbG9nJztcbmltcG9ydCB7VFVJX0lTX01PQklMRSwgdHVpSXNTdHJpbmd9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtUdWlEaWFsb2dDb250ZXh0LCBUdWlEaWFsb2dPcHRpb25zLCBUdWlEaWFsb2dTZXJ2aWNlfSBmcm9tICdAdGFpZ2EtdWkvY29yZSc7XG5pbXBvcnQgdHlwZSB7UG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcbmltcG9ydCB0eXBlIHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IGludGVyZmFjZSBUdWlSZXNwb25zaXZlRGlhbG9nT3B0aW9uczxJID0gdW5kZWZpbmVkPlxuICAgIGV4dGVuZHMgT21pdDxUdWlEaWFsb2dPcHRpb25zPEk+LCAnY2xvc2VhYmxlJyB8ICdsYWJlbCc+LFxuICAgICAgICBUdWlTaGVldERpYWxvZ09wdGlvbnM8ST4ge1xuICAgIHJlYWRvbmx5IGxhYmVsOiBQb2x5bW9ycGhldXNDb250ZW50O1xuICAgIHJlYWRvbmx5IGNsb3NlYWJsZTogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBTYW1lIGFzIGBUdWlEaWFsb2dTZXJ2aWNlYCBidXQgYXV0b21hdGljYWxseSBzd2l0Y2hlcyB0byBgVHVpU2hlZXREaWFsb2dTZXJ2aWNlYCBvbiBtb2JpbGVcbiAqL1xuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgVHVpUmVzcG9uc2l2ZURpYWxvZ1NlcnZpY2Uge1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KFRVSV9JU19NT0JJTEUpIHJlYWRvbmx5IGlzTW9iaWxlOiBib29sZWFuLFxuICAgICAgICBASW5qZWN0KFR1aURpYWxvZ1NlcnZpY2UpIHJlYWRvbmx5IGRpYWxvZ3M6IFR1aURpYWxvZ1NlcnZpY2UsXG4gICAgICAgIEBJbmplY3QoVHVpU2hlZXREaWFsb2dTZXJ2aWNlKSByZWFkb25seSBzaGVldHM6IFR1aVNoZWV0RGlhbG9nU2VydmljZSxcbiAgICApIHt9XG5cbiAgICBvcGVuPEcgPSB2b2lkPihcbiAgICAgICAgY29udGVudDogUG9seW1vcnBoZXVzQ29udGVudDxcbiAgICAgICAgICAgIFR1aURpYWxvZ0NvbnRleHQ8Rz4gJiBUdWlSZXNwb25zaXZlRGlhbG9nT3B0aW9uczxhbnk+XG4gICAgICAgID4sXG4gICAgICAgIG9wdGlvbnM6IFBhcnRpYWw8VHVpUmVzcG9uc2l2ZURpYWxvZ09wdGlvbnM8YW55Pj4gPSB7fSxcbiAgICApOiBPYnNlcnZhYmxlPEc+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaXNNb2JpbGVcbiAgICAgICAgICAgID8gdGhpcy5zaGVldHMub3Blbihjb250ZW50LCBvcHRpb25zKVxuICAgICAgICAgICAgOiB0aGlzLmRpYWxvZ3Mub3Blbihjb250ZW50LCB7XG4gICAgICAgICAgICAgICAgICAuLi5vcHRpb25zLFxuICAgICAgICAgICAgICAgICAgbGFiZWw6IHR1aUlzU3RyaW5nKG9wdGlvbnMubGFiZWwpID8gb3B0aW9ucy5sYWJlbCA6ICcnLFxuICAgICAgICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
|
package/esm2015/directives/responsive-dialog/taiga-ui-addon-mobile-directives-responsive-dialog.js
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tbW9iaWxlLWRpcmVjdGl2ZXMtcmVzcG9uc2l2ZS1kaWFsb2cuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1tb2JpbGUvZGlyZWN0aXZlcy9yZXNwb25zaXZlLWRpYWxvZy90YWlnYS11aS1hZGRvbi1tb2JpbGUtZGlyZWN0aXZlcy1yZXNwb25zaXZlLWRpYWxvZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -1,17 +1,42 @@
|
|
|
1
1
|
import { __decorate } from 'tslib';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
|
-
import { ElementRef, Component, ChangeDetectionStrategy,
|
|
3
|
+
import { NgZone, ElementRef, Directive, Inject, Output, Component, ChangeDetectionStrategy, ViewChild, ViewChildren, HostBinding, HostListener, inject, Injectable, NgModule } from '@angular/core';
|
|
4
4
|
import * as i2 from '@taiga-ui/cdk';
|
|
5
|
-
import { EMPTY_QUERY, tuiPure, tuiCreateToken, tuiProvideOptions, AbstractTuiDialogService, AbstractTuiDialogDirective, TuiClickOutsideModule, tuiAsDialog } from '@taiga-ui/cdk';
|
|
5
|
+
import { tuiTypedFromEvent, tuiZonefree, EMPTY_QUERY, tuiPure, tuiCreateToken, tuiProvideOptions, AbstractTuiDialogService, AbstractTuiDialogDirective, TuiClickOutsideModule, tuiAsDialog } from '@taiga-ui/cdk';
|
|
6
6
|
import { TUI_ANIMATIONS_DURATION, TUI_COMMON_ICONS, TUI_CLOSE_WORD, tuiSlideInTop, TuiButtonModule } from '@taiga-ui/core';
|
|
7
7
|
import { shouldCall } from '@tinkoff/ng-event-plugins';
|
|
8
|
-
import * as
|
|
8
|
+
import * as i4 from '@tinkoff/ng-polymorpheus';
|
|
9
9
|
import { POLYMORPHEUS_CONTEXT, PolymorpheusComponent, PolymorpheusModule } from '@tinkoff/ng-polymorpheus';
|
|
10
|
-
import * as
|
|
10
|
+
import * as i5 from 'rxjs';
|
|
11
11
|
import { BehaviorSubject } from 'rxjs';
|
|
12
12
|
import * as i1 from '@angular/common';
|
|
13
13
|
import { CommonModule } from '@angular/common';
|
|
14
14
|
|
|
15
|
+
const TUI_SHEET_DIALOG_CLOSE = 'tui-sheet-dialog-close';
|
|
16
|
+
class TuiSheetDialogCloseDirective {
|
|
17
|
+
constructor(zone, el) {
|
|
18
|
+
this.zone = zone;
|
|
19
|
+
this.el = el;
|
|
20
|
+
this.tuiSheetDialogClose = tuiTypedFromEvent(this.el.nativeElement, TUI_SHEET_DIALOG_CLOSE).pipe(tuiZonefree(this.zone));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
TuiSheetDialogCloseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogCloseDirective, deps: [{ token: NgZone }, { token: ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
24
|
+
TuiSheetDialogCloseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiSheetDialogCloseDirective, selector: "[tuiSheetDialogClose]", outputs: { tuiSheetDialogClose: "tuiSheetDialogClose" }, ngImport: i0 });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogCloseDirective, decorators: [{
|
|
26
|
+
type: Directive,
|
|
27
|
+
args: [{
|
|
28
|
+
selector: '[tuiSheetDialogClose]',
|
|
29
|
+
}]
|
|
30
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone, decorators: [{
|
|
31
|
+
type: Inject,
|
|
32
|
+
args: [NgZone]
|
|
33
|
+
}] }, { type: i0.ElementRef, decorators: [{
|
|
34
|
+
type: Inject,
|
|
35
|
+
args: [ElementRef]
|
|
36
|
+
}] }]; }, propDecorators: { tuiSheetDialogClose: [{
|
|
37
|
+
type: Output
|
|
38
|
+
}] } });
|
|
39
|
+
|
|
15
40
|
// So we re-enter ngZone and trigger change detection
|
|
16
41
|
function isCloseable() {
|
|
17
42
|
return this.context.closeable;
|
|
@@ -76,7 +101,7 @@ class TuiSheetDialogComponent {
|
|
|
76
101
|
}
|
|
77
102
|
}
|
|
78
103
|
TuiSheetDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogComponent, deps: [{ token: ElementRef }, { token: TUI_ANIMATIONS_DURATION }, { token: TUI_COMMON_ICONS }, { token: TUI_CLOSE_WORD }, { token: POLYMORPHEUS_CONTEXT }], target: i0.ɵɵFactoryTarget.Component });
|
|
79
|
-
TuiSheetDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiSheetDialogComponent, selector: "tui-sheet-dialog", host: { listeners: { "$.class._stuck": "stuck$", "document:touchstart.passive.silent": "onPointerChange(1)", "document:touchend.silent": "onPointerChange(-1)", "document:touchcancel.silent": "onPointerChange(-1)", "scroll.silent": "onPointerChange(0)" }, properties: { "$.class._stuck": "stuck$", "@tuiSlideInTop": "this.slideInTop", "style.top.px": "this.offset", "class._closeable": "this.closeable" } }, viewQueries: [{ propertyName: "sheet", first: true, predicate: ["sheet"], descendants: true }, { propertyName: "stopsRefs", predicate: ["stops"], descendants: true }], ngImport: i0, template: "<div class=\"t-stops\">\n <div\n *ngFor=\"let stop of context.stops\"\n #stops\n class=\"t-stop\"\n [style.margin-top]=\"stop\"\n ></div>\n</div>\n<div\n #sheet\n class=\"t-sheet\"\n [class.t-sheet_small]=\"isSmall\"\n (tuiClickOutside)=\"close()\"\n>\n <div
|
|
104
|
+
TuiSheetDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiSheetDialogComponent, selector: "tui-sheet-dialog", host: { listeners: { "$.class._stuck": "stuck$", "document:touchstart.passive.silent": "onPointerChange(1)", "document:touchend.silent": "onPointerChange(-1)", "document:touchcancel.silent": "onPointerChange(-1)", "scroll.silent": "onPointerChange(0)" }, properties: { "$.class._stuck": "stuck$", "class._fullscreen": "context.fullscreen === true", "@tuiSlideInTop": "this.slideInTop", "style.top.px": "this.offset", "class._closeable": "this.closeable" } }, viewQueries: [{ propertyName: "sheet", first: true, predicate: ["sheet"], descendants: true }, { propertyName: "stopsRefs", predicate: ["stops"], descendants: true }], ngImport: i0, template: "<div class=\"t-stops\">\n <div\n *ngFor=\"let stop of context.stops\"\n #stops\n class=\"t-stop\"\n [style.margin-top]=\"stop\"\n ></div>\n</div>\n<div\n #sheet\n class=\"t-sheet\"\n [class.t-sheet_small]=\"isSmall\"\n (tuiClickOutside)=\"close()\"\n (tuiSheetDialogClose)=\"close()\"\n>\n <div\n *ngIf=\"context.bar\"\n class=\"t-top\"\n ></div>\n <h2\n *ngIf=\"context.label\"\n class=\"t-heading\"\n [id]=\"context.id\"\n >\n <ng-container *polymorpheusOutlet=\"context.label as label; context: context\">\n {{ label }}\n </ng-container>\n </h2>\n <div\n *ngIf=\"context.content\"\n class=\"t-content\"\n >\n <ng-container *polymorpheusOutlet=\"context.content as text; context: context\">\n {{ text }}\n </ng-container>\n </div>\n</div>\n<div class=\"t-footer\"></div>\n", styles: [":host{position:fixed;top:0;left:0;bottom:0;right:0;right:-1rem;display:flex;flex-direction:column;-webkit-clip-path:inset(0 1rem 0 0 round .75rem .75rem 0 0);clip-path:inset(0 1rem 0 0 round .75rem .75rem 0 0);font:var(--tui-font-text-m);overflow-y:scroll;scroll-snap-type:y mandatory;overscroll-behavior:none;box-shadow:0 20rem var(--tui-elevation-01)}:host._closeable{display:block}:host._closeable .t-stops{display:flex}:host._fullscreen{display:block}:host._fullscreen .t-sheet{display:flex;flex-direction:column;min-block-size:calc(100% - 1rem)}:host._fullscreen .t-content{display:flex;flex-direction:column;flex-grow:1}.t-stops{display:none;height:100%;scroll-snap-stop:always;scroll-snap-align:start}.t-stop{scroll-snap-stop:normal;scroll-snap-align:start;height:1rem;width:1rem}.t-sheet{box-shadow:var(--tui-shadow);width:calc(100% - 1rem);border-radius:.75rem .75rem 0 0;padding:0 1rem;margin-top:auto;background:var(--tui-elevation-01);box-sizing:border-box;scroll-snap-stop:always;scroll-snap-align:start}@supports (-moz-appearance: none){.t-sheet_small{scroll-snap-align:end}}.t-top{position:-webkit-sticky;position:sticky;top:0;z-index:1;height:1.5rem;background:var(--tui-elevation-01)}.t-top:after{content:\"\";position:absolute;top:.5rem;left:50%;width:2rem;height:.25rem;transform:translate(-50%);background:var(--tui-base-09);opacity:.3;border-radius:1rem}.t-heading{position:-webkit-sticky;position:sticky;top:1.5rem;z-index:1;display:flex;margin:0;padding-bottom:1rem;font:var(--tui-font-heading-6);background:var(--tui-elevation-01)}.t-heading:last-child{margin-bottom:-.75rem}.t-heading:after{content:\"\";position:absolute;top:100%;left:0;right:0;height:1px;background:var(--tui-base-03);opacity:0}:host._stuck .t-heading:after{opacity:1}.t-close{right:-.25rem;flex-shrink:0;margin-left:auto}.t-content{position:relative;isolation:isolate}.t-content:nth-child(3){margin-top:1rem}.t-footer{height:1rem;scroll-snap-stop:always;scroll-snap-align:end;background:var(--tui-elevation-01)}\n"], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.TuiClickOutsideDirective, selector: "[tuiClickOutside]", outputs: ["tuiClickOutside"] }, { type: TuiSheetDialogCloseDirective, selector: "[tuiSheetDialogClose]", outputs: ["tuiSheetDialogClose"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], animations: [tuiSlideInTop], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
80
105
|
__decorate([
|
|
81
106
|
shouldCall(isCloseable)
|
|
82
107
|
], TuiSheetDialogComponent.prototype, "close", null);
|
|
@@ -94,6 +119,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
94
119
|
host: {
|
|
95
120
|
'[$.class._stuck]': 'stuck$',
|
|
96
121
|
'($.class._stuck)': 'stuck$',
|
|
122
|
+
'[class._fullscreen]': 'context.fullscreen === true',
|
|
97
123
|
},
|
|
98
124
|
}]
|
|
99
125
|
}], ctorParameters: function () { return [{ type: i0.ElementRef, decorators: [{
|
|
@@ -105,7 +131,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
105
131
|
}] }, { type: undefined, decorators: [{
|
|
106
132
|
type: Inject,
|
|
107
133
|
args: [TUI_COMMON_ICONS]
|
|
108
|
-
}] }, { type:
|
|
134
|
+
}] }, { type: i5.Observable, decorators: [{
|
|
109
135
|
type: Inject,
|
|
110
136
|
args: [TUI_CLOSE_WORD]
|
|
111
137
|
}] }, { type: undefined, decorators: [{
|
|
@@ -146,6 +172,8 @@ const TUI_SHEET_DIALOG_DEFAULT_OPTIONS = {
|
|
|
146
172
|
initial: 0,
|
|
147
173
|
offset: 16,
|
|
148
174
|
closeable: true,
|
|
175
|
+
bar: true,
|
|
176
|
+
fullscreen: false,
|
|
149
177
|
};
|
|
150
178
|
/**
|
|
151
179
|
* Default parameters for mobile dialog component
|
|
@@ -199,15 +227,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
199
227
|
class TuiSheetDialogModule {
|
|
200
228
|
}
|
|
201
229
|
TuiSheetDialogModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
202
|
-
TuiSheetDialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, declarations: [TuiSheetDialogComponent,
|
|
230
|
+
TuiSheetDialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, declarations: [TuiSheetDialogComponent,
|
|
231
|
+
TuiSheetDialogDirective,
|
|
232
|
+
TuiSheetDialogCloseDirective], imports: [CommonModule, PolymorpheusModule, TuiClickOutsideModule, TuiButtonModule], exports: [TuiSheetDialogComponent,
|
|
233
|
+
TuiSheetDialogDirective,
|
|
234
|
+
TuiSheetDialogCloseDirective] });
|
|
203
235
|
TuiSheetDialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, providers: [tuiAsDialog(TuiSheetDialogService)], imports: [[CommonModule, PolymorpheusModule, TuiClickOutsideModule, TuiButtonModule]] });
|
|
204
236
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiSheetDialogModule, decorators: [{
|
|
205
237
|
type: NgModule,
|
|
206
238
|
args: [{
|
|
207
239
|
imports: [CommonModule, PolymorpheusModule, TuiClickOutsideModule, TuiButtonModule],
|
|
208
|
-
declarations: [
|
|
240
|
+
declarations: [
|
|
241
|
+
TuiSheetDialogComponent,
|
|
242
|
+
TuiSheetDialogDirective,
|
|
243
|
+
TuiSheetDialogCloseDirective,
|
|
244
|
+
],
|
|
209
245
|
providers: [tuiAsDialog(TuiSheetDialogService)],
|
|
210
|
-
exports: [
|
|
246
|
+
exports: [
|
|
247
|
+
TuiSheetDialogComponent,
|
|
248
|
+
TuiSheetDialogDirective,
|
|
249
|
+
TuiSheetDialogCloseDirective,
|
|
250
|
+
],
|
|
211
251
|
}]
|
|
212
252
|
}] });
|
|
213
253
|
|
|
@@ -215,5 +255,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
215
255
|
* Generated bundle index. Do not edit.
|
|
216
256
|
*/
|
|
217
257
|
|
|
218
|
-
export { TUI_SHEET_DIALOG_DEFAULT_OPTIONS, TUI_SHEET_DIALOG_OPTIONS, TuiSheetDialogComponent, TuiSheetDialogDirective, TuiSheetDialogModule, TuiSheetDialogService, tuiSheetDialogOptionsProvider };
|
|
258
|
+
export { TUI_SHEET_DIALOG_CLOSE, TUI_SHEET_DIALOG_DEFAULT_OPTIONS, TUI_SHEET_DIALOG_OPTIONS, TuiSheetDialogCloseDirective, TuiSheetDialogComponent, TuiSheetDialogDirective, TuiSheetDialogModule, TuiSheetDialogService, tuiSheetDialogOptionsProvider };
|
|
219
259
|
//# sourceMappingURL=taiga-ui-addon-mobile-components-sheet-dialog.js.map
|