diff --git a/app/controllers/saml_logins_controller.rb b/app/controllers/saml_logins_controller.rb new file mode 100644 index 00000000..8a999cf5 --- /dev/null +++ b/app/controllers/saml_logins_controller.rb @@ -0,0 +1,34 @@ +class SamlLoginsController < ApplicationController + + require "net/http" + require "uri" + require 'rexml/document' + include REXML + + def index + + if params[:wa] == "wsignoutcleanup1.0" #logout + + redirect_to :root + + else #login + + + @wresult = params[:wresult] + @wctx = params[:wctx] + + @main_url = LIST[:sites][@wctx]['url'] + @main_public_key = LIST[:sites][@wctx]['key'] + + @doc = REXML::Document.new @wresult + + public_key = OpenSSL::PKey::RSA.new(@main_public_key) + encrypted_data = public_key.public_encrypt(@doc.elements["//saml:AttributeValue"].text) + + redirect_to "http://#{@main_url}/user_login?" + { :wresult => encrypted_data }.to_param + + end + + end + +end diff --git a/app/jobs/get_announcement_from_rss.rb b/app/jobs/get_announcement_from_rss.rb new file mode 100644 index 00000000..267c29ae --- /dev/null +++ b/app/jobs/get_announcement_from_rss.rb @@ -0,0 +1,7 @@ +class GetAnnouncementFromRss + @queue = :high + + def self.perform() + %x(ruby "#{Rails.root}/lib/rss_ntu_job.rb") + end +end \ No newline at end of file diff --git a/config/list.yml b/config/list.yml index b9722e7c..c8962cfc 100644 --- a/config/list.yml +++ b/config/list.yml @@ -80,3 +80,48 @@ default_widget_style: - style3 - style4 - style5 + +sites: + www: + url: www.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAx3fDAM40XvEiM5oG7YbA\nKnhc5Dyv/ZhVDzyrg95QB0ylBPtSs6g5xgkSSQMnIpAUCzdVIMrUd/A6DuH6f+T5\nccshgh3aDj3wISfgYZc9e7WY1csOItq9lOr6YG4HEABSyjVCcX/RrB8kCuuIGcvR\nRnvu/4fFb93vsVYHwGuivTYRJ+8VM8fOtIFCvbCxZsFj6r5cMl4qI4g4vaIn3xf2\ndXUCICebvdIBfMAdW29yaCScEap1oawEfdXtKCD5vYvAaRZ85jLY/FV5dYhbe1dz\n9G7+B1HI7VBm5bKV0MI1ZH2MTRczaqjLGf6ZF0FbMmcMYLx8iEGL1z0/hgOTcNT6\nrQIDAQAB\n-----END PUBLIC KEY-----\n" + ga: + url: www.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAx3fDAM40XvEiM5oG7YbA\nKnhc5Dyv/ZhVDzyrg95QB0ylBPtSs6g5xgkSSQMnIpAUCzdVIMrUd/A6DuH6f+T5\nccshgh3aDj3wISfgYZc9e7WY1csOItq9lOr6YG4HEABSyjVCcX/RrB8kCuuIGcvR\nRnvu/4fFb93vsVYHwGuivTYRJ+8VM8fOtIFCvbCxZsFj6r5cMl4qI4g4vaIn3xf2\ndXUCICebvdIBfMAdW29yaCScEap1oawEfdXtKCD5vYvAaRZ85jLY/FV5dYhbe1dz\n9G7+B1HI7VBm5bKV0MI1ZH2MTRczaqjLGf6ZF0FbMmcMYLx8iEGL1z0/hgOTcNT6\nrQIDAQAB\n-----END PUBLIC KEY-----\n" + doc: + url: doc.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4aE7R0/49UBf5v4rbNiA\nnaXjPZ9rio9fjkaAZeow62yaZtoGurqf44BVj/cjQVUmLnMU4WDcZMI0osLa15+H\ndXSGCP8Upmvi+eA2UqhhBZts1IQ33rPMAjePAbpSGbNRxous0VpH7cc9BxMffQwh\nsygcbghUCEE3dVWdTFGokvgxkBzaKKTNbiqhmbuc8QIuzOvFFGkZHgqlxFHcaNYZ\n7KZJxqvuKSXsJcxIsQKzDiAPI11J3zgRdIf/CFVQv5g15gl1ieQgFdGc3jplsBcd\nrdLApPZ39+BWr9a/Gj9lgP6Ll5G/cM4Uq18a7TCWJIC9PNGw8bBDJTjnUEqmOu3R\nZQIDAQAB\n-----END PUBLIC KEY-----\n" + cashier: + url: cashier.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA9wliL8gFsRn0DVZusd2h\nSoj6aQWkKq1UU6fj3vzcrb1adMy8RnKogTW6z1W9wxrcrI/GfyRz9Wop0+9+XNYx\nDH+QQ+/1po/O/MkPBGZ6WxXpH2BSCncdJdYZ9qLvlJHHRhFtczcSQki693MCDUCy\nMrMDvmL4YOowHExD7A5qrCIaYnbNcUCYMKluSLxR52AUeAuYjCwZbkgEwIQRdZ+M\n3JMgTD/9GFsvZ4c5x6n1cUnKCJNyyUIvI8jThtOnySCU8ZN17nWfKb1Cxavt17Vp\nGSdyIIL2SO9+rjOFW3PrAyX5P3xEgPYoDxA1QsYLYbj189qA0sT17xf9H7KcNzyP\n7wIDAQAB\n-----END PUBLIC KEY-----\n" + general: + url: general.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAvyFUUFyaEJgsR+bYhTXx\nOA60kw82ohyHCDzkoHDT/k2xS520RZR0AzxT449qD3XfRr0+7F0c6rMx/2pBG7hS\nlHjgrTX7eQ70wV8H4OApriDIp1UDemm4+fKxcPZ6vhWqzp+3ijPdhJXe7OC9D89I\n9QKdlHPBxKFnUrBJiqn3cHGLpRrYTsKpI/Nl7VW4UJJh0k7R7P1Jqry0e+HalOLB\nBu5kl5z6iYBPy1gJ4psDHWuoNboxIgIsVR1SSLM7Mooebwx2qjm3W4VQuc7eQk0g\nh7KH4B8CrK4bC+K6lAS3ZzmTlA6M1WZPtIKv3XqEYCkyomMnkdTNZQYKbCKKlLBo\ntQIDAQAB\n-----END PUBLIC KEY-----\n" + social: + url: social.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAqB8htGdGzDPs3GA76REG\nyjM0eEYdXV6ugi4hPZEViCOBg3POC5RZslA5oTCYYWfTVui8jHC2CPD3AYQLG67Z\n79g2miLHEEyDzG7dp//dc85qp0FYR2JII1y26fJutMVCgn0hth6OpfjPB2QhkgZf\nat+Ico5ppDYIx+4jX8xQr4qqRlUIAmECMAE5ATiAUqfv117GJG/fR3AsKZPYm2U1\nFhSpKT2mvC0AiqstZzxYEm4srl1ZjpJPJ7uU+ewvi/EhRyLWFGPmygP6fvg4IaKS\nG00dx7FGedyLVcSaxJCoCX5Z98hIYEStanCSzuR3FQEL0JaB8ZKKWY8dsB+U1v46\nQwIDAQAB\n-----END PUBLIC KEY-----\n" + property: + url: property.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA1bmnJSRmxcehehuKBwSQ\nXiuYhAxzUOmptIk0sgciB1hK8++anXMaHXf3QA6UiXWjNyU+g2ZL1nVfVl0Qd3Ps\nxM2+hSeZRus2sw0g7CQea7NkAqLGQrpicnZ8Fgcb+0qwgClk0RVBXwJzfTDu6V+5\nL9lLEKWnSdHmoGkxkZTPMAtJpXYx9SMLtljPYGkMWKY2C1cBqPdMOl/rKTUZ9dYp\n2eJ13NTXDJJgDJOhDFHevzK/I6kwxdJbetNo4IO1dhQdbPionR5SNkkCNZvfy3k3\n68+xopPKH3xECCIuxorcePx0hyoeXS8vdmJ09VKHVUz08LBYGq2S/36V5LIc1P/6\nSQIDAQAB\n-----END PUBLIC KEY-----\n" + procurement: + url: procurement.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAze/Yr3vrpRBpeu7ohyEP\nboPvZ476dtANbvW+rMuDyKeGD5FfoZYwzF+AbMIK6KfleWizObnMM8ABC0LdBuag\nQ0Brk4FMxyKz0aXlSgG3OZiZXJaaWm2/+gqghgpBLpAPMRFnEmK2y11b/EgCxurV\nl+RZ/MgrIviRGipnU7GXfG4O7Ai21oD4lzKt3WbvuWgBdgtEsYpZMIyddWrhkUki\noM39Vm72mCyKPkysCVYCnYaMwDXVx/SKuTRHiVQZ4GNIv74rwp7BOCkfDZ8HrNLH\nr3ObCB8X0Bh9GqUUj7gYu3cFmx8lXer7qkGtGUq2wNUM0CBc01EODVO9e9RQnulA\n3wIDAQAB\n-----END PUBLIC KEY-----\n" + fss: + url: fss.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAzsvi4FfIQokfP2QmiRTs\nzuxjPg7oPK7pLHNQC/AyY35H0vmkXGTc74pVvLbfSuaprLO10WVzE4bGGQmhmls1\nDqeY7EyHg1vs7GHQm1932n+Va+qDToSx7S+Zs1ZOglYAdEzBI3dyhefIcDtNUfty\n0i64RGiEzDH4yV5lecilXo5Q4/7W/HNdtw8Oe//LopOZ2Mj+Eq7Tk70WkGFDV73Z\n/jIBLBn51g2P9nrsid63OLe1X8u0l9+xSGff0fR1VlqbElBRACCrAmPvs9ceOW7H\n+yLw71elR4nMDm+/dx/zimeYUj0WaY2A3/O8xucPhSP22YCRiO1jEsAEvMXkCU9p\n8wIDAQAB\n-----END PUBLIC KEY-----\n" + medicine: + url: medicine.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAwx7zQLnde6Azy/03bIxg\nkp5rM0DsKKkBbX8C5vhUADxaC2zVmVJuF0NnTGCWutNSSYsKWRKzFwEoZdzJ+8XS\nr8f9kRdEB0yu3Akv+EhZyHA7yVGyFvNAhPGVuekSmpDlpFFKanAqlhBzrhByku5A\nTqp2fXi3zHMoP6WX8QXb6SpG/y4CBpjXCI1qLCAJRw0Fkt7yMXkJnjO2q7zCKAnU\nnv6DVz5yDuBiZPfYlW09KHVWxSehgk5fvLu9Jb/s1XklPwEw1m5BPhIA1YG0QelR\nXk9Pdvwb7aM59LZx1xQZYcku0KGSqLo9rCDTD8YT47226v921yeM36Az8t8e4egU\nzwIDAQAB\n-----END PUBLIC KEY-----\n" + police: + url: police.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAzKawlFWAMzA/uV/kcewd\nmtj8PcqxosmnSh7ZzJ0DumG2ieeP9oDBicqbqIEaeJVvrRzYJD2a+u8x5KKMKB8J\nHbMUpCBFlIpkDMjU/oZVMcYT9pcH51QWNvCgHG7prVykSGFz1JRvjSP6cwuZKBFd\nFFneOViETqoMIO1DbRLXsGfPvMOJY9C1xDwv1dLv0Wbj7M9N6eNz06a50bu3I4gl\nMumxWnZUabXL3G62S/Si4NM7J2jOUnkEOxJWOhcAX/iiqS9T8AHu84um2+mLQpfB\nJJFFIWCIAtU78VnIN5JSWwjFU5TsiSyCFYpGXKxUFD25cFmt3SfG0gwmrFis5Pdn\nhwIDAQAB\n-----END PUBLIC KEY-----\n" + construction: + url: construction.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAvxJcKnPUDaNNyhdGpedL\n+h2OI9RDDZUTkHcvX1UvBNvlX2+dvok6sHQh2AhZoNyCUFZTbp2CRSNfIM5jXigD\nfHA3KzpN7cmGG7W7nIdBBkZU/ly4HFvkD7mGoEymB0JYgZkz59CXBx+3Zg6KLSYY\nZDoOw6wikrl643So2zFZvwHJpDkRkmX5oWWYqXOZxaZnkgbhvA3KdcH9+C1aEBYY\npY2K2MJt86k0ahW/CJfVRDb9CWSxAGir1RAPu9bRV9y9WWKKGWekH0/IqhhJPT8q\nl3v6PB1Oc6ltbOyYkS2xHbmvRxjORzGen0Xcbjzo4N8HBEoPe0Uc5iP0Y50GDjEL\nEQIDAQAB\n-----END PUBLIC KEY-----\n" + sec: + url: sec.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEApsVKJ8Cvr/A0dmHR+vDS\nAYjVzGqMNJ/4pO7GwMzUZMNSkpq3b9CIjrIGg/QKj7woTHnKM39vczu5gxPXJGYN\nIo+PnWsibMDjcz2Vm8s11XXIPho/Ce+hQkWpWGzxpaH7Z/qLKSwiwHdHhlgN3fWw\njR8jYhreQYfohkRGR70h8A9TTU4YkFY/+8yIdwGns61+5tK981kMbVkm+pcgL0cP\nMN08I7MM+c87COY6IO27jVb/ALPAYpo+QUdAfEp5hlI7BQW95nB7LHOnxAm7lLTD\nhbdETUssieQUicwgDpGa2aD769nH+V3UCp0nA4yPDWyJJyKEWsD5EEK24VAcotql\nkwIDAQAB\n-----END PUBLIC KEY-----\n" + info: + url: info.ga.ntu.edu.tw + key: "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA5MLcsMcedzVWjw7pd/lr\nf8GdrzV6rubsJgEBJbC2OdrloHc+7uxEwWiYNTfg4j46nY/zCuTqzV/Wcfni5pY8\n0yuOmZdH9LjK0PW5BgXYJwe/bZkQmQcIQhkoSPghR8o+kZlI0a3+3gs4eAkpxB21\nPR5Rg2fvzDkaO3WcHf13HymayIk9wn4i0NdLUXgKSWcz5XNJtVBh6jtMkDq7ioOH\nQZT9OAODFw5CW/TvXBJaAvSEdDHsCNTE4vgJO1h6qowC27mErgjilA7TM81JFp40\nwexOW/gXHc4gCsj9BY39tDTqa56QIbJjKdqx7iyHUr1jMFmII1osS1ZVATco9RrM\naQIDAQAB\n-----END PUBLIC KEY-----\n" + diff --git a/config/resque_schedule.yml b/config/resque_schedule.yml index e73f9642..426ca360 100644 --- a/config/resque_schedule.yml +++ b/config/resque_schedule.yml @@ -8,4 +8,10 @@ generate_system_summary: cron: 0 0 12 * * * class: GenerateSystemSummary args: - description: Generate the system status such as disk free space,package version list for showing at site tab \ No newline at end of file + description: Generate the system status such as disk free space,package version list for showing at site tab + +get_announcement_from_rss: + cron: 0 0 [2,12] * * * + class: GetAnnouncementFromRss + args: + description: Loop through the announcement RSS until 24h ago diff --git a/config/routes.rb b/config/routes.rb index 8dda41e9..fcd28b47 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -13,6 +13,8 @@ Orbit::Application.routes.draw do match 'user_logout' => 'sessions#destroy' end + match "saml_login" => 'saml_logins#index' + mount Resque::Server, :at => "/admin/resque" mount Rack::GridFS::Endpoint.new(:db => Mongoid.database,:lookup=>:path), :at => "gridfs" diff --git a/lib/rss_ntu_job.rb b/lib/rss_ntu_job.rb new file mode 100644 index 00000000..e22becff --- /dev/null +++ b/lib/rss_ntu_job.rb @@ -0,0 +1,158 @@ +# encoding: utf-8 + +require 'rss' +require 'mongo' + +SITES = { "總務處-各單位公告" => "0", + "總務處-文書組" => "1", + "總務處-出納組" => "2", + "總務處-事務組" => "3", + "總務處-保管組" => "5", + "總務處-採購組" => "6", + "總務處-經營管理組" => "7", + "總務處-駐衛警察隊" => "9", + "總務處-營繕組" => "10", + "總務處-總務處" => "11", + "社會科學院-社會科學院總務分處" => "4", + "醫學院-醫學院總務分處" => "8" } + +SITE_KEYS = SITES.keys + +DB_BASE_NAME = "production_new" + +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('Wes,', 'Wed,').gsub(/(encoding=\"big5\")/, 'encoding="utf-8"')) + feed.items.each do |item| + if item.pubDate > yesterday + if SITE_KEYS.include?(item.author) + author = item.author.strip + category = item.category.to_s.gsub(/\<(\/)*category\>/, '') + if all[author] + all[author][item.link.strip] = {title: item.title.strip, author: author, link: item.link.strip, date: item.pubDate, category: category, description: item.description.gsub("\r\n", '
').strip} + else + all[author] = {item.link.strip => {title: item.title.strip, author: author, link: item.link.strip, date: item.pubDate, category: category, description: item.description.gsub("\r\n", '
').strip}} + end + 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, bulletin_module_id) + if categories.keys.include? "rss_#{category}" + [categories["rss_#{category}"], categories] + else + cat = { + _type: "Category", + module_app_id: bulletin_module_id, + key: "rss_#{category}", + disable: false, + custom: 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}") + + bulletin_module_id = db["module_apps"].find(key: "announcement").first + + coll_bulletin = db["bulletins"] + coll_buffer_cat = db["buffer_categories"] + coll_cat = db["categories"] + coll_bulletin_cat = db["categories"].find(module_app_id: bulletin_module_id["_id"]) + + categories = coll_bulletin_cat.find().to_a.inject({}) do |categories, category| + categories[category['key']] = category['_id'] + categories + end + [categories, coll_bulletin, coll_cat, bulletin_module_id["_id"],coll_buffer_cat] +end + +# Get main site (總務處) categories +@main_categories, @main_coll_bulletin, @main_coll_cat, @main_bulletin_module_id, @main_coll_buffer_cat = get_mongo_and_categories +@copy_categories, @copy_coll_bulletin, @copy_coll_cat, @copy_bulletin_module_id, @copy_coll_buffer_cat = get_mongo_and_categories('11') + +all.each do |key, value| # Loop through all the authors + site_number = SITES[key] + categories, coll_bulletin, coll_cat, bulletin_module_id, coll_buffer_cat = get_mongo_and_categories(site_number) # Get current's site categories + value.each_value do |bul| # Loop through all the items + category_id, categories = get_category_id(bul[:category], categories, coll_cat, bulletin_module_id) + unless coll_bulletin.find_one(rss_link: bul[:link]) + bulletin = { _type: "Bulletin", + postdate: bul[:date], + created_at: bul[:date], + updated_at: bul[:date], + public: true, + is_checked: true, + is_pending: false, + is_rejected: false, + category_id: category_id, + title: {:zh_tw => bul[:title]}, + text: {:zh_tw => bul[:description]}, + available_for_en: false, + available_for_zh_tw: true, + rss_link: bul[:link], + is_top: false, + is_hot: false, + is_hidden: false } + bs = coll_bulletin.save(bulletin) + + buffer_cat = { _type: "BufferCategory", + category_id: category_id, + categorizable_type: "Bulletin", + categorizable_id: bs } + coll_buffer_cat.save(buffer_cat) + + unless site_number.eql?("0") || @main_coll_bulletin.find_one(rss_link: bul[:link]) # Copy the item to the main site + + category_id, @main_categories = get_category_id(bul[:category], @main_categories, @main_coll_cat, @main_bulletin_module_id) + main_bulletin = bulletin.clone + main_bulletin['_id'] = BSON::ObjectId.new + main_bulletin[:category_id] = category_id + main_bs = @main_coll_bulletin.save(main_bulletin) + + main_buffer_cat = { _type: "BufferCategory", + category_id: category_id, + categorizable_type: "Bulletin", + categorizable_id: main_bs } + @main_coll_buffer_cat.save(main_buffer_cat) + + category_id, @copy_categories = get_category_id(bul[:category], @copy_categories, @copy_coll_cat, @copy_bulletin_module_id) + copy_bulletin = bulletin.clone + copy_bulletin['_id'] = BSON::ObjectId.new + copy_bulletin[:category_id] = category_id + @copy_coll_bulletin.save(copy_bulletin) + copy_bs = @copy_coll_bulletin.save(copy_bulletin) + + copy_buffer_cat = { _type: "BufferCategory", + category_id: category_id, + categorizable_type: "Bulletin", + categorizable_id: copy_bs } + @copy_coll_buffer_cat.save(copy_buffer_cat) + + end + end + end +end + + + diff --git a/vendor/built_in_modules/survey_b/Gemfile b/vendor/built_in_modules/survey_b/Gemfile new file mode 100644 index 00000000..6872b8bb --- /dev/null +++ b/vendor/built_in_modules/survey_b/Gemfile @@ -0,0 +1,17 @@ +source "http://rubygems.org" + +# Declare your gem's dependencies in survey_b.gemspec. +# Bundler will treat runtime dependencies like base dependencies, and +# development dependencies will be added by default to the :development group. +gemspec + +# jquery-rails is used by the dummy application +gem "jquery-rails" + +# Declare any dependencies that are still in development here instead of in +# your gemspec. These might include edge Rails or gems from your path or +# Git. Remember to move these dependencies to your gemspec before releasing +# your gem to rubygems.org. + +# To use debugger +# gem 'debugger' diff --git a/vendor/built_in_modules/survey_b/MIT-LICENSE b/vendor/built_in_modules/survey_b/MIT-LICENSE new file mode 100644 index 00000000..5146945d --- /dev/null +++ b/vendor/built_in_modules/survey_b/MIT-LICENSE @@ -0,0 +1,20 @@ +Copyright 2013 YOURNAME + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/vendor/built_in_modules/survey_b/README.rdoc b/vendor/built_in_modules/survey_b/README.rdoc new file mode 100644 index 00000000..08791bc9 --- /dev/null +++ b/vendor/built_in_modules/survey_b/README.rdoc @@ -0,0 +1,3 @@ += SurveyB + +This project rocks and uses MIT-LICENSE. \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/Rakefile b/vendor/built_in_modules/survey_b/Rakefile new file mode 100644 index 00000000..428131fa --- /dev/null +++ b/vendor/built_in_modules/survey_b/Rakefile @@ -0,0 +1,38 @@ +#!/usr/bin/env rake +begin + require 'bundler/setup' +rescue LoadError + puts 'You must `gem install bundler` and `bundle install` to run rake tasks' +end +begin + require 'rdoc/task' +rescue LoadError + require 'rdoc/rdoc' + require 'rake/rdoctask' + RDoc::Task = Rake::RDocTask +end + +RDoc::Task.new(:rdoc) do |rdoc| + rdoc.rdoc_dir = 'rdoc' + rdoc.title = 'SurveyB' + rdoc.options << '--line-numbers' + rdoc.rdoc_files.include('README.rdoc') + rdoc.rdoc_files.include('lib/**/*.rb') +end + + + + +Bundler::GemHelper.install_tasks + +require 'rake/testtask' + +Rake::TestTask.new(:test) do |t| + t.libs << 'lib' + t.libs << 'test' + t.pattern = 'test/**/*_test.rb' + t.verbose = false +end + + +task :default => :test diff --git a/vendor/built_in_modules/survey_b/app/controllers/application_controller.rb b/vendor/built_in_modules/survey_b/app/controllers/application_controller.rb new file mode 100644 index 00000000..307a4acd --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/controllers/application_controller.rb @@ -0,0 +1,23 @@ +class ApplicationController < ActionController::Base + protect_from_forgery + before_filter :set_locale + + # Set I18n.locale + def set_locale + # update session if passed + session[:locale] = params[:locale] if params[:locale] + + # set locale based on session or default + begin + # check if locale is valid for non site pages + if !VALID_LOCALES.include?(session[:locale]) + I18n.locale = I18n.default_locale + else + I18n.locale = session[:locale] + end + rescue + I18n.locale = I18n.default_locale + end + end + +end diff --git a/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/periods_controller.rb b/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/periods_controller.rb new file mode 100644 index 00000000..d850adbb --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/periods_controller.rb @@ -0,0 +1,81 @@ +class Panel::SurveyB::BackEnd::PeriodsController < OrbitBackendController + + # include AdminHelper + # include OrbitControllerLib::DivisionForDisable + + # before_filter :for_app_manager + + open_for_manager + + # def initialize + # super + # @app_title = 'survey_b' + # end + + + # before_filter :force_order_for_user,:only => :index + # before_filter :for_app_sub_manager,:except => :index + + + def index + @periods = SurveyBPeriod.page params[:page] + respond_to do |format| + format.html # index.html.erb + format.xml { render :xml => @periods } + format.js + end + end + + def new + @period = SurveyBPeriod.new + + respond_to do |format| + format.html # new.html.erb + format.xml { render :xml => @period } + end + end + + def create + @period = SurveyBPeriod.new params[:survey_b_period] + + respond_to do |format| + if @period.save + format.html { redirect_to(panel_survey_b_back_end_periods_url) } + format.xml { render :xml => @period, :status => :created, :location => @period } + else + format.html { render :action => "new" } + format.xml { render :xml => @period.errors, :status => :unprocessable_entity } + end + end + end + + def edit + @period = SurveyBPeriod.find(params[:id]) + end + + def update + @period = SurveyBPeriod.find(params[:id]) + + respond_to do |format| + if @period.update_attributes(params[:survey_b_period]) + format.html { redirect_to(panel_survey_b_back_end_periods_url(:page => params[:page])) } + format.xml { head :ok } + else + format.html { render :action => "edit" } + format.xml { render :xml => @period.errors, :status => :unprocessable_entity } + end + end + end + + def destroy + @period = SurveyBPeriod.find(params[:id]) + + respond_to do |format| + if @period.destroy + format.html { redirect_to(panel_survey_b_back_end_periods_url(:page => params[:page])) } + format.xml { head :ok } + end + end + end + +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/settings_controller.rb b/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/settings_controller.rb new file mode 100644 index 00000000..6ceda2e0 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/settings_controller.rb @@ -0,0 +1,37 @@ +class Panel::SurveyB::BackEnd::SettingsController < OrbitBackendController + + # include AdminHelper + # include OrbitControllerLib::DivisionForDisable + + # before_filter :for_app_manager + open_for_manager + + # def initialize + # super + # @app_title = 'survey_b' + # end + + def show + redirect_to edit_panel_survey_b_back_end_setting_path + end + + def edit + @setting = SurveyBSetting.first_or_create + end + + def update + @setting = SurveyBSetting.first_or_create + + respond_to do |format| + if @setting.update_attributes(params[:survey_b_setting]) + format.html { redirect_to(panel_survey_b_back_end_periods_url) } + format.xml { head :ok } + else + format.html { render :action => "edit" } + format.xml { render :xml => @setting.errors, :status => :unprocessable_entity } + end + end + end + + +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/survey_b_controller.rb b/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/survey_b_controller.rb new file mode 100644 index 00000000..7ac66530 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/back_end/survey_b_controller.rb @@ -0,0 +1,168 @@ +class Panel::SurveyB::BackEnd::SurveyBController < OrbitBackendController + # include AdminHelper + # include OrbitControllerLib::DivisionForDisable + + # before_filter :for_app_manager + + open_for_manager + + #before_filter :force_order_for_user,:only => :index + #before_filter :for_app_sub_manager,:except => :index + + + # def initialize + # super + # @app_title = 'survey_b' + # end + + def index + if params[:period] && @period = SurveyBPeriod.find(params[:period]) + @answers = ::SurveyBAnswer.where(:created_at.gte => @period.start_date, :created_at.lte => @period.end_date) + else + @answers = ::SurveyBAnswer.all + end + if params[:sort] + options = params[:sort_options] + options = [options] if !options.class.eql?(Array) + options.each do |option| + @answers = @answers.order_by(option, params[:direction]) + end + end + @answers = @answers.page(params[:page]).per(10) + respond_to do |format| + format.html # index.html.erb + format.xml { render :xml => @answers } + format.js + end + end + + def destroy + @answers = SurveyBAnswer.find(params[:id]) + # @bulletin.bulletin_files.destroy + @answers.destroy + + respond_to do |format| + + format.html { redirect_to(panel_survey_b_back_end_survey_b_index_path(:period => params[:period], :page => params[:page])) } + # format.xml { head :ok } + format.js + end + end + + def delete + if params[:ids] + answers = SurveyBAnswer.any_in(:_id => params[:ids]).destroy_all + end + redirect_to panel_survey_b_back_end_survey_b_index_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options]) + end + + def result + if params[:period] && @period = SurveyBPeriod.find(params[:period]) + @answers = ::SurveyBAnswer.where(:created_at.gte => @period.start_date, :created_at.lte => @period.end_date) + else + @answers = ::SurveyBAnswer.all + end + @results = Hash[(t('survey_b.institutions').keys + [ 'all' ]).map do |i_key| + [i_key, Hash[(t('survey_b.questions').keys + ['count', 'sum', 'sum7'] ).map{|q_key| [q_key, 0] }].merge({ 'count' => 0, 'sum' => 0, 'sum7' => 0 })] + end] + [:good_institutions, :bad_institutions].each do |item| + @results[item] = Hash[t('survey_b.institutions').map{|k, i| [k, 0] }] + end + [:person_question, :rate_question, :quality_question].each do |item| + @results[item] = t("survey_b.#{item}_options").map{|o| 0 } + end + @answers.each do |answer| + t('survey_b.institutions').each do |i_key, institution| + if answer[i_key.to_s] + @results[i_key]['count'] += 1 + t('survey_b.questions').keys.each do |q_key| + point = 10 - ( answer[i_key.to_s][q_key.to_s].to_i * 2 ) + @results[i_key][q_key] += point + @results[i_key]['sum'] += point + if q_key != :question6 + @results[i_key]['sum7'] += point + end + end + end + end + [:good_institutions, :bad_institutions].each do |item| + if answer[item.to_s] + answer[item.to_s].each do |institution| + @results[item][institution] += 1 + end + end + end + [:person_question, :rate_question, :quality_question].each do |item| + if answer[item.to_s] + @results[item][answer[item.to_s].to_i] += 1 + end + end + end + t('survey_b.institutions').each do |i_key, institution| + (t('survey_b.questions').keys + ['count', 'sum', 'sum7'] ).each do |q_key| + @results['all'][q_key] += @results[i_key][q_key] + end + end + end + + def export + + if params[:period] && @period = SurveyBPeriod.find(params[:period]) + @answers = ::SurveyBAnswer.where(:created_at.gte => @period.start_date, :created_at.lte => @period.end_date) + @comment_question = ::SurveyBAnswer.where(:created_at.gte => @period.start_date, :created_at.lte => @period.end_date, :comment_question.nin => ['']) + else + @answers = ::SurveyBAnswer.all + @comment_question = ::SurveyBAnswer.where(:comment_question.nin => ['']) + end + @results = Hash[(t('survey_b.institutions').keys + [ 'all' ]).map do |i_key| + [i_key, Hash[(t('survey_b.questions').keys + ['count', 'sum', 'sum7'] ).map{|q_key| [q_key, 0] }].merge({ 'count' => 0, 'sum' => 0, 'sum7' => 0 })] + end] + [:good_institutions, :bad_institutions].each do |item| + @results[item] = Hash[t('survey_b.institutions').map{|k, i| [k, 0] }] + end + [:person_question, :rate_question, :quality_question].each do |item| + @results[item] = t("survey_b.#{item}_options").map{|o| 0 } + end + @answers.each do |answer| + t('survey_b.institutions').each do |i_key, institution| + if answer[i_key.to_s] + @results[i_key]['count'] += 1 + t('survey_b.questions').keys.each do |q_key| + point = 10 - ( answer[i_key.to_s][q_key.to_s].to_i * 2 ) + @results[i_key][q_key] += point + @results[i_key]['sum'] += point + if q_key != :question6 + @results[i_key]['sum7'] += point + end + end + end + end + [:good_institutions, :bad_institutions].each do |item| + if answer[item.to_s] + answer[item.to_s].each do |institution| + @results[item][institution] += 1 + end + end + end + [:person_question, :rate_question, :quality_question].each do |item| + if answer[item.to_s] + @results[item][answer[item.to_s].to_i] += 1 + end + end + end + t('survey_b.institutions').each do |i_key, institution| + (t('survey_b.questions').keys + ['count', 'sum', 'sum7'] ).each do |q_key| + @results['all'][q_key] += @results[i_key][q_key] + end + end + + @setting = SurveyBSetting.first + + headers['Content-Type'] = "application/vnd.ms-excel" + headers['Content-Disposition'] = "attachment; filename=#{@period.title}.xls" + headers['Cache-Control'] = '' + + render :layout => false + end + +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/front_end/survey_b_controller.rb b/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/front_end/survey_b_controller.rb new file mode 100644 index 00000000..96b06067 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/controllers/panel/survey_b/front_end/survey_b_controller.rb @@ -0,0 +1,88 @@ +class Panel::SurveyB::FrontEnd::SurveyBController < OrbitWidgetController + helper ApplicationHelper + + def index + if params[:period].nil? + @period = SurveyBPeriod.get_current_survey() + else + @period = SurveyBPeriod.find(params[:period]) + end + + redirect_standalone panel_survey_b_front_end_survey_b_index_path( :standalone => 'true') do + @setting = SurveyBSetting.first_or_create + if params[:agree] == '1' + # @period = SurveyBPeriod.first + render :index, :layout => 'standalone' + else + # Escape from error when announcement is empty + if @setting.announcement.nil? + @setting.announcement = " " + end + render :announcement, :layout => 'standalone' + end + end + end + + def create + answer = params[:answer] + @answer_model = ::SurveyBAnswer.new + not_answered = true + [:contact_name, :contact_phone, :contact_e_mail, :person_question, :rate_question, :quality_question].each do |item| + if answer[item].blank? + @answer_model.errors.add t("survey_b.#{item.to_s}_label"), t('survey_b.not_answered') + else + @answer_model[item] = answer[item] + end + end + @answer_model[:comment_question] = answer[:comment_question] + [:good_institutions, :bad_institutions].each do |item| + t('survey_b.institutions').each do |i_key, institution| + if answer[item][i_key] == '1' + @answer_model[item] ||= [] + @answer_model[item].push i_key + end + end + end + t('survey_b.institutions').each do |i_key, institution| + if answer["institution_check"][i_key] == '1' + not_answered = false + @answer_model[i_key] ||= {} + t('survey_b.questions').each do |q_key, question| + if answer[i_key] && answer[i_key][q_key] + @answer_model[i_key][q_key] = answer[i_key][q_key] + else + @answer_model.errors.add institution + question, t('survey_b.not_answered') + end + end + end + end + if not_answered + @answer_model.errors.add t('survey_b.institution_check_label'), t('survey_b.not_answered') + end + if @answer_model.errors.empty? + @answer_model.save! + render :answer_success + else + @answer_error = @answer_model.errors.full_messages.join(',') + render :answer_error + end + end + + def redirect_standalone url + unless params[:standalone] == 'true' + @redirect_url = url + render :redirect_standalone + else + module_app = ModuleApp.first(:conditions => {:key => 'survey_b'}) + @item = Item.where(module_app_id: module_app.id).first + + if @period + yield + else + # render :no_survey + # render :json => "No Survey" + render :no_survey, :layout => 'standalone' + end + end + end +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/models/survey_b_answer.rb b/vendor/built_in_modules/survey_b/app/models/survey_b_answer.rb new file mode 100644 index 00000000..20f1f5cd --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/models/survey_b_answer.rb @@ -0,0 +1,5 @@ +class SurveyBAnswer + include Mongoid::Document + include Mongoid::Timestamps + +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/models/survey_b_period.rb b/vendor/built_in_modules/survey_b/app/models/survey_b_period.rb new file mode 100644 index 00000000..ed728272 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/models/survey_b_period.rb @@ -0,0 +1,41 @@ +class SurveyBPeriod + include Mongoid::Document + include Mongoid::Timestamps + + field :title, :type => String + field :start_date, :type => DateTime + field :end_date, :type => DateTime + + validates :start_date, :end_date, :presence => true + + def self.get_current_survey + self.where(:start_date.lte => Time.now, :end_date.gte => Time.now).first + end + + def isAvailable? + if start_date <= Time.now and end_date >= Time.now + return true + else + return false + end + end + + def get_status_type + # status type + # reference to config/locales/en.yml and zh-tw.yml + # status_types: + # type1: 調查中 + # type2: 未開始 + # type3: 已結束 + + if start_date <= Time.now and end_date >= Time.now + return "type1" + end + if start_date > Time.now + return "type2" + end + if end_date < Time.now + return "type3" + end + end +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/models/survey_b_setting.rb b/vendor/built_in_modules/survey_b/app/models/survey_b_setting.rb new file mode 100644 index 00000000..f75a2d9b --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/models/survey_b_setting.rb @@ -0,0 +1,17 @@ +class SurveyBSetting + + include Mongoid::Document + + field :description, :localize => true + field :announcement, :localize => true + + def self.first_or_create + setting = self.first + unless setting + setting = self.new + setting.save + end + setting + end + +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/_form.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/_form.html.erb new file mode 100644 index 00000000..8e359700 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/_form.html.erb @@ -0,0 +1,68 @@ +<% content_for :page_specific_css do %> + <%= stylesheet_link_tag "lib/main-forms" %> + <%= stylesheet_link_tag "lib/fileupload" %> + <%= stylesheet_link_tag "lib/main-list" %> +<% end %> +<% content_for :page_specific_javascript do %> + <%= javascript_include_tag "lib/bootstrap-fileupload" %> + <%= javascript_include_tag "lib/bootstrap-datetimepicker" %> + <%= javascript_include_tag "lib/datetimepicker/datetimepicker.js" %> + <%= javascript_include_tag "lib/module-area" %> +<% end %> + +<%= f.error_messages %> + +<%= @period.errors.full_messages.join ', ' %> + + +
+ + + + + + +
+ + +
+ + +
+ +
+ <%= f.text_field :title %> +
+
+ + +
+ +
+ <%= f.datetime_picker :start_date, :no_label => true %> +
+
+ +
+ +
+ <%= f.datetime_picker :end_date, :no_label => true %> +
+
+ +
+ +
+
+ + + +
+ <%= hidden_field_tag 'page', params[:page] if !params[:page].blank? %> + <%= f.submit t('submit'), class: 'btn btn-primary' %> + <%= link_to t('cancel'), get_go_back, :class=>"btn" %> +
diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/_period.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/_period.html.erb new file mode 100644 index 00000000..13394fb4 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/_period.html.erb @@ -0,0 +1,33 @@ + + + <%= link_to period.title, panel_survey_b_front_end_survey_b_index_path(:period => period, :standalone => true), :target=>"_blank" %> + + + + <%= display_date_time period.start_date %> + - + <%= display_date_time period.end_date %> + +
+ +
+ + + <% status_type = t('survey_b.status_types') %> + <% if period.start_date > Time.now %> + <%= status_type[:type2] %> + <% end %> + <% if period.start_date <= Time.now and period.end_date >= Time.now %> + <%= status_type[:type1] %> + <% end %> + <% if period.end_date < Time.now %> + <%= status_type[:type3] %> + <% end %> + + \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/edit.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/edit.html.erb new file mode 100644 index 00000000..b253fa38 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/edit.html.erb @@ -0,0 +1,6 @@ +

