@cardstack/boxel-cli 0.2.0-unstable.448 → 0.3.0-unstable.13
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/bundled-types/base/-private.d.ts +1 -0
- package/bundled-types/base/address.d.ts +17 -0
- package/bundled-types/base/ai-app-generator.d.ts +14 -0
- package/bundled-types/base/amount-with-currency.d.ts +10 -0
- package/bundled-types/base/avif-image-def.d.ts +12 -0
- package/bundled-types/base/avif-meta-extractor.d.ts +4 -0
- package/bundled-types/base/base64-image.d.ts +25 -0
- package/bundled-types/base/big-integer.d.ts +12 -0
- package/bundled-types/base/boolean.d.ts +14 -0
- package/bundled-types/base/brand-functional-palette.d.ts +16 -0
- package/bundled-types/base/brand-guide.d.ts +26 -0
- package/bundled-types/base/brand-logo.d.ts +29 -0
- package/bundled-types/base/card-api.d.ts +513 -0
- package/bundled-types/base/card-serialization.d.ts +47 -0
- package/bundled-types/base/cards-grid.d.ts +10 -0
- package/bundled-types/base/code-ref.d.ts +14 -0
- package/bundled-types/base/codemirror-editor.d.ts +135 -0
- package/bundled-types/base/color-field/components/advanced-color-picker.d.ts +66 -0
- package/bundled-types/base/color-field/components/color-picker-field.d.ts +22 -0
- package/bundled-types/base/color-field/components/color-wheel-picker.d.ts +44 -0
- package/bundled-types/base/color-field/components/contrast-checker-addon.d.ts +14 -0
- package/bundled-types/base/color-field/components/recent-colors-addon.d.ts +19 -0
- package/bundled-types/base/color-field/components/slider-picker.d.ts +40 -0
- package/bundled-types/base/color-field/components/swatches-picker.d.ts +5 -0
- package/bundled-types/base/color-field/modifiers/setup-element-modifier.d.ts +10 -0
- package/bundled-types/base/color-field/util/color-field-signature.d.ts +9 -0
- package/bundled-types/base/color-field/util/color-utils.d.ts +96 -0
- package/bundled-types/base/color-field/util/css-color-parsers.d.ts +11 -0
- package/bundled-types/base/color.d.ts +10 -0
- package/bundled-types/base/command.d.ts +593 -0
- package/bundled-types/base/commands/search-card-result.d.ts +36 -0
- package/bundled-types/base/components/age.d.ts +22 -0
- package/bundled-types/base/components/business-days.d.ts +16 -0
- package/bundled-types/base/components/card-list.d.ts +25 -0
- package/bundled-types/base/components/cards-grid-layout.d.ts +58 -0
- package/bundled-types/base/components/countdown.d.ts +31 -0
- package/bundled-types/base/components/expiration-warning.d.ts +24 -0
- package/bundled-types/base/components/time-ago.d.ts +24 -0
- package/bundled-types/base/components/time-slots.d.ts +20 -0
- package/bundled-types/base/components/timeline.d.ts +22 -0
- package/bundled-types/base/contains-many-component.d.ts +7 -0
- package/bundled-types/base/coordinate.d.ts +7 -0
- package/bundled-types/base/country.d.ts +23 -0
- package/bundled-types/base/css-value.d.ts +6 -0
- package/bundled-types/base/csv-file-def.d.ts +29 -0
- package/bundled-types/base/currency.d.ts +16 -0
- package/bundled-types/base/date/day.d.ts +9 -0
- package/bundled-types/base/date/month-day.d.ts +10 -0
- package/bundled-types/base/date/month-year.d.ts +9 -0
- package/bundled-types/base/date/month.d.ts +9 -0
- package/bundled-types/base/date/quarter.d.ts +10 -0
- package/bundled-types/base/date/week.d.ts +9 -0
- package/bundled-types/base/date/year.d.ts +9 -0
- package/bundled-types/base/date-range-field.d.ts +12 -0
- package/bundled-types/base/date.d.ts +12 -0
- package/bundled-types/base/datetime-stamp.d.ts +7 -0
- package/bundled-types/base/datetime.d.ts +12 -0
- package/bundled-types/base/default-templates/atom.d.ts +10 -0
- package/bundled-types/base/default-templates/card-info.d.ts +32 -0
- package/bundled-types/base/default-templates/embedded.d.ts +11 -0
- package/bundled-types/base/default-templates/field-edit.d.ts +10 -0
- package/bundled-types/base/default-templates/file-def-edit.d.ts +8 -0
- package/bundled-types/base/default-templates/fitted.d.ts +12 -0
- package/bundled-types/base/default-templates/head.d.ts +13 -0
- package/bundled-types/base/default-templates/image-def-atom.d.ts +8 -0
- package/bundled-types/base/default-templates/image-def-embedded.d.ts +8 -0
- package/bundled-types/base/default-templates/image-def-fitted.d.ts +8 -0
- package/bundled-types/base/default-templates/image-def-isolated.d.ts +8 -0
- package/bundled-types/base/default-templates/isolated-and-edit.d.ts +15 -0
- package/bundled-types/base/default-templates/markdown-fallback.d.ts +19 -0
- package/bundled-types/base/default-templates/markdown.d.ts +60 -0
- package/bundled-types/base/default-templates/missing-template.d.ts +13 -0
- package/bundled-types/base/default-templates/theme-dashboard.d.ts +126 -0
- package/bundled-types/base/detailed-style-reference.d.ts +48 -0
- package/bundled-types/base/email.d.ts +10 -0
- package/bundled-types/base/enum.d.ts +30 -0
- package/bundled-types/base/ethereum-address.d.ts +13 -0
- package/bundled-types/base/field-component.d.ts +65 -0
- package/bundled-types/base/field-support.d.ts +55 -0
- package/bundled-types/base/file-api.d.ts +2 -0
- package/bundled-types/base/file-menu-items.d.ts +4 -0
- package/bundled-types/base/gif-image-def.d.ts +12 -0
- package/bundled-types/base/gif-meta-extractor.d.ts +4 -0
- package/bundled-types/base/gts-file-def.d.ts +7 -0
- package/bundled-types/base/helpers/country.d.ts +3198 -0
- package/bundled-types/base/helpers/sanitized-html.d.ts +2 -0
- package/bundled-types/base/helpers/set-background-image.d.ts +2 -0
- package/bundled-types/base/image-file-def.d.ts +1 -0
- package/bundled-types/base/image.d.ts +8 -0
- package/bundled-types/base/index.d.ts +1 -0
- package/bundled-types/base/join-the-community.d.ts +14 -0
- package/bundled-types/base/jpg-image-def.d.ts +12 -0
- package/bundled-types/base/jpg-meta-extractor.d.ts +4 -0
- package/bundled-types/base/json-file-def.d.ts +23 -0
- package/bundled-types/base/links-to-editor.d.ts +22 -0
- package/bundled-types/base/links-to-many-component.d.ts +7 -0
- package/bundled-types/base/llm-model.d.ts +6 -0
- package/bundled-types/base/markdown-file-def.d.ts +25 -0
- package/bundled-types/base/markdown-helpers.d.ts +26 -0
- package/bundled-types/base/markdown.d.ts +1 -0
- package/bundled-types/base/matrix-event.d.ts +400 -0
- package/bundled-types/base/menu-items.d.ts +21 -0
- package/bundled-types/base/number/components/badge-counter.d.ts +32 -0
- package/bundled-types/base/number/components/badge-metric.d.ts +34 -0
- package/bundled-types/base/number/components/badge-notification.d.ts +38 -0
- package/bundled-types/base/number/components/gauge.d.ts +45 -0
- package/bundled-types/base/number/components/number-input.d.ts +27 -0
- package/bundled-types/base/number/components/progress-bar.d.ts +44 -0
- package/bundled-types/base/number/components/progress-circle.d.ts +41 -0
- package/bundled-types/base/number/components/score.d.ts +41 -0
- package/bundled-types/base/number/components/stat.d.ts +38 -0
- package/bundled-types/base/number/util/index.d.ts +29 -0
- package/bundled-types/base/number.d.ts +52 -0
- package/bundled-types/base/percentage.d.ts +9 -0
- package/bundled-types/base/phone-number.d.ts +25 -0
- package/bundled-types/base/png-image-def.d.ts +12 -0
- package/bundled-types/base/png-meta-extractor.d.ts +4 -0
- package/bundled-types/base/positioned-card.d.ts +7 -0
- package/bundled-types/base/query-field-support.d.ts +6 -0
- package/bundled-types/base/realm-config.d.ts +16 -0
- package/bundled-types/base/realm.d.ts +7 -0
- package/bundled-types/base/resources/command-data.d.ts +43 -0
- package/bundled-types/base/response-field.d.ts +6 -0
- package/bundled-types/base/rich-markdown.d.ts +30 -0
- package/bundled-types/base/shared-state.d.ts +1 -0
- package/bundled-types/base/skill-plus.d.ts +79 -0
- package/bundled-types/base/skill-reference.d.ts +12 -0
- package/bundled-types/base/skill-set.d.ts +18 -0
- package/bundled-types/base/skill.d.ts +21 -0
- package/bundled-types/base/spec.d.ts +108 -0
- package/bundled-types/base/string.d.ts +2 -0
- package/bundled-types/base/structured-theme-variables.d.ts +85 -0
- package/bundled-types/base/structured-theme.d.ts +32 -0
- package/bundled-types/base/style-reference.d.ts +14 -0
- package/bundled-types/base/svg-image-def.d.ts +12 -0
- package/bundled-types/base/svg-meta-extractor.d.ts +12 -0
- package/bundled-types/base/system-card.d.ts +17 -0
- package/bundled-types/base/tag.d.ts +15 -0
- package/bundled-types/base/text-area.d.ts +2 -0
- package/bundled-types/base/text-file-def.d.ts +23 -0
- package/bundled-types/base/text-input-validator.d.ts +13 -0
- package/bundled-types/base/theme.d.ts +2 -0
- package/bundled-types/base/time/duration.d.ts +14 -0
- package/bundled-types/base/time/relative-time.d.ts +10 -0
- package/bundled-types/base/time/time-range.d.ts +11 -0
- package/bundled-types/base/time.d.ts +9 -0
- package/bundled-types/base/ts-file-def.d.ts +26 -0
- package/bundled-types/base/ts-highlight.d.ts +1 -0
- package/bundled-types/base/types/@cardstack/boxel-host/index.d.ts +5 -0
- package/bundled-types/base/types/ember-css-url/index.d.ts +15 -0
- package/bundled-types/base/typography.d.ts +14 -0
- package/bundled-types/base/url.d.ts +13 -0
- package/bundled-types/base/watched-array.d.ts +7 -0
- package/bundled-types/base/webp-image-def.d.ts +12 -0
- package/bundled-types/base/webp-meta-extractor.d.ts +4 -0
- package/bundled-types/base/website.d.ts +8 -0
- package/bundled-types/base/welcome-to-boxel.d.ts +22 -0
- package/bundled-types/boxel-ui/components/accordion/index.gts +50 -0
- package/bundled-types/boxel-ui/components/accordion/item/index.gts +156 -0
- package/bundled-types/boxel-ui/components/accordion/usage.gts +157 -0
- package/bundled-types/boxel-ui/components/add-button/index.gts +46 -0
- package/bundled-types/boxel-ui/components/add-button/usage.gts +54 -0
- package/bundled-types/boxel-ui/components/alert/index.gts +151 -0
- package/bundled-types/boxel-ui/components/alert/usage.gts +66 -0
- package/bundled-types/boxel-ui/components/avatar/index.gts +79 -0
- package/bundled-types/boxel-ui/components/avatar/usage.gts +96 -0
- package/bundled-types/boxel-ui/components/basic-fitted/index.gts +340 -0
- package/bundled-types/boxel-ui/components/basic-fitted/usage.gts +223 -0
- package/bundled-types/boxel-ui/components/button/index.gts +416 -0
- package/bundled-types/boxel-ui/components/button/usage.gts +334 -0
- package/bundled-types/boxel-ui/components/card-container/index.gts +251 -0
- package/bundled-types/boxel-ui/components/card-container/usage.gts +53 -0
- package/bundled-types/boxel-ui/components/card-header/index.gts +473 -0
- package/bundled-types/boxel-ui/components/card-header/usage.gts +295 -0
- package/bundled-types/boxel-ui/components/circle-spinner/index.gts +42 -0
- package/bundled-types/boxel-ui/components/circle-spinner/usage.gts +48 -0
- package/bundled-types/boxel-ui/components/color-palette/index.gts +134 -0
- package/bundled-types/boxel-ui/components/color-palette/usage.gts +69 -0
- package/bundled-types/boxel-ui/components/color-picker/index.gts +125 -0
- package/bundled-types/boxel-ui/components/color-picker/usage.gts +56 -0
- package/bundled-types/boxel-ui/components/container/index.gts +67 -0
- package/bundled-types/boxel-ui/components/container/usage.gts +59 -0
- package/bundled-types/boxel-ui/components/context-button/index.gts +184 -0
- package/bundled-types/boxel-ui/components/context-button/usage.gts +125 -0
- package/bundled-types/boxel-ui/components/copy-button/index.gts +79 -0
- package/bundled-types/boxel-ui/components/copy-button/usage.gts +25 -0
- package/bundled-types/boxel-ui/components/date-range-picker/index.gts +211 -0
- package/bundled-types/boxel-ui/components/date-range-picker/setup.gts +11 -0
- package/bundled-types/boxel-ui/components/date-range-picker/usage.gts +52 -0
- package/bundled-types/boxel-ui/components/drag-and-drop/index.gts +256 -0
- package/bundled-types/boxel-ui/components/drag-and-drop/usage.gts +142 -0
- package/bundled-types/boxel-ui/components/dropdown/index.gts +478 -0
- package/bundled-types/boxel-ui/components/dropdown/trigger/index.gts +70 -0
- package/bundled-types/boxel-ui/components/dropdown/trigger/usage.gts +54 -0
- package/bundled-types/boxel-ui/components/dropdown/usage.gts +119 -0
- package/bundled-types/boxel-ui/components/email-input/index.gts +111 -0
- package/bundled-types/boxel-ui/components/email-input/usage.gts +75 -0
- package/bundled-types/boxel-ui/components/entity-icon-display/index.gts +144 -0
- package/bundled-types/boxel-ui/components/entity-icon-display/usage.gts +54 -0
- package/bundled-types/boxel-ui/components/entity-thumbnail-display/index.gts +148 -0
- package/bundled-types/boxel-ui/components/entity-thumbnail-display/usage.gts +76 -0
- package/bundled-types/boxel-ui/components/field-container/index.gts +150 -0
- package/bundled-types/boxel-ui/components/field-container/usage.gts +188 -0
- package/bundled-types/boxel-ui/components/filter-list/index.gts +255 -0
- package/bundled-types/boxel-ui/components/filter-list/usage.gts +153 -0
- package/bundled-types/boxel-ui/components/fitted-card-container/index.gts +66 -0
- package/bundled-types/boxel-ui/components/fitted-card-container/usage.gts +81 -0
- package/bundled-types/boxel-ui/components/grid-container/grid-item-container/index.gts +37 -0
- package/bundled-types/boxel-ui/components/grid-container/index.gts +116 -0
- package/bundled-types/boxel-ui/components/grid-container/usage.gts +105 -0
- package/bundled-types/boxel-ui/components/header/index.gts +101 -0
- package/bundled-types/boxel-ui/components/header/usage.gts +116 -0
- package/bundled-types/boxel-ui/components/icon-button/index.gts +148 -0
- package/bundled-types/boxel-ui/components/icon-button/usage.gts +249 -0
- package/bundled-types/boxel-ui/components/input/index.gts +560 -0
- package/bundled-types/boxel-ui/components/input/usage.gts +449 -0
- package/bundled-types/boxel-ui/components/input-group/accessories/index.gts +191 -0
- package/bundled-types/boxel-ui/components/input-group/controls/index.gts +54 -0
- package/bundled-types/boxel-ui/components/input-group/index.gts +347 -0
- package/bundled-types/boxel-ui/components/input-group/usage.gts +437 -0
- package/bundled-types/boxel-ui/components/kanban/card.gts +89 -0
- package/bundled-types/boxel-ui/components/kanban/column-header.gts +151 -0
- package/bundled-types/boxel-ui/components/kanban/drag.gts +1007 -0
- package/bundled-types/boxel-ui/components/kanban/engine.ts +247 -0
- package/bundled-types/boxel-ui/components/kanban/ghost.gts +64 -0
- package/bundled-types/boxel-ui/components/kanban/index.gts +16 -0
- package/bundled-types/boxel-ui/components/kanban/modifiers.gts +42 -0
- package/bundled-types/boxel-ui/components/kanban/plane-inner.gts +525 -0
- package/bundled-types/boxel-ui/components/kanban/plane.gts +163 -0
- package/bundled-types/boxel-ui/components/kanban/usage.gts +392 -0
- package/bundled-types/boxel-ui/components/label/index.gts +64 -0
- package/bundled-types/boxel-ui/components/loading-indicator/index.gts +78 -0
- package/bundled-types/boxel-ui/components/loading-indicator/usage.gts +72 -0
- package/bundled-types/boxel-ui/components/menu/index.gts +267 -0
- package/bundled-types/boxel-ui/components/menu/usage.gts +100 -0
- package/bundled-types/boxel-ui/components/message/index.gts +146 -0
- package/bundled-types/boxel-ui/components/message/usage.gts +263 -0
- package/bundled-types/boxel-ui/components/modal/index.gts +159 -0
- package/bundled-types/boxel-ui/components/modal/usage.gts +206 -0
- package/bundled-types/boxel-ui/components/multi-select/after-options.gts +59 -0
- package/bundled-types/boxel-ui/components/multi-select/index.gts +230 -0
- package/bundled-types/boxel-ui/components/multi-select/selected-item.gts +91 -0
- package/bundled-types/boxel-ui/components/multi-select/trigger.gts +190 -0
- package/bundled-types/boxel-ui/components/multi-select/usage.gts +420 -0
- package/bundled-types/boxel-ui/components/phone-input/index.gts +149 -0
- package/bundled-types/boxel-ui/components/phone-input/usage.gts +73 -0
- package/bundled-types/boxel-ui/components/picker/before-options-with-search.gts +340 -0
- package/bundled-types/boxel-ui/components/picker/index.gts +427 -0
- package/bundled-types/boxel-ui/components/picker/option-row.gts +270 -0
- package/bundled-types/boxel-ui/components/picker/selected-item.gts +171 -0
- package/bundled-types/boxel-ui/components/picker/trigger-labeled.gts +216 -0
- package/bundled-types/boxel-ui/components/picker/usage.gts +179 -0
- package/bundled-types/boxel-ui/components/pill/index.gts +231 -0
- package/bundled-types/boxel-ui/components/pill/usage.gts +230 -0
- package/bundled-types/boxel-ui/components/progress-bar/index.gts +124 -0
- package/bundled-types/boxel-ui/components/progress-bar/usage.gts +131 -0
- package/bundled-types/boxel-ui/components/progress-radial/index.gts +95 -0
- package/bundled-types/boxel-ui/components/progress-radial/usage.gts +79 -0
- package/bundled-types/boxel-ui/components/radio-input/index.gts +143 -0
- package/bundled-types/boxel-ui/components/radio-input/item.gts +210 -0
- package/bundled-types/boxel-ui/components/radio-input/usage.gts +303 -0
- package/bundled-types/boxel-ui/components/realm-icon/index.gts +129 -0
- package/bundled-types/boxel-ui/components/realm-icon/usage.gts +62 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/handle.gts +180 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/index.gts +341 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/panel.gts +86 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/usage.gts +350 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/adjust-layout-by-delta.ts +231 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/assert.ts +10 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/calculate-delta-percentage.ts +41 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/calculate-unsafe-default-layout.ts +53 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/compare-layouts.ts +12 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/const.ts +6 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/determine-pivot-indices.ts +15 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/dom/get-panel-element.ts +10 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/dom/get-panel-elements-for-group.ts +8 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/dom/get-panel-group-element.ts +21 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/dom/get-resize-handle-element-index.ts +14 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/dom/get-resize-handle-element.ts +12 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/dom/get-resize-handle-elements-for-group.ts +10 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/fuzzy-layouts-equal.ts +22 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/fuzzy-numbers.ts +21 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/get-resize-event-coordinates.ts +8 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/get-resize-event-cursor-position.ts +10 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/panel-resize-handle-registry.ts +446 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/resize-panel.ts +35 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/types.ts +23 -0
- package/bundled-types/boxel-ui/components/resizable-panel-group/utils/validate-panel-group-layout.ts +86 -0
- package/bundled-types/boxel-ui/components/select/index.gts +882 -0
- package/bundled-types/boxel-ui/components/select/trigger.gts +132 -0
- package/bundled-types/boxel-ui/components/select/usage.gts +353 -0
- package/bundled-types/boxel-ui/components/skeleton-placeholder/index.gts +89 -0
- package/bundled-types/boxel-ui/components/skeleton-placeholder/usage.gts +102 -0
- package/bundled-types/boxel-ui/components/sort-dropdown/index.gts +91 -0
- package/bundled-types/boxel-ui/components/sort-dropdown/usage.gts +77 -0
- package/bundled-types/boxel-ui/components/swatch/index.gts +81 -0
- package/bundled-types/boxel-ui/components/swatch/usage.gts +57 -0
- package/bundled-types/boxel-ui/components/switch/index.gts +95 -0
- package/bundled-types/boxel-ui/components/switch/usage.gts +79 -0
- package/bundled-types/boxel-ui/components/tabbed-header/index.gts +141 -0
- package/bundled-types/boxel-ui/components/tabbed-header/usage.gts +103 -0
- package/bundled-types/boxel-ui/components/tag/index.gts +50 -0
- package/bundled-types/boxel-ui/components/tag/usage.gts +89 -0
- package/bundled-types/boxel-ui/components/tag-list/index.gts +85 -0
- package/bundled-types/boxel-ui/components/tag-list/usage.gts +129 -0
- package/bundled-types/boxel-ui/components/tooltip/index.gts +306 -0
- package/bundled-types/boxel-ui/components/tooltip/usage.gts +168 -0
- package/bundled-types/boxel-ui/components/view-selector/index.gts +166 -0
- package/bundled-types/boxel-ui/components/view-selector/usage.gts +149 -0
- package/bundled-types/boxel-ui/components.ts +169 -0
- package/bundled-types/boxel-ui/helpers/add-class-to-svg.ts +8 -0
- package/bundled-types/boxel-ui/helpers/clipboard.ts +21 -0
- package/bundled-types/boxel-ui/helpers/cn.ts +12 -0
- package/bundled-types/boxel-ui/helpers/color-tools.ts +331 -0
- package/bundled-types/boxel-ui/helpers/compact.ts +3 -0
- package/bundled-types/boxel-ui/helpers/contrast-color.ts +32 -0
- package/bundled-types/boxel-ui/helpers/css-var.ts +41 -0
- package/bundled-types/boxel-ui/helpers/currency-format.ts +25 -0
- package/bundled-types/boxel-ui/helpers/dayjs-format.ts +27 -0
- package/bundled-types/boxel-ui/helpers/deterministic-color-from-string.ts +45 -0
- package/bundled-types/boxel-ui/helpers/element.ts +16 -0
- package/bundled-types/boxel-ui/helpers/extract-css-variables.ts +126 -0
- package/bundled-types/boxel-ui/helpers/format-age.ts +72 -0
- package/bundled-types/boxel-ui/helpers/format-countdown.ts +110 -0
- package/bundled-types/boxel-ui/helpers/format-currency.ts +95 -0
- package/bundled-types/boxel-ui/helpers/format-date-time.ts +567 -0
- package/bundled-types/boxel-ui/helpers/format-duration.ts +143 -0
- package/bundled-types/boxel-ui/helpers/format-file-size.ts +49 -0
- package/bundled-types/boxel-ui/helpers/format-list.ts +73 -0
- package/bundled-types/boxel-ui/helpers/format-names.ts +103 -0
- package/bundled-types/boxel-ui/helpers/format-number.ts +140 -0
- package/bundled-types/boxel-ui/helpers/format-ordinal.ts +115 -0
- package/bundled-types/boxel-ui/helpers/format-period.ts +188 -0
- package/bundled-types/boxel-ui/helpers/format-relative-time.ts +789 -0
- package/bundled-types/boxel-ui/helpers/generate-css-variables.ts +47 -0
- package/bundled-types/boxel-ui/helpers/markdown-escape.ts +36 -0
- package/bundled-types/boxel-ui/helpers/math-helpers.ts +18 -0
- package/bundled-types/boxel-ui/helpers/menu-divider.ts +15 -0
- package/bundled-types/boxel-ui/helpers/menu-item.ts +76 -0
- package/bundled-types/boxel-ui/helpers/optional.ts +7 -0
- package/bundled-types/boxel-ui/helpers/pick.ts +11 -0
- package/bundled-types/boxel-ui/helpers/sanitize-html.ts +45 -0
- package/bundled-types/boxel-ui/helpers/string.ts +15 -0
- package/bundled-types/boxel-ui/helpers/theme-css.ts +148 -0
- package/bundled-types/boxel-ui/helpers/truth-helpers.ts +48 -0
- package/bundled-types/boxel-ui/helpers/validate-email-format.ts +138 -0
- package/bundled-types/boxel-ui/helpers/validate-phone-format.ts +201 -0
- package/bundled-types/boxel-ui/helpers.ts +134 -0
- package/bundled-types/boxel-ui/icons/ai-bw.gts +22 -0
- package/bundled-types/boxel-ui/icons/arrow-left.gts +25 -0
- package/bundled-types/boxel-ui/icons/arrow-right.gts +28 -0
- package/bundled-types/boxel-ui/icons/arrow-top-left.gts +22 -0
- package/bundled-types/boxel-ui/icons/arrow-up.gts +25 -0
- package/bundled-types/boxel-ui/icons/atom.gts +26 -0
- package/bundled-types/boxel-ui/icons/boxel-icon-with-text.gts +29 -0
- package/bundled-types/boxel-ui/icons/boxel-icon.gts +34 -0
- package/bundled-types/boxel-ui/icons/card-definition.gts +26 -0
- package/bundled-types/boxel-ui/icons/card-instance.gts +26 -0
- package/bundled-types/boxel-ui/icons/card.gts +24 -0
- package/bundled-types/boxel-ui/icons/cardbot-lg.gts +24 -0
- package/bundled-types/boxel-ui/icons/caret-down.gts +23 -0
- package/bundled-types/boxel-ui/icons/caret-up.gts +23 -0
- package/bundled-types/boxel-ui/icons/check-mark.gts +23 -0
- package/bundled-types/boxel-ui/icons/chevron-right.gts +23 -0
- package/bundled-types/boxel-ui/icons/copy.gts +28 -0
- package/bundled-types/boxel-ui/icons/diagonal-arrow-left-up.gts +21 -0
- package/bundled-types/boxel-ui/icons/download.gts +19 -0
- package/bundled-types/boxel-ui/icons/dropdown-arrow-down.gts +20 -0
- package/bundled-types/boxel-ui/icons/dropdown-arrow-filled.gts +19 -0
- package/bundled-types/boxel-ui/icons/dropdown-arrow-up.gts +20 -0
- package/bundled-types/boxel-ui/icons/edit.gts +14 -0
- package/bundled-types/boxel-ui/icons/embedded.gts +34 -0
- package/bundled-types/boxel-ui/icons/exclamation-circle.gts +26 -0
- package/bundled-types/boxel-ui/icons/exclamation.gts +20 -0
- package/bundled-types/boxel-ui/icons/eye.gts +19 -0
- package/bundled-types/boxel-ui/icons/failure-bordered.gts +26 -0
- package/bundled-types/boxel-ui/icons/field.gts +26 -0
- package/bundled-types/boxel-ui/icons/file-alert.gts +28 -0
- package/bundled-types/boxel-ui/icons/file.gts +27 -0
- package/bundled-types/boxel-ui/icons/fitted.gts +42 -0
- package/bundled-types/boxel-ui/icons/folder.gts +26 -0
- package/bundled-types/boxel-ui/icons/form.gts +38 -0
- package/bundled-types/boxel-ui/icons/four-lines.gts +21 -0
- package/bundled-types/boxel-ui/icons/grid-3x3.gts +26 -0
- package/bundled-types/boxel-ui/icons/group.gts +22 -0
- package/bundled-types/boxel-ui/icons/head.gts +28 -0
- package/bundled-types/boxel-ui/icons/highlight-icon.gts +46 -0
- package/bundled-types/boxel-ui/icons/icon-circle-selected.gts +25 -0
- package/bundled-types/boxel-ui/icons/icon-circle.gts +25 -0
- package/bundled-types/boxel-ui/icons/icon-code.gts +22 -0
- package/bundled-types/boxel-ui/icons/icon-funnel.gts +23 -0
- package/bundled-types/boxel-ui/icons/icon-globe.gts +19 -0
- package/bundled-types/boxel-ui/icons/icon-grid.gts +68 -0
- package/bundled-types/boxel-ui/icons/icon-hexagon.gts +22 -0
- package/bundled-types/boxel-ui/icons/icon-inherit.gts +19 -0
- package/bundled-types/boxel-ui/icons/icon-link.gts +20 -0
- package/bundled-types/boxel-ui/icons/icon-list.gts +40 -0
- package/bundled-types/boxel-ui/icons/icon-minus-circle.gts +26 -0
- package/bundled-types/boxel-ui/icons/icon-pencil-crossed-out.gts +33 -0
- package/bundled-types/boxel-ui/icons/icon-pencil-not-crossed-out.gts +21 -0
- package/bundled-types/boxel-ui/icons/icon-pencil.gts +23 -0
- package/bundled-types/boxel-ui/icons/icon-plus-circle.gts +31 -0
- package/bundled-types/boxel-ui/icons/icon-plus-thin.gts +19 -0
- package/bundled-types/boxel-ui/icons/icon-plus.gts +20 -0
- package/bundled-types/boxel-ui/icons/icon-search-thick.gts +27 -0
- package/bundled-types/boxel-ui/icons/icon-search.gts +25 -0
- package/bundled-types/boxel-ui/icons/icon-table.gts +44 -0
- package/bundled-types/boxel-ui/icons/icon-trash.gts +24 -0
- package/bundled-types/boxel-ui/icons/icon-turn-down-right.gts +18 -0
- package/bundled-types/boxel-ui/icons/icon-x.gts +21 -0
- package/bundled-types/boxel-ui/icons/image-placeholder.gts +30 -0
- package/bundled-types/boxel-ui/icons/isolated.gts +20 -0
- package/bundled-types/boxel-ui/icons/loading-indicator.gts +26 -0
- package/bundled-types/boxel-ui/icons/lock.gts +23 -0
- package/bundled-types/boxel-ui/icons/markdown.gts +19 -0
- package/bundled-types/boxel-ui/icons/profile.gts +23 -0
- package/bundled-types/boxel-ui/icons/publish-site-icon.gts +25 -0
- package/bundled-types/boxel-ui/icons/rows-4.gts +26 -0
- package/bundled-types/boxel-ui/icons/select-all.gts +25 -0
- package/bundled-types/boxel-ui/icons/send.gts +21 -0
- package/bundled-types/boxel-ui/icons/sparkle.gts +21 -0
- package/bundled-types/boxel-ui/icons/star-filled.gts +25 -0
- package/bundled-types/boxel-ui/icons/star-half-fill.gts +27 -0
- package/bundled-types/boxel-ui/icons/star.gts +25 -0
- package/bundled-types/boxel-ui/icons/success-bordered.gts +30 -0
- package/bundled-types/boxel-ui/icons/three-dots-horizontal.gts +21 -0
- package/bundled-types/boxel-ui/icons/triangle-left.gts +23 -0
- package/bundled-types/boxel-ui/icons/triangle-right.gts +23 -0
- package/bundled-types/boxel-ui/icons/types.ts +10 -0
- package/bundled-types/boxel-ui/icons/upload.gts +20 -0
- package/bundled-types/boxel-ui/icons/warning.gts +19 -0
- package/bundled-types/boxel-ui/icons.gts +249 -0
- package/bundled-types/boxel-ui/modifiers/auto-focus.ts +7 -0
- package/bundled-types/boxel-ui/modifiers/set-css-var.ts +24 -0
- package/bundled-types/boxel-ui/modifiers.ts +14 -0
- package/bundled-types/boxel-ui/types/@cardstack/boxel-ui/index.d.ts +3 -0
- package/bundled-types/boxel-ui/types/ember-css-url/index.d.ts +15 -0
- package/bundled-types/boxel-ui/types/ember-draggable-modifiers/index.d.ts +109 -0
- package/bundled-types/boxel-ui/types/ember-draggable-modifiers/utils.d.ts +7 -0
- package/bundled-types/boxel-ui/types/ember-focus-trap/index.d.ts +20 -0
- package/bundled-types/boxel-ui/types/ember-power-calendar/components/index.d.ts +9 -0
- package/bundled-types/boxel-ui/types/ember-resize-modifier/index.d.ts +14 -0
- package/bundled-types/boxel-ui/types/ember-set-body-class/index.d.ts +12 -0
- package/bundled-types/boxel-ui/types/ember-sortable/index.d.ts +52 -0
- package/bundled-types/boxel-ui/types/global.d.ts +7 -0
- package/bundled-types/boxel-ui/usage.ts +112 -0
- package/bundled-types/boxel-ui/utils/date-utils.ts +192 -0
- package/bundled-types/boxel-ui/utils/fitted-formats.ts +161 -0
- package/bundled-types/host-app/app.ts +22 -0
- package/bundled-types/host-app/commands/add-field-to-card-definition.ts +74 -0
- package/bundled-types/host-app/commands/ai-assistant.ts +203 -0
- package/bundled-types/host-app/commands/apply-markdown-edit.ts +203 -0
- package/bundled-types/host-app/commands/apply-search-replace-block.ts +225 -0
- package/bundled-types/host-app/commands/ask-ai.ts +66 -0
- package/bundled-types/host-app/commands/authed-fetch.ts +53 -0
- package/bundled-types/host-app/commands/bot-requests/create-listing-pr-request.ts +77 -0
- package/bundled-types/host-app/commands/bot-requests/send-bot-trigger-event.ts +53 -0
- package/bundled-types/host-app/commands/can-read-realm.ts +34 -0
- package/bundled-types/host-app/commands/cancel-indexing-job.ts +29 -0
- package/bundled-types/host-app/commands/check-correctness.ts +309 -0
- package/bundled-types/host-app/commands/copy-and-edit.ts +311 -0
- package/bundled-types/host-app/commands/copy-card-as-markdown.ts +41 -0
- package/bundled-types/host-app/commands/copy-card-to-stack.ts +70 -0
- package/bundled-types/host-app/commands/copy-card.ts +67 -0
- package/bundled-types/host-app/commands/copy-file-to-realm.ts +82 -0
- package/bundled-types/host-app/commands/copy-source.ts +46 -0
- package/bundled-types/host-app/commands/create-ai-assistant-room.ts +144 -0
- package/bundled-types/host-app/commands/create-and-open-submission-workflow-card.ts +30 -0
- package/bundled-types/host-app/commands/create-specs.ts +422 -0
- package/bundled-types/host-app/commands/create-submission-workflow.ts +172 -0
- package/bundled-types/host-app/commands/evaluate-module.ts +119 -0
- package/bundled-types/host-app/commands/execute-atomic-operations.ts +44 -0
- package/bundled-types/host-app/commands/fetch-card-json.ts +33 -0
- package/bundled-types/host-app/commands/full-reindex-realm.ts +30 -0
- package/bundled-types/host-app/commands/generate-example-cards.ts +298 -0
- package/bundled-types/host-app/commands/generate-readme-spec.ts +116 -0
- package/bundled-types/host-app/commands/generate-theme-example.ts +147 -0
- package/bundled-types/host-app/commands/generate-thumbnail.ts +247 -0
- package/bundled-types/host-app/commands/get-all-realm-metas.ts +38 -0
- package/bundled-types/host-app/commands/get-available-realm-identifiers.ts +29 -0
- package/bundled-types/host-app/commands/get-card-type-schema.ts +59 -0
- package/bundled-types/host-app/commands/get-card.ts +34 -0
- package/bundled-types/host-app/commands/get-catalog-realm-identifiers.ts +29 -0
- package/bundled-types/host-app/commands/get-default-writable-realm.ts +28 -0
- package/bundled-types/host-app/commands/get-events-from-room.ts +70 -0
- package/bundled-types/host-app/commands/get-realm-of-resource-identifier.ts +37 -0
- package/bundled-types/host-app/commands/get-user-system-card.ts +38 -0
- package/bundled-types/host-app/commands/index.ts +590 -0
- package/bundled-types/host-app/commands/instantiate-card.ts +185 -0
- package/bundled-types/host-app/commands/invalidate-realm-identifiers.ts +33 -0
- package/bundled-types/host-app/commands/invite-user-to-room.ts +34 -0
- package/bundled-types/host-app/commands/lint-and-fix.ts +60 -0
- package/bundled-types/host-app/commands/listing-action-build.ts +79 -0
- package/bundled-types/host-app/commands/listing-action-init.ts +106 -0
- package/bundled-types/host-app/commands/listing-create.ts +632 -0
- package/bundled-types/host-app/commands/listing-generate-example.ts +83 -0
- package/bundled-types/host-app/commands/listing-install.ts +227 -0
- package/bundled-types/host-app/commands/listing-remix.ts +150 -0
- package/bundled-types/host-app/commands/listing-update-specs.ts +116 -0
- package/bundled-types/host-app/commands/listing-use.ts +97 -0
- package/bundled-types/host-app/commands/one-shot-llm-request.ts +209 -0
- package/bundled-types/host-app/commands/open-ai-assistant-room.ts +38 -0
- package/bundled-types/host-app/commands/open-create-listing-modal.ts +52 -0
- package/bundled-types/host-app/commands/open-in-interact-mode.ts +36 -0
- package/bundled-types/host-app/commands/open-workspace.ts +38 -0
- package/bundled-types/host-app/commands/patch-card-instance.ts +108 -0
- package/bundled-types/host-app/commands/patch-code.ts +243 -0
- package/bundled-types/host-app/commands/patch-fields.ts +304 -0
- package/bundled-types/host-app/commands/patch-theme.ts +52 -0
- package/bundled-types/host-app/commands/persist-module-inspector-view.ts +41 -0
- package/bundled-types/host-app/commands/populate-with-sample-data.ts +84 -0
- package/bundled-types/host-app/commands/preview-format.ts +52 -0
- package/bundled-types/host-app/commands/read-binary-file.ts +62 -0
- package/bundled-types/host-app/commands/read-card-for-ai-assistant.ts +50 -0
- package/bundled-types/host-app/commands/read-file-for-ai-assistant.ts +46 -0
- package/bundled-types/host-app/commands/read-source.ts +46 -0
- package/bundled-types/host-app/commands/read-text-file.ts +44 -0
- package/bundled-types/host-app/commands/register-bot.ts +42 -0
- package/bundled-types/host-app/commands/reindex-realm.ts +30 -0
- package/bundled-types/host-app/commands/retry-submission-workflow.ts +119 -0
- package/bundled-types/host-app/commands/sanitize-module-list.ts +83 -0
- package/bundled-types/host-app/commands/save-card.ts +44 -0
- package/bundled-types/host-app/commands/screenshot-card.ts +148 -0
- package/bundled-types/host-app/commands/search-and-choose.ts +180 -0
- package/bundled-types/host-app/commands/search-cards.ts +102 -0
- package/bundled-types/host-app/commands/search-google-images.ts +100 -0
- package/bundled-types/host-app/commands/send-ai-assistant-message.ts +122 -0
- package/bundled-types/host-app/commands/send-request-via-proxy.ts +70 -0
- package/bundled-types/host-app/commands/serialize-card.ts +45 -0
- package/bundled-types/host-app/commands/set-active-llm.ts +39 -0
- package/bundled-types/host-app/commands/set-user-system-card.ts +29 -0
- package/bundled-types/host-app/commands/show-card.ts +102 -0
- package/bundled-types/host-app/commands/show-file.ts +39 -0
- package/bundled-types/host-app/commands/store-add.ts +37 -0
- package/bundled-types/host-app/commands/summarize-session.ts +82 -0
- package/bundled-types/host-app/commands/switch-submode.ts +112 -0
- package/bundled-types/host-app/commands/sync-openrouter-models.ts +373 -0
- package/bundled-types/host-app/commands/transform-cards.ts +59 -0
- package/bundled-types/host-app/commands/unregister-bot.ts +29 -0
- package/bundled-types/host-app/commands/update-code-path-with-selection.ts +45 -0
- package/bundled-types/host-app/commands/update-playground-selection.ts +37 -0
- package/bundled-types/host-app/commands/update-room-skills.ts +231 -0
- package/bundled-types/host-app/commands/utils.ts +178 -0
- package/bundled-types/host-app/commands/validate-realm.ts +40 -0
- package/bundled-types/host-app/commands/write-binary-file.ts +142 -0
- package/bundled-types/host-app/commands/write-text-file.ts +104 -0
- package/bundled-types/host-app/components/.gitkeep +0 -0
- package/bundled-types/host-app/components/ai-assistant/action-bar.gts +188 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-button-active-bg.webp +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-button-active-bg@2x.webp +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-button-active-bg@3x.webp +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-icon-animated.webp +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-icon-bw.png +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-icon-bw@2x.png +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-icon-bw@3x.png +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-icon.webp +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-icon@2x.webp +0 -0
- package/bundled-types/host-app/components/ai-assistant/ai-assist-icon@3x.webp +0 -0
- package/bundled-types/host-app/components/ai-assistant/apply-button/index.gts +226 -0
- package/bundled-types/host-app/components/ai-assistant/apply-button/usage.gts +81 -0
- package/bundled-types/host-app/components/ai-assistant/attached-file-dropdown-menu.gts +179 -0
- package/bundled-types/host-app/components/ai-assistant/attachment-picker/attach-button.gts +176 -0
- package/bundled-types/host-app/components/ai-assistant/attachment-picker/attached-items.gts +271 -0
- package/bundled-types/host-app/components/ai-assistant/attachment-picker/index.gts +144 -0
- package/bundled-types/host-app/components/ai-assistant/attachment-picker/usage.gts +127 -0
- package/bundled-types/host-app/components/ai-assistant/button.gts +60 -0
- package/bundled-types/host-app/components/ai-assistant/chat-input/index.gts +203 -0
- package/bundled-types/host-app/components/ai-assistant/chat-input/usage.gts +68 -0
- package/bundled-types/host-app/components/ai-assistant/code-block/actions.gts +58 -0
- package/bundled-types/host-app/components/ai-assistant/code-block/apply-code-patch-button.gts +66 -0
- package/bundled-types/host-app/components/ai-assistant/code-block/command-header.gts +115 -0
- package/bundled-types/host-app/components/ai-assistant/code-block/diff-editor-header.gts +209 -0
- package/bundled-types/host-app/components/ai-assistant/code-block/index.gts +228 -0
- package/bundled-types/host-app/components/ai-assistant/code-block/patch-footer.gts +32 -0
- package/bundled-types/host-app/components/ai-assistant/code-block/view-code-button.gts +73 -0
- package/bundled-types/host-app/components/ai-assistant/focus-pill/index.gts +60 -0
- package/bundled-types/host-app/components/ai-assistant/focus-pill/usage.gts +45 -0
- package/bundled-types/host-app/components/ai-assistant/llm-mode-toggle.gts +113 -0
- package/bundled-types/host-app/components/ai-assistant/llm-select.gts +158 -0
- package/bundled-types/host-app/components/ai-assistant/message/aibot-message.gts +374 -0
- package/bundled-types/host-app/components/ai-assistant/message/attachments.gts +153 -0
- package/bundled-types/host-app/components/ai-assistant/message/index.gts +678 -0
- package/bundled-types/host-app/components/ai-assistant/message/meta.gts +66 -0
- package/bundled-types/host-app/components/ai-assistant/message/text-content.gts +32 -0
- package/bundled-types/host-app/components/ai-assistant/message/usage.gts +182 -0
- package/bundled-types/host-app/components/ai-assistant/message/user-message.gts +52 -0
- package/bundled-types/host-app/components/ai-assistant/new-session-button.gts +126 -0
- package/bundled-types/host-app/components/ai-assistant/new-session-settings.gts +180 -0
- package/bundled-types/host-app/components/ai-assistant/new-session.gts +83 -0
- package/bundled-types/host-app/components/ai-assistant/panel-popover.gts +102 -0
- package/bundled-types/host-app/components/ai-assistant/panel.gts +453 -0
- package/bundled-types/host-app/components/ai-assistant/past-session-item.gts +323 -0
- package/bundled-types/host-app/components/ai-assistant/past-sessions.gts +115 -0
- package/bundled-types/host-app/components/ai-assistant/rename-session.gts +144 -0
- package/bundled-types/host-app/components/ai-assistant/restore-file-modal.gts +105 -0
- package/bundled-types/host-app/components/ai-assistant/skill-menu/index.gts +190 -0
- package/bundled-types/host-app/components/ai-assistant/skill-menu/skill-toggle.gts +168 -0
- package/bundled-types/host-app/components/ai-assistant/skill-menu/usage.gts +48 -0
- package/bundled-types/host-app/components/ai-assistant/toast.gts +293 -0
- package/bundled-types/host-app/components/card-catalog/modal.gts +579 -0
- package/bundled-types/host-app/components/card-error.gts +41 -0
- package/bundled-types/host-app/components/card-instance-picker/index.gts +54 -0
- package/bundled-types/host-app/components/card-pill.gts +189 -0
- package/bundled-types/host-app/components/card-prerender.gts +880 -0
- package/bundled-types/host-app/components/card-renderer.gts +84 -0
- package/bundled-types/host-app/components/card-search/constants.ts +76 -0
- package/bundled-types/host-app/components/card-search/item-button.gts +243 -0
- package/bundled-types/host-app/components/card-search/panel.gts +150 -0
- package/bundled-types/host-app/components/card-search/search-bar.gts +218 -0
- package/bundled-types/host-app/components/card-search/search-content.gts +604 -0
- package/bundled-types/host-app/components/card-search/search-result-header.gts +165 -0
- package/bundled-types/host-app/components/card-search/search-result-section.gts +545 -0
- package/bundled-types/host-app/components/card-search/section-header.gts +117 -0
- package/bundled-types/host-app/components/editor/directory.gts +308 -0
- package/bundled-types/host-app/components/editor/file-tree.gts +69 -0
- package/bundled-types/host-app/components/editor/import-module.gts +27 -0
- package/bundled-types/host-app/components/editor/indexed-file-tree.gts +572 -0
- package/bundled-types/host-app/components/editor/recent-files.gts +141 -0
- package/bundled-types/host-app/components/file-pill.gts +206 -0
- package/bundled-types/host-app/components/head-format-preview.gts +781 -0
- package/bundled-types/host-app/components/host-mode/breadcrumb-item.gts +150 -0
- package/bundled-types/host-app/components/host-mode/breadcrumbs.gts +131 -0
- package/bundled-types/host-app/components/host-mode/card.gts +199 -0
- package/bundled-types/host-app/components/host-mode/content.gts +195 -0
- package/bundled-types/host-app/components/host-mode/stack-item.gts +310 -0
- package/bundled-types/host-app/components/host-mode/stack.gts +91 -0
- package/bundled-types/host-app/components/matrix/auth-container.gts +66 -0
- package/bundled-types/host-app/components/matrix/auth.gts +73 -0
- package/bundled-types/host-app/components/matrix/forgot-password.gts +487 -0
- package/bundled-types/host-app/components/matrix/login.gts +241 -0
- package/bundled-types/host-app/components/matrix/register-user.gts +843 -0
- package/bundled-types/host-app/components/matrix/room-message-command.gts +330 -0
- package/bundled-types/host-app/components/matrix/room-message.gts +261 -0
- package/bundled-types/host-app/components/matrix/room.gts +1872 -0
- package/bundled-types/host-app/components/matrix/user-profile.gts +99 -0
- package/bundled-types/host-app/components/modal-container.gts +171 -0
- package/bundled-types/host-app/components/operator-mode/binary-file-info.gts +77 -0
- package/bundled-types/host-app/components/operator-mode/card-adoption-chain.gts +99 -0
- package/bundled-types/host-app/components/operator-mode/card-error-detail.gts +87 -0
- package/bundled-types/host-app/components/operator-mode/card-error.gts +177 -0
- package/bundled-types/host-app/components/operator-mode/card-schema-editor.gts +616 -0
- package/bundled-types/host-app/components/operator-mode/card-url-bar.gts +197 -0
- package/bundled-types/host-app/components/operator-mode/choose-file-modal.gts +562 -0
- package/bundled-types/host-app/components/operator-mode/choose-subscription-plan-modal.gts +517 -0
- package/bundled-types/host-app/components/operator-mode/code-editor.gts +736 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/editor-indicator.gts +128 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/format-chooser.gts +589 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/inner-container.gts +162 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/left-panel-toggle.gts +267 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/module-inspector.gts +836 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/playground/field-chooser-modal.gts +97 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/playground/instance-chooser-dropdown.gts +346 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/playground/playground-background.png +0 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/playground/playground-panel.gts +1274 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/playground/playground-preview.gts +155 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/playground/playground.gts +98 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/playground/spec-search.gts +70 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/schema-editor.gts +205 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/spec-preview-badge.gts +72 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/spec-preview.gts +432 -0
- package/bundled-types/host-app/components/operator-mode/code-submode/toggle-button.gts +72 -0
- package/bundled-types/host-app/components/operator-mode/code-submode.gts +1030 -0
- package/bundled-types/host-app/components/operator-mode/container.gts +270 -0
- package/bundled-types/host-app/components/operator-mode/context-menu-button.gts +95 -0
- package/bundled-types/host-app/components/operator-mode/copy-button.gts +277 -0
- package/bundled-types/host-app/components/operator-mode/create-file-modal.gts +1087 -0
- package/bundled-types/host-app/components/operator-mode/create-listing-modal.gts +513 -0
- package/bundled-types/host-app/components/operator-mode/definition-container/base.gts +222 -0
- package/bundled-types/host-app/components/operator-mode/definition-container/clickable.gts +59 -0
- package/bundled-types/host-app/components/operator-mode/definition-container/divider.gts +48 -0
- package/bundled-types/host-app/components/operator-mode/definition-container/index.gts +108 -0
- package/bundled-types/host-app/components/operator-mode/delete-modal.gts +123 -0
- package/bundled-types/host-app/components/operator-mode/detail-panel-selector.gts +320 -0
- package/bundled-types/host-app/components/operator-mode/detail-panel.gts +834 -0
- package/bundled-types/host-app/components/operator-mode/edit-field-modal.gts +450 -0
- package/bundled-types/host-app/components/operator-mode/error-display.gts +590 -0
- package/bundled-types/host-app/components/operator-mode/host-submode/open-site-popover.gts +127 -0
- package/bundled-types/host-app/components/operator-mode/host-submode/publishing-realm-popover.gts +159 -0
- package/bundled-types/host-app/components/operator-mode/host-submode.gts +373 -0
- package/bundled-types/host-app/components/operator-mode/interact-submode/neighbor-stack-trigger.gts +116 -0
- package/bundled-types/host-app/components/operator-mode/interact-submode.gts +1021 -0
- package/bundled-types/host-app/components/operator-mode/new-file-button.gts +187 -0
- package/bundled-types/host-app/components/operator-mode/operator-mode-overlays.gts +511 -0
- package/bundled-types/host-app/components/operator-mode/overlays.gts +342 -0
- package/bundled-types/host-app/components/operator-mode/preview-panel/fitted-format-gallery.gts +127 -0
- package/bundled-types/host-app/components/operator-mode/preview-panel/index.gts +443 -0
- package/bundled-types/host-app/components/operator-mode/preview-panel/markdown-preview.gts +175 -0
- package/bundled-types/host-app/components/operator-mode/preview-panel/metadata-panel.gts +214 -0
- package/bundled-types/host-app/components/operator-mode/preview-panel/rendered-markdown.gts +718 -0
- package/bundled-types/host-app/components/operator-mode/private-dependency-violation.gts +70 -0
- package/bundled-types/host-app/components/operator-mode/profile/profile-email.gts +686 -0
- package/bundled-types/host-app/components/operator-mode/profile/profile-settings-modal.gts +454 -0
- package/bundled-types/host-app/components/operator-mode/profile/profile-subscription.gts +170 -0
- package/bundled-types/host-app/components/operator-mode/profile-info-popover.gts +263 -0
- package/bundled-types/host-app/components/operator-mode/publish-realm-modal.gts +1529 -0
- package/bundled-types/host-app/components/operator-mode/remove-field-modal.gts +135 -0
- package/bundled-types/host-app/components/operator-mode/send-error-to-ai-assistant.gts +195 -0
- package/bundled-types/host-app/components/operator-mode/stack-item.gts +1341 -0
- package/bundled-types/host-app/components/operator-mode/stack.gts +191 -0
- package/bundled-types/host-app/components/operator-mode/submode-layout.gts +781 -0
- package/bundled-types/host-app/components/operator-mode/syntax-error-display.gts +72 -0
- package/bundled-types/host-app/components/operator-mode/workspace-chooser/add-workspace.gts +282 -0
- package/bundled-types/host-app/components/operator-mode/workspace-chooser/index.gts +299 -0
- package/bundled-types/host-app/components/operator-mode/workspace-chooser/item-container.gts +50 -0
- package/bundled-types/host-app/components/operator-mode/workspace-chooser/workspace-loading-indicator.gts +50 -0
- package/bundled-types/host-app/components/operator-mode/workspace-chooser/workspace.gts +1079 -0
- package/bundled-types/host-app/components/pill-menu/index.gts +281 -0
- package/bundled-types/host-app/components/pill-menu/usage.gts +64 -0
- package/bundled-types/host-app/components/prerendered-card-search.gts +274 -0
- package/bundled-types/host-app/components/realm-dropdown.gts +209 -0
- package/bundled-types/host-app/components/realm-picker/index.gts +142 -0
- package/bundled-types/host-app/components/search-sheet/index.gts +426 -0
- package/bundled-types/host-app/components/search-sheet/usage.gts +99 -0
- package/bundled-types/host-app/components/submode-switcher.gts +260 -0
- package/bundled-types/host-app/components/type-picker/index.gts +111 -0
- package/bundled-types/host-app/components/with-known-realms-loaded.gts +47 -0
- package/bundled-types/host-app/components/with-loaded-realm.gts +39 -0
- package/bundled-types/host-app/components/with-subscription-data.gts +247 -0
- package/bundled-types/host-app/config/environment.ts +66 -0
- package/bundled-types/host-app/deprecation-workflow.js +30 -0
- package/bundled-types/host-app/lib/browser-queue.ts +198 -0
- package/bundled-types/host-app/lib/codemirror-context.ts +1081 -0
- package/bundled-types/host-app/lib/command-definitions.ts +41 -0
- package/bundled-types/host-app/lib/download-realm.ts +9 -0
- package/bundled-types/host-app/lib/example-card-helpers.ts +99 -0
- package/bundled-types/host-app/lib/externals.ts +247 -0
- package/bundled-types/host-app/lib/field-path-parser.ts +520 -0
- package/bundled-types/host-app/lib/file-def-manager.ts +712 -0
- package/bundled-types/host-app/lib/file-upload-state.ts +6 -0
- package/bundled-types/host-app/lib/formatted-message/utils.ts +272 -0
- package/bundled-types/host-app/lib/gc-card-store.ts +1084 -0
- package/bundled-types/host-app/lib/host-base-command.ts +29 -0
- package/bundled-types/host-app/lib/html-component.ts +144 -0
- package/bundled-types/host-app/lib/html-to-markdown.ts +96 -0
- package/bundled-types/host-app/lib/isolated-render.gts +90 -0
- package/bundled-types/host-app/lib/known-file-meta-urls.ts +17 -0
- package/bundled-types/host-app/lib/limited-set.ts +68 -0
- package/bundled-types/host-app/lib/matrix-classes/member.ts +28 -0
- package/bundled-types/host-app/lib/matrix-classes/message-builder.ts +444 -0
- package/bundled-types/host-app/lib/matrix-classes/message-code-patch-result.ts +44 -0
- package/bundled-types/host-app/lib/matrix-classes/message-command.ts +109 -0
- package/bundled-types/host-app/lib/matrix-classes/message.ts +239 -0
- package/bundled-types/host-app/lib/matrix-classes/room.ts +174 -0
- package/bundled-types/host-app/lib/matrix-utils.ts +114 -0
- package/bundled-types/host-app/lib/mutex.ts +62 -0
- package/bundled-types/host-app/lib/prerender-fetch-headers.ts +46 -0
- package/bundled-types/host-app/lib/prerender-util.ts +31 -0
- package/bundled-types/host-app/lib/public-path.ts +1 -0
- package/bundled-types/host-app/lib/random-name.ts +26 -0
- package/bundled-types/host-app/lib/realm-utils.ts +45 -0
- package/bundled-types/host-app/lib/search-cache-key.ts +33 -0
- package/bundled-types/host-app/lib/search-in-flight-key.ts +28 -0
- package/bundled-types/host-app/lib/search-replace-block-parsing.ts +101 -0
- package/bundled-types/host-app/lib/setup-globals.ts +15 -0
- package/bundled-types/host-app/lib/sqlite-adapter.ts +510 -0
- package/bundled-types/host-app/lib/stack-item.ts +164 -0
- package/bundled-types/host-app/lib/utils.ts +84 -0
- package/bundled-types/host-app/lib/window-error-handler.ts +132 -0
- package/bundled-types/host-app/router.ts +31 -0
- package/bundled-types/host-app/services/ai-assistant-panel-service.ts +850 -0
- package/bundled-types/host-app/services/billing-service.ts +208 -0
- package/bundled-types/host-app/services/card-service.ts +373 -0
- package/bundled-types/host-app/services/card-type-service.ts +226 -0
- package/bundled-types/host-app/services/code-semantics-service.ts +297 -0
- package/bundled-types/host-app/services/command-service.ts +975 -0
- package/bundled-types/host-app/services/environment-service.ts +26 -0
- package/bundled-types/host-app/services/error-display.ts +42 -0
- package/bundled-types/host-app/services/file-upload.ts +212 -0
- package/bundled-types/host-app/services/host-mode-service.ts +381 -0
- package/bundled-types/host-app/services/host-mode-state-service.ts +160 -0
- package/bundled-types/host-app/services/loader-service.ts +148 -0
- package/bundled-types/host-app/services/local-indexer.ts +68 -0
- package/bundled-types/host-app/services/local-persistence-service.ts +296 -0
- package/bundled-types/host-app/services/logger-service.ts +13 -0
- package/bundled-types/host-app/services/matrix-sdk-loader.ts +346 -0
- package/bundled-types/host-app/services/matrix-service.ts +2287 -0
- package/bundled-types/host-app/services/message-service.ts +84 -0
- package/bundled-types/host-app/services/module-contents-service.ts +333 -0
- package/bundled-types/host-app/services/monaco-service.ts +333 -0
- package/bundled-types/host-app/services/network.ts +101 -0
- package/bundled-types/host-app/services/operator-mode-state-service.ts +1591 -0
- package/bundled-types/host-app/services/playground-panel-service.ts +236 -0
- package/bundled-types/host-app/services/queue.ts +30 -0
- package/bundled-types/host-app/services/realm-info-service.ts +37 -0
- package/bundled-types/host-app/services/realm-server.ts +1209 -0
- package/bundled-types/host-app/services/realm.ts +1413 -0
- package/bundled-types/host-app/services/recent-cards-service.ts +174 -0
- package/bundled-types/host-app/services/recent-files-service.ts +224 -0
- package/bundled-types/host-app/services/render-error-state.ts +55 -0
- package/bundled-types/host-app/services/render-service.ts +362 -0
- package/bundled-types/host-app/services/render-store.ts +27 -0
- package/bundled-types/host-app/services/reset.ts +19 -0
- package/bundled-types/host-app/services/scroll-position-service.ts +81 -0
- package/bundled-types/host-app/services/spec-panel-service.ts +107 -0
- package/bundled-types/host-app/services/store.ts +2540 -0
- package/bundled-types/host-app/utils/assert-never.ts +3 -0
- package/bundled-types/host-app/utils/auth-error-guard.ts +183 -0
- package/bundled-types/host-app/utils/auth-service-worker-registration.ts +123 -0
- package/bundled-types/host-app/utils/card-search/query-builder.ts +169 -0
- package/bundled-types/host-app/utils/card-search/section-pagination.ts +57 -0
- package/bundled-types/host-app/utils/card-search/sections.ts +240 -0
- package/bundled-types/host-app/utils/card-search/type-filter.ts +124 -0
- package/bundled-types/host-app/utils/card-search/types.ts +11 -0
- package/bundled-types/host-app/utils/card-search/url.ts +23 -0
- package/bundled-types/host-app/utils/clipboard.ts +23 -0
- package/bundled-types/host-app/utils/editor/boxel-formatter.ts +65 -0
- package/bundled-types/host-app/utils/editor/editor-language.ts +88 -0
- package/bundled-types/host-app/utils/editor/monaco-test-waiter.ts +302 -0
- package/bundled-types/host-app/utils/file-def-attributes-extractor.ts +438 -0
- package/bundled-types/host-app/utils/file-name.ts +38 -0
- package/bundled-types/host-app/utils/id-from-card-or-url.ts +11 -0
- package/bundled-types/host-app/utils/lint-formatting.ts +57 -0
- package/bundled-types/host-app/utils/local-storage-keys.ts +28 -0
- package/bundled-types/host-app/utils/normalized-dir-path.ts +3 -0
- package/bundled-types/host-app/utils/prettify-messages.ts +21 -0
- package/bundled-types/host-app/utils/prettify-prompts.ts +21 -0
- package/bundled-types/host-app/utils/realm-index-boilerplate.ts +27 -0
- package/bundled-types/host-app/utils/register-boxel-transition.ts +17 -0
- package/bundled-types/host-app/utils/render-desync-detector.ts +362 -0
- package/bundled-types/host-app/utils/render-error.ts +455 -0
- package/bundled-types/host-app/utils/render-timer-stub.ts +249 -0
- package/bundled-types/host-app/utils/run-while-active.ts +14 -0
- package/bundled-types/host-app/utils/schema-editor.ts +25 -0
- package/bundled-types/host-app/utils/text-suggestion.ts +82 -0
- package/bundled-types/host-app/utils/titleize.ts +10 -0
- package/bundled-types/host-app/utils/uuid.ts +13 -0
- package/bundled-types/host-tests/helpers/adapter.ts +464 -0
- package/bundled-types/host-tests/helpers/base-realm.ts +464 -0
- package/bundled-types/host-tests/helpers/cards/view-card-demo.ts +119 -0
- package/bundled-types/host-tests/helpers/field-test-helpers.gts +54 -0
- package/bundled-types/host-tests/helpers/image-fixture.ts +3 -0
- package/bundled-types/host-tests/helpers/index.gts +2099 -0
- package/bundled-types/host-tests/helpers/indexer.ts +293 -0
- package/bundled-types/host-tests/helpers/interact-submode-setup.gts +551 -0
- package/bundled-types/host-tests/helpers/mock-matrix/_client.ts +1042 -0
- package/bundled-types/host-tests/helpers/mock-matrix/_sdk.ts +71 -0
- package/bundled-types/host-tests/helpers/mock-matrix/_server-state.ts +343 -0
- package/bundled-types/host-tests/helpers/mock-matrix/_sliding-sync.ts +140 -0
- package/bundled-types/host-tests/helpers/mock-matrix/_utils.ts +146 -0
- package/bundled-types/host-tests/helpers/mock-matrix.ts +200 -0
- package/bundled-types/host-tests/helpers/operator-mode-parameters-match.ts +71 -0
- package/bundled-types/host-tests/helpers/operator-mode-state.ts +18 -0
- package/bundled-types/host-tests/helpers/percy-snapshot.ts +228 -0
- package/bundled-types/host-tests/helpers/playground.ts +130 -0
- package/bundled-types/host-tests/helpers/realm-server-mock/index.ts +100 -0
- package/bundled-types/host-tests/helpers/realm-server-mock/routes.ts +617 -0
- package/bundled-types/host-tests/helpers/realm-server-mock/types.ts +24 -0
- package/bundled-types/host-tests/helpers/recent-files-cards.ts +86 -0
- package/bundled-types/host-tests/helpers/render-component.ts +40 -0
- package/bundled-types/host-tests/helpers/setup-qunit.js +164 -0
- package/bundled-types/host-tests/helpers/setup.ts +349 -0
- package/bundled-types/host-tests/helpers/shard-warmup.ts +72 -0
- package/bundled-types/host-tests/helpers/stream.ts +60 -0
- package/bundled-types/host-tests/helpers/test-auth.ts +27 -0
- package/bundled-types/host-tests/helpers/test-realm-registry.ts +23 -0
- package/bundled-types/host-tests/helpers/test-realm-service-worker.ts +92 -0
- package/bundled-types/host-tests/helpers/uncaught-exceptions.ts +16 -0
- package/bundled-types/host-tests/helpers/visit-operator-mode.ts +39 -0
- package/bundled-types/host-types/@cardstack/host/index.d.ts +3 -0
- package/bundled-types/host-types/@joplin/turndown-plugin-gfm/index.d.ts +15 -0
- package/bundled-types/host-types/@sqlite.org/sqlite-wasm/index.d.ts +122 -0
- package/bundled-types/host-types/ember-click-outside/modifiers/on-click-outside.ts +16 -0
- package/bundled-types/host-types/ember-concurrency/helpers/perform.d.ts +3 -0
- package/bundled-types/host-types/ember-css-url/index.d.ts +15 -0
- package/bundled-types/host-types/ember-data/types/registries/model.d.ts +6 -0
- package/bundled-types/host-types/ember-elsewhere/from-elsewhere.d.ts +12 -0
- package/bundled-types/host-types/ember-elsewhere/to-elsewhere.d.ts +16 -0
- package/bundled-types/host-types/ember-focus-trap/index.d.ts +4 -0
- package/bundled-types/host-types/ember-keyboard/modifiers/on-key.d.ts +15 -0
- package/bundled-types/host-types/index.d.ts +6 -0
- package/bundled-types/local-types/eslint-js.d.ts +5 -0
- package/bundled-types/local-types/index.d.ts +115 -0
- package/bundled-types/local-types/marked-gfm-heading-id.d.ts +12 -0
- package/bundled-types/local-types/matrix-js-sdk/index.d.ts +11 -0
- package/bundled-types/local-types/package.json +13 -0
- package/bundled-types/shims/boxel-cli-shims.d.ts +10 -0
- package/dist/index.js +100 -100
- package/package.json +13 -7
- package/src/commands/parse.ts +277 -34
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import IconX from '@cardstack/boxel-icons/x';
|
|
2
|
+
import { on } from '@ember/modifier';
|
|
3
|
+
import Component from '@glimmer/component';
|
|
4
|
+
|
|
5
|
+
import cn from '../../helpers/cn.ts';
|
|
6
|
+
import IconButton from '../icon-button/index.gts';
|
|
7
|
+
import BoxelInput from '../input/index.gts';
|
|
8
|
+
import Swatch from '../swatch/index.gts';
|
|
9
|
+
|
|
10
|
+
interface Signature {
|
|
11
|
+
Args: {
|
|
12
|
+
color: string | null;
|
|
13
|
+
disabled?: boolean;
|
|
14
|
+
onChange: (color: string | null) => void;
|
|
15
|
+
placeholder?: string;
|
|
16
|
+
};
|
|
17
|
+
Element: HTMLDivElement;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export default class ColorPicker extends Component<Signature> {
|
|
21
|
+
<template>
|
|
22
|
+
<div class='color-picker' ...attributes>
|
|
23
|
+
<label class={{cn 'color-input-container' disabled=@disabled}}>
|
|
24
|
+
<span class='boxel-sr-only'>Color Picker</span>
|
|
25
|
+
<Swatch
|
|
26
|
+
class='color-preview'
|
|
27
|
+
@color={{@color}}
|
|
28
|
+
@hideLabel={{true}}
|
|
29
|
+
@style='round'
|
|
30
|
+
/>
|
|
31
|
+
<BoxelInput
|
|
32
|
+
type='color'
|
|
33
|
+
@value={{@color}}
|
|
34
|
+
@onInput={{@onChange}}
|
|
35
|
+
@disabled={{@disabled}}
|
|
36
|
+
data-test-color-input
|
|
37
|
+
/>
|
|
38
|
+
</label>
|
|
39
|
+
|
|
40
|
+
<BoxelInput
|
|
41
|
+
class='color-text-input'
|
|
42
|
+
@value={{@color}}
|
|
43
|
+
@onInput={{@onChange}}
|
|
44
|
+
@disabled={{@disabled}}
|
|
45
|
+
@placeholder={{@placeholder}}
|
|
46
|
+
data-test-color-text-input
|
|
47
|
+
/>
|
|
48
|
+
|
|
49
|
+
{{#if @color}}
|
|
50
|
+
{{#unless @disabled}}
|
|
51
|
+
<IconButton
|
|
52
|
+
class='remove'
|
|
53
|
+
@icon={{IconX}}
|
|
54
|
+
@width='16px'
|
|
55
|
+
@height='16px'
|
|
56
|
+
{{on 'click' this.remove}}
|
|
57
|
+
aria-label='Unset color'
|
|
58
|
+
data-test-remove-color
|
|
59
|
+
/>
|
|
60
|
+
{{/unless}}
|
|
61
|
+
{{/if}}
|
|
62
|
+
</div>
|
|
63
|
+
|
|
64
|
+
<style scoped>
|
|
65
|
+
@layer boxelComponentL3 {
|
|
66
|
+
.color-picker {
|
|
67
|
+
--color-picker-width: 2.5rem;
|
|
68
|
+
--color-picker-height: 2.5rem;
|
|
69
|
+
position: relative;
|
|
70
|
+
}
|
|
71
|
+
.color-text-input {
|
|
72
|
+
padding-inline: var(--color-picker-width);
|
|
73
|
+
transition: none;
|
|
74
|
+
}
|
|
75
|
+
.color-input-container {
|
|
76
|
+
position: absolute;
|
|
77
|
+
top: 0;
|
|
78
|
+
left: 0;
|
|
79
|
+
display: flex;
|
|
80
|
+
align-items: center;
|
|
81
|
+
justify-content: center;
|
|
82
|
+
width: var(--color-picker-width);
|
|
83
|
+
height: 100%;
|
|
84
|
+
z-index: 1;
|
|
85
|
+
}
|
|
86
|
+
.color-input-container > :deep(.input-container) {
|
|
87
|
+
visibility: collapse;
|
|
88
|
+
position: absolute;
|
|
89
|
+
top: 0;
|
|
90
|
+
left: 0;
|
|
91
|
+
display: block;
|
|
92
|
+
}
|
|
93
|
+
.color-input-container:not(.disabled):hover {
|
|
94
|
+
cursor: pointer;
|
|
95
|
+
}
|
|
96
|
+
.color-input-container:not(.disabled):hover :deep(.preview) {
|
|
97
|
+
box-shadow: var(--shadow-xs, var(--boxel-box-shadow));
|
|
98
|
+
}
|
|
99
|
+
.remove {
|
|
100
|
+
position: absolute;
|
|
101
|
+
top: 0;
|
|
102
|
+
right: 0;
|
|
103
|
+
display: flex;
|
|
104
|
+
align-items: center;
|
|
105
|
+
justify-content: center;
|
|
106
|
+
width: var(--color-picker-width);
|
|
107
|
+
height: 100%;
|
|
108
|
+
z-index: 1;
|
|
109
|
+
opacity: 0.5;
|
|
110
|
+
}
|
|
111
|
+
.remove:focus,
|
|
112
|
+
.remove:hover {
|
|
113
|
+
opacity: 1;
|
|
114
|
+
outline: 0;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
</style>
|
|
118
|
+
</template>
|
|
119
|
+
|
|
120
|
+
private remove = (ev: Event) => {
|
|
121
|
+
ev.preventDefault();
|
|
122
|
+
ev.stopPropagation();
|
|
123
|
+
this.args.onChange?.(null);
|
|
124
|
+
};
|
|
125
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { fn } from '@ember/helper';
|
|
2
|
+
import Component from '@glimmer/component';
|
|
3
|
+
import { tracked } from '@glimmer/tracking';
|
|
4
|
+
import FreestyleUsage from 'ember-freestyle/components/freestyle/usage';
|
|
5
|
+
|
|
6
|
+
import ColorPicker from './index.gts';
|
|
7
|
+
|
|
8
|
+
export default class ColorPickerUsage extends Component {
|
|
9
|
+
@tracked color: string | null = 'oklch(59.69% 0.56 49.77 / .5)';
|
|
10
|
+
@tracked disabled = false;
|
|
11
|
+
|
|
12
|
+
private onChange = (newColor: string | null) => {
|
|
13
|
+
this.color = newColor;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
<template>
|
|
17
|
+
<FreestyleUsage
|
|
18
|
+
@name='ColorPicker'
|
|
19
|
+
@description='Color input field that allows users to select a color from the color spectrum or type in a color code.'
|
|
20
|
+
>
|
|
21
|
+
<:example>
|
|
22
|
+
<label>
|
|
23
|
+
<span class='boxel-sr-only'>Color</span>
|
|
24
|
+
<ColorPicker
|
|
25
|
+
@color={{this.color}}
|
|
26
|
+
@onChange={{this.onChange}}
|
|
27
|
+
@disabled={{this.disabled}}
|
|
28
|
+
/>
|
|
29
|
+
</label>
|
|
30
|
+
</:example>
|
|
31
|
+
|
|
32
|
+
<:api as |Args|>
|
|
33
|
+
<Args.String
|
|
34
|
+
@name='color'
|
|
35
|
+
@optional={{false}}
|
|
36
|
+
@description='Color value'
|
|
37
|
+
@value={{this.color}}
|
|
38
|
+
@onInput={{fn (mut this.color)}}
|
|
39
|
+
/>
|
|
40
|
+
<Args.Action
|
|
41
|
+
@name='onChange'
|
|
42
|
+
@description='A callback function that is called when the color is changed.'
|
|
43
|
+
@value={{this.onChange}}
|
|
44
|
+
@onInput={{fn (mut this.onChange)}}
|
|
45
|
+
/>
|
|
46
|
+
<Args.Bool
|
|
47
|
+
@name='disabled'
|
|
48
|
+
@description='Whether the color picker is disabled.'
|
|
49
|
+
@value={{this.disabled}}
|
|
50
|
+
@onInput={{fn (mut this.disabled)}}
|
|
51
|
+
@defaultValue={{false}}
|
|
52
|
+
/>
|
|
53
|
+
</:api>
|
|
54
|
+
</FreestyleUsage>
|
|
55
|
+
</template>
|
|
56
|
+
}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import type { TemplateOnlyComponent } from '@ember/component/template-only';
|
|
2
|
+
|
|
3
|
+
import { cn, element, eq } from '../../helpers.ts';
|
|
4
|
+
|
|
5
|
+
export type BoxelContainerDisplayOption =
|
|
6
|
+
| 'default'
|
|
7
|
+
| 'grid'
|
|
8
|
+
| 'inline-grid'
|
|
9
|
+
| 'flex'
|
|
10
|
+
| 'inline-flex';
|
|
11
|
+
|
|
12
|
+
interface Signature {
|
|
13
|
+
Args: {
|
|
14
|
+
display?: BoxelContainerDisplayOption;
|
|
15
|
+
tag?: keyof HTMLElementTagNameMap;
|
|
16
|
+
};
|
|
17
|
+
Blocks: {
|
|
18
|
+
default: [];
|
|
19
|
+
};
|
|
20
|
+
Element: HTMLElement;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const Container: TemplateOnlyComponent<Signature> = <template>
|
|
24
|
+
{{#let (element @tag) as |TagName|}}
|
|
25
|
+
<TagName
|
|
26
|
+
class={{cn
|
|
27
|
+
'boxel-container'
|
|
28
|
+
boxel-grid=(eq @display 'grid')
|
|
29
|
+
boxel-inline-grid=(eq @display 'inline-grid')
|
|
30
|
+
boxel-flex=(eq @display 'flex')
|
|
31
|
+
boxel-inline-flex=(eq @display 'inline-flex')
|
|
32
|
+
}}
|
|
33
|
+
...attributes
|
|
34
|
+
>
|
|
35
|
+
{{yield}}
|
|
36
|
+
</TagName>
|
|
37
|
+
{{/let}}
|
|
38
|
+
<style scoped>
|
|
39
|
+
@layer {
|
|
40
|
+
.boxel-container {
|
|
41
|
+
padding: var(--boxel-container-padding, var(--boxel-sp));
|
|
42
|
+
}
|
|
43
|
+
.boxel-grid {
|
|
44
|
+
display: grid;
|
|
45
|
+
gap: var(--boxel-container-gap, var(--boxel-sp));
|
|
46
|
+
}
|
|
47
|
+
.boxel-inline-grid {
|
|
48
|
+
display: inline-grid;
|
|
49
|
+
gap: var(--boxel-container-gap, var(--boxel-sp));
|
|
50
|
+
}
|
|
51
|
+
.boxel-flex {
|
|
52
|
+
display: flex;
|
|
53
|
+
flex-wrap: wrap;
|
|
54
|
+
gap: var(--boxel-container-gap, var(--boxel-sp));
|
|
55
|
+
align-items: center;
|
|
56
|
+
}
|
|
57
|
+
.boxel-inline-flex {
|
|
58
|
+
display: inline-flex;
|
|
59
|
+
flex-wrap: wrap;
|
|
60
|
+
gap: var(--boxel-container-gap, var(--boxel-sp));
|
|
61
|
+
align-items: center;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
</style>
|
|
65
|
+
</template>;
|
|
66
|
+
|
|
67
|
+
export default Container;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { fn } from '@ember/helper';
|
|
2
|
+
import Component from '@glimmer/component';
|
|
3
|
+
import { tracked } from '@glimmer/tracking';
|
|
4
|
+
import FreestyleUsage from 'ember-freestyle/components/freestyle/usage';
|
|
5
|
+
|
|
6
|
+
import BoxelContainer, { type BoxelContainerDisplayOption } from './index.gts';
|
|
7
|
+
|
|
8
|
+
interface Signature {
|
|
9
|
+
Element: HTMLElement;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export default class BoxelContainerUsage extends Component<Signature> {
|
|
13
|
+
private displayOptions: BoxelContainerDisplayOption[] = [
|
|
14
|
+
'default',
|
|
15
|
+
'grid',
|
|
16
|
+
'inline-grid',
|
|
17
|
+
'flex',
|
|
18
|
+
'inline-flex',
|
|
19
|
+
];
|
|
20
|
+
@tracked private tag?: keyof HTMLElementTagNameMap;
|
|
21
|
+
@tracked private display?: BoxelContainerDisplayOption;
|
|
22
|
+
|
|
23
|
+
<template>
|
|
24
|
+
<FreestyleUsage @name='BoxelContainer'>
|
|
25
|
+
<:description>
|
|
26
|
+
A container that provides standard padding, with options to make it grid
|
|
27
|
+
or flexbox.
|
|
28
|
+
</:description>
|
|
29
|
+
<:example>
|
|
30
|
+
<BoxelContainer
|
|
31
|
+
@display={{this.display}}
|
|
32
|
+
@tag={{if this.tag this.tag 'div'}}
|
|
33
|
+
>
|
|
34
|
+
<h3>h3</h3>
|
|
35
|
+
<p>Hello</p>
|
|
36
|
+
</BoxelContainer>
|
|
37
|
+
</:example>
|
|
38
|
+
<:api as |Args|>
|
|
39
|
+
<Args.String
|
|
40
|
+
@name='tag'
|
|
41
|
+
@description='HTML element tag name (ie. button, section, ul, etc)'
|
|
42
|
+
@value={{this.tag}}
|
|
43
|
+
@defaultValue='div'
|
|
44
|
+
@optional={{true}}
|
|
45
|
+
@onInput={{fn (mut this.tag)}}
|
|
46
|
+
/>
|
|
47
|
+
<Args.String
|
|
48
|
+
@name='display'
|
|
49
|
+
@optional={{true}}
|
|
50
|
+
@description='Css display property for grid, flex, inline-grid, and inline-flex'
|
|
51
|
+
@defaultValue='HTML element default'
|
|
52
|
+
@options={{this.displayOptions}}
|
|
53
|
+
@onInput={{fn (mut this.display)}}
|
|
54
|
+
@value='default'
|
|
55
|
+
/>
|
|
56
|
+
</:api>
|
|
57
|
+
</FreestyleUsage>
|
|
58
|
+
</template>
|
|
59
|
+
}
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import DotsVertical from '@cardstack/boxel-icons/dots-vertical';
|
|
2
|
+
import Plus from '@cardstack/boxel-icons/plus';
|
|
3
|
+
import Trash from '@cardstack/boxel-icons/trash-2';
|
|
4
|
+
import XIcon from '@cardstack/boxel-icons/x';
|
|
5
|
+
import type { TemplateOnlyComponent } from '@ember/component/template-only';
|
|
6
|
+
import { concat } from '@ember/helper';
|
|
7
|
+
|
|
8
|
+
import cn from '../../helpers/cn.ts';
|
|
9
|
+
import { IconPencil, ThreeDotsHorizontal } from '../../icons.gts';
|
|
10
|
+
import type { Icon } from '../../icons/types.ts';
|
|
11
|
+
import type { BoxelButtonSize } from '../button/index.gts';
|
|
12
|
+
import IconButton from '../icon-button/index.gts';
|
|
13
|
+
|
|
14
|
+
export type ContextButtonVariant =
|
|
15
|
+
| 'highlight'
|
|
16
|
+
| 'ghost'
|
|
17
|
+
| 'destructive'
|
|
18
|
+
| 'highlight-icon'
|
|
19
|
+
| 'destructive-icon'
|
|
20
|
+
| 'primary-dark'; // 'highlight' is default
|
|
21
|
+
|
|
22
|
+
export const contextButtonVariants: ContextButtonVariant[] = [
|
|
23
|
+
'highlight',
|
|
24
|
+
'highlight-icon',
|
|
25
|
+
'ghost',
|
|
26
|
+
'destructive',
|
|
27
|
+
'destructive-icon',
|
|
28
|
+
'primary-dark',
|
|
29
|
+
];
|
|
30
|
+
|
|
31
|
+
export type ContextButtonIcon =
|
|
32
|
+
| 'context-menu'
|
|
33
|
+
| 'context-menu-vertical'
|
|
34
|
+
| 'add'
|
|
35
|
+
| 'edit'
|
|
36
|
+
| 'delete'
|
|
37
|
+
| 'close'
|
|
38
|
+
| Icon; // 'context-menu' is default
|
|
39
|
+
|
|
40
|
+
export const contextButtonIconOptions: ContextButtonIcon[] = [
|
|
41
|
+
'context-menu',
|
|
42
|
+
'context-menu-vertical',
|
|
43
|
+
'add',
|
|
44
|
+
'edit',
|
|
45
|
+
'delete',
|
|
46
|
+
'close',
|
|
47
|
+
];
|
|
48
|
+
|
|
49
|
+
interface Signature {
|
|
50
|
+
Args: {
|
|
51
|
+
disabled?: boolean;
|
|
52
|
+
height?: string; // iconHeight
|
|
53
|
+
icon?: ContextButtonIcon; // defaults to horizontal 'content-menu'
|
|
54
|
+
isActive?: boolean;
|
|
55
|
+
isToggle?: boolean;
|
|
56
|
+
label: string; // aria-label for icon button (required)
|
|
57
|
+
loading?: boolean;
|
|
58
|
+
size?: BoxelButtonSize;
|
|
59
|
+
variant?: ContextButtonVariant;
|
|
60
|
+
width?: string; // iconWidth
|
|
61
|
+
};
|
|
62
|
+
Element: HTMLButtonElement | HTMLAnchorElement;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
const getIcon = (icon: ContextButtonIcon = 'context-menu') => {
|
|
66
|
+
if (icon === 'context-menu') {
|
|
67
|
+
return ThreeDotsHorizontal;
|
|
68
|
+
}
|
|
69
|
+
if (icon === 'context-menu-vertical') {
|
|
70
|
+
return DotsVertical;
|
|
71
|
+
}
|
|
72
|
+
if (icon === 'close') {
|
|
73
|
+
return XIcon;
|
|
74
|
+
}
|
|
75
|
+
if (icon === 'add') {
|
|
76
|
+
return Plus;
|
|
77
|
+
}
|
|
78
|
+
if (icon === 'edit') {
|
|
79
|
+
return IconPencil;
|
|
80
|
+
}
|
|
81
|
+
if (icon === 'delete') {
|
|
82
|
+
return Trash;
|
|
83
|
+
}
|
|
84
|
+
return icon;
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
function getVariant(variant: ContextButtonVariant = 'highlight') {
|
|
88
|
+
if (contextButtonVariants.includes(variant)) {
|
|
89
|
+
return variant;
|
|
90
|
+
}
|
|
91
|
+
return 'highlight';
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
const DropdownButton: TemplateOnlyComponent<Signature> = <template>
|
|
95
|
+
{{#let (getVariant @variant) (getIcon @icon) as |variant icon|}}
|
|
96
|
+
<IconButton
|
|
97
|
+
class={{cn
|
|
98
|
+
'boxel-context-button'
|
|
99
|
+
(concat 'boxel-context-button--' variant)
|
|
100
|
+
boxel-context-button--active=@isActive
|
|
101
|
+
}}
|
|
102
|
+
@icon={{icon}}
|
|
103
|
+
@size={{if @size @size 'base'}}
|
|
104
|
+
@loading={{@loading}}
|
|
105
|
+
@disabled={{@disabled}}
|
|
106
|
+
@width={{@width}}
|
|
107
|
+
@height={{@height}}
|
|
108
|
+
aria-label={{@label}}
|
|
109
|
+
aria-pressed={{if @isToggle (if @isActive 'true' 'false')}}
|
|
110
|
+
data-active={{if @isActive 'true' 'false'}}
|
|
111
|
+
...attributes
|
|
112
|
+
/>
|
|
113
|
+
{{/let}}
|
|
114
|
+
<style scoped>
|
|
115
|
+
@layer boxelComponentL2 {
|
|
116
|
+
.boxel-context-button {
|
|
117
|
+
color: inherit;
|
|
118
|
+
background-color: transparent;
|
|
119
|
+
transition: none;
|
|
120
|
+
}
|
|
121
|
+
.boxel-context-button--highlight-icon {
|
|
122
|
+
color: var(--primary, var(--boxel-highlight));
|
|
123
|
+
}
|
|
124
|
+
.boxel-context-button--highlight:hover,
|
|
125
|
+
.boxel-context-button--highlight.boxel-context-button--active,
|
|
126
|
+
.boxel-context-button--highlight-icon:hover {
|
|
127
|
+
color: var(--primary-foreground, var(--boxel-dark));
|
|
128
|
+
background-color: var(--primary, var(--boxel-highlight));
|
|
129
|
+
}
|
|
130
|
+
.boxel-context-button--highlight-icon.boxel-context-button--active {
|
|
131
|
+
color: var(--primary-foreground, var(--boxel-dark));
|
|
132
|
+
background-color: var(--primary, var(--boxel-highlight));
|
|
133
|
+
}
|
|
134
|
+
.boxel-context-button--highlight[aria-expanded='true'],
|
|
135
|
+
.boxel-context-button--highlight-icon[aria-expanded='true'] {
|
|
136
|
+
color: var(--primary-foreground, var(--boxel-dark));
|
|
137
|
+
background-color: color-mix(
|
|
138
|
+
in oklab,
|
|
139
|
+
var(--primary, var(--boxel-highlight)),
|
|
140
|
+
var(--primary-foreground, var(--boxel-dark)) 15%
|
|
141
|
+
);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
.boxel-context-button--ghost:hover {
|
|
145
|
+
background-color: color-mix(in oklab, currentColor 10%, transparent);
|
|
146
|
+
}
|
|
147
|
+
.boxel-context-button--ghost.boxel-context-button--active {
|
|
148
|
+
background-color: color-mix(in oklab, currentColor 10%, transparent);
|
|
149
|
+
}
|
|
150
|
+
.boxel-context-button--ghost[aria-expanded='true'] {
|
|
151
|
+
background-color: color-mix(in oklab, currentColor 25%, transparent);
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
.boxel-context-button--destructive-icon {
|
|
155
|
+
color: var(--destructive, var(--boxel-danger));
|
|
156
|
+
}
|
|
157
|
+
.boxel-context-button--destructive:hover,
|
|
158
|
+
.boxel-context-button--destructive.boxel-context-button--active,
|
|
159
|
+
.boxel-context-button--destructive-icon:hover {
|
|
160
|
+
color: var(--destructive-foreground, var(--boxel-light-100));
|
|
161
|
+
background-color: var(--destructive, var(--boxel-danger));
|
|
162
|
+
}
|
|
163
|
+
.boxel-context-button--destructive-icon.boxel-context-button--active {
|
|
164
|
+
color: var(--destructive-foreground, var(--boxel-light-100));
|
|
165
|
+
background-color: var(--destructive, var(--boxel-danger));
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
.boxel-context-button--primary-dark {
|
|
169
|
+
color: var(--primary, var(--boxel-highlight));
|
|
170
|
+
background-color: var(--primary-foreground, var(--boxel-700));
|
|
171
|
+
border: 1px solid var(--boxel-light-hover-35);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
.boxel-context-button:disabled,
|
|
175
|
+
.boxel-context-button[disabled] {
|
|
176
|
+
color: var(--boxel-400);
|
|
177
|
+
pointer-events: none;
|
|
178
|
+
cursor: initial;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
</style>
|
|
182
|
+
</template>;
|
|
183
|
+
|
|
184
|
+
export default DropdownButton;
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { fn } from '@ember/helper';
|
|
2
|
+
import Component from '@glimmer/component';
|
|
3
|
+
import { tracked } from '@glimmer/tracking';
|
|
4
|
+
import FreestyleUsage from 'ember-freestyle/components/freestyle/usage';
|
|
5
|
+
|
|
6
|
+
import { type BoxelButtonSize, buttonSizeOptions } from '../button/index.gts';
|
|
7
|
+
import ContextButton, {
|
|
8
|
+
type ContextButtonIcon,
|
|
9
|
+
type ContextButtonVariant,
|
|
10
|
+
contextButtonIconOptions,
|
|
11
|
+
contextButtonVariants,
|
|
12
|
+
} from './index.gts';
|
|
13
|
+
|
|
14
|
+
export default class ContextButtonUsage extends Component {
|
|
15
|
+
private iconOptions = contextButtonIconOptions;
|
|
16
|
+
private variants = contextButtonVariants;
|
|
17
|
+
private sizeVariants = buttonSizeOptions;
|
|
18
|
+
@tracked private icon?: ContextButtonIcon;
|
|
19
|
+
@tracked private variant?: ContextButtonVariant;
|
|
20
|
+
@tracked private size?: BoxelButtonSize;
|
|
21
|
+
@tracked private width?: string;
|
|
22
|
+
@tracked private height?: string;
|
|
23
|
+
@tracked private isLoading = false;
|
|
24
|
+
@tracked private isDisabled = false;
|
|
25
|
+
@tracked private isActive = false;
|
|
26
|
+
@tracked private isToggle = false;
|
|
27
|
+
@tracked private label = 'context-button usage';
|
|
28
|
+
|
|
29
|
+
<template>
|
|
30
|
+
<FreestyleUsage @name='ContextButton'>
|
|
31
|
+
<:example>
|
|
32
|
+
<ContextButton
|
|
33
|
+
@label={{this.label}}
|
|
34
|
+
@icon={{this.icon}}
|
|
35
|
+
@variant={{this.variant}}
|
|
36
|
+
@size={{this.size}}
|
|
37
|
+
@loading={{this.isLoading}}
|
|
38
|
+
@disabled={{this.isDisabled}}
|
|
39
|
+
@isActive={{this.isActive}}
|
|
40
|
+
@isToggle={{this.isToggle}}
|
|
41
|
+
@width={{this.width}}
|
|
42
|
+
@height={{this.height}}
|
|
43
|
+
/>
|
|
44
|
+
</:example>
|
|
45
|
+
|
|
46
|
+
<:api as |Args|>
|
|
47
|
+
<Args.String
|
|
48
|
+
@name='label'
|
|
49
|
+
@description='aria-label attribute value'
|
|
50
|
+
@required={{true}}
|
|
51
|
+
@value={{this.label}}
|
|
52
|
+
@onInput={{fn (mut this.label)}}
|
|
53
|
+
/>
|
|
54
|
+
<Args.String
|
|
55
|
+
@name='icon'
|
|
56
|
+
@description='Options from dropdown, or IconComponent'
|
|
57
|
+
@value={{this.icon}}
|
|
58
|
+
@options={{this.iconOptions}}
|
|
59
|
+
@onInput={{fn (mut this.icon)}}
|
|
60
|
+
@defaultValue='context-menu'
|
|
61
|
+
/>
|
|
62
|
+
<Args.String
|
|
63
|
+
@name='variant'
|
|
64
|
+
@optional={{true}}
|
|
65
|
+
@value={{this.variant}}
|
|
66
|
+
@options={{this.variants}}
|
|
67
|
+
@onInput={{fn (mut this.variant)}}
|
|
68
|
+
@defaultValue='default'
|
|
69
|
+
/>
|
|
70
|
+
<Args.String
|
|
71
|
+
@name='size'
|
|
72
|
+
@optional={{true}}
|
|
73
|
+
@value={{this.size}}
|
|
74
|
+
@options={{this.sizeVariants}}
|
|
75
|
+
@onInput={{fn (mut this.size)}}
|
|
76
|
+
@defaultValue='base (30px)'
|
|
77
|
+
/>
|
|
78
|
+
<Args.Bool
|
|
79
|
+
@name='loading'
|
|
80
|
+
@optional={{true}}
|
|
81
|
+
@value={{this.isLoading}}
|
|
82
|
+
@onInput={{fn (mut this.isLoading)}}
|
|
83
|
+
@defaultValue='false'
|
|
84
|
+
/>
|
|
85
|
+
<Args.Bool
|
|
86
|
+
@name='disabled'
|
|
87
|
+
@optional={{true}}
|
|
88
|
+
@value={{this.isDisabled}}
|
|
89
|
+
@onInput={{fn (mut this.isDisabled)}}
|
|
90
|
+
@defaultValue='false'
|
|
91
|
+
/>
|
|
92
|
+
<Args.Bool
|
|
93
|
+
@name='isActive'
|
|
94
|
+
@optional={{true}}
|
|
95
|
+
@value={{this.isActive}}
|
|
96
|
+
@onInput={{fn (mut this.isActive)}}
|
|
97
|
+
@defaultValue='false'
|
|
98
|
+
/>
|
|
99
|
+
<Args.Bool
|
|
100
|
+
@name='isToggle'
|
|
101
|
+
@optional={{true}}
|
|
102
|
+
@value={{this.isToggle}}
|
|
103
|
+
@onInput={{fn (mut this.isToggle)}}
|
|
104
|
+
@defaultValue='false'
|
|
105
|
+
/>
|
|
106
|
+
<Args.String
|
|
107
|
+
@name='width'
|
|
108
|
+
@optional={{true}}
|
|
109
|
+
@description='icon width'
|
|
110
|
+
@defaultValue='16px or 20px'
|
|
111
|
+
@value={{this.width}}
|
|
112
|
+
@onInput={{fn (mut this.width)}}
|
|
113
|
+
/>
|
|
114
|
+
<Args.String
|
|
115
|
+
@name='height'
|
|
116
|
+
@optional={{true}}
|
|
117
|
+
@description='icon height'
|
|
118
|
+
@defaultValue='16px or 20px'
|
|
119
|
+
@value={{this.height}}
|
|
120
|
+
@onInput={{fn (mut this.height)}}
|
|
121
|
+
/>
|
|
122
|
+
</:api>
|
|
123
|
+
</FreestyleUsage>
|
|
124
|
+
</template>
|
|
125
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import Copy from '@cardstack/boxel-icons/copy';
|
|
2
|
+
import { on } from '@ember/modifier';
|
|
3
|
+
import { action } from '@ember/object';
|
|
4
|
+
import type { MiddlewareState } from '@floating-ui/dom';
|
|
5
|
+
import Component from '@glimmer/component';
|
|
6
|
+
import { tracked } from '@glimmer/tracking';
|
|
7
|
+
|
|
8
|
+
import {
|
|
9
|
+
type BoxelButtonKind,
|
|
10
|
+
type BoxelButtonSize,
|
|
11
|
+
} from '../button/index.gts';
|
|
12
|
+
import IconButton from '../icon-button/index.gts';
|
|
13
|
+
import Tooltip from '../tooltip/index.gts';
|
|
14
|
+
|
|
15
|
+
interface Signature {
|
|
16
|
+
Args: {
|
|
17
|
+
ariaLabel?: string;
|
|
18
|
+
height?: string;
|
|
19
|
+
offset?: number;
|
|
20
|
+
placement?: MiddlewareState['placement'];
|
|
21
|
+
size?: BoxelButtonSize;
|
|
22
|
+
textToCopy: string;
|
|
23
|
+
tooltipText?: string;
|
|
24
|
+
variant?: BoxelButtonKind;
|
|
25
|
+
width?: string;
|
|
26
|
+
};
|
|
27
|
+
Element: HTMLElement;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export default class CopyButton extends Component<Signature> {
|
|
31
|
+
@tracked private recentlyCopied = false;
|
|
32
|
+
|
|
33
|
+
@action private async copyToClipboard() {
|
|
34
|
+
try {
|
|
35
|
+
await navigator.clipboard.writeText(this.args.textToCopy);
|
|
36
|
+
this.recentlyCopied = true;
|
|
37
|
+
|
|
38
|
+
setTimeout(() => (this.recentlyCopied = false), 2000);
|
|
39
|
+
} catch (error: unknown) {
|
|
40
|
+
console.error(error instanceof Error ? error.message : error);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
<template>
|
|
45
|
+
<Tooltip
|
|
46
|
+
@placement={{@placement}}
|
|
47
|
+
@offset={{@offset}}
|
|
48
|
+
class='boxel-copy-button-tooltip'
|
|
49
|
+
...attributes
|
|
50
|
+
>
|
|
51
|
+
<:trigger>
|
|
52
|
+
<IconButton
|
|
53
|
+
@icon={{Copy}}
|
|
54
|
+
@variant={{@variant}}
|
|
55
|
+
@size={{if @size @size 'base'}}
|
|
56
|
+
@width={{if @width @width '18'}}
|
|
57
|
+
@height={{if @height @height '18'}}
|
|
58
|
+
{{on 'click' this.copyToClipboard}}
|
|
59
|
+
class='boxel-copy-button'
|
|
60
|
+
aria-label={{if
|
|
61
|
+
this.recentlyCopied
|
|
62
|
+
'Copied'
|
|
63
|
+
(if @ariaLabel @ariaLabel 'Copy to clipboard')
|
|
64
|
+
}}
|
|
65
|
+
data-test-boxel-copy-button
|
|
66
|
+
/>
|
|
67
|
+
</:trigger>
|
|
68
|
+
<:content>
|
|
69
|
+
<span>
|
|
70
|
+
{{if
|
|
71
|
+
this.recentlyCopied
|
|
72
|
+
'Copied!'
|
|
73
|
+
(if @tooltipText @tooltipText 'Copy to clipboard')
|
|
74
|
+
}}
|
|
75
|
+
</span>
|
|
76
|
+
</:content>
|
|
77
|
+
</Tooltip>
|
|
78
|
+
</template>
|
|
79
|
+
}
|