alchemy_cms 7.0.8 → 7.1.0.pre.b2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (394) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +162 -0
  3. data/Gemfile +9 -11
  4. data/README.md +11 -9
  5. data/alchemy_cms.gemspec +4 -3
  6. data/app/assets/config/alchemy_manifest.js +3 -5
  7. data/app/assets/images/alchemy/missing-image.svg +1 -1
  8. data/app/assets/javascripts/alchemy/admin.js +1 -23
  9. data/app/assets/javascripts/alchemy/alchemy.confirm_dialog.js.coffee +2 -3
  10. data/app/assets/javascripts/alchemy/alchemy.dialog.js.coffee +19 -34
  11. data/app/assets/javascripts/alchemy/alchemy.elements_window.js.coffee +38 -13
  12. data/app/assets/javascripts/alchemy/alchemy.file_progress.js.coffee +1 -1
  13. data/app/assets/javascripts/alchemy/alchemy.fixed_elements.js +32 -25
  14. data/app/assets/javascripts/alchemy/alchemy.growler.js.coffee +1 -1
  15. data/app/assets/javascripts/alchemy/alchemy.image_overlay.coffee +3 -5
  16. data/app/assets/javascripts/alchemy/alchemy.initializer.js.coffee +0 -57
  17. data/app/assets/javascripts/alchemy/alchemy.link_dialog.js.coffee +24 -65
  18. data/app/assets/javascripts/alchemy/alchemy.list_filter.js.coffee +2 -2
  19. data/app/assets/javascripts/alchemy/alchemy.preview.js.coffee +5 -4
  20. data/app/assets/javascripts/alchemy/alchemy.preview_window.js.coffee +5 -5
  21. data/app/assets/javascripts/alchemy/templates/index.js +0 -2
  22. data/app/assets/javascripts/alchemy/templates/node_folder.hbs +1 -1
  23. data/app/assets/javascripts/alchemy/templates/page.hbs +1 -1
  24. data/app/assets/javascripts/alchemy/templates/page_folder.hbs +2 -2
  25. data/app/assets/javascripts/tinymce/icons/remixicons/icons.js +93 -0
  26. data/app/assets/javascripts/tinymce/plugins/alchemy_link/plugin.min.js +37 -18
  27. data/app/assets/stylesheets/alchemy/_custom-properties.scss +82 -0
  28. data/app/assets/stylesheets/alchemy/_mixins.scss +38 -30
  29. data/app/assets/stylesheets/alchemy/_variables.scss +23 -8
  30. data/app/assets/stylesheets/alchemy/admin.scss +3 -4
  31. data/app/assets/stylesheets/alchemy/archive.scss +110 -50
  32. data/app/assets/stylesheets/alchemy/attachments.scss +5 -4
  33. data/app/assets/stylesheets/alchemy/buttons.scss +41 -166
  34. data/app/assets/stylesheets/alchemy/dashboard.scss +31 -6
  35. data/app/assets/stylesheets/alchemy/dialogs.scss +12 -28
  36. data/app/assets/stylesheets/alchemy/elements.scss +272 -282
  37. data/app/assets/stylesheets/alchemy/flash.scss +20 -12
  38. data/app/assets/stylesheets/alchemy/forms.scss +21 -34
  39. data/app/assets/stylesheets/alchemy/frame.scss +11 -32
  40. data/app/assets/stylesheets/alchemy/hints.scss +4 -62
  41. data/app/assets/stylesheets/alchemy/image_library.scss +36 -33
  42. data/app/assets/stylesheets/alchemy/menubar.scss +7 -6
  43. data/app/assets/stylesheets/alchemy/navigation.scss +27 -15
  44. data/app/assets/stylesheets/alchemy/nodes.scss +11 -7
  45. data/app/assets/stylesheets/alchemy/notices.scss +16 -4
  46. data/app/assets/stylesheets/alchemy/page-select.scss +10 -2
  47. data/app/assets/stylesheets/alchemy/pagination.scss +22 -13
  48. data/app/assets/stylesheets/alchemy/resource_info.scss +7 -5
  49. data/app/assets/stylesheets/alchemy/selects.scss +49 -42
  50. data/app/assets/stylesheets/alchemy/shoelace.scss +345 -0
  51. data/app/assets/stylesheets/alchemy/sitemap.scss +24 -14
  52. data/app/assets/stylesheets/alchemy/spinner.scss +9 -19
  53. data/app/assets/stylesheets/alchemy/tables.scss +16 -24
  54. data/app/assets/stylesheets/alchemy/tags.scss +4 -0
  55. data/app/assets/stylesheets/alchemy/toolbar.scss +29 -25
  56. data/app/assets/stylesheets/alchemy/upload.scss +140 -89
  57. data/app/assets/stylesheets/tinymce/skins/content/alchemy/content.min.scss +69 -0
  58. data/app/assets/stylesheets/tinymce/skins/skintool.json +38 -0
  59. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/content.css +711 -0
  60. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/content.inline.css +705 -0
  61. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/content.inline.min.css +7 -0
  62. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/content.min.css +7 -0
  63. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/content.mobile.css +29 -0
  64. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/content.mobile.min.css +7 -0
  65. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/fonts/tinymce-mobile.woff +0 -0
  66. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/skin.min.scss +3798 -0
  67. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/skin.mobile.css +677 -0
  68. data/app/assets/stylesheets/tinymce/skins/ui/alchemy/skin.mobile.min.css +7 -0
  69. data/app/components/alchemy/admin/node_select.rb +39 -0
  70. data/app/components/alchemy/admin/page_select.rb +42 -0
  71. data/app/controllers/alchemy/admin/base_controller.rb +5 -6
  72. data/app/controllers/alchemy/admin/elements_controller.rb +63 -35
  73. data/app/controllers/alchemy/admin/pages_controller.rb +9 -4
  74. data/app/controllers/alchemy/base_controller.rb +4 -2
  75. data/app/controllers/concerns/alchemy/admin/uploader_responses.rb +1 -1
  76. data/app/controllers/concerns/alchemy/site_redirects.rb +1 -1
  77. data/app/decorators/alchemy/element_editor.rb +0 -2
  78. data/app/helpers/alchemy/admin/attachments_helper.rb +6 -5
  79. data/app/helpers/alchemy/admin/base_helper.rb +17 -12
  80. data/app/helpers/alchemy/admin/ingredients_helper.rb +4 -1
  81. data/app/helpers/alchemy/admin/pages_helper.rb +5 -11
  82. data/app/helpers/alchemy/base_helper.rb +47 -13
  83. data/app/javascript/alchemy_admin/clipboard.js +16 -0
  84. data/app/javascript/alchemy_admin/components/alchemy_html_element.js +129 -0
  85. data/app/javascript/alchemy_admin/components/button.js +59 -0
  86. data/app/javascript/alchemy_admin/components/char_counter.js +40 -0
  87. data/app/javascript/alchemy_admin/components/datepicker.js +39 -0
  88. data/app/javascript/alchemy_admin/components/dialog_link.js +45 -0
  89. data/app/javascript/alchemy_admin/components/element_editor/publish_element_button.js +36 -0
  90. data/app/javascript/alchemy_admin/components/element_editor.js +553 -0
  91. data/app/javascript/alchemy_admin/components/ingredient_group.js +54 -0
  92. data/app/javascript/alchemy_admin/components/link_buttons/link_button.js +48 -0
  93. data/app/javascript/alchemy_admin/components/link_buttons/unlink_button.js +38 -0
  94. data/app/javascript/alchemy_admin/components/link_buttons.js +79 -0
  95. data/app/javascript/alchemy_admin/components/node_select.js +45 -0
  96. data/app/javascript/alchemy_admin/components/overlay.js +18 -0
  97. data/app/javascript/alchemy_admin/components/page_select.js +63 -0
  98. data/app/javascript/alchemy_admin/components/remote_select.js +134 -0
  99. data/app/javascript/alchemy_admin/components/select.js +12 -0
  100. data/app/javascript/alchemy_admin/components/spinner.js +31 -0
  101. data/app/javascript/alchemy_admin/components/tinymce.js +134 -0
  102. data/app/javascript/alchemy_admin/components/uploader/file_upload.js +266 -0
  103. data/app/javascript/alchemy_admin/components/uploader/progress.js +258 -0
  104. data/app/javascript/alchemy_admin/components/uploader.js +132 -0
  105. data/app/javascript/alchemy_admin/dirty.js +49 -0
  106. data/app/javascript/alchemy_admin/file_editors.js +1 -1
  107. data/app/javascript/alchemy_admin/gui.js +14 -0
  108. data/app/javascript/alchemy_admin/i18n.js +12 -8
  109. data/app/javascript/alchemy_admin/image_cropper.js +6 -3
  110. data/app/javascript/alchemy_admin/image_loader.js +7 -15
  111. data/app/javascript/alchemy_admin/ingredient_anchor_link.js +2 -5
  112. data/app/javascript/alchemy_admin/initializer.js +65 -0
  113. data/app/javascript/alchemy_admin/locales/en.js +31 -0
  114. data/app/javascript/alchemy_admin/picture_editors.js +6 -4
  115. data/app/javascript/alchemy_admin/picture_selector.js +38 -0
  116. data/app/javascript/alchemy_admin/please_wait_overlay.js +8 -0
  117. data/app/javascript/alchemy_admin/sortable_elements.js +78 -0
  118. data/app/javascript/alchemy_admin/spinner.js +36 -0
  119. data/app/javascript/alchemy_admin/tags_autocomplete.js +46 -0
  120. data/app/javascript/alchemy_admin/utils/ajax.js +6 -5
  121. data/app/javascript/alchemy_admin/utils/debounce.js +10 -0
  122. data/app/javascript/alchemy_admin/utils/dom_helpers.js +20 -0
  123. data/app/javascript/alchemy_admin/utils/format.js +11 -0
  124. data/app/javascript/alchemy_admin/utils/max.js +3 -0
  125. data/app/javascript/alchemy_admin/utils/string_conversions.js +10 -0
  126. data/app/javascript/alchemy_admin.js +64 -13
  127. data/app/javascript/menubar.js +10 -0
  128. data/app/models/alchemy/attachment.rb +9 -11
  129. data/app/models/alchemy/element.rb +11 -0
  130. data/app/models/alchemy/ingredients/richtext.rb +1 -10
  131. data/app/models/alchemy/node.rb +4 -0
  132. data/app/models/alchemy/page/page_naming.rb +7 -0
  133. data/app/models/alchemy/page/page_natures.rb +10 -2
  134. data/app/models/alchemy/page.rb +11 -51
  135. data/app/models/alchemy/picture/url.rb +1 -9
  136. data/app/models/alchemy/picture_variant.rb +11 -2
  137. data/app/models/concerns/alchemy/picture_thumbnails.rb +1 -1
  138. data/app/serializers/alchemy/page_tree_serializer.rb +2 -1
  139. data/app/services/alchemy/copy_page.rb +98 -0
  140. data/app/views/alchemy/_menubar.html.erb +17 -13
  141. data/app/views/alchemy/admin/attachments/_archive_overlay.html.erb +14 -10
  142. data/app/views/alchemy/admin/attachments/_attachment.html.erb +44 -36
  143. data/app/views/alchemy/admin/attachments/_replace_button.html.erb +15 -21
  144. data/app/views/alchemy/admin/attachments/archive_overlay.js.erb +0 -1
  145. data/app/views/alchemy/admin/attachments/assign.js.erb +1 -1
  146. data/app/views/alchemy/admin/attachments/index.html.erb +6 -4
  147. data/app/views/alchemy/admin/attachments/show.html.erb +10 -23
  148. data/app/views/alchemy/admin/clipboard/clear.js.erb +1 -1
  149. data/app/views/alchemy/admin/clipboard/index.html.erb +3 -7
  150. data/app/views/alchemy/admin/clipboard/insert.js.erb +1 -1
  151. data/app/views/alchemy/admin/crop.html.erb +1 -1
  152. data/app/views/alchemy/admin/dashboard/_locked_pages.html.erb +1 -1
  153. data/app/views/alchemy/admin/dashboard/index.html.erb +13 -11
  154. data/app/views/alchemy/admin/dashboard/info.html.erb +7 -7
  155. data/app/views/alchemy/admin/elements/_add_nested_element_form.html.erb +21 -23
  156. data/app/views/alchemy/admin/elements/_element.html.erb +52 -44
  157. data/app/views/alchemy/admin/elements/_footer.html.erb +1 -1
  158. data/app/views/alchemy/admin/elements/_form.html.erb +1 -1
  159. data/app/views/alchemy/admin/elements/_header.html.erb +11 -12
  160. data/app/views/alchemy/admin/elements/_toolbar.html.erb +33 -45
  161. data/app/views/alchemy/admin/elements/create.js.erb +7 -15
  162. data/app/views/alchemy/admin/elements/destroy.js.erb +0 -2
  163. data/app/views/alchemy/admin/elements/index.html.erb +27 -24
  164. data/app/views/alchemy/admin/elements/new.html.erb +9 -11
  165. data/app/views/alchemy/admin/ingredients/_file_fields.html.erb +2 -2
  166. data/app/views/alchemy/admin/ingredients/_picture_fields.html.erb +3 -3
  167. data/app/views/alchemy/admin/ingredients/_video_fields.html.erb +1 -2
  168. data/app/views/alchemy/admin/languages/_form.html.erb +2 -3
  169. data/app/views/alchemy/admin/languages/_language.html.erb +15 -8
  170. data/app/views/alchemy/admin/languages/_table.html.erb +1 -0
  171. data/app/views/alchemy/admin/layoutpages/_layoutpage.html.erb +28 -16
  172. data/app/views/alchemy/admin/layoutpages/index.html.erb +2 -2
  173. data/app/views/alchemy/admin/legacy_page_urls/_legacy_page_url.html.erb +12 -8
  174. data/app/views/alchemy/admin/legacy_page_urls/_new.html.erb +1 -1
  175. data/app/views/alchemy/admin/nodes/_form.html.erb +20 -21
  176. data/app/views/alchemy/admin/nodes/_node.html.erb +39 -34
  177. data/app/views/alchemy/admin/nodes/index.html.erb +1 -1
  178. data/app/views/alchemy/admin/pages/_anchor_link.html.erb +4 -4
  179. data/app/views/alchemy/admin/pages/_create_language_form.html.erb +2 -2
  180. data/app/views/alchemy/admin/pages/_current_page.html.erb +1 -1
  181. data/app/views/alchemy/admin/pages/_external_link.html.erb +4 -4
  182. data/app/views/alchemy/admin/pages/_file_link.html.erb +5 -5
  183. data/app/views/alchemy/admin/pages/_form.html.erb +10 -21
  184. data/app/views/alchemy/admin/pages/_internal_link.html.erb +4 -4
  185. data/app/views/alchemy/admin/pages/_locked_page.html.erb +2 -2
  186. data/app/views/alchemy/admin/pages/_new_page_form.html.erb +4 -17
  187. data/app/views/alchemy/admin/pages/_page.html.erb +76 -72
  188. data/app/views/alchemy/admin/pages/_page_infos.html.erb +23 -7
  189. data/app/views/alchemy/admin/pages/_page_layout_filter.html.erb +2 -1
  190. data/app/views/alchemy/admin/pages/_page_status.html.erb +11 -21
  191. data/app/views/alchemy/admin/pages/_publication_fields.html.erb +2 -5
  192. data/app/views/alchemy/admin/pages/_table.html.erb +1 -1
  193. data/app/views/alchemy/admin/pages/_table_row.html.erb +43 -39
  194. data/app/views/alchemy/admin/pages/_toolbar.html.erb +43 -38
  195. data/app/views/alchemy/admin/pages/configure.html.erb +12 -14
  196. data/app/views/alchemy/admin/pages/edit.html.erb +80 -103
  197. data/app/views/alchemy/admin/pages/info.html.erb +20 -11
  198. data/app/views/alchemy/admin/pages/link.html.erb +22 -16
  199. data/app/views/alchemy/admin/pages/new.html.erb +9 -11
  200. data/app/views/alchemy/admin/pages/unlock.js.erb +10 -3
  201. data/app/views/alchemy/admin/partials/_language_tree_select.html.erb +15 -13
  202. data/app/views/alchemy/admin/partials/_main_navigation_entry.html.erb +3 -5
  203. data/app/views/alchemy/admin/partials/_routes.html.erb +10 -2
  204. data/app/views/alchemy/admin/partials/_site_select.html.erb +6 -5
  205. data/app/views/alchemy/admin/partials/_toolbar_button.html.erb +28 -23
  206. data/app/views/alchemy/admin/pictures/_archive.html.erb +5 -5
  207. data/app/views/alchemy/admin/pictures/_archive_overlay.html.erb +1 -1
  208. data/app/views/alchemy/admin/pictures/_filter_and_size_bar.html.erb +21 -23
  209. data/app/views/alchemy/admin/pictures/_infos.html.erb +2 -6
  210. data/app/views/alchemy/admin/pictures/_picture.html.erb +17 -21
  211. data/app/views/alchemy/admin/pictures/_picture_to_assign.html.erb +17 -16
  212. data/app/views/alchemy/admin/pictures/_tag_list.html.erb +1 -1
  213. data/app/views/alchemy/admin/pictures/archive_overlay.js.erb +1 -1
  214. data/app/views/alchemy/admin/pictures/assign.js.erb +1 -1
  215. data/app/views/alchemy/admin/pictures/index.html.erb +34 -30
  216. data/app/views/alchemy/admin/pictures/show.html.erb +3 -3
  217. data/app/views/alchemy/admin/resources/_filter.html.erb +2 -2
  218. data/app/views/alchemy/admin/resources/_form.html.erb +2 -2
  219. data/app/views/alchemy/admin/resources/_per_page_select.html.erb +1 -1
  220. data/app/views/alchemy/admin/resources/_resource.html.erb +16 -9
  221. data/app/views/alchemy/admin/resources/_table.html.erb +4 -1
  222. data/app/views/alchemy/admin/resources/index.html.erb +22 -19
  223. data/app/views/alchemy/admin/sites/index.html.erb +2 -1
  224. data/app/views/alchemy/admin/styleguide/index.html.erb +54 -28
  225. data/app/views/alchemy/admin/tags/_tag.html.erb +16 -14
  226. data/app/views/alchemy/admin/tags/index.html.erb +15 -12
  227. data/app/views/alchemy/admin/tinymce/_setup.html.erb +28 -0
  228. data/app/views/alchemy/admin/uploader/_button.html.erb +23 -29
  229. data/app/views/alchemy/admin/uploader/_setup.html.erb +3 -8
  230. data/app/views/alchemy/base/500.html.erb +1 -1
  231. data/app/views/alchemy/base/error_notice.js.erb +0 -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/_file_editor.html.erb +5 -5
  235. data/app/views/alchemy/ingredients/_link_editor.html.erb +1 -1
  236. data/app/views/alchemy/ingredients/_node_editor.html.erb +6 -19
  237. data/app/views/alchemy/ingredients/_page_editor.html.erb +7 -19
  238. data/app/views/alchemy/ingredients/_picture_editor.html.erb +2 -2
  239. data/app/views/alchemy/ingredients/_richtext_editor.html.erb +6 -15
  240. data/app/views/alchemy/ingredients/_select_editor.html.erb +2 -1
  241. data/app/views/alchemy/ingredients/_text_editor.html.erb +1 -1
  242. data/app/views/alchemy/ingredients/shared/_anchor.html.erb +1 -1
  243. data/app/views/alchemy/ingredients/shared/_link_tools.html.erb +10 -20
  244. data/app/views/alchemy/ingredients/shared/_picture_tools.html.erb +42 -49
  245. data/app/views/kaminari/alchemy/_first_page.html.erb +4 -2
  246. data/app/views/kaminari/alchemy/_gap.html.erb +1 -1
  247. data/app/views/kaminari/alchemy/_last_page.html.erb +4 -2
  248. data/app/views/kaminari/alchemy/_next_page.html.erb +4 -2
  249. data/app/views/kaminari/alchemy/_prev_page.html.erb +4 -2
  250. data/app/views/layouts/alchemy/admin.html.erb +10 -29
  251. data/bundles/shoelace.js +10 -0
  252. data/bundles/tinymce.js +20 -0
  253. data/config/alchemy/config.yml +11 -10
  254. data/config/alchemy/modules.yml +30 -30
  255. data/config/brakeman.ignore +0 -34
  256. data/config/importmap.rb +9 -5
  257. data/config/initializers/dragonfly.rb +1 -0
  258. data/config/initializers/rails_live_reload.rb +13 -0
  259. data/config/locales/alchemy.en.yml +25 -9
  260. data/config/routes.rb +2 -1
  261. data/lib/alchemy/auth_accessors.rb +6 -1
  262. data/lib/alchemy/config.rb +24 -2
  263. data/lib/alchemy/dev_support/live_reload_watcher.rb +5 -0
  264. data/lib/alchemy/engine.rb +10 -3
  265. data/lib/alchemy/forms/builder.rb +18 -12
  266. data/lib/alchemy/resources_helper.rb +3 -3
  267. data/lib/alchemy/test_support/capybara_helpers.rb +8 -5
  268. data/lib/alchemy/test_support/having_picture_thumbnails_examples.rb +6 -6
  269. data/lib/alchemy/test_support/rspec_matchers.rb +14 -0
  270. data/lib/alchemy/test_support/shared_uploader_examples.rb +1 -1
  271. data/lib/alchemy/tinymce.rb +19 -3
  272. data/lib/alchemy/version.rb +1 -1
  273. data/package.json +30 -9
  274. data/rollup.config.mjs +65 -0
  275. data/vendor/assets/fonts/remixicon.eot +0 -0
  276. data/vendor/assets/fonts/remixicon.svg +7816 -0
  277. data/vendor/assets/fonts/remixicon.ttf +0 -0
  278. data/vendor/assets/fonts/remixicon.woff +0 -0
  279. data/vendor/assets/fonts/remixicon.woff2 +0 -0
  280. data/vendor/assets/stylesheets/remixicon.scss +10480 -0
  281. data/vendor/assets/stylesheets/tinymce/skins/content/default/content.min.css +1 -0
  282. data/vendor/javascript/clipboard.min.js +7 -0
  283. data/vendor/javascript/flatpickr.min.js +1 -0
  284. data/vendor/javascript/keymaster.min.js +1 -0
  285. data/vendor/javascript/rails-ujs.min.js +1 -0
  286. data/vendor/javascript/shoelace.min.js +995 -0
  287. data/vendor/javascript/sortable.min.js +7 -0
  288. data/vendor/javascript/tinymce.min.js +1 -0
  289. data/vendor/javascript/ungap-custom-elements.min.js +3 -0
  290. metadata +111 -124
  291. data/.codeclimate.yml +0 -35
  292. data/.editorconfig +0 -23
  293. data/.github/FUNDING.yml +0 -4
  294. data/.github/ISSUE_TEMPLATE/Bug_report.md +0 -22
  295. data/.github/ISSUE_TEMPLATE/Feature_request.md +0 -17
  296. data/.github/PULL_REQUEST_TEMPLATE.md +0 -18
  297. data/.github/workflows/brakeman-analysis.yml +0 -46
  298. data/.github/workflows/lint.yml +0 -37
  299. data/.github/workflows/stale.yml +0 -33
  300. data/.github/workflows/test.yml +0 -124
  301. data/.gitignore +0 -31
  302. data/.hound.yml +0 -9
  303. data/.localeapp/config.rb +0 -8
  304. data/.prettierrc +0 -6
  305. data/.rspec +0 -1
  306. data/.rubocop.yml +0 -7
  307. data/.standard.yml +0 -4
  308. data/.yardopts +0 -5
  309. data/app/assets/javascripts/alchemy/alchemy.autocomplete.js.coffee +0 -30
  310. data/app/assets/javascripts/alchemy/alchemy.base.js.coffee +0 -53
  311. data/app/assets/javascripts/alchemy/alchemy.buttons.js.coffee +0 -45
  312. data/app/assets/javascripts/alchemy/alchemy.char_counter.js.coffee +0 -19
  313. data/app/assets/javascripts/alchemy/alchemy.dirty.js.coffee +0 -59
  314. data/app/assets/javascripts/alchemy/alchemy.dragndrop.js.coffee +0 -79
  315. data/app/assets/javascripts/alchemy/alchemy.element_editors.js.coffee +0 -267
  316. data/app/assets/javascripts/alchemy/alchemy.gui.js.coffee +0 -27
  317. data/app/assets/javascripts/alchemy/alchemy.spinner.js +0 -32
  318. data/app/assets/javascripts/alchemy/alchemy.tooltips.coffee +0 -10
  319. data/app/assets/javascripts/alchemy/alchemy.uploader.js.coffee +0 -131
  320. data/app/assets/javascripts/alchemy/menubar.js.coffee +0 -8
  321. data/app/assets/javascripts/alchemy/node_select.js +0 -39
  322. data/app/assets/javascripts/alchemy/page_select.js +0 -46
  323. data/app/assets/javascripts/alchemy/templates/node.hbs +0 -16
  324. data/app/assets/javascripts/alchemy/templates/spinner.hbs +0 -7
  325. data/app/assets/stylesheets/alchemy/jquery-ui.scss +0 -435
  326. data/app/assets/stylesheets/tinymce/skins/alchemy/content.min.css.scss +0 -94
  327. data/app/assets/stylesheets/tinymce/skins/alchemy/fonts/tinymce-small.svg +0 -63
  328. data/app/assets/stylesheets/tinymce/skins/alchemy/fonts/tinymce-small.ttf +0 -0
  329. data/app/assets/stylesheets/tinymce/skins/alchemy/fonts/tinymce-small.woff +0 -0
  330. data/app/assets/stylesheets/tinymce/skins/alchemy/fonts/tinymce.svg +0 -129
  331. data/app/assets/stylesheets/tinymce/skins/alchemy/fonts/tinymce.ttf +0 -0
  332. data/app/assets/stylesheets/tinymce/skins/alchemy/fonts/tinymce.woff +0 -0
  333. data/app/assets/stylesheets/tinymce/skins/alchemy/img/anchor.gif +0 -0
  334. data/app/assets/stylesheets/tinymce/skins/alchemy/img/loader.gif +0 -0
  335. data/app/assets/stylesheets/tinymce/skins/alchemy/img/object.gif +0 -0
  336. data/app/assets/stylesheets/tinymce/skins/alchemy/img/trans.gif +0 -0
  337. data/app/assets/stylesheets/tinymce/skins/alchemy/skin.min.css.scss +0 -2105
  338. data/app/javascript/alchemy_admin/datepicker.js +0 -33
  339. data/app/javascript/alchemy_admin/tinymce.js +0 -146
  340. data/app/javascript/alchemy_admin/translations.js +0 -32
  341. data/app/views/alchemy/admin/elements/fold.js.erb +0 -33
  342. data/app/views/alchemy/admin/elements/order.js.erb +0 -11
  343. data/app/views/alchemy/admin/elements/publish.js.erb +0 -21
  344. data/app/views/alchemy/admin/elements/update.js.erb +0 -27
  345. data/vendor/assets/fonts/fa-regular-400.eot +0 -0
  346. data/vendor/assets/fonts/fa-regular-400.svg +0 -803
  347. data/vendor/assets/fonts/fa-regular-400.ttf +0 -0
  348. data/vendor/assets/fonts/fa-regular-400.woff +0 -0
  349. data/vendor/assets/fonts/fa-regular-400.woff2 +0 -0
  350. data/vendor/assets/fonts/fa-solid-900.eot +0 -0
  351. data/vendor/assets/fonts/fa-solid-900.svg +0 -4938
  352. data/vendor/assets/fonts/fa-solid-900.ttf +0 -0
  353. data/vendor/assets/fonts/fa-solid-900.woff +0 -0
  354. data/vendor/assets/fonts/fa-solid-900.woff2 +0 -0
  355. data/vendor/assets/javascripts/clipboard.min.js +0 -7
  356. data/vendor/assets/javascripts/fileupload/jquery.fileupload-process.js +0 -178
  357. data/vendor/assets/javascripts/fileupload/jquery.fileupload-validate.js +0 -125
  358. data/vendor/assets/javascripts/fileupload/jquery.fileupload.js +0 -1502
  359. data/vendor/assets/javascripts/fileupload/jquery.iframe-transport.js +0 -224
  360. data/vendor/assets/javascripts/jquery-ui/data.js +0 -45
  361. data/vendor/assets/javascripts/jquery-ui/ie.js +0 -20
  362. data/vendor/assets/javascripts/jquery-ui/keycode.js +0 -51
  363. data/vendor/assets/javascripts/jquery-ui/plugin.js +0 -49
  364. data/vendor/assets/javascripts/jquery-ui/safe-active-element.js +0 -46
  365. data/vendor/assets/javascripts/jquery-ui/safe-blur.js +0 -27
  366. data/vendor/assets/javascripts/jquery-ui/scroll-parent.js +0 -50
  367. data/vendor/assets/javascripts/jquery-ui/unique-id.js +0 -54
  368. data/vendor/assets/javascripts/jquery-ui/version.js +0 -20
  369. data/vendor/assets/javascripts/jquery-ui/widget.js +0 -754
  370. data/vendor/assets/javascripts/jquery-ui/widgets/draggable.js +0 -1268
  371. data/vendor/assets/javascripts/jquery-ui/widgets/mouse.js +0 -241
  372. data/vendor/assets/javascripts/jquery-ui/widgets/sortable.js +0 -1623
  373. data/vendor/assets/javascripts/jquery-ui/widgets/tabs.js +0 -931
  374. data/vendor/assets/javascripts/jquery_plugins/jquery.scrollTo.min.js +0 -7
  375. data/vendor/assets/javascripts/jquery_plugins/jquery.ui.tabspaging.js +0 -296
  376. data/vendor/assets/javascripts/keymaster.js +0 -296
  377. data/vendor/assets/javascripts/requestAnimationFrame.js +0 -31
  378. data/vendor/assets/javascripts/tinymce/license.txt +0 -504
  379. data/vendor/assets/javascripts/tinymce/tinymce.min.js +0 -2
  380. data/vendor/assets/stylesheets/fontawesome/_animated.scss +0 -20
  381. data/vendor/assets/stylesheets/fontawesome/_bordered-pulled.scss +0 -20
  382. data/vendor/assets/stylesheets/fontawesome/_core.scss +0 -21
  383. data/vendor/assets/stylesheets/fontawesome/_fixed-width.scss +0 -6
  384. data/vendor/assets/stylesheets/fontawesome/_icons.scss +0 -1441
  385. data/vendor/assets/stylesheets/fontawesome/_larger.scss +0 -23
  386. data/vendor/assets/stylesheets/fontawesome/_list.scss +0 -18
  387. data/vendor/assets/stylesheets/fontawesome/_mixins.scss +0 -56
  388. data/vendor/assets/stylesheets/fontawesome/_rotated-flipped.scss +0 -24
  389. data/vendor/assets/stylesheets/fontawesome/_screen-reader.scss +0 -5
  390. data/vendor/assets/stylesheets/fontawesome/_stacked.scss +0 -31
  391. data/vendor/assets/stylesheets/fontawesome/_variables.scss +0 -1458
  392. data/vendor/assets/stylesheets/fontawesome/fontawesome.scss +0 -16
  393. data/vendor/assets/stylesheets/fontawesome/regular.scss +0 -23
  394. data/vendor/assets/stylesheets/fontawesome/solid.scss +0 -24
