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,39 +1,39 @@
1
1
  - content_for :head do
2
- = render 'locomotive/custom_fields/form', :f => f
2
+ = render 'locomotive/custom_fields/form', f: f
3
3
 
4
4
  - content_for :backbone_view_data do
5
5
  :plain
6
- content_type: #{j @content_type.persisted? ? @content_type.to_json.html_safe : 'null'},
7
- inverse_of_list: #{j options_for_content_type_inverse_of.to_json.html_safe}
6
+ content_type: #{escape_json @content_type.persisted? ? @content_type.to_json.html_safe : 'null'},
7
+ inverse_of_list: #{escape_json options_for_content_type_inverse_of.to_json.html_safe}
8
8
 
9
- = f.inputs :name => :information do
9
+ = f.inputs name: :information do
10
10
 
11
- = f.input :name, :wrapper_html => { :class => 'highlighted' }
11
+ = f.input :name, wrapper_html: { class: 'highlighted' }
12
12
 
13
13
  = f.input :slug
14
14
 
15
15
  = f.input :description
16
16
 
17
- = f.inputs :name => :custom_fields, :class => "inputs foldable" do
17
+ = f.inputs name: :custom_fields, class: "inputs foldable" do
18
18
 
19
- = f.input :entries_custom_fields, :as => :'Locomotive::Empty', :label => false, :wrapper_html => { :id => 'custom_fields_input' }
19
+ = f.input :entries_custom_fields, as: :'Locomotive::Empty', label: false, wrapper_html: { id: 'custom_fields_input' }
20
20
 
21
21
  - if @content_type.persisted?
22
22
 
23
- = f.inputs :name => :presentation, :class => "inputs foldable #{'folded' if inputs_folded?(@content_type)}" do
23
+ = f.inputs name: :presentation, class: "inputs foldable #{'folded' if inputs_folded?(@content_type)}" do
24
24
 
25
- = f.input :label_field_id, :as => :select, :collection => options_for_label_field(@content_type), :include_blank => false
25
+ = f.input :label_field_id, as: :select, collection: options_for_label_field(@content_type), include_blank: false
26
26
 
27
- = f.input :group_by_field_id, :as => :select, :collection => options_for_group_by_field(@content_type)
27
+ = f.input :group_by_field_id, as: :select, collection: options_for_group_by_field(@content_type)
28
28
 
29
- = f.input :raw_item_template, :as => :'Locomotive::SmallCode'
29
+ = f.input :raw_item_template, as: :'Locomotive::SmallCode'
30
30
 
31
- = f.inputs :name => :options, :class => "inputs foldable #{'folded' if inputs_folded?(@content_type)}" do
31
+ = f.inputs name: :options, class: "inputs foldable #{'folded' if inputs_folded?(@content_type)}" do
32
32
 
33
- = f.input :order_by, :as => :select, :collection => options_for_order_by(@content_type), :include_blank => false
33
+ = f.input :order_by, as: :select, collection: options_for_order_by(@content_type), include_blank: false
34
34
 
35
- = f.input :order_direction, :as => :select, :collection => options_for_order_direction, :include_blank => false, :wrapper_html => { :style => "#{'display: none' if @content_type.order_manually?}" }
35
+ = f.input :order_direction, as: :select, collection: options_for_order_direction, include_blank: false, wrapper_html: { style: "#{'display: none' if @content_type.order_manually?}" }
36
36
 
37
- = f.input :public_submission_enabled, :as => :'Locomotive::Toggle'
37
+ = f.input :public_submission_enabled, as: :'Locomotive::Toggle'
38
38
 
39
- = f.input :public_submission_accounts, :as => :select, :collection => options_for_account, :include_blank => false, :multiple => true, :wrapper_html => { :class => 'multiple', :style => (@content_type.public_submission_enabled? ? '' : 'display: none') }
39
+ = f.input :public_submission_accounts, as: :select, collection: options_for_account, include_blank: false, multiple: true, wrapper_html: { class: 'multiple', style: (@content_type.public_submission_enabled? ? '' : 'display: none') }
@@ -7,13 +7,13 @@
7
7
  = render 'locomotive/shared/actions/contents'
8
8
 
9
9
  - content_for :buttons do
