alchemy_cms 6.0.0.pre.rc7 → 6.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/ci.yml +8 -0
- data/CHANGELOG.md +12 -0
- data/Gemfile +3 -1
- data/alchemy_cms.gemspec +2 -2
- data/app/assets/javascripts/alchemy/alchemy.link_dialog.js.coffee +2 -0
- data/app/assets/stylesheets/alchemy/archive.scss +5 -0
- data/app/assets/stylesheets/alchemy/elements.scss +4 -0
- data/app/controllers/alchemy/admin/elements_controller.rb +2 -6
- data/app/controllers/alchemy/admin/pages_controller.rb +6 -3
- data/app/controllers/alchemy/api/contents_controller.rb +1 -5
- data/app/controllers/alchemy/api/elements_controller.rb +2 -6
- data/app/controllers/alchemy/api/pages_controller.rb +2 -6
- data/app/helpers/alchemy/elements_helper.rb +2 -2
- data/app/models/alchemy/picture.rb +1 -1
- data/app/views/alchemy/admin/partials/_routes.html.erb +4 -0
- data/app/views/alchemy/admin/resources/_form.html.erb +5 -0
- data/config/alchemy/config.yml +1 -0
- data/lib/alchemy/engine.rb +12 -1
- data/lib/alchemy/essence.rb +0 -26
- data/lib/alchemy/resource.rb +16 -1
- data/lib/alchemy/test_support/essence_shared_examples.rb +0 -12
- data/lib/alchemy/upgrader/tasks/ingredients_migrator.rb +1 -1
- data/lib/alchemy/version.rb +1 -1
- data/package/src/image_loader.js +2 -2
- data/package/src/picture_editors.js +5 -5
- data/package.json +1 -1
- metadata +24 -24
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: f1db98328d1be1d96ee705e68f64b757f33d0997e4f622626ca86e4e42511079
|
4
|
+
data.tar.gz: 563c9f02b864e170ac88a9d3f405c61b46da38fec41d0f4dfba0ff0c179407ba
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 524ab50512e3a7c377f3619f20c6ec812e1c12a933b94fb56d8bbc5b94b843cd9708451b77b96af8be7776bb0c733c90af549da76820109a0163a0338b8599dc
|
7
|
+
data.tar.gz: 7c8346e5b07d35e2ef471cb90aff4fe8e62e2050ef13d03436cb2492e0cb5a6d9a2003eefa0f4f55d0a61cfdcbda48596788956908964c71333ca0ebdfa1565d
|
data/.github/workflows/ci.yml
CHANGED
@@ -11,6 +11,7 @@ jobs:
|
|
11
11
|
rails:
|
12
12
|
- "6.0"
|
13
13
|
- "6.1"
|
14
|
+
- "7.0"
|
14
15
|
ruby:
|
15
16
|
- "2.6"
|
16
17
|
- "2.7"
|
@@ -18,6 +19,13 @@ jobs:
|
|
18
19
|
database:
|
19
20
|
- mysql
|
20
21
|
- postgresql
|
22
|
+
exclude:
|
23
|
+
- rails: "7.0"
|
24
|
+
ruby: "2.6"
|
25
|
+
database: mysql
|
26
|
+
- rails: "7.0"
|
27
|
+
ruby: "2.6"
|
28
|
+
database: postgresql
|
21
29
|
env:
|
22
30
|
DB: ${{ matrix.database }}
|
23
31
|
DB_USER: alchemy_user
|
data/CHANGELOG.md
CHANGED
@@ -1,3 +1,15 @@
|
|
1
|
+
## 6.0.0 (2022-04-11)
|
2
|
+
|
3
|
+
- [ruby - main] Allow ransack version 3.0.1 [#2287](https://github.com/AlchemyCMS/alchemy_cms/pull/2287) ([depfu](https://github.com/apps/depfu))
|
4
|
+
- Fix image loader [#2285](https://github.com/AlchemyCMS/alchemy_cms/pull/2285) ([tvdeyen](https://github.com/tvdeyen))
|
5
|
+
- Don't delete locals in render_element so they can be used by all elements in render_elements [#2283](https://github.com/AlchemyCMS/alchemy_cms/pull/2283) ([dbwinger](https://github.com/dbwinger))
|
6
|
+
- Don't hardcode URLs in Javascript [#2282](https://github.com/AlchemyCMS/alchemy_cms/pull/2282) ([dssjoblom](https://github.com/dssjoblom))
|
7
|
+
- [ruby - main] Allow ransack 3.0.0 [#2278](https://github.com/AlchemyCMS/alchemy_cms/pull/2278) ([depfu](https://github.com/apps/depfu))
|
8
|
+
- Show site and language name on page select in Link dialog [#2276](https://github.com/AlchemyCMS/alchemy_cms/pull/2276) ([dbwinger](https://github.com/dbwinger))
|
9
|
+
- Allow webp as image file format [#2274](https://github.com/AlchemyCMS/alchemy_cms/pull/2274) ([tvdeyen](https://github.com/tvdeyen))
|
10
|
+
- Rails 7 Support [#2225](https://github.com/AlchemyCMS/alchemy_cms/pull/2225) ([tvdeyen](https://github.com/tvdeyen))
|
11
|
+
- Support AR enums in resource models [#2210](https://github.com/AlchemyCMS/alchemy_cms/pull/2210) ([robinboening](https://github.com/robinboening))
|
12
|
+
|
1
13
|
## 6.0.0-rc7 (2022-03-28)
|
2
14
|
|
3
15
|
- fix(Sitemap): Use response data [#2272](https://github.com/AlchemyCMS/alchemy_cms/pull/2272) ([tvdeyen](https://github.com/tvdeyen))
|
data/Gemfile
CHANGED
@@ -3,11 +3,13 @@ source "https://rubygems.org"
|
|
3
3
|
|
4
4
|
gemspec
|
5
5
|
|
6
|
-
rails_version = ENV.fetch("RAILS_VERSION",
|
6
|
+
rails_version = ENV.fetch("RAILS_VERSION", 7.0).to_f
|
7
7
|
# Necessary until a new 6.1.5 version has been released
|
8
8
|
# https://github.com/rails/rails/pull/44691
|
9
9
|
if rails_version.to_s.match?(/6.1/)
|
10
10
|
gem "rails", git: "https://github.com/rails/rails", branch: "6-1-stable"
|
11
|
+
elsif rails_version.to_s.match?(/7.0/)
|
12
|
+
gem "rails", git: "https://github.com/rails/rails", branch: "7-0-stable"
|
11
13
|
else
|
12
14
|
gem "rails", "~> #{rails_version}.0"
|
13
15
|
end
|
data/alchemy_cms.gemspec
CHANGED
@@ -29,7 +29,7 @@ Gem::Specification.new do |gem|
|
|
29
29
|
activesupport
|
30
30
|
railties
|
31
31
|
].each do |rails_gem|
|
32
|
-
gem.add_runtime_dependency rails_gem, [">= 6.0", "<
|
32
|
+
gem.add_runtime_dependency rails_gem, [">= 6.0", "< 7.1"]
|
33
33
|
end
|
34
34
|
|
35
35
|
gem.add_runtime_dependency "active_model_serializers", ["~> 0.10.0"]
|
@@ -46,7 +46,7 @@ Gem::Specification.new do |gem|
|
|
46
46
|
gem.add_runtime_dependency "kaminari", ["~> 1.1"]
|
47
47
|
gem.add_runtime_dependency "originator", ["~> 3.1"]
|
48
48
|
gem.add_runtime_dependency "non-stupid-digest-assets", ["~> 1.0.8"]
|
49
|
-
gem.add_runtime_dependency "ransack", [">= 1.8", "
|
49
|
+
gem.add_runtime_dependency "ransack", [">= 1.8", "< 4.0"]
|
50
50
|
gem.add_runtime_dependency "request_store", ["~> 1.2"]
|
51
51
|
gem.add_runtime_dependency "responders", [">= 2.0", "< 4.0"]
|
52
52
|
gem.add_runtime_dependency "sassc-rails", ["~> 2.1"]
|
@@ -87,6 +87,8 @@ class window.Alchemy.LinkDialog extends Alchemy.Dialog
|
|
87
87
|
name: page.name
|
88
88
|
url_path: page.url_path
|
89
89
|
page_id: page.id
|
90
|
+
language: page.language
|
91
|
+
site: page.site
|
90
92
|
more: meta.page * meta.per_page < meta.total_count
|
91
93
|
initSelection: ($element, callback) =>
|
92
94
|
urlname = $element.val()
|
@@ -106,18 +106,14 @@ module Alchemy
|
|
106
106
|
def element_includes
|
107
107
|
[
|
108
108
|
{
|
109
|
-
contents:
|
110
|
-
essence: :ingredient_association,
|
111
|
-
},
|
109
|
+
contents: :essence,
|
112
110
|
ingredients: :related_object,
|
113
111
|
},
|
114
112
|
:tags,
|
115
113
|
{
|
116
114
|
all_nested_elements: [
|
117
115
|
{
|
118
|
-
contents:
|
119
|
-
essence: :ingredient_association,
|
120
|
-
},
|
116
|
+
contents: :essence,
|
121
117
|
ingredients: :related_object,
|
122
118
|
},
|
123
119
|
:tags,
|
@@ -179,9 +179,12 @@ module Alchemy
|
|
179
179
|
@pages_locked_by_user = Page.from_current_site.locked_by(current_alchemy_user)
|
180
180
|
respond_to do |format|
|
181
181
|
format.js
|
182
|
-
format.html
|
183
|
-
redirect_to
|
184
|
-
|
182
|
+
format.html do
|
183
|
+
redirect_to(
|
184
|
+
params[:redirect_to].presence || admin_pages_path,
|
185
|
+
allow_other_host: true,
|
186
|
+
)
|
187
|
+
end
|
185
188
|
end
|
186
189
|
end
|
187
190
|
|
@@ -47,18 +47,14 @@ module Alchemy
|
|
47
47
|
{
|
48
48
|
nested_elements: [
|
49
49
|
{
|
50
|
-
contents:
|
51
|
-
essence: :ingredient_association,
|
52
|
-
},
|
50
|
+
contents: :essence,
|
53
51
|
ingredients: :related_object,
|
54
52
|
},
|
55
53
|
:tags,
|
56
54
|
],
|
57
55
|
},
|
58
56
|
{
|
59
|
-
contents:
|
60
|
-
essence: :ingredient_association,
|
61
|
-
},
|
57
|
+
contents: :essence,
|
62
58
|
ingredients: :related_object,
|
63
59
|
},
|
64
60
|
:tags,
|
@@ -112,17 +112,13 @@ module Alchemy
|
|
112
112
|
{
|
113
113
|
nested_elements: [
|
114
114
|
{
|
115
|
-
contents:
|
116
|
-
essence: :ingredient_association,
|
117
|
-
},
|
115
|
+
contents: :essence,
|
118
116
|
},
|
119
117
|
:tags,
|
120
118
|
],
|
121
119
|
},
|
122
120
|
{
|
123
|
-
contents:
|
124
|
-
essence: :ingredient_association,
|
125
|
-
},
|
121
|
+
contents: :essence,
|
126
122
|
},
|
127
123
|
:tags,
|
128
124
|
],
|
@@ -149,8 +149,8 @@ module Alchemy
|
|
149
149
|
render element, {
|
150
150
|
element: element,
|
151
151
|
counter: counter,
|
152
|
-
options: options,
|
153
|
-
}.merge(options
|
152
|
+
options: options.except(:locals),
|
153
|
+
}.merge(options[:locals] || {})
|
154
154
|
rescue ActionView::MissingTemplate => e
|
155
155
|
warning(%(
|
156
156
|
Element view partial not found for #{element.name}.\n
|
@@ -5,6 +5,10 @@
|
|
5
5
|
return '<%= alchemy.admin_picture_path(id: 1) %>'.replace(/1/, id);
|
6
6
|
},
|
7
7
|
|
8
|
+
url_admin_picture_path: function(id) {
|
9
|
+
return '<%= alchemy.url_admin_picture_path(id: 1) %>'.replace(/1/, id);
|
10
|
+
},
|
11
|
+
|
8
12
|
fold_admin_element_path: function(id) {
|
9
13
|
return '<%= alchemy.fold_admin_element_path(id: 1) %>'.replace(/1/, id);
|
10
14
|
},
|
@@ -8,6 +8,11 @@
|
|
8
8
|
input_html: {class: 'alchemy_selectbox'} %>
|
9
9
|
<% elsif attribute[:type].in? %i[date time datetime] %>
|
10
10
|
<%= f.datepicker attribute[:name], resource_attribute_field_options(attribute) %>
|
11
|
+
<% elsif attribute[:enum].present? %>
|
12
|
+
<%= f.input attribute[:name],
|
13
|
+
collection: attribute[:enum],
|
14
|
+
include_blank: Alchemy.t(:blank, scope: 'resources.relation_select'),
|
15
|
+
input_html: {class: 'alchemy_selectbox'} %>
|
11
16
|
<% else %>
|
12
17
|
<%= f.input attribute[:name], resource_attribute_field_options(attribute) %>
|
13
18
|
<% end %>
|
data/config/alchemy/config.yml
CHANGED
data/lib/alchemy/engine.rb
CHANGED
@@ -37,7 +37,7 @@ module Alchemy
|
|
37
37
|
end
|
38
38
|
end
|
39
39
|
|
40
|
-
|
40
|
+
config.after_initialize do
|
41
41
|
if Alchemy.user_class
|
42
42
|
ActiveSupport.on_load(:active_record) do
|
43
43
|
Alchemy.user_class.model_stamper
|
@@ -45,5 +45,16 @@ module Alchemy
|
|
45
45
|
end
|
46
46
|
end
|
47
47
|
end
|
48
|
+
|
49
|
+
initializer "alchemy.webp-mime_type" do
|
50
|
+
# Rails does not know anything about webp even in 2022
|
51
|
+
unless Mime::Type.lookup_by_extension(:webp)
|
52
|
+
Mime::Type.register("image/webp", :webp)
|
53
|
+
end
|
54
|
+
# Dragonfly uses Rack to read the mime type and guess what
|
55
|
+
unless Rack::Mime::MIME_TYPES[".webp"]
|
56
|
+
Rack::Mime::MIME_TYPES[".webp"] = "image/webp"
|
57
|
+
end
|
58
|
+
end
|
48
59
|
end
|
49
60
|
end
|
data/lib/alchemy/essence.rb
CHANGED
@@ -3,18 +3,6 @@
|
|
3
3
|
require "active_record"
|
4
4
|
|
5
5
|
module Alchemy #:nodoc:
|
6
|
-
# A bogus association that skips eager loading for essences not having an ingredient association
|
7
|
-
class IngredientAssociation < ActiveRecord::Associations::BelongsToAssociation
|
8
|
-
# Skip eager loading if called by Rails' preloader
|
9
|
-
def klass
|
10
|
-
if caller.any? { |line| line =~ /preloader\.rb/ }
|
11
|
-
nil
|
12
|
-
else
|
13
|
-
super
|
14
|
-
end
|
15
|
-
end
|
16
|
-
end
|
17
|
-
|
18
6
|
module Essence #:nodoc:
|
19
7
|
def self.included(base)
|
20
8
|
base.extend(ClassMethods)
|
@@ -43,8 +31,6 @@ module Alchemy #:nodoc:
|
|
43
31
|
ingredient_column: "body",
|
44
32
|
}.update(options)
|
45
33
|
|
46
|
-
@_classes_with_ingredient_association ||= []
|
47
|
-
|
48
34
|
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
49
35
|
attr_writer :validation_errors
|
50
36
|
include Alchemy::Essence::InstanceMethods
|
@@ -87,18 +73,6 @@ module Alchemy #:nodoc:
|
|
87
73
|
alias_method :#{configuration[:ingredient_column]}, :ingredient_association
|
88
74
|
alias_method :#{configuration[:ingredient_column]}=, :ingredient_association=
|
89
75
|
RUBY
|
90
|
-
|
91
|
-
@_classes_with_ingredient_association << self
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
# Overwrite ActiveRecords method to return a bogus association class that skips eager loading
|
96
|
-
# for essence classes that do not have an ingredient association
|
97
|
-
def _reflect_on_association(name)
|
98
|
-
if name == :ingredient_association && !in?(@_classes_with_ingredient_association)
|
99
|
-
OpenStruct.new(association_class: Alchemy::IngredientAssociation)
|
100
|
-
else
|
101
|
-
super
|
102
76
|
end
|
103
77
|
end
|
104
78
|
|
data/lib/alchemy/resource.rb
CHANGED
@@ -169,10 +169,25 @@ module Alchemy
|
|
169
169
|
name: col.name,
|
170
170
|
type: resource_column_type(col),
|
171
171
|
relation: resource_relation(col.name),
|
172
|
-
|
172
|
+
enum: enum_values_collection_for_select(col.name),
|
173
|
+
}.delete_if { |_k, v| v.blank? }
|
173
174
|
end.compact
|
174
175
|
end
|
175
176
|
|
177
|
+
def enum_values_collection_for_select(column_name)
|
178
|
+
enum = model.defined_enums[column_name]
|
179
|
+
return if enum.blank?
|
180
|
+
|
181
|
+
enum.keys.map do |key|
|
182
|
+
[
|
183
|
+
::I18n.t(key, scope: [
|
184
|
+
:activerecord, :attributes, model.model_name.i18n_key, "#{column_name}_values"
|
185
|
+
], default: key.humanize),
|
186
|
+
key,
|
187
|
+
]
|
188
|
+
end
|
189
|
+
end
|
190
|
+
|
176
191
|
def sorted_attributes
|
177
192
|
@_sorted_attributes ||= attributes.
|
178
193
|
sort_by { |attr| attr[:name] == "name" ? 0 : 1 }.
|
@@ -7,18 +7,6 @@ RSpec.shared_examples_for "an essence" do
|
|
7
7
|
let(:content) { Alchemy::Content.new(name: "foo") }
|
8
8
|
let(:content_definition) { { "name" => "foo" } }
|
9
9
|
|
10
|
-
describe "eager loading" do
|
11
|
-
before do
|
12
|
-
2.times { described_class.create! }
|
13
|
-
end
|
14
|
-
|
15
|
-
it "does not throw error if eager loaded" do
|
16
|
-
expect {
|
17
|
-
described_class.all.includes(:ingredient_association).to_a
|
18
|
-
}.to_not raise_error
|
19
|
-
end
|
20
|
-
end
|
21
|
-
|
22
10
|
it "touches the element after save" do
|
23
11
|
element = FactoryBot.create(:alchemy_element)
|
24
12
|
content = FactoryBot.create(:alchemy_content, element: element, essence: essence, essence_type: essence.class.name)
|
@@ -16,7 +16,7 @@ module Alchemy::Upgrader::Tasks
|
|
16
16
|
# eager load all elements that have ingredients defined but no ingredient records yet.
|
17
17
|
all_elements = Alchemy::Element
|
18
18
|
.named(elements_with_ingredients.map { |d| d[:name] })
|
19
|
-
.includes(contents:
|
19
|
+
.includes(contents: :essence)
|
20
20
|
.left_outer_joins(:ingredients).where(alchemy_ingredients: { id: nil })
|
21
21
|
.to_a
|
22
22
|
elements_with_ingredients.map do |element_definition|
|
data/lib/alchemy/version.rb
CHANGED
data/package/src/image_loader.js
CHANGED
@@ -40,9 +40,9 @@ export default class ImageLoader {
|
|
40
40
|
}
|
41
41
|
|
42
42
|
onError(evt) {
|
43
|
-
const message = `Could not load ${this.image.src}`
|
43
|
+
const message = `Could not load "${this.image.src}"`
|
44
44
|
this.removeSpinner()
|
45
|
-
this.parent.innerHTML = `<span class="icon fas fa-exclamation-triangle" title="${message}" />`
|
45
|
+
this.parent.innerHTML = `<span class="icon error fas fa-exclamation-triangle" title="${message}" />`
|
46
46
|
console.error(message, evt)
|
47
47
|
this.unbind()
|
48
48
|
}
|
@@ -5,7 +5,6 @@ import ImageLoader from "./image_loader"
|
|
5
5
|
|
6
6
|
const UPDATE_DELAY = 125
|
7
7
|
const IMAGE_PLACEHOLDER = '<i class="icon far fa-image fa-fw"></i>'
|
8
|
-
const EMPTY_IMAGE = '<img src="" class="img_paddingtop" />'
|
9
8
|
const THUMBNAIL_SIZE = "160x120"
|
10
9
|
|
11
10
|
class PictureEditor {
|
@@ -62,7 +61,7 @@ class PictureEditor {
|
|
62
61
|
this.image.removeAttribute("alt")
|
63
62
|
this.image.removeAttribute("src")
|
64
63
|
this.imageLoader.load(true)
|
65
|
-
get(
|
64
|
+
get(Alchemy.routes.url_admin_picture_path(this.pictureId), {
|
66
65
|
crop: this.imageCropperEnabled,
|
67
66
|
crop_from: this.cropFrom,
|
68
67
|
crop_size: this.cropSize,
|
@@ -83,9 +82,10 @@ class PictureEditor {
|
|
83
82
|
ensureImage() {
|
84
83
|
if (this.image) return
|
85
84
|
|
86
|
-
|
87
|
-
this.
|
88
|
-
this.
|
85
|
+
const img = new Image()
|
86
|
+
this.thumbnailBackground.replaceChildren(img)
|
87
|
+
this.image = img
|
88
|
+
this.imageLoader = new ImageLoader(img)
|
89
89
|
}
|
90
90
|
|
91
91
|
removeImage() {
|
data/package.json
CHANGED
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: 6.0.0
|
4
|
+
version: 6.0.0
|
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: 2022-
|
16
|
+
date: 2022-04-11 00:00:00.000000000 Z
|
17
17
|
dependencies:
|
18
18
|
- !ruby/object:Gem::Dependency
|
19
19
|
name: actionmailer
|
@@ -24,7 +24,7 @@ dependencies:
|
|
24
24
|
version: '6.0'
|
25
25
|
- - "<"
|
26
26
|
- !ruby/object:Gem::Version
|
27
|
-
version: '
|
27
|
+
version: '7.1'
|
28
28
|
type: :runtime
|
29
29
|
prerelease: false
|
30
30
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -34,7 +34,7 @@ dependencies:
|
|
34
34
|
version: '6.0'
|
35
35
|
- - "<"
|
36
36
|
- !ruby/object:Gem::Version
|
37
|
-
version: '
|
37
|
+
version: '7.1'
|
38
38
|
- !ruby/object:Gem::Dependency
|
39
39
|
name: actionpack
|
40
40
|
requirement: !ruby/object:Gem::Requirement
|
@@ -44,7 +44,7 @@ dependencies:
|
|
44
44
|
version: '6.0'
|
45
45
|
- - "<"
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version: '
|
47
|
+
version: '7.1'
|
48
48
|
type: :runtime
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -54,7 +54,7 @@ dependencies:
|
|
54
54
|
version: '6.0'
|
55
55
|
- - "<"
|
56
56
|
- !ruby/object:Gem::Version
|
57
|
-
version: '
|
57
|
+
version: '7.1'
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: actionview
|
60
60
|
requirement: !ruby/object:Gem::Requirement
|
@@ -64,7 +64,7 @@ dependencies:
|
|
64
64
|
version: '6.0'
|
65
65
|
- - "<"
|
66
66
|
- !ruby/object:Gem::Version
|
67
|
-
version: '
|
67
|
+
version: '7.1'
|
68
68
|
type: :runtime
|
69
69
|
prerelease: false
|
70
70
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -74,7 +74,7 @@ dependencies:
|
|
74
74
|
version: '6.0'
|
75
75
|
- - "<"
|
76
76
|
- !ruby/object:Gem::Version
|
77
|
-
version: '
|
77
|
+
version: '7.1'
|
78
78
|
- !ruby/object:Gem::Dependency
|
79
79
|
name: activejob
|
80
80
|
requirement: !ruby/object:Gem::Requirement
|
@@ -84,7 +84,7 @@ dependencies:
|
|
84
84
|
version: '6.0'
|
85
85
|
- - "<"
|
86
86
|
- !ruby/object:Gem::Version
|
87
|
-
version: '
|
87
|
+
version: '7.1'
|
88
88
|
type: :runtime
|
89
89
|
prerelease: false
|
90
90
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -94,7 +94,7 @@ dependencies:
|
|
94
94
|
version: '6.0'
|
95
95
|
- - "<"
|
96
96
|
- !ruby/object:Gem::Version
|
97
|
-
version: '
|
97
|
+
version: '7.1'
|
98
98
|
- !ruby/object:Gem::Dependency
|
99
99
|
name: activemodel
|
100
100
|
requirement: !ruby/object:Gem::Requirement
|
@@ -104,7 +104,7 @@ dependencies:
|
|
104
104
|
version: '6.0'
|
105
105
|
- - "<"
|
106
106
|
- !ruby/object:Gem::Version
|
107
|
-
version: '
|
107
|
+
version: '7.1'
|
108
108
|
type: :runtime
|
109
109
|
prerelease: false
|
110
110
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -114,7 +114,7 @@ dependencies:
|
|
114
114
|
version: '6.0'
|
115
115
|
- - "<"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version: '
|
117
|
+
version: '7.1'
|
118
118
|
- !ruby/object:Gem::Dependency
|
119
119
|
name: activerecord
|
120
120
|
requirement: !ruby/object:Gem::Requirement
|
@@ -124,7 +124,7 @@ dependencies:
|
|
124
124
|
version: '6.0'
|
125
125
|
- - "<"
|
126
126
|
- !ruby/object:Gem::Version
|
127
|
-
version: '
|
127
|
+
version: '7.1'
|
128
128
|
type: :runtime
|
129
129
|
prerelease: false
|
130
130
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -134,7 +134,7 @@ dependencies:
|
|
134
134
|
version: '6.0'
|
135
135
|
- - "<"
|
136
136
|
- !ruby/object:Gem::Version
|
137
|
-
version: '
|
137
|
+
version: '7.1'
|
138
138
|
- !ruby/object:Gem::Dependency
|
139
139
|
name: activesupport
|
140
140
|
requirement: !ruby/object:Gem::Requirement
|
@@ -144,7 +144,7 @@ dependencies:
|
|
144
144
|
version: '6.0'
|
145
145
|
- - "<"
|
146
146
|
- !ruby/object:Gem::Version
|
147
|
-
version: '
|
147
|
+
version: '7.1'
|
148
148
|
type: :runtime
|
149
149
|
prerelease: false
|
150
150
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -154,7 +154,7 @@ dependencies:
|
|
154
154
|
version: '6.0'
|
155
155
|
- - "<"
|
156
156
|
- !ruby/object:Gem::Version
|
157
|
-
version: '
|
157
|
+
version: '7.1'
|
158
158
|
- !ruby/object:Gem::Dependency
|
159
159
|
name: railties
|
160
160
|
requirement: !ruby/object:Gem::Requirement
|
@@ -164,7 +164,7 @@ dependencies:
|
|
164
164
|
version: '6.0'
|
165
165
|
- - "<"
|
166
166
|
- !ruby/object:Gem::Version
|
167
|
-
version: '
|
167
|
+
version: '7.1'
|
168
168
|
type: :runtime
|
169
169
|
prerelease: false
|
170
170
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -174,7 +174,7 @@ dependencies:
|
|
174
174
|
version: '6.0'
|
175
175
|
- - "<"
|
176
176
|
- !ruby/object:Gem::Version
|
177
|
-
version: '
|
177
|
+
version: '7.1'
|
178
178
|
- !ruby/object:Gem::Dependency
|
179
179
|
name: active_model_serializers
|
180
180
|
requirement: !ruby/object:Gem::Requirement
|
@@ -408,9 +408,9 @@ dependencies:
|
|
408
408
|
- - ">="
|
409
409
|
- !ruby/object:Gem::Version
|
410
410
|
version: '1.8'
|
411
|
-
- - "
|
411
|
+
- - "<"
|
412
412
|
- !ruby/object:Gem::Version
|
413
|
-
version:
|
413
|
+
version: '4.0'
|
414
414
|
type: :runtime
|
415
415
|
prerelease: false
|
416
416
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -418,9 +418,9 @@ dependencies:
|
|
418
418
|
- - ">="
|
419
419
|
- !ruby/object:Gem::Version
|
420
420
|
version: '1.8'
|
421
|
-
- - "
|
421
|
+
- - "<"
|
422
422
|
- !ruby/object:Gem::Version
|
423
|
-
version:
|
423
|
+
version: '4.0'
|
424
424
|
- !ruby/object:Gem::Dependency
|
425
425
|
name: request_store
|
426
426
|
requirement: !ruby/object:Gem::Requirement
|
@@ -1515,9 +1515,9 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
1515
1515
|
version: 2.5.0
|
1516
1516
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
1517
1517
|
requirements:
|
1518
|
-
- - "
|
1518
|
+
- - ">="
|
1519
1519
|
- !ruby/object:Gem::Version
|
1520
|
-
version:
|
1520
|
+
version: '0'
|
1521
1521
|
requirements:
|
1522
1522
|
- ImageMagick (libmagick), v6.6 or greater.
|
1523
1523
|
rubygems_version: 3.1.6
|