zen 0.3 → 0.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (373) hide show
  1. data/.gems +3 -2
  2. data/.rvmrc +1 -1
  3. data/.travis.yml +5 -0
  4. data/.yardopts +2 -1
  5. data/LICENSE +1 -1
  6. data/README.md +28 -24
  7. data/Rakefile +5 -2
  8. data/guide/asset_management.md +6 -6
  9. data/guide/autosaving_forms.md +42 -0
  10. data/guide/changelog.md +41 -0
  11. data/guide/faq.md +49 -0
  12. data/guide/getting_started.md +24 -13
  13. data/guide/hacking.md +40 -9
  14. data/guide/images/categories/categories.png +0 -0
  15. data/guide/images/categories/category_groups.png +0 -0
  16. data/guide/images/categories/new_category.png +0 -0
  17. data/guide/images/categories/new_category_group.png +0 -0
  18. data/guide/images/comments/comments.png +0 -0
  19. data/guide/images/comments/edit_comment.png +0 -0
  20. data/guide/images/custom_fields/custom_field_groups.png +0 -0
  21. data/guide/images/custom_fields/custom_field_types.png +0 -0
  22. data/guide/images/custom_fields/custom_fields.png +0 -0
  23. data/guide/images/custom_fields/edit_custom_field_general.png +0 -0
  24. data/guide/images/custom_fields/edit_custom_field_group.png +0 -0
  25. data/guide/images/custom_fields/edit_custom_field_settings.png +0 -0
  26. data/guide/images/custom_fields/edit_custom_field_type.png +0 -0
  27. data/guide/images/dashboard/added.png +0 -0
  28. data/guide/images/dashboard/columns.png +0 -0
  29. data/guide/images/dashboard/dashboard.png +0 -0
  30. data/guide/images/dashboard/options.png +0 -0
  31. data/guide/images/menus/edit_menu.png +0 -0
  32. data/guide/images/menus/edit_menu_item.png +0 -0
  33. data/guide/images/menus/menu_item_hierarchy.png +0 -0
  34. data/guide/images/menus/menu_items.png +0 -0
  35. data/guide/images/menus/menus.png +0 -0
  36. data/guide/images/sections/edit_entry.png +0 -0
  37. data/guide/images/sections/edit_entry_categories.png +0 -0
  38. data/guide/images/sections/edit_entry_general.png +0 -0
  39. data/guide/images/sections/edit_entry_meta.png +0 -0
  40. data/guide/images/sections/edit_section_comments.png +0 -0
  41. data/guide/images/sections/edit_section_general.png +0 -0
  42. data/guide/images/sections/edit_section_groups.png +0 -0
  43. data/guide/images/sections/entries.png +0 -0
  44. data/guide/images/sections/sections.png +0 -0
  45. data/guide/images/settings/overview_general.png +0 -0
  46. data/guide/images/settings/overview_security.png +0 -0
  47. data/guide/images/settings/overview_user.png +0 -0
  48. data/guide/images/users/edit_user.png +0 -0
  49. data/guide/images/users/edit_user_group.png +0 -0
  50. data/guide/images/users/edit_user_group_permissions.png +0 -0
  51. data/guide/images/users/edit_user_permissions.png +0 -0
  52. data/guide/images/users/overview.png +0 -0
  53. data/guide/images/users/user_groups_overview.png +0 -0
  54. data/guide/installation.md +7 -1
  55. data/guide/javascript.md +36 -273
  56. data/guide/javascript/zen_autosave.md +26 -0
  57. data/guide/javascript/zen_editor.md +83 -0
  58. data/guide/javascript/zen_hash.md +34 -0
  59. data/guide/javascript/zen_htmltable.md +78 -0
  60. data/guide/javascript/zen_tabs.md +44 -0
  61. data/guide/javascript/zen_window.md +49 -0
  62. data/guide/zen_compared.md +201 -0
  63. data/lib/vendor/sequel_sluggable.rb +1 -1
  64. data/lib/zen.rb +64 -44
  65. data/lib/zen/asset_groups.rb +10 -10
  66. data/lib/zen/bin/create.rb +8 -1
  67. data/lib/zen/helper/breadcrumb.rb +4 -12
  68. data/lib/zen/helper/controller.rb +209 -6
  69. data/lib/zen/helper/locale.rb +19 -0
  70. data/lib/zen/helper/search.rb +1 -1
  71. data/lib/zen/helper/stacked_aspect.rb +7 -43
  72. data/lib/zen/helper/theme.rb +3 -3
  73. data/lib/zen/language.rb +5 -10
  74. data/lib/zen/language/translation.rb +1 -1
  75. data/lib/zen/layout/admin.xhtml +41 -25
  76. data/lib/zen/layout/login.xhtml +8 -3
  77. data/lib/zen/migrator.rb +54 -0
  78. data/lib/zen/model/helper.rb +20 -1
  79. data/lib/zen/model/init.rb +2 -0
  80. data/lib/zen/model/plugin/events.rb +158 -0
  81. data/lib/zen/package.rb +32 -6
  82. data/lib/zen/package/all.rb +1 -0
  83. data/lib/zen/package/categories/lib/categories.rb +6 -6
  84. data/lib/zen/package/categories/lib/categories/controller/categories.rb +20 -83
  85. data/lib/zen/package/categories/lib/categories/controller/category_groups.rb +23 -74
  86. data/lib/zen/package/categories/lib/categories/model/category.rb +58 -1
  87. data/lib/zen/package/categories/lib/categories/model/category_group.rb +62 -2
  88. data/lib/zen/package/categories/lib/categories/view/admin/categories/form.xhtml +46 -40
  89. data/lib/zen/package/categories/lib/categories/view/admin/categories/index.xhtml +74 -75
  90. data/lib/zen/package/categories/lib/categories/view/admin/category-groups/form.xhtml +27 -24
  91. data/lib/zen/package/categories/lib/categories/view/admin/category-groups/index.xhtml +83 -86
  92. data/lib/zen/package/comments/lib/comments.rb +5 -5
  93. data/lib/zen/package/comments/lib/comments/controller/comments.rb +12 -64
  94. data/lib/zen/package/comments/lib/comments/controller/comments_form.rb +4 -22
  95. data/lib/zen/package/comments/lib/comments/model/comment.rb +65 -16
  96. data/lib/zen/package/comments/lib/comments/view/admin/comments/form.xhtml +52 -49
  97. data/lib/zen/package/comments/lib/comments/view/admin/comments/index.xhtml +52 -60
  98. data/lib/zen/package/comments/migrations/1308774099_comment_status.rb +1 -1
  99. data/lib/zen/package/custom_fields/lib/custom_fields.rb +11 -13
  100. data/lib/zen/package/custom_fields/lib/custom_fields/blue_form_parameters.rb +29 -13
  101. data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_field_groups.rb +21 -50
  102. data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_field_types.rb +27 -71
  103. data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_fields.rb +25 -78
  104. data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field.rb +48 -1
  105. data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_group.rb +35 -1
  106. data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_method.rb +3 -0
  107. data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_type.rb +40 -1
  108. data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_value.rb +1 -0
  109. data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-groups/form.xhtml +29 -26
  110. data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-groups/index.xhtml +96 -100
  111. data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-types/form.xhtml +56 -53
  112. data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-types/index.xhtml +82 -82
  113. data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-fields/form.xhtml +88 -85
  114. data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-fields/index.xhtml +83 -80
  115. data/lib/zen/package/dashboard/lib/dashboard.rb +28 -0
  116. data/lib/zen/package/dashboard/lib/dashboard/controller/dashboard.rb +154 -0
  117. data/lib/zen/package/dashboard/lib/dashboard/language/en/dashboard.rb +35 -0
  118. data/lib/zen/package/dashboard/lib/dashboard/language/nl/dashboard.rb +36 -0
  119. data/lib/zen/package/dashboard/lib/dashboard/model/widget.rb +45 -0
  120. data/lib/zen/package/dashboard/lib/dashboard/public/admin/dashboard/css/dashboard.css +74 -0
  121. data/lib/zen/package/dashboard/lib/dashboard/public/admin/dashboard/js/dashboard.js +102 -0
  122. data/lib/zen/package/dashboard/lib/dashboard/view/admin/index.xhtml +29 -0
  123. data/lib/zen/package/dashboard/lib/dashboard/view/admin/widget/welcome.xhtml +28 -0
  124. data/lib/zen/package/dashboard/lib/dashboard/widget.rb +292 -0
  125. data/lib/zen/package/dashboard/lib/dashboard/widget/welcome.rb +9 -0
  126. data/lib/zen/package/dashboard/migrations/1326411254_create_schema.rb +28 -0
  127. data/lib/zen/package/extensions/lib/extensions.rb +5 -5
  128. data/lib/zen/package/extensions/lib/extensions/view/admin/extensions/index.xhtml +72 -67
  129. data/lib/zen/package/menu.rb +6 -1
  130. data/lib/zen/package/menus/lib/menus.rb +6 -4
  131. data/lib/zen/package/menus/lib/menus/controller/menu_items.rb +69 -104
  132. data/lib/zen/package/menus/lib/menus/controller/menus.rb +19 -76
  133. data/lib/zen/package/menus/lib/menus/helper/menu.rb +54 -38
  134. data/lib/zen/package/menus/lib/menus/helper/menu_frontend.rb +7 -13
  135. data/lib/zen/package/menus/lib/menus/model/menu.rb +158 -2
  136. data/lib/zen/package/menus/lib/menus/model/menu_item.rb +73 -10
  137. data/lib/zen/package/menus/lib/menus/public/admin/menus/css/menus.css +47 -0
  138. data/lib/zen/package/menus/lib/menus/public/admin/menus/js/lib/nested_sortables.js +549 -0
  139. data/lib/zen/package/menus/lib/menus/public/admin/menus/js/menu_items.js +38 -0
  140. data/lib/zen/package/menus/lib/menus/view/admin/menu-items/form.xhtml +51 -61
  141. data/lib/zen/package/menus/lib/menus/view/admin/menu-items/index.xhtml +18 -81
  142. data/lib/zen/package/menus/lib/menus/view/admin/menus/form.xhtml +49 -44
  143. data/lib/zen/package/menus/lib/menus/view/admin/menus/index.xhtml +81 -83
  144. data/lib/zen/package/sections/lib/sections.rb +9 -4
  145. data/lib/zen/package/sections/lib/sections/controller/section_entries.rb +80 -132
  146. data/lib/zen/package/sections/lib/sections/controller/sections.rb +27 -73
  147. data/lib/zen/package/sections/lib/sections/helper/section.rb +44 -1
  148. data/lib/zen/package/sections/lib/sections/language/en/section_entries.rb +2 -0
  149. data/lib/zen/package/sections/lib/sections/language/nl/section_entries.rb +2 -0
  150. data/lib/zen/package/sections/lib/sections/model/section.rb +48 -1
  151. data/lib/zen/package/sections/lib/sections/model/section_entry.rb +55 -5
  152. data/lib/zen/package/sections/lib/sections/model/section_entry_status.rb +2 -0
  153. data/lib/zen/package/sections/lib/sections/view/admin/section-entries/form.xhtml +76 -67
  154. data/lib/zen/package/sections/lib/sections/view/admin/section-entries/index.xhtml +74 -79
  155. data/lib/zen/package/sections/lib/sections/view/admin/section-entries/recent_entries.xhtml +45 -0
  156. data/lib/zen/package/sections/lib/sections/view/admin/sections/form.xhtml +119 -0
  157. data/lib/zen/package/sections/lib/sections/view/admin/sections/index.xhtml +96 -0
  158. data/lib/zen/package/sections/lib/sections/widget/recent_entries.rb +14 -0
  159. data/lib/zen/package/sections/migrations/1308813320_section_entry_statuses.rb +1 -1
  160. data/lib/zen/package/settings/lib/settings.rb +14 -5
  161. data/lib/zen/package/settings/lib/settings/controller/settings.rb +4 -4
  162. data/lib/zen/package/settings/lib/settings/language/nl/settings.rb +1 -1
  163. data/lib/zen/package/settings/lib/settings/setting.rb +1 -1
  164. data/lib/zen/package/settings/lib/settings/view/admin/settings/index.xhtml +21 -17
  165. data/lib/zen/package/users/lib/users.rb +18 -19
  166. data/lib/zen/package/users/lib/users/controller/user_groups.rb +23 -50
  167. data/lib/zen/package/users/lib/users/controller/users.rb +57 -89
  168. data/lib/zen/package/users/lib/users/helper/acl.rb +1 -0
  169. data/lib/zen/package/users/lib/users/language/en/user_groups.rb +1 -0
  170. data/lib/zen/package/users/lib/users/language/en/users.rb +2 -1
  171. data/lib/zen/package/users/lib/users/language/nl/user_groups.rb +1 -0
  172. data/lib/zen/package/users/lib/users/language/nl/users.rb +2 -1
  173. data/lib/zen/package/users/lib/users/model/permission.rb +13 -0
  174. data/lib/zen/package/users/lib/users/model/user.rb +57 -4
  175. data/lib/zen/package/users/lib/users/model/user_group.rb +37 -3
  176. data/lib/zen/package/users/lib/users/model/user_status.rb +4 -0
  177. data/lib/zen/package/users/lib/users/public/admin/{css/users/permissions.css → users/css/users.css} +0 -0
  178. data/lib/zen/package/users/lib/users/public/admin/{js/users/permissions.js → users/js/users.js} +4 -2
  179. data/lib/zen/package/users/lib/users/view/admin/user-groups/form.xhtml +51 -47
  180. data/lib/zen/package/users/lib/users/view/admin/user-groups/index.xhtml +62 -69
  181. data/lib/zen/package/users/lib/users/view/admin/users/form.xhtml +92 -82
  182. data/lib/zen/package/users/lib/users/view/admin/users/index.xhtml +68 -66
  183. data/lib/zen/package/users/lib/users/view/admin/users/login.xhtml +36 -28
  184. data/lib/zen/package/users/lib/users/view/admin/users/permissions.xhtml +5 -7
  185. data/lib/zen/package/users/lib/users/view/admin/users/register.xhtml +47 -41
  186. data/lib/zen/package/users/migrations/1320272365_status_ids.rb +1 -1
  187. data/lib/zen/public/admin/{js/vendor/mootools → mootools/js}/core.js +113 -108
  188. data/lib/zen/public/admin/{js/vendor/mootools → mootools/js}/more.js +99 -6
  189. data/lib/zen/public/admin/zen/css/buttons.css +106 -0
  190. data/lib/zen/public/admin/{css/zen → zen/css}/datepicker.css +45 -30
  191. data/lib/zen/public/admin/zen/css/editor.css +69 -0
  192. data/lib/zen/public/admin/{css/zen → zen/css}/forms.css +28 -30
  193. data/lib/zen/public/admin/zen/css/general.css +183 -0
  194. data/lib/zen/public/admin/zen/css/layout.css +224 -0
  195. data/lib/zen/public/admin/zen/css/messages.css +34 -0
  196. data/lib/zen/public/admin/{css/zen → zen/css}/reset.css +4 -9
  197. data/lib/zen/public/admin/zen/css/tables.css +57 -0
  198. data/lib/zen/public/admin/zen/css/tabs.css +84 -0
  199. data/lib/zen/public/admin/zen/css/window.css +74 -0
  200. data/lib/zen/public/admin/{images/zen → zen/images}/icons/asc.png +0 -0
  201. data/lib/zen/public/admin/{images/zen → zen/images}/icons/bold.png +0 -0
  202. data/lib/zen/public/admin/zen/images/icons/box.png +0 -0
  203. data/lib/zen/public/admin/zen/images/icons/categories.png +0 -0
  204. data/lib/zen/public/admin/{images/zen → zen/images}/icons/close.png +0 -0
  205. data/lib/zen/public/admin/zen/images/icons/comment.png +0 -0
  206. data/lib/zen/public/admin/{images/zen → zen/images}/icons/desc.png +0 -0
  207. data/lib/zen/public/admin/{images/zen → zen/images}/icons/edit.png +0 -0
  208. data/lib/zen/public/admin/{images/zen → zen/images}/icons/error.png +0 -0
  209. data/lib/zen/public/admin/zen/images/icons/external.png +0 -0
  210. data/lib/zen/public/admin/zen/images/icons/globe.png +0 -0
  211. data/lib/zen/public/admin/{images/zen → zen/images}/icons/italic.png +0 -0
  212. data/lib/zen/public/admin/{images/zen → zen/images}/icons/link.png +0 -0
  213. data/lib/zen/public/admin/zen/images/icons/lock.png +0 -0
  214. data/lib/zen/public/admin/{images/zen → zen/images}/icons/ol.png +0 -0
  215. data/lib/zen/public/admin/zen/images/icons/pages.png +0 -0
  216. data/lib/zen/public/admin/{images/zen → zen/images}/icons/preview.png +0 -0
  217. data/lib/zen/public/admin/zen/images/icons/relation.png +0 -0
  218. data/lib/zen/public/admin/zen/images/icons/settings.png +0 -0
  219. data/lib/zen/public/admin/zen/images/icons/template.png +0 -0
  220. data/lib/zen/public/admin/{images/zen → zen/images}/icons/ul.png +0 -0
  221. data/lib/zen/public/admin/{images/zen → zen/images}/icons/user.png +0 -0
  222. data/lib/zen/public/admin/zen/images/icons/user_group.png +0 -0
  223. data/lib/zen/public/admin/{js/zen → zen/js}/index.js +21 -9
  224. data/lib/zen/public/admin/zen/js/lib/autosave.js +185 -0
  225. data/lib/zen/public/admin/zen/js/lib/base.js +60 -0
  226. data/lib/zen/public/admin/{js/vendor → zen/js/lib}/datepicker.js +52 -28
  227. data/lib/zen/public/admin/{js/zen → zen/js}/lib/editor.js +23 -34
  228. data/lib/zen/public/admin/{js/zen → zen/js}/lib/editor/markdown.js +5 -1
  229. data/lib/zen/public/admin/{js/zen → zen/js}/lib/editor/textile.js +4 -0
  230. data/lib/zen/public/admin/zen/js/lib/hash.js +218 -0
  231. data/lib/zen/public/admin/{js/zen → zen/js}/lib/html_table.js +5 -0
  232. data/lib/zen/public/admin/zen/js/lib/tabs.js +194 -0
  233. data/lib/zen/public/admin/{js/zen → zen/js}/lib/window.js +54 -29
  234. data/lib/zen/security.rb +50 -0
  235. data/lib/zen/spec/helper.rb +5 -120
  236. data/lib/zen/spec/helper/capybara.rb +75 -0
  237. data/lib/zen/spec/helper/general.rb +75 -0
  238. data/lib/zen/spec/simplecov.rb +1 -0
  239. data/lib/zen/task/build.rake +2 -21
  240. data/lib/zen/task/clean.rake +1 -10
  241. data/lib/zen/task/db.rake +4 -10
  242. data/lib/zen/task/package.rake +2 -5
  243. data/lib/zen/task/setup.rake +1 -1
  244. data/lib/zen/task/test.rake +6 -6
  245. data/lib/zen/task/theme.rake +2 -5
  246. data/lib/zen/theme.rb +26 -22
  247. data/lib/zen/version.rb +1 -1
  248. data/lib/zen/view/bottom.xhtml +2 -3
  249. data/lib/zen/view/search.xhtml +3 -5
  250. data/proto/app/config/config.rb.erb +1 -1
  251. data/proto/app/theme/default/index.xhtml +116 -20
  252. data/proto/app/theme/partials/head.xhtml +9 -0
  253. data/proto/app/theme/partials/sidebar.xhtml +40 -0
  254. data/proto/app/theme/theme.rb +3 -0
  255. data/spec/Rakefile +1 -2
  256. data/spec/fixtures/zen/helper/stacked_aspect.rb +54 -0
  257. data/spec/fixtures/zen/package/dashboard/controller/widget.rb +15 -0
  258. data/spec/fixtures/zen/package/dashboard/widget.rb +5 -0
  259. data/spec/fixtures/zen/theme/theme.rb +2 -2
  260. data/spec/helper.rb +19 -10
  261. data/spec/zen/controller/admin_controller.rb +3 -3
  262. data/spec/zen/controller/main_controller.rb +7 -7
  263. data/spec/zen/controller/preview.rb +3 -3
  264. data/spec/zen/event.rb +4 -4
  265. data/spec/zen/helper/breadcrumb.rb +4 -8
  266. data/spec/zen/helper/controller.rb +47 -4
  267. data/spec/zen/helper/locale.rb +3 -3
  268. data/spec/zen/helper/message.rb +4 -4
  269. data/spec/zen/helper/stacked_aspect.rb +40 -0
  270. data/spec/zen/helper/theme.rb +9 -9
  271. data/spec/zen/language.rb +8 -8
  272. data/spec/zen/markup.rb +6 -6
  273. data/spec/zen/package.rb +11 -9
  274. data/spec/zen/package/categories/controller/categories.rb +56 -24
  275. data/spec/zen/package/categories/controller/category_groups.rb +55 -23
  276. data/spec/zen/package/categories/helper/category.rb +5 -5
  277. data/spec/zen/package/categories/helper/category_frontend.rb +5 -5
  278. data/spec/zen/package/comments/anti_spam.rb +4 -4
  279. data/spec/zen/package/comments/controller/comments.rb +95 -24
  280. data/spec/zen/package/comments/controller/comments_form.rb +31 -26
  281. data/spec/zen/package/comments/helper/comment.rb +3 -3
  282. data/spec/zen/package/comments/helper/comment_frontend.rb +6 -6
  283. data/spec/zen/package/custom_fields/blue_form_parameters.rb +8 -8
  284. data/spec/zen/package/custom_fields/controller/custom_field_groups.rb +58 -27
  285. data/spec/zen/package/custom_fields/controller/custom_field_types.rb +57 -27
  286. data/spec/zen/package/custom_fields/controller/custom_fields.rb +58 -27
  287. data/spec/zen/package/custom_fields/helper/custom_field.rb +7 -7
  288. data/spec/zen/package/dashboard/controller/dashboard.rb +147 -0
  289. data/spec/zen/package/dashboard/widget.rb +56 -0
  290. data/spec/zen/package/extensions/controller/extensions.rb +4 -4
  291. data/spec/zen/package/menus/controller/menu_items.rb +48 -39
  292. data/spec/zen/package/menus/controller/menus.rb +55 -24
  293. data/spec/zen/package/menus/helper/menu.rb +6 -14
  294. data/spec/zen/package/menus/helper/menu_frontend.rb +7 -7
  295. data/spec/zen/package/menus/model/menu.rb +121 -0
  296. data/spec/zen/package/menus/model/menu_item.rb +34 -0
  297. data/spec/zen/package/sections/controller/section_entries.rb +104 -39
  298. data/spec/zen/package/sections/controller/sections.rb +60 -27
  299. data/spec/zen/package/sections/helper/section.rb +5 -5
  300. data/spec/zen/package/sections/helper/section_frontend.rb +9 -9
  301. data/spec/zen/package/sections/widget.rb +44 -0
  302. data/spec/zen/package/settings/controller/settings.rb +18 -16
  303. data/spec/zen/package/settings/settings.rb +12 -12
  304. data/spec/zen/package/users/controller/user_groups.rb +61 -29
  305. data/spec/zen/package/users/controller/users.rb +118 -39
  306. data/spec/zen/package/users/helper/access.rb +3 -3
  307. data/spec/zen/package/users/helper/acl.rb +4 -4
  308. data/spec/zen/package/users/helper/users.rb +5 -5
  309. data/spec/zen/security.rb +25 -0
  310. data/spec/zen/theme.rb +20 -18
  311. data/spec/zen/validation.rb +5 -5
  312. data/spec/zen/vendor/sequel_sluggable.rb +12 -0
  313. data/zen.gemspec +27 -4
  314. metadata +182 -124
  315. data/AUTHORS +0 -4
  316. data/guide/_static/categories/categories.png +0 -0
  317. data/guide/_static/categories/category_groups.png +0 -0
  318. data/guide/_static/categories/new_category.png +0 -0
  319. data/guide/_static/categories/new_category_group.png +0 -0
  320. data/guide/_static/comments/comments.png +0 -0
  321. data/guide/_static/comments/edit_comment.png +0 -0
  322. data/guide/_static/custom_fields/custom_field_groups.png +0 -0
  323. data/guide/_static/custom_fields/custom_field_types.png +0 -0
  324. data/guide/_static/custom_fields/custom_fields.png +0 -0
  325. data/guide/_static/custom_fields/edit_custom_field_general.png +0 -0
  326. data/guide/_static/custom_fields/edit_custom_field_group.png +0 -0
  327. data/guide/_static/custom_fields/edit_custom_field_settings.png +0 -0
  328. data/guide/_static/custom_fields/edit_custom_field_type.png +0 -0
  329. data/guide/_static/menus/edit_menu.png +0 -0
  330. data/guide/_static/menus/edit_menu_item.png +0 -0
  331. data/guide/_static/menus/menu_items.png +0 -0
  332. data/guide/_static/menus/menus.png +0 -0
  333. data/guide/_static/sections/edit_entry.png +0 -0
  334. data/guide/_static/sections/edit_entry_categories.png +0 -0
  335. data/guide/_static/sections/edit_entry_general.png +0 -0
  336. data/guide/_static/sections/edit_entry_meta.png +0 -0
  337. data/guide/_static/sections/edit_section_comments.png +0 -0
  338. data/guide/_static/sections/edit_section_general.png +0 -0
  339. data/guide/_static/sections/edit_section_groups.png +0 -0
  340. data/guide/_static/sections/entries.png +0 -0
  341. data/guide/_static/sections/sections.png +0 -0
  342. data/guide/_static/settings/overview_general.png +0 -0
  343. data/guide/_static/settings/overview_security.png +0 -0
  344. data/guide/_static/settings/overview_user.png +0 -0
  345. data/guide/_static/users/edit_user.png +0 -0
  346. data/guide/_static/users/edit_user_group.png +0 -0
  347. data/guide/_static/users/edit_user_group_permissions.png +0 -0
  348. data/guide/_static/users/edit_user_permissions.png +0 -0
  349. data/guide/_static/users/overview.png +0 -0
  350. data/guide/_static/users/user_groups_overview.png +0 -0
  351. data/lib/zen/controller/translations.rb +0 -49
  352. data/lib/zen/package/sections/lib/sections/view/admin/form.xhtml +0 -113
  353. data/lib/zen/package/sections/lib/sections/view/admin/index.xhtml +0 -97
  354. data/lib/zen/public/admin/css/zen/buttons.css +0 -46
  355. data/lib/zen/public/admin/css/zen/editor.css +0 -88
  356. data/lib/zen/public/admin/css/zen/general.css +0 -109
  357. data/lib/zen/public/admin/css/zen/grid.css +0 -100
  358. data/lib/zen/public/admin/css/zen/layout.css +0 -184
  359. data/lib/zen/public/admin/css/zen/messages.css +0 -54
  360. data/lib/zen/public/admin/css/zen/tables.css +0 -97
  361. data/lib/zen/public/admin/css/zen/tabs.css +0 -47
  362. data/lib/zen/public/admin/css/zen/window.css +0 -73
  363. data/lib/zen/public/admin/images/zen/icons/accept.png +0 -0
  364. data/lib/zen/public/admin/images/zen/icons/add.png +0 -0
  365. data/lib/zen/public/admin/images/zen/icons/back.png +0 -0
  366. data/lib/zen/public/admin/images/zen/icons/delete.png +0 -0
  367. data/lib/zen/public/admin/images/zen/icons/help.png +0 -0
  368. data/lib/zen/public/admin/images/zen/icons/info.png +0 -0
  369. data/lib/zen/public/admin/images/zen/icons/logout.png +0 -0
  370. data/lib/zen/public/admin/images/zen/icons/pdf.png +0 -0
  371. data/lib/zen/public/admin/images/zen/icons/view.png +0 -0
  372. data/lib/zen/public/admin/js/zen/lib/tabs.js +0 -207
  373. data/lib/zen/view/main.xhtml +0 -19
