@ccslabs/xtend 0.1.0-rc.1 → 0.1.2

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 (566) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/README.md +4 -0
  3. package/catalog/component-catalog-coverage.js +2 -0
  4. package/catalog/epic13-package-export-lock.js +11 -1
  5. package/catalog/epic13-rmt-production-readiness.js +0 -1
  6. package/catalog/epic18-rmt-action-effect-runtime.d.ts +36 -0
  7. package/catalog/epic18-rmt-action-effect-runtime.js +249 -0
  8. package/catalog/epic18-rmt-app-platform-authoring.d.ts +39 -0
  9. package/catalog/epic18-rmt-app-platform-authoring.js +319 -0
  10. package/catalog/epic18-rmt-app-platform-fixture.d.ts +33 -0
  11. package/catalog/epic18-rmt-app-platform-fixture.js +221 -0
  12. package/catalog/epic18-rmt-app-platform-release-handoff.d.ts +30 -0
  13. package/catalog/epic18-rmt-app-platform-release-handoff.js +231 -0
  14. package/catalog/epic18-rmt-app-platform-tooling.d.ts +38 -0
  15. package/catalog/epic18-rmt-app-platform-tooling.js +242 -0
  16. package/catalog/epic18-rmt-component-template-primitives.d.ts +33 -0
  17. package/catalog/epic18-rmt-component-template-primitives.js +240 -0
  18. package/catalog/epic18-rmt-dom-descriptor-renderer.d.ts +35 -0
  19. package/catalog/epic18-rmt-dom-descriptor-renderer.js +232 -0
  20. package/catalog/epic18-rmt-event-routing-runtime.d.ts +35 -0
  21. package/catalog/epic18-rmt-event-routing-runtime.js +234 -0
  22. package/catalog/epic18-rmt-state-selector-runtime.d.ts +34 -0
  23. package/catalog/epic18-rmt-state-selector-runtime.js +216 -0
  24. package/catalog/epic18-rmt-surface-resource-graph-runtime.d.ts +36 -0
  25. package/catalog/epic18-rmt-surface-resource-graph-runtime.js +256 -0
  26. package/catalog/surface-manager-controller.js +5 -1
  27. package/catalog/surface-manager-materialization.js +7 -1
  28. package/catalog/surface-manager-overlay-bridge.js +41 -6
  29. package/catalog/surface-manager-workbench-fixture.js +1 -1
  30. package/catalog/surface-type-capability-matrix.d.ts +61 -0
  31. package/catalog/surface-type-capability-matrix.js +183 -0
  32. package/catalog/type-exports-rmt.js +37 -1
  33. package/catalog/type-exports.js +3 -3
  34. package/components/icon-packs/lucide.js +4 -0
  35. package/components/manifest.json +2 -0
  36. package/components/prism-rmt.d.ts +34 -0
  37. package/components/prism-rmt.js +130 -0
  38. package/components/xcards.js +15 -0
  39. package/components/xcode.d.ts +36 -1
  40. package/components/xcode.js +215 -20
  41. package/components/xfooter.js +17 -0
  42. package/components/xheader.js +14 -0
  43. package/components/xhero.js +16 -1
  44. package/components/xlink.js +97 -14
  45. package/components/xmasonry.js +15 -0
  46. package/components/xplayer.d.ts +44 -2
  47. package/components/xplayer.js +242 -15
  48. package/components/xrouter.js +27 -2
  49. package/components/xsection.js +15 -0
  50. package/components/xsidepanel.js +10 -2
  51. package/components/xsurfacemanager-controller.d.ts +2 -1
  52. package/components/xsurfacemanager-controller.js +27 -3
  53. package/components/xsurfacemanager.d.ts +2 -0
  54. package/components/xsurfacemanager.js +20 -8
  55. package/components/xsurfaceoverlay-bridge.d.ts +20 -5
  56. package/components/xsurfaceoverlay-bridge.js +114 -18
  57. package/components/xsurfaceportal.d.ts +29 -0
  58. package/components/xsurfaceportal.js +122 -0
  59. package/components/xsurfaceregion.d.ts +50 -0
  60. package/components/xsurfaceregion.js +285 -0
  61. package/components/xsurfacewindow.js +2 -1
  62. package/components/xtooltip.js +89 -23
  63. package/docs/README.md +222 -298
  64. package/docs/changelog.md +107 -0
  65. package/docs/component-catalog-coverage.md +9 -9
  66. package/docs/component-platform.md +19 -1
  67. package/docs/component-ux-app-authoring.md +56 -63
  68. package/docs/components/xcode.md +83 -53
  69. package/docs/components/xsurfaceportal.md +32 -0
  70. package/docs/components/xsurfaceregion.md +37 -0
  71. package/docs/components.md +105 -69
  72. package/docs/de/README.md +264 -0
  73. package/docs/de/XTend-ADR.md +221 -0
  74. package/docs/de/a11y-keyboard-smokes.md +62 -0
  75. package/docs/de/about.md +18 -0
  76. package/docs/de/api.md +157 -0
  77. package/docs/de/best-practices.md +76 -0
  78. package/docs/de/changelog.md +107 -0
  79. package/docs/de/component-catalog-coverage.md +58 -0
  80. package/docs/de/component-lab.md +103 -0
  81. package/docs/de/component-long-tail-migration.md +41 -0
  82. package/docs/de/component-platform.md +177 -0
  83. package/docs/de/component-ux-app-authoring.md +123 -0
  84. package/docs/de/component-ux-authoring.md +96 -0
  85. package/docs/de/component-ux-gates.md +45 -0
  86. package/docs/de/components/x-rmt-lifecycle-demo-build.md +60 -0
  87. package/docs/de/components/xalert.md +81 -0
  88. package/docs/de/components/xbutton.md +103 -0
  89. package/docs/de/components/xcalendar.md +82 -0
  90. package/docs/de/components/xcards.md +128 -0
  91. package/docs/de/components/xcheckbox.md +102 -0
  92. package/docs/de/components/xcode.md +156 -0
  93. package/docs/de/components/xdialog.md +92 -0
  94. package/docs/de/components/xdrawer.md +84 -0
  95. package/docs/de/components/xfooter.md +126 -0
  96. package/docs/de/components/xform.md +128 -0
  97. package/docs/de/components/xheader.md +308 -0
  98. package/docs/de/components/xhero.md +142 -0
  99. package/docs/de/components/xicon.md +125 -0
  100. package/docs/de/components/xinput.md +129 -0
  101. package/docs/de/components/xlightbox.md +98 -0
  102. package/docs/de/components/xlink.md +109 -0
  103. package/docs/de/components/xmasonry.md +124 -0
  104. package/docs/de/components/xmenu.md +158 -0
  105. package/docs/de/components/xmodal.md +82 -0
  106. package/docs/de/components/xplayer.md +104 -0
  107. package/docs/de/components/xpopover.md +67 -0
  108. package/docs/de/components/xprogress.md +56 -0
  109. package/docs/de/components/xradio.md +103 -0
  110. package/docs/de/components/xrouter.md +260 -0
  111. package/docs/de/components/xsection.md +125 -0
  112. package/docs/de/components/xselect.md +105 -0
  113. package/docs/de/components/xsidepanel.md +30 -0
  114. package/docs/de/components/xspinner.md +102 -0
  115. package/docs/de/components/xstate.md +148 -0
  116. package/docs/de/components/xstatus.md +55 -0
  117. package/docs/de/components/xsummary.md +78 -0
  118. package/docs/de/components/xsurfacemanager.md +27 -0
  119. package/docs/de/components/xsurfacewindow.md +21 -0
  120. package/docs/de/components/xtabs.md +160 -0
  121. package/docs/de/components/xtextarea.md +98 -0
  122. package/docs/de/components/xtheme.md +167 -0
  123. package/docs/de/components/xtoast.md +62 -0
  124. package/docs/de/components/xtooltip.md +66 -0
  125. package/docs/de/components/xtype.md +82 -0
  126. package/docs/de/components/xutils.md +144 -0
  127. package/docs/de/components/xwriter.md +94 -0
  128. package/docs/de/components.md +153 -0
  129. package/docs/de/conditional-network-evidence-ci.md +38 -0
  130. package/docs/de/conditional-network-evidence.md +50 -0
  131. package/docs/de/core-migration-guide.md +110 -0
  132. package/docs/de/design-tokens.md +116 -0
  133. package/docs/de/docs-rmt-production-hardening.md +31 -0
  134. package/docs/de/enterprise-adoption.md +413 -0
  135. package/docs/de/enterprise-component-flex-release-handoff.md +129 -0
  136. package/docs/de/epic10-platform-gates.md +62 -0
  137. package/docs/de/epic10-release-handoff.md +81 -0
  138. package/docs/de/epic11-enterprise-ux-handoff.md +70 -0
  139. package/docs/de/epic12-rc0-handoff.md +61 -0
  140. package/docs/de/epic18-media-manager-vendor-upstream.md +318 -0
  141. package/docs/de/epic18-rmt-app-platform-release-handoff.md +67 -0
  142. package/docs/de/epic18-vendor-bugfixes.md +34 -0
  143. package/docs/de/existing-component-metadata.md +67 -0
  144. package/docs/de/hydration-performance-closure.md +34 -0
  145. package/docs/de/hydration-policies.md +71 -0
  146. package/docs/de/known-residual-triage.md +22 -0
  147. package/docs/de/manifest-import-policy.md +79 -0
  148. package/docs/de/manifest.md +112 -0
  149. package/docs/de/motion-contrast.md +67 -0
  150. package/docs/de/package-export-lock.md +44 -0
  151. package/docs/de/performance-measurements.md +106 -0
  152. package/docs/de/performance-regression.md +89 -0
  153. package/docs/de/performance.md +94 -0
  154. package/docs/de/previews/README.md +17 -0
  155. package/docs/de/prod-browser-csp-smokes.md +40 -0
  156. package/docs/de/public-component-types.md +79 -0
  157. package/docs/de/quick-start-guide.md +220 -0
  158. package/docs/de/rc0-adoption-guide.md +102 -0
  159. package/docs/de/rc0-gate-matrix.md +58 -0
  160. package/docs/de/rc1-gate-matrix-ci-handoff.md +56 -0
  161. package/docs/de/rc1-migration-notes.md +69 -0
  162. package/docs/de/rc1-readiness.md +46 -0
  163. package/docs/de/release-owner-acceptance.md +56 -0
  164. package/docs/de/release-report-pack-dry-run-evidence.md +39 -0
  165. package/docs/de/rmt-action-effect-runtime.md +81 -0
  166. package/docs/de/rmt-app-platform-authoring.md +54 -0
  167. package/docs/de/rmt-app-platform-fixture.md +46 -0
  168. package/docs/de/rmt-app-platform-migration-guide.md +88 -0
  169. package/docs/de/rmt-app-platform-tooling.md +79 -0
  170. package/docs/de/rmt-component-template-primitives.md +57 -0
  171. package/docs/de/rmt-dom-descriptor-renderer.md +64 -0
  172. package/docs/de/rmt-dsl-authoring-polish.md +145 -0
  173. package/docs/de/rmt-event-routing-runtime.md +81 -0
  174. package/docs/de/rmt-first-demo-app.md +77 -0
  175. package/docs/de/rmt-first-xtend-apps.md +129 -0
  176. package/docs/de/rmt-kernel-panic-recovery-incident-handoff.md +61 -0
  177. package/docs/de/rmt-kernel-security-hardening-migration.md +50 -0
  178. package/docs/de/rmt-kernel-trusted-output-authoring.md +69 -0
  179. package/docs/de/rmt-language-server.md +234 -0
  180. package/docs/de/rmt-lifecycle-demo.md +24 -0
  181. package/docs/de/rmt-linter.md +140 -0
  182. package/docs/de/rmt-node-ssr-adapter.md +100 -0
  183. package/docs/de/rmt-php-ssr-adapter.md +120 -0
  184. package/docs/de/rmt-production-readiness.md +63 -0
  185. package/docs/de/rmt-state-selector-runtime.md +47 -0
  186. package/docs/de/rmt-surface-resource-graph-runtime.md +92 -0
  187. package/docs/de/rmt-tooling-release-gates.md +77 -0
  188. package/docs/de/rmt-vnext-authoring.md +170 -0
  189. package/docs/de/rmt-vnext-component-primitives.md +188 -0
  190. package/docs/de/rmt-vnext-cross-surface-events.md +68 -0
  191. package/docs/de/rmt-vnext-enterprise-mfe-handoff.md +70 -0
  192. package/docs/de/rmt-vnext-fabric-bridge-evidence.md +81 -0
  193. package/docs/de/rmt-vnext-migration-notes.md +62 -0
  194. package/docs/de/rmt-vnext-primitive-authoring-tooling.md +247 -0
  195. package/docs/de/rmt-vnext-primitive-grammar-design.md +289 -0
  196. package/docs/de/rmt-vnext-primitive-lowering.md +108 -0
  197. package/docs/de/rmt-vnext-primitive-migration.md +119 -0
  198. package/docs/de/rmt-vnext-primitive-parser-ast.md +76 -0
  199. package/docs/de/rmt-vnext-primitive-semantic-graph.md +118 -0
  200. package/docs/de/rmt-vnext-primitives-compiler-backlog.md +739 -0
  201. package/docs/de/rmt-vnext-release-handoff.md +83 -0
  202. package/docs/de/rmt-vnext-remote-surfaces.md +90 -0
  203. package/docs/de/rmt-vnext-source-to-sea-gate.md +612 -0
  204. package/docs/de/rmt-vnext-surface-registry-enterprise.md +76 -0
  205. package/docs/de/screenreader-signals.md +56 -0
  206. package/docs/de/supply-chain-gates.md +100 -0
  207. package/docs/de/surface-manager-authoring-guide.md +94 -0
  208. package/docs/de/surface-manager-browser-lab.md +45 -0
  209. package/docs/de/surface-manager-component-lab.md +43 -0
  210. package/docs/de/surface-manager-controller.md +66 -0
  211. package/docs/de/surface-manager-layout-engines.md +32 -0
  212. package/docs/de/surface-manager-lazy-hydration.md +63 -0
  213. package/docs/de/surface-manager-migration-guide.md +122 -0
  214. package/docs/de/surface-manager-native-rmt-surfaces.md +38 -0
  215. package/docs/de/surface-manager-overlay-bridge.md +53 -0
  216. package/docs/de/surface-manager-persistence.md +30 -0
  217. package/docs/de/surface-manager-quality-gates.md +51 -0
  218. package/docs/de/surface-manager-release-handoff.md +68 -0
  219. package/docs/de/surface-manager-remote-policy.md +54 -0
  220. package/docs/de/surface-manager-rmt-authoring.md +102 -0
  221. package/docs/de/surface-manager-route-lifecycle.md +59 -0
  222. package/docs/de/surface-manager-runtime-release-handoff.md +69 -0
  223. package/docs/de/surface-manager-side-panel-runtime.md +36 -0
  224. package/docs/de/surface-manager-stack-policy.md +39 -0
  225. package/docs/de/surface-manager-window-runtime.md +47 -0
  226. package/docs/de/surface-manager-workbench-fixture.md +43 -0
  227. package/docs/de/third-party-design-authoring.md +406 -0
  228. package/docs/de/trusted-dom-boundary-browser-proof.md +32 -0
  229. package/docs/de/trusted-dom-sanitizing.md +110 -0
  230. package/docs/de/type-exports.md +61 -0
  231. package/docs/de/typescript-components.md +63 -0
  232. package/docs/de/visual-browser-regression.md +83 -0
  233. package/docs/de/visual-owner-artifacts.md +46 -0
  234. package/docs/de/visual-snapshot-automation.md +87 -0
  235. package/docs/de/xtend-api-types.md +55 -0
  236. package/docs/de/xtend-builder-types.md +55 -0
  237. package/docs/de/xtend-catalog-types.md +44 -0
  238. package/docs/de/xtend-fabric-rmt-lane-mapping.md +143 -0
  239. package/docs/de/xtend-fabric.md +474 -0
  240. package/docs/de/xtend-loader-types.md +58 -0
  241. package/docs/de/xtend-loader.md +265 -0
  242. package/docs/de/xtend-policy-types.md +38 -0
  243. package/docs/de/xtend-rmt-types.md +40 -0
  244. package/docs/de/xtend-vendor-types.md +36 -0
  245. package/docs/de/xtendrmt-app-dsl.md +334 -0
  246. package/docs/de/xtendrmt-migration-guide.md +266 -0
  247. package/docs/de/xtendrmt-native-authoring.md +333 -0
  248. package/docs/de/xtendrmt-overview.md +109 -0
  249. package/docs/de/xtendrmt-parsedown-scheduling.md +301 -0
  250. package/docs/de/xtendrmt-runtime-bridge.md +155 -0
  251. package/docs/en/README.md +163 -0
  252. package/docs/en/XTend-ADR.md +221 -0
  253. package/docs/en/a11y-keyboard-smokes.md +68 -0
  254. package/docs/en/about.md +25 -0
  255. package/docs/en/api.md +171 -0
  256. package/docs/en/best-practices.md +125 -0
  257. package/docs/en/changelog.md +104 -0
  258. package/docs/en/component-catalog-coverage.md +104 -0
  259. package/docs/en/component-lab.md +103 -0
  260. package/docs/en/component-long-tail-migration.md +41 -0
  261. package/docs/en/component-platform.md +243 -0
  262. package/docs/en/component-ux-app-authoring.md +118 -0
  263. package/docs/en/component-ux-authoring.md +96 -0
  264. package/docs/en/component-ux-gates.md +45 -0
  265. package/docs/en/components/x-rmt-lifecycle-demo-build.md +75 -0
  266. package/docs/en/components/xalert.md +94 -0
  267. package/docs/en/components/xbutton.md +118 -0
  268. package/docs/en/components/xcalendar.md +95 -0
  269. package/docs/en/components/xcards.md +139 -0
  270. package/docs/en/components/xcheckbox.md +118 -0
  271. package/docs/en/components/xcode.md +153 -0
  272. package/docs/en/components/xdialog.md +108 -0
  273. package/docs/en/components/xdrawer.md +110 -0
  274. package/docs/en/components/xfooter.md +138 -0
  275. package/docs/en/components/xform.md +147 -0
  276. package/docs/en/components/xheader.md +308 -0
  277. package/docs/en/components/xhero.md +157 -0
  278. package/docs/en/components/xicon.md +149 -0
  279. package/docs/en/components/xinput.md +147 -0
  280. package/docs/en/components/xlightbox.md +113 -0
  281. package/docs/en/components/xlink.md +130 -0
  282. package/docs/en/components/xmasonry.md +136 -0
  283. package/docs/en/components/xmenu.md +185 -0
  284. package/docs/en/components/xmodal.md +102 -0
  285. package/docs/en/components/xplayer.md +114 -0
  286. package/docs/en/components/xpopover.md +87 -0
  287. package/docs/en/components/xprogress.md +73 -0
  288. package/docs/en/components/xradio.md +119 -0
  289. package/docs/en/components/xrouter.md +260 -0
  290. package/docs/en/components/xsection.md +136 -0
  291. package/docs/en/components/xselect.md +122 -0
  292. package/docs/en/components/xsidepanel.md +48 -0
  293. package/docs/en/components/xspinner.md +118 -0
  294. package/docs/en/components/xstate.md +163 -0
  295. package/docs/en/components/xstatus.md +71 -0
  296. package/docs/en/components/xsummary.md +90 -0
  297. package/docs/en/components/xsurfacemanager.md +42 -0
  298. package/docs/en/components/xsurfacewindow.md +31 -0
  299. package/docs/en/components/xtabs.md +187 -0
  300. package/docs/en/components/xtextarea.md +115 -0
  301. package/docs/en/components/xtheme.md +203 -0
  302. package/docs/en/components/xtoast.md +78 -0
  303. package/docs/en/components/xtooltip.md +85 -0
  304. package/docs/en/components/xtype.md +91 -0
  305. package/docs/en/components/xutils.md +161 -0
  306. package/docs/en/components/xwriter.md +106 -0
  307. package/docs/en/components.md +151 -0
  308. package/docs/en/conditional-network-evidence-ci.md +38 -0
  309. package/docs/en/conditional-network-evidence.md +50 -0
  310. package/docs/en/core-migration-guide.md +110 -0
  311. package/docs/en/design-tokens.md +137 -0
  312. package/docs/en/docs-rmt-production-hardening.md +31 -0
  313. package/docs/en/enterprise-adoption.md +413 -0
  314. package/docs/en/enterprise-component-flex-release-handoff.md +129 -0
  315. package/docs/en/epic10-platform-gates.md +62 -0
  316. package/docs/en/epic10-release-handoff.md +81 -0
  317. package/docs/en/epic11-enterprise-ux-handoff.md +70 -0
  318. package/docs/en/epic12-rc0-handoff.md +61 -0
  319. package/docs/en/epic18-media-manager-vendor-upstream.md +232 -0
  320. package/docs/en/epic18-rmt-app-platform-release-handoff.md +60 -0
  321. package/docs/en/epic18-vendor-bugfixes.md +29 -0
  322. package/docs/en/existing-component-metadata.md +67 -0
  323. package/docs/en/hydration-performance-closure.md +34 -0
  324. package/docs/en/hydration-policies.md +75 -0
  325. package/docs/en/known-residual-triage.md +22 -0
  326. package/docs/en/manifest-import-policy.md +81 -0
  327. package/docs/en/manifest.md +135 -0
  328. package/docs/en/motion-contrast.md +67 -0
  329. package/docs/en/package-export-lock.md +44 -0
  330. package/docs/en/performance-measurements.md +106 -0
  331. package/docs/en/performance-regression.md +89 -0
  332. package/docs/en/performance.md +132 -0
  333. package/docs/en/previews/README.md +17 -0
  334. package/docs/en/prod-browser-csp-smokes.md +40 -0
  335. package/docs/en/public-component-types.md +79 -0
  336. package/docs/en/quick-start-guide.md +189 -0
  337. package/docs/en/rc0-adoption-guide.md +102 -0
  338. package/docs/en/rc0-gate-matrix.md +58 -0
  339. package/docs/en/rc1-gate-matrix-ci-handoff.md +56 -0
  340. package/docs/en/rc1-migration-notes.md +69 -0
  341. package/docs/en/rc1-readiness.md +46 -0
  342. package/docs/en/release-owner-acceptance.md +56 -0
  343. package/docs/en/release-report-pack-dry-run-evidence.md +39 -0
  344. package/docs/en/rmt-action-effect-runtime.md +101 -0
  345. package/docs/en/rmt-app-platform-authoring.md +47 -0
  346. package/docs/en/rmt-app-platform-fixture.md +35 -0
  347. package/docs/en/rmt-app-platform-migration-guide.md +75 -0
  348. package/docs/en/rmt-app-platform-tooling.md +58 -0
  349. package/docs/en/rmt-component-template-primitives.md +49 -0
  350. package/docs/en/rmt-dom-descriptor-renderer.md +54 -0
  351. package/docs/en/rmt-dsl-authoring-polish.md +143 -0
  352. package/docs/en/rmt-event-routing-runtime.md +98 -0
  353. package/docs/en/rmt-first-demo-app.md +87 -0
  354. package/docs/en/rmt-first-xtend-apps.md +127 -0
  355. package/docs/en/rmt-kernel-panic-recovery-incident-handoff.md +60 -0
  356. package/docs/en/rmt-kernel-security-hardening-migration.md +49 -0
  357. package/docs/en/rmt-kernel-trusted-output-authoring.md +68 -0
  358. package/docs/en/rmt-language-server.md +243 -0
  359. package/docs/en/rmt-lifecycle-demo.md +23 -0
  360. package/docs/en/rmt-linter.md +146 -0
  361. package/docs/en/rmt-node-ssr-adapter.md +99 -0
  362. package/docs/en/rmt-php-ssr-adapter.md +118 -0
  363. package/docs/en/rmt-production-readiness.md +63 -0
  364. package/docs/en/rmt-state-selector-runtime.md +34 -0
  365. package/docs/en/rmt-surface-resource-graph-runtime.md +68 -0
  366. package/docs/en/rmt-tooling-release-gates.md +77 -0
  367. package/docs/en/rmt-vnext-authoring.md +102 -0
  368. package/docs/en/rmt-vnext-component-primitives.md +185 -0
  369. package/docs/en/rmt-vnext-cross-surface-events.md +59 -0
  370. package/docs/en/rmt-vnext-enterprise-mfe-handoff.md +62 -0
  371. package/docs/en/rmt-vnext-fabric-bridge-evidence.md +64 -0
  372. package/docs/en/rmt-vnext-migration-notes.md +62 -0
  373. package/docs/en/rmt-vnext-primitive-authoring-tooling.md +174 -0
  374. package/docs/en/rmt-vnext-primitive-grammar-design.md +268 -0
  375. package/docs/en/rmt-vnext-primitive-lowering.md +91 -0
  376. package/docs/en/rmt-vnext-primitive-migration.md +93 -0
  377. package/docs/en/rmt-vnext-primitive-parser-ast.md +59 -0
  378. package/docs/en/rmt-vnext-primitive-semantic-graph.md +103 -0
  379. package/docs/en/rmt-vnext-primitives-compiler-backlog.md +327 -0
  380. package/docs/en/rmt-vnext-release-handoff.md +83 -0
  381. package/docs/en/rmt-vnext-remote-surfaces.md +81 -0
  382. package/docs/en/rmt-vnext-source-to-sea-gate.md +482 -0
  383. package/docs/en/rmt-vnext-surface-registry-enterprise.md +68 -0
  384. package/docs/en/screenreader-signals.md +56 -0
  385. package/docs/en/supply-chain-gates.md +106 -0
  386. package/docs/en/surface-manager-authoring-guide.md +94 -0
  387. package/docs/en/surface-manager-browser-lab.md +45 -0
  388. package/docs/en/surface-manager-component-lab.md +43 -0
  389. package/docs/en/surface-manager-controller.md +66 -0
  390. package/docs/en/surface-manager-layout-engines.md +32 -0
  391. package/docs/en/surface-manager-lazy-hydration.md +63 -0
  392. package/docs/en/surface-manager-migration-guide.md +113 -0
  393. package/docs/en/surface-manager-native-rmt-surfaces.md +38 -0
  394. package/docs/en/surface-manager-overlay-bridge.md +53 -0
  395. package/docs/en/surface-manager-persistence.md +30 -0
  396. package/docs/en/surface-manager-quality-gates.md +51 -0
  397. package/docs/en/surface-manager-release-handoff.md +68 -0
  398. package/docs/en/surface-manager-remote-policy.md +54 -0
  399. package/docs/en/surface-manager-rmt-authoring.md +89 -0
  400. package/docs/en/surface-manager-route-lifecycle.md +59 -0
  401. package/docs/en/surface-manager-runtime-release-handoff.md +69 -0
  402. package/docs/en/surface-manager-side-panel-runtime.md +36 -0
  403. package/docs/en/surface-manager-stack-policy.md +39 -0
  404. package/docs/en/surface-manager-window-runtime.md +47 -0
  405. package/docs/en/surface-manager-workbench-fixture.md +43 -0
  406. package/docs/en/third-party-design-authoring.md +406 -0
  407. package/docs/en/trusted-dom-boundary-browser-proof.md +32 -0
  408. package/docs/en/trusted-dom-sanitizing.md +124 -0
  409. package/docs/en/type-exports.md +61 -0
  410. package/docs/en/typescript-components.md +63 -0
  411. package/docs/en/visual-browser-regression.md +83 -0
  412. package/docs/en/visual-owner-artifacts.md +46 -0
  413. package/docs/en/visual-snapshot-automation.md +87 -0
  414. package/docs/en/xtend-api-types.md +55 -0
  415. package/docs/en/xtend-builder-types.md +55 -0
  416. package/docs/en/xtend-catalog-types.md +44 -0
  417. package/docs/en/xtend-fabric-rmt-lane-mapping.md +143 -0
  418. package/docs/en/xtend-fabric.md +474 -0
  419. package/docs/en/xtend-loader-types.md +58 -0
  420. package/docs/en/xtend-loader.md +265 -0
  421. package/docs/en/xtend-policy-types.md +38 -0
  422. package/docs/en/xtend-rmt-types.md +40 -0
  423. package/docs/en/xtend-vendor-types.md +36 -0
  424. package/docs/en/xtendrmt-app-dsl.md +331 -0
  425. package/docs/en/xtendrmt-migration-guide.md +256 -0
  426. package/docs/en/xtendrmt-native-authoring.md +336 -0
  427. package/docs/en/xtendrmt-overview.md +63 -0
  428. package/docs/en/xtendrmt-parsedown-scheduling.md +301 -0
  429. package/docs/en/xtendrmt-runtime-bridge.md +155 -0
  430. package/docs/enterprise-adoption.md +4 -2
  431. package/docs/epic18-media-manager-vendor-upstream.md +318 -0
  432. package/docs/epic18-rmt-app-platform-release-handoff.md +67 -0
  433. package/docs/epic18-vendor-bugfixes.md +34 -0
  434. package/docs/index.php +1056 -109
  435. package/docs/manifest.md +8 -2
  436. package/docs/menu.json +986 -133
  437. package/docs/package-export-lock.md +2 -2
  438. package/docs/public-component-types.md +2 -2
  439. package/docs/quick-start-guide.md +126 -58
  440. package/docs/rmt-action-effect-runtime.md +101 -0
  441. package/docs/rmt-app-platform-authoring.md +54 -0
  442. package/docs/rmt-app-platform-fixture.md +46 -0
  443. package/docs/rmt-app-platform-migration-guide.md +88 -0
  444. package/docs/rmt-app-platform-tooling.md +79 -0
  445. package/docs/rmt-component-template-primitives.md +57 -0
  446. package/docs/rmt-dom-descriptor-renderer.md +64 -0
  447. package/docs/rmt-dsl-authoring-polish.md +67 -44
  448. package/docs/rmt-event-routing-runtime.md +98 -0
  449. package/docs/rmt-first-demo-app.md +2 -2
  450. package/docs/rmt-first-xtend-apps.md +70 -46
  451. package/docs/rmt-language-server.md +61 -4
  452. package/docs/rmt-lifecycle-demo.md +1 -2
  453. package/docs/rmt-node-ssr-adapter.md +144 -0
  454. package/docs/rmt-php-ssr-adapter.md +158 -0
  455. package/docs/rmt-state-selector-runtime.md +47 -0
  456. package/docs/rmt-surface-resource-graph-runtime.md +92 -0
  457. package/docs/rmt-vnext-authoring.md +128 -18
  458. package/docs/rmt-vnext-component-primitives.md +188 -0
  459. package/docs/rmt-vnext-fabric-bridge-evidence.md +81 -0
  460. package/docs/rmt-vnext-primitive-authoring-tooling.md +247 -0
  461. package/docs/rmt-vnext-primitive-grammar-design.md +289 -0
  462. package/docs/rmt-vnext-primitive-lowering.md +108 -0
  463. package/docs/rmt-vnext-primitive-migration.md +119 -0
  464. package/docs/rmt-vnext-primitive-parser-ast.md +76 -0
  465. package/docs/rmt-vnext-primitive-semantic-graph.md +118 -0
  466. package/docs/rmt-vnext-primitives-compiler-backlog.md +742 -0
  467. package/docs/rmt-vnext-release-handoff.md +14 -0
  468. package/docs/rmt-vnext-source-to-sea-gate.md +629 -0
  469. package/docs/surface-manager-migration-guide.md +34 -6
  470. package/docs/surface-manager-overlay-bridge.md +9 -4
  471. package/docs/surface-manager-rmt-authoring.md +50 -34
  472. package/docs/surface-manager-workbench-fixture.md +1 -2
  473. package/docs/third-party-design-authoring.md +1 -1
  474. package/docs/type-exports.md +3 -3
  475. package/docs/utils/pageloader.js +811 -62
  476. package/docs/visual-browser-regression.md +1 -1
  477. package/docs/xtend-rmt-types.md +3 -2
  478. package/docs/xtendrmt-app-dsl.md +187 -122
  479. package/docs/xtendrmt-docs-shell-vnext.rmt +165 -0
  480. package/docs/xtendrmt-migration-guide.md +48 -17
  481. package/docs/xtendrmt-native-authoring.md +213 -217
  482. package/docs/xtendrmt-overview.md +81 -61
  483. package/docs/xtendrmt-parsedown-scheduling.md +23 -8
  484. package/fabric/package.json +1 -1
  485. package/package.json +684 -21
  486. package/tools/package.json +5 -1
  487. package/tools/rmt-editor/vscode/README.md +72 -5
  488. package/tools/rmt-editor/vscode/XTend-Logo.png +0 -0
  489. package/tools/rmt-editor/vscode/extension.d.ts +33 -0
  490. package/tools/rmt-editor/vscode/extension.js +1816 -7
  491. package/tools/rmt-editor/vscode/language-configuration.json +2 -1
  492. package/tools/rmt-editor/vscode/package.json +193 -2
  493. package/tools/rmt-editor/vscode/snippets/rmt.code-snippets +41 -0
  494. package/tools/rmt-editor/vscode/syntaxes/rmt.tmLanguage.json +103 -1
  495. package/tools/rmt-editor/vscode/templates/launch.json +70 -0
  496. package/tools/rmt-editor/vscode/templates/tasks.json +172 -0
  497. package/tools/rmt-editor/vscode/xtend-rmt-language-0.0.0-enterprise-readiness.vsix +0 -0
  498. package/tools/rmt-language/app-platform-tooling.d.ts +128 -0
  499. package/tools/rmt-language/app-platform-tooling.js +677 -0
  500. package/tools/rmt-language/completions.d.ts +5 -0
  501. package/tools/rmt-language/completions.js +185 -3
  502. package/tools/rmt-language/diagnostics.js +54 -0
  503. package/tools/rmt-language/hover.js +36 -0
  504. package/tools/rmt-language/rmt-tooling-public-types.d.ts +7 -0
  505. package/tools/rmt-language/rules/app-platform-policy.js +39 -0
  506. package/tools/rmt-language/rules/index.js +5 -1
  507. package/tools/rmt-language/semantic-graph.d.ts +6 -0
  508. package/tools/rmt-language/semantic-graph.js +928 -0
  509. package/tools/rmt-language/snippets/index.js +44 -0
  510. package/tools/rmt-language/snippets/rmt.code-snippets +41 -0
  511. package/tools/rmt-language/vnext-compatibility.d.ts +10 -0
  512. package/tools/rmt-language/vnext-compatibility.js +642 -0
  513. package/tools/rmt-language/vnext-compiler.d.ts +5 -0
  514. package/tools/rmt-language/vnext-compiler.js +863 -17
  515. package/tools/rmt-language/vnext-parser.js +725 -9
  516. package/tools/rmt-language/vnext-release.d.ts +1 -0
  517. package/tools/rmt-language/vnext-release.js +20 -0
  518. package/tools/rmt-language/vnext-source-to-sea.d.ts +33 -0
  519. package/tools/rmt-language/vnext-source-to-sea.js +2227 -0
  520. package/tools/rmt-language/vnext-surfaces.js +111 -52
  521. package/tools/rmt-language/vnext-tooling.d.ts +19 -1
  522. package/tools/rmt-language/vnext-tooling.js +1247 -5
  523. package/tools/rmt-language-server/protocol.js +3 -0
  524. package/tools/rmt-language-server/server.d.ts +2 -0
  525. package/tools/rmt-language-server/server.js +176 -22
  526. package/tools/rmt-linter/cli.d.ts +2 -0
  527. package/tools/rmt-linter/cli.js +62 -0
  528. package/xtend-builder/generators/registry.js +11 -0
  529. package/xtend-builder/generators/rmt-app-platform.js +239 -0
  530. package/xtend-builder/generators/rmt-lifecycle-demo.js +3 -11
  531. package/xtend-builder/lib/cli.js +38 -0
  532. package/xtend-builder/package.json +3 -3
  533. package/xtend-builder/scaffold.config.js +29 -2
  534. package/xtend.css +49 -2
  535. package/xtendrmt/package.json +49 -1
  536. package/xtendrmt/rmt-action-effect-runtime.d.ts +126 -0
  537. package/xtendrmt/rmt-action-effect-runtime.js +494 -0
  538. package/xtendrmt/rmt-component-capability-registry.d.ts +180 -0
  539. package/xtendrmt/rmt-component-capability-registry.js +636 -0
  540. package/xtendrmt/rmt-core.d.ts +6 -0
  541. package/xtendrmt/rmt-core.esm.js +32 -6
  542. package/xtendrmt/rmt-dom-descriptor-renderer.d.ts +107 -0
  543. package/xtendrmt/rmt-dom-descriptor-renderer.js +1066 -0
  544. package/xtendrmt/rmt-event-routing-runtime.d.ts +144 -0
  545. package/xtendrmt/rmt-event-routing-runtime.js +666 -0
  546. package/xtendrmt/rmt-lifecycle-demo.app.js +2 -2
  547. package/xtendrmt/rmt-lifecycle-demo.core.json +4 -0
  548. package/xtendrmt/rmt-lifecycle-demo.rmt-build.app.js +1 -1
  549. package/xtendrmt/rmt-lifecycle-demo.rmt-build.scaffold.json +2 -2
  550. package/xtendrmt/rmt-lifecycle-demo.scaffold.json +4 -4
  551. package/xtendrmt/rmt-native-shell-runtime.d.ts +77 -0
  552. package/xtendrmt/rmt-native-shell-runtime.js +309 -0
  553. package/xtendrmt/rmt-node-ssr-adapter.d.ts +197 -0
  554. package/xtendrmt/rmt-node-ssr-adapter.js +1006 -0
  555. package/xtendrmt/rmt-php-ssr-adapter.php +976 -0
  556. package/xtendrmt/rmt-runtime.browser.js +32 -6
  557. package/xtendrmt/rmt-runtime.esm.js +32 -6
  558. package/xtendrmt/rmt-state-selector-runtime.d.ts +166 -0
  559. package/xtendrmt/rmt-state-selector-runtime.js +866 -0
  560. package/xtendrmt/rmt-surface-resource-graph-runtime.d.ts +224 -0
  561. package/xtendrmt/rmt-surface-resource-graph-runtime.js +932 -0
  562. package/xtendrmt/rmt-vnext-enterprise-mfe-demo.core.json +3 -0
  563. package/xtendrmt/rmt-vnext-reference-demo.core.json +3 -0
  564. package/xtendrmt/xtendrmt-bestcase-demo.core.json +3420 -372
  565. package/xtendrmt/xtendrmt-bestcase-demo.js +424 -8
  566. package/xtendrmt/xtendrmt-bestcase-demo.rmt +214 -6
