UNPKG

@scriptloom/ngx-media-query

Version:

A convenient media query service for building responsive Angular components.

227 lines 31.6 kB
import { Directive } from '@angular/core'; import { Store } from '@ngrx/store'; import { addMediaQuery, selectMediaQuery, } from './media-queries.actions'; import { screenWidthLg, screenWidthMd, screenWidthSm, screenWidthXl, screenWidthXs } from './media-queries.models'; export class MediaQueriesDirective { constructor(store) { this.store = store; // screen this.screenQuery = window.matchMedia('screen'); this.screenQueryListener = () => { }; // xs this.upperXsQuery = window.matchMedia('(max-width: 599px)'); this.xsQueryListener = this.screenXsConditional(); // sm this.lowerSmQuery = window.matchMedia('(min-width: 600px)'); this.upperSmQuery = window.matchMedia('(max-width: 959px)'); this.smQueryListener = this.screenSmConditional(); // md this.lowerMdQuery = window.matchMedia('(min-width: 960px)'); this.upperMdQuery = window.matchMedia('(max-width: 1279px)'); this.mdQueryListener = this.screenMdConditional(); // lg this.lowerLgQuery = window.matchMedia('(min-width: 1280px)'); this.upperLgQuery = window.matchMedia('(max-width: 1919px)'); this.lgQueryListener = this.screenLgConditional(); // xl this.lowerXlQuery = window.matchMedia('(min-width: 1920px)'); this.upperXlQuery = window.matchMedia('(max-width: 5000px)'); this.xlQueryListener = this.screenXlConditional(); } ngOnInit() { if (typeof window.matchMedia('(min-width: 0px)').addEventListener !== 'undefined') { // screen this.screenQuery.addEventListener('change', this.screenQueryListener); // xs this.upperXsQuery.addEventListener('change', this.xsQueryListener); // sm this.lowerSmQuery.addEventListener('change', this.smQueryListener); this.upperSmQuery.addEventListener('change', this.smQueryListener); // md this.lowerMdQuery.addEventListener('change', this.mdQueryListener); this.upperMdQuery.addEventListener('change', this.mdQueryListener); // lg this.lowerLgQuery.addEventListener('change', this.lgQueryListener); this.upperLgQuery.addEventListener('change', this.lgQueryListener); // xl this.lowerXlQuery.addEventListener('change', this.xlQueryListener); this.upperXlQuery.addEventListener('change', this.xlQueryListener); } else { // As of July 4, 2020 it is expect Safari does not implement // MediaQueryList.addEventListener and so MediaQueryList.addListener // is used if the MediaQueryList.addEventListener is not found. See: // https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList. // screen this.screenQuery.addListener(this.screenQueryListener); // xs this.upperXsQuery.addListener(this.xsQueryListener); // sm this.lowerSmQuery.addListener(this.smQueryListener); this.upperSmQuery.addListener(this.smQueryListener); // md this.lowerMdQuery.addListener(this.mdQueryListener); this.upperMdQuery.addListener(this.mdQueryListener); // lg this.lowerLgQuery.addListener(this.lgQueryListener); this.upperLgQuery.addListener(this.lgQueryListener); // xl this.lowerXlQuery.addListener(this.xlQueryListener); this.upperXlQuery.addListener(this.xlQueryListener); } // initialize states this.initializeState(); } ngOnDestroy() { if (typeof window.matchMedia('(min-width: 0px)').removeEventListener !== 'undefined') { // screen this.screenQuery.removeEventListener('change', this.screenQueryListener); // xs this.upperXsQuery.removeEventListener('change', this.xsQueryListener); // sm this.lowerSmQuery.removeEventListener('change', this.smQueryListener); this.upperSmQuery.removeEventListener('change', this.smQueryListener); // md this.lowerMdQuery.removeEventListener('change', this.mdQueryListener); this.upperMdQuery.removeEventListener('change', this.mdQueryListener); // lg this.lowerLgQuery.removeEventListener('change', this.lgQueryListener); this.upperLgQuery.removeEventListener('change', this.lgQueryListener); // xl this.lowerXlQuery.removeEventListener('change', this.xlQueryListener); this.upperXlQuery.removeEventListener('change', this.xlQueryListener); } else { // As of July 4, 2020 it is expect Safari does not implement // MediaQueryList.removeEventListener and so MediaQueryList.removeListener // is used if the MediaQueryList.removeEventListener is not found. See: // https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList // screen this.screenQuery.removeListener(this.screenQueryListener); // xs this.upperXsQuery.removeListener(this.xsQueryListener); // sm this.lowerSmQuery.removeListener(this.smQueryListener); this.upperSmQuery.removeListener(this.smQueryListener); // md this.lowerMdQuery.removeListener(this.mdQueryListener); this.upperMdQuery.removeListener(this.mdQueryListener); // lg this.lowerLgQuery.removeListener(this.lgQueryListener); this.upperLgQuery.removeListener(this.lgQueryListener); // xl this.lowerXlQuery.removeListener(this.xlQueryListener); this.upperXlQuery.removeListener(this.xlQueryListener); } } dispatchMediaQuery() { const id = new Date().getTime().toString(); this.store.dispatch(addMediaQuery({ mediaQuery: { id, query: this.currentMediaQuery, } })); this.store.dispatch(selectMediaQuery({ id })); } // Class methods. // xs screenXsConditional() { return () => { if (this.screenQuery.matches && this.upperXsQuery.matches) { this.notifyStoreScreenWidthXs(); } }; } notifyStoreScreenWidthXs() { this.currentMediaQuery = screenWidthXs; this.dispatchMediaQuery(); } // sm screenSmConditional() { return () => { if (this.screenQuery.matches && this.lowerSmQuery.matches && this.upperSmQuery.matches) { this.notifyStoreScreenWidthSm(); } }; } notifyStoreScreenWidthSm() { this.currentMediaQuery = screenWidthSm; this.dispatchMediaQuery(); } // md screenMdConditional() { return () => { if (this.screenQuery.matches && this.lowerMdQuery.matches && this.upperMdQuery.matches) { this.notifyStoreScreenWidthMd(); } }; } notifyStoreScreenWidthMd() { this.currentMediaQuery = screenWidthMd; this.dispatchMediaQuery(); } // lg screenLgConditional() { return () => { if (this.screenQuery.matches && this.lowerLgQuery.matches && this.upperLgQuery.matches) { this.notifyStoreScreenWidthLg(); } }; } notifyStoreScreenWidthLg() { this.currentMediaQuery = screenWidthLg; this.dispatchMediaQuery(); } // xl screenXlConditional() { return () => { if (this.screenQuery.matches && this.lowerXlQuery.matches && this.upperXlQuery.matches) { this.notifyStoreScreenWidthXl(); } }; } notifyStoreScreenWidthXl() { this.currentMediaQuery = screenWidthXl; this.dispatchMediaQuery(); } initializeState() { // Initialize the store with a MediaQueryStateInterface // reflecting the size of current user's screen. // Since the media events will not have fired on initialization, // we set the starting state using the window object. if (window.screen && window.innerWidth < 600) { this.notifyStoreScreenWidthXs(); } else if (window.screen && window.innerWidth < 960 && window.innerWidth >= 600) { this.notifyStoreScreenWidthSm(); } else if (window.screen && window.innerWidth < 1280 && window.innerWidth >= 960) { this.notifyStoreScreenWidthMd(); } else if (window.screen && window.innerWidth < 1920 && window.innerWidth >= 960) { this.notifyStoreScreenWidthLg(); } else if (window.screen) { this.notifyStoreScreenWidthXl(); } } } MediaQueriesDirective.decorators = [ { type: Directive, args: [{ selector: '[libNgxMediaQuery]' },] } ]; MediaQueriesDirective.ctorParameters = () => [ { type: Store } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-queries.directive.js","sourceRoot":"/home/james/WebstormProjects/lib-ngx/projects/ngx-media-query/src/","sources":["lib/store/media-queries.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, OnDestroy, OnInit } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  addMediaQuery, selectMediaQuery,\n} from './media-queries.actions';\nimport {\n  MediaQuery,\n  screenWidthLg,\n  screenWidthMd,\n  screenWidthSm,\n  screenWidthXl,\n  screenWidthXs\n} from './media-queries.models';\n\n@Directive({\n  selector: '[libNgxMediaQuery]'\n})\nexport class MediaQueriesDirective implements OnInit, OnDestroy {\n\n  // mediaQuery\n  currentMediaQuery: MediaQuery;\n\n  // screen\n  screenQuery: MediaQueryList;\n  private readonly screenQueryListener: () => void;\n  // xs\n  upperXsQuery: MediaQueryList;\n  private readonly xsQueryListener: () => void;\n  // sm\n  lowerSmQuery: MediaQueryList;\n  upperSmQuery: MediaQueryList;\n  private readonly smQueryListener: () => void;\n  // md\n  lowerMdQuery: MediaQueryList;\n  upperMdQuery: MediaQueryList;\n  private readonly mdQueryListener: () => void;\n  // lg\n  lowerLgQuery: MediaQueryList;\n  upperLgQuery: MediaQueryList;\n  private readonly lgQueryListener: () => void;\n  // xl\n  lowerXlQuery: MediaQueryList;\n  upperXlQuery: MediaQueryList;\n  private readonly xlQueryListener: () => void;\n\n  constructor(\n    private store: Store,\n  ) {\n    // screen\n    this.screenQuery = window.matchMedia('screen');\n    this.screenQueryListener = () => {};\n    // xs\n    this.upperXsQuery = window.matchMedia('(max-width: 599px)');\n    this.xsQueryListener = this.screenXsConditional();\n    // sm\n    this.lowerSmQuery = window.matchMedia('(min-width: 600px)');\n    this.upperSmQuery = window.matchMedia('(max-width: 959px)');\n    this.smQueryListener = this.screenSmConditional();\n    // md\n    this.lowerMdQuery = window.matchMedia('(min-width: 960px)');\n    this.upperMdQuery = window.matchMedia('(max-width: 1279px)');\n    this.mdQueryListener = this.screenMdConditional();\n    // lg\n    this.lowerLgQuery = window.matchMedia('(min-width: 1280px)');\n    this.upperLgQuery = window.matchMedia('(max-width: 1919px)');\n    this.lgQueryListener = this.screenLgConditional();\n    // xl\n    this.lowerXlQuery = window.matchMedia('(min-width: 1920px)');\n    this.upperXlQuery = window.matchMedia('(max-width: 5000px)');\n    this.xlQueryListener = this.screenXlConditional();\n  }\n\n\n  ngOnInit(): void {\n    if (typeof window.matchMedia('(min-width: 0px)').addEventListener !== 'undefined') {\n      // screen\n      this.screenQuery.addEventListener('change', this.screenQueryListener);\n      // xs\n      this.upperXsQuery.addEventListener('change', this.xsQueryListener);\n      // sm\n      this.lowerSmQuery.addEventListener('change', this.smQueryListener);\n      this.upperSmQuery.addEventListener('change', this.smQueryListener);\n      // md\n      this.lowerMdQuery.addEventListener('change', this.mdQueryListener);\n      this.upperMdQuery.addEventListener('change', this.mdQueryListener);\n      // lg\n      this.lowerLgQuery.addEventListener('change', this.lgQueryListener);\n      this.upperLgQuery.addEventListener('change', this.lgQueryListener);\n      // xl\n      this.lowerXlQuery.addEventListener('change', this.xlQueryListener);\n      this.upperXlQuery.addEventListener('change', this.xlQueryListener);\n    } else {\n      // As of July 4, 2020 it is expect Safari does not implement\n      // MediaQueryList.addEventListener and so MediaQueryList.addListener\n      // is used if the MediaQueryList.addEventListener is not found. See:\n      // https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList.\n\n      // screen\n      this.screenQuery.addListener(this.screenQueryListener);\n      // xs\n      this.upperXsQuery.addListener(this.xsQueryListener);\n      // sm\n      this.lowerSmQuery.addListener(this.smQueryListener);\n      this.upperSmQuery.addListener(this.smQueryListener);\n      // md\n      this.lowerMdQuery.addListener(this.mdQueryListener);\n      this.upperMdQuery.addListener(this.mdQueryListener);\n      // lg\n      this.lowerLgQuery.addListener(this.lgQueryListener);\n      this.upperLgQuery.addListener(this.lgQueryListener);\n      // xl\n      this.lowerXlQuery.addListener(this.xlQueryListener);\n      this.upperXlQuery.addListener(this.xlQueryListener);\n    }\n    // initialize states\n    this.initializeState();\n  }\n\n  ngOnDestroy(): void {\n    if (typeof window.matchMedia('(min-width: 0px)').removeEventListener !== 'undefined') {\n      // screen\n      this.screenQuery.removeEventListener('change', this.screenQueryListener);\n      // xs\n      this.upperXsQuery.removeEventListener('change', this.xsQueryListener);\n      // sm\n      this.lowerSmQuery.removeEventListener('change', this.smQueryListener);\n      this.upperSmQuery.removeEventListener('change', this.smQueryListener);\n      // md\n      this.lowerMdQuery.removeEventListener('change', this.mdQueryListener);\n      this.upperMdQuery.removeEventListener('change', this.mdQueryListener);\n      // lg\n      this.lowerLgQuery.removeEventListener('change', this.lgQueryListener);\n      this.upperLgQuery.removeEventListener('change', this.lgQueryListener);\n      // xl\n      this.lowerXlQuery.removeEventListener('change', this.xlQueryListener);\n      this.upperXlQuery.removeEventListener('change', this.xlQueryListener);\n    } else {\n      // As of July 4, 2020 it is expect Safari does not implement\n      // MediaQueryList.removeEventListener and so MediaQueryList.removeListener\n      // is used if the MediaQueryList.removeEventListener is not found. See:\n      // https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList\n      // screen\n      this.screenQuery.removeListener(this.screenQueryListener);\n      // xs\n      this.upperXsQuery.removeListener(this.xsQueryListener);\n      // sm\n      this.lowerSmQuery.removeListener(this.smQueryListener);\n      this.upperSmQuery.removeListener(this.smQueryListener);\n      // md\n      this.lowerMdQuery.removeListener(this.mdQueryListener);\n      this.upperMdQuery.removeListener(this.mdQueryListener);\n      // lg\n      this.lowerLgQuery.removeListener(this.lgQueryListener);\n      this.upperLgQuery.removeListener(this.lgQueryListener);\n      // xl\n      this.lowerXlQuery.removeListener(this.xlQueryListener);\n      this.upperXlQuery.removeListener(this.xlQueryListener);\n    }\n  }\n\n  private dispatchMediaQuery(): void {\n    const id = new Date().getTime().toString();\n    this.store.dispatch(addMediaQuery({\n      mediaQuery: {\n        id,\n        query: this.currentMediaQuery,\n      }\n    }));\n    this.store.dispatch(selectMediaQuery({ id }));\n  }\n\n  // Class methods.\n\n  // xs\n  screenXsConditional(): () => void {\n    return () => {\n      if (this.screenQuery.matches\n        && this.upperXsQuery.matches) {\n        this.notifyStoreScreenWidthXs();\n      }\n    };\n  }\n\n  private notifyStoreScreenWidthXs(): void {\n    this.currentMediaQuery = screenWidthXs;\n    this.dispatchMediaQuery();\n  }\n\n  // sm\n  screenSmConditional(): () => void {\n    return () => {\n      if (this.screenQuery.matches\n        && this.lowerSmQuery.matches\n        && this.upperSmQuery.matches) {\n        this.notifyStoreScreenWidthSm();\n      }\n    };\n  }\n\n  private notifyStoreScreenWidthSm(): void {\n    this.currentMediaQuery = screenWidthSm;\n    this.dispatchMediaQuery();\n  }\n\n  // md\n  screenMdConditional(): () => void {\n    return () => {\n      if (this.screenQuery.matches\n        && this.lowerMdQuery.matches\n        && this.upperMdQuery.matches) {\n        this.notifyStoreScreenWidthMd();\n      }\n    };\n  }\n\n  private notifyStoreScreenWidthMd(): void {\n    this.currentMediaQuery = screenWidthMd;\n    this.dispatchMediaQuery();\n  }\n\n  // lg\n  screenLgConditional(): () => void {\n    return () => {\n      if (this.screenQuery.matches\n        && this.lowerLgQuery.matches\n        && this.upperLgQuery.matches) {\n        this.notifyStoreScreenWidthLg();\n      }\n    };\n  }\n\n  private notifyStoreScreenWidthLg(): void {\n    this.currentMediaQuery = screenWidthLg;\n    this.dispatchMediaQuery();\n  }\n\n  // xl\n  screenXlConditional(): () => void {\n    return () => {\n      if (this.screenQuery.matches\n        && this.lowerXlQuery.matches\n        && this.upperXlQuery.matches) {\n        this.notifyStoreScreenWidthXl();\n      }\n    };\n  }\n\n  private notifyStoreScreenWidthXl(): void {\n    this.currentMediaQuery = screenWidthXl;\n    this.dispatchMediaQuery();\n  }\n\n  private initializeState(): void {\n    // Initialize the store with a MediaQueryStateInterface\n    // reflecting the size of current user's screen.\n    // Since the media events will not have fired on initialization,\n    // we set the starting state using the window object.\n    if (window.screen && window.innerWidth < 600) {\n      this.notifyStoreScreenWidthXs();\n    } else if (window.screen && window.innerWidth < 960 && window.innerWidth >= 600) {\n      this.notifyStoreScreenWidthSm();\n    } else if (window.screen && window.innerWidth < 1280 && window.innerWidth >= 960) {\n      this.notifyStoreScreenWidthMd();\n    } else if (window.screen && window.innerWidth < 1920 && window.innerWidth >= 960) {\n      this.notifyStoreScreenWidthLg();\n    } else if (window.screen) {\n      this.notifyStoreScreenWidthXl();\n    }\n  }\n}\n"]}