alchemy_cms 7.0.0.pre.a → 7.0.0.pre.c

Sign up to get free protection for your applications and to get access to all the features.
Files changed (237) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/brakeman-analysis.yml +2 -2
  3. data/.github/workflows/lint.yml +37 -0
  4. data/.github/workflows/{ci.yml → test.yml} +8 -8
  5. data/.gitignore +0 -5
  6. data/.hound.yml +2 -3
  7. data/.rubocop.yml +4 -350
  8. data/.standard.yml +3 -0
  9. data/CHANGELOG.md +33 -0
  10. data/Gemfile +3 -2
  11. data/README.md +10 -12
  12. data/Rakefile +0 -19
  13. data/alchemy_cms.gemspec +4 -2
  14. data/app/assets/config/alchemy_manifest.js +1 -0
  15. data/app/assets/javascripts/alchemy/admin.js +0 -2
  16. data/app/assets/javascripts/alchemy/alchemy.dirty.js.coffee +1 -1
  17. data/app/assets/javascripts/alchemy/alchemy.initializer.js.coffee +5 -12
  18. data/app/assets/javascripts/alchemy/alchemy.link_dialog.js.coffee +6 -1
  19. data/app/assets/stylesheets/alchemy/base.scss +2 -2
  20. data/app/components/alchemy/ingredients/audio_view.rb +37 -0
  21. data/app/components/alchemy/ingredients/base_view.rb +38 -0
  22. data/app/components/alchemy/ingredients/boolean_view.rb +13 -0
  23. data/app/components/alchemy/ingredients/datetime_view.rb +22 -0
  24. data/app/components/alchemy/ingredients/file_view.rb +40 -0
  25. data/app/components/alchemy/ingredients/headline_view.rb +20 -0
  26. data/app/components/alchemy/ingredients/html_view.rb +9 -0
  27. data/app/components/alchemy/ingredients/link_view.rb +25 -0
  28. data/app/components/alchemy/ingredients/node_view.rb +11 -0
  29. data/app/components/alchemy/ingredients/page_view.rb +15 -0
  30. data/app/components/alchemy/ingredients/picture_view.rb +108 -0
  31. data/app/components/alchemy/ingredients/richtext_view.rb +22 -0
  32. data/app/components/alchemy/ingredients/select_view.rb +6 -0
  33. data/app/components/alchemy/ingredients/text_view.rb +41 -0
  34. data/app/components/alchemy/ingredients/video_view.rb +39 -0
  35. data/app/controllers/alchemy/admin/attachments_controller.rb +3 -3
  36. data/app/controllers/alchemy/admin/base_controller.rb +7 -7
  37. data/app/controllers/alchemy/admin/clipboard_controller.rb +2 -2
  38. data/app/controllers/alchemy/admin/elements_controller.rb +26 -11
  39. data/app/controllers/alchemy/admin/languages_controller.rb +1 -1
  40. data/app/controllers/alchemy/admin/nodes_controller.rb +2 -2
  41. data/app/controllers/alchemy/admin/pages_controller.rb +10 -10
  42. data/app/controllers/alchemy/admin/pictures_controller.rb +14 -14
  43. data/app/controllers/alchemy/admin/resources_controller.rb +27 -28
  44. data/app/controllers/alchemy/admin/styleguide_controller.rb +1 -0
  45. data/app/controllers/alchemy/admin/tags_controller.rb +11 -11
  46. data/app/controllers/alchemy/api/base_controller.rb +2 -2
  47. data/app/controllers/alchemy/api/elements_controller.rb +11 -11
  48. data/app/controllers/alchemy/api/ingredients_controller.rb +1 -1
  49. data/app/controllers/alchemy/api/nodes_controller.rb +1 -1
  50. data/app/controllers/alchemy/api/pages_controller.rb +11 -11
  51. data/app/controllers/alchemy/attachments_controller.rb +3 -3
  52. data/app/controllers/alchemy/base_controller.rb +1 -8
  53. data/app/controllers/alchemy/messages_controller.rb +9 -9
  54. data/app/controllers/alchemy/pages_controller.rb +8 -19
  55. data/app/controllers/concerns/alchemy/admin/archive_overlay.rb +1 -0
  56. data/app/controllers/concerns/alchemy/admin/uploader_responses.rb +5 -7
  57. data/app/controllers/concerns/alchemy/legacy_page_redirects.rb +5 -5
  58. data/app/decorators/alchemy/element_editor.rb +4 -4
  59. data/app/decorators/alchemy/ingredient_editor.rb +6 -6
  60. data/app/helpers/alchemy/admin/attachments_helper.rb +1 -1
  61. data/app/helpers/alchemy/admin/base_helper.rb +21 -22
  62. data/app/helpers/alchemy/admin/elements_helper.rb +1 -1
  63. data/app/helpers/alchemy/admin/form_helper.rb +1 -1
  64. data/app/helpers/alchemy/admin/navigation_helper.rb +7 -7
  65. data/app/helpers/alchemy/admin/pages_helper.rb +2 -2
  66. data/app/helpers/alchemy/admin/tags_helper.rb +3 -3
  67. data/app/helpers/alchemy/base_helper.rb +2 -2
  68. data/app/helpers/alchemy/elements_block_helper.rb +9 -7
  69. data/app/helpers/alchemy/elements_helper.rb +12 -12
  70. data/app/helpers/alchemy/pages_helper.rb +11 -11
  71. data/app/helpers/alchemy/url_helper.rb +1 -1
  72. data/{package/src → app/javascript/alchemy_admin}/datepicker.js +1 -0
  73. data/{package/src → app/javascript/alchemy_admin}/node_tree.js +2 -2
  74. data/{package/src → app/javascript/alchemy_admin}/page_publication_fields.js +1 -1
  75. data/{package/src → app/javascript/alchemy_admin}/page_sorter.js +1 -1
  76. data/{package/src → app/javascript/alchemy_admin}/picture_editors.js +2 -2
  77. data/{package/src → app/javascript/alchemy_admin}/sitemap.js +4 -4
  78. data/app/javascript/alchemy_admin/tinymce.js +142 -0
  79. data/app/javascript/alchemy_admin.js +34 -0
  80. data/app/mailers/alchemy/messages_mailer.rb +1 -1
  81. data/app/models/alchemy/attachment.rb +6 -6
  82. data/app/models/alchemy/base_record.rb +1 -0
  83. data/app/models/alchemy/eager_loading.rb +6 -6
  84. data/app/models/alchemy/element/definitions.rb +1 -1
  85. data/app/models/alchemy/element/element_ingredients.rb +3 -3
  86. data/app/models/alchemy/element.rb +2 -2
  87. data/app/models/alchemy/elements_repository.rb +1 -1
  88. data/app/models/alchemy/image_cropper_settings.rb +2 -2
  89. data/app/models/alchemy/ingredient.rb +14 -12
  90. data/app/models/alchemy/ingredient_validator.rb +1 -1
  91. data/app/models/alchemy/ingredients/datetime.rb +1 -1
  92. data/app/models/alchemy/ingredients/file.rb +5 -5
  93. data/app/models/alchemy/ingredients/headline.rb +4 -4
  94. data/app/models/alchemy/ingredients/picture.rb +27 -9
  95. data/app/models/alchemy/ingredients/richtext.rb +15 -12
  96. data/app/models/alchemy/ingredients/text.rb +6 -6
  97. data/app/models/alchemy/language/code.rb +1 -1
  98. data/app/models/alchemy/language.rb +4 -4
  99. data/app/models/alchemy/legacy_page_url.rb +1 -1
  100. data/app/models/alchemy/node.rb +2 -2
  101. data/app/models/alchemy/page/page_elements.rb +14 -14
  102. data/app/models/alchemy/page/page_naming.rb +4 -4
  103. data/app/models/alchemy/page/page_natures.rb +1 -1
  104. data/app/models/alchemy/page/page_scopes.rb +5 -5
  105. data/app/models/alchemy/page.rb +11 -11
  106. data/app/models/alchemy/picture/calculations.rb +2 -2
  107. data/app/models/alchemy/picture/transformations.rb +2 -2
  108. data/app/models/alchemy/picture/url.rb +4 -4
  109. data/app/models/alchemy/picture.rb +11 -10
  110. data/app/models/alchemy/picture_thumb/create.rb +1 -1
  111. data/app/models/alchemy/picture_thumb.rb +1 -1
  112. data/app/models/alchemy/picture_variant.rb +2 -3
  113. data/app/models/alchemy/tag.rb +8 -0
  114. data/app/models/concerns/alchemy/picture_thumbnails.rb +6 -6
  115. data/app/serializers/alchemy/base_serializer.rb +1 -1
  116. data/app/serializers/alchemy/page_tree_serializer.rb +7 -7
  117. data/app/services/alchemy/duplicate_element.rb +3 -3
  118. data/app/services/alchemy/tag_validations.rb +1 -1
  119. data/app/views/alchemy/_menubar.html.erb +1 -1
  120. data/app/views/alchemy/admin/attachments/_replace_button.html.erb +1 -1
  121. data/app/views/alchemy/admin/attachments/destroy.js.erb +1 -1
  122. data/app/views/alchemy/admin/elements/_element.html.erb +3 -0
  123. data/app/views/alchemy/admin/nodes/index.html.erb +4 -2
  124. data/app/views/alchemy/admin/pages/_page_layout_filter.html.erb +1 -1
  125. data/app/views/alchemy/admin/pages/edit.html.erb +3 -7
  126. data/app/views/alchemy/admin/pages/index.html.erb +1 -1
  127. data/app/views/alchemy/admin/pages/update.js.erb +12 -6
  128. data/app/views/alchemy/admin/pictures/_infos.html.erb +1 -1
  129. data/app/views/alchemy/admin/resources/_filter_bar.html.erb +1 -1
  130. data/app/views/alchemy/admin/styleguide/index.html.erb +1 -1
  131. data/app/views/alchemy/admin/uploader/_button.html.erb +1 -1
  132. data/app/views/alchemy/base/permission_denied.js.erb +1 -1
  133. data/app/views/alchemy/base/redirect.js.erb +1 -1
  134. data/app/views/alchemy/ingredients/_audio_view.html.erb +1 -14
  135. data/app/views/alchemy/ingredients/_boolean_view.html.erb +1 -1
  136. data/app/views/alchemy/ingredients/_datetime_view.html.erb +3 -9
  137. data/app/views/alchemy/ingredients/_file_view.html.erb +3 -16
  138. data/app/views/alchemy/ingredients/_headline_view.html.erb +4 -10
  139. data/app/views/alchemy/ingredients/_html_view.html.erb +1 -1
  140. data/app/views/alchemy/ingredients/_link_view.html.erb +4 -9
  141. data/app/views/alchemy/ingredients/_node_view.html.erb +1 -1
  142. data/app/views/alchemy/ingredients/_page_view.html.erb +1 -4
  143. data/app/views/alchemy/ingredients/_picture_view.html.erb +4 -5
  144. data/app/views/alchemy/ingredients/_richtext_editor.html.erb +11 -2
  145. data/app/views/alchemy/ingredients/_richtext_view.html.erb +3 -3
  146. data/app/views/alchemy/ingredients/_select_view.html.erb +1 -1
  147. data/app/views/alchemy/ingredients/_text_view.html.erb +3 -19
  148. data/app/views/alchemy/ingredients/_video_view.html.erb +3 -18
  149. data/app/views/alchemy/ingredients/shared/_link_tools.html.erb +1 -0
  150. data/app/views/alchemy/ingredients/shared/_picture_tools.html.erb +1 -0
  151. data/app/views/layouts/alchemy/admin.html.erb +9 -15
  152. data/bin/importmap +4 -0
  153. data/bin/setup +28 -0
  154. data/bin/start +17 -0
  155. data/config/brakeman.ignore +0 -46
  156. data/config/importmap.rb +8 -0
  157. data/config/initializers/assets.rb +1 -0
  158. data/config/initializers/dragonfly.rb +1 -0
  159. data/config/initializers/mime_types.rb +1 -0
  160. data/config/initializers/mini_profiler.rb +1 -0
  161. data/config/initializers/simple_form.rb +3 -2
  162. data/config/locales/alchemy.en.yml +1 -1
  163. data/config/routes.rb +21 -20
  164. data/config/spring.rb +1 -0
  165. data/db/migrate/20230121212637_alchemy_six_point_one.rb +8 -8
  166. data/db/migrate/20230505132743_add_indexes_to_alchemy_pictures.rb +6 -0
  167. data/lib/alchemy/admin/locale.rb +3 -3
  168. data/lib/alchemy/admin/preview_url.rb +2 -2
  169. data/lib/alchemy/auth_accessors.rb +1 -1
  170. data/lib/alchemy/config.rb +1 -1
  171. data/lib/alchemy/controller_actions.rb +4 -4
  172. data/lib/alchemy/deprecation.rb +1 -0
  173. data/lib/alchemy/dragonfly/processors/thumbnail.rb +1 -1
  174. data/lib/alchemy/element_definition.rb +2 -2
  175. data/lib/alchemy/engine.rb +16 -1
  176. data/lib/alchemy/filetypes.rb +7 -7
  177. data/lib/alchemy/forms/builder.rb +4 -4
  178. data/lib/alchemy/i18n.rb +6 -4
  179. data/lib/alchemy/install/tasks.rb +2 -1
  180. data/lib/alchemy/name_conversions.rb +1 -1
  181. data/lib/alchemy/page_layout.rb +1 -1
  182. data/lib/alchemy/permissions.rb +5 -4
  183. data/lib/alchemy/resource.rb +10 -10
  184. data/lib/alchemy/resources_helper.rb +7 -7
  185. data/lib/alchemy/routing_constraints.rb +2 -2
  186. data/lib/alchemy/seeder.rb +12 -5
  187. data/lib/alchemy/shell.rb +2 -1
  188. data/lib/alchemy/taggable.rb +3 -2
  189. data/lib/alchemy/tasks/tidy.rb +1 -0
  190. data/lib/alchemy/test_support/capybara_helpers.rb +1 -1
  191. data/lib/alchemy/test_support/config_stubbing.rb +1 -0
  192. data/lib/alchemy/test_support/factories/element_factory.rb +4 -0
  193. data/lib/alchemy/test_support/factories/page_factory.rb +2 -2
  194. data/lib/alchemy/test_support/having_crop_action_examples.rb +9 -9
  195. data/lib/alchemy/test_support/having_picture_thumbnails_examples.rb +33 -33
  196. data/lib/alchemy/test_support/integration_helpers.rb +4 -3
  197. data/lib/alchemy/test_support/shared_contexts.rb +2 -1
  198. data/lib/alchemy/test_support/shared_dom_ids_examples.rb +9 -9
  199. data/lib/alchemy/test_support/shared_ingredient_examples.rb +12 -6
  200. data/lib/alchemy/test_support/shared_uploader_examples.rb +1 -0
  201. data/lib/alchemy/tinymce.rb +3 -26
  202. data/lib/alchemy/upgrader/seven_point_zero.rb +13 -23
  203. data/lib/alchemy/upgrader.rb +1 -11
  204. data/lib/alchemy/version.rb +1 -1
  205. data/lib/alchemy.rb +5 -0
  206. data/lib/alchemy_cms.rb +3 -1
  207. data/lib/generators/alchemy/base.rb +3 -2
  208. data/lib/generators/alchemy/elements/elements_generator.rb +2 -1
  209. data/lib/generators/alchemy/ingredient/ingredient_generator.rb +1 -0
  210. data/lib/generators/alchemy/install/files/application.html.erb +2 -2
  211. data/lib/generators/alchemy/install/install_generator.rb +2 -25
  212. data/lib/generators/alchemy/module/module_generator.rb +1 -0
  213. data/lib/generators/alchemy/page_layouts/page_layouts_generator.rb +1 -0
  214. data/lib/generators/alchemy/site_layouts/site_layouts_generator.rb +1 -0
  215. data/lib/generators/alchemy/views/views_generator.rb +2 -1
  216. data/lib/tasks/alchemy/thumbnails.rake +5 -5
  217. data/lib/tasks/alchemy/tidy.rake +1 -0
  218. data/lib/tasks/alchemy/upgrade.rake +10 -15
  219. data/package.json +6 -26
  220. metadata +80 -31
  221. data/app/assets/javascripts/alchemy/alchemy.tinymce.js.coffee +0 -93
  222. data/app/presenters/alchemy/picture_view.rb +0 -88
  223. data/app/views/alchemy/admin/pages/_tinymce_custom_config.html.erb +0 -10
  224. data/package/admin.js +0 -32
  225. data/package/dist/admin.js +0 -16
  226. data/package/dist/admin.js.map +0 -7
  227. data/package/src/__tests__/i18n.spec.js +0 -93
  228. data/package/src/utils/__tests__/ajax.spec.js +0 -168
  229. data/package/src/utils/__tests__/events.spec.js +0 -38
  230. /data/{package/src → app/javascript/alchemy_admin}/file_editors.js +0 -0
  231. /data/{package/src → app/javascript/alchemy_admin}/i18n.js +0 -0
  232. /data/{package/src → app/javascript/alchemy_admin}/image_cropper.js +0 -0
  233. /data/{package/src → app/javascript/alchemy_admin}/image_loader.js +0 -0
  234. /data/{package/src → app/javascript/alchemy_admin}/ingredient_anchor_link.js +0 -0
  235. /data/{package/src → app/javascript/alchemy_admin}/translations.js +0 -0
  236. /data/{package/src → app/javascript/alchemy_admin}/utils/ajax.js +0 -0
  237. /data/{package/src → app/javascript/alchemy_admin}/utils/events.js +0 -0
