alchemy_cms 7.0.0.pre.a → 7.0.0.pre.b
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/brakeman-analysis.yml +2 -2
- data/.github/workflows/ci.yml +7 -7
- data/.github/workflows/lint.yml +17 -0
- data/.hound.yml +2 -3
- data/.rubocop.yml +4 -350
- data/.standard.yml +3 -0
- data/CHANGELOG.md +29 -0
- data/Gemfile +3 -1
- data/README.md +7 -9
- data/Rakefile +1 -1
- data/alchemy_cms.gemspec +2 -1
- data/app/assets/javascripts/alchemy/admin.js +0 -1
- data/app/assets/javascripts/alchemy/alchemy.link_dialog.js.coffee +6 -1
- data/app/components/alchemy/ingredients/audio_view.rb +37 -0
- data/app/components/alchemy/ingredients/base_view.rb +38 -0
- data/app/components/alchemy/ingredients/boolean_view.rb +13 -0
- data/app/components/alchemy/ingredients/datetime_view.rb +22 -0
- data/app/components/alchemy/ingredients/file_view.rb +40 -0
- data/app/components/alchemy/ingredients/headline_view.rb +20 -0
- data/app/components/alchemy/ingredients/html_view.rb +9 -0
- data/app/components/alchemy/ingredients/link_view.rb +25 -0
- data/app/components/alchemy/ingredients/node_view.rb +11 -0
- data/app/components/alchemy/ingredients/page_view.rb +15 -0
- data/app/components/alchemy/ingredients/picture_view.rb +108 -0
- data/app/components/alchemy/ingredients/richtext_view.rb +22 -0
- data/app/components/alchemy/ingredients/select_view.rb +6 -0
- data/app/components/alchemy/ingredients/text_view.rb +41 -0
- data/app/components/alchemy/ingredients/video_view.rb +39 -0
- data/app/controllers/alchemy/admin/attachments_controller.rb +3 -3
- data/app/controllers/alchemy/admin/base_controller.rb +7 -7
- data/app/controllers/alchemy/admin/clipboard_controller.rb +2 -2
- data/app/controllers/alchemy/admin/elements_controller.rb +26 -11
- data/app/controllers/alchemy/admin/languages_controller.rb +1 -1
- data/app/controllers/alchemy/admin/nodes_controller.rb +2 -2
- data/app/controllers/alchemy/admin/pages_controller.rb +10 -10
- data/app/controllers/alchemy/admin/pictures_controller.rb +14 -14
- data/app/controllers/alchemy/admin/resources_controller.rb +27 -28
- data/app/controllers/alchemy/admin/styleguide_controller.rb +1 -0
- data/app/controllers/alchemy/admin/tags_controller.rb +11 -11
- data/app/controllers/alchemy/api/base_controller.rb +2 -2
- data/app/controllers/alchemy/api/elements_controller.rb +11 -11
- data/app/controllers/alchemy/api/ingredients_controller.rb +1 -1
- data/app/controllers/alchemy/api/nodes_controller.rb +1 -1
- data/app/controllers/alchemy/api/pages_controller.rb +11 -11
- data/app/controllers/alchemy/attachments_controller.rb +3 -3
- data/app/controllers/alchemy/base_controller.rb +1 -1
- data/app/controllers/alchemy/messages_controller.rb +9 -9
- data/app/controllers/alchemy/pages_controller.rb +8 -19
- data/app/controllers/concerns/alchemy/admin/archive_overlay.rb +1 -0
- data/app/controllers/concerns/alchemy/admin/uploader_responses.rb +5 -7
- data/app/controllers/concerns/alchemy/legacy_page_redirects.rb +5 -5
- data/app/decorators/alchemy/element_editor.rb +4 -4
- data/app/decorators/alchemy/ingredient_editor.rb +6 -6
- data/app/helpers/alchemy/admin/attachments_helper.rb +1 -1
- data/app/helpers/alchemy/admin/base_helper.rb +21 -22
- data/app/helpers/alchemy/admin/elements_helper.rb +1 -1
- data/app/helpers/alchemy/admin/form_helper.rb +1 -1
- data/app/helpers/alchemy/admin/navigation_helper.rb +7 -7
- data/app/helpers/alchemy/admin/pages_helper.rb +2 -2
- data/app/helpers/alchemy/admin/tags_helper.rb +3 -3
- data/app/helpers/alchemy/base_helper.rb +2 -2
- data/app/helpers/alchemy/elements_block_helper.rb +9 -7
- data/app/helpers/alchemy/elements_helper.rb +12 -12
- data/app/helpers/alchemy/pages_helper.rb +11 -11
- data/app/helpers/alchemy/url_helper.rb +1 -1
- data/app/mailers/alchemy/messages_mailer.rb +1 -1
- data/app/models/alchemy/attachment.rb +6 -6
- data/app/models/alchemy/base_record.rb +1 -0
- data/app/models/alchemy/eager_loading.rb +6 -6
- data/app/models/alchemy/element/definitions.rb +1 -1
- data/app/models/alchemy/element/element_ingredients.rb +3 -3
- data/app/models/alchemy/element.rb +2 -2
- data/app/models/alchemy/elements_repository.rb +1 -1
- data/app/models/alchemy/image_cropper_settings.rb +2 -2
- data/app/models/alchemy/ingredient.rb +14 -12
- data/app/models/alchemy/ingredient_validator.rb +1 -1
- data/app/models/alchemy/ingredients/datetime.rb +1 -1
- data/app/models/alchemy/ingredients/file.rb +5 -5
- data/app/models/alchemy/ingredients/headline.rb +4 -4
- data/app/models/alchemy/ingredients/picture.rb +27 -9
- data/app/models/alchemy/ingredients/richtext.rb +15 -12
- data/app/models/alchemy/ingredients/text.rb +6 -6
- data/app/models/alchemy/language/code.rb +1 -1
- data/app/models/alchemy/language.rb +4 -4
- data/app/models/alchemy/legacy_page_url.rb +1 -1
- data/app/models/alchemy/node.rb +2 -2
- data/app/models/alchemy/page/page_elements.rb +14 -14
- data/app/models/alchemy/page/page_naming.rb +4 -4
- data/app/models/alchemy/page/page_natures.rb +1 -1
- data/app/models/alchemy/page/page_scopes.rb +5 -5
- data/app/models/alchemy/page.rb +11 -11
- data/app/models/alchemy/picture/calculations.rb +2 -2
- data/app/models/alchemy/picture/transformations.rb +2 -2
- data/app/models/alchemy/picture/url.rb +4 -4
- data/app/models/alchemy/picture.rb +11 -10
- data/app/models/alchemy/picture_thumb/create.rb +1 -1
- data/app/models/alchemy/picture_thumb.rb +1 -1
- data/app/models/alchemy/picture_variant.rb +2 -3
- data/app/models/alchemy/tag.rb +8 -0
- data/app/models/concerns/alchemy/picture_thumbnails.rb +6 -6
- data/app/serializers/alchemy/base_serializer.rb +1 -1
- data/app/serializers/alchemy/page_tree_serializer.rb +7 -7
- data/app/services/alchemy/duplicate_element.rb +3 -3
- data/app/services/alchemy/tag_validations.rb +1 -1
- data/app/views/alchemy/admin/elements/_element.html.erb +3 -0
- data/app/views/alchemy/admin/pages/edit.html.erb +0 -3
- data/app/views/alchemy/admin/pages/update.js.erb +10 -4
- data/app/views/alchemy/admin/pictures/_infos.html.erb +1 -1
- data/app/views/alchemy/ingredients/_audio_view.html.erb +1 -14
- data/app/views/alchemy/ingredients/_boolean_view.html.erb +1 -1
- data/app/views/alchemy/ingredients/_datetime_view.html.erb +3 -9
- data/app/views/alchemy/ingredients/_file_view.html.erb +3 -16
- data/app/views/alchemy/ingredients/_headline_view.html.erb +4 -10
- data/app/views/alchemy/ingredients/_html_view.html.erb +1 -1
- data/app/views/alchemy/ingredients/_link_view.html.erb +4 -9
- data/app/views/alchemy/ingredients/_node_view.html.erb +1 -1
- data/app/views/alchemy/ingredients/_page_view.html.erb +1 -4
- data/app/views/alchemy/ingredients/_picture_view.html.erb +4 -5
- data/app/views/alchemy/ingredients/_richtext_editor.html.erb +11 -2
- data/app/views/alchemy/ingredients/_richtext_view.html.erb +3 -3
- data/app/views/alchemy/ingredients/_select_view.html.erb +1 -1
- data/app/views/alchemy/ingredients/_text_view.html.erb +3 -19
- data/app/views/alchemy/ingredients/_video_view.html.erb +3 -18
- data/app/views/alchemy/ingredients/shared/_link_tools.html.erb +1 -0
- data/app/views/alchemy/ingredients/shared/_picture_tools.html.erb +1 -0
- data/app/views/layouts/alchemy/admin.html.erb +7 -9
- data/bin/setup +37 -0
- data/bin/start +17 -0
- data/config/initializers/assets.rb +1 -0
- data/config/initializers/dragonfly.rb +1 -0
- data/config/initializers/mime_types.rb +1 -0
- data/config/initializers/mini_profiler.rb +1 -0
- data/config/initializers/simple_form.rb +3 -2
- data/config/locales/alchemy.en.yml +1 -1
- data/config/routes.rb +21 -20
- data/config/spring.rb +1 -0
- data/db/migrate/20230121212637_alchemy_six_point_one.rb +8 -8
- data/db/migrate/20230505132743_add_indexes_to_alchemy_pictures.rb +6 -0
- data/lib/alchemy/admin/locale.rb +3 -3
- data/lib/alchemy/admin/preview_url.rb +2 -2
- data/lib/alchemy/auth_accessors.rb +1 -1
- data/lib/alchemy/config.rb +1 -1
- data/lib/alchemy/controller_actions.rb +4 -4
- data/lib/alchemy/deprecation.rb +1 -0
- data/lib/alchemy/dragonfly/processors/thumbnail.rb +1 -1
- data/lib/alchemy/element_definition.rb +2 -2
- data/lib/alchemy/engine.rb +2 -1
- data/lib/alchemy/filetypes.rb +7 -7
- data/lib/alchemy/forms/builder.rb +4 -4
- data/lib/alchemy/i18n.rb +6 -4
- data/lib/alchemy/install/tasks.rb +2 -1
- data/lib/alchemy/name_conversions.rb +1 -1
- data/lib/alchemy/page_layout.rb +1 -1
- data/lib/alchemy/permissions.rb +5 -4
- data/lib/alchemy/resource.rb +10 -10
- data/lib/alchemy/resources_helper.rb +7 -7
- data/lib/alchemy/routing_constraints.rb +2 -2
- data/lib/alchemy/seeder.rb +12 -5
- data/lib/alchemy/shell.rb +2 -1
- data/lib/alchemy/taggable.rb +3 -2
- data/lib/alchemy/tasks/tidy.rb +1 -0
- data/lib/alchemy/test_support/capybara_helpers.rb +1 -1
- data/lib/alchemy/test_support/config_stubbing.rb +1 -0
- data/lib/alchemy/test_support/factories/element_factory.rb +4 -0
- data/lib/alchemy/test_support/factories/page_factory.rb +2 -2
- data/lib/alchemy/test_support/having_crop_action_examples.rb +9 -9
- data/lib/alchemy/test_support/having_picture_thumbnails_examples.rb +33 -33
- data/lib/alchemy/test_support/integration_helpers.rb +4 -3
- data/lib/alchemy/test_support/shared_contexts.rb +2 -1
- data/lib/alchemy/test_support/shared_dom_ids_examples.rb +9 -9
- data/lib/alchemy/test_support/shared_ingredient_examples.rb +12 -6
- data/lib/alchemy/test_support/shared_uploader_examples.rb +1 -0
- data/lib/alchemy/tinymce.rb +3 -26
- data/lib/alchemy/upgrader.rb +1 -0
- data/lib/alchemy/version.rb +1 -1
- data/lib/alchemy_cms.rb +1 -0
- data/lib/generators/alchemy/base.rb +3 -2
- data/lib/generators/alchemy/elements/elements_generator.rb +2 -1
- data/lib/generators/alchemy/ingredient/ingredient_generator.rb +1 -0
- data/lib/generators/alchemy/install/files/application.html.erb +1 -1
- data/lib/generators/alchemy/install/install_generator.rb +2 -1
- data/lib/generators/alchemy/module/module_generator.rb +1 -0
- data/lib/generators/alchemy/page_layouts/page_layouts_generator.rb +1 -0
- data/lib/generators/alchemy/site_layouts/site_layouts_generator.rb +1 -0
- data/lib/generators/alchemy/views/views_generator.rb +2 -1
- data/lib/tasks/alchemy/thumbnails.rake +5 -5
- data/lib/tasks/alchemy/tidy.rake +1 -0
- data/lib/tasks/alchemy/upgrade.rake +6 -5
- data/package/admin.js +2 -0
- data/package/dist/admin.js +3 -3
- data/package/dist/admin.js.map +4 -4
- data/package/src/datepicker.js +1 -0
- data/package/src/tinymce.js +142 -0
- data/package.json +2 -2
- metadata +39 -7
- data/app/assets/javascripts/alchemy/alchemy.tinymce.js.coffee +0 -93
- data/app/presenters/alchemy/picture_view.rb +0 -88
- data/app/views/alchemy/admin/pages/_tinymce_custom_config.html.erb +0 -10
data/package/src/datepicker.js
CHANGED
@@ -24,6 +24,7 @@ export default function Datepicker(scope = document) {
|
|
24
24
|
altInput: true,
|
25
25
|
altFormat: Alchemy.t(`formats.${type}`),
|
26
26
|
altInputClass: "flatpickr-input",
|
27
|
+
dateFormat: "Z",
|
27
28
|
enableTime: /time/.test(type),
|
28
29
|
noCalendar: type === "time",
|
29
30
|
time_24hr: Alchemy.t("formats.time_24hr"),
|
@@ -0,0 +1,142 @@
|
|
1
|
+
// Alchemy Tinymce wrapper
|
2
|
+
//
|
3
|
+
|
4
|
+
let tinymceCustomConfigs = {}
|
5
|
+
let tinymceIntersectionObserver = null
|
6
|
+
|
7
|
+
// Returns default config for a tinymce editor.
|
8
|
+
function getDefaultConfig(editorId) {
|
9
|
+
const config = Alchemy.TinymceDefaults
|
10
|
+
config.language = Alchemy.locale
|
11
|
+
config.selector = `#${editorId}`
|
12
|
+
config.init_instance_callback = initInstanceCallback
|
13
|
+
return config
|
14
|
+
}
|
15
|
+
|
16
|
+
// Returns configuration for given custom tinymce editor selector.
|
17
|
+
//
|
18
|
+
// It uses the +.getDefaultConfig+ and merges the custom parts.
|
19
|
+
function getConfig(editorId) {
|
20
|
+
const editorConfig = tinymceCustomConfigs[editorId] || {}
|
21
|
+
return { ...getDefaultConfig(editorId), ...editorConfig }
|
22
|
+
}
|
23
|
+
|
24
|
+
// create intersection observer and register textareas to be initialized when
|
25
|
+
// they are visible
|
26
|
+
function initEditors(ids) {
|
27
|
+
initializeIntersectionObserver()
|
28
|
+
|
29
|
+
ids.forEach((id) => {
|
30
|
+
const editorId = `tinymce_${id}`
|
31
|
+
const textarea = document.getElementById(editorId)
|
32
|
+
|
33
|
+
if (textarea) {
|
34
|
+
tinymceIntersectionObserver.observe(textarea)
|
35
|
+
} else {
|
36
|
+
console.warn(`Could not initialize TinyMCE for textarea#${editorId}!`)
|
37
|
+
}
|
38
|
+
})
|
39
|
+
}
|
40
|
+
|
41
|
+
// initialize IntersectionObserver
|
42
|
+
// the observer will initialize Tinymce if the textarea becomes visible
|
43
|
+
function initializeIntersectionObserver() {
|
44
|
+
if (tinymceIntersectionObserver !== null) {
|
45
|
+
tinymceIntersectionObserver.disconnect()
|
46
|
+
}
|
47
|
+
|
48
|
+
const observerCallback = (entries, observer) => {
|
49
|
+
entries.forEach((entry) => {
|
50
|
+
if (entry.intersectionRatio > 0) {
|
51
|
+
initTinymceEditor(entry.target)
|
52
|
+
// disable observer after the Tinymce was initialized
|
53
|
+
observer.unobserve(entry.target)
|
54
|
+
}
|
55
|
+
})
|
56
|
+
}
|
57
|
+
const options = {
|
58
|
+
root: Alchemy.ElementEditors.element_area.get(0),
|
59
|
+
rootMargin: "0px",
|
60
|
+
threshold: [0.05]
|
61
|
+
}
|
62
|
+
|
63
|
+
tinymceIntersectionObserver = new IntersectionObserver(
|
64
|
+
observerCallback,
|
65
|
+
options
|
66
|
+
)
|
67
|
+
}
|
68
|
+
|
69
|
+
// Initializes one specific TinyMCE editor
|
70
|
+
function initTinymceEditor(textarea) {
|
71
|
+
const editorId = textarea.id
|
72
|
+
const config = getConfig(editorId)
|
73
|
+
|
74
|
+
// remove editor instance, if already initialized
|
75
|
+
removeEditor(editorId)
|
76
|
+
|
77
|
+
if (config) {
|
78
|
+
const spinner = new Alchemy.Spinner("small")
|
79
|
+
textarea.closest(".tinymce_container").prepend(spinner.spin().el.get(0))
|
80
|
+
tinymce.init(config)
|
81
|
+
} else {
|
82
|
+
console.warn("No tinymce configuration found for", id)
|
83
|
+
}
|
84
|
+
}
|
85
|
+
|
86
|
+
// Gets called after an editor instance gets initialized
|
87
|
+
function initInstanceCallback(editor) {
|
88
|
+
const element = document.getElementById(editor.id).closest(".element-editor")
|
89
|
+
element.getElementsByClassName("spinner").item(0).remove()
|
90
|
+
editor.on("dirty", function () {
|
91
|
+
Alchemy.setElementDirty(element)
|
92
|
+
})
|
93
|
+
editor.on("click", function (event) {
|
94
|
+
event.target = element
|
95
|
+
Alchemy.ElementEditors.onClickElement(event)
|
96
|
+
})
|
97
|
+
}
|
98
|
+
|
99
|
+
function removeEditor(editorId) {
|
100
|
+
const editorElement = document.getElementById(editorId)
|
101
|
+
if (tinymceIntersectionObserver && editorElement) {
|
102
|
+
tinymceIntersectionObserver.unobserve(editorElement)
|
103
|
+
}
|
104
|
+
|
105
|
+
const editor = tinymce.get(editorId)
|
106
|
+
if (editor) {
|
107
|
+
editor.remove()
|
108
|
+
}
|
109
|
+
}
|
110
|
+
|
111
|
+
export default {
|
112
|
+
// Initializes all TinyMCE editors with given ids
|
113
|
+
//
|
114
|
+
// @param ids [Array]
|
115
|
+
// - Editor ids that should be initialized.
|
116
|
+
init(ids) {
|
117
|
+
initEditors(ids)
|
118
|
+
},
|
119
|
+
|
120
|
+
// Initializes TinyMCE editor with given options
|
121
|
+
initWith(options) {
|
122
|
+
tinymce.init({ ...Alchemy.TinymceDefaults, ...options })
|
123
|
+
},
|
124
|
+
|
125
|
+
// Removes the TinyMCE editor from given dom ids.
|
126
|
+
remove(ids) {
|
127
|
+
ids.forEach((id) => removeEditor(`tinymce_${id}`))
|
128
|
+
},
|
129
|
+
|
130
|
+
// Remove all tinymce instances for given selector
|
131
|
+
removeFrom(selector) {
|
132
|
+
// the selector is a jQuery selector - it has to be refactor if we taking care of the calling methods
|
133
|
+
$(selector).each(function (element) {
|
134
|
+
removeEditor(element.id)
|
135
|
+
})
|
136
|
+
},
|
137
|
+
|
138
|
+
// set tinymce configuration for a given selector key
|
139
|
+
setCustomConfig(key, configuration) {
|
140
|
+
tinymceCustomConfigs[key] = configuration
|
141
|
+
}
|
142
|
+
}
|
data/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@alchemy_cms/admin",
|
3
|
-
"version": "7.0.0-
|
3
|
+
"version": "7.0.0-b",
|
4
4
|
"description": "AlchemyCMS",
|
5
5
|
"browser": "package/dist/admin.js",
|
6
6
|
"files": [
|
@@ -33,7 +33,7 @@
|
|
33
33
|
"@babel/core": "^7.9.6",
|
34
34
|
"@babel/preset-env": "^7.9.6",
|
35
35
|
"babel-jest": "^29.0.1",
|
36
|
-
"esbuild": "^0.
|
36
|
+
"esbuild": "^0.18.4",
|
37
37
|
"jest": "^25.2.7",
|
38
38
|
"prettier": "^2.0.2",
|
39
39
|
"xhr-mock": "^2.5.1"
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: alchemy_cms
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 7.0.0.pre.
|
4
|
+
version: 7.0.0.pre.b
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Thomas von Deyen
|
@@ -13,7 +13,7 @@ authors:
|
|
13
13
|
autorequire:
|
14
14
|
bindir: bin
|
15
15
|
cert_chain: []
|
16
|
-
date: 2023-
|
16
|
+
date: 2023-06-22 00:00:00.000000000 Z
|
17
17
|
dependencies:
|
18
18
|
- !ruby/object:Gem::Dependency
|
19
19
|
name: actionmailer
|
@@ -509,6 +509,20 @@ dependencies:
|
|
509
509
|
- - ">="
|
510
510
|
- !ruby/object:Gem::Version
|
511
511
|
version: '2.5'
|
512
|
+
- !ruby/object:Gem::Dependency
|
513
|
+
name: view_component
|
514
|
+
requirement: !ruby/object:Gem::Requirement
|
515
|
+
requirements:
|
516
|
+
- - "~>"
|
517
|
+
- !ruby/object:Gem::Version
|
518
|
+
version: '3.0'
|
519
|
+
type: :runtime
|
520
|
+
prerelease: false
|
521
|
+
version_requirements: !ruby/object:Gem::Requirement
|
522
|
+
requirements:
|
523
|
+
- - "~>"
|
524
|
+
- !ruby/object:Gem::Version
|
525
|
+
version: '3.0'
|
512
526
|
- !ruby/object:Gem::Dependency
|
513
527
|
name: capybara
|
514
528
|
requirement: !ruby/object:Gem::Requirement
|
@@ -692,6 +706,7 @@ files:
|
|
692
706
|
- ".github/PULL_REQUEST_TEMPLATE.md"
|
693
707
|
- ".github/workflows/brakeman-analysis.yml"
|
694
708
|
- ".github/workflows/ci.yml"
|
709
|
+
- ".github/workflows/lint.yml"
|
695
710
|
- ".github/workflows/stale.yml"
|
696
711
|
- ".gitignore"
|
697
712
|
- ".hound.yml"
|
@@ -699,6 +714,7 @@ files:
|
|
699
714
|
- ".prettierrc"
|
700
715
|
- ".rspec"
|
701
716
|
- ".rubocop.yml"
|
717
|
+
- ".standard.yml"
|
702
718
|
- ".yardopts"
|
703
719
|
- CHANGELOG.md
|
704
720
|
- CODE_OF_CONDUCT.md
|
@@ -743,7 +759,6 @@ files:
|
|
743
759
|
- app/assets/javascripts/alchemy/alchemy.preview_window.js.coffee
|
744
760
|
- app/assets/javascripts/alchemy/alchemy.spinner.js
|
745
761
|
- app/assets/javascripts/alchemy/alchemy.string_extension.js.coffee
|
746
|
-
- app/assets/javascripts/alchemy/alchemy.tinymce.js.coffee
|
747
762
|
- app/assets/javascripts/alchemy/alchemy.tooltips.coffee
|
748
763
|
- app/assets/javascripts/alchemy/alchemy.uploader.js.coffee
|
749
764
|
- app/assets/javascripts/alchemy/menubar.js.coffee
|
@@ -817,6 +832,21 @@ files:
|
|
817
832
|
- app/assets/stylesheets/tinymce/skins/alchemy/img/object.gif
|
818
833
|
- app/assets/stylesheets/tinymce/skins/alchemy/img/trans.gif
|
819
834
|
- app/assets/stylesheets/tinymce/skins/alchemy/skin.min.css.scss
|
835
|
+
- app/components/alchemy/ingredients/audio_view.rb
|
836
|
+
- app/components/alchemy/ingredients/base_view.rb
|
837
|
+
- app/components/alchemy/ingredients/boolean_view.rb
|
838
|
+
- app/components/alchemy/ingredients/datetime_view.rb
|
839
|
+
- app/components/alchemy/ingredients/file_view.rb
|
840
|
+
- app/components/alchemy/ingredients/headline_view.rb
|
841
|
+
- app/components/alchemy/ingredients/html_view.rb
|
842
|
+
- app/components/alchemy/ingredients/link_view.rb
|
843
|
+
- app/components/alchemy/ingredients/node_view.rb
|
844
|
+
- app/components/alchemy/ingredients/page_view.rb
|
845
|
+
- app/components/alchemy/ingredients/picture_view.rb
|
846
|
+
- app/components/alchemy/ingredients/richtext_view.rb
|
847
|
+
- app/components/alchemy/ingredients/select_view.rb
|
848
|
+
- app/components/alchemy/ingredients/text_view.rb
|
849
|
+
- app/components/alchemy/ingredients/video_view.rb
|
820
850
|
- app/controllers/alchemy/admin/attachments_controller.rb
|
821
851
|
- app/controllers/alchemy/admin/base_controller.rb
|
822
852
|
- app/controllers/alchemy/admin/clipboard_controller.rb
|
@@ -931,7 +961,6 @@ files:
|
|
931
961
|
- app/models/concerns/alchemy/dom_ids.rb
|
932
962
|
- app/models/concerns/alchemy/picture_thumbnails.rb
|
933
963
|
- app/models/concerns/alchemy/touch_elements.rb
|
934
|
-
- app/presenters/alchemy/picture_view.rb
|
935
964
|
- app/serializers/alchemy/attachment_serializer.rb
|
936
965
|
- app/serializers/alchemy/base_serializer.rb
|
937
966
|
- app/serializers/alchemy/element_serializer.rb
|
@@ -1034,7 +1063,6 @@ files:
|
|
1034
1063
|
- app/views/alchemy/admin/pages/_sitemap.html.erb
|
1035
1064
|
- app/views/alchemy/admin/pages/_table.html.erb
|
1036
1065
|
- app/views/alchemy/admin/pages/_table_row.html.erb
|
1037
|
-
- app/views/alchemy/admin/pages/_tinymce_custom_config.html.erb
|
1038
1066
|
- app/views/alchemy/admin/pages/_toolbar.html.erb
|
1039
1067
|
- app/views/alchemy/admin/pages/configure.html.erb
|
1040
1068
|
- app/views/alchemy/admin/pages/edit.html.erb
|
@@ -1165,6 +1193,8 @@ files:
|
|
1165
1193
|
- babel.config.js
|
1166
1194
|
- bin/rails
|
1167
1195
|
- bin/rspec
|
1196
|
+
- bin/setup
|
1197
|
+
- bin/start
|
1168
1198
|
- config/alchemy/config.yml
|
1169
1199
|
- config/alchemy/modules.yml
|
1170
1200
|
- config/brakeman.ignore
|
@@ -1178,6 +1208,7 @@ files:
|
|
1178
1208
|
- config/spring.rb
|
1179
1209
|
- db/migrate/20230121212637_alchemy_six_point_one.rb
|
1180
1210
|
- db/migrate/20230123112425_add_searchable_to_alchemy_pages.rb
|
1211
|
+
- db/migrate/20230505132743_add_indexes_to_alchemy_pictures.rb
|
1181
1212
|
- lib/alchemy.rb
|
1182
1213
|
- lib/alchemy/ability_helper.rb
|
1183
1214
|
- lib/alchemy/admin/locale.rb
|
@@ -1312,6 +1343,7 @@ files:
|
|
1312
1343
|
- package/src/page_sorter.js
|
1313
1344
|
- package/src/picture_editors.js
|
1314
1345
|
- package/src/sitemap.js
|
1346
|
+
- package/src/tinymce.js
|
1315
1347
|
- package/src/translations.js
|
1316
1348
|
- package/src/utils/__tests__/ajax.spec.js
|
1317
1349
|
- package/src/utils/__tests__/events.spec.js
|
@@ -1391,7 +1423,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
1391
1423
|
requirements:
|
1392
1424
|
- - ">="
|
1393
1425
|
- !ruby/object:Gem::Version
|
1394
|
-
version:
|
1426
|
+
version: 3.0.0
|
1395
1427
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
1396
1428
|
requirements:
|
1397
1429
|
- - ">"
|
@@ -1399,7 +1431,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
1399
1431
|
version: 1.3.1
|
1400
1432
|
requirements:
|
1401
1433
|
- ImageMagick (libmagick), v6.6 or greater.
|
1402
|
-
rubygems_version: 3.4.
|
1434
|
+
rubygems_version: 3.4.12
|
1403
1435
|
signing_key:
|
1404
1436
|
specification_version: 4
|
1405
1437
|
summary: A powerful, userfriendly and flexible CMS for Rails
|
@@ -1,93 +0,0 @@
|
|
1
|
-
# Alchemy Tinymce wrapper
|
2
|
-
#
|
3
|
-
$.extend Alchemy.Tinymce,
|
4
|
-
|
5
|
-
customConfigs: {}
|
6
|
-
|
7
|
-
# Returns default config for a tinymce editor.
|
8
|
-
#
|
9
|
-
getDefaultConfig: (id) ->
|
10
|
-
config = @defaults
|
11
|
-
config.language = Alchemy.locale
|
12
|
-
config.selector = "#tinymce_#{id}"
|
13
|
-
config.init_instance_callback = @initInstanceCallback
|
14
|
-
return config
|
15
|
-
|
16
|
-
# Returns configuration for given custom tinymce editor selector.
|
17
|
-
#
|
18
|
-
# It uses the +.getDefaultConfig+ and merges the custom parts.
|
19
|
-
#
|
20
|
-
getConfig: (id, selector) ->
|
21
|
-
editor_config = @customConfigs[selector]
|
22
|
-
if editor_config
|
23
|
-
$.extend({}, @getDefaultConfig(id), editor_config)
|
24
|
-
else
|
25
|
-
@getDefaultConfig(id)
|
26
|
-
|
27
|
-
# Initializes all TinyMCE editors with given ids
|
28
|
-
#
|
29
|
-
# @param ids [Array]
|
30
|
-
# - Editor ids that should be initialized.
|
31
|
-
#
|
32
|
-
init: (ids) ->
|
33
|
-
for id in ids
|
34
|
-
@initEditor(id)
|
35
|
-
|
36
|
-
# Initializes TinyMCE editor with given options
|
37
|
-
#
|
38
|
-
initWith: (options) ->
|
39
|
-
tinymce.init $.extend({}, @defaults, options)
|
40
|
-
return
|
41
|
-
|
42
|
-
# Initializes one specific TinyMCE editor
|
43
|
-
#
|
44
|
-
# @param id [Number]
|
45
|
-
# - Editor id that should be initialized.
|
46
|
-
#
|
47
|
-
initEditor: (id) ->
|
48
|
-
editor_id = "tinymce_#{id}"
|
49
|
-
textarea = $("##{editor_id}")
|
50
|
-
editor = tinymce.get(editor_id)
|
51
|
-
# remove editor instance, if already initialized
|
52
|
-
editor.remove() if editor
|
53
|
-
if textarea.length == 0
|
54
|
-
console.warn "Could not initialize TinyMCE for textarea#tinymce_#{id}!"
|
55
|
-
return
|
56
|
-
config = @getConfig(id, textarea[0].classList[1])
|
57
|
-
if config
|
58
|
-
spinner = new Alchemy.Spinner('small')
|
59
|
-
textarea.closest('.tinymce_container').prepend spinner.spin().el
|
60
|
-
tinymce.init(config)
|
61
|
-
else
|
62
|
-
console.warn('No tinymce configuration found for', id)
|
63
|
-
|
64
|
-
# Gets called after an editor instance gets intialized
|
65
|
-
#
|
66
|
-
initInstanceCallback: (editor) ->
|
67
|
-
$this = $("##{editor.id}")
|
68
|
-
element = $this.closest('.element-editor')
|
69
|
-
element.find('.spinner').remove()
|
70
|
-
editor.on 'dirty', ->
|
71
|
-
Alchemy.setElementDirty(element)
|
72
|
-
return
|
73
|
-
editor.on 'click', (event) ->
|
74
|
-
event.target = element[0]
|
75
|
-
Alchemy.ElementEditors.onClickElement(event)
|
76
|
-
return
|
77
|
-
return
|
78
|
-
|
79
|
-
# Removes the TinyMCE editor from given dom ids.
|
80
|
-
#
|
81
|
-
remove: (ids) ->
|
82
|
-
for id in ids
|
83
|
-
editor = tinymce.get("tinymce_#{id}")
|
84
|
-
if editor
|
85
|
-
editor.remove()
|
86
|
-
|
87
|
-
# Remove all tinymce instances for given selector
|
88
|
-
removeFrom: (selector) ->
|
89
|
-
$(selector).each ->
|
90
|
-
elem = tinymce.get(this.id)
|
91
|
-
elem.remove() if elem
|
92
|
-
return
|
93
|
-
return
|
@@ -1,88 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
module Alchemy
|
4
|
-
# Renders a picture ingredient view
|
5
|
-
class PictureView
|
6
|
-
include ActionView::Helpers::AssetTagHelper
|
7
|
-
include ActionView::Helpers::UrlHelper
|
8
|
-
include Rails.application.routes.url_helpers
|
9
|
-
|
10
|
-
attr_reader :ingredient, :html_options, :options, :picture
|
11
|
-
|
12
|
-
DEFAULT_OPTIONS = {
|
13
|
-
show_caption: true,
|
14
|
-
disable_link: false,
|
15
|
-
srcset: [],
|
16
|
-
sizes: [],
|
17
|
-
}.with_indifferent_access
|
18
|
-
|
19
|
-
def initialize(ingredient, options = {}, html_options = {})
|
20
|
-
@ingredient = ingredient
|
21
|
-
@options = DEFAULT_OPTIONS.merge(ingredient.settings).merge(options || {})
|
22
|
-
@html_options = html_options || {}
|
23
|
-
@picture = ingredient.picture
|
24
|
-
end
|
25
|
-
|
26
|
-
def render
|
27
|
-
return if picture.blank?
|
28
|
-
|
29
|
-
output = caption ? img_tag + caption : img_tag
|
30
|
-
|
31
|
-
if is_linked?
|
32
|
-
output = link_to(output, url_for(ingredient.link), {
|
33
|
-
title: ingredient.link_title.presence,
|
34
|
-
target: ingredient.link_target == "blank" ? "_blank" : nil,
|
35
|
-
data: { link_target: ingredient.link_target.presence },
|
36
|
-
})
|
37
|
-
end
|
38
|
-
|
39
|
-
if caption
|
40
|
-
content_tag(:figure, output, { class: ingredient.css_class.presence }.merge(html_options))
|
41
|
-
else
|
42
|
-
output
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
def caption
|
47
|
-
return unless show_caption?
|
48
|
-
|
49
|
-
@_caption ||= content_tag(:figcaption, ingredient.caption)
|
50
|
-
end
|
51
|
-
|
52
|
-
def src
|
53
|
-
ingredient.picture_url(options.except(*DEFAULT_OPTIONS.keys))
|
54
|
-
end
|
55
|
-
|
56
|
-
def img_tag
|
57
|
-
@_img_tag ||= image_tag(
|
58
|
-
src, {
|
59
|
-
alt: alt_text,
|
60
|
-
title: ingredient.title.presence,
|
61
|
-
class: caption ? nil : ingredient.css_class.presence,
|
62
|
-
srcset: srcset.join(", ").presence,
|
63
|
-
sizes: options[:sizes].join(", ").presence,
|
64
|
-
}.merge(caption ? {} : html_options)
|
65
|
-
)
|
66
|
-
end
|
67
|
-
|
68
|
-
def show_caption?
|
69
|
-
options[:show_caption] && ingredient.caption.present?
|
70
|
-
end
|
71
|
-
|
72
|
-
def is_linked?
|
73
|
-
!options[:disable_link] && ingredient.link.present?
|
74
|
-
end
|
75
|
-
|
76
|
-
def srcset
|
77
|
-
options[:srcset].map do |size|
|
78
|
-
url = ingredient.picture_url(size: size)
|
79
|
-
width, height = size.split("x")
|
80
|
-
width.present? ? "#{url} #{width}w" : "#{url} #{height}h"
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
def alt_text
|
85
|
-
ingredient.alt_tag.presence || html_options.delete(:alt) || ingredient.picture.name&.humanize
|
86
|
-
end
|
87
|
-
end
|
88
|
-
end
|
@@ -1,10 +0,0 @@
|
|
1
|
-
<script>
|
2
|
-
// Populate custom tinymce configurations
|
3
|
-
<% Alchemy::Tinymce.custom_config_ingredients(@page).each do |ingredient| %>
|
4
|
-
Alchemy.Tinymce.customConfigs["<%= ingredient['element'] %>_<%= ingredient['role'] %>"] = {
|
5
|
-
<% ingredient.fetch('settings', {}).fetch('tinymce', {}).each do |k, v| %>
|
6
|
-
<%= k %>: <%== v.to_json %>,
|
7
|
-
<% end %>
|
8
|
-
};
|
9
|
-
<% end %>
|
10
|
-
</script>
|