<%= t(:edit) + t('survey_b.period') %>

+<%= form_for @period, url: panel_survey_b_back_end_period_path(@period), html: {class: "form-horizontal main-forms previewable"} do |f| %> +
+ <%= render :partial => 'form', :locals => {:f => f} %> +
+<% end %> diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/index.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/index.html.erb new file mode 100644 index 00000000..451eda01 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/index.html.erb @@ -0,0 +1,19 @@ + + + + + + + + + + <%= render :partial => 'period', :collection => @periods %> + +
<%= t('survey_b.period_title') %><%= t('survey_b.period') %><%= t('survey_b.status') %>
+ +
+ <%= link_to t(:add) + t('survey_b.period'), new_panel_survey_b_back_end_period_path, :class => 'btn btn-primary pull-right' %> +
+ <%= paginate @periods %> +
+
\ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/index.js.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/index.js.erb new file mode 100644 index 00000000..8d120956 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/index.js.erb @@ -0,0 +1,2 @@ +$("#tbody_survey_periods").html("<%= j render :partial => 'answer', :collection => @periods %>"); +$("#survey_periods_pagination").html("<%= j paginate @periods %>"); \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/new.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/new.html.erb new file mode 100644 index 00000000..2d36c1e1 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/periods/new.html.erb @@ -0,0 +1,6 @@ +

