@wiggindev/utils 0.2.2 → 0.2.5
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/dist/events/document.d.ts +14 -5
- package/dist/events/element.d.ts +17 -5
- package/dist/events/eventTypes.d.ts +12 -6
- package/dist/events/index.d.ts +9 -9
- package/dist/events/window.d.ts +14 -5
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +5 -4
- package/dist/index.modern.js +77 -1
- package/dist/index.modern.js.map +1 -1
- package/dist/index.module.js +78 -1
- package/dist/index.module.js.map +1 -1
- package/dist/index.umd.js +86 -1
- package/dist/index.umd.js.map +1 -1
- package/dist/noop.d.ts +1 -1
- package/dist/throttle.d.ts +9 -4
- package/dist/types/Callback.d.ts +1 -1
- package/dist/types/LiteralUnion.d.ts +13 -4
- package/dist/types/index.d.ts +2 -2
- package/package.json +5 -25
- package/src/index.ts +1 -0
- package/src/throttle.ts +1 -1
- package/src/types/Callback.ts +1 -0
- package/tsconfig.json +3 -22
- package/.editorconfig +0 -10
- package/.eslintrc.cjs +0 -51
- package/.husky/pre-commit +0 -4
- package/.idea/modules.xml +0 -8
- package/.idea/utils.iml +0 -12
- package/.prettierignore +0 -2
- package/.prettierrc.json +0 -9
- package/.yarn/plugins/@yarnpkg/plugin-typescript.cjs +0 -9
- package/.yarn/plugins/@yarnpkg/plugin-version.cjs +0 -550
- package/.yarn/releases/yarn-3.2.1.cjs +0 -786
- package/.yarn/versions/0983ae7a.yml +0 -0
- package/.yarn/versions/8c37ee1f.yml +0 -0
- package/.yarn/versions/8f03c815.yml +0 -0
- package/.yarn/versions/bea7639b.yml +0 -0
- package/lint-staged.config.cjs +0 -9
@@ -1,5 +1,14 @@
|
|
1
|
-
import { EventListener, EventName } from './eventTypes';
|
2
|
-
export declare const on: <E extends EventName<DocumentEventMap>>(
|
3
|
-
|
4
|
-
|
5
|
-
|
1
|
+
import { EventListener, EventName } from './eventTypes';
|
2
|
+
export declare const on: <E extends EventName<DocumentEventMap>>(
|
3
|
+
event: E,
|
4
|
+
listener: EventListener<DocumentEventMap, E>
|
5
|
+
) => void;
|
6
|
+
export declare const off: <E extends EventName<DocumentEventMap>>(
|
7
|
+
event: E,
|
8
|
+
listener: EventListener<DocumentEventMap, E>
|
9
|
+
) => void;
|
10
|
+
export declare const once: <E extends EventName<DocumentEventMap>>(
|
11
|
+
event: E,
|
12
|
+
listener: EventListener<DocumentEventMap, E>
|
13
|
+
) => void;
|
14
|
+
export declare const trigger: (event: string) => void;
|
package/dist/events/element.d.ts
CHANGED
@@ -1,5 +1,17 @@
|
|
1
|
-
import { EventListener, EventName } from './eventTypes';
|
2
|
-
export declare const on: <E extends EventName<HTMLElementEventMap>>(
|
3
|
-
|
4
|
-
|
5
|
-
|
1
|
+
import { EventListener, EventName } from './eventTypes';
|
2
|
+
export declare const on: <E extends EventName<HTMLElementEventMap>>(
|
3
|
+
element: HTMLElement,
|
4
|
+
event: E,
|
5
|
+
listener: EventListener<HTMLElementEventMap, E>
|
6
|
+
) => void;
|
7
|
+
export declare const off: <E extends EventName<HTMLElementEventMap>>(
|
8
|
+
element: HTMLElement,
|
9
|
+
event: E,
|
10
|
+
listener: EventListener<HTMLElementEventMap, E>
|
11
|
+
) => void;
|
12
|
+
export declare const once: <E extends EventName<HTMLElementEventMap>>(
|
13
|
+
element: HTMLElement,
|
14
|
+
event: E,
|
15
|
+
listener: EventListener<HTMLElementEventMap, E>
|
16
|
+
) => void;
|
17
|
+
export declare const trigger: (element: HTMLElement, event: string) => void;
|
@@ -1,6 +1,12 @@
|
|
1
|
-
import { LiteralUnion } from '../types/LiteralUnion';
|
2
|
-
declare type EventMap = WindowEventMap | DocumentEventMap | HTMLElementEventMap;
|
3
|
-
export declare type EventName<M extends EventMap> = LiteralUnion<
|
4
|
-
|
5
|
-
|
6
|
-
|
1
|
+
import { LiteralUnion } from '../types/LiteralUnion';
|
2
|
+
declare type EventMap = WindowEventMap | DocumentEventMap | HTMLElementEventMap;
|
3
|
+
export declare type EventName<M extends EventMap> = LiteralUnion<
|
4
|
+
keyof M,
|
5
|
+
string
|
6
|
+
>;
|
7
|
+
export declare type EventListener<
|
8
|
+
M extends EventMap,
|
9
|
+
N extends EventName<M>
|
10
|
+
> = (event: N extends keyof M ? M[N] : Event) => void;
|
11
|
+
export declare type DomEventListener = (event: Event) => void;
|
12
|
+
export {};
|
package/dist/events/index.d.ts
CHANGED
@@ -1,9 +1,9 @@
|
|
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
|
+
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';
|
package/dist/events/window.d.ts
CHANGED
@@ -1,5 +1,14 @@
|
|
1
|
-
import { EventListener, EventName } from './eventTypes';
|
2
|
-
export declare const on: <E extends EventName<WindowEventMap>>(
|
3
|
-
|
4
|
-
|
5
|
-
|
1
|
+
import { EventListener, EventName } from './eventTypes';
|
2
|
+
export declare const on: <E extends EventName<WindowEventMap>>(
|
3
|
+
event: E,
|
4
|
+
listener: EventListener<WindowEventMap, E>
|
5
|
+
) => void;
|
6
|
+
export declare const off: <E extends EventName<WindowEventMap>>(
|
7
|
+
event: E,
|
8
|
+
listener: EventListener<WindowEventMap, E>
|
9
|
+
) => void;
|
10
|
+
export declare const once: <E extends EventName<WindowEventMap>>(
|
11
|
+
event: E,
|
12
|
+
listener: EventListener<WindowEventMap, E>
|
13
|
+
) => void;
|
14
|
+
export declare const trigger: (event: string) => void;
|
package/dist/index.cjs.map
CHANGED
@@ -1 +1 @@
|
|
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
|
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
CHANGED
@@ -1,4 +1,5 @@
|
|
1
|
-
export { events } from './events';
|
2
|
-
export type {
|
3
|
-
export {
|
4
|
-
export {
|
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/dist/index.modern.js
CHANGED
@@ -1,2 +1,78 @@
|
|
1
|
-
const e
|
1
|
+
const e = (e, n) => {
|
2
|
+
document.addEventListener(e, n);
|
3
|
+
},
|
4
|
+
n = (e, n) => {
|
5
|
+
document.removeEventListener(e, n);
|
6
|
+
},
|
7
|
+
t = (e, n) => {
|
8
|
+
window.addEventListener(e, n);
|
9
|
+
},
|
10
|
+
o = (e, n) => {
|
11
|
+
window.removeEventListener(e, n);
|
12
|
+
},
|
13
|
+
r = (e, n, t) => {
|
14
|
+
e.addEventListener(n, t);
|
15
|
+
},
|
16
|
+
s = (e, n, t) => {
|
17
|
+
e.removeEventListener(n, t);
|
18
|
+
},
|
19
|
+
d = {
|
20
|
+
document: {
|
21
|
+
__proto__: null,
|
22
|
+
on: e,
|
23
|
+
off: n,
|
24
|
+
once: (t, o) => {
|
25
|
+
const r = e => {
|
26
|
+
o(e), n(t, r);
|
27
|
+
};
|
28
|
+
e(t, r);
|
29
|
+
},
|
30
|
+
trigger: e => {
|
31
|
+
const n = new CustomEvent(e);
|
32
|
+
document.dispatchEvent(n);
|
33
|
+
},
|
34
|
+
},
|
35
|
+
window: {
|
36
|
+
__proto__: null,
|
37
|
+
on: t,
|
38
|
+
off: o,
|
39
|
+
once: (e, n) => {
|
40
|
+
const r = t => {
|
41
|
+
n(t), o(e, r);
|
42
|
+
};
|
43
|
+
t(e, r);
|
44
|
+
},
|
45
|
+
trigger: e => {
|
46
|
+
const n = new CustomEvent(e);
|
47
|
+
window.dispatchEvent(n);
|
48
|
+
},
|
49
|
+
},
|
50
|
+
element: {
|
51
|
+
__proto__: null,
|
52
|
+
on: r,
|
53
|
+
off: s,
|
54
|
+
once: (e, n, t) => {
|
55
|
+
const o = r => {
|
56
|
+
t(r), s(e, n, o);
|
57
|
+
};
|
58
|
+
r(e, n, o);
|
59
|
+
},
|
60
|
+
trigger: (e, n) => {
|
61
|
+
const t = new CustomEvent(n);
|
62
|
+
e.dispatchEvent(t);
|
63
|
+
},
|
64
|
+
},
|
65
|
+
},
|
66
|
+
i = (e, n) => {
|
67
|
+
let t, o;
|
68
|
+
return (...r) => (
|
69
|
+
t ||
|
70
|
+
((t = !0),
|
71
|
+
setTimeout(() => (t = !1), n),
|
72
|
+
(o = e.apply(void 0, r))),
|
73
|
+
o
|
74
|
+
);
|
75
|
+
},
|
76
|
+
c = () => {};
|
77
|
+
export { d as events, c as noop, i as throttle };
|
2
78
|
//# sourceMappingURL=index.modern.js.map
|
package/dist/index.modern.js.map
CHANGED
@@ -1 +1 @@
|
|
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
|
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"}
|
package/dist/index.module.js
CHANGED
@@ -1,2 +1,79 @@
|
|
1
|
-
var n
|
1
|
+
var n = function (n, t) {
|
2
|
+
document.addEventListener(n, t);
|
3
|
+
},
|
4
|
+
t = function (n, t) {
|
5
|
+
document.removeEventListener(n, t);
|
6
|
+
},
|
7
|
+
e = function (n, t) {
|
8
|
+
window.addEventListener(n, t);
|
9
|
+
},
|
10
|
+
o = function (n, t) {
|
11
|
+
window.removeEventListener(n, t);
|
12
|
+
},
|
13
|
+
i = function (n, t, e) {
|
14
|
+
n.addEventListener(t, e);
|
15
|
+
},
|
16
|
+
u = function (n, t, e) {
|
17
|
+
n.removeEventListener(t, e);
|
18
|
+
},
|
19
|
+
c = {
|
20
|
+
document: {
|
21
|
+
__proto__: null,
|
22
|
+
on: n,
|
23
|
+
off: t,
|
24
|
+
once: function (e, o) {
|
25
|
+
n(e, function n(i) {
|
26
|
+
o(i), t(e, n);
|
27
|
+
});
|
28
|
+
},
|
29
|
+
trigger: function (n) {
|
30
|
+
var t = new CustomEvent(n);
|
31
|
+
document.dispatchEvent(t);
|
32
|
+
},
|
33
|
+
},
|
34
|
+
window: {
|
35
|
+
__proto__: null,
|
36
|
+
on: e,
|
37
|
+
off: o,
|
38
|
+
once: function (n, t) {
|
39
|
+
e(n, function e(i) {
|
40
|
+
t(i), o(n, e);
|
41
|
+
});
|
42
|
+
},
|
43
|
+
trigger: function (n) {
|
44
|
+
var t = new CustomEvent(n);
|
45
|
+
window.dispatchEvent(t);
|
46
|
+
},
|
47
|
+
},
|
48
|
+
element: {
|
49
|
+
__proto__: null,
|
50
|
+
on: i,
|
51
|
+
off: u,
|
52
|
+
once: function (n, t, e) {
|
53
|
+
i(n, t, function o(i) {
|
54
|
+
e(i), u(n, t, o);
|
55
|
+
});
|
56
|
+
},
|
57
|
+
trigger: function (n, t) {
|
58
|
+
var e = new CustomEvent(t);
|
59
|
+
n.dispatchEvent(e);
|
60
|
+
},
|
61
|
+
},
|
62
|
+
},
|
63
|
+
r = function (n, t) {
|
64
|
+
var e, o;
|
65
|
+
return function () {
|
66
|
+
return (
|
67
|
+
e ||
|
68
|
+
((e = !0),
|
69
|
+
setTimeout(function () {
|
70
|
+
return (e = !1);
|
71
|
+
}, t),
|
72
|
+
(o = n.apply(void 0, [].slice.call(arguments)))),
|
73
|
+
o
|
74
|
+
);
|
75
|
+
};
|
76
|
+
},
|
77
|
+
f = function () {};
|
78
|
+
export { c as events, f as noop, r as throttle };
|
2
79
|
//# sourceMappingURL=index.module.js.map
|
package/dist/index.module.js.map
CHANGED
@@ -1 +1 @@
|
|
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
|
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
CHANGED
@@ -1,2 +1,87 @@
|
|
1
|
-
!
|
1
|
+
!(function (n, t) {
|
2
|
+
'object' == typeof exports && 'undefined' != typeof module
|
3
|
+
? t(exports)
|
4
|
+
: 'function' == typeof define && define.amd
|
5
|
+
? define(['exports'], t)
|
6
|
+
: t(((n || self).utils = {}));
|
7
|
+
})(this, function (n) {
|
8
|
+
var t = function (n, t) {
|
9
|
+
document.addEventListener(n, t);
|
10
|
+
},
|
11
|
+
e = function (n, t) {
|
12
|
+
document.removeEventListener(n, t);
|
13
|
+
},
|
14
|
+
o = function (n, t) {
|
15
|
+
window.addEventListener(n, t);
|
16
|
+
},
|
17
|
+
i = function (n, t) {
|
18
|
+
window.removeEventListener(n, t);
|
19
|
+
},
|
20
|
+
u = function (n, t, e) {
|
21
|
+
n.addEventListener(t, e);
|
22
|
+
},
|
23
|
+
f = function (n, t, e) {
|
24
|
+
n.removeEventListener(t, e);
|
25
|
+
},
|
26
|
+
c = void 0;
|
27
|
+
(n.events = {
|
28
|
+
document: {
|
29
|
+
__proto__: null,
|
30
|
+
on: t,
|
31
|
+
off: e,
|
32
|
+
once: function (n, o) {
|
33
|
+
t(n, function t(i) {
|
34
|
+
o(i), e(n, t);
|
35
|
+
});
|
36
|
+
},
|
37
|
+
trigger: function (n) {
|
38
|
+
var t = new CustomEvent(n);
|
39
|
+
document.dispatchEvent(t);
|
40
|
+
},
|
41
|
+
},
|
42
|
+
window: {
|
43
|
+
__proto__: null,
|
44
|
+
on: o,
|
45
|
+
off: i,
|
46
|
+
once: function (n, t) {
|
47
|
+
o(n, function e(o) {
|
48
|
+
t(o), i(n, e);
|
49
|
+
});
|
50
|
+
},
|
51
|
+
trigger: function (n) {
|
52
|
+
var t = new CustomEvent(n);
|
53
|
+
window.dispatchEvent(t);
|
54
|
+
},
|
55
|
+
},
|
56
|
+
element: {
|
57
|
+
__proto__: null,
|
58
|
+
on: u,
|
59
|
+
off: f,
|
60
|
+
once: function (n, t, e) {
|
61
|
+
u(n, t, function o(i) {
|
62
|
+
e(i), f(n, t, o);
|
63
|
+
});
|
64
|
+
},
|
65
|
+
trigger: function (n, t) {
|
66
|
+
var e = new CustomEvent(t);
|
67
|
+
n.dispatchEvent(e);
|
68
|
+
},
|
69
|
+
},
|
70
|
+
}),
|
71
|
+
(n.noop = function () {}),
|
72
|
+
(n.throttle = function (n, t) {
|
73
|
+
var e, o;
|
74
|
+
return function () {
|
75
|
+
return (
|
76
|
+
e ||
|
77
|
+
((e = !0),
|
78
|
+
setTimeout(function () {
|
79
|
+
return (e = !1);
|
80
|
+
}, t),
|
81
|
+
(o = n.apply(c, [].slice.call(arguments)))),
|
82
|
+
o
|
83
|
+
);
|
84
|
+
};
|
85
|
+
});
|
86
|
+
});
|
2
87
|
//# sourceMappingURL=index.umd.js.map
|
package/dist/index.umd.js.map
CHANGED
@@ -1 +1 @@
|
|
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
|
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
CHANGED
@@ -1 +1 @@
|
|
1
|
-
export declare const noop: () => undefined;
|
1
|
+
export declare const noop: () => undefined;
|
package/dist/throttle.d.ts
CHANGED
@@ -1,4 +1,9 @@
|
|
1
|
-
import { Callback } from './types
|
2
|
-
declare type ThrottledFunction<C extends Callback> = (
|
3
|
-
|
4
|
-
|
1
|
+
import { Callback } from './types';
|
2
|
+
declare type ThrottledFunction<C extends Callback> = (
|
3
|
+
...args: Parameters<C>
|
4
|
+
) => ReturnType<C>;
|
5
|
+
export declare const throttle: <C extends Callback>(
|
6
|
+
callback: C,
|
7
|
+
limit: number
|
8
|
+
) => ThrottledFunction<C>;
|
9
|
+
export {};
|
package/dist/types/Callback.d.ts
CHANGED
@@ -1 +1 @@
|
|
1
|
-
export declare type Callback = (...args: any) => any;
|
1
|
+
export declare type Callback = (...args: any) => any;
|
@@ -1,4 +1,13 @@
|
|
1
|
-
/** from type-fest: https://github.com/sindresorhus/type-fest/blob/main/source/literal-union.d.ts */
|
2
|
-
declare type Primitive =
|
3
|
-
|
4
|
-
|
1
|
+
/** from type-fest: https://github.com/sindresorhus/type-fest/blob/main/source/literal-union.d.ts */
|
2
|
+
declare type Primitive =
|
3
|
+
| null
|
4
|
+
| undefined
|
5
|
+
| string
|
6
|
+
| number
|
7
|
+
| boolean
|
8
|
+
| symbol
|
9
|
+
| bigint;
|
10
|
+
export declare type LiteralUnion<LiteralType, BaseType extends Primitive> =
|
11
|
+
| LiteralType
|
12
|
+
| (BaseType & Record<never, never>);
|
13
|
+
export {};
|
package/dist/types/index.d.ts
CHANGED
@@ -1,2 +1,2 @@
|
|
1
|
-
export type { LiteralUnion } from './LiteralUnion';
|
2
|
-
export type { Callback } from './Callback';
|
1
|
+
export type { LiteralUnion } from './LiteralUnion';
|
2
|
+
export type { Callback } from './Callback';
|
package/package.json
CHANGED
@@ -1,16 +1,13 @@
|
|
1
1
|
{
|
2
2
|
"name": "@wiggindev/utils",
|
3
3
|
"description": "Various utilities that I use in my projects",
|
4
|
-
"version": "0.2.
|
4
|
+
"version": "0.2.5",
|
5
5
|
"author": {
|
6
6
|
"name": "Andrew Wiggin",
|
7
7
|
"email": "andrew@wiggin.dev",
|
8
8
|
"url": "https://wiggin.dev"
|
9
9
|
},
|
10
|
-
"repository":
|
11
|
-
"type": "git",
|
12
|
-
"url": "https://github.com/wiggindev/utils.git"
|
13
|
-
},
|
10
|
+
"repository": "git://github.com/wiggindev/utils",
|
14
11
|
"type": "module",
|
15
12
|
"source": "src/index.ts",
|
16
13
|
"exports": {
|
@@ -22,28 +19,11 @@
|
|
22
19
|
"unpkg": "dist/index.umd.js",
|
23
20
|
"types": "dist/index.d.ts",
|
24
21
|
"scripts": {
|
25
|
-
"build": "
|
26
|
-
"dev": "
|
27
|
-
"_postinstall": "husky install",
|
28
|
-
"prepack": "pinst --disable",
|
29
|
-
"postpack": "pinst --enable",
|
30
|
-
"lint": "tsc --noEmit && yarn eslint",
|
31
|
-
"format": "yarn eslint --fix && yarn prettier --write ."
|
22
|
+
"build": "rm -rf dist && microbundle",
|
23
|
+
"dev": "rm -rf dist && microbundle watch"
|
32
24
|
},
|
33
25
|
"devDependencies": {
|
34
|
-
"
|
35
|
-
"@typescript-eslint/eslint-plugin": "^5.23.0",
|
36
|
-
"@typescript-eslint/parser": "^5.23.0",
|
37
|
-
"eslint": "^8.15.0",
|
38
|
-
"eslint-config-prettier": "^8.5.0",
|
39
|
-
"eslint-plugin-prettier": "^4.0.0",
|
40
|
-
"husky": "^8.0.1",
|
41
|
-
"lint-staged": "^12.4.1",
|
42
|
-
"microbundle": "^0.15.0",
|
43
|
-
"pinst": "^3.0.0",
|
44
|
-
"prettier": "^2.6.2",
|
45
|
-
"rimraf": "^3.0.2",
|
46
|
-
"typescript": "^4.6.4"
|
26
|
+
"microbundle": "^0.15.0"
|
47
27
|
},
|
48
28
|
"packageManager": "yarn@3.2.1",
|
49
29
|
"publishConfig": {
|
package/src/index.ts
CHANGED
package/src/throttle.ts
CHANGED
package/src/types/Callback.ts
CHANGED