@@ -4,7 +4,7 @@ module Alchemy
4
4
  module Tinymce
5
5
  mattr_accessor :languages, :plugins
6
6
 
7
- @@plugins = %w(alchemy_link anchor autoresize charmap code directionality fullscreen hr link lists paste tabfocus table)
7
+ @@plugins = %w[alchemy_link anchor autoresize charmap code directionality fullscreen hr link lists paste tabfocus table]
8
8
  @@init = {
9
9
  skin: "alchemy",
10
10
  width: "auto",
@@ -15,14 +15,14 @@ module Alchemy
15
15
  statusbar: true,
16
16
  toolbar: [
17
17
  "bold italic underline | strikethrough subscript superscript | numlist bullist indent outdent | removeformat | fullscreen",
18
- "pastetext charmap hr | undo redo | alchemy_link unlink anchor | code",
18
+ "pastetext charmap hr | undo redo | alchemy_link unlink anchor | code"
19
19
  ],
20
20
  fix_list_elements: true,
21
21
  convert_urls: false,
22
22
  entity_encoding: "raw",
23
23
  paste_as_text: true,
24
24
  element_format: "html",
25
- branding: false,
25
+ branding: false
26
26
  }
27
27
 
28
28
  class << self
@@ -33,29 +33,6 @@ module Alchemy
33
33
  def init
