Orbit PersonalResearch Module
This commit is contained in:
commit
4f98fa07b9
|
@ -0,0 +1,6 @@
|
||||||
|
.bundle/
|
||||||
|
log/*.log
|
||||||
|
pkg/
|
||||||
|
test/dummy/db/*.sqlite3
|
||||||
|
test/dummy/log/*.log
|
||||||
|
test/dummy/tmp/
|
|
@ -0,0 +1,17 @@
|
||||||
|
source "http://rubygems.org"
|
||||||
|
|
||||||
|
# Declare your gem's dependencies in personal_research.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 'ruby-debug19', :require => 'ruby-debug'
|
|
@ -0,0 +1,20 @@
|
||||||
|
Copyright 2012 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.
|
|
@ -0,0 +1,3 @@
|
||||||
|
= PersonalResearch
|
||||||
|
|
||||||
|
This project rocks and uses MIT-LICENSE.
|
|
@ -0,0 +1,39 @@
|
||||||
|
#!/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 = 'PersonalResearch'
|
||||||
|
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,151 @@
|
||||||
|
orbitDesktop.prototype.initializePersonalResearch = function(target,url,cache){ // this init journal papers
|
||||||
|
this.initializePersonalResearch.formCallback = function(data){
|
||||||
|
if(data.success){
|
||||||
|
o.notify(data.msg,"success");
|
||||||
|
o.sub_menu_item($("div[content-type=menu] a").eq(0));
|
||||||
|
}else{
|
||||||
|
o.notify(data.msg,"alert");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.initializePersonalResearch.list = function(){ // to open list part in journal papers page
|
||||||
|
var journalData;
|
||||||
|
var bindHandlers = function(){ // to bind handlers for list page
|
||||||
|
|
||||||
|
}
|
||||||
|
bindHandlers();
|
||||||
|
|
||||||
|
var bindSecondaryHandlers = function(){
|
||||||
|
$("#journal_p div#paper_list a.icon-check-empty").click(function(){
|
||||||
|
if($(this).hasClass("icon-check-empty")){
|
||||||
|
$(this).switchClass("icon-check-empty","icon-check",0);
|
||||||
|
} else if($(this) .hasClass("icon-check")) {
|
||||||
|
$(this).switchClass("icon-check","icon-check-empty",0);
|
||||||
|
} else if($(this).hasClass("icon-star")){
|
||||||
|
$(this).removeClass("icon-star").addClass("icon-star-empty");
|
||||||
|
} else if($(this).hasClass("icon-star-empty")){
|
||||||
|
$(this).removeClass("icon-star-empty").addClass("icon-star");
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
})
|
||||||
|
}
|
||||||
|
o.enableSharing("div.share_mode");
|
||||||
|
}
|
||||||
|
this.initializePersonalResearch.researchDelete = function(data,dom){
|
||||||
|
var parent = dom.parent().parent().parent();
|
||||||
|
if(data.success){
|
||||||
|
parent.hide("slide",function(){parent.remove();});
|
||||||
|
o.notify(data.msg,"success");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.initializePersonalResearch.cancelresearch = function(){
|
||||||
|
o.highlight_sub_menu_item(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
var uploadFiles = function(){
|
||||||
|
$('#add_plugin_file a.add').click(function(){
|
||||||
|
var new_id = $(this).prev().attr('value');
|
||||||
|
var old_id = new RegExp("new_writing_journal_files", "g");
|
||||||
|
$(this).prev().attr('value', parseInt(new_id) + 1);
|
||||||
|
var x = get_html(old_id,new_id);
|
||||||
|
var newfield = $(x);
|
||||||
|
$(this).parents('table').append(newfield);
|
||||||
|
newfield.find('.action a.delete').click(function(){
|
||||||
|
newfield.remove();
|
||||||
|
});
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
$('.action a.remove_existing_record').click(function(){
|
||||||
|
$(this).toggleClass("color-red",function(){
|
||||||
|
if($(this).hasClass('color-red')){
|
||||||
|
$(this).next('.should_destroy').attr('value', 1);
|
||||||
|
}else{
|
||||||
|
$(this).next('.should_destroy').removeAttr('value');
|
||||||
|
}
|
||||||
|
})
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
var languageSelect = function(){
|
||||||
|
$(".language_select a").click(function(event) {
|
||||||
|
$("*[data-language]").hide();
|
||||||
|
$("*[data-language="+$(this).data("lang")+"]").show();
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.initializePersonalResearch.editresearch = function(){
|
||||||
|
o.highlight_sub_menu_item(1);
|
||||||
|
uploadFiles();
|
||||||
|
languageSelect();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.initializePersonalResearch.addresearch = function(){ // to open add pages in journal papers page
|
||||||
|
uploadFiles();
|
||||||
|
languageSelect();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.initializePersonalResearch.brief = function(){
|
||||||
|
o.enablelanguageSelect();
|
||||||
|
$("textarea.editor").ckeditor({
|
||||||
|
height: 300,
|
||||||
|
width: $(".overview").width() - 20
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
this.initializePersonalResearch.coAuthorformCallback = function(data){
|
||||||
|
if(data.success){
|
||||||
|
o.notify(data.msg,"success");
|
||||||
|
o.sub_menu_item($("div[content-type=menu] a").eq(3));
|
||||||
|
}else{
|
||||||
|
o.notify(data.msg,"alert");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.initializePersonalResearch.coauthor = function(){ // to open add pages in coauthor page
|
||||||
|
var bindHandlers = function(){ // to bind handlers for add page
|
||||||
|
|
||||||
|
}
|
||||||
|
bindHandlers();
|
||||||
|
}
|
||||||
|
this.initializePersonalResearch.coauthorRelationForm = function(data){
|
||||||
|
if(data.success){
|
||||||
|
o.notify(data.msg,"success");
|
||||||
|
$("#co_author_relation_table").html(data.newvalue);
|
||||||
|
}else{
|
||||||
|
o.notify(data.msg,"alert");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.initializePersonalResearch.coauthorRelationEditForm = function(data){
|
||||||
|
if(data.success){
|
||||||
|
o.notify(data.msg,"success");
|
||||||
|
var x = o.layout_data.generate_layout_html(data.newvalue);
|
||||||
|
$("div[container=true] div.overview").html(x.markup);
|
||||||
|
}else{
|
||||||
|
o.notify(data.msg,"alert");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.initializePersonalResearch.allnone = function(d,o){
|
||||||
|
switch(o.attr("href")){
|
||||||
|
case "all":
|
||||||
|
$("div.overview a.icon-check-empty").removeClass("icon-check-empty").addClass("icon-check");
|
||||||
|
break;
|
||||||
|
case "none":
|
||||||
|
$("div.overview a.icon-check").removeClass("icon-check").addClass("icon-check-empty");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.initializePersonalResearch.allnone = function(d,o){
|
||||||
|
switch(o.attr("href")){
|
||||||
|
case "all":
|
||||||
|
$("div.overview a.icon-check-empty").removeClass("icon-check-empty").addClass("icon-check");
|
||||||
|
break;
|
||||||
|
case "none":
|
||||||
|
$("div.overview a.icon-check").removeClass("icon-check").addClass("icon-check-empty");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,115 @@
|
||||||
|
/* Books */
|
||||||
|
[page-name="research_list"] .list_t_item .inner {
|
||||||
|
padding-left: 30px; }
|
||||||
|
[page-name="research_list"] .list_item_action {
|
||||||
|
font-size: 12px;
|
||||||
|
float: left;
|
||||||
|
margin-left: -30px; }
|
||||||
|
[page-name="research_list"] .list_item_action a {
|
||||||
|
display: block;
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
line-height: 20px;
|
||||||
|
margin: 1px 1px 6px 1px; }
|
||||||
|
[page-name="research_list"] .list_item_action .icon-star-empty {
|
||||||
|
color: #999;
|
||||||
|
font-size: 20px; }
|
||||||
|
[page-name="research_list"] .list_item_action .icon-star {
|
||||||
|
color: #faa732;
|
||||||
|
font-size: 20px; }
|
||||||
|
[page-name="research_list"] .list_item_action .icon-check-empty {
|
||||||
|
color: #999;
|
||||||
|
font-size: 20px; }
|
||||||
|
[page-name="research_list"] .list_item_action .icon-check {
|
||||||
|
color: #333;
|
||||||
|
font-size: 20px; }
|
||||||
|
[page-name="research_list"] .file_view .list_t_des {
|
||||||
|
overflow: hidden; }
|
||||||
|
[page-name="research_list"] .file_view .file {
|
||||||
|
float: left;
|
||||||
|
width: 120px;
|
||||||
|
height: 50px;
|
||||||
|
padding: 6px;
|
||||||
|
margin: 1px;
|
||||||
|
position: relative;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
/* webkit */
|
||||||
|
-khtml-box-sizing: border-box;
|
||||||
|
/* konqueror */
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
/* firefox */
|
||||||
|
-ms-box-sizing: border-box;
|
||||||
|
/* ie */
|
||||||
|
box-sizing: border-box;
|
||||||
|
/* css3 */ }
|
||||||
|
[page-name="research_list"] .file_view .file:hover {
|
||||||
|
background-color: #f7f7f7; }
|
||||||
|
[page-name="research_list"] .file_view .file img {
|
||||||
|
width: 38px;
|
||||||
|
height: 38px;
|
||||||
|
position: absolute;
|
||||||
|
left: 6px;
|
||||||
|
top: 6px; }
|
||||||
|
[page-name="research_list"] .file_view .file .filetitle {
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
height: 38px;
|
||||||
|
padding-left: 40px;
|
||||||
|
overflow: hidden;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
/* webkit */
|
||||||
|
-khtml-box-sizing: border-box;
|
||||||
|
/* konqueror */
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
/* firefox */
|
||||||
|
-ms-box-sizing: border-box;
|
||||||
|
/* ie */
|
||||||
|
box-sizing: border-box;
|
||||||
|
/* css3 */ }
|
||||||
|
|
||||||
|
/* Books Books list */
|
||||||
|
[page-name="books_books"] .datalist_item .inner {
|
||||||
|
padding-left: 30px; }
|
||||||
|
[page-name="books_books"] .list_item_action {
|
||||||
|
font-size: 12px;
|
||||||
|
float: left;
|
||||||
|
margin-left: -30px; }
|
||||||
|
[page-name="books_books"] .list_item_action i {
|
||||||
|
color: #999;
|
||||||
|
font-size: 20px;
|
||||||
|
display: block;
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
line-height: 20px;
|
||||||
|
margin: 1px 1px 6px 1px; }
|
||||||
|
[page-name="books_books"] .list_t_desc {
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
font-size: 12px;
|
||||||
|
color: #999; }
|
||||||
|
|
||||||
|
/* Books Co-Author */
|
||||||
|
[page-name="books_coauthor"] .list_t_item {
|
||||||
|
height: 110px; }
|
||||||
|
[page-name="books_coauthor"] .list_item_function a {
|
||||||
|
display: inline-block;
|
||||||
|
padding: 4px;
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
font-size: 11px;
|
||||||
|
-webkit-text-size-adjust: none; }
|
||||||
|
[page-name="books_coauthor"] .info {
|
||||||
|
font-family: Arial, sans-serif; }
|
||||||
|
[page-name="books_coauthor"] .info li {
|
||||||
|
margin-bottom: 8px;
|
||||||
|
color: #999; }
|
||||||
|
[page-name="books_coauthor"] .info .name {
|
||||||
|
font-size: 18px;
|
||||||
|
line-height: 24px;
|
||||||
|
color: #333; }
|
||||||
|
|
||||||
|
/* Books Co-Author Relationship*/
|
||||||
|
[page-name="books_coauthor_relation"] .edit_co_author_relation {
|
||||||
|
/*margin-left: -10px;*/ }
|
||||||
|
[page-name="books_coauthor_relation"] .form_space {
|
||||||
|
margin-bottom: 10px;
|
||||||
|
font-size: 18px;
|
||||||
|
font-family: Arial, sans-serif; }
|
|
@ -0,0 +1,123 @@
|
||||||
|
@import "desktop-helper";
|
||||||
|
|
||||||
|
/* Books */
|
||||||
|
[page-name="research_list"] {
|
||||||
|
.list_t_item .inner { padding-left: 30px; }
|
||||||
|
.list_item_action {
|
||||||
|
font-size: 12px;
|
||||||
|
float: left;
|
||||||
|
margin-left: -30px;
|
||||||
|
|
||||||
|
a {
|
||||||
|
display: block;
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
line-height: 20px;
|
||||||
|
margin: 1px 1px 6px 1px;
|
||||||
|
}
|
||||||
|
.icon-star-empty { color: #999; font-size: 20px; }
|
||||||
|
.icon-star { color: #faa732; font-size: 20px; }
|
||||||
|
.icon-check-empty { color: #999; font-size: 20px; }
|
||||||
|
.icon-check { color: #333; font-size: 20px; }
|
||||||
|
}
|
||||||
|
|
||||||
|
.file_view {
|
||||||
|
.list_t_des {
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.file {
|
||||||
|
float: left;
|
||||||
|
width: 120px;
|
||||||
|
height: 50px;
|
||||||
|
padding: 6px;
|
||||||
|
margin: 1px;
|
||||||
|
position: relative;
|
||||||
|
@include box-sizing;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background-color: lighten($gray, 10%);
|
||||||
|
}
|
||||||
|
img {
|
||||||
|
width: 38px;
|
||||||
|
height: 38px;
|
||||||
|
position: absolute;
|
||||||
|
left: 6px;
|
||||||
|
top: 6px;
|
||||||
|
}
|
||||||
|
.filetitle {
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
height: 38px;
|
||||||
|
padding-left: 40px;
|
||||||
|
overflow: hidden;
|
||||||
|
@include box-sizing;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Books Books list */
|
||||||
|
[page-name="books_books"] {
|
||||||
|
|
||||||
|
.datalist_item .inner {
|
||||||
|
padding-left: 30px;
|
||||||
|
}
|
||||||
|
.list_item_action {
|
||||||
|
font-size: 12px;
|
||||||
|
float: left;
|
||||||
|
margin-left: -30px;
|
||||||
|
}
|
||||||
|
.list_item_action i {
|
||||||
|
color: #999;
|
||||||
|
font-size: 20px;
|
||||||
|
display: block;
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
line-height: 20px;
|
||||||
|
margin: 1px 1px 6px 1px;
|
||||||
|
}
|
||||||
|
.list_t_desc {
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
font-size: 12px;
|
||||||
|
color: #999;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Books Co-Author */
|
||||||
|
[page-name="books_coauthor"] {
|
||||||
|
.list_t_item {
|
||||||
|
height: 110px;
|
||||||
|
}
|
||||||
|
.list_item_function {}
|
||||||
|
.list_item_function a {
|
||||||
|
display: inline-block;
|
||||||
|
padding: 4px;
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
font-size: 11px;
|
||||||
|
-webkit-text-size-adjust: none;
|
||||||
|
}
|
||||||
|
.info {
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
}
|
||||||
|
.info li {
|
||||||
|
margin-bottom: 8px;
|
||||||
|
color: #999;
|
||||||
|
}
|
||||||
|
.info .name {
|
||||||
|
font-size: 18px;
|
||||||
|
line-height: 24px;
|
||||||
|
color: #333;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Books Co-Author Relationship*/
|
||||||
|
[page-name="books_coauthor_relation"]{
|
||||||
|
.edit_co_author_relation {
|
||||||
|
/*margin-left: -10px;*/
|
||||||
|
}
|
||||||
|
.form_space {
|
||||||
|
margin-bottom: 10px;
|
||||||
|
font-size: 18px;
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
}
|
||||||
|
}
|
|
@ -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
|
|
@ -0,0 +1,10 @@
|
||||||
|
class Panel::PersonalResearch::BackEnd::PersonalResearchIntrosController < Admin::PersonalPluginIntrosController
|
||||||
|
|
||||||
|
def initialize
|
||||||
|
super
|
||||||
|
@app_type = 'personal_research_intro'
|
||||||
|
@app_type_name = 'personal_research'
|
||||||
|
@reback_name = 'Research'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,189 @@
|
||||||
|
class Panel::PersonalResearch::BackEnd::ResearchsController < OrbitBackendController
|
||||||
|
include AdminHelper
|
||||||
|
include OrbitControllerLib::DivisionForDisable
|
||||||
|
|
||||||
|
before_filter :authenticate_user!
|
||||||
|
|
||||||
|
def index
|
||||||
|
get_plugins
|
||||||
|
|
||||||
|
# @tags = get_tags
|
||||||
|
# @categories = get_categories_for_index
|
||||||
|
# @statuses = get_statuses
|
||||||
|
# category_ids = @categories.collect{|t| t.id}
|
||||||
|
|
||||||
|
@researchs = get_sorted_and_filtered("research")
|
||||||
|
respond_to do |format|
|
||||||
|
format.html # index.html.erb
|
||||||
|
format.js { }
|
||||||
|
format.xml { render :xml => @researchs }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# GET /researchs/1
|
||||||
|
# GET /researchs/1.xml
|
||||||
|
def show
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
respond_to do |format|
|
||||||
|
format.html # show.html.erb
|
||||||
|
format.xml { render :xml => @research }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# GET /researchs/new
|
||||||
|
# GET /researchs/new.xml
|
||||||
|
def new
|
||||||
|
|
||||||
|
get_plugins
|
||||||
|
|
||||||
|
@research = Research.new
|
||||||
|
|
||||||
|
@tags = get_tags
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
format.html # new.html.erb
|
||||||
|
format.xml { render :xml => @research }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# GET /researchs/1/edit
|
||||||
|
def edit
|
||||||
|
|
||||||
|
get_plugins
|
||||||
|
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
|
||||||
|
@tags = get_tags
|
||||||
|
end
|
||||||
|
|
||||||
|
# POST /researchs
|
||||||
|
# POST /researchs.xml
|
||||||
|
def create
|
||||||
|
|
||||||
|
@tags = get_tags
|
||||||
|
|
||||||
|
@research = Research.new(params[:research])
|
||||||
|
|
||||||
|
if params[:research][:user_id]
|
||||||
|
@research.create_user_id = params[:research][:user_id]
|
||||||
|
@research.update_user_id = params[:research][:user_id]
|
||||||
|
else
|
||||||
|
@research.create_user_id = current_user.id
|
||||||
|
@research.update_user_id = current_user.id
|
||||||
|
end
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
if @research.save
|
||||||
|
|
||||||
|
if params[:research][:user_id]
|
||||||
|
format.html { redirect_to(admin_users_new_interface_url(:id=>params[:research][:user_id],:show_plugin_profile=>"Research")) }
|
||||||
|
else
|
||||||
|
format.html { redirect_to(panel_personal_research_back_end_researchs_url) }
|
||||||
|
end
|
||||||
|
|
||||||
|
format.xml { render :xml => @research, :status => :created, :location => @research }
|
||||||
|
else
|
||||||
|
format.html { render :action => "new" }
|
||||||
|
format.xml { render :xml => @research.errors, :status => :unprocessable_entity }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# PUT /researchs/1
|
||||||
|
# PUT /researchs/1.xml
|
||||||
|
def update
|
||||||
|
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
|
||||||
|
@research.update_user_id = current_user.id
|
||||||
|
|
||||||
|
params[:research][:tag_ids] ||=[]
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
if @research.update_attributes(params[:research])
|
||||||
|
format.html { redirect_to(panel_personal_research_back_end_researchs_url) }
|
||||||
|
# format.js { render 'toggle_enable' }
|
||||||
|
format.xml { head :ok }
|
||||||
|
else
|
||||||
|
format.html { render :action => "edit" }
|
||||||
|
format.xml { render :xml => @research.errors, :status => :unprocessable_entity }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
# DELETE /researchs/1
|
||||||
|
# DELETE /researchs/1.xml
|
||||||
|
def destroy
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
@research.destroy
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
format.html { redirect_to(panel_personal_research_back_end_researchs_url) }
|
||||||
|
# format.xml { head :ok }
|
||||||
|
format.js
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def delete
|
||||||
|
if params[:ids]
|
||||||
|
researchs = Research.any_in(:_id => params[:ids]).destroy_all
|
||||||
|
end
|
||||||
|
redirect_to panel_personal_research_back_end_researchs_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
|
||||||
|
end
|
||||||
|
|
||||||
|
def data_share
|
||||||
|
|
||||||
|
if params[:ids]
|
||||||
|
|
||||||
|
@researchs = Research.any_in(:_id => params[:ids])
|
||||||
|
|
||||||
|
@researchs.each do |research|
|
||||||
|
|
||||||
|
research.is_hidden = params[:disable]
|
||||||
|
|
||||||
|
research.save
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
|
||||||
|
format.html { redirect_to(admin_users_new_interface_url(:id=>params[:user_id],:show_plugin_profile=>"Research")) }
|
||||||
|
format.json { render json: {"success"=>true}.to_json}
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
protected
|
||||||
|
|
||||||
|
|
||||||
|
# def get_index_categories(id = nil)
|
||||||
|
# @bulletin_categorys = []
|
||||||
|
# if(is_manager? || is_admin?)
|
||||||
|
# @bulletin_categorys = (id ? BulletinCategory.admin_manager_all.find(id).to_a : BulletinCategory.admin_manager_all)
|
||||||
|
# elsif is_sub_manager?
|
||||||
|
# @bulletin_categorys = BulletinCategory.all
|
||||||
|
# end
|
||||||
|
# @bulletin_categorys
|
||||||
|
# end
|
||||||
|
|
||||||
|
|
||||||
|
# def get_categorys(id = nil)
|
||||||
|
# @research_categorys = []
|
||||||
|
# if(is_manager? || is_admin?)
|
||||||
|
# @research_categorys = (id ? ResearchCategory.admin_manager_all.find(id).to_a : ResearchCategory.admin_manager_all))
|
||||||
|
# elsif is_sub_manager?
|
||||||
|
# @research_categorys = ResearchCategory.all.authed_for_user(current_user,'edit')
|
||||||
|
# end
|
||||||
|
# if @research_categorys.empty? && params[:action] != "index"
|
||||||
|
# flash[:alert] = t("announcement.error.no_avilb_cate_for_posting")
|
||||||
|
# redirect_to :action => :index
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
|
||||||
|
def get_plugins
|
||||||
|
@plugins = OrbitApp::Plugin::Registration.all
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,71 @@
|
||||||
|
class Panel::PersonalResearch::Desktop::PersonalResearchsController < ApplicationController
|
||||||
|
|
||||||
|
def index
|
||||||
|
@researches = Research.where(create_user_id: current_user.id)
|
||||||
|
@view_by = params[:view]
|
||||||
|
page = params[:page]
|
||||||
|
page ||= 1
|
||||||
|
|
||||||
|
@per_column = 5
|
||||||
|
|
||||||
|
case @view_by
|
||||||
|
when "abstract"
|
||||||
|
@per_column = 1
|
||||||
|
when "file"
|
||||||
|
@per_column = 2
|
||||||
|
end
|
||||||
|
|
||||||
|
if @view_by.nil?
|
||||||
|
@view_by = " "
|
||||||
|
@researches = @researches.asc(:paper_title)
|
||||||
|
else
|
||||||
|
@researches = @researches.asc(@view_by).asc(:paper_title)
|
||||||
|
end
|
||||||
|
@researches = @researches.page(page).per(50)
|
||||||
|
respond_to do |format|
|
||||||
|
format.html { render :layout => false}
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def new
|
||||||
|
@research = Research.new
|
||||||
|
render :layout => false
|
||||||
|
end
|
||||||
|
|
||||||
|
def create
|
||||||
|
params[:research][:create_user_id] = current_user.id
|
||||||
|
@research = Research.new(params[:research])
|
||||||
|
if @research.save
|
||||||
|
render json: {success: true, msg: t('create_success')}.to_json
|
||||||
|
else
|
||||||
|
error_msg = @research.errors.full_messages.join("<br />")
|
||||||
|
render json: {success: false, msg: error_msg}.to_json
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def edit
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
render :layout => false
|
||||||
|
end
|
||||||
|
|
||||||
|
def update
|
||||||
|
params[:research][:create_user_id] = current_user.id
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
if @research.update_attributes(params[:research])
|
||||||
|
render json: {success: true, msg: t('create_success')}.to_json
|
||||||
|
else
|
||||||
|
error_msg = @research.errors.full_messages.join("<br />")
|
||||||
|
render json: {success: false, msg: error_msg}.to_json
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def destroy
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
@research.destroy
|
||||||
|
render :json => {success: true, msg: t('delete_success')}
|
||||||
|
end
|
||||||
|
|
||||||
|
def research_window
|
||||||
|
render :layout => false
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,32 @@
|
||||||
|
class Panel::PersonalResearch::Desktop::PluginIntrosController < ApplicationController
|
||||||
|
|
||||||
|
def index
|
||||||
|
@intro = PersonalResearchIntro.where(:user_id => current_user.id.to_s).first
|
||||||
|
if @intro.blank?
|
||||||
|
@intro = PersonalResearchIntro.new
|
||||||
|
render "new", :layout => false
|
||||||
|
else
|
||||||
|
render "edit", :layout => false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def create
|
||||||
|
@intro = PersonalResearchIntro.new(params[:personal_research_intro])
|
||||||
|
@intro.user_id = current_user.id
|
||||||
|
if @intro.save
|
||||||
|
render :json => {"success" => true}.to_json
|
||||||
|
else
|
||||||
|
render :json => {"success" => false}.to_json
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def update
|
||||||
|
@intro = PersonalResearchIntro.find(params[:id])
|
||||||
|
if @intro.update_attributes(params[:personal_research_intro])
|
||||||
|
render :json => {"success" => true}.to_json
|
||||||
|
else
|
||||||
|
render :json => {"success" => false}.to_json
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,22 @@
|
||||||
|
class Panel::PersonalResearch::FrontEnd::ResearchsController < OrbitWidgetController
|
||||||
|
|
||||||
|
def initialize
|
||||||
|
super
|
||||||
|
@app_title = 'personal_research'
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
def index
|
||||||
|
|
||||||
|
@researchs = Research.where(:is_hidden=>false).desc(:publish_date).page(params[:page]).per(10)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
# GET /researchs/1
|
||||||
|
# GET /researchs/1.xml
|
||||||
|
def show
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,160 @@
|
||||||
|
class Panel::PersonalResearch::Plugin::ResearchsController < OrbitBackendController
|
||||||
|
include AdminHelper
|
||||||
|
include OrbitControllerLib::DivisionForDisable
|
||||||
|
|
||||||
|
before_filter :authenticate_user!
|
||||||
|
|
||||||
|
def index
|
||||||
|
|
||||||
|
|
||||||
|
@filter = params[:filter]
|
||||||
|
new_filter = params[:new_filter]
|
||||||
|
|
||||||
|
if @filter && params[:clear]
|
||||||
|
@filter.delete(params[:type])
|
||||||
|
elsif @filter && new_filter
|
||||||
|
if @filter.has_key?(new_filter[:type]) && @filter[new_filter[:type]].include?(new_filter[:id].to_s)
|
||||||
|
@filter[new_filter[:type]].delete(new_filter[:id].to_s)
|
||||||
|
elsif @filter.has_key?(new_filter[:type])
|
||||||
|
@filter[new_filter[:type]] << new_filter[:id].to_s
|
||||||
|
else
|
||||||
|
@filter.merge!({new_filter[:type] => [new_filter[:id].to_s]})
|
||||||
|
end
|
||||||
|
elsif new_filter
|
||||||
|
@filter = {new_filter[:type] => [new_filter[:id].to_s]}
|
||||||
|
end
|
||||||
|
|
||||||
|
# @researchs = (params[:sort] || @filter) ? get_sorted_and_filtered("research",:create_user_id => current_user.id) : get_viewable("research",:create_user_id => current_user.id)
|
||||||
|
@researchs = @researchs = Research.all.where(:create_user_id => current_user.id).page(params[:page]).per(10)
|
||||||
|
|
||||||
|
@tags = get_tags
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
format.html # index.html.erb
|
||||||
|
format.xml { render :xml => @researchs }
|
||||||
|
format.js
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# GET /researchs/1
|
||||||
|
# GET /researchs/1.xml
|
||||||
|
def show
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
respond_to do |format|
|
||||||
|
format.html # show.html.erb
|
||||||
|
format.xml { render :xml => @research }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# GET /researchs/new
|
||||||
|
# GET /researchs/new.xml
|
||||||
|
def new
|
||||||
|
|
||||||
|
@research = Research.new
|
||||||
|
|
||||||
|
@tags = get_tags
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
format.html # new.html.erb
|
||||||
|
format.xml { render :xml => @research }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# GET /researchs/1/edit
|
||||||
|
def edit
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
|
||||||
|
@tags = get_tags
|
||||||
|
end
|
||||||
|
|
||||||
|
# POST /researchs
|
||||||
|
# POST /researchs.xml
|
||||||
|
def create
|
||||||
|
|
||||||
|
@tags = get_tags
|
||||||
|
|
||||||
|
@research = Research.new(params[:research])
|
||||||
|
|
||||||
|
@research.create_user_id = current_user.id
|
||||||
|
@research.update_user_id = current_user.id
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
if @research.save
|
||||||
|
format.html { redirect_to(panel_personal_research_plugin_researchs_url) }
|
||||||
|
format.xml { render :xml => @research, :status => :created, :location => @research }
|
||||||
|
else
|
||||||
|
format.html { render :action => "new" }
|
||||||
|
format.xml { render :xml => @research.errors, :status => :unprocessable_entity }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# PUT /researchs/1
|
||||||
|
# PUT /researchs/1.xml
|
||||||
|
def update
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
|
||||||
|
@research.update_user_id = current_user.id
|
||||||
|
|
||||||
|
params[:research][:tag_ids] ||=[]
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
if @research.update_attributes(params[:research])
|
||||||
|
format.html { redirect_to(panel_personal_research_plugin_researchs_url) }
|
||||||
|
# format.js { render 'toggle_enable' }
|
||||||
|
format.xml { head :ok }
|
||||||
|
else
|
||||||
|
format.html { render :action => "edit" }
|
||||||
|
format.xml { render :xml => @research.errors, :status => :unprocessable_entity }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# DELETE /researchs/1
|
||||||
|
# DELETE /researchs/1.xml
|
||||||
|
def destroy
|
||||||
|
@research = Research.find(params[:id])
|
||||||
|
@research.destroy
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
format.html { redirect_to(panel_personal_research_plugin_researchs_url) }
|
||||||
|
# format.xml { head :ok }
|
||||||
|
format.js
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def delete
|
||||||
|
if params[:ids]
|
||||||
|
researchs = Research.any_in(:_id => params[:ids]).destroy_all
|
||||||
|
end
|
||||||
|
redirect_to panel_personal_research_plugin_researchs_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
|
||||||
|
end
|
||||||
|
|
||||||
|
protected
|
||||||
|
|
||||||
|
|
||||||
|
# def get_index_categories(id = nil)
|
||||||
|
# @bulletin_categorys = []
|
||||||
|
# if(is_manager? || is_admin?)
|
||||||
|
# @bulletin_categorys = (id ? BulletinCategory.admin_manager_all.find(id).to_a : BulletinCategory.admin_manager_all)
|
||||||
|
# elsif is_sub_manager?
|
||||||
|
# @bulletin_categorys = BulletinCategory.all
|
||||||
|
# end
|
||||||
|
# @bulletin_categorys
|
||||||
|
# end
|
||||||
|
|
||||||
|
|
||||||
|
# def get_categorys(id = nil)
|
||||||
|
# @research_categorys = []
|
||||||
|
# if(is_manager? || is_admin?)
|
||||||
|
# @research_categorys = (id ? ResearchCategory.admin_manager_all.find(id).to_a : ResearchCategory.admin_manager_all))
|
||||||
|
# elsif is_sub_manager?
|
||||||
|
# @research_categorys = ResearchCategory.all.authed_for_user(current_user,'edit')
|
||||||
|
# end
|
||||||
|
# if @research_categorys.empty? && params[:action] != "index"
|
||||||
|
# flash[:alert] = t("announcement.error.no_avilb_cate_for_posting")
|
||||||
|
# redirect_to :action => :index
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,104 @@
|
||||||
|
module Panel::PersonalResearch::Desktop::PersonalResearchsHelper
|
||||||
|
def publication_record publication, view
|
||||||
|
content_tag :li,
|
||||||
|
"item" => "true",
|
||||||
|
"item" => "true",
|
||||||
|
"data-id" => publication.id.to_s,
|
||||||
|
:class => "list_t_item #{view.blank? ? '' : "#{view}_view" } #{publication.is_hidden? ? "private" : "public" }" do
|
||||||
|
content_tag :div,
|
||||||
|
:class => "inner" do
|
||||||
|
marker(publication.id) + \
|
||||||
|
content(publication, view) + \
|
||||||
|
edit_or_delete(publication)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def marker id
|
||||||
|
content_tag :div,
|
||||||
|
:class => "list_item_action" do
|
||||||
|
content_tag(:a, "",:href=>"",
|
||||||
|
:class => "icon-check-empty",
|
||||||
|
"toggle-onclick"=>"icon-check-empty icon-check",
|
||||||
|
"data-id" => id.to_s,
|
||||||
|
"ajax-remote"=>"false") + \
|
||||||
|
content_tag(:a, "",:href=>"",
|
||||||
|
:class => "icon-star-empty",
|
||||||
|
"toggle-onclick"=>"icon-star-empty icon-star",
|
||||||
|
"data-id" => id.to_s,
|
||||||
|
"ajax-remote"=>"false")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def content publication, view
|
||||||
|
case view
|
||||||
|
when "research_title"
|
||||||
|
des = content_tag(:div, publication.research_title,
|
||||||
|
:class => "list_t_des")
|
||||||
|
when "keywords"
|
||||||
|
des = content_tag(:div, publication.keywords,
|
||||||
|
:class => "list_t_des")
|
||||||
|
when "extracted_chapters"
|
||||||
|
des = content_tag(:div, publication.extracted_chapters,
|
||||||
|
:class => "list_t_des")
|
||||||
|
when "file"
|
||||||
|
des = content_tag(:div, link_publication_file(publication),
|
||||||
|
:class => "list_t_des")
|
||||||
|
else
|
||||||
|
end
|
||||||
|
|
||||||
|
content_tag(:div, publication.research_title,
|
||||||
|
:class => "list_t_title") + des
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
def edit_or_delete publication
|
||||||
|
content_tag :div,
|
||||||
|
:class => "list_item_function" do
|
||||||
|
content_tag(:a, t("edit"),
|
||||||
|
:class => "journal_paper_edit admbg2 admtxt",
|
||||||
|
:href => edit_panel_personal_research_desktop_personal_research_path(publication),
|
||||||
|
"callback-method" => "editresearch",
|
||||||
|
"ajax-remote" => "get") + \
|
||||||
|
content_tag(:a, t(:delete_),
|
||||||
|
"ajax-remote" => "delete",
|
||||||
|
"confirm-message" => t("sure?"),
|
||||||
|
"callback-method" => "researchDelete",
|
||||||
|
:class => "journal_paper_delete admbg2 admtxt",
|
||||||
|
:href => panel_personal_research_desktop_personal_research_path(publication))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def link_publication_file publication
|
||||||
|
publication.research_files.map{|file|
|
||||||
|
link_to(image_tag(check_file_type(file.file.url)) + \
|
||||||
|
content_tag(:span, (file.title_translations[I18n.locale.to_s] rescue nil), :class => "filetitle"),
|
||||||
|
file.file.url,
|
||||||
|
:class => "file",
|
||||||
|
"target" => "_blank",
|
||||||
|
"title" => (file.title_translations[I18n.locale.to_s] rescue nil))
|
||||||
|
}.inject(:+)
|
||||||
|
end
|
||||||
|
|
||||||
|
def check_file_type file
|
||||||
|
if not file.nil?
|
||||||
|
file_type = MIME::Types.type_for(file).first.to_s.split("/")[1]
|
||||||
|
file_type = "/assets/ft-icons/#{file_type}/#{file_type}-48_32.png"
|
||||||
|
else
|
||||||
|
file_type = ""
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def generate_authors_name ids
|
||||||
|
author_name = ids.map{|m|
|
||||||
|
if m == "0"
|
||||||
|
#{:id => 0, :text => current_user.name, :email => current_user.email }
|
||||||
|
{:id => 0, :text => current_user.name }
|
||||||
|
else
|
||||||
|
#{:id => m, :text => ConferenceCoAuthor.find(m).co_author, :email => ConferenceCoAuthor.find(m).email}
|
||||||
|
{:id => m, :text => ConferenceCoAuthor.find(m).co_author}
|
||||||
|
end
|
||||||
|
}
|
||||||
|
author_name.to_json
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
class PersonalResearchIntro < PersonalPluginIntro
|
||||||
|
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,87 @@
|
||||||
|
# encoding: utf-8
|
||||||
|
|
||||||
|
class Research
|
||||||
|
include Mongoid::Document
|
||||||
|
include Mongoid::Timestamps
|
||||||
|
include Mongoid::MultiParameterAttributes
|
||||||
|
|
||||||
|
include OrbitModel::LanguageRestrict
|
||||||
|
include OrbitModel::Status
|
||||||
|
include OrbitTag::Taggable
|
||||||
|
|
||||||
|
LANGUAGE_TYPES = [ "English", "Chinese" ]
|
||||||
|
|
||||||
|
|
||||||
|
field :research_title, localize: true
|
||||||
|
field :authors, localize: true
|
||||||
|
field :extracted_chapters, localize: true
|
||||||
|
|
||||||
|
# has_and_belongs_to_many :tags, :class_name => "PersonalResearchTag"
|
||||||
|
|
||||||
|
field :year
|
||||||
|
field :language
|
||||||
|
field :publish_date , :type => Date
|
||||||
|
field :keywords
|
||||||
|
field :url
|
||||||
|
field :note
|
||||||
|
field :create_user_id, :type => BSON::ObjectId
|
||||||
|
field :update_user_id, :type => BSON::ObjectId
|
||||||
|
|
||||||
|
paginates_per 10
|
||||||
|
|
||||||
|
has_many :research_files, :autosave => true, :dependent => :destroy
|
||||||
|
|
||||||
|
accepts_nested_attributes_for :research_files, :allow_destroy => true
|
||||||
|
|
||||||
|
# before_save :clean_checkboxs
|
||||||
|
|
||||||
|
validates :research_title, :at_least_one => true
|
||||||
|
|
||||||
|
before_validation :add_http
|
||||||
|
|
||||||
|
after_save :save_research_files
|
||||||
|
|
||||||
|
validates :url, :format => /^(http|https):\/\/(([a-z0-9]+([\-\.]{1}[a-z0-9]+)*\.[a-z]{2,5})|((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?))(:[0-9]{1,5})?(\/.*)?/i, :unless => Proc.new{self.url.blank?}
|
||||||
|
|
||||||
|
def self.search( category_id = nil )
|
||||||
|
|
||||||
|
if category_id.to_s.size > 0
|
||||||
|
|
||||||
|
find(:all, :conditions => {research_category_id: category_id}).desc( :is_top, :title )
|
||||||
|
|
||||||
|
else
|
||||||
|
|
||||||
|
find(:all).desc( :is_top, :title)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
def self.widget_datas
|
||||||
|
|
||||||
|
where( :is_hidden => false ).desc(:is_top, :created_at)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
def save_research_files
|
||||||
|
self.research_files.each do |t|
|
||||||
|
if t.should_destroy
|
||||||
|
t.destroy
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
protected
|
||||||
|
|
||||||
|
def add_http
|
||||||
|
unless self.url.blank? || self.url[/^http:\/\//] || self.url[/^https:\/\//]
|
||||||
|
self.url = 'http://' + self.url
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def clean_checkboxs
|
||||||
|
self.tagged_ids.delete('')
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,14 @@
|
||||||
|
class ResearchFile
|
||||||
|
|
||||||
|
include Mongoid::Document
|
||||||
|
include Mongoid::Timestamps
|
||||||
|
|
||||||
|
mount_uploader :file, AssetUploader
|
||||||
|
|
||||||
|
field :description, localize: true
|
||||||
|
field :should_destroy, :type => Boolean
|
||||||
|
field :title, localize: true
|
||||||
|
|
||||||
|
belongs_to :research
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,3 @@
|
||||||
|
<div class="filter-clear">
|
||||||
|
<%= link_to content_tag(:i, nil, :class => 'icons-cycle') + t(:clear), panel_personal_research_back_end_researchs_path(:filter => @filter, :sort => params[:sort], :direction => params[:direction], :clear => true, :type => type), :class => "btn js_history" %>
|
||||||
|
</div>
|
|
@ -0,0 +1,9 @@
|
||||||
|
<div class="table-label">
|
||||||
|
<div id="sort_headers" class="table-label">
|
||||||
|
<%= render 'sort_headers' %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<%= javascript_include_tag "sort_header" %>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,6 @@
|
||||||
|
<div class="accordion-inner" data-toggle="buttons-checkbox">
|
||||||
|
<% @tags.each do |tag| -%>
|
||||||
|
<%= link_to tag.name, panel_personal_research_back_end_researchs_path(:filter => @filter, :new_filter => {:type => 'tags', :id => tag.id}, :sort => params[:sort], :direction => params[:direction], :sort_options => params[:sort_options]), :class => "btn js_history#{is_filter_active?('tags', tag.id)}" %>
|
||||||
|
<% end -%>
|
||||||
|
</div>
|
||||||
|
<%= render :partial => 'clear_filters', :locals => {:type => 'tags'} %>
|
|
@ -0,0 +1,262 @@
|
||||||
|
<% # 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/file-type" %>
|
||||||
|
<%= javascript_include_tag "lib/module-area" %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<%= f.error_messages %>
|
||||||
|
|
||||||
|
<!-- 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></li>
|
||||||
|
<li class="active">
|
||||||
|
<a href="#basic" data-toggle="tab"><%= t(:basic) %></a>
|
||||||
|
</li>
|
||||||
|
<% if show_form_status_field(@research) %>
|
||||||
|
<li>
|
||||||
|
<a href="#status" data-toggle="tab"><%= t(:status) %></a>
|
||||||
|
</li>
|
||||||
|
<% end %>
|
||||||
|
<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">
|
||||||
|
|
||||||
|
<% if !params[:user_id].blank? %>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("personal_plugins.author") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= User.from_id(params[:user_id]).name rescue ''%>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<!-- year -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.year") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= select_year((@research.year ? @research.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'research[year]',:class => 'span1'} ) %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- publish_date -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.publication_date") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.date_select :publish_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year, :month], :discard_day => true }, {:class => 'span1'} %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- url -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.url") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_field :url , :class => "span6" %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- keywords -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.keywords") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_field :keywords %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- language -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.language") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.radio_button :language, "Chinese" %> <%= t("personal_research.Chinese") %>
|
||||||
|
<%= f.radio_button :language, "English" %> <%= t("personal_research.English") %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- note -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.note") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_area :note, rows: 2, class: "input-block-level" %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Status Module -->
|
||||||
|
<% if show_form_status_field(@research) %>
|
||||||
|
<div class="tab-pane fade" id="status">
|
||||||
|
|
||||||
|
<!-- Status -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t(:status) %></label>
|
||||||
|
<div class="controls" data-toggle="buttons-checkbox">
|
||||||
|
<label class="checkbox inline btn <%= 'active' if @research.is_hidden? %>">
|
||||||
|
<%= f.check_box :is_hidden %> <%= t(:hide) %>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<!-- Tag Module -->
|
||||||
|
<div class="tab-pane fade" id="tag">
|
||||||
|
|
||||||
|
<!-- Tag -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t(:tags) %></label>
|
||||||
|
<div class="controls" data-toggle="buttons-checkbox">
|
||||||
|
<% @tags.each do |tag| %>
|
||||||
|
<label class="checkbox inline btn <%= 'active' if @research.tag_ids.include?(tag.id) %>">
|
||||||
|
<%= check_box_tag 'research[tag_ids][]', tag.id, @research.tag_ids.include?(tag.id) %> <%= tag.name %>
|
||||||
|
<%= hidden_field_tag 'research[tag_ids][]', '' %>
|
||||||
|
</label>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Language Tabs -->
|
||||||
|
<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 %>"><%= I18nVariable.from_locale(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" : '' %>">
|
||||||
|
|
||||||
|
<!-- research_title-->
|
||||||
|
<div class="control-group input-title">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.research_title") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.fields_for :research_title_translations do |f| %>
|
||||||
|
<%= f.text_field locale, class: "input-block-level", placeholder: t("personal_research.research_title"), value: (@research.research_title_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- extracted_chapters-->
|
||||||
|
<div class="control-group input-title">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.extracted_chapters") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.fields_for :extracted_chapters_translations do |f| %>
|
||||||
|
<%= f.text_field locale, class: "input-block-level", placeholder: t("personal_research.extracted_chapters"), value: (@research.extracted_chapters_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- authors-->
|
||||||
|
<div class="control-group input-title">
|
||||||
|
<label class="control-label muted"><%= t("personal_research.authors") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.fields_for :authors_translations do |f| %>
|
||||||
|
<%= f.text_field locale, class: "input-block-level", placeholder: t("personal_research.authors"), value: (@research.authors_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<!-- File -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t(:file_) %></label>
|
||||||
|
<div class="controls">
|
||||||
|
|
||||||
|
<!-- Exist -->
|
||||||
|
<% if @research && !@research.research_files.blank? %>
|
||||||
|
<div class="exist">
|
||||||
|
<% @research.research_files.each_with_index do |research_file, i| %>
|
||||||
|
<%= f.fields_for :research_files, research_file do |f| %>
|
||||||
|
<%= render :partial => 'form_file', :object => research_file, :locals => {:f => f, :i => i} %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
<hr>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<!-- Add -->
|
||||||
|
<div class="add-target">
|
||||||
|
</div>
|
||||||
|
<p class="add-btn">
|
||||||
|
<%= hidden_field_tag 'plugin_file_field_count', @research.research_files.count %>
|
||||||
|
<a id="add_file" class="trigger btn btn-small btn-primary"><i class="icons-plus"></i> <%= t(:add) %></a>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Form Actions -->
|
||||||
|
<div class="form-actions">
|
||||||
|
<%= f.hidden_field :user_id, :value => params[:user_id] if !params[:user_id].blank? %>
|
||||||
|
<%= f.submit t('submit'), class: 'btn btn-primary' %>
|
||||||
|
<%= link_to t('cancel'), get_go_back, :class=>"btn" %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<script>
|
||||||
|
$(document).ready(function() {
|
||||||
|
$('.main-forms .add-on').tooltip();
|
||||||
|
$(document).on('click', '#add_file', function(){
|
||||||
|
var new_id = $(this).prev().attr('value');
|
||||||
|
var old_id = new RegExp("new_research_files", "g");
|
||||||
|
var on = $('.language-nav li.active').index();
|
||||||
|
var le = $(this).parent('.add-btn').prev('.add-target').children('.start-line').length;
|
||||||
|
$(this).prev().attr('value', parseInt(new_id) + 1);
|
||||||
|
$(this).parent().siblings('.add-target').append(("<%= escape_javascript(add_attribute 'form_file', f, :research_files) %>").replace(old_id, new_id));
|
||||||
|
$(this).parent('.add-btn').prev('.add-target').children('.start-line').eq(le).children('.input-append').find('.tab-content').each(function() {
|
||||||
|
$(this).children('.tab-pane').eq(on).addClass('in active').siblings().removeClass('in active');
|
||||||
|
});
|
||||||
|
formTip();
|
||||||
|
});
|
||||||
|
$(document).on('click', '.delete_file', function(){
|
||||||
|
$(this).parents('.input-prepend').remove();
|
||||||
|
});
|
||||||
|
$(document).on('click', '.remove_existing_record', function(){
|
||||||
|
if(confirm("<%= I18n.t(:sure?)%>")){
|
||||||
|
$(this).children('.should_destroy').attr('value', 1);
|
||||||
|
$(this).parents('.start-line').hide();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,45 @@
|
||||||
|
<% if form_file.new_record? %>
|
||||||
|
<div class="fileupload fileupload-new start-line" data-provides="fileupload">
|
||||||
|
<% else %>
|
||||||
|
<div class="fileupload fileupload-exist start-line" data-provides="fileupload">
|
||||||
|
<% if form_file.file.blank? %>
|
||||||
|
<%= t(:no_file) %>
|
||||||
|
<% else %>
|
||||||
|
<%= link_to content_tag(:i) + form_file.file_identifier, form_file.file.url, {:class => 'file-link file-type', :target => '_blank', :title => form_file.file_identifier} %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
<div class="input-prepend input-append">
|
||||||
|
<label>
|
||||||
|
<span class="add-on btn btn-file" title='<%= t(:file_) %>'>
|
||||||
|
<i class="icons-paperclip"></i>
|
||||||
|
<%= f.file_field :file %>
|
||||||
|
</span>
|
||||||
|
<div class="uneditable-input input-medium">
|
||||||
|
<i class="icon-file fileupload-exists"></i>
|
||||||
|
<span class="fileupload-preview"><%= (form_file.new_record? || form_file.file.blank?) ? t(:select_file) : t(:change_file) %></span>
|
||||||
|
</div>
|
||||||
|
</label>
|
||||||
|
<span class="add-on icons-pencil" title='<%= t(:alternative) %>'></span>
|
||||||
|
<span class="tab-content">
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<span class="tab-pane fade <%= ( i == 0 ) ? "in active" : '' %> <%= locale %>">
|
||||||
|
<%= f.fields_for :title_translations do |f| %>
|
||||||
|
<%= f.text_field locale, :class => "input-medium", placeholder: t(:alternative), :value => (form_file.title_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</span>
|
||||||
|
<% end %>
|
||||||
|
</span>
|
||||||
|
</span>
|
||||||
|
<% if form_file.new_record? %>
|
||||||
|
<span class="delete_file add-on btn" title="<%= t(:delete_) %>">
|
||||||
|
<a class="icon-trash"></a>
|
||||||
|
</span>
|
||||||
|
<% else %>
|
||||||
|
<span class="remove_existing_record add-on btn" title="<%= t(:remove) %>">
|
||||||
|
<%= f.hidden_field :id %>
|
||||||
|
<a class="icon-remove"></a>
|
||||||
|
<%= f.hidden_field :_destroy, :value => nil, :class => 'should_destroy' %>
|
||||||
|
</span>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,17 @@
|
||||||
|
<tr id="<%= dom_id research %>" class="with_action">
|
||||||
|
<td class="span1"><%= research.publish_date.strftime("%Y.%m") %></td>
|
||||||
|
<td class="span1">
|
||||||
|
<%= link_to research.research_title , panel_personal_research_front_end_research_path(research) %>
|
||||||
|
<div class="quick-edit">
|
||||||
|
<ul class="nav nav-pills hide">
|
||||||
|
<%if at_least_module_manager || research.research_category.cur_user_is_sub_manager_of(:edit)%>
|
||||||
|
<li><%= link_to t('edit'), edit_panel_personal_research_back_end_research_path(research) %></li>
|
||||||
|
<li><%= link_to t(:delete_), panel_personal_research_back_end_research_path(research), :confirm => t('sure?'), :method => :delete, :remote => true %></li>
|
||||||
|
<% end -%>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<td class="span1"><%= research.url %></td>
|
||||||
|
<td class="span1"><%= User.from_id(research.create_user_id).name rescue ''%></td>
|
||||||
|
</tr>
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
$("#<%= dom_id @research %>").remove();
|
|
@ -0,0 +1,15 @@
|
||||||
|
<% content_for :side_bar do %>
|
||||||
|
<%= render :partial => 'layouts/side_bar', :locals => {:link_name => t(:user), :link_url => admin_site_site_info_path(@site), :icon => 'icons-users', :side_bar_content => 'admin/users_new_interface/side_bar'} %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<div class="subnav">
|
||||||
|
|
||||||
|
<%= render :partial => 'admin/plugins/plugin_list' %>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<%= form_for @research, url: panel_personal_research_back_end_research_path(@research), html: {class: "form-horizontal main-forms previewable"} do |f| %>
|
||||||
|
<fieldset>
|
||||||
|
<%= render partial: 'form', locals: {f: f} %>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,34 @@
|
||||||
|
<% content_for :side_bar do %>
|
||||||
|
<%= render :partial => 'layouts/side_bar', :locals => {:link_name => t(:user), :link_url => admin_site_site_info_path(@site), :icon => 'icons-users', :side_bar_content => 'admin/users_new_interface/side_bar'} %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<div class="subnav">
|
||||||
|
|
||||||
|
<%= render :partial => 'admin/plugins/plugin_list' %>
|
||||||
|
|
||||||
|
<%= render 'filter' %>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<table class="table main-list">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="span1"><%= t('personal_research.publication_date') %></th>
|
||||||
|
<th class="span3"><%= t('personal_research.research_title') %></th>
|
||||||
|
<th class="span2"><%= t('personal_research.url') %></th>
|
||||||
|
<th class="span1"><%= t("personal_plugins.author") %></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody id="tbody_researchs" class="sort-holder">
|
||||||
|
<%= render :partial => 'research', :collection => @researchs %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<div class="bottomnav clearfix">
|
||||||
|
<div class="action pull-right">
|
||||||
|
<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t('announcement.add_new'), new_panel_personal_research_back_end_research_path, :class => 'btn btn-primary pull-right' %>
|
||||||
|
</div>
|
||||||
|
<div class="pagination pagination-centered">
|
||||||
|
<%= paginate @researchs, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,3 @@
|
||||||
|
$("#sort_headers").html("<%= j render 'sort_headers' %>");
|
||||||
|
$("#tbody_researchs").html("<%= j render :partial => 'research', :collection => @researchs %>");
|
||||||
|
$("#research_pagination").html("<%= j paginate @researchs, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>");
|
|
@ -0,0 +1,15 @@
|
||||||
|
<% content_for :side_bar do %>
|
||||||
|
<%= render :partial => 'layouts/side_bar', :locals => {:link_name => t(:user), :link_url => admin_site_site_info_path(@site), :icon => 'icons-users', :side_bar_content => 'admin/users_new_interface/side_bar'} %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<div class="subnav">
|
||||||
|
|
||||||
|
<%= render :partial => 'admin/plugins/plugin_list' %>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<%= form_for @research, url: panel_personal_research_back_end_researchs_path, html: {class: "form-horizontal main-forms previewable"} do |f| %>
|
||||||
|
<fieldset>
|
||||||
|
<%= render partial: 'form', locals: {f: f} %>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,3 @@
|
||||||
|
$("#enable_<%= @bulletin.id %>").toggle();
|
||||||
|
$("#disable_<%= @bulletin.id %>").toggle();
|
||||||
|
$("#bulletin_<%= @bulletin.id %>").toggleClass('disable');
|
|
@ -0,0 +1,103 @@
|
||||||
|
<div class="toolbar hh1">
|
||||||
|
<div class="fn_g hp">
|
||||||
|
|
||||||
|
<%= f.submit t("save"), name: "commit", class: "fn_btn ini_input hp hh1 thmc2 thmtxt" %>
|
||||||
|
<% if not @research.new_record? %>
|
||||||
|
<%= submit_tag t("cancel"), :type => "button", "callback-method"=>"cancelresearch", "ajax-remote" => "get", :href => panel_personal_research_desktop_personal_researchs_path, class: "fn_btn ini_input hp hh1 admbg2 admtxt" %>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1 ">Language</div>
|
||||||
|
<div class="admbg sdm_o language_select">
|
||||||
|
<ul>
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<li><a class="hp hh1 admtxt" href="" data-lang="<%= locale %>"><%= I18nVariable.from_locale(locale) %></a></li>
|
||||||
|
<% end %>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1"><span class="icon-question-sign"></span></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="overview" content-layout="simple" base-width="420">
|
||||||
|
<ul class="s_form" isotope="true">
|
||||||
|
<li class="s_grid_row">
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<% style = locale != I18n.locale.to_s ? 'style=display:none;' : "" %>
|
||||||
|
<% data = "data-language=" + locale %>
|
||||||
|
<div class="form_fix" <%= style %> <%= data %>>
|
||||||
|
<%= f.fields_for :research_title_translations do |f| %>
|
||||||
|
<%= f.text_field locale,
|
||||||
|
size: "20",
|
||||||
|
placeholder: t("personal_research.research_title")+ "("+I18nVariable.from_locale(locale)+")",
|
||||||
|
class: "s_grid_12 s_grid",
|
||||||
|
value: (@research.research_title_translations[locale.to_s] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<%= f.fields_for :extracted_chapters_translations do |f| %>
|
||||||
|
<%= f.text_field locale,
|
||||||
|
size: "20",
|
||||||
|
placeholder: t("personal_research.extracted_chapters")+ "("+I18nVariable.from_locale(locale)+")",
|
||||||
|
class: "s_grid_12 s_grid",
|
||||||
|
value: (@research.extracted_chapters_translations[locale.to_s] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
</li>
|
||||||
|
<li class="s_grid_row">
|
||||||
|
<%= label_tag("", t("personal_research.publication_date"), class: "s_grid_4 s_grid") %>
|
||||||
|
<%= f.date_select :publish_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year] }, {:class => 's_grid_4 s_grid'} %>
|
||||||
|
<%= f.date_select :publish_date, {:use_month_numbers => true, :order => [:month, :day] }, {:class => 's_grid_2 s_grid'} %>
|
||||||
|
</li>
|
||||||
|
<li class="s_grid_row">
|
||||||
|
<%= label_tag("", t("personal_research.url"), class: "s_grid_4 s_grid") %><%= f.text_field :url, size: "20", class: "s_grid_8 s_grid"%>
|
||||||
|
</li>
|
||||||
|
<li class="s_grid_row">
|
||||||
|
<%= f.text_area :keywords, size: "20x3", placeholder: t("personal_research.keywords"), class: "s_grid_12 s_grid_h_2 s_grid"%>
|
||||||
|
</li>
|
||||||
|
<li class="s_grid_row">
|
||||||
|
<%= f.label :language, t("personal_research.language"), :class => "s_grid s_grid_4" %>
|
||||||
|
<%= f.select :language, Research::LANGUAGE_TYPES,{} ,{:class => "s_grid s_grid_8"} %>
|
||||||
|
</li>
|
||||||
|
<li class="s_grid_row">
|
||||||
|
<%= f.text_area :note, size: "20x3", placeholder: t("personal_research.note"), class: "s_grid_12 s_grid s_grid_h_3 s_grid_h_full"%>
|
||||||
|
</li>
|
||||||
|
|
||||||
|
<li class="s_grid_row">
|
||||||
|
<table class="s_table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="s_grid_2"><%= t("personal_research.file")%></th>
|
||||||
|
<th class="s_grid_4"><%= t("personal_research.file_name")%></th>
|
||||||
|
<th class="s_grid_4"><%= t("personal_research.description") %></th>
|
||||||
|
<th class="s_grid_2"></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tfoot>
|
||||||
|
<tr>
|
||||||
|
<td colspan="4">
|
||||||
|
<div id='add_plugin_file' class="info_input plugin_files_block s_action">
|
||||||
|
<%= hidden_field_tag 'plugin_file_field_count', @research.research_files.count %>
|
||||||
|
<a class="add setting_btn thmc1 thmtxt w1 hh1 hp" href="#"><i class="icon-plus icon-white"></i> add</a>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tfoot>
|
||||||
|
<tbody>
|
||||||
|
<% @research.research_files.each_with_index do |research_file, i| %>
|
||||||
|
<%= f.fields_for :research_files, research_file do |f| %>
|
||||||
|
<%= render :partial => 'form_file', :object => research_file, :locals => {:f => f, :i => i} %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<script>
|
||||||
|
var get_html = function(old_id,new_id){
|
||||||
|
return ("<%= escape_javascript(add_attribute 'form_file', f, :research_files) %>").replace(old_id, new_id);
|
||||||
|
}
|
||||||
|
</script>
|
|
@ -0,0 +1,50 @@
|
||||||
|
<tr id="<%= "plugin_file_#{form_file.id}" if !form_file.new_record? %>" class="list_item">
|
||||||
|
<td>
|
||||||
|
<div>
|
||||||
|
<% if form_file.new_record? %>
|
||||||
|
<%= f.file_field :file, class: "s_grid_2", onchange:"var temp = o.filepathSplitter(this.value);temp=temp[temp.length - 1];this.parentNode.getElementsByTagName('label')[0].innerHTML = temp;var inputs = this.parentNode.parentNode.parentNode.getElementsByClassName('title_field');inputs[0].value = temp;inputs[1].value = temp;" %>
|
||||||
|
<label></label>
|
||||||
|
<% else %>
|
||||||
|
<%= link_to(image_tag(check_file_type(form_file.file.url)),
|
||||||
|
form_file.file.url,
|
||||||
|
:class => "file",
|
||||||
|
"target" => "_blank",
|
||||||
|
"title" => form_file.title) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<% style = locale != I18n.locale.to_s ? 'style=display:none;' : "" %>
|
||||||
|
<% data = "data-language=" + locale %>
|
||||||
|
<td <%= style %> <%= data %>>
|
||||||
|
<%= f.fields_for :file_title_translations do |f| %>
|
||||||
|
<%= f.text_field locale,
|
||||||
|
class: 's_grid_4 title_field',
|
||||||
|
placeholder: I18nVariable.from_locale(locale),
|
||||||
|
value: (form_file.file_title_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</td>
|
||||||
|
|
||||||
|
<td <%= style %> <%= data %>>
|
||||||
|
<%= f.fields_for :file_description_translations do |f| %>
|
||||||
|
<%= f.text_field locale,
|
||||||
|
class: 's_grid_4',
|
||||||
|
placeholder: I18nVariable.from_locale(locale),
|
||||||
|
value: (form_file.file_description_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</td>
|
||||||
|
<% end %>
|
||||||
|
<td>
|
||||||
|
<span class="action">
|
||||||
|
<% if form_file.new_record? %>
|
||||||
|
<a class="delete"><i class="icon-remove" style="cursor:pointer;"></i></a>
|
||||||
|
<% else %>
|
||||||
|
<%= f.hidden_field :id %>
|
||||||
|
<a class="remove_existing_record" style="cursor:pointer;"><i class="icon-remove"></i></a>
|
||||||
|
<%= f.hidden_field :should_destroy, :value => nil, :class => 'should_destroy' %>
|
||||||
|
<% end %>
|
||||||
|
<%= form_file.file.file ? ( link_to '', form_file.file.url, {:class => 'icon-eye-open', :target => '_blank', :title => t(:view)} ) : '' %>
|
||||||
|
</span>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
<%= form_for @research, html: { multipart: true, "form-type"=>"ajax_form", "callback-method"=>"formCallback"}, url: panel_personal_research_desktop_personal_research_path(@research) do |f| %>
|
||||||
|
<%= render partial: 'form', locals: {:f => f} %>
|
||||||
|
<%end%>
|
|
@ -0,0 +1,70 @@
|
||||||
|
<div class="toolbar hh1">
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1"><span class="icon-check"></span></div>
|
||||||
|
<div class="admbg sdm_o">
|
||||||
|
<ul id="journal_selection_options">
|
||||||
|
<li><a class="hp hh1 admtxt" href="all" ajax-remote="false" callback-method="allnone">All</a></li>
|
||||||
|
<li><a class="hp hh1 admtxt" href="none" ajax-remote="false" callback-method="allnone">None</a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1">More</div>
|
||||||
|
<div class="admbg sdm_o">
|
||||||
|
<ul>
|
||||||
|
<li><a class="hp hh1 admtxt" href="">Delete</a></li>
|
||||||
|
<li><a class="hp hh1 admtxt" href="">Tag</a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1">Tag</div>
|
||||||
|
<div class="admbg sdm_o">
|
||||||
|
<ul>
|
||||||
|
<li><a class="hp hh1 admtxt" href="">All</a></li>
|
||||||
|
<li><a class="hp hh1 admtxt" href="">Starred</a></li>
|
||||||
|
<li><a class="hp hh1 admtxt" href="">MIT</a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1">Status</div>
|
||||||
|
<div class="admbg sdm_o">
|
||||||
|
<ul>
|
||||||
|
<li><a class="hp hh1 admtxt" href="">All</a></li>
|
||||||
|
<li><a class="hp hh1 admtxt" href="">Published</a></li>
|
||||||
|
<li><a class="hp hh1 admtxt" href="">Pending</a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1">View</div>
|
||||||
|
<div class="admbg sdm_o">
|
||||||
|
<ul id="journal_view_selection">
|
||||||
|
<li><%= link_to "Title", panel_personal_research_desktop_personal_researchs_path + "?view=research_title", :class => "hp hh1 admtxt", "ajax-remote" => "get" %></li>
|
||||||
|
<li><%= link_to "Extracted Chapters", panel_personal_research_desktop_personal_researchs_path + "?view=extracted_chapters", :class => "hp hh1 admtxt", "ajax-remote" => "get" %></li>
|
||||||
|
<li><%= link_to "File", panel_personal_research_desktop_personal_researchs_path + "?view=file", :class => "hp hh1 admtxt", "ajax-remote" => "get" %></li>
|
||||||
|
<li><%= link_to "Keywords", panel_personal_research_desktop_personal_researchs_path + "?view=keywords", :class => "hp hh1 admtxt", "ajax-remote" => "get" %></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1">Share</div>
|
||||||
|
<div class="admbg sdm_o share_mode" data-link="<%= data_share_panel_personal_research_back_end_researchs_path %>" data-var="disable" >
|
||||||
|
<ul>
|
||||||
|
<li><a class="hp hh1 admtxt" href="" item-class="private" data-mode="true" >Private</a></li>
|
||||||
|
<li><a class="hp hh1 admtxt" href="" item-class="public" data-mode="false" >Public</a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1"><span class="icon-question-sign"></span></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="overview" page-name="research_list" content-layout="simple" base-width="300" per-column="<%= @per_column.to_s %>" pagination-var="view=<%= @view_by %>&page" >
|
||||||
|
<ul isotope="true">
|
||||||
|
<% @researches.each do |w| %>
|
||||||
|
<%= publication_record w, @view_by%>
|
||||||
|
<% end %>
|
||||||
|
</ul>
|
||||||
|
</div>
|
|
@ -0,0 +1,3 @@
|
||||||
|
<%= form_for @research, html: { multipart: true, "form-type"=>"ajax_form", "callback-method"=>"formCallback"}, url: panel_personal_research_desktop_personal_researchs_path do |f| %>
|
||||||
|
<%= render partial: 'form', locals: {:f => f} %>
|
||||||
|
<%end%>
|
|
@ -0,0 +1,36 @@
|
||||||
|
<%= stylesheet_link_tag "/assets/personal_research/desktop/personal_research" %>
|
||||||
|
<%= javascript_include_tag "personal_research/desktop/personal_research" %>
|
||||||
|
<div id="personal_research">
|
||||||
|
<div id="content">
|
||||||
|
<div id="header" class="hh2">
|
||||||
|
<div class="dtitle w2 hh2 hp">
|
||||||
|
<span class="thmtxth">Research</span>
|
||||||
|
</div>
|
||||||
|
<div id="search_app" class="hfn w2 hh1 hp thmc3">
|
||||||
|
<input type="text" class="ini_input form" value="Search" id="searchbox" />
|
||||||
|
<input type="submit" class="ini_input submit thmc1" value="Submit"/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="holder">
|
||||||
|
<div id="panel_l" class="ph">
|
||||||
|
<div class="s_menu sm_v" content-type="menu">
|
||||||
|
<ul id='setting_left_nav'>
|
||||||
|
<li><a href="<%= panel_personal_research_desktop_personal_researchs_path %>" callback-method="list" class="hh1 w2 hp active thmc1 thmtxt" load="true" onclick='return false;'>List</a></li>
|
||||||
|
<li><a href="<%= new_panel_personal_research_desktop_personal_research_path %>" callback-method="addresearch" class="admtxt hh1 w2 hp" onclick='return false;'>Add/Edit</a></li>
|
||||||
|
<li><a href="<%= panel_personal_research_desktop_plugin_intros_path %>" class="admtxt hh1 w2 hp" callback-method="brief" onclick='return false;'>Brief Info</a></li>
|
||||||
|
<!-- <li><a href="" class="admtxt hh1 w2 hp" onclick='return false;'>Books</a></li>
|
||||||
|
<li><a href="" class="admtxt hh1 w2 hp" onclick='return false;'>Co-Authors</a></li>
|
||||||
|
<li><a href="" class="admtxt hh1 w2 hp" onclick='return false;'>Tags & Keywords</a></li>
|
||||||
|
<li><a href="" class="admtxt hh1 w2 hp" onclick='return false;'>Analysis</a></li>
|
||||||
|
<li><a href="" class="admtxt hh1 w2 hp" onclick='return false;'>Import</a></li>
|
||||||
|
<li><a href="" class="admtxt hh1 w2 hp" onclick='return false;'>Export</a></li> -->
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="panel_r" container="true" class="ph pw admbg hp">
|
||||||
|
</div>
|
||||||
|
<div class="clear"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,54 @@
|
||||||
|
<div class="toolbar hh1">
|
||||||
|
<div class="fn_g hp">
|
||||||
|
|
||||||
|
<%= f.submit t("save"), name: "commit", class: "fn_btn ini_input hp hh1 thmc2 thmtxt" %>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1 ">Language</div>
|
||||||
|
<div class="admbg sdm_o language_select">
|
||||||
|
<ul>
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<li><a class="hp hh1 admtxt" href="" data-lang="<%= locale %>"><%= I18nVariable.from_locale(locale) %></a></li>
|
||||||
|
<% end %>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="hh1 hp sdm">
|
||||||
|
<div class="sdm_t hh1"><span class="icon-question-sign"></span></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="overview" content-layout="simple">
|
||||||
|
<ul class="s_form">
|
||||||
|
<li class="s_grid_row">
|
||||||
|
<%= label_tag("", "Frontend Page", :class => 's_grid s_grid_4') %>
|
||||||
|
<div class="s_select_g s_grid s_grid_8 s_grid_h_2">
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
<%= f.check_box :brief_intro,
|
||||||
|
id: "field-0" %>
|
||||||
|
<label for="field-0"> Brief Intro </label>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<%= f.check_box :complete_list,
|
||||||
|
id: "field-1" %>
|
||||||
|
<label for="field-1"> Complete List </label>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<% style = locale != I18n.locale.to_s ? 'style=display:none;' : "" %>
|
||||||
|
<% data = "data-language=" + locale %>
|
||||||
|
<li class="s_grid_row" <%= style %> <%= data %>>
|
||||||
|
<%= label_tag("", I18nVariable.from_locale(locale), :class => 's_grid s_grid_4') %>
|
||||||
|
</li>
|
||||||
|
<li class="s_grid_row" <%= style %> <%= data %>>
|
||||||
|
<%= f.fields_for :text_translations do |f| %>
|
||||||
|
<%= f.text_area locale, :class=>"editor", rows: 5, :value => (@intro.text_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</li>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
|
||||||
|
</ul>
|
||||||
|
</div>
|
|
@ -0,0 +1,3 @@
|
||||||
|
<%= form_for @intro, html: { multipart: true, "form-type"=>"ajax_form","notification"=>"Brief Intro Updated"}, url: panel_personal_research_desktop_plugin_intro_path(@intro) do |f| %>
|
||||||
|
<%= render partial: 'form', locals: {:f => f} %>
|
||||||
|
<%end%>
|
|
@ -0,0 +1,3 @@
|
||||||
|
<%= form_for @intro, html: { multipart: true, "form-type"=>"ajax_form", "notification"=>"Brief Intro Saved"}, url: panel_personal_research_desktop_plugin_intros_path do |f| %>
|
||||||
|
<%= render partial: 'form', locals: {f: f} %>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,48 @@
|
||||||
|
<%
|
||||||
|
if @member
|
||||||
|
|
||||||
|
@researchs = Research.where(is_hidden: false, :create_user_id => @member.id).desc(:publish_date)
|
||||||
|
|
||||||
|
@research_intro = !PersonalResearchIntro.where(:user_id => @member.id).blank? ? PersonalResearchIntro.where(:user_id => @member.id).first : PersonalResearchIntro.new
|
||||||
|
%>
|
||||||
|
|
||||||
|
<% if @research_intro.brief_intro and !@research_intro.blank? %>
|
||||||
|
|
||||||
|
<div class="info">
|
||||||
|
<%= @research_intro.text.html_safe rescue '' %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% if ( !@research_intro.blank? and @research_intro.complete_list ) or @research_intro.blank? %>
|
||||||
|
|
||||||
|
<% if !@researchs.blank? %>
|
||||||
|
|
||||||
|
<table class="table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="grid2"><%= t('personal_research.publication_date') %></th>
|
||||||
|
<th class="grid10"><%= t('personal_research.research_title') %></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
<% @researchs.each do |research| %>
|
||||||
|
|
||||||
|
<tr>
|
||||||
|
<td><%= research.publish_date.strftime("%Y.%m") %></td>
|
||||||
|
<td>
|
||||||
|
<%= link_to research.research_title, panel_personal_research_front_end_research_path(research) %>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% end %>
|
|
@ -0,0 +1,34 @@
|
||||||
|
<% # encoding: utf-8 %>
|
||||||
|
|
||||||
|
<%= flash_messages %>
|
||||||
|
|
||||||
|
<h1><%= t('module_name.personal_research') %></h1>
|
||||||
|
|
||||||
|
|
||||||
|
<table class="table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="grid2"><%= t('personal_research.publication_date') %></th>
|
||||||
|
<th class="grid10"><%= t('personal_research.research_title') %></th>
|
||||||
|
<th class="grid10"><%= t('personal_research.authors') %></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
<% @researchs.each do |research| %>
|
||||||
|
|
||||||
|
<tr>
|
||||||
|
<td><%= research.publish_date.strftime("%Y.%m") %></td>
|
||||||
|
<td>
|
||||||
|
<%= link_to research.research_title, panel_personal_research_front_end_research_path(research) %>
|
||||||
|
</td>
|
||||||
|
<td><%= "#{User.from_id(research.create_user_id).name rescue ''},#{research.authors rescue ''}"%></td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
|
||||||
|
<%= paginate @researchs, :params => {:inner => false}%>
|
|
@ -0,0 +1,47 @@
|
||||||
|
<% # encoding: utf-8 %>
|
||||||
|
|
||||||
|
<table>
|
||||||
|
<caption> <%= t("module_name.personal_research") %> </caption>
|
||||||
|
<tbody>
|
||||||
|
<% if !@research.year.blank? %>
|
||||||
|
<tr><th><%= t("personal_research.year")%></th><td><%= @research.year %></td></tr>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% if !@research.language.blank? %>
|
||||||
|
<tr><th><%= t("personal_research.language")%></th><td><%= @research.language %></td></tr>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% if !@research.research_title.blank? %>
|
||||||
|
<tr><th><%= t("personal_research.research_title")%></th><td><%= @research.research_title %></td></tr>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% if !@research.extracted_chapters.blank? %>
|
||||||
|
<tr><th><%= t("personal_research.extracted_chapters")%></th><td><%= @research.extracted_chapters %></td></tr>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% if !@research.publish_date.blank? %>
|
||||||
|
<tr><th><%= t("personal_research.publication_date")%></th><td><%= @research.publish_date %></td></tr>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% if !@research.url.blank? %>
|
||||||
|
<tr><th><%= t("personal_research.url")%></th><td><%= link_to t(:url), @research.url, {:target => '_blank', :title => @research.url} if !@research.url.blank? %></td></tr>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<tr><th><%= t("personal_research.authors")%></th><td><%= "#{User.from_id(@research.create_user_id).name rescue ''},#{@research.authors rescue ''}"%></td></tr>
|
||||||
|
|
||||||
|
<% if @research.research_files.size > 0 %>
|
||||||
|
<tr><th><%= t("personal_research.file")%></th>
|
||||||
|
<td>
|
||||||
|
<div>
|
||||||
|
<div class="showFile">
|
||||||
|
<i class="icons-paperclip"></i>
|
||||||
|
<% @research.research_files.each do | wjfile | %>
|
||||||
|
<%= link_to wjfile.title, wjfile.file.url, {:target => '_blank', :title => wjfile.title} if wjfile.file.file %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
|
@ -0,0 +1,96 @@
|
||||||
|
<% content_for :page_specific_css do %>
|
||||||
|
<%= stylesheet_link_tag "lib/list-check" %>
|
||||||
|
<% end %>
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<%= javascript_include_tag "lib/list-check" %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<%
|
||||||
|
@filter = params[:filter]
|
||||||
|
new_filter = params[:new_filter]
|
||||||
|
|
||||||
|
if @filter && params[:clear]
|
||||||
|
@filter.delete(params[:type])
|
||||||
|
elsif @filter && new_filter
|
||||||
|
if @filter.has_key?(new_filter[:type]) && @filter[new_filter[:type]].include?(new_filter[:id].to_s)
|
||||||
|
@filter[new_filter[:type]].delete(new_filter[:id].to_s)
|
||||||
|
elsif @filter.has_key?(new_filter[:type])
|
||||||
|
@filter[new_filter[:type]] << new_filter[:id].to_s
|
||||||
|
else
|
||||||
|
@filter.merge!({new_filter[:type] => [new_filter[:id].to_s]})
|
||||||
|
end
|
||||||
|
elsif new_filter
|
||||||
|
@filter = {new_filter[:type] => [new_filter[:id].to_s]}
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
if @user && is_admin?
|
||||||
|
@researchs = Research.where(:create_user_id => @user.id).desc(:publish_date).page(params[:page]).per(10)
|
||||||
|
else
|
||||||
|
@researchs = Research.where(is_hidden: false, :create_user_id => @user.id).desc(:publish_date).page(params[:page]).per(10)
|
||||||
|
end
|
||||||
|
|
||||||
|
%>
|
||||||
|
|
||||||
|
<% if is_admin? %>
|
||||||
|
<div class="list-active">
|
||||||
|
<div class="btn-group">
|
||||||
|
<%= link_to('Hide', '#', :class => "btn btn-mini list-active-btn disabled", "data-check-action" => "list-be-hide", :rel => data_share_panel_personal_research_back_end_researchs_path(:user_id => params[:id], :disable => 'true') ) %>
|
||||||
|
<%= link_to('Show', '#', :class => "btn btn-mini list-active-btn disabled", "data-check-action" => "list-be-show", :rel => data_share_panel_personal_research_back_end_researchs_path(:user_id => params[:id], :disable => 'false') ) %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<% end -%>
|
||||||
|
|
||||||
|
<table class="table table-condensed table-striped">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<% if is_admin? %>
|
||||||
|
<th><input type="checkbox" class="list-check" /></th>
|
||||||
|
<% end -%>
|
||||||
|
<th class="span2"><%= t('personal_research.publication_date') %></th>
|
||||||
|
<th><%= t('personal_research.research_title') %></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
<% @researchs.each do |research| %>
|
||||||
|
|
||||||
|
<tr class="<%= research.is_hidden ? "checkHide" : "" %>">
|
||||||
|
<% if is_admin? %>
|
||||||
|
<td>
|
||||||
|
<%= check_box_tag 'to_change[]', research.id.to_s, false, :class => "list-check" %>
|
||||||
|
</td>
|
||||||
|
<% end -%>
|
||||||
|
<td><%= research.publish_date.strftime("%Y.%m") %></td>
|
||||||
|
<td>
|
||||||
|
<%= link_to research.research_title, panel_personal_research_front_end_research_path(research) %>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<% if is_admin? %>
|
||||||
|
<div class="bottomnav clearfix">
|
||||||
|
<div class="action pull-right">
|
||||||
|
<%= link_to content_tag(:i, nil, :class => 'icon-plus') + t('personal_plugins.edit_brief_intro'), panel_personal_research_back_end_personal_research_intros_path(:user_id => @user.id), :class => 'btn btn-primary' %>
|
||||||
|
<%= link_to content_tag(:i, nil, :class => 'icon-plus') + t('announcement.add_new'), new_panel_personal_research_back_end_research_path(:user_id => @user.id), :class => 'btn btn-primary' %>
|
||||||
|
</div>
|
||||||
|
<div class="pagination pagination-centered">
|
||||||
|
<%= paginate @researchs, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<div id="dialog" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="Delete item" aria-hidden="true">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
|
||||||
|
<h3><%= t(:sure?) %></h3>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button class="btn" data-dismiss="modal" aria-hidden="true"><%= t(:close) %></button>
|
||||||
|
<button class="delete-item btn btn-danger"><%= t(:submit) %></button>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,11 @@
|
||||||
|
<div id="filter" class="subnav">
|
||||||
|
<div class="filters">
|
||||||
|
<div id="sort_headers" class="table-label">
|
||||||
|
<%= render 'sort_headers' %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<%= javascript_include_tag "sort_header" %>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,183 @@
|
||||||
|
<% # encoding: utf-8 %>
|
||||||
|
|
||||||
|
<%= f.error_messages %>
|
||||||
|
|
||||||
|
<!--Widget start-->
|
||||||
|
|
||||||
|
<div id="sub-wiget">
|
||||||
|
|
||||||
|
<div id="widget-tags" class="widget-box widget-size-300">
|
||||||
|
<div class="widget-action clear tip" title="Setting">
|
||||||
|
<a class="action"><i class="icon-cog icon-white"></i></a>
|
||||||
|
</div>
|
||||||
|
<h3 class="widget-title"><i class="icons-tag"></i>Tags</h3>
|
||||||
|
<div class="widget-content clear form-horizontal">
|
||||||
|
<% @tags.each do |tag| %>
|
||||||
|
<%= content_tag :label,:class => "checkbox inline" do -%>
|
||||||
|
<%= check_box_tag 'research[tag_ids][]', tag.id, @research.tag_ids.include?(tag.id)%>
|
||||||
|
<%= tag.name %>
|
||||||
|
<%= hidden_field_tag 'research[tag_ids][]', '' %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<!--Wiget End-->
|
||||||
|
<!--Post Start-->
|
||||||
|
|
||||||
|
<div id="post-body">
|
||||||
|
<div id="post-body-content" class="clear">
|
||||||
|
|
||||||
|
<div class="title">
|
||||||
|
<%= f.label :year ,t("personal_research.year")%>
|
||||||
|
<%= select_year((@research.year ? @research.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'research[year]'} ) %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<ul class="nav nav-tabs">
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
<li <%= ( i == 0 ) ? "class=active" : '' %>><a data-toggle="tab" href=".<%= locale %>"><%= I18nVariable.from_locale(locale) %></a></li>
|
||||||
|
<% end %>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<div class="tab-content">
|
||||||
|
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
|
||||||
|
<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
|
||||||
|
<div class="title">
|
||||||
|
<%= f.label :research_title ,t("personal_research.research_title")%>
|
||||||
|
<%= f.fields_for :research_title_translations do |f| %>
|
||||||
|
<%= I18nVariable.from_locale(locale) %>
|
||||||
|
<%= f.text_field locale, :class=>'post-title', :value => (@research.research_title_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="title">
|
||||||
|
<%= f.label :extracted_chapters ,t("personal_research.extracted_chapters")%>
|
||||||
|
<%= f.fields_for :extracted_chapters_translations do |f| %>
|
||||||
|
<%= I18nVariable.from_locale(locale) %>
|
||||||
|
<%= f.text_field locale, :class=>'post-title', :value => (@research.extracted_chapters_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="title">
|
||||||
|
<%= f.label :authors,t("web_resource.authors") %>
|
||||||
|
<%= f.fields_for :authors_translations do |f| %>
|
||||||
|
<%= I18nVariable.from_locale(locale) %>
|
||||||
|
<%= f.text_area locale, :size => "60x3", :value => (@research.authors_translations[locale] rescue nil) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="title">
|
||||||
|
<%= f.label :publish_date ,t("personal_research.publish_date")%>
|
||||||
|
<%= f.date_select :publish_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year, :month], :discard_day => true }, {:class => 'span1'} %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="title">
|
||||||
|
<%= f.label :url, t("personal_research.url") %>
|
||||||
|
<%= f.text_field :url %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="title">
|
||||||
|
<%= f.label :keywords, t("personal_research.keywords") %>
|
||||||
|
<%= f.text_field :keywords %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="title">
|
||||||
|
<%= f.label :language, t("personal_research.language") %>
|
||||||
|
<%= f.radio_button :language, "Chinese" %> <%= t("personal_research.Chinese") %>
|
||||||
|
<%= f.radio_button :language, "English" %> <%= t("personal_research.English") %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="title">
|
||||||
|
<%= f.label :note, t("personal_research.note") %>
|
||||||
|
<%= f.text_area :note, :size => "60x3" %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<div>
|
||||||
|
|
||||||
|
<div id='plugin_files' class="plugin_files_block">
|
||||||
|
|
||||||
|
<table class="table table-condensed">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>File</th>
|
||||||
|
<th>File Name</th>
|
||||||
|
<th class="span1"></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tfoot>
|
||||||
|
<tr>
|
||||||
|
<td style="text-align:center" colspan="3">
|
||||||
|
<div id='add_plugin_file' class="info_input plugin_files_block">
|
||||||
|
<%= hidden_field_tag 'plugin_file_field_count', @research.research_files.count %>
|
||||||
|
<a class="add"><span class="btn btn-primary btn-small"><i class="icon-plus icon-white"></i> ADD/新增</span></a>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
|
</tfoot>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
<% @research.research_files.each_with_index do |research_file, i| %>
|
||||||
|
<%= f.fields_for :research_files, research_file do |f| %>
|
||||||
|
<%= render :partial => 'form_file', :object => research_file, :locals => {:f => f, :i => i} %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Post End-->
|
||||||
|
|
||||||
|
|
||||||
|
<div class="form-actions">
|
||||||
|
<%= f.submit t('submit'), :class=>'btn btn-primary' %>
|
||||||
|
<%= link_to t('cancel'), get_go_back, :class=>"btn" %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<%= javascript_include_tag "archive_plugin_form" %>
|
||||||
|
<script>
|
||||||
|
$('#add_plugin_file a.add').live('click', function(){
|
||||||
|
var new_id = $(this).prev().attr('value');
|
||||||
|
var old_id = new RegExp("new_add_plugin_files", "g");
|
||||||
|
$(this).prev().attr('value', parseInt(new_id) + 1);
|
||||||
|
$(this).parents('table').append(("<%= escape_javascript(add_attribute 'form_file', f, :research_files) %>").replace(old_id, new_id));
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.add_plugin_files_block a.delete').live('click', function(){
|
||||||
|
$(this).parents('.list_item').remove();
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.action a.remove_existing_record').live('click', function(){
|
||||||
|
$(this).next('.should_destroy').attr('value', 1);
|
||||||
|
$("tr#add_plugin_file_" + $(this).prev().attr('value')).hide();
|
||||||
|
});
|
||||||
|
|
||||||
|
</script>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,50 @@
|
||||||
|
<% # encoding: utf-8 %>
|
||||||
|
|
||||||
|
<tr id="<%= "plugin_file_#{form_file.id}" if !form_file.new_record? %>" class='list_item'>
|
||||||
|
<td>
|
||||||
|
<div class="control-group">
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.file_field :file %>
|
||||||
|
<%= form_file.file.file ? ( link_to t(:view), form_file.file.url, {:class => 'btn', :target => '_blank', :title => t(:view)} ) : '' %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
|
||||||
|
<div class="tab-content">
|
||||||
|
|
||||||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||||||
|
|
||||||
|
<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
|
||||||
|
<%#= f.fields_for :i18n_variable, (form_file.new_record? ? form_file.build_i18n_variable : form_file.i18n_variable ) do |f| %>
|
||||||
|
<%= f.fields_for :file_title_translations do |f| %>
|
||||||
|
<div class="control-group">
|
||||||
|
<label for="link-<%= locale %>" class="control-label"><%= I18nVariable.from_locale(locale) %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_field locale, :class=>'post-file_title', :value => (form_file.file_title_translations[locale] rescue nil) %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</td>
|
||||||
|
|
||||||
|
<td>
|
||||||
|
<span class="action">
|
||||||
|
<% if form_file.new_record? %>
|
||||||
|
<a class="delete"><i class="icon-remove"></i></a>
|
||||||
|
<% else %>
|
||||||
|
<%= f.hidden_field :id %>
|
||||||
|
<a class="remove_existing_record"><i class="icon-remove"></i></a>
|
||||||
|
<%= f.hidden_field :should_destroy, :value => nil, :class => 'should_destroy' %>
|
||||||
|
<% end %>
|
||||||
|
</span>
|
||||||
|
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
<tr id="<%= dom_id research %>" class="with_action">
|
||||||
|
<td>
|
||||||
|
<% if (research.create_user_id == current_user.id) || is_manager? %>
|
||||||
|
<%= check_box_tag 'to_delete[]', research.id, false, :class => "checkbox_in_list" %>
|
||||||
|
<% end -%>
|
||||||
|
</td>
|
||||||
|
<td><%= research.publish_date.strftime("%Y.%m") %></td>
|
||||||
|
<td>
|
||||||
|
<%= link_to research.research_title , panel_personal_research_front_end_research_path(research) %>
|
||||||
|
<div class="quick-edit">
|
||||||
|
<ul class="nav nav-pills hide">
|
||||||
|
<%if at_least_module_manager || research.research_category.cur_user_is_sub_manager_of(:edit)%>
|
||||||
|
<li><%= link_to t('edit'), edit_panel_personal_research_plugin_research_path(research) %></li>
|
||||||
|
<li><%= link_to t(:delete_), panel_personal_research_plugin_research_path(research), :confirm => t('sure?'), :method => :delete, :remote => true %></li>
|
||||||
|
<% end -%>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<td><%= research.url %></td>
|
||||||
|
</tr>
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
<%= render_sort_bar(true, delete_panel_personal_research_back_end_researchs_path(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options]),
|
||||||
|
['publish_date', 'publish_date', 'span1', 'research.publish_date'],
|
||||||
|
['research_title', 'research_title','span3', 'research.research_title'],
|
||||||
|
['url', 'url','span3', 'research.url']).html_safe %>
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
$("#<%= dom_id @research %>").remove();
|
|
@ -0,0 +1,5 @@
|
||||||
|
<h1><%= t('personal_research.editing_personal_research') %></h1>
|
||||||
|
|
||||||
|
<%= form_for @research, :url => panel_personal_research_plugin_research_path(@research), :html => {:class => 'clear'} do |f| %>
|
||||||
|
<%= render :partial => 'form', :locals => {:f => f} %>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,22 @@
|
||||||
|
<%= render 'filter' %>
|
||||||
|
<table class="table main-list">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="span1"></th>
|
||||||
|
<th class="span1"></th>
|
||||||
|
<th class="span2"></th>
|
||||||
|
<th class="span3"></th>
|
||||||
|
<th class="span2"></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody id="tbody_researchs" class="sort-holder">
|
||||||
|
<%= render :partial => 'research', :collection => @researchs %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<div class="form-actions form-fixed pagination-right">
|
||||||
|
<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t('announcement.add_new'), new_panel_personal_research_plugin_research_path, :class => 'btn btn-primary pull-right' %>
|
||||||
|
<div id="research_pagination" class="paginationFixed">
|
||||||
|
<%= paginate @researchs, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,3 @@
|
||||||
|
$("#sort_headers").html("<%= j render 'sort_headers' %>");
|
||||||
|
$("#tbody_researchs").html("<%= j render :partial => 'research', :collection => @researchs %>");
|
||||||
|
$("#research_pagination").html("<%= j paginate @researchs, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>");
|
|
@ -0,0 +1,10 @@
|
||||||
|
|
||||||
|
<%= flash_messages %>
|
||||||
|
<div id="poststuff">
|
||||||
|
<h1><%= t('research.new_personal_research') %></h1>
|
||||||
|
<%= form_for @research, :url => panel_personal_research_plugin_researchs_path, :html => {:class => 'clear'} do |f| %>
|
||||||
|
<%= render :partial => 'form', :locals => {:f => f} %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<%#= link_back %>
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
$("#enable_<%= @bulletin.id %>").toggle();
|
||||||
|
$("#disable_<%= @bulletin.id %>").toggle();
|
||||||
|
$("#bulletin_<%= @bulletin.id %>").toggleClass('disable');
|
|
@ -0,0 +1,53 @@
|
||||||
|
en:
|
||||||
|
module_name:
|
||||||
|
personal_research: Research Project
|
||||||
|
personal_research:
|
||||||
|
paper_title : "Paper Title"
|
||||||
|
research_title : "Research Title"
|
||||||
|
extracted_chapters : "Extracted Chapters"
|
||||||
|
publishers : "Publishers"
|
||||||
|
authors : "Authors"
|
||||||
|
tags : "Tags"
|
||||||
|
year : "Year"
|
||||||
|
language : "Language"
|
||||||
|
isbn : "ISSN(ISBN)"
|
||||||
|
vol_no : "Vol.No"
|
||||||
|
issue_no : "Issue.No"
|
||||||
|
form_to_start : "From"
|
||||||
|
form_to_end : "To"
|
||||||
|
total_pages : "Total Pages"
|
||||||
|
keywords : "Keywords"
|
||||||
|
abstract : "Abstract"
|
||||||
|
publication_date : "Date of Publication"
|
||||||
|
url : "Reference URL"
|
||||||
|
note : "Note"
|
||||||
|
level_type : "Level Type"
|
||||||
|
author_type : "Author Type"
|
||||||
|
from : "From"
|
||||||
|
to : "To"
|
||||||
|
file : "File"
|
||||||
|
file_name : "File name"
|
||||||
|
description : "File Description"
|
||||||
|
pages : "Pages"
|
||||||
|
book_paper_type : "Book Paper Type"
|
||||||
|
frontend:
|
||||||
|
researchs: "Research Front-end"
|
||||||
|
|
||||||
|
create_success : "Successfully Create"
|
||||||
|
update_success : "Successfully Update"
|
||||||
|
delete_success : "Successfully Delete"
|
||||||
|
add: "Add"
|
||||||
|
back: "Back"
|
||||||
|
delete: "Delete"
|
||||||
|
edit: "Edit"
|
||||||
|
nothing: "Nothing"
|
||||||
|
show: "Show"
|
||||||
|
sure?: "Are you sure?"
|
||||||
|
update: "Update"
|
||||||
|
yes_: "Yes"
|
||||||
|
no_: "No"
|
||||||
|
cancel : "Cancel"
|
||||||
|
save: "save"
|
||||||
|
hintText: "Type in a search term"
|
||||||
|
noResultsText: "No results"
|
||||||
|
searchingText: "Searching…"
|
|
@ -0,0 +1,53 @@
|
||||||
|
zh_tw:
|
||||||
|
module_name:
|
||||||
|
personal_research: 研究
|
||||||
|
personal_research:
|
||||||
|
paper_title : "論文名稱"
|
||||||
|
research_title : "名稱"
|
||||||
|
extracted_chapters : "摘要"
|
||||||
|
publishers : "Publishers"
|
||||||
|
authors : "作者"
|
||||||
|
tags : "領域"
|
||||||
|
year : "年度"
|
||||||
|
language : "語言"
|
||||||
|
isbn : "ISSN(ISBN)"
|
||||||
|
vol_no : "卷數"
|
||||||
|
issue_no : "期數"
|
||||||
|
form_to_start : "起"
|
||||||
|
form_to_end : "訖"
|
||||||
|
total_pages : "總頁數"
|
||||||
|
keywords : "關鍵字"
|
||||||
|
abstract : "摘要"
|
||||||
|
publication_date : "發表日期"
|
||||||
|
url : "參考連結"
|
||||||
|
note : "記事"
|
||||||
|
level_type : "期刊類別"
|
||||||
|
author_type : "作者類別"
|
||||||
|
from : "起"
|
||||||
|
to : "訖"
|
||||||
|
file : "檔案"
|
||||||
|
file_name : "檔案名稱"
|
||||||
|
description : "描述"
|
||||||
|
pages : "Pages"
|
||||||
|
book_paper_type : "Book Paper Type"
|
||||||
|
frontend:
|
||||||
|
researchs: "研究前台"
|
||||||
|
|
||||||
|
create_success : "新增完成!!"
|
||||||
|
update_success : "更新完成!!"
|
||||||
|
delete_success : "刪除成功!!"
|
||||||
|
add: "新增"
|
||||||
|
back: "返回"
|
||||||
|
delete: "刪除"
|
||||||
|
edit: "編輯"
|
||||||
|
nothing: "無"
|
||||||
|
show: "顯示"
|
||||||
|
sure?: "您肯定嗎?"
|
||||||
|
update: "更新"
|
||||||
|
yes_: "是"
|
||||||
|
no_: "否"
|
||||||
|
cancel : "取消"
|
||||||
|
save: "儲存"
|
||||||
|
hintText: "請輸入搜尋關鍵字"
|
||||||
|
noResultsText: "沒有相關的比對結果"
|
||||||
|
searchingText: "搜尋中…"
|
|
@ -0,0 +1,42 @@
|
||||||
|
Rails.application.routes.draw do
|
||||||
|
|
||||||
|
namespace :panel do
|
||||||
|
namespace :personal_research do
|
||||||
|
namespace :desktop do
|
||||||
|
match "research_window" => "personal_researchs#research_window"
|
||||||
|
resources :personal_researchs
|
||||||
|
resources :plugin_intros
|
||||||
|
end
|
||||||
|
namespace :back_end do
|
||||||
|
|
||||||
|
match 'research_setting' => "researchs#research_setting" ,:as => :research_setting
|
||||||
|
|
||||||
|
resources :researchs do
|
||||||
|
collection do
|
||||||
|
get 'delete'
|
||||||
|
get 'data_share'
|
||||||
|
end
|
||||||
|
|
||||||
|
match "tag_quick_add" => "researchs#tag_quick_add" ,:as => :tag_quick_add
|
||||||
|
match "tag_quick_edit" => "researchs#tag_quick_edit" ,:as => :tag_quick_edit
|
||||||
|
end
|
||||||
|
|
||||||
|
resources :personal_research_intros
|
||||||
|
resources :tags
|
||||||
|
end
|
||||||
|
namespace :front_end do
|
||||||
|
resources :researchs
|
||||||
|
end
|
||||||
|
namespace :plugin do
|
||||||
|
resources :researchs
|
||||||
|
end
|
||||||
|
namespace :widget do
|
||||||
|
match "researchs" => "researchs#index"
|
||||||
|
match "home_list" => "researchs#home_list"
|
||||||
|
match "reload_researchs" => "researchs#reload_researchs"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
match "/appfront/*path" => redirect("/panel/*path")
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
require "personal_research/engine"
|
||||||
|
|
||||||
|
module PersonalResearch
|
||||||
|
end
|
|
@ -0,0 +1,23 @@
|
||||||
|
module PersonalResearch
|
||||||
|
class Engine < Rails::Engine
|
||||||
|
initializer "personal_research" do
|
||||||
|
OrbitApp.registration "PersonalResearch",:type=> 'ModuleApp' do
|
||||||
|
module_label 'module_name.personal_research'
|
||||||
|
base_url File.expand_path File.dirname(__FILE__)
|
||||||
|
personal_plugin :enable => true, :sort_number => '20', :app_name=>"Research", :intro_app_name=>"PersonalResearchIntro",:path=>"panel/personal_research/plugin/profile",:front_path=>"panel/personal_research/front_end/profile",:admin_path=>"/panel/personal_research/back_end/researchs",:i18n=>'module_name.personal_research'
|
||||||
|
|
||||||
|
version "0.1"
|
||||||
|
organization "Rulingcom"
|
||||||
|
author "RD dep"
|
||||||
|
intro "I am intro"
|
||||||
|
update_info 'some update_info'
|
||||||
|
|
||||||
|
front_end do
|
||||||
|
app_page 'researchs' do
|
||||||
|
frontend_i18n "personal_research.frontend.researchs"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,3 @@
|
||||||
|
module PersonalResearch
|
||||||
|
VERSION = "0.0.1"
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
# desc "Explaining what the task does"
|
||||||
|
# task :personal_research do
|
||||||
|
# # Task goes here
|
||||||
|
# end
|
|
@ -0,0 +1,23 @@
|
||||||
|
$:.push File.expand_path("../lib", __FILE__)
|
||||||
|
|
||||||
|
# Maintain your gem's version:
|
||||||
|
require "personal_research/version"
|
||||||
|
|
||||||
|
# Describe your gem and declare its dependencies:
|
||||||
|
Gem::Specification.new do |s|
|
||||||
|
s.name = "personal_research"
|
||||||
|
s.version = PersonalResearch::VERSION
|
||||||
|
s.authors = ["RulingDigital"]
|
||||||
|
s.email = ["service@rulingcom.com"]
|
||||||
|
s.homepage = "http://www.rulingcom.com"
|
||||||
|
s.summary = ""
|
||||||
|
s.description = "Orbit PersonalResearch module"
|
||||||
|
|
||||||
|
s.files = Dir["{app,config,db,lib}/**/*"] + ["MIT-LICENSE", "Rakefile", "README.rdoc"]
|
||||||
|
s.test_files = Dir["test/**/*"]
|
||||||
|
|
||||||
|
# s.add_dependency "rails", "~> 3.1.8"
|
||||||
|
# s.add_dependency "jquery-rails"
|
||||||
|
|
||||||
|
s.add_development_dependency "sqlite3"
|
||||||
|
end
|
|
@ -0,0 +1,12 @@
|
||||||
|
{
|
||||||
|
"title": "personal_research",
|
||||||
|
"object": "research",
|
||||||
|
"version": "0.1",
|
||||||
|
"organization": "Rulingcom",
|
||||||
|
"author": "RD dep",
|
||||||
|
"intro": "A simple blog……",
|
||||||
|
"update_info": "Some info",
|
||||||
|
"create_date": "09-05-2012",
|
||||||
|
"enable_frontend": true,
|
||||||
|
"has_plugin": true
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
#!/usr/bin/env ruby.exe
|
||||||
|
#!/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.
|
||||||
|
|
||||||
|
ENGINE_PATH = File.expand_path('../..', __FILE__)
|
||||||
|
load File.expand_path('../../test/dummy/script/rails', __FILE__)
|
|
@ -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
|
|
@ -0,0 +1,9 @@
|
||||||
|
// This is a manifest file that'll be compiled into including all the files listed below.
|
||||||
|
// Add new JavaScript/Coffee code in separate files in this directory and they'll automatically
|
||||||
|
// be included in the compiled file accessible from http://example.com/assets/application.js
|
||||||
|
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
||||||
|
// the compiled file.
|
||||||
|
//
|
||||||
|
//= require jquery
|
||||||
|
//= require jquery_ujs
|
||||||
|
//= require_tree .
|
|
@ -0,0 +1,7 @@
|
||||||
|
/*
|
||||||
|
* This is a manifest file that'll automatically include all the stylesheets available in this directory
|
||||||
|
* and any sub-directories. 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 .
|
||||||
|
*/
|
|
@ -0,0 +1,3 @@
|
||||||
|
class ApplicationController < ActionController::Base
|
||||||
|
protect_from_forgery
|
||||||
|
end
|
|
@ -0,0 +1,2 @@
|
||||||
|
module ApplicationHelper
|
||||||
|
end
|
|
@ -0,0 +1,14 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Dummy</title>
|
||||||
|
<%= stylesheet_link_tag "application" %>
|
||||||
|
<%= javascript_include_tag "application" %>
|
||||||
|
<%= csrf_meta_tags %>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<%= yield %>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -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
|
|
@ -0,0 +1,45 @@
|
||||||
|
require File.expand_path('../boot', __FILE__)
|
||||||
|
|
||||||
|
require 'rails/all'
|
||||||
|
|
||||||
|
Bundler.require
|
||||||
|
require "personal_research"
|
||||||
|
|
||||||
|
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 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
|
||||||
|
|
|
@ -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__)
|
|
@ -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
|
|
@ -0,0 +1,5 @@
|
||||||
|
# Load the rails application
|
||||||
|
require File.expand_path('../application', __FILE__)
|
||||||
|
|
||||||
|
# Initialize the rails application
|
||||||
|
Dummy::Application.initialize!
|
|
@ -0,0 +1,30 @@
|
||||||
|
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
|
||||||
|
|
||||||
|
# Do not compress assets
|
||||||
|
config.assets.compress = false
|
||||||
|
|
||||||
|
# Expands the lines which load the assets
|
||||||
|
config.assets.debug = true
|
||||||
|
end
|
|
@ -0,0 +1,60 @@
|
||||||
|
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 Rails.root.join("public/assets")
|
||||||
|
# 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
|
||||||
|
|
||||||
|
# Use a different logger for distributed setups
|
||||||
|
# config.logger = 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
|
||||||
|
end
|
|
@ -0,0 +1,39 @@
|
||||||
|
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
|
||||||
|
|
||||||
|
# Use SQL instead of Active Record's schema dumper when creating the test 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
|
||||||
|
|
||||||
|
# Print deprecation notices to the stderr
|
||||||
|
config.active_support.deprecation = :stderr
|
||||||
|
end
|
|
@ -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,10 @@
|
||||||
|
# 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
|
|
@ -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
|
|
@ -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 = 'b792c5762056bbba452d7add125e012a983c701a8e3b32948c92bace3ce28f72ccb6af53d34b057d11193cf59678ed8e017a033b8329a40468b20ba6341a439b'
|
|
@ -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
|
|
@ -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
|
|
@ -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"
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue