@datarailsshared/datarailsshared 1.6.340 → 1.6.344

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.
@@ -1,6 +1,6 @@
1
1
  @import '@angular/material/prebuilt-themes/deeppurple-amber.css';
2
2
  @import '@ng-select/ng-select/themes/default.theme.css';
3
- @import 'ngx-toastr/toastr';
3
+ @import 'ngx-toastr/toastr.css';
4
4
  @import '@ctrl/ngx-emoji-mart/picker';
5
5
 
6
6
  @import 'codemirror/lib/codemirror.css';
@@ -11,6 +11,10 @@ export class DrawerConfig {
11
11
  this.disableClose = false;
12
12
  /** Aria label to assign to the drawer element. */
13
13
  this.ariaLabel = null;
14
+ /** Aria role for the drawer container */
15
+ this.role = 'dialog';
16
+ /** Whether the drawer should be treated as a modal dialog */
17
+ this.isModal = true;
14
18
  /**
15
19
  * Whether the drawer should close when the user goes backwards/forwards in history.
16
20
  * Note that this usually doesn't include clicking on links (unless the user is using
@@ -32,6 +36,8 @@ export class DrawerConfig {
32
36
  this.position = 'bottom';
33
37
  /** Whether to render the drawer without default container styles and handle. */
34
38
  this.unstyled = false;
39
+ /** Drag behavior for bottom drawer. */
40
+ this.dragMode = 'dismiss';
35
41
  }
