This is page 174 of 181. Use http://codebase.md/xmlui-org/xmlui/tools/vscode/resources/%7BimageSrc%7D?lines=true&page={x} to view the full context. # Directory Structure ``` ├── .changeset │ └── config.json ├── .eslintrc.cjs ├── .github │ ├── build-checklist.png │ ├── ISSUE_TEMPLATE │ │ ├── bug_report.md │ │ └── feature_request.md │ └── workflows │ ├── deploy-blog.yml │ ├── deploy-docs-optimized.yml │ ├── deploy-docs.yml │ ├── prepare-versions.yml │ ├── release-packages.yml │ ├── run-all-tests.yml │ └── run-smoke-tests.yml ├── .gitignore ├── .prettierrc.js ├── .vscode │ ├── launch.json │ └── settings.json ├── blog │ ├── .gitignore │ ├── .gitkeep │ ├── CHANGELOG.md │ ├── extensions.ts │ ├── index.html │ ├── index.ts │ ├── layout-changes.md │ ├── package.json │ ├── public │ │ ├── blog │ │ │ ├── images │ │ │ │ ├── blog-page-component.png │ │ │ │ ├── blog-scrabble.png │ │ │ │ ├── integrated-blog-search.png │ │ │ │ └── lorem-ipsum.png │ │ │ ├── lorem-ipsum.md │ │ │ ├── newest-post.md │ │ │ ├── older-post.md │ │ │ └── welcome-to-the-xmlui-blog.md │ │ ├── mockServiceWorker.js │ │ ├── resources │ │ │ ├── favicon.ico │ │ │ ├── files │ │ │ │ └── for-download │ │ │ │ └── xmlui │ │ │ │ └── xmlui-standalone.umd.js │ │ │ ├── github.svg │ │ │ ├── llms.txt │ │ │ ├── logo-dark.svg │ │ │ ├── logo.svg │ │ │ ├── pg-popout.svg │ │ │ ├── rss.svg │ │ │ └── xmlui-logo.svg │ │ ├── serve.json │ │ └── web.config │ ├── scripts │ │ ├── download-latest-xmlui.js │ │ ├── generate-rss.js │ │ ├── get-releases.js │ │ └── utils.js │ ├── src │ │ ├── components │ │ │ ├── BlogOverview.xmlui │ │ │ ├── BlogPage.xmlui │ │ │ └── PageNotFound.xmlui │ │ ├── config.ts │ │ ├── Main.xmlui │ │ └── themes │ │ └── blog-theme.ts │ └── tsconfig.json ├── CONTRIBUTING.md ├── docs │ ├── .gitignore │ ├── CHANGELOG.md │ ├── ComponentRefLinks.txt │ ├── content │ │ ├── _meta.json │ │ ├── components │ │ │ ├── _meta.json │ │ │ ├── _overview.md │ │ │ ├── APICall.md │ │ │ ├── App.md │ │ │ ├── AppHeader.md │ │ │ ├── AppState.md │ │ │ ├── AutoComplete.md │ │ │ ├── Avatar.md │ │ │ ├── Backdrop.md │ │ │ ├── Badge.md │ │ │ ├── BarChart.md │ │ │ ├── Bookmark.md │ │ │ ├── Breakout.md │ │ │ ├── Button.md │ │ │ ├── Card.md │ │ │ ├── Carousel.md │ │ │ ├── ChangeListener.md │ │ │ ├── Checkbox.md │ │ │ ├── CHStack.md │ │ │ ├── ColorPicker.md │ │ │ ├── Column.md │ │ │ ├── ContentSeparator.md │ │ │ ├── CVStack.md │ │ │ ├── DataSource.md │ │ │ ├── DateInput.md │ │ │ ├── DatePicker.md │ │ │ ├── DonutChart.md │ │ │ ├── DropdownMenu.md │ │ │ ├── EmojiSelector.md │ │ │ ├── ExpandableItem.md │ │ │ ├── FileInput.md │ │ │ ├── FileUploadDropZone.md │ │ │ ├── FlowLayout.md │ │ │ ├── Footer.md │ │ │ ├── Form.md │ │ │ ├── FormItem.md │ │ │ ├── FormSection.md │ │ │ ├── Fragment.md │ │ │ ├── H1.md │ │ │ ├── H2.md │ │ │ ├── H3.md │ │ │ ├── H4.md │ │ │ ├── H5.md │ │ │ ├── H6.md │ │ │ ├── Heading.md │ │ │ ├── HSplitter.md │ │ │ ├── HStack.md │ │ │ ├── Icon.md │ │ │ ├── IFrame.md │ │ │ ├── Image.md │ │ │ ├── Items.md │ │ │ ├── LabelList.md │ │ │ ├── Legend.md │ │ │ ├── LineChart.md │ │ │ ├── Link.md │ │ │ ├── List.md │ │ │ ├── Logo.md │ │ │ ├── Markdown.md │ │ │ ├── MenuItem.md │ │ │ ├── MenuSeparator.md │ │ │ ├── ModalDialog.md │ │ │ ├── NavGroup.md │ │ │ ├── NavLink.md │ │ │ ├── NavPanel.md │ │ │ ├── NoResult.md │ │ │ ├── NumberBox.md │ │ │ ├── Option.md │ │ │ ├── Page.md │ │ │ ├── PageMetaTitle.md │ │ │ ├── Pages.md │ │ │ ├── Pagination.md │ │ │ ├── PasswordInput.md │ │ │ ├── PieChart.md │ │ │ ├── ProgressBar.md │ │ │ ├── Queue.md │ │ │ ├── RadioGroup.md │ │ │ ├── RealTimeAdapter.md │ │ │ ├── Redirect.md │ │ │ ├── Select.md │ │ │ ├── Slider.md │ │ │ ├── Slot.md │ │ │ ├── SpaceFiller.md │ │ │ ├── Spinner.md │ │ │ ├── Splitter.md │ │ │ ├── Stack.md │ │ │ ├── StickyBox.md │ │ │ ├── SubMenuItem.md │ │ │ ├── Switch.md │ │ │ ├── TabItem.md │ │ │ ├── Table.md │ │ │ ├── TableOfContents.md │ │ │ ├── Tabs.md │ │ │ ├── Text.md │ │ │ ├── TextArea.md │ │ │ ├── TextBox.md │ │ │ ├── Theme.md │ │ │ ├── TimeInput.md │ │ │ ├── Timer.md │ │ │ ├── ToneChangerButton.md │ │ │ ├── ToneSwitch.md │ │ │ ├── Tooltip.md │ │ │ ├── Tree.md │ │ │ ├── VSplitter.md │ │ │ ├── VStack.md │ │ │ ├── xmlui-animations │ │ │ │ ├── _meta.json │ │ │ │ ├── _overview.md │ │ │ │ ├── Animation.md │ │ │ │ ├── FadeAnimation.md │ │ │ │ ├── FadeInAnimation.md │ │ │ │ ├── FadeOutAnimation.md │ │ │ │ ├── ScaleAnimation.md │ │ │ │ └── SlideInAnimation.md │ │ │ ├── xmlui-pdf │ │ │ │ ├── _meta.json │ │ │ │ ├── _overview.md │ │ │ │ └── Pdf.md │ │ │ ├── xmlui-spreadsheet │ │ │ │ ├── _meta.json │ │ │ │ ├── _overview.md │ │ │ │ └── Spreadsheet.md │ │ │ └── xmlui-website-blocks │ │ │ ├── _meta.json │ │ │ ├── _overview.md │ │ │ ├── Carousel.md │ │ │ ├── HelloMd.md │ │ │ ├── HeroSection.md │ │ │ └── ScrollToTop.md │ │ └── extensions │ │ ├── _meta.json │ │ ├── xmlui-animations │ │ │ ├── _meta.json │ │ │ ├── _overview.md │ │ │ ├── Animation.md │ │ │ ├── FadeAnimation.md │ │ │ ├── FadeInAnimation.md │ │ │ ├── FadeOutAnimation.md │ │ │ ├── ScaleAnimation.md │ │ │ └── SlideInAnimation.md │ │ └── xmlui-website-blocks │ │ ├── _meta.json │ │ ├── _overview.md │ │ ├── Carousel.md │ │ ├── HelloMd.md │ │ ├── HeroSection.md │ │ └── ScrollToTop.md │ ├── extensions.ts │ ├── index.html │ ├── index.ts │ ├── package.json │ ├── public │ │ ├── feed.rss │ │ ├── mockServiceWorker.js │ │ ├── pages │ │ │ ├── _meta.json │ │ │ ├── app-structure.md │ │ │ ├── build-editor-component.md │ │ │ ├── build-hello-world-component.md │ │ │ ├── components-intro.md │ │ │ ├── context-variables.md │ │ │ ├── forms.md │ │ │ ├── globals.md │ │ │ ├── glossary.md │ │ │ ├── helper-tags.md │ │ │ ├── hosted-deployment.md │ │ │ ├── howto │ │ │ │ ├── assign-a-complex-json-literal-to-a-component-variable.md │ │ │ │ ├── chain-a-refetch.md │ │ │ │ ├── debug-a-component.md │ │ │ │ ├── delay-a-datasource-until-another-datasource-is-ready.md │ │ │ │ ├── delegate-a-method.md │ │ │ │ ├── do-custom-form-validation.md │ │ │ │ ├── expose-a-method-from-a-component.md │ │ │ │ ├── filter-and-transform-data-from-an-api.md │ │ │ │ ├── group-items-in-list-by-a-property.md │ │ │ │ ├── handle-background-operations.md │ │ │ │ ├── hide-an-element-until-its-datasource-is-ready.md │ │ │ │ ├── make-a-set-of-equal-width-cards.md │ │ │ │ ├── make-a-table-responsive.md │ │ │ │ ├── make-navpanel-width-responsive.md │ │ │ │ ├── modify-a-value-reported-in-a-column.md │ │ │ │ ├── paginate-a-list.md │ │ │ │ ├── pass-data-to-a-modal-dialog.md │ │ │ │ ├── react-to-button-click-not-keystrokes.md │ │ │ │ ├── set-the-initial-value-of-a-select-from-fetched-data.md │ │ │ │ ├── share-a-modaldialog-across-components.md │ │ │ │ ├── sync-selections-between-table-and-list-views.md │ │ │ │ ├── update-ui-optimistically.md │ │ │ │ ├── use-built-in-form-validation.md │ │ │ │ └── use-the-same-modaldialog-to-add-or-edit.md │ │ │ ├── howto.md │ │ │ ├── intro.md │ │ │ ├── layout.md │ │ │ ├── markup.md │ │ │ ├── mcp.md │ │ │ ├── modal-dialogs.md │ │ │ ├── news-and-reviews.md │ │ │ ├── reactive-intro.md │ │ │ ├── refactoring.md │ │ │ ├── routing-and-links.md │ │ │ ├── samples │ │ │ │ ├── color-palette.xmlui │ │ │ │ ├── color-values.xmlui │ │ │ │ ├── shadow-sizes.xmlui │ │ │ │ ├── spacing-sizes.xmlui │ │ │ │ ├── swatch.xmlui │ │ │ │ ├── theme-gallery-brief.xmlui │ │ │ │ └── theme-gallery.xmlui │ │ │ ├── scoping.md │ │ │ ├── scripting.md │ │ │ ├── styles-and-themes │ │ │ │ ├── common-units.md │ │ │ │ ├── layout-props.md │ │ │ │ ├── theme-variable-defaults.md │ │ │ │ ├── theme-variables.md │ │ │ │ └── themes.md │ │ │ ├── template-properties.md │ │ │ ├── test.md │ │ │ ├── tutorial-01.md │ │ │ ├── tutorial-02.md │ │ │ ├── tutorial-03.md │ │ │ ├── tutorial-04.md │ │ │ ├── tutorial-05.md │ │ │ ├── tutorial-06.md │ │ │ ├── tutorial-07.md │ │ │ ├── tutorial-08.md │ │ │ ├── tutorial-09.md │ │ │ ├── tutorial-10.md │ │ │ ├── tutorial-11.md │ │ │ ├── tutorial-12.md │ │ │ ├── universal-properties.md │ │ │ ├── user-defined-components.md │ │ │ ├── vscode.md │ │ │ ├── working-with-markdown.md │ │ │ ├── working-with-text.md │ │ │ ├── xmlui-animations │ │ │ │ ├── _meta.json │ │ │ │ ├── _overview.md │ │ │ │ ├── Animation.md │ │ │ │ ├── FadeAnimation.md │ │ │ │ ├── FadeInAnimation.md │ │ │ │ ├── FadeOutAnimation.md │ │ │ │ ├── ScaleAnimation.md │ │ │ │ └── SlideInAnimation.md │ │ │ ├── xmlui-charts │ │ │ │ ├── _meta.json │ │ │ │ ├── _overview.md │ │ │ │ ├── BarChart.md │ │ │ │ ├── DonutChart.md │ │ │ │ ├── LabelList.md │ │ │ │ ├── Legend.md │ │ │ │ ├── LineChart.md │ │ │ │ └── PieChart.md │ │ │ ├── xmlui-pdf │ │ │ │ ├── _meta.json │ │ │ │ ├── _overview.md │ │ │ │ └── Pdf.md │ │ │ └── xmlui-spreadsheet │ │ │ ├── _meta.json │ │ │ ├── _overview.md │ │ │ └── Spreadsheet.md │ │ ├── resources │ │ │ ├── devdocs │ │ │ │ ├── debug-proxy-object-2.png │ │ │ │ ├── debug-proxy-object.png │ │ │ │ ├── table_editor_01.png │ │ │ │ ├── table_editor_02.png │ │ │ │ ├── table_editor_03.png │ │ │ │ ├── table_editor_04.png │ │ │ │ ├── table_editor_05.png │ │ │ │ ├── table_editor_06.png │ │ │ │ ├── table_editor_07.png │ │ │ │ ├── table_editor_08.png │ │ │ │ ├── table_editor_09.png │ │ │ │ ├── table_editor_10.png │ │ │ │ ├── table_editor_11.png │ │ │ │ ├── table-editor-01.png │ │ │ │ ├── table-editor-02.png │ │ │ │ ├── table-editor-03.png │ │ │ │ ├── table-editor-04.png │ │ │ │ ├── table-editor-06.png │ │ │ │ ├── table-editor-07.png │ │ │ │ ├── table-editor-08.png │ │ │ │ ├── table-editor-09.png │ │ │ │ └── xmlui-rendering-of-tiptap-markdown.png │ │ │ ├── favicon.ico │ │ │ ├── files │ │ │ │ ├── clients.json │ │ │ │ ├── daily-revenue.json │ │ │ │ ├── dashboard-stats.json │ │ │ │ ├── demo.xmlui │ │ │ │ ├── demo.xmlui.xs │ │ │ │ ├── downloads │ │ │ │ │ └── downloads.json │ │ │ │ ├── for-download │ │ │ │ │ ├── index-with-api.html │ │ │ │ │ ├── index.html │ │ │ │ │ ├── mockApi.js │ │ │ │ │ ├── start-darwin.sh │ │ │ │ │ ├── start-linux.sh │ │ │ │ │ ├── start.bat │ │ │ │ │ └── xmlui │ │ │ │ │ └── xmlui-standalone.umd.js │ │ │ │ ├── getting-started │ │ │ │ │ ├── cl-tutorial-final.zip │ │ │ │ │ ├── cl-tutorial.zip │ │ │ │ │ ├── cl-tutorial2.zip │ │ │ │ │ ├── cl-tutorial3.zip │ │ │ │ │ ├── cl-tutorial4.zip │ │ │ │ │ ├── cl-tutorial5.zip │ │ │ │ │ ├── cl-tutorial6.zip │ │ │ │ │ ├── getting-started.zip │ │ │ │ │ ├── hello-xmlui.zip │ │ │ │ │ ├── xmlui-empty.zip │ │ │ │ │ └── xmlui-starter.zip │ │ │ │ ├── howto │ │ │ │ │ └── component-icons │ │ │ │ │ └── up-arrow.svg │ │ │ │ ├── invoices.json │ │ │ │ ├── monthly-status.json │ │ │ │ ├── news-and-reviews.json │ │ │ │ ├── products.json │ │ │ │ ├── releases.json │ │ │ │ ├── tutorials │ │ │ │ │ ├── datasource │ │ │ │ │ │ └── api.ts │ │ │ │ │ └── p2do │ │ │ │ │ ├── api.ts │ │ │ │ │ └── todo-logo.svg │ │ │ │ └── xmlui.json │ │ │ ├── github.svg │ │ │ ├── images │ │ │ │ ├── apiaction-tutorial │ │ │ │ │ ├── add-success.png │ │ │ │ │ ├── apiaction-param.png │ │ │ │ │ ├── change-completed.png │ │ │ │ │ ├── change-in-progress.png │ │ │ │ │ ├── confirm-delete.png │ │ │ │ │ ├── data-error.png │ │ │ │ │ ├── data-progress.png │ │ │ │ │ ├── data-success.png │ │ │ │ │ ├── display-1.png │ │ │ │ │ ├── item-deleted.png │ │ │ │ │ ├── item-updated.png │ │ │ │ │ ├── missing-api-key.png │ │ │ │ │ ├── new-item-added.png │ │ │ │ │ └── test-message.png │ │ │ │ ├── chat-api │ │ │ │ │ └── domain-model.svg │ │ │ │ ├── components │ │ │ │ │ ├── image │ │ │ │ │ │ └── breakfast.jpg │ │ │ │ │ ├── markdown │ │ │ │ │ │ └── colors.png │ │ │ │ │ └── modal │ │ │ │ │ ├── deep_link_dialog_1.jpg │ │ │ │ │ └── deep_link_dialog_2.jpg │ │ │ │ ├── create-apps │ │ │ │ │ ├── collapsed-vertical.png │ │ │ │ │ ├── using-forms-warning-dialog.png │ │ │ │ │ └── using-forms.png │ │ │ │ ├── datasource-tutorial │ │ │ │ │ ├── data-with-header.png │ │ │ │ │ ├── filtered-data.png │ │ │ │ │ ├── filtered-items.png │ │ │ │ │ ├── initial-page-items.png │ │ │ │ │ ├── list-items.png │ │ │ │ │ ├── next-page-items.png │ │ │ │ │ ├── no-data.png │ │ │ │ │ ├── pagination-1.jpg │ │ │ │ │ ├── pagination-1.png │ │ │ │ │ ├── polling-1.png │ │ │ │ │ ├── refetch-data.png │ │ │ │ │ ├── slow-loading.png │ │ │ │ │ ├── test-message.png │ │ │ │ │ ├── Thumbs.db │ │ │ │ │ ├── unconventional-data.png │ │ │ │ │ └── unfiltered-items.png │ │ │ │ ├── flower.jpg │ │ │ │ ├── get-started │ │ │ │ │ ├── add-new-contact.png │ │ │ │ │ ├── app-modified.png │ │ │ │ │ ├── app-start.png │ │ │ │ │ ├── app-with-boxes.png │ │ │ │ │ ├── app-with-toast.png │ │ │ │ │ ├── boilerplate-structure.png │ │ │ │ │ ├── cl-initial.png │ │ │ │ │ ├── cl-start.png │ │ │ │ │ ├── contact-counts.png │ │ │ │ │ ├── contact-dialog-title.png │ │ │ │ │ ├── contact-dialog.png │ │ │ │ │ ├── contact-menus.png │ │ │ │ │ ├── contact-predicates.png │ │ │ │ │ ├── context-menu.png │ │ │ │ │ ├── dashboard-numbers.png │ │ │ │ │ ├── default-contact-list.png │ │ │ │ │ ├── delete-contact.png │ │ │ │ │ ├── delete-task.png │ │ │ │ │ ├── detailed-template.png │ │ │ │ │ ├── edit-contact-details.png │ │ │ │ │ ├── edited-contact-saved.png │ │ │ │ │ ├── empty-sections.png │ │ │ │ │ ├── filter-completed.png │ │ │ │ │ ├── fullwidth-desktop.png │ │ │ │ │ ├── fullwidth-mobile.png │ │ │ │ │ ├── initial-table.png │ │ │ │ │ ├── items-and-badges.png │ │ │ │ │ ├── loading-message.png │ │ │ │ │ ├── new-contact-button.png │ │ │ │ │ ├── new-contact-saved.png │ │ │ │ │ ├── no-empty-sections.png │ │ │ │ │ ├── personal-todo-initial.png │ │ │ │ │ ├── piechart.png │ │ │ │ │ ├── review-today.png │ │ │ │ │ ├── rudimentary-dashboard.png │ │ │ │ │ ├── section-collapsed.png │ │ │ │ │ ├── sectioned-items.png │ │ │ │ │ ├── sections-ordered.png │ │ │ │ │ ├── spacex-list-with-links.png │ │ │ │ │ ├── spacex-list.png │ │ │ │ │ ├── start-personal-todo-1.png │ │ │ │ │ ├── submit-new-contact.png │ │ │ │ │ ├── submit-new-task.png │ │ │ │ │ ├── syntax-highlighting.png │ │ │ │ │ ├── table-with-badge.png │ │ │ │ │ ├── template-with-card.png │ │ │ │ │ ├── test-emulated-api.png │ │ │ │ │ ├── Thumbs.db │ │ │ │ │ ├── todo-logo.png │ │ │ │ │ └── xmlui-tools.png │ │ │ │ ├── HelloApp.png │ │ │ │ ├── HelloApp2.png │ │ │ │ ├── logos │ │ │ │ │ ├── xmlui1.svg │ │ │ │ │ ├── xmlui2.svg │ │ │ │ │ ├── xmlui3.svg │ │ │ │ │ ├── xmlui4.svg │ │ │ │ │ ├── xmlui5.svg │ │ │ │ │ ├── xmlui6.svg │ │ │ │ │ └── xmlui7.svg │ │ │ │ ├── pdf │ │ │ │ │ └── dummy-pdf.jpg │ │ │ │ ├── rendering-engine │ │ │ │ │ ├── AppEngine-flow.svg │ │ │ │ │ ├── Component.svg │ │ │ │ │ ├── CompoundComponent.svg │ │ │ │ │ ├── RootComponent.svg │ │ │ │ │ └── tree-with-containers.svg │ │ │ │ ├── reviewers-guide │ │ │ │ │ ├── AppEngine-flow.svg │ │ │ │ │ └── incbutton-in-action.png │ │ │ │ ├── tools │ │ │ │ │ └── boilerplate-structure.png │ │ │ │ ├── try.svg │ │ │ │ ├── tutorial │ │ │ │ │ ├── app-chat-history.png │ │ │ │ │ ├── app-content-placeholder.png │ │ │ │ │ ├── app-header-and-content.png │ │ │ │ │ ├── app-links-channel-selected.png │ │ │ │ │ ├── app-links-click.png │ │ │ │ │ ├── app-navigation.png │ │ │ │ │ ├── finished-ex01.png │ │ │ │ │ ├── finished-ex02.png │ │ │ │ │ ├── hello.png │ │ │ │ │ ├── splash-screen-advanced.png │ │ │ │ │ ├── splash-screen-after-click.png │ │ │ │ │ ├── splash-screen-centered.png │ │ │ │ │ ├── splash-screen-events.png │ │ │ │ │ ├── splash-screen-expression.png │ │ │ │ │ ├── splash-screen-reuse-after.png │ │ │ │ │ ├── splash-screen-reuse-before.png │ │ │ │ │ └── splash-screen.png │ │ │ │ └── tutorial-01.png │ │ │ ├── llms.txt │ │ │ ├── logo-dark.svg │ │ │ ├── logo.svg │ │ │ ├── pg-popout.svg │ │ │ └── xmlui-logo.svg │ │ ├── serve.json │ │ └── web.config │ ├── scripts │ │ ├── download-latest-xmlui.js │ │ ├── generate-rss.js │ │ ├── get-releases.js │ │ └── utils.js │ ├── src │ │ ├── components │ │ │ ├── BlogOverview.xmlui │ │ │ ├── BlogPage.xmlui │ │ │ ├── Boxes.xmlui │ │ │ ├── Breadcrumb.xmlui │ │ │ ├── ChangeLog.xmlui │ │ │ ├── ColorPalette.xmlui │ │ │ ├── DocumentLinks.xmlui │ │ │ ├── DocumentPage.xmlui │ │ │ ├── DocumentPageNoTOC.xmlui │ │ │ ├── Icons.xmlui │ │ │ ├── IncButton.xmlui │ │ │ ├── IncButton2.xmlui │ │ │ ├── NameValue.xmlui │ │ │ ├── PageNotFound.xmlui │ │ │ ├── PaletteItem.xmlui │ │ │ ├── Palettes.xmlui │ │ │ ├── SectionHeader.xmlui │ │ │ ├── TBD.xmlui │ │ │ ├── Test.xmlui │ │ │ ├── ThemesIntro.xmlui │ │ │ ├── ThousandThemes.xmlui │ │ │ ├── TubeStops.xmlui │ │ │ ├── TubeStops.xmlui.xs │ │ │ └── TwoColumnCode.xmlui │ │ ├── config.ts │ │ ├── Main.xmlui │ │ └── themes │ │ ├── docs-theme.ts │ │ ├── earthtone.ts │ │ ├── xmlui-gray-on-default.ts │ │ ├── xmlui-green-on-default.ts │ │ └── xmlui-orange-on-default.ts │ └── tsconfig.json ├── LICENSE ├── package-lock.json ├── package.json ├── packages │ ├── xmlui-animations │ │ ├── .gitignore │ │ ├── CHANGELOG.md │ │ ├── demo │ │ │ └── Main.xmlui │ │ ├── index.html │ │ ├── index.ts │ │ ├── meta │ │ │ └── componentsMetadata.ts │ │ ├── package.json │ │ ├── src │ │ │ ├── Animation.tsx │ │ │ ├── AnimationNative.tsx │ │ │ ├── FadeAnimation.tsx │ │ │ ├── FadeInAnimation.tsx │ │ │ ├── FadeOutAnimation.tsx │ │ │ ├── index.tsx │ │ │ ├── ScaleAnimation.tsx │ │ │ └── SlideInAnimation.tsx │ │ └── tsconfig.json │ ├── xmlui-devtools │ │ ├── .gitignore │ │ ├── CHANGELOG.md │ │ ├── demo │ │ │ └── Main.xmlui │ │ ├── index.html │ │ ├── index.ts │ │ ├── meta │ │ │ └── componentsMetadata.ts │ │ ├── package.json │ │ ├── src │ │ │ ├── devtools │ │ │ │ ├── DevTools.tsx │ │ │ │ ├── DevToolsNative.module.scss │ │ │ │ ├── DevToolsNative.tsx │ │ │ │ ├── ModalDialog.module.scss │ │ │ │ ├── ModalDialog.tsx │ │ │ │ ├── ModalVisibilityContext.tsx │ │ │ │ ├── Tooltip.module.scss │ │ │ │ ├── Tooltip.tsx │ │ │ │ └── utils.ts │ │ │ ├── editor │ │ │ │ └── Editor.tsx │ │ │ └── index.tsx │ │ ├── tsconfig.json │ │ └── vite.config-overrides.ts │ ├── xmlui-hello-world │ │ ├── .gitignore │ │ ├── index.ts │ │ ├── meta │ │ │ └── componentsMetadata.ts │ │ ├── package.json │ │ ├── src │ │ │ ├── HelloWorld.module.scss │ │ │ ├── HelloWorld.tsx │ │ │ ├── HelloWorldNative.tsx │ │ │ └── index.tsx │ │ └── tsconfig.json │ ├── xmlui-os-frames │ │ ├── .gitignore │ │ ├── demo │ │ │ └── Main.xmlui │ │ ├── index.html │ │ ├── index.ts │ │ ├── meta │ │ │ └── componentsMetadata.ts │ │ ├── package.json │ │ ├── src │ │ │ ├── index.tsx │ │ │ ├── IPhoneFrame.module.scss │ │ │ ├── IPhoneFrame.tsx │ │ │ ├── MacOSAppFrame.module.scss │ │ │ ├── MacOSAppFrame.tsx │ │ │ ├── WindowsAppFrame.module.scss │ │ │ └── WindowsAppFrame.tsx │ │ └── tsconfig.json │ ├── xmlui-pdf │ │ ├── .gitignore │ │ ├── CHANGELOG.md │ │ ├── demo │ │ │ ├── components │ │ │ │ └── Pdf.xmlui │ │ │ └── Main.xmlui │ │ ├── index.html │ │ ├── index.ts │ │ ├── meta │ │ │ └── componentsMetadata.ts │ │ ├── package.json │ │ ├── src │ │ │ ├── index.tsx │ │ │ ├── LazyPdfNative.tsx │ │ │ ├── Pdf.module.scss │ │ │ └── Pdf.tsx │ │ └── tsconfig.json │ ├── xmlui-playground │ │ ├── .gitignore │ │ ├── CHANGELOG.md │ │ ├── demo │ │ │ └── Main.xmlui │ │ ├── index.html │ │ ├── index.ts │ │ ├── meta │ │ │ └── componentsMetadata.ts │ │ ├── package.json │ │ ├── src │ │ │ ├── hooks │ │ │ │ ├── usePlayground.ts │ │ │ │ └── useToast.ts │ │ │ ├── index.tsx │ │ │ ├── playground │ │ │ │ ├── Box.module.scss │ │ │ │ ├── Box.tsx │ │ │ │ ├── CodeSelector.tsx │ │ │ │ ├── ConfirmationDialog.module.scss │ │ │ │ ├── ConfirmationDialog.tsx │ │ │ │ ├── Editor.tsx │ │ │ │ ├── Header.module.scss │ │ │ │ ├── Header.tsx │ │ │ │ ├── Playground.tsx │ │ │ │ ├── PlaygroundContent.module.scss │ │ │ │ ├── PlaygroundContent.tsx │ │ │ │ ├── PlaygroundNative.module.scss │ │ │ │ ├── PlaygroundNative.tsx │ │ │ │ ├── Preview.module.scss │ │ │ │ ├── Preview.tsx │ │ │ │ ├── Select.module.scss │ │ │ │ ├── StandalonePlayground.tsx │ │ │ │ ├── StandalonePlaygroundNative.module.scss │ │ │ │ ├── StandalonePlaygroundNative.tsx │ │ │ │ ├── ThemeSwitcher.module.scss │ │ │ │ ├── ThemeSwitcher.tsx │ │ │ │ ├── ToneSwitcher.tsx │ │ │ │ ├── Tooltip.module.scss │ │ │ │ ├── Tooltip.tsx │ │ │ │ └── utils.ts │ │ │ ├── providers │ │ │ │ ├── Toast.module.scss │ │ │ │ └── ToastProvider.tsx │ │ │ ├── state │ │ │ │ └── store.ts │ │ │ ├── themes │ │ │ │ └── theme.ts │ │ │ └── utils │ │ │ └── helpers.ts │ │ └── tsconfig.json │ ├── xmlui-search │ │ ├── .gitignore │ │ ├── CHANGELOG.md │ │ ├── demo │ │ │ └── Main.xmlui │ │ ├── index.html │ │ ├── index.ts │ │ ├── meta │ │ │ └── componentsMetadata.ts │ │ ├── package.json │ │ ├── src │ │ │ ├── index.tsx │ │ │ ├── Search.module.scss │ │ │ └── Search.tsx │ │ └── tsconfig.json │ ├── xmlui-spreadsheet │ │ ├── .gitignore │ │ ├── demo │ │ │ └── Main.xmlui │ │ ├── index.html │ │ ├── index.ts │ │ ├── meta │ │ │ └── componentsMetadata.ts │ │ ├── package.json │ │ ├── src │ │ │ ├── index.tsx │ │ │ ├── Spreadsheet.tsx │ │ │ └── SpreadsheetNative.tsx │ │ └── tsconfig.json │ └── xmlui-website-blocks │ ├── .gitignore │ ├── CHANGELOG.md │ ├── demo │ │ ├── components │ │ │ ├── HeroBackgroundBreakoutPage.xmlui │ │ │ ├── HeroBackgroundsPage.xmlui │ │ │ ├── HeroContentsPage.xmlui │ │ │ ├── HeroTextAlignPage.xmlui │ │ │ ├── HeroTextPage.xmlui │ │ │ └── HeroTonesPage.xmlui │ │ ├── Main.xmlui │ │ └── themes │ │ └── default.ts │ ├── index.html │ ├── index.ts │ ├── meta │ │ └── componentsMetadata.ts │ ├── package.json │ ├── public │ │ └── resources │ │ ├── building.jpg │ │ └── xmlui-logo.svg │ ├── src │ │ ├── Carousel │ │ │ ├── Carousel.module.scss │ │ │ ├── Carousel.tsx │ │ │ ├── CarouselContext.tsx │ │ │ └── CarouselNative.tsx │ │ ├── FancyButton │ │ │ ├── FancyButton.module.scss │ │ │ ├── FancyButton.tsx │ │ │ └── FancyButton.xmlui │ │ ├── Hello │ │ │ ├── Hello.tsx │ │ │ ├── Hello.xmlui │ │ │ └── Hello.xmlui.xs │ │ ├── HeroSection │ │ │ ├── HeroSection.module.scss │ │ │ ├── HeroSection.tsx │ │ │ └── HeroSectionNative.tsx │ │ ├── index.tsx │ │ ├── ScrollToTop │ │ │ ├── ScrollToTop.module.scss │ │ │ ├── ScrollToTop.tsx │ │ │ └── ScrollToTopNative.tsx │ │ └── vite-env.d.ts │ └── tsconfig.json ├── README.md ├── tools │ ├── codefence │ │ └── xmlui-code-fence-docs.md │ ├── create-app │ │ ├── .gitignore │ │ ├── CHANGELOG.md │ │ ├── create-app.ts │ │ ├── helpers │ │ │ ├── copy.ts │ │ │ ├── get-pkg-manager.ts │ │ │ ├── git.ts │ │ │ ├── install.ts │ │ │ ├── is-folder-empty.ts │ │ │ ├── is-writeable.ts │ │ │ ├── make-dir.ts │ │ │ └── validate-pkg.ts │ │ ├── index.ts │ │ ├── package.json │ │ ├── templates │ │ │ ├── default │ │ │ │ └── ts │ │ │ │ ├── gitignore │ │ │ │ ├── index.html │ │ │ │ ├── index.ts │ │ │ │ ├── public │ │ │ │ │ ├── mockServiceWorker.js │ │ │ │ │ ├── resources │ │ │ │ │ │ ├── favicon.ico │ │ │ │ │ │ └── xmlui-logo.svg │ │ │ │ │ └── serve.json │ │ │ │ └── src │ │ │ │ ├── components │ │ │ │ │ ├── ApiAware.xmlui │ │ │ │ │ ├── Home.xmlui │ │ │ │ │ ├── IncButton.xmlui │ │ │ │ │ └── PagePanel.xmlui │ │ │ │ ├── config.ts │ │ │ │ └── Main.xmlui │ │ │ ├── index.ts │ │ │ └── types.ts │ │ └── tsconfig.json │ ├── create-xmlui-hello-world │ │ ├── index.js │ │ └── package.json │ └── vscode │ ├── .gitignore │ ├── .vscode │ │ ├── launch.json │ │ └── tasks.json │ ├── .vscodeignore │ ├── build.sh │ ├── CHANGELOG.md │ ├── esbuild.js │ ├── eslint.config.mjs │ ├── formatter-docs.md │ ├── generate-test-sample.sh │ ├── LICENSE.md │ ├── package-lock.json │ ├── package.json │ ├── README.md │ ├── resources │ │ ├── xmlui-logo.png │ │ └── xmlui-markup-syntax-highlighting.png │ ├── src │ │ ├── extension.ts │ │ └── server.ts │ ├── syntaxes │ │ └── xmlui.tmLanguage.json │ ├── test-samples │ │ └── sample.xmlui │ ├── tsconfig.json │ └── tsconfig.tsbuildinfo ├── turbo.json └── xmlui ├── .gitignore ├── bin │ ├── bootstrap.js │ ├── build-lib.ts │ ├── build.ts │ ├── index.ts │ ├── preview.ts │ ├── start.ts │ ├── vite-xmlui-plugin.ts │ └── viteConfig.ts ├── CHANGELOG.md ├── conventions │ ├── component-qa-checklist.md │ ├── copilot-conventions.md │ ├── create-xmlui-components.md │ ├── mermaid.md │ ├── testing-conventions.md │ └── xmlui-in-a-nutshell.md ├── dev-docs │ ├── accessibility.md │ ├── build-system.md │ ├── build-xmlui.md │ ├── component-behaviors.md │ ├── components-with-options.md │ ├── containers.md │ ├── data-operations.md │ ├── glossary.md │ ├── index.md │ ├── next │ │ ├── component-dev-guide.md │ │ ├── configuration-management-enhancement-summary.md │ │ ├── documentation-scripts-refactoring-complete-summary.md │ │ ├── documentation-scripts-refactoring-plan.md │ │ ├── duplicate-pattern-extraction-summary.md │ │ ├── error-handling-standardization-summary.md │ │ ├── generating-component-reference.md │ │ ├── index.md │ │ ├── logging-consistency-implementation-summary.md │ │ ├── project-build.md │ │ ├── project-structure.md │ │ ├── theme-context.md │ │ ├── tiptap-design-considerations.md │ │ ├── working-with-code.md │ │ ├── xmlui-runtime-architecture │ │ └── xmlui-wcag-accessibility-report.md │ ├── react-fundamentals.md │ ├── release-method.md │ ├── standalone-app.md │ ├── ud-components.md │ └── xmlui-repo.md ├── package.json ├── playwright.config.ts ├── scripts │ ├── coverage-only.js │ ├── e2e-test-summary.js │ ├── generate-docs │ │ ├── build-downloads-map.mjs │ │ ├── build-pages-map.mjs │ │ ├── components-config.json │ │ ├── configuration-management.mjs │ │ ├── constants.mjs │ │ ├── create-theme-files.mjs │ │ ├── DocsGenerator.mjs │ │ ├── error-handling.mjs │ │ ├── extensions-config.json │ │ ├── folders.mjs │ │ ├── generate-summary-files.mjs │ │ ├── get-docs.mjs │ │ ├── input-handler.mjs │ │ ├── logger.mjs │ │ ├── logging-standards.mjs │ │ ├── MetadataProcessor.mjs │ │ ├── pattern-utilities.mjs │ │ └── utils.mjs │ ├── get-langserver-metadata.mjs │ ├── inline-links.mjs │ └── README-e2e-summary.md ├── src │ ├── abstractions │ │ ├── _conventions.md │ │ ├── ActionDefs.ts │ │ ├── AppContextDefs.ts │ │ ├── ComponentDefs.ts │ │ ├── ContainerDefs.ts │ │ ├── ExtensionDefs.ts │ │ ├── FunctionDefs.ts │ │ ├── RendererDefs.ts │ │ ├── scripting │ │ │ ├── BlockScope.ts │ │ │ ├── Compilation.ts │ │ │ ├── LogicalThread.ts │ │ │ ├── LoopScope.ts │ │ │ ├── modules.ts │ │ │ ├── ScriptParserError.ts │ │ │ ├── Token.ts │ │ │ ├── TryScope.ts │ │ │ └── TryScopeExp.ts │ │ └── ThemingDefs.ts │ ├── components │ │ ├── _conventions.md │ │ ├── abstractions.ts │ │ ├── Accordion │ │ │ ├── Accordion.md │ │ │ ├── Accordion.module.scss │ │ │ ├── Accordion.spec.ts │ │ │ ├── Accordion.tsx │ │ │ ├── AccordionContext.tsx │ │ │ ├── AccordionItem.tsx │ │ │ ├── AccordionItemNative.tsx │ │ │ └── AccordionNative.tsx │ │ ├── Animation │ │ │ └── AnimationNative.tsx │ │ ├── APICall │ │ │ ├── APICall.md │ │ │ ├── APICall.spec.ts │ │ │ ├── APICall.tsx │ │ │ └── APICallNative.tsx │ │ ├── App │ │ │ ├── App.md │ │ │ ├── App.module.scss │ │ │ ├── App.spec.ts │ │ │ ├── App.tsx │ │ │ ├── AppLayoutContext.ts │ │ │ ├── AppNative.tsx │ │ │ ├── AppStateContext.ts │ │ │ ├── doc-resources │ │ │ │ ├── condensed-sticky.xmlui │ │ │ │ ├── condensed.xmlui │ │ │ │ ├── horizontal-sticky.xmlui │ │ │ │ ├── horizontal.xmlui │ │ │ │ ├── vertical-full-header.xmlui │ │ │ │ ├── vertical-sticky.xmlui │ │ │ │ └── vertical.xmlui │ │ │ ├── IndexerContext.ts │ │ │ ├── LinkInfoContext.ts │ │ │ ├── SearchContext.tsx │ │ │ ├── Sheet.module.scss │ │ │ └── Sheet.tsx │ │ ├── AppHeader │ │ │ ├── AppHeader.md │ │ │ ├── AppHeader.module.scss │ │ │ ├── AppHeader.spec.ts │ │ │ ├── AppHeader.tsx │ │ │ └── AppHeaderNative.tsx │ │ ├── AppState │ │ │ ├── AppState.md │ │ │ ├── AppState.spec.ts │ │ │ ├── AppState.tsx │ │ │ └── AppStateNative.tsx │ │ ├── AutoComplete │ │ │ ├── AutoComplete.md │ │ │ ├── AutoComplete.module.scss │ │ │ ├── AutoComplete.spec.ts │ │ │ ├── AutoComplete.tsx │ │ │ ├── AutoCompleteContext.tsx │ │ │ └── AutoCompleteNative.tsx │ │ ├── Avatar │ │ │ ├── Avatar.md │ │ │ ├── Avatar.module.scss │ │ │ ├── Avatar.spec.ts │ │ │ ├── Avatar.tsx │ │ │ └── AvatarNative.tsx │ │ ├── Backdrop │ │ │ ├── Backdrop.md │ │ │ ├── Backdrop.module.scss │ │ │ ├── Backdrop.spec.ts │ │ │ ├── Backdrop.tsx │ │ │ └── BackdropNative.tsx │ │ ├── Badge │ │ │ ├── Badge.md │ │ │ ├── Badge.module.scss │ │ │ ├── Badge.spec.ts │ │ │ ├── Badge.tsx │ │ │ └── BadgeNative.tsx │ │ ├── Bookmark │ │ │ ├── Bookmark.md │ │ │ ├── Bookmark.module.scss │ │ │ ├── Bookmark.spec.ts │ │ │ ├── Bookmark.tsx │ │ │ └── BookmarkNative.tsx │ │ ├── Breakout │ │ │ ├── Breakout.module.scss │ │ │ ├── Breakout.spec.ts │ │ │ ├── Breakout.tsx │ │ │ └── BreakoutNative.tsx │ │ ├── Button │ │ │ ├── Button-style.spec.ts │ │ │ ├── Button.md │ │ │ ├── Button.module.scss │ │ │ ├── Button.spec.ts │ │ │ ├── Button.tsx │ │ │ └── ButtonNative.tsx │ │ ├── Card │ │ │ ├── Card.md │ │ │ ├── Card.module.scss │ │ │ ├── Card.spec.ts │ │ │ ├── Card.tsx │ │ │ └── CardNative.tsx │ │ ├── Carousel │ │ │ ├── Carousel.md │ │ │ ├── Carousel.module.scss │ │ │ ├── Carousel.spec.ts │ │ │ ├── Carousel.tsx │ │ │ ├── CarouselContext.tsx │ │ │ ├── CarouselItem.tsx │ │ │ ├── CarouselItemNative.tsx │ │ │ └── CarouselNative.tsx │ │ ├── ChangeListener │ │ │ ├── ChangeListener.md │ │ │ ├── ChangeListener.spec.ts │ │ │ ├── ChangeListener.tsx │ │ │ └── ChangeListenerNative.tsx │ │ ├── chart-color-schemes.ts │ │ ├── Charts │ │ │ ├── AreaChart │ │ │ │ ├── AreaChart.md │ │ │ │ ├── AreaChart.spec.ts │ │ │ │ ├── AreaChart.tsx │ │ │ │ └── AreaChartNative.tsx │ │ │ ├── BarChart │ │ │ │ ├── BarChart.md │ │ │ │ ├── BarChart.module.scss │ │ │ │ ├── BarChart.spec.ts │ │ │ │ ├── BarChart.tsx │ │ │ │ └── BarChartNative.tsx │ │ │ ├── DonutChart │ │ │ │ ├── DonutChart.spec.ts │ │ │ │ └── DonutChart.tsx │ │ │ ├── LabelList │ │ │ │ ├── LabelList.spec.ts │ │ │ │ ├── LabelList.tsx │ │ │ │ ├── LabelListNative.module.scss │ │ │ │ └── LabelListNative.tsx │ │ │ ├── Legend │ │ │ │ ├── Legend.spec.ts │ │ │ │ ├── Legend.tsx │ │ │ │ └── LegendNative.tsx │ │ │ ├── LineChart │ │ │ │ ├── LineChart.md │ │ │ │ ├── LineChart.module.scss │ │ │ │ ├── LineChart.spec.ts │ │ │ │ ├── LineChart.tsx │ │ │ │ └── LineChartNative.tsx │ │ │ ├── PieChart │ │ │ │ ├── PieChart.md │ │ │ │ ├── PieChart.spec.ts │ │ │ │ ├── PieChart.tsx │ │ │ │ ├── PieChartNative.module.scss │ │ │ │ └── PieChartNative.tsx │ │ │ ├── RadarChart │ │ │ │ ├── RadarChart.md │ │ │ │ ├── RadarChart.spec.ts │ │ │ │ ├── RadarChart.tsx │ │ │ │ └── RadarChartNative.tsx │ │ │ ├── Tooltip │ │ │ │ ├── TooltipContent.module.scss │ │ │ │ ├── TooltipContent.spec.ts │ │ │ │ └── TooltipContent.tsx │ │ │ └── utils │ │ │ ├── abstractions.ts │ │ │ └── ChartProvider.tsx │ │ ├── Checkbox │ │ │ ├── Checkbox.md │ │ │ ├── Checkbox.spec.ts │ │ │ └── Checkbox.tsx │ │ ├── CodeBlock │ │ │ ├── CodeBlock.module.scss │ │ │ ├── CodeBlock.spec.ts │ │ │ ├── CodeBlock.tsx │ │ │ ├── CodeBlockNative.tsx │ │ │ └── highlight-code.ts │ │ ├── collectedComponentMetadata.ts │ │ ├── ColorPicker │ │ │ ├── ColorPicker.md │ │ │ ├── ColorPicker.module.scss │ │ │ ├── ColorPicker.spec.ts │ │ │ ├── ColorPicker.tsx │ │ │ └── ColorPickerNative.tsx │ │ ├── Column │ │ │ ├── Column.md │ │ │ ├── Column.tsx │ │ │ ├── ColumnNative.tsx │ │ │ ├── doc-resources │ │ │ │ └── list-component-data.js │ │ │ └── TableContext.tsx │ │ ├── component-utils.ts │ │ ├── ComponentProvider.tsx │ │ ├── ComponentRegistryContext.tsx │ │ ├── container-helpers.tsx │ │ ├── ContentSeparator │ │ │ ├── ContentSeparator.md │ │ │ ├── ContentSeparator.module.scss │ │ │ ├── ContentSeparator.spec.ts │ │ │ ├── ContentSeparator.tsx │ │ │ └── ContentSeparatorNative.tsx │ │ ├── DataSource │ │ │ ├── DataSource.md │ │ │ └── DataSource.tsx │ │ ├── DateInput │ │ │ ├── DateInput.md │ │ │ ├── DateInput.module.scss │ │ │ ├── DateInput.spec.ts │ │ │ ├── DateInput.tsx │ │ │ └── DateInputNative.tsx │ │ ├── DatePicker │ │ │ ├── DatePicker.md │ │ │ ├── DatePicker.module.scss │ │ │ ├── DatePicker.spec.ts │ │ │ ├── DatePicker.tsx │ │ │ └── DatePickerNative.tsx │ │ ├── DropdownMenu │ │ │ ├── DropdownMenu.md │ │ │ ├── DropdownMenu.module.scss │ │ │ ├── DropdownMenu.spec.ts │ │ │ ├── DropdownMenu.tsx │ │ │ ├── DropdownMenuNative.tsx │ │ │ ├── MenuItem.md │ │ │ └── SubMenuItem.md │ │ ├── EmojiSelector │ │ │ ├── EmojiSelector.md │ │ │ ├── EmojiSelector.spec.ts │ │ │ ├── EmojiSelector.tsx │ │ │ └── EmojiSelectorNative.tsx │ │ ├── ExpandableItem │ │ │ ├── ExpandableItem.module.scss │ │ │ ├── ExpandableItem.spec.ts │ │ │ ├── ExpandableItem.tsx │ │ │ └── ExpandableItemNative.tsx │ │ ├── FileInput │ │ │ ├── FileInput.md │ │ │ ├── FileInput.module.scss │ │ │ ├── FileInput.spec.ts │ │ │ ├── FileInput.tsx │ │ │ └── FileInputNative.tsx │ │ ├── FileUploadDropZone │ │ │ ├── FileUploadDropZone.md │ │ │ ├── FileUploadDropZone.module.scss │ │ │ ├── FileUploadDropZone.spec.ts │ │ │ ├── FileUploadDropZone.tsx │ │ │ └── FileUploadDropZoneNative.tsx │ │ ├── FlowLayout │ │ │ ├── FlowLayout.md │ │ │ ├── FlowLayout.module.scss │ │ │ ├── FlowLayout.spec.ts │ │ │ ├── FlowLayout.spec.ts-snapshots │ │ │ │ └── Edge-cases-boxShadow-is-not-clipped-1-non-smoke-darwin.png │ │ │ ├── FlowLayout.tsx │ │ │ └── FlowLayoutNative.tsx │ │ ├── Footer │ │ │ ├── Footer.md │ │ │ ├── Footer.module.scss │ │ │ ├── Footer.spec.ts │ │ │ ├── Footer.tsx │ │ │ └── FooterNative.tsx │ │ ├── Form │ │ │ ├── Form.md │ │ │ ├── Form.module.scss │ │ │ ├── Form.spec.ts │ │ │ ├── Form.tsx │ │ │ ├── formActions.ts │ │ │ ├── FormContext.ts │ │ │ └── FormNative.tsx │ │ ├── FormItem │ │ │ ├── FormItem.md │ │ │ ├── FormItem.module.scss │ │ │ ├── FormItem.spec.ts │ │ │ ├── FormItem.tsx │ │ │ ├── FormItemNative.tsx │ │ │ ├── HelperText.module.scss │ │ │ ├── HelperText.tsx │ │ │ ├── ItemWithLabel.tsx │ │ │ └── Validations.ts │ │ ├── FormSection │ │ │ ├── FormSection.md │ │ │ ├── FormSection.ts │ │ │ └── FormSection.xmlui │ │ ├── Fragment │ │ │ ├── Fragment.spec.ts │ │ │ └── Fragment.tsx │ │ ├── Heading │ │ │ ├── abstractions.ts │ │ │ ├── H1.md │ │ │ ├── H1.spec.ts │ │ │ ├── H2.md │ │ │ ├── H2.spec.ts │ │ │ ├── H3.md │ │ │ ├── H3.spec.ts │ │ │ ├── H4.md │ │ │ ├── H4.spec.ts │ │ │ ├── H5.md │ │ │ ├── H5.spec.ts │ │ │ ├── H6.md │ │ │ ├── H6.spec.ts │ │ │ ├── Heading.md │ │ │ ├── Heading.module.scss │ │ │ ├── Heading.spec.ts │ │ │ ├── Heading.tsx │ │ │ └── HeadingNative.tsx │ │ ├── HoverCard │ │ │ ├── HoverCard.tsx │ │ │ └── HovercardNative.tsx │ │ ├── HtmlTags │ │ │ ├── HtmlTags.module.scss │ │ │ ├── HtmlTags.spec.ts │ │ │ └── HtmlTags.tsx │ │ ├── Icon │ │ │ ├── AdmonitionDanger.tsx │ │ │ ├── AdmonitionInfo.tsx │ │ │ ├── AdmonitionNote.tsx │ │ │ ├── AdmonitionTip.tsx │ │ │ ├── AdmonitionWarning.tsx │ │ │ ├── ApiIcon.tsx │ │ │ ├── ArrowDropDown.module.scss │ │ │ ├── ArrowDropDown.tsx │ │ │ ├── ArrowDropUp.module.scss │ │ │ ├── ArrowDropUp.tsx │ │ │ ├── ArrowLeft.module.scss │ │ │ ├── ArrowLeft.tsx │ │ │ ├── ArrowRight.module.scss │ │ │ ├── ArrowRight.tsx │ │ │ ├── Attach.tsx │ │ │ ├── Binding.module.scss │ │ │ ├── Binding.tsx │ │ │ ├── BoardIcon.tsx │ │ │ ├── BoxIcon.tsx │ │ │ ├── CheckIcon.tsx │ │ │ ├── ChevronDownIcon.tsx │ │ │ ├── ChevronLeft.tsx │ │ │ ├── ChevronRight.tsx │ │ │ ├── ChevronUpIcon.tsx │ │ │ ├── CodeFileIcon.tsx │ │ │ ├── CodeSandbox.tsx │ │ │ ├── CompactListIcon.tsx │ │ │ ├── ContentCopyIcon.tsx │ │ │ ├── DarkToLightIcon.tsx │ │ │ ├── DatabaseIcon.module.scss │ │ │ ├── DatabaseIcon.tsx │ │ │ ├── DocFileIcon.tsx │ │ │ ├── DocIcon.tsx │ │ │ ├── DotMenuHorizontalIcon.tsx │ │ │ ├── DotMenuIcon.tsx │ │ │ ├── EmailIcon.tsx │ │ │ ├── EmptyFolderIcon.tsx │ │ │ ├── ErrorIcon.tsx │ │ │ ├── ExpressionIcon.tsx │ │ │ ├── FillPlusCricleIcon.tsx │ │ │ ├── FilterIcon.tsx │ │ │ ├── FolderIcon.tsx │ │ │ ├── GlobeIcon.tsx │ │ │ ├── HomeIcon.tsx │ │ │ ├── HyperLinkIcon.tsx │ │ │ ├── Icon.md │ │ │ ├── Icon.module.scss │ │ │ ├── Icon.spec.ts │ │ │ ├── Icon.tsx │ │ │ ├── IconNative.tsx │ │ │ ├── ImageFileIcon.tsx │ │ │ ├── Inspect.tsx │ │ │ ├── LightToDark.tsx │ │ │ ├── LinkIcon.tsx │ │ │ ├── ListIcon.tsx │ │ │ ├── LooseListIcon.tsx │ │ │ ├── MoonIcon.tsx │ │ │ ├── MoreOptionsIcon.tsx │ │ │ ├── NoSortIcon.tsx │ │ │ ├── PDFIcon.tsx │ │ │ ├── PenIcon.tsx │ │ │ ├── PhoneIcon.tsx │ │ │ ├── PhotoIcon.tsx │ │ │ ├── PlusIcon.tsx │ │ │ ├── SearchIcon.tsx │ │ │ ├── ShareIcon.tsx │ │ │ ├── SortAscendingIcon.tsx │ │ │ ├── SortDescendingIcon.tsx │ │ │ ├── StarsIcon.tsx │ │ │ ├── SunIcon.tsx │ │ │ ├── svg │ │ │ │ ├── admonition_danger.svg │ │ │ │ ├── admonition_info.svg │ │ │ │ ├── admonition_note.svg │ │ │ │ ├── admonition_tip.svg │ │ │ │ ├── admonition_warning.svg │ │ │ │ ├── api.svg │ │ │ │ ├── arrow-dropdown.svg │ │ │ │ ├── arrow-left.svg │ │ │ │ ├── arrow-right.svg │ │ │ │ ├── arrow-up.svg │ │ │ │ ├── attach.svg │ │ │ │ ├── binding.svg │ │ │ │ ├── box.svg │ │ │ │ ├── bulb.svg │ │ │ │ ├── code-file.svg │ │ │ │ ├── code-sandbox.svg │ │ │ │ ├── dark_to_light.svg │ │ │ │ ├── database.svg │ │ │ │ ├── doc.svg │ │ │ │ ├── empty-folder.svg │ │ │ │ ├── expression.svg │ │ │ │ ├── eye-closed.svg │ │ │ │ ├── eye-dark.svg │ │ │ │ ├── eye.svg │ │ │ │ ├── file-text.svg │ │ │ │ ├── filter.svg │ │ │ │ ├── folder.svg │ │ │ │ ├── img.svg │ │ │ │ ├── inspect.svg │ │ │ │ ├── light_to_dark.svg │ │ │ │ ├── moon.svg │ │ │ │ ├── pdf.svg │ │ │ │ ├── photo.svg │ │ │ │ ├── share.svg │ │ │ │ ├── stars.svg │ │ │ │ ├── sun.svg │ │ │ │ ├── trending-down.svg │ │ │ │ ├── trending-level.svg │ │ │ │ ├── trending-up.svg │ │ │ │ ├── txt.svg │ │ │ │ ├── unknown-file.svg │ │ │ │ ├── unlink.svg │ │ │ │ └── xls.svg │ │ │ ├── TableDeleteColumnIcon.tsx │ │ │ ├── TableDeleteRowIcon.tsx │ │ │ ├── TableInsertColumnIcon.tsx │ │ │ ├── TableInsertRowIcon.tsx │ │ │ ├── TrashIcon.tsx │ │ │ ├── TrendingDownIcon.tsx │ │ │ ├── TrendingLevelIcon.tsx │ │ │ ├── TrendingUpIcon.tsx │ │ │ ├── TxtIcon.tsx │ │ │ ├── UnknownFileIcon.tsx │ │ │ ├── UnlinkIcon.tsx │ │ │ ├── UserIcon.tsx │ │ │ ├── WarningIcon.tsx │ │ │ └── XlsIcon.tsx │ │ ├── IconProvider.tsx │ │ ├── IconRegistryContext.tsx │ │ ├── IFrame │ │ │ ├── IFrame.md │ │ │ ├── IFrame.module.scss │ │ │ ├── IFrame.spec.ts │ │ │ ├── IFrame.tsx │ │ │ └── IFrameNative.tsx │ │ ├── Image │ │ │ ├── Image.md │ │ │ ├── Image.module.scss │ │ │ ├── Image.spec.ts │ │ │ ├── Image.tsx │ │ │ └── ImageNative.tsx │ │ ├── Input │ │ │ ├── index.ts │ │ │ ├── InputAdornment.module.scss │ │ │ ├── InputAdornment.tsx │ │ │ ├── InputDivider.module.scss │ │ │ ├── InputDivider.tsx │ │ │ ├── InputLabel.module.scss │ │ │ ├── InputLabel.tsx │ │ │ ├── PartialInput.module.scss │ │ │ └── PartialInput.tsx │ │ ├── InspectButton │ │ │ ├── InspectButton.module.scss │ │ │ └── InspectButton.tsx │ │ ├── Items │ │ │ ├── Items.md │ │ │ ├── Items.spec.ts │ │ │ ├── Items.tsx │ │ │ └── ItemsNative.tsx │ │ ├── Link │ │ │ ├── Link.md │ │ │ ├── Link.module.scss │ │ │ ├── Link.spec.ts │ │ │ ├── Link.tsx │ │ │ └── LinkNative.tsx │ │ ├── List │ │ │ ├── doc-resources │ │ │ │ └── list-component-data.js │ │ │ ├── List.md │ │ │ ├── List.module.scss │ │ │ ├── List.spec.ts │ │ │ ├── List.tsx │ │ │ └── ListNative.tsx │ │ ├── Logo │ │ │ ├── doc-resources │ │ │ │ └── xmlui-logo.svg │ │ │ ├── Logo.md │ │ │ ├── Logo.tsx │ │ │ └── LogoNative.tsx │ │ ├── Markdown │ │ │ ├── CodeText.module.scss │ │ │ ├── CodeText.tsx │ │ │ ├── Markdown.md │ │ │ ├── Markdown.module.scss │ │ │ ├── Markdown.spec.ts │ │ │ ├── Markdown.tsx │ │ │ ├── MarkdownNative.tsx │ │ │ ├── parse-binding-expr.ts │ │ │ └── utils.ts │ │ ├── metadata-helpers.ts │ │ ├── ModalDialog │ │ │ ├── ConfirmationModalContextProvider.tsx │ │ │ ├── Dialog.module.scss │ │ │ ├── Dialog.tsx │ │ │ ├── ModalDialog.md │ │ │ ├── ModalDialog.module.scss │ │ │ ├── ModalDialog.spec.ts │ │ │ ├── ModalDialog.tsx │ │ │ ├── ModalDialogNative.tsx │ │ │ └── ModalVisibilityContext.tsx │ │ ├── NavGroup │ │ │ ├── NavGroup.md │ │ │ ├── NavGroup.module.scss │ │ │ ├── NavGroup.spec.ts │ │ │ ├── NavGroup.tsx │ │ │ ├── NavGroupContext.ts │ │ │ └── NavGroupNative.tsx │ │ ├── NavLink │ │ │ ├── NavLink.md │ │ │ ├── NavLink.module.scss │ │ │ ├── NavLink.spec.ts │ │ │ ├── NavLink.tsx │ │ │ └── NavLinkNative.tsx │ │ ├── NavPanel │ │ │ ├── NavPanel.md │ │ │ ├── NavPanel.module.scss │ │ │ ├── NavPanel.spec.ts │ │ │ ├── NavPanel.tsx │ │ │ └── NavPanelNative.tsx │ │ ├── NestedApp │ │ │ ├── AppWithCodeView.module.scss │ │ │ ├── AppWithCodeView.tsx │ │ │ ├── AppWithCodeViewNative.tsx │ │ │ ├── defaultProps.tsx │ │ │ ├── logo.svg │ │ │ ├── NestedApp.module.scss │ │ │ ├── NestedApp.tsx │ │ │ ├── NestedAppNative.tsx │ │ │ ├── Tooltip.module.scss │ │ │ ├── Tooltip.tsx │ │ │ └── utils.ts │ │ ├── NoResult │ │ │ ├── NoResult.md │ │ │ ├── NoResult.module.scss │ │ │ ├── NoResult.spec.ts │ │ │ ├── NoResult.tsx │ │ │ └── NoResultNative.tsx │ │ ├── NumberBox │ │ │ ├── numberbox-abstractions.ts │ │ │ ├── NumberBox.md │ │ │ ├── NumberBox.module.scss │ │ │ ├── NumberBox.spec.ts │ │ │ ├── NumberBox.tsx │ │ │ └── NumberBoxNative.tsx │ │ ├── Option │ │ │ ├── Option.md │ │ │ ├── Option.spec.ts │ │ │ ├── Option.tsx │ │ │ ├── OptionNative.tsx │ │ │ └── OptionTypeProvider.tsx │ │ ├── PageMetaTitle │ │ │ ├── PageMetaTilteNative.tsx │ │ │ ├── PageMetaTitle.md │ │ │ ├── PageMetaTitle.spec.ts │ │ │ └── PageMetaTitle.tsx │ │ ├── Pages │ │ │ ├── Page.md │ │ │ ├── Pages.md │ │ │ ├── Pages.module.scss │ │ │ ├── Pages.tsx │ │ │ └── PagesNative.tsx │ │ ├── Pagination │ │ │ ├── Pagination.md │ │ │ ├── Pagination.module.scss │ │ │ ├── Pagination.spec.ts │ │ │ ├── Pagination.tsx │ │ │ └── PaginationNative.tsx │ │ ├── PositionedContainer │ │ │ ├── PositionedContainer.module.scss │ │ │ ├── PositionedContainer.tsx │ │ │ └── PositionedContainerNative.tsx │ │ ├── ProfileMenu │ │ │ ├── ProfileMenu.module.scss │ │ │ └── ProfileMenu.tsx │ │ ├── ProgressBar │ │ │ ├── ProgressBar.md │ │ │ ├── ProgressBar.module.scss │ │ │ ├── ProgressBar.spec.ts │ │ │ ├── ProgressBar.tsx │ │ │ └── ProgressBarNative.tsx │ │ ├── Queue │ │ │ ├── Queue.md │ │ │ ├── Queue.spec.ts │ │ │ ├── Queue.tsx │ │ │ ├── queueActions.ts │ │ │ └── QueueNative.tsx │ │ ├── RadioGroup │ │ │ ├── RadioGroup.md │ │ │ ├── RadioGroup.module.scss │ │ │ ├── RadioGroup.spec.ts │ │ │ ├── RadioGroup.tsx │ │ │ ├── RadioGroupNative.tsx │ │ │ ├── RadioItem.tsx │ │ │ └── RadioItemNative.tsx │ │ ├── RealTimeAdapter │ │ │ ├── RealTimeAdapter.tsx │ │ │ └── RealTimeAdapterNative.tsx │ │ ├── Redirect │ │ │ ├── Redirect.md │ │ │ ├── Redirect.spec.ts │ │ │ └── Redirect.tsx │ │ ├── ResponsiveBar │ │ │ ├── README.md │ │ │ ├── ResponsiveBar.md │ │ │ ├── ResponsiveBar.module.scss │ │ │ ├── ResponsiveBar.spec.ts │ │ │ ├── ResponsiveBar.tsx │ │ │ └── ResponsiveBarNative.tsx │ │ ├── Select │ │ │ ├── HiddenOption.tsx │ │ │ ├── OptionContext.ts │ │ │ ├── Select.md │ │ │ ├── Select.module.scss │ │ │ ├── Select.spec.ts │ │ │ ├── Select.tsx │ │ │ ├── SelectContext.tsx │ │ │ └── SelectNative.tsx │ │ ├── SelectionStore │ │ │ ├── SelectionStore.md │ │ │ ├── SelectionStore.tsx │ │ │ └── SelectionStoreNative.tsx │ │ ├── Slider │ │ │ ├── Slider.md │ │ │ ├── Slider.module.scss │ │ │ ├── Slider.spec.ts │ │ │ ├── Slider.tsx │ │ │ └── SliderNative.tsx │ │ ├── Slot │ │ │ ├── Slot.md │ │ │ ├── Slot.spec.ts │ │ │ └── Slot.ts │ │ ├── SlotItem.tsx │ │ ├── SpaceFiller │ │ │ ├── SpaceFiller.md │ │ │ ├── SpaceFiller.module.scss │ │ │ ├── SpaceFiller.spec.ts │ │ │ ├── SpaceFiller.tsx │ │ │ └── SpaceFillerNative.tsx │ │ ├── Spinner │ │ │ ├── Spinner.md │ │ │ ├── Spinner.module.scss │ │ │ ├── Spinner.spec.ts │ │ │ ├── Spinner.tsx │ │ │ └── SpinnerNative.tsx │ │ ├── Splitter │ │ │ ├── HSplitter.md │ │ │ ├── HSplitter.spec.ts │ │ │ ├── Splitter.md │ │ │ ├── Splitter.module.scss │ │ │ ├── Splitter.spec.ts │ │ │ ├── Splitter.tsx │ │ │ ├── SplitterNative.tsx │ │ │ ├── utils.ts │ │ │ ├── VSplitter.md │ │ │ └── VSplitter.spec.ts │ │ ├── Stack │ │ │ ├── CHStack.md │ │ │ ├── CHStack.spec.ts │ │ │ ├── CVStack.md │ │ │ ├── CVStack.spec.ts │ │ │ ├── HStack.md │ │ │ ├── HStack.spec.ts │ │ │ ├── Stack.md │ │ │ ├── Stack.module.scss │ │ │ ├── Stack.spec.ts │ │ │ ├── Stack.tsx │ │ │ ├── StackNative.tsx │ │ │ ├── VStack.md │ │ │ └── VStack.spec.ts │ │ ├── StickyBox │ │ │ ├── StickyBox.md │ │ │ ├── StickyBox.module.scss │ │ │ ├── StickyBox.tsx │ │ │ └── StickyBoxNative.tsx │ │ ├── Switch │ │ │ ├── Switch.md │ │ │ ├── Switch.spec.ts │ │ │ └── Switch.tsx │ │ ├── Table │ │ │ ├── doc-resources │ │ │ │ └── list-component-data.js │ │ │ ├── react-table-config.d.ts │ │ │ ├── Table.md │ │ │ ├── Table.module.scss │ │ │ ├── Table.spec.ts │ │ │ ├── Table.tsx │ │ │ ├── TableNative.tsx │ │ │ └── useRowSelection.tsx │ │ ├── TableOfContents │ │ │ ├── TableOfContents.module.scss │ │ │ ├── TableOfContents.spec.ts │ │ │ ├── TableOfContents.tsx │ │ │ └── TableOfContentsNative.tsx │ │ ├── Tabs │ │ │ ├── TabContext.tsx │ │ │ ├── TabItem.md │ │ │ ├── TabItem.tsx │ │ │ ├── TabItemNative.tsx │ │ │ ├── Tabs.md │ │ │ ├── Tabs.module.scss │ │ │ ├── Tabs.spec.ts │ │ │ ├── Tabs.tsx │ │ │ └── TabsNative.tsx │ │ ├── Text │ │ │ ├── Text.md │ │ │ ├── Text.module.scss │ │ │ ├── Text.spec.ts │ │ │ ├── Text.tsx │ │ │ └── TextNative.tsx │ │ ├── TextArea │ │ │ ├── TextArea.md │ │ │ ├── TextArea.module.scss │ │ │ ├── TextArea.spec.ts │ │ │ ├── TextArea.tsx │ │ │ ├── TextAreaNative.tsx │ │ │ ├── TextAreaResizable.tsx │ │ │ └── useComposedRef.ts │ │ ├── TextBox │ │ │ ├── TextBox.md │ │ │ ├── TextBox.module.scss │ │ │ ├── TextBox.spec.ts │ │ │ ├── TextBox.tsx │ │ │ └── TextBoxNative.tsx │ │ ├── Theme │ │ │ ├── NotificationToast.tsx │ │ │ ├── Theme.md │ │ │ ├── Theme.module.scss │ │ │ ├── Theme.spec.ts │ │ │ ├── Theme.tsx │ │ │ └── ThemeNative.tsx │ │ ├── TimeInput │ │ │ ├── TimeInput.md │ │ │ ├── TimeInput.module.scss │ │ │ ├── TimeInput.spec.ts │ │ │ ├── TimeInput.tsx │ │ │ ├── TimeInputNative.tsx │ │ │ └── utils.ts │ │ ├── Timer │ │ │ ├── Timer.md │ │ │ ├── Timer.spec.ts │ │ │ ├── Timer.tsx │ │ │ └── TimerNative.tsx │ │ ├── Toggle │ │ │ ├── Toggle.module.scss │ │ │ └── Toggle.tsx │ │ ├── ToneChangerButton │ │ │ ├── ToneChangerButton.md │ │ │ ├── ToneChangerButton.spec.ts │ │ │ └── ToneChangerButton.tsx │ │ ├── ToneSwitch │ │ │ ├── ToneSwitch.md │ │ │ ├── ToneSwitch.module.scss │ │ │ ├── ToneSwitch.spec.ts │ │ │ ├── ToneSwitch.tsx │ │ │ └── ToneSwitchNative.tsx │ │ ├── Tooltip │ │ │ ├── Tooltip.md │ │ │ ├── Tooltip.module.scss │ │ │ ├── Tooltip.spec.ts │ │ │ ├── Tooltip.tsx │ │ │ └── TooltipNative.tsx │ │ ├── Tree │ │ │ ├── testData.ts │ │ │ ├── Tree-dynamic.spec.ts │ │ │ ├── Tree-icons.spec.ts │ │ │ ├── Tree.md │ │ │ ├── Tree.spec.ts │ │ │ ├── TreeComponent.module.scss │ │ │ ├── TreeComponent.tsx │ │ │ └── TreeNative.tsx │ │ ├── TreeDisplay │ │ │ ├── TreeDisplay.md │ │ │ ├── TreeDisplay.module.scss │ │ │ ├── TreeDisplay.tsx │ │ │ └── TreeDisplayNative.tsx │ │ ├── ValidationSummary │ │ │ ├── ValidationSummary.module.scss │ │ │ └── ValidationSummary.tsx │ │ └── VisuallyHidden.tsx │ ├── components-core │ │ ├── abstractions │ │ │ ├── ComponentRenderer.ts │ │ │ ├── LoaderRenderer.ts │ │ │ ├── standalone.ts │ │ │ └── treeAbstractions.ts │ │ ├── action │ │ │ ├── actions.ts │ │ │ ├── APICall.tsx │ │ │ ├── FileDownloadAction.tsx │ │ │ ├── FileUploadAction.tsx │ │ │ ├── NavigateAction.tsx │ │ │ └── TimedAction.tsx │ │ ├── ApiBoundComponent.tsx │ │ ├── appContext │ │ │ ├── date-functions.ts │ │ │ ├── math-function.ts │ │ │ └── misc-utils.ts │ │ ├── AppContext.tsx │ │ ├── behaviors │ │ │ ├── Behavior.tsx │ │ │ └── CoreBehaviors.tsx │ │ ├── component-hooks.ts │ │ ├── ComponentDecorator.tsx │ │ ├── ComponentViewer.tsx │ │ ├── CompoundComponent.tsx │ │ ├── constants.ts │ │ ├── DebugViewProvider.tsx │ │ ├── descriptorHelper.ts │ │ ├── devtools │ │ │ ├── InspectorDialog.module.scss │ │ │ ├── InspectorDialog.tsx │ │ │ └── InspectorDialogVisibilityContext.tsx │ │ ├── EngineError.ts │ │ ├── event-handlers.ts │ │ ├── InspectorButton.module.scss │ │ ├── InspectorContext.tsx │ │ ├── interception │ │ │ ├── abstractions.ts │ │ │ ├── ApiInterceptor.ts │ │ │ ├── ApiInterceptorProvider.tsx │ │ │ ├── apiInterceptorWorker.ts │ │ │ ├── Backend.ts │ │ │ ├── Errors.ts │ │ │ ├── IndexedDb.ts │ │ │ ├── initMock.ts │ │ │ ├── InMemoryDb.ts │ │ │ ├── ReadonlyCollection.ts │ │ │ └── useApiInterceptorContext.tsx │ │ ├── loader │ │ │ ├── ApiLoader.tsx │ │ │ ├── DataLoader.tsx │ │ │ ├── ExternalDataLoader.tsx │ │ │ ├── Loader.tsx │ │ │ ├── MockLoaderRenderer.tsx │ │ │ └── PageableLoader.tsx │ │ ├── LoaderComponent.tsx │ │ ├── markup-check.ts │ │ ├── parts.ts │ │ ├── renderers.ts │ │ ├── rendering │ │ │ ├── AppContent.tsx │ │ │ ├── AppRoot.tsx │ │ │ ├── AppWrapper.tsx │ │ │ ├── buildProxy.ts │ │ │ ├── collectFnVarDeps.ts │ │ │ ├── ComponentAdapter.tsx │ │ │ ├── ComponentWrapper.tsx │ │ │ ├── Container.tsx │ │ │ ├── containers.ts │ │ │ ├── ContainerWrapper.tsx │ │ │ ├── ErrorBoundary.module.scss │ │ │ ├── ErrorBoundary.tsx │ │ │ ├── InvalidComponent.module.scss │ │ │ ├── InvalidComponent.tsx │ │ │ ├── nodeUtils.ts │ │ │ ├── reducer.ts │ │ │ ├── renderChild.tsx │ │ │ ├── StandaloneComponent.tsx │ │ │ ├── StateContainer.tsx │ │ │ ├── UnknownComponent.module.scss │ │ │ ├── UnknownComponent.tsx │ │ │ └── valueExtractor.ts │ │ ├── reportEngineError.ts │ │ ├── RestApiProxy.ts │ │ ├── script-runner │ │ │ ├── asyncProxy.ts │ │ │ ├── AttributeValueParser.ts │ │ │ ├── bannedFunctions.ts │ │ │ ├── BindingTreeEvaluationContext.ts │ │ │ ├── eval-tree-async.ts │ │ │ ├── eval-tree-common.ts │ │ │ ├── eval-tree-sync.ts │ │ │ ├── ParameterParser.ts │ │ │ ├── process-statement-async.ts │ │ │ ├── process-statement-common.ts │ │ │ ├── process-statement-sync.ts │ │ │ ├── ScriptingSourceTree.ts │ │ │ ├── simplify-expression.ts │ │ │ ├── statement-queue.ts │ │ │ └── visitors.ts │ │ ├── StandaloneApp.tsx │ │ ├── StandaloneExtensionManager.ts │ │ ├── TableOfContentsContext.tsx │ │ ├── theming │ │ │ ├── _themes.scss │ │ │ ├── component-layout-resolver.ts │ │ │ ├── extendThemeUtils.ts │ │ │ ├── hvar.ts │ │ │ ├── layout-resolver.ts │ │ │ ├── parse-layout-props.ts │ │ │ ├── StyleContext.tsx │ │ │ ├── StyleRegistry.ts │ │ │ ├── ThemeContext.tsx │ │ │ ├── ThemeProvider.tsx │ │ │ ├── themes │ │ │ │ ├── base-utils.ts │ │ │ │ ├── palette.ts │ │ │ │ ├── root.ts │ │ │ │ ├── solid.ts │ │ │ │ ├── theme-colors.ts │ │ │ │ └── xmlui.ts │ │ │ ├── themeVars.module.scss │ │ │ ├── themeVars.ts │ │ │ ├── transformThemeVars.ts │ │ │ └── utils.ts │ │ ├── utils │ │ │ ├── actionUtils.ts │ │ │ ├── audio-utils.ts │ │ │ ├── base64-utils.ts │ │ │ ├── compound-utils.ts │ │ │ ├── css-utils.ts │ │ │ ├── DataLoaderQueryKeyGenerator.ts │ │ │ ├── date-utils.ts │ │ │ ├── extractParam.ts │ │ │ ├── hooks.tsx │ │ │ ├── LruCache.ts │ │ │ ├── mergeProps.ts │ │ │ ├── misc.ts │ │ │ ├── request-params.ts │ │ │ ├── statementUtils.ts │ │ │ └── treeUtils.ts │ │ └── xmlui-parser.ts │ ├── index-standalone.ts │ ├── index.scss │ ├── index.ts │ ├── language-server │ │ ├── server-common.ts │ │ ├── server-web-worker.ts │ │ ├── server.ts │ │ ├── services │ │ │ ├── common │ │ │ │ ├── docs-generation.ts │ │ │ │ ├── lsp-utils.ts │ │ │ │ ├── metadata-utils.ts │ │ │ │ └── syntax-node-utilities.ts │ │ │ ├── completion.ts │ │ │ ├── diagnostic.ts │ │ │ ├── format.ts │ │ │ └── hover.ts │ │ └── xmlui-metadata-generated.mjs │ ├── logging │ │ ├── LoggerContext.tsx │ │ ├── LoggerInitializer.tsx │ │ ├── LoggerService.ts │ │ └── xmlui.ts │ ├── logo.svg │ ├── parsers │ │ ├── common │ │ │ ├── GenericToken.ts │ │ │ ├── InputStream.ts │ │ │ └── utils.ts │ │ ├── scripting │ │ │ ├── code-behind-collect.ts │ │ │ ├── Lexer.ts │ │ │ ├── modules.ts │ │ │ ├── Parser.ts │ │ │ ├── ParserError.ts │ │ │ ├── ScriptingNodeTypes.ts │ │ │ ├── TokenTrait.ts │ │ │ ├── TokenType.ts │ │ │ └── tree-visitor.ts │ │ ├── style-parser │ │ │ ├── errors.ts │ │ │ ├── source-tree.ts │ │ │ ├── StyleInputStream.ts │ │ │ ├── StyleLexer.ts │ │ │ ├── StyleParser.ts │ │ │ └── tokens.ts │ │ └── xmlui-parser │ │ ├── CharacterCodes.ts │ │ ├── diagnostics.ts │ │ ├── fileExtensions.ts │ │ ├── index.ts │ │ ├── lint.ts │ │ ├── parser.ts │ │ ├── ParserError.ts │ │ ├── scanner.ts │ │ ├── syntax-kind.ts │ │ ├── syntax-node.ts │ │ ├── transform.ts │ │ ├── utils.ts │ │ ├── xmlui-serializer.ts │ │ └── xmlui-tree.ts │ ├── react-app-env.d.ts │ ├── syntax │ │ ├── monaco │ │ │ ├── grammar.monacoLanguage.ts │ │ │ ├── index.ts │ │ │ ├── xmlui-dark.ts │ │ │ ├── xmlui-light.ts │ │ │ └── xmluiscript.monacoLanguage.ts │ │ └── textMate │ │ ├── index.ts │ │ ├── xmlui-dark.json │ │ ├── xmlui-light.json │ │ ├── xmlui.json │ │ └── xmlui.tmLanguage.json │ ├── testing │ │ ├── assertions.ts │ │ ├── component-test-helpers.ts │ │ ├── ComponentDrivers.ts │ │ ├── drivers │ │ │ ├── DateInputDriver.ts │ │ │ ├── ModalDialogDriver.ts │ │ │ ├── NumberBoxDriver.ts │ │ │ ├── TextBoxDriver.ts │ │ │ ├── TimeInputDriver.ts │ │ │ ├── TimerDriver.ts │ │ │ └── TreeDriver.ts │ │ ├── fixtures.ts │ │ ├── infrastructure │ │ │ ├── index.html │ │ │ ├── main.tsx │ │ │ ├── public │ │ │ │ ├── mockServiceWorker.js │ │ │ │ ├── resources │ │ │ │ │ ├── bell.svg │ │ │ │ │ ├── box.svg │ │ │ │ │ ├── doc.svg │ │ │ │ │ ├── eye.svg │ │ │ │ │ ├── flower-640x480.jpg │ │ │ │ │ ├── sun.svg │ │ │ │ │ ├── test-image-100x100.jpg │ │ │ │ │ └── txt.svg │ │ │ │ └── serve.json │ │ │ └── TestBed.tsx │ │ └── themed-app-test-helpers.ts │ └── vite-env.d.ts ├── tests │ ├── components │ │ ├── CodeBlock │ │ │ └── hightlight-code.test.ts │ │ ├── playground-pattern.test.ts │ │ └── Tree │ │ └── Tree-states.test.ts │ ├── components-core │ │ ├── abstractions │ │ │ └── treeAbstractions.test.ts │ │ ├── container │ │ │ └── buildProxy.test.ts │ │ ├── interception │ │ │ ├── orderBy.test.ts │ │ │ ├── ReadOnlyCollection.test.ts │ │ │ └── request-param-converter.test.ts │ │ ├── scripts-runner │ │ │ ├── AttributeValueParser.test.ts │ │ │ ├── eval-tree-arrow-async.test.ts │ │ │ ├── eval-tree-arrow.test.ts │ │ │ ├── eval-tree-func-decl-async.test.ts │ │ │ ├── eval-tree-func-decl.test.ts │ │ │ ├── eval-tree-pre-post.test.ts │ │ │ ├── eval-tree-regression.test.ts │ │ │ ├── eval-tree.test.ts │ │ │ ├── function-proxy.test.ts │ │ │ ├── parser-regression.test.ts │ │ │ ├── process-event.test.ts │ │ │ ├── process-function.test.ts │ │ │ ├── process-implicit-context.test.ts │ │ │ ├── process-statement-asgn.test.ts │ │ │ ├── process-statement-destruct.test.ts │ │ │ ├── process-statement-regs.test.ts │ │ │ ├── process-statement-sync.test.ts │ │ │ ├── process-statement.test.ts │ │ │ ├── process-switch-sync.test.ts │ │ │ ├── process-switch.test.ts │ │ │ ├── process-try-sync.test.ts │ │ │ ├── process-try.test.ts │ │ │ └── test-helpers.ts │ │ ├── test-metadata-handler.ts │ │ ├── theming │ │ │ ├── border-segments.test.ts │ │ │ ├── component-layout.resolver.test.ts │ │ │ ├── layout-property-parser.test.ts │ │ │ ├── layout-resolver.test.ts │ │ │ ├── layout-resolver2.test.ts │ │ │ ├── layout-vp-override.test.ts │ │ │ └── padding-segments.test.ts │ │ └── utils │ │ ├── date-utils.test.ts │ │ ├── format-human-elapsed-time.test.ts │ │ └── LruCache.test.ts │ ├── language-server │ │ ├── completion.test.ts │ │ ├── format.test.ts │ │ ├── hover.test.ts │ │ └── mockData.ts │ └── parsers │ ├── common │ │ └── input-stream.test.ts │ ├── markdown │ │ └── parse-binding-expression.test.ts │ ├── parameter-parser.test.ts │ ├── paremeter-parser.test.ts │ ├── scripting │ │ ├── eval-tree-arrow.test.ts │ │ ├── eval-tree-pre-post.test.ts │ │ ├── eval-tree.test.ts │ │ ├── function-proxy.test.ts │ │ ├── lexer-literals.test.ts │ │ ├── lexer-misc.test.ts │ │ ├── module-parse.test.ts │ │ ├── parser-arrow.test.ts │ │ ├── parser-assignments.test.ts │ │ ├── parser-binary.test.ts │ │ ├── parser-destructuring.test.ts │ │ ├── parser-errors.test.ts │ │ ├── parser-expressions.test.ts │ │ ├── parser-function.test.ts │ │ ├── parser-literals.test.ts │ │ ├── parser-primary.test.ts │ │ ├── parser-regex.test.ts │ │ ├── parser-statements.test.ts │ │ ├── parser-unary.test.ts │ │ ├── process-event.test.ts │ │ ├── process-implicit-context.test.ts │ │ ├── process-statement-asgn.test.ts │ │ ├── process-statement-destruct.test.ts │ │ ├── process-statement-regs.test.ts │ │ ├── process-statement-sync.test.ts │ │ ├── process-statement.test.ts │ │ ├── process-switch-sync.test.ts │ │ ├── process-switch.test.ts │ │ ├── process-try-sync.test.ts │ │ ├── process-try.test.ts │ │ ├── simplify-expression.test.ts │ │ ├── statement-hooks.test.ts │ │ └── test-helpers.ts │ ├── style-parser │ │ ├── generateHvarChain.test.ts │ │ ├── parseHVar.test.ts │ │ ├── parser.test.ts │ │ └── tokens.test.ts │ └── xmlui │ ├── lint.test.ts │ ├── parser.test.ts │ ├── scanner.test.ts │ ├── transform.attr.test.ts │ ├── transform.circular.test.ts │ ├── transform.element.test.ts │ ├── transform.errors.test.ts │ ├── transform.escape.test.ts │ ├── transform.regression.test.ts │ ├── transform.script.test.ts │ ├── transform.test.ts │ └── xmlui.ts ├── tests-e2e │ ├── api-bound-component-regression.spec.ts │ ├── api-call-as-extracted-component.spec.ts │ ├── assign-to-object-or-array-regression.spec.ts │ ├── binding-regression.spec.ts │ ├── children-as-template-context-vars.spec.ts │ ├── compound-component.spec.ts │ ├── context-vars-regression.spec.ts │ ├── data-bindings.spec.ts │ ├── datasource-and-api-usage-in-var.spec.ts │ ├── datasource-direct-binding.spec.ts │ ├── datasource-onLoaded-regression.spec.ts │ ├── modify-array-item-regression.spec.ts │ ├── namespaces.spec.ts │ ├── push-to-array-regression.spec.ts │ ├── screen-breakpoints.spec.ts │ ├── scripting.spec.ts │ ├── state-scope-in-pages.spec.ts │ └── state-var-scopes.spec.ts ├── tsconfig.bin.json ├── tsconfig.json ├── tsconfig.node.json ├── vite.config.ts └── vitest.config.ts ``` # Files -------------------------------------------------------------------------------- /xmlui/dev-docs/standalone-app.md: -------------------------------------------------------------------------------- ```markdown 1 | # Standalone Rendering Architecture 2 | 3 | This document provides comprehensive documentation of XMLUI's standalone app architecture for developers working on the XMLUI core framework. It covers the complete rendering pipeline from app bootstrapping through component rendering, explaining how XMLUI source files (.xmlui, .xmlui.xs) are transformed into running React applications. 4 | 5 | The document is structured in three main sections: (1) Translation and Rendering explains the two deployment modes (built vs buildless) and high-level architecture, (2) Component Hierarchy Flow shows the provider stack and rendering tree, and (3) Implementation Details provides in-depth documentation of each component, provider, and rendering utility with behavior descriptions and cross-references. 6 | 7 | ## Translation and Rendering 8 | 9 | XMLUI supports two distinct deployment modes that determine how source files are processed and delivered to the browser: 10 | 11 | **Built Apps** use compile-time transformation via Vite plugins. Source files (.xmlui, .xmlui.xs) are pre-compiled during build time and bundled into the runtime, providing faster startup and optimized performance for production deployment. 12 | 13 | **Buildless Apps** fetch and parse sources at runtime using sophisticated fallback logic, enabling rapid development and deployment without a build step. This approach allows zero-config deployment to any static web server. 14 | 15 | Both modes converge on the same rendering pipeline once the app's internal representation is prepared. Both use the `StandaloneApp` component as their entry point, but pass different arguments based on how component definitions are resolved. 16 | 17 | ### Understanding the Modes Through Examples 18 | 19 | **Pure Buildless App: xmlui-invoice** 20 | 21 | Standalone applications like xmlui-invoice exemplify the buildless approach: 22 | 23 | ``` 24 | xmlui-invoice/ 25 | ├── index.html # Loads xmlui-standalone.umd.js 26 | ├── Main.xmlui # App entry point 27 | ├── components/ # Component source files 28 | │ ├── InvoiceList.xmlui 29 | │ └── InvoiceForm.xmlui 30 | └── xmlui/ 31 | └── 0.9.90.js # XMLUI runtime 32 | ``` 33 | 34 | When the browser loads `index.html`, the standalone runtime automatically: 35 | 1. Detects `Main.xmlui` as the entry point 36 | 2. Fetches and parses it at runtime 37 | 3. Discovers referenced components (`InvoiceList`, `InvoiceForm`) 38 | 4. Recursively fetches and parses them from the `components/` directory 39 | 5. Passes `undefined` as the `runtime` parameter to `StandaloneApp` 40 | 41 | ```typescript 42 | // From index-standalone.ts (bundled in xmlui-standalone.umd.js) 43 | startApp(undefined, undefined, Xmlui); 44 | ``` 45 | 46 | The `StandaloneApp` component's `useStandalone()` hook recognizes the missing runtime and triggers the fallback logic that fetches source files on-demand. 47 | 48 | **Built App: The XMLUI Documentation Site** 49 | 50 | The documentation site at xmlui.com demonstrates the built approach: 51 | 52 | ``` 53 | docs/ 54 | ├── index.html # Loads bundled JavaScript 55 | ├── index.ts # Entry point with import.meta.glob 56 | ├── src/ 57 | │ └── Main.xmlui # Source files for development 58 | ├── package.json # Build scripts 59 | └── dist/ # Compiled output 60 | ├── index.html 61 | └── internal/ 62 | └── chunks/ # Pre-compiled bundles 63 | ``` 64 | 65 | The `index.ts` entry point uses Vite's `import.meta.glob()` to pre-compile all source files: 66 | 67 | ```typescript 68 | // From docs/index.ts 69 | import { startApp } from "xmlui"; 70 | 71 | export const runtime = import.meta.glob(`/src/**`, { eager: true }); 72 | startApp(runtime, usedExtensions); 73 | ``` 74 | 75 | During the build process (`npm run build:docs`): 76 | 1. Vite's xmlui plugin transforms all `.xmlui` files into component definitions 77 | 2. Component definitions are bundled into JavaScript modules 78 | 3. The `runtime` object contains pre-compiled components 79 | 4. `StandaloneApp` receives the populated `runtime` parameter and skips fetching 80 | 81 | The resulting `dist/` folder contains optimized bundles that start faster since parsing already happened at build time. 82 | 83 | **Hybrid Case: Extension Development** 84 | 85 | The build-hello-world-component tutorial shows an interesting hybrid pattern - a **built extension consumed by buildless apps**: 86 | 87 | Extension development uses a build step: 88 | ```bash 89 | npm run build:extension # Creates dist/xmlui-hello-world.js 90 | ``` 91 | 92 | But the resulting extension is consumed by buildless standalone apps: 93 | 94 | ```html 95 | <!-- Buildless app index.html --> 96 | <script src="https://unpkg.com/xmlui@latest/dist/standalone/xmlui-standalone.umd.js"></script> 97 | <script src="xmlui/xmlui-hello-world.js"></script> 98 | ``` 99 | 100 | The extension package itself is pre-compiled (built), but the app loading it remains buildless. The extension registers its components with `StandaloneApp`'s extension manager, which makes them available to the runtime component discovery system. 101 | 102 | ### How StandaloneApp Unifies Both Modes 103 | 104 | The `startApp()` function is the universal bootstrapping mechanism: 105 | 106 | ```typescript 107 | export function startApp( 108 | runtime: any, // Pre-compiled components or undefined 109 | extensions: Extension[] | Extension = [], 110 | extensionManager: StandaloneExtensionManager = new StandaloneExtensionManager(), 111 | ) { 112 | extensionManager.registerExtension(extensions); 113 | let rootElement: HTMLElement | null = document.getElementById("root"); 114 | if (!rootElement) { 115 | rootElement = document.createElement("div"); 116 | rootElement.setAttribute("id", "root"); 117 | document.body.appendChild(rootElement); 118 | } 119 | if (!contentRoot) { 120 | contentRoot = ReactDOM.createRoot(rootElement); 121 | } 122 | contentRoot.render( 123 | <StandaloneApp runtime={runtime} extensionManager={extensionManager} /> 124 | ); 125 | return contentRoot; 126 | } 127 | ``` 128 | 129 | The `StandaloneApp` component's internal logic adapts based on what it receives: 130 | 131 | **Built Mode (runtime provided):** 132 | - `mergeAppDefWithRuntime()` extracts pre-compiled definitions 133 | - No network requests for component source files 134 | - Immediate rendering pipeline initialization 135 | 136 | **Buildless Mode (runtime is undefined):** 137 | - `useStandalone()` hook detects missing runtime 138 | - Fetches `Main.xmlui` using `xmlUiMarkupToComponent()` 139 | - Loads `config.json` for configuration 140 | - Recursively discovers and loads components via `collectMissingComponents()` 141 | - Parses both `.xmlui` markup and `.xmlui.xs` code-behind files 142 | - Assembles `StandaloneAppDescription` for rendering 143 | 144 | Both paths converge at the same point: a fully-prepared `StandaloneAppDescription` object passed to `AppRoot` for rendering. The component hierarchy, state management, and rendering pipeline are identical regardless of deployment mode. 145 | 146 | ### When the Mode is Determined 147 | 148 | The built vs buildless decision is made **at project inception**, not during development: 149 | 150 | **Creating a standalone app (buildless by design):** 151 | ```bash 152 | mkdir my-app 153 | cd my-app 154 | # Create index.html, Main.xmlui 155 | # Deploy to any web server 156 | ``` 157 | 158 | As a standalone app developer, you work exclusively in buildless mode. There is no choice to make - you edit `.xmlui` files, refresh the browser, and see changes immediately. 159 | 160 | **Creating an extension (requires build):** 161 | ```bash 162 | npm init -y 163 | npm install --save-dev xmlui 164 | # Extensions must use the build system 165 | npm run build:extension 166 | ``` 167 | 168 | Extension developers work in built mode to create distributable packages. The build step compiles TypeScript to JavaScript and packages the extension for consumption by buildless apps. 169 | 170 | **Creating a documentation/demo site (architectural decision):** 171 | ```bash 172 | # Decision point: Do we need HMR and build-time optimization? 173 | # If yes → built mode (like the docs site) 174 | # If no → buildless mode (like example apps) 175 | ``` 176 | 177 | The docs site was architected as a built app to support hot module reloading during development and build-time optimization for production. This decision was made once at project inception. 178 | 179 | ### Key Takeaway 180 | 181 | The mode is inherent to the project type. Standalone app developers never think about builds. Extension developers always use builds. The docs site developers work with builds because that's how the docs site was designed. Once the initial architecture is established, the mode doesn't change. 182 | 183 | ### Buildless Apps: Direct Source File Execution 184 | 185 | Buildless apps represent one of XMLUI's most powerful features - the ability to run applications directly from source files without any compilation step. 186 | 187 | **Typical Buildless App Structure:** 188 | ``` 189 | xmlui-app/ 190 | ├── index.html # Entry HTML page with xmlui runtime script 191 | ├── Main.xmlui # App entry point 192 | ├── config.json # App configuration (optional) 193 | ├── components/ # Custom components directory (optional) 194 | │ ├── ClientDetails.xmlui 195 | │ └── Home.xmlui 196 | ├── resources/ # Static resources (optional) 197 | │ └── favicon.ico 198 | ├── themes/ # Custom themes (optional) 199 | │ └── app-theme.json 200 | └── xmlui/ # XMLUI runtime 201 | └── 0.9.90.js 202 | ``` 203 | 204 | When using a web server that can serve static files, only these three files are required to create a fully functional XMLUI app: 205 | - `index.html` 206 | - `xmlui/<xmlui-version>.js` 207 | - `Main.xmlui` 208 | 209 | **How Buildless Apps Bootstrap:** 210 | 1. Browser loads `index.html` which includes the XMLUI runtime script 211 | 2. Runtime automatically looks for `Main.xmlui` as the entry point 212 | 3. Framework fetches and parses source files on-demand as components are referenced 213 | 4. Component discovery happens recursively - as markup references components, they're loaded from the `components/` directory 214 | 5. Themes and configuration are loaded from their respective directories/files 215 | 216 | **Key Characteristics of Buildless Deployment:** 217 | - **Zero Build Step**: Apps can be deployed directly to any static web server 218 | - **Runtime Parsing**: Source files are fetched and parsed in the browser 219 | - **Development Speed**: Changes are immediately visible on page refresh 220 | - **Simple Deployment**: Copy files to a web server and serve `index.html` 221 | 222 | This buildless approach enables rapid prototyping and simple deployment scenarios where build complexity isn't desired. 223 | 224 | ### Built Apps: Pre-compiled for Performance 225 | 226 | Built apps represent XMLUI's production-ready deployment approach where source files are pre-compiled during build time, resulting in optimized bundles with faster startup times and reduced runtime overhead. 227 | 228 | Built apps use the vite development server with hot module reloading. If you change the XMLUI app's source code, the app is updated in the browser automatically without manual refresh. XMLUI has a vite plugin that compiles xmlui source files to their internal definition and so do not require the parsing cycles a buildless app executes. So, the app starts faster. 229 | 230 | **How Built Apps Bootstrap:** 231 | 1. Build process pre-compiles all .xmlui and .xmlui.xs files using the vite-xmlui-plugin 232 | 2. Source files are transformed into component definitions and bundled into JavaScript modules 233 | 3. Browser loads index.html which includes the compiled JavaScript and CSS bundles 234 | 4. Pre-compiled component definitions are already available in memory - no fetching required 235 | 5. StandaloneApp receives the pre-compiled runtime object with all app definitions ready 236 | 6. Rendering begins immediately without parsing delays since everything is pre-processed 237 | 238 | **Key Characteristics of Built Deployment:** 239 | - **Optimized Performance**: All source files are pre-parsed and bundled 240 | - **Dependency Bundling**: All XMLUI components and logic are included in the JavaScript bundle 241 | - **Asset Optimization**: CSS is extracted and optimized, resources are processed 242 | - **Production Ready**: Minified, tree-shaken, and optimized for fast loading 243 | - **No Runtime Parsing**: No need to fetch and parse .xmlui files at runtime 244 | 245 | ## The StandaloneApp Component 246 | 247 | The **StandaloneApp** component is the root React component for XMLUI standalone applications. It has these main responsibilities: 248 | 249 | - **Preparing the app's internal representation** - Converts XMLUI source files (.xmlui, .xmlui.xs, config.json, themes) into the internal component definitions and app structure that the XMLUI rendering engine can process. This includes loading sources (either from pre-compiled runtime or by fetching files dynamically), parsing markup, resolving component dependencies, and handling errors. 250 | - **Initiating the rendering** - Delegates to the XMLUI rendering engine by wrapping the prepared app definition to begin the React rendering process. 251 | 252 | ### Internal App Representation 253 | 254 | An XMLUI app is represented as an immutable object in memory composed from the XMLUI app's source files. The `StandaloneApp` component creates this internal representation in different ways depending whether the app uses built or buildless mode. 255 | 256 | **Key Properties:** 257 | - `appDef`: Pre-defined app description (used in inline/test modes) 258 | - `runtime`: Pre-compiled component definitions (for built apps) 259 | 260 | **Built Mode:** The `runtime` property contains pre-compiled component definitions created by the vite-xmlui-plugin during build time. The `mergeAppDefWithRuntime()` function combines any provided `appDef` with the pre-compiled runtime to create the final app representation. 261 | 262 | **Buildless Mode:** When no pre-compiled runtime exists, the `useStandalone` hook implements fallback logic: 263 | 1. Fetches `Main.xmlui` as the entry point using `xmlUiMarkupToComponent()` 264 | 2. Loads `config.json` for app configuration and theme settings 265 | 3. Recursively discovers and loads missing components from the `components/` directory using `collectMissingComponents()` 266 | 4. Parses both `.xmlui` markup files and `.xmlui.xs` code-behind files 267 | 5. Assembles everything into a `StandaloneAppDescription` object with entryPoint, components, themes, and configuration 268 | 269 | The resulting internal representation is a complete app definition that the rendering engine can process regardless of whether it was created from pre-compiled sources or parsed at runtime. 270 | 271 | ### Components Contributing to the Rendering Engine 272 | 273 | Here's a comprehensive table of all objects involved in rendering XMLUI apps: 274 | 275 | | **Object** | **Type** | **Role/Contribution to Rendering** | 276 | |------------|----------|-------------------------------------| 277 | | **StandaloneApp** | React Component | Root component that prepares app internal representation and initiates rendering via ApiInterceptorProvider → AppRoot | 278 | | **ApiInterceptorProvider** | React Component | Wraps the app to provide mocked API functionality and routing context; waits for API interceptor initialization if needed | 279 | | **AppRoot** | React Component | Main rendering orchestrator that wraps app definition in root Container and Theme components; sets up component registry | 280 | | **ComponentProvider** | React Context | Provides component registry that maps component names to their renderer functions; manages core and compound components | 281 | | **StyleProvider** | React Component | Provides CSS-in-JS styling context and theme-based styling capabilities for components | 282 | | **DebugViewProvider** | React Context | Provides debug configuration and development tooling context for the application | 283 | | **AppWrapper** | React Component | Sets up multiple provider layers (Router, QueryClient, HelmetProvider, LoggerProvider, IconProvider, ThemeProvider, etc.) | 284 | | **Router** | React Component | Provides routing functionality (BrowserRouter/HashRouter/MemoryRouter) for navigation and URL management | 285 | | **QueryClientProvider** | React Context | Provides React Query client for data fetching, caching, and server state management | 286 | | **HelmetProvider** | React Context | Manages document head elements (title, meta tags, etc.) for SEO and document metadata | 287 | | **LoggerProvider** | React Context | Provides logging infrastructure and configuration for application-wide logging | 288 | | **IconProvider** | React Context | Provides icon registry and icon rendering functionality throughout the application | 289 | | **ThemeProvider** | React Context | Provides theme context and theme switching functionality throughout the app | 290 | | **InspectorProvider** | React Context | Provides development tools and component inspection capabilities for debugging | 291 | | **ConfirmationModalContextProvider** | React Context | Manages confirmation dialogs and modal interactions throughout the application | 292 | | **AppContent** | React Component | Creates application context with global functions, viewport management, theme info, and app state; provides navigation and utility functions | 293 | | **AppContext.Provider** | React Context | Provides global app functions (navigate, toast, confirm, etc.) and environment information | 294 | | **AppStateContext.Provider** | React Context | Manages application state in "buckets" to avoid prop drilling through component hierarchies | 295 | | **StandaloneComponent** | React Component | Root container renderer that wraps the app definition in a Container component and initiates the renderChild process | 296 | | **renderChild()** | Function | The "jolly-joker" function that recursively processes component definitions into React elements; handles TextNode, Slot, and component rendering | 297 | | **ComponentWrapper** | React Component | Prepares components for XMLUI environment; connects with state management; transforms data operations; routes to ContainerWrapper or ComponentAdapter | 298 | | **ContainerWrapper** | React Component | Manages state containers for components that need state management; wraps components in StateContainer for isolated state | 299 | | **ComponentAdapter** | React Component | Translates XMLUI domain concepts to React concepts; creates RendererContext; handles API-bound components, slots, decorations, and error boundaries | 300 | | **Container** | React Component | Manages component state and provides context for child components; handles state isolation and cleanup | 301 | | **StateContainer** | React Component | Provides isolated state management for container components; manages component lifecycle and state updates | 302 | | **ApiBoundComponent** | React Component | Handles components with API-bound properties and events (DataSource, APICall, FileUpload, etc.) | 303 | | **ComponentDecorator** | React Component | Decorates components with test IDs, inspection attributes, and other development/tooling features | 304 | | **SlotItem** | React Component | Manages template transposition for Slot components in reusable component patterns | 305 | | **ErrorBoundary** | React Component | Catches and displays rendering errors; provides graceful degradation when components fail | 306 | | **RendererContext** | Type/Object | Context object passed to component renderers containing state, renderChild, extractValue, event handlers, and layout info | 307 | | **ComponentRegistry** | Object | Maps component names to their renderer functions; manages core components and user-defined components | 308 | | **LayoutContext** | Object | Provides layout information to components (e.g., whether rendered in horizontal/vertical stack) | 309 | | **ValueExtractor** | Object | Extracts and evaluates property values from component definitions, handling expressions and data binding | 310 | 311 | ### Component Hierarchy Flow 312 | 313 | #### StandaloneApp Hierarchy 314 | 315 | ``` 316 | StandaloneApp 317 | └── ApiInterceptorProvider (API mocking) 318 | └── AppRoot (main orchestrator) 319 | ``` 320 | 321 | This segment provides the foundational app bootstrapping and API infrastructure. StandaloneApp prepares the internal app representation from source files, while ApiInterceptorProvider sets up mocked API capabilities and routing context before delegating to the main rendering orchestrator. 322 | 323 | #### AppRoot Hierarchy 324 | 325 | ``` 326 | AppRoot 327 | └── ComponentProvider (component registry) 328 | └── StyleProvider (CSS-in-JS) 329 | └── DebugViewProvider (debug context) 330 | └── AppWrapper (multiple providers) 331 | ``` 332 | 333 | This segment establishes the core rendering infrastructure and development environment. ComponentProvider sets up the component registry that maps component names to their renderers. StyleProvider enables CSS-in-JS styling capabilities, while DebugViewProvider configures development tooling and debugging context throughout the application. 334 | 335 | #### AppWrapper Hierarchy 336 | 337 | ``` 338 | AppWrapper 339 | └── Router (BrowserRouter/HashRouter/MemoryRouter) 340 | └── QueryClientProvider (React Query) 341 | └── HelmetProvider (document head management) 342 | └── LoggerProvider (logging context) 343 | └── IconProvider (icon registry) 344 | └── ThemeProvider (theme context) 345 | └── InspectorProvider (dev tools) 346 | └── ConfirmationModalContextProvider (modal dialogs) 347 | └── AppContent (app context + state) 348 | ``` 349 | 350 | This segment creates the comprehensive application runtime environment through multiple provider layers. Router handles navigation and URL management, QueryClientProvider manages data fetching and caching, while HelmetProvider controls document metadata. 351 | 352 | The remaining providers establish essential app services: LoggerProvider for application-wide logging, IconProvider for icon registry and rendering, ThemeProvider for theme management, InspectorProvider for development tools, and ConfirmationModalContextProvider for modal dialog interactions. 353 | 354 | #### AppContent Hierarchy 355 | 356 | ``` 357 | AppContent 358 | └── AppContext.Provider (global app functions) 359 | └── AppStateContext.Provider (app state management) 360 | └── StandaloneComponent (root container) 361 | └── renderChild() → ComponentWrapper → ContainerWrapper/ComponentAdapter 362 | ``` 363 | 364 | This segment provides the final application context and initiates the actual component rendering process. AppContext.Provider supplies global app functions like navigation, toast notifications, and utility functions. AppStateContext.Provider manages application state in organized "buckets" to avoid prop drilling. 365 | 366 | StandaloneComponent wraps the app definition in a root Container and calls renderChild() to begin the recursive component rendering process, routing through ComponentWrapper to either ContainerWrapper for stateful components or ComponentAdapter for regular components. 367 | 368 | This architecture ensures proper separation of concerns, with each layer providing specific functionality needed for XMLUI app rendering and execution. 369 | 370 | ## Implementation Details 371 | 372 | This section provides detailed documentation for every component, provider, context, and utility function in the XMLUI rendering pipeline. Each entry includes a concise description, behavior bullets explaining key responsibilities and interactions, and cross-references to related components. Use this as a reference when working with specific parts of the rendering architecture, debugging issues, or understanding how components collaborate to transform XMLUI definitions into rendered React applications. 373 | 374 | ### The `StandaloneApp` Component 375 | 376 | `StandaloneApp` resolves the app's internal representation from precompiled runtime or by parsing sources on-demand, then passes the prepared app definition (entryPoint, components, themes, resources, globals) to `ApiInterceptorProvider` for API mocking setup and to `AppRoot` which wraps it in theme/container roots and starts the rendering pipeline. 377 | 378 | | **Property** | **Role & processing** | 379 | |-------------|-------------------------------------| 380 | | `appDef` | Pre-defined app description (`StandaloneAppDescription`) for inline/test modes. Merged with `runtime` via `mergeAppDefWithRuntime()` to form the final app representation passed to `AppRoot`. | 381 | | `appGlobals` | Global variables and configuration values. Combined with runtime/app-provided globals and forwarded to `AppRoot` as `globalProps`. | 382 | | `decorateComponentsWithTestId` | Enables test ID decoration for E2E testing. Propagated to `AppRoot` and used by `ComponentDecorator` to add `data-testid` attributes. | 383 | | `debugEnabled` | Enables debug logging and development features. Sent to `AppRoot` and debug providers to control logging and dev tooling. | 384 | | `runtime` | Pre-compiled component definitions (`RuntimeProps`) for built apps. `useStandalone` extracts app description, components, themes and sources from it; merged with `appDef` when present. | 385 | | `extensionManager` | Manager for third-party components and extensions. Passed into `ComponentProvider`/`AppRoot` to register or resolve external components. | 386 | | `waitForApiInterceptor` | If true, `ApiInterceptorProvider` delays rendering until the API interceptor is initialized. Controls startup timing for mocked APIs. | 387 | | `children` | Additional child elements included in the rendered app. Forwarded into `AppRoot`/`AppWrapper` and rendered inside the app tree. | 388 | 389 | #### `useStandalone()` 390 | 391 | This hook produces a ready-to-render `StandaloneAppDescription` and, optionally, a `projectCompilation`. It accepts either a precompiled `runtime` or it builds the app at runtime by fetching and compiling source files. 392 | 393 | On mount it resolves any provided `runtime`. If no runtime is available (or buildless mode is required), it fetches `Main.xmlui` and `config.json`. It then loads themes and parses markup and `.xs` code-behinds. Missing components are discovered and fetched recursively. Finally it runs linting, assembles compilation metadata, and sets `standaloneApp` and `projectCompilation` for `StandaloneApp` to consume. 394 | 395 | #### See Also 396 | 397 | - `resolveRuntime()` — convert precompiled runtime entries into a `StandaloneAppDescription` + `projectCompilation`. 398 | - `mergeAppDefWithRuntime()` — shallow-merge inline `appDef` into a resolved runtime. 399 | - `parseComponentMarkupResponse()` — parse `.xmlui` markup into component defs (errors → error components). 400 | - `parseCodeBehindResponse()` — parse `.xs` code-behinds and produce declarations to merge. 401 | - `collectMissingComponents()` — find missing compound components from entryPoint markup. 402 | - `processAppLinting()` — run lint rules and produce a lint error component when severity is `Error`. 403 | - `discoverCompilationDependencies()` — compute component dependency sets for `projectCompilation`. 404 | 405 | ### The `ApiInterceptorProvider` Component 406 | 407 | `ApiInterceptorProvider` wraps the prepared app and provides an API interception layer used for mocking, request routing, and instrumentation. It initializes an interceptor and exposes its lifecycle (start, ready, dispose). When `waitForApiInterceptor` is true the provider can delay rendering until the interceptor reports ready. The interceptor can rewrite, stub, or capture HTTP requests and responses so components see predictable data during development and testing. 408 | 409 | #### Behavior 410 | 411 | - Exposes context hooks and utilities so components can send instrumented requests, read intercepted responses, or register fixtures. 412 | - Supports route- or pattern-based request stubs and passthrough rules. Handlers can proxy requests to a real backend when needed. 413 | - Receives the resolved `StandaloneAppDescription` and forwards it to `AppRoot` once the interceptor permits rendering. It works with `AppContext`/`ApiContext` to expose mocked endpoints and runtime flags, and cooperates with development tooling (inspector, logger) to record traces and replay fixtures. 414 | - On initialization failure the provider either falls back to passthrough mode or blocks rendering depending on configuration. Runtime network or CORS errors are reported via the app's error reporting hooks (for example `errReportScriptError` / `errReportModuleErrors`). 415 | - Keep the provider lightweight — heavy transformations should be implemented as dedicated request handlers registered with the interceptor. 416 | 417 | #### See Also 418 | 419 | - `waitForApiInterceptor` — prop that controls whether rendering waits for interceptor readiness. 420 | - `errReportScriptError()` — report runtime script errors to the app's error reporting subsystem. 421 | - `errReportModuleErrors()` — report module/compilation errors discovered during parsing or runtime. 422 | - `ApiContext` — context object exposing interceptor utilities and runtime flags to components. 423 | 424 | 425 | ### The `AppRoot` Component 426 | 427 | `AppRoot` is the main rendering orchestrator. It receives the resolved `StandaloneAppDescription`, registers components and themes, and mounts the provider stack that supplies styling, routing, data clients, and debugging tools. In short: `AppRoot` turns the prepared app description into a live React environment and hands control to `AppContent`/`StandaloneComponent` to start rendering. 428 | 429 | #### Behavior 430 | 431 | - Installs the `ComponentProvider` registry and registers core plus app-provided component renderers. It merges runtime and inline definitions and exposes the registry to children. 432 | - Wraps the app in styling and utility providers (`StyleProvider`, `QueryClientProvider`, `HelmetProvider`, `LoggerProvider`, `ThemeProvider`, etc.) via `AppWrapper` so components get consistent styling, data fetching, and logging contexts. 433 | - Forwards `globalProps`, `extensionManager`, and runtime flags into `AppContent` so navigation, toasts, theme switching, and extension resolution work at runtime. 434 | - Initiates mounting of `StandaloneComponent` which calls `renderChild()` to recursively translate component definitions into React elements. It also coordinates initial data prefetching and feature-flag/hydration steps when available. 435 | - Surface critical errors early: missing core components, registry failures, or unrecoverable initialization errors are reported through the app's error hooks and may render a fallback error component instead of the app tree. 436 | 437 | #### See Also 438 | 439 | - `ComponentProvider` — component registry used by `AppRoot` to resolve renderers. 440 | - `AppWrapper` — the layered provider composition that `AppRoot` mounts for routing, theming, and tooling. 441 | - `AppContent` — supplies global functions and application state to rendered components. 442 | - `StandaloneComponent` / `renderChild()` — the entry point that begins recursive component rendering. 443 | 444 | ### The `ComponentProvider` Component 445 | 446 | `ComponentProvider` maintains the component registry used throughout the app. It maps XMLUI component names (strings used in `.xmlui` markup) to renderer functions (React renderers or adapters) and manages registration of core, extension, and user-provided components. 447 | 448 | The registry is the single source of truth for resolving component names at render time. XMLUI uses it to decouple markup from implementation, to allow extensions or app code to override renderers, and to supply safe placeholder/error renderers when a referenced component is missing. The registry is treated as effectively read-only during normal runtime to ensure consistent rendering across the tree; updates happen only during initialization or controlled hot-reload flows. 449 | 450 | #### Behavior 451 | 452 | - Initializes the `ComponentRegistry` with core platform components and merges in app-provided or runtime component definitions. 453 | - Exposes resolver functions via context so `renderChild()` and `ComponentWrapper` can look up renderers by component name. Lookups return error or placeholder renderers when components are missing. 454 | - Supports extension points: `extensionManager` can register or override component renderers before the app mounts. 455 | - Protects the registry from accidental runtime mutations; updates are performed only during initialization or explicit hot-reload flows. 456 | - When a requested renderer is missing, the provider triggers error reporting and may return a lint/error component to preserve rendering continuity. 457 | 458 | #### See Also 459 | 460 | - `ComponentRegistry` — the data structure that stores renderer mappings. 461 | - `extensionManager` — registers third-party or app-specific components into the registry. 462 | - `renderChild()` / `ComponentWrapper` — the runtime callers that resolve renderers from the registry. 463 | 464 | 465 | ### The `StyleProvider` Component 466 | 467 | `StyleProvider` supplies the CSS-in-JS and theme context used by components. It wires theme values, design tokens, and runtime style overrides into a context consumable by component renderers and layout helpers. The provider centralizes style computation so components can remain declarative and theme-agnostic. 468 | 469 | Example: markup → computed CSS class 470 | 471 | ```xml 472 | <Stack width="48px" height="24px" backgroundColor="purple" /> 473 | ``` 474 | 475 | The framework may translate those props into a dynamic CSS class applied to the Stack, for example: 476 | 477 | ```css 478 | .stack_autogen_x1y2 { width:48px; height:24px; background-color:purple; } 479 | ``` 480 | 481 | #### Behavior 482 | 483 | - Exposes theme values, token resolvers, and a style renderer (class names or inline styles) via context to all components. 484 | - Applies runtime theme overrides, merges app and runtime theme definitions, and provides a fallback theme when none is supplied. 485 | - Coordinates with `ThemeProvider` (if present) to support theme switching and persistence across sessions. 486 | - Offers utilities for responsive tokens and layout-aware style resolution (for example direction, density, or breakpoint-aware tokens). 487 | - Keeps style calculation performant by memoizing theme-derived values and avoiding per-render recomputation where possible. 488 | 489 | #### See Also 490 | 491 | - `ThemeProvider` — higher-level theme switching and persistence. 492 | - `ComponentDecorator` — may rely on style context to compute inspection overlays or test attributes. 493 | - `LayoutContext` — provides layout information that StyleProvider can use for responsive styling. 494 | 495 | 496 | ### The `DebugViewProvider` Component 497 | 498 | `DebugViewProvider` supplies debug configuration and development tooling hooks to the app. It toggles debugging UI, controls verbose logging levels, and exposes inspection facilities used by developer tools (for example component inspectors and trace overlays). The provider keeps development-only concerns out of production flows by gating features on `debugEnabled` and environment flags. 499 | 500 | #### Behavior 501 | 502 | - Exposes debug flags, inspector toggles, and UI hooks via context so components and dev tools can opt into inspection and enhanced logging. 503 | - Integrates with `ComponentDecorator` and `InspectorProvider` to render overlays, show component metadata, and capture event traces. 504 | - Enables verbose logging and runtime diagnostics when `debugEnabled` is true; otherwise it is a no-op to avoid performance overhead. 505 | - Provides short-lived utilities for tracing renders and network calls; these are disabled in production builds. 506 | 507 | #### See Also 508 | 509 | - `InspectorProvider` — concrete inspector implementation that renders UI overlays. 510 | - `ComponentDecorator` — decorates components with inspection attributes used by the debug view. 511 | - `LoggerProvider` — captures and displays verbose logs when debug tools are active. 512 | 513 | 514 | ### The `AppWrapper` Component 515 | 516 | `AppWrapper` composes the global provider stack the app needs at runtime. It mounts routing, data clients, head management, logging, icons, theming, and other cross-cutting services so application components can assume those services exist. `AppWrapper` keeps the wiring in one place and forwards `children` into the fully provisioned runtime. 517 | 518 | #### Behavior 519 | 520 | - Chooses and mounts a `Router` implementation (Browser/Hash/Memory) based on environment and configuration. 521 | - Creates and provides shared clients such as React Query's `QueryClient`, `HelmetProvider` for document head, and `LoggerProvider` for centralized logging. 522 | - Mounts `IconProvider`, `ThemeProvider`, `InspectorProvider`, and modal/dialog contexts so UI components can rely on a consistent environment. 523 | - Forwards `globalProps` and app-level callbacks into `AppContent` and ensures providers are correctly nested to avoid context shadowing. 524 | - Keeps provider initialization idempotent and supports reinitialization for hot-reload or test harnesses. 525 | 526 | #### See Also 527 | 528 | - `Router` — navigation and URL management choices mounted by `AppWrapper`. 529 | - `QueryClientProvider` — data-fetching client used for server state management. 530 | - `HelmetProvider` — document head manager for title/meta updates. 531 | - `ConfirmationModalContextProvider` — global modal/dialog context used throughout the app. 532 | 533 | 534 | ### The `Router` Component 535 | 536 | `Router` is provided by the external `react-router-dom` package (version 6.26.2). XMLUI does not implement its own router; instead it selects and configures one of three router implementations from `react-router-dom` based on the app's runtime environment and configuration. The router manages client-side navigation, URL state, and history so XMLUI apps can support multi-page navigation without full-page reloads. 537 | 538 | #### Behavior 539 | 540 | - `AppWrapper` selects the router implementation: `MemoryRouter` for preview mode, `HashRouter` when `useHashBasedRouting` is true (the default), or `BrowserRouter` otherwise. 541 | - In preview mode or REMIX environments the app may skip mounting a client-side router entirely and rely on server or parent-frame routing. 542 | - The router receives a `basename` prop (from `routerBaseName`) which prefixes all routes. `HashRouter` ignores `basename` since hash routing uses fragment identifiers. 543 | - XMLUI components use router hooks (`useNavigate`, `useLocation`, etc.) from `react-router-dom` to read or update URL state. The `navigate` function exposed in `AppContext` wraps the router's navigation API. 544 | - The router integrates with XMLUI's `Link`, `NavLink`, and `Redirect` components to enable declarative navigation in markup. 545 | 546 | #### See Also 547 | 548 | - `react-router-dom` (external package) — the library providing `BrowserRouter`, `HashRouter`, and `MemoryRouter`. 549 | - `AppWrapper` — selects and mounts the appropriate router implementation. 550 | - `AppContext.navigate` — global navigation function that uses the router's navigation API. 551 | - `routerBaseName` — prop controlling the base path for all routes. 552 | 553 | 554 | ### The `QueryClientProvider` Component 555 | 556 | `QueryClientProvider` is provided by the external `@tanstack/react-query` package (version 4.36.1). XMLUI uses React Query for declarative data fetching, caching, and server state management. The provider makes a singleton `QueryClient` instance available throughout the app so components can use hooks like `useQuery`, `useMutation`, and `useQueryClient` to manage server data. 557 | 558 | #### Behavior 559 | 560 | - `AppRoot` creates the singleton `queryClient` instance at module scope with default options: `refetchOnWindowFocus` is disabled to prevent unnecessary refetches when switching browser tabs. 561 | - `AppWrapper` wraps the entire app in `QueryClientProvider` and passes the singleton client. The provider sits at the outermost layer (alongside `ErrorBoundary`) so all nested components can access React Query hooks. 562 | - XMLUI components like `DataSource`, `APICall`, and `FileUpload` use React Query internally to handle async data operations, automatic retries, background refetching, and optimistic updates. 563 | - The client is shared across all components and routes so query results are cached and deduplicated. Multiple components requesting the same query key receive the same cached data. 564 | - In development mode XMLUI can optionally mount `@tanstack/react-query-devtools` to provide query inspection and cache debugging tools. 565 | 566 | #### See Also 567 | 568 | - `@tanstack/react-query` (external package) — the library providing `QueryClient`, `QueryClientProvider`, and React Query hooks. 569 | - `AppRoot` — creates the singleton `queryClient` instance used throughout the app. 570 | - `AppWrapper` — mounts `QueryClientProvider` at the outermost provider layer. 571 | - `AppContext.queryClient` — exposes the query client instance to app code for imperative cache operations. 572 | 573 | 574 | ### The `HelmetProvider` Component 575 | 576 | `HelmetProvider` is provided by the external `react-helmet-async` package (version 1.3.0). XMLUI uses React Helmet Async to manage document head elements like `<title>`, `<meta>` tags, and `<link>` tags declaratively from within components. The provider enables server-side rendering (SSR) compatibility by tracking head changes asynchronously and allows multiple components to contribute head elements that are automatically deduplicated and merged. 577 | 578 | #### Behavior 579 | 580 | - `AppWrapper` mounts `HelmetProvider` near the top of the provider stack and includes a default `Helmet` component that sets the site title template (`%s | ${siteName}`) so pages can declare their titles without repeating the site name. 581 | - In SSR or preview environments `AppWrapper` sets `HelmetProvider.canUseDOM = false` to disable direct DOM manipulation and enable server-side head rendering. 582 | - XMLUI components and app code can use the `Helmet` component from `react-helmet-async` to declaratively set document metadata. Multiple `Helmet` instances merge their changes and the last-mounted instance takes precedence for conflicting values. 583 | - The provider supports all standard head elements: title, meta tags (description, keywords, Open Graph, Twitter cards), link tags (canonical URLs, favicons, stylesheets), script tags, and base tags. 584 | - Changes made through `Helmet` are automatically cleaned up when components unmount so the document head stays synchronized with the current component tree. 585 | 586 | #### See Also 587 | 588 | - `react-helmet-async` (external package) — the library providing `HelmetProvider` and `Helmet` components for document head management. 589 | - `AppWrapper` — mounts `HelmetProvider` and configures the default title template. 590 | - `Helmet` — the component used within XMLUI apps to set document head elements declaratively. 591 | 592 | 593 | ### The `LoggerProvider` Component 594 | 595 | `LoggerProvider` is an internal XMLUI component that maintains a centralized log storage and provides logging capabilities throughout the app. It collects log entries with timestamps so development tools and debug views can display application activity and diagnostic information. The provider is lightweight and acts as a bridge between the global logger singleton and React's component tree. 596 | 597 | #### Behavior 598 | 599 | - Maintains an in-memory array of log entries where each entry includes a timestamp and the logged arguments. Log entries accumulate during the app session for inspection by debug tools. 600 | - Exposes the `useLogger` hook that returns `logs` (all collected entries) and `addLog` (function to append new entries). Components can use this hook to record events or retrieve the log history. 601 | - Integrates with `LoggerInitializer` which registers a callback with the global logger singleton so all logger calls (`logger.log`, `logger.warn`, `logger.error`, etc.) are captured and stored in the provider's state. 602 | - Works with `DebugViewProvider` and `InspectorProvider` to surface logs in development UIs. When debug mode is disabled the logger still captures entries but they may not be displayed. 603 | - The provider does not persist logs across page refreshes; it is intended for runtime debugging and inspection only. 604 | 605 | #### See Also 606 | 607 | - `LoggerInitializer` — registers the provider's callback with the global logger singleton to capture log calls. 608 | - `useLogger` — hook that exposes log entries and the `addLog` function to components. 609 | - `DebugViewProvider` — uses logger data to display debug information and diagnostics. 610 | - Global logger singleton — the shared logger instance (`logger.log`, `logger.warn`, `logger.error`) that sends entries to the provider. 611 | 612 | 613 | ### The `IconProvider` Component 614 | 615 | `IconProvider` maintains the icon registry used throughout the XMLUI app. It maps icon names (strings used in XMLUI markup and components) to icon renderer functions and manages both built-in icons from the `react-icons` package (version 4.12.0) and custom XMLUI-specific icons. The provider enables declarative icon usage and supports dynamic loading of custom SVG icons from app resources. 616 | 617 | #### Behavior 618 | 619 | - Initializes the icon registry by registering hundreds of built-in icons from `react-icons` libraries (Feather Icons via `react-icons/fi`, AntDesign icons via `react-icons/ai`, Bootstrap icons via `react-icons/bs`, and others) plus custom XMLUI icons (check, chevron, warning, etc.). 620 | - Exposes resolver functions via context through the `useIconRegistry` hook. Components like `Icon` use `lookupIconRenderer(name)` to resolve icon names to renderer functions at runtime. 621 | - Supports custom SVG icons loaded from app resources via `ensureCustomSvgIcon(resourceUrl)`. Custom SVGs are fetched, parsed, and added to a hidden sprite element in the DOM for efficient rendering. 622 | - Returns the full list of registered icon names via `getRegisteredIconNames()` for tooling, autocomplete, and documentation purposes. 623 | - The registry is populated at module load time and remains read-only during runtime to ensure consistent icon resolution across the app. 624 | 625 | #### See Also 626 | 627 | - `react-icons` (external package) — provides the built-in icon library with hundreds of icons from popular icon sets. 628 | - `useIconRegistry` — hook that exposes icon registry functions (`lookupIconRenderer`, `getRegisteredIconNames`, `ensureCustomSvgIcon`) to components. 629 | - `Icon` component — the main consumer of the icon registry that renders icons by name. 630 | - Custom XMLUI icons — XMLUI-specific icon components defined in `src/components/Icon/` for specialized UI needs. 631 | 632 | 633 | ### The `ThemeProvider` Component 634 | 635 | `ThemeProvider` is an internal XMLUI component that manages the theming system throughout the app. It handles theme selection, tone switching (light/dark mode), theme extension chains, CSS variable generation, and font/resource loading. The provider enables declarative theming where components reference theme variables without coupling to specific color values or styles. 636 | 637 | #### Behavior 638 | 639 | - Maintains the active theme and tone (light or dark) and exposes them via `useTheme` and `useThemes` hooks. Components can query the current theme, switch themes dynamically, or toggle between light and dark tones. 640 | - Supports built-in themes (XmlUi, XmlUiCyan, XmlUiGray, XmlUiGreen, XmlUiOrange, XmlUiPurple, XmlUiRed) plus app-provided custom themes. Themes can extend other themes to create hierarchical theme chains where values cascade and override. 641 | - Generates CSS variables dynamically from theme definitions at runtime. Theme variables (`--xmlui-spacing-md`, `--xmlui-color-primary`, etc.) are injected into the DOM and consumed by component styles for consistent theming. 642 | - Loads fonts and resources declared in theme definitions. Font URLs are converted to `<link>` tags in the document head while other resources are mapped to accessible URLs via the resource resolver. 643 | - Coordinates with `StyleProvider` to apply theme-aware styling and with the `Theme` component to create nested theme scopes where child components inherit or override parent theme values. 644 | - Persists theme and tone selections across sessions when configured. The provider can restore the user's last selected theme/tone on app restart. 645 | 646 | #### See Also 647 | 648 | - `useTheme` — hook that returns the current theme definition and tone; components use this to access theme variables programmatically. 649 | - `useThemes` — hook that returns available themes and functions to switch themes or toggle tones. 650 | - `StyleProvider` — works with ThemeProvider to apply theme-aware CSS-in-JS styling. 651 | - `Theme` component — creates nested theme scopes where children can inherit or override theme values. 652 | - Built-in themes — the default theme set (XmlUi, XmlUiCyan, etc.) defined in `src/components-core/theming/themes/`. 653 | 654 | 655 | ### The `InspectorProvider` Component 656 | 657 | `InspectorProvider` is an internal XMLUI component that powers the developer tools and component inspection system. It maintains a registry of inspectable components in the running app and provides interactive debugging features like click-to-inspect component trees, source code viewing, and runtime property inspection. The provider is designed for development environments and is typically disabled in production builds. 658 | 659 | #### Behavior 660 | 661 | - Maintains a registry of all inspectable components currently mounted in the app. Components register themselves via the `attach` callback and deregister on unmount via `detach` so the inspector always sees the current component tree. 662 | - Supports inspect mode where clicking on rendered components in the app selects them for inspection. When a component is selected the inspector displays its definition, props, state, and location in the source files. 663 | - Provides source code viewing via integration with `InspectorDialog` and `AppWithCodeViewNative`. The inspector can display the `.xmlui` markup and `.xs` code-behind for the selected component when `sources` are available. 664 | - Exposes inspection functions via `useDevTools`, `useInspector`, and `useInspectMode` hooks. Components and debug UIs use these hooks to control inspect mode, query inspected nodes, and access compilation metadata. 665 | - Renders floating `InspectButton` components over inspectable elements when inspect mode is active. These buttons provide visual feedback and enable click-to-inspect functionality. 666 | - Integrates with `projectCompilation` to provide detailed type information, component dependencies, and linting results in the inspector UI. 667 | 668 | #### See Also 669 | 670 | - `useDevTools` — hook that exposes inspector state and controls (open/close inspector, inspect mode toggle). 671 | - `useInspector` — hook that returns the currently inspected component node and inspection utilities. 672 | - `InspectorDialog` — the UI component that displays detailed component inspection information. 673 | - `ComponentViewer` — renders the visual inspector overlay when components are being inspected. 674 | 675 | 676 | ### The `ConfirmationModalContextProvider` Component 677 | 678 | `ConfirmationModalContextProvider` is an internal XMLUI component that manages confirmation dialogs and modal prompts throughout the app. It provides a promise-based API for displaying modal dialogs that require user confirmation or selection. The provider centralizes modal management so components don't need to maintain local modal state. 679 | 680 | #### Behavior 681 | 682 | - Exposes the `useConfirm` hook that returns a `confirm` function. Calling `confirm(title, message, actionLabel)` displays a modal dialog and returns a promise that resolves with the user's choice (true for confirm, false for cancel). 683 | - Supports custom button configurations where callers can specify multiple buttons with different labels, variants, theme colors, and return values. The promise resolves with the `value` property of the clicked button. 684 | - Auto-focuses the last button in the dialog when the modal opens so users can quickly confirm or cancel via keyboard (Enter/Escape). Focus management ensures accessibility and good UX. 685 | - Renders a single `Dialog` component instance that is reused for all confirmation prompts. The dialog content (title, message, buttons) updates based on the current confirmation request. 686 | - Handles concurrent confirmation requests by queueing them. Only one confirmation dialog is displayed at a time; subsequent requests wait for the previous dialog to close. 687 | - Integrates with `AppContent` which wraps the `confirm` function and exposes it via `AppContext` so components can trigger confirmations using `appContext.confirm(...)`. 688 | 689 | #### See Also 690 | 691 | - `useConfirm` — hook that exposes the `confirm` function for displaying confirmation dialogs. 692 | - `Dialog` component — the UI component that renders the modal dialog container and backdrop. 693 | - `AppContext.confirm` — global confirmation function exposed to all components via app context. 694 | - `Button` component — used to render the action buttons in confirmation dialogs. 695 | 696 | 697 | ### The `AppContent` Component 698 | 699 | `AppContent` creates the application context layer that provides global functions, viewport information, theme management, and app state infrastructure to all components. It sits just inside the provider stack and wraps the root container component. The component assembles the `AppContextObject` with dozens of utility functions and environment properties that components access via `useAppContext`. 700 | 701 | #### Behavior 702 | 703 | - Creates and provides `AppContext` with global functions including `navigate` (routing), `toast` (notifications), `confirm` (modal dialogs), date utilities, math functions, file utilities, and miscellaneous helpers. Components use `useAppContext()` to access these functions. 704 | - Manages viewport detection by reading CSS custom properties from the theme and creating media queries for different breakpoints (phone, tablet, desktop, large desktop). Exposes `mediaSize` object with viewport dimensions and responsive flags. 705 | - Handles theme management integration by exposing `activeThemeId`, `activeThemeTone`, `setTheme`, `setThemeTone`, `toggleThemeTone` functions. Supports keyboard shortcuts (Alt+Ctrl+Shift+T for theme, Alt+Ctrl+Shift+O for tone). 706 | - Provides environment information including `standalone` flag, `debugEnabled` flag, `appIsInShadowDom` detection, iframe embedding status, window focus state, and XMLUI version. 707 | - Creates `AppStateContext` for bucket-based state management where components can store and retrieve state by bucket name without prop drilling. Provides `update(bucket, patch)` function to merge updates. 708 | - Handles hash-based anchor scrolling for single-page navigation. Listens to location changes and scrolls to anchors in both light DOM and shadow DOM environments. 709 | - Collects registered action functions from the component registry and exposes them via the `Actions` object so markup can reference custom app actions. 710 | 711 | #### See Also 712 | 713 | - `useAppContext` — hook that returns the global `AppContextObject` with all utility functions and environment properties. 714 | - `AppContext.Provider` — the React context provider that makes the app context available to components. 715 | - `AppStateContext.Provider` — the React context provider for bucket-based state management. 716 | - `StandaloneComponent` — receives the root container and begins recursive component rendering. 717 | 718 | 719 | ### The `AppContext.Provider` Component 720 | 721 | `AppContext.Provider` is the React context provider that supplies the global `AppContextObject` to all components in the XMLUI app. The context object contains utility functions, environment information, theme controls, navigation helpers, and integration points that components access via the `useAppContext` hook. This provider enables components to interact with app-level services without explicit prop passing. 722 | 723 | #### Behavior 724 | 725 | - Provides `navigate` function wrapping `react-router-dom`'s navigation API for programmatic routing. Components call `appContext.navigate(path)` to change routes. 726 | - Provides `toast` function from `react-hot-toast` for displaying temporary notifications. Supports success/error/info variants with customizable duration and positioning. 727 | - Provides `confirm` function from `ConfirmationModalContextProvider` for displaying modal dialogs that return promises. Components use `await appContext.confirm(title, message)` for user confirmations. 728 | - Exposes theme controls (`activeThemeId`, `activeThemeTone`, `setTheme`, `setThemeTone`, `toggleThemeTone`) so components can query or change the active theme and tone. 729 | - Exposes viewport information via `mediaSize` object containing breakpoint flags (`isPhone`, `isTablet`, `isDesktop`, etc.) and dimension values. Components use this for responsive behavior. 730 | - Provides environment flags including `standalone` (standalone app mode), `debugEnabled` (debug tooling active), `appIsInShadowDom` (shadow DOM detection), `isInIFrame`, and `isWindowFocused`. 731 | - Exposes utility functions including date formatting, math operations, file utilities (`formatFileSizeInBytes`, `getFileExtension`), delay functions, and path-based property access via Lodash `get`. 732 | - Provides `queryClient` (React Query singleton), `apiInterceptorContext` (API mocking state), `loggedInUser` (authentication state), and `Actions` (registered action functions). 733 | 734 | #### See Also 735 | 736 | - `useAppContext` — hook that components use to access the `AppContextObject` with all global functions and properties. 737 | - `AppContent` — the component that creates and populates the `AppContextObject` before passing it to the provider. 738 | - `AppContextObject` type — TypeScript interface defining all properties available in the app context. 739 | 740 | 741 | ### The `AppStateContext.Provider` Component 742 | 743 | `AppStateContext.Provider` enables bucket-based state management throughout the XMLUI app. It provides a centralized state store organized into named buckets where components can store and retrieve state without prop drilling. The provider uses the `use-context-selector` library for optimized re-rendering so components only re-render when their selected bucket changes. 744 | 745 | #### Behavior 746 | 747 | - Maintains `appState` as a two-level object where top-level keys are bucket names and values are bucket-specific state objects. Each bucket is isolated from others. 748 | - Provides `update(bucket, patch)` function that merges the patch object into the specified bucket. Uses shallow merge so components can update individual properties without replacing the entire bucket. 749 | - Supports optimized context selection via `useAppStateContextPart(selector)` hook from `use-context-selector`. Components specify a selector function to subscribe only to specific buckets or values. 750 | - Enables components to share state without parent-child prop passing. Any component can read or write to any bucket by name, making it useful for cross-cutting concerns like form state, UI preferences, or feature flags. 751 | - Initializes with empty state (`EMPTY_OBJECT`) and populates buckets on-demand as components write to them. Buckets are created lazily when first accessed. 752 | - The provider sits immediately inside `AppContext.Provider` so state management has access to the full app context for utilities and environment information. 753 | 754 | #### See Also 755 | 756 | - `useAppStateContextPart` — hook that components use to subscribe to specific buckets or values from the app state with optimized re-rendering. 757 | - `IAppStateContext` interface — TypeScript type defining the shape of the app state context (`appState` object and `update` function). 758 | - `use-context-selector` package — external library providing optimized context selection to prevent unnecessary re-renders. 759 | - `AppContent` — the component that creates the app state infrastructure and provides both AppContext and AppStateContext. 760 | 761 | 762 | ### The `StandaloneComponent` Component 763 | 764 | `StandaloneComponent` is the entry point for rendering the resolved XMLUI app definition. It receives the root component node (typically the app's entry point from `Main.xmlui`) and wraps it in a `Container` if needed to provide initial state management. The component then calls `renderChild` to begin the recursive rendering process that transforms the component definition tree into React elements. 765 | 766 | #### Behavior 767 | 768 | - Wraps the root node in a `Container` component if it isn't already one. This ensures the app has a root state container for managing top-level state, functions, and variables. 769 | - Accepts optional `functions` and `vars` props that are merged into the root container. These provide global functions and variables accessible throughout the app. 770 | - Calls `renderChild` with the root container node and minimal context (empty state, noop callbacks) to initiate the recursive component rendering process. `renderChild` is the core rendering function that processes component definitions. 771 | - Maintains a `memoedVarsRef` for caching computed variables across renders to optimize performance. This ref is passed down through the rendering tree. 772 | - Supports `children` prop that can be injected into the rendered root. If children are provided and the rendered result is a valid React element, it clones the element and inserts the children. 773 | - Acts as the bridge between the prepared app definition (from `StandaloneApp` → `AppRoot` → `AppContent`) and the actual component rendering tree (via `renderChild` → `ComponentWrapper` → renderers). 774 | 775 | #### See Also 776 | 777 | - `renderChild` — the core recursive rendering function that transforms component definitions into React elements. 778 | - `Container` component — the state container that wraps components needing isolated state management. 779 | - `ComponentWrapper` — receives rendered components and routes them to ContainerWrapper or ComponentAdapter. 780 | - `AppContent` — renders `StandaloneComponent` with the root container node to begin app rendering. 781 | 782 | 783 | ### The `ComponentWrapper` Component 784 | 785 | `ComponentWrapper` is the outermost React component wrapping every XMLUI component in the rendering tree. It receives component definitions from `renderChild`, performs data transformation (DataSource, loaders, data props), determines whether the component needs state management, and routes to either `ContainerWrapper` (for stateful components) or `ComponentAdapter` (for stateless components). It acts as a dispatcher and data preprocessor, while `ComponentAdapter` performs the actual semantic translation from XMLUI domain concepts to React representation. 786 | 787 | #### Behavior 788 | 789 | - Transforms child `DataSource` components into `loaders` on the parent node so data fetching is handled consistently. DataSources declared as children become loader definitions. 790 | - Transforms string `data` props into `DataSource` components with `url` props. This enables declarative data fetching where `data="https://api.example.com/users"` automatically fetches and provides the data. 791 | - Transforms `dataSourceRef` props (references to loaders by UID) into `DataSourceRef` component types so components can reference data from other loaders. 792 | - Transforms `raw_data` props into resolved `data` props with `__DATA_RESOLVED` flag to indicate the data is already available and doesn't need fetching. 793 | - Uses `isContainerLike(node)` to determine if the component needs state management. Components with `loaders`, `vars`, `uses`, `contextVars`, `functions`, or `scriptCollected` are container-like. 794 | - Routes container-like components to `ContainerWrapper` which wraps them in `StateContainer` for isolated state management. Routes other components to `ComponentAdapter` for direct rendering. 795 | - Maintains stable `layoutContext` ref across renders to prevent unnecessary re-renders when layout context hasn't changed. 796 | - Memoized with `React.memo` to prevent re-rendering when props haven't changed. Uses `forwardRef` to support ref forwarding for DOM element access. 797 | 798 | #### See Also 799 | 800 | - `isContainerLike` — function that determines if a component needs wrapping in a state container. 801 | - `ContainerWrapper` — handles stateful components by wrapping them in `StateContainer` for isolated state. 802 | - `ComponentAdapter` — handles stateless components by translating XMLUI concepts to React and calling renderers. 803 | - `renderChild` — the function that calls `ComponentWrapper` for each component in the tree. 804 | 805 | 806 | ### The `ContainerWrapper` Component 807 | 808 | `ContainerWrapper` manages stateful components by wrapping them in `StateContainer` to provide isolated state management, component APIs, and lifecycle coordination. It receives components that need state (identified by `isContainerLike`) and ensures they have a `Container` wrapper with proper state isolation from parent and sibling components. 809 | 810 | #### Behavior 811 | 812 | - Checks if the component node is already a `Container` type. If not, wraps it automatically by calling `getWrappedWithContainer` which creates a Container and moves state-related properties (`loaders`, `vars`, `functions`, `uses`, `api`, `contextVars`) from the component to the wrapper. 813 | - Wraps the containerized node in `ErrorBoundary` to catch and handle rendering errors gracefully. Errors in one container don't crash the entire app. 814 | - Delegates to `StateContainer` which manages the actual state lifecycle: initializing state from `vars` and `loaders`, dispatching state updates, tracking state changes via `statePartChanged`, and cleaning up on unmount. 815 | - Passes `isImplicit` flag to `StateContainer` indicating whether the container was auto-created (implicit) or explicitly declared in markup. Implicit containers are optimized differently. 816 | - Forwards parent context including `parentState`, `parentStatePartChanged`, `parentRegisterComponentApi`, `parentDispatch` so the container can interact with parent state and register its API. 817 | - Maintains `layoutContextRef` for stable layout context passing and `uidInfoRef` for component UID tracking and API registration. 818 | - Memoized with `React.memo` and supports `forwardRef` for ref forwarding to child components. 819 | 820 | #### See Also 821 | 822 | - `StateContainer` — the component that manages container state lifecycle, loaders, variables, and component APIs. 823 | - `isContainerLike` — function that identifies components needing state management based on their properties. 824 | - `getWrappedWithContainer` — function that wraps non-Container components in a Container and moves state properties. 825 | - `ComponentWrapper` — routes components to ContainerWrapper when they need state management. 826 | - `ErrorBoundary` — catches rendering errors within containers to prevent app crashes. 827 | 828 | 829 | ### The `ComponentAdapter` Component 830 | 831 | `ComponentAdapter` translates XMLUI component definitions into their React representation. It receives prepared component nodes from `ComponentWrapper`, creates the `RendererContext` with all necessary rendering utilities (state access, event handlers, value extraction, child rendering), looks up the component renderer from the registry, and executes it to produce the final React element. It handles special cases including API-bound components, Slot transposition, component decoration with test IDs, error boundaries, and behavior attachment. 832 | 833 | #### Behavior 834 | 835 | - Creates unique UIDs for each component instance and manages component lifecycle including cleanup callbacks when components unmount. 836 | - Builds the `RendererContext` object containing all utilities needed by renderers: `state`, `updateState`, `extractValue`, `lookupEventHandler`, `lookupAction`, `renderChild`, `registerComponentApi`, `extractResourceUrl`, and layout information. 837 | - Resolves layout properties from component props using the current theme and layout context. Computes CSS classes via `useComponentStyle` and applies responsive styling based on viewport breakpoints. 838 | - Looks up the component renderer function from the `ComponentRegistry` and executes it with the prepared context. Handles missing renderers by displaying `UnknownComponent` warnings. 839 | - Wraps API-bound components (those with `DataSource`, `APICall`, `FileUpload` props/events) in `ApiBoundComponent` for automatic data loading and transformation. 840 | - Decorates visual components with test IDs via `ComponentDecorator` when `decorateComponentsWithTestId` is enabled. Adds `data-testid` and `data-inspectId` attributes for E2E testing and inspection. 841 | - Handles `Slot` components specially by delegating to `slotRenderer` which transposes children from parent components into compound component slots for template composition. 842 | - Attaches core behaviors to rendered components where applicable. Behaviors can augment components with cross-cutting concerns like accessibility enhancements or development tooling. 843 | 844 | #### See Also 845 | 846 | - `RendererContext` — the context object passed to component renderers containing all rendering utilities and state. 847 | - `ComponentRegistry` — maps component names to renderer functions; used by ComponentAdapter to resolve renderers. 848 | - `ApiBoundComponent` — wraps components with API-bound props/events to handle data loading and event execution. 849 | - `ComponentDecorator` — decorates components with test IDs and inspection attributes for development tooling. 850 | - `SlotItem` / `slotRenderer` — handle Slot transposition for compound component template composition. 851 | 852 | 853 | ### The `Container` Component 854 | 855 | `Container` is the core component that implements XMLUI's stateful component behavior. It manages component state including variables, loaders, functions, and component APIs. It executes event handlers written in XMLUI's scripting language, coordinates async operations, handles state updates via a reducer pattern, and provides the complete state context to child components. The Container acts as the state management boundary where component-specific state is isolated from parent and sibling components. 856 | 857 | #### Behavior 858 | 859 | - Receives `componentState` from `StateContainer` and manages state updates via the container reducer through `dispatch` actions. State changes are coordinated through action types like `COMPONENT_STATE_CHANGED` and `STATE_PART_CHANGED`. 860 | - Executes synchronous and asynchronous event handlers written in XMLUI script via `runCodeSync` and `runCodeAsync`. Parses handler code into statement trees, evaluates them in a binding context with access to state and app utilities, and applies resulting state changes via proxied state objects. 861 | - Manages component lifecycle including mounting, updating, and cleanup. Registers component APIs via `registerComponentApi` so parent components can access child component methods and properties. 862 | - Provides complete evaluation context to scripts including `appContext` (global utilities), `localContext` (proxied state), `eventArgs` (event parameters), and implicit context (component-specific utilities like `navigate`, `apiInstance`, `lookupAction`). 863 | - Handles loader components that fetch external data via `LoaderComponent`. Coordinates data loading, caching, error handling, and provides loaded data to component state. 864 | - Implements two-way data binding and state synchronization. Detects state changes via proxy change tracking, batches updates, and triggers re-renders when state parts change. 865 | - Supports implicit containers (auto-created by `ContainerWrapper`) and explicit containers (declared in markup). Implicit containers delegate to parent dispatch while explicit containers maintain isolated state. 866 | 867 | #### See Also 868 | 869 | - `StateContainer` — wraps Container and manages the state reducer, state merging, variable resolution, and API registration. 870 | - `ContainerActionKind` — defines action types for the container reducer including state changes, loader updates, and API registrations. 871 | - `buildProxy` — creates proxied state objects that track changes for two-way binding and state synchronization. 872 | - `processStatementQueue` / `processStatementQueueAsync` — execute parsed XMLUI script statements synchronously or asynchronously. 873 | - `LoaderComponent` — handles external data loading within containers via DataSource and loader definitions. 874 | 875 | 876 | ### The `StateContainer` Component 877 | 878 | `StateContainer` wraps the `Container` component and manages the complete state lifecycle for stateful XMLUI components. It initializes the container reducer, resolves variables and functions from code-behind scripts, merges parent state with local state via the `uses` property, manages component API registration, and provides the final combined state to the Container. It coordinates state from multiple sources including parent state, routing parameters, context variables, computed variables, and component APIs. 879 | 880 | #### Behavior 881 | 882 | - Creates the container reducer via `createContainerReducer` and initializes component state with `useReducer`. The reducer handles all state mutations including component state changes, loader updates, and state part changes. 883 | - Extracts scoped state from parent via `uses` property which specifies which parent state fields the container should access. Merges this with local state and context variables to create the complete state context. 884 | - Resolves computed variables and functions from code-behind `.xs` files and inline `vars`/`functions` definitions. Collects variable dependencies, performs two-pass resolution to handle forward references, and memoizes computed values for performance. 885 | - Manages component API registration where child components expose methods and properties to parents. Collects APIs via `registerComponentApi` callback and merges them into component state so they're accessible as state properties. 886 | - Provides routing context variables including `$pathname`, `$routeParams`, `$queryParams`, and `$linkInfo` which are automatically available in component state for route-aware components. 887 | - Implements `statePartChanged` callback that determines whether state changes belong to the local container or should propagate to parent. Routes state updates to the correct scope based on variable ownership. 888 | - Wraps the Container in `ErrorBoundary` to catch and display code-behind parsing errors and runtime errors. Throws `CodeBehindParseError` when module errors are detected during script parsing. 889 | 890 | #### See Also 891 | 892 | - `Container` — the core stateful component that StateContainer wraps; handles state execution and event processing. 893 | - `createContainerReducer` — factory function that creates the reducer for managing container state mutations. 894 | - `extractScopedState` — extracts parent state fields specified in the `uses` property for state scoping. 895 | - `useVars` — hook that resolves computed variables and functions with dependency tracking and memoization. 896 | - `collectFnVarDeps` — collects variable dependencies from function definitions to determine resolution order. 897 | 898 | 899 | ### The `ApiBoundComponent` Component 900 | 901 | `ApiBoundComponent` transforms components with API-bound properties and events (DataSource, APICall, FileUpload, FileDownload) into components with automatic data loading and event handling capabilities. It wraps API operation definitions into loaders, generates event handler functions that call the appropriate actions, exposes component APIs for manual data fetching and updates, and delegates rendering to the standard component pipeline with the transformed node. 902 | 903 | #### Behavior 904 | 905 | - Transforms API-bound props (properties with DataSource or DataSourceRef types) into loader definitions. Each API-bound prop becomes a DataLoader component that manages data fetching, caching, and state. 906 | - Generates event handler functions for API-bound events (APICall, FileUpload, FileDownload) by creating JavaScript code that calls global Actions (upload, download, callApi) with bound parameters and nested success/error handlers. 907 | - Exposes component APIs for programmatic data control including `fetch_{prop}` (refetch data), `update_{prop}` (update cached data), `addItem_{prop}`, `getItems_{prop}`, and `deleteItem_{prop}` for collection manipulation. 908 | - Injects loader state into component props so `data` prop receives `{loader.value}`, `loading` receives loader progress state, `pageInfo` receives pagination metadata, and events like `requestRefetch` are automatically wired to loader methods. 909 | - Supports prefetched content integration where loader values fallback to `appGlobals.prefetchedContent` for initial render optimization before actual data loads. 910 | - Handles DataSourceRef components (references to existing loaders by UID) by creating references instead of duplicate loaders for shared data sources. 911 | - Wraps the transformed node with loaders, computed variables, and API methods then delegates to `renderChild` for standard rendering through ComponentWrapper and Container layers. 912 | 913 | #### See Also 914 | 915 | - `DataLoader` — the loader component type created for each API-bound property to manage data fetching. 916 | - `Actions.callApi` / `Actions.upload` / `Actions.download` — global action functions called by generated event handlers. 917 | - `parseAttributeValue` — parses URL attributes to determine if they're static or dynamic for prefetch key generation. 918 | - `ComponentWrapper` — receives the transformed node from ApiBoundComponent and routes it through the rendering pipeline. 919 | 920 | 921 | ### The `ComponentDecorator` Component 922 | 923 | `ComponentDecorator` adds custom attributes to the DOM nodes of rendered components for development tooling, testing, and debugging purposes. It injects attributes like `data-testid` and `data-inspectId` into component DOM elements even when components don't forward refs properly. The decorator uses hidden sibling elements to locate the target DOM node when direct ref access isn't available. 924 | 925 | #### Behavior 926 | 927 | - Accepts an `attr` object containing attribute name-value pairs to inject into the child component's DOM element. Common attributes include `data-testid` (for E2E testing) and `data-inspectId` (for component inspection). 928 | - Attempts to access the child component's DOM node via ref forwarding. If the component handles refs the decorator attaches directly to that ref. 929 | - When ref forwarding isn't available renders hidden helper `<span>` elements before and after the child component. Uses these siblings' refs to locate the actual DOM node via `nextElementSibling` traversal. 930 | - Sets attributes on the located DOM node via `setAttribute` in a `useLayoutEffect` hook. Removes attributes when their values are undefined to clean up no-longer-needed attributes. 931 | - Supports `allowOnlyRefdChild` mode where decoration only happens if the component properly handles refs. Used for compound components or modal dialogs where sibling-based location isn't reliable. 932 | - Calls `onTargetMounted` callback when the target DOM node is located and mounted. Used by inspector tools to refresh inspection state after dynamic component mounting. 933 | 934 | #### See Also 935 | 936 | - `ComponentAdapter` — uses ComponentDecorator to inject test IDs and inspection attributes into visual components. 937 | - `useInspector` — provides `inspectId` values that ComponentDecorator injects for component inspection tooling. 938 | - `composeRefs` — from `@radix-ui/react-compose-refs` used to merge forwarded refs with the decorator's internal ref. 939 | 940 | 941 | ### The `SlotItem` Component 942 | 943 | `SlotItem` implements template transposition for Slot components in XMLUI's compound component system. It receives slot content defined in the parent component's markup, wraps it in a Container with context variables derived from slot props, and renders the content so it has access to data pushed from the compound component. Slots enable compound components to accept customizable template fragments from parent components. 944 | 945 | #### Behavior 946 | 947 | - Receives slot content as `node` (component definition or array of definitions) from the parent component where the compound component is used with custom child markup. 948 | - Transforms slot props (passed from the compound component) into context variables prefixed with `$`. For example a slot prop `item` becomes context variable `$item` accessible in the slot content. 949 | - Wraps the slot content in a Container with `contextVars` set to the transformed slot props. This Container creates a new state scope where slot content can access compound component data. 950 | - Delegates to `renderChild` to render the containerized slot content through the standard rendering pipeline (ComponentWrapper → ContainerWrapper/ComponentAdapter). 951 | - Memoized with `React.memo` and uses shallow comparison memoization for slot props to prevent unnecessary re-renders when slot props haven't changed. 952 | - Enables compound components to inject data into parent-provided templates. For example a `List` compound component can pass `$item` and `$index` to custom slot content for each list item. 953 | 954 | #### See Also 955 | 956 | - `Slot` component — the placeholder in compound component markup that SlotItem renders content into. 957 | - `slotRenderer` — the renderer function in ComponentAdapter that delegates to SlotItem for Slot transposition. 958 | - `CompoundComponent` — the infrastructure that enables template composition with slots and context variable injection. 959 | - `Container` — wraps slot content to provide the context variable scope for slot props. 960 | 961 | 962 | ### The `ErrorBoundary` Component 963 | 964 | `ErrorBoundary` is a React error boundary component that catches rendering errors in child components and displays a fallback error UI instead of crashing the entire app. It implements React's error boundary lifecycle methods (`getDerivedStateFromError` and `componentDidCatch`) to intercept errors during the rendering phase and provide graceful degradation when components fail to render. 965 | 966 | #### Behavior 967 | 968 | - Implements `getDerivedStateFromError` static method to capture errors thrown during rendering, lifecycle methods, or constructors of child components. Updates internal state to trigger fallback UI rendering. 969 | - Displays a styled error overlay with the error message when an error is caught. The overlay shows "There was an error!" heading and the error's message text for debugging. 970 | - Logs caught errors to the console via `componentDidCatch` with error details, error info (component stack trace), and the error location for debugging purposes. 971 | - Resets error state when the `node` prop changes via `componentDidUpdate`. This allows the boundary to recover and retry rendering when the component definition changes (useful for hot module reloading). 972 | - Used extensively throughout the rendering pipeline to wrap containers (`StateContainer` wraps Container in ErrorBoundary) and prevent errors in one component from crashing parent or sibling components. 973 | - Does not catch errors in event handlers, async code, or errors thrown outside the React rendering phase. Only catches errors during component rendering, lifecycle methods, and constructors. 974 | 975 | #### See Also 976 | 977 | - `StateContainer` — wraps the Container component in ErrorBoundary to catch parsing and runtime errors in stateful components. 978 | - `ContainerWrapper` — uses ErrorBoundary to isolate container errors and prevent app crashes. 979 | - `InvalidComponent` — displays error messages for invalid component configurations; complementary to ErrorBoundary's runtime error handling. 980 | 981 | 982 | ### The `RendererContext` Type 983 | 984 | `RendererContext` is the TypeScript interface defining the complete context object passed to component renderer functions. It provides all utilities, state access, event handling, and rendering capabilities that component renderers need to transform XMLUI component definitions into React elements. The context encapsulates the rendering environment so renderers remain pure functions that receive everything they need via this single parameter. 985 | 986 | #### Behavior 987 | 988 | - Provides `node` (the component definition with props, events, children) and `state` (container state with variables, component APIs, and data) so renderers can access component configuration and runtime state. 989 | - Exposes `extractValue` (ValueExtractor) for evaluating binding expressions in component props. Renderers use this to resolve `{expression}` syntax to actual values from state or app context. 990 | - Provides event handling via `lookupEventHandler` (gets async handler for event name), `lookupAction` (resolves action by name), and `lookupSyncCallback` (resolves sync callback) so renderers can wire events to handlers. 991 | - Enables state management through `updateState` function that component renderers call to update component-specific state. Also provides `registerComponentApi` for exposing component methods to parent components. 992 | - Supplies `renderChild` function that renderers call to recursively render child components. This is the core recursive rendering mechanism that processes the component tree. 993 | - Includes `extractResourceUrl` for resolving logical resource URLs to physical URLs using the theme's resource resolver, and `className` for computed CSS classes from layout props. 994 | - Provides `layoutContext` describing the rendering context (stack orientation, wrap behavior, etc.) and `appContext` with global utilities (navigate, toast, theme, etc.) and `uid` (unique component instance identifier). 995 | 996 | #### See Also 997 | 998 | - `ComponentAdapter` — creates the RendererContext object and passes it to component renderer functions. 999 | - `ValueExtractor` — the type for `extractValue` function that evaluates binding expressions and extracts typed values. 1000 | - `ComponentRendererFn` — the function signature for component renderers that receive RendererContext as their parameter. 1001 | - `renderChild` — the core recursive rendering function exposed via RendererContext for rendering child components. 1002 | 1003 | 1004 | ### The `ComponentRegistry` Class 1005 | 1006 | `ComponentRegistry` maintains the central registry of all components, loaders, actions, and theme variables available in an XMLUI application. It maps component names to renderer functions, manages namespaces for core/app/extension components, collects theme variables from registered components, and provides lookup methods used throughout the rendering pipeline to resolve components by name. The registry is created during app initialization and accessed via React context. 1007 | 1008 | #### Behavior 1009 | 1010 | - Maintains three namespace pools (CORE_NS for framework components, APP_NS for app-specific components, EXTENSIONS_NS for third-party extensions) where components are organized by namespace to prevent name collisions and enable overriding. 1011 | - Registers all core XMLUI components during construction including Stack, Button, Text, Table, List, Form, Modal, and 100+ HTML element wrappers. Uses environment variables (`VITE_USED_COMPONENTS_*`) for tree-shaking unused components in production builds. 1012 | - Supports component lookup via `lookupComponentRenderer(name)` which searches namespaces in priority order (core → app → extensions) for components without namespace prefix, or direct namespace lookup for qualified names (`MyNamespace.MyComponent`). 1013 | - Collects theme variables from component descriptors into a unified set and maintains default theme variable values. Provides `componentThemeVars` and `componentDefaultThemeVars` getters for theme resolution. 1014 | - Registers compound components (components defined in XMLUI markup) alongside native React components. Compound components are stored with their `compoundComponentDef` for later rendering via `CompoundComponent` infrastructure. 1015 | - Exposes action functions via `lookupAction(type)` and loader renderers via `lookupLoaderRenderer(type)` so the execution pipeline can resolve custom actions and data loaders by name. 1016 | - Integrates with `StandaloneExtensionManager` to receive extension component registrations dynamically. Subscribes to extension events and registers contributed components on-the-fly. 1017 | - Provides `destroy()` method to clean up subscriptions when the registry is unmounted (hot module reload scenarios). Ensures proper cleanup of extension manager listeners. 1018 | 1019 | #### See Also 1020 | 1021 | - `ComponentProvider` — the React component that creates ComponentRegistry and provides it via context to the app. 1022 | - `useComponentRegistry` — the React hook that components use to access the registry from context. 1023 | - `lookupComponentRenderer` — the primary lookup method used by ComponentAdapter to resolve renderer functions. 1024 | - `ComponentRegistryEntry` — the type describing registered components including renderer, descriptor, and compound component definitions. 1025 | 1026 | 1027 | ### The `LayoutContext` Type 1028 | 1029 | `LayoutContext` is a TypeScript type describing the layout environment in which a component is rendered. It provides information about the parent layout container (such as Stack orientation, Grid configuration, or Flow layout behavior) and optionally supplies a `wrapChild` function that parent components use to wrap rendered children in layout-specific React elements. Layout contexts enable parent components to control child rendering without children needing explicit knowledge of their layout environment. 1030 | 1031 | #### Behavior 1032 | 1033 | - Contains optional `type` property identifying the layout context kind (for example "Stack", "Grid", "Flow") so children can adapt rendering based on parent layout. 1034 | - Provides optional `wrapChild` function that parent components like Stack use to wrap each child in layout-specific elements. For example Stack wraps children in flex items with alignment and spacing applied. 1035 | - Supports arbitrary additional properties via index signature allowing layout-specific data to be passed through context. Stack adds `orientation` ("horizontal"/"vertical"), Grid adds column/row info, Flow adds wrapping behavior. 1036 | - Passed down the rendering tree via `renderChild` calls where parent components create new layout contexts for their children. Children receive the context via `RendererContext.layoutContext`. 1037 | - Used by `ComponentAdapter` to apply layout-specific styling when `wrapChild` is defined. After rendering a component the adapter checks for `layoutContext.wrapChild` and invokes it to wrap the result. 1038 | - Enables declarative layout composition where layout containers control child presentation without requiring children to import or understand parent layout logic. Children remain layout-agnostic. 1039 | 1040 | #### See Also 1041 | 1042 | - `renderChild` — accepts optional `layoutContext` parameter to pass layout information to child components during recursive rendering. 1043 | - `RendererContext.layoutContext` — exposes the current layout context to component renderers so they can adapt to parent layout. 1044 | - Stack component — creates layout contexts with `orientation` and `wrapChild` to control flex item rendering and spacing. 1045 | - `ComponentAdapter` — applies `layoutContext.wrapChild` after rendering components to wrap them in layout-specific elements. 1046 | 1047 | 1048 | ### The `ValueExtractor` Function 1049 | 1050 | `ValueExtractor` is a function type with typed methods for evaluating binding expressions in XMLUI component props. It extracts values from expressions like `{variableName}` or `{state.property}` by resolving them against component state and app context. The extractor memoizes results based on expression dependencies to avoid unnecessary re-computation and provides specialized methods for extracting typed values (strings, numbers, booleans, sizes) with validation and type coercion. 1051 | 1052 | #### Behavior 1053 | 1054 | - Core function `extractValue(expression, strict)` evaluates any expression type (string with bindings, objects, arrays, primitives) by parsing parameter strings, collecting variable dependencies, and resolving them from state/appContext. Returns the computed value. 1055 | - Memoizes expression evaluation using dependency tracking where each expression is parsed once to identify dependencies (variables it references). Subsequent evaluations only recompute when dependency values change using shallow comparison. 1056 | - Provides typed extraction methods including `asString` (coerce to string), `asNumber` (validate number or throw), `asBoolean` (JavaScript truthiness), `asOptionalNumber`/`asOptionalBoolean` (with default values), and `asSize` (parse CSS size values). 1057 | - Handles special string conversion via `asDisplayText` which preserves multiple spaces by converting consecutive spaces to non-breaking spaces (`\xa0`) for proper whitespace rendering in HTML. 1058 | - Supports array extraction via `asOptionalStringArray` which parses array syntax `["item1", "item2"]` from strings or coerces existing arrays to string arrays for consistent handling. 1059 | - Uses `extractParam` internally to resolve binding expressions like `{$item.name}` by looking up variables in state and appContext with support for dot notation property access. 1060 | - Parses CSS size values via `StyleParser` to handle theme variable references like `spacing.md` and converts them to CSS custom properties `var(--xmlui-spacing-md)` for theme-aware sizing. 1061 | 1062 | #### See Also 1063 | 1064 | - `createValueExtractor` — factory function that creates ValueExtractor instances with bound state, appContext, and memoization infrastructure. 1065 | - `RendererContext.extractValue` — the ValueExtractor instance provided to component renderers for evaluating prop expressions. 1066 | - `extractParam` — lower-level utility that resolves binding expressions by looking up variables in state/appContext. 1067 | - `collectVariableDependencies` — analyzes expression ASTs to determine which state variables an expression depends on for memoization. 1068 | 1069 | 1070 | ### The `renderChild()` Function 1071 | 1072 | `renderChild()` is the core recursive rendering function that transforms XMLUI component definitions into React elements. It handles special cases (TextNode, Slot, conditional rendering), evaluates component visibility via `when` conditions, extracts component keys for React reconciliation, and delegates to `ComponentWrapper` which routes components through the rendering pipeline. This function is the "jolly-joker" that makes the entire component tree recursive by passing itself to rendered components. 1073 | 1074 | #### Behavior 1075 | 1076 | - Evaluates `when` condition via `shouldKeep(node.when, state, appContext)` to determine component visibility. Returns null for components with false `when` conditions implementing conditional rendering. 1077 | - Handles `TextNode` components specially by extracting the text value via `extractParam` to resolve binding expressions like `{variableName}` in text content. Converts boolean values to strings for rendering. 1078 | - Handles `TextNodeCData` components by rendering the text value directly without expression evaluation or whitespace processing to preserve exact formatting including whitespace. 1079 | - Implements Slot transposition logic for compound components where named slots (ending with "Template") are resolved from parent props and unnamed slots use parent children. Falls back to default slot template when parent provides no content. 1080 | - Extracts component keys via `extractParam(state, node.uid, appContext, true)` to generate stable React keys for reconciliation. Keys can be expressions evaluated from state. 1081 | - Delegates actual rendering to `ComponentWrapper` by passing complete rendering context including state, dispatch, lookupAction, renderChild (itself for recursion), layoutContext, and cleanup functions. 1082 | - Receives `ChildRendererContext` parameter containing all rendering infrastructure (state, appContext, dispatch, callbacks) and passes it through the rendering chain to enable recursive component tree traversal. 1083 | 1084 | #### See Also 1085 | 1086 | - `ComponentWrapper` — receives nodes from renderChild and routes them to ContainerWrapper or ComponentAdapter based on state requirements. 1087 | - `shouldKeep` — evaluates `when` conditions to determine if components should render or return null for conditional rendering. 1088 | - `extractParam` — resolves binding expressions in component properties and keys for dynamic value extraction. 1089 | - `ChildRendererContext` — the context type containing all state, callbacks, and utilities needed for recursive rendering. 1090 | - Slot transposition — special handling for Slot components that transpose parent content into compound component templates. 1091 | 1092 | ```