@flamingo-stack/openframe-frontend-core 0.0.213 → 0.0.214
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-3JWIJJ44.js → chunk-5OWDOFKK.js} +2 -2
- package/dist/{chunk-IK2X5YJU.js → chunk-HWY35EAK.js} +2 -2
- package/dist/{chunk-OTKJASSX.cjs → chunk-IZL2KEH6.cjs} +24 -24
- package/dist/{chunk-OTKJASSX.cjs.map → chunk-IZL2KEH6.cjs.map} +1 -1
- package/dist/{chunk-35XIT2CF.cjs → chunk-KDNGUYZM.cjs} +17 -17
- package/dist/{chunk-35XIT2CF.cjs.map → chunk-KDNGUYZM.cjs.map} +1 -1
- package/dist/{chunk-ZTJVRSN5.js → chunk-UKND27XC.js} +2 -2
- package/dist/chunk-UKND27XC.js.map +1 -0
- package/dist/{chunk-ZDF6F7ED.cjs → chunk-YZUUFTIK.cjs} +2 -2
- package/dist/chunk-YZUUFTIK.cjs.map +1 -0
- package/dist/components/chat/index.cjs +2 -2
- package/dist/components/chat/index.js +1 -1
- package/dist/components/contact/index.cjs +3 -3
- package/dist/components/contact/index.js +2 -2
- package/dist/components/features/index.cjs +2 -2
- package/dist/components/features/index.js +1 -1
- package/dist/components/index.cjs +49 -49
- package/dist/components/index.js +2 -2
- package/dist/components/navigation/index.cjs +2 -2
- package/dist/components/navigation/index.js +1 -1
- package/dist/components/tickets/index.cjs +61 -61
- package/dist/components/tickets/index.js +3 -3
- package/dist/components/ui/index.cjs +2 -2
- package/dist/components/ui/index.js +1 -1
- package/dist/index.cjs +2 -2
- package/dist/index.js +1 -1
- package/package.json +1 -1
- package/src/.index.md +36 -34
- package/src/components/.alert-dialog.md +27 -23
- package/src/components/.announcement-bar.md +26 -21
- package/src/components/.breadcrumb.md +19 -15
- package/src/components/.calendar.md +24 -19
- package/src/components/.categories-cart.md +29 -24
- package/src/components/.checkbox.md +23 -25
- package/src/components/.chevron-button.md +37 -32
- package/src/components/.comment-card.md +32 -62
- package/src/components/.dialog.md +26 -26
- package/src/components/.dynamic-skeleton.md +54 -57
- package/src/components/.empty-state.md +42 -51
- package/src/components/.faq-accordion.md +27 -21
- package/src/components/.filter-chip.md +41 -24
- package/src/components/.flamingo-logo.md +20 -23
- package/src/components/.footer-waitlist-button.md +29 -22
- package/src/components/.footer.md +32 -32
- package/src/components/.icons-block.md +27 -17
- package/src/components/.image-cropper.md +41 -32
- package/src/components/.index.md +33 -39
- package/src/components/.input.md +31 -35
- package/src/components/.logs-list.md +31 -20
- package/src/components/.media-carousel.md +35 -36
- package/src/components/.open-source-features.md +33 -16
- package/src/components/.pagination.md +52 -51
- package/src/components/.provider-button.md +21 -23
- package/src/components/.select.md +31 -20
- package/src/components/.sidebar.md +34 -24
- package/src/components/.smooth-accordion.md +29 -24
- package/src/components/.social-icon-row.md +36 -32
- package/src/components/.textarea.md +25 -31
- package/src/components/.tool-icon.md +24 -26
- package/src/components/.unified-filter-logic.md +37 -30
- package/src/components/.unified-pagination.md +23 -22
- package/src/components/.user-summary-stub.md +38 -22
- package/src/components/.vendor-display-button.md +25 -25
- package/src/components/.vendor-icon.md +33 -25
- package/src/components/.why-it-matters.md +28 -25
- package/src/components/chat/.approval-batch-message.md +51 -0
- package/src/components/chat/.approval-request-message.md +35 -34
- package/src/components/chat/.chat-attachment-bar.md +64 -0
- package/src/components/chat/.chat-container.md +36 -18
- package/src/components/chat/.chat-input.md +37 -20
- package/src/components/chat/.chat-message-enhanced.md +30 -49
- package/src/components/chat/.chat-message-list.md +45 -32
- package/src/components/chat/.chat-message-skeleton.md +26 -22
- package/src/components/chat/.chat-panel-context.md +52 -0
- package/src/components/chat/.chat-ref.types.md +42 -0
- package/src/components/chat/.chat-sidebar-skeleton.md +34 -25
- package/src/components/chat/.chat-sidebar.md +31 -26
- package/src/components/chat/.chat-ticket-list.md +39 -0
- package/src/components/chat/.context-compaction-display.md +36 -0
- package/src/components/chat/.cycling-phrase.md +52 -0
- package/src/components/chat/.embeddable-chat.md +48 -0
- package/src/components/chat/.expand-chevron.md +24 -0
- package/src/components/chat/.index.md +31 -35
- package/src/components/chat/.mingo-onboarding-card-skeleton.md +44 -0
- package/src/components/chat/.mingo-onboarding-card.md +62 -0
- package/src/components/chat/.model-display.md +32 -30
- package/src/components/chat/.nav-link-anchor-via-runtime.md +40 -0
- package/src/components/chat/.remark-card-links.md +38 -0
- package/src/components/chat/.slash-command-suggestions.md +47 -0
- package/src/components/chat/.source-action-button.md +48 -0
- package/src/components/chat/.thinking-display.md +42 -0
- package/src/components/chat/.tool-call-blocks.md +45 -0
- package/src/components/chat/.tool-execution-display.md +44 -36
- package/src/components/chat/chat-container.tsx +1 -1
- package/src/components/chat/entity-cards/.admin-content-card.md +43 -0
- package/src/components/chat/entity-cards/.block-card.md +47 -0
- package/src/components/chat/entity-cards/.blog-card.md +52 -0
- package/src/components/chat/entity-cards/.blog-image-placeholder.md +39 -0
- package/src/components/chat/entity-cards/.campaign-card-admin.md +47 -0
- package/src/components/chat/entity-cards/.case-study-card.md +58 -0
- package/src/components/chat/entity-cards/.chat-ticket-item.md +40 -0
- package/src/components/chat/entity-cards/.chat-video-entity-card.md +43 -0
- package/src/components/chat/entity-cards/.customer-interview-card.md +53 -0
- package/src/components/chat/entity-cards/.data-room-doc-card.md +47 -0
- package/src/components/chat/entity-cards/.dispatch.md +39 -0
- package/src/components/chat/entity-cards/.entity-author-card.md +51 -0
- package/src/components/chat/entity-cards/.generic-entity-card.md +62 -0
- package/src/components/chat/entity-cards/.github-activity-card.md +61 -0
- package/src/components/chat/entity-cards/.hubspot-ticket-card.md +53 -0
- package/src/components/chat/entity-cards/.index.md +66 -0
- package/src/components/chat/entity-cards/.investor-update-card.md +47 -0
- package/src/components/chat/entity-cards/.onboarding-guide-card.md +58 -0
- package/src/components/chat/entity-cards/.product-release-card-defaults.md +31 -0
- package/src/components/chat/entity-cards/.product-release-card.md +29 -0
- package/src/components/chat/entity-cards/.program-card-defaults.md +41 -0
- package/src/components/chat/entity-cards/.program-card.md +59 -0
- package/src/components/chat/entity-cards/.roadmap-card.md +46 -0
- package/src/components/chat/entity-cards/.roadmap-vote-button.md +52 -0
- package/src/components/chat/entity-cards/.slack-message-card.md +48 -0
- package/src/components/chat/entity-cards/.task-type-icon.md +47 -0
- package/src/components/chat/hooks/.index.md +36 -21
- package/src/components/chat/hooks/.use-chat-attachment-image-gallery.md +51 -0
- package/src/components/chat/hooks/.use-chat-attachments.md +48 -0
- package/src/components/chat/hooks/.use-chat-card-item.md +39 -0
- package/src/components/chat/hooks/.use-chat-identity.md +45 -0
- package/src/components/chat/hooks/.use-chat.md +58 -0
- package/src/components/chat/hooks/.use-chunk-catchup.md +46 -48
- package/src/components/chat/hooks/.use-close-on-navigation.md +44 -0
- package/src/components/chat/hooks/.use-collapsible.md +48 -0
- package/src/components/chat/hooks/.use-embedded-chat.md +32 -0
- package/src/components/chat/hooks/.use-jetstream-dialog-subscription.md +40 -0
- package/src/components/chat/hooks/.use-nats-chat-adapter.md +52 -0
- package/src/components/chat/hooks/.use-nats-dialog-subscription.md +49 -30
- package/src/components/chat/hooks/.use-proxied-image-url.md +40 -0
- package/src/components/chat/hooks/.use-realtime-chunk-processor.md +43 -40
- package/src/components/chat/hooks/.use-slash-commands.md +46 -0
- package/src/components/chat/hooks/.use-sse-chat-adapter.md +34 -0
- package/src/components/chat/hooks/.use-sse.md +60 -0
- package/src/components/chat/hooks/.use-unified-chat.md +57 -0
- package/src/components/chat/types/.api.types.md +52 -38
- package/src/components/chat/types/.chat.types.md +43 -34
- package/src/components/chat/types/.component.types.md +47 -48
- package/src/components/chat/types/.index.md +20 -27
- package/src/components/chat/types/.message.types.md +58 -48
- package/src/components/chat/types/.network.types.md +57 -31
- package/src/components/chat/types/.processing.types.md +49 -31
- package/src/components/chat/types/.unified-chat-state.types.md +41 -0
- package/src/components/chat/types/entities/.blog.md +43 -0
- package/src/components/chat/types/entities/.case-study.md +26 -0
- package/src/components/chat/types/entities/.content-ref.md +41 -0
- package/src/components/chat/types/entities/.customer-interview.md +28 -0
- package/src/components/chat/types/entities/.data-room-doc.md +36 -0
- package/src/components/chat/types/entities/.github-activity.md +43 -0
- package/src/components/chat/types/entities/.hubspot-ticket.md +53 -0
- package/src/components/chat/types/entities/.index.md +42 -0
- package/src/components/chat/types/entities/.investor-update.md +45 -0
- package/src/components/chat/types/entities/.onboarding-guide.md +50 -0
- package/src/components/chat/types/entities/.program-types.md +57 -0
- package/src/components/chat/types/entities/.roadmap-item.md +58 -0
- package/src/components/chat/types/entities/.slack-message.md +35 -0
- package/src/components/chat/utils/.agent-status-message.md +45 -0
- package/src/components/chat/utils/.auto-continuation-directive.md +58 -0
- package/src/components/chat/utils/.chat-attachment-markdown.md +54 -0
- package/src/components/chat/utils/.chat-authed-fetch.md +25 -0
- package/src/components/chat/utils/.chat-nav-resolution.md +46 -0
- package/src/components/chat/utils/.chat-proxy-auth-storage.md +38 -0
- package/src/components/chat/utils/.chip-action-class.md +34 -0
- package/src/components/chat/utils/.chip-styles.md +46 -0
- package/src/components/chat/utils/.chunk-parser.md +38 -28
- package/src/components/chat/utils/.clickup-task-type-utils.md +48 -0
- package/src/components/chat/utils/.compact-card-classes.md +62 -0
- package/src/components/chat/utils/.decide-new-tab.md +51 -0
- package/src/components/chat/utils/.external-app-urls.md +29 -0
- package/src/components/chat/utils/.extract-incomplete-message-state.md +25 -29
- package/src/components/chat/utils/.flatten-assistant-content.md +34 -0
- package/src/components/chat/utils/.icon-registry.md +46 -0
- package/src/components/chat/utils/.index.md +37 -32
- package/src/components/chat/utils/.is-cross-origin-url.md +35 -0
- package/src/components/chat/utils/.message-segment-accumulator.md +25 -34
- package/src/components/chat/utils/.nav-anchor-props.md +44 -0
- package/src/components/chat/utils/.nav-click-handler.md +47 -0
- package/src/components/chat/utils/.onboarding-icons.md +28 -0
- package/src/components/chat/utils/.process-historical-messages.md +46 -35
- package/src/components/chat/utils/.scroll-anchor.md +40 -0
- package/src/components/chat/utils/.slash-dispatch-utils.md +44 -0
- package/src/components/chat/utils/.source-icons.md +35 -0
- package/src/components/chat/utils/.source-row-cta.md +54 -0
- package/src/components/chat/utils/.tool-call-helpers.md +42 -0
- package/src/components/contact/.contact-form.md +43 -0
- package/src/components/contact/.index.md +27 -0
- package/src/components/features/.array-entry-manager.md +36 -45
- package/src/components/features/.changelog-manager.md +47 -21
- package/src/components/features/.changelog-sections-manager.md +21 -26
- package/src/components/features/.command-box.md +31 -28
- package/src/components/features/.entity-summary-editor.md +46 -0
- package/src/components/features/.entity-video-section.md +51 -0
- package/src/components/features/.figma-prototype-viewer.md +48 -29
- package/src/components/features/.filters-dropdown.md +33 -46
- package/src/components/features/.highlight-config-section.md +42 -0
- package/src/components/features/.highlight-generation-section.md +46 -0
- package/src/components/features/.highlight-video-combined-section.md +47 -0
- package/src/components/features/.highlight-video-preview.md +44 -0
- package/src/components/features/.highlight-video-section.md +47 -0
- package/src/components/features/.index.md +40 -66
- package/src/components/features/.media-gallery-manager.md +48 -38
- package/src/components/features/.more-about-button.md +22 -19
- package/src/components/features/.og-editor-preview.md +40 -36
- package/src/components/features/.parallax-image-showcase.md +33 -26
- package/src/components/features/.paths-display.md +42 -43
- package/src/components/features/.platform-badge.md +37 -36
- package/src/components/features/.platform-filter.md +23 -16
- package/src/components/features/.policy-configuration-panel.md +48 -56
- package/src/components/features/.provider-button.md +33 -36
- package/src/components/features/.push-button-selector.md +40 -29
- package/src/components/features/.release-media-manager.md +46 -31
- package/src/components/features/.section-selector.md +26 -31
- package/src/components/features/.select-button.md +35 -25
- package/src/components/features/.seo-editor-preview.md +41 -44
- package/src/components/features/.social-links-manager.md +25 -19
- package/src/components/features/.start-with-openframe-button.md +37 -29
- package/src/components/features/.status-filter-component.md +36 -20
- package/src/components/features/.tags-selector.md +40 -24
- package/src/components/features/.transcribe-and-summarize-combined-section.md +45 -0
- package/src/components/features/.transcribe-summarize-section.md +48 -0
- package/src/components/features/.transcript-summary-editor.md +53 -0
- package/src/components/features/.video-bites-display.md +46 -0
- package/src/components/features/.video-clips-section.md +41 -0
- package/src/components/features/.video-ratio-tabs.md +56 -0
- package/src/components/features/.video-source-selector.md +60 -0
- package/src/components/features/.video.md +44 -0
- package/src/components/features/.waitlist-form.md +60 -0
- package/src/components/features/ai-enrich/.AIEnrichButton.md +30 -27
- package/src/components/features/ai-enrich/.AIEnrichSection.md +46 -42
- package/src/components/features/board/.board-column-header.md +38 -0
- package/src/components/features/board/.board-column.md +43 -0
- package/src/components/features/board/.board.md +51 -0
- package/src/components/features/board/.color-utils.md +26 -0
- package/src/components/features/board/.index.md +56 -0
- package/src/components/features/board/.ticket-card-skeleton.md +38 -0
- package/src/components/features/board/.ticket-card.md +47 -0
- package/src/components/features/board/.types.md +45 -0
- package/src/components/features/board/.use-board-collapse.md +34 -0
- package/src/components/features/notifications/.index.md +57 -0
- package/src/components/features/notifications/.notification-drawer.md +34 -0
- package/src/components/features/notifications/.notification-tile.md +39 -0
- package/src/components/features/notifications/.notifications-context.md +73 -0
- package/src/components/features/notifications/.types.md +45 -0
- package/src/components/icons/.about-icon.md +20 -28
- package/src/components/icons/.ai-robot-icon.md +15 -17
- package/src/components/icons/.bash-icon.md +16 -23
- package/src/components/icons/.buildings-icon.md +10 -24
- package/src/components/icons/.capterra-icon.md +30 -26
- package/src/components/icons/.carta-icon.md +29 -0
- package/src/components/icons/.clickup-icon.md +26 -0
- package/src/components/icons/.cmd-icon.md +15 -22
- package/src/components/icons/.coins-icon.md +17 -25
- package/src/components/icons/.community-hub-icon.md +19 -25
- package/src/components/icons/.community-icon.md +24 -21
- package/src/components/icons/.compare-icon.md +32 -19
- package/src/components/icons/.copy-icon.md +29 -15
- package/src/components/icons/.custom-external-link-icon.md +19 -17
- package/src/components/icons/.custom-fork-icon.md +32 -21
- package/src/components/icons/.custom-license-icon.md +29 -25
- package/src/components/icons/.custom-star-icon.md +20 -28
- package/src/components/icons/.custom-time-icon.md +21 -22
- package/src/components/icons/.cut-vendor-costs-icon.md +6 -19
- package/src/components/icons/.dashboard-icon.md +13 -18
- package/src/components/icons/.deno-icon.md +16 -23
- package/src/components/icons/.donut-icon.md +12 -23
- package/src/components/icons/.double-chevron-icon.md +28 -36
- package/src/components/icons/.elestio-logo.md +13 -23
- package/src/components/icons/.empty-vendor-icon.md +16 -18
- package/src/components/icons/.explore-categories-icon.md +18 -29
- package/src/components/icons/.eye-icon.md +16 -26
- package/src/components/icons/.facebook-icon.md +9 -20
- package/src/components/icons/.figma-icon.md +8 -17
- package/src/components/icons/.filter-icon.md +15 -17
- package/src/components/icons/.flamingo-logo.md +28 -27
- package/src/components/icons/.folder-shield-icon.md +28 -19
- package/src/components/icons/.g2-icon.md +22 -21
- package/src/components/icons/.getapp-icon.md +25 -21
- package/src/components/icons/.github-icon.md +13 -25
- package/src/components/icons/.globe-icon.md +14 -19
- package/src/components/icons/.google-gemini-icon.md +16 -19
- package/src/components/icons/.google-logo.md +15 -21
- package/src/components/icons/.grid-view-icon.md +30 -19
- package/src/components/icons/.hamburger-icon.md +22 -20
- package/src/components/icons/.hand-dollar-icon.md +24 -34
- package/src/components/icons/.hotel-icon.md +27 -21
- package/src/components/icons/.icon-utils.md +28 -29
- package/src/components/icons/.image-icon.md +15 -22
- package/src/components/icons/.index.md +25 -28
- package/src/components/icons/.info-circle-icon.md +29 -30
- package/src/components/icons/.instagram-icon.md +10 -24
- package/src/components/icons/.jump-in-icon.md +18 -18
- package/src/components/icons/.linux-icon.md +18 -18
- package/src/components/icons/.log-out-icon.md +15 -23
- package/src/components/icons/.logs-icon.md +14 -23
- package/src/components/icons/.margin-crisis-icon.md +21 -20
- package/src/components/icons/.menu-icon.md +18 -19
- package/src/components/icons/.miami-cyber-gang-logo-face-only.md +18 -21
- package/src/components/icons/.miami-cyber-gang-logo.md +22 -14
- package/src/components/icons/.mlg-logo.md +18 -16
- package/src/components/icons/.moon-icon.md +32 -22
- package/src/components/icons/.ms-icon.md +30 -19
- package/src/components/icons/.nushell-icon.md +7 -21
- package/src/components/icons/.open-source-icon.md +19 -23
- package/src/components/icons/.openai-icon.md +9 -24
- package/src/components/icons/.openframe-ai-icons.md +25 -26
- package/src/components/icons/.openframe-logo.md +28 -22
- package/src/components/icons/.openframe-text.md +24 -27
- package/src/components/icons/.openmsp-logo.md +26 -23
- package/src/components/icons/.pilot-icon.md +23 -0
- package/src/components/icons/.powershell-icon.md +17 -22
- package/src/components/icons/.python-icon.md +16 -23
- package/src/components/icons/.queries-icon.md +13 -21
- package/src/components/icons/.reddit-icon.md +28 -24
- package/src/components/icons/.remote-control-icon.md +13 -17
- package/src/components/icons/.script-icon.md +27 -19
- package/src/components/icons/.search-icon.md +21 -21
- package/src/components/icons/.send-icon.md +14 -16
- package/src/components/icons/.settings-icon.md +30 -19
- package/src/components/icons/.shape-circle-dash-icon.md +16 -21
- package/src/components/icons/.shell-icon.md +15 -19
- package/src/components/icons/.shield-check-icon.md +18 -31
- package/src/components/icons/.shield-key-icon.md +25 -25
- package/src/components/icons/.shield-lock-icon.md +8 -18
- package/src/components/icons/.slack-icon.md +28 -32
- package/src/components/icons/.sparkles-icon.md +18 -23
- package/src/components/icons/.sso-configuration-icon.md +29 -16
- package/src/components/icons/.sun-icon.md +20 -18
- package/src/components/icons/.table-view-icon.md +17 -19
- package/src/components/icons/.telegram-icon.md +8 -22
- package/src/components/icons/.thumbs-down-icon.md +10 -19
- package/src/components/icons/.thumbs-up-icon.md +8 -17
- package/src/components/icons/.tool-directory-icons.md +24 -28
- package/src/components/icons/.trustpilot-icon.md +25 -22
- package/src/components/icons/.user-icon.md +26 -28
- package/src/components/icons/.users-group-icon.md +28 -24
- package/src/components/icons/.vendor-showcase-icons.md +21 -29
- package/src/components/icons/.vendors-icon.md +18 -22
- package/src/components/icons/.whatsapp-icon.md +30 -14
- package/src/components/icons/.x-icon.md +18 -23
- package/src/components/icons/.x-logo.md +13 -38
- package/src/components/icons/.youtube-icon.md +8 -19
- package/src/components/icons/device-type-icons/.get-device-type-icon.md +26 -34
- package/src/components/icons-v2-generated/.index.md +52 -0
- package/src/components/icons-v2-generated/alphabet/.index.md +33 -0
- package/src/components/icons-v2-generated/arrows/.index.md +39 -0
- package/src/components/icons-v2-generated/audio-and-visual/.index.md +40 -0
- package/src/components/icons-v2-generated/brand-logos/.elestio-logo-icon.md +40 -0
- package/src/components/icons-v2-generated/brand-logos/.gemini-logo-icon.md +37 -0
- package/src/components/icons-v2-generated/brand-logos/.google-gemini-logo-icon.md +33 -0
- package/src/components/icons-v2-generated/brand-logos/.index.md +38 -0
- package/src/components/icons-v2-generated/brand-logos/.meshcentral-logo-grey-icon.md +35 -0
- package/src/components/icons-v2-generated/brand-logos/.meshcentral-logo-icon.md +36 -0
- package/src/components/icons-v2-generated/buildings/.index.md +48 -0
- package/src/components/icons-v2-generated/charts/.index.md +40 -0
- package/src/components/icons-v2-generated/clothes/.index.md +48 -0
- package/src/components/icons-v2-generated/coding/.index.md +42 -0
- package/src/components/icons-v2-generated/communication/.index.md +39 -0
- package/src/components/icons-v2-generated/date-and-time/.index.md +29 -0
- package/src/components/icons-v2-generated/design/.index.md +39 -0
- package/src/components/icons-v2-generated/devices/.index.md +38 -0
- package/src/components/icons-v2-generated/documents/.index.md +38 -0
- package/src/components/icons-v2-generated/finance/.index.md +34 -0
- package/src/components/icons-v2-generated/food-and-drinks/.index.md +34 -0
- package/src/components/icons-v2-generated/food-and-drinks/.leafy-green-icon.md +36 -0
- package/src/components/icons-v2-generated/food-and-drinks/.strawberry-icon.md +39 -0
- package/src/components/icons-v2-generated/health/.index.md +40 -0
- package/src/components/icons-v2-generated/household/.index.md +45 -0
- package/src/components/icons-v2-generated/interface/.index.md +36 -0
- package/src/components/icons-v2-generated/map-and-travel/.index.md +41 -0
- package/src/components/icons-v2-generated/media-playback/.index.md +51 -0
- package/src/components/icons-v2-generated/number/.index.md +41 -0
- package/src/components/icons-v2-generated/school/.index.md +37 -0
- package/src/components/icons-v2-generated/security/.fingerprint-icon.md +38 -0
- package/src/components/icons-v2-generated/security/.index.md +39 -0
- package/src/components/icons-v2-generated/shopping/.index.md +42 -0
- package/src/components/icons-v2-generated/signs-and-symbols/.index.md +32 -0
- package/src/components/icons-v2-generated/sort-and-filter/.index.md +35 -0
- package/src/components/icons-v2-generated/sport/.index.md +41 -0
- package/src/components/icons-v2-generated/text-editor/.index.md +44 -0
- package/src/components/icons-v2-generated/users/.index.md +45 -0
- package/src/components/icons-v2-generated/vehicles-and-delivery/.index.md +36 -0
- package/src/components/icons-v2-generated/weather-and-nature/.flower-sakura-icon.md +36 -0
- package/src/components/icons-v2-generated/weather-and-nature/.index.md +34 -0
- package/src/components/layout/.article-detail-layout.md +43 -0
- package/src/components/layout/.back-button.md +40 -0
- package/src/components/layout/.list-page-layout.md +35 -26
- package/src/components/layout/.page-container.md +27 -38
- package/src/components/layout/.page-layout.md +50 -0
- package/src/components/layout/.title-block.md +42 -0
- package/src/components/loading/.card-skeleton.md +38 -29
- package/src/components/loading/.device-card-skeleton.md +29 -25
- package/src/components/loading/.index.md +39 -46
- package/src/components/loading/.margin-report-skeleton.md +45 -34
- package/src/components/loading/.organization-card-skeleton.md +39 -44
- package/src/components/loading/.page-layout-skeleton.md +34 -45
- package/src/components/loading/.unified-skeleton.md +62 -36
- package/src/components/navigation/.app-header.md +40 -29
- package/src/components/navigation/.app-layout.md +25 -26
- package/src/components/navigation/.header-global-search.md +34 -37
- package/src/components/navigation/.header-organization-filter.md +23 -22
- package/src/components/navigation/.header.md +31 -35
- package/src/components/navigation/.mobile-burger-menu.md +39 -47
- package/src/components/navigation/.mobile-nav-panel.md +51 -32
- package/src/components/navigation/.navigation-sidebar-header.md +36 -0
- package/src/components/navigation/.navigation-sidebar-item.md +45 -0
- package/src/components/navigation/.navigation-sidebar-toggle.md +38 -0
- package/src/components/navigation/.navigation-sidebar.md +33 -34
- package/src/components/navigation/.sliding-sidebar.md +52 -41
- package/src/components/navigation/.sticky-section-nav.md +56 -48
- package/src/components/platform/.ScriptArguments.md +39 -25
- package/src/components/platform/.ScriptInfoSection.md +30 -26
- package/src/components/platform/.ShellTypeBadge.md +18 -13
- package/src/components/platform/.SoftwareInfo.md +23 -27
- package/src/components/platform/.SoftwareSourceBadge.md +28 -19
- package/src/components/platform/.ToolBadge.md +25 -26
- package/src/components/providers/.theme-provider.md +52 -0
- package/src/components/shared/delivery/.delivery-lists.md +39 -0
- package/src/components/shared/delivery/.delivery-row.md +41 -0
- package/src/components/shared/delivery/.delivery-table.md +41 -0
- package/src/components/shared/delivery/.index.md +38 -0
- package/src/components/shared/dev-section/.dev-card-row.md +60 -0
- package/src/components/shared/dev-section/.dev-section-page.md +48 -0
- package/src/components/shared/dev-section/.dev-section-view.md +43 -0
- package/src/components/shared/dev-section/.index.md +38 -0
- package/src/components/shared/legal-document/.index.md +40 -0
- package/src/components/shared/legal-document/.legal-document-page.md +50 -0
- package/src/components/shared/legal-document/.use-legal-docs.md +42 -0
- package/src/components/shared/onboarding/.onboarding-step-card.md +32 -31
- package/src/components/shared/onboarding/.onboarding-walkthrough.md +39 -43
- package/src/components/shared/product-release/.index.md +28 -30
- package/src/components/shared/product-release/.product-release-card-skeleton.md +28 -28
- package/src/components/shared/product-release/.product-release-card.md +45 -27
- package/src/components/shared/product-release/.release-detail-page.md +23 -24
- package/src/components/shared/roadmap/.index.md +37 -0
- package/src/components/shared/roadmap/.roadmap-grid-skeleton.md +39 -0
- package/src/components/shared/roadmap/.roadmap-grid.md +66 -0
- package/src/components/shared/roadmap/.use-roadmap-voting.md +68 -0
- package/src/components/tickets/.help-center-card.md +51 -0
- package/src/components/tickets/.help-center-create-form.md +38 -0
- package/src/components/tickets/.help-center-list.md +40 -0
- package/src/components/tickets/.index.md +65 -0
- package/src/components/tickets/.ticket-center.md +51 -0
- package/src/components/tickets/.ticket-detail-drawer.md +48 -0
- package/src/components/tickets/.ticket-linked-delivery-card.md +36 -0
- package/src/components/tickets/.ticket-open-form.md +50 -0
- package/src/components/tickets/.ticket-row.md +30 -0
- package/src/components/tickets/.types.md +57 -0
- package/src/components/tickets/hooks/.use-ticket-actions.md +77 -0
- package/src/components/tickets/hooks/.use-ticket-engagements.md +42 -0
- package/src/components/tickets/hooks/.use-tickets-list.md +54 -0
- package/src/components/ui/.actions-menu.md +66 -41
- package/src/components/ui/.alert-dialog.md +29 -26
- package/src/components/ui/.allowed-domains-input.md +29 -21
- package/src/components/ui/.assignee-dropdown.md +45 -0
- package/src/components/ui/.autocomplete.md +47 -41
- package/src/components/ui/.benefit-card.md +51 -36
- package/src/components/ui/.brand-association-card.md +30 -27
- package/src/components/ui/.breadcrumb.md +17 -15
- package/src/components/ui/.checkbox-block.md +39 -35
- package/src/components/ui/.checkbox-with-description.md +23 -16
- package/src/components/ui/.checkbox.md +31 -23
- package/src/components/ui/.circular-progress.md +49 -19
- package/src/components/ui/.content-loader.md +32 -20
- package/src/components/ui/.cursor-pagination.md +41 -52
- package/src/components/ui/.dashboard-info-card.md +33 -26
- package/src/components/ui/.date-picker.md +27 -25
- package/src/components/ui/.device-card-compact.md +28 -29
- package/src/components/ui/.device-card.md +27 -27
- package/src/components/ui/.dialog.md +25 -16
- package/src/components/ui/.drawer.md +86 -0
- package/src/components/ui/.dropdown-button.md +45 -0
- package/src/components/ui/.entity-image.md +46 -0
- package/src/components/ui/.error-state.md +41 -28
- package/src/components/ui/.feature-card.md +35 -31
- package/src/components/ui/.feature-list.md +48 -0
- package/src/components/ui/.field-wrapper.md +47 -0
- package/src/components/ui/.file-upload.md +42 -0
- package/src/components/ui/.filter-checkbox-item.md +43 -0
- package/src/components/ui/.filter-list.md +57 -0
- package/src/components/ui/.filter-modal.md +59 -0
- package/src/components/ui/.floating-tooltip.md +43 -26
- package/src/components/ui/.hidden-tags-popup.md +49 -0
- package/src/components/ui/.hover-dropdown.md +54 -0
- package/src/components/ui/.image-gallery-modal.md +41 -34
- package/src/components/ui/.image-uploader.md +53 -0
- package/src/components/ui/.index.md +40 -34
- package/src/components/ui/.info-card.md +31 -31
- package/src/components/ui/.info-row.md +31 -27
- package/src/components/ui/.input-trigger.md +44 -0
- package/src/components/ui/.input.md +37 -31
- package/src/components/ui/.markdown-editor.md +57 -0
- package/src/components/ui/.modal-v2.md +51 -0
- package/src/components/ui/.modal.md +32 -31
- package/src/components/ui/.more-actions-menu.md +45 -38
- package/src/components/ui/.organization-card.md +31 -37
- package/src/components/ui/.page-actions.md +44 -54
- package/src/components/ui/.phone-input.md +54 -0
- package/src/components/ui/.progress-bar.md +35 -27
- package/src/components/ui/.radio-group.md +39 -27
- package/src/components/ui/.release-changelog-section.md +34 -34
- package/src/components/ui/.search-input.md +48 -0
- package/src/components/ui/.select.md +54 -34
- package/src/components/ui/.service-card.md +42 -40
- package/src/components/ui/.sheet.md +27 -18
- package/src/components/ui/.simple-markdown-renderer.md +29 -31
- package/src/components/ui/.sort-column-item.md +42 -0
- package/src/components/ui/.square-avatar.md +34 -24
- package/src/components/ui/.status-badge.md +26 -38
- package/src/components/ui/.switch.md +22 -35
- package/src/components/ui/.tab-navigation.md +56 -53
- package/src/components/ui/.tab-selector.md +40 -0
- package/src/components/ui/.tag-key-value-filter.md +56 -0
- package/src/components/ui/.tag-search-input.md +53 -0
- package/src/components/ui/.tag.md +49 -31
- package/src/components/ui/.tags-manager.md +60 -0
- package/src/components/ui/.textarea.md +44 -34
- package/src/components/ui/.ticket-attachments-list.md +45 -0
- package/src/components/ui/.ticket-detail-section.md +29 -0
- package/src/components/ui/.ticket-info-section.md +56 -0
- package/src/components/ui/.ticket-note-card.md +53 -0
- package/src/components/ui/.ticket-notes-section.md +54 -0
- package/src/components/ui/.ticket-status-tag.md +49 -0
- package/src/components/ui/.title-content-block.md +25 -26
- package/src/components/ui/.toaster.md +40 -28
- package/src/components/ui/.tooltip.md +22 -11
- package/src/components/ui/.truncate-text.md +39 -0
- package/src/components/ui/button/.button-styles.md +35 -0
- package/src/components/ui/button/.button.md +53 -0
- package/src/components/ui/button/.split-button.md +48 -0
- package/src/components/ui/data-table/.data-table-body.md +48 -0
- package/src/components/ui/data-table/.data-table-column-filter.md +45 -0
- package/src/components/ui/data-table/.data-table-cursor-footer.md +45 -0
- package/src/components/ui/data-table/.data-table-empty.md +43 -0
- package/src/components/ui/data-table/.data-table-header.md +55 -0
- package/src/components/ui/data-table/.data-table-infinite-footer.md +44 -0
- package/src/components/ui/data-table/.data-table-row-count.md +43 -0
- package/src/components/ui/data-table/.data-table-row.md +47 -0
- package/src/components/ui/data-table/.data-table-skeleton.md +42 -0
- package/src/components/ui/data-table/.data-table.md +47 -0
- package/src/components/ui/data-table/.index.md +55 -0
- package/src/components/ui/data-table/.types.md +54 -0
- package/src/components/ui/data-table/.use-data-table.md +45 -0
- package/src/components/ui/data-table/.utils.md +38 -0
- package/src/components/ui/file-manager/.file-manager-action-bar.md +39 -30
- package/src/components/ui/file-manager/.file-manager-breadcrumb.md +29 -27
- package/src/components/ui/file-manager/.file-manager-context-menu.md +38 -42
- package/src/components/ui/file-manager/.file-manager-empty.md +26 -39
- package/src/components/ui/file-manager/.file-manager-table-row.md +33 -41
- package/src/components/ui/file-manager/.file-manager.md +35 -31
- package/src/components/ui/query-report-table/.index.md +43 -0
- package/src/components/ui/query-report-table/.query-report-table-header.md +36 -0
- package/src/components/ui/query-report-table/.query-report-table-row.md +40 -0
- package/src/components/ui/query-report-table/.query-report-table-skeleton.md +44 -0
- package/src/components/ui/query-report-table/.query-report-table.md +47 -0
- package/src/components/ui/query-report-table/.types.md +41 -0
- package/src/components/ui/query-report-table/.utils.md +35 -0
- package/src/components/ui/table/.index.md +27 -48
- package/src/components/ui/table/.table-cell.md +18 -27
- package/src/components/ui/table/.table-column-filter-dropdown.md +40 -0
- package/src/components/ui/table/.table-description-cell.md +24 -14
- package/src/components/ui/table/.table-empty-state.md +21 -22
- package/src/components/ui/table/.table-header.md +25 -40
- package/src/components/ui/table/.table-row.md +22 -40
- package/src/components/ui/table/.table-skeleton.md +33 -26
- package/src/components/ui/table/.table-timestamp-cell.md +26 -16
- package/src/components/ui/table/.table.md +39 -59
- package/src/components/ui/table/.types.md +44 -36
- package/src/components/ui/table/.utils.md +18 -20
- package/src/contexts/.chat-runtime-context.md +54 -0
- package/src/contexts/.endpoints-runtime-context.md +58 -0
- package/src/contexts/.index.md +53 -0
- package/src/contexts/.use-outer-or-default.md +36 -0
- package/src/embed-shims/.index.md +45 -0
- package/src/embed-shims/.next-dynamic.md +43 -0
- package/src/embed-shims/.next-image.md +45 -0
- package/src/embed-shims/.next-link.md +59 -0
- package/src/embed-shims/.next-navigation.md +59 -0
- package/src/hooks/.index.md +34 -29
- package/src/hooks/.use-access-code-integration.md +49 -0
- package/src/hooks/.use-contact-submission.md +37 -26
- package/src/hooks/.use-copy-to-clipboard.md +42 -0
- package/src/hooks/.use-near-viewport.md +44 -0
- package/src/hooks/.use-og-placeholder.md +51 -0
- package/src/hooks/.use-toast.md +36 -35
- package/src/hooks/state/.use-api-params.md +29 -46
- package/src/hooks/state/.use-query-params.md +37 -33
- package/src/hooks/ui/.index.md +33 -32
- package/src/hooks/ui/.use-auto-limit-tags.md +54 -0
- package/src/hooks/ui/.use-horizontal-scrollbar.md +74 -0
- package/src/hooks/ui/.use-image-edge-color.md +42 -0
- package/src/hooks/ui/.use-media-query.md +33 -25
- package/src/hooks/ui/.use-search.md +51 -0
- package/src/nats/.nats.md +49 -28
- package/src/schemas/.contact-schema.md +45 -0
- package/src/stories/.AnnouncementBar.stories.md +45 -0
- package/src/stories/.AppLayout.stories.md +20 -21
- package/src/stories/.Autocomplete.stories.md +48 -34
- package/src/stories/.Board.stories.md +35 -0
- package/src/stories/.Button.stories.md +36 -33
- package/src/stories/.ChatTicketList.stories.md +33 -0
- package/src/stories/.CheckboxBlock.stories.md +40 -28
- package/src/stories/.ContentLoader.stories.md +47 -0
- package/src/stories/.DashboardInfoCard.stories.md +57 -0
- package/src/stories/.DataTable.stories.md +41 -0
- package/src/stories/.DatePicker.stories.md +66 -52
- package/src/stories/.DeviceCard.stories.md +41 -40
- package/src/stories/.DeviceCardCompact.stories.md +41 -0
- package/src/stories/.DotsLoaderIcon.stories.md +36 -0
- package/src/stories/.Drawer.stories.md +58 -0
- package/src/stories/.EmbeddableChat.stories.md +41 -0
- package/src/stories/.FileManager.stories.md +41 -0
- package/src/stories/.FileManagerActionBar.stories.md +38 -0
- package/src/stories/.FileUpload.stories.md +53 -0
- package/src/stories/.FilterList.stories.md +54 -0
- package/src/stories/.FilterModal.stories.md +72 -0
- package/src/stories/.FiltersDropdown.stories.md +57 -0
- package/src/stories/.Header.stories.md +48 -0
- package/src/stories/.ImageUploader.stories.md +49 -0
- package/src/stories/.InfoCard.stories.md +54 -0
- package/src/stories/.Input.stories.md +48 -30
- package/src/stories/.ListPageLayout.stories.md +56 -43
- package/src/stories/.MingoOnboardingCard.stories.md +42 -0
- package/src/stories/.MingoOnboardingCardSkeleton.stories.md +35 -0
- package/src/stories/.Modal.stories.md +40 -31
- package/src/stories/.NotificationDrawer.stories.md +55 -0
- package/src/stories/.OnboardingStepCard.stories.md +41 -0
- package/src/stories/.OrganizationCard.stories.md +61 -0
- package/src/stories/.PageActions.stories.md +52 -49
- package/src/stories/.PageContainer.stories.md +41 -35
- package/src/stories/.PageLayout.stories.md +60 -0
- package/src/stories/.ParallaxImageShowcase.stories.md +49 -0
- package/src/stories/.PhoneInput.stories.md +53 -0
- package/src/stories/.QueryReportTable.stories.md +44 -0
- package/src/stories/.RadioGroup.stories.md +46 -0
- package/src/stories/.RadioGroupBlock.stories.md +45 -0
- package/src/stories/.Select.stories.md +29 -15
- package/src/stories/.SlashCommandSuggestions.stories.md +41 -0
- package/src/stories/.SplitButton.stories.md +62 -0
- package/src/stories/.TabNavigation.stories.md +47 -38
- package/src/stories/.TabSelector.stories.md +65 -0
- package/src/stories/.Table.stories.md +38 -46
- package/src/stories/.TableColumnFilterDropdown.stories.md +46 -0
- package/src/stories/.Tag.stories.md +43 -32
- package/src/stories/.TagKeyValueFilter.stories.md +44 -0
- package/src/stories/.TagSearchInput.stories.md +61 -0
- package/src/stories/.Textarea.stories.md +49 -26
- package/src/stories/.Theme.stories.md +41 -0
- package/src/stories/.TicketAttachmentsList.stories.md +39 -0
- package/src/stories/.TicketDescriptionViewer.stories.md +39 -0
- package/src/stories/.TicketInfoSection.stories.md +40 -0
- package/src/stories/.TicketKnowledgeBaseList.stories.md +36 -0
- package/src/stories/.TicketNotesSection.stories.md +50 -0
- package/src/stories/.Toaster.stories.md +40 -0
- package/src/stories/.ToolExecutionDisplay.stories.md +41 -0
- package/src/stories/.Tooltip.stories.md +41 -0
- package/src/stories/.UserSummary.stories.md +41 -0
- package/src/stories/.WaitlistForm.stories.md +42 -0
- package/src/stories/BlogCard.stories.tsx +61 -0
- package/src/stories/CampaignCardAdmin.stories.tsx +52 -0
- package/src/stories/CaseStudyCard.stories.tsx +42 -0
- package/src/stories/ChatContainer.stories.tsx +186 -0
- package/src/stories/ChatInlineVideoPill.stories.tsx +63 -0
- package/src/stories/CustomerInterviewCard.stories.tsx +42 -0
- package/src/stories/DataRoomDocCard.stories.tsx +52 -0
- package/src/stories/GenericEntityCard.stories.tsx +66 -0
- package/src/stories/GitHubActivityCard.stories.tsx +61 -0
- package/src/stories/HubspotTicketCard.stories.tsx +98 -0
- package/src/stories/InvestorUpdateCard.stories.tsx +42 -0
- package/src/stories/OnboardingGuideCard.stories.tsx +52 -0
- package/src/stories/ProductReleaseCard.stories.tsx +61 -0
- package/src/stories/ProgramCard.stories.tsx +79 -0
- package/src/stories/RoadmapCard.stories.tsx +75 -0
- package/src/stories/SlackMessageCard.stories.tsx +41 -0
- package/src/stories/__fixtures__/chat-cards.ts +604 -0
- package/src/types/.blog.md +53 -29
- package/src/types/.case-study.md +44 -27
- package/src/types/.customer-interview.md +66 -44
- package/src/types/.delivery.md +40 -0
- package/src/types/.employee.md +24 -30
- package/src/types/.index.md +33 -47
- package/src/types/.marketing.md +49 -44
- package/src/types/.navigation.md +33 -25
- package/src/types/.os.types.md +32 -27
- package/src/types/.platform.md +31 -28
- package/src/types/.product-release.md +65 -38
- package/src/types/.supabase.md +37 -29
- package/src/types/.team.md +41 -33
- package/src/types/.video-processing.md +54 -0
- package/src/types/.waitlist.md +40 -36
- package/src/utils/.access-code-client.md +37 -36
- package/src/utils/.cn.md +31 -23
- package/src/utils/.color-analysis.md +35 -0
- package/src/utils/.country-phone-utils.md +39 -0
- package/src/utils/.date-formatters.md +19 -18
- package/src/utils/.embed-authed-fetch.md +39 -0
- package/src/utils/.embed-proxy-auth-storage.md +38 -0
- package/src/utils/.fetch-priority.md +41 -0
- package/src/utils/.format.md +74 -25
- package/src/utils/.generic-domain-utils.md +42 -0
- package/src/utils/.image-proxy.md +59 -23
- package/src/utils/.index.md +42 -49
- package/src/utils/.local-storage-adapter.md +50 -0
- package/src/utils/.ods-color-utils.md +55 -38
- package/src/utils/.platform-config.md +45 -25
- package/src/utils/.scroll-into-view.md +40 -0
- package/src/utils/.source-icons.md +53 -0
- package/src/utils/.sse-decision-frame.md +46 -0
- package/src/utils/dev-sections/.index.md +34 -0
- package/src/utils/dev-sections/.openframe-dev-sections.md +49 -0
- package/dist/chunk-ZDF6F7ED.cjs.map +0 -1
- package/dist/chunk-ZTJVRSN5.js.map +0 -1
- package/src/components/.card.md +0 -42
- package/src/components/.contact-button.md +0 -30
- package/src/components/.drawer.md +0 -46
- package/src/components/.fixed-layout-container.md +0 -47
- package/src/components/.footer-waitlist-card.md +0 -29
- package/src/components/.join-waitlist-cta.md +0 -29
- package/src/components/.sheet.md +0 -47
- package/src/components/.sliding-panel.md +0 -48
- package/src/components/.tooltip.md +0 -48
- package/src/components/.use-mobile.md +0 -42
- package/src/components/.vendor-compact-card.md +0 -66
- package/src/components/.x-button.md +0 -42
- package/src/components/features/.github-repo-button.md +0 -40
- package/src/components/features/.organization-icon.md +0 -47
- package/src/components/features/.organization-selector.md +0 -45
- package/src/components/icons/.fleet-icon.md +0 -39
- package/src/components/icons/.meshcentral-icon.md +0 -35
- package/src/components/icons/.refresh-icon.md +0 -34
- package/src/components/icons/.tactical-icon.md +0 -35
- package/src/components/ui/.button.md +0 -69
- package/src/components/ui/.log-table-row.md +0 -47
- package/src/components/ui/.selectable-device-card.md +0 -46
- package/src/hooks/.api-hooks-stub.md +0 -45
- package/src/hooks/api/.use-product-releases.md +0 -53
- package/src/stories/.OrganizationSelector.stories.md +0 -42
- package/src/stories/.SelectableDeviceCard.stories.md +0 -30
- package/src/utils/.lite-youtube-embed-stub.md +0 -37
- package/src/utils/.lite-youtube-embed.md +0 -33
- /package/dist/{chunk-3JWIJJ44.js.map → chunk-5OWDOFKK.js.map} +0 -0
- /package/dist/{chunk-IK2X5YJU.js.map → chunk-HWY35EAK.js.map} +0 -0
|
@@ -1,58 +1,43 @@
|
|
|
1
|
-
<!-- source-hash:
|
|
2
|
-
|
|
1
|
+
<!-- source-hash: 3fe84f90a3dc18cad93f45db6906a477 -->
|
|
2
|
+
Renders the header row for a legacy table component, handling column labels, sorting indicators, filtering dropdowns, selection checkboxes, and responsive visibility.
|
|
3
3
|
|
|
4
4
|
## Key Components
|
|
5
5
|
|
|
6
|
-
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
- Responsive visibility controls for mobile/desktop
|
|
11
|
-
- Customizable column alignment and widths
|
|
6
|
+
- **`TableHeader<T>`** *(deprecated)* — Main exported component. Use `DataTableHeader` from `data-table` instead.
|
|
7
|
+
- **`getAlignment`** — Maps column `align` prop to Tailwind flex-justification classes.
|
|
8
|
+
- **`handleSort`** — Toggles sort direction and calls `onSort` for sortable columns.
|
|
9
|
+
- **`getSortIcon`** — Returns the appropriate sort icon (`Arrow01UpIcon`, `Arrow01DownIcon`, or `SwitchVrIcon`) based on active sort state.
|
|
12
10
|
|
|
13
11
|
## Usage Example
|
|
14
12
|
|
|
15
13
|
```typescript
|
|
16
14
|
import { TableHeader } from './table-header'
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
email: string
|
|
23
|
-
status: 'active' | 'inactive'
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
const columns: TableColumn<User>[] = [
|
|
27
|
-
{
|
|
28
|
-
key: 'name',
|
|
29
|
-
label: 'Name',
|
|
30
|
-
sortable: true,
|
|
31
|
-
align: 'left'
|
|
32
|
-
},
|
|
33
|
-
{
|
|
34
|
-
key: 'status',
|
|
35
|
-
label: 'Status',
|
|
36
|
-
filterable: true,
|
|
37
|
-
filterOptions: [
|
|
38
|
-
{ label: 'Active', value: 'active' },
|
|
39
|
-
{ label: 'Inactive', value: 'inactive' }
|
|
40
|
-
]
|
|
41
|
-
}
|
|
15
|
+
|
|
16
|
+
const columns = [
|
|
17
|
+
{ key: 'name', label: 'Name', sortable: true },
|
|
18
|
+
{ key: 'status', label: 'Status', filterable: true, filterOptions: ['Active', 'Inactive'] },
|
|
19
|
+
{ key: '__actions__', label: '' },
|
|
42
20
|
]
|
|
43
21
|
|
|
44
22
|
<TableHeader
|
|
45
23
|
columns={columns}
|
|
46
24
|
sortBy="name"
|
|
47
25
|
sortDirection="asc"
|
|
48
|
-
onSort={(key, direction) =>
|
|
49
|
-
filters={{
|
|
50
|
-
onFilterChange={
|
|
51
|
-
selectable
|
|
26
|
+
onSort={(key, direction) => console.log(key, direction)}
|
|
27
|
+
filters={{}}
|
|
28
|
+
onFilterChange={(key, value) => console.log(key, value)}
|
|
29
|
+
selectable
|
|
52
30
|
allSelected={false}
|
|
53
|
-
|
|
54
|
-
|
|
31
|
+
someSelected={true}
|
|
32
|
+
onSelectAll={(checked) => console.log(checked)}
|
|
33
|
+
totalItemsCount={42}
|
|
34
|
+
stickyHeader
|
|
35
|
+
stickyHeaderOffset="top-16"
|
|
55
36
|
/>
|
|
56
37
|
```
|
|
57
38
|
|
|
58
|
-
|
|
39
|
+
## Notes
|
|
40
|
+
|
|
41
|
+
- Hidden on mobile (`hidden md:flex`); on non-`lg` screens, only filterable and `__actions__` columns are rendered.
|
|
42
|
+
- The `__actions__` column slot displays a `"Showing N results"` count instead of a header label.
|
|
43
|
+
- Sticky header behavior is controlled via `stickyHeader` and `stickyHeaderOffset` props.
|
|
@@ -1,52 +1,34 @@
|
|
|
1
|
-
<!-- source-hash:
|
|
2
|
-
A
|
|
1
|
+
<!-- source-hash: fc61b63b86b6a05d8f7ae1ddcc0dba93 -->
|
|
2
|
+
A deprecated table row component that renders a single row in a tabular layout, supporting click handlers, link navigation, row selection, and dynamic cell rendering with nested property access.
|
|
3
3
|
|
|
4
4
|
## Key Components
|
|
5
5
|
|
|
6
|
-
-
|
|
7
|
-
-
|
|
8
|
-
-
|
|
9
|
-
- **
|
|
6
|
+
- **`TableRow<T>`** — Generic row component accepting typed `item` data, column definitions, and interaction callbacks. Marked `@deprecated` — use `DataTableRow` from `data-table` instead.
|
|
7
|
+
- **`handleRowClick`** — Click handler that respects `[data-no-row-click]` elements (e.g., checkboxes), preventing event propagation to row-level handlers.
|
|
8
|
+
- **`getCellValue`** — Resolves cell content via `column.renderCell` or dot-notation key traversal (e.g., `"user.address.city"`), with fallbacks for `null`, `boolean`, and `object` values.
|
|
9
|
+
- **Link mode** — When `href` is provided without `onClick`, renders an absolutely-positioned `<Link>` overlay for full-row navigation while keeping inner elements pointer-event-safe.
|
|
10
10
|
|
|
11
11
|
## Usage Example
|
|
12
12
|
|
|
13
13
|
```typescript
|
|
14
|
-
import { TableRow } from './table-row'
|
|
15
|
-
|
|
16
|
-
// Define your data structure
|
|
17
|
-
interface User {
|
|
18
|
-
id: string
|
|
19
|
-
name: string
|
|
20
|
-
email: string
|
|
21
|
-
profile: {
|
|
22
|
-
role: string
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
// Configure columns
|
|
27
|
-
const columns = [
|
|
28
|
-
{ key: 'name', label: 'Name' },
|
|
29
|
-
{ key: 'email', label: 'Email' },
|
|
30
|
-
{ key: 'profile.role', label: 'Role' }, // Nested property access
|
|
31
|
-
{
|
|
32
|
-
key: 'actions',
|
|
33
|
-
label: 'Actions',
|
|
34
|
-
renderCell: (user: User) => (
|
|
35
|
-
<button data-no-row-click>Edit</button>
|
|
36
|
-
)
|
|
37
|
-
}
|
|
38
|
-
]
|
|
39
|
-
|
|
40
|
-
// Render table row
|
|
41
14
|
<TableRow
|
|
42
|
-
item={
|
|
43
|
-
columns={columns}
|
|
44
|
-
selectable={true}
|
|
45
|
-
selected={isSelected}
|
|
46
|
-
onSelect={handleUserSelect}
|
|
47
|
-
onClick={handleRowClick}
|
|
15
|
+
item={user}
|
|
48
16
|
index={0}
|
|
17
|
+
columns={[
|
|
18
|
+
{ key: 'name', label: 'Name' },
|
|
19
|
+
{ key: 'address.city', label: 'City' },
|
|
20
|
+
{
|
|
21
|
+
key: 'status',
|
|
22
|
+
label: 'Status',
|
|
23
|
+
renderCell: (item) => <StatusBadge status={item.status} />
|
|
24
|
+
}
|
|
25
|
+
]}
|
|
26
|
+
href={`/users/${user.id}`}
|
|
27
|
+
selectable
|
|
28
|
+
selected={selectedIds.has(user.id)}
|
|
29
|
+
onSelect={(item) => toggleSelection(item.id)}
|
|
30
|
+
compact={false}
|
|
49
31
|
/>
|
|
50
32
|
```
|
|
51
33
|
|
|
52
|
-
|
|
34
|
+
> **Deprecation notice:** This component is superseded by `DataTableRow` from the `data-table` package, which provides improved composability and feature support.
|
|
@@ -1,38 +1,45 @@
|
|
|
1
|
-
<!-- source-hash:
|
|
2
|
-
|
|
1
|
+
<!-- source-hash: 1ccd2771fe5f338fc464bca5ddb0e198 -->
|
|
2
|
+
Renders animated loading skeleton rows for table/card layouts with responsive desktop and mobile variants.
|
|
3
3
|
|
|
4
4
|
## Key Components
|
|
5
5
|
|
|
6
|
-
-
|
|
7
|
-
-
|
|
8
|
-
-
|
|
6
|
+
- **`TableCardSkeleton`** *(deprecated)* — Main exported component. Renders `n` pulsing skeleton rows with configurable columns, optional action buttons, and optional chevron indicators. Use `DataTableSkeleton` from `data-table` instead.
|
|
7
|
+
- **`ROW_HEIGHT_DESKTOP`** *(deprecated)* — Tailwind height class `h-[68px] md:h-[80px]` for desktop rows.
|
|
8
|
+
- **`ROW_HEIGHT_MOBILE`** *(deprecated)* — Tailwind height class `h-[68px]` for mobile rows.
|
|
9
9
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
10
|
+
## Props (`TableCardSkeletonProps`)
|
|
11
|
+
|
|
12
|
+
| Prop | Type | Default | Description |
|
|
13
|
+
|------|------|---------|-------------|
|
|
14
|
+
| `columns` | `Column[]` | required | Column definitions with `key` and optional `width` |
|
|
15
|
+
| `rows` | `number` | `10` | Number of skeleton rows to render |
|
|
16
|
+
| `hasActions` | `boolean` | `false` | Show action button placeholders |
|
|
17
|
+
| `hasChevron` | `boolean` | `false` | Show chevron placeholder |
|
|
18
|
+
| `className` | `string` | — | Extra classes on each row wrapper |
|
|
19
|
+
| `rowClassName` | `string` | — | Extra classes on the inner row layout |
|
|
13
20
|
|
|
14
21
|
## Usage Example
|
|
15
22
|
|
|
16
23
|
```typescript
|
|
17
24
|
import { TableCardSkeleton } from './table-skeleton'
|
|
18
25
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
26
|
+
const columns = [
|
|
27
|
+
{ key: 'name', width: 'w-1/3' },
|
|
28
|
+
{ key: 'status' },
|
|
29
|
+
{ key: 'date' },
|
|
30
|
+
]
|
|
31
|
+
|
|
32
|
+
// While data is loading:
|
|
33
|
+
if (isLoading) {
|
|
34
|
+
return (
|
|
35
|
+
<TableCardSkeleton
|
|
36
|
+
columns={columns}
|
|
37
|
+
rows={5}
|
|
38
|
+
hasActions
|
|
39
|
+
hasChevron
|
|
40
|
+
/>
|
|
41
|
+
)
|
|
42
|
+
}
|
|
36
43
|
```
|
|
37
44
|
|
|
38
|
-
|
|
45
|
+
> **Deprecation notice:** `TableCardSkeleton` is deprecated. Migrate to `DataTableSkeleton` from the `data-table` package for new implementations.
|
|
@@ -1,37 +1,47 @@
|
|
|
1
|
-
<!-- source-hash:
|
|
2
|
-
|
|
1
|
+
<!-- source-hash: 7500f4530337c7688e67a30e99d9fabd -->
|
|
2
|
+
Renders a two-line table cell displaying a formatted timestamp with an optional labeled ID beneath it.
|
|
3
3
|
|
|
4
4
|
## Key Components
|
|
5
5
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
### `TableTimestampCell` *(deprecated — use `data-table` instead)*
|
|
7
|
+
A React client component that stacks a primary timestamp line and a secondary ID line within a flex column layout.
|
|
8
|
+
|
|
9
|
+
### `TableTimestampCellProps` *(deprecated)*
|
|
10
|
+
| Prop | Type | Default | Description |
|
|
11
|
+
|------|------|---------|-------------|
|
|
12
|
+
| `timestamp` | `string \| Date` | — | Timestamp to display; auto-formatted if ISO string or Date |
|
|
13
|
+
| `id` | `string` | — | ID value shown below the timestamp |
|
|
14
|
+
| `idLabel` | `string` | `undefined` | Optional label prefix (e.g. `"Log ID"`) |
|
|
15
|
+
| `className` | `string` | `undefined` | Additional CSS classes for the container |
|
|
16
|
+
| `formatTimestamp` | `boolean` | `true` | Disable to render the timestamp as-is |
|
|
17
|
+
|
|
18
|
+
### `formatTimestampValue` *(internal)*
|
|
19
|
+
Converts a `Date` or ISO string to a locale-formatted string. Already-formatted strings (containing `,` or `/` + `:`) are returned unchanged. Falls back to `String(timestamp)` if parsing fails.
|
|
9
20
|
|
|
10
21
|
## Usage Example
|
|
11
22
|
|
|
12
23
|
```typescript
|
|
13
24
|
import { TableTimestampCell } from './table-timestamp-cell'
|
|
14
25
|
|
|
15
|
-
//
|
|
26
|
+
// With an ISO string and a labeled ID
|
|
16
27
|
<TableTimestampCell
|
|
17
|
-
timestamp="2024-
|
|
18
|
-
id="
|
|
28
|
+
timestamp="2024-06-15T14:30:00Z"
|
|
29
|
+
id="abc-123"
|
|
30
|
+
idLabel="Log ID"
|
|
19
31
|
/>
|
|
20
32
|
|
|
21
|
-
// With
|
|
33
|
+
// With a Date object, no label
|
|
22
34
|
<TableTimestampCell
|
|
23
35
|
timestamp={new Date()}
|
|
24
|
-
id="
|
|
25
|
-
idLabel="Log ID"
|
|
36
|
+
id="xyz-789"
|
|
26
37
|
/>
|
|
27
38
|
|
|
28
|
-
//
|
|
39
|
+
// Skip auto-formatting (display raw value)
|
|
29
40
|
<TableTimestampCell
|
|
30
|
-
timestamp="
|
|
31
|
-
id="
|
|
41
|
+
timestamp="Jun 15, 2024 2:30 PM"
|
|
42
|
+
id="xyz-789"
|
|
32
43
|
formatTimestamp={false}
|
|
33
|
-
className="min-w-[200px]"
|
|
34
44
|
/>
|
|
35
45
|
```
|
|
36
46
|
|
|
37
|
-
|
|
47
|
+
> **Deprecated:** This component is marked for removal. Migrate to the `data-table` component for new implementations.
|
|
@@ -1,67 +1,47 @@
|
|
|
1
|
-
<!-- source-hash:
|
|
2
|
-
A
|
|
1
|
+
<!-- source-hash: ec4b9765ec4a72e85067393812e2e172 -->
|
|
2
|
+
A deprecated generic `Table` component that renders a card-style data table with sorting, filtering, selection, pagination, and infinite scroll support.
|
|
3
3
|
|
|
4
4
|
## Key Components
|
|
5
5
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
-
|
|
9
|
-
-
|
|
10
|
-
|
|
6
|
+
### `injectSyntheticColumns<T>`
|
|
7
|
+
Internal helper that appends synthetic columns to the column definitions:
|
|
8
|
+
- **`__actions__`** — renders row-level action buttons or a custom `renderRowActions` slot
|
|
9
|
+
- **`__chevron__`** — renders a navigation chevron button when `rowHref` is provided
|
|
10
|
+
|
|
11
|
+
### `Table<T>`
|
|
12
|
+
The main exported component. **Marked `@deprecated`** — use `DataTable` from `data-table` instead.
|
|
13
|
+
|
|
14
|
+
Key features:
|
|
15
|
+
- **Loading state** — shows `TableCardSkeleton` while fetching with no data
|
|
16
|
+
- **Empty state** — renders `TableEmptyState` with a configurable message
|
|
17
|
+
- **Row selection** — checkbox-based with `selectable`, `selectedRows`, and `onSelectionChange`
|
|
18
|
+
- **Bulk actions toolbar** — appears when rows are selected and `showToolbar` + `bulkActions` are set
|
|
19
|
+
- **Sorting & filtering** — delegated to `TableHeader` via `sortBy`, `sortDirection`, `onSort`, `filters`
|
|
20
|
+
- **Pagination** — supports cursor-based (`CursorPagination`) or page-based (`Pagination`)
|
|
21
|
+
- **Infinite scroll** — uses `IntersectionObserver` on a sentinel `<div>` to trigger `onLoadMore`
|
|
22
|
+
- **Sticky header** — controlled via `stickyHeader` and `stickyHeaderOffset`
|
|
23
|
+
- **Placeholder rows** — invisible rows maintain consistent table height when data count is below `skeletonRows`
|
|
11
24
|
|
|
12
25
|
## Usage Example
|
|
13
26
|
|
|
14
27
|
```typescript
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
{
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
{
|
|
32
|
-
{
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
const rowActions = [
|
|
36
|
-
{
|
|
37
|
-
label: 'Edit',
|
|
38
|
-
onClick: (user: User) => console.log('Edit', user),
|
|
39
|
-
variant: 'outline' as const
|
|
40
|
-
},
|
|
41
|
-
{
|
|
42
|
-
label: 'Delete',
|
|
43
|
-
onClick: (user: User) => console.log('Delete', user),
|
|
44
|
-
variant: 'destructive' as const
|
|
45
|
-
}
|
|
46
|
-
]
|
|
47
|
-
|
|
48
|
-
export default function UsersTable() {
|
|
49
|
-
return (
|
|
50
|
-
<Table
|
|
51
|
-
data={users}
|
|
52
|
-
columns={columns}
|
|
53
|
-
rowKey="id"
|
|
54
|
-
rowActions={rowActions}
|
|
55
|
-
selectable={true}
|
|
56
|
-
onRowClick={(user) => console.log('Clicked', user)}
|
|
57
|
-
bulkActions={[
|
|
58
|
-
{
|
|
59
|
-
label: 'Delete Selected',
|
|
60
|
-
onClick: (selected) => console.log('Bulk delete', selected),
|
|
61
|
-
requiresSelection: true
|
|
62
|
-
}
|
|
63
|
-
]}
|
|
64
|
-
/>
|
|
65
|
-
)
|
|
66
|
-
}
|
|
28
|
+
<Table
|
|
29
|
+
data={users}
|
|
30
|
+
rowKey="id"
|
|
31
|
+
columns={[
|
|
32
|
+
{ key: 'name', label: 'Name', renderCell: (u) => u.name },
|
|
33
|
+
{ key: 'email', label: 'Email', renderCell: (u) => u.email },
|
|
34
|
+
]}
|
|
35
|
+
rowActions={[{ label: 'Edit', icon: <EditIcon />, onClick: (u) => openEdit(u) }]}
|
|
36
|
+
rowHref={(u) => `/users/${u.id}`}
|
|
37
|
+
onRowClick={(u) => console.log(u)}
|
|
38
|
+
cursorPagination={{
|
|
39
|
+
hasNextPage: true,
|
|
40
|
+
hasPreviousPage: false,
|
|
41
|
+
onNext: fetchNext,
|
|
42
|
+
onPrevious: fetchPrev,
|
|
43
|
+
}}
|
|
44
|
+
loading={isFetching}
|
|
45
|
+
skeletonRows={5}
|
|
46
|
+
/>
|
|
67
47
|
```
|
|
@@ -1,66 +1,74 @@
|
|
|
1
|
-
<!-- source-hash:
|
|
2
|
-
|
|
1
|
+
<!-- source-hash: 808a537086105a4fbc3af48a2f6c9794 -->
|
|
2
|
+
Legacy table component type definitions, all marked `@deprecated` in favor of the `data-table` module's types.
|
|
3
3
|
|
|
4
4
|
## Key Components
|
|
5
5
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
6
|
+
| Type | Kind | Description |
|
|
7
|
+
|------|------|-------------|
|
|
8
|
+
| `TableColumn<T>` | Interface | Column definition with sorting, filtering, rendering, and responsive visibility options |
|
|
9
|
+
| `TableProps<T>` | Interface | Full table configuration including data, pagination, selection, sorting, filtering, and styling |
|
|
10
|
+
| `CursorPagination` | Interface | Cursor-based pagination controls with next/previous navigation callbacks |
|
|
11
|
+
| `PagePagination` | Interface | Page-number-based pagination with page change callback |
|
|
12
|
+
| `InfiniteScrollConfig` | Interface | Infinite scroll configuration with load-more callback |
|
|
13
|
+
| `FilterOption` | Interface | Single filter option with id, label, and value |
|
|
14
|
+
| `FilterSection` | Interface | Grouped filter UI section supporting checkbox, radio, or select types |
|
|
15
|
+
| `TableFilters` | Interface | Map of column keys to active filter values |
|
|
16
|
+
| `BulkAction<T>` | Interface | Bulk action definition applied to selected rows |
|
|
17
|
+
| `RowAction<T>` | Interface | Per-row action with label, icon, and click handler |
|
|
18
|
+
| `TableHeaderProps<T>` | Interface | Props for the table header sub-component |
|
|
19
|
+
| `TableRowProps<T>` | Interface | Props for an individual table row sub-component |
|
|
20
|
+
| `TableCellProps` | Interface | Props for a single table cell |
|
|
21
|
+
| `TableCardSkeletonProps` | Interface | Skeleton loader configuration for loading states |
|
|
22
|
+
| `TableEmptyStateProps` | Interface | Empty state display with optional action button |
|
|
23
|
+
| `TailwindBreakpoint` | Type | Responsive breakpoint union: `'md' \| 'lg' \| 'xl' \| '2xl'` |
|
|
21
24
|
|
|
22
25
|
## Usage Example
|
|
23
26
|
|
|
27
|
+
> ⚠️ **Deprecated** — migrate to types from the `data-table` module instead.
|
|
28
|
+
|
|
24
29
|
```typescript
|
|
30
|
+
import type { TableColumn, TableProps, CursorPagination } from './types'
|
|
31
|
+
|
|
25
32
|
interface User {
|
|
26
33
|
id: string
|
|
27
34
|
name: string
|
|
28
35
|
email: string
|
|
29
|
-
status: 'active' | 'inactive'
|
|
30
36
|
}
|
|
31
37
|
|
|
32
|
-
const
|
|
38
|
+
const columns: TableColumn<User>[] = [
|
|
33
39
|
{
|
|
34
40
|
key: 'name',
|
|
35
41
|
label: 'Name',
|
|
36
42
|
sortable: true,
|
|
37
|
-
|
|
43
|
+
hideAt: 'md',
|
|
44
|
+
renderCell: (user) => <span className="font-medium">{user.name}</span>,
|
|
38
45
|
},
|
|
39
46
|
{
|
|
40
47
|
key: 'email',
|
|
41
48
|
label: 'Email',
|
|
42
|
-
hideAt: 'sm',
|
|
43
|
-
renderCell: (user) => <a href={`mailto:${user.email}`}>{user.email}</a>
|
|
44
|
-
},
|
|
45
|
-
{
|
|
46
|
-
key: 'status',
|
|
47
|
-
label: 'Status',
|
|
48
49
|
filterable: true,
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
{ id: 'inactive', label: 'Inactive', value: 'inactive' }
|
|
52
|
-
]
|
|
53
|
-
}
|
|
50
|
+
filterKey: 'email',
|
|
51
|
+
},
|
|
54
52
|
]
|
|
55
53
|
|
|
54
|
+
const pagination: CursorPagination = {
|
|
55
|
+
hasNextPage: true,
|
|
56
|
+
endCursor: 'cursor_abc123',
|
|
57
|
+
onNext: (cursor) => fetchUsers({ after: cursor }),
|
|
58
|
+
onReset: () => fetchUsers({}),
|
|
59
|
+
totalCount: 200,
|
|
60
|
+
showInfo: true,
|
|
61
|
+
}
|
|
62
|
+
|
|
56
63
|
const tableProps: TableProps<User> = {
|
|
57
64
|
data: users,
|
|
58
|
-
columns
|
|
65
|
+
columns,
|
|
59
66
|
rowKey: 'id',
|
|
67
|
+
loading: false,
|
|
60
68
|
selectable: true,
|
|
61
|
-
cursorPagination:
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
}
|
|
69
|
+
cursorPagination: pagination,
|
|
70
|
+
stickyHeader: true,
|
|
71
|
+
stickyHeaderOffset: 'top-[72px]',
|
|
72
|
+
onRowClick: (user) => router.push(`/users/${user.id}`),
|
|
65
73
|
}
|
|
66
74
|
```
|
|
@@ -1,34 +1,32 @@
|
|
|
1
|
-
<!-- source-hash:
|
|
2
|
-
|
|
1
|
+
<!-- source-hash: 465bf764d0dff56cb3acee5c13872c73 -->
|
|
2
|
+
Brief utility module providing responsive visibility helpers for table columns based on Tailwind CSS breakpoints. Both exports are deprecated in favor of `data-table`.
|
|
3
3
|
|
|
4
4
|
## Key Components
|
|
5
5
|
|
|
6
|
-
- **`getHideClasses()`**
|
|
7
|
-
- **`isHiddenOnMobile()`**
|
|
6
|
+
- **`getHideClasses(hideAt?)`** — Generates Tailwind CSS utility classes to hide/show an element at specified breakpoints. Supports single or multiple breakpoints and computes the appropriate `hidden`/`flex` class combinations.
|
|
7
|
+
- **`isHiddenOnMobile(column)`** — Returns `true` if a `TableColumn` is configured to hide at the `md` breakpoint (i.e., hidden on mobile).
|
|
8
8
|
|
|
9
9
|
## Usage Example
|
|
10
10
|
|
|
11
11
|
```typescript
|
|
12
12
|
import { getHideClasses, isHiddenOnMobile } from './utils'
|
|
13
|
-
import type { TableColumn } from './types'
|
|
14
13
|
|
|
15
|
-
//
|
|
16
|
-
|
|
17
|
-
|
|
14
|
+
// Single breakpoint: hide below md, show at md and above
|
|
15
|
+
getHideClasses('md')
|
|
16
|
+
// → 'hidden md:flex'
|
|
18
17
|
|
|
19
|
-
//
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
title: 'Email',
|
|
23
|
-
hideAt: ['sm', 'md']
|
|
24
|
-
}
|
|
18
|
+
// Multiple breakpoints: hide at md and lg, show at xl
|
|
19
|
+
getHideClasses(['md', 'lg'])
|
|
20
|
+
// → 'md:hidden lg:hidden xl:flex'
|
|
25
21
|
|
|
26
|
-
|
|
22
|
+
// Hide at 2xl with no larger breakpoint — just hide
|
|
23
|
+
getHideClasses('2xl')
|
|
24
|
+
// → '2xl:hidden'
|
|
27
25
|
|
|
28
|
-
//
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
26
|
+
// Check if a column is hidden on mobile
|
|
27
|
+
const column = { key: 'email', hideAt: 'md' }
|
|
28
|
+
isHiddenOnMobile(column)
|
|
29
|
+
// → true
|
|
32
30
|
```
|
|
33
31
|
|
|
34
|
-
|
|
32
|
+
> **Deprecated:** Both `getHideClasses` and `isHiddenOnMobile` are deprecated. Use the `data-table` component instead.
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
<!-- source-hash: 246e5605bed712d2ecbfd71d23933d41 -->
|
|
2
|
+
Provides the React context and typed interface that supply runtime configuration to the Flamingo/OpenFrame chat panel, decoupling API endpoints, navigation behavior, and identity source from the host environment.
|
|
3
|
+
|
|
4
|
+
## Key Components
|
|
5
|
+
|
|
6
|
+
### `ChatRuntime` Interface
|
|
7
|
+
The central config shape with three top-level concerns:
|
|
8
|
+
|
|
9
|
+
| Field | Description |
|
|
10
|
+
|---|---|
|
|
11
|
+
| `endpoints` | All API URLs: streaming chat, agent approval, slash-commands, attachment upload/view, identity, and optional image proxy |
|
|
12
|
+
| `navigation` | Mode (`'host'` or `'embed'`), external URL handler, in-app router callback, and new-tab decision logic |
|
|
13
|
+
| `source` | Required string used for `localStorage` namespacing (`mingo-chat-<source>-v1`) |
|
|
14
|
+
|
|
15
|
+
### `ChatRuntimeContext`
|
|
16
|
+
Raw React context (`createContext<ChatRuntime | null>(null)`). Mount via `<ChatRuntimeContext.Provider value={...}>` at your tree root.
|
|
17
|
+
|
|
18
|
+
### `useChatRuntime()`
|
|
19
|
+
Nullable consumer hook. Returns `null` when no provider is mounted — signals unconfigured runtime. Use for optional/graceful-degradation consumers.
|
|
20
|
+
|
|
21
|
+
### `useRequiredChatRuntime()`
|
|
22
|
+
Strict consumer hook used inside chat internals. Throws a descriptive error if called outside a provider. Use this inside the chat panel itself.
|
|
23
|
+
|
|
24
|
+
## Usage Example
|
|
25
|
+
|
|
26
|
+
```typescript
|
|
27
|
+
// Host (hub) — already handled by <HubRuntimeProvider>
|
|
28
|
+
// Embedded app — wire your own provider:
|
|
29
|
+
|
|
30
|
+
const runtime = useMemo<ChatRuntime>(() => ({
|
|
31
|
+
source: 'my-embedded-app',
|
|
32
|
+
endpoints: {
|
|
33
|
+
chatStreamUrl: 'https://hub.openframe.ai/api/docs/chat',
|
|
34
|
+
approvalToolUrl: 'https://hub.openframe.ai/api/chat/agent/confirm-tool',
|
|
35
|
+
commandsUrl: 'https://hub.openframe.ai/api/docs/commands',
|
|
36
|
+
buildListUrl: (type, ids) => null,
|
|
37
|
+
attachmentUploadUrl: 'https://hub.openframe.ai/api/storage/upload',
|
|
38
|
+
attachmentViewUrlPrefix: 'https://hub.openframe.ai/api/storage/view/chat-attachments/',
|
|
39
|
+
identityUrl: 'https://hub.openframe.ai/api/chat/identity',
|
|
40
|
+
},
|
|
41
|
+
navigation: {
|
|
42
|
+
mode: 'embed',
|
|
43
|
+
defaultContentOrigin: 'https://hub.openframe.ai',
|
|
44
|
+
},
|
|
45
|
+
}), [])
|
|
46
|
+
|
|
47
|
+
return (
|
|
48
|
+
<ChatRuntimeContext.Provider value={runtime}>
|
|
49
|
+
<ChatPanel />
|
|
50
|
+
</ChatRuntimeContext.Provider>
|
|
51
|
+
)
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
> **Memoization is required.** Passing a new object reference on every render invalidates downstream `useMemo` consumers across the entire chat tree (slash-commands, nav links, stream factory). Always stabilize with `useMemo` and stable deps.
|