34
34
  @@init
35
35
  end
36
-
37
- def custom_configs_present?(page)
38
- custom_config_ingredients(page).any?
39
- end
40
-
41
- def custom_config_ingredients(page)
42
- ingredient_definitions_from_elements(page.descendent_element_definitions)
43
- end
44
-
45
- private
46
-
47
- def ingredient_definitions_from_elements(definitions)
48
- definitions.collect do |el|
49
- next if el["ingredients"].blank?
50
-
51
- ingredients = el["ingredients"].select do |c|
52
- c["settings"] && c["settings"]["tinymce"].is_a?(Hash)
53
- end
54
- next if ingredients.blank?
55
-
56
- ingredients.map { |c| c.merge("element" => el["name"]) }
57
- end.flatten.compact
58
- end
59
36
  end
60
37
  end
61
38
  end
@@ -8,30 +8,20 @@ module Alchemy
8
8
  include Thor::Actions
9
9
 
10
10
  class << self
11
- def update_admin_entrypoint
12
- if File.exist? "app/javascript/packs/alchemy/admin.js"
13
- FileUtils.mv "app/javascript/packs/alchemy/admin.js", "app/javascript/alchemy_admin.js"
14
- else
15
- log "Skipping. No alchemy/admin entrypoint found. Maybe already migrated from Webpacker?", :info
16
- end
17
- if Dir.exist?("app/javascript/packs/alchemy") && Dir.empty?("app/javascript/packs/alchemy")
18
- FileUtils.rm_r "app/javascript/packs/alchemy"
19
- end
20
- if File.exist? "config/importmap.rb"
21
- # We want the bundled package if using importmaps
22
- task.gsub_file "app/javascript/alchemy_admin.js", 'import "@alchemy_cms/admin"', 'import "@alchemy_cms/dist/admin"'
23
- end
24
- if task.ask("Do you want to remove webpacker now? (y/N)", default: "N") == "y"
11
+ def remove_admin_entrypoint
12
+ FileUtils.rm_rf "app/javascript/packs/alchemy/admin.js"
13
+ FileUtils.rm_rf "app/javascript/packs/alchemy_admin.js"
14
+ FileUtils.rm_rf "app/javascript/packs/alchemy"
15
+ FileUtils.rm_rf "app/javascript/packs/alchemy"
16
+ task.run "yarn remove @alchemy_cms/admin"
17
+ if task.ask("Do you want to remove webpacker as well? (y/N)", default: "N") == "y"
18
+ task.run "bundle remove webpacker"
25
19
  task.run "yarn remove @rails/webpacker webpack webpack-cli webpack-dev-server"