10
- = local_action_button :show_entries, content_entries_url(@content_type.slug_was), :icon => 'icon-eye-open'
11
- = local_action_button :new_entry, new_content_entry_url(@content_type.slug_was), :icon => 'icon-plus'
10
+ = local_action_button :show_entries, content_entries_url(@content_type.slug_was), icon: 'icon-eye-open'
11
+ = local_action_button :new_entry, new_content_entry_url(@content_type.slug_was), icon: 'icon-plus'
12
12
 
13
13
  %p!= t('.help')
14
14
 
15
- = semantic_form_for @content_type, :url => content_type_url(@content_type) do |f|
15
+ = semantic_form_for @content_type, url: content_type_url(@content_type) do |f|
16
16
 
17
- = render 'form', :f => f
17
+ = render 'form', f: f
18
18
 
19
- = render 'locomotive/shared/form_actions', :back_url => content_entries_url(@content_type.slug_was), :button_label => :update
19
+ = render 'locomotive/shared/form_actions', back_url: content_entries_url(@content_type.slug_was), button_label: :update
@@ -8,8 +8,8 @@
8
8
 
9
9
  %p!= t('.help')
10
10
 
11
- = semantic_form_for @content_type, :url => content_types_url do |f|
11
+ = semantic_form_for @content_type, url: content_types_url do |f|
12
12
 
13
- = render 'form', :f => f
13
+ = render 'form', f: f
14
14
 
15
- = render 'locomotive/shared/form_actions', :back_url => pages_url, :button_label => :create
15
+ = render 'locomotive/shared/form_actions', back_url: pages_url, button_label: :create
@@ -4,33 +4,33 @@
4
4
 
5
5
  - content_for :backbone_view_data do
6
6
  :plain
7
- site: #{j @site.to_json(:current_account => current_locomotive_account, :current_site => current_site).html_safe},
7
+ site: #{escape_json @site.to_json(current_account: current_locomotive_account, current_site: current_site).html_safe},
8
8
  errors: #{@site.errors.to_json}
9
9
 
10
- = f.inputs :name => :information do
11
- = f.input :name, :wrapper_html => { :style => 'display: none' }
12
- = f.input :locales, :as => '::Locomotive::Locales', :collection => ordered_current_site_locales, :input_html => { :class => 'locales' }
10
+ = f.inputs name: :information do
11
+ = f.input :name, wrapper_html: { style: 'display: none' }
12
+ = f.input :locales, as: '::Locomotive::Locales', collection: ordered_current_site_locales, input_html: { class: 'locales' }
13
13
 
14
14
  - if can?(:point, Locomotive::Site)
15
15
  - if manage_subdomain_or_domains?
16
- = f.inputs :name => :access_points do
17
- = f.input :subdomain, :as => :'Locomotive::Subdomain', :domain => application_domain, :input_html => { :readonly => !manage_subdomain? }
16
+ = f.inputs name: :access_points do
17
+ = f.input :subdomain, as: :'Locomotive::Subdomain', domain: application_domain, input_html: { readonly: !manage_subdomain? }
18
18
 
19
19
  - if manage_domains?
20
- = f.input :domains, :as => :'Locomotive::Empty'
20
+ = f.input :domains, as: :'Locomotive::Empty'
21
21
 
22
22
 
23
- = f.inputs :name => :seo, :class => "inputs foldable #{'folded' if inputs_folded?(@site)}" do
23
+ = f.inputs name: :seo, class: "inputs foldable #{'folded' if inputs_folded?(@site)}" do
24
24
  = f.input :seo_title
25
25
  = f.input :meta_keywords
26
26
  = f.input :meta_description
27
27
 
28
28
  - if can?(:index, Locomotive::Membership)
29
29
 
30
- = f.inputs :name => :memberships do
31
- = f.input :memberships, :as => :'Locomotive::Empty', :label => false, :wrapper_html => { :id => 'site_memberships_input' }
30
+ = f.inputs name: :memberships do
31
+ = f.input :memberships, as: :'Locomotive::Empty', label: false, wrapper_html: { id: 'site_memberships_input' }
32
32
 
33
33
  - if can?(:manage, current_site)
34
34
 
