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.
Files changed (470) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +18 -1
  3. data/Gemfile.lock +257 -174
  4. data/README.md +1 -1
  5. data/app/assets/builds/avo/application.css +13979 -0
  6. data/app/assets/builds/avo/application.js +1160 -0
  7. data/app/assets/builds/avo/application.js.map +7 -0
  8. data/app/assets/builds/avo/late-registration.js +2 -0
  9. data/app/assets/builds/avo/late-registration.js.map +7 -0
  10. data/app/assets/config/avo_manifest.js +2 -1
  11. data/app/assets/images/avo/placeholder.svg +1 -0
  12. data/app/assets/stylesheets/application.css +250 -0
  13. data/app/assets/stylesheets/css/button-group.css +23 -0
  14. data/app/assets/stylesheets/css/components/avatar.css +128 -0
  15. data/app/assets/stylesheets/css/components/breadcrumbs.css +43 -0
  16. data/app/assets/stylesheets/css/components/button.css +343 -0
  17. data/app/assets/stylesheets/css/components/color_scheme_switcher.css +226 -0
  18. data/app/assets/stylesheets/css/components/discreet_information.css +49 -0
  19. data/app/assets/stylesheets/css/components/field-wrapper.css +107 -0
  20. data/app/assets/stylesheets/css/components/grid.css +120 -0
  21. data/app/assets/stylesheets/css/components/input.css +312 -0
  22. data/app/assets/stylesheets/css/components/modal.css +228 -0
  23. data/app/assets/stylesheets/css/components/tooltip.css +25 -0
  24. data/app/assets/stylesheets/css/components/ui/badge.css +143 -0
  25. data/app/assets/stylesheets/css/components/ui/card.css +95 -0
  26. data/app/assets/stylesheets/css/components/ui/checkbox.css +50 -0
  27. data/app/assets/stylesheets/css/components/ui/description_list.css +3 -0
  28. data/app/assets/stylesheets/css/components/ui/dropdown.css +68 -0
  29. data/app/assets/stylesheets/css/components/ui/file_upload_input.css +94 -0
  30. data/app/assets/stylesheets/css/components/ui/file_upload_item.css +78 -0
  31. data/app/assets/stylesheets/css/components/ui/panel.css +59 -0
  32. data/app/assets/stylesheets/css/components/ui/panel_header.css +48 -0
  33. data/app/assets/stylesheets/css/components/ui/radio.css +22 -0
  34. data/app/assets/stylesheets/css/components/ui/tabs.css +74 -0
  35. data/app/assets/stylesheets/css/css-animations.css +54 -0
  36. data/app/assets/stylesheets/css/fields/code.css +75 -9
  37. data/app/assets/stylesheets/css/fields/easy-mde.css +7 -0
  38. data/app/assets/stylesheets/css/fields/key_value.css +97 -0
  39. data/app/assets/stylesheets/css/fields/progress.css +4 -4
  40. data/app/assets/stylesheets/css/fields/status.css +7 -1
  41. data/app/assets/stylesheets/css/fields/tags.css +33 -16
  42. data/app/assets/stylesheets/css/fields/tiptap.css +17 -15
  43. data/app/assets/stylesheets/css/fields/trix.css +62 -2
  44. data/app/assets/stylesheets/css/fonts.css +24 -24
  45. data/app/assets/stylesheets/css/layout.css +135 -0
  46. data/app/assets/stylesheets/css/pagination.css +114 -78
  47. data/app/assets/stylesheets/css/resource-controls.css +13 -0
  48. data/app/assets/stylesheets/css/search.css +22 -12
  49. data/app/assets/stylesheets/css/sidebar.css +310 -24
  50. data/app/assets/stylesheets/css/table.css +60 -0
  51. data/app/assets/stylesheets/css/tooltips.css +1 -1
  52. data/app/assets/stylesheets/css/typography.css +10 -1
  53. data/app/assets/stylesheets/css/variables.css +318 -0
  54. data/app/assets/svgs/avo/moon-plus-plus.svg +1 -0
  55. data/app/components/avo/actions_component.html.erb +30 -36
  56. data/app/components/avo/actions_component.rb +8 -11
  57. data/app/components/avo/alert_component.html.erb +3 -3
  58. data/app/components/avo/alert_component.rb +1 -1
  59. data/app/components/avo/asset_manager/javascript_component.html.erb +1 -2
  60. data/app/components/avo/backtrace_alert_component.html.erb +4 -4
  61. data/app/components/avo/base_component.rb +3 -4
  62. data/app/components/avo/breadcrumb_element_component.html.erb +17 -0
  63. data/app/components/avo/breadcrumb_element_component.rb +21 -0
  64. data/app/components/avo/breadcrumbs_component.html.erb +19 -0
  65. data/app/components/avo/breadcrumbs_component.rb +5 -0
  66. data/app/components/avo/button_component.rb +20 -126
  67. data/app/components/avo/clipboard_component.html.erb +3 -2
  68. data/app/components/avo/clipboard_component.rb +1 -1
  69. data/app/components/avo/component_missing_component.rb +11 -0
  70. data/app/components/avo/cover_component.html.erb +3 -0
  71. data/app/components/avo/cover_component.rb +25 -0
  72. data/app/components/avo/debug/status_component.html.erb +59 -0
  73. data/app/components/avo/debug/status_component.rb +30 -0
  74. data/app/components/avo/description_list_component.rb +11 -0
  75. data/app/components/avo/discreet_information_component.html.erb +31 -6
  76. data/app/components/avo/discreet_information_component.rb +23 -32
  77. data/app/components/avo/divider_component.html.erb +2 -2
  78. data/app/components/avo/empty_state_component.html.erb +2 -9
  79. data/app/components/avo/empty_state_component.rb +0 -8
  80. data/app/components/avo/field_wrapper_component.html.erb +21 -22
  81. data/app/components/avo/field_wrapper_component.rb +9 -18
  82. data/app/components/avo/fields/avatar_field/index_component.html.erb +9 -0
  83. data/app/components/avo/fields/avatar_field/index_component.rb +4 -0
  84. data/app/components/avo/fields/badge_field/index_component.html.erb +7 -1
  85. data/app/components/avo/fields/badge_field/show_component.html.erb +6 -1
  86. data/app/components/avo/fields/belongs_to_field/edit_component.html.erb +16 -14
  87. data/app/components/avo/fields/belongs_to_field/edit_component.rb +13 -3
  88. data/app/components/avo/fields/boolean_field/edit_component.html.erb +2 -2
  89. data/app/components/avo/fields/boolean_group_field/edit_component.html.erb +1 -1
  90. data/app/components/avo/fields/boolean_group_field/edit_component.rb +2 -3
  91. data/app/components/avo/fields/code_field/show_component.html.erb +1 -1
  92. data/app/components/avo/fields/common/boolean_check_component.rb +3 -3
  93. data/app/components/avo/fields/common/boolean_group_component.html.erb +2 -2
  94. data/app/components/avo/fields/common/files/controls_component.html.erb +30 -27
  95. data/app/components/avo/fields/common/files/controls_component.rb +0 -1
  96. data/app/components/avo/fields/common/files/list_viewer_component.html.erb +4 -5
  97. data/app/components/avo/fields/common/files/view_type/grid_item_component.html.erb +1 -1
  98. data/app/components/avo/fields/common/files/view_type/list_item_component.html.erb +7 -19
  99. data/app/components/avo/fields/common/heading_component.html.erb +2 -2
  100. data/app/components/avo/fields/common/heading_component.rb +1 -1
  101. data/app/components/avo/fields/common/key_value_component.html.erb +20 -24
  102. data/app/components/avo/fields/common/nested_field_component.html.erb +1 -1
  103. data/app/components/avo/fields/common/nested_field_component.rb +1 -1
  104. data/app/components/avo/fields/common/progress_bar_component.html.erb +2 -2
  105. data/app/components/avo/fields/common/stars_component.html.erb +1 -1
  106. data/app/components/avo/fields/common/status_viewer_component.html.erb +4 -10
  107. data/app/components/avo/fields/date_field/edit_component.html.erb +14 -1
  108. data/app/components/avo/fields/date_time_field/edit_component.html.erb +3 -3
  109. data/app/components/avo/fields/easy_mde_field/show_component.html.erb +1 -1
  110. data/app/components/avo/fields/edit_component.rb +9 -5
  111. data/app/components/avo/fields/file_field/edit_component.html.erb +14 -6
  112. data/app/components/avo/fields/files_field/edit_component.html.erb +11 -4
  113. data/app/components/avo/fields/has_one_field/show_component.html.erb +10 -9
  114. data/app/components/avo/fields/heading_field/edit_component.html.erb +1 -1
  115. data/app/components/avo/fields/heading_field/show_component.html.erb +2 -2
  116. data/app/components/avo/fields/password_field/edit_component.html.erb +5 -7
  117. data/app/components/avo/fields/progress_bar_field/edit_component.html.erb +1 -1
  118. data/app/components/avo/fields/radio_field/edit_component.html.erb +1 -1
  119. data/app/components/avo/fields/show_component.rb +4 -7
  120. data/app/components/avo/fields/stars_field/edit_component.html.erb +3 -4
  121. data/app/components/avo/fields/tags_field/edit_component.html.erb +1 -1
  122. data/app/components/avo/fields/tags_field/tag_component.html.erb +7 -8
  123. data/app/components/avo/fields/time_field/edit_component.html.erb +3 -3
  124. data/app/components/avo/fields/tiptap_field/edit_component.html.erb +11 -11
  125. data/app/components/avo/fields/tiptap_field/show_component.html.erb +4 -4
  126. data/app/components/avo/fields/trix_field/edit_component.html.erb +2 -2
  127. data/app/components/avo/filters_component.html.erb +8 -16
  128. data/app/components/avo/index/field_wrapper_component.html.erb +9 -2
  129. data/app/components/avo/index/field_wrapper_component.rb +0 -16
  130. data/app/components/avo/index/grid_cover_empty_state_component.html.erb +16 -2
  131. data/app/components/avo/index/grid_cover_empty_state_component.rb +90 -0
  132. data/app/components/avo/index/grid_item_component.html.erb +29 -12
  133. data/app/components/avo/index/grid_item_component.rb +12 -10
  134. data/app/components/avo/index/resource_controls_component.html.erb +1 -1
  135. data/app/components/avo/index/resource_controls_component.rb +7 -17
  136. data/app/components/avo/index/resource_controls_dropdown_component.html.erb +3 -0
  137. data/app/components/avo/index/resource_controls_dropdown_component.rb +81 -0
  138. data/app/components/avo/index/table_row_component.html.erb +11 -11
  139. data/app/components/avo/items/panel_component.html.erb +8 -18
  140. data/app/components/avo/items/panel_component.rb +0 -20
  141. data/app/components/avo/items/switcher_component.html.erb +60 -1
  142. data/app/components/avo/items/switcher_component.rb +10 -5
  143. data/app/components/avo/items/visible_items_component.html.erb +2 -1
  144. data/app/components/avo/items/visible_items_component.rb +1 -0
  145. data/app/components/avo/media_library/item_details_component.html.erb +2 -2
  146. data/app/components/avo/media_library/list_component.html.erb +24 -19
  147. data/app/components/avo/media_library/list_component.rb +2 -2
  148. data/app/components/avo/media_library/list_item_component.html.erb +3 -3
  149. data/app/components/avo/modal_component.html.erb +52 -20
  150. data/app/components/avo/modal_component.rb +7 -12
  151. data/app/components/avo/paginator_component.html.erb +46 -33
  152. data/app/components/avo/paginator_component.rb +10 -5
  153. data/app/components/avo/panel_name_component.html.erb +1 -1
  154. data/app/components/avo/profile_item_component.html.erb +4 -4
  155. data/app/components/avo/profile_item_component.rb +2 -4
  156. data/app/components/avo/referrer_params_component.html.erb +1 -1
  157. data/app/components/avo/resource_component.rb +8 -19
  158. data/app/components/avo/resource_listing_component.html.erb +22 -0
  159. data/app/components/avo/resource_listing_component.rb +28 -0
  160. data/app/components/avo/resource_sidebar_component.html.erb +2 -2
  161. data/app/components/avo/resource_sidebar_component.rb +0 -4
  162. data/app/components/avo/row_component.html.erb +1 -1
  163. data/app/components/avo/row_selector_component.html.erb +2 -4
  164. data/app/components/avo/row_selector_component.rb +0 -1
  165. data/app/components/avo/search_overlay_component.html.erb +6 -0
  166. data/app/components/avo/search_overlay_component.rb +2 -0
  167. data/app/components/avo/sidebar/base_item_component.rb +9 -9
  168. data/app/components/avo/sidebar/group_component.html.erb +23 -27
  169. data/app/components/avo/sidebar/group_component.rb +4 -0
  170. data/app/components/avo/sidebar/link_component.html.erb +30 -7
  171. data/app/components/avo/sidebar/link_component.rb +30 -2
  172. data/app/components/avo/sidebar/section_component.html.erb +31 -11
  173. data/app/components/avo/sidebar/section_component.rb +1 -3
  174. data/app/components/avo/sidebar_component.html.erb +35 -36
  175. data/app/components/avo/sidebar_component.rb +16 -0
  176. data/app/components/avo/sidebar_profile_component.html.erb +27 -36
  177. data/app/components/avo/sidebar_profile_component.rb +14 -0
  178. data/app/components/avo/tab_group_component.html.erb +21 -9
  179. data/app/components/avo/tab_group_component.rb +54 -15
  180. data/app/components/avo/turbo_frame_wrapper_component.html.erb +4 -8
  181. data/app/components/avo/turbo_frame_wrapper_component.rb +9 -0
  182. data/app/components/avo/u_i/avatar_component.html.erb +11 -0
  183. data/app/components/avo/u_i/avatar_component.rb +61 -0
  184. data/app/components/avo/u_i/badge_component.html.erb +9 -0
  185. data/app/components/avo/u_i/badge_component.rb +35 -0
  186. data/app/components/avo/u_i/card_component.html.erb +29 -0
  187. data/app/components/avo/u_i/card_component.rb +65 -0
  188. data/app/components/avo/u_i/dropdown_component.html.erb +14 -0
  189. data/app/components/avo/u_i/dropdown_component.rb +26 -0
  190. data/app/components/avo/u_i/dropdown_menu_component.html.erb +16 -0
  191. data/app/components/avo/u_i/dropdown_menu_component.rb +8 -0
  192. data/app/components/avo/u_i/file_upload_input_component.html.erb +26 -0
  193. data/app/components/avo/u_i/file_upload_input_component.rb +15 -0
  194. data/app/components/avo/u_i/file_upload_item_component.html.erb +48 -0
  195. data/app/components/avo/u_i/file_upload_item_component.rb +17 -0
  196. data/app/components/avo/u_i/icon_button_component.html.erb +7 -0
  197. data/app/components/avo/u_i/icon_button_component.rb +22 -0
  198. data/app/components/avo/u_i/panel_component.html.erb +49 -0
  199. data/app/components/avo/u_i/panel_component.rb +29 -0
  200. data/app/components/avo/u_i/panel_header_component.html.erb +37 -0
  201. data/app/components/avo/u_i/panel_header_component.rb +24 -0
  202. data/app/components/avo/u_i/search_input_component.html.erb +28 -0
  203. data/app/components/avo/u_i/search_input_component.rb +12 -0
  204. data/app/components/avo/u_i/tabs/tab_component.html.erb +26 -0
  205. data/app/components/avo/u_i/tabs/tab_component.rb +25 -0
  206. data/app/components/avo/u_i/tabs/tabs_component.html.erb +7 -0
  207. data/app/components/avo/u_i/tabs/tabs_component.rb +13 -0
  208. data/app/components/avo/view_types/base_view_type_component.rb +26 -0
  209. data/app/components/avo/view_types/grid_component.html.erb +18 -0
  210. data/app/components/avo/view_types/grid_component.rb +4 -0
  211. data/app/components/avo/view_types/map_component.html.erb +17 -0
  212. data/app/components/avo/view_types/map_component.rb +110 -0
  213. data/app/components/avo/view_types/table_component.html.erb +63 -0
  214. data/app/components/avo/{index/resource_table_component.rb → view_types/table_component.rb} +1 -10
  215. data/app/components/avo/views/resource_edit_component.html.erb +12 -18
  216. data/app/components/avo/views/resource_edit_component.rb +1 -27
  217. data/app/components/avo/views/resource_index_component.html.erb +97 -74
  218. data/app/components/avo/views/resource_index_component.rb +23 -3
  219. data/app/components/avo/views/resource_show_component.html.erb +4 -2
  220. data/app/components/avo/views/resource_show_component.rb +1 -4
  221. data/app/controllers/avo/associations_controller.rb +1 -1
  222. data/app/controllers/avo/base_application_controller.rb +7 -5
  223. data/app/controllers/avo/base_controller.rb +139 -40
  224. data/app/controllers/avo/debug_controller.rb +0 -29
  225. data/app/controllers/avo/media_library_controller.rb +17 -1
  226. data/app/controllers/avo/search_controller.rb +5 -0
  227. data/app/controllers/concerns/avo/initializes_avo.rb +7 -8
  228. data/app/helpers/avo/application_helper.rb +60 -46
  229. data/app/helpers/avo/turbo_stream_actions_helper.rb +10 -1
  230. data/app/helpers/avo/url_helpers.rb +3 -2
  231. data/app/javascript/{avo.base.js → application.js} +9 -18
  232. data/app/javascript/js/application.js +40 -0
  233. data/app/javascript/js/controllers/action_controller.js +4 -4
  234. data/app/javascript/js/controllers/actions_overflow_controller.js +21 -6
  235. data/app/javascript/js/controllers/color_scheme_switcher_controller.js +226 -0
  236. data/app/javascript/js/controllers/dropdown_menu_controller.js +42 -0
  237. data/app/javascript/js/controllers/fields/code_field_controller.js +20 -3
  238. data/app/javascript/js/controllers/fields/easy_mde_controller.js +23 -1
  239. data/app/javascript/js/controllers/fields/key_value_controller.js +43 -39
  240. data/app/javascript/js/controllers/fields/panel_refresh_controller.js +4 -0
  241. data/app/javascript/js/controllers/fields/tags_field_controller.js +2 -2
  242. data/app/javascript/js/controllers/fields/tags_field_helpers.js +4 -6
  243. data/app/javascript/js/controllers/grid_cover_empty_state_controller.js +42 -0
  244. data/app/javascript/js/controllers/item_selector_controller.js +0 -2
  245. data/app/javascript/js/controllers/loading_button_controller.js +1 -5
  246. data/app/javascript/js/controllers/map_dark_mode_controller.js +131 -0
  247. data/app/javascript/js/controllers/menu_controller.js +38 -16
  248. data/app/javascript/js/controllers/modal_controller.js +16 -0
  249. data/app/javascript/js/controllers/modal_size_controller.js +83 -0
  250. data/app/javascript/js/controllers/nested_form_controller.js +2 -2
  251. data/app/javascript/js/controllers/password_visibility_controller.js +13 -0
  252. data/app/javascript/js/controllers/preview_controller.js +2 -2
  253. data/app/javascript/js/controllers/resource_search_controller.js +123 -0
  254. data/app/javascript/js/controllers/search_controller.js +10 -29
  255. data/app/javascript/js/controllers/sidebar_controller.js +29 -9
  256. data/app/javascript/js/controllers/table_row_controller.js +28 -0
  257. data/app/javascript/js/controllers/tippy_controller.js +1 -1
  258. data/app/javascript/js/controllers/toggle_controller.js +40 -5
  259. data/app/javascript/js/controllers.js +14 -2
  260. data/app/javascript/js/custom-stream-actions.js +10 -8
  261. data/app/views/avo/actions/show.html.erb +14 -10
  262. data/app/views/avo/base/_boolean_filter.html.erb +1 -1
  263. data/app/views/avo/base/_date_time_filter.html.erb +3 -3
  264. data/app/views/avo/base/_multiple_select_filter.html.erb +1 -1
  265. data/app/views/avo/base/_new_via_belongs_to.html.erb +2 -3
  266. data/app/views/avo/base/_text_filter.html.erb +1 -1
  267. data/app/views/avo/base/preview.html.erb +5 -4
  268. data/app/views/avo/debug/status.html.erb +5 -92
  269. data/app/views/avo/debug/status.text.erb +0 -2
  270. data/app/views/avo/home/_actions.html.erb +1 -1
  271. data/app/views/avo/home/_dashboards.html.erb +1 -1
  272. data/app/views/avo/home/_filters.html.erb +1 -1
  273. data/app/views/avo/home/_resources.html.erb +2 -2
  274. data/app/views/avo/home/failed_to_load.html.erb +2 -2
  275. data/app/views/avo/home/index.html.erb +25 -25
  276. data/app/views/avo/media_library/_form.html.erb +43 -28
  277. data/app/views/avo/media_library/show.html.erb +7 -3
  278. data/app/views/avo/modal/_size_selector.html.erb +46 -0
  279. data/app/views/avo/partials/_alerts.html.erb +1 -1
  280. data/app/views/avo/partials/_color_scheme_switcher.html.erb +106 -0
  281. data/app/views/avo/partials/_color_theme_override.html.erb +49 -0
  282. data/app/views/avo/partials/_confirm_dialog.html.erb +19 -17
  283. data/app/views/avo/partials/_custom_tools_alert.html.erb +6 -6
  284. data/app/views/avo/partials/_footer.html.erb +1 -1
  285. data/app/views/avo/partials/_header.html.erb +1 -1
  286. data/app/views/avo/partials/_javascript.html.erb +0 -2
  287. data/app/views/avo/partials/_navbar.html.erb +53 -8
  288. data/app/views/avo/partials/_sortable_component.html.erb +1 -1
  289. data/app/views/avo/partials/_table_header.html.erb +28 -19
  290. data/app/views/avo/partials/_view_toggle_button.html.erb +6 -29
  291. data/app/views/avo/partials/distribution_chart.html.erb +2 -2
  292. data/app/views/avo/private/_links_and_buttons.html.erb +12 -8
  293. data/app/views/avo/private/design.html.erb +8 -4
  294. data/app/views/avo/sidebar/_license_warning.html.erb +3 -3
  295. data/app/views/layouts/avo/application.html.erb +39 -17
  296. data/app/views/layouts/avo/modal.html.erb +7 -0
  297. data/avo.gemspec +3 -4
  298. data/config/i18n-tasks.yml +1 -1
  299. data/config/importmap.rb +1 -0
  300. data/config/initializers/pagy.rb +5 -25
  301. data/config/routes/dynamic_routes.rb +4 -0
  302. data/config/routes.rb +6 -7
  303. data/db/factories.rb +14 -0
  304. data/lib/avo/asset_manager.rb +2 -0
  305. data/lib/avo/avatar.rb +7 -0
  306. data/lib/avo/base_action.rb +16 -4
  307. data/lib/avo/concerns/breadcrumbs.rb +7 -66
  308. data/lib/avo/concerns/form_builder.rb +41 -0
  309. data/lib/avo/concerns/{has_profile_photo.rb → has_avatar.rb} +8 -4
  310. data/lib/avo/concerns/{has_cover_photo.rb → has_cover.rb} +4 -4
  311. data/lib/avo/concerns/has_description.rb +9 -0
  312. data/lib/avo/concerns/has_item_type.rb +6 -2
  313. data/lib/avo/concerns/has_items.rb +43 -58
  314. data/lib/avo/concerns/pagination.rb +29 -19
  315. data/lib/avo/concerns/row_controls_configuration.rb +22 -15
  316. data/lib/avo/configuration/branding.rb +7 -7
  317. data/lib/avo/configuration.rb +92 -45
  318. data/lib/avo/{cover_photo.rb → cover.rb} +2 -2
  319. data/lib/avo/current.rb +0 -11
  320. data/lib/avo/discreet_information.rb +52 -29
  321. data/lib/avo/dsl/field_parser.rb +1 -1
  322. data/lib/avo/engine.rb +41 -8
  323. data/lib/avo/error_manager.rb +1 -1
  324. data/lib/avo/fields/avatar_field.rb +19 -0
  325. data/lib/avo/fields/badge_field.rb +23 -3
  326. data/lib/avo/fields/base_field.rb +46 -1
  327. data/lib/avo/fields/concerns/dom_id.rb +17 -0
  328. data/lib/avo/fields/concerns/file_authorization.rb +4 -0
  329. data/lib/avo/fields/concerns/has_html_attributes.rb +1 -1
  330. data/lib/avo/fields/concerns/is_searchable.rb +2 -5
  331. data/lib/avo/fields/concerns/nested.rb +1 -1
  332. data/lib/avo/fields/files_field.rb +2 -2
  333. data/lib/avo/fields/frame_base_field.rb +2 -2
  334. data/lib/avo/fields/id_field.rb +5 -1
  335. data/lib/avo/fields/progress_bar_field.rb +1 -1
  336. data/lib/avo/fields/text_field.rb +1 -1
  337. data/lib/avo/photo_object.rb +12 -1
  338. data/lib/avo/plugin_manager.rb +4 -0
  339. data/lib/avo/resources/base.rb +33 -21
  340. data/lib/avo/resources/controls/actions_list.rb +3 -3
  341. data/lib/avo/resources/controls/base_control.rb +1 -1
  342. data/lib/avo/resources/items/card.rb +16 -0
  343. data/lib/avo/resources/items/header.rb +11 -0
  344. data/lib/avo/resources/items/holder.rb +18 -23
  345. data/lib/avo/resources/items/item_group.rb +5 -7
  346. data/lib/avo/resources/items/sidebar.rb +5 -9
  347. data/lib/avo/resources/items/tab.rb +8 -8
  348. data/lib/avo/resources/items/tab_group.rb +8 -10
  349. data/lib/avo/resources/resource_manager.rb +2 -1
  350. data/lib/avo/services/hq_reporter.rb +102 -0
  351. data/lib/avo/services/telemetry_service.rb +0 -1
  352. data/lib/avo/test_helpers.rb +36 -22
  353. data/lib/avo/u_i_instance.rb +60 -0
  354. data/lib/avo/version.rb +1 -1
  355. data/lib/avo/view_inquirer.rb +6 -1
  356. data/lib/avo/view_types/view_type_manager.rb +70 -0
  357. data/lib/avo.rb +30 -45
  358. data/lib/generators/avo/action_generator.rb +1 -1
  359. data/lib/generators/avo/resource_generator.rb +43 -0
  360. data/lib/generators/avo/resource_tool_generator.rb +1 -1
  361. data/lib/generators/avo/tailwindcss/install_generator.rb +0 -6
  362. data/lib/generators/avo/templates/cards/partial_card_partial.tt +1 -1
  363. data/lib/generators/avo/templates/initializer/avo.tt +7 -9
  364. data/lib/generators/avo/templates/locales/avo.ar.yml +25 -0
  365. data/lib/generators/avo/templates/locales/avo.de.yml +25 -0
  366. data/lib/generators/avo/templates/locales/avo.en.yml +25 -0
  367. data/lib/generators/avo/templates/locales/avo.es.yml +25 -0
  368. data/lib/generators/avo/templates/locales/avo.fr.yml +25 -0
  369. data/lib/generators/avo/templates/locales/avo.it.yml +25 -0
  370. data/lib/generators/avo/templates/locales/avo.ja.yml +25 -0
  371. data/lib/generators/avo/templates/locales/avo.nb.yml +25 -0
  372. data/lib/generators/avo/templates/locales/avo.nl.yml +25 -0
  373. data/lib/generators/avo/templates/locales/avo.nn.yml +25 -0
  374. data/lib/generators/avo/templates/locales/avo.pl.yml +25 -0
  375. data/lib/generators/avo/templates/locales/avo.pt-BR.yml +25 -0
  376. data/lib/generators/avo/templates/locales/avo.pt.yml +25 -0
  377. data/lib/generators/avo/templates/locales/avo.ro.yml +25 -0
  378. data/lib/generators/avo/templates/locales/avo.ru.yml +25 -0
  379. data/lib/generators/avo/templates/locales/avo.tr.yml +25 -0
  380. data/lib/generators/avo/templates/locales/{avo.uk.yml → avo.ua.yml} +26 -1
  381. data/lib/generators/avo/templates/locales/avo.zh-TW.yml +25 -0
  382. data/lib/generators/avo/templates/locales/avo.zh.yml +25 -0
  383. data/lib/generators/avo/templates/resource/resource.tt +10 -1
  384. data/lib/generators/avo/templates/resource_tools/partial.tt +20 -22
  385. data/lib/generators/avo/templates/tailwindcss/avo.tailwind.css +1 -3
  386. data/lib/generators/avo/templates/tailwindcss/tailwind.config.js +0 -7
  387. data/lib/generators/avo/templates/tool/view.tt +14 -16
  388. data/lib/generators/avo/tool_generator.rb +3 -3
  389. data/lib/generators/avo/version_generator.rb +1 -1
  390. data/lib/tasks/avo_tasks.rake +29 -25
  391. metadata +145 -97
  392. data/app/assets/stylesheets/avo.base.css +0 -130
  393. data/app/assets/stylesheets/css/breadcrumbs.css +0 -16
  394. data/app/assets/stylesheets/css/buttons.css +0 -19
  395. data/app/assets/stylesheets/css/tailwindcss/base.css +0 -1
  396. data/app/assets/stylesheets/css/tailwindcss/components.css +0 -1
  397. data/app/assets/stylesheets/css/tailwindcss/utilities.css +0 -1
  398. data/app/assets/svgs/avo/arrow-down.svg +0 -3
  399. data/app/assets/svgs/avo/arrow-up.svg +0 -3
  400. data/app/assets/svgs/avo/detach.svg +0 -8
  401. data/app/assets/svgs/avo/download-solid-reversed.svg +0 -3
  402. data/app/assets/svgs/avo/download-solid.svg +0 -3
  403. data/app/assets/svgs/avo/edit.svg +0 -5
  404. data/app/assets/svgs/avo/editor-bold.svg +0 -1
  405. data/app/assets/svgs/avo/editor-italic.svg +0 -1
  406. data/app/assets/svgs/avo/editor-link.svg +0 -1
  407. data/app/assets/svgs/avo/editor-list.svg +0 -1
  408. data/app/assets/svgs/avo/editor-strike.svg +0 -1
  409. data/app/assets/svgs/avo/editor-underline.svg +0 -1
  410. data/app/assets/svgs/avo/eye.svg +0 -1
  411. data/app/assets/svgs/avo/trash-sm.svg +0 -3
  412. data/app/assets/svgs/avo/trash.svg +0 -7
  413. data/app/components/avo/cover_photo_component.html.erb +0 -3
  414. data/app/components/avo/cover_photo_component.rb +0 -19
  415. data/app/components/avo/fields/common/badge_viewer_component.html.erb +0 -1
  416. data/app/components/avo/fields/common/badge_viewer_component.rb +0 -33
  417. data/app/components/avo/index/resource_grid_component.html.erb +0 -23
  418. data/app/components/avo/index/resource_grid_component.rb +0 -10
  419. data/app/components/avo/index/resource_map_component.html.erb +0 -16
  420. data/app/components/avo/index/resource_map_component.rb +0 -114
  421. data/app/components/avo/index/resource_table_component.html.erb +0 -52
  422. data/app/components/avo/panel_component.html.erb +0 -63
  423. data/app/components/avo/panel_component.rb +0 -43
  424. data/app/components/avo/panel_header_component.html.erb +0 -42
  425. data/app/components/avo/panel_header_component.rb +0 -31
  426. data/app/components/avo/profile_photo_component.html.erb +0 -6
  427. data/app/components/avo/profile_photo_component.rb +0 -9
  428. data/app/components/avo/sidebar/heading_component.html.erb +0 -21
  429. data/app/components/avo/sidebar/heading_component.rb +0 -9
  430. data/app/components/avo/tab_switcher_component.html.erb +0 -20
  431. data/app/components/avo/tab_switcher_component.rb +0 -45
  432. data/app/views/avo/base/close_modal_and_reload_field.turbo_stream.erb +0 -8
  433. data/app/views/avo/debug/report.html.erb +0 -37
  434. data/app/views/avo/partials/_panel_breadcrumbs.html.erb +0 -3
  435. data/app/views/avo/partials/_resource_search.html.erb +0 -16
  436. data/lib/avo/licensing/community_license.rb +0 -6
  437. data/lib/avo/licensing/h_q.rb +0 -202
  438. data/lib/avo/licensing/license.rb +0 -76
  439. data/lib/avo/licensing/license_manager.rb +0 -24
  440. data/lib/avo/licensing/nil_license.rb +0 -14
  441. data/lib/avo/licensing/pro_license.rb +0 -20
  442. data/lib/avo/licensing/request.rb +0 -20
  443. data/lib/avo/profile_photo.rb +0 -7
  444. data/lib/avo/services/debug_service.rb +0 -107
  445. data/public/avo-assets/placeholder.svg +0 -1
  446. data/tailwind.preset.js +0 -171
  447. /data/{public/avo-assets → app/assets/images/avo}/favicon.ico +0 -0
  448. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.eot +0 -0
  449. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.svg +0 -0
  450. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.ttf +0 -0
  451. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.woff +0 -0
  452. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-500.woff2 +0 -0
  453. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.eot +0 -0
  454. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.svg +0 -0
  455. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.ttf +0 -0
  456. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.woff +0 -0
  457. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-600.woff2 +0 -0
  458. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.eot +0 -0
  459. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.svg +0 -0
  460. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.ttf +0 -0
  461. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.woff +0 -0
  462. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-700.woff2 +0 -0
  463. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.eot +0 -0
  464. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.svg +0 -0
  465. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.ttf +0 -0
  466. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.woff +0 -0
  467. /data/{public/avo-assets → app/assets/images/avo}/fonts/inter-v7-latin-regular.woff2 +0 -0
  468. /data/{public/avo-assets → app/assets/images/avo}/logo-on-white.png +0 -0
  469. /data/{public/avo-assets → app/assets/images/avo}/logo.png +0 -0
  470. /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
+