26
- FileUtils.rm_r "app/javascript/packs"
27
- FileUtils.rm_r "config/webpack"
28
- FileUtils.rm "config/webpacker.yml"
29
- FileUtils.rm "bin/webpack"
30
- FileUtils.rm "bin/webpack-dev-server"
31
- end
32
- if task.ask("Do you want to add jsbundling-rails now? (Y/n)", default: "Y") == "Y"
33
- task.run "bundle add jsbundling-rails"
34
- task.run "bin/rails javascript:install:esbuild"
20
+ FileUtils.rm_rf "app/javascript/packs"
21
+ FileUtils.rm_rf "config/webpack"
22
+ FileUtils.rm_f "config/webpacker.yml"
23
+ FileUtils.rm_f "bin/webpack"
24
+ FileUtils.rm_f "bin/webpack-dev-server"
35
25
  end
36
26
  end
37
27
 
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "alchemy/shell"
3
4
 
4
5
  module Alchemy
@@ -24,17 +25,6 @@ module Alchemy
24
25
  todo "Check the default configuration file (./config/alchemy/config.yml.defaults) for new configuration options and insert them into your config file.", "Configuration has changed"
25
26
  end
26
27
  end
27
-
28
- def update_npm_package
29
- desc "Update npm package."
30
- if File.exist? Rails.root.join("config/importmap.rb")
31
- `bin/importmap pin @alchemy_cms/admin@~#{Alchemy.version}`
32
- elsif File.exist? Rails.root.join("package.json")
33
- `yarn add @alchemy_cms/admin@~#{Alchemy.version}`
34
- else
35
- log("Could not update alchemy admin package! Make sure you have a JS bundler installed", :warning)
36
- end
37
- end
38
28
  end