35
- = f.inputs :name => :robots_txt, :class => "inputs foldable #{'folded' if inputs_folded?(@site)}" do
36
- = f.input :robots_txt, :as => :'Locomotive::Code', :picker => false, :wrapper_html => { :class => 'small no-label' }
35
+ = f.inputs name: :robots_txt, class: "inputs foldable #{'folded' if inputs_folded?(@site)}" do
36
+ = f.input :robots_txt, as: :'Locomotive::Code', picker: false, wrapper_html: { class: 'small no-label' }
@@ -1,4 +1,4 @@
1
- - title link_to(@site.name.blank? ? @site.name_was : @site.name, '#', :rel => 'site_name', :title => t('.ask_for_name'), :class => 'editable')
1
+ - title link_to(@site.name.blank? ? @site.name_was : @site.name, '#', rel: 'site_name', title: t('.ask_for_name'), class: 'editable')
2
2
 
3
3
  - content_for :submenu do
4
4
  = render_cell 'locomotive/settings_menu', :show
@@ -8,12 +8,12 @@
8
8
 
9
9
  - content_for :buttons do
10
10
  - if can?(:create, Locomotive::Account)
11
- = local_action_button t('.new_membership'), new_membership_url, :icon => 'icon-plus'
11
+ = local_action_button t('.new_membership'), new_membership_url, icon: 'icon-plus'
12
12
 
13
13
  %p!= t('.help')
14
14
 
15
- = semantic_form_for @site, :url => current_site_url do |form|
15
+ = semantic_form_for @site, url: current_site_url do |form|
16
16
 
17
- = render 'form', :f => form
17
+ = render 'form', f: form
18
18
 
19
- = render 'locomotive/shared/form_actions', :button_label => :update
19
+ = render 'locomotive/shared/form_actions', button_label: :update
@@ -1,6 +1,6 @@
1
- %script{ :type => 'text/html', :id => 'custom_fields_list' }
1
+ %script{ type: 'text/html', id: 'custom_fields_list' }
2
2
 
3
- %p.empty{ :style => 'display: none' }!= t('.empty')
3
+ %p.empty{ style: 'display: none' }!= t('.empty')
4
4
 
5
5
  %ul
6
6
 
@@ -8,15 +8,15 @@
8
8
 
9
9
  .new-entry
10
10
 
11
- = text_field_tag 'label', '', :id => '', :placeholder => t('.default_label')
11
+ = text_field_tag 'label', '', id: '', placeholder: t('.default_label')
12
12
 
13
13
  = select_tag 'type', options_for_select(options_for_custom_field_type)
14
14
 
15
15
  %span.actions
16
- = link_to t('locomotive.buttons.new_item'), '#', :class => 'add'
16
+ = link_to t('locomotive.buttons.new_item'), '#', class: 'add'
17
17
 
18
18
 
19
- %script{ :type => 'text/html', :id => 'custom_field_entry' }
19
+ %script{ type: 'text/html', id: 'custom_field_entry' }
20
20
 
21
21
  = f.semantic_fields_for :contents_custom_field, CustomFields::Field.new do |g|
22
22
 
@@ -24,36 +24,40 @@
24
24
  %i.icon-reorder
25
25
 
26
26
  .label-input.col
27
- = g.text_field :label, :class => 'label'
27
+ = g.text_field :label, class: 'label'
28
28
 
29
29
  .type-input.col
30
- = g.select :type, options_for_custom_field_type, {}, { :class => 'type' }
30
+ = g.select :type, options_for_custom_field_type, {}, { class: 'type' }
31
31
 
32
32
  .required-input.col
33
33
  %span= t('.required')
34
- = g.check_box :required, :class => 'required'
34
+ = g.check_box :required, class: 'required'
35
35
 
36
- %ol.nested{ :style => 'display: none' }
36
+ %ol.nested{ style: 'display: none' }
37
37
 
38
- = g.input :name, :input_html => { :class => 'name' }
38
+ = g.input :name, input_html: { class: 'name' }
39
39
 
40
- = g.input :hint, :input_html => { :class => 'hint' }
40
+ = g.input :hint, input_html: { class: 'hint' }
41
41
 
42
- = g.input :localized, :as => :'Locomotive::Toggle', :wrapper_html => { :class => 'localized' }, :input_html => { :class => 'localized' }
42
+ = g.input :localized, as: :'Locomotive::Toggle', wrapper_html: { class: 'localized' }, input_html: { class: 'localized' }
43
43
 
