lolita 3.1.10 → 3.1.11

Sign up to get free protection for your applications and to get access to all the features.
Files changed (239) hide show
  1. data/.document +5 -5
  2. data/.rspec +2 -2
  3. data/GUIDELINES.rdoc +24 -24
  4. data/Gemfile +26 -26
  5. data/History.rdoc +162 -154
  6. data/LICENSE.txt +22 -22
  7. data/README.rdoc +98 -98
  8. data/Rakefile +40 -40
  9. data/VERSION +1 -1
  10. data/app/controllers/lolita/info_controller.rb +41 -41
  11. data/app/controllers/lolita/rest_controller.rb +130 -130
  12. data/app/helpers/components/lolita/configuration/list_component.rb +10 -10
  13. data/app/helpers/lolita_helper.rb +11 -11
  14. data/app/views/components/lolita/configuration/column/_display.html.erb +4 -4
  15. data/app/views/components/lolita/configuration/column/_header.html.erb +7 -7
  16. data/app/views/components/lolita/configuration/column/_sort.html.erb +4 -4
  17. data/app/views/components/lolita/configuration/columns/_body.html.erb +4 -4
  18. data/app/views/components/lolita/configuration/columns/_display.html.erb +1 -1
  19. data/app/views/components/lolita/configuration/columns/_first.html.erb +2 -2
  20. data/app/views/components/lolita/configuration/columns/_first_column_header.html.erb +3 -3
  21. data/app/views/components/lolita/configuration/columns/_header.html.erb +8 -8
  22. data/app/views/components/lolita/configuration/columns/_last.html.erb +4 -4
  23. data/app/views/components/lolita/configuration/columns/_last_column_header.html.erb +2 -2
  24. data/app/views/components/lolita/configuration/columns/_row.html.erb +7 -7
  25. data/app/views/components/lolita/configuration/field/_display.html.erb +9 -9
  26. data/app/views/components/lolita/configuration/field/_label.html.erb +1 -1
  27. data/app/views/components/lolita/configuration/field/_object.html.erb +1 -1
  28. data/app/views/components/lolita/configuration/field/array/_display.html.erb +4 -4
  29. data/app/views/components/lolita/configuration/field/array/habtm/_display.html.erb +26 -26
  30. data/app/views/components/lolita/configuration/field/array/select/_display.html.erb +5 -5
  31. data/app/views/components/lolita/configuration/field/boolean/filter/_display.html.erb +1 -1
  32. data/app/views/components/lolita/configuration/field/date/_display.html.erb +1 -1
  33. data/app/views/components/lolita/configuration/field/date_time/date/_display.html.erb +1 -1
  34. data/app/views/components/lolita/configuration/field/integer/_display.html.erb +1 -1
  35. data/app/views/components/lolita/configuration/field/string/_display.html.erb +4 -4
  36. data/app/views/components/lolita/configuration/field/string/disabled/_display.html.erb +1 -1
  37. data/app/views/components/lolita/configuration/field/string/password/_display.html.erb +3 -3
  38. data/app/views/components/lolita/configuration/field/string/text/_display.html.erb +18 -18
  39. data/app/views/components/lolita/configuration/field_set/_display.html.erb +5 -5
  40. data/app/views/components/lolita/configuration/list/_display.html.erb +10 -10
  41. data/app/views/components/lolita/configuration/list/_filter.html.erb +7 -7
  42. data/app/views/components/lolita/configuration/list/_new_resource.html.erb +4 -4
  43. data/app/views/components/lolita/configuration/list/_title.html.erb +4 -4
  44. data/app/views/components/lolita/configuration/tab/_display.html.erb +17 -17
  45. data/app/views/components/lolita/configuration/tab/_fields.html.erb +6 -6
  46. data/app/views/components/lolita/configuration/tab/content/_display.html.erb +1 -1
  47. data/app/views/components/lolita/configuration/tab/default/_display.html.erb +8 -8
  48. data/app/views/components/lolita/configuration/tabs/_display.html.erb +10 -10
  49. data/app/views/components/lolita/navigation/_display.html.erb +2 -2
  50. data/app/views/components/lolita/navigation/_tree.html.erb +38 -38
  51. data/app/views/components/lolita/shared/_flash.html.erb +5 -5
  52. data/app/views/components/lolita/shared/_header.html.erb +8 -8
  53. data/app/views/components/lolita/shared/_right_sidebar.html.erb +13 -13
  54. data/app/views/layouts/lolita/application.html.erb +44 -44
  55. data/app/views/lolita/info/index.html.erb +232 -232
  56. data/app/views/lolita/rest/form.html.erb +1 -1
  57. data/app/views/lolita/rest/index.html.erb +1 -1
  58. data/author +1 -1
  59. data/config/locales/default/lv.yml +180 -180
  60. data/config/locales/en.yml +20 -20
  61. data/config/locales/lv.yml +20 -20
  62. data/config/routes.rb +3 -3
  63. data/db/seed.rb +1 -1
  64. data/features/create_page.feature +19 -19
  65. data/features/step_definitions/lolita_steps.rb +7 -7
  66. data/features/step_definitions/web_steps.rb +219 -219
  67. data/features/support/env.rb +73 -73
  68. data/features/support/paths.rb +35 -35
  69. data/lib/generators/helpers/file_helper.rb +22 -22
  70. data/lib/generators/lolita/assets_generator.rb +18 -18
  71. data/lib/generators/lolita/install_generator.rb +28 -28
  72. data/lib/generators/templates/lolita.rb +19 -19
  73. data/lib/lolita.rb +184 -184
  74. data/lib/lolita/adapter/abstract_adapter.rb +13 -13
  75. data/lib/lolita/adapter/active_record.rb +148 -148
  76. data/lib/lolita/adapter/mongoid.rb +127 -127
  77. data/lib/lolita/base_configuration.rb +165 -165
  78. data/lib/lolita/builder.rb +249 -249
  79. data/lib/lolita/configuration/base.rb +76 -76
  80. data/lib/lolita/configuration/column.rb +93 -94
  81. data/lib/lolita/configuration/columns.rb +66 -66
  82. data/lib/lolita/configuration/factory.rb +55 -55
  83. data/lib/lolita/configuration/field.rb +216 -216
  84. data/lib/lolita/configuration/field/array.rb +75 -75
  85. data/lib/lolita/configuration/field/big_decimal.rb +12 -12
  86. data/lib/lolita/configuration/field/boolean.rb +12 -12
  87. data/lib/lolita/configuration/field/date.rb +12 -12
  88. data/lib/lolita/configuration/field/date_time.rb +13 -13
  89. data/lib/lolita/configuration/field/integer.rb +12 -12
  90. data/lib/lolita/configuration/field/string.rb +13 -13
  91. data/lib/lolita/configuration/field/time.rb +13 -13
  92. data/lib/lolita/configuration/field_set.rb +25 -25
  93. data/lib/lolita/configuration/fields.rb +35 -35
  94. data/lib/lolita/configuration/filter.rb +108 -108
  95. data/lib/lolita/configuration/list.rb +104 -104
  96. data/lib/lolita/configuration/page.rb +125 -124
  97. data/lib/lolita/configuration/tab.rb +187 -187
  98. data/lib/lolita/configuration/tab/content.rb +21 -21
  99. data/lib/lolita/configuration/tab/default.rb +25 -25
  100. data/lib/lolita/configuration/tabs.rb +132 -132
  101. data/lib/lolita/controllers/component_helpers.rb +127 -127
  102. data/lib/lolita/controllers/internal_helpers.rb +109 -109
  103. data/lib/lolita/controllers/url_helpers.rb +111 -111
  104. data/lib/lolita/controllers/user_helpers.rb +32 -32
  105. data/lib/lolita/controllers/view_user_helpers.rb +12 -12
  106. data/lib/lolita/dbi/base.rb +50 -50
  107. data/lib/lolita/errors.rb +12 -12
  108. data/lib/lolita/hooks.rb +355 -355
  109. data/lib/lolita/hooks/named_hook.rb +125 -125
  110. data/lib/lolita/lazy_loader.rb +46 -46
  111. data/lib/lolita/mapping.rb +55 -55
  112. data/lib/lolita/modules.rb +6 -6
  113. data/lib/lolita/modules/rest.rb +10 -10
  114. data/lib/lolita/navigation/branch.rb +132 -132
  115. data/lib/lolita/navigation/tree.rb +116 -116
  116. data/lib/lolita/observed_array.rb +74 -74
  117. data/lib/lolita/rails.rb +20 -20
  118. data/lib/lolita/rails/all.rb +10 -10
  119. data/lib/lolita/rails/routes.rb +133 -133
  120. data/lib/lolita/ruby_ext/accessors.rb +26 -26
  121. data/lib/lolita/support/formatter.rb +62 -62
  122. data/lib/lolita/support/formatter/rails.rb +56 -56
  123. data/lib/lolita/test/matchers.rb +77 -77
  124. data/lolita.gemspec +2 -2
  125. data/public/javascripts/jquery-1.6.min.js +15 -15
  126. data/public/javascripts/jquery-ui-1.8.13.min.js +407 -407
  127. data/public/javascripts/lolita/main.js +39 -39
  128. data/public/javascripts/lolita/tab.js +41 -41
  129. data/public/javascripts/modernizr-1.7.min.js +1 -1
  130. data/public/javascripts/rails.js +137 -137
  131. data/public/javascripts/tinymce/langs/en.js +221 -221
  132. data/public/javascripts/tinymce/license.txt +504 -504
  133. data/public/javascripts/tinymce/themes/advanced/about.htm +52 -52
  134. data/public/javascripts/tinymce/themes/advanced/anchor.htm +26 -26
  135. data/public/javascripts/tinymce/themes/advanced/charmap.htm +51 -51
  136. data/public/javascripts/tinymce/themes/advanced/color_picker.htm +74 -74
  137. data/public/javascripts/tinymce/themes/advanced/editor_template_src.js +1328 -1328
  138. data/public/javascripts/tinymce/themes/advanced/image.htm +80 -80
  139. data/public/javascripts/tinymce/themes/advanced/js/about.js +73 -73
  140. data/public/javascripts/tinymce/themes/advanced/js/anchor.js +42 -42
  141. data/public/javascripts/tinymce/themes/advanced/js/charmap.js +354 -354
  142. data/public/javascripts/tinymce/themes/advanced/js/color_picker.js +329 -329
  143. data/public/javascripts/tinymce/themes/advanced/js/image.js +247 -247
  144. data/public/javascripts/tinymce/themes/advanced/js/link.js +153 -153
  145. data/public/javascripts/tinymce/themes/advanced/js/source_editor.js +56 -56
  146. data/public/javascripts/tinymce/themes/advanced/langs/en.js +68 -68
  147. data/public/javascripts/tinymce/themes/advanced/langs/en_dlg.js +53 -53
  148. data/public/javascripts/tinymce/themes/advanced/link.htm +57 -57
  149. data/public/javascripts/tinymce/themes/advanced/shortcuts.htm +47 -47
  150. data/public/javascripts/tinymce/themes/advanced/skins/cirkuit/content.css +66 -66
  151. data/public/javascripts/tinymce/themes/advanced/skins/cirkuit/dialog.css +117 -117
  152. data/public/javascripts/tinymce/themes/advanced/skins/cirkuit/ui.css +988 -988
  153. data/public/javascripts/tinymce/themes/advanced/source_editor.htm +25 -25
  154. data/public/javascripts/tinymce/tiny_mce_popup.js +4 -4
  155. data/public/javascripts/tinymce_config.js +15 -15
  156. data/public/stylesheets/lolita/default.css +169 -169
  157. data/public/stylesheets/lolita/style.css +253 -253
  158. data/spec/adapter_helper.rb +43 -43
  159. data/spec/builder_spec.rb +120 -120
  160. data/spec/configuration/base_spec.rb +44 -44
  161. data/spec/configuration/column_spec.rb +89 -89
  162. data/spec/configuration/columns_spec.rb +54 -54
  163. data/spec/configuration/field_set_spec.rb +12 -12
  164. data/spec/configuration/field_spec.rb +118 -118
  165. data/spec/configuration/filter_spec.rb +122 -122
  166. data/spec/configuration/list_spec.rb +76 -76
  167. data/spec/configuration/page_spec.rb +19 -19
  168. data/spec/configuration/tab_spec.rb +165 -165
  169. data/spec/configuration/tabs_spec.rb +106 -106
  170. data/spec/controllers/component_helpers_spec.rb +5 -5
  171. data/spec/controllers/internal_helpers_spec.rb +76 -76
  172. data/spec/controllers/lolita_rest_nested_resources_spec.rb +33 -33
  173. data/spec/controllers/lolita_rest_spec.rb +53 -53
  174. data/spec/dbi/base_spec.rb +44 -44
  175. data/spec/hooks_spec.rb +257 -257
  176. data/spec/lolita_spec.rb +13 -13
  177. data/spec/mapping_spec.rb +29 -29
  178. data/spec/navigation/branch_spec.rb +81 -81
  179. data/spec/navigation/tree_spec.rb +73 -73
  180. data/spec/orm/mongoid.rb +11 -11
  181. data/spec/rails_app/app/controllers/application_controller.rb +3 -3
  182. data/spec/rails_app/app/helpers/application_helper.rb +3 -3
  183. data/spec/rails_app/app/mongoid/address.rb +7 -7
  184. data/spec/rails_app/app/mongoid/category.rb +5 -5
  185. data/spec/rails_app/app/mongoid/comment.rb +5 -5
  186. data/spec/rails_app/app/mongoid/post.rb +18 -18
  187. data/spec/rails_app/app/mongoid/preference.rb +5 -5
  188. data/spec/rails_app/app/mongoid/profile.rb +13 -13
  189. data/spec/rails_app/app/mongoid/tag.rb +3 -3
  190. data/spec/rails_app/app/views/components/lolita/configuration/list/_body_cell.html.erb +1 -1
  191. data/spec/rails_app/config/application.rb +26 -26
  192. data/spec/rails_app/config/boot.rb +13 -13
  193. data/spec/rails_app/config/environment.rb +5 -5
  194. data/spec/rails_app/config/environments/development.rb +19 -19
  195. data/spec/rails_app/config/environments/production.rb +33 -33
  196. data/spec/rails_app/config/environments/test.rb +33 -33
  197. data/spec/rails_app/config/initializers/backtrace_silencers.rb +7 -7
  198. data/spec/rails_app/config/initializers/inflections.rb +2 -2
  199. data/spec/rails_app/config/initializers/secret_token.rb +1 -1
  200. data/spec/rails_app/config/routes.rb +2 -2
  201. data/spec/rails_app/lib/lolita/configuration/field/my_custom_collection.rb +13 -13
  202. data/spec/rails_app/public/javascripts/jquery-1.5.1.min.js +15 -15
  203. data/spec/rails_app/public/javascripts/lolita/main.js +6 -6
  204. data/spec/rails_app/public/javascripts/lolita/tab.js +40 -40
  205. data/spec/rails_app/public/javascripts/modernizr-1.7.min.js +1 -1
  206. data/spec/rails_app/public/javascripts/rails.js +137 -137
  207. data/spec/rails_app/public/javascripts/tinymce/langs/en.js +221 -221
  208. data/spec/rails_app/public/javascripts/tinymce/license.txt +504 -504
  209. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/about.htm +52 -52
  210. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/anchor.htm +26 -26
  211. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/charmap.htm +51 -51
  212. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/color_picker.htm +74 -74
  213. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/editor_template_src.js +1328 -1328
  214. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/image.htm +80 -80
  215. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/about.js +73 -73
  216. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/anchor.js +42 -42
  217. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/charmap.js +354 -354
  218. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/color_picker.js +329 -329
  219. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/image.js +247 -247
  220. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/link.js +153 -153
  221. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/source_editor.js +56 -56
  222. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/langs/en.js +68 -68
  223. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/langs/en_dlg.js +53 -53
  224. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/link.htm +57 -57
  225. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/shortcuts.htm +47 -47
  226. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/content.css +66 -66
  227. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/dialog.css +117 -117
  228. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/ui.css +988 -988
  229. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/source_editor.htm +25 -25
  230. data/spec/rails_app/public/javascripts/tinymce/tiny_mce_popup.js +4 -4
  231. data/spec/rails_app/public/stylesheets/lolita/default.css +169 -169
  232. data/spec/rails_app/public/stylesheets/lolita/style.css +214 -214
  233. data/spec/routing/routes_spec.rb +15 -15
  234. data/spec/spec_helper.rb +46 -46
  235. data/spec/support/factories/category.rb +3 -3
  236. data/spec/support/factories/post.rb +4 -4
  237. data/spec/support/factories/tag.rb +2 -2
  238. data/spec/support/formatter_spec.rb +42 -42
  239. metadata +31 -31
@@ -1,109 +1,109 @@
1
- # coding: utf-8
2
- module Lolita
3
- module Configuration
4
- # Lolita::Configuration::Filter is for filtering data in list view.
5
- # By now it supports these field types:
6
- # - Array
7
- # - Boolean
8
- #
9
- # To use it, call "filter" method in list block, filter method accepts field names
10
- # as arguments. You can pass block and configure each field. Field configuration is just like in tab configuration.
11
- #
12
- # === Examples
13
- #
14
- # # this will build country select field and is_deleted checkbox
15
- # list do
16
- # filter :country, :is_deleted
17
- # end
18
- #
19
- # # For example you have text field "status" with values opened,closed,rejected
20
- # list do
21
- # filter do
22
- # field :status, :array, :options_for_select => %w(open closed rejected)
23
- # field :is_deleted, :title => "Deleted"
24
- # end
25
- # end
26
- #
27
- class Filter
28
- include Lolita::Builder
29
- attr_reader :dbi
30
-
31
- def initialize(dbi,*args,&block)
32
- @dbi = dbi
33
- @fields=Lolita::Configuration::Fields.new
34
- set_attributes(*args)
35
- self.instance_eval(&block) if block_given?
36
- end
37
-
38
- def field *args, &block
39
- field=Lolita::Configuration::Field.add(self.dbi,*args,&block)
40
- field
41
- @fields<<field
42
- field
43
- end
44
-
45
- # Set all fields in tab. Accept <code>fields</code> as Array.
46
- # Each array element can be Lolita::Configuration::Field object or
47
- # Hash, that will be passed to #field method.
48
- def fields=(fields)
49
- if fields.is_a?(Array)
50
- fields.each{|field_attr|
51
- if field_attr.is_a?(Lolita::Configuration::Field)
52
- @fields<<field_attr
53
- else
54
- self.field(field_attr)
55
- end
56
- }
57
- end
58
- end
59
-
60
- def fields(*args, &block)
61
- unless args.empty?
62
- args.each do |field_name|
63
- f = field(field_name)
64
- f.instance_eval(&block) if block_given?
65
- end
66
- end
67
- if @fields.empty?
68
- field :search
69
- end
70
- @fields
71
- end
72
-
73
- # Used to set attributes if block not given.
74
- def set_attributes(*args)
75
- if args && args[0]
76
- if args[0].is_a?(Hash)
77
- args[0].each{|m,value|
78
- self.send("#{m}=".to_sym,value)
79
- }
80
- else
81
- fields *args
82
- end
83
- end
84
- end
85
-
86
- def field_name field
87
- "f_#{field.name}"
88
- end
89
-
90
- def options_for_select field
91
- if field.options_for_select
92
- field.options_for_select
93
- else
94
- if field.association_values.respond_to?(:call)
95
- field.association_values.call(self)
96
- else
97
- field.association_values
98
- end
99
- end
100
- end
101
-
102
- def html_option_for_select field
103
- {
104
- :include_blank => ::I18n.t('lolita.filter.include_blank_by_title', :title => field.title)
105
- }
106
- end
107
- end
108
- end
1
+ # coding: utf-8
2
+ module Lolita
3
+ module Configuration
4
+ # Lolita::Configuration::Filter is for filtering data in list view.
5
+ # By now it supports these field types:
6
+ # - Array
7
+ # - Boolean
8
+ #
9
+ # To use it, call "filter" method in list block, filter method accepts field names
10
+ # as arguments. You can pass block and configure each field. Field configuration is just like in tab configuration.
11
+ #
12
+ # === Examples
13
+ #
14
+ # # this will build country select field and is_deleted checkbox
15
+ # list do
16
+ # filter :country, :is_deleted
17
+ # end
18
+ #
19
+ # # For example you have text field "status" with values opened,closed,rejected
20
+ # list do
21
+ # filter do
22
+ # field :status, :array, :options_for_select => %w(open closed rejected)
23
+ # field :is_deleted, :title => "Deleted"
24
+ # end
25
+ # end
26
+ #
27
+ class Filter
28
+ include Lolita::Builder
29
+ attr_reader :dbi
30
+
31
+ def initialize(dbi,*args,&block)
32
+ @dbi = dbi
33
+ @fields=Lolita::Configuration::Fields.new
34
+ set_attributes(*args)
35
+ self.instance_eval(&block) if block_given?
36
+ end
37
+
38
+ def field *args, &block
39
+ field=Lolita::Configuration::Field.add(self.dbi,*args,&block)
40
+ field
41
+ @fields<<field
42
+ field
43
+ end
44
+
45
+ # Set all fields in tab. Accept <code>fields</code> as Array.
46
+ # Each array element can be Lolita::Configuration::Field object or
47
+ # Hash, that will be passed to #field method.
48
+ def fields=(fields)
49
+ if fields.is_a?(Array)
50
+ fields.each{|field_attr|
51
+ if field_attr.is_a?(Lolita::Configuration::Field)
52
+ @fields<<field_attr
53
+ else
54
+ self.field(field_attr)
55
+ end
56
+ }
57
+ end
58
+ end
59
+
60
+ def fields(*args, &block)
61
+ unless args.empty?
62
+ args.each do |field_name|
63
+ f = field(field_name)
64
+ f.instance_eval(&block) if block_given?
65
+ end
66
+ end
67
+ if @fields.empty?
68
+ field :search
69
+ end
70
+ @fields
71
+ end
72
+
73
+ # Used to set attributes if block not given.
74
+ def set_attributes(*args)
75
+ if args && args[0]
76
+ if args[0].is_a?(Hash)
77
+ args[0].each{|m,value|
78
+ self.send("#{m}=".to_sym,value)
79
+ }
80
+ else
81
+ fields *args
82
+ end
83
+ end
84
+ end
85
+
86
+ def field_name field
87
+ "f_#{field.name}"
88
+ end
89
+
90
+ def options_for_select field
91
+ if field.options_for_select
92
+ field.options_for_select
93
+ else
94
+ if field.association_values.respond_to?(:call)
95
+ field.association_values.call(self)
96
+ else
97
+ field.association_values
98
+ end
99
+ end
100
+ end
101
+
102
+ def html_option_for_select field
103
+ {
104
+ :include_blank => ::I18n.t('lolita.filter.include_blank_by_title', :title => field.title)
105
+ }
106
+ end
107
+ end
108
+ end
109
109
  end
@@ -1,105 +1,105 @@
1
- module Lolita
2
- module Configuration
3
- class List
4
- include Lolita::Builder
5
-
6
- attr_reader :dbi,:initialized_attributes
7
-
8
- def initialize(*args,&block)
9
- if args && args[0].is_a?(Lolita::DBI::Base)
10
- @dbi=args.shift
11
- end
12
- @columns=Lolita::Configuration::Columns.new(self)
13
- @set_attributes=[]
14
- set_attributes(*args)
15
- self.instance_eval(&block) if block_given?
16
- self.generate!()
17
- end
18
-
19
- # Look for methods in Page class. Load @page on demand and call method on it.
20
- def method_missing(method_name,*args,&block)
21
- if Lolita::Configuration::Page.public_instance_methods.include?(method_name.to_sym)
22
- @page||=Lolita::Configuration::Page.new(@dbi)
23
- @page.send(method_name.to_sym,*args,&block)
24
- else
25
- super
26
- end
27
- end
28
- # Set columns. Allowed classes are Lolita::Configuration::Columns or
29
- # Array.
30
- def columns=(value)
31
- set_attribute(:columns)
32
- if value.is_a?(Lolita::Configuration::Columns)
33
- @columns=value
34
- elsif value.is_a?(Array)
35
- value.each{|el| @columns<<el}
36
- else
37
- raise ArgumentError.new("Columns must bet Array or Lolita::Configuration::Columns.")
38
- end
39
- end
40
-
41
- # Get list columns (also block setter)
42
- def columns(*args)
43
- if args && !args.empty?
44
- self.columns=args
45
- end
46
- self.generate!
47
- @columns
48
- end
49
-
50
- # Generate uninitialized attributes
51
- def generate!()
52
- @columns.generate! unless is_set?(:columns)
53
- end
54
-
55
- # checks if filter defined
56
- def filter?
57
- @filter.is_a?(Lolita::Configuration::Filter)
58
- end
59
-
60
- # Filter by now works only for these field types:
61
- # - belongs_to
62
- # - boolean
63
- #
64
- def filter(*args,&block)
65
- @filter ||= Lolita::Configuration::Filter.new(self.dbi,*args,&block)
66
- end
67
-
68
- # Block setter for columns
69
- def column(*args,&block)
70
- set_attribute(:columns)
71
- if block_given?
72
- @columns<<block
73
- else
74
- @columns.add(Lolita::Configuration::Column.new(@dbi,*args))
75
- end
76
- end
77
-
78
- private
79
-
80
- # Used to set attributes if block not given.
81
- def set_attributes(*args)
82
- if args && args[0]
83
- if args[0].is_a?(Hash)
84
- args[0].each{|m,value|
85
- self.send("#{m}=".to_sym,value)
86
- }
87
- else
88
- raise ArgumentError.new("Lolita::Configuration::List arguments must be Hash instead of #{args[0].class}")
89
- end
90
- end
91
- end
92
-
93
- # Mark attribute as set.
94
- def set_attribute(var)
95
- @set_attributes<<var unless is_set?(var)
96
- end
97
-
98
- # Determine if attribute is set and don't need to generate it.
99
- def is_set?(var)
100
- @set_attributes.include?(var)
101
- end
102
-
103
- end
104
- end
1
+ module Lolita
2
+ module Configuration
3
+ class List
4
+ include Lolita::Builder
5
+
6
+ attr_reader :dbi,:initialized_attributes
7
+
8
+ def initialize(*args,&block)
9
+ if args && args[0].is_a?(Lolita::DBI::Base)
10
+ @dbi=args.shift
11
+ end
12
+ @columns=Lolita::Configuration::Columns.new(self)
13
+ @set_attributes=[]
14
+ set_attributes(*args)
15
+ self.instance_eval(&block) if block_given?
16
+ self.generate!()
17
+ end
18
+
19
+ # Look for methods in Page class. Load @page on demand and call method on it.
20
+ def method_missing(method_name,*args,&block)
21
+ if Lolita::Configuration::Page.public_instance_methods.include?(method_name.to_sym)
22
+ @page||=Lolita::Configuration::Page.new(@dbi,self)
23
+ @page.send(method_name.to_sym,*args,&block)
24
+ else
25
+ super
26
+ end
27
+ end
28
+ # Set columns. Allowed classes are Lolita::Configuration::Columns or
29
+ # Array.
30
+ def columns=(value)
31
+ set_attribute(:columns)
32
+ if value.is_a?(Lolita::Configuration::Columns)
33
+ @columns=value
34
+ elsif value.is_a?(Array)
35
+ value.each{|el| @columns<<el}
36
+ else
37
+ raise ArgumentError.new("Columns must bet Array or Lolita::Configuration::Columns.")
38
+ end
39
+ end
40
+
41
+ # Get list columns (also block setter)
42
+ def columns(*args)
43
+ if args && !args.empty?
44
+ self.columns=args
45
+ end
46
+ self.generate!
47
+ @columns
48
+ end
49
+
50
+ # Generate uninitialized attributes
51
+ def generate!()
52
+ @columns.generate! unless is_set?(:columns)
53
+ end
54
+
55
+ # checks if filter defined
56
+ def filter?
57
+ @filter.is_a?(Lolita::Configuration::Filter)
58
+ end
59
+
60
+ # Filter by now works only for these field types:
61
+ # - belongs_to
62
+ # - boolean
63
+ #
64
+ def filter(*args,&block)
65
+ @filter ||= Lolita::Configuration::Filter.new(self.dbi,*args,&block)
66
+ end
67
+
68
+ # Block setter for columns
69
+ def column(*args,&block)
70
+ set_attribute(:columns)
71
+ if block_given?
72
+ @columns<<block
73
+ else
74
+ @columns.add(Lolita::Configuration::Column.new(@dbi,*args))
75
+ end
76
+ end
77
+
78
+ private
79
+
80
+ # Used to set attributes if block not given.
81
+ def set_attributes(*args)
82
+ if args && args[0]
83
+ if args[0].is_a?(Hash)
84
+ args[0].each{|m,value|
85
+ self.send("#{m}=".to_sym,value)
86
+ }
87
+ else
88
+ raise ArgumentError.new("Lolita::Configuration::List arguments must be Hash instead of #{args[0].class}")
89
+ end
90
+ end
91
+ end
92
+
93
+ # Mark attribute as set.
94
+ def set_attribute(var)
95
+ @set_attributes<<var unless is_set?(var)
96
+ end
97
+
98
+ # Determine if attribute is set and don't need to generate it.
99
+ def is_set?(var)
100
+ @set_attributes.include?(var)
101
+ end
102
+
103
+ end
104
+ end
105
105
  end
