Compare commits
5 Commits
0913_ntu_s
...
master
Author | SHA1 | Date |
---|---|---|
chris | f8bb0bba56 | |
Spen | 47b8b3e277 | |
chris | ecc3581106 | |
Matthew K. Fu JuYuan | 6d4d3ccfd4 | |
Harry Bomrah | 141b708392 |
|
@ -4,8 +4,6 @@
|
||||||
.rvmrc
|
.rvmrc
|
||||||
|
|
||||||
Gemfile.lock
|
Gemfile.lock
|
||||||
Procfile
|
|
||||||
log/*
|
|
||||||
|
|
||||||
db/*.sqlite3
|
db/*.sqlite3
|
||||||
log/*.log
|
log/*.log
|
||||||
|
|
|
@ -15,6 +15,11 @@ function load_tinymce() {
|
||||||
theme_advanced_statusbar_location : "bottom",
|
theme_advanced_statusbar_location : "bottom",
|
||||||
theme_advanced_resizing : true,
|
theme_advanced_resizing : true,
|
||||||
|
|
||||||
|
// Domain Absolute URLs
|
||||||
|
relative_urls : false,
|
||||||
|
remove_script_host : false,
|
||||||
|
document_base_url: window.location.protocol + '//' + window.location.host,
|
||||||
|
|
||||||
// Skin options
|
// Skin options
|
||||||
skin : "o2k7",
|
skin : "o2k7",
|
||||||
skin_variant : "silver",
|
skin_variant : "silver",
|
||||||
|
|
|
@ -100,8 +100,9 @@ div[data-role="page"] {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
border: none;
|
border: none;
|
||||||
z-index: 50;
|
z-index: 50;
|
||||||
background-image: -webkit-linear-gradient(top, #e35479, #cb2d56);
|
/*background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#545b60), to(#191a1c));*/
|
||||||
-webkit-box-shadow: 0 1px 3px rgba(0,0,0,0.8),inset 0 1px 0 #7f95a5,0 -1px 0 #1f2024 inset;
|
background-image: -webkit-linear-gradient(top, #5282A6, #133757);
|
||||||
|
-webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.8), inset 0 1px 0 rgba(127, 149, 165, 1), 0 -1px 0 rgba(31, 32, 36, 1) inset;
|
||||||
}
|
}
|
||||||
.header h1.ui-title {
|
.header h1.ui-title {
|
||||||
margin: 8px 30%;
|
margin: 8px 30%;
|
||||||
|
@ -114,12 +115,14 @@ div[data-role="page"] {
|
||||||
left: 50%;
|
left: 50%;
|
||||||
margin-left: -15px;
|
margin-left: -15px;
|
||||||
font-size: 20px;
|
font-size: 20px;
|
||||||
color: #ffc8e7;
|
/*color: #727272;*/
|
||||||
background-color: #cb2d56;
|
color: #7CA6C5;
|
||||||
|
/*background-color: #252525;*/
|
||||||
|
background-color: #144366;
|
||||||
border-radius: 0 0 5px 5px;
|
border-radius: 0 0 5px 5px;
|
||||||
height: 15px;
|
height: 15px;
|
||||||
line-height: 16px;
|
line-height: 16px;
|
||||||
box-shadow: 1px 2px 2px rgba(0,0,0,0.5);
|
box-shadow: 1px 2px 2px rgba(0, 0, 0, .5);
|
||||||
}
|
}
|
||||||
.header .language .ui-btn-text {
|
.header .language .ui-btn-text {
|
||||||
left: 0;
|
left: 0;
|
||||||
|
@ -132,14 +135,14 @@ div[data-role="page"] {
|
||||||
background-image: none;
|
background-image: none;
|
||||||
}
|
}
|
||||||
.header .ui-btn-up-a {
|
.header .ui-btn-up-a {
|
||||||
border: 1px solid #a21050;
|
border: 1px solid #133547;
|
||||||
background-color: #cb2d56;
|
background-color: #0C4C64;
|
||||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#e35479), to(#cb2d56));
|
background-image: -webkit-gradient(linear, left top, left bottom, from( #0D6691 ), to( #0E3A4B ));
|
||||||
background-image: -webkit-linear-gradient(#e35479, #cb2d56);
|
background-image: -webkit-linear-gradient( #0D6691 , #0E3A4B );
|
||||||
background-image: -moz-linear-gradient(#e35479, #cb2d56);
|
background-image: -moz-linear-gradient( #0D6691 , #0E3A4B );
|
||||||
background-image: -ms-linear-gradient(#e35479, #cb2d56);
|
background-image: -ms-linear-gradient( #0D6691 , #0E3A4B );
|
||||||
background-image: -o-linear-gradient(#e35479, #cb2d56);
|
background-image: -o-linear-gradient( #0D6691 , #0E3A4B );
|
||||||
background-image: linear-gradient(#e35479, #cb2d56);
|
background-image: linear-gradient( #0D6691 , #0E3A4B );
|
||||||
}
|
}
|
||||||
.header h1 img {
|
.header h1 img {
|
||||||
height: 30px;
|
height: 30px;
|
|
@ -43,7 +43,7 @@ class MobileController < ApplicationController
|
||||||
|
|
||||||
def page
|
def page
|
||||||
@page_title = t('mobile.page')
|
@page_title = t('mobile.page')
|
||||||
@page_contexts = PageContext.where(:archived => false).page(params[:page_main]).per(15)
|
@page_contexts = get_sorted_page_from_structure
|
||||||
end
|
end
|
||||||
|
|
||||||
def page_content
|
def page_content
|
||||||
|
@ -57,4 +57,12 @@ class MobileController < ApplicationController
|
||||||
@no_footer = true if request.path =~ /app/
|
@no_footer = true if request.path =~ /app/
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def get_sorted_page_from_structure
|
||||||
|
page_contexts = Item.structure_ordered_items.inject([]){ |pages, page|
|
||||||
|
pages << page.page_contexts.where(archived: false).limit(1)[0] if page.is_a?(Page) && !page.page_contexts.blank?
|
||||||
|
pages
|
||||||
|
}
|
||||||
|
Kaminari.paginate_array(page_contexts).page(params[:page]).per(15)
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
class GetAnnouncementFromRss
|
|
||||||
@queue = :high
|
|
||||||
|
|
||||||
def self.perform()
|
|
||||||
%x(ruby "#{Rails.root}/lib/rss_ntu_job.rb")
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -17,4 +17,4 @@
|
||||||
<%= render :partial=> "widget_ext_options" %>
|
<%= render :partial=> "widget_ext_options" %>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
|
@ -1,17 +1,6 @@
|
||||||
<!DOCTYPE HTML>
|
<!DOCTYPE HTML>
|
||||||
<html class="<%= I18n.locale.to_s %>">
|
<html class="<%= I18n.locale.to_s %>">
|
||||||
<head>
|
<head>
|
||||||
<script type="text/javascript">
|
|
||||||
var _gaq = _gaq || [];
|
|
||||||
_gaq.push(['_setAccount', 'UA-39393439-1']);
|
|
||||||
_gaq.push(['_trackPageview']);
|
|
||||||
|
|
||||||
(function() {
|
|
||||||
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
|
|
||||||
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
|
|
||||||
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
|
|
||||||
})();
|
|
||||||
</script>
|
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
<%= page_title(@item).html_safe %>
|
<%= page_title(@item).html_safe %>
|
||||||
<link rel="shortcut icon" href="<%= asset_path "ncculogo.ico" %>">
|
<link rel="shortcut icon" href="<%= asset_path "ncculogo.ico" %>">
|
||||||
|
|
|
@ -3,6 +3,9 @@
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
<ul>
|
<ul>
|
||||||
<li>學務處電話:<a href="tel:+886-2-3366-2995~2997">+886-2-3366-2995~2997</a></li>
|
<li>總機電話:<a href="tel:+886229393091">02-29393091</a></li>
|
||||||
<li>學務處傳真:+886-2-2391-9095</li>
|
<li>傳真:02-29379611</li>
|
||||||
|
<li>緊急重大事件通聯窗口:校內分機 66119、66110</li>
|
||||||
|
<li>總值日室:<a href="tel:+88229387132">02-29387132</a></li>
|
||||||
|
<li>駐警衛室:<a href="tel:+88229387129">02-29387129</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
|
@ -5,6 +5,6 @@
|
||||||
<div id='map_canvas'></div>
|
<div id='map_canvas'></div>
|
||||||
|
|
||||||
<script type='text/javascript'>
|
<script type='text/javascript'>
|
||||||
var $map_center = "25.015205, 121.535491"
|
var $map_center = "24.987449, 121.576117"
|
||||||
var $map_zoom = 17
|
var $map_zoom = 17
|
||||||
</script>
|
</script>
|
|
@ -4,10 +4,10 @@ en:
|
||||||
bulletin: Bulletin
|
bulletin: Bulletin
|
||||||
contact: Contact
|
contact: Contact
|
||||||
copyright: Copyright
|
copyright: Copyright
|
||||||
copyright_text: Copyright© 2008 National Taiwan University ALL RIGHTS RESERVED
|
copyright_text: Thisi University © All RIGHTS RESERVED.
|
||||||
copyright_orbit: Powered by RulingDigital
|
copyright_orbit: Powered by RulingDigital
|
||||||
home: Home
|
home: Home
|
||||||
language: Language
|
language: Language
|
||||||
location: Location
|
location: Location
|
||||||
location_description: '<h3>National Taiwan University</h3>No. 1, Sec. 4, Roosevelt Road, Taipei, 10617 Taiwan (R.O.C)'
|
location_description: '<h3>This University</h3>No.101,Sec. 2, Jiafeng S Road, Zhubei City, Hsinchu County 302, Taiwan'
|
||||||
page: Page
|
page: Page
|
|
@ -4,10 +4,10 @@ zh_tw:
|
||||||
bulletin: 公告
|
bulletin: 公告
|
||||||
contact: 聯絡資訊
|
contact: 聯絡資訊
|
||||||
copyright: 著作權宣告
|
copyright: 著作權宣告
|
||||||
copyright_text: 本網站著作權屬於國立臺灣大學 學生事務處
|
copyright_text: 本網站著作權屬於本大學。
|
||||||
copyright_orbit: 銳綸數位建置
|
copyright_orbit: 銳綸數位建置
|
||||||
home: 首頁
|
home: 首頁
|
||||||
language: 語言
|
language: 語言
|
||||||
location: 地理位置
|
location: 地理位置
|
||||||
location_description: '<h3>臺灣大學總務處 版權所有</h3>10617 臺北市大安區羅斯福路四段一號'
|
location_description: '<h3>本大學</h3>302新竹縣竹北市嘉豐南路二段101號'
|
||||||
page: 頁面
|
page: 頁面
|
||||||
|
|
|
@ -1,4 +0,0 @@
|
||||||
en:
|
|
||||||
|
|
||||||
ntu:
|
|
||||||
rss_origin: Back to NTU Announcements
|
|
|
@ -1,4 +0,0 @@
|
||||||
zh_tw:
|
|
||||||
|
|
||||||
ntu:
|
|
||||||
rss_origin: 回臺大校園公佈欄
|
|
|
@ -11,7 +11,7 @@ backup_server:
|
||||||
description: BackupServer and remove old backups
|
description: BackupServer and remove old backups
|
||||||
|
|
||||||
update_tag_cloud:
|
update_tag_cloud:
|
||||||
cron: 0 30 2 * * *
|
cron: 0 0 [0,12] * * *
|
||||||
class: UpdateTagCloud
|
class: UpdateTagCloud
|
||||||
args:
|
args:
|
||||||
description: UpdateTagCloud
|
description: UpdateTagCloud
|
||||||
|
@ -27,9 +27,3 @@ email_cron:
|
||||||
class: EmailCron
|
class: EmailCron
|
||||||
args:
|
args:
|
||||||
description: EmailCron
|
description: EmailCron
|
||||||
|
|
||||||
get_announcement_from_rss:
|
|
||||||
cron: 0 0 [2,12] * * *
|
|
||||||
class: GetAnnouncementFromRss
|
|
||||||
args:
|
|
||||||
description: Loop through the announcement RSS until 24h ago
|
|
||||||
|
|
|
@ -1,99 +0,0 @@
|
||||||
# encoding: utf-8
|
|
||||||
|
|
||||||
# encoding: utf-8
|
|
||||||
|
|
||||||
require 'rss'
|
|
||||||
require 'mongo'
|
|
||||||
|
|
||||||
AUTHORS = %w[ 學生事務處-學生住宿服務組
|
|
||||||
學生事務處-學生職業生涯發展中心
|
|
||||||
學生事務處-衛生保健及醫療中心
|
|
||||||
學生事務處-課外活動指導組
|
|
||||||
學生事務處-學生活動中心管理組
|
|
||||||
學生事務處-僑生及陸生輔導組
|
|
||||||
學生事務處-生活輔導組
|
|
||||||
學生事務處-軍訓組
|
|
||||||
學生事務處-學生心理輔導中心
|
|
||||||
學生事務處-學生事務處]
|
|
||||||
|
|
||||||
DB_BASE_NAME = "site"
|
|
||||||
|
|
||||||
all = []
|
|
||||||
continue = true
|
|
||||||
i = 1
|
|
||||||
yesterday = Time.now - 86400
|
|
||||||
|
|
||||||
while continue do
|
|
||||||
open("http://ann.cc.ntu.edu.tw/asp/rss.asp?page=#{i}") do |rss|
|
|
||||||
feed = RSS::Parser.parse(rss.read.encode('utf-8', 'big5', invalid: :replace, undef: :replace, replace: '').gsub('<pubDate>Wes,', '<pubDate>Wed,').gsub(/(encoding=\"big5\")/, 'encoding="utf-8"'))
|
|
||||||
feed.items.each do |item|
|
|
||||||
if item.pubDate > yesterday
|
|
||||||
if AUTHORS.include?(item.author)
|
|
||||||
author = item.author.strip
|
|
||||||
category = item.category.to_s.gsub(/\<(\/)*category\>/, '')
|
|
||||||
all << {title: item.title.strip, author: author, link: item.link.strip, date: item.pubDate, category: category, description: item.description.gsub("\r\n", '<br/>').strip}
|
|
||||||
end
|
|
||||||
else
|
|
||||||
continue = false
|
|
||||||
break
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
i += 1
|
|
||||||
end
|
|
||||||
|
|
||||||
# Get corresponding category_id or create a new one
|
|
||||||
def get_category_id(category, categories, coll_cat)
|
|
||||||
if categories.keys.include? "rss_#{category}"
|
|
||||||
[categories["rss_#{category}"], categories]
|
|
||||||
else
|
|
||||||
cat = {
|
|
||||||
_type: "BulletinCategory",
|
|
||||||
key: "rss_#{category}",
|
|
||||||
disable: false,
|
|
||||||
title: {:zh_tw => category},
|
|
||||||
created_at: Time.now,
|
|
||||||
updated_at: Time.now
|
|
||||||
}
|
|
||||||
categories["rss_#{category}"] = result = coll_cat.save(cat)
|
|
||||||
[result, categories]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# Get categories and id based on a given site number
|
|
||||||
def get_mongo_and_categories(site_number="0")
|
|
||||||
db = Mongo::Connection.new("localhost", 27017).db("#{DB_BASE_NAME}_#{site_number}")
|
|
||||||
coll_bulletin = db["bulletins"]
|
|
||||||
coll_cat = db["bulletin_categories"]
|
|
||||||
|
|
||||||
categories = coll_cat.find().to_a.inject({}) do |categories, category|
|
|
||||||
categories[category['key']] = category['_id']
|
|
||||||
categories
|
|
||||||
end
|
|
||||||
[categories, coll_bulletin, coll_cat]
|
|
||||||
end
|
|
||||||
|
|
||||||
# Get categories
|
|
||||||
categories, coll_bulletin, coll_cat = get_mongo_and_categories
|
|
||||||
|
|
||||||
all.each do |bul| # Loop through all the items
|
|
||||||
category_id, categories = get_category_id(bul[:category], categories, coll_cat)
|
|
||||||
unless coll_bulletin.find_one(rss_link: bul[:link])
|
|
||||||
bulletin = { _type: "Bulletin",
|
|
||||||
postdate: bul[:date],
|
|
||||||
created_at: bul[:date],
|
|
||||||
updated_at: bul[:date],
|
|
||||||
is_checked: true,
|
|
||||||
is_pending: false,
|
|
||||||
is_rejected: false,
|
|
||||||
bulletin_category_id: category_id,
|
|
||||||
title: {:zh_tw => bul[:title]},
|
|
||||||
text: {:zh_tw => bul[:description]},
|
|
||||||
available_for_zh_tw: true,
|
|
||||||
rss_link: bul[:link] }
|
|
||||||
coll_bulletin.save(bulletin)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,91 +0,0 @@
|
||||||
# encoding: utf-8
|
|
||||||
|
|
||||||
require 'rss'
|
|
||||||
require 'mongo'
|
|
||||||
|
|
||||||
AUTHORS = %w[ 學生事務處-學生住宿服務組
|
|
||||||
學生事務處-學生職業生涯發展中心
|
|
||||||
學生事務處-衛生保健及醫療中心
|
|
||||||
學生事務處-課外活動指導組
|
|
||||||
學生事務處-學生活動中心管理組
|
|
||||||
學生事務處-僑生及陸生輔導組
|
|
||||||
學生事務處-生活輔導組
|
|
||||||
學生事務處-軍訓組
|
|
||||||
學生事務處-學生心理輔導中心
|
|
||||||
學生事務處-學生事務處]
|
|
||||||
|
|
||||||
DB_BASE_NAME = "site"
|
|
||||||
|
|
||||||
all = []
|
|
||||||
continue = true
|
|
||||||
i = 1
|
|
||||||
while continue do
|
|
||||||
open("http://ann.cc.ntu.edu.tw/asp/rss.asp?page=#{i}") do |rss|
|
|
||||||
feed = RSS::Parser.parse(rss.read.encode('utf-8', 'big5', invalid: :replace, undef: :replace, replace: '').gsub('<pubDate>Wes,', '<pubDate>Wed,').gsub(/(encoding=\"big5\")/, 'encoding="utf-8"'))
|
|
||||||
feed.items.size
|
|
||||||
feed.items.each do |item|
|
|
||||||
if AUTHORS.include?(item.author)
|
|
||||||
author = item.author.strip
|
|
||||||
category = item.category.to_s.gsub(/\<(\/)*category\>/, '')
|
|
||||||
all << {title: item.title.strip, author: author, link: item.link.strip, date: item.pubDate, category: category, description: item.description.gsub("\r\n", '<br/>').strip}
|
|
||||||
end
|
|
||||||
end
|
|
||||||
continue = false if feed.items.size < 100
|
|
||||||
end
|
|
||||||
i += 1
|
|
||||||
end
|
|
||||||
|
|
||||||
# Get corresponding category_id or create a new one
|
|
||||||
def get_category_id(category, categories, coll_cat)
|
|
||||||
if categories.keys.include? "rss_#{category}"
|
|
||||||
[categories["rss_#{category}"], categories]
|
|
||||||
else
|
|
||||||
cat = {
|
|
||||||
_type: "BulletinCategory",
|
|
||||||
key: "rss_#{category}",
|
|
||||||
disable: false,
|
|
||||||
title: {:zh_tw => category},
|
|
||||||
created_at: Time.now,
|
|
||||||
updated_at: Time.now
|
|
||||||
}
|
|
||||||
categories["rss_#{category}"] = result = coll_cat.save(cat)
|
|
||||||
[result, categories]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# Get categories and id based on a given site number
|
|
||||||
def get_mongo_and_categories(site_number="0")
|
|
||||||
db = Mongo::Connection.new("localhost", 27017).db("#{DB_BASE_NAME}_#{site_number}")
|
|
||||||
coll_bulletin = db["bulletins"]
|
|
||||||
coll_cat = db["bulletin_categories"]
|
|
||||||
|
|
||||||
categories = coll_cat.find().to_a.inject({}) do |categories, category|
|
|
||||||
categories[category['key']] = category['_id']
|
|
||||||
categories
|
|
||||||
end
|
|
||||||
[categories, coll_bulletin, coll_cat]
|
|
||||||
end
|
|
||||||
|
|
||||||
# Get categories
|
|
||||||
categories, coll_bulletin, coll_cat = get_mongo_and_categories
|
|
||||||
|
|
||||||
all.each do |bul| # Loop through all the items
|
|
||||||
category_id, categories = get_category_id(bul[:category], categories, coll_cat)
|
|
||||||
unless coll_bulletin.find_one(rss_link: bul[:link])
|
|
||||||
bulletin = { _type: "Bulletin",
|
|
||||||
postdate: bul[:date],
|
|
||||||
created_at: bul[:date],
|
|
||||||
updated_at: bul[:date],
|
|
||||||
is_checked: true,
|
|
||||||
is_pending: false,
|
|
||||||
is_rejected: false,
|
|
||||||
bulletin_category_id: category_id,
|
|
||||||
title: {:zh_tw => bul[:title]},
|
|
||||||
text: {:zh_tw => bul[:description]},
|
|
||||||
available_for_zh_tw: true,
|
|
||||||
rss_link: bul[:link] }
|
|
||||||
coll_bulletin.save(bulletin)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
|
@ -310,34 +310,6 @@ namespace :migrate do
|
||||||
Rake::Task["web_link_url:web_link_url_i18n"].execute
|
Rake::Task["web_link_url:web_link_url_i18n"].execute
|
||||||
end
|
end
|
||||||
|
|
||||||
task :save_users => :environment do
|
|
||||||
User.where(:email.not => /guest/).each{|s|s.save}
|
|
||||||
end
|
|
||||||
|
|
||||||
task :fix_bulletin_rss_available_lang => :environment do
|
|
||||||
Bulletin.all.each do |bull|
|
|
||||||
if bull.create_user_id.nil?
|
|
||||||
bull.update_attribute(:available_for_zh_tw, true)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
task :fix_imported_rss => :environment do
|
|
||||||
categories = BulletinCategory.where(key: /rss_/).entries
|
|
||||||
unless categories.blank?
|
|
||||||
categories.each do |category|
|
|
||||||
bulletins = category.bulletins
|
|
||||||
unless bulletins.blank?
|
|
||||||
bulletins.each do |bulletin|
|
|
||||||
bulletin.update_attribute(:is_top, false) unless bulletin.is_top?
|
|
||||||
bulletin.update_attribute(:is_hot, false) unless bulletin.is_hot?
|
|
||||||
bulletin.update_attribute(:is_hidden, false) unless bulletin.is_hidden?
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
task :fix_tagged_ids => :environment do
|
task :fix_tagged_ids => :environment do
|
||||||
Tag.all.each do |tag|
|
Tag.all.each do |tag|
|
||||||
tag.taggings.each do |tagging|
|
tag.taggings.each do |tagging|
|
||||||
|
|
|
@ -1,168 +0,0 @@
|
||||||
# encoding: utf-8
|
|
||||||
|
|
||||||
namespace :mongo_files do
|
|
||||||
|
|
||||||
MODELS = { 'ad_image' => 'file',
|
|
||||||
'archive_file_multiple' => 'file',
|
|
||||||
'asset' => 'data',
|
|
||||||
'bulletin' => 'image',
|
|
||||||
'bulletin_file' => 'file',
|
|
||||||
'design' => 'zip_file',
|
|
||||||
'design_file' => 'file',
|
|
||||||
'gallery_image' => 'file',
|
|
||||||
'image' => 'file',
|
|
||||||
'lab_file' => 'file',
|
|
||||||
'location_info' => 'file',
|
|
||||||
'preview_file' => 'file',
|
|
||||||
'project_file' => 'file',
|
|
||||||
'research_file' => 'file',
|
|
||||||
'site' => 'default_image',
|
|
||||||
'stylesheet' => 'file_orig',
|
|
||||||
'user' => 'avatar',
|
|
||||||
'writing_book_file' => 'file',
|
|
||||||
'writing_conference_file' => 'file',
|
|
||||||
'writing_journal_file' => 'file',
|
|
||||||
'writing_patent_file' => 'file' }
|
|
||||||
|
|
||||||
IMAGE_UPLOADER_MODELS = %w[ad_image bulletin image site]
|
|
||||||
|
|
||||||
task :clean => :environment do
|
|
||||||
@files = Mongoid.database['fs.files']
|
|
||||||
@chunks = Mongoid.database['fs.chunks']
|
|
||||||
clean_duplicates
|
|
||||||
clean_unused
|
|
||||||
remove_objects
|
|
||||||
end
|
|
||||||
|
|
||||||
# Remove unused files from db
|
|
||||||
def clean_unused
|
|
||||||
db_array = @files.find().inject([]) do |db_files, file|
|
|
||||||
db_files << file['filename']
|
|
||||||
db_files
|
|
||||||
end
|
|
||||||
|
|
||||||
p "# of files in db: #{db_array.size}"
|
|
||||||
|
|
||||||
name_array = MODELS.inject([]) do |model_files, (model, type)|
|
|
||||||
model.classify.constantize.all.each do |item|
|
|
||||||
url = item.send(type).url
|
|
||||||
thumb_url = item.send(type).thumb.url rescue nil
|
|
||||||
if url && !url.eql?('sign-in-logo.png')
|
|
||||||
url = url.gsub('/gridfs/', '')
|
|
||||||
model_files << url
|
|
||||||
end
|
|
||||||
if thumb_url && !thumb_url.eql?('sign-in-logo.png')
|
|
||||||
thumb_url = thumb_url.gsub('/gridfs/', '')
|
|
||||||
model_files << thumb_url
|
|
||||||
end
|
|
||||||
end
|
|
||||||
model_files
|
|
||||||
end
|
|
||||||
|
|
||||||
p "# of files from uploaders: #{name_array.size}"
|
|
||||||
useless_files = db_array - name_array
|
|
||||||
p "# of unmatched files: #{useless_files.size}"
|
|
||||||
|
|
||||||
useless_files.each do |file|
|
|
||||||
id = @files.find_one('filename' => file)['_id']
|
|
||||||
@files.remove('_id' => id)
|
|
||||||
@chunks.remove('files_id' => id)
|
|
||||||
end
|
|
||||||
# p files.remove('filename' => { "$in" => useless_files})
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
# Remove duplicate files from db
|
|
||||||
def clean_duplicates
|
|
||||||
p "# of files in db: #{@files.count}"
|
|
||||||
file_hash = @files.find().sort({uploadDate: -1}).inject({}) do |db_files, file|
|
|
||||||
name = file['filename']
|
|
||||||
if db_files[name]
|
|
||||||
db_files[name] += [file['_id']]
|
|
||||||
else
|
|
||||||
db_files[name] = [file['_id']]
|
|
||||||
end
|
|
||||||
db_files
|
|
||||||
end
|
|
||||||
file_array = file_hash.inject([]) do |files, (key, value)|
|
|
||||||
files += value.drop(1) if value.size > 1
|
|
||||||
files
|
|
||||||
end
|
|
||||||
p "# of duplicate ids to delete: #{file_array.size}"
|
|
||||||
file_array.each do |id|
|
|
||||||
@files.remove('_id' => id)
|
|
||||||
@chunks.remove('files_id' => id)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
task :file_size => :environment do
|
|
||||||
files = Mongoid.database['fs.files']
|
|
||||||
size_array = files.find().inject([]) do |size, file|
|
|
||||||
# size << [file['length'], file['filename']]
|
|
||||||
size << [file['filename'], file['length']]
|
|
||||||
size
|
|
||||||
end
|
|
||||||
size_array.sort.each do |pair|
|
|
||||||
p "#{pair[0]} - #{pair[1]}"
|
|
||||||
end
|
|
||||||
p size_array.size
|
|
||||||
end
|
|
||||||
|
|
||||||
def remove_objects
|
|
||||||
# Destroy writing_journals and writing_journal_files
|
|
||||||
Mongoid.database['writing_journals'].remove()
|
|
||||||
Mongoid.database['writing_journal_files'].remove()
|
|
||||||
|
|
||||||
db_array = @files.find().inject([]) do |db_files, file|
|
|
||||||
db_files << file['filename'] if file['filename'] =~ /writing_journal_file|news_bulletin_file|image\/image/
|
|
||||||
db_files
|
|
||||||
end
|
|
||||||
p db_array.size
|
|
||||||
db_array.each do |file|
|
|
||||||
id = @files.find_one('filename' => file)['_id']
|
|
||||||
@files.remove('_id' => id)
|
|
||||||
@chunks.remove('files_id' => id)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def remove_unlinked
|
|
||||||
# name_array = AdBanner.all.inject([]) do |files, banner|
|
|
||||||
# banner.ad_images.inject(files) do |image_files, image|
|
|
||||||
# url = image.file.url
|
|
||||||
# thumb_url = image.file.thumb.url rescue nil
|
|
||||||
# if url && !url.eql?('sign-in-logo.png')
|
|
||||||
# url = url.gsub('/gridfs/', '')
|
|
||||||
# image_files << url
|
|
||||||
# end
|
|
||||||
# if thumb_url && !thumb_url.eql?('sign-in-logo.png')
|
|
||||||
# thumb_url = thumb_url.gsub('/gridfs/', '')
|
|
||||||
# image_files << thumb_url
|
|
||||||
# end
|
|
||||||
# image_files
|
|
||||||
# end
|
|
||||||
# files
|
|
||||||
# end
|
|
||||||
name_array = Design.all.inject([]) do |files, design|
|
|
||||||
files += design.images.inject(files) do |image_files, image|
|
|
||||||
p image_files += get_url_and_thumb(image.file)
|
|
||||||
image_files
|
|
||||||
end
|
|
||||||
files
|
|
||||||
end
|
|
||||||
p name_array.size
|
|
||||||
end
|
|
||||||
|
|
||||||
def get_url_and_thumb(file)
|
|
||||||
url = file.url
|
|
||||||
thumb_url = file.thumb.url rescue nil
|
|
||||||
files = [url, thumb_url].inject([]) do |urls, current|
|
|
||||||
urls << current.gsub('/gridfs/', '') if current && !current.eql?('sign-in-logo.png')
|
|
||||||
urls
|
|
||||||
end
|
|
||||||
files
|
|
||||||
end
|
|
||||||
|
|
||||||
task :delete_rss_ann => :environment do
|
|
||||||
Bulletin.where(create_user_id: nil).destroy
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -9,17 +9,17 @@ namespace :web_link_url do
|
||||||
|
|
||||||
@weblinks.each do |wl|
|
@weblinks.each do |wl|
|
||||||
|
|
||||||
if wl.url_translations.is_a?(String)
|
if wl.url.nil?
|
||||||
|
|
||||||
@wlurl = wl.url_translations
|
|
||||||
|
|
||||||
wl.url_translations = {}
|
|
||||||
|
|
||||||
wl.url_translations["zh_tw"] = @wlurl
|
|
||||||
|
|
||||||
wl.url_translations["en"] = @wlurl
|
|
||||||
|
|
||||||
wl.save
|
@wlurl = wl.url_translations
|
||||||
|
|
||||||
|
wl.url_translations = {}
|
||||||
|
|
||||||
|
wl.url_translations["zh_tw"] = @wlurl
|
||||||
|
|
||||||
|
wl.url_translations["en"] = @wlurl
|
||||||
|
|
||||||
|
wl.save
|
||||||
|
|
||||||
else
|
else
|
||||||
puts 'no data'
|
puts 'no data'
|
||||||
|
|
|
@ -40,7 +40,6 @@ class Bulletin
|
||||||
field :not_checked_reason
|
field :not_checked_reason
|
||||||
|
|
||||||
field :public, :type => Boolean, :default => true
|
field :public, :type => Boolean, :default => true
|
||||||
field :rss_link
|
|
||||||
|
|
||||||
scope :can_display, where(is_checked: true, is_rejected: false, is_pending: false)
|
scope :can_display, where(is_checked: true, is_rejected: false, is_pending: false)
|
||||||
scope :available_for_lang, ->(locale){ where("available_for_#{locale}".to_sym => true) }
|
scope :available_for_lang, ->(locale){ where("available_for_#{locale}".to_sym => true) }
|
||||||
|
|
|
@ -36,11 +36,6 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
<% unless @bulletin.rss_link.blank? %>
|
|
||||||
<div>
|
|
||||||
<%= link_to t('ntu.rss_origin'), @bulletin.rss_link %>
|
|
||||||
</div>
|
|
||||||
<% end %>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<%= share_links(@bulletin, 'announcement') %>
|
<%= share_links(@bulletin, 'announcement') %>
|
||||||
|
|
|
@ -29,8 +29,8 @@ module Announcement
|
||||||
|
|
||||||
widgets do
|
widgets do
|
||||||
default_widget do
|
default_widget do
|
||||||
sorting 'desc(:postdate)'
|
sorting 'desc(:is_top, :postdate)'
|
||||||
query 'Bulletin.available_for_lang(I18n.locale).any_of( {deadline: nil,:postdate.lte => Time.now} , {:deadline.gte => Time.now,:postdate.lte => Time.now} )'
|
query 'Bulletin.can_display.available_for_lang(I18n.locale).any_of( {deadline: nil,:postdate.lte => Time.now} , {:deadline.gte => Time.now,:postdate.lte => Time.now} )'
|
||||||
enable ["typeA","typeB_style3","typeC"]
|
enable ["typeA","typeB_style3","typeC"]
|
||||||
image :image
|
image :image
|
||||||
field :postdate
|
field :postdate
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 12 KiB |
|
@ -9,15 +9,38 @@ class Panel::Gallery::Widget::AlbumsController < OrbitWidgetController
|
||||||
@album = GalleryAlbum.find(@part.widget_options['album_id']) rescue nil
|
@album = GalleryAlbum.find(@part.widget_options['album_id']) rescue nil
|
||||||
@album_images = @album.gallery_images if @album
|
@album_images = @album.gallery_images if @album
|
||||||
|
|
||||||
|
|
||||||
@settings = {"vertical"=>vertical,"horizontal"=>horizontal} #[note] horizontal has it's limitation from 2 to 6
|
@settings = {"vertical"=>vertical,"horizontal"=>horizontal} #[note] horizontal has it's limitation from 2 to 6
|
||||||
@class = "c" + @settings["horizontal"].to_s
|
@class = "c" + @settings["horizontal"].to_s
|
||||||
@total = @settings["vertical"] * @settings["horizontal"]
|
@total = @settings["vertical"] * @settings["horizontal"]
|
||||||
@rnd = Random.new
|
@rnd = Random.new
|
||||||
@images = []
|
@images = []
|
||||||
for i in 0..@total-1
|
|
||||||
image = @album_images[@rnd.rand(0...@album_images.count)]
|
if @album_images.count > @total
|
||||||
values = {"show_link"=>theater_panel_gallery_front_end_album_path(image),"thumb"=>image.file.thumb.url}
|
@randoms = []
|
||||||
@images << values
|
until @randoms.count == @total do
|
||||||
|
r = @rnd.rand(0...@album_images.count)
|
||||||
|
if !@randoms.include?r
|
||||||
|
@randoms << r
|
||||||
|
image = @album_images[r]
|
||||||
|
values = {"show_link"=>theater_panel_gallery_front_end_album_path(image),"thumb"=>image.file.thumb.url}
|
||||||
|
@images << values
|
||||||
|
end
|
||||||
|
end
|
||||||
|
elsif @album_images.count == @total
|
||||||
|
@album_images.each do |image|
|
||||||
|
values = {"show_link"=>theater_panel_gallery_front_end_album_path(image),"thumb"=>image.file.thumb.url}
|
||||||
|
@images << values
|
||||||
|
end
|
||||||
|
else
|
||||||
|
@album_images.each do |image|
|
||||||
|
values = {"show_link"=>theater_panel_gallery_front_end_album_path(image),"thumb"=>image.file.thumb.url}
|
||||||
|
@images << values
|
||||||
|
end
|
||||||
|
until @images.count == @total do
|
||||||
|
values = {"show_link"=>"javascript:void(0);","thumb"=>"assets/gallery/nodata.jpg"}
|
||||||
|
@images << values
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue