@covalent/core 3.1.2-beta.6 → 3.1.2-beta.7
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/covalent-core-side-sheet.umd.js +1396 -0
- package/bundles/covalent-core-side-sheet.umd.js.map +1 -0
- package/bundles/covalent-core-side-sheet.umd.min.js +16 -0
- package/bundles/covalent-core-side-sheet.umd.min.js.map +1 -0
- package/dialogs/_dialog-theme.scss +1 -0
- package/esm2015/side-sheet/covalent-core-side-sheet.js +12 -0
- package/esm2015/side-sheet/index.js +7 -0
- package/esm2015/side-sheet/public-api.js +11 -0
- package/esm2015/side-sheet/side-sheet-container.js +388 -0
- package/esm2015/side-sheet/side-sheet-ref.js +47 -0
- package/esm2015/side-sheet/side-sheet.animation.js +20 -0
- package/esm2015/side-sheet/side-sheet.config.js +12 -0
- package/esm2015/side-sheet/side-sheet.content-directives.js +255 -0
- package/esm2015/side-sheet/side-sheet.js +312 -0
- package/esm2015/side-sheet/side-sheet.module.js +36 -0
- package/fesm2015/covalent-core-side-sheet.js +1070 -0
- package/fesm2015/covalent-core-side-sheet.js.map +1 -0
- package/package.json +1 -1
- package/side-sheet/README.md +66 -0
- package/side-sheet/covalent-core-side-sheet.d.ts +6 -0
- package/side-sheet/covalent-core-side-sheet.metadata.json +1 -0
- package/side-sheet/index.d.ts +1 -0
- package/side-sheet/package.json +11 -0
- package/side-sheet/public-api.d.ts +5 -0
- package/side-sheet/side-sheet-container.d.ts +92 -0
- package/side-sheet/side-sheet-ref.d.ts +9 -0
- package/side-sheet/side-sheet.animation.d.ts +4 -0
- package/side-sheet/side-sheet.config.d.ts +3 -0
- package/side-sheet/side-sheet.content-directives.d.ts +50 -0
- package/side-sheet/side-sheet.d.ts +56 -0
- package/side-sheet/side-sheet.module.d.ts +2 -0
- package/side-sheet/side-sheet.scss +69 -0
- package/side-sheet/side-sheet.theme.scss +8 -0
- package/theming/_all-theme.scss +2 -0
- package/theming/prebuilt/blue-grey-deep-orange.css +5 -1
- package/theming/prebuilt/blue-grey-deep-orange.css.map +1 -1
- package/theming/prebuilt/blue-orange.css +5 -1
- package/theming/prebuilt/blue-orange.css.map +1 -1
- package/theming/prebuilt/indigo-pink.css +5 -1
- package/theming/prebuilt/indigo-pink.css.map +1 -1
- package/theming/prebuilt/orange-light-blue.css +5 -1
- package/theming/prebuilt/orange-light-blue.css.map +1 -1
- package/theming/prebuilt/teal-orange.css +5 -1
- package/theming/prebuilt/teal-orange.css.map +1 -1
@@ -0,0 +1,388 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview added by tsickle
|
3
|
+
* Generated from: side-sheet-container.ts
|
4
|
+
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
5
|
+
*/
|
6
|
+
import { FocusMonitor, FocusTrapFactory } from '@angular/cdk/a11y';
|
7
|
+
import { BasePortalOutlet, CdkPortalOutlet } from '@angular/cdk/portal';
|
8
|
+
import { DOCUMENT } from '@angular/common';
|
9
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, ElementRef, EventEmitter, Inject, Optional, ViewChild, ViewEncapsulation, } from '@angular/core';
|
10
|
+
import { tdSideSheetAnimations } from './side-sheet.animation';
|
11
|
+
import { CovalentSideSheetConfig } from './side-sheet.config';
|
12
|
+
/**
|
13
|
+
* @return {?}
|
14
|
+
*/
|
15
|
+
export function _getFocusedElementPierceShadowDom() {
|
16
|
+
/** @type {?} */
|
17
|
+
let activeElement = typeof document !== 'undefined' && document ? ((/** @type {?} */ (document.activeElement))) : null;
|
18
|
+
while (activeElement && activeElement.shadowRoot) {
|
19
|
+
/** @type {?} */
|
20
|
+
const newActiveElement = (/** @type {?} */ (activeElement.shadowRoot.activeElement));
|
21
|
+
if (newActiveElement === activeElement) {
|
22
|
+
break;
|
23
|
+
}
|
24
|
+
else {
|
25
|
+
activeElement = newActiveElement;
|
26
|
+
}
|
27
|
+
}
|
28
|
+
return activeElement;
|
29
|
+
}
|
30
|
+
/**
|
31
|
+
* Base class for the `CovalentSideSheetContainer`. The base class does not implement
|
32
|
+
* animations as these are left to implementers of the side-sheet container.
|
33
|
+
* @abstract
|
34
|
+
*/
|
35
|
+
export class _CovalentSideSheetContainerBase extends BasePortalOutlet {
|
36
|
+
/**
|
37
|
+
* @param {?} _elementRef
|
38
|
+
* @param {?} _focusTrapFactory
|
39
|
+
* @param {?} _changeDetectorRef
|
40
|
+
* @param {?} _document
|
41
|
+
* @param {?} _config
|
42
|
+
* @param {?=} _focusMonitor
|
43
|
+
*/
|
44
|
+
constructor(_elementRef, _focusTrapFactory, _changeDetectorRef, _document, _config, _focusMonitor) {
|
45
|
+
super();
|
46
|
+
this._elementRef = _elementRef;
|
47
|
+
this._focusTrapFactory = _focusTrapFactory;
|
48
|
+
this._changeDetectorRef = _changeDetectorRef;
|
49
|
+
this._config = _config;
|
50
|
+
this._focusMonitor = _focusMonitor;
|
51
|
+
/**
|
52
|
+
* Emits when an animation state changes.
|
53
|
+
*/
|
54
|
+
this._animationStateChanged = new EventEmitter();
|
55
|
+
/**
|
56
|
+
* Element that was focused before the side-sheet was opened. Save this to restore upon close.
|
57
|
+
*/
|
58
|
+
this._elementFocusedBeforeSideSheetWasOpened = null;
|
59
|
+
/**
|
60
|
+
* Type of interaction that led to the side-sheet being closed. This is used to determine
|
61
|
+
* whether the focus style will be applied when returning focus to its original location
|
62
|
+
* after the side-sheet is closed.
|
63
|
+
*/
|
64
|
+
this._closeInteractionType = null;
|
65
|
+
/**
|
66
|
+
* Attaches a DOM portal to the side-sheet container.
|
67
|
+
* @param portal Portal to be attached.
|
68
|
+
* @deprecated To be turned into a method.
|
69
|
+
*/
|
70
|
+
this.attachDomPortal = (/**
|
71
|
+
* @param {?} portal
|
72
|
+
* @return {?}
|
73
|
+
*/
|
74
|
+
(portal) => {
|
75
|
+
return this._portalOutlet.attachDomPortal(portal);
|
76
|
+
});
|
77
|
+
this._ariaLabelledBy = _config.ariaLabelledBy || null;
|
78
|
+
this._document = _document;
|
79
|
+
}
|
80
|
+
/**
|
81
|
+
* Initializes the side-sheet container with the attached content.
|
82
|
+
* @return {?}
|
83
|
+
*/
|
84
|
+
_initializeWithAttachedContent() {
|
85
|
+
this._setupFocusTrap();
|
86
|
+
// Save the previously focused element. This element will be re-focused
|
87
|
+
// when the side-sheet closes.
|
88
|
+
this._capturePreviouslyFocusedElement();
|
89
|
+
}
|
90
|
+
/**
|
91
|
+
* Attach a ComponentPortal as content to this side-sheet container.
|
92
|
+
* @template T
|
93
|
+
* @param {?} portal Portal to be attached as the side-sheet content.
|
94
|
+
* @return {?}
|
95
|
+
*/
|
96
|
+
attachComponentPortal(portal) {
|
97
|
+
return this._portalOutlet.attachComponentPortal(portal);
|
98
|
+
}
|
99
|
+
/**
|
100
|
+
* Attach a TemplatePortal as content to this side-sheet container.
|
101
|
+
* @template C
|
102
|
+
* @param {?} portal Portal to be attached as the side-sheet content.
|
103
|
+
* @return {?}
|
104
|
+
*/
|
105
|
+
attachTemplatePortal(portal) {
|
106
|
+
return this._portalOutlet.attachTemplatePortal(portal);
|
107
|
+
}
|
108
|
+
/**
|
109
|
+
* Moves focus back into the side-sheet if it was moved out.
|
110
|
+
* @return {?}
|
111
|
+
*/
|
112
|
+
_recaptureFocus() {
|
113
|
+
if (!this._containsFocus()) {
|
114
|
+
this._trapFocus();
|
115
|
+
}
|
116
|
+
}
|
117
|
+
/**
|
118
|
+
* Moves the focus inside the focus trap. When autoFocus is not set to 'side-sheet', if focus
|
119
|
+
* cannot be moved then focus will go to the side-sheet container.
|
120
|
+
* @protected
|
121
|
+
* @return {?}
|
122
|
+
*/
|
123
|
+
_trapFocus() {
|
124
|
+
/** @type {?} */
|
125
|
+
const element = this._elementRef.nativeElement;
|
126
|
+
if (!this._config.autoFocus) {
|
127
|
+
if (!this._containsFocus()) {
|
128
|
+
element.focus();
|
129
|
+
}
|
130
|
+
}
|
131
|
+
else {
|
132
|
+
this._focusTrap.focusInitialElementWhenReady().then((/**
|
133
|
+
* @param {?} focusedSuccessfully
|
134
|
+
* @return {?}
|
135
|
+
*/
|
136
|
+
(focusedSuccessfully) => {
|
137
|
+
// If we weren't able to find a focusable element in the side-sheet, then focus the side-sheet
|
138
|
+
// container instead.
|
139
|
+
if (!focusedSuccessfully) {
|
140
|
+
this._focusSideSheetContainer();
|
141
|
+
}
|
142
|
+
}));
|
143
|
+
}
|
144
|
+
}
|
145
|
+
/**
|
146
|
+
* Restores focus to the element that was focused before the side-sheet opened.
|
147
|
+
* @protected
|
148
|
+
* @return {?}
|
149
|
+
*/
|
150
|
+
_restoreFocus() {
|
151
|
+
/** @type {?} */
|
152
|
+
const previousElement = this._elementFocusedBeforeSideSheetWasOpened;
|
153
|
+
// We need the extra check, because IE can set the `activeElement` to null in some cases.
|
154
|
+
if (this._config.restoreFocus && previousElement && typeof previousElement.focus === 'function') {
|
155
|
+
/** @type {?} */
|
156
|
+
const activeElement = _getFocusedElementPierceShadowDom();
|
157
|
+
/** @type {?} */
|
158
|
+
const element = this._elementRef.nativeElement;
|
159
|
+
// Make sure that focus is still inside the side-sheet or is on the body (usually because a
|
160
|
+
// non-focusable element like the backdrop was clicked) before moving it. It's possible that
|
161
|
+
// the consumer moved it themselves before the animation was done, in which case we shouldn't
|
162
|
+
// do anything.
|
163
|
+
if (!activeElement ||
|
164
|
+
activeElement === this._document.body ||
|
165
|
+
activeElement === element ||
|
166
|
+
element.contains(activeElement)) {
|
167
|
+
if (this._focusMonitor) {
|
168
|
+
this._focusMonitor.focusVia(previousElement, this._closeInteractionType);
|
169
|
+
this._closeInteractionType = null;
|
170
|
+
}
|
171
|
+
else {
|
172
|
+
previousElement.focus();
|
173
|
+
}
|
174
|
+
}
|
175
|
+
}
|
176
|
+
if (this._focusTrap) {
|
177
|
+
this._focusTrap.destroy();
|
178
|
+
}
|
179
|
+
}
|
180
|
+
/**
|
181
|
+
* Sets up the focus trap.
|
182
|
+
* @private
|
183
|
+
* @return {?}
|
184
|
+
*/
|
185
|
+
_setupFocusTrap() {
|
186
|
+
this._focusTrap = this._focusTrapFactory.create(this._elementRef.nativeElement);
|
187
|
+
}
|
188
|
+
/**
|
189
|
+
* Captures the element that was focused before the side-sheet was opened.
|
190
|
+
* @private
|
191
|
+
* @return {?}
|
192
|
+
*/
|
193
|
+
_capturePreviouslyFocusedElement() {
|
194
|
+
if (this._document) {
|
195
|
+
this._elementFocusedBeforeSideSheetWasOpened = _getFocusedElementPierceShadowDom();
|
196
|
+
}
|
197
|
+
}
|
198
|
+
/**
|
199
|
+
* Focuses the side-sheet container.
|
200
|
+
* @private
|
201
|
+
* @return {?}
|
202
|
+
*/
|
203
|
+
_focusSideSheetContainer() {
|
204
|
+
// Note that there is no focus method when rendering on the server.
|
205
|
+
if (this._elementRef.nativeElement.focus) {
|
206
|
+
this._elementRef.nativeElement.focus();
|
207
|
+
}
|
208
|
+
}
|
209
|
+
/**
|
210
|
+
* Returns whether focus is inside the side-sheet.
|
211
|
+
* @private
|
212
|
+
* @return {?}
|
213
|
+
*/
|
214
|
+
_containsFocus() {
|
215
|
+
/** @type {?} */
|
216
|
+
const element = this._elementRef.nativeElement;
|
217
|
+
/** @type {?} */
|
218
|
+
const activeElement = _getFocusedElementPierceShadowDom();
|
219
|
+
return element === activeElement || element.contains(activeElement);
|
220
|
+
}
|
221
|
+
}
|
222
|
+
_CovalentSideSheetContainerBase.decorators = [
|
223
|
+
{ type: Directive }
|
224
|
+
];
|
225
|
+
/** @nocollapse */
|
226
|
+
_CovalentSideSheetContainerBase.ctorParameters = () => [
|
227
|
+
{ type: ElementRef },
|
228
|
+
{ type: FocusTrapFactory },
|
229
|
+
{ type: ChangeDetectorRef },
|
230
|
+
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DOCUMENT,] }] },
|
231
|
+
{ type: CovalentSideSheetConfig },
|
232
|
+
{ type: FocusMonitor }
|
233
|
+
];
|
234
|
+
_CovalentSideSheetContainerBase.propDecorators = {
|
235
|
+
_portalOutlet: [{ type: ViewChild, args: [CdkPortalOutlet, { static: true },] }]
|
236
|
+
};
|
237
|
+
if (false) {
|
238
|
+
/**
|
239
|
+
* @type {?}
|
240
|
+
* @protected
|
241
|
+
*/
|
242
|
+
_CovalentSideSheetContainerBase.prototype._document;
|
243
|
+
/**
|
244
|
+
* The portal outlet inside of this container into which the side-sheet content will be loaded.
|
245
|
+
* @type {?}
|
246
|
+
*/
|
247
|
+
_CovalentSideSheetContainerBase.prototype._portalOutlet;
|
248
|
+
/**
|
249
|
+
* The class that traps and manages focus within the side-sheet.
|
250
|
+
* @type {?}
|
251
|
+
* @private
|
252
|
+
*/
|
253
|
+
_CovalentSideSheetContainerBase.prototype._focusTrap;
|
254
|
+
/**
|
255
|
+
* Emits when an animation state changes.
|
256
|
+
* @type {?}
|
257
|
+
*/
|
258
|
+
_CovalentSideSheetContainerBase.prototype._animationStateChanged;
|
259
|
+
/**
|
260
|
+
* Element that was focused before the side-sheet was opened. Save this to restore upon close.
|
261
|
+
* @type {?}
|
262
|
+
* @private
|
263
|
+
*/
|
264
|
+
_CovalentSideSheetContainerBase.prototype._elementFocusedBeforeSideSheetWasOpened;
|
265
|
+
/**
|
266
|
+
* Type of interaction that led to the side-sheet being closed. This is used to determine
|
267
|
+
* whether the focus style will be applied when returning focus to its original location
|
268
|
+
* after the side-sheet is closed.
|
269
|
+
* @type {?}
|
270
|
+
*/
|
271
|
+
_CovalentSideSheetContainerBase.prototype._closeInteractionType;
|
272
|
+
/**
|
273
|
+
* ID of the element that should be considered as the side-sheet's label.
|
274
|
+
* @type {?}
|
275
|
+
*/
|
276
|
+
_CovalentSideSheetContainerBase.prototype._ariaLabelledBy;
|
277
|
+
/**
|
278
|
+
* ID for the container DOM element.
|
279
|
+
* @type {?}
|
280
|
+
*/
|
281
|
+
_CovalentSideSheetContainerBase.prototype._id;
|
282
|
+
/**
|
283
|
+
* Attaches a DOM portal to the side-sheet container.
|
284
|
+
* \@param portal Portal to be attached.
|
285
|
+
* @deprecated To be turned into a method.
|
286
|
+
* @type {?}
|
287
|
+
*/
|
288
|
+
_CovalentSideSheetContainerBase.prototype.attachDomPortal;
|
289
|
+
/**
|
290
|
+
* @type {?}
|
291
|
+
* @protected
|
292
|
+
*/
|
293
|
+
_CovalentSideSheetContainerBase.prototype._elementRef;
|
294
|
+
/**
|
295
|
+
* @type {?}
|
296
|
+
* @protected
|
297
|
+
*/
|
298
|
+
_CovalentSideSheetContainerBase.prototype._focusTrapFactory;
|
299
|
+
/**
|
300
|
+
* @type {?}
|
301
|
+
* @protected
|
302
|
+
*/
|
303
|
+
_CovalentSideSheetContainerBase.prototype._changeDetectorRef;
|
304
|
+
/**
|
305
|
+
* The side-sheet configuration.
|
306
|
+
* @type {?}
|
307
|
+
*/
|
308
|
+
_CovalentSideSheetContainerBase.prototype._config;
|
309
|
+
/**
|
310
|
+
* @type {?}
|
311
|
+
* @private
|
312
|
+
*/
|
313
|
+
_CovalentSideSheetContainerBase.prototype._focusMonitor;
|
314
|
+
/**
|
315
|
+
* Starts the side-sheet exit animation.
|
316
|
+
* @abstract
|
317
|
+
* @return {?}
|
318
|
+
*/
|
319
|
+
_CovalentSideSheetContainerBase.prototype._startExitAnimation = function () { };
|
320
|
+
}
|
321
|
+
/**
|
322
|
+
* Internal component that wraps the generated side-sheet content.
|
323
|
+
* This animation below is the only reason for duplicating most of the Material dialog code
|
324
|
+
*/
|
325
|
+
export class CovalentSideSheetContainer extends _CovalentSideSheetContainerBase {
|
326
|
+
constructor() {
|
327
|
+
super(...arguments);
|
328
|
+
/**
|
329
|
+
* State of the side-sheet animation.
|
330
|
+
*/
|
331
|
+
this._state = 'enter';
|
332
|
+
}
|
333
|
+
/**
|
334
|
+
* Callback, invoked whenever an animation on the host completes.
|
335
|
+
* @param {?} __0
|
336
|
+
* @return {?}
|
337
|
+
*/
|
338
|
+
_onAnimationDone({ toState, totalTime }) {
|
339
|
+
if (toState === 'enter') {
|
340
|
+
this._trapFocus();
|
341
|
+
this._animationStateChanged.next({ state: 'opened', totalTime });
|
342
|
+
}
|
343
|
+
else if (toState === 'exit') {
|
344
|
+
this._restoreFocus();
|
345
|
+
this._animationStateChanged.next({ state: 'closed', totalTime });
|
346
|
+
}
|
347
|
+
}
|
348
|
+
/**
|
349
|
+
* Starts the side-sheet exit animation.
|
350
|
+
* @return {?}
|
351
|
+
*/
|
352
|
+
_startExitAnimation() {
|
353
|
+
this._state = 'exit';
|
354
|
+
this._changeDetectorRef.markForCheck();
|
355
|
+
}
|
356
|
+
}
|
357
|
+
CovalentSideSheetContainer.decorators = [
|
358
|
+
{ type: Component, args: [{
|
359
|
+
selector: 'td-side-sheet-container',
|
360
|
+
template: `
|
361
|
+
<ng-template cdkPortalOutlet></ng-template>
|
362
|
+
`,
|
363
|
+
encapsulation: ViewEncapsulation.None,
|
364
|
+
changeDetection: ChangeDetectionStrategy.Default,
|
365
|
+
animations: [tdSideSheetAnimations.sideSheetContainer],
|
366
|
+
host: {
|
367
|
+
'class': 'td-side-sheet-container',
|
368
|
+
'tabindex': '-1',
|
369
|
+
'aria-modal': 'true',
|
370
|
+
'[id]': '_id',
|
371
|
+
'[attr.role]': '_config.role',
|
372
|
+
'[attr.aria-labelledby]': '_config.ariaLabel ? null : _ariaLabelledBy',
|
373
|
+
'[attr.aria-label]': '_config.ariaLabel',
|
374
|
+
'[attr.aria-describedby]': '_config.ariaDescribedBy || null',
|
375
|
+
'[@sideSheetContainer]': '_state',
|
376
|
+
'(@sideSheetContainer.done)': '_onAnimationDone($event)',
|
377
|
+
},
|
378
|
+
styles: [".td-side-sheet-container{background-color:#fff;box-shadow:0 8px 10px -5px rgba(0,0,0,.2),0 16px 24px 2px rgba(0,0,0,.14),0 6px 30px 5px rgba(0,0,0,.12);box-sizing:border-box;display:block;height:100%;max-height:inherit;min-height:inherit;outline:0;overflow:auto;padding:24px;width:100%}.td-side-sheet-wrapper{-ms-flex-direction:column;display:-ms-flexbox;display:flex;flex-direction:column;height:100%}.td-side-sheet-content{-ms-flex:1;-webkit-overflow-scrolling:touch;flex:1;margin:0 -24px;overflow:auto;padding:0 24px}.td-side-sheet-title{margin:-16px 0 20px}.td-side-sheet-actions,.td-side-sheet-title{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex}.td-side-sheet-actions{-ms-flex-pack:justify;-ms-flex-wrap:wrap;box-sizing:content-box;flex-wrap:wrap;justify-content:space-between;margin:0 -16px -24px;padding:8px 0}.td-side-sheet-actions[align=end]{-ms-flex-pack:end;justify-content:flex-end}.td-side-sheet-actions[align=center]{-ms-flex-pack:center;justify-content:center}.td-side-sheet-actions .mat-button-base+.mat-button-base,.td-side-sheet-actions .mat-mdc-button-base+.mat-mdc-button-base{margin-left:8px}[dir=rtl] .td-side-sheet-actions .mat-button-base+.mat-button-base,[dir=rtl] .td-side-sheet-actions .mat-mdc-button-base+.mat-mdc-button-base{margin-left:0;margin-right:8px}"]
|
379
|
+
}] }
|
380
|
+
];
|
381
|
+
if (false) {
|
382
|
+
/**
|
383
|
+
* State of the side-sheet animation.
|
384
|
+
* @type {?}
|
385
|
+
*/
|
386
|
+
CovalentSideSheetContainer.prototype._state;
|
387
|
+
}
|
388
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-sheet-container.js","sourceRoot":"../../../../../src/platform/core/side-sheet/","sources":["side-sheet-container.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable */\nimport { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusOrigin, FocusTrap, FocusTrapFactory } from '@angular/cdk/a11y';\nimport { BasePortalOutlet, CdkPortalOutlet, ComponentPortal, DomPortal, TemplatePortal } from '@angular/cdk/portal';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EmbeddedViewRef,\n  EventEmitter,\n  Inject,\n  Optional,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { tdSideSheetAnimations } from './side-sheet.animation';\nimport { CovalentSideSheetConfig } from './side-sheet.config';\n\nexport function _getFocusedElementPierceShadowDom(): HTMLElement | null {\n  let activeElement =\n    typeof document !== 'undefined' && document ? (document.activeElement as HTMLElement | null) : null;\n\n  while (activeElement && activeElement.shadowRoot) {\n    const newActiveElement = activeElement.shadowRoot.activeElement as HTMLElement | null;\n    if (newActiveElement === activeElement) {\n      break;\n    } else {\n      activeElement = newActiveElement;\n    }\n  }\n\n  return activeElement;\n}\n\n/**\n * Base class for the `CovalentSideSheetContainer`. The base class does not implement\n * animations as these are left to implementers of the side-sheet container.\n */\n@Directive()\nexport abstract class _CovalentSideSheetContainerBase extends BasePortalOutlet {\n  protected _document: Document;\n\n  /** The portal outlet inside of this container into which the side-sheet content will be loaded. */\n  @ViewChild(CdkPortalOutlet, { static: true }) _portalOutlet: CdkPortalOutlet;\n\n  /** The class that traps and manages focus within the side-sheet. */\n  private _focusTrap: FocusTrap;\n\n  /** Emits when an animation state changes. */\n  _animationStateChanged = new EventEmitter<{\n    state: 'opened' | 'opening' | 'closing' | 'closed';\n    totalTime: number;\n  }>();\n\n  /** Element that was focused before the side-sheet was opened. Save this to restore upon close. */\n  private _elementFocusedBeforeSideSheetWasOpened: HTMLElement | null = null;\n\n  /**\n   * Type of interaction that led to the side-sheet being closed. This is used to determine\n   * whether the focus style will be applied when returning focus to its original location\n   * after the side-sheet is closed.\n   */\n  _closeInteractionType: FocusOrigin | null = null;\n\n  /** ID of the element that should be considered as the side-sheet's label. */\n  _ariaLabelledBy: string | null;\n\n  /** ID for the container DOM element. */\n  _id: string;\n\n  constructor(\n    protected _elementRef: ElementRef,\n    protected _focusTrapFactory: FocusTrapFactory,\n    protected _changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Inject(DOCUMENT) _document: any,\n    /** The side-sheet configuration. */\n    public _config: CovalentSideSheetConfig,\n    private _focusMonitor?: FocusMonitor,\n  ) {\n    super();\n    this._ariaLabelledBy = _config.ariaLabelledBy || null;\n    this._document = _document;\n  }\n\n  /** Starts the side-sheet exit animation. */\n  abstract _startExitAnimation(): void;\n\n  /** Initializes the side-sheet container with the attached content. */\n  _initializeWithAttachedContent() {\n    this._setupFocusTrap();\n    // Save the previously focused element. This element will be re-focused\n    // when the side-sheet closes.\n    this._capturePreviouslyFocusedElement();\n  }\n\n  /**\n   * Attach a ComponentPortal as content to this side-sheet container.\n   * @param portal Portal to be attached as the side-sheet content.\n   */\n  attachComponentPortal<T>(portal: ComponentPortal<T>): ComponentRef<T> {\n    return this._portalOutlet.attachComponentPortal(portal);\n  }\n\n  /**\n   * Attach a TemplatePortal as content to this side-sheet container.\n   * @param portal Portal to be attached as the side-sheet content.\n   */\n  attachTemplatePortal<C>(portal: TemplatePortal<C>): EmbeddedViewRef<C> {\n    return this._portalOutlet.attachTemplatePortal(portal);\n  }\n\n  /**\n   * Attaches a DOM portal to the side-sheet container.\n   * @param portal Portal to be attached.\n   * @deprecated To be turned into a method.\n   */\n  attachDomPortal = (portal: DomPortal) => {\n    return this._portalOutlet.attachDomPortal(portal);\n  };\n\n  /** Moves focus back into the side-sheet if it was moved out. */\n  _recaptureFocus() {\n    if (!this._containsFocus()) {\n      this._trapFocus();\n    }\n  }\n\n  /**\n   * Moves the focus inside the focus trap. When autoFocus is not set to 'side-sheet', if focus\n   * cannot be moved then focus will go to the side-sheet container.\n   */\n  protected _trapFocus() {\n    const element = this._elementRef.nativeElement;\n    if (!this._config.autoFocus) {\n      if (!this._containsFocus()) {\n        element.focus();\n      }\n    } else {\n      this._focusTrap.focusInitialElementWhenReady().then((focusedSuccessfully) => {\n        // If we weren't able to find a focusable element in the side-sheet, then focus the side-sheet\n        // container instead.\n        if (!focusedSuccessfully) {\n          this._focusSideSheetContainer();\n        }\n      });\n    }\n  }\n\n  /** Restores focus to the element that was focused before the side-sheet opened. */\n  protected _restoreFocus() {\n    const previousElement = this._elementFocusedBeforeSideSheetWasOpened;\n\n    // We need the extra check, because IE can set the `activeElement` to null in some cases.\n    if (this._config.restoreFocus && previousElement && typeof previousElement.focus === 'function') {\n      const activeElement = _getFocusedElementPierceShadowDom();\n      const element = this._elementRef.nativeElement;\n\n      // Make sure that focus is still inside the side-sheet or is on the body (usually because a\n      // non-focusable element like the backdrop was clicked) before moving it. It's possible that\n      // the consumer moved it themselves before the animation was done, in which case we shouldn't\n      // do anything.\n      if (\n        !activeElement ||\n        activeElement === this._document.body ||\n        activeElement === element ||\n        element.contains(activeElement)\n      ) {\n        if (this._focusMonitor) {\n          this._focusMonitor.focusVia(previousElement, this._closeInteractionType);\n          this._closeInteractionType = null;\n        } else {\n          previousElement.focus();\n        }\n      }\n    }\n\n    if (this._focusTrap) {\n      this._focusTrap.destroy();\n    }\n  }\n\n  /** Sets up the focus trap. */\n  private _setupFocusTrap() {\n    this._focusTrap = this._focusTrapFactory.create(this._elementRef.nativeElement);\n  }\n\n  /** Captures the element that was focused before the side-sheet was opened. */\n  private _capturePreviouslyFocusedElement() {\n    if (this._document) {\n      this._elementFocusedBeforeSideSheetWasOpened = _getFocusedElementPierceShadowDom();\n    }\n  }\n\n  /** Focuses the side-sheet container. */\n  private _focusSideSheetContainer() {\n    // Note that there is no focus method when rendering on the server.\n    if (this._elementRef.nativeElement.focus) {\n      this._elementRef.nativeElement.focus();\n    }\n  }\n\n  /** Returns whether focus is inside the side-sheet. */\n  private _containsFocus() {\n    const element = this._elementRef.nativeElement;\n    const activeElement = _getFocusedElementPierceShadowDom();\n    return element === activeElement || element.contains(activeElement);\n  }\n}\n\n/**\n * Internal component that wraps the generated side-sheet content.\n * This animation below is the only reason for duplicating most of the Material dialog code\n */\n@Component({\n  selector: 'td-side-sheet-container',\n  template: `\n    <ng-template cdkPortalOutlet></ng-template>\n  `,\n  styleUrls: ['side-sheet.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.Default,\n  animations: [tdSideSheetAnimations.sideSheetContainer],\n  host: {\n    'class': 'td-side-sheet-container',\n    'tabindex': '-1',\n    'aria-modal': 'true',\n    '[id]': '_id',\n    '[attr.role]': '_config.role',\n    '[attr.aria-labelledby]': '_config.ariaLabel ? null : _ariaLabelledBy',\n    '[attr.aria-label]': '_config.ariaLabel',\n    '[attr.aria-describedby]': '_config.ariaDescribedBy || null',\n    '[@sideSheetContainer]': '_state',\n    '(@sideSheetContainer.done)': '_onAnimationDone($event)',\n  },\n})\nexport class CovalentSideSheetContainer extends _CovalentSideSheetContainerBase {\n  /** State of the side-sheet animation. */\n  _state: 'void' | 'enter' | 'exit' = 'enter';\n\n  /** Callback, invoked whenever an animation on the host completes. */\n  _onAnimationDone({ toState, totalTime }: AnimationEvent) {\n    if (toState === 'enter') {\n      this._trapFocus();\n      this._animationStateChanged.next({ state: 'opened', totalTime });\n    } else if (toState === 'exit') {\n      this._restoreFocus();\n      this._animationStateChanged.next({ state: 'closed', totalTime });\n    }\n  }\n\n  /** Starts the side-sheet exit animation. */\n  _startExitAnimation(): void {\n    this._state = 'exit';\n    this._changeDetectorRef.markForCheck();\n  }\n}\n"]}
|
@@ -0,0 +1,47 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview added by tsickle
|
3
|
+
* Generated from: side-sheet-ref.ts
|
4
|
+
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
5
|
+
*/
|
6
|
+
import { MatDialogRef } from '@angular/material/dialog';
|
7
|
+
// Counter for unique dialog ids.
|
8
|
+
/** @type {?} */
|
9
|
+
let uniqueId = 0;
|
10
|
+
// Create a new side sheet ref to change the id of the ref
|
11
|
+
/**
|
12
|
+
* @template T, R
|
13
|
+
*/
|
14
|
+
export class CovalentSideSheetRef extends MatDialogRef {
|
15
|
+
/**
|
16
|
+
* @param {?} overlayRef
|
17
|
+
* @param {?} _containerInstance
|
18
|
+
* @param {?=} id
|
19
|
+
*/
|
20
|
+
constructor(overlayRef, _containerInstance, id = `td-side-sheet-${uniqueId++}`) {
|
21
|
+
super(overlayRef, _containerInstance, id);
|
22
|
+
this._containerInstance = _containerInstance;
|
23
|
+
this.id = id;
|
24
|
+
}
|
25
|
+
}
|
26
|
+
if (false) {
|
27
|
+
/** @type {?} */
|
28
|
+
CovalentSideSheetRef.prototype._containerInstance;
|
29
|
+
/** @type {?} */
|
30
|
+
CovalentSideSheetRef.prototype.id;
|
31
|
+
}
|
32
|
+
/**
|
33
|
+
* @template R
|
34
|
+
* @param {?} ref
|
35
|
+
* @param {?} interactionType
|
36
|
+
* @param {?=} result
|
37
|
+
* @return {?}
|
38
|
+
*/
|
39
|
+
export function _closeSideSheetVia(ref, interactionType, result) {
|
40
|
+
// Some mock dialog ref instances in tests do not have the `_containerInstance` property.
|
41
|
+
// For those, we keep the behavior as is and do not deal with the interaction type.
|
42
|
+
if (ref._containerInstance !== undefined) {
|
43
|
+
ref._containerInstance._closeInteractionType = interactionType;
|
44
|
+
}
|
45
|
+
return ref.close(result);
|
46
|
+
}
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1zaGVldC1yZWYuanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vc3JjL3BsYXRmb3JtL2NvcmUvc2lkZS1zaGVldC8iLCJzb3VyY2VzIjpbInNpZGUtc2hlZXQtcmVmLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBR0EsT0FBTyxFQUFFLFlBQVksRUFBMkIsTUFBTSwwQkFBMEIsQ0FBQzs7O0lBRzdFLFFBQVEsR0FBRyxDQUFDOzs7OztBQUdoQixNQUFNLE9BQU8sb0JBQWlDLFNBQVEsWUFBa0I7Ozs7OztJQUN0RSxZQUNFLFVBQXNCLEVBQ2Ysa0JBQTJDLEVBQ3pDLEtBQWEsaUJBQWlCLFFBQVEsRUFBRSxFQUFFO1FBRW5ELEtBQUssQ0FBQyxVQUFVLEVBQUUsa0JBQWtCLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFIbkMsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUF5QjtRQUN6QyxPQUFFLEdBQUYsRUFBRSxDQUF3QztJQUdyRCxDQUFDO0NBQ0Y7OztJQUxHLGtEQUFrRDs7SUFDbEQsa0NBQW1EOzs7Ozs7Ozs7QUFNdkQsTUFBTSxVQUFVLGtCQUFrQixDQUFJLEdBQW9CLEVBQUUsZUFBNEIsRUFBRSxNQUFVO0lBQ2xHLHlGQUF5RjtJQUN6RixtRkFBbUY7SUFDbkYsSUFBSSxHQUFHLENBQUMsa0JBQWtCLEtBQUssU0FBUyxFQUFFO1FBQ3hDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxxQkFBcUIsR0FBRyxlQUFlLENBQUM7S0FDaEU7SUFDRCxPQUFPLEdBQUcsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7QUFDM0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qIHRzbGludDpkaXNhYmxlICovXG5pbXBvcnQgeyBGb2N1c09yaWdpbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7IE92ZXJsYXlSZWYgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBNYXREaWFsb2dSZWYsIF9NYXREaWFsb2dDb250YWluZXJCYXNlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcblxuLy8gQ291bnRlciBmb3IgdW5pcXVlIGRpYWxvZyBpZHMuXG5sZXQgdW5pcXVlSWQgPSAwO1xuXG4vLyBDcmVhdGUgYSBuZXcgc2lkZSBzaGVldCByZWYgdG8gY2hhbmdlIHRoZSBpZCBvZiB0aGUgcmVmXG5leHBvcnQgY2xhc3MgQ292YWxlbnRTaWRlU2hlZXRSZWY8VCwgUiA9IGFueT4gZXh0ZW5kcyBNYXREaWFsb2dSZWY8VCwgUj4ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBvdmVybGF5UmVmOiBPdmVybGF5UmVmLFxuICAgIHB1YmxpYyBfY29udGFpbmVySW5zdGFuY2U6IF9NYXREaWFsb2dDb250YWluZXJCYXNlLFxuICAgIHJlYWRvbmx5IGlkOiBzdHJpbmcgPSBgdGQtc2lkZS1zaGVldC0ke3VuaXF1ZUlkKyt9YCxcbiAgKSB7XG4gICAgc3VwZXIob3ZlcmxheVJlZiwgX2NvbnRhaW5lckluc3RhbmNlLCBpZCk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIF9jbG9zZVNpZGVTaGVldFZpYTxSPihyZWY6IE1hdERpYWxvZ1JlZjxSPiwgaW50ZXJhY3Rpb25UeXBlOiBGb2N1c09yaWdpbiwgcmVzdWx0PzogUikge1xuICAvLyBTb21lIG1vY2sgZGlhbG9nIHJlZiBpbnN0YW5jZXMgaW4gdGVzdHMgZG8gbm90IGhhdmUgdGhlIGBfY29udGFpbmVySW5zdGFuY2VgIHByb3BlcnR5LlxuICAvLyBGb3IgdGhvc2UsIHdlIGtlZXAgdGhlIGJlaGF2aW9yIGFzIGlzIGFuZCBkbyBub3QgZGVhbCB3aXRoIHRoZSBpbnRlcmFjdGlvbiB0eXBlLlxuICBpZiAocmVmLl9jb250YWluZXJJbnN0YW5jZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgcmVmLl9jb250YWluZXJJbnN0YW5jZS5fY2xvc2VJbnRlcmFjdGlvblR5cGUgPSBpbnRlcmFjdGlvblR5cGU7XG4gIH1cbiAgcmV0dXJuIHJlZi5jbG9zZShyZXN1bHQpO1xufVxuIl19
|
@@ -0,0 +1,20 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview added by tsickle
|
3
|
+
* Generated from: side-sheet.animation.ts
|
4
|
+
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
5
|
+
*/
|
6
|
+
import { animate, state, style, transition, trigger } from '@angular/animations';
|
7
|
+
import { AnimationCurves, AnimationDurations } from '@angular/material/core';
|
8
|
+
/** @type {?} */
|
9
|
+
export const tdSideSheetAnimations = {
|
10
|
+
/**
|
11
|
+
* Animation that is applied on the side-sheet container by default.
|
12
|
+
*/
|
13
|
+
sideSheetContainer: trigger('sideSheetContainer', [
|
14
|
+
state('void, exit', style({ transform: 'translateX(100%)' })),
|
15
|
+
state('enter', style({ transform: 'translateX(0%)', opacity: 1 })),
|
16
|
+
transition('* => enter', animate(`${AnimationDurations.ENTERING} ${AnimationCurves.ACCELERATION_CURVE}`, style({ transform: 'translateX(0)', opacity: 1 }))),
|
17
|
+
transition('* => void, * => exit', animate(`${AnimationDurations.EXITING} ${AnimationCurves.ACCELERATION_CURVE}`, style({ transform: 'translateX(100%)' }))),
|
18
|
+
]),
|
19
|
+
};
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1zaGVldC5hbmltYXRpb24uanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vc3JjL3BsYXRmb3JtL2NvcmUvc2lkZS1zaGVldC8iLCJzb3VyY2VzIjpbInNpZGUtc2hlZXQuYW5pbWF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQTRCLE1BQU0scUJBQXFCLENBQUM7QUFDM0csT0FBTyxFQUFFLGVBQWUsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQUU3RSxNQUFNLE9BQU8scUJBQXFCLEdBRTlCOzs7O0lBRUYsa0JBQWtCLEVBQUUsT0FBTyxDQUFDLG9CQUFvQixFQUFFO1FBQ2hELEtBQUssQ0FBQyxZQUFZLEVBQUUsS0FBSyxDQUFDLEVBQUUsU0FBUyxFQUFFLGtCQUFrQixFQUFFLENBQUMsQ0FBQztRQUM3RCxLQUFLLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNsRSxVQUFVLENBQ1IsWUFBWSxFQUNaLE9BQU8sQ0FDTCxHQUFHLGtCQUFrQixDQUFDLFFBQVEsSUFBSSxlQUFlLENBQUMsa0JBQWtCLEVBQUUsRUFDdEUsS0FBSyxDQUFDLEVBQUUsU0FBUyxFQUFFLGVBQWUsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FDbEQsQ0FDRjtRQUNELFVBQVUsQ0FDUixzQkFBc0IsRUFDdEIsT0FBTyxDQUNMLEdBQUcsa0JBQWtCLENBQUMsT0FBTyxJQUFJLGVBQWUsQ0FBQyxrQkFBa0IsRUFBRSxFQUNyRSxLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQyxDQUN6QyxDQUNGO0tBQ0YsQ0FBQztDQUNIIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYW5pbWF0ZSwgc3RhdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyLCBBbmltYXRpb25UcmlnZ2VyTWV0YWRhdGEgfSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcbmltcG9ydCB7IEFuaW1hdGlvbkN1cnZlcywgQW5pbWF0aW9uRHVyYXRpb25zIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmV4cG9ydCBjb25zdCB0ZFNpZGVTaGVldEFuaW1hdGlvbnM6IHtcbiAgcmVhZG9ubHkgc2lkZVNoZWV0Q29udGFpbmVyOiBBbmltYXRpb25UcmlnZ2VyTWV0YWRhdGE7XG59ID0ge1xuICAvKiogQW5pbWF0aW9uIHRoYXQgaXMgYXBwbGllZCBvbiB0aGUgc2lkZS1zaGVldCBjb250YWluZXIgYnkgZGVmYXVsdC4gKi9cbiAgc2lkZVNoZWV0Q29udGFpbmVyOiB0cmlnZ2VyKCdzaWRlU2hlZXRDb250YWluZXInLCBbXG4gICAgc3RhdGUoJ3ZvaWQsIGV4aXQnLCBzdHlsZSh7IHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMTAwJSknIH0pKSxcbiAgICBzdGF0ZSgnZW50ZXInLCBzdHlsZSh7IHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMCUpJywgb3BhY2l0eTogMSB9KSksXG4gICAgdHJhbnNpdGlvbihcbiAgICAgICcqID0+IGVudGVyJyxcbiAgICAgIGFuaW1hdGUoXG4gICAgICAgIGAke0FuaW1hdGlvbkR1cmF0aW9ucy5FTlRFUklOR30gJHtBbmltYXRpb25DdXJ2ZXMuQUNDRUxFUkFUSU9OX0NVUlZFfWAsXG4gICAgICAgIHN0eWxlKHsgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgwKScsIG9wYWNpdHk6IDEgfSksXG4gICAgICApLFxuICAgICksXG4gICAgdHJhbnNpdGlvbihcbiAgICAgICcqID0+IHZvaWQsICogPT4gZXhpdCcsXG4gICAgICBhbmltYXRlKFxuICAgICAgICBgJHtBbmltYXRpb25EdXJhdGlvbnMuRVhJVElOR30gJHtBbmltYXRpb25DdXJ2ZXMuQUNDRUxFUkFUSU9OX0NVUlZFfWAsXG4gICAgICAgIHN0eWxlKHsgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgxMDAlKScgfSksXG4gICAgICApLFxuICAgICksXG4gIF0pLFxufTtcbiJdfQ==
|
@@ -0,0 +1,12 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview added by tsickle
|
3
|
+
* Generated from: side-sheet.config.ts
|
4
|
+
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
5
|
+
*/
|
6
|
+
import { MatDialogConfig } from '@angular/material/dialog';
|
7
|
+
/**
|
8
|
+
* @template D
|
9
|
+
*/
|
10
|
+
export class CovalentSideSheetConfig extends MatDialogConfig {
|
11
|
+
}
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1zaGVldC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vc3JjL3BsYXRmb3JtL2NvcmUvc2lkZS1zaGVldC8iLCJzb3VyY2VzIjpbInNpZGUtc2hlZXQuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDOzs7O0FBRTNELE1BQU0sT0FBTyx1QkFBaUMsU0FBUSxlQUFrQjtDQUFHIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWF0RGlhbG9nQ29uZmlnIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcblxuZXhwb3J0IGNsYXNzIENvdmFsZW50U2lkZVNoZWV0Q29uZmlnPEQgPSBhbnk+IGV4dGVuZHMgTWF0RGlhbG9nQ29uZmlnPEQ+IHt9XG4iXX0=
|