@@ -4,17 +4,40 @@ module CustomFields
4
4
  ##
5
5
  # Model that represents a single custom field group.
6
6
  #
7
- # @since 0.1
7
+ # @since 0.1
8
+ # @event before_new_custom_field_group
9
+ # @event after_new_custom_field_group
10
+ # @event before_edit_custom_field_group
11
+ # @event after_edit_custom_field_group
12
+ # @event before_delete_custom_field_group
13
+ # @event after_delete_custom_field_group
8
14
  #
9
15
  class CustomFieldGroup < Sequel::Model
10
16
  include Zen::Model::Helper
11
17
 
18
+ ##
19
+ # Array containing the columns that can be set by the user.
20
+ #
21
+ # @since 17-02-2012
22
+ #
23
+ COLUMNS = [:name, :description]
24
+
12
25
  one_to_many :custom_fields,
13
26
  :class => 'CustomFields::Model::CustomField',
14
27
  :order => :sort_order
15
28
 
16
29
  many_to_many :sections, :class => 'Sections::Model::Section'
17
30
 
31
+ plugin :association_dependencies, :custom_fields => :delete
32
+
33
+ plugin :events,
34
+ :before_create => :before_new_custom_field_group,
35
+ :after_create => :after_new_custom_field_group,
36
+ :before_update => :before_edit_custom_field_group,
37
+ :after_update => :after_edit_custom_field_group,
38
+ :before_destroy => :before_delete_custom_field_group,
39
+ :after_destroy => :after_delete_custom_field_group
40
+
18
41
  ##
