| /** |
| * @fileoverview added by tsickle |
| * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc |
| */ |
| import { Directive, ElementRef, Input } from '@angular/core'; |
| import { Renderer2 } from '@angular/core'; |
| import { TdMediaService } from '../services/media.service'; |
| var TdMediaToggleDirective = /** @class */ (function () { |
| function TdMediaToggleDirective(_renderer, _elementRef, _mediaService) { |
| this._renderer = _renderer; |
| this._elementRef = _elementRef; |
| this._mediaService = _mediaService; |
| this._matches = false; |
| this._attributes = {}; |
| this._styles = {}; |
| this._classes = []; |
| } |
| Object.defineProperty(TdMediaToggleDirective.prototype, "query", { |
| /** |
| * tdMediaToggle: string |
| * Media query used to evaluate screen/window size. |
| * Toggles attributes, classes and styles if media query is matched. |
| */ |
| set: /** |
| * tdMediaToggle: string |
| * Media query used to evaluate screen/window size. |
| * Toggles attributes, classes and styles if media query is matched. |
| * @param {?} query |
| * @return {?} |
| */ |
| function (query) { |
| if (!query) { |
| throw new Error('Query needed for [tdMediaToggle] directive.'); |
| } |
| this._query = query; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdMediaToggleDirective.prototype, "attributes", { |
| /** |
| * mediaAttributes: {[key: string]: string} |
| * Attributes to be toggled when media query matches. |
| */ |
| set: /** |
| * mediaAttributes: {[key: string]: string} |
| * Attributes to be toggled when media query matches. |
| * @param {?} attributes |
| * @return {?} |
| */ |
| function (attributes) { |
| this._attributes = attributes; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdMediaToggleDirective.prototype, "classes", { |
| /** |
| * mediaClasses: string[] |
| * CSS Classes to be toggled when media query matches. |
| */ |
| set: /** |
| * mediaClasses: string[] |
| * CSS Classes to be toggled when media query matches. |
| * @param {?} classes |
| * @return {?} |
| */ |
| function (classes) { |
| this._classes = classes; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdMediaToggleDirective.prototype, "styles", { |
| /** |
| * mediaStyles: {[key: string]: string} |
| * CSS Styles to be toggled when media query matches. |
| */ |
| set: /** |
| * mediaStyles: {[key: string]: string} |
| * CSS Styles to be toggled when media query matches. |
| * @param {?} styles |
| * @return {?} |
| */ |
| function (styles) { |
| this._styles = styles; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| /** |
| * @return {?} |
| */ |
| TdMediaToggleDirective.prototype.ngOnInit = /** |
| * @return {?} |
| */ |
| function () { |
| var _this = this; |
| this._mediaChange(this._mediaService.query(this._query)); |
| this._subscription = this._mediaService.registerQuery(this._query).subscribe(function (matches) { |
| _this._mediaChange(matches); |
| }); |
| }; |
| /** |
| * @return {?} |
| */ |
| TdMediaToggleDirective.prototype.ngOnDestroy = /** |
| * @return {?} |
| */ |
| function () { |
| if (this._subscription) { |
| this._subscription.unsubscribe(); |
| } |
| }; |
| /** |
| * @param {?} matches |
| * @return {?} |
| */ |
| TdMediaToggleDirective.prototype._mediaChange = /** |
| * @param {?} matches |
| * @return {?} |
| */ |
| function (matches) { |
| this._matches = matches; |
| this._changeAttributes(); |
| this._changeClasses(); |
| this._changeStyles(); |
| }; |
| /** |
| * @return {?} |
| */ |
| TdMediaToggleDirective.prototype._changeAttributes = /** |
| * @return {?} |
| */ |
| function () { |
| for (var attr in this._attributes) { |
| if (this._matches) { |
| this._renderer.setAttribute(this._elementRef.nativeElement, attr, this._attributes[attr]); |
| } |
| else { |
| this._renderer.removeAttribute(this._elementRef.nativeElement, attr); |
| } |
| } |
| }; |
| /** |
| * @return {?} |
| */ |
| TdMediaToggleDirective.prototype._changeClasses = /** |
| * @return {?} |
| */ |
| function () { |
| var _this = this; |
| this._classes.forEach(function (className) { |
| if (_this._matches) { |
| _this._renderer.addClass(_this._elementRef.nativeElement, className); |
| } |
| else { |
| _this._renderer.removeClass(_this._elementRef.nativeElement, className); |
| } |
| }); |
| }; |
| /** |
| * @return {?} |
| */ |
| TdMediaToggleDirective.prototype._changeStyles = /** |
| * @return {?} |
| */ |
| function () { |
| for (var style in this._styles) { |
| if (this._matches) { |
| this._renderer.setStyle(this._elementRef.nativeElement, style, this._styles[style]); |
| } |
| else { |
| this._renderer.removeStyle(this._elementRef.nativeElement, style); |
| } |
| } |
| }; |
| TdMediaToggleDirective.decorators = [ |
| { type: Directive, args: [{ |
| selector: '[tdMediaToggle]', |
| },] } |
| ]; |
| /** @nocollapse */ |
| TdMediaToggleDirective.ctorParameters = function () { return [ |
| { type: Renderer2 }, |
| { type: ElementRef }, |
| { type: TdMediaService } |
| ]; }; |
| TdMediaToggleDirective.propDecorators = { |
| query: [{ type: Input, args: ['tdMediaToggle',] }], |
| attributes: [{ type: Input, args: ['mediaAttributes',] }], |
| classes: [{ type: Input, args: ['mediaClasses',] }], |
| styles: [{ type: Input, args: ['mediaStyles',] }] |
| }; |
| return TdMediaToggleDirective; |
| }()); |
| export { TdMediaToggleDirective }; |
| if (false) { |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._subscription; |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._query; |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._matches; |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._attributes; |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._styles; |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._classes; |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._renderer; |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._elementRef; |
| /** @type {?} */ |
| TdMediaToggleDirective.prototype._mediaService; |
| } |
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-toggle.directive.js","sourceRoot":"ng://@covalent/core/","sources":["media/directives/media-toggle.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnInit, OnDestroy } from '@angular/core';\nimport { Renderer2 } from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { TdMediaService } from '../services/media.service';\n\n@Directive({\n  selector: '[tdMediaToggle]',\n})\nexport class TdMediaToggleDirective implements OnInit, OnDestroy {\n\n  private _subscription: Subscription;\n\n  private _query: string;\n  private _matches: boolean = false;\n  private _attributes: {[key: string]: string} = {};\n  private _styles: {[key: string]: string} = {};\n  private _classes: string[] = [];\n\n  /**\n   * tdMediaToggle: string\n   * Media query used to evaluate screen/window size.\n   * Toggles attributes, classes and styles if media query is matched.\n   */\n  @Input('tdMediaToggle')\n  set query(query: string) {\n    if (!query) {\n      throw new Error('Query needed for [tdMediaToggle] directive.');\n    }\n    this._query = query;\n  }\n\n  /**\n   * mediaAttributes: {[key: string]: string}\n   * Attributes to be toggled when media query matches.\n   */\n  @Input('mediaAttributes')\n  set attributes(attributes: any) {\n    this._attributes = attributes;\n  }\n\n  /**\n   * mediaClasses: string[]\n   * CSS Classes to be toggled when media query matches.\n   */\n  @Input('mediaClasses')\n  set classes(classes: string[]) {\n    this._classes = classes;\n  }\n\n  /**\n   * mediaStyles: {[key: string]: string}\n   * CSS Styles to be toggled when media query matches.\n   */\n  @Input('mediaStyles')\n  set styles(styles: any) {\n    this._styles = styles;\n  }\n\n  constructor(private _renderer: Renderer2, private _elementRef: ElementRef, private _mediaService: TdMediaService) { }\n\n  ngOnInit(): void {\n    this._mediaChange(this._mediaService.query(this._query));\n    this._subscription = this._mediaService.registerQuery(this._query).subscribe((matches: boolean) => {\n      this._mediaChange(matches);\n    });\n  }\n\n  ngOnDestroy(): void {\n    if (this._subscription) {\n      this._subscription.unsubscribe();\n    }\n  }\n\n  private _mediaChange(matches: boolean): void {\n    this._matches = matches;\n    this._changeAttributes();\n    this._changeClasses();\n    this._changeStyles();\n  }\n\n  private _changeAttributes(): void {\n    for (let attr in this._attributes) {\n      if (this._matches) {\n        this._renderer.setAttribute(this._elementRef.nativeElement, attr, this._attributes[attr]);\n      } else {\n        this._renderer.removeAttribute(this._elementRef.nativeElement, attr);\n      }\n    }\n  }\n\n  private _changeClasses(): void {\n    this._classes.forEach((className: string) => {\n      if (this._matches) {\n        this._renderer.addClass(this._elementRef.nativeElement, className);\n      } else {\n        this._renderer.removeClass(this._elementRef.nativeElement, className);\n      }\n    });\n  }\n\n  private _changeStyles(): void {\n    for (let style in this._styles) {\n      if (this._matches) {\n        this._renderer.setStyle(this._elementRef.nativeElement, style, this._styles[style]);\n      } else {\n        this._renderer.removeStyle(this._elementRef.nativeElement, style);\n      }\n    }\n  }\n\n}\n"]} |