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,318 @@
1
+ /* TODO: rename this file to theming or something similar */
2
+ @theme {
3
+ --color-avo-neutral-25: oklch(98.51% 0.0000 89.88);
4
+ --color-avo-neutral-50: oklch(97.31% 0.0000 89.88);
5
+ --color-avo-neutral-100: oklch(92.80% 0.0000 89.88);
6
+ --color-avo-neutral-200: oklch(86.07% 0.0000 89.88);
7
+ --color-avo-neutral-300: oklch(75.72% 0.0000 89.88);
8
+ --color-avo-neutral-400: oklch(62.68% 0.0000 89.88);
9
+ --color-avo-neutral-500: oklch(53.48% 0.0000 89.88);
10
+ --color-avo-neutral-600: oklch(47.84% 0.0000 89.88);
11
+ --color-avo-neutral-700: oklch(42.76% 0.0000 89.88);
12
+ --color-avo-neutral-800: oklch(39.04% 0.0000 89.88);
13
+ --color-avo-neutral-900: oklch(27.68% 0.0000 89.88);
14
+ --color-avo-neutral-950: oklch(20.46% 0.0000 89.88);
15
+
16
+ /* semantic - Mode 1 */
17
+ --color-success: var(--color-green-500);
18
+ --color-success-content: var(--color-green-600);
19
+ --color-success-foreground: var(--color-green-400);
20
+ --color-info: var(--color-blue-400);
21
+ --color-info-content: var(--color-blue-600);
22
+ --color-info-foreground: var(--color-blue-500);
23
+ --color-warning: var(--color-yellow-500);
24
+ --color-warning-content: var(--color-yellow-600);
25
+ --color-warning-foreground: var(--color-yellow-400);
26
+ --color-danger: var(--color-red-500);
27
+ --color-danger-content: var(--color-red-600);
28
+ --color-danger-foreground: var(--color-red-400);
29
+
30
+ --shadow-content: 0 8px 16px 0 rgba(0, 0, 0, 0.08);
31
+
32
+ --box-shadow-card: 0px 8px 16px 0px rgba(0, 0, 0, 0.04);
33
+ --box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.04);
34
+ --box-shadow-grid-card: 0 -1.5px 0 1px var(--color-secondary) inset, 0 0.8px 0 1.3px var(--color-primary) inset;
35
+
36
+ --box-shadow-active: 0 0 0 2px var(--color-info-foreground);
37
+ --box-shadow-error: 0 0 5px 1px var(--color-red-600), 0 0 0 1px var(--color-red-600), 0 0 0 3px var(--color-red-300);
38
+ --box-shadow-success: 0 0 5px 1px var(--color-green-600), 0 0 0 1px var(--color-green-600), 0 0 0 3px var(--color-green-300);
39
+ --box-shadow-focus: 0 0 0 1px var(--color-primary), 0 0 0 3px var(--color-info-foreground);
40
+ --box-shadow-search-input-shortcut: 0 -1.5px 0 1px var(--color-secondary) inset, 0 0.8px 0 1.3px var(--color-primary) inset;
41
+
42
+ /* foundations - Light Mode */
43
+ --color-background: var(--color-avo-neutral-25);
44
+ --color-foreground: var(--color-avo-neutral-800);
45
+ --color-primary: var(--color-white);
46
+ --color-secondary: var(--color-avo-neutral-50);
47
+ --color-tertiary: var(--color-avo-neutral-100);
48
+ --color-content: var(--color-avo-neutral-950);
49
+ --color-content-secondary: var(--color-avo-neutral-500);
50
+
51
+ /* themes - Neutral Light */
52
+ --color-accent: var(--color-avo-neutral-800);
53
+ --color-accent-content: var(--color-avo-neutral-950);
54
+ --color-accent-foreground: var(--color-white);
55
+ }
56
+
57
+ /* Dark theme */
58
+ .dark {
59
+ /* foundations - Dark Mode */
60
+ --color-background: var(--color-avo-neutral-900);
61
+ --color-foreground: var(--color-avo-neutral-50);
62
+ --color-primary: var(--color-avo-neutral-950);
63
+ --color-secondary: var(--color-avo-neutral-800);
64
+ --color-tertiary: var(--color-avo-neutral-700);
65
+ --color-content: var(--color-white);
66
+ --color-content-secondary: var(--color-avo-neutral-300);
67
+
68
+ /* themes - Neutral Dark */
69
+ --color-accent: var(--color-avo-neutral-50);
70
+ --color-accent-content: var(--color-avo-neutral-100);
71
+ --color-accent-foreground: var(--color-avo-neutral-950);
72
+ }
73
+
74
+ .theme-slate {
75
+ --color-avo-neutral-25: oklch(98.51% 0.0000 89.88);
76
+ --color-avo-neutral-50: var(--color-slate-50);
77
+ --color-avo-neutral-100: var(--color-slate-100);
78
+ --color-avo-neutral-200: var(--color-slate-200);
79
+ --color-avo-neutral-300: var(--color-slate-300);
80
+ --color-avo-neutral-400: var(--color-slate-400);
81
+ --color-avo-neutral-500: var(--color-slate-500);
82
+ --color-avo-neutral-600: var(--color-slate-600);
83
+ --color-avo-neutral-700: var(--color-slate-700);
84
+ --color-avo-neutral-800: var(--color-slate-800);
85
+ --color-avo-neutral-900: var(--color-slate-900);
86
+ --color-avo-neutral-950: var(--color-slate-950);
87
+ }
88
+ .theme-stone {
89
+ --color-avo-neutral-25: oklch(98.51% 0.0000 89.88);
90
+ --color-avo-neutral-50: var(--color-stone-50);
91
+ --color-avo-neutral-100: var(--color-stone-100);
92
+ --color-avo-neutral-200: var(--color-stone-200);
93
+ --color-avo-neutral-300: var(--color-stone-300);
94
+ --color-avo-neutral-400: var(--color-stone-400);
95
+ --color-avo-neutral-500: var(--color-stone-500);
96
+ --color-avo-neutral-600: var(--color-stone-600);
97
+ --color-avo-neutral-700: var(--color-stone-700);
98
+ --color-avo-neutral-800: var(--color-stone-800);
99
+ --color-avo-neutral-900: var(--color-stone-900);
100
+ --color-avo-neutral-950: var(--color-stone-950);
101
+ }
102
+ .theme-taupe {
103
+ --color-avo-neutral-25: oklch(98.5% 0.004 70);
104
+ --color-avo-neutral-50: var(--color-taupe-50);
105
+ --color-avo-neutral-100: var(--color-taupe-100);
106
+ --color-avo-neutral-200: var(--color-taupe-200);
107
+ --color-avo-neutral-300: var(--color-taupe-300);
108
+ --color-avo-neutral-400: var(--color-taupe-400);
109
+ --color-avo-neutral-500: var(--color-taupe-500);
110
+ --color-avo-neutral-600: var(--color-taupe-600);
111
+ --color-avo-neutral-700: var(--color-taupe-700);
112
+ --color-avo-neutral-800: var(--color-taupe-800);
113
+ --color-avo-neutral-900: var(--color-taupe-900);
114
+ --color-avo-neutral-950: var(--color-taupe-950);
115
+ }
116
+ .theme-mauve {
117
+ --color-avo-neutral-25: oklch(98.5% 0.005 310);
118
+ --color-avo-neutral-50: var(--color-mauve-50);
119
+ --color-avo-neutral-100: var(--color-mauve-100);
120
+ --color-avo-neutral-200: var(--color-mauve-200);
121
+ --color-avo-neutral-300: var(--color-mauve-300);
122
+ --color-avo-neutral-400: var(--color-mauve-400);
123
+ --color-avo-neutral-500: var(--color-mauve-500);
124
+ --color-avo-neutral-600: var(--color-mauve-600);
125
+ --color-avo-neutral-700: var(--color-mauve-700);
126
+ --color-avo-neutral-800: var(--color-mauve-800);
127
+ --color-avo-neutral-900: var(--color-mauve-900);
128
+ --color-avo-neutral-950: var(--color-mauve-950);
129
+ }
130
+ .theme-mist {
131
+ --color-avo-neutral-25: oklch(98.5% 0.004 240);
132
+ --color-avo-neutral-50: var(--color-mist-50);
133
+ --color-avo-neutral-100: var(--color-mist-100);
134
+ --color-avo-neutral-200: var(--color-mist-200);
135
+ --color-avo-neutral-300: var(--color-mist-300);
136
+ --color-avo-neutral-400: var(--color-mist-400);
137
+ --color-avo-neutral-500: var(--color-mist-500);
138
+ --color-avo-neutral-600: var(--color-mist-600);
139
+ --color-avo-neutral-700: var(--color-mist-700);
140
+ --color-avo-neutral-800: var(--color-mist-800);
141
+ --color-avo-neutral-900: var(--color-mist-900);
142
+ --color-avo-neutral-950: var(--color-mist-950);
143
+ }
144
+ .theme-gray {
145
+ --color-avo-neutral-25: oklch(98.51% 0.0000 89.88);
146
+ --color-avo-neutral-50: var(--color-gray-50);
147
+ --color-avo-neutral-100: var(--color-gray-100);
148
+ --color-avo-neutral-200: var(--color-gray-200);
149
+ --color-avo-neutral-300: var(--color-gray-300);
150
+ --color-avo-neutral-400: var(--color-gray-400);
151
+ --color-avo-neutral-500: var(--color-gray-500);
152
+ --color-avo-neutral-600: var(--color-gray-600);
153
+ --color-avo-neutral-700: var(--color-gray-700);
154
+ --color-avo-neutral-800: var(--color-gray-800);
155
+ --color-avo-neutral-900: var(--color-gray-900);
156
+ --color-avo-neutral-950: var(--color-gray-950);
157
+ }
158
+ .theme-zinc {
159
+ --color-avo-neutral-25: oklch(98.51% 0.0000 89.88);
160
+ --color-avo-neutral-50: var(--color-zinc-50);
161
+ --color-avo-neutral-100: var(--color-zinc-100);
162
+ --color-avo-neutral-200: var(--color-zinc-200);
163
+ --color-avo-neutral-300: var(--color-zinc-300);
164
+ --color-avo-neutral-400: var(--color-zinc-400);
165
+ --color-avo-neutral-500: var(--color-zinc-500);
166
+ --color-avo-neutral-600: var(--color-zinc-600);
167
+ --color-avo-neutral-700: var(--color-zinc-700);
168
+ --color-avo-neutral-800: var(--color-zinc-800);
169
+ --color-avo-neutral-900: var(--color-zinc-900);
170
+ --color-avo-neutral-950: var(--color-zinc-950);
171
+ }
172
+ .theme-neutral {
173
+ --color-avo-neutral-25: oklch(98.51% 0.0000 89.88);
174
+ --color-avo-neutral-50: var(--color-neutral-50);
175
+ --color-avo-neutral-100: var(--color-neutral-100);
176
+ --color-avo-neutral-200: var(--color-neutral-200);
177
+ --color-avo-neutral-300: var(--color-neutral-300);
178
+ --color-avo-neutral-400: var(--color-neutral-400);
179
+ --color-avo-neutral-500: var(--color-neutral-500);
180
+ --color-avo-neutral-600: var(--color-neutral-600);
181
+ --color-avo-neutral-700: var(--color-neutral-700);
182
+ --color-avo-neutral-800: var(--color-neutral-800);
183
+ --color-avo-neutral-900: var(--color-neutral-900);
184
+ --color-avo-neutral-950: var(--color-neutral-950);
185
+ }
186
+ .theme-olive {
187
+ --color-avo-neutral-25: oklch(98.5% 0.005 140);
188
+ --color-avo-neutral-50: var(--color-olive-50);
189
+ --color-avo-neutral-100: var(--color-olive-100);
190
+ --color-avo-neutral-200: var(--color-olive-200);
191
+ --color-avo-neutral-300: var(--color-olive-300);
192
+ --color-avo-neutral-400: var(--color-olive-400);
193
+ --color-avo-neutral-500: var(--color-olive-500);
194
+ --color-avo-neutral-600: var(--color-olive-600);
195
+ --color-avo-neutral-700: var(--color-olive-700);
196
+ --color-avo-neutral-800: var(--color-olive-800);
197
+ --color-avo-neutral-900: var(--color-olive-900);
198
+ --color-avo-neutral-950: var(--color-olive-950);
199
+ }
200
+
201
+ .accent-red {
202
+ /* themes - Red */
203
+ --color-accent: var(--color-red-500);
204
+ --color-accent-content: var(--color-red-600);
205
+ --color-accent-foreground: var(--color-white);
206
+ }
207
+
208
+ .accent-orange {
209
+ /* themes - Orange */
210
+ --color-accent: var(--color-orange-500);
211
+ --color-accent-content: var(--color-orange-600);
212
+ --color-accent-foreground: var(--color-white);
213
+ }
214
+
215
+ .accent-amber {
216
+ /* themes - Amber */
217
+ --color-accent: var(--color-amber-500);
218
+ --color-accent-content: var(--color-amber-600);
219
+ --color-accent-foreground: var(--color-white);
220
+ }
221
+
222
+ .accent-yellow {
223
+ /* themes - Yellow */
224
+ --color-accent: var(--color-yellow-500);
225
+ --color-accent-content: var(--color-yellow-600);
226
+ --color-accent-foreground: var(--color-white);
227
+ }
228
+
229
+ .accent-lime {
230
+ /* themes - Lime */
231
+ --color-accent: var(--color-lime-500);
232
+ --color-accent-content: var(--color-lime-600);
233
+ --color-accent-foreground: var(--color-white);
234
+ }
235
+
236
+ .accent-green {
237
+ /* themes - Green */
238
+ --color-accent: var(--color-green-500);
239
+ --color-accent-content: var(--color-green-600);
240
+ --color-accent-foreground: var(--color-white);
241
+ }
242
+
243
+ .accent-emerald {
244
+ /* themes - Emerald */
245
+ --color-accent: var(--color-emerald-500);
246
+ --color-accent-content: var(--color-emerald-600);
247
+ --color-accent-foreground: var(--color-white);
248
+ }
249
+
250
+ .accent-teal {
251
+ /* themes - Teal */
252
+ --color-accent: var(--color-teal-500);
253
+ --color-accent-content: var(--color-teal-600);
254
+ --color-accent-foreground: var(--color-white);
255
+ }
256
+
257
+ .accent-cyan {
258
+ /* themes - Cyan */
259
+ --color-accent: var(--color-cyan-500);
260
+ --color-accent-content: var(--color-cyan-600);
261
+ --color-accent-foreground: var(--color-white);
262
+ }
263
+
264
+ .accent-sky {
265
+ /* themes - Sky */
266
+ --color-accent: var(--color-sky-500);
267
+ --color-accent-content: var(--color-sky-600);
268
+ --color-accent-foreground: var(--color-white);
269
+ }
270
+
271
+ .accent-blue {
272
+ /* themes - Blue */
273
+ --color-accent: var(--color-blue-500);
274
+ --color-accent-content: var(--color-blue-600);
275
+ --color-accent-foreground: var(--color-white);
276
+ }
277
+
278
+ .accent-indigo {
279
+ /* themes - Indigo */
280
+ --color-accent: var(--color-indigo-500);
281
+ --color-accent-content: var(--color-indigo-600);
282
+ --color-accent-foreground: var(--color-white);
283
+ }
284
+
285
+ .accent-violet {
286
+ /* themes - Violet */
287
+ --color-accent: var(--color-violet-500);
288
+ --color-accent-content: var(--color-violet-600);
289
+ --color-accent-foreground: var(--color-white);
290
+ }
291
+
292
+ .accent-purple {
293
+ /* themes - Purple */
294
+ --color-accent: var(--color-purple-500);
295
+ --color-accent-content: var(--color-purple-600);
296
+ --color-accent-foreground: var(--color-white);
297
+ }
298
+
299
+ .accent-fuchsia {
300
+ /* themes - Fuchsia */
301
+ --color-accent: var(--color-fuchsia-500);
302
+ --color-accent-content: var(--color-fuchsia-600);
303
+ --color-accent-foreground: var(--color-white);
304
+ }
305
+
306
+ .accent-pink {
307
+ /* themes - Pink */
308
+ --color-accent: var(--color-pink-500);
309
+ --color-accent-content: var(--color-pink-600);
310
+ --color-accent-foreground: var(--color-white);
311
+ }
312
+
313
+ .accent-rose {
314
+ /* themes - Rose */
315
+ --color-accent: var(--color-rose-500);
316
+ --color-accent-content: var(--color-rose-600);
317
+ --color-accent-foreground: var(--color-white);
318
+ }
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke="currentColor"><path d="M10 6C10 10.4183 13.5817 14 18 14C19.4386 14 20.7885 13.6203 21.9549 12.9556C21.4738 18.0302 17.2005 22 12 22C6.47715 22 2 17.5228 2 12C2 6.79948 5.9698 2.52616 11.0444 2.04507C10.3797 3.21152 10 4.56142 10 6ZM4 12C4 16.4183 7.58172 20 12 20C14.9654 20 17.5757 18.3788 18.9571 15.9546C18.6407 15.9848 18.3214 16 18 16C12.4772 16 8 11.5228 8 6C8 5.67863 8.01524 5.35933 8.04536 5.04293C5.62119 6.42426 4 9.03458 4 12ZM18.1642 2.29104L19 2.5V3.5L18.1642 3.70896C17.4476 3.8881 16.8881 4.4476 16.709 5.16417L16.5 6H15.5L15.291 5.16417C15.1119 4.4476 14.5524 3.8881 13.8358 3.70896L13 3.5V2.5L13.8358 2.29104C14.5524 2.1119 15.1119 1.5524 15.291 0.835829L15.5 0H16.5L16.709 0.835829C16.8881 1.5524 17.4476 2.1119 18.1642 2.29104ZM23.1642 7.29104L24 7.5V8.5L23.1642 8.70896C22.4476 8.8881 21.8881 9.4476 21.709 10.1642L21.5 11H20.5L20.291 10.1642C20.1119 9.4476 19.5524 8.8881 18.8358 8.70896L18 8.5V7.5L18.8358 7.29104C19.5524 7.1119 20.1119 6.5524 20.291 5.83583L20.5 5H21.5L21.709 5.83583C21.8881 6.5524 22.4476 7.1119 23.1642 7.29104Z"/></svg>
@@ -1,43 +1,37 @@
1
- <div class="relative flex flex-col w-full sm:w-auto js-actions-dropdown"
1
+ <div
2
+ class="actions-dropdown relative flex w-full flex-col sm:w-auto"
2
3
  data-component-name="<%= self.class.to_s.underscore %>"
