alchemy_cms 7.1.10 → 7.2.0.b

Sign up to get free protection for your applications and to get access to all the features.
Files changed (308) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +132 -16
  3. data/Gemfile +2 -4
  4. data/LICENSE +1 -1
  5. data/README.md +5 -6
  6. data/SECURITY.md +1 -1
  7. data/alchemy_cms.gemspec +3 -4
  8. data/app/assets/javascripts/alchemy/admin.js +0 -9
  9. data/app/assets/javascripts/alchemy/alchemy.dialog.js.coffee +5 -15
  10. data/app/assets/javascripts/alchemy/alchemy.image_overlay.coffee +5 -4
  11. data/app/assets/javascripts/alchemy/templates/index.js +0 -1
  12. data/app/assets/javascripts/alchemy/templates/node_folder.hbs +1 -1
  13. data/app/assets/javascripts/alchemy/templates/page_folder.hbs +1 -1
  14. data/app/assets/javascripts/tinymce/plugins/alchemy_link/plugin.min.js +20 -7
  15. data/app/assets/stylesheets/alchemy/_custom-properties.scss +12 -0
  16. data/app/assets/stylesheets/alchemy/_mixins.scss +10 -6
  17. data/app/assets/stylesheets/alchemy/_variables.scss +3 -0
  18. data/app/assets/stylesheets/alchemy/admin.scss +2 -2
  19. data/app/assets/stylesheets/alchemy/archive.scss +4 -3
  20. data/app/assets/stylesheets/alchemy/attachment-select.scss +19 -0
  21. data/app/assets/stylesheets/alchemy/base.scss +31 -18
  22. data/app/assets/stylesheets/alchemy/buttons.scss +3 -4
  23. data/app/assets/stylesheets/alchemy/dashboard.scss +1 -1
  24. data/app/assets/stylesheets/alchemy/dialogs.scss +2 -5
  25. data/app/assets/stylesheets/alchemy/elements.scss +73 -41
  26. data/app/assets/stylesheets/alchemy/flash.scss +20 -70
  27. data/app/assets/stylesheets/alchemy/forms.scss +41 -36
  28. data/app/assets/stylesheets/alchemy/frame.scss +12 -3
  29. data/app/assets/stylesheets/alchemy/icons.scss +34 -2
  30. data/app/assets/stylesheets/alchemy/image_library.scss +18 -9
  31. data/app/assets/stylesheets/alchemy/{filter_field.scss → list_filter.scss} +8 -7
  32. data/app/assets/stylesheets/alchemy/lists.scss +1 -1
  33. data/app/assets/stylesheets/alchemy/navigation.scss +9 -12
  34. data/app/assets/stylesheets/alchemy/node-select.scss +1 -1
  35. data/app/assets/stylesheets/alchemy/nodes.scss +15 -13
  36. data/app/assets/stylesheets/alchemy/notices.scss +56 -39
  37. data/app/assets/stylesheets/alchemy/page-select.scss +1 -4
  38. data/app/assets/stylesheets/alchemy/pagination.scss +11 -1
  39. data/app/assets/stylesheets/alchemy/preview_window.scss +3 -3
  40. data/app/assets/stylesheets/alchemy/search.scss +4 -4
  41. data/app/assets/stylesheets/alchemy/selects.scss +13 -7
  42. data/app/assets/stylesheets/alchemy/shoelace.scss +33 -2
  43. data/app/assets/stylesheets/alchemy/sitemap.scss +155 -159
  44. data/app/assets/stylesheets/alchemy/tables.scss +49 -12
  45. data/app/assets/stylesheets/alchemy/tags.scss +17 -11
  46. data/app/assets/stylesheets/alchemy/toolbar.scss +2 -2
  47. data/app/assets/stylesheets/alchemy/typography.scss +41 -22
  48. data/app/assets/stylesheets/alchemy/upload.scss +5 -4
  49. data/app/components/alchemy/admin/attachment_select.rb +39 -0
  50. data/app/components/alchemy/admin/icon.rb +72 -0
  51. data/app/components/alchemy/admin/link_dialog/anchor_tab.rb +41 -0
  52. data/app/components/alchemy/admin/link_dialog/base_tab.rb +75 -0
  53. data/app/components/alchemy/admin/link_dialog/external_tab.rb +42 -0
  54. data/app/components/alchemy/admin/link_dialog/file_tab.rb +45 -0
  55. data/app/components/alchemy/admin/link_dialog/internal_tab.rb +66 -0
  56. data/app/components/alchemy/admin/link_dialog/tabs.rb +33 -0
  57. data/app/components/alchemy/admin/list_filter.rb +42 -0
  58. data/app/components/alchemy/admin/message.rb +19 -0
  59. data/app/components/alchemy/admin/tags_autocomplete.rb +25 -0
  60. data/app/components/alchemy/admin/toolbar_button.rb +111 -0
  61. data/app/components/alchemy/ingredients/link_view.rb +1 -7
  62. data/app/components/alchemy/ingredients/picture_view.rb +2 -2
  63. data/app/components/alchemy/ingredients/text_view.rb +1 -2
  64. data/app/controllers/alchemy/admin/base_controller.rb +1 -1
  65. data/app/controllers/alchemy/admin/elements_controller.rb +4 -2
  66. data/app/controllers/alchemy/admin/ingredients_controller.rb +2 -0
  67. data/app/controllers/alchemy/admin/languages_controller.rb +1 -1
  68. data/app/controllers/alchemy/admin/legacy_page_urls_controller.rb +12 -4
  69. data/app/controllers/alchemy/admin/nodes_controller.rb +26 -0
  70. data/app/controllers/alchemy/admin/pages_controller.rb +11 -78
  71. data/app/controllers/alchemy/admin/picture_descriptions_controller.rb +15 -0
  72. data/app/controllers/alchemy/admin/pictures_controller.rb +18 -1
  73. data/app/controllers/alchemy/admin/resources_controller.rb +15 -10
  74. data/app/controllers/alchemy/api/attachments_controller.rb +44 -0
  75. data/app/controllers/alchemy/api/pages_controller.rb +10 -6
  76. data/app/controllers/alchemy/base_controller.rb +2 -2
  77. data/app/controllers/alchemy/messages_controller.rb +3 -3
  78. data/app/controllers/alchemy/pages_controller.rb +8 -6
  79. data/app/controllers/concerns/alchemy/admin/current_language.rb +1 -1
  80. data/app/controllers/concerns/alchemy/legacy_page_redirects.rb +1 -1
  81. data/app/decorators/alchemy/element_editor.rb +2 -2
  82. data/app/helpers/alchemy/admin/base_helper.rb +8 -60
  83. data/app/helpers/alchemy/admin/elements_helper.rb +1 -1
  84. data/app/helpers/alchemy/admin/ingredients_helper.rb +1 -1
  85. data/app/helpers/alchemy/base_helper.rb +9 -91
  86. data/app/helpers/alchemy/elements_helper.rb +3 -3
  87. data/app/helpers/alchemy/pages_helper.rb +16 -9
  88. data/app/javascript/alchemy_admin/components/attachment_select.js +24 -0
  89. data/app/javascript/alchemy_admin/components/button.js +3 -0
  90. data/app/javascript/alchemy_admin/components/clipboard_button.js +3 -2
  91. data/app/javascript/alchemy_admin/components/dialog_link.js +10 -7
  92. data/app/javascript/alchemy_admin/components/dom_id_select.js +69 -0
  93. data/app/javascript/alchemy_admin/components/element_editor/delete_element_button.js +42 -0
  94. data/app/javascript/alchemy_admin/components/element_editor/publish_element_button.js +4 -2
  95. data/app/javascript/alchemy_admin/components/element_editor.js +21 -13
  96. data/app/javascript/alchemy_admin/components/elements_window.js +87 -0
  97. data/app/javascript/alchemy_admin/components/growl.js +13 -0
  98. data/app/javascript/alchemy_admin/components/icon.js +51 -0
  99. data/app/javascript/alchemy_admin/components/index.js +24 -0
  100. data/app/javascript/alchemy_admin/components/ingredient_group.js +6 -0
  101. data/app/javascript/alchemy_admin/components/link_buttons/link_button.js +21 -11
  102. data/app/javascript/alchemy_admin/components/link_buttons/unlink_button.js +2 -1
  103. data/app/javascript/alchemy_admin/components/link_buttons.js +1 -0
  104. data/app/javascript/alchemy_admin/components/list_filter.js +68 -0
  105. data/app/javascript/alchemy_admin/components/message.js +69 -0
  106. data/app/javascript/alchemy_admin/components/node_select.js +1 -1
  107. data/app/javascript/alchemy_admin/components/overlay.js +6 -6
  108. data/app/javascript/alchemy_admin/components/page_select.js +3 -7
  109. data/app/javascript/alchemy_admin/components/preview_window.js +121 -0
  110. data/app/javascript/alchemy_admin/components/remote_select.js +4 -1
  111. data/app/javascript/alchemy_admin/components/select.js +37 -1
  112. data/app/javascript/alchemy_admin/components/tags_autocomplete.js +57 -0
  113. data/app/javascript/alchemy_admin/components/uploader/file_upload.js +4 -3
  114. data/app/javascript/alchemy_admin/components/uploader/progress.js +1 -1
  115. data/app/javascript/alchemy_admin/confirm_dialog.js +133 -0
  116. data/app/javascript/alchemy_admin/dirty.js +19 -14
  117. data/app/javascript/alchemy_admin/fixed_elements.js +24 -0
  118. data/app/javascript/alchemy_admin/growler.js +15 -0
  119. data/app/javascript/alchemy_admin/gui.js +2 -4
  120. data/app/javascript/alchemy_admin/hotkeys.js +60 -0
  121. data/app/javascript/alchemy_admin/image_loader.js +2 -2
  122. data/app/javascript/alchemy_admin/ingredient_anchor_link.js +2 -3
  123. data/app/javascript/alchemy_admin/initializer.js +1 -8
  124. data/app/javascript/alchemy_admin/link_dialog.js +131 -0
  125. data/app/javascript/alchemy_admin/locales/en.js +3 -0
  126. data/app/javascript/alchemy_admin/node_tree.js +4 -3
  127. data/app/javascript/alchemy_admin/page_sorter.js +23 -14
  128. data/app/javascript/alchemy_admin/picture_editors.js +3 -2
  129. data/app/javascript/alchemy_admin/shoelace_theme.js +60 -0
  130. data/app/javascript/alchemy_admin/sitemap.js +9 -3
  131. data/app/javascript/alchemy_admin/sortable_elements.js +4 -6
  132. data/app/javascript/alchemy_admin.js +18 -42
  133. data/app/models/alchemy/current.rb +26 -0
  134. data/app/models/alchemy/element.rb +1 -1
  135. data/app/models/alchemy/ingredients/audio.rb +0 -11
  136. data/app/models/alchemy/ingredients/headline.rb +8 -1
  137. data/app/models/alchemy/ingredients/picture.rb +6 -0
  138. data/app/models/alchemy/ingredients/video.rb +0 -12
  139. data/app/models/alchemy/language.rb +8 -6
  140. data/app/models/alchemy/node.rb +2 -2
  141. data/app/models/alchemy/page/page_elements.rb +8 -8
  142. data/app/models/alchemy/page/page_layouts.rb +3 -3
  143. data/app/models/alchemy/page/page_natures.rb +13 -9
  144. data/app/models/alchemy/page/page_scopes.rb +2 -2
  145. data/app/models/alchemy/page/publisher.rb +1 -0
  146. data/app/models/alchemy/page.rb +13 -28
  147. data/app/models/alchemy/picture.rb +8 -0
  148. data/app/models/alchemy/picture_description.rb +8 -0
  149. data/app/models/alchemy/picture_variant.rb +1 -1
  150. data/app/models/alchemy/site.rb +10 -7
  151. data/app/serializers/alchemy/attachment_serializer.rb +8 -0
  152. data/app/serializers/alchemy/page_node_serializer.rb +9 -0
  153. data/app/views/alchemy/_menubar.html.erb +1 -1
  154. data/app/views/alchemy/_preview_mode_code.html.erb +1 -1
  155. data/app/views/alchemy/admin/attachments/_tag_list.html.erb +2 -2
  156. data/app/views/alchemy/admin/attachments/archive_overlay.js.erb +0 -1
  157. data/app/views/alchemy/admin/attachments/edit.html.erb +3 -4
  158. data/app/views/alchemy/admin/clipboard/clear.js.erb +1 -1
  159. data/app/views/alchemy/admin/clipboard/index.html.erb +1 -1
  160. data/app/views/alchemy/admin/clipboard/insert.js.erb +1 -1
  161. data/app/views/alchemy/admin/clipboard/remove.js.erb +1 -1
  162. data/app/views/alchemy/admin/dashboard/_locked_pages.html.erb +1 -1
  163. data/app/views/alchemy/admin/dashboard/_sites.html.erb +1 -1
  164. data/app/views/alchemy/admin/dashboard/help.html.erb +48 -12
  165. data/app/views/alchemy/admin/dashboard/index.html.erb +1 -1
  166. data/app/views/alchemy/admin/dashboard/info.html.erb +5 -8
  167. data/app/views/alchemy/admin/elements/_add_nested_element_form.html.erb +1 -1
  168. data/app/views/alchemy/admin/elements/_element.html.erb +5 -5
  169. data/app/views/alchemy/admin/elements/_footer.html.erb +1 -1
  170. data/app/views/alchemy/admin/elements/_header.html.erb +6 -2
  171. data/app/views/alchemy/admin/elements/_toolbar.html.erb +8 -6
  172. data/app/views/alchemy/admin/elements/create.js.erb +0 -5
  173. data/app/views/alchemy/admin/elements/index.html.erb +70 -34
  174. data/app/views/alchemy/admin/ingredients/_file_fields.html.erb +1 -2
  175. data/app/views/alchemy/admin/ingredients/_picture_fields.html.erb +3 -5
  176. data/app/views/alchemy/admin/languages/_language.html.erb +1 -1
  177. data/app/views/alchemy/admin/languages/index.html.erb +2 -2
  178. data/app/views/alchemy/admin/layoutpages/_layoutpage.html.erb +18 -18
  179. data/app/views/alchemy/admin/layoutpages/edit.html.erb +3 -4
  180. data/app/views/alchemy/admin/layoutpages/index.html.erb +2 -2
  181. data/app/views/alchemy/admin/legacy_page_urls/_legacy_page_url.html.erb +10 -11
  182. data/app/views/alchemy/admin/legacy_page_urls/_new.html.erb +15 -17
  183. data/app/views/alchemy/admin/legacy_page_urls/_table.html.erb +16 -0
  184. data/app/views/alchemy/admin/legacy_page_urls/_update.turbo_stream.erb +12 -0
  185. data/app/views/alchemy/admin/legacy_page_urls/create.turbo_stream.erb +8 -0
  186. data/app/views/alchemy/admin/legacy_page_urls/destroy.turbo_stream.erb +1 -0
  187. data/app/views/alchemy/admin/legacy_page_urls/edit.html.erb +27 -0
  188. data/app/views/alchemy/admin/legacy_page_urls/show.html.erb +1 -0
  189. data/app/views/alchemy/admin/legacy_page_urls/update.turbo_stream.erb +1 -0
  190. data/app/views/alchemy/admin/nodes/_form.html.erb +12 -11
  191. data/app/views/alchemy/admin/nodes/_label.html.erb +1 -0
  192. data/app/views/alchemy/admin/nodes/_node.html.erb +19 -19
  193. data/app/views/alchemy/admin/nodes/_page_nodes.html.erb +48 -0
  194. data/app/views/alchemy/admin/nodes/_update.turbo_stream.erb +9 -0
  195. data/app/views/alchemy/admin/nodes/create.turbo_stream.erb +1 -0
  196. data/app/views/alchemy/admin/nodes/destroy.turbo_stream.erb +1 -0
  197. data/app/views/alchemy/admin/nodes/index.html.erb +3 -3
  198. data/app/views/alchemy/admin/pages/_form.html.erb +3 -4
  199. data/app/views/alchemy/admin/pages/_legacy_urls.html.erb +4 -15
  200. data/app/views/alchemy/admin/pages/_page.html.erb +39 -39
  201. data/app/views/alchemy/admin/pages/_table_row.html.erb +3 -3
  202. data/app/views/alchemy/admin/pages/_toolbar.html.erb +2 -2
  203. data/app/views/alchemy/admin/pages/configure.html.erb +6 -0
  204. data/app/views/alchemy/admin/pages/edit.html.erb +15 -62
  205. data/app/views/alchemy/admin/pages/unlock.js.erb +3 -3
  206. data/app/views/alchemy/admin/partials/_autocomplete_tag_list.html.erb +3 -1
  207. data/app/views/alchemy/admin/partials/_flash_notices.html.erb +4 -2
  208. data/app/views/alchemy/admin/partials/_language_tree_select.html.erb +1 -1
  209. data/app/views/alchemy/admin/partials/_main_navigation_entry.html.erb +5 -2
  210. data/app/views/alchemy/admin/partials/_remote_search_form.html.erb +2 -2
  211. data/app/views/alchemy/admin/partials/_search_form.html.erb +2 -2
  212. data/app/views/alchemy/admin/partials/_site_select.html.erb +1 -1
  213. data/app/views/alchemy/admin/picture_descriptions/_form.html.erb +11 -0
  214. data/app/views/alchemy/admin/picture_descriptions/edit.html.erb +6 -0
  215. data/app/views/alchemy/admin/pictures/_form.html.erb +4 -3
  216. data/app/views/alchemy/admin/pictures/_infos.html.erb +1 -1
  217. data/app/views/alchemy/admin/pictures/_picture_description_field.html.erb +29 -0
  218. data/app/views/alchemy/admin/pictures/_tag_list.html.erb +2 -2
  219. data/app/views/alchemy/admin/pictures/archive_overlay.js.erb +0 -2
  220. data/app/views/alchemy/admin/pictures/edit_multiple.html.erb +3 -3
  221. data/app/views/alchemy/admin/pictures/show.html.erb +3 -3
  222. data/app/views/alchemy/admin/resources/_form.html.erb +3 -4
  223. data/app/views/alchemy/admin/resources/_tag_list.html.erb +2 -2
  224. data/app/views/alchemy/admin/resources/index.html.erb +2 -2
  225. data/app/views/alchemy/admin/sites/index.html.erb +1 -1
  226. data/app/views/alchemy/admin/styleguide/index.html.erb +29 -24
  227. data/app/views/alchemy/admin/tags/_tag.html.erb +1 -1
  228. data/app/views/alchemy/admin/tags/edit.html.erb +1 -1
  229. data/app/views/alchemy/admin/tags/index.html.erb +1 -1
  230. data/app/views/alchemy/base/500.html.erb +7 -18
  231. data/app/views/alchemy/base/error_notice.html.erb +3 -1
  232. data/app/views/alchemy/ingredients/_boolean_editor.html.erb +1 -1
  233. data/app/views/alchemy/ingredients/_datetime_editor.html.erb +1 -1
  234. data/app/views/alchemy/ingredients/_headline_editor.html.erb +13 -8
  235. data/app/views/alchemy/ingredients/_picture_editor.html.erb +1 -1
  236. data/app/views/alchemy/ingredients/shared/_picture_tools.html.erb +1 -1
  237. data/app/views/alchemy/language_links/_language.html.erb +1 -1
  238. data/app/views/kaminari/alchemy/_first_page.html.erb +2 -2
  239. data/app/views/kaminari/alchemy/_gap.html.erb +1 -1
  240. data/app/views/kaminari/alchemy/_last_page.html.erb +2 -2
  241. data/app/views/kaminari/alchemy/_next_page.html.erb +2 -2
  242. data/app/views/kaminari/alchemy/_prev_page.html.erb +2 -2
  243. data/app/views/layouts/alchemy/admin.html.erb +2 -1
  244. data/bundles/shoelace.js +3 -1
  245. data/config/locales/alchemy.en.yml +16 -3
  246. data/config/routes.rb +3 -1
  247. data/db/migrate/20240314105244_create_alchemy_picture_descriptions.rb +11 -0
  248. data/lib/alchemy/configuration_methods.rb +1 -1
  249. data/lib/alchemy/controller_actions.rb +3 -3
  250. data/lib/alchemy/element_definition.rb +10 -6
  251. data/lib/alchemy/engine.rb +19 -2
  252. data/lib/alchemy/page_layout.rb +10 -6
  253. data/lib/alchemy/permissions.rb +3 -2
  254. data/lib/alchemy/routing_constraints.rb +1 -1
  255. data/lib/alchemy/seeder.rb +2 -2
  256. data/lib/alchemy/test_support/capybara_helpers.rb +4 -0
  257. data/lib/alchemy/test_support/factories/language_factory.rb +1 -1
  258. data/lib/alchemy/test_support/shared_contexts.rb +8 -0
  259. data/lib/alchemy/tinymce.rb +2 -1
  260. data/lib/alchemy/version.rb +1 -1
  261. data/lib/alchemy.rb +36 -0
  262. data/lib/alchemy_cms.rb +0 -1
  263. data/lib/generators/alchemy/menus/templates/node.html.erb +2 -2
  264. data/lib/generators/alchemy/menus/templates/node.html.haml +2 -2
  265. data/lib/generators/alchemy/menus/templates/node.html.slim +2 -2
  266. data/lib/generators/alchemy/menus/templates/wrapper.html.erb +1 -1
  267. data/lib/generators/alchemy/menus/templates/wrapper.html.haml +1 -1
  268. data/lib/generators/alchemy/menus/templates/wrapper.html.slim +1 -1
  269. data/lib/tasks/alchemy/sitemap.rake +97 -0
  270. data/package.json +8 -8
  271. data/vendor/assets/fonts/remixicon.symbol.svg +11 -0
  272. data/vendor/javascript/shoelace.min.js +333 -118
  273. data/vendor/javascript/sortable.min.js +1 -1
  274. data/vendor/javascript/tinymce.min.js +1 -1
  275. data/vendor/javascript/ungap-custom-elements.min.js +1 -1
  276. metadata +61 -54
  277. data/app/assets/javascripts/alchemy/alchemy.confirm_dialog.js.coffee +0 -85
  278. data/app/assets/javascripts/alchemy/alchemy.elements_window.js.coffee +0 -107
  279. data/app/assets/javascripts/alchemy/alchemy.file_progress.js.coffee +0 -66
  280. data/app/assets/javascripts/alchemy/alchemy.fixed_elements.js +0 -45
  281. data/app/assets/javascripts/alchemy/alchemy.growler.js.coffee +0 -24
  282. data/app/assets/javascripts/alchemy/alchemy.hotkeys.js.coffee +0 -49
  283. data/app/assets/javascripts/alchemy/alchemy.initializer.js.coffee +0 -0
  284. data/app/assets/javascripts/alchemy/alchemy.link_dialog.js.coffee +0 -230
  285. data/app/assets/javascripts/alchemy/alchemy.list_filter.js.coffee +0 -49
  286. data/app/assets/javascripts/alchemy/alchemy.preview_window.js.coffee +0 -82
  287. data/app/assets/javascripts/alchemy/alchemy.string_extension.js.coffee +0 -11
  288. data/app/assets/javascripts/alchemy/templates/page.hbs +0 -19
  289. data/app/javascript/alchemy_admin/tags_autocomplete.js +0 -46
  290. data/app/models/alchemy/tree_node.rb +0 -7
  291. data/app/views/alchemy/admin/elements/destroy.js.erb +0 -8
  292. data/app/views/alchemy/admin/legacy_page_urls/_form.html.erb +0 -5
  293. data/app/views/alchemy/admin/legacy_page_urls/create.js.erb +0 -9
  294. data/app/views/alchemy/admin/legacy_page_urls/destroy.js.erb +0 -6
  295. data/app/views/alchemy/admin/legacy_page_urls/update.js.erb +0 -2
  296. data/app/views/alchemy/admin/pages/_anchor_link.html.erb +0 -22
  297. data/app/views/alchemy/admin/pages/_external_link.html.erb +0 -31
  298. data/app/views/alchemy/admin/pages/_file_link.html.erb +0 -31
  299. data/app/views/alchemy/admin/pages/_internal_link.html.erb +0 -35
  300. data/app/views/alchemy/admin/pages/link.html.erb +0 -26
  301. data/app/views/alchemy/admin/partials/_flash.html.erb +0 -4
  302. data/app/views/alchemy/admin/partials/_toolbar_button.html.erb +0 -29
  303. data/vendor/assets/fonts/remixicon.eot +0 -0
  304. data/vendor/assets/fonts/remixicon.svg +0 -7816
  305. data/vendor/assets/fonts/remixicon.ttf +0 -0
  306. data/vendor/assets/fonts/remixicon.woff +0 -0
  307. data/vendor/assets/fonts/remixicon.woff2 +0 -0
  308. data/vendor/assets/stylesheets/remixicon.scss +0 -10480
