@companix/re-render 0.0.1
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/bundle.cjs.js +1 -0
- package/dist/bundle.es.js +66 -0
- package/package.json +39 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=require("react"),o=r=>{const e={};return s=>{const t=r(s);return e[t]||(e[t]=n()),e[t]}},n=()=>{let r=[];return{call(){r.forEach(({callback:e})=>e())},subscribe(e){return r.push(e),{unsubscribe(){r=r.filter(s=>s!==e)}}}}},a=r=>{const[,e]=c.useState([]),{unsubscribe:s}=c.useMemo(()=>r.subscribe({callback:()=>e([])}),[]);c.useEffect(()=>()=>s(),[])},i=r=>{r.call()},l=r=>{const e={value:r,subscribers:[],set:s=>{e.value=s,e.subscribers.forEach(t=>{t.rerender()})},change:s=>{e.value=s(e.value),e.subscribers.forEach(t=>{t.rerender()})}};return e},d=r=>{const[,e]=c.useState([]),s=c.useMemo(()=>{const t={rerender:()=>e([])};return r.subscribers.push(t),()=>{const u=r.subscribers.findIndex(b=>b===t);u!==-1&&r.subscribers.splice(u,1)}},[]);return c.useEffect(()=>()=>{s()},[]),r.value};exports.createState=l;exports.createSubject=n;exports.createSubjectStore=o;exports.rerender=i;exports.useLocalState=d;exports.useRerender=a;
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { useState as t, useMemo as u, useEffect as b } from "react";
|
|
2
|
+
const l = (r) => {
|
|
3
|
+
const e = {};
|
|
4
|
+
return (s) => {
|
|
5
|
+
const c = r(s);
|
|
6
|
+
return e[c] || (e[c] = i()), e[c];
|
|
7
|
+
};
|
|
8
|
+
}, i = () => {
|
|
9
|
+
let r = [];
|
|
10
|
+
return {
|
|
11
|
+
call() {
|
|
12
|
+
r.forEach(({ callback: e }) => e());
|
|
13
|
+
},
|
|
14
|
+
subscribe(e) {
|
|
15
|
+
return r.push(e), {
|
|
16
|
+
unsubscribe() {
|
|
17
|
+
r = r.filter((s) => s !== e);
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
}, d = (r) => {
|
|
23
|
+
const [, e] = t([]), { unsubscribe: s } = u(() => r.subscribe({
|
|
24
|
+
callback: () => e([])
|
|
25
|
+
}), []);
|
|
26
|
+
b(() => () => s(), []);
|
|
27
|
+
}, f = (r) => {
|
|
28
|
+
r.call();
|
|
29
|
+
}, h = (r) => {
|
|
30
|
+
const e = {
|
|
31
|
+
value: r,
|
|
32
|
+
subscribers: [],
|
|
33
|
+
set: (s) => {
|
|
34
|
+
e.value = s, e.subscribers.forEach((c) => {
|
|
35
|
+
c.rerender();
|
|
36
|
+
});
|
|
37
|
+
},
|
|
38
|
+
change: (s) => {
|
|
39
|
+
e.value = s(e.value), e.subscribers.forEach((c) => {
|
|
40
|
+
c.rerender();
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
return e;
|
|
45
|
+
}, S = (r) => {
|
|
46
|
+
const [, e] = t([]), s = u(() => {
|
|
47
|
+
const c = {
|
|
48
|
+
rerender: () => e([])
|
|
49
|
+
};
|
|
50
|
+
return r.subscribers.push(c), () => {
|
|
51
|
+
const n = r.subscribers.findIndex((o) => o === c);
|
|
52
|
+
n !== -1 && r.subscribers.splice(n, 1);
|
|
53
|
+
};
|
|
54
|
+
}, []);
|
|
55
|
+
return b(() => () => {
|
|
56
|
+
s();
|
|
57
|
+
}, []), r.value;
|
|
58
|
+
};
|
|
59
|
+
export {
|
|
60
|
+
h as createState,
|
|
61
|
+
i as createSubject,
|
|
62
|
+
l as createSubjectStore,
|
|
63
|
+
f as rerender,
|
|
64
|
+
S as useLocalState,
|
|
65
|
+
d as useRerender
|
|
66
|
+
};
|
package/package.json
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@companix/re-render",
|
|
3
|
+
"version": "0.0.01",
|
|
4
|
+
"description": "",
|
|
5
|
+
"main": "./dist/bundle.cjs.js",
|
|
6
|
+
"module": "./dist/bundle.es.js",
|
|
7
|
+
"types": "./src/index.ts",
|
|
8
|
+
"author": "Pavel Victorov",
|
|
9
|
+
"files": [
|
|
10
|
+
"dist"
|
|
11
|
+
],
|
|
12
|
+
"peerDependencies": {
|
|
13
|
+
"react": "^18.3.1",
|
|
14
|
+
"react-dom": "^18.3.1"
|
|
15
|
+
},
|
|
16
|
+
"scripts": {
|
|
17
|
+
"echo": "echo \"re-render\"",
|
|
18
|
+
"dev": "vite --config vite.config.mts",
|
|
19
|
+
"build": "vite build --config vite.build.mts",
|
|
20
|
+
"lint": "eslint . --ext .ts,.tsx"
|
|
21
|
+
},
|
|
22
|
+
"devDependencies": {
|
|
23
|
+
"@rollup/plugin-eslint": "^9.0.5",
|
|
24
|
+
"@rollup/plugin-typescript": "^11.1.6",
|
|
25
|
+
"@types/react": "^18.3.1",
|
|
26
|
+
"@types/react-dom": "^18.3.1",
|
|
27
|
+
"@typescript-eslint/parser": "^5.62.0",
|
|
28
|
+
"@vitejs/plugin-react": "^4.6.0",
|
|
29
|
+
"eslint-config-react-app": "^7.0.1",
|
|
30
|
+
"eslint-plugin-import": "^2.29.1",
|
|
31
|
+
"eslint-plugin-react": "^7.34.3",
|
|
32
|
+
"eslint-plugin-react-hooks": "^4.6.2",
|
|
33
|
+
"eslint-webpack-plugin": "^4.2.0",
|
|
34
|
+
"react": "^18.3.1",
|
|
35
|
+
"react-dom": "^18.3.1",
|
|
36
|
+
"vite": "^7.0.0",
|
|
37
|
+
"vite-plugin-checker": "^0.9.3"
|
|
38
|
+
}
|
|
39
|
+
}
|