44
- = g.input :select_options, :as => :'Locomotive::Empty', :wrapper_html => { :class => 'extra select-options', :style => 'display: none' }
44
+ = g.input :unique, as: :'Locomotive::Toggle', wrapper_html: {class: 'unique'}, input_html: { class: 'unique'}
45
45
 
46
- = g.input :text_formatting, :as => :select, :collection => options_for_text_formatting, :include_blank => false, :wrapper_html => { :class => 'extra text-formatting' }, :input_html => { :class => 'text_formatting' }
46
+ = g.input :select_options, as: :'Locomotive::Empty', wrapper_html: { class: 'extra select-options', style: 'display: none' }
47
47
 
48
- = g.input :class_name, :as => :select, :collection => options_for_content_type, :include_blank => false, :wrapper_html => { :class => 'extra class-name', :style => 'display: none' }, :input_html => { :class => 'class_name' }
48
+ = g.input :text_formatting, as: :select, collection: options_for_text_formatting, include_blank: false, wrapper_html: { class: 'extra text-formatting' }, input_html: { class: 'text_formatting' }
49
49
 
50
- = g.input :inverse_of, :as => :select, :collection => [], :wrapper_html => { :class => 'extra inverse-of', :style => 'display: none' }, :input_html => { :class => 'inverse_of' }
50
+ = g.input :class_name, as: :select, collection: options_for_content_type, include_blank: false, wrapper_html: { class: 'extra class-name', style: 'display: none' }, input_html: { class: 'class_name' }
51
51
 
52
- = g.input :ui_enabled, :as => :'Locomotive::Toggle', :wrapper_html => { :class => 'extra ui-enabled' }, :input_html => { :class => 'ui_enabled' }
52
+ = g.input :inverse_of, as: :select, collection: [], wrapper_html: { class: 'extra inverse-of', style: 'display: none' }, input_html: { class: 'inverse_of' }
53
+
54
+ = g.input :ui_enabled, as: :'Locomotive::Toggle', wrapper_html: { class: 'extra ui-enabled' }, input_html: { class: 'ui_enabled' }
55
+
56
+ = render_cell 'locomotive/partials', :display, :custom_fields_form, g: g
53
57
 
54
58
  .actions
55
- = link_to_icon :caret_down, '#', :class => 'toggle'
56
- = link_to_icon :trash, '#', :class => 'remove', :data => { :confirm => t('locomotive.messages.confirm') }
59
+ = link_to_icon :caret_down, '#', class: 'toggle'
60
+ = link_to_icon :trash, '#', class: 'remove', data: { confirm: t('locomotive.messages.confirm') }
57
61
 
58
62
  .clear
59
63
 
@@ -1,16 +1,16 @@
1
- %script{ :type => 'text/html', :id => 'select_options_list' }
1
+ %script{ type: 'text/html', id: 'select_options_list' }
2
2
 
3
3
  %ul{ :'data-prompt' => t('locomotive.custom_fields.form.select_options.ask_name') }
4
4
 
5
5
  %span.actions
6
- = link_to t('locomotive.buttons.new_item'), '#', :class => 'add'
6
+ = link_to t('locomotive.buttons.new_item'), '#', class: 'add'
7
7
 
8
8
 
9
- %script{ :type => 'text/html', :id => 'select_option_entry' }
9
+ %script{ type: 'text/html', id: 'select_option_entry' }
10
10
 
11
11
  %li.entry
12
12
  %span.name {{name}}
13
13
 
14
14
  %span.actions
15
- = link_to_icon :move, '#', :class => 'drag'
16
- = link_to_icon :trash, '#', :class => 'remove', :data => { :confirm => t('locomotive.messages.confirm') }
15
+ = link_to_icon :move, '#', class: 'drag'
16
+ = link_to_icon :trash, '#', class: 'remove', data: { confirm: t('locomotive.messages.confirm') }
@@ -1,5 +1,5 @@
1
1
  = f.input :"#{name}_id",