19
42
  # Searches for a set of custom field groups.
20
43
  #
@@ -35,6 +58,17 @@ module CustomFields
35
58
  validates_presence(:name)
36
59
  validates_max_length(255, :name)
37
60
  end
61
+
62
+ ##
63
+ # Hook that is executed before creating or saving an object.
64
+ #
65
+ # @since 03-01-2012
66
+ #
67
+ def before_save
68
+ sanitize_fields([:name, :description])
69
+
70
+ super
71
+ end
38
72
  end # CustomFieldGroup
39
73
  end # Model
40
74
  end # CustomFields
@@ -7,7 +7,10 @@ module CustomFields
7
7
  # @since 0.2.8
8
8
  #
9
9
  class CustomFieldMethod < Sequel::Model
10
+ one_to_many :custom_field_types,
11
+ :class => 'CustomFields::Model::CustomFieldType'
10
12
 
13
+ plugin :association_dependencies, :custom_field_types => :delete
11
14
  end # CustomFieldType
12
15
  end # Model
13
16
  end # CustomFields
@@ -4,14 +4,42 @@ module CustomFields
4
4
  ##
5
5
  # Model for managing custom field types.
6
6
  #
7
- # @since 0.2.8
7
+ # @since 0.2.8
8
+ # @event before_new_custom_field_type
9
+ # @event after_new_custom_field_type
10
+ # @event before_edit_custom_field_type
11
+ # @event after_edit_custom_field_type
12
+ # @event before_delete_custom_field_type
13
+ # @event after_delete_custom_field_type
8
14
  #
9
15
  class CustomFieldType < Sequel::Model
10
16
  include Zen::Model::Helper
11
17
 
18
+ ##
19
+ # Array containing all the columns that can be set by the user.
20
+ #
21
+ # @since 17-02-2012
22
+ #
23
+ COLUMNS = [
24
+ :name, :language_string, :html_class, :serialize, :allow_markup,
25
+ :custom_field_method_id
26
+ ]
27
+
12
28
  many_to_one :custom_field_method,
13
29
  :class => 'CustomFields::Model::CustomFieldMethod'
14
30
 
31
+ one_to_many :custom_fields, :class => 'CustomFields::Model::CustomField'
32
+
33
+ plugin :association_dependencies, :custom_fields => :delete
34
+
35
+ plugin :events,
36
+ :before_create => :before_new_custom_field_type,
37
+ :after_create => :after_new_custom_field_type,
38
+ :before_update => :before_edit_custom_field_type,
39
+ :after_update => :after_edit_custom_field_type,
40
+ :before_destroy => :before_delete_custom_field_type,
41
+ :after_destroy => :after_delete_custom_field_type
42
+
15
43
  ##
16
44
  # Searches for a set of custom field types.
17
45
  #
@@ -55,6 +83,17 @@ module CustomFields
55
83
 
56
84
  validates_max_length(255, [:name, :language_string, :html_class])
