lolita 3.1.9 → 3.1.10

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 +154 -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 +94 -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 +124 -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,166 +1,166 @@
1
- module Lolita
2
- # Base::Configuration methods are accessable through Lolita module.
3
- # Like Lolita.modules and Lolita.routes and so on.
4
- class BaseConfiguration
5
-
6
- attr_reader :scope, :modules, :routes, :controllers,:resources
7
- attr_accessor :mappings,:default_route,:user_classes,:authentication
8
- attr_writer :default_locale
9
-
10
- def initialize(scope)
11
- @scope=scope
12
- @mappings={}
13
- @resources={}
14
- @default_module=nil
15
- @user_classes=[]
16
- @modules=[]
17
- @routes={}
18
- @controllers={}
19
- end
20
-
21
- def navigation
22
- @navigation||=Lolita::Navigation::Base.new()
23
- @navigation
24
- end
25
-
26
- def locales=(value)
27
- unless value.is_a?(Array)
28
- @locales=[value]
29
- else
30
- @locales=value
31
- end
32
- end
33
-
34
- def locales
35
- @locales || []
36
- end
37
-
38
- def locale()
39
- @locale || default_locale
40
- end
41
-
42
- def locale=given_locale
43
- @locale=if locales.include?(given_locale.to_s.to_sym)
44
- given_locale.to_s.to_sym
45
- else
46
- Lolita.default_locale
47
- end
48
- end
49
- # Return default locale. First looks for defined default locale for Lolita, when not found than
50
- # take first of defined #locales for Lolita, if there no defined locales for Lolita, than
51
- # look for I18n and take default locale from there or if there is no I18n than take :en
52
- def default_locale
53
- @default_locale || self.locales.first || (defined?(::I18n) ? ::I18n.default_locale : :en)
54
- end
55
- # Call (with #call) to route klass
56
- # And return all names of routes that are needed for resource.
57
- # When with #add_module routes are defined like
58
- # Lolita.add_module MyModule, :route=>:my_module
59
- # then this will be passed to the method that creates routes, but
60
- # when Proc is passed to <i>:route</i> then this Proc should return
61
- # name of route or nil.
62
- # These names then are used for methods like <em>lolita_[route_name]_route</em>
63
- # that should be required somewhere in you module.
64
- def conditional_routes(klass=nil)
65
- @routes.map{|name,route|
66
- if route.first
67
- if route.last.respond_to?(:call)
68
- route.last.call(klass)
69
- else
70
- route.last
71
- end
72
- end
73
- }.compact
74
- end
75
-
76
- # Find all routes that is needed for defined classes
77
- # And return only one for each different route.
78
- def common_routes(klasses)
79
- @routes.map{|name,route|
80
- unless route.first
81
- klasses.map{|klass| route.last.respond_to?(:call) ? route.last.call(klass) : route.last}
82
- end
83
- }.flatten.compact.uniq
84
- end
85
-
86
- # Include module in Lolita, don't know why i need this
87
- def use(module_name)
88
- Lolita.send(:include,module_name)
89
- end
90
-
91
- def add_mapping(resource,options={})
92
- mapping = Lolita::Mapping.new(resource, options)
93
- self.mappings[mapping.name] = mapping
94
- mapping
95
- end
96
-
97
- # Add new module to Lolita
98
- # Accpted options
99
- # * <tt>controller</tt> - not in use
100
- # * <tt>nested</tt> - is route stands itsefl or is used in combination with resource
101
- # * <tt>route</tt> - Symbol of route name or lambad, that return route name based on resource.
102
- # Route name is used to call method lolita_[route_name] in Mapper class, and that should draw route.
103
- # * <tt>:name</tt> - name of module, underscored symbol. Used to draw default route, by default always
104
- # lolita_rest is called, but if route with resource name is found, than by default this route will be drawn.
105
- # Like lolita_for :posts, can go to different controller than rest and do other things.
106
- # * <tt>:path</tt> - some file that will be included. Deprecated will be removed
107
- # ====Example
108
- # Lolita.add_module Lolita::Posts, :route=>:post, :name=>:post
109
- # lolita_for :posts #=> create url whatever is defined in lolita_post method, and goes to :controller=>"lolita/posts"
110
- # Lolita.add_module Lolita::FileUpload, :route=>lambda{|resource| resource.lolita.tabs.by_type(:file) ? :file_upload : nil}
111
- # lolita_for :users #=> creat default rest urls and also call method lolita_file_upload if user lolita define :file tab.
112
- # To add route for public interface that goes to added module, than use
113
- # Lolita.add_module Post, :name=>:posts
114
- # And then when in routes.rb will be defined lolita_for(:posts) it will call method <i>lolita_posts_route</i>
115
- # and that method should define resource.
116
- # ====Example
117
- # # require this in your gem or lib
118
- # module ActionDispatch::Routing
119
- # class Mapper
120
- # protected
121
- # def lolita_posts_route mapping, controllers
122
- # resources mapping.plural,:only=>[:index,:new,:create],
123
- # :controller=>controllers[:posts],:module=>mapping.module
124
- # end
125
- # end
126
- # end
127
- # You open Mapper class and add your method that call #resources or #match or other method that define route
128
- # For common route for all lolita resources your method should look like this
129
- # ====Example
130
- # def lolita_files_route
131
- # mapping=Lolita.add_mapping(:files,:class_name=>"Lolita::Multimedia::File",:module=>"file_upload")
132
- # scope :module=>mapping.module do
133
- # resources mapping.name
134
- # end
135
- # end
136
- def add_module module_container, options={}
137
- raise ArgumentError, "Can't add module without module container!" unless module_container
138
- options.assert_valid_keys(:controller,:route,:model,:path,:name,:nested)
139
- name=options[:name]||module_container.to_s.to_sym
140
- self.modules<<module_container
141
-
142
- if options.has_key?(:route)
143
- self.routes[name]=[options.has_key?(:nested) ? options[:nested] : true,options[:route]]
144
- end
145
- self.controllers[name]=options[:controller] if options.has_key?(:controller)
146
-
147
- if options[:path]
148
- require File.join(options[:path],name.to_s)
149
- end
150
-
151
- end
152
-
153
- # Lolita.extend_route_for(:any,:posts,:file_upload) do |resource|
154
- # if resource.tabs.by_type(:metadata)
155
- # with do
156
- # resources :metadata
157
- # end
158
- # end
159
- #end
160
- # :any for any
161
- # lolita/posts/metadata
162
- # lolita/posts/files/metadata
163
- def lolita_extend_route_for()
164
- end
165
- end
1
+ module Lolita
2
+ # Base::Configuration methods are accessable through Lolita module.
3
+ # Like Lolita.modules and Lolita.routes and so on.
4
+ class BaseConfiguration
5
+
6
+ attr_reader :scope, :modules, :routes, :controllers,:resources
7
+ attr_accessor :mappings,:default_route,:user_classes,:authentication
8
+ attr_writer :default_locale
9
+
10
+ def initialize(scope)
11
+ @scope=scope
12
+ @mappings={}
13
+ @resources={}
14
+ @default_module=nil
15
+ @user_classes=[]
16
+ @modules=[]
17
+ @routes={}
18
+ @controllers={}
19
+ end
20
+
21
+ def navigation
22
+ @navigation||=Lolita::Navigation::Base.new()
23
+ @navigation
24
+ end
25
+
26
+ def locales=(value)
27
+ unless value.is_a?(Array)
28
+ @locales=[value]
29
+ else
30
+ @locales=value
31
+ end
32
+ end
33
+
34
+ def locales
35
+ @locales || []
36
+ end
37
+
38
+ def locale()
39
+ @locale || default_locale
40
+ end
41
+
42
+ def locale=given_locale
43
+ @locale=if locales.include?(given_locale.to_s.to_sym)
44
+ given_locale.to_s.to_sym
45
+ else
46
+ Lolita.default_locale
47
+ end
48
+ end
49
+ # Return default locale. First looks for defined default locale for Lolita, when not found than
50
+ # take first of defined #locales for Lolita, if there no defined locales for Lolita, than
51
+ # look for I18n and take default locale from there or if there is no I18n than take :en
52
+ def default_locale
53
+ @default_locale || self.locales.first || (defined?(::I18n) ? ::I18n.default_locale : :en)
54
+ end
55
+ # Call (with #call) to route klass
56
+ # And return all names of routes that are needed for resource.
57
+ # When with #add_module routes are defined like
58
+ # Lolita.add_module MyModule, :route=>:my_module
59
+ # then this will be passed to the method that creates routes, but
60
+ # when Proc is passed to <i>:route</i> then this Proc should return
61
+ # name of route or nil.
62
+ # These names then are used for methods like <em>lolita_[route_name]_route</em>
63
+ # that should be required somewhere in you module.
64
+ def conditional_routes(klass=nil)
65
+ @routes.map{|name,route|
66
+ if route.first
67
+ if route.last.respond_to?(:call)
68
+ route.last.call(klass)
69
+ else
70
+ route.last
71
+ end
72
+ end
73
+ }.compact
74
+ end
75
+
76
+ # Find all routes that is needed for defined classes
77
+ # And return only one for each different route.
78
+ def common_routes(klasses)
79
+ @routes.map{|name,route|
80
+ unless route.first
81
+ klasses.map{|klass| route.last.respond_to?(:call) ? route.last.call(klass) : route.last}
82
+ end
83
+ }.flatten.compact.uniq
84
+ end
85
+
86
+ # Include module in Lolita, don't know why i need this
87
+ def use(module_name)
88
+ Lolita.send(:include,module_name)
89
+ end
90
+
91
+ def add_mapping(resource,options={})
92
+ mapping = Lolita::Mapping.new(resource, options)
93
+ self.mappings[mapping.name] = mapping
94
+ mapping
95
+ end
96
+
97
+ # Add new module to Lolita
98
+ # Accpted options
99
+ # * <tt>controller</tt> - not in use
100
+ # * <tt>nested</tt> - is route stands itsefl or is used in combination with resource
101
+ # * <tt>route</tt> - Symbol of route name or lambad, that return route name based on resource.
102
+ # Route name is used to call method lolita_[route_name] in Mapper class, and that should draw route.
103
+ # * <tt>:name</tt> - name of module, underscored symbol. Used to draw default route, by default always
104
+ # lolita_rest is called, but if route with resource name is found, than by default this route will be drawn.
105
+ # Like lolita_for :posts, can go to different controller than rest and do other things.
106
+ # * <tt>:path</tt> - some file that will be included. Deprecated will be removed
107
+ # ====Example
108
+ # Lolita.add_module Lolita::Posts, :route=>:post, :name=>:post
109
+ # lolita_for :posts #=> create url whatever is defined in lolita_post method, and goes to :controller=>"lolita/posts"
110
+ # Lolita.add_module Lolita::FileUpload, :route=>lambda{|resource| resource.lolita.tabs.by_type(:file) ? :file_upload : nil}
111
+ # lolita_for :users #=> creat default rest urls and also call method lolita_file_upload if user lolita define :file tab.
112
+ # To add route for public interface that goes to added module, than use
113
+ # Lolita.add_module Post, :name=>:posts
114
+ # And then when in routes.rb will be defined lolita_for(:posts) it will call method <i>lolita_posts_route</i>
115
+ # and that method should define resource.
116
+ # ====Example
117
+ # # require this in your gem or lib
118
+ # module ActionDispatch::Routing
119
+ # class Mapper
120
+ # protected
121
+ # def lolita_posts_route mapping, controllers
122
+ # resources mapping.plural,:only=>[:index,:new,:create],
123
+ # :controller=>controllers[:posts],:module=>mapping.module
124
+ # end
125
+ # end
126
+ # end
127
+ # You open Mapper class and add your method that call #resources or #match or other method that define route
128
+ # For common route for all lolita resources your method should look like this
129
+ # ====Example
130
+ # def lolita_files_route
131
+ # mapping=Lolita.add_mapping(:files,:class_name=>"Lolita::Multimedia::File",:module=>"file_upload")
132
+ # scope :module=>mapping.module do
133
+ # resources mapping.name
134
+ # end
135
+ # end
136
+ def add_module module_container, options={}
137
+ raise ArgumentError, "Can't add module without module container!" unless module_container
138
+ options.assert_valid_keys(:controller,:route,:model,:path,:name,:nested)
139
+ name=options[:name]||module_container.to_s.to_sym
140
+ self.modules<<module_container
141
+
142
+ if options.has_key?(:route)
143
+ self.routes[name]=[options.has_key?(:nested) ? options[:nested] : true,options[:route]]
144
+ end
145
+ self.controllers[name]=options[:controller] if options.has_key?(:controller)
146
+
147
+ if options[:path]
148
+ require File.join(options[:path],name.to_s)
149
+ end
150
+
151
+ end
152
+
153
+ # Lolita.extend_route_for(:any,:posts,:file_upload) do |resource|
154
+ # if resource.tabs.by_type(:metadata)
155
+ # with do
156
+ # resources :metadata
157
+ # end
158
+ # end
159
+ #end
160
+ # :any for any
161
+ # lolita/posts/metadata
162
+ # lolita/posts/files/metadata
163
+ def lolita_extend_route_for()
164
+ end
165
+ end
166
166
  end
