alchemy_cms 2.1.5 → 2.1.6
Sign up to get free protection for your applications and to get access to all the features.
- data/.travis.yml +1 -0
- data/app/assets/javascripts/alchemy/alchemy.base.js +1 -1
- data/app/assets/javascripts/alchemy/alchemy.buttons.js +5 -5
- data/app/assets/javascripts/alchemy/alchemy.dragndrop.js +1 -1
- data/app/assets/javascripts/alchemy/alchemy.element_editor_selector.js +2 -2
- data/app/assets/javascripts/alchemy/alchemy.windows.js +1 -1
- data/app/assets/stylesheets/alchemy/base.css.scss +22 -13
- data/app/assets/stylesheets/alchemy/buttons.css.scss +14 -14
- data/app/assets/stylesheets/alchemy/elements.css.scss +79 -46
- data/app/controllers/alchemy/admin/elements_controller.rb +1 -1
- data/app/helpers/alchemy/admin/base_helper.rb +4 -3
- data/app/helpers/alchemy/admin/elements_helper.rb +2 -2
- data/app/helpers/alchemy/admin/essences_helper.rb +7 -14
- data/app/models/alchemy/element.rb +13 -10
- data/app/models/alchemy/message.rb +2 -2
- data/app/models/alchemy/page.rb +1 -1
- data/app/views/alchemy/admin/clipboard/index.html.erb +4 -3
- data/app/views/alchemy/admin/clipboard/insert.js.erb +2 -2
- data/app/views/alchemy/admin/contents/create.js.erb +48 -13
- data/app/views/alchemy/admin/contents/new.html.erb +1 -1
- data/app/views/alchemy/admin/elements/_element.html.erb +1 -1
- data/app/views/alchemy/admin/elements/_elements_select.html.erb +1 -1
- data/app/views/alchemy/admin/elements/create.js.erb +9 -5
- data/app/views/alchemy/admin/elements/fold.js.erb +9 -7
- data/app/views/alchemy/admin/elements/trash.js.erb +13 -11
- data/app/views/alchemy/admin/elements/update.js.erb +10 -7
- data/app/views/alchemy/admin/essence_files/edit.html.erb +1 -1
- data/app/views/alchemy/admin/essence_pictures/edit.html.erb +3 -3
- data/app/views/alchemy/admin/pages/_contactform_links.html.erb +1 -1
- data/app/views/alchemy/admin/pages/_create_language_form.html.erb +1 -1
- data/app/views/alchemy/admin/pages/_external_link.html.erb +1 -1
- data/app/views/alchemy/admin/pages/_file_link.html.erb +2 -2
- data/app/views/alchemy/admin/pages/_internal_link.html.erb +1 -1
- data/app/views/alchemy/admin/pages/_new_page_form.html.erb +1 -1
- data/app/views/alchemy/admin/partials/_language_tree_select.html.erb +1 -1
- data/app/views/alchemy/admin/partials/_upload_form.html.erb +2 -2
- data/app/views/alchemy/admin/resources/destroy.js.erb +1 -1
- data/app/views/alchemy/admin/users/_table.html.erb +3 -3
- data/app/views/alchemy/elements/_contactform_editor.html.erb +1 -4
- data/app/views/alchemy/essences/_essence_date_editor.html.erb +2 -3
- data/app/views/alchemy/essences/_essence_date_view.html.erb +4 -6
- data/app/views/alchemy/essences/_essence_text_editor.html.erb +2 -2
- data/app/views/layouts/alchemy/admin.html.erb +1 -1
- data/config/alchemy/elements.yml +2 -0
- data/config/locales/alchemy.de.yml +8 -3
- data/config/locales/alchemy.en.yml +4 -3
- data/lib/alchemy/capistrano.rb +6 -6
- data/lib/alchemy/essence.rb +9 -4
- data/lib/alchemy/version.rb +1 -1
- data/spec/helpers/admin/elements_helper_spec.rb +1 -1
- data/spec/integration/security_spec.rb +2 -2
- data/spec/models/page_spec.rb +28 -1
- data/spec/support/alchemy/specs_helpers.rb +1 -1
- metadata +33 -34
- data/app/views/alchemy/admin/elements/destroy.js.erb +0 -6
@@ -1,7 +1,4 @@
|
|
1
1
|
<%= render_essence_editor_by_name(element, 'mail_from') %>
|
2
2
|
<%= render_essence_editor_by_name(element, 'mail_to') %>
|
3
3
|
<%= render_essence_editor_by_name(element, 'subject') %>
|
4
|
-
|
5
|
-
<label><%= t('alchemy.contactform.labels.success_page') %></label>
|
6
|
-
<p><%= page_selector(element, 'success_page') %></p>
|
7
|
-
</div>
|
4
|
+
<%= page_selector(element, 'success_page', :page_attribute => :urlname) %>
|
@@ -1,10 +1,9 @@
|
|
1
|
-
<div class="content_editor" id="<%= content_dom_id(content) %>">
|
1
|
+
<div class="content_editor essence_date" id="<%= content_dom_id(content) %>">
|
2
2
|
<label><%= render_content_name(content) %></label>
|
3
3
|
<%= alchemy_datepicker(
|
4
4
|
content.essence, :date, {
|
5
5
|
:name => content.form_field_name,
|
6
|
-
:id => content.form_field_id
|
7
|
-
:style => 'width: 140px'
|
6
|
+
:id => content.form_field_id
|
8
7
|
}
|
9
8
|
) %>
|
10
9
|
<label for="<%= content.form_field_id %>" style="cursor: pointer; display: inline; display: inline-block; position: relative; top: 3px; margin: 0;">
|
@@ -1,7 +1,5 @@
|
|
1
|
-
<%- if content.essence.date.
|
2
|
-
<%= l(
|
1
|
+
<%- if content.essence.date.present? -%>
|
2
|
+
<%= l(content.essence.date, :format => (options[:date_format])) -%>
|
3
3
|
<%- elsif options[:date_format] == :rfc822 -%>
|
4
|
-
<%= content.essence.date.to_s(:rfc822)
|
5
|
-
<%-
|
6
|
-
<%= l(content.essence.date, :format => (options[:date_format])) %>
|
7
|
-
<%- end -%>
|
4
|
+
<%= content.essence.date.to_s(:rfc822) -%>
|
5
|
+
<%- end -%>
|
@@ -1,5 +1,5 @@
|
|
1
1
|
<%- cache(content) do -%>
|
2
|
-
<div class="content_editor" id="<%= content_dom_id(content) %>">
|
2
|
+
<div class="content_editor<%= options[:display_inline].to_s == 'true' ? ' display_inline' : '' %>" id="<%= content_dom_id(content) %>">
|
3
3
|
|
4
4
|
<%- if content.settings[:display_as] == "checkbox" -%>
|
5
5
|
|
@@ -37,7 +37,7 @@
|
|
37
37
|
content.form_field_name,
|
38
38
|
options_method,
|
39
39
|
{
|
40
|
-
:class => "essence_editor_select"
|
40
|
+
:class => "alchemy_selectbox essence_editor_select"
|
41
41
|
}
|
42
42
|
) %>
|
43
43
|
<%- end -%>
|
@@ -66,7 +66,7 @@
|
|
66
66
|
Alchemy.resizeFrame();
|
67
67
|
Alchemy.Tooltips();
|
68
68
|
if (typeof(jQuery().sb) === 'function') {
|
69
|
-
Alchemy.SelectBox('body#alchemy select');
|
69
|
+
Alchemy.SelectBox('body#alchemy select.alchemy_selectbox');
|
70
70
|
}
|
71
71
|
Alchemy.Datepicker();
|
72
72
|
if ($('#flash_notices').length > 0) {
|
data/config/alchemy/elements.yml
CHANGED
@@ -71,8 +71,13 @@ de:
|
|
71
71
|
image_mosaic:
|
72
72
|
caption: "Mosaik Bildunterschrift"
|
73
73
|
file: Datei
|
74
|
-
|
74
|
+
contactform:
|
75
|
+
success_page: 'Folgeseite'
|
76
|
+
|
75
77
|
content_validations:
|
78
|
+
contactform:
|
79
|
+
success_page:
|
80
|
+
blank: 'Bitte wählen Sie eine Folgeseite'
|
76
81
|
errors:
|
77
82
|
blank: '%{field} darf nicht leer sein.'
|
78
83
|
wrong_format: '%{field} hat das falsche Format.'
|
@@ -108,7 +113,6 @@ de:
|
|
108
113
|
message: 'Nachricht'
|
109
114
|
send: 'Nachricht absenden!'
|
110
115
|
mandatory_fields: 'Pflichtfelder. Bitte füllen Sie diese Felder aus. Vielen Dank!'
|
111
|
-
success_page: 'Folgeseite'
|
112
116
|
# Translations for the contactform validations.
|
113
117
|
# Validations are set in the config/alchemy/config.yml mailer section.
|
114
118
|
validations:
|
@@ -196,6 +200,7 @@ de:
|
|
196
200
|
"Do you really want to delete this content?": "Wollen Sie diesen Inhalt wirklich löschen?"
|
197
201
|
"Drag an element over to the element window to restore it": "Ziehen Sie ein Element mit der Maus in das Elemente Fenster, um es wieder herzustellen."
|
198
202
|
"Edit Picturemask": "Bildmaske bearbeiten"
|
203
|
+
"Elements": "Elemente"
|
199
204
|
"Element trashed": "Das Element wurde in den Papierkorb gelegt"
|
200
205
|
"Error with the Flash® Uploader!": "Fehler mit dem Flash® Uploader!"
|
201
206
|
"Excerpt": "Auszug"
|
@@ -247,7 +252,6 @@ de:
|
|
247
252
|
"Picture deleted successfully": "%{name} wurde gelöscht"
|
248
253
|
"Picture cache flushed": "Bildercache wurde geleert"
|
249
254
|
"Please Signup": "Um Ihre Homepage bearbeiten zu können, müssen Sie als erstes einen Admin Benutzer einrichten."
|
250
|
-
"Please check contents below.": "Bitte überprüfen Sie die markierten Felder."
|
251
255
|
"Please choose": "Bitte wählen"
|
252
256
|
"Please choose a page layout.": "Bitte wählen Sie einen Seitentyp."
|
253
257
|
choose_element: "Bitte wählen Sie ein Element."
|
@@ -337,6 +341,7 @@ de:
|
|
337
341
|
contactform_body: "Nachrichten Vorlage"
|
338
342
|
content_essence_not_found: "Essenz wurde nicht gefunden"
|
339
343
|
content_not_found: "Das Feld für diesen Inhalt ist nicht vorhanden."
|
344
|
+
content_validations_headline: "Bitte überprüfen Sie die markierten Felder."
|
340
345
|
copy: "kopieren"
|
341
346
|
copy_element: "Element kopieren"
|
342
347
|
copy_page: "Seite kopieren"
|
@@ -68,7 +68,9 @@ en:
|
|
68
68
|
news_headline: "News Headline"
|
69
69
|
image_mosaic:
|
70
70
|
caption: "Mosaic Caption"
|
71
|
-
|
71
|
+
contactform:
|
72
|
+
success_page: 'Followup page'
|
73
|
+
|
72
74
|
# == Translations for the build in full text search.
|
73
75
|
search_result_page:
|
74
76
|
no_results: 'No results found'
|
@@ -94,7 +96,6 @@ en:
|
|
94
96
|
message: 'Message'
|
95
97
|
send: 'Send Message'
|
96
98
|
mandatory_fields: 'Mandatory fields.'
|
97
|
-
success_page: 'Followup page'
|
98
99
|
# Translations for the contactform validations.
|
99
100
|
# Validations are set in the config/alchemy/config.yml mailer section.
|
100
101
|
validations:
|
@@ -170,7 +171,6 @@ en:
|
|
170
171
|
"Page saved": "Page: '%{name}' saved."
|
171
172
|
"Password": "Password"
|
172
173
|
"Paste from clipboard": "Paste from clipboard"
|
173
|
-
"Please check contents below.": "Please check marked fields below"
|
174
174
|
"Successfully added content": "Succesfully added %{content}"
|
175
175
|
"Successfully deleted content": "Succesfully deleted %{content}"
|
176
176
|
"User created": "User created"
|
@@ -196,6 +196,7 @@ en:
|
|
196
196
|
contactform_body: "Message Template"
|
197
197
|
content_essence_not_found: "Content essence not found"
|
198
198
|
content_not_found: "Field for content not present."
|
199
|
+
content_validations_headline: "Please check marked fields below"
|
199
200
|
copy_element: "Copy this element"
|
200
201
|
copy_language_tree_heading: "Copy page tree"
|
201
202
|
copy_page: "Copy page"
|
data/lib/alchemy/capistrano.rb
CHANGED
@@ -6,7 +6,7 @@ require "alchemy/mount_point"
|
|
6
6
|
Capistrano::Configuration.instance(:must_exist).load do
|
7
7
|
|
8
8
|
after "deploy:setup", "alchemy:shared_folders:create"
|
9
|
-
after "deploy:
|
9
|
+
after "deploy:finalize_update", "alchemy:shared_folders:symlink"
|
10
10
|
before "deploy:start", "alchemy:db:seed"
|
11
11
|
|
12
12
|
namespace :alchemy do
|
@@ -27,11 +27,11 @@ Capistrano::Configuration.instance(:must_exist).load do
|
|
27
27
|
# Call after deploy:symlink like +after "deploy:symlink", "alchemy:symlink_folders"+ in your +deploy.rb+.
|
28
28
|
desc "Sets the symlinks for uploads, picture cache and ferret index folder. Call after deploy:symlink"
|
29
29
|
task :symlink, :roles => :app do
|
30
|
-
run "rm -rf #{
|
31
|
-
run "ln -nfs #{shared_path}/uploads #{
|
32
|
-
run "ln -nfs #{shared_path}/cache/* #{
|
33
|
-
run "rm -rf #{
|
34
|
-
run "ln -nfs #{shared_path}/index #{
|
30
|
+
run "rm -rf #{release_path}/uploads"
|
31
|
+
run "ln -nfs #{shared_path}/uploads #{release_path}/"
|
32
|
+
run "ln -nfs #{shared_path}/cache/* #{release_path}/public/"
|
33
|
+
run "rm -rf #{release_path}/index"
|
34
|
+
run "ln -nfs #{shared_path}/index #{release_path}/"
|
35
35
|
end
|
36
36
|
|
37
37
|
end
|
data/lib/alchemy/essence.rb
CHANGED
@@ -26,6 +26,7 @@ module Alchemy #:nodoc:
|
|
26
26
|
validate_column = configuration[:validate_column].blank? ? ingredient_column : configuration[:validate_column]
|
27
27
|
|
28
28
|
class_eval <<-EOV
|
29
|
+
attr_accessor :validation_errors
|
29
30
|
include Alchemy::Essence::InstanceMethods
|
30
31
|
stampable
|
31
32
|
validate :essence_validations, :on => :update
|
@@ -94,10 +95,11 @@ module Alchemy #:nodoc:
|
|
94
95
|
# validate_format_with: '^[a-z0-9]+([\-\.]{1}[a-z0-9]+)*\.[a-z]{2,5}(:[0-9]{1,5})?(\/.*)?$'
|
95
96
|
#
|
96
97
|
def essence_validations
|
98
|
+
self.validation_errors ||= []
|
97
99
|
return true if description.blank? || description['validate'].blank?
|
98
100
|
description['validate'].each do |validation|
|
99
101
|
if validation == 'presence' && ingredient.blank?
|
100
|
-
|
102
|
+
self.validation_errors << :blank
|
101
103
|
elsif validation == 'format'
|
102
104
|
if description['validate_format_as'].blank? && !description['validate_format_with'].blank?
|
103
105
|
matcher = Regexp.new(description['validate_format_with'])
|
@@ -114,14 +116,17 @@ module Alchemy #:nodoc:
|
|
114
116
|
raise 'No validation format matcher given'
|
115
117
|
end
|
116
118
|
if ingredient.match(matcher).nil?
|
117
|
-
|
119
|
+
self.validation_errors << :invalid
|
118
120
|
end
|
119
121
|
elsif validation == 'uniqueness' && !acts_as_essence_class.send("find_by_#{ingredient_column}", ingredient).blank?
|
120
|
-
|
122
|
+
self.validation_errors << :taken
|
121
123
|
end
|
122
124
|
end
|
125
|
+
self.validation_errors.each do |validation_error|
|
126
|
+
self.errors.add(self.ingredient_column, validation_error)
|
127
|
+
end
|
123
128
|
end
|
124
|
-
|
129
|
+
|
125
130
|
# Essence description from config/elements.yml
|
126
131
|
def description
|
127
132
|
return {} if element.nil? or element.content_descriptions.nil?
|
data/lib/alchemy/version.rb
CHANGED
@@ -27,7 +27,7 @@ describe Alchemy::Admin::ElementsHelper do
|
|
27
27
|
end
|
28
28
|
|
29
29
|
it "should return string of elements grouped by cell for select_tag helper" do
|
30
|
-
helper.grouped_elements_for_select(@elements).should == helper.grouped_options_for_select({"
|
30
|
+
helper.grouped_elements_for_select(@elements).should == helper.grouped_options_for_select({"Foo cell"=>[["1", "1#foo_cell"], ["2", "2#foo_cell"]]})
|
31
31
|
end
|
32
32
|
|
33
33
|
context "with empty elements array" do
|
@@ -12,7 +12,7 @@ describe "Security: " do
|
|
12
12
|
|
13
13
|
it "render the signup view" do
|
14
14
|
visit '/alchemy/'
|
15
|
-
within('#alchemy_greeting') { page.should have_content('
|
15
|
+
within('#alchemy_greeting') { page.should have_content('signup') }
|
16
16
|
end
|
17
17
|
end
|
18
18
|
|
@@ -39,7 +39,7 @@ describe "Security: " do
|
|
39
39
|
visit '/alchemy/admin/login'
|
40
40
|
fill_in('alchemy_user_session_login', :with => 'jdoe')
|
41
41
|
fill_in('alchemy_user_session_password', :with => 's3cr3t')
|
42
|
-
click_on('
|
42
|
+
click_on('Login')
|
43
43
|
end
|
44
44
|
|
45
45
|
it "should be redirected to dashboard" do
|
data/spec/models/page_spec.rb
CHANGED
@@ -107,7 +107,12 @@ describe Alchemy::Page do
|
|
107
107
|
|
108
108
|
describe '#create' do
|
109
109
|
|
110
|
-
context "
|
110
|
+
context "before/after filter" do
|
111
|
+
|
112
|
+
it "should automatically set the title from its name" do
|
113
|
+
page = Factory(:page, :name => 'My Testpage', :language => @language, :parent_id => @language_root.id)
|
114
|
+
page.title.should == 'My Testpage'
|
115
|
+
end
|
111
116
|
|
112
117
|
it "should get a webfriendly urlname" do
|
113
118
|
page = Factory(:page, :name => 'klingon$&stößel ', :language => @language, :parent_id => @language_root.id)
|
@@ -133,6 +138,28 @@ describe Alchemy::Page do
|
|
133
138
|
|
134
139
|
end
|
135
140
|
|
141
|
+
describe '#update' do
|
142
|
+
|
143
|
+
context "before/after filter" do
|
144
|
+
|
145
|
+
it "should not set the title automatically if the name changed but title is not blank" do
|
146
|
+
page = Factory(:page, :name => 'My Testpage', :language => @language, :parent_id => @language_root.id)
|
147
|
+
page.name = "My Renaming Test"
|
148
|
+
page.save; page.reload
|
149
|
+
page.title.should == "My Testpage"
|
150
|
+
end
|
151
|
+
|
152
|
+
it "should not automatically set the title if it changed its value" do
|
153
|
+
page = Factory(:page, :name => 'My Testpage', :language => @language, :parent_id => @language_root.id)
|
154
|
+
page.title = "I like SEO"
|
155
|
+
page.save; page.reload
|
156
|
+
page.title.should == "I like SEO"
|
157
|
+
end
|
158
|
+
|
159
|
+
end
|
160
|
+
|
161
|
+
end
|
162
|
+
|
136
163
|
context "with children" do
|
137
164
|
|
138
165
|
before(:each) do
|
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: 2.1.
|
4
|
+
version: 2.1.6
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -11,11 +11,11 @@ authors:
|
|
11
11
|
autorequire:
|
12
12
|
bindir: bin
|
13
13
|
cert_chain: []
|
14
|
-
date: 2012-02-
|
14
|
+
date: 2012-02-22 00:00:00.000000000 Z
|
15
15
|
dependencies:
|
16
16
|
- !ruby/object:Gem::Dependency
|
17
17
|
name: rails
|
18
|
-
requirement: &
|
18
|
+
requirement: &70206693498780 !ruby/object:Gem::Requirement
|
19
19
|
none: false
|
20
20
|
requirements:
|
21
21
|
- - ~>
|
@@ -23,10 +23,10 @@ dependencies:
|
|
23
23
|
version: 3.1.3
|
24
24
|
type: :runtime
|
25
25
|
prerelease: false
|
26
|
-
version_requirements: *
|
26
|
+
version_requirements: *70206693498780
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: authlogic
|
29
|
-
requirement: &
|
29
|
+
requirement: &70206693492700 !ruby/object:Gem::Requirement
|
30
30
|
none: false
|
31
31
|
requirements:
|
32
32
|
- - ! '>='
|
@@ -34,10 +34,10 @@ dependencies:
|
|
34
34
|
version: '0'
|
35
35
|
type: :runtime
|
36
36
|
prerelease: false
|
37
|
-
version_requirements: *
|
37
|
+
version_requirements: *70206693492700
|
38
38
|
- !ruby/object:Gem::Dependency
|
39
39
|
name: awesome_nested_set
|
40
|
-
requirement: &
|
40
|
+
requirement: &70206693490340 !ruby/object:Gem::Requirement
|
41
41
|
none: false
|
42
42
|
requirements:
|
43
43
|
- - ~>
|
@@ -45,10 +45,10 @@ dependencies:
|
|
45
45
|
version: '2.0'
|
46
46
|
type: :runtime
|
47
47
|
prerelease: false
|
48
|
-
version_requirements: *
|
48
|
+
version_requirements: *70206693490340
|
49
49
|
- !ruby/object:Gem::Dependency
|
50
50
|
name: declarative_authorization
|
51
|
-
requirement: &
|
51
|
+
requirement: &70206693488500 !ruby/object:Gem::Requirement
|
52
52
|
none: false
|
53
53
|
requirements:
|
54
54
|
- - ~>
|
@@ -56,10 +56,10 @@ dependencies:
|
|
56
56
|
version: 0.5.4
|
57
57
|
type: :runtime
|
58
58
|
prerelease: false
|
59
|
-
version_requirements: *
|
59
|
+
version_requirements: *70206693488500
|
60
60
|
- !ruby/object:Gem::Dependency
|
61
61
|
name: tvdeyen-fleximage
|
62
|
-
requirement: &
|
62
|
+
requirement: &70206693266780 !ruby/object:Gem::Requirement
|
63
63
|
none: false
|
64
64
|
requirements:
|
65
65
|
- - ~>
|
@@ -67,10 +67,10 @@ dependencies:
|
|
67
67
|
version: 1.0.9
|
68
68
|
type: :runtime
|
69
69
|
prerelease: false
|
70
|
-
version_requirements: *
|
70
|
+
version_requirements: *70206693266780
|
71
71
|
- !ruby/object:Gem::Dependency
|
72
72
|
name: will_paginate
|
73
|
-
requirement: &
|
73
|
+
requirement: &70206693264480 !ruby/object:Gem::Requirement
|
74
74
|
none: false
|
75
75
|
requirements:
|
76
76
|
- - ~>
|
@@ -78,10 +78,10 @@ dependencies:
|
|
78
78
|
version: '3.0'
|
79
79
|
type: :runtime
|
80
80
|
prerelease: false
|
81
|
-
version_requirements: *
|
81
|
+
version_requirements: *70206693264480
|
82
82
|
- !ruby/object:Gem::Dependency
|
83
83
|
name: acts_as_ferret
|
84
|
-
requirement: &
|
84
|
+
requirement: &70206693263140 !ruby/object:Gem::Requirement
|
85
85
|
none: false
|
86
86
|
requirements:
|
87
87
|
- - ~>
|
@@ -89,10 +89,10 @@ dependencies:
|
|
89
89
|
version: '0.5'
|
90
90
|
type: :runtime
|
91
91
|
prerelease: false
|
92
|
-
version_requirements: *
|
92
|
+
version_requirements: *70206693263140
|
93
93
|
- !ruby/object:Gem::Dependency
|
94
94
|
name: acts_as_list
|
95
|
-
requirement: &
|
95
|
+
requirement: &70206693261540 !ruby/object:Gem::Requirement
|
96
96
|
none: false
|
97
97
|
requirements:
|
98
98
|
- - ~>
|
@@ -100,10 +100,10 @@ dependencies:
|
|
100
100
|
version: '0.1'
|
101
101
|
type: :runtime
|
102
102
|
prerelease: false
|
103
|
-
version_requirements: *
|
103
|
+
version_requirements: *70206693261540
|
104
104
|
- !ruby/object:Gem::Dependency
|
105
105
|
name: magiclabs-userstamp
|
106
|
-
requirement: &
|
106
|
+
requirement: &70206693260620 !ruby/object:Gem::Requirement
|
107
107
|
none: false
|
108
108
|
requirements:
|
109
109
|
- - ~>
|
@@ -111,10 +111,10 @@ dependencies:
|
|
111
111
|
version: 2.0.2
|
112
112
|
type: :runtime
|
113
113
|
prerelease: false
|
114
|
-
version_requirements: *
|
114
|
+
version_requirements: *70206693260620
|
115
115
|
- !ruby/object:Gem::Dependency
|
116
116
|
name: dynamic_form
|
117
|
-
requirement: &
|
117
|
+
requirement: &70206693432660 !ruby/object:Gem::Requirement
|
118
118
|
none: false
|
119
119
|
requirements:
|
120
120
|
- - ~>
|
@@ -122,10 +122,10 @@ dependencies:
|
|
122
122
|
version: '1.1'
|
123
123
|
type: :runtime
|
124
124
|
prerelease: false
|
125
|
-
version_requirements: *
|
125
|
+
version_requirements: *70206693432660
|
126
126
|
- !ruby/object:Gem::Dependency
|
127
127
|
name: jquery-rails
|
128
|
-
requirement: &
|
128
|
+
requirement: &70206693432100 !ruby/object:Gem::Requirement
|
129
129
|
none: false
|
130
130
|
requirements:
|
131
131
|
- - ~>
|
@@ -133,10 +133,10 @@ dependencies:
|
|
133
133
|
version: 1.0.16
|
134
134
|
type: :runtime
|
135
135
|
prerelease: false
|
136
|
-
version_requirements: *
|
136
|
+
version_requirements: *70206693432100
|
137
137
|
- !ruby/object:Gem::Dependency
|
138
138
|
name: attachment_magic
|
139
|
-
requirement: &
|
139
|
+
requirement: &70206693431480 !ruby/object:Gem::Requirement
|
140
140
|
none: false
|
141
141
|
requirements:
|
142
142
|
- - ~>
|
@@ -144,10 +144,10 @@ dependencies:
|
|
144
144
|
version: 0.2.1
|
145
145
|
type: :runtime
|
146
146
|
prerelease: false
|
147
|
-
version_requirements: *
|
147
|
+
version_requirements: *70206693431480
|
148
148
|
- !ruby/object:Gem::Dependency
|
149
149
|
name: rspec-rails
|
150
|
-
requirement: &
|
150
|
+
requirement: &70206693430680 !ruby/object:Gem::Requirement
|
151
151
|
none: false
|
152
152
|
requirements:
|
153
153
|
- - ~>
|
@@ -155,10 +155,10 @@ dependencies:
|
|
155
155
|
version: '2.8'
|
156
156
|
type: :development
|
157
157
|
prerelease: false
|
158
|
-
version_requirements: *
|
158
|
+
version_requirements: *70206693430680
|
159
159
|
- !ruby/object:Gem::Dependency
|
160
160
|
name: sqlite3
|
161
|
-
requirement: &
|
161
|
+
requirement: &70206693430180 !ruby/object:Gem::Requirement
|
162
162
|
none: false
|
163
163
|
requirements:
|
164
164
|
- - ! '>='
|
@@ -166,7 +166,7 @@ dependencies:
|
|
166
166
|
version: '0'
|
167
167
|
type: :development
|
168
168
|
prerelease: false
|
169
|
-
version_requirements: *
|
169
|
+
version_requirements: *70206693430180
|
170
170
|
description: Alchemy is a Rails 3 CMS with a flexible content storing architecture.
|
171
171
|
email:
|
172
172
|
- alchemy@magiclabs.de
|
@@ -343,7 +343,6 @@ files:
|
|
343
343
|
- app/views/alchemy/admin/elements/_new_element_form.html.erb
|
344
344
|
- app/views/alchemy/admin/elements/_picture_editor.html.erb
|
345
345
|
- app/views/alchemy/admin/elements/create.js.erb
|
346
|
-
- app/views/alchemy/admin/elements/destroy.js.erb
|
347
346
|
- app/views/alchemy/admin/elements/fold.js.erb
|
348
347
|
- app/views/alchemy/admin/elements/index.html.erb
|
349
348
|
- app/views/alchemy/admin/elements/list.js.erb
|
@@ -806,7 +805,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
806
805
|
version: '0'
|
807
806
|
segments:
|
808
807
|
- 0
|
809
|
-
hash:
|
808
|
+
hash: 2472603467692044268
|
810
809
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
811
810
|
none: false
|
812
811
|
requirements:
|
@@ -815,11 +814,11 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
815
814
|
version: '0'
|
816
815
|
segments:
|
817
816
|
- 0
|
818
|
-
hash:
|
817
|
+
hash: 2472603467692044268
|
819
818
|
requirements:
|
820
819
|
- ImageMagick (libmagick), v6.6 or greater.
|
821
820
|
rubyforge_project:
|
822
|
-
rubygems_version: 1.8.
|
821
|
+
rubygems_version: 1.8.15
|
823
822
|
signing_key:
|
824
823
|
specification_version: 3
|
825
824
|
summary: An extremly flexbile CMS for Rails 3.1.
|