39
29
  end
40
30
  end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Alchemy
4
- VERSION = "7.0.0-a"
4
+ VERSION = "7.0.0-c"
5
5
 
6
6
  def self.version
7
7
  VERSION
data/lib/alchemy.rb CHANGED
@@ -1,6 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require "alchemy/admin/preview_url"
4
+ require "importmap-rails"
4
5
 
5
6
  module Alchemy
6
7
  YAML_PERMITTED_CLASSES = %w[Symbol Date Regexp]
@@ -78,4 +79,8 @@ module Alchemy
78
79
  # Alchemy.enable_searchable = true
79
80
  #
80
81
  mattr_accessor :enable_searchable, default: false
82
+
83
+ # JS Importmap instance
84
+ singleton_class.attr_accessor :importmap
85
+ self.importmap = Importmap::Map.new
81
86
  end
data/lib/alchemy_cms.rb CHANGED
@@ -12,6 +12,7 @@ require "cancan"
12
12
  require "dragonfly"
13
13
  require "gutentag"
14
14
  require "handlebars_assets"
15
+ require "importmap-rails"
15
16
  require "jquery-rails"
16
17
  require "jquery-ui-rails"
17
18
  require "kaminari"
@@ -21,8 +22,9 @@ require "request_store"
21
22
  require "responders"
