locomotive_cms 2.0.3 → 2.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (378) hide show
  1. checksums.yaml +15 -0
  2. data/Gemfile +3 -3
  3. data/README.textile +7 -7
  4. data/app/assets/images/locomotive/icons/flags/ja.png +0 -0
  5. data/app/assets/javascripts/locomotive/aloha.js.coffee +3 -0
  6. data/app/assets/javascripts/locomotive/models/page.js.coffee +1 -1
  7. data/app/assets/javascripts/locomotive/models/site.js.coffee +16 -6
  8. data/app/assets/javascripts/locomotive/utils/aloha_settings.js.coffee +1 -1
  9. data/app/assets/javascripts/locomotive/views/content_entries/_form_view.js.coffee +5 -0
  10. data/app/assets/javascripts/locomotive/views/my_account/edit_view.js.coffee +14 -0
  11. data/app/assets/javascripts/locomotive/views/pages/_form_view.js.coffee +1 -1
  12. data/app/assets/javascripts/locomotive/views/pages/edit_view.js.coffee +2 -1
  13. data/app/assets/javascripts/tinymce/plugins/locomotive_media/langs/de.js +1 -0
  14. data/app/assets/stylesheets/locomotive.css +1 -0
  15. data/app/assets/stylesheets/locomotive/backoffice/formtastic_changes.css.scss +18 -3
  16. data/app/assets/stylesheets/locomotive/backoffice/layout.css.scss +1 -1
  17. data/app/assets/stylesheets/locomotive/backoffice/menu/main.css.scss +7 -3
  18. data/app/assets/stylesheets/locomotive/backoffice/pagination.css.scss +37 -0
  19. data/app/assets/stylesheets/locomotive/backoffice/tagit_changes.css.scss +49 -0
  20. data/app/cells/locomotive/content_locale_picker/show.html.haml +1 -1
  21. data/app/cells/locomotive/global_actions_cell.rb +8 -8
  22. data/app/cells/locomotive/main_menu/show.html.haml +2 -2
  23. data/app/cells/locomotive/main_menu_cell.rb +2 -2
  24. data/app/cells/locomotive/menu_cell.rb +6 -6
  25. data/app/cells/locomotive/partials_cell.rb +21 -0
  26. data/app/cells/locomotive/settings_menu_cell.rb +4 -4
  27. data/app/cells/locomotive/sub_menu/show.html.haml +2 -2
  28. data/app/cells/locomotive/sub_menu_cell.rb +1 -1
  29. data/app/controllers/locomotive/accounts_controller.rb +4 -4
  30. data/app/controllers/locomotive/api/accounts_controller.rb +1 -0
  31. data/app/controllers/locomotive/api/content_assets_controller.rb +1 -1
  32. data/app/controllers/locomotive/api/content_entries_controller.rb +1 -1
  33. data/app/controllers/locomotive/api/content_types_controller.rb +2 -2
  34. data/app/controllers/locomotive/api/pages_controller.rb +1 -1
  35. data/app/controllers/locomotive/api/snippets_controller.rb +1 -1
  36. data/app/controllers/locomotive/api/theme_assets_controller.rb +47 -0
  37. data/app/controllers/locomotive/api/tokens_controller.rb +2 -2
  38. data/app/controllers/locomotive/base_controller.rb +5 -2
  39. data/app/controllers/locomotive/content_assets_controller.rb +1 -1
  40. data/app/controllers/locomotive/content_entries_controller.rb +22 -9
  41. data/app/controllers/locomotive/content_types_controller.rb +6 -6
  42. data/app/controllers/locomotive/current_site_controller.rb +6 -6
  43. data/app/controllers/locomotive/installation_controller.rb +11 -3
  44. data/app/controllers/locomotive/memberships_controller.rb +6 -6
  45. data/app/controllers/locomotive/my_account_controller.rb +9 -3
  46. data/app/controllers/locomotive/pages_controller.rb +10 -6
  47. data/app/controllers/locomotive/passwords_controller.rb +1 -1
  48. data/app/controllers/locomotive/public/content_entries_controller.rb +1 -1
  49. data/app/controllers/locomotive/public/pages_controller.rb +5 -5
  50. data/app/controllers/locomotive/public/robots_controller.rb +1 -1
  51. data/app/controllers/locomotive/public/sitemaps_controller.rb +1 -1
  52. data/app/controllers/locomotive/sessions_controller.rb +1 -1
  53. data/app/controllers/locomotive/sites_controller.rb +5 -5
  54. data/app/controllers/locomotive/snippets_controller.rb +6 -6
  55. data/app/controllers/locomotive/theme_assets_controller.rb +6 -6
  56. data/app/controllers/locomotive/translations_controller.rb +1 -1
  57. data/app/helpers/locomotive/accounts_helper.rb +1 -1
  58. data/app/helpers/locomotive/base_helper.rb +13 -21
  59. data/app/helpers/locomotive/content_types_helper.rb +3 -3
  60. data/app/helpers/locomotive/custom_fields_helper.rb +5 -5
  61. data/app/helpers/locomotive/installation_helper.rb +1 -1
  62. data/app/helpers/locomotive/pages_helper.rb +5 -5
  63. data/app/helpers/locomotive/snippets_helper.rb +1 -1
  64. data/app/helpers/locomotive/theme_assets_helper.rb +1 -1
  65. data/app/helpers/locomotive/translations_helper.rb +2 -2
  66. data/app/inputs/locomotive/api_key_input.rb +40 -0
  67. data/app/inputs/locomotive/code_input.rb +5 -5
  68. data/app/inputs/locomotive/file_input.rb +6 -6
  69. data/app/inputs/locomotive/locale_input.rb +5 -5
  70. data/app/inputs/locomotive/locales_input.rb +4 -4
  71. data/app/inputs/locomotive/rte_input.rb +1 -1
  72. data/app/inputs/locomotive/small_code_input.rb +1 -1
  73. data/app/inputs/locomotive/subdomain_input.rb +1 -1
  74. data/app/mailers/locomotive/devise_mailer.rb +1 -1
  75. data/app/mailers/locomotive/notifications.rb +3 -3
  76. data/app/models/locomotive/ability.rb +10 -11
  77. data/app/models/locomotive/account.rb +61 -26
  78. data/app/models/locomotive/content_asset.rb +8 -8
  79. data/app/models/locomotive/content_entry.rb +8 -7
  80. data/app/models/locomotive/content_type.rb +12 -7
  81. data/app/models/locomotive/editable_control.rb +2 -2
  82. data/app/models/locomotive/editable_element.rb +13 -8
  83. data/app/models/locomotive/editable_file.rb +5 -3
  84. data/app/models/locomotive/editable_short_text.rb +3 -3
  85. data/app/models/locomotive/extensions/asset/types.rb +2 -2
  86. data/app/models/locomotive/extensions/content_entry/csv.rb +78 -0
  87. data/app/models/locomotive/extensions/content_type/item_template.rb +3 -3
  88. data/app/models/locomotive/extensions/content_type/sync.rb +4 -4
  89. data/app/models/locomotive/extensions/page/editable_elements.rb +1 -1
  90. data/app/models/locomotive/extensions/page/parse.rb +2 -2
  91. data/app/models/locomotive/extensions/page/render.rb +7 -1
  92. data/app/models/locomotive/extensions/page/templatized.rb +20 -15
  93. data/app/models/locomotive/extensions/page/tree.rb +4 -4
  94. data/app/models/locomotive/extensions/shared/seo.rb +3 -3
  95. data/app/models/locomotive/extensions/site/first_installation.rb +5 -2
  96. data/app/models/locomotive/extensions/site/locales.rb +9 -6
  97. data/app/models/locomotive/extensions/site/subdomain_domains.rb +8 -8
  98. data/app/models/locomotive/membership.rb +6 -6
  99. data/app/models/locomotive/page.rb +30 -23
  100. data/app/models/locomotive/site.rb +19 -15
  101. data/app/models/locomotive/snippet.rb +5 -5
  102. data/app/models/locomotive/theme_asset.rb +17 -6
  103. data/app/models/locomotive/translation.rb +21 -16
  104. data/app/presenters/locomotive/account_presenter.rb +1 -1
  105. data/app/presenters/locomotive/content_entry_presenter.rb +2 -2
  106. data/app/presenters/locomotive/content_field_presenter.rb +2 -2
  107. data/app/presenters/locomotive/content_type_presenter.rb +6 -1
  108. data/app/presenters/locomotive/theme_asset_presenter.rb +2 -2
  109. data/app/uploaders/locomotive/editable_file_uploader.rb +1 -1
  110. data/app/uploaders/locomotive/theme_asset_uploader.rb +1 -1
  111. data/app/views/locomotive/accounts/new.html.haml +6 -6
  112. data/app/views/locomotive/content_assets/_asset.html.haml +3 -3
  113. data/app/views/locomotive/content_assets/_picker.html.haml +12 -12
  114. data/app/views/locomotive/content_entries/_form.html.haml +9 -8
  115. data/app/views/locomotive/content_entries/_list.html.haml +8 -5
  116. data/app/views/locomotive/content_entries/edit.html.haml +6 -6
  117. data/app/views/locomotive/content_entries/index.html.haml +8 -6
  118. data/app/views/locomotive/content_entries/new.html.haml +5 -5
  119. data/app/views/locomotive/content_types/_form.html.haml +16 -16
  120. data/app/views/locomotive/content_types/edit.html.haml +5 -5
  121. data/app/views/locomotive/content_types/new.html.haml +3 -3
  122. data/app/views/locomotive/current_site/_form.html.haml +12 -12
  123. data/app/views/locomotive/current_site/edit.html.haml +5 -5
  124. data/app/views/locomotive/custom_fields/_form.html.haml +23 -19
  125. data/app/views/locomotive/custom_fields/_select_templates.html.haml +5 -5
  126. data/app/views/locomotive/custom_fields/types/_belongs_to.html.haml +4 -4
  127. data/app/views/locomotive/custom_fields/types/_boolean.html.haml +3 -3
  128. data/app/views/locomotive/custom_fields/types/_date.html.haml +4 -4
  129. data/app/views/locomotive/custom_fields/types/_email.html.haml +4 -0
  130. data/app/views/locomotive/custom_fields/types/_file.html.haml +3 -3
  131. data/app/views/locomotive/custom_fields/types/_float.html.haml +6 -0
  132. data/app/views/locomotive/custom_fields/types/_has_many.html.haml +10 -10
  133. data/app/views/locomotive/custom_fields/types/_integer.html.haml +5 -0
  134. data/app/views/locomotive/custom_fields/types/_many_to_many.html.haml +10 -10
  135. data/app/views/locomotive/custom_fields/types/_select.html.haml +10 -10
  136. data/app/views/locomotive/custom_fields/types/_string.html.haml +3 -3
  137. data/app/views/locomotive/custom_fields/types/_tags.html.haml +4 -0
  138. data/app/views/locomotive/custom_fields/types/_text.html.haml +4 -4
  139. data/app/views/locomotive/devise_mailer/reset_password_instructions.html.haml +1 -1
  140. data/app/views/locomotive/installation/step_1.html.haml +5 -5
  141. data/app/views/locomotive/installation/step_2.html.haml +6 -6
  142. data/app/views/locomotive/kaminari/_first_page.html.haml +2 -0
  143. data/app/views/locomotive/kaminari/_gap.html.haml +2 -0
  144. data/app/views/locomotive/kaminari/_last_page.html.haml +2 -0
  145. data/app/views/locomotive/kaminari/_next_page.html.haml +2 -0
  146. data/app/views/locomotive/kaminari/_page.html.haml +2 -0
  147. data/app/views/locomotive/kaminari/_paginator.html.haml +11 -0
  148. data/app/views/locomotive/kaminari/_prev_page.html.haml +2 -0
  149. data/app/views/locomotive/layouts/application.html.haml +2 -2
  150. data/app/views/locomotive/layouts/not_logged_in.html.haml +3 -3
  151. data/app/views/locomotive/memberships/new.html.haml +4 -4
  152. data/app/views/locomotive/my_account/edit.html.haml +14 -13
  153. data/app/views/locomotive/notifications/new_content_entry.html.haml +2 -2
  154. data/app/views/locomotive/pages/_editable_elements.html.haml +20 -20
  155. data/app/views/locomotive/pages/_form.html.haml +23 -27
  156. data/app/views/locomotive/pages/_page.html.haml +6 -6
  157. data/app/views/locomotive/pages/edit.html.haml +5 -5
  158. data/app/views/locomotive/pages/index.html.haml +2 -2
  159. data/app/views/locomotive/pages/new.html.haml +4 -4
  160. data/app/views/locomotive/passwords/edit.html.haml +3 -3
  161. data/app/views/locomotive/passwords/new.html.haml +2 -2
  162. data/app/views/locomotive/public/pages/show_toolbar.html.haml +15 -15
  163. data/app/views/locomotive/sessions/new.html.haml +4 -4
  164. data/app/views/locomotive/shared/_footer.html.haml +1 -1
  165. data/app/views/locomotive/shared/_head.html.haml +7 -7
  166. data/app/views/locomotive/shared/_header.html.haml +2 -2
  167. data/app/views/locomotive/shared/_locale_picker_link.html.haml +1 -1
  168. data/app/views/locomotive/shared/_site_picker.html.haml +2 -2
  169. data/app/views/locomotive/shared/actions/_contents.html.haml +1 -1
  170. data/app/views/locomotive/shared/menu/_contents.html.haml +5 -5
  171. data/app/views/locomotive/sites/_domains.html.haml +7 -7
  172. data/app/views/locomotive/sites/_form.html.haml +6 -1
  173. data/app/views/locomotive/sites/_memberships.html.haml +3 -3
  174. data/app/views/locomotive/sites/new.html.haml +3 -3
  175. data/app/views/locomotive/snippets/_form.html.haml +6 -6
  176. data/app/views/locomotive/snippets/_snippet.html.haml +2 -2
  177. data/app/views/locomotive/snippets/edit.html.haml +5 -5
  178. data/app/views/locomotive/snippets/new.html.haml +3 -3
  179. data/app/views/locomotive/theme_assets/_asset.html.haml +2 -2
  180. data/app/views/locomotive/theme_assets/_form.html.haml +10 -10
  181. data/app/views/locomotive/theme_assets/_list.html.haml +3 -3
  182. data/app/views/locomotive/theme_assets/_picker.html.haml +8 -8
  183. data/app/views/locomotive/theme_assets/edit.html.haml +7 -7
  184. data/app/views/locomotive/theme_assets/index.html.haml +6 -6
  185. data/app/views/locomotive/theme_assets/new.html.haml +3 -3
  186. data/app/views/locomotive/translations/_form.html.haml +3 -3
  187. data/app/views/locomotive/translations/edit.html.haml +6 -6
  188. data/app/views/locomotive/translations/index.html.haml +2 -0
  189. data/app/views/locomotive/translations/new.html.haml +2 -2
  190. data/config/initializers/csv_renderer.rb +10 -0
  191. data/config/locales/admin_ui.de.yml +1 -0
  192. data/config/locales/admin_ui.en.yml +12 -0
  193. data/config/locales/admin_ui.es.yml +1 -0
  194. data/config/locales/admin_ui.et.yml +1 -0
  195. data/config/locales/admin_ui.fr.yml +12 -0
  196. data/config/locales/admin_ui.it.yml +1 -0
  197. data/config/locales/admin_ui.ja.yml +335 -0
  198. data/config/locales/admin_ui.nb.yml +1 -0
  199. data/config/locales/admin_ui.nl.yml +1 -0
  200. data/config/locales/admin_ui.pl.yml +1 -0
  201. data/config/locales/admin_ui.pt-BR.yml +8 -0
  202. data/config/locales/admin_ui.ru.yml +1 -0
  203. data/config/locales/carrierwave.ja.yml +4 -0
  204. data/config/locales/default.de.yml +1 -1
  205. data/config/locales/default.en.yml +1 -1
  206. data/config/locales/default.es.yml +3 -0
  207. data/config/locales/default.et.yml +2 -2
  208. data/config/locales/default.fr.yml +1 -1
  209. data/config/locales/default.it.yml +3 -0
  210. data/config/locales/default.ja.yml +94 -0
  211. data/config/locales/default.nb.yml +1 -1
  212. data/config/locales/default.nl.yml +5 -0
  213. data/config/locales/default.pl.yml +2 -2
  214. data/config/locales/default.pt-BR.yml +3 -2
  215. data/config/locales/default.ru.yml +19 -16
  216. data/config/locales/devise.ja.yml +63 -0
  217. data/config/locales/flash.ja.yml +115 -0
  218. data/config/locales/formtastic.en.yml +7 -0
  219. data/config/locales/formtastic.fr.yml +9 -0
  220. data/config/locales/formtastic.ja.yml +103 -0
  221. data/config/locales/formtastic.pt-BR.yml +1 -1
  222. data/config/routes.rb +5 -2
  223. data/features/api/authentication.feature +24 -2
  224. data/features/api/authorization/pages.feature +3 -1
  225. data/features/api/entries_custom_fields.feature +2 -2
  226. data/features/backoffice/authorization/pages.feature +7 -7
  227. data/features/backoffice/content_types/email.feature +26 -0
  228. data/features/backoffice/content_types/has_many.feature +20 -0
  229. data/features/backoffice/content_types/integer.feature +26 -0
  230. data/features/backoffice/content_types/many_to_many.feature +29 -1
  231. data/features/backoffice/content_types/tags.feature +22 -0
  232. data/features/backoffice/content_types/uniqueness.feature +29 -0
  233. data/features/backoffice/contents.feature +16 -0
  234. data/features/backoffice/installation.feature +33 -0
  235. data/features/backoffice/my_account.feature +21 -0
  236. data/features/backoffice/pages.feature +21 -1
  237. data/features/backoffice/site.feature +59 -40
  238. data/features/backoffice/snippets.feature +1 -1
  239. data/features/backoffice/translations.feature +7 -1
  240. data/features/public/basic.feature +1 -1
  241. data/features/public/pages.feature +92 -0
  242. data/features/public/session.feature +40 -0
  243. data/features/public/tags.feature +45 -0
  244. data/features/step_definitions/backoffice_steps.rb +4 -0
  245. data/features/step_definitions/content_types_steps.rb +16 -3
  246. data/features/step_definitions/more_web_steps.rb +35 -4
  247. data/features/step_definitions/page_steps.rb +52 -35
  248. data/features/step_definitions/pagination_steps.rb +4 -4
  249. data/features/step_definitions/site_steps.rb +22 -10
  250. data/features/step_definitions/snippet_steps.rb +1 -1
  251. data/features/step_definitions/theme_asset_steps.rb +2 -2
  252. data/features/step_definitions/translation_steps.rb +1 -1
  253. data/features/step_definitions/web_steps.rb +1 -1
  254. data/features/support/http.rb +1 -1
  255. data/features/support/locales.rb +5 -0
  256. data/lib/generators/locomotive/install/install_generator.rb +1 -6
  257. data/lib/generators/locomotive/install/templates/carrierwave.rb +4 -4
  258. data/lib/generators/locomotive/install/templates/locomotive.rb +12 -7
  259. data/lib/locomotive.rb +4 -4
  260. data/lib/locomotive/action_controller.rb +1 -0
  261. data/lib/locomotive/action_controller/responder.rb +9 -10
  262. data/lib/locomotive/action_controller/section_helpers.rb +1 -1
  263. data/lib/locomotive/action_controller/ssl.rb +11 -0
  264. data/lib/locomotive/action_controller/url_helpers.rb +9 -5
  265. data/lib/locomotive/carrierwave/asset.rb +6 -6
  266. data/lib/locomotive/configuration.rb +28 -26
  267. data/lib/locomotive/core_ext.rb +1 -2
  268. data/lib/locomotive/custom_fields.rb +12 -6
  269. data/lib/locomotive/dependencies.rb +1 -0
  270. data/lib/locomotive/dragonfly.rb +1 -1
  271. data/lib/locomotive/engine.rb +3 -3
  272. data/lib/locomotive/formtastic.rb +1 -1
  273. data/lib/locomotive/httparty/webservice.rb +1 -1
  274. data/lib/locomotive/kaminari.rb +28 -13
  275. data/lib/locomotive/liquid.rb +1 -0
  276. data/lib/locomotive/liquid/drops/content_entry.rb +1 -1
  277. data/lib/locomotive/liquid/drops/content_types.rb +27 -2
  278. data/lib/locomotive/liquid/drops/page.rb +14 -2
  279. data/lib/locomotive/liquid/drops/proxy_collection.rb +4 -0
  280. data/lib/locomotive/liquid/drops/session_proxy.rb +16 -0
  281. data/lib/locomotive/liquid/drops/site.rb +11 -3
  282. data/lib/locomotive/liquid/drops/uploader.rb +1 -1
  283. data/lib/locomotive/liquid/filters/base.rb +1 -1
  284. data/lib/locomotive/liquid/filters/date.rb +2 -2
  285. data/lib/locomotive/liquid/filters/html.rb +12 -12
  286. data/lib/locomotive/liquid/filters/translate.rb +21 -3
  287. data/lib/locomotive/liquid/tags/consume.rb +50 -19
  288. data/lib/locomotive/liquid/tags/editable/base.rb +9 -9
  289. data/lib/locomotive/liquid/tags/editable/control.rb +1 -1
  290. data/lib/locomotive/liquid/tags/editable/file.rb +1 -1
  291. data/lib/locomotive/liquid/tags/editable/short_text.rb +1 -1
  292. data/lib/locomotive/liquid/tags/fetch_page.rb +28 -0
  293. data/lib/locomotive/liquid/tags/hybrid.rb +25 -0
  294. data/lib/locomotive/liquid/tags/inherited_block.rb +2 -2
  295. data/lib/locomotive/liquid/tags/inline_editor.rb +4 -4
  296. data/lib/locomotive/liquid/tags/javascript.rb +16 -0
  297. data/lib/locomotive/liquid/tags/link_to.rb +42 -0
  298. data/lib/locomotive/liquid/tags/locale_switcher.rb +1 -1
  299. data/lib/locomotive/liquid/tags/nav.rb +2 -2
  300. data/lib/locomotive/liquid/tags/paginate.rb +2 -2
  301. data/lib/locomotive/liquid/tags/session_assign.rb +39 -0
  302. data/lib/locomotive/liquid/tags/snippet.rb +1 -1
  303. data/lib/locomotive/liquid/tags/with_scope.rb +6 -2
  304. data/lib/locomotive/logger.rb +1 -1
  305. data/lib/locomotive/middlewares/cache.rb +1 -1
  306. data/lib/locomotive/middlewares/fonts.rb +1 -1
  307. data/lib/locomotive/middlewares/inline_editor.rb +1 -1
  308. data/lib/locomotive/middlewares/permalink.rb +1 -1
  309. data/lib/locomotive/middlewares/seo_trailing_slash.rb +1 -1
  310. data/lib/locomotive/mongoid/patches.rb +21 -21
  311. data/lib/locomotive/rails/action_view.rb +20 -4
  312. data/lib/locomotive/regexps.rb +1 -1
  313. data/lib/locomotive/render.rb +4 -2
  314. data/lib/locomotive/routing/default_constraint.rb +1 -1
  315. data/lib/locomotive/routing/site_dispatcher.rb +1 -1
  316. data/lib/locomotive/session_store.rb +7 -7
  317. data/lib/locomotive/version.rb +1 -1
  318. data/lib/tasks/development.rake +11 -9
  319. data/lib/tasks/locomotive.rake +11 -11
  320. data/mongodb/migrate/20130204072721_make_editable_elements_consistent.rb +3 -1
  321. data/mongodb/migrate/20130326201349_rename_entry_to_content_entry.rb +6 -6
  322. data/mongodb/migrate/20130511121956_generate_checksum_for_theme_assets.rb +14 -0
  323. data/mongodb/migrate/20130530162559_api_key_for_all_accounts.rb +10 -0
  324. data/spec/cells/locomotive/global_actions_spec.rb +11 -11
  325. data/spec/cells/locomotive/main_menu_cell_spec.rb +9 -9
  326. data/spec/cells/locomotive/settings_menu_cell_spec.rb +11 -11
  327. data/spec/dummy/config/environments/development.rb +1 -1
  328. data/spec/dummy/config/initializers/locomotive.rb +16 -11
  329. data/spec/dummy/config/mongoid.yml +99 -18
  330. data/spec/lib/action_view_spec.rb +19 -0
  331. data/spec/lib/core_ext_spec.rb +2 -2
  332. data/spec/lib/locomotive/configuration_spec.rb +1 -1
  333. data/spec/lib/locomotive/httparty/webservice_spec.rb +6 -6
  334. data/spec/lib/locomotive/liquid/drops/content_entry_spec.rb +1 -1
  335. data/spec/lib/locomotive/liquid/drops/current_user.rb +3 -3
  336. data/spec/lib/locomotive/liquid/drops/page_spec.rb +63 -14
  337. data/spec/lib/locomotive/liquid/drops/site_spec.rb +3 -3
  338. data/spec/lib/locomotive/liquid/filters/html_spec.rb +22 -7
  339. data/spec/lib/locomotive/liquid/filters/resize_spec.rb +3 -3
  340. data/spec/lib/locomotive/liquid/filters/translate_spec.rb +26 -12
  341. data/spec/lib/locomotive/liquid/tags/consume_spec.rb +26 -2
  342. data/spec/lib/locomotive/liquid/tags/csrf_spec.rb +3 -3
  343. data/spec/lib/locomotive/liquid/tags/editable/short_text_spec.rb +1 -1
  344. data/spec/lib/locomotive/liquid/tags/extends_spec.rb +5 -5
  345. data/spec/lib/locomotive/liquid/tags/javascript_spec.rb +18 -0
  346. data/spec/lib/locomotive/liquid/tags/locale_switcher_spec.rb +23 -13
  347. data/spec/lib/locomotive/liquid/tags/nav_spec.rb +11 -11
  348. data/spec/lib/locomotive/liquid/tags/paginate_spec.rb +13 -13
  349. data/spec/lib/locomotive/liquid/tags/seo_spec.rb +8 -8
  350. data/spec/lib/locomotive/liquid/tags/with_scope_spec.rb +8 -2
  351. data/spec/lib/locomotive/presentable_spec.rb +10 -10
  352. data/spec/lib/locomotive/render_spec.rb +14 -14
  353. data/spec/mailers/locomotive/notifications_spec.rb +3 -3
  354. data/spec/models/locomotive/ability_spec.rb +23 -9
  355. data/spec/models/locomotive/account_spec.rb +30 -8
  356. data/spec/models/locomotive/content_asset_spec.rb +1 -1
  357. data/spec/models/locomotive/content_entry_spec.rb +57 -2
  358. data/spec/models/locomotive/content_type_spec.rb +42 -41
  359. data/spec/models/locomotive/editable_control_spec.rb +5 -5
  360. data/spec/models/locomotive/editable_file_spec.rb +21 -5
  361. data/spec/models/locomotive/editable_long_text_spec.rb +3 -3
  362. data/spec/models/locomotive/editable_short_text_spec.rb +8 -8
  363. data/spec/models/locomotive/extensions/page/editable_elements_spec.rb +9 -9
  364. data/spec/models/locomotive/extensions/page/redirect_spec.rb +1 -1
  365. data/spec/models/locomotive/extensions/page/render_spec.rb +4 -8
  366. data/spec/models/locomotive/extensions/site/locales_spec.rb +2 -2
  367. data/spec/models/locomotive/membership_spec.rb +5 -5
  368. data/spec/models/locomotive/page_spec.rb +10 -1
  369. data/spec/models/locomotive/site_spec.rb +19 -19
  370. data/spec/models/locomotive/snippet_spec.rb +9 -9
  371. data/spec/models/locomotive/theme_asset_spec.rb +91 -57
  372. data/spec/requests/admin_ssl_spec.rb +25 -0
  373. data/spec/support/factories.rb +32 -27
  374. data/spec/support/locomotive.rb +2 -0
  375. data/vendor/assets/javascripts/locomotive/backbone.sync.js +1 -1
  376. data/vendor/assets/javascripts/locomotive/tag-it.min.js +16 -0
  377. data/vendor/assets/stylesheets/locomotive/jquery.tagit.css +67 -0
  378. metadata +108 -138
