first commit
This commit is contained in:
commit
3f73010279
|
@ -0,0 +1,8 @@
|
||||||
|
.bundle/
|
||||||
|
log/*.log
|
||||||
|
pkg/
|
||||||
|
test/dummy/db/*.sqlite3
|
||||||
|
test/dummy/db/*.sqlite3-journal
|
||||||
|
test/dummy/log/*.log
|
||||||
|
test/dummy/tmp/
|
||||||
|
test/dummy/.sass-cache
|
|
@ -0,0 +1,14 @@
|
||||||
|
source "https://rubygems.org"
|
||||||
|
|
||||||
|
# Declare your gem's dependencies in e_paper.gemspec.
|
||||||
|
# Bundler will treat runtime dependencies like base dependencies, and
|
||||||
|
# development dependencies will be added by default to the :development group.
|
||||||
|
gemspec
|
||||||
|
|
||||||
|
# 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'
|
|
@ -0,0 +1,20 @@
|
||||||
|
Copyright 2019 Harry Bomrah
|
||||||
|
|
||||||
|
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.
|
|
@ -0,0 +1,3 @@
|
||||||
|
= EPaper
|
||||||
|
|
||||||
|
This project rocks and uses MIT-LICENSE.
|
|
@ -0,0 +1,34 @@
|
||||||
|
begin
|
||||||
|
require 'bundler/setup'
|
||||||
|
rescue LoadError
|
||||||
|
puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
|
||||||
|
end
|
||||||
|
|
||||||
|
require 'rdoc/task'
|
||||||
|
|
||||||
|
RDoc::Task.new(:rdoc) do |rdoc|
|
||||||
|
rdoc.rdoc_dir = 'rdoc'
|
||||||
|
rdoc.title = 'EPaper'
|
||||||
|
rdoc.options << '--line-numbers'
|
||||||
|
rdoc.rdoc_files.include('README.rdoc')
|
||||||
|
rdoc.rdoc_files.include('lib/**/*.rb')
|
||||||
|
end
|
||||||
|
|
||||||
|
APP_RAKEFILE = File.expand_path("../test/dummy/Rakefile", __FILE__)
|
||||||
|
load 'rails/tasks/engine.rake'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
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
|
|
@ -0,0 +1,13 @@
|
||||||
|
// 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
|
||||||
|
// compiled file.
|
||||||
|
//
|
||||||
|
// Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
|
||||||
|
// about supported directives.
|
||||||
|
//
|
||||||
|
//= require_tree .
|
|
@ -0,0 +1,15 @@
|
||||||
|
/*
|
||||||
|
* 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 bottom of the
|
||||||
|
* compiled file so the styles you add here take precedence over styles defined in any styles
|
||||||
|
* defined in the other CSS/SCSS files in this directory. It is generally better to create a new
|
||||||
|
* file per style scope.
|
||||||
|
*
|
||||||
|
*= require_tree .
|
||||||
|
*= require_self
|
||||||
|
*/
|
|
@ -0,0 +1,61 @@
|
||||||
|
class Admin::EPaperCriteriasController < OrbitAdminController
|
||||||
|
|
||||||
|
def initialize
|
||||||
|
super
|
||||||
|
@app_title = "e_paper"
|
||||||
|
end
|
||||||
|
|
||||||
|
def index
|
||||||
|
@table_fields = [t('e_paper.criteria_title'),t('e_paper.date_span')]
|
||||||
|
|
||||||
|
@filter_fields = filter_fields([], @module_app.tags)
|
||||||
|
@filter_fields.delete(:status)
|
||||||
|
@filter_fields.delete(:categories)
|
||||||
|
@criterias = PaperCriteria.order_by(sort)
|
||||||
|
# .with_tags(filters("tags"))
|
||||||
|
|
||||||
|
@criterias = search_data(@criterias,[:title]).page(params[:page]).per(10)
|
||||||
|
@url = "/" + I18n.locale.to_s + "/" +Page.where(:module => "e_paper").first.url + "?method=papers"
|
||||||
|
render :partial => "index" if request.xhr?
|
||||||
|
end
|
||||||
|
|
||||||
|
def new
|
||||||
|
@paper_criteria = PaperCriteria.new
|
||||||
|
end
|
||||||
|
|
||||||
|
def create
|
||||||
|
paper_criteria = PaperCriteria.create(paper_criteria_params)
|
||||||
|
redirect_to admin_e_paper_criterias_path
|
||||||
|
end
|
||||||
|
|
||||||
|
def edit
|
||||||
|
@paper_criteria = PaperCriteria.find(params[:id])
|
||||||
|
end
|
||||||
|
|
||||||
|
def update
|
||||||
|
paper_criteria = PaperCriteria.find(params[:id])
|
||||||
|
paper_criteria.update_attributes(paper_criteria_params)
|
||||||
|
redirect_to admin_e_paper_criterias_path
|
||||||
|
end
|
||||||
|
|
||||||
|
def destroy
|
||||||
|
paper_criteria = PaperCriteria.find(params[:id])
|
||||||
|
paper_criteria.destroy
|
||||||
|
redirect_to admin_e_paper_criterias_path
|
||||||
|
end
|
||||||
|
|
||||||
|
def send_test_email
|
||||||
|
paper_criteria = PaperCriteria.find(params[:id])
|
||||||
|
page = Page.where(:module_app => "e_paper").first.url rescue ""
|
||||||
|
email = Email.new(:mail_subject => paper_criteria.title, :mail_lang => :zh_tw, :template => "admin/e_paper_criterias/emailer", :template_data => {"paper" => paper_criteria, "page" => "http://" + request.host_with_port + page}, :mail_to => params[:email])
|
||||||
|
email.deliver
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def paper_criteria_params
|
||||||
|
params.require(:paper_criteria).permit!
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,28 @@
|
||||||
|
class Admin::EPaperSubscribersController < OrbitAdminController
|
||||||
|
|
||||||
|
def initialize
|
||||||
|
super
|
||||||
|
@app_title = "e_paper"
|
||||||
|
end
|
||||||
|
|
||||||
|
def index
|
||||||
|
@table_fields = [t('email'), t('status'), t('language')]
|
||||||
|
|
||||||
|
@filter_fields = filter_fields([], [])
|
||||||
|
@filter_fields.delete(:status)
|
||||||
|
@filter_fields.delete(:category)
|
||||||
|
@filter_fields.delete(:tags)
|
||||||
|
@subscribers = EPaperSubscriber.order_by(sort)
|
||||||
|
|
||||||
|
@subscribers = search_data(@subscribers,[:email]).page(params[:page]).per(10)
|
||||||
|
render :partial => "index" if request.xhr?
|
||||||
|
end
|
||||||
|
|
||||||
|
def destroy
|
||||||
|
subscriber = EPaperSubscriber.find(params[:id]) rescue nil
|
||||||
|
if !subscriber.nil?
|
||||||
|
subscriber.destroy
|
||||||
|
end
|
||||||
|
redirect_to admin_e_paper_subscribers_path
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,59 @@
|
||||||
|
class Admin::EPapersController < OrbitAdminController
|
||||||
|
def index
|
||||||
|
@table_fields = [:category,t('e_paper.title'),t('e_paper.publish_date'),t('tags')]
|
||||||
|
@categories = @module_app.categories.enabled
|
||||||
|
@tags = @module_app.tags
|
||||||
|
@filter_fields = filter_fields(@categories, @tags)
|
||||||
|
@filter_fields.delete(:status)
|
||||||
|
@papers = EPaperTopic.order_by(sort)
|
||||||
|
.with_categories(filters("category"))
|
||||||
|
|
||||||
|
|
||||||
|
@papers = search_data(@papers,[:title]).page(params[:page]).per(10)
|
||||||
|
|
||||||
|
render :partial => "index" if request.xhr?
|
||||||
|
end
|
||||||
|
|
||||||
|
def new
|
||||||
|
@paper = EPaperTopic.new
|
||||||
|
end
|
||||||
|
|
||||||
|
def destroy
|
||||||
|
paper = EPaperTopic.find(params[:id])
|
||||||
|
paper.destroy
|
||||||
|
redirect_to admin_e_papers_path
|
||||||
|
end
|
||||||
|
|
||||||
|
def create
|
||||||
|
@paper = EPaperTopic.new(e_paper_params)
|
||||||
|
@paper.save
|
||||||
|
redirect_to admin_e_papers_path
|
||||||
|
end
|
||||||
|
|
||||||
|
def edit
|
||||||
|
@paper = EPaperTopic.find(params[:id])
|
||||||
|
end
|
||||||
|
|
||||||
|
def update
|
||||||
|
paper = EPaperTopic.find(params[:id])
|
||||||
|
paper.update_attributes(e_paper_params)
|
||||||
|
paper.save
|
||||||
|
redirect_to admin_e_papers_path
|
||||||
|
end
|
||||||
|
|
||||||
|
def subscribers
|
||||||
|
@subscribers = Subscriber.all.desc(:created_at)
|
||||||
|
end
|
||||||
|
|
||||||
|
def send_email_to_subscribers
|
||||||
|
end
|
||||||
|
|
||||||
|
def instructions
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def e_paper_params
|
||||||
|
params.require(:e_paper_topic).permit!
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,231 @@
|
||||||
|
class EPapersController < ApplicationController
|
||||||
|
|
||||||
|
def index
|
||||||
|
topics = EPaperTopic.filter_by_categories.desc(:period)
|
||||||
|
data = topics.collect do |topic|
|
||||||
|
{
|
||||||
|
"title" => topic.title,
|
||||||
|
"link_to_show" => OrbitHelper.url_to_show(topic.to_param),
|
||||||
|
"description" => topic.description,
|
||||||
|
"img_url" => topic.image.url,
|
||||||
|
"img_url_thumb" => topic.image.thumb.url,
|
||||||
|
"category" => topic.category.title
|
||||||
|
}
|
||||||
|
end
|
||||||
|
{
|
||||||
|
"topics" => data,
|
||||||
|
"extras" => {
|
||||||
|
|
||||||
|
},
|
||||||
|
"total_pages" => topics.total_pages
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def papers
|
||||||
|
params = OrbitHelper.params
|
||||||
|
criterias = PaperCriteria.all.desc(:start_date).page(OrbitHelper.page_number).per(OrbitHelper.page_data_count)
|
||||||
|
data = criterias.collect do |criteria|
|
||||||
|
{
|
||||||
|
"title" => criteria.title,
|
||||||
|
"description" => criteria.description,
|
||||||
|
"link_to_show" => OrbitHelper.url_to_show(criteria.to_param) + "?method=topics"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
{
|
||||||
|
"criterias" => data,
|
||||||
|
"extras" => {
|
||||||
|
"th_title" => t('e_paper.title'),
|
||||||
|
"th_description" => t('e_paper.description')
|
||||||
|
},
|
||||||
|
"total_pages" => criterias.total_pages
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def show
|
||||||
|
params = OrbitHelper.params
|
||||||
|
epaper = EPaperTopic.where(:uid => params[:uid]).first
|
||||||
|
member = MemberProfile.find(epaper.article_authors.first) rescue nil
|
||||||
|
if !member.nil?
|
||||||
|
member_pic = member.get_avatar
|
||||||
|
member_autobiography = member.autobiography
|
||||||
|
member_name = member.name
|
||||||
|
end
|
||||||
|
{
|
||||||
|
|
||||||
|
"content" => epaper.content,
|
||||||
|
"publish_date" => epaper.period,
|
||||||
|
"description" => epaper.description,
|
||||||
|
"image_url" => epaper.image.url,
|
||||||
|
"image_thumb_url" => epaper.image.thumb.url,
|
||||||
|
"title" => epaper.title,
|
||||||
|
"category_title" => epaper.category.title,
|
||||||
|
"criteria_title" => epaper.criteria_title,
|
||||||
|
"member_pic" => member_pic,
|
||||||
|
"member_autobiography" => member_autobiography,
|
||||||
|
"member_name" => member_name
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def topics
|
||||||
|
params = OrbitHelper.params
|
||||||
|
criteria = PaperCriteria.where(:uid => params[:uid]).first
|
||||||
|
if params["category"].present?
|
||||||
|
papers = criteria.epaper_topics.where(:category_id => params["category"]).group_by(&:category)
|
||||||
|
else
|
||||||
|
papers = criteria.epaper_topics.group_by(&:category)
|
||||||
|
end
|
||||||
|
data = []
|
||||||
|
papers.each do |category, topics|
|
||||||
|
topics_data = topics.collect do |topic|
|
||||||
|
{
|
||||||
|
"title" => topic.title,
|
||||||
|
"link_to_show" => OrbitHelper.url_to_show(topic.to_param),
|
||||||
|
"description" => topic.description,
|
||||||
|
"img_url" => topic.image.url,
|
||||||
|
"img_url_thumb" => topic.image.thumb.url,
|
||||||
|
"category" => category.title
|
||||||
|
}
|
||||||
|
end
|
||||||
|
data << {
|
||||||
|
"category_title" => category.title,
|
||||||
|
"category_link" => params["url"] + "/" + params["page"] + "?method=topics&category=#{category.id.to_s}",
|
||||||
|
"topics" => topics_data
|
||||||
|
}
|
||||||
|
end
|
||||||
|
{
|
||||||
|
"categories" => data,
|
||||||
|
"extras" => {}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def criteria_list
|
||||||
|
params = OrbitHelper.params
|
||||||
|
criterias = PaperCriteria.all.desc(:start_date).limit(OrbitHelper.widget_data_count)
|
||||||
|
data = criterias.collect do |criteria|
|
||||||
|
{
|
||||||
|
"title" => criteria.title,
|
||||||
|
"description" => criteria.description,
|
||||||
|
"link_to_show" => OrbitHelper.url_to_show(criteria.to_param) + "?method=topics"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
{
|
||||||
|
"criterias" => data,
|
||||||
|
"extras" => {
|
||||||
|
"th_title" => t('e_paper.title'),
|
||||||
|
"th_description" => t('e_paper.description'),
|
||||||
|
"read_more" => OrbitHelper.widget_more_url + "?method=papers"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def category_wise_articles
|
||||||
|
topics = EPaperTopic.filter_by_widget_categories.desc(:period)
|
||||||
|
data = topics.collect do |topic|
|
||||||
|
{
|
||||||
|
"title" => topic.title,
|
||||||
|
"link_to_show" => OrbitHelper.url_to_show(topic.to_param),
|
||||||
|
"description" => topic.description,
|
||||||
|
"img_url" => topic.image.url,
|
||||||
|
"img_url_thumb" => topic.image.thumb.url,
|
||||||
|
"category" => topic.category.title
|
||||||
|
}
|
||||||
|
end
|
||||||
|
{
|
||||||
|
"topics" => data,
|
||||||
|
"extras" => {
|
||||||
|
"more_url" => OrbitHelper.widget_more_url
|
||||||
|
},
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def latest_criteria
|
||||||
|
criteria = PaperCriteria.last
|
||||||
|
papers = criteria.epaper_topics.group_by(&:category)
|
||||||
|
data = []
|
||||||
|
papers.each do |category, topics|
|
||||||
|
topics_data = topics.collect do |topic|
|
||||||
|
{
|
||||||
|
"title" => topic.title,
|
||||||
|
"link_to_show" => OrbitHelper.url_to_show(topic.to_param),
|
||||||
|
"description" => topic.description,
|
||||||
|
"img_url" => topic.image.url,
|
||||||
|
"img_url_thumb" => topic.image.thumb.url,
|
||||||
|
"category" => category.title
|
||||||
|
}
|
||||||
|
end
|
||||||
|
data << {
|
||||||
|
"category_title" => category.title,
|
||||||
|
"topics" => topics_data
|
||||||
|
}
|
||||||
|
end
|
||||||
|
{
|
||||||
|
"categories" => data,
|
||||||
|
"extras" => {
|
||||||
|
"read_more" => OrbitHelper.widget_more_url + "?method=topics"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def latest_slider
|
||||||
|
criteria = PaperCriteria.last
|
||||||
|
papers = criteria.epaper_topics.group_by(&:category)
|
||||||
|
data = []
|
||||||
|
papers.each do |category, topics|
|
||||||
|
topics_data = topics.collect do |topic|
|
||||||
|
{
|
||||||
|
"title" => topic.title,
|
||||||
|
"link_to_show" => OrbitHelper.url_to_show(topic.to_param),
|
||||||
|
"description" => topic.description,
|
||||||
|
"img_url" => topic.image.url,
|
||||||
|
"img_url_thumb" => topic.image.thumb.url,
|
||||||
|
"category" => category.title
|
||||||
|
}
|
||||||
|
end
|
||||||
|
data << {
|
||||||
|
"category_title" => category.title,
|
||||||
|
"topics" => topics_data
|
||||||
|
}
|
||||||
|
end
|
||||||
|
{
|
||||||
|
"categories" => data,
|
||||||
|
"extras" => {
|
||||||
|
"read_more" => OrbitHelper.widget_more_url + "?method=topics"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def subscribe
|
||||||
|
{}
|
||||||
|
end
|
||||||
|
|
||||||
|
def subscribeuser
|
||||||
|
subscriber = EPaperSubscriber.where(:email => params[:email])
|
||||||
|
if subscriber.count == 0
|
||||||
|
subscriber = EPaperSubscriber.new
|
||||||
|
subscriber.email = params[:email]
|
||||||
|
subscriber.subscribed = true
|
||||||
|
subscriber.language = params[:language]
|
||||||
|
subscriber.save
|
||||||
|
data = {"success" => true, "msg" => "Successfully Subscribed!!!"}
|
||||||
|
elsif subscriber.first.subscribed
|
||||||
|
data = {"success" => false, "msg" => "Already Subscribed!!!"}
|
||||||
|
elsif !subscriber.first.subscribed
|
||||||
|
su = subscriber.first
|
||||||
|
su.subscribed = true
|
||||||
|
su.save
|
||||||
|
data = {"success" => true, "msg" => "Successfully Subscribed!!!"}
|
||||||
|
end
|
||||||
|
render :json => data.to_json
|
||||||
|
end
|
||||||
|
|
||||||
|
def unsubscribeuser
|
||||||
|
subscriber = EPaperSubscriber.where(:email => params[:email]).first rescue nil
|
||||||
|
if !subscriber.nil?
|
||||||
|
subscriber.subscribed = false
|
||||||
|
subscriber.save
|
||||||
|
data = {"success" => true, "msg" => "Successfully Unsubscribed!!!"}
|
||||||
|
end
|
||||||
|
render :json => data.to_json
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
module EPaper
|
||||||
|
module ApplicationHelper
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,11 @@
|
||||||
|
class EPaperSubscriber
|
||||||
|
|
||||||
|
include Mongoid::Document
|
||||||
|
include Mongoid::Timestamps
|
||||||
|
|
||||||
|
field :email
|
||||||
|
field :subscribed, type: Boolean, :default => true
|
||||||
|
field :language
|
||||||
|
field :last_paper_sent
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,29 @@
|
||||||
|
class EPaperTopic
|
||||||
|
|
||||||
|
include Mongoid::Document
|
||||||
|
include Mongoid::Timestamps
|
||||||
|
include OrbitModel::Status
|
||||||
|
include OrbitCategory::Categorizable
|
||||||
|
include OrbitTag::Taggable
|
||||||
|
include Slug
|
||||||
|
|
||||||
|
field :title,as: :slug_title, localize: true
|
||||||
|
field :period, type: DateTime
|
||||||
|
field :description, localize: true
|
||||||
|
field :content, localize: true
|
||||||
|
field :mailed, type: Boolean, default: false
|
||||||
|
field :ready_to_send, type: Boolean, default: false
|
||||||
|
field :article_authors, type: Array, default: []
|
||||||
|
|
||||||
|
mount_uploader :image, ImageUploader
|
||||||
|
|
||||||
|
scope :can_display, ->{where(:is_hidden=>false,:title.ne => "").order_by([:period, :desc])}
|
||||||
|
|
||||||
|
def article_author_profiles
|
||||||
|
MemberProfile.find(self.article_authors)
|
||||||
|
end
|
||||||
|
|
||||||
|
def criteria_title
|
||||||
|
PaperCriteria.where(:start_date.lte => self.period, :end_date.gte => self.period).first.title rescue ""
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,22 @@
|
||||||
|
class PaperCriteria
|
||||||
|
include Mongoid::Document
|
||||||
|
include Mongoid::Timestamps
|
||||||
|
include Slug
|
||||||
|
|
||||||
|
field :title,as: :slug_title, localize: true
|
||||||
|
field :description, localize: true
|
||||||
|
field :start_date, type: DateTime
|
||||||
|
field :end_date, type: DateTime
|
||||||
|
field :sending_time, type: DateTime
|
||||||
|
field :sending_title, localize: true
|
||||||
|
field :sending_notes
|
||||||
|
field :language_to_send, type: Array, :default => []
|
||||||
|
field :receivers, type: Array, :default => []
|
||||||
|
field :other_emails
|
||||||
|
|
||||||
|
|
||||||
|
def epaper_topics
|
||||||
|
EPaperTopic.where(:period.gte => self.start_date, :period.lte => self.end_date).can_display
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,145 @@
|
||||||
|
<% 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/file-type" %>
|
||||||
|
<%= javascript_include_tag "lib/module-area" %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<div class="input-area">
|
||||||
|
|
||||||
|
<!-- Module Tabs -->
|
||||||
|
<div class="nav-name"><strong><%= t(:module) %></strong></div>
|
||||||
|
<ul class="nav nav-pills module-nav">
|
||||||
|
<li class="active"><a href="#basic" data-toggle="tab"><%= t(:basic) %></a></li>
|
||||||
|
<li><a href="#setting" data-toggle="tab"><%= t("e_paper.email_setting") %></a></li>
|
||||||
|
<li><a href="#record" data-toggle="tab"><%= t("e_paper.email_record") %></a></li>
|
||||||
|
<!-- <li><a href="#imageupload" data-toggle="tab"><%= t(:image) %></a></li> -->
|
||||||
|
</ul>
|
||||||
|
<div class="tab-content module-area">
|
||||||
|
|
||||||
|
<!-- Basic Module -->
|
||||||
|
<div class="tab-pane fade in active" id="basic">
|
||||||
|
|
||||||
|
<!-- Date Time Picker -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t(:start_date) %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.datetime_picker :start_date, :no_label => true, :new_record => @paper_criteria.new_record?, :data=>{"picker-type" => "range", "range" => "start"} %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t(:end_date) %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.datetime_picker :end_date, :no_label => true, :new_record => @paper_criteria.new_record?, :data=>{"picker-type" => "range", "range" => "end"} %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane fade" id="setting">
|
||||||
|
|
||||||
|
<!-- Date Time Picker -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("e_paper.sending_time") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.datetime_picker :sending_time, :no_label => true, :new_record => @paper_criteria.new_record? %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("e_paper.sending_title") + " (" + t(locale.to_s) + ")" %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.fields_for :sending_title_translations do |f| %>
|
||||||
|
<%= f.text_field locale, value: (@paper_criteria.sending_title_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("e_paper.sending_notes") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_area :sending_notes %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("e_paper.languages") %></label>
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<div class="controls">
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" <%= @paper_criteria.language_to_send.include?(locale.to_s) ? "checked=checked" : "" %> name="paper_criteria[language_to_send][]" value="<%= locale.to_s %>"> <%= t(locale.to_s) %>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("e_paper.receivers") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" <%= @paper_criteria.receivers.include?("subscriber") ? "checked=checked" : "" %> name="paper_criteria[receivers][]" value="subscriber"> <%= t("e_paper.subscriber") %>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="controls">
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" <%= @paper_criteria.receivers.include?("website_member") ? "checked=checked" : "" %> name="paper_criteria[receivers][]" value="member"> <%= t("e_paper.website_member") %>
|
||||||
|
<label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("e_paper.other_emails") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_area :other_emails %>
|
||||||
|
<div class="hint">Separated by , (comma)</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane fade" id="record">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="nav-name"><strong><%= t(:language) %></strong></div>
|
||||||
|
<ul class="nav nav-pills language-nav">
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<li class="<%= 'active' if i == 0 %>">
|
||||||
|
<a data-toggle="tab" href=".<%= locale %>"><%= t(locale) %></a>
|
||||||
|
</li>
|
||||||
|
<% end %>
|
||||||
|
</ul>
|
||||||
|
<!-- Language -->
|
||||||
|
<div class="tab-content language-area">
|
||||||
|
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
|
||||||
|
<div class="<%= locale %> tab-pane fade <%= ( i == 0 ) ? "in active" : '' %>">
|
||||||
|
|
||||||
|
<!-- Title-->
|
||||||
|
<div class="control-group input-title">
|
||||||
|
<label class="control-label muted"><%= t(:title) %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.fields_for :title_translations do |f| %>
|
||||||
|
<%= f.text_field locale, class: "input-block-level", placeholder: t(:title), value: (@paper_criteria.title_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- Sub Title -->
|
||||||
|
<div class="control-group input-subtitle">
|
||||||
|
<label class="control-label muted"><%= t(:subtitle) %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<div class="textarea">
|
||||||
|
<%= f.fields_for :description_translations do |f| %>
|
||||||
|
<%= f.text_area locale, rows: 2, class: "input-block-level", value: (@paper_criteria.description_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<!-- Form Actions -->
|
||||||
|
<div class="form-actions">
|
||||||
|
<%= f.submit t('submit'), class: 'btn btn-primary' %>
|
||||||
|
</div>
|
|
@ -0,0 +1,51 @@
|
||||||
|
<table class="table main-list">
|
||||||
|
<thead>
|
||||||
|
<tr class="sort-header">
|
||||||
|
<% @table_fields.each do |f| %>
|
||||||
|
<%= thead(f) %>
|
||||||
|
<% end %>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<% @criterias.each do |criteria| %>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<%= criteria.title %>
|
||||||
|
<div class="quick-edit">
|
||||||
|
<ul class="nav nav-pills">
|
||||||
|
<li><a href="<%= edit_admin_e_paper_criteria_path(criteria.id) %>"><%= t(:edit) %></a></li>
|
||||||
|
<li><a class="test-email" href="<%= send_test_email_admin_e_paper_criteria_path(criteria.id) %>"><%= t('e_paper.test_mail') %></a></li>
|
||||||
|
<li><a class="delete text-error" href="<%= admin_e_paper_criteria_path(criteria.id) %>" data-method="delete" data-confirm="Are you sure?"><%= t(:delete_) %></a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<td><%= criteria.start_date.strftime("%Y/%m/%d") rescue "N/A" %> ~ <%= criteria.end_date.strftime("%Y/%m/%d") rescue "N/A" %></td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<div class="bottomnav clearfix" style="left: 81px;">
|
||||||
|
<%= content_tag :div, paginate(@criterias), class: "pagination pagination-centered" %>
|
||||||
|
<div class="action pull-right">
|
||||||
|
<a class="btn btn-primary" href="<%= new_admin_e_paper_criteria_path %>">
|
||||||
|
<%= t("e_paper.new_criteria") %>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(".test-email").on("click",function(){
|
||||||
|
var el = $(this),
|
||||||
|
email = prompt("Please enter an email address to send test email.", "<%= current_user.member_profile.email rescue "" %>");
|
||||||
|
if(email != null){
|
||||||
|
$.ajax({
|
||||||
|
url : el.attr("href"),
|
||||||
|
data : {"email" : email},
|
||||||
|
dataType : "json",
|
||||||
|
type : "get"
|
||||||
|
}).done(function(){
|
||||||
|
alert("Email sent.")
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
})
|
||||||
|
</script>
|
|
@ -0,0 +1,7 @@
|
||||||
|
<div id="new">
|
||||||
|
<%= form_for @paper_criteria, :url => {:action=>"update"}, :html => {:class => 'form-horizontal main-forms'} do |f| %>
|
||||||
|
<fieldset>
|
||||||
|
<%= render :partial => 'form', :locals => {:f => f} %>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
|
@ -0,0 +1,172 @@
|
||||||
|
<% paper = @data["paper"] %>
|
||||||
|
<% page = @data["page"] %>
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title><%= paper.title %></title>
|
||||||
|
<style type="text/css">
|
||||||
|
.epaper-show .epaper-show-title {
|
||||||
|
border-bottom: 2px solid #ddd;
|
||||||
|
padding: 0 0 10px;
|
||||||
|
margin: 10px 0 20px;
|
||||||
|
color: #881f05;
|
||||||
|
}
|
||||||
|
.epaper-show .ep-info {
|
||||||
|
background: #fff;
|
||||||
|
border-radius: 3px;
|
||||||
|
padding: 10px;
|
||||||
|
margin: 0 0 15px;
|
||||||
|
}
|
||||||
|
.epaper-show .ep-info-title {
|
||||||
|
border-bottom: 1px solid #eee;
|
||||||
|
padding: 0 0 5px;
|
||||||
|
margin: 0 0 8px;
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
.epaper-show .ep-info-date {
|
||||||
|
float: left;
|
||||||
|
width: 50%;
|
||||||
|
margin: 0 0 5px;
|
||||||
|
color: #888;
|
||||||
|
}
|
||||||
|
.epaper-show .ep-info-period {
|
||||||
|
float: right;
|
||||||
|
width: 50%;
|
||||||
|
margin: 0 0 5px;
|
||||||
|
text-align: right;
|
||||||
|
padding: 0 10px 0 0;
|
||||||
|
color: #888;
|
||||||
|
}
|
||||||
|
.epaper-show .ep-info-description {
|
||||||
|
clear: both;
|
||||||
|
padding: 10px 0 0;
|
||||||
|
overflow: hidden;
|
||||||
|
border-top: 1px solid #eee;
|
||||||
|
}
|
||||||
|
.epaper-show .ep-info-description span {
|
||||||
|
float: right;
|
||||||
|
width: calc(100% - 90px);
|
||||||
|
line-height: 1.5;
|
||||||
|
}
|
||||||
|
.epaper-show .ep-content-item {
|
||||||
|
float: left;
|
||||||
|
width: calc(50% - 20px);
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
vertical-align: top;
|
||||||
|
min-height: 200px;
|
||||||
|
padding: 20px;
|
||||||
|
margin: 10px;
|
||||||
|
}
|
||||||
|
.epaper-show .ep-content-title {
|
||||||
|
color: #881f05;
|
||||||
|
font-size: 20px;
|
||||||
|
border-left: 4px solid #881f05;
|
||||||
|
display: block;
|
||||||
|
padding: 0 0 0 10px;
|
||||||
|
margin: 0 0 10px;
|
||||||
|
}
|
||||||
|
.epaper-show p.ep-content-text {
|
||||||
|
color: #666;
|
||||||
|
font-size: 15px;
|
||||||
|
}
|
||||||
|
.epaper-show a.ep-content-more {
|
||||||
|
background: #881f05;
|
||||||
|
color: #fff;
|
||||||
|
padding: 2px 10px;
|
||||||
|
border-radius: 5px;
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ep-topic-show .ep-topic-title {
|
||||||
|
margin: 10px 0;
|
||||||
|
color: #881f05;
|
||||||
|
}
|
||||||
|
.ep-topic-show .ep-topic-date {
|
||||||
|
background: #fff;
|
||||||
|
padding: 10px;
|
||||||
|
border-radius: 3px;
|
||||||
|
margin: 0 0 10px;
|
||||||
|
}
|
||||||
|
.ep-topic-show .ep-topic-content {
|
||||||
|
font-size: 15px;
|
||||||
|
line-height: 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
.epaper-form {
|
||||||
|
background: #fff;
|
||||||
|
padding: 20px;
|
||||||
|
width: 100%;
|
||||||
|
max-width: 300px;
|
||||||
|
margin: auto;
|
||||||
|
border-radius: 5px;
|
||||||
|
box-shadow: 0 0 30px rgba(0, 0, 0, 0.05);
|
||||||
|
}
|
||||||
|
.epaper-form input.input-mail {
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
margin: 0 0 20px;
|
||||||
|
padding: 5px 10px;
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
border-radius: 5px;
|
||||||
|
color: #333;
|
||||||
|
}
|
||||||
|
.epaper-form .btn-primary {
|
||||||
|
width: 50%;
|
||||||
|
float: left;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
.epaper-form .btn-white {
|
||||||
|
background: none;
|
||||||
|
width: 50%;
|
||||||
|
outline: none;
|
||||||
|
float: right;
|
||||||
|
color: #888;
|
||||||
|
}
|
||||||
|
.epaper-form .btn-white:active {
|
||||||
|
outline: none;
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
.epaper-form .btn-white:hover {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
.epaper-form .ep-form-title {
|
||||||
|
font-size: 20px;
|
||||||
|
margin: 0 0 15px;
|
||||||
|
}
|
||||||
|
.epaper-form h3.ep-form-title .en {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.epaper-form form {
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.school-heading{
|
||||||
|
padding: 20px;
|
||||||
|
text-align: center;
|
||||||
|
border-bottom: 1px solid #c8c8c8;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="epaper-show">
|
||||||
|
<h3 class="epaper-show-title"><%= t('e_paper.intro') %></h3>
|
||||||
|
<div class="ep-info">
|
||||||
|
<div class="ep-info-title"><%= t('e_paper.title') %>:<span><%= paper.title %></span></div>
|
||||||
|
<div class="ep-info-date"><%= t('e_paper.date') %>:<span><%= paper.created_at.strftime("%Y-%m-%d") %></span></div>
|
||||||
|
<div class="ep-info-period"><%= t('e_paper.period') %>:<span><%= paper.period.strftime("%Y-%m-%d") %></span></div>
|
||||||
|
<div class="ep-info-description"><%= t('e_paper.description') %><span><%= paper.description %></span></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="ep-content">
|
||||||
|
<% paper.epaper_topics.desc(:created_at).each do |topic| %>
|
||||||
|
<div class="ep-content-item">
|
||||||
|
<a class="ep-content-title" href="<%= page + "/" + paper.to_param + "?method=showtopic" %>" target="_blank"><%= topic.episode %></a>
|
||||||
|
<% t = strip_tags(topic.content) %>
|
||||||
|
<p class="ep-content-text"><%= t[0..100] %></p>
|
||||||
|
<a class="ep-content-more" href="<%= page + "/" + paper.to_param + "?method=showtopic" %>" target="_blank">more</a>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,4 @@
|
||||||
|
<%= render_filter @filter_fields, "index_table" %>
|
||||||
|
<div id="index_table">
|
||||||
|
<%= render 'index'%>
|
||||||
|
</div>
|
|
@ -0,0 +1,7 @@
|
||||||
|
<div id="new">
|
||||||
|
<%= form_for @paper_criteria, :url => {:action=>"create"}, :html => {:class => 'form-horizontal main-forms'} do |f| %>
|
||||||
|
<fieldset>
|
||||||
|
<%= render :partial => 'form', :locals => {:f => f} %>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
|
@ -0,0 +1,32 @@
|
||||||
|
<table class="table main-list">
|
||||||
|
<thead>
|
||||||
|
<tr class="sort-header">
|
||||||
|
<% @table_fields.each do |f| %>
|
||||||
|
<%= thead(f) %>
|
||||||
|
<% end %>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<% @subscribers.each do |subscriber| %>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<%= subscriber.email rescue "" %>
|
||||||
|
<div class="quick-edit">
|
||||||
|
<ul class="nav nav-pills">
|
||||||
|
<li><a class="delete text-error" href="<%= admin_e_paper_subscriber_path(subscriber.id) %>" data-method="delete" data-confirm="Are you sure?"><%= t(:delete_) %></a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<%= subscriber.subscribed ? "Subscribed" : "Unsubscribed" %>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<%= t(subscriber.language) %>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<div class="bottomnav clearfix" style="left: 81px;">
|
||||||
|
<%= content_tag :div, paginate(@subscribers), class: "pagination pagination-centered" %>
|
||||||
|
</div>
|
|
@ -0,0 +1,4 @@
|
||||||
|
<%= render_filter @filter_fields, "index_table" %>
|
||||||
|
<div id="index_table">
|
||||||
|
<%= render 'index'%>
|
||||||
|
</div>
|
|
@ -0,0 +1,149 @@
|
||||||
|
<% 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" %>
|
||||||
|
<% end %>
|
||||||
|
<%#= f.error_messages %>
|
||||||
|
<fieldset>
|
||||||
|
<!-- Input Area -->
|
||||||
|
<div class="input-area">
|
||||||
|
|
||||||
|
<!-- Module Tabs -->
|
||||||
|
<div class="nav-name"><strong><%= t(:module) %></strong></div>
|
||||||
|
<ul class="nav nav-pills module-nav">
|
||||||
|
<li class="active">
|
||||||
|
<a href="#basic" data-toggle="tab"><%= t(:basic) %></a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a href="#imageupload" data-toggle="tab"><%= t(:image) %></a>
|
||||||
|
</li>
|
||||||
|
<li><a href="#tag" data-toggle="tab"><%= t(:tags) %></a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<!-- Module -->
|
||||||
|
<div class="tab-content module-area">
|
||||||
|
|
||||||
|
<!-- Basic Module -->
|
||||||
|
<div class="tab-pane fade in active" id="basic">
|
||||||
|
|
||||||
|
<!-- Category -->
|
||||||
|
<div class="control-group">
|
||||||
|
<%= f.label :category ,t(:category), :class=>"control-label muted" %>
|
||||||
|
<div class="controls">
|
||||||
|
<%= select_category(f, @module_app) %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group input-period">
|
||||||
|
<%= f.label :period ,t('e_paper.period'), :class => "control-label muted" %>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.datetime_picker :period, :no_label => true, :new_record => @paper.new_record? %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group input-period">
|
||||||
|
<%= f.label :article_author ,t('e_paper.article_author'), :class => "control-label muted" %>
|
||||||
|
<div class="controls">
|
||||||
|
<div class="content-box">
|
||||||
|
<%= render partial: 'admin/member_selects/email_selection_box', locals: {field: 'e_paper_topic[article_authors][]', email_members: @paper.article_author_profiles} %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane fade" id="imageupload">
|
||||||
|
|
||||||
|
<!-- Images Upload -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t(:image) %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<div class="fileupload fileupload-new clearfix <%= 'fileupload-edit' if @paper.image.file %>" data-provides="fileupload">
|
||||||
|
<div class="fileupload-new thumbnail pull-left">
|
||||||
|
<% if @paper.image.file %>
|
||||||
|
<%= image_tag @paper.image %>
|
||||||
|
<% else %>
|
||||||
|
<img src="http://www.placehold.it/50x50/EFEFEF/AAAAAA" />
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<div class="fileupload-preview fileupload-exists thumbnail pull-left"></div>
|
||||||
|
<span class="btn btn-file">
|
||||||
|
<span class="fileupload-new"><%= t(:select_image) %></span>
|
||||||
|
<span class="fileupload-exists"><%= t(:change) %></span>
|
||||||
|
<%= f.file_field :image %>
|
||||||
|
</span>
|
||||||
|
<a href="#" class="btn fileupload-exists" data-dismiss="fileupload"><%= t(:cancel) %></a>
|
||||||
|
<div class="controls" data-toggle="buttons-checkbox">
|
||||||
|
<label class="checkbox inline btn btn-danger fileupload-remove">
|
||||||
|
<%= f.check_box :remove_image %><%= t(:remove) %>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- Tag Module -->
|
||||||
|
<div class="tab-pane fade" id="tag">
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t(:tags) %></label>
|
||||||
|
<%= select_tags(f, @module_app) %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<!-- Language Tabs -->
|
||||||
|
<div class="nav-name"><strong>Language</strong></div>
|
||||||
|
<ul class="nav nav-pills language-nav">
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<li <%= ( i == 0 ) ? "class=active" : '' %>><a data-toggle="tab" href=".<%= locale %>"><%= t(locale.to_s) %></a></li>
|
||||||
|
<% end %>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<!-- Language -->
|
||||||
|
<div class="tab-content language-area">
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
|
||||||
|
<div class="control-group input-title">
|
||||||
|
<%= f.label :title , t('e_paper.title'), :class=>"control-label muted" %>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.fields_for :title_translations do |f| %>
|
||||||
|
<%= f.text_field locale, :class=>'input-block-level', :value => (@paper.title_translations[locale.to_s] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="control-group input-description">
|
||||||
|
<%= f.label :description ,t('e_paper.description'), :class => "control-label muted" %>
|
||||||
|
<%= f.fields_for :description_translations do |f| %>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_area locale, :class=>'input-block-level', :value => (@paper.description_translations[locale] rescue nil) %>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<div class="control-group input-content">
|
||||||
|
<label class="control-label muted"><%= t('e_paper.content') %> (<%= t(locale.to_s) %>)</label>
|
||||||
|
<div class="controls">
|
||||||
|
<div class="textarea">
|
||||||
|
<%= f.fields_for :content_translations do |f| %>
|
||||||
|
<%= f.cktext_area locale, rows: 5, class: "input-block-level", :value => (@paper.content_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Form Actions -->
|
||||||
|
<div class="form-actions">
|
||||||
|
<input type="hidden" name="referer_url" value="<%= request.referer %>">
|
||||||
|
<%= f.submit t('submit'), class: 'btn btn-primary' %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</fieldset>
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
<table class="table main-list">
|
||||||
|
<thead>
|
||||||
|
<tr class="sort-header">
|
||||||
|
<% @table_fields.each do |f| %>
|
||||||
|
<%= thead(f) %>
|
||||||
|
<% end %>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<% @papers.each do |paper| %>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<%= paper.category.title rescue "" %>
|
||||||
|
<% if (paper.category.disable rescue false) %>
|
||||||
|
<span class="label"><%= t(:disable) %></span>
|
||||||
|
<% end %>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<%= paper.title %>
|
||||||
|
<div class="quick-edit">
|
||||||
|
<ul class="nav nav-pills">
|
||||||
|
<% if can_edit_or_delete?(paper) %>
|
||||||
|
<li><a href="<%= edit_admin_e_paper_path(paper.id) %>"><%= t(:edit) %></a></li>
|
||||||
|
<li><a class="delete text-error" href="<%= admin_e_paper_path(paper.id) %>" data-method="delete" data-confirm="Are you sure?"><%= t(:delete_) %></a></li>
|
||||||
|
<% end %>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<%= paper.period.strftime("%Y-%m-%d") rescue "" %>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<% paper.tags.each do |tag| %>
|
||||||
|
<span class="label label-warning"><%= tag.name %></span>
|
||||||
|
<% end %>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<div class="bottomnav clearfix" style="left: 81px;">
|
||||||
|
<%= content_tag :div, paginate(@papers), class: "pagination pagination-centered" %>
|
||||||
|
</div>
|
|
@ -0,0 +1,31 @@
|
||||||
|
<script>
|
||||||
|
if(document.querySelectorAll("#orbit-bar").length==0) location.reload();
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<table class="table main-list">
|
||||||
|
<thead>
|
||||||
|
<tr class="sort-header">
|
||||||
|
<% @table_fields.each do |f| %>
|
||||||
|
<%= thead(f) %>
|
||||||
|
<% end %>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<% @subscribers.each do |sub| %>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<%= sub.email %>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<a data-method="delete" data-confirm="Are you sure?" href="<%= delete_subscriber_admin_e_paper_path(sub.id, :page => params[:page]) %>" class="btn btn-danger"><%= t(:delete_) %></a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<%=
|
||||||
|
content_tag :div, class: "bottomnav clearfix" do
|
||||||
|
content_tag :div, paginate(@subscribers), class: "pagination pagination-centered"
|
||||||
|
end
|
||||||
|
%>
|
|
@ -0,0 +1,7 @@
|
||||||
|
<div id="new">
|
||||||
|
<%= form_for @paper, :url => {:action=>"update"}, :html => {:class => 'form-horizontal main-forms'} do |f| %>
|
||||||
|
<fieldset>
|
||||||
|
<%= render :partial => 'form', :locals => {:f => f} %>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
|
@ -0,0 +1,4 @@
|
||||||
|
<%= render_filter @filter_fields, "index_table" %>
|
||||||
|
<div id="index_table">
|
||||||
|
<%= render 'index'%>
|
||||||
|
</div>
|
|
@ -0,0 +1 @@
|
||||||
|
this is instructions page
|
|
@ -0,0 +1,7 @@
|
||||||
|
<div id="new">
|
||||||
|
<%= form_for @paper, :url => {:action=>"create"}, :html => {:class => 'form-horizontal main-forms'} do |f| %>
|
||||||
|
<fieldset>
|
||||||
|
<%= render :partial => 'form', :locals => {:f => f} %>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
|
@ -0,0 +1,4 @@
|
||||||
|
<%= render_filter @filter_fields, "index_table" %>
|
||||||
|
<div id="index_table">
|
||||||
|
<%= render 'subscriber_index'%>
|
||||||
|
</div>
|
|
@ -0,0 +1 @@
|
||||||
|
<%= render_view %>
|
|
@ -0,0 +1 @@
|
||||||
|
<%= render_view %>
|
|
@ -0,0 +1 @@
|
||||||
|
<%= render_view %>
|
|
@ -0,0 +1 @@
|
||||||
|
<%= render_view %>
|
|
@ -0,0 +1,12 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
# This command will automatically be run when you run "rails" with Rails 4 gems installed from the root of your application.
|
||||||
|
|
||||||
|
ENGINE_ROOT = File.expand_path('../..', __FILE__)
|
||||||
|
ENGINE_PATH = File.expand_path('../../lib/e_paper/engine', __FILE__)
|
||||||
|
|
||||||
|
# Set up gems listed in the Gemfile.
|
||||||
|
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
|
||||||
|
require 'bundler/setup' if File.exist?(ENV['BUNDLE_GEMFILE'])
|
||||||
|
|
||||||
|
require 'rails/all'
|
||||||
|
require 'rails/engine/commands'
|
|
@ -0,0 +1,36 @@
|
||||||
|
en:
|
||||||
|
module_name: "ePaper"
|
||||||
|
e_paper:
|
||||||
|
e_paper: "ePaper"
|
||||||
|
all_articles: All Articles
|
||||||
|
title: Title
|
||||||
|
description: Description
|
||||||
|
new_paper: New Paper
|
||||||
|
period: Publish Date
|
||||||
|
add: New Topic
|
||||||
|
topic_name: "Topic"
|
||||||
|
content: "Content"
|
||||||
|
publish_date: "Publish_date"
|
||||||
|
history: "History Episode"
|
||||||
|
intro: "Intro"
|
||||||
|
date: "Date"
|
||||||
|
send: "Mail ePaper"
|
||||||
|
sending: "Sending in process"
|
||||||
|
published: "Published"
|
||||||
|
subscribers: Subscribers
|
||||||
|
test_mail: Send Test Email
|
||||||
|
paper_criteria: ePaper Issue
|
||||||
|
criteria_title: Issue Title
|
||||||
|
date_span: Article Date Range
|
||||||
|
new_criteria: New Issue
|
||||||
|
article_author: Article Author
|
||||||
|
instructions: Instructions
|
||||||
|
email_setting: Email Settings
|
||||||
|
email_record: Email Records
|
||||||
|
sending_time: Sending Time
|
||||||
|
sending_title: Sending Title
|
||||||
|
sending_notes: Sending Notes
|
||||||
|
subscriber: Subscribers
|
||||||
|
website_member: Website Members
|
||||||
|
other_email: Other Email
|
||||||
|
receivers: Receivers
|
|
@ -0,0 +1,37 @@
|
||||||
|
zh_tw:
|
||||||
|
module_name: 電子報
|
||||||
|
e_paper:
|
||||||
|
e_paper: "電子報"
|
||||||
|
title: "文章標題"
|
||||||
|
publish_date: "發行日期"
|
||||||
|
all_articles: 文章列表
|
||||||
|
description: "報別簡介"
|
||||||
|
new_paper: "新增文章"
|
||||||
|
period: "發行週期"
|
||||||
|
add: "新增主題"
|
||||||
|
topic_name: "主題名稱"
|
||||||
|
content: "內容"
|
||||||
|
publish_date: "發行日期"
|
||||||
|
history: "歷史主題"
|
||||||
|
intro: "報別簡介"
|
||||||
|
date: "日期"
|
||||||
|
send: "發送電子報"
|
||||||
|
sending: "發送處理中"
|
||||||
|
published: "已發送"
|
||||||
|
subscribers: 訂閱者
|
||||||
|
test_mail: 發送測試郵件
|
||||||
|
paper_criteria: 發行電子報
|
||||||
|
criteria_title: 期數標題
|
||||||
|
date_span: 文章日期範圍
|
||||||
|
new_criteria: 新增電子報
|
||||||
|
article_author: 作者
|
||||||
|
instructions: 使用說明
|
||||||
|
email_setting: 寄送設定
|
||||||
|
email_record: 寄送紀錄
|
||||||
|
sending_time: 寄送時間
|
||||||
|
sending_title: 寄送標題
|
||||||
|
sending_notes: 寄送備註
|
||||||
|
subscriber: 訂閱者
|
||||||
|
website_member: 網站會員
|
||||||
|
other_email: 其他Email
|
||||||
|
receivers: 收件人
|
|
@ -0,0 +1,29 @@
|
||||||
|
Rails.application.routes.draw do
|
||||||
|
|
||||||
|
locales = Site.first.in_use_locales rescue I18n.available_locales
|
||||||
|
|
||||||
|
scope "(:locale)", locale: Regexp.new(locales.join("|")) do
|
||||||
|
namespace :admin do
|
||||||
|
resources :e_paper_criterias do
|
||||||
|
member do
|
||||||
|
get "send_test_email"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
resources :e_paper_subscribers
|
||||||
|
resources :e_papers do
|
||||||
|
member do
|
||||||
|
get :send_email_to_subscribers
|
||||||
|
delete "delete_subscriber"
|
||||||
|
get "send_test_email"
|
||||||
|
end
|
||||||
|
collection do
|
||||||
|
get "instructions"
|
||||||
|
get "subscribers"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
get "/xhr/epaper/subscribeuser", to: "e_papers#subscribeuser"
|
||||||
|
get "/xhr/epaper/unsubscribeuser", to: "e_papers#unsubscribeuser"
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,20 @@
|
||||||
|
$:.push File.expand_path("../lib", __FILE__)
|
||||||
|
|
||||||
|
# Maintain your gem's version:
|
||||||
|
require "e_paper/version"
|
||||||
|
|
||||||
|
# Describe your gem and declare its dependencies:
|
||||||
|
Gem::Specification.new do |s|
|
||||||
|
s.name = "e_paper"
|
||||||
|
s.version = EPaper::VERSION
|
||||||
|
s.authors = ["Harry Bomrah"]
|
||||||
|
s.email = ["harry@rulingcom.com"]
|
||||||
|
s.homepage = "http://www.rulingdigital.com"
|
||||||
|
s.summary = "Summary of EPaper."
|
||||||
|
s.description = "Description of EPaper."
|
||||||
|
s.license = "MIT"
|
||||||
|
|
||||||
|
s.files = Dir["{app,config,db,lib}/**/*", "MIT-LICENSE", "Rakefile", "README.rdoc"]
|
||||||
|
s.test_files = Dir["test/**/*"]
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
require "e_paper/engine"
|
||||||
|
|
||||||
|
module EPaper
|
||||||
|
end
|
|
@ -0,0 +1,64 @@
|
||||||
|
module EPaper
|
||||||
|
class Engine < ::Rails::Engine
|
||||||
|
initializer "e_paper" do
|
||||||
|
OrbitApp.registration "EPaper", :type => "ModuleApp" do
|
||||||
|
module_label "e_paper.e_paper"
|
||||||
|
base_url File.expand_path File.dirname(__FILE__)
|
||||||
|
widget_methods ["criteria_list","category_wise_articles","latest_criteria", "latest_slider", "subscribe"]
|
||||||
|
widget_settings [{"data_count"=>30}]
|
||||||
|
taggable "EPaperCriteria"
|
||||||
|
categorizable
|
||||||
|
authorizable
|
||||||
|
frontend_enabled
|
||||||
|
data_count 1..30
|
||||||
|
|
||||||
|
side_bar do
|
||||||
|
head_label_i18n 'e_paper.e_paper', icon_class: "icons-book"
|
||||||
|
available_for "users"
|
||||||
|
active_for_controllers (['admin/e_papers', 'admin/e_paper_criterias'])
|
||||||
|
head_link_path "admin_e_papers_path"
|
||||||
|
|
||||||
|
context_link 'e_paper.all_articles',
|
||||||
|
:link_path=>"admin_e_papers_path" ,
|
||||||
|
:priority=>1,
|
||||||
|
:active_for_action=>{'admin/e_papers'=>'index'},
|
||||||
|
:available_for => 'users'
|
||||||
|
context_link 'new_',
|
||||||
|
:link_path=>"new_admin_e_paper_path" ,
|
||||||
|
:priority=>2,
|
||||||
|
:active_for_action=>{'admin/e_papers'=>'new'},
|
||||||
|
:available_for => 'sub_managers'
|
||||||
|
context_link 'categories',
|
||||||
|
:link_path=>"admin_module_app_categories_path" ,
|
||||||
|
:link_arg=>"{:module_app_id=>ModuleApp.find_by(:key=>'e_paper').id}",
|
||||||
|
:priority=>3,
|
||||||
|
:active_for_action=>{'admin/e_papers'=>'categories'},
|
||||||
|
:active_for_category => 'EPaper',
|
||||||
|
:available_for => 'managers'
|
||||||
|
context_link 'tags',
|
||||||
|
:link_path=>"admin_module_app_tags_path" ,
|
||||||
|
:link_arg=>"{:module_app_id=>ModuleApp.find_by(:key=>'e_paper').id}",
|
||||||
|
:priority=>4,
|
||||||
|
:active_for_action=>{'admin/e_papers'=>'tags'},
|
||||||
|
:active_for_tag => 'e_paper',
|
||||||
|
:available_for => 'managers'
|
||||||
|
context_link 'e_paper.paper_criteria',
|
||||||
|
:link_path=>"admin_e_paper_criterias_path" ,
|
||||||
|
:priority=>5,
|
||||||
|
:active_for_action=>{'admin/e_paper_criterias'=>'index'},
|
||||||
|
:available_for => 'managers'
|
||||||
|
context_link 'e_paper.subscribers',
|
||||||
|
:link_path=>"admin_e_paper_subscribers_path" ,
|
||||||
|
:priority=>6,
|
||||||
|
:active_for_action=>{'admin/e_paper_subscribers'=>'index'},
|
||||||
|
:available_for => 'managers'
|
||||||
|
context_link 'e_paper.instructions',
|
||||||
|
:link_path=>"instructions_admin_e_papers_path" ,
|
||||||
|
:priority=>7,
|
||||||
|
:active_for_action=>{'admin/e_paper'=>'instructions'},
|
||||||
|
:available_for => 'users'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,3 @@
|
||||||
|
module EPaper
|
||||||
|
VERSION = "0.0.1"
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
# desc "Explaining what the task does"
|
||||||
|
# task :e_paper do
|
||||||
|
# # Task goes here
|
||||||
|
# end
|
|
@ -0,0 +1,28 @@
|
||||||
|
== README
|
||||||
|
|
||||||
|
This README would normally document whatever steps are necessary to get the
|
||||||
|
application up and running.
|
||||||
|
|
||||||
|
Things you may want to cover:
|
||||||
|
|
||||||
|
* Ruby version
|
||||||
|
|
||||||
|
* System dependencies
|
||||||
|
|
||||||
|
* Configuration
|
||||||
|
|
||||||
|
* Database creation
|
||||||
|
|
||||||
|
* Database initialization
|
||||||
|
|
||||||
|
* How to run the test suite
|
||||||
|
|
||||||
|
* Services (job queues, cache servers, search engines, etc.)
|
||||||
|
|
||||||
|
* Deployment instructions
|
||||||
|
|
||||||
|
* ...
|
||||||
|
|
||||||
|
|
||||||
|
Please feel free to use a different markup language if you do not plan to run
|
||||||
|
<tt>rake doc:app</tt>.
|
|
@ -0,0 +1,6 @@
|
||||||
|
# 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__)
|
||||||
|
|
||||||
|
Rails.application.load_tasks
|
|
@ -0,0 +1,13 @@
|
||||||
|
// 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
|
||||||
|
// compiled file.
|
||||||
|
//
|
||||||
|
// Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
|
||||||
|
// about supported directives.
|
||||||
|
//
|
||||||
|
//= require_tree .
|
|
@ -0,0 +1,15 @@
|
||||||
|
/*
|
||||||
|
* 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 bottom of the
|
||||||
|
* compiled file so the styles you add here take precedence over styles defined in any styles
|
||||||
|
* defined in the other CSS/SCSS files in this directory. It is generally better to create a new
|
||||||
|
* file per style scope.
|
||||||
|
*
|
||||||
|
*= require_tree .
|
||||||
|
*= require_self
|
||||||
|
*/
|
|
@ -0,0 +1,5 @@
|
||||||
|
class ApplicationController < ActionController::Base
|
||||||
|
# Prevent CSRF attacks by raising an exception.
|
||||||
|
# For APIs, you may want to use :null_session instead.
|
||||||
|
protect_from_forgery with: :exception
|
||||||
|
end
|
|
@ -0,0 +1,2 @@
|
||||||
|
module ApplicationHelper
|
||||||
|
end
|
|
@ -0,0 +1,14 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Dummy</title>
|
||||||
|
<%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track' => true %>
|
||||||
|
<%= javascript_include_tag 'application', 'data-turbolinks-track' => true %>
|
||||||
|
<%= csrf_meta_tags %>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<%= yield %>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,3 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
|
||||||
|
load Gem.bin_path('bundler', 'bundle')
|
|
@ -0,0 +1,4 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
APP_PATH = File.expand_path('../../config/application', __FILE__)
|
||||||
|
require_relative '../config/boot'
|
||||||
|
require 'rails/commands'
|
|
@ -0,0 +1,4 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
require_relative '../config/boot'
|
||||||
|
require 'rake'
|
||||||
|
Rake.application.run
|
|
@ -0,0 +1,4 @@
|
||||||
|
# This file is used by Rack-based servers to start the application.
|
||||||
|
|
||||||
|
require ::File.expand_path('../config/environment', __FILE__)
|
||||||
|
run Rails.application
|
|
@ -0,0 +1,23 @@
|
||||||
|
require File.expand_path('../boot', __FILE__)
|
||||||
|
|
||||||
|
require 'rails/all'
|
||||||
|
|
||||||
|
Bundler.require(*Rails.groups)
|
||||||
|
require "e_paper"
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
# 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
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
# Set up gems listed in the Gemfile.
|
||||||
|
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../../../Gemfile', __FILE__)
|
||||||
|
|
||||||
|
require 'bundler/setup' if File.exist?(ENV['BUNDLE_GEMFILE'])
|
||||||
|
$LOAD_PATH.unshift File.expand_path('../../../../lib', __FILE__)
|
|
@ -0,0 +1,25 @@
|
||||||
|
# SQLite version 3.x
|
||||||
|
# gem install sqlite3
|
||||||
|
#
|
||||||
|
# Ensure the SQLite 3 gem is defined in your Gemfile
|
||||||
|
# gem 'sqlite3'
|
||||||
|
#
|
||||||
|
default: &default
|
||||||
|
adapter: sqlite3
|
||||||
|
pool: 5
|
||||||
|
timeout: 5000
|
||||||
|
|
||||||
|
development:
|
||||||
|
<<: *default
|
||||||
|
database: db/development.sqlite3
|
||||||
|
|
||||||
|
# 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:
|
||||||
|
<<: *default
|
||||||
|
database: db/test.sqlite3
|
||||||
|
|
||||||
|
production:
|
||||||
|
<<: *default
|
||||||
|
database: db/production.sqlite3
|
|
@ -0,0 +1,5 @@
|
||||||
|
# Load the Rails application.
|
||||||
|
require File.expand_path('../application', __FILE__)
|
||||||
|
|
||||||
|
# Initialize the Rails application.
|
||||||
|
Rails.application.initialize!
|
|
@ -0,0 +1,37 @@
|
||||||
|
Rails.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
|
||||||
|
|
||||||
|
# Do not eager load code on boot.
|
||||||
|
config.eager_load = false
|
||||||
|
|
||||||
|
# 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
|
||||||
|
|
||||||
|
# Raise an error on page load if there are pending migrations.
|
||||||
|
config.active_record.migration_error = :page_load
|
||||||
|
|
||||||
|
# Debug mode disables concatenation and preprocessing of assets.
|
||||||
|
# This option may cause significant delays in view rendering with a large
|
||||||
|
# number of complex assets.
|
||||||
|
config.assets.debug = true
|
||||||
|
|
||||||
|
# Adds additional error checking when serving assets at runtime.
|
||||||
|
# Checks for improperly declared sprockets dependencies.
|
||||||
|
# Raises helpful error messages.
|
||||||
|
config.assets.raise_runtime_errors = true
|
||||||
|
|
||||||
|
# Raises error for missing translations
|
||||||
|
# config.action_view.raise_on_missing_translations = true
|
||||||
|
end
|
|
@ -0,0 +1,78 @@
|
||||||
|
Rails.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
|
||||||
|
|
||||||
|
# Eager load code on boot. This eager loads most of Rails and
|
||||||
|
# your application in memory, allowing both threaded web servers
|
||||||
|
# and those relying on copy on write to perform better.
|
||||||
|
# Rake tasks automatically ignore this option for performance.
|
||||||
|
config.eager_load = true
|
||||||
|
|
||||||
|
# Full error reports are disabled and caching is turned on.
|
||||||
|
config.consider_all_requests_local = false
|
||||||
|
config.action_controller.perform_caching = true
|
||||||
|
|
||||||
|
# Enable Rack::Cache to put a simple HTTP cache in front of your application
|
||||||
|
# Add `rack-cache` to your Gemfile before enabling this.
|
||||||
|
# For large-scale production use, consider using a caching reverse proxy like nginx, varnish or squid.
|
||||||
|
# config.action_dispatch.rack_cache = 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.js_compressor = :uglifier
|
||||||
|
# config.assets.css_compressor = :sass
|
||||||
|
|
||||||
|
# Do not fallback to assets pipeline if a precompiled asset is missed.
|
||||||
|
config.assets.compile = false
|
||||||
|
|
||||||
|
# Generate digests for assets URLs.
|
||||||
|
config.assets.digest = true
|
||||||
|
|
||||||
|
# `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb
|
||||||
|
|
||||||
|
# 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
|
||||||
|
|
||||||
|
# Set to :debug to see everything in the log.
|
||||||
|
config.log_level = :info
|
||||||
|
|
||||||
|
# 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"
|
||||||
|
|
||||||
|
# Ignore bad email addresses and do not raise email delivery errors.
|
||||||
|
# Set this to true and configure the email server for immediate delivery to raise delivery errors.
|
||||||
|
# config.action_mailer.raise_delivery_errors = false
|
||||||
|
|
||||||
|
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to
|
||||||
|
# the I18n.default_locale when a translation cannot be found).
|
||||||
|
config.i18n.fallbacks = true
|
||||||
|
|
||||||
|
# Send deprecation notices to registered listeners.
|
||||||
|
config.active_support.deprecation = :notify
|
||||||
|
|
||||||
|
# Disable automatic flushing of the log to improve performance.
|
||||||
|
# config.autoflush_log = false
|
||||||
|
|
||||||
|
# Use default logging formatter so that PID and timestamp are not suppressed.
|
||||||
|
config.log_formatter = ::Logger::Formatter.new
|
||||||
|
|
||||||
|
# Do not dump schema after migrations.
|
||||||
|
config.active_record.dump_schema_after_migration = false
|
||||||
|
end
|
|
@ -0,0 +1,39 @@
|
||||||
|
Rails.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
|
||||||
|
|
||||||
|
# Do not eager load code on boot. This avoids loading your whole application
|
||||||
|
# just for the purpose of running a single test. If you are using a tool that
|
||||||
|
# preloads Rails for running tests, you may have to set it to true.
|
||||||
|
config.eager_load = false
|
||||||
|
|
||||||
|
# Configure static asset server for tests with Cache-Control for performance.
|
||||||
|
config.serve_static_assets = true
|
||||||
|
config.static_cache_control = 'public, max-age=3600'
|
||||||
|
|
||||||
|
# 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
|
||||||
|
|
||||||
|
# Print deprecation notices to the stderr.
|
||||||
|
config.active_support.deprecation = :stderr
|
||||||
|
|
||||||
|
# Raises error for missing translations
|
||||||
|
# config.action_view.raise_on_missing_translations = true
|
||||||
|
end
|
|
@ -0,0 +1,8 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Version of your assets, change this if you want to expire all your assets.
|
||||||
|
Rails.application.config.assets.version = '1.0'
|
||||||
|
|
||||||
|
# Precompile additional assets.
|
||||||
|
# application.js, application.css, and all non-JS/CSS in app/assets folder are already added.
|
||||||
|
# Rails.application.config.assets.precompile += %w( search.js )
|
|
@ -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!
|
|
@ -0,0 +1,3 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
Rails.application.config.action_dispatch.cookies_serializer = :json
|
|
@ -0,0 +1,4 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Configure sensitive parameters which will be filtered from the log file.
|
||||||
|
Rails.application.config.filter_parameters += [:password]
|
|
@ -0,0 +1,16 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Add new inflection rules using the following format. Inflections
|
||||||
|
# are locale specific, and you may define rules for as many different
|
||||||
|
# locales as you wish. All of these examples are active by default:
|
||||||
|
# ActiveSupport::Inflector.inflections(:en) 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(:en) do |inflect|
|
||||||
|
# inflect.acronym 'RESTful'
|
||||||
|
# end
|
|
@ -0,0 +1,4 @@
|
||||||
|
# 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
|
|
@ -0,0 +1,3 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
Rails.application.config.session_store :cookie_store, key: '_dummy_session'
|
|
@ -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] if respond_to?(:wrap_parameters)
|
||||||
|
end
|
||||||
|
|
||||||
|
# To enable root element in JSON for ActiveRecord objects.
|
||||||
|
# ActiveSupport.on_load(:active_record) do
|
||||||
|
# self.include_root_in_json = true
|
||||||
|
# end
|
|
@ -0,0 +1,23 @@
|
||||||
|
# Files in the config/locales directory are used for internationalization
|
||||||
|
# and are automatically loaded by Rails. If you want to use locales other
|
||||||
|
# than English, add the necessary files in this directory.
|
||||||
|
#
|
||||||
|
# To use the locales, use `I18n.t`:
|
||||||
|
#
|
||||||
|
# I18n.t 'hello'
|
||||||
|
#
|
||||||
|
# In views, this is aliased to just `t`:
|
||||||
|
#
|
||||||
|
# <%= t('hello') %>
|
||||||
|
#
|
||||||
|
# To use a different locale, set it with `I18n.locale`:
|
||||||
|
#
|
||||||
|
# I18n.locale = :es
|
||||||
|
#
|
||||||
|
# This would use the information in config/locales/es.yml.
|
||||||
|
#
|
||||||
|
# To learn more, please read the Rails Internationalization guide
|
||||||
|
# available at http://guides.rubyonrails.org/i18n.html.
|
||||||
|
|
||||||
|
en:
|
||||||
|
hello: "Hello world"
|
|
@ -0,0 +1,4 @@
|
||||||
|
Rails.application.routes.draw do
|
||||||
|
|
||||||
|
mount EPaper::Engine => "/e_paper"
|
||||||
|
end
|
|
@ -0,0 +1,22 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Your secret key is used 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.
|
||||||
|
# You can use `rake secret` to generate a secure secret key.
|
||||||
|
|
||||||
|
# Make sure the secrets in this file are kept private
|
||||||
|
# if you're sharing your code publicly.
|
||||||
|
|
||||||
|
development:
|
||||||
|
secret_key_base: a4cfadf78f7bf950de69d51bd59a5dc6abb5ed74896bfa97b8cadd820d25721cac612fdd1d01c0d51998208a90e3bbfd218361c0f8485b09780de9aab39e6fe8
|
||||||
|
|
||||||
|
test:
|
||||||
|
secret_key_base: 07b46972f0b8548616f825cf2c9d67b0112988e8e7090b94d0d5d718d3365a9469049fc012869025f54ac91edcb06644d800b595f48d90000179b1bdd223c8ad
|
||||||
|
|
||||||
|
# Do not keep production secrets in the repository,
|
||||||
|
# instead read values from the environment.
|
||||||
|
production:
|
||||||
|
secret_key_base: <%= ENV["SECRET_KEY_BASE"] %>
|
|
@ -0,0 +1,67 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>The page you were looking for doesn't exist (404)</title>
|
||||||
|
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: #EFEFEF;
|
||||||
|
color: #2E2F30;
|
||||||
|
text-align: center;
|
||||||
|
font-family: arial, sans-serif;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog {
|
||||||
|
width: 95%;
|
||||||
|
max-width: 33em;
|
||||||
|
margin: 4em auto 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > div {
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #BBB;
|
||||||
|
border-top: #B00100 solid 4px;
|
||||||
|
border-top-left-radius: 9px;
|
||||||
|
border-top-right-radius: 9px;
|
||||||
|
background-color: white;
|
||||||
|
padding: 7px 12% 0;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 100%;
|
||||||
|
color: #730E15;
|
||||||
|
line-height: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > p {
|
||||||
|
margin: 0 0 1em;
|
||||||
|
padding: 1em;
|
||||||
|
background-color: #F7F7F7;
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #999;
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
border-top-color: #DADADA;
|
||||||
|
color: #666;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<!-- This file lives in public/404.html -->
|
||||||
|
<div class="dialog">
|
||||||
|
<div>
|
||||||
|
<h1>The page you were looking for doesn't exist.</h1>
|
||||||
|
<p>You may have mistyped the address or the page may have moved.</p>
|
||||||
|
</div>
|
||||||
|
<p>If you are the application owner check the logs for more information.</p>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,67 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>The change you wanted was rejected (422)</title>
|
||||||
|
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: #EFEFEF;
|
||||||
|
color: #2E2F30;
|
||||||
|
text-align: center;
|
||||||
|
font-family: arial, sans-serif;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog {
|
||||||
|
width: 95%;
|
||||||
|
max-width: 33em;
|
||||||
|
margin: 4em auto 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > div {
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #BBB;
|
||||||
|
border-top: #B00100 solid 4px;
|
||||||
|
border-top-left-radius: 9px;
|
||||||
|
border-top-right-radius: 9px;
|
||||||
|
background-color: white;
|
||||||
|
padding: 7px 12% 0;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 100%;
|
||||||
|
color: #730E15;
|
||||||
|
line-height: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > p {
|
||||||
|
margin: 0 0 1em;
|
||||||
|
padding: 1em;
|
||||||
|
background-color: #F7F7F7;
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #999;
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
border-top-color: #DADADA;
|
||||||
|
color: #666;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<!-- This file lives in public/422.html -->
|
||||||
|
<div class="dialog">
|
||||||
|
<div>
|
||||||
|
<h1>The change you wanted was rejected.</h1>
|
||||||
|
<p>Maybe you tried to change something you didn't have access to.</p>
|
||||||
|
</div>
|
||||||
|
<p>If you are the application owner check the logs for more information.</p>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,66 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>We're sorry, but something went wrong (500)</title>
|
||||||
|
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: #EFEFEF;
|
||||||
|
color: #2E2F30;
|
||||||
|
text-align: center;
|
||||||
|
font-family: arial, sans-serif;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog {
|
||||||
|
width: 95%;
|
||||||
|
max-width: 33em;
|
||||||
|
margin: 4em auto 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > div {
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #BBB;
|
||||||
|
border-top: #B00100 solid 4px;
|
||||||
|
border-top-left-radius: 9px;
|
||||||
|
border-top-right-radius: 9px;
|
||||||
|
background-color: white;
|
||||||
|
padding: 7px 12% 0;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 100%;
|
||||||
|
color: #730E15;
|
||||||
|
line-height: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > p {
|
||||||
|
margin: 0 0 1em;
|
||||||
|
padding: 1em;
|
||||||
|
background-color: #F7F7F7;
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #999;
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
border-top-color: #DADADA;
|
||||||
|
color: #666;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<!-- This file lives in public/500.html -->
|
||||||
|
<div class="dialog">
|
||||||
|
<div>
|
||||||
|
<h1>We're sorry, but something went wrong.</h1>
|
||||||
|
</div>
|
||||||
|
<p>If you are the application owner check the logs for more information.</p>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,7 @@
|
||||||
|
require 'test_helper'
|
||||||
|
|
||||||
|
class EPaperTest < ActiveSupport::TestCase
|
||||||
|
test "truth" do
|
||||||
|
assert_kind_of Module, EPaper
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,10 @@
|
||||||
|
require 'test_helper'
|
||||||
|
|
||||||
|
class NavigationTest < ActionDispatch::IntegrationTest
|
||||||
|
fixtures :all
|
||||||
|
|
||||||
|
# test "the truth" do
|
||||||
|
# assert true
|
||||||
|
# end
|
||||||
|
end
|
||||||
|
|
|
@ -0,0 +1,19 @@
|
||||||
|
# Configure Rails Environment
|
||||||
|
ENV["RAILS_ENV"] = "test"
|
||||||
|
|
||||||
|
require File.expand_path("../../test/dummy/config/environment.rb", __FILE__)
|
||||||
|
ActiveRecord::Migrator.migrations_paths = [File.expand_path("../../test/dummy/db/migrate", __FILE__)]
|
||||||
|
ActiveRecord::Migrator.migrations_paths << File.expand_path('../../db/migrate', __FILE__)
|
||||||
|
require "rails/test_help"
|
||||||
|
|
||||||
|
# Filter out Minitest backtrace while allowing backtrace from other libraries
|
||||||
|
# to be shown.
|
||||||
|
Minitest.backtrace_filter = Minitest::BacktraceFilter.new
|
||||||
|
|
||||||
|
# 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
|
Loading…
Reference in New Issue