@wiggindev/utils 0.2.8 → 0.2.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,33 +1,40 @@
1
1
  {
2
- "name": "@wiggindev/utils",
3
- "description": "Various utilities that I use in my projects",
4
- "version": "0.2.8",
5
- "author": {
6
- "name": "Andrew Wiggin",
7
- "email": "andrew@wiggin.dev",
8
- "url": "https://wiggin.dev"
9
- },
10
- "repository": "git://github.com/wiggindev/utils",
11
- "type": "module",
12
- "source": "src/index.ts",
13
- "exports": {
14
- "require": "./dist/index.cjs",
15
- "default": "./dist/index.modern.js"
16
- },
17
- "main": "dist/index.cjs",
18
- "module": "dist/index.module.js",
19
- "unpkg": "dist/index.umd.js",
20
- "types": "dist/index.d.ts",
21
- "scripts": {
22
- "build": "rm -rf dist && microbundle",
23
- "dev": "rm -rf dist && microbundle watch"
24
- },
25
- "devDependencies": {
26
- "microbundle": "^0.15.0"
27
- },
28
- "packageManager": "yarn@3.2.1",
29
- "publishConfig": {
30
- "access": "public",
31
- "registry": "https://registry.npmjs.org/"
32
- }
33
- }
2
+ "name": "@wiggindev/utils",
3
+ "description": "Various utilities that I use in my projects",
4
+ "version": "0.2.13",
5
+ "author": {
6
+ "name": "Andrew Wiggin",
7
+ "email": "andrew@wiggin.dev",
8
+ "url": "https://wiggin.dev"
9
+ },
10
+ "repository": {
11
+ "type": "git",
12
+ "url": "https://github.com/wiggindev/-wiggindev.git",
13
+ "directory": "packages/utils"
14
+ },
15
+ "files": [
16
+ "dist",
17
+ "README.md"
18
+ ],
19
+ "type": "module",
20
+ "source": "src/index.ts",
21
+ "exports": {
22
+ "require": "./dist/index.cjs",
23
+ "default": "./dist/index.modern.js"
24
+ },
25
+ "main": "dist/index.cjs",
26
+ "module": "dist/index.module.js",
27
+ "unpkg": "dist/index.umd.js",
28
+ "types": "dist/index.d.ts",
29
+ "scripts": {
30
+ "clean": "rm -rf dist",
31
+ "build": "yarn clean && microbundle",
32
+ "dev": "microbundle watch"
33
+ },
34
+ "devDependencies": {
35
+ "microbundle": "^0.15.0"
36
+ },
37
+ "publishConfig": {
38
+ "access": "public"
39
+ }
40
+ }
@@ -1,5 +0,0 @@
1
- import { EventListener, EventName } from './eventTypes';
2
- export declare const on: <E extends EventName<DocumentEventMap>>(event: E, listener: EventListener<DocumentEventMap, E>) => void;
3
- export declare const off: <E extends EventName<DocumentEventMap>>(event: E, listener: EventListener<DocumentEventMap, E>) => void;
4
- export declare const once: <E extends EventName<DocumentEventMap>>(event: E, listener: EventListener<DocumentEventMap, E>) => void;
5
- export declare const trigger: (event: string) => void;
@@ -1,5 +0,0 @@
1
- import { EventListener, EventName } from './eventTypes';
2
- export declare const on: <E extends EventName<HTMLElementEventMap>>(element: HTMLElement, event: E, listener: EventListener<HTMLElementEventMap, E>) => void;
3
- export declare const off: <E extends EventName<HTMLElementEventMap>>(element: HTMLElement, event: E, listener: EventListener<HTMLElementEventMap, E>) => void;
4
- export declare const once: <E extends EventName<HTMLElementEventMap>>(element: HTMLElement, event: E, listener: EventListener<HTMLElementEventMap, E>) => void;
5
- export declare const trigger: (element: HTMLElement, event: string) => void;
@@ -1,6 +0,0 @@
1
- import { LiteralUnion } from '../types/LiteralUnion';
2
- declare type EventMap = WindowEventMap | DocumentEventMap | HTMLElementEventMap;
3
- export declare type EventName<M extends EventMap> = LiteralUnion<keyof M, string>;
4
- export declare type EventListener<M extends EventMap, N extends EventName<M>> = (event: N extends keyof M ? M[N] : Event) => void;
5
- export declare type DomEventListener = (event: Event) => void;
6
- export {};
@@ -1,9 +0,0 @@
1
- import * as documentEvents from './document';
2
- import * as windowEvents from './window';
3
- import * as elementEvents from './element';
4
- export declare const events: {
5
- document: typeof documentEvents;
6
- window: typeof windowEvents;
7
- element: typeof elementEvents;
8
- };
9
- export type { EventListener, EventName } from './eventTypes';
@@ -1,5 +0,0 @@
1
- import { EventListener, EventName } from './eventTypes';
2
- export declare const on: <E extends EventName<WindowEventMap>>(event: E, listener: EventListener<WindowEventMap, E>) => void;
3
- export declare const off: <E extends EventName<WindowEventMap>>(event: E, listener: EventListener<WindowEventMap, E>) => void;
4
- export declare const once: <E extends EventName<WindowEventMap>>(event: E, listener: EventListener<WindowEventMap, E>) => void;
5
- export declare const trigger: (event: string) => void;
package/dist/index.cjs DELETED
@@ -1,2 +0,0 @@
1
- var n=function(n,t){document.addEventListener(n,t)},t=function(n,t){document.removeEventListener(n,t)},e=function(n,t){window.addEventListener(n,t)},o=function(n,t){window.removeEventListener(n,t)},i=function(n,t,e){n.addEventListener(t,e)},r=function(n,t,e){n.removeEventListener(t,e)};exports.events={document:{__proto__:null,on:n,off:t,once:function(e,o){n(e,function n(i){o(i),t(e,n)})},trigger:function(n){var t=new CustomEvent(n);document.dispatchEvent(t)}},window:{__proto__:null,on:e,off:o,once:function(n,t){e(n,function e(i){t(i),o(n,e)})},trigger:function(n){var t=new CustomEvent(n);window.dispatchEvent(t)}},element:{__proto__:null,on:i,off:r,once:function(n,t,e){i(n,t,function o(i){e(i),r(n,t,o)})},trigger:function(n,t){var e=new CustomEvent(t);n.dispatchEvent(e)}}},exports.noop=function(){},exports.throttle=function(n,t){var e,o;return function(){return e||(e=!0,setTimeout(function(){return e=!1},t),o=n.apply(void 0,[].slice.call(arguments))),o}};
2
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.cjs","sources":["../src/events/document.ts","../src/events/window.ts","../src/events/element.ts","../src/events/index.ts","../src/noop.ts","../src/throttle.ts"],"sourcesContent":["import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n document.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n document.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n const wrappedListener: EventListener<DocumentEventMap, E> = e => {\n listener(e);\n off(event, wrappedListener);\n };\n on(event, wrappedListener);\n};\n\nexport const trigger = (event: string) => {\n const customEvent = new CustomEvent(event);\n document.dispatchEvent(customEvent);\n};\n","import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n window.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n window.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n const wrappedListener: EventListener<WindowEventMap, E> = e => {\n listener(e);\n off(event, wrappedListener);\n };\n on(event, wrappedListener);\n};\n\nexport const trigger = (event: string) => {\n const customEvent = new CustomEvent(event);\n window.dispatchEvent(customEvent);\n};\n","import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n element.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n element.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n const wrappedListener: EventListener<HTMLElementEventMap, E> = e => {\n listener(e);\n off(element, event, wrappedListener);\n };\n on(element, event, wrappedListener);\n};\n\nexport const trigger = (element: HTMLElement, event: string) => {\n const customEvent = new CustomEvent(event);\n element.dispatchEvent(customEvent);\n};\n","import * as documentEvents from './document';\nimport * as windowEvents from './window';\nimport * as elementEvents from './element';\n\nexport const events = {\n document: documentEvents,\n window: windowEvents,\n element: elementEvents,\n};\n\nexport type { EventListener, EventName } from './eventTypes';\n","export const noop = () => undefined;\n","import { Callback } from './types';\n\ntype ThrottledFunction<C extends Callback> = (\n ...args: Parameters<C>\n) => ReturnType<C>;\n\nexport const throttle = <C extends Callback>(\n callback: C,\n limit: number\n): ThrottledFunction<C> => {\n let waiting: boolean;\n let prev: ReturnType<C>;\n return (...args: Parameters<C>) => {\n if (!waiting) {\n waiting = true;\n setTimeout(() => (waiting = false), limit);\n prev = callback.apply(this, args) as ReturnType<C>;\n }\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return prev;\n };\n};\n"],"names":["on","event","listener","document","addEventListener","off","removeEventListener","window","element","wrappedListener","e","customEvent","CustomEvent","dispatchEvent","callback","limit","waiting","prev","setTimeout","apply","slice","call","arguments"],"mappings":"AAEO,IAAMA,EAAK,SACdC,EACAC,GAEAC,SAASC,iBAAiBH,EAAOC,IAGxBG,EAAM,SACfJ,EACAC,GAEAC,SAASG,oBAAoBL,EAAOC,ICX3BF,EAAK,SACdC,EACAC,GAEAK,OAAOH,iBAAiBH,EAAOC,IAGtBG,EAAM,SACfJ,EACAC,GAEAK,OAAOD,oBAAoBL,EAAOC,ICXzBF,EAAK,SACdQ,EACAP,EACAC,GAEAM,EAAQJ,iBAAiBH,EAAOC,IAGvBG,EAAM,SACfG,EACAP,EACAC,GAEAM,EAAQF,oBAAoBL,EAAOC,mBCXjB,CAClBC,yCHWgB,SAChBF,EACAC,GAMAF,EAAGC,EAJyD,SAAtDQ,EAAsDC,GACxDR,EAASQ,GACTL,EAAIJ,EAAOQ,cAKI,SAACR,GACpB,IAAMU,EAAc,IAAIC,YAAYX,GACpCE,SAASU,cAAcF,KGvBvBJ,uCFUgB,SAChBN,EACAC,GAMAF,EAAGC,EAJuD,SAApDQ,EAAoDC,GACtDR,EAASQ,GACTL,EAAIJ,EAAOQ,cAKI,SAACR,GACpB,IAAMU,EAAc,IAAIC,YAAYX,GACpCM,OAAOM,cAAcF,KEtBrBH,wCDWgB,SAChBA,EACAP,EACAC,GAMAF,EAAGQ,EAASP,EAJmD,SAAzDQ,EAAyDC,GAC3DR,EAASQ,GACTL,EAAIG,EAASP,EAAOQ,cAKL,SAACD,EAAsBP,GAC1C,IAAMU,EAAc,IAAIC,YAAYX,GACpCO,EAAQK,cAAcF,mBEhCN,8BCMI,SACpBG,EACAC,GAEA,IAAIC,EACAC,EACJ,OAAO,WAOH,OANKD,IACDA,GAAU,EACVE,WAAW,WAAA,OAAOF,GAAU,GAAQD,GACpCE,EAAOH,EAASK,aACnB,GAAAC,MAAAC,KAAAC,aAEML"}
package/dist/index.d.ts DELETED
@@ -1,5 +0,0 @@
1
- export { events } from './events';
2
- export type { EventName, EventListener } from './events';
3
- export type { LiteralUnion, Callback } from './types';
4
- export { throttle } from './throttle';
5
- export { noop } from './noop';
@@ -1,2 +0,0 @@
1
- const e=(e,n)=>{document.addEventListener(e,n)},n=(e,n)=>{document.removeEventListener(e,n)},t=(e,n)=>{window.addEventListener(e,n)},o=(e,n)=>{window.removeEventListener(e,n)},r=(e,n,t)=>{e.addEventListener(n,t)},s=(e,n,t)=>{e.removeEventListener(n,t)},d={document:{__proto__:null,on:e,off:n,once:(t,o)=>{const r=e=>{o(e),n(t,r)};e(t,r)},trigger:e=>{const n=new CustomEvent(e);document.dispatchEvent(n)}},window:{__proto__:null,on:t,off:o,once:(e,n)=>{const r=t=>{n(t),o(e,r)};t(e,r)},trigger:e=>{const n=new CustomEvent(e);window.dispatchEvent(n)}},element:{__proto__:null,on:r,off:s,once:(e,n,t)=>{const o=r=>{t(r),s(e,n,o)};r(e,n,o)},trigger:(e,n)=>{const t=new CustomEvent(n);e.dispatchEvent(t)}}},i=(e,n)=>{let t,o;return(...r)=>(t||(t=!0,setTimeout(()=>t=!1,n),o=e.apply(void 0,r)),o)},c=()=>{};export{d as events,c as noop,i as throttle};
2
- //# sourceMappingURL=index.modern.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.modern.js","sources":["../src/events/document.ts","../src/events/window.ts","../src/events/element.ts","../src/events/index.ts","../src/throttle.ts","../src/noop.ts"],"sourcesContent":["import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n document.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n document.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n const wrappedListener: EventListener<DocumentEventMap, E> = e => {\n listener(e);\n off(event, wrappedListener);\n };\n on(event, wrappedListener);\n};\n\nexport const trigger = (event: string) => {\n const customEvent = new CustomEvent(event);\n document.dispatchEvent(customEvent);\n};\n","import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n window.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n window.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n const wrappedListener: EventListener<WindowEventMap, E> = e => {\n listener(e);\n off(event, wrappedListener);\n };\n on(event, wrappedListener);\n};\n\nexport const trigger = (event: string) => {\n const customEvent = new CustomEvent(event);\n window.dispatchEvent(customEvent);\n};\n","import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n element.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n element.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n const wrappedListener: EventListener<HTMLElementEventMap, E> = e => {\n listener(e);\n off(element, event, wrappedListener);\n };\n on(element, event, wrappedListener);\n};\n\nexport const trigger = (element: HTMLElement, event: string) => {\n const customEvent = new CustomEvent(event);\n element.dispatchEvent(customEvent);\n};\n","import * as documentEvents from './document';\nimport * as windowEvents from './window';\nimport * as elementEvents from './element';\n\nexport const events = {\n document: documentEvents,\n window: windowEvents,\n element: elementEvents,\n};\n\nexport type { EventListener, EventName } from './eventTypes';\n","import { Callback } from './types';\n\ntype ThrottledFunction<C extends Callback> = (\n ...args: Parameters<C>\n) => ReturnType<C>;\n\nexport const throttle = <C extends Callback>(\n callback: C,\n limit: number\n): ThrottledFunction<C> => {\n let waiting: boolean;\n let prev: ReturnType<C>;\n return (...args: Parameters<C>) => {\n if (!waiting) {\n waiting = true;\n setTimeout(() => (waiting = false), limit);\n prev = callback.apply(this, args) as ReturnType<C>;\n }\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return prev;\n };\n};\n","export const noop = () => undefined;\n"],"names":["on","event","listener","document","addEventListener","off","removeEventListener","window","element","events","wrappedListener","e","customEvent","CustomEvent","dispatchEvent","throttle","callback","limit","waiting","prev","args","setTimeout","apply","this","noop"],"mappings":"AAEO,MAAMA,EAAK,CACdC,EACAC,KAEAC,SAASC,iBAAiBH,EAAOC,IAGxBG,EAAM,CACfJ,EACAC,KAEAC,SAASG,oBAAoBL,EAAOC,ICX3BF,EAAK,CACdC,EACAC,KAEAK,OAAOH,iBAAiBH,EAAOC,IAGtBG,EAAM,CACfJ,EACAC,KAEAK,OAAOD,oBAAoBL,EAAOC,ICXzBF,EAAK,CACdQ,EACAP,EACAC,KAEAM,EAAQJ,iBAAiBH,EAAOC,IAGvBG,EAAM,CACfG,EACAP,EACAC,KAEAM,EAAQF,oBAAoBL,EAAOC,ICX1BO,EAAS,CAClBN,yCHWgB,CAChBF,EACAC,KAEA,MAAMQ,EAAsDC,IACxDT,EAASS,GACTN,EAAIJ,EAAOS,IAEfV,EAAGC,EAAOS,YAGUT,IACpB,MAAMW,EAAc,IAAIC,YAAYZ,GACpCE,SAASW,cAAcF,KGvBvBL,uCFUgB,CAChBN,EACAC,KAEA,MAAMQ,EAAoDC,IACtDT,EAASS,GACTN,EAAIJ,EAAOS,IAEfV,EAAGC,EAAOS,YAGUT,IACpB,MAAMW,EAAc,IAAIC,YAAYZ,GACpCM,OAAOO,cAAcF,KEtBrBJ,wCDWgB,CAChBA,EACAP,EACAC,KAEA,MAAMQ,EAAyDC,IAC3DT,EAASS,GACTN,EAAIG,EAASP,EAAOS,IAExBV,EAAGQ,EAASP,EAAOS,YAGA,CAACF,EAAsBP,KAC1C,MAAMW,EAAc,IAAIC,YAAYZ,GACpCO,EAAQM,cAAcF,ME1BbG,EAAW,CACpBC,EACAC,KAEA,IAAIC,EACAC,EACJ,MAAO,IAAIC,KACFF,IACDA,GAAU,EACVG,WAAW,IAAOH,GAAU,EAAQD,GACpCE,EAAOH,EAASM,WAAMC,EAAMH,IAGzBD,ICnBFK,EAAO"}
@@ -1,2 +0,0 @@
1
- var n=function(n,t){document.addEventListener(n,t)},t=function(n,t){document.removeEventListener(n,t)},e=function(n,t){window.addEventListener(n,t)},o=function(n,t){window.removeEventListener(n,t)},i=function(n,t,e){n.addEventListener(t,e)},u=function(n,t,e){n.removeEventListener(t,e)},c={document:{__proto__:null,on:n,off:t,once:function(e,o){n(e,function n(i){o(i),t(e,n)})},trigger:function(n){var t=new CustomEvent(n);document.dispatchEvent(t)}},window:{__proto__:null,on:e,off:o,once:function(n,t){e(n,function e(i){t(i),o(n,e)})},trigger:function(n){var t=new CustomEvent(n);window.dispatchEvent(t)}},element:{__proto__:null,on:i,off:u,once:function(n,t,e){i(n,t,function o(i){e(i),u(n,t,o)})},trigger:function(n,t){var e=new CustomEvent(t);n.dispatchEvent(e)}}},r=function(n,t){var e,o;return function(){return e||(e=!0,setTimeout(function(){return e=!1},t),o=n.apply(void 0,[].slice.call(arguments))),o}},f=function(){};export{c as events,f as noop,r as throttle};
2
- //# sourceMappingURL=index.module.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.module.js","sources":["../src/events/document.ts","../src/events/window.ts","../src/events/element.ts","../src/events/index.ts","../src/throttle.ts","../src/noop.ts"],"sourcesContent":["import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n document.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n document.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n const wrappedListener: EventListener<DocumentEventMap, E> = e => {\n listener(e);\n off(event, wrappedListener);\n };\n on(event, wrappedListener);\n};\n\nexport const trigger = (event: string) => {\n const customEvent = new CustomEvent(event);\n document.dispatchEvent(customEvent);\n};\n","import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n window.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n window.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n const wrappedListener: EventListener<WindowEventMap, E> = e => {\n listener(e);\n off(event, wrappedListener);\n };\n on(event, wrappedListener);\n};\n\nexport const trigger = (event: string) => {\n const customEvent = new CustomEvent(event);\n window.dispatchEvent(customEvent);\n};\n","import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n element.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n element.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n const wrappedListener: EventListener<HTMLElementEventMap, E> = e => {\n listener(e);\n off(element, event, wrappedListener);\n };\n on(element, event, wrappedListener);\n};\n\nexport const trigger = (element: HTMLElement, event: string) => {\n const customEvent = new CustomEvent(event);\n element.dispatchEvent(customEvent);\n};\n","import * as documentEvents from './document';\nimport * as windowEvents from './window';\nimport * as elementEvents from './element';\n\nexport const events = {\n document: documentEvents,\n window: windowEvents,\n element: elementEvents,\n};\n\nexport type { EventListener, EventName } from './eventTypes';\n","import { Callback } from './types';\n\ntype ThrottledFunction<C extends Callback> = (\n ...args: Parameters<C>\n) => ReturnType<C>;\n\nexport const throttle = <C extends Callback>(\n callback: C,\n limit: number\n): ThrottledFunction<C> => {\n let waiting: boolean;\n let prev: ReturnType<C>;\n return (...args: Parameters<C>) => {\n if (!waiting) {\n waiting = true;\n setTimeout(() => (waiting = false), limit);\n prev = callback.apply(this, args) as ReturnType<C>;\n }\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return prev;\n };\n};\n","export const noop = () => undefined;\n"],"names":["on","event","listener","document","addEventListener","off","removeEventListener","window","element","events","wrappedListener","e","customEvent","CustomEvent","dispatchEvent","throttle","callback","limit","waiting","prev","setTimeout","apply","slice","call","arguments","noop"],"mappings":"AAEO,IAAMA,EAAK,SACdC,EACAC,GAEAC,SAASC,iBAAiBH,EAAOC,IAGxBG,EAAM,SACfJ,EACAC,GAEAC,SAASG,oBAAoBL,EAAOC,ICX3BF,EAAK,SACdC,EACAC,GAEAK,OAAOH,iBAAiBH,EAAOC,IAGtBG,EAAM,SACfJ,EACAC,GAEAK,OAAOD,oBAAoBL,EAAOC,ICXzBF,EAAK,SACdQ,EACAP,EACAC,GAEAM,EAAQJ,iBAAiBH,EAAOC,IAGvBG,EAAM,SACfG,EACAP,EACAC,GAEAM,EAAQF,oBAAoBL,EAAOC,ICX1BO,EAAS,CAClBN,yCHWgB,SAChBF,EACAC,GAMAF,EAAGC,EAJyD,SAAtDS,EAAsDC,GACxDT,EAASS,GACTN,EAAIJ,EAAOS,cAKI,SAACT,GACpB,IAAMW,EAAc,IAAIC,YAAYZ,GACpCE,SAASW,cAAcF,KGvBvBL,uCFUgB,SAChBN,EACAC,GAMAF,EAAGC,EAJuD,SAApDS,EAAoDC,GACtDT,EAASS,GACTN,EAAIJ,EAAOS,cAKI,SAACT,GACpB,IAAMW,EAAc,IAAIC,YAAYZ,GACpCM,OAAOO,cAAcF,KEtBrBJ,wCDWgB,SAChBA,EACAP,EACAC,GAMAF,EAAGQ,EAASP,EAJmD,SAAzDS,EAAyDC,GAC3DT,EAASS,GACTN,EAAIG,EAASP,EAAOS,cAKL,SAACF,EAAsBP,GAC1C,IAAMW,EAAc,IAAIC,YAAYZ,GACpCO,EAAQM,cAAcF,ME1BbG,EAAW,SACpBC,EACAC,GAEA,IAAIC,EACAC,EACJ,OAAO,WAOH,OANKD,IACDA,GAAU,EACVE,WAAW,WAAA,OAAOF,GAAU,GAAQD,GACpCE,EAAOH,EAASK,aACnB,GAAAC,MAAAC,KAAAC,aAEML,ICnBFM,EAAO"}
package/dist/index.umd.js DELETED
@@ -1,2 +0,0 @@
1
- !function(n,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((n||self).utils={})}(this,function(n){var t=function(n,t){document.addEventListener(n,t)},e=function(n,t){document.removeEventListener(n,t)},o=function(n,t){window.addEventListener(n,t)},i=function(n,t){window.removeEventListener(n,t)},u=function(n,t,e){n.addEventListener(t,e)},f=function(n,t,e){n.removeEventListener(t,e)},c=void 0;n.events={document:{__proto__:null,on:t,off:e,once:function(n,o){t(n,function t(i){o(i),e(n,t)})},trigger:function(n){var t=new CustomEvent(n);document.dispatchEvent(t)}},window:{__proto__:null,on:o,off:i,once:function(n,t){o(n,function e(o){t(o),i(n,e)})},trigger:function(n){var t=new CustomEvent(n);window.dispatchEvent(t)}},element:{__proto__:null,on:u,off:f,once:function(n,t,e){u(n,t,function o(i){e(i),f(n,t,o)})},trigger:function(n,t){var e=new CustomEvent(t);n.dispatchEvent(e)}}},n.noop=function(){},n.throttle=function(n,t){var e,o;return function(){return e||(e=!0,setTimeout(function(){return e=!1},t),o=n.apply(c,[].slice.call(arguments))),o}}});
2
- //# sourceMappingURL=index.umd.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.umd.js","sources":["../src/events/document.ts","../src/events/window.ts","../src/events/element.ts","../src/events/index.ts","../src/noop.ts","../src/throttle.ts"],"sourcesContent":["import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n document.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n document.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<DocumentEventMap>>(\n event: E,\n listener: EventListener<DocumentEventMap, E>\n) => {\n const wrappedListener: EventListener<DocumentEventMap, E> = e => {\n listener(e);\n off(event, wrappedListener);\n };\n on(event, wrappedListener);\n};\n\nexport const trigger = (event: string) => {\n const customEvent = new CustomEvent(event);\n document.dispatchEvent(customEvent);\n};\n","import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n window.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n window.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<WindowEventMap>>(\n event: E,\n listener: EventListener<WindowEventMap, E>\n) => {\n const wrappedListener: EventListener<WindowEventMap, E> = e => {\n listener(e);\n off(event, wrappedListener);\n };\n on(event, wrappedListener);\n};\n\nexport const trigger = (event: string) => {\n const customEvent = new CustomEvent(event);\n window.dispatchEvent(customEvent);\n};\n","import { EventListener, EventName, DomEventListener } from './eventTypes';\n\nexport const on = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n element.addEventListener(event, listener as DomEventListener);\n};\n\nexport const off = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n element.removeEventListener(event, listener as DomEventListener);\n};\n\nexport const once = <E extends EventName<HTMLElementEventMap>>(\n element: HTMLElement,\n event: E,\n listener: EventListener<HTMLElementEventMap, E>\n) => {\n const wrappedListener: EventListener<HTMLElementEventMap, E> = e => {\n listener(e);\n off(element, event, wrappedListener);\n };\n on(element, event, wrappedListener);\n};\n\nexport const trigger = (element: HTMLElement, event: string) => {\n const customEvent = new CustomEvent(event);\n element.dispatchEvent(customEvent);\n};\n","import * as documentEvents from './document';\nimport * as windowEvents from './window';\nimport * as elementEvents from './element';\n\nexport const events = {\n document: documentEvents,\n window: windowEvents,\n element: elementEvents,\n};\n\nexport type { EventListener, EventName } from './eventTypes';\n","export const noop = () => undefined;\n","import { Callback } from './types';\n\ntype ThrottledFunction<C extends Callback> = (\n ...args: Parameters<C>\n) => ReturnType<C>;\n\nexport const throttle = <C extends Callback>(\n callback: C,\n limit: number\n): ThrottledFunction<C> => {\n let waiting: boolean;\n let prev: ReturnType<C>;\n return (...args: Parameters<C>) => {\n if (!waiting) {\n waiting = true;\n setTimeout(() => (waiting = false), limit);\n prev = callback.apply(this, args) as ReturnType<C>;\n }\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return prev;\n };\n};\n"],"names":["on","event","listener","document","addEventListener","off","removeEventListener","window","element","wrappedListener","e","customEvent","CustomEvent","dispatchEvent","callback","limit","waiting","prev","setTimeout","apply","_this","slice","call","arguments"],"mappings":"+NAEO,IAAMA,EAAK,SACdC,EACAC,GAEAC,SAASC,iBAAiBH,EAAOC,IAGxBG,EAAM,SACfJ,EACAC,GAEAC,SAASG,oBAAoBL,EAAOC,ICX3BF,EAAK,SACdC,EACAC,GAEAK,OAAOH,iBAAiBH,EAAOC,IAGtBG,EAAM,SACfJ,EACAC,GAEAK,OAAOD,oBAAoBL,EAAOC,ICXzBF,EAAK,SACdQ,EACAP,EACAC,GAEAM,EAAQJ,iBAAiBH,EAAOC,IAGvBG,EAAM,SACfG,EACAP,EACAC,GAEAM,EAAQF,oBAAoBL,EAAOC,sBCXjB,CAClBC,yCHWgB,SAChBF,EACAC,GAMAF,EAAGC,EAJyD,SAAtDQ,EAAsDC,GACxDR,EAASQ,GACTL,EAAIJ,EAAOQ,cAKI,SAACR,GACpB,IAAMU,EAAc,IAAIC,YAAYX,GACpCE,SAASU,cAAcF,KGvBvBJ,uCFUgB,SAChBN,EACAC,GAMAF,EAAGC,EAJuD,SAApDQ,EAAoDC,GACtDR,EAASQ,GACTL,EAAIJ,EAAOQ,cAKI,SAACR,GACpB,IAAMU,EAAc,IAAIC,YAAYX,GACpCM,OAAOM,cAAcF,KEtBrBH,wCDWgB,SAChBA,EACAP,EACAC,GAMAF,EAAGQ,EAASP,EAJmD,SAAzDQ,EAAyDC,GAC3DR,EAASQ,GACTL,EAAIG,EAASP,EAAOQ,cAKL,SAACD,EAAsBP,GAC1C,IAAMU,EAAc,IAAIC,YAAYX,GACpCO,EAAQK,cAAcF,aEhCN,wBCMI,SACpBG,EACAC,GAEA,IAAIC,EACAC,EACJ,OAAO,WAOH,OANKD,IACDA,GAAU,EACVE,WAAW,WAAA,OAAOF,GAAU,GAAQD,GACpCE,EAAOH,EAASK,MAAMC,EACzB,GAAAC,MAAAC,KAAAC,aAEMN"}
package/dist/noop.d.ts DELETED
@@ -1 +0,0 @@
1
- export declare const noop: () => undefined;
@@ -1,4 +0,0 @@
1
- import { Callback } from './types';
2
- declare type ThrottledFunction<C extends Callback> = (...args: Parameters<C>) => ReturnType<C>;
3
- export declare const throttle: <C extends Callback>(callback: C, limit: number) => ThrottledFunction<C>;
4
- export {};
@@ -1 +0,0 @@
1
- export declare type Callback = (...args: any) => any;
@@ -1,4 +0,0 @@
1
- /** from type-fest: https://github.com/sindresorhus/type-fest/blob/main/source/literal-union.d.ts */
2
- declare type Primitive = null | undefined | string | number | boolean | symbol | bigint;
3
- export declare type LiteralUnion<LiteralType, BaseType extends Primitive> = LiteralType | (BaseType & Record<never, never>);
4
- export {};
@@ -1,2 +0,0 @@
1
- export type { LiteralUnion } from './LiteralUnion';
2
- export type { Callback } from './Callback';
@@ -1,31 +0,0 @@
1
- import { EventListener, EventName, DomEventListener } from './eventTypes';
2
-
3
- export const on = <E extends EventName<DocumentEventMap>>(
4
- event: E,
5
- listener: EventListener<DocumentEventMap, E>
6
- ) => {
7
- document.addEventListener(event, listener as DomEventListener);
8
- };
9
-
10
- export const off = <E extends EventName<DocumentEventMap>>(
11
- event: E,
12
- listener: EventListener<DocumentEventMap, E>
13
- ) => {
14
- document.removeEventListener(event, listener as DomEventListener);
15
- };
16
-
17
- export const once = <E extends EventName<DocumentEventMap>>(
18
- event: E,
19
- listener: EventListener<DocumentEventMap, E>
20
- ) => {
21
- const wrappedListener: EventListener<DocumentEventMap, E> = e => {
22
- listener(e);
23
- off(event, wrappedListener);
24
- };
25
- on(event, wrappedListener);
26
- };
27
-
28
- export const trigger = (event: string) => {
29
- const customEvent = new CustomEvent(event);
30
- document.dispatchEvent(customEvent);
31
- };
@@ -1,34 +0,0 @@
1
- import { EventListener, EventName, DomEventListener } from './eventTypes';
2
-
3
- export const on = <E extends EventName<HTMLElementEventMap>>(
4
- element: HTMLElement,
5
- event: E,
6
- listener: EventListener<HTMLElementEventMap, E>
7
- ) => {
8
- element.addEventListener(event, listener as DomEventListener);
9
- };
10
-
11
- export const off = <E extends EventName<HTMLElementEventMap>>(
12
- element: HTMLElement,
13
- event: E,
14
- listener: EventListener<HTMLElementEventMap, E>
15
- ) => {
16
- element.removeEventListener(event, listener as DomEventListener);
17
- };
18
-
19
- export const once = <E extends EventName<HTMLElementEventMap>>(
20
- element: HTMLElement,
21
- event: E,
22
- listener: EventListener<HTMLElementEventMap, E>
23
- ) => {
24
- const wrappedListener: EventListener<HTMLElementEventMap, E> = e => {
25
- listener(e);
26
- off(element, event, wrappedListener);
27
- };
28
- on(element, event, wrappedListener);
29
- };
30
-
31
- export const trigger = (element: HTMLElement, event: string) => {
32
- const customEvent = new CustomEvent(event);
33
- element.dispatchEvent(customEvent);
34
- };
@@ -1,9 +0,0 @@
1
- import { LiteralUnion } from '../types/LiteralUnion';
2
-
3
- type EventMap = WindowEventMap | DocumentEventMap | HTMLElementEventMap;
4
-
5
- export type EventName<M extends EventMap> = LiteralUnion<keyof M, string>;
6
- export type EventListener<M extends EventMap, N extends EventName<M>> = (
7
- event: N extends keyof M ? M[N] : Event
8
- ) => void;
9
- export type DomEventListener = (event: Event) => void;
@@ -1,11 +0,0 @@
1
- import * as documentEvents from './document';
2
- import * as windowEvents from './window';
3
- import * as elementEvents from './element';
4
-
5
- export const events = {
6
- document: documentEvents,
7
- window: windowEvents,
8
- element: elementEvents,
9
- };
10
-
11
- export type { EventListener, EventName } from './eventTypes';
@@ -1,31 +0,0 @@
1
- import { EventListener, EventName, DomEventListener } from './eventTypes';
2
-
3
- export const on = <E extends EventName<WindowEventMap>>(
4
- event: E,
5
- listener: EventListener<WindowEventMap, E>
6
- ) => {
7
- window.addEventListener(event, listener as DomEventListener);
8
- };
9
-
10
- export const off = <E extends EventName<WindowEventMap>>(
11
- event: E,
12
- listener: EventListener<WindowEventMap, E>
13
- ) => {
14
- window.removeEventListener(event, listener as DomEventListener);
15
- };
16
-
17
- export const once = <E extends EventName<WindowEventMap>>(
18
- event: E,
19
- listener: EventListener<WindowEventMap, E>
20
- ) => {
21
- const wrappedListener: EventListener<WindowEventMap, E> = e => {
22
- listener(e);
23
- off(event, wrappedListener);
24
- };
25
- on(event, wrappedListener);
26
- };
27
-
28
- export const trigger = (event: string) => {
29
- const customEvent = new CustomEvent(event);
30
- window.dispatchEvent(customEvent);
31
- };
package/src/index.ts DELETED
@@ -1,5 +0,0 @@
1
- export { events } from './events';
2
- export type { EventName, EventListener } from './events';
3
- export type { LiteralUnion, Callback } from './types';
4
- export { throttle } from './throttle';
5
- export { noop } from './noop';
package/src/noop.ts DELETED
@@ -1 +0,0 @@
1
- export const noop = () => undefined;
package/src/throttle.ts DELETED
@@ -1,22 +0,0 @@
1
- import { Callback } from './types';
2
-
3
- type ThrottledFunction<C extends Callback> = (
4
- ...args: Parameters<C>
5
- ) => ReturnType<C>;
6
-
7
- export const throttle = <C extends Callback>(
8
- callback: C,
9
- limit: number
10
- ): ThrottledFunction<C> => {
11
- let waiting: boolean;
12
- let prev: ReturnType<C>;
13
- return (...args: Parameters<C>) => {
14
- if (!waiting) {
15
- waiting = true;
16
- setTimeout(() => (waiting = false), limit);
17
- prev = callback.apply(this, args) as ReturnType<C>;
18
- }
19
- // eslint-disable-next-line @typescript-eslint/no-unsafe-return
20
- return prev;
21
- };
22
- };
@@ -1,2 +0,0 @@
1
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
2
- export type Callback = (...args: any) => any;
@@ -1,7 +0,0 @@
1
- /** from type-fest: https://github.com/sindresorhus/type-fest/blob/main/source/literal-union.d.ts */
2
-
3
- type Primitive = null | undefined | string | number | boolean | symbol | bigint;
4
-
5
- export type LiteralUnion<LiteralType, BaseType extends Primitive> =
6
- | LiteralType
7
- | (BaseType & Record<never, never>);
@@ -1,2 +0,0 @@
1
- export type { LiteralUnion } from './LiteralUnion';
2
- export type { Callback } from './Callback';
package/tsconfig.json DELETED
@@ -1,8 +0,0 @@
1
- {
2
- "extends": "../../tsconfig.json",
3
- "compilerOptions": {
4
- "outDir": "dist"
5
- },
6
- "include": ["src/**/*"],
7
- "exclude": ["dist"]
8
- }