zen 0.3 → 0.4
Sign up to get free protection for your applications and to get access to all the features.
- data/.gems +3 -2
- data/.rvmrc +1 -1
- data/.travis.yml +5 -0
- data/.yardopts +2 -1
- data/LICENSE +1 -1
- data/README.md +28 -24
- data/Rakefile +5 -2
- data/guide/asset_management.md +6 -6
- data/guide/autosaving_forms.md +42 -0
- data/guide/changelog.md +41 -0
- data/guide/faq.md +49 -0
- data/guide/getting_started.md +24 -13
- data/guide/hacking.md +40 -9
- data/guide/images/categories/categories.png +0 -0
- data/guide/images/categories/category_groups.png +0 -0
- data/guide/images/categories/new_category.png +0 -0
- data/guide/images/categories/new_category_group.png +0 -0
- data/guide/images/comments/comments.png +0 -0
- data/guide/images/comments/edit_comment.png +0 -0
- data/guide/images/custom_fields/custom_field_groups.png +0 -0
- data/guide/images/custom_fields/custom_field_types.png +0 -0
- data/guide/images/custom_fields/custom_fields.png +0 -0
- data/guide/images/custom_fields/edit_custom_field_general.png +0 -0
- data/guide/images/custom_fields/edit_custom_field_group.png +0 -0
- data/guide/images/custom_fields/edit_custom_field_settings.png +0 -0
- data/guide/images/custom_fields/edit_custom_field_type.png +0 -0
- data/guide/images/dashboard/added.png +0 -0
- data/guide/images/dashboard/columns.png +0 -0
- data/guide/images/dashboard/dashboard.png +0 -0
- data/guide/images/dashboard/options.png +0 -0
- data/guide/images/menus/edit_menu.png +0 -0
- data/guide/images/menus/edit_menu_item.png +0 -0
- data/guide/images/menus/menu_item_hierarchy.png +0 -0
- data/guide/images/menus/menu_items.png +0 -0
- data/guide/images/menus/menus.png +0 -0
- data/guide/images/sections/edit_entry.png +0 -0
- data/guide/images/sections/edit_entry_categories.png +0 -0
- data/guide/images/sections/edit_entry_general.png +0 -0
- data/guide/images/sections/edit_entry_meta.png +0 -0
- data/guide/images/sections/edit_section_comments.png +0 -0
- data/guide/images/sections/edit_section_general.png +0 -0
- data/guide/images/sections/edit_section_groups.png +0 -0
- data/guide/images/sections/entries.png +0 -0
- data/guide/images/sections/sections.png +0 -0
- data/guide/images/settings/overview_general.png +0 -0
- data/guide/images/settings/overview_security.png +0 -0
- data/guide/images/settings/overview_user.png +0 -0
- data/guide/images/users/edit_user.png +0 -0
- data/guide/images/users/edit_user_group.png +0 -0
- data/guide/images/users/edit_user_group_permissions.png +0 -0
- data/guide/images/users/edit_user_permissions.png +0 -0
- data/guide/images/users/overview.png +0 -0
- data/guide/images/users/user_groups_overview.png +0 -0
- data/guide/installation.md +7 -1
- data/guide/javascript.md +36 -273
- data/guide/javascript/zen_autosave.md +26 -0
- data/guide/javascript/zen_editor.md +83 -0
- data/guide/javascript/zen_hash.md +34 -0
- data/guide/javascript/zen_htmltable.md +78 -0
- data/guide/javascript/zen_tabs.md +44 -0
- data/guide/javascript/zen_window.md +49 -0
- data/guide/zen_compared.md +201 -0
- data/lib/vendor/sequel_sluggable.rb +1 -1
- data/lib/zen.rb +64 -44
- data/lib/zen/asset_groups.rb +10 -10
- data/lib/zen/bin/create.rb +8 -1
- data/lib/zen/helper/breadcrumb.rb +4 -12
- data/lib/zen/helper/controller.rb +209 -6
- data/lib/zen/helper/locale.rb +19 -0
- data/lib/zen/helper/search.rb +1 -1
- data/lib/zen/helper/stacked_aspect.rb +7 -43
- data/lib/zen/helper/theme.rb +3 -3
- data/lib/zen/language.rb +5 -10
- data/lib/zen/language/translation.rb +1 -1
- data/lib/zen/layout/admin.xhtml +41 -25
- data/lib/zen/layout/login.xhtml +8 -3
- data/lib/zen/migrator.rb +54 -0
- data/lib/zen/model/helper.rb +20 -1
- data/lib/zen/model/init.rb +2 -0
- data/lib/zen/model/plugin/events.rb +158 -0
- data/lib/zen/package.rb +32 -6
- data/lib/zen/package/all.rb +1 -0
- data/lib/zen/package/categories/lib/categories.rb +6 -6
- data/lib/zen/package/categories/lib/categories/controller/categories.rb +20 -83
- data/lib/zen/package/categories/lib/categories/controller/category_groups.rb +23 -74
- data/lib/zen/package/categories/lib/categories/model/category.rb +58 -1
- data/lib/zen/package/categories/lib/categories/model/category_group.rb +62 -2
- data/lib/zen/package/categories/lib/categories/view/admin/categories/form.xhtml +46 -40
- data/lib/zen/package/categories/lib/categories/view/admin/categories/index.xhtml +74 -75
- data/lib/zen/package/categories/lib/categories/view/admin/category-groups/form.xhtml +27 -24
- data/lib/zen/package/categories/lib/categories/view/admin/category-groups/index.xhtml +83 -86
- data/lib/zen/package/comments/lib/comments.rb +5 -5
- data/lib/zen/package/comments/lib/comments/controller/comments.rb +12 -64
- data/lib/zen/package/comments/lib/comments/controller/comments_form.rb +4 -22
- data/lib/zen/package/comments/lib/comments/model/comment.rb +65 -16
- data/lib/zen/package/comments/lib/comments/view/admin/comments/form.xhtml +52 -49
- data/lib/zen/package/comments/lib/comments/view/admin/comments/index.xhtml +52 -60
- data/lib/zen/package/comments/migrations/1308774099_comment_status.rb +1 -1
- data/lib/zen/package/custom_fields/lib/custom_fields.rb +11 -13
- data/lib/zen/package/custom_fields/lib/custom_fields/blue_form_parameters.rb +29 -13
- data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_field_groups.rb +21 -50
- data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_field_types.rb +27 -71
- data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_fields.rb +25 -78
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field.rb +48 -1
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_group.rb +35 -1
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_method.rb +3 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_type.rb +40 -1
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_value.rb +1 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-groups/form.xhtml +29 -26
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-groups/index.xhtml +96 -100
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-types/form.xhtml +56 -53
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-types/index.xhtml +82 -82
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-fields/form.xhtml +88 -85
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-fields/index.xhtml +83 -80
- data/lib/zen/package/dashboard/lib/dashboard.rb +28 -0
- data/lib/zen/package/dashboard/lib/dashboard/controller/dashboard.rb +154 -0
- data/lib/zen/package/dashboard/lib/dashboard/language/en/dashboard.rb +35 -0
- data/lib/zen/package/dashboard/lib/dashboard/language/nl/dashboard.rb +36 -0
- data/lib/zen/package/dashboard/lib/dashboard/model/widget.rb +45 -0
- data/lib/zen/package/dashboard/lib/dashboard/public/admin/dashboard/css/dashboard.css +74 -0
- data/lib/zen/package/dashboard/lib/dashboard/public/admin/dashboard/js/dashboard.js +102 -0
- data/lib/zen/package/dashboard/lib/dashboard/view/admin/index.xhtml +29 -0
- data/lib/zen/package/dashboard/lib/dashboard/view/admin/widget/welcome.xhtml +28 -0
- data/lib/zen/package/dashboard/lib/dashboard/widget.rb +292 -0
- data/lib/zen/package/dashboard/lib/dashboard/widget/welcome.rb +9 -0
- data/lib/zen/package/dashboard/migrations/1326411254_create_schema.rb +28 -0
- data/lib/zen/package/extensions/lib/extensions.rb +5 -5
- data/lib/zen/package/extensions/lib/extensions/view/admin/extensions/index.xhtml +72 -67
- data/lib/zen/package/menu.rb +6 -1
- data/lib/zen/package/menus/lib/menus.rb +6 -4
- data/lib/zen/package/menus/lib/menus/controller/menu_items.rb +69 -104
- data/lib/zen/package/menus/lib/menus/controller/menus.rb +19 -76
- data/lib/zen/package/menus/lib/menus/helper/menu.rb +54 -38
- data/lib/zen/package/menus/lib/menus/helper/menu_frontend.rb +7 -13
- data/lib/zen/package/menus/lib/menus/model/menu.rb +158 -2
- data/lib/zen/package/menus/lib/menus/model/menu_item.rb +73 -10
- data/lib/zen/package/menus/lib/menus/public/admin/menus/css/menus.css +47 -0
- data/lib/zen/package/menus/lib/menus/public/admin/menus/js/lib/nested_sortables.js +549 -0
- data/lib/zen/package/menus/lib/menus/public/admin/menus/js/menu_items.js +38 -0
- data/lib/zen/package/menus/lib/menus/view/admin/menu-items/form.xhtml +51 -61
- data/lib/zen/package/menus/lib/menus/view/admin/menu-items/index.xhtml +18 -81
- data/lib/zen/package/menus/lib/menus/view/admin/menus/form.xhtml +49 -44
- data/lib/zen/package/menus/lib/menus/view/admin/menus/index.xhtml +81 -83
- data/lib/zen/package/sections/lib/sections.rb +9 -4
- data/lib/zen/package/sections/lib/sections/controller/section_entries.rb +80 -132
- data/lib/zen/package/sections/lib/sections/controller/sections.rb +27 -73
- data/lib/zen/package/sections/lib/sections/helper/section.rb +44 -1
- data/lib/zen/package/sections/lib/sections/language/en/section_entries.rb +2 -0
- data/lib/zen/package/sections/lib/sections/language/nl/section_entries.rb +2 -0
- data/lib/zen/package/sections/lib/sections/model/section.rb +48 -1
- data/lib/zen/package/sections/lib/sections/model/section_entry.rb +55 -5
- data/lib/zen/package/sections/lib/sections/model/section_entry_status.rb +2 -0
- data/lib/zen/package/sections/lib/sections/view/admin/section-entries/form.xhtml +76 -67
- data/lib/zen/package/sections/lib/sections/view/admin/section-entries/index.xhtml +74 -79
- data/lib/zen/package/sections/lib/sections/view/admin/section-entries/recent_entries.xhtml +45 -0
- data/lib/zen/package/sections/lib/sections/view/admin/sections/form.xhtml +119 -0
- data/lib/zen/package/sections/lib/sections/view/admin/sections/index.xhtml +96 -0
- data/lib/zen/package/sections/lib/sections/widget/recent_entries.rb +14 -0
- data/lib/zen/package/sections/migrations/1308813320_section_entry_statuses.rb +1 -1
- data/lib/zen/package/settings/lib/settings.rb +14 -5
- data/lib/zen/package/settings/lib/settings/controller/settings.rb +4 -4
- data/lib/zen/package/settings/lib/settings/language/nl/settings.rb +1 -1
- data/lib/zen/package/settings/lib/settings/setting.rb +1 -1
- data/lib/zen/package/settings/lib/settings/view/admin/settings/index.xhtml +21 -17
- data/lib/zen/package/users/lib/users.rb +18 -19
- data/lib/zen/package/users/lib/users/controller/user_groups.rb +23 -50
- data/lib/zen/package/users/lib/users/controller/users.rb +57 -89
- data/lib/zen/package/users/lib/users/helper/acl.rb +1 -0
- data/lib/zen/package/users/lib/users/language/en/user_groups.rb +1 -0
- data/lib/zen/package/users/lib/users/language/en/users.rb +2 -1
- data/lib/zen/package/users/lib/users/language/nl/user_groups.rb +1 -0
- data/lib/zen/package/users/lib/users/language/nl/users.rb +2 -1
- data/lib/zen/package/users/lib/users/model/permission.rb +13 -0
- data/lib/zen/package/users/lib/users/model/user.rb +57 -4
- data/lib/zen/package/users/lib/users/model/user_group.rb +37 -3
- data/lib/zen/package/users/lib/users/model/user_status.rb +4 -0
- data/lib/zen/package/users/lib/users/public/admin/{css/users/permissions.css → users/css/users.css} +0 -0
- data/lib/zen/package/users/lib/users/public/admin/{js/users/permissions.js → users/js/users.js} +4 -2
- data/lib/zen/package/users/lib/users/view/admin/user-groups/form.xhtml +51 -47
- data/lib/zen/package/users/lib/users/view/admin/user-groups/index.xhtml +62 -69
- data/lib/zen/package/users/lib/users/view/admin/users/form.xhtml +92 -82
- data/lib/zen/package/users/lib/users/view/admin/users/index.xhtml +68 -66
- data/lib/zen/package/users/lib/users/view/admin/users/login.xhtml +36 -28
- data/lib/zen/package/users/lib/users/view/admin/users/permissions.xhtml +5 -7
- data/lib/zen/package/users/lib/users/view/admin/users/register.xhtml +47 -41
- data/lib/zen/package/users/migrations/1320272365_status_ids.rb +1 -1
- data/lib/zen/public/admin/{js/vendor/mootools → mootools/js}/core.js +113 -108
- data/lib/zen/public/admin/{js/vendor/mootools → mootools/js}/more.js +99 -6
- data/lib/zen/public/admin/zen/css/buttons.css +106 -0
- data/lib/zen/public/admin/{css/zen → zen/css}/datepicker.css +45 -30
- data/lib/zen/public/admin/zen/css/editor.css +69 -0
- data/lib/zen/public/admin/{css/zen → zen/css}/forms.css +28 -30
- data/lib/zen/public/admin/zen/css/general.css +183 -0
- data/lib/zen/public/admin/zen/css/layout.css +224 -0
- data/lib/zen/public/admin/zen/css/messages.css +34 -0
- data/lib/zen/public/admin/{css/zen → zen/css}/reset.css +4 -9
- data/lib/zen/public/admin/zen/css/tables.css +57 -0
- data/lib/zen/public/admin/zen/css/tabs.css +84 -0
- data/lib/zen/public/admin/zen/css/window.css +74 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/asc.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/bold.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/box.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/categories.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/close.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/comment.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/desc.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/edit.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/error.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/external.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/globe.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/italic.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/link.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/lock.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/ol.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/pages.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/preview.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/relation.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/settings.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/template.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/ul.png +0 -0
- data/lib/zen/public/admin/{images/zen → zen/images}/icons/user.png +0 -0
- data/lib/zen/public/admin/zen/images/icons/user_group.png +0 -0
- data/lib/zen/public/admin/{js/zen → zen/js}/index.js +21 -9
- data/lib/zen/public/admin/zen/js/lib/autosave.js +185 -0
- data/lib/zen/public/admin/zen/js/lib/base.js +60 -0
- data/lib/zen/public/admin/{js/vendor → zen/js/lib}/datepicker.js +52 -28
- data/lib/zen/public/admin/{js/zen → zen/js}/lib/editor.js +23 -34
- data/lib/zen/public/admin/{js/zen → zen/js}/lib/editor/markdown.js +5 -1
- data/lib/zen/public/admin/{js/zen → zen/js}/lib/editor/textile.js +4 -0
- data/lib/zen/public/admin/zen/js/lib/hash.js +218 -0
- data/lib/zen/public/admin/{js/zen → zen/js}/lib/html_table.js +5 -0
- data/lib/zen/public/admin/zen/js/lib/tabs.js +194 -0
- data/lib/zen/public/admin/{js/zen → zen/js}/lib/window.js +54 -29
- data/lib/zen/security.rb +50 -0
- data/lib/zen/spec/helper.rb +5 -120
- data/lib/zen/spec/helper/capybara.rb +75 -0
- data/lib/zen/spec/helper/general.rb +75 -0
- data/lib/zen/spec/simplecov.rb +1 -0
- data/lib/zen/task/build.rake +2 -21
- data/lib/zen/task/clean.rake +1 -10
- data/lib/zen/task/db.rake +4 -10
- data/lib/zen/task/package.rake +2 -5
- data/lib/zen/task/setup.rake +1 -1
- data/lib/zen/task/test.rake +6 -6
- data/lib/zen/task/theme.rake +2 -5
- data/lib/zen/theme.rb +26 -22
- data/lib/zen/version.rb +1 -1
- data/lib/zen/view/bottom.xhtml +2 -3
- data/lib/zen/view/search.xhtml +3 -5
- data/proto/app/config/config.rb.erb +1 -1
- data/proto/app/theme/default/index.xhtml +116 -20
- data/proto/app/theme/partials/head.xhtml +9 -0
- data/proto/app/theme/partials/sidebar.xhtml +40 -0
- data/proto/app/theme/theme.rb +3 -0
- data/spec/Rakefile +1 -2
- data/spec/fixtures/zen/helper/stacked_aspect.rb +54 -0
- data/spec/fixtures/zen/package/dashboard/controller/widget.rb +15 -0
- data/spec/fixtures/zen/package/dashboard/widget.rb +5 -0
- data/spec/fixtures/zen/theme/theme.rb +2 -2
- data/spec/helper.rb +19 -10
- data/spec/zen/controller/admin_controller.rb +3 -3
- data/spec/zen/controller/main_controller.rb +7 -7
- data/spec/zen/controller/preview.rb +3 -3
- data/spec/zen/event.rb +4 -4
- data/spec/zen/helper/breadcrumb.rb +4 -8
- data/spec/zen/helper/controller.rb +47 -4
- data/spec/zen/helper/locale.rb +3 -3
- data/spec/zen/helper/message.rb +4 -4
- data/spec/zen/helper/stacked_aspect.rb +40 -0
- data/spec/zen/helper/theme.rb +9 -9
- data/spec/zen/language.rb +8 -8
- data/spec/zen/markup.rb +6 -6
- data/spec/zen/package.rb +11 -9
- data/spec/zen/package/categories/controller/categories.rb +56 -24
- data/spec/zen/package/categories/controller/category_groups.rb +55 -23
- data/spec/zen/package/categories/helper/category.rb +5 -5
- data/spec/zen/package/categories/helper/category_frontend.rb +5 -5
- data/spec/zen/package/comments/anti_spam.rb +4 -4
- data/spec/zen/package/comments/controller/comments.rb +95 -24
- data/spec/zen/package/comments/controller/comments_form.rb +31 -26
- data/spec/zen/package/comments/helper/comment.rb +3 -3
- data/spec/zen/package/comments/helper/comment_frontend.rb +6 -6
- data/spec/zen/package/custom_fields/blue_form_parameters.rb +8 -8
- data/spec/zen/package/custom_fields/controller/custom_field_groups.rb +58 -27
- data/spec/zen/package/custom_fields/controller/custom_field_types.rb +57 -27
- data/spec/zen/package/custom_fields/controller/custom_fields.rb +58 -27
- data/spec/zen/package/custom_fields/helper/custom_field.rb +7 -7
- data/spec/zen/package/dashboard/controller/dashboard.rb +147 -0
- data/spec/zen/package/dashboard/widget.rb +56 -0
- data/spec/zen/package/extensions/controller/extensions.rb +4 -4
- data/spec/zen/package/menus/controller/menu_items.rb +48 -39
- data/spec/zen/package/menus/controller/menus.rb +55 -24
- data/spec/zen/package/menus/helper/menu.rb +6 -14
- data/spec/zen/package/menus/helper/menu_frontend.rb +7 -7
- data/spec/zen/package/menus/model/menu.rb +121 -0
- data/spec/zen/package/menus/model/menu_item.rb +34 -0
- data/spec/zen/package/sections/controller/section_entries.rb +104 -39
- data/spec/zen/package/sections/controller/sections.rb +60 -27
- data/spec/zen/package/sections/helper/section.rb +5 -5
- data/spec/zen/package/sections/helper/section_frontend.rb +9 -9
- data/spec/zen/package/sections/widget.rb +44 -0
- data/spec/zen/package/settings/controller/settings.rb +18 -16
- data/spec/zen/package/settings/settings.rb +12 -12
- data/spec/zen/package/users/controller/user_groups.rb +61 -29
- data/spec/zen/package/users/controller/users.rb +118 -39
- data/spec/zen/package/users/helper/access.rb +3 -3
- data/spec/zen/package/users/helper/acl.rb +4 -4
- data/spec/zen/package/users/helper/users.rb +5 -5
- data/spec/zen/security.rb +25 -0
- data/spec/zen/theme.rb +20 -18
- data/spec/zen/validation.rb +5 -5
- data/spec/zen/vendor/sequel_sluggable.rb +12 -0
- data/zen.gemspec +27 -4
- metadata +182 -124
- data/AUTHORS +0 -4
- data/guide/_static/categories/categories.png +0 -0
- data/guide/_static/categories/category_groups.png +0 -0
- data/guide/_static/categories/new_category.png +0 -0
- data/guide/_static/categories/new_category_group.png +0 -0
- data/guide/_static/comments/comments.png +0 -0
- data/guide/_static/comments/edit_comment.png +0 -0
- data/guide/_static/custom_fields/custom_field_groups.png +0 -0
- data/guide/_static/custom_fields/custom_field_types.png +0 -0
- data/guide/_static/custom_fields/custom_fields.png +0 -0
- data/guide/_static/custom_fields/edit_custom_field_general.png +0 -0
- data/guide/_static/custom_fields/edit_custom_field_group.png +0 -0
- data/guide/_static/custom_fields/edit_custom_field_settings.png +0 -0
- data/guide/_static/custom_fields/edit_custom_field_type.png +0 -0
- data/guide/_static/menus/edit_menu.png +0 -0
- data/guide/_static/menus/edit_menu_item.png +0 -0
- data/guide/_static/menus/menu_items.png +0 -0
- data/guide/_static/menus/menus.png +0 -0
- data/guide/_static/sections/edit_entry.png +0 -0
- data/guide/_static/sections/edit_entry_categories.png +0 -0
- data/guide/_static/sections/edit_entry_general.png +0 -0
- data/guide/_static/sections/edit_entry_meta.png +0 -0
- data/guide/_static/sections/edit_section_comments.png +0 -0
- data/guide/_static/sections/edit_section_general.png +0 -0
- data/guide/_static/sections/edit_section_groups.png +0 -0
- data/guide/_static/sections/entries.png +0 -0
- data/guide/_static/sections/sections.png +0 -0
- data/guide/_static/settings/overview_general.png +0 -0
- data/guide/_static/settings/overview_security.png +0 -0
- data/guide/_static/settings/overview_user.png +0 -0
- data/guide/_static/users/edit_user.png +0 -0
- data/guide/_static/users/edit_user_group.png +0 -0
- data/guide/_static/users/edit_user_group_permissions.png +0 -0
- data/guide/_static/users/edit_user_permissions.png +0 -0
- data/guide/_static/users/overview.png +0 -0
- data/guide/_static/users/user_groups_overview.png +0 -0
- data/lib/zen/controller/translations.rb +0 -49
- data/lib/zen/package/sections/lib/sections/view/admin/form.xhtml +0 -113
- data/lib/zen/package/sections/lib/sections/view/admin/index.xhtml +0 -97
- data/lib/zen/public/admin/css/zen/buttons.css +0 -46
- data/lib/zen/public/admin/css/zen/editor.css +0 -88
- data/lib/zen/public/admin/css/zen/general.css +0 -109
- data/lib/zen/public/admin/css/zen/grid.css +0 -100
- data/lib/zen/public/admin/css/zen/layout.css +0 -184
- data/lib/zen/public/admin/css/zen/messages.css +0 -54
- data/lib/zen/public/admin/css/zen/tables.css +0 -97
- data/lib/zen/public/admin/css/zen/tabs.css +0 -47
- data/lib/zen/public/admin/css/zen/window.css +0 -73
- data/lib/zen/public/admin/images/zen/icons/accept.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/add.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/back.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/delete.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/help.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/info.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/logout.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/pdf.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/view.png +0 -0
- data/lib/zen/public/admin/js/zen/lib/tabs.js +0 -207
- data/lib/zen/view/main.xhtml +0 -19
@@ -59,7 +59,7 @@ Zen::Language::Translation.add do |trans|
|
|
59
59
|
t['buttons.new'] = 'Add user'
|
60
60
|
t['buttons.delete'] = 'Delete selected users'
|
61
61
|
t['buttons.save'] = 'Save user'
|
62
|
-
t['buttons.register'] = '
|
62
|
+
t['buttons.register'] = 'Confirm registration'
|
63
63
|
|
64
64
|
t['description'] = 'Manage users, user groups and permissions.'
|
65
65
|
|
@@ -67,6 +67,7 @@ Zen::Language::Translation.add do |trans|
|
|
67
67
|
t['permissions.edit'] = 'Edit user'
|
68
68
|
t['permissions.new'] = 'Add user'
|
69
69
|
t['permissions.delete'] = 'Delete user'
|
70
|
+
t['permissions.status'] = 'Change user status'
|
70
71
|
|
71
72
|
t['tabs.settings'] = 'User Settings'
|
72
73
|
end
|
@@ -60,7 +60,7 @@ Zen::Language::Translation.add do |trans|
|
|
60
60
|
t['buttons.new'] = 'Gebruiker toevoegen'
|
61
61
|
t['buttons.save'] = 'Gebruiker opslaan'
|
62
62
|
t['buttons.delete'] = 'Geselecteerde gebruikers verwijderen'
|
63
|
-
t['buttons.register'] = '
|
63
|
+
t['buttons.register'] = 'Bevestig registratie'
|
64
64
|
|
65
65
|
t['description'] = 'Beheer gebruikers, gebruikers groepen en rechten.'
|
66
66
|
|
@@ -68,6 +68,7 @@ Zen::Language::Translation.add do |trans|
|
|
68
68
|
t['permissions.edit'] = 'Rechten aanpassen'
|
69
69
|
t['permissions.new'] = 'Rechten aanmaken'
|
70
70
|
t['permissions.delete'] = 'Rechten verwijderen'
|
71
|
+
t['permissions.status'] = 'Gebruikers status aanpassen'
|
71
72
|
|
72
73
|
t['tabs.settings'] = 'Gebruikers instellingen'
|
73
74
|
end
|
@@ -6,6 +6,8 @@ module Users
|
|
6
6
|
# @since 0.3
|
7
7
|
#
|
8
8
|
class Permission < Sequel::Model
|
9
|
+
include Zen::Model::Helper
|
10
|
+
|
9
11
|
many_to_one :user , :class => 'Users::Model::User'
|
10
12
|
many_to_one :user_group, :class => 'Users::Model::UserGroup'
|
11
13
|
|
@@ -23,6 +25,17 @@ module Users
|
|
23
25
|
validates_presence(:user_id)
|
24
26
|
end
|
25
27
|
end
|
28
|
+
|
29
|
+
##
|
30
|
+
# Hook that is executed before creating or saving an object.
|
31
|
+
#
|
32
|
+
# @since 03-01-2012
|
33
|
+
#
|
34
|
+
def before_save
|
35
|
+
sanitize_fields([:permission])
|
36
|
+
|
37
|
+
super
|
38
|
+
end
|
26
39
|
end # Permission
|
27
40
|
end # Model
|
28
41
|
end # Users
|
@@ -1,16 +1,52 @@
|
|
1
1
|
module Users
|
2
|
-
#:nodoc:
|
3
2
|
module Model
|
4
3
|
##
|
5
4
|
# Model that represents a single user.
|
6
5
|
#
|
7
|
-
# @
|
6
|
+
# @example Sending an Email for a new user
|
7
|
+
# Zen::Event.listen(:after_new_user) do |user|
|
8
|
+
# Mail.deliver do
|
9
|
+
# from 'user@domain.tld'
|
10
|
+
# to user.email
|
11
|
+
# subject 'Your new account'
|
12
|
+
# body "Dear #{user.name}, your account has been created."
|
13
|
+
# end
|
14
|
+
# end
|
15
|
+
#
|
16
|
+
# @since 0.1
|
17
|
+
# @event before_new_user
|
18
|
+
# @event after_new_user
|
19
|
+
# @event before_edit_user
|
20
|
+
# @event after_edit_user
|
21
|
+
# @event before_delete_user
|
22
|
+
# @event after_delete_user
|
8
23
|
#
|
9
24
|
class User < Sequel::Model
|
25
|
+
##
|
10
26
|
# Regex to do some basic Email validation. Emails such as foo@bar,
|
11
|
-
# foo@bar.com and foo@bar.a.b are all valid but foo bar@bar.com
|
27
|
+
# "foo@bar.com" and "foo@bar.a.b" are all valid but "foo bar@bar.com"
|
28
|
+
# isn't.
|
29
|
+
#
|
12
30
|
EMAIL_REGEX = '^[^@]\S+@\S+(\.[a-z]+)*[^.]$'
|
13
31
|
|
32
|
+
##
|
33
|
+
# Array containing the columns that can be set by the user.
|
34
|
+
#
|
35
|
+
# @since 17-02-2012
|
36
|
+
#
|
37
|
+
COLUMNS = [
|
38
|
+
:email,
|
39
|
+
:name,
|
40
|
+
:website,
|
41
|
+
:password,
|
42
|
+
:confirm_password,
|
43
|
+
:user_status_id,
|
44
|
+
:language,
|
45
|
+
:frontend_language,
|
46
|
+
:date_format,
|
47
|
+
:user_group_pks
|
48
|
+
]
|
49
|
+
|
14
50
|
include Zen::Model::Helper
|
15
51
|
|
16
52
|
many_to_many :user_groups, :class => 'Users::Model::UserGroup',
|
@@ -18,10 +54,19 @@ module Users
|
|
18
54
|
|
19
55
|
many_to_one :user_status, :class => 'Users::Model::UserStatus'
|
20
56
|
one_to_many :permissions, :class => 'Users::Model::Permission'
|
57
|
+
one_to_many :widgets, :class => 'Dashboard::Model::Widget'
|
21
58
|
|
22
59
|
plugin :timestamps, :create => :created_at, :update => :updated_at
|
23
60
|
plugin :association_dependencies, :permissions => :delete
|
24
61
|
|
62
|
+
plugin :events,
|
63
|
+
:before_create => :before_new_user,
|
64
|
+
:after_create => :after_new_user,
|
65
|
+
:before_update => :before_edit_user,
|
66
|
+
:after_update => :after_edit_user,
|
67
|
+
:before_destroy => :before_delete_user,
|
68
|
+
:after_destroy => :after_delete_user
|
69
|
+
|
25
70
|
##
|
26
71
|
# Searches for a set of users that match the given query.
|
27
72
|
#
|
@@ -83,7 +128,10 @@ module Users
|
|
83
128
|
def password=(password)
|
84
129
|
return if password.nil? or password.empty?
|
85
130
|
|
86
|
-
password = BCrypt::Password.create(
|
131
|
+
password = BCrypt::Password.create(
|
132
|
+
Zen::Security.sanitize(password),
|
133
|
+
:cost => 10
|
134
|
+
)
|
87
135
|
|
88
136
|
super(password)
|
89
137
|
end
|
@@ -106,6 +154,11 @@ module Users
|
|
106
154
|
# @since 0.3
|
107
155
|
#
|
108
156
|
def before_save
|
157
|
+
# Password is sanitized in password=.
|
158
|
+
sanitize_fields([
|
159
|
+
:email, :name, :website, :language, :frontend_language, :date_format
|
160
|
+
])
|
161
|
+
|
109
162
|
if self.user_status_id.nil?
|
110
163
|
self.user_status_id = Users::Model::UserStatus[:name => 'closed'].id
|
111
164
|
end
|
@@ -4,17 +4,40 @@ module Users
|
|
4
4
|
##
|
5
5
|
# Model that represents a single user group.
|
6
6
|
#
|
7
|
-
# @since
|
7
|
+
# @since 0.1
|
8
|
+
# @event before_new_user_group
|
9
|
+
# @event after_new_user_user
|
10
|
+
# @event before_edit_user_group
|
11
|
+
# @event after_edit_user_group
|
12
|
+
# @event before_delete_user_group
|
13
|
+
# @event after_delete_user_group
|
8
14
|
#
|
9
15
|
class UserGroup < 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, :slug, :description, :super_group]
|
24
|
+
|
12
25
|
many_to_many :users , :class => 'Users::Model::User'
|
13
26
|
one_to_many :permissions, :class => 'Users::Model::Permission'
|
14
27
|
|
15
28
|
plugin :sluggable, :source => :name, :freeze => false
|
16
|
-
|
17
|
-
|
29
|
+
|
30
|
+
plugin :association_dependencies,
|
31
|
+
:permissions => :delete,
|
32
|
+
:users => :nullify
|
33
|
+
|
34
|
+
plugin :events,
|
35
|
+
:before_create => :before_new_user_group,
|
36
|
+
:after_create => :after_new_user_group,
|
37
|
+
:before_update => :before_edit_user_group,
|
38
|
+
:after_update => :after_edit_user_group,
|
39
|
+
:before_destroy => :before_delete_user_group,
|
40
|
+
:after_destroy => :after_delete_user_group
|
18
41
|
|
19
42
|
##
|
20
43
|
# Searches for a set of users that match the given query.
|
@@ -40,6 +63,17 @@ module Users
|
|
40
63
|
|
41
64
|
validates_type(TrueClass, :super_group)
|
42
65
|
end
|
66
|
+
|
67
|
+
##
|
68
|
+
# Hook that is executed before creating or saving an object.
|
69
|
+
#
|
70
|
+
# @since 03-01-2012
|
71
|
+
#
|
72
|
+
def before_save
|
73
|
+
sanitize_fields([:name, :slug, :description])
|
74
|
+
|
75
|
+
super
|
76
|
+
end
|
43
77
|
end # UserGroup
|
44
78
|
end # Model
|
45
79
|
end # Users
|
@@ -6,6 +6,10 @@ module Users
|
|
6
6
|
# @since 03-11-2011
|
7
7
|
#
|
8
8
|
class UserStatus < Sequel::Model
|
9
|
+
one_to_many :users, :class => 'Users::Model::User'
|
10
|
+
|
11
|
+
plugin :association_dependencies, :users => :delete
|
12
|
+
|
9
13
|
##
|
10
14
|
# Returns a hash where the keys are the IDs of the various statuses and
|
11
15
|
# the values the translations.
|
data/lib/zen/package/users/lib/users/public/admin/{css/users/permissions.css → users/css/users.css}
RENAMED
File without changes
|
data/lib/zen/package/users/lib/users/public/admin/{js/users/permissions.js → users/js/users.js}
RENAMED
@@ -1,3 +1,5 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
1
3
|
/**
|
2
4
|
* Javascript file loaded by the Users package. The code in this file is used to
|
3
5
|
* make it easier for users to check all the checkboxes for a package when
|
@@ -8,7 +10,7 @@
|
|
8
10
|
window.addEvent('domready', function()
|
9
11
|
{
|
10
12
|
// Button that can be used to allow all the permissions for a package.
|
11
|
-
$$('.package .button.allow
|
13
|
+
$$('.package .button.allow').addEvent('click', function()
|
12
14
|
{
|
13
15
|
var checkboxes = this.getParent('.package')
|
14
16
|
.getChildren('.permissions input[type="checkbox"]');
|
@@ -20,7 +22,7 @@ window.addEvent('domready', function()
|
|
20
22
|
});
|
21
23
|
|
22
24
|
// Button that can be used to deny all the permissions for a package.
|
23
|
-
$$('.package .button.deny
|
25
|
+
$$('.package .button.deny').addEvent('click', function()
|
24
26
|
{
|
25
27
|
var checkboxes = this.getParent('.package')
|
26
28
|
.getChildren('.permissions input[type="checkbox"]');
|
@@ -3,10 +3,11 @@
|
|
3
3
|
<h1>#{get_breadcrumbs}</h1>
|
4
4
|
</header>
|
5
5
|
|
6
|
+
<?r if @user_group.exists? ?>
|
6
7
|
<div class="tabs">
|
7
8
|
<ul>
|
8
9
|
<li>
|
9
|
-
<a href="#user_group_tab"
|
10
|
+
<a href="#user_group_tab" class="icon user_group"
|
10
11
|
title="#{lang('user_groups.titles.edit')}">
|
11
12
|
#{lang('user_groups.titles.edit')}
|
12
13
|
</a>
|
@@ -14,7 +15,7 @@
|
|
14
15
|
|
15
16
|
<?r if user_authorized?(:show_permission) ?>
|
16
17
|
<li>
|
17
|
-
<a href="#permissions"
|
18
|
+
<a href="#permissions" class="icon lock"
|
18
19
|
title="#{lang('permissions.titles.index')}">
|
19
20
|
#{lang('permissions.titles.index')}
|
20
21
|
</a>
|
@@ -22,56 +23,59 @@
|
|
22
23
|
<?r end ?>
|
23
24
|
</ul>
|
24
25
|
</div>
|
26
|
+
<?r end ?>
|
25
27
|
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
28
|
+
<div class="body">
|
29
|
+
#{form_for(
|
30
|
+
@user_group,
|
31
|
+
:method => :post,
|
32
|
+
:action => Users::Controller::UserGroups.r(:save),
|
33
|
+
:id => :user_group_form,
|
34
|
+
:'data-autosave-url' => Users::Controller::UserGroups.r(:autosave)
|
35
|
+
) do |f|
|
36
|
+
f.input_hidden(:id, @user_group.id)
|
37
|
+
f.input_hidden(:csrf_token, get_csrf_token)
|
34
38
|
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
39
|
+
f.g.div(:id => 'user_group_tab') do
|
40
|
+
f.input_text(
|
41
|
+
lang('user_groups.labels.name'),
|
42
|
+
:name,
|
43
|
+
:required => :required,
|
44
|
+
:maxlength => 255
|
45
|
+
)
|
42
46
|
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
47
|
+
f.input_text(
|
48
|
+
lang('user_groups.labels.slug'),
|
49
|
+
:slug,
|
50
|
+
:maxlength => 255
|
51
|
+
)
|
48
52
|
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
53
|
+
f.input_radio(
|
54
|
+
lang('user_groups.labels.super_group'),
|
55
|
+
:super_group,
|
56
|
+
@user_group.super_group,
|
57
|
+
:values => @boolean_hash.invert,
|
58
|
+
:required => :required
|
59
|
+
)
|
56
60
|
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
61
|
+
f.textarea(
|
62
|
+
lang('user_groups.labels.description'),
|
63
|
+
:description,
|
64
|
+
:rows => 10
|
65
|
+
)
|
66
|
+
end
|
63
67
|
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
68
|
+
if user_authorized?(:show_permission) and @user_group.exists?
|
69
|
+
f.g.div(:id => 'permissions') do
|
70
|
+
render_file(__DIR__('../users/permissions.xhtml'))
|
71
|
+
end
|
72
|
+
end
|
69
73
|
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
74
|
+
f.g.input(
|
75
|
+
:type => 'submit',
|
76
|
+
:value => lang('user_groups.buttons.save'),
|
77
|
+
:class => 'button'
|
78
|
+
)
|
79
|
+
end}
|
80
|
+
</div>
|
77
81
|
</section>
|
@@ -1,85 +1,78 @@
|
|
1
1
|
<section>
|
2
|
-
|
3
|
-
|
4
|
-
<header>
|
2
|
+
<header class="with_search">
|
5
3
|
<h1>#{get_breadcrumbs}</h1>
|
4
|
+
|
5
|
+
#{render_search_form(Users::Controller::UserGroups.r(:index))}
|
6
6
|
</header>
|
7
7
|
|
8
|
-
<
|
9
|
-
<
|
8
|
+
<div class="body">
|
9
|
+
<form method="post" action="#{Users::Controller::UserGroups.r(:delete)}">
|
10
|
+
<input type="hidden" name="csrf_token" value="#{get_csrf_token}" />
|
10
11
|
|
11
|
-
|
12
|
+
<?r if !@user_groups.empty? ?>
|
12
13
|
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
14
|
+
<table>
|
15
|
+
<thead>
|
16
|
+
<tr>
|
17
|
+
<?r if user_authorized?(:delete_user_group) ?>
|
18
|
+
<th class="no_sort">
|
19
|
+
<input type="checkbox" />
|
20
|
+
</th>
|
21
|
+
<?r end ?>
|
21
22
|
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
23
|
+
<th>#{lang('user_groups.labels.id')}</th>
|
24
|
+
<th>#{lang('user_groups.labels.name')}</th>
|
25
|
+
<th>#{lang('user_groups.labels.slug')}</th>
|
26
|
+
<th>#{lang('user_groups.labels.super_group')}</th>
|
27
|
+
</tr>
|
28
|
+
</thead>
|
29
|
+
<tbody>
|
30
|
+
<?r @user_groups.each do |group| ?>
|
31
|
+
<tr>
|
32
|
+
<?r if user_authorized?(:delete_user_group) ?>
|
33
|
+
<td>
|
34
|
+
<input type="checkbox" name="user_group_ids[]"
|
35
|
+
value="#{group.id}" />
|
36
|
+
</td>
|
37
|
+
<?r end ?>
|
37
38
|
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
</
|
55
|
-
</table>
|
39
|
+
<td>#{group.id}</td>
|
40
|
+
<td>
|
41
|
+
#{if user_authorized?(:edit_user_group)
|
42
|
+
edit_link(
|
43
|
+
Users::Controller::UserGroups.r(:edit, group.id),
|
44
|
+
group.name
|
45
|
+
)
|
46
|
+
else
|
47
|
+
group.name
|
48
|
+
end}
|
49
|
+
</td>
|
50
|
+
<td>#{group.slug}</td>
|
51
|
+
<td>#{@boolean_hash[group.super_group]}</td>
|
52
|
+
</tr>
|
53
|
+
<?r end ?>
|
54
|
+
</tbody>
|
55
|
+
</table>
|
56
56
|
|
57
|
-
|
58
|
-
and @user_groups.page_count > 1
|
59
|
-
@user_groups.navigation
|
60
|
-
end}
|
57
|
+
#{render_pagination(@user_groups)}
|
61
58
|
|
62
|
-
|
59
|
+
<?r else ?>
|
63
60
|
|
64
|
-
|
61
|
+
<p>#{lang('user_groups.messages.no_groups')}</p>
|
65
62
|
|
66
|
-
|
63
|
+
<?r end ?>
|
67
64
|
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
lang('user_groups.buttons.new')
|
72
|
-
:new
|
65
|
+
<?r if user_authorized?(:new_user_group) ?>
|
66
|
+
#{new_button(
|
67
|
+
Users::Controller::UserGroups.r(:new),
|
68
|
+
lang('user_groups.buttons.new')
|
73
69
|
)}
|
74
|
-
|
75
|
-
<?r end ?>
|
70
|
+
<?r end ?>
|
76
71
|
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
<?r end ?>
|
84
|
-
</form>
|
72
|
+
<?r if user_authorized?(:delete_user_group) \
|
73
|
+
and !@user_groups.empty? ?>
|
74
|
+
#{delete_button(lang('user_groups.buttons.delete'))}
|
75
|
+
<?r end ?>
|
76
|
+
</form>
|
77
|
+
</div>
|
85
78
|
</section>
|