3
4
  data-controller="toggle actions-picker"
4
- data-actions-picker-enabled-class="text-black hover:bg-primary-500 hover:text-white"
5
- data-actions-picker-disabled-class="cursor-wait text-gray-500"
5
+ data-actions-picker-enabled-class="text-content hover:bg-secondary"
6
+ data-actions-picker-disabled-class="cursor-wait text-content/60"
6
7
  data-resource-name="<%= @resource.class.to_s %>"
7
- <% if @resource.record.present? %> data-record-id="<%= @resource.record_param %>" <% end %>
8
- >
9
- <%= a_button style: @style,
10
- type: :button,
11
- color: @color,
12
- size: @size,
13
- class: "focus:outline-none",
14
- icon: @icon,
15
- icon_class: @icon_class,
16
- data: {
17
- action: "click->toggle#togglePanel",
18
- actions_dropdown_button: @resource.model_key,
19
- tippy: "tooltip",
20
- tippy_content: @title
21
- } do %>
22
- <%= @label %>
8
+ <% if @resource.record.present? %>
9
+ data-record-id="<%= @resource.record_param %>"
23
10
  <% end %>
24
- <div
25
- class="absolute flex inset-auto xl:right-0 top-full bg-white w-full sm:w-auto sm:min-w-[300px] mt-2 z-40 shadow-modal rounded overflow-hidden hidden"
26
- data-toggle-target="panel"
27
- data-controller="actions-overflow"
28
- data-actions-overflow-panel-list-value="<%= !@as_row_control %>"
29
- data-actions-overflow-target="content"
30
- data-transition-enter="transition ease-out duration-100"
31
- data-transition-enter-start="transform opacity-0 -translate-y-1"
32
- data-transition-enter-end="transform opacity-100 translate-y-0"
33
- data-transition-leave="transition ease-in duration-75"
34
- data-transition-leave-start="transform opacity-100 translate-y-0"
35
- data-transition-leave-end="transform opacity-0 -translate-y-1"
36
- >
37
- <div data-target="actions-list" class="w-full space divide-y">
11
+ >
12
+
13
+ <%= render ui.dropdown(classes: "z-100", data: { dropdown_list: @label }) do |component| %>
14
+ <% component.with_trigger do %>
15
+ <%= a_button style: @style,
16
+ type: :button,
17
+ color: @color,
18
+ size: @size,
19
+ class: "focus:outline-hidden",
20
+ icon: @icon,
21
+ icon_class: @icon_class,
22
+ data: {
23
+ action: component.action,
24
+ actions_dropdown_button: @resource.model_key,
25
+ tippy: "tooltip",
26
+ tippy_content: @title
27
+ } do %>
28
+ <%= @label %>
29
+ <% end %>
30
+ <% end %>
31
+ <% component.with_items do %>
38
32
  <% @actions.each do |action| %>
