@hot-updater/console 0.28.0 → 0.29.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.output/nitro.json +17 -0
- package/.output/public/apple-touch-icon.png +0 -0
- package/.output/public/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2 +0 -0
- package/.output/public/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2 +0 -0
- package/.output/public/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2 +0 -0
- package/.output/public/assets/inter-greek-wght-normal-CkhJZR-_.woff2 +0 -0
- package/.output/public/assets/inter-latin-ext-wght-normal-DO1Apj_S.woff2 +0 -0
- package/.output/public/assets/inter-latin-wght-normal-Dx4kXJAl.woff2 +0 -0
- package/.output/public/assets/inter-vietnamese-wght-normal-CBcvBZtf.woff2 +0 -0
- package/.output/public/assets/main-Dlx8-qN-.js +61 -0
- package/.output/public/assets/routes-DB0tWmiJ.js +10 -0
- package/.output/public/assets/styles-Bfxg4M1x.css +2 -0
- package/.output/public/favicon-16x16.png +0 -0
- package/.output/public/favicon-32x32.png +0 -0
- package/.output/public/favicon.ico +0 -0
- package/.output/public/logo.svg +1 -0
- package/.output/public/manifest.json +30 -0
- package/.output/public/robots.txt +3 -0
- package/.output/server/_chunks/ssr-renderer.mjs +15 -0
- package/.output/server/_libs/@floating-ui/core+[...].mjs +698 -0
- package/.output/server/_libs/@floating-ui/dom+[...].mjs +644 -0
- package/.output/server/_libs/@floating-ui/react-dom+[...].mjs +839 -0
- package/.output/server/_libs/@radix-ui/react-alert-dialog+[...].mjs +2093 -0
- package/.output/server/_libs/@radix-ui/react-popper+[...].mjs +287 -0
- package/.output/server/_libs/@radix-ui/react-select+[...].mjs +1003 -0
- package/.output/server/_libs/@tanstack/devtools-event-client+[...].mjs +196 -0
- package/.output/server/_libs/@tanstack/form-core+[...].mjs +2396 -0
- package/.output/server/_libs/@tanstack/react-form+[...].mjs +298 -0
- package/.output/server/_libs/@tanstack/react-router+[...].mjs +13068 -0
- package/.output/server/_libs/@tanstack/react-table+[...].mjs +2372 -0
- package/.output/server/_libs/chownr.mjs +60 -0
- package/.output/server/_libs/class-variance-authority+clsx.mjs +69 -0
- package/.output/server/_libs/core-util-is.mjs +67 -0
- package/.output/server/_libs/dayjs.mjs +408 -0
- package/.output/server/_libs/h3+rou3+srvx.mjs +1158 -0
- package/.output/server/_libs/hookable.mjs +41 -0
- package/.output/server/_libs/immediate.mjs +57 -0
- package/.output/server/_libs/inherits.mjs +39 -0
- package/.output/server/_libs/isaacs__fs-minipass+minipass.mjs +1120 -0
- package/.output/server/_libs/isarray.mjs +10 -0
- package/.output/server/_libs/jszip+[...].mjs +8311 -0
- package/.output/server/_libs/lucide-react.mjs +371 -0
- package/.output/server/_libs/minizlib.mjs +345 -0
- package/.output/server/_libs/next-themes.mjs +49 -0
- package/.output/server/_libs/radix-ui__number.mjs +6 -0
- package/.output/server/_libs/radix-ui__primitive.mjs +9 -0
- package/.output/server/_libs/radix-ui__react-arrow.mjs +23 -0
- package/.output/server/_libs/radix-ui__react-collection.mjs +78 -0
- package/.output/server/_libs/radix-ui__react-direction.mjs +11 -0
- package/.output/server/_libs/radix-ui__react-label.mjs +22 -0
- package/.output/server/_libs/radix-ui__react-separator.mjs +31 -0
- package/.output/server/_libs/radix-ui__react-slider.mjs +451 -0
- package/.output/server/_libs/radix-ui__react-switch.mjs +118 -0
- package/.output/server/_libs/radix-ui__react-tooltip.mjs +491 -0
- package/.output/server/_libs/semver.mjs +1339 -0
- package/.output/server/_libs/sonner.mjs +908 -0
- package/.output/server/_libs/tailwind-merge.mjs +1962 -0
- package/.output/server/_libs/tanstack__history.mjs +322 -0
- package/.output/server/_libs/tanstack__query-core.mjs +2073 -0
- package/.output/server/_libs/tanstack__react-query.mjs +146 -0
- package/.output/server/_libs/tanstack__router-core.mjs +6 -0
- package/.output/server/_libs/tar.mjs +1996 -0
- package/.output/server/_libs/ufo.mjs +64 -0
- package/.output/server/_runtime.mjs +26 -0
- package/.output/server/_ssr/api-rpc-D3ZehMIN.mjs +217 -0
- package/.output/server/_ssr/config.server-JUYQ7UbI.mjs +26 -0
- package/.output/server/_ssr/deleteBundle-DWUxu9-K.mjs +22 -0
- package/.output/server/_ssr/extract-timestamp-from-uuidv7-B90UBADU.mjs +24 -0
- package/.output/server/_ssr/promoteBundle-DtMHuubR.mjs +1571 -0
- package/.output/server/_ssr/router-pgc7NX76.mjs +250 -0
- package/.output/server/_ssr/routes-PqTTQSoI.mjs +1833 -0
- package/.output/server/_ssr/sidebar-DXng0IOP.mjs +439 -0
- package/.output/server/_ssr/ssr.mjs +5050 -0
- package/.output/server/_ssr/start-DQK0r85G.mjs +4 -0
- package/.output/server/_tanstack-start-manifest_v-DTbQVOpU.mjs +17 -0
- package/.output/server/index.mjs +417 -0
- package/.output/server/node_modules/tslib/modules/index.js +70 -0
- package/.output/server/node_modules/tslib/modules/package.json +3 -0
- package/.output/server/node_modules/tslib/package.json +47 -0
- package/.output/server/node_modules/tslib/tslib.js +484 -0
- package/.output/server/package.json +9 -0
- package/README.md +191 -2
- package/package.json +77 -50
- package/dist/.gitkeep +0 -0
- package/dist/assets/favicon-BkwcEHsj.ico +0 -0
- package/dist/assets/index-DUlKsori.css +0 -1
- package/dist/assets/index-ijmIcyn1.js +0 -27
- package/dist/assets/logo-BYNFyja1.png +0 -0
- package/dist/index.cjs +0 -2129
- package/dist/index.d.cts +0 -218
- package/dist/index.d.ts +0 -218
- package/dist/index.html +0 -14
- package/dist/index.js +0 -2125
|
@@ -0,0 +1,484 @@
|
|
|
1
|
+
/******************************************************************************
|
|
2
|
+
Copyright (c) Microsoft Corporation.
|
|
3
|
+
|
|
4
|
+
Permission to use, copy, modify, and/or distribute this software for any
|
|
5
|
+
purpose with or without fee is hereby granted.
|
|
6
|
+
|
|
7
|
+
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
|
8
|
+
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
9
|
+
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
10
|
+
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
11
|
+
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
12
|
+
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
13
|
+
PERFORMANCE OF THIS SOFTWARE.
|
|
14
|
+
***************************************************************************** */
|
|
15
|
+
/* global global, define, Symbol, Reflect, Promise, SuppressedError, Iterator */
|
|
16
|
+
var __extends;
|
|
17
|
+
var __assign;
|
|
18
|
+
var __rest;
|
|
19
|
+
var __decorate;
|
|
20
|
+
var __param;
|
|
21
|
+
var __esDecorate;
|
|
22
|
+
var __runInitializers;
|
|
23
|
+
var __propKey;
|
|
24
|
+
var __setFunctionName;
|
|
25
|
+
var __metadata;
|
|
26
|
+
var __awaiter;
|
|
27
|
+
var __generator;
|
|
28
|
+
var __exportStar;
|
|
29
|
+
var __values;
|
|
30
|
+
var __read;
|
|
31
|
+
var __spread;
|
|
32
|
+
var __spreadArrays;
|
|
33
|
+
var __spreadArray;
|
|
34
|
+
var __await;
|
|
35
|
+
var __asyncGenerator;
|
|
36
|
+
var __asyncDelegator;
|
|
37
|
+
var __asyncValues;
|
|
38
|
+
var __makeTemplateObject;
|
|
39
|
+
var __importStar;
|
|
40
|
+
var __importDefault;
|
|
41
|
+
var __classPrivateFieldGet;
|
|
42
|
+
var __classPrivateFieldSet;
|
|
43
|
+
var __classPrivateFieldIn;
|
|
44
|
+
var __createBinding;
|
|
45
|
+
var __addDisposableResource;
|
|
46
|
+
var __disposeResources;
|
|
47
|
+
var __rewriteRelativeImportExtension;
|
|
48
|
+
(function (factory) {
|
|
49
|
+
var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {};
|
|
50
|
+
if (typeof define === "function" && define.amd) {
|
|
51
|
+
define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); });
|
|
52
|
+
}
|
|
53
|
+
else if (typeof module === "object" && typeof module.exports === "object") {
|
|
54
|
+
factory(createExporter(root, createExporter(module.exports)));
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
factory(createExporter(root));
|
|
58
|
+
}
|
|
59
|
+
function createExporter(exports, previous) {
|
|
60
|
+
if (exports !== root) {
|
|
61
|
+
if (typeof Object.create === "function") {
|
|
62
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
exports.__esModule = true;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return function (id, v) { return exports[id] = previous ? previous(id, v) : v; };
|
|
69
|
+
}
|
|
70
|
+
})
|
|
71
|
+
(function (exporter) {
|
|
72
|
+
var extendStatics = Object.setPrototypeOf ||
|
|
73
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
74
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
75
|
+
|
|
76
|
+
__extends = function (d, b) {
|
|
77
|
+
if (typeof b !== "function" && b !== null)
|
|
78
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
79
|
+
extendStatics(d, b);
|
|
80
|
+
function __() { this.constructor = d; }
|
|
81
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
__assign = Object.assign || function (t) {
|
|
85
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
86
|
+
s = arguments[i];
|
|
87
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
|
|
88
|
+
}
|
|
89
|
+
return t;
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
__rest = function (s, e) {
|
|
93
|
+
var t = {};
|
|
94
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
95
|
+
t[p] = s[p];
|
|
96
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
97
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
98
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
99
|
+
t[p[i]] = s[p[i]];
|
|
100
|
+
}
|
|
101
|
+
return t;
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
__decorate = function (decorators, target, key, desc) {
|
|
105
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
106
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
107
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
108
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
__param = function (paramIndex, decorator) {
|
|
112
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
113
|
+
};
|
|
114
|
+
|
|
115
|
+
__esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
|
|
116
|
+
function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
|
|
117
|
+
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
|
|
118
|
+
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
|
|
119
|
+
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
|
|
120
|
+
var _, done = false;
|
|
121
|
+
for (var i = decorators.length - 1; i >= 0; i--) {
|
|
122
|
+
var context = {};
|
|
123
|
+
for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
|
|
124
|
+
for (var p in contextIn.access) context.access[p] = contextIn.access[p];
|
|
125
|
+
context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
|
|
126
|
+
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
|
|
127
|
+
if (kind === "accessor") {
|
|
128
|
+
if (result === void 0) continue;
|
|
129
|
+
if (result === null || typeof result !== "object") throw new TypeError("Object expected");
|
|
130
|
+
if (_ = accept(result.get)) descriptor.get = _;
|
|
131
|
+
if (_ = accept(result.set)) descriptor.set = _;
|
|
132
|
+
if (_ = accept(result.init)) initializers.unshift(_);
|
|
133
|
+
}
|
|
134
|
+
else if (_ = accept(result)) {
|
|
135
|
+
if (kind === "field") initializers.unshift(_);
|
|
136
|
+
else descriptor[key] = _;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
if (target) Object.defineProperty(target, contextIn.name, descriptor);
|
|
140
|
+
done = true;
|
|
141
|
+
};
|
|
142
|
+
|
|
143
|
+
__runInitializers = function (thisArg, initializers, value) {
|
|
144
|
+
var useValue = arguments.length > 2;
|
|
145
|
+
for (var i = 0; i < initializers.length; i++) {
|
|
146
|
+
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
|
|
147
|
+
}
|
|
148
|
+
return useValue ? value : void 0;
|
|
149
|
+
};
|
|
150
|
+
|
|
151
|
+
__propKey = function (x) {
|
|
152
|
+
return typeof x === "symbol" ? x : "".concat(x);
|
|
153
|
+
};
|
|
154
|
+
|
|
155
|
+
__setFunctionName = function (f, name, prefix) {
|
|
156
|
+
if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
|
|
157
|
+
return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
__metadata = function (metadataKey, metadataValue) {
|
|
161
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
__awaiter = function (thisArg, _arguments, P, generator) {
|
|
165
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
166
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
167
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
168
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
169
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
170
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
171
|
+
});
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
__generator = function (thisArg, body) {
|
|
175
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
176
|
+
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
177
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
178
|
+
function step(op) {
|
|
179
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
180
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
181
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
182
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
183
|
+
switch (op[0]) {
|
|
184
|
+
case 0: case 1: t = op; break;
|
|
185
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
186
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
187
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
188
|
+
default:
|
|
189
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
190
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
191
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
192
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
193
|
+
if (t[2]) _.ops.pop();
|
|
194
|
+
_.trys.pop(); continue;
|
|
195
|
+
}
|
|
196
|
+
op = body.call(thisArg, _);
|
|
197
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
198
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
199
|
+
}
|
|
200
|
+
};
|
|
201
|
+
|
|
202
|
+
__exportStar = function(m, o) {
|
|
203
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);
|
|
204
|
+
};
|
|
205
|
+
|
|
206
|
+
__createBinding = Object.create ? (function(o, m, k, k2) {
|
|
207
|
+
if (k2 === undefined) k2 = k;
|
|
208
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
209
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
210
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
211
|
+
}
|
|
212
|
+
Object.defineProperty(o, k2, desc);
|
|
213
|
+
}) : (function(o, m, k, k2) {
|
|
214
|
+
if (k2 === undefined) k2 = k;
|
|
215
|
+
o[k2] = m[k];
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
__values = function (o) {
|
|
219
|
+
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
220
|
+
if (m) return m.call(o);
|
|
221
|
+
if (o && typeof o.length === "number") return {
|
|
222
|
+
next: function () {
|
|
223
|
+
if (o && i >= o.length) o = void 0;
|
|
224
|
+
return { value: o && o[i++], done: !o };
|
|
225
|
+
}
|
|
226
|
+
};
|
|
227
|
+
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
228
|
+
};
|
|
229
|
+
|
|
230
|
+
__read = function (o, n) {
|
|
231
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
232
|
+
if (!m) return o;
|
|
233
|
+
var i = m.call(o), r, ar = [], e;
|
|
234
|
+
try {
|
|
235
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
236
|
+
}
|
|
237
|
+
catch (error) { e = { error: error }; }
|
|
238
|
+
finally {
|
|
239
|
+
try {
|
|
240
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
241
|
+
}
|
|
242
|
+
finally { if (e) throw e.error; }
|
|
243
|
+
}
|
|
244
|
+
return ar;
|
|
245
|
+
};
|
|
246
|
+
|
|
247
|
+
/** @deprecated */
|
|
248
|
+
__spread = function () {
|
|
249
|
+
for (var ar = [], i = 0; i < arguments.length; i++)
|
|
250
|
+
ar = ar.concat(__read(arguments[i]));
|
|
251
|
+
return ar;
|
|
252
|
+
};
|
|
253
|
+
|
|
254
|
+
/** @deprecated */
|
|
255
|
+
__spreadArrays = function () {
|
|
256
|
+
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
|
|
257
|
+
for (var r = Array(s), k = 0, i = 0; i < il; i++)
|
|
258
|
+
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
|
|
259
|
+
r[k] = a[j];
|
|
260
|
+
return r;
|
|
261
|
+
};
|
|
262
|
+
|
|
263
|
+
__spreadArray = function (to, from, pack) {
|
|
264
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
265
|
+
if (ar || !(i in from)) {
|
|
266
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
267
|
+
ar[i] = from[i];
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
271
|
+
};
|
|
272
|
+
|
|
273
|
+
__await = function (v) {
|
|
274
|
+
return this instanceof __await ? (this.v = v, this) : new __await(v);
|
|
275
|
+
};
|
|
276
|
+
|
|
277
|
+
__asyncGenerator = function (thisArg, _arguments, generator) {
|
|
278
|
+
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
|
|
279
|
+
var g = generator.apply(thisArg, _arguments || []), i, q = [];
|
|
280
|
+
return i = Object.create((typeof AsyncIterator === "function" ? AsyncIterator : Object).prototype), verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;
|
|
281
|
+
function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }
|
|
282
|
+
function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }
|
|
283
|
+
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
|
|
284
|
+
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
|
|
285
|
+
function fulfill(value) { resume("next", value); }
|
|
286
|
+
function reject(value) { resume("throw", value); }
|
|
287
|
+
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
|
|
288
|
+
};
|
|
289
|
+
|
|
290
|
+
__asyncDelegator = function (o) {
|
|
291
|
+
var i, p;
|
|
292
|
+
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
|
|
293
|
+
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }
|
|
294
|
+
};
|
|
295
|
+
|
|
296
|
+
__asyncValues = function (o) {
|
|
297
|
+
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
|
|
298
|
+
var m = o[Symbol.asyncIterator], i;
|
|
299
|
+
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
|
|
300
|
+
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
|
|
301
|
+
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
|
|
302
|
+
};
|
|
303
|
+
|
|
304
|
+
__makeTemplateObject = function (cooked, raw) {
|
|
305
|
+
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
|
|
306
|
+
return cooked;
|
|
307
|
+
};
|
|
308
|
+
|
|
309
|
+
var __setModuleDefault = Object.create ? (function(o, v) {
|
|
310
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
311
|
+
}) : function(o, v) {
|
|
312
|
+
o["default"] = v;
|
|
313
|
+
};
|
|
314
|
+
|
|
315
|
+
var ownKeys = function(o) {
|
|
316
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
317
|
+
var ar = [];
|
|
318
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
319
|
+
return ar;
|
|
320
|
+
};
|
|
321
|
+
return ownKeys(o);
|
|
322
|
+
};
|
|
323
|
+
|
|
324
|
+
__importStar = function (mod) {
|
|
325
|
+
if (mod && mod.__esModule) return mod;
|
|
326
|
+
var result = {};
|
|
327
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
328
|
+
__setModuleDefault(result, mod);
|
|
329
|
+
return result;
|
|
330
|
+
};
|
|
331
|
+
|
|
332
|
+
__importDefault = function (mod) {
|
|
333
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
334
|
+
};
|
|
335
|
+
|
|
336
|
+
__classPrivateFieldGet = function (receiver, state, kind, f) {
|
|
337
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
338
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
339
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
340
|
+
};
|
|
341
|
+
|
|
342
|
+
__classPrivateFieldSet = function (receiver, state, value, kind, f) {
|
|
343
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
344
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
345
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
346
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
347
|
+
};
|
|
348
|
+
|
|
349
|
+
__classPrivateFieldIn = function (state, receiver) {
|
|
350
|
+
if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object");
|
|
351
|
+
return typeof state === "function" ? receiver === state : state.has(receiver);
|
|
352
|
+
};
|
|
353
|
+
|
|
354
|
+
__addDisposableResource = function (env, value, async) {
|
|
355
|
+
if (value !== null && value !== void 0) {
|
|
356
|
+
if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
|
|
357
|
+
var dispose, inner;
|
|
358
|
+
if (async) {
|
|
359
|
+
if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
|
|
360
|
+
dispose = value[Symbol.asyncDispose];
|
|
361
|
+
}
|
|
362
|
+
if (dispose === void 0) {
|
|
363
|
+
if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
|
|
364
|
+
dispose = value[Symbol.dispose];
|
|
365
|
+
if (async) inner = dispose;
|
|
366
|
+
}
|
|
367
|
+
if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
|
|
368
|
+
if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };
|
|
369
|
+
env.stack.push({ value: value, dispose: dispose, async: async });
|
|
370
|
+
}
|
|
371
|
+
else if (async) {
|
|
372
|
+
env.stack.push({ async: true });
|
|
373
|
+
}
|
|
374
|
+
return value;
|
|
375
|
+
};
|
|
376
|
+
|
|
377
|
+
var _SuppressedError = typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
|
|
378
|
+
var e = new Error(message);
|
|
379
|
+
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
380
|
+
};
|
|
381
|
+
|
|
382
|
+
__disposeResources = function (env) {
|
|
383
|
+
function fail(e) {
|
|
384
|
+
env.error = env.hasError ? new _SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
|
|
385
|
+
env.hasError = true;
|
|
386
|
+
}
|
|
387
|
+
var r, s = 0;
|
|
388
|
+
function next() {
|
|
389
|
+
while (r = env.stack.pop()) {
|
|
390
|
+
try {
|
|
391
|
+
if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);
|
|
392
|
+
if (r.dispose) {
|
|
393
|
+
var result = r.dispose.call(r.value);
|
|
394
|
+
if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
|
|
395
|
+
}
|
|
396
|
+
else s |= 1;
|
|
397
|
+
}
|
|
398
|
+
catch (e) {
|
|
399
|
+
fail(e);
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();
|
|
403
|
+
if (env.hasError) throw env.error;
|
|
404
|
+
}
|
|
405
|
+
return next();
|
|
406
|
+
};
|
|
407
|
+
|
|
408
|
+
__rewriteRelativeImportExtension = function (path, preserveJsx) {
|
|
409
|
+
if (typeof path === "string" && /^\.\.?\//.test(path)) {
|
|
410
|
+
return path.replace(/\.(tsx)$|((?:\.d)?)((?:\.[^./]+?)?)\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {
|
|
411
|
+
return tsx ? preserveJsx ? ".jsx" : ".js" : d && (!ext || !cm) ? m : (d + ext + "." + cm.toLowerCase() + "js");
|
|
412
|
+
});
|
|
413
|
+
}
|
|
414
|
+
return path;
|
|
415
|
+
};
|
|
416
|
+
|
|
417
|
+
exporter("__extends", __extends);
|
|
418
|
+
exporter("__assign", __assign);
|
|
419
|
+
exporter("__rest", __rest);
|
|
420
|
+
exporter("__decorate", __decorate);
|
|
421
|
+
exporter("__param", __param);
|
|
422
|
+
exporter("__esDecorate", __esDecorate);
|
|
423
|
+
exporter("__runInitializers", __runInitializers);
|
|
424
|
+
exporter("__propKey", __propKey);
|
|
425
|
+
exporter("__setFunctionName", __setFunctionName);
|
|
426
|
+
exporter("__metadata", __metadata);
|
|
427
|
+
exporter("__awaiter", __awaiter);
|
|
428
|
+
exporter("__generator", __generator);
|
|
429
|
+
exporter("__exportStar", __exportStar);
|
|
430
|
+
exporter("__createBinding", __createBinding);
|
|
431
|
+
exporter("__values", __values);
|
|
432
|
+
exporter("__read", __read);
|
|
433
|
+
exporter("__spread", __spread);
|
|
434
|
+
exporter("__spreadArrays", __spreadArrays);
|
|
435
|
+
exporter("__spreadArray", __spreadArray);
|
|
436
|
+
exporter("__await", __await);
|
|
437
|
+
exporter("__asyncGenerator", __asyncGenerator);
|
|
438
|
+
exporter("__asyncDelegator", __asyncDelegator);
|
|
439
|
+
exporter("__asyncValues", __asyncValues);
|
|
440
|
+
exporter("__makeTemplateObject", __makeTemplateObject);
|
|
441
|
+
exporter("__importStar", __importStar);
|
|
442
|
+
exporter("__importDefault", __importDefault);
|
|
443
|
+
exporter("__classPrivateFieldGet", __classPrivateFieldGet);
|
|
444
|
+
exporter("__classPrivateFieldSet", __classPrivateFieldSet);
|
|
445
|
+
exporter("__classPrivateFieldIn", __classPrivateFieldIn);
|
|
446
|
+
exporter("__addDisposableResource", __addDisposableResource);
|
|
447
|
+
exporter("__disposeResources", __disposeResources);
|
|
448
|
+
exporter("__rewriteRelativeImportExtension", __rewriteRelativeImportExtension);
|
|
449
|
+
});
|
|
450
|
+
|
|
451
|
+
0 && (module.exports = {
|
|
452
|
+
__extends: __extends,
|
|
453
|
+
__assign: __assign,
|
|
454
|
+
__rest: __rest,
|
|
455
|
+
__decorate: __decorate,
|
|
456
|
+
__param: __param,
|
|
457
|
+
__esDecorate: __esDecorate,
|
|
458
|
+
__runInitializers: __runInitializers,
|
|
459
|
+
__propKey: __propKey,
|
|
460
|
+
__setFunctionName: __setFunctionName,
|
|
461
|
+
__metadata: __metadata,
|
|
462
|
+
__awaiter: __awaiter,
|
|
463
|
+
__generator: __generator,
|
|
464
|
+
__exportStar: __exportStar,
|
|
465
|
+
__createBinding: __createBinding,
|
|
466
|
+
__values: __values,
|
|
467
|
+
__read: __read,
|
|
468
|
+
__spread: __spread,
|
|
469
|
+
__spreadArrays: __spreadArrays,
|
|
470
|
+
__spreadArray: __spreadArray,
|
|
471
|
+
__await: __await,
|
|
472
|
+
__asyncGenerator: __asyncGenerator,
|
|
473
|
+
__asyncDelegator: __asyncDelegator,
|
|
474
|
+
__asyncValues: __asyncValues,
|
|
475
|
+
__makeTemplateObject: __makeTemplateObject,
|
|
476
|
+
__importStar: __importStar,
|
|
477
|
+
__importDefault: __importDefault,
|
|
478
|
+
__classPrivateFieldGet: __classPrivateFieldGet,
|
|
479
|
+
__classPrivateFieldSet: __classPrivateFieldSet,
|
|
480
|
+
__classPrivateFieldIn: __classPrivateFieldIn,
|
|
481
|
+
__addDisposableResource: __addDisposableResource,
|
|
482
|
+
__disposeResources: __disposeResources,
|
|
483
|
+
__rewriteRelativeImportExtension: __rewriteRelativeImportExtension,
|
|
484
|
+
});
|
package/README.md
CHANGED
|
@@ -1,3 +1,192 @@
|
|
|
1
|
-
# Hot Updater
|
|
1
|
+
# Hot Updater Console (v2)
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
Modern web-based management console for Hot Updater built with **TanStack Start** and **shadcn/ui**.
|
|
4
|
+
|
|
5
|
+
## 🚀 Features
|
|
6
|
+
|
|
7
|
+
- **Bundle Management** - View, filter, and manage OTA update bundles
|
|
8
|
+
- **Real-time Filtering** - Filter by platform (iOS/Android) and channel
|
|
9
|
+
- **Bundle Editor** - Edit bundle configurations with intuitive forms
|
|
10
|
+
- **Rollout Control** - Adjust rollout percentage with visual slider
|
|
11
|
+
- **Rollout Statistics** - View deployment metrics and success rates
|
|
12
|
+
- **Channel Promotion** - Copy or move bundles between channels
|
|
13
|
+
- **Emergency Rollback** - One-click disable and rollback
|
|
14
|
+
- **Dark Mode** - Full dark mode support with system preference detection
|
|
15
|
+
- **Responsive Design** - Works seamlessly on desktop, tablet, and mobile
|
|
16
|
+
|
|
17
|
+
## 🛠️ Tech Stack
|
|
18
|
+
|
|
19
|
+
### Frontend
|
|
20
|
+
- **TanStack Start** - Full-stack React framework with SSR
|
|
21
|
+
- **TanStack Router** - File-based routing with type safety
|
|
22
|
+
- **TanStack Query** - Data fetching and caching
|
|
23
|
+
- **TanStack Form** - Form state management and validation
|
|
24
|
+
- **TanStack Table** - Powerful table with sorting and pagination
|
|
25
|
+
- **React 19** - Latest React features
|
|
26
|
+
|
|
27
|
+
### UI Components
|
|
28
|
+
- **shadcn/ui** - High-quality accessible components (Radix Mira style)
|
|
29
|
+
- **Tailwind CSS v4** - Utility-first CSS with oklch color system
|
|
30
|
+
- **Lucide React** - Beautiful icon library
|
|
31
|
+
- **Sonner** - Toast notifications
|
|
32
|
+
|
|
33
|
+
### Backend
|
|
34
|
+
- **TanStack Start Server Functions** - Type-safe server endpoints
|
|
35
|
+
- **Hot Updater Plugins** - Storage and database plugin integration
|
|
36
|
+
|
|
37
|
+
## 📦 Installation
|
|
38
|
+
|
|
39
|
+
```bash
|
|
40
|
+
# Install dependencies (from monorepo root)
|
|
41
|
+
pnpm install
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
## 🏃♂️ Development
|
|
45
|
+
|
|
46
|
+
```bash
|
|
47
|
+
# Start development server
|
|
48
|
+
pnpm dev
|
|
49
|
+
|
|
50
|
+
# Build for production
|
|
51
|
+
pnpm build
|
|
52
|
+
|
|
53
|
+
# Preview production build
|
|
54
|
+
pnpm preview
|
|
55
|
+
|
|
56
|
+
# Type checking
|
|
57
|
+
pnpm test:type
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
The console will be available at `http://localhost:3000`.
|
|
61
|
+
|
|
62
|
+
## 📁 Project Structure
|
|
63
|
+
|
|
64
|
+
```
|
|
65
|
+
src/
|
|
66
|
+
├── routes/
|
|
67
|
+
│ ├── __root.tsx # Root layout with providers
|
|
68
|
+
│ ├── index.tsx # Bundle list page
|
|
69
|
+
│ └── api/ # API routes (future)
|
|
70
|
+
├── components/
|
|
71
|
+
│ ├── ui/ # shadcn components
|
|
72
|
+
│ ├── features/
|
|
73
|
+
│ │ └── bundles/ # Bundle-related components
|
|
74
|
+
│ ├── PlatformIcon.tsx # iOS/Android icons
|
|
75
|
+
│ ├── BundleIdDisplay.tsx # Truncated bundle ID with tooltip
|
|
76
|
+
│ ├── RolloutPercentageBadge.tsx
|
|
77
|
+
│ ├── TimestampDisplay.tsx # UUIDv7 timestamp formatting
|
|
78
|
+
│ ├── ChannelBadge.tsx
|
|
79
|
+
│ └── EnabledStatusIcon.tsx
|
|
80
|
+
├── hooks/
|
|
81
|
+
│ └── useFilterParams.ts # URL-based filter state
|
|
82
|
+
├── lib/
|
|
83
|
+
│ ├── api.ts # React Query hooks
|
|
84
|
+
│ ├── constants.ts # Shared constants
|
|
85
|
+
│ ├── utils.ts # Utility functions
|
|
86
|
+
│ ├── extract-timestamp-from-uuidv7.ts
|
|
87
|
+
│ └── server/
|
|
88
|
+
│ ├── api.server.ts # Server functions
|
|
89
|
+
│ └── config.server.ts # Hot Updater config loader
|
|
90
|
+
└── styles.css # Global styles & theme variables
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
## 🎨 Key Components
|
|
94
|
+
|
|
95
|
+
### Bundle List Page
|
|
96
|
+
- **FilterToolbar** - Platform and channel filters with reset button
|
|
97
|
+
- **BundlesTable** - Server-side paginated table (20 per page)
|
|
98
|
+
- **BundleTableColumns** - Column definitions with custom cell renderers
|
|
99
|
+
|
|
100
|
+
### Bundle Editor Sheet
|
|
101
|
+
- **BundleEditorSheet** - Right-side slide-out panel
|
|
102
|
+
- **BundleEditorForm** - TanStack Form with validation
|
|
103
|
+
- **BundleMetadata** - Read-only bundle information display
|
|
104
|
+
|
|
105
|
+
### Dialogs
|
|
106
|
+
- **PromoteChannelDialog** - Channel promotion with copy/move toggle
|
|
107
|
+
- **DeleteBundleDialog** - Confirmation dialog with bundle details
|
|
108
|
+
- **EmergencyRollbackButton** - One-click disable + 0% rollout
|
|
109
|
+
|
|
110
|
+
## 🔌 API Integration
|
|
111
|
+
|
|
112
|
+
The console integrates with Hot Updater's plugin system through TanStack Start server functions:
|
|
113
|
+
|
|
114
|
+
- `getConfig()` - Load console configuration
|
|
115
|
+
- `getChannels()` - List available channels
|
|
116
|
+
- `getBundles(filters)` - List bundles with pagination
|
|
117
|
+
- `getBundle(bundleId)` - Get single bundle details
|
|
118
|
+
- `updateBundle(bundleId, data)` - Update bundle configuration
|
|
119
|
+
- `createBundle(bundle)` - Create new bundle
|
|
120
|
+
- `deleteBundle(bundleId)` - Delete bundle
|
|
121
|
+
|
|
122
|
+
## 🎯 Configuration
|
|
123
|
+
|
|
124
|
+
Configure Hot Updater in `hot-updater.config.ts`:
|
|
125
|
+
|
|
126
|
+
```typescript
|
|
127
|
+
import { mockDatabase, mockStorage } from "@hot-updater/mock";
|
|
128
|
+
|
|
129
|
+
export default {
|
|
130
|
+
storage: mockStorage(),
|
|
131
|
+
database: mockDatabase({
|
|
132
|
+
latency: { min: 500, max: 700 },
|
|
133
|
+
initialBundles: [
|
|
134
|
+
// ... your bundles
|
|
135
|
+
],
|
|
136
|
+
}),
|
|
137
|
+
};
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
## 🌈 Theming
|
|
141
|
+
|
|
142
|
+
The console uses Tailwind CSS v4 with oklch color space for accessible colors. Theme variables are defined in `src/styles.css`:
|
|
143
|
+
|
|
144
|
+
- Light mode: Default
|
|
145
|
+
- Dark mode: Automatically enabled with `class="dark"`
|
|
146
|
+
- System preference: Respects OS theme setting
|
|
147
|
+
|
|
148
|
+
## 🔒 Type Safety
|
|
149
|
+
|
|
150
|
+
- Full TypeScript strict mode
|
|
151
|
+
- Type-safe server functions with TanStack Start
|
|
152
|
+
- Type-safe routing with TanStack Router
|
|
153
|
+
- Type-safe forms with TanStack Form
|
|
154
|
+
|
|
155
|
+
## 📊 Data Flow
|
|
156
|
+
|
|
157
|
+
1. **URL State** → `useFilterParams()` hook manages filter state in URL
|
|
158
|
+
2. **Server Functions** → TanStack Start server functions call Hot Updater plugins
|
|
159
|
+
3. **React Query** → `useBundlesQuery()` fetches and caches data
|
|
160
|
+
4. **UI Components** → Display data with shadcn components
|
|
161
|
+
5. **Mutations** → `useUpdateBundleMutation()` updates data with optimistic updates
|
|
162
|
+
6. **Cache Invalidation** → React Query automatically refreshes affected queries
|
|
163
|
+
|
|
164
|
+
## 🚦 Development Guidelines
|
|
165
|
+
|
|
166
|
+
- **Server-only code** must use `.server.ts` extension
|
|
167
|
+
- **Client-side constants** live in `src/lib/constants.ts`
|
|
168
|
+
- **shadcn components** are customizable in `src/components/ui/`
|
|
169
|
+
- **Form validation** uses TanStack Form validators
|
|
170
|
+
- **Toast notifications** use Sonner for success/error feedback
|
|
171
|
+
|
|
172
|
+
## 🐛 Troubleshooting
|
|
173
|
+
|
|
174
|
+
### Build Errors
|
|
175
|
+
- Ensure `.server.ts` files are not imported on the client
|
|
176
|
+
- Check that native modules (`.node`) are excluded from bundling
|
|
177
|
+
|
|
178
|
+
### Development Server
|
|
179
|
+
- Default port is 3000
|
|
180
|
+
- Change port: `pnpm dev --port 3001`
|
|
181
|
+
|
|
182
|
+
### Hot Updater Config
|
|
183
|
+
- Ensure `hot-updater.config.ts` is at package root
|
|
184
|
+
- Verify storage and database plugins are correctly initialized
|
|
185
|
+
|
|
186
|
+
## 📝 License
|
|
187
|
+
|
|
188
|
+
MIT - See monorepo LICENSE file
|
|
189
|
+
|
|
190
|
+
## 🤝 Contributing
|
|
191
|
+
|
|
192
|
+
See the main Hot Updater repository for contribution guidelines.
|