@@ -1,125 +1,126 @@
1
- module Lolita
2
- module Configuration
3
- class Page
4
-
5
- # page options is used to define specific options for pagination like :joins or :conditions
6
- lolita_accessor :page_options
7
- attr_writer :per_page
8
- def initialize(dbi)
9
- @dbi=dbi
10
- @sort_columns=[]
11
- end
12
-
13
- # Records per page (also block setter)
14
- def per_page(value=nil)
15
- if value
16
- @per_page=value
17
- self
18
- else
19
- @per_page
20
- end
21
- end
22
-
23
- # Define new sort column with ascending sort direction
24
- def asc(column)
25
- @sort_columns<<[column.to_sym,:asc]
26
- self
27
- end
28
-
29
- # Define new sort columns with descending sort direction
30
- def desc(column)
31
- @sort_columns<<[column.to_sym,:desc]
32
- self
33
- end
34
-
35
- # Return all sort columns.
36
- # Each column is an Array where first element is column name and second is direction
37
- # ====Example
38
- # page=Lolita::Configuration::Page.new(@dbi)
39
- # page.asc(:created_at)
40
- # page.sort_columns #=> [[:created_at,:asc]]
41
- def sort_columns
42
- @sort_columns
43
- end
44
-
45
- # Paginate
46
- # Options:
47
- # * <tt>:per_page</tt> - record count per page, default uses list.per_page
48
- # * <tt>:page</tt> - what page to show
49
- # * <tt>:sort_columns</tt> - sort columns for page. See #sort_columns
50
- # * <tt>:asc</tt> - column to sort in ascending direction
51
- # list.paginate(1,:asc=>:created_at)
52
- # * <tt>:desc</tt> - column to sort in descending direction
53
- #
54
- # ====Example
55
- # list.paginate(1)
56
- # list.paginate
57
- # list.paginate(:per_page=>2,:page=>1)
58
- def paginate *args
59
- options=args ? args.extract_options! : {}
60
- hold=options.delete(:hold)
61
- @params=options.delete(:params)
62
- set_values_from_options(options)
63
- options[:page]||=((args && args.first) || 1)
64
- options[:per_page]||=@per_page || 10
65
- @last_options=options
66
- @last_options[:sort]=self.sort_columns unless self.sort_columns.empty?
67
- unless hold
68
- get_page()
69
- end
70
- end
71
-
72
- def get_page()
73
- @page=@dbi.filter(filter_conditions).paginate((@page_options||{}).merge(@last_options))
74
- end
75
-
76
- # Return last paginated page
77
- # ====Example
78
- # list.paginate(2)
79
- # # call page to avoid another call to db
80
- # list.page
81
- def last_page
82
- @page
83
- end
84
-
85
- private
86
-
87
- # returns filter conditions as Hash for get_page()
88
- def filter_conditions
89
- if @params
90
- conditions = {}
91
- @params.each_pair do |k,v|
92
- if k.to_s =~ /^f_([a-z0-9_\-]+)$/ && !v.to_s.strip.blank?
93
- conditions[$1.to_sym] = v
94
- end
95
- end
96
- conditions
97
- else
98
- {}
99
- end
100
- end
101
-
102
- def allowed_options
103
- [:sort_columns,:asc,:desc]
104
- end
105
-
106
- def set_values_from_options(options)
107
- allowed_options.each{|meth|
108
- if options.has_key?(meth)
109
- self.send(meth,options.delete(meth))
110
- end
111
- }
112
- parse_params
113
- end
114
-
115
- def parse_params
116
- if @params
117
- if @params.has_key?(:sc)
118
- self.send((@params[:sd] || :asc).to_sym,@params[:sc])
119
- end
120
- end
121
- end
122
-
123
- end
124
- end
1
+ module Lolita
2
+ module Configuration
3
+ class Page
4
+
5
+ # page options is used to define specific options for pagination like :joins or :conditions
6
+ lolita_accessor :page_options
7
+ attr_writer :per_page
8
+ def initialize(dbi, list=nil)
9
+ @dbi=dbi
10
+ @list = list
11
+ @sort_columns=[]
12
+ end
13
+
14
+ # Records per page (also block setter)
15
+ def per_page(value=nil)
16
+ if value
17
+ @per_page=value
18
+ self
19
+ else
20
+ @per_page
21
+ end
22
+ end
23
+
24
+ # Define new sort column with ascending sort direction
25
+ def asc(column)
26
+ @sort_columns<<[column.to_sym,:asc]
27
+ self
28
+ end
29
+
30
+ # Define new sort columns with descending sort direction
31
+ def desc(column)
32
+ @sort_columns<<[column.to_sym,:desc]
33
+ self
34
+ end
35
+
36
+ # Return all sort columns.
37
+ # Each column is an Array where first element is column name and second is direction
38
+ # ====Example
39
+ # page=Lolita::Configuration::Page.new(@dbi)
40
+ # page.asc(:created_at)
41
+ # page.sort_columns #=> [[:created_at,:asc]]
42
+ def sort_columns
43
+ @sort_columns
44
+ end
45
+
46
+ # Paginate
47
+ # Options:
48
+ # * <tt>:per_page</tt> - record count per page, default uses list.per_page
49
+ # * <tt>:page</tt> - what page to show
50
+ # * <tt>:sort_columns</tt> - sort columns for page. See #sort_columns
51
+ # * <tt>:asc</tt> - column to sort in ascending direction
52
+ # list.paginate(1,:asc=>:created_at)
53
+ # * <tt>:desc</tt> - column to sort in descending direction
54
+ #
55
+ # ====Example
56
+ # list.paginate(1)
57
+ # list.paginate
58
+ # list.paginate(:per_page=>2,:page=>1)
59
+ def paginate *args
60
+ options=args ? args.extract_options! : {}
61
+ hold=options.delete(:hold)
62
+ @params=options.delete(:params)
63
+ set_values_from_options(options)
64
+ options[:page]||=((args && args.first) || 1)
65
+ options[:per_page]||=@per_page || 10
66
+ @last_options=options
67
+ @last_options[:sort]=self.sort_columns unless self.sort_columns.empty?
68
+ unless hold
69
+ get_page()
70
+ end
71
+ end
72
+
73
+ def get_page()
74
+ @page=@dbi.filter(filter_conditions).paginate((@page_options||{}).merge(@last_options))
75
+ end
76
+
77
+ # Return last paginated page
78
+ # ====Example
79
+ # list.paginate(2)
80
+ # # call page to avoid another call to db
81
+ # list.page
82
+ def last_page
83
+ @page
84
+ end
85
+
86
+ private
87
+
88
+ # returns filter conditions as Hash for get_page()
89
+ def filter_conditions
90
+ if @params
91
+ conditions = {}
92
+ @params.each_pair do |k,v|
93
+ if k.to_s =~ /^f_([a-z0-9_\-]+)$/ && !v.to_s.strip.blank?
94
+ conditions[$1.to_sym] = v
95
+ end
96
+ end
97
+ conditions
98
+ else
99
+ {}
100
+ end
101
+ end
102
+
103
+ def allowed_options
104
+ [:sort_columns,:asc,:desc]
105
+ end
106
+
107
+ def set_values_from_options(options)
108
+ allowed_options.each{|meth|
109
+ if options.has_key?(meth)
110
+ self.send(meth,options.delete(meth))
111
+ end
112
+ }
113
+ parse_params
114
+ end
115
+
116
+ def parse_params
117
+ if @params
118
+ if @params.has_key?(:sc)
119
+ self.send((@params[:sd] || :asc).to_sym,@params[:sc])
120
+ end
121
+ end
122
+ end
123
+
124
+ end
125
+ end
125
126
  end