@@ -0,0 +1,285 @@
1
+ class XSurfaceRegion extends HTMLElement {
2
+ static get observedAttributes() {
3
+ return [
4
+ 'surface-id',
5
+ 'label',
6
+ 'kind',
7
+ 'open',
8
+ 'active',
9
+ 'hidden',
10
+ 'mode',
11
+ 'placement',
12
+ 'initial-x',
13
+ 'initial-y',
14
+ 'initial-width',
15
+ 'initial-height',
16
+ 'role'
17
+ ];
18
+ }
19
+
20
+ static get xtendComponentContract() {
21
+ return {
22
+ schema: 'xtend.component.contract.v2',
23
+ tag: 'x-surface-region',
24
+ maturity: 'experimental',
25
+ source: {
26
+ strategy: 'xtend.legacy-esm.component-source',
27
+ state: 'js-runtime',
28
+ sourcePath: 'components/xsurfaceregion.js'
29
+ },
30
+ runtime: {
31
+ format: 'esm',
32
+ artifact: 'components/xsurfaceregion.js',
33
+ declaration: 'components/xsurfaceregion.d.ts',
34
+ localOnly: true,
35
+ cdnAllowed: false
36
+ },
37
+ rmt: {
38
+ adapter: 'xtend.component',
39
+ surfaceContract: 'xtend.surface.record.v1',
40
+ kernelBoundary: 'no-rmt-kernel-import-of-xtend-types'
41
+ },
42
+ fabric: {
43
+ api: '@xtend-fabric',
44
+ defaultLane: 'visible',
45
+ diagnosticsLane: 'diagnostics'
46
+ }
47
+ };
48
+ }
49
+
50
+ static get xtendRmtMetadata() {
51
+ return {
52
+ schema: 'xtend.rmt.component-contract.v1',
53
+ adapter: 'xtend.component',
54
+ tag: 'x-surface-region',
55
+ componentRecordKind: 'custom_element',
56
+ templateMode: 'dom_descriptor',
57
+ eventBindingMode: 'dom-event-to-rmt-command',
58
+ schedules: ['surface.visible.render', 'surface.user-blocking.open', 'surface.transition.layout', 'surface.diagnostics.snapshot'],
59
+ hydration: { policy: 'visible', lane: 'visible' },
60
+ surface: {
61
+ schema: 'xtend.surface.record.v1',
62
+ type: 'region',
63
+ kinds: ['root', 'workspace', 'page', 'card', 'list', 'region', 'overlay-host'],
64
+ controller: 'xtend.surface.controller.v1'
65
+ },
66
+ kernelBoundary: 'no-rmt-kernel-import-of-xtend-types'
67
+ };
68
+ }
69
+
70
+ static get xtendScaffoldPerformanceProfile() {
71
+ return {
72
+ schema: 'xtend.performance.component-profile.v1',
73
+ budgetClass: 'surface-content',
74
+ lane: 'surface.region.visible',
75
+ hydrationPolicy: 'visible',
76
+ measurements: ['surface-record-sync', 'bounds-application', 'command-dispatch']
77
+ };
78
+ }
79
+
80
+ constructor() {
81
+ super();
82
+ this.surfaceManager = null;
83
+ this._applyingSnapshot = false;
84
+ this._onPointerDown = this.focusRegion.bind(this);
85
+ this.attachShadow({ mode: 'open' });
86
+ this.shadowRoot.innerHTML = `
87
+ <style>
88
+ :host {
89
+ --surface-region-x: 0px;
90
+ --surface-region-y: 0px;
91
+ --surface-region-width: auto;
92
+ --surface-region-height: auto;
93
+ --surface-region-z: 0;
94
+ display: block;
95
+ position: relative;
96
+ min-width: 0;
97
+ min-height: 0;
98
+ z-index: var(--surface-region-z);
99
+ box-sizing: border-box;
100
+ }
101
+ :host([mode="floating"]) {
102
+ position: absolute;
103
+ left: var(--surface-region-x);
104
+ top: var(--surface-region-y);
105
+ width: var(--surface-region-width);
106
+ height: var(--surface-region-height);
107
+ }
108
+ :host([hidden]),
109
+ :host(:not([open])) {
110
+ display: none;
111
+ }
112
+ :host([active]) {
113
+ outline: var(--surface-region-active-outline, 0);
114
+ }
115
+ .region {
116
+ box-sizing: border-box;
117
+ min-width: 0;
118
+ min-height: 0;
119
+ width: 100%;
120
+ height: 100%;
121
+ }
122
+ :host(:not([mode="floating"])) .region {
123
+ width: auto;
124
+ height: auto;
125
+ }
126
+ </style>
127
+ <section class="region" part="region" tabindex="-1">
128
+ <slot></slot>
129
+ </section>
130
+ `;
131
+ this._region = this.shadowRoot.querySelector('.region');
132
+ }
133
+
134
+ connectedCallback() {
135
+ if (!this.hasAttribute('surface-id') && this.id) this.setAttribute('surface-id', this.id);
136
+ if (!this.hasAttribute('kind')) this.setAttribute('kind', this.getAttribute('data-surface-kind') || 'region');
137
+ if (!this.hasAttribute('open') && !this.hasAttribute('hidden')) this.setAttribute('open', '');
138
+ this._syncA11y();
139
+ this._applyInitialBounds();
140
+ this.addEventListener('pointerdown', this._onPointerDown);
141
+ this.surfaceManager = this.closest('x-surface-manager');
142
+ if (this.surfaceManager && typeof this.surfaceManager.registerSurface === 'function') {
143
+ this.surfaceManager.registerSurface(this);
144
+ }
145
+ }
146
+
147
+ disconnectedCallback() {
148
+ this.removeEventListener('pointerdown', this._onPointerDown);
149
+ }
150
+
151
+ attributeChangedCallback(name, oldValue, newValue) {
152
+ if (oldValue === newValue) return;
153
+ if (name === 'label' || name === 'surface-id' || name === 'role') this._syncA11y();
154
+ if (name.startsWith('initial-')) this._applyInitialBounds();
155
+ if (this._applyingSnapshot || !this.isConnected) return;
156
+ if (name === 'open') {
157
+ this.hasAttribute('open') ? this.openRegion() : this.closeRegion('attribute');
158
+ }
159
+ }
160
+
161
+ get surfaceId() {
162
+ return this.getAttribute('surface-id') || this.id || 'surface.region';
163
+ }
164
+
165
+ get kind() {
166
+ return this.getAttribute('kind') || this.getAttribute('data-surface-kind') || 'region';
167
+ }
168
+
169
+ get open() {
170
+ return this.hasAttribute('open') && !this.hasAttribute('hidden');
171
+ }
172
+
173
+ set open(value) {
174
+ this.toggleAttribute('open', Boolean(value));
175
+ this.toggleAttribute('hidden', !value);
176
+ }
177
+
178
+ toSurfaceRecord(managerId) {
179
+ const mode = this.getAttribute('mode') || 'region';
180
+ return {
181
+ schema: 'xtend.surface.record.v1',
182
+ id: this.surfaceId,
183
+ type: 'region',
184
+ kind: this.kind,
185
+ manager: managerId,
186
+ label: this.getAttribute('label') || this.surfaceId,
187
+ placement: this.getAttribute('placement') || null,
188
+ mode,
189
+ initialBounds: this._readBounds(),
190
+ capabilities: ['open', 'focus', 'close', 'update', 'restore', 'snapshot'],
191
+ defaultOpen: this.open,
192
+ modal: false,
193
+ metadata: {
194
+ source: 'x-surface-region',
195
+ surfaceKind: this.kind
196
+ }
197
+ };
198
+ }
199
+
200
+ applySurfaceSnapshot(record) {
201
+ this._applyingSnapshot = true;
202
+ const bounds = record.bounds || this._readBounds();
203
+ this.style.setProperty('--surface-region-x', `${Number(bounds.x) || 0}px`);
204
+ this.style.setProperty('--surface-region-y', `${Number(bounds.y) || 0}px`);
205
+ this.style.setProperty('--surface-region-width', `${Number(bounds.width) || 640}px`);
206
+ this.style.setProperty('--surface-region-height', `${Number(bounds.height) || 360}px`);
207
+ this.style.setProperty('--surface-region-z', String(record.zIndex || 0));
208
+ this.toggleAttribute('open', record.status !== 'closed');
209
+ this.toggleAttribute('hidden', record.status === 'closed');
210
+ this.toggleAttribute('active', Boolean(record.active));
211
+ if (record.kind) this.setAttribute('kind', record.kind);
212
+ if (record.mode) this.setAttribute('mode', record.mode);
213
+ if (record.placement) this.setAttribute('placement', record.placement);
214
+ this._syncA11y(record);
215
+ this._applyingSnapshot = false;
216
+ }
217
+
218
+ openRegion() {
219
+ return this._command('open');
220
+ }
221
+
222
+ closeRegion(reason) {
223
+ return this._command('close', { reason });
224
+ }
225
+
226
+ focusRegion() {
227
+ return this._command('focus');
228
+ }
229
+
230
+ restoreRegion() {
231
+ return this._command('restore');
232
+ }
233
+
234
+ updateRegion(payload = {}) {
235
+ return this._command('update', payload);
236
+ }
237
+
238
+ _readBounds() {
239
+ return {
240
+ x: Number(this.getAttribute('initial-x') || 0),
241
+ y: Number(this.getAttribute('initial-y') || 0),
242
+ width: Number(this.getAttribute('initial-width') || 640),
243
+ height: Number(this.getAttribute('initial-height') || 360),
244
+ minWidth: 160,
245
+ minHeight: 96
246
+ };
247
+ }
248
+
249
+ _applyInitialBounds() {
250
+ const bounds = this._readBounds();
251
+ this.style.setProperty('--surface-region-x', `${bounds.x}px`);
252
+ this.style.setProperty('--surface-region-y', `${bounds.y}px`);
253
+ this.style.setProperty('--surface-region-width', `${bounds.width}px`);
254
+ this.style.setProperty('--surface-region-height', `${bounds.height}px`);
255
+ }
256
+
257
+ _syncA11y(record = null) {
258
+ if (!this._region) return;
259
+ const label = this.getAttribute('label') || this.surfaceId;
260
+ const role = this.getAttribute('role') || (this.kind === 'page' ? 'main' : 'region');
261
+ this._region.setAttribute('role', role);
262
+ this._region.setAttribute('aria-label', label);
263
+ this._region.setAttribute('aria-hidden', record && record.status === 'closed' || this.hasAttribute('hidden') ? 'true' : 'false');
264
+ }
265
+
266
+ _command(command, payload = {}) {
267
+ const detail = {
268
+ surfaceId: this.surfaceId,
269
+ command,
270
+ payload
271
+ };
272
+ this.dispatchEvent(new CustomEvent('surface-region-command', {
273
+ bubbles: true,
274
+ composed: true,
275
+ detail
276
+ }));
277
+ return detail;
278
+ }
279
+ }
280
+
281
+ if (!customElements.get('x-surface-region')) {
282
+ customElements.define('x-surface-region', XSurfaceRegion);
283
+ }
284
+
285
+ export { XSurfaceRegion };
@@ -246,7 +246,8 @@ class XSurfaceWindow extends HTMLElement {
246
246
  .content {
247
247
  flex: 1;
248
248
  min-height: 0;
249
- overflow: auto;
249
+ overflow-y: auto;
250
+ overflow-x: hidden;
250
251
  padding: var(--surface-window-content-padding, 1rem);
251
252
  }
252
253
  .resize {
@@ -139,7 +139,7 @@ class XTooltip extends HTMLElement {
139
139
  escapeBehavior: 'dismiss-visible-tooltip',
140
140
  outsideClick: 'anchor-blur-or-hover-leave',
141
141
  scrollLock: 'not-applicable',
142
- portalStrategy: 'anchor-local-layer',
142
+ portalStrategy: 'viewport-fixed-layer',
143
143
  events: ['tooltip-opened', 'tooltip-closed'],
144
144
  commands: ['show', 'hide', 'toggle', 'snapshot'],
145
145
  stateKey: 'xtooltip-open-<id>',
@@ -157,7 +157,8 @@ class XTooltip extends HTMLElement {
157
157
  overlaySemantics: {
158
158
  escapeDismissesVisibleTooltip: true,
159
159
  describedbyRequired: true,
160
- anchorLocalPortal: true
160
+ anchorLocalPortal: false,
161
+ viewportFixedLayer: true
161
162
  }
162
163
  };
163
164
  }
@@ -168,12 +169,14 @@ class XTooltip extends HTMLElement {
168
169
  this._open = false;
169
170
  this._showTimer = 0;
170
171
  this._hideTimer = 0;
172
+ this._positionFrame = 0;
171
173
  this._unsubscribeState = null;
172
174
  this._synchronizingAttribute = false;
173
175
  this._onAnchorEnter = () => this.show({ source: 'anchor' });
174
176
  this._onAnchorLeave = () => this.hide({ source: 'anchor' });
175
177
  this._onAnchorFocus = () => this.show({ source: 'focus' });
176
178
  this._onAnchorBlur = () => this.hide({ source: 'blur' });
179
+ this._onViewportChange = () => this._schedulePositionUpdate();
177
180
  this._onKeyDown = this._handleKeyDown.bind(this);
178
181
  this.attachShadow({ mode: 'open' });
179
182
  this.shadowRoot.innerHTML = `
@@ -201,9 +204,15 @@ class XTooltip extends HTMLElement {
201
204
  display: none;
202
205
  }
203
206
  .tooltip {
204
- position: absolute;
207
+ position: fixed;
208
+ top: var(--xtooltip-top, -9999px);
209
+ left: var(--xtooltip-left, -9999px);
210
+ right: auto;
211
+ bottom: auto;
205
212
  z-index: var(--xtend-overlay-z);
206
- max-width: min(18rem, 80vw);
213
+ box-sizing: border-box;
214
+ width: max-content;
215
+ max-width: min(18rem, calc(100vw - 1rem));
207
216
  padding: 0.5rem 0.625rem;
208
217
  border-radius: var(--xtooltip-radius);
209
218
  background: var(--xtooltip-bg);
@@ -221,41 +230,30 @@ class XTooltip extends HTMLElement {
221
230
  pointer-events: auto;
222
231
  }
223
232
  :host([placement="bottom"]) .tooltip {
224
- top: calc(100% + 0.5rem);
225
- left: 50%;
226
- transform: translate(-50%, 2px);
233
+ transform: translateY(2px);
227
234
  }
228
235
  :host([placement="bottom"][open]) .tooltip {
229
- transform: translate(-50%, 0);
236
+ transform: translateY(0);
230
237
  }
231
238
  :host([placement="top"]) .tooltip,
232
239
  .tooltip {
233
- bottom: calc(100% + 0.5rem);
234
- left: 50%;
235
- transform: translate(-50%, 2px);
240
+ transform: translateY(-2px);
236
241
  }
237
242
  :host([placement="top"][open]) .tooltip,
238
243
  :host([open]) .tooltip {
239
- transform: translate(-50%, 0);
244
+ transform: translateY(0);
240
245
  }
241
246
  :host([placement="left"]) .tooltip {
242
- right: calc(100% + 0.5rem);
243
- top: 50%;
244
- bottom: auto;
245
- left: auto;
246
- transform: translate(-2px, -50%);
247
+ transform: translateX(-2px);
247
248
  }
248
249
  :host([placement="left"][open]) .tooltip {
249
- transform: translate(0, -50%);
250
+ transform: translateX(0);
250
251
  }
251
252
  :host([placement="right"]) .tooltip {
252
- left: calc(100% + 0.5rem);
253
- top: 50%;
254
- bottom: auto;
255
- transform: translate(2px, -50%);
253
+ transform: translateX(2px);
256
254
  }
257
255
  :host([placement="right"][open]) .tooltip {
258
- transform: translate(0, -50%);
256
+ transform: translateX(0);
259
257
  }
260
258
  .tooltip:focus-visible {
261
259
  outline: 2px solid currentColor;
@@ -310,6 +308,12 @@ class XTooltip extends HTMLElement {
310
308
  if (this._unsubscribeState) this._unsubscribeState();
311
309
  window.clearTimeout(this._showTimer);
312
310
  window.clearTimeout(this._hideTimer);
311
+ window.removeEventListener('resize', this._onViewportChange);
312
+ window.removeEventListener('scroll', this._onViewportChange, true);
313
+ if (this._positionFrame) {
314
+ window.cancelAnimationFrame(this._positionFrame);
315
+ this._positionFrame = 0;
316
+ }
313
317
  }
314
318
 
315
319
  attributeChangedCallback(name, oldValue, newValue) {
@@ -323,6 +327,9 @@ class XTooltip extends HTMLElement {
323
327
  if (name === 'label') {
324
328
  this._tooltip.setAttribute('aria-label', this.label);
325
329
  }
330
+ if (name === 'placement' && this.isConnected && this.open) {
331
+ this._schedulePositionUpdate();
332
+ }
326
333
  }
327
334
 
328
335
  get open() {
@@ -383,11 +390,22 @@ class XTooltip extends HTMLElement {
383
390
 
384
391
  _setOpen(isOpen, source) {
385
392
  if (this._open === isOpen) return;
393
+ if (isOpen) {
394
+ this._updatePosition();
395
+ }
386
396
  this._open = isOpen;
387
397
  this._synchronizingAttribute = true;
388
398
  this.toggleAttribute('open', isOpen);
389
399
  this._synchronizingAttribute = false;
390
400
  this._tooltip.setAttribute('aria-hidden', isOpen ? 'false' : 'true');
401
+ if (isOpen) {
402
+ window.addEventListener('resize', this._onViewportChange);
403
+ window.addEventListener('scroll', this._onViewportChange, true);
404
+ this._schedulePositionUpdate();
405
+ } else {
406
+ window.removeEventListener('resize', this._onViewportChange);
407
+ window.removeEventListener('scroll', this._onViewportChange, true);
408
+ }
391
409
  xstate.set(`xtooltip-open-${this.id}`, isOpen);
392
410
  this.dispatchEvent(new CustomEvent(isOpen ? 'tooltip-opened' : 'tooltip-closed', {
393
411
  detail: { id: this.id, open: isOpen, source, placement: this.getAttribute('placement') || 'top' },
@@ -406,6 +424,9 @@ class XTooltip extends HTMLElement {
406
424
  this._anchor.addEventListener('focus', this._onAnchorFocus);
407
425
  this._anchor.addEventListener('blur', this._onAnchorBlur);
408
426
  this._anchor.setAttribute('aria-describedby', this._tooltip.id);
427
+ if (this.open) {
428
+ this._schedulePositionUpdate();
429
+ }
409
430
  }
410
431
 
411
432
  _unbindAnchor() {
@@ -425,6 +446,51 @@ class XTooltip extends HTMLElement {
425
446
  this.hide({ source: 'escape', immediate: true });
426
447
  }
427
448
  }
449
+
450
+ _schedulePositionUpdate() {
451
+ if (!this.open || this._positionFrame) return;
452
+ this._positionFrame = window.requestAnimationFrame(() => {
453
+ this._positionFrame = 0;
454
+ this._updatePosition();
455
+ });
456
+ }
457
+
458
+ _updatePosition() {
459
+ const anchor = this._anchor || this.shadowRoot.querySelector('.trigger');
460
+ if (!anchor || !this._tooltip) return;
461
+
462
+ const anchorRect = anchor.getBoundingClientRect();
463
+ if (!anchorRect.width && !anchorRect.height) return;
464
+
465
+ const tooltipRect = this._tooltip.getBoundingClientRect();
466
+ const width = tooltipRect.width || this._tooltip.offsetWidth;
467
+ const height = tooltipRect.height || this._tooltip.offsetHeight;
468
+ if (!width || !height) return;
469
+
470
+ const gap = 8;
471
+ const margin = 8;
472
+ const placement = this.getAttribute('placement') || 'top';
473
+ let left = anchorRect.left + (anchorRect.width / 2) - (width / 2);
474
+ let top = anchorRect.top - height - gap;
475
+
476
+ if (placement === 'bottom') {
477
+ top = anchorRect.bottom + gap;
478
+ } else if (placement === 'left') {
479
+ left = anchorRect.left - width - gap;
480
+ top = anchorRect.top + (anchorRect.height / 2) - (height / 2);
481
+ } else if (placement === 'right') {
482
+ left = anchorRect.right + gap;
483
+ top = anchorRect.top + (anchorRect.height / 2) - (height / 2);
484
+ }
485
+
486
+ const maxLeft = Math.max(margin, window.innerWidth - width - margin);
487
+ const maxTop = Math.max(margin, window.innerHeight - height - margin);
488
+ const clampedLeft = Math.min(Math.max(left, margin), maxLeft);
489
+ const clampedTop = Math.min(Math.max(top, margin), maxTop);
490
+
491
+ this._tooltip.style.setProperty('--xtooltip-left', `${Math.round(clampedLeft)}px`);
492
+ this._tooltip.style.setProperty('--xtooltip-top', `${Math.round(clampedTop)}px`);
493
+ }
428
494
  }
429
495
 
430
496
  if (!customElements.get('x-tooltip')) {