sunrise-core 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/README.rdoc +46 -0
- data/Rakefile +44 -0
- data/app/controllers/manage/assets_controller.rb +70 -0
- data/app/controllers/manage/base_controller.rb +24 -0
- data/app/controllers/manage/pages_controller.rb +37 -0
- data/app/controllers/manage/settings_controller.rb +24 -0
- data/app/controllers/manage/structures_controller.rb +45 -0
- data/app/controllers/manage/users_controller.rb +78 -0
- data/app/controllers/pages_controller.rb +22 -0
- data/app/views/layouts/manage.html.erb +40 -0
- data/app/views/manage/assets/_collection.html.erb +32 -0
- data/app/views/manage/assets/_picture.html.erb +10 -0
- data/app/views/manage/assets/_swfscript.html.erb +51 -0
- data/app/views/manage/headers/_form.html.erb +14 -0
- data/app/views/manage/pages/_form.html.erb +11 -0
- data/app/views/manage/pages/edit.html.erb +6 -0
- data/app/views/manage/pages/new.html.erb +6 -0
- data/app/views/manage/settings/_form.html.erb +22 -0
- data/app/views/manage/settings/index.html.erb +14 -0
- data/app/views/manage/shared/_head.html.erb +41 -0
- data/app/views/manage/shared/_locale.html.erb +8 -0
- data/app/views/manage/shared/_notice.html.erb +7 -0
- data/app/views/manage/shared/_panel.html.erb +34 -0
- data/app/views/manage/structures/_form.html.erb +28 -0
- data/app/views/manage/structures/_structure.html.erb +34 -0
- data/app/views/manage/structures/edit.html.erb +6 -0
- data/app/views/manage/structures/index.html.erb +51 -0
- data/app/views/manage/structures/new.html.erb +6 -0
- data/app/views/manage/users/_form.html.erb +15 -0
- data/app/views/manage/users/_model_filter.html.erb +33 -0
- data/app/views/manage/users/_user.html.erb +55 -0
- data/app/views/manage/users/edit.html.erb +6 -0
- data/app/views/manage/users/index.html.erb +36 -0
- data/app/views/manage/users/new.html.erb +6 -0
- data/app/views/manage/users/show.html.erb +19 -0
- data/config/locales/defaults/en.yml +149 -0
- data/config/locales/defaults/pluralize.rb +6 -0
- data/config/locales/defaults/ru.yml +170 -0
- data/config/locales/defaults/uk.yml +238 -0
- data/config/locales/devise.en.yml +39 -0
- data/config/locales/devise.ru.yml +41 -0
- data/config/locales/devise.uk.yml +41 -0
- data/config/locales/manage/en.yml +248 -0
- data/config/locales/manage/ru.yml +248 -0
- data/config/locales/manage/uk.yml +248 -0
- data/config/routes.rb +24 -0
- data/lib/generators/sunrise/USAGE +7 -0
- data/lib/generators/sunrise/install_generator.rb +120 -0
- data/lib/generators/sunrise/templates/config/application.yml +4 -0
- data/lib/generators/sunrise/templates/config/database.yml +34 -0
- data/lib/generators/sunrise/templates/config/logrotate-config +9 -0
- data/lib/generators/sunrise/templates/config/nginx-config-passenger +51 -0
- data/lib/generators/sunrise/templates/config/seeds.rb +25 -0
- data/lib/generators/sunrise/templates/config/sunrise.rb +7 -0
- data/lib/generators/sunrise/templates/helpers/manage/assets_helper.rb +16 -0
- data/lib/generators/sunrise/templates/helpers/manage/base_helper.rb +81 -0
- data/lib/generators/sunrise/templates/helpers/manage/pages_helper.rb +2 -0
- data/lib/generators/sunrise/templates/helpers/manage/settings_helper.rb +2 -0
- data/lib/generators/sunrise/templates/helpers/manage/structures_helper.rb +12 -0
- data/lib/generators/sunrise/templates/helpers/manage/users_helper.rb +6 -0
- data/lib/generators/sunrise/templates/images/manage/add_post_bot.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/add_post_top.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/add_white_bot.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/add_white_top.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/arrow.png +0 -0
- data/lib/generators/sunrise/templates/images/manage/back_but_lc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/back_but_rc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/bot_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/bot_duo_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_bg.png +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_block_lc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_block_rc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_freze_lc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_freze_rc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_gr.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_gr_l.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_gr_r.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_search.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_unfreze_lc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/but_unfreze_rc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/button_add_foto.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/button_add_foto_ru.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/button_add_foto_ua.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/button_add_foto_uk.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/cancelbutton.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/dark_arr.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/dark_arr_left.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/dark_cross_ico.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/dot.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bg_small.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bg_small_blocked.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bg_small_frozed.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bg_small_notact.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bot_small.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bot_small_blocked.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bot_small_frozed.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_bot_small_notact.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_top_small.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_top_small_blocked.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_top_small_frozed.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/duo_top_small_notact.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/edit_white_top.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/empty.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/filter_bot_bg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/filter_top_bg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/flag_en.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/flag_en_nonact.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/flag_ru.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/flag_ru_nonact.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/flag_ua.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/flag_ua_nonact.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/foto.jpg +0 -0
- data/lib/generators/sunrise/templates/images/manage/ico_add.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/ico_del.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/ico_down.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/ico_edit.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/ico_settings.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/ico_up.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/input_bg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/l_but_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/minimise_but.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/mp3.png +0 -0
- data/lib/generators/sunrise/templates/images/manage/page_arr_hover.png +0 -0
- data/lib/generators/sunrise/templates/images/manage/page_next_arr.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/page_num_hover.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/page_prev_arr.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/panel/l_but_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/panel/maximise_but.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/panel/r_but_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/panel/top_menu_arr.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/panel/user_pic.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/preloader.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/r_but_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/select_bg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/select_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/struct_corn_lg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/struct_corn_llg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/struct_corn_lw.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/struct_corn_rg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/struct_corn_rlg.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/struct_corn_rw.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/tab_gl.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/tab_gr.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/tab_wl.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/tab_wr.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/top_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/top_duo_corn.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/top_menu_arr.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/transp_cross.png +0 -0
- data/lib/generators/sunrise/templates/images/manage/upload_progress.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/user_act_lc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/user_act_rc.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/user_ico.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/user_pic.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/user_pic_small.gif +0 -0
- data/lib/generators/sunrise/templates/images/manage/user_pic_thumb.gif +0 -0
- data/lib/generators/sunrise/templates/javascripts/datepicker/jquery-ui-i18n.js +1176 -0
- data/lib/generators/sunrise/templates/javascripts/datepicker/jquery.ui.datepicker-ru.js +37 -0
- data/lib/generators/sunrise/templates/javascripts/datepicker/jquery.ui.datepicker-uk.js +37 -0
- data/lib/generators/sunrise/templates/javascripts/jquery-ui-timepicker-addon.js +911 -0
- data/lib/generators/sunrise/templates/javascripts/jquery.cookie.js +97 -0
- data/lib/generators/sunrise/templates/javascripts/jquery.fancybox-1.3.4.pack.js +46 -0
- data/lib/generators/sunrise/templates/javascripts/jquery.tmpl.min.js +10 -0
- data/lib/generators/sunrise/templates/javascripts/manage.js +290 -0
- data/lib/generators/sunrise/templates/javascripts/preloader.js +47 -0
- data/lib/generators/sunrise/templates/javascripts/swfupload/fileprogress.js +114 -0
- data/lib/generators/sunrise/templates/javascripts/swfupload/handlers.js +164 -0
- data/lib/generators/sunrise/templates/javascripts/swfupload/swfupload.js +1134 -0
- data/lib/generators/sunrise/templates/javascripts/swfupload/swfupload.queue.js +98 -0
- data/lib/generators/sunrise/templates/javascripts/swfupload/swfupload.swf +0 -0
- data/lib/generators/sunrise/templates/migrate/create_assets.rb +28 -0
- data/lib/generators/sunrise/templates/migrate/create_headers.rb +20 -0
- data/lib/generators/sunrise/templates/migrate/create_pages.rb +17 -0
- data/lib/generators/sunrise/templates/migrate/create_roles.rb +16 -0
- data/lib/generators/sunrise/templates/migrate/create_structures.rb +27 -0
- data/lib/generators/sunrise/templates/migrate/create_users.rb +29 -0
- data/lib/generators/sunrise/templates/models/defaults/ability.rb +38 -0
- data/lib/generators/sunrise/templates/models/defaults/asset.rb +7 -0
- data/lib/generators/sunrise/templates/models/defaults/attachment_file.rb +33 -0
- data/lib/generators/sunrise/templates/models/defaults/avatar.rb +36 -0
- data/lib/generators/sunrise/templates/models/defaults/header.rb +5 -0
- data/lib/generators/sunrise/templates/models/defaults/page.rb +5 -0
- data/lib/generators/sunrise/templates/models/defaults/picture.rb +34 -0
- data/lib/generators/sunrise/templates/models/defaults/position_type.rb +7 -0
- data/lib/generators/sunrise/templates/models/defaults/role.rb +20 -0
- data/lib/generators/sunrise/templates/models/defaults/role_type.rb +8 -0
- data/lib/generators/sunrise/templates/models/defaults/structure.rb +11 -0
- data/lib/generators/sunrise/templates/models/defaults/structure_type.rb +9 -0
- data/lib/generators/sunrise/templates/models/defaults/user.rb +51 -0
- data/lib/generators/sunrise/templates/stylesheets/application.css +1 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/blank.gif +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_close.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_loading.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_nav_left.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_nav_right.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_shadow_e.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_shadow_n.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_shadow_ne.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_shadow_nw.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_shadow_s.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_shadow_se.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_shadow_sw.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_shadow_w.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_title_left.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_title_main.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_title_over.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancy_title_right.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancybox-x.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancybox-y.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/images/fancybox.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/fancybox/jquery.fancybox-1.3.4.css +359 -0
- data/lib/generators/sunrise/templates/stylesheets/manage/ie.css +16 -0
- data/lib/generators/sunrise/templates/stylesheets/manage/main.css +1074 -0
- data/lib/generators/sunrise/templates/stylesheets/manage/panel.css +126 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-bg_flat_75_ffffff_40x100.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-bg_glass_55_fbf9ee_1x400.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-bg_glass_75_dadada_1x400.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-bg_glass_75_e6e6e6_1x400.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-bg_glass_95_fef1ec_1x400.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-bg_highlight-soft_75_cccccc_1x100.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-icons_222222_256x240.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-icons_2e83ff_256x240.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-icons_454545_256x240.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-icons_888888_256x240.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/images/ui-icons_cd0a0a_256x240.png +0 -0
- data/lib/generators/sunrise/templates/stylesheets/smoothness/jquery-ui-1.8.6.custom.css +572 -0
- data/lib/generators/sunrise/templates/sweepers/page_sweeper.rb +22 -0
- data/lib/generators/sunrise/templates/sweepers/structure_sweeper.rb +29 -0
- data/lib/generators/sunrise/templates/sweepers/user_sweeper.rb +17 -0
- data/lib/generators/sunrise/templates/views/layouts/application.html.erb +37 -0
- data/lib/generators/sunrise/templates/views/pages/show.html.erb +2 -0
- data/lib/generators/sunrise/templates/views/shared/_notice.html.erb +17 -0
- data/lib/sunrise/controllers/head_options.rb +40 -0
- data/lib/sunrise/core.rb +80 -0
- data/lib/sunrise/core_ext/array.rb +22 -0
- data/lib/sunrise/core_ext/i18n.rb +21 -0
- data/lib/sunrise/core_ext/string.rb +28 -0
- data/lib/sunrise/core_ext.rb +3 -0
- data/lib/sunrise/core_plugins.rb +32 -0
- data/lib/sunrise/engine.rb +45 -0
- data/lib/sunrise/model_filter.rb +158 -0
- data/lib/sunrise/models/asset.rb +102 -0
- data/lib/sunrise/models/header.rb +34 -0
- data/lib/sunrise/models/page.rb +27 -0
- data/lib/sunrise/models/position_type.rb +15 -0
- data/lib/sunrise/models/role.rb +28 -0
- data/lib/sunrise/models/role_type.rb +15 -0
- data/lib/sunrise/models/structure.rb +43 -0
- data/lib/sunrise/models/structure_type.rb +15 -0
- data/lib/sunrise/models/user.rb +124 -0
- data/lib/sunrise/plugin.rb +46 -0
- data/lib/sunrise/plugins.rb +56 -0
- data/lib/sunrise/system_settings.rb +65 -0
- data/lib/sunrise/utils/accessible_attributes.rb +32 -0
- data/lib/sunrise/utils/header.rb +29 -0
- data/lib/sunrise/utils/i18n_backend.rb +87 -0
- data/lib/sunrise/utils/mysql.rb +105 -0
- data/lib/sunrise/utils/settingslogic.rb +164 -0
- data/lib/sunrise/utils/transliteration.rb +72 -0
- data/lib/sunrise/version.rb +3 -0
- data/lib/sunrise/views/form_builder.rb +44 -0
- data/lib/sunrise/views/helpers.rb +190 -0
- data/lib/sunrise/views/inputs/date_time_input.rb +46 -0
- data/lib/sunrise-core.rb +2 -0
- metadata +492 -0
data/README.rdoc
ADDED
@@ -0,0 +1,46 @@
|
|
1
|
+
= SunRise CMS
|
2
|
+
|
3
|
+
== Install
|
4
|
+
|
5
|
+
gem 'inherited_resources'
|
6
|
+
gem 'paperclip'
|
7
|
+
gem 'mime-types'
|
8
|
+
gem 'kaminari'
|
9
|
+
gem 'cancan'
|
10
|
+
gem 'cancan_namespace'
|
11
|
+
gem 'devise'
|
12
|
+
gem 'simple_form'
|
13
|
+
gem 'ckeditor', '3.5.2'
|
14
|
+
|
15
|
+
gem 'enum_field', :git => 'git://github.com/galetahub/enum_field.git'
|
16
|
+
gem 'awesome_nested_set', :git => 'git://github.com/galetahub/awesome_nested_set.git'
|
17
|
+
gem 'salty_slugs', :git => 'git://github.com/galetahub/salty_slugs.git'
|
18
|
+
gem 'attach_file_field', :git => 'git://github.com/galetahub/attach_file_field.git'
|
19
|
+
|
20
|
+
gem 'sunrise'
|
21
|
+
|
22
|
+
rails generate sunrise:install
|
23
|
+
|
24
|
+
Feature for Rails 3.1: copy migrations from all plugins, engins:
|
25
|
+
|
26
|
+
rake railties:install:migrations
|
27
|
+
|
28
|
+
Generate devise configurations:
|
29
|
+
|
30
|
+
rails generate devise:install
|
31
|
+
|
32
|
+
Generate simple_form configurations:
|
33
|
+
|
34
|
+
rails generate simple_form:install
|
35
|
+
|
36
|
+
Generate attach_file_field assets:
|
37
|
+
|
38
|
+
rails generate attach_file_field
|
39
|
+
|
40
|
+
Migrate database:
|
41
|
+
|
42
|
+
rake db:migrate
|
43
|
+
|
44
|
+
Autoload generated models in application.rb:
|
45
|
+
|
46
|
+
config.autoload_paths += %W(#{config.root}/app/models/defaults #{config.root}/app/sweepers)
|
data/Rakefile
ADDED
@@ -0,0 +1,44 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
require 'rake'
|
3
|
+
require 'rake/testtask'
|
4
|
+
require 'rake/rdoctask'
|
5
|
+
require File.join(File.dirname(__FILE__), 'lib', 'sunrise', 'version')
|
6
|
+
|
7
|
+
desc 'Default: run unit tests.'
|
8
|
+
task :default => :test
|
9
|
+
|
10
|
+
desc 'Test the sunrise plugin.'
|
11
|
+
Rake::TestTask.new(:test) do |t|
|
12
|
+
t.libs << 'lib'
|
13
|
+
t.libs << 'test'
|
14
|
+
t.pattern = 'test/**/*_test.rb'
|
15
|
+
t.verbose = true
|
16
|
+
end
|
17
|
+
|
18
|
+
desc 'Generate documentation for the sunrise plugin.'
|
19
|
+
Rake::RDocTask.new(:rdoc) do |rdoc|
|
20
|
+
rdoc.rdoc_dir = 'rdoc'
|
21
|
+
rdoc.title = 'Sunrise Core'
|
22
|
+
rdoc.options << '--line-numbers' << '--inline-source'
|
23
|
+
rdoc.rdoc_files.include('README')
|
24
|
+
rdoc.rdoc_files.include('lib/**/*.rb')
|
25
|
+
end
|
26
|
+
|
27
|
+
begin
|
28
|
+
require 'jeweler'
|
29
|
+
Jeweler::Tasks.new do |s|
|
30
|
+
s.name = "sunrise-core"
|
31
|
+
s.version = Sunrise::VERSION.dup
|
32
|
+
s.summary = "Rails CMS"
|
33
|
+
s.description = "Sunrise is a Aimbulance CMS"
|
34
|
+
s.email = "galeta.igor@gmail.com"
|
35
|
+
s.homepage = "https://github.com/galetahub/sunrise-core"
|
36
|
+
s.authors = ["Igor Galeta", "Pavlo Galeta"]
|
37
|
+
s.files = FileList["[A-Z]*", "{app,config,lib}/**/*"] - %w(Gemfile Gemfile.lock)
|
38
|
+
#s.extra_rdoc_files = FileList["[A-Z]*"]
|
39
|
+
end
|
40
|
+
|
41
|
+
Jeweler::GemcutterTasks.new
|
42
|
+
rescue LoadError
|
43
|
+
puts "Jeweler not available. Install it with: gem install jeweler"
|
44
|
+
end
|
@@ -0,0 +1,70 @@
|
|
1
|
+
class Manage::AssetsController < Manage::BaseController
|
2
|
+
before_filter :find_klass, :only => [:create, :sort]
|
3
|
+
before_filter :find_asset, :only => [:destroy]
|
4
|
+
|
5
|
+
respond_to :html, :xml
|
6
|
+
|
7
|
+
authorize_resource
|
8
|
+
|
9
|
+
def create
|
10
|
+
@asset ||= @klass.new(params[:asset])
|
11
|
+
|
12
|
+
@asset.assetable_type = params[:assetable_type]
|
13
|
+
@asset.assetable_id = params[:assetable_id] || 0
|
14
|
+
@asset.guid = params[:guid]
|
15
|
+
@asset.data = params[:data_file]
|
16
|
+
@asset.user = current_user
|
17
|
+
@asset.save
|
18
|
+
|
19
|
+
respond_with(@asset) do |format|
|
20
|
+
format.html { head :ok }
|
21
|
+
format.xml { render :xml => @asset.to_xml }
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
def destroy
|
26
|
+
@asset.destroy
|
27
|
+
|
28
|
+
respond_with(@asset) do |format|
|
29
|
+
format.html { head :ok }
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
def sort
|
34
|
+
params[:picture].each_with_index do |id, index|
|
35
|
+
@klass.move_to(index, id)
|
36
|
+
end
|
37
|
+
|
38
|
+
respond_with(@klass) do |format|
|
39
|
+
format.html { head :ok }
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
protected
|
44
|
+
|
45
|
+
def find_asset
|
46
|
+
@asset = Asset.find(params[:id])
|
47
|
+
end
|
48
|
+
|
49
|
+
def find_klass
|
50
|
+
c_names = []
|
51
|
+
c_values = []
|
52
|
+
|
53
|
+
unless params[:assetable_id].blank?
|
54
|
+
c_names << "assetable_id = ?"
|
55
|
+
c_values << params[:assetable_id].to_i
|
56
|
+
|
57
|
+
c_names << "assetable_type = ?"
|
58
|
+
c_values << params[:assetable_type]
|
59
|
+
else
|
60
|
+
c_names << "guid = ?"
|
61
|
+
c_values << params[:guid]
|
62
|
+
end
|
63
|
+
|
64
|
+
@klass = params[:klass].blank? ? Asset : params[:klass].classify.constantize
|
65
|
+
|
66
|
+
if params[:collection].blank?
|
67
|
+
@asset = @klass.find(:first, :conditions=>[c_names.join(' AND ')] + c_values)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
class Manage::BaseController < ApplicationController
|
2
|
+
before_filter :authenticate_user!
|
3
|
+
check_authorization
|
4
|
+
|
5
|
+
layout "manage"
|
6
|
+
respond_to :html
|
7
|
+
|
8
|
+
protected
|
9
|
+
|
10
|
+
rescue_from CanCan::AccessDenied do |exception|
|
11
|
+
flash[:failure] = exception.message
|
12
|
+
flash[:failure] ||= I18n.t(:access_denied, :scope => [:flash, :users])
|
13
|
+
|
14
|
+
respond_to do |format|
|
15
|
+
format.html { redirect_to new_session_path(:user) }
|
16
|
+
format.xml { head :unauthorized }
|
17
|
+
format.js { head :unauthorized }
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
def current_ability
|
22
|
+
@current_ability ||= ::Ability.new(current_user, :manage)
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
class Manage::PagesController < Manage::BaseController
|
2
|
+
before_filter :find_structure
|
3
|
+
before_filter :find_page
|
4
|
+
|
5
|
+
cache_sweeper :page_sweeper, :only => [:create, :update, :destroy]
|
6
|
+
|
7
|
+
authorize_resource
|
8
|
+
|
9
|
+
# GET /manage/structures/1/page/edit
|
10
|
+
def edit
|
11
|
+
respond_with(@page) do |format|
|
12
|
+
format.html { render :action => (@page.new_record? ? 'new' : 'edit') }
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
# POST /manage/structures/1/page
|
17
|
+
def create
|
18
|
+
@page.update_attributes(params[:page])
|
19
|
+
respond_with(@page, :location => manage_structures_path)
|
20
|
+
end
|
21
|
+
|
22
|
+
# PUT /manage/structures/1/page
|
23
|
+
def update
|
24
|
+
@page.update_attributes(params[:page])
|
25
|
+
respond_with(@page, :location => manage_structures_path)
|
26
|
+
end
|
27
|
+
|
28
|
+
protected
|
29
|
+
|
30
|
+
def find_structure
|
31
|
+
@structure = Structure.find(params[:structure_id])
|
32
|
+
end
|
33
|
+
|
34
|
+
def find_page
|
35
|
+
@page = @structure.page || @structure.build_page(:title => @structure.title)
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
class Manage::SettingsController < Manage::BaseController
|
2
|
+
authorize_resource :class => false
|
3
|
+
|
4
|
+
# GET /manage/settings
|
5
|
+
def index
|
6
|
+
end
|
7
|
+
|
8
|
+
# POST /manage/settings
|
9
|
+
def create
|
10
|
+
respond_to do |format|
|
11
|
+
if Sunrise::SystemSettings.update_settings(params[:settings])
|
12
|
+
flash[:notice] = I18n.t('flash.manage.settings.create.success')
|
13
|
+
|
14
|
+
format.html { redirect_to manage_settings_path }
|
15
|
+
format.xml { head :ok }
|
16
|
+
else
|
17
|
+
flash.now[:error] = I18n.t('flash.manage.settings.create.failure')
|
18
|
+
|
19
|
+
format.html { render :action => "index" }
|
20
|
+
format.xml { head :unprocessable_entity }
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
class Manage::StructuresController < Manage::BaseController
|
2
|
+
inherit_resources
|
3
|
+
defaults :route_prefix => 'manage'
|
4
|
+
|
5
|
+
before_filter :find_root, :only=>[:index]
|
6
|
+
before_filter :find_structure, :only => [:edit, :update, :destroy, :move]
|
7
|
+
|
8
|
+
load_and_authorize_resource
|
9
|
+
|
10
|
+
cache_sweeper :structure_sweeper, :only=>[:create, :update, :destroy, :move]
|
11
|
+
|
12
|
+
def create
|
13
|
+
create!{ manage_structures_path }
|
14
|
+
end
|
15
|
+
|
16
|
+
def update
|
17
|
+
update!{ manage_structures_path }
|
18
|
+
end
|
19
|
+
|
20
|
+
def destroy
|
21
|
+
destroy!{ manage_structures_path }
|
22
|
+
end
|
23
|
+
|
24
|
+
# POST /manage/structures/1/move
|
25
|
+
def move
|
26
|
+
@structure.move_by_direction(params[:direction])
|
27
|
+
|
28
|
+
respond_with(@structure, :location => manage_structures_path)
|
29
|
+
end
|
30
|
+
|
31
|
+
protected
|
32
|
+
|
33
|
+
def find_root
|
34
|
+
@structure ||= Structure.with_kind(StructureType.main).with_depth(0).find(:first)
|
35
|
+
@structure
|
36
|
+
end
|
37
|
+
|
38
|
+
def find_structure
|
39
|
+
@structure = Structure.find_by_permalink(params[:id])
|
40
|
+
end
|
41
|
+
|
42
|
+
def collection
|
43
|
+
@structures = (@structures || end_of_association_chain).with_depth(1)
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,78 @@
|
|
1
|
+
class Manage::UsersController < Manage::BaseController
|
2
|
+
inherit_resources
|
3
|
+
defaults :route_prefix => 'manage'
|
4
|
+
|
5
|
+
load_and_authorize_resource
|
6
|
+
|
7
|
+
before_filter :make_filter, :only=>[:index]
|
8
|
+
before_filter :check_params, :only => [:create, :update]
|
9
|
+
|
10
|
+
cache_sweeper :user_sweeper, :only=>[:update, :destroy]
|
11
|
+
|
12
|
+
def create
|
13
|
+
@user = User.new(params[:user])
|
14
|
+
@user.roles_attributes = @roles
|
15
|
+
create! { manage_users_path }
|
16
|
+
end
|
17
|
+
|
18
|
+
def update
|
19
|
+
@user.roles_attributes = @roles
|
20
|
+
update!{ manage_users_path }
|
21
|
+
end
|
22
|
+
|
23
|
+
def destroy
|
24
|
+
destroy!{ manage_users_path }
|
25
|
+
end
|
26
|
+
|
27
|
+
# POST /manage/users/1/activate
|
28
|
+
def activate
|
29
|
+
@user.confirm!
|
30
|
+
respond_with(@user, :location => manage_users_path)
|
31
|
+
end
|
32
|
+
|
33
|
+
# POST /manage/users/1/suspend
|
34
|
+
def suspend
|
35
|
+
@user.suspend!
|
36
|
+
respond_with(@user, :location => manage_users_path)
|
37
|
+
end
|
38
|
+
|
39
|
+
# POST /manage/users/1/unsuspend
|
40
|
+
def unsuspend
|
41
|
+
@user.unsuspend!
|
42
|
+
respond_with(@user, :location => manage_users_path)
|
43
|
+
end
|
44
|
+
|
45
|
+
# POST /manage/users/1/delete
|
46
|
+
def delete
|
47
|
+
@user.delete!
|
48
|
+
respond_with(@user, :location => manage_users_path)
|
49
|
+
end
|
50
|
+
|
51
|
+
protected
|
52
|
+
|
53
|
+
def collection
|
54
|
+
@users = (@users || end_of_association_chain).merge(@search.scoped).includes(:avatar).page(params[:page])
|
55
|
+
end
|
56
|
+
|
57
|
+
def make_filter
|
58
|
+
@search = Sunrise::ModelFilter.new(User, :attributes=>[:name, :email])
|
59
|
+
@search.update_attributes(params[:search])
|
60
|
+
end
|
61
|
+
|
62
|
+
def check_params
|
63
|
+
unless params[:user].blank?
|
64
|
+
@roles = params[:user].delete(:roles_attributes)
|
65
|
+
|
66
|
+
if params[:user][:password].blank?
|
67
|
+
params[:user].delete(:password)
|
68
|
+
params[:user].delete(:password_confirmation)
|
69
|
+
end
|
70
|
+
|
71
|
+
@user.accessible = :all
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
def find_user
|
76
|
+
@user = User.find(params[:id])
|
77
|
+
end
|
78
|
+
end
|
@@ -0,0 +1,22 @@
|
|
1
|
+
class PagesController < ApplicationController
|
2
|
+
before_filter :find_structure
|
3
|
+
before_filter :set_header
|
4
|
+
|
5
|
+
caches_action :show, :layout => false
|
6
|
+
|
7
|
+
def show
|
8
|
+
@page = @structure.page || Page.new
|
9
|
+
respond_with(@page)
|
10
|
+
end
|
11
|
+
|
12
|
+
protected
|
13
|
+
|
14
|
+
def find_structure
|
15
|
+
@structure = Structure.with_kind(StructureType.page).find_by_slug(params[:id])
|
16
|
+
raise ActiveRecord::RecordNotFound.new("Structure #{params[:id]} not found") if @structure.nil?
|
17
|
+
end
|
18
|
+
|
19
|
+
def set_header
|
20
|
+
head_options(@structure)
|
21
|
+
end
|
22
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
2
|
+
<html xmlns="http://www.w3.org/1999/xhtml">
|
3
|
+
<head>
|
4
|
+
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
5
|
+
<%= csrf_meta_tag %>
|
6
|
+
<title><%= t('manage.page_title') %></title>
|
7
|
+
<%= stylesheet_link_tag "manage/main", "fancybox/jquery.fancybox-1.3.4" %>
|
8
|
+
<%= stylesheet_link_tag "smoothness/jquery-ui-1.8.6.custom" %>
|
9
|
+
<!--[if lt IE 7]><%= stylesheet_link_tag "manage/ie" %><![endif]-->
|
10
|
+
|
11
|
+
<script src="https://www.google.com/jsapi?key=" type="text/javascript"></script>
|
12
|
+
<script language="Javascript" type="text/javascript">
|
13
|
+
//<![CDATA[
|
14
|
+
google.load("jquery", "1.5.1");
|
15
|
+
google.load("jqueryui", "1.8.6");
|
16
|
+
google.load("swfobject", "2.2");
|
17
|
+
//]]>
|
18
|
+
</script>
|
19
|
+
|
20
|
+
<%= javascript_include_tag "jquery.tmpl.min", "jquery.fancybox-1.3.4.pack", "jquery.cookie" %>
|
21
|
+
<%= javascript_include_tag "jquery-ui-timepicker-addon", "datepicker/jquery.ui.datepicker-#{I18n.locale}" %>
|
22
|
+
<%= javascript_include_tag :ckeditor, "preloader", "rails", "manage" %>
|
23
|
+
<%= attach_include_files %>
|
24
|
+
<%= yield(:head)%>
|
25
|
+
</head>
|
26
|
+
<body>
|
27
|
+
<div class="main">
|
28
|
+
<%= render :partial => "manage/shared/head" %>
|
29
|
+
<div class="main-frame">
|
30
|
+
<div class="struct-bl">
|
31
|
+
<div id="manage_container" class="bot-bg">
|
32
|
+
<%= render :partial => 'manage/shared/notice' if flash %>
|
33
|
+
<%= yield %>
|
34
|
+
</div>
|
35
|
+
</div>
|
36
|
+
</div>
|
37
|
+
</div>
|
38
|
+
<%= yield(:footer) %>
|
39
|
+
</body>
|
40
|
+
</html>
|
@@ -0,0 +1,32 @@
|
|
1
|
+
<% unless model.new_record? %>
|
2
|
+
<div class="gray-blocks">
|
3
|
+
<div style="padding: 20px;" class="bg-bl">
|
4
|
+
<div style="padding: 0px 0px 15px;" class="gr-title"><%= t('manage.pictures') %></div>
|
5
|
+
|
6
|
+
<%= content_tag(:div, :id=>"swf_collection_#{model.id}", :class=>"galery") do %>
|
7
|
+
<%= render :partial=>"/manage/assets/picture", :collection => model.pictures %>
|
8
|
+
<% end %>
|
9
|
+
|
10
|
+
<div style="padding-top:20px;">
|
11
|
+
<%= content_tag(:span, nil, :id=>"swf_button_#{model.id}", :class=>"white-but") %>
|
12
|
+
<%= content_tag(:div, nil, :id=>"swf_container_#{model.id}") %>
|
13
|
+
</div>
|
14
|
+
</div>
|
15
|
+
</div>
|
16
|
+
|
17
|
+
<%= render :partial=>"/manage/assets/swfscript", :locals=>{:model=>model, :klass=>model.pictures.name } %>
|
18
|
+
|
19
|
+
<script type='text/javascript'>
|
20
|
+
$(document).ready(function(){
|
21
|
+
Manage.init_assets('div.galery', '<%= sort_manage_assets_path(:klass => model.pictures.name) %>');
|
22
|
+
});
|
23
|
+
</script>
|
24
|
+
<script id="asset_tmpl" type="text/x-jquery-tmpl">
|
25
|
+
<div id="<%= dom_class(model.class.reflections[:pictures].klass) %>_${id}" class="asset ill">
|
26
|
+
<%= link_to image_tag("manage/empty.gif", :alt=>t('manage.delete'), :title=>t('manage.delete')),
|
27
|
+
"/manage/assets/${id}", :remote => true, :method => :delete, :confirm => t('manage.confirm_delete'), :class => "del" %>
|
28
|
+
|
29
|
+
<a class="fancybox" href="${link_path}"><img title="${image_title}" src="${image_path}"></a>
|
30
|
+
</div>
|
31
|
+
</script>
|
32
|
+
<% end %>
|
@@ -0,0 +1,10 @@
|
|
1
|
+
<%= content_tag(:div, :class=>"asset ill", :id => dom_id(picture)) do %>
|
2
|
+
<%= link_to image_tag("manage/empty.gif", :alt=>t('manage.delete'), :title=>t('manage.delete')),
|
3
|
+
manage_asset_path(picture),
|
4
|
+
:remote => true,
|
5
|
+
:method => :delete,
|
6
|
+
:confirm => t('manage.confirm_delete'),
|
7
|
+
:class => "del" %>
|
8
|
+
|
9
|
+
<%= link_to image_tag(picture.url(:thumb), :title => picture.filename), picture.url(:content), :class => "fancybox" %>
|
10
|
+
<% end %>
|
@@ -0,0 +1,51 @@
|
|
1
|
+
<% javascript "swfupload/swfupload", "swfupload/swfupload.queue", "swfupload/fileprogress", "swfupload/handlers" %>
|
2
|
+
|
3
|
+
<script type="text/javascript">
|
4
|
+
$(document).ready(function(){
|
5
|
+
new SWFUpload({
|
6
|
+
// Backend settings
|
7
|
+
upload_url: "<%= manage_assets_path_with_session_information(klass, {:collection=>1}) %>",
|
8
|
+
post_params: {"assetable_type" : "<%= model.class.to_s %>", "assetable_id" : "<%= model.id %>"},
|
9
|
+
file_post_name: "data_file",
|
10
|
+
|
11
|
+
// Flash file settings
|
12
|
+
file_size_limit : "10 MB",
|
13
|
+
file_types : "*.jpg;*.jpeg;*.png;*.gif", // or you could use something like: "*.doc;*.wpd;*.pdf",
|
14
|
+
file_types_description : "All Images",
|
15
|
+
file_upload_limit : 20,
|
16
|
+
file_queue_limit : 0,
|
17
|
+
|
18
|
+
// The event handler functions are defined in handlers.js
|
19
|
+
//swfupload_loaded_handler : swfUploadLoaded,
|
20
|
+
file_queued_handler : fileQueued,
|
21
|
+
file_queue_error_handler : fileQueueError,
|
22
|
+
file_dialog_complete_handler : fileDialogComplete,
|
23
|
+
upload_start_handler : uploadStart,
|
24
|
+
upload_progress_handler : uploadProgress,
|
25
|
+
upload_error_handler : uploadError,
|
26
|
+
upload_success_handler : uploadSuccess,
|
27
|
+
upload_complete_handler : uploadComplete,
|
28
|
+
queue_complete_handler : queueComplete, // Queue plugin event
|
29
|
+
|
30
|
+
// Button Settings
|
31
|
+
button_image_url : "/images/manage/button_add_foto_<%= I18n.locale %>.gif",
|
32
|
+
button_placeholder_id : <%=raw "swf_button_#{model.id}".inspect %>,
|
33
|
+
button_width: 170,
|
34
|
+
button_height: 32,
|
35
|
+
button_window_mode: SWFUpload.WINDOW_MODE.TRANSPARENT,
|
36
|
+
button_cursor: SWFUpload.CURSOR.HAND,
|
37
|
+
|
38
|
+
// Flash Settings
|
39
|
+
flash_url : "/javascripts/swfupload/swfupload.swf",
|
40
|
+
|
41
|
+
custom_settings : {
|
42
|
+
progressTarget : <%=raw "swf_container_#{model.id}".inspect %>,
|
43
|
+
collectionTarget: <%=raw "swf_collection_#{model.id}".inspect %>,
|
44
|
+
cancelButtonId : "btn_cancel"
|
45
|
+
},
|
46
|
+
|
47
|
+
// Debug settings
|
48
|
+
debug: <%= Rails.env.development? ? 'true' : 'false' %>
|
49
|
+
});
|
50
|
+
});
|
51
|
+
</script>
|
@@ -0,0 +1,14 @@
|
|
1
|
+
<div class="edit-white-bl margin-top">
|
2
|
+
<div class="bot-bg">
|
3
|
+
<div class="wh-title"><%= t('manage.keywords') %></div>
|
4
|
+
<div class="elem-bl">
|
5
|
+
<div class="inputs-bl">
|
6
|
+
<%= form.fields_for :header, form.object.header || Header.new do |h| %>
|
7
|
+
<%= h.input :title %>
|
8
|
+
<%= h.input :keywords %>
|
9
|
+
<%= h.input :description, :input_html => {:cols=>70, :rows=>5} %>
|
10
|
+
<% end %>
|
11
|
+
</div>
|
12
|
+
</div>
|
13
|
+
</div>
|
14
|
+
</div>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
<%= manage_form_for [@structure, @page], :url => manage_structure_page_path(@structure.id) do |f| %>
|
2
|
+
<div class="bot-bg">
|
3
|
+
<div class="inputs-bl">
|
4
|
+
<%= f.input :title, :input_html => { :class => "text name" } %>
|
5
|
+
|
6
|
+
<%= f.ckeditor :content, :input_html => options_for_ckeditor %>
|
7
|
+
</div>
|
8
|
+
</div>
|
9
|
+
|
10
|
+
<%= f.button :submit, :url => manage_structures_path %>
|
11
|
+
<% end %>
|
@@ -0,0 +1,22 @@
|
|
1
|
+
<ul class="lang-tabs">
|
2
|
+
<% Sunrise::SystemSettings.keys.each_with_index do |section, i| %>
|
3
|
+
<%= content_tag(:li, :class => (i == 0 ? "active" : "not-active")) do %>
|
4
|
+
<span><%= link_to_function t("manage.settings.#{section}"), 'TabPanel.click(event)', :class=>"tab", :id=>"s#{section}" %></span>
|
5
|
+
<% end %>
|
6
|
+
<% end %>
|
7
|
+
</ul>
|
8
|
+
|
9
|
+
<% Sunrise::SystemSettings.keys.each_with_index do |section, i| %>
|
10
|
+
<%= content_tag(:div, :class => "add-white-bl", :id => "s#{section}_block", :style => (i == 0 ? nil: "display:none;")) do %>
|
11
|
+
<div class="bot-bg">
|
12
|
+
<div class="inputs-bl">
|
13
|
+
<%= form.fields_for section do |s| %>
|
14
|
+
<% Sunrise::SystemSettings[section].each do |attribute, value| %>
|
15
|
+
<%= s.label attribute %>
|
16
|
+
<%= s.text_field attribute, :class=>"text", :value => value %>
|
17
|
+
<% end %>
|
18
|
+
<% end %>
|
19
|
+
</div>
|
20
|
+
</div>
|
21
|
+
<% end %>
|
22
|
+
<% end %>
|
@@ -0,0 +1,14 @@
|
|
1
|
+
<div class="edit-bl">
|
2
|
+
<div class="bot-bg">
|
3
|
+
<div class="block-title"><%= t('manage.edit') %>:</div>
|
4
|
+
<%= form_for Sunrise::SystemSettings.ostruct, :as => :settings, :url => manage_settings_path, :html => { :id => "settings_form" } do |f| -%>
|
5
|
+
<%= render :partial=>"manage/settings/form", :object => f %>
|
6
|
+
|
7
|
+
<div style="padding: 20px 0px 10px 20px;" class="buts">
|
8
|
+
<%= link_to_function content_tag(:span, t('manage.update')), "$('#settings_form').submit()", :class=>"gr" %>
|
9
|
+
<%= link_to t('manage.cancel'), manage_settings_path, :class=>"erase" %>
|
10
|
+
<%= f.submit t('manage.update'), :style=>"display:none;" %>
|
11
|
+
</div>
|
12
|
+
<% end %>
|
13
|
+
</div>
|
14
|
+
</div>
|
@@ -0,0 +1,41 @@
|
|
1
|
+
<div class="head">
|
2
|
+
<%= link_to image_tag("manage/minimise_but.gif", :alt=>t('manage.go_site'), :title=>t('manage.go_site')), root_path, :class=>"minimaze" %>
|
3
|
+
<div class="logo"><%=raw t('manage.title') %></div>
|
4
|
+
|
5
|
+
<div class="main-menu">
|
6
|
+
<ul>
|
7
|
+
<% Sunrise::Plugins.active.menu('main').each do |plugin| %>
|
8
|
+
<% if can? :read, plugin.klass, :context => :manage %>
|
9
|
+
<li><%= link_to_unless_current_span2 plugin.title, [:manage, plugin.name] %></li>
|
10
|
+
<% end %>
|
11
|
+
<% end %>
|
12
|
+
|
13
|
+
<% unless Sunrise::Plugins.active.menu('select').empty? %>
|
14
|
+
<li><%= link_to_function t('manage.plugins.other'), "SelectList.toggle(event)", :class=>"arr", :id=>"menu_select" %></li>
|
15
|
+
<% end %>
|
16
|
+
</ul>
|
17
|
+
</div>
|
18
|
+
|
19
|
+
<div class="user">
|
20
|
+
<div class="user-info">
|
21
|
+
<div class="info">
|
22
|
+
<%= link_to current_user.name, edit_manage_user_path(current_user), :class=>"name" %>
|
23
|
+
<%= link_to t('manage.exit'), destroy_user_session_path, :class=>"exit" %>
|
24
|
+
</div>
|
25
|
+
</div>
|
26
|
+
|
27
|
+
<div class="user-foto">
|
28
|
+
<%= link_to manage_user_avatar_tag(current_user, :type=>:small), edit_manage_user_path(current_user) %>
|
29
|
+
</div>
|
30
|
+
</div>
|
31
|
+
</div>
|
32
|
+
|
33
|
+
<% unless Sunrise::Plugins.active.menu('select').empty? %>
|
34
|
+
<div id='menu_select_list' class="select-list" style='display:none;'>
|
35
|
+
<% Sunrise::Plugins.active.menu('select').each do |plugin| %>
|
36
|
+
<% if can? :read, plugin.klass, :context => :manage %>
|
37
|
+
<%= link_to plugin.title, [:manage, plugin.name] %>
|
38
|
+
<% end %>
|
39
|
+
<% end %>
|
40
|
+
</div>
|
41
|
+
<% end %>
|
@@ -0,0 +1,8 @@
|
|
1
|
+
<% param ||= "s"%>
|
2
|
+
<ul class="lang-tabs" id="lang_tab_ul_<%=param%>">
|
3
|
+
<% Globalize.available_locales.each do |locale| %>
|
4
|
+
<%= content_tag(:li, :class=>(I18n.locale.to_s == locale.to_s ? 'active' : 'not-active')) do %>
|
5
|
+
<span><%= link_to_function t("manage.locale.#{locale}"), 'TabPanel.click(event)', :class=>locale, :id=>"#{param + locale.to_s}" %></span>
|
6
|
+
<% end %>
|
7
|
+
<% end %>
|
8
|
+
</ul>
|