36
42
  }
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyYXdlci9kcmF3ZXItY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVVBOztHQUVHO0FBQ0gsTUFBTSxPQUFPLFlBQVk7SUFBekI7UUFpQkksb0RBQW9EO1FBQ3BELFNBQUksR0FBYyxJQUFJLENBQUM7UUFFdkIseUNBQXlDO1FBQ3pDLGdCQUFXLEdBQWEsS0FBSyxDQUFDO1FBSzlCLCtFQUErRTtRQUMvRSxpQkFBWSxHQUFhLEtBQUssQ0FBQztRQUUvQixrREFBa0Q7UUFDbEQsY0FBUyxHQUFtQixJQUFJLENBQUM7UUFFakM7Ozs7V0FJRztRQUNILHNCQUFpQixHQUFhLElBQUksQ0FBQztRQUVuQzs7OztXQUlHO1FBQ0gsY0FBUyxHQUF3QyxnQkFBZ0IsQ0FBQztRQUVsRTs7O1dBR0c7UUFDSCxpQkFBWSxHQUFhLElBQUksQ0FBQztRQUs5Qiw4QkFBOEI7UUFDOUIsYUFBUSxHQUFvQixRQUFRLENBQUM7UUEwQnJDLGdGQUFnRjtRQUNoRixhQUFRLEdBQWEsS0FBSyxDQUFDO0lBQy9CLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9iaWRpJztcbmltcG9ydCB7IFNjcm9sbFN0cmF0ZWd5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgSW5qZWN0b3IsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqIE9wdGlvbnMgZm9yIHdoZXJlIHRvIHNldCBmb2N1cyB0byBhdXRvbWF0aWNhbGx5IG9uIGRpYWxvZyBvcGVuLiAqL1xuZXhwb3J0IHR5cGUgQXV0b0ZvY3VzVGFyZ2V0ID0gJ2RpYWxvZycgfCAnZmlyc3QtdGFiYmFibGUnIHwgJ2ZpcnN0LWhlYWRpbmcnO1xuXG4vKiogUG9zc2libGUgb3ZlcnJpZGVzIGZvciBhIGRyYXdlcidzIHBvc2l0aW9uLiAqL1xuZXhwb3J0IHR5cGUgRHJhd2VyUG9zaXRpb24gPSAndG9wJyB8ICdib3R0b20nIHwgJ2xlZnQnIHwgJ3JpZ2h0JztcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIHVzZWQgd2hlbiBvcGVuaW5nIGEgZHJhd2VyLlxuICovXG5leHBvcnQgY2xhc3MgRHJhd2VyQ29uZmlnPEQgPSBhbnk+IHtcbiAgICAvKiogVGhlIHZpZXcgY29udGFpbmVyIHRvIHBsYWNlIHRoZSBvdmVybGF5IGZvciB0aGUgZHJhd2VyIGludG8uICovXG4gICAgdmlld0NvbnRhaW5lclJlZj86IFZpZXdDb250YWluZXJSZWY7XG5cbiAgICAvKiogRWxlbWVudCB0byBvYnNlcnZlIGZvciByZXNpemUgY2hhbmdlcyB0byBhZGp1c3QgZHJhd2VyIHBvc2l0aW9uaW5nLlxuICAgICAqIFRoZSBkcmF3ZXIgd2lsbCBmaXQgd2l0aGluIHRoZSBib3VuZGFyaWVzIG9mIHRoaXMgZWxlbWVudC4gKi9cbiAgICBvYnNlcnZlZEVsZW1lbnQ/OiBIVE1MRWxlbWVudDtcblxuICAgIC8qKiBJRCBmb3IgdGhlIGRyYXdlci4gSWYgb21pdHRlZCwgYSB1bmlxdWUgb25lIHdpbGwgYmUgZ2VuZXJhdGVkLiAqL1xuICAgIGlkPzogc3RyaW5nO1xuXG4gICAgLyoqIEV4dHJhIENTUyBjbGFzc2VzIHRvIGJlIGFkZGVkIHRvIHRoZSBkcmF3ZXIgY29udGFpbmVyLiAqL1xuICAgIHBhbmVsQ2xhc3M/OiBzdHJpbmcgfCBzdHJpbmdbXTtcblxuICAgIC8qKiBUZXh0IGxheW91dCBkaXJlY3Rpb24gZm9yIHRoZSBkcmF3ZXIuICovXG4gICAgZGlyZWN0aW9uPzogRGlyZWN0aW9uO1xuXG4gICAgLyoqIERhdGEgYmVpbmcgaW5qZWN0ZWQgaW50byB0aGUgY2hpbGQgY29tcG9uZW50LiAqL1xuICAgIGRhdGE/OiBEIHwgbnVsbCA9IG51bGw7XG5cbiAgICAvKiogV2hldGhlciB0aGUgZHJhd2VyIGhhcyBhIGJhY2tkcm9wLiAqL1xuICAgIGhhc0JhY2tkcm9wPzogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgLyoqIEN1c3RvbSBjbGFzcyBmb3IgdGhlIGJhY2tkcm9wLiAqL1xuICAgIGJhY2tkcm9wQ2xhc3M/OiBzdHJpbmc7XG5cbiAgICAvKiogV2hldGhlciB0aGUgdXNlciBjYW4gdXNlIGVzY2FwZSBvciBjbGlja2luZyBvdXRzaWRlIHRvIGNsb3NlIHRoZSBkcmF3ZXIuICovXG4gICAgZGlzYWJsZUNsb3NlPzogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgLyoqIEFyaWEgbGFiZWwgdG8gYXNzaWduIHRvIHRoZSBkcmF3ZXIgZWxlbWVudC4gKi9cbiAgICBhcmlhTGFiZWw/OiBzdHJpbmcgfCBudWxsID0gbnVsbDtcblxuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgdGhlIGRyYXdlciBzaG91bGQgY2xvc2Ugd2hlbiB0aGUgdXNlciBnb2VzIGJhY2t3YXJkcy9mb3J3YXJkcyBpbiBoaXN0b3J5LlxuICAgICAqIE5vdGUgdGhhdCB0aGlzIHVzdWFsbHkgZG9lc24ndCBpbmNsdWRlIGNsaWNraW5nIG9uIGxpbmtzICh1bmxlc3MgdGhlIHVzZXIgaXMgdXNpbmdcbiAgICAgKiB0aGUgYEhhc2hMb2NhdGlvblN0cmF0ZWd5YCkuXG4gICAgICovXG4gICAgY2xvc2VPbk5hdmlnYXRpb24/OiBib29sZWFuID0gdHJ1ZTtcblxuICAgIC8qKlxuICAgICAqIFdoZXJlIHRoZSBkcmF3ZXIgc2hvdWxkIGZvY3VzIG9uIG9wZW4uXG4gICAgICogQGJyZWFraW5nLWNoYW5nZSAxNC4wLjAgUmVtb3ZlIGJvb2xlYW4gb3B0aW9uIGZyb20gYXV0b0ZvY3VzLiBVc2Ugc3RyaW5nIG9yXG4gICAgICogQXV0b0ZvY3VzVGFyZ2V0IGluc3RlYWQuXG4gICAgICovXG4gICAgYXV0b0ZvY3VzPzogQXV0b0ZvY3VzVGFyZ2V0IHwgc3RyaW5nIHwgYm9vbGVhbiA9ICdmaXJzdC10YWJiYWJsZSc7XG5cbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIHRoZSBkcmF3ZXIgc2hvdWxkIHJlc3RvcmUgZm9jdXMgdG8gdGhlXG4gICAgICogcHJldmlvdXNseS1mb2N1c2VkIGVsZW1lbnQsIGFmdGVyIGl0J3MgY2xvc2VkLlxuICAgICAqL1xuICAgIHJlc3RvcmVGb2N1cz86IGJvb2xlYW4gPSB0cnVlO1xuXG4gICAgLyoqIFNjcm9sbCBzdHJhdGVneSB0byBiZSB1c2VkIGZvciB0aGUgZHJhd2VyLiAqL1xuICAgIHNjcm9sbFN0cmF0ZWd5PzogU2Nyb2xsU3RyYXRlZ3k7XG5cbiAgICAvKiogUG9zaXRpb24gb2YgdGhlIGRyYXdlci4gKi9cbiAgICBwb3NpdGlvbj86IERyYXdlclBvc2l0aW9uID0gJ2JvdHRvbSc7XG5cbiAgICAvKiogV2lkdGggb2YgdGhlIGRyYXdlci4gKi9cbiAgICB3aWR0aD86IHN0cmluZztcblxuICAgIC8qKiBIZWlnaHQgb2YgdGhlIGRyYXdlci4gKi9cbiAgICBoZWlnaHQ/OiBzdHJpbmc7XG5cbiAgICAvKiogTWluLXdpZHRoIG9mIHRoZSBkcmF3ZXIuIElmIGEgbnVtYmVyIGlzIHByb3ZpZGVkLCBhc3N1bWVzIHBpeGVsIHVuaXRzLiAqL1xuICAgIG1pbldpZHRoPzogbnVtYmVyIHwgc3RyaW5nO1xuXG4gICAgLyoqIE1pbi1oZWlnaHQgb2YgdGhlIGRyYXdlci4gSWYgYSBudW1iZXIgaXMgcHJvdmlkZWQsIGFzc3VtZXMgcGl4ZWwgdW5pdHMuICovXG4gICAgbWluSGVpZ2h0PzogbnVtYmVyIHwgc3RyaW5nO1xuXG4gICAgLyoqIE1heC13aWR0aCBvZiB0aGUgZHJhd2VyLiBJZiBhIG51bWJlciBpcyBwcm92aWRlZCwgYXNzdW1lcyBwaXhlbCB1bml0cy4gKi9cbiAgICBtYXhXaWR0aD86IG51bWJlciB8IHN0cmluZztcblxuICAgIC8qKiBNYXgtaGVpZ2h0IG9mIHRoZSBkcmF3ZXIuIElmIGEgbnVtYmVyIGlzIHByb3ZpZGVkLCBhc3N1bWVzIHBpeGVsIHVuaXRzLiAqL1xuICAgIG1heEhlaWdodD86IG51bWJlciB8IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEluamVjdG9yIHVzZWQgZm9yIHRoZSBpbnN0YW50aWF0aW9uIG9mIHRoZSBjb21wb25lbnQgdG8gYmUgYXR0YWNoZWQuIElmIHByb3ZpZGVkLFxuICAgICAqIHRha2VzIHByZWNlZGVuY2Ugb3ZlciB0aGUgaW5qZWN0b3IgaW5kaXJlY3RseSBwcm92aWRlZCBieSBgVmlld0NvbnRhaW5lclJlZmAuXG4gICAgICovXG4gICAgaW5qZWN0b3I/OiBJbmplY3RvcjtcblxuICAgIC8qKiBXaGV0aGVyIHRvIHJlbmRlciB0aGUgZHJhd2VyIHdpdGhvdXQgZGVmYXVsdCBjb250YWluZXIgc3R5bGVzIGFuZCBoYW5kbGUuICovXG4gICAgdW5zdHlsZWQ/OiBib29sZWFuID0gZmFsc2U7XG59XG4iXX0=
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyYXdlci9kcmF3ZXItY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNBOztHQUVHO0FBQ0gsTUFBTSxPQUFPLFlBQVk7SUFBekI7UUFpQkksb0RBQW9EO1FBQ3BELFNBQUksR0FBYyxJQUFJLENBQUM7UUFFdkIseUNBQXlDO1FBQ3pDLGdCQUFXLEdBQWEsS0FBSyxDQUFDO1FBSzlCLCtFQUErRTtRQUMvRSxpQkFBWSxHQUFhLEtBQUssQ0FBQztRQUUvQixrREFBa0Q7UUFDbEQsY0FBUyxHQUFtQixJQUFJLENBQUM7UUFFakMseUNBQXlDO1FBQ3pDLFNBQUksR0FBZ0IsUUFBUSxDQUFDO1FBRTdCLDZEQUE2RDtRQUM3RCxZQUFPLEdBQWEsSUFBSSxDQUFDO1FBRXpCOzs7O1dBSUc7UUFDSCxzQkFBaUIsR0FBYSxJQUFJLENBQUM7UUFFbkM7Ozs7V0FJRztRQUNILGNBQVMsR0FBd0MsZ0JBQWdCLENBQUM7UUFFbEU7OztXQUdHO1FBQ0gsaUJBQVksR0FBYSxJQUFJLENBQUM7UUFLOUIsOEJBQThCO1FBQzlCLGFBQVEsR0FBb0IsUUFBUSxDQUFDO1FBMEJyQyxnRkFBZ0Y7UUFDaEYsYUFBUSxHQUFhLEtBQUssQ0FBQztRQUUzQix1Q0FBdUM7UUFDdkMsYUFBUSxHQUFvQixTQUFTLENBQUM7SUFDMUMsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2JpZGknO1xuaW1wb3J0IHsgRGlhbG9nUm9sZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kaWFsb2cnO1xuaW1wb3J0IHsgU2Nyb2xsU3RyYXRlZ3kgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBJbmplY3RvciwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKiogT3B0aW9ucyBmb3Igd2hlcmUgdG8gc2V0IGZvY3VzIHRvIGF1dG9tYXRpY2FsbHkgb24gZGlhbG9nIG9wZW4uICovXG5leHBvcnQgdHlwZSBBdXRvRm9jdXNUYXJnZXQgPSAnZGlhbG9nJyB8ICdmaXJzdC10YWJiYWJsZScgfCAnZmlyc3QtaGVhZGluZyc7XG5cbi8qKiBQb3NzaWJsZSBvdmVycmlkZXMgZm9yIGEgZHJhd2VyJ3MgcG9zaXRpb24uICovXG5leHBvcnQgdHlwZSBEcmF3ZXJQb3NpdGlvbiA9ICd0b3AnIHwgJ2JvdHRvbScgfCAnbGVmdCcgfCAncmlnaHQnO1xuXG4vKiogUG9zc2libGUgZHJhZyBiZWhhdmlvcnMgZm9yIGEgYm90dG9tLXBvc2l0aW9uZWQgZHJhd2VyLiAqL1xuZXhwb3J0IHR5cGUgRHJhd2VyRHJhZ01vZGUgPSAnZGlzbWlzcycgfCAncmVzaXplJztcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIHVzZWQgd2hlbiBvcGVuaW5nIGEgZHJhd2VyLlxuICovXG5leHBvcnQgY2xhc3MgRHJhd2VyQ29uZmlnPEQgPSBhbnk+IHtcbiAgICAvKiogVGhlIHZpZXcgY29udGFpbmVyIHRvIHBsYWNlIHRoZSBvdmVybGF5IGZvciB0aGUgZHJhd2VyIGludG8uICovXG4gICAgdmlld0NvbnRhaW5lclJlZj86IFZpZXdDb250YWluZXJSZWY7XG5cbiAgICAvKiogRWxlbWVudCB0byBvYnNlcnZlIGZvciByZXNpemUgY2hhbmdlcyB0byBhZGp1c3QgZHJhd2VyIHBvc2l0aW9uaW5nLlxuICAgICAqIFRoZSBkcmF3ZXIgd2lsbCBmaXQgd2l0aGluIHRoZSBib3VuZGFyaWVzIG9mIHRoaXMgZWxlbWVudC4gKi9cbiAgICBvYnNlcnZlZEVsZW1lbnQ/OiBIVE1MRWxlbWVudDtcblxuICAgIC8qKiBJRCBmb3IgdGhlIGRyYXdlci4gSWYgb21pdHRlZCwgYSB1bmlxdWUgb25lIHdpbGwgYmUgZ2VuZXJhdGVkLiAqL1xuICAgIGlkPzogc3RyaW5nO1xuXG4gICAgLyoqIEV4dHJhIENTUyBjbGFzc2VzIHRvIGJlIGFkZGVkIHRvIHRoZSBkcmF3ZXIgY29udGFpbmVyLiAqL1xuICAgIHBhbmVsQ2xhc3M/OiBzdHJpbmcgfCBzdHJpbmdbXTtcblxuICAgIC8qKiBUZXh0IGxheW91dCBkaXJlY3Rpb24gZm9yIHRoZSBkcmF3ZXIuICovXG4gICAgZGlyZWN0aW9uPzogRGlyZWN0aW9uO1xuXG4gICAgLyoqIERhdGEgYmVpbmcgaW5qZWN0ZWQgaW50byB0aGUgY2hpbGQgY29tcG9uZW50LiAqL1xuICAgIGRhdGE/OiBEIHwgbnVsbCA9IG51bGw7XG5cbiAgICAvKiogV2hldGhlciB0aGUgZHJhd2VyIGhhcyBhIGJhY2tkcm9wLiAqL1xuICAgIGhhc0JhY2tkcm9wPzogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgLyoqIEN1c3RvbSBjbGFzcyBmb3IgdGhlIGJhY2tkcm9wLiAqL1xuICAgIGJhY2tkcm9wQ2xhc3M/OiBzdHJpbmc7XG5cbiAgICAvKiogV2hldGhlciB0aGUgdXNlciBjYW4gdXNlIGVzY2FwZSBvciBjbGlja2luZyBvdXRzaWRlIHRvIGNsb3NlIHRoZSBkcmF3ZXIuICovXG4gICAgZGlzYWJsZUNsb3NlPzogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgLyoqIEFyaWEgbGFiZWwgdG8gYXNzaWduIHRvIHRoZSBkcmF3ZXIgZWxlbWVudC4gKi9cbiAgICBhcmlhTGFiZWw/OiBzdHJpbmcgfCBudWxsID0gbnVsbDtcblxuICAgIC8qKiBBcmlhIHJvbGUgZm9yIHRoZSBkcmF3ZXIgY29udGFpbmVyICovXG4gICAgcm9sZT86IERpYWxvZ1JvbGUgPSAnZGlhbG9nJztcblxuICAgIC8qKiBXaGV0aGVyIHRoZSBkcmF3ZXIgc2hvdWxkIGJlIHRyZWF0ZWQgYXMgYSBtb2RhbCBkaWFsb2cgKi9cbiAgICBpc01vZGFsPzogYm9vbGVhbiA9IHRydWU7XG5cbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIHRoZSBkcmF3ZXIgc2hvdWxkIGNsb3NlIHdoZW4gdGhlIHVzZXIgZ29lcyBiYWNrd2FyZHMvZm9yd2FyZHMgaW4gaGlzdG9yeS5cbiAgICAgKiBOb3RlIHRoYXQgdGhpcyB1c3VhbGx5IGRvZXNuJ3QgaW5jbHVkZSBjbGlja2luZyBvbiBsaW5rcyAodW5sZXNzIHRoZSB1c2VyIGlzIHVzaW5nXG4gICAgICogdGhlIGBIYXNoTG9jYXRpb25TdHJhdGVneWApLlxuICAgICAqL1xuICAgIGNsb3NlT25OYXZpZ2F0aW9uPzogYm9vbGVhbiA9IHRydWU7XG5cbiAgICAvKipcbiAgICAgKiBXaGVyZSB0aGUgZHJhd2VyIHNob3VsZCBmb2N1cyBvbiBvcGVuLlxuICAgICAqIEBicmVha2luZy1jaGFuZ2UgMTQuMC4wIFJlbW92ZSBib29sZWFuIG9wdGlvbiBmcm9tIGF1dG9Gb2N1cy4gVXNlIHN0cmluZyBvclxuICAgICAqIEF1dG9Gb2N1c1RhcmdldCBpbnN0ZWFkLlxuICAgICAqL1xuICAgIGF1dG9Gb2N1cz86IEF1dG9Gb2N1c1RhcmdldCB8IHN0cmluZyB8IGJvb2xlYW4gPSAnZmlyc3QtdGFiYmFibGUnO1xuXG4gICAgLyoqXG4gICAgICogV2hldGhlciB0aGUgZHJhd2VyIHNob3VsZCByZXN0b3JlIGZvY3VzIHRvIHRoZVxuICAgICAqIHByZXZpb3VzbHktZm9jdXNlZCBlbGVtZW50LCBhZnRlciBpdCdzIGNsb3NlZC5cbiAgICAgKi9cbiAgICByZXN0b3JlRm9jdXM/OiBib29sZWFuID0gdHJ1ZTtcblxuICAgIC8qKiBTY3JvbGwgc3RyYXRlZ3kgdG8gYmUgdXNlZCBmb3IgdGhlIGRyYXdlci4gKi9cbiAgICBzY3JvbGxTdHJhdGVneT86IFNjcm9sbFN0cmF0ZWd5O1xuXG4gICAgLyoqIFBvc2l0aW9uIG9mIHRoZSBkcmF3ZXIuICovXG4gICAgcG9zaXRpb24/OiBEcmF3ZXJQb3NpdGlvbiA9ICdib3R0b20nO1xuXG4gICAgLyoqIFdpZHRoIG9mIHRoZSBkcmF3ZXIuICovXG4gICAgd2lkdGg/OiBzdHJpbmc7XG5cbiAgICAvKiogSGVpZ2h0IG9mIHRoZSBkcmF3ZXIuICovXG4gICAgaGVpZ2h0Pzogc3RyaW5nO1xuXG4gICAgLyoqIE1pbi13aWR0aCBvZiB0aGUgZHJhd2VyLiBJZiBhIG51bWJlciBpcyBwcm92aWRlZCwgYXNzdW1lcyBwaXhlbCB1bml0cy4gKi9cbiAgICBtaW5XaWR0aD86IG51bWJlciB8IHN0cmluZztcblxuICAgIC8qKiBNaW4taGVpZ2h0IG9mIHRoZSBkcmF3ZXIuIElmIGEgbnVtYmVyIGlzIHByb3ZpZGVkLCBhc3N1bWVzIHBpeGVsIHVuaXRzLiAqL1xuICAgIG1pbkhlaWdodD86IG51bWJlciB8IHN0cmluZztcblxuICAgIC8qKiBNYXgtd2lkdGggb2YgdGhlIGRyYXdlci4gSWYgYSBudW1iZXIgaXMgcHJvdmlkZWQsIGFzc3VtZXMgcGl4ZWwgdW5pdHMuICovXG4gICAgbWF4V2lkdGg/OiBudW1iZXIgfCBzdHJpbmc7XG5cbiAgICAvKiogTWF4LWhlaWdodCBvZiB0aGUgZHJhd2VyLiBJZiBhIG51bWJlciBpcyBwcm92aWRlZCwgYXNzdW1lcyBwaXhlbCB1bml0cy4gKi9cbiAgICBtYXhIZWlnaHQ/OiBudW1iZXIgfCBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBJbmplY3RvciB1c2VkIGZvciB0aGUgaW5zdGFudGlhdGlvbiBvZiB0aGUgY29tcG9uZW50IHRvIGJlIGF0dGFjaGVkLiBJZiBwcm92aWRlZCxcbiAgICAgKiB0YWtlcyBwcmVjZWRlbmNlIG92ZXIgdGhlIGluamVjdG9yIGluZGlyZWN0bHkgcHJvdmlkZWQgYnkgYFZpZXdDb250YWluZXJSZWZgLlxuICAgICAqL1xuICAgIGluamVjdG9yPzogSW5qZWN0b3I7XG5cbiAgICAvKiogV2hldGhlciB0byByZW5kZXIgdGhlIGRyYXdlciB3aXRob3V0IGRlZmF1bHQgY29udGFpbmVyIHN0eWxlcyBhbmQgaGFuZGxlLiAqL1xuICAgIHVuc3R5bGVkPzogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgLyoqIERyYWcgYmVoYXZpb3IgZm9yIGJvdHRvbSBkcmF3ZXIuICovXG4gICAgZHJhZ01vZGU/OiBEcmF3ZXJEcmFnTW9kZSA9ICdkaXNtaXNzJztcbn1cbiJdfQ==
@@ -3,12 +3,12 @@ import { CdkDialogContainer, DialogModule } from '@angular/cdk/dialog';
3
3
  import { OverlayRef } from '@angular/cdk/overlay';
