lolita 3.3.5 → 3.3.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (104) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/stylesheets/lolita/PIE-custom.htc +87 -87
  3. data/app/assets/stylesheets/lolita/PIE.htc +81 -81
  4. data/app/assets/stylesheets/lolita/application.css +6 -6
  5. data/app/assets/stylesheets/lolita/default.css.erb +169 -169
  6. data/app/assets/stylesheets/lolita/jquery-ui-1.8.16.lolita.css.erb +567 -567
  7. data/app/controllers/lolita/info_controller.rb +4 -5
  8. data/app/helpers/components/lolita/configuration/list_component.rb +10 -10
  9. data/app/views/components/lolita/configuration/column/_first.html.haml +1 -1
  10. data/app/views/components/lolita/configuration/column/header/_first.html.haml +1 -1
  11. data/app/views/components/lolita/configuration/column/header/_sort.html.haml +6 -6
  12. data/app/views/components/lolita/configuration/columns/header/_display.html.haml +5 -5
  13. data/app/views/components/lolita/configuration/field/array/checkbox/_display.html.haml +7 -7
  14. data/app/views/components/lolita/configuration/search/_display.html.haml +2 -2
  15. data/app/views/kaminari/lolita/_first_page.html.erb +11 -11
  16. data/app/views/kaminari/lolita/_gap.html.erb +8 -8
  17. data/app/views/kaminari/lolita/_last_page.html.erb +11 -11
  18. data/app/views/kaminari/lolita/_next_page.html.erb +11 -11
  19. data/app/views/kaminari/lolita/_page.html.erb +12 -12
  20. data/app/views/kaminari/lolita/_paginator.html.erb +23 -23
  21. data/app/views/kaminari/lolita/_prev_page.html.erb +11 -11
  22. data/app/views/lolita/info/index.html.erb +232 -232
  23. data/lib/lolita/adapter/field_helper.rb +18 -18
  24. data/lib/lolita/configuration/field/big_decimal.rb +12 -12
  25. data/lib/lolita/configuration/field/boolean.rb +12 -12
  26. data/lib/lolita/configuration/field/date.rb +12 -12
  27. data/lib/lolita/configuration/field/hidden.rb +12 -12
  28. data/lib/lolita/configuration/field/integer.rb +11 -11
  29. data/lib/lolita/configuration/field/string.rb +16 -16
  30. data/lib/lolita/configuration/field/time.rb +13 -13
  31. data/lib/lolita/configuration/field_set.rb +25 -25
  32. data/lib/lolita/configuration/nested_form.rb +104 -104
  33. data/lib/lolita/configuration/search.rb +104 -104
  34. data/lib/lolita/dbi/base.rb +56 -56
  35. data/lib/lolita/hooks/named_hook.rb +125 -125
  36. data/lib/lolita/lazy_loader.rb +54 -54
  37. data/lib/lolita/navigation/tree.rb +132 -132
  38. data/lib/lolita/ruby_ext/accessors.rb +26 -26
  39. data/lib/lolita/search/simple.rb +75 -75
  40. data/lib/lolita/support/formatter/rails.rb +56 -56
  41. data/lib/lolita/support/formatter.rb +62 -62
  42. data/lib/lolita/test/matchers.rb +77 -77
  43. data/lib/lolita/version.rb +1 -1
  44. data/lib/lolita.rb +2 -2
  45. data/spec/builder_spec.rb +120 -120
  46. data/spec/rails_app/app/controllers/application_controller.rb +3 -3
  47. data/spec/rails_app/app/helpers/application_helper.rb +3 -3
  48. data/spec/rails_app/app/mongoid/address.rb +7 -7
  49. data/spec/rails_app/app/mongoid/comment.rb +5 -5
  50. data/spec/rails_app/app/mongoid/preference.rb +5 -5
  51. data/spec/rails_app/app/mongoid/profile.rb +13 -13
  52. data/spec/rails_app/app/mongoid/tag.rb +3 -3
  53. data/spec/rails_app/app/views/components/lolita/configuration/list/_body_cell.html.erb +1 -1
  54. data/spec/rails_app/config/environment.rb +5 -5
  55. data/spec/rails_app/config/environments/production.rb +37 -37
  56. data/spec/rails_app/config/environments/test.rb +37 -37
  57. data/spec/rails_app/config/initializers/backtrace_silencers.rb +7 -7
  58. data/spec/rails_app/config/initializers/inflections.rb +2 -2
  59. data/spec/rails_app/config/initializers/secret_token.rb +1 -1
  60. data/spec/rails_app/lib/lolita/configuration/field/my_custom_collection.rb +13 -13
  61. data/spec/rails_app/log/development.log +14313 -753
  62. data/spec/rails_app/public/javascripts/jquery-1.5.1.min.js +15 -15
  63. data/spec/rails_app/public/javascripts/lolita/main.js +6 -6
  64. data/spec/rails_app/public/javascripts/modernizr-1.7.min.js +1 -1
  65. data/spec/rails_app/public/javascripts/rails.js +137 -137
  66. data/spec/rails_app/public/javascripts/tinymce/langs/en.js +221 -221
  67. data/spec/rails_app/public/javascripts/tinymce/license.txt +504 -504
  68. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/about.htm +52 -52
  69. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/anchor.htm +26 -26
  70. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/charmap.htm +51 -51
  71. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/color_picker.htm +74 -74
  72. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/editor_template_src.js +1328 -1328
  73. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/image.htm +80 -80
  74. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/about.js +73 -73
  75. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/anchor.js +42 -42
  76. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/charmap.js +354 -354
  77. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/color_picker.js +329 -329
  78. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/image.js +247 -247
  79. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/link.js +153 -153
  80. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/source_editor.js +56 -56
  81. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/langs/en.js +68 -68
  82. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/langs/en_dlg.js +53 -53
  83. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/link.htm +57 -57
  84. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/shortcuts.htm +47 -47
  85. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/content.css +66 -66
  86. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/dialog.css +117 -117
  87. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/ui.css +988 -988
  88. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/source_editor.htm +25 -25
  89. data/spec/rails_app/public/javascripts/tinymce/tiny_mce_popup.js +4 -4
  90. data/spec/rails_app/public/stylesheets/lolita/default.css +169 -169
  91. data/spec/rails_app/public/stylesheets/lolita/style.css +214 -214
  92. data/vendor/assets/javascripts/jquery-numeric.js +279 -279
  93. data/vendor/assets/javascripts/modernizr_1_7_min.js +1 -1
  94. data/vendor/assets/javascripts/tinymce/themes/advanced/skins/cirkuit/content.css +66 -66
  95. data/vendor/assets/javascripts/tinymce/themes/advanced/skins/cirkuit/dialog.css +117 -117
  96. data/vendor/assets/javascripts/tinymce/themes/advanced/skins/cirkuit/ui.css +988 -988
  97. data/vendor/assets/stylesheets/jquery-ui-1.8.16.custom.css +567 -567
  98. metadata +342 -349
  99. data/app/controllers/lolita/field_data_controller.rb~ +0 -45
  100. data/app/views/components/lolita/configuration/field/array/autocomplete/_display.html.haml~ +0 -16
  101. data/app/views/components/lolita/configuration/filter/_display.html.haml~ +0 -9
  102. data/lib/lolita/configuration/filter.rb~ +0 -122
  103. data/lib/lolita/version.rb~ +0 -30
  104. data/spec/configuration/filter_spec.rb~ +0 -167