@@ -1,10 +1,10 @@
1
1
  %ul#menu
2
2
  - @list.each_with_index do |entry, index|
3
- %li{ :class => "entry entry-#{index} #{entry[:class]}" }
3
+ %li{ class: "entry entry-#{index} #{entry[:class]}" }
4
4
  %div.left
5
5
  %span
6
6
  = link_to entry[:url] do
7
- %i{ :class => entry[:icon] }
7
+ %i{ class: entry[:icon] }
8
8
  %span= entry[:label]
9
9
  %div.right
10
10
  %span
@@ -4,8 +4,8 @@ module Locomotive
4
4
  protected
5
5
 
6
6
  def build_list
7
- add :contents, :url => pages_url, :icon => 'icon-folder-open'
8
- add :settings, :url => edit_current_site_url, :icon => 'icon-cog'
7
+ add :contents, url: pages_url, icon: 'icon-folder-open'
8
+ add :settings, url: edit_current_site_url, icon: 'icon-cog'
9
9
  end
10
10
 
11
11
  end
@@ -3,7 +3,7 @@ module Locomotive
3
3
 
4
4
  include ::Locomotive::Engine.routes.url_helpers
5
5
 
6
- delegate :main_app, :sections, :to => :parent_controller
6
+ delegate :main_app, :sections, to: :parent_controller
7
7
 