2
- :label => field.label,
3
- :hint => field.hint,
4
- :as => :select,
5
- :collection => options_for_belongs_to_custom_field(field.class_name)
2
+ label: field.label,
3
+ hint: field.hint,
4
+ as: :select,
5
+ collection: options_for_belongs_to_custom_field(field.class_name)
@@ -1,4 +1,4 @@
1
1
  = f.input name,
2
- :label => field.label,
3
- :hint => field.hint,
4
- :as => :'Locomotive::Toggle'
2
+ label: field.label,
3
+ hint: field.hint,
4
+ as: :'Locomotive::Toggle'
@@ -1,5 +1,5 @@
1
1
  = f.input :"formatted_#{name}",
2
- :label => field.label,
3
- :hint => field.hint,
4
- :wrapper_html => { :class => 'date' },
5
- :input_html => { :maxlength => 10 }
2
+ label: field.label,
3
+ hint: field.hint,
4
+ wrapper_html: { class: 'date' },
5
+ input_html: { maxlength: 10 }
@@ -0,0 +1,4 @@
1
+ = f.input name,
2
+ label: field.label,
3
+ hint: field.hint,
4
+ wrapper_html: { class: "#{'highlighted' if highlighted}" }
@@ -1,4 +1,4 @@
1
1
  = f.input name,
2
- :label => field.label,
3
- :hint => field.hint,
4
- :as => :'Locomotive::File'
2
+ label: field.label,
3
+ hint: field.hint,
4
+ as: :'Locomotive::File'
@@ -0,0 +1,6 @@
1
+ = f.input name,
2
+ label: field.label,
3
+ hint: field.hint,
4
+ as: :number,
5
+ step: 0.1,
6
+ wrapper_html: { class: "#{'highlighted' if highlighted}" }
@@ -4,25 +4,25 @@
4
4
  - new_target_content_entry = target_content_type.entries.build(field.inverse_of => f.object)
5
5
 
6
6
  = f.input name.to_sym,
7
- :label => field.label,
8
- :hint => field.hint,
9
- :as => :'locomotive/empty',
10
- :wrapper_html => { :id => "content_entry_#{name}_input", :class => 'empty relationship input' }
7
+ label: field.label,
8
+ hint: field.hint,
9
+ as: :'locomotive/empty',
10
+ wrapper_html: { id: "content_entry_#{name}_input", class: 'empty relationship input' }
11
11
 
12
12
  - content_for :head do
13
13
 
14
- %script{ :type => 'text/html', :id => "#{name}_list" }
14
+ %script{ type: 'text/html', id: "#{name}_list" }
15
15
 
16
- %p.empty{ :style => 'display: none' }!= t('.empty')
16
+ %p.empty{ style: 'display: none' }!= t('.empty')
17
17
 
18
18
  %ul
19
19
 
20
20
  %hr
21
21
 
22
22
  %p.actions
23
- = link_to t('.new_entry'), '#', :class => 'add'
23
+ = link_to t('.new_entry'), '#', class: 'add'
24
24
 
25
- %script{ :type => 'text/html', :id => "#{name}_entry" }
25
+ %script{ type: 'text/html', id: "#{name}_entry" }
26
26
  %li
27
27
  .handle.col
28
28
  %i.icon-reorder
@@ -31,8 +31,8 @@
31
31
  {{label}}
32
32
 
33
33
  %span.actions
34
- = link_to_icon :pencil, '#', :class => 'edit'
35
- = link_to_icon :trash, '#', :class => 'remove', :data => { :confirm => t('locomotive.messages.confirm') }
34
+ = link_to_icon :pencil, '#', class: 'edit'
35
+ = link_to_icon :trash, '#', class: 'remove', data: { confirm: t('locomotive.messages.confirm') }
36
36
 
37
37
 
38
38
  - content_for :backbone_view_data do
@@ -0,0 +1,5 @@
1
+ = f.input name,
2
+ label: field.label,
3
+ hint: field.hint,
4
+ as: :number,
5
+ wrapper_html: { class: "#{'highlighted' if highlighted}" }
@@ -2,16 +2,16 @@
2
2
  - target_content_type = Locomotive::ContentType.class_name_to_content_type(field.class_name, current_site)
3
3
 
4
4
  = f.input name.to_sym,
