releaf 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +24 -0
- data/README.md +74 -0
- data/Rakefile +62 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-bg_flat_75_ffffff_40x100.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-bg_glass_55_fbf9ee_1x400.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-bg_glass_75_dadada_1x400.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-bg_glass_75_e6e6e6_1x400.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-bg_glass_95_fef1ec_1x400.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-bg_highlight-soft_75_cccccc_1x100.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-icons_222222_256x240.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-icons_2e83ff_256x240.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-icons_454545_256x240.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-icons_888888_256x240.png +0 -0
- data/app/assets/images/releaf/3rd_party/jquery-ui-1.9.2.custom/ui-icons_cd0a0a_256x240.png +0 -0
- data/app/assets/images/releaf/3rd_party/lightbox/close.png +0 -0
- data/app/assets/images/releaf/3rd_party/lightbox/loading.gif +0 -0
- data/app/assets/images/releaf/3rd_party/lightbox/next.png +0 -0
- data/app/assets/images/releaf/3rd_party/lightbox/prev.png +0 -0
- data/app/assets/images/releaf/add.png +0 -0
- data/app/assets/images/releaf/background.jpg +0 -0
- data/app/assets/images/releaf/button/button_bgr.gif +0 -0
- data/app/assets/images/releaf/button/button_hover_bgr.png +0 -0
- data/app/assets/images/releaf/controllers/content/close.gif +0 -0
- data/app/assets/images/releaf/controllers/content/close_active.gif +0 -0
- data/app/assets/images/releaf/controllers/content/close_hover.gif +0 -0
- data/app/assets/images/releaf/controllers/content/global_fields_bgr.png +0 -0
- data/app/assets/images/releaf/controllers/content/open.gif +0 -0
- data/app/assets/images/releaf/controllers/content/open_2.gif +0 -0
- data/app/assets/images/releaf/controllers/content/open_active.gif +0 -0
- data/app/assets/images/releaf/controllers/content/open_hover.gif +0 -0
- data/app/assets/images/releaf/controllers/sessions/background.jpg +0 -0
- data/app/assets/images/releaf/controllers/sessions/logo.jpg +0 -0
- data/app/assets/images/releaf/expand_tool/close.png +0 -0
- data/app/assets/images/releaf/expand_tool/close_hover.png +0 -0
- data/app/assets/images/releaf/expand_tool/close_hover_shim.png +0 -0
- data/app/assets/images/releaf/expand_tool/close_shim.png +0 -0
- data/app/assets/images/releaf/expand_tool/loader.gif +0 -0
- data/app/assets/images/releaf/expand_tool/open.png +0 -0
- data/app/assets/images/releaf/expand_tool/open_hover.png +0 -0
- data/app/assets/images/releaf/expand_tool/open_hover_shim.png +0 -0
- data/app/assets/images/releaf/expand_tool/open_shim.png +0 -0
- data/app/assets/images/releaf/favicon.ico +0 -0
- data/app/assets/images/releaf/globalFieldContainerBgr.png +0 -0
- data/app/assets/images/releaf/icons/129.png +0 -0
- data/app/assets/images/releaf/icons/130.png +0 -0
- data/app/assets/images/releaf/icons/accept.png +0 -0
- data/app/assets/images/releaf/icons/add.png +0 -0
- data/app/assets/images/releaf/icons/arrow_down.png +0 -0
- data/app/assets/images/releaf/icons/arrow_left.png +0 -0
- data/app/assets/images/releaf/icons/arrow_refresh.png +0 -0
- data/app/assets/images/releaf/icons/arrow_up.png +0 -0
- data/app/assets/images/releaf/icons/bin_empty.png +0 -0
- data/app/assets/images/releaf/icons/bullet_black.png +0 -0
- data/app/assets/images/releaf/icons/bullet_connect.png +0 -0
- data/app/assets/images/releaf/icons/bullet_start.png +0 -0
- data/app/assets/images/releaf/icons/bullet_tick.png +0 -0
- data/app/assets/images/releaf/icons/chrome.png +0 -0
- data/app/assets/images/releaf/icons/control_play.png +0 -0
- data/app/assets/images/releaf/icons/date.png +0 -0
- data/app/assets/images/releaf/icons/delete.png +0 -0
- data/app/assets/images/releaf/icons/disk.png +0 -0
- data/app/assets/images/releaf/icons/drag-handle.png +0 -0
- data/app/assets/images/releaf/icons/error.png +0 -0
- data/app/assets/images/releaf/icons/eye.png +0 -0
- data/app/assets/images/releaf/icons/firefox.png +0 -0
- data/app/assets/images/releaf/icons/google-not-available.gif +0 -0
- data/app/assets/images/releaf/icons/google.gif +0 -0
- data/app/assets/images/releaf/icons/keyboard.png +0 -0
- data/app/assets/images/releaf/icons/left_16.png +0 -0
- data/app/assets/images/releaf/icons/link.png +0 -0
- data/app/assets/images/releaf/icons/magnifier.png +0 -0
- data/app/assets/images/releaf/icons/notAllowed.png +0 -0
- data/app/assets/images/releaf/icons/page_white_add.png +0 -0
- data/app/assets/images/releaf/icons/page_white_edit.png +0 -0
- data/app/assets/images/releaf/icons/page_white_put.png +0 -0
- data/app/assets/images/releaf/icons/page_white_text.png +0 -0
- data/app/assets/images/releaf/icons/pencil.png +0 -0
- data/app/assets/images/releaf/icons/picture.png +0 -0
- data/app/assets/images/releaf/icons/right_16.png +0 -0
- data/app/assets/images/releaf/icons/tick.png +0 -0
- data/app/assets/images/releaf/icons/warning.png +0 -0
- data/app/assets/images/releaf/icons/world_go.png +0 -0
- data/app/assets/images/releaf/icons/world_link.png +0 -0
- data/app/assets/images/releaf/input/autocompleteExpandIcon.png +0 -0
- data/app/assets/images/releaf/input/input_bgr.gif +0 -0
- data/app/assets/images/releaf/language_root.png +0 -0
- data/app/assets/images/releaf/loader.gif +0 -0
- data/app/assets/images/releaf/logout.png +0 -0
- data/app/assets/images/releaf/main_menu/active_bgr.png +0 -0
- data/app/assets/images/releaf/main_menu/bgr.png +0 -0
- data/app/assets/images/releaf/main_menu/hover_bgr.png +0 -0
- data/app/assets/images/releaf/module.png +0 -0
- data/app/assets/images/releaf/panel_layout/active_bgr.png +0 -0
- data/app/assets/images/releaf/panel_layout/secondary_panel_horizontal_bgr.png +0 -0
- data/app/assets/images/releaf/panel_layout/secondary_panel_vertical_bgr.png +0 -0
- data/app/assets/images/releaf/releaf_table/selected_bgr.png +0 -0
- data/app/assets/images/releaf/releaf_table/th_bgr.gif +0 -0
- data/app/assets/javascripts/releaf/3rd_party/jquery-cookie/README.md +73 -0
- data/app/assets/javascripts/releaf/3rd_party/jquery-cookie/jquery.cookie.js +47 -0
- data/app/assets/javascripts/releaf/3rd_party/jquery-cookie/server.js +24 -0
- data/app/assets/javascripts/releaf/3rd_party/jquery-cookie/test.html +19 -0
- data/app/assets/javascripts/releaf/3rd_party/jquery-cookie/test.js +80 -0
- data/app/assets/javascripts/releaf/3rd_party/jquery-ui-timepicker-addon.js +1882 -0
- data/app/assets/javascripts/releaf/3rd_party/lightbox.js.erb +379 -0
- data/app/assets/javascripts/releaf/application.js +14 -0
- data/app/assets/javascripts/releaf/controllers/base.js +170 -0
- data/app/assets/javascripts/releaf/controllers/releaf/content.js +90 -0
- data/app/assets/javascripts/releaf/controllers/releaf/translations.js +31 -0
- data/app/assets/javascripts/releaf/include/continuous_scroll.js +321 -0
- data/app/assets/javascripts/releaf/include/field.type_autocomplete.js +58 -0
- data/app/assets/javascripts/releaf/include/field.type_richtext.js +90 -0
- data/app/assets/javascripts/releaf/include/localization.js +12 -0
- data/app/assets/javascripts/releaf/include/nested_fields.js +71 -0
- data/app/assets/javascripts/releaf/include/sortable.js +27 -0
- data/app/assets/javascripts/releaf/lib/request_url.js +183 -0
- data/app/assets/stylesheets/releaf/3rd_party/jquery-ui-1.9.2.custom.css.erb +464 -0
- data/app/assets/stylesheets/releaf/3rd_party/jquery-ui-timepicker-addon.css +10 -0
- data/app/assets/stylesheets/releaf/3rd_party/lightbox.css.erb +157 -0
- data/app/assets/stylesheets/releaf/application.css.erb +122 -0
- data/app/assets/stylesheets/releaf/controllers/base.css.erb +205 -0
- data/app/assets/stylesheets/releaf/controllers/releaf/content.css.erb +416 -0
- data/app/assets/stylesheets/releaf/controllers/releaf/sessions.css.scss.erb +116 -0
- data/app/assets/stylesheets/releaf/controllers/releaf/translations.css.erb +205 -0
- data/app/assets/stylesheets/releaf/include/button.css.erb +176 -0
- data/app/assets/stylesheets/releaf/include/field.css.erb +257 -0
- data/app/assets/stylesheets/releaf/include/input.css.erb +40 -0
- data/app/assets/stylesheets/releaf/include/main_menu.css.erb +66 -0
- data/app/assets/stylesheets/releaf/include/pagination.css.erb +29 -0
- data/app/assets/stylesheets/releaf/include/panel_layout.css.erb +251 -0
- data/app/assets/stylesheets/releaf/include/releaf_table.css.erb +112 -0
- data/app/assets/stylesheets/releaf/include/sortable.css.erb +12 -0
- data/app/controllers/releaf/admins_controller.rb +48 -0
- data/app/controllers/releaf/application_controller.rb +11 -0
- data/app/controllers/releaf/base_application_controller.rb +15 -0
- data/app/controllers/releaf/base_controller.rb +310 -0
- data/app/controllers/releaf/content_controller.rb +166 -0
- data/app/controllers/releaf/roles_controller.rb +36 -0
- data/app/controllers/releaf/sessions_controller.rb +5 -0
- data/app/controllers/releaf/tinymce_assets_controller.rb +26 -0
- data/app/controllers/releaf/translations_controller.rb +121 -0
- data/app/helpers/releaf/admin_helper.rb +79 -0
- data/app/helpers/releaf/application_helper.rb +4 -0
- data/app/helpers/releaf/pagination_renderer.rb +44 -0
- data/app/helpers/releaf/releaf_devise_helper.rb +8 -0
- data/app/models/releaf/admin.rb +51 -0
- data/app/models/releaf/node.rb +221 -0
- data/app/models/releaf/node_base.rb +25 -0
- data/app/models/releaf/role.rb +119 -0
- data/app/models/releaf/tinymce_asset.rb +6 -0
- data/app/views/layouts/releaf/admin.html.haml +51 -0
- data/app/views/releaf/aliases/_edit.body.haml +50 -0
- data/app/views/releaf/aliases/_edit.header.haml +19 -0
- data/app/views/releaf/aliases/_index.row.haml +5 -0
- data/app/views/releaf/aliases/_secondary_panel.haml +13 -0
- data/app/views/releaf/base/_edit.body.haml +19 -0
- data/app/views/releaf/base/_edit.field.haml +96 -0
- data/app/views/releaf/base/_edit.field.type_autocomplete.haml +15 -0
- data/app/views/releaf/base/_edit.field.type_checkbox.haml +5 -0
- data/app/views/releaf/base/_edit.field.type_date.haml +8 -0
- data/app/views/releaf/base/_edit.field.type_datetime.haml +8 -0
- data/app/views/releaf/base/_edit.field.type_delete_nested.haml +3 -0
- data/app/views/releaf/base/_edit.field.type_file.haml +10 -0
- data/app/views/releaf/base/_edit.field.type_image.haml +14 -0
- data/app/views/releaf/base/_edit.field.type_link.haml +4 -0
- data/app/views/releaf/base/_edit.field.type_password.haml +4 -0
- data/app/views/releaf/base/_edit.field.type_richtext.haml +4 -0
- data/app/views/releaf/base/_edit.field.type_richtext_i18n.haml +27 -0
- data/app/views/releaf/base/_edit.field.type_select.haml +11 -0
- data/app/views/releaf/base/_edit.field.type_text.haml +4 -0
- data/app/views/releaf/base/_edit.field.type_text_i18n.haml +27 -0
- data/app/views/releaf/base/_edit.field.type_textarea.haml +4 -0
- data/app/views/releaf/base/_edit.field.type_textarea_i18n.haml +27 -0
- data/app/views/releaf/base/_edit.field.type_time.haml +8 -0
- data/app/views/releaf/base/_edit.footer.haml +14 -0
- data/app/views/releaf/base/_edit.form.haml +4 -0
- data/app/views/releaf/base/_edit.has_many_associations.haml +45 -0
- data/app/views/releaf/base/_edit.header.haml +3 -0
- data/app/views/releaf/base/_index.body.haml +6 -0
- data/app/views/releaf/base/_index.cell.haml +19 -0
- data/app/views/releaf/base/_index.footer.haml +22 -0
- data/app/views/releaf/base/_index.header.haml +4 -0
- data/app/views/releaf/base/_index.row.haml +6 -0
- data/app/views/releaf/base/_index.search.haml +5 -0
- data/app/views/releaf/base/_index.table.haml +8 -0
- data/app/views/releaf/base/_secondary_panel.haml +9 -0
- data/app/views/releaf/base/_show.body.haml +7 -0
- data/app/views/releaf/base/_show.field.haml +78 -0
- data/app/views/releaf/base/_show.field.type_html.haml +1 -0
- data/app/views/releaf/base/_show.footer.haml +16 -0
- data/app/views/releaf/base/_show.header.haml +3 -0
- data/app/views/releaf/base/confirm_destroy.haml +10 -0
- data/app/views/releaf/base/edit.haml +1 -0
- data/app/views/releaf/base/index.haml +3 -0
- data/app/views/releaf/base/new.haml +1 -0
- data/app/views/releaf/base/show.haml +3 -0
- data/app/views/releaf/content/_edit.body.haml +45 -0
- data/app/views/releaf/content/_edit.content_fields.haml +19 -0
- data/app/views/releaf/content/_edit.slug.haml +12 -0
- data/app/views/releaf/content/_get_content_form.haml +7 -0
- data/app/views/releaf/content/_secondary_panel.haml +3 -0
- data/app/views/releaf/content/_show.field.content.haml +11 -0
- data/app/views/releaf/content/_tree_level.haml +16 -0
- data/app/views/releaf/content/ajax.new.haml +3 -0
- data/app/views/releaf/content/index.haml +0 -0
- data/app/views/releaf/roles/_edit.field.admins.haml +0 -0
- data/app/views/releaf/roles/_edit.field.permissions.haml +5 -0
- data/app/views/releaf/roles/_show.field.default.haml +6 -0
- data/app/views/releaf/roles/_show.field.permissions.haml +11 -0
- data/app/views/releaf/sessions/new.html.haml +17 -0
- data/app/views/releaf/translations/_edit.body.haml +50 -0
- data/app/views/releaf/translations/_edit.header.haml +19 -0
- data/app/views/releaf/translations/_index.row.haml +5 -0
- data/app/views/releaf/translations/_secondary_panel.haml +13 -0
- data/bin/releaf +25 -0
- data/lib/generators/releaf/install_generator.rb +87 -0
- data/lib/generators/releaf/templates/config/common_fields.yml.example +17 -0
- data/lib/generators/releaf/templates/controllers/home_controller.rb +4 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-bg_flat_75_ffffff_40x100.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-bg_glass_55_fbf9ee_1x400.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-bg_glass_75_dadada_1x400.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-bg_glass_75_e6e6e6_1x400.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-bg_glass_95_fef1ec_1x400.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-bg_highlight-soft_75_cccccc_1x100.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-icons_222222_256x240.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-icons_2e83ff_256x240.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-icons_454545_256x240.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-icons_888888_256x240.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/jquery_ui/smoothness/ui-icons_cd0a0a_256x240.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/lightbox/close.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/lightbox/loading.gif +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/lightbox/next.png +0 -0
- data/lib/generators/releaf/templates/images/3rd_party/lightbox/prev.png +0 -0
- data/lib/generators/releaf/templates/initializers/releaf.rb +59 -0
- data/lib/generators/releaf/templates/initializers/releaf_i18n.rb +8 -0
- data/lib/generators/releaf/templates/initializers/releaf_store_current_template.rb +25 -0
- data/lib/generators/releaf/templates/javascripts/3rd_party/jquery_ui.js +14850 -0
- data/lib/generators/releaf/templates/javascripts/3rd_party/lightbox.js.erb +379 -0
- data/lib/generators/releaf/templates/javascripts/application.js +15 -0
- data/lib/generators/releaf/templates/javascripts/lib/js_check.js +8 -0
- data/lib/generators/releaf/templates/javascripts/lib/request_url.js +169 -0
- data/lib/generators/releaf/templates/javascripts/lib/sortable.js +29 -0
- data/lib/generators/releaf/templates/migrations/create_releaf_admins.rb +53 -0
- data/lib/generators/releaf/templates/migrations/create_releaf_nodes.rb +25 -0
- data/lib/generators/releaf/templates/migrations/create_releaf_roles.rb +11 -0
- data/lib/generators/releaf/templates/migrations/create_releaf_tinymce_assets.rb +10 -0
- data/lib/generators/releaf/templates/migrations/create_releaf_translations.rb +31 -0
- data/lib/generators/releaf/templates/models/admin_ability.rb +51 -0
- data/lib/generators/releaf/templates/seeds.rb +64 -0
- data/lib/generators/releaf/templates/stylesheets/3rd_party/jquery_ui/smoothness.css.erb +1174 -0
- data/lib/generators/releaf/templates/stylesheets/3rd_party/lightbox.css.erb +157 -0
- data/lib/generators/releaf/templates/stylesheets/3rd_party/reset.css +48 -0
- data/lib/generators/releaf/templates/stylesheets/application.scss +15 -0
- data/lib/generators/releaf/templates/stylesheets/style.scss +45 -0
- data/lib/generators/releaf/templates/views/home/index.html.haml +1 -0
- data/lib/generators/releaf/templates/views/layouts/application.html.haml +26 -0
- data/lib/i18n/backend/releaf.rb +96 -0
- data/lib/i18n/backend/releaf/translation.rb +56 -0
- data/lib/i18n/backend/releaf/translation_data.rb +32 -0
- data/lib/i18n/backend/releaf/translation_group.rb +30 -0
- data/lib/i18n/releaf.rb +1 -0
- data/lib/releaf.rb +30 -0
- data/lib/releaf/engine.rb +4 -0
- data/lib/releaf/slug.rb +79 -0
- data/lib/releaf/version.rb +3 -0
- data/lib/tasks/releaf_tasks.rake +4 -0
- data/spec/dummy/README.rdoc +261 -0
- data/spec/dummy/Rakefile +7 -0
- data/spec/dummy/app/assets/images/rails.png +0 -0
- data/spec/dummy/app/assets/javascripts/application.js +15 -0
- data/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/models/admin_ability.rb +51 -0
- data/spec/dummy/app/models/settings.rb +2 -0
- data/spec/dummy/app/views/layouts/application.html.haml +10 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/config/application.rb +68 -0
- data/spec/dummy/config/boot.rb +6 -0
- data/spec/dummy/config/common_fields.yml.example +17 -0
- data/spec/dummy/config/database.yml +42 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +37 -0
- data/spec/dummy/config/environments/production.rb +67 -0
- data/spec/dummy/config/environments/test.rb +37 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/devise.rb +232 -0
- data/spec/dummy/config/initializers/dragonfly.rb +1 -0
- data/spec/dummy/config/initializers/inflections.rb +15 -0
- data/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/spec/dummy/config/initializers/releaf.rb +59 -0
- data/spec/dummy/config/initializers/releaf_i18n.rb +8 -0
- data/spec/dummy/config/initializers/releaf_store_current_template.rb +25 -0
- data/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/spec/dummy/config/initializers/session_store.rb +8 -0
- data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/spec/dummy/config/locales/devise.en.yml +58 -0
- data/spec/dummy/config/locales/en.yml +5 -0
- data/spec/dummy/config/routes.rb +11 -0
- data/spec/dummy/db/migrate/20130204164516_create_settings.rb +17 -0
- data/spec/dummy/db/migrate/20130204164523_create_releaf_nodes.rb +25 -0
- data/spec/dummy/db/migrate/20130204164524_create_releaf_roles.rb +11 -0
- data/spec/dummy/db/migrate/20130204164525_create_releaf_translations.rb +31 -0
- data/spec/dummy/db/migrate/20130204164526_create_releaf_admins.rb +53 -0
- data/spec/dummy/db/schema.rb +112 -0
- data/spec/dummy/db/seeds.rb +64 -0
- data/spec/dummy/doc/README_FOR_APP +2 -0
- data/spec/dummy/log/development.log +74 -0
- data/spec/dummy/log/test.log +129 -0
- data/spec/dummy/public/404.html +26 -0
- data/spec/dummy/public/422.html +26 -0
- data/spec/dummy/public/500.html +25 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/script/rails +6 -0
- data/spec/dummy/tmp/cache/9C5/660/settings%3Ai18n_updated_at +1 -0
- data/spec/factories/factories.rb +24 -0
- data/spec/features/admin_spec.rb +41 -0
- data/spec/spec_helper.rb +23 -0
- data/templates/releaf/installer.rb +196 -0
- metadata +777 -0
@@ -0,0 +1,10 @@
|
|
1
|
+
.body.outset_box
|
2
|
+
.question= t('confirm_destroy')
|
3
|
+
.description= @item
|
4
|
+
.buttons
|
5
|
+
= form_for @item, :url => url_for( :action => 'destroy', :id => @item.id ), :method => 'delete' do |f|
|
6
|
+
%button{ :type => 'submit' }
|
7
|
+
= image_tag 'releaf/icons/bin_empty.png', :alt => ''
|
8
|
+
%span= t('yes')
|
9
|
+
%a.button{ :href => url_for( :action => 'show', :id => @item.id ) }
|
10
|
+
%span= t('no')
|
@@ -0,0 +1 @@
|
|
1
|
+
= render "edit.form"
|
@@ -0,0 +1 @@
|
|
1
|
+
= render "edit.form"
|
@@ -0,0 +1,45 @@
|
|
1
|
+
.body.inset_box.no_shadow
|
2
|
+
- if f.object.new_record?
|
3
|
+
= f.hidden_field :parent_id, :value => params[:parent_id] || f.object.parent_id
|
4
|
+
|
5
|
+
|
6
|
+
.globalFieldContainer.collapsableSection.global_fields
|
7
|
+
= render 'edit.field', :name => 'name', :f => f
|
8
|
+
|
9
|
+
.field{ 'data-name' => 'template' }
|
10
|
+
.label_wrap
|
11
|
+
= f.label :content_type, 'Veids:', :title => f.object.content_type
|
12
|
+
.value
|
13
|
+
= f.select :content_type, options_for_select(@base_models.map { |m| m.name }, f.object.content_type || params[:content_type]), {:include_blank => f.object.new_record?}, {:title => @item.content_type, :disabled => f.object.new_record? == false }
|
14
|
+
.clear
|
15
|
+
|
16
|
+
|
17
|
+
= render 'edit.slug', :name => 'slug', :f => f
|
18
|
+
|
19
|
+
.field{ 'data-name' => 'position' }
|
20
|
+
.label_wrap= f.label :position, t('position') + ':'
|
21
|
+
.value
|
22
|
+
:ruby
|
23
|
+
opt_for_select = [[t('first'), 1]]
|
24
|
+
@order_nodes.each do |node|
|
25
|
+
# FIXME fix i18n usage
|
26
|
+
opt_for_select.push [ t('after') + ' ' + node.name, node.lower_item ? node.lower_item.position : node.position ]
|
27
|
+
end
|
28
|
+
|
29
|
+
= f.select :position, options_for_select(opt_for_select, @position)
|
30
|
+
.clear
|
31
|
+
|
32
|
+
= render 'edit.field', :name => 'visible', :f => f
|
33
|
+
= render 'edit.field', :name => 'protected', :f => f
|
34
|
+
.clear
|
35
|
+
|
36
|
+
|
37
|
+
%button.no_styling.toggleSection.collapse{:title => "Saīsināt sadaļu", :type => "button"}
|
38
|
+
= image_tag("releaf/icons/130.png", :alt => "Saīsināt sadaļu")
|
39
|
+
%button.no_styling.toggleSection.expand{:title => "Parādīt pilnu sadaļu", :type => "button"}
|
40
|
+
= image_tag("releaf/icons/129.png", :alt => "Parādīt pilnu sadaļu")
|
41
|
+
.clear.persistent
|
42
|
+
|
43
|
+
- if f.object.content
|
44
|
+
= render 'edit.content_fields', :f => f
|
45
|
+
|
@@ -0,0 +1,19 @@
|
|
1
|
+
.nested_object
|
2
|
+
- f.object.common_field_names.each do |common_field_name|
|
3
|
+
- if @controller.has_template( "_edit.field.#{common_field_name}" )
|
4
|
+
= render "edit.field.#{common_field_name}", :name => common_field_name, :f => f
|
5
|
+
- else
|
6
|
+
= render 'edit.field', :name => common_field_name, :f => f
|
7
|
+
|
8
|
+
|
9
|
+
|
10
|
+
= f.fields_for :content_object, f.object.content_object do |ff|
|
11
|
+
|
12
|
+
- (ff.object.class.column_names - %w[id created_at updated_at]).each do |name|
|
13
|
+
- if @controller.has_template( "_edit.field.#{name}" )
|
14
|
+
= render "edit.field.#{name}", :name => name, :f => ff
|
15
|
+
- else
|
16
|
+
= render 'edit.field', :name => name, :f => ff
|
17
|
+
|
18
|
+
|
19
|
+
= render 'edit.has_many_associations', :f => ff
|
@@ -0,0 +1,12 @@
|
|
1
|
+
.field.type_text{ 'data-name' => name }
|
2
|
+
.label_wrap><= f.label name, name.humanize + ':'
|
3
|
+
.value><
|
4
|
+
= f.text_field name
|
5
|
+
%button.no_styling.generate_slug{:type => 'button', :'data-new_slug_url' => generate_url_releaf_nodes_path(:parent_id => f.object.parent_id, :id => f.object.id), :title => t('.suggest_slug', :rescue_format => false)}><
|
6
|
+
= image_tag('releaf/icons/keyboard.png', :alt => t('.suggest_slug', :rescue_format => false))
|
7
|
+
.object_url><
|
8
|
+
%a{:href => "/#{f.object.url}"}
|
9
|
+
= "#{request.protocol}#{request.host_with_port}/#{f.object.parent.try(:url)}/"
|
10
|
+
%span><= f.object.slug
|
11
|
+
= "/"
|
12
|
+
.clear
|
@@ -0,0 +1,7 @@
|
|
1
|
+
= fields_for "#{@controller.current_object_class_name}[content_attributes]", @item do |ff|
|
2
|
+
|
3
|
+
- (ff.object.class.column_names - %w[id created_at updated_at]).each do |name|
|
4
|
+
- if @controller.has_template( "_edit.field.#{name}" )
|
5
|
+
= render "edit.field.#{name}", :name => name, :f => ff
|
6
|
+
- else
|
7
|
+
= render 'edit.field', :name => name, :f => ff
|
@@ -0,0 +1,11 @@
|
|
1
|
+
- old_item = @item
|
2
|
+
|
3
|
+
- @item = @item.content
|
4
|
+
|
5
|
+
- (@item.class.column_names - %w[id created_at]).each do |name|
|
6
|
+
- if @controller.has_template( "_show.field.#{name}" )
|
7
|
+
= render "show.field.#{name}", :name => name
|
8
|
+
- else
|
9
|
+
= render 'show.field', :name => name
|
10
|
+
|
11
|
+
- @item = old_item
|
@@ -0,0 +1,16 @@
|
|
1
|
+
%ul.block
|
2
|
+
- nodes.each do |node|
|
3
|
+
%li
|
4
|
+
.node{ :style => "background-color:rgba(188,224,178,#{[ 1-level.to_f/10, 0.3 ].max});", :class => params[:id].to_i == node.id ? :active : nil }
|
5
|
+
%a.create{:href => url_for(:action => :new, :parent_id => node.id)}><
|
6
|
+
= image_tag("releaf/add.png")
|
7
|
+
%input{:name => "ids[]", :type => "checkbox", :value => node.id}/
|
8
|
+
- if node.children.empty?
|
9
|
+
.toggle{:style => "margin-left:#{15*level}px;"}><
|
10
|
+
- else
|
11
|
+
%button.no_styling.toggle.open{"data-id" => node.id, :type => "button", :style => "margin-left:#{15*level}px;"}>< Toggle
|
12
|
+
%a.edit{:href => url_for(:action => :edit, :id => node.id), :title => node.url, :style=> "left: #{43+15*level}px;"}><
|
13
|
+
= image_tag "releaf/language_root.png", :alt => ''
|
14
|
+
%span= node.name
|
15
|
+
- if !node.children.empty?
|
16
|
+
= render 'tree_level', :nodes => node.children, :level => level + 1
|
File without changes
|
File without changes
|
@@ -0,0 +1,5 @@
|
|
1
|
+
- AdminAbility::PERMISSIONS.each do |permissions|
|
2
|
+
- if permissions.is_a? String
|
3
|
+
= render 'edit.field.type_checkbox', :name => "#{permissions}_permission", :f => f
|
4
|
+
- elsif permissions.is_a? Array
|
5
|
+
= render 'edit.field.type_select', :name => "#{permissions[0]}_permissions", :select_options => permissions[1], :f => f
|
@@ -0,0 +1,11 @@
|
|
1
|
+
- AdminAbility::PERMISSIONS.each do |permissions|
|
2
|
+
- if permissions.is_a? String
|
3
|
+
.field.no_label_wrap_padding
|
4
|
+
.label_wrap
|
5
|
+
.label Manage #{permissions}:
|
6
|
+
.value_wrap= @item.send(:"#{permissions}_permission")
|
7
|
+
- elsif permissions.is_a? Array
|
8
|
+
.field.no_label_wrap_padding
|
9
|
+
.label_wrap
|
10
|
+
.label #{permissions[0]} permissions:
|
11
|
+
.value_wrap= @item.send(:"#{permissions[0]}_permissions")
|
@@ -0,0 +1,17 @@
|
|
1
|
+
.login_form_container
|
2
|
+
= form_for(resource, :as => resource_name, :url => session_path(resource_name), :html => { :class => "login_form" } ) do |f|
|
3
|
+
.logo_container
|
4
|
+
= image_tag("releaf/controllers/#{controller.controller_name}/logo.jpg")
|
5
|
+
.inputs
|
6
|
+
%label.login
|
7
|
+
%span Email:
|
8
|
+
= f.email_field :email, :autofocus => "autofocus"
|
9
|
+
%label
|
10
|
+
%span Password:
|
11
|
+
= f.password_field :password
|
12
|
+
.actions
|
13
|
+
%button{:type => "submit"} Sign in
|
14
|
+
%div.copy
|
15
|
+
%span © 2012-#{Time.now.year} CubeSystems
|
16
|
+
|
|
17
|
+
= link_to "www.cubesystems.lv", "http://cubesystems.lv"
|
@@ -0,0 +1,50 @@
|
|
1
|
+
.body.inset_box.no_shadow
|
2
|
+
|
3
|
+
-#TODO: improve style/html
|
4
|
+
-if f.object.errors.any?
|
5
|
+
#error_explanation
|
6
|
+
%strong= "#{pluralize(f.object.errors.count, "error")} prohibited this news from being saved:"
|
7
|
+
%ul
|
8
|
+
- f.object.errors.full_messages.each do |msg|
|
9
|
+
%li= msg
|
10
|
+
|
11
|
+
.nested_wrap
|
12
|
+
%table.releaf_table.no_border.label_first_column.translations.translations_table.list{:cellpadding => "0", :cellspacing => "0"}
|
13
|
+
%thead
|
14
|
+
%tr
|
15
|
+
%th.code_header Nosaukums
|
16
|
+
- Settings.i18n_locales.each do |locale|
|
17
|
+
%th.language_header{"data-locale" => locale}
|
18
|
+
%span.name= locale
|
19
|
+
%th.delete_header
|
20
|
+
%tbody#variables.list
|
21
|
+
- f.object.translations.each do |translation|
|
22
|
+
%tr.item{ :id => "translation_#{translation.id}" }
|
23
|
+
%td.translation_name.codeColumn
|
24
|
+
.wrap
|
25
|
+
%input{:type=>"hidden", :name=>"translations[#{translation.id}][id]", :value=>"#{translation.id}"}/
|
26
|
+
%input{:type=>"text", :name=>"translations[#{translation.id}][key]", :value=>"#{translation.plain_key}"}/
|
27
|
+
- Settings.i18n_locales.each do |locale|
|
28
|
+
|
29
|
+
%td.translationCell{"data-locale" => locale}
|
30
|
+
.wrap
|
31
|
+
%input{:type=>"text", :name=>"translations[#{translation.id}][localization][#{locale}]", :value=>translation.locales[locale]}/
|
32
|
+
%td.delete_column
|
33
|
+
%span.remove= image_tag("releaf/icons/delete.png", :alt => "delete", :title => :delete)
|
34
|
+
|
35
|
+
%table{:style => "display:none;"}
|
36
|
+
%tbody
|
37
|
+
%tr.template.item{:id => "translation__template_" }
|
38
|
+
%td.translation_name.codeColumn
|
39
|
+
.wrap
|
40
|
+
%input{:type=>"text", :name=>"translations[_template_][key]", :value=>""}/
|
41
|
+
- Settings.i18n_locales.each do |locale|
|
42
|
+
%td.translationCell{"data-locale" => locale}
|
43
|
+
.wrap
|
44
|
+
%input{:type=>"text", :name=>"translations[_template_][localization][#{locale}]", :value=>""}/
|
45
|
+
%td.delete_column
|
46
|
+
%span.remove= image_tag("releaf/icons/delete.png", :alt => "delete", :title => :delete)
|
47
|
+
|
48
|
+
%button.add.new(type='button')
|
49
|
+
= image_tag 'releaf/icons/add.png', :atl => ''
|
50
|
+
%span New
|
@@ -0,0 +1,19 @@
|
|
1
|
+
.visibleLanguagesSwitch
|
2
|
+
%button{:type => "button"}
|
3
|
+
Redzamās valodas
|
4
|
+
=image_tag("releaf/expand_tool/close_hover_shim.png", :alt => "")
|
5
|
+
%ul.block
|
6
|
+
- Settings.i18n_locales.each do |locale|
|
7
|
+
%li
|
8
|
+
%label
|
9
|
+
.header
|
10
|
+
.padding
|
11
|
+
.groupInfo
|
12
|
+
.field
|
13
|
+
%label{:for => "context"} Konteksts:
|
14
|
+
%input#context{:name => "translation_group[scope]", :size => "50", :type => "text", :value => @item.scope}/
|
15
|
+
.translations_table.translations_table_head
|
16
|
+
.th.code_header{:style => "width: 208px; "}>< Nosaukums
|
17
|
+
- Settings.i18n_locales.each do |locale|
|
18
|
+
.th.language_header.languageId-1.languageCode-lv{"data-languagecode" => locale, "data-languageid" => "1", :style => "width: 300px; "}><
|
19
|
+
%span.name= locale
|
@@ -0,0 +1,13 @@
|
|
1
|
+
.inner.standard_submenu
|
2
|
+
%ul.block
|
3
|
+
%li
|
4
|
+
.section_title= t('translations')
|
5
|
+
%ul
|
6
|
+
%li{:class=> params[:id].blank? ? "active" : ""}
|
7
|
+
%a{:href => releaf_translation_groups_path}= t('all_translations')
|
8
|
+
%li
|
9
|
+
.section_title= t('groups')
|
10
|
+
%ul
|
11
|
+
- @groups.each do |group|
|
12
|
+
%li{:class=> !params[:id].blank? && params[:id].to_i == group.id ? "active" : ""}
|
13
|
+
%a{:href => edit_releaf_translation_group_path(group.id)}= group.scope
|
data/bin/releaf
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
gem 'railties'
|
3
|
+
require 'rails/generators'
|
4
|
+
require 'rails/generators/rails/app/app_generator'
|
5
|
+
template_path = File.expand_path('../../templates/releaf/installer.rb', __FILE__)
|
6
|
+
|
7
|
+
if ARGV.size == 0 || ARGV[0] == "--help"
|
8
|
+
puts "Usage:"
|
9
|
+
puts " releaf APP_NAME [options]"
|
10
|
+
puts ""
|
11
|
+
puts "Options:"
|
12
|
+
# Support when running locally
|
13
|
+
relative_path = File.expand_path('../../lib/generators/releaf/install_generator.rb', __FILE__)
|
14
|
+
require relative_path
|
15
|
+
Releaf::Generators::InstallGenerator.class_options.each do |raw, option|
|
16
|
+
dasherized = "--#{option.name.to_s.gsub('_', '-')}"
|
17
|
+
dasherized = [option.aliases, "[#{dasherized}]"].flatten.join(', ') if option.aliases.any?
|
18
|
+
puts " #{dasherized}".ljust(28) << "# #{option.description}"
|
19
|
+
end
|
20
|
+
exit 0
|
21
|
+
end
|
22
|
+
|
23
|
+
application_name = ARGV.shift
|
24
|
+
|
25
|
+
result = Rails::Generators::AppGenerator.start [application_name, '-m', template_path, '--skip-gemfile', '--skip-bundle', '--database=mysql', '--skip-test-unit'] | ARGV
|
@@ -0,0 +1,87 @@
|
|
1
|
+
module Releaf
|
2
|
+
module Generators
|
3
|
+
class InstallGenerator < Rails::Generators::Base
|
4
|
+
include Rails::Generators::Migration
|
5
|
+
|
6
|
+
class_option :rvm, :type => :boolean, :aliases => nil, :group => :runtime, :default => true,
|
7
|
+
:desc => "Install with rvm gemset support"
|
8
|
+
|
9
|
+
def self.next_migration_number(path)
|
10
|
+
unless @prev_migration_nr
|
11
|
+
@prev_migration_nr = Time.now.utc.strftime("%Y%m%d%H%M%S").to_i
|
12
|
+
else
|
13
|
+
@prev_migration_nr += 1
|
14
|
+
end
|
15
|
+
@prev_migration_nr.to_s
|
16
|
+
end
|
17
|
+
|
18
|
+
source_root File.expand_path('../templates', __FILE__)
|
19
|
+
|
20
|
+
def install_initializer
|
21
|
+
copy_files 'initializers', 'config/initializers'
|
22
|
+
end
|
23
|
+
|
24
|
+
def install_migrations
|
25
|
+
get_file_list('migrations').each do |migration|
|
26
|
+
migration_template "migrations/#{migration}", "db/migrate/#{migration}"
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
def install_seeds
|
31
|
+
copy_file "seeds.rb", "db/seeds.rb"
|
32
|
+
end
|
33
|
+
|
34
|
+
def install_models
|
35
|
+
copy_files 'models', 'app/models'
|
36
|
+
end
|
37
|
+
|
38
|
+
def install_configs
|
39
|
+
copy_files 'config', 'config'
|
40
|
+
end
|
41
|
+
|
42
|
+
def install_views
|
43
|
+
copy_files 'views', 'app/views'
|
44
|
+
end
|
45
|
+
|
46
|
+
def install_controllers
|
47
|
+
copy_files 'controllers', 'app/controllers'
|
48
|
+
end
|
49
|
+
|
50
|
+
def install_stylesheets
|
51
|
+
copy_files 'stylesheets', 'app/assets/stylesheets'
|
52
|
+
end
|
53
|
+
|
54
|
+
def install_javascripts
|
55
|
+
copy_files 'javascripts', 'app/assets/javascripts'
|
56
|
+
end
|
57
|
+
|
58
|
+
def install_images
|
59
|
+
copy_files 'images', 'app/assets/images'
|
60
|
+
end
|
61
|
+
|
62
|
+
private
|
63
|
+
|
64
|
+
def copy_files subdir, dest_dir
|
65
|
+
raise ArgumEnterror unless subdir.is_a? String
|
66
|
+
raise ArgumEnterror unless dest_dir.is_a? String
|
67
|
+
raise ArgumetnError if subdir.blank?
|
68
|
+
raise ArgumetnError if dest_dir.blank?
|
69
|
+
|
70
|
+
get_file_list(subdir).each do |image|
|
71
|
+
copy_file [subdir, image].join('/'), [dest_dir, image].join('/')
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
def get_file_list subdir
|
76
|
+
raise ArgumentError unless subdir.is_a? String
|
77
|
+
raise ArgumetnError if subdir.blank?
|
78
|
+
dir = File.dirname(__FILE__)
|
79
|
+
search_path = [dir, 'templates', subdir].join('/') + '/'
|
80
|
+
file_list = Dir.glob(search_path + '**/*').map { |filename| File.directory?(filename) ? nil : filename.sub(search_path, '') }
|
81
|
+
file_list.delete nil
|
82
|
+
return file_list
|
83
|
+
end
|
84
|
+
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
-
|
2
|
+
field_name: seo_title
|
3
|
+
field_type: string
|
4
|
+
default: test
|
5
|
+
apply_to: ['Text', 'HomeController']
|
6
|
+
apply_to:
|
7
|
+
- Text
|
8
|
+
- HomeController
|
9
|
+
deny_to:
|
10
|
+
- Text
|
11
|
+
levels: [1,2,3]
|
12
|
+
|
13
|
+
-
|
14
|
+
field_name: seo_description
|
15
|
+
field_type: text
|
16
|
+
default: example_default_value
|
17
|
+
apply_to:
|