lolita 3.2.0.rc2 → 3.2.0.rc.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/History.rdoc +3 -0
- data/README.md +2 -1
- data/VERSION +1 -1
- data/app/assets/javascripts/lolita/tab.js +41 -0
- data/app/controllers/lolita/field_data_controller.rb +20 -0
- data/app/helpers/lolita_helper.rb +12 -0
- data/app/views/components/lolita/configuration/field/array/habtm/_display.html.haml +4 -3
- data/app/views/components/lolita/configuration/field/array/polymorphic/_display.html.haml +6 -0
- data/app/views/components/lolita/configuration/field/array/polymorphic/_options_for_select.html.haml +1 -0
- data/app/views/components/lolita/configuration/field/array/select/_display.html.erb +1 -1
- data/app/views/layouts/lolita/application.html.erb +1 -0
- data/config/routes.rb +1 -0
- data/lib/lolita/adapter/active_record.rb +19 -4
- data/lib/lolita/adapter/mongoid.rb +12 -4
- data/lib/lolita/configuration/factory/field.rb +10 -2
- data/lib/lolita/configuration/field.rb +6 -1
- data/lib/lolita/configuration/field/array.rb +103 -24
- data/lib/lolita/configuration/field/integer.rb +0 -1
- data/lib/lolita/configuration/tabs.rb +6 -0
- data/lib/lolita/system_configuration/application.rb +7 -1
- data/lolita.gemspec +5 -2
- data/spec/configuration/field_spec.rb +1 -1
- metadata +34 -31
data/History.rdoc
CHANGED
@@ -5,6 +5,9 @@
|
|
5
5
|
* Removed specific pagination methods from adapters
|
6
6
|
* Removed Lolita::Configuration::Factory and Lolita::Configuration::Page
|
7
7
|
* Range, Float, Symbol, Hash fields are added to support Mongoid ORM
|
8
|
+
* All fields automaticly have html_options[:class] updated with its type
|
9
|
+
* Assets can be passet to lolita through application configuration attribute #assets
|
10
|
+
* Polymorphic association field
|
8
11
|
|
9
12
|
* Changes
|
10
13
|
* #value, #value=, #record_value removed from Lolita::Configuration::Field
|
data/README.md
CHANGED
@@ -1,6 +1,7 @@
|
|
1
1
|
#Lolita
|
2
2
|
|
3
|
-
Great Rails CMS, that turns your business logic into good-looking, fully functional workspace.
|
3
|
+
Great Rails CMS, that turns your business logic into good-looking, fully functional workspace.
|
4
|
+
Works with Rails 3.1
|
4
5
|
##Demo
|
5
6
|
See the demo page at [Demo](http://lolita-demo.ithouse.lv)
|
6
7
|
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
3.2.0.
|
1
|
+
3.2.0.rc.3
|
@@ -34,4 +34,45 @@ $(function(){
|
|
34
34
|
$(".tab .tab-title.grey").live('click',function(){
|
35
35
|
$(this).parent().toggleClass("minimized")
|
36
36
|
})
|
37
|
+
// Integer field validator
|
38
|
+
$(".integer").live("keydown",function(event){
|
39
|
+
// Allow only backspace and delete
|
40
|
+
if ( event.keyCode == 46 || event.keyCode == 8 ) {
|
41
|
+
// let it happen, don't do anything
|
42
|
+
}
|
43
|
+
else {
|
44
|
+
// Ensure that it is a number and stop the keypress
|
45
|
+
if (event.keyCode < 48 || event.keyCode > 57 ) {
|
46
|
+
event.preventDefault();
|
47
|
+
}
|
48
|
+
}
|
49
|
+
})
|
50
|
+
|
51
|
+
$("select[data-polymorphic-url]").live("change",function(){
|
52
|
+
var url = $(this).attr("data-polymorphic-url")
|
53
|
+
var select = $(this)[0]
|
54
|
+
var jselect = $(this)
|
55
|
+
var id = jselect.attr("id").replace(/_type$/,"_id")
|
56
|
+
jselect.find('option').each(function(i){
|
57
|
+
var option = $(this);
|
58
|
+
if(i==select.selectedIndex){
|
59
|
+
var val = option.val()
|
60
|
+
if(val.length > 1){
|
61
|
+
url = url.replace(/\/klass\//,"/"+val+"/")
|
62
|
+
var klass = option.val()
|
63
|
+
$.ajax({
|
64
|
+
url: url,
|
65
|
+
type: "get",
|
66
|
+
success:function(html){
|
67
|
+
$("#"+id).html(html)
|
68
|
+
}
|
69
|
+
})
|
70
|
+
}else{
|
71
|
+
$("#"+id).html("")
|
72
|
+
}
|
73
|
+
|
74
|
+
}
|
75
|
+
})
|
76
|
+
})
|
77
|
+
|
37
78
|
})
|
@@ -0,0 +1,20 @@
|
|
1
|
+
class Lolita::FieldDataController < ApplicationController
|
2
|
+
include Lolita::Controllers::UserHelpers
|
3
|
+
|
4
|
+
before_filter :authenticate_lolita_user!
|
5
|
+
before_filter :find_field
|
6
|
+
|
7
|
+
def array_polymorphic
|
8
|
+
klass = params[:class].camelize.constantize
|
9
|
+
data_collection = @field.polymorphic_association_values(:klass => klass)
|
10
|
+
@id = params[:id].to_s.to_i
|
11
|
+
@collection = [[]]+data_collection
|
12
|
+
render_component(*@field.build(:state => :options_for_select, :collection => @collection, :id => @id))
|
13
|
+
end
|
14
|
+
|
15
|
+
def find_field
|
16
|
+
@field = params[:field_class].camelize.constantize.lolita.tabs.fields.detect{|field|
|
17
|
+
field.name.to_s == params[:name].to_s
|
18
|
+
}
|
19
|
+
end
|
20
|
+
end
|
@@ -9,4 +9,16 @@ module LolitaHelper
|
|
9
9
|
end
|
10
10
|
classes.join(" ")
|
11
11
|
end
|
12
|
+
|
13
|
+
def include_application_assets
|
14
|
+
result = ""
|
15
|
+
Lolita.application.assets.each do |asset_name|
|
16
|
+
if attr_name.match(/\.js(\.|$)/)
|
17
|
+
result << javascript_include_tag(asset_name)
|
18
|
+
elsif attr_name.match(/\.css(\.|$)/)
|
19
|
+
result << stylesheet_link_tag(asset_name)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
raw(result)
|
23
|
+
end
|
12
24
|
end
|
@@ -1,7 +1,8 @@
|
|
1
|
-
=
|
1
|
+
- ids_method = field.name.to_s.match(/_ids$/) ? field.name : "#{field.name.to_s.singularize}_ids"
|
2
|
+
= hidden_field_tag "#{resource_name}[#{ids_method}][]",""
|
2
3
|
- field.view_values(self).each do |value|
|
3
|
-
- editors = resource.send(:"#{
|
4
|
+
- editors = resource.send(:"#{ids_method}")
|
4
5
|
.habtm-container
|
5
6
|
= label_tag "#{resource_name}_#{field.name}_#{value.last}",value.first, :class => "habtm-label"
|
6
|
-
= check_box_tag "#{resource_name}[#{
|
7
|
+
= check_box_tag "#{resource_name}[#{ids_method}][]", value.last, resource.send("#{ids_method}").include?(value.last), :id => "#{resource_name}_#{field.name}_#{value.last}", :class => "habtm-checkbox"
|
7
8
|
.clear
|
@@ -0,0 +1,6 @@
|
|
1
|
+
- record = tab_form.object
|
2
|
+
- type_name = field.association.name.to_s + "_type"
|
3
|
+
- id_name = field.association.name.to_s + "_id"
|
4
|
+
|
5
|
+
= tab_form.select(type_name,field.polymorphic_classes, {:include_blank => true},{:"data-polymorphic-url" => array_field_data_collector_path(:name => field.name, :field_class => record.class.to_s, :class => "klass", :id =>record.send(id_name) || 0) })
|
6
|
+
= tab_form.select(id_name, field.polymorphic_association_values(:record => record))
|
data/app/views/components/lolita/configuration/field/array/polymorphic/_options_for_select.html.haml
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
= options_for_select(collection,id)
|
data/config/routes.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
Rails.application.routes.draw do
|
2
2
|
match '/lolita' => "lolita/info#index"
|
3
3
|
match '/lolita/info/properties' => "lolita/info#properties"
|
4
|
+
match "/lolita/array_field/:name/:field_class/:class/:id" => "lolita/field_data#array_polymorphic", :as => "array_field_data_collector"
|
4
5
|
end
|
@@ -24,15 +24,26 @@ module Lolita
|
|
24
24
|
end
|
25
25
|
|
26
26
|
def key
|
27
|
-
@association.
|
27
|
+
if @association.macro == :belongs_to
|
28
|
+
@association.foreign_key
|
29
|
+
else
|
30
|
+
@association.association_foreign_key
|
31
|
+
end
|
28
32
|
end
|
29
33
|
|
30
34
|
def polymorphic?
|
31
35
|
@association.options[:polymorphic]
|
32
36
|
end
|
33
37
|
|
38
|
+
def native_macro
|
39
|
+
@association.macro
|
40
|
+
end
|
41
|
+
|
34
42
|
def macro
|
35
|
-
convertator = {
|
43
|
+
convertator = {
|
44
|
+
:has_many => :many, :has_one => :one, :belongs_to => :one,
|
45
|
+
:has_and_belongs_to_many => :many_to_many
|
46
|
+
}
|
36
47
|
convertator[@association.macro]
|
37
48
|
end
|
38
49
|
end
|
@@ -77,11 +88,15 @@ module Lolita
|
|
77
88
|
end
|
78
89
|
|
79
90
|
def association
|
80
|
-
|
91
|
+
if @association.nil?
|
81
92
|
possible_association = @adapter.associations.detect{|name,association|
|
82
93
|
[association.key.to_s].include?(@name.to_s)
|
83
94
|
}
|
84
|
-
@association =
|
95
|
+
@association = if possible_association
|
96
|
+
possible_association.last
|
97
|
+
else
|
98
|
+
false
|
99
|
+
end
|
85
100
|
end
|
86
101
|
@association
|
87
102
|
end
|
@@ -24,13 +24,17 @@ module Lolita
|
|
24
24
|
end
|
25
25
|
|
26
26
|
def key
|
27
|
-
@association.
|
27
|
+
@association.foreign_key
|
28
|
+
end
|
29
|
+
|
30
|
+
def native_macro
|
31
|
+
@association.macro
|
28
32
|
end
|
29
33
|
|
30
34
|
def macro
|
31
35
|
convertator = {
|
32
36
|
:references_many => :many, :references_one => :one, :referenced_in => :one,
|
33
|
-
:references_and_referenced_in_many => :
|
37
|
+
:references_and_referenced_in_many => :many_to_many, :embeds_one => :one, :embeds_many => :many
|
34
38
|
}
|
35
39
|
convertator[@association.macro]
|
36
40
|
end
|
@@ -76,11 +80,15 @@ module Lolita
|
|
76
80
|
end
|
77
81
|
|
78
82
|
def association
|
79
|
-
|
83
|
+
if @association.nil?
|
80
84
|
possible_association = @adapter.associations.detect{|name,association|
|
81
85
|
[association.key.to_s].include?(@name.to_s)
|
82
86
|
}
|
83
|
-
@association =
|
87
|
+
@association = if possible_association
|
88
|
+
possible_association.last
|
89
|
+
else
|
90
|
+
false
|
91
|
+
end
|
84
92
|
end
|
85
93
|
@association
|
86
94
|
end
|
@@ -16,9 +16,13 @@ module Lolita
|
|
16
16
|
name = args[0] || options[:name] || (dbi_field ? dbi_field.name : nil)
|
17
17
|
dbi_field ||= dbi.field_by_name(name)
|
18
18
|
dbi_field ||= dbi.field_by_association(name)
|
19
|
-
|
20
|
-
options[:dbi_field] = dbi_field
|
19
|
+
association ||= detect_association(dbi,name)
|
21
20
|
|
21
|
+
type = args[1] || options[:type] ||
|
22
|
+
(association ? :array : nil ) ||
|
23
|
+
(dbi_field ? dbi_field.type : nil) ||
|
24
|
+
:string
|
25
|
+
options[:dbi_field] = dbi_field
|
22
26
|
if !name || !type
|
23
27
|
raise Lolita::FieldTypeError, "type not defined. Set is as second argument or as :dbi_field where value is Adapter::[ORM]::Field object."
|
24
28
|
else
|
@@ -28,6 +32,10 @@ module Lolita
|
|
28
32
|
|
29
33
|
end
|
30
34
|
|
35
|
+
def self.detect_association(dbi,name)
|
36
|
+
dbi.associations[name.to_sym]
|
37
|
+
end
|
38
|
+
|
31
39
|
def self.field_class(name)
|
32
40
|
("Lolita::Configuration::Field::"+name.to_s.camelize).constantize
|
33
41
|
end
|
@@ -101,7 +101,7 @@ module Lolita
|
|
101
101
|
|
102
102
|
def find_dbi_field
|
103
103
|
@dbi_field ||= self.dbi.fields.detect{|field|
|
104
|
-
field.name.to_s ==
|
104
|
+
field.name.to_s == @name.to_s || (field.association && field.association.name.to_s == @name.to_s)
|
105
105
|
}
|
106
106
|
end
|
107
107
|
|
@@ -114,6 +114,11 @@ module Lolita
|
|
114
114
|
def set_default_values
|
115
115
|
self.options||={}
|
116
116
|
self.html_options ||= {}
|
117
|
+
@html_options[:class] = if @html_options[:class]
|
118
|
+
"#{@html_options[:class]} #{self.type}"
|
119
|
+
else
|
120
|
+
self.type.to_s
|
121
|
+
end
|
117
122
|
end
|
118
123
|
|
119
124
|
def validate
|
@@ -1,16 +1,27 @@
|
|
1
1
|
module Lolita
|
2
2
|
module Configuration
|
3
3
|
module Field
|
4
|
-
|
4
|
+
# Fields with Array is used to
|
5
|
+
# * create select for belongs_to association or
|
6
|
+
# * has_and_belongs_to_many field for selecting all associated objects or
|
7
|
+
# * for polymorphic belongs_to associations
|
8
|
+
# ==Polymorphic builder (:polymorphic)
|
9
|
+
# Create two select boxes one of all related classes and second with related records for that class.
|
10
|
+
# Related classes can have <em>polymorphic_select_name</em> instance method, that is used to populate second
|
11
|
+
# select with visible values by default it calles <em>text_method</em>. It will fallback first content column. Class should respond to one
|
12
|
+
# of these.
|
5
13
|
class Array < Lolita::Configuration::Field::Base
|
6
14
|
lolita_accessor :conditions,:text_method,:value_method,:find_options,:association,:include_blank
|
15
|
+
lolita_accessor :related_classes
|
7
16
|
|
8
17
|
def initialize dbi,name,*args, &block
|
9
|
-
self.builder="select"
|
10
18
|
@include_blank=true
|
11
19
|
super
|
12
20
|
self.find_dbi_field unless self.dbi_field
|
13
|
-
|
21
|
+
|
22
|
+
@association ||= self.dbi_field ? self.dbi_field.association : detect_association
|
23
|
+
self.builder = detect_builder unless @builder
|
24
|
+
self.name = recognize_real_name
|
14
25
|
end
|
15
26
|
|
16
27
|
def options_for_select=(value=nil)
|
@@ -28,50 +39,118 @@ module Lolita
|
|
28
39
|
# by default it it is <code>id</code>. Use <code>conditions</code> or
|
29
40
|
# <code>find_options</code> for advanced search. When <code>find_options</code>
|
30
41
|
# is used, than <code>conditions</code> is ignored.
|
31
|
-
def association_values() #TODO test
|
42
|
+
def association_values(record = nil) #TODO test
|
32
43
|
@association_values=if options_for_select
|
33
44
|
options_for_select
|
45
|
+
elsif @association && @association.polymorphic?
|
46
|
+
polymorphic_association_values(record)
|
34
47
|
elsif @association
|
35
48
|
klass=@association.klass
|
36
|
-
current_text_method=@text_method || default_text_method(klass)
|
37
|
-
current_value_method=@value_method || :id
|
38
49
|
options=@find_options || {}
|
39
50
|
options[:conditions]||=@conditions
|
40
|
-
|
41
|
-
klass.find(:all,options).map{|r|
|
42
|
-
[r.send(current_text_method),r.send(current_value_method)]
|
43
|
-
}
|
51
|
+
options_array(klass.find(:all,options))
|
44
52
|
else
|
45
53
|
[]
|
46
54
|
end
|
47
55
|
@association_values
|
48
56
|
end
|
49
57
|
|
58
|
+
# Collect values for polymorphic association, you may pass
|
59
|
+
# * <tt>:klass</tt> - class that's records are used
|
60
|
+
# * <tt>:record</tt> - record class that has polymorphic association. It is used to call to detect related object class.
|
61
|
+
def polymorphic_association_values(options={})
|
62
|
+
options ||= {}
|
63
|
+
options[:klass] ||= options[:record] && options[:record].send(self.name) ? options[:record].send(self.name).class : nil
|
64
|
+
if options[:klass]
|
65
|
+
options_array(options[:klass].all)
|
66
|
+
else
|
67
|
+
[]
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
def options_array(collection)
|
72
|
+
klass = collection.last ? collection.last.class : nil
|
73
|
+
collection.map{|r|
|
74
|
+
[r.send(current_text_method(klass)),r.send(current_value_method)]
|
75
|
+
}
|
76
|
+
end
|
77
|
+
|
78
|
+
def current_text_method(klass)
|
79
|
+
@text_method || default_text_method(klass)
|
80
|
+
end
|
81
|
+
|
82
|
+
def current_value_method
|
83
|
+
@value_method || :id
|
84
|
+
end
|
85
|
+
|
50
86
|
# used in views for shorter accessing to values
|
51
87
|
def view_values(view)
|
52
|
-
|
88
|
+
record = view.send(:tab_form).object
|
89
|
+
values = association_values(record)
|
53
90
|
if values.respond_to?(:call)
|
54
91
|
values.call(view)
|
55
92
|
else
|
56
|
-
association_values
|
93
|
+
association_values(record)
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
def detect_builder
|
98
|
+
if @association
|
99
|
+
if @association.polymorphic?
|
100
|
+
"polymorphic"
|
101
|
+
elsif @association.macro == :many_to_many
|
102
|
+
"habtm"
|
103
|
+
else
|
104
|
+
"select"
|
105
|
+
end
|
106
|
+
else
|
107
|
+
"select"
|
57
108
|
end
|
58
109
|
end
|
59
110
|
|
60
|
-
|
111
|
+
def detect_association
|
112
|
+
unless @association
|
113
|
+
dbi.associations[self.name.to_sym]
|
114
|
+
else
|
115
|
+
@association
|
116
|
+
end
|
117
|
+
end
|
61
118
|
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
119
|
+
def polymorphic_classes
|
120
|
+
if @related_classes
|
121
|
+
@related_classes.map do |klass|
|
122
|
+
[klass.constantize.model_name.human, klass.to_s]
|
123
|
+
end
|
124
|
+
end
|
125
|
+
end
|
126
|
+
|
127
|
+
def recognize_real_name
|
128
|
+
if @association && !@association.polymorphic? && @association.macro == :one
|
129
|
+
self.name = @association.key
|
130
|
+
else
|
131
|
+
@name
|
132
|
+
end
|
133
|
+
end
|
134
|
+
|
135
|
+
private
|
136
|
+
|
137
|
+
def default_text_method(klass)
|
138
|
+
assoc_dbi=Lolita::DBI::Base.create(klass) rescue nil
|
139
|
+
if assoc_dbi
|
140
|
+
field=assoc_dbi.fields.detect{|f| f.type.to_s=="string"}
|
141
|
+
if field
|
142
|
+
field.name
|
143
|
+
else
|
144
|
+
raise Lolita::FieldTypeError, %^
|
145
|
+
Can't find any content field in #{assoc_dbi.klass}.
|
146
|
+
Use text_method in #{klass} to set one.
|
147
|
+
^
|
148
|
+
end
|
149
|
+
else
|
150
|
+
warn("Not a ORM class (#{klass.inspect})")
|
151
|
+
end
|
72
152
|
end
|
73
153
|
end
|
74
154
|
end
|
75
155
|
end
|
76
156
|
end
|
77
|
-
end
|
@@ -1,13 +1,19 @@
|
|
1
1
|
module Lolita
|
2
2
|
module SystemConfiguration
|
3
|
+
# This configuration is used in application lolita initializer
|
4
|
+
# For detailed documentation see initializer.
|
3
5
|
class Application
|
4
6
|
|
5
|
-
attr_writer :name
|
7
|
+
attr_writer :name, :assets
|
6
8
|
|
7
9
|
def name
|
8
10
|
@name || default_name
|
9
11
|
end
|
10
12
|
|
13
|
+
def assets
|
14
|
+
@assets ||= []
|
15
|
+
end
|
16
|
+
|
11
17
|
def default_name
|
12
18
|
if defined?(Rails)
|
13
19
|
Rails::Application.subclasses.first.to_s.split("::").first
|
data/lolita.gemspec
CHANGED
@@ -5,11 +5,11 @@
|
|
5
5
|
|
6
6
|
Gem::Specification.new do |s|
|
7
7
|
s.name = "lolita"
|
8
|
-
s.version = "3.2.0.
|
8
|
+
s.version = "3.2.0.rc.3"
|
9
9
|
|
10
10
|
s.required_rubygems_version = Gem::Requirement.new("> 1.3.1") if s.respond_to? :required_rubygems_version=
|
11
11
|
s.authors = ["ITHouse (Latvia) and Arturs Meisters"]
|
12
|
-
s.date = "2011-09-
|
12
|
+
s.date = "2011-09-09"
|
13
13
|
s.description = "Great Rails CMS, that turns your business logic into good-looking, fully functional workspace. "
|
14
14
|
s.email = "support@ithouse.lv"
|
15
15
|
s.extra_rdoc_files = [
|
@@ -36,6 +36,7 @@ Gem::Specification.new do |s|
|
|
36
36
|
"app/assets/stylesheets/lolita/application.css",
|
37
37
|
"app/assets/stylesheets/lolita/default.css.erb",
|
38
38
|
"app/assets/stylesheets/lolita/style.css.erb",
|
39
|
+
"app/controllers/lolita/field_data_controller.rb",
|
39
40
|
"app/controllers/lolita/info_controller.rb",
|
40
41
|
"app/controllers/lolita/rest_controller.rb",
|
41
42
|
"app/helpers/components/lolita/configuration/list_component.rb",
|
@@ -58,6 +59,8 @@ Gem::Specification.new do |s|
|
|
58
59
|
"app/views/components/lolita/configuration/field/array/_display.html.erb",
|
59
60
|
"app/views/components/lolita/configuration/field/array/filter/_display.html.erb",
|
60
61
|
"app/views/components/lolita/configuration/field/array/habtm/_display.html.haml",
|
62
|
+
"app/views/components/lolita/configuration/field/array/polymorphic/_display.html.haml",
|
63
|
+
"app/views/components/lolita/configuration/field/array/polymorphic/_options_for_select.html.haml",
|
61
64
|
"app/views/components/lolita/configuration/field/array/select/_display.html.erb",
|
62
65
|
"app/views/components/lolita/configuration/field/big_decimal/_display.html.erb",
|
63
66
|
"app/views/components/lolita/configuration/field/boolean/_display.html.erb",
|
@@ -81,7 +81,7 @@ describe Lolita::Configuration::Field do
|
|
81
81
|
|
82
82
|
it "should allow set field that references to (has_many or has_one) any class" do
|
83
83
|
field=Lolita::Configuration::Factory::Field.add(@dbi,:comments,:array)
|
84
|
-
field.type.should == "array"
|
84
|
+
field.type.to_s.should == "array"
|
85
85
|
field.association.macro.should == :many
|
86
86
|
end
|
87
87
|
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: lolita
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.2.0.
|
4
|
+
version: 3.2.0.rc.3
|
5
5
|
prerelease: 6
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,11 +9,11 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2011-09-
|
12
|
+
date: 2011-09-09 00:00:00.000000000Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: rails
|
16
|
-
requirement: &
|
16
|
+
requirement: &85967590 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - ~>
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: 3.1.0
|
22
22
|
type: :runtime
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *85967590
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: kaminari
|
27
|
-
requirement: &
|
27
|
+
requirement: &85963300 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ~>
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: 0.12.4
|
33
33
|
type: :runtime
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *85963300
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: abstract
|
38
|
-
requirement: &
|
38
|
+
requirement: &85962920 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ! '>='
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: '0'
|
44
44
|
type: :runtime
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *85962920
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: builder
|
49
|
-
requirement: &
|
49
|
+
requirement: &85962540 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ~>
|
@@ -54,10 +54,10 @@ dependencies:
|
|
54
54
|
version: '3.0'
|
55
55
|
type: :runtime
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *85962540
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: haml
|
60
|
-
requirement: &
|
60
|
+
requirement: &85962140 !ruby/object:Gem::Requirement
|
61
61
|
none: false
|
62
62
|
requirements:
|
63
63
|
- - ~>
|
@@ -65,10 +65,10 @@ dependencies:
|
|
65
65
|
version: 3.1.2
|
66
66
|
type: :runtime
|
67
67
|
prerelease: false
|
68
|
-
version_requirements: *
|
68
|
+
version_requirements: *85962140
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: jquery-rails
|
71
|
-
requirement: &
|
71
|
+
requirement: &85961800 !ruby/object:Gem::Requirement
|
72
72
|
none: false
|
73
73
|
requirements:
|
74
74
|
- - ! '>='
|
@@ -76,10 +76,10 @@ dependencies:
|
|
76
76
|
version: '0'
|
77
77
|
type: :runtime
|
78
78
|
prerelease: false
|
79
|
-
version_requirements: *
|
79
|
+
version_requirements: *85961800
|
80
80
|
- !ruby/object:Gem::Dependency
|
81
81
|
name: tinymce-rails
|
82
|
-
requirement: &
|
82
|
+
requirement: &85961450 !ruby/object:Gem::Requirement
|
83
83
|
none: false
|
84
84
|
requirements:
|
85
85
|
- - ! '>='
|
@@ -87,10 +87,10 @@ dependencies:
|
|
87
87
|
version: '0'
|
88
88
|
type: :runtime
|
89
89
|
prerelease: false
|
90
|
-
version_requirements: *
|
90
|
+
version_requirements: *85961450
|
91
91
|
- !ruby/object:Gem::Dependency
|
92
92
|
name: jeweler
|
93
|
-
requirement: &
|
93
|
+
requirement: &85961080 !ruby/object:Gem::Requirement
|
94
94
|
none: false
|
95
95
|
requirements:
|
96
96
|
- - ~>
|
@@ -98,10 +98,10 @@ dependencies:
|
|
98
98
|
version: 1.5.2
|
99
99
|
type: :development
|
100
100
|
prerelease: false
|
101
|
-
version_requirements: *
|
101
|
+
version_requirements: *85961080
|
102
102
|
- !ruby/object:Gem::Dependency
|
103
103
|
name: rspec
|
104
|
-
requirement: &
|
104
|
+
requirement: &85960610 !ruby/object:Gem::Requirement
|
105
105
|
none: false
|
106
106
|
requirements:
|
107
107
|
- - ~>
|
@@ -109,10 +109,10 @@ dependencies:
|
|
109
109
|
version: 2.6.0
|
110
110
|
type: :development
|
111
111
|
prerelease: false
|
112
|
-
version_requirements: *
|
112
|
+
version_requirements: *85960610
|
113
113
|
- !ruby/object:Gem::Dependency
|
114
114
|
name: rspec-rails
|
115
|
-
requirement: &
|
115
|
+
requirement: &85959250 !ruby/object:Gem::Requirement
|
116
116
|
none: false
|
117
117
|
requirements:
|
118
118
|
- - ~>
|
@@ -120,10 +120,10 @@ dependencies:
|
|
120
120
|
version: 2.6.1
|
121
121
|
type: :development
|
122
122
|
prerelease: false
|
123
|
-
version_requirements: *
|
123
|
+
version_requirements: *85959250
|
124
124
|
- !ruby/object:Gem::Dependency
|
125
125
|
name: factory_girl
|
126
|
-
requirement: &
|
126
|
+
requirement: &85958850 !ruby/object:Gem::Requirement
|
127
127
|
none: false
|
128
128
|
requirements:
|
129
129
|
- - ! '>='
|
@@ -131,10 +131,10 @@ dependencies:
|
|
131
131
|
version: '0'
|
132
132
|
type: :development
|
133
133
|
prerelease: false
|
134
|
-
version_requirements: *
|
134
|
+
version_requirements: *85958850
|
135
135
|
- !ruby/object:Gem::Dependency
|
136
136
|
name: ffaker
|
137
|
-
requirement: &
|
137
|
+
requirement: &85957860 !ruby/object:Gem::Requirement
|
138
138
|
none: false
|
139
139
|
requirements:
|
140
140
|
- - ! '>='
|
@@ -142,10 +142,10 @@ dependencies:
|
|
142
142
|
version: '0'
|
143
143
|
type: :development
|
144
144
|
prerelease: false
|
145
|
-
version_requirements: *
|
145
|
+
version_requirements: *85957860
|
146
146
|
- !ruby/object:Gem::Dependency
|
147
147
|
name: ruby-debug19
|
148
|
-
requirement: &
|
148
|
+
requirement: &85956980 !ruby/object:Gem::Requirement
|
149
149
|
none: false
|
150
150
|
requirements:
|
151
151
|
- - ! '>='
|
@@ -153,10 +153,10 @@ dependencies:
|
|
153
153
|
version: '0'
|
154
154
|
type: :development
|
155
155
|
prerelease: false
|
156
|
-
version_requirements: *
|
156
|
+
version_requirements: *85956980
|
157
157
|
- !ruby/object:Gem::Dependency
|
158
158
|
name: database_cleaner
|
159
|
-
requirement: &
|
159
|
+
requirement: &85956420 !ruby/object:Gem::Requirement
|
160
160
|
none: false
|
161
161
|
requirements:
|
162
162
|
- - ! '>='
|
@@ -164,7 +164,7 @@ dependencies:
|
|
164
164
|
version: '0'
|
165
165
|
type: :development
|
166
166
|
prerelease: false
|
167
|
-
version_requirements: *
|
167
|
+
version_requirements: *85956420
|
168
168
|
description: ! 'Great Rails CMS, that turns your business logic into good-looking,
|
169
169
|
fully functional workspace. '
|
170
170
|
email: support@ithouse.lv
|
@@ -193,6 +193,7 @@ files:
|
|
193
193
|
- app/assets/stylesheets/lolita/application.css
|
194
194
|
- app/assets/stylesheets/lolita/default.css.erb
|
195
195
|
- app/assets/stylesheets/lolita/style.css.erb
|
196
|
+
- app/controllers/lolita/field_data_controller.rb
|
196
197
|
- app/controllers/lolita/info_controller.rb
|
197
198
|
- app/controllers/lolita/rest_controller.rb
|
198
199
|
- app/helpers/components/lolita/configuration/list_component.rb
|
@@ -215,6 +216,8 @@ files:
|
|
215
216
|
- app/views/components/lolita/configuration/field/array/_display.html.erb
|
216
217
|
- app/views/components/lolita/configuration/field/array/filter/_display.html.erb
|
217
218
|
- app/views/components/lolita/configuration/field/array/habtm/_display.html.haml
|
219
|
+
- app/views/components/lolita/configuration/field/array/polymorphic/_display.html.haml
|
220
|
+
- app/views/components/lolita/configuration/field/array/polymorphic/_options_for_select.html.haml
|
218
221
|
- app/views/components/lolita/configuration/field/array/select/_display.html.erb
|
219
222
|
- app/views/components/lolita/configuration/field/big_decimal/_display.html.erb
|
220
223
|
- app/views/components/lolita/configuration/field/boolean/_display.html.erb
|
@@ -479,7 +482,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
479
482
|
version: '0'
|
480
483
|
segments:
|
481
484
|
- 0
|
482
|
-
hash:
|
485
|
+
hash: 675447699
|
483
486
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
484
487
|
none: false
|
485
488
|
requirements:
|