<%=t(:add) + t('survey_b.period') %>

+<%= form_for @period, url: panel_survey_b_back_end_periods_path, html: {class: "form-horizontal main-forms previewable"} do |f| %> +
+ <%= render partial: 'form', locals: {f: f} %> +
+<% end %> \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/settings/_form.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/settings/_form.html.erb new file mode 100644 index 00000000..bb858c66 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/settings/_form.html.erb @@ -0,0 +1,72 @@ +<% # encoding: utf-8 %> +<% content_for :page_specific_css do %> + <%= stylesheet_link_tag "lib/main-forms" %> + <%= stylesheet_link_tag "lib/fileupload" %> + <%= stylesheet_link_tag "lib/main-list" %> +<% end %> +<% content_for :page_specific_javascript do %> + <%= javascript_include_tag "lib/bootstrap-fileupload" %> + <%= javascript_include_tag "lib/bootstrap-datetimepicker" %> + <%= javascript_include_tag "lib/datetimepicker/datetimepicker.js" %> + <%= javascript_include_tag "lib/module-area" %> +<% end %> + +<%= f.error_messages %> + + + + +
+ + + + + + +
+ + <% @site_in_use_locales.each_with_index do |locale, i| %> + +
"> + + +
+ +
+
+ <%= f.fields_for :description_translations do |f| %> + <%= f.text_area locale, rows: 7, class: "input-block-level", value: (@setting.description_translations[locale] rescue nil) %> + <% end %> +
+
+
+ + +
+ +
+
+ <%= f.fields_for :announcement_translations do |f| %> + <%= f.text_area locale, rows: 7, class: "input-block-level", :value => (@setting.announcement_translations[locale] rescue nil) %> + <% end %> +
+
+
+ +
+ + <% end %> +
+
+ + +
+ <%= f.submit t('submit'), class: 'btn btn-primary' %> + <%= link_to t('cancel'), get_go_back, :class=>"btn" %> +
diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/settings/edit.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/settings/edit.html.erb new file mode 100644 index 00000000..530073d7 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/settings/edit.html.erb @@ -0,0 +1,7 @@ + +