@@ -1,5 +1,7 @@
1
- .icon {
2
- color: $icon-color;
1
+ alchemy-icon {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ justify-content: center;
3
5
 
4
6
  &.disabled {
5
7
  opacity: 0.3;
@@ -8,4 +10,34 @@
8
10
  &.blank {
9
11
  background: transparent;
10
12
  }
13
+
14
+ &.error {
15
+ padding: 2rem;
16
+ }
17
+ }
18
+
19
+ .icon {
20
+ fill: var(--color-icon, currentColor);
21
+ width: var(--icon-size, var(--icon-size-md));
22
+ height: var(--icon-size, var(--icon-size-md));
23
+
24
+ &--xs {
25
+ width: var(--icon-size-xs);
26
+ height: var(--icon-size-xs);
27
+ }
28
+
29
+ &--sm {
30
+ width: var(--icon-size-sm);
31
+ height: var(--icon-size-sm);
32
+ }
33
+
34
+ &--1x {
35
+ width: var(--icon-size-1x);
36
+ height: var(--icon-size-1x);
37
+ }
38
+
39
+ &--xl {
40
+ width: var(--icon-size-xl);
41
+ height: var(--icon-size-xl);
42
+ }
11
43
  }
@@ -57,6 +57,9 @@ $image-overlay-transition-easing: ease-in;
57
57
 
58
58
  .alchemy-image-overlay-close {
59
59
  position: absolute;
60
+ display: flex;
61
+ justify-content: center;
62
+ align-items: center;
60
63
  width: 32px;
61
64
  height: 32px;
62
65
  top: 2 * $default-padding;
@@ -107,6 +110,7 @@ $image-overlay-transition-easing: ease-in;
107
110
 
108
111
  form .input .select2-container,
109
112
  form .input input[type="text"],
113
+ form .input textarea,
110
114
  .resource_info .value p {
111
115
  width: 100%;
112
116
  }
@@ -218,31 +222,38 @@ $image-overlay-transition-easing: ease-in;
218
222
 
219
223
  .previous-picture,
220
224
  .next-picture {
225
+ display: flex;
221
226
  position: absolute;
222
227
  top: 0;
223
228
  width: 64px;
224
229
  height: 128px;
225
- line-height: 120px;
226
230
  margin-top: -64px;
227
231
  cursor: pointer;
228
- text-align: center;
232
+ justify-content: center;
233
+ align-items: center;
229
234
  text-decoration: none;
230
235
  transition: background-color $image-overlay-transition-duration linear;
231
236
 
237
+ .icon {
238
+ width: 32px;
239
+ height: 32px;
240
+ fill: $white;
241
+ filter: drop-shadow(0 0 1px $very-dark-gray);
242
+ }
243
+
232
244
  &:hover {
233
245
  background-color: rgba(0, 0, 0, 0.3);
234
246
 
235
247
  .icon {
236
- color: $white;
237
- text-shadow: none;
248
+ transition: fill $image-overlay-transition-duration linear;
238
249
  }
239
250
  }
240
251
  }
241
252
 
242
253
  .icon {
243
- font-size: 4em;
244
- color: $medium-gray;
245
- text-shadow: 0 0 $default-padding $text-color;
254
+ --icon-size: 4em;
255
+ fill: $medium-gray;
256
+ filter: drop-shadow(0 0 $default-padding $text-color);
246
257
  transition: all $image-overlay-transition-duration linear;
247
258
  vertical-align: middle;
248
259
  }
@@ -255,7 +266,5 @@ $image-overlay-transition-easing: ease-in;
255
266
  .next-picture {
256
267
  right: $image-overlay-form-width + $picture-overlay-handle-width;
257
268
  @include border-left-radius($default-border-radius);
258
- transition: right $image-overlay-transition-duration
259
- $image-overlay-transition-easing;
260
269
  }
261
270
  }
@@ -1,8 +1,8 @@
1
- .js_filter_field_box {
1
+ alchemy-list-filter {
2
+ display: flex;
2
3
  position: relative;
3
- margin: $form-field-margin;
4
4
 
5
- > .icon {
5
+ > alchemy-icon {
6
6
  position: absolute;
7
7
  left: 8px;
8
8
  top: 50%;
@@ -15,21 +15,22 @@
15
15
  padding-right: 24px;
16
16
  margin: 0;
17
17
 
18
- .input & {
18
+ form .input & {
19
19
  float: none;
20
20
  width: 100%;
21
21
  }
22
22
  }
23
23
 
24
24
  .js_filter_field_clear {
25
- display: none;
25
+ display: flex;
26
+ visibility: hidden;
26
27
  position: absolute;
27
28
  right: 4px;
28
29
  top: 50%;
29
30
  transform: translateY(-50%);
30
31
  width: 16px;
31
32
  height: 16px;
32
- line-height: 14px;
33
- text-align: center;
33
+ align-items: center;
34
+ justify-content: center;
34
35
  }
35
36
  }
@@ -41,7 +41,7 @@ ul.list {
41
41
 
42
42
  .list-primary,
43
43
  .list-secondary {
44
- display: inline-block;
44
+ display: inline-flex;
45
45
  overflow: hidden;
46
46
  text-overflow: ellipsis;
47
47
  vertical-align: middle;
@@ -124,34 +124,31 @@
124
124
  opacity: 1;
125
125
  }
126
126
 
127
+ svg {
128
+ fill: currentColor;
129
+ transition: fill $transition-duration $transition-easing;
130
+ }
131
+
127
132
  img,
128
133
  svg,
129
134
  .icon {
130
135
  display: inline-flex;
131
- width: 24px;
132
- height: 24px;
136
+ width: var(--icon-size-xxl);
137
+ height: var(--icon-size-xxl);
133
138
  align-items: center;
134
139
  justify-content: center;
135
140
  }
136
141
 
137
142
  img {
138
143
  border-style: none;
139
- height: 24px;
140
144
  vertical-align: -0.6em;
141
145
  }
142
146
 
143
- .icon {
144
- vertical-align: -0.15em;
145
- font-size: 20px;
146
- font-weight: 400;
147
- color: inherit;
148
- }
149
-
150
147
  a {
151
148
  display: flex;
152
149
  align-items: center;
153
150
  height: 46px;
154
- padding-left: 3 * $default-padding;
151
+ padding-left: 14px;
155
152
  font-weight: bold;
156
153
  color: $main-menu-text-color;
157
154
  transition: color $transition-duration $transition-easing;
@@ -214,7 +211,7 @@
214
211
  line-height: 24px;
215
212
 
216
213
  a {
217
- padding: 8px 4px 8px 44px;
214
+ padding: 8px 4px 8px 42px;
218
215
  }
219
216
  }
220
217
  }
@@ -14,7 +14,7 @@
14
14
  margin: 0 8px 0 4px;
15
15
 
16
16
  .select2-highlighted & {
17
- color: $white;
17
+ fill: $white;
18
18
  }
19
19
  }
20
20
  }
@@ -27,6 +27,7 @@
27
27
  overflow: hidden;
28
28
  text-overflow: ellipsis;
29
29
  max-width: 100%;
30
+ line-height: 2;
30
31
 
31
32
  .external & {
32
33
  max-width: 90%;
@@ -35,6 +36,9 @@
35
36
  }
36
37
 
37
38
  .node_page {
39
+ display: inline-flex;
40
+ gap: $default-padding;
41
+ align-items: center;
38
42
  padding: 0 8px;
39
43
  margin-left: auto;
40
44
  }
@@ -48,14 +52,10 @@
48
52
  line-height: $sitemap-line-height;
49
53
  font-size: $small-font-size;
50
54
  @include border-right-radius($default-border-radius);
51
-
52
- > i {
53
- margin-left: auto;
54
- padding-left: $default-padding;
55
- }
56
55
  }
57
56
 
58
57
  .node_folder {
58
+ display: inline-flex;
59
59
  cursor: pointer;
60
60
  }
61
61
 
@@ -84,6 +84,8 @@
84
84
  }
85
85
 
86
86
  .sitemap_node {
87
+ display: flex;
88
+ align-items: center;
87
89
  height: $sitemap-line-height;
88
90
  margin: 3 * $default-margin 0;
89
91
  transition: background-color $transition-duration;
@@ -102,8 +104,9 @@
102
104
  }
103
105
 
104
106
  .node_name {
105
- height: $sitemap-line-height;
106
107
  display: flex;
108
+ height: $sitemap-line-height;
109
+ flex: 1;
107
110
  justify-content: space-between;
108
111
  @include border-left-radius($default-border-radius);
109
112
  padding: 0 0 0 10px;
@@ -124,27 +127,26 @@
124
127
  }
125
128
 
126
129
  .nodes_tree-left_images {
130
+ justify-content: center;
131
+ display: flex;
132
+ align-items: center;
127
133
  position: relative;
128
134
  width: 32px;
129
- line-height: $sitemap-line-height;
130
- float: left;
135
+ height: $sitemap-line-height;
131
136
  padding: 0 2 * $default-padding;
132
- text-align: center;
133
137
  }
134
138
 
135
139
  .nodes_tree-right_tools {
136
140
  display: flex;
137
141
  height: $sitemap-line-height;
138
142
  padding: 0 2 * $default-padding;
139
- float: right;
140
143
  align-items: center;
141
144
 
142
145
  > a {
143
- float: left;
146
+ display: inline-flex;
144
147
  width: $sitemap-line-height;
145
148
  height: $sitemap-line-height;
146
- line-height: $sitemap-line-height;
147
- text-align: center;
149
+ align-items: center;
148
150
  text-decoration: none;
149
151
  margin: 0;
150
152
 
@@ -1,30 +1,73 @@
1
- // Some table columns also have .message class
2
- div.message {
3
- padding: 8px 8px 8px 32px;
4
- line-height: 17px;
1
+ alchemy-message {
2
+ display: block;
5
3
  border-width: $default-border-width;
6
4
  border-style: $default-border-style;
7
5
  border-radius: $default-border-radius;
8
6
  position: relative;
7
+ padding: 8px 16px 8px 32px;
9
8
  margin-bottom: 8px;
10
9
  text-align: left;
10
+ min-height: 2.6em;
11
+ word-break: break-word;
12
+ line-height: 1.5;
11
13
 
12
- h1,
13
- h2,
14
- h3 {
15
- margin-top: 0;
14
+ &[type="footnote"] {
15
+ font-size: $small-font-size;
16
+ margin: 16px;
17
+ }
18
+
19
+ &[type="notice"] {
20
+ border-color: $success_border_color;
21
+ color: $success_text_color;
22
+ background-color: $success_background_color;
16
23
  }
17
24
 
18
- .icon {
25
+ &[type="hint"] {
26
+ background-color: $hint-background-color;
27
+ border-color: $hint-background-color;
28
+ color: $hint-text-color;
29
+ }
30
+
31
+ &[type="info"] {
32
+ background-color: $info_background_color;
33
+ border-color: $info_border_color;
34
+ color: $info_text_color;
35
+ }
36
+
37
+ &[type="error"] {
38
+ background-color: $error_background_color;
39
+ border-color: $error_border_color;
40
+ color: $error_text_color;
41
+ }
42
+
43
+ &[type="warning"],
44
+ &[type="warn"],
45
+ &[type="alert"] {
46
+ background-color: $warning_background_color;
47
+ border-color: $warning_border_color;
48
+ color: $warning_text_color;
49
+ }
50
+
51
+ alchemy-icon {
19
52
  position: absolute;
20
53
  left: 2 * $default-margin;
21
- top: 2 * $default-margin;
54
+ top: 9px;
22
55
  color: inherit;
56
+
57
+ .icon {
58
+ fill: currentColor;
59
+ }
23
60
  }
24
61
 
25
- &.footnote {
26
- font-size: $small-font-size;
27
- margin: 16px;
62
+ h1 {
63
+ font-size: 1.3rem;
64
+ line-height: 1.1;
65
+ }
66
+
67
+ h1,
68
+ h2,
69
+ h3 {
70
+ margin-top: 0;
28
71
  }
29
72
 
30
73
  a {
@@ -45,30 +88,4 @@ div.message {
45
88
  margin-bottom: 4px;
46
89
  }
47
90
  }
48
-
49
- &.hint {
50
- background-color: $hint-background-color;
51
- border-color: $hint-background-color;
52
- color: $hint-text-color;
53
- }
54
-
55
- &.info {
56
- background-color: $info_background_color;
57
- border-color: $info_border_color;
58
- color: $info_text_color;
59
- }
60
-
61
- &.error {
62
- background-color: $error_background_color;
63
- border-color: $error_border_color;
64
- color: $error_text_color;
65
- }
66
-
67
- &.warning,
68
- &.warn,
69
- &.alert {
70
- background-color: $warning_background_color;
71
- border-color: $warning_border_color;
72
- color: $warning_text_color;
73
- }
74
91
  }
@@ -12,10 +12,7 @@
12
12
 
13
13
  .icon {
14
14
  margin: 0 $default-margin;
15
-
16
- .select2-highlighted & {
17
- color: $white;
18
- }
15
+ fill: currentColor;
19
16
  }
20
17
  }
21
18
 
@@ -65,8 +65,18 @@
65
65
  margin: 0;
66
66
  }
67
67
 
68
+ .next_page,
69
+ .previous_page,
70
+ .first-page,
71
+ .last-page,
72
+ .gap {
73
+ display: inline-flex;
74
+ align-items: center;
75
+ justify-content: center;
76
+ }
77
+
68
78
  .icon {
69
- color: inherit;
79
+ fill: currentColor;
70
80
  }
71
81
  }
72
82
 
@@ -16,12 +16,12 @@
16
16
 
17
17
  .collapsed-menu.elements-window-visible & {
18
18
  width: calc(
19
- 100vw - #{$collapsed-main-menu-width - $default-border-width} - #{$elements-window-min-width}
19
+ 100vw - #{$collapsed-main-menu-width - $default-border-width} - #{$elements-window-width}
20
20
  );
21
21
 
22
- @media screen and (min-width: 1777px) {
22
+ @media screen and (min-width: $large-screen-break-point) {
23
23
  width: calc(
24
- 100vw - #{$collapsed-main-menu-width - $default-border-width} - #{$elements-window-width}
24
+ 100vw - #{$collapsed-main-menu-width - $default-border-width} - #{$elements-window-min-width}
25
25
  );
26
26
  }
27
27
  }
@@ -28,19 +28,19 @@
28
28
  }
29
29
 
30
30
  .search_field_clear {
31
- display: none;
31
+ display: flex;
32
+ visibility: hidden;
32
33
  position: absolute;
33
34
  top: 7px;
34
35
  right: 8px;
35
36
  width: 16px;
36
37
  height: 16px;
37
- line-height: 14px;
38
- text-align: center;
38
+ align-items: center;
39
+ justify-content: center;
39
40
  }
40
41
 
41
42
  #toolbar,
42
43
  #overlay_toolbar {
43
-
44
44
  .search_form {
45
45
  position: absolute;
46
46
  top: 0;
@@ -74,13 +74,16 @@ select {
74
74
  display: flex;
75
75
  align-items: center;
76
76
  justify-content: center;
77
- font-family: "remixicon";
78
77
  background-image: none;
79
- font-weight: normal;
80
78
  color: $icon-color;
81
79
 
82
80
  &:before {
83
- content: $ri-arrow-down-s-line;
81
+ display: inline-block;
82
+ content: "";
83
+ width: 1rem;
84
+ height: 1rem;
85
+ background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="#{$icon-color}"><path d="M11.9999 13.1714L16.9497 8.22168L18.3639 9.63589L11.9999 15.9999L5.63599 9.63589L7.0502 8.22168L11.9999 13.1714Z"></path></svg>')
86
+ no-repeat;
84
87
  }
85
88
  }
86
89
  }
@@ -131,16 +134,19 @@ select {
131
134
  &.select2-container-multi,
132
135
  &.select2-allowclear {
133
136
  .select2-search-choice-close {
134
- font-family: "remixicon";
135
137
  left: auto;
136
138
  right: $default-padding;
137
- top: $default-padding;
139
+ top: 5px;
138
140
  background: none;
139
- font-size: 12px;
140
141
  text-decoration: none;
141
142
 
142
143
  &:before {
143
- content: $ri-close-line;
144
+ content: "";
145
+ display: inline-flex;
146
+ width: 12px;
147
+ height: 12px;
148
+ background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="#{$icon-color}"><path d="M11.9997 10.5865L16.9495 5.63672L18.3637 7.05093L13.4139 12.0007L18.3637 16.9504L16.9495 18.3646L11.9997 13.4149L7.04996 18.3646L5.63574 16.9504L10.5855 12.0007L5.63574 7.05093L7.04996 5.63672L11.9997 10.5865Z"></path></svg>')
149
+ no-repeat;
144
150
  }
145
151
 
146
152
  &:hover {
@@ -96,7 +96,7 @@
96
96
  --sl-shadow-small: 0 1px 2px hsl(240 3.8% 46.1% / 12%);
97
97
  --sl-shadow-medium: 0 2px 4px hsl(240 3.8% 46.1% / 12%);
98
98
  --sl-shadow-large: 0 2px 8px hsl(240 3.8% 46.1% / 12%);
99
- --sl-shadow-x-large: 0 4px 16px hsl(240 3.8% 46.1% / 12%);
99
+ --sl-shadow-x-large: 0 8px 16px rgba(35, 35, 35, 0.5);
100
100
 
101
101
  /*
102
102
  * Spacings
@@ -255,7 +255,7 @@
255
255
  * Overlays
256
256
  */
257
257
 
258
- --sl-overlay-background-color: hsl(240 3.8% 46.1% / 33%);
258
+ --sl-overlay-background-color: hsl(0 0% 39.2% / 40%);
259
259
 
260
260
  /*
261
261
  * Panels
@@ -343,3 +343,34 @@ sl-tooltip {
343
343
  box-shadow: 0 0 var(--spacing-1) var(--color-grey_medium);
344
344
  }
345
345
  }
346
+
347
+ sl-dialog {
348
+ &::part(panel) {
349
+ background-color: var(--color-grey_light);
350
+ --body-spacing: var(--spacing-4) var(--spacing-3);
351
+ --footer-spacing: var(--spacing-4) var(--spacing-3);
352
+ }
353
+
354
+ &::part(header) {
355
+ --header-spacing: var(--spacing-3);
356
+ background-color: var(--color-blue_dark);
357
+ border-top-left-radius: var(--border-radius_medium);
358
+ border-top-right-radius: var(--border-radius_medium);
359
+ }
360
+
361
+ &::part(header-actions) {
362
+ --header-spacing: var(--spacing-1);
363
+ }
364
+
365
+ &::part(title) {
366
+ --sl-font-size-large: var(--font-size_small);
367
+ color: var(--color-white);
368
+ }
369
+
370
+ &::part(close-button) {
371
+ --sl-color-primary-600: var(--color-white);
372
+ --sl-color-primary-700: var(--color-white);
373
+ color: var(--color-white);
374
+ fill: currentColor;
375
+ }
376
+ }