4
4
  import { CdkPortalOutlet, PortalModule } from '@angular/cdk/portal';
5
5
  import { CommonModule, DOCUMENT } from '@angular/common';
6
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, inject, Inject, NgZone, Optional, ViewChild, ViewEncapsulation, } from '@angular/core';
6
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, inject, Inject, NgZone, Optional, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
7
7
  import { MatCommonModule } from '@angular/material/core';
8
8
  import { distinctUntilChanged, finalize, fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';
9
9
  import { drDrawerAnimations } from './drawer-animation';
10
10
  import { DrawerConfig } from './drawer-config';
11
- import { BottomPositionStrategy } from './drawer-position-strategy';
11
+ import { BottomDismissPositionStrategy, BottomResizePositionStrategy } from './drawer-position-strategy';
12
12
  import * as i0 from "@angular/core";
13
13
  import * as i1 from "@angular/cdk/a11y";
14
14
  import * as i2 from "./drawer-config";
@@ -18,6 +18,9 @@ import * as i5 from "@angular/common";
18
18
  const _c0 = ["handleRef"];
19
19
  function DrawerContainer_div_0_Template(rf, ctx) { if (rf & 1) {
20
20
  i0.ɵɵelement(0, "div", 3, 4);
21
+ } if (rf & 2) {
22
+ const ctx_r0 = i0.ɵɵnextContext();
23
+ i0.ɵɵclassProp("handle--resize", ctx_r0._config.dragMode === "resize")("handle--dismiss", ctx_r0._config.dragMode === "dismiss");
21
24
  } }
22
25
  function DrawerContainer_ng_template_2_Template(rf, ctx) { }
23
26
  /**
@@ -31,6 +34,8 @@ export class DrawerContainer extends CdkDialogContainer {
31
34
  constructor(elementRef, focusTrapFactory, document, config, checker, ngZone, overlayRef, focusMonitor) {
32
35
  super(elementRef, focusTrapFactory, document, config, checker, ngZone, overlayRef, focusMonitor);
33
36
  this.overlayRef = overlayRef;
37
+ /** Emits final height (px) after resize. Available only in resize mode. */
38
+ this.afterResized = new EventEmitter();
34
39
  /** The state of the drawer animations. */
35
40
  this._animationState = 'void';
36
41
  /** Emits whenever the state of the animation changes. */
@@ -71,45 +76,35 @@ export class DrawerContainer extends CdkDialogContainer {
71
76
  resolvePositionStrategy() {
72
77
  switch (this._config.position) {
73
78
  case 'bottom':
74
- return new BottomPositionStrategy();
79
+ return this._config.dragMode === 'resize'
80
+ ? new BottomResizePositionStrategy(this._config)
81
+ : new BottomDismissPositionStrategy();
82
+ default:
83
+ return undefined;
75
84
  }
76
85
  }
77
86
  setupDragListener() {
87
+ const strategy = this.positionStrategy;
88
+ if (!strategy)
89
+ return;
78
90
  const mousedown$ = fromEvent(this._handleRef.nativeElement, 'mousedown');
79
91
  const mousemove$ = fromEvent(document, 'mousemove');
80
92
  const mouseup$ = fromEvent(document, 'mouseup');
81
- let lastPosition = 0;
82
- let initPosition = 0;
83
- let currentPosition = 0;
84
93
  const container = this._elementRef.nativeElement;
85
- setTimeout(() => {
86
- lastPosition = this.getContainerPosition(container);
87
- initPosition = lastPosition;
88
- });
94
+ const overlayElement = this.overlayRef.overlayElement;
89
95
  mousedown$
90
- .pipe(switchMap(() => mousemove$.pipe(finalize(() => {
91
- const container = this._elementRef.nativeElement;
92
- if (this.positionStrategy.shouldClose(currentPosition, initPosition, lastPosition)) {
96
+ .pipe(tap(() => strategy.onDragStart(container, overlayElement)), switchMap(() => mousemove$.pipe(takeUntil(mouseup$), finalize(() => {
97
+ const result = strategy.onDragEnd(container, overlayElement);
98
+ if (result.shouldClose) {
93
99
  this.overlayRef.dispose();
94
100
  return;
95
101
  }
96
- container.style.transition = 'transform 0.5s cubic-bezier(0.32, 0.72, 0, 1)';
97
- container.style.transform = `translate3d(0px, 0px, 0px)`;
98
- }), takeUntil(mouseup$))), map((event) => this.positionStrategy.extractMousePosition(event)), distinctUntilChanged(), tap((position) => {
99
- let containerPosition = this.getContainerPosition(container);
100
- containerPosition = Math.min(containerPosition, lastPosition);
101
- lastPosition = Math.min(containerPosition, lastPosition);
102
- currentPosition = position;
103
- container.style.transition = 'none';
104
- container.style.transform = this.positionStrategy.calculateTransform(position, containerPosition);
105
- }), takeUntil(this.destroy$))
102
+ if (result.height !== undefined) {
103
+ this.afterResized.emit(result.height);
104
+ }
105
+ }))), map((event) => strategy.extractMousePosition(event)), distinctUntilChanged(), tap((position) => strategy.onDragMove(position, container, overlayElement)), takeUntil(this.destroy$))
106
106
  .subscribe();
107
107
  }
108
- getContainerPosition(container) {
109
- return this._config.position === 'bottom' || this._config.position === 'top'
110
- ? container.getBoundingClientRect().top
111
- : container.getBoundingClientRect().left;
112
- }
113
108
  ngOnDestroy() {
114
109
  super.ngOnDestroy();
115
110
  this.destroy$.next();
@@ -142,8 +137,8 @@ export class DrawerContainer extends CdkDialogContainer {
142
137
  i0.ɵɵsyntheticHostProperty("@state", ctx._animationState);
143
138
  i0.ɵɵclassMap(ctx._drawerPosition);
144
139
  i0.ɵɵclassProp("dr-drawer-container", !ctx._config.unstyled);
145
- } }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 3, vars: 3, consts: [["class", "handle", 4, "ngIf"], [1, "dr-drawer-container__wrapper"], ["cdkPortalOutlet", ""], [1, "handle"], ["handleRef", ""]], template: function DrawerContainer_Template(rf, ctx) { if (rf & 1) {
146
- i0.ɵɵtemplate(0, DrawerContainer_div_0_Template, 2, 0, "div", 0);
140
+ } }, outputs: { afterResized: "afterResized" }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 3, vars: 3, consts: [["class", "handle", 3, "handle--resize", "handle--dismiss", 4, "ngIf"], [1, "dr-drawer-container__wrapper"], ["cdkPortalOutlet", ""], [1, "handle"], ["handleRef", ""]], template: function DrawerContainer_Template(rf, ctx) { if (rf & 1) {
141
+ i0.ɵɵtemplate(0, DrawerContainer_div_0_Template, 2, 4, "div", 0);
147
142
  i0.ɵɵelementStart(1, "div", 1);
148
143
  i0.ɵɵtemplate(2, DrawerContainer_ng_template_2_Template, 0, 0, "ng-template", 2);
149
144
  i0.ɵɵelementEnd();
@@ -151,7 +146,7 @@ export class DrawerContainer extends CdkDialogContainer {
151
146
  i0.ɵɵproperty("ngIf", ctx._config.position === "bottom" && !ctx._config.unstyled);
152
147
  i0.ɵɵadvance(1);
153
148
  i0.ɵɵclassProp("unstyled-wrapper", ctx._config.unstyled);
154
- } }, dependencies: [PortalModule, i4.CdkPortalOutlet, DialogModule, MatCommonModule, CommonModule, i5.NgIf], styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.dr-drawer-container__wrapper.unstyled-wrapper{flex:unset;overflow:unset}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"], encapsulation: 2, data: { animation: [drDrawerAnimations.drawerState] } }); }
149
+ } }, dependencies: [PortalModule, i4.CdkPortalOutlet, DialogModule, MatCommonModule, CommonModule, i5.NgIf], styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;height:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.dr-drawer-container__wrapper.unstyled-wrapper{flex:unset;overflow:unset}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;user-select:none;-webkit-user-select:none;flex-shrink:0}.handle--resize{cursor:ns-resize}.handle--dismiss{cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px;transition:background-color .2s ease}.handle:hover:after{background-color:#b6b8bf}.handle:active:after{background-color:#9b9ea8}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"], encapsulation: 2, data: { animation: [drDrawerAnimations.drawerState] } }); }
155
150
  }
156
151
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrawerContainer, [{
157
152
  type: Component,
@@ -166,7 +161,7 @@ export class DrawerContainer extends CdkDialogContainer {
166
161
  '[@state]': '_animationState',
167
162
  '(@state.start)': '_onAnimationStart($event)',
168
163
  '(@state.done)': '_onAnimationDone($event)',
169
- }, standalone: true, imports: [PortalModule, DialogModule, MatCommonModule, CommonModule], template: "<div *ngIf=\"_config.position === 'bottom' && !_config.unstyled\" #handleRef class=\"handle\"></div>\n<div class=\"dr-drawer-container__wrapper\" [class.unstyled-wrapper]=\"_config.unstyled\">\n <ng-template cdkPortalOutlet></ng-template>\n</div>\n", styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.dr-drawer-container__wrapper.unstyled-wrapper{flex:unset;overflow:unset}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"] }]
164
+ }, standalone: true, imports: [PortalModule, DialogModule, MatCommonModule, CommonModule], template: "<div\n *ngIf=\"_config.position === 'bottom' && !_config.unstyled\"\n #handleRef\n class=\"handle\"\n [class.handle--resize]=\"_config.dragMode === 'resize'\"\n [class.handle--dismiss]=\"_config.dragMode === 'dismiss'\"></div>\n<div class=\"dr-drawer-container__wrapper\" [class.unstyled-wrapper]=\"_config.unstyled\">\n <ng-template cdkPortalOutlet></ng-template>\n</div>\n", styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;height:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.dr-drawer-container__wrapper.unstyled-wrapper{flex:unset;overflow:unset}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;user-select:none;-webkit-user-select:none;flex-shrink:0}.handle--resize{cursor:ns-resize}.handle--dismiss{cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px;transition:background-color .2s ease}.handle:hover:after{background-color:#b6b8bf}.handle:active:after{background-color:#9b9ea8}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"] }]
170
165
  }], function () { return [{ type: i0.ElementRef }, { type: i1.FocusTrapFactory }, { type: Document, decorators: [{
171
166
  type: Optional
172
167
  }, {
@@ -178,5 +173,7 @@ export class DrawerContainer extends CdkDialogContainer {
178
173
  }], _handleRef: [{
179
174
  type: ViewChild,
180
175
  args: ['handleRef']
176
+ }], afterResized: [{
177
+ type: Output
181
178
  }] }); })();