57
85
  end
86
+
87
+ ##
88
+ # Hook that is executed before creating or saving an object.
89
+ #
90
+ # @since 03-01-2012
91
+ #
92
+ def before_save
93
+ sanitize_fields([:name, :language_string, :html_class])
94
+
95
+ super
96
+ end
58
97
  end # CustomFieldType
59
98
  end # Model
60
99
  end # CustomFields
@@ -19,6 +19,7 @@ module CustomFields
19
19
  # @param [Mixed] value The value to store.
20
20
  #
21
21
  def value=(val)
22
+ val = Zen::Security.sanitize(val)
22
23
  type = custom_field.custom_field_type
23
24
 
24
25
  if !type.nil? and type.serialize == true
@@ -3,33 +3,36 @@
3
3
  <h1>#{get_breadcrumbs}</h1>
4
4
  </header>
5
5
 
6
- #{form_for(
7
- @field_group,
8
- :method => :post,
9
- :action => CustomFields::Controller::CustomFieldGroups.r(:save),
10
- :id => :custom_field_group_form
11
- ) do |f|
12
- f.input_hidden(:id , @field_group.id)
13
- f.input_hidden(:csrf_token, get_csrf_token)
6
+ <div class="body">
7
+ #{form_for(
8
+ @field_group,
9
+ :method => :post,
10
+ :action => CustomFields::Controller::CustomFieldGroups.r(:save),
11
+ :id => :custom_field_group_form,
12
+ :'data-autosave-url' => CustomFields::Controller::CustomFieldGroups \
13
+ .r(:autosave)
14
+ ) do |f|
15
+ f.input_hidden(:id , @field_group.id)
16
+ f.input_hidden(:csrf_token, get_csrf_token)
14
17
 
15
- f.input_text(
16
- lang('custom_field_groups.labels.name'),
17
- :name,
18
- :required => :required,
19
- :maxlength => 255
20
- )
18
+ f.input_text(
19
+ lang('custom_field_groups.labels.name'),
20
+ :name,
21
+ :required => :required,
22
+ :maxlength => 255
23
+ )
21
24
 
22
- f.textarea(
23
- lang('custom_field_groups.labels.description'),
24
- :description,
25
- :rows => 8
26
- )
25
+ f.textarea(
26
+ lang('custom_field_groups.labels.description'),
27
+ :description,
28
+ :rows => 8
29
+ )
27
30
 
28
- f.g.div(:class => 'button') do
29
- f.g.input(
30
- :type => 'submit',
31
- :value => lang('custom_field_groups.buttons.save')
32
- )
33
- end
34
- end}
31
+ f.g.input(
32
+ :type => 'submit',
33
+ :value => lang('custom_field_groups.buttons.save'),
34
+ :class => 'button'
35
+ )
36
+ end}
37
+ </div>
35
38
  </section>
@@ -1,112 +1,108 @@
1
1
  <section>
2
- #{render_search_form(
3
- ::CustomFields::Controller::CustomFieldGroups.r(:index)
4
- )}
5
-
6
- <header>
2
+ <header class="with_search">
7
3
  <h1>#{get_breadcrumbs}</h1>
8
- </header>
9
-
10
- <form method="post"
11
- action="#{CustomFields::Controller::CustomFieldGroups.r(:delete)}">
12
- <input type="hidden" name="csrf_token" value="#{get_csrf_token}" />
13
4
 
14
- <?r if !@field_groups.empty? ?>
15
-
16
- <table>
17
- <thead>
18
- <tr>
19
- <?r if user_authorized?(:delete_custom_field_group) ?>
20
- <th class="no_sort">
21
- <input type="checkbox" />
22
- </th>
23
- <?r end ?>
24
-
25
- <th>#{lang('custom_field_groups.labels.id')}</th>
26
- <th>#{lang('custom_field_groups.labels.name')}</th>
27
- <th>#{lang('custom_field_groups.labels.sections')}</th>
28
-
29
- <?r if user_authorized?(:show_custom_field) ?>
30
- <th></th>
31
- <?r end ?>
32
- </tr>
33
- </thead>
34
- <tbody>
35
- <?r @field_groups.each do |group| ?>
36
- <tr>
37
- <?r if user_authorized?(:delete) ?>
38
- <td>
39
- <input type="checkbox" name="custom_field_group_ids[]"
40
- value="#{group.id}" />
41
- </td>
42
- <?r end ?>
43
-
44
- <td>#{group.id}</td>
45
-
46
- <?r if user_authorized?(:edit_custom_field_group) ?>
47
-
48
- <td>
49
- #{CustomFields::Controller::CustomFieldGroups.a(
50
- group.name, :edit, group.id
51
- )}
52
- </td>
53
-
54
- <?r else ?>
55
-
56
- <td>#{group.name}</td>
57
-
58
- <?r end ?>
5
+ #{render_search_form(
6
+ CustomFields::Controller::CustomFieldGroups.r(:index)
7
+ )}
8
+ </header>
59
9
 
60
- <td>
61
- #{sections = group.sections.map { |s| s.name }
62
-
63
- if sections.empty?
64
- lang('custom_field_groups.labels.none')
65
- else
66
- sections.join(', ')
67
- end}
68
- </td>
69
-
70
- <?r if user_authorized?(:show_custom_field) ?>
71
- <td>
72
- #{CustomFields::Controller::CustomFields.a(
73
- lang('custom_field_groups.labels.manage_fields'),
74
- :index,
75
- group.id
76
- )}
77
- </td>
10
+ <div class="body">
11
+ <form method="post"
12
+ action="#{CustomFields::Controller::CustomFieldGroups.r(:delete)}">
13
+ <input type="hidden" name="csrf_token" value="#{get_csrf_token}" />
14
+
15
+ <?r if !@field_groups.empty? ?>
16
+
17
+ <table>
18
+ <thead>
19
+ <tr>
20
+ <?r if user_authorized?(:delete_custom_field_group) ?>
21
+ <th class="no_sort">
22
+ <input type="checkbox" />
23
+ </th>
24
+ <?r end ?>
25
+
26
+ <th>#{lang('custom_field_groups.labels.id')}</th>
27
+ <th>#{lang('custom_field_groups.labels.name')}</th>
28
+ <th>#{lang('custom_field_groups.labels.sections')}</th>
29
+
30
+ <?r if user_authorized?(:show_custom_field) ?>
31
+ <th></th>
32
+ <?r end ?>
33
+ </tr>
34
+ </thead>
35
+ <tbody>
36
+ <?r @field_groups.each do |group| ?>
37
+ <tr>
38
+ <?r if user_authorized?(:delete) ?>
39
+ <td>
40
+ <input type="checkbox" name="custom_field_group_ids[]"
41
+ value="#{group.id}" />
42
+ </td>
43
+ <?r end ?>
44
+
45
+ <td>#{group.id}</td>
46
+
47
+ <td>
48
+ #{if user_authorized?(:edit_custom_field_group)
49
+ edit_link(
50
+ CustomFields::Controller::CustomFieldGroups.r(
51
+ :edit,
52
+ group.id
53
+ ),
54
+ group.name
55
+ )
56
+ else
57
+ group.name
58
+ end}
59
+ </td>
60
+
61
+ <td>
62
+ #{sections = group.sections.map { |s| s.name }
63
+
64
+ if sections.empty?
65
+ lang('custom_field_groups.labels.none')
66
+ else
67
+ sections.join(', ')
68
+ end}
69
+ </td>
70
+
71
+ <?r if user_authorized?(:show_custom_field) ?>
72
+ <td>
73
+ #{manage_link(
74
+ CustomFields::Controller::CustomFields.r(
75
+ :index,
76
+ group.id
77
+ ),
78
+ lang('custom_field_groups.labels.manage_fields')
79
+ )}
80
+ </td>
81
+ <?r end ?>
82
+ </tr>
78
83
  <?r end ?>
79
- </tr>
80
- <?r end ?>
81
- </tbody>
82
- </table>
84
+ </tbody>
85
+ </table>
83
86
 
84
- #{if @field_groups.respond_to?(:navigation) \
85
- and @field_groups.page_count > 1
86
- @field_groups.navigation
87
- end}
87
+ #{render_pagination(@field_groups)}
88
88
 
89
- <?r else ?>
89
+ <?r else ?>
90
90
 
91
- <p>#{lang('custom_field_groups.messages.no_groups')}</p>
91
+ <p>#{lang('custom_field_groups.messages.no_groups')}</p>
92
92
 
93
- <?r end ?>
93
+ <?r end ?>
94
94
 
95
- <?r if user_authorized?(:new_custom_field_group) ?>
96
- <div class="button">
97
- #{CustomFields::Controller::CustomFieldGroups.a(
98
- lang('custom_field_groups.buttons.new'),
99
- :new
95
+ <?r if user_authorized?(:new_custom_field_group) ?>
96
+ #{new_button(
97
+ CustomFields::Controller::CustomFieldGroups.r(:new),
98
+ lang('custom_field_groups.buttons.new')
100
99
  )}
101
- </div>
102
- <?r end ?>
103
-
104
- <?r if user_authorized?(:delete_custom_field_group) \
105
- and !@field_groups.empty? ?>
106
- <div class="button">
107
- <input type="submit"
108
- value="#{lang('custom_field_groups.buttons.delete')}" />
109
- </div>
110
- <?r end ?>
111
- </form>
100
+ <?r end ?>
101
+
102
+ <?r if user_authorized?(:delete_custom_field_group) \
103
+ and !@field_groups.empty? ?>
104
+ #{delete_button(lang('custom_field_groups.buttons.delete'))}
105
+ <?r end ?>
106
+ </form>
107
+ </div>
112
108
  </section>
@@ -3,64 +3,67 @@
3
3
  <h1>#{get_breadcrumbs}</h1>
4
4
  </header>
5
5
 
6
- #{form_for(
7
- @custom_field_type,
8
- :method => :post,
9
- :id => :custom_field_type_form,
10
- :action => CustomFields::Controller::CustomFieldTypes.r(:save)
11
- ) do |f|
12
- f.input_hidden(:csrf_token, get_csrf_token)
13
- f.input_hidden(:id , @custom_field_type.id)
6
+ <div class="body">
7
+ #{form_for(
8
+ @custom_field_type,
9
+ :method => :post,
10
+ :id => :custom_field_type_form,
11
+ :action => CustomFields::Controller::CustomFieldTypes.r(:save),
12
+ :'data-autosave-url' => CustomFields::Controller::CustomFieldTypes \
13
+ .r(:autosave)
14
+ ) do |f|
15
+ f.input_hidden(:csrf_token, get_csrf_token)
16
+ f.input_hidden(:id , @custom_field_type.id)
14
17
 
15
- f.input_text(
16
- lang('custom_field_types.labels.name'),
17
- :name,
18
- :required => :required,
19
- :maxlength => 255
20
- )
18
+ f.input_text(
19
+ lang('custom_field_types.labels.name'),
20
+ :name,
21
+ :required => :required,
22
+ :maxlength => 255
23
+ )
21
24
 
22
- f.input_text(
23
- lang('custom_field_types.labels.language_string'),
24
- :language_string,
25
- :required => :required,
26
- :maxlength => 255
27
- )
25
+ f.input_text(
26
+ lang('custom_field_types.labels.language_string'),
27
+ :language_string,
28
+ :required => :required,
29
+ :maxlength => 255
30
+ )
28
31
 
29
- f.input_text(
30
- lang('custom_field_types.labels.html_class'),
31
- :html_class,
32
- :maxlength => 255,
33
- :pattern => '^[a-zA-Z\\\-_0-9\\\s]*$'
34
- )
32
+ f.input_text(
33
+ lang('custom_field_types.labels.html_class'),
34
+ :html_class,
35
+ :maxlength => 255,
36
+ :pattern => '^[a-zA-Z\\\-_0-9\\\s]*$'
37
+ )
35
38
 
36
- f.input_radio(
37
- lang('custom_field_types.labels.serialize'),
38
- :serialize,
39
- @custom_field_type.serialize,
40
- :values => @boolean_hash.invert
41
- )
39
+ f.input_radio(
40
+ lang('custom_field_types.labels.serialize'),
41
+ :serialize,
42
+ @custom_field_type.serialize,
43
+ :values => @boolean_hash.invert
44
+ )
42
45
 
43
- f.input_radio(
44
- lang('custom_field_types.labels.allow_markup'),
45
- :allow_markup,
46
- @custom_field_type.allow_markup,
47
- :values => @boolean_hash.invert
48
- )
46
+ f.input_radio(
47
+ lang('custom_field_types.labels.allow_markup'),
48
+ :allow_markup,
49
+ @custom_field_type.allow_markup,
50
+ :values => @boolean_hash.invert
51
+ )
49
52
 
50
- f.select(
51
- lang('custom_field_types.labels.custom_field_method_id'),
52
- :custom_field_method_id,
53
- :values => @custom_field_methods,
54
- :size => 1,
55
- :selected => @custom_field_type.custom_field_method_id,
56
- :required => :required
57
- )
53
+ f.select(
54
+ lang('custom_field_types.labels.custom_field_method_id'),
55
+ :custom_field_method_id,
56
+ :values => @custom_field_methods,
57
+ :size => 1,
58
+ :selected => @custom_field_type.custom_field_method_id,
59
+ :required => :required
60
+ )
58
61
 
59
- f.g.div(:class => 'button') do
60
- f.g.input(
61
- :type => :submit,
62
- :value => lang('custom_field_types.buttons.save')
63
- )
64
- end
65
- end}
62
+ f.g.input(
63
+ :type => :submit,
64
+ :value => lang('custom_field_types.buttons.save'),
65
+ :class => 'button'
66
+ )
67
+ end}
68
+ </div>
66
69
  </section>