@nativescript/vite 8.0.0-alpha.5 → 8.0.0-alpha.50

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.
Files changed (424) hide show
  1. package/README.md +51 -11
  2. package/bin/cli.cjs +8 -14
  3. package/configuration/angular.d.ts +34 -1
  4. package/configuration/angular.js +376 -165
  5. package/configuration/angular.js.map +1 -1
  6. package/configuration/base.js +241 -51
  7. package/configuration/base.js.map +1 -1
  8. package/configuration/javascript.js +14 -93
  9. package/configuration/javascript.js.map +1 -1
  10. package/configuration/react.js +41 -73
  11. package/configuration/react.js.map +1 -1
  12. package/configuration/solid.js +51 -6
  13. package/configuration/solid.js.map +1 -1
  14. package/configuration/typescript.js +12 -93
  15. package/configuration/typescript.js.map +1 -1
  16. package/helpers/app-components.d.ts +2 -1
  17. package/helpers/app-components.js.map +1 -1
  18. package/helpers/app-css-state.d.ts +8 -0
  19. package/helpers/app-css-state.js +8 -0
  20. package/helpers/app-css-state.js.map +1 -0
  21. package/helpers/bundler-context.d.ts +11 -0
  22. package/helpers/bundler-context.js +71 -0
  23. package/helpers/bundler-context.js.map +1 -0
  24. package/helpers/cli-flags.d.ts +12 -0
  25. package/helpers/cli-flags.js +34 -0
  26. package/helpers/cli-flags.js.map +1 -1
  27. package/helpers/css-platform-plugin.d.ts +14 -0
  28. package/helpers/css-platform-plugin.js +43 -25
  29. package/helpers/css-platform-plugin.js.map +1 -1
  30. package/helpers/dev-host.d.ts +360 -0
  31. package/helpers/dev-host.js +694 -0
  32. package/helpers/dev-host.js.map +1 -0
  33. package/helpers/dynamic-import-plugin.js +1 -1
  34. package/helpers/dynamic-import-plugin.js.map +1 -1
  35. package/helpers/esbuild-platform-resolver.js +4 -1
  36. package/helpers/esbuild-platform-resolver.js.map +1 -1
  37. package/helpers/external-configs.d.ts +10 -12
  38. package/helpers/external-configs.js +58 -35
  39. package/helpers/external-configs.js.map +1 -1
  40. package/helpers/global-defines.d.ts +142 -0
  41. package/helpers/global-defines.js +213 -11
  42. package/helpers/global-defines.js.map +1 -1
  43. package/helpers/hmr-scope.d.ts +26 -0
  44. package/helpers/hmr-scope.js +67 -0
  45. package/helpers/hmr-scope.js.map +1 -0
  46. package/helpers/init.js +0 -18
  47. package/helpers/init.js.map +1 -1
  48. package/helpers/logging.d.ts +1 -0
  49. package/helpers/logging.js +65 -4
  50. package/helpers/logging.js.map +1 -1
  51. package/helpers/main-entry.d.ts +3 -1
  52. package/helpers/main-entry.js +301 -53
  53. package/helpers/main-entry.js.map +1 -1
  54. package/helpers/nativeclass-esbuild-plugin.d.ts +2 -1
  55. package/helpers/nativeclass-esbuild-plugin.js.map +1 -1
  56. package/helpers/nativeclass-transform.js +5 -6
  57. package/helpers/nativeclass-transform.js.map +1 -1
  58. package/helpers/nativeclass-transformer-plugin.d.ts +9 -2
  59. package/helpers/nativeclass-transformer-plugin.js +157 -14
  60. package/helpers/nativeclass-transformer-plugin.js.map +1 -1
  61. package/helpers/nativescript-package-resolver.js +10 -62
  62. package/helpers/nativescript-package-resolver.js.map +1 -1
  63. package/helpers/normalize-id.d.ts +42 -0
  64. package/helpers/normalize-id.js +60 -0
  65. package/helpers/normalize-id.js.map +1 -0
  66. package/helpers/ns-core-url.d.ts +29 -7
  67. package/helpers/ns-core-url.js +69 -12
  68. package/helpers/ns-core-url.js.map +1 -1
  69. package/helpers/optimize-deps.d.ts +16 -0
  70. package/helpers/optimize-deps.js +17 -0
  71. package/helpers/optimize-deps.js.map +1 -0
  72. package/helpers/package-platform-aliases.js +34 -49
  73. package/helpers/package-platform-aliases.js.map +1 -1
  74. package/helpers/platform-types.d.ts +2 -0
  75. package/helpers/platform-types.js +2 -0
  76. package/helpers/platform-types.js.map +1 -0
  77. package/helpers/postcss-platform-config.d.ts +17 -1
  78. package/helpers/postcss-platform-config.js +20 -37
  79. package/helpers/postcss-platform-config.js.map +1 -1
  80. package/helpers/project.d.ts +35 -0
  81. package/helpers/project.js +120 -2
  82. package/helpers/project.js.map +1 -1
  83. package/helpers/resolve-main-field-platform.d.ts +20 -0
  84. package/helpers/resolve-main-field-platform.js +49 -0
  85. package/helpers/resolve-main-field-platform.js.map +1 -0
  86. package/helpers/resolver.js +17 -2
  87. package/helpers/resolver.js.map +1 -1
  88. package/helpers/theme-core-plugins.js +1 -1
  89. package/helpers/theme-core-plugins.js.map +1 -1
  90. package/helpers/ts-config-paths.d.ts +14 -0
  91. package/helpers/ts-config-paths.js +90 -9
  92. package/helpers/ts-config-paths.js.map +1 -1
  93. package/helpers/typescript-check.d.ts +2 -1
  94. package/helpers/typescript-check.js +2 -2
  95. package/helpers/typescript-check.js.map +1 -1
  96. package/helpers/ui-registration.d.ts +21 -0
  97. package/helpers/ui-registration.js +156 -0
  98. package/helpers/ui-registration.js.map +1 -0
  99. package/helpers/utils.d.ts +9 -0
  100. package/helpers/utils.js +22 -2
  101. package/helpers/utils.js.map +1 -1
  102. package/helpers/workers.d.ts +20 -19
  103. package/helpers/workers.js +624 -4
  104. package/helpers/workers.js.map +1 -1
  105. package/hmr/client/css-handler.d.ts +2 -1
  106. package/hmr/client/css-handler.js +50 -26
  107. package/hmr/client/css-handler.js.map +1 -1
  108. package/hmr/client/css-update-overlay.d.ts +18 -0
  109. package/hmr/client/css-update-overlay.js +27 -0
  110. package/hmr/client/css-update-overlay.js.map +1 -0
  111. package/hmr/client/framework-client-strategy.d.ts +79 -0
  112. package/hmr/client/framework-client-strategy.js +19 -0
  113. package/hmr/client/framework-client-strategy.js.map +1 -0
  114. package/hmr/client/hmr-pending-overlay.d.ts +13 -0
  115. package/hmr/client/hmr-pending-overlay.js +60 -0
  116. package/hmr/client/hmr-pending-overlay.js.map +1 -0
  117. package/hmr/client/index.js +891 -220
  118. package/hmr/client/index.js.map +1 -1
  119. package/hmr/client/utils.d.ts +7 -1
  120. package/hmr/client/utils.js +207 -29
  121. package/hmr/client/utils.js.map +1 -1
  122. package/hmr/entry-runtime.d.ts +2 -1
  123. package/hmr/entry-runtime.js +256 -69
  124. package/hmr/entry-runtime.js.map +1 -1
  125. package/hmr/frameworks/angular/build/angular-linker.d.ts +12 -0
  126. package/hmr/frameworks/angular/build/angular-linker.js +109 -0
  127. package/hmr/frameworks/angular/build/angular-linker.js.map +1 -0
  128. package/hmr/frameworks/angular/build/inject-component-hmr-registration.d.ts +112 -0
  129. package/hmr/frameworks/angular/build/inject-component-hmr-registration.js +291 -0
  130. package/hmr/frameworks/angular/build/inject-component-hmr-registration.js.map +1 -0
  131. package/hmr/frameworks/angular/build/inject-hmr-vite-ignore.d.ts +75 -0
  132. package/hmr/frameworks/angular/build/inject-hmr-vite-ignore.js +221 -0
  133. package/hmr/frameworks/angular/build/inject-hmr-vite-ignore.js.map +1 -0
  134. package/{helpers/angular → hmr/frameworks/angular/build}/inline-decorator-component-templates.js +1 -170
  135. package/hmr/frameworks/angular/build/inline-decorator-component-templates.js.map +1 -0
  136. package/hmr/frameworks/angular/build/js-lexer.d.ts +4 -0
  137. package/{helpers/angular/synthesize-decorator-ctor-parameters.js → hmr/frameworks/angular/build/js-lexer.js} +22 -96
  138. package/hmr/frameworks/angular/build/js-lexer.js.map +1 -0
  139. package/hmr/frameworks/angular/build/shared-linker.d.ts +39 -0
  140. package/hmr/frameworks/angular/build/shared-linker.js +128 -0
  141. package/hmr/frameworks/angular/build/shared-linker.js.map +1 -0
  142. package/hmr/frameworks/angular/build/synthesize-decorator-ctor-parameters.js +88 -0
  143. package/hmr/frameworks/angular/build/synthesize-decorator-ctor-parameters.js.map +1 -0
  144. package/{helpers/angular → hmr/frameworks/angular/build}/synthesize-injectable-factories.js +1 -174
  145. package/hmr/frameworks/angular/build/synthesize-injectable-factories.js.map +1 -0
  146. package/{helpers/angular → hmr/frameworks/angular/build}/util.d.ts +1 -0
  147. package/hmr/frameworks/angular/build/util.js +155 -0
  148. package/hmr/frameworks/angular/build/util.js.map +1 -0
  149. package/hmr/frameworks/angular/client/index.d.ts +1 -0
  150. package/hmr/frameworks/angular/client/index.js +859 -21
  151. package/hmr/frameworks/angular/client/index.js.map +1 -1
  152. package/hmr/frameworks/angular/client/strategy.d.ts +9 -0
  153. package/hmr/frameworks/angular/client/strategy.js +19 -0
  154. package/hmr/frameworks/angular/client/strategy.js.map +1 -0
  155. package/hmr/frameworks/angular/server/angular-root-component.d.ts +79 -0
  156. package/hmr/frameworks/angular/server/angular-root-component.js +149 -0
  157. package/hmr/frameworks/angular/server/angular-root-component.js.map +1 -0
  158. package/hmr/frameworks/angular/server/linker.js +1 -4
  159. package/hmr/frameworks/angular/server/linker.js.map +1 -1
  160. package/hmr/frameworks/angular/server/strategy.js +460 -12
  161. package/hmr/frameworks/angular/server/strategy.js.map +1 -1
  162. package/hmr/{server → frameworks/angular/server}/websocket-angular-entry.js +2 -2
  163. package/hmr/frameworks/angular/server/websocket-angular-entry.js.map +1 -0
  164. package/hmr/{server → frameworks/angular/server}/websocket-angular-hot-update.d.ts +17 -11
  165. package/hmr/frameworks/angular/server/websocket-angular-hot-update.js +336 -0
  166. package/hmr/frameworks/angular/server/websocket-angular-hot-update.js.map +1 -0
  167. package/hmr/frameworks/react/server/strategy.d.ts +2 -0
  168. package/hmr/frameworks/react/server/strategy.js +150 -0
  169. package/hmr/frameworks/react/server/strategy.js.map +1 -0
  170. package/hmr/frameworks/solid/build/solid-jsx-deps.d.ts +15 -0
  171. package/hmr/frameworks/solid/build/solid-jsx-deps.js +178 -0
  172. package/hmr/frameworks/solid/build/solid-jsx-deps.js.map +1 -0
  173. package/hmr/frameworks/solid/client/app-runtime.d.ts +54 -0
  174. package/hmr/frameworks/solid/client/app-runtime.js +184 -0
  175. package/hmr/frameworks/solid/client/app-runtime.js.map +1 -0
  176. package/hmr/frameworks/solid/server/strategy.js +291 -16
  177. package/hmr/frameworks/solid/server/strategy.js.map +1 -1
  178. package/hmr/frameworks/typescript/server/strategy.js +38 -14
  179. package/hmr/frameworks/typescript/server/strategy.js.map +1 -1
  180. package/hmr/frameworks/vue/client/dep-propagation.d.ts +36 -0
  181. package/hmr/frameworks/vue/client/dep-propagation.js +101 -0
  182. package/hmr/frameworks/vue/client/dep-propagation.js.map +1 -0
  183. package/hmr/frameworks/vue/client/index.d.ts +8 -0
  184. package/hmr/frameworks/vue/client/index.js +56 -243
  185. package/hmr/frameworks/vue/client/index.js.map +1 -1
  186. package/hmr/frameworks/vue/client/strategy.d.ts +33 -0
  187. package/hmr/frameworks/vue/client/strategy.js +157 -0
  188. package/hmr/frameworks/vue/client/strategy.js.map +1 -0
  189. package/hmr/frameworks/vue/client/vue-sfc-update-overlay.d.ts +49 -0
  190. package/hmr/frameworks/vue/client/vue-sfc-update-overlay.js +142 -0
  191. package/hmr/frameworks/vue/client/vue-sfc-update-overlay.js.map +1 -0
  192. package/hmr/frameworks/vue/server/sfc-route-assemble.d.ts +7 -0
  193. package/hmr/frameworks/vue/server/sfc-route-assemble.js +747 -0
  194. package/hmr/frameworks/vue/server/sfc-route-assemble.js.map +1 -0
  195. package/hmr/frameworks/vue/server/sfc-route-meta.d.ts +7 -0
  196. package/hmr/frameworks/vue/server/sfc-route-meta.js +80 -0
  197. package/hmr/frameworks/vue/server/sfc-route-meta.js.map +1 -0
  198. package/hmr/frameworks/vue/server/sfc-route-serve.d.ts +8 -0
  199. package/hmr/frameworks/vue/server/sfc-route-serve.js +459 -0
  200. package/hmr/frameworks/vue/server/sfc-route-serve.js.map +1 -0
  201. package/hmr/frameworks/vue/server/sfc-route-shared.d.ts +38 -0
  202. package/hmr/frameworks/vue/server/sfc-route-shared.js +48 -0
  203. package/hmr/frameworks/vue/server/sfc-route-shared.js.map +1 -0
  204. package/hmr/frameworks/vue/server/strategy.d.ts +35 -0
  205. package/hmr/frameworks/vue/server/strategy.js +278 -1
  206. package/hmr/frameworks/vue/server/strategy.js.map +1 -1
  207. package/hmr/frameworks/vue/server/websocket-sfc.d.ts +15 -0
  208. package/hmr/frameworks/vue/server/websocket-sfc.js +20 -0
  209. package/hmr/frameworks/vue/server/websocket-sfc.js.map +1 -0
  210. package/hmr/helpers/ast-normalizer.d.ts +3 -1
  211. package/hmr/helpers/ast-normalizer.js +77 -10
  212. package/hmr/helpers/ast-normalizer.js.map +1 -1
  213. package/hmr/helpers/cjs-named-exports.d.ts +23 -0
  214. package/hmr/helpers/cjs-named-exports.js +152 -0
  215. package/hmr/helpers/cjs-named-exports.js.map +1 -0
  216. package/hmr/helpers/package-exports.d.ts +16 -0
  217. package/hmr/helpers/package-exports.js +396 -0
  218. package/hmr/helpers/package-exports.js.map +1 -0
  219. package/hmr/server/constants.js +20 -5
  220. package/hmr/server/constants.js.map +1 -1
  221. package/hmr/server/core-sanitize.d.ts +86 -7
  222. package/hmr/server/core-sanitize.js +170 -45
  223. package/hmr/server/core-sanitize.js.map +1 -1
  224. package/hmr/server/device-transform-helpers.d.ts +24 -0
  225. package/hmr/server/device-transform-helpers.js +408 -0
  226. package/hmr/server/device-transform-helpers.js.map +1 -0
  227. package/hmr/server/framework-strategy.d.ts +108 -11
  228. package/hmr/server/hmr-module-graph.d.ts +37 -0
  229. package/hmr/server/hmr-module-graph.js +214 -0
  230. package/hmr/server/hmr-module-graph.js.map +1 -0
  231. package/hmr/server/import-map.d.ts +11 -2
  232. package/hmr/server/import-map.js +92 -45
  233. package/hmr/server/import-map.js.map +1 -1
  234. package/hmr/server/index.js +7 -16
  235. package/hmr/server/index.js.map +1 -1
  236. package/hmr/server/ns-core-cjs-shape.d.ts +2 -4
  237. package/hmr/server/ns-core-cjs-shape.js +4 -6
  238. package/hmr/server/ns-core-cjs-shape.js.map +1 -1
  239. package/hmr/server/ns-rt-bridge.d.ts +51 -0
  240. package/hmr/server/ns-rt-bridge.js +131 -0
  241. package/hmr/server/ns-rt-bridge.js.map +1 -0
  242. package/hmr/server/ns-rt-route.d.ts +5 -0
  243. package/hmr/server/ns-rt-route.js +38 -0
  244. package/hmr/server/ns-rt-route.js.map +1 -0
  245. package/hmr/server/perf-instrumentation.d.ts +114 -0
  246. package/hmr/server/perf-instrumentation.js +197 -0
  247. package/hmr/server/perf-instrumentation.js.map +1 -0
  248. package/hmr/server/process-code-for-device.d.ts +14 -0
  249. package/hmr/server/process-code-for-device.js +699 -0
  250. package/hmr/server/process-code-for-device.js.map +1 -0
  251. package/hmr/server/require-guard.d.ts +1 -0
  252. package/hmr/server/require-guard.js +12 -0
  253. package/hmr/server/require-guard.js.map +1 -0
  254. package/hmr/server/rewrite-imports.d.ts +2 -0
  255. package/hmr/server/rewrite-imports.js +630 -0
  256. package/hmr/server/rewrite-imports.js.map +1 -0
  257. package/hmr/server/route-helpers.d.ts +7 -0
  258. package/hmr/server/route-helpers.js +13 -0
  259. package/hmr/server/route-helpers.js.map +1 -0
  260. package/hmr/server/server-origin.d.ts +2 -0
  261. package/hmr/server/server-origin.js +83 -0
  262. package/hmr/server/server-origin.js.map +1 -0
  263. package/hmr/server/shared-transform-request.js +13 -7
  264. package/hmr/server/shared-transform-request.js.map +1 -1
  265. package/hmr/server/transform-cache-invalidation.d.ts +37 -0
  266. package/hmr/server/transform-cache-invalidation.js +156 -0
  267. package/hmr/server/transform-cache-invalidation.js.map +1 -0
  268. package/hmr/server/vendor-bare-module-shims.d.ts +4 -0
  269. package/hmr/server/vendor-bare-module-shims.js +80 -0
  270. package/hmr/server/vendor-bare-module-shims.js.map +1 -0
  271. package/hmr/server/vite-plugin.js +78 -42
  272. package/hmr/server/vite-plugin.js.map +1 -1
  273. package/hmr/server/websocket-core-bridge.d.ts +45 -4
  274. package/hmr/server/websocket-core-bridge.js +50 -48
  275. package/hmr/server/websocket-core-bridge.js.map +1 -1
  276. package/hmr/server/websocket-css-hot-update.d.ts +33 -0
  277. package/hmr/server/websocket-css-hot-update.js +65 -0
  278. package/hmr/server/websocket-css-hot-update.js.map +1 -0
  279. package/hmr/server/websocket-device-transform.d.ts +3 -0
  280. package/hmr/server/websocket-device-transform.js +7 -0
  281. package/hmr/server/websocket-device-transform.js.map +1 -0
  282. package/hmr/server/websocket-graph-upsert.d.ts +15 -0
  283. package/hmr/server/websocket-graph-upsert.js +20 -0
  284. package/hmr/server/websocket-graph-upsert.js.map +1 -1
  285. package/hmr/server/websocket-hmr-pending.d.ts +37 -0
  286. package/hmr/server/websocket-hmr-pending.js +55 -0
  287. package/hmr/server/websocket-hmr-pending.js.map +1 -0
  288. package/hmr/server/websocket-hot-update.d.ts +77 -0
  289. package/hmr/server/websocket-hot-update.js +360 -0
  290. package/hmr/server/websocket-hot-update.js.map +1 -0
  291. package/hmr/server/websocket-import-map-route.d.ts +15 -0
  292. package/hmr/server/websocket-import-map-route.js +50 -0
  293. package/hmr/server/websocket-import-map-route.js.map +1 -0
  294. package/hmr/server/websocket-module-bindings.js +3 -3
  295. package/hmr/server/websocket-module-bindings.js.map +1 -1
  296. package/hmr/server/websocket-module-specifiers.d.ts +66 -2
  297. package/hmr/server/websocket-module-specifiers.js +191 -20
  298. package/hmr/server/websocket-module-specifiers.js.map +1 -1
  299. package/hmr/server/websocket-ns-core.d.ts +21 -0
  300. package/hmr/server/websocket-ns-core.js +311 -0
  301. package/hmr/server/websocket-ns-core.js.map +1 -0
  302. package/hmr/server/websocket-ns-entry.d.ts +21 -0
  303. package/hmr/server/websocket-ns-entry.js +164 -0
  304. package/hmr/server/websocket-ns-entry.js.map +1 -0
  305. package/hmr/server/websocket-ns-m-paths.d.ts +1 -1
  306. package/hmr/server/websocket-ns-m-paths.js +58 -13
  307. package/hmr/server/websocket-ns-m-paths.js.map +1 -1
  308. package/hmr/server/websocket-ns-m-request.d.ts +11 -1
  309. package/hmr/server/websocket-ns-m-request.js +18 -25
  310. package/hmr/server/websocket-ns-m-request.js.map +1 -1
  311. package/hmr/server/websocket-ns-m.d.ts +33 -0
  312. package/hmr/server/websocket-ns-m.js +752 -0
  313. package/hmr/server/websocket-ns-m.js.map +1 -0
  314. package/hmr/server/websocket-served-module-helpers.d.ts +49 -3
  315. package/hmr/server/websocket-served-module-helpers.js +403 -87
  316. package/hmr/server/websocket-served-module-helpers.js.map +1 -1
  317. package/hmr/server/websocket-txn.js +2 -8
  318. package/hmr/server/websocket-txn.js.map +1 -1
  319. package/hmr/server/websocket-vendor-unifier.d.ts +0 -1
  320. package/hmr/server/websocket-vendor-unifier.js +4 -9
  321. package/hmr/server/websocket-vendor-unifier.js.map +1 -1
  322. package/hmr/server/websocket.d.ts +8 -39
  323. package/hmr/server/websocket.js +608 -6300
  324. package/hmr/server/websocket.js.map +1 -1
  325. package/hmr/shared/ns-globals.d.ts +118 -0
  326. package/hmr/shared/ns-globals.js +29 -0
  327. package/hmr/shared/ns-globals.js.map +1 -0
  328. package/hmr/shared/protocol.d.ts +145 -0
  329. package/hmr/shared/protocol.js +28 -0
  330. package/hmr/shared/protocol.js.map +1 -0
  331. package/hmr/shared/runtime/boot-placeholder-ui.d.ts +69 -0
  332. package/hmr/shared/runtime/boot-placeholder-ui.js +101 -0
  333. package/hmr/shared/runtime/boot-placeholder-ui.js.map +1 -0
  334. package/hmr/shared/runtime/boot-progress.d.ts +44 -0
  335. package/hmr/shared/runtime/boot-progress.js +133 -0
  336. package/hmr/shared/runtime/boot-progress.js.map +1 -0
  337. package/hmr/shared/runtime/boot-timeline.d.ts +18 -0
  338. package/hmr/shared/runtime/boot-timeline.js +42 -0
  339. package/hmr/shared/runtime/boot-timeline.js.map +1 -0
  340. package/hmr/shared/runtime/browser-runtime-contract.js.map +1 -1
  341. package/hmr/shared/runtime/dev-overlay-snapshots.d.ts +31 -0
  342. package/hmr/shared/runtime/dev-overlay-snapshots.js +324 -0
  343. package/hmr/shared/runtime/dev-overlay-snapshots.js.map +1 -0
  344. package/hmr/shared/runtime/dev-overlay.d.ts +119 -26
  345. package/hmr/shared/runtime/dev-overlay.js +1196 -262
  346. package/hmr/shared/runtime/dev-overlay.js.map +1 -1
  347. package/hmr/shared/runtime/global-scope.d.ts +18 -0
  348. package/hmr/shared/runtime/global-scope.js +21 -0
  349. package/hmr/shared/runtime/global-scope.js.map +1 -0
  350. package/hmr/shared/runtime/hooks.js +2 -1
  351. package/hmr/shared/runtime/hooks.js.map +1 -1
  352. package/hmr/shared/runtime/http-only-boot.js +7 -6
  353. package/hmr/shared/runtime/http-only-boot.js.map +1 -1
  354. package/hmr/shared/runtime/module-provenance.js +4 -6
  355. package/hmr/shared/runtime/module-provenance.js.map +1 -1
  356. package/hmr/shared/runtime/root-placeholder-view.d.ts +19 -0
  357. package/hmr/shared/runtime/root-placeholder-view.js +311 -0
  358. package/hmr/shared/runtime/root-placeholder-view.js.map +1 -0
  359. package/hmr/shared/runtime/root-placeholder.js +393 -200
  360. package/hmr/shared/runtime/root-placeholder.js.map +1 -1
  361. package/hmr/shared/runtime/session-bootstrap.js +168 -4
  362. package/hmr/shared/runtime/session-bootstrap.js.map +1 -1
  363. package/hmr/shared/runtime/vendor-bootstrap.js +3 -10
  364. package/hmr/shared/runtime/vendor-bootstrap.js.map +1 -1
  365. package/hmr/shared/vendor/manifest-collect.d.ts +4 -0
  366. package/hmr/shared/vendor/manifest-collect.js +549 -0
  367. package/hmr/shared/vendor/manifest-collect.js.map +1 -0
  368. package/hmr/shared/vendor/manifest-loader.d.ts +2 -1
  369. package/hmr/shared/vendor/manifest-loader.js +5 -3
  370. package/hmr/shared/vendor/manifest-loader.js.map +1 -1
  371. package/hmr/shared/vendor/manifest.d.ts +1 -7
  372. package/hmr/shared/vendor/manifest.js +84 -819
  373. package/hmr/shared/vendor/manifest.js.map +1 -1
  374. package/hmr/shared/vendor/vendor-device-shim.d.ts +1 -0
  375. package/hmr/shared/vendor/vendor-device-shim.js +208 -0
  376. package/hmr/shared/vendor/vendor-device-shim.js.map +1 -0
  377. package/hmr/shared/vendor/vendor-esbuild-plugins.d.ts +38 -0
  378. package/hmr/shared/vendor/vendor-esbuild-plugins.js +296 -0
  379. package/hmr/shared/vendor/vendor-esbuild-plugins.js.map +1 -0
  380. package/hmr/vendor-bootstrap.d.ts +1 -3
  381. package/hmr/vendor-bootstrap.js +4 -6
  382. package/hmr/vendor-bootstrap.js.map +1 -1
  383. package/index.d.ts +1 -0
  384. package/index.js +5 -0
  385. package/index.js.map +1 -1
  386. package/package.json +61 -11
  387. package/runtime/core-aliases-early.js +25 -55
  388. package/runtime/core-aliases-early.js.map +1 -1
  389. package/shims/react-jsx-runtime.d.ts +4 -0
  390. package/shims/react-jsx-runtime.js +37 -0
  391. package/shims/react-jsx-runtime.js.map +1 -0
  392. package/helpers/angular/angular-linker.d.ts +0 -13
  393. package/helpers/angular/angular-linker.js +0 -194
  394. package/helpers/angular/angular-linker.js.map +0 -1
  395. package/helpers/angular/inline-decorator-component-templates.js.map +0 -1
  396. package/helpers/angular/shared-linker.d.ts +0 -11
  397. package/helpers/angular/shared-linker.js +0 -75
  398. package/helpers/angular/shared-linker.js.map +0 -1
  399. package/helpers/angular/synthesize-decorator-ctor-parameters.js.map +0 -1
  400. package/helpers/angular/synthesize-injectable-factories.js.map +0 -1
  401. package/helpers/angular/util.js +0 -67
  402. package/helpers/angular/util.js.map +0 -1
  403. package/helpers/prelink-angular.d.ts +0 -2
  404. package/helpers/prelink-angular.js +0 -117
  405. package/helpers/prelink-angular.js.map +0 -1
  406. package/hmr/server/websocket-angular-entry.js.map +0 -1
  407. package/hmr/server/websocket-angular-hot-update.js +0 -239
  408. package/hmr/server/websocket-angular-hot-update.js.map +0 -1
  409. package/hmr/server/websocket-ns-m-finalize.d.ts +0 -22
  410. package/hmr/server/websocket-ns-m-finalize.js +0 -88
  411. package/hmr/server/websocket-ns-m-finalize.js.map +0 -1
  412. package/hmr/server/websocket-runtime-compat.d.ts +0 -19
  413. package/hmr/server/websocket-runtime-compat.js +0 -286
  414. package/hmr/server/websocket-runtime-compat.js.map +0 -1
  415. package/hmr/server/websocket-vue-sfc.d.ts +0 -27
  416. package/hmr/server/websocket-vue-sfc.js +0 -1117
  417. package/hmr/server/websocket-vue-sfc.js.map +0 -1
  418. package/transformers/NativeClass/index.d.ts +0 -2
  419. package/transformers/NativeClass/index.js +0 -222
  420. package/transformers/NativeClass/index.js.map +0 -1
  421. /package/{helpers/angular → hmr/frameworks/angular/build}/inline-decorator-component-templates.d.ts +0 -0
  422. /package/{helpers/angular → hmr/frameworks/angular/build}/synthesize-decorator-ctor-parameters.d.ts +0 -0
  423. /package/{helpers/angular → hmr/frameworks/angular/build}/synthesize-injectable-factories.d.ts +0 -0
  424. /package/hmr/{server → frameworks/angular/server}/websocket-angular-entry.d.ts +0 -0