182
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-container.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.ts","../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusTrapFactory, InteractivityChecker } from '@angular/cdk/a11y';\nimport { CdkDialogContainer, DialogModule } from '@angular/cdk/dialog';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortalOutlet, PortalModule } from '@angular/cdk/portal';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Inject,\n    NgZone,\n    OnDestroy,\n    Optional,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { MatCommonModule } from '@angular/material/core';\nimport { distinctUntilChanged, finalize, fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';\nimport { drDrawerAnimations } from './drawer-animation';\nimport { DrawerConfig } from './drawer-config';\nimport { BottomPositionStrategy, DrawerPositionStrategy } from './drawer-position-strategy';\n\n/**\n * Internal component that wraps user-provided drawer content.\n * @docs-private\n */\n@Component({\n    selector: 'dr-drawer-container',\n    templateUrl: 'drawer-container.component.html',\n    styleUrls: ['drawer-container.component.scss'],\n    // In Ivy embedded views will be change detected from their declaration place, rather than where\n    // they were stamped out. This means that we can't have the drawer container be OnPush,\n    // because it might cause the sheets that were opened from a template not to be out of date.\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n    animations: [drDrawerAnimations.drawerState],\n    host: {\n        '[class.dr-drawer-container]': '!_config.unstyled',\n        '[class]': '_drawerPosition',\n        tabindex: '-1',\n        '[id]': '_config.id',\n        '[attr.role]': '_config.role',\n        '[attr.aria-modal]': '_config.isModal',\n        '[attr.aria-label]': '_config.ariaLabel',\n        '[@state]': '_animationState',\n        '(@state.start)': '_onAnimationStart($event)',\n        '(@state.done)': '_onAnimationDone($event)',\n    },\n    standalone: true,\n    imports: [PortalModule, DialogModule, MatCommonModule, CommonModule],\n})\nexport class DrawerContainer extends CdkDialogContainer<DrawerConfig> implements OnDestroy, AfterViewInit {\n    /** The portal outlet inside of this container into which the content will be loaded. */\n    @ViewChild(CdkPortalOutlet, { static: true })\n    _portalOutlet!: CdkPortalOutlet;\n\n    @ViewChild('handleRef')\n    _handleRef?: ElementRef<HTMLDivElement>;\n\n    /** The state of the drawer animations. */\n    _animationState: 'void' | 'visible' | 'hidden' = 'void';\n\n    /** Emits whenever the state of the animation changes. */\n    readonly _animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    /** Whether the component has been destroyed. */\n    private _destroyed = false;\n\n    get _drawerPosition() {\n        return this._config.unstyled ? '' : `dr-drawer-${this._config.position}`;\n    }\n\n    private readonly _changeDetectorRef = inject(ChangeDetectorRef);\n\n    private readonly destroy$ = new Subject<void>();\n\n    positionStrategy!: DrawerPositionStrategy;\n\n    constructor(\n        elementRef: ElementRef<HTMLElement>,\n        focusTrapFactory: FocusTrapFactory,\n        @Optional() @Inject(DOCUMENT) document: Document,\n        config: DrawerConfig,\n        checker: InteractivityChecker,\n        ngZone: NgZone,\n        private overlayRef: OverlayRef,\n        focusMonitor?: FocusMonitor,\n    ) {\n        super(elementRef, focusTrapFactory, document, config, checker, ngZone, overlayRef, focusMonitor);\n    }\n\n    protected override _contentAttached(): void {\n        // Delegate to the original dialog-container initialization (i.e. saving the\n        // previous element, setting up the focus trap and moving focus to the container).\n        super._contentAttached();\n\n        this.enter();\n    }\n\n    /** Begin animation of bottom sheet entrance into view. */\n    enter(): void {\n        if (!this._destroyed) {\n            this._animationState = 'visible';\n            this._changeDetectorRef.markForCheck();\n            this._changeDetectorRef.detectChanges();\n        }\n    }\n\n    /** Begin animation of the bottom sheet exiting from view. */\n    exit(): void {\n        (this._elementRef.nativeElement as HTMLElement).style.transition = undefined;\n        if (!this._destroyed) {\n            this._animationState = 'hidden';\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.positionStrategy = this.resolvePositionStrategy();\n        if (this.positionStrategy && !this._config.unstyled && this._handleRef) {\n            this.setupDragListener();\n        }\n    }\n\n    private resolvePositionStrategy(): DrawerPositionStrategy {\n        switch (this._config.position) {\n            case 'bottom':\n                return new BottomPositionStrategy();\n        }\n    }\n\n    private setupDragListener(): void {\n        const mousedown$ = fromEvent(this._handleRef.nativeElement, 'mousedown');\n        const mousemove$ = fromEvent(document, 'mousemove');\n        const mouseup$ = fromEvent(document, 'mouseup');\n\n        let lastPosition = 0;\n        let initPosition = 0;\n        let currentPosition = 0;\n        const container = this._elementRef.nativeElement as HTMLElement;\n\n        setTimeout(() => {\n            lastPosition = this.getContainerPosition(container);\n            initPosition = lastPosition;\n        });\n\n        mousedown$\n            .pipe(\n                switchMap(() =>\n                    mousemove$.pipe(\n                        finalize(() => {\n                            const container = this._elementRef.nativeElement as HTMLElement;\n                            if (this.positionStrategy.shouldClose(currentPosition, initPosition, lastPosition)) {\n                                this.overlayRef.dispose();\n                                return;\n                            }\n                            container.style.transition = 'transform 0.5s cubic-bezier(0.32, 0.72, 0, 1)';\n                            container.style.transform = `translate3d(0px, 0px, 0px)`;\n                        }),\n                        takeUntil(mouseup$),\n                    ),\n                ),\n                map((event: MouseEvent) => this.positionStrategy.extractMousePosition(event)),\n                distinctUntilChanged(),\n                tap((position) => {\n                    let containerPosition = this.getContainerPosition(container);\n\n                    containerPosition = Math.min(containerPosition, lastPosition);\n                    lastPosition = Math.min(containerPosition, lastPosition);\n                    currentPosition = position;\n\n                    container.style.transition = 'none';\n                    container.style.transform = this.positionStrategy.calculateTransform(position, containerPosition);\n                }),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    private getContainerPosition(container: HTMLElement): number {\n        return this._config.position === 'bottom' || this._config.position === 'top'\n            ? container.getBoundingClientRect().top\n            : container.getBoundingClientRect().left;\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n\n        this.destroy$.next();\n        this.destroy$.complete();\n        this._destroyed = true;\n    }\n\n    _onAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'visible') {\n            this._trapFocus();\n        }\n\n        this._animationStateChanged.emit(event);\n    }\n\n    _onAnimationStart(event: AnimationEvent) {\n        this._animationStateChanged.emit(event);\n    }\n\n    protected override _captureInitialFocus(): void {}\n}\n","<div *ngIf=\"_config.position === 'bottom' && !_config.unstyled\" #handleRef class=\"handle\"></div>\n<div class=\"dr-drawer-container__wrapper\" [class.unstyled-wrapper]=\"_config.unstyled\">\n    <ng-template cdkPortalOutlet></ng-template>\n</div>\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-container.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.ts","../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusTrapFactory, InteractivityChecker } from '@angular/cdk/a11y';\nimport { CdkDialogContainer, DialogModule } from '@angular/cdk/dialog';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortalOutlet, PortalModule } from '@angular/cdk/portal';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Inject,\n    NgZone,\n    OnDestroy,\n    Optional,\n    Output,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { MatCommonModule } from '@angular/material/core';\nimport { distinctUntilChanged, finalize, fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';\nimport { drDrawerAnimations } from './drawer-animation';\nimport { DrawerConfig } from './drawer-config';\nimport { BottomDismissPositionStrategy, BottomResizePositionStrategy, DrawerPositionStrategy } from './drawer-position-strategy';\n\n/**\n * Internal component that wraps user-provided drawer content.\n * @docs-private\n */\n@Component({\n    selector: 'dr-drawer-container',\n    templateUrl: 'drawer-container.component.html',\n    styleUrls: ['drawer-container.component.scss'],\n    // In Ivy embedded views will be change detected from their declaration place, rather than where\n    // they were stamped out. This means that we can't have the drawer container be OnPush,\n    // because it might cause the sheets that were opened from a template not to be out of date.\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n    animations: [drDrawerAnimations.drawerState],\n    host: {\n        '[class.dr-drawer-container]': '!_config.unstyled',\n        '[class]': '_drawerPosition',\n        tabindex: '-1',\n        '[id]': '_config.id',\n        '[attr.role]': '_config.role',\n        '[attr.aria-modal]': '_config.isModal',\n        '[attr.aria-label]': '_config.ariaLabel',\n        '[@state]': '_animationState',\n        '(@state.start)': '_onAnimationStart($event)',\n        '(@state.done)': '_onAnimationDone($event)',\n    },\n    standalone: true,\n    imports: [PortalModule, DialogModule, MatCommonModule, CommonModule],\n})\nexport class DrawerContainer extends CdkDialogContainer<DrawerConfig> implements OnDestroy, AfterViewInit {\n    /** The portal outlet inside of this container into which the content will be loaded. */\n    @ViewChild(CdkPortalOutlet, { static: true })\n    _portalOutlet!: CdkPortalOutlet;\n\n    @ViewChild('handleRef')\n    _handleRef?: ElementRef<HTMLDivElement>;\n\n    /** Emits final height (px) after resize. Available only in resize mode. */\n    @Output() afterResized = new EventEmitter<number>();\n\n    /** The state of the drawer animations. */\n    _animationState: 'void' | 'visible' | 'hidden' = 'void';\n\n    /** Emits whenever the state of the animation changes. */\n    readonly _animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    /** Whether the component has been destroyed. */\n    private _destroyed = false;\n\n    get _drawerPosition() {\n        return this._config.unstyled ? '' : `dr-drawer-${this._config.position}`;\n    }\n\n    private readonly _changeDetectorRef = inject(ChangeDetectorRef);\n\n    private readonly destroy$ = new Subject<void>();\n\n    positionStrategy?: DrawerPositionStrategy;\n\n    constructor(\n        elementRef: ElementRef<HTMLElement>,\n        focusTrapFactory: FocusTrapFactory,\n        @Optional() @Inject(DOCUMENT) document: Document,\n        config: DrawerConfig,\n        checker: InteractivityChecker,\n        ngZone: NgZone,\n        private overlayRef: OverlayRef,\n        focusMonitor?: FocusMonitor,\n    ) {\n        super(elementRef, focusTrapFactory, document, config, checker, ngZone, overlayRef, focusMonitor);\n    }\n\n    protected override _contentAttached(): void {\n        // Delegate to the original dialog-container initialization (i.e. saving the\n        // previous element, setting up the focus trap and moving focus to the container).\n        super._contentAttached();\n\n        this.enter();\n    }\n\n    /** Begin animation of bottom sheet entrance into view. */\n    enter(): void {\n        if (!this._destroyed) {\n            this._animationState = 'visible';\n            this._changeDetectorRef.markForCheck();\n            this._changeDetectorRef.detectChanges();\n        }\n    }\n\n    /** Begin animation of the bottom sheet exiting from view. */\n    exit(): void {\n        (this._elementRef.nativeElement as HTMLElement).style.transition = undefined;\n        if (!this._destroyed) {\n            this._animationState = 'hidden';\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.positionStrategy = this.resolvePositionStrategy();\n        if (this.positionStrategy && !this._config.unstyled && this._handleRef) {\n            this.setupDragListener();\n        }\n    }\n\n    private resolvePositionStrategy(): DrawerPositionStrategy | undefined {\n        switch (this._config.position) {\n            case 'bottom':\n                return this._config.dragMode === 'resize'\n                    ? new BottomResizePositionStrategy(this._config)\n                    : new BottomDismissPositionStrategy();\n            default:\n                return undefined;\n        }\n    }\n\n    private setupDragListener(): void {\n        const strategy = this.positionStrategy;\n        if (!strategy) return;\n\n        const mousedown$ = fromEvent(this._handleRef!.nativeElement, 'mousedown');\n        const mousemove$ = fromEvent(document, 'mousemove');\n        const mouseup$ = fromEvent(document, 'mouseup');\n\n        const container = this._elementRef.nativeElement as HTMLElement;\n        const overlayElement = this.overlayRef.overlayElement;\n\n        mousedown$\n            .pipe(\n                tap(() => strategy.onDragStart(container, overlayElement)),\n                switchMap(() =>\n                    mousemove$.pipe(\n                        takeUntil(mouseup$),\n                        finalize(() => {\n                            const result = strategy.onDragEnd(container, overlayElement);\n\n                            if (result.shouldClose) {\n                                this.overlayRef.dispose();\n                                return;\n                            }\n\n                            if (result.height !== undefined) {\n                                this.afterResized.emit(result.height);\n                            }\n                        }),\n                    ),\n                ),\n                map((event: MouseEvent) => strategy.extractMousePosition(event)),\n                distinctUntilChanged(),\n                tap((position) => strategy.onDragMove(position, container, overlayElement)),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n\n        this.destroy$.next();\n        this.destroy$.complete();\n        this._destroyed = true;\n    }\n\n    _onAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'visible') {\n            this._trapFocus();\n        }\n\n        this._animationStateChanged.emit(event);\n    }\n\n    _onAnimationStart(event: AnimationEvent) {\n        this._animationStateChanged.emit(event);\n    }\n\n    protected override _captureInitialFocus(): void {}\n}\n","<div\n    *ngIf=\"_config.position === 'bottom' && !_config.unstyled\"\n    #handleRef\n    class=\"handle\"\n    [class.handle--resize]=\"_config.dragMode === 'resize'\"\n    [class.handle--dismiss]=\"_config.dragMode === 'dismiss'\"></div>\n<div class=\"dr-drawer-container__wrapper\" [class.unstyled-wrapper]=\"_config.unstyled\">\n    <ng-template cdkPortalOutlet></ng-template>\n</div>\n"]}
@@ -1,14 +1,100 @@
1
- export class BottomPositionStrategy {
1
+ export class BottomDismissPositionStrategy {
2
+ constructor() {
3
+ this.startMouseY = null;
4
+ this.deltaY = 0;
5
+ }
2
6
  extractMousePosition(event) {
3
7
  return event.clientY;
4
8
  }
5
- calculateTransform(currentPosition, containerPosition) {
6
- return currentPosition > containerPosition
7
- ? `translate3d(0px, ${currentPosition - containerPosition}px, 0px)`
8
- : `translate3d(0px, 0px, 0px)`;
9
+ onDragStart(container) {
10
+ this.startMouseY = null;
11
+ this.deltaY = 0;
12
+ }
13
+ onDragMove(mouseY, container) {
14
+ if (this.startMouseY === null) {
15
+ this.startMouseY = mouseY;
16
+ return;
17
+ }
18
+ this.deltaY = mouseY - this.startMouseY;
19
+ if (this.deltaY < 0) {
20
+ this.deltaY = 0;
21
+ }
22
+ container.style.transition = 'none';
23
+ container.style.transform = `translate3d(0px, ${this.deltaY}px, 0px)`;
24
+ }
25
+ onDragEnd(container) {
26
+ const containerHeight = container.getBoundingClientRect().height;
27
+ const shouldClose = this.deltaY > containerHeight / 2;
28
+ if (!shouldClose) {
29
+ container.style.transition = 'transform 0.5s cubic-bezier(0.32, 0.72, 0, 1)';
30
+ container.style.transform = `translate3d(0px, 0px, 0px)`;
31
+ }
32
+ return { shouldClose };
33
+ }
34
+ }
35
+ export class BottomResizePositionStrategy {
36
+ constructor(config) {
37
+ this.config = config;
38
+ this.startMouseY = null;
39
+ this.startHeightPx = 0;
40
+ this.currentHeightPx = 0;
41
+ const viewportH = window.innerHeight;
42
+ this.minHeightPx = this.toPx(config.minHeight ?? '10vh', viewportH);
43
+ this.maxHeightPx = this.toPx(config.maxHeight ?? '90vh', viewportH);
44
+ this.minHeightPx = Math.max(0, this.minHeightPx);
45
+ this.maxHeightPx = Math.max(this.minHeightPx, this.maxHeightPx);
46
+ }
47
+ extractMousePosition(event) {
48
+ return event.clientY;
49
+ }
50
+ onDragStart(container, overlayElement) {
51
+ this.startMouseY = null;
52
+ const rect = overlayElement.getBoundingClientRect();
53
+ this.startHeightPx = rect.height;
54
+ this.currentHeightPx = this.startHeightPx;
55
+ overlayElement.style.transition = 'none';
56
+ overlayElement.style.height = `${this.startHeightPx}px`;
57
+ overlayElement.style.maxHeight = 'none';
58
+ container.style.height = '100%';
59
+ }
60
+ onDragMove(mouseY, container, overlayElement) {
61
+ if (this.startMouseY === null) {
62
+ this.startMouseY = mouseY;
63
+ return;
64
+ }
65
+ const delta = this.startMouseY - mouseY;
66
+ let nextHeight = this.startHeightPx + delta;
67
+ nextHeight = Math.max(this.minHeightPx, Math.min(this.maxHeightPx, nextHeight));
68
+ this.currentHeightPx = nextHeight;
69
+ overlayElement.style.height = `${nextHeight}px`;
70
+ }
71
+ onDragEnd(container, overlayElement) {
72
+ let height = this.currentHeightPx || overlayElement.getBoundingClientRect().height;
73
+ height = Math.max(this.minHeightPx, Math.min(this.maxHeightPx, height));
74
+ overlayElement.style.transition = 'height 200ms cubic-bezier(0.32, 0.72, 0, 1)';
75
+ overlayElement.style.height = `${height}px`;
76
+ this.startMouseY = NaN;
77
+ this.currentHeightPx = height;
78
+ return { shouldClose: false, height };
9
79
  }
10
- shouldClose(currentPosition, initPosition, lastPosition) {
11
- return Math.abs(currentPosition - initPosition) <= currentPosition - lastPosition;
80
+ toPx(value, viewportH) {
81
+ if (typeof value === 'number') {
82
+ return value;
83
+ }
84
+ const raw = String(value).trim();
85
+ if (!raw) {
86
+ return 0;
87
+ }
88
+ if (raw.endsWith('vh')) {
89
+ const n = parseFloat(raw);
90
+ return Number.isFinite(n) ? (n / 100) * viewportH : 0;
91
+ }
92
+ if (raw.endsWith('px')) {
93
+ const n = parseFloat(raw);
94
+ return Number.isFinite(n) ? n : 0;
95
+ }
96
+ const asNumber = parseFloat(raw);
97
+ return Number.isFinite(asNumber) ? asNumber : 0;
12
98
  }
13
99
  }
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLXBvc2l0aW9uLXN0cmF0ZWd5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHJhd2VyL2RyYXdlci1wb3NpdGlvbi1zdHJhdGVneS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNQSxNQUFNLE9BQU8sc0JBQXNCO0lBQy9CLG9CQUFvQixDQUFDLEtBQWlCO1FBQ2xDLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQztJQUN6QixDQUFDO0lBRUQsa0JBQWtCLENBQUMsZUFBdUIsRUFBRSxpQkFBeUI7UUFDakUsT0FBTyxlQUFlLEdBQUcsaUJBQWlCO1lBQ3RDLENBQUMsQ0FBQyxvQkFBb0IsZUFBZSxHQUFHLGlCQUFpQixVQUFVO1lBQ25FLENBQUMsQ0FBQyw0QkFBNEIsQ0FBQztJQUN2QyxDQUFDO0lBRUQsV0FBVyxDQUFDLGVBQXVCLEVBQUUsWUFBb0IsRUFBRSxZQUFvQjtRQUMzRSxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsZUFBZSxHQUFHLFlBQVksQ0FBQyxJQUFJLGVBQWUsR0FBRyxZQUFZLENBQUM7SUFDdEYsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBEcmF3ZXJQb3NpdGlvblN0cmF0ZWd5IHtcbiAgICBleHRyYWN0TW91c2VQb3NpdGlvbihldmVudDogTW91c2VFdmVudCk6IG51bWJlcjtcbiAgICBjYWxjdWxhdGVUcmFuc2Zvcm0oY3VycmVudFBvc2l0aW9uOiBudW1iZXIsIGNvbnRhaW5lclBvc2l0aW9uOiBudW1iZXIpOiBzdHJpbmc7XG4gICAgc2hvdWxkQ2xvc2UoY3VycmVudFBvc2l0aW9uOiBudW1iZXIsIGluaXRQb3NpdGlvbjogbnVtYmVyLCBsYXN0UG9zaXRpb246IG51bWJlcik6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjbGFzcyBCb3R0b21Qb3NpdGlvblN0cmF0ZWd5IGltcGxlbWVudHMgRHJhd2VyUG9zaXRpb25TdHJhdGVneSB7XG4gICAgZXh0cmFjdE1vdXNlUG9zaXRpb24oZXZlbnQ6IE1vdXNlRXZlbnQpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gZXZlbnQuY2xpZW50WTtcbiAgICB9XG5cbiAgICBjYWxjdWxhdGVUcmFuc2Zvcm0oY3VycmVudFBvc2l0aW9uOiBudW1iZXIsIGNvbnRhaW5lclBvc2l0aW9uOiBudW1iZXIpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gY3VycmVudFBvc2l0aW9uID4gY29udGFpbmVyUG9zaXRpb25cbiAgICAgICAgICAgID8gYHRyYW5zbGF0ZTNkKDBweCwgJHtjdXJyZW50UG9zaXRpb24gLSBjb250YWluZXJQb3NpdGlvbn1weCwgMHB4KWBcbiAgICAgICAgICAgIDogYHRyYW5zbGF0ZTNkKDBweCwgMHB4LCAwcHgpYDtcbiAgICB9XG5cbiAgICBzaG91bGRDbG9zZShjdXJyZW50UG9zaXRpb246IG51bWJlciwgaW5pdFBvc2l0aW9uOiBudW1iZXIsIGxhc3RQb3NpdGlvbjogbnVtYmVyKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiBNYXRoLmFicyhjdXJyZW50UG9zaXRpb24gLSBpbml0UG9zaXRpb24pIDw9IGN1cnJlbnRQb3NpdGlvbiAtIGxhc3RQb3NpdGlvbjtcbiAgICB9XG59XG4iXX0=
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-position-strategy.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-position-strategy.ts"],"names":[],"mappings":"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","sourcesContent":["import { DrawerConfig } from './drawer-config';\n\nexport interface DrawerPositionStrategy {\n    extractMousePosition(event: MouseEvent): number;\n    onDragStart(container: HTMLElement, overlayElement: HTMLElement): void;\n    onDragMove(currentPosition: number, container: HTMLElement, overlayElement: HTMLElement): void;\n    onDragEnd(container: HTMLElement, overlayElement: HTMLElement): { shouldClose: boolean; height?: number };\n}\n\nexport class BottomDismissPositionStrategy implements DrawerPositionStrategy {\n    private startMouseY: number | null = null;\n    private deltaY: number = 0;\n\n    extractMousePosition(event: MouseEvent): number {\n        return event.clientY;\n    }\n\n    onDragStart(container: HTMLElement): void {\n        this.startMouseY = null;\n        this.deltaY = 0;\n    }\n\n    onDragMove(mouseY: number, container: HTMLElement): void {\n        if (this.startMouseY === null) {\n            this.startMouseY = mouseY;\n            return;\n        }\n\n        this.deltaY = mouseY - this.startMouseY;\n\n        if (this.deltaY < 0) {\n            this.deltaY = 0;\n        }\n\n        container.style.transition = 'none';\n        container.style.transform = `translate3d(0px, ${this.deltaY}px, 0px)`;\n    }\n\n    onDragEnd(container: HTMLElement): { shouldClose: boolean } {\n        const containerHeight = container.getBoundingClientRect().height;\n        const shouldClose = this.deltaY > containerHeight / 2;\n\n        if (!shouldClose) {\n            container.style.transition = 'transform 0.5s cubic-bezier(0.32, 0.72, 0, 1)';\n            container.style.transform = `translate3d(0px, 0px, 0px)`;\n        }\n\n        return { shouldClose };\n    }\n}\n\nexport class BottomResizePositionStrategy implements DrawerPositionStrategy {\n    private startMouseY: number | null = null;\n    private startHeightPx: number = 0;\n    private currentHeightPx: number = 0;\n\n    private minHeightPx: number;\n    private maxHeightPx: number;\n\n    constructor(private readonly config: DrawerConfig) {\n        const viewportH = window.innerHeight;\n\n        this.minHeightPx = this.toPx(config.minHeight ?? '10vh', viewportH);\n        this.maxHeightPx = this.toPx(config.maxHeight ?? '90vh', viewportH);\n\n        this.minHeightPx = Math.max(0, this.minHeightPx);\n        this.maxHeightPx = Math.max(this.minHeightPx, this.maxHeightPx);\n    }\n\n    extractMousePosition(event: MouseEvent): number {\n        return event.clientY;\n    }\n\n    onDragStart(container: HTMLElement, overlayElement: HTMLElement): void {\n        this.startMouseY = null;\n\n        const rect = overlayElement.getBoundingClientRect();\n        this.startHeightPx = rect.height;\n        this.currentHeightPx = this.startHeightPx;\n\n        overlayElement.style.transition = 'none';\n        overlayElement.style.height = `${this.startHeightPx}px`;\n        overlayElement.style.maxHeight = 'none';\n\n        container.style.height = '100%';\n    }\n\n    onDragMove(mouseY: number, container: HTMLElement, overlayElement: HTMLElement): void {\n        if (this.startMouseY === null) {\n            this.startMouseY = mouseY;\n            return;\n        }\n\n        const delta = this.startMouseY - mouseY;\n        let nextHeight = this.startHeightPx + delta;\n\n        nextHeight = Math.max(this.minHeightPx, Math.min(this.maxHeightPx, nextHeight));\n        this.currentHeightPx = nextHeight;\n\n        overlayElement.style.height = `${nextHeight}px`;\n    }\n\n    onDragEnd(container: HTMLElement, overlayElement: HTMLElement): { shouldClose: boolean; height: number } {\n        let height = this.currentHeightPx || overlayElement.getBoundingClientRect().height;\n        height = Math.max(this.minHeightPx, Math.min(this.maxHeightPx, height));\n\n        overlayElement.style.transition = 'height 200ms cubic-bezier(0.32, 0.72, 0, 1)';\n        overlayElement.style.height = `${height}px`;\n\n        this.startMouseY = NaN;\n        this.currentHeightPx = height;\n\n        return { shouldClose: false, height };\n    }\n\n    private toPx(value: number | string, viewportH: number): number {\n        if (typeof value === 'number') {\n            return value;\n        }\n\n        const raw = String(value).trim();\n\n        if (!raw) {\n            return 0;\n        }\n\n        if (raw.endsWith('vh')) {\n            const n = parseFloat(raw);\n            return Number.isFinite(n) ? (n / 100) * viewportH : 0;\n        }\n\n        if (raw.endsWith('px')) {\n            const n = parseFloat(raw);\n            return Number.isFinite(n) ? n : 0;\n        }\n\n        const asNumber = parseFloat(raw);\n        return Number.isFinite(asNumber) ? asNumber : 0;\n    }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';
2
- import { merge, Subject } from 'rxjs';
2
+ import { EMPTY, merge, Subject } from 'rxjs';
3
3
  import { filter, take } from 'rxjs/operators';
4
4
  /**
5
5
  * Reference to a drawer dispatched from the drawer service.
@@ -54,6 +54,7 @@ export class DrawerRef {
54
54
  this.dismiss();
55
55
  }
56
56
  });
57
+ this._afterResized$ = containerInstance?.afterResized?.asObservable() ?? EMPTY;
57
58
  }
58
59
  /**
59
60
  * Dismisses the drawer.
@@ -94,6 +95,10 @@ export class DrawerRef {
94
95
  afterOpened() {
95
96
  return this._afterOpened;
96
97
  }
98
+ /** Gets an observable that emits the final height (px) after resize. Available only in resize mode. */
99
+ afterResized() {
100
+ return this._afterResized$;
101
+ }
97
102
  /**
98
103
  * Gets an observable that emits when the overlay's backdrop has been clicked.
99
104
  */
@@ -107,4 +112,4 @@ export class DrawerRef {
107
112
  return this._ref.keydownEvents;
108
113
  }
109
114
  }
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-ref.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-ref.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAK9C;;GAEG;AACH,MAAM,OAAO,SAAS;IAClB,qEAAqE;IACrE,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,IAAI,CAAC,iBAAkB,CAAC;IACxC,CAAC;IAED;;;OAGG;IACH,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;IAClC,CAAC;IAcD,+CAA+C;IAC/C,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC;IAC/C,CAAC;IAcD,YACY,IAAqB,EAC7B,MAAoB,EACpB,iBAAkC;QAF1B,SAAI,GAAJ,IAAI,CAAiB;QAbjC,yEAAyE;QACxD,oBAAe,GAAG,IAAI,OAAO,EAAiB,CAAC;QAEhE,8EAA8E;QAC7D,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAahD,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC;QACxC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAElB,wCAAwC;QACxC,iBAAiB,CAAC,sBAAsB;aACnC,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,MAAM,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS,CAAC,EAC5E,IAAI,CAAC,CAAC,CAAC,CACV;aACA,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QACjC,CAAC,CAAC,CAAC;QAEP,qDAAqD;QACrD,iBAAiB,CAAC,sBAAsB;aACnC,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,MAAM,IAAI,KAAK,CAAC,OAAO,KAAK,QAAQ,CAAC,EAC3E,IAAI,CAAC,CAAC,CAAC,CACV;aACA,SAAS,CAAC,GAAG,EAAE;YACZ,YAAY,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACzC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACzC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACxC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACpH,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,KAAK,CAAC,IAAI,KAAK,SAAS,IAAI,CAAC,cAAc,CAAC,KAAsB,CAAC,CAAC,EAAE;gBAC7F,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,OAAO,EAAE,CAAC;aAClB;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACH,OAAO,CAAC,MAAU;QACd,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;QAEhC,IAAI,IAAI,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE;YACxD,qDAAqD;YACrD,IAAI,CAAC,iBAAiB,CAAC,sBAAsB;iBACxC,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,OAAO,CAAC,EAC9C,IAAI,CAAC,CAAC,CAAC,CACV;iBACA,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBACjB,2FAA2F;gBAC3F,yFAAyF;gBACzF,4FAA4F;gBAC5F,2FAA2F;gBAC3F,iFAAiF;gBACjF,IAAI,CAAC,qBAAqB,GAAG,UAAU,CAAC,GAAG,EAAE;oBACzC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAClC,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,GAAG,CAAC,CAAC;gBAE1B,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;YAC1C,CAAC,CAAC,CAAC;YAEP,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;YAC9B,IAAI,CAAC,iBAAiB,GAAG,IAAK,CAAC;SAClC;IACL,CAAC;IAED,wEAAwE;IACxE,cAAc;QACV,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAED,+EAA+E;IAC/E,WAAW;QACP,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;IAC5B,CAAC;IAED,mFAAmF;IACnF,WAAW;QACP,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,aAAa;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;IACnC,CAAC;IAED;;OAEG;IACH,aAAa;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;IACnC,CAAC;CACJ","sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';\nimport { merge, Observable, Subject } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DrawerConfig } from './drawer-config';\nimport { DrawerContainer } from './drawer-container.component';\nimport { ComponentRef } from '@angular/core';\n\n/**\n * Reference to a drawer dispatched from the drawer service.\n */\nexport class DrawerRef<T = any, R = any> {\n    /** Instance of the component making up the content of the drawer. */\n    get instance(): T {\n        return this._ref.componentInstance!;\n    }\n\n    /**\n     * `ComponentRef` of the component opened into the drawer. Will be\n     * null when the drawer is opened using a `TemplateRef`.\n     */\n    get componentRef(): ComponentRef<T> | null {\n        return this._ref.componentRef;\n    }\n\n    /**\n     * Instance of the component into which the drawer content is projected.\n     * @docs-private\n     */\n    containerInstance: DrawerContainer;\n\n    /** Whether the user is allowed to close the drawer. */\n    disableClose: boolean | undefined;\n\n    /** Unique ID for the drawer. */\n    id: string;\n\n    /** Gets the overlay element for the drawer. */\n    get overlayElement(): HTMLElement {\n        return this._ref.overlayRef.overlayElement;\n    }\n\n    /** Subject for notifying the user that the drawer has been dismissed. */\n    private readonly _afterDismissed = new Subject<R | undefined>();\n\n    /** Subject for notifying the user that the drawer has opened and appeared. */\n    private readonly _afterOpened = new Subject<void>();\n\n    /** Result to be passed down to the `afterDismissed` stream. */\n    private _result: R | undefined;\n\n    /** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */\n    private _closeFallbackTimeout: any;\n\n    constructor(\n        private _ref: DialogRef<R, T>,\n        config: DrawerConfig,\n        containerInstance: DrawerContainer,\n    ) {\n        this.containerInstance = containerInstance;\n        this.disableClose = config.disableClose;\n        this.id = _ref.id;\n\n        // Emit when opening animation completes\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'visible'),\n                take(1),\n            )\n            .subscribe(() => {\n                this._afterOpened.next();\n                this._afterOpened.complete();\n            });\n\n        // Dispose overlay when closing animation is complete\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'hidden'),\n                take(1),\n            )\n            .subscribe(() => {\n                clearTimeout(this._closeFallbackTimeout);\n                this._ref.close(this._result);\n            });\n\n        _ref.overlayRef.detachments().subscribe(() => {\n            this._ref.close(this._result);\n            this._afterDismissed.next(this._result);\n            this._afterDismissed.complete();\n        });\n\n        merge(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {\n            if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event as KeyboardEvent))) {\n                event.preventDefault();\n                this.dismiss();\n            }\n        });\n    }\n\n    /**\n     * Dismisses the drawer.\n     * @param result Data to be passed back to the drawer opener.\n     */\n    dismiss(result?: R): void {\n        this._afterDismissed.next(result);\n        this._afterDismissed.complete();\n\n        if (this.containerInstance && !this._afterDismissed.closed) {\n            // Transition the backdrop in parallel to the drawer.\n            this.containerInstance._animationStateChanged\n                .pipe(\n                    filter((event) => event.phaseName === 'start'),\n                    take(1),\n                )\n                .subscribe((event) => {\n                    // The logic that disposes of the overlay depends on the exit animation completing, however\n                    // it isn't guaranteed if the parent view is destroyed while it's running. Add a fallback\n                    // timeout which will clean everything up if the animation hasn't fired within the specified\n                    // amount of time plus 100ms. We don't need to run this outside the NgZone, because for the\n                    // vast majority of cases the timeout will have been cleared before it has fired.\n                    this._closeFallbackTimeout = setTimeout(() => {\n                        this._ref.close(this._result);\n                    }, event.totalTime + 100);\n\n                    this._ref.overlayRef.detachBackdrop();\n                });\n\n            this._result = result;\n            this.containerInstance.exit();\n            this.containerInstance = null!;\n        }\n    }\n\n    /** Gets an observable that is notified when the drawer is dismissed. */\n    afterDismissed(): Observable<R | undefined> {\n        return this._afterDismissed;\n    }\n\n    /** Gets an observable that is notified when the drawer is finished closing. */\n    afterClosed(): Observable<R | undefined> {\n        return this._ref.closed;\n    }\n\n    /** Gets an observable that is notified when the drawer has opened and appeared. */\n    afterOpened(): Observable<void> {\n        return this._afterOpened;\n    }\n\n    /**\n     * Gets an observable that emits when the overlay's backdrop has been clicked.\n     */\n    backdropClick(): Observable<MouseEvent> {\n        return this._ref.backdropClick;\n    }\n\n    /**\n     * Gets an observable that emits when keydown events are targeted on the overlay.\n     */\n    keydownEvents(): Observable<KeyboardEvent> {\n        return this._ref.keydownEvents;\n    }\n}\n"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-ref.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';\nimport { EMPTY, merge, Observable, Subject } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DrawerConfig } from './drawer-config';\nimport { DrawerContainer } from './drawer-container.component';\nimport { ComponentRef } from '@angular/core';\n\n/**\n * Reference to a drawer dispatched from the drawer service.\n */\nexport class DrawerRef<T = any, R = any> {\n    /** Instance of the component making up the content of the drawer. */\n    get instance(): T {\n        return this._ref.componentInstance!;\n    }\n\n    /**\n     * `ComponentRef` of the component opened into the drawer. Will be\n     * null when the drawer is opened using a `TemplateRef`.\n     */\n    get componentRef(): ComponentRef<T> | null {\n        return this._ref.componentRef;\n    }\n\n    /**\n     * Instance of the component into which the drawer content is projected.\n     * @docs-private\n     */\n    containerInstance: DrawerContainer;\n\n    /** Whether the user is allowed to close the drawer. */\n    disableClose: boolean | undefined;\n\n    /** Unique ID for the drawer. */\n    id: string;\n\n    /** Gets the overlay element for the drawer. */\n    get overlayElement(): HTMLElement {\n        return this._ref.overlayRef.overlayElement;\n    }\n\n    /** Subject for notifying the user that the drawer has been dismissed. */\n    private readonly _afterDismissed = new Subject<R | undefined>();\n\n    /** Subject for notifying the user that the drawer has opened and appeared. */\n    private readonly _afterOpened = new Subject<void>();\n\n    /** Result to be passed down to the `afterDismissed` stream. */\n    private _result: R | undefined;\n\n    /** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */\n    private _closeFallbackTimeout: any;\n\n    /** Subject for notifying the user that the drawer has been resized. */\n    private readonly _afterResized$: Observable<number>;\n\n    constructor(\n        private _ref: DialogRef<R, T>,\n        config: DrawerConfig,\n        containerInstance: DrawerContainer,\n    ) {\n        this.containerInstance = containerInstance;\n        this.disableClose = config.disableClose;\n        this.id = _ref.id;\n\n        // Emit when opening animation completes\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'visible'),\n                take(1),\n            )\n            .subscribe(() => {\n                this._afterOpened.next();\n                this._afterOpened.complete();\n            });\n\n        // Dispose overlay when closing animation is complete\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'hidden'),\n                take(1),\n            )\n            .subscribe(() => {\n                clearTimeout(this._closeFallbackTimeout);\n                this._ref.close(this._result);\n            });\n\n        _ref.overlayRef.detachments().subscribe(() => {\n            this._ref.close(this._result);\n            this._afterDismissed.next(this._result);\n            this._afterDismissed.complete();\n        });\n\n        merge(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {\n            if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event as KeyboardEvent))) {\n                event.preventDefault();\n                this.dismiss();\n            }\n        });\n\n        this._afterResized$ = containerInstance?.afterResized?.asObservable() ?? EMPTY;\n    }\n\n    /**\n     * Dismisses the drawer.\n     * @param result Data to be passed back to the drawer opener.\n     */\n    dismiss(result?: R): void {\n        this._afterDismissed.next(result);\n        this._afterDismissed.complete();\n\n        if (this.containerInstance && !this._afterDismissed.closed) {\n            // Transition the backdrop in parallel to the drawer.\n            this.containerInstance._animationStateChanged\n                .pipe(\n                    filter((event) => event.phaseName === 'start'),\n                    take(1),\n                )\n                .subscribe((event) => {\n                    // The logic that disposes of the overlay depends on the exit animation completing, however\n                    // it isn't guaranteed if the parent view is destroyed while it's running. Add a fallback\n                    // timeout which will clean everything up if the animation hasn't fired within the specified\n                    // amount of time plus 100ms. We don't need to run this outside the NgZone, because for the\n                    // vast majority of cases the timeout will have been cleared before it has fired.\n                    this._closeFallbackTimeout = setTimeout(() => {\n                        this._ref.close(this._result);\n                    }, event.totalTime + 100);\n\n                    this._ref.overlayRef.detachBackdrop();\n                });\n\n            this._result = result;\n            this.containerInstance.exit();\n            this.containerInstance = null!;\n        }\n    }\n\n    /** Gets an observable that is notified when the drawer is dismissed. */\n    afterDismissed(): Observable<R | undefined> {\n        return this._afterDismissed;\n    }\n\n    /** Gets an observable that is notified when the drawer is finished closing. */\n    afterClosed(): Observable<R | undefined> {\n        return this._ref.closed;\n    }\n\n    /** Gets an observable that is notified when the drawer has opened and appeared. */\n    afterOpened(): Observable<void> {\n        return this._afterOpened;\n    }\n\n    /** Gets an observable that emits the final height (px) after resize. Available only in resize mode. */\n    afterResized(): Observable<number> {\n        return this._afterResized$;\n    }\n\n    /**\n     * Gets an observable that emits when the overlay's backdrop has been clicked.\n     */\n    backdropClick(): Observable<MouseEvent> {\n        return this._ref.backdropClick;\n    }\n\n    /**\n     * Gets an observable that emits when keydown events are targeted on the overlay.\n     */\n    keydownEvents(): Observable<KeyboardEvent> {\n        return this._ref.keydownEvents;\n    }\n}\n"]}