@anexia/platform-tools
Version:
Provides Ionic Framework way class mapping of current platform and orientation on the root document node ´html´ for usage inside scss or :host-context selecting.
92 lines • 13.6 kB
JavaScript
import { Injectable } from '@angular/core';
import { fromEvent } from "rxjs";
import { startWith, tap } from "rxjs/operators";
import * as i0 from "@angular/core";
export class PlatformToolsService {
constructor() {
setupPlatforms(window);
fromEvent(window, 'resize').pipe(startWith(true), tap(_ => updateOrientation(window))).subscribe();
}
}
PlatformToolsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.3", ngImport: i0, type: PlatformToolsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
PlatformToolsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.3", ngImport: i0, type: PlatformToolsService, providedIn: 'root' });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.3", ngImport: i0, type: PlatformToolsService, decorators: [{
type: Injectable,
args: [{
providedIn: 'root'
}]
}], ctorParameters: function () { return []; } });
export function updateOrientation(win) {
if (win.matchMedia("(orientation: portrait)").matches) {
win.document.documentElement.classList.add('is-portrait');
win.document.documentElement.classList.remove('is-landscape');
}
if (win.matchMedia("(orientation: landscape)").matches) {
win.document.documentElement.classList.add('is-landscape');
win.document.documentElement.classList.remove('is-portrait');
}
}
export const setupPlatforms = (win = window) => {
if (typeof win === 'undefined') {
return [];
}
let platforms = null;
platforms = detectPlatforms(win);
platforms.forEach(p => win.document.documentElement.classList.add(`plt-${p}`));
return platforms;
};
const detectPlatforms = (win) => Object.keys(PLATFORMS_MAP).filter(p => PLATFORMS_MAP[p](win));
const isMobileWeb = (win) => isMobile(win);
const isIpad = (win) => {
// iOS 12 and below
if (testUserAgent(win, /iPad/i)) {
return true;
}
// iOS 13+
if (testUserAgent(win, /Macintosh/i) && isMobile(win)) {
return true;
}
return false;
};
const isIphone = (win) => testUserAgent(win, /iPhone/i);
const isIOS = (win) => testUserAgent(win, /iPhone|iPod/i) || isIpad(win);
const isAndroid = (win) => testUserAgent(win, /android|sink/i);
const isAndroidTablet = (win) => {
return isAndroid(win) && !testUserAgent(win, /mobile/i);
};
const isPhablet = (win) => {
const width = win.innerWidth;
const height = win.innerHeight;
const smallest = Math.min(width, height);
const largest = Math.max(width, height);
return (smallest > 390 && smallest < 520) &&
(largest > 620 && largest < 800);
};
const isTablet = (win) => {
const width = win.innerWidth;
const height = win.innerHeight;
const smallest = Math.min(width, height);
const largest = Math.max(width, height);
return (isIpad(win) ||
isAndroidTablet(win) ||
((smallest > 460 && smallest < 820) &&
(largest > 780 && largest < 1400)));
};
const isMobile = (win) => matchMedia(win, '(any-pointer:coarse)');
const isDesktop = (win) => !isMobile(win);
const isPWA = (win) => !!(win.matchMedia('(display-mode: standalone)').matches || win.navigator.standalone);
export const testUserAgent = (win, expr) => expr.test(win.navigator.userAgent);
const matchMedia = (win, query) => win.matchMedia(query).matches;
const PLATFORMS_MAP = {
'ipad': isIpad,
'iphone': isIphone,
'ios': isIOS,
'android': isAndroid,
'phablet': isPhablet,
'tablet': isTablet,
'pwa': isPWA,
'mobile': isMobile,
'mobileweb': isMobileWeb,
'desktop': isDesktop
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"platform-tools.service.js","sourceRoot":"","sources":["../../../../projects/platform-tools/src/lib/platform-tools.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {fromEvent} from \"rxjs\";\nimport {startWith, tap} from \"rxjs/operators\";\n\nexport type Platforms = keyof typeof PLATFORMS_MAP;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class PlatformToolsService {\n\n  public constructor() {\n    setupPlatforms(window);\n\n    fromEvent(window, 'resize').pipe(\n      startWith(true),\n      tap(_ => updateOrientation(window))\n    ).subscribe();\n\n  }\n\n}\n\nexport function updateOrientation(win?: any) {\n\n  if (win.matchMedia(\"(orientation: portrait)\").matches) {\n    win.document.documentElement.classList.add('is-portrait');\n    win.document.documentElement.classList.remove('is-landscape');\n  }\n\n  if (win.matchMedia(\"(orientation: landscape)\").matches) {\n    win.document.documentElement.classList.add('is-landscape');\n    win.document.documentElement.classList.remove('is-portrait');\n  }\n\n}\n\nexport const setupPlatforms = (win: any = window) => {\n  if (typeof win === 'undefined') {\n    return [];\n  }\n\n  let platforms: Platforms[] | undefined | null = null;\n  platforms = detectPlatforms(win);\n  platforms.forEach(p => win.document.documentElement.classList.add(`plt-${p}`));\n\n  return platforms;\n};\n\nconst detectPlatforms = (win: Window) =>\n  (Object.keys(PLATFORMS_MAP) as Platforms[]).filter(p => PLATFORMS_MAP[p](win));\n\nconst isMobileWeb = (win: Window): boolean =>\n  isMobile(win);\n\nconst isIpad = (win: Window) => {\n  // iOS 12 and below\n  if (testUserAgent(win, /iPad/i)) {\n    return true;\n  }\n\n  // iOS 13+\n  if (testUserAgent(win, /Macintosh/i) && isMobile(win)) {\n    return true;\n  }\n\n  return false;\n};\n\nconst isIphone = (win: Window) =>\n  testUserAgent(win, /iPhone/i);\n\nconst isIOS = (win: Window) =>\n  testUserAgent(win, /iPhone|iPod/i) || isIpad(win);\n\nconst isAndroid = (win: Window) =>\n  testUserAgent(win, /android|sink/i);\n\nconst isAndroidTablet = (win: Window) => {\n  return isAndroid(win) && !testUserAgent(win, /mobile/i);\n};\n\nconst isPhablet = (win: Window) => {\n  const width = win.innerWidth;\n  const height = win.innerHeight;\n  const smallest = Math.min(width, height);\n  const largest = Math.max(width, height);\n\n  return (smallest > 390 && smallest < 520) &&\n    (largest > 620 && largest < 800);\n};\n\nconst isTablet = (win: Window) => {\n  const width = win.innerWidth;\n  const height = win.innerHeight;\n  const smallest = Math.min(width, height);\n  const largest = Math.max(width, height);\n\n  return (\n    isIpad(win) ||\n    isAndroidTablet(win) ||\n    (\n      (smallest > 460 && smallest < 820) &&\n      (largest > 780 && largest < 1400)\n    )\n  );\n};\n\nconst isMobile = (win: Window) =>\n  matchMedia(win, '(any-pointer:coarse)');\n\nconst isDesktop = (win: Window) =>\n  !isMobile(win);\n\nconst isPWA = (win: Window): boolean =>\n  !!(win.matchMedia('(display-mode: standalone)').matches || (win.navigator as any).standalone);\n\nexport const testUserAgent = (win: Window, expr: RegExp) =>\n  expr.test(win.navigator.userAgent);\n\nconst matchMedia = (win: Window, query: string): boolean =>\n  win.matchMedia(query).matches;\n\nconst PLATFORMS_MAP = {\n  'ipad': isIpad,\n  'iphone': isIphone,\n  'ios': isIOS,\n  'android': isAndroid,\n  'phablet': isPhablet,\n  'tablet': isTablet,\n  'pwa': isPWA,\n  'mobile': isMobile,\n  'mobileweb': isMobileWeb,\n  'desktop': isDesktop\n};\n"]}