8
8
  attr_accessor :list
9
9
 
@@ -19,10 +19,10 @@ module Locomotive
19
19
 
20
20
  def url_options
21
21
  super.reverse_merge(
22
- :host => request.host_with_port,
23
- :protocol => request.protocol,
24
- :_path_segments => request.symbolized_path_parameters
25
- ).merge(:script_name => request.script_name)
22
+ host: request.host_with_port,
23
+ protocol: request.protocol,
24
+ _path_segments: request.symbolized_path_parameters
25
+ ).merge(script_name: request.script_name)
26
26
  end
27
27
 
28
28
  class MenuProxy
@@ -65,7 +65,7 @@ module Locomotive
65
65
  attributes[:label] = localize_label(name)
66
66
  end
67
67
 
68
- attributes.merge!(:name => name, :class => name.to_s.dasherize.downcase)
68
+ attributes.merge!(name: name, class: name.to_s.dasherize.downcase)
69
69
  end
70
70
 
71
71
  def add(name, attributes)
@@ -0,0 +1,21 @@
1
+ module Locomotive
2
+ class PartialsCell < Cell::Rails
3
+ cattr_accessor :templates
4
+
5
+ def self.add_template(namespace, name)
6
+ self.templates ||= {}
7
+ self.templates[namespace] ||= []
8
+ self.templates[namespace] << name
9
+ end
10
+
11
+ def display(namespace, locals = {})
12
+ return unless self.class.templates && self.class.templates[namespace].present?
13
+
14
+ locals.each_pair do |k,v|
15
+ instance_variable_set("@#{k}", v)
16
+ end
17
+
18
+ self.class.templates[namespace].map { |template| render view: template }.join.html_safe
19
+ end
20
+ end
21
+ end
@@ -4,10 +4,10 @@ module Locomotive
4
4
  protected