5
- :label => field.label,
6
- :hint => field.hint,
7
- :as => :'Locomotive::Empty',
8
- :wrapper_html => { :id => "content_entry_#{name}_input", :class => 'empty relationship input' }
5
+ label: field.label,
6
+ hint: field.hint,
7
+ as: :'Locomotive::Empty',
8
+ wrapper_html: { id: "content_entry_#{name}_input", class: 'empty relationship input' }
9
9
 
10
10
  - content_for :head do
11
11
 
12
- %script{ :type => 'text/html', :id => "#{name}_list" }
12
+ %script{ type: 'text/html', id: "#{name}_list" }
13
13
 
14
- %p.empty{ :style => 'display: none' }!= t('.empty')
14
+ %p.empty{ style: 'display: none' }!= t('.empty')
15
15
 
16
16
  %ul
17
17
 
@@ -22,9 +22,9 @@
22
22
  = select_tag 'entry', []
23
23
 
24
24
  %span.actions
25
- = link_to t('locomotive.buttons.new_item'), '#', :class => 'add'
25
+ = link_to t('locomotive.buttons.new_item'), '#', class: 'add'
26
26
 
27
- %script{ :type => 'text/html', :id => "#{name}_entry" }
27
+ %script{ type: 'text/html', id: "#{name}_entry" }
28
28
  %li
29
29
  .handle.col
30
30
  %i.icon-reorder
@@ -33,8 +33,8 @@
33
33
  {{label}}
34
34
 
35
35
  %span.actions
36
- = link_to_icon :trash, '#', :class => 'remove', :data => { :confirm => t('locomotive.messages.confirm') }
36
+ = link_to_icon :trash, '#', class: 'remove', data: { confirm: t('locomotive.messages.confirm') }
37
37
 
38
38
  - content_for :backbone_view_data do
39
39
  :plain
40
- , all_#{name}_entries: #{j target_content_type.list_or_group_entries.to_json(:depth => 1).html_safe}
40
+ , all_#{name}_entries: #{escape_json target_content_type.list_or_group_entries.to_json(depth: 1).html_safe}
@@ -1,8 +1,8 @@
1
1
  = f.input :"#{name}_id",
2
- :label => field.label,
3
- :hint => field.hint,
4
- :as => :select,
5
- :collection => field.ordered_select_options.map { |option| [option.name, option.id] }
2
+ label: field.label,
3
+ hint: field.hint,
4
+ as: :select,
5
+ collection: field.ordered_select_options.map { |option| [option.name, option.id] }
6
6
 
7
7
  - content_for :head do
8
8
 
@@ -11,8 +11,8 @@
11
11
  / Handlebar templates for managing the select options
12
12
  = render 'locomotive/custom_fields/select_templates'
13
13
 
14
- %script{ :type => 'text/html', :id => 'edit_select_options_button' }
15
- = link_to t('locomotive.content_entries.form.edit_select_options'), '#', :class => 'edit-options-button'
14
+ %script{ type: 'text/html', id: 'edit_select_options_button' }
15
+ = link_to t('locomotive.content_entries.form.edit_select_options'), '#', class: 'edit-options-button'
16
16
 
17
17
 
18
18
  - content_for :foot do
@@ -20,15 +20,15 @@
20
20
  - required_once :select_options_popup do
21
21
 
22
22
  / Handlebar template for the popup
23
- %div{ :id => 'edit-select-option-entries', :style => 'display: none' }
23
+ %div{ id: 'edit-select-option-entries', style: 'display: none' }
24
24
 
25
25
  %h2
26
26
  = t('.manage_select_options_entries')
27
27
 
28
- .placeholder{ :data => { :sending_form_message => t('locomotive.messages.sending_form') } }
28
+ .placeholder{ data: { sending_form_message: t('locomotive.messages.sending_form') } }
29
29
 
30
30
  .dialog-actions
31
- = link_to t('locomotive.buttons.close'), '#', :id => 'close-link'
31
+ = link_to t('locomotive.buttons.close'), '#', id: 'close-link'
32
32
 
33
33
  .button-wrapper
34
- = submit_tag t('locomotive.shared.form_actions.update'), { :data => { :disable_with => t('locomotive.shared.form_actions.disable_with') } }
34
+ = submit_tag t('locomotive.shared.form_actions.update'), { data: { disable_with: t('locomotive.shared.form_actions.disable_with') } }