#
tokens: 49890/50000 253/1626 files (page 1/141)
lines: off (toggle) GitHub
raw markdown copy
This is page 1 of 141. Use http://codebase.md/xmlui-org/xmlui/%7BfontLink%7D?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

--------------------------------------------------------------------------------
/blog/.gitkeep:
--------------------------------------------------------------------------------

```

```

--------------------------------------------------------------------------------
/tools/vscode/.gitignore:
--------------------------------------------------------------------------------

```
out
node_modules
client/server
.vscode-test
*.vsix
dist/

```

--------------------------------------------------------------------------------
/.prettierrc.js:
--------------------------------------------------------------------------------

```javascript
module.exports = {
    printWidth: 100,
    singleQuote: false,
    semi: true
};
```

--------------------------------------------------------------------------------
/tools/vscode/.vscodeignore:
--------------------------------------------------------------------------------

```
.vscode/**
**/*.ts
**/*.map
.gitignore
**/tsconfig.*
contributing.md
node_modules/**
esbuild.*
eslint.config.*
.turbo

```

--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------

```
node_modules
test-results
.vs
.idea
.windsurf
__tmp
__setup
__deploy
.DS_Store
.turbo
test-results
coverage
.next
xmlui-optimized-output
xmlui-temp-build

docs/scripts/component-metadata.json

```

--------------------------------------------------------------------------------
/docs/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?
ui-optimized.zip

```

--------------------------------------------------------------------------------
/tools/create-app/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

.env.production


```

--------------------------------------------------------------------------------
/blog/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?
ui-optimized.zip
ui.zip

# Generated files
public/feed.rss
public/blog-search-data.json

```

--------------------------------------------------------------------------------
/packages/xmlui-animations/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/packages/xmlui-devtools/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/packages/xmlui-hello-world/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/packages/xmlui-os-frames/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/packages/xmlui-pdf/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/packages/xmlui-search/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/packages/xmlui-spreadsheet/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/packages/xmlui-website-blocks/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/xmlui/.gitignore:
--------------------------------------------------------------------------------

```
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

storybook-static

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

scripts/generate-docs/**/*metadata.json
/test-results/
/playwright-report/
/blob-report/
/playwright/.cache/

```

--------------------------------------------------------------------------------
/.eslintrc.cjs:
--------------------------------------------------------------------------------

```
/**
 * This is intended to be a basic starting point for linting in your app.
 * It relies on recommended configs out of the box for simplicity, but you can
 * and should modify this configuration to best suit your team's needs.
 */

/** @type {import('eslint').Linter.Config} */
module.exports = {
  root: true,
  parserOptions: {
    projectService: true,
    tsconfigRootDir: __dirname,
    // sourceType: "module",
    // ecmaFeatures: {
    //   jsx: true,
    // },
  },
  env: {
    browser: true,
    commonjs: true,
    es6: true,
  },
  ignorePatterns: ["!**/.server", "!**/.client"],

  // Base config
  overrides: [
    // React
    {
      files: ["**/*.{js,jsx,ts,tsx}"],
      plugins: ["react"],
      extends: [
        "plugin:react/recommended",
        "plugin:react/jsx-runtime",
        "plugin:react-hooks/recommended",
      ],
      settings: {
        react: {
          version: "detect",
        },
        formComponents: ["Form"],
        linkComponents: [
          { name: "Link", linkAttribute: "to" },
          { name: "NavLink", linkAttribute: "to" },
        ],
        "import/resolver": {
          typescript: {},
        },
      },
    },

    // Typescript
    {
      files: ["**/*.{ts,tsx}"],
      plugins: ["@typescript-eslint"],
      parser: "@typescript-eslint/parser",
      settings: {
        "import/internal-regex": "^~/",
        "import/resolver": {
          node: {
            extensions: [".ts", ".tsx"],
          },
          typescript: {
            alwaysTryTypes: true,
          },
        },
      },
      extends: ["plugin:@typescript-eslint/recommended"],
      rules: {
        "@typescript-eslint/consistent-type-imports": "error",
        "@typescript-eslint/no-floating-promises": "error",
        "@typescript-eslint/no-unused-vars": "off",
        "@typescript-eslint/ban-ts-comment": "off",
        "@typescript-eslint/no-inferrable-types": "off",
        "@typescript-eslint/no-empty-interface": "off",
        "@typescript-eslint/no-explicit-any": "off",

        "require-await": "error",
        "react/prop-types": "off",
        "react/display-name": "off",
        "prefer-const": "off",
      },
    },

    // Node
    {
      files: [".eslintrc.cjs"],
      env: {
        node: true,
      },
    },
  ],
};

```

--------------------------------------------------------------------------------
/tools/vscode/README.md:
--------------------------------------------------------------------------------

```markdown
# XMLUI Tools for Visual Studio Code