@@ -1,13 +1,13 @@
1
- module Lolita
2
- module Configuration
3
- module Field
4
- class Time < Lolita::Configuration::Field::Base
5
- attr_accessor :format
6
- def initialize dbi,name,*args, &block
7
-
8
- super
9
- end
10
- end
11
- end
12
- end
13
- end
1
+ module Lolita
2
+ module Configuration
3
+ module Field
4
+ class Time < Lolita::Configuration::Field::Base
5
+ attr_accessor :format
6
+ def initialize dbi,name,*args, &block
7
+
8
+ super
9
+ end
10
+ end
11
+ end
12
+ end
13
+ end
@@ -1,26 +1,26 @@
1
- module Lolita
2
- module Configuration
3
- class FieldSet
4
-
5
- @@last_fieldset=0
6
-
7
- attr_reader :parent
8
- attr_accessor :name
9
-
10
- def initialize parent,name=nil
11
- @parent=parent
12
- self.name=name || "fieldset_#{next_fieldset}"
13
- end
14
-
15
- def fields
16
- self.parent.fields.reject{|f| f.field_set!=self}
17
- end
18
-
19
- private
20
-
21
- def next_fieldset
22
- @@last_fieldset+=1
23
- end
24
- end
25
- end
1
+ module Lolita
2
+ module Configuration
3
+ class FieldSet
4
+
5
+ @@last_fieldset=0
6
+
7
+ attr_reader :parent
8
+ attr_accessor :name
9
+
10
+ def initialize parent,name=nil
11
+ @parent=parent
12
+ self.name=name || "fieldset_#{next_fieldset}"
13
+ end
14
+
15
+ def fields
16
+ self.parent.fields.reject{|f| f.field_set!=self}
17
+ end
18
+
19
+ private
20
+
21
+ def next_fieldset
22
+ @@last_fieldset+=1
23
+ end
24
+ end
25
+ end
26
26
  end
