avo 3.30.4 → 4.0.0.beta.2
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.
- checksums.yaml +4 -4
- data/Gemfile +18 -1
- data/Gemfile.lock +257 -174
- data/README.md +1 -1
- data/app/assets/builds/avo/application.css +13979 -0
- data/app/assets/builds/avo/application.js +1160 -0
- data/app/assets/builds/avo/application.js.map +7 -0
- data/app/assets/builds/avo/late-registration.js +2 -0
- data/app/assets/builds/avo/late-registration.js.map +7 -0
- data/app/assets/config/avo_manifest.js +2 -1
- data/app/assets/images/avo/placeholder.svg +1 -0
- data/app/assets/stylesheets/application.css +250 -0
- data/app/assets/stylesheets/css/button-group.css +23 -0
- data/app/assets/stylesheets/css/components/avatar.css +128 -0
- data/app/assets/stylesheets/css/components/breadcrumbs.css +43 -0
- data/app/assets/stylesheets/css/components/button.css +343 -0
- data/app/assets/stylesheets/css/components/color_scheme_switcher.css +226 -0
- data/app/assets/stylesheets/css/components/discreet_information.css +49 -0
- data/app/assets/stylesheets/css/components/field-wrapper.css +107 -0
- data/app/assets/stylesheets/css/components/grid.css +120 -0
- data/app/assets/stylesheets/css/components/input.css +312 -0
- data/app/assets/stylesheets/css/components/modal.css +228 -0
- data/app/assets/stylesheets/css/components/tooltip.css +25 -0
- data/app/assets/stylesheets/css/components/ui/badge.css +143 -0
- data/app/assets/stylesheets/css/components/ui/card.css +95 -0
- data/app/assets/stylesheets/css/components/ui/checkbox.css +50 -0
- data/app/assets/stylesheets/css/components/ui/description_list.css +3 -0
- data/app/assets/stylesheets/css/components/ui/dropdown.css +68 -0
- data/app/assets/stylesheets/css/components/ui/file_upload_input.css +94 -0
- data/app/assets/stylesheets/css/components/ui/file_upload_item.css +78 -0
- data/app/assets/stylesheets/css/components/ui/panel.css +59 -0
- data/app/assets/stylesheets/css/components/ui/panel_header.css +48 -0
- data/app/assets/stylesheets/css/components/ui/radio.css +22 -0
- data/app/assets/stylesheets/css/components/ui/tabs.css +74 -0
- data/app/assets/stylesheets/css/css-animations.css +54 -0
- data/app/assets/stylesheets/css/fields/code.css +75 -9
- data/app/assets/stylesheets/css/fields/easy-mde.css +7 -0
- data/app/assets/stylesheets/css/fields/key_value.css +97 -0
- data/app/assets/stylesheets/css/fields/progress.css +4 -4
- data/app/assets/stylesheets/css/fields/status.css +7 -1
- data/app/assets/stylesheets/css/fields/tags.css +33 -16
- data/app/assets/stylesheets/css/fields/tiptap.css +17 -15
- data/app/assets/stylesheets/css/fields/trix.css +62 -2
- data/app/assets/stylesheets/css/fonts.css +24 -24
- data/app/assets/stylesheets/css/layout.css +135 -0
- data/app/assets/stylesheets/css/pagination.css +114 -78
- data/app/assets/stylesheets/css/resource-controls.css +13 -0
- data/app/assets/stylesheets/css/search.css +22 -12
- data/app/assets/stylesheets/css/sidebar.css +310 -24
- data/app/assets/stylesheets/css/table.css +60 -0
- data/app/assets/stylesheets/css/tooltips.css +1 -1
- data/app/assets/stylesheets/css/typography.css +10 -1
- data/app/assets/stylesheets/css/variables.css +318 -0
- data/app/assets/svgs/avo/moon-plus-plus.svg +1 -0
- data/app/components/avo/actions_component.html.erb +30 -36
- data/app/components/avo/actions_component.rb +8 -11
- data/app/components/avo/alert_component.html.erb +3 -3
- data/app/components/avo/alert_component.rb +1 -1
- data/app/components/avo/asset_manager/javascript_component.html.erb +1 -2
- data/app/components/avo/backtrace_alert_component.html.erb +4 -4
- data/app/components/avo/base_component.rb +3 -4
- data/app/components/avo/breadcrumb_element_component.html.erb +17 -0
- data/app/components/avo/breadcrumb_element_component.rb +21 -0
- data/app/components/avo/breadcrumbs_component.html.erb +19 -0
- data/app/components/avo/breadcrumbs_component.rb +5 -0
- data/app/components/avo/button_component.rb +20 -126
- data/app/components/avo/clipboard_component.html.erb +3 -2
- data/app/components/avo/clipboard_component.rb +1 -1
- data/app/components/avo/component_missing_component.rb +11 -0
- data/app/components/avo/cover_component.html.erb +3 -0
- data/app/components/avo/cover_component.rb +25 -0
- data/app/components/avo/debug/status_component.html.erb +59 -0
- data/app/components/avo/debug/status_component.rb +30 -0
- data/app/components/avo/description_list_component.rb +11 -0
- data/app/components/avo/discreet_information_component.html.erb +31 -6
- data/app/components/avo/discreet_information_component.rb +23 -32
- data/app/components/avo/divider_component.html.erb +2 -2
- data/app/components/avo/empty_state_component.html.erb +2 -9
- data/app/components/avo/empty_state_component.rb +0 -8
- data/app/components/avo/field_wrapper_component.html.erb +21 -22
- data/app/components/avo/field_wrapper_component.rb +9 -18
- data/app/components/avo/fields/avatar_field/index_component.html.erb +9 -0
- data/app/components/avo/fields/avatar_field/index_component.rb +4 -0
- data/app/components/avo/fields/badge_field/index_component.html.erb +7 -1
- data/app/components/avo/fields/badge_field/show_component.html.erb +6 -1
- data/app/components/avo/fields/belongs_to_field/edit_component.html.erb +16 -14
- data/app/components/avo/fields/belongs_to_field/edit_component.rb +13 -3
- data/app/components/avo/fields/boolean_field/edit_component.html.erb +2 -2
- data/app/components/avo/fields/boolean_group_field/edit_component.html.erb +1 -1
- data/app/components/avo/fields/boolean_group_field/edit_component.rb +2 -3
- data/app/components/avo/fields/code_field/show_component.html.erb +1 -1
- data/app/components/avo/fields/common/boolean_check_component.rb +3 -3
- data/app/components/avo/fields/common/boolean_group_component.html.erb +2 -2
- data/app/components/avo/fields/common/files/controls_component.html.erb +30 -27
- data/app/components/avo/fields/common/files/controls_component.rb +0 -1
- data/app/components/avo/fields/common/files/list_viewer_component.html.erb +4 -5
- data/app/components/avo/fields/common/files/view_type/grid_item_component.html.erb +1 -1
- data/app/components/avo/fields/common/files/view_type/list_item_component.html.erb +7 -19
- data/app/components/avo/fields/common/heading_component.html.erb +2 -2
- data/app/components/avo/fields/common/heading_component.rb +1 -1
- data/app/components/avo/fields/common/key_value_component.html.erb +20 -24
- data/app/components/avo/fields/common/nested_field_component.html.erb +1 -1
- data/app/components/avo/fields/common/nested_field_component.rb +1 -1
- data/app/components/avo/fields/common/progress_bar_component.html.erb +2 -2
- data/app/components/avo/fields/common/stars_component.html.erb +1 -1
- data/app/components/avo/fields/common/status_viewer_component.html.erb +4 -10
- data/app/components/avo/fields/date_field/edit_component.html.erb +14 -1
- data/app/components/avo/fields/date_time_field/edit_component.html.erb +3 -3
- data/app/components/avo/fields/easy_mde_field/show_component.html.erb +1 -1
- data/app/components/avo/fields/edit_component.rb +9 -5
- data/app/components/avo/fields/file_field/edit_component.html.erb +14 -6
- data/app/components/avo/fields/files_field/edit_component.html.erb +11 -4
- data/app/components/avo/fields/has_one_field/show_component.html.erb +10 -9
- data/app/components/avo/fields/heading_field/edit_component.html.erb +1 -1
- data/app/components/avo/fields/heading_field/show_component.html.erb +2 -2
- data/app/components/avo/fields/password_field/edit_component.html.erb +5 -7
- data/app/components/avo/fields/progress_bar_field/edit_component.html.erb +1 -1
- data/app/components/avo/fields/radio_field/edit_component.html.erb +1 -1
- data/app/components/avo/fields/show_component.rb +4 -7
- data/app/components/avo/fields/stars_field/edit_component.html.erb +3 -4
- data/app/components/avo/fields/tags_field/edit_component.html.erb +1 -1
- data/app/components/avo/fields/tags_field/tag_component.html.erb +7 -8
- data/app/components/avo/fields/time_field/edit_component.html.erb +3 -3
- data/app/components/avo/fields/tiptap_field/edit_component.html.erb +11 -11
- data/app/components/avo/fields/tiptap_field/show_component.html.erb +4 -4
- data/app/components/avo/fields/trix_field/edit_component.html.erb +2 -2
- data/app/components/avo/filters_component.html.erb +8 -16
- data/app/components/avo/index/field_wrapper_component.html.erb +9 -2
- data/app/components/avo/index/field_wrapper_component.rb +0 -16
- data/app/components/avo/index/grid_cover_empty_state_component.html.erb +16 -2
- data/app/components/avo/index/grid_cover_empty_state_component.rb +90 -0
- data/app/components/avo/index/grid_item_component.html.erb +29 -12
- data/app/components/avo/index/grid_item_component.rb +12 -10
- data/app/components/avo/index/resource_controls_component.html.erb +1 -1
- data/app/components/avo/index/resource_controls_component.rb +7 -17
- data/app/components/avo/index/resource_controls_dropdown_component.html.erb +3 -0
- data/app/components/avo/index/resource_controls_dropdown_component.rb +81 -0
- data/app/components/avo/index/table_row_component.html.erb +11 -11
- data/app/components/avo/items/panel_component.html.erb +8 -18
- data/app/components/avo/items/panel_component.rb +0 -20
- data/app/components/avo/items/switcher_component.html.erb +60 -1
- data/app/components/avo/items/switcher_component.rb +10 -5
- data/app/components/avo/items/visible_items_component.html.erb +2 -1
- data/app/components/avo/items/visible_items_component.rb +1 -0
- data/app/components/avo/media_library/item_details_component.html.erb +2 -2
- data/app/components/avo/media_library/list_component.html.erb +24 -19
- data/app/components/avo/media_library/list_component.rb +2 -2
- data/app/components/avo/media_library/list_item_component.html.erb +3 -3
- data/app/components/avo/modal_component.html.erb +52 -20
- data/app/components/avo/modal_component.rb +7 -12
- data/app/components/avo/paginator_component.html.erb +46 -33
- data/app/components/avo/paginator_component.rb +10 -5
- data/app/components/avo/panel_name_component.html.erb +1 -1
- data/app/components/avo/profile_item_component.html.erb +4 -4
- data/app/components/avo/profile_item_component.rb +2 -4
- data/app/components/avo/referrer_params_component.html.erb +1 -1
- data/app/components/avo/resource_component.rb +8 -19
- data/app/components/avo/resource_listing_component.html.erb +22 -0
- data/app/components/avo/resource_listing_component.rb +28 -0
- data/app/components/avo/resource_sidebar_component.html.erb +2 -2
- data/app/components/avo/resource_sidebar_component.rb +0 -4
- data/app/components/avo/row_component.html.erb +1 -1
- data/app/components/avo/row_selector_component.html.erb +2 -4
- data/app/components/avo/row_selector_component.rb +0 -1
- data/app/components/avo/search_overlay_component.html.erb +6 -0
- data/app/components/avo/search_overlay_component.rb +2 -0
- data/app/components/avo/sidebar/base_item_component.rb +9 -9
- data/app/components/avo/sidebar/group_component.html.erb +23 -27
- data/app/components/avo/sidebar/group_component.rb +4 -0
- data/app/components/avo/sidebar/link_component.html.erb +30 -7
- data/app/components/avo/sidebar/link_component.rb +30 -2
- data/app/components/avo/sidebar/section_component.html.erb +31 -11
- data/app/components/avo/sidebar/section_component.rb +1 -3
- data/app/components/avo/sidebar_component.html.erb +35 -36
- data/app/components/avo/sidebar_component.rb +16 -0
- data/app/components/avo/sidebar_profile_component.html.erb +27 -36
- data/app/components/avo/sidebar_profile_component.rb +14 -0
- data/app/components/avo/tab_group_component.html.erb +21 -9
- data/app/components/avo/tab_group_component.rb +54 -15
- data/app/components/avo/turbo_frame_wrapper_component.html.erb +4 -8
- data/app/components/avo/turbo_frame_wrapper_component.rb +9 -0
- data/app/components/avo/u_i/avatar_component.html.erb +11 -0
- data/app/components/avo/u_i/avatar_component.rb +61 -0
- data/app/components/avo/u_i/badge_component.html.erb +9 -0
- data/app/components/avo/u_i/badge_component.rb +35 -0
- data/app/components/avo/u_i/card_component.html.erb +29 -0
- data/app/components/avo/u_i/card_component.rb +65 -0
- data/app/components/avo/u_i/dropdown_component.html.erb +14 -0
- data/app/components/avo/u_i/dropdown_component.rb +26 -0
- data/app/components/avo/u_i/dropdown_menu_component.html.erb +16 -0
- data/app/components/avo/u_i/dropdown_menu_component.rb +8 -0
- data/app/components/avo/u_i/file_upload_input_component.html.erb +26 -0
- data/app/components/avo/u_i/file_upload_input_component.rb +15 -0
- data/app/components/avo/u_i/file_upload_item_component.html.erb +48 -0
- data/app/components/avo/u_i/file_upload_item_component.rb +17 -0
- data/app/components/avo/u_i/icon_button_component.html.erb +7 -0
- data/app/components/avo/u_i/icon_button_component.rb +22 -0
- data/app/components/avo/u_i/panel_component.html.erb +49 -0
- data/app/components/avo/u_i/panel_component.rb +29 -0
- data/app/components/avo/u_i/panel_header_component.html.erb +37 -0
- data/app/components/avo/u_i/panel_header_component.rb +24 -0
- data/app/components/avo/u_i/search_input_component.html.erb +28 -0
- data/app/components/avo/u_i/search_input_component.rb +12 -0
- data/app/components/avo/u_i/tabs/tab_component.html.erb +26 -0
- data/app/components/avo/u_i/tabs/tab_component.rb +25 -0
- data/app/components/avo/u_i/tabs/tabs_component.html.erb +7 -0
- data/app/components/avo/u_i/tabs/tabs_component.rb +13 -0
- data/app/components/avo/view_types/base_view_type_component.rb +26 -0
- data/app/components/avo/view_types/grid_component.html.erb +18 -0
- data/app/components/avo/view_types/grid_component.rb +4 -0
- data/app/components/avo/view_types/map_component.html.erb +17 -0
- data/app/components/avo/view_types/map_component.rb +110 -0
- data/app/components/avo/view_types/table_component.html.erb +63 -0
- data/app/components/avo/{index/resource_table_component.rb → view_types/table_component.rb} +1 -10
- data/app/components/avo/views/resource_edit_component.html.erb +12 -18
- data/app/components/avo/views/resource_edit_component.rb +1 -27
- data/app/components/avo/views/resource_index_component.html.erb +97 -74
- data/app/components/avo/views/resource_index_component.rb +23 -3
- data/app/components/avo/views/resource_show_component.html.erb +4 -2
- data/app/components/avo/views/resource_show_component.rb +1 -4
- data/app/controllers/avo/associations_controller.rb +1 -1
- data/app/controllers/avo/base_application_controller.rb +7 -5
- data/app/controllers/avo/base_controller.rb +139 -40
- data/app/controllers/avo/debug_controller.rb +0 -29
- data/app/controllers/avo/media_library_controller.rb +17 -1
- data/app/controllers/avo/search_controller.rb +5 -0
- data/app/controllers/concerns/avo/initializes_avo.rb +7 -8
- data/app/helpers/avo/application_helper.rb +60 -46
- data/app/helpers/avo/turbo_stream_actions_helper.rb +10 -1
- data/app/helpers/avo/url_helpers.rb +3 -2
- data/app/javascript/{avo.base.js → application.js} +9 -18
- data/app/javascript/js/application.js +40 -0
- data/app/javascript/js/controllers/action_controller.js +4 -4
- data/app/javascript/js/controllers/actions_overflow_controller.js +21 -6
- data/app/javascript/js/controllers/color_scheme_switcher_controller.js +226 -0
- data/app/javascript/js/controllers/dropdown_menu_controller.js +42 -0
- data/app/javascript/js/controllers/fields/code_field_controller.js +20 -3
- data/app/javascript/js/controllers/fields/easy_mde_controller.js +23 -1
- data/app/javascript/js/controllers/fields/key_value_controller.js +43 -39
- data/app/javascript/js/controllers/fields/panel_refresh_controller.js +4 -0
- data/app/javascript/js/controllers/fields/tags_field_controller.js +2 -2
- data/app/javascript/js/controllers/fields/tags_field_helpers.js +4 -6
- data/app/javascript/js/controllers/grid_cover_empty_state_controller.js +42 -0
- data/app/javascript/js/controllers/item_selector_controller.js +0 -2
- data/app/javascript/js/controllers/loading_button_controller.js +1 -5
- data/app/javascript/js/controllers/map_dark_mode_controller.js +131 -0
- data/app/javascript/js/controllers/menu_controller.js +38 -16
- data/app/javascript/js/controllers/modal_controller.js +16 -0
- data/app/javascript/js/controllers/modal_size_controller.js +83 -0
- data/app/javascript/js/controllers/nested_form_controller.js +2 -2
- data/app/javascript/js/controllers/password_visibility_controller.js +13 -0
- data/app/javascript/js/controllers/preview_controller.js +2 -2
- data/app/javascript/js/controllers/resource_search_controller.js +123 -0
- data/app/javascript/js/controllers/search_controller.js +10 -29
- data/app/javascript/js/controllers/sidebar_controller.js +29 -9
- data/app/javascript/js/controllers/table_row_controller.js +28 -0
- data/app/javascript/js/controllers/tippy_controller.js +1 -1
- data/app/javascript/js/controllers/toggle_controller.js +40 -5
- data/app/javascript/js/controllers.js +14 -2
- data/app/javascript/js/custom-stream-actions.js +10 -8
- data/app/views/avo/actions/show.html.erb +14 -10
- data/app/views/avo/base/_boolean_filter.html.erb +1 -1
- data/app/views/avo/base/_date_time_filter.html.erb +3 -3
- data/app/views/avo/base/_multiple_select_filter.html.erb +1 -1
- data/app/views/avo/base/_new_via_belongs_to.html.erb +2 -3
- data/app/views/avo/base/_text_filter.html.erb +1 -1
- data/app/views/avo/base/preview.html.erb +5 -4
- data/app/views/avo/debug/status.html.erb +5 -92
- data/app/views/avo/debug/status.text.erb +0 -2
- data/app/views/avo/home/_actions.html.erb +1 -1
- data/app/views/avo/home/_dashboards.html.erb +1 -1
- data/app/views/avo/home/_filters.html.erb +1 -1
- data/app/views/avo/home/_resources.html.erb +2 -2
- data/app/views/avo/home/failed_to_load.html.erb +2 -2
- data/app/views/avo/home/index.html.erb +25 -25
- data/app/views/avo/media_library/_form.html.erb +43 -28
- data/app/views/avo/media_library/show.html.erb +7 -3
- data/app/views/avo/modal/_size_selector.html.erb +46 -0
- data/app/views/avo/partials/_alerts.html.erb +1 -1
- data/app/views/avo/partials/_color_scheme_switcher.html.erb +106 -0
- data/app/views/avo/partials/_color_theme_override.html.erb +49 -0
- data/app/views/avo/partials/_confirm_dialog.html.erb +19 -17
- data/app/views/avo/partials/_custom_tools_alert.html.erb +6 -6
- data/app/views/avo/partials/_footer.html.erb +1 -1
- data/app/views/avo/partials/_header.html.erb +1 -1
- data/app/views/avo/partials/_javascript.html.erb +0 -2
- data/app/views/avo/partials/_navbar.html.erb +53 -8
- data/app/views/avo/partials/_sortable_component.html.erb +1 -1
- data/app/views/avo/partials/_table_header.html.erb +28 -19
- data/app/views/avo/partials/_view_toggle_button.html.erb +6 -29
- data/app/views/avo/partials/distribution_chart.html.erb +2 -2
- data/app/views/avo/private/_links_and_buttons.html.erb +12 -8
- data/app/views/avo/private/design.html.erb +8 -4
- data/app/views/avo/sidebar/_license_warning.html.erb +3 -3
- data/app/views/layouts/avo/application.html.erb +39 -17
- data/app/views/layouts/avo/modal.html.erb +7 -0
- data/avo.gemspec +3 -4
- data/config/i18n-tasks.yml +1 -1
- data/config/importmap.rb +1 -0
- data/config/initializers/pagy.rb +5 -25
- data/config/routes/dynamic_routes.rb +4 -0
- data/config/routes.rb +6 -7
- data/db/factories.rb +14 -0
- data/lib/avo/asset_manager.rb +2 -0
- data/lib/avo/avatar.rb +7 -0
- data/lib/avo/base_action.rb +16 -4
- data/lib/avo/concerns/breadcrumbs.rb +7 -66
- data/lib/avo/concerns/form_builder.rb +41 -0
- data/lib/avo/concerns/{has_profile_photo.rb → has_avatar.rb} +8 -4
- data/lib/avo/concerns/{has_cover_photo.rb → has_cover.rb} +4 -4
- data/lib/avo/concerns/has_description.rb +9 -0
- data/lib/avo/concerns/has_item_type.rb +6 -2
- data/lib/avo/concerns/has_items.rb +43 -58
- data/lib/avo/concerns/pagination.rb +29 -19
- data/lib/avo/concerns/row_controls_configuration.rb +22 -15
- data/lib/avo/configuration/branding.rb +7 -7
- data/lib/avo/configuration.rb +92 -45
- data/lib/avo/{cover_photo.rb → cover.rb} +2 -2
- data/lib/avo/current.rb +0 -11
- data/lib/avo/discreet_information.rb +52 -29
- data/lib/avo/dsl/field_parser.rb +1 -1
- data/lib/avo/engine.rb +41 -8
- data/lib/avo/error_manager.rb +1 -1
- data/lib/avo/fields/avatar_field.rb +19 -0
- data/lib/avo/fields/badge_field.rb +23 -3
- data/lib/avo/fields/base_field.rb +46 -1
- data/lib/avo/fields/concerns/dom_id.rb +17 -0
- data/lib/avo/fields/concerns/file_authorization.rb +4 -0
- data/lib/avo/fields/concerns/has_html_attributes.rb +1 -1
- data/lib/avo/fields/concerns/is_searchable.rb +2 -5
- data/lib/avo/fields/concerns/nested.rb +1 -1
- data/lib/avo/fields/files_field.rb +2 -2
- data/lib/avo/fields/frame_base_field.rb +2 -2
- data/lib/avo/fields/id_field.rb +5 -1
- data/lib/avo/fields/progress_bar_field.rb +1 -1
- data/lib/avo/fields/text_field.rb +1 -1
- data/lib/avo/photo_object.rb +12 -1
- data/lib/avo/plugin_manager.rb +4 -0
- data/lib/avo/resources/base.rb +33 -21
- data/lib/avo/resources/controls/actions_list.rb +3 -3
- data/lib/avo/resources/controls/base_control.rb +1 -1
- data/lib/avo/resources/items/card.rb +16 -0
- data/lib/avo/resources/items/header.rb +11 -0
- data/lib/avo/resources/items/holder.rb +18 -23
- data/lib/avo/resources/items/item_group.rb +5 -7
- data/lib/avo/resources/items/sidebar.rb +5 -9
- data/lib/avo/resources/items/tab.rb +8 -8
- data/lib/avo/resources/items/tab_group.rb +8 -10
- data/lib/avo/resources/resource_manager.rb +2 -1
- data/lib/avo/services/hq_reporter.rb +102 -0
- data/lib/avo/services/telemetry_service.rb +0 -1
- data/lib/avo/test_helpers.rb +36 -22
- data/lib/avo/u_i_instance.rb +60 -0
- data/lib/avo/version.rb +1 -1
- data/lib/avo/view_inquirer.rb +6 -1
- data/lib/avo/view_types/view_type_manager.rb +70 -0
- data/lib/avo.rb +30 -45
- data/lib/generators/avo/action_generator.rb +1 -1
- data/lib/generators/avo/resource_generator.rb +43 -0
- data/lib/generators/avo/resource_tool_generator.rb +1 -1
- data/lib/generators/avo/tailwindcss/install_generator.rb +0 -6
- data/lib/generators/avo/templates/cards/partial_card_partial.tt +1 -1
- data/lib/generators/avo/templates/initializer/avo.tt +7 -9
- data/lib/generators/avo/templates/locales/avo.ar.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.de.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.en.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.es.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.fr.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.it.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.ja.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.nb.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.nl.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.nn.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.pl.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.pt-BR.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.pt.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.ro.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.ru.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.tr.yml +25 -0
- data/lib/generators/avo/templates/locales/{avo.uk.yml → avo.ua.yml} +26 -1
- data/lib/generators/avo/templates/locales/avo.zh-TW.yml +25 -0
- data/lib/generators/avo/templates/locales/avo.zh.yml +25 -0
- data/lib/generators/avo/templates/resource/resource.tt +10 -1
- data/lib/generators/avo/templates/resource_tools/partial.tt +20 -22
- data/lib/generators/avo/templates/tailwindcss/avo.tailwind.css +1 -3
- data/lib/generators/avo/templates/tailwindcss/tailwind.config.js +0 -7
- data/lib/generators/avo/templates/tool/view.tt +14 -16
- data/lib/generators/avo/tool_generator.rb +3 -3
- data/lib/generators/avo/version_generator.rb +1 -1
- data/lib/tasks/avo_tasks.rake +29 -25
- metadata +145 -97
- data/app/assets/stylesheets/avo.base.css +0 -130
- data/app/assets/stylesheets/css/breadcrumbs.css +0 -16
- data/app/assets/stylesheets/css/buttons.css +0 -19
- data/app/assets/stylesheets/css/tailwindcss/base.css +0 -1
- data/app/assets/stylesheets/css/tailwindcss/components.css +0 -1
- data/app/assets/stylesheets/css/tailwindcss/utilities.css +0 -1
- data/app/assets/svgs/avo/arrow-down.svg +0 -3
- data/app/assets/svgs/avo/arrow-up.svg +0 -3
- data/app/assets/svgs/avo/detach.svg +0 -8
- data/app/assets/svgs/avo/download-solid-reversed.svg +0 -3
- data/app/assets/svgs/avo/download-solid.svg +0 -3
- data/app/assets/svgs/avo/edit.svg +0 -5
- data/app/assets/svgs/avo/editor-bold.svg +0 -1
- data/app/assets/svgs/avo/editor-italic.svg +0 -1
- data/app/assets/svgs/avo/editor-link.svg +0 -1
- data/app/assets/svgs/avo/editor-list.svg +0 -1
- data/app/assets/svgs/avo/editor-strike.svg +0 -1
- data/app/assets/svgs/avo/editor-underline.svg +0 -1
- data/app/assets/svgs/avo/eye.svg +0 -1
- data/app/assets/svgs/avo/trash-sm.svg +0 -3
- data/app/assets/svgs/avo/trash.svg +0 -7
- data/app/components/avo/cover_photo_component.html.erb +0 -3
- data/app/components/avo/cover_photo_component.rb +0 -19
- data/app/components/avo/fields/common/badge_viewer_component.html.erb +0 -1
- data/app/components/avo/fields/common/badge_viewer_component.rb +0 -33
- data/app/components/avo/index/resource_grid_component.html.erb +0 -23
- data/app/components/avo/index/resource_grid_component.rb +0 -10
- data/app/components/avo/index/resource_map_component.html.erb +0 -16
- data/app/components/avo/index/resource_map_component.rb +0 -114
- data/app/components/avo/index/resource_table_component.html.erb +0 -52
- data/app/components/avo/panel_component.html.erb +0 -63
- data/app/components/avo/panel_component.rb +0 -43
- data/app/components/avo/panel_header_component.html.erb +0 -42
- data/app/components/avo/panel_header_component.rb +0 -31
- data/app/components/avo/profile_photo_component.html.erb +0 -6
- data/app/components/avo/profile_photo_component.rb +0 -9
- data/app/components/avo/sidebar/heading_component.html.erb +0 -21
- data/app/components/avo/sidebar/heading_component.rb +0 -9
- data/app/components/avo/tab_switcher_component.html.erb +0 -20
- data/app/components/avo/tab_switcher_component.rb +0 -45
- data/app/views/avo/base/close_modal_and_reload_field.turbo_stream.erb +0 -8
- data/app/views/avo/debug/report.html.erb +0 -37
- data/app/views/avo/partials/_panel_breadcrumbs.html.erb +0 -3
- data/app/views/avo/partials/_resource_search.html.erb +0 -16
- data/lib/avo/licensing/community_license.rb +0 -6
- data/lib/avo/licensing/h_q.rb +0 -202
- data/lib/avo/licensing/license.rb +0 -76
- data/lib/avo/licensing/license_manager.rb +0 -24
- data/lib/avo/licensing/nil_license.rb +0 -14
- data/lib/avo/licensing/pro_license.rb +0 -20
- data/lib/avo/licensing/request.rb +0 -20
- data/lib/avo/profile_photo.rb +0 -7
- data/lib/avo/services/debug_service.rb +0 -107
- data/public/avo-assets/placeholder.svg +0 -1
- data/tailwind.preset.js +0 -171
- /data/{public/avo-assets → app/assets/images/avo}/favicon.ico +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.eot +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.svg +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.ttf +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.woff +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.woff2 +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.eot +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.svg +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.ttf +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.woff +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.woff2 +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.eot +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.svg +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.ttf +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.woff +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.woff2 +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.eot +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.svg +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.ttf +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.woff +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.woff2 +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/logo-on-white.png +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/logo.png +0 -0
- /data/{public/avo-assets → app/assets/images/avo}/logomark.png +0 -0
|
@@ -0,0 +1,343 @@
|
|
|
1
|
+
@layer base {
|
|
2
|
+
.button {
|
|
3
|
+
@apply inline-flex justify-center grow-0 items-center font-medium leading-none fill-current whitespace-nowrap transition-transform duration-50 cursor-pointer disabled:cursor-not-allowed disabled:opacity-60 data-[disabled='true']:opacity-60 gap-1.5 border border-transparent rounded-lg;
|
|
4
|
+
|
|
5
|
+
--btn-text-color: color-mix(in oklab, var(--btn-color-accent), var(--color-content) 20%);
|
|
6
|
+
|
|
7
|
+
/* Base styles for all button types */
|
|
8
|
+
&:active:not(:disabled) {
|
|
9
|
+
@apply translate-y-px;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
&.button--focus-visible,
|
|
13
|
+
&:focus-visible {
|
|
14
|
+
@apply outline-none rounded-lg;
|
|
15
|
+
|
|
16
|
+
box-shadow: 0 0 0 1px var(--color-primary), 0 0 0 3px var(--color-info-foreground);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
/* Default colors */
|
|
21
|
+
--btn-color-accent: var(--color-avo-neutral-50);
|
|
22
|
+
--btn-color-accent-content: var(--color-avo-neutral-100);
|
|
23
|
+
--btn-color-accent-foreground: var(--color-avo-neutral-950);
|
|
24
|
+
|
|
25
|
+
&&.button--color-primary {
|
|
26
|
+
--btn-color-accent: var(--color-avo-neutral-800);
|
|
27
|
+
--btn-color-accent-content: var(--color-avo-neutral-950);
|
|
28
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
&&.button--color-accent {
|
|
32
|
+
--btn-color-accent: var(--color-accent);
|
|
33
|
+
--btn-color-accent-content: var(--color-accent-content);
|
|
34
|
+
--btn-color-accent-foreground: var(--color-accent-foreground);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
&&.button--color-teal {
|
|
38
|
+
--btn-color-accent: var(--color-teal-500);
|
|
39
|
+
--btn-color-accent-content: var(--color-teal-600);
|
|
40
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
&&.button--color-red {
|
|
44
|
+
--btn-color-accent: var(--color-red-500);
|
|
45
|
+
--btn-color-accent-content: var(--color-red-600);
|
|
46
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
&&.button--color-blue {
|
|
50
|
+
--btn-color-accent: var(--color-blue-500);
|
|
51
|
+
--btn-color-accent-content: var(--color-blue-600);
|
|
52
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
&&.button--color-gray {
|
|
56
|
+
--btn-color-accent: var(--color-gray-500);
|
|
57
|
+
--btn-color-accent-content: var(--color-gray-600);
|
|
58
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
&&.button--color-orange {
|
|
62
|
+
--btn-color-accent: var(--color-orange-500);
|
|
63
|
+
--btn-color-accent-content: var(--color-orange-600);
|
|
64
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
&&.button--color-green {
|
|
68
|
+
--btn-color-accent: var(--color-green-500);
|
|
69
|
+
--btn-color-accent-content: var(--color-green-600);
|
|
70
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
&&.button--color-amber {
|
|
74
|
+
--btn-color-accent: var(--color-amber-500);
|
|
75
|
+
--btn-color-accent-content: var(--color-amber-600);
|
|
76
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
&&.button--color-yellow {
|
|
80
|
+
--btn-color-accent: var(--color-yellow-500);
|
|
81
|
+
--btn-color-accent-content: var(--color-yellow-600);
|
|
82
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
&&.button--color-lime {
|
|
86
|
+
--btn-color-accent: var(--color-lime-500);
|
|
87
|
+
--btn-color-accent-content: var(--color-lime-600);
|
|
88
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
&&.button--color-emerald {
|
|
92
|
+
--btn-color-accent: var(--color-emerald-500);
|
|
93
|
+
--btn-color-accent-content: var(--color-emerald-600);
|
|
94
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
&&.button--color-cyan {
|
|
98
|
+
--btn-color-accent: var(--color-cyan-500);
|
|
99
|
+
--btn-color-accent-content: var(--color-cyan-600);
|
|
100
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
&&.button--color-sky {
|
|
104
|
+
--btn-color-accent: var(--color-sky-500);
|
|
105
|
+
--btn-color-accent-content: var(--color-sky-600);
|
|
106
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
&&.button--color-indigo {
|
|
110
|
+
--btn-color-accent: var(--color-indigo-500);
|
|
111
|
+
--btn-color-accent-content: var(--color-indigo-600);
|
|
112
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
&&.button--color-violet {
|
|
116
|
+
--btn-color-accent: var(--color-violet-500);
|
|
117
|
+
--btn-color-accent-content: var(--color-violet-600);
|
|
118
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
&&.button--color-purple {
|
|
122
|
+
--btn-color-accent: var(--color-purple-500);
|
|
123
|
+
--btn-color-accent-content: var(--color-purple-600);
|
|
124
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
&&.button--color-fuchsia {
|
|
128
|
+
--btn-color-accent: var(--color-fuchsia-500);
|
|
129
|
+
--btn-color-accent-content: var(--color-fuchsia-600);
|
|
130
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
&&.button--color-pink {
|
|
134
|
+
--btn-color-accent: var(--color-pink-500);
|
|
135
|
+
--btn-color-accent-content: var(--color-pink-600);
|
|
136
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
&&.button--color-rose {
|
|
140
|
+
--btn-color-accent: var(--color-rose-500);
|
|
141
|
+
--btn-color-accent-content: var(--color-rose-600);
|
|
142
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
.dark {
|
|
147
|
+
.button--style-primary {
|
|
148
|
+
&:not([class*="button--color-"]) {
|
|
149
|
+
--btn-color-accent: var(--color-avo-neutral-800);
|
|
150
|
+
--btn-color-accent-content: var(--color-avo-neutral-950);
|
|
151
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
152
|
+
background: linear-gradient(180deg, var(--btn-color-accent-content) 0%, var(--btn-color-accent) 100%);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
.button--style-outline {
|
|
157
|
+
--btn-color-accent: var(--color-avo-neutral-50);
|
|
158
|
+
--btn-color-accent-content: var(--color-avo-neutral-100);
|
|
159
|
+
--btn-color-accent-foreground: var(--color-avo-neutral-950);
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
.button--style-text {
|
|
163
|
+
&:not([class*="button--color-"]) {
|
|
164
|
+
|
|
165
|
+
--btn-text-color: var(--color-avo-neutral-50);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
.button.button--color-primary {
|
|
170
|
+
--btn-color-accent: var(--color-avo-neutral-50);
|
|
171
|
+
--btn-color-accent-content: var(--color-avo-neutral-100);
|
|
172
|
+
--btn-color-accent-foreground: var(--color-avo-neutral-950);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
/* Primary style */
|
|
177
|
+
.button--style-primary {
|
|
178
|
+
@apply text-(--btn-color-accent-foreground) border-(--btn-color-accent-content);
|
|
179
|
+
background: linear-gradient(180deg, var(--btn-color-accent-content) 0%, var(--btn-color-accent) 100%);
|
|
180
|
+
|
|
181
|
+
&:not([class*="button--color-"]) {
|
|
182
|
+
background: linear-gradient(180deg, var(--color-white) 0%, var(--color-white) 100%);
|
|
183
|
+
|
|
184
|
+
&.button--hover,
|
|
185
|
+
&:hover {
|
|
186
|
+
background: linear-gradient(180deg, color-mix(in oklab, var(--btn-color-accent-content) 96%, var(--color-black)) 0%, color-mix(in oklab, var(--btn-color-accent) 96%, var(--color-black)) 100%);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
box-shadow:
|
|
191
|
+
0 -0.5px 0 0.1px var(--btn-color-accent-content) inset,
|
|
192
|
+
0 0.8px 0 0.1px color-mix(in oklab, var(--color-white) 45%, transparent) inset;
|
|
193
|
+
|
|
194
|
+
&.button--hover,
|
|
195
|
+
&:hover {
|
|
196
|
+
@apply text-(--btn-color-accent-foreground);
|
|
197
|
+
|
|
198
|
+
background: linear-gradient(180deg, color-mix(in oklab, var(--btn-color-accent-content) 90%, var(--color-black)) 0%, color-mix(in oklab, var(--btn-color-accent) 90%, var(--color-black)) 100%), var(--color-primary);
|
|
199
|
+
box-shadow: 0 -0.5px 0 0.1px var(--btn-color-accent-content) inset, 0 0.8px 0 0.1px color-mix(in oklab, var(--color-white) 45%, transparent) inset;
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
&.button--active,
|
|
203
|
+
&:active {
|
|
204
|
+
@apply bg-accent;
|
|
205
|
+
box-shadow: 0 0.5px 2px 0.5px var(--btn-color-accent-content) inset;
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
&.button--disabled,
|
|
209
|
+
&:disabled,
|
|
210
|
+
&[disabled],
|
|
211
|
+
&[data-disabled='true'] {
|
|
212
|
+
@apply text-(--btn-color-accent-foreground) border-transparent;
|
|
213
|
+
box-shadow: none;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
/* Outline style */
|
|
218
|
+
.button--style-outline {
|
|
219
|
+
@apply text-(--btn-text-color);
|
|
220
|
+
|
|
221
|
+
/* Special override to make it look more neutral when standlone */
|
|
222
|
+
&:not([class*="button--color-"]) {
|
|
223
|
+
@apply text-content border-content-secondary/50;
|
|
224
|
+
|
|
225
|
+
--btn-box-shadow-color: color-mix(in oklab, var(--color-content), transparent 65%);
|
|
226
|
+
|
|
227
|
+
&.button--hover,
|
|
228
|
+
&:hover {
|
|
229
|
+
--btn-box-shadow-color: color-mix(in oklab, var(--color-content), transparent 55%);
|
|
230
|
+
@apply text-content bg-tertiary;
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
&.button--disabled,
|
|
234
|
+
&:disabled,
|
|
235
|
+
&[disabled],
|
|
236
|
+
&[data-disabled='true'] {
|
|
237
|
+
@apply text-content-secondary border-content-secondary;
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
--btn-box-shadow-color: color-mix(in oklab, var(--btn-color-accent), transparent 65%);
|
|
242
|
+
|
|
243
|
+
border-color: var(--btn-color-accent);
|
|
244
|
+
background: var(--color-primary);
|
|
245
|
+
box-shadow: 0 -1.5px 0 0 var(--btn-box-shadow-color) inset, 0 0.8px 0 0px var(--color-primary) inset;
|
|
246
|
+
|
|
247
|
+
&.button--hover,
|
|
248
|
+
&:hover {
|
|
249
|
+
@apply text-(--btn-text-color);
|
|
250
|
+
|
|
251
|
+
--btn-box-shadow-color: color-mix(in oklab, var(--btn-color-accent), transparent 55%);
|
|
252
|
+
background: color-mix(in oklab, var(--btn-color-accent), var(--color-primary) 85%);
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
&.button--active:not(:disabled),
|
|
256
|
+
&:active:not(:disabled) {
|
|
257
|
+
background-color: color-mix(in oklab, var(--btn-color-accent-content) 10%, transparent);
|
|
258
|
+
|
|
259
|
+
box-shadow: 0 4px 4px 0.5px color-mix(in oklab, var(--color-black) 4%, transparent) inset;
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
&.button--disabled,
|
|
263
|
+
&:disabled,
|
|
264
|
+
&[disabled],
|
|
265
|
+
&[data-disabled='true'] {
|
|
266
|
+
@apply bg-secondary text-(--btn-color-accent-content);
|
|
267
|
+
box-shadow: none;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
/* Tertiary style (outline buttons) */
|
|
272
|
+
.button--style-text {
|
|
273
|
+
@apply bg-transparent text-(--btn-text-color) border border-transparent;
|
|
274
|
+
|
|
275
|
+
&:not([class*="button--color-"]) {
|
|
276
|
+
--btn-color-accent: var(--color-avo-neutral-800);
|
|
277
|
+
--btn-color-accent-content: var(--color-avo-neutral-950);
|
|
278
|
+
--btn-color-accent-foreground: var(--color-white);
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
&.button--hover,
|
|
282
|
+
&:hover {
|
|
283
|
+
@apply bg-secondary text-(--btn-text-color);
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
&.button--active,
|
|
287
|
+
&:active {
|
|
288
|
+
@apply bg-secondary;
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
&.button--disabled,
|
|
292
|
+
&:disabled,
|
|
293
|
+
&[disabled],
|
|
294
|
+
&[data-disabled='true'] {
|
|
295
|
+
@apply text-content;
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
/* Size variants */
|
|
300
|
+
.button--size-xs {
|
|
301
|
+
@apply text-xs px-2 py-1.5;
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
.button--size-sm {
|
|
305
|
+
@apply text-xs px-2 py-1.5;
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
.button--size-md {
|
|
309
|
+
@apply text-sm px-3 py-2;
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
.button--size-lg {
|
|
313
|
+
@apply text-sm px-3 py-3;
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
/* Icon button sizes */
|
|
317
|
+
.button--size-xs .button__icon,
|
|
318
|
+
.button--size-sm .button__icon{
|
|
319
|
+
@apply h-3;
|
|
320
|
+
}
|
|
321
|
+
.button--size-md .button__icon,
|
|
322
|
+
.button--size-lg .button__icon {
|
|
323
|
+
@apply h-4;
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
/* Icon spacing */
|
|
327
|
+
.button__icon {
|
|
328
|
+
@apply pointer-events-none shrink-0 grow-0 w-auto -my-px;
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
.button__icon:not(:last-child) {
|
|
332
|
+
@apply me-1;
|
|
333
|
+
}
|
|
334
|
+
|
|
335
|
+
/* Loading state */
|
|
336
|
+
.button--loading {
|
|
337
|
+
@apply relative;
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
.button__spinner {
|
|
341
|
+
@apply absolute inset-0 flex items-center justify-center;
|
|
342
|
+
}
|
|
343
|
+
}
|
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
/* Color Scheme Switcher Component - Based on Design System */
|
|
2
|
+
.color-scheme-switcher {
|
|
3
|
+
@apply inline-flex items-center gap-1 p-1 rounded-lg bg-neutral-100 dark:bg-neutral-800 border border-neutral-200 dark:border-neutral-700;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
.color-scheme-switcher__button {
|
|
7
|
+
@apply inline-flex items-center justify-center p-1.5 rounded-md transition-all duration-150 text-neutral-600 dark:text-neutral-400 hover:bg-neutral-200 dark:hover:bg-neutral-700 focus:outline-none focus:ring-2 focus:ring-primary-400 focus:ring-offset-1 active:scale-95;
|
|
8
|
+
@apply border-0 bg-transparent cursor-pointer;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
/* Scheme buttons - active states using scheme selection classes */
|
|
12
|
+
.color-scheme-switcher__button[data-scheme="light"] {
|
|
13
|
+
@apply bg-transparent text-neutral-600 dark:text-neutral-400 shadow-none;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
.scheme-light .color-scheme-switcher__button[data-scheme="light"] {
|
|
17
|
+
@apply bg-white text-primary-600 shadow-sm;
|
|
18
|
+
@apply dark:bg-transparent dark:text-neutral-400 dark:shadow-none;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.color-scheme-switcher__button[data-scheme="dark"] {
|
|
22
|
+
@apply bg-transparent text-neutral-600 dark:text-neutral-400 shadow-none;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.scheme-dark .color-scheme-switcher__button[data-scheme="dark"] {
|
|
26
|
+
@apply bg-white dark:bg-neutral-700 text-primary-600 dark:text-primary-400 shadow-sm;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.color-scheme-switcher__button[data-scheme="auto"] {
|
|
30
|
+
@apply bg-transparent text-neutral-600 dark:text-neutral-400 shadow-none;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.scheme-auto .color-scheme-switcher__button[data-scheme="auto"] {
|
|
34
|
+
@apply bg-white dark:bg-neutral-700 text-primary-600 dark:text-primary-400 shadow-sm;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.color-scheme-switcher__icon {
|
|
38
|
+
@apply size-4;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.color-scheme-switcher__text {
|
|
42
|
+
@apply text-xs font-medium px-1;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/* Theme (neutrals) dropdown */
|
|
46
|
+
.color-scheme-switcher__theme-wrapper {
|
|
47
|
+
@apply relative;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
.color-scheme-switcher__button--theme {
|
|
51
|
+
@apply gap-1;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.color-scheme-switcher__theme-panel {
|
|
55
|
+
@apply absolute top-full mt-2 start-0 z-40;
|
|
56
|
+
@apply rounded-lg bg-white dark:bg-neutral-800;
|
|
57
|
+
@apply border border-neutral-200 dark:border-neutral-700;
|
|
58
|
+
@apply shadow-lg p-2 min-w-[160px];
|
|
59
|
+
animation: css-animate-slide-down 0.15s ease-out;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.color-scheme-switcher__theme-options {
|
|
63
|
+
@apply flex flex-col gap-0.5;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.color-scheme-switcher__theme-option {
|
|
67
|
+
@apply flex items-center gap-2 w-full px-2 py-1.5;
|
|
68
|
+
@apply rounded-md transition-all duration-150;
|
|
69
|
+
@apply hover:bg-neutral-100 dark:hover:bg-neutral-700;
|
|
70
|
+
@apply focus:outline-none focus:ring-2 focus:ring-primary-400 focus:ring-offset-1;
|
|
71
|
+
@apply border-0 bg-transparent cursor-pointer;
|
|
72
|
+
@apply text-neutral-700 dark:text-neutral-300 text-xs font-medium;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
.color-scheme-switcher__theme-option--active {
|
|
76
|
+
@apply bg-neutral-100 dark:bg-neutral-700;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
.color-scheme-switcher__theme-preview {
|
|
80
|
+
@apply size-4 rounded-full border border-neutral-200 dark:border-neutral-600 shadow-sm;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/* Theme preview swatches - show a representative mid-tone for each neutral */
|
|
84
|
+
.color-scheme-switcher__theme-preview--brand {
|
|
85
|
+
background: oklch(62.68% 0.0000 89.88);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.color-scheme-switcher__theme-preview--slate {
|
|
89
|
+
@apply bg-slate-400;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
.color-scheme-switcher__theme-preview--stone {
|
|
93
|
+
@apply bg-stone-400;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
.color-scheme-switcher__theme-preview--gray {
|
|
97
|
+
@apply bg-gray-400;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
.color-scheme-switcher__theme-preview--zinc {
|
|
101
|
+
@apply bg-zinc-400;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
.color-scheme-switcher__theme-preview--neutral {
|
|
105
|
+
@apply bg-neutral-400;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
.color-scheme-switcher__theme-preview--taupe {
|
|
109
|
+
background: oklch(63% 0.012 70);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
.color-scheme-switcher__theme-preview--mauve {
|
|
113
|
+
background: oklch(63% 0.014 310);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
.color-scheme-switcher__theme-preview--mist {
|
|
117
|
+
background: oklch(63% 0.012 240);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
.color-scheme-switcher__theme-preview--olive {
|
|
121
|
+
background: oklch(63% 0.014 140);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
.color-scheme-switcher__theme-option-label {
|
|
125
|
+
@apply leading-none;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
/* Accent color dropdown */
|
|
129
|
+
.color-scheme-switcher__accent-wrapper {
|
|
130
|
+
@apply relative;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
.color-scheme-switcher__accent-panel {
|
|
134
|
+
@apply absolute top-full mt-2 end-0 z-40;
|
|
135
|
+
@apply rounded-lg bg-white dark:bg-neutral-800;
|
|
136
|
+
@apply border border-neutral-200 dark:border-neutral-700;
|
|
137
|
+
@apply shadow-lg p-2 min-w-[160px];
|
|
138
|
+
animation: css-animate-slide-down 0.15s ease-out;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
.color-scheme-switcher__accent-options {
|
|
142
|
+
@apply grid grid-cols-3 gap-2;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
.color-scheme-switcher__accent-option {
|
|
146
|
+
@apply flex items-center justify-center p-1;
|
|
147
|
+
@apply rounded-md transition-all duration-150;
|
|
148
|
+
@apply hover:bg-neutral-100 dark:hover:bg-neutral-700;
|
|
149
|
+
@apply focus:outline-none focus:ring-2 focus:ring-primary-400 focus:ring-offset-1;
|
|
150
|
+
@apply border-0 bg-transparent cursor-pointer;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
.color-scheme-switcher__accent-option--active {
|
|
154
|
+
@apply bg-neutral-100 dark:bg-neutral-700 ring-2 ring-primary-400 ring-offset-1;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
.color-scheme-switcher__accent-preview {
|
|
158
|
+
@apply size-6 rounded-full border-2 border-white dark:border-neutral-600 shadow-sm;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
.color-scheme-switcher__accent-preview--neutral {
|
|
162
|
+
@apply bg-neutral-400 dark:bg-neutral-500;
|
|
163
|
+
background-image: linear-gradient(135deg, transparent 45%, white 45%, white 55%, transparent 55%);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
/* Accent button with badge */
|
|
167
|
+
.color-scheme-switcher__button--accent {
|
|
168
|
+
@apply relative;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
.color-scheme-switcher__accent-badge {
|
|
172
|
+
@apply absolute top-0 end-0;
|
|
173
|
+
@apply translate-x-1/2 -translate-y-1/2;
|
|
174
|
+
@apply hidden;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
.color-scheme-switcher__accent-badge-preview {
|
|
178
|
+
@apply size-2 rounded-full border border-white dark:border-neutral-800 shadow-sm;
|
|
179
|
+
@apply hidden;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
.color-scheme-switcher__accent-badge-preview--neutral {
|
|
183
|
+
@apply bg-neutral-400 dark:bg-neutral-500;
|
|
184
|
+
background-image: linear-gradient(135deg, transparent 45%, white 45%, white 55%, transparent 55%);
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
/* Show accent badge based on body accent class */
|
|
188
|
+
.accent-red .color-scheme-switcher__accent-badge,
|
|
189
|
+
.accent-orange .color-scheme-switcher__accent-badge,
|
|
190
|
+
.accent-amber .color-scheme-switcher__accent-badge,
|
|
191
|
+
.accent-yellow .color-scheme-switcher__accent-badge,
|
|
192
|
+
.accent-lime .color-scheme-switcher__accent-badge,
|
|
193
|
+
.accent-green .color-scheme-switcher__accent-badge,
|
|
194
|
+
.accent-emerald .color-scheme-switcher__accent-badge,
|
|
195
|
+
.accent-teal .color-scheme-switcher__accent-badge,
|
|
196
|
+
.accent-cyan .color-scheme-switcher__accent-badge,
|
|
197
|
+
.accent-sky .color-scheme-switcher__accent-badge,
|
|
198
|
+
.accent-blue .color-scheme-switcher__accent-badge,
|
|
199
|
+
.accent-indigo .color-scheme-switcher__accent-badge,
|
|
200
|
+
.accent-violet .color-scheme-switcher__accent-badge,
|
|
201
|
+
.accent-purple .color-scheme-switcher__accent-badge,
|
|
202
|
+
.accent-fuchsia .color-scheme-switcher__accent-badge,
|
|
203
|
+
.accent-pink .color-scheme-switcher__accent-badge,
|
|
204
|
+
.accent-rose .color-scheme-switcher__accent-badge {
|
|
205
|
+
@apply inline-block;
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
.accent-red .color-scheme-switcher__accent-badge-preview--red,
|
|
209
|
+
.accent-orange .color-scheme-switcher__accent-badge-preview--orange,
|
|
210
|
+
.accent-amber .color-scheme-switcher__accent-badge-preview--amber,
|
|
211
|
+
.accent-yellow .color-scheme-switcher__accent-badge-preview--yellow,
|
|
212
|
+
.accent-lime .color-scheme-switcher__accent-badge-preview--lime,
|
|
213
|
+
.accent-green .color-scheme-switcher__accent-badge-preview--green,
|
|
214
|
+
.accent-emerald .color-scheme-switcher__accent-badge-preview--emerald,
|
|
215
|
+
.accent-teal .color-scheme-switcher__accent-badge-preview--teal,
|
|
216
|
+
.accent-cyan .color-scheme-switcher__accent-badge-preview--cyan,
|
|
217
|
+
.accent-sky .color-scheme-switcher__accent-badge-preview--sky,
|
|
218
|
+
.accent-blue .color-scheme-switcher__accent-badge-preview--blue,
|
|
219
|
+
.accent-indigo .color-scheme-switcher__accent-badge-preview--indigo,
|
|
220
|
+
.accent-violet .color-scheme-switcher__accent-badge-preview--violet,
|
|
221
|
+
.accent-purple .color-scheme-switcher__accent-badge-preview--purple,
|
|
222
|
+
.accent-fuchsia .color-scheme-switcher__accent-badge-preview--fuchsia,
|
|
223
|
+
.accent-pink .color-scheme-switcher__accent-badge-preview--pink,
|
|
224
|
+
.accent-rose .color-scheme-switcher__accent-badge-preview--rose {
|
|
225
|
+
@apply inline-block;
|
|
226
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
.discreet-information {
|
|
2
|
+
@apply inline-flex shrink-0 rounded-md gap-1 items-center py-0.5 text-xs h-6 text-content-secondary;
|
|
3
|
+
}
|
|
4
|
+
|
|
5
|
+
.discreet-information__icon {
|
|
6
|
+
@apply inline size-4 text-content-secondary;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
.discreet-information__text {
|
|
10
|
+
@apply inline px-2;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.discreet-information__badge {
|
|
14
|
+
@apply inline-flex rounded-md items-center font-semibold gap-1 py-1 px-1 bg-linear-to-b from-primary/85 to-primary/85 bg-foreground text-foreground;
|
|
15
|
+
|
|
16
|
+
.discreet-information__icon {
|
|
17
|
+
@apply text-foreground me-1 size-3;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.discreet-information__key-value {
|
|
22
|
+
@apply inline-flex items-center;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.discreet-information__key {
|
|
26
|
+
@apply rounded-sm py-0.5 px-2 font-normal bg-linear-to-b to-avo-neutral-200 from-foreground/6 to-black/4 bg-secondary;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.discreet-information--as-key-value,
|
|
30
|
+
.discreet-information--as-badge {
|
|
31
|
+
@apply text-content-secondary font-semibold rounded-md;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
.discreet-information--as-text {
|
|
35
|
+
@apply items-center;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
.discreet-information--as-badge {
|
|
39
|
+
@apply rounded-md;
|
|
40
|
+
|
|
41
|
+
.discreet-information__text {
|
|
42
|
+
@apply px-1;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.discreet-information--as-key-value {
|
|
47
|
+
@apply inline-flex items-center bg-secondary px-0.5;
|
|
48
|
+
}
|
|
49
|
+
|