@@ -1,5 +1,5 @@
1
1
  .resources-header {
2
- padding: 2 * $default-padding;
2
+ padding: 0 2 * $default-padding;
3
3
  }
4
4
 
5
5
  .applied-filter {
@@ -25,18 +25,14 @@
25
25
  }
26
26
  }
27
27
 
28
- div#image_assign_filter_and_image_sizing {
29
- width: 100%;
30
- height: 40px;
31
- }
28
+ .selected_item_tools {
29
+ margin: -2 * $default-padding;
30
+ border-bottom: 1px solid $default-border-color;
31
+ margin-bottom: 4 * $default-padding;
32
+ padding: 4 * $default-padding;
32
33
 
33
- #picture_archive {
34
- .selected_item_tools {
35
- margin: -2 * $default-padding;
36
- border-bottom: 1px solid $default-border-color;
37
- margin-bottom: 4 * $default-padding;
38
- padding: 4 * $default-padding;
39
- display: none;
34
+ .button {
35
+ vertical-align: middle;
40
36
  }
41
37
  }
42
38
 
@@ -45,9 +41,7 @@ div#image_assign_filter_and_image_sizing {
45
41
  display: flex;
46
42
  align-items: center;
47
43
  justify-content: center;
48
- background-color: $thumbnail-background-color;
49
- width: 100%;
50
- height: 120px;
44
+ box-shadow: 0 0 1px 1px $default-border-color;
51
45
 
52
46
  &:hover {
53
47
  text-decoration: none;
@@ -55,55 +49,65 @@ div#image_assign_filter_and_image_sizing {
55
49
  }
56
50
 
57
51
  .picture_thumbnail {
58
- margin: 2 * $default-margin;
59
- background-color: #fff;
52
+ --picture-thumbnail-border-radius: var(--border-radius_medium);
53
+ display: flex;
54
+ align-items: center;
55
+ justify-content: center;
56
+ width: var(--picture-thumbnail-width);
57
+ height: var(--picture-thumbnail-height);
60
58
  position: relative;
61
- box-shadow: 0 0 0 1px $default-border-color;
62
- width: 160px;
59
+ border-radius: var(--picture-thumbnail-border-radius);
60
+ padding: 2 * $default-padding;
61
+ padding-bottom: 2.5em;
62
+ transition: all $transition-duration;
63
+
64
+ img,
65
+ .thumbnail_background {
66
+ border-radius: var(--picture-thumbnail-border-radius);
67
+ }
63
68
 
64
69
  img {
65
- width: 100%;
66
- height: 100%;
67
- object-fit: contain;
70
+ max-width: 100%;
71
+ max-height: 100%;
72
+
73
+ &:not([src*="alchemy/missing-image"]) {
74
+ background: $thumbnail-background;
75
+ }
68
76
 
69
- &[src$=".svg"] {
70
- width: auto;
71
- height: auto;
77
+ &[src$=".svg"]:not([src*="alchemy/missing-image"]) {
78
+ width: var(--picture-width);
79
+ max-height: var(--picture-height);
72
80
  }
73
81
  }
74
82
 
75
83
  .picture_name {
76
- display: block;
84
+ position: absolute;
77
85
  width: 100%;
78
86
  text-align: center;
79
87
  white-space: nowrap;
80
88
  overflow: hidden;
81
89
  bottom: 0;
82
90
  left: 0;
83
- line-height: 2;
91
+ line-height: 2.5;
84
92
  padding: 0 $default-padding;
85
93
  text-overflow: ellipsis;
86
94
  }
87
95
 
88
- &.small {
89
- width: 80px;
90
-
91
- .thumbnail_background {
92
- height: 60px;
96
+ &:hover,
97
+ &:focus-within {
98
+ .picture_tool,
99
+ .picture_tags {
100
+ visibility: visible;
101
+ opacity: 1;
93
102
  }
94
103
  }
95
104
 
96
- &.large {
97
- width: 240px;
105
+ &:hover,
106
+ &:focus-within,
107
+ &.active {
108
+ box-shadow: 0 0 4px 2px $default-border-color;
98
109
 
99
- .thumbnail_background {
100
- height: 180px;
101
- }
102
- }
103
-
104
- &:hover {
105
- .picture_tool,
106
- .picture_tags {
110
+ .picture_tool.select {
107
111
  visibility: visible;
108
112
  opacity: 1;
109
113
  }
@@ -112,8 +116,34 @@ div#image_assign_filter_and_image_sizing {
112
116
 
113
117
  #pictures,
114
118
  #overlay_picture_list {
115
- display: flex;
116
- flex-wrap: wrap;
119
+ --picture-width: 160px;
120
+ --picture-height: 120px;
121
+ --picture-thumbnail-width: calc(var(--picture-width) + var(--spacing-2));
122
+ --picture-thumbnail-height: calc(
123
+ var(--picture-height) + var(--spacing-2) + 2.5em
124
+ );
125
+
126
+ display: grid;
127
+ gap: 2 * $default-margin;
128
+ grid-template-columns: repeat(
129
+ auto-fill,
130
+ minmax(var(--picture-thumbnail-width), auto)
131
+ );
132
+ justify-items: center;
133
+
134
+ &.picture-size--small {
135
+ --picture-width: 80px;
136
+ --picture-height: 60px;
137
+ }
138
+
139
+ &.picture-size--large {
140
+ --picture-width: 240px;
141
+ --picture-height: 180px;
142
+ }
143
+ }
144
+
145
+ #picture_archive {
146
+ overflow: visible;
117
147
  }
118
148
 
119
149
  #pictures {
@@ -133,17 +163,23 @@ div.assign_image_list_image {
133
163
  }
134
164
 
135
165
  .picture_tool {
166
+ display: flex;
136
167
  width: 20px;
137
168
  height: 20px;
169
+ align-items: center;
170
+ justify-content: center;
138
171
  position: absolute;
139
172
  background-color: white;
140
173
  top: $default-padding;
141
174
  padding: $default-padding / 2;
142
175
  z-index: 10;
143
- text-align: center;
144
176
  border-radius: $default-border-radius;
145
177
  box-shadow: 0 0 1px $dark-gray;
146
178
 
179
+ &:hover {
180
+ text-decoration: none;
181
+ }
182
+
147
183
  &.visible {
148
184
  visibility: visible;
149
185
  opacity: 1;
@@ -169,22 +205,32 @@ div.assign_image_list_image {
169
205
  }
170
206
 
171
207
  a {
172
- display: block;
208
+ display: flex;
209
+ align-items: center;
210
+ justify-content: center;
173
211
  width: 16px;
174
212
  height: 16px;
175
213
  cursor: pointer;
214
+
215
+ &:hover {
216
+ text-decoration: none;
217
+ }
176
218
  }
177
219
  }
178
220
 
179
221
  .picture_tags {
180
222
  overflow: hidden;
181
223
  position: absolute;
182
- bottom: 22px;
224
+ bottom: 28px;
183
225
  left: 0;
184
226
  width: 100%;
185
227
  max-height: 80%;
186
228
  padding: $default-padding;
187
229
  pointer-events: none;
230
+
231
+ .tag {
232
+ box-shadow: 0 0 2px 2px $default-border-color;
233
+ }
188
234
  }
189
235
 
190
236
  .picture_tags,
@@ -237,11 +283,25 @@ div#filter_bar {
237
283
  #assign_image_list,
238
284
  #assign_file_list {
239
285
  position: relative;
240
- height: 548px;
286
+ height: 558px;
241
287
  }
242
288
 
243
289
  #assign_image_list {
244
- padding-right: 244px;
290
+ padding-right: 240px;
291
+ padding-bottom: 60px;
292
+ }
293
+
294
+ #overlay_picture_list {
295
+ height: 100%;
296
+ overflow: auto;
297
+
298
+ .picture_thumbnail:hover {
299
+ box-shadow: none;
300
+
301
+ .thumbnail_background {
302
+ box-shadow: 0 0 4px 4px $default-border-color;
303
+ }
304
+ }
245
305
  }
246
306
 
247
307
  #overlay_file_list {
@@ -268,8 +328,8 @@ div#filter_bar {
268
328
  }
269
329
 
270
330
  .icon {
271
- margin-top: -2px;
272
331
  margin-right: 4px;
332
+ vertical-align: bottom;
273
333
  }
274
334
  }
275
335
  }
@@ -2,18 +2,19 @@
2
2
  background-color: $medium-gray;
3
3
  margin-top: 12px;
4
4
 
5
- audio, video {
5
+ audio,
6
+ video {
6
7
  display: block;
7
8
  }
8
9
 
9
10
  &.image-preview {
10
11
  height: 300px;
11
12
  text-align: center;
12
- padding: 2*$default-padding;
13
+ padding: 2 * $default-padding;
13
14
  white-space: nowrap;
14
15
 
15
16
  &:before {
16
- content: '';
17
+ content: "";
17
18
  display: inline-block;
18
19
  height: 100%;
19
20
  vertical-align: middle;
@@ -34,6 +35,6 @@
34
35
  .full-iframe {
35
36
  width: 100%;
36
37
  background-color: white;
37
- min-height: 335px;
38
+ min-height: 435px;
38
39
  margin-top: 12px;
39
40
  }
@@ -26,16 +26,20 @@ input.button {
26
26
 
27
27
  &.small {
28
28
  padding: $small-button-padding;
29
- vertical-align: inherit;
30
29
  line-height: 4 * $default-padding;
31
30
  font-size: inherit;
32
31
  }
33
32
 
34
- &.with_icon .icon {
35
- position: relative;
36
- top: -1px;
37
- margin-right: 2 * $default-margin;
38
- color: inherit;
33
+ &.with_icon {
34
+ display: inline-flex;
35
+ align-items: center;
36
+ justify-content: center;
37
+
38
+ .icon {
39
+ font-weight: normal;
40
+ margin-right: $default-margin;
41
+ color: inherit;
42
+ }
39
43
  }
40
44
 
41
45
  &[disabled] {
@@ -44,64 +48,49 @@ input.button {
44
48
  }
45
49
 
46
50
  .icon_button {
47
- width: 27px;
48
- height: 27px;
49
- line-height: 21px;
51
+ position: relative;
52
+ display: inline-flex;
53
+ align-items: center;
54
+ justify-content: center;
55
+ width: $icon-button-width;
56
+ height: $icon-button-height;
50
57
  margin: 0;
51
- padding: 3px;
52
- overflow: hidden;
53
- text-align: center;
58
+ padding: 0;
54
59
  text-shadow: none;
55
60
  border-radius: $default-border-radius;
56
61
 
57
- img {
58
- position: absolute;
59
- top: 2px;
60
- left: 3px;
61
- }
62
-
63
62
  &.small {
64
- width: 15px;
65
- height: 15px;
66
- padding: 0;
67
- float: none;
68
- display: inline-block;
69
- vertical-align: middle;
70
- position: relative;
71
- top: 0px;
63
+ width: $icon-button-small-width;
64
+ height: $icon-button-small-height;
72
65
  background: none;
73
66
  border: none;
67
+ padding: 0; // button.small has padding
68
+ }
74
69
 
75
- .icon {
76
- position: absolute;
77
- top: 50%;
78
- transform: translateX(-50%) translateY(-50%);
79
- transition: color 250ms;
80
- }
81
-
82
- &:hover {
83
- border: $default-border-width $default-border-style $icon-color;
84
- color: $icon-color;
70
+ &.active,
71
+ &:active,
72
+ &:hover:not([disabled]):not(.disabled):not(.linked) {
73
+ text-decoration: none;
74
+ background-color: $default-border-color;
75
+ cursor: pointer;
76
+ }
85
77
 
86
- .icon {
87
- color: inherit;
88
- }
89
- }
78
+ .icon {
79
+ color: inherit;
80
+ transition: color 250ms;
90
81
  }
91
82
 
92
83
  &.disabled,
93
84
  &[disabled] {
94
- span {
95
- opacity: 0.3;
96
- cursor: not-allowed;
97
- }
85
+ pointer-events: none;
98
86
 
99
87
  i {
100
88
  opacity: 0.3;
101
89
  }
102
90
 
103
91
  &:hover {
104
- cursor: not-allowed;
92
+ text-decoration: none;
93
+ cursor: default;
105
94
  }
106
95
  }
107
96
 
@@ -109,15 +98,21 @@ input.button {
109
98
  @include linked-button;
110
99
  }
111
100
 
112
- &:focus {
101
+ &:focus:not(.disabled):not([disabled]) {
113
102
  @include default-focus-style;
114
103
  }
104
+
105
+ .spinner {
106
+ position: static;
107
+ transform: none;
108
+ }
115
109
  }
116
110
 
117
111
  button.icon_button {
118
112
  background: transparent;
119
113
  border: 0 none;
120
114
  box-shadow: none;
115
+ font-weight: normal;
121
116
 
122
117
  &:disabled,
123
118
  &.disabled {
@@ -128,123 +123,3 @@ button.icon_button {
128
123
  #new_element button.button {
129
124
  float: right;
130
125
  }
131
-
132
- .button_with_label {
133
- position: relative;
134
- display: inline-block;
135
- text-align: center;
136
-
137
- .toolbar_buttons & {
138
- margin: 0 2 * $default-margin;
139
- }
140
-
141
- &.active,
142
- &:active,
143
- &:hover {
144
- .icon_button:not([disabled]) {
145
- background-color: $default-border-color;
146
- cursor: pointer;
147
- }
148
- }
149
-
150
- .select2-container,
151
- select {
152
- margin: 0;
153
- top: 0;
154
- }
155
-
156
- .icon_button {
157
- float: none;
158
- margin-right: auto;
159
- margin-left: auto;
160
- display: inline-block;
161
- vertical-align: middle;
162
- position: relative;
163
- }
164
-
165
- &.disabled {
166
- opacity: 0.5;
167
- cursor: default;
168
- }
169
- }
170
-
171
- .button_with_label,
172
- .button_group {
173
- .icon_button {
174
- width: 29px;
175
- height: 29px;
176
- line-height: 24px;
177
- }
178
-
179
- label {
180
- border-radius: $default-border-radius;
181
- position: absolute;
182
- visibility: hidden;
183
- top: -20px;
184
- left: 50%;
185
- margin-left: -13px;
186
- z-index: 30;
187
- background-color: $tooltip-background-color;
188
- color: $white;
189
- padding: $default-padding 2 * $default-padding 1.5 * $default-padding;
190
- line-height: 1;
191
- box-shadow: 0 0 4px $default-border-color;
192
- white-space: nowrap;
193
- pointer-events: none;
194
- opacity: 0;
195
- transition: 0.3s;
196
-
197
- &:before {
198
- content: "";
199
- position: absolute;
200
- bottom: -10px;
201
- left: 8px;
202
- border: 5px transparent solid;
203
- border-top-color: $tooltip-background-color;
204
- }
205
-
206
- &.center {
207
- left: auto;
208
- right: 50%;
209
- margin-left: 0;
210
- transform: translateX(50%);
211
-
212
- &:before {
213
- left: auto;
214
- right: 50%;
215
- transform: translateX(50%);
216
- }
217
- }
218
-
219
- &.left {
220
- left: auto;
221
- right: 50%;
222
- margin-left: 0;
223
- margin-right: -13px;
224
-
225
- &:before {
226
- left: auto;
227
- right: 8px;
228
- }
229
- }
230
-
231
- &.right-aligned {
232
- left: auto;
233
- margin-left: auto;
234
- right: 50%;
235
- margin-right: -13px;
236
-
237
- &:before {
238
- left: auto;
239
- right: 8px;
240
- }
241
- }
242
- }
243
-
244
- &:hover label {
245
- visibility: visible;
246
- opacity: 1;
247
- top: -25px;
248
- transition-delay: 0.2s;
249
- }
250
- }
@@ -1,6 +1,6 @@
1
1
  #dashboard {
2
2
  overflow: auto;
3
- padding: 4*$default-padding 0;
3
+ padding: 4 * $default-padding 0;
4
4
  width: 100%;
5
5
  position: relative;
6
6
 
@@ -35,8 +35,13 @@
35
35
  td {
36
36
  position: relative;
37
37
 
38
- &:first-child { width: 40% }
39
- form { float: right }
38
+ &:first-child {
39
+ width: 40%;
40
+ }
41
+
42
+ form {
43
+ float: right;
44
+ }
40
45
  }
41
46
  }
42
47
  }
@@ -53,10 +58,30 @@
53
58
  display: none;
54
59
  }
55
60
 
56
- & > span { display: none }
61
+ > span {
62
+ display: inline-flex;
63
+ gap: $default-padding;
64
+ align-items: center;
65
+
66
+ &.hidden {
67
+ display: none;
68
+ }
69
+
70
+ .icon {
71
+ color: inherit;
72
+ }
73
+ }
74
+
75
+ #up_to_date {
76
+ color: $success_text_color;
77
+ }
78
+
79
+ #error {
80
+ color: $error_text_color;
81
+ }
57
82
 
58
- span.icon {
59
- vertical-align: top;
83
+ #update_available {
84
+ color: $warning_text_color;
60
85
  }
61
86
  }
62
87