22
23
  require "sassc-rails"
23
24
  require "simple_form"
24
- require "turbolinks"
25
+ require "turbo-rails"
25
26
  require "userstamp"
27
+ require "view_component"
26
28
 
27
29
  # Require globally used Alchemy mixins
28
30
  require_relative "alchemy/ability_helper"
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "rails"
3
4
 
4
5
  module Alchemy
@@ -11,7 +12,7 @@ module Alchemy
11
12
  def conditional_template(source, destination)
12
13
  files = Dir.glob(destination.gsub(/\.([a-z]+)$/, "*"))
13
14
  if files.any?
14
- ext = File.extname(files.first)[1..-1]
15
+ ext = File.extname(files.first)[1..]
15
16
 
16
17
  # If view already exists using a different template engine, change
17
18
  # source and destination file names to use that engine.
@@ -36,7 +37,7 @@ module Alchemy
36
37
  YAML.safe_load(
37
38
  ERB.new(File.read(Rails.root.join("config", "alchemy", name))).result,
38
39
  permitted_classes: YAML_PERMITTED_CLASSES,
39
- aliases: true,
40
+ aliases: true
40
41
  )
41
42
  rescue Errno::ENOENT
42
43
  puts "\nERROR: Could not read config/alchemy/#{name} file. Please run: `rails generate alchemy:install`"
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require_relative "../base"
3
4
 
4
5
  module Alchemy
@@ -26,7 +27,7 @@ module Alchemy
26
27
  end
27
28
 
28
29
  def element_name(element)
29
- if element["name"] =~ Alchemy::Element::NAME_REGEXP
30
+ if Alchemy::Element::NAME_REGEXP.match?(element["name"])
30
31
  element["name"].underscore
31
32
  else
32
33
  raise "Element name '#{element["name"]}' has wrong format. Only lowercase and non whitespace characters allowed."
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "rails"
3
4
 
4
5
  module Alchemy
@@ -5,8 +5,8 @@
5
5
  <%= csrf_meta_tags %>
6
6
  <%= csp_meta_tag %>
7
7
 
8
- <%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track': 'reload' %>
9
- <%= javascript_link_tag 'application', 'data-turbolinks-track': 'reload' %>
8
+ <%= stylesheet_link_tag 'application', media: 'all', 'data-turbo-track': 'reload' %>
9
+ <%= javascript_include_tag 'application', 'data-turbo-track': 'reload' %>
10
10
  </head>