@@ -1,250 +1,250 @@
1
- module Lolita
2
- # Any Lolita::Configuration class that should return visual information about itself
3
- # can include Builder::Base, that provide default methods for _controllers_ to use.
4
- # * #build method is used to render component for class instance.
5
- # * #build_options is method that return specific options for builder, to pass to component,
6
- # such as :color,:postition etc.
7
- # * #builder is setter/getter method for Lolita::Configuration, that accept Hash or Array or single
8
- # String or Symbol for buider.
9
- #
10
- # Usage in your model
11
- # You can change behaviour of any of configuraton elements, to do so you should specify what
12
- # builder you want to use.
13
- # lolita do
14
- # list do
15
- # column do
16
- # name :my_column
17
- # builder :name => "my_columns",:state => :display, :if=>{:state => :display}
18
- # end
19
- # end
20
- # end
21
- # This expample show, how to replace :display component of column by your own :display.
22
- # <i>:if</i> is determine, that column use builder provided to component render, but when state is <i>:display</i>
23
- # then it will be replaced with this on. There are elements, that only have one <i>:display</i> state, than it's
24
- # not necessary to provide <i>:if</i> or <i>:unless</i> state.
25
- module Builder
26
-
27
- class Custom
28
-
29
- class << self
30
- def create(element, *args)
31
- possible_builder = extract_args(*args)
32
- if possible_builder.is_a?(Hash)
33
- Lolita::Builder::Custom.new(element, possible_builder)
34
- else
35
- possible_builder
36
- end
37
- end
38
-
39
- def extract_args(*args)
40
- if args && args.any?
41
- options = args.extract_options! || {}
42
- if args[0] && args[0].is_a?(self)
43
- args[0]
44
- elsif args[0].is_a?(String) || args[0].is_a?(Symbol)
45
- options[:name] = args[0]
46
- if args[1]
47
- options[:state] = args[1]
48
- end
49
- options
50
- elsif options
51
- options
52
- else
53
- raise ArgumentError, "Don't know how to make builder from #{options}."
54
- end
55
- else
56
- return {}
57
- end
58
- end
59
- end
60
-
61
- attr_accessor :options,:build_attributes
62
-
63
- def initialize(element, attributes_as_hash)
64
- @element = element
65
- @options = {}
66
- @build_attributes = {}
67
- @conditions = {}
68
- set_attributes(attributes_as_hash)
69
- set_default_attribute_values
70
- end
71
-
72
- def with(*values)
73
- new_values = self.class.extract_args(*values)
74
- if new_values.is_a?(Hash)
75
- @build_attributes = new_values
76
- else
77
- raise ArgumentError, "Can't build with other builder, use build on that builder!"
78
- end
79
- self
80
- end
81
-
82
- def build
83
-
84
- path = if conditions?
85
- switch_path do |name,state|
86
- if conditions_met?
87
- [fixed_name(name).to_sym,state.to_sym]
88
- else
89
- [self.name, self.state]
90
- end
91
- end
92
- else
93
- [self.name,self.state]
94
- end
95
- result = path + [merged_options]
96
- return result
97
- end
98
-
99
- def name
100
- result = if build_attributes[:name].to_s.size > 0
101
- fixed_name(build_attributes[:name])
102
- else
103
- fixed_name(@name,build_attributes[:name])
104
- end
105
- result.to_sym
106
- end
107
-
108
- def state
109
- result = if build_attributes[:state] && build_attributes[:state].to_s.size > 0
110
- build_attributes[:state]
111
- else
112
- @state
113
- end
114
- result.to_sym
115
- end
116
-
117
- private
118
-
119
- def switch_path
120
- old_name = @name
121
- old_state = @state
122
- @name = nil
123
- @state = default_state
124
- result = yield old_name,old_state
125
- @name = old_name
126
- @state = old_state
127
- result
128
- end
129
-
130
- def conditions?
131
- @conditions.any?
132
- end
133
-
134
- def conditions_met?
135
- @conditions_met = if conditions?
136
- if @conditions[:if]
137
- compare(@conditions[:if],true)
138
- elsif @conditions[:unless]
139
- compare(@conditions[:unless],false)
140
- end
141
- end
142
- @conditions_met
143
- end
144
-
145
- def compare(pattern,predicate)
146
- result = true
147
- pattern.each do |key,value|
148
- result &&= ((value.to_sym == self.send(key)) == predicate)
149
- end
150
- result
151
- end
152
-
153
- def fixed_name(name_to_fix, first_part = nil)
154
- unless name_to_fix.to_s[0] == "/"
155
- "/#{first_part.to_s.size > 0 ? first_part : default_name}/#{name_to_fix}".gsub(/\/{2,}/,"/").gsub(/\/$/,"")
156
- else
157
- name_to_fix
158
- end
159
- end
160
-
161
- def default_name
162
- @element.builder_default_name
163
- end
164
-
165
- def default_state
166
- @element.builder_default_state
167
- end
168
-
169
- def attributes
170
- [:name,:state]
171
- end
172
-
173
- def conditions
174
- [:if,:unless]
175
- end
176
-
177
- def merged_options
178
- result = {}
179
- (@build_attributes || {}).merge(@options).each do |key,value|
180
- unless attributes.include?(key.to_sym)
181
- result[key.to_sym] = value
182
- end
183
- end
184
- result
185
- end
186
-
187
- def set_attributes(attributes_as_hash)
188
- attributes_as_hash.each do |attr_name, value|
189
- if attributes.include?(attr_name.to_sym)
190
- instance_variable_set(:"@#{attr_name}",value)
191
- elsif conditions.include?(attr_name.to_sym)
192
- @conditions[attr_name.to_sym] = value
193
- else
194
- @options[attr_name.to_sym] = value
195
- end
196
- end
197
- end
198
-
199
- def set_default_attribute_values
200
- @state ||= default_state
201
- end
202
-
203
- end
204
-
205
- def builder *args
206
- if args && args.any?
207
- set_builder(*args)
208
- else
209
- @builder||=set_builder(nil)
210
- @builder
211
- end
212
- end
213
-
214
- def builder=(*args)
215
- set_builder(*args)
216
- end
217
-
218
- def build *values
219
- result = builder.with(*values).build
220
- result[result.size-1].merge!(default_options)
221
- result
222
- end
223
-
224
- def default_options
225
- {builder_local_variable_name => self}
226
- end
227
-
228
- def builder_default_name
229
- self.class.to_s.split("::").map(&:underscore).join("/").to_sym
230
- end
231
-
232
- alias :builder_name :builder_default_name
233
-
234
- def builder_default_state
235
- :display
236
- end
237
-
238
- alias :default_build_state :builder_default_state
239
-
240
- private
241
-
242
- def set_builder *args
243
- @builder=Lolita::Builder::Custom.create(self,*args)
244
- end
245
-
246
- def builder_local_variable_name
247
- self.class.to_s.split("::").last.underscore.to_sym
248
- end
249
- end
1
+ module Lolita
2
+ # Any Lolita::Configuration class that should return visual information about itself
3
+ # can include Builder::Base, that provide default methods for _controllers_ to use.
4
+ # * #build method is used to render component for class instance.
5
+ # * #build_options is method that return specific options for builder, to pass to component,
6
+ # such as :color,:postition etc.
7
+ # * #builder is setter/getter method for Lolita::Configuration, that accept Hash or Array or single
8
+ # String or Symbol for buider.
9
+ #
10
+ # Usage in your model
11
+ # You can change behaviour of any of configuraton elements, to do so you should specify what
12
+ # builder you want to use.
13
+ # lolita do
14
+ # list do
15
+ # column do
16
+ # name :my_column
17
+ # builder :name => "my_columns",:state => :display, :if=>{:state => :display}
18
+ # end
19
+ # end
20
+ # end
21
+ # This expample show, how to replace :display component of column by your own :display.
22
+ # <i>:if</i> is determine, that column use builder provided to component render, but when state is <i>:display</i>
23
+ # then it will be replaced with this on. There are elements, that only have one <i>:display</i> state, than it's
24
+ # not necessary to provide <i>:if</i> or <i>:unless</i> state.
25
+ module Builder
26
+
27
+ class Custom
28
+
29
+ class << self
30
+ def create(element, *args)
31
+ possible_builder = extract_args(*args)
32
+ if possible_builder.is_a?(Hash)
33
+ Lolita::Builder::Custom.new(element, possible_builder)
34
+ else
35
+ possible_builder
36
+ end
37
+ end
38
+
39
+ def extract_args(*args)
40
+ if args && args.any?
41
+ options = args.extract_options! || {}
42
+ if args[0] && args[0].is_a?(self)
43
+ args[0]
44
+ elsif args[0].is_a?(String) || args[0].is_a?(Symbol)
45
+ options[:name] = args[0]
46
+ if args[1]
47
+ options[:state] = args[1]
48
+ end
49
+ options
50
+ elsif options
51
+ options
52
+ else
53
+ raise ArgumentError, "Don't know how to make builder from #{options}."
54
+ end
55
+ else
56
+ return {}
57
+ end
58
+ end
59
+ end
60
+
61
+ attr_accessor :options,:build_attributes
62
+
63
+ def initialize(element, attributes_as_hash)
64
+ @element = element
65
+ @options = {}
66
+ @build_attributes = {}
67
+ @conditions = {}
68
+ set_attributes(attributes_as_hash)
69
+ set_default_attribute_values
70
+ end
71
+
72
+ def with(*values)
73
+ new_values = self.class.extract_args(*values)
74
+ if new_values.is_a?(Hash)
75
+ @build_attributes = new_values
76
+ else
77
+ raise ArgumentError, "Can't build with other builder, use build on that builder!"
78
+ end
79
+ self
80
+ end
81
+
82
+ def build
83
+
84
+ path = if conditions?
85
+ switch_path do |name,state|
86
+ if conditions_met?
87
+ [fixed_name(name).to_sym,state.to_sym]
88
+ else
89
+ [self.name, self.state]
90
+ end
91
+ end
92
+ else
93
+ [self.name,self.state]
94
+ end
95
+ result = path + [merged_options]
96
+ return result
97
+ end
98
+
99
+ def name
100
+ result = if build_attributes[:name].to_s.size > 0
101
+ fixed_name(build_attributes[:name])
102
+ else
103
+ fixed_name(@name,build_attributes[:name])
104
+ end
105
+ result.to_sym
106
+ end
107
+
108
+ def state
109
+ result = if build_attributes[:state] && build_attributes[:state].to_s.size > 0
110
+ build_attributes[:state]
111
+ else
112
+ @state
113
+ end
114
+ result.to_sym
115
+ end
116
+
117
+ private
118
+
119
+ def switch_path
120
+ old_name = @name
121
+ old_state = @state
122
+ @name = nil
123
+ @state = default_state
124
+ result = yield old_name,old_state
125
+ @name = old_name
126
+ @state = old_state
127
+ result
128
+ end
129
+
130
+ def conditions?
131
+ @conditions.any?
132
+ end
133
+
134
+ def conditions_met?
135
+ @conditions_met = if conditions?
136
+ if @conditions[:if]
137
+ compare(@conditions[:if],true)
138
+ elsif @conditions[:unless]
139
+ compare(@conditions[:unless],false)
140
+ end
141
+ end
142
+ @conditions_met
143
+ end
144
+
145
+ def compare(pattern,predicate)
146
+ result = true
147
+ pattern.each do |key,value|
148
+ result &&= ((value.to_sym == self.send(key)) == predicate)
149
+ end
150
+ result
151
+ end
152
+
153
+ def fixed_name(name_to_fix, first_part = nil)
154
+ unless name_to_fix.to_s[0] == "/"
155
+ "/#{first_part.to_s.size > 0 ? first_part : default_name}/#{name_to_fix}".gsub(/\/{2,}/,"/").gsub(/\/$/,"")
156
+ else
157
+ name_to_fix
158
+ end
159
+ end
160
+
161
+ def default_name
162
+ @element.builder_default_name
163
+ end
164
+
165
+ def default_state
166
+ @element.builder_default_state
167
+ end
168
+
169
+ def attributes
170
+ [:name,:state]
171
+ end
172
+
173
+ def conditions
174
+ [:if,:unless]
175
+ end
176
+
177
+ def merged_options
178
+ result = {}
179
+ (@build_attributes || {}).merge(@options).each do |key,value|
180
+ unless attributes.include?(key.to_sym)
181
+ result[key.to_sym] = value
182
+ end
183
+ end
184
+ result
185
+ end
186
+
187
+ def set_attributes(attributes_as_hash)
188
+ attributes_as_hash.each do |attr_name, value|
189
+ if attributes.include?(attr_name.to_sym)
190
+ instance_variable_set(:"@#{attr_name}",value)
191
+ elsif conditions.include?(attr_name.to_sym)
192
+ @conditions[attr_name.to_sym] = value
193
+ else
194
+ @options[attr_name.to_sym] = value
195
+ end
196
+ end
197
+ end
198
+
199
+ def set_default_attribute_values
200
+ @state ||= default_state
201
+ end
202
+
203
+ end
204
+
205
+ def builder *args
206
+ if args && args.any?
207
+ set_builder(*args)
208
+ else
209
+ @builder||=set_builder(nil)
210
+ @builder
211
+ end
212
+ end
213
+
214
+ def builder=(*args)
215
+ set_builder(*args)
216
+ end
217
+
218
+ def build *values
219
+ result = builder.with(*values).build
220
+ result[result.size-1].merge!(default_options)
221
+ result
222
+ end
223
+
224
+ def default_options
225
+ {builder_local_variable_name => self}
226
+ end
227
+
228
+ def builder_default_name
229
+ self.class.to_s.split("::").map(&:underscore).join("/").to_sym
230
+ end
231
+
232
+ alias :builder_name :builder_default_name
233
+
234
+ def builder_default_state
235
+ :display
236
+ end
237
+
238
+ alias :default_build_state :builder_default_state
239
+
240
+ private
241
+
242
+ def set_builder *args
243
+ @builder=Lolita::Builder::Custom.create(self,*args)
244
+ end
245
+
246
+ def builder_local_variable_name
247
+ self.class.to_s.split("::").last.underscore.to_sym
248
+ end
249
+ end
250
250
  end