@@ -0,0 +1,699 @@
1
+ // Device code-transform: cleans Vite/framework noise out of a served module,
2
+ // injects NativeScript build globals + the process.env shim, normalizes
3
+ // imports/helpers for the on-device ESM runtime, and collects an importer's
4
+ // app-relative dependencies. Pure functions only.
5
+ import { sanitizeStrayCoreReferences, isDeepCoreSubpath } from './core-sanitize.js';
6
+ import * as path from 'path';
7
+ import * as PAT from './constants.js';
8
+ import { astNormalizeModuleImportsAndHelpers, astVerifyAndAnnotateDuplicates } from '../helpers/ast-normalizer.js';
9
+ import { stripDanglingViteCjsImports } from '../helpers/sanitize.js';
10
+ import { getVendorManifest, resolveVendorSpecifier } from '../shared/vendor/registry.js';
11
+ import { getProjectRootPath } from '../../helpers/project.js';
12
+ import { getCliFlags, resolvePlatform } from '../../helpers/cli-flags.js';
13
+ import { resolveVerboseFlag } from '../../helpers/logging.js';
14
+ import { getProjectFlavor } from '../../helpers/flavor.js';
15
+ import { buildDefineShimStatements, buildGuardedDefineSeedStatement, buildUserDefineShimStatements, getRuntimeDefineValues } from '../../helpers/global-defines.js';
16
+ import { linkAngularPartialsIfNeeded } from '../frameworks/angular/server/linker.js';
17
+ import { isCoreGlobalsReference, isNativeScriptCoreModule, isNativeScriptPluginModule, normalizeNativeScriptCoreSpecifier, resolveVendorFromCandidate } from './websocket-module-specifiers.js';
18
+ import { ensureNativeScriptModuleBindings, getProcessCodeResolvedSpecifierOverrides } from './websocket-module-bindings.js';
19
+ import { deduplicateLinkerImports, ensureDestructureRtImports, ensureVariableDynamicImportHelper, hoistTopLevelStaticImports, repairImportEqualsAssignments, stripCoreGlobalsImports, stripViteDynamicImportVirtual } from './websocket-served-module-helpers.js';
20
+ import { buildNodeModuleProvenancePrelude, normalizeImportPath, removeNamedImports, rewriteVitePrebundleImportsForDevice, shouldRemapImport } from './device-transform-helpers.js';
21
+ // Build a serialized process.env object from CLI --env.* flags.
22
+ // This is injected into every HTTP-served module so app code referencing
23
+ // process.env.TEST_ENV (etc.) works on device in HMR dev mode.
24
+ const __processEnvEntries = { NODE_ENV: 'development' };
25
+ try {
26
+ const flags = getCliFlags();
27
+ for (const [k, v] of Object.entries(flags || {})) {
28
+ // Skip internal NativeScript build flags
29
+ if (['ios', 'android', 'visionos', 'platform', 'hmr', 'verbose'].includes(k))
30
+ continue;
31
+ __processEnvEntries[k] = String(v);
32
+ }
33
+ }
34
+ catch { }
35
+ const __processEnvJson = JSON.stringify(__processEnvEntries);
36
+ // Canonical define values resolved once
37
+ const __runtimeDefines = (() => {
38
+ let platform;
39
+ let verbose = false;
40
+ try {
41
+ platform = resolvePlatform();
42
+ verbose = resolveVerboseFlag();
43
+ }
44
+ catch { }
45
+ return { platform, values: getRuntimeDefineValues({ platform, isDevMode: true, verbose }) };
46
+ })();
47
+ // Guarded platform seed injected ahead of the per-module define shims so
48
+ // whichever HTTP-served module evaluates FIRST seeds globalThis correctly.
49
+ //
50
+ // Why this is needed: under HMR the device bundle's externalized core imports
51
+ // (`import "http://…/ns/core/globals"` etc.) evaluate BEFORE the bundle's own
52
+ // body per ESM semantics — so the bundle's inlined `virtual:ns-defines-seed`
53
+ // statements have NOT run when the HTTP core graph instantiates. Without this
54
+ // seed, code reading `globalThis.__APPLE__` directly would see undefined.
55
+ // Only emitted when a platform flag was actually detected — seeding
56
+ // all-false platform flags would be worse than not seeding.
57
+ const __platformSeed = __runtimeDefines.platform ? buildGuardedDefineSeedStatement(__runtimeDefines.values) : '';
58
+ function collectImportDependencies(code, importerPath) {
59
+ const importerDir = path.posix.dirname(importerPath);
60
+ const deps = new Set();
61
+ const patterns = [PAT.IMPORT_PATTERN_1, PAT.IMPORT_PATTERN_2, PAT.EXPORT_PATTERN, PAT.IMPORT_PATTERN_3];
62
+ for (const pattern of patterns) {
63
+ pattern.lastIndex = 0;
64
+ let match;
65
+ while ((match = pattern.exec(code)) !== null) {
66
+ const rawSpec = match[2];
67
+ const spec = normalizeNativeScriptCoreSpecifier(rawSpec);
68
+ if (!spec || !shouldRemapImport(spec)) {
69
+ continue;
70
+ }
71
+ if (resolveVendorFromCandidate(spec)) {
72
+ continue;
73
+ }
74
+ // Manifest-aware vendor spec detection
75
+ try {
76
+ if (resolveVendorSpecifier && resolveVendorSpecifier(spec)) {
77
+ continue;
78
+ }
79
+ }
80
+ catch { }
81
+ const normalized = normalizeImportPath(spec, importerDir);
82
+ if (normalized) {
83
+ if (resolveVendorFromCandidate(normalized)) {
84
+ continue;
85
+ }
86
+ try {
87
+ if (resolveVendorSpecifier && resolveVendorSpecifier(normalized)) {
88
+ continue;
89
+ }
90
+ }
91
+ catch { }
92
+ if (isCoreGlobalsReference(normalized)) {
93
+ continue;
94
+ }
95
+ if (isNativeScriptCoreModule(normalized)) {
96
+ continue;
97
+ }
98
+ if (isNativeScriptPluginModule(normalized)) {
99
+ continue;
100
+ }
101
+ deps.add(normalized);
102
+ }
103
+ }
104
+ }
105
+ return deps;
106
+ }
107
+ /**
108
+ * Clean code: remove Vite/Vue noise, rewrite to vendor
109
+ */
110
+ function cleanCode(code, strategy) {
111
+ let result = code;
112
+ // Remove Vite client and hot module noise ('$1' keeps the preceding
113
+ // newline/semicolon boundary — see VITE_CLIENT_IMPORT in constants.ts)
114
+ result = result.replace(PAT.VITE_CLIENT_IMPORT, '$1');
115
+ result = result.replace(PAT.IMPORT_META_HOT_ASSIGNMENT, '');
116
+ // Keep import.meta.hot call sites; runtime now provides a stable import.meta.hot.
117
+ result = strategy.preClean?.(result) ?? result;
118
+ result = strategy.rewriteFrameworkImports?.(result) ?? result;
119
+ // Vendor manifest-driven import rewrites
120
+ // NOTE: Static and side-effect vendor imports are intentionally NOT rewritten here.
121
+ // They are left as import statements so that ensureNativeScriptModuleBindings()
122
+ // (called later in processCodeForDevice) can transform them using the robust
123
+ // __nsVendorRequire + __nsPick pattern that works on device.
124
+ // Only dynamic imports are handled here since ensureNativeScriptModuleBindings
125
+ // does not process dynamic import() calls.
126
+ try {
127
+ const manifest = getVendorManifest();
128
+ if (manifest) {
129
+ // Dynamic import rewrites: import('pkg') -> Promise.resolve(__nsVendor('id'))
130
+ const dynImportRE = /(import\(\s*["'])([^"']+)(["']\s*\))/g;
131
+ result = result.replace(dynImportRE, (full, pre, spec, post) => {
132
+ if (isNativeScriptCoreModule(spec))
133
+ return full;
134
+ const resolved = resolveVendorSpecifier(spec);
135
+ if (!resolved || /^@nativescript\/core(\b|\/)/i.test(resolved))
136
+ return full;
137
+ return `Promise.resolve(__nsVendor(${JSON.stringify(resolved)}))`;
138
+ });
139
+ }
140
+ }
141
+ catch (e) {
142
+ // Non-fatal; fallback to original code if manifest logic fails
143
+ }
144
+ result = result.replace(PAT.VITE_CLIENT_IMPORT, '$1').replace(PAT.IMPORT_META_HOT_ASSIGNMENT, '');
145
+ // The stripped /@vite/client import may have carried the `injectQuery`
146
+ // binding (Vite 8 rewrites worker/url dynamic imports to
147
+ // `__vite__injectQuery(url, 'import')`). Shim it as identity — query
148
+ // injection is meaningless for the on-device HTTP loader.
149
+ if (/\b__vite__injectQuery\s*\(/.test(result) && !/(?:const|let|var|function)\s+__vite__injectQuery\b/.test(result)) {
150
+ result = `const __vite__injectQuery = (url) => url;\n` + result;
151
+ }
152
+ // Clean up HMR noise
153
+ result = strategy.postClean?.(result) ?? result;
154
+ result = stripCoreGlobalsImports(result);
155
+ return result;
156
+ }
157
+ /**
158
+ * Process code for device: inject globals, remove framework imports
159
+ */
160
+ function processCodeForDevice(code, isVitePreBundled, preserveVendorImports = false, isNodeModule = false, sourceId, options) {
161
+ let result = code;
162
+ const resolvedSpecifierOverrides = options?.resolvedSpecifierOverrides || getProcessCodeResolvedSpecifierOverrides(sourceId, getProjectRootPath());
163
+ const bindingOptions = {
164
+ preserveNonPluginVendorImports: preserveVendorImports,
165
+ resolvedSpecifierOverrides,
166
+ };
167
+ // Ensure Angular partial declarations are linked before any sanitizers run so runtime never hits the JIT path.
168
+ result = linkAngularPartialsIfNeeded(result);
169
+ // Post-linker: deduplicate/resolve imports the Angular linker injected with bare specifiers
170
+ result = deduplicateLinkerImports(result);
171
+ // First: aggressively strip any lingering virtual dynamic-import-helper before anything else.
172
+ // Doing this up-front prevents downstream dependency collection from seeing the virtual id.
173
+ result = stripViteDynamicImportVirtual(result);
174
+ // Skip reactive injection for Vite pre-bundled deps (they have Vue bundled already)
175
+ if (isVitePreBundled) {
176
+ return result;
177
+ }
178
+ // Inject ALL NativeScript/build globals at the top (matching global-defines.ts)
179
+ // This ensures any code using __DEV__, __ANDROID__, __IOS__, etc. works correctly
180
+ const allGlobals = [
181
+ // Minimal process shim — populated with CLI --env.* flags at module load time.
182
+ // In production builds, Vite/Rollup replaces process.env.* statically.
183
+ // In HMR dev mode the code runs as-is on device, so we need the shim.
184
+ //
185
+ // IMPORTANT: every check goes through `globalThis.process` (a member
186
+ // expression), NEVER bare `typeof process` (an identifier reference).
187
+ // bare identifier resolution
188
+ // against runtime-added global object properties is not reliable in
189
+ // V8 module scope. `globalThis.process` is unambiguous: it always
190
+ // reads the `process` property off the (single) global object.
191
+ //
192
+ // The shim is also strictly additive — it only initializes
193
+ // `globalThis.process` and `globalThis.process.env` if they are
194
+ // missing. App code that pre-populates `process.env` (e.g. an Azure
195
+ // App Configuration boot module) is preserved; we never overwrite a
196
+ // populated env with the bare `{ NODE_ENV: 'development' }` stub.
197
+ `if (typeof globalThis.process === "undefined" || globalThis.process === null) { globalThis.process = { env: ${__processEnvJson} }; } else if (!globalThis.process.env) { globalThis.process.env = ${__processEnvJson}; }`,
198
+ // Seed platform defines from the dev server's CLI flags BEFORE the const
199
+ // shims snapshot them — see __platformSeed above for the ESM-ordering
200
+ // rationale (externalized core imports evaluate before the bundle body).
201
+ ...(__platformSeed ? [__platformSeed] : []),
202
+ // Per-module shim consts with canonical fallbacks — generated from the
203
+ // same getRuntimeDefineValues source as the seed and Vite's `define`.
204
+ ...buildDefineShimStatements(__runtimeDefines.values),
205
+ // App-configured `__FOO__` defines (e.g. __NS_NATIVE_OVERRIDES__). Excludes
206
+ // the builtin keys just shimmed above so we never emit a duplicate `const`.
207
+ ...buildUserDefineShimStatements(Object.keys(__runtimeDefines.values)),
208
+ ];
209
+ result = allGlobals.join('\n') + '\n' + result;
210
+ const nodeModuleProvenancePrelude = buildNodeModuleProvenancePrelude(sourceId);
211
+ if (nodeModuleProvenancePrelude) {
212
+ result = nodeModuleProvenancePrelude + result;
213
+ }
214
+ // AST normalization: inject /ns/rt helper aliases for underscore-prefixed identifiers.
215
+ // ONLY for app source files — library code in node_modules should be served as-is.
216
+ // Running the normalizer on libraries like tslib injects harmful destructures
217
+ // (e.g., `const { SuppressedError } = __ns_rt_ns_1`) that shadow globals.
218
+ if (!isNodeModule) {
219
+ // CRITICAL ORDERING: canonicalise any bare `@nativescript/core[/sub]`
220
+ // specifiers to `/ns/core[/sub]` BEFORE the AST normaliser sees them.
221
+ // `astNormalizeModuleImportsAndHelpers` defensively rewrites bare
222
+ // `@nativescript/core` imports and emits a one-shot
223
+ // `[ast-normalizer] unexpected @nativescript/core spec` warning —
224
+ // the warning means the upstream rewriter regressed. For Vue SFC
225
+ // `<script>` blocks the bare specifier flows through Vite's
226
+ // transform pipeline without a per-statement source-string rewrite
227
+ // (Vite's resolver only edits the module graph, not the emitted
228
+ // code), so the only upstream rewriter that can canonicalise these
229
+ // in dev mode is this regex sweep. Running it here keeps the AST
230
+ // normaliser purely a tripwire instead of an active rewriter.
231
+ try {
232
+ result = sanitizeStrayCoreReferences(result);
233
+ }
234
+ catch { }
235
+ try {
236
+ // The unsound underscore TEXT-SCAN fallback inside the normalizer is
237
+ // only meaningful for compiled Vue template helpers; on every other
238
+ // flavor it has misread app/library internals as helpers (see the
239
+ // fallback's comment in ast-normalizer.ts). AST-based detection stays
240
+ // on for all flavors.
241
+ result = astNormalizeModuleImportsAndHelpers(result, { underscoreTextFallback: getProjectFlavor() === 'vue' });
242
+ }
243
+ catch { }
244
+ // Verify there are no duplicate top-level const/let bindings after AST normalization
245
+ try {
246
+ result = astVerifyAndAnnotateDuplicates(result);
247
+ }
248
+ catch { }
249
+ }
250
+ // If AST marker present OR this is a node_modules file, skip regex-based helper
251
+ // alias injection. Library code should NOT get /ns/rt destructures injected —
252
+ // underscore-prefixed identifiers in libraries are internal variables, not NS helpers.
253
+ // Vue-only for the same reason as the normalizer's text fallback: /ns/rt
254
+ // underscore helpers (`_toDisplayString`, …) only exist in compiled Vue
255
+ // template output; on other flavors this scope-blind regex misreads app
256
+ // internals as helpers.
257
+ if (getProjectFlavor() === 'vue' && !isNodeModule && !/^\s*(?:\/\/|\/\*) \[ast-normalized\]/m.test(result)) {
258
+ try {
259
+ const underscored = new Set();
260
+ // `(?![\w$])` (not `\b`): `\w` excludes `$`, so `\b` would match the prefix
261
+ // `_Symbol` inside Babel temp vars like `_Symbol$toStringTag`.
262
+ const re = /(^|[^.\w$])_([A-Za-z]\w*)(?![\w$])/g;
263
+ let m;
264
+ while ((m = re.exec(result))) {
265
+ const name = m[2];
266
+ if (name === 'ctx' || name === 'cache')
267
+ continue;
268
+ if (name.startsWith('hoisted_'))
269
+ continue;
270
+ if (name.startsWith('component_'))
271
+ continue;
272
+ if (name.startsWith('directive_'))
273
+ continue;
274
+ if (name === 'sfc_main')
275
+ continue;
276
+ if (name === 'ns_sfc__' || name.startsWith('ns_sfc'))
277
+ continue;
278
+ if (name.startsWith('sfc'))
279
+ continue;
280
+ try {
281
+ const declRE = new RegExp(`(^|\\n)\\s*(?:const|let|var)\\s+_${name}\\b`);
282
+ if (declRE.test(result))
283
+ continue;
284
+ }
285
+ catch { }
286
+ underscored.add(name);
287
+ }
288
+ if (underscored.size) {
289
+ const needed = [];
290
+ for (const n of underscored) {
291
+ const aliasNeedle = new RegExp(`\\b${n}\\s+as\\s+_${n}\\b`);
292
+ if (!aliasNeedle.test(result))
293
+ needed.push(n);
294
+ }
295
+ if (needed.length) {
296
+ const importLine = `import { ${needed.map((n) => `${n} as _${n}`).join(', ')} } from "/ns/rt";\n`;
297
+ result = importLine + result;
298
+ }
299
+ }
300
+ }
301
+ catch { }
302
+ }
303
+ // In strict dev mode, proactively surface duplicate-binding diagnostics to avoid "already declared" runtime errors
304
+ try {
305
+ if (/^\s*\/\/ \[ast-verify\]\[duplicate-bindings\]/m.test(result)) {
306
+ const diagnosticLine = (result.match(/^\s*\/\/ \[ast-verify\]\[duplicate-bindings\][^\n]*/m) || [])[0] || '// [ast-verify][duplicate-bindings]';
307
+ const brief = diagnosticLine.replace(/^[^:]*:?\s?/, '');
308
+ const escaped = brief.replace(/["\\]/g, '\\$&');
309
+ const thrower = `throw new Error("[nsv-hmr] Duplicate top-level bindings detected: ${escaped}");`;
310
+ result = `${thrower}\n` + result;
311
+ }
312
+ }
313
+ catch { }
314
+ // Remove Vite internal imports (dynamic-import-helper, etc.)
315
+ // This handles both standalone lines and concatenated imports on the same line
316
+ // EXCEPT oxc runtime helpers (decorators etc.): Vite 8's oxc transform emits
317
+ // `import _decorate from "/@id/__x00__@oxc-project+runtime@<ver>/helpers/decorate.js"`.
318
+ // Unlike other virtual ids these are real, servable dev-server URLs returning
319
+ // self-contained ESM — stripping them leaves `_decorate`/`_decorateMetadata`
320
+ // undefined at runtime. They're origin-prefixed for the device in rewriteImports.
321
+ result = result.replace(/import\s+[^;]+\s+from\s+["']\/@id\/(?!__x00__@oxc-project\+runtime)[^"']*["'];?\s*/g, '');
322
+ // Also remove side-effect only virtual id imports like: import "/@id/__x00__vite/dynamic-import-helper.js";
323
+ // These can slip through and cause the NativeScript runtime to attempt resolving
324
+ // a non-existent physical file (e.g. /@id/__x00__vite/dynamic-import-helper.js) leading to
325
+ // module not found crashes during HMR evaluation.
326
+ if (/^[\t ]*import\s+["']\/@id\/[^"']+["'];?\s*$/m.test(result)) {
327
+ result = result.replace(/^[\t ]*import\s+["']\/@id\/[^"']+["'];?\s*$/gm, '');
328
+ // Inject a lightweight marker comment (harmless if left in output) so devs can confirm rewrite took place when viewing streamed artifact.
329
+ result = `// [hmr-sanitize] stripped virtual /@id/ side-effect imports\n${result}`;
330
+ }
331
+ // IMPORTANT: Perform vendor-module binding injection BEFORE stripping Vite prebundle imports.
332
+ // This allows the rewriter to see and canonicalize '/node_modules/.vite/deps/*' specifiers back
333
+ // to their package ids (e.g., '@nativescript/firebase-core') and generate require-based bindings
334
+ // so named imports like `{ firebase }` are preserved as const bindings.
335
+ //
336
+ // Some upstream transforms can emit a multiline form:
337
+ // import { x } from
338
+ // "/node_modules/.vite/deps/...";
339
+ // If we don't normalize it, later stripping of naked string-only lines can leave
340
+ // an invalid `import ... from` statement.
341
+ try {
342
+ result = result.replace(/(^|\n)([\t ]*import\s+[^;]*?\s+from)\s*\n\s*("\/?node_modules\/\.vite\/deps\/[^"\n]+"\s*;?\s*)/gm, (_m, p1, p2, p3) => `${p1}${p2} ${p3}`);
343
+ }
344
+ catch { }
345
+ // When preserveVendorImports is true (HMR /ns/m/ endpoint), skip the
346
+ // __nsVendorRequire + __nsPick rewrite. Vendor imports stay as bare
347
+ // specifiers so the device-side import map resolves them via V8's native
348
+ // module system, which correctly handles export * re-exports.
349
+ result = ensureNativeScriptModuleBindings(result, bindingOptions);
350
+ // Repair any accidental "import ... = expr" assignments that may have slipped in.
351
+ try {
352
+ result = repairImportEqualsAssignments(result);
353
+ }
354
+ catch { }
355
+ // Strip Vite prebundle deps imports (both named and side-effect) and any malformed const string artifacts
356
+ // Example problematic line observed: const "/node_modules/.vite/deps/@nativescript_firebase-messaging.js?v=...";
357
+ if (/node_modules\/\.vite\/deps\//.test(result)) {
358
+ result = rewriteVitePrebundleImportsForDevice(result, preserveVendorImports);
359
+ // Malformed const string lines accidentally produced by upstream transforms
360
+ result = result.replace(/^[\t ]*const\s+["']\/?node_modules\/\.vite\/deps\/[^"']+["'];?\s*$/gm, '// [hmr-sanitize] stripped malformed const prebundle ref\n');
361
+ // Naked string-only lines pointing at prebundle deps
362
+ result = result.replace(/^[\t ]*["']\/?node_modules\/\.vite\/deps\/[^"']+["'];?\s*$/gm, '// [hmr-sanitize] stripped prebundle side-effect literal\n');
363
+ }
364
+ // Dynamic aliasing covers helper imports; no further static list handling needed.
365
+ // Handle navigation helpers (dev bridge): $navigateTo, $navigateBack
366
+ // Note: do NOT inject $showModal as a named import; AST normalizer/destructure covers it when imported,
367
+ // and free-uses are handled via AST injection. This avoids duplicate identifier redeclarations.
368
+ if (/\$(?:navigate(?:To|Back)|showModal)\b/.test(result)) {
369
+ const navHelpers = [];
370
+ // Only consider free uses (not property access like obj.$navigateTo)
371
+ const needTo = /(^|[^.\w$])\$navigateTo\b/.test(result);
372
+ const needBack = /(^|[^.\w$])\$navigateBack\b/.test(result);
373
+ if (needTo)
374
+ navHelpers.push('$navigateTo');
375
+ if (needBack)
376
+ navHelpers.push('$navigateBack');
377
+ // Intentionally exclude $showModal from navHelpers injection to prevent named import reinsertion
378
+ // Remove any direct imports/usages that might shadow globals
379
+ // 1) From 'vue' or 'nativescript-vue' sources
380
+ result = removeNamedImports(result, navHelpers);
381
+ // 2) From our runtime bridge '/ns/rt' (versioned or not)
382
+ try {
383
+ // Do NOT re-introduce named imports from /ns/rt for nav helpers; drop them entirely after removing nav helpers.
384
+ const rtNamedRE = /(^|\n)\s*import\s*\{([^}]+)\}\s*from\s*["'](?:https?:\/\/[^"']+)?\/ns\/rt(?:\/[\d]+)?["'];?\s*/gm;
385
+ // Also compute locally-declared helpers to drop regardless of free-use detection
386
+ const hasLocalToForDrop = /(^|[\n;])\s*(?:const|let|var|function)\s+\$navigateTo\b/.test(result);
387
+ const hasLocalBackForDrop = /(^|[\n;])\s*(?:const|let|var|function)\s+\$navigateBack\b/.test(result);
388
+ result = result.replace(rtNamedRE, (full, pfx, specList) => {
389
+ const drop = new Set(navHelpers);
390
+ if (hasLocalToForDrop)
391
+ drop.add('$navigateTo');
392
+ if (hasLocalBackForDrop)
393
+ drop.add('$navigateBack');
394
+ const remaining = String(specList)
395
+ .split(',')
396
+ .map((s) => s.trim())
397
+ .filter(Boolean)
398
+ .filter((entry) => {
399
+ const base = entry.split(/\s+as\s+/i)[0].trim();
400
+ return !drop.has(base);
401
+ });
402
+ if (!remaining.length)
403
+ return pfx || '';
404
+ // Preserve non-navigation named imports for later normalization
405
+ return `${pfx}import { ${remaining.join(', ')} } from "/ns/rt";`;
406
+ });
407
+ // Also strip $navigateTo/$navigateBack from any destructuring previously created from /ns/rt
408
+ // Also remove from destructures bound off any __ns_rt_ns temp (including _re)
409
+ const rtDestructureRE = /(^|[\n;])\s*const\s*\{([^}]+)\}\s*=\s*(__ns_rt_ns(?:\d+|_re))\s*;?\s*/gm;
410
+ result = result.replace(rtDestructureRE, (full, pfx, specList, varName) => {
411
+ const cleaned = String(specList)
412
+ .split(',')
413
+ .map((s) => s.trim())
414
+ .filter(Boolean)
415
+ .filter((seg) => {
416
+ const lhs = seg.split(':')[0].trim();
417
+ return !/^\$navigate(?:To|Back)$/.test(lhs);
418
+ });
419
+ if (!cleaned.length)
420
+ return pfx || '';
421
+ return `${pfx}const { ${cleaned.join(', ')} } = ${varName};`;
422
+ });
423
+ }
424
+ catch { }
425
+ // Inject named imports from /ns/rt to provide bindings without redeclaration collisions
426
+ const imports = [];
427
+ const hasImportTo = /(^|\n)\s*import\s*\{[^}]*\$navigateTo[^}]*\}\s*from\s*["'](?:https?:\/\/[^"']+)?\/ns\/rt(?:\/[\d]+)?["']/.test(result);
428
+ const hasImportBack = /(^|\n)\s*import\s*\{[^}]*\$navigateBack[^}]*\}\s*from\s*["'](?:https?:\/\/[^"']+)?\/ns\/rt(?:\/[\d]+)?["']/.test(result);
429
+ // Avoid adding named imports if a local binding already exists (e.g., wrapper const)
430
+ const hasLocalTo = /(^|[\n;])\s*(?:const|let|var|function)\s+\$navigateTo\b/.test(result);
431
+ const hasLocalBack = /(^|[\n;])\s*(?:const|let|var|function)\s+\$navigateBack\b/.test(result);
432
+ if (needTo && !hasImportTo && !hasLocalTo)
433
+ imports.push('$navigateTo');
434
+ if (needBack && !hasImportBack && !hasLocalBack)
435
+ imports.push('$navigateBack');
436
+ // Do not inject $showModal named import; avoid duplicates with destructures created upstream
437
+ if (imports.length) {
438
+ result = `import { ${imports.join(', ')} } from "/ns/rt";\n` + result;
439
+ }
440
+ }
441
+ // Ensure vendor bindings also apply after potential wrapper injections above
442
+ // (idempotent: second pass will be a no-op if imports already consumed).
443
+ result = ensureNativeScriptModuleBindings(result, bindingOptions);
444
+ try {
445
+ result = repairImportEqualsAssignments(result);
446
+ }
447
+ catch { }
448
+ // Rewrite any previously-injected vendor-based core access to the unified HTTP core bridge
449
+ try {
450
+ const vendorCoreRE1 = /globalThis\.__nsVendor\s*\(\s*["']@nativescript\/core["']\s*\)/g;
451
+ const vendorCoreRE2 = /__nsVendor\s*\(\s*["']@nativescript\/core["']\s*\)/g;
452
+ if (vendorCoreRE1.test(result) || vendorCoreRE2.test(result)) {
453
+ const hasImport = /import\s+__ns_core_bridge\s+from\s+["'][^"']*\/(?:\@ns|ns)\/core(?:\/[^"']+)?["']\s*;?/.test(result) || /(^|\n)\s*import\s+__ns_core_bridge\s+from\s+["']\/(?:\@ns|ns)\/core["']\s*;?/m.test(result);
454
+ if (!hasImport) {
455
+ result = `import __ns_core_bridge from "/ns/core";\n` + result;
456
+ }
457
+ result = result.replace(vendorCoreRE1, '__ns_core_bridge');
458
+ result = result.replace(vendorCoreRE2, '__ns_core_bridge');
459
+ }
460
+ }
461
+ catch { }
462
+ // Rewrite any explicit require('@nativescript/core[/sub]') calls to the unified core bridge
463
+ try {
464
+ const reqCoreRE1 = /(^|[^.\w$])require\(\s*["']@nativescript\/core([^"'\n]*)["']\s*\)/g;
465
+ const reqCoreRE2 = /(?:globalThis|window|self)\.require\(\s*["']@nativescript\/core([^"'\n]*)["']\s*\)/g;
466
+ if (reqCoreRE1.test(result) || reqCoreRE2.test(result)) {
467
+ const hasImport = /import\s+__ns_core_bridge\s+from\s+["'][^"']*\/(?:\@ns|ns)\/core(?:\/[^"']+)?["']\s*;?/.test(result) || /(^|\n)\s*import\s+__ns_core_bridge\s+from\s+["']\/(?:\@ns|ns)\/core["']\s*;?/m.test(result);
468
+ if (!hasImport) {
469
+ result = `import __ns_core_bridge from "/ns/core";\n` + result;
470
+ }
471
+ result = result.replace(reqCoreRE1, (_m, p1, _sub) => `${p1}__ns_core_bridge`);
472
+ result = result.replace(reqCoreRE2, '__ns_core_bridge');
473
+ }
474
+ }
475
+ catch { }
476
+ // Apply the three-pass safety net for stray @nativescript/core references
477
+ // (naked string literals, dangling `from` merges, lingering resolved-path
478
+ // references). Centralised in core-sanitize.sanitizeStrayCoreReferences so
479
+ // every NS-M emitter applies the same passes in the same order.
480
+ result = sanitizeStrayCoreReferences(result);
481
+ result = ensureVariableDynamicImportHelper(result);
482
+ // Normalize any lingering @nativescript/core imports to the /ns/core bridge (non-destructive best-effort)
483
+ try {
484
+ // Rewrite named imports from the /ns/core bridge into default import + destructuring.
485
+ // This makes `import { Frame } from '@nativescript/core'` work even if the bridge provides only a default export.
486
+ {
487
+ let __core_ns_seq = 0;
488
+ const toDestructureCore = (specList) => specList
489
+ .split(',')
490
+ .map((s) => s.trim())
491
+ .filter(Boolean)
492
+ .map((seg) => {
493
+ const m = seg.split(/\s+as\s+/i);
494
+ return m.length === 2 ? `${m[0].trim()}: ${m[1].trim()}` : seg;
495
+ })
496
+ .join(', ');
497
+ const reNamed = /(^|\n)\s*import\s*\{([^}]+)\}\s*from\s*["']((?:https?:\/\/[^"']+)?\/ns\/core(?:\/[^"']+)?)['"];?\s*/gm;
498
+ result = result.replace(reNamed, (_full, pfx, specList, src) => {
499
+ // Deep subpath URLs serve actual ESM with real named exports — skip.
500
+ if (isDeepCoreSubpath(src))
501
+ return _full;
502
+ __core_ns_seq++;
503
+ const tmp = `__ns_core_ns${__core_ns_seq}`;
504
+ const decl = `const { ${toDestructureCore(specList)} } = ${tmp};`;
505
+ return `${pfx}import ${tmp} from ${JSON.stringify(src)};\n${decl}\n`;
506
+ });
507
+ const reMixed = /(^|\n)\s*import\s+([A-Za-z_$][\w$]*)\s*,\s*\{([^}]+)\}\s*from\s*["']((?:https?:\/\/[^"']+)?\/ns\/core(?:\/[^"']+)?)['"];?\s*/gm;
508
+ result = result.replace(reMixed, (_full, pfx, defName, specList, src) => {
509
+ if (isDeepCoreSubpath(src))
510
+ return _full;
511
+ const decl = `const { ${toDestructureCore(specList)} } = ${defName};`;
512
+ return `${pfx}import ${defName} from ${JSON.stringify(src)};\n${decl}\n`;
513
+ });
514
+ }
515
+ }
516
+ catch { }
517
+ // Note: Removed legacy var-based underscore prelude to avoid const/var redeclaration conflicts.
518
+ // Normalize concatenated imports that may have ended up after a statement on the same line
519
+ try {
520
+ // Common concatenations
521
+ // Keep a single semicolon before the import to avoid generating ';;'
522
+ result = result.replace(/;\s*import\s+/g, ';\nimport ');
523
+ result = result.replace(/}\s*import\s+/g, '}\nimport ');
524
+ // Fallback: ensure any static import that isn't at start of line gets a newline before it.
525
+ //
526
+ // Only match after **structural** statement-ending characters: `;`, `}`, `)`, `]`. We
527
+ // deliberately do NOT include `'`, `"`, or `` ` `` here — those are string-literal
528
+ // terminators (and openers!), and including them caused the regex to fire inside
529
+ // example code embedded in error strings. Concrete failure observed:
530
+ // `@supabase/realtime-js` throws an Error whose message contains the literal
531
+ // `' import ws from "ws"\n' +`. With `'` in the delimiter class, the engine matched
532
+ // the opening `'` of that string literal as a "statement terminator" and rewrote the
533
+ // example to `'\nimport ws from "..."` — splitting the string across two lines and
534
+ // producing a SyntaxError on device. The structural delimiters below do not appear
535
+ // inside string-literal openers, so the rewrite is safe.
536
+ result = result.replace(/([;}\)\]])\s*(import\s+[^;\n]*\s+from\s*["'][^"']+["'])/g, '$1\n$2');
537
+ }
538
+ catch { }
539
+ // Collapse duplicate destructuring from the same temp namespace var (e.g., multiple const { x } = __ns_rt_ns1)
540
+ try {
541
+ const collapse = (code, prefix) => {
542
+ const re = new RegExp(`(^|\\n)\\s*const\\s*\\{([^}]+)\\}\\s*=\\s*(${prefix}\\d+)\\s*;?\\s*`, 'gm');
543
+ const byVar = {};
544
+ code.replace(re, (_full, _pfx, specList, varName) => {
545
+ const set = (byVar[varName] || (byVar[varName] = new Set()));
546
+ String(specList)
547
+ .split(',')
548
+ .map((s) => s.trim())
549
+ .filter(Boolean)
550
+ .forEach((seg) => set.add(seg));
551
+ return '';
552
+ });
553
+ if (Object.keys(byVar).length) {
554
+ // Remove all existing destructures first
555
+ code = code.replace(re, (full, pfx) => pfx || '');
556
+ // Re-emit one per var
557
+ const blocks = Object.entries(byVar).map(([varName, set]) => `const { ${Array.from(set).join(', ')} } = ${varName};`);
558
+ code = blocks.join('\n') + '\n' + code;
559
+ }
560
+ return code;
561
+ };
562
+ result = collapse(result, '__ns_rt_ns');
563
+ result = collapse(result, '__ns_core_ns');
564
+ }
565
+ catch { }
566
+ // After consolidating destructures, hoist static import declarations to the very top so imports
567
+ // always come before any statements that might reference their bindings. This ordering avoids
568
+ // device runtimes that are stricter about imports-first semantics during module instantiation.
569
+ try {
570
+ result = hoistTopLevelStaticImports(result);
571
+ }
572
+ catch { }
573
+ // Final safety: normalize any lingering named imports from /ns/rt into default+destructure
574
+ // Skip for node_modules (no /ns/rt helpers needed) and when AST marker present
575
+ try {
576
+ if (!isNodeModule && !/^\s*\/\* \[ast-normalized\] \*\//m.test(result)) {
577
+ result = ensureDestructureRtImports(result);
578
+ }
579
+ }
580
+ catch { }
581
+ // Post-pass: if both a destructure from __ns_rt_ns* and named imports from /ns/rt exist,
582
+ // remove overlapping named specifiers to avoid "Identifier has already been declared".
583
+ try {
584
+ // Collect all bindings destructured from any __ns_rt_ns* temp
585
+ const rtDestructureRE = /(^|\n)\s*const\s*\{([^}]+)\}\s*=\s*(__ns_rt_ns(?:\d+|_re))\s*;?\s*/gm;
586
+ const rtBound = new Set();
587
+ let m;
588
+ while ((m = rtDestructureRE.exec(result)) !== null) {
589
+ const specList = String(m[2] || '');
590
+ specList
591
+ .split(',')
592
+ .map((s) => s.trim())
593
+ .filter(Boolean)
594
+ .forEach((seg) => {
595
+ const bind = seg.includes(':') ? seg.split(':')[1].trim() : seg;
596
+ if (bind)
597
+ rtBound.add(bind);
598
+ });
599
+ }
600
+ if (rtBound.size) {
601
+ // Rewrite named imports from /ns/rt by removing any specifiers already provided via destructure
602
+ const rtNamedImportRE = /(^|\n)\s*import\s*\{([^}]+)\}\s*from\s*["']((?:https?:\/\/[^"']+)?\/ns\/rt(?:\/[\d]+)?)["'];?\s*/gm;
603
+ const edits = [];
604
+ while ((m = rtNamedImportRE.exec(result)) !== null) {
605
+ const full = m[0];
606
+ const pfx = m[1] || '';
607
+ const specList = String(m[2] || '');
608
+ const src = m[3];
609
+ const kept = [];
610
+ specList
611
+ .split(',')
612
+ .map((s) => s.trim())
613
+ .filter(Boolean)
614
+ .forEach((seg) => {
615
+ const name = seg.split(/\s+as\s+/i)[0].trim();
616
+ if (!rtBound.has(name))
617
+ kept.push(seg);
618
+ });
619
+ let replacement = '';
620
+ if (kept.length) {
621
+ replacement = `${pfx}import { ${kept.join(', ')} } from ${JSON.stringify(src)};`;
622
+ }
623
+ else {
624
+ // Drop the import entirely if nothing remains
625
+ replacement = pfx || '';
626
+ }
627
+ edits.push({
628
+ start: rtNamedImportRE.lastIndex - full.length,
629
+ end: rtNamedImportRE.lastIndex,
630
+ text: replacement,
631
+ });
632
+ }
633
+ if (edits.length) {
634
+ // Apply edits in reverse order
635
+ edits
636
+ .sort((a, b) => b.start - a.start)
637
+ .forEach((e) => {
638
+ result = result.slice(0, e.start) + e.text + result.slice(e.end);
639
+ });
640
+ }
641
+ }
642
+ }
643
+ catch { }
644
+ // Tidy-ups: remove stray lines that are only semicolons and collapse excessive blank lines
645
+ try {
646
+ // Remove lines that contain only an optional whitespace and a single ';'
647
+ result = result.replace(/^[ \t]*;[ \t]*$/gm, '');
648
+ // Collapse 3+ blank lines into at most 2 to keep output compact and consistent
649
+ result = result.replace(/\n{3,}/g, '\n\n');
650
+ }
651
+ catch { }
652
+ // De-duplicate destructured bindings across different temp vars to avoid 'Identifier has already been declared'
653
+ try {
654
+ const reDestructureAny = /(^|\n)\s*const\s*\{([^}]+)\}\s*=\s*(__ns_(?:rt|core)_[A-Za-z0-9_]+)\s*;?\s*/gm;
655
+ const seenBindings = new Set();
656
+ const edits = [];
657
+ let m;
658
+ while ((m = reDestructureAny.exec(result)) !== null) {
659
+ const full = m[0];
660
+ const pfx = m.index;
661
+ const specList = m[2];
662
+ const varName = m[3];
663
+ const entries = specList
664
+ .split(',')
665
+ .map((s) => s.trim())
666
+ .filter(Boolean);
667
+ const kept = [];
668
+ for (const seg of entries) {
669
+ const bind = seg.includes(':') ? seg.split(':')[1].trim() : seg;
670
+ if (seenBindings.has(bind))
671
+ continue;
672
+ seenBindings.add(bind);
673
+ kept.push(seg);
674
+ }
675
+ const replacement = kept.length ? `${m[1]}const { ${kept.join(', ')} } = ${varName};` : m[1] || '';
676
+ edits.push({ start: pfx, end: pfx + full.length, text: replacement });
677
+ }
678
+ if (edits.length) {
679
+ // Apply edits in reverse order to not mess up indices
680
+ edits
681
+ .sort((a, b) => b.start - a.start)
682
+ .forEach((e) => {
683
+ result = result.slice(0, e.start) + e.text + result.slice(e.end);
684
+ });
685
+ }
686
+ }
687
+ catch { }
688
+ // As a final safety net, neutralize any uses of Vite's CJS import helpers when the helper variable
689
+ // itself is not declared (e.g., stripped earlier during sanitation). This prevents runtime errors like
690
+ // "Cannot read properties of undefined (reading 'initNorrix')" on device when accessing
691
+ // __vite__cjsImportX__pkg["prop"].
692
+ try {
693
+ result = stripDanglingViteCjsImports(result);
694
+ }
695
+ catch { }
696
+ return result;
697
+ }
698
+ export { processCodeForDevice, cleanCode, collectImportDependencies };
699
+ //# sourceMappingURL=process-code-for-device.js.map