Skip to content

Commit

Permalink
fix: improve services intellisense
Browse files Browse the repository at this point in the history
  • Loading branch information
edgardz committed Apr 22, 2022
1 parent 5b7a73e commit f8bb4f8
Show file tree
Hide file tree
Showing 9 changed files with 121 additions and 24 deletions.
28 changes: 28 additions & 0 deletions src/services/cookie.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import Cookies from 'js-cookie';

type CookieListener = (name: string, value: string | undefined) => void;

class Service {
listeners: CookieListener[] = [];

set = (name: string, value: string, options: Cookies.CookieAttributes = { expires: 30 }) => {
Cookies.set(name, value, options);
this.listeners.forEach((listener) => listener(name, value));
};

get = (name: string) => {
return Cookies.get(name);
};

listen = (listener: CookieListener) => {
if (!this.listeners.includes(listener)) this.listeners.push(listener);
};

dismiss = (listener: CookieListener) => {
this.listeners = this.listeners.filter((l) => l !== listener);
};
}

const CookieService = new Service();

export default CookieService;
47 changes: 47 additions & 0 deletions src/services/local-storage.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
type LocalStorageListener = (name: string, value: string | undefined) => void;

const KEY = 'NEXTJS-BOILERPLATE';

class Service {
listeners: LocalStorageListener[] = [];

set = (name: string, value: string): boolean => {
try {
if (value !== undefined) {
const serializedData = localStorage.getItem(KEY);
if (serializedData === null) {
localStorage.setItem(KEY, JSON.stringify({ [name]: value }));
} else {
localStorage.setItem(KEY, JSON.stringify({ ...JSON.parse(serializedData), [name]: value }));
}
}
this.listeners.forEach((listener) => listener(name, value));
return true;
} catch (e) {
// no local storage (ssr or incognito mode)
return false;
}
};

get = (name: string): string | null => {
try {
const serializedData = localStorage.getItem(KEY);
if (!serializedData) return null;
return JSON.parse(serializedData)[name] || null;
} catch (e) {
// no local storage (ssr or incognito mode)
return null;
}
};

listen = (listener: LocalStorageListener) => {
if (!this.listeners.includes(listener)) this.listeners.push(listener);
};

dismiss = (listener: LocalStorageListener) => {
this.listeners = this.listeners.filter((l) => l !== listener);
};
}
const LocalStorageService = new Service();

export default LocalStorageService;
6 changes: 4 additions & 2 deletions src/services/lock-body-scroll.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import scrollPage from '@/utils/scroll-page';
/**
* Lock and unlock body scroll with page position restoration
*/
class LockBodyScroll {
class Service {
scrollPosY = 0;
isLocked = false;

Expand All @@ -33,4 +33,6 @@ class LockBodyScroll {
};
}

export default new LockBodyScroll();
const LockBodyScrollService = new Service();

export default LockBodyScrollService;
6 changes: 4 additions & 2 deletions src/services/orientation.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
type OrientationListener = (e?: Event) => void;

class OrientationService {
class Service {
listeners: OrientationListener[] = [];

onOrientation = (e: Event) => {
Expand All @@ -22,4 +22,6 @@ class OrientationService {
};
}

export default new OrientationService();
const OrientationService = new Service();

export default OrientationService;
6 changes: 4 additions & 2 deletions src/services/pointer-move.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { device } from '@jam3/detect';

type PointerMoveListener = (x?: number, y?: number, e?: MouseEvent | TouchEvent) => void;

class PointerMoveService {
class Service {
listeners: PointerMoveListener[] = [];

onMove = (e: MouseEvent | TouchEvent) => {
Expand All @@ -26,4 +26,6 @@ class PointerMoveService {
};
}

export default new PointerMoveService();
const PointerMoveService = new Service();

export default PointerMoveService;
8 changes: 5 additions & 3 deletions src/services/raf.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
type RequestAnimationFrameListener = (delta?: number) => void;
type RequestAnimationFrameListener = ((delta?: number) => void) | ((delta: number) => void);

class RequestAnimationFrameService {
class Service {
listeners: RequestAnimationFrameListener[] = [];
frameId = 0;
elapsed = 0;
Expand Down Expand Up @@ -30,4 +30,6 @@ class RequestAnimationFrameService {
};
}

export default new RequestAnimationFrameService();
const RafService = new Service();

export default RafService;
30 changes: 20 additions & 10 deletions src/services/resize.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,31 +2,41 @@ import { device } from '@jam3/detect';

type ResizeListener = (e?: Event | UIEvent) => void;

class ResizeService {
let timeout: NodeJS.Timeout;
class Service {
debounceTime = 10; // in ms
listeners: ResizeListener[] = [];

onResize = (e: Event | UIEvent) => {
setTimeout(
() => {
this.listeners.forEach((listener) => listener(e));
},
device.mobile ? 500 : 0 // some mobile browsers only update window dimensions when the rotate animation finishes
);
clearTimeout(timeout);

timeout = setTimeout(() => {
this.listeners.forEach((listener) => listener(e));
if (device.mobile) {
timeout = setTimeout(() => {
this.listeners.forEach((listener) => listener(e));
}, 500); // some mobile browsers only update window dimensions when the rotate animation finishes
}
}, this.debounceTime);
};

listen = (listener: ResizeListener) => {
if (!this.listeners.length) {
window.addEventListener(device.mobile ? 'orientationchange' : 'resize', this.onResize);
window.addEventListener('resize', this.onResize);
if (device.mobile) window.addEventListener('orientationchange', this.onResize);
}
if (!this.listeners.includes(listener)) this.listeners.push(listener);
};

dismiss = (listener: ResizeListener) => {
this.listeners = this.listeners.filter((l) => l !== listener);
if (!this.listeners.length) {
window.removeEventListener(device.mobile ? 'orientationchange' : 'resize', this.onResize);
window.removeEventListener('resize', this.onResize);
if (device.mobile) window.removeEventListener('orientationchange', this.onResize);
}
};
}

export default new ResizeService();
const ResizeService = new Service();

export default ResizeService;
6 changes: 4 additions & 2 deletions src/services/scroll.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
type ScrollListener = (e?: Event) => void;

class ScrollService {
class Service {
listeners: ScrollListener[] = [];

onScroll = (e: Event) => {
Expand All @@ -22,4 +22,6 @@ class ScrollService {
};
}

export default new ScrollService();
const ScrollService = new Service();

export default ScrollService;
8 changes: 5 additions & 3 deletions src/services/visibility.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
type VisibilityListener = (e?: Event) => void;
type VisibilityListener = ((e: Event) => void) | ((e?: Event) => void);

class VisibilityService {
class Service {
listeners: VisibilityListener[] = [];

onVisibility = (e: Event) => {
Expand All @@ -22,4 +22,6 @@ class VisibilityService {
};
}

export default new VisibilityService();
const VisibilityService = new Service();

export default VisibilityService;

0 comments on commit f8bb4f8

Please sign in to comment.