typo 5.4.4 → 5.5
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +59 -28
- data/MAINTAINERS +9 -17
- data/README +28 -20
- data/UPGRADE +6 -2
- data/app/controllers/accounts_controller.rb +1 -1
- data/app/controllers/admin/content_controller.rb +1 -1
- data/app/controllers/admin/feedback_controller.rb +3 -3
- data/app/controllers/admin/pages_controller.rb +2 -0
- data/app/controllers/application_controller.rb +6 -1
- data/app/controllers/articles_controller.rb +13 -1
- data/app/helpers/application_helper.rb +5 -2
- data/app/helpers/authors_helper.rb +14 -3
- data/app/models/article.rb +6 -4
- data/app/models/blog.rb +0 -4
- data/app/models/blog_sweeper.rb +1 -1
- data/app/models/content.rb +10 -5
- data/app/models/page_cache.rb +6 -7
- data/app/models/user.rb +1 -0
- data/app/views/admin/content/_form.html.erb +13 -11
- data/app/views/admin/content/_images.html.erb +1 -1
- data/app/views/admin/content/_simple_editor.html.erb +1 -0
- data/app/views/admin/content/_visual_editor.html.erb +1 -0
- data/app/views/admin/dashboard/_overview.html.erb +7 -7
- data/app/views/admin/pages/_form.html.erb +1 -0
- data/app/views/admin/pages/_images.html.erb +18 -0
- data/app/views/admin/pages/_simple_editor.html.erb +1 -2
- data/app/views/admin/pages/_visual_editor.html.erb +2 -1
- data/app/views/admin/pages/index.html.erb +1 -1
- data/app/views/admin/settings/feedback.html.erb +2 -1
- data/app/views/admin/tags/edit.html.erb +1 -1
- data/app/views/articles/_article.html.erb +17 -13
- data/app/views/articles/_article_content.html.erb +1 -0
- data/app/views/articles/_comment_box.html.erb +1 -1
- data/app/views/articles/_password_form.html.erb +10 -0
- data/app/views/articles/groupings.html.erb +1 -1
- data/app/views/articles/index.html.erb +1 -2
- data/app/views/articles/read.html.erb +1 -4
- data/app/views/articles/search.html.erb +1 -1
- data/app/views/layouts/administration.html.erb +1 -1
- data/app/views/shared/_search.html.erb +1 -1
- data/config/ckeditor.yml +14 -0
- data/config/environment.rb +13 -25
- data/config/environments/test.rb +1 -3
- data/config/filemanager.yml +16 -0
- data/config/initializers/access_rules.rb +5 -0
- data/config/routes.rb +5 -1
- data/db/migrate/004_add_sidebars.rb +3 -9
- data/db/migrate/089_drop_cache_information_table.rb +31 -0
- data/db/migrate/090_remove_keywords_from_posts.rb +9 -0
- data/db/migrate/091_adds_password_protection_to_posts.rb +9 -0
- data/doc/CACHE.SETUP.README +36 -0
- data/lang/de_DE.rb +6 -1
- data/lang/pl_PL.rb +221 -89
- data/lib/filemanager.rb +53 -0
- data/lib/filemanager/controller.rb +217 -0
- data/lib/i18n_interpolation_deprecation.rb +26 -0
- data/lib/rails_patch/active_support.rb +4 -0
- data/lib/tasks/release.rake +4 -131
- data/lib/typo_version.rb +1 -1
- data/public/.htaccess +6 -5
- data/public/filemanager/images/avi.gif +0 -0
- data/public/filemanager/images/box.gif +0 -0
- data/public/filemanager/images/bullet.gif +0 -0
- data/public/filemanager/images/close.gif +0 -0
- data/public/filemanager/images/closelabel.gif +0 -0
- data/public/filemanager/images/doc.gif +0 -0
- data/public/filemanager/images/donate-button.gif +0 -0
- data/public/filemanager/images/download-icon.gif +0 -0
- data/public/filemanager/images/folder.gif +0 -0
- data/public/filemanager/images/gif.gif +0 -0
- data/public/filemanager/images/htm.gif +0 -0
- data/public/filemanager/images/html.gif +0 -0
- data/public/filemanager/images/image-1.jpg +0 -0
- data/public/filemanager/images/image.gif +0 -0
- data/public/filemanager/images/jpg.gif +0 -0
- data/public/filemanager/images/loading.gif +0 -0
- data/public/filemanager/images/mov.gif +0 -0
- data/public/filemanager/images/nextlabel.gif +0 -0
- data/public/filemanager/images/pdf.gif +0 -0
- data/public/filemanager/images/png.gif +0 -0
- data/public/filemanager/images/ppt.gif +0 -0
- data/public/filemanager/images/prevlabel.gif +0 -0
- data/public/filemanager/images/rar.gif +0 -0
- data/public/filemanager/images/rm.gif +0 -0
- data/public/filemanager/images/rmvb.gif +0 -0
- data/public/filemanager/images/separator.gif +0 -0
- data/public/filemanager/images/spacer.gif +0 -0
- data/public/filemanager/images/swf.gif +0 -0
- data/public/filemanager/images/thumb-1.jpg +0 -0
- data/public/filemanager/images/tool_copy.gif +0 -0
- data/public/filemanager/images/tool_cut.gif +0 -0
- data/public/filemanager/images/tool_del.gif +0 -0
- data/public/filemanager/images/tool_folder.gif +0 -0
- data/public/filemanager/images/tool_imagemanager.gif +0 -0
- data/public/filemanager/images/tool_new.gif +0 -0
- data/public/filemanager/images/tool_paste.gif +0 -0
- data/public/filemanager/images/tool_props.gif +0 -0
- data/public/filemanager/images/tool_refresh.gif +0 -0
- data/public/filemanager/images/tool_unzip.gif +0 -0
- data/public/filemanager/images/tool_upload.gif +0 -0
- data/public/filemanager/images/tool_zip.gif +0 -0
- data/public/filemanager/images/txt.gif +0 -0
- data/public/filemanager/images/unknown.gif +0 -0
- data/public/filemanager/images/wmv.gif +0 -0
- data/public/filemanager/images/xls.gif +0 -0
- data/public/filemanager/images/zip.gif +0 -0
- data/public/filemanager/javascripts/filemanager.js +6 -0
- data/public/filemanager/javascripts/lang/en.js +31 -0
- data/public/filemanager/javascripts/lang/zh_CN.js +31 -0
- data/public/filemanager/javascripts/lightbox.js +497 -0
- data/public/filemanager/javascripts/translate.js +42 -0
- data/public/filemanager/resources/resources.txt +1 -0
- data/public/filemanager/stylesheets/filelist.css +147 -0
- data/public/filemanager/stylesheets/general.css +135 -0
- data/public/filemanager/stylesheets/lightbox.css +27 -0
- data/public/javascripts/prototype_ext.js +117 -0
- data/public/stylesheets/administration.css +19 -2
- data/themes/dirtylicious/views/articles/_article.html.erb +16 -12
- data/themes/dirtylicious/views/articles/_article_content.html.erb +1 -0
- data/themes/dirtylicious/views/articles/_password_form.html.erb +10 -0
- data/themes/scribbish/views/articles/_article.html.erb +18 -14
- data/themes/scribbish/views/articles/_article_content.html.erb +1 -0
- data/themes/scribbish/views/articles/_password_form.html.erb +10 -0
- data/themes/standard_issue/views/articles/_article.html.erb +16 -12
- data/themes/standard_issue/views/articles/_article_content.html.erb +1 -0
- data/themes/standard_issue/views/articles/_password_form.html.erb +10 -0
- data/themes/true-blue-3/helpers/theme_helper.rb +2 -2
- data/themes/true-blue-3/images/submit_form.jpg +0 -0
- data/themes/true-blue-3/stylesheets/style.css +27 -3
- data/themes/true-blue-3/views/articles/_article.html.erb +13 -8
- data/themes/true-blue-3/views/articles/_article_content.html.erb +1 -0
- data/themes/true-blue-3/views/articles/_comment_form.html.erb +1 -1
- data/themes/true-blue-3/views/articles/_password_form.html.erb +10 -0
- data/themes/true-blue-3/views/categories/_article.html.erb +5 -0
- data/themes/true-blue-3/views/tags/_article.html.erb +4 -0
- data/themes/typographic/views/articles/_article.html.erb +16 -12
- data/themes/typographic/views/articles/_article_content.html.erb +1 -0
- data/themes/typographic/views/articles/_password_form.html.erb +10 -0
- data/vendor/plugins/easy-ckeditor/app/controllers/ckeditor_controller.rb +2 -1
- data/vendor/plugins/easy-ckeditor/lib/ckeditor.rb +1 -20
- data/vendor/plugins/easy-ckeditor/{tasks → lib/tasks}/ckeditor_tasks.rake +0 -0
- data/vendor/plugins/filemanager/app/controllers/fm/filemanager_controller.rb +22 -0
- data/vendor/plugins/filemanager/app/views/fm/filemanager/index.html.erb +512 -0
- data/vendor/plugins/filemanager/app/views/fm/filemanager/view.html.erb +67 -0
- data/vendor/plugins/filemanager/filemanager.yml +16 -0
- data/vendor/plugins/static_sidebar/lib/static_sidebar.rb +4 -2
- data/vendor/plugins/typo_converter/{tasks → lib/tasks}/typo_converters_tasks.rake +0 -0
- data/vendor/plugins/typo_login_system/lib/access_control.rb +24 -1
- data/vendor/plugins/typo_textfilter_code/{tasks → lib/tasks}/typo_textfilter_code_tasks.rake +0 -0
- data/vendor/plugins/typo_textfilter_code/lib/typo_textfilter_code.rb +4 -3
- data/vendor/plugins/typo_textfilter_flickr/{tasks → lib/tasks}/typo_textfilter_flickr_tasks.rake +0 -0
- data/vendor/plugins/typo_textfilter_htmlfilter/{tasks → lib/tasks}/typo_textfilter_htmlfilter_tasks.rake +0 -0
- data/vendor/plugins/typo_textfilter_lightbox/{tasks → lib/tasks}/typo_textfilter_lightbox_tasks.rake +0 -0
- data/vendor/plugins/typo_textfilter_markdown/{tasks → lib/tasks}/typo_textfilter_markdown_tasks.rake +0 -0
- data/vendor/plugins/typo_textfilter_none/{tasks → lib/tasks}/typo_textfilter_none_tasks.rake +0 -0
- data/vendor/plugins/typo_textfilter_smartypants/{tasks → lib/tasks}/typo_textfilter_smartypants_tasks.rake +0 -0
- data/vendor/plugins/typo_textfilter_textile/{tasks → lib/tasks}/typo_textfilter_textile_tasks.rake +0 -0
- data/vendor/plugins/typo_textfilter_textile_and_markdown/{tasks → lib/tasks}/typo_textfilter_textile_and_markdown_tasks.rake +0 -0
- data/vendor/plugins/xml_sidebar/views/content.rhtml +1 -1
- metadata +190 -195
- data/app/controllers/admin/cache_controller.rb +0 -9
- data/app/models/cache_information.rb +0 -19
- data/db/schema.rb +0 -242
- data/doc/test_themes.rb +0 -50
- data/public/javascripts/ckeditor/config.js +0 -27
- data/spec/controllers/accounts_controller_spec.rb +0 -414
- data/spec/controllers/admin/cache_controller_spec.rb +0 -18
- data/spec/controllers/admin/categories_controller_spec.rb +0 -73
- data/spec/controllers/admin/content_controller_spec.rb +0 -443
- data/spec/controllers/admin/dashboard_controller_spec.rb +0 -13
- data/spec/controllers/admin/feedback_controller_spec.rb +0 -308
- data/spec/controllers/admin/pages_controller_spec.rb +0 -80
- data/spec/controllers/admin/profiles_controller_spec.rb +0 -22
- data/spec/controllers/admin/resources_controller_spec.rb +0 -53
- data/spec/controllers/admin/settings_controller_spec.rb +0 -80
- data/spec/controllers/admin/tags_controller_spec.rb +0 -64
- data/spec/controllers/admin/textfilters_controller_spec.rb +0 -20
- data/spec/controllers/admin/themes_controller_spec.rb +0 -30
- data/spec/controllers/admin/users_controller_spec.rb +0 -109
- data/spec/controllers/application_controller_spec.rb +0 -18
- data/spec/controllers/articles_controller_spec.rb +0 -440
- data/spec/controllers/authors_controller_spec.rb +0 -42
- data/spec/controllers/backend_controller_spec.rb +0 -337
- data/spec/controllers/categories_controller_spec.rb +0 -117
- data/spec/controllers/comments_controller_spec.rb +0 -137
- data/spec/controllers/routes/articles_routing_spec.rb +0 -31
- data/spec/controllers/routes/xml_routing_spec.rb +0 -71
- data/spec/controllers/setup_controller_spec.rb +0 -24
- data/spec/controllers/tags_controller_spec.rb +0 -147
- data/spec/controllers/textfilter_controller_spec.rb +0 -192
- data/spec/controllers/theme_controller_spec.rb +0 -39
- data/spec/controllers/xml_controller_spec.rb +0 -185
- data/spec/factories.rb +0 -69
- data/spec/helpers/application_helper_spec.rb +0 -25
- data/spec/helpers/content_helper_spec.rb +0 -28
- data/spec/lib/text_filter_plugin_spec.rb +0 -15
- data/spec/models/amazon_sidebar_spec.rb +0 -40
- data/spec/models/article_closing_spec.rb +0 -42
- data/spec/models/article_spec.rb +0 -515
- data/spec/models/blog_spec.rb +0 -116
- data/spec/models/cache_information_spec.rb +0 -42
- data/spec/models/cache_support_spec.rb +0 -51
- data/spec/models/category_spec.rb +0 -44
- data/spec/models/comment_spec.rb +0 -240
- data/spec/models/configuration_spec.rb +0 -91
- data/spec/models/content_state/feedback_states_spec.rb +0 -64
- data/spec/models/notification_spec.rb +0 -8
- data/spec/models/page_cache_spec.rb +0 -30
- data/spec/models/page_spec.rb +0 -91
- data/spec/models/ping_pinger_spec.rb +0 -33
- data/spec/models/ping_spec.rb +0 -154
- data/spec/models/redirect_spec.rb +0 -17
- data/spec/models/resource_spec.rb +0 -39
- data/spec/models/route_cache_spec.rb +0 -11
- data/spec/models/sidebar_spec.rb +0 -7
- data/spec/models/static_sidebar_spec.rb +0 -17
- data/spec/models/tag_spec.rb +0 -65
- data/spec/models/text_filter_spec.rb +0 -34
- data/spec/models/theme_spec.rb +0 -45
- data/spec/models/trackback_spec.rb +0 -60
- data/spec/models/trigger_spec.rb +0 -40
- data/spec/models/user_spec.rb +0 -198
- data/spec/rcov.opts +0 -2
- data/spec/spec.opts +0 -4
- data/spec/spec_helper.rb +0 -133
- data/spec/views/articles/index_spec.rb +0 -63
- data/spec/views/articles/read_spec.rb +0 -67
- data/spec/views/comments/html_sanitization_spec.rb +0 -119
- data/test/fixtures/blogs.yml +0 -27
- data/test/fixtures/categories.yml +0 -29
- data/test/fixtures/categorizations.yml +0 -31
- data/test/fixtures/contents.yml +0 -231
- data/test/fixtures/feedback.yml +0 -180
- data/test/fixtures/notification_mailer/article +0 -3
- data/test/fixtures/notification_mailer/comment +0 -3
- data/test/fixtures/notification_mailer/trackback +0 -3
- data/test/fixtures/notifications.yml +0 -0
- data/test/fixtures/page_caches.yml +0 -7
- data/test/fixtures/profiles.yml +0 -27
- data/test/fixtures/redirects.yml +0 -10
- data/test/fixtures/resources.yml +0 -21
- data/test/fixtures/sidebars.yml +0 -10
- data/test/fixtures/tags.yml +0 -10
- data/test/fixtures/text_filters.yml +0 -37
- data/test/fixtures/triggers.yml +0 -1
- data/test/fixtures/users.yml +0 -101
- data/test/mocks/test/dns_mock.rb +0 -13
- data/test/mocks/test/flickr_mock.rb +0 -30
- data/test/mocks/test/http_mock.rb +0 -39
- data/test/mocks/test/theme_mock.rb +0 -5
- data/test/mocks/test/xmlrpc_mock.rb +0 -28
- data/test/mocks/themes/123-numbers-in-path/about.markdown +0 -0
- data/test/mocks/themes/CamelCaseDirectory/about.markdown +0 -0
- data/test/mocks/themes/i-have-special-chars/about.markdown +0 -0
- data/test/mocks/themes/typographic/about.markdown +0 -7
- data/test/mocks/themes/typographic/images/Thumbs.db +0 -0
- data/test/mocks/themes/typographic/images/accept.png +0 -0
- data/test/mocks/themes/typographic/images/accept50.png +0 -0
- data/test/mocks/themes/typographic/images/bg_body.jpg +0 -0
- data/test/mocks/themes/typographic/images/bg_white.png +0 -0
- data/test/mocks/themes/typographic/images/bg_wrapper.jpg +0 -0
- data/test/mocks/themes/typographic/images/bullet_bottom.png +0 -0
- data/test/mocks/themes/typographic/images/bullet_right.png +0 -0
- data/test/mocks/themes/typographic/images/email_open.png +0 -0
- data/test/mocks/themes/typographic/images/email_open50.png +0 -0
- data/test/mocks/themes/typographic/images/meta.png +0 -0
- data/test/mocks/themes/typographic/images/page_edit.png +0 -0
- data/test/mocks/themes/typographic/images/page_edit50.png +0 -0
- data/test/mocks/themes/typographic/images/tag.png +0 -0
- data/test/mocks/themes/typographic/images/user.png +0 -0
- data/test/mocks/themes/typographic/images/user50.png +0 -0
- data/test/mocks/themes/typographic/images/world_link.png +0 -0
- data/test/mocks/themes/typographic/images/world_link50.png +0 -0
- data/test/mocks/themes/typographic/layouts/default.html.erb +0 -42
- data/test/mocks/themes/typographic/preview.png +0 -0
- data/test/mocks/themes/typographic/stylesheets/colors.css +0 -51
- data/test/mocks/themes/typographic/stylesheets/layout.css +0 -346
- data/test/mocks/themes/typographic/stylesheets/reset.css +0 -5
- data/test/mocks/themes/typographic/stylesheets/style.css +0 -36
- data/test/mocks/themes/typographic/views/articles/_article.html.erb +0 -41
- data/test/mocks/themes/typographic/views/articles/_comment.html.erb +0 -14
- data/test/mocks/themes/typographic/views/articles/_comment_form.html.erb +0 -48
- data/test/mocks/themes/typographic/views/articles/_comment_list.html.erb +0 -7
- data/test/mocks/themes/typographic/views/articles/_trackback.html.erb +0 -9
- data/test/mocks/themes/typographic/views/articles/comment_preview.html.erb +0 -10
- data/test/mocks/themes/typographic/views/articles/index.html.erb +0 -5
- data/test/mocks/themes/typographic/views/articles/read.html.erb +0 -42
- data/test/mocks/themes/typographic/views/shared/_search.html.erb +0 -17
- data/test/mocks/themes/typographic/views/theme/static_view_test.html.erb +0 -1
- data/test/test_helper.rb +0 -13
- data/themes/true-blue-3/images/frederic-de-villamil.jpg +0 -0
- data/themes/true-blue-3/images/textarea_bg.jpg +0 -0
data/lib/typo_version.rb
CHANGED
@@ -1 +1 @@
|
|
1
|
-
TYPO_VERSION = '5.
|
1
|
+
TYPO_VERSION = '5.5'
|
data/public/.htaccess
CHANGED
@@ -11,9 +11,6 @@ AddHandler cgi-script .cgi
|
|
11
11
|
# RewriteCond %{REQUEST_URI} ^/notrails.*
|
12
12
|
# RewriteRule .* - [L]
|
13
13
|
|
14
|
-
# Redirect all requests not available on the filesystem to Rails
|
15
|
-
RewriteEngine On
|
16
|
-
|
17
14
|
# If Typo is accessed via an Alias directive, then you MUST also set
|
18
15
|
# the RewriteBase in this htaccess file.
|
19
16
|
#
|
@@ -21,8 +18,12 @@ RewriteEngine On
|
|
21
18
|
# Alias /blog /path/to/typo/public
|
22
19
|
# RewriteBase /blog
|
23
20
|
|
24
|
-
|
25
|
-
RewriteRule
|
21
|
+
RewriteEngine On
|
22
|
+
RewriteRule ^/$ /cache/index.html [QSA]
|
23
|
+
RewriteCond %{DOCUMENT_ROOT}/cache/%{REQUEST_FILENAME} -f
|
24
|
+
RewriteRule ^/(.*)$ /cache/$1 [PT]
|
25
|
+
RewriteCond %{DOCUMENT_ROOT}/cache/%{REQUEST_FILENAME}.html -f
|
26
|
+
RewriteRule ^/(.*)$ /cache/$1.html [PT]
|
26
27
|
RewriteCond %{REQUEST_FILENAME} !-f
|
27
28
|
RewriteRule ^(.*)$ dispatch.fcgi [QSA,L]
|
28
29
|
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
@@ -0,0 +1,31 @@
|
|
1
|
+
var FMLang = {
|
2
|
+
name : "Filemanager",
|
3
|
+
rename : "",
|
4
|
+
copy : "",
|
5
|
+
cut : "",
|
6
|
+
paste : "",
|
7
|
+
remove : "",
|
8
|
+
download : "",
|
9
|
+
selectFile : "",
|
10
|
+
unzipFile : "",
|
11
|
+
new_folder : "",
|
12
|
+
new_file : "",
|
13
|
+
upload_file : "",
|
14
|
+
upload : "",
|
15
|
+
file_name : "",
|
16
|
+
file_size : "",
|
17
|
+
modification_date : "",
|
18
|
+
directory_information : "",
|
19
|
+
directory_name : "",
|
20
|
+
sub_directories : "",
|
21
|
+
files : "",
|
22
|
+
file_total_size : "",
|
23
|
+
preview_area : "",
|
24
|
+
width : "",
|
25
|
+
Height : "",
|
26
|
+
keep_radio : "",
|
27
|
+
thumb : "",
|
28
|
+
submit : "",
|
29
|
+
angle : "",
|
30
|
+
view : ""
|
31
|
+
}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
var FMLang = {
|
2
|
+
name : "Filemanager",
|
3
|
+
rename : "重命名",
|
4
|
+
copy : "复制",
|
5
|
+
cut : "剪切",
|
6
|
+
paste : "粘帖",
|
7
|
+
remove : "删除",
|
8
|
+
download : "下载",
|
9
|
+
selectFile : "选中",
|
10
|
+
unzipFile : "解压",
|
11
|
+
new_folder : "新建目录",
|
12
|
+
new_file : "新建文件",
|
13
|
+
upload_file : "上传文件",
|
14
|
+
upload : "上传",
|
15
|
+
file_name : "文件名",
|
16
|
+
file_size : "大小",
|
17
|
+
modification_date : "最后编辑时间",
|
18
|
+
directory_information : "目录信息",
|
19
|
+
directory_name : "目录名",
|
20
|
+
sub_directories : "下级目录数",
|
21
|
+
files : "文件数",
|
22
|
+
file_total_size : "文件总容量",
|
23
|
+
preview_area : "预览区域",
|
24
|
+
width : "宽度",
|
25
|
+
Height : "高度",
|
26
|
+
keep_radio : "保持比例",
|
27
|
+
thumb : "缩略图",
|
28
|
+
submit : "提交",
|
29
|
+
angle : "角度",
|
30
|
+
view : "查看"
|
31
|
+
}
|
@@ -0,0 +1,497 @@
|
|
1
|
+
// -----------------------------------------------------------------------------------
|
2
|
+
//
|
3
|
+
// Lightbox v2.04
|
4
|
+
// by Lokesh Dhakar - http://www.lokeshdhakar.com
|
5
|
+
// Last Modification: 2/9/08
|
6
|
+
//
|
7
|
+
// For more information, visit:
|
8
|
+
// http://lokeshdhakar.com/projects/lightbox2/
|
9
|
+
//
|
10
|
+
// Licensed under the Creative Commons Attribution 2.5 License - http://creativecommons.org/licenses/by/2.5/
|
11
|
+
// - Free for use in both personal and commercial projects
|
12
|
+
// - Attribution requires leaving author name, author link, and the license info intact.
|
13
|
+
//
|
14
|
+
// Thanks: Scott Upton(uptonic.com), Peter-Paul Koch(quirksmode.com), and Thomas Fuchs(mir.aculo.us) for ideas, libs, and snippets.
|
15
|
+
// Artemy Tregubenko (arty.name) for cleanup and help in updating to latest ver of proto-aculous.
|
16
|
+
//
|
17
|
+
// -----------------------------------------------------------------------------------
|
18
|
+
/*
|
19
|
+
|
20
|
+
Table of Contents
|
21
|
+
-----------------
|
22
|
+
Configuration
|
23
|
+
|
24
|
+
Lightbox Class Declaration
|
25
|
+
- initialize()
|
26
|
+
- updateImageList()
|
27
|
+
- start()
|
28
|
+
- changeImage()
|
29
|
+
- resizeImageContainer()
|
30
|
+
- showImage()
|
31
|
+
- updateDetails()
|
32
|
+
- updateNav()
|
33
|
+
- enableKeyboardNav()
|
34
|
+
- disableKeyboardNav()
|
35
|
+
- keyboardAction()
|
36
|
+
- preloadNeighborImages()
|
37
|
+
- end()
|
38
|
+
|
39
|
+
Function Calls
|
40
|
+
- document.observe()
|
41
|
+
|
42
|
+
*/
|
43
|
+
// -----------------------------------------------------------------------------------
|
44
|
+
|
45
|
+
//
|
46
|
+
// Configurationl
|
47
|
+
//
|
48
|
+
LightboxOptions = Object.extend({
|
49
|
+
fileLoadingImage: '/filemanager/images/loading.gif',
|
50
|
+
fileBottomNavCloseImage: '/filemanager/images/closelabel.gif',
|
51
|
+
|
52
|
+
overlayOpacity: 0.8, // controls transparency of shadow overlay
|
53
|
+
|
54
|
+
animate: true, // toggles resizing animations
|
55
|
+
resizeSpeed: 7, // controls the speed of the image resizing animations (1=slowest and 10=fastest)
|
56
|
+
|
57
|
+
borderSize: 10, //if you adjust the padding in the CSS, you will need to update this variable
|
58
|
+
|
59
|
+
// When grouping images this is used to write: Image # of #.
|
60
|
+
// Change it for non-english localization
|
61
|
+
labelImage: "Image",
|
62
|
+
labelOf: "of"
|
63
|
+
}, window.LightboxOptions || {});
|
64
|
+
|
65
|
+
// -----------------------------------------------------------------------------------
|
66
|
+
|
67
|
+
var Lightbox = Class.create();
|
68
|
+
|
69
|
+
Lightbox.prototype = {
|
70
|
+
imageArray: [],
|
71
|
+
activeImage: undefined,
|
72
|
+
|
73
|
+
// initialize()
|
74
|
+
// Constructor runs on completion of the DOM loading. Calls updateImageList and then
|
75
|
+
// the function inserts html at the bottom of the page which is used to display the shadow
|
76
|
+
// overlay and the image container.
|
77
|
+
//
|
78
|
+
initialize: function() {
|
79
|
+
|
80
|
+
this.updateImageList();
|
81
|
+
|
82
|
+
this.keyboardAction = this.keyboardAction.bindAsEventListener(this);
|
83
|
+
|
84
|
+
if (LightboxOptions.resizeSpeed > 10) LightboxOptions.resizeSpeed = 10;
|
85
|
+
if (LightboxOptions.resizeSpeed < 1) LightboxOptions.resizeSpeed = 1;
|
86
|
+
|
87
|
+
this.resizeDuration = LightboxOptions.animate ? ((11 - LightboxOptions.resizeSpeed) * 0.15) : 0;
|
88
|
+
this.overlayDuration = LightboxOptions.animate ? 0.2 : 0; // shadow fade in/out duration
|
89
|
+
|
90
|
+
// When Lightbox starts it will resize itself from 250 by 250 to the current image dimension.
|
91
|
+
// If animations are turned off, it will be hidden as to prevent a flicker of a
|
92
|
+
// white 250 by 250 box.
|
93
|
+
var size = (LightboxOptions.animate ? 250 : 1) + 'px';
|
94
|
+
|
95
|
+
|
96
|
+
// Code inserts html at the bottom of the page that looks similar to this:
|
97
|
+
//
|
98
|
+
// <div id="overlay"></div>
|
99
|
+
// <div id="lightbox">
|
100
|
+
// <div id="outerImageContainer">
|
101
|
+
// <div id="imageContainer">
|
102
|
+
// <img id="lightboxImage">
|
103
|
+
// <div style="" id="hoverNav">
|
104
|
+
// <a href="#" id="prevLink"></a>
|
105
|
+
// <a href="#" id="nextLink"></a>
|
106
|
+
// </div>
|
107
|
+
// <div id="loading">
|
108
|
+
// <a href="#" id="loadingLink">
|
109
|
+
// <img src="images/loading.gif">
|
110
|
+
// </a>
|
111
|
+
// </div>
|
112
|
+
// </div>
|
113
|
+
// </div>
|
114
|
+
// <div id="imageDataContainer">
|
115
|
+
// <div id="imageData">
|
116
|
+
// <div id="imageDetails">
|
117
|
+
// <span id="caption"></span>
|
118
|
+
// <span id="numberDisplay"></span>
|
119
|
+
// </div>
|
120
|
+
// <div id="bottomNav">
|
121
|
+
// <a href="#" id="bottomNavClose">
|
122
|
+
// <img src="images/close.gif">
|
123
|
+
// </a>
|
124
|
+
// </div>
|
125
|
+
// </div>
|
126
|
+
// </div>
|
127
|
+
// </div>
|
128
|
+
|
129
|
+
|
130
|
+
var objBody = $$('body')[0];
|
131
|
+
|
132
|
+
objBody.appendChild(Builder.node('div',{id:'overlay'}));
|
133
|
+
|
134
|
+
objBody.appendChild(Builder.node('div',{id:'lightbox'}, [
|
135
|
+
Builder.node('div',{id:'outerImageContainer'},
|
136
|
+
Builder.node('div',{id:'imageContainer'}, [
|
137
|
+
Builder.node('img',{id:'lightboxImage'}),
|
138
|
+
Builder.node('div',{id:'hoverNav'}, [
|
139
|
+
Builder.node('a',{id:'prevLink', href: '#' }),
|
140
|
+
Builder.node('a',{id:'nextLink', href: '#' })
|
141
|
+
]),
|
142
|
+
Builder.node('div',{id:'loading'},
|
143
|
+
Builder.node('a',{id:'loadingLink', href: '#' },
|
144
|
+
Builder.node('img', {src: LightboxOptions.fileLoadingImage})
|
145
|
+
)
|
146
|
+
)
|
147
|
+
])
|
148
|
+
),
|
149
|
+
Builder.node('div', {id:'imageDataContainer'},
|
150
|
+
Builder.node('div',{id:'imageData'}, [
|
151
|
+
Builder.node('div',{id:'imageDetails'}, [
|
152
|
+
Builder.node('span',{id:'caption'}),
|
153
|
+
Builder.node('span',{id:'numberDisplay'})
|
154
|
+
]),
|
155
|
+
Builder.node('div',{id:'bottomNav'},
|
156
|
+
Builder.node('a',{id:'bottomNavClose', href: '#' },
|
157
|
+
Builder.node('img', { src: LightboxOptions.fileBottomNavCloseImage })
|
158
|
+
)
|
159
|
+
)
|
160
|
+
])
|
161
|
+
)
|
162
|
+
]));
|
163
|
+
|
164
|
+
|
165
|
+
$('overlay').hide().observe('click', (function() { this.end(); }).bind(this));
|
166
|
+
$('lightbox').hide().observe('click', (function(event) { if (event.element().id == 'lightbox') this.end(); }).bind(this));
|
167
|
+
$('outerImageContainer').setStyle({ width: size, height: size });
|
168
|
+
$('prevLink').observe('click', (function(event) { event.stop(); this.changeImage(this.activeImage - 1); }).bindAsEventListener(this));
|
169
|
+
$('nextLink').observe('click', (function(event) { event.stop(); this.changeImage(this.activeImage + 1); }).bindAsEventListener(this));
|
170
|
+
$('loadingLink').observe('click', (function(event) { event.stop(); this.end(); }).bind(this));
|
171
|
+
$('bottomNavClose').observe('click', (function(event) { event.stop(); this.end(); }).bind(this));
|
172
|
+
|
173
|
+
var th = this;
|
174
|
+
(function(){
|
175
|
+
var ids =
|
176
|
+
'overlay lightbox outerImageContainer imageContainer lightboxImage hoverNav prevLink nextLink loading loadingLink ' +
|
177
|
+
'imageDataContainer imageData imageDetails caption numberDisplay bottomNav bottomNavClose';
|
178
|
+
$w(ids).each(function(id){ th[id] = $(id); });
|
179
|
+
}).defer();
|
180
|
+
},
|
181
|
+
|
182
|
+
//
|
183
|
+
// updateImageList()
|
184
|
+
// Loops through anchor tags looking for 'lightbox' references and applies onclick
|
185
|
+
// events to appropriate links. You can rerun after dynamically adding images w/ajax.
|
186
|
+
//
|
187
|
+
updateImageList: function() {
|
188
|
+
this.updateImageList = Prototype.emptyFunction;
|
189
|
+
|
190
|
+
document.observe('click', (function(event){
|
191
|
+
var target = event.findElement('a[rel^=lightbox]') || event.findElement('area[rel^=lightbox]');
|
192
|
+
if (target) {
|
193
|
+
event.stop();
|
194
|
+
this.start(target);
|
195
|
+
}
|
196
|
+
}).bind(this));
|
197
|
+
},
|
198
|
+
|
199
|
+
//
|
200
|
+
// start()
|
201
|
+
// Display overlay and lightbox. If image is part of a set, add siblings to imageArray.
|
202
|
+
//
|
203
|
+
start: function(imageLink) {
|
204
|
+
|
205
|
+
$$('select', 'object', 'embed').each(function(node){ node.style.visibility = 'hidden' });
|
206
|
+
|
207
|
+
// stretch overlay to fill page and fade in
|
208
|
+
var arrayPageSize = this.getPageSize();
|
209
|
+
$('overlay').setStyle({ width: arrayPageSize[0] + 'px', height: arrayPageSize[1] + 'px' });
|
210
|
+
|
211
|
+
new Effect.Appear(this.overlay, { duration: this.overlayDuration, from: 0.0, to: LightboxOptions.overlayOpacity });
|
212
|
+
|
213
|
+
this.imageArray = [];
|
214
|
+
var imageNum = 0;
|
215
|
+
|
216
|
+
if ((imageLink.rel == 'lightbox')){
|
217
|
+
// if image is NOT part of a set, add single image to imageArray
|
218
|
+
this.imageArray.push([imageLink.href, imageLink.title]);
|
219
|
+
} else {
|
220
|
+
// if image is part of a set..
|
221
|
+
this.imageArray =
|
222
|
+
$$(imageLink.tagName + '[href][rel="' + imageLink.rel + '"]').
|
223
|
+
collect(function(anchor){ return [anchor.href, anchor.title]; }).
|
224
|
+
uniq();
|
225
|
+
|
226
|
+
while (this.imageArray[imageNum][0] != imageLink.href) { imageNum++; }
|
227
|
+
}
|
228
|
+
|
229
|
+
// calculate top and left offset for the lightbox
|
230
|
+
var arrayPageScroll = document.viewport.getScrollOffsets();
|
231
|
+
var lightboxTop = arrayPageScroll[1] + (document.viewport.getHeight() / 10);
|
232
|
+
var lightboxLeft = arrayPageScroll[0];
|
233
|
+
this.lightbox.setStyle({ top: lightboxTop + 'px', left: lightboxLeft + 'px' }).show();
|
234
|
+
|
235
|
+
this.changeImage(imageNum);
|
236
|
+
},
|
237
|
+
|
238
|
+
//
|
239
|
+
// changeImage()
|
240
|
+
// Hide most elements and preload image in preparation for resizing image container.
|
241
|
+
//
|
242
|
+
changeImage: function(imageNum) {
|
243
|
+
|
244
|
+
this.activeImage = imageNum; // update global var
|
245
|
+
|
246
|
+
// hide elements during transition
|
247
|
+
if (LightboxOptions.animate) this.loading.show();
|
248
|
+
this.lightboxImage.hide();
|
249
|
+
this.hoverNav.hide();
|
250
|
+
this.prevLink.hide();
|
251
|
+
this.nextLink.hide();
|
252
|
+
// HACK: Opera9 does not currently support scriptaculous opacity and appear fx
|
253
|
+
this.imageDataContainer.setStyle({opacity: .0001});
|
254
|
+
this.numberDisplay.hide();
|
255
|
+
|
256
|
+
var imgPreloader = new Image();
|
257
|
+
|
258
|
+
// once image is preloaded, resize image container
|
259
|
+
|
260
|
+
|
261
|
+
imgPreloader.onload = (function(){
|
262
|
+
this.lightboxImage.src = this.imageArray[this.activeImage][0];
|
263
|
+
this.resizeImageContainer(imgPreloader.width, imgPreloader.height);
|
264
|
+
}).bind(this);
|
265
|
+
imgPreloader.src = this.imageArray[this.activeImage][0];
|
266
|
+
},
|
267
|
+
|
268
|
+
//
|
269
|
+
// resizeImageContainer()
|
270
|
+
//
|
271
|
+
resizeImageContainer: function(imgWidth, imgHeight) {
|
272
|
+
|
273
|
+
// get current width and height
|
274
|
+
var widthCurrent = this.outerImageContainer.getWidth();
|
275
|
+
var heightCurrent = this.outerImageContainer.getHeight();
|
276
|
+
|
277
|
+
// get new width and height
|
278
|
+
var widthNew = (imgWidth + LightboxOptions.borderSize * 2);
|
279
|
+
var heightNew = (imgHeight + LightboxOptions.borderSize * 2);
|
280
|
+
|
281
|
+
// scalars based on change from old to new
|
282
|
+
var xScale = (widthNew / widthCurrent) * 100;
|
283
|
+
var yScale = (heightNew / heightCurrent) * 100;
|
284
|
+
|
285
|
+
// calculate size difference between new and old image, and resize if necessary
|
286
|
+
var wDiff = widthCurrent - widthNew;
|
287
|
+
var hDiff = heightCurrent - heightNew;
|
288
|
+
|
289
|
+
if (hDiff != 0) new Effect.Scale(this.outerImageContainer, yScale, {scaleX: false, duration: this.resizeDuration, queue: 'front'});
|
290
|
+
if (wDiff != 0) new Effect.Scale(this.outerImageContainer, xScale, {scaleY: false, duration: this.resizeDuration, delay: this.resizeDuration});
|
291
|
+
|
292
|
+
// if new and old image are same size and no scaling transition is necessary,
|
293
|
+
// do a quick pause to prevent image flicker.
|
294
|
+
var timeout = 0;
|
295
|
+
if ((hDiff == 0) && (wDiff == 0)){
|
296
|
+
timeout = 100;
|
297
|
+
if (Prototype.Browser.IE) timeout = 250;
|
298
|
+
}
|
299
|
+
|
300
|
+
(function(){
|
301
|
+
this.prevLink.setStyle({ height: imgHeight + 'px' });
|
302
|
+
this.nextLink.setStyle({ height: imgHeight + 'px' });
|
303
|
+
this.imageDataContainer.setStyle({ width: widthNew + 'px' });
|
304
|
+
|
305
|
+
this.showImage();
|
306
|
+
}).bind(this).delay(timeout / 1000);
|
307
|
+
},
|
308
|
+
|
309
|
+
//
|
310
|
+
// showImage()
|
311
|
+
// Display image and begin preloading neighbors.
|
312
|
+
//
|
313
|
+
showImage: function(){
|
314
|
+
this.loading.hide();
|
315
|
+
new Effect.Appear(this.lightboxImage, {
|
316
|
+
duration: this.resizeDuration,
|
317
|
+
queue: 'end',
|
318
|
+
afterFinish: (function(){ this.updateDetails(); }).bind(this)
|
319
|
+
});
|
320
|
+
this.preloadNeighborImages();
|
321
|
+
},
|
322
|
+
|
323
|
+
//
|
324
|
+
// updateDetails()
|
325
|
+
// Display caption, image number, and bottom nav.
|
326
|
+
//
|
327
|
+
updateDetails: function() {
|
328
|
+
|
329
|
+
// if caption is not null
|
330
|
+
if (this.imageArray[this.activeImage][1] != ""){
|
331
|
+
this.caption.update(this.imageArray[this.activeImage][1]).show();
|
332
|
+
}
|
333
|
+
|
334
|
+
// if image is part of set display 'Image x of x'
|
335
|
+
if (this.imageArray.length > 1){
|
336
|
+
this.numberDisplay.update( LightboxOptions.labelImage + ' ' + (this.activeImage + 1) + ' ' + LightboxOptions.labelOf + ' ' + this.imageArray.length).show();
|
337
|
+
}
|
338
|
+
|
339
|
+
new Effect.Parallel(
|
340
|
+
[
|
341
|
+
new Effect.SlideDown(this.imageDataContainer, { sync: true, duration: this.resizeDuration, from: 0.0, to: 1.0 }),
|
342
|
+
new Effect.Appear(this.imageDataContainer, { sync: true, duration: this.resizeDuration })
|
343
|
+
],
|
344
|
+
{
|
345
|
+
duration: this.resizeDuration,
|
346
|
+
afterFinish: (function() {
|
347
|
+
// update overlay size and update nav
|
348
|
+
var arrayPageSize = this.getPageSize();
|
349
|
+
this.overlay.setStyle({ height: arrayPageSize[1] + 'px' });
|
350
|
+
this.updateNav();
|
351
|
+
}).bind(this)
|
352
|
+
}
|
353
|
+
);
|
354
|
+
},
|
355
|
+
|
356
|
+
//
|
357
|
+
// updateNav()
|
358
|
+
// Display appropriate previous and next hover navigation.
|
359
|
+
//
|
360
|
+
updateNav: function() {
|
361
|
+
|
362
|
+
this.hoverNav.show();
|
363
|
+
|
364
|
+
// if not first image in set, display prev image button
|
365
|
+
if (this.activeImage > 0) this.prevLink.show();
|
366
|
+
|
367
|
+
// if not last image in set, display next image button
|
368
|
+
if (this.activeImage < (this.imageArray.length - 1)) this.nextLink.show();
|
369
|
+
|
370
|
+
this.enableKeyboardNav();
|
371
|
+
},
|
372
|
+
|
373
|
+
//
|
374
|
+
// enableKeyboardNav()
|
375
|
+
//
|
376
|
+
enableKeyboardNav: function() {
|
377
|
+
document.observe('keydown', this.keyboardAction);
|
378
|
+
},
|
379
|
+
|
380
|
+
//
|
381
|
+
// disableKeyboardNav()
|
382
|
+
//
|
383
|
+
disableKeyboardNav: function() {
|
384
|
+
document.stopObserving('keydown', this.keyboardAction);
|
385
|
+
},
|
386
|
+
|
387
|
+
//
|
388
|
+
// keyboardAction()
|
389
|
+
//
|
390
|
+
keyboardAction: function(event) {
|
391
|
+
var keycode = event.keyCode;
|
392
|
+
|
393
|
+
var escapeKey;
|
394
|
+
if (event.DOM_VK_ESCAPE) { // mozilla
|
395
|
+
escapeKey = event.DOM_VK_ESCAPE;
|
396
|
+
} else { // ie
|
397
|
+
escapeKey = 27;
|
398
|
+
}
|
399
|
+
|
400
|
+
var key = String.fromCharCode(keycode).toLowerCase();
|
401
|
+
|
402
|
+
if (key.match(/x|o|c/) || (keycode == escapeKey)){ // close lightbox
|
403
|
+
this.end();
|
404
|
+
} else if ((key == 'p') || (keycode == 37)){ // display previous image
|
405
|
+
if (this.activeImage != 0){
|
406
|
+
this.disableKeyboardNav();
|
407
|
+
this.changeImage(this.activeImage - 1);
|
408
|
+
}
|
409
|
+
} else if ((key == 'n') || (keycode == 39)){ // display next image
|
410
|
+
if (this.activeImage != (this.imageArray.length - 1)){
|
411
|
+
this.disableKeyboardNav();
|
412
|
+
this.changeImage(this.activeImage + 1);
|
413
|
+
}
|
414
|
+
}
|
415
|
+
},
|
416
|
+
|
417
|
+
//
|
418
|
+
// preloadNeighborImages()
|
419
|
+
// Preload previous and next images.
|
420
|
+
//
|
421
|
+
preloadNeighborImages: function(){
|
422
|
+
var preloadNextImage, preloadPrevImage;
|
423
|
+
if (this.imageArray.length > this.activeImage + 1){
|
424
|
+
preloadNextImage = new Image();
|
425
|
+
preloadNextImage.src = this.imageArray[this.activeImage + 1][0];
|
426
|
+
}
|
427
|
+
if (this.activeImage > 0){
|
428
|
+
preloadPrevImage = new Image();
|
429
|
+
preloadPrevImage.src = this.imageArray[this.activeImage - 1][0];
|
430
|
+
}
|
431
|
+
|
432
|
+
},
|
433
|
+
|
434
|
+
//
|
435
|
+
// end()
|
436
|
+
//
|
437
|
+
end: function() {
|
438
|
+
this.disableKeyboardNav();
|
439
|
+
this.lightbox.hide();
|
440
|
+
new Effect.Fade(this.overlay, { duration: this.overlayDuration });
|
441
|
+
$$('select', 'object', 'embed').each(function(node){ node.style.visibility = 'visible' });
|
442
|
+
},
|
443
|
+
|
444
|
+
//
|
445
|
+
// getPageSize()
|
446
|
+
//
|
447
|
+
getPageSize: function() {
|
448
|
+
|
449
|
+
var xScroll, yScroll;
|
450
|
+
|
451
|
+
if (window.innerHeight && window.scrollMaxY) {
|
452
|
+
xScroll = window.innerWidth + window.scrollMaxX;
|
453
|
+
yScroll = window.innerHeight + window.scrollMaxY;
|
454
|
+
} else if (document.body.scrollHeight > document.body.offsetHeight){ // all but Explorer Mac
|
455
|
+
xScroll = document.body.scrollWidth;
|
456
|
+
yScroll = document.body.scrollHeight;
|
457
|
+
} else { // Explorer Mac...would also work in Explorer 6 Strict, Mozilla and Safari
|
458
|
+
xScroll = document.body.offsetWidth;
|
459
|
+
yScroll = document.body.offsetHeight;
|
460
|
+
}
|
461
|
+
|
462
|
+
var windowWidth, windowHeight;
|
463
|
+
|
464
|
+
if (self.innerHeight) { // all except Explorer
|
465
|
+
if(document.documentElement.clientWidth){
|
466
|
+
windowWidth = document.documentElement.clientWidth;
|
467
|
+
} else {
|
468
|
+
windowWidth = self.innerWidth;
|
469
|
+
}
|
470
|
+
windowHeight = self.innerHeight;
|
471
|
+
} else if (document.documentElement && document.documentElement.clientHeight) { // Explorer 6 Strict Mode
|
472
|
+
windowWidth = document.documentElement.clientWidth;
|
473
|
+
windowHeight = document.documentElement.clientHeight;
|
474
|
+
} else if (document.body) { // other Explorers
|
475
|
+
windowWidth = document.body.clientWidth;
|
476
|
+
windowHeight = document.body.clientHeight;
|
477
|
+
}
|
478
|
+
|
479
|
+
// for small pages with total height less then height of the viewport
|
480
|
+
if(yScroll < windowHeight){
|
481
|
+
pageHeight = windowHeight;
|
482
|
+
} else {
|
483
|
+
pageHeight = yScroll;
|
484
|
+
}
|
485
|
+
|
486
|
+
// for small pages with total width less then width of the viewport
|
487
|
+
if(xScroll < windowWidth){
|
488
|
+
pageWidth = xScroll;
|
489
|
+
} else {
|
490
|
+
pageWidth = windowWidth;
|
491
|
+
}
|
492
|
+
|
493
|
+
return [pageWidth,pageHeight];
|
494
|
+
}
|
495
|
+
}
|
496
|
+
|
497
|
+
document.observe('dom:loaded', function () { new Lightbox(); });
|