<%= t('survey_b.setting') %>

+<%= form_for @setting, url: panel_survey_b_back_end_setting_path, html: {class: "form-horizontal main-forms previewable"} do |f| %> +
+ <%= render :partial => 'form', :locals => {:f => f} %> +
+<% end %> \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_answer.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_answer.html.erb new file mode 100644 index 00000000..082098bc --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_answer.html.erb @@ -0,0 +1,13 @@ + + + <%= check_box_tag 'to_delete[]', answer.id, false, :class => "checkbox_in_list" %> + + <% [:contact_name, :contact_phone, :contact_e_mail, :comment_question].each do |question| %> + + <%= answer[question] %> + + <% end %> + + <%= answer.created_at %> + + \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_filter.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_filter.html.erb new file mode 100644 index 00000000..0042d5c3 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_filter.html.erb @@ -0,0 +1,11 @@ + + +<% content_for :page_specific_javascript do %> + <%= javascript_include_tag "sort_header" %> +<% end %> \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_sort_headers.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_sort_headers.html.erb new file mode 100644 index 00000000..a865ff0c --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/_sort_headers.html.erb @@ -0,0 +1,7 @@ +<% _sort_args = [] %> +<% [:contact_name, :contact_phone, :contact_e_mail, :comment_question].each do |question| %> + <% _sort_args.push [question.to_s, question.to_s, 'span1', t("survey_b.#{question}_label")] %> +<% end %> +<% _sort_args.push ['created_at', 'created_at','span1', 'created_at'] %> +<%= render_sort_bar(true, delete_panel_survey_b_back_end_survey_b_index_path(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options]), + *_sort_args).html_safe %> \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/export.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/export.html.erb new file mode 100644 index 00000000..ded30d65 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/export.html.erb @@ -0,0 +1,257 @@ + + + + + + + + + + + + + +
標題<%= @period.title rescue '' %>
問卷前言<%= @setting.description rescue '' %>
填答人數<%= @answers.count rescue '' %>
+ +

+ +一 、 顧客滿意填表人身分分析 + + + + <% @results[:person_question].each_with_index do |count, option| %> + + <% end %> + + + + <% @results[:person_question].each_with_index do |count, option| %> + + <% end %> + + + + <% @results[:person_question].each_with_index do |count, option| %> + <% @pcount = count.to_f / @answers.count %> + + <% end %> + +
身份<%= t("survey_b.person_question_options")[option] %>
填答人數<%= count %>
比例<%= @pcount == 0 ? "0" : sprintf("%.2f", @pcount * 100 ) %>%
+ +

+ +二、 整體行政品質表現比較分析 + +

+對於總務處這一、二年之行政品質表現,您感覺是 + + + + <% @results[:quality_question].each_with_index do |count, option| %> + + <% end %> + + + + + <% @qcount = 0 %> + <% @results[:quality_question].each_with_index do |count, option| %> + + <% @qcount = @qcount + count %> + <% end %> + + + + + <% @tqcount = 0 %> + <% @results[:quality_question].each_with_index do |count, option| %> + <% @pcount = count.to_f / @qcount %> + + <% @tqcount = @tqcount + @pcount %> + <% end %> + + +
行政品質表現<%= t("survey_b.quality_question_options")[option] %>
填答人數<%= count %><%= @qcount %>
比例<%= @pcount == 0 ? "0" : sprintf("%.2f", @pcount * 100 ) %>%<%= @tqcount %>
+ +
+對本處整體行政品質表現給予評鑑分數 + + + + <% @results[:rate_question].each_with_index do |count, option| %> + + <% end %> + + + + + <% @rcount = 0 %> + <% @results[:rate_question].each_with_index do |count, option| %> + + <% @rcount = @rcount + count %> + <% end %> + + + + + <% @tqcount = 0 %> + <% @results[:rate_question].each_with_index do |count, option| %> + <% @pcount = count.to_f / @rcount %> + + <% @tqcount = @tqcount + @pcount %> + <% end %> + + +
行政品質表現<%= t("survey_b.rate_question_options")[option] %>
填答人數<%= count %><%= @rcount %>
比例<%= @pcount == 0 ? "0" : sprintf("%.2f", @pcount * 100 ) %>%<%= @tqcount %>
+ +
+以您與總務處各單位接觸之經驗,您覺得以下哪一組的服務品質較優。 (可複選) + + + + <% @results[:good_institutions].each do |institution, count| %> + + <% end %> + + + + + <% @gcount = 0 %> + <% @results[:good_institutions].each do |institution, count| %> + + <% @gcount = @gcount + count %> + <% end %> + + + + + <% @tqcount = 0 %> + <% @results[:good_institutions].each do |institution, count| %> + <% @pcount = count.to_f / @gcount %> + + <% @tqcount = @tqcount + @pcount %> + <% end %> + + +
組別<%= t("survey_b.institutions.#{institution}") %>
人數<%= count %><%= @gcount %>
比例<%= @pcount == 0 ? "0" : sprintf("%.2f", @pcount * 100 ) %>%<%= @tqcount %>
+ +
+以您與總務處各單位接觸之經驗,您覺得以下哪一組的服務品質尚待改進。 (可複選) + + + + <% @results[:bad_institutions].each do |institution, count| %> + + <% end %> + + + + + <% @bcount = 0 %> + <% @results[:bad_institutions].each do |institution, count| %> + + <% @bcount = @bcount + count %> + <% end %> + + + + + <% @tqcount = 0 %> + <% @results[:bad_institutions].each do |institution, count| %> + <% @pcount = count.to_f / @bcount %> + + <% @tqcount = @tqcount + @pcount %> + <% end %> + + +
組別<%= t("survey_b.institutions.#{institution}") %>
人數<%= count %><%= @bcount %>
比例<%= @pcount == 0 ? "0" : sprintf("%.2f", @pcount * 100 ) %>%<%= @tqcount %>
+ +

+三、 各單位顧客滿意度調查分析 + + + + <% @results[:bad_institutions].each do |institution, count| %> + + <% end %> + + + + <% @tcount = 0 %> + + <% t('survey_b.institutions').each do |i_key, institution| %> + <% if @results[i_key]['count'] == 0 %> + + <% @tcount = @tcount + @results[i_key]['count'] %> + <% else %> + + <% @tcount = @tcount + (( @results[i_key]['sum'].to_f / t('survey_b.questions').count.to_f ) / @results[i_key]['count'].to_f ) %> + <% end %> + <% end %> + + + + <% @tcount = 0 %> + + <% t('survey_b.institutions').each do |i_key, institution| %> + <% if @results[i_key]['count'] == 0 %> + + <% @tcount = @tcount + @results[i_key]['count'] %> + <% else %> + + <% @tcount = @tcount + ( ( @results[i_key]['sum7'].to_f / 7.0 ) / @results[i_key]['count'].to_f ) %> + <% end %> + <% end %> + + + + <% @tcount = 0 %> + + <% t('survey_b.institutions').each do |i_key, institution| %> + + <% @tcount = @tcount + @results[i_key]['count'] %> + <% end %> + + +<% t('survey_b.questions').each do |q_key, question| %> + <% @tcount = 0 %> + + + + <% t('survey_b.institutions').each do |i_key, institution| %> + <% if @results[i_key]['count'] == 0 %> + + <% @tcount = @tcount + @results[i_key]['count'] %> + <% else %> + + <% @tcount = @tcount + ( @results[i_key][q_key].to_f / @results[i_key]['count'].to_f ) %> + <% end %> + <% end %> + + +<% end %> +
組別<%= t("survey_b.institutions.#{institution}") %>
<%= t('survey_b.answered_sum') %><%= t('survey_b.no_data') %><%= sprintf("%.2f", ( @results[i_key]['sum'].to_f / t('survey_b.questions').count.to_f ) / @results[i_key]['count'].to_f ) %><%= @tcount %>
<%= t('survey_b.answered_sum7') %><%= t('survey_b.no_data') %><%= sprintf("%.2f", ( @results[i_key]['sum7'].to_f / 7.0 ) / @results[i_key]['count'].to_f ) %><%= @tcount %>
<%= t('survey_b.answered_count') %><%= @results[i_key]['count'] %><%= @tcount %>
<%= question.sub /\d\./, '' %><%= t('survey_b.no_data') %><%= sprintf("%.2f", ( @results[i_key][q_key].to_f / @results[i_key]['count'].to_f )) %><%= @tcount %>
+ + +

+您覺得本處之行政品質有那些地方尚待改進嗎? + + + + + +
填答人數<%= @comment_question.count %>
+ + +

+ + + + + + + + + +
發佈日期<%= display_date_time @period.start_date %>
截止日期<%= display_date_time @period.end_date %>
+ diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/index.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/index.html.erb new file mode 100644 index 00000000..80310b0f --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/index.html.erb @@ -0,0 +1,33 @@ +<% set_default_index do + objects @answers + quick_edit_link type: 'delete', + link: 'panel_survey_b_back_end_survey_b_path', + link_option: ":period=>params[:period],:page=>params[:page]" + + field db_field: 'contact_name', + translation: 'survey_b.contact_name_label', + quick_edit: true, + sort: 'contact_name', + header_class: 'span3' + field db_field: 'contact_phone', + translation: 'survey_b.contact_phone_label', + sort: 'contact_phone', + header_class: 'span3' + field db_field: 'contact_e_mail', + translation: 'survey_b.contact_e_mail_label', + sort: 'contact_e_mail', + header_class: 'span5' + field db_field: 'comment_question', + translation: 'survey_b.comment_question_label', + sort: 'comment_question', + header_class: 'span5' + field db_field: 'created_at', + translation: 'survey_b.created_at', + display_option: 'display_date_time(value)', + hide: 'phone', + sort: 'created_at' + footer link: 'panel_survey_b_back_end_periods_path', + link_name: t(:back) + t('survey_b.survey_b') +end %> + +<%= render 'admin/default_index/index' %> \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/index.js.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/index.js.erb new file mode 100644 index 00000000..45932f38 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/index.js.erb @@ -0,0 +1,4 @@ +$("#delete_all").attr("action", "<%= delete_panel_survey_b_back_end_survey_b_index_path(:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil, :sort_options => params[:sort_options]) %>"); +$("#sort_headers").html("<%= j render 'sort_headers' %>"); +$("#tbody_survey_answers").html("<%= j render :partial => 'answer', :collection => @answers %>"); +$("#survey_answers_pagination").html("<%= j paginate @answers %>"); \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/result.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/result.html.erb new file mode 100644 index 00000000..19d27a11 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/back_end/survey_b/result.html.erb @@ -0,0 +1,134 @@ +<% if @period %> +

<%= @period.title %>

+

+ <%= t('survey_b.period') %>: + <%= display_date_time @period.start_date %> + - + <%= display_date_time @period.end_date %> +

+<% end %> + + + + + + + + + <% t('survey_b.questions').each do |q_key, question| %> + + <% end %> + + + + <% (t('survey_b.institutions').merge({ 'all' => t('survey_b.answered_sum') })).each do |i_key, institution| %> + + + + + + <% t('survey_b.questions').each do |q_key, question| %> + + <% end %> + + <% end %> + +
<%= t('survey_b.answered_sum') %><%= t('survey_b.answered_sum7') %><%= t('survey_b.answered_count') %> + <%= question.sub /\d\./, '' %> +
<%= institution %> + <% if @results[i_key]['count'] == 0 %> + <%= t('survey_b.no_data') %> + <% else %> + <%= sprintf("%.2f", ( @results[i_key]['sum'].to_f / t('survey_b.questions').count.to_f ) / @results[i_key]['count'].to_f ) %> + <%#= ( ( @results[i_key]['sum'].to_f / t('survey_b.questions').count.to_f ) / @results[i_key]['count'].to_f ).round(2) %> + <% end %> + + <% if @results[i_key]['count'] == 0 %> + <%= t('survey_b.no_data') %> + <% else %> + <%= sprintf("%.2f", ( @results[i_key]['sum7'].to_f / 7.0 ) / @results[i_key]['count'].to_f ) %> + <%#= ( ( @results[i_key]['sum7'].to_f / 7.0 ) / @results[i_key]['count'].to_f ).round(2) %> + <% end %> + + <%= @results[i_key]['count'] %> + + <% if @results[i_key]['count'] == 0 %> + <%= t('survey_b.no_data') %> + <% else %> + <%= sprintf("%.2f", ( @results[i_key][q_key].to_f / @results[i_key]['count'].to_f )) %> + <%#= ( @results[i_key][q_key].to_f / @results[i_key]['count'].to_f ).round(2) %> + <% end %> +
+ + + + \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/_answer_error.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/_answer_error.erb new file mode 100644 index 00000000..ff24dea3 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/_answer_error.erb @@ -0,0 +1 @@ +alert("<%= @answer_error %>"); \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/_answer_success.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/_answer_success.html.erb new file mode 100644 index 00000000..3681d869 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/_answer_success.html.erb @@ -0,0 +1,2 @@ +alert("<%= t('survey.answer_success')%>"); +window.location.href = "<%= root_path %>"; \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/announcement.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/announcement.html.erb new file mode 100644 index 00000000..0c91f0db --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/announcement.html.erb @@ -0,0 +1,32 @@ +

<%= @period.title %>

+ +
+
+
+ <% if @period.isAvailable? %> + <%= form_for :answer, :url => panel_survey_b_front_end_survey_b_index_path, :method => :get, :html => {:class => 'survey_b clear'} do |f| %> + <%= f.hidden_field :standalone, :value => true, :name => :standalone %> + <%= f.hidden_field :period_id, :value => @period.id, :name => :period %> +

+ <%= p @setting.announcement.gsub("\n", '
').html_safe %> +

+
+

+ <%= f.check_box :agree, :name => :agree %> + <%= f.label :agree, t('survey_b.agree_check'), :style => "display:inline" %> +

+ +
+ <%= f.submit t('submit'), :class => 'survey-submit' %> +
+ <% end %> + <% else %> + <% status_type = t('survey_b.status_types') %> +

<%= t('survey_b.survey_b') + status_type[@period.get_status_type.to_sym] %>

+ <% end %> +
+
+
+<% content_for :page_stylesheets do %> + +<% end %> \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_error.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_error.html.erb new file mode 100644 index 00000000..0b23ec05 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_error.html.erb @@ -0,0 +1,4 @@ + \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_error.js.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_error.js.erb new file mode 100644 index 00000000..d03295a4 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_error.js.erb @@ -0,0 +1 @@ +<%= render 'answer_error' %> \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_success.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_success.html.erb new file mode 100644 index 00000000..3beb02b1 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_success.html.erb @@ -0,0 +1,3 @@ + \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_success.js.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_success.js.erb new file mode 100644 index 00000000..c1c8ac18 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/answer_success.js.erb @@ -0,0 +1 @@ +<%= render 'answer_success' %> \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/index.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/index.html.erb new file mode 100644 index 00000000..efcf5611 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/index.html.erb @@ -0,0 +1,145 @@ +<% # encoding: utf-8 %> +<% institutions = t('survey_b.institutions') %> +

<%= @period.title %>

+
+
+
+ <%= form_for :answer, :url => panel_survey_b_front_end_survey_b_index_path(:standalone => true), :html => {:class => 'survey_b clear'} do |f| %> +
+ <%= @setting.description.gsub("\n", '
').html_safe %> +
+
    +
  1. + <%= f.label :institution_check, t('survey_b.institution_check_label'), :class => "o-question-title" %> + <%= f.fields_for :institution_check do |cf| %> + <% institutions.each do |key, institution_name| %> +
    + <%= cf.check_box key, :'data-institution' => key %> + <%= cf.label key, institution_name, :style => "display:inline" %> +
    + <% end %> + <% end %> +
  2. + <% institutions.each do |key, institution_name| %> +
  3. + <%= f.label "#{key}_group", t('survey_b.institution_group_label', :institution => institution_name), :class => "o-question-title" %> + <%= f.fields_for key do |rgf| %> + + + + + <% t('survey_b.degrees').each do |degree| %> + + <% end %> + + + + <% j = 0 %> + <% t('survey_b.questions').each do |q_key, question| %> + > + + <% t('survey_b.degrees').each_with_index do |degree, d| %> + + <% end %> + + <% j += 1 %> + <% end %> + +
    + <%= degree %> +
    + <%= question %> + + <%= rgf.radio_button q_key, d %> +
    + <% end %> +
  4. + <% end %> +
  5. + <%= f.label :quality_question, t('survey_b.quality_question_label'), :class => "o-question-title" %> +
      + <% t('survey_b.quality_question_options').each_with_index do |option, i| %> +
    • + <%= f.radio_button :quality_question, i %> + <%= f.label "quality_question_#{i}", option, :class => 'o-question-option' %> +
    • + <% end %> +
    +
  6. + <% [:good_institutions, :bad_institutions].each do |item| %> +
  7. + <%= f.label item, t("survey_b.#{item.to_s}_label"), :class => "o-question-title" %> + <%= f.fields_for item do |cf| %> + <% institutions.each do |key, institution_name| %> +
    + <%= cf.check_box key, :'data-institution' => key %> + <%= cf.label key, institution_name, :style => "display:inline" %> +
    + <% end %> + <% end %> +
  8. + <% end %> +
  9. + <%= f.label :rate_question, t('survey_b.rate_question_label'), :class => "o-question-title" %> +
      + <% t('survey_b.rate_question_options').each_with_index do |option, i| %> +
    • + <%= f.radio_button :rate_question, i %> + <%= f.label "quality_question_#{i}", option, :class => 'o-question-option' %> +
    • + <% end %> +
    +
  10. +
  11. + <%= f.label :person_question, t('survey_b.person_question_label'), :class => "o-question-title" %> +
      + <% t('survey_b.person_question_options').each_with_index do |option, i| %> +
    • + <%= f.radio_button :person_question, i %> + <%= f.label "quality_question_#{i}", option, :class => 'o-question-option' %> +
    • + <% end %> +
    +
  12. +
  13. +

    <%= t('survey_b.comment_question_notice') %>

    + <%= f.label :comment_question, t('survey_b.comment_question_label'), :class => "o-question-title" %> + <%= f.text_area :comment_question, :rows => 5 %> +
  14. +
  15. +

    <%== t('survey_b.contact_notice') %>

    + <% [:contact_name, :contact_phone, :contact_e_mail].each do |item| %> + <%= f.label :item, t("survey_b.#{item.to_s}_label"), :class => "o-question-title" %> + <%= f.text_field item %> + <% end %> +
  16. +
+
+ <%= f.submit t('submit'), :class => 'survey-submit' %> +
+ <% end %> +
+
+
+<% content_for :page_stylesheets do %> + +<% end %> + + \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/no_survey.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/no_survey.html.erb new file mode 100644 index 00000000..e6735343 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/no_survey.html.erb @@ -0,0 +1,6 @@ +

<%= t('survey_b.no_survey') %>

+ \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/redirect_standalone.html.erb b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/redirect_standalone.html.erb new file mode 100644 index 00000000..de9b2f49 --- /dev/null +++ b/vendor/built_in_modules/survey_b/app/views/panel/survey_b/front_end/survey_b/redirect_standalone.html.erb @@ -0,0 +1,3 @@ + \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/config/locales/en.yml b/vendor/built_in_modules/survey_b/config/locales/en.yml new file mode 100644 index 00000000..d71ed578 --- /dev/null +++ b/vendor/built_in_modules/survey_b/config/locales/en.yml @@ -0,0 +1,105 @@ +en: + + survey_b: + survey_b: 滿意度調查 + result: 結果 + export: 匯出 + + setting: 設定 + description: 前言 + announcement: 個資宣告 + agree_check: 同意 + + created_at: 日期 + + institution_check_label: 您與本處有業務接觸之單位為:(請點選) + institution_group_label: "您對 %{institution} 所提供之" + + not_answered: 沒有回答 + + period: 調查期間 + period_title: 問卷標題 + no_survey: 尚無滿意度調查 + + status: 狀態 + status_types: + type1: 調查中 + type2: 未開始 + type3: 已結束 + + no_data: 沒有數據 + answered_count: 答題人數 + answered_sum: 整體平均 + answered_sum7: 七項平均 + + institutions: + institution1: 文書組 + institution2: 事務組 + institution3: 保管組 + institution4: 營繕組 + institution5: 出納組 + institution6: 採購組 + institution7: 經營管理組 + institution8: 駐警隊 + institution9: 社科院總務分處 + institution10: 醫學院總務分處 + # institution11: 總務處秘書室 + + degrees: + - 很滿意 + - 滿意 + - 尚可 + - 不滿意 + - 非常不滿意 + + questions: + question1: 1.服務態度 + question2: 2.主動服務之精神 + question3: 3.電話禮貌 + question4: 4.電話接聽速度 + question5: 5.承辦人專業態度 + question6: 6.辦公室環境 + question7: 7.業務辦理效率 + question8: 8.電腦化作業 + + quality_question_column: 行政品質 + quality_question_label: 對於總務處這一、二年之行政品質表現,您感覺是 + quality_question_options: + - 有顯著改善 + - 有些改善 + - 沒有改善 + - 降低 + + good_institutions_column: 品質較優 + good_institutions_label: 以您與總務處各單位接觸之經驗,您覺得那一組的服務品質較優。(可複選,可不選) + bad_institutions_column: 尚待改進 + bad_institutions_label: 以您與總務處各單位接觸之經驗,您覺得那一組的服務品質尚待改進。(可複選,可不選) + + rate_question_column: 評鑑分數 + rate_question_label: 若請您對本處整體行政品質表現給予評鑑分數,您會給幾分? + rate_question_options: + - 90分以上(極優) + - 80分至90分(優良) + - 70分至80分(尚可) + - 60至70分(待提昇) + - 60分以下(亟待改善) + + person_question_column: 身分 + person_question_label: 您的身分是 + person_question_options: + - 教師 + - 職工 + - 學生 + - 廠商 + - 其他 + + comment_question_notice: 您覺得本處之行政品質有那些地方尚有待改進嗎?(歡迎您將反應意見具體描述,以供我們檢討改進,謝謝您的指教!) + comment_question_label: 意見欄: + + contact_notice: 請您填寫以下個人資料,這些資訊僅供調查結束後辦理抽獎活動,及加速處理回覆您的建議事項之用。您的個人資料絕不會外流,請放心填寫!總務處感謝您的支持與愛護。 + contact_name_label: 填表人 + contact_phone_label: 聯絡電話 + contact_e_mail_label: e-mail + + frontend: + survey_b: 滿意度調查前台 diff --git a/vendor/built_in_modules/survey_b/config/locales/zh_tw.yml b/vendor/built_in_modules/survey_b/config/locales/zh_tw.yml new file mode 100644 index 00000000..fe80f891 --- /dev/null +++ b/vendor/built_in_modules/survey_b/config/locales/zh_tw.yml @@ -0,0 +1,105 @@ +zh_tw: + + survey_b: + survey_b: 滿意度調查 + result: 結果 + export: 匯出 + + setting: 設定 + description: 前言 + announcement: 個資宣告 + agree_check: 同意 + + created_at: 日期 + + institution_check_label: 您與本處有業務接觸之單位為:(請點選) + institution_group_label: "您對 %{institution} 所提供之" + + not_answered: 沒有回答 + + period: 調查期間 + period_title: 問卷標題 + no_survey: 尚無滿意度調查 + + status: 狀態 + status_types: + type1: 調查中 + type2: 未開始 + type3: 已結束 + + no_data: 沒有數據 + answered_count: 答題人數 + answered_sum: 整體平均 + answered_sum7: 七項平均 + + institutions: + institution1: 文書組 + institution2: 事務組 + institution3: 保管組 + institution4: 營繕組 + institution5: 出納組 + institution6: 採購組 + institution7: 經營管理組 + institution8: 駐警隊 + institution9: 社科院總務分處 + institution10: 醫學院總務分處 + # institution11: 總務處秘書室 + + degrees: + - 很滿意 + - 滿意 + - 尚可 + - 不滿意 + - 非常不滿意 + + questions: + question1: 1.服務態度 + question2: 2.主動服務之精神 + question3: 3.電話禮貌 + question4: 4.電話接聽速度 + question5: 5.承辦人專業態度 + question6: 6.辦公室環境 + question7: 7.業務辦理效率 + question8: 8.電腦化作業 + + quality_question_column: 行政品質 + quality_question_label: 對於總務處這一、二年之行政品質表現,您感覺是 + quality_question_options: + - 有顯著改善 + - 有些改善 + - 沒有改善 + - 降低 + + good_institutions_column: 品質較優 + good_institutions_label: 以您與總務處各單位接觸之經驗,您覺得那一組的服務品質較優。(可複選,可不選) + bad_institutions_column: 尚待改進 + bad_institutions_label: 以您與總務處各單位接觸之經驗,您覺得那一組的服務品質尚待改進。(可複選,可不選) + + rate_question_column: 評鑑分數 + rate_question_label: 若請您對本處整體行政品質表現給予評鑑分數,您會給幾分? + rate_question_options: + - 90分以上(極優) + - 80分至90分(優良) + - 70分至80分(尚可) + - 60至70分(待提昇) + - 60分以下(亟待改善) + + person_question_column: 身分 + person_question_label: 您的身分是 + person_question_options: + - 教師 + - 職工 + - 學生 + - 廠商 + - 其他 + + comment_question_notice: 您覺得本處之行政品質有那些地方尚有待改進嗎?(歡迎您將反應意見具體描述,以供我們檢討改進,謝謝您的指教!) + comment_question_label: 意見欄: + + contact_notice: 請您填寫以下個人資料,這些資訊僅供調查結束後辦理抽獎活動,及加速處理回覆您的建議事項之用。您的個人資料絕不會外流,請放心填寫!總務處感謝您的支持與愛護。 + contact_name_label: 填表人 + contact_phone_label: 聯絡電話 + contact_e_mail_label: e-mail + + frontend: + survey_b: 滿意度調查前台 diff --git a/vendor/built_in_modules/survey_b/config/routes.rb b/vendor/built_in_modules/survey_b/config/routes.rb new file mode 100644 index 00000000..23fd4a66 --- /dev/null +++ b/vendor/built_in_modules/survey_b/config/routes.rb @@ -0,0 +1,24 @@ +Rails.application.routes.draw do + + namespace :panel do + namespace :survey_b do + namespace :back_end do + resources :survey_b do + collection do + get 'result' + get 'delete' + get 'export' + end + end + resources :periods + resource :setting + end + namespace :front_end do + resources :survey_b do + + end + end + end + end + match "/appfront/*path" => redirect("/panel/*path") +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/init.rb b/vendor/built_in_modules/survey_b/init.rb new file mode 100644 index 00000000..3f506d4a --- /dev/null +++ b/vendor/built_in_modules/survey_b/init.rb @@ -0,0 +1,61 @@ +module SurveyB + OrbitApp.registration "SurveyB",:type=> 'ModuleApp' do + module_label 'survey_b.survey_b' + base_url File.expand_path File.dirname(__FILE__) + + version "0.1" + organization "Rulingcom" + author "RD dep" + intro "I am intro" + update_info 'some update_info' + + front_end do + app_page 'survey_b' do + frontend_i18n "survey_b.frontend.survey_b" + end + end + + authorizable + + widgets do + customize_widget "widget1" do + widget_i18n "survey_b.widget.widget1" + style [] + end + end + + side_bar do + head_label_i18n 'survey_b.survey_b',:icon_class=>"icons-bars" + available_for [:admin,:manager,:sub_manager] + active_for_controllers ({:private=>['survey_b', 'periods', 'settings']}) + + head_link_path "panel_survey_b_back_end_periods_path" + + # context_link 'survey_b.result', + # :link_path=>"result_panel_survey_b_back_end_survey_b_index_path" , + # :priority=>1, + # :active_for_action=>{:survey_b=>:result}, + # :available_for => [:manager] + + context_link 'list_', + :link_path=>"panel_survey_b_back_end_periods_path" , + :priority=>1, + :active_for_action=>{:survey_b=>:index}, + :available_for => [:manager] + + # context_link 'survey_b.period', + # :link_path=>"panel_survey_b_back_end_periods_path" , + # :priority=>1, + # :active_for_action=>{:periods=>:index}, + # :available_for => [:manager] + + context_link 'survey_b.setting', + :link_path=>"edit_panel_survey_b_back_end_setting_path" , + :priority=>1, + :active_for_action=>{:settings=>[:edit, :update]}, + :available_for => [:manager] + end + + end + +end \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/lib/survey_b.rb b/vendor/built_in_modules/survey_b/lib/survey_b.rb new file mode 100644 index 00000000..2a194f2e --- /dev/null +++ b/vendor/built_in_modules/survey_b/lib/survey_b.rb @@ -0,0 +1,2 @@ +module SurveyB +end diff --git a/vendor/built_in_modules/survey_b/lib/survey_b/version.rb b/vendor/built_in_modules/survey_b/lib/survey_b/version.rb new file mode 100644 index 00000000..ee077c28 --- /dev/null +++ b/vendor/built_in_modules/survey_b/lib/survey_b/version.rb @@ -0,0 +1,3 @@ +module SurveyB + VERSION = "0.0.1" +end diff --git a/vendor/built_in_modules/survey_b/lib/tasks/survey_b_tasks.rake b/vendor/built_in_modules/survey_b/lib/tasks/survey_b_tasks.rake new file mode 100644 index 00000000..9e7c6288 --- /dev/null +++ b/vendor/built_in_modules/survey_b/lib/tasks/survey_b_tasks.rake @@ -0,0 +1,4 @@ +# desc "Explaining what the task does" +# task :survey_b do +# # Task goes here +# end diff --git a/vendor/built_in_modules/survey_b/survey_b.gemspec b/vendor/built_in_modules/survey_b/survey_b.gemspec new file mode 100644 index 00000000..60f0bd6c --- /dev/null +++ b/vendor/built_in_modules/survey_b/survey_b.gemspec @@ -0,0 +1,22 @@ +$:.push File.expand_path("../lib", __FILE__) + +# Maintain your gem's version: +require "survey_b/version" + +# Describe your gem and declare its dependencies: +Gem::Specification.new do |s| + s.name = "survey_b" + s.version = SurveyB::VERSION + s.authors = ["TODO: Your name"] + s.email = ["TODO: Your email"] + s.homepage = "TODO" + s.summary = "TODO: Summary of SurveyB." + s.description = "TODO: Description of SurveyB." + + s.files = Dir["{app,config,db,lib}/**/*"] + ["MIT-LICENSE", "Rakefile", "README.rdoc"] + s.test_files = Dir["test/**/*"] + + s.add_dependency "rails", "~> 3.2.12" + + s.add_development_dependency "sqlite3" +end diff --git a/vendor/built_in_modules/survey_b/survey_b.json b/vendor/built_in_modules/survey_b/survey_b.json new file mode 100644 index 00000000..ec9a4e03 --- /dev/null +++ b/vendor/built_in_modules/survey_b/survey_b.json @@ -0,0 +1,12 @@ +{ + "title": "survey_b", + "version": "0.1", + "organization": "Rulingcom", + "author": "RD dep", + "intro": "survey_b", + "update_info": "Some info", + "create_date": "05-14-2013", + "widgets": ["survey_bs"], + "category": [], + "enable_frontend": true +} diff --git a/vendor/built_in_modules/survey_b/test/dummy/README.rdoc b/vendor/built_in_modules/survey_b/test/dummy/README.rdoc new file mode 100644 index 00000000..7c36f235 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/README.rdoc @@ -0,0 +1,261 @@ +== Welcome to Rails + +Rails is a web-application framework that includes everything needed to create +database-backed web applications according to the Model-View-Control pattern. + +This pattern splits the view (also called the presentation) into "dumb" +templates that are primarily responsible for inserting pre-built data in between +HTML tags. The model contains the "smart" domain objects (such as Account, +Product, Person, Post) that holds all the business logic and knows how to +persist themselves to a database. The controller handles the incoming requests +(such as Save New Account, Update Product, Show Post) by manipulating the model +and directing data to the view. + +In Rails, the model is handled by what's called an object-relational mapping +layer entitled Active Record. This layer allows you to present the data from +database rows as objects and embellish these data objects with business logic +methods. You can read more about Active Record in +link:files/vendor/rails/activerecord/README.html. + +The controller and view are handled by the Action Pack, which handles both +layers by its two parts: Action View and Action Controller. These two layers +are bundled in a single package due to their heavy interdependence. This is +unlike the relationship between the Active Record and Action Pack that is much +more separate. Each of these packages can be used independently outside of +Rails. You can read more about Action Pack in +link:files/vendor/rails/actionpack/README.html. + + +== Getting Started + +1. At the command prompt, create a new Rails application: + rails new myapp (where myapp is the application name) + +2. Change directory to myapp and start the web server: + cd myapp; rails server (run with --help for options) + +3. Go to http://localhost:3000/ and you'll see: + "Welcome aboard: You're riding Ruby on Rails!" + +4. Follow the guidelines to start developing your application. You can find +the following resources handy: + +* The Getting Started Guide: http://guides.rubyonrails.org/getting_started.html +* Ruby on Rails Tutorial Book: http://www.railstutorial.org/ + + +== Debugging Rails + +Sometimes your application goes wrong. Fortunately there are a lot of tools that +will help you debug it and get it back on the rails. + +First area to check is the application log files. Have "tail -f" commands +running on the server.log and development.log. Rails will automatically display +debugging and runtime information to these files. Debugging info will also be +shown in the browser on requests from 127.0.0.1. + +You can also log your own messages directly into the log file from your code +using the Ruby logger class from inside your controllers. Example: + + class WeblogController < ActionController::Base + def destroy + @weblog = Weblog.find(params[:id]) + @weblog.destroy + logger.info("#{Time.now} Destroyed Weblog ID ##{@weblog.id}!") + end + end + +The result will be a message in your log file along the lines of: + + Mon Oct 08 14:22:29 +1000 2007 Destroyed Weblog ID #1! + +More information on how to use the logger is at http://www.ruby-doc.org/core/ + +Also, Ruby documentation can be found at http://www.ruby-lang.org/. There are +several books available online as well: + +* Programming Ruby: http://www.ruby-doc.org/docs/ProgrammingRuby/ (Pickaxe) +* Learn to Program: http://pine.fm/LearnToProgram/ (a beginners guide) + +These two books will bring you up to speed on the Ruby language and also on +programming in general. + + +== Debugger + +Debugger support is available through the debugger command when you start your +Mongrel or WEBrick server with --debugger. This means that you can break out of +execution at any point in the code, investigate and change the model, and then, +resume execution! You need to install ruby-debug to run the server in debugging +mode. With gems, use sudo gem install ruby-debug. Example: + + class WeblogController < ActionController::Base + def index + @posts = Post.all + debugger + end + end + +So the controller will accept the action, run the first line, then present you +with a IRB prompt in the server window. Here you can do things like: + + >> @posts.inspect + => "[#nil, "body"=>nil, "id"=>"1"}>, + #"Rails", "body"=>"Only ten..", "id"=>"2"}>]" + >> @posts.first.title = "hello from a debugger" + => "hello from a debugger" + +...and even better, you can examine how your runtime objects actually work: + + >> f = @posts.first + => #nil, "body"=>nil, "id"=>"1"}> + >> f. + Display all 152 possibilities? (y or n) + +Finally, when you're ready to resume execution, you can enter "cont". + + +== Console + +The console is a Ruby shell, which allows you to interact with your +application's domain model. Here you'll have all parts of the application +configured, just like it is when the application is running. You can inspect +domain models, change values, and save to the database. Starting the script +without arguments will launch it in the development environment. + +To start the console, run rails console from the application +directory. + +Options: + +* Passing the -s, --sandbox argument will rollback any modifications + made to the database. +* Passing an environment name as an argument will load the corresponding + environment. Example: rails console production. + +To reload your controllers and models after launching the console run +reload! + +More information about irb can be found at: +link:http://www.rubycentral.org/pickaxe/irb.html + + +== dbconsole + +You can go to the command line of your database directly through rails +dbconsole. You would be connected to the database with the credentials +defined in database.yml. Starting the script without arguments will connect you +to the development database. Passing an argument will connect you to a different +database, like rails dbconsole production. Currently works for MySQL, +PostgreSQL and SQLite 3. + +== Description of Contents + +The default directory structure of a generated Ruby on Rails application: + + |-- app + | |-- assets + | |-- images + | |-- javascripts + | `-- stylesheets + | |-- controllers + | |-- helpers + | |-- mailers + | |-- models + | `-- views + | `-- layouts + |-- config + | |-- environments + | |-- initializers + | `-- locales + |-- db + |-- doc + |-- lib + | `-- tasks + |-- log + |-- public + |-- script + |-- test + | |-- fixtures + | |-- functional + | |-- integration + | |-- performance + | `-- unit + |-- tmp + | |-- cache + | |-- pids + | |-- sessions + | `-- sockets + `-- vendor + |-- assets + `-- stylesheets + `-- plugins + +app + Holds all the code that's specific to this particular application. + +app/assets + Contains subdirectories for images, stylesheets, and JavaScript files. + +app/controllers + Holds controllers that should be named like weblogs_controller.rb for + automated URL mapping. All controllers should descend from + ApplicationController which itself descends from ActionController::Base. + +app/models + Holds models that should be named like post.rb. Models descend from + ActiveRecord::Base by default. + +app/views + Holds the template files for the view that should be named like + weblogs/index.html.erb for the WeblogsController#index action. All views use + eRuby syntax by default. + +app/views/layouts + Holds the template files for layouts to be used with views. This models the + common header/footer method of wrapping views. In your views, define a layout + using the layout :default and create a file named default.html.erb. + Inside default.html.erb, call <% yield %> to render the view using this + layout. + +app/helpers + Holds view helpers that should be named like weblogs_helper.rb. These are + generated for you automatically when using generators for controllers. + Helpers can be used to wrap functionality for your views into methods. + +config + Configuration files for the Rails environment, the routing map, the database, + and other dependencies. + +db + Contains the database schema in schema.rb. db/migrate contains all the + sequence of Migrations for your schema. + +doc + This directory is where your application documentation will be stored when + generated using rake doc:app + +lib + Application specific libraries. Basically, any kind of custom code that + doesn't belong under controllers, models, or helpers. This directory is in + the load path. + +public + The directory available for the web server. Also contains the dispatchers and the + default HTML files. This should be set as the DOCUMENT_ROOT of your web + server. + +script + Helper scripts for automation and generation. + +test + Unit and functional tests along with fixtures. When using the rails generate + command, template test files will be generated for you and placed in this + directory. + +vendor + External libraries that the application depends on. Also includes the plugins + subdirectory. If the app has frozen rails, those gems also go here, under + vendor/rails/. This directory is in the load path. diff --git a/vendor/built_in_modules/survey_b/test/dummy/Rakefile b/vendor/built_in_modules/survey_b/test/dummy/Rakefile new file mode 100644 index 00000000..36458522 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/Rakefile @@ -0,0 +1,7 @@ +#!/usr/bin/env rake +# Add your own tasks in files placed in lib/tasks ending in .rake, +# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake. + +require File.expand_path('../config/application', __FILE__) + +Dummy::Application.load_tasks diff --git a/vendor/built_in_modules/survey_b/test/dummy/app/assets/javascripts/application.js b/vendor/built_in_modules/survey_b/test/dummy/app/assets/javascripts/application.js new file mode 100644 index 00000000..9097d830 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/app/assets/javascripts/application.js @@ -0,0 +1,15 @@ +// This is a manifest file that'll be compiled into application.js, which will include all the files +// listed below. +// +// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts, +// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path. +// +// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the +// the compiled file. +// +// WARNING: THE FIRST BLANK LINE MARKS THE END OF WHAT'S TO BE PROCESSED, ANY BLANK LINE SHOULD +// GO AFTER THE REQUIRES BELOW. +// +//= require jquery +//= require jquery_ujs +//= require_tree . diff --git a/vendor/built_in_modules/survey_b/test/dummy/app/assets/stylesheets/application.css b/vendor/built_in_modules/survey_b/test/dummy/app/assets/stylesheets/application.css new file mode 100644 index 00000000..3192ec89 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/app/assets/stylesheets/application.css @@ -0,0 +1,13 @@ +/* + * This is a manifest file that'll be compiled into application.css, which will include all the files + * listed below. + * + * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets, + * or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path. + * + * You're free to add application-wide styles to this file and they'll appear at the top of the + * compiled file, but it's generally better to create a new file per style scope. + * + *= require_self + *= require_tree . + */ diff --git a/vendor/built_in_modules/survey_b/test/dummy/app/controllers/application_controller.rb b/vendor/built_in_modules/survey_b/test/dummy/app/controllers/application_controller.rb new file mode 100644 index 00000000..e8065d95 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/app/controllers/application_controller.rb @@ -0,0 +1,3 @@ +class ApplicationController < ActionController::Base + protect_from_forgery +end diff --git a/vendor/built_in_modules/survey_b/test/dummy/app/helpers/application_helper.rb b/vendor/built_in_modules/survey_b/test/dummy/app/helpers/application_helper.rb new file mode 100644 index 00000000..de6be794 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/app/helpers/application_helper.rb @@ -0,0 +1,2 @@ +module ApplicationHelper +end diff --git a/vendor/built_in_modules/survey_b/test/dummy/app/views/layouts/application.html.erb b/vendor/built_in_modules/survey_b/test/dummy/app/views/layouts/application.html.erb new file mode 100644 index 00000000..4cab2684 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/app/views/layouts/application.html.erb @@ -0,0 +1,14 @@ + + + + Dummy + <%= stylesheet_link_tag "application", :media => "all" %> + <%= javascript_include_tag "application" %> + <%= csrf_meta_tags %> + + + +<%= yield %> + + + diff --git a/vendor/built_in_modules/survey_b/test/dummy/config.ru b/vendor/built_in_modules/survey_b/test/dummy/config.ru new file mode 100644 index 00000000..1989ed8d --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config.ru @@ -0,0 +1,4 @@ +# This file is used by Rack-based servers to start the application. + +require ::File.expand_path('../config/environment', __FILE__) +run Dummy::Application diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/application.rb b/vendor/built_in_modules/survey_b/test/dummy/config/application.rb new file mode 100644 index 00000000..0009468a --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/application.rb @@ -0,0 +1,59 @@ +require File.expand_path('../boot', __FILE__) + +require 'rails/all' + +Bundler.require +require "survey_b" + +module Dummy + class Application < Rails::Application + # Settings in config/environments/* take precedence over those specified here. + # Application configuration should go into files in config/initializers + # -- all .rb files in that directory are automatically loaded. + + # Custom directories with classes and modules you want to be autoloadable. + # config.autoload_paths += %W(#{config.root}/extras) + + # Only load the plugins named here, in the order given (default is alphabetical). + # :all can be used as a placeholder for all plugins not explicitly named. + # config.plugins = [ :exception_notification, :ssl_requirement, :all ] + + # Activate observers that should always be running. + # config.active_record.observers = :cacher, :garbage_collector, :forum_observer + + # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone. + # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC. + # config.time_zone = 'Central Time (US & Canada)' + + # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded. + # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s] + # config.i18n.default_locale = :de + + # Configure the default encoding used in templates for Ruby 1.9. + config.encoding = "utf-8" + + # Configure sensitive parameters which will be filtered from the log file. + config.filter_parameters += [:password] + + # Enable escaping HTML in JSON. + config.active_support.escape_html_entities_in_json = true + + # Use SQL instead of Active Record's schema dumper when creating the database. + # This is necessary if your schema can't be completely dumped by the schema dumper, + # like if you have constraints or database-specific column types + # config.active_record.schema_format = :sql + + # Enforce whitelist mode for mass assignment. + # This will create an empty whitelist of attributes available for mass-assignment for all models + # in your app. As such, your models will need to explicitly whitelist or blacklist accessible + # parameters by using an attr_accessible or attr_protected declaration. + config.active_record.whitelist_attributes = true + + # Enable the asset pipeline + config.assets.enabled = true + + # Version of your assets, change this if you want to expire all your assets + config.assets.version = '1.0' + end +end + diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/boot.rb b/vendor/built_in_modules/survey_b/test/dummy/config/boot.rb new file mode 100644 index 00000000..eba06813 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/boot.rb @@ -0,0 +1,10 @@ +require 'rubygems' +gemfile = File.expand_path('../../../../Gemfile', __FILE__) + +if File.exist?(gemfile) + ENV['BUNDLE_GEMFILE'] = gemfile + require 'bundler' + Bundler.setup +end + +$:.unshift File.expand_path('../../../../lib', __FILE__) \ No newline at end of file diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/database.yml b/vendor/built_in_modules/survey_b/test/dummy/config/database.yml new file mode 100644 index 00000000..51a4dd45 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/database.yml @@ -0,0 +1,25 @@ +# SQLite version 3.x +# gem install sqlite3 +# +# Ensure the SQLite 3 gem is defined in your Gemfile +# gem 'sqlite3' +development: + adapter: sqlite3 + database: db/development.sqlite3 + pool: 5 + timeout: 5000 + +# Warning: The database defined as "test" will be erased and +# re-generated from your development database when you run "rake". +# Do not set this db to the same as development or production. +test: + adapter: sqlite3 + database: db/test.sqlite3 + pool: 5 + timeout: 5000 + +production: + adapter: sqlite3 + database: db/production.sqlite3 + pool: 5 + timeout: 5000 diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/environment.rb b/vendor/built_in_modules/survey_b/test/dummy/config/environment.rb new file mode 100644 index 00000000..3da5eb91 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/environment.rb @@ -0,0 +1,5 @@ +# Load the rails application +require File.expand_path('../application', __FILE__) + +# Initialize the rails application +Dummy::Application.initialize! diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/environments/development.rb b/vendor/built_in_modules/survey_b/test/dummy/config/environments/development.rb new file mode 100644 index 00000000..82c74d15 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/environments/development.rb @@ -0,0 +1,37 @@ +Dummy::Application.configure do + # Settings specified here will take precedence over those in config/application.rb + + # In the development environment your application's code is reloaded on + # every request. This slows down response time but is perfect for development + # since you don't have to restart the web server when you make code changes. + config.cache_classes = false + + # Log error messages when you accidentally call methods on nil. + config.whiny_nils = true + + # Show full error reports and disable caching + config.consider_all_requests_local = true + config.action_controller.perform_caching = false + + # Don't care if the mailer can't send + config.action_mailer.raise_delivery_errors = false + + # Print deprecation notices to the Rails logger + config.active_support.deprecation = :log + + # Only use best-standards-support built into browsers + config.action_dispatch.best_standards_support = :builtin + + # Raise exception on mass assignment protection for Active Record models + config.active_record.mass_assignment_sanitizer = :strict + + # Log the query plan for queries taking more than this (works + # with SQLite, MySQL, and PostgreSQL) + config.active_record.auto_explain_threshold_in_seconds = 0.5 + + # Do not compress assets + config.assets.compress = false + + # Expands the lines which load the assets + config.assets.debug = true +end diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/environments/production.rb b/vendor/built_in_modules/survey_b/test/dummy/config/environments/production.rb new file mode 100644 index 00000000..bdac56a7 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/environments/production.rb @@ -0,0 +1,67 @@ +Dummy::Application.configure do + # Settings specified here will take precedence over those in config/application.rb + + # Code is not reloaded between requests + config.cache_classes = true + + # Full error reports are disabled and caching is turned on + config.consider_all_requests_local = false + config.action_controller.perform_caching = true + + # Disable Rails's static asset server (Apache or nginx will already do this) + config.serve_static_assets = false + + # Compress JavaScripts and CSS + config.assets.compress = true + + # Don't fallback to assets pipeline if a precompiled asset is missed + config.assets.compile = false + + # Generate digests for assets URLs + config.assets.digest = true + + # Defaults to nil and saved in location specified by config.assets.prefix + # config.assets.manifest = YOUR_PATH + + # Specifies the header that your server uses for sending files + # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache + # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx + + # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies. + # config.force_ssl = true + + # See everything in the log (default is :info) + # config.log_level = :debug + + # Prepend all log lines with the following tags + # config.log_tags = [ :subdomain, :uuid ] + + # Use a different logger for distributed setups + # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new) + + # Use a different cache store in production + # config.cache_store = :mem_cache_store + + # Enable serving of images, stylesheets, and JavaScripts from an asset server + # config.action_controller.asset_host = "http://assets.example.com" + + # Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added) + # config.assets.precompile += %w( search.js ) + + # Disable delivery errors, bad email addresses will be ignored + # config.action_mailer.raise_delivery_errors = false + + # Enable threaded mode + # config.threadsafe! + + # Enable locale fallbacks for I18n (makes lookups for any locale fall back to + # the I18n.default_locale when a translation can not be found) + config.i18n.fallbacks = true + + # Send deprecation notices to registered listeners + config.active_support.deprecation = :notify + + # Log the query plan for queries taking more than this (works + # with SQLite, MySQL, and PostgreSQL) + # config.active_record.auto_explain_threshold_in_seconds = 0.5 +end diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/environments/test.rb b/vendor/built_in_modules/survey_b/test/dummy/config/environments/test.rb new file mode 100644 index 00000000..f1a48141 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/environments/test.rb @@ -0,0 +1,37 @@ +Dummy::Application.configure do + # Settings specified here will take precedence over those in config/application.rb + + # The test environment is used exclusively to run your application's + # test suite. You never need to work with it otherwise. Remember that + # your test database is "scratch space" for the test suite and is wiped + # and recreated between test runs. Don't rely on the data there! + config.cache_classes = true + + # Configure static asset server for tests with Cache-Control for performance + config.serve_static_assets = true + config.static_cache_control = "public, max-age=3600" + + # Log error messages when you accidentally call methods on nil + config.whiny_nils = true + + # Show full error reports and disable caching + config.consider_all_requests_local = true + config.action_controller.perform_caching = false + + # Raise exceptions instead of rendering exception templates + config.action_dispatch.show_exceptions = false + + # Disable request forgery protection in test environment + config.action_controller.allow_forgery_protection = false + + # Tell Action Mailer not to deliver emails to the real world. + # The :test delivery method accumulates sent emails in the + # ActionMailer::Base.deliveries array. + config.action_mailer.delivery_method = :test + + # Raise exception on mass assignment protection for Active Record models + config.active_record.mass_assignment_sanitizer = :strict + + # Print deprecation notices to the stderr + config.active_support.deprecation = :stderr +end diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/initializers/backtrace_silencers.rb b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/backtrace_silencers.rb new file mode 100644 index 00000000..59385cdf --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/backtrace_silencers.rb @@ -0,0 +1,7 @@ +# Be sure to restart your server when you modify this file. + +# You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces. +# Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ } + +# You can also remove all the silencers if you're trying to debug a problem that might stem from framework code. +# Rails.backtrace_cleaner.remove_silencers! diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/initializers/inflections.rb b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/inflections.rb new file mode 100644 index 00000000..5d8d9be2 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/inflections.rb @@ -0,0 +1,15 @@ +# Be sure to restart your server when you modify this file. + +# Add new inflection rules using the following format +# (all these examples are active by default): +# ActiveSupport::Inflector.inflections do |inflect| +# inflect.plural /^(ox)$/i, '\1en' +# inflect.singular /^(ox)en/i, '\1' +# inflect.irregular 'person', 'people' +# inflect.uncountable %w( fish sheep ) +# end +# +# These inflection rules are supported but not enabled by default: +# ActiveSupport::Inflector.inflections do |inflect| +# inflect.acronym 'RESTful' +# end diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/initializers/mime_types.rb b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/mime_types.rb new file mode 100644 index 00000000..72aca7e4 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/mime_types.rb @@ -0,0 +1,5 @@ +# Be sure to restart your server when you modify this file. + +# Add new mime types for use in respond_to blocks: +# Mime::Type.register "text/richtext", :rtf +# Mime::Type.register_alias "text/html", :iphone diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/initializers/secret_token.rb b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/secret_token.rb new file mode 100644 index 00000000..75afdebe --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/secret_token.rb @@ -0,0 +1,7 @@ +# Be sure to restart your server when you modify this file. + +# Your secret key for verifying the integrity of signed cookies. +# If you change this key, all old signed cookies will become invalid! +# Make sure the secret is at least 30 characters and all random, +# no regular words or you'll be exposed to dictionary attacks. +Dummy::Application.config.secret_token = 'd7805d46c934ccf6140641370f099c8cabadbfcf7dbafc17f06c1b4750b9bc1ef733a96efba7389aa14ecfb942607d142a4a979e76040ce0df9a06944d45fb70' diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/initializers/session_store.rb b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/session_store.rb new file mode 100644 index 00000000..952473ff --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/session_store.rb @@ -0,0 +1,8 @@ +# Be sure to restart your server when you modify this file. + +Dummy::Application.config.session_store :cookie_store, key: '_dummy_session' + +# Use the database for sessions instead of the cookie-based default, +# which shouldn't be used to store highly confidential information +# (create the session table with "rails generate session_migration") +# Dummy::Application.config.session_store :active_record_store diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/initializers/wrap_parameters.rb b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/wrap_parameters.rb new file mode 100644 index 00000000..999df201 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/initializers/wrap_parameters.rb @@ -0,0 +1,14 @@ +# Be sure to restart your server when you modify this file. +# +# This file contains settings for ActionController::ParamsWrapper which +# is enabled by default. + +# Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array. +ActiveSupport.on_load(:action_controller) do + wrap_parameters format: [:json] +end + +# Disable root element in JSON by default. +ActiveSupport.on_load(:active_record) do + self.include_root_in_json = false +end diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/locales/en.yml b/vendor/built_in_modules/survey_b/test/dummy/config/locales/en.yml new file mode 100644 index 00000000..179c14ca --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/locales/en.yml @@ -0,0 +1,5 @@ +# Sample localization file for English. Add more files in this directory for other locales. +# See https://github.com/svenfuchs/rails-i18n/tree/master/rails%2Flocale for starting points. + +en: + hello: "Hello world" diff --git a/vendor/built_in_modules/survey_b/test/dummy/config/routes.rb b/vendor/built_in_modules/survey_b/test/dummy/config/routes.rb new file mode 100644 index 00000000..eb8579be --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/config/routes.rb @@ -0,0 +1,58 @@ +Dummy::Application.routes.draw do + # The priority is based upon order of creation: + # first created -> highest priority. + + # Sample of regular route: + # match 'products/:id' => 'catalog#view' + # Keep in mind you can assign values other than :controller and :action + + # Sample of named route: + # match 'products/:id/purchase' => 'catalog#purchase', :as => :purchase + # This route can be invoked with purchase_url(:id => product.id) + + # Sample resource route (maps HTTP verbs to controller actions automatically): + # resources :products + + # Sample resource route with options: + # resources :products do + # member do + # get 'short' + # post 'toggle' + # end + # + # collection do + # get 'sold' + # end + # end + + # Sample resource route with sub-resources: + # resources :products do + # resources :comments, :sales + # resource :seller + # end + + # Sample resource route with more complex sub-resources + # resources :products do + # resources :comments + # resources :sales do + # get 'recent', :on => :collection + # end + # end + + # Sample resource route within a namespace: + # namespace :admin do + # # Directs /admin/products/* to Admin::ProductsController + # # (app/controllers/admin/products_controller.rb) + # resources :products + # end + + # You can have the root of your site routed with "root" + # just remember to delete public/index.html. + # root :to => 'welcome#index' + + # See how all your routes lay out with "rake routes" + + # This is a legacy wild controller route that's not recommended for RESTful applications. + # Note: This route will make all actions in every controller accessible via GET requests. + # match ':controller(/:action(/:id))(.:format)' +end diff --git a/vendor/built_in_modules/survey_b/test/dummy/public/404.html b/vendor/built_in_modules/survey_b/test/dummy/public/404.html new file mode 100644 index 00000000..9a48320a --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/public/404.html @@ -0,0 +1,26 @@ + + + + The page you were looking for doesn't exist (404) + + + + + +
+

The page you were looking for doesn't exist.

+

You may have mistyped the address or the page may have moved.

+
+ + diff --git a/vendor/built_in_modules/survey_b/test/dummy/public/422.html b/vendor/built_in_modules/survey_b/test/dummy/public/422.html new file mode 100644 index 00000000..83660ab1 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/public/422.html @@ -0,0 +1,26 @@ + + + + The change you wanted was rejected (422) + + + + + +
+

The change you wanted was rejected.

+

Maybe you tried to change something you didn't have access to.

+
+ + diff --git a/vendor/built_in_modules/survey_b/test/dummy/public/500.html b/vendor/built_in_modules/survey_b/test/dummy/public/500.html new file mode 100644 index 00000000..f3648a0d --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/public/500.html @@ -0,0 +1,25 @@ + + + + We're sorry, but something went wrong (500) + + + + + +
+

We're sorry, but something went wrong.

+
+ + diff --git a/vendor/built_in_modules/survey_b/test/dummy/public/favicon.ico b/vendor/built_in_modules/survey_b/test/dummy/public/favicon.ico new file mode 100644 index 00000000..e69de29b diff --git a/vendor/built_in_modules/survey_b/test/dummy/script/rails b/vendor/built_in_modules/survey_b/test/dummy/script/rails new file mode 100644 index 00000000..f8da2cff --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/dummy/script/rails @@ -0,0 +1,6 @@ +#!/usr/bin/env ruby +# This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application. + +APP_PATH = File.expand_path('../../config/application', __FILE__) +require File.expand_path('../../config/boot', __FILE__) +require 'rails/commands' diff --git a/vendor/built_in_modules/survey_b/test/survey_b_test.rb b/vendor/built_in_modules/survey_b/test/survey_b_test.rb new file mode 100644 index 00000000..3caa9891 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/survey_b_test.rb @@ -0,0 +1,7 @@ +require 'test_helper' + +class SurveyBTest < ActiveSupport::TestCase + test "truth" do + assert_kind_of Module, SurveyB + end +end diff --git a/vendor/built_in_modules/survey_b/test/test_helper.rb b/vendor/built_in_modules/survey_b/test/test_helper.rb new file mode 100644 index 00000000..1e26a313 --- /dev/null +++ b/vendor/built_in_modules/survey_b/test/test_helper.rb @@ -0,0 +1,15 @@ +# Configure Rails Environment +ENV["RAILS_ENV"] = "test" + +require File.expand_path("../dummy/config/environment.rb", __FILE__) +require "rails/test_help" + +Rails.backtrace_cleaner.remove_silencers! + +# Load support files +Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f } + +# Load fixtures from the engine +if ActiveSupport::TestCase.method_defined?(:fixture_path=) + ActiveSupport::TestCase.fixture_path = File.expand_path("../fixtures", __FILE__) +end