5
5
 
6
6
  def build_list
7
- add :site, :url => edit_current_site_url
8
- add :theme_assets, :url => theme_assets_url
9
- add :translations, :url => translations_url
10
- add :account, :url => edit_my_account_url
7
+ add :site, url: edit_current_site_url
8
+ add :theme_assets, url: theme_assets_url
9
+ add :translations, url: translations_url
10
+ add :account, url: edit_my_account_url
11
11
  end
12
12
 
13
13
  end
@@ -1,4 +1,4 @@
1
1
  - @list.each do |item|
2
2
  %li
3
- = link_to item[:url], :class => item[:class] do
4
- %span= item[:label]
3
+ = link_to item[:url], class: item[:class] do
4
+ %span= item[:label]
@@ -6,7 +6,7 @@ module Locomotive
6
6
  def build_item(name, attributes)
7
7
  item = super
8
8
  enhanced_class = "#{'on' if name.to_s == sections(:sub).to_s} #{item[:class]}"
9
- item.merge(:class => enhanced_class)
9
+ item.merge(class: enhanced_class)
10
10
  end
11
11
 
12
12
  end
@@ -4,15 +4,15 @@ module Locomotive
4
4
  sections 'settings'
5
5
 
6
6
  def new
7
- @account = Account.new(:email => params[:email])
7
+ @account = Account.new(email: params[:email])
8
8
  respond_with @account
9
9
  end
10
10
 
11
11
  def create
12
12
  @account = Account.create(params[:account])
13
- current_site.memberships.create(:account => @account) if @account.errors.empty?
14
- respond_with @account, :location => edit_current_site_url
13
+ current_site.memberships.create(account: @account) if @account.errors.empty?
14
+ respond_with @account, location: edit_current_site_url
15
15
  end
16
16
 
17
17
  end
18
- end
18
+ end
@@ -5,6 +5,7 @@ module Locomotive
5
5
  load_and_authorize_resource class: Locomotive::Account
6
6
 
7
7
  def index
8
+ @accounts = @accounts.ordered
8
9
  respond_with(@accounts)
9
10
  end
10
11
 
@@ -31,4 +31,4 @@ module Locomotive
31
31
 
32
32
  end
33
33
  end
34
- end
34
+ end
@@ -43,4 +43,4 @@ module Locomotive
43
43
 
44
44
  end
45
45
  end
46
- end
46
+ end
@@ -5,7 +5,7 @@ module Locomotive
5
5
  load_and_authorize_resource class: Locomotive::ContentType, through: :current_site
6
6
 
7
7
  def index
8
- @content_types = @content_types.order_by([[:name, :asc]])
8
+ @content_types = @content_types.order_by(:name.asc)
9
9
  respond_with(@content_types)