39
- <%= render_item(action)%>
33
+ <%= render_item(action) %>
40
34
  <% end %>
41
- </div>
42
- </div>
35
+ <% end %>
36
+ <% end %>
43
37
  </div>
@@ -8,9 +8,7 @@ class Avo::ActionsComponent < Avo::BaseComponent
8
8
  prop :icon_class
9
9
  prop :size, default: :md
10
10
  prop :title
11
- prop :color do |value|
12
- value || :primary
13
- end
11
+ prop :color
14
12
  prop :include, default: [].freeze do |include|
15
13
  Array(include).to_set
16
14
  end
@@ -22,7 +20,7 @@ class Avo::ActionsComponent < Avo::BaseComponent
22
20
  label || I18n.t("avo.actions")
23
21
  end
24
22
  end
25
- prop :style, default: :outline
23
+ prop :style, default: :primary
26
24
  prop :actions, default: [].freeze
27
25
  prop :exclude, default: [].freeze do |exclude|
28
26
  Array(exclude).to_set
@@ -63,7 +61,7 @@ class Avo::ActionsComponent < Avo::BaseComponent
63
61
  private
64
62
 
65
63
  def icon(icon)
66
- helpers.svg icon, class: "h-5 shrink-0 mr-1 inline pointer-events-none"
64
+ helpers.svg icon, class: "h-5 shrink-0 me-1 inline pointer-events-none"
67
65
  end
