neo.mjs 10.0.0-beta.5 → 10.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (491) hide show
  1. package/.github/RELEASE_NOTES/v10.0.0-beta.1.md +20 -0
  2. package/.github/RELEASE_NOTES/v10.0.0-beta.2.md +73 -0
  3. package/.github/RELEASE_NOTES/v10.0.0-beta.3.md +39 -0
  4. package/.github/RELEASE_NOTES/v10.0.0-beta.5.md +70 -0
  5. package/.github/RELEASE_NOTES/v10.0.0-beta.6.md +48 -0
  6. package/.github/RELEASE_NOTES/v10.0.0.md +52 -0
  7. package/.github/epic-functional-components.md +498 -0
  8. package/.github/ticket-asymmetric-vdom-updates.md +122 -0
  9. package/README.md +0 -3
  10. package/ServiceWorker.mjs +2 -2
  11. package/apps/colors/store/Colors.mjs +1 -0
  12. package/apps/colors/view/GridContainer.mjs +3 -0
  13. package/apps/colors/view/HeaderToolbar.mjs +2 -0
  14. package/apps/colors/view/Viewport.mjs +3 -0
  15. package/apps/covid/view/FooterContainer.mjs +3 -0
  16. package/apps/covid/view/GalleryContainer.mjs +2 -0
  17. package/apps/covid/view/GalleryContainerController.mjs +1 -0
  18. package/apps/covid/view/HeaderContainer.mjs +2 -0
  19. package/apps/covid/view/HelixContainer.mjs +2 -0
  20. package/apps/covid/view/HelixContainerController.mjs +1 -0
  21. package/apps/covid/view/MainContainer.mjs +3 -0
  22. package/apps/covid/view/TableContainer.mjs +3 -0
  23. package/apps/covid/view/TableContainerController.mjs +1 -0
  24. package/apps/covid/view/WorldMapContainer.mjs +2 -0
  25. package/apps/covid/view/country/Gallery.mjs +3 -0
  26. package/apps/covid/view/country/Helix.mjs +8 -0
  27. package/apps/covid/view/country/HistoricalDataTable.mjs +1 -0
  28. package/apps/covid/view/country/Table.mjs +2 -0
  29. package/apps/covid/view/mapboxGl/Component.mjs +1 -0
  30. package/apps/covid/view/mapboxGl/Container.mjs +2 -0
  31. package/apps/email/EPIC_PLAN.md +58 -0
  32. package/apps/email/neo-config.json +2 -2
  33. package/apps/email/store/Emails.mjs +11 -1
  34. package/apps/email/view/ComposeView.mjs +44 -0
  35. package/apps/email/view/MainView.mjs +89 -0
  36. package/apps/email/view/Viewport.mjs +4 -33
  37. package/apps/email/view/ViewportStateProvider.mjs +3 -3
  38. package/apps/form/store/SideNav.mjs +1 -0
  39. package/apps/form/view/FormContainer.mjs +1 -0
  40. package/apps/form/view/FormPageContainer.mjs +2 -0
  41. package/apps/form/view/SideNavList.mjs +1 -0
  42. package/apps/form/view/Viewport.mjs +3 -0
  43. package/apps/portal/childapps/preview/MainContainer.mjs +1 -0
  44. package/apps/portal/index.html +1 -1
  45. package/apps/portal/store/BlogPosts.mjs +2 -0
  46. package/apps/portal/store/Content.mjs +1 -0
  47. package/apps/portal/store/ContentSections.mjs +1 -0
  48. package/apps/portal/store/Examples.mjs +1 -0
  49. package/apps/portal/view/HeaderToolbar.mjs +1 -0
  50. package/apps/portal/view/Viewport.mjs +5 -0
  51. package/apps/portal/view/ViewportController.mjs +11 -3
  52. package/apps/portal/view/about/Container.mjs +2 -0
  53. package/apps/portal/view/about/MemberContainer.mjs +7 -0
  54. package/apps/portal/view/blog/Container.mjs +2 -0
  55. package/apps/portal/view/blog/List.mjs +2 -0
  56. package/apps/portal/view/examples/List.mjs +29 -19
  57. package/apps/portal/view/examples/TabContainer.mjs +4 -0
  58. package/apps/portal/view/home/ContentBox.mjs +3 -0
  59. package/apps/portal/view/home/FeatureSection.mjs +8 -0
  60. package/apps/portal/view/home/FooterContainer.mjs +4 -1
  61. package/apps/portal/view/home/MainContainer.mjs +2 -0
  62. package/apps/portal/view/home/parts/AfterMath.mjs +2 -0
  63. package/apps/portal/view/home/parts/BaseContainer.mjs +1 -0
  64. package/apps/portal/view/home/parts/Colors.mjs +4 -0
  65. package/apps/portal/view/home/parts/Features.mjs +2 -0
  66. package/apps/portal/view/home/parts/Helix.mjs +5 -0
  67. package/apps/portal/view/home/parts/How.mjs +4 -0
  68. package/apps/portal/view/home/parts/MainNeo.mjs +1 -0
  69. package/apps/portal/view/home/parts/References.mjs +2 -0
  70. package/apps/portal/view/learn/ContentComponent.mjs +11 -5
  71. package/apps/portal/view/learn/ContentTreeList.mjs +2 -0
  72. package/apps/portal/view/learn/CubeLayoutButton.mjs +1 -0
  73. package/apps/portal/view/learn/MainContainer.mjs +4 -0
  74. package/apps/portal/view/learn/PageContainer.mjs +2 -0
  75. package/apps/portal/view/learn/PageSectionsContainer.mjs +3 -0
  76. package/apps/portal/view/learn/PageSectionsList.mjs +1 -0
  77. package/apps/portal/view/services/Component.mjs +1 -0
  78. package/apps/realworld/api/Base.mjs +1 -0
  79. package/apps/realworld/view/HeaderComponent.mjs +4 -0
  80. package/apps/realworld/view/HomeComponent.mjs +7 -0
  81. package/apps/realworld/view/MainContainer.mjs +2 -0
  82. package/apps/realworld/view/MainContainerController.mjs +2 -0
  83. package/apps/realworld/view/article/CommentComponent.mjs +3 -0
  84. package/apps/realworld/view/article/Component.mjs +17 -10
  85. package/apps/realworld/view/article/CreateCommentComponent.mjs +2 -0
  86. package/apps/realworld/view/article/CreateComponent.mjs +5 -0
  87. package/apps/realworld/view/article/PreviewComponent.mjs +9 -0
  88. package/apps/realworld/view/article/TagListComponent.mjs +2 -0
  89. package/apps/realworld/view/user/ProfileComponent.mjs +7 -0
  90. package/apps/realworld/view/user/SettingsComponent.mjs +5 -0
  91. package/apps/realworld/view/user/SignUpComponent.mjs +3 -0
  92. package/apps/realworld2/api/Base.mjs +1 -0
  93. package/apps/realworld2/view/FooterComponent.mjs +1 -0
  94. package/apps/realworld2/view/HeaderToolbar.mjs +3 -0
  95. package/apps/realworld2/view/HomeContainer.mjs +1 -0
  96. package/apps/realworld2/view/MainContainer.mjs +2 -0
  97. package/apps/realworld2/view/MainContainerController.mjs +1 -0
  98. package/apps/realworld2/view/article/Helix.mjs +1 -0
  99. package/apps/realworld2/view/article/PreviewComponent.mjs +9 -0
  100. package/apps/realworld2/view/article/PreviewList.mjs +1 -0
  101. package/apps/realworld2/view/article/TagListComponent.mjs +2 -0
  102. package/apps/route/view/CenterContainer.mjs +1 -0
  103. package/apps/route/view/MainView.mjs +1 -0
  104. package/apps/sharedcovid/childapps/sharedcovidchart/MainContainer.mjs +1 -0
  105. package/apps/sharedcovid/childapps/sharedcovidgallery/MainContainer.mjs +1 -0
  106. package/apps/sharedcovid/childapps/sharedcovidhelix/MainContainer.mjs +1 -0
  107. package/apps/sharedcovid/childapps/sharedcovidmap/MainContainer.mjs +1 -0
  108. package/apps/sharedcovid/view/FooterContainer.mjs +3 -0
  109. package/apps/sharedcovid/view/GalleryContainer.mjs +2 -0
  110. package/apps/sharedcovid/view/GalleryContainerController.mjs +1 -0
  111. package/apps/sharedcovid/view/HeaderContainer.mjs +2 -0
  112. package/apps/sharedcovid/view/HelixContainer.mjs +2 -0
  113. package/apps/sharedcovid/view/HelixContainerController.mjs +1 -0
  114. package/apps/sharedcovid/view/MainContainer.mjs +3 -0
  115. package/apps/sharedcovid/view/TableContainer.mjs +3 -0
  116. package/apps/sharedcovid/view/TableContainerController.mjs +1 -0
  117. package/apps/sharedcovid/view/WorldMapContainer.mjs +2 -0
  118. package/apps/sharedcovid/view/country/Gallery.mjs +3 -0
  119. package/apps/sharedcovid/view/country/Helix.mjs +8 -0
  120. package/apps/sharedcovid/view/country/HistoricalDataTable.mjs +1 -0
  121. package/apps/sharedcovid/view/country/Table.mjs +2 -0
  122. package/apps/sharedcovid/view/mapboxGl/Component.mjs +1 -0
  123. package/apps/sharedcovid/view/mapboxGl/Container.mjs +2 -0
  124. package/apps/shareddialog/childapps/shareddialog2/view/MainContainer.mjs +2 -0
  125. package/apps/shareddialog/view/DemoDialog.mjs +2 -0
  126. package/apps/shareddialog/view/MainContainer.mjs +2 -0
  127. package/apps/shareddialog/view/MainContainerController.mjs +1 -0
  128. package/buildScripts/addReactiveTags.mjs +191 -0
  129. package/buildScripts/checkReactiveTags.mjs +160 -0
  130. package/docs/app/store/Api.mjs +1 -0
  131. package/docs/app/store/Examples.mjs +1 -0
  132. package/docs/app/view/ApiTreeList.mjs +1 -0
  133. package/docs/app/view/ContentTabContainer.mjs +2 -0
  134. package/docs/app/view/ExamplesTreeList.mjs +2 -0
  135. package/docs/app/view/HeaderContainer.mjs +3 -0
  136. package/docs/app/view/MainContainer.mjs +5 -0
  137. package/docs/app/view/classdetails/HeaderComponent.mjs +1 -0
  138. package/docs/app/view/classdetails/MainContainer.mjs +3 -0
  139. package/docs/app/view/classdetails/MembersList.mjs +5 -0
  140. package/docs/app/view/classdetails/SourceViewComponent.mjs +2 -0
  141. package/examples/ConfigurationViewport.mjs +14 -8
  142. package/examples/calendar/weekview/MainContainer.mjs +4 -0
  143. package/examples/component/coronaGallery/CountryGallery.mjs +2 -0
  144. package/examples/component/coronaGallery/CountryStore.mjs +1 -0
  145. package/examples/component/coronaGallery/Viewport.mjs +3 -0
  146. package/examples/component/coronaGallery/ViewportController.mjs +1 -0
  147. package/examples/component/coronaHelix/CountryHelix.mjs +7 -0
  148. package/examples/component/coronaHelix/MainContainer.mjs +1 -0
  149. package/examples/component/gallery/ImageStore.mjs +1 -0
  150. package/examples/component/helix/ImageStore.mjs +1 -0
  151. package/examples/component/helix/Viewport.mjs +3 -0
  152. package/examples/component/helix/ViewportController.mjs +1 -0
  153. package/examples/component/multiWindowCoronaGallery/childapp/Viewport.mjs +1 -0
  154. package/examples/component/multiWindowHelix/childapp/Viewport.mjs +1 -0
  155. package/examples/component/wrapper/googleMaps/MapComponent.mjs +2 -0
  156. package/examples/core/config/MainContainer.mjs +2 -0
  157. package/examples/dialog/DemoDialog.mjs +2 -0
  158. package/examples/dialog/MainContainer.mjs +1 -0
  159. package/examples/form/field/color/MainStore.mjs +1 -0
  160. package/examples/functional/button/base/MainContainer.mjs +207 -0
  161. package/examples/functional/button/base/app.mjs +6 -0
  162. package/examples/functional/button/base/index.html +11 -0
  163. package/examples/functional/button/base/neo-config.json +6 -0
  164. package/examples/functional/defineComponent/Component.mjs +18 -0
  165. package/examples/functional/defineComponent/MainContainer.mjs +41 -0
  166. package/examples/functional/defineComponent/app.mjs +6 -0
  167. package/examples/functional/defineComponent/index.html +11 -0
  168. package/examples/functional/defineComponent/neo-config.json +6 -0
  169. package/examples/functional/hostComponent/Component.mjs +32 -0
  170. package/examples/functional/hostComponent/MainContainer.mjs +48 -0
  171. package/examples/functional/hostComponent/app.mjs +6 -0
  172. package/examples/functional/hostComponent/index.html +11 -0
  173. package/examples/functional/hostComponent/neo-config.json +6 -0
  174. package/examples/grid/animatedRowSorting/Viewport.mjs +1 -1
  175. package/examples/grid/bigData/ControlsContainer.mjs +3 -0
  176. package/examples/grid/bigData/GridContainer.mjs +4 -2
  177. package/examples/grid/bigData/MainContainer.mjs +2 -0
  178. package/examples/grid/bigData/MainModel.mjs +1 -0
  179. package/examples/grid/bigData/MainStore.mjs +3 -0
  180. package/examples/grid/cellEditing/MainContainer.mjs +1 -1
  181. package/examples/grid/container/MainContainer.mjs +1 -1
  182. package/examples/grid/covid/GridContainer.mjs +3 -0
  183. package/examples/grid/covid/MainContainer.mjs +2 -0
  184. package/examples/grid/covid/Store.mjs +1 -0
  185. package/examples/grid/nestedRecordFields/EditUserDialog.mjs +3 -0
  186. package/examples/grid/nestedRecordFields/Viewport.mjs +3 -1
  187. package/examples/list/animate/List.mjs +4 -0
  188. package/examples/list/animate/MainContainer.mjs +2 -0
  189. package/examples/list/circle/MainStore.mjs +1 -0
  190. package/examples/list/color/MainStore.mjs +1 -0
  191. package/examples/preloadingAssets/view/MainContainer.mjs +2 -0
  192. package/examples/stateProvider/advanced/MainContainer.mjs +1 -0
  193. package/examples/stateProvider/dialog/EditUserDialog.mjs +2 -0
  194. package/examples/stateProvider/dialog/MainContainer.mjs +1 -0
  195. package/examples/stateProvider/extendedClass/MainContainer.mjs +2 -0
  196. package/examples/stateProvider/inline/MainContainer.mjs +1 -0
  197. package/examples/stateProvider/inlineNoStateProvider/MainContainer.mjs +1 -0
  198. package/examples/stateProvider/inlineNoStateProvider/MainContainerController.mjs +2 -0
  199. package/examples/stateProvider/multiWindow/EditUserDialog.mjs +3 -0
  200. package/examples/stateProvider/multiWindow/MainContainer.mjs +1 -0
  201. package/examples/stateProvider/multiWindow/Viewport.mjs +1 -0
  202. package/examples/stateProvider/nestedData/MainContainer.mjs +1 -0
  203. package/examples/stateProvider/table/MainContainer.mjs +1 -0
  204. package/examples/table/covid/MainContainer.mjs +2 -0
  205. package/examples/table/covid/Store.mjs +1 -0
  206. package/examples/table/covid/TableContainer.mjs +3 -0
  207. package/examples/table/nestedRecordFields/EditUserDialog.mjs +3 -0
  208. package/examples/table/nestedRecordFields/Viewport.mjs +1 -0
  209. package/examples/todoList/version1/MainComponent.mjs +1 -1
  210. package/examples/toolbar/breadcrumb/view/MainContainer.mjs +2 -0
  211. package/examples/toolbar/paging/store/Users.mjs +1 -0
  212. package/examples/toolbar/paging/view/AddUserDialog.mjs +3 -0
  213. package/examples/toolbar/paging/view/MainContainer.mjs +3 -0
  214. package/examples/treeAccordion/MainContainer.mjs +2 -2
  215. package/examples/worker/task/MainContainer.mjs +1 -0
  216. package/learn/Glossary.md +1 -0
  217. package/learn/UsingTheseTopics.md +1 -0
  218. package/learn/benefits/ConfigSystem.md +2 -0
  219. package/learn/benefits/Effort.md +1 -0
  220. package/learn/benefits/Features.md +1 -0
  221. package/learn/benefits/FormsEngine.md +1 -0
  222. package/learn/benefits/FourEnvironments.md +2 -0
  223. package/learn/benefits/Introduction.md +2 -0
  224. package/learn/benefits/MultiWindow.md +3 -1
  225. package/learn/benefits/OffTheMainThread.md +2 -0
  226. package/learn/benefits/Quick.md +2 -0
  227. package/learn/benefits/RPCLayer.md +2 -0
  228. package/learn/benefits/Speed.md +2 -0
  229. package/learn/blog/v10-deep-dive-functional-components.md +293 -0
  230. package/learn/blog/v10-deep-dive-reactivity.md +522 -0
  231. package/learn/blog/v10-deep-dive-state-provider.md +432 -0
  232. package/learn/blog/v10-deep-dive-vdom-revolution.md +194 -0
  233. package/learn/blog/v10-post1-love-story.md +383 -0
  234. package/learn/comparisons/NeoVsAngular.md +90 -0
  235. package/learn/comparisons/NeoVsExtJs.md +178 -0
  236. package/learn/comparisons/NeoVsNextJs.md +124 -0
  237. package/learn/comparisons/NeoVsReact.md +95 -0
  238. package/learn/comparisons/NeoVsSolid.md +78 -0
  239. package/learn/comparisons/NeoVsVue.md +92 -0
  240. package/learn/comparisons/Overview.md +46 -0
  241. package/learn/gettingstarted/ComponentModels.md +2 -0
  242. package/learn/gettingstarted/Config.md +2 -0
  243. package/learn/gettingstarted/DescribingTheUI.md +2 -0
  244. package/learn/gettingstarted/Events.md +2 -0
  245. package/learn/gettingstarted/Extending.md +2 -0
  246. package/learn/gettingstarted/References.md +2 -0
  247. package/learn/gettingstarted/Setup.md +3 -2
  248. package/learn/gettingstarted/Workspaces.md +2 -0
  249. package/learn/guides/datahandling/Collections.md +1 -0
  250. package/learn/guides/datahandling/Records.md +1 -0
  251. package/learn/guides/datahandling/StateProviders.md +130 -16
  252. package/learn/guides/datahandling/Tables.md +1 -1
  253. package/learn/guides/fundamentals/ConfigSystemDeepDive.md +1 -0
  254. package/learn/guides/fundamentals/DeclarativeComponentTreesVsImperativeVdom.md +2 -0
  255. package/learn/guides/fundamentals/DeclarativeVDOMWithEffects.md +10 -8
  256. package/learn/guides/fundamentals/ExtendingNeoClasses.md +1 -0
  257. package/learn/guides/fundamentals/InstanceLifecycle.md +3 -1
  258. package/learn/guides/fundamentals/MainThreadAddons.md +2 -0
  259. package/learn/guides/specificfeatures/Mixins.md +3 -1
  260. package/learn/guides/specificfeatures/MultiWindow.md +3 -1
  261. package/learn/guides/specificfeatures/PortalApp.md +2 -0
  262. package/learn/guides/uibuildingblocks/ComponentsAndContainers.md +2 -0
  263. package/learn/guides/uibuildingblocks/CustomComponents.md +2 -0
  264. package/learn/guides/uibuildingblocks/Layouts.md +2 -0
  265. package/learn/guides/uibuildingblocks/WorkingWithVDom.md +28 -2
  266. package/learn/guides/userinteraction/Forms.md +2 -0
  267. package/learn/guides/userinteraction/events/CustomEvents.md +2 -1
  268. package/learn/guides/userinteraction/events/DomEvents.md +2 -0
  269. package/learn/javascript/ClassFeatures.md +4 -3
  270. package/learn/javascript/Classes.md +10 -13
  271. package/learn/javascript/Overrides.md +10 -6
  272. package/learn/javascript/Super.md +12 -8
  273. package/learn/tree.json +71 -64
  274. package/learn/tutorials/Earthquakes.md +2 -0
  275. package/learn/tutorials/RSP.md +3 -1
  276. package/learn/tutorials/TodoList.md +103 -7
  277. package/package.json +8 -6
  278. package/resources/scss/src/apps/email/ComposeView.scss +16 -0
  279. package/resources/scss/src/apps/email/MainView.scss +5 -0
  280. package/resources/scss/src/apps/portal/learn/ContentComponent.scss +5 -4
  281. package/src/DefaultConfig.mjs +12 -2
  282. package/src/Main.mjs +1 -0
  283. package/src/Neo.mjs +219 -166
  284. package/src/Xhr.mjs +1 -0
  285. package/src/button/Base.mjs +13 -0
  286. package/src/button/Effect.mjs +16 -2
  287. package/src/button/Split.mjs +2 -0
  288. package/src/calendar/store/Calendars.mjs +1 -0
  289. package/src/calendar/store/Colors.mjs +1 -0
  290. package/src/calendar/store/Events.mjs +1 -0
  291. package/src/calendar/view/DayComponent.mjs +2 -0
  292. package/src/calendar/view/EditEventContainer.mjs +4 -1
  293. package/src/calendar/view/MainContainer.mjs +13 -0
  294. package/src/calendar/view/MainContainerStateProvider.mjs +14 -28
  295. package/src/calendar/view/SettingsContainer.mjs +1 -0
  296. package/src/calendar/view/YearComponent.mjs +16 -0
  297. package/src/calendar/view/calendars/ColorsList.mjs +2 -0
  298. package/src/calendar/view/calendars/Container.mjs +2 -0
  299. package/src/calendar/view/calendars/EditContainer.mjs +1 -0
  300. package/src/calendar/view/month/Component.mjs +11 -0
  301. package/src/calendar/view/settings/GeneralContainer.mjs +1 -0
  302. package/src/calendar/view/settings/MonthContainer.mjs +1 -0
  303. package/src/calendar/view/settings/WeekContainer.mjs +1 -0
  304. package/src/calendar/view/settings/YearContainer.mjs +1 -0
  305. package/src/calendar/view/week/Component.mjs +15 -1
  306. package/src/calendar/view/week/TimeAxisComponent.mjs +4 -0
  307. package/src/code/LivePreview.mjs +51 -23
  308. package/src/collection/Base.mjs +7 -10
  309. package/src/collection/Filter.mjs +6 -0
  310. package/src/collection/Sorter.mjs +3 -0
  311. package/src/component/Abstract.mjs +412 -0
  312. package/src/component/Base.mjs +48 -1077
  313. package/src/component/Canvas.mjs +1 -0
  314. package/src/component/Chip.mjs +4 -0
  315. package/src/component/Circle.mjs +14 -0
  316. package/src/component/Clock.mjs +4 -0
  317. package/src/component/DateSelector.mjs +12 -0
  318. package/src/component/Gallery.mjs +11 -0
  319. package/src/component/Helix.mjs +24 -0
  320. package/src/component/Label.mjs +1 -0
  321. package/src/component/Legend.mjs +3 -0
  322. package/src/component/MagicMoveText.mjs +4 -0
  323. package/src/component/Progress.mjs +3 -0
  324. package/src/component/Splitter.mjs +3 -0
  325. package/src/component/StatusBadge.mjs +6 -0
  326. package/src/component/Timer.mjs +4 -0
  327. package/src/component/Toast.mjs +6 -0
  328. package/src/component/Video.mjs +1 -0
  329. package/src/component/mwc/Button.mjs +7 -0
  330. package/src/component/mwc/TextField.mjs +9 -0
  331. package/src/component/wrapper/AmChart.mjs +2 -0
  332. package/src/component/wrapper/GoogleMaps.mjs +3 -0
  333. package/src/component/wrapper/MapboxGL.mjs +5 -0
  334. package/src/component/wrapper/MonacoEditor.mjs +12 -0
  335. package/src/container/Accordion.mjs +2 -0
  336. package/src/container/Base.mjs +7 -3
  337. package/src/container/Panel.mjs +1 -0
  338. package/src/container/Viewport.mjs +1 -0
  339. package/src/controller/Application.mjs +1 -0
  340. package/src/controller/Base.mjs +1 -0
  341. package/src/controller/Component.mjs +1 -0
  342. package/src/core/Base.mjs +86 -33
  343. package/src/core/Compare.mjs +4 -7
  344. package/src/core/Config.mjs +65 -52
  345. package/src/core/Effect.mjs +86 -24
  346. package/src/core/EffectManager.mjs +117 -8
  347. package/src/core/IdGenerator.mjs +13 -44
  348. package/src/core/Observable.mjs +69 -65
  349. package/src/data/Model.mjs +2 -0
  350. package/src/data/Store.mjs +7 -0
  351. package/src/data/connection/WebSocket.mjs +2 -0
  352. package/src/date/DayViewComponent.mjs +2 -0
  353. package/src/date/SelectorContainer.mjs +14 -0
  354. package/src/dialog/Base.mjs +8 -0
  355. package/src/draggable/DragZone.mjs +5 -0
  356. package/src/draggable/tree/DragZone.mjs +1 -0
  357. package/src/filter/BooleanContainer.mjs +2 -0
  358. package/src/filter/NumberContainer.mjs +3 -0
  359. package/src/filter/ToggleOperatorsButton.mjs +2 -0
  360. package/src/form/Fieldset.mjs +6 -0
  361. package/src/form/field/Base.mjs +7 -0
  362. package/src/form/field/CheckBox.mjs +18 -0
  363. package/src/form/field/Chip.mjs +1 -0
  364. package/src/form/field/ComboBox.mjs +8 -0
  365. package/src/form/field/Country.mjs +1 -0
  366. package/src/form/field/Currency.mjs +2 -0
  367. package/src/form/field/Date.mjs +4 -0
  368. package/src/form/field/Display.mjs +1 -0
  369. package/src/form/field/Email.mjs +1 -0
  370. package/src/form/field/FileUpload.mjs +7 -0
  371. package/src/form/field/Hidden.mjs +1 -0
  372. package/src/form/field/Number.mjs +7 -0
  373. package/src/form/field/Password.mjs +1 -0
  374. package/src/form/field/Phone.mjs +3 -0
  375. package/src/form/field/Picker.mjs +2 -0
  376. package/src/form/field/Radio.mjs +1 -0
  377. package/src/form/field/Range.mjs +3 -0
  378. package/src/form/field/Search.mjs +2 -0
  379. package/src/form/field/Text.mjs +43 -5
  380. package/src/form/field/TextArea.mjs +7 -0
  381. package/src/form/field/Time.mjs +6 -0
  382. package/src/form/field/Url.mjs +3 -0
  383. package/src/form/field/ZipCode.mjs +2 -0
  384. package/src/form/field/trigger/Base.mjs +3 -0
  385. package/src/form/field/trigger/Clear.mjs +2 -0
  386. package/src/form/field/trigger/CopyToClipboard.mjs +2 -0
  387. package/src/form/field/trigger/Date.mjs +1 -0
  388. package/src/form/field/trigger/Picker.mjs +1 -0
  389. package/src/form/field/trigger/Search.mjs +1 -0
  390. package/src/form/field/trigger/SpinDown.mjs +2 -0
  391. package/src/form/field/trigger/SpinUp.mjs +1 -0
  392. package/src/form/field/trigger/Time.mjs +2 -0
  393. package/src/functional/_export.mjs +6 -0
  394. package/src/functional/button/Base.mjs +384 -0
  395. package/src/functional/component/Base.mjs +405 -0
  396. package/src/functional/defineComponent.mjs +102 -0
  397. package/src/functional/useConfig.mjs +52 -0
  398. package/src/functional/useEvent.mjs +43 -0
  399. package/src/grid/Body.mjs +20 -1
  400. package/src/grid/Container.mjs +50 -60
  401. package/src/grid/ScrollManager.mjs +2 -0
  402. package/src/grid/VerticalScrollbar.mjs +2 -0
  403. package/src/grid/column/Base.mjs +2 -0
  404. package/src/grid/header/Button.mjs +7 -0
  405. package/src/grid/header/Toolbar.mjs +6 -0
  406. package/src/grid/plugin/AnimateRows.mjs +2 -0
  407. package/src/layout/Base.mjs +3 -0
  408. package/src/layout/Card.mjs +1 -0
  409. package/src/layout/Cube.mjs +18 -4
  410. package/src/layout/Fit.mjs +1 -0
  411. package/src/layout/Flexbox.mjs +7 -0
  412. package/src/layout/Form.mjs +2 -0
  413. package/src/layout/Grid.mjs +1 -0
  414. package/src/layout/HBox.mjs +1 -0
  415. package/src/layout/VBox.mjs +1 -0
  416. package/src/list/Base.mjs +13 -0
  417. package/src/list/Chip.mjs +1 -0
  418. package/src/list/Circle.mjs +2 -0
  419. package/src/list/Color.mjs +1 -0
  420. package/src/list/plugin/Animate.mjs +2 -0
  421. package/src/main/DeltaUpdates.mjs +1 -0
  422. package/src/main/DomEvents.mjs +2 -0
  423. package/src/main/addon/CloneNode.mjs +1 -0
  424. package/src/main/addon/Cookie.mjs +1 -0
  425. package/src/main/addon/GoogleMaps.mjs +1 -0
  426. package/src/main/addon/LocalStorage.mjs +1 -0
  427. package/src/main/addon/MapboxGL.mjs +1 -0
  428. package/src/main/addon/Markdown.mjs +1 -0
  429. package/src/main/addon/Navigator.mjs +1 -0
  430. package/src/main/addon/Popover.mjs +1 -0
  431. package/src/main/addon/Stylesheet.mjs +1 -0
  432. package/src/main/addon/WindowPosition.mjs +1 -0
  433. package/src/manager/Component.mjs +0 -71
  434. package/src/manager/VDomUpdate.mjs +320 -0
  435. package/src/menu/List.mjs +6 -0
  436. package/src/menu/Model.mjs +1 -0
  437. package/src/menu/Panel.mjs +3 -0
  438. package/src/menu/Store.mjs +1 -0
  439. package/src/mixin/DomEvents.mjs +130 -0
  440. package/src/mixin/VdomLifecycle.mjs +670 -0
  441. package/src/plugin/Base.mjs +1 -0
  442. package/src/plugin/Resizable.mjs +2 -0
  443. package/src/selection/Model.mjs +15 -18
  444. package/src/selection/grid/BaseModel.mjs +1 -0
  445. package/src/sitemap/Component.mjs +1 -0
  446. package/src/state/Provider.mjs +129 -87
  447. package/src/state/createHierarchicalDataProxy.mjs +39 -25
  448. package/src/tab/Container.mjs +6 -0
  449. package/src/tab/Strip.mjs +1 -0
  450. package/src/tab/header/Button.mjs +2 -0
  451. package/src/tab/header/EffectButton.mjs +2 -0
  452. package/src/tab/header/Toolbar.mjs +1 -0
  453. package/src/table/Body.mjs +3 -0
  454. package/src/table/Container.mjs +10 -0
  455. package/src/table/header/Button.mjs +8 -0
  456. package/src/table/header/Toolbar.mjs +5 -0
  457. package/src/table/plugin/CellEditing.mjs +1 -0
  458. package/src/toolbar/Base.mjs +4 -0
  459. package/src/toolbar/Breadcrumb.mjs +3 -0
  460. package/src/toolbar/Paging.mjs +5 -0
  461. package/src/tooltip/Base.mjs +2 -0
  462. package/src/tree/List.mjs +3 -0
  463. package/src/util/HashHistory.mjs +1 -0
  464. package/src/util/KeyNavigation.mjs +2 -0
  465. package/src/util/Matrix.mjs +1 -0
  466. package/src/util/VDom.mjs +18 -5
  467. package/src/util/VNode.mjs +7 -1
  468. package/src/util/vdom/TreeBuilder.mjs +105 -0
  469. package/src/vdom/Helper.mjs +35 -23
  470. package/src/vdom/VNode.mjs +4 -6
  471. package/src/worker/App.mjs +1 -0
  472. package/src/worker/Base.mjs +2 -0
  473. package/src/worker/Manager.mjs +2 -0
  474. package/src/worker/ServiceBase.mjs +6 -1
  475. package/src/worker/mixin/RemoteMethodAccess.mjs +1 -6
  476. package/test/siesta/siesta.js +17 -2
  477. package/test/siesta/tests/VdomCalendar.mjs +19 -15
  478. package/test/siesta/tests/VdomHelper.mjs +7 -7
  479. package/test/siesta/tests/classic/Button.mjs +113 -0
  480. package/test/siesta/tests/core/Effect.mjs +10 -14
  481. package/test/siesta/tests/core/EffectBatching.mjs +72 -79
  482. package/test/siesta/tests/functional/Button.mjs +113 -0
  483. package/test/siesta/tests/state/ProviderNestedDataConfigs.mjs +314 -0
  484. package/test/siesta/tests/state/createHierarchicalDataProxy.mjs +42 -55
  485. package/test/siesta/tests/vdom/Advanced.mjs +14 -8
  486. package/test/siesta/tests/vdom/VdomAsymmetricUpdates.mjs +366 -0
  487. package/test/siesta/tests/vdom/VdomRealWorldUpdates.mjs +249 -0
  488. package/test/siesta/tests/vdom/layout/Cube.mjs +11 -7
  489. package/test/siesta/tests/vdom/table/Container.mjs +9 -5
  490. package/learn/javascript/NewNode.md +0 -31
  491. package/src/core/EffectBatchManager.mjs +0 -68