10
10
  end
11
11
 
@@ -80,4 +80,4 @@ module Locomotive
80
80
 
81
81
  end
82
82
  end
83
- end
83
+ end
@@ -5,7 +5,7 @@ module Locomotive
5
5
  load_and_authorize_resource class: Locomotive::Page, through: :current_site
6
6
 
7
7
  def index
8
- @pages = @pages.order_by([[:depth, :asc], [:position, :asc]])
8
+ @pages = @pages.order_by(:depth.asc, :position.asc)
9
9
  respond_with(@pages)
10
10
  end
11
11
 
@@ -5,7 +5,7 @@ module Locomotive
5
5
  load_and_authorize_resource class: Locomotive::Snippet, through: :current_site
6
6
 
7
7
  def index
8
- @snippets = @snippets.order_by([[:name, :asc]])
8
+ @snippets = @snippets.order_by(:name.asc)
9
9
  respond_with(@snippets)
10
10
  end
11
11
 
@@ -29,6 +29,53 @@ module Locomotive
29
29
  respond_with @theme_asset
30
30
  end
31
31
 
32
+ def self.description
33
+ {
34
+ overall: %{Manage the assets (stylesheets, javascripts, images, fonts) used by a site},
35
+ actions: {
36
+ index: {
37
+ description: %{Return all the theme assets},
38
+ example: {
39
+ command: %{curl 'http://mysite.com/locomotive/api/theme_assets.json?auth_token=dtsjkqs1TJrWiSiJt2gg'},
40
+ response: %(TODO)
41
+ }
42
+ },
43
+ show: {
44
+ description: %{Return the attributes of a theme asset},
45
+ response: Locomotive::ThemeAssetPresenter.getters_to_hash,
46
+ example: {
47
+ command: %{curl 'http://mysite.com/locomotive/api/theme_assets/4244af4ef0000002.json?auth_token=dtsjkqs1TJrWiSiJt2gg'},
48
+ response: %(TODO)
49
+ }
50
+ },
51
+ create: {
52
+ description: %{Create a theme asset},
53
+ params: Locomotive::ThemeAssetPresenter.setters_to_hash,
54
+ example: {
55
+ command: %{curl -d '...' 'http://mysite.com/locomotive/api/theme_assets.json?auth_token=dtsjkqs1TJrWiSiJt2gg'},
56
+ response: %(TODO)
57
+ }
58
+ },
59
+ update: {
60
+ description: %{Update a theme asset},
61
+ params: Locomotive::ThemeAssetPresenter.setters_to_hash,
62
+ example: {
63
+ command: %{curl -d '...' -X UPDATE 'http://mysite.com/locomotive/api/theme_assets/4244af4ef0000002.json?auth_token=dtsjkqs1TJrWiSiJt2gg'},
64
+ response: %(TODO)
65
+ }
66
+ },
67
+ destroy: {
68
+ description: %{Delete a theme asset},
69
+ example: {
70
+ command: %{curl -X DELETE 'http://mysite.com/locomotive/api/theme_assets/4244af4ef0000002.json?auth_token=dtsjkqs1TJrWiSiJt2gg'},
71
+ response: %(TODO)
72
+ }
73
+ }
74
+ }
75
+ }
76
+ end
77
+
78
+
32
79
  end
