ngx-materialize
Version:
An Angular wrap around Materialize library
136 lines (135 loc) • 13.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import { isPlatformBrowser } from '@angular/common';
import { Inject, Injectable, PLATFORM_ID } from '@angular/core';
import { fromEvent, Observable } from 'rxjs';
import { map, publishReplay, refCount, startWith } from 'rxjs/operators';
var MzMediaService = /** @class */ (function () {
function MzMediaService(platformId) {
this.mediaBreakpoints = [
{ alias: 's', minWidth: 0, maxWidth: 600 },
{ alias: 'm', minWidth: 601, maxWidth: 992 },
{ alias: 'l', minWidth: 993, maxWidth: 1200 },
{ alias: 'xl', minWidth: 1201, maxWidth: Number.MAX_VALUE },
];
this.matchOperators = [
{
operator: 'gt',
match: function (breakpoint) { return window.innerWidth > breakpoint.maxWidth; },
},
{
operator: 'lt',
match: function (breakpoint) { return window.innerWidth < breakpoint.minWidth; },
},
{
operator: null,
match: function (breakpoint) { return window.innerWidth >= breakpoint.minWidth && window.innerWidth <= breakpoint.maxWidth; },
},
];
if (isPlatformBrowser(platformId)) {
this.media = this.registerWindowResizeListener();
}
else {
this.media = Observable.create();
}
}
/**
* @param {?} breakpoint
* @return {?}
*/
MzMediaService.prototype.isActive = /**
* @param {?} breakpoint
* @return {?}
*/
function (breakpoint) {
var _this = this;
return new Observable(function (subscriber) {
_this.media.subscribe(function (media) {
try {
subscriber.next(_this.isActiveBreakpoint(breakpoint));
}
catch (/** @type {?} */ error) {
subscriber.error(error);
}
});
});
};
/**
* @return {?}
*/
MzMediaService.prototype.registerWindowResizeListener = /**
* @return {?}
*/
function () {
var _this = this;
return fromEvent(window, 'resize')
.pipe(map(function () { return _this.getWindowMedia(); }), startWith(this.getWindowMedia()), publishReplay(1), refCount());
};
/**
* @return {?}
*/
MzMediaService.prototype.getWindowMedia = /**
* @return {?}
*/
function () {
return {
alias: this.mediaBreakpoints.find(function (breakpoint) { return window.innerWidth <= breakpoint.maxWidth; }).alias,
windowHeight: window.innerHeight,
windowWidth: window.innerWidth,
};
};
/**
* @param {?} breakpoint
* @return {?}
*/
MzMediaService.prototype.isActiveBreakpoint = /**
* @param {?} breakpoint
* @return {?}
*/
function (breakpoint) {
var /** @type {?} */ matchOperator;
var /** @type {?} */ mediaBreakpoint;
if (breakpoint) {
var /** @type {?} */ fragments_1 = breakpoint.split('-');
if (fragments_1.length === 1) {
matchOperator = this.matchOperators.find(function (x) { return x.operator === null; });
mediaBreakpoint = this.mediaBreakpoints.find(function (x) { return x.alias === fragments_1[0]; });
}
else if (fragments_1.length === 2) {
matchOperator = this.matchOperators.find(function (x) { return x.operator === fragments_1[0]; });
mediaBreakpoint = this.mediaBreakpoints.find(function (x) { return x.alias === fragments_1[1]; });
}
}
if (!mediaBreakpoint || !matchOperator) {
throw Error("MzMediaService.isActive parameter is invalid: '" + breakpoint + "' is not a recognized breakpoint.");
}
return matchOperator.match(mediaBreakpoint);
};
MzMediaService.decorators = [
{ type: Injectable },
];
/** @nocollapse */
MzMediaService.ctorParameters = function () { return [
{ type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] },] },
]; };
return MzMediaService;
}());
export { MzMediaService };
function MzMediaService_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
MzMediaService.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
MzMediaService.ctorParameters;
/** @type {?} */
MzMediaService.prototype.media;
/** @type {?} */
MzMediaService.prototype.mediaBreakpoints;
/** @type {?} */
MzMediaService.prototype.matchOperators;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media.service.js","sourceRoot":"ng://ngx-materialize/","sources":["src/media/media.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\r\nimport { Inject, Injectable, PLATFORM_ID } from '@angular/core';\r\nimport { fromEvent, Observable } from 'rxjs';\r\nimport { map, publishReplay, refCount, startWith } from 'rxjs/operators';\r\n\r\nimport { MatchOperator, Media, MediaBreakpoint } from './models/index';\r\n\r\n@Injectable()\r\nexport class MzMediaService {\r\n\r\n  media: Observable<Media>;\r\n\r\n  // based on nodes_modules/materialize-css/sass/components/_variable.scss\r\n  private readonly mediaBreakpoints: MediaBreakpoint[] = [\r\n    { alias: 's', minWidth: 0, maxWidth: 600 },\r\n    { alias: 'm', minWidth: 601, maxWidth: 992 },\r\n    { alias: 'l', minWidth: 993, maxWidth: 1200 },\r\n    { alias: 'xl', minWidth: 1201, maxWidth: Number.MAX_VALUE },\r\n  ];\r\n\r\n  private readonly matchOperators: MatchOperator[] = [\r\n    {\r\n      operator: 'gt',\r\n      match: (breakpoint: MediaBreakpoint) => window.innerWidth > breakpoint.maxWidth,\r\n    },\r\n    {\r\n      operator: 'lt',\r\n      match: (breakpoint: MediaBreakpoint) => window.innerWidth < breakpoint.minWidth,\r\n    },\r\n    {\r\n      operator: null,\r\n      match: (breakpoint: MediaBreakpoint) => window.innerWidth >= breakpoint.minWidth && window.innerWidth <= breakpoint.maxWidth,\r\n    },\r\n  ];\r\n\r\n  constructor(@Inject(PLATFORM_ID) platformId: Object) {\r\n    if (isPlatformBrowser(platformId)) {\r\n      this.media = this.registerWindowResizeListener();\r\n    } else {\r\n      this.media = Observable.create();\r\n    }\r\n  }\r\n\r\n  isActive(breakpoint: string): Observable<boolean> {\r\n    return new Observable<boolean>(subscriber => {\r\n      this.media.subscribe((media: Media) => {\r\n        try {\r\n          subscriber.next(this.isActiveBreakpoint(breakpoint));\r\n        } catch (error) {\r\n          subscriber.error(error);\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  private registerWindowResizeListener(): Observable<Media> {\r\n    return fromEvent(window, 'resize')\r\n      .pipe(\r\n        map(() => this.getWindowMedia()),\r\n        startWith(this.getWindowMedia()),\r\n        publishReplay(1),\r\n        refCount(),\r\n      );\r\n  }\r\n\r\n  private getWindowMedia(): Media {\r\n    return {\r\n      alias: this.mediaBreakpoints.find((breakpoint: MediaBreakpoint) => window.innerWidth <= breakpoint.maxWidth).alias,\r\n      windowHeight: window.innerHeight,\r\n      windowWidth: window.innerWidth,\r\n    };\r\n  }\r\n\r\n  private isActiveBreakpoint(breakpoint: string): boolean {\r\n    let matchOperator: MatchOperator;\r\n    let mediaBreakpoint: MediaBreakpoint;\r\n\r\n    if (breakpoint) {\r\n      const fragments = breakpoint.split('-');\r\n\r\n      if (fragments.length === 1) {\r\n        matchOperator = this.matchOperators.find(x => x.operator === null);\r\n        mediaBreakpoint = this.mediaBreakpoints.find(x => x.alias === fragments[0]);\r\n      } else if (fragments.length === 2) {\r\n        matchOperator = this.matchOperators.find(x => x.operator === fragments[0]);\r\n        mediaBreakpoint = this.mediaBreakpoints.find(x => x.alias === fragments[1]);\r\n      }\r\n    }\r\n\r\n    if (!mediaBreakpoint || !matchOperator) {\r\n      throw Error(`MzMediaService.isActive parameter is invalid: '${breakpoint}' is not a recognized breakpoint.`);\r\n    }\r\n\r\n    return matchOperator.match(mediaBreakpoint);\r\n  }\r\n}\r\n"]}