@@ -1,105 +1,105 @@
1
- module Lolita
2
- module Configuration
3
- # Accept those attributes
4
- # * <tt>:name</tt> - Name of nested relation, like :comments.
5
- # * <tt>:field_style</tt> - Is fields rendered with as normal (with lable and staff) or like in table (:simple). Default :simple
6
- # * <tt>:expandable</tt> - Show or not "Add new" and "Delete" links in form,
7
- # by default, it is expandable if association macro is :many
8
- # * <tt>:field_rejection_proc</tt> - Proc, that contains condition of how to reject field.
9
- # By default form rejects all fields from parent tab that doesn't have current form as field nested_form
10
- # ====Example
11
- # form = Lolita::Configuration::NestedForm.new(Lolita::Configuration::Tab::Content.new,:comments)
12
- # form.field_rejection_proc = Proc.new{|field|
13
- # field.name.to_s.match(/_id$/)
14
- # }
15
- # # form exclude all fields that ends with _id
16
- class NestedForm
17
- include Lolita::Builder
18
- @@last_nested_form=0
19
-
20
- attr_reader :parent, :options, :field_style
21
- attr_accessor :name, :expandable, :field_rejection_proc
22
- attr_writer :build_method
23
-
24
- def initialize parent,name=nil, options ={}
25
- @parent=parent
26
- @options = options
27
- self.name=name || "nested_form_#{next_nested_form}"
28
- set_attributes_from(options)
29
- end
30
-
31
- def allow_destroy?
32
- dbi.klass.nested_attributes_options[name][:allow_destroy]
33
- end
34
-
35
- def update_only?
36
- dbi.klass.nested_attributes_options[name][:update_only]
37
- end
38
-
39
- def build_method
40
- @build_method || self.name
41
- end
42
- # Set field style - normal or simple. Default - normal.
43
- def field_style=(value)
44
- allowed_values = [:normal,:simple]
45
- raise ArgumentError, "Only #{allowed_values.inspect} are allowed" unless allowed_values.include?(value)
46
- @field_style = value
47
- end
48
-
49
- # Detect if it's possible to add more than one field group, like if model has many other objects.
50
- def expandable?
51
- @expandable == true || (@expandable == nil && macro == :many)
52
- end
53
-
54
- # Create field, that is not real field, but represents nested attributes as one.
55
- # It is used to create label.
56
- def as_field
57
- Lolita::Configuration::Factory::Field.add(dbi,self.name, :string)
58
- end
59
-
60
- # Parent (a.k.a tab) dbi
61
- def dbi
62
- @parent.dbi
63
- end
64
-
65
- # Fields setter. Fields should be array and each element should be Lolita::Configuration::Field object.
66
- def fields=(new_fields)
67
- @fields = new_fields
68
- end
69
-
70
- # Return all fields. Each time fields ar returned from @fields if its defined or calculated by using #field_rejection_proc
71
- # or collected from parent (tab) where fields nested form is same with self.
72
- def fields
73
- if @fields
74
- @fields
75
- elsif field_rejection_proc
76
- self.parent.fields.reject(&field_rejection_proc)
77
- else
78
- self.parent.fields.reject{|f| f.nested_form!=self}
79
- end
80
- end
81
-
82
- # Parent (tab) dbi klass
83
- def klass
84
- dbi.reflect_on_association(name).klass
85
- end
86
-
87
- # Parent (tab) dbi klass reflection with #name and macros of that.
88
- def macro
89
- dbi.reflect_on_association(name).macro
90
- end
91
-
92
- private
93
-
94
- def next_nested_form
95
- @@last_nested_form+=1
96
- end
97
-
98
- def set_attributes_from(options)
99
- options.each{|key,value|
100
- instance_variable_set(:"@#{key}",value)
101
- }
102
- end
103
- end
104
- end
1
+ module Lolita
2
+ module Configuration
3
+ # Accept those attributes
4
+ # * <tt>:name</tt> - Name of nested relation, like :comments.
5
+ # * <tt>:field_style</tt> - Is fields rendered with as normal (with lable and staff) or like in table (:simple). Default :simple
6
+ # * <tt>:expandable</tt> - Show or not "Add new" and "Delete" links in form,
7
+ # by default, it is expandable if association macro is :many
8
+ # * <tt>:field_rejection_proc</tt> - Proc, that contains condition of how to reject field.
9
+ # By default form rejects all fields from parent tab that doesn't have current form as field nested_form
10
+ # ====Example
11
+ # form = Lolita::Configuration::NestedForm.new(Lolita::Configuration::Tab::Content.new,:comments)
12
+ # form.field_rejection_proc = Proc.new{|field|
13
+ # field.name.to_s.match(/_id$/)
14
+ # }
15
+ # # form exclude all fields that ends with _id
16
+ class NestedForm
17
+ include Lolita::Builder
18
+ @@last_nested_form=0
19
+
20
+ attr_reader :parent, :options, :field_style
21
+ attr_accessor :name, :expandable, :field_rejection_proc
22
+ attr_writer :build_method
23
+
24
+ def initialize parent,name=nil, options ={}
25
+ @parent=parent
26
+ @options = options
27
+ self.name=name || "nested_form_#{next_nested_form}"
28
+ set_attributes_from(options)
29
+ end
30
+
31
+ def allow_destroy?
32
+ dbi.klass.nested_attributes_options[name][:allow_destroy]
33
+ end
34
+
35
+ def update_only?
36
+ dbi.klass.nested_attributes_options[name][:update_only]
37
+ end
38
+
39
+ def build_method
40
+ @build_method || self.name
41
+ end
42
+ # Set field style - normal or simple. Default - normal.
43
+ def field_style=(value)
44
+ allowed_values = [:normal,:simple]
45
+ raise ArgumentError, "Only #{allowed_values.inspect} are allowed" unless allowed_values.include?(value)
46
+ @field_style = value
47
+ end
48
+
49
+ # Detect if it's possible to add more than one field group, like if model has many other objects.
50
+ def expandable?
51
+ @expandable == true || (@expandable == nil && macro == :many)
52
+ end
53
+
54
+ # Create field, that is not real field, but represents nested attributes as one.
55
+ # It is used to create label.
56
+ def as_field
57
+ Lolita::Configuration::Factory::Field.add(dbi,self.name, :string)
58
+ end
59
+
60
+ # Parent (a.k.a tab) dbi
61
+ def dbi
62
+ @parent.dbi
63
+ end
64
+
65
+ # Fields setter. Fields should be array and each element should be Lolita::Configuration::Field object.
66
+ def fields=(new_fields)
67
+ @fields = new_fields
68
+ end
69
+
70
+ # Return all fields. Each time fields ar returned from @fields if its defined or calculated by using #field_rejection_proc
71
+ # or collected from parent (tab) where fields nested form is same with self.
72
+ def fields
73
+ if @fields
74
+ @fields
75
+ elsif field_rejection_proc
76
+ self.parent.fields.reject(&field_rejection_proc)
77
+ else
78
+ self.parent.fields.reject{|f| f.nested_form!=self}
79
+ end
80
+ end
81
+
82
+ # Parent (tab) dbi klass
83
+ def klass
84
+ dbi.reflect_on_association(name).klass
85
+ end
86
+
87
+ # Parent (tab) dbi klass reflection with #name and macros of that.
88
+ def macro
89
+ dbi.reflect_on_association(name).macro
90
+ end
91
+
92
+ private
93
+
94
+ def next_nested_form
95
+ @@last_nested_form+=1
96
+ end
97
+
98
+ def set_attributes_from(options)
99
+ options.each{|key,value|
100
+ instance_variable_set(:"@#{key}",value)
101
+ }
102
+ end
103
+ end
104
+ end
105
105
  end