@@ -0,0 +1,178 @@
1
+ # Neo.mjs vs Ext.js
2
+
3
+ Neo.mjs is a comprehensive JavaScript ecosystem for building high-performance, multi-threaded web applications. Unlike legacy frameworks like Ext.js that are architecturally bound to a single thread and a rigid, monolithic build system, Neo.mjs is a self-contained system with **zero runtime dependencies**. It provides a complete, out-of-the-box solution that includes four distinct development and deployment environments, from a revolutionary zero-builds development mode to thread-optimized production bundles.
4
+
5
+ This article provides a focused comparison between the Neo.mjs ecosystem and Ext.js. While both are designed for building complex enterprise-grade applications, they employ fundamentally different strategies to achieve their goals. We will explore their approaches to **architecture, rendering, component models, and development workflow**, highlighting the upgrade path from Ext.js's legacy model to Neo.mjs's modern, worker-based paradigm.
6
+
7
+ ## A Look Back: Ext.js's Legacy and Current Landscape
8
+
9
+ Ext.js emerged in 2007 as a groundbreaking JavaScript framework, offering unparalleled capabilities for building rich,
10
+ enterprise-grade web applications. Its comprehensive component library, sophisticated class system, and robust data
11
+ management were truly innovative and years ahead of their time, establishing it as a dominant force in complex UI
12
+ development.
13
+
14
+ However, the landscape of web development has evolved at an unprecedented pace. While Ext.js continues to exist and
15
+ receive updates, the perception within the developer community, particularly over the last 5-7 years, has been one of
16
+ **stagnation and a significant lag in adopting modern web standards and paradigms**. The framework has struggled to
17
+ keep pace with the rapid advancements in JavaScript, browser capabilities, and developer expectations for performance
18
+ and workflow. This has often led to experienced solution engineers, including those with deep expertise in Ext.js
19
+ internals, being brought in to perform extensive performance tuning and framework-level debugging on large-scale
20
+ Ext.js implementations, highlighting the inherent challenges.
21
+
22
+ It is precisely this deep understanding of the limitations of existing frameworks, gained from extensive
23
+ experience with their large-scale implementations, that motivated the creation of Neo.mjs. **Crucially,
24
+ Neo.mjs was built from the ground up with a completely new and independent architecture**, representing a
25
+ deliberate and complete break from legacy constraints and ensuring a truly modern and unburdened foundation.
26
+
27
+ This context is important for understanding why many developers, who once relied on Ext.js for its power and
28
+ comprehensiveness, are now actively seeking modern alternatives that can deliver similar enterprise-grade capabilities
29
+ with contemporary performance, architecture, and development workflows. Neo.mjs, in contrast, has been built from the
30
+ ground up to embrace these modern advancements, offering a level of innovation and agility that directly addresses the
31
+ perceived stagnation in Ext.js's recent evolution.
32
+
33
+ ## Core Similarities: Enterprise Application Development
34
+
35
+ Both Neo.mjs and Ext.js share common ground in building large-scale, enterprise-grade user interfaces:
36
+
37
+ * **Comprehensive Frameworks:** Both are full-fledged frameworks (not just libraries) providing a wide array of
38
+ features out-of-the-box, including a rich component library, data management, and application structure.
39
+ * **Class-Based Architecture:** Both heavily rely on a class-based object-oriented programming (OOP) model for
40
+ structuring applications. This includes a foundational `Base` class (`Ext.core.Base` in Ext.js, `Neo.core.Base`
41
+ in Neo.mjs) providing core functionalities like class creation, configuration management, and event systems.
42
+ * **Component-Based UI:** Both promote building UIs as a composition of reusable components.
43
+ * **Declarative UI (Initial Definition):** Both allow for declarative definition of UI components and
44
+ layouts for initial rendering. However, their approaches to *updating* the UI declaratively differ
45
+ significantly, as explored in the "Rendering Mechanism" section.
46
+ * **Data Management:** Both provide robust data management layers (Stores, Models) for handling application data.
47
+
48
+ ## Key Differences: Modern Architecture & Performance
49
+
50
+ This is where the two frameworks diverge significantly, with Neo.mjs addressing many of the historical challenges and
51
+ limitations of Ext.js.
52
+
53
+ ### 1. Overall Architecture: Main Thread Blocking vs. Worker-Based
54
+
55
+ * **Ext.js: Main Thread Bound & Synchronous Operations**
56
+ * Ext.js applications run entirely on the Main JavaScript Thread. All component rendering, layout calculations,
57
+ data processing, and event handling occur on this single thread.
58
+ * **Implication:** Ext.js applications, especially complex ones with large data sets or intricate layouts, are
59
+ prone to Main Thread blocking. This leads to UI freezes, unresponsiveness, and a poor user experience. Its
60
+ synchronous nature for many operations exacerbates this issue.
61
+
62
+ * **Neo.mjs: Worker-Based (Main Thread + App Worker + VDom Worker)**
63
+ * Neo.mjs's defining feature is its multi-threaded architecture. Application logic (component instances, state,
64
+ business logic, `vdomEffect`s) runs in a dedicated **App Worker**, separate from the Main Thread. The VDOM diffing
65
+ occurs in a **VDom Worker**.
66
+ * Communication between workers and the Main Thread happens via asynchronous message passing.
67
+ * **Benefit:** This architecture keeps the Main Thread almost entirely free and responsive, preventing UI freezes
68
+ even during heavy computations or complex application logic. It inherently leverages multi-core CPUs for parallel
69
+ processing, leading to superior UI responsiveness and performance under heavy load. This directly solves the Main
70
+ Thread blocking issues common in Ext.js.
71
+
72
+ ### 2. Rendering Mechanism & DOM Interaction
73
+
74
+ * **Ext.js: Direct DOM Manipulation & String-Based Rendering**
75
+ * Ext.js components often directly manipulate the DOM. While it has its own rendering engine, it frequently relies
76
+ on generating HTML strings (`outerHTML`, `innerHTML`) and injecting them into the DOM. Its template system, often
77
+ using `x-template` or similar string-based approaches, typically results in **full DOM replacements** for updates,
78
+ rather than granular changes.
79
+ * **Performance Consideration:** Frequent direct DOM manipulations and string-based rendering can be inefficient and
80
+ lead to numerous browser reflows/repaints, especially for dynamic updates. The lack of granular updates means even
81
+ small data changes can trigger large, expensive DOM re-creations.
82
+ * **XSS Risk:** String-based rendering can introduce Cross-Site Scripting (XSS) vulnerabilities if not handled carefully.
83
+
84
+ * **Neo.mjs: Virtual DOM (Off-Main-Thread Diffing & Optimized Direct DOM API Updates)**
85
+ * Neo.mjs uses a Virtual DOM. Your `createVdom()` method (within functional components) returns a plain JavaScript
86
+ object representing the desired UI structure. **This VDOM is defined using simple nested JavaScript objects and
87
+ arrays, akin to a JSON-like description of the DOM. Crucially, Neo.mjs's VDOM objects are mutable.**
88
+ * **Off-Main-Thread Diffing:** The VDOM diffing process occurs in a dedicated **VDom Worker**, offloading this
89
+ computational work from the Main Thread.
90
+ * **Surgical Direct DOM API Updates (`Neo.main.DeltaUpdates` & `DomApiRenderer`):** The VDom Worker sends "deltas"
91
+ (minimal change instructions) to the Main Thread. `Neo.main.DeltaUpdates` then applies these changes using direct
92
+ DOM APIs. For inserting new subtrees, `DomApiRenderer` builds detached `DocumentFragments` and inserts them in a
93
+ single, atomic operation. For updates to existing nodes, `DeltaUpdates` directly manipulates attributes, classes,
94
+ styles, and content using native DOM methods.
95
+ * **Benefit:** This approach minimizes costly browser reflows/repaints, enhances security (by avoiding `innerHTML`
96
+ for updates), and ensures highly efficient, surgical DOM updates. Neo.mjs components are **completely decoupled
97
+ from the real DOM**, residing in the App Worker and never directly reading from or writing to the DOM.
98
+
99
+ ### 3. Reactivity & Change Detection
100
+
101
+ * **Ext.js: Traditional Event-Driven & Explicit Setter-Based Updates**
102
+ * Ext.js relies on a traditional event-driven model for reactivity. Components fire events, and other components or
103
+ controllers listen to these events.
104
+ * **No True Reactivity:** Ext.js does not possess a modern, fine-grained reactivity system. Data changes are not
105
+ automatically propagated to the UI. Developers *must* explicitly call setter methods (e.g.,
106
+ `component.setTitle('New Title')`, `record.set('fieldName', 'newValue')`) to update values. Simply assigning a
107
+ new value to a property (e.g., `component.title = 'New Title'`) will **not** update the UI.
108
+ * **Change Detection:** Updates are often triggered manually or through specific framework mechanisms, which can
109
+ sometimes lead to developers needing to explicitly refresh components or views.
110
+
111
+ * **Neo.mjs: True, Fine-Grained Reactivity**
112
+ * Neo.mjs is built on a modern, fine-grained reactivity system powered by `Neo.core.Config` and `Neo.core.Effect`. When a reactive config or state changes, only the specific parts of the UI that depend on it are automatically updated.
113
+ * Developers can simply change a value (`this.myConfig = 'new value'`), and the UI updates automatically and efficiently. There is no need for manual event listeners or explicit setter calls to trigger UI changes. This dramatically simplifies development, reduces boilerplate, and eliminates a common source of bugs.
114
+
115
+ ### 4. Development Workflow & Modern JavaScript
116
+
117
+ * **Ext.js: Legacy JavaScript & Build Tools**
118
+ * Ext.js's foundational architecture is rooted in pre-ES5 (conceptually ES4-like) paradigms, and it does not fully
119
+ leverage modern JavaScript capabilities. While newer versions support ES6+, the core framework still carries
120
+ significant legacy baggage.
121
+ * **Build Process:** Typically involves a complex build process with Sencha Cmd for compilation, minification,
122
+ and code splitting.
123
+ * **Debugging:** Debugging can be challenging due to the transpiled and often obfuscated code, requiring extensive
124
+ use of source maps.
125
+
126
+ * **Neo.mjs: Zero Builds Dev Mode & Native ES Modules**
127
+ * Neo.mjs champions a **"zero builds" instant development mode** as its primary workflow, leveraging native ES
128
+ Modules, ES6 classes, and dynamic imports directly in the browser.
129
+ * **Benefit:** This offers unparalleled speed and debugging clarity. Code changes are reflected instantly without
130
+ any compilation step. Developers work directly with the real code in the browser's dev tools, eliminating the
131
+ need for source maps and vastly simplifying debugging.
132
+ * **Deployment Flexibility:** Provides optimized build environments (`dist/esm`, `dist/production`) for deployment,
133
+ maintaining modularity or thread-specific bundling.
134
+
135
+ ### 5. Component Model & Extensibility
136
+
137
+ * **Ext.js: Rich Component Library & XTypes**
138
+ * Ext.js provides an extremely rich and comprehensive set of UI components (grids, forms, charts, etc.) out-of-the-box.
139
+ Components are instantiated using `xtypes`.
140
+ * **Monolithic Design & No Lazy-Loading:** Ext.js components are often large, self-contained units not inherently
141
+ designed for granular, on-demand lazy-loading. Applications are typically bundled into large, monolithic
142
+ JavaScript files, impacting initial load times.
143
+ * **Extensibility:** Highly extensible through its class system, mixins, and plugins. However, its proprietary
144
+ class system and synchronous nature can limit the scope and performance of extensions, and debugging can be challenging.
145
+ * **Class-Based Only:** Ext.js is exclusively class-based. It does not natively support the modern functional
146
+ component paradigm, making it challenging to adopt contemporary UI development patterns.
147
+
148
+ * **Neo.mjs: A Modern, Dual Component Model**
149
+ * Neo.mjs offers a flexible, dual component model. Developers can use a powerful, full-featured class-based system (`Neo.component.Base`) that will feel familiar yet superior to Ext.js developers, or they can adopt a modern, lightweight functional component paradigm using the `defineComponent()` API with hooks.
150
+ * This provides a clear upgrade path and allows teams to choose the best tool for the job, from complex enterprise grids to simple, declarative UI functions. Its component library achieves feature parity with many of Ext.js's offerings, but with technically superior, modular, and more performant implementations.
151
+ * **Superior Extensibility:** Leveraging native ES Modules, a clean class hierarchy, mixins, and plugins, Neo.mjs offers a more modern and performant level of extensibility. The worker-based architecture enables extensions that run off the Main Thread, opening new possibilities for high-performance features without impacting UI responsiveness.
152
+
153
+ ## Conclusion: Why Neo.mjs is a Modern Successor to Ext.js
154
+
155
+ While Ext.js has been a powerful tool for building enterprise applications, Neo.mjs offers fundamental architectural and
156
+ modern development advantages that directly address many of Ext.js's historical limitations, leading to superior technical
157
+ performance, responsiveness, and maintainability.
158
+ Notably, Neo.mjs being built on the latest fully supported ES features, ensures a truly modern and unburdened foundation.
159
+
160
+ Indeed, as members of the Neo.mjs community state, "Neo.mjs is what Sencha should have built, but were incapable of."
161
+ This sentiment is further reinforced by the belief that "Neo.mjs is the ideal framework to migrate to, coming from Ext.js."
162
+
163
+ * **Unblocked Main Thread & Inherent Performance:** Neo.mjs's worker-based architecture fundamentally shifts application
164
+ logic off the Main Thread, directly solving the UI blocking issues common in Ext.js applications.
165
+ * **Optimized & Precise DOM Updates:** By leveraging a VDom and surgical direct DOM API updates, Neo.mjs achieves highly
166
+ efficient and smooth visual updates, avoiding the performance pitfalls of frequent direct DOM manipulation
167
+ and string-based rendering.
168
+ * **Modern Reactivity:** Neo.mjs's fine-grained reactivity system provides precise and automatic updates, simplifying
169
+ state management and reducing the need for manual event handling compared to Ext.js's traditional event-driven model.
170
+ * **Streamlined Development Workflow:** The "zero builds" development mode and native ES Module approach offer a
171
+ significantly faster and more transparent development experience compared to Ext.js's often complex build
172
+ processes and legacy JavaScript.
173
+ * **Linear Effort for Complexity:** Neo.mjs's unified config system, predictable component lifecycle, and modular
174
+ design enable a more linear relationship between complexity and development effort, leading to faster development
175
+ cycles and lower maintenance costs in the long run.
176
+
177
+ For organizations and developers looking for a modern, performant, and maintainable framework to build complex
178
+ enterprise-grade web applications, Neo.mjs presents a compelling and technically superior successor to Ext.js.
@@ -0,0 +1,124 @@
1
+ # Neo.mjs vs Next.js
2
+
3
+ Neo.mjs and Next.js are both powerful JavaScript frameworks, but they operate with fundamentally different architectural
4
+ philosophies and excel in distinct domains. This document aims to clarify their core strengths and illustrate how they
5
+ can be used in complementary ways, rather than as direct competitors.
6
+
7
+ * **Neo.mjs:** A comprehensive, multi-threaded frontend ecosystem designed for building highly performant, complex,
8
+ and interactive Single-Page Applications (SPAs) where Main Thread responsiveness is paramount.
9
+ * **Next.js:** A React framework specializing in Server-Side Rendering (SSR), Static Site Generation (SSG), and API
10
+ routes, primarily focused on delivering content-rich, SEO-optimized web experiences.
11
+
12
+ ## 1. Core Philosophy & Architecture
13
+
14
+ ### Neo.mjs: Client-Side, Multi-Threaded for UI Responsiveness
15
+
16
+ Neo.mjs is architected from the ground up to leverage a multi-threaded environment within the browser. Its core philosophy
17
+ is to offload computationally intensive tasks from the Main UI Thread to ensure a consistently responsive user experience.
18
+
19
+ * **App Worker:** Runs the application logic, state management, and component structure.
20
+ * **Main Thread:** Dedicated to rendering the virtual DOM and handling user events, kept almost entirely free.
21
+ * **Data Worker:** Manages data fetching and processing.
22
+ * **VDom Worker:** Handles virtual DOM diffing and patching.
23
+
24
+ This architecture guarantees that the main thread remains unblocked, resulting in smooth animations, fast user interactions,
25
+ and a highly performant application, especially for complex and data-intensive UIs.
26
+
27
+ ### Next.js: Server-Side First for Content & SEO
28
+
29
+ Next.js is a React framework that extends React's capabilities with powerful server-side rendering and static site generation
30
+ features. Its primary goal is to improve performance and SEO by pre-rendering pages on the server or at build time.
31
+
32
+ * **Server-Side Rendering (SSR):** Pages are rendered on the server for each request, providing up-to-date content and
33
+ improving initial load times.
34
+ * **Static Site Generation (SSG):** Pages are generated at build time, resulting in extremely fast-loading static HTML
35
+ files, ideal for content that doesn't change frequently.
36
+ * **API Routes:** Built-in backend capabilities allow for creating serverless functions directly within the Next.js
37
+ project, simplifying full-stack development.
38
+
39
+ Next.js excels at building content-heavy websites, blogs, and e-commerce applications where initial page load time and
40
+ SEO are critical.
41
+
42
+ ## 2. Primary Use Cases
43
+
44
+ Given their distinct architectures, Neo.mjs and Next.js naturally fit different primary use cases, though they can also
45
+ complement each other.
46
+
47
+ ### Neo.mjs: Complex, Interactive SPAs & Enterprise Applications
48
+
49
+ Neo.mjs is ideally suited for applications that demand high levels of interactivity, real-time data processing, and
50
+ guaranteed UI responsiveness, even under heavy load.
51
+
52
+ * **Rich Data Dashboards:** Building complex dashboards with numerous interactive components, charts, and real-time updates.
53
+ * **Enterprise-Grade SPAs:** Large-scale business applications requiring robust architecture, high performance, and maintainability.
54
+ * **Interactive Tools & Editors:** Applications where user input directly manipulates complex UI elements or data structures.
55
+ * **Any application where Main Thread responsiveness is a critical non-functional requirement.**
56
+
57
+ ### Neo.mjs: Multi-Window / Multi-Screen Applications
58
+
59
+ Neo.mjs's multi-threaded architecture extends naturally to support complex multi-window and multi-screen application scenarios.
60
+ This is a capability rarely found in other frameworks and offers significant advantages for specific use cases.
61
+
62
+ * **Shared Data & State:** Raw data and application state can be seamlessly shared and synchronized across multiple
63
+ connected browser windows or even different screens (e.g., a main application window and a separate pop-out dashboard
64
+ or control panel). This significantly reduces network traffic as data is fetched once and distributed locally.
65
+ * **Synchronized UI:** Changes in one window can instantly reflect in others, ensuring all connected views are fully in sync.
66
+ * **Component Tree Mobility:** Neo.mjs can move entire component trees (UI elements and their associated logic) between
67
+ different browser windows while maintaining the same underlying JavaScript instances. This enables dynamic, flexible
68
+ user interfaces where users can customize their workspace by arranging application parts across multiple displays.
69
+ * **Reduced Traffic:** With data and logic shared and synchronized locally, the need to re-fetch or re-process information
70
+ for each window is eliminated, leading to a more efficient and responsive user experience.
71
+
72
+ This capability is particularly valuable for enterprise applications, trading platforms, control centers, or any scenario
73
+ where users need to monitor and interact with complex data across multiple views simultaneously.
74
+
75
+ ### Next.js: Content-Driven Websites & SEO-Critical Applications
76
+
77
+ Next.js is a leading choice for applications where content delivery, fast initial page loads, and search engine
78
+ optimization are paramount.
79
+
80
+ * **Marketing Websites & Blogs:** Delivering static or server-rendered content quickly and efficiently.
81
+ * **E-commerce Frontends:** Providing fast, SEO-friendly product pages and checkout flows.
82
+ * **Portfolios & Documentation Sites:** Static content that benefits from pre-rendering.
83
+ * **Applications requiring a robust backend for data fetching and API management.**
84
+
85
+ ### Complementary Use Cases: The Best of Both Worlds
86
+
87
+ It's important to note that Neo.mjs and Next.js are not mutually exclusive. They can be used together to leverage their
88
+ respective strengths:
89
+
90
+ * **Next.js as a Content Shell:** Use Next.js to handle the public-facing, SEO-optimized content (e.g., landing pages,
91
+ blog posts). When a user navigates to a highly interactive section (e.g., a complex dashboard or a data visualization
92
+ tool), a Neo.mjs application can be seamlessly embedded or loaded as a separate SPA.
93
+ * **Next.js for API Backend:** Utilize Next.js's API Routes to build a robust backend for data fetching and business
94
+ logic, while a Neo.mjs application consumes these APIs to power its rich client-side UI.
95
+
96
+ ## 3. Architectural Trade-offs
97
+
98
+ | Feature | Neo.mjs | Next.js |
99
+ | ----------------------- | --------------------------------------- | --------------------------------------- |
100
+ | **Primary Focus** | Client-Side UI Responsiveness | Server-Side Content Delivery & SEO |
101
+ | **Core Architecture** | Multi-Threaded (Worker-Based) | Single-Threaded (React + Node.js) |
102
+ | **Rendering Strategy** | Client-Side (Off-Main-Thread VDOM) | SSR, SSG, CSR (Main Thread React VDOM) |
103
+ | **Main Thread Impact** | Minimal (Logic in Workers) | Significant (All React/DOM work) |
104
+ | **SEO** | Requires pre-rendering solution | Built-in (SSR/SSG) |
105
+ | **Initial Load** | Fast for Returning Users (Client-side caching) | Fast for First-Time Users (SSR/SSG) |
106
+ | **Backend Integration** | Via standard APIs | Built-in API Routes |
107
+ | **Navigation Model** | Single-Page Application (SPA) | Page-Based (MPA with client-side routing) |
108
+
109
+ ## Conclusion
110
+
111
+ Choosing between Neo.mjs and Next.js depends entirely on your application's primary requirements. If your goal is to
112
+ build a highly interactive, performant, and responsive client-side application that can handle complex UIs and heavy
113
+ data processing without blocking the Main Thread, Neo.mjs is the superior choice. Neo.mjs's architecture, leveraging
114
+ Service Workers for aggressive client-side caching of application code, results in near-instant load times for
115
+ returning users, significantly reducing network traffic as only raw data needs to be fetched from the backend.
116
+ Furthermore, its Single-Page Application (SPA) model ensures seamless navigation without full browser reloads, providing
117
+ a fluid and highly engaging user experience for interactive applications.
118
+
119
+ If your priority is delivering SEO-friendly, content-rich web pages with fast initial load times for first-time users,
120
+ and you prefer a React-based full-stack framework, Next.js is an excellent solution.
121
+
122
+ For many modern web projects, the most powerful approach might involve combining their strengths, using Next.js for
123
+ content delivery and API services, and embedding or integrating Neo.mjs for the most demanding
124
+ interactive client-side experiences.
@@ -0,0 +1,95 @@
1
+ # Neo.mjs vs React.js
2
+
3
+ Neo.mjs is a comprehensive JavaScript ecosystem for building high-performance, multi-threaded web applications. Unlike libraries such as React that form only one part of a complex, manually assembled toolchain, Neo.mjs is a self-contained system with **zero runtime dependencies**. It provides a complete, out-of-the-box solution that includes four distinct development and deployment environments, from a revolutionary zero-builds development mode to thread-optimized production bundles.
4
+
5
+ This article provides a focused comparison between the Neo.mjs ecosystem and React. React, now over a decade old, has become an industry standard, but its foundational architecture is rooted in the single-threaded limitations of its time. We will explore their fundamentally different approaches to **architecture, rendering, and reactivity**, highlighting the trade-offs between React's library-focused, Main-Thread-bound model and Neo.mjs's holistic, worker-based paradigm.
6
+
7
+ ## Foundational Concepts: A Shared Heritage
8
+
9
+ Despite their architectural differences, both frameworks build upon foundational concepts that have shaped UI development:
10
+
11
+ * **Component-Based Architecture (with a distinction):** Both frameworks promote building UIs as a composition of reusable components. However, Neo.mjs extends this concept with `Neo.core.Base`, allowing any class-based entity (like controllers, models, or routers) to leverage the framework's powerful class system, even if they don't directly render UI. This contrasts with frameworks where non-visual logic might often be shoehorned into component structures.
12
+ * **Declarative UI:** Developers describe *what* the UI should look like for a given state, and the framework handles *how* to update the DOM.
13
+ * **Reactive Paradigm:** Both leverage reactive programming principles where UI updates are driven by changes in state.
14
+ * **Functional Components & Hooks:** Both support defining components as functions and provide hooks for managing state and side effects, though their implementation and performance characteristics differ significantly.
15
+
16
+ ## Key Differences: Architectural & Rendering Strategies
17
+
18
+ This is where the two frameworks diverge significantly, each offering unique trade-offs and advantages.
19
+
20
+ ### 1. Overall Architecture: Main Thread vs. Worker-Based
21
+
22
+ * **React: Main Thread Focused**
23
+ * React applications run predominantly on the Main JavaScript Thread of the browser. All component logic, state management, VDOM reconciliation, and direct DOM manipulation occur on this single thread.
24
+ * **Implication:** While React is highly optimized, complex computations, large state updates, or extensive component trees can potentially block the Main Thread, leading to UI jank, unresponsiveness, and a poor user experience. React relies on techniques like Fiber reconciliation and `requestIdleCallback` (via `Scheduler`) to yield to the browser, but it's still fundamentally bound by the Main Thread's limitations.
25
+
26
+ * **Neo.mjs: Worker-Based (Main Thread + App Worker + VDom Worker)**
27
+ * Neo.mjs's defining feature is its multi-threaded architecture. Application logic (component instances, state, business logic, `vdomEffect`s) runs in a dedicated **App Worker**, separate from the Main Thread. The VDOM diffing occurs in a **VDom Worker**.
28
+ * Communication between workers and the Main Thread happens via asynchronous message passing.
29
+ * **Benefit:** This architecture keeps the Main Thread almost entirely free and responsive, preventing UI freezes even during heavy computations or complex application logic. It inherently leverages multi-core CPUs for parallel processing, leading to superior UI responsiveness and performance under heavy load.
30
+
31
+ ### 2. Rendering Mechanism
32
+
33
+ * **React: Main-Thread VDOM & Enforced Immutability**
34
+ * React uses a Virtual DOM. When state or props change, React builds a new VDOM tree on the Main Thread, compares it with the previous one (reconciliation), and calculates the minimal set of changes (diffing). These changes are then applied to the real DOM, all on the same thread responsible for user interactions.
35
+ * **VDOM Definition:** Primarily uses JSX, a syntax extension requiring a build step (e.g., Babel) to transpile HTML-like structures into `React.createElement` calls.
36
+ * **The Burden of Immutability:** React's reconciliation algorithm relies on developers treating state as immutable. To change state, you must create a *new* object or array reference instead of modifying the existing one. This forces developers into patterns using spread syntax (`...`) or libraries like Immer to manage state changes. While this simplifies React's diffing logic, it offloads significant cognitive and boilerplate burden onto the developer and can be a frequent source of bugs when not handled correctly.
37
+
38
+ * **Neo.mjs: Off-Thread VDOM & Developer-Friendly Mutability**
39
+ * Neo.mjs also uses a Virtual DOM, but its philosophy and implementation are fundamentally different. The VDOM is defined using plain JavaScript objects and arrays—no JSX or build step is required for UI definition.
40
+ * **Mutability by Design, Immutability in Process:** Neo.mjs embraces developer convenience by allowing **direct, mutable manipulation** of component state (configs) and the VDOM structure within the App Worker. This eliminates the boilerplate and cognitive load of managing immutable updates. The architectural brilliance lies in how it achieves the benefits of immutability: when an update is triggered, Neo.mjs creates a **JSON snapshot** of the relevant VDOM tree. This snapshot is sent to the VDom Worker, making the *update process itself* immutable and predictable for diffing. This provides the best of both worlds: simple, direct mutation for the developer and a safe, immutable structure for the high-performance diffing algorithm in another thread.
41
+ * **Off-Main-Thread Diffing:** The entire VDOM diffing process occurs in the dedicated **VDom Worker**, completely freeing the Main Thread from this heavy computation.
42
+ * **Scoped VDOM (Encapsulation & Performance):** The VDom Worker sends only the "deltas" (a minimal set of change instructions) back to the Main Thread. For insertions, `DomApiRenderer` **builds the entire new DOM subtree in memory**, completely detached from the live document, and inserts it in a **single, atomic operation**. Furthermore, Neo.mjs's VDOM is **scoped by default**. When a parent component renders, its children are represented by simple `{componentId: '...'}` placeholders. This provides two key advantages:
43
+ 1. **Performance:** A parent's update never processes the complex VDOM of its children, keeping update payloads extremely small and efficient.
44
+ 2. **Encapsulation:** It is architecturally impossible for a parent to accidentally reach into and manipulate a child's internal VDOM structure. This enforces clear ownership and prevents a wide class of bugs.
45
+
46
+ ### 3. Component Execution Model: Precision vs. Brute Force
47
+
48
+ * **React: Cascading Re-Renders & The `memo` Tax**
49
+ * When a component's state changes, React re-executes the entire component function. This is just the beginning. By default, it then triggers a cascading re-render of **all its child components**, regardless of whether their own props have changed.
50
+ * This brute-force approach creates a significant performance problem known as "unnecessary re-renders." To fight this, developers are forced to pay the `memo` tax: wrapping components in `React.memo()`, manually memoizing functions with `useCallback()`, and objects with `useMemo()`. This adds significant boilerplate, increases complexity, and is a notorious source of bugs, including stale closures and incorrect dependency arrays. This manual optimization becomes a core, and often frustrating, part of the development process.
51
+
52
+ * **Neo.mjs: Surgical Effects & Automatic Efficiency**
53
+ * Neo.mjs's model is fundamentally more efficient and intelligent. A component's `createVdom` method is wrapped in a `Neo.core.Effect`. This effect automatically and dynamically tracks its dependencies—the specific `config` values it reads.
54
+ * When a config value changes, only the specific `createVdom` effects that depend on that *exact* piece of state are queued for re-execution. There are no cascading re-renders. If a parent's `createVdom` re-runs, but the configs passed to a child have not changed, the child component's `createVdom` function is **never executed**.
55
+ * **Benefit (Zero Manual Optimization):** This fine-grained reactivity completely eliminates the need for manual memoization (`memo`, `useCallback`, `useMemo`). The framework handles dependency tracking automatically and precisely, delivering optimal performance out-of-the-box without the boilerplate and complexity inherent in React. This also sidesteps entire classes of bugs like stale closures, as dependencies are discovered fresh on every run, without requiring manual dependency arrays.
56
+
57
+ * **State Management & The End of Props Drilling:** React often relies on its Context API or third-party state management libraries to avoid "props drilling." However, this often introduces performance issues, as any change to a context value re-renders all consuming components by default. Neo.mjs's architecture makes props drilling an obsolete anti-pattern. A deeply nested component can subscribe directly to the precise piece of state it needs from a `StateProvider` via an `Effect`. This creates a direct, performant link between the state and the component that needs it, completely bypassing all intermediate components. This results in a cleaner, more decoupled, and more performant architecture by default.
58
+
59
+ ### 4. Scaling Complexity: Linear Effort vs. Exponential Overhead
60
+
61
+ A key differentiator between the frameworks is how they handle growing application complexity.
62
+
63
+ * **React: Exponential Complexity in Large Applications**
64
+ * Consider a complex dashboard with a global state (e.g., a user profile in a Context). When a single value in that state changes (e.g., the user's name), React's default behavior is to re-render **every single component** that consumes that context.
65
+ * To prevent the entire UI from lagging, developers must manually optimize each consuming component. This involves wrapping components in `React.memo` and using selector-like functions with `useMemo` to extract only the needed data. As the application grows, the number of these manual optimizations grows, leading to an exponential increase in boilerplate and performance-tuning effort. The burden is on the developer to constantly fight the framework's default behavior.
66
+
67
+ * **Neo.mjs: Built-in Efficiency and Linear Effort**
68
+ * Neo.mjs's architecture is designed to handle this scenario effortlessly. Multiple state changes are automatically batched into a single, de-duplicated update cycle via the `EffectBatchManager`.
69
+ * In the same complex dashboard scenario, if a value in a global `StateProvider` changes, only the `createVdom` effects in components that *directly depend on that specific value* will re-run. All other components remain untouched, with **zero manual optimization required from the developer**.
70
+ * This leads to a **linear relationship between complexity and effort**. As you add more components, you don't need to add more performance optimizations. The framework's core design ensures that updates are always surgical and efficient, allowing developers to focus on features instead of fighting the rendering engine. This is a direct result of the sophisticated, multi-layered batching and aggregation built into the framework's core.
71
+
72
+ ### Other Considerations:
73
+
74
+ * **Development & Deployment Environments:** Neo.mjs offers four distinct environments, providing unparalleled flexibility:
75
+ * **Zero Builds Development Mode:** The primary development workflow, leveraging native ES Modules for instant code reflection and debugging without a build step. This contrasts sharply with React's typical development setup which always involves a build process.
76
+ * **`dist/esm`:** Deploys as native ES Modules, preserving the dev mode's file structure for efficient modular loading in modern browsers.
77
+ * **`dist/production`:** Generates highly optimized, thread-specific bundles using Webpack for maximum compatibility and minification.
78
+ * **`dist/development`:** A bundled but unminified environment for debugging production-specific issues or for TypeScript preference, serving as a bridge to traditional build-based workflows.
79
+ * **Dynamic Module Loading:** Neo.mjs uniquely supports dynamically loading code-based modules (even with arbitrary `import` statements) from different environments at runtime, a powerful feature for plugin architectures or user-generated code that most other frameworks struggle with.
80
+
81
+ * **JSX vs. Plain Objects:** React uses JSX (requiring a build step for UI definition). Neo.mjs uses plain JavaScript objects for VDOM (no JSX compilation needed for VDOM definition).
82
+ * **Side Effects:** Both frameworks advocate for managing side effects outside the pure render function. React uses `useEffect`. Neo.mjs uses separate `Neo.core.Effect` instances or dedicated hooks for side effects.
83
+ * **Ecosystem & Maturity:** React has a massive, mature ecosystem with abundant libraries, tools, and community support. Neo.mjs has a smaller but dedicated community, with a focus on framework-level solutions and integrated features.
84
+ * **Learning Curve:** React's initial learning curve can be gentle, but mastering its performance optimizations (memoization, context, custom hooks) can be complex. Neo.mjs has a steeper initial learning curve due to its worker-based architecture, but once understood, it offers inherent performance benefits.
85
+ * **Dependency Management (Batteries Included):** React projects often involve a large `node_modules` directory and can lead to complex dependency trees and version conflicts, a common pain point often referred to as "dependency hell." Neo.mjs, in contrast, is a "batteries included" framework. It literally has zero real runtime dependencies outside of its own core. This native ES Module approach and integrated framework significantly reduces this complexity, offering a much leaner and more controlled dependency management experience.
86
+
87
+ ## Conclusion: Why Neo.mjs Offers Significant Technical Advantages Over React
88
+
89
+ For applications where guaranteed Main Thread responsiveness, high performance under load, leveraging multi-core processing, and long-term maintainability are paramount, Neo.mjs presents a compelling and technically superior alternative.
90
+
91
+ * **Unblocked Main Thread & Inherent Performance:** Neo.mjs's unique worker-based architecture fundamentally shifts application logic off the Main Thread. This ensures the UI remains fluid and responsive even during heavy computations, leading to inherently higher performance ceilings without the need for extensive manual optimizations common in React.
92
+ * **Optimized & Precise DOM Updates:** Through off-Main-Thread VDOM diffing, sophisticated batching, and surgical direct DOM API updates, Neo.mjs achieves highly efficient and smooth visual updates, precisely targeting changes and avoiding unnecessary re-renders.
93
+ * **Linear Effort for Complexity:** Unlike frameworks where effort can grow exponentially with application complexity, Neo.mjs's unified config system, predictable component lifecycle, and modular design enable a more linear relationship between complexity and development effort, leading to faster development cycles and lower maintenance costs in the long run.
94
+
95
+ The choice between them depends on the specific application's needs. For applications where guaranteed Main Thread responsiveness, high performance under load, leveraging multi-core processing, and long-term maintainability are paramount, Neo.mjs presents a compelling and technically superior alternative.
@@ -0,0 +1,78 @@
1
+ # Neo.mjs vs Solid.js
2
+
3
+ Neo.mjs is a comprehensive JavaScript ecosystem for building high-performance, multi-threaded web applications. Unlike libraries such as Solid.js that focus purely on rendering and are typically part of a manually assembled toolchain, Neo.mjs is a self-contained system with **zero runtime dependencies**. It provides a complete, out-of-the-box solution that includes four distinct development and deployment environments, from a revolutionary zero-builds development mode to thread-optimized production bundles.
4
+
5
+ This article provides a focused comparison between the Neo.mjs ecosystem and Solid.js. While both frameworks leverage fine-grained reactivity for high performance, they employ fundamentally different architectural and rendering strategies to achieve their goals. We will explore their approaches to **rendering, reactivity, and DOM updates**, highlighting the trade-offs between Solid's "no-VDOM," Main-Thread-bound model and Neo.mjs's holistic, worker-based paradigm.
6
+
7
+ ## Core Similarities: Fine-Grained Reactivity
8
+
9
+ At their heart, both frameworks share the philosophy of **fine-grained reactivity**:
10
+
11
+ * **Direct Updates:** When a piece of reactive state changes, only the specific parts of the UI that directly depend on that state are updated. This minimizes unnecessary re-renders of entire component trees, a common performance bottleneck in traditional Virtual DOM frameworks.
12
+ * **Reactive Primitives:**
13
+ * **Solid.js:** Utilizes "signals" (`createSignal`) as its primary reactive primitive.
14
+ * **Neo.mjs:** Employs `Neo.core.Config` instances as its core reactive primitive.
15
+ * **Automatic Dependency Tracking:** Both frameworks automatically detect dependencies. When code executes within a reactive context (e.g., an effect, a memo, or a component's render logic), any reactive primitive accessed during that execution is automatically subscribed to. This eliminates the need for manual dependency declarations in many cases.
16
+
17
+ ## Key Differences: Architectural & Rendering Strategies
18
+
19
+ This is where the two frameworks diverge significantly, each offering unique trade-offs.
20
+
21
+ ### 1. Rendering Mechanism: A Tale of Two Architectures
22
+
23
+ * **Solid.js: No VDOM—A Consequence of Single-Threaded Design**
24
+ * Because it operates entirely on the Main Thread, Solid.js can forgo a Virtual DOM. It compiles JSX directly into highly optimized, imperative JavaScript instructions that create and surgically manipulate the real DOM.
25
+ * When a signal (which holds an immutable value) updates, Solid's reactive graph knows precisely which DOM node to change and updates it directly, without any VDOM diffing overhead.
26
+ * **Benefit:** This "no VDOM" approach is extremely fast for DOM updates, as it eliminates the overhead of VDOM reconciliation. This is the peak of Main-Thread rendering performance.
27
+
28
+ * **Neo.mjs: VDOM as a Necessity for Multi-Threading**
29
+ * For Neo.mjs, a Virtual DOM is not an optional design choice—it is a **necessary and powerful consequence** of its multi-threaded architecture. Since components and application logic live in the App Worker, they have **no access to the DOM**.
30
+ * The VDOM serves as the essential, serializable blueprint of the UI. It's a lightweight description defined using plain JavaScript objects (no JSX).
31
+ * **Mutability by Design, Immutability in Process:** Neo.mjs allows for convenient, direct mutation of state and VDOM in the App Worker. When an update is triggered, it sends an immutable JSON snapshot of the VDOM to a dedicated VDom Worker for diffing. This provides developer convenience without sacrificing performance.
32
+ * **Benefit:** This architecture makes off-thread VDOM diffing possible, which in turn guarantees Main Thread responsiveness. The overhead of the VDOM is the price for keeping the UI from ever freezing. The process is further optimized via atomic DOM insertions, where entire subtrees are built in a detached state and inserted into the live DOM in a single operation.
33
+
34
+ ### 2. Component Execution Model
35
+
36
+ * **Solid.js: Components Run Once**
37
+ * Solid's functional components execute only *once* during their initial render. Their primary role is to set up the reactive graph (signals, effects, memos) and create the real DOM nodes. They do not re-run when state changes. Updates are handled by the fine-grained reactivity system directly updating the DOM.
38
+ * **Benefit:** Extremely efficient, as component functions are not re-executed.
39
+
40
+ * **Neo.mjs: `createVdom` Re-runs Inside an Effect**
41
+ * In Neo.mjs, the `createVdom` method of a functional component is wrapped in a `Neo.core.Effect`. This effect automatically tracks which `config` values it reads.
42
+ * When a dependency changes, the `Effect` re-executes the `createVdom()` function to get a new VDOM description. This is fundamentally different from a React re-render, as it's a targeted re-execution of only the VDOM generation logic, not the entire component setup, and it doesn't cascade to children whose configs haven't changed.
43
+ * **Benefit:** This model is highly intuitive (the VDOM function re-runs when its inputs change) and provides automatic, surgical updates without the developer needing to worry about manual dependency tracking or memoization.
44
+
45
+ ### 3. Overall Architecture
46
+
47
+ * **Solid.js: Single-Threaded (Main Thread Focused)**
48
+ * Solid.js operates entirely on the main JavaScript thread. Its optimizations are focused on making the Main Thread's work as fast and efficient as possible.
49
+ * **Benefit:** Simpler deployment and debugging model, as all JavaScript runs in one context.
50
+
51
+ * **Neo.mjs: Worker-Based (Main Thread + App Worker + VDom Worker)**
52
+ * This is Neo.mjs's most distinctive feature. Application logic (including component instances, state, and `vdomEffect`s) runs in a dedicated **App Worker**, separate from the Main Thread. The VDOM diffing occurs in a **VDom Worker**.
53
+ * Communication between workers and the Main Thread happens via message passing.
54
+ * **Benefit:** Keeps the Main Thread free and responsive, preventing UI freezes even during heavy computations or complex application logic. It inherently leverages multi-core CPUs for parallel processing.
55
+
56
+ ### 4. Update Aggregation & Batching
57
+
58
+ * **Solid.js:** Relies on its fine-grained reactivity and direct DOM manipulation for efficient updates. While it has its own batching mechanisms for signal updates, it doesn't have a VDOM reconciliation phase to aggregate changes.
59
+ * **Neo.mjs:** Employs sophisticated batching and aggregation:
60
+ * **Roundtrip-Based Batching:** Multiple reactive changes within a single tick can be batched into one VDom worker request.
61
+ * **VDom Tree Aggregation (`VdomLifecycle`):** Changes in child components can be aggregated into a parent's update. If a parent is updating, a child's update is deferred and its changes are included in the parent's VDOM diff, minimizing redundant VDom worker roundtrips.
62
+ * **`requestAnimationFrame` Aggregation:** The final application of deltas on the Main Thread (via `DeltaUpdates`) is implicitly batched by the browser's `requestAnimationFrame` cycle, ensuring all DOM changes for a frame are applied efficiently.
63
+ * **Benefit:** This multi-layered batching and aggregation strategy leads to significantly fewer real DOM changes and smoother visual updates, especially in complex applications.
64
+
65
+ ### Other Considerations:
66
+
67
+ * **JSX vs. Plain Objects:** Solid uses JSX (requiring a build step), while Neo.mjs uses plain JavaScript objects for VDOM (no JSX compilation needed). **This means Neo.mjs's VDOM is defined using simple nested JavaScript objects and arrays, akin to a JSON-like description of the DOM.**
68
+ * **Side Effects:** Solid has explicit `createEffect` and `createRenderEffect` hooks for managing side effects. In Neo.mjs, `createVdom` is the primary effect for rendering, and other side effects would typically be managed by separate `Neo.core.Effect` instances or dedicated hooks.
69
+ * **Ecosystem & Maturity:** Solid.js has a growing community and ecosystem. Neo.mjs has a smaller but dedicated community, with a focus on framework-level solutions.
70
+
71
+ ## Conclusion
72
+
73
+ Both Neo.mjs and Solid.js are highly performant, modern reactive frameworks.
74
+
75
+ * **Solid.js** excels by completely sidestepping the Virtual DOM, compiling directly to efficient DOM operations, and running components only once. It's a lean, fast choice for Main Thread-bound applications.
76
+ * **Neo.mjs** offers a unique value proposition with its worker-based architecture, offloading heavy computation from the Main Thread to ensure UI responsiveness. It combines this with a sophisticated VDOM pipeline that includes off-Main-Thread diffing, intelligent batching/aggregation, and surgical direct DOM API updates.
77
+
78
+ The choice between them depends on the specific application's needs: Solid.js for ultimate Main Thread rendering speed, and Neo.mjs for guaranteed Main Thread responsiveness and leveraging multi-core processing, especially in complex, data-intensive applications.
@@ -0,0 +1,92 @@
1
+ # Neo.mjs vs Vue.js
2
+
3
+ Neo.mjs is a comprehensive JavaScript ecosystem for building high-performance, multi-threaded web applications. Unlike frameworks like Vue.js, which operate within a single-threaded browser environment, Neo.mjs is a self-contained system with **zero runtime dependencies**. It provides a complete, out-of-the-box solution that includes four distinct development and deployment environments, from a revolutionary zero-builds development mode to thread-optimized production bundles.
4
+
5
+ This article provides a focused comparison between the Neo.mjs ecosystem and Vue.js. While both frameworks share a commitment to reactivity and component-based architecture, their underlying philosophies on how to achieve performance and scalability are fundamentally different. We will explore their approaches to **architecture, rendering, and reactivity**, highlighting the trade-offs between Vue's highly optimized, single-threaded model and Neo.mjs's holistic, worker-based paradigm.
6
+
7
+ ## Foundational Concepts: A Shared Heritage
8
+
9
+ Despite their architectural differences, both frameworks build upon foundational concepts that have shaped modern UI development:
10
+
11
+ * **Component-Based Architecture:** Both frameworks champion building UIs as a composition of reusable components. Neo.mjs extends this with `Neo.core.Base`, allowing any class-based entity (controllers, models, etc.) to leverage the framework's powerful class system, even without a UI.
12
+ * **Declarative UI:** Developers describe *what* the UI should look like for a given state, and the framework handles *how* to update the DOM.
13
+ * **Reactive Paradigm:** Both are built on reactive principles where UI updates are driven by changes in state. Vue's reactivity system is renowned for its efficiency and ease of use.
14
+ * **Functional Components & Modern APIs:** Both support defining components as functions (or with script setup in Vue) and provide APIs (Hooks in Neo.mjs, Composition API in Vue) for managing state and side effects.
15
+
16
+ ## Key Differences: Architectural & Rendering Strategies
17
+
18
+ This is where the two frameworks diverge significantly, each offering unique trade-offs and advantages.
19
+
20
+ ### 1. Overall Architecture: Main Thread vs. Worker-Based
21
+
22
+ * **Vue.js: Main Thread Focused**
23
+ * Vue applications run entirely on the Main JavaScript Thread. All component logic, state management (e.g., Pinia), VDOM reconciliation, and direct DOM manipulation occur on this single thread.
24
+ * **Implication:** Vue is exceptionally well-optimized for the Main Thread. Its reactivity system is designed to minimize unnecessary work. However, it is still fundamentally bound by the single-threaded nature of JavaScript. Very complex computations or large, synchronous state updates can still potentially block the Main Thread, impacting the user experience in data-heavy, high-frequency update scenarios.
25
+
26
+ * **Neo.mjs: Worker-Based (Main Thread + App Worker + VDom Worker)**
27
+ * Neo.mjs's defining feature is its multi-threaded architecture. Application logic (component instances, state, business logic, `vdomEffect`s) runs in a dedicated **App Worker**, separate from the Main Thread. The VDOM diffing occurs in a **VDom Worker**.
28
+ * Communication between workers and the Main Thread happens via asynchronous message passing.
29
+ * **Benefit:** This architecture keeps the Main Thread almost entirely free and responsive, preventing UI freezes even during heavy computations or complex application logic. It inherently leverages multi-core CPUs for parallel processing, leading to superior UI responsiveness and performance under heavy load.
30
+
31
+ ### 2. Rendering Mechanism
32
+
33
+ * **Vue.js: Main-Thread VDOM & Compiler-Optimized Updates**
34
+ * Vue uses a Virtual DOM and a sophisticated compiler. During the build process, Vue's template compiler analyzes templates and converts them into highly optimized render functions.
35
+ * **VDOM Definition:** Primarily uses Single-File Components (SFCs) with HTML-like templates, which are compiled into JavaScript render functions. It also supports JSX.
36
+ * **Compiler Intelligence:** The compiler can detect static parts of a template and hoist them out of the render function, so they are created only once. It also applies other optimizations, such as patching flags, to help the runtime VDOM diffing algorithm take fast paths and skip unnecessary checks. This makes Vue's rendering extremely efficient on the Main Thread.
37
+
38
+ * **Neo.mjs: Off-Thread VDOM & Developer-Friendly Mutability**
39
+ * Neo.mjs also uses a Virtual DOM, but its philosophy and implementation are fundamentally different. The VDOM is defined using plain JavaScript objects and arrays—no special template syntax or build step is required for UI definition.
40
+ * **Mutability by Design, Immutability in Process:** Neo.mjs embraces developer convenience by allowing **direct, mutable manipulation** of component state (configs) and the VDOM structure within the App Worker. This eliminates the boilerplate and cognitive load of managing immutable updates. The architectural brilliance lies in how it achieves the benefits of immutability: when an update is triggered, Neo.mjs creates a **JSON snapshot** of the relevant VDOM tree. This snapshot is sent to the VDom Worker, making the *update process itself* immutable and predictable for diffing. This provides the best of both worlds: simple, direct mutation for the developer and a safe, immutable structure for the high-performance diffing algorithm in another thread.
41
+ * **Off-Main-Thread Diffing:** The entire VDOM diffing process occurs in the dedicated **VDom Worker**, completely freeing the Main Thread from this heavy computation.
42
+ * **Scoped VDOM (Encapsulation & Performance):** The VDom Worker sends only the "deltas" (a minimal set of change instructions) back to the Main Thread. For insertions, `DomApiRenderer` **builds the entire new DOM subtree in memory**, completely detached from the live document, and inserts it in a **single, atomic operation**. Furthermore, Neo.mjs's VDOM is **scoped by default**. When a parent component renders, its children are represented by simple `{componentId: '...'}` placeholders. This provides two key advantages:
43
+ 1. **Performance:** A parent's update never processes the complex VDOM of its children, keeping update payloads extremely small and efficient.
44
+ 2. **Encapsulation:** It is architecturally impossible for a parent to accidentally reach into and manipulate a child's internal VDOM structure. This enforces clear ownership and prevents a wide class of bugs.
45
+
46
+ ### 3. Component Execution Model: Precision vs. Optimization
47
+
48
+ * **Vue.js: Fine-Grained Reactivity & Optimized Re-Renders**
49
+ * Vue's reactivity system is one of its most celebrated features. When a piece of reactive state (e.g., from `ref` or `reactive`) changes, Vue automatically tracks which components depend on it and triggers updates only for those specific components.
50
+ * It avoids the "cascading re-render" problem of React by default. If a parent component re-renders, it will not unnecessarily re-render child components whose props have not changed. This is a significant performance advantage and a core part of Vue's design.
51
+
52
+ * **Neo.mjs: Surgical Effects & Automatic Efficiency**
53
+ * Neo.mjs's model achieves a similar outcome through a different mechanism. A component's `createVdom` method is wrapped in a `Neo.core.Effect`. This effect automatically and dynamically tracks its dependencies—the specific `config` values it reads.
54
+ * When a config value changes, only the specific `createVdom` effects that depend on that *exact* piece of state are queued for re-execution. There are no cascading re-renders. If a parent's `createVdom` re-runs, but the configs passed to a child have not changed, the child component's `createVdom` function is **never executed**.
55
+ * **Benefit (Zero Manual Optimization):** Like Vue, this fine-grained reactivity eliminates the need for manual memoization (`memo`, `useCallback`, `useMemo`) that plagues React development. The framework handles dependency tracking automatically and precisely, delivering optimal performance out-of-the-box.
56
+
57
+ ### 4. Scaling Complexity: Linear Effort vs. Main-Thread Limits
58
+
59
+ A key differentiator between the frameworks is how they handle growing application complexity.
60
+
61
+ * **Vue.js: Optimized for Main-Thread Scalability**
62
+ * Vue is designed to scale gracefully on the Main Thread. Its reactivity system and compiler optimizations ensure that as an application grows, performance remains high. State management with Pinia is also highly optimized.
63
+ * However, the fundamental limitation remains: all work competes for the same single thread. For extremely data-intensive applications, like real-time financial dashboards or complex graphical editors, the Main Thread can still become a bottleneck, no matter how optimized the framework is.
64
+
65
+ * **Neo.mjs: Built-in Efficiency and Linear Effort**
66
+ * Neo.mjs's architecture is designed to handle this scenario effortlessly. Multiple state changes are automatically batched into a single, de-duplicated update cycle via the `EffectBatchManager`.
67
+ * In a complex dashboard scenario, if a value in a global `StateProvider` changes, only the `createVdom` effects in components that *directly depend on that specific value* will re-run. All other components remain untouched. The crucial difference is that this logic runs in the **App Worker**, and the VDOM diffing runs in the **VDom Worker**, leaving the Main Thread free.
68
+ * This leads to a **linear relationship between complexity and effort**. As you add more components, you don't need to add more performance optimizations. The framework's core design ensures that updates are always surgical and efficient, allowing developers to focus on features instead of fighting the rendering engine. This is a direct result of the sophisticated, multi-layered batching and aggregation built into the framework's core.
69
+
70
+ ### Other Considerations:
71
+
72
+ * **Development & Deployment Environments:** Neo.mjs offers four distinct environments, providing unparalleled flexibility:
73
+ * **Zero Builds Development Mode:** The primary development workflow, leveraging native ES Modules for instant code reflection and debugging without a build step. This contrasts with Vue's typical SFC-based development which always requires a build process (e.g., Vite).
74
+ * **`dist/esm`:** Deploys as native ES Modules, preserving the dev mode's file structure.
75
+ * **`dist/production`:** Generates highly optimized, thread-specific bundles using Webpack.
76
+ * **`dist/development`:** A bundled but unminified environment for debugging production-specific issues.
77
+ * **Dynamic Module Loading:** Neo.mjs uniquely supports dynamically loading code-based modules (even with arbitrary `import` statements) from different environments at runtime, a powerful feature for plugin architectures.
78
+
79
+ * **Templates vs. Plain Objects:** Vue primarily uses HTML-like templates in SFCs (requiring a build step). Neo.mjs uses plain JavaScript objects for VDOM (no compilation needed for VDOM definition).
80
+ * **Ecosystem & Maturity:** Vue has a massive, mature ecosystem with a rich collection of libraries, tools (like Vite and Vue Devtools), and extensive community support. Neo.mjs has a smaller but dedicated community, with a focus on framework-level solutions and integrated features.
81
+ * **Learning Curve:** Vue is famous for its gentle learning curve and excellent documentation. Neo.mjs has a steeper initial learning curve due to its worker-based architecture, but once understood, it offers inherent performance benefits that don't require manual tuning.
82
+ * **Dependency Management (Batteries Included):** Vue projects, while often leaner than React, still rely on `node_modules` and a build toolchain. Neo.mjs is a "batteries included" framework with zero real runtime dependencies outside of its own core. This native ES Module approach significantly reduces complexity and dependency management overhead.
83
+
84
+ ## Conclusion: Why Neo.mjs Offers Significant Technical Advantages Over Vue.js
85
+
86
+ For applications where guaranteed Main Thread responsiveness, high performance under load, leveraging multi-core processing, and long-term maintainability are paramount, Neo.mjs presents a compelling and technically superior alternative.
87
+
88
+ * **Unblocked Main Thread & Inherent Performance:** While Vue is highly optimized for the Main Thread, Neo.mjs's unique worker-based architecture fundamentally removes application logic from the Main Thread entirely. This is not an optimization strategy but a core architectural principle, ensuring the UI remains fluid and responsive even during heavy computations that would challenge any single-threaded framework.
89
+ * **True Parallelism:** Neo.mjs doesn't just optimize tasks on the Main Thread; it runs them in parallel on separate threads. This provides a higher performance ceiling for complex, data-intensive applications.
90
+ * **Linear Effort for Complexity:** Like Vue, Neo.mjs avoids unnecessary re-renders. However, by offloading this work to workers, it ensures that even complex update cycles have zero impact on the Main Thread's availability, allowing for more scalable and maintainable applications in the long run.
91
+
92
+ The choice between them depends on the specific application's needs. For many content-driven sites and standard business applications, Vue's performance and developer experience are excellent. For applications pushing the boundaries of complexity and performance, where guaranteed UI fluidity is a critical requirement, Neo.mjs offers a fundamentally more robust and scalable architecture.