68
66
 
69
67
  def render_item(action)
@@ -76,7 +74,7 @@ class Avo::ActionsComponent < Avo::BaseComponent
76
74
  render_action_link(action.action, icon: action.icon)
77
75
  when defined?(Avo::Advanced::Resources::Controls::LinkTo) && Avo::Advanced::Resources::Controls::LinkTo
78
76
  link_to action.args[:path],
79
- class: action.args.delete(:class) || "flex items-center px-4 py-3 w-full text-black font-semibold text-sm hover:bg-primary-100",
77
+ class: action.args.delete(:class),
80
78
  **action.args.except(:path, :label, :icon) do
81
79
  raw("#{icon(action.args[:icon])} #{action.args[:label]}")
82
80
  end
@@ -102,16 +100,15 @@ class Avo::ActionsComponent < Avo::BaseComponent
102
100
  "actions-picker-target": action.standalone ? "standaloneAction" : "resourceAction",
103
101
  disabled: action.disabled?,
104
102
  turbo_prefetch: false,
105
- enabled_classes: "text-black",
106
- disabled_classes: "text-gray-500",
103
+ disabled_classes: "dropdown-menu__item--disabled",
107
104
  resource_name: action.resource.model_key
108
105
  }
109
106
  end
110
107
 
111
108
  def action_css_class(action)