11
11
 
12
12
  <body>
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "rails/generators"
3
4
  require "alchemy/install/tasks"
4
5
  require "alchemy/version"
@@ -57,7 +58,7 @@ module Alchemy
57
58
  end
58
59
 
59
60
  def copy_yml_files
60
- %w(elements page_layouts menus).each do |file|
61
+ %w[elements page_layouts menus].each do |file|
61
62
  template "#{__dir__}/templates/#{file}.yml.tt", app_config_path.join("alchemy", "#{file}.yml")
62
63
  end
63
64
  end
@@ -98,30 +99,6 @@ module Alchemy
98
99
  rake "gutentag:install:migrations"
99
100
  end
100
101
 
101
- def add_npm_package
102
- if File.exist? app_root.join("package.json")
103
- run "yarn add @alchemy_cms/admin@~#{Alchemy.version}"
104
- elsif File.exist? app_root.join("config/importmap.rb")
105
- run "bin/importmap pin @alchemy_cms/admin@~#{Alchemy.version}"
106
- else
107
- log("Could not add alchemy admin package! Make sure you have a JS bundler installed", :warning)
108
- end
109
- end
110
-
111
- def copy_alchemy_entry_point
112
- if Dir.exist? app_root.join("app/javascript")
113
- if File.exist? app_root.join("config/importmap.rb")
114
- # We want the bundled package if using importmaps
115
- create_file app_root.join("app/javascript/alchemy_admin.js"), 'import "@alchemy_cms/dist/admin"'
116
- else
117
- # We want the normal package if using a bundler locally
118
- create_file app_root.join("app/javascript/alchemy_admin.js"), 'import "@alchemy_cms/admin"'
119
- end
120
- else
121
- log("Could not add alchemy admin entry point! Make sure you have a JS bundler installed", :warning)
122
- end
123
- end
124
-
125
102
  def set_primary_language
126
103
  header
