zen 0.2.7 → 0.2.8
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +15 -0
- data/.mailmap +2 -0
- data/.rvmrc +2 -0
- data/.travis.yml +8 -3
- data/AUTHORS +1 -2
- data/CHANGELOG.md +48 -17
- data/README.md +44 -39
- data/Rakefile +4 -0
- data/bin/zen +5 -30
- data/lib/zen.rb +13 -19
- data/lib/zen/asset.rb +99 -64
- data/lib/zen/bin/create.rb +94 -0
- data/lib/zen/bin/runner.rb +118 -0
- data/lib/zen/controller/admin_controller.rb +52 -36
- data/lib/zen/controller/base_controller.rb +5 -5
- data/lib/zen/controller/frontend_controller.rb +7 -7
- data/lib/zen/controller/main_controller.rb +12 -10
- data/lib/zen/controller/preview.rb +15 -11
- data/lib/zen/helper/acl.rb +73 -53
- data/lib/zen/helper/blue_form_vendor.rb +689 -0
- data/lib/zen/helper/breadcrumb.rb +23 -19
- data/lib/zen/helper/message.rb +3 -3
- data/lib/zen/helper/theme.rb +18 -13
- data/lib/zen/language.rb +62 -58
- data/lib/zen/language/en/zen_general.yml +2 -4
- data/lib/zen/language/nl/zen_general.yml +2 -4
- data/lib/zen/layout/admin.xhtml +3 -12
- data/lib/zen/layout/login.xhtml +1 -6
- data/lib/zen/model/methods.rb +6 -6
- data/lib/zen/model/settings.rb +5 -4
- data/lib/zen/package.rb +47 -38
- data/lib/zen/package/all.rb +3 -5
- data/lib/zen/package/base.rb +7 -7
- data/lib/zen/package/categories/lib/categories.rb +8 -3
- data/lib/zen/package/categories/lib/categories/controller/categories.rb +81 -55
- data/lib/zen/package/categories/lib/categories/controller/category_groups.rb +45 -44
- data/lib/zen/package/categories/lib/categories/helper/category.rb +88 -0
- data/lib/zen/package/categories/lib/categories/language/en/categories.yml +5 -4
- data/lib/zen/package/categories/lib/categories/language/en/category_groups.yml +5 -4
- data/lib/zen/package/categories/lib/categories/language/nl/categories.yml +5 -4
- data/lib/zen/package/categories/lib/categories/language/nl/category_groups.yml +5 -4
- data/lib/zen/package/categories/lib/categories/model/category.rb +15 -13
- data/lib/zen/package/categories/lib/categories/model/category_group.rb +3 -3
- data/lib/zen/package/categories/lib/categories/plugin/categories.rb +36 -25
- data/lib/zen/package/categories/lib/categories/view/admin/categories/form.xhtml +49 -56
- data/lib/zen/package/categories/lib/categories/view/admin/categories/index.xhtml +48 -35
- data/lib/zen/package/categories/lib/categories/view/admin/category-groups/form.xhtml +36 -29
- data/lib/zen/package/categories/lib/categories/view/admin/category-groups/index.xhtml +42 -37
- data/lib/zen/package/comments/lib/comments.rb +4 -1
- data/lib/zen/package/comments/lib/comments/controller/comments.rb +39 -32
- data/lib/zen/package/comments/lib/comments/controller/comments_form.rb +45 -26
- data/lib/zen/package/comments/lib/comments/helper/comment.rb +35 -0
- data/lib/zen/package/comments/lib/comments/language/en/comments.yml +9 -7
- data/lib/zen/package/comments/lib/comments/language/nl/comments.yml +10 -8
- data/lib/zen/package/comments/lib/comments/model/comment.rb +31 -17
- data/lib/zen/package/comments/lib/comments/model/comment_status.rb +15 -0
- data/lib/zen/package/comments/lib/comments/plugin/anti_spam.rb +27 -18
- data/lib/zen/package/comments/lib/comments/plugin/comments.rb +25 -20
- data/lib/zen/package/comments/lib/comments/view/admin/comments/form.xhtml +61 -54
- data/lib/zen/package/comments/lib/comments/view/admin/comments/index.xhtml +38 -23
- data/lib/zen/package/comments/migrations/1308774099_comment_status.rb +60 -0
- data/lib/zen/package/custom_fields/lib/custom_fields.rb +33 -7
- data/lib/zen/package/custom_fields/lib/custom_fields/blue_form_parameters.rb +209 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_field_groups.rb +50 -47
- data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_field_types.rb +215 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/controller/custom_fields.rb +111 -73
- data/lib/zen/package/custom_fields/lib/custom_fields/helper/custom_field.rb +79 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/language/en/custom_field_groups.yml +20 -19
- data/lib/zen/package/custom_fields/lib/custom_fields/language/en/custom_field_types.yml +40 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/language/en/custom_fields.yml +34 -32
- data/lib/zen/package/custom_fields/lib/custom_fields/language/nl/custom_field_groups.yml +5 -4
- data/lib/zen/package/custom_fields/lib/custom_fields/language/nl/custom_field_types.yml +40 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/language/nl/custom_fields.yml +18 -16
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field.rb +31 -11
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_method.rb +15 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_type.rb +50 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/model/custom_field_value.rb +28 -7
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-groups/form.xhtml +33 -28
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-groups/index.xhtml +48 -46
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-types/form.xhtml +61 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-types/index.xhtml +93 -0
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-fields/form.xhtml +105 -99
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-fields/index.xhtml +43 -39
- data/lib/zen/package/custom_fields/migrations/1295255665_create_schema.rb +47 -16
- data/lib/zen/package/custom_fields/migrations/1310659580_custom_field_types.rb +148 -0
- data/lib/zen/package/custom_fields/migrations/1311694920_rename_css_class.rb +11 -0
- data/lib/zen/package/menus/lib/menus/controller/menu_items.rb +40 -35
- data/lib/zen/package/menus/lib/menus/controller/menus.rb +47 -43
- data/lib/zen/package/menus/lib/menus/helper/{menu_item.rb → menu.rb} +42 -15
- data/lib/zen/package/menus/lib/menus/language/en/menu_items.yml +5 -5
- data/lib/zen/package/menus/lib/menus/language/en/menus.yml +9 -8
- data/lib/zen/package/menus/lib/menus/language/nl/menu_items.yml +8 -8
- data/lib/zen/package/menus/lib/menus/language/nl/menus.yml +11 -10
- data/lib/zen/package/menus/lib/menus/model/menu.rb +5 -5
- data/lib/zen/package/menus/lib/menus/model/menu_item.rb +6 -5
- data/lib/zen/package/menus/lib/menus/plugin/menus.rb +41 -43
- data/lib/zen/package/menus/lib/menus/view/admin/menu-items/form.xhtml +59 -63
- data/lib/zen/package/menus/lib/menus/view/admin/menu-items/index.xhtml +35 -30
- data/lib/zen/package/menus/lib/menus/view/admin/menus/form.xhtml +46 -37
- data/lib/zen/package/menus/lib/menus/view/admin/menus/index.xhtml +37 -37
- data/lib/zen/package/menus/migrations/1297184342_create_schema.rb +5 -5
- data/lib/zen/package/menus/migrations/1308671733_rename_order_column.rb +11 -0
- data/lib/zen/package/menus/migrations/1311695030_rename_css_class.rb +17 -0
- data/lib/zen/package/sections/lib/sections.rb +18 -11
- data/lib/zen/package/sections/lib/sections/controller/section_entries.rb +115 -109
- data/lib/zen/package/sections/lib/sections/controller/sections.rb +72 -50
- data/lib/zen/package/sections/lib/sections/helper/section.rb +53 -0
- data/lib/zen/package/sections/lib/sections/language/en/section_entries.yml +5 -4
- data/lib/zen/package/sections/lib/sections/language/en/sections.yml +5 -4
- data/lib/zen/package/sections/lib/sections/language/nl/section_entries.yml +5 -4
- data/lib/zen/package/sections/lib/sections/language/nl/sections.yml +5 -4
- data/lib/zen/package/sections/lib/sections/model/section.rb +17 -9
- data/lib/zen/package/sections/lib/sections/model/section_entry.rb +192 -13
- data/lib/zen/package/sections/lib/sections/model/section_entry_status.rb +13 -0
- data/lib/zen/package/sections/lib/sections/plugin/section_entries.rb +60 -39
- data/lib/zen/package/sections/lib/sections/plugin/sections.rb +14 -11
- data/lib/zen/package/sections/lib/sections/view/admin/form.xhtml +100 -97
- data/lib/zen/package/sections/lib/sections/view/admin/index.xhtml +41 -39
- data/lib/zen/package/sections/lib/sections/view/admin/section-entries/form.xhtml +95 -215
- data/lib/zen/package/sections/lib/sections/view/admin/section-entries/index.xhtml +48 -40
- data/lib/zen/package/sections/migrations/1308672298_use_id_for_default_section.rb +40 -0
- data/lib/zen/package/sections/migrations/1308813320_section_entry_statuses.rb +58 -0
- data/lib/zen/package/settings/lib/settings/controller/settings.rb +5 -8
- data/lib/zen/package/settings/lib/settings/model/setting.rb +2 -37
- data/lib/zen/package/settings/lib/settings/plugin/setting_base.rb +18 -1
- data/lib/zen/package/settings/lib/settings/plugin/settings.rb +13 -7
- data/lib/zen/package/settings/lib/settings/view/admin/settings/index.xhtml +2 -1
- data/lib/zen/package/users/lib/users.rb +3 -1
- data/lib/zen/package/users/lib/users/controller/access_rules.rb +77 -60
- data/lib/zen/package/users/lib/users/controller/user_groups.rb +41 -36
- data/lib/zen/package/users/lib/users/controller/users.rb +48 -42
- data/lib/zen/package/users/lib/users/helper/users.rb +72 -0
- data/lib/zen/package/users/lib/users/language/en/access_rules.yml +6 -5
- data/lib/zen/package/users/lib/users/language/en/user_groups.yml +5 -4
- data/lib/zen/package/users/lib/users/language/en/users.yml +1 -0
- data/lib/zen/package/users/lib/users/language/nl/access_rules.yml +5 -4
- data/lib/zen/package/users/lib/users/language/nl/user_groups.yml +5 -4
- data/lib/zen/package/users/lib/users/language/nl/users.yml +1 -0
- data/lib/zen/package/users/lib/users/model/access_rule.rb +5 -1
- data/lib/zen/package/users/lib/users/model/user.rb +17 -10
- data/lib/zen/package/users/lib/users/public/admin/js/users/access_rules.js +10 -37
- data/lib/zen/package/users/lib/users/public/admin/js/users/lib/access_rules.js +49 -0
- data/lib/zen/package/users/lib/users/view/admin/access-rules/form.xhtml +105 -96
- data/lib/zen/package/users/lib/users/view/admin/access-rules/index.xhtml +48 -41
- data/lib/zen/package/users/lib/users/view/admin/user-groups/form.xhtml +42 -32
- data/lib/zen/package/users/lib/users/view/admin/user-groups/index.xhtml +43 -38
- data/lib/zen/package/users/lib/users/view/admin/users/form.xhtml +76 -67
- data/lib/zen/package/users/lib/users/view/admin/users/index.xhtml +43 -41
- data/lib/zen/package/users/lib/users/view/admin/users/login.xhtml +12 -9
- data/lib/zen/package/users/migrations/1295281013_create_schema.rb +2 -2
- data/lib/zen/plugin.rb +56 -50
- data/lib/zen/plugin/markup/lib/markup/markup.rb +33 -21
- data/lib/zen/public/admin/css/zen/buttons.css +11 -7
- data/lib/zen/public/admin/css/zen/datepicker.css +6 -6
- data/lib/zen/public/admin/css/zen/forms.css +2 -1
- data/lib/zen/public/admin/css/zen/general.css +15 -10
- data/lib/zen/public/admin/css/zen/layout.css +51 -20
- data/lib/zen/public/admin/css/zen/tables.css +39 -11
- data/lib/zen/public/admin/css/zen/tabs.css +6 -4
- data/lib/zen/public/admin/css/zen/window.css +11 -11
- data/lib/zen/public/{favicon.ico → admin/favicon.ico} +0 -0
- data/lib/zen/public/admin/images/zen/icons/asc.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/desc.png +0 -0
- data/lib/zen/public/admin/js/vendor/datepicker.js +0 -11
- data/lib/zen/public/admin/js/{mootools → vendor/mootools}/core.js +0 -1
- data/lib/zen/public/admin/js/{mootools → vendor/mootools}/more.js +100 -29
- data/lib/zen/public/admin/js/zen/index.js +48 -0
- data/lib/zen/public/admin/js/zen/lib/asset.js +111 -0
- data/lib/zen/public/admin/js/zen/{editor.js → lib/editor.js} +107 -127
- data/lib/zen/public/admin/js/zen/{editor → lib/editor}/markdown.js +7 -9
- data/lib/zen/public/admin/js/zen/{editor → lib/editor}/textile.js +7 -9
- data/lib/zen/public/admin/js/zen/lib/html_table.js +143 -0
- data/lib/zen/public/admin/js/zen/{tabs.js → lib/tabs.js} +40 -37
- data/lib/zen/public/admin/js/zen/{window.js → lib/window.js} +24 -20
- data/lib/zen/spec/bacon/color_output.rb +39 -0
- data/lib/zen/spec/helper.rb +152 -0
- data/lib/zen/spec/simplecov.rb +22 -0
- data/lib/zen/task/build.rake +20 -43
- data/lib/zen/task/clean.rake +2 -6
- data/lib/zen/task/db.rake +8 -12
- data/lib/zen/task/package.rake +4 -10
- data/lib/zen/task/plugin.rake +3 -9
- data/lib/zen/task/proto.rake +0 -62
- data/lib/zen/task/test.rake +6 -3
- data/lib/zen/task/theme.rake +4 -11
- data/lib/zen/theme.rb +22 -24
- data/lib/zen/validation.rb +34 -27
- data/lib/zen/version.rb +2 -8
- data/lib/zen/view/head.xhtml +7 -0
- data/lib/zen/view/main.xhtml +7 -22
- data/{proto/package/migrations → pkg}/.gitkeep +0 -0
- data/proto/app/app.rb +1 -0
- data/proto/app/config/config.rb +5 -4
- data/proto/app/config/database.rb +19 -41
- data/proto/app/config/middlewares.rb +32 -29
- data/proto/{package/lib/package/view/admin/package/index.xhtml → app/log/database/dev/.gitkeep} +0 -0
- data/proto/app/log/database/live/.gitkeep +0 -0
- data/spec/Rakefile +26 -0
- data/spec/fixtures/zen/asset.rb +18 -0
- data/spec/fixtures/zen/helper/acl.rb +39 -0
- data/spec/fixtures/zen/helper/message.rb +19 -0
- data/spec/fixtures/zen/language/en/spec.yml +10 -0
- data/spec/fixtures/zen/language/nl/spec.yml +7 -0
- data/spec/fixtures/zen/package.rb +17 -0
- data/spec/fixtures/zen/package/comments/controller/comments_form.rb +27 -0
- data/spec/fixtures/zen/package/settings/plugin/settings.rb +20 -0
- data/spec/fixtures/zen/plugin.rb +7 -0
- data/spec/fixtures/zen/theme/404.xhtml +1 -0
- data/spec/fixtures/zen/theme/default-section/index.xhtml +1 -0
- data/spec/fixtures/zen/theme/helper/404.xhtml +1 -0
- data/spec/fixtures/zen/theme/helper/partial.xhtml +1 -0
- data/spec/fixtures/zen/theme/helper/wrong_partial.xhtml +1 -0
- data/spec/fixtures/zen/theme/partials/partial.xhtml +1 -0
- data/spec/fixtures/zen/theme/theme.rb +11 -0
- data/spec/fixtures/zen/validation.rb +22 -0
- data/spec/helper.rb +41 -0
- data/spec/zen/all.rb +5 -0
- data/spec/zen/asset.rb +97 -0
- data/spec/zen/bin/create.rb +89 -0
- data/spec/zen/bin/runner.rb +47 -0
- data/spec/zen/controller/admin_controller.rb +26 -0
- data/spec/zen/controller/main_controller.rb +81 -0
- data/spec/zen/controller/preview.rb +33 -0
- data/spec/zen/helper/acl.rb +149 -0
- data/spec/zen/helper/breadcrumb.rb +38 -0
- data/spec/zen/helper/message.rb +31 -0
- data/spec/zen/helper/theme.rb +58 -0
- data/spec/zen/language.rb +55 -0
- data/spec/zen/package.rb +23 -0
- data/spec/zen/package/categories/controller/categories.rb +123 -0
- data/spec/zen/package/categories/controller/category_groups.rb +108 -0
- data/spec/zen/package/categories/helper/category.rb +75 -0
- data/spec/zen/package/categories/plugin/categories.rb +92 -0
- data/spec/zen/package/comments/controller/comments.rb +134 -0
- data/spec/zen/package/comments/controller/comments_form.rb +343 -0
- data/spec/zen/package/comments/helper/comment.rb +47 -0
- data/spec/zen/package/comments/plugin/anti_spam.rb +59 -0
- data/spec/zen/package/comments/plugin/comments.rb +107 -0
- data/spec/zen/package/custom_fields/blue_form_parameters.rb +183 -0
- data/spec/zen/package/custom_fields/controller/custom_field_groups.rb +120 -0
- data/spec/zen/package/custom_fields/controller/custom_field_types.rb +169 -0
- data/spec/zen/package/custom_fields/controller/custom_fields.rb +158 -0
- data/spec/zen/package/custom_fields/helper/custom_field.rb +86 -0
- data/spec/zen/package/menus/controller/menu_items.rb +110 -0
- data/spec/zen/package/menus/controller/menus.rb +110 -0
- data/spec/zen/package/menus/helper/menu.rb +75 -0
- data/spec/zen/package/menus/plugin/menus.rb +120 -0
- data/spec/zen/package/sections/controller/section_entries.rb +201 -0
- data/spec/zen/package/sections/controller/sections.rb +116 -0
- data/spec/zen/package/sections/helper/section.rb +74 -0
- data/spec/zen/package/sections/plugin/section_entries.rb +161 -0
- data/spec/zen/package/sections/plugin/sections.rb +75 -0
- data/spec/zen/package/settings/controller/settings.rb +36 -0
- data/spec/zen/package/settings/plugin/settings.rb +33 -0
- data/spec/zen/package/users/controller/access_rules.rb +90 -0
- data/spec/zen/package/users/controller/user_groups.rb +101 -0
- data/spec/zen/package/users/controller/users.rb +130 -0
- data/spec/zen/package/users/helper/users.rb +97 -0
- data/spec/zen/plugin.rb +64 -0
- data/spec/zen/plugin/helper.rb +11 -0
- data/spec/zen/plugin/markup.rb +44 -0
- data/spec/zen/theme.rb +41 -0
- data/spec/zen/validation.rb +63 -0
- data/zen.gemspec +36 -0
- metadata +159 -113
- data/MANIFEST +0 -266
- data/lib/zen/bin/app.rb +0 -40
- data/lib/zen/ext/string.rb +0 -185
- data/lib/zen/helper/common.rb +0 -106
- data/lib/zen/package/categories/lib/categories/view/admin/categories/edit.xhtml +0 -7
- data/lib/zen/package/categories/lib/categories/view/admin/categories/new.xhtml +0 -7
- data/lib/zen/package/categories/lib/categories/view/admin/category-groups/edit.xhtml +0 -7
- data/lib/zen/package/categories/lib/categories/view/admin/category-groups/new.xhtml +0 -7
- data/lib/zen/package/comments/lib/comments/view/admin/comments/edit.xhtml +0 -7
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-groups/edit.xhtml +0 -7
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-field-groups/new.xhtml +0 -7
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-fields/edit.xhtml +0 -7
- data/lib/zen/package/custom_fields/lib/custom_fields/view/admin/custom-fields/new.xhtml +0 -7
- data/lib/zen/package/menus/lib/menus/view/admin/menu-items/edit.xhtml +0 -7
- data/lib/zen/package/menus/lib/menus/view/admin/menu-items/new.xhtml +0 -7
- data/lib/zen/package/menus/lib/menus/view/admin/menus/edit.xhtml +0 -7
- data/lib/zen/package/menus/lib/menus/view/admin/menus/new.xhtml +0 -7
- data/lib/zen/package/sections/lib/sections/view/admin/edit.xhtml +0 -7
- data/lib/zen/package/sections/lib/sections/view/admin/new.xhtml +0 -7
- data/lib/zen/package/sections/lib/sections/view/admin/section-entries/edit.xhtml +0 -7
- data/lib/zen/package/sections/lib/sections/view/admin/section-entries/new.xhtml +0 -7
- data/lib/zen/package/users/lib/users/view/admin/access-rules/edit.xhtml +0 -7
- data/lib/zen/package/users/lib/users/view/admin/access-rules/new.xhtml +0 -7
- data/lib/zen/package/users/lib/users/view/admin/user-groups/edit.xhtml +0 -7
- data/lib/zen/package/users/lib/users/view/admin/user-groups/new.xhtml +0 -7
- data/lib/zen/package/users/lib/users/view/admin/users/edit.xhtml +0 -7
- data/lib/zen/package/users/lib/users/view/admin/users/new.xhtml +0 -7
- data/lib/zen/plugin/controller.rb +0 -59
- data/lib/zen/public/admin/css/zen/notifications.css +0 -84
- data/lib/zen/public/admin/images/zen/icons/large/error.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/large/notice.png +0 -0
- data/lib/zen/public/admin/images/zen/icons/large/success.png +0 -0
- data/lib/zen/public/admin/js/zen/core.js +0 -73
- data/lib/zen/public/admin/js/zen/init.js +0 -80
- data/proto/package/lib/package.rb +0 -21
- data/proto/package/lib/package/controller/controllers.rb +0 -50
- data/proto/package/lib/package/language/en/languages.yml +0 -4
- data/proto/package/lib/package/model/model.rb +0 -12
data/.gitignore
ADDED
data/.mailmap
ADDED
data/.rvmrc
ADDED
data/.travis.yml
CHANGED
data/AUTHORS
CHANGED
data/CHANGELOG.md
CHANGED
@@ -1,28 +1,59 @@
|
|
1
|
-
## 0.2.
|
1
|
+
## 0.2.8 - August 3, 2011
|
2
|
+
|
3
|
+
* Replaced RSpec with Bacon.
|
4
|
+
* When retrieving section entries comments are now retrieved properly.
|
5
|
+
* Comments and categories are no longer retrieved by default when calling the
|
6
|
+
section entries plugin.
|
7
|
+
* Statuses of comments and section entries are now stored in a separate table.
|
8
|
+
* Plugins can be called as a singleton using Zen::Plugin.plugin.
|
9
|
+
* The column menu_items.order has been renamed to menu_items.sort_order.
|
10
|
+
* The accessor method for settings that defines the possible values now accepts
|
11
|
+
a Proc, this makes it possible for conditional possible values and such.
|
12
|
+
* Various performance tweaks.
|
13
|
+
* The rake task proto:package has been removed.
|
14
|
+
* The core package have been cleaned up and are much more robust thanks to
|
15
|
+
better validation of various objects such as category groups when viewing a
|
16
|
+
list of categories.
|
17
|
+
* Assets can now be loaded for specific methods using Zen::Asset by specifying
|
18
|
+
the :method key.
|
19
|
+
* Users can now create their own custom field types.
|
20
|
+
* Overview pages now paginate their results so they display a maximum of 20 rows
|
21
|
+
per page.
|
22
|
+
* All references to "css_class" and "css_id" have been replaced with
|
23
|
+
"html_class" and "html_id".
|
24
|
+
* Ramaze::Helper::Common has been removed.
|
25
|
+
* Tables can now be sorted by clicking on the headers.
|
26
|
+
* The required permissions for the #save() methods of all controllers have been
|
27
|
+
set correctly (issue #28).
|
28
|
+
* The executable now uses OptionParser instead of Commander.
|
29
|
+
* The total code coverage has been increased to 95.63% meaning Zen has become
|
30
|
+
even more stable than ever.
|
31
|
+
* Fixed a few broken migrations.
|
32
|
+
|
33
|
+
## 0.2.7 - June 16, 2011
|
2
34
|
|
3
35
|
* Started using Ramaze.setup for Gem management.
|
4
|
-
* Websites can no longer be marked as "offline", this was a rather useless
|
36
|
+
* Websites can no longer be marked as "offline", this was a rather useless
|
37
|
+
feature anyway.
|
5
38
|
* Fixed various bugs
|
6
39
|
|
7
|
-
## 0.2.6.1 - June
|
40
|
+
## 0.2.6.1 - June 1, 2011
|
8
41
|
|
9
|
-
* Dropped Zen.settings and modified the settings plugin so that it works
|
10
|
-
using a multi-process based environment such as Unicorn.
|
42
|
+
* Dropped Zen.settings and modified the settings plugin so that it works
|
43
|
+
properly when using a multi-process based environment such as Unicorn.
|
11
44
|
|
12
|
-
## 0.2.6 - May
|
45
|
+
## 0.2.6 - May 29, 2011
|
13
46
|
|
14
47
|
* Zen is now using RVM for gem management and such.
|
15
|
-
* Began working on making Zen compatible with at least JRuby. Rubinius isn't
|
16
|
-
effort at this time.
|
17
|
-
* Removed Ramaze::Helper::Common.notification in favor of
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
for more information.
|
48
|
+
* Began working on making Zen compatible with at least JRuby. Rubinius isn't
|
49
|
+
worth the effort at this time.
|
50
|
+
* Removed Ramaze::Helper::Common.notification in favor of
|
51
|
+
Ramaze::Helper::Message.
|
52
|
+
* Dropped Zen::Database, Zen::Settings and most of the options in favor of
|
53
|
+
instance variables set in the main Zen module. See commit
|
54
|
+
d40ee1c2e518a323b2983e1bcfb7a0d863bf3b2f for more information.
|
22
55
|
* Translated Zen to Dutch.
|
23
56
|
* Re-organized the application prototypes to make them easier to use/understand.
|
24
|
-
* Implemented the anti-spam system as a plugin and added a decent XSS protection
|
25
|
-
using Loofah.
|
57
|
+
* Implemented the anti-spam system as a plugin and added a decent XSS protection
|
58
|
+
system using Loofah.
|
26
59
|
* Various changes to the Javascript classes.
|
27
|
-
|
28
|
-
[d40ee1c2e518a323b2983e1bcfb7a0d863bf3b2f]: https://github.com/zen-cms/Zen-Core/commit/d40ee1c2e518a323b2983e1bcfb7a0d863bf3b2f
|
data/README.md
CHANGED
@@ -1,16 +1,17 @@
|
|
1
1
|
# README
|
2
2
|
|
3
|
-
Zen is a modular CMS written on top of the awesome Ramaze framework. Zen was
|
4
|
-
the frustration with Expression Engine, a popular CMS built on top
|
5
|
-
framework which in turn is written using PHP. While I really
|
6
|
-
ExpressionEngine and EllisLab there were several problems
|
7
|
-
to write a system that's loosely based on
|
8
|
-
|
9
|
-
|
3
|
+
Zen is a modular CMS written on top of the awesome Ramaze framework. Zen was
|
4
|
+
built out of the frustration with Expression Engine, a popular CMS built on top
|
5
|
+
of the Codeigniter framework which in turn is written using PHP. While I really
|
6
|
+
like Codeigniter, ExpressionEngine and EllisLab there were several problems
|
7
|
+
that bothered me. So I set out to write a system that's loosely based on
|
8
|
+
ExpressionEngine but fits my needs. Because of this certain features may seem
|
9
|
+
similar to those provided by EE and while at certain points there are
|
10
|
+
similarities there are also pretty big differences.
|
10
11
|
|
11
12
|
## Requirements
|
12
13
|
|
13
|
-
* Ramaze 2011.01.30 or newer
|
14
|
+
* Ramaze 2011.01.30 or newer
|
14
15
|
* Ruby 1.9.2
|
15
16
|
* A database (MySQL, PostgreSQL, etc)
|
16
17
|
|
@@ -19,47 +20,50 @@ points there are similarities there are also pretty big differences.
|
|
19
20
|
Installing Zen using Rubygems is probably the easiest way:
|
20
21
|
|
21
22
|
$ gem install zen
|
22
|
-
$ zen
|
23
|
+
$ zen create application_name
|
23
24
|
|
24
25
|
If you like to hack with the core of Zen it's best to install it using Git:
|
25
26
|
|
26
|
-
$ git clone git://github.com/zen-cms/
|
27
|
+
$ git clone git://github.com/zen-cms/Zen-Core.git
|
27
28
|
$ cd zen-core
|
28
29
|
$ rake build:gem
|
29
30
|
|
30
31
|
## Database Support
|
31
32
|
|
32
|
-
Technically Zen should run on any given DBMS that's supported by Sequel as Zen
|
33
|
-
use any DBMS specific field types. However, there might be a chance that
|
34
|
-
If you happen to have any problems getting Zen running using your
|
35
|
-
feel free to submit a ticket or post it on the mailing
|
33
|
+
Technically Zen should run on any given DBMS that's supported by Sequel as Zen
|
34
|
+
doesn't use any DBMS specific field types. However, there might be a chance that
|
35
|
+
it won't work. If you happen to have any problems getting Zen running using your
|
36
|
+
database of choice feel free to submit a ticket or post it on the mailing
|
37
|
+
list.
|
36
38
|
|
37
|
-
The Zen website itself is tested and served using MySQL, SQLite3 works just as
|
38
|
-
PostgreSQL will be tested in the near future.
|
39
|
+
The Zen website itself is tested and served using MySQL, SQLite3 works just as
|
40
|
+
fine and PostgreSQL will be tested in the near future.
|
39
41
|
|
40
42
|
## Running Zen
|
41
43
|
|
42
|
-
Zen can be run using any webserver as long as it supports Rack. Thin, Unicorn or
|
43
|
-
they should all work. The main website of Zen is served using Unicorn
|
44
|
-
development is done using WEBRick and Unicorn.
|
44
|
+
Zen can be run using any webserver as long as it supports Rack. Thin, Unicorn or
|
45
|
+
Passenger, they should all work. The main website of Zen is served using Unicorn
|
46
|
+
and Nginx, development is done using WEBRick and Unicorn.
|
45
47
|
|
46
48
|
## Documentation
|
47
49
|
|
48
|
-
The documentation (both the userguide and the API docs) can be found on the
|
49
|
-
located [here][zen documentation].
|
50
|
+
The documentation (both the userguide and the API docs) can be found on the
|
51
|
+
website, located [here][zen documentation].
|
50
52
|
|
51
53
|
## Hacking/Contributing
|
52
54
|
|
53
|
-
Zen follows a relatively strict set of guidelines when it comes to developing
|
54
|
-
and making sure everything goes along smoothly. When working with
|
55
|
-
on [nvie's branch model][nvie branch model] is used.
|
56
|
-
is directly used for pushing Gems and thus
|
57
|
-
is used to contain less stable (but
|
58
|
-
|
55
|
+
Zen follows a relatively strict set of guidelines when it comes to developing
|
56
|
+
core features and making sure everything goes along smoothly. When working with
|
57
|
+
Git a branch model based on [nvie's branch model][nvie branch model] is used.
|
58
|
+
This means that the "master" branch is directly used for pushing Gems and thus
|
59
|
+
should *always* contain stable code. Develop is used to contain less stable (but
|
60
|
+
not unstable) commits that will be pushed into "master" from time to time. All
|
61
|
+
other branches, e.g. "rspec2" will be used for individual features.
|
59
62
|
|
60
|
-
Besides following this model developers are also expected to write tests using
|
61
|
-
RSpec or Capybara for their features. Capybara is used to test
|
62
|
-
based tests while RSpec is used to test libraries,
|
63
|
+
Besides following this model developers are also expected to write tests using
|
64
|
+
either RSpec or Capybara for their features. Capybara is used to test
|
65
|
+
controllers and browser based tests while RSpec is used to test libraries,
|
66
|
+
helpers, etc.
|
63
67
|
|
64
68
|
## Coding Standards
|
65
69
|
|
@@ -68,28 +72,29 @@ based tests while RSpec is used to test libraries, helpers, etc.
|
|
68
72
|
* Document your code, that includes CSS and Javascript files.
|
69
73
|
* No tabs at all times.
|
70
74
|
* Markdown is used for all markup.
|
71
|
-
* The maximum width of each line should be no more than
|
72
|
-
easier to read code in terminals or when using split view modes.
|
75
|
+
* The maximum width of each line should be no more than 80 characters, this
|
76
|
+
makes it easier to read code in terminals or when using split view modes. The
|
77
|
+
limit used to be 90 characters but this was decreased to fit the Ruby coding
|
78
|
+
standards. Existing code using the 90 character limit will be changed over
|
79
|
+
time.
|
73
80
|
|
74
81
|
## Community
|
75
82
|
|
76
83
|
* [Website][zen website]
|
77
84
|
* [Mailing list][mailing list]
|
78
85
|
|
79
|
-
Zen does not have it's own IRC channel at this time but you can usually find me
|
80
|
-
of the following channels on Freenode:
|
86
|
+
Zen does not have it's own IRC channel at this time but you can usually find me
|
87
|
+
in any of the following channels on Freenode:
|
81
88
|
|
82
89
|
* \#forrst-chat
|
83
90
|
* \#ramaze
|
84
|
-
* \#codeigniter
|
85
|
-
* \#mootools
|
86
91
|
|
87
92
|
## License
|
88
93
|
|
89
|
-
Zen is licensed under the MIT license. For more information about this license
|
90
|
-
the file "LICENSE".
|
94
|
+
Zen is licensed under the MIT license. For more information about this license
|
95
|
+
open the file "LICENSE".
|
91
96
|
|
92
97
|
[zen website]: http://zen-cms.com/
|
93
|
-
[zen documentation]: http://zen-cms.com/userguide/
|
98
|
+
[zen documentation]: http://zen-cms.com/userguide/index.html
|
94
99
|
[nvie branch model]: http://nvie.com/posts/a-successful-git-branching-model/
|
95
100
|
[mailing list]: https://groups.google.com/forum/#!forum/zen-cms
|
data/Rakefile
CHANGED
data/bin/zen
CHANGED
@@ -1,34 +1,9 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
|
-
require 'ramaze'
|
3
|
-
require File.expand_path('../../lib/zen/version', __FILE__)
|
4
|
-
|
5
|
-
Ramaze.setup(:verbose => false) do
|
6
|
-
gem 'commander', ['~> 4.0.4']
|
7
|
-
end
|
8
|
-
|
9
|
-
require 'commander/import'
|
10
|
-
|
11
|
-
# Set the extra information message
|
12
|
-
information = <<-MSG
|
13
|
-
* Website: http://zen-cms.com/
|
14
|
-
* Github: https://github.com/zen-cms
|
15
|
-
* License: MIT License
|
16
|
-
MSG
|
17
2
|
|
18
|
-
|
19
|
-
|
20
|
-
program :version , Zen::Version
|
21
|
-
program :description, 'Zen is a modular CMS written using Ramaze.'
|
22
|
-
|
23
|
-
program :help, 'Example' , '$ zen [COMMAND] [OPTIONS]'
|
24
|
-
program :help, 'Information', information.strip
|
25
|
-
|
26
|
-
program :help_formatter, Commander::HelpFormatter::TerminalCompact
|
3
|
+
require 'ramaze'
|
4
|
+
require 'optparse'
|
27
5
|
|
28
|
-
|
29
|
-
|
30
|
-
commands = Dir.glob(commands)
|
6
|
+
require __DIR__('../lib/zen/version')
|
7
|
+
require __DIR__('../lib/zen/bin/runner')
|
31
8
|
|
32
|
-
|
33
|
-
require cmd
|
34
|
-
end
|
9
|
+
Zen::Bin::Runner.run
|
data/lib/zen.rb
CHANGED
@@ -3,7 +3,7 @@ require 'ramaze'
|
|
3
3
|
require 'yaml'
|
4
4
|
|
5
5
|
Ramaze.setup(:verbose => false) do
|
6
|
-
gem 'sequel' , ['~> 3.
|
6
|
+
gem 'sequel' , ['~> 3.26']
|
7
7
|
gem 'bcrypt-ruby' , ['~> 2.1.4'], :lib => 'bcrypt'
|
8
8
|
gem 'sequel_sluggable', ['~> 0.0.6']
|
9
9
|
gem 'loofah' , ['~> 1.0.0']
|
@@ -12,8 +12,9 @@ end
|
|
12
12
|
require __DIR__('zen/version')
|
13
13
|
|
14
14
|
##
|
15
|
-
# Main module for Zen, all other modules and classes will be placed inside this
|
16
|
-
# This module loads all required classes and is used for starting the
|
15
|
+
# Main module for Zen, all other modules and classes will be placed inside this
|
16
|
+
# module. This module loads all required classes and is used for starting the
|
17
|
+
# application.
|
17
18
|
#
|
18
19
|
# @author Yorick Peterse
|
19
20
|
# @since 0.1
|
@@ -25,8 +26,8 @@ module Zen
|
|
25
26
|
|
26
27
|
class << self
|
27
28
|
##
|
28
|
-
# Variable that will contain a database connection that was established
|
29
|
-
# Sequel.connect.
|
29
|
+
# Variable that will contain a database connection that was established
|
30
|
+
# using Sequel.connect.
|
30
31
|
#
|
31
32
|
# @author Yorick Peterse
|
32
33
|
# @since 0.2.6
|
@@ -63,15 +64,8 @@ module Zen
|
|
63
64
|
css = File.join(p, 'admin/css/global.css')
|
64
65
|
js = File.join(p, 'admin/js/global.js')
|
65
66
|
|
66
|
-
|
67
|
-
if File.exist?(
|
68
|
-
::Zen::Asset.stylesheet(['global'], :global => true)
|
69
|
-
end
|
70
|
-
|
71
|
-
# Load the JS file if it's there
|
72
|
-
if File.exist?(js)
|
73
|
-
::Zen::Asset.javascript(['global'], :global => true)
|
74
|
-
end
|
67
|
+
Zen::Asset.stylesheet(['global'], :global => true) if File.exist?(css)
|
68
|
+
Zen::Asset.javascript(['global'], :global => true) if File.exist?(js)
|
75
69
|
end
|
76
70
|
end
|
77
71
|
|
@@ -85,9 +79,10 @@ module Zen
|
|
85
79
|
# Migrate all settings
|
86
80
|
begin
|
87
81
|
plugin(:settings, :migrate)
|
88
|
-
rescue
|
82
|
+
rescue => e
|
89
83
|
Ramaze::Log.warn(
|
90
|
-
|
84
|
+
'Failed to migrate the settings, make sure the database ' + \
|
85
|
+
'table is up to date'
|
91
86
|
)
|
92
87
|
end
|
93
88
|
end
|
@@ -110,7 +105,6 @@ Zen::Language.load('zen_general')
|
|
110
105
|
|
111
106
|
# Load all additional files
|
112
107
|
require __DIR__('zen/plugin/helper')
|
113
|
-
require __DIR__('zen/plugin/controller')
|
114
108
|
require __DIR__('zen/plugin/markup/lib/markup')
|
115
109
|
|
116
110
|
require __DIR__('zen/package')
|
@@ -123,7 +117,7 @@ require __DIR__('zen/controller/admin_controller')
|
|
123
117
|
require __DIR__('zen/controller/main_controller')
|
124
118
|
require __DIR__('zen/controller/preview')
|
125
119
|
|
126
|
-
# Load the cache for the settings. This has to be done outside any of the init
|
127
|
-
# that would make it impossible to set a custom cache.
|
120
|
+
# Load the cache for the settings. This has to be done outside any of the init
|
121
|
+
# methods as that would make it impossible to set a custom cache.
|
128
122
|
Ramaze::Cache.options.names.push(:settings)
|
129
123
|
Ramaze::Cache.options.settings = Ramaze::Cache::LRU
|
data/lib/zen/asset.rb
CHANGED
@@ -3,16 +3,18 @@ require 'ramaze/gestalt'
|
|
3
3
|
#:nodoc:
|
4
4
|
module Zen
|
5
5
|
##
|
6
|
-
# The Asset module is a module used to register what Javascript files and
|
7
|
-
# should be loaded for the current request. This can be very
|
8
|
-
# a widget to all pages or override a certain
|
6
|
+
# The Asset module is a module used to register what Javascript files and
|
7
|
+
# stylesheets should be loaded for the current request. This can be very
|
8
|
+
# useful if you want to add a widget to all pages or override a certain
|
9
|
+
# stylesheet.
|
9
10
|
#
|
10
11
|
# ## Adding Assets
|
11
12
|
#
|
12
|
-
# Assets can be added by calling either Zen::Asset.stylesheet or
|
13
|
-
# Both take an array of files and a hash with some
|
14
|
-
# on the exact usage and all the
|
15
|
-
# are a few quick
|
13
|
+
# Assets can be added by calling either Zen::Asset.stylesheet or
|
14
|
+
# Zen::Asset.javascript. Both take an array of files and a hash with some
|
15
|
+
# configuration options, for more info on the exact usage and all the
|
16
|
+
# available parameters see the individual methods. Here are a few quick
|
17
|
+
# examples of loading files:
|
16
18
|
#
|
17
19
|
# # Load 3 Javascript files of which 2 will be loaded globally
|
18
20
|
# Zen::Asset.javascript(
|
@@ -27,18 +29,19 @@ module Zen
|
|
27
29
|
#
|
28
30
|
# ## Customizing Options
|
29
31
|
#
|
30
|
-
# This module uses Innate::Optioned to provide a few options that can be
|
31
|
-
# following options are available:
|
32
|
+
# This module uses Innate::Optioned to provide a few options that can be
|
33
|
+
# changed. The following options are available:
|
32
34
|
#
|
33
35
|
# * prefix: The global prefix to use for all assets, set to "admin" by default.
|
34
|
-
# * javascript_prefix: The prefix to use for all Javascript files on top of
|
35
|
-
#
|
36
|
-
# * stylesheet_prefix: Similar to the javascript_prefix option but for
|
36
|
+
# * javascript_prefix: The prefix to use for all Javascript files on top of
|
37
|
+
# the globalprefix.
|
38
|
+
# * stylesheet_prefix: Similar to the javascript_prefix option but for
|
39
|
+
# stylesheets.
|
37
40
|
#
|
38
41
|
# ## Building Assets
|
39
42
|
#
|
40
|
-
# Building assets shouldn't be required as Zen already does this but if you
|
41
|
-
# need it you can build the files as following:
|
43
|
+
# Building assets shouldn't be required as Zen already does this but if you
|
44
|
+
# happen to need it you can build the files as following:
|
42
45
|
#
|
43
46
|
# Zen::Asset.build(:stylesheet)
|
44
47
|
# Zen::Asset.build(:javascript)
|
@@ -46,9 +49,9 @@ module Zen
|
|
46
49
|
# ## Controller Usage
|
47
50
|
#
|
48
51
|
# While this module can be called by any other piece of code the class
|
49
|
-
# Zen::Controller::AdminController provides shortcuts to Zen::Asset.javascript
|
50
|
-
# Zen::Asset.stylesheet. These shortcuts work identical but are defined
|
51
|
-
# and thus can be used inside your class declaration:
|
52
|
+
# Zen::Controller::AdminController provides shortcuts to Zen::Asset.javascript
|
53
|
+
# and Zen::Asset.stylesheet. These shortcuts work identical but are defined
|
54
|
+
# as class methods and thus can be used inside your class declaration:
|
52
55
|
#
|
53
56
|
# class Something < Zen::Controller::AdminController
|
54
57
|
# stylesheet ['reset'], :global => true
|
@@ -60,19 +63,15 @@ module Zen
|
|
60
63
|
module Asset
|
61
64
|
include ::Innate::Optioned
|
62
65
|
|
63
|
-
class << self
|
64
|
-
include ::Innate::Trinity
|
65
|
-
end
|
66
|
-
|
67
66
|
options.dsl do
|
68
|
-
o 'Prefix for
|
69
|
-
o 'Prefix for
|
70
|
-
o 'Prefix for
|
67
|
+
o 'Prefix for JS and CSS files' , :prefix , 'admin'
|
68
|
+
o 'Prefix for JS files on top of :prefix', :javascript_prefix, 'js'
|
69
|
+
o 'Prefix for CSS on top of :prefix' , :stylesheet_prefix, 'css'
|
71
70
|
end
|
72
71
|
|
73
72
|
##
|
74
|
-
# Hash containing all the global and controller specific stylesheets that
|
75
|
-
# loaded when calling build_stylesheets.
|
73
|
+
# Hash containing all the global and controller specific stylesheets that
|
74
|
+
# have to be loaded when calling build_stylesheets.
|
76
75
|
#
|
77
76
|
# @author Yorick Peterse
|
78
77
|
# @since 0.2.5
|
@@ -82,8 +81,8 @@ module Zen
|
|
82
81
|
}
|
83
82
|
|
84
83
|
##
|
85
|
-
# Hash containing all the global and controller specific stylesheets to
|
86
|
-
# calling build_javascripts.
|
84
|
+
# Hash containing all the global and controller specific stylesheets to
|
85
|
+
# load when calling build_javascripts.
|
87
86
|
#
|
88
87
|
# @author Yorick Peterse
|
89
88
|
# @since 0.2.5
|
@@ -93,9 +92,9 @@ module Zen
|
|
93
92
|
}
|
94
93
|
|
95
94
|
##
|
96
|
-
# Registers the given Javascripts files so that they're either loaded for
|
97
|
-
# current action or for all actions. Note that the first argument of
|
98
|
-
# should always be an array.
|
95
|
+
# Registers the given Javascripts files so that they're either loaded for
|
96
|
+
# the current action or for all actions. Note that the first argument of
|
97
|
+
# this method should always be an array.
|
99
98
|
#
|
100
99
|
# @example
|
101
100
|
# # Loads /admin/js/users/access_rules.js for the current action only
|
@@ -106,17 +105,13 @@ module Zen
|
|
106
105
|
#
|
107
106
|
# @author Yorick Peterse
|
108
107
|
# @since 0.2.5
|
109
|
-
# @
|
110
|
-
# load relatively to the root of the application (/).
|
111
|
-
# @param [Hash] options A hash containing additional options.
|
112
|
-
# @option options [TrueClass] :global When set to true the specified files will be
|
113
|
-
# loaded globally rather than just for the current action.
|
114
|
-
# @option options [String/Symbol] controller The name of the controller for which
|
115
|
-
# the specified files should be loaded.
|
108
|
+
# @see Zen::Asset.process
|
116
109
|
#
|
117
110
|
def self.javascript(files, options = {})
|
118
111
|
options = {
|
119
|
-
:prefix => File.join(
|
112
|
+
:prefix => File.join(
|
113
|
+
'/', self.options.prefix, self.options.javascript_prefix
|
114
|
+
),
|
120
115
|
:type => :javascript
|
121
116
|
}.merge(options)
|
122
117
|
|
@@ -124,24 +119,21 @@ module Zen
|
|
124
119
|
end
|
125
120
|
|
126
121
|
##
|
127
|
-
# Registers a number of stylesheets that can either be loaded globally or
|
128
|
-
# current action.
|
122
|
+
# Registers a number of stylesheets that can either be loaded globally or
|
123
|
+
# for the current action.
|
129
124
|
#
|
130
125
|
# @example
|
131
126
|
# Zen::Asset.stylesheet ['foobar/admin_template'], :global => true
|
132
127
|
#
|
133
128
|
# @author Yorick Peterse
|
134
129
|
# @since 0.2.5
|
135
|
-
# @
|
136
|
-
# @param [Hash] options A hash containing additional options to use.
|
137
|
-
# @option options [TrueClass] :global When set to true all the specified stylesheets
|
138
|
-
# will be loaded globally rather than just for the current action.
|
139
|
-
# @option options [String/Symbol] controller The name of the controller for which
|
140
|
-
# the specified files should be loaded.
|
130
|
+
# @see Zen::Asset.process
|
141
131
|
#
|
142
132
|
def self.stylesheet(files, options = {})
|
143
133
|
options = {
|
144
|
-
:prefix => File.join(
|
134
|
+
:prefix => File.join(
|
135
|
+
'/', self.options.prefix, self.options.stylesheet_prefix
|
136
|
+
),
|
145
137
|
:type => :stylesheet
|
146
138
|
}.merge(options)
|
147
139
|
|
@@ -149,8 +141,8 @@ module Zen
|
|
149
141
|
end
|
150
142
|
|
151
143
|
##
|
152
|
-
# Builds either all Javascript files or stylesheets. This method will load
|
153
|
-
# global and action specific files.
|
144
|
+
# Builds either all Javascript files or stylesheets. This method will load
|
145
|
+
# both the global and action specific files.
|
154
146
|
#
|
155
147
|
# @example
|
156
148
|
# # Build the HTML tags for all stylesheets
|
@@ -167,9 +159,16 @@ module Zen
|
|
167
159
|
def self.build(type)
|
168
160
|
type = type.to_sym
|
169
161
|
attrs = {}
|
170
|
-
controller = action.node.to_s.to_sym
|
162
|
+
controller = Ramaze::Current.action.node.to_s.to_sym
|
163
|
+
method = Ramaze::Current.action.method.to_s.to_sym
|
171
164
|
gestalt = Ramaze::Gestalt.new
|
172
165
|
|
166
|
+
# The method in Ramaze::Current.action.method does not always contain the
|
167
|
+
# method since the assets are built in a layout.
|
168
|
+
if method.empty? and Ramaze::Current.actions[-2]
|
169
|
+
method = Ramaze::Current.actions[-2].method.to_s.to_sym
|
170
|
+
end
|
171
|
+
|
173
172
|
# Set the basic elements of the tag
|
174
173
|
if type === :stylesheet
|
175
174
|
tag = :link
|
@@ -184,7 +183,13 @@ module Zen
|
|
184
183
|
|
185
184
|
# Get all the files to build
|
186
185
|
if !files[controller].nil?
|
187
|
-
|
186
|
+
if files[controller].key?(method)
|
187
|
+
files = files[:global] + files[controller][method]
|
188
|
+
elsif !files[controller][:__all].nil?
|
189
|
+
files = files[:global] + files[controller][:__all]
|
190
|
+
else
|
191
|
+
files = files[:global]
|
192
|
+
end
|
188
193
|
else
|
189
194
|
files = files[:global]
|
190
195
|
end
|
@@ -211,19 +216,29 @@ module Zen
|
|
211
216
|
# Stores the given files in the correct hash based on the specified options.
|
212
217
|
#
|
213
218
|
# @example
|
214
|
-
# process(
|
219
|
+
# process(
|
220
|
+
# ['foobar', 'baz'],
|
221
|
+
# :global => false,
|
222
|
+
# :type => :javascript,
|
223
|
+
# :prefix => 'js'
|
224
|
+
# )
|
215
225
|
#
|
216
226
|
# @author Yorick Peterse
|
217
227
|
# @since 0.2.5
|
218
228
|
# @param [Array] files An array of files to load.
|
219
229
|
# @param [Hash] options A hash containing all the required options.
|
220
|
-
# @option options [TrueClass] :global Specifies that all the files should be
|
221
|
-
# globally.
|
222
|
-
# @option options [Symbol] :type The type of asset that's loaded, can either
|
223
|
-
# :javascript or :stylesheet.
|
230
|
+
# @option options [TrueClass] :global Specifies that all the files should be
|
231
|
+
# loaded globally.
|
232
|
+
# @option options [Symbol] :type The type of asset that's loaded, can either
|
233
|
+
# be :javascript or :stylesheet.
|
224
234
|
# @option options [String] :prefix The prefix to use for all the assets.
|
225
|
-
# @option options [TrueClass] :global
|
226
|
-
#
|
235
|
+
# @option options [TrueClass] :global When set to true the specified files
|
236
|
+
# will be loaded globally.
|
237
|
+
# @option options [Symbol/String] :controller The class of the controller
|
238
|
+
# for which the assets should be loaded.
|
239
|
+
# @option options [Symbol/String/Array] :method A string or symbol that
|
240
|
+
# represents a single method for which to load the assets OR an array of
|
241
|
+
# methods.
|
227
242
|
#
|
228
243
|
def self.process(files, options)
|
229
244
|
# Determine whether the files should be loaded globally
|
@@ -242,14 +257,34 @@ module Zen
|
|
242
257
|
ext = '.css'
|
243
258
|
end
|
244
259
|
|
260
|
+
# Get the method to load the assets for
|
261
|
+
if options.key?(:method) and options[:method].class != Array
|
262
|
+
options[:method] = [options[:method]]
|
263
|
+
end
|
264
|
+
|
245
265
|
# Add all the files
|
246
266
|
files.each do |f|
|
247
|
-
f
|
248
|
-
f
|
249
|
-
save[key] ||= []
|
267
|
+
f = f.to_s + ext
|
268
|
+
f = File.join(options[:prefix], f)
|
250
269
|
|
251
|
-
|
252
|
-
|
270
|
+
# Load the assets for all the given methods
|
271
|
+
if options.key?(:method)
|
272
|
+
options[:method].each do |method|
|
273
|
+
method = method.to_sym
|
274
|
+
save[key] ||= {}
|
275
|
+
save[key][method] ||= []
|
276
|
+
|
277
|
+
save[key][method].push(f) unless save[key][method].include?(f)
|
278
|
+
end
|
279
|
+
# Load the assets for all methods in the controller
|
280
|
+
else
|
281
|
+
if key === :global
|
282
|
+
save[key].push(f) unless save[key].include?(f)
|
283
|
+
else
|
284
|
+
save[key] ||= {}
|
285
|
+
save[key][:__all] ||= []
|
286
|
+
save[key][:__all].push(f) unless save[key][:__all].include?(f)
|
287
|
+
end
|
253
288
|
end
|
254
289
|
end
|
255
290
|
end
|