112
- helpers.class_names("flex items-center px-4 py-3 w-full font-semibold text-sm hover:bg-primary-100", {
113
- "text-gray-500": action.disabled?,
114
- "text-black": action.enabled?,
109
+ helpers.class_names("", {
110
+ "dropdown-menu__item--disabled": action.disabled?,
111
+ "": action.enabled?,
115
112
  })
116
113
  end
117
114
  end
@@ -10,13 +10,13 @@
10
10
  <div class="flex items-center min-h-full">
11
11
  <%= helpers.svg icon, class: "h-6" %>
12
12
  </div>
13
- <div class="ml-3 w-0 flex-1 pt-0.5">
13
+ <div class="ms-3 w-0 flex-1 pt-0.5">
14
14
  <p class="text-sm leading-5 font-semibold">
15
15
  <%= sanitize @message.to_s %>
16
16
  </p>
17
17
  </div>
18
- <div class="ml-4 flex-shrink-0 flex items-center">
19
- <button data-action="alert#close" class="inline-flex text-white focus:outline-none focus:text-gray-300 transition ease-in-out duration-150">
18
+ <div class="ms-4 shrink-0 flex items-center">
19
+ <button data-action="alert#close" class="inline-flex text-white focus:outline-hidden focus:text-gray-300 transition ease-in-out duration-150">
20
20
  <svg class="h-5 w-5" viewBox="0 0 20 20" fill="currentColor">
21
21
  <path fill-rule="evenodd" d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z" clip-rule="evenodd"/>
22
22
  </svg>
@@ -19,7 +19,7 @@ class Avo::AlertComponent < Avo::BaseComponent
19
19
  def classes
20
20
  return "hidden" if is_empty?
21
21
 
22
- result = "max-w-lg w-full shadow-lg rounded px-4 py-3 rounded relative border text-white pointer-events-auto"
22
+ result = "max-w-lg w-full shadow-lg px-4 py-3 rounded-sm relative border text-white pointer-events-auto"
23
23
 
24
24
  result += if is_error?
25
25
  " bg-red-400 border-red-600"
@@ -8,5 +8,4 @@
8
8
  <% end %>
9
9
 
10
10
  <%# This is the last script to run so it can register custom StimulusJS controllers from plugins. %>
11
- <% path = Avo::PACKED ? '/avo-assets/late-registration' : 'late-registration' %>
12
- <%= javascript_include_tag path, "data-turbo-track": "reload", defer: true %>
11
+ <%= javascript_include_tag 'avo/late-registration', "data-turbo-track": "reload", defer: true %>
@@ -1,21 +1,21 @@
1
1
  <div data-controller="alert"
2
2
  data-alert-dismiss-after-value="<%= Avo.configuration.alert_dismiss_time %>"
3
3
  data-alert-remove-delay-value="0"
4
- class="w-full shadow-lg px-4 py-3 rounded relative border text-white pointer-events-auto bg-red-400 border-red-600"
4
+ class="w-full shadow-lg px-4 py-3 rounded-sm relative border text-white pointer-events-auto bg-red-400 border-red-600"
5
5
  >
6
6
  <div class="px-2">
7
7
  <div class="flex h-full">
8
8
  <div class="flex items-center min-h-full">
9
9
  <%= helpers.svg "heroicons/solid/exclamation-circle", class: "h-6" %>
10
10
  </div>
11
- <div class="ml-3 w-0 flex-1 pt-0.5">
11
+ <div class="ms-3 w-0 flex-1 pt-0.5">
12
12
  <p class="text-sm leading-5 font-semibold">
13
13
  <strong>Backtrace:</strong>
14
14
  <pre class='overflow-y-scroll max-h-64 whitespace-pre-wrap text-xs'><%= @backtrace.join("\n") %></pre>
15
15
  </p>
16
16
  </div>
17
- <div class="ml-4 flex-shrink-0 flex items-center">
18
- <button data-action="alert#close" class="inline-flex text-white focus:outline-none focus:text-gray-300 transition ease-in-out duration-150">
17
+ <div class="ms-4 shrink-0 flex items-center">
18
+ <button data-action="alert#close" class="inline-flex text-white focus:outline-hidden focus:text-gray-300 transition ease-in-out duration-150">
19
19
  <svg class="h-5 w-5" viewBox="0 0 20 20" fill="currentColor">
20
20
  <path fill-rule="evenodd" d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z" clip-rule="evenodd"/>
21
21
  </svg>
@@ -4,15 +4,14 @@ class Avo::BaseComponent < ViewComponent::Base
4
4
  extend PropInitializer::Properties
5
5
  include Turbo::FramesHelper
6
6
  include Avo::Concerns::FindAssociationField
7
+ include Avo::ApplicationHelper
7
8
 
8
9
  delegate :e, to: :helpers
9
10
  delegate :d, to: :helpers
10
11
  delegate :main_app, to: :helpers
11
12
  delegate :avo, to: :helpers
12
-
13
- def has_with_trial(ability)
14
- Avo.license.has_with_trial(ability)
15
- end
13
+ delegate :ui, to: :helpers
14
+ delegate :svg, to: :helpers
16
15
 
17
16
  def component_name = self.class.name.to_s.underscore
18
17
 
@@ -0,0 +1,17 @@
1
+ <%= wrapper_element class: class_names(
2
+ "breadcrumb-element",
3
+ "breadcrumb-element--link": link?
4
+ ) do %>
5
+ <% if @avatar.present? %>
6
+ <div class="breadcrumb-element__avatar">
7
+ <%= render Avo::UI::AvatarComponent.new src: helpers.main_app.url_for(@avatar.value), shape: :square, type: :avatar, size: :tiny %>
8
+ </div>
9
+ <% elsif @initials.present? %>
10
+ <span class="breadcrumb-element__initials"><%= render Avo::UI::AvatarComponent.new shape: :square, type: :initials, size: :tiny, initials: @initials %></span>
11
+ <% end %>
12
+ <% if @icon.present? %>
13
+ <%= helpers.svg @icon, class: "breadcrumb-element__icon" %>
14
+ <% end %>
15
+
16
+ <%= content_tag :span, @text, class: "breadcrumb-element__text" %>
17
+ <% end %>
@@ -0,0 +1,21 @@
1
+ # frozen_string_literal: true
2
+
3
+ class Avo::BreadcrumbElementComponent < Avo::BaseComponent
4
+ prop :text
5
+ prop :url, default: nil
6
+ prop :icon, default: nil
7
+ prop :initials, default: nil
8
+ prop :avatar
9
+
10
+ def link?
11
+ @url.present?
12
+ end
13
+
14
+ def wrapper_element(args = {}, &block)
15
+ if link?
16
+ link_to @url, **args, &block
17
+ else
18
+ content_tag :span, **args, &block
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,19 @@
1
+ <%= tag.nav class: "breadcrumbs", aria: { label: "Breadcrumb" } do %>
2
+ <div class="breadcrumbs__container">
3
+ <% @items.each_with_index do |item, index| %>
4
+ <% is_last = index == @items.length - 1 %>
5
+
6
+ <%= render Avo::BreadcrumbElementComponent.new(
7
+ text: item.title,
8
+ url: item.path,
9
+ icon: item.icon,
10
+ avatar: item.avatar,
11
+ initials: item.initials
12
+ ) %>
13
+
14
+ <% unless is_last %>
15
+ <span class="breadcrumbs__separator">/</span>
16
+ <% end %>
17
+ <% end %>
18
+ </div>
19
+ <% end %>
@@ -0,0 +1,5 @@
1
+ # frozen_string_literal: true
2
+
3
+ class Avo::BreadcrumbsComponent < Avo::BaseComponent
4
+ prop :items, default: -> { [] }
5
+ end