@nativescript/vite 8.0.0-alpha.4 → 8.0.0-alpha.41

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