create-a-npm 1.0.6 → 1.1.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/LICENSE CHANGED
@@ -1,6 +1,6 @@
1
1
  # MIT License
2
2
 
3
- Copyright (c) <2024> <earthnut.dev>
3
+ Copyright ©️ <2024> <Mr.MudBean>
4
4
 
5
5
  Permission to use, copy, modify, and/or distribute this software for any
6
6
  purpose with or without fee is hereby granted, provided that the above
@@ -16,7 +16,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16
16
 
17
17
  # MIT 许可证
18
18
 
19
- 版权所有 (c) [2024] [花生亻]
19
+ 版权所有 ©️ [2024] [泥豆君]
20
20
 
21
21
  特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
22
22
 
package/README.md CHANGED
@@ -1,6 +1,9 @@
1
1
  # 构建简单的 npm 库
2
2
 
3
- [![version](<https://img.shields.io/npm/v/create-a-npm.svg?logo=npm&logoColor=rgb(0,0,0)&label=版本号&labelColor=rgb(73,73,228)&color=rgb(0,0,0)>)](https://www.npmjs.com/package/create-a-npm) [![issues 提交](<https://img.shields.io/badge/issues-提交-rgb(255,0,63)?logo=github>)](https://github.com/earthnutDev/create-a-npm/issues)
3
+ [![version](<https://img.shields.io/npm/v/create-a-npm.svg?logo=npm&logoColor=rgb(0,0,0)&label=版本号&labelColor=rgb(73,73,228)&color=rgb(0,0,0)>)](https://www.npmjs.com/package/create-a-npm) [![issues 提交](<https://img.shields.io/badge/issues-提交-rgb(255,0,63)?logo=github>)](https://github.com/MrMudBead/create-a-npm/issues)
4
+
5
+ > [info]
6
+ > 广告时间到,推荐 [vscode 插件](https://marketplace.visualstudio.com/items?itemName=MrMudBean.auto-last-modified) 自动添加文件头部注释
4
7
 
5
8
  ## 安装
6
9
 
@@ -0,0 +1,226 @@
1
+ THIRD-PARTY LICENSE
2
+ ==================================================
3
+
4
+ a-type-of-js (2.0.0)
5
+ ------------------------------
6
+ # MIT License
7
+
8
+ Copyright (c) <2025> <Mr.MudBean>
9
+
10
+ Permission to use, copy, modify, and/or distribute this software for any
11
+ purpose with or without fee is hereby granted, provided that the above
12
+ copyright notice and this permission notice appear in all copies.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
15
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
16
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
17
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
18
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
19
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
20
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
21
+
22
+ # MIT 许可证
23
+
24
+ 版权所有 (c) [2025] [花生亻]
25
+
26
+ 特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
27
+
28
+ 上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。
29
+
30
+ 软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。
31
+
32
+ a-node-tools (4.4.2)
33
+ ------------------------------
34
+ # MIT License
35
+
36
+ Copyright (c) <2024> <Mr.MudBean>
37
+
38
+ Permission to use, copy, modify, and/or distribute this software for any
39
+ purpose with or without fee is hereby granted, provided that the above
40
+ copyright notice and this permission notice appear in all copies.
41
+
42
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
43
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
44
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
45
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
46
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
47
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
48
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
49
+
50
+ # MIT 许可证
51
+
52
+ 版权所有 (c) [2024] [泥豆君]
53
+
54
+ 特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
55
+
56
+ 上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。
57
+
58
+ 软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。
59
+
60
+ a-js-tools (2.0.1)
61
+ ------------------------------
62
+ # MIT License
63
+
64
+ Copyright (c) <2024> <Mr.MudBean>
65
+
66
+ Permission to use, copy, modify, and/or distribute this software for any
67
+ purpose with or without fee is hereby granted, provided that the above
68
+ copyright notice and this permission notice appear in all copies.
69
+
70
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
71
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
72
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
73
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
74
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
75
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
76
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
77
+
78
+ # MIT 许可证
79
+
80
+ 版权所有 (c) [2024] [泥豆君]
81
+
82
+ 特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
83
+
84
+ 上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。
85
+
86
+ 软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。
87
+
88
+ @qqi/log (1.0.0)
89
+ ------------------------------
90
+ # MIT License
91
+
92
+ Copyright (c) <2025> <Mr.MudBean>
93
+
94
+ Permission to use, copy, modify, and/or distribute this software for any
95
+ purpose with or without fee is hereby granted, provided that the above
96
+ copyright notice and this permission notice appear in all copies.
97
+
98
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
99
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
100
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
101
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
102
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
103
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
104
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
105
+
106
+ # MIT 许可证
107
+
108
+ 版权所有 (c) [2025] [泥豆君]
109
+
110
+ 特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
111
+
112
+ 上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。
113
+
114
+ 软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。
115
+
116
+ @color-pen/static (1.1.1)
117
+ ------------------------------
118
+ # MIT License
119
+
120
+ Copyright (c) <2025> <Mr.MudBean>
121
+
122
+ Permission to use, copy, modify, and/or distribute this software for any
123
+ purpose with or without fee is hereby granted, provided that the above
124
+ copyright notice and this permission notice appear in all copies.
125
+
126
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
127
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
128
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
129
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
130
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
131
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
132
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
133
+
134
+ # MIT 许可证
135
+
136
+ 版权所有 (c) [2025] [泥豆君]
137
+
138
+ 特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
139
+
140
+ 上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。
141
+
142
+ 软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。
143
+
144
+ color-pen (3.0.0)
145
+ ------------------------------
146
+ # MIT License
147
+
148
+ Copyright (c) <2025> <Mr.MudBean>
149
+
150
+ Permission to use, copy, modify, and/or distribute this software for any
151
+ purpose with or without fee is hereby granted, provided that the above
152
+ copyright notice and this permission notice appear in all copies.
153
+
154
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
155
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
156
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
157
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
158
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
159
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
160
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
161
+
162
+ # MIT 许可证
163
+
164
+ 版权所有 (c) [2025] [泥豆君]
165
+
166
+ 特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
167
+
168
+ 上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。
169
+
170
+ 软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。
171
+
172
+ a-command (3.0.1)
173
+ ------------------------------
174
+ # MIT License
175
+
176
+ Copyright (c) <2024> <MrMudBean>
177
+
178
+ Permission to use, copy, modify, and/or distribute this software for any
179
+ purpose with or without fee is hereby granted, provided that the above
180
+ copyright notice and this permission notice appear in all copies.
181
+
182
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
183
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
184
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
185
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
186
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
187
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
188
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
189
+
190
+ # MIT 许可证
191
+
192
+ 版权所有 (c) [2024] [泥豆君]
193
+
194
+ 特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
195
+
196
+ 上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。
197
+
198
+ 软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。
199
+
200
+ qqi (1.0.0)
201
+ ------------------------------
202
+ # MIT License
203
+
204
+ Copyright (c) <2025> <Mr.MudBean>
205
+
206
+ Permission to use, copy, modify, and/or distribute this software for any
207
+ purpose with or without fee is hereby granted, provided that the above
208
+ copyright notice and this permission notice appear in all copies.
209
+
210
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
211
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
212
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
213
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
214
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
215
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
216
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
217
+
218
+ # MIT 许可证
219
+
220
+ 版权所有 (c) [2025] [泥豆君]
221
+
222
+ 特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:
223
+
224
+ 上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。
225
+
226
+ 软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。
package/bin.js ADDED
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ import{statSync as e,readFileSync as n,readdirSync as t,writeFileSync as r,mkdirSync as s,unlinkSync as i}from"node:fs";import{arch as o,homedir as a,userInfo as c}from"node:os";import{dirname as l,normalize as u,join as p,resolve as d}from"node:path";import"node:fs/promises";import{fileURLToPath as f}from"node:url";import{emitKeypressEvents as h}from"node:readline";import{spawn as g}from"node:child_process";import m from"node:https";import{resolve as b}from"node:path/posix";function w(e){const n=typeof e;if("object"!==n&&"function"!==n)return n;const t=Reflect.apply(Object.prototype.toString,e,[]).replace(/^.*\s(.*)]$/,"$1").toLowerCase();return"error"!==t?t:e instanceof SyntaxError?"syntaxerror":e instanceof TypeError?"typeerror":e instanceof URIError?"urierror":e instanceof ReferenceError?"referenceerror":e instanceof AggregateError?"aggregateerror":e instanceof RangeError?"rangeerror":e instanceof EvalError?"evalerror":"error"}function $(e){return"string"===w(e)}function y(e){return"regexp"===w(e)}function v(e){return $(e)&&""===e.valueOf()}function x(e){return $(e)&&""===e.valueOf().trim()}function E(e){return"number"===w(e)}function k(e){return Number.isNaN(e)}function j(e){return 0===e}function C(e){return"boolean"===w(e)}function A(e){return!0===e}function I(e){return!1===e}function T(e){return null===e}function R(e){return void 0===e}function _(e){return"function"===w(e)}function O(e){return Array.isArray(e)}function S(e){if(O(e))return 0===e.length;throw new TypeError("参数必须为数组")}function N(e){return"object"===w(e)}function D(e){return N(e)&&0===Reflect.ownKeys(e).length}function P(e){return"symbol"===w(e)}function F(e,n){return void 0===n||("function"==typeof n?n(e):n)}function M(n){return e(n,{throwIfNoEntry:!1})}function L(e){return e.prototype.apply=Function.apply,e.prototype.bind=Function.bind,e.prototype.call=Function.call,e.prototype.length=Function.length,e.prototype.name=Function.name,e.prototype.toString=Function.toString,e}function G(e,n){return Object.keys(n).forEach(t=>e[t]=n[t]),e}function B(e=1,n=0){if(!isFinite(e)||!isFinite(n)||k(e)||k(n)||!E(e)||!E(n))throw new TypeError("getRandomInt: max or min is NaN or is not a number");let t=Math.ceil(Number(n)),r=Math.floor(Number(e));return r===t?r:(t>r&&([r,t]=[t,r]),Math.round(Math.random()*(r-t)+t))}function H(e){if(!N(e)&&!E(e)||E(e)&&k(e)||E(e)&&!isFinite(e)||E(e)&&!Number.isInteger(e)||E(e)&&Number.isInteger(e)&&e<1||E(e)&&e<1||N(e)&&(!E(e.length)||e.length<1||!Number.isInteger(e.length)))throw new TypeError("参数类型错误 ❌ (getRandomString)");const n={length:32,chars:"abcdefghijklmnopqrstuvwxyz",chars2:"0123456789",chars3:"!@#$%^&*()_+~`|}{[]:;?><,./-=",type:"string",includeUppercaseLetters:!1,includeNumbers:!1,includeSpecial:!1};if("uuid"===n.type)return crypto.randomUUID();E(e)&&Number.isInteger(e)&&e>0&&G(n,{length:e}),N(e)&&(G(n,e),n.length=n.length<1?32:n.length);const t=n.chars.split("");n.includeUppercaseLetters&&o(t,n.chars.toUpperCase()),n.includeNumbers&&o(t,n.chars2),n.includeSpecial&&o(t,n.chars3);let r="";const s=t.join(""),i=s.length;if(globalThis&&globalThis.crypto&&globalThis.crypto.getRandomValues){globalThis.crypto.getRandomValues(new Uint8Array(n.length)).forEach(e=>r+=s[e%i])}else for(let e=0;e<n.length;e++)r+=s[B(i-1)];function o(e,n){const t=e.length,r=n.length,s=Math.max(t,r);for(let i=0;i<s;i++)i<t&&!R(n[i])?e[i]+=n[i]:i<r&&(e[i]=n[i])}if(!/[a-zA-Z]/.test(r))return String.fromCharCode(B(97,122)).concat(r.slice(1));for(;!/^[a-zA-Z]$/.test(r[0]);)r=r.slice(1)+r[0];return r}function U(e,n=200){if(!_(e))throw new TypeError("callback must be a function");let t;E(n)&&(n={delay:n,this:null}),(R(n.delay)||!isFinite(n.delay)||n.delay<0)&&(n.delay=200);const r=()=>{t&&(clearTimeout(t),t=void 0)},s=(...s)=>{r(),t=setTimeout(()=>{try{const t=n&&n.this?n.this:null;e.apply(t,s)}catch(e){console.log("Debounce callback throw an error",e)}},Math.max(n.delay||5,5))};return s.cancel=()=>r(),s}function K(){return!R(globalThis&&globalThis.process&&globalThis.process.versions&&globalThis.process.versions.node||void 0)}function W(e,n){if(!O(e)||!O(n))throw new TypeError("参数需为数组");if(S(e)||S(n))return e;const t=new Set(n);return e.filter(e=>!t.has(e))}const q={union:function(...e){if(S(e))return[];if(e.some(e=>!O(e)))throw new TypeError("参数必须都是数组形式的元素");if(1===e.length)return[...e[0]];const n=new Set;for(const t of e)for(const e of t)n.add(e);return Array.from(n)},intersection:function(e,n){if(!O(e)||!O(n))throw new TypeError("参数必须是数组类型数据");if(S(e)||S(n))return[];const[t,r]=e.length<=n.length?[e,n]:[n,e],s=new Set(t);return r.filter(e=>s.has(e))},difference:W,symmetricDifference:function(e,n){if(!O(e)||!O(n))throw new TypeError("参数必须是数组");return S(e)?[...n]:S(n)?[...e]:[...W(e,n),...W(n,e)]}};async function z(e=1e3){if(!isFinite(e)||e<0)throw new TypeError("delay 应该是一个正常的数值");return j(e)?Promise.resolve():new Promise(n=>setTimeout(n,e))}const V=[!1,!0,"all","info","error","warn"];function Y(e){return!!V.includes(e)&&e}function J(...e){}function Z(){this.error=this.info=this.warn=J}const Q=K()?"node":"browser",X="",ee=`${X}[`;function ne(){return new RegExp(`(\\x1b\\[(${["([1-4]?[0-9])(;([1-4]?[0-9]+))*m","[m]","\\?(25|7)[hl]","\\d*;?\\d*[HFr]","6n","\\d{0,4}[A-DTS]","[0-3]?[JKg]","[0-6]?W"].map(e=>`(${e})`).join("|")}))`.concat("|(\\x1b[78DMc])"),"g")}const te=`${ee}0m`;function re(e,n=!0){if(A(n)){if(!$(e))throw new TypeError("`color` must be a string or number but not number[] when isHex is true");if(e.startsWith("0x"))e=e.replace(/0x/,"#");else if(!e.startsWith("#"))throw new TypeError("`color` must be a string or number but not number[] when isHex is true")}else{if(!I(n))throw new TypeError("The second variable `isHex` must be boolean");if(O(e)){if(e.some(e=>!isFinite(e))||3!==e.length)throw new TypeError("If the `color` is an array, it must be 3 in length and be of numeric type");e=`rgb(${e.join(",")})`}else{if(E(e))throw new TypeError("If the `color` is not number when isHex is false");if($(e)){if(!e.startsWith("rgb(")||!e.endsWith(")"))throw new TypeError("If the `color` is a string, it must be rgb(r, g, b)");{const n=e.replace(/.*\((.*)\).*/,"$1").split(",");if(3!==n.length||n.some(e=>!isFinite(Number(e))||Number(e)<0||Number(e)>255))throw new TypeError("If the `color` is a string, it must be rgb(r, g, b)")}}}}let t=0,r=0,s=0;if(e.startsWith("#"))if(6==(e=e.slice(1)).length)t=se(parseInt(e.slice(0,2),16)),r=se(parseInt(e.slice(2,4),16)),s=se(parseInt(e.slice(4,6),16));else{if(3!=e.length)return B(255);t=se(parseInt(e.slice(0,1).repeat(2),16)),r=se(parseInt(e.slice(1,2).repeat(2),16)),s=se(parseInt(e.slice(2,3).repeat(2),16))}else if(e.startsWith("rgb")){const n=e.replace(/.*\((.*)\).*/,"$1").split(",");t=se(Number(n[0])),r=se(Number(n[1])),s=se(Number(n[2]))}return 16+36*t+6*r+s}function se(e){const n=isFinite(e)?Math.floor(6*e/256):B(6);return Math.min(5,Math.max(0,n))}function ie(e,n,t,r=!0){const s=r?"38":"48";if(E(e)&&E(n)&&E(t))return`${s};5;${re([e,n,t],!1)}`;if($(e)&&R(n)&&R(t)){if(e.startsWith("rgb"))return`${s};5;${re(e,!1)}`;if(e.startsWith("#")||e.startsWith("0x"))return`${s};5;${re(e,!0)}`;oe()}else{if(E(e)&&R(n)&&R(t))return`${s};5;${re(e,!0)}`;oe()}}function oe(){throw new TypeError(' 使用 color() 或 bgColor() 时,可使用三整数 `r , g , b` 或单字符串 `"rgb(r , g, b)"` 或十六进制数值 `0xrgb`、`0xrrggbb` 或十六进制字符串表达 `"#rgb"`、`"#rrggbb"` ,不接受其他格式的参数')}function ae(e,n,t,r=!0){try{return ie(e,n,t,r)}catch(e){throw console.error(e),new TypeError('使用 rgb() 或 bgRgb() 时,参数可以为单字符串 `"rgb(r, g, b)"` 或三个数值 `r , g ,b`。不接受其他格式')}}function ce(e,n=!0){try{return ie(e,void 0,void 0,n)}catch(e){throw console.error(e),new TypeError('使用 hex() 或 bgHex() 时,参数可以为单字符串 `"0xnnnnnn"`、`"#rgb"` 、`"#rrggbb"` 或一个数值 `0xrrggbb`。不接受其他格式')}}function le(e,n=!1){return e<0&&(e=0),e>255&&(e=255),e=isFinite(e)?Math.round(e):B(255),`${[48,38][Number(n)]};5;${e}`}const ue={black:"38;5;0",red:"38;5;1",green:"38;5;2",yellow:"38;5;3",blue:"38;5;4",magenta:"38;5;5",cyan:"38;5;6",white:"38;5;7",brightBlack:"38;5;8",brightRed:"38;5;9",brightGreen:"38;5;10",brightYellow:"38;5;11",brightBlue:"38;5;12",brightMagenta:"38;5;13",brightCyan:"38;5;14",brightWhite:"38;5;15",bgBlack:"48;5;0",bgRed:"48;5;1",bgGreen:"48;5;2",bgYellow:"48;5;3",bgBlue:"48;5;4",bgMagenta:"48;5;5",bgCyan:"48;5;6",bgWhite:"48;5;7",bgBrightBlack:"48;5;8",bgBrightRed:"48;5;9",bgBrightGreen:"48;5;10",bgBrightYellow:"48;5;11",bgBrightBlue:"48;5;12",bgBrightMagenta:"48;5;13",bgBrightCyan:"48;5;14",bgBrightWhite:"48;5;15",bold:"1",dim:"2",italic:"3",underline:"4",blink:"5",reversed:"7",hide:"8",random:"random",bgRandom:"bgRandom",rgb:(e,n,t)=>ae(e,n,t),hex:e=>ce(e),color:(e,n,t)=>ie(e,n,t),number:e=>le(e,!0),bgRgb:(e,n,t)=>ae(e,n,t,!1),bgHex:e=>ce(e,!1),bgColor:(e,n,t)=>ie(e,n,t,!1),bgNumber:e=>le(e)};Object.freeze(ue);const pe=["#000000","#c23621","#25bc24","#adad29","#492ee1","#dd38dd","#33bbc8","#cbcccd","#818383","#fc391f","#31e722","#eaec23","#5833ff","#f93578","#14f0f0","#ebeded"];function de(e){let n=Number(e);if(!isFinite(n))throw new TypeError("色值反向解析出错");if(n<16){return pe[n]}const t=e=>Math.floor(256*e/6+B(42)).toString(16).padStart(2,"0");n-=16;const r=n%36;return`#${t(Math.floor(n/36))}${t(Math.floor(r/6))}${t(r%6)}`}class fe{constructor(e){this.parse(e),this.build()}build(){this.hide&&(this.color="transparent"),this.reversed&&([this.color,this.bgColor]=[this.bgColor,this.color]),R(this.color)||(this.str+=`color: ${this.color};`),R(this.bgColor)||(this.str+=`background: ${this.bgColor};`),0!==this.bold&&(this.str+=`font-weight: ${1===this.bold?800:200};`),this.italic&&(this.str+="font-style: italic;"),this.underline&&(this.str+="border-bottom: 1px #666 solid;")}color=void 0;bgColor=void 0;bold=0;italic=!1;underline=!1;reversed=!1;hide=!1;str="";parse(e){e.replace(/38;5;(\d+)/g,"c-$1").replace(/48;5;(\d+)/g,"b-$1").split(";").reverse().forEach(e=>{0===this.bold&&e===ue.bold?this.bold=1:0===this.bold&&e===ue.dim?this.bold=-1:e===ue.italic?this.italic=!0:e===ue.underline?this.underline=!0:e===ue.reversed?this.reversed=!0:e===ue.hide?this.hide=!0:R(this.color)&&e.startsWith("c")?this.color=de(e.split("-")[1]):R(this.bgColor)&&e.startsWith("b")&&(this.bgColor=de(e.split("-")[1]))})}}function he(e){return K()?[e]:function(e){e=e.replace(new RegExp("\\\\[0m","g"),"");const n=ne(),t=[""];let r,s=0,i="";const o=()=>{const n=e.substring(s,r?.index??e.length);t[0]+="%c".concat(n),t.push(i)};for(;!T(r=n.exec(e));)o(),i=R(r[7])?new fe(r[3].slice(0,-1)).str:"",s=n.lastIndex;return o(),t}(e)}function ge(e,n){if(v(e=T(e)||R(e)?"":e.toString()))return"";if(S(n))return e;const t=e.indexOf(ee),r=e.indexOf(`${ee}0m`);return n=function(e){return e.map(e=>"random"===e?`38;5;${B(255)}`:"bgRandom"===e?`48;5;${B(255)}`:e)}(n),t>-1&&r>-1?ge(e.substring(0,t),n).concat(e.substring(t,r+4)).concat(ge(e.substring(r+4),n)):e.endsWith("\r\n")?(e=e.substring(0,e.length-2),`${ee}${n.join(";")}m${e}${ee}0m\r\n`):e.endsWith("\n")?(e=e.substring(0,e.length-1),`${ee}${n.join(";")}m${e}${ee}0m\n`):`${ee}${n.join(";")}m${e}${ee}0m`}function me(e,n){const t=parseInt(n);if(t>10){const r=A(38===t)?"38;5;":"48;5;",s=e.findIndex(e=>e.startsWith(r));return s>-1?e.toSpliced(s,1,n):[...e,n]}return e.includes(n)?[...e]:[...e,n]}const be=L(function(e=[]){const n=(n,...t)=>{if(F(n,()=>O(n)&&n.every(e=>$(e)))){let r="";for(let s=0;s<n.length;s++)r+=ge(n[s],e),s<t.length&&(r+=ge(t[s],e));return r}if(S(t))return ge(n,e);throw new Error("pen: 缺少参数")},t=Object.keys(ue).map(n=>[n,{get:()=>function(e,n){let t=[];if(F(e,$(ue[e])))return t=me(n,ue[e]),new be(t);if("hex"===e||"bgHex"===e)return r=>(t=me(n,ue[e](r)),new be(t));if("rgb"===e||"bgRgb"===e)return(r,s,i)=>{if($(r)&&R(s)&&R(i))t=me(n,ue[e](r));else{if(!(E(r)&&E(s)&&E(i)))throw new Error(`${e} 的参数类型不正确,请使用 'rgb' 或 'hex' 函数`);t=me(n,ue[e](r,s,i))}return new be(t)};if("color"===e||"bgColor"===e)return(r,s,i)=>{if($(r)&&R(s)&&R(i))t=me(n,ue[e](r));else{if(!(E(r)&&E(s)&&E(i)))throw new Error(`${e} 的参数类型不正确,请使用 'rgb' 或 'hex' 函数`);t=me(n,ue[e](r,s,i))}return new be(t)};if("number"===e||"bgNumber"===e)return r=>{if(E(r))return t=me(n,ue[e](r)),new be(t);throw new TypeError(`${e} 的参数应为有效正整数数值,范围 0 - 255`)};throw new Error(`${e} 函数不存在`)}(n,e)}]),r=Object.fromEntries(t);return Object.defineProperties(n,r),n});const we=new be([]),$e=new be([ue.red]),ye=new be([ue.green]),ve=new be([ue.yellow]);new be([ue.blue]);const xe=new be([ue.magenta]),Ee=new be([ue.cyan]);new be([ue.white]);const ke=new be([ue.brightBlack]),je=new be([ue.brightRed]),Ce=new be([ue.brightGreen]),Ae=new be([ue.brightYellow]);new be([ue.brightBlue]);new be([ue.brightMagenta]),new be([ue.brightCyan]);new be([ue.brightWhite]),new be([ue.bgBlack]),new be([ue.bgRed]),new be([ue.bgGreen]),new be([ue.bgYellow]),new be([ue.bgBlue]),new be([ue.bgMagenta]),new be([ue.bgCyan]),new be([ue.bgWhite]),new be([ue.bgBrightBlack]),new be([ue.bgBrightRed]),new be([ue.bgBrightGreen]),new be([ue.bgBrightYellow]),new be([ue.bgBrightBlue]);const Ie=new be([ue.bgBrightMagenta]);new be([ue.bgBrightCyan]),new be([ue.bgBrightWhite]);const Te=new be([ue.bold]),Re=new be([ue.italic]),_e=new be([ue.underline]),Oe=new be([ue.hide]);new be([ue.dim]),new be([ue.blink]),new be([ue.reversed]),we.rgb;const Se=we.hex,Ne=we.color;we.bgRgb;const De=we.bgHex;we.bgColor;const Pe=we.random;function Fe(e){const n=ne(),t=e.replace(n,"");let r=0;for(let e=0,n=t.length;e<n;e++)r+=1+Number(Me(t[e]));return r}function Me(e){const n=e.codePointAt(0)||0;return n>=19968&&n<=40959||n>=13312&&n<=19903||n>=131072&&n<=191471||n>=63744&&n<=64255||n>=65280&&n<=65519||n>=65381&&n<=65439||n>=127744&&n<=129750||n>=128512&&n<=128591||n>=128640&&n<=128767||n>=9728&&n<=9983||n>=9984&&n<=10175||n>=44032&&n<=55215||n>=12288&&n<=12351}function Le(e,n,t=!0){const r=n,s=e;if(0===r)return"";let i=!1;const o=Fe(s);if(o<=r)return s.concat(" ".repeat(r-o));const a=r>0,c=ne();c.lastIndex=0;const l=[...s.replaceAll(c,"")],u=a?l:l.reverse(),p=u.length,d=Math.abs(r);let f=Math.floor(d/2),h=u.slice(0,f).join(""),g=Fe(h);for(;f<p;){if(g+=Fe(u[f]),g===d){h+=u[f];break}if(g===d+1){t&&(i=!0);break}if(g>d+1)break;h+=u[f],f++}if(a&&s.startsWith(h)||!a&&s.endsWith(h=[...h].reverse().join("")))return i?h+" ":h;if(a){let e;for(c.lastIndex=0;null!==(e=c.exec(s));){const n=h;if(h=n.slice(0,e.index).concat(e[0]).concat(n.slice(e.index)),s.startsWith(h))break}h+=te}else{const e=[...h];let n=e.length-1;h="";const t=[...s].reverse();for(let r=0,s=t.length;r<s;r++){const s=t[r];if(s===e[n])--n;else if(n<0)break;h=s+h}h=te+h}return i?h+" ":h}function Ge(e){return`${ee}?7l${e.toString()}${ee}?7h`}function Be(e){try{throw new Error}catch(n){const t=(n.stack?.split("\n")||[]).map(e=>{const n=/at\s(.*)\s\((.*):(\d*):(\d*)\)/.exec(e);return n?{name:n[1],path:n[2],line:n[3],column:n[4]}:{name:""}}),r=t.filter(e=>""!==e.name&&void 0!==e.path),s=r[3]??r[2]??r[1]??r[0],i=` ${"info"===e?"💡":"error"===e?"❌":"⚠️ "} ${(new Date).toLocaleString()} `,o=("info"===e?we.bgCyan.brightWhite:"error"===e?we.bgBlack.red:we.bgBrightYellow.brightGreen)(i);console.log(`${o} ${s?.name??""} ${s?.line?.concat(" 行")} ${s?.column?.concat(" 列")}`)}}function He(...e){Be("error"),console.error(...e)}function Ue(...e){Be("warn"),console.warn(...e)}function Ke(...e){Be("info"),console.info(...e)}function We(e,n,t){if("node"===Q){const r=globalThis?.process.env[t.toUpperCase().concat("_DEV")]||globalThis?.process.env[t.toLowerCase().concat("_dev")];if(!1===e||R(r)||"false"===r)return Reflect.apply(Z,n,[]);[...V,"true","false"].includes(r)&&(e="true"===r?"all":r),n.info=["all","info",!0].includes(e)?Ke:J,n.error=["all","error",!0].includes(e)?He:J,n.warn=["all","warn",!0].includes(e)?Ue:J}else{if(!1===e)return Reflect.apply(Z,n,[]);n.info=["all","info",!0].includes(e)?Ke:J,n.error=["all","error",!0].includes(e)?He:J,n.warn=["all","warn",!0].includes(e)?Ue:J}}function qe(e){R(e)&&(e={name:H(10),type:!1}),C(e)&&(e={name:H(10),type:e}),$(e)&&(e={name:e,type:!1});let{name:n="",type:t=!1}=e;n=n.trim().replace(/\s+/g,"_");const r="node"===Q&&(globalThis?.process.env[n.toUpperCase().concat("_DEV")]??globalThis?.process.env[n.toLowerCase().concat("_dev")])||!1;t="node"!==Q||Y(("false"!==r&&("true"===r||r))??t);const s={error:J,warn:J,info:J};We(t,s,n);const i=(...e)=>{Reflect.apply(s.info,this,e)};return Object.setPrototypeOf(i,this),Object.defineProperties(this,{type:{get:()=>t||!1,set(e){const r=Y(e);r!==t&&(t=r,We(t,s,n))}},error:{value:(...e)=>Reflect.apply(s.error,this,e),configurable:!1,enumerable:!1,writable:!1},warn:{value:(...e)=>Reflect.apply(s.warn,this,e),configurable:!1,enumerable:!1,writable:!1}}),i}we.bgRandom,we.number,we.bgNumber,qe.prototype.clear=()=>{"browser"===Q?console.clear():console.log(X.concat("c"))};const ze=L(qe),Ve=new ze({type:"error",name:"a node tools"});function Ye(...e){return u(p(...e))}function Je(e,n="file",...t){t=t.filter(e=>$(e));let r=d(...t);const s=M(r);if(Ve("当前工作目录",r),!s)return Ve("🎯 工作目录不存在"),"";if(s.isFile())r=l(r);else if(!s.isDirectory())return;let i=20;const o=()=>{const t=M(Ye(r,e));if(t&&("file"==n&&t.isFile()||"directory"==n&&t.isDirectory()))return r;if(j(i))return;i--,Ve("♻️ 查找中...",r);const s=Ye(r,"..");return s!==r?(r=s,o()):void 0};return o()}function Ze(t){if(!/.json^/.test(t)&&!e(t,{throwIfNoEntry:!1}))return null;try{const e=n(t,{encoding:"utf-8"});return JSON.parse(e||"null")}catch(e){return Ve.error(e),null}}function Qe(e){try{const n=M(e);if(n&&n.isDirectory())return 0==t(e,{withFileTypes:!0}).length?1:0}catch(e){return Ve.error("is ",e),-1}return-1}function Xe(e,n){try{return r(e,JSON.stringify(n,null,2),{encoding:"utf-8",flag:"w"}),!0}catch(e){return Ve.error(e),!1}}const en=Xe,nn=()=>K()&&process&&process.stdout&&process.stdout.isTTY||!1,tn=K()&&"win32"===process.platform||!K()&&window.navigator.userAgent.includes("Windows");function rn(e){const n=new RegExp(e);let t;try{throw new Error}catch(e){t=e}const r=(t.stack?.replace(/\\/gm,"/").split("\n")).reverse(),s=r.findIndex((e,t,r)=>!n.test(e)&&n.test(r[t+1]));if(-1==s)return{name:"",line:0,row:0,originArr:r};let i=r[s];return/\(.*\)/.test(i)&&(i=i.replace(/^.*\((.*)\).*/,"$1")),/file:\/*/.test(i)&&(i=i.replace(/^.*file:\/*(.*)/,"$1")),tn||i.startsWith("/")||(i="/"+i),{name:i.replace(/^(.*):\d+:\d+$/,"$1"),line:Number(i.replace(/^.*:(\d+):\d+$/,"$")),row:Number(i.replace(/^.*:\d+:(\d+)$/,"$1")),originArr:r}}function sn(){let e;try{new Function('import("")'),e=f(import.meta.url)}catch(n){Ve.error(n),e=__filename}tn&&(e=e.replace(/\\/gm,"/")),e=rn(e).name;return[e,l(e)]}const{stdin:on}=process,an={list:[],listened:!1,on(e,n,t){I(this.listened)&&(this.listened=!0,h(process.stdin),nn()&&process.stdin.setRawMode(!0),process.stdin.resume(),on.on("keypress",un),process.on("beforeExit",cn),process.stdin.on("end",ln));const r=this.list,s={key:e,callback:n,resolve:t};return S(r)&&Ve("当前执行的栈中没有数据",s),r.push(e),this[e]=s,s},remove(){const e=this.list,n=e.shift();return n&&this.del(n),Ve("执行完毕一项,还有:",e),!(e.length>0)&&(this.listened=!1,cn(),Ve("监听已移除"),!0)},del(e){Ve("开始移除",e);const n=this.list[0]===e&&!R(this[e]);if(Ve("当前 key 是否为当前执行项",n),n)return this.remove(),!0;{const n=this.list.includes(e),t=!R(this[e]);return n&&t?(this.list.splice(this.list.indexOf(e),1),this[e].resolve(!0),delete this[e],!0):n?(this.list.splice(this.list.indexOf(e),1),!0):!!t&&(this.list.splice(this.list.indexOf(e),1),this[e].resolve(!0),!0)}}};function cn(){on.removeListener("keypress",un),process.removeListener("beforeExit",cn),process.stdin.removeListener("end",ln),nn()&&on?.setRawMode(!1),on.pause()}function ln(){cn()}function un(e,n){const t=an[an.list[0]],{callback:r,resolve:s}=t;Ve("当前执行的回调是",{...t,rl:"原始值为 readline 的 Interface 对象"}),_(r)?A(Reflect.apply(r,null,[e,n]))&&(Ve("回调遇见了想待的键,执行了退出操作,keyValue: < ",e,"> key: <",n,">"),an.remove(),s(!0)):(an.remove(),s(!1))}const pn=(e,n)=>async function(e,n){if(!K())throw new RangeError("当前环境不支持 readInput");const t=n??Symbol(H(3));return new Promise(n=>{an.on(t,e,n)})}(e,n);function dn(e="",n=!0){let t="";const r=w(e);if(!C(n))throw Ve.error(""),new TypeError("lineFeed 的类型必须是 boolean ");if("bigint"===r){const r=Object.prototype.toString.call(e).concat("n");t=n?`${r}\n`:`${r}`}else if(["string","number","boolean","function","null"].includes(r))t=n?`${e}\n`:`${e}`;else{const r=JSON.stringify(e,(e,n)=>_(n)?`${n}`:null==n?"undefined":n,2);t=n?`${r}\n`:`${r}`}K()?process.stdout.write(t):console.log(...he(t.replace(/\n$/,"")))}function fn(e,n){e=(e=e?.toString?e:"").toString();const t=process.stdout.columns,r=[..."-".repeat(t)].map(e=>Pe(e)).join("");if(x(e))e=r;else{e=A(n)?[...e].map(e=>Pe(e)).join(""):Ne(n)(e);const s=Fe(e=Le(e,t-4).trim());e=Le(e+r,t-Math.floor((t-s)/2)),e=Le(r+e,-t)}dn(),dn(e)}function hn(e,n=!0){dn(`${n?ee:X}${e}`,!1)}function gn(){hn("?25l")}function mn(){hn("?25h")}function bn(e=!1){e&&$n(1/0),hn("0J")}function wn(e=1,n=!1){hn(`${vn(e,"vertical")}A`),n&&$n(1/0)}function $n(e=1){hn(`${vn(e)}D`)}function yn(e=1){hn(`${vn(e)}C`)}function vn(e,n="horizontal"){(!E(e=Number(e))||isNaN(e)||e<1||!1===Number.isInteger(e)&&e!==1/0)&&(e=1);const t=K()?"horizontal"===n?process.stdout.columns:process.stdout.rows:80;return(1/0===e||e>t)&&(e=t),e}function xn(){mn()}function En(e){const n=e[e.length-1];$(n)&&!n.endsWith("\n")&&e.push("\n"),e.forEach(e=>dn(e,!1))}function kn(e,n){const{show:t,info:r,prefix:s,interval:i,canCtrlCExit:o,canCtrlDExit:a,beforeDestroyed:c}=n??{show:!0,info:"请等待",prefix:0,interval:20,canCtrlCExit:!1,canCtrlDExit:!1,beforeDestroyed:()=>{}},l=C(e)?{show:e,info:r,prefix:s,interval:i,canCtrlCExit:o,canCtrlDExit:a,beforeDestroyed:c}:$(e)?{show:t,info:e,prefix:s,interval:i,canCtrlCExit:o,canCtrlDExit:a,beforeDestroyed:c}:R(e)?{show:t,info:r,prefix:s,interval:i,canCtrlCExit:o,canCtrlDExit:a,beforeDestroyed:c}:E(e)?{show:!0,info:"请等待",prefix:isNaN(e)?s:Math.min(Math.max(0,e),2),interval:i,canCtrlCExit:o,canCtrlDExit:a,beforeDestroyed:c}:{show:t,info:r,prefix:s,interval:i,canCtrlCExit:o,canCtrlDExit:a,beforeDestroyed:c,...e};return l.interval=isFinite(l.interval)?Math.max(20,Math.min(2e3,l.interval)):i,l.info=l.info.replace(/\n/g,"\\n"),l}function jn(){mn()}Object.defineProperties(pn,{remove:{value:e=>an.del(e)}});const Cn=[".","..","...","....","...",".."],An=[["⋯","⋱","⋮","⋰","⋯","⋱","⋮","⋰"],["🕐","🕑","🕒","🕓","🕔","🕕","🕖","🕗","🕘","🕙","🕚","🕛"],["🕜","🕝","🕞","🕟","🕠","🕡","🕢","🕣","🕤","🕥","🕦","🕧"],["👈","👆","👉","👇","🤘","🤟","🫳","🫴","👊"],["🌞","🌕","🌖","🌗","🌜","🌘","🌑","🌒","🌓","🌛","🌔","🌔","🌔","🌝"]];class In{#e;#n=void 0;#t=Symbol("waiting-tips");#r=[];#s=(...e)=>En(e);state="destroyed";#i=0;#o=4e4;#a=!1;async destroyed(){"destroyed"!==this.state&&(this.state="destroyed",this.#i=0,R(this.#n)||clearInterval(this.#n),pn.remove(this.#t),$n(1/0),bn(),process.removeListener("exit",xn),process.removeListener("SIGINT",jn),mn(),this.#r.forEach(e=>this.#s(...e)),this.#r.length=0,this.log=this.#s,!function(e){return"promise"===w(e)}(this.#e.beforeDestroyed)?this.#e.beforeDestroyed(this.#a):await this.#e.beforeDestroyed(this.#a),this.#a=!1)}log=this.#s;run(e){"run"===this.state&&this.destroyed(),this.#a=!1,this.state="run",this.#i=Date.now(),this.#e=R(e)?this.#e:kn(e,this.#e);const{prefix:n,info:t,interval:r,canCtrlCExit:s,canCtrlDExit:i}=this.#e;this.log=(...e)=>this.#r.push(e);const o=Cn.length,a=An[Math.min(An.length-1,Math.max(n,0))],c=a.length,l=a.reduce((e,n)=>Math.max(e,Fe(n)),0);let u=0;gn(),process.on("exit",xn),process.on("SIGINT",jn),this.#n=setInterval(()=>{bn(!0),this.#r.forEach(e=>En(e)),this.#r.length=0,dn("\n".repeat(2)),wn(3),hn(7,!1);const e=Le(a[++u%c],l);Date.now()-this.#i<this.#o?dn(Ge(`${e} ${t.replace(/\n/,"\\n")}${Cn[Math.floor(u/10)%o]}`),!1):dn(Ge(`${e} ${t} ${xe`当前已执行 ${Math.ceil((Date.now()-this.#i)/1e3)} 秒`}\n \n\r${Ee`可使用双击 esc 键退出(确保执行完成,若执行仍在期望时间内,请忽略)`}`),!1),hn(8,!1)},r),pn((e,n)=>!!(n?.meta&&n?.sequence===X.repeat(2)||A(n?.ctrl)&&(s&&"c"===n?.name||i&&"d"===n?.name))&&(this.#a=!0,this.destroyed(),!0),this.#t)}set timeout(e){this.#i=Date.now(),this.#o=!isFinite(e)||e<0?4e4:e<600?1e3*e:e}get timeout(){return this.#o}constructor(e){this.#e=kn(e),A(this.#e.show)&&this.run()}}function Tn(e){return new In(e)}function Rn(e,n,t){let r=e.toString().trim();return/\n$/.test(r)||(r=r.concat(tn?"\r\n":"\n")),r=r.replace(/\n+/g,"\n"),bn(),n&&t.log(r),r}function _n(e){const n={result:{success:!1,data:"",error:"",status:1,isSIGINT:!1,runCode:"",runCwd:""},env:{cmd:[],code:"",cwd:"",printLog:!1,shell:!0,callBack:()=>{},waiting:{show:!1,info:"",prefix:0,interval:10,canCtrlDExit:!1,canCtrlCExit:!1,async beforeDestroyed(){}}}},{env:t,result:r}=n;Ve("runOtherCode 方法 开始执行 "),function(e,n){if(I(K()))throw new RangeError("当前环境不支持 node 环境");const{env:t}=n;$(e)&&(t.code=e,e={code:e,waiting:!1});const r=process.cwd();let s=b(r,e.cwd||"");-1===Qe(s)&&(Ve(`执行目录 ${$e(s)} 不存在,使用命令执行目录 ${Ee(r)}`),s=r);const i=e.code.replace(/\s{2,}/g," ").trim().split(" ");Object.assign(n.env,{shell:!0,hideWaiting:!0,waitingMessage:"请稍等",printLog:!1,...e,cmd:i,cwd:s})}(e,n),Ve("执行参数",n);const{cmd:s,waiting:i,cwd:o,shell:a,code:c}=t,[l,u]=(()=>{if(i instanceof In)return[i,"run"===i.state];const e=kn(i);return[Tn(e),e.show]})();r.runCode=c,r.runCwd=o||process.cwd();try{return new Promise(e=>{const t=A(a)?g(c,[],{cwd:o,shell:a}):g(s[0],s.slice(1),{cwd:o,shell:a});u&&l.run({beforeDestroyed:e=>{if(e){if(Ve("执行退出前"),tn){try{t.killed||t.kill(-1)}catch(e){Ve.error("使用 child.kill(child.pid, -1 ) 关闭子进程失败",e),g("taskkill",["/pid",t.pid?.toString()||"","/T","/F"],{stdio:"pipe"})}Ve("终结在 windows 下的子进程")}else t.kill("SIGTERM"),Ve("终结在非 windows 下的子进程");n.result.isSIGINT=!0}}}),t.on("spawn",()=>function(e){const{result:n}=e;Ve("子线程已启动,运行状态良好"),n.success=!0,n.status=1}(n)),t.stdout.on("data",e=>function(e,n,t){const{env:r,result:s}=n,i=Rn(e,r.printLog,t);Ve(Ie`stdout on data`,i),s.data+=i}(e,n,l)),t.on("exit",(e,n)=>{Ve("子进程已退出了,退出码为 <",e,">"),T(n)||Ve.error("子进程被其他信号中断执行,执行的退出信号为:",n)}),t.stderr.on("data",e=>function(e,n,t){const{env:r,result:s}=n,i=Rn(e,r.printLog,t);Ve(Ie`stderr on data`,i),s.error+=i}(e,n,l)),t.on("error",e=>function(e,n,t){const{env:r,result:s}=n;{const n=Rn(e,r.printLog,t);Ve(Ie`error`,n),Ve.error("error",n),s.success=!1,s.status=""!==s.data?2:3,s.error+=n}}(e,n,l)),t.on("close",(t,r)=>function(e,n,t,r,s){const{env:i,result:o}=r,{callBack:a}=i;Ve("进行正常关闭",e),setTimeout(async()=>{a&&_(a)&&Reflect.apply(a,null,[]),await s.destroyed(),0!==e&&"SIGINT"!==n&&"SIGTERM"!==n?(o.success=!1,o.status=3):"SIGINT"!==n&&"SIGTERM"!==n||(o.success=!1,o.status=4,o.isSIGINT=!0),t(o)})}(t??0,r??"",e,n,l))})}catch(e){const n=e.toString();return Ve.error("创建(但是确是非 node 无法创建子进程,而是更上游的 node 创建的错误)子进程出错",e),new Promise(e=>{(async()=>{await l.destroyed()})(),r.error=n,r.success=!1,r.status=0,e(r)})}}const On=e=>_n(e);async function Sn(e,n="官方",t=5e3){const r={"淘宝":"registry.npmmirror.com","官方":"registry.npmjs.org","腾讯":"mirrors.tencent.com","中科大":"npmreg.proxy.ustclug.org",yarn:"registry.yarnpkg.com"},s=r[n]||r["官方"];return Ve("get npm pkg info 开始执行"),new Promise(r=>{(()=>{let i="";const o=function(e){if(!e||!$(e))return null;if(e.includes("@")){const n=e.replace(/\/+/g,"/").replace(/@+/g,"@").replace(/\/$/,"").split("@").map(e=>e.trim().replace(/^\/*/,"")),t=n.length;return""===n[0]?3===t||2===t&&""!==n[1]?`@${n[1]}`:null:2===t?`${n[0]}`:null}return e}(e)||"a-node-tools";Ve("解析后的 pkg 名称",o);const a=("腾讯"===n?"/npm":"").concat(`/${o}`),c={hostname:s,path:a,port:443,method:"GET",timeout:t,headers:{"sec-fetch-dest":"empty","X-Spiferacl":"1"}};Ve("请求参数",c);const l=m.get(c,e=>{e.on("data",e=>{R(e)||(i+=e.toString())}),e.on("end",()=>{if(200==e.statusCode)try{const e=JSON.parse(i);e.version=e["dist-tags"].latest,r({data:e,success:!0,status:"success",error:null})}catch(e){Ve.error("转化错误",e),r({data:null,success:!0,status:"parseJsonError",error:e,message:i})}else 404==e.statusCode?r({data:null,success:!0,status:"notFound",error:null,message:"npm 中没有该包"}):r({data:null,success:!0,status:"otherCode",error:null,message:`请求的返回请求码: ${e.statusCode}`})})});l.on("error",e=>{Ve.error("请求错误",e),r({data:null,success:!1,status:"error",error:e})}),l.on("timeout",()=>{Ve.error("请求超时"),l.destroy(),r({data:null,success:!1,status:"timeout",error:null})}),l.end(),Ve("结束方法")})()})}const Nn=process.argv.slice(2);Object.freeze(Nn);class Dn{originalArg=Nn.slice();name="";__filename="";get state(){return this._state}set state(e){this._state=[void 0,{code:1,text:"start"},{code:2,text:"bind over"},{code:3,text:"run over"},{code:4,text:"over",overCode:e}][E(e)?e:4]}_state={code:1,text:"start"};args=new Pn;abbr={};helpInfo="";hasShowVersion=!1;originalBind={};values=[]}class Pn extends Array{get $nomatch(){return[]}get $map(){return{}}get $arrMap(){return[]}get $only(){return[]}get $original(){return[]}get $isVoid(){return!1}}const Fn={},Mn=new ze({name:"a command"}),Ln=I(Mn.type);function Gn(e){return[e.replace(/^(.*?)\s.*/gm,"$1")||"",/<.+>/.test(e)&&e.replace(/.*<(.+)>.*/,"$1")||"",e.replace(/.*?\((.*)\).*?/,"$1")||""]}function Bn(e,n){switch(n.state.code){case 3:return void Mn.warn("执行绑定","但是已经执行过 `run`");case 4:return void Mn.warn("执行绑定,但是 command 已完成全部应做动作");default:n.state=2}if($(e)){const[t,r,s]=Gn(e);return Bn({name:t,abbr:r,info:s},n)}if(O(e))return e.forEach(e=>Bn(e,n));if(!R(e)&&!e.name&&!e.info)return function(e,n){const t={name:"",info:"",abbr:"",options:[]},r=Object.keys(e),s=Object.keys(t);return r.forEach(t=>{if(!s.includes(t)){const[r,s,i]=Gn(t);return Bn({name:r,info:i,abbr:s,options:e[t]},n)}})}(e,n);const t=e;t.abbr&&(n.abbr[t.abbr]=t.name),t.options?t.options=function(e,n,t){O(e)||(e=[e]);const r={};return e.forEach(e=>{let s={name:"",abbr:"",info:""};$(e)?[s.name,s.abbr,s.info]=Gn(e):s=Object.assign(s,e),s.abbr&&(t.abbr[`${n}^${s.abbr}`]=s.name),r[s.name]=s}),r}(t.options,t.name,n):t.options={},n.originalBind[t.name]={abbr:"",...t}}function Hn(){return new Proxy(new Dn,{get(e,n,t){if("args"===n){const n=JSON.parse(JSON.stringify(e[Symbol.for("_args")]||[]));return new Proxy(n,{get(t,r,s){return"$nomatch"===r?e.values.slice():"$map"===r?function(e){if(S(e))return{};const n=new Object;return e.forEach(e=>{const t=n[e.name]||{};t.value=[...t.value||[],...e.value||[]],e.options&&e.options.forEach(e=>{t[e.name]=[...t[e.name]||[],...e.value||[]]}),n[e.name]=t}),n}(n):"$arrMap"===r?S(i=n)?[]:i.map(e=>{const n={},t=n[e.name]||{};return e.value&&!S(e.value)&&(t.value=e.value),R(e)||R(e.options)||S(e.options)||(t.options=[],e.options.forEach(e=>{t.options?.push(Object.fromEntries([[e.name,e.value]]))})),n[e.name]=t,n}):"$only"===r?[...new Set(n.map(e=>e.name))]:"$original"===r?Nn.slice():"$isVoid"===r?0==Nn.slice().length:Reflect.get(t,r,s);var i},set:(e,n,t,r)=>(Reflect.set(e,n,t,r),!0)})}return Reflect.get(e,n,t)},set:(e,n,t,r)=>("args"===n?e[Symbol.for("_args")]=t:Reflect.set(e,n,t,r),!0)})}const Un=" ".repeat(4);function Kn(e){return e.state="help",$(e.helpInfo)&&"help"!==e.helpInfo?function(e,n){const t=e.originalBind[n];if(dn(`${Un}${t.name}${Un}${xe(t.info)}\n`),t.options&&!D(t.options)){dn(`${ve(`${Un}使用:`)} ${e.name} ${n} [subOptions/subAbbr [value]]\n`),dn(`${Ee(`${Un}subOptions:`)} \n`),Wn(t.options||{})}else{dn(`${ye(`${Un}使用:`)} ${e.name} ${n} [value]\n`)}}(e,e.helpInfo):O(e.helpInfo)&&2==e.helpInfo.length?function(e){const n=e.name,t=e.helpInfo.join(" "),r=e.originalBind[e.helpInfo[0]].options[e.helpInfo[1]].info;dn(`${Ee(" 可使用:")} ${n} ${t} [value]\n${ye(" 描述:")} ${r}`)}(e):function(e){dn(`${je(" 可使用:")} ${e.name} options/abbr [subOptions/subAbbr [value]]\n\n选项:\n`);const n=Wn(e.originalBind);!function(e){["version -v 版本描述","help -h 帮助查看"].forEach(n=>{const[t,r,s]=n.split(" ");dn(qn({len:e,name:t,info:s,abbr:r})),dn("")})}(n)}(e)}function Wn(e){const n=Object.keys(e).sort();let t=8;n.forEach(e=>t=Math.max(t,e.length));const r=Math.min(15,t+1);return dn(qn({len:r,name:"子命令",info:"描述",abbr:"缩写",color:!1})),dn(""),n.forEach(n=>{const{name:t,abbr:s,info:i}=e[n];let o=!1;"options"in e[n]&&!D(e[n].options)&&(o=!0),dn(qn({len:r,name:t,info:i,abbr:s,textDecoration:o})),dn("")}),r}function qn(e){const n=Object.assign({name:"",info:"",abbr:"",len:15,color:!0,textDecoration:!1},e);let t=we[n.color?"green":"black"](Un);return t+=we[n.textDecoration?"blue":"black"](n.name.slice(0,n.len)),t+=" ".repeat(n.len+1-zn(n.name,n.len)),t+=we[n.color?"yellow":"black"]`${n.abbr?.slice(0,6)||""}${" ".repeat(7-zn(n.abbr||"",6))}`,t+=n.color?xe(n.info):n.info,t}function zn(e,n){return Math.min(e.replace(/[^\x00-\x7f]/,"11").length,n)}const Vn="";function Yn(e){const{name:n,object:t,item:r,result:s}=e;x(n)||(r.name&&t.options?.push(r),s.push(JSON.parse(JSON.stringify(t))))}function Jn(e,n){"true"==e?e=!0:"false"==e?e=!1:e==Number(e)&&(e=Number(e)),x(n.name)?n.values.push(e):n[n.item.name?"item":"object"].value.push(e)}function Zn(e,n){const t=[];let r="";const s=(e,n)=>R(n)||x(n)?t.push(e):t.push(e,n);function i(e,o){if(!x(r)){if(n.originalBind[r].options[e])return s(e,o);const t=n.abbr[`${r}^${e}`];if(!R(t))return s(t,o)}if(n.originalBind[e])return r=e,s(e,o);if(n.abbr[e])return e=n.abbr[e],r=e,s(e,o);if(e.includes("=")){const n=e.indexOf("=");if(0===n||n===e.length-1)return t.push(e);const[r,s]=[e.slice(0,n),e.slice(n+1)||"true"];return i(r,s)}return R(o)||x(o)?t.push(e):t.push(`${e}=${o}`)}return e.forEach(e=>i(e)),t}function Qn(e,n,t){t.init(),e=Zn(e.filter(e=>""!==e),n),e.forEach(e=>{const{name:r}=t;return e=e.trim(),/^([a-z]|[A-Z]|-|\$|_)/.test(e)?!x(r)&&n.originalBind[r].options&&n.originalBind[r].options[e]?function(e,n){const{item:t,object:r}=n;t.name&&r.options.push(t),n.resetItem(e)}(e,t):n.originalBind[e]?function(e,n){x(n.name)||(Yn(n),n.resetItem("")),n.resetObject(e)}(e,t):Jn(e,t):Jn(e,t)}),Yn(t)}function Xn(e){switch(e.state.code){case 3:return void dn("已经执行过 `run`");case 4:return void dn("已完成全部");default:e.state=3}!function(e){if(2==process.argv.length)return;const n=e.originalArg,t=`${Vn}${n.join(Vn)}${Vn}`,r=n.findIndex(e=>/^(-h|help)$/.test(e));if(new RegExp(`${Vn}(-v|version)${Vn}`,"i").test(t))return void(e.hasShowVersion=!0);if(j(r))return void(e.helpInfo="help");let s=[];const i={result:[],values:[],name:"",object:{name:"",value:[],options:[]},item:{name:"",value:[]},resetObject(e){this.name=e,this.object={name:e,value:[],options:[]}},resetItem(e){this.item={name:e,value:[]}},init(){this.result=[],this.values=[],this.resetItem(""),this.resetObject("")}};r>0?(Qn(n.slice(0,r+1),e,i),e.values=i.values,e.args=i.result,s=e.args,S(s)?e.helpInfo="help":[R,S].some(e=>e(s[0].options))?e.helpInfo=s[0].name:e.helpInfo=[s[0].name,s[0].options[0].name]):(Qn(n,e,i),e.values=i.values,e.args=i.result)}(e),function(e){["name","originBind","abbr"].forEach(n=>{const t=n;e[t]&&(Object.freeze(e[t]),Object.defineProperty(e,n,{value:e[t],writable:!1,enumerable:!0,configurable:!1}))})}(e)}function et(e){e.state="version";const n=Je("package.json","file",rn(e.__filename).name);if(R(n))return nt();const t=Ye(n,"package.json");if(!M(t))return nt();const r=Ze(t);if(T(r))return nt();const{platform:s}=process,i=we.brightCyan(r.name),a=r.version,c="win32"==s?"Windows":"darwin"==s?"mac":s,l=we.brightMagenta(o());dn(`${i} 版本 ${we.brightRed(a)} (${c} ${l})`)}function nt(){dn("抱歉,未找到版本定义说明")}const tt=Se("#333"),rt=Se("#666"),st=Se("#aaa"),it=De("#666"),ot=rt(".".repeat(3)),at=(e="❖")=>Ce(e),ct=(e="▶︎")=>Ae(e),lt=(e="⚉")=>je(e),ut=(e="◦")=>rt(e),pt=(e="●")=>Ce.blink(e),dt=(e="□")=>rt(e),ft=(e="□")=>Ce.blink(e),ht=(e="■")=>rt(e),gt=(e="■")=>Ce.blink(e);function mt(e,n="⚉"){dn(`${lt(n)} ${Se("#612").italic(e)}`)}function bt(e,n="❖"){dn(`${at(n)} ${e}`)}const wt={callList:[],on(e,n){const t=this.callList;S(t)&&(Mn("当前执行列表为空,直接执行任务",e),Reflect.apply(n,void 0,[])),t.push([e,n])},remove(e){const n=this.callList,t=n.findIndex(([n])=>n===e);return n.splice(t,1),S(n)?(Mn("当前执行列表为空,返回 true 结束执行"),!0):(Reflect.apply(n[0][1],null,[]),!1)}},$t={data:"",kind:0,multi:!1,progressCount:0,indexOfCursor:0,init:function(e){this.data=e,this.multi=O(e)}},yt={get kind(){return $t.kind},set kind(e){(!isFinite(e)||0!=e&&1!=e)&&(e=0),$t.kind=e},get multi(){return $t.multi},enterText:[],get progressCount(){return $t.progressCount},set progressCount(e){$t.progressCount=e,e<0&&Reflect.apply(vt,this,[])},get indexOfCursor(){return $t.indexOfCursor},set indexOfCursor(e){$t.indexOfCursor=e},currentIssue:{text:"请更换为你自己的问题",tip:"",type:"text",private:!0,errorText:"",resultText:"",required:!0,defaultValue:"",mustInfo:!1,canCtrlCExit:!1,canCtrlDExit:!1,isWrapLine:!1,usableLength:0,mustInfoLen:0,row:0,cum:0,maxLen:0,minLen:0,len:0,verify:[]},results:[],assign(e){Object.keys(e).forEach(n=>{if(!Object.hasOwn(this,n)||R(e[n]))throw dn(`${n} is not exist`),new Error(`${n} is not exist`);this[n]=e[n]})},beforeStart(){this.results.length=this.enterText.length=this.indexOfCursor=0,this.progressCount=$t.multi?-$t.data.length:-1}};function vt(){const{multi:e,progressCount:n}=this,t=e&&O($t.data)?$t.data[$t.data.length+n]:$t.data,r={text:"请更换为你自己的问题",tip:"",type:"text",private:!0,errorText:"",resultText:"",required:!0,defaultValue:"",mustInfo:!1,canCtrlCExit:!1,canCtrlDExit:!1,isWrapLine:!1,usableLength:0,mustInfoLen:0,row:0,cum:0,maxLen:0,minLen:0,len:0,verify:[]};Object.assign(r,$(t)||E(t)?{text:t}:t);const s=O(r.tip)?1:0;let i;1==s?i=[r.tip[0]]:(i=[],[r.tip,r.defaultValue].every(e=>v(e))&&(r.required=!0),!x(r.defaultValue)&&v(r.tip)&&(r.tip=r.defaultValue)),r.text=x(r.text.toString())?"请使用你自己的问题":r.text,this.assign({indexOfCursor:0,kind:s,enterText:i,currentIssue:r})}const xt=U(()=>{const{kind:e,currentIssue:n,enterText:t}=yt,{mustInfo:r,text:s,required:i,tip:o,verify:a}=n;gn();let c="",l=!1;if(j(n.row)||(c+=`${ee}${n.row}A`,n.row=0),c+=`\r${ee}0J${te}`,r)c=Et(c),l=!0;else if(!S(t)){const e=t.join("");for(const t of a)if(y(t.reg)&&$(t.info)&&[R,C].some(e=>e(t.inverse))){t.reg.lastIndex=0;const r=t.reg.test(e);if(A(t.inverse)&&A(r)||A(!t.inverse)&&I(r)){n.mustInfo=t.warn?Ae(t.info):t.info,c=Et(c),l=!0;break}}}const u=0===e&&i?je.blink("*"):"";c+=`${ct()} ${u}${s}${u}: `,n.row+=Number(n.isWrapLine),c+="\n".repeat(Number(n.isWrapLine)),j(e)?S(t)&&$(o)?v(o)?c+=Re.dim.blink("I"):c+=" ".concat(it.italic.dim(o[0])).concat(Re.dim(o.slice(1))):(c+=" ",c=function(e){const{type:n,usableLength:t}=yt.currentIssue;e="text"===n?function(e,n){const{enterText:t,indexOfCursor:r}=yt,s=Fe(t.join(""))>n;r===t.length?(s?e=function(e,n){const{enterText:t}=yt;return e+=ot.concat([...Le(t.toReversed().join(""),n-3,!1)].reverse().join("")),e}(e,n):e+=t.join(""),e+=it.hide(" ")):s?e=function(e,n){const{indexOfCursor:t,enterText:r}=yt,s=r.join(""),i=r.length,o=Math.floor(n/2),a=Le(s,o),c=a.length-1,l=a[c]===s[c]?c:c-1,u=Le(s,-o),p=u.length-1,d=u[p]===s[i-1-p]?i-1-p:i-p,f=r.map((e,n)=>n===t?it(e):e).join("");if(t>=d)e+=ot,e+=Le(f,3-n,!1);else if(t<l)e+=Le(f,n-3,!1),e+=ot;else{const n=o-Fe(r[t])-3;e+=ot,e+=Le(s.slice(0,t),-n,!1),e+=it(r[t]),e+=Le(s.slice(t+1),n,!1),e+=ot}return e}(e,n):e+=`${t.map((e,n)=>n===r?it(e):e).join("")}`;return e}(e,t):function(e){const{enterText:n,indexOfCursor:t}=yt;t===n.length?(e+=` ${n.map(()=>"*").join("")}`,e+=it.hide("1")):e+=` ${n.map((e,n)=>n===t?it("*"):"*").join("")}`;return e}(e);return e}(c)):c=function(e){const{currentIssue:n,enterText:t}=yt;return e+n.tip.map(e=>e===t[0]?_e.bold.blink.cyan(e):xe(e)).join(" ")}(c),Mn("计算完成的文本为",c),dn(Ge(c)),n.row++,function(e){const{currentIssue:n,indexOfCursor:t,enterText:r}=yt,{text:s,required:i,mustInfoLen:o}=n;if(e)return yn(o);const a=r.slice(0,t).join(""),c=s.toString().concat(a),l=Fe(c),u=l+7+2*Number(i),p=u%process.stdout.columns;Mn("用户输入",r.join("")),Mn("光标所在的位置",t),Mn("实际参与计算的用户输入的文本为",a),Mn("计算总文本",c),Mn("计算文本长度",l),Mn("计算可用长度",u),Mn("屏幕宽",process.stdout.columns),Mn("光标偏移量",u%process.stdout.columns),yn(p)}(l),l||dn(Oe("I"),!1),hn("8m")},66);function Et(e){const{currentIssue:n}=yt;e+="\n\r",n.row++;let t="";if(C(n.mustInfo)){const e=n.required?" ":"";t+=" ".repeat(2).concat(e).concat($e(n.text)).concat(e).concat(" ".repeat(3)),t+=$e.blink`👆`}else t+=xe(n.mustInfo);let r=Fe(t);const s=process.stderr.columns-4;return s<r&&(r=s,t=Le(t,s)),n.mustInfoLen=r,e+=t,e+=`\r${ee}1A`,n.row--,n.mustInfo=!1,e}function kt(){const{currentIssue:e}=yt;!function(){const{currentIssue:e}=yt,n=process.stdout.columns;let t=n-Fe(e.text.toString())-2*Number(e.required)-4-7;const r=t<5;r&&(t=n-4);e.isWrapLine=r,e.usableLength=t}();const{isWrapLine:n}=e,t=2+Number(n);dn("\n".repeat(t),!1),e.row+=t,wn(t),e.row-=t}async function jt(){try{await pn((e=this,(n,t)=>{const{kind:r,currentIssue:s,enterText:i,results:o}=e,{tip:a,text:c,canCtrlCExit:l,canCtrlDExit:u}=s;let p=[],d=0,f=0,h=!0;switch(j(r)||(p=a,d=p.length-1,f=p.indexOf(i[0])),Mn("\n 用户使用了",n,t),t.name){case"return":if(function(){const{enterText:e,currentIssue:n,results:t}=yt,r=n.text;let s=e.join("").trim();if(v(s)&&n.required)return n.mustInfo=!0,!1;const{len:i,minLen:o,maxLen:a,verify:c}=n,l=s.length;if(j(yt.kind)){if(c.length>0)for(const e of c)if([R,I].some(n=>n(e.warn))&&y(e.reg)&&$(e.info)&&[R,C].some(n=>n(e.inverse))){e.reg.lastIndex=0;const n=e.reg.test(s);if(A(e.inverse)&&n||!e.inverse&&!n)return!1}if(!j(i)&&l!==i)return n.mustInfo=`您输入的长度 ${ye(l)} 不符合要求值 ${Ee(i)}`,!1;if(!j(o)&&l<o)return n.mustInfo=`您输入的长度 ${ye(l)} 小于最低要求${Ee(o)}`,!1;if(a>o&&l>a)return n.mustInfo=`您输入的长度 ${ye(l)} 大于最低要求${Ee(a)}`,!1}return v(s)&&I(n.required)&&(s=n.defaultValue||n.tip||""),t.push({q:r,r:s}),!0}())return h=!1,!0;break;case"left":!function(e,n,t){const{kind:r,enterText:s}=yt;j(r)?yt.indexOfCursor=0===yt.indexOfCursor?s.length:yt.indexOfCursor-1:s[0]=e[0===n?t:n-1]}(p,f,d);break;case"right":!function(e,n,t){const{kind:r,enterText:s}=yt;j(r)?yt.indexOfCursor=yt.indexOfCursor==yt.enterText.length?0:yt.indexOfCursor+1:s[0]=e[n==t?0:n+1]}(p,f,d);break;case"delete":case"backspace":!function(){const{enterText:e,kind:n}=yt;j(n)&&!j(yt.indexOfCursor)&&(e.splice(yt.indexOfCursor-1,1),yt.indexOfCursor--)}();break;case"escape":if(t?.sequence===X.repeat(2))return o.push({q:c,r:void 0}),h=!1,!0;break;default:if(Mn("当前触发为含 ctrl 键的功能键",n,t),I(t?.ctrl))!function(e){const{enterText:n,kind:t}=yt;R(e)||0!==t||(yt.indexOfCursor==n.length?n.push(e):n.splice(yt.indexOfCursor,0,e),yt.indexOfCursor+=1)}(n);else if(h=!1,hn("m"),A(l)&&"c"===t?.name||A(u)&&"d"===t?.name)return o.push({q:c,r:void 0}),!0}return h&&xt(),!1}))}catch(e){Mn.error("接收用户输入出错",e),dn(e)}var e}function Ct(e,n){const t=Symbol("question");try{return new Promise((r,s)=>{wt.on(t,async()=>{try{const s=await async function(e,n){process.stdout.removeListener("resize",At),process.stdout.on("resize",At),Mn("初始化问题"),$t.init(e),Mn("初始化当前问题"),yt.beforeStart(),Mn("开始绘制问题");do{kt(),xt();try{await Reflect.apply(jt,yt,[])}catch(e){Mn.error(e)}const{currentIssue:e,results:n}=yt;j(e.row)||(wn(e.row,!0),e.row=0),hn("m"),mn(),bn(!0);const t=e.resultText||e.text,r=n[n.length-1].r;e.private||(R(r)?mt(e.errorText||t):bt(`${rt(t)}: ${"text"===e.type?r:r.replace(/./gm,"*")}`)),++yt.progressCount}while(yt.progressCount<0);return process.stdout.removeListener("resize",At),hn("m"),mn(),bn(!0),yt.multi?A(n)&&O(e)?yt.results.map(e=>e.r):yt.results:yt.results[0].r}(e,n);wt.remove(t),r(s)}catch(e){Mn.error("\n\n\n\n\n执行出现错误",e),wt.remove(t),s(e)}})})}catch(e){return Mn.error("系统故障",e),dn("系统故障",!1),dn(e),new Promise((n,t)=>{t(e)})}}const At=U(()=>{const{currentIssue:e}=yt;j(e.row)||(wn(e.row,!0),e.row=0),dn(te,!1),bn(!0),kt(),xt()}),It=async function(e,n){return Ct(e,n)};function Tt(e=!0){return process.stdout.rows-4*(1+Number(e))}function Rt(e){const n=[];for(let t=0,r=e.length;t<r;t++){const r=e[t];if(F(r,e=>[$,E].some(n=>n(e))))n.push({value:r,label:r,checked:!1,tip:"",disable:!1});else{if(!F(r,e=>[$,$].some(n=>n(e.label))&&[$,E,P].some(n=>n(e.value))))throw new TypeError(`${r} 的类型非法(有可能是返回值类型更改后未在解析中兼容)`);{let e=r.checked;!R(e)&&C(e)||(e=!1);let t=r.tip;!R(t)&&$(t)||(t="");const s=r.value;if(R(s)||T(s))throw new TypeError("value 值类型非法");const i=r.label,o=A(r.disable);n.push({checked:e,tip:t,value:s,label:i,disable:o})}}}return n}const _t="请使用键盘选择,请使用 Enter 键进行选择",Ot=!1,St="radio",Nt={drawData:[],info:_t,focus:0,renderInfo:{rows:0,renderRows:0,otherInfoRows:0,allowBelow:!1,size:{width:0,height:0}},resultText:"",errorText:"",private:Ot,required:Ot,kind:St,canCtrlCExit:Ot,canCtrlDExit:Ot,mustInfo:Ot,maxRows:Tt(),data:[],initData(e){Mn("初始化数据"),this.reset(),O(e)?this.data=Rt(e):Object.keys(e).forEach(n=>{const t=e[n];switch(n){case"data":this.data=O(t)?Rt(t):[];break;case"info":this.info=$(t)?t:_t;break;case"resultText":this.resultText=$(t)?t:this.info||"";break;case"errorText":this.errorText=$(t)?t:this.resultText||this.info||"";break;case"private":this.private=C(t)?t:Ot;break;case"required":this.required=C(t)?t:Ot;break;case"kind":this.kind="check"===t?"check":St;break;case"canCtrlCExit":this.canCtrlCExit=C(t)?t:Ot;break;case"canCtrlDExit":this.canCtrlDExit=C(t)?t:Ot;break;case"maxRows":this.maxRows=isFinite(t)&&Number.isInteger(t)&&t>0?t+4:Tt()}});const n=this.data;for(const e in n){if(!n[e].disable)return this.focus=Number(e),!1}return!0},reset(){this.drawData.length=this.data.length=this.focus=0,this.maxRows=Tt(),this.renderInfo={rows:0,renderRows:0,otherInfoRows:0,allowBelow:!1,size:{width:0,height:0}},this.info=_t,this.kind=St,this.resultText=this.errorText="",this.private=!0,this.required=this.canCtrlCExit=this.canCtrlDExit=this.mustInfo=Ot}};function Dt(e){const{data:n}=Nt,t=process.stdout.columns-7,r=t-3,s=n[e].label.toString();return Fe(s)<=t?s:Le(s,r,!1).concat(ot)}const Pt=()=>{!function(){const{focus:e,drawData:n,data:t,kind:r}=Nt;for(let s=0,i=t.length;s<i;s++){const i=t[s];if(R(n[s])){const t=Fe(i.label.toString());n[s]={index:s,text:Dt(s),length:t,checked:"radio"!==r&&i.checked,focus:s===e,changed:!0,show:!0,disable:i.disable}}else s===e?(n[s].changed=!0,n[s].focus=!0):s!==e&&A(n[s].focus)&&(n[s].changed=!0,n[s].focus=!1)}}(),function(){const{drawData:e,renderInfo:n,focus:t}=Nt,{renderRows:r}=n,s=e.length;if(s===r)return void e.forEach(e=>e.show=!0);const i=s-1,o=Math.floor((r-1)/2);let a=1&r?t-o:t-o-1;a=a<0?0:a;let c=r+a-1;c>i&&(c=i,a=c-r+1);e.forEach(e=>{const{index:n}=e;n>c||n<a?e.show=!1:n===c&&n!==i||n===a&&0!==n?(e.show=!0,e.text=ot):e.text===ot?(e.show=!0,e.text=Dt(n)):e.show=!0})}();const{info:e,mustInfo:n,renderInfo:t,focus:r,data:s}=Nt,{rows:i,allowBelow:o,size:a}=t,{width:c}=a;let l=`${ee}${c}D`;l+="\n".repeat(i),l+=`${ee}${i}A`,l+=`${ee}J`,l+=Ge(`${ct()} ${e} \n\n`),l+=function(){const{drawData:e,kind:n}=Nt;let t="";for(let r=0,s=e.length;r<s;r++){const s=e[r];s.show&&(s.focus?(t+=Ge(` ${"radio"===n?pt():s.checked?gt():ft()} ${s.text}`),t+="\n"):s.text===ot?(t+=` ${ot}`,t+="\n"):s.disable?(t+=Ge(` ${"radio"===n?st`⊗`:s.checked?st`▣`:st`☒`} ${st(s.text)}`),t+="\n"):(t+=Ge(` ${"radio"===n?ut():s.checked?ht():dt()} ${tt(s.text||"")}`),t+="\n"))}return t}(),l+=`${ee}J`,o&&(n?l+=function(){const e=process.stdout.columns-7;Nt.mustInfo=!1;const n="抱歉,该项至少选择一项!!!请使用空格键或是左右键切换选择状态",t=Fe(n)<e?n:Le(n,e);return"\n".concat($e(t))}():s[r].tip?(l+="\n",l+=Ge(`${Ee(s[r].tip)}`)):l+="\n",l+="\n"),Ln&&(l+=`${ee}${c}D${ee}${i}A`),dn(l,!1)},Ft=U(Pt,66),Mt=U(Pt,600);function Lt(){const{data:e,renderInfo:n,maxRows:t}=Nt,[r,s]=[process.stdout.columns,process.stdout.rows],i=e.length;n.size={width:r,height:s};const o=n.rows=Math.max(Math.min(i+4,Tt(!1),t),5),a=n.allowBelow=Tt()>e.length||o>6,c=n.otherInfoRows=a?4:2;n.renderRows=o-c}async function Gt(){const{data:e,required:n,kind:t,drawData:r,canCtrlCExit:s,canCtrlDExit:i}=Nt,o={exit:!1};return await pn((a,c)=>{const{focus:l}=Nt;switch(c.name){case"return":return Mn("用户已选择,返回真值告诉等待程序可终结当前输入"),"check"!==t||!n||!S(r.filter(e=>e.checked))||(Nt.mustInfo=!0,Ft(),!1);case"up":Mn("用户使用了键盘键的 up 键"),Ht(!1),Ft();break;case"down":Mn("用户使用了键盘键的 down 键"),Ht(),Ft();break;case"right":Mn("用户使用了键盘键的右键");case"left":Mn("用户使用了键盘键的左键");case"space":Mn("用户使用了键盘键的空格键"),"check"===t&&(e[l].checked=r[l].checked=!r[l].checked,Ft());break;case"escape":if(c?.sequence===X.repeat(2))return o.exit=!0,!0;break;default:if(Mn("用户使用了键盘键的非方向键 <",a,">, <",c,">"),A(c?.ctrl)&&("check"===Nt.kind&&("a"===c?.name&&(Bt(),Ft()),"z"===c?.name&&(Bt(!1),Ft()),"r"===c?.name&&(Nt.data.forEach(e=>{e.disable||(e.checked=!e.checked)}),Nt.drawData.forEach(e=>{e.disable||(e.checked=!e.checked)}),Ft())),A(s)&&"c"===c?.name||A(i)&&"d"===c?.name))return o.exit=!0,!0}return!1}),o.exit}function Bt(e=!0){Nt.data.forEach(n=>{n.disable||(n.checked=e)}),Nt.drawData.forEach(n=>{n.disable||(n.checked=e)})}function Ht(e=!0){const{focus:n,drawData:t}=Nt,r=t.length-1,s=e?n===r?t:[...t.slice(n+1),...t.slice(0,n+1)]:0===n?t.toReversed():[...t.slice(n),...t.slice(0,n)].toReversed();for(const e of s)if(!e.disable)return void(Nt.focus=e.index)}async function Ut(e,n){if(process.stdout.removeListener("resize",Kt),process.stdout.on("resize",Kt),Nt.initData(e))return;gn(),Mn("初始绘制问题选项"),Lt(),Ft(),Mn("绘制完成,等待用户操作");const t=await Gt();dn(te,!1),process.stdout.removeListener("resize",Kt);const{resultText:r,info:s,focus:i,kind:o,drawData:a,errorText:c}=Nt;if(mn(),bn(!0),t)return void(Nt.private||mt(c||r||s));const l=a.filter(e=>e.checked);if(!Nt.private){const e="radio"===o?[a[i].text]:l.map(e=>e.text);bt(`${rt.italic.dim(r||s)}: ${rt(e.join("、"))}`)}const u="radio"===o?Nt.data[i].value:l.map(e=>Nt.data[e.index].value),p="radio"===o?i:l.map(e=>e.index);return"string"==n||R(n)?u:p}const Kt=U(()=>{const{drawData:e,renderInfo:n}=Nt,t=n.size.height;e.length=0,dn(te,!1),bn(),Lt(),process.stdout.rows!==t?Mt():Ft()},33);function Wt(e,n){return async function(e,n){const t=Symbol("selection");return new Promise((r,s)=>{wt.on(t,async()=>{try{const s=await Ut(e,n);wt.remove(t),r(s)}catch(e){Mn.error(e),wt.remove(t),s()}})})}(e,n)}const qt=new class{#c;#l;constructor(e=""){if($(e)||(e=`${e}`),this.#c=Symbol(e),Fn[this.#c])throw new Error(`${e} 已经存在,请更换初始化命令名称,若仍想在原命令上操作,请抽离为单独的文件做数据共享`);this.#l=Fn[this.#c]=Hn(),[this.#l.__filename]=sn(),this.#l.name=e||$(process.argv[1])&&process.argv.slice(1,2)[0].replace(/.*\/.*?$/,"$1")||"",Object.defineProperty(this,"#uniKey",{value:this.#c,writable:!1,enumerable:!1,configurable:!1})}get name(){return this.#l.name}get state(){return this.#l.state}isEnd(e=!1){const n=4===this.#l.state.code;return n&&A(e)&&this.end(),n}end(){return this.#l.state="end",process.exit()}error(){return this.#l.state="error",process.exit(1)}bind(e){return Bn(e,this.#l),this}run(){const e=this.#l;return Xn(e),x(e.helpInfo)||Kn(e),e.hasShowVersion&&et(e),this}get args(){return this.#l.args}get values(){return this.#l.values.slice()}help(e,n){const t=this.#l;$(e)&&t.originalBind[e]?$(n)&&t.originalBind[e].options&&t.originalBind[e].options[n]?t.helpInfo=[e,n]:t.helpInfo=e:t.helpInfo="help",Kn(this.#l)}version(){et(this.#l)}}("create a npm");qt.bind(["manager <-m> (包管理器)"]),qt.run().isEnd(!0);const zt=new ze({name:"create a npm",type:!1}),Vt=!!zt.type,Yt={manager:{value:"",accept:["npm","yarn","pnpm"]}},Jt=["husky","action","rollup","typescript","eslint","prettier"],[Zt]=sn();let Qt=Je("package.json","file",Zt);zt("获取到的地址为",Qt),R(Qt)&&(Qt=process.cwd());const Xt=Ze(Ye(Qt,"package.json"));zt("获取到的数据为:",Xt);const er={cwd:"",range:"",pkgFile(...e){return Ye(this.cwd,...e)},rangeFile(...e){return Ye(this.range,...e)},get name(){return this.package.name},set name(e){this.childPkg?this.carryRange?(this.range=e.replace(/^@(.*)\/.*$/g,"$1"),this.cwd=e.replace(/@/,"").replace(/\//,"/packages/")):this.cwd=e.replace(/^.*\/(.*)$/g,"$1"):this.cwd=e,this.package.name=e},bin:0,local:{author:{name:"",email:"",url:""},dependencies:Jt},package:{name:"",version:"0.0.0",description:"",author:{name:"",email:"",url:""},dependencies:Xt?.dependencies||{},devDependencies:Xt?.devDependencies||{}},install:!1,carryRange:!1,childPkg:!1,buildDevDependencies(){const{dependencies:e}=this.local,{devDependencies:n}=this.package;zt("获取的本地的包信息",e),zt("获取本地的");const t={},r=function(e){Object.keys(e).forEach(t=>this[t]=n[t]||e[t])}.bind(t);return r({"@eslint/js":"^9.39.2","@qqi/check-version":"^1.1.0","@qqi/rollup-external":"^1.1.0","@rollup/plugin-commonjs":"^29.0.0","@rollup/plugin-json":"^6.1.0","@rollup/plugin-node-resolve":"^16.0.3","@rollup/plugin-terser":"^0.4.4","@rollup/plugin-typescript":"^12.3.0",gvv:"^1.0.0",jja:"^2.4.0",pjj:"^1.0.5",rollup:"^4.55.1","rollup-plugin-cleanup":"^3.2.1","rollup-plugin-copy":"^3.5.0",vjj:"^1.0.12","@color-pen/static":"^1.1.1","@qqi/log":"^1.0.0","a-command":"^3.0.1","a-js-tools":"^2.0.1","a-node-tools":"^4.4.2","a-type-of-js":"^2.0.0","color-pen":"^3.0.0","colored-table":"^0.2.0",qqi:"^1.0.0"}),e.includes("husky")&&e.includes("prettier")&&r({husky:"^9.1.7","lint-staged":"^16.2.7"}),e.includes("eslint")&&(r({eslint:"^9.39.2","eslint-config-prettier":"^10.1.8","eslint-plugin-jsdoc":"^62.0.0",globals:"^17.0.0","@eslint/js":"^9.39.2","eslint-plugin-import":"^2.32.0","eslint-plugin-jsonc":"^2.21.0","eslint-plugin-unused-imports":"^4.3.0","eslint-import-resolver-typescript":"^4.4.4"}),e.includes("typescript")&&r({"typescript-eslint":"^8.53.0"}),e.includes("prettier")&&r({"eslint-config-prettier":"^10.1.8"})),e.includes("prettier")&&r({prettier:"^3.8.0"}),e.includes("typescript")&&r({"@types/node":"^25.0.9","@rollup/plugin-node-resolve":"^16.0.3",typescript:"^5.9.3"}),delete t.merge,Vt&&(zt("构建的依赖图",t),zt(`构建依赖图(${Object.keys(t).length})和原版本的 ${Object.keys(n).length}`),zt("俩者的差集",q.symmetricDifference(Object.keys(n),Object.keys(t)))),t},commandParameters:Yt},nr=Tn({show:!1});function tr(e,n){Xe(er.pkgFile(e),n)}async function rr(e="好的,正在做退出前最后的工作,请稍等"){return await async function(e,n=10){if(!$(e))throw new TypeError("str 需是一个字符串");if(!isFinite(n)||n<0||n>1e4)throw new RangeError("delay 需是一个 0 到 10000 之间(不包括两端)的数值");const t=Array.from(e);if(0!==t.length){for(const r of t)await z(n),Ve(`当前字符 ${Te(r)} 长度为:`,r.length),Ve(`当前字符 ${we.reversed(r)} 在 charCodeAt`,r.charCodeAt(0),r.charCodeAt(1),r.charCodeAt(2)),1===r.length&&k(r.charCodeAt(1))?dn(r,!1):2===e.length&&e.charCodeAt(0)>=55296&&e.charCodeAt(0)<=56319&&e.charCodeAt(1)>=56320&&e.charCodeAt(1)<=57343?(dn(r,!1),dn(" ",!1)):2===e.length&&65039===e.charCodeAt(1)?(dn(r,!1),dn(" ",!1)):(dn(r,!1),dn(" ",!1));dn()}else dn()}(e),nr.destroyed(),bn(),mn(),fn("终结线",!0),qt.end()}function sr(){const{manager:e}=Yt;return"pnpm"===e.value?"pnpm install --frozen-lockfile --prod=false":e.value+" ci"}async function ir(e){er.childPkg=er.carryRange=!1,e.startsWith("@")&&(er.childPkg=!0,await async function(e){const n=await Wt({info:"检测到当前文件包含域",data:[{value:0,label:"子包模式",tip:`默认您是在 ${ye(e.replace(/^@(.*)\/.*$/,"$1").concat("/packages"))} 目录下`},{value:1,label:"嵌套模式",tip:`默认为您创建 ${ye(e.replace(/@/,"").replace(/\//,"/packages/"))} 路径`}]});if(R(n))return await rr();er.carryRange=Boolean(n)}(e));const n=e.startsWith("@")?er.carryRange?e.replace(/@/,"").replace(/\//,"/packages/"):e.replace(/^.*\/(.*)$/,"$1"):e;zt("获取当前的目录",n);const t=Qe(n);if(0==t){const n=["更换为其他名称","直接退出"],t=await It({text:`当前目录下存在非空同名文件夹(${je(e)})`,tip:n});return!(!R(t)&&t!==n[1])&&await rr()}nr.run({info:"正在检测 npm 是否有该同名包"});const r=Vt&&await Sn(e)||{data:void 0};if(nr.destroyed(),zt("获取线上的 npm 包数据",r),r.data){const n=["更改为其他名称","忽视并继续","直接退出"],t=await It({text:Se("#f63")`当前包名称(${xe(e)})已经存在于 npm 中`,tip:n});if(R(t)||t===n[2])return await rr();if(t===n[0])return!1}return er.name=e,-1===t&&s(n,{recursive:!0}),!0}async function or(e=!0){let n=e&&qt.args.$original[0]||"";if(zt("当前获取的输入名称",n),x(n)&&(n=await async function(){const e=await It({text:"您即将创建的包名",tip:"请使用空格/连字符(-)做分隔符",minLen:1,maxLen:212,verify:[{reg:/^[a-z@]/,info:"首字符应为小写英文字符或 @"},{reg:/[A-Z]/,info:"不应当有大些英文字符",inverse:!0},{reg:/^[^@].*\/.*/,info:`仅当为范围时才可以包含 ${xe`/`} 符号`,inverse:!0},{reg:/.*\/.*\/.*/,info:`仅只能包含一个 ${xe`/`} 符号`,inverse:!0},{reg:/^[@a-z].*@.*$/,info:`${xe`@`} 仅允许在首位出现`,inverse:!0},{reg:/^[a-z0-9@/\-_.]+$/,info:`仅允许 ${xe`-`}、${xe`_`} 字符出现`}]});return R(e)?await rr("您选择退出,清稍等"):e}()),n=n.trim().replace(/\s+/gm,"-"),x(n)||/^[^a-z@]/.test(n)||/^[a-z0-9][a-z0-9.\-_]*\/[a-z0-9.\-_]*$/.test(n)||n.length>212||/[A-Z]/gm.test(n)||/\s/.test(n)||/.*\/.*\/.*/.test(n)||/^[@a-z].*@.*$/gm.test(n)||/^[^a-z0-9@/\-_.]+$/gm.test(n))return await async function(){const e=["重新输入","退出"],n=await It({text:Se("#f63")("您的输入为字符非法")+"重新输入或退出",tip:e});if(R(n)||n===e[1])return await rr()}(),await z(100),await or(!1);return I(await ir(n))?await or(!1):void 0}async function ar(){const{manager:e}=Yt,n=function(e=!1){if(I(e)){const e=e=>Boolean(Je(e,"file"));if(e("pnpm-lock.yaml"))return"pnpm";if(e("yarn.lock"))return"yarn";if(e("package-lock.json"))return"npm"}const n=process.env.npm_config_user_agent||"";return n.includes("pnpm")?"pnpm":n.includes("yarn")?"yarn":n.includes("npm")?"npm":process.env.PNPM_HOME?"pnpm":process.env.YARN_IGNORE_PATH?"yarn":"npm"}(),t=(()=>{const t=[...e.accept];if(t[0]===n)return t;for(let e=0,r=t.length;e<r;e++)if(t[e]===n){[t[0],t[e]]=[t[e],t[0]];break}return t})(),r=await Wt({info:"请选择您使用的包管理器",data:t});e.value=r??"npm"}function cr(){const{dependencies:e}=er.local,n="++++",t=e.includes("prettier"),r=e.includes("typescript");return`// eslint.config.mjs(ESM 格式)\nimport globals from 'globals'; // 全局变量(非插件,必备)\nimport js from '@eslint/js'; // 必须:核心推荐规则\n${r?"import tseslint from 'typescript-eslint'; // 必须:TypeScript 支持":n}\nimport importPlugin from 'eslint-plugin-import'; // 必须:导入导出规范\n${t?"import prettierConfig from 'eslint-config-prettier'; // 必须:关闭 Prettier 冲突规则":n}\n\n// 可选插件(按需启用)\nimport jsdocPlugin from 'eslint-plugin-jsdoc'; // 可选:JSDoc 注释\nimport unusedImportsPlugin from 'eslint-plugin-unused-imports'; // 可选:删除未使用导入\n\n${r?"import { dirname, resolve } from 'node:path';\nimport { fileURLToPath } from 'node:url';\n \nconst __dirname = dirname(fileURLToPath(import.meta.url));\nconst tsconfigPath = resolve(__dirname, 'tsconfig.types.json');":n}\n\nconst ignorePattern = [\n 'node_modules/',\n 'dist/',\n 'build/',\n 'coverage/',\n 'lib/',\n 'es/',\n '**/test/**', // 匹配任何目录下的 test 目录\n '**/*.test.ts', // 匹配任何目标下的 .test.ts 文件\n '**/*.spec.ts', // 匹配 .spec.ts 文件\n '**/*.min.js',\n 'pnpm-lock.yaml',\n 'package-lock.json',\n 'yarn.lock',\n '.docusaurus',\n '.wrangler',\n];\n\nexport default [\n // 0. 忽略文件配置\n {\n ignores: ignorePattern, // 优先配置忽略规则,提升性能\n },\n // 1. 基础配置(所有文件通用)\n js.configs.recommended, // 必须:ESLint 核心推荐规则\n {\n languageOptions: {\n globals: {\n ...globals.browser, // 浏览器全局变量\n ...globals.node, // Node.js 全局变量\n },\n },\n },\n\n ${r?"// 2. TypeScript 配置(必须)\n ...tseslint.configs.recommended.map(config => ({\n ...config,\n files: ['src/**/*.{ts,tsx}'], // 按需配置\n // ignores: ignorePattern,\n languageOptions: {\n ...config.languageOptions,\n globals: {\n ...globals.browser,\n ...globals.node,\n ...globals.es2025, // 浏览器 + Node + ES2025 全局\n },\n // parser: tseslint.parser, // 显式指定 TS 解析器,解决接口不匹配\n parserOptions: {\n ...config.languageOptions?.parserOptions,\n tsconfigRootDir: __dirname, // ESM 获取当前配置目录\n project: [tsconfigPath], // 类型感知规则,或者指定实际的 tsconfig.json\n ecmaVersion: 'latest',\n sourceType: 'module',\n // ecmaFeatures: { jsx: true }, // 开启JSX解析,适配React\n },\n },\n plugins: {\n ...config?.plugins,\n // 需要搭配安装 eslint-import-resolver-typescript\n import: importPlugin,\n 'unused-imports': unusedImportsPlugin, // 内置未使用导入插件\n },\n settings: {\n 'import/parsers': {\n '@typescript-eslint/parser': ['.ts', '.tsx'],\n },\n 'import/resolver': {\n typescript: {\n project: tsconfigPath,\n alwaysTryTypes: true,\n },\n node: true, // 兜底 node 解析器,兼容 commonjs/esm 混合模块\n },\n },\n rules: {\n // 原生规则对 TS 语法支持极差,必须关闭\n 'no-unused-vars': 'off',\n '@typescript-eslint/no-unused-vars': [\n 'warn',\n {\n vars: 'all',\n args: 'after-used',\n argsIgnorePattern: '^_',\n varsIgnorePattern: '^_',\n },\n ],\n 'import/order': [\n 'error',\n {\n groups: [\n 'builtin',\n 'external',\n 'internal',\n 'parent',\n 'sibling',\n 'index',\n ],\n alphabetize: {\n order: 'asc',\n caseInsensitive: true,\n },\n },\n ],\n 'import/no-duplicates': 'error',\n 'import/no-cycle': 'warn',\n // 未使用的导入规则, error 强制级别删除,联动 ts-eslint 规则\n 'unused-imports/no-unused-imports': 'error',\n 'unused-imports/no-unused-vars': 'off', // 与 '@typescript-eslint/no-unused-vars' 冲突\n },\n })),":"// 2. import 插件配置\n {\n plugins: {\n import: pluginImport,\n },\n rules: {\n ...pluginImport.configs.recommended.rules,\n 'import/no-unresolved': 'error',\n 'import/order': [\n 'error',\n {\n groups: ['builtin', 'external', 'parent', 'sibling', 'index'],\n pathGroups: [\n {\n pattern: '{react,react-dom/**}',\n group: 'external',\n position: 'before',\n },\n ],\n pathGroupsExcludedImportTypes: ['react'],\n 'newlines-between': 'always',\n alphabetize: { order: 'asc', caseInsensitive: true },\n },\n ],\n },\n },"}\n\n // 3. 可选:JSDoc 注释规范 \n {\n files: ['**/*.{js,ts,jsx,tsx}'],\n plugins: {\n jsdoc: jsdocPlugin,\n },\n rules: {\n // 基础规则\n 'jsdoc/check-alignment': 'error',\n 'jsdoc/check-param-names': 'error',\n 'jsdoc/check-tag-names': [\n 'error',\n {\n // 配置允许的标签\n definedTags: ['packageDocumentation', 'lastModified'],\n },\n ],\n 'jsdoc/check-types': 'error',\n\n ${r?"\n // TypeScript 适配规则\n 'jsdoc/no-types': 'error',\n 'jsdoc/require-param-type': 'off', // 使用 TS 类型\n 'jsdoc/require-returns-type': 'off', // 使用 TS 类型":n}\n\n // 文档质量规则\n 'jsdoc/require-description': [\n 'error',\n {\n contexts: ['TSInterfaceDeclaration', 'TSTypeAliasDeclaration'],\n },\n ],\n 'jsdoc/require-jsdoc': [\n 'warn',\n {\n require: {\n FunctionDeclaration: true,\n MethodDefinition: true,\n ClassDeclaration: true,\n },\n },\n ],\n },\n },\n\n${r?n:" // 4. 未使用导入插件\n {\n plugins: {\n 'unused-imports': pluginUnusedImports,\n },\n rules: {\n 'unused-imports/no-unused-imports': 'error',\n 'unused-imports/no-unused-vars': [\n 'warn',\n { vars: 'all', varsIgnorePattern: '^_', args: 'after-used', argsIgnorePattern: '^_' },\n ],\n },\n },"}\n\n ${t?` // ${r?4:5}. 关闭 Prettier 冲突规则(必须,用 Prettier 时)\n eslintConfigPrettier,`:n}\n // ${r?5:6} 文件特定覆盖\n {\n files: ['**/*.test.js', '**/*.spec.js'],\n languageOptions: {\n globals: {\n ...globals.mocha,\n ...globals.jest,\n },\n },\n },\n];\n`.replace(/\+{3,}\n?/gm,"")}const lr=()=>{const e=(new Date).getFullYear(),{name:n}=er.local.author;return`# MIT License\n \nCopyright ©️ <${e}> <${n}>\n\nPermission to use, copy, modify, and/or distribute this software for any \npurpose with or without fee is hereby granted, provided that the above \ncopyright notice and this permission notice appear in all copies.\n\nTHE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES \nWITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF \nMERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR \nANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES \nWHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN \nACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF \nOR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n\n# MIT 许可证\n\n版权所有 ©️ [${e}] [${n}]\n\n特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:\n\n上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。\n\n软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。`};function ur(){return JSON.stringify({printWidth:80,tabWidth:2,useTabs:!1,semi:!0,singleQuote:!0,trailingComma:"all",bracketSpacing:!0,arrowParens:"avoid",endOfLine:"auto"},null,2)}function pr(){s(er.rangeFile("scripts"),{recursive:!0}),r(er.rangeFile("scripts/check_version_install.sh"),'#!/bin/bash\n\ninstall_check_version() {\n # 在子项目的直接\n if ! npm list -g --depth=0 | grep -q " ${CHECK_VERSION}"; then \n echo "当前未全局安装 \'${CHECK_VERSION}\',即将进行安装"\n npm install ${CHECK_VERSION} --global\n else \n echo "包 ${CHECK_VERSION} 已全局安装"\n fi\n}'),r(er.rangeFile("scripts/detect_changes.sh"),'#!/bin/bash\n\n# 获取上一次提交的 SHA\nPREVIOUS_COMMIT=$(git rev-parse HEAD^)\nCURRENT_COMMIT=$(git rev-parse HEAD)\n\n# 获取变更的文件列表\nCHANGED_FILES=$(git diff --name-only $PREVIOUS_COMMIT $CURRENT_COMMIT)\n\n# 初始化变更的包数组\nCHANGED_PACKAGE_ARRAY=()\n\necho "开始循环调用验证函数"\n\nmain() {\n # 遍历变更的文件,找出变更的 packages 下的直接子文件夹\n for file in $CHANGED_FILES; do\n if [[ $file == packages/* ]]; then\n PACKAGE_DIR=$(echo $file | cut -d\'/\' -f2)\n # 如果其不存在于数组之中\n if [[ ! " ${CHANGED_PACKAGE_ARRAY[@]} " =~ " ${PACKAGE_DIR} " ]]; then\n CHANGED_PACKAGE_ARRAY+=("$PACKAGE_DIR") # 文件变更数组添加元素\n fi\n fi\n done\n \n # 将数组转为逗号分隔的字符串\n CHANGED_PACKAGES=$(IFS=,; echo "${CHANGED_PACKAGE_ARRAY[*]}")\n \n # 将变更的数据输出到步骤输出值中\n # echo "update_packages=$CHANGED_PACKAGES" >> $GITHUB_OUTPUT \n # 将变更的包字符串输出到环境变量\n echo "update_packages=$CHANGED_PACKAGES" >> $GITHUB_ENV\n \n printf "\\e[31m检测文件变更的包信息处理完成 \\e[m$CHANGED_PACKAGES \\n"\n}\necho "准备好了么"\nmain\necho "哈哈,执行 🎊 🎊 🎊"\n'),function(){const{manager:e}=Yt;r(er.rangeFile("scripts/pub.sh"),`#!/bin/bash\n\n# 获取环境变量中的变更包字符串\nUPDATE_PACKAGES=$UPDATE_PACKAGES\n# 执行根路径\nREPO_ROOT=$REPO_ROOT\n# 发布异常的包\nPUB_ERROR=()\nCHECK_VERSION="@qqi/check-version"\n# 读取版本检测是否可用\nsource ./scripts/check_version_install.sh \necho "工作根路径 $REPO_ROOT"\nPACKAGES_DIR="\${REPO_ROOT}/packages"\n# 将字符串转为数组\nIFS=',' read -r -a PACKAGE_ARRAY <<< "$UPDATE_PACKAGES"\n \nupdate_version() {\n local input="$1"\n local NAME=$(echo "\${input//-/ }" | tr -s ' ') # 替换 - 为空格并删除重复的空格\n local CWD="\${PACKAGES_DIR}/$input"\n\n local tag=""\n cd $REPO_ROOT # 每次需要手动更新到根下才能正确的校验版本号\n if ! tag=$(npx "\${CHECK_VERSION}" n=\${input} 2>&1); then\n echo "未通过版本校验:$tag"\n return 0 \n fi\n echo "获取 \${NAME} 的发布标签为 \${tag}"\n\n if [ ! -d "$CWD" ]; then \n echo "进入项目 $NAME 故障,路径为 \${CWD}"\n return 0\n fi\n cd "$CWD"\n\n # 依赖安装 \n ${sr()}\n if ! ${e.value} run build; then \n echo "构建 $NAME 失败" \n PUB_ERROR+=("$input")\n return 0\n fi\n local BUILD_DIST="\${CWD}/dist"\n if [ ! -d "\${BUILD_DIST}" ]; then\n echo "未找到 $NAME dist 构建:\${BUILD_DIST}"\n PUB_ERROR+=("$input")\n return 0\n fi\n cd "\${BUILD_DIST}" \n \n echo "开始发布 $NAME npm 包 \${tag} 版本"\n if ! ${e.value} publish --provenance --access public --tag "\${tag}" --no-git-checks; then\n echo "💥💥💥 $NAME 发布到 npm 💥💥💥"\n PUB_ERROR+=("$input")\n else \n echo "🪧 $package 发布终结 🫧🫧🫧🫧🫧🫧"\n fi\n}\n\nmain() {\n # 校验版本可用情况\n if [ ! -d "$PACKAGES_DIR" ]; then\n echo "没有找到 \${PACKAGES_DIR}"\n exit 0\n fi\n echo "☁️ 来"\n install_check_version # 检查版本包安装校验\n # 遍历变更的包数组,进行 npm 包推送\n # "\${ARR[@]}" 引用数组所有元素\n # "\${!ARR[@]}" 引用数组所有索引 \${ARR[$index]}\n # "\${#ARR[@]}" 数组长度 \n for package in "\${PACKAGE_ARRAY[@]}"; do\n echo "当前执行的推送为 $package"\n update_version "$package"\n done\n\n}\n\necho "准备好了么"\nmain\nif [ \${#PUB_ERROR[@]} -gt 0 ]; then \n echo "发布包 \${PUB_ERROR[@]} 异常 "\nelse \n echo "所有发布均已成功:\${PACKAGE_ARRAY[@]}"\n echo "🚀🚀 发布成功,完结 🎉🎉 撒花 🎉🎉"\nfi`)}(),r(er.rangeFile("scripts/workflow_dispatch.sh"),'#!/bin/bash\n\n# 从环境变量中获取手动触发要更新的包数据\nINPUT_PACKAGE=$INPUT_PACKAGE\n# 初始化变更的包数组\nCHANGED_PACKAGE_ARRAY=()\n# 初始化最终要更新的包的数组\nUPDATE_PACKAGE_ARRAY=()\n\n# 读取 packages 下直接子文件夹名并放入到数组 CHANGED_PACKAGE_ARRAY 中 \nwhile IFS= read -r PACKAGE_DIR; do \n PACKAGE_DIR=$(echo "${PACKAGE_DIR// /?}" | tr -s \'?\') # 保护我方空格\n CHANGED_PACKAGE_ARRAY+=("$PACKAGE_DIR")\ndone < <(find packages -mindepth 1 -maxdepth 1 -type d -exec basename {} \\;)\n\ncheck_version() {\n local input="$1"\n local NAME=$(echo "${input//-/ }" | tr -s \' \') # 替换 - 为空格并删除重复的空白字符\n echo "输入:${input}"\n echo "使用:${NAME}"\n \n # 该包是否由手动触发选择\n if [ "$INPUT_PACKAGE" = "all" ] || [ "$INPUT_PACKAGE" = "${input}" ]; then\n echo "手动触发发布且包含 ${NAME}"\n UPDATE_PACKAGE_ARRAY+=("$input")\n return 0\n else\n echo "该包 ${input} 未在手动触发选择"\n return 0\n fi\n}\n\n\nmain() {\n for PACKAGE_NAME in ${CHANGED_PACKAGE_ARRAY[@]}; do \n check_version "$PACKAGE_NAME"\n done\n\n echo "校验版本数据完毕 ${UPDATE_PACKAGE_ARRAY}"\n\n # 将数组转为逗号分隔的字符串\n UPDATE_PACKAGES=$(IFS=,; echo "${UPDATE_PACKAGE_ARRAY[*]}")\n\n # 将变更的包字符串输出到环境变量\n # echo "update_packages=$UPDATE_PACKAGES" >> $GITHUB_OUTPUT \n echo "update_packages=$UPDATE_PACKAGES" >> $GITHUB_ENV\n\n printf "\\e[38;5;164m手动触发的包为 \\e[m$UPDATE_PACKAGES \\n"\n}\necho "准备好了么"\nmain\necho "哈哈,执行 🎊 🎊 🎊"\n')}function dr(){const{dependencies:e}=er.local;e.includes("action")&&(!function(){const{manager:e}=Yt,n=".github/workflows";s(er.rangeFile(n),{recursive:!0}),r(er.rangeFile(n,"发布.yml"),`name: 发布到 npm\non:\n push:\n branches: '*'\n paths:\n - 'packages/**' # 主包更新\n - 'package.json' # 全局依赖\n\n workflow_dispatch: # 手动触发\n inputs:\n version:\n description: '触发原因(选填)'\n required: false\n default: '手动触发'\n ref:\n description: '分支(选填)'\n required: false\n default: ''\n type: string\n package:\n description: '子包'\n required: true\n type: choice\n options:\n - core\n - all\n default: 'all'\n \n# 新的 OpenID Connect 验证方式\n# 无需手动填写 NODE_AUTH_TOKEN 且定期更换\npermissions:\n id-token: write # 唯一必须的权限:启用 OIDC\n contents: read # write 必须,克隆代码库权限\n # packages: write\n\njobs:\n pub:\n # 在提交的代码包含 \`version\` 字样时才运行该动作\n # 或者手动触发\n name: |\n 发布到 npm\n runs-on: ubuntu-latest\n # permissions:\n # packages: write\n # contents: write\n # id-token: write\n # 复合条件判断(自动触发检查提交信息,手动触发直接放行)\n # contains 函数\n # startsWith 函数\n # endsWith 函数\n if: |\n (github.event_name == 'push' && startsWith(github.event.head_commit.message, 'version')) ||\n github.event_name == 'workflow_dispatch'\n steps:\n - name: 代码检出\n uses: actions/checkout@v4\n with:\n ref: \${{ github.event.inputs.ref || github.ref_name }}\n fetch-depth: 0\n\n - name: 初始化 Node 并设定 Node 版本\n uses: actions/setup-node@v4\n with:\n node-version: 24\n registry-url: https://registry.npmjs.org\n\n - name: clean npm auth\n run: |\n npm config delete //registry.npmjs.org/:_authToken\n rm -f ~/.npmrc\n shell: bash\n\n ${"pnpm"===e.value?"\n - name: pnpm 安装\n uses: pnpm/action-setup@v2\n with:\n version: 10\n run_install: false\n\n - name: 缓存 pnpm\n id: pnpm-store\n run: echo \"STORE_PATH=$(pnpm store path)\" >> $GITHUB_OUTPUT\n\n - name: Cache pnpm store\n uses: actions/cache@v4\n with:\n path: ${{ steps.pnpm-store.outputs.STORE_PATH }}\n key: ${{ runner.os }}-pnpm-store-${{ hashFiles('pnpm-lock.yaml') }}\n restore-keys: |\n ${{ runner.os }}-pnpm-store-\n ":"yarn"===e.value?"\n - name: yarn 安装\n uses: actions/setup-yarn@v4\n with:\n version: '1.22' \n - name: 获取 yarn 缓存路径\n id: yarn-cache-path\n run: echo \"CACHE_PATH=$(yarn cache dir)\" >> $GITHUB_OUTPUT # 获取 Yarn 全局环衬路径\n \n - name: 缓存 Yarn 依赖\n uses: actions/cache@v4\n with: \n path: ${{ steps.yarn-cache-path.outputs.CACHE_PATH }} # 缓存 Yarn 全局缓存目录\n key: ${{ runner.os }}-yarn-cache-${{ hashFiles('yarn.lock) }} # 基于 yarn.lock 哈希值生成唯一的 key\n restore-keys: |\n ${{ runner.os }}-yarn-cache # 缓存未命中时,按前缀恢复最近的缓存 \n ":""}\n \n - name: 安装全局依赖\n run: |\n ${sr()}\n cd scripts\n chmod +x detect_changes.sh workflow_dispatch.sh pub.sh\n # chmod +x scripts/detect_changes.sh\n # chmod +x scripts/workflow_dispatch.sh\n # chmod +x scripts/pub.sh\n\n - name: 检测子包变更情况(推送代码时触发)\n if: github.event_name == 'push'\n id: detect-changes\n run: |\n ./scripts/detect_changes.sh\n\n - name: 检测子包变更情况(手动触发时触发)\n if: github.event_name == 'workflow_dispatch'\n id: workflow-changes\n env:\n INPUT_PACKAGE: \${{ github.event.inputs.package }}\n run: |\n ./scripts/workflow_dispatch.sh\n\n - name: 设置工作根路径\n run: |\n echo "REPO_ROOT=$(pwd)" >> $GITHUB_ENV\n\n - name: 发布到 npm\n if: \${{ env.update_packages && env.update_packages != '' }}\n env:\n NPM_CONFIG_USERCONFIG: /dev/null # 强制忽略本地配置\n UPDATE_PACKAGES: \${{ env.update_packages }}\n REPO_ROOT: \${{ env.REPO_ROOT }}\n run: |\n ./scripts/pub.sh\n\n `)}(),pr()),e.includes("typescript")&&(r(er.rangeFile("tsconfig.json"),JSON.stringify({extends:"./tsconfig.base.json",include:["packages/**/index.ts","packages/**/src/**/*.ts","packages/**/eg/**/*.ts"],exclude:["node_modules","packages/**/node_modules","packages/**/**/*.test.ts","jest.setup.ts"]})),r(er.rangeFile("tsconfig.base.json"),JSON.stringify({compilerOptions:{rootDir:".",jsx:"preserve",strict:!0,target:"ESNext",module:"ESNext",skipLibCheck:!0,esModuleInterop:!0,moduleResolution:"Bundler",allowSyntheticDefaultImports:!0,isolatedModules:!0,lib:["ESNext","DOM"],sourceMap:!1}}))),r(er.rangeFile("README.md"),"# 你会更改这里的内容的\n \n毕竟,我猜你有很多话要说\n记录下来,哪怕不会有人看见\n "),function(){const{dependencies:e}=er.local,n={name:er.name.replace(/^@(.*)\/.*$/,"$1")+"-root",version:"0.0.0",type:"module",private:!0,description:"改了这里。毕竟,你有自己的话要说",scripts:{diff:"jja pkg --diff=官方",vjj:"vjj",push:"gvv","push:version":"gvv",prepublishOnly:"pjj"},devDependencies:er.buildDevDependencies()};e.includes("husky")&&e.includes("prettier")&&(n["lint-staged"]={"*.{js,ts}":["prettier --write"]},n.scripts.prepare="husky"),e.includes("eslint")&&(n.scripts.eslint="jja cls && eslint packages"),e.includes("prettier")&&(n.scripts.prettier="jja cls && prettier . --write"),Xe(er.rangeFile("package.json"),n)}(),r(er.rangeFile("LICENSE"),lr()),e.includes("eslint")&&r(er.rangeFile("eslint.config.js"),cr()),e.includes("prettier")&&(r(er.rangeFile(".prettierrc"),ur()),r(er.rangeFile(".prettierignore"),"\nnode_modules\ndist\n*.tgz\n*.zip\ncoverage\n.DS_Store\n.eg")),r(er.rangeFile(".markdownlint.json"),'{\n "MD024": false,\n "MD013": false\n}\n'),r(er.rangeFile(".gitignore"),"\nnode_modules\ndist\n*.tgz\n*.zip\ncoverage\n.DS_Store\n.eg")}function fr(){const e=(()=>{const e=new Date;return`${e.getFullYear()}-${e.getMonth()+1}-${e.getDate()}`})();r(er.pkgFile("CHANGELOG.md"),`# 更新日志 📔\n\n## v0.0.0 (${e})\n`)}function hr(){const{dependencies:e}=er.local,n=e.includes("typescript"),t=1===er.bin;s(er.pkgFile("src"),{recursive:!0}),r(er.pkgFile("src/index."+(n?"ts":"js")),t?'#!/usr/bin/env node\n\nconsole.log("你好");':"export function sayHello() {\n console.log('哈喽');\n }\n ")}function gr(){r(er.pkgFile("LICENSE"),lr())}function mr(){const{author:e}=er.local,{name:n,url:t}=e,s=er.name.replace(/^@/,""),i=s.split("/");r(er.pkgFile("README.md"),`# ${er.name}\n\r\n[![version](<https://img.shields.io/npm/v/${er.name}.svg?logo=npm&logoColor=rgb(0,0,0)&label=版本号&labelColor=rgb(73,73,228)&color=rgb(0,0,0)>)](https://www.npmjs.com/package/${er.name}) [![issues 提交](<https://img.shields.io/badge/issues-提交-rgb(255,0,63)?logo=github>)](https://github.com/${n.replace(/\s+/g,"_")}/${i[0]}/issues)\n \n## 文档地址\n\n参看 [${t}/${s}](${t}/${s})`)}function br(){s(Ye(er.pkgFile("scripts")),{recursive:!0});const{author:e}=er.local,n=er.name.replace(/^@/,"").split("/"),t=n[0],{bin:i}=er;r(er.pkgFile("scripts/clean-package-json.js"),`import {\n pathJoin,\n readFileToJsonSync,\n writeJsonFileSync,\n ${1!==i?"getDirectoryBy,\n fileExist,":""}\n} from 'a-node-tools';\n${1!==i?"import { readdirSync } from 'node:fs';\nimport { basename, extname } from 'node:path';":""}\n\n// 原始 package.json 内容\nlet packageJson = readFileToJsonSync('./package.json');\nconst dependencies = packageJson.dependencies;\n// 移除冗余的键\n[\n 'scripts',\n 'devDependencies',\n 'lint-staged',\n 'private',\n 'dependencies',\n].forEach(key => delete packageJson[key]);\n ${1!==i?"const esPrefix = 'es'; // es 前缀\nconst cjsPrefix = 'cjs'; // cjs 前缀\nconst dtsPrefix = 'es/src'; // 类型文件的前缀\n// 查看当前打包 dist 文件路径\nconst distParentPath = getDirectoryBy('dist', 'directory');\n// <-- !!! --\x3e\n// <-- !!! --\x3e\n// <-- !!! --\x3e\n// 查看当前的源码文件路径(原则上与上面值一致)\nconst srcParentDirectory = getDirectoryBy('src', 'directory');\n// 当前 src 的路径\nconst srcDirectory = pathJoin(srcParentDirectory, 'src');\n// src 目录下的文件列表\nconst srcChildrenList = readdirSync(srcDirectory);\n// 打包的 exports\nconst exportsList = {};\n\nfor (const childrenName of srcChildrenList) {\n // 如果是测试文件则跳过\n if (\n // 剔除测试文件\n childrenName.endsWith('.test.ts') ||\n // 剔除单独配置的根文件\n childrenName.endsWith('index.ts') ||\n childrenName.endsWith('utils') ||\n // 剔除非导出模块\n ['testData.ts', 'types.ts'].includes(childrenName)\n )\n continue;\n // 文件名(不带后缀)\n const childrenBaseName = basename(childrenName, extname(childrenName));\n // 子文件/夹的路径\n const childPath = pathJoin(srcDirectory, childrenName);\n\n const childFile = fileExist(childPath); // 文件元数据\n if (!childFile) throw new RangeError(`${childrenName} 文件未能读取`);\n // 子文件是文件夹时以 index.xxx.js 为准\n if (childFile.isDirectory()) {\n exportsList[`./${childrenBaseName}`] = {\n default: `./${esPrefix}/${childrenName}/index.js`,\n import: `./${esPrefix}/${childrenName}/index.js`,\n require: `./${cjsPrefix}/${childrenName}/index.js`,\n types: `./${dtsPrefix}/${childrenName}/index.d.ts`,\n };\n } else if (childFile.isFile()) {\n exportsList[`./${childrenBaseName}`] = {\n default: `./${esPrefix}/${childrenBaseName}.js`,\n import: `./${esPrefix}/${childrenBaseName}.js`,\n require: `./${cjsPrefix}/${childrenBaseName}.js`,\n types: `./${dtsPrefix}/${childrenBaseName}.d.ts`,\n };\n } else {\n throw new RangeError(`${childrenName} 文件类型不符合要求`);\n }\n}":""}\npackageJson = {\n ...packageJson,\n ${1!==i?"main: `${cjsPrefix}/index.js`,\n module: `${esPrefix}/index.mjs`,\n types: 'index.d.ts',":""}\n author: {\n name: '${e.name}',\n email: '${e.email}',\n url: '${e.url}',\n },\n description: '',\n license: 'MIT',\n files: [${1!==i?"cjsPrefix, esPrefix ,":""} ${0!==i?"bin.js ,":""} 'LICENSE', 'README.md'],\n \n exports: {\n '.': {\n import: {\n default: './index.mjs',\n types: './index.d.ts',\n },\n require: {\n default: './index.cjs',\n types: './index.d.ts',\n },\n },\n },\n\n keywords: ['${t}', '${n[0]}'],\n homepage: '${e.url}',\n dependencies,\n bugs: {\n url: 'https://github.com/${e.name}/${t}/issues',\n email: '${e.email}',\n },${0!==i?`\n bin: {\n ${er.name} : './bin.js',\n },\n `:""} \n repository: {\n type: 'git',\n url: 'git+https://github.com/${e.name}/${t}.git',\n },\n publishConfig: {\n access: 'public',\n registry: 'https://registry.npmjs.org/',\n },\n browserslist: ['node>=18.0.0'],\n engines: {\n node: '>=18.0.0',\n },\n};\n\n{\n // 整理打包后 package.json 文件路径\n const distPackagePath = pathJoin(distParentPath, './dist/package.json');\n // 写入新的 packages.json 文件\n writeJsonFileSync(distPackagePath, packageJson);\n}\n`)}function wr(){const{dependencies:e}=er.local,n=e.includes("typescript")?"ts":"js";s(er.pkgFile("eg"),{recursive:!0}),r(er.pkgFile("eg/index."+n),"import { sayHello } from '../src/index';\n\nsayHello(); \n")}function $r(){const{dependencies:e}=er.local;e.includes("typescript")&&(1!==er.bin&&r(er.pkgFile("tsconfig.types.json"),'/** 该文件打包前使用 */\n{\n "extends": "../../tsconfig.base.json",\n "compilerOptions": {\n "emitDeclarationOnly": true,\n "declaration": true,\n "declarationDir": "dist/"\n // "types": ["node"],\n },\n "exclude": ["node_modules", "dist", "**/*.test.ts", "eg", "jest.setup.ts"]\n}\n'),r(er.pkgFile("tsconfig.rollup.json"),'{\n "extends": "./tsconfig.types.json",\n "compilerOptions": {\n "declarationDir": null,\n "declaration": false\n },\n "include": ["eg", "eg/*.ts", "src/**/*.ts", "./index.ts"],\n "exclude": ["node_modules", "**/*.test.ts"]\n}\n')),function(){const{dependencies:e}=er.local,n=e.includes("typescript");r(er.pkgFile("rollup.config.js"),`${n?"import typescript from '@rollup/plugin-typescript';":"+++++"}\nimport resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\nimport json from '@rollup/plugin-json';\nimport cleanup from 'rollup-plugin-cleanup';\nimport copy from 'rollup-plugin-copy';\nimport { external } from '@qqi/rollup-external';\n\nexport default {\n input: './index.${n?"ts":"js"}',\n output: \n ${1!==er.bin?"[{\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: true,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },{\n format: 'cjs',\n entryFileNames: '[name].cjs',\n preserveModules: true,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },],":"{\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: false,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },"}\n // 配置需要排除的或包含包\n external: external(),\n plugins: [\n resolve(),\n commonjs(),\n json(),\n ${n?"typescript({\n tsconfig: './tsconfig.rollup.json',\n exclude: ['node_modules', 'test'],\n }),":"+++"}\n // 去除无用代码\n cleanup(),\n copy({\n targets: [\n { src: 'README.md', dest: 'dist' },\n { src: 'LICENSE', dest: 'dist' },\n ],\n }),\n ],\n};\n`.replace(/\+{2,}\n?/gm,""))}(),function(){const{dependencies:e}=er.local,n=e.includes("typescript");r(er.pkgFile("rollup.config.eg.js"),`${n?"import typescript from '@rollup/plugin-typescript';":""}\nimport resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\nimport json from '@rollup/plugin-json';\nimport cleanup from 'rollup-plugin-cleanup';\nimport { external } from '@qqi/rollup-external';\n\n/** 生成 npm 文件的打包配置文件 */\nexport default {\n input: './eg/index.${n?"ts":"js"}',\n output:{\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: false,\n sourcemap: false,\n exports: 'named',\n dir: '.eg/',\n },\n // 配置需要排除的包\n external: external({ ignore: ['node:'] }),\n plugins: [\n resolve(),\n commonjs(),\n // 可打包 json 内容\n json(),\n ${n?"\ntypescript({\ntsconfig: './tsconfig.rollup.json',\n}),\n":""}\n // 去除无用代码\n cleanup(),\n ],\n};\n`)}(),mr(),function(){const{manager:e}=Yt,{dependencies:n}=er.local,t=n.includes("typescript"),r={type:"module",version:"0.0.0",name:er.name,description:"写点什么吧,空白只本应存在于虚空",scripts:{b:"rollup --config rollup.config.js"+(t||1!==er.bin?" && tsc -p tsconfig.types.json":""),build:`${e.value} run b && ${e.value} run clean:package`,test:"jja rm .eg && rollup --config rollup.config.eg.js && node .eg/index.mjs","push:version":"gvv",push:"gvv",diff:"jja pkg --diff=官方",vjj:"vjj",prepublishOnly:"pjj","clean:package":"node scripts/clean-package-json.js"},license:"MIT"};Xe(er.pkgFile("package.json"),r)}(),gr(),hr(),fr(),r(er.pkgFile("todo.md"),"# 代办\n\n"),br(),wr()}const yr=new ze({name:"qqi",type:!1});I(yr.type);const vr=new class{#u;#p=!0;get available(){return this.#p}constructor(e){const n=function(){const e=a();if(yr("当前获取用户主目录为",e),!e||"/"===e||e.includes("Default"))throw new Error("未能获取到主目录路径 <"+e+">");try{const n=Ye(e,"test_write"+Date.now());return en(n,{}),i(n),e}catch(e){return void yr.error(e)}}();if(R(n))return this.#p=!1,void(this.#u="");this.#p=!0,this.#u=Ye(n,".earthnut.dev.data",`${e}`)}read(e){if(!this.available)return null;const n=Ye(this.#u,e);return R(M(n))?{}:Ze(n)||{}}write(e,n){if(!this.available)return!1;const t=Ye(this.#u,e),r=Ye(t,"../");yr("创建的文件路径为"),s(r,{recursive:!0}),yr("写入的文件路径为:",t),yr("写入文件内容为",n);const i=en(t,n);return yr("写入反馈",i),i}getPath(e){return Ye(this.#u,e)}}("create-a-npm");function xr(e){const n=Symbol("diy");return e.push({label:"手动输入值",value:n,tip:"使用其他输入名称"}),n}function Er(e,n){if(!vr.available)return;const t=vr.read("config"),r=t?.author?.[n]??"";if(x(r))return;er.local.author[n]=r;let s=!1;for(const n in e){const t=e[n];if(t.value===r){t.tip+=ye`(上次使用该值)`,s=!0,e.unshift(e.splice(Number(n),1)[0]);break}}s||e.unshift({label:`${r}`,value:r,tip:"上次使用"})}async function kr(){const e=[];await async function(e){const n=await On("git config user.email");if(!n.success)return await rr("获取本地的 git config user.email 出错\n".concat(n.error||n.data));const t=n.data.replace(/\n$/,"")||"";x(t)||e.push({value:t,tip:"该值从 git 全局配置读取",label:t})}(e),function(e){const{author:n}=er.local;if(x(n.name))return;const t=`${n.name.replace(/\s+/g,"_")}@outlook.com`;e.push({value:t,label:t,tip:"该值由 name 值合成而来"})}(e),Er(e,"email");const n=xr(e);await async function(e,n){const{author:t}=er.local,r=t.email;let s=await Wt({data:e,info:"请选择您的通讯邮箱"});if(R(s))return await rr();F(s,e=>e===n)&&(s=await async function(){const e=await It({text:"请输入您将配置的邮箱",maxLen:50,minLen:5,verify:[{reg:/^[^\s@]+@[^\s@]+\.[^\s@]{2,}$/,info:"需符合邮箱基本模式"}]});if(R(e))return await rr();return e}());Vt&&zt(ke("获取当前的用户名 "),s);zt("是否执行写入",vr.available),er.package.author.email=t.email=s,vr.available&&r!==s&&(zt("写入的值",er.local),vr.write("config",er.local))}(e,n)}async function jr(){const e=[];!function(e){const{author:n}=er.local;if(x(n.name))return;const t=`${n.name.replace(/\s+/g,"_")}.github.io`;e.push({value:t,label:t,tip:"该值由 name 值合成而来"})}(e),Er(e,"url");const n=xr(e);await async function(e,n){const{author:t}=er.local,r=t.url;let s=await Wt({data:e,info:"请配置您的个人网站"});if(R(s))return await rr();F(s,e=>e===n)&&(s=await async function(){const e=await It({text:"请输入您将配置的网址",maxLen:50,minLen:5,verify:[{reg:/^https?:\/{2}.+/,info:"需符合网址基本模式"}]});if(R(e))return await rr();return e}());Vt&&zt(ke("获取当前的网址 "),s);zt("是否执行写入",vr.available),er.package.author.url=t.url=s,vr.available&&r!==s&&(zt("写入的值",er.local),vr.write("config",er.local))}(e,n)}async function Cr(){const e=[];await async function(e){const n=await On("git config user.name");if(n.success){const t=n.data?.replace(/\n$/,"")||"";x(t)||e.push({label:`${t}`,value:t,tip:"由 git 全局配置读取"})}}(e),function(e){const n=process.env.USER??process.env.USERNAME??c().username;e.push({label:`${n}`,value:n,tip:"设备用户名"})}(e);const n=xr(e);Er(e,"name"),await async function(e,n){const{author:t}=er.local,r=t.name;let s=await Wt({data:e,info:"请选择要使用的用户名"});if(R(s))return await rr();F(s,e=>e===n)&&(s=await async function(){const e=await It({text:"请输入您将配置的用户名",maxLen:16});if(R(e))return await rr();return e}());Vt&&zt(ke("获取当前的用户名 "),s);zt("是否执行写入",vr.available),er.package.author.name=t.name=s,vr.available&&r!==s&&(zt("写入的值",er.local),vr.write("config",er.local))}(e,n)}async function Ar(){const e=await async function(){const e=["name","email","url"],{local:n}=er;if(!vr.available)return e;const t=vr.read("config");if(R(t?.author))return e;O(t?.dependencies)&&(n.dependencies=t.dependencies);const{author:r}=t,s=Object.keys(r).filter(e=>!x(r[e])&&(n.author[e]=r[e])&&!0).map(e=>({value:e,label:`${e} : ${r[e]}`,checked:!0}));if(S(s))return e;const i=await Wt({info:"以下为上次使用配置,选中的项将跳过配置",data:s,kind:"check"});return R(i)?await rr():(zt("选项的值",i),q.difference(e,i))}();zt("获取需要更改的项",e),e.includes("name")&&await Cr(),e.includes("email")&&await kr(),e.includes("url")&&await jr(),await async function(){const e=await Wt({info:"请选择开发模式",data:[{value:0,label:"仅是可用库",tip:"当前仅是使用的库,譬如:"+ye`a-js-tools`},{value:1,label:"仅是可执行库",tip:"当前仅包含可执行内容,譬如:"+ye`jja`},{value:2,label:"库 + bin",tip:"即包含可执行又包含可导出使用内容,譬如:"+ye`qqi`}]});R(e)||(er.bin=e)}(),await async function(){const{local:e}=er,n=e.dependencies,t=[{value:"rollup",tip:"该项为必须项",label:"打包工具 rollup",checked:!0,disable:!0},{value:"typescript",tip:"如果使用 typescript 建议使用该项",label:"使用 "+ye`typescript`,checked:n.includes("typescript")},...[["eslint",`使用代码问题工具 ${ye`eslint`}`],["prettier",`格式化代码 ${ye`prettier`}`],["husky",`git 提交 hook 管理 ${ye`husky`}`],["action",`CI/CD 使用自动化构建、发布 ${ye`github action`} `]].map(e=>({value:e[0],label:e[1],checked:n.includes(e[0])}))],r=await Wt({data:t,kind:"check",info:"请选择要使用的辅助功能"});zt("用户选择的依赖",r),R(r)?e.dependencies=Jt:(e.dependencies=r,vr.available&&(zt("执行储存的数据",e),vr.write("config",e)))}(),await async function(){const e=["安装","跳过"],n=await It({text:"是否安装依赖",tip:e});R(n)||n===e[1]||(er.install=!0)}()}function Ir(){tr("tsconfig.base.json",{compilerOptions:{forceConsistentCasingInFileNames:!0,rootDir:".",jsx:"preserve",strict:!0,target:"ESNext",module:"ESNext",skipLibCheck:!0,esModuleInterop:!0,moduleResolution:"Bundler",allowSyntheticDefaultImports:!0,isolatedModules:!0,lib:["ESNext","DOM"],sourceMap:!1}}),tr("tsconfig.json",{extends:"./tsconfig.base.json",include:["index.ts","src/**/*.ts","**.d.ts","test/**/*.ts"],exclude:["node_modules","dist"]}),tr("tsconfig.types.json",{extends:"./tsconfig.base.json",compilerOptions:{emitDeclarationOnly:!0,declaration:!0,declarationDir:"dist/es"},exclude:["node_modules","test","dist","eg"]})}function Tr(){const{dependencies:e}=er.local;e.includes("action")&&(function(){const{manager:e}=Yt,n=".github/workflows";s(er.pkgFile(n),{recursive:!0}),r(er.pkgFile(n,"发布.yml"),`name: 发布到 npm\non:\n push:\n branches: '*'\n workflow_dispatch: # 手动触发\n inputs:\n version:\n description: '触发原因(选填)'\n required: false\n default: '手动触发'\n type: string\n ref:\n description: '发布的分支(选填)'\n required: false\n default: ''\n type: string\n\n# 新的 OpenID Connect 验证方式\n# 无需手动填写 NODE_AUTH_TOKEN 且定期更换\npermissions:\n id-token: write # 唯一必须的权限:启用 OIDC\n contents: read # write 必须,克隆代码库权限\n # packages: write\n\njobs:\n pub:\n # 在提交的代码包含 \`version\` 字样时才运行该动作\n # 或者手动触发\n name: |\n 发布到 npm\n runs-on: ubuntu-latest\n # 复合条件判断(自动触发检查提交信息,手动触发直接放行)\n # startsWith(github.event.head_commit.message, 'version')\n # contains(github.event.inputs.version, '手动触发')\n # endsWith(github.event.head_commit.message, 'version')\n if: |\n (github.event_name == 'push' && startsWith(github.event.head_commit.message, 'version')) ||\n github.event_name == 'workflow_dispatch'\n steps:\n - name: 代码检出\n uses: actions/checkout@v4\n with:\n ref: \${{ github.event.inputs.ref || github.ref_name }}\n fetch-depth: 1\n\n - name: 初始化 Node 并设定 Node 版本\n uses: actions/setup-node@v4\n with:\n node-version: 24\n registry-url: https://registry.npmjs.org\n\n - name: clean npm auth\n run: |\n npm config delete //registry.npmjs.org/:_authToken\n rm -f ~/.npmrc\n shell: bash\n\n ${"pnpm"===e.value?"\n - name: pnpm 安装\n uses: pnpm/action-setup@v2\n with:\n version: 10\n run_install: false\n\n - name: 缓存 pnpm\n id: pnpm-store\n run: echo \"STORE_PATH=$(pnpm store path)\" >> $GITHUB_OUTPUT\n\n - name: Cache pnpm store\n uses: actions/cache@v4\n with:\n path: ${{ steps.pnpm-store.outputs.STORE_PATH }}\n key: ${{ runner.os }}-pnpm-store-${{ hashFiles('pnpm-lock.yaml') }}\n restore-keys: |\n ${{ runner.os }}-pnpm-store-\n ":"yarn"===e.value?"\n - name: yarn 安装\n uses: actions/setup-yarn@v4\n with:\n version: '1.22' \n - name: 获取 yarn 缓存路径\n id: yarn-cache-path\n run: echo \"CACHE_PATH=$(yarn cache dir)\" >> $GITHUB_OUTPUT # 获取 Yarn 全局环衬路径\n \n - name: 缓存 Yarn 依赖\n uses: actions/cache@v4\n with: \n path: ${{ steps.yarn-cache-path.outputs.CACHE_PATH }} # 缓存 Yarn 全局缓存目录\n key: ${{ runner.os }}-yarn-cache-${{ hashFiles('yarn.lock) }} # 基于 yarn.lock 哈希值生成唯一的 key\n restore-keys: |\n ${{ runner.os }}-yarn-cache # 缓存未命中时,按前缀恢复最近的缓存 \n ":""}\n \n - name: 发布到 npm\n env:\n NPM_CONFIG_USERCONFIG: /dev/null # 强制忽略本地配置\n run: |\n chmod +x ./scripts/pub.sh\n ./scripts/pub.sh\n`)}(),function(){const{manager:e}=Yt;s(Ye(er.pkgFile("scripts")),{recursive:!0}),r(er.pkgFile("scripts","pub.sh"),`#!/bin/bash\n\nCHECK_VERSION="@qqi/check-version"\n# 安装 \ninstall_check_version() {\n if ! npm list -g --depth=0 | grep -q " \${CHECK_VERSION}"; then \n echo "当前未全局安装 '\${CHECK_VERSION}',即将进行安装"\n npm install \${CHECK_VERSION} --global\n else \n echo "包 \${CHECK_VERSION} 已全局安装"\n fi\n}\n\ntag=""\ninstall_check_version\nif ! tag=$(npx "\${CHECK_VERSION}" c=. 2>&1); then\n echo "未通过版本校验:$tag"\n exit 0\nfi\necho "获取🉐发布标签为 \${tag}"\n# 依赖安装\n${sr()}\n# 构建项目\nif ! ${e.value} run build; then \n echo "构建失败" \n exit 0\nfi\n\n# 切换到构建目录\nif [ ! -d "dist" ]; then \n echo "未找到 dist 构建码"\n exit 0\nfi\n\n# 确保脚本在遇见错误时立即退出\nset -e\n\ncd "dist"\necho "开始发布 npm 包 \${tag} 版本"\nif ! ${e.value} publish --provenance --access public --tag "\${tag}" --no-git-checks; then\n echo "发布失败" \n exit 1\nfi\necho "🚀🚀 发布成功,完结 🎉🎉 撒花 🎉🎉"\n\n`)}()),e.includes("typescript")&&Ir(),function(){const{dependencies:e}=er.local,n=e.includes("typescript"),t=1===er.bin;r(er.pkgFile("rollup.config.js"),`${n?"import typescript from '@rollup/plugin-typescript';":""}\nimport resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\nimport json from '@rollup/plugin-json';\nimport cleanup from 'rollup-plugin-cleanup';\nimport copy from 'rollup-plugin-copy';\nimport { external } from '@qqi/rollup-external';\n${t?"import license form 'rollup-plugin-license';\nimport terser from '@rollup/plugin-terser';":""}\n\nexport default {\n input: './src/index.${n?"ts":"js"}',\n output: ['es' ${t?"":", 'cjs'"} ].map(e => ({\n format: e, // 打包模式\n entryFileNames: '${t?"bin":"[name]"}.js', // 打包文件名\n preserveModules: false, // 保留独立模块结构(关键)\n // preserveModulesRoot: 'src', // 保持 src 目录结构\n sourcemap: false, // 正式环境:关闭 source map\n // exports: 'named', // 导出模式\n dir: \`dist/${t?"":"${e}/"}\`,\n })),\n // 配置需要排除或包含的包\n external: external({\n ignore: ['node:']\n }),\n plugins: [\n resolve(),\n commonjs(),\n json(),${n?"\ntypescript(),":""}\n cleanup(), ${t?"\nterser({\n format: {\n comments: false\n }\n }),":""}\n copy({\n targets: [\n { src: 'README.md', dest: 'dist' },\n { src: 'LICENSE', dest: 'dist' },\n ],\n }),${t?`\nlicense({\n thirdParty: {\n allow: '(MIT OR Apache-2.0 OR BSD-3-Clause)', // 仅允许这些许可证依赖\n output: {\n file: 'dist/THIRD-PARTY-LICENSES.txt',\n template: dependencies =>\n \`THIRD-PARTY LICENSE\n${"=".repeat(50)}\n\n\`.concat(\n dependencies\n ?.map(\n dep =>\n \`\${dep.name} (\${dep.version})\n${"-".repeat(30)}\n\${dep.licenseText}\n\`,\n )\n .join('\n'),\n ),\n },\n },\n }),`:""}\n ],\n};`)}(),function(){const{dependencies:e}=er.local,n=e.includes("typescript");r(er.pkgFile("rollup.config.eg.js"),`${n?"import typescript from '@rollup/plugin-typescript';":""}\nimport resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\nimport json from '@rollup/plugin-json';\nimport cleanup from 'rollup-plugin-cleanup';\nimport { external } from '@qqi/rollup-external';\n\n/** 生成 npm 文件的打包配置文件 */\nexport default {\n input: './eg/index.${n?"ts":"js"}',\n output: {\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: false,\n sourcemap: false,\n exports: 'named',\n dir: '.eg/',\n },\n // 配置需要排除的包\n external: external({ ignore: ['node:'] }),\n plugins: [\n resolve(),\n commonjs(),\n // 可打包 json 内容\n json(),\n ${n?"typescript(),":""}\n // 去除无用代码\n cleanup(),\n ],\n};\n `)}(),mr(),function(){const{manager:e}=Yt,{dependencies:n}=er.local,t=n.includes("typescript"),r={name:er.name,version:"0.0.0",type:"module",private:!0,description:"",scripts:{b:"rollup --config rollup.config.js"+(1!==er.bin&&t?" && tsc -p tsconfig.types.json":""),build:`jja cls rm dist && ${e.value} run b && ${e.value} run clean:package`,"clean:package":"node scripts/clean-package-json.js",diff:"jja pkg --diff=淘宝",prepublishOnly:"pjj",push:"gvv","push:version":"gvv",test:"jja rm .eg && rollup --config rollup.config.eg.js && node .eg/index.js",vjj:"vjj"},devDependencies:er.buildDevDependencies()},s=function(e,n="scripts"){Object.keys(e).forEach(t=>{this[n]||(this[n]={}),this[n][t]=e[t]})}.bind(r);n.includes("husky")&&n.includes("prettier")&&(s({"*.{js,ts}":["prettier --write"]},"lint-staged"),s({prepare:"husky"})),n.includes("eslint")&&s({lint:"jja cls && eslint . --fix"}),n.includes("prettier")&&s({beautify:"jja cls && prettier . --write"});const{description:i,...o}=r;tr("package.json",o)}(),gr(),hr(),e.includes("eslint")&&r(er.pkgFile("eslint.config.mjs"),cr()),e.includes("prettier")&&(r(er.pkgFile(".prettierignore"),"\nnode_modules\ndist\n*.tgz\n*.zip\ncoverage\n.DS_Store\n.eg"),r(er.pkgFile(".prettierrc"),ur())),r(er.pkgFile(".markdownlint.json"),'{\n "MD024": false,\n "MD013": false\n}\n'),fr(),r(er.pkgFile(".gitignore"),"\nnode_modules\ndist\n*.tgz\n*.zip\ncoverage\n.DS_Store\n.eg"),br(),wr()}async function Rr(){return zt("开始构建应用"),""==er.name?(await or(),await Ar(),void await Rr()):er.childPkg?(er.carryRange&&dr(),void $r()):void Tr()}(async()=>{try{try{const e=Ye("test_write"+Date.now());Xe(e,{}),i(e)}catch(e){return zt.error(e),console.log(e),await rr("您没有当前目录的写文件的权限,请确认后再试")}fn("华丽开始分割",!0),function(){const e=qt.args.$map,{manager:n}=Yt;zt("解析元素参数",e);const t=e.manager?.value?.[0]??"";n.accept.includes(t)&&(n.value=t)}();const{manager:e}=Yt;zt(e),v(e.value)?await ar():dn(Ee`您选择使用 ${xe(e.value)} 作为包管理器`),await or(),await Ar(),await Rr(),er.install&&await async function(){const{manager:e}=Yt;await On({code:`${e.value} install`,cwd:er.childPkg?er.rangeFile(""):er.pkgFile(""),printLog:!0,waiting:"请稍等,正在安装依赖"})}(),dn(ye`创建项目完毕`),er.childPkg?dn(`请 cd 到 ${xe`./${er.range}`} 目录下`):dn(`请 cd 到 ${xe(er.cwd)} 目录下`),dn(),er.install||dn(`执行 ${ke("npm"===e.value?"npm install":"yarn"===e.value?"yarn":"pnpm install")}`),dn(ke`简单测试使用 ${Ce`${e.value} test`}`),dn(ke`简单打包使用 ${Ce`${e.value} run build`}`),dn(ye`创建项目完毕`),dn(),await rr("")}catch(e){zt.error(e)}})();
package/package.json CHANGED
@@ -1,75 +1,85 @@
1
1
  {
2
2
  "name": "create-a-npm",
3
3
  "type": "module",
4
- "version": "1.0.6",
5
- "description": "一个一键生成一个符合特定规则 <就是一个简单的代码模板库> 的 npm 包",
6
- "license": "MIT",
4
+ "version": "1.1.0",
7
5
  "devDependencies": {
8
- "@eslint/js": "^9.32.0",
9
- "@qqi/check-version": "^1.0.4",
10
- "@qqi/rollup-external": "^1.0.9",
11
- "@rollup/plugin-commonjs": "^28.0.6",
6
+ "@eslint/js": "^9.39.2",
7
+ "@qqi/check-version": "^1.1.0",
8
+ "@qqi/rollup-external": "^1.1.0",
9
+ "@rollup/plugin-commonjs": "^29.0.0",
12
10
  "@rollup/plugin-json": "^6.1.0",
13
- "@rollup/plugin-node-resolve": "^16.0.1",
11
+ "@rollup/plugin-node-resolve": "^16.0.3",
14
12
  "@rollup/plugin-terser": "^0.4.4",
15
- "@rollup/plugin-typescript": "^12.1.4",
16
- "@types/node": "^24.1.0",
17
- "eslint": "^9.32.0",
13
+ "@rollup/plugin-typescript": "^12.3.0",
14
+ "@types/node": "^25.0.9",
15
+ "eslint": "^9.39.2",
18
16
  "eslint-config-prettier": "^10.1.8",
19
- "eslint-plugin-jsdoc": "^51.4.1",
20
- "globals": "^16.3.0",
21
- "gvv": "^0.1.5",
17
+ "eslint-import-resolver-typescript": "^4.4.4",
18
+ "eslint-plugin-import": "^2.32.0",
19
+ "eslint-plugin-jsdoc": "^62.0.0",
20
+ "eslint-plugin-jsonc": "^2.21.0",
21
+ "eslint-plugin-promise": "^7.2.1",
22
+ "eslint-plugin-unused-imports": "^4.3.0",
23
+ "globals": "^17.0.0",
24
+ "gvv": "^1.0.0",
22
25
  "husky": "^9.1.7",
23
- "jja": "^2.3.14",
24
- "lint-staged": "^16.1.2",
25
- "pjj": "^1.0.3",
26
- "prettier": "^3.6.2",
27
- "rollup": "^4.46.0",
26
+ "jja": "^2.4.0",
27
+ "lint-staged": "^16.2.7",
28
+ "pjj": "^1.0.5",
29
+ "prettier": "^3.8.0",
30
+ "rollup": "^4.55.1",
28
31
  "rollup-plugin-cleanup": "^3.2.1",
29
32
  "rollup-plugin-copy": "^3.5.0",
33
+ "rollup-plugin-license": "^3.6.0",
30
34
  "tslib": "^2.8.1",
31
- "typescript": "^5.8.3",
32
- "typescript-eslint": "^8.38.0",
33
- "vjj": "^1.0.9"
34
- },
35
- "dependencies": {
36
- "@color-pen/static": "^1.0.1",
37
- "@qqi/log": "^0.1.1",
38
- "a-command": "^2.3.13",
39
- "a-js-tools": "^1.0.10",
40
- "a-node-tools": "^4.2.19",
41
- "a-type-of-js": "^1.0.7",
42
- "color-pen": "^2.0.13",
43
- "colored-table": "^0.1.0",
44
- "qqi": "^0.1.1"
35
+ "typescript": "^5.9.3",
36
+ "typescript-eslint": "^8.53.0",
37
+ "vjj": "^1.0.12",
38
+ "@color-pen/static": "^1.1.1",
39
+ "@qqi/log": "^1.0.0",
40
+ "a-command": "^3.0.1",
41
+ "a-js-tools": "^2.0.1",
42
+ "a-node-tools": "^4.4.2",
43
+ "a-type-of-js": "^2.0.0",
44
+ "color-pen": "^3.0.0",
45
+ "colored-table": "^0.2.0",
46
+ "qqi": "^1.0.0"
45
47
  },
46
48
  "author": {
47
- "name": "🥜",
48
- "email": "earthnut.dev@outlook.com",
49
+ "name": "泥豆君",
50
+ "email": "Mr.MudBean@outlook.com",
49
51
  "url": "https://earthnut.dev"
50
52
  },
53
+ "description": "一个简单的代码模板库",
54
+ "license": "MIT",
51
55
  "files": [
52
- "bin.mjs"
56
+ "bin.js",
57
+ "LICENSE",
58
+ "README.md",
59
+ "THIRD-PARTY-LICENSES.txt"
53
60
  ],
54
61
  "keywords": [
55
62
  "crate-a-npm",
56
63
  "create-a-pkg",
57
- "earthnut"
64
+ "crate a npm"
58
65
  ],
59
- "repository": {
60
- "type": "git",
61
- "url": "git+https://github.com/earthnutDev/create-a-npm.git"
62
- },
63
66
  "homepage": "https://earthnut.dev/npm/create-a-npm",
64
67
  "bugs": {
65
- "url": "https://github.com/earthnutDev/create-a-npm/issues",
66
- "email": "earthnut.dev@outlook.com"
68
+ "url": "https://github.com/MrMudBean/create-a-npm/issues",
69
+ "email": "Mr.MudBean@outlook.com"
70
+ },
71
+ "repository": {
72
+ "type": "git",
73
+ "url": "git+https://github.com/MrMudBean/create-a-npm.git"
67
74
  },
68
75
  "publishConfig": {
69
76
  "access": "public",
70
77
  "registry": "https://registry.npmjs.org/"
71
78
  },
72
79
  "bin": {
73
- "create-a-npm": "bin.mjs"
80
+ "create-a-npm": "bin.js"
81
+ },
82
+ "engines": {
83
+ "node": ">=18.0.0"
74
84
  }
75
85
  }
package/bin.mjs DELETED
@@ -1,2 +0,0 @@
1
- #!/usr/bin/env node
2
- import{initializeFile as n,getDirectoryBy as e,readFileToJsonSync as t,pathJoin as s,waitingTips as i,typewrite as a,cursorAfterClear as o,cursorShow as r,colorLine as c,writeJsonFile as l,isEmptyDir as p,getNpmPkgInfo as u,runOtherCode as d,detectPackageManager as m,_p as g}from"a-node-tools";import{Dog as f}from"@qqi/log";import{isFalse as h,isUndefined as $,isBusinessEmptyString as A,isType as v,isArray as E,isEmptyArray as y,isEmptyString as _}from"a-type-of-js";import{Command as j}from"a-command";import{magentaPen as k,greenPen as b,brightRedPen as w,hexPen as R,brightBlackPen as C,cyanPen as T,brightGreenPen as P}from"color-pen";import{mkdirSync as O,writeFileSync as D,unlinkSync as N}from"node:fs";import{sleep as x,enArr as I}from"a-js-tools";import{userInfo as S}from"node:os";import{QQI as F}from"qqi";const G=new f({name:"create a npm",type:!1}),H=h(G.type),U=new j("create a npm");U.bind(["manager <-m> (包管理器)"]),U.run().isEnd(!0);const K=["husky","action","rollup","typescript","eslint","prettier"],M={manager:{value:"",accept:["npm","yarn","pnpm"]}},[q]=n();let L=e("package.json","file",q);G("获取到的地址为",L),$(L)&&(L=process.cwd());const B=t(s(L,"package.json"));G("获取到的数据为:",B);const W={cwd:"",range:"",pkgFile(...n){return s(this.cwd,...n)},rangeFile(...n){return s(this.range,...n)},get name(){return this.package.name},set name(n){this.childPkg?this.carryRange?(this.range=n.replace(/^@(.*)\/.*$/g,"$1"),this.cwd=n.replace(/@/,"").replace(/\//,"/packages/")):this.cwd=n.replace(/^.*\/(.*)$/g,"$1"):this.cwd=n,this.package.name=n},bin:0,local:{author:{name:"",email:"",url:""},dependencies:K},package:{name:"",version:"0.0.0",description:"",author:{name:"",email:"",url:""},dependencies:B?.dependencies||{},devDependencies:B?.devDependencies||{}},install:!1,carryRange:!1,childPkg:!1,buildDevDependencies(){const{dependencies:n}=this.local,{devDependencies:e,dependencies:t}=this.package;G("获取的本地的包信息",n),G("获取本地的");const s={"@qqi/check-version":e["@qqi/check-version"]||"^1.0.2","@qqi/rollup-external":e["@qqi/rollup-external"]||"^1.0.6","@rollup/plugin-commonjs":e["@rollup/plugin-commonjs"]||"^28.0.3","@rollup/plugin-json":e["@rollup/plugin-json"]||"^6.1.0","@rollup/plugin-node-resolve":e["@rollup/plugin-node-resolve"]||"^16.0.1","@rollup/plugin-terser":e["@rollup/plugin-terser"]||"^0.4.4","a-command":t["a-command"]||"^2.3.8","a-node-tools":t["a-node-tools"]||"^4.2.6",gvv:e.gvv||"^0.0.7",tslib:e.tslib||"^2.8.1",jja:e.jja||"^2.3.8",pjj:e.pjj||"^1.0.1",vjj:e.vjj||"^1.0.5",rollup:e.rollup||"^4.43.0","rollup-plugin-cleanup":e["rollup-plugin-cleanup"]||"^3.2.1","rollup-plugin-copy":e["rollup-plugin-copy"]||"^3.5.0"};return n.includes("husky")&&n.includes("prettier")&&(s.husky=e.husky||"^9.1.7",s["lint-staged"]=e["lint-staged"]||"^16.1.0"),n.includes("eslint")&&(s.eslint=e.eslint||"^9.28.0",s["eslint-plugin-jsdoc"]=e["eslint-plugin-jsdoc"]||"^51.0.1",s.globals=e.globals||"^16.2.0",s["@eslint/js"]=e["@eslint/js"]||"^9.28.0",n.includes("typescript")&&(s["typescript-eslint"]=e["typescript-eslint"]||"^8.34.0"),n.includes("prettier")&&(s["eslint-config-prettier"]=e["eslint-config-prettier"]||"^10.1.5")),n.includes("prettier")&&(s.prettier=e.prettier||"^3.5.3"),n.includes("typescript")&&(s["@types/node"]=e["@types/node"]||"^24.0.1",s["@rollup/plugin-typescript"]=e["@rollup/plugin-typescript"]||"^12.1.2",s.typescript=e.typescript||"^5.8.3"),G("构建的依赖图",s),s},commandParameters:M},Y=i({show:!1});function V(n,e){l(W.pkgFile(n),e)}async function z(n="好的,正在做退出前最后的工作,请稍等"){return await a(n),Y.destroyed(),o(),r(),c("终结线",!0),U.end()}function J(){const{manager:n}=M;return"pnpm"===n.value?"pnpm install --frozen-lockfile --prod=false":n.value+" ci"}async function Q(n){W.childPkg=W.carryRange=!1,n.startsWith("@")&&(W.childPkg=!0,await async function(n){const e=await U.selection({info:"检测到当前文件包含域",data:[{value:0,label:"子包模式",tip:`默认您是在${b(n.replace(/^@(.*)\/.*$/,"$1").concat("/packages"))}目录下`},{value:1,label:"嵌套模式",tip:`默认为您创建 ${b(n.replace(/@/,"").replace(/\//,"/packages/"))}`}]});if($(e))return await z();W.carryRange=Boolean(e)}(n));const e=n.startsWith("@")?W.carryRange?n.replace(/@/,"").replace(/\//,"/packages/"):n.replace(/^.*\/(.*)$/,"$1"):n;G("获取当前的目录",e);const t=p(e);if(0==t){const e=["更换为其他名称","直接退出"],t=await U.question({text:`当前目录下存在非空同名文件夹(${w(n)})`,tip:e});return!(!$(t)&&t!==e[1])&&await z()}Y.run({info:"正在检测 npm 是否有该同名包"});const s=H&&await u(n)||{data:void 0};if(Y.destroyed(),G("获取线上的 npm 包数据",s),s.data){const e=["更改为其他名称","忽视并继续","直接退出"],t=await U.question({text:R("#f63")`当前包名称(${k(n)})已经存在于 npm 中`,tip:e});if($(t)||t===e[2])return await z();if(t===e[0])return!1}return W.name=n,-1===t&&O(e,{recursive:!0}),!0}async function Z(n=!0){let e=n&&U.args.$original[0]||"";if(G("当前获取的输入名称",e),A(e)&&(e=await async function(){const n=await U.question({text:"您即将创建的包名",tip:"请使用空格/连字符(-)做分隔符",minLen:1,maxLen:212,verify:[{reg:/^[a-z@]/,info:"首字符应为小写英文字符或 @"},{reg:/[A-Z]/,info:"不应当有大些英文字符",inverse:!0},{reg:/^[^@].*\/.*/,info:`仅当为范围时才可以包含 ${k`/`} 符号`,inverse:!0},{reg:/.*\/.*\/.*/,info:`仅只能包含一个 ${k`/`} 符号`,inverse:!0},{reg:/^[@a-z].*@.*$/,info:`${k`@`} 仅允许在首位出现`,inverse:!0},{reg:/^[a-z0-9@/\-_.]+$/,info:`仅允许 ${k`-`}、${k`_`} 字符出现`}]});return $(n)?await z("您选择退出,清稍等"):n}()),e=e.trim().replace(/\s+/gm,"-"),A(e)||/^[^a-z@]/.test(e)||/^[a-z0-9][a-z0-9.\-_]*\/[a-z0-9.\-_]*$/.test(e)||e.length>212||/[A-Z]/gm.test(e)||/\s/.test(e)||/.*\/.*\/.*/.test(e)||/^[@a-z].*@.*$/gm.test(e)||/^[^a-z0-9@/\-_.]+$/gm.test(e))return await async function(){const n=["重新输入","退出"],e=await U.question({text:R("#f63")("您的输入为字符非法")+"重新输入或退出",tip:n});if($(e)||e===n[1])return await z()}(),await x(100),await Z(!1);const t=await Q(e);return h(t)?await Z(!1):void 0}function X(n){const e=Symbol("diy");return n.push({label:"手动输入值",value:e,tip:"使用其他输入名称"}),e}const nn=new F("create-a-npm");async function en(n,e){const{author:t}=W.local,s=t.name;let i=await U.selection({data:n,info:"请选择要使用的用户名"});if($(i))return await z();v(i,n=>n===e)&&(i=await async function(){const n=await U.question({text:"请输入您将配置的用户名",maxLen:16});return $(n)?await z():n}()),H||G(C("获取当前的用户名 "),i),G("是否执行写入",nn.available),W.package.author.name=t.name=i,nn.available&&s!==i&&(G("写入的值",W.local),nn.write("config",W.local))}function tn(n,e){if(!nn.available)return;const t=nn.read("config"),s=t?.author?.[e]??"";if(A(s))return;W.local.author[e]=s;let i=!1;for(const e in n){const t=n[e];if(t.value===s){t.tip+=b`(上次使用该值)`,i=!0,n.unshift(n.splice(Number(e),1)[0]);break}}i||n.unshift({label:`${s}`,value:s,tip:"上次使用"})}async function sn(){const n=[];await async function(n){const e=await d("git config user.name");if(e.success){const t=e.data?.replace(/\n$/,"")||"";A(t)||n.push({label:`${t}`,value:t,tip:"由 git 全局配置读取"})}}(n),function(n){const e=process.env.USER??process.env.USERNAME??S().username;n.push({label:`${e}`,value:e,tip:"设备用户名"})}(n);const e=X(n);tn(n,"name"),await en(n,e)}async function an(n,e){const{author:t}=W.local,s=t.email;let i=await U.selection({data:n,info:"请选择您的通讯邮箱"});if($(i))return await z();v(i,n=>n===e)&&(i=await async function(){const n=await U.question({text:"请输入您将配置的邮箱",maxLen:50,minLen:5,verify:[{reg:/^[^\s@]+@[^\s@]+\.[^\s@]{2,}$/,info:"需符合邮箱基本模式"}]});return $(n)?await z():n}()),H||G(C("获取当前的用户名 "),i),G("是否执行写入",nn.available),W.package.author.email=t.email=i,nn.available&&s!==i&&(G("写入的值",W.local),nn.write("config",W.local))}async function on(){const n=[];await async function(n){const e=await d("git config user.email");if(!e.success)return await z("获取本地的 git config user.email 出错\n".concat(e.error||e.data));const t=e.data.replace(/\n$/,"")||"";A(t)||n.push({value:t,tip:"该值从 git 全局配置读取",label:t})}(n),function(n){const{author:e}=W.local;if(A(e.name))return;const t=`${e.name.replace(/\s+/g,"_")}@outlook.com`;n.push({value:t,label:t,tip:"该值由 name 值合成而来"})}(n),tn(n,"email");const e=X(n);await an(n,e)}async function rn(n,e){const{author:t}=W.local,s=t.url;let i=await U.selection({data:n,info:"请配置您的个人网站"});if($(i))return await z();v(i,n=>n===e)&&(i=await async function(){const n=await U.question({text:"请输入您将配置的网址",maxLen:50,minLen:5,verify:[{reg:/^https?:\/{2}.+/,info:"需符合网址基本模式"}]});return $(n)?await z():n}()),H||G(C("获取当前的网址 "),i),G("是否执行写入",nn.available),W.package.author.url=t.url=i,nn.available&&s!==i&&(G("写入的值",W.local),nn.write("config",W.local))}async function cn(){const n=[];!function(n){const{author:e}=W.local;if(A(e.name))return;const t=`${e.name.replace(/\s+/g,"_")}.github.io`;n.push({value:t,label:t,tip:"该值由 name 值合成而来"})}(n),tn(n,"url");const e=X(n);await rn(n,e)}async function ln(){const n=await async function(){const n=["name","email","url"],{local:e}=W;if(!nn.available)return n;const t=nn.read("config");if($(t?.author))return n;E(t?.dependencies)&&(e.dependencies=t.dependencies);const{author:s}=t,i=Object.keys(s).filter(n=>!A(s[n])&&(e.author[n]=s[n])&&!0).map(n=>({value:n,label:`${n} : ${s[n]}`,checked:!0}));if(y(i))return n;const a=await U.selection({info:"以下为上次使用配置,选中的项将跳过配置",data:i,kind:"check"});return $(a)?await z():(G("选项的值",a),I.difference(n,a))}();G("获取需要更改的项",n),n.includes("name")&&await sn(),n.includes("email")&&await on(),n.includes("url")&&await cn(),await async function(){const n=await U.selection({info:"请选择开发模式",data:[{value:0,label:"仅是可用库",tip:"当前仅是使用的库,譬如:"+b`a-js-tools`},{value:1,label:"仅是可执行库",tip:"当前仅包含可执行内容,譬如:"+b`jja`},{value:2,label:"库 + bin",tip:"即包含可执行又包含可导出使用内容,譬如:"+b`qqi`}]});$(n)||(W.bin=n)}(),await async function(){const{local:n}=W,e=n.dependencies,t=[{value:"rollup",tip:"该项为必须项",label:"打包工具 rollup",checked:!0,disable:!0},{value:"typescript",tip:"如果使用 typescript 建议使用该项",label:"使用 "+b`typescript`,checked:e.includes("typescript")},...[["eslint",`使用代码问题工具 ${b`eslint`}`],["prettier",`格式化代码 ${b`prettier`}`],["husky",`git 提交 hook 管理 ${b`husky`}`],["action",`CI/CD 使用自动化构建、发布 ${b`github action`} `]].map(n=>({value:n[0],label:n[1],checked:e.includes(n[0])}))],s=await U.selection({data:t,kind:"check",info:"请选择要使用的辅助功能"});G("用户选择的依赖",s),$(s)?n.dependencies=K:(n.dependencies=s,nn.available&&(G("执行储存的数据",n),nn.write("config",n)))}(),await async function(){const n=["安装","跳过"],e=await U.question({text:"是否安装依赖",tip:n});$(e)||e===n[1]||(W.install=!0)}()}function pn(){const{dependencies:n}=W.local,e="++++",t=n.includes("prettier"),s=n.includes("typescript");return`import globals from 'globals';\nimport pluginJs from '@eslint/js';\n${t?"import tseslint from 'typescript-eslint';":e}\n${s?"import eslintConfigPrettier from 'eslint-config-prettier';":e}\nimport jsdocPlugin from 'eslint-plugin-jsdoc';\n\nexport default [\n { files: ['**/*.{js,mjs,cjs${s?".ts":""}}'] },\n { languageOptions: { globals: globals.browser } },\n pluginJs.configs.recommended,\n ${s?"...tseslint.configs.recommended,":e}\n\n {\n plugins: {\n jsdoc: jsdocPlugin,\n },\n rules: {\n // 基础规则\n 'jsdoc/check-alignment': 'error',\n 'jsdoc/check-param-names': 'error',\n 'jsdoc/check-tag-names': [\n 'error',\n {\n // 配置允许的标签\n definedTags: ['packageDocumentation'],\n },\n ],\n 'jsdoc/check-types': 'error',\n\n ${s?"\n // TypeScript 适配规则\n 'jsdoc/no-types': 'error',\n 'jsdoc/require-param-type': 'off', // 使用 TS 类型\n 'jsdoc/require-returns-type': 'off', // 使用 TS 类型":""}\n\n // 文档质量规则\n 'jsdoc/require-description': [\n 'error',\n {\n contexts: ['TSInterfaceDeclaration', 'TSTypeAliasDeclaration'],\n },\n ],\n 'jsdoc/require-jsdoc': [\n 'warn',\n {\n require: {\n FunctionDeclaration: true,\n MethodDefinition: true,\n ClassDeclaration: true,\n },\n },\n ],\n },\n },\n ${t?"eslintConfigPrettier,":e}\n];\n`.replace(/\+{3,}\n?/gm,"")}function un(){V("tsconfig.base.json",{compilerOptions:{baseUrl:".",jsx:"preserve",strict:!0,target:"ESNext",module:"ESNext",skipLibCheck:!0,esModuleInterop:!0,moduleResolution:"Bundler",allowSyntheticDefaultImports:!0,isolatedModules:!0,lib:["ESNext","DOM"],sourceMap:!1}}),V("tsconfig.json",{extends:"./tsconfig.base.json",include:["index.ts","src/**/*.ts","**.d.ts","test/**/*.ts"],exclude:["node_modules","dist"]}),V("tsconfig.types.json",{extends:"./tsconfig.base.json",compilerOptions:{emitDeclarationOnly:!0,declaration:!0,declarationDir:"dist/"},exclude:["node_modules","test","dist","eg"]})}function dn(){const{author:n}=W.local,{name:e,url:t}=n,s=W.name.replace(/^@/,""),i=s.split("/");D(W.pkgFile("README.md"),`# ${W.name}\n\r\n[![version](<https://img.shields.io/npm/v/${W.name}.svg?logo=npm&logoColor=rgb(0,0,0)&label=版本号&labelColor=rgb(73,73,228)&color=rgb(0,0,0)>)](https://www.npmjs.com/package/${W.name}) [![issues 提交](<https://img.shields.io/badge/issues-提交-rgb(255,0,63)?logo=github>)](https://github.com/${e.replace(/\s+/g,"_")}/${i[0]}/issues)\n \n## 文档地址\n\n参看 [${t}/${s}](${t}/${s})`)}const mn=()=>{const n=(new Date).getFullYear(),{name:e}=W.local.author;return`# MIT License\n \nCopyright (c) <${n}> <${e}>\n\nPermission to use, copy, modify, and/or distribute this software for any \npurpose with or without fee is hereby granted, provided that the above \ncopyright notice and this permission notice appear in all copies.\n\nTHE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES \nWITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF \nMERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR \nANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES \nWHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN \nACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF \nOR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n\n# MIT 许可证\n\n版权所有 (c) [${n}] [${e}]\n\n特此免费授予任何获得本软件及相关文档文件(以下简称“软件”)副本的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、再许可和/或出售该软件副本的权利,并允许向其提供该软件的人这样做,但须遵守以下条件:\n\n上述版权声明和本许可声明应包含在所有副本或软件的重要部分中。\n\n软件按“原样”提供,不附带任何形式的明示或暗示的保证,包括但不限于适销性、特定用途适用性和不侵权的保证。在任何情况下,作者或版权持有人均不对因合同、侵权或其他方式引起的任何索赔、损害或其他责任负责,无论是在与软件或软件的使用或其他交易有关的任何诉讼中。`};function gn(){D(W.pkgFile("LICENSE"),mn())}function fn(){const n=(()=>{const n=new Date;return`${n.getFullYear()}-${n.getMonth()+1}-${n.getDate()}`})();D(W.pkgFile("CHANGELOG.md"),`# 更新日志 📔\n\n## v0.0.0 (${n})\n`)}function hn(){const{dependencies:n}=W.local,e=n.includes("typescript")?"ts":"js";O(W.pkgFile("eg"),{recursive:!0}),D(W.pkgFile("eg/index."+e),"import { sayHello } from '../index';\n sayHello(); \n")}function $n(){const{dependencies:n}=W.local,e=n.includes("typescript");O(W.pkgFile("src"),{recursive:!0}),D(W.pkgFile("index."+(e?"ts":"js")),(0!==W.bin?"#!/usr/bin/env node\n\n":"")+"export { sayHello } from './src/index';"),D(W.pkgFile("src/index."+(e?"ts":"js")),"\n \rexport function sayHello() {\n console.log('哈喽');\n }\n ")}function An(){O(s(W.pkgFile("scripts")),{recursive:!0});const{author:n}=W.local,e=W.name.replace(/^@/,"").split("/"),t=e[0];D(W.pkgFile("scripts/clean-package-json.js"),`\nimport {\n pathJoin,\n readFileToJsonSync,\n getDirectoryBy,\n writeJsonFile,\n} from 'a-node-tools';\n\nlet packageJson = readFileToJsonSync('./package.json');\n\n['scripts', 'devDependencies', 'lint-staged', 'private'].forEach(\n key => delete packageJson[key],\n);\n\npackageJson = {\n main: 'index.cjs',\n module: 'index.mjs',\n types: 'index.d.ts',\n ...packageJson,\n publishConfig: {\n access: 'public',\n registry: 'https://registry.npmjs.org/',\n },\n files: ['index.d.ts', 'index.mjs', 'index.cjs', 'src'],\n exports: {\n '.': {\n import: {\n default: './index.mjs',\n types: './index.d.ts',\n },\n require: {\n default: './index.cjs',\n types: './index.d.ts',\n },\n },\n },\n repository: {\n type: 'git',\n url: 'git+https://github.com/${n.name}/${t}.git',\n },\n author: {\n name: '${n.name}',\n email: '${n.email}',\n url: '${n.url}',\n },\n browserslist: ['node>=18.0.0'],\n engines: {\n node: '>=18.0.0',\n },\n keywords: ['${t}', '${e[0]}'],\n homepage: '${n.url}',\n bugs: {\n url: 'https://github.com/${n.name}/${t}/issues',\n email: '${n.email}',\n },${0!==W.bin?`\n bin: {\n ${W.name} : './bin.mjs',\n },\n `:""}\n};\n\n{\n const distPath = getDirectoryBy('dist', 'directory');\n\n const distPackagePath = pathJoin(distPath, './dist/package.json');\n\n writeJsonFile(distPackagePath, packageJson);\n}\n`)}function vn(){const{dependencies:n}=W.local;n.includes("action")&&(function(){const{manager:n}=M,e=".github/workflows";O(W.pkgFile(e),{recursive:!0}),D(W.pkgFile(e,"发布.yml"),`name: 发布到 npm\non:\n push:\n branches: '*'\n workflow_dispatch: # 手动触发\n inputs:\n version:\n description: '触发原因(选填)'\n required: false\n default: '手动触发'\n type: string\n ref:\n description: '发布的分支(选填)'\n required: false\n default: ''\n type: string\n\njobs:\n pub:\n # 在提交的代码包含 \`version\` 字样时才运行该动作\n # 或者手动触发\n name: |\n 发布到 npm\n runs-on: ubuntu-latest\n permissions:\n packages: write\n contents: write\n id-token: write\n # 复合条件判断(自动触发检查提交信息,手动触发直接放行)\n # startsWith(github.event.head_commit.message, 'version')\n # contains(github.event.inputs.version, '手动触发')\n # endsWith(github.event.head_commit.message, 'version')\n if: |\n (github.event_name == 'push' && startsWith(github.event.head_commit.message, 'version')) ||\n github.event_name == 'workflow_dispatch'\n steps:\n - name: 代码检出\n uses: actions/checkout@v4\n with:\n ref: \${{ github.event.inputs.ref || github.ref_name }}\n fetch-depth: 1\n\n - name: 初始化 Node 并设定 Node 版本\n uses: actions/setup-node@v4\n with:\n node-version: 22.x\n registry-url: https://registry.npmjs.org\n ${"pnpm"===n.value?"\n - name: pnpm 安装\n uses: pnpm/action-setup@v2\n with:\n version: 10\n run_install: false\n\n - name: 缓存 pnpm\n id: pnpm-store\n run: echo \"STORE_PATH=$(pnpm store path)\" >> $GITHUB_OUTPUT\n\n - name: Cache pnpm store\n uses: actions/cache@v4\n with:\n path: ${{ steps.pnpm-store.outputs.STORE_PATH }}\n key: ${{ runner.os }}-pnpm-store-${{ hashFiles('pnpm-lock.yaml') }}\n restore-keys: |\n ${{ runner.os }}-pnpm-store-\n ":"yarn"===n.value?"\n - name: yarn 安装\n uses: actions/setup-yarn@v4\n with:\n version: '1.22' \n - name: 获取 yarn 缓存路径\n id: yarn-cache-path\n run: echo \"CACHE_PATH=$(yarn cache dir)\" >> $GITHUB_OUTPUT # 获取 Yarn 全局环衬路径\n \n - name: 缓存 Yarn 依赖\n uses: actions/cache@v4\n with: \n path: ${{ steps.yarn-cache-path.outputs.CACHE_PATH }} # 缓存 Yarn 全局缓存目录\n key: ${{ runner.os }}-yarn-cache-${{ hashFiles('yarn.lock) }} # 基于 yarn.lock 哈希值生成唯一的 key\n restore-keys: |\n ${{ runner.os }}-yarn-cache # 缓存未命中时,按前缀恢复最近的缓存 \n ":""}\n \n - name: 发布到 npm\n env:\n NODE_AUTH_TOKEN: \${{secrets.NPM_TOKEN}}\n run: |\n chmod +x ./scripts/pub.sh\n ./scripts/pub.sh\n`)}(),function(){const{manager:n}=M;O(s(W.pkgFile("scripts")),{recursive:!0}),D(W.pkgFile("scripts","pub.sh"),`#!/bin/bash\n\nCHECK_VERSION="@qqi/check-version"\n# 安装 \ninstall_check_version() {\n if ! npm list -g --depth=0 | grep -q " \${CHECK_VERSION}"; then \n echo "当前未全局安装 '\${CHECK_VERSION}',即将进行安装"\n npm install \${CHECK_VERSION} --global\n else \n echo "包 \${CHECK_VERSION} 已全局安装"\n fi\n}\n\ntag=""\ninstall_check_version\nif ! tag=$(npx "\${CHECK_VERSION}" c=. 2>&1); then\n echo "未通过版本校验:$tag"\n exit 0\nfi\necho "获取🉐发布标签为 \${tag}"\n# 依赖安装\n${J()}\n# 构建项目\nif ! ${n.value} run build; then \n echo "构建失败" \n exit 0\nfi\n\n# 切换到构建目录\nif [ ! -d "dist" ]; then \n echo "未找到 dist 构建码"\n exit 0\nfi\n\n# 确保脚本在遇见错误时立即退出\nset -e\n\ncd "dist"\necho "开始发布 npm 包 \${tag} 版本"\nif ! ${n.value} publish --provenance --access public --tag "\${tag}" --no-git-checks; then\n echo "发布失败" \n exit 1\nfi\necho "🚀🚀 发布成功,完结 🎉🎉 撒花 🎉🎉"\n\n`)}()),n.includes("typescript")&&un(),function(){const{dependencies:n}=W.local,e=n.includes("typescript");D(W.pkgFile("rollup.config.js"),`${e?"import typescript from '@rollup/plugin-typescript'":""};\nimport resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\nimport json from '@rollup/plugin-json';\nimport cleanup from 'rollup-plugin-cleanup';\nimport copy from 'rollup-plugin-copy';\nimport { external } from '@qqi/rollup-external';\n\nexport default {\n input: './index.${e?"ts":"js"}',\n output: ${1!==W.bin?"[\n {\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: true,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },\n {\n format: 'cjs',\n entryFileNames: '[name].cjs',\n preserveModules: true,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },\n ],":"{\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: false,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },"}\n // 配置需要排除或包含的包\n external: external(),\n plugins: [\n resolve(),\n commonjs(),\n json(),${e?"typescript(),":""}\n cleanup(),\n copy({\n targets: [\n { src: 'README.md', dest: 'dist' },\n { src: 'LICENSE', dest: 'dist' },\n ],\n }),\n ],\n};`)}(),function(){const{dependencies:n}=W.local,e=n.includes("typescript");D(W.pkgFile("rollup.config.eg.js"),`${e?"import typescript from '@rollup/plugin-typescript';":""}\nimport resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\nimport json from '@rollup/plugin-json';\nimport cleanup from 'rollup-plugin-cleanup';\nimport { external } from '@qqi/rollup-external';\n\n/** 生成 npm 文件的打包配置文件 */\nexport default {\n input: './eg/index.${e?"ts":"js"}',\n output: {\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: false,\n sourcemap: false,\n exports: 'named',\n dir: '.eg/',\n },\n // 配置需要排除的包\n external: external({ ignore: ['node:'] }),\n plugins: [\n resolve(),\n commonjs(),\n // 可打包 json 内容\n json(),\n ${e?"typescript(),":""}\n // 去除无用代码\n cleanup(),\n ],\n};\n `)}(),dn(),function(){const{manager:n}=M,{dependencies:e}=W.local,t=e.includes("typescript"),s={name:W.name,version:"0.0.0",type:"module",private:!0,description:"",scripts:{b:"rollup --config rollup.config.js"+(1!==W.bin&&t?" && tsc -p tsconfig.types.json":""),build:`jja cls rm dist && ${n.value} run b && ${n.value} run clean:package`,"clean:package":"node scripts/clean-package-json.js",diff:"jja pkg --diff=官方",prepublishOnly:"pjj",push:"gvv","push:version":"gvv",test:"jja rm .eg && rollup --config rollup.config.eg.js && node .eg/index.mjs",vjj:"vjj"},license:"MIT",devDependencies:W.buildDevDependencies()};e.includes("husky")&&e.includes("prettier")&&(s["lint-staged"]={"*.{js,ts}":["prettier --write"]},s.scripts.prepare="husky"),e.includes("eslint")&&(s.scripts.eslint="jja cls && eslint packages"),e.includes("prettier")&&(s.scripts.prettier="jja cls && prettier . --write"),V("package.json",s)}(),gn(),$n(),n.includes("eslint")&&D(W.pkgFile("eslint.config.js"),pn()),n.includes("prettier")&&(D(W.pkgFile(".prettierignore"),"\nnode_modules\ndist\n*.tgz\ncoverage\n.DS_Store\n.eg"),D(W.pkgFile(".prettierrc"),'{\n "printWidth": 80,\n "tabWidth": 2,\n "useTabs": false,\n "semi": true,\n "singleQuote": true,\n "trailingComma": "all",\n "bracketSpacing": true,\n "arrowParens": "avoid",\n "endOfLine": "auto"\n}')),D(W.pkgFile(".markdownlint.json"),'{\n "MD024": false,\n "MD013": false\n}\n'),fn(),D(W.pkgFile(".gitignore"),"\nnode_modules\ndist\n*.tgz\ncoverage\n.DS_Store\n.eg"),An(),hn()}function En(){O(W.rangeFile("scripts"),{recursive:!0}),D(W.rangeFile("scripts/check_version_install.sh"),'#!/bin/bash\n\ninstall_check_version() {\n # 在子项目的直接\n if ! npm list -g --depth=0 | grep -q " ${CHECK_VERSION}"; then \n echo "当前未全局安装 \'${CHECK_VERSION}\',即将进行安装"\n npm install ${CHECK_VERSION} --global\n else \n echo "包 ${CHECK_VERSION} 已全局安装"\n fi\n}'),D(W.rangeFile("scripts/detect_changes.sh"),'#!/bin/bash\n\n# 获取上一次提交的 SHA\nPREVIOUS_COMMIT=$(git rev-parse HEAD^)\nCURRENT_COMMIT=$(git rev-parse HEAD)\n\n# 获取变更的文件列表\nCHANGED_FILES=$(git diff --name-only $PREVIOUS_COMMIT $CURRENT_COMMIT)\n\n# 初始化变更的包数组\nCHANGED_PACKAGE_ARRAY=()\n\necho "开始循环调用验证函数"\n\nmain() {\n # 遍历变更的文件,找出变更的 packages 下的直接子文件夹\n for file in $CHANGED_FILES; do\n if [[ $file == packages/* ]]; then\n PACKAGE_DIR=$(echo $file | cut -d\'/\' -f2)\n # 如果其不存在于数组之中\n if [[ ! " ${CHANGED_PACKAGE_ARRAY[@]} " =~ " ${PACKAGE_DIR} " ]]; then\n CHANGED_PACKAGE_ARRAY+=("$PACKAGE_DIR") # 文件变更数组添加元素\n fi\n fi\n done\n \n # 将数组转为逗号分隔的字符串\n CHANGED_PACKAGES=$(IFS=,; echo "${CHANGED_PACKAGE_ARRAY[*]}")\n \n # 将变更的数据输出到步骤输出值中\n # echo "update_packages=$CHANGED_PACKAGES" >> $GITHUB_OUTPUT \n # 将变更的包字符串输出到环境变量\n echo "update_packages=$CHANGED_PACKAGES" >> $GITHUB_ENV\n \n printf "\\e[31m检测文件变更的包信息处理完成 \\e[m$CHANGED_PACKAGES \\n"\n}\necho "准备好了么"\nmain\necho "哈哈,执行 🎊 🎊 🎊"\n'),function(){const{manager:n}=M;D(W.rangeFile("scripts/pub.sh"),`#!/bin/bash\n\n# 获取环境变量中的变更包字符串\nUPDATE_PACKAGES=$UPDATE_PACKAGES\n# 执行根路径\nREPO_ROOT=$REPO_ROOT\n# 发布异常的包\nPUB_ERROR=()\nCHECK_VERSION="@qqi/check-version"\n# 读取版本检测是否可用\nsource ./scripts/check_version_install.sh \necho "工作根路径 $REPO_ROOT"\nPACKAGES_DIR="\${REPO_ROOT}/packages"\n# 将字符串转为数组\nIFS=',' read -r -a PACKAGE_ARRAY <<< "$UPDATE_PACKAGES"\n \nupdate_version() {\n local input="$1"\n local NAME=$(echo "\${input//-/ }" | tr -s ' ') # 替换 - 为空格并删除重复的空格\n local CWD="\${PACKAGES_DIR}/$input"\n\n local tag=""\n cd $REPO_ROOT # 每次需要手动更新到根下才能正确的校验版本号\n if ! tag=$(npx "\${CHECK_VERSION}" n=\${input} 2>&1); then\n echo "未通过版本校验:$tag"\n return 0 \n fi\n echo "获取 \${NAME} 的发布标签为 \${tag}"\n\n if [ ! -d "$CWD" ]; then \n echo "进入项目 $NAME 故障,路径为 \${CWD}"\n return 0\n fi\n cd "$CWD"\n\n # 依赖安装 \n ${J()}\n if ! ${n.value} run build; then \n echo "构建 $NAME 失败" \n PUB_ERROR+=("$input")\n return 0\n fi\n local BUILD_DIST="\${CWD}/dist"\n if [ ! -d "\${BUILD_DIST}" ]; then\n echo "未找到 $NAME dist 构建:\${BUILD_DIST}"\n PUB_ERROR+=("$input")\n return 0\n fi\n cd "\${BUILD_DIST}" \n \n echo "开始发布 $NAME npm 包 \${tag} 版本"\n if ! ${n.value} publish --provenance --access public --tag "\${tag}" --no-git-checks; then\n echo "💥💥💥 $NAME 发布到 npm 💥💥💥"\n PUB_ERROR+=("$input")\n else \n echo "🪧 $package 发布终结 🫧🫧🫧🫧🫧🫧"\n fi\n}\n\nmain() {\n # 校验版本可用情况\n if [ ! -d "$PACKAGES_DIR" ]; then\n echo "没有找到 \${PACKAGES_DIR}"\n exit 0\n fi\n echo "☁️ 来"\n install_check_version # 检查版本包安装校验\n # 遍历变更的包数组,进行 npm 包推送\n # "\${ARR[@]}" 引用数组所有元素\n # "\${!ARR[@]}" 引用数组所有索引 \${ARR[$index]}\n # "\${#ARR[@]}" 数组长度 \n for package in "\${PACKAGE_ARRAY[@]}"; do\n echo "当前执行的推送为 $package"\n update_version "$package"\n done\n\n}\n\necho "准备好了么"\nmain\nif [ \${#PUB_ERROR[@]} -gt 0 ]; then \n echo "发布包 \${PUB_ERROR[@]} 异常 "\nelse \n echo "所有发布均已成功:\${PACKAGE_ARRAY[@]}"\n echo "🚀🚀 发布成功,完结 🎉🎉 撒花 🎉🎉"\nfi`)}(),D(W.rangeFile("scripts/workflow_dispatch.sh"),'#!/bin/bash\n\n# 从环境变量中获取手动触发要更新的包数据\nINPUT_PACKAGE=$INPUT_PACKAGE\n# 初始化变更的包数组\nCHANGED_PACKAGE_ARRAY=()\n# 初始化最终要更新的包的数组\nUPDATE_PACKAGE_ARRAY=()\n\n# 读取 packages 下直接子文件夹名并放入到数组 CHANGED_PACKAGE_ARRAY 中 \nwhile IFS= read -r PACKAGE_DIR; do \n PACKAGE_DIR=$(echo "${PACKAGE_DIR// /?}" | tr -s \'?\') # 保护我方空格\n CHANGED_PACKAGE_ARRAY+=("$PACKAGE_DIR")\ndone < <(find packages -mindepth 1 -maxdepth 1 -type d -exec basename {} \\;)\n\ncheck_version() {\n local input="$1"\n local NAME=$(echo "${input//-/ }" | tr -s \' \') # 替换 - 为空格并删除重复的空白字符\n echo "输入:${input}"\n echo "使用:${NAME}"\n \n # 该包是否由手动触发选择\n if [ "$INPUT_PACKAGE" = "all" ] || [ "$INPUT_PACKAGE" = "${input}" ]; then\n echo "手动触发发布且包含 ${NAME}"\n UPDATE_PACKAGE_ARRAY+=("$input")\n return 0\n else\n echo "该包 ${input} 未在手动触发选择"\n return 0\n fi\n}\n\n\nmain() {\n for PACKAGE_NAME in ${CHANGED_PACKAGE_ARRAY[@]}; do \n check_version "$PACKAGE_NAME"\n done\n\n echo "校验版本数据完毕 ${UPDATE_PACKAGE_ARRAY}"\n\n # 将数组转为逗号分隔的字符串\n UPDATE_PACKAGES=$(IFS=,; echo "${UPDATE_PACKAGE_ARRAY[*]}")\n\n # 将变更的包字符串输出到环境变量\n # echo "update_packages=$UPDATE_PACKAGES" >> $GITHUB_OUTPUT \n echo "update_packages=$UPDATE_PACKAGES" >> $GITHUB_ENV\n\n printf "\\e[38;5;164m手动触发的包为 \\e[m$UPDATE_PACKAGES \\n"\n}\necho "准备好了么"\nmain\necho "哈哈,执行 🎊 🎊 🎊"\n')}function yn(){const{dependencies:n}=W.local;n.includes("action")&&(!function(){const{manager:n}=M,e=".github/workflows";O(W.rangeFile(e),{recursive:!0}),D(W.rangeFile(e,"发布.yml"),`name: 发布到 npm\non:\n push:\n branches: '*'\n paths:\n - 'packages/**' # 主包更新\n - 'package.json' # 全局依赖\n\n workflow_dispatch: # 手动触发\n inputs:\n version:\n description: '触发原因(选填)'\n required: false\n default: '手动触发'\n ref:\n description: '分支(选填)'\n required: false\n default: ''\n type: string\n package:\n description: '子包'\n required: true\n type: choice\n options:\n - core\n - all\n default: 'all'\n\njobs:\n pub:\n # 在提交的代码包含 \`version\` 字样时才运行该动作\n # 或者手动触发\n name: |\n 发布到 npm\n runs-on: ubuntu-latest\n permissions:\n packages: write\n contents: write\n id-token: write\n # 复合条件判断(自动触发检查提交信息,手动触发直接放行)\n # contains 函数\n # startsWith 函数\n # endsWith 函数\n if: |\n (github.event_name == 'push' && startsWith(github.event.head_commit.message, 'version')) ||\n github.event_name == 'workflow_dispatch'\n steps:\n - name: 代码检出\n uses: actions/checkout@v4\n with:\n ref: \${{ github.event.inputs.ref || github.ref_name }}\n fetch-depth: 0\n\n - name: 初始化 Node 并设定 Node 版本\n uses: actions/setup-node@v4\n with:\n node-version: 22.x\n registry-url: https://registry.npmjs.org\n \n ${"pnpm"===n.value?"\n - name: pnpm 安装\n uses: pnpm/action-setup@v2\n with:\n version: 10\n run_install: false\n\n - name: 缓存 pnpm\n id: pnpm-store\n run: echo \"STORE_PATH=$(pnpm store path)\" >> $GITHUB_OUTPUT\n\n - name: Cache pnpm store\n uses: actions/cache@v4\n with:\n path: ${{ steps.pnpm-store.outputs.STORE_PATH }}\n key: ${{ runner.os }}-pnpm-store-${{ hashFiles('pnpm-lock.yaml') }}\n restore-keys: |\n ${{ runner.os }}-pnpm-store-\n ":"yarn"===n.value?"\n - name: yarn 安装\n uses: actions/setup-yarn@v4\n with:\n version: '1.22' \n - name: 获取 yarn 缓存路径\n id: yarn-cache-path\n run: echo \"CACHE_PATH=$(yarn cache dir)\" >> $GITHUB_OUTPUT # 获取 Yarn 全局环衬路径\n \n - name: 缓存 Yarn 依赖\n uses: actions/cache@v4\n with: \n path: ${{ steps.yarn-cache-path.outputs.CACHE_PATH }} # 缓存 Yarn 全局缓存目录\n key: ${{ runner.os }}-yarn-cache-${{ hashFiles('yarn.lock) }} # 基于 yarn.lock 哈希值生成唯一的 key\n restore-keys: |\n ${{ runner.os }}-yarn-cache # 缓存未命中时,按前缀恢复最近的缓存 \n ":""}\n \n - name: 安装全局依赖\n run: |\n ${J()}\n cd scripts\n chmod +x detect_changes.sh workflow_dispatch.sh pub.sh\n # chmod +x scripts/detect_changes.sh\n # chmod +x scripts/workflow_dispatch.sh\n # chmod +x scripts/pub.sh\n\n - name: 检测子包变更情况(推送代码时触发)\n if: github.event_name == 'push'\n id: detect-changes\n run: |\n ./scripts/detect_changes.sh\n\n - name: 检测子包变更情况(手动触发时触发)\n if: github.event_name == 'workflow_dispatch'\n id: workflow-changes\n env:\n INPUT_PACKAGE: \${{ github.event.inputs.package }}\n run: |\n ./scripts/workflow_dispatch.sh\n\n - name: 设置工作根路径\n run: |\n echo "REPO_ROOT=$(pwd)" >> $GITHUB_ENV\n\n - name: 发布到 npm\n if: \${{ env.update_packages && env.update_packages != '' }}\n env:\n NODE_AUTH_TOKEN: \${{ secrets.NPM_TOKEN }}\n UPDATE_PACKAGES: \${{ env.update_packages }}\n REPO_ROOT: \${{ env.REPO_ROOT }}\n run: |\n ./scripts/pub.sh\n\n `)}(),En()),n.includes("typescript")&&(D(W.rangeFile("tsconfig.json"),'{\n "extends": "./tsconfig.base.json",\n "include": [\n "packages/**/index.ts",\n "packages/**/src/**/*.ts",\n "packages/**/eg/**/*.ts"\n ],\n "exclude": [\n "node_modules",\n "packages/**/node_modules",\n "packages/**/**/*.test.ts",\n "jest.setup.ts"\n ]\n}\n'),D(W.rangeFile("tsconfig.base.json"),'{\n "compilerOptions": {\n "baseUrl": ".",\n "jsx": "preserve",\n "strict": false,\n "target": "ESNext",\n "module": "ESNext",\n "skipLibCheck": true,\n "esModuleInterop": true,\n "moduleResolution": "Bundler",\n "allowSyntheticDefaultImports": true,\n "isolatedModules": true,\n "lib": ["ESNext", "DOM"],\n "sourceMap": false\n }\n}\n')),D(W.rangeFile("README.md"),"# 你会更改这里的内容的\n \n毕竟,我猜你有很多话要说\n记录下来,哪怕不会有人看见\n "),function(){const{dependencies:n}=W.local,e={name:W.name.replace(/^@(.*)\/.*$/,"$1")+"-root",version:"0.0.0",type:"module",private:!0,description:"改了这里。毕竟,你有自己的话要说",scripts:{diff:"jja pkg --diff=官方",vjj:"vjj",push:"gvv","push:version":"gvv",prepublishOnly:"pjj"},devDependencies:W.buildDevDependencies()};n.includes("husky")&&n.includes("prettier")&&(e["lint-staged"]={"*.{js,ts}":["prettier --write"]},e.scripts.prepare="husky"),n.includes("eslint")&&(e.scripts.eslint="jja cls && eslint packages"),n.includes("prettier")&&(e.scripts.prettier="jja cls && prettier . --write"),l(W.rangeFile("package.json"),e)}(),D(W.rangeFile("LICENSE"),mn()),n.includes("eslint")&&D(W.rangeFile("eslint.config.js"),pn()),n.includes("prettier")&&(D(W.rangeFile(".prettierrc"),'{\n "printWidth": 80,\n "tabWidth": 2,\n "useTabs": false,\n "semi": true,\n "singleQuote": true,\n "trailingComma": "all",\n "bracketSpacing": true,\n "arrowParens": "avoid",\n "endOfLine": "auto"\n}'),D(W.rangeFile(".prettierignore"),"\nnode_modules\ndist\n*.tgz\ncoverage\n.DS_Store\n.eg")),D(W.rangeFile(".markdownlint.json"),'{\n "MD024": false,\n "MD013": false\n}\n'),D(W.rangeFile(".gitignore"),"\nnode_modules\ndist\n*.tgz\ncoverage\n.DS_Store\n.eg")}function _n(){const{dependencies:n}=W.local;n.includes("typescript")&&(1!==W.bin&&D(W.pkgFile("tsconfig.types.json"),'/** 该文件打包前使用 */\n{\n "extends": "../../tsconfig.base.json",\n "compilerOptions": {\n "emitDeclarationOnly": true,\n "declaration": true,\n "declarationDir": "dist/"\n // "types": ["node"],\n },\n "exclude": ["node_modules", "dist", "**/*.test.ts", "eg", "jest.setup.ts"]\n}\n'),D(W.pkgFile("tsconfig.rollup.json"),'{\n "extends": "./tsconfig.types.json",\n "compilerOptions": {\n "declarationDir": null,\n "declaration": false\n },\n "include": ["eg", "eg/*.ts", "src/**/*.ts", "./index.ts"],\n "exclude": ["node_modules", "**/*.test.ts"]\n}\n')),function(){const{dependencies:n}=W.local,e=n.includes("typescript");D(W.pkgFile("rollup.config.js"),`${e?"import typescript from '@rollup/plugin-typescript';":"+++++"}\nimport resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\nimport json from '@rollup/plugin-json';\nimport cleanup from 'rollup-plugin-cleanup';\nimport copy from 'rollup-plugin-copy';\nimport { external } from '@qqi/rollup-external';\n\nexport default {\n input: './index.${e?"ts":"js"}',\n output: \n ${1!==W.bin?"[{\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: true,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },{\n format: 'cjs',\n entryFileNames: '[name].cjs',\n preserveModules: true,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },],":"{\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: false,\n sourcemap: false,\n exports: 'named',\n dir: 'dist/',\n },"}\n // 配置需要排除的或包含包\n external: external(),\n plugins: [\n resolve(),\n commonjs(),\n json(),\n ${e?"typescript({\n tsconfig: './tsconfig.rollup.json',\n exclude: ['node_modules', 'test'],\n }),":"+++"}\n // 去除无用代码\n cleanup(),\n copy({\n targets: [\n { src: 'README.md', dest: 'dist' },\n { src: 'LICENSE', dest: 'dist' },\n ],\n }),\n ],\n};\n`.replace(/\+{2,}\n?/gm,""))}(),function(){const{dependencies:n}=W.local,e=n.includes("typescript");D(W.pkgFile("rollup.config.eg.js"),`${e?"import typescript from '@rollup/plugin-typescript';":""}\nimport resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\nimport json from '@rollup/plugin-json';\nimport cleanup from 'rollup-plugin-cleanup';\nimport { external } from '@qqi/rollup-external';\n\n/** 生成 npm 文件的打包配置文件 */\nexport default {\n input: './eg/index.${e?"ts":"js"}',\n output:{\n format: 'es',\n entryFileNames: '[name].mjs',\n preserveModules: false,\n sourcemap: false,\n exports: 'named',\n dir: '.eg/',\n },\n // 配置需要排除的包\n external: external({ ignore: ['node:'] }),\n plugins: [\n resolve(),\n commonjs(),\n // 可打包 json 内容\n json(),\n ${e?"\ntypescript({\ntsconfig: './tsconfig.rollup.json',\n}),\n":""}\n // 去除无用代码\n cleanup(),\n ],\n};\n`)}(),dn(),function(){const{manager:n}=M,{dependencies:e}=W.local,t=e.includes("typescript"),s={type:"module",version:"0.0.0",name:W.name,description:"写点什么吧,空白只本应存在于虚空",scripts:{b:"rollup --config rollup.config.js"+(t||1!==W.bin?" && tsc -p tsconfig.types.json":""),build:`${n.value} run b && ${n.value} run clean:package`,test:"jja rm .eg && rollup --config rollup.config.eg.js && node .eg/index.mjs","push:version":"gvv",push:"gvv",diff:"jja pkg --diff=官方",vjj:"vjj",prepublishOnly:"pjj","clean:package":"node scripts/clean-package-json.js"},license:"MIT"};l(W.pkgFile("package.json"),s)}(),gn(),$n(),fn(),D(W.pkgFile("todo.md"),"# 代办\n\n"),An(),hn()}async function jn(){return G("开始构建应用"),""==W.name?(await Z(),await ln(),void await jn()):W.childPkg?(W.carryRange&&yn(),void _n()):void vn()}(async()=>{try{try{const n=s("test_write"+Date.now());l(n,{}),N(n)}catch(n){return G.error(n),console.log(n),await z("您没有当前目录的写文件的权限,请确认后再试")}c("华丽开始分割",!0),function(){const n=U.args.$map,{manager:e}=M;G("解析元素参数",n);const t=n.manager?.value?.[0]??"";e.accept.includes(t)&&(e.value=t)}();const{manager:n}=M;G(n),_(n.value)?await async function(){const{manager:n}=M,e=m(),t=(()=>{const t=[...n.accept];if(t[0]===e)return t;for(let n=0,s=t.length;n<s;n++)if(t[n]===e){[t[0],t[n]]=[t[n],t[0]];break}return t})(),s=await U.selection({info:"请选择您使用的包管理器",data:t});n.value=s??"npm"}():g(T`您选择使用 ${k(n.value)} 作为包管理器`),await Z(),await ln(),await jn(),W.install&&await async function(){const{manager:n}=M;await d({code:`${n.value} install`,cwd:W.childPkg?W.rangeFile(""):W.pkgFile(""),printLog:!0,waiting:"请稍等,正在安装依赖"})}(),g(b`创建项目完毕`),W.childPkg?g(`请 cd 到 ${k`./${W.range}`} 目录下`):g(`请 cd 到 ${k(W.cwd)} 目录下`),g(),W.install||g(`执行 ${C("npm"===n.value?"npm install":"yarn"===n.value?"yarn":"pnpm install")}`),g(C`简单测试使用 ${P`${n.value} test`}`),g(C`简单打包使用 ${P`${n.value} run build`}`),g(b`创建项目完毕`),g(),await z("")}catch(n){G.error(n)}})();