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
@@ -1,7 +1,7 @@
1
1
  /* EDIT STYLES */
2
2
 
3
3
  .tiptap {
4
- @apply m-0 p-4 outline-none min-h-44;
4
+ @apply m-0 p-4 outline-hidden min-h-44;
5
5
 
6
6
  >*+* {
7
7
  @apply mt-4;
@@ -9,7 +9,7 @@
9
9
 
10
10
  ul,
11
11
  ol {
12
- @apply pl-6 list-outside;
12
+ @apply ps-6 list-outside;
13
13
  }
14
14
 
15
15
  ul {
@@ -22,7 +22,7 @@
22
22
  }
23
23
 
24
24
  .tiptap__field {
25
- @apply w-full mb-4 border border-gray-200 rounded;
25
+ @apply w-full mb-4 rounded-lg border border-tertiary;
26
26
  }
27
27
 
28
28
  .tiptap__editor {
@@ -30,11 +30,12 @@
30
30
  }
31
31
 
32
32
  .tiptap__toolbar {
33
- @apply flex items-center justify-between px-3 py-2 border-b bg-gray-50;
33
+ @apply flex items-center justify-between px-3 py-2 rounded-t-lg border border-tertiary bg-secondary;
34
34
  }
35
35
 
36
36
  .tiptap__toolbar-area {
37
- @apply flex flex-wrap items-center divide-gray-200 sm:divide-x sm:rtl:divide-x-reverse;
37
+ @apply flex flex-wrap items-center sm:divide-x sm:rtl:divide-x-reverse divide-tertiary;
38
+ --tw-divide-opacity: 1;
38
39
  }
39
40
 
40
41
  .tiptap__button-group {
@@ -54,27 +55,28 @@
54
55
  }
55
56
 
56
57
  .tiptap__button {
57
- @apply p-1 text-gray-500 rounded cursor-pointer;
58
+ @apply p-1 rounded-sm cursor-pointer;
58
59
 
59
60
  &:hover:enabled {
60
- @apply bg-gray-100;
61
+ background-color: var(--color-tertiary);
61
62
  }
62
63
 
63
64
  &:active:enabled {
64
- @apply bg-gray-200;
65
+ @apply bg-tertiary;
65
66
  }
66
67
 
67
68
  &:disabled {
68
- @apply text-gray-200 cursor-default;
69
+ @apply cursor-default text-content-secondary;
69
70
  }
70
71
 
71
72
  svg {
72
73
  @apply block h-6;
74
+ stroke: var(--color-content);
73
75
  }
74
76
  }
75
77
 
76
78
  .tiptap__button--selected {
77
- @apply bg-gray-900/10;
79
+ @apply bg-tertiary;
78
80
  }
79
81
 
80
82
  /* LINK STYLES */
@@ -84,8 +86,8 @@
84
86
  }
85
87
 
86
88
  .tiptap__link-field {
87
- &:placeholder {
88
- @apply italic text-gray-400;
89
+ &::placeholder {
90
+ @apply italic text-content-secondary;
89
91
  }
90
92
 
91
93
  &:focus::placeholder {
@@ -94,13 +96,13 @@
94
96
  }
95
97
 
96
98
  .tiptap__link-field {
97
- @apply text-sm mr-2 py-1 border border-gray-200 rounded;
99
+ @apply text-sm me-2 py-1 rounded-lg border border-tertiary bg-primary text-content;
98
100
  }
99
101
 
100
102
  /* SHOW STYLES */
101
103
 
102
104
  .tiptap__content {
103
- @apply py-2 max-w-4xl;
105
+ @apply py-2 max-w-4xl text-content;
104
106
 
105
107
  >*+* {
106
108
  @apply mt-4;
@@ -108,7 +110,7 @@
108
110
 
109
111
  ul,
110
112
  ol {
111
- @apply pl-6 list-outside;
113
+ @apply ps-6 list-outside;
112
114
  }
113
115
 
114
116
  ul {
@@ -26,19 +26,79 @@
26
26
  @apply list-decimal;
27
27
  }
28
28
 
29
+ trix-editor {
30
+ @apply border border-tertiary rounded-lg bg-primary text-content;
31
+
32
+ &:empty::before {
33
+ @apply !text-content-secondary;
34
+ }
35
+ }
36
+
29
37
  trix-toolbar {
30
38
  .trix-button-row {
31
39
  @apply flex-wrap gap-x-5;
32
40
  }
33
41
 
42
+ .trix-button-group {
43
+ @apply border border-tertiary;
44
+ }
45
+
34
46
  .trix-button-group:not(:first-child) {
35
- @apply ml-0;
47
+ @apply ms-0;
36
48
  }
37
49
  }
38
50
 
39
51
  /* Hack to remove border from trix when rendered from ActionText */
40
52
  .trix-content {
41
53
  & .trix-content {
42
- border: none;
54
+ @apply border-none;
55
+ }
56
+ }
57
+
58
+ /* Theme-token based Trix styling */
59
+ .trix-content pre {
60
+ @apply bg-tertiary text-content;
61
+ }
62
+
63
+ trix-toolbar {
64
+ .trix-button-group {
65
+ @apply bg-secondary border-tertiary;
43
66
  }
67
+
68
+ .trix-button {
69
+ @apply text-content border-tertiary;
70
+
71
+ &:not(:disabled):hover {
72
+ @apply bg-tertiary;
73
+ }
74
+
75
+ &.trix-active {
76
+ @apply bg-tertiary;
77
+ }
78
+ }
79
+
80
+ .trix-dialog {
81
+ @apply bg-secondary border-tertiary shadow-none;
82
+ }
83
+
84
+ .trix-input--dialog {
85
+ @apply bg-primary text-content border-tertiary;
86
+
87
+ &::placeholder {
88
+ @apply text-content-secondary;
89
+ }
90
+ }
91
+
92
+ .trix-button--dialog {
93
+ @apply text-content border-tertiary;
94
+
95
+ &:hover {
96
+ @apply bg-tertiary;
97
+ }
98
+ }
99
+ }
100
+
101
+ /* Trix toolbar icons are image-based and need inversion only in dark mode. */
102
+ .dark trix-toolbar .trix-button--icon::before {
103
+ filter: invert(1);
44
104
  }
@@ -3,50 +3,50 @@
3
3
  font-family: 'Inter';
4
4
  font-style: normal;
5
5
  font-weight: 400;
6
- src: url('/avo-assets/fonts/inter-v7-latin-regular.eot'); /* IE9 Compat Modes */
6
+ src: url('fonts/inter-v7-latin-regular.eot'); /* IE9 Compat Modes */
7
7
  src: local(''),
8
- url('/avo-assets/fonts/inter-v7-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
9
- url('/avo-assets/fonts/inter-v7-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
10
- url('/avo-assets/fonts/inter-v7-latin-regular.woff') format('woff'), /* Modern Browsers */
11
- url('/avo-assets/fonts/inter-v7-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
12
- url('/avo-assets/fonts/inter-v7-latin-regular.svg#Inter') format('svg'); /* Legacy iOS */
8
+ url('fonts/inter-v7-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
9
+ url('fonts/inter-v7-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
10
+ url('fonts/inter-v7-latin-regular.woff') format('woff'), /* Modern Browsers */
11
+ url('fonts/inter-v7-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
12
+ url('fonts/inter-v7-latin-regular.svg#Inter') format('svg'); /* Legacy iOS */
13
13
  }
14
14
  /* inter-500 - latin */
15
15
  @font-face {
16
16
  font-family: 'Inter';
17
17
  font-style: normal;
18
18
  font-weight: 500;
19
- src: url('/avo-assets/fonts/inter-v7-latin-500.eot'); /* IE9 Compat Modes */
19
+ src: url('fonts/inter-v7-latin-500.eot'); /* IE9 Compat Modes */
20
20
  src: local(''),
21
- url('/avo-assets/fonts/inter-v7-latin-500.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
22
- url('/avo-assets/fonts/inter-v7-latin-500.woff2') format('woff2'), /* Super Modern Browsers */
23
- url('/avo-assets/fonts/inter-v7-latin-500.woff') format('woff'), /* Modern Browsers */
24
- url('/avo-assets/fonts/inter-v7-latin-500.ttf') format('truetype'), /* Safari, Android, iOS */
25
- url('/avo-assets/fonts/inter-v7-latin-500.svg#Inter') format('svg'); /* Legacy iOS */
21
+ url('fonts/inter-v7-latin-500.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
22
+ url('fonts/inter-v7-latin-500.woff2') format('woff2'), /* Super Modern Browsers */
23
+ url('fonts/inter-v7-latin-500.woff') format('woff'), /* Modern Browsers */
24
+ url('fonts/inter-v7-latin-500.ttf') format('truetype'), /* Safari, Android, iOS */
25
+ url('fonts/inter-v7-latin-500.svg#Inter') format('svg'); /* Legacy iOS */
26
26
  }
27
27
  /* inter-600 - latin */
28
28
  @font-face {
29
29
  font-family: 'Inter';
30
30
  font-style: normal;
31
31
  font-weight: 600;
32
- src: url('/avo-assets/fonts/inter-v7-latin-600.eot'); /* IE9 Compat Modes */
32
+ src: url('fonts/inter-v7-latin-600.eot'); /* IE9 Compat Modes */
33
33
  src: local(''),
34
- url('/avo-assets/fonts/inter-v7-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
35
- url('/avo-assets/fonts/inter-v7-latin-600.woff2') format('woff2'), /* Super Modern Browsers */
36
- url('/avo-assets/fonts/inter-v7-latin-600.woff') format('woff'), /* Modern Browsers */
37
- url('/avo-assets/fonts/inter-v7-latin-600.ttf') format('truetype'), /* Safari, Android, iOS */
38
- url('/avo-assets/fonts/inter-v7-latin-600.svg#Inter') format('svg'); /* Legacy iOS */
34
+ url('fonts/inter-v7-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
35
+ url('fonts/inter-v7-latin-600.woff2') format('woff2'), /* Super Modern Browsers */
36
+ url('fonts/inter-v7-latin-600.woff') format('woff'), /* Modern Browsers */
37
+ url('fonts/inter-v7-latin-600.ttf') format('truetype'), /* Safari, Android, iOS */
38
+ url('fonts/inter-v7-latin-600.svg#Inter') format('svg'); /* Legacy iOS */
39
39
  }
40
40
  /* inter-700 - latin */
41
41
  @font-face {
42
42
  font-family: 'Inter';
43
43
  font-style: normal;
44
44
  font-weight: 700;
45
- src: url('/avo-assets/fonts/inter-v7-latin-700.eot'); /* IE9 Compat Modes */
45
+ src: url('fonts/inter-v7-latin-700.eot'); /* IE9 Compat Modes */
46
46
  src: local(''),
47
- url('/avo-assets/fonts/inter-v7-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
48
- url('/avo-assets/fonts/inter-v7-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
49
- url('/avo-assets/fonts/inter-v7-latin-700.woff') format('woff'), /* Modern Browsers */
50
- url('/avo-assets/fonts/inter-v7-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
51
- url('/avo-assets/fonts/inter-v7-latin-700.svg#Inter') format('svg'); /* Legacy iOS */
47
+ url('fonts/inter-v7-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
48
+ url('fonts/inter-v7-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
49
+ url('fonts/inter-v7-latin-700.woff') format('woff'), /* Modern Browsers */
50
+ url('fonts/inter-v7-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
51
+ url('fonts/inter-v7-latin-700.svg#Inter') format('svg'); /* Legacy iOS */
52
52
  }
@@ -0,0 +1,135 @@
1
+ :root {
2
+ --top-navbar-height: 4rem;
3
+ }
4
+
5
+ .skip-to-content {
6
+ @apply absolute overflow-hidden whitespace-nowrap border-0 p-0;
7
+
8
+ width: 1px;
9
+ height: 1px;
10
+ margin: -1px;
11
+ clip: rect(0, 0, 0, 0);
12
+
13
+ &:focus {
14
+ @apply z-[9999] fixed top-2 start-2 w-auto h-auto overflow-visible px-4 py-2 rounded-lg text-sm font-medium;
15
+
16
+ clip: auto;
17
+ margin: 0;
18
+ background-color: var(--color-foreground);
19
+ color: var(--color-background);
20
+ }
21
+ }
22
+
23
+ .top-navbar {
24
+ height: var(--top-navbar-height);
25
+ }
26
+
27
+ /* The sidebar width stays the same regardless of the sidebar open state. */
28
+ /* The content width and margin offset changes based on the sidebar open state and the :lg breakpoint. */
29
+ .main {
30
+ --sidebar-width: --spacing(64);
31
+ --sidebar-offset-size: 0rem;
32
+ --content-width: calc(100% - var(--sidebar-offset-size) - var(--spacing) * 2);
33
+
34
+ @media (min-width: theme(--breakpoint-lg)) {
35
+ &.sidebar-open {
36
+ --sidebar-offset-size: var(--sidebar-width);
37
+ }
38
+ }
39
+
40
+ @apply mt-(--top-navbar-height);
41
+
42
+ .main-content-area {
43
+ @apply w-(--content-width) ms-1 flex flex-1 flex-col z-50 fixed rounded-2xl bg-primary shadow-content p-4 h-full;
44
+
45
+ transition: margin 0.1s ease-in-out, width 0.1s ease-in-out;
46
+
47
+ height: calc(100dvh - var(--spacing) - var(--top-navbar-height));
48
+
49
+ .scrollable-wrapper {
50
+ @apply overflow-y-auto h-full flex-1 flex flex-col px-2;
51
+ }
52
+ .avo-container {
53
+ @apply flex flex-1 flex-col justify-between;
54
+ }
55
+ }
56
+
57
+ &.sidebar-open {
58
+ /* Add padding to the main area to allow for the sidebar to expand. */
59
+ .main-content-area {
60
+ @media (min-width: theme(--breakpoint-lg)) {
61
+ margin-inline-start: calc(var(--sidebar-width) + var(--spacing));
62
+ width: var(--content-width);
63
+
64
+ }
65
+ }
66
+ }
67
+ }
68
+
69
+ .container-large {
70
+ @apply 2xl:container 2xl:mx-auto;
71
+ }
72
+
73
+ .container-small {
74
+ @apply xl:px-0 xl:w-240 xl:mx-auto;
75
+ }
76
+
77
+ .container-full-width {
78
+ @apply w-full;
79
+ }
80
+
81
+ .top-navbar {
82
+ @apply z-100 fixed w-full flex shrink-0 items-center px-4 lg:px-2 space-x-4 rtl:space-x-reverse lg:space-x-0;
83
+ }
84
+
85
+ /* Sidebar toggle: choose icon via navbar variables; visibility driven by data attribute */
86
+ .sidebar-toggle-icon {
87
+ @apply inline-flex;
88
+ }
89
+
90
+ .sidebar-toggle-icon--closed {
91
+ @apply hidden;
92
+ }
93
+
94
+ button[data-sidebar-state='closed'] .sidebar-toggle-icon--open {
95
+ @apply hidden;
96
+ }
97
+
98
+ button[data-sidebar-state='closed'] .sidebar-toggle-icon--closed {
99
+ @apply inline-flex;
100
+ }
101
+
102
+ /* Default hidden state - LTR: sidebar slides in from left */
103
+ .avo-sidebar {
104
+ @apply fixed z-60 top-0 flex-1 border-e border-tertiary lg:border-none mt-(--top-navbar-height) h-[calc(100dvh-var(--top-navbar-height))] bg-background lg:bg-transparent w-(--sidebar-width);
105
+
106
+ transform: translateX(-100%);
107
+ transition: transform 0.1s ease;
108
+ }
109
+
110
+ /* RTL: sidebar slides in from right when hidden */
111
+ html[dir="rtl"] .avo-sidebar {
112
+ transform: translateX(100%);
113
+ }
114
+
115
+ /* Desktop: show sidebar when sidebar-open class is present (lg+ only) */
116
+ @media (min-width: theme(--breakpoint-lg)) {
117
+ .sidebar-open .avo-sidebar {
118
+ transform: translateX(0);
119
+ }
120
+
121
+ html[dir="rtl"] .sidebar-open .avo-sidebar {
122
+ transform: translateX(0);
123
+ }
124
+ }
125
+
126
+ /* Mobile: show sidebar only when explicitly toggled open */
127
+ @media (width < theme(--breakpoint-lg)) {
128
+ .sidebar-mobile-open .avo-sidebar {
129
+ transform: translateX(0);
130
+ }
131
+
132
+ html[dir="rtl"] .sidebar-mobile-open .avo-sidebar {
133
+ transform: translateX(0);
134
+ }
135
+ }
@@ -1,103 +1,139 @@
1
- .pagy-gem-version-7 {
2
- .pagy-nav,
3
- .pagy-nav-js,
4
- .pagy-combo-nav-js {
5
- @apply relative z-0 flex;
6
- }
1
+ /* Pagination Component
2
+ BEM: .pagination (block)
3
+ .pagination__per-page (elements)
4
+ .pagination__controls, .pagination__info, .pagination__nav (elements) */
7
5
 
8
- .pagy-nav.pagination,
9
- .pagy-nav-js.pagination,
10
- .pagy-combo-nav-js.pagination {
11
- @apply space-x-2;
12
- }
6
+ .pagination {
7
+ @apply flex w-full flex-col items-stretch justify-between gap-2 sm:flex-row sm:items-end sm:gap-0;
8
+ }
13
9
 
14
- .pagy-nav .page a{
15
- @apply block;
16
- }
10
+ /* === Per-page selector (left) === */
17
11
 
18
- .pagy-nav .page a,
19
- .pagy-nav .page.active a,
20
- .pagy-nav .page.prev.disabled a,
21
- .pagy-nav .page.next.disabled a,
22
- .pagy-nav-js .page a,
23
- .pagy-combo-nav-js .page a,
24
- .pagy-combo-nav-js .pagy-combo-input a {
25
- @apply rounded px-3 py-1 text-sm text-gray-500 font-semibold bg-white shadow-md border border-gray-300;
26
-
27
- &:hover{
28
- @apply bg-gray-150;
29
- }
12
+ .pagination__per-page {
13
+ --pagination-per-page-width: 10rem; /* w-48 equivalent; use 165px for exact Figma match */
14
+ @apply flex items-center;
15
+ }
30
16
 
31
- &:active{
32
- @apply bg-gray-200;
33
- }
34
- }
17
+ .pagination__per-page-input {
18
+ width: var(--pagination-per-page-width);
19
+ min-width: var(--pagination-per-page-width);
20
+ @apply py-1 px-2 bg-primary border border-tertiary rounded-lg overflow-hidden text-ellipsis whitespace-nowrap text-content cursor-pointer text-sm leading-5 font-normal inline-flex items-center gap-1;
21
+ }
35
22
 
36
- .pagy-nav .page.prev.disabled a,
37
- .pagy-nav-js .page.prev.disabled a,
38
- .pagy-combo-nav-js .page.prev.disabled a,
39
- .pagy-nav .page.next.disabled a,
40
- .pagy-nav-js .page.next.disabled a,
41
- .pagy-combo-nav-js .page.next.disabled a {
42
- @apply text-gray-300 cursor-default;
23
+ /* Dropdown menu matches trigger width */
24
+ .pagination__per-page .dropdown-popover {
25
+ width: var(--pagination-per-page-width);
26
+ min-width: var(--pagination-per-page-width);
27
+ }
43
28
 
44
- &:hover {
45
- @apply text-gray-300 bg-white;
46
- }
29
+ .pagination__per-page-value {
30
+ @apply flex-1 text-start font-normal;
31
+ }
47
32
 
48
- &:active {
49
- @apply text-gray-300 bg-white;
50
- }
33
+ .pagination__per-page-icon {
34
+ @apply shrink-0 inline-flex items-center justify-center size-4 text-content-secondary;
35
+
36
+ & svg {
37
+ @apply size-4;
51
38
  }
39
+ }
40
+
41
+ /* Per-page option: number bold (700), "per page" normal (400) */
42
+ .pagination__per-page-option-num {
43
+ @apply font-bold;
44
+ }
52
45
 
53
- .pagy-nav .page.active a,
54
- .pagy-nav-js .page.active a {
55
- @apply text-white cursor-default bg-gray-500 border-gray-500;
46
+ .pagination__per-page .dropdown-menu__item {
47
+ @apply font-normal;
48
+ }
56
49
 
57
- &:hover {
58
- @apply text-white bg-gray-500;
59
- }
50
+ /* === Controls pill (right) === */
60
51
 
61
- &:active {
62
- @apply bg-gray-500 text-white;
63
- }
52
+ .pagination__controls {
53
+ @apply flex w-fit shrink-0 items-center gap-3 rounded-lg border border-tertiary bg-primary overflow-hidden ps-3 pe-2 overflow-visible;
54
+ }
55
+
56
+ /* Info text with right-border divider */
57
+ .pagination__info {
58
+ @apply flex items-center py-1 pe-3 border-e border-tertiary whitespace-nowrap overflow-hidden text-ellipsis text-sm text-content leading-5 font-normal;
59
+
60
+ &:last-child {
61
+ @apply border-e-0 pe-1;
64
62
  }
65
63
  }
66
64
 
67
- .pagy-gem-version-8-or-more {
68
- .pagy.nav {
69
- @apply relative z-0 flex space-x-2 max-sm:flex-wrap max-sm:gap-2 max-sm:justify-center;
65
+ .pagination__info-number {
66
+ @apply font-bold;
67
+ }
70
68
 
71
- a.gap {
72
- @apply text-gray-500;
73
- }
69
+ /* Nav buttons wrapper */
70
+ .pagination__nav {
71
+ @apply flex items-center;
72
+ }
74
73
 
75
- & a:not(.gap) {
76
- @apply block rounded px-3 py-1 text-sm text-gray-500 font-semibold bg-white shadow-md border border-gray-300;
74
+ /* === Pagy nav === */
75
+ .pagy.series-nav {
76
+ @apply flex items-center gap-0.5;
77
77
 
78
- &:hover{
79
- @apply bg-gray-150;
80
- }
78
+ a[role="separator"] {
79
+ @apply px-2 text-sm text-content-secondary;
80
+ }
81
81
 
82
- &:active{
83
- @apply bg-gray-200;
84
- }
82
+ & a:not([role="separator"]) {
83
+ @apply inline-flex items-center justify-center min-w-8 px-3 py-0.5 rounded-lg border border-transparent
84
+ text-sm font-medium leading-tight text-content no-underline transition-colors;
85
85
 
86
- &.current {
87
- @apply text-white cursor-default bg-gray-500 border-gray-500;
86
+ &:hover:not([aria-current="page"]):not([aria-disabled="true"]) {
87
+ @apply bg-secondary;
88
+ }
88
89
 
89
- &:hover {
90
- @apply text-white bg-gray-500;
91
- }
90
+ &:active:not([aria-current="page"]):not([aria-disabled="true"]) {
91
+ @apply bg-tertiary;
92
+ }
92
93
 
93
- &:active {
94
- @apply bg-gray-500 text-white;
95
- }
96
- }
94
+ &[aria-disabled="true"]:not([aria-current="page"]) {
95
+ @apply opacity-40 cursor-not-allowed pointer-events-none;
96
+ }
97
97
 
98
- &[aria-disabled="true"]:not(.current) {
99
- @apply bg-gray-100 text-gray-300 cursor-default;
100
- }
98
+ &[aria-current="page"] {
99
+ @apply bg-secondary text-content cursor-default font-medium;
101
100
  }
102
101
  }
102
+
103
+ /* Compact previous/next controls */
104
+ & a:not([role="separator"]):first-child,
105
+ & a:not([role="separator"]):last-child {
106
+ @apply min-w-0 px-2 py-1;
107
+ }
108
+ }
109
+
110
+ /* Avo paginator only: hide prev/next text and paint data-uri icons */
111
+ .pagination__nav .pagy.series-nav {
112
+ & a:not([role="separator"]):first-child,
113
+ & a:not([role="separator"]):last-child {
114
+ font-size: 0;
115
+ line-height: 0;
116
+ }
117
+
118
+ & a:not([role="separator"]):first-child::before,
119
+ & a:not([role="separator"]):last-child::before {
120
+ content: "";
121
+ @apply block size-3.5 bg-current;
122
+ -webkit-mask-repeat: no-repeat;
123
+ -webkit-mask-position: center;
124
+ -webkit-mask-size: contain;
125
+ mask-repeat: no-repeat;
126
+ mask-position: center;
127
+ mask-size: contain;
128
+ }
129
+
130
+ & a:not([role="separator"]):first-child::before {
131
+ -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M5 12l14 0'/%3E%3Cpath d='M5 12l6 6'/%3E%3Cpath d='M5 12l6 -6'/%3E%3C/svg%3E");
132
+ mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M5 12l14 0'/%3E%3Cpath d='M5 12l6 6'/%3E%3Cpath d='M5 12l6 -6'/%3E%3C/svg%3E");
133
+ }
134
+
135
+ & a:not([role="separator"]):last-child::before {
136
+ -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M5 12l14 0'/%3E%3Cpath d='M13 18l6 -6'/%3E%3Cpath d='M13 6l6 6'/%3E%3C/svg%3E");
137
+ mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M5 12l14 0'/%3E%3Cpath d='M13 18l6 -6'/%3E%3Cpath d='M13 6l6 6'/%3E%3C/svg%3E");
138
+ }
103
139
  }
@@ -0,0 +1,13 @@
1
+ @layer base {
2
+ .resource-controls {
3
+ .resource-control,
4
+ button,
5
+ a {
6
+ @apply text-content-secondary;
7
+
8
+ &:hover {
9
+ @apply text-content;
10
+ }
11
+ }
12
+ }
13
+ }