@nativescript/vite 0.0.1 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +19 -0
- package/README.md +81 -0
- package/{dist/configuration → configuration}/angular.d.ts +1 -1
- package/configuration/angular.js +371 -0
- package/configuration/angular.js.map +1 -0
- package/configuration/base.d.ts +5 -0
- package/configuration/base.js +491 -0
- package/configuration/base.js.map +1 -0
- package/configuration/javascript.d.ts +4 -0
- package/configuration/javascript.js +152 -0
- package/configuration/javascript.js.map +1 -0
- package/{dist/configuration → configuration}/react.d.ts +1 -1
- package/{dist/configuration → configuration}/react.js +18 -17
- package/configuration/react.js.map +1 -0
- package/{dist/configuration → configuration}/solid.d.ts +1 -1
- package/{dist/configuration → configuration}/solid.js +17 -16
- package/configuration/solid.js.map +1 -0
- package/configuration/typescript.d.ts +4 -0
- package/configuration/typescript.js +176 -0
- package/configuration/typescript.js.map +1 -0
- package/{dist/configuration → configuration}/vue.d.ts +1 -1
- package/configuration/vue.js +163 -0
- package/configuration/vue.js.map +1 -0
- package/helpers/angular/angular-linker.d.ts +13 -0
- package/helpers/angular/angular-linker.js +189 -0
- package/helpers/angular/angular-linker.js.map +1 -0
- package/helpers/angular/shared-linker.d.ts +4 -0
- package/helpers/angular/shared-linker.js +39 -0
- package/helpers/angular/shared-linker.js.map +1 -0
- package/helpers/angular/util.d.ts +1 -0
- package/helpers/angular/util.js +67 -0
- package/helpers/angular/util.js.map +1 -0
- package/helpers/cli-flags.d.ts +1 -0
- package/helpers/cli-flags.js +15 -0
- package/helpers/cli-flags.js.map +1 -0
- package/{dist/helpers → helpers}/commonjs-plugins.js +14 -13
- package/helpers/commonjs-plugins.js.map +1 -0
- package/{dist/helpers → helpers}/config-as-json.d.ts +1 -1
- package/{dist/helpers → helpers}/config-as-json.js +7 -6
- package/helpers/config-as-json.js.map +1 -0
- package/helpers/css-platform-plugin.d.ts +10 -0
- package/helpers/css-platform-plugin.js +76 -0
- package/helpers/css-platform-plugin.js.map +1 -0
- package/helpers/css-tree.js +22 -0
- package/helpers/css-tree.js.map +1 -0
- package/{dist/helpers → helpers}/dynamic-import-plugin.js +8 -7
- package/helpers/dynamic-import-plugin.js.map +1 -0
- package/helpers/esbuild-platform-resolver.d.ts +14 -0
- package/helpers/esbuild-platform-resolver.js +93 -0
- package/helpers/esbuild-platform-resolver.js.map +1 -0
- package/helpers/external-configs.d.ts +6 -0
- package/helpers/external-configs.js +34 -0
- package/helpers/external-configs.js.map +1 -0
- package/{dist/helpers → helpers}/flavor.d.ts +1 -0
- package/helpers/flavor.js +51 -0
- package/helpers/flavor.js.map +1 -0
- package/helpers/global-defines.d.ts +25 -0
- package/helpers/global-defines.js +29 -0
- package/helpers/global-defines.js.map +1 -0
- package/helpers/init.d.ts +1 -0
- package/helpers/init.js +119 -0
- package/helpers/init.js.map +1 -0
- package/helpers/logging.d.ts +13 -0
- package/helpers/logging.js +115 -0
- package/helpers/logging.js.map +1 -0
- package/helpers/main-entry.d.ts +10 -0
- package/helpers/main-entry.js +223 -0
- package/helpers/main-entry.js.map +1 -0
- package/{dist/helpers → helpers}/module-resolution.js +4 -3
- package/helpers/module-resolution.js.map +1 -0
- package/helpers/module-runner-patch.d.ts +3 -0
- package/helpers/module-runner-patch.js +63 -0
- package/helpers/module-runner-patch.js.map +1 -0
- package/helpers/nativeclass-transform.d.ts +7 -0
- package/helpers/nativeclass-transform.js +158 -0
- package/helpers/nativeclass-transform.js.map +1 -0
- package/helpers/nativeclass-transformer-plugin.d.ts +5 -0
- package/helpers/nativeclass-transformer-plugin.js +23 -0
- package/helpers/nativeclass-transformer-plugin.js.map +1 -0
- package/{dist/helpers → helpers}/nativescript-package-resolver.js +18 -17
- package/helpers/nativescript-package-resolver.js.map +1 -0
- package/helpers/ns-cli-plugins.d.ts +14 -0
- package/helpers/ns-cli-plugins.js +165 -0
- package/helpers/ns-cli-plugins.js.map +1 -0
- package/helpers/package-platform-aliases.d.ts +10 -0
- package/{dist/helpers → helpers}/package-platform-aliases.js +19 -23
- package/helpers/package-platform-aliases.js.map +1 -0
- package/helpers/postcss-platform-config.d.ts +13 -0
- package/helpers/postcss-platform-config.js +97 -0
- package/helpers/postcss-platform-config.js.map +1 -0
- package/helpers/prelink-angular.d.ts +2 -0
- package/helpers/prelink-angular.js +117 -0
- package/helpers/prelink-angular.js.map +1 -0
- package/helpers/preserve-imports.d.ts +2 -0
- package/helpers/preserve-imports.js +38 -0
- package/helpers/preserve-imports.js.map +1 -0
- package/{dist/helpers → helpers}/project.js +2 -4
- package/helpers/project.js.map +1 -0
- package/helpers/resolver.d.ts +4 -0
- package/{dist/helpers → helpers}/resolver.js +7 -6
- package/helpers/resolver.js.map +1 -0
- package/helpers/theme-core-plugins.d.ts +14 -0
- package/helpers/theme-core-plugins.js +121 -0
- package/helpers/theme-core-plugins.js.map +1 -0
- package/helpers/ts-config-paths.d.ts +10 -0
- package/{dist/helpers → helpers}/ts-config-paths.js +73 -72
- package/helpers/ts-config-paths.js.map +1 -0
- package/{dist/helpers → helpers}/utils.d.ts +10 -0
- package/helpers/utils.js +143 -0
- package/helpers/utils.js.map +1 -0
- package/{dist/helpers → helpers}/workers.js +15 -16
- package/helpers/workers.js.map +1 -0
- package/hmr/client/css-handler.d.ts +4 -0
- package/hmr/client/css-handler.js +78 -0
- package/hmr/client/css-handler.js.map +1 -0
- package/hmr/client/index.d.ts +13 -0
- package/hmr/client/index.js +1723 -0
- package/hmr/client/index.js.map +1 -0
- package/hmr/client/utils.d.ts +38 -0
- package/hmr/client/utils.js +426 -0
- package/hmr/client/utils.js.map +1 -0
- package/hmr/entry-runtime.d.ts +8 -0
- package/hmr/entry-runtime.js +135 -0
- package/hmr/entry-runtime.js.map +1 -0
- package/hmr/frameworks/angular/client/index.d.ts +8 -0
- package/hmr/frameworks/angular/client/index.js +59 -0
- package/hmr/frameworks/angular/client/index.js.map +1 -0
- package/hmr/frameworks/angular/server/linker.d.ts +1 -0
- package/hmr/frameworks/angular/server/linker.js +101 -0
- package/hmr/frameworks/angular/server/linker.js.map +1 -0
- package/hmr/frameworks/angular/server/strategy.d.ts +2 -0
- package/hmr/frameworks/angular/server/strategy.js +187 -0
- package/hmr/frameworks/angular/server/strategy.js.map +1 -0
- package/hmr/frameworks/solid/server/strategy.d.ts +2 -0
- package/hmr/frameworks/solid/server/strategy.js +56 -0
- package/hmr/frameworks/solid/server/strategy.js.map +1 -0
- package/hmr/frameworks/typescript/server/strategy.d.ts +2 -0
- package/hmr/frameworks/typescript/server/strategy.js +125 -0
- package/hmr/frameworks/typescript/server/strategy.js.map +1 -0
- package/hmr/frameworks/vue/client/index.d.ts +22 -0
- package/hmr/frameworks/vue/client/index.js +1541 -0
- package/hmr/frameworks/vue/client/index.js.map +1 -0
- package/hmr/frameworks/vue/server/compiler.d.ts +11 -0
- package/hmr/frameworks/vue/server/compiler.js +26 -0
- package/hmr/frameworks/vue/server/compiler.js.map +1 -0
- package/hmr/frameworks/vue/server/sfc-transforms.d.ts +14 -0
- package/hmr/frameworks/vue/server/sfc-transforms.js +282 -0
- package/hmr/frameworks/vue/server/sfc-transforms.js.map +1 -0
- package/hmr/frameworks/vue/server/strategy.d.ts +2 -0
- package/hmr/frameworks/vue/server/strategy.js +272 -0
- package/hmr/frameworks/vue/server/strategy.js.map +1 -0
- package/hmr/helpers/ast-extract.d.ts +6 -0
- package/hmr/helpers/ast-extract.js +72 -0
- package/hmr/helpers/ast-extract.js.map +1 -0
- package/hmr/helpers/ast-normalizer.d.ts +7 -0
- package/hmr/helpers/ast-normalizer.js +772 -0
- package/hmr/helpers/ast-normalizer.js.map +1 -0
- package/hmr/helpers/babel.d.ts +3 -0
- package/hmr/helpers/babel.js +17 -0
- package/hmr/helpers/babel.js.map +1 -0
- package/hmr/helpers/sanitize.d.ts +6 -0
- package/hmr/helpers/sanitize.js +55 -0
- package/hmr/helpers/sanitize.js.map +1 -0
- package/hmr/helpers/vendor-rewrite.d.ts +1 -0
- package/hmr/helpers/vendor-rewrite.js +35 -0
- package/hmr/helpers/vendor-rewrite.js.map +1 -0
- package/hmr/server/compiler.d.ts +2 -0
- package/hmr/server/compiler.js +75 -0
- package/hmr/server/compiler.js.map +1 -0
- package/hmr/server/constants.d.ts +14 -0
- package/hmr/server/constants.js +23 -0
- package/hmr/server/constants.js.map +1 -0
- package/hmr/server/core-sanitize.d.ts +32 -0
- package/hmr/server/core-sanitize.js +134 -0
- package/hmr/server/core-sanitize.js.map +1 -0
- package/hmr/server/framework-strategy.d.ts +68 -0
- package/hmr/server/framework-strategy.js +2 -0
- package/hmr/server/framework-strategy.js.map +1 -0
- package/hmr/server/index.d.ts +5 -0
- package/hmr/server/index.js +23 -0
- package/hmr/server/index.js.map +1 -0
- package/hmr/server/vite-plugin.d.ts +5 -0
- package/hmr/server/vite-plugin.js +44 -0
- package/hmr/server/vite-plugin.js.map +1 -0
- package/hmr/server/websocket.d.ts +21 -0
- package/hmr/server/websocket.js +5619 -0
- package/hmr/server/websocket.js.map +1 -0
- package/hmr/shared/runtime/http-only-boot.d.ts +1 -0
- package/hmr/shared/runtime/http-only-boot.js +107 -0
- package/hmr/shared/runtime/http-only-boot.js.map +1 -0
- package/hmr/shared/runtime/root-placeholder.d.ts +1 -0
- package/hmr/shared/runtime/root-placeholder.js +142 -0
- package/hmr/shared/runtime/root-placeholder.js.map +1 -0
- package/hmr/shared/runtime/vendor-bootstrap.d.ts +1 -0
- package/hmr/shared/runtime/vendor-bootstrap.js +134 -0
- package/hmr/shared/runtime/vendor-bootstrap.js.map +1 -0
- package/hmr/shared/vendor/manifest-loader.d.ts +9 -0
- package/hmr/shared/vendor/manifest-loader.js +38 -0
- package/hmr/shared/vendor/manifest-loader.js.map +1 -0
- package/hmr/shared/vendor/manifest.d.ts +35 -0
- package/hmr/shared/vendor/manifest.js +811 -0
- package/hmr/shared/vendor/manifest.js.map +1 -0
- package/hmr/shared/vendor/registry.d.ts +9 -0
- package/hmr/shared/vendor/registry.js +62 -0
- package/hmr/shared/vendor/registry.js.map +1 -0
- package/hmr/vendor-bootstrap.d.ts +3 -0
- package/hmr/vendor-bootstrap.js +32 -0
- package/hmr/vendor-bootstrap.js.map +1 -0
- package/{dist/index.d.ts → index.d.ts} +2 -0
- package/index.js +19 -0
- package/index.js.map +1 -0
- package/package.json +42 -30
- package/{dist/polyfills → polyfills}/mdn-data-at-rules.js +1 -0
- package/polyfills/mdn-data-at-rules.js.map +1 -0
- package/{dist/polyfills → polyfills}/mdn-data-properties.js +1 -0
- package/polyfills/mdn-data-properties.js.map +1 -0
- package/{dist/polyfills → polyfills}/mdn-data-syntaxes.js +1 -0
- package/polyfills/mdn-data-syntaxes.js.map +1 -0
- package/{dist/polyfills → polyfills}/module.js +1 -0
- package/polyfills/module.js.map +1 -0
- package/runtime/core-aliases-early.d.ts +1 -0
- package/runtime/core-aliases-early.js +334 -0
- package/runtime/core-aliases-early.js.map +1 -0
- package/shims/angular-animations-stub.d.ts +68 -0
- package/shims/angular-animations-stub.js +140 -0
- package/shims/angular-animations-stub.js.map +1 -0
- package/shims/node-module.d.ts +5 -0
- package/shims/node-module.js +13 -0
- package/shims/node-module.js.map +1 -0
- package/{dist/shims → shims}/react-reconciler-constants.js +2 -1
- package/shims/react-reconciler-constants.js.map +1 -0
- package/{dist/shims → shims}/react-reconciler.js +1 -0
- package/shims/react-reconciler.js.map +1 -0
- package/{dist/shims → shims}/set-value.js +5 -1
- package/shims/set-value.js.map +1 -0
- package/transformers/NativeClass/index.d.ts +2 -0
- package/transformers/NativeClass/index.js +222 -0
- package/transformers/NativeClass/index.js.map +1 -0
- package/dist/configuration/angular.js +0 -30
- package/dist/configuration/base.d.ts +0 -13
- package/dist/configuration/base.js +0 -228
- package/dist/configuration/old-without-merge-base.d.ts +0 -13
- package/dist/configuration/old-without-merge-base.js +0 -249
- package/dist/configuration/vue.js +0 -45
- package/dist/helpers/css-tree.js +0 -21
- package/dist/helpers/flavor.js +0 -40
- package/dist/helpers/global-defines.d.ts +0 -14
- package/dist/helpers/global-defines.js +0 -18
- package/dist/helpers/main-entry.d.ts +0 -5
- package/dist/helpers/main-entry.js +0 -75
- package/dist/helpers/ns-cli-plugins.d.ts +0 -17
- package/dist/helpers/ns-cli-plugins.js +0 -128
- package/dist/helpers/package-platform-aliases.d.ts +0 -4
- package/dist/helpers/resolver.d.ts +0 -4
- package/dist/helpers/ts-config-paths.d.ts +0 -4
- package/dist/helpers/utils.js +0 -94
- package/dist/hmr/hmr-angular.d.ts +0 -1
- package/dist/hmr/hmr-angular.js +0 -34
- package/dist/hmr/hmr-bridge.d.ts +0 -18
- package/dist/hmr/hmr-bridge.js +0 -154
- package/dist/hmr/hmr-client.d.ts +0 -5
- package/dist/hmr/hmr-client.js +0 -93
- package/dist/hmr/hmr-server.d.ts +0 -20
- package/dist/hmr/hmr-server.js +0 -179
- package/dist/index.js +0 -5
- package/dist/transformers/NativeClass/index.d.ts +0 -5
- package/dist/transformers/NativeClass/index.js +0 -46
- /package/{dist/helpers → helpers}/commonjs-plugins.d.ts +0 -0
- /package/{dist/helpers → helpers}/css-tree.d.ts +0 -0
- /package/{dist/helpers → helpers}/dynamic-import-plugin.d.ts +0 -0
- /package/{dist/helpers → helpers}/module-resolution.d.ts +0 -0
- /package/{dist/helpers → helpers}/nativescript-package-resolver.d.ts +0 -0
- /package/{dist/helpers → helpers}/project.d.ts +0 -0
- /package/{dist/helpers → helpers}/workers.d.ts +0 -0
- /package/{dist/polyfills → polyfills}/mdn-data-at-rules.d.ts +0 -0
- /package/{dist/polyfills → polyfills}/mdn-data-properties.d.ts +0 -0
- /package/{dist/polyfills → polyfills}/mdn-data-syntaxes.d.ts +0 -0
- /package/{dist/polyfills → polyfills}/module.d.ts +0 -0
- /package/{dist/shims → shims}/react-reconciler-constants.d.ts +0 -0
- /package/{dist/shims → shims}/react-reconciler.d.ts +0 -0
- /package/{dist/shims → shims}/set-value.d.ts +0 -0
package/dist/helpers/utils.js
DELETED
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import path from "path";
|
|
2
|
-
import fs from "fs";
|
|
3
|
-
import { transformSync } from "esbuild";
|
|
4
|
-
import { satisfies } from "semver";
|
|
5
|
-
import { createRequire } from 'node:module';
|
|
6
|
-
const require = createRequire(import.meta.url);
|
|
7
|
-
import { getPackageJson, getProjectFilePath } from "./project.js";
|
|
8
|
-
// get the name from the package for the output
|
|
9
|
-
const packageJson = getPackageJson();
|
|
10
|
-
export function nsConfigToJson() {
|
|
11
|
-
let configObject;
|
|
12
|
-
;
|
|
13
|
-
const tsPath = getProjectFilePath("nativescript.config.ts");
|
|
14
|
-
const tsCode = fs.readFileSync(tsPath, "utf-8");
|
|
15
|
-
// a) Transpile your TS config to CommonJS so we can require() it
|
|
16
|
-
const { code: cjsCode } = transformSync(tsCode, {
|
|
17
|
-
loader: "ts",
|
|
18
|
-
format: "cjs",
|
|
19
|
-
target: "esnext",
|
|
20
|
-
});
|
|
21
|
-
// b) Evaluate it in a VM-style sandbox to pull out the default export
|
|
22
|
-
const module = { exports: {} };
|
|
23
|
-
const requireFunc = (id) => require(id);
|
|
24
|
-
new Function("exports", "require", "module", "__filename", "__dirname", cjsCode)(module.exports, requireFunc, module, tsPath, path.dirname(tsPath));
|
|
25
|
-
configObject = module.exports.default ?? module.exports;
|
|
26
|
-
// ensure the config has a name
|
|
27
|
-
configObject.name = packageJson.name;
|
|
28
|
-
// ensure the main entry is set to "bundle"
|
|
29
|
-
configObject.main = "bundle";
|
|
30
|
-
return configObject;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Resolves the NativeScript platform-specific file for a given module ID.
|
|
34
|
-
* @param id The module ID to resolve.
|
|
35
|
-
* @param platform The target platform (e.g., "ios", "android").
|
|
36
|
-
* @returns The resolved file path or undefined if not found.
|
|
37
|
-
*/
|
|
38
|
-
export function resolveNativeScriptPlatformFile(id, platform) {
|
|
39
|
-
const ext = path.extname(id);
|
|
40
|
-
const base = id.slice(0, -ext.length);
|
|
41
|
-
let platformFile = `${base}.${platform}${ext}`;
|
|
42
|
-
if (fs.existsSync(platformFile)) {
|
|
43
|
-
return platformFile;
|
|
44
|
-
}
|
|
45
|
-
// core uses indices for many barrels
|
|
46
|
-
platformFile = `${base}/index.${platform}${ext}`;
|
|
47
|
-
if (fs.existsSync(platformFile)) {
|
|
48
|
-
return platformFile;
|
|
49
|
-
}
|
|
50
|
-
// fallback to non-platform file
|
|
51
|
-
return fs.existsSync(id) ? id : undefined;
|
|
52
|
-
}
|
|
53
|
-
/**
|
|
54
|
-
* Utility to get all dependencies from the project package.json.
|
|
55
|
-
* The result combines dependencies and devDependencies
|
|
56
|
-
*
|
|
57
|
-
* @returns string[] dependencies
|
|
58
|
-
*/
|
|
59
|
-
export function getAllDependencies() {
|
|
60
|
-
return [
|
|
61
|
-
...Object.keys(packageJson.dependencies ?? {}),
|
|
62
|
-
...Object.keys(packageJson.devDependencies ?? {}),
|
|
63
|
-
];
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* Check if a dependency is present in package.json
|
|
67
|
-
*/
|
|
68
|
-
export function hasDependency(packageName) {
|
|
69
|
-
try {
|
|
70
|
-
const packageJsonPath = path.resolve(process.cwd(), "package.json");
|
|
71
|
-
const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, "utf-8"));
|
|
72
|
-
return !!(packageJson.dependencies?.[packageName] ||
|
|
73
|
-
packageJson.devDependencies?.[packageName] ||
|
|
74
|
-
packageJson.peerDependencies?.[packageName]);
|
|
75
|
-
}
|
|
76
|
-
catch {
|
|
77
|
-
return false;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Get the version of a dependency from package.json
|
|
82
|
-
*/
|
|
83
|
-
export function getDependencyVersion(packageName) {
|
|
84
|
-
try {
|
|
85
|
-
const packageJsonPath = path.resolve(process.cwd(), "package.json");
|
|
86
|
-
const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, "utf-8"));
|
|
87
|
-
return (packageJson.dependencies?.[packageName] ||
|
|
88
|
-
packageJson.devDependencies?.[packageName] ||
|
|
89
|
-
packageJson.peerDependencies?.[packageName]);
|
|
90
|
-
}
|
|
91
|
-
catch {
|
|
92
|
-
return undefined;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare function handleAngularHmrUpdate(): void;
|
package/dist/hmr/hmr-angular.js
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { isDevMode, ɵresetCompiledComponents,
|
|
2
|
-
// @ts-ignore
|
|
3
|
-
} from "@angular/core";
|
|
4
|
-
export function handleAngularHmrUpdate() {
|
|
5
|
-
// Reset JIT compiled components cache
|
|
6
|
-
ɵresetCompiledComponents();
|
|
7
|
-
try {
|
|
8
|
-
console.log(`typeof global["__cleanup_ng_hot__"]`, typeof global["__cleanup_ng_hot__"]);
|
|
9
|
-
if (global["__cleanup_ng_hot__"])
|
|
10
|
-
global["__cleanup_ng_hot__"]();
|
|
11
|
-
global["__reboot_ng_modules__"]();
|
|
12
|
-
console.log('angular called __reboot_ng_modules__!');
|
|
13
|
-
// need to call some kind of apply here?
|
|
14
|
-
// Webpack would call in this order with angular-hot-loader/hmr-accept:
|
|
15
|
-
/**
|
|
16
|
-
* angular hot dispose called!
|
|
17
|
-
hot dispose called here?!
|
|
18
|
-
__cleanup_ng_hot__ called!
|
|
19
|
-
angular hot accept about to be called!
|
|
20
|
-
Angular is running in development mode.
|
|
21
|
-
[HMR][bd598ae5b97083449f33] success | Successfully applied update.
|
|
22
|
-
calling global.__onLiveSync!
|
|
23
|
-
*/
|
|
24
|
-
global.__onLiveSync();
|
|
25
|
-
}
|
|
26
|
-
catch (e) {
|
|
27
|
-
console.error("[NG HMR] Error disposing previous module");
|
|
28
|
-
console.error(e, e?.stack);
|
|
29
|
-
// HMR breaks when rejecting the main module dispose, so we manually trigger an HMR restart
|
|
30
|
-
// const hash = __webpack_require__.h();
|
|
31
|
-
// console.log(`[HMR][${hash}] failure | Error disposing previous module`);
|
|
32
|
-
// throw e;
|
|
33
|
-
}
|
|
34
|
-
}
|
package/dist/hmr/hmr-bridge.d.ts
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Simple HMR Notification Bridge
|
|
3
|
-
*
|
|
4
|
-
* This creates a lightweight WebSocket server that the NativeScript CLI
|
|
5
|
-
* can notify when builds complete, and forwards those to the app.
|
|
6
|
-
*/
|
|
7
|
-
declare class SimpleHMRBridge {
|
|
8
|
-
private wsServer;
|
|
9
|
-
private connectedClients;
|
|
10
|
-
private buildProcess;
|
|
11
|
-
start(): Promise<void>;
|
|
12
|
-
private startWebSocketServer;
|
|
13
|
-
private startNativeScriptBuild;
|
|
14
|
-
private parseBuildOutput;
|
|
15
|
-
private notifyClients;
|
|
16
|
-
stop(): Promise<void>;
|
|
17
|
-
}
|
|
18
|
-
export { SimpleHMRBridge };
|
package/dist/hmr/hmr-bridge.js
DELETED
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Simple HMR Notification Bridge
|
|
3
|
-
*
|
|
4
|
-
* This creates a lightweight WebSocket server that the NativeScript CLI
|
|
5
|
-
* can notify when builds complete, and forwards those to the app.
|
|
6
|
-
*/
|
|
7
|
-
import { WebSocketServer } from 'ws';
|
|
8
|
-
import WebSocketType from 'ws';
|
|
9
|
-
import { spawn } from 'child_process';
|
|
10
|
-
import { pathToFileURL } from 'node:url';
|
|
11
|
-
import { resolve } from 'node:path';
|
|
12
|
-
const isMain = () => typeof process !== 'undefined' &&
|
|
13
|
-
!!process.argv?.[1] &&
|
|
14
|
-
import.meta.url === pathToFileURL(resolve(process.argv[1])).href;
|
|
15
|
-
class SimpleHMRBridge {
|
|
16
|
-
constructor() {
|
|
17
|
-
this.connectedClients = new Set();
|
|
18
|
-
}
|
|
19
|
-
async start() {
|
|
20
|
-
console.log('🔥 Starting Simple HMR Bridge...');
|
|
21
|
-
// Start WebSocket server for NativeScript app
|
|
22
|
-
this.startWebSocketServer();
|
|
23
|
-
// Start NativeScript build process
|
|
24
|
-
this.startNativeScriptBuild();
|
|
25
|
-
console.log('🔥 HMR Bridge ready!');
|
|
26
|
-
}
|
|
27
|
-
startWebSocketServer() {
|
|
28
|
-
const HMR_WS_PORT = 24678;
|
|
29
|
-
this.wsServer = new WebSocketServer({ port: HMR_WS_PORT });
|
|
30
|
-
this.wsServer.on('connection', (ws) => {
|
|
31
|
-
console.log('🔥 NativeScript client connected to HMR bridge');
|
|
32
|
-
this.connectedClients.add(ws);
|
|
33
|
-
// Send connection confirmation
|
|
34
|
-
ws.send(JSON.stringify({
|
|
35
|
-
type: 'connected',
|
|
36
|
-
timestamp: Date.now()
|
|
37
|
-
}));
|
|
38
|
-
ws.on('close', () => {
|
|
39
|
-
console.log('🔥 NativeScript client disconnected');
|
|
40
|
-
this.connectedClients.delete(ws);
|
|
41
|
-
});
|
|
42
|
-
ws.on('message', (message) => {
|
|
43
|
-
try {
|
|
44
|
-
const data = JSON.parse(message.toString());
|
|
45
|
-
console.log('🔥 Received from NativeScript:', data);
|
|
46
|
-
}
|
|
47
|
-
catch (e) {
|
|
48
|
-
console.error('🔥 Invalid message from NativeScript:', e);
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
});
|
|
52
|
-
console.log(`🔥 HMR bridge listening on ws://localhost:${HMR_WS_PORT}`);
|
|
53
|
-
}
|
|
54
|
-
startNativeScriptBuild() {
|
|
55
|
-
console.log('🔥 Starting NativeScript build with HMR notifications...');
|
|
56
|
-
// Get platform from command line arguments (default to 'ios' if not provided)
|
|
57
|
-
const platform = process.argv[2] || 'ios';
|
|
58
|
-
console.log(`🔥 Building for platform: ${platform}`);
|
|
59
|
-
// Start ns run with specified platform
|
|
60
|
-
const args = ['debug', platform];
|
|
61
|
-
this.buildProcess = spawn('ns', args, {
|
|
62
|
-
cwd: process.cwd(),
|
|
63
|
-
stdio: ['inherit', 'pipe', 'pipe'],
|
|
64
|
-
env: {
|
|
65
|
-
...process.env,
|
|
66
|
-
NS_HMR_BRIDGE: 'true' // Signal to our Vite config that HMR bridge is active
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
this.buildProcess.stdout.on('data', (data) => {
|
|
70
|
-
const output = data.toString();
|
|
71
|
-
process.stdout.write(output);
|
|
72
|
-
// Listen for build completion messages
|
|
73
|
-
this.parseBuildOutput(output);
|
|
74
|
-
});
|
|
75
|
-
this.buildProcess.stderr.on('data', (data) => {
|
|
76
|
-
process.stderr.write(data);
|
|
77
|
-
});
|
|
78
|
-
this.buildProcess.on('close', (code) => {
|
|
79
|
-
console.log(`🔥 NativeScript build process exited with code ${code}`);
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
parseBuildOutput(output) {
|
|
83
|
-
// Look for our HMR indicators in the build output
|
|
84
|
-
const lines = output.split('\n');
|
|
85
|
-
for (const line of lines) {
|
|
86
|
-
// Look for our HMR build completion messages
|
|
87
|
-
if (line.includes('🔥 HMR update - copying only changed files')) {
|
|
88
|
-
// Extract changed files from the next lines
|
|
89
|
-
const changedFilesMatch = line.match(/🔥 HMR update - copying only changed files for: (.+)/);
|
|
90
|
-
if (changedFilesMatch) {
|
|
91
|
-
try {
|
|
92
|
-
const changedFiles = JSON.parse(changedFilesMatch[1].replace(/'/g, '"'));
|
|
93
|
-
this.notifyClients({
|
|
94
|
-
type: 'build-complete',
|
|
95
|
-
timestamp: Date.now(),
|
|
96
|
-
changedFiles,
|
|
97
|
-
buildType: 'incremental',
|
|
98
|
-
isHMR: true
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
catch (e) {
|
|
102
|
-
console.log('🔥 Could not parse changed files from:', changedFilesMatch[1]);
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
else if (line.includes('🔥 Full build - copying all files')) {
|
|
107
|
-
this.notifyClients({
|
|
108
|
-
type: 'build-complete',
|
|
109
|
-
timestamp: Date.now(),
|
|
110
|
-
buildType: 'full',
|
|
111
|
-
isHMR: false
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
else if (line.includes('Vite build completed!')) {
|
|
115
|
-
// Build is done, notify clients
|
|
116
|
-
console.log('🔥 Build completed, notifying clients...');
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
notifyClients(update) {
|
|
121
|
-
const message = JSON.stringify(update);
|
|
122
|
-
let sentCount = 0;
|
|
123
|
-
this.connectedClients.forEach((client) => {
|
|
124
|
-
if (client.readyState === WebSocketType.OPEN) {
|
|
125
|
-
client.send(message);
|
|
126
|
-
sentCount++;
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
if (sentCount > 0) {
|
|
130
|
-
console.log(`🔥 Notified ${sentCount} clients of update:`, update.type);
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
async stop() {
|
|
134
|
-
console.log('🔥 Stopping HMR bridge...');
|
|
135
|
-
if (this.buildProcess) {
|
|
136
|
-
this.buildProcess.kill('SIGTERM');
|
|
137
|
-
}
|
|
138
|
-
if (this.wsServer) {
|
|
139
|
-
this.wsServer.close();
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
// Export for use in startup script
|
|
144
|
-
export { SimpleHMRBridge };
|
|
145
|
-
// Auto-start if run directly
|
|
146
|
-
if (isMain()) {
|
|
147
|
-
const bridge = new SimpleHMRBridge();
|
|
148
|
-
bridge.start().catch(console.error);
|
|
149
|
-
// Handle graceful shutdown
|
|
150
|
-
process.on('SIGINT', () => {
|
|
151
|
-
console.log('\n🔥 Shutting down HMR bridge...');
|
|
152
|
-
bridge.stop().then(() => process.exit(0));
|
|
153
|
-
});
|
|
154
|
-
}
|
package/dist/hmr/hmr-client.d.ts
DELETED
package/dist/hmr/hmr-client.js
DELETED
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Simple NativeScript HMR Client for Vite
|
|
3
|
-
* Based on @nativescript/webpack loaders but simplified for Vite
|
|
4
|
-
*/
|
|
5
|
-
// Import WebSocket polyfill directly
|
|
6
|
-
import { WebSocket as NativeScriptWebSocket } from '@valor/nativescript-websockets/websocket';
|
|
7
|
-
// Ensure WebSocket is available globally for other code
|
|
8
|
-
if (typeof global !== 'undefined') {
|
|
9
|
-
global.WebSocket = NativeScriptWebSocket;
|
|
10
|
-
}
|
|
11
|
-
// Make WebSocket available in current scope
|
|
12
|
-
const WebSocket = NativeScriptWebSocket;
|
|
13
|
-
// import { Application } from "@nativescript/core";
|
|
14
|
-
let hmrBootEmittedSymbol = Symbol.for("HMRBootEmitted");
|
|
15
|
-
let originalLiveSyncSymbol = Symbol.for("OriginalLiveSync");
|
|
16
|
-
let hmrRuntimeLastLiveSyncSymbol = Symbol.for("HMRRuntimeLastLiveSync");
|
|
17
|
-
if (global.__onLiveSync !== global[hmrRuntimeLastLiveSyncSymbol]) {
|
|
18
|
-
// we store the original liveSync here in case this code runs again
|
|
19
|
-
// which happens when you module.hot.accept() the main file
|
|
20
|
-
global[originalLiveSyncSymbol] = global.__onLiveSync;
|
|
21
|
-
}
|
|
22
|
-
global[hmrRuntimeLastLiveSyncSymbol] = async function () {
|
|
23
|
-
console.log(`calling global[hmrRuntimeLastLiveSyncSymbol]`);
|
|
24
|
-
await global[originalLiveSyncSymbol]();
|
|
25
|
-
};
|
|
26
|
-
global.__onLiveSync = global[hmrRuntimeLastLiveSyncSymbol];
|
|
27
|
-
if (!global[hmrBootEmittedSymbol]) {
|
|
28
|
-
global[hmrBootEmittedSymbol] = true;
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Note: allow vite to inject each flavor client handling
|
|
32
|
-
* Start Manual Flavor Testing
|
|
33
|
-
*/
|
|
34
|
-
const flavor = "angular";
|
|
35
|
-
import { handleAngularHmrUpdate } from "./hmr-angular.js";
|
|
36
|
-
/**
|
|
37
|
-
* End Manual Flavor Testing
|
|
38
|
-
*/
|
|
39
|
-
class SimpleNativeScriptHMRClient {
|
|
40
|
-
constructor() {
|
|
41
|
-
this.ws = null;
|
|
42
|
-
console.log("🔥 Simple HMR Client starting...");
|
|
43
|
-
console.log("🔥 WebSocket available:", typeof WebSocket !== 'undefined');
|
|
44
|
-
console.log("🔥 global.WebSocket available:", typeof global !== 'undefined' && typeof global.WebSocket !== 'undefined');
|
|
45
|
-
this.connect();
|
|
46
|
-
}
|
|
47
|
-
connect() {
|
|
48
|
-
try {
|
|
49
|
-
// Check if WebSocket is available
|
|
50
|
-
if (typeof WebSocket === 'undefined') {
|
|
51
|
-
console.error("🔥 WebSocket is not available - HMR disabled");
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
this.ws = new WebSocket("ws://localhost:24678");
|
|
55
|
-
this.ws.onopen = () => {
|
|
56
|
-
console.log("🔥 HMR connected");
|
|
57
|
-
};
|
|
58
|
-
this.ws.onmessage = (event) => {
|
|
59
|
-
try {
|
|
60
|
-
const update = JSON.parse(event.data);
|
|
61
|
-
this.handleUpdate(update);
|
|
62
|
-
}
|
|
63
|
-
catch (error) {
|
|
64
|
-
console.error("🔥 HMR message error:", error);
|
|
65
|
-
}
|
|
66
|
-
};
|
|
67
|
-
}
|
|
68
|
-
catch (error) {
|
|
69
|
-
console.error("🔥 HMR connection failed:", error);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
handleUpdate(update) {
|
|
73
|
-
console.log("🔥 HMR update received:", update.type);
|
|
74
|
-
if (update.type === "build-complete" && update.isHMR) {
|
|
75
|
-
// skip very first one since it's initial build
|
|
76
|
-
console.log("🔥 Applying HMR update for:", update.changedFiles);
|
|
77
|
-
switch (flavor) {
|
|
78
|
-
case "angular":
|
|
79
|
-
// Handle Angular specific HMR updates
|
|
80
|
-
handleAngularHmrUpdate();
|
|
81
|
-
break;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
// Initialize on app launch
|
|
87
|
-
let hmrClient;
|
|
88
|
-
if (!hmrClient) {
|
|
89
|
-
console.log("🔥 Initializing Simple NativeScript HMR Client");
|
|
90
|
-
// Application.on(Application.launchEvent, () => {
|
|
91
|
-
hmrClient = new SimpleNativeScriptHMRClient();
|
|
92
|
-
// });
|
|
93
|
-
}
|
package/dist/hmr/hmr-server.d.ts
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* NativeScript True HMR Implementation
|
|
3
|
-
*
|
|
4
|
-
* This creates a bridge between Vite's dev server HMR and NativeScript runtime
|
|
5
|
-
* to enable true hot module replacement without losing application state.
|
|
6
|
-
*/
|
|
7
|
-
declare class NativeScriptHMRServer {
|
|
8
|
-
private viteServer;
|
|
9
|
-
private wsServer;
|
|
10
|
-
private buildProcess;
|
|
11
|
-
private connectedClients;
|
|
12
|
-
start(): Promise<void>;
|
|
13
|
-
private startViteDevServer;
|
|
14
|
-
private startHMRBridge;
|
|
15
|
-
private handleViteHMRMessage;
|
|
16
|
-
private broadcastToClients;
|
|
17
|
-
private startBuildProcess;
|
|
18
|
-
stop(): Promise<void>;
|
|
19
|
-
}
|
|
20
|
-
export { NativeScriptHMRServer };
|
package/dist/hmr/hmr-server.js
DELETED
|
@@ -1,179 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* NativeScript True HMR Implementation
|
|
3
|
-
*
|
|
4
|
-
* This creates a bridge between Vite's dev server HMR and NativeScript runtime
|
|
5
|
-
* to enable true hot module replacement without losing application state.
|
|
6
|
-
*/
|
|
7
|
-
import { createServer } from 'vite';
|
|
8
|
-
import { spawn } from 'child_process';
|
|
9
|
-
import { WebSocketServer, WebSocket } from 'ws';
|
|
10
|
-
import path from 'path';
|
|
11
|
-
import fs from 'fs';
|
|
12
|
-
import { getProjectFilePath } from '../helpers/project.js';
|
|
13
|
-
const HMR_WS_PORT = 24678; // Different from Vite's default
|
|
14
|
-
const VITE_DEV_PORT = 5173;
|
|
15
|
-
class NativeScriptHMRServer {
|
|
16
|
-
constructor() {
|
|
17
|
-
this.connectedClients = new Set();
|
|
18
|
-
}
|
|
19
|
-
async start() {
|
|
20
|
-
console.log('🔥 Starting NativeScript True HMR...');
|
|
21
|
-
// 1. Start Vite dev server for true HMR
|
|
22
|
-
await this.startViteDevServer();
|
|
23
|
-
// 2. Start WebSocket bridge for NativeScript
|
|
24
|
-
await this.startHMRBridge();
|
|
25
|
-
// 3. Start build process for NativeScript integration
|
|
26
|
-
await this.startBuildProcess();
|
|
27
|
-
console.log('🔥 True HMR ready! Connect your NativeScript app.');
|
|
28
|
-
}
|
|
29
|
-
async startViteDevServer() {
|
|
30
|
-
console.log('🔥 Starting Vite dev server...');
|
|
31
|
-
this.viteServer = await createServer({
|
|
32
|
-
configFile: getProjectFilePath('vite.config.ts'),
|
|
33
|
-
server: {
|
|
34
|
-
port: VITE_DEV_PORT,
|
|
35
|
-
hmr: {
|
|
36
|
-
port: VITE_DEV_PORT + 1, // Vite's internal HMR port
|
|
37
|
-
}
|
|
38
|
-
},
|
|
39
|
-
mode: 'ios' // or get from args
|
|
40
|
-
});
|
|
41
|
-
await this.viteServer.listen();
|
|
42
|
-
console.log(`🔥 Vite dev server running on http://localhost:${VITE_DEV_PORT}`);
|
|
43
|
-
// Hook into Vite's HMR system
|
|
44
|
-
this.viteServer.ws.on('send', (data) => {
|
|
45
|
-
this.handleViteHMRMessage(data);
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
async startHMRBridge() {
|
|
49
|
-
console.log('🔥 Starting HMR WebSocket bridge...');
|
|
50
|
-
this.wsServer = new WebSocketServer({ port: HMR_WS_PORT });
|
|
51
|
-
this.wsServer.on('connection', (ws) => {
|
|
52
|
-
console.log('🔥 NativeScript client connected to HMR bridge');
|
|
53
|
-
this.connectedClients.add(ws);
|
|
54
|
-
// Send connection confirmation
|
|
55
|
-
ws.send(JSON.stringify({
|
|
56
|
-
type: 'connected',
|
|
57
|
-
timestamp: Date.now()
|
|
58
|
-
}));
|
|
59
|
-
ws.on('close', () => {
|
|
60
|
-
console.log('🔥 NativeScript client disconnected');
|
|
61
|
-
this.connectedClients.delete(ws);
|
|
62
|
-
});
|
|
63
|
-
ws.on('message', (message) => {
|
|
64
|
-
try {
|
|
65
|
-
const data = JSON.parse(message.toString());
|
|
66
|
-
console.log('🔥 Received from NativeScript:', data);
|
|
67
|
-
}
|
|
68
|
-
catch (e) {
|
|
69
|
-
console.error('🔥 Invalid message from NativeScript:', e);
|
|
70
|
-
}
|
|
71
|
-
});
|
|
72
|
-
});
|
|
73
|
-
console.log(`🔥 HMR bridge listening on ws://localhost:${HMR_WS_PORT}`);
|
|
74
|
-
}
|
|
75
|
-
handleViteHMRMessage(data) {
|
|
76
|
-
if (!data || typeof data !== 'object')
|
|
77
|
-
return;
|
|
78
|
-
// Filter out irrelevant file changes
|
|
79
|
-
if (data.updates) {
|
|
80
|
-
const relevantUpdates = data.updates.filter(update => {
|
|
81
|
-
const path = update.path || '';
|
|
82
|
-
return (path.includes('/src/') ||
|
|
83
|
-
path.endsWith('package.json') ||
|
|
84
|
-
path.endsWith('vite.config.ts') ||
|
|
85
|
-
path.endsWith('tsconfig.json') ||
|
|
86
|
-
path.endsWith('nativescript.config.ts'));
|
|
87
|
-
});
|
|
88
|
-
if (relevantUpdates.length === 0) {
|
|
89
|
-
console.log('🔥 Ignoring HMR update for non-src files');
|
|
90
|
-
return; // Skip if no relevant updates
|
|
91
|
-
}
|
|
92
|
-
data.updates = relevantUpdates;
|
|
93
|
-
}
|
|
94
|
-
console.log('🔥 Vite HMR update:', data);
|
|
95
|
-
// Transform Vite HMR message to NativeScript format
|
|
96
|
-
let hmrUpdate;
|
|
97
|
-
if (data.type === 'update') {
|
|
98
|
-
// CSS updates
|
|
99
|
-
const cssUpdates = data.updates?.filter(u => u.path.endsWith('.css') || u.path.endsWith('.scss'));
|
|
100
|
-
if (cssUpdates?.length > 0) {
|
|
101
|
-
hmrUpdate = {
|
|
102
|
-
type: 'css-update',
|
|
103
|
-
path: cssUpdates[0].path,
|
|
104
|
-
timestamp: Date.now(),
|
|
105
|
-
updates: cssUpdates
|
|
106
|
-
};
|
|
107
|
-
}
|
|
108
|
-
// JS/TS updates
|
|
109
|
-
else {
|
|
110
|
-
hmrUpdate = {
|
|
111
|
-
type: 'js-update',
|
|
112
|
-
timestamp: Date.now(),
|
|
113
|
-
updates: data.updates
|
|
114
|
-
};
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
else if (data.type === 'full-reload') {
|
|
118
|
-
hmrUpdate = {
|
|
119
|
-
type: 'full-reload',
|
|
120
|
-
timestamp: Date.now()
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
|
-
else {
|
|
124
|
-
return; // Ignore other message types
|
|
125
|
-
}
|
|
126
|
-
// Broadcast to connected NativeScript clients
|
|
127
|
-
this.broadcastToClients(hmrUpdate);
|
|
128
|
-
}
|
|
129
|
-
broadcastToClients(update) {
|
|
130
|
-
const message = JSON.stringify(update);
|
|
131
|
-
let sentCount = 0;
|
|
132
|
-
this.connectedClients.forEach((client) => {
|
|
133
|
-
if (client.readyState === WebSocket.OPEN) {
|
|
134
|
-
client.send(message);
|
|
135
|
-
sentCount++;
|
|
136
|
-
}
|
|
137
|
-
});
|
|
138
|
-
console.log(`🔥 Broadcasted ${update.type} to ${sentCount} clients`);
|
|
139
|
-
}
|
|
140
|
-
async startBuildProcess() {
|
|
141
|
-
// This runs the traditional build process for initial bundle creation
|
|
142
|
-
// but won't be used for HMR - that's handled by the dev server
|
|
143
|
-
console.log('🔥 Starting initial build process...');
|
|
144
|
-
// We might not need this if we can serve directly from Vite dev server
|
|
145
|
-
// But keeping it for compatibility with NativeScript CLI expectations
|
|
146
|
-
}
|
|
147
|
-
async stop() {
|
|
148
|
-
console.log('🔥 Stopping HMR server...');
|
|
149
|
-
if (this.viteServer) {
|
|
150
|
-
await this.viteServer.close();
|
|
151
|
-
}
|
|
152
|
-
if (this.wsServer) {
|
|
153
|
-
this.wsServer.close();
|
|
154
|
-
}
|
|
155
|
-
if (this.buildProcess) {
|
|
156
|
-
this.buildProcess.kill();
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
// CLI interface
|
|
161
|
-
async function main() {
|
|
162
|
-
const hmrServer = new NativeScriptHMRServer();
|
|
163
|
-
// Handle graceful shutdown
|
|
164
|
-
process.on('SIGINT', async () => {
|
|
165
|
-
await hmrServer.stop();
|
|
166
|
-
process.exit(0);
|
|
167
|
-
});
|
|
168
|
-
process.on('SIGTERM', async () => {
|
|
169
|
-
await hmrServer.stop();
|
|
170
|
-
process.exit(0);
|
|
171
|
-
});
|
|
172
|
-
await hmrServer.start();
|
|
173
|
-
}
|
|
174
|
-
// Export for use in other contexts
|
|
175
|
-
export { NativeScriptHMRServer };
|
|
176
|
-
// Run if called directly
|
|
177
|
-
// if (require.main === module) {
|
|
178
|
-
// main().catch(console.error);
|
|
179
|
-
// }
|
package/dist/index.js
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import ts from 'typescript';
|
|
2
|
-
/**
|
|
3
|
-
* A TypeScript transform that compiles classes marked with `@NativeClass` as es5
|
|
4
|
-
*/
|
|
5
|
-
export default function (ctx) {
|
|
6
|
-
function isNativeClassExtension(node) {
|
|
7
|
-
let decorators;
|
|
8
|
-
if ('canHaveDecorators' in ts && ts.canHaveDecorators(node)) {
|
|
9
|
-
// use the newer decorators API when using a newer typescript version
|
|
10
|
-
// @ts-ignore
|
|
11
|
-
decorators = ts.getDecorators(node);
|
|
12
|
-
}
|
|
13
|
-
else {
|
|
14
|
-
// fallback to old behavior on older typescript versions
|
|
15
|
-
decorators = node.decorators;
|
|
16
|
-
}
|
|
17
|
-
return !!decorators?.some((d) => {
|
|
18
|
-
const fullText = d.getFullText().trim();
|
|
19
|
-
if (fullText.indexOf('@NativeClass') > -1) {
|
|
20
|
-
console.log('found @NativeClass decorator in:', fullText);
|
|
21
|
-
}
|
|
22
|
-
return fullText.indexOf('@NativeClass') > -1;
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
function visitNode(node) {
|
|
26
|
-
if (ts.isClassDeclaration(node) && isNativeClassExtension(node)) {
|
|
27
|
-
return createHelper(node);
|
|
28
|
-
}
|
|
29
|
-
return ts.visitEachChild(node, visitNode, ctx);
|
|
30
|
-
}
|
|
31
|
-
function createHelper(node) {
|
|
32
|
-
// we remove the decorator for now!
|
|
33
|
-
return ts.factory.createIdentifier(ts
|
|
34
|
-
.transpileModule(node.getText().replace(/@NativeClass(\((.|\n)*?\))?/gm, ''), {
|
|
35
|
-
compilerOptions: {
|
|
36
|
-
noEmitHelpers: true,
|
|
37
|
-
module: ts.ModuleKind.ESNext,
|
|
38
|
-
target: ts.ScriptTarget.ES5,
|
|
39
|
-
experimentalDecorators: true,
|
|
40
|
-
emitDecoratorMetadata: true,
|
|
41
|
-
},
|
|
42
|
-
})
|
|
43
|
-
.outputText.replace(/(Object\.defineProperty\(.*?{.*?)(enumerable:\s*false)(.*?}\))/gs, '$1enumerable: true$3'));
|
|
44
|
-
}
|
|
45
|
-
return (source) => ts.factory.updateSourceFile(source, ts.visitNodes(source.statements, visitNode));
|
|
46
|
-
}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|