@dugararchit/flex-layout 13.0.0-dugararchit
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/README.md +7 -0
- package/_private-utils/angular-flex-layout-_private-utils.d.ts +5 -0
- package/_private-utils/auto-prefixer.d.ts +24 -0
- package/_private-utils/index.d.ts +10 -0
- package/_private-utils/layout-validator.d.ts +32 -0
- package/_private-utils/object-extend.d.ts +15 -0
- package/_private-utils/package.json +10 -0
- package/_private-utils/testing/angular-flex-layout-_private-utils-testing.d.ts +5 -0
- package/_private-utils/testing/custom-matchers.d.ts +65 -0
- package/_private-utils/testing/dom-tools.d.ts +47 -0
- package/_private-utils/testing/helpers.d.ts +24 -0
- package/_private-utils/testing/index.d.ts +10 -0
- package/_private-utils/testing/package.json +10 -0
- package/angular-flex-layout-13.0.0-beta.38.tgz +0 -0
- package/angular-flex-layout.d.ts +5 -0
- package/core/README.md +25 -0
- package/core/add-alias.d.ts +14 -0
- package/core/angular-flex-layout-core.d.ts +5 -0
- package/core/base/base2.d.ts +60 -0
- package/core/base/index.d.ts +8 -0
- package/core/basis-validator/basis-validator.d.ts +13 -0
- package/core/breakpoints/break-point-registry.d.ts +42 -0
- package/core/breakpoints/break-point.d.ts +14 -0
- package/core/breakpoints/break-points-token.d.ts +14 -0
- package/core/breakpoints/breakpoint-tools.d.ts +19 -0
- package/core/breakpoints/data/break-points.d.ts +12 -0
- package/core/breakpoints/data/orientation-break-points.d.ts +23 -0
- package/core/breakpoints/index.d.ts +12 -0
- package/core/browser-provider.d.ts +24 -0
- package/core/match-media/index.d.ts +9 -0
- package/core/match-media/match-media.d.ts +59 -0
- package/core/match-media/mock/mock-match-media.d.ts +92 -0
- package/core/media-change.d.ts +30 -0
- package/core/media-marshaller/media-marshaller.d.ts +123 -0
- package/core/media-marshaller/print-hook.d.ts +95 -0
- package/core/media-observer/index.d.ts +8 -0
- package/core/media-observer/media-observer.d.ts +115 -0
- package/core/media-trigger/index.d.ts +8 -0
- package/core/media-trigger/media-trigger.d.ts +73 -0
- package/core/module.d.ts +11 -0
- package/core/multiply/multiplier.d.ts +5 -0
- package/core/package.json +10 -0
- package/core/public-api.d.ts +25 -0
- package/core/sass/_layout-bp.scss +76 -0
- package/core/style-builder/style-builder.d.ts +21 -0
- package/core/style-utils/style-utils.d.ts +53 -0
- package/core/stylesheet-map/index.d.ts +8 -0
- package/core/stylesheet-map/stylesheet-map.d.ts +24 -0
- package/core/tokens/breakpoint-token.d.ts +10 -0
- package/core/tokens/index.d.ts +10 -0
- package/core/tokens/library-config.d.ts +26 -0
- package/core/tokens/server-token.d.ts +15 -0
- package/core/utils/array.d.ts +9 -0
- package/core/utils/index.d.ts +9 -0
- package/core/utils/sort.d.ts +15 -0
- package/esm2020/_private-utils/angular-flex-layout-_private-utils.mjs +5 -0
- package/esm2020/_private-utils/auto-prefixer.mjs +65 -0
- package/esm2020/_private-utils/index.mjs +11 -0
- package/esm2020/_private-utils/layout-validator.mjs +83 -0
- package/esm2020/_private-utils/object-extend.mjs +30 -0
- package/esm2020/_private-utils/testing/angular-flex-layout-_private-utils-testing.mjs +5 -0
- package/esm2020/_private-utils/testing/custom-matchers.mjs +201 -0
- package/esm2020/_private-utils/testing/dom-tools.mjs +101 -0
- package/esm2020/_private-utils/testing/helpers.mjs +43 -0
- package/esm2020/_private-utils/testing/index.mjs +11 -0
- package/esm2020/angular-flex-layout.mjs +5 -0
- package/esm2020/core/add-alias.mjs +23 -0
- package/esm2020/core/angular-flex-layout-core.mjs +5 -0
- package/esm2020/core/base/base2.mjs +131 -0
- package/esm2020/core/base/index.mjs +9 -0
- package/esm2020/core/basis-validator/basis-validator.mjs +48 -0
- package/esm2020/core/breakpoints/break-point-registry.mjs +76 -0
- package/esm2020/core/breakpoints/break-point.mjs +2 -0
- package/esm2020/core/breakpoints/break-points-token.mjs +30 -0
- package/esm2020/core/breakpoints/breakpoint-tools.mjs +53 -0
- package/esm2020/core/breakpoints/data/break-points.mjs +78 -0
- package/esm2020/core/breakpoints/data/orientation-break-points.mjs +40 -0
- package/esm2020/core/breakpoints/index.mjs +13 -0
- package/esm2020/core/browser-provider.mjs +41 -0
- package/esm2020/core/match-media/index.mjs +10 -0
- package/esm2020/core/match-media/match-media.mjs +186 -0
- package/esm2020/core/match-media/mock/mock-match-media.mjs +224 -0
- package/esm2020/core/media-change.mjs +25 -0
- package/esm2020/core/media-marshaller/media-marshaller.mjs +317 -0
- package/esm2020/core/media-marshaller/print-hook.mjs +265 -0
- package/esm2020/core/media-observer/index.mjs +9 -0
- package/esm2020/core/media-observer/media-observer.mjs +195 -0
- package/esm2020/core/media-trigger/index.mjs +9 -0
- package/esm2020/core/media-trigger/media-trigger.mjs +188 -0
- package/esm2020/core/module.mjs +27 -0
- package/esm2020/core/multiply/multiplier.mjs +16 -0
- package/esm2020/core/public-api.mjs +26 -0
- package/esm2020/core/style-builder/style-builder.mjs +15 -0
- package/esm2020/core/style-utils/style-utils.mjs +174 -0
- package/esm2020/core/stylesheet-map/index.mjs +9 -0
- package/esm2020/core/stylesheet-map/stylesheet-map.mjs +59 -0
- package/esm2020/core/tokens/breakpoint-token.mjs +13 -0
- package/esm2020/core/tokens/index.mjs +11 -0
- package/esm2020/core/tokens/library-config.mjs +30 -0
- package/esm2020/core/tokens/server-token.mjs +19 -0
- package/esm2020/core/utils/array.mjs +12 -0
- package/esm2020/core/utils/index.mjs +10 -0
- package/esm2020/core/utils/sort.mjs +20 -0
- package/esm2020/extended/angular-flex-layout-extended.mjs +5 -0
- package/esm2020/extended/class/class.mjs +88 -0
- package/esm2020/extended/img-src/img-src.mjs +106 -0
- package/esm2020/extended/module.mjs +45 -0
- package/esm2020/extended/public-api.mjs +13 -0
- package/esm2020/extended/show-hide/show-hide.mjs +176 -0
- package/esm2020/extended/style/style-transforms.mjs +76 -0
- package/esm2020/extended/style/style.mjs +130 -0
- package/esm2020/flex/angular-flex-layout-flex.mjs +5 -0
- package/esm2020/flex/flex/flex.mjs +291 -0
- package/esm2020/flex/flex-align/flex-align.mjs +80 -0
- package/esm2020/flex/flex-fill/flex-fill.mjs +50 -0
- package/esm2020/flex/flex-offset/flex-offset.mjs +121 -0
- package/esm2020/flex/flex-order/flex-order.mjs +66 -0
- package/esm2020/flex/layout/layout.mjs +86 -0
- package/esm2020/flex/layout-align/layout-align.mjs +194 -0
- package/esm2020/flex/layout-gap/layout-gap.mjs +282 -0
- package/esm2020/flex/module.mjs +62 -0
- package/esm2020/flex/public-api.mjs +17 -0
- package/esm2020/grid/align-columns/align-columns.mjs +137 -0
- package/esm2020/grid/align-rows/align-rows.mjs +119 -0
- package/esm2020/grid/angular-flex-layout-grid.mjs +5 -0
- package/esm2020/grid/area/area.mjs +67 -0
- package/esm2020/grid/areas/areas.mjs +86 -0
- package/esm2020/grid/auto/auto.mjs +89 -0
- package/esm2020/grid/column/column.mjs +67 -0
- package/esm2020/grid/columns/columns.mjs +96 -0
- package/esm2020/grid/gap/gap.mjs +85 -0
- package/esm2020/grid/grid-align/grid-align.mjs +111 -0
- package/esm2020/grid/module.mjs +73 -0
- package/esm2020/grid/public-api.mjs +20 -0
- package/esm2020/grid/row/row.mjs +67 -0
- package/esm2020/grid/rows/rows.mjs +96 -0
- package/esm2020/module.mjs +64 -0
- package/esm2020/public-api.mjs +20 -0
- package/esm2020/server/angular-flex-layout-server.mjs +5 -0
- package/esm2020/server/module.mjs +22 -0
- package/esm2020/server/public-api.mjs +10 -0
- package/esm2020/server/server-match-media.mjs +151 -0
- package/esm2020/server/server-provider.mjs +140 -0
- package/esm2020/version.mjs +11 -0
- package/extended/README.md +18 -0
- package/extended/angular-flex-layout-extended.d.ts +5 -0
- package/extended/class/class.d.ts +38 -0
- package/extended/img-src/img-src.d.ts +51 -0
- package/extended/module.d.ts +16 -0
- package/extended/package.json +10 -0
- package/extended/public-api.d.ts +12 -0
- package/extended/show-hide/show-hide.d.ts +61 -0
- package/extended/style/style-transforms.d.ts +36 -0
- package/extended/style/style.d.ts +45 -0
- package/fesm2015/angular-flex-layout-_private-utils-testing.mjs +357 -0
- package/fesm2015/angular-flex-layout-_private-utils-testing.mjs.map +1 -0
- package/fesm2015/angular-flex-layout-_private-utils.mjs +193 -0
- package/fesm2015/angular-flex-layout-_private-utils.mjs.map +1 -0
- package/fesm2015/angular-flex-layout-core.mjs +2331 -0
- package/fesm2015/angular-flex-layout-core.mjs.map +1 -0
- package/fesm2015/angular-flex-layout-extended.mjs +621 -0
- package/fesm2015/angular-flex-layout-extended.mjs.map +1 -0
- package/fesm2015/angular-flex-layout-flex.mjs +1206 -0
- package/fesm2015/angular-flex-layout-flex.mjs.map +1 -0
- package/fesm2015/angular-flex-layout-grid.mjs +1047 -0
- package/fesm2015/angular-flex-layout-grid.mjs.map +1 -0
- package/fesm2015/angular-flex-layout-server.mjs +324 -0
- package/fesm2015/angular-flex-layout-server.mjs.map +1 -0
- package/fesm2015/angular-flex-layout.mjs +94 -0
- package/fesm2015/angular-flex-layout.mjs.map +1 -0
- package/fesm2020/angular-flex-layout-_private-utils-testing.mjs +357 -0
- package/fesm2020/angular-flex-layout-_private-utils-testing.mjs.map +1 -0
- package/fesm2020/angular-flex-layout-_private-utils.mjs +192 -0
- package/fesm2020/angular-flex-layout-_private-utils.mjs.map +1 -0
- package/fesm2020/angular-flex-layout-core.mjs +2304 -0
- package/fesm2020/angular-flex-layout-core.mjs.map +1 -0
- package/fesm2020/angular-flex-layout-extended.mjs +612 -0
- package/fesm2020/angular-flex-layout-extended.mjs.map +1 -0
- package/fesm2020/angular-flex-layout-flex.mjs +1198 -0
- package/fesm2020/angular-flex-layout-flex.mjs.map +1 -0
- package/fesm2020/angular-flex-layout-grid.mjs +1047 -0
- package/fesm2020/angular-flex-layout-grid.mjs.map +1 -0
- package/fesm2020/angular-flex-layout-server.mjs +322 -0
- package/fesm2020/angular-flex-layout-server.mjs.map +1 -0
- package/fesm2020/angular-flex-layout.mjs +92 -0
- package/fesm2020/angular-flex-layout.mjs.map +1 -0
- package/flex/README.md +19 -0
- package/flex/angular-flex-layout-flex.d.ts +5 -0
- package/flex/flex/flex.d.ts +59 -0
- package/flex/flex-align/flex-align.d.ts +32 -0
- package/flex/flex-fill/flex-fill.d.ts +33 -0
- package/flex/flex-offset/flex-offset.d.ts +44 -0
- package/flex/flex-order/flex-order.d.ts +34 -0
- package/flex/layout/layout.d.ts +43 -0
- package/flex/layout-align/layout-align.d.ts +49 -0
- package/flex/layout-gap/layout-gap.d.ts +65 -0
- package/flex/module.d.ts +21 -0
- package/flex/package.json +10 -0
- package/flex/public-api.d.ts +16 -0
- package/grid/README.md +19 -0
- package/grid/align-columns/align-columns.d.ts +39 -0
- package/grid/align-rows/align-rows.d.ts +39 -0
- package/grid/angular-flex-layout-grid.d.ts +5 -0
- package/grid/area/area.d.ts +34 -0
- package/grid/areas/areas.d.ts +41 -0
- package/grid/auto/auto.d.ts +41 -0
- package/grid/column/column.d.ts +34 -0
- package/grid/columns/columns.d.ts +43 -0
- package/grid/gap/gap.d.ts +42 -0
- package/grid/grid-align/grid-align.d.ts +37 -0
- package/grid/module.d.ts +23 -0
- package/grid/package.json +10 -0
- package/grid/public-api.d.ts +19 -0
- package/grid/row/row.d.ts +34 -0
- package/grid/rows/rows.d.ts +43 -0
- package/module.d.ts +30 -0
- package/package.json +100 -0
- package/public-api.d.ts +18 -0
- package/server/README.md +23 -0
- package/server/angular-flex-layout-server.d.ts +5 -0
- package/server/module.d.ts +6 -0
- package/server/package.json +10 -0
- package/server/public-api.d.ts +9 -0
- package/server/server-match-media.d.ts +61 -0
- package/server/server-provider.d.ts +44 -0
- package/version.d.ts +10 -0
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { Inject, Injectable } from '@angular/core';
|
|
9
|
+
import { mergeAlias } from '../add-alias';
|
|
10
|
+
import { MediaChange } from '../media-change';
|
|
11
|
+
import { LAYOUT_CONFIG } from '../tokens/library-config';
|
|
12
|
+
import { sortDescendingPriority } from '../utils/sort';
|
|
13
|
+
import { DOCUMENT } from '@angular/common';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "../breakpoints/break-point-registry";
|
|
16
|
+
const PRINT = 'print';
|
|
17
|
+
export const BREAKPOINT_PRINT = {
|
|
18
|
+
alias: PRINT,
|
|
19
|
+
mediaQuery: PRINT,
|
|
20
|
+
priority: 1000
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* PrintHook - Use to intercept print MediaQuery activations and force
|
|
24
|
+
* layouts to render with the specified print alias/breakpoint
|
|
25
|
+
*
|
|
26
|
+
* Used in MediaMarshaller and MediaObserver
|
|
27
|
+
*/
|
|
28
|
+
export class PrintHook {
|
|
29
|
+
constructor(breakpoints, layoutConfig, _document) {
|
|
30
|
+
this.breakpoints = breakpoints;
|
|
31
|
+
this.layoutConfig = layoutConfig;
|
|
32
|
+
this._document = _document;
|
|
33
|
+
// registeredBeforeAfterPrintHooks tracks if we registered the `beforeprint`
|
|
34
|
+
// and `afterprint` event listeners.
|
|
35
|
+
this.registeredBeforeAfterPrintHooks = false;
|
|
36
|
+
// isPrintingBeforeAfterEvent is used to track if we are printing from within
|
|
37
|
+
// a `beforeprint` event handler. This prevents the typical `stopPrinting`
|
|
38
|
+
// form `interceptEvents` so that printing is not stopped while the dialog
|
|
39
|
+
// is still open. This is an extension of the `isPrinting` property on
|
|
40
|
+
// browsers which support `beforeprint` and `afterprint` events.
|
|
41
|
+
this.isPrintingBeforeAfterEvent = false;
|
|
42
|
+
this.beforePrintEventListeners = [];
|
|
43
|
+
this.afterPrintEventListeners = [];
|
|
44
|
+
this.formerActivations = null;
|
|
45
|
+
// Is this service currently in print mode
|
|
46
|
+
this.isPrinting = false;
|
|
47
|
+
this.queue = new PrintQueue();
|
|
48
|
+
this.deactivations = [];
|
|
49
|
+
}
|
|
50
|
+
/** Add 'print' mediaQuery: to listen for matchMedia activations */
|
|
51
|
+
withPrintQuery(queries) {
|
|
52
|
+
return [...queries, PRINT];
|
|
53
|
+
}
|
|
54
|
+
/** Is the MediaChange event for any 'print' @media */
|
|
55
|
+
isPrintEvent(e) {
|
|
56
|
+
return e.mediaQuery.startsWith(PRINT);
|
|
57
|
+
}
|
|
58
|
+
/** What is the desired mqAlias to use while printing? */
|
|
59
|
+
get printAlias() {
|
|
60
|
+
return [...(this.layoutConfig.printWithBreakpoints ?? [])];
|
|
61
|
+
}
|
|
62
|
+
/** Lookup breakpoints associated with print aliases. */
|
|
63
|
+
get printBreakPoints() {
|
|
64
|
+
return this.printAlias
|
|
65
|
+
.map(alias => this.breakpoints.findByAlias(alias))
|
|
66
|
+
.filter(bp => bp !== null);
|
|
67
|
+
}
|
|
68
|
+
/** Lookup breakpoint associated with mediaQuery */
|
|
69
|
+
getEventBreakpoints({ mediaQuery }) {
|
|
70
|
+
const bp = this.breakpoints.findByQuery(mediaQuery);
|
|
71
|
+
const list = bp ? [...this.printBreakPoints, bp] : this.printBreakPoints;
|
|
72
|
+
return list.sort(sortDescendingPriority);
|
|
73
|
+
}
|
|
74
|
+
/** Update event with printAlias mediaQuery information */
|
|
75
|
+
updateEvent(event) {
|
|
76
|
+
let bp = this.breakpoints.findByQuery(event.mediaQuery);
|
|
77
|
+
if (this.isPrintEvent(event)) {
|
|
78
|
+
// Reset from 'print' to first (highest priority) print breakpoint
|
|
79
|
+
bp = this.getEventBreakpoints(event)[0];
|
|
80
|
+
event.mediaQuery = bp?.mediaQuery ?? '';
|
|
81
|
+
}
|
|
82
|
+
return mergeAlias(event, bp);
|
|
83
|
+
}
|
|
84
|
+
// registerBeforeAfterPrintHooks registers a `beforeprint` event hook so we can
|
|
85
|
+
// trigger print styles synchronously and apply proper layout styles.
|
|
86
|
+
// It is a noop if the hooks have already been registered or if the document's
|
|
87
|
+
// `defaultView` is not available.
|
|
88
|
+
registerBeforeAfterPrintHooks(target) {
|
|
89
|
+
// `defaultView` may be null when rendering on the server or in other contexts.
|
|
90
|
+
if (!this._document.defaultView || this.registeredBeforeAfterPrintHooks) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
this.registeredBeforeAfterPrintHooks = true;
|
|
94
|
+
const beforePrintListener = () => {
|
|
95
|
+
// If we aren't already printing, start printing and update the styles as
|
|
96
|
+
// if there was a regular print `MediaChange`(from matchMedia).
|
|
97
|
+
if (!this.isPrinting) {
|
|
98
|
+
this.isPrintingBeforeAfterEvent = true;
|
|
99
|
+
this.startPrinting(target, this.getEventBreakpoints(new MediaChange(true, PRINT)));
|
|
100
|
+
target.updateStyles();
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
const afterPrintListener = () => {
|
|
104
|
+
// If we aren't already printing, start printing and update the styles as
|
|
105
|
+
// if there was a regular print `MediaChange`(from matchMedia).
|
|
106
|
+
this.isPrintingBeforeAfterEvent = false;
|
|
107
|
+
if (this.isPrinting) {
|
|
108
|
+
this.stopPrinting(target);
|
|
109
|
+
target.updateStyles();
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
// Could we have teardown logic to remove if there are no print listeners being used?
|
|
113
|
+
this._document.defaultView.addEventListener('beforeprint', beforePrintListener);
|
|
114
|
+
this._document.defaultView.addEventListener('afterprint', afterPrintListener);
|
|
115
|
+
this.beforePrintEventListeners.push(beforePrintListener);
|
|
116
|
+
this.afterPrintEventListeners.push(afterPrintListener);
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Prepare RxJS tap operator with partial application
|
|
120
|
+
* @return pipeable tap predicate
|
|
121
|
+
*/
|
|
122
|
+
interceptEvents(target) {
|
|
123
|
+
return (event) => {
|
|
124
|
+
if (this.isPrintEvent(event)) {
|
|
125
|
+
if (event.matches && !this.isPrinting) {
|
|
126
|
+
this.startPrinting(target, this.getEventBreakpoints(event));
|
|
127
|
+
target.updateStyles();
|
|
128
|
+
}
|
|
129
|
+
else if (!event.matches && this.isPrinting && !this.isPrintingBeforeAfterEvent) {
|
|
130
|
+
this.stopPrinting(target);
|
|
131
|
+
target.updateStyles();
|
|
132
|
+
}
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
this.collectActivations(target, event);
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
/** Stop mediaChange event propagation in event streams */
|
|
139
|
+
blockPropagation() {
|
|
140
|
+
return (event) => {
|
|
141
|
+
return !(this.isPrinting || this.isPrintEvent(event));
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Save current activateBreakpoints (for later restore)
|
|
146
|
+
* and substitute only the printAlias breakpoint
|
|
147
|
+
*/
|
|
148
|
+
startPrinting(target, bpList) {
|
|
149
|
+
this.isPrinting = true;
|
|
150
|
+
this.formerActivations = target.activatedBreakpoints;
|
|
151
|
+
target.activatedBreakpoints = this.queue.addPrintBreakpoints(bpList);
|
|
152
|
+
}
|
|
153
|
+
/** For any print de-activations, reset the entire print queue */
|
|
154
|
+
stopPrinting(target) {
|
|
155
|
+
target.activatedBreakpoints = this.deactivations;
|
|
156
|
+
this.deactivations = [];
|
|
157
|
+
this.formerActivations = null;
|
|
158
|
+
this.queue.clear();
|
|
159
|
+
this.isPrinting = false;
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* To restore pre-Print Activations, we must capture the proper
|
|
163
|
+
* list of breakpoint activations BEFORE print starts. OnBeforePrint()
|
|
164
|
+
* is supported; so 'print' mediaQuery activations are used as a fallback
|
|
165
|
+
* in browsers without `beforeprint` support.
|
|
166
|
+
*
|
|
167
|
+
* > But activated breakpoints are deactivated BEFORE 'print' activation.
|
|
168
|
+
*
|
|
169
|
+
* Let's capture all de-activations using the following logic:
|
|
170
|
+
*
|
|
171
|
+
* When not printing:
|
|
172
|
+
* - clear cache when activating non-print breakpoint
|
|
173
|
+
* - update cache (and sort) when deactivating
|
|
174
|
+
*
|
|
175
|
+
* When printing:
|
|
176
|
+
* - sort and save when starting print
|
|
177
|
+
* - restore as activatedTargets and clear when stop printing
|
|
178
|
+
*/
|
|
179
|
+
collectActivations(target, event) {
|
|
180
|
+
if (!this.isPrinting || this.isPrintingBeforeAfterEvent) {
|
|
181
|
+
if (!this.isPrintingBeforeAfterEvent) {
|
|
182
|
+
// Only clear deactivations if we aren't printing from a `beforeprint` event.
|
|
183
|
+
// Otherwise, this will clear before `stopPrinting()` is called to restore
|
|
184
|
+
// the pre-Print Activations.
|
|
185
|
+
this.deactivations = [];
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
if (!event.matches) {
|
|
189
|
+
const bp = this.breakpoints.findByQuery(event.mediaQuery);
|
|
190
|
+
// Deactivating a breakpoint
|
|
191
|
+
if (bp) {
|
|
192
|
+
const hasFormerBp = this.formerActivations && this.formerActivations.includes(bp);
|
|
193
|
+
const wasActivated = !this.formerActivations && target.activatedBreakpoints.includes(bp);
|
|
194
|
+
const shouldDeactivate = hasFormerBp || wasActivated;
|
|
195
|
+
if (shouldDeactivate) {
|
|
196
|
+
this.deactivations.push(bp);
|
|
197
|
+
this.deactivations.sort(sortDescendingPriority);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
/** Teardown logic for the service. */
|
|
204
|
+
ngOnDestroy() {
|
|
205
|
+
if (this._document.defaultView) {
|
|
206
|
+
this.beforePrintEventListeners.forEach(l => this._document.defaultView.removeEventListener('beforeprint', l));
|
|
207
|
+
this.afterPrintEventListeners.forEach(l => this._document.defaultView.removeEventListener('afterprint', l));
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
PrintHook.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: PrintHook, deps: [{ token: i1.BreakPointRegistry }, { token: LAYOUT_CONFIG }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
212
|
+
PrintHook.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: PrintHook, providedIn: 'root' });
|
|
213
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: PrintHook, decorators: [{
|
|
214
|
+
type: Injectable,
|
|
215
|
+
args: [{ providedIn: 'root' }]
|
|
216
|
+
}], ctorParameters: function () { return [{ type: i1.BreakPointRegistry }, { type: undefined, decorators: [{
|
|
217
|
+
type: Inject,
|
|
218
|
+
args: [LAYOUT_CONFIG]
|
|
219
|
+
}] }, { type: undefined, decorators: [{
|
|
220
|
+
type: Inject,
|
|
221
|
+
args: [DOCUMENT]
|
|
222
|
+
}] }]; } });
|
|
223
|
+
// ************************************************************************
|
|
224
|
+
// Internal Utility class 'PrintQueue'
|
|
225
|
+
// ************************************************************************
|
|
226
|
+
/**
|
|
227
|
+
* Utility class to manage print breakpoints + activatedBreakpoints
|
|
228
|
+
* with correct sorting WHILE printing
|
|
229
|
+
*/
|
|
230
|
+
class PrintQueue {
|
|
231
|
+
constructor() {
|
|
232
|
+
/** Sorted queue with prioritized print breakpoints */
|
|
233
|
+
this.printBreakpoints = [];
|
|
234
|
+
}
|
|
235
|
+
addPrintBreakpoints(bpList) {
|
|
236
|
+
bpList.push(BREAKPOINT_PRINT);
|
|
237
|
+
bpList.sort(sortDescendingPriority);
|
|
238
|
+
bpList.forEach(bp => this.addBreakpoint(bp));
|
|
239
|
+
return this.printBreakpoints;
|
|
240
|
+
}
|
|
241
|
+
/** Add Print breakpoint to queue */
|
|
242
|
+
addBreakpoint(bp) {
|
|
243
|
+
if (!!bp) {
|
|
244
|
+
const bpInList = this.printBreakpoints.find(it => it.mediaQuery === bp.mediaQuery);
|
|
245
|
+
if (bpInList === undefined) {
|
|
246
|
+
// If this is a `printAlias` breakpoint, then append. If a true 'print' breakpoint,
|
|
247
|
+
// register as highest priority in the queue
|
|
248
|
+
this.printBreakpoints = isPrintBreakPoint(bp) ? [bp, ...this.printBreakpoints]
|
|
249
|
+
: [...this.printBreakpoints, bp];
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
/** Restore original activated breakpoints and clear internal caches */
|
|
254
|
+
clear() {
|
|
255
|
+
this.printBreakpoints = [];
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
// ************************************************************************
|
|
259
|
+
// Internal Utility methods
|
|
260
|
+
// ************************************************************************
|
|
261
|
+
/** Only support intercept queueing if the Breakpoint is a print @media query */
|
|
262
|
+
function isPrintBreakPoint(bp) {
|
|
263
|
+
return bp?.mediaQuery.startsWith(PRINT) ?? false;
|
|
264
|
+
}
|
|
265
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"print-hook.js","sourceRoot":"","sources":["../../../../../../projects/libs/flex-layout/core/media-marshaller/print-hook.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AACH,OAAO,EAAC,MAAM,EAAE,UAAU,EAAY,MAAM,eAAe,CAAC;AAE5D,OAAO,EAAC,UAAU,EAAC,MAAM,cAAc,CAAC;AACxC,OAAO,EAAC,WAAW,EAAC,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAC,aAAa,EAAsB,MAAM,0BAA0B,CAAC;AAE5E,OAAO,EAAC,sBAAsB,EAAC,MAAM,eAAe,CAAC;AACrD,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;;;AAUzC,MAAM,KAAK,GAAG,OAAO,CAAC;AACtB,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,KAAK,EAAE,KAAK;IACZ,UAAU,EAAE,KAAK;IACjB,QAAQ,EAAE,IAAI;CACf,CAAC;AAEF;;;;;GAKG;AAEH,MAAM,OAAO,SAAS;IACpB,YACc,WAA+B,EACR,YAAiC,EACtC,SAAc;QAFhC,gBAAW,GAAX,WAAW,CAAoB;QACR,iBAAY,GAAZ,YAAY,CAAqB;QACtC,cAAS,GAAT,SAAS,CAAK;QA+C9C,4EAA4E;QAC5E,qCAAqC;QAC7B,oCAA+B,GAAG,KAAK,CAAC;QAEhD,6EAA6E;QAC7E,0EAA0E;QAC1E,0EAA0E;QAC1E,sEAAsE;QACtE,gEAAgE;QACxD,+BAA0B,GAAG,KAAK,CAAC;QAEnC,8BAAyB,GAAe,EAAE,CAAC;QAC3C,6BAAwB,GAAe,EAAE,CAAC;QAE1C,sBAAiB,GAA6B,IAAI,CAAC;QA+I3D,0CAA0C;QAClC,eAAU,GAAG,KAAK,CAAC;QACnB,UAAK,GAAG,IAAI,UAAU,EAAE,CAAC;QACzB,kBAAa,GAAiB,EAAE,CAAC;IA9MzC,CAAC;IAED,mEAAmE;IACnE,cAAc,CAAC,OAAiB;QAC9B,OAAO,CAAC,GAAG,OAAO,EAAE,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,sDAAsD;IACtD,YAAY,CAAC,CAAc;QACzB,OAAO,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,yDAAyD;IACzD,IAAI,UAAU;QACZ,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,oBAAoB,IAAI,EAAE,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,wDAAwD;IACxD,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,UAAU;aACjB,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aACjD,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,IAAI,CAAiB,CAAC;IACjD,CAAC;IAED,mDAAmD;IACnD,mBAAmB,CAAC,EAAC,UAAU,EAAc;QAC3C,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QACpD,MAAM,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC;QAEzE,OAAO,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC3C,CAAC;IAED,0DAA0D;IAC1D,WAAW,CAAC,KAAkB;QAC5B,IAAI,EAAE,GAAuB,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAE5E,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE;YAC5B,kEAAkE;YAClE,EAAE,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YACxC,KAAK,CAAC,UAAU,GAAG,EAAE,EAAE,UAAU,IAAI,EAAE,CAAC;SACzC;QAED,OAAO,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IAC/B,CAAC;IAmBD,+EAA+E;IAC/E,qEAAqE;IACrE,8EAA8E;IAC9E,kCAAkC;IAClC,6BAA6B,CAAC,MAAkB;QAC9C,+EAA+E;QAC/E,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,IAAI,IAAI,CAAC,+BAA+B,EAAE;YACvE,OAAO;SACR;QAED,IAAI,CAAC,+BAA+B,GAAG,IAAI,CAAC;QAE5C,MAAM,mBAAmB,GAAG,GAAG,EAAE;YAC/B,yEAAyE;YACzE,+DAA+D;YAC/D,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;gBACpB,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC;gBACvC,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;gBACnF,MAAM,CAAC,YAAY,EAAE,CAAC;aACvB;QACH,CAAC,CAAC;QAEF,MAAM,kBAAkB,GAAG,GAAG,EAAE;YAC9B,yEAAyE;YACzE,+DAA+D;YAC/D,IAAI,CAAC,0BAA0B,GAAG,KAAK,CAAC;YACxC,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;gBAC1B,MAAM,CAAC,YAAY,EAAE,CAAC;aACvB;QACH,CAAC,CAAC;QAEF,qFAAqF;QACrF,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,gBAAgB,CAAC,aAAa,EAAE,mBAAmB,CAAC,CAAC;QAChF,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,gBAAgB,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAE9E,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACzD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IACzD,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,MAAkB;QAChC,OAAO,CAAC,KAAkB,EAAE,EAAE;YAC5B,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE;gBAC5B,IAAI,KAAK,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;oBACrC,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;oBAC5D,MAAM,CAAC,YAAY,EAAE,CAAC;iBACvB;qBAAM,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,0BAA0B,EAAE;oBAChF,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;oBAC1B,MAAM,CAAC,YAAY,EAAE,CAAC;iBACvB;gBAED,OAAO;aACR;YAED,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACzC,CAAC,CAAC;IACJ,CAAC;IAED,0DAA0D;IAC1D,gBAAgB;QACd,OAAO,CAAC,KAAkB,EAAW,EAAE;YACrC,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;QACxD,CAAC,CAAC;IACJ,CAAC;IAED;;;OAGG;IACO,aAAa,CAAC,MAAkB,EAAE,MAA4B;QACtE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,oBAAoB,CAAC;QACrD,MAAM,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;IACvE,CAAC;IAED,iEAAiE;IACvD,YAAY,CAAC,MAAkB;QACvC,MAAM,CAAC,oBAAoB,GAAG,IAAI,CAAC,aAAa,CAAC;QACjD,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;QACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACH,kBAAkB,CAAC,MAAkB,EAAE,KAAkB;QACvD,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,0BAA0B,EAAE;YACvD,IAAI,CAAC,IAAI,CAAC,0BAA0B,EAAE;gBACpC,6EAA6E;gBAC7E,0EAA0E;gBAC1E,6BAA6B;gBAC7B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;gBAExB,OAAO;aACR;YAED,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;gBAClB,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;gBAC1D,4BAA4B;gBAC5B,IAAI,EAAE,EAAE;oBACN,MAAM,WAAW,GAAG,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;oBAClF,MAAM,YAAY,GAAG,CAAC,IAAI,CAAC,iBAAiB,IAAI,MAAM,CAAC,oBAAoB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;oBACzF,MAAM,gBAAgB,GAAG,WAAW,IAAI,YAAY,CAAC;oBACrD,IAAI,gBAAgB,EAAE;wBACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;wBAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;qBACjD;iBACF;aACF;SACF;IACH,CAAC;IAED,sCAAsC;IACtC,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE;YAC9B,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,mBAAmB,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9G,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;SAC7G;IACH,CAAC;;sGA9MU,SAAS,oDAGR,aAAa,aACb,QAAQ;0GAJT,SAAS,cADG,MAAM;2FAClB,SAAS;kBADrB,UAAU;mBAAC,EAAC,UAAU,EAAE,MAAM,EAAC;;0BAIzB,MAAM;2BAAC,aAAa;;0BACpB,MAAM;2BAAC,QAAQ;;AAkNtB,2EAA2E;AAC3E,sCAAsC;AACtC,2EAA2E;AAE3E;;;GAGG;AACH,MAAM,UAAU;IAAhB;QACE,sDAAsD;QACtD,qBAAgB,GAAiB,EAAE,CAAC;IA4BtC,CAAC;IA1BC,mBAAmB,CAAC,MAA4B;QAC9C,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC9B,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACpC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC;QAE7C,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAED,oCAAoC;IACpC,aAAa,CAAC,EAAsB;QAClC,IAAI,CAAC,CAAC,EAAE,EAAE;YACR,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,KAAK,EAAE,CAAC,UAAU,CAAC,CAAC;YAEnF,IAAI,QAAQ,KAAK,SAAS,EAAE;gBAC1B,mFAAmF;gBACnF,4CAA4C;gBAC5C,IAAI,CAAC,gBAAgB,GAAG,iBAAiB,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC;oBAC1E,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC;aACtC;SACF;IACH,CAAC;IAED,uEAAuE;IACvE,KAAK;QACH,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC7B,CAAC;CACF;AAED,2EAA2E;AAC3E,2BAA2B;AAC3B,2EAA2E;AAE3E,gFAAgF;AAChF,SAAS,iBAAiB,CAAC,EAAsB;IAC/C,OAAO,EAAE,EAAE,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC;AACnD,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {Inject, Injectable, OnDestroy} from '@angular/core';\n\nimport {mergeAlias} from '../add-alias';\nimport {MediaChange} from '../media-change';\nimport {BreakPoint} from '../breakpoints/break-point';\nimport {LAYOUT_CONFIG, LayoutConfigOptions} from '../tokens/library-config';\nimport {BreakPointRegistry, OptionalBreakPoint} from '../breakpoints/break-point-registry';\nimport {sortDescendingPriority} from '../utils/sort';\nimport {DOCUMENT} from '@angular/common';\n\n/**\n * Interface to apply PrintHook to call anonymous `target.updateStyles()`\n */\nexport interface HookTarget {\n  activatedBreakpoints: BreakPoint[];\n  updateStyles(): void;\n}\n\nconst PRINT = 'print';\nexport const BREAKPOINT_PRINT = {\n  alias: PRINT,\n  mediaQuery: PRINT,\n  priority: 1000\n};\n\n/**\n * PrintHook - Use to intercept print MediaQuery activations and force\n *             layouts to render with the specified print alias/breakpoint\n *\n * Used in MediaMarshaller and MediaObserver\n */\n@Injectable({providedIn: 'root'})\nexport class PrintHook implements OnDestroy {\n  constructor(\n      protected breakpoints: BreakPointRegistry,\n      @Inject(LAYOUT_CONFIG) protected layoutConfig: LayoutConfigOptions,\n      @Inject(DOCUMENT) protected _document: any) {\n  }\n\n  /** Add 'print' mediaQuery: to listen for matchMedia activations */\n  withPrintQuery(queries: string[]): string[] {\n    return [...queries, PRINT];\n  }\n\n  /** Is the MediaChange event for any 'print' @media */\n  isPrintEvent(e: MediaChange): boolean {\n    return e.mediaQuery.startsWith(PRINT);\n  }\n\n  /** What is the desired mqAlias to use while printing? */\n  get printAlias(): string[] {\n    return [...(this.layoutConfig.printWithBreakpoints ?? [])];\n  }\n\n  /** Lookup breakpoints associated with print aliases. */\n  get printBreakPoints(): BreakPoint[] {\n    return this.printAlias\n        .map(alias => this.breakpoints.findByAlias(alias))\n        .filter(bp => bp !== null) as BreakPoint[];\n  }\n\n  /** Lookup breakpoint associated with mediaQuery */\n  getEventBreakpoints({mediaQuery}: MediaChange): BreakPoint[] {\n    const bp = this.breakpoints.findByQuery(mediaQuery);\n    const list = bp ? [...this.printBreakPoints, bp] : this.printBreakPoints;\n\n    return list.sort(sortDescendingPriority);\n  }\n\n  /** Update event with printAlias mediaQuery information */\n  updateEvent(event: MediaChange): MediaChange {\n    let bp: OptionalBreakPoint = this.breakpoints.findByQuery(event.mediaQuery);\n\n    if (this.isPrintEvent(event)) {\n      // Reset from 'print' to first (highest priority) print breakpoint\n      bp = this.getEventBreakpoints(event)[0];\n      event.mediaQuery = bp?.mediaQuery ?? '';\n    }\n\n    return mergeAlias(event, bp);\n  }\n\n\n  // registeredBeforeAfterPrintHooks tracks if we registered the `beforeprint`\n  //  and `afterprint` event listeners.\n  private registeredBeforeAfterPrintHooks = false;\n\n  // isPrintingBeforeAfterEvent is used to track if we are printing from within\n  // a `beforeprint` event handler. This prevents the typical `stopPrinting`\n  // form `interceptEvents` so that printing is not stopped while the dialog\n  // is still open. This is an extension of the `isPrinting` property on\n  // browsers which support `beforeprint` and `afterprint` events.\n  private isPrintingBeforeAfterEvent = false;\n\n  private beforePrintEventListeners: Function[] = [];\n  private afterPrintEventListeners: Function[] = [];\n\n  private formerActivations: Array<BreakPoint> | null = null;\n\n  // registerBeforeAfterPrintHooks registers a `beforeprint` event hook so we can\n  // trigger print styles synchronously and apply proper layout styles.\n  // It is a noop if the hooks have already been registered or if the document's\n  // `defaultView` is not available.\n  registerBeforeAfterPrintHooks(target: HookTarget) {\n    // `defaultView` may be null when rendering on the server or in other contexts.\n    if (!this._document.defaultView || this.registeredBeforeAfterPrintHooks) {\n      return;\n    }\n\n    this.registeredBeforeAfterPrintHooks = true;\n\n    const beforePrintListener = () => {\n      // If we aren't already printing, start printing and update the styles as\n      // if there was a regular print `MediaChange`(from matchMedia).\n      if (!this.isPrinting) {\n        this.isPrintingBeforeAfterEvent = true;\n        this.startPrinting(target, this.getEventBreakpoints(new MediaChange(true, PRINT)));\n        target.updateStyles();\n      }\n    };\n\n    const afterPrintListener = () => {\n      // If we aren't already printing, start printing and update the styles as\n      // if there was a regular print `MediaChange`(from matchMedia).\n      this.isPrintingBeforeAfterEvent = false;\n      if (this.isPrinting) {\n        this.stopPrinting(target);\n        target.updateStyles();\n      }\n    };\n\n    // Could we have teardown logic to remove if there are no print listeners being used?\n    this._document.defaultView.addEventListener('beforeprint', beforePrintListener);\n    this._document.defaultView.addEventListener('afterprint', afterPrintListener);\n\n    this.beforePrintEventListeners.push(beforePrintListener);\n    this.afterPrintEventListeners.push(afterPrintListener);\n  }\n\n  /**\n   * Prepare RxJS tap operator with partial application\n   * @return pipeable tap predicate\n   */\n  interceptEvents(target: HookTarget) {\n    return (event: MediaChange) => {\n      if (this.isPrintEvent(event)) {\n        if (event.matches && !this.isPrinting) {\n          this.startPrinting(target, this.getEventBreakpoints(event));\n          target.updateStyles();\n        } else if (!event.matches && this.isPrinting && !this.isPrintingBeforeAfterEvent) {\n          this.stopPrinting(target);\n          target.updateStyles();\n        }\n\n        return;\n      }\n\n      this.collectActivations(target, event);\n    };\n  }\n\n  /** Stop mediaChange event propagation in event streams */\n  blockPropagation() {\n    return (event: MediaChange): boolean => {\n      return !(this.isPrinting || this.isPrintEvent(event));\n    };\n  }\n\n  /**\n   * Save current activateBreakpoints (for later restore)\n   * and substitute only the printAlias breakpoint\n   */\n  protected startPrinting(target: HookTarget, bpList: OptionalBreakPoint[]) {\n    this.isPrinting = true;\n    this.formerActivations = target.activatedBreakpoints;\n    target.activatedBreakpoints = this.queue.addPrintBreakpoints(bpList);\n  }\n\n  /** For any print de-activations, reset the entire print queue */\n  protected stopPrinting(target: HookTarget) {\n    target.activatedBreakpoints = this.deactivations;\n    this.deactivations = [];\n    this.formerActivations = null;\n    this.queue.clear();\n    this.isPrinting = false;\n  }\n\n  /**\n   * To restore pre-Print Activations, we must capture the proper\n   * list of breakpoint activations BEFORE print starts. OnBeforePrint()\n   * is supported; so 'print' mediaQuery activations are used as a fallback\n   * in browsers without `beforeprint` support.\n   *\n   * >  But activated breakpoints are deactivated BEFORE 'print' activation.\n   *\n   * Let's capture all de-activations using the following logic:\n   *\n   *  When not printing:\n   *    - clear cache when activating non-print breakpoint\n   *    - update cache (and sort) when deactivating\n   *\n   *  When printing:\n   *    - sort and save when starting print\n   *    - restore as activatedTargets and clear when stop printing\n   */\n  collectActivations(target: HookTarget, event: MediaChange) {\n    if (!this.isPrinting || this.isPrintingBeforeAfterEvent) {\n      if (!this.isPrintingBeforeAfterEvent) {\n        // Only clear deactivations if we aren't printing from a `beforeprint` event.\n        // Otherwise, this will clear before `stopPrinting()` is called to restore\n        // the pre-Print Activations.\n        this.deactivations = [];\n\n        return;\n      }\n\n      if (!event.matches) {\n        const bp = this.breakpoints.findByQuery(event.mediaQuery);\n        // Deactivating a breakpoint\n        if (bp) {\n          const hasFormerBp = this.formerActivations && this.formerActivations.includes(bp);\n          const wasActivated = !this.formerActivations && target.activatedBreakpoints.includes(bp);\n          const shouldDeactivate = hasFormerBp || wasActivated;\n          if (shouldDeactivate) {\n            this.deactivations.push(bp);\n            this.deactivations.sort(sortDescendingPriority);\n          }\n        }\n      }\n    }\n  }\n\n  /** Teardown logic for the service. */\n  ngOnDestroy() {\n    if (this._document.defaultView) {\n      this.beforePrintEventListeners.forEach(l => this._document.defaultView.removeEventListener('beforeprint', l));\n      this.afterPrintEventListeners.forEach(l => this._document.defaultView.removeEventListener('afterprint', l));\n    }\n  }\n\n  // Is this service currently in print mode\n  private isPrinting = false;\n  private queue = new PrintQueue();\n  private deactivations: BreakPoint[] = [];\n}\n\n// ************************************************************************\n// Internal Utility class 'PrintQueue'\n// ************************************************************************\n\n/**\n * Utility class to manage print breakpoints + activatedBreakpoints\n * with correct sorting WHILE printing\n */\nclass PrintQueue {\n  /** Sorted queue with prioritized print breakpoints */\n  printBreakpoints: BreakPoint[] = [];\n\n  addPrintBreakpoints(bpList: OptionalBreakPoint[]): BreakPoint[] {\n    bpList.push(BREAKPOINT_PRINT);\n    bpList.sort(sortDescendingPriority);\n    bpList.forEach(bp => this.addBreakpoint(bp));\n\n    return this.printBreakpoints;\n  }\n\n  /** Add Print breakpoint to queue */\n  addBreakpoint(bp: OptionalBreakPoint) {\n    if (!!bp) {\n      const bpInList = this.printBreakpoints.find(it => it.mediaQuery === bp.mediaQuery);\n\n      if (bpInList === undefined) {\n        // If this is a `printAlias` breakpoint, then append. If a true 'print' breakpoint,\n        // register as highest priority in the queue\n        this.printBreakpoints = isPrintBreakPoint(bp) ? [bp, ...this.printBreakpoints]\n            : [...this.printBreakpoints, bp];\n      }\n    }\n  }\n\n  /** Restore original activated breakpoints and clear internal caches */\n  clear() {\n    this.printBreakpoints = [];\n  }\n}\n\n// ************************************************************************\n// Internal Utility methods\n// ************************************************************************\n\n/** Only support intercept queueing if the Breakpoint is a print @media query */\nfunction isPrintBreakPoint(bp: OptionalBreakPoint): boolean {\n  return bp?.mediaQuery.startsWith(PRINT) ?? false;\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
export * from './media-observer';
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWJzL2ZsZXgtbGF5b3V0L2NvcmUvbWVkaWEtb2JzZXJ2ZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL21lZGlhLW9ic2VydmVyJztcbiJdfQ==
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { Injectable } from '@angular/core';
|
|
9
|
+
import { Subject, asapScheduler, of } from 'rxjs';
|
|
10
|
+
import { debounceTime, distinctUntilChanged, filter, map, switchMap, takeUntil, } from 'rxjs/operators';
|
|
11
|
+
import { mergeAlias } from '../add-alias';
|
|
12
|
+
import { MediaChange } from '../media-change';
|
|
13
|
+
import { sortDescendingPriority } from '../utils/sort';
|
|
14
|
+
import { coerceArray } from '../utils/array';
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
import * as i1 from "../breakpoints/break-point-registry";
|
|
17
|
+
import * as i2 from "../match-media/match-media";
|
|
18
|
+
import * as i3 from "../media-marshaller/print-hook";
|
|
19
|
+
/**
|
|
20
|
+
* MediaObserver enables applications to listen for 1..n mediaQuery activations and to determine
|
|
21
|
+
* if a mediaQuery is currently activated.
|
|
22
|
+
*
|
|
23
|
+
* Since a breakpoint change will first deactivate 1...n mediaQueries and then possibly activate
|
|
24
|
+
* 1..n mediaQueries, the MediaObserver will debounce notifications and report ALL *activations*
|
|
25
|
+
* in 1 event notification. The reported activations will be sorted in descending priority order.
|
|
26
|
+
*
|
|
27
|
+
* This class uses the BreakPoint Registry to inject alias information into the raw MediaChange
|
|
28
|
+
* notification. For custom mediaQuery notifications, alias information will not be injected and
|
|
29
|
+
* those fields will be ''.
|
|
30
|
+
*
|
|
31
|
+
* Note: Developers should note that only mediaChange activations (not de-activations)
|
|
32
|
+
* are announced by the MediaObserver.
|
|
33
|
+
*
|
|
34
|
+
* @usage
|
|
35
|
+
*
|
|
36
|
+
* // RxJS
|
|
37
|
+
* import { filter } from 'rxjs/operators';
|
|
38
|
+
* import { MediaObserver } from '@angular/flex-layout';
|
|
39
|
+
*
|
|
40
|
+
* @Component({ ... })
|
|
41
|
+
* export class AppComponent {
|
|
42
|
+
* status: string = '';
|
|
43
|
+
*
|
|
44
|
+
* constructor(mediaObserver: MediaObserver) {
|
|
45
|
+
* const media$ = mediaObserver.asObservable().pipe(
|
|
46
|
+
* filter((changes: MediaChange[]) => true) // silly noop filter
|
|
47
|
+
* );
|
|
48
|
+
*
|
|
49
|
+
* media$.subscribe((changes: MediaChange[]) => {
|
|
50
|
+
* let status = '';
|
|
51
|
+
* changes.forEach( change => {
|
|
52
|
+
* status += `'${change.mqAlias}' = (${change.mediaQuery}) <br/>` ;
|
|
53
|
+
* });
|
|
54
|
+
* this.status = status;
|
|
55
|
+
* });
|
|
56
|
+
*
|
|
57
|
+
* }
|
|
58
|
+
* }
|
|
59
|
+
*/
|
|
60
|
+
export class MediaObserver {
|
|
61
|
+
constructor(breakpoints, matchMedia, hook) {
|
|
62
|
+
this.breakpoints = breakpoints;
|
|
63
|
+
this.matchMedia = matchMedia;
|
|
64
|
+
this.hook = hook;
|
|
65
|
+
/** Filter MediaChange notifications for overlapping breakpoints */
|
|
66
|
+
this.filterOverlaps = false;
|
|
67
|
+
this.destroyed$ = new Subject();
|
|
68
|
+
this._media$ = this.watchActivations();
|
|
69
|
+
this.media$ = this._media$.pipe(filter((changes) => changes.length > 0), map((changes) => changes[0]));
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Completes the active subject, signalling to all complete for all
|
|
73
|
+
* MediaObserver subscribers
|
|
74
|
+
*/
|
|
75
|
+
ngOnDestroy() {
|
|
76
|
+
this.destroyed$.next();
|
|
77
|
+
this.destroyed$.complete();
|
|
78
|
+
}
|
|
79
|
+
// ************************************************
|
|
80
|
+
// Public Methods
|
|
81
|
+
// ************************************************
|
|
82
|
+
/**
|
|
83
|
+
* Observe changes to current activation 'list'
|
|
84
|
+
*/
|
|
85
|
+
asObservable() {
|
|
86
|
+
return this._media$;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Allow programmatic query to determine if one or more media query/alias match
|
|
90
|
+
* the current viewport size.
|
|
91
|
+
* @param value One or more media queries (or aliases) to check.
|
|
92
|
+
* @returns Whether any of the media queries match.
|
|
93
|
+
*/
|
|
94
|
+
isActive(value) {
|
|
95
|
+
const aliases = splitQueries(coerceArray(value));
|
|
96
|
+
return aliases.some(alias => {
|
|
97
|
+
const query = toMediaQuery(alias, this.breakpoints);
|
|
98
|
+
return query !== null && this.matchMedia.isActive(query);
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
// ************************************************
|
|
102
|
+
// Internal Methods
|
|
103
|
+
// ************************************************
|
|
104
|
+
/**
|
|
105
|
+
* Register all the mediaQueries registered in the BreakPointRegistry
|
|
106
|
+
* This is needed so subscribers can be auto-notified of all standard, registered
|
|
107
|
+
* mediaQuery activations
|
|
108
|
+
*/
|
|
109
|
+
watchActivations() {
|
|
110
|
+
const queries = this.breakpoints.items.map(bp => bp.mediaQuery);
|
|
111
|
+
return this.buildObservable(queries);
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Only pass/announce activations (not de-activations)
|
|
115
|
+
*
|
|
116
|
+
* Since multiple-mediaQueries can be activation in a cycle,
|
|
117
|
+
* gather all current activations into a single list of changes to observers
|
|
118
|
+
*
|
|
119
|
+
* Inject associated (if any) alias information into the MediaChange event
|
|
120
|
+
* - Exclude mediaQuery activations for overlapping mQs. List bounded mQ ranges only
|
|
121
|
+
* - Exclude print activations that do not have an associated mediaQuery
|
|
122
|
+
*
|
|
123
|
+
* NOTE: the raw MediaChange events [from MatchMedia] do not
|
|
124
|
+
* contain important alias information; as such this info
|
|
125
|
+
* must be injected into the MediaChange
|
|
126
|
+
*/
|
|
127
|
+
buildObservable(mqList) {
|
|
128
|
+
const hasChanges = (changes) => {
|
|
129
|
+
const isValidQuery = (change) => (change.mediaQuery.length > 0);
|
|
130
|
+
return (changes.filter(isValidQuery).length > 0);
|
|
131
|
+
};
|
|
132
|
+
const excludeOverlaps = (changes) => {
|
|
133
|
+
return !this.filterOverlaps ? changes : changes.filter(change => {
|
|
134
|
+
const bp = this.breakpoints.findByQuery(change.mediaQuery);
|
|
135
|
+
return bp?.overlapping ?? true;
|
|
136
|
+
});
|
|
137
|
+
};
|
|
138
|
+
const ignoreDuplicates = (previous, current) => {
|
|
139
|
+
if (previous.length !== current.length) {
|
|
140
|
+
return false;
|
|
141
|
+
}
|
|
142
|
+
const previousMqs = previous.map(mc => mc.mediaQuery);
|
|
143
|
+
const currentMqs = new Set(current.map(mc => mc.mediaQuery));
|
|
144
|
+
const difference = new Set(previousMqs.filter(mq => !currentMqs.has(mq)));
|
|
145
|
+
return difference.size === 0;
|
|
146
|
+
};
|
|
147
|
+
/**
|
|
148
|
+
*/
|
|
149
|
+
return this.matchMedia
|
|
150
|
+
.observe(this.hook.withPrintQuery(mqList))
|
|
151
|
+
.pipe(filter((change) => change.matches), debounceTime(0, asapScheduler), switchMap(_ => of(this.findAllActivations())), map(excludeOverlaps), filter(hasChanges), distinctUntilChanged(ignoreDuplicates), takeUntil(this.destroyed$));
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Find all current activations and prepare single list of activations
|
|
155
|
+
* sorted by descending priority.
|
|
156
|
+
*/
|
|
157
|
+
findAllActivations() {
|
|
158
|
+
const mergeMQAlias = (change) => {
|
|
159
|
+
const bp = this.breakpoints.findByQuery(change.mediaQuery);
|
|
160
|
+
return mergeAlias(change, bp);
|
|
161
|
+
};
|
|
162
|
+
const replaceWithPrintAlias = (change) => {
|
|
163
|
+
return this.hook.isPrintEvent(change) ? this.hook.updateEvent(change) : change;
|
|
164
|
+
};
|
|
165
|
+
return this.matchMedia
|
|
166
|
+
.activations
|
|
167
|
+
.map(query => new MediaChange(true, query))
|
|
168
|
+
.map(replaceWithPrintAlias)
|
|
169
|
+
.map(mergeMQAlias)
|
|
170
|
+
.sort(sortDescendingPriority);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
MediaObserver.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: MediaObserver, deps: [{ token: i1.BreakPointRegistry }, { token: i2.MatchMedia }, { token: i3.PrintHook }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
174
|
+
MediaObserver.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: MediaObserver, providedIn: 'root' });
|
|
175
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: MediaObserver, decorators: [{
|
|
176
|
+
type: Injectable,
|
|
177
|
+
args: [{ providedIn: 'root' }]
|
|
178
|
+
}], ctorParameters: function () { return [{ type: i1.BreakPointRegistry }, { type: i2.MatchMedia }, { type: i3.PrintHook }]; } });
|
|
179
|
+
/**
|
|
180
|
+
* Find associated breakpoint (if any)
|
|
181
|
+
*/
|
|
182
|
+
function toMediaQuery(query, locator) {
|
|
183
|
+
const bp = locator.findByAlias(query) ?? locator.findByQuery(query);
|
|
184
|
+
return bp?.mediaQuery ?? null;
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Split each query string into separate query strings if two queries are provided as comma
|
|
188
|
+
* separated.
|
|
189
|
+
*/
|
|
190
|
+
function splitQueries(queries) {
|
|
191
|
+
return queries.map((query) => query.split(','))
|
|
192
|
+
.reduce((a1, a2) => a1.concat(a2))
|
|
193
|
+
.map(query => query.trim());
|
|
194
|
+
}
|
|
195
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-observer.js","sourceRoot":"","sources":["../../../../../../projects/libs/flex-layout/core/media-observer/media-observer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {Injectable, OnDestroy} from '@angular/core';\nimport {Subject, asapScheduler, Observable, of} from 'rxjs';\nimport {\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  map,\n  switchMap,\n  takeUntil,\n} from 'rxjs/operators';\n\nimport {mergeAlias} from '../add-alias';\nimport {MediaChange} from '../media-change';\nimport {MatchMedia} from '../match-media/match-media';\nimport {PrintHook} from '../media-marshaller/print-hook';\nimport {BreakPointRegistry, OptionalBreakPoint} from '../breakpoints/break-point-registry';\n\nimport {sortDescendingPriority} from '../utils/sort';\nimport {coerceArray} from '../utils/array';\n\n\n/**\n * MediaObserver enables applications to listen for 1..n mediaQuery activations and to determine\n * if a mediaQuery is currently activated.\n *\n * Since a breakpoint change will first deactivate 1...n mediaQueries and then possibly activate\n * 1..n mediaQueries, the MediaObserver will debounce notifications and report ALL *activations*\n * in 1 event notification. The reported activations will be sorted in descending priority order.\n *\n * This class uses the BreakPoint Registry to inject alias information into the raw MediaChange\n * notification. For custom mediaQuery notifications, alias information will not be injected and\n * those fields will be ''.\n *\n * Note: Developers should note that only mediaChange activations (not de-activations)\n *       are announced by the MediaObserver.\n *\n *  @usage\n *\n *  // RxJS\n *  import { filter } from 'rxjs/operators';\n *  import { MediaObserver } from '@angular/flex-layout';\n *\n *  @Component({ ... })\n *  export class AppComponent {\n *    status: string = '';\n *\n *    constructor(mediaObserver: MediaObserver) {\n *      const media$ = mediaObserver.asObservable().pipe(\n *        filter((changes: MediaChange[]) => true)   // silly noop filter\n *      );\n *\n *      media$.subscribe((changes: MediaChange[]) => {\n *        let status = '';\n *        changes.forEach( change => {\n *          status += `'${change.mqAlias}' = (${change.mediaQuery}) <br/>` ;\n *        });\n *        this.status = status;\n *     });\n *\n *    }\n *  }\n */\n@Injectable({providedIn: 'root'})\nexport class MediaObserver implements OnDestroy {\n\n  /**\n   * @deprecated Use `asObservable()` instead.\n   * @breaking-change 8.0.0-beta.25\n   * @deletion-target 10.0.0\n   */\n  readonly media$: Observable<MediaChange>;\n\n  /** Filter MediaChange notifications for overlapping breakpoints */\n  filterOverlaps = false;\n\n  constructor(protected breakpoints: BreakPointRegistry,\n              protected matchMedia: MatchMedia,\n              protected hook: PrintHook) {\n    this._media$ = this.watchActivations();\n    this.media$ = this._media$.pipe(\n      filter((changes: MediaChange[]) => changes.length > 0),\n      map((changes: MediaChange[]) => changes[0])\n    );\n  }\n\n  /**\n   * Completes the active subject, signalling to all complete for all\n   * MediaObserver subscribers\n   */\n  ngOnDestroy(): void {\n    this.destroyed$.next();\n    this.destroyed$.complete();\n  }\n\n  // ************************************************\n  // Public Methods\n  // ************************************************\n\n  /**\n   * Observe changes to current activation 'list'\n   */\n  asObservable(): Observable<MediaChange[]> {\n    return this._media$;\n  }\n\n  /**\n   * Allow programmatic query to determine if one or more media query/alias match\n   * the current viewport size.\n   * @param value One or more media queries (or aliases) to check.\n   * @returns Whether any of the media queries match.\n   */\n  isActive(value: string | string[]): boolean {\n    const aliases = splitQueries(coerceArray(value));\n    return aliases.some(alias => {\n      const query = toMediaQuery(alias, this.breakpoints);\n      return query !== null && this.matchMedia.isActive(query);\n    });\n  }\n\n  // ************************************************\n  // Internal Methods\n  // ************************************************\n\n  /**\n   * Register all the mediaQueries registered in the BreakPointRegistry\n   * This is needed so subscribers can be auto-notified of all standard, registered\n   * mediaQuery activations\n   */\n  private watchActivations() {\n    const queries = this.breakpoints.items.map(bp => bp.mediaQuery);\n    return this.buildObservable(queries);\n  }\n\n  /**\n   * Only pass/announce activations (not de-activations)\n   *\n   * Since multiple-mediaQueries can be activation in a cycle,\n   * gather all current activations into a single list of changes to observers\n   *\n   * Inject associated (if any) alias information into the MediaChange event\n   * - Exclude mediaQuery activations for overlapping mQs. List bounded mQ ranges only\n   * - Exclude print activations that do not have an associated mediaQuery\n   *\n   * NOTE: the raw MediaChange events [from MatchMedia] do not\n   *       contain important alias information; as such this info\n   *       must be injected into the MediaChange\n   */\n  private buildObservable(mqList: string[]): Observable<MediaChange[]> {\n    const hasChanges = (changes: MediaChange[]) => {\n      const isValidQuery = (change: MediaChange) => (change.mediaQuery.length > 0);\n      return (changes.filter(isValidQuery).length > 0);\n    };\n    const excludeOverlaps = (changes: MediaChange[]) => {\n      return !this.filterOverlaps ? changes : changes.filter(change => {\n        const bp = this.breakpoints.findByQuery(change.mediaQuery);\n        return bp?.overlapping ?? true;\n      });\n    };\n    const ignoreDuplicates = (previous: MediaChange[], current: MediaChange[]): boolean => {\n      if (previous.length !== current.length) {\n        return false;\n      }\n\n      const previousMqs = previous.map(mc => mc.mediaQuery);\n      const currentMqs = new Set(current.map(mc => mc.mediaQuery));\n      const difference = new Set(previousMqs.filter(mq => !currentMqs.has(mq)));\n\n      return difference.size === 0;\n    };\n\n    /**\n     */\n    return this.matchMedia\n        .observe(this.hook.withPrintQuery(mqList))\n        .pipe(\n            filter((change: MediaChange) => change.matches),\n            debounceTime(0, asapScheduler),\n            switchMap(_ => of(this.findAllActivations())),\n            map(excludeOverlaps),\n            filter(hasChanges),\n            distinctUntilChanged(ignoreDuplicates),\n            takeUntil(this.destroyed$)\n        );\n  }\n\n  /**\n   * Find all current activations and prepare single list of activations\n   * sorted by descending priority.\n   */\n  private findAllActivations(): MediaChange[] {\n    const mergeMQAlias = (change: MediaChange) => {\n      const bp: OptionalBreakPoint = this.breakpoints.findByQuery(change.mediaQuery);\n      return mergeAlias(change, bp);\n    };\n    const replaceWithPrintAlias = (change: MediaChange) => {\n      return this.hook.isPrintEvent(change) ? this.hook.updateEvent(change) : change;\n    };\n\n    return this.matchMedia\n        .activations\n        .map(query => new MediaChange(true, query))\n        .map(replaceWithPrintAlias)\n        .map(mergeMQAlias)\n        .sort(sortDescendingPriority);\n  }\n\n  private readonly _media$: Observable<MediaChange[]>;\n  private readonly destroyed$ = new Subject<void>();\n}\n\n/**\n * Find associated breakpoint (if any)\n */\nfunction toMediaQuery(query: string, locator: BreakPointRegistry): string | null {\n  const bp = locator.findByAlias(query) ?? locator.findByQuery(query);\n  return bp?.mediaQuery ?? null;\n}\n\n/**\n * Split each query string into separate query strings if two queries are provided as comma\n * separated.\n */\nfunction splitQueries(queries: string[]): string[] {\n  return queries.map((query: string) => query.split(','))\n                .reduce((a1: string[], a2: string[]) => a1.concat(a2))\n                .map(query => query.trim());\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
export * from './media-trigger';
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWJzL2ZsZXgtbGF5b3V0L2NvcmUvbWVkaWEtdHJpZ2dlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbWVkaWEtdHJpZ2dlcic7XG4iXX0=
|