@@ -1,105 +1,105 @@
1
- module Lolita
2
- module Configuration
3
- # Proxy class for search. It supports two methods #with and #run.
4
- # By default with method accepts method name or nothing and creates Lolita::Search::Simple instance
5
- # that will be used to run search on current dbi.
6
- # By default search run against all content fields, but when _:fields_ options is passed it search in
7
- # those fields only.
8
- # ==== Example
9
- # class Post < ActiveRecord::Base
10
- # include Lolita::Configuration
11
- # lolita do
12
- # list do
13
- # search :fields => [:name]
14
- # end
15
- # end
16
- # end
17
- # #with method also accepts class or instance of some class, that will be used to run search.
18
- # That class should have #run method that accepts query and request.
19
- # ====Example
20
- # class MyCustomSearch
21
- # def initialize(dbi)
22
- # @dbi = dbi
23
- # end
24
- #
25
- # def run(query,request = nil)
26
- # @dbi.klass.where(:my_field => query)
27
- # end
28
- # end
29
- # Also you can put your search method in model. For more see Lolita::Search::Simple
30
- # ====Example
31
- # class Post < ActiveRecord::Base
32
- # include Lolita::Configuration
33
- # lolita do
34
- # list do
35
- # search :my_custom_search
36
- # end
37
- # end
38
- #
39
- # def self.my_custom_search(query,request)
40
- # self.where(:title => query, :user_id => request.params[:user_id])
41
- # end
42
- # end
43
- class Search
44
- include Lolita::Builder
45
- attr_reader :dbi
46
- attr_writer :with, :fields
47
-
48
- def initialize dbi, *args, &block
49
- @dbi = dbi
50
- set_attributes(args ? args.extract_options! : {})
51
- instance_eval(&block) if block_given?
52
- @with ||= args[0]!=true && args[0] ? args[0] : nil
53
- end
54
-
55
- def with(value = nil)
56
- @with = value if value
57
- if !@with || [String,Symbol].include?(@with.class)
58
- @with = Lolita::Search::Simple.new(dbi,@with, :fields => @fields)
59
- elsif @with.class == Class
60
- initialize_arity = @with.instance_method(:initialize).arity
61
- @with = if initialize_arity < 0 || initialize_arity > 1
62
- @with.new(dbi,:fields => @fields)
63
- else
64
- @with.new(dbi)
65
- end
66
- end
67
- @with
68
- end
69
-
70
- def run(query,request = nil)
71
- if self.with.method(:run).arity < 0 || self.with.method(:run).arity > 1
72
- self.with.run(query,request)
73
- else
74
- self.with.run(query)
75
- end
76
- end
77
-
78
- def update method_name,list,request
79
- if method_name == :paginate && list.search
80
- search_criteria = list.search.run(request && request.params[:q] || "",request)
81
- page_criteria = if search_criteria.respond_to?(:where)
82
- list.page_criteria.merge(search_criteria)
83
- elsif search_criteria.nil?
84
- list.page_criteria
85
- else
86
- search_criteria
87
- end
88
- list.instance_variable_set(:@page_criteria,page_criteria)
89
- end
90
- end
91
-
92
- private
93
-
94
- def set_attributes options
95
- if options.respond_to?(:each)
96
- options.each do |method_name, value|
97
- self.send(:"#{method_name}=",value)
98
- end
99
- end
100
- end
101
-
102
- end
103
-
104
- end
1
+ module Lolita
2
+ module Configuration
3
+ # Proxy class for search. It supports two methods #with and #run.
4
+ # By default with method accepts method name or nothing and creates Lolita::Search::Simple instance
5
+ # that will be used to run search on current dbi.
6
+ # By default search run against all content fields, but when _:fields_ options is passed it search in
7
+ # those fields only.
8
+ # ==== Example
9
+ # class Post < ActiveRecord::Base
10
+ # include Lolita::Configuration
11
+ # lolita do
12
+ # list do
13
+ # search :fields => [:name]
14
+ # end
15
+ # end
16
+ # end
17
+ # #with method also accepts class or instance of some class, that will be used to run search.
18
+ # That class should have #run method that accepts query and request.
19
+ # ====Example
20
+ # class MyCustomSearch
21
+ # def initialize(dbi)
22
+ # @dbi = dbi
23
+ # end
24
+ #
25
+ # def run(query,request = nil)
26
+ # @dbi.klass.where(:my_field => query)
27
+ # end
28
+ # end
29
+ # Also you can put your search method in model. For more see Lolita::Search::Simple
30
+ # ====Example
31
+ # class Post < ActiveRecord::Base
32
+ # include Lolita::Configuration
33
+ # lolita do
34
+ # list do
35
+ # search :my_custom_search
36
+ # end
37
+ # end
38
+ #
39
+ # def self.my_custom_search(query,request)
40
+ # self.where(:title => query, :user_id => request.params[:user_id])
41
+ # end
42
+ # end
43
+ class Search
44
+ include Lolita::Builder
45
+ attr_reader :dbi
46
+ attr_writer :with, :fields
47
+
48
+ def initialize dbi, *args, &block
49
+ @dbi = dbi
50
+ set_attributes(args ? args.extract_options! : {})
51
+ instance_eval(&block) if block_given?
52
+ @with ||= args[0]!=true && args[0] ? args[0] : nil
53
+ end
54
+
55
+ def with(value = nil)
56
+ @with = value if value
57
+ if !@with || [String,Symbol].include?(@with.class)
58
+ @with = Lolita::Search::Simple.new(dbi,@with, :fields => @fields)
59
+ elsif @with.class == Class
60
+ initialize_arity = @with.instance_method(:initialize).arity
61
+ @with = if initialize_arity < 0 || initialize_arity > 1
62
+ @with.new(dbi,:fields => @fields)
63
+ else
64
+ @with.new(dbi)
65
+ end
66
+ end
67
+ @with
68
+ end
69
+
70
+ def run(query,request = nil)
71
+ if self.with.method(:run).arity < 0 || self.with.method(:run).arity > 1
72
+ self.with.run(query,request)
73
+ else
74
+ self.with.run(query)
75
+ end
76
+ end
77
+
78
+ def update method_name,list,request
79
+ if method_name == :paginate && list.search
80
+ search_criteria = list.search.run(request && request.params[:q] || "",request)
81
+ page_criteria = if search_criteria.respond_to?(:where)
82
+ list.page_criteria.merge(search_criteria)
83
+ elsif search_criteria.nil?
84
+ list.page_criteria
85
+ else
86
+ search_criteria
87
+ end
88
+ list.instance_variable_set(:@page_criteria,page_criteria)
89
+ end
90
+ end
91
+
92
+ private
93
+
94
+ def set_attributes options
95
+ if options.respond_to?(:each)
96
+ options.each do |method_name, value|
97
+ self.send(:"#{method_name}=",value)
98
+ end
99
+ end
100
+ end
101
+
102
+ end
103
+
104
+ end
105
105
  end
