@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,39 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: bdc3702e0fe4e374acdfea6c089ef641 -->
|
|
2
|
-
A React SVG icon component that renders a fleet/grid pattern with six circles arranged in a 3x2 layout, commonly used to represent multiple items, applications, or a dashboard grid.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **FleetIcon** - Forwardable React component that renders an SVG with six circles
|
|
7
|
-
- **FleetIconProps** - TypeScript interface extending SVGProps with custom size, color, and className options
|
|
8
|
-
- **Default Props** - Size defaults to 16px, color defaults to white
|
|
9
|
-
|
|
10
|
-
## Usage Example
|
|
11
|
-
|
|
12
|
-
```typescript
|
|
13
|
-
import { FleetIcon } from './fleet-icon'
|
|
14
|
-
|
|
15
|
-
// Basic usage
|
|
16
|
-
<FleetIcon />
|
|
17
|
-
|
|
18
|
-
// Custom size and color
|
|
19
|
-
<FleetIcon size={24} color="#3b82f6" />
|
|
20
|
-
|
|
21
|
-
// With custom styling
|
|
22
|
-
<FleetIcon
|
|
23
|
-
size={32}
|
|
24
|
-
color="currentColor"
|
|
25
|
-
className="hover:opacity-80 transition-opacity"
|
|
26
|
-
/>
|
|
27
|
-
|
|
28
|
-
// With ref forwarding
|
|
29
|
-
const iconRef = useRef<SVGSVGElement>(null)
|
|
30
|
-
<FleetIcon ref={iconRef} size={20} />
|
|
31
|
-
|
|
32
|
-
// As a clickable element
|
|
33
|
-
<button onClick={handleClick}>
|
|
34
|
-
<FleetIcon size={18} color="#059669" />
|
|
35
|
-
<span>View Applications</span>
|
|
36
|
-
</button>
|
|
37
|
-
```
|
|
38
|
-
|
|
39
|
-
The component uses a 14x14 viewBox with circles positioned at coordinates that create a visually balanced grid pattern. It supports all standard SVG props through prop spreading and integrates with the project's `cn` utility for className merging.
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: f32c8e718257f79d463e31e96d749bac -->
|
|
2
|
-
A React SVG icon component for MeshCentral remote access software, providing a scalable vector graphic representation with customizable styling properties.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **`MeshCentralIcon`** - Main React functional component that renders the MeshCentral logo as an SVG
|
|
7
|
-
- **`MeshCentralIconProps`** - TypeScript interface defining component props:
|
|
8
|
-
- `className?: string` - Optional CSS classes for styling
|
|
9
|
-
- `size?: number | string` - Icon dimensions (default: 16px)
|
|
10
|
-
- `color?: string` - Fill color for the SVG paths (default: 'white')
|
|
11
|
-
|
|
12
|
-
## Usage Example
|
|
13
|
-
|
|
14
|
-
```typescript
|
|
15
|
-
import { MeshCentralIcon } from './meshcentral-icon';
|
|
16
|
-
|
|
17
|
-
// Basic usage with defaults (16px, white)
|
|
18
|
-
<MeshCentralIcon />
|
|
19
|
-
|
|
20
|
-
// Customized icon
|
|
21
|
-
<MeshCentralIcon
|
|
22
|
-
size={32}
|
|
23
|
-
color="#2563eb"
|
|
24
|
-
className="hover:opacity-80 transition-opacity"
|
|
25
|
-
/>
|
|
26
|
-
|
|
27
|
-
// Responsive icon
|
|
28
|
-
<MeshCentralIcon
|
|
29
|
-
size="2rem"
|
|
30
|
-
color="currentColor"
|
|
31
|
-
className="text-blue-600 dark:text-blue-400"
|
|
32
|
-
/>
|
|
33
|
-
```
|
|
34
|
-
|
|
35
|
-
The component renders a detailed SVG with multiple path elements forming the MeshCentral logo, using a 512x512 viewBox for crisp scaling at any size. The SVG structure maintains aspect ratio and provides clean vector graphics suitable for both light and dark themes.
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: 3b5cb1abf955acf4d62987a1d45ff2c8 -->
|
|
2
|
-
A React component that renders a customizable refresh/reload SVG icon with configurable size, color, and styling properties.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **RefreshIconProps**: Interface defining optional props for customization
|
|
7
|
-
- `className` - CSS class name for styling
|
|
8
|
-
- `size` - Icon dimensions in pixels (default: 22)
|
|
9
|
-
- `color` - Fill color for the icon (default: '#888888')
|
|
10
|
-
- **RefreshIcon**: Main component that renders a circular refresh arrow SVG
|
|
11
|
-
|
|
12
|
-
## Usage Example
|
|
13
|
-
|
|
14
|
-
```typescript
|
|
15
|
-
import { RefreshIcon } from './refresh-icon';
|
|
16
|
-
|
|
17
|
-
// Basic usage with defaults
|
|
18
|
-
<RefreshIcon />
|
|
19
|
-
|
|
20
|
-
// Customized refresh icon
|
|
21
|
-
<RefreshIcon
|
|
22
|
-
className="my-refresh-icon"
|
|
23
|
-
size={32}
|
|
24
|
-
color="#007bff"
|
|
25
|
-
/>
|
|
26
|
-
|
|
27
|
-
// In a button component
|
|
28
|
-
<button onClick={handleRefresh}>
|
|
29
|
-
<RefreshIcon size={18} color="#ffffff" />
|
|
30
|
-
Refresh Data
|
|
31
|
-
</button>
|
|
32
|
-
```
|
|
33
|
-
|
|
34
|
-
The component renders a clean, modern refresh icon with two curved arrows forming a circular pattern, perfect for refresh buttons, reload indicators, or sync status displays.
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: b37c82db332e759e3fdf73bead000401 -->
|
|
2
|
-
A React component that renders an SVG tactical icon with customizable size, styling, and color properties.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **TacticalIcon**: A functional React component that renders a tactical/military-style icon as an SVG
|
|
7
|
-
- **Props Interface**:
|
|
8
|
-
- `size?: number` - Controls width and height (default: 16px)
|
|
9
|
-
- `className?: string` - Optional CSS class for styling
|
|
10
|
-
- `color?: string` - Fill color for the icon (default: 'white')
|
|
11
|
-
|
|
12
|
-
## Usage Example
|
|
13
|
-
|
|
14
|
-
```typescript
|
|
15
|
-
import { TacticalIcon } from './tactical-icon'
|
|
16
|
-
|
|
17
|
-
// Basic usage with defaults
|
|
18
|
-
<TacticalIcon />
|
|
19
|
-
|
|
20
|
-
// Customized icon
|
|
21
|
-
<TacticalIcon
|
|
22
|
-
size={24}
|
|
23
|
-
color="#FF0000"
|
|
24
|
-
className="tactical-indicator"
|
|
25
|
-
/>
|
|
26
|
-
|
|
27
|
-
// Large icon with custom styling
|
|
28
|
-
<TacticalIcon
|
|
29
|
-
size={48}
|
|
30
|
-
color="currentColor"
|
|
31
|
-
className="hover:opacity-75 transition-opacity"
|
|
32
|
-
/>
|
|
33
|
-
```
|
|
34
|
-
|
|
35
|
-
The component uses a complex SVG path to create a detailed tactical symbol, making it suitable for military applications, gaming interfaces, or strategic planning tools. The icon is scalable and maintains its proportions at any size while allowing full customization of appearance through standard CSS properties.
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: c4b8d37ede69f03fe1bce212068811c0 -->
|
|
2
|
-
A reusable button component with comprehensive variant support, icon handling, and Next.js navigation integration for the OpenFrame design system.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **Button**: Main React component with forwardRef support
|
|
7
|
-
- **buttonVariants**: CVA-based style variants with 20+ predefined styles
|
|
8
|
-
- **ButtonProps**: TypeScript interface extending HTML button attributes
|
|
9
|
-
- **Navigation Integration**: Built-in Next.js router and Link component support
|
|
10
|
-
|
|
11
|
-
## Usage Example
|
|
12
|
-
|
|
13
|
-
```typescript
|
|
14
|
-
import { Button } from './button'
|
|
15
|
-
import { ExternalLink, Plus } from 'lucide-react'
|
|
16
|
-
|
|
17
|
-
// Primary CTA button
|
|
18
|
-
<Button variant="primary" size="lg">
|
|
19
|
-
Get Started
|
|
20
|
-
</Button>
|
|
21
|
-
|
|
22
|
-
// Button with icons
|
|
23
|
-
<Button
|
|
24
|
-
variant="secondary"
|
|
25
|
-
leftIcon={<Plus />}
|
|
26
|
-
rightIcon={<ExternalLink />}
|
|
27
|
-
>
|
|
28
|
-
Add Item
|
|
29
|
-
</Button>
|
|
30
|
-
|
|
31
|
-
// Navigation button with Next.js Link
|
|
32
|
-
<Button
|
|
33
|
-
variant="outline"
|
|
34
|
-
href="/dashboard"
|
|
35
|
-
openInNewTab={true}
|
|
36
|
-
>
|
|
37
|
-
Open Dashboard
|
|
38
|
-
</Button>
|
|
39
|
-
|
|
40
|
-
// Icon-only button
|
|
41
|
-
<Button
|
|
42
|
-
variant="ghost"
|
|
43
|
-
size="icon"
|
|
44
|
-
centerIcon={<Plus />}
|
|
45
|
-
aria-label="Add item"
|
|
46
|
-
/>
|
|
47
|
-
|
|
48
|
-
// Loading state
|
|
49
|
-
<Button
|
|
50
|
-
variant="primary"
|
|
51
|
-
loading={true}
|
|
52
|
-
disabled={true}
|
|
53
|
-
>
|
|
54
|
-
Processing...
|
|
55
|
-
</Button>
|
|
56
|
-
|
|
57
|
-
// Custom styling with dual navigation
|
|
58
|
-
<Button
|
|
59
|
-
variant="flamingo-primary"
|
|
60
|
-
navigateUrl="/dashboard"
|
|
61
|
-
showExternalLinkOnHover={true}
|
|
62
|
-
alignment="left"
|
|
63
|
-
noPadding={true}
|
|
64
|
-
>
|
|
65
|
-
Custom Action
|
|
66
|
-
</Button>
|
|
67
|
-
```
|
|
68
|
-
|
|
69
|
-
The component supports 20+ variants (primary, secondary, outline, ghost, destructive, etc.), multiple sizes, accessibility features, and advanced navigation patterns including dual-mode navigation and external link handling.
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: ef91f8df50a8d9fa66e1d939cdc2b6a5 -->
|
|
2
|
-
A responsive table row component for displaying log entries with detailed information and action controls in the Flamingo/OpenFrame system.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **LogTableRow**: Main component with responsive desktop/mobile layouts
|
|
7
|
-
- **LogTableRowProps**: Interface defining log entry structure (ID, timestamp, status, source, device, description)
|
|
8
|
-
- **FleetMDMIcon**: Internal SVG icon component for MDM source visualization
|
|
9
|
-
- **StatusTag integration**: Uses status tags with variant-based styling
|
|
10
|
-
- **Button components**: Action buttons for "more options" and "log details"
|
|
11
|
-
|
|
12
|
-
## Usage Example
|
|
13
|
-
|
|
14
|
-
```typescript
|
|
15
|
-
import { LogTableRow } from './log-table-row'
|
|
16
|
-
|
|
17
|
-
function LogsList() {
|
|
18
|
-
return (
|
|
19
|
-
<div className="space-y-2">
|
|
20
|
-
<LogTableRow
|
|
21
|
-
logId="LOG-001"
|
|
22
|
-
timestamp="2024-01-15 14:30:22"
|
|
23
|
-
status={{
|
|
24
|
-
label: "Success",
|
|
25
|
-
variant: "success"
|
|
26
|
-
}}
|
|
27
|
-
source={{
|
|
28
|
-
name: "Fleet MDM",
|
|
29
|
-
icon: <FleetMDMIcon />
|
|
30
|
-
}}
|
|
31
|
-
device={{
|
|
32
|
-
name: "MacBook-Pro-123",
|
|
33
|
-
organization: "Acme Corp"
|
|
34
|
-
}}
|
|
35
|
-
description={{
|
|
36
|
-
title: "Device enrollment completed",
|
|
37
|
-
details: "Successfully enrolled device into MDM system"
|
|
38
|
-
}}
|
|
39
|
-
onMoreClick={() => console.log('More actions clicked')}
|
|
40
|
-
onDetailsClick={() => console.log('View details clicked')}
|
|
41
|
-
/>
|
|
42
|
-
</div>
|
|
43
|
-
)
|
|
44
|
-
}
|
|
45
|
-
```
|
|
46
|
-
|
|
47
|
-
The component automatically switches between detailed desktop layout (showing all fields in separate columns) and compact mobile layout (condensed information with essential actions).
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: ff9f153f95ede31a79f3bd2078852119 -->
|
|
2
|
-
A client-side React component that renders a selectable card for displaying device information with hover states and selection feedback.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **`SelectableDeviceCardProps`** - Interface defining component props including title, device type, icon, subtitle, selection state, and click handler
|
|
7
|
-
- **`SelectableDeviceCard`** - Main functional component that renders an interactive device card with visual feedback for selection states
|
|
8
|
-
|
|
9
|
-
## Key Features
|
|
10
|
-
|
|
11
|
-
- **Device Type Icons** - Automatically displays appropriate icons based on device type or accepts custom icons
|
|
12
|
-
- **Selection States** - Visual distinction between selected and unselected states with different color schemes
|
|
13
|
-
- **Hover Effects** - Smooth transitions and hover states for better user interaction
|
|
14
|
-
- **Responsive Design** - Adaptive sizing for icons and text across different screen sizes
|
|
15
|
-
- **Accessibility** - Proper click handling and visual feedback for selection
|
|
16
|
-
|
|
17
|
-
## Usage Example
|
|
18
|
-
|
|
19
|
-
```typescript
|
|
20
|
-
import { SelectableDeviceCard } from './selectable-device-card'
|
|
21
|
-
import { DeviceType } from '../icons/device-type-icons/get-device-type-icon'
|
|
22
|
-
|
|
23
|
-
function DeviceList() {
|
|
24
|
-
const [selectedDevice, setSelectedDevice] = useState<string | null>(null)
|
|
25
|
-
|
|
26
|
-
return (
|
|
27
|
-
<div className="space-y-2">
|
|
28
|
-
<SelectableDeviceCard
|
|
29
|
-
title="MacBook Pro"
|
|
30
|
-
type={DeviceType.LAPTOP}
|
|
31
|
-
subtitle="Connected via WiFi"
|
|
32
|
-
selected={selectedDevice === 'macbook'}
|
|
33
|
-
onSelect={() => setSelectedDevice('macbook')}
|
|
34
|
-
/>
|
|
35
|
-
|
|
36
|
-
<SelectableDeviceCard
|
|
37
|
-
title="iPhone 15"
|
|
38
|
-
type={DeviceType.MOBILE}
|
|
39
|
-
subtitle="Last seen: 2 hours ago"
|
|
40
|
-
selected={selectedDevice === 'iphone'}
|
|
41
|
-
onSelect={() => setSelectedDevice('iphone')}
|
|
42
|
-
/>
|
|
43
|
-
</div>
|
|
44
|
-
)
|
|
45
|
-
}
|
|
46
|
-
```
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: f4fc25c5acc64d9e92e2f93976f24738 -->
|
|
2
|
-
A hook injection system that enables ui-kit components to access API hooks from consuming projects while providing fallback stub implementations.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
**Type Definitions:**
|
|
7
|
-
- `UseVendorsHook` - Type for vendor data fetching hook with filtering and pagination options
|
|
8
|
-
- `UseSubcategoryCountHook` - Type for subcategory count fetching hook
|
|
9
|
-
|
|
10
|
-
**Hook Management:**
|
|
11
|
-
- `setUseVendorsHook()` - Injects vendor hook implementation from main project
|
|
12
|
-
- `setUseSubcategoryCountHook()` - Injects subcategory count hook implementation
|
|
13
|
-
- `useVendors()` - Consumer-facing hook with fallback to stub data
|
|
14
|
-
- `useSubcategoryCountByCategory()` - Consumer-facing hook with fallback to stub data
|
|
15
|
-
|
|
16
|
-
## Usage Example
|
|
17
|
-
|
|
18
|
-
**In main project (hook injection):**
|
|
19
|
-
```typescript
|
|
20
|
-
import { setUseVendorsHook, setUseSubcategoryCountHook } from '@ui-kit/api-hooks-stub';
|
|
21
|
-
import { useVendors as realUseVendors, useSubcategoryCount } from './api/hooks';
|
|
22
|
-
|
|
23
|
-
// Setup hooks during app initialization
|
|
24
|
-
setUseVendorsHook(realUseVendors);
|
|
25
|
-
setUseSubcategoryCountHook(useSubcategoryCount);
|
|
26
|
-
```
|
|
27
|
-
|
|
28
|
-
**In ui-kit components:**
|
|
29
|
-
```typescript
|
|
30
|
-
import { useVendors, useSubcategoryCountByCategory } from './api-hooks-stub';
|
|
31
|
-
|
|
32
|
-
function VendorList() {
|
|
33
|
-
const { data, isLoading, error } = useVendors({
|
|
34
|
-
filtering: ['active'],
|
|
35
|
-
pageSize: 20
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
const subcategoryCount = useSubcategoryCountByCategory('technology');
|
|
39
|
-
|
|
40
|
-
if (isLoading) return <div>Loading...</div>;
|
|
41
|
-
return <div>{data?.vendors.map(vendor => ...)}</div>;
|
|
42
|
-
}
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
This pattern allows ui-kit components to remain decoupled from specific API implementations while gracefully degrading to stub data when hooks aren't properly injected.
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: 5ef95c525ada086cb9ed9dcf9679709a -->
|
|
2
|
-
A comprehensive set of React Query hooks for managing product releases, providing both public-facing and admin functionality with automatic cache management and toast notifications.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **Query Key Factory** (`releaseKeys`) - Structured cache key management for React Query
|
|
7
|
-
- **Public Hooks** - `useReleases()`, `useRelease()` for fetching public release data
|
|
8
|
-
- **Admin Query Hooks** - `useAdminReleases()`, `useAdminRelease()` for admin interfaces
|
|
9
|
-
- **Admin Mutation Hooks** - `useCreateRelease()`, `useUpdateRelease()`, `useDeleteRelease()` for CRUD operations
|
|
10
|
-
- **Automatic Cache Invalidation** - Mutations automatically refresh related queries
|
|
11
|
-
- **Toast Integration** - Built-in success/error notifications via `useToast()`
|
|
12
|
-
|
|
13
|
-
## Usage Example
|
|
14
|
-
|
|
15
|
-
```typescript
|
|
16
|
-
'use client'
|
|
17
|
-
import { useReleases, useCreateRelease } from './use-product-releases'
|
|
18
|
-
|
|
19
|
-
function ReleasesPage() {
|
|
20
|
-
// Fetch releases with filtering
|
|
21
|
-
const { data: releases, isLoading } = useReleases({
|
|
22
|
-
tags: ['feature', 'bugfix'],
|
|
23
|
-
release_status: ['published'],
|
|
24
|
-
featured: true,
|
|
25
|
-
limit: 10
|
|
26
|
-
})
|
|
27
|
-
|
|
28
|
-
// Admin create mutation
|
|
29
|
-
const createRelease = useCreateRelease()
|
|
30
|
-
|
|
31
|
-
const handleCreate = async () => {
|
|
32
|
-
await createRelease.mutateAsync({
|
|
33
|
-
title: 'New Release',
|
|
34
|
-
version: '1.2.0',
|
|
35
|
-
release_type: 'minor',
|
|
36
|
-
release_status: 'draft'
|
|
37
|
-
})
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
if (isLoading) return <div>Loading...</div>
|
|
41
|
-
|
|
42
|
-
return (
|
|
43
|
-
<div>
|
|
44
|
-
{releases?.data.map(release => (
|
|
45
|
-
<div key={release.slug}>{release.title}</div>
|
|
46
|
-
))}
|
|
47
|
-
<button onClick={handleCreate}>Create Release</button>
|
|
48
|
-
</div>
|
|
49
|
-
)
|
|
50
|
-
}
|
|
51
|
-
```
|
|
52
|
-
|
|
53
|
-
The hooks require `QueryClientProvider` wrapper and should only be used in client components due to the `'use client'` directive.
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: e98134c8b03bd09e8fc3edeb2e50f64d -->
|
|
2
|
-
A Storybook configuration file defining interactive stories for the OrganizationSelector component, including various states and usage scenarios.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **Sample Data**: `sampleOrganizations` - Mock data array with 10 fictional organizations for testing
|
|
7
|
-
- **Meta Configuration**: Storybook metadata with component settings, layout, and control types
|
|
8
|
-
- **Story Variants**: Seven different stories showcasing component states and interactions
|
|
9
|
-
- **Interactive Story**: `WithSearchInteractive` - Demonstrates real state management with React hooks
|
|
10
|
-
|
|
11
|
-
## Usage Example
|
|
12
|
-
|
|
13
|
-
```typescript
|
|
14
|
-
// Basic story with default props
|
|
15
|
-
export const Default: Story = {
|
|
16
|
-
args: {
|
|
17
|
-
organizations: sampleOrganizations,
|
|
18
|
-
value: '',
|
|
19
|
-
onValueChange: () => {},
|
|
20
|
-
placeholder: 'Choose organization',
|
|
21
|
-
label: 'Organization',
|
|
22
|
-
},
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
// Interactive story with state management
|
|
26
|
-
export const WithSearchInteractive: Story = {
|
|
27
|
-
render: () => {
|
|
28
|
-
const [value, setValue] = useState('')
|
|
29
|
-
return (
|
|
30
|
-
<OrganizationSelector
|
|
31
|
-
organizations={sampleOrganizations}
|
|
32
|
-
value={value}
|
|
33
|
-
onValueChange={setValue}
|
|
34
|
-
label="Organization"
|
|
35
|
-
searchable
|
|
36
|
-
/>
|
|
37
|
-
)
|
|
38
|
-
},
|
|
39
|
-
}
|
|
40
|
-
```
|
|
41
|
-
|
|
42
|
-
The stories cover common use cases including default state, search functionality, loading states, disabled state, preselected values, and scenarios with limited data sets.
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: 1a01780173e4f46ca59a5e44727afa17 -->
|
|
2
|
-
Storybook stories configuration file that defines interactive documentation and test cases for the SelectableDeviceCard component, showcasing various states including selection, device types, and group interactions.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **Meta Configuration**: Storybook metadata with component controls and documentation
|
|
7
|
-
- **Story Variants**: Eight different story configurations demonstrating component states
|
|
8
|
-
- **Interactive Examples**: Stories with React hooks for dynamic selection behavior
|
|
9
|
-
- **Device Type Demos**: Examples for desktop, laptop, server, and mobile device types
|
|
10
|
-
- **Selection Group**: Multi-card selection scenario with state management
|
|
11
|
-
|
|
12
|
-
## Usage Example
|
|
13
|
-
|
|
14
|
-
```typescript
|
|
15
|
-
import { SelectableDeviceCard } from './SelectableDeviceCard.stories'
|
|
16
|
-
|
|
17
|
-
// Basic story usage in Storybook
|
|
18
|
-
const basicExample = Default.args // { title: 'MacBook Pro', type: 'laptop' }
|
|
19
|
-
|
|
20
|
-
// Interactive story with state
|
|
21
|
-
const interactiveStory = Interactive.render({
|
|
22
|
-
title: 'My Device',
|
|
23
|
-
type: 'desktop'
|
|
24
|
-
})
|
|
25
|
-
|
|
26
|
-
// Selection group pattern
|
|
27
|
-
const selectionGroup = SelectionGroup.decorators[0]()
|
|
28
|
-
```
|
|
29
|
-
|
|
30
|
-
The stories cover essential use cases including default states, selected states, subtitle variations, different device types (desktop, laptop, server), custom icons, and interactive selection groups. Each story includes proper controls for testing different props and demonstrates real-world usage patterns for device selection interfaces.
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: 90b0001b941d30b6c3699508d4981c9a -->
|
|
2
|
-
A lightweight React component that provides YouTube video embedding functionality using a standard iframe approach, serving as a simplified alternative to more complex lite YouTube embed solutions.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **`LiteYouTubeEmbedProps`** - Interface defining component props including video ID, title, poster image, and styling options
|
|
7
|
-
- **`LiteYouTubeEmbed`** - React functional component that renders a YouTube iframe with proper accessibility and permissions settings
|
|
8
|
-
|
|
9
|
-
## Usage Example
|
|
10
|
-
|
|
11
|
-
```typescript
|
|
12
|
-
import { LiteYouTubeEmbed } from './lite-youtube-embed-stub';
|
|
13
|
-
|
|
14
|
-
function VideoPlayer() {
|
|
15
|
-
return (
|
|
16
|
-
<LiteYouTubeEmbed
|
|
17
|
-
id="dQw4w9WgXcQ"
|
|
18
|
-
title="Never Gonna Give You Up"
|
|
19
|
-
className="video-container"
|
|
20
|
-
/>
|
|
21
|
-
);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
// With custom styling
|
|
25
|
-
function StyledVideo() {
|
|
26
|
-
return (
|
|
27
|
-
<LiteYouTubeEmbed
|
|
28
|
-
id="awc-yAnkhIo"
|
|
29
|
-
title="OpenFrame Demo"
|
|
30
|
-
poster="custom-thumbnail.jpg"
|
|
31
|
-
className="w-full aspect-video rounded-lg"
|
|
32
|
-
/>
|
|
33
|
-
);
|
|
34
|
-
}
|
|
35
|
-
```
|
|
36
|
-
|
|
37
|
-
The component automatically configures iframe permissions for media playback, autoplay, and fullscreen functionality. While it accepts a `poster` prop in the interface, the current implementation relies on YouTube's default iframe behavior for thumbnail display. This stub version prioritizes simplicity over advanced features like lazy loading or custom poster images.
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
<!-- source-hash: fcad50083a3635f489d5b92635164c9a -->
|
|
2
|
-
A lightweight YouTube embed component that displays a thumbnail image with play button overlay, only loading the actual iframe when clicked to improve initial page performance.
|
|
3
|
-
|
|
4
|
-
## Key Components
|
|
5
|
-
|
|
6
|
-
- **LiteYouTubeEmbedProps** - Interface defining component props including video ID, title, custom thumbnail URL, and CSS classes
|
|
7
|
-
- **LiteYouTubeEmbed** - Main component that renders either a clickable thumbnail or full YouTube iframe based on load state
|
|
8
|
-
- **handleLoad** - State handler that switches from thumbnail to iframe when user clicks
|
|
9
|
-
|
|
10
|
-
## Usage Example
|
|
11
|
-
|
|
12
|
-
```typescript
|
|
13
|
-
import { LiteYouTubeEmbed } from './lite-youtube-embed';
|
|
14
|
-
|
|
15
|
-
// Basic usage with video ID
|
|
16
|
-
<LiteYouTubeEmbed
|
|
17
|
-
id="dQw4w9WgXcQ"
|
|
18
|
-
title="Never Gonna Give You Up"
|
|
19
|
-
/>
|
|
20
|
-
|
|
21
|
-
// With custom thumbnail and styling
|
|
22
|
-
<LiteYouTubeEmbed
|
|
23
|
-
id="awc-yAnkhIo"
|
|
24
|
-
title="OpenFrame Demo"
|
|
25
|
-
thumbnail="https://img.youtube.com/vi/awc-yAnkhIo/hqdefault.jpg"
|
|
26
|
-
className="w-full max-w-2xl mx-auto rounded-lg shadow-lg"
|
|
27
|
-
/>
|
|
28
|
-
|
|
29
|
-
// Minimal usage
|
|
30
|
-
<LiteYouTubeEmbed id="VIDEO_ID" />
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
The component automatically uses YouTube's `maxresdefault.jpg` thumbnail if no custom thumbnail is provided, and includes a styled red play button overlay that mimics YouTube's interface. The iframe loads with standard YouTube embed permissions for autoplay, fullscreen, and media controls.
|
|
File without changes
|
|
File without changes
|