ccstate-react 3.0.0
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/CHANGELOG.md +10 -0
- package/babel.config.json +3 -0
- package/dist/LICENSE +21 -0
- package/dist/README.md +849 -0
- package/dist/index.cjs +150 -0
- package/dist/index.d.cts +26 -0
- package/dist/index.d.ts +26 -0
- package/dist/index.js +142 -0
- package/dist/package.json +33 -0
- package/package.json +58 -0
- package/rollup.config.mjs +84 -0
- package/src/__tests__/get-and-set.test.tsx +267 -0
- package/src/__tests__/items.test.tsx +242 -0
- package/src/__tests__/loadable.test.tsx +532 -0
- package/src/__tests__/memory.test.tsx +62 -0
- package/src/__tests__/resolved.test.tsx +102 -0
- package/src/index.ts +5 -0
- package/src/provider.ts +16 -0
- package/src/useGet.ts +20 -0
- package/src/useLoadable.ts +69 -0
- package/src/useResolved.ts +12 -0
- package/src/useSet.ts +22 -0
- package/tsconfig.json +8 -0
- package/vitest.config.ts +3 -0
package/dist/index.cjs
ADDED
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var ccstate = require('ccstate');
|
|
5
|
+
|
|
6
|
+
var StoreContext = react.createContext(null);
|
|
7
|
+
var StoreProvider = StoreContext.Provider;
|
|
8
|
+
function useStore() {
|
|
9
|
+
var store = react.useContext(StoreContext);
|
|
10
|
+
if (!store) {
|
|
11
|
+
throw new Error('Store context not found - did you forget to wrap your app with StoreProvider?');
|
|
12
|
+
}
|
|
13
|
+
return store;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
function useGet(atom) {
|
|
17
|
+
var store = useStore();
|
|
18
|
+
return react.useSyncExternalStore(function (fn) {
|
|
19
|
+
var ctrl = new AbortController();
|
|
20
|
+
store.sub(atom, ccstate.command(fn), {
|
|
21
|
+
signal: ctrl.signal
|
|
22
|
+
});
|
|
23
|
+
return function () {
|
|
24
|
+
ctrl.abort();
|
|
25
|
+
};
|
|
26
|
+
}, function () {
|
|
27
|
+
return store.get(atom);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function useSet(atom) {
|
|
32
|
+
var store = useStore();
|
|
33
|
+
if ('write' in atom) {
|
|
34
|
+
return function () {
|
|
35
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
36
|
+
args[_key] = arguments[_key];
|
|
37
|
+
}
|
|
38
|
+
var ret = store.set.apply(store, [atom].concat(args));
|
|
39
|
+
return ret;
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
return function (value) {
|
|
43
|
+
store.set(atom, value);
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function _arrayLikeToArray(r, a) {
|
|
48
|
+
(null == a || a > r.length) && (a = r.length);
|
|
49
|
+
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
|
|
50
|
+
return n;
|
|
51
|
+
}
|
|
52
|
+
function _arrayWithHoles(r) {
|
|
53
|
+
if (Array.isArray(r)) return r;
|
|
54
|
+
}
|
|
55
|
+
function _iterableToArrayLimit(r, l) {
|
|
56
|
+
var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
|
|
57
|
+
if (null != t) {
|
|
58
|
+
var e,
|
|
59
|
+
n,
|
|
60
|
+
i,
|
|
61
|
+
u,
|
|
62
|
+
a = [],
|
|
63
|
+
f = !0,
|
|
64
|
+
o = !1;
|
|
65
|
+
try {
|
|
66
|
+
if (i = (t = t.call(r)).next, 0 === l) ; else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
|
|
67
|
+
} catch (r) {
|
|
68
|
+
o = !0, n = r;
|
|
69
|
+
} finally {
|
|
70
|
+
try {
|
|
71
|
+
if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return;
|
|
72
|
+
} finally {
|
|
73
|
+
if (o) throw n;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return a;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
function _nonIterableRest() {
|
|
80
|
+
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
81
|
+
}
|
|
82
|
+
function _slicedToArray(r, e) {
|
|
83
|
+
return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest();
|
|
84
|
+
}
|
|
85
|
+
function _unsupportedIterableToArray(r, a) {
|
|
86
|
+
if (r) {
|
|
87
|
+
if ("string" == typeof r) return _arrayLikeToArray(r, a);
|
|
88
|
+
var t = {}.toString.call(r).slice(8, -1);
|
|
89
|
+
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
function useLoadableInternal(atom, keepLastResolved) {
|
|
94
|
+
var promise = useGet(atom);
|
|
95
|
+
var _useState = react.useState({
|
|
96
|
+
state: 'loading'
|
|
97
|
+
}),
|
|
98
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
99
|
+
promiseResult = _useState2[0],
|
|
100
|
+
setPromiseResult = _useState2[1];
|
|
101
|
+
react.useEffect(function () {
|
|
102
|
+
var ctrl = new AbortController();
|
|
103
|
+
var signal = ctrl.signal;
|
|
104
|
+
if (!keepLastResolved) {
|
|
105
|
+
setPromiseResult({
|
|
106
|
+
state: 'loading'
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
void promise.then(function (ret) {
|
|
110
|
+
if (signal.aborted) return;
|
|
111
|
+
setPromiseResult({
|
|
112
|
+
state: 'hasData',
|
|
113
|
+
data: ret
|
|
114
|
+
});
|
|
115
|
+
})["catch"](function (error) {
|
|
116
|
+
if (signal.aborted) return;
|
|
117
|
+
setPromiseResult({
|
|
118
|
+
state: 'hasError',
|
|
119
|
+
error: error
|
|
120
|
+
});
|
|
121
|
+
});
|
|
122
|
+
return function () {
|
|
123
|
+
ctrl.abort();
|
|
124
|
+
};
|
|
125
|
+
}, [promise]);
|
|
126
|
+
return promiseResult;
|
|
127
|
+
}
|
|
128
|
+
function useLoadable(atom) {
|
|
129
|
+
return useLoadableInternal(atom, false);
|
|
130
|
+
}
|
|
131
|
+
function useLastLoadable(atom) {
|
|
132
|
+
return useLoadableInternal(atom, true);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
function useResolved(atom) {
|
|
136
|
+
var loadable = useLoadable(atom);
|
|
137
|
+
return loadable.state === 'hasData' ? loadable.data : undefined;
|
|
138
|
+
}
|
|
139
|
+
function useLastResolved(atom) {
|
|
140
|
+
var loadable = useLastLoadable(atom);
|
|
141
|
+
return loadable.state === 'hasData' ? loadable.data : undefined;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
exports.StoreProvider = StoreProvider;
|
|
145
|
+
exports.useGet = useGet;
|
|
146
|
+
exports.useLastLoadable = useLastLoadable;
|
|
147
|
+
exports.useLastResolved = useLastResolved;
|
|
148
|
+
exports.useLoadable = useLoadable;
|
|
149
|
+
exports.useResolved = useResolved;
|
|
150
|
+
exports.useSet = useSet;
|
package/dist/index.d.cts
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { State, Computed, Updater, Command, Store } from 'ccstate';
|
|
2
|
+
import * as react from 'react';
|
|
3
|
+
|
|
4
|
+
declare function useGet<T>(atom: State<T> | Computed<T>): T;
|
|
5
|
+
|
|
6
|
+
declare function useSet<T>(atom: State<T>): (value: T | Updater<T>) => void;
|
|
7
|
+
declare function useSet<T, ARGS extends unknown[]>(atom: Command<T, ARGS>): (...args: ARGS) => T;
|
|
8
|
+
|
|
9
|
+
declare function useResolved<T>(atom: State<Promise<T>> | Computed<Promise<T>>): T | undefined;
|
|
10
|
+
declare function useLastResolved<T>(atom: State<Promise<T>> | Computed<Promise<T>>): T | undefined;
|
|
11
|
+
|
|
12
|
+
type Loadable<T> = {
|
|
13
|
+
state: 'loading';
|
|
14
|
+
} | {
|
|
15
|
+
state: 'hasData';
|
|
16
|
+
data: T;
|
|
17
|
+
} | {
|
|
18
|
+
state: 'hasError';
|
|
19
|
+
error: unknown;
|
|
20
|
+
};
|
|
21
|
+
declare function useLoadable<T>(atom: State<Promise<T>> | Computed<Promise<T>>): Loadable<T>;
|
|
22
|
+
declare function useLastLoadable<T>(atom: State<Promise<T>> | Computed<Promise<T>>): Loadable<T>;
|
|
23
|
+
|
|
24
|
+
declare const StoreProvider: react.Provider<Store | null>;
|
|
25
|
+
|
|
26
|
+
export { StoreProvider, useGet, useLastLoadable, useLastResolved, useLoadable, useResolved, useSet };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { State, Computed, Updater, Command, Store } from 'ccstate';
|
|
2
|
+
import * as react from 'react';
|
|
3
|
+
|
|
4
|
+
declare function useGet<T>(atom: State<T> | Computed<T>): T;
|
|
5
|
+
|
|
6
|
+
declare function useSet<T>(atom: State<T>): (value: T | Updater<T>) => void;
|
|
7
|
+
declare function useSet<T, ARGS extends unknown[]>(atom: Command<T, ARGS>): (...args: ARGS) => T;
|
|
8
|
+
|
|
9
|
+
declare function useResolved<T>(atom: State<Promise<T>> | Computed<Promise<T>>): T | undefined;
|
|
10
|
+
declare function useLastResolved<T>(atom: State<Promise<T>> | Computed<Promise<T>>): T | undefined;
|
|
11
|
+
|
|
12
|
+
type Loadable<T> = {
|
|
13
|
+
state: 'loading';
|
|
14
|
+
} | {
|
|
15
|
+
state: 'hasData';
|
|
16
|
+
data: T;
|
|
17
|
+
} | {
|
|
18
|
+
state: 'hasError';
|
|
19
|
+
error: unknown;
|
|
20
|
+
};
|
|
21
|
+
declare function useLoadable<T>(atom: State<Promise<T>> | Computed<Promise<T>>): Loadable<T>;
|
|
22
|
+
declare function useLastLoadable<T>(atom: State<Promise<T>> | Computed<Promise<T>>): Loadable<T>;
|
|
23
|
+
|
|
24
|
+
declare const StoreProvider: react.Provider<Store | null>;
|
|
25
|
+
|
|
26
|
+
export { StoreProvider, useGet, useLastLoadable, useLastResolved, useLoadable, useResolved, useSet };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { createContext, useContext, useSyncExternalStore, useState, useEffect } from 'react';
|
|
2
|
+
import { command } from 'ccstate';
|
|
3
|
+
|
|
4
|
+
var StoreContext = createContext(null);
|
|
5
|
+
var StoreProvider = StoreContext.Provider;
|
|
6
|
+
function useStore() {
|
|
7
|
+
var store = useContext(StoreContext);
|
|
8
|
+
if (!store) {
|
|
9
|
+
throw new Error('Store context not found - did you forget to wrap your app with StoreProvider?');
|
|
10
|
+
}
|
|
11
|
+
return store;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
function useGet(atom) {
|
|
15
|
+
var store = useStore();
|
|
16
|
+
return useSyncExternalStore(function (fn) {
|
|
17
|
+
var ctrl = new AbortController();
|
|
18
|
+
store.sub(atom, command(fn), {
|
|
19
|
+
signal: ctrl.signal
|
|
20
|
+
});
|
|
21
|
+
return function () {
|
|
22
|
+
ctrl.abort();
|
|
23
|
+
};
|
|
24
|
+
}, function () {
|
|
25
|
+
return store.get(atom);
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
function useSet(atom) {
|
|
30
|
+
var store = useStore();
|
|
31
|
+
if ('write' in atom) {
|
|
32
|
+
return function () {
|
|
33
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
34
|
+
args[_key] = arguments[_key];
|
|
35
|
+
}
|
|
36
|
+
var ret = store.set.apply(store, [atom].concat(args));
|
|
37
|
+
return ret;
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
return function (value) {
|
|
41
|
+
store.set(atom, value);
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function _arrayLikeToArray(r, a) {
|
|
46
|
+
(null == a || a > r.length) && (a = r.length);
|
|
47
|
+
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
|
|
48
|
+
return n;
|
|
49
|
+
}
|
|
50
|
+
function _arrayWithHoles(r) {
|
|
51
|
+
if (Array.isArray(r)) return r;
|
|
52
|
+
}
|
|
53
|
+
function _iterableToArrayLimit(r, l) {
|
|
54
|
+
var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
|
|
55
|
+
if (null != t) {
|
|
56
|
+
var e,
|
|
57
|
+
n,
|
|
58
|
+
i,
|
|
59
|
+
u,
|
|
60
|
+
a = [],
|
|
61
|
+
f = !0,
|
|
62
|
+
o = !1;
|
|
63
|
+
try {
|
|
64
|
+
if (i = (t = t.call(r)).next, 0 === l) ; else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
|
|
65
|
+
} catch (r) {
|
|
66
|
+
o = !0, n = r;
|
|
67
|
+
} finally {
|
|
68
|
+
try {
|
|
69
|
+
if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return;
|
|
70
|
+
} finally {
|
|
71
|
+
if (o) throw n;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
return a;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
function _nonIterableRest() {
|
|
78
|
+
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
79
|
+
}
|
|
80
|
+
function _slicedToArray(r, e) {
|
|
81
|
+
return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest();
|
|
82
|
+
}
|
|
83
|
+
function _unsupportedIterableToArray(r, a) {
|
|
84
|
+
if (r) {
|
|
85
|
+
if ("string" == typeof r) return _arrayLikeToArray(r, a);
|
|
86
|
+
var t = {}.toString.call(r).slice(8, -1);
|
|
87
|
+
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
function useLoadableInternal(atom, keepLastResolved) {
|
|
92
|
+
var promise = useGet(atom);
|
|
93
|
+
var _useState = useState({
|
|
94
|
+
state: 'loading'
|
|
95
|
+
}),
|
|
96
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
97
|
+
promiseResult = _useState2[0],
|
|
98
|
+
setPromiseResult = _useState2[1];
|
|
99
|
+
useEffect(function () {
|
|
100
|
+
var ctrl = new AbortController();
|
|
101
|
+
var signal = ctrl.signal;
|
|
102
|
+
if (!keepLastResolved) {
|
|
103
|
+
setPromiseResult({
|
|
104
|
+
state: 'loading'
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
void promise.then(function (ret) {
|
|
108
|
+
if (signal.aborted) return;
|
|
109
|
+
setPromiseResult({
|
|
110
|
+
state: 'hasData',
|
|
111
|
+
data: ret
|
|
112
|
+
});
|
|
113
|
+
})["catch"](function (error) {
|
|
114
|
+
if (signal.aborted) return;
|
|
115
|
+
setPromiseResult({
|
|
116
|
+
state: 'hasError',
|
|
117
|
+
error: error
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
return function () {
|
|
121
|
+
ctrl.abort();
|
|
122
|
+
};
|
|
123
|
+
}, [promise]);
|
|
124
|
+
return promiseResult;
|
|
125
|
+
}
|
|
126
|
+
function useLoadable(atom) {
|
|
127
|
+
return useLoadableInternal(atom, false);
|
|
128
|
+
}
|
|
129
|
+
function useLastLoadable(atom) {
|
|
130
|
+
return useLoadableInternal(atom, true);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
function useResolved(atom) {
|
|
134
|
+
var loadable = useLoadable(atom);
|
|
135
|
+
return loadable.state === 'hasData' ? loadable.data : undefined;
|
|
136
|
+
}
|
|
137
|
+
function useLastResolved(atom) {
|
|
138
|
+
var loadable = useLastLoadable(atom);
|
|
139
|
+
return loadable.state === 'hasData' ? loadable.data : undefined;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
export { StoreProvider, useGet, useLastLoadable, useLastResolved, useLoadable, useResolved, useSet };
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "ccstate-react",
|
|
3
|
+
"version": "2.2.0",
|
|
4
|
+
"description": "CCState React Hooks",
|
|
5
|
+
"private": false,
|
|
6
|
+
"repository": {
|
|
7
|
+
"type": "git",
|
|
8
|
+
"url": "git+https://github.com/e7h4n/ccstate.git"
|
|
9
|
+
},
|
|
10
|
+
"license": "MIT",
|
|
11
|
+
"type": "module",
|
|
12
|
+
"main": "./index.cjs",
|
|
13
|
+
"module": "./index.js",
|
|
14
|
+
"exports": {
|
|
15
|
+
".": {
|
|
16
|
+
"import": "./index.js",
|
|
17
|
+
"require": "./index.cjs"
|
|
18
|
+
}
|
|
19
|
+
},
|
|
20
|
+
"peerDependencies": {
|
|
21
|
+
"@types/react": ">=17.0.0",
|
|
22
|
+
"react": ">=17.0.0",
|
|
23
|
+
"ccstate": "workspace:^"
|
|
24
|
+
},
|
|
25
|
+
"peerDependenciesMeta": {
|
|
26
|
+
"@types/react": {
|
|
27
|
+
"optional": true
|
|
28
|
+
},
|
|
29
|
+
"react": {
|
|
30
|
+
"optional": true
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "ccstate-react",
|
|
3
|
+
"version": "3.0.0",
|
|
4
|
+
"description": "CCState React Hooks",
|
|
5
|
+
"repository": {
|
|
6
|
+
"type": "git",
|
|
7
|
+
"url": "git+https://github.com/e7h4n/ccstate.git"
|
|
8
|
+
},
|
|
9
|
+
"license": "MIT",
|
|
10
|
+
"type": "module",
|
|
11
|
+
"main": "./dist/index.cjs",
|
|
12
|
+
"module": "./dist/index.js",
|
|
13
|
+
"exports": {
|
|
14
|
+
".": {
|
|
15
|
+
"import": "./dist/index.js",
|
|
16
|
+
"require": "./dist/index.cjs"
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"peerDependencies": {
|
|
20
|
+
"@types/react": ">=17.0.0",
|
|
21
|
+
"react": ">=17.0.0",
|
|
22
|
+
"ccstate": "^3.0.0"
|
|
23
|
+
},
|
|
24
|
+
"peerDependenciesMeta": {
|
|
25
|
+
"@types/react": {
|
|
26
|
+
"optional": true
|
|
27
|
+
},
|
|
28
|
+
"react": {
|
|
29
|
+
"optional": true
|
|
30
|
+
}
|
|
31
|
+
},
|
|
32
|
+
"devDependencies": {
|
|
33
|
+
"@babel/preset-env": "^7.26.0",
|
|
34
|
+
"@babel/preset-typescript": "^7.26.0",
|
|
35
|
+
"@rollup/plugin-babel": "^6.0.4",
|
|
36
|
+
"@rollup/plugin-node-resolve": "^15.3.0",
|
|
37
|
+
"@testing-library/jest-dom": "^6.6.3",
|
|
38
|
+
"@testing-library/react": "^16.0.1",
|
|
39
|
+
"@testing-library/user-event": "^14.5.2",
|
|
40
|
+
"@types/react": "^18.3.1",
|
|
41
|
+
"@types/react-dom": "^18.3.1",
|
|
42
|
+
"happy-dom": "^15.11.7",
|
|
43
|
+
"jest-leak-detector": "^29.7.0",
|
|
44
|
+
"json": "^11.0.0",
|
|
45
|
+
"react": "^18.3.1",
|
|
46
|
+
"react-dom": "^18.3.1",
|
|
47
|
+
"rollup": "^4.28.1",
|
|
48
|
+
"rollup-plugin-dts": "^6.1.1",
|
|
49
|
+
"shx": "^0.3.4",
|
|
50
|
+
"signal-timers": "^1.0.4",
|
|
51
|
+
"vitest": "^2.1.8",
|
|
52
|
+
"ccstate": "^3.0.0"
|
|
53
|
+
},
|
|
54
|
+
"scripts": {
|
|
55
|
+
"build": "rollup -c",
|
|
56
|
+
"prebuild": "shx rm -rf dist"
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
// @ts-check
|
|
2
|
+
import * as fs from 'node:fs';
|
|
3
|
+
import * as path from 'node:path';
|
|
4
|
+
import { babel } from '@rollup/plugin-babel';
|
|
5
|
+
import { dts } from 'rollup-plugin-dts';
|
|
6
|
+
import { nodeResolve } from '@rollup/plugin-node-resolve';
|
|
7
|
+
|
|
8
|
+
const __dirname = path.dirname(new URL(import.meta.url).pathname);
|
|
9
|
+
const projectRootDir = path.resolve(__dirname);
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* @param {string} id
|
|
13
|
+
* @returns {boolean}
|
|
14
|
+
*/
|
|
15
|
+
function external(id) {
|
|
16
|
+
return !id.startsWith('.') && !id.startsWith(projectRootDir);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* @param {{input:string, targetCJS:string, targetES:string}} param0
|
|
21
|
+
* @returns {import('rollup').RollupOptions[]}
|
|
22
|
+
*/
|
|
23
|
+
function generateTarget({ input, targetCJS, targetES }) {
|
|
24
|
+
return [
|
|
25
|
+
{
|
|
26
|
+
input,
|
|
27
|
+
onwarn: (warning) => {
|
|
28
|
+
throw new Error(warning?.message);
|
|
29
|
+
},
|
|
30
|
+
external,
|
|
31
|
+
plugins: [
|
|
32
|
+
nodeResolve({
|
|
33
|
+
extensions: ['.ts'],
|
|
34
|
+
}),
|
|
35
|
+
babel({
|
|
36
|
+
exclude: 'node_modules/**',
|
|
37
|
+
extensions: ['.ts'],
|
|
38
|
+
babelHelpers: 'bundled',
|
|
39
|
+
configFile: path.resolve(projectRootDir, './babel.config.json'),
|
|
40
|
+
}),
|
|
41
|
+
],
|
|
42
|
+
output: [
|
|
43
|
+
{
|
|
44
|
+
file: targetCJS,
|
|
45
|
+
format: 'cjs',
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
file: targetES,
|
|
49
|
+
format: 'es',
|
|
50
|
+
},
|
|
51
|
+
],
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
input,
|
|
55
|
+
onwarn: (warning) => {
|
|
56
|
+
throw new Error(warning?.message);
|
|
57
|
+
},
|
|
58
|
+
external,
|
|
59
|
+
plugins: [
|
|
60
|
+
dts({
|
|
61
|
+
respectExternal: true,
|
|
62
|
+
tsconfig: path.resolve(projectRootDir, './tsconfig.json'),
|
|
63
|
+
// https://github.com/Swatinem/rollup-plugin-dts/issues/143
|
|
64
|
+
compilerOptions: { preserveSymlinks: false },
|
|
65
|
+
}),
|
|
66
|
+
],
|
|
67
|
+
output: [
|
|
68
|
+
{
|
|
69
|
+
file: targetCJS.replace(/\.cjs$/, '.d.cts'),
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
file: targetES.replace(/\.js$/, '.d.ts'),
|
|
73
|
+
},
|
|
74
|
+
],
|
|
75
|
+
},
|
|
76
|
+
];
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/** @type { Array<import('rollup').RollupOptions> } */
|
|
80
|
+
export default generateTarget({
|
|
81
|
+
input: './src/index.ts',
|
|
82
|
+
targetCJS: './dist/index.cjs',
|
|
83
|
+
targetES: './dist/index.js',
|
|
84
|
+
});
|