127
104
  install_tasks.set_primary_language(
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "rails"
3
4
 
4
5
  module Alchemy
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require_relative "../base"
3
4
 
4
5
  module Alchemy
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require_relative "../base"
3
4
 
4
5
  module Alchemy
@@ -1,10 +1,11 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "rails"
3
4
 
4
5
  module Alchemy
5
6
  module Generators
6
7
  class ViewsGenerator < ::Rails::Generators::Base
7
- ALCHEMY_VIEWS = %w(breadcrumb language_links messages_mailer)
8
+ ALCHEMY_VIEWS = %w[breadcrumb language_links messages_mailer]
8
9
 
9
10
  desc "Generates Alchemy views for #{ALCHEMY_VIEWS.to_sentence}."
10
11
 
@@ -5,7 +5,7 @@ namespace :alchemy do
5
5
  desc "Generates all thumbnails for Alchemy Pictures and Picture Ingredients."
6
6
  task thumbnails: [
7
7
  "alchemy:generate:picture_thumbnails",
8
- "alchemy:generate:ingredient_picture_thumbnails",
8
+ "alchemy:generate:ingredient_picture_thumbnails"
9
9
  ]
10
10
 
11
11
  desc "Generates thumbnails for Alchemy Pictures."
@@ -24,10 +24,10 @@ namespace :alchemy do
24
24
 
25
25
  desc "Generates thumbnails for Alchemy Picture Ingredients (set ELEMENTS=element1,element2 to only generate thumbnails for a subset of elements)."
26
26
  task ingredient_picture_thumbnails: :environment do
27
- ingredient_pictures = Alchemy::Ingredients::Picture.
28
- joins(:element).
29
- preload({ related_object: :thumbs }).
30
- merge(Alchemy::Element.published)
27
+ ingredient_pictures = Alchemy::Ingredients::Picture
28
+ .joins(:element)
29
+ .preload({related_object: :thumbs})
30
+ .merge(Alchemy::Element.published)
31
31
 
32
32
  if ENV["ELEMENTS"].present?
33
33
  ingredient_pictures = ingredient_pictures.merge(
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "alchemy/tasks/tidy"
3
4
 
4
5
  namespace :alchemy do
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "alchemy/upgrader"
3
4
  require "alchemy/version"
4
5
 
@@ -6,7 +7,7 @@ namespace :alchemy do
6
7
  desc "Upgrades your app to AlchemyCMS v#{Alchemy::VERSION}."
7
8
  task upgrade: [
8
9
  "alchemy:upgrade:prepare",
9
- "alchemy:upgrade:7.0:run",
10
+ "alchemy:upgrade:7.0:run"
10
11
  ] do
11
12
  Alchemy::Upgrader.display_todos
12
13
  end
@@ -15,14 +16,13 @@ namespace :alchemy do
15
16
  desc "Alchemy Upgrader: Prepares the database and updates Alchemys configuration file."
16
17
  task prepare: [
17
18
  "alchemy:upgrade:database",
18
- "alchemy:upgrade:config",
19
- "alchemy:upgrade:package",
19
+ "alchemy:upgrade:config"
20
20
  ]
21
21
 
22
22
  desc "Alchemy Upgrader: Prepares the database."
23
23
  task database: [
24
24
  "alchemy:install:migrations",
25
- "db:migrate",
25
+ "db:migrate"
26
26
  ]
27
27
 
28
28
  desc "Alchemy Upgrader: Copy configuration file."
@@ -30,28 +30,23 @@ namespace :alchemy do
30
30
  Alchemy::Upgrader.copy_new_config_file
31
31
  end
32
32
 
33
- desc "Alchemy Upgrader: Install new Node package."
34
- task package: [:environment] do
35
- Alchemy::Upgrader.update_npm_package
36
- end
37
-
38
33
  desc "Upgrade Alchemy to v7.0"
39
34
  task "7.0" => [
40
35
  "alchemy:upgrade:prepare",
41
- "alchemy:upgrade:7.0:run",
36
+ "alchemy:upgrade:7.0:run"
42
37
  ] do
43
38
  Alchemy::Upgrader.display_todos
44
39
  end
45
40
 
46
41
  namespace "7.0" do
47
42
  task "run" => [
48
- "alchemy:upgrade:7.0:update_admin_entrypoint",
43
+ "alchemy:upgrade:7.0:remove_admin_entrypoint"
49
44
  ]
50
45
 
51
- desc "Update alchemy admin entrypoint"
52
- task update_admin_entrypoint: [:environment] do
53
- puts "adding npm_package..."
54
- Alchemy::Upgrader::SevenPointZero.update_admin_entrypoint
46
+ desc "Remove alchemy admin entrypoint"
47
+ task remove_admin_entrypoint: [:environment] do
48
+ puts "removing npm_package..."
49
+ Alchemy::Upgrader::SevenPointZero.remove_admin_entrypoint
55
50
  end
56
51
  end
57
52
  end
data/package.json CHANGED
@@ -1,41 +1,21 @@
1
1
  {
2
- "name": "@alchemy_cms/admin",
3
- "version": "7.0.0-a",
4
- "description": "AlchemyCMS",
5
- "browser": "package/dist/admin.js",
6
- "files": [
7
- "package/**/*"
8
- ],
9
- "directories": {
10
- "lib": "package"
11
- },
2
+ "name": "alchemy_admin",
12
3
  "scripts": {
13
4
  "test": "jest",
14
- "build": "esbuild package/admin.js --bundle --sourcemap --minify --outdir=package/dist --public-path=assets"
15
- },
16
- "repository": {
17
- "type": "git",
18
- "url": "git+https://github.com/AlchemyCMS/alchemy_cms.git"
5
+ "lint": "prettier --check 'app/javascript/**/*.js'"
19
6
  },
20
7
  "keywords": [],
21
8
  "author": "Thomas von Deyen",
22
9
  "license": "BSD-3-Clause",
23
- "bugs": {
24
- "url": "https://github.com/AlchemyCMS/alchemy_cms/issues"
25
- },
26
- "homepage": "https://github.com/AlchemyCMS/alchemy_cms#readme",
27
- "dependencies": {
28
- "flatpickr": "^4.6.9",
29
- "lodash-es": "^4.17.21",
30
- "sortablejs": "^1.10.2"
31
- },
32
10
  "devDependencies": {
33
11
  "@babel/core": "^7.9.6",
34
12
  "@babel/preset-env": "^7.9.6",
35
13
  "babel-jest": "^29.0.1",
36
- "esbuild": "^0.17.5",
14
+ "flatpickr": "^4.6.9",
37
15
  "jest": "^25.2.7",
16
+ "lodash-es": "^4.17.21",
38
17
  "prettier": "^2.0.2",
18
+ "sortablejs": "^1.10.2",
39
19
  "xhr-mock": "^2.5.1"
40
20
  },
41
21
  "jest": {
@@ -43,7 +23,7 @@
43
23
  "Alchemy": {}
44
24
  },
45
25
  "roots": [
46
- "package"
26
+ "spec/javascript/alchemy_admin"
47
27
  ]
48
28
  }
49
29
  }