@@ -1,56 +1,56 @@
1
- module Lolita
2
- module DBI
3
- # Lolita::DBI::Base is ORM Interface class, that handle the request to ORM classes.
4
- # Depending on given class DBI::Base detect which ORM class is used and include right adapter
5
- # for that class. Other Lolita classes that need to manipulate with data need to have dbi object
6
- # or it can be created in that class.
7
- # Lolita::DBI::Base support Mongoid and ActiveRecord::Base, or details see Lolita::Adapter.
8
- class Base
9
-
10
- def self.create(class_object)
11
- dbi = self.new(class_object)
12
- return dbi.adapter
13
- end
14
-
15
- attr_reader :adapter_name #return connected adapter name
16
- attr_reader :klass # return related orm class object
17
- attr_reader :adapter # connected Adaptee for adapter
18
-
19
- # Expect ORM class that is supported by Lolita. See Adapter for available adapters.
20
- def initialize(class_object)
21
- @klass=class_object
22
- detect_adapter
23
- connect_adapter
24
- end
25
-
26
- # Detect which ORM class is given and based on it connect Adapter.
27
- def detect_adapter
28
- if defined?(Mongoid) && defined?(Mongoid::Document) && self.klass.ancestors.include?(Mongoid::Document)
29
- @adapter_name=:mongoid
30
- elsif defined?(ActiveRecord) && defined?(ActiveRecord::Base) && self.klass.ancestors.include?(ActiveRecord::Base)
31
- @adapter_name=:active_record
32
- else
33
- raise NotORMClassError.new("Lolita::DBI::Base can not find appropriate #{self.klass} class adapter.")
34
- end
35
- end
36
-
37
- # Connect Adapter by including adapter module into DBI::Base class.
38
- def connect_adapter()
39
- @adapter="Lolita::Adapter::#{self.adapter_name.to_s.camelize}".constantize.new(self)
40
- end
41
-
42
- def method_missing(metod,*args,&block)
43
- @adapter.send(metod,*args,&block)
44
- end
45
-
46
- class << self
47
- # Return Array of available adapters.
48
- def adapters
49
- Dir[File.expand_path(File.join(File.dirname(__FILE__),'..','adapter','**','*.rb'))].map {|f|
50
- File.basename(f,".rb").to_sym
51
- }.reject{|el| el==:abstract_adapter}
52
- end
53
- end
54
- end
55
- end
56
- end
1
+ module Lolita
2
+ module DBI
3
+ # Lolita::DBI::Base is ORM Interface class, that handle the request to ORM classes.
4
+ # Depending on given class DBI::Base detect which ORM class is used and include right adapter
5
+ # for that class. Other Lolita classes that need to manipulate with data need to have dbi object
6
+ # or it can be created in that class.
7
+ # Lolita::DBI::Base support Mongoid and ActiveRecord::Base, or details see Lolita::Adapter.
8
+ class Base
9
+
10
+ def self.create(class_object)
11
+ dbi = self.new(class_object)
12
+ return dbi.adapter
13
+ end
14
+
15
+ attr_reader :adapter_name #return connected adapter name
16
+ attr_reader :klass # return related orm class object
17
+ attr_reader :adapter # connected Adaptee for adapter
18
+
19
+ # Expect ORM class that is supported by Lolita. See Adapter for available adapters.
20
+ def initialize(class_object)
21
+ @klass=class_object
22
+ detect_adapter
23
+ connect_adapter
24
+ end
25
+
26
+ # Detect which ORM class is given and based on it connect Adapter.
27
+ def detect_adapter
28
+ if defined?(Mongoid) && defined?(Mongoid::Document) && self.klass.ancestors.include?(Mongoid::Document)
29
+ @adapter_name=:mongoid
30
+ elsif defined?(ActiveRecord) && defined?(ActiveRecord::Base) && self.klass.ancestors.include?(ActiveRecord::Base)
31
+ @adapter_name=:active_record
32
+ else
33
+ raise NotORMClassError.new("Lolita::DBI::Base can not find appropriate #{self.klass} class adapter.")
34
+ end
35
+ end
36
+
37
+ # Connect Adapter by including adapter module into DBI::Base class.
38
+ def connect_adapter()
39
+ @adapter="Lolita::Adapter::#{self.adapter_name.to_s.camelize}".constantize.new(self)
40
+ end
41
+
42
+ def method_missing(metod,*args,&block)
43
+ @adapter.send(metod,*args,&block)
44
+ end
45
+
46
+ class << self
47
+ # Return Array of available adapters.
48
+ def adapters
49
+ Dir[File.expand_path(File.join(File.dirname(__FILE__),'..','adapter','**','*.rb'))].map {|f|
50
+ File.basename(f,".rb").to_sym
51
+ }.reject{|el| el==:abstract_adapter}
52
+ end
53
+ end
54
+ end
55
+ end
56
+ end