33
80
  end
34
81
  end
@@ -6,7 +6,7 @@ module Locomotive
6
6
 
7
7
  def create
8
8
  begin
9
- token = Account.create_api_token(current_site, params[:email], params[:password])
9
+ token = Account.create_api_token(current_site, params[:email], params[:password], params[:api_key])
10
10
  respond_with({ token: token }, location: root_url)
11
11
  rescue Exception => e
12
12
  respond_with({ message: e.message }, status: 401, location: root_url)
@@ -29,7 +29,7 @@ module Locomotive
29
29
  overall: %{Manage a session token which will be passed to all the other REST calls},
30
30
  actions: {
31
31
  create: {
32
- description: %{Generate a session token from an email and a password},
32
+ description: %{Generate a session token from either an email and a password OR an api key},
33
33
  params: { email: 'String', password: 'String' },
34
34
  response: { token: 'String' },
35
35
  example: {
@@ -5,9 +5,12 @@ module Locomotive
5
5
  include Locomotive::ActionController::LocaleHelpers
6
6
  include Locomotive::ActionController::SectionHelpers
7
7
  include Locomotive::ActionController::UrlHelpers
8
+ include Locomotive::ActionController::Ssl
8
9
 
9
10
  layout '/locomotive/layouts/application'
10
11
 
12
+ before_filter :require_ssl
13
+
11
14
  before_filter :require_account
12
15
 
13
16
  before_filter :require_site
@@ -34,7 +37,7 @@ module Locomotive
34
37
  ::Locomotive.log "[CanCan::AccessDenied] #{exception.inspect}"
35
38
 
36
39
  if request.xhr?
37
- render :json => { :error => exception.message }
40
+ render json: { error: exception.message }
38
41
  else
39
42
  flash[:alert] = exception.message
40
43
 
@@ -58,4 +61,4 @@ module Locomotive
58
61
  end
59
62
 
60
63
  end
61
- end
64
+ end
@@ -1,7 +1,7 @@
1
1
  module Locomotive
2
2
  class ContentAssetsController < BaseController
3
3
 
4
- respond_to :json, :only => [:index, :create, :destroy]
4
+ respond_to :json, only: [:index, :create, :destroy]
5
5
 
6
6
  def index
7
7
  @content_assets = current_site.content_assets
@@ -5,21 +5,34 @@ module Locomotive
5
5
 
6
6
  localized
7
7
 
8
- before_filter :back_to_default_site_locale, :only => %w(new create)
8
+ before_filter :back_to_default_site_locale, only: %w(new create)
9
9
 
10
10
  before_filter :set_content_type
11
11
 
12
- respond_to :json, :only => [:show, :edit, :create, :update, :sort]
13
-
14
12
  skip_load_and_authorize_resource
15
13
 
16
14
  before_filter :authorize_content
17
15
 
16
+ respond_to :json, only: [:show, :edit, :create, :update, :sort]
17
+
18
+ respond_to :csv, only: [:export]
19
+
18
20
  def index
19
- @content_entries = @content_type.list_or_group_entries
21
+ options = { page: params[:page] || 1, per_page: Locomotive.config.ui[:per_page] }
22
+ @content_entries = @content_type.list_or_group_entries(options)
20
23
  respond_with @content_entries
21
24
  end
22
25
 
26
+ def export
27
+ @content_entries = @content_type.ordered_entries
28
+ respond_with @content_entries, {
29
+ filename: @content_type.slug,
30
+ col_sep: ';',
31
+ content_type: @content_type,
32
+ host: request.host_with_port
33
+ }
34
+ end
35
+
23
36
  def show
24
37
  @content_entry = @content_type.entries.find(params[:id])
25
38
  respond_with @content_entry
@@ -32,7 +45,7 @@ module Locomotive
32
45
 
33
46
  def create
34
47
  @content_entry = @content_type.entries.create(params[:content_entry])
35
- respond_with @content_entry, :location => edit_content_entry_url(@content_type.slug, @content_entry._id)
48
+ respond_with @content_entry, location: edit_content_entry_url(@content_type.slug, @content_entry._id)
36
49
  end
37
50
 
38
51
  def edit
@@ -43,7 +56,7 @@ module Locomotive
43
56
  def update
44
57
  @content_entry = @content_type.entries.find(params[:id])
45
58
  @content_entry.update_attributes(params[:content_entry])
46
- respond_with @content_entry, :location => edit_content_entry_url(@content_type.slug, @content_entry._id)
59
+ respond_with @content_entry, location: edit_content_entry_url(@content_type.slug, @content_entry._id)
47
60
  end
48
61
 
49
62
  def sort
@@ -54,13 +67,13 @@ module Locomotive
54
67
  def destroy
55
68
  @content_entry = @content_type.entries.find(params[:id])
56
69
  @content_entry.destroy
57
- respond_with @content_entry, :location => content_entries_url(@content_type.slug)
70
+ respond_with @content_entry, location: content_entries_url(@content_type.slug)
58
71
  end
59
72
 
60
73
  protected
61
74
 
62
75
  def set_content_type
63
- @content_type ||= current_site.content_types.where(:slug => params[:slug]).first
76
+ @content_type ||= current_site.content_types.where(slug: params[:slug]).first
64
77
  end
65
78
 
66
79
  def authorize_content
@@ -68,4 +81,4 @@ module Locomotive
68
81
  end
69
82
 
70
83
  end
71
- end
84
+ end
@@ -3,9 +3,9 @@ module Locomotive
3
3
 
4
4
  sections 'contents'
5
5
 
6
- before_filter :back_to_default_site_locale, :only => %w(new create)
6
+ before_filter :back_to_default_site_locale, only: %w(new create)
7
7
 
8
- respond_to :json, :only => [:create, :update, :destroy]
8
+ respond_to :json, only: [:create, :update, :destroy]
9
9
 
10
10
  helper 'Locomotive::Accounts', 'Locomotive::CustomFields'
11
11
 
@@ -16,7 +16,7 @@ module Locomotive
16
16
 
17
17
  def create
18
18
  @content_type = current_site.content_types.create(params[:content_type])
19
- respond_with @content_type, :location => edit_content_type_url(@content_type._id)
19
+ respond_with @content_type, location: edit_content_type_url(@content_type._id)
20
20
  end
21
21
 
22
22
  def edit
@@ -27,14 +27,14 @@ module Locomotive
27
27
  def update
28
28
  @content_type = current_site.content_types.find(params[:id])
29
29
  @content_type.update_attributes(params[:content_type])
30
- respond_with @content_type, :location => edit_content_type_url(@content_type._id)
30
+ respond_with @content_type, location: edit_content_type_url(@content_type._id)
31
31
  end
32
32
 
33
33
  def destroy
34
34
  @content_type = current_site.content_types.find(params[:id])
35
35
  @content_type.destroy
36
- respond_with @content_type, :location => pages_url
36
+ respond_with @content_type, location: pages_url
37
37
  end
38
38
 
39
39
  end
40
- end
40
+ end
@@ -7,15 +7,15 @@ module Locomotive
7
7
 
8
8
  skip_load_and_authorize_resource
9
9
 
10
- load_and_authorize_resource :class => 'Site'
10
+ load_and_authorize_resource class: 'Site'
11
11
 
12
12
  helper 'Locomotive::Sites'
13
13
 
14
14
  before_filter :filter_attributes
15
15
 
16
- before_filter :ensure_domains_list, :only => :update
16
+ before_filter :ensure_domains_list, only: :update
17
17
 
18
- respond_to :json, :only => :update
18
+ respond_to :json, only: :update
19
19
 
20
20
  def edit
21
21
  @site = current_site
@@ -25,7 +25,7 @@ module Locomotive
25
25
  def update
26
26
  @site = current_site
27
27
  @site.update_attributes(params[:site])
28
- respond_with @site, :location => edit_current_site_url(new_host_if_subdomain_changed)
28
+ respond_with @site, location: edit_current_site_url(new_host_if_subdomain_changed)
29
29
  end
30
30
 
31
31
  protected
@@ -40,7 +40,7 @@ module Locomotive
40
40
  if !Locomotive.config.manage_subdomain? || @site.domains.include?(request.host)
41
41
  {}
42
42
  else
43
- { :host => site_url(@site, { :fullpath => false, :protocol => false }) }
43
+ { host: site_url(@site, { fullpath: false, protocol: false }) }
44
44
  end
45
45
  end
46
46
 
@@ -49,4 +49,4 @@ module Locomotive
49
49
  end
50
50
 
51
51
  end
52
- end
52
+ end