This extension adds tools for working with [XMLUI](https://docs.xmlui.org) files.

- Syntax highlighting for `.xmlui` files and `.xmlui.xs` files
- Hover for core components
- Completion for core components
- Code formatting for `.xmlui` files
- Diagnostics for errors

## Features

![](./tools/vscode/resources/xmlui-markup-syntax-highlighting.png)

```

--------------------------------------------------------------------------------
/xmlui/src/components/ResponsiveBar/README.md:
--------------------------------------------------------------------------------

```markdown
# ResponsiveBar Component

The ResponsiveBar component has been successfully created and tested! Here's what it does:

## Features

1. **Automatic overflow management**: When child components don't fit in the available width, they're automatically moved to a dropdown menu
2. **Real-time responsiveness**: The component monitors container width changes and adjusts the layout accordingly
3. **Zero configuration**: Works out of the box with sensible defaults
4. **Customizable overflow icon**: You can specify a custom icon for the dropdown trigger

## Usage Example

```xmlui
<ResponsiveBar>
  <Button label="File" />
  <Button label="Edit" />
  <Button label="View" />
  <Button label="Window" />
  <Button label="Help" />
</ResponsiveBar>
```

When the container is narrow, the last buttons (Window, Help) will be moved to a dropdown menu accessible via a "..." icon.

## Implementation Strategy

The component uses a two-phase rendering approach:

1. **Measurement phase**: All children are rendered invisibly to measure their widths
2. **Display phase**: Based on measurements, children are split between visible area and overflow dropdown

## Files Created

- `ResponsiveBar.tsx` - Main component with metadata and renderer
- `ResponsiveBarNative.tsx` - Native React implementation with size observation
- `ResponsiveBar.module.scss` - Styling with theme variables
- `ResponsiveBar.md` - Documentation with examples
- `ResponsiveBar.spec.ts` - End-to-end tests

## Integration

The component has been registered in the ComponentProvider and is ready to use in XMLUI applications!

## Testing

All tests pass:
- ✅ Renders children in horizontal layout
- ✅ Moves overflowing items to dropdown when container is too narrow
- ✅ Responds to container resize

```

--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------

```markdown
![NPM Version](https://img.shields.io/npm/v/xmlui?color=blue)
![Components](https://img.shields.io/badge/Components-92-brightgreen)
![Extension packages](https://img.shields.io/badge/Extension%20packages-7-brightgreen)
![Theme variables](https://img.shields.io/badge/theme%20variables-3639-brightgreen)

# XMLUI


**XMLUI** is a framework for building user interfaces declaratively, with XML markup and flexible theming.

**Easy to create**. Build on the web platform with little or no knowledge of React or CSS.

**Clean and modern**. Enjoy themes that look great out of the box and are easy to modify. Create experiences that meet expectations for modern web apps.

**Connected**. Read and write APIs with little or no scripting.

**Modular**. Use a comprehensive suite of [components](https://docs.xmlui.org/components/_overview) that you can extend with — again! — little or no scripting.

**Easy to deploy**. Just drop a handful of files onto a static webserver.

## See it in action

```xml
<App>
  <Select id="lines" initialValue="bakerloo">
    <Items data="https://api.tfl.gov.uk/line/mode/tube/status">
        <Option value="{$item.id}" label="{$item.name}" />
    </Items>
  </Select>
  <DataSource
    id="tubeStations"
    url="https://api.tfl.gov.uk/Line/{lines.value}/Route/Sequence/inbound"
    resultSelector="stations"/>
  <Table data="{tubeStations}" height="280px">
    <Column bindTo="name" />
    <Column bindTo="modes" />
  </Table>
</App>
```

![xmlui](https://github.com/user-attachments/assets/93523e15-be19-47d1-913d-d8016c1e44e4)


## Getting started

The fastest way to get started with XMLUI is to [download our starter kit](https://github.com/xmlui-org/xmlui-invoice/releases), which includes the XMLUI engine and `XMLUI Invoice` - a complete business application that demonstrates key features and common patterns.

### What's included

XMLUI Invoice: A complete business application with client and product management, invoice creation and tracking, search, and charts.

XMLUI engine: The core framework file.

XMLUI test server: A simple server to run the app.

### Quick start

Extract the files to a working folder and run the start script.

### See also

Visit [demo.xmlui.org](https://demo.xmlui.org) to explore a gallery of components.

Visit [docs.xmlui.org](https://docs.xmlui.org) for an introduction, a tutorial, and full documentation. The documentation site is itself an XMLUI app!

<a href="https://docs.xmlui.org"><img width="1285" alt="image" src="https://github.com/user-attachments/assets/9a54ae74-4f45-4079-a5d4-142e23fb4134" /></a>


## Contributing

We welcome contributions! If you have ideas for new features, suggestions, or find a bug, please open an issue. Pull requests are also encouraged. (Please read our [Contribution Guidelines](./CONTRIBUTING.md) before contributing.)

## Feature Requests

Have a feature request? Here's how to submit it:

If your feature request is not already listed in the [Issues](https://github.com/xmlui-org/xmlui/issues) section, please follow these steps:

1. Click on the link below to open the feature request template.
2. Fill out the template with as much detail as possible.
3. Submit the issue.

[New feature request](https://github.com/xmlui-org/xmlui/issues/new?template=feature_request.md)

## Bug Reports

Have you found a bug? Here's how to report it:

1. Click on the link below to open the bug report template.
2. Fill out the template with as much detail as possible.
3. Submit the issue.

[New bug report](https://github.com/xmlui-org/xmlui/issues/new?template=bug_report.md)

## License

XMLUI is licensed under the MIT License. See the [LICENSE](./LICENSE) file for more information.

## Attribution

XMLUI was stared as an internal project at [/n software](https://nsoftware.com) which is the primary sponsor and source of funding for this open source project.

Our virtualized components and data management mechanisms would not be as simple, performant, and powerful without the help of a few [TanStack](https://github.com/TanStack) projects, such as [query](https://github.com/TanStack/query), [table](https://github.com/TanStack/table), and others. We appreciate their outstanding work!

We based some of our essential components on [Radix UI](https://www.radix-ui.com/) components and involved some of the architectural approaches they used in their project. Thanks to all project contributors for their excellent work.

We loved the simple and beautiful UI style used by the [Tabler.io](https://tabler.io/) project; it illuminated our component design and theming. Thanks to [Paweł Kuna](https://github.com/codecalm) for this inspiration.


```

--------------------------------------------------------------------------------
/tools/vscode/LICENSE.md:
--------------------------------------------------------------------------------

```markdown
The MIT License (MIT)

Copyright (c) 2024 /n software

Permission is hereby granted, free f charge, to any person obtaining a opy
of this software and associated ocumentation files (the "Software"), o deal
in the Software without restriction, ncluding without limitation the ights
to use, copy, modify, merge, ublish, distribute, sublicense, nd/or sell
copies of the Software, and to ermit persons to whom the Software is
furnished to do so, subject to the ollowing conditions:

The above copyright notice and this ermission notice shall be included n all
copies or substantial portions of he Software.

THE SOFTWARE IS PROVIDED "AS IS", ITHOUT WARRANTY OF ANY KIND, EXPRESS R
IMPLIED, INCLUDING BUT NOT LIMITED O THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND ONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE IABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF ONTRACT, TORT OR OTHERWISE, ARISING ROM,
OUT OF OR IN CONNECTION WITH THE OFTWARE OR THE USE OR OTHER DEALINGS N THE
SOFTWARE.

```

--------------------------------------------------------------------------------
/CONTRIBUTING.md:
--------------------------------------------------------------------------------

```markdown
# Contributing to xmlui

Welcome to **xmlui**! We're thrilled to have you contribute to our project. This document outlines the guidelines for contributing, ensuring a smooth and collaborative experience for everyone.

**xmlui** is a modern web UI framework designed to empower desktop developers to effortlessly create web applications without requiring deep knowledge of HTML, CSS, or JavaScript. 

Your contributions are valuable and help us improve and grow the project.

## Code of Conduct

We expect all contributors to act respectfully and professionally, maintaining a positive and inclusive environment for everyone in our community.

## Getting Started

Before you begin contributing, please ensure you have:

1. **Node.js** (version 16 or higher) installed on your system
2. **npm** or **yarn** package manager
3. A **GitHub account** for submitting pull requests
4. **Git** installed and configured

### Setting Up the Development Environment

1. **Fork the Repository**: Fork the xmlui repository to your GitHub account
2. **Clone Your Fork**: 
   ```bash
   git clone https://github.com/your-username/xmlui.git
   cd xmlui
   ```
3. **Install Dependencies**:
   ```bash
   npm install
   # or
   yarn install
   ```

## How to Contribute

There are several ways you can contribute to **xmlui**:

- **Reporting Bugs**: If you find a bug, please report it using our [issue tracker](https://github.com/xmlui-com/xmlui/issues/new?template=bug_report.md)
- **Suggesting Features**: Have a feature request? Open a [feature request issue](https://github.com/xmlui-com/xmlui/issues/new?template=feature_request.md)
- **Writing Code**: If you'd like to contribute code, follow the guidelines below
- **Improving Documentation**: Help us improve our documentation by fixing typos, adding missing reference information, creating tutorials, and developing how-to sections

### Reporting Bugs

When reporting bugs, please follow these steps:

1. **Check Existing Issues**: Before reporting, search existing issues to avoid duplicates
2. **Use the Bug Report Template**: Open a new issue using the bug report template
3. **Provide Detailed Information**: Include:
   - Steps to reproduce the issue
   - Expected vs. actual behavior
   - Browser and OS information
   - Screenshots or code snippets when applicable
   - Error messages or console logs

### Suggesting Features

To suggest new features:

1. **Search Existing Requests**: Check if your suggestion has already been proposed
2. **Use the Feature Request Template**: Open a new feature request issue
3. **Provide Clear Details**: Include:
   - A clear description of the proposed feature
   - Use cases and benefits
   - Potential implementation considerations
   - Examples or mockups if applicable

### Writing Code

To contribute code to xmlui:

1. **Fork the Repository**: Fork the repository to your GitHub account
2. **Clone Your Fork**: Clone your fork locally
3. **Create a Feature Branch**: Create a new branch for your work:
   ```bash
   git checkout -b feature/your-feature-name
   # or for bug fixes:
   git checkout -b bugfix/issue-description
   ```
4. **Make Your Changes**: Implement your feature or bug fix
5. **Follow Code Standards**: Ensure your code follows our coding standards (see below)
6. **Write Tests**: Add or update tests for your changes
7. **Test Your Changes**: Run the test suite to ensure everything works
8. **Commit Your Changes**: Use clear and descriptive commit messages
9. **Push to Your Fork**: Push your branch to your forked repository
10. **Open a Pull Request**: Create a pull request from your branch to the main repository

#### Code Standards

- Follow TypeScript/JavaScript best practices
- Use meaningful variable and function names
- Add JSDoc comments for public APIs
- Maintain consistent indentation (2 spaces)
- Follow the existing code style in the project
- Ensure your code is properly formatted (use Prettier if configured)

### Improving Documentation

You can help improve our documentation in the following ways:

- **Fixing Typos and Grammar**: Correct spelling and grammatical errors
- **Adding Missing Reference Information**: Complete API documentation and add missing details
- **Creating Tutorials**: Develop step-by-step tutorials for common use cases
- **Writing How-To Guides**: Create guides for specific tasks and workflows
- **Improving Examples**: Add or enhance code examples and demonstrations

To contribute to documentation:

1. **Identify Areas for Improvement**: Look for outdated, incomplete, or unclear documentation
2. **Make Your Changes**: Edit the relevant documentation files (usually `.md` files)
3. **Test Your Changes**: Preview your changes to ensure proper formatting
4. **Submit a Pull Request**: Follow the same process as code contributions

## Development Workflow

### Project Structure

Understanding the project structure will help you navigate and contribute effectively:

- `/src/` - Main source code
- `/src/components/` - UI components
- `/tests/` - Test files
- `/docs/` - Documentation files
- `/tools/` - Development tools and utilities
- `/examples/` - Example applications

### Branching Strategy

We use a Git flow-inspired branching strategy:

- **main**: The main branch contains stable, production-ready code and is protected
- **feature/[feature-name]**: For developing new features
- **bugfix/[issue-description]**: For fixing bugs
- **docs/[doc-update]**: For documentation updates
- **refactor/[refactor-description]**: For code refactoring

### Running Tests

Before submitting any changes, ensure all tests pass:

```bash
# Run all tests
npm test
# or
yarn test

# Run tests in watch mode during development
npm run test:watch
# or
yarn test:watch

# Run tests with coverage
npm run test:coverage
# or
yarn test:coverage
```

### Code Reviews

All submissions require code review before merging:

1. **Automated Checks**: Your pull request will run automated tests and linting
2. **Peer Review**: A project maintainer will review your code
3. **Feedback**: Address any feedback or requested changes
4. **Approval**: Once approved, your changes will be merged

### Testing Guidelines

When contributing code, please ensure:

- **Write Tests**: Add tests for new functionality
- **Update Existing Tests**: Modify tests when changing existing functionality
- **Test Coverage**: Maintain or improve test coverage
- **Test Types**:
  - Unit tests for individual functions/components
  - Integration tests for component interactions
  - End-to-end tests for complete user workflows

### Commit Message Guidelines

Write clear and descriptive commit messages following conventional commit format:

- `feat: add new DatePicker component with min/max value support`
- `fix: resolve memory leak in component cleanup`
- `docs: update API documentation for Button component`
- `refactor: optimize rendering performance in ListView`
- `test: add unit tests for form validation`
- `build: update webpack configuration for production builds`
- `chore: update dependencies to latest versions`

**Commit Message Structure:**
```
<type>(<scope>): <description>

[optional body]

[optional footer]
```

**Types:**
- `feat`: A new feature
- `fix`: A bug fix
- `docs`: Documentation only changes
- `refactor`: A code change that improves code quality, structure, or readability without fixing bugs or adding features
- `test`: Adding missing tests or correcting existing tests
- `build`: Changes that affect the build system or external dependencies
- `ci`: Changes to CI configuration files and scripts
- `chore`: Other changes that don't modify src or test files

## Pull Request Guidelines

When submitting a pull request:

1. **Use a Clear Title**: Describe what your PR does in the title
2. **Fill Out the Template**: Complete the pull request template
3. **Link Related Issues**: Reference any related issues using `#issue-number`
4. **Describe Your Changes**: Explain what you changed and why
5. **Add Screenshots**: For UI changes, include before/after screenshots
6. **Keep It Focused**: One feature or fix per pull request
7. **Update Documentation**: Update relevant documentation for your changes

## Community and Support

### Getting Help

If you need help while contributing:

- **GitHub Discussions**: Use GitHub Discussions for questions and community support
- **Issue Tracker**: Report bugs and request features through GitHub Issues
- **Documentation**: Check our documentation for guides and API references

### Communication Guidelines

- Be respectful and inclusive in all interactions
- Provide constructive feedback when reviewing code
- Ask questions if something is unclear
- Help others when you can
- Follow our Code of Conduct at all times

## Recognition

We value all contributions to xmlui! Contributors will be:

- Listed in our `CONTRIBUTORS.md` file
- Mentioned in release notes for significant contributions
- Eligible for special contributor badges and recognition

## Licensing

By contributing to **xmlui**, you agree that your contributions will be licensed under the [MIT License](https://github.com/xmlui-com/xmlui/blob/main/LICENSE).

## Questions?

If you have any questions about contributing, please:

- Check our [FAQ](https://github.com/xmlui-com/xmlui/wiki/FAQ) 
- Open a [discussion](https://github.com/xmlui-com/xmlui/discussions)
- Reach out to the maintainers

## Acknowledgements

Thank you for considering contributing to **xmlui**! Your contributions are greatly appreciated and make a significant impact on the project's success. Every contribution, no matter how small, helps make xmlui better for everyone.

```

--------------------------------------------------------------------------------
/docs/ComponentRefLinks.txt:
--------------------------------------------------------------------------------

```

```

--------------------------------------------------------------------------------
/packages/xmlui-hello-world/meta/componentsMetadata.ts:
--------------------------------------------------------------------------------

```typescript

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/meta/componentsMetadata.ts:
--------------------------------------------------------------------------------

```typescript

```

--------------------------------------------------------------------------------
/tools/vscode/build.sh:
--------------------------------------------------------------------------------

```bash

```

--------------------------------------------------------------------------------
/tools/vscode/formatter-docs.md:
--------------------------------------------------------------------------------

```markdown

```

--------------------------------------------------------------------------------
/tools/vscode/generate-test-sample.sh:
--------------------------------------------------------------------------------

```bash

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/eye-dark.svg:
--------------------------------------------------------------------------------

```

```

--------------------------------------------------------------------------------
/docs/public/pages/test.md:
--------------------------------------------------------------------------------

```markdown
# Test


```

--------------------------------------------------------------------------------
/blog/public/blog/older-post.md:
--------------------------------------------------------------------------------

```markdown
This is an older post.

```

--------------------------------------------------------------------------------
/blog/public/blog/newest-post.md:
--------------------------------------------------------------------------------

```markdown
This is the newest post.

```

--------------------------------------------------------------------------------
/xmlui/src/components/Footer/Footer.md:
--------------------------------------------------------------------------------

```markdown
%-DESC-START

%-DESC-END

```

--------------------------------------------------------------------------------
/xmlui/src/react-app-env.d.ts:
--------------------------------------------------------------------------------

```typescript
/// <reference types="react-scripts" />

```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-pdf/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Pdf": "Pdf"
}
```

--------------------------------------------------------------------------------
/docs/public/pages/xmlui-pdf/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Pdf": "Pdf"
}
```

--------------------------------------------------------------------------------
/docs/content/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "components": "Components",
  "extensions": "Extensions"
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ArrowLeft.module.scss:
--------------------------------------------------------------------------------

```scss
@layer components {
  .arrowLeft {
    fill: currentColor;
  }
}

```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-website-blocks/_overview.md:
--------------------------------------------------------------------------------

```markdown
# Xmlui Website Blocks Package

This package contains components...
```

--------------------------------------------------------------------------------
/docs/content/extensions/xmlui-website-blocks/_overview.md:
--------------------------------------------------------------------------------

```markdown
# Xmlui Website Blocks Package

This package contains components...
```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-spreadsheet/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Spreadsheet": "Spreadsheet"
}
```

--------------------------------------------------------------------------------
/docs/public/pages/xmlui-spreadsheet/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Spreadsheet": "Spreadsheet"
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/Binding.module.scss:
--------------------------------------------------------------------------------

```scss
@layer components {
  .binding {
    fill: var(--colorFontMain);
  }
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/DatabaseIcon.module.scss:
--------------------------------------------------------------------------------

```scss
@layer components {
  .database {
    fill: var(--colorFontMain);
  }
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ArrowRight.module.scss:
--------------------------------------------------------------------------------

```scss
@layer components {
  .arrowRight {
    fill: var(--colorFontMain);
  }
}

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ArrowDropUp.module.scss:
--------------------------------------------------------------------------------

```scss
@layer components {
  .arrowDropUp {
    fill: var(--colorFontMain);
  }
}

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ArrowDropDown.module.scss:
--------------------------------------------------------------------------------

```scss
@layer components {
  .arrowDropDown {
    fill: var(--colorFontMain);
  }
}


```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-pdf/_overview.md:
--------------------------------------------------------------------------------

```markdown
# Xmlui Pdf Package

This package provides components for working with pdf files.
```

--------------------------------------------------------------------------------
/tools/vscode/src/server.ts:
--------------------------------------------------------------------------------

```typescript
import * as languageServer from "xmlui/language-server";
languageServer.start();

```

--------------------------------------------------------------------------------
/xmlui/scripts/generate-docs/components-config.json:
--------------------------------------------------------------------------------

```json
{
  "excludeComponentStatuses": ["in progress", "deprecated"],
  "cleanFolder": true
}
```

--------------------------------------------------------------------------------
/packages/xmlui-playground/src/playground/Box.module.scss:
--------------------------------------------------------------------------------

```scss
.box {
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
}

```

--------------------------------------------------------------------------------
/xmlui/tsconfig.node.json:
--------------------------------------------------------------------------------

```json
{
  "compilerOptions": {
    "composite": true,
  },
  "include": ["vite.config.ts"]
}

```

--------------------------------------------------------------------------------
/blog/public/serve.json:
--------------------------------------------------------------------------------

```json
{
  "rewrites": [
    {
      "source": "**",
      "destination": "/index.html"
    }
  ]
}
```

--------------------------------------------------------------------------------
/docs/public/serve.json:
--------------------------------------------------------------------------------

```json
{
  "rewrites": [
    {
      "source": "**",
      "destination": "/index.html"
    }
  ]
}
```

--------------------------------------------------------------------------------
/tools/create-app/templates/default/ts/public/serve.json:
--------------------------------------------------------------------------------

```json
{
  "rewrites": [
    {
      "source": "**",
      "destination": "/index.html"
    }
  ]
}
```

--------------------------------------------------------------------------------
/xmlui/src/testing/infrastructure/public/serve.json:
--------------------------------------------------------------------------------

```json
{
  "rewrites": [
    {
      "source": "**",
      "destination": "/index.html"
    }
  ]
}
```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-spreadsheet/_overview.md:
--------------------------------------------------------------------------------

```markdown
# Xmlui Spreadsheet Package

This package provides an experimental spreadsheet component for XMLUI.
```

--------------------------------------------------------------------------------
/xmlui/src/components/Input/index.ts:
--------------------------------------------------------------------------------

```typescript
export { 
  PartialInput, 
  type PartialInputProps, 
  type BlurDirection 
} from "./PartialInput";

```

--------------------------------------------------------------------------------
/docs/content/extensions/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "xmlui-animations": "Xmlui Animations Package",
  "xmlui-website-blocks": "Xmlui Website Blocks Package"
}
```

--------------------------------------------------------------------------------
/blog/extensions.ts:
--------------------------------------------------------------------------------

```typescript
import playground from "xmlui-playground";
import search from "xmlui-search";

export default [playground, search];
```

--------------------------------------------------------------------------------
/packages/xmlui-devtools/vite.config-overrides.ts:
--------------------------------------------------------------------------------

```typescript
import vsixPlugin from '@codingame/monaco-vscode-rollup-vsix-plugin';

export default {
  plugins: [vsixPlugin()]
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/SpaceFiller/SpaceFillerNative.tsx:
--------------------------------------------------------------------------------

```typescript
import styles from "./SpaceFiller.module.scss";

export const SpaceFiller = () => <div className={styles.spacer} />;

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/theming/themeVars.module.scss:
--------------------------------------------------------------------------------

```scss
@use "./themes" as t;

$themeVars: ();

:export {
  keyPrefix: #{t.$THEME-VAR-PREFIX};
  themeVars: t.json-stringify($themeVars);
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Heading/abstractions.ts:
--------------------------------------------------------------------------------

```typescript
export const headingLevels = ["h1", "h2", "h3", "h4", "h5", "h6"] as const;
export type HeadingLevel = typeof headingLevels[number];

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/src/playground/Preview.module.scss:
--------------------------------------------------------------------------------

```scss
@use "xmlui/themes.scss" as themes;

.preview {
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: transparent;
}



```

--------------------------------------------------------------------------------
/xmlui/src/parsers/xmlui-parser/fileExtensions.ts:
--------------------------------------------------------------------------------

```typescript

export const componentFileExtension = "xmlui";
export const codeBehindFileExtension = "xmlui.xs";
export const moduleFileExtension = "xs";
```

--------------------------------------------------------------------------------
/xmlui/src/components/Bookmark/Bookmark.module.scss:
--------------------------------------------------------------------------------

```scss

@layer components {
  .anchorRef{
    --my-scroll-margin-top: var(--header-height);
    scroll-margin-top: var(--my-scroll-margin-top);
  }
}

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/arrow-left.svg:
--------------------------------------------------------------------------------

```
<svg viewBox="0 0 9 18" fill="none" xmlns="http://www.w3.org/2000/svg">
    <path d="M1.19249e-07 9L9 0.339745L9 17.6603L1.19249e-07 9Z" />
</svg>
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/arrow-up.svg:
--------------------------------------------------------------------------------

```
<svg width="18" height="9" viewBox="0 0 18 9" fill="none" xmlns="http://www.w3.org/2000/svg">
    <path d="M9 0L17.6603 9H0.339746L9 0Z" />
</svg>
```

--------------------------------------------------------------------------------
/docs/public/pages/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "xmlui-animations": "Xmlui Animations",
  "xmlui-charts": "Xmlui Charts",
  "xmlui-pdf": "Xmlui Pdf",
  "xmlui-spreadsheet": "Xmlui Spreadsheet"
}
```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-website-blocks/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Carousel": "Carousel",
  "HelloMd": "HelloMd",
  "HeroSection": "HeroSection",
  "ScrollToTop": "ScrollToTop"
}
```

--------------------------------------------------------------------------------
/docs/content/extensions/xmlui-website-blocks/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Carousel": "Carousel",
  "HelloMd": "HelloMd",
  "HeroSection": "HeroSection",
  "ScrollToTop": "ScrollToTop"
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/PDFIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Pdf from "./svg/pdf.svg?react";
import type {IconBaseProps} from "./IconNative";

export const PDFIcon = (props: IconBaseProps) => <Pdf {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/BoxIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Box from "./svg/box.svg?react";
import type {IconBaseProps} from "./IconNative";

export const BoxIcon = (props: IconBaseProps) => <Box {...props} />

```

--------------------------------------------------------------------------------
/packages/xmlui-hello-world/src/index.tsx:
--------------------------------------------------------------------------------

```typescript
import { helloWorldComponentRenderer } from "./HelloWorld";

export default {
  namespace: "XMLUIExtensions",
  components: [helloWorldComponentRenderer],
};

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ApiIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/api.svg?react";
import type {IconBaseProps} from "./IconNative";

export const ApiIcon = (props: IconBaseProps) => <Icon {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ListIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {FiList} from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const ListIcon = (props: IconBaseProps) => <FiList {...props}/>

```

--------------------------------------------------------------------------------
/packages/xmlui-spreadsheet/src/index.tsx:
--------------------------------------------------------------------------------

```typescript
import { spreadsheetComponentRenderer } from "./Spreadsheet";

export default {
  namespace: "XMLUIExtensions",
  components: [spreadsheetComponentRenderer],
};

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/HomeIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import { FiHome } from 'react-icons/fi';
import type {IconBaseProps} from "./IconNative";

export const HomeIcon = (props: IconBaseProps) => <FiHome {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/TxtIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/txt.svg?react";
import type { IconBaseProps } from "./IconNative";

export const TxtIcon = (props: IconBaseProps) => <Icon {...props} />;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/UserIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import { FiUser } from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const UserIcon = (props: IconBaseProps) => <FiUser {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/XlsIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/xls.svg?react";
import type { IconBaseProps } from "./IconNative";

export const XlsIcon = (props: IconBaseProps) => <Icon {...props} />;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Breakout/Breakout.module.scss:
--------------------------------------------------------------------------------

```scss
@layer components {
  .breakout {
    left: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    position: relative;
    right: 50%;
    width: 100vw;
  }

}

```

--------------------------------------------------------------------------------
/xmlui/src/abstractions/scripting/modules.ts:
--------------------------------------------------------------------------------

```typescript
// A function that resolves a module name to the text of the module
export type ModuleResolver = (
  sourceModule: string,
  moduleName: string
) => string | null;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/LinkIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {IoMdLink} from "react-icons/io";
import type {IconBaseProps} from "./IconNative";

export const LinkIcon = (props: IconBaseProps) => <IoMdLink {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ShareIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Share from "./svg/share.svg?react";
import type {IconBaseProps} from "./IconNative";

export const ShareIcon = (props: IconBaseProps) => <Share {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/CheckIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import { FiCheck } from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const CheckIcon = (props: IconBaseProps) => <FiCheck {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/PhoneIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import { FiPhone } from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const PhoneIcon = (props: IconBaseProps) => <FiPhone {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/PhotoIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Photo from "./svg/photo.svg?react";
import type {IconBaseProps} from "./IconNative";

export const PhotoIcon = (props: IconBaseProps) => <Photo {...props} />

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/src/themes/theme.ts:
--------------------------------------------------------------------------------

```typescript
import type { ThemeDefinition } from "xmlui";

export const Theme: ThemeDefinition = {
  name: "Theme",
  id: "theme",
  extends: ["xmlui"],
  themeVars: {
  },
};
  
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/DocIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/doc.svg?react";
import type {IconBaseProps} from "./IconNative";

export const DocIcon = (props: IconBaseProps) => (
  <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/SearchIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {FiSearch} from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const SearchIcon = (props: IconBaseProps) => <FiSearch {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/BoardIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import { FiGrid } from "react-icons/fi";
import type { IconBaseProps } from "./IconNative";

export const BoardIcon = (props: IconBaseProps) => <FiGrid {...props} />;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/arrow-dropdown.svg:
--------------------------------------------------------------------------------

```
<svg width="18" height="9" viewBox="0 0 18 9" fill="none" xmlns="http://www.w3.org/2000/svg">
    <path d="M9 9L0.339745 4.3915e-07L17.6603 1.80194e-06L9 9Z" />
</svg>
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/CompactListIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import type {IconBaseProps} from "./IconNative";
import {FiList} from "react-icons/fi";

export const CompactListIcon = (props: IconBaseProps) => <FiList {...props}/>;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/FilterIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/filter.svg?react";
import type { IconBaseProps } from "./IconNative";

export const FilterIcon = (props: IconBaseProps) => <Icon {...props} />;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/FolderIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Folder from "./svg/folder.svg?react";
import type {IconBaseProps} from "./IconNative";

export const FolderIcon = (props: IconBaseProps) => <Folder {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/SunIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/sun.svg?react";
import type {IconBaseProps} from "./IconNative";

export const SunIcon = (props: IconBaseProps) => (
    <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/MoonIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/moon.svg?react";
import type {IconBaseProps} from "./IconNative";

export const MoonIcon = (props: IconBaseProps) => (
    <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/arrow-right.svg:
--------------------------------------------------------------------------------

```
<svg width="9" height="18" viewBox="0 0 9 18" fill="none" xmlns="http://www.w3.org/2000/svg">
    <path d="M9 9L-8.15666e-07 17.6603L-5.85621e-08 0.339745L9 9Z" />
</svg>
```

--------------------------------------------------------------------------------
/xmlui/src/testing/infrastructure/main.tsx:
--------------------------------------------------------------------------------

```typescript
import ReactDOM from "react-dom/client";
import TestBed from "./TestBed";

ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
    <TestBed />
);

```

--------------------------------------------------------------------------------
/docs/extensions.ts:
--------------------------------------------------------------------------------

```typescript
import playground from "xmlui-playground";
import search from "xmlui-search";
import helloWorld from "xmlui-hello-world";

export default [playground, search, helloWorld];
```

--------------------------------------------------------------------------------
/xmlui/scripts/generate-docs/extensions-config.json:
--------------------------------------------------------------------------------

```json
{
  "excludeComponentStatuses": ["deprecated", "internal"],
  "cleanFolder": true,
  "includeByName": ["xmlui-animations", "xmlui-website-blocks"],
  "excludeByName": []
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ExpressionIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/expression.svg?react";
import type {IconBaseProps} from "./IconNative";

export const ExpressionIcon = (props: IconBaseProps) => <Icon {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ImageFileIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/img.svg?react";
import type {IconBaseProps} from "./IconNative";

export const ImageFileIcon = (props: IconBaseProps) => (
  <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/StarsIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/stars.svg?react";
import type {IconBaseProps} from "./IconNative";

export const StarsIcon = (props: IconBaseProps) => (
    <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/UnlinkIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Unlink from "./svg/unlink.svg?react";
import type { IconBaseProps } from "./IconNative";

export const UnlinkIcon = (props: IconBaseProps) => <Unlink {...props} />;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/Inspect.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/inspect.svg?react";
import type {IconBaseProps} from "./IconNative";

export const InspectIcon = (props: IconBaseProps) => (
  <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/PlusIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {AiOutlinePlus} from "react-icons/ai";
import type {IconBaseProps} from "./IconNative";

export const PlusIcon = (props: IconBaseProps) => <AiOutlinePlus {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/DocFileIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import DocFile from "./svg/file-text.svg?react";
import type {IconBaseProps} from "./IconNative";

export const DocFileIcon = (props: IconBaseProps) => <DocFile {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ErrorIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {BiErrorCircle} from "react-icons/bi";
import type {IconBaseProps} from "./IconNative";

export const ErrorIcon = (props: IconBaseProps) => <BiErrorCircle {...props}/>

```

--------------------------------------------------------------------------------
/tools/create-app/helpers/make-dir.ts:
--------------------------------------------------------------------------------

```typescript
import fs from 'fs'

export function makeDir(
    root: string,
    options = { recursive: true }
): Promise<string | undefined> {
    return fs.promises.mkdir(root, options)
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ChevronUpIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import { FiChevronUp } from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const ChevronUpIcon = (props: IconBaseProps) => <FiChevronUp {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/Attach.tsx:
--------------------------------------------------------------------------------

```typescript
import type { IconBaseProps } from "./IconNative";
import Attach from "./svg/attach.svg?react";

export const AttachmentIcon = (props: IconBaseProps) => (<Attach {...props} />);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/CodeFileIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import CodeFile from "./svg/code-file.svg?react";
import type {IconBaseProps} from "./IconNative";

export const CodeFileIcon = (props: IconBaseProps) => <CodeFile {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/PenIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {HiOutlinePencil} from 'react-icons/hi';
import type {IconBaseProps} from "./IconNative";

export const PenIcon = (props: IconBaseProps) => <HiOutlinePencil {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/UnknownFileIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/unknown-file.svg?react";
import type { IconBaseProps } from "./IconNative";

export const UnknownFileIcon = (props: IconBaseProps) => <Icon {...props} />;

```

--------------------------------------------------------------------------------
/xmlui/src/testing/drivers/ModalDialogDriver.ts:
--------------------------------------------------------------------------------

```typescript
import { ComponentDriver } from "../ComponentDrivers";

export class ModalDialogDriver extends ComponentDriver {
  get titlePart() {
    return this.getByPartName("title");
  }
}

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/AdmonitionTip.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/admonition_tip.svg?react";
import type { IconBaseProps } from "./IconNative";

export const AdmonitionTipIcon = (props: IconBaseProps) => <Icon {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/AdmonitionInfo.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/admonition_info.svg?react";
import type { IconBaseProps } from "./IconNative";

export const AdmonitionInfoIcon = (props: IconBaseProps) => <Icon {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/AdmonitionNote.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/admonition_note.svg?react";
import type { IconBaseProps } from "./IconNative";

export const AdmonitionNoteIcon = (props: IconBaseProps) => <Icon {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ChevronDownIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import { FiChevronDown } from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const ChevronDownIcon = (props: IconBaseProps) => <FiChevronDown {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/TrendingLevelIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/trending-level.svg?react";
import type { IconBaseProps } from "./IconNative";

export const TrendingLevelIcon = (props: IconBaseProps) => <Icon {...props} />;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/TrendingUpIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/trending-up.svg?react";
import type {IconBaseProps} from "./IconNative";

export const TrendingUpIcon = (props: IconBaseProps) => (
    <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/WarningIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {AiOutlineWarning} from "react-icons/ai";
import type {IconBaseProps} from "./IconNative";

export const WarningIcon = (props: IconBaseProps) => <AiOutlineWarning {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/DarkToLightIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/dark_to_light.svg?react";
import type {IconBaseProps} from "./IconNative";

export const DarkToLightIcon = (props: IconBaseProps) => (
  <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/GlobeIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {MdOutlineLanguage} from "react-icons/md";
import type {IconBaseProps} from "./IconNative";

export const GlobeIcon = (props: IconBaseProps) => <MdOutlineLanguage {...props}/>;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/HyperLinkIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {MdOutlineLaunch} from "react-icons/md";
import type {IconBaseProps} from "./IconNative";

export const HyperLinkIcon = (props: IconBaseProps) => <MdOutlineLaunch  {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/LightToDark.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/light_to_dark.svg?react";
import type {IconBaseProps} from "./IconNative";

export const LightToDarkIcon = (props: IconBaseProps) => (
  <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/AdmonitionDanger.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/admonition_danger.svg?react";
import type { IconBaseProps } from "./IconNative";

export const AdmonitionDangerIcon = (props: IconBaseProps) => <Icon {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ChevronRight.tsx:
--------------------------------------------------------------------------------

```typescript
import { FiChevronRight } from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const ChevronRightIcon = (props: IconBaseProps) => <FiChevronRight {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/TrendingDownIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/trending-down.svg?react";
import type {IconBaseProps} from "./IconNative";

export const TrendingDownIcon = (props: IconBaseProps) => (
    <Icon {...props} />
);

```

--------------------------------------------------------------------------------
/xmlui/bin/bootstrap.js:
--------------------------------------------------------------------------------

```javascript
#!/usr/bin/env node

require("ts-node").register({
  transpileOnly: true,
  esm: true,
  compilerOptions: {
    module: "commonjs",
    esModuleInterop: true,
  },
});
require("./index");

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/LooseListIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {HiOutlineViewList} from "react-icons/hi";
import type {IconBaseProps} from "./IconNative";

export const LooseListIcon = (props: IconBaseProps) => <HiOutlineViewList {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/MoreOptionsIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {FiMoreHorizontal} from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const MoreOptionsIcon = (props: IconBaseProps) => <FiMoreHorizontal {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/AdmonitionWarning.tsx:
--------------------------------------------------------------------------------

```typescript
import Icon from "./svg/admonition_warning.svg?react";
import type { IconBaseProps } from "./IconNative";

export const AdmonitionWarningIcon = (props: IconBaseProps) => <Icon {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/EmailIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import type {IconBaseProps} from "./IconNative";
import {MdOutlineMailOutline} from "react-icons/md";

export const EmailIcon = (props: IconBaseProps) => <MdOutlineMailOutline {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/CodeSandbox.tsx:
--------------------------------------------------------------------------------

```typescript
import CodeSandbox from "./svg/code-sandbox.svg?react";
import type {IconBaseProps} from "./IconNative";

export const CodeSandboxIcon = (props: IconBaseProps) => <CodeSandbox {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/EmptyFolderIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import EmptyFolder from "./svg/empty-folder.svg?react";
import type {IconBaseProps} from "./IconNative";

export const EmptyFolderIcon = (props: IconBaseProps) => <EmptyFolder {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/FillPlusCricleIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {AiFillPlusCircle} from "react-icons/ai";
import type {IconBaseProps} from "./IconNative";

export const FillPlusCircleIcon = (props: IconBaseProps) => <AiFillPlusCircle {...props}/>

```

--------------------------------------------------------------------------------
/docs/public/resources/files/dashboard-stats.json:
--------------------------------------------------------------------------------

```json
[
  {
    "total_invoices": 93,
    "total_clients": 30,
    "outstanding": 3502.9,
    "paid_this_year": 1960.18,
    "draft_invoices": 7,
    "sent_invoices": 6,
    "paid_invoices": 80
  }
]

```

--------------------------------------------------------------------------------
/xmlui/src/components/App/IndexerContext.ts:
--------------------------------------------------------------------------------

```typescript
import React, { useContext } from "react";

export const IndexerContext = React.createContext({
  indexing: false
});

export function useIndexerContext(){
  return useContext(IndexerContext);
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/TrashIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import {MdOutlineDeleteForever} from "react-icons/md";
import type {IconBaseProps} from "./IconNative";

export const TrashIcon = (props: IconBaseProps) => <MdOutlineDeleteForever {...props} />

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/src/playground/PlaygroundNative.module.scss:
--------------------------------------------------------------------------------

```scss
@use "xmlui/themes.scss" as themes;

.playground {
  overflow: hidden;
  margin-top: 1.25rem;
  border-radius: 16px;
  border: 1px solid themes.$borderColor;
  box-shadow: themes.$boxShadow-md;
}

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ContentCopyIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import type {IconBaseProps} from "./IconNative";
import {MdOutlineContentCopy} from "react-icons/md";

export const ContentCopyIcon = (props: IconBaseProps) => <MdOutlineContentCopy {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/DotMenuIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import type {IconBaseProps} from "./IconNative";
import { IoEllipsisVertical } from "react-icons/io5";

export const DotMenuIcon = (props: IconBaseProps) => (
  <IoEllipsisVertical {...props}/>
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Input/InputDivider.module.scss:
--------------------------------------------------------------------------------

```scss
/* InputDivider base styles - only non-conflicting defaults */
@layer components {
  .inputDivider {
    white-space: pre;
    display: inline-block;
    font: inherit;
    user-select: none;
  }
}

```

--------------------------------------------------------------------------------
/docs/public/pages/xmlui-charts/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "BarChart": "BarChart",
  "DonutChart": "DonutChart",
  "LabelList": "LabelList",
  "Legend": "Legend",
  "LineChart": "LineChart",
  "PieChart": "PieChart"
}
```

--------------------------------------------------------------------------------
/xmlui/src/components/VisuallyHidden.tsx:
--------------------------------------------------------------------------------

```typescript
import { VisuallyHidden as VH } from "@radix-ui/react-visually-hidden";

export const VisuallyHidden = ({ children, ...props }: { children: React.ReactNode }) => (
  <VH {...props}>{children}</VH>
);

```

--------------------------------------------------------------------------------
/packages/xmlui-devtools/src/devtools/ModalVisibilityContext.tsx:
--------------------------------------------------------------------------------

```typescript
import React from "react";

interface IModalVisibilityContext {
  requestClose: () => Promise<void>;
}

export const ModalVisibilityContext = React.createContext<IModalVisibilityContext | null>(null);

```

--------------------------------------------------------------------------------
/packages/xmlui-devtools/src/index.tsx:
--------------------------------------------------------------------------------

```typescript
import { devToolsComponentRenderer } from "./devtools/DevTools";

export default {
  namespace: "XMLUIDevtools",
  components: [devToolsComponentRenderer],
};

export { Editor } from "./editor/Editor";

```

--------------------------------------------------------------------------------
/packages/xmlui-devtools/meta/componentsMetadata.ts:
--------------------------------------------------------------------------------

```typescript
import { EditorMd } from "../src/devtools/DevTools";

export const componentMetadata = {
  name: "Editor",
  state: "experimental",
  description: `XMLUI Editor`,
  metadata: {
    Editor: EditorMd,
  },
};

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/DotMenuHorizontalIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import type { IconBaseProps } from "./IconNative";
import { IoEllipsisHorizontal } from "react-icons/io5";

export const DotMenuHorizontalIcon = (props: IconBaseProps) => <IoEllipsisHorizontal {...props} />;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ChevronLeft.tsx:
--------------------------------------------------------------------------------

```typescript
import React from "react";
import {FiChevronLeft} from "react-icons/fi";
import type {IconBaseProps} from "./IconNative";

export const ChevronLeftIcon = (props: IconBaseProps) => <FiChevronLeft {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/devtools/InspectorDialogVisibilityContext.tsx:
--------------------------------------------------------------------------------

```typescript
import React from "react";

interface IModalVisibilityContext {
  requestClose: () => Promise<void>;
}

export const InspectorDialogVisibilityContext = React.createContext<IModalVisibilityContext | null>(null);

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/rendering/nodeUtils.ts:
--------------------------------------------------------------------------------

```typescript
import type { ComponentDef } from "../../abstractions/ComponentDefs";

export function hasRenderableChildren(children: ComponentDef[]): boolean {
  return !!children?.some((child) => child?.type !== "Slot");  
}
```

--------------------------------------------------------------------------------
/docs/public/resources/files/for-download/start-darwin.sh:
--------------------------------------------------------------------------------

```bash
#!/bin/bash

# Check if npx is available
if command -v npx > /dev/null 2>&1; then
    # Run npx http-server -y -o
    npx -y http-server -o
else
    echo "npx is not available. Please install Node.js and npm."
fi

```

--------------------------------------------------------------------------------
/packages/xmlui-search/meta/componentsMetadata.ts:
--------------------------------------------------------------------------------

```typescript
import { SearchMd } from "../src";

export const componentMetadata = {
  name: "Search",
  state: "experimental",
  description: "Search component for Markdown content.",
  metadata: {
    Search: SearchMd,
  },
};

```

--------------------------------------------------------------------------------
/docs/public/resources/files/for-download/start-linux.sh:
--------------------------------------------------------------------------------

```bash
#!/usr/bin/env bash

# Check if npx is available
if command -v npx > /dev/null 2>&1; then
    # Run npx http-server -y -o
    npx -y http-server -o
else
    echo "npx is not available. Please install Node.js and npm."
fi

```

--------------------------------------------------------------------------------
/packages/xmlui-pdf/meta/componentsMetadata.ts:
--------------------------------------------------------------------------------

```typescript
import { PdfMd } from "../src";

export const componentMetadata = {
  name: "PDF",
  state: "in progress",
  description: "This package provides components for working with pdf files.",
  metadata: {
    Pdf: PdfMd,
  },
};

```

--------------------------------------------------------------------------------
/tools/create-app/tsconfig.json:
--------------------------------------------------------------------------------

```json
{
  "compilerOptions": {
    "target": "es2019",
    "moduleResolution": "node",
    "strict": true,
    "resolveJsonModule": true,
    "esModuleInterop": true,
    "skipLibCheck": false
  },
  "exclude": ["templates", "dist"]
}
```

--------------------------------------------------------------------------------
/docs/public/resources/files/for-download/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <script src="./xmlui/xmlui-standalone.umd.js"></script>
</head>
<body>
</body>
</html>

```

--------------------------------------------------------------------------------
/tools/create-app/templates/default/ts/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
export const runtime = import.meta.glob(`/src/**`, { eager: true });
startApp(runtime);

if (import.meta.hot) {
    import.meta.hot.accept((newModule) => {
        startApp(newModule?.runtime);
    });
}
```

--------------------------------------------------------------------------------
/xmlui/src/abstractions/ContainerDefs.ts:
--------------------------------------------------------------------------------

```typescript
// We store the state application state in a hierarchical structure of containers. 
// This type represents the state within a single container stored as key and value 
// pairs.
export type ContainerState = Record<string | symbol, any>;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/Binding.tsx:
--------------------------------------------------------------------------------

```typescript
import type {IconBaseProps} from "./IconNative";
import Binding from "./svg/binding.svg?react";
import style from "./Binding.module.scss";

export const BindingIcon = (props: IconBaseProps) => <Binding className={style.binding} {...props}/>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/filter.svg:
--------------------------------------------------------------------------------

```
<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M22 3H2L10 12.46V19L14 21V12.46L22 3Z" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
</svg>

```

--------------------------------------------------------------------------------
/tools/create-app/helpers/is-writeable.ts:
--------------------------------------------------------------------------------

```typescript
import fs from 'fs'

export async function isWriteable(directory: string): Promise<boolean> {
    try {
        await fs.promises.access(directory, (fs.constants || fs).W_OK)
        return true
    } catch (err) {
        return false
    }
}
```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-animations/_overview.md:
--------------------------------------------------------------------------------

```markdown
# Xmlui Animations Package

This package contains components that deal with different sorts of animations.
These components can wrap other components and provide different sorts of animations that run when the child component visibility changes.
```

--------------------------------------------------------------------------------
/docs/content/extensions/xmlui-animations/_overview.md:
--------------------------------------------------------------------------------

```markdown
# Xmlui Animations Package

This package contains components that deal with different sorts of animations.
These components can wrap other components and provide different sorts of animations that run when the child component visibility changes.
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ArrowDropUp.tsx:
--------------------------------------------------------------------------------

```typescript
import styles from "./ArrowDropUp.module.scss";
import Arrow from "./svg/arrow-up.svg?react";
import type {IconBaseProps} from "./IconNative";

export const ArrowDropUp = (props: IconBaseProps) => (<Arrow className={styles.arrowDropUp} {...props}/>);

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ArrowLeft.tsx:
--------------------------------------------------------------------------------

```typescript
import styles from "./ArrowLeft.module.scss";
import Arrow from "./svg/arrow-left.svg?react";
import type {IconBaseProps} from "./IconNative";

export const ArrowLeft = (props: IconBaseProps) => (
  <Arrow className={styles.arrowLeft} {...props}/>
);

```

--------------------------------------------------------------------------------
/xmlui/src/components/NestedApp/defaultProps.tsx:
--------------------------------------------------------------------------------

```typescript
// Default props for NestedApp component
import { EMPTY_ARRAY } from "../../components-core/constants";

export const defaultProps = {
  allowPlaygroundPopup: true,
  withFrame: true,
  noHeader: false,
  splitView: false,
  components: EMPTY_ARRAY
};
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ArrowRight.tsx:
--------------------------------------------------------------------------------

```typescript
import styles from "./ArrowRight.module.scss";
import Arrow from "./svg/arrow-right.svg?react";
import type {IconBaseProps} from "./IconNative";

export const ArrowRight = (props: IconBaseProps) => (<Arrow className={styles.arrowRight} {...props} />);

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/appContext/misc-utils.ts:
--------------------------------------------------------------------------------

```typescript
import { capitalize, defaultTo } from "lodash-es";

import { distinct, findByField, pluralize, toHashObject } from "../utils/misc";

export const miscellaneousUtils = {
  capitalize,
  pluralize,
  defaultTo,
  toHashObject,
  findByField,
  distinct
};

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/constants.ts:
--------------------------------------------------------------------------------

```typescript
export const EMPTY_ARRAY: Array<any> = Object.freeze([]) as unknown as Array<any>;
export const EMPTY_OBJECT = Object.freeze({}) as unknown as {};
export const noop = (...args: any[]) => ({} as any);
export const asyncNoop = async (...args: any[]) => {};

```

--------------------------------------------------------------------------------
/tools/create-app/templates/default/ts/src/config.ts:
--------------------------------------------------------------------------------

```typescript
import type { StandaloneAppDescription } from "xmlui";

const App: StandaloneAppDescription = {
  name: "Tutorial",
  version: "0.0.1",
  resources: {
    logo: "resources/xmlui-logo.svg",
    favicon: "resources/favicon.ico",
  },
};

export default App;

```

--------------------------------------------------------------------------------
/xmlui/src/language-server/server.ts:
--------------------------------------------------------------------------------

```typescript
import {
  createConnection,
  ProposedFeatures,
} from 'vscode-languageserver/node';
import * as serverCommon from "./server-common"

export function start(){
  const connection = createConnection(ProposedFeatures.all);
  serverCommon.start(connection)
}

```

--------------------------------------------------------------------------------
/xmlui/src/components/ProfileMenu/ProfileMenu.module.scss:
--------------------------------------------------------------------------------

```scss
@use "../../components-core/theming/themes" as t;

@layer components {
  .loggedInUserInfoWrapper {
    padding: t.$space-2;
    font-size: t.$fontSize-sm;
  }

  .name {
    color: t.$textColor-primary;
  }

  .email {
    color: t.$textColor-subtitle;
  }
}

```

--------------------------------------------------------------------------------
/xmlui/src/syntax/textMate/index.ts:
--------------------------------------------------------------------------------

```typescript
import xmluiThemeDark from "./xmlui-dark.json";
import xmluiThemeLight from "./xmlui-light.json";
import xmluiTheme from "./xmlui.json";
import xmluiGrammar from "./xmlui.tmLanguage.json";

export { xmluiThemeDark, xmluiThemeLight, xmluiTheme, xmluiGrammar };

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/DatabaseIcon.tsx:
--------------------------------------------------------------------------------

```typescript
import Datavase from "./svg/database.svg?react";
import type { IconBaseProps } from "../Icon/IconNative";
import styles from "./DatabaseIcon.module.scss"

export const DatabaseIcon = (props: IconBaseProps) => <Datavase className={styles.database} {...props} />

```

--------------------------------------------------------------------------------
/xmlui/src/components/ToneSwitch/ToneSwitch.md:
--------------------------------------------------------------------------------

```markdown
%-DESC-START

```xmlui-pg {4} copy display name="Example: using ToneSwitch"
<App>
  <AppHeader>
    <SpaceFiller />
    <ToneSwitch />
  </AppHeader>
  <Card
    title="Tone Switch"
    subtitle="Toggle the switch to change the tone."
  />
</App>
```

%-DESC-END
```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/ArrowDropDown.tsx:
--------------------------------------------------------------------------------

```typescript
import styles from "./ArrowDropDown.module.scss";
import Arrow from "./svg/arrow-dropdown.svg?react"
import type {IconBaseProps} from "./IconNative";

export const ArrowDropDown = (props: IconBaseProps) => (<Arrow  className={styles.arrowDropDown} {...props} />);

```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-animations/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Animation": "Animation",
  "FadeAnimation": "FadeAnimation",
  "FadeInAnimation": "FadeInAnimation",
  "FadeOutAnimation": "FadeOutAnimation",
  "ScaleAnimation": "ScaleAnimation",
  "SlideInAnimation": "SlideInAnimation"
}
```

--------------------------------------------------------------------------------
/docs/content/extensions/xmlui-animations/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Animation": "Animation",
  "FadeAnimation": "FadeAnimation",
  "FadeInAnimation": "FadeInAnimation",
  "FadeOutAnimation": "FadeOutAnimation",
  "ScaleAnimation": "ScaleAnimation",
  "SlideInAnimation": "SlideInAnimation"
}
```

--------------------------------------------------------------------------------
/docs/public/pages/xmlui-animations/_meta.json:
--------------------------------------------------------------------------------

```json
{
  "_overview": "Extension Overview",
  "Animation": "Animation",
  "FadeAnimation": "FadeAnimation",
  "FadeInAnimation": "FadeInAnimation",
  "FadeOutAnimation": "FadeOutAnimation",
  "ScaleAnimation": "ScaleAnimation",
  "SlideInAnimation": "SlideInAnimation"
}
```

--------------------------------------------------------------------------------
/docs/public/pages/xmlui-spreadsheet/_overview.md:
--------------------------------------------------------------------------------

```markdown
## Xmlui Spreadsheet Package

This package provides an experimental spreadsheet component for XMLUI.

## Package Components

| Component | Description | Status |
| :---: | --- | :---: |
| [Spreadsheet](./xmlui-spreadsheet/Spreadsheet) | XMLUI Spreadsheet | experimental |

```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-website-blocks/HelloMd.md:
--------------------------------------------------------------------------------

```markdown
# HelloMd [#hellomd]

A sample component

## Properties

This component does not have any properties.

## Events

This component does not have any events.

## Exposed Methods

This component does not expose any methods.

## Styling

This component does not have any styles.

```

--------------------------------------------------------------------------------
/docs/content/extensions/xmlui-website-blocks/HelloMd.md:
--------------------------------------------------------------------------------

```markdown
# HelloMd [#hellomd]

A sample component

## Properties

This component does not have any properties.

## Events

This component does not have any events.

## Exposed Methods

This component does not expose any methods.

## Styling

This component does not have any styles.

```

--------------------------------------------------------------------------------
/packages/xmlui-search/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import Search from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, Search);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, Search);
  });
}

```

--------------------------------------------------------------------------------
/xmlui/vitest.config.ts:
--------------------------------------------------------------------------------

```typescript
import viteConfig from "./vite.config";
import { defineConfig, mergeConfig } from "vitest/config";

export default defineConfig(configEnv => mergeConfig(
    viteConfig(configEnv),
    defineConfig({
      test: {
        include: ["**/tests/**/*.test.ts"],
      },
    })
));
```

--------------------------------------------------------------------------------
/xmlui/src/components/PageMetaTitle/PageMetaTilteNative.tsx:
--------------------------------------------------------------------------------

```typescript
import { Helmet } from "react-helmet-async";

// Default props for PageMetaTitle component
export const defaultProps = {
  title: "XMLUI Application"
};

export const PageMetaTitle = ({ title = defaultProps.title }: { title: string }) => {
  return <Helmet title={title} />;
};

```

--------------------------------------------------------------------------------
/packages/xmlui-spreadsheet/meta/componentsMetadata.ts:
--------------------------------------------------------------------------------

```typescript
import { SpreadsheetMd } from "../src/Spreadsheet";

export const componentMetadata = {
  name: "Spreadsheet",
  state: "experimental",
  description: "This package provides an experimental spreadsheet component for XMLUI.",
  metadata: {
    Spreadsheet: SpreadsheetMd,
  },
};

```

--------------------------------------------------------------------------------
/xmlui/src/syntax/monaco/index.ts:
--------------------------------------------------------------------------------

```typescript
export { XmluiGrammar as xmluiGrammar } from "./grammar.monacoLanguage";
export { XmluiScripGrammar as xmluiScriptGrammar } from "./xmluiscript.monacoLanguage";
export { default as xmluiThemeDark } from "./xmlui-dark";
export { default as xmluiThemeLight } from "./xmlui-light";

```

--------------------------------------------------------------------------------
/docs/public/resources/files/for-download/index-with-api.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <script src="./xmlui/mockApiDef.js"></script>
    <script src="./xmlui/xmlui-standalone.umd.js"></script>
</head>
<body>
</body>
</html>

```

--------------------------------------------------------------------------------
/packages/xmlui-hello-world/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import HelloWorld from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, HelloWorld);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, HelloWorld);
  });
}

```

--------------------------------------------------------------------------------
/packages/xmlui-os-frames/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import components from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, components);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, components);
  });
}

```

--------------------------------------------------------------------------------
/packages/xmlui-pdf/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import pdf from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, pdf);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, pdf);
  });
}

export default pdf;

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import Playground from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, Playground);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, Playground);
  });
}

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/src/playground/Box.tsx:
--------------------------------------------------------------------------------

```typescript
import type { CSSProperties } from "react";
import style from "./Box.module.scss";

export const Box = ({
  children,
  styles,
}: {
  children: React.ReactNode;
  styles?: CSSProperties;
}) => {
  return (
    <div style={styles} className={style.box}>
      {children}
    </div>
  );
};

```

--------------------------------------------------------------------------------
/docs/public/pages/xmlui-pdf/_overview.md:
--------------------------------------------------------------------------------

```markdown
## Xmlui Pdf Package

This package provides components for working with pdf files.

## Package Components

| Component | Description | Status |
| :---: | --- | :---: |
| [Pdf](./xmlui-pdf/Pdf) | The `Pdf` component provides a read-only preview of a pdf document's contents. | experimental |

```

--------------------------------------------------------------------------------
/docs/src/themes/xmlui-gray-on-default.ts:
--------------------------------------------------------------------------------

```typescript
import type { ThemeDefinition } from "xmlui";

export const XmluiGrayOnDefaultTheme: ThemeDefinition = {
  name: "XMLUI Gray Documentation Theme",
  id: "xmlui-gray-on-default",
  extends: ["xmlui-gray", "docs-theme"],
  themeVars: {},
  resources: {},
};

export default XmluiGrayOnDefaultTheme;

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/trending-level.svg:
--------------------------------------------------------------------------------

```
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="icon ms-1">
  <path stroke="none" d="M0 0h24v24H0z" fill="none"></path>
  <path d="M5 12l14 0"></path>
</svg>
```

--------------------------------------------------------------------------------
/xmlui/src/components/ToneChangerButton/ToneChangerButton.md:
--------------------------------------------------------------------------------

```markdown
%-DESC-START

```xmlui-pg {4} copy display name="Example: using ToneChangerButton"
<App>
  <AppHeader>
    <SpaceFiller />
    <ToneChangerButton />
  </AppHeader>
  <Card
    title="Tone Changer Button"
    subtitle="Click the button in the header to change the tone."
  />
</App>
```

%-DESC-END
```

--------------------------------------------------------------------------------
/tools/vscode/tsconfig.json:
--------------------------------------------------------------------------------

```json
{
  "compilerOptions": {
    "module": "ESNext",
    "moduleResolution": "bundler",
    "target": "es2020",
    "lib": ["ESNext"],
    "outDir": "dist",
    "rootDir": "src",
    "skipLibCheck": true,
    "sourceMap": true
  },
  "include": ["src"],
  "exclude": ["node_modules", ".vscode-test"]
}

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/src/index.tsx:
--------------------------------------------------------------------------------

```typescript
import { playgroundComponentRenderer } from "./playground/Playground";
import { standalonePlaygroundComponentRenderer } from "./playground/StandalonePlayground";

export default {
  namespace: "XMLUIExtensions",
  components: [playgroundComponentRenderer, standalonePlaygroundComponentRenderer],
};

```

--------------------------------------------------------------------------------
/docs/src/themes/xmlui-green-on-default.ts:
--------------------------------------------------------------------------------

```typescript
import type { ThemeDefinition } from "xmlui";

export const XmluiGreenOnDefaultTheme: ThemeDefinition = {
  name: "XMLUI Green Documentation Theme",
  id: "xmlui-green-on-default",
  extends: ["xmlui-green", "docs-theme"],
  themeVars: {},
  resources: {},
};

export default XmluiGreenOnDefaultTheme;

```

--------------------------------------------------------------------------------
/xmlui/src/logging/LoggerInitializer.tsx:
--------------------------------------------------------------------------------

```typescript
import { useLogger } from "./LoggerContext";
import { useEffect } from "react";
import { loggerService } from "./LoggerService";

export const LoggerInitializer = () => {
  const { addLog } = useLogger();

  useEffect(() => {
    loggerService.registerCallback(addLog);
  }, [addLog]);

  return null;
};

```

--------------------------------------------------------------------------------
/docs/src/themes/xmlui-orange-on-default.ts:
--------------------------------------------------------------------------------

```typescript
import type { ThemeDefinition } from "xmlui";

export const XmluiOrangeOnDefaultTheme: ThemeDefinition = {
  name: "XMLUI Orange Documentation Theme",
  id: "xmlui-orange-on-default",
  extends: ["xmlui-orange", "docs-theme"],
  themeVars: {},
  resources: {},
};

export default XmluiOrangeOnDefaultTheme;

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/src/hooks/useToast.ts:
--------------------------------------------------------------------------------

```typescript
import {useContext} from "react";
import { ToastContext } from "../providers/ToastProvider";

export const useToast = () => {
    const context = useContext(ToastContext);
    if (context === undefined) {
        throw new Error('useToast must be used within a ToastProvider');
    }
    return context;
};

```

--------------------------------------------------------------------------------
/packages/xmlui-website-blocks/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import websites from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, [websites]);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, [websites]);
  });
}

export default websites;

```

--------------------------------------------------------------------------------
/blog/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import usedExtensions from "./extensions";

export const runtime = import.meta.glob(`/src/**`, { eager: true });
startApp(runtime, usedExtensions);

if (import.meta.hot) {
    import.meta.hot.accept((newModule) => {
        startApp(newModule?.runtime, usedExtensions);
    });
}

```

--------------------------------------------------------------------------------
/docs/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import usedExtensions from "./extensions";

export const runtime = import.meta.glob(`/src/**`, { eager: true });
startApp(runtime, usedExtensions);

if (import.meta.hot) {
    import.meta.hot.accept((newModule) => {
        startApp(newModule?.runtime, usedExtensions);
    });
}

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/interception/useApiInterceptorContext.tsx:
--------------------------------------------------------------------------------

```typescript
import { createContext, useContext } from "react";

import type { IApiInterceptorContext } from "../../abstractions/AppContextDefs";

export const ApiInterceptorContext = createContext<IApiInterceptorContext>(null as any);

export function useApiInterceptorContext() {
  return useContext(ApiInterceptorContext);
}

```

--------------------------------------------------------------------------------
/packages/xmlui-animations/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/resources/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
<body>
<div id="root"></div>
<script type="module" src="/index.ts"></script>
</body>
</html>

```

--------------------------------------------------------------------------------
/packages/xmlui-devtools/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/resources/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
<body>
<div id="root"></div>
<script type="module" src="/index.ts"></script>
</body>
</html>

```

--------------------------------------------------------------------------------
/packages/xmlui-os-frames/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/resources/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
<body>
<div id="root"></div>
<script type="module" src="/index.ts"></script>
</body>
</html>

```

--------------------------------------------------------------------------------
/packages/xmlui-pdf/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/resources/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
<body>
<div id="root"></div>
<script type="module" src="/index.ts"></script>
</body>
</html>

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/resources/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
<body>
<div id="root"></div>
<script type="module" src="/index.ts"></script>
</body>
</html>

```

--------------------------------------------------------------------------------
/packages/xmlui-search/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/resources/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
<body>
<div id="root"></div>
<script type="module" src="/index.ts"></script>
</body>
</html>

```

--------------------------------------------------------------------------------
/packages/xmlui-website-blocks/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/resources/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
<body>
<div id="root"></div>
<script type="module" src="/index.ts"></script>
</body>
</html>

```

--------------------------------------------------------------------------------
/xmlui/src/language-server/services/common/lsp-utils.ts:
--------------------------------------------------------------------------------

```typescript
import type { Position, Range } from "vscode-languageserver";

type OffsetRange = { pos: number; end: number };

export function offsetRangeToPosRange(
  offsetToPos: (offset: number) => Position,
  range: OffsetRange,
): Range {
  return {
    start: offsetToPos(range.pos),
    end: offsetToPos(range.end),
  };
}

```

--------------------------------------------------------------------------------
/packages/xmlui-playground/src/hooks/usePlayground.ts:
--------------------------------------------------------------------------------

```typescript
import {useContext} from "react";
import {PlaygroundContext} from "../state/store";

export const usePlayground = () => {
    const context = useContext(PlaygroundContext);
    if (context === undefined) {
        throw new Error('usePlayground must be used within a PlaygroundProvider');
    }

    return context;
};

```

--------------------------------------------------------------------------------
/packages/xmlui-animations/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import animations from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, [animations]);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, [animations]);
  });
}

export default animations;

```

--------------------------------------------------------------------------------
/docs/public/pages/news-and-reviews.md:
--------------------------------------------------------------------------------

```markdown
# News and reviews

```xmlui-pg
<Table data="/resources/files/news-and-reviews.json" sortBy="date" sortDirection="descending">
  <Column bindTo="date" />
  <Column width="4*" header="title">
    <Link target="_blank" to="{$item.url}">
      { $item.title }
    </Link>
  </Column>
  <Column bindTo="source" />
</Table>
```
```

--------------------------------------------------------------------------------
/docs/content/components/xmlui-spreadsheet/Spreadsheet.md:
--------------------------------------------------------------------------------

```markdown
# Spreadsheet [#spreadsheet]

XMLUI Spreadsheet

## Properties

### `worksheets`

This property sets the initial value of the spreadsheet's worksheets.

## Events

This component does not have any events.

## Exposed Methods

This component does not expose any methods.

## Styling

This component does not have any styles.

```

--------------------------------------------------------------------------------
/packages/xmlui-spreadsheet/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import spreadsheet from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, [spreadsheet]);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, [spreadsheet]);
  });
}

export default spreadsheet;

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/parts.ts:
--------------------------------------------------------------------------------

```typescript
export const PART_LABEL = "label";
export const PART_LABELED_ITEM = "labeledItem";
export const PART_INPUT = "input";
export const PART_START_ADORNMENT = "startAdornment";
export const PART_END_ADORNMENT = "endAdornment";
export const PART_TRACK = "track";
export const PART_RANGE = "range";
export const PART_THUMB = "thumb";




```

--------------------------------------------------------------------------------
/xmlui/src/components/Input/InputLabel.module.scss:
--------------------------------------------------------------------------------

```scss
@use "../../components-core/theming/themes" as t;

@layer components {
  .inputLabel {
    cursor: pointer;
    color: t.$textColor-subtitle;
    padding-bottom: t.$space-1;

    &.disabled {
      cursor: not-allowed;
      color: t.$textColor--disabled;
    }
  }

  .required {
    color: t.$textColor-InputLabel-required;
  }
}

```

--------------------------------------------------------------------------------
/tools/create-app/templates/types.ts:
--------------------------------------------------------------------------------

```typescript
import { PackageManager } from '../helpers/get-pkg-manager'

export type TemplateType = 'default'// | 'app' | 'default-tw' | 'app-tw'

export type TemplateMode = 'js' | 'ts'

export interface InstallTemplateArgs {
    appName: string
    root: string
    packageManager: PackageManager
    template: TemplateType
    useGit: boolean;
}
```

--------------------------------------------------------------------------------
/xmlui/src/abstractions/FunctionDefs.ts:
--------------------------------------------------------------------------------

```typescript
// XMLUI executes its code asynchronously. This type defines functions that can be 
// used in XMLUI as actions or event handlers.
export type AsyncFunction = (...args: any) => Promise<any> | any;

// XMLUI executes some code synchronously. This type defines those functions' signature
export type SyncFunction = (...args: any) => any;

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/rendering/UnknownComponent.module.scss:
--------------------------------------------------------------------------------

```scss
@use "../theming/themes" as themes;

.errorOverlay{
  background-color: rgba(255,162,162, 0.8);
  border-radius: 10px;
  padding: 8px;
  min-width: 200px;
}

.title{
  background-color: themes.$color-danger-500;
  color: white;
  font-weight: themes.$fontWeight-light;
  border-radius: 4px;
  padding-left: 4px;
  padding-right: 8px;
}

```

--------------------------------------------------------------------------------
/xmlui/src/components/Breakout/BreakoutNative.tsx:
--------------------------------------------------------------------------------

```typescript
import type { ReactNode } from "react";

import styles from "./Breakout.module.scss";

type Props = {
  children?: ReactNode;
  style?: React.CSSProperties;
};

export const Breakout = ({ children, style, ...rest }: Props) => {
  return (
    <div {...rest} style={style} className={styles.breakout}>
      {children}
    </div>
  );
};

```

--------------------------------------------------------------------------------
/tools/create-xmlui-hello-world/package.json:
--------------------------------------------------------------------------------

```json
{
  "name": "create-xmlui-hello-world",
  "version": "0.1.0",
  "description": "Create a minimal HelloWorld XMLUI component",
  "main": "index.js",
  "bin": {
    "create-xmlui-hello-world": "./index.js"
  },
  "scripts": {
    "build": "node index.js"
  },
  "keywords": ["xmlui", "component", "hello-world"],
  "author": "",
  "license": "ISC"
}


```

--------------------------------------------------------------------------------
/docs/public/pages/tutorial-01.md:
--------------------------------------------------------------------------------

```markdown
# XMLUI Invoice

XMLUI Invoice is a demo app that illustrates a range of XMLUI components and patterns. You can [download](https://github.com/xmlui-org/xmlui-invoice/releases/latest/download/xmlui-invoice.zip) the final version to run, explore, and modify. In this tutorial we'll build the app step by step.

![](/resources/images/tutorial-01.png)



```

--------------------------------------------------------------------------------
/xmlui/src/abstractions/ExtensionDefs.ts:
--------------------------------------------------------------------------------

```typescript
import type { ComponentRendererDef, CompoundComponentRendererInfo } from "./RendererDefs";
import type { ThemeDefinition } from "./ThemingDefs";

export type ComponentExtension = ComponentRendererDef | CompoundComponentRendererInfo;

export interface Extension{
  namespace?: string;
  components?: ComponentExtension[];
  themes?: ThemeDefinition[];
}
```

--------------------------------------------------------------------------------
/packages/xmlui-devtools/index.ts:
--------------------------------------------------------------------------------

```typescript
import { startApp } from "xmlui";
import DevTools from "./src";

export const runtime = import.meta.glob(`/demo/**`, { eager: true });
startApp(runtime, DevTools);

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    startApp(newModule?.runtime, DevTools);
  });
}

export default DevTools;

export { Editor } from "./src/editor/Editor";

```

--------------------------------------------------------------------------------
/packages/xmlui-pdf/src/LazyPdfNative.tsx:
--------------------------------------------------------------------------------

```typescript
import { Suspense, lazy, forwardRef } from "react";

const Pdf = lazy(() => import("./Pdf"));

interface Props {
  src?: string;
  data?: any; // Binary data for PDF content
}

export const LazyPdf = forwardRef((props: Props, ref) => {
  return (
    <Suspense fallback={<div>Loading...</div>}>
      <Pdf {...props} ref={ref} />
    </Suspense>
  );
});

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/trending-up.svg:
--------------------------------------------------------------------------------

```
<svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-trending-up" width="24" height="24" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round">
  <path stroke="none" d="M0 0h24v24H0z" fill="none"/>
  <path d="M3 17l6 -6l4 4l8 -8" />
  <path d="M14 7l7 0l0 7" />
</svg>

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/trending-down.svg:
--------------------------------------------------------------------------------

```
<svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-trending-down" width="24" height="24" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round">
  <path stroke="none" d="M0 0h24v24H0z" fill="none"/>
  <path d="M3 7l6 6l4 -4l8 8" />
  <path d="M21 10l0 7l-7 0" />
</svg>



```

--------------------------------------------------------------------------------
/xmlui/src/components/Input/InputAdornment.module.scss:
--------------------------------------------------------------------------------

```scss
@use "../../components-core/theming/themes" as t;

@layer components {
  .wrapper {
    display: flex;
    gap: t.$space-2;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: t.$textColor-subtitle;
  }

  .clickable {
    cursor: pointer;

    &:hover {
      opacity: 0.8;
    }

    &:focus {
      outline: none;
    }
  }
}

```

--------------------------------------------------------------------------------
/xmlui/src/components/ModalDialog/Dialog.module.scss:
--------------------------------------------------------------------------------

```scss
@use "../../components-core/theming/themes" as t;

@layer components {
  .dialogContent {
    display: flex;
    flex-direction: column;
  }

  .dialogActions {
    &:not(:empty) {
      margin-top: t.$space-4;
    }
  }

  @media (min-width: 40em) {
    .dialogActions {
      display: flex;
      justify-content: flex-end;
      gap: t.$space-4;
    }
  }

}


```

--------------------------------------------------------------------------------
/xmlui/src/components/StickyBox/StickyBox.md:
--------------------------------------------------------------------------------

```markdown
%-PROP-START to

```xmlui-pg copy display name="Example: to" height="200px"
<App>
  <StickyBox to="top">
    This part of the UI sticks to the top
  </StickyBox>
  <Stack backgroundColor="red" height="80px" width="100%" />
  <Stack backgroundColor="green" height="80px" width="100%" />
  <Stack backgroundColor="blue" height="80px" width="100%" />
</App>
```

%-PROP-END

```

--------------------------------------------------------------------------------
/xmlui/src/components/Icon/svg/stars.svg:
--------------------------------------------------------------------------------

```
<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="currentColor">
  <path d="m354-287 126-76 126 77-33-144 111-96-146-13-58-136-58 135-146 13 111 97-33 143ZM233-120l65-281L80-590l288-25 112-265 112 265 288 25-218 189 65 281-247-149-247 149Zm457-560 21-89-71-59 94-8 36-84 36 84 94 8-71 59 21 89-80-47-80 47ZM480-481Z"/>
</svg>
```

--------------------------------------------------------------------------------
/packages/xmlui-os-frames/meta/componentsMetadata.ts:
--------------------------------------------------------------------------------

```typescript
import { iphoneFrameMd, macAppFrameMd, windowsAppFrameMd } from "../src";

export const componentMetadata = {
  name: "OSFrames",
  description: "This package provides containers that appear to look like OS-specific windows.",
  state: "internal",
  metadata: {
    WindowsAppFrame: windowsAppFrameMd,
    MacAppFrame: macAppFrameMd,
    IphoneFrame: iphoneFrameMd,
  },
};

```

--------------------------------------------------------------------------------
/docs/src/themes/earthtone.ts:
--------------------------------------------------------------------------------

```typescript
import type { ThemeDefinition } from "xmlui";

export const EarthtoneTheme: ThemeDefinition = {
  name: "XMLUI Documentation Theme",
  id: "earthtone",
  extends: "docs-theme",
  themeVars: {
    "color-primary": "hsl(30, 50%, 30%)",
    "color-secondary": "hsl(120, 40%, 25%)",
    "color-surface": "hsl(39, 43%, 97%)",
  },
  resources: {},
};

export default EarthtoneTheme;

```

--------------------------------------------------------------------------------
/packages/xmlui-website-blocks/demo/themes/default.ts:
--------------------------------------------------------------------------------

```typescript
import type { ThemeDefinition } from "xmlui";

export const Default: ThemeDefinition = {
  id: "default",
  name: "Default demo theme",
  extends: "xmlui",
  resources: {
  },
  themeVars: {
    "paddingTop-H1": "$space-6",
    "paddingBottom-H1": "$space-8",
    "textColor-H1": "$color-primary-600",
  },
  tones: {
    light: {},
    dark: {},
  },
};

export default Default;

```

--------------------------------------------------------------------------------
/tools/create-app/templates/default/ts/index.html:
--------------------------------------------------------------------------------

```html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/resources/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <script>window.__PUBLIC_PATH = '/'</script>
  <base href="/">
</head>
<body>
<div id="root"></div>
<script type="module" src="/index.ts"></script>
</body>
</html>

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/interception/initMock.ts:
--------------------------------------------------------------------------------

```typescript
import { ApiInterceptor } from "./ApiInterceptor";
import type { ApiInterceptorDefinition } from "./abstractions";

// Create the worker for the ApiInterceptorProvider
export const initMock = async (apiInterceptorDefinition: ApiInterceptorDefinition) => {
  const apiInstance = new ApiInterceptor(apiInterceptorDefinition);
  await apiInstance.initialize();
  return apiInstance;
};

```

--------------------------------------------------------------------------------
/xmlui/src/components-core/action/TimedAction.tsx:
--------------------------------------------------------------------------------

```typescript
import type { ActionExecutionContext } from "../../abstractions/ActionDefs";
import { delay as doDelay } from "../utils/misc";
import { createAction } from "./actions";

async function delay(_executionContext: ActionExecutionContext, timeoutInMs: number, callback?: any) {
  await doDelay(timeoutInMs);
  await callback?.();
}

export const timedAction = createAction("delay", delay);

```

--------------------------------------------------------------------------------
/xmlui/src/abstractions/scripting/BlockScope.ts:
--------------------------------------------------------------------------------

```typescript
// Represents a block scope
export type BlockScope = {
  // --- Block-scoped variable values
  vars: Record<string, any>;

  // --- Block-scopes const values
  constVars?: Set<string>;

  // --- Optional return value of an expression
  returnValue?: any;
};

// Represents a parameter redirect to a "vars"
export type RedirectInfo = {
  valueScope: any;
  valueIndex: string | number;
}

```

--------------------------------------------------------------------------------
/xmlui/src/testing/drivers/DateInputDriver.ts:
--------------------------------------------------------------------------------

```typescript
import { InputComponentDriver } from "../ComponentDrivers";

export class DateInputDriver extends InputComponentDriver {
  get dayInput() {
    return this.getByPartName("day");
  }

  get monthInput() {
    return this.getByPartName("month");
  }

  get yearInput() {
    return this.getByPartName("year");
  }

  get clearButton() {
    return this.getByPartName("clearButton");
  }
}

```
Page 1/141FirstPrevNextLast