Add Brief intro. for all personal plugins
Add Share Setting for Personal Plugins ( if have old data must be add default value "field: is_hidden => false " ) Apply New UI to Member Plugin Edit Page Personal Plugin Summary fix Academic Info. list fix
This commit is contained in:
		
							parent
							
								
									b487740035
								
							
						
					
					
						commit
						a067bcd304
					
				| 
						 | 
				
			
			@ -0,0 +1,105 @@
 | 
			
		|||
var ListCheck = function(element) {
 | 
			
		||||
  this.element = $(element);
 | 
			
		||||
  this.element.data('exists', true);
 | 
			
		||||
  if(this.element.context.parentNode.tagName == "TD") {
 | 
			
		||||
    this.elementWrap = $(this.element.context.parentNode);
 | 
			
		||||
    this.elementWrap.addClass('listCheck');
 | 
			
		||||
  } else if(this.element.context.parentNode.tagName == "TH") {
 | 
			
		||||
    this.elementWrap = $(this.element.context.parentNode);
 | 
			
		||||
    this.elementWrap.addClass('listCheckHead');
 | 
			
		||||
  }
 | 
			
		||||
  this.element.before('<i class="icon-check-empty" />');
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
$.fn.listCheck = function (callback) {
 | 
			
		||||
  this.each(function (i) {
 | 
			
		||||
      if(!$(this).data('exists')) {
 | 
			
		||||
         new ListCheck(this);
 | 
			
		||||
      };
 | 
			
		||||
  });
 | 
			
		||||
  this.on(clickEvent, function(e) {
 | 
			
		||||
    if($(this).prop('checked')) {
 | 
			
		||||
      $(this).siblings('i').addClass('icon-check').removeClass('icon-check-empty').closest('tr').addClass('checkHit');
 | 
			
		||||
    } else {
 | 
			
		||||
      $(this).siblings('i').addClass('icon-check-empty').removeClass('icon-check').closest('tr').removeClass('checkHit');
 | 
			
		||||
    };
 | 
			
		||||
    if ($(this).closest('.listCheckHead').length) {
 | 
			
		||||
      $('.listCheck .list-check').prop('checked', $(this).prop('checked'));
 | 
			
		||||
      if($(this).prop('checked')) {
 | 
			
		||||
        $('.listCheck i').addClass('icon-check').removeClass('icon-check-empty').closest('tr').addClass('checkHit');
 | 
			
		||||
      } else {
 | 
			
		||||
        $('.listCheck i').addClass('icon-check-empty').removeClass('icon-check').closest('tr').removeClass('checkHit');
 | 
			
		||||
      }
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    var _isCheck = $('tbody .list-check').filter(':checked').length,
 | 
			
		||||
        _defaultLength = $('tbody .list-check').length;
 | 
			
		||||
 | 
			
		||||
    if(_isCheck > 0 && _isCheck < _defaultLength) {
 | 
			
		||||
      $('.listCheckHead i').removeClass('icon-check-empty icon-check').addClass('icon-minus');
 | 
			
		||||
    } else if(!_isCheck) {
 | 
			
		||||
      $('.listCheckHead i').removeClass('icon-minus icon-check').addClass('icon-check-empty');
 | 
			
		||||
    } else {
 | 
			
		||||
      $('.listCheckHead i').removeClass('icon-check-empty icon-minus').addClass('icon-check');
 | 
			
		||||
    }
 | 
			
		||||
    _isCheck ? $('.list-active-btn').removeClass('disabled').data('actionable', true) : $('.list-active-btn').addClass('disabled').data('actionable', false);
 | 
			
		||||
  });
 | 
			
		||||
};
 | 
			
		||||
function clearCheck() {
 | 
			
		||||
  $('.list-check').each(function() {
 | 
			
		||||
    $(this).prop('checked', false);
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
function actionSuccess(e) {
 | 
			
		||||
  $("tbody .list-check").each(function() {
 | 
			
		||||
    switch(e) {
 | 
			
		||||
      case 'list-be-hide':
 | 
			
		||||
        $(this).filter(':checked').closest('tr').addClass('checkHide');
 | 
			
		||||
        break;
 | 
			
		||||
      case 'list-be-show':
 | 
			
		||||
        $(this).filter(':checked').closest('tr').removeClass('checkHide');
 | 
			
		||||
        break;
 | 
			
		||||
      case 'list-be-remove':
 | 
			
		||||
        $(this).filter(':checked').closest('tr').fadeOut(300, function() {
 | 
			
		||||
          $(this).remove();
 | 
			
		||||
        });
 | 
			
		||||
        break;
 | 
			
		||||
    };
 | 
			
		||||
    $('.list-check').siblings('i').removeAttr('class').addClass('icon-check-empty').closest('tr').removeClass('checkHit');
 | 
			
		||||
  });
 | 
			
		||||
  clearCheck();
 | 
			
		||||
}
 | 
			
		||||
$(function() {
 | 
			
		||||
  var $t = null,
 | 
			
		||||
      _data = null;
 | 
			
		||||
  clearCheck();
 | 
			
		||||
  $('.list-check').listCheck();
 | 
			
		||||
  $('.list-active-btn').data('actionable', false).on(clickEvent, function(e) {
 | 
			
		||||
    $t = $(this)
 | 
			
		||||
    _data = $(this).data()
 | 
			
		||||
    _data.actionable ? $('#dialog').modal('show') : "";
 | 
			
		||||
    e.preventDefault();
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  $("#dialog").on('show', function (e) {
 | 
			
		||||
    $(this).find('.delete-item').on(clickEvent, function() {
 | 
			
		||||
      var _v = [];
 | 
			
		||||
      $("tbody .list-check").each(function() {
 | 
			
		||||
        this.checked && _v.push("ids[]="+this.value)
 | 
			
		||||
      });
 | 
			
		||||
      var _t = $t.attr("rel");
 | 
			
		||||
      if(_t.indexOf("?") > -1) {
 | 
			
		||||
        $.ajax(_t + "&" + _v.join("&")).done(function() {
 | 
			
		||||
          actionSuccess(_data.checkAction)
 | 
			
		||||
        });
 | 
			
		||||
      } else {
 | 
			
		||||
        $.ajax(_t + "?" + _v.join("&")).done(function() {
 | 
			
		||||
          actionSuccess(_data.checkAction)
 | 
			
		||||
        });
 | 
			
		||||
      }
 | 
			
		||||
      $('#dialog').modal('hide');
 | 
			
		||||
      $('.list-active-btn').addClass('disabled').data('actionable', false);
 | 
			
		||||
      e.preventDefault();
 | 
			
		||||
    })
 | 
			
		||||
  });
 | 
			
		||||
});
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,28 @@
 | 
			
		|||
.table .listCheckHead,
 | 
			
		||||
.table .listCheck {
 | 
			
		||||
	width: 30px;
 | 
			
		||||
	vertical-align: middle;
 | 
			
		||||
	padding: 0 0 0 10px!important;
 | 
			
		||||
}
 | 
			
		||||
.listCheckHead .list-check,
 | 
			
		||||
.listCheck .list-check {
 | 
			
		||||
	position: absolute;
 | 
			
		||||
	margin: -12px 0 0 -1px;
 | 
			
		||||
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
 | 
			
		||||
	filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
 | 
			
		||||
	opacity: 0;
 | 
			
		||||
}
 | 
			
		||||
.listCheckHead i,
 | 
			
		||||
.listCheck i {
 | 
			
		||||
	display: block;
 | 
			
		||||
}
 | 
			
		||||
.checkHide td {
 | 
			
		||||
	background-color: #E6E6E6 !important;
 | 
			
		||||
	color: #B9B9B9;
 | 
			
		||||
}
 | 
			
		||||
.checkHide a {
 | 
			
		||||
	color: #B9B9B9;
 | 
			
		||||
}
 | 
			
		||||
.checkHit td {
 | 
			
		||||
	background-color: #FFFEDB !important;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -3,9 +3,9 @@
 | 
			
		|||
	color: #000;
 | 
			
		||||
	text-decoration: none;
 | 
			
		||||
	display: block;
 | 
			
		||||
	overflow: hidden;
 | 
			
		||||
	width: 100%;
 | 
			
		||||
	text-overflow: ellipsis;
 | 
			
		||||
	overflow: hidden;
 | 
			
		||||
	white-space: nowrap;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -364,6 +364,9 @@
 | 
			
		|||
#profile #module-navbar {
 | 
			
		||||
	margin-left: 10px;
 | 
			
		||||
}
 | 
			
		||||
#profile #module-navbar .navbar {
 | 
			
		||||
	margin-bottom: 15px;
 | 
			
		||||
}
 | 
			
		||||
#profile #member-module {
 | 
			
		||||
	margin-left: 360px;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -372,9 +375,13 @@
 | 
			
		|||
}
 | 
			
		||||
#profile #member-module #module-content .content {
 | 
			
		||||
	right: 10px;
 | 
			
		||||
	padding-bottom: 10px;
 | 
			
		||||
	outline: none;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#profile #member-module #module-content .list-active {
 | 
			
		||||
	padding-bottom: 8px;
 | 
			
		||||
	/*border-bottom: 1px solid #DDD;*/
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Responsive */
 | 
			
		||||
@media (max-width: 979px) {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -26,6 +26,9 @@
 | 
			
		|||
  margin-top: 4px;
 | 
			
		||||
  margin-left: 10px;
 | 
			
		||||
}
 | 
			
		||||
.topnav .btn-group {
 | 
			
		||||
  margin-left: 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Bottom Nav */
 | 
			
		||||
.bottomnav {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,83 @@
 | 
			
		|||
class Admin::PersonalPluginIntrosController < OrbitMemberController
 | 
			
		||||
     
 | 
			
		||||
  include OrbitControllerLib::DivisionForDisable
 | 
			
		||||
  
 | 
			
		||||
  before_filter :authenticate_user!
 | 
			
		||||
  before_filter :is_admin?
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
  def index
 | 
			
		||||
 | 
			
		||||
    get_types
 | 
			
		||||
    @plugin_intro = @types.where(:user_id => params[:user_id]).first
 | 
			
		||||
 | 
			
		||||
    if @plugin_intro.blank?
 | 
			
		||||
 | 
			
		||||
      @set_type = @types.new()
 | 
			
		||||
      @url = eval("panel_#{@app_type_name}_back_end_#{@app_type}s_path(:user_id=>params[:user_id])")
 | 
			
		||||
      @verb = :post
 | 
			
		||||
 | 
			
		||||
    else
 | 
			
		||||
 | 
			
		||||
      @set_type = @types.find(@plugin_intro.id)
 | 
			
		||||
      @url = polymorphic_path(["panel_#{@app_type_name}_back_end", @plugin_intro])
 | 
			
		||||
      @verb = :put
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  def show
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  def new
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
 | 
			
		||||
  def edit
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def create
 | 
			
		||||
    
 | 
			
		||||
	  get_types
 | 
			
		||||
	
 | 
			
		||||
    @plugin_intro = @types.new(params[:plugin_intro]) 
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      if @plugin_intro.save
 | 
			
		||||
        format.html { redirect_to(admin_users_new_interface_url(:id=>params[:plugin_intro][:user_id],:show_plugin_profile=>@reback_name)) }
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  def update
 | 
			
		||||
  
 | 
			
		||||
	  get_types
 | 
			
		||||
	
 | 
			
		||||
    @plugin_intro = @types.find(params[:id]) 
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
          
 | 
			
		||||
      if @plugin_intro.update_attributes(params[:plugin_intro])
 | 
			
		||||
        format.html { redirect_to(admin_users_new_interface_url(:id=>params[:plugin_intro][:user_id],:show_plugin_profile=>@reback_name)) }
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  def destroy
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  protected
 | 
			
		||||
  
 | 
			
		||||
  def get_types
 | 
			
		||||
    @types = @app_type.classify.constantize
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -98,9 +98,11 @@ class Admin::UsersNewInterfaceController <  OrbitMemberController
 | 
			
		|||
    
 | 
			
		||||
 | 
			
		||||
    if(!params[:show_plugin_profile].nil?)
 | 
			
		||||
      @right_partial = OrbitApp::Plugin::Registration.find_by_key(params[:show_plugin_profile]).profile_partial_path rescue 'plugin_summary'
 | 
			
		||||
      @right_partial = OrbitApp::Plugin::Registration.find_by_app_name(params[:show_plugin_profile]).profile_partial_path rescue 'plugin_summary'
 | 
			
		||||
      @plugin_app_name = OrbitApp::Plugin::Registration.find_by_app_name(params[:show_plugin_profile]).name rescue nil
 | 
			
		||||
    else
 | 
			
		||||
      @right_partial = "plugin_summary"
 | 
			
		||||
      @plugin_app_name = ''
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    # @user.attribute_values.each{|att_val|
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,28 @@
 | 
			
		|||
class PersonalPluginIntro
 | 
			
		||||
  
 | 
			
		||||
  include Mongoid::Document
 | 
			
		||||
  include Mongoid::Timestamps
 | 
			
		||||
  # include OrbitCoreLib::ObjectAuthable
 | 
			
		||||
  # include OrbitCoreLib::ObjectDisable
 | 
			
		||||
 | 
			
		||||
  # has_and_belongs_to_many :users
 | 
			
		||||
  belongs_to :user
 | 
			
		||||
 | 
			
		||||
  field :text, localize: true
 | 
			
		||||
  field :brief_intro, :type => Boolean, :default => false
 | 
			
		||||
  field :complete_list, :type => Boolean, :default => true
 | 
			
		||||
  
 | 
			
		||||
 | 
			
		||||
  def pp_object
 | 
			
		||||
    brief_intro
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def self.from_id(id)
 | 
			
		||||
    PersonalPluginIntro.find(id) rescue nil
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def self.is_localized?(field_name)
 | 
			
		||||
    self.fields[field_name.to_s].localized?
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -39,11 +39,14 @@ class User
 | 
			
		|||
 | 
			
		||||
  has_many :user_actions, :dependent => :destroy
 | 
			
		||||
  
 | 
			
		||||
  has_many :personal_plugin_intro
 | 
			
		||||
 | 
			
		||||
#  has_and_belongs_to_many :statuses
 | 
			
		||||
  has_and_belongs_to_many :roles
 | 
			
		||||
  has_and_belongs_to_many :sub_roles
 | 
			
		||||
  has_and_belongs_to_many :role_statuses
 | 
			
		||||
  has_and_belongs_to_many :role_categorys
 | 
			
		||||
 | 
			
		||||
  accepts_nested_attributes_for :attribute_values, :allow_destroy => true 
 | 
			
		||||
 | 
			
		||||
  before_create :initialize_desktop
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,117 @@
 | 
			
		|||
<% # encoding: utf-8 %>
 | 
			
		||||
 | 
			
		||||
<% 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 %>
 | 
			
		||||
 | 
			
		||||
<% 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" %>
 | 
			
		||||
<% end %>
 | 
			
		||||
 | 
			
		||||
<%= form_for(:plugin_intro, :url => @url, :method => @verb, html: {class: "form-horizontal main-forms previewable"} ) do |f| %>
 | 
			
		||||
 | 
			
		||||
<%= f.error_messages %>
 | 
			
		||||
 | 
			
		||||
<fieldset>
 | 
			
		||||
 | 
			
		||||
    <!-- Input Area -->
 | 
			
		||||
    <div class="input-area">
 | 
			
		||||
 | 
			
		||||
      <!-- Module Tabs --> 
 | 
			
		||||
      <div class="nav-name"><strong><%= I18n.t("module_name.#{@app_type_name}") %></strong></div>
 | 
			
		||||
      <ul class="nav nav-pills module-nav">
 | 
			
		||||
        <li></li>
 | 
			
		||||
        <li class="active">
 | 
			
		||||
          <a href="#basic" data-toggle="tab"><%= t(:basic) %></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 %>
 | 
			
		||||
 | 
			
		||||
          <!-- frontend_page -->
 | 
			
		||||
          <div class="control-group">
 | 
			
		||||
            <label class="control-label muted"><%= t("personal_plugins.frontend_page") %></label>
 | 
			
		||||
            <div class="controls">
 | 
			
		||||
                <%= f.check_box :brief_intro, :checked => @set_type.brief_intro %> <%= t("personal_plugins.brief_intro") %>
 | 
			
		||||
                <%= f.check_box :complete_list, :checked => @set_type.complete_list %> <%= t("personal_plugins.complete_list") %>
 | 
			
		||||
            </div>
 | 
			
		||||
          </div> 
 | 
			
		||||
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
      <!-- Language Tabs -->
 | 
			
		||||
      <div class="nav-name"><strong><%= t(:language) %></strong></div>
 | 
			
		||||
      <ul class="nav nav-pills language-nav">
 | 
			
		||||
        <% @site_valid_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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
        
 | 
			
		||||
          <div class="<%= locale %> tab-pane fade <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
 | 
			
		||||
            <!-- Content -->
 | 
			
		||||
            <div class="control-group input-content">
 | 
			
		||||
              <label class="control-label muted"><%= t(:content) %></label>
 | 
			
		||||
              <div class="controls">
 | 
			
		||||
                <div class="textarea">
 | 
			
		||||
                  <%= f.fields_for :text_translations do |f| %>
 | 
			
		||||
                    <%= f.cktext_area locale, rows: 5, class: "input-block-level", :value => (@set_type.text_translations[locale] rescue nil) %>
 | 
			
		||||
                  <% end %>
 | 
			
		||||
                </div>
 | 
			
		||||
              </div>
 | 
			
		||||
            </div>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
          </div>
 | 
			
		||||
 | 
			
		||||
        <% end %>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
       </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>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
</fieldset>
 | 
			
		||||
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -4,8 +4,8 @@
 | 
			
		|||
        <table class="table table-striped">
 | 
			
		||||
            <thead>
 | 
			
		||||
                <tr>
 | 
			
		||||
                                    <th>模組</th>
 | 
			
		||||
                                    <th class="span2">數量</th>
 | 
			
		||||
                    <th><%= t(:module) %></th>
 | 
			
		||||
                    <th class="span2"><%= t(:quantity) %></th>
 | 
			
		||||
                </tr>
 | 
			
		||||
            </thead>
 | 
			
		||||
        </table>
 | 
			
		||||
| 
						 | 
				
			
			@ -21,22 +21,22 @@
 | 
			
		|||
                <div class="overview">
 | 
			
		||||
                    <table class="table table-striped">
 | 
			
		||||
                        <tbody>
 | 
			
		||||
 | 
			
		||||
                            <% 
 | 
			
		||||
                                @plugins.each do |plugin| 
 | 
			
		||||
 | 
			
		||||
                                  if is_admin?
 | 
			
		||||
                                    @data = plugin.app_name.classify.constantize.where(:create_user_id=>@user.id).count
 | 
			
		||||
                                  else
 | 
			
		||||
                                    @data = plugin.app_name.classify.constantize.where(:is_hidden=>false , :create_user_id=>@user.id).count
 | 
			
		||||
                                  end
 | 
			
		||||
                            %>
 | 
			
		||||
                                <tr>
 | 
			
		||||
                                                <td>University</td>
 | 
			
		||||
                                                <td class="span2">2,304</td>
 | 
			
		||||
                                            </tr>
 | 
			
		||||
                                            <tr>
 | 
			
		||||
                                                <td>Master</td>
 | 
			
		||||
                                                <td class="span2">783</td>
 | 
			
		||||
                                            </tr>
 | 
			
		||||
                                            <tr>
 | 
			
		||||
                                                <td>Doctor</td>
 | 
			
		||||
                                                <td class="span2">45</td>
 | 
			
		||||
                                            </tr>
 | 
			
		||||
                                            <tr>
 | 
			
		||||
                                                <td>Staff</td>
 | 
			
		||||
                                                <td class="span2">62</td>
 | 
			
		||||
                                    <td><%= plugin.name %></td>
 | 
			
		||||
                                    <td class="span2"><%= @data %></td>
 | 
			
		||||
                                </tr>
 | 
			
		||||
                            <% end -%>   
 | 
			
		||||
 | 
			
		||||
                        </tbody>
 | 
			
		||||
                    </table>
 | 
			
		||||
                </div>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -5,7 +5,8 @@
 | 
			
		|||
<%= render :partial => "js_and_css"%>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<div id="filter" class="topnav clearfix">
 | 
			
		||||
<% content_for :right_nav do %>
 | 
			
		||||
 | 
			
		||||
  <div class="searchClear pull-left" style="clear: left;">
 | 
			
		||||
    <form action="" method="get">
 | 
			
		||||
      <%= text_field_tag 'mq',( params[:mq] ? params[:mq] : '' ), {:id=>'filter-input', :class => "search-query input-medium", :placeholder => 'Search'} %>
 | 
			
		||||
| 
						 | 
				
			
			@ -34,8 +35,8 @@
 | 
			
		|||
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
</div>
 | 
			
		||||
  
 | 
			
		||||
<% end %>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<div id="list-view">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -5,8 +5,9 @@
 | 
			
		|||
<%= render :partial => "js_and_css"%>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<div id="filter" class="topnav clearfix">
 | 
			
		||||
  <div class="searchClear pull-left">
 | 
			
		||||
<% content_for :right_nav do %>
 | 
			
		||||
 | 
			
		||||
  <div class="searchClear pull-left" style="clear: left;">
 | 
			
		||||
    <form action="" method="get">
 | 
			
		||||
      <%= text_field_tag 'mq',( params[:mq] ? params[:mq] : '' ), {:id=>'filter-input', :class => "search-query input-medium", :placeholder => 'Search'} %>
 | 
			
		||||
      <input type="hidden" name="at" id="at" value="<%= params[:at] %>" />
 | 
			
		||||
| 
						 | 
				
			
			@ -35,7 +36,8 @@
 | 
			
		|||
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
</div>
 | 
			
		||||
  
 | 
			
		||||
<% end %>
 | 
			
		||||
 | 
			
		||||
<div id="list-view">
 | 
			
		||||
	<ul id="member-abstract" class="clearfix">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -5,8 +5,9 @@
 | 
			
		|||
<%= render :partial => "js_and_css"%>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<div id="filter" class="topnav clearfix">
 | 
			
		||||
  <div class="searchClear pull-left">
 | 
			
		||||
<% content_for :right_nav do %>
 | 
			
		||||
 | 
			
		||||
  <div class="searchClear pull-left" style="clear: left;">
 | 
			
		||||
    <form action="" method="get">
 | 
			
		||||
      <%= text_field_tag 'mq',( params[:mq] ? params[:mq] : '' ), {:id=>'filter-input', :class => "search-query input-medium", :placeholder => 'Search'} %>
 | 
			
		||||
      <input type="hidden" name="at" id="at" value="<%= params[:at] %>" />
 | 
			
		||||
| 
						 | 
				
			
			@ -35,7 +36,8 @@
 | 
			
		|||
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
</div>
 | 
			
		||||
  
 | 
			
		||||
<% end %>
 | 
			
		||||
 | 
			
		||||
<div id="list-view">
 | 
			
		||||
	<ul id="member-card" class="clearfix">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -43,7 +43,7 @@
 | 
			
		|||
                  <div class="navbar">
 | 
			
		||||
                    <div class="navbar-inner">
 | 
			
		||||
                      <span class="brand">
 | 
			
		||||
                        <%= params[:show_plugin_profile].nil? ? t(:all_plugin_summary) : params[:show_plugin_profile] %>
 | 
			
		||||
                        <%= @plugin_app_name.nil? ? t(:all_plugin_summary) : @plugin_app_name %>
 | 
			
		||||
                      </span>
 | 
			
		||||
                      <ul class="nav pull-right">
 | 
			
		||||
                        <li class="divider-vertical"></li>
 | 
			
		||||
| 
						 | 
				
			
			@ -52,8 +52,8 @@
 | 
			
		|||
                          <ul class="dropdown-menu">
 | 
			
		||||
 | 
			
		||||
                            <% @plugins.each do |plugin| %>
 | 
			
		||||
                                <%= content_tag :li, :class=>(params[:show_plugin_profile] == plugin.name ? "active" : nil) do %>
 | 
			
		||||
                                    <%= link_to plugin.name, :show_plugin_profile => plugin.name %>
 | 
			
		||||
                                <%= content_tag :li, :class=>(params[:show_plugin_profile] == plugin.app_name ? "active" : nil) do %>
 | 
			
		||||
                                    <%= link_to plugin.name, :show_plugin_profile => plugin.app_name %>
 | 
			
		||||
                                <% end -%>    
 | 
			
		||||
                            <% end -%>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -23,8 +23,8 @@
 | 
			
		|||
	<section id="main-wrap">
 | 
			
		||||
    <div class="wrap-inner">
 | 
			
		||||
      <div id="filter" class="topnav clearfix">
 | 
			
		||||
        <ul class="breadcrumb">
 | 
			
		||||
          <li><a href="/orbit_4.0.1/admin/dashboards/dashboards.shtml">Dashboard</a> <span class="divider">/</span></li>
 | 
			
		||||
        <ul class="breadcrumb text-info pull-left">
 | 
			
		||||
          <li><a href="<%= admin_users_new_interface_index_path %>">Member</a> <span class="divider">/</span></li>
 | 
			
		||||
          <li class="active">All</li>
 | 
			
		||||
        </ul>
 | 
			
		||||
        <%= yield :right_nav %>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -331,6 +331,12 @@ en:
 | 
			
		|||
  password_confirmation: Password confirmation
 | 
			
		||||
  password_current: Current password
 | 
			
		||||
  pending: Pending
 | 
			
		||||
  personal_plugins:
 | 
			
		||||
    author : "Author"
 | 
			
		||||
    edit_brief_intro : "Edit Brief Intro."
 | 
			
		||||
    brief_intro : "Brief Intro."
 | 
			
		||||
    complete_list : "Complete List"
 | 
			
		||||
    frontend_page : "Frontend Page"
 | 
			
		||||
  picture: Picture
 | 
			
		||||
  placeholder: Field Hint
 | 
			
		||||
  plugins: Plugins
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -332,6 +332,12 @@ zh_tw:
 | 
			
		|||
  password_confirmation: 確認密碼
 | 
			
		||||
  password_current: 目前的密碼
 | 
			
		||||
  pending: 待審核
 | 
			
		||||
  personal_plugins:
 | 
			
		||||
    author : "著作人"
 | 
			
		||||
    edit_brief_intro : "編輯摘要"
 | 
			
		||||
    brief_intro : "摘要"
 | 
			
		||||
    complete_list : "完整列表"
 | 
			
		||||
    frontend_page : "前台呈現"
 | 
			
		||||
  picture: 圖片
 | 
			
		||||
  placeholder: 欄位提示文字
 | 
			
		||||
  plugins: 學術資訊
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -24,4 +24,4 @@ production:
 | 
			
		|||
  # password: <%= ENV['MONGOID_PASSWORD'] %>
 | 
			
		||||
  # database: <%= ENV['MONGOID_DATABASE'] %>
 | 
			
		||||
  <<: *defaults
 | 
			
		||||
  database: test_site
 | 
			
		||||
  database: test_site_new
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -14,6 +14,13 @@ module OrbitApp
 | 
			
		|||
            @@registrations << DataSheet.new(name,args,:base_path=>base_path)
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          def find_by_app_name(name)
 | 
			
		||||
            @@registrations.each{|t|
 | 
			
		||||
              return t if t.app_name == name
 | 
			
		||||
            }
 | 
			
		||||
            return nil
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          def find_by_key(key)
 | 
			
		||||
            @@registrations.each{|t|
 | 
			
		||||
              return t if t.name == key
 | 
			
		||||
| 
						 | 
				
			
			@ -46,6 +53,8 @@ module OrbitApp
 | 
			
		|||
          def initialize(name,partial=nil,*args ,&block)
 | 
			
		||||
            @base_path = args[0][:base_path]
 | 
			
		||||
            @name = partial[0][:i18n].nil? ? name : lambda{ I18n.t(partial[0][:i18n]) } 
 | 
			
		||||
            @app_name = partial[0][:app_name]
 | 
			
		||||
            @intro_app_name = partial[0][:intro_app_name]
 | 
			
		||||
            @partial_path = ''
 | 
			
		||||
            @front_partial_path = ''
 | 
			
		||||
            @admin_partial_path = ''
 | 
			
		||||
| 
						 | 
				
			
			@ -59,6 +68,14 @@ module OrbitApp
 | 
			
		|||
            block.arity < 1 ? instance_eval(&block) : block.call(self) if block_given?
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          def app_name
 | 
			
		||||
            return  @app_name
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          def intro_app_name
 | 
			
		||||
            return  @intro_app_name
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          def profile_partial_path
 | 
			
		||||
            return  @partial_path
 | 
			
		||||
          end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -33,7 +33,6 @@
 | 
			
		|||
                      else
 | 
			
		||||
                        @rodata = nil
 | 
			
		||||
                      end
 | 
			
		||||
                  end
 | 
			
		||||
 | 
			
		||||
                    if !@rodata.blank? and !@member.get_attribute_value(rf).get_value_by_locale(I18n.locale).blank?
 | 
			
		||||
                  %>
 | 
			
		||||
| 
						 | 
				
			
			@ -47,4 +46,7 @@
 | 
			
		|||
 | 
			
		||||
                  <% end -%>
 | 
			
		||||
                  
 | 
			
		||||
                <% end -%>
 | 
			
		||||
 | 
			
		||||
                <%= render :partial => 'show_sub_role',:collection=> @member.get_sub_roles_by_role(show_roles)%>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -46,33 +46,66 @@
 | 
			
		|||
     <%= show_avatar(@member) %>
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	<div class="member-module">
 | 
			
		||||
		<div class="module-nav">
 | 
			
		||||
			<ul>
 | 
			
		||||
				<% @plugins.each do |plugin| %>
 | 
			
		||||
				<%
 | 
			
		||||
				  @plugins.each do |plugin| 
 | 
			
		||||
 | 
			
		||||
				  @data = plugin.app_name.classify.constantize.where(is_hidden: false, :create_user_id=>@member.id)
 | 
			
		||||
				  @intro_data = plugin.intro_app_name.classify.constantize.where(:user_id=>@member.id).first
 | 
			
		||||
				%>
 | 
			
		||||
 | 
			
		||||
					<% if !@intro_data.blank? %>
 | 
			
		||||
 | 
			
		||||
						<% if !@intro_data.brief_intro.blank? or !@intro_data.complete_list.blank? %>
 | 
			
		||||
						  <li><a href="#<%= plugin.name %>"><%= plugin.name %></a></li>
 | 
			
		||||
						<% end %>
 | 
			
		||||
 | 
			
		||||
					<% else %>
 | 
			
		||||
 | 
			
		||||
						<% if !@data.blank? %>
 | 
			
		||||
						  <li><a href="#<%= plugin.name %>"><%= plugin.name %></a></li>
 | 
			
		||||
						<% end %>
 | 
			
		||||
 | 
			
		||||
					<% end %>
 | 
			
		||||
 | 
			
		||||
				<% end %>
 | 
			
		||||
			</ul>
 | 
			
		||||
		</div>
 | 
			
		||||
		<div class="module-content">
 | 
			
		||||
			<%
 | 
			
		||||
 | 
			
		||||
			  @plugins.each do |plugin|
 | 
			
		||||
 | 
			
		||||
				@plugin_partial = !plugin.front_partial_path.blank? ? OrbitApp::Plugin::Registration.find_by_key(plugin.name).front_partial_path : nil
 | 
			
		||||
 | 
			
		||||
				@data = plugin.app_name.classify.constantize.where(:create_user_id=>@member.id)
 | 
			
		||||
				@intro_data = plugin.intro_app_name.classify.constantize.where(:user_id=>@member.id).first
 | 
			
		||||
			%>
 | 
			
		||||
 | 
			
		||||
				<% if !@intro_data.blank? %>
 | 
			
		||||
 | 
			
		||||
					<% if !@intro_data.brief_intro.blank? or !@intro_data.complete_list.blank? %>
 | 
			
		||||
						<div class="module-pane" id="<%= plugin.name %>">
 | 
			
		||||
							<%= render :partial => @plugin_partial if !@plugin_partial.blank? %>
 | 
			
		||||
						</div>					
 | 
			
		||||
					<% end %>
 | 
			
		||||
 | 
			
		||||
				<% else %>
 | 
			
		||||
 | 
			
		||||
					<% if !@data.blank? %>
 | 
			
		||||
						<div class="module-pane" id="<%= plugin.name %>">
 | 
			
		||||
							<%= render :partial => @plugin_partial if !@plugin_partial.blank? %>
 | 
			
		||||
						</div>					
 | 
			
		||||
					<% end %>
 | 
			
		||||
 | 
			
		||||
				<% end %>
 | 
			
		||||
		</div>
 | 
			
		||||
 | 
			
		||||
			<% end %>
 | 
			
		||||
 | 
			
		||||
	    </div>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	</div>
 | 
			
		||||
	
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,10 @@
 | 
			
		|||
class Panel::PersonalBook::BackEnd::PersonalBookIntrosController < Admin::PersonalPluginIntrosController
 | 
			
		||||
 | 
			
		||||
  def initialize
 | 
			
		||||
    super
 | 
			
		||||
    @app_type = 'personal_book_intro'
 | 
			
		||||
    @app_type_name = 'personal_book'
 | 
			
		||||
    @reback_name = 'WritingBook'
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -9,43 +9,19 @@ class Panel::PersonalBook::BackEnd::WritingBooksController < OrbitBackendControl
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
  def index
 | 
			
		||||
  
 | 
			
		||||
    get_plugins
 | 
			
		||||
 | 
			
		||||
  get_categorys("BookPaperType",params[:book_paper_type_id])
 | 
			
		||||
  @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
 | 
			
		||||
  
 | 
			
		||||
  @paper_types =  BookPaperType.all
 | 
			
		||||
  @paper_type_ids = @paper_types.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
  
 | 
			
		||||
 | 
			
		||||
	# @writing_books = WritingBook.search(params[:category_id])
 | 
			
		||||
	#@writing_books = (params[:sort] || @filter) ? get_sorted_and_filtered_writing_books : WritingBook.all.page(params[:page]).per(10)
 | 
			
		||||
 | 
			
		||||
  @writing_books = (params[:sort] || @filter) ? get_sorted_and_filtered("writing_book",:book_paper_type_id.in => @paper_type_ids) : get_viewable("writing_book",:book_paper_type_id.in => @paper_type_ids)
 | 
			
		||||
  @books = @writing_books.page params[:page]
 | 
			
		||||
 | 
			
		||||
  @tags = get_tags
 | 
			
		||||
    # @tags = get_tags
 | 
			
		||||
    # @categories = get_categories_for_index
 | 
			
		||||
    # @statuses = get_statuses
 | 
			
		||||
    # category_ids = @categories.collect{|t| t.id}
 | 
			
		||||
    @paper_type_ids = BookPaperType.all.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
 | 
			
		||||
    @writing_books = get_sorted_and_filtered("writing_book", :book_paper_type_id.in => @paper_type_ids)
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      format.html # index.html.erb
 | 
			
		||||
      format.js { }
 | 
			
		||||
      format.xml  { render :xml => @writing_books }
 | 
			
		||||
      format.js
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -196,10 +172,11 @@ class Panel::PersonalBook::BackEnd::WritingBooksController < OrbitBackendControl
 | 
			
		|||
    end
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      
 | 
			
		||||
      if @writing_book.save
 | 
			
		||||
	  
 | 
			
		||||
		    if params[:writing_book][:user_id]
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:writing_book][:user_id],:show_plugin_profile=>'Book')) }
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:writing_book][:user_id],:show_plugin_profile=>"WritingBook")) }
 | 
			
		||||
        else
 | 
			
		||||
		     format.html { redirect_to(panel_personal_book_back_end_writing_books_url) }
 | 
			
		||||
        end
 | 
			
		||||
| 
						 | 
				
			
			@ -209,7 +186,9 @@ class Panel::PersonalBook::BackEnd::WritingBooksController < OrbitBackendControl
 | 
			
		|||
        format.html { render :action => "new" }
 | 
			
		||||
        format.xml  { render :xml => @writing_book.errors, :status => :unprocessable_entity }
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  end
 | 
			
		||||
| 
						 | 
				
			
			@ -260,6 +239,7 @@ class Panel::PersonalBook::BackEnd::WritingBooksController < OrbitBackendControl
 | 
			
		|||
          format.xml  { render :xml => @writing_book.errors, :status => :unprocessable_entity }
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
  
 | 
			
		||||
  end
 | 
			
		||||
| 
						 | 
				
			
			@ -284,6 +264,29 @@ class Panel::PersonalBook::BackEnd::WritingBooksController < OrbitBackendControl
 | 
			
		|||
    redirect_to panel_personal_book_back_end_writing_books_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def data_share
 | 
			
		||||
 | 
			
		||||
    if params[:ids]
 | 
			
		||||
    
 | 
			
		||||
      @writing_books = WritingBook.any_in(:_id => params[:ids])
 | 
			
		||||
      
 | 
			
		||||
      @writing_books.each do |writing_book|
 | 
			
		||||
 | 
			
		||||
        writing_book.is_hidden = params[:disable]
 | 
			
		||||
 | 
			
		||||
        writing_book.save
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
    
 | 
			
		||||
      format.html { redirect_to(admin_users_new_interface_url(:id=>params[:user_id],:show_plugin_profile=>"WritingBook")) }
 | 
			
		||||
      
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  protected
 | 
			
		||||
 
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,4 @@
 | 
			
		|||
class PersonalBookIntro < PersonalPluginIntro
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -1,17 +1,58 @@
 | 
			
		|||
<% # 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 %>
 | 
			
		||||
 | 
			
		||||
	<!--Widget start-->
 | 
			
		||||
<!-- Input Area -->
 | 
			
		||||
<div class="input-area">
 | 
			
		||||
 | 
			
		||||
	<div id="sub-wiget">
 | 
			
		||||
  <!-- 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(@writing_book) %>
 | 
			
		||||
      <li>
 | 
			
		||||
        <a href="#status" data-toggle="tab"><%= t(:status) %></a>
 | 
			
		||||
      </li>
 | 
			
		||||
    <% end %>
 | 
			
		||||
    <li>
 | 
			
		||||
      <a href="#tag" data-toggle="tab"><%= t(:tags) %></a>
 | 
			
		||||
    </li>
 | 
			
		||||
  </ul>
 | 
			
		||||
 | 
			
		||||
		<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>
 | 
			
		||||
  <!-- 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>
 | 
			
		||||
			<h3 class="widget-title"><i class="icons-tag"></i><%= f.label :author_type ,t("personal_book.author_type")%></h3>
 | 
			
		||||
			<div class="widget-content clear form-horizontal">
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <% end %>
 | 
			
		||||
 | 
			
		||||
      <!-- Category -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.author_type") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<% @author_types.each do |author_type| %>
 | 
			
		||||
				<%= content_tag :label,:class => "checkbox inline" do -%>
 | 
			
		||||
					<%= check_box_tag 'writing_book[book_author_type_ids][]', author_type.id, @writing_book.book_author_type_ids.include?(author_type.id)%>
 | 
			
		||||
| 
						 | 
				
			
			@ -22,235 +63,278 @@
 | 
			
		|||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		<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 'writing_book[tag_ids][]', tag.id, @writing_book.tag_ids.include?(tag.id)%>
 | 
			
		||||
						<%= tag.name %>
 | 
			
		||||
            <%= hidden_field_tag 'writing_book[tag_ids][]', '' %>
 | 
			
		||||
					<% end %>
 | 
			
		||||
				<% end %>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>  
 | 
			
		||||
  
 | 
			
		||||
	</div>
 | 
			
		||||
  
 | 
			
		||||
  
 | 
			
		||||
<!--Wiget End-->
 | 
			
		||||
<!--Post Start-->
 | 
			
		||||
 | 
			
		||||
	<div id="post-body">
 | 
			
		||||
		<div id="post-body-content" class="clear">
 | 
			
		||||
			
 | 
			
		||||
			<% if !params[:user_id].blank? %>
 | 
			
		||||
			
 | 
			
		||||
			<div class="span6">
 | 
			
		||||
				<%= t("著作人")%>
 | 
			
		||||
				<%= User.from_id(params[:user_id]).name rescue ''%>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<% end %>
 | 
			
		||||
		
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :year ,t("personal_book.year")%>
 | 
			
		||||
				<%= select_year((@writing_book.year ? @writing_book.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'writing_book[year]'} ) %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :book_paper_type ,t("personal_book.book_paper_type")%>
 | 
			
		||||
      <!-- Category -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.book_paper_type") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.select :book_paper_type_id, @paper_types.collect {|t| [ t.title, t.id ]} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<ul class="nav nav-tabs">
 | 
			
		||||
				<% @site_valid_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>
 | 
			
		||||
      <!-- year -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.year") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= select_year((@writing_book.year ? @writing_book.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'writing_book[year]',:class => 'span1'} ) %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :publish_date ,t("personal_book.publish_date")%>
 | 
			
		||||
      <!-- publish_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.publish_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, :day] }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
			
 | 
			
		||||
			<div class="tab-content">
 | 
			
		||||
			
 | 
			
		||||
				<% @site_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
				
 | 
			
		||||
				<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :paper_title ,t("personal_book.paper_title")%>
 | 
			
		||||
						<%= f.fields_for :paper_title_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_book.paper_title_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :book_title ,t("personal_book.book_title")%>
 | 
			
		||||
						<%= f.fields_for :book_title_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_book.book_title_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
					</div>
 | 
			
		||||
					
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :extracted_chapters ,t("personal_book.extracted_chapters")%>
 | 
			
		||||
						<%= f.fields_for :extracted_chapters_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_book.extracted_chapters_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
					</div>
 | 
			
		||||
					
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :publisher ,t("personal_book.publisher")%>
 | 
			
		||||
						<%= f.fields_for :publisher_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_book.publisher_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
					</div>
 | 
			
		||||
					
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :editor ,t("personal_book.editor")%>
 | 
			
		||||
						<%= f.fields_for :editor_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_book.editor_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 => (@writing_book.authors_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
					</div>
 | 
			
		||||
					
 | 
			
		||||
				</div>
 | 
			
		||||
 | 
			
		||||
				<% end %>
 | 
			
		||||
				
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :publication_date ,t("personal_book.publication_date")%>
 | 
			
		||||
      <!-- publication_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.publication_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.date_select :publication_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1890, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :url, t("personal_book.url") %>
 | 
			
		||||
				<%= f.text_field :url %>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :keywords, t("personal_book.keywords") %>
 | 
			
		||||
      <!-- url -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.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_book.keywords") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :keywords %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :pages, t("personal_book.pages") %>
 | 
			
		||||
      <!-- pages -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.pages") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :pages %>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :isbn, t("personal_book.isbn") %>
 | 
			
		||||
				<%= f.text_field :isbn %>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div id="title">
 | 
			
		||||
				<%= f.label :language, t("personal_book.language") %>
 | 
			
		||||
      <!-- isbn -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.isbn") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :isbn %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- language -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.language") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.radio_button :language, "Chinese" %> <%= t("personal_book.Chinese") %>
 | 
			
		||||
			<%= f.radio_button :language, "English" %> <%= t("personal_book.English") %> 
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :note, t("personal_book.note") %>
 | 
			
		||||
				<%= f.text_area :note, :size => "60x3" %>
 | 
			
		||||
      <!-- note -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_book.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(@writing_book) %>
 | 
			
		||||
      <div class="tab-pane fade" id="status">
 | 
			
		||||
 | 
			
		||||
		
 | 
			
		||||
		
 | 
			
		||||
			
 | 
			
		||||
		<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', @writing_book.writing_book_files.count %>
 | 
			
		||||
								<a class="add"><span class="btn btn-primary btn-small"><i class="icon-plus icon-white"></i> ADD/新增</span></a>
 | 
			
		||||
        <!-- 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 @writing_book.is_hidden? %>">
 | 
			
		||||
              <%= f.check_box :is_hidden %> <%= t(:hide) %>
 | 
			
		||||
            </label>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
						</td>
 | 
			
		||||
					</tr>
 | 
			
		||||
 | 
			
		||||
				</tfoot>
 | 
			
		||||
				<tbody>
 | 
			
		||||
      </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 @writing_book.tag_ids.include?(tag.id) %>">
 | 
			
		||||
              <%= check_box_tag 'writing_book[tag_ids][]', tag.id, @writing_book.tag_ids.include?(tag.id) %> <%= tag.name %>
 | 
			
		||||
              <%= hidden_field_tag 'writing_book[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_valid_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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
    
 | 
			
		||||
      <div class="<%= locale %> tab-pane fade <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
 | 
			
		||||
        <!-- paper_title-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_book.paper_title") %></label>
 | 
			
		||||
          <div class="controls">          	
 | 
			
		||||
            <%= f.fields_for :paper_title_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_book.paper_title"), value: (@writing_book.paper_title_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- book_title-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_book.book_title") %></label>
 | 
			
		||||
          <div class="controls">          	
 | 
			
		||||
            <%= f.fields_for :book_title_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_book.book_title"), value: (@writing_book.book_title_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- extracted_chapters-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_book.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_book.extracted_chapters"), value: (@writing_book.extracted_chapters_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- publisher-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_book.publisher") %></label>
 | 
			
		||||
          <div class="controls">          	
 | 
			
		||||
            <%= f.fields_for :publisher_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_book.publisher"), value: (@writing_book.publisher_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- editor-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_book.editor") %></label>
 | 
			
		||||
          <div class="controls">          	
 | 
			
		||||
            <%= f.fields_for :editor_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_book.editor"), value: (@writing_book.editor_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- authors-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_book.authors") %></label>
 | 
			
		||||
          <div class="controls">          	
 | 
			
		||||
            <%= f.fields_for :authors_translations do |f| %>
 | 
			
		||||
              <%= f.text_area locale, rows: 2, class: "input-block-level", value: (@writing_book.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 @writing_book && !@writing_book.writing_book_files.blank? %>
 | 
			
		||||
          <div class="exist">
 | 
			
		||||
            <% @writing_book.writing_book_files.each_with_index do |writing_book_file, i| %>
 | 
			
		||||
              <%= f.fields_for :writing_book_files, writing_book_file do |f| %>
 | 
			
		||||
                <%= render :partial => 'form_file', :object => writing_book_file, :locals => {:f => f, :i => i} %>
 | 
			
		||||
              <% end %>
 | 
			
		||||
            <% end %> 
 | 
			
		||||
				</tbody>
 | 
			
		||||
			</table>
 | 
			
		||||
            <hr>
 | 
			
		||||
          </div>
 | 
			
		||||
        <% end %>
 | 
			
		||||
 | 
			
		||||
        <!-- Add -->
 | 
			
		||||
        <div class="add-target">
 | 
			
		||||
        </div>
 | 
			
		||||
        <p class="add-btn">
 | 
			
		||||
          <%= hidden_field_tag 'plugin_file_field_count', @writing_book.writing_book_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>
 | 
			
		||||
 | 
			
		||||
<!--Post End-->
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
</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' %>
 | 
			
		||||
  <%= 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(){
 | 
			
		||||
    $(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_add_plugin_files", "g");
 | 
			
		||||
        var old_id = new RegExp("new_writing_book_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).parents('table').append(("<%= escape_javascript(add_attribute 'form_file', f, :writing_book_files) %>").replace(old_id, new_id));
 | 
			
		||||
        $(this).parent().siblings('.add-target').append(("<%= escape_javascript(add_attribute 'form_file', f, :writing_book_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');
 | 
			
		||||
        });
 | 
			
		||||
		
 | 
			
		||||
		$('.add_plugin_files_block a.delete').live('click', function(){
 | 
			
		||||
		  $(this).parents('.list_item').remove();
 | 
			
		||||
        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();
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
		$('.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 %>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,50 +1,45 @@
 | 
			
		|||
<% # 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_valid_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>
 | 
			
		||||
  <div class="fileupload fileupload-new start-line" data-provides="fileupload">
 | 
			
		||||
<% 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' %>
 | 
			
		||||
  <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_valid_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>
 | 
			
		||||
			
 | 
			
		||||
			</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		
 | 
			
		||||
      <% 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>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,9 +1,4 @@
 | 
			
		|||
<tr id="<%= dom_id writing_book %>" class="with_action">
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
		<% if (writing_book.create_user_id ==  current_user.id) || is_manager? %>
 | 
			
		||||
			<%= check_box_tag 'to_delete[]', writing_book.id, false, :class => "checkbox_in_list" %>
 | 
			
		||||
		<% end -%>
 | 
			
		||||
	</td>
 | 
			
		||||
	<td class="span1"><%= writing_book.year %></td>
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
	<%= link_to writing_book.create_link, panel_personal_book_front_end_writing_book_path(writing_book) %>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -9,8 +9,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<h1><%= t('personal_book.editing_personal_book') %></h1>
 | 
			
		||||
 | 
			
		||||
<%= form_for @writing_book, :url => panel_personal_book_back_end_writing_book_path(@writing_book), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @writing_book, url: panel_personal_book_back_end_writing_book_path(@writing_book), html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -13,10 +13,9 @@
 | 
			
		|||
<table class="table main-list">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"><%= t("personal_book.year") %></th>
 | 
			
		||||
			<th class="span7"><%= t("personal_book.book_title") %></th>
 | 
			
		||||
			<th class="span1"><%= t("personal_plugins.author") %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody id="tbody_writing_books" class="sort-holder">
 | 
			
		||||
| 
						 | 
				
			
			@ -24,10 +23,13 @@
 | 
			
		|||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<div class="form-actions form-fixed pagination-right">
 | 
			
		||||
<div class="bottomnav clearfix">
 | 
			
		||||
	<div class="action pull-right">
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-cog icon-white') + t('setting'), panel_personal_book_back_end_writing_book_setting_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t('announcement.add_new'), new_panel_personal_book_back_end_writing_book_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<div id="writing_book_pagination" class="paginationFixed">
 | 
			
		||||
	<%= paginate @books, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @writing_books, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -9,14 +9,8 @@
 | 
			
		|||
 | 
			
		||||
</div> 
 | 
			
		||||
 | 
			
		||||
<%= flash_messages %>
 | 
			
		||||
 | 
			
		||||
<div id="poststuff">
 | 
			
		||||
<h1><%= t('writing_book.new_personal_book') %></h1>
 | 
			
		||||
<%= form_for @writing_book, :url => panel_personal_book_back_end_writing_books_path, :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @writing_book, url: panel_personal_book_back_end_writing_books_path, html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%#= link_back %>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -15,7 +15,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_book_back_end_writing_book_paper_type_quick_add_path('add') %>#myModal1" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>論文型態</span>                        
 | 
			
		||||
                        <span><%= t("personal_book.book_paper_type") %></span>                        
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			@ -41,7 +41,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">          
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_book_back_end_writing_book_author_type_quick_add_path('add') %>#myModal2" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>作者型態</span>
 | 
			
		||||
                        <span><%= t("personal_book.author_type") %></span>
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,12 +1,21 @@
 | 
			
		|||
<%
 | 
			
		||||
  if @member
 | 
			
		||||
    @writing_books = WritingBook.where(:create_user_id => @member.id).desc(:year)
 | 
			
		||||
  else
 | 
			
		||||
    @writing_books = WritingBook.all.desc(:year)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
    @writing_books = WritingBook.where(is_hidden: false, :create_user_id => @member.id).desc(:year)
 | 
			
		||||
 | 
			
		||||
    @writing_book_intro = !PersonalBookIntro.where(:user_id => @member.id).blank? ? PersonalBookIntro.where(:user_id => @member.id).first : PersonalBookIntro.new
 | 
			
		||||
%>
 | 
			
		||||
 | 
			
		||||
  <% if @writing_book_intro.brief_intro and !@writing_book_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <div class="info">
 | 
			
		||||
        <%= @writing_book_intro.text.html_safe rescue '' %>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% if ( !@writing_book_intro.blank? and @writing_book_intro.complete_list ) or @writing_book_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <% if !@writing_books.blank? %>  
 | 
			
		||||
 | 
			
		||||
      <table class="table">
 | 
			
		||||
| 
						 | 
				
			
			@ -34,9 +43,8 @@
 | 
			
		|||
        </tbody>
 | 
			
		||||
      </table>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<% else %> 
 | 
			
		||||
 | 
			
		||||
  <%= t('nothing')%>
 | 
			
		||||
    <% end %>
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
<% end %> 
 | 
			
		||||
| 
						 | 
				
			
			@ -1,3 +1,10 @@
 | 
			
		|||
<% 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]
 | 
			
		||||
| 
						 | 
				
			
			@ -17,17 +24,29 @@
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  if @user
 | 
			
		||||
    @writing_books = WritingBook.where(:create_user_id => @user.id).page(params[:page]).per(10)
 | 
			
		||||
  if @user && is_admin?
 | 
			
		||||
    @writing_books = WritingBook.where(:create_user_id => @user.id).desc(:year).page(params[:page]).per(10)
 | 
			
		||||
  else
 | 
			
		||||
    @writing_books = WritingBook.all.page(params[:page]).per(10)
 | 
			
		||||
    @writing_books = WritingBook.where(is_hidden: false, :create_user_id => @user.id).desc(:year).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_book_back_end_writing_books_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_book_back_end_writing_books_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="span1"><%= t('personal_book.year') %></th>
 | 
			
		||||
			<th><%= t('personal_book.book_title') %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
| 
						 | 
				
			
			@ -36,7 +55,12 @@
 | 
			
		|||
		
 | 
			
		||||
	<% @writing_books.each do |writing_book| %>	
 | 
			
		||||
			
 | 
			
		||||
    <tr>
 | 
			
		||||
    <tr class="<%= writing_book.is_hidden ? "checkHide" : "" %>">
 | 
			
		||||
      <% if is_admin? %>
 | 
			
		||||
      <td>
 | 
			
		||||
        <%= check_box_tag 'to_change[]', writing_book.id.to_s, false, :class => "list-check" %>
 | 
			
		||||
      </td>
 | 
			
		||||
      <% end -%>
 | 
			
		||||
			<td><%= writing_book.year %></td>
 | 
			
		||||
			<td>
 | 
			
		||||
			<%= link_to writing_book.create_link, panel_personal_book_front_end_writing_book_path(writing_book) %>
 | 
			
		||||
| 
						 | 
				
			
			@ -48,11 +72,25 @@
 | 
			
		|||
  </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_book_back_end_personal_book_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_book_back_end_writing_book_path(:user_id => @user.id), :class => 'btn btn-primary' %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @writing_books, :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>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -10,9 +10,12 @@ Rails.application.routes.draw do
 | 
			
		|||
	  
 | 
			
		||||
        match 'writing_book_setting' => "writing_books#writing_book_setting" ,:as => :writing_book_setting
 | 
			
		||||
 | 
			
		||||
        # match 'writing_book_intro' => "writing_books#writing_book_intro" ,:as => :writing_book_intro
 | 
			
		||||
		  		
 | 
			
		||||
        resources :writing_books do
 | 
			
		||||
          collection do
 | 
			
		||||
            get 'delete'
 | 
			
		||||
            get 'data_share'
 | 
			
		||||
          end
 | 
			
		||||
		  
 | 
			
		||||
          match "author_type_quick_add" => "writing_books#author_type_quick_add" ,:as => :author_type_quick_add
 | 
			
		||||
| 
						 | 
				
			
			@ -21,6 +24,8 @@ Rails.application.routes.draw do
 | 
			
		|||
          match "paper_type_quick_add" => "writing_books#paper_type_quick_add" ,:as => :paper_type_quick_add
 | 
			
		||||
          match "paper_type_quick_edit" => "writing_books#paper_type_quick_edit" ,:as => :paper_type_quick_edit
 | 
			
		||||
        end
 | 
			
		||||
        
 | 
			
		||||
        resources :personal_book_intros
 | 
			
		||||
        resources :book_paper_types
 | 
			
		||||
        resources :book_author_types
 | 
			
		||||
        resources :tags
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2,7 +2,7 @@ module PersonalBook
 | 
			
		|||
  OrbitApp.registration "PersonalBook",:type=> 'ModuleApp' do
 | 
			
		||||
    module_label 'module_name.personal_book'
 | 
			
		||||
    base_url File.expand_path File.dirname(__FILE__)
 | 
			
		||||
    personal_plugin :enable => true,:path=>"panel/personal_book/plugin/profile",:front_path=>"panel/personal_book/front_end/profile",:admin_path=>"/panel/personal_book/back_end/writing_books",:i18n=>'module_name.personal_book'
 | 
			
		||||
    personal_plugin :enable => true, :app_name=>"WritingBook", :intro_app_name=>"PersonalBookIntro",:path=>"panel/personal_book/plugin/profile",:front_path=>"panel/personal_book/front_end/profile",:admin_path=>"/panel/personal_book/back_end/writing_books",:i18n=>'module_name.personal_book'
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,10 @@
 | 
			
		|||
class Panel::PersonalConference::BackEnd::PersonalConferenceIntrosController < Admin::PersonalPluginIntrosController
 | 
			
		||||
 | 
			
		||||
  def initialize
 | 
			
		||||
    super
 | 
			
		||||
    @app_type = 'personal_conference_intro'
 | 
			
		||||
    @app_type_name = 'personal_conference'
 | 
			
		||||
    @reback_name = 'WritingConference'
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -9,43 +9,19 @@ class Panel::PersonalConference::BackEnd::WritingConferencesController < OrbitBa
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
  def index
 | 
			
		||||
  
 | 
			
		||||
    get_plugins
 | 
			
		||||
 | 
			
		||||
  get_categorys("ConferencePaperType",params[:conference_paper_type_id])
 | 
			
		||||
  @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
 | 
			
		||||
  
 | 
			
		||||
  @paper_types =  ConferencePaperType.all
 | 
			
		||||
  @paper_type_ids = @paper_types.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
  
 | 
			
		||||
 | 
			
		||||
	# @writing_conferences = WritingConference.search(params[:category_id])
 | 
			
		||||
	#@writing_conferences = (params[:sort] || @filter) ? get_sorted_and_filtered_writing_conferences : WritingConference.all.page(params[:page]).per(10)
 | 
			
		||||
 | 
			
		||||
    @writing_conferences = (params[:sort] || @filter) ? get_sorted_and_filtered("writing_conference",:conference_paper_type_id.in => @paper_type_ids) : get_viewable("writing_conference",:conference_paper_type_id.in => @paper_type_ids)
 | 
			
		||||
    @conferences = @writing_conferences.page params[:page]
 | 
			
		||||
 | 
			
		||||
  @tags = get_tags
 | 
			
		||||
    # @tags = get_tags
 | 
			
		||||
    # @categories = get_categories_for_index
 | 
			
		||||
    # @statuses = get_statuses
 | 
			
		||||
    # category_ids = @categories.collect{|t| t.id}
 | 
			
		||||
    @paper_type_ids = ConferencePaperType.all.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
 | 
			
		||||
    @writing_conferences = get_sorted_and_filtered("writing_conference", :conference_paper_type_id.in => @paper_type_ids)
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      format.html # index.html.erb
 | 
			
		||||
      format.js { }
 | 
			
		||||
      format.xml  { render :xml => @writing_conferences }
 | 
			
		||||
      format.js
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -197,7 +173,7 @@ class Panel::PersonalConference::BackEnd::WritingConferencesController < OrbitBa
 | 
			
		|||
      if @writing_conference.save
 | 
			
		||||
	  
 | 
			
		||||
		    if params[:writing_conference][:user_id]
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:writing_conference][:user_id],:show_plugin_profile=>'Conference')) }
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:writing_conference][:user_id],:show_plugin_profile=>'WritingConference')) }
 | 
			
		||||
        else
 | 
			
		||||
		      format.html { redirect_to(panel_personal_conference_back_end_writing_conferences_url) }
 | 
			
		||||
        end
 | 
			
		||||
| 
						 | 
				
			
			@ -258,6 +234,7 @@ class Panel::PersonalConference::BackEnd::WritingConferencesController < OrbitBa
 | 
			
		|||
          format.xml  { render :xml => @writing_conference.errors, :status => :unprocessable_entity }
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
  
 | 
			
		||||
  end
 | 
			
		||||
| 
						 | 
				
			
			@ -282,6 +259,30 @@ class Panel::PersonalConference::BackEnd::WritingConferencesController < OrbitBa
 | 
			
		|||
    redirect_to panel_personal_conference_back_end_writing_conferences_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def data_share
 | 
			
		||||
 | 
			
		||||
    if params[:ids]
 | 
			
		||||
    
 | 
			
		||||
      @writing_conferences = WritingConference.any_in(:_id => params[:ids])
 | 
			
		||||
      
 | 
			
		||||
      @writing_conferences.each do |writing_conference|
 | 
			
		||||
 | 
			
		||||
        writing_conference.is_hidden = params[:disable]
 | 
			
		||||
 | 
			
		||||
        writing_conference.save
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
    
 | 
			
		||||
      format.html { redirect_to(admin_users_new_interface_url(:id=>params[:user_id],:show_plugin_profile=>"WritingConference")) }
 | 
			
		||||
      
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  
 | 
			
		||||
  protected
 | 
			
		||||
 
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										4
									
								
								vendor/built_in_modules/personal_conference/app/models/personal_conference_intro.rb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										4
									
								
								vendor/built_in_modules/personal_conference/app/models/personal_conference_intro.rb
								
								
								
									vendored
								
								
									Normal file
								
							| 
						 | 
				
			
			@ -0,0 +1,4 @@
 | 
			
		|||
class PersonalConferenceIntro < PersonalPluginIntro
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -1,17 +1,58 @@
 | 
			
		|||
<% # 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 %>
 | 
			
		||||
 | 
			
		||||
	<!--Widget start-->
 | 
			
		||||
<!-- Input Area -->
 | 
			
		||||
<div class="input-area">
 | 
			
		||||
 | 
			
		||||
	<div id="sub-wiget">
 | 
			
		||||
  <!-- 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(@writing_conference) %>
 | 
			
		||||
      <li>
 | 
			
		||||
        <a href="#status" data-toggle="tab"><%= t(:status) %></a>
 | 
			
		||||
      </li>
 | 
			
		||||
    <% end %>
 | 
			
		||||
    <li>
 | 
			
		||||
      <a href="#tag" data-toggle="tab"><%= t(:tags) %></a>
 | 
			
		||||
    </li>
 | 
			
		||||
  </ul>
 | 
			
		||||
 | 
			
		||||
		<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>
 | 
			
		||||
  <!-- 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>
 | 
			
		||||
			<h3 class="widget-title"><i class="icons-tag"></i><%= f.label :paper_type ,t("personal_conference.paper_type")%></h3>
 | 
			
		||||
			<div class="widget-content clear form-horizontal">
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <% end %>
 | 
			
		||||
 | 
			
		||||
      <!-- paper_type -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.paper_type") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		<% @paper_types.each do |paper_type| %>
 | 
			
		||||
			<%= content_tag :label,:class => "checkbox inline" do -%>
 | 
			
		||||
				<%= check_box_tag 'writing_conference[conference_paper_type_ids][]', paper_type.id, @writing_conference.conference_paper_type_ids.include?(paper_type.id)%>
 | 
			
		||||
| 
						 | 
				
			
			@ -22,12 +63,10 @@
 | 
			
		|||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
		<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><%= f.label :author_type ,t("personal_conference.author_type")%></h3>
 | 
			
		||||
			<div class="widget-content clear form-horizontal">
 | 
			
		||||
      <!-- author_type -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.author_type") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		<% @author_types.each do |author_type| %>
 | 
			
		||||
			<%= content_tag :label,:class => "checkbox inline" do -%>
 | 
			
		||||
				<%= check_box_tag 'writing_conference[conference_author_type_ids][]', author_type.id, @writing_conference.conference_author_type_ids.include?(author_type.id)%>
 | 
			
		||||
| 
						 | 
				
			
			@ -38,221 +77,257 @@
 | 
			
		|||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		<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>
 | 
			
		||||
      <!-- year -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.year") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		  <%= select_year((@writing_conference.year ? @writing_conference.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'writing_conference[year]',:class => 'span1'} ) %>
 | 
			
		||||
        </div>
 | 
			
		||||
			<h3 class="widget-title"><i class="icons-tag"></i>Tags</h3>
 | 
			
		||||
			<div class="widget-content clear form-horizontal">
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- period_start_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.period_start_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		  <%= f.date_select :period_start_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- period_end_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.period_end_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		  <%= f.date_select :period_end_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- publication_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.publication_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		  <%= f.date_select :publication_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1890, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- url -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.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_conference.keywords") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		  <%= f.text_field :keywords %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- abstract -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.abstract") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		  <%= f.text_field :abstract %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- language -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.language") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
		  <%= f.select :language, WritingConference::LANGUAGE_TYPES, :prompt => 'Select' %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- note -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_conference.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(@writing_conference) %>
 | 
			
		||||
      <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 @writing_conference.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| %>
 | 
			
		||||
					<%= content_tag :label,:class => "checkbox inline" do -%>
 | 
			
		||||
						<%= check_box_tag 'writing_conference[tag_ids][]', tag.id, @writing_conference.tag_ids.include?(tag.id)%>
 | 
			
		||||
						<%= tag.name %>
 | 
			
		||||
            <label class="checkbox inline btn <%= 'active' if @writing_conference.tag_ids.include?(tag.id) %>">
 | 
			
		||||
              <%= check_box_tag 'writing_conference[tag_ids][]', tag.id, @writing_conference.tag_ids.include?(tag.id) %> <%= tag.name %>
 | 
			
		||||
              <%= hidden_field_tag 'writing_conference[tag_ids][]', '' %>
 | 
			
		||||
					<% end %>
 | 
			
		||||
            </label>
 | 
			
		||||
          <% end %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
<!--Wiget End-->
 | 
			
		||||
<!--Post Start-->
 | 
			
		||||
 | 
			
		||||
	<div id="post-body">
 | 
			
		||||
		<div id="post-body-content" class="clear">
 | 
			
		||||
			
 | 
			
		||||
			<% if !params[:user_id].blank? %>
 | 
			
		||||
			
 | 
			
		||||
			<div class="span6">
 | 
			
		||||
				<%= t("著作人")%>
 | 
			
		||||
				<%= User.from_id(params[:user_id]).name rescue ''%>
 | 
			
		||||
  </div>
 | 
			
		||||
 | 
			
		||||
			<% end %>		
 | 
			
		||||
		
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :year ,t("personal_conference.year")%>
 | 
			
		||||
				<%= select_year((@writing_conference.year ? @writing_conference.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'writing_conference[year]'} ) %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<ul class="nav nav-tabs">
 | 
			
		||||
  <!-- Language Tabs -->
 | 
			
		||||
  <div class="nav-name"><strong><%= t(:language) %></strong></div>
 | 
			
		||||
  <ul class="nav nav-pills language-nav">
 | 
			
		||||
    <% @site_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
			    <li <%= ( i == 0 ) ? "class=active" : '' %>><a data-toggle="tab" href=".<%= locale %>"><%= I18nVariable.from_locale(locale) %></a></li>
 | 
			
		||||
      <li class="<%= 'active' if i == 0 %>">
 | 
			
		||||
        <a data-toggle="tab" href=".<%= locale %>"><%= I18nVariable.from_locale(locale) %></a>
 | 
			
		||||
      </li>
 | 
			
		||||
    <% end %>
 | 
			
		||||
  </ul>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :period_start_date ,t("personal_conference.period_start_date")%>
 | 
			
		||||
				<%= f.date_select :period_start_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :period_end_date ,t("personal_conference.period_end_date")%>
 | 
			
		||||
				<%= f.date_select :period_end_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<div class="tab-content">
 | 
			
		||||
  <!-- Language -->
 | 
			
		||||
  <div class="tab-content language-area">
 | 
			
		||||
 | 
			
		||||
    <% @site_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
    
 | 
			
		||||
				<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :paper_title ,t("personal_conference.paper_title")%>
 | 
			
		||||
      <div class="<%= locale %> tab-pane fade <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
 | 
			
		||||
        <!-- paper_title-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_conference.paper_title") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :paper_title_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_conference.paper_title_translations[locale] rescue nil) %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_conference.paper_title"), value: (@writing_conference.paper_title_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :conference_title ,t("personal_conference.conference_title")%>
 | 
			
		||||
        <!-- conference_title-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_conference.conference_title") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :conference_title_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_conference.conference_title_translations[locale] rescue nil) %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_conference.conference_title"), value: (@writing_conference.conference_title_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :location ,t("personal_conference.location")%>
 | 
			
		||||
        <!-- location-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_conference.location") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :location_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_conference.location_translations[locale] rescue nil) %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_conference.location"), value: (@writing_conference.location_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :sponsor ,t("personal_conference.sponsor")%>
 | 
			
		||||
        <!-- sponsor-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_conference.sponsor") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :sponsor_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@writing_conference.sponsor_translations[locale] rescue nil) %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_conference.sponsor"), value: (@writing_conference.sponsor_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :authors,t("web_resource.authors") %>
 | 
			
		||||
        <!-- authors-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_conference.authors") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :authors_translations do |f| %>
 | 
			
		||||
								<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
								<%= f.text_area locale, :size => "60x3", :value => (@writing_conference.authors_translations[locale] rescue nil) %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_conference.authors"), value: (@writing_conference.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 @writing_conference && !@writing_conference.writing_conference_files.blank? %>
 | 
			
		||||
          <div class="exist">
 | 
			
		||||
            <% @writing_conference.writing_conference_files.each_with_index do |archive_file_multiple, i| %>
 | 
			
		||||
              <%= f.fields_for :writing_conference_files, archive_file_multiple do |f| %>
 | 
			
		||||
                <%= render :partial => 'form_file', :object => archive_file_multiple, :locals => {:f => f, :i => i} %>
 | 
			
		||||
              <% end %>
 | 
			
		||||
            <% end %> 
 | 
			
		||||
            <hr>
 | 
			
		||||
          </div>
 | 
			
		||||
        <% end %>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :publication_date ,t("personal_conference.publication_date")%>
 | 
			
		||||
				<%= f.date_select :publication_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1890, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
        <!-- Add -->
 | 
			
		||||
        <div class="add-target">
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :url, t("personal_conference.url") %>
 | 
			
		||||
				<%= f.text_field :url %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :keywords, t("personal_conference.keywords") %>
 | 
			
		||||
				<%= f.text_field :keywords %>
 | 
			
		||||
			</div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :abstract, t("personal_conference.abstract") %>
 | 
			
		||||
				<%= f.text_field :abstract %>
 | 
			
		||||
			</div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :language, t("personal_journal.language") %>
 | 
			
		||||
				<%= f.select :language, WritingConference::LANGUAGE_TYPES, :prompt => 'Select' %>
 | 
			
		||||
			</div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :note, t("personal_conference.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">
 | 
			
		||||
        <p class="add-btn">
 | 
			
		||||
        	<%= hidden_field_tag 'plugin_file_field_count', @writing_conference.writing_conference_files.count %>
 | 
			
		||||
								<a class="add"><span class="btn btn-primary btn-small"><i class="icon-plus icon-white"></i> ADD/新增</span></a>
 | 
			
		||||
          <a id="add_file" class="trigger btn btn-small btn-primary"><i class="icons-plus"></i> <%= t(:add) %></a>
 | 
			
		||||
        </p>
 | 
			
		||||
 | 
			
		||||
      </div>
 | 
			
		||||
    </div>
 | 
			
		||||
						</td>
 | 
			
		||||
					</tr>
 | 
			
		||||
				
 | 
			
		||||
				</tfoot>
 | 
			
		||||
				<tbody>
 | 
			
		||||
					
 | 
			
		||||
					<% @writing_conference.writing_conference_files.each_with_index do |writing_conference_file, i| %>
 | 
			
		||||
						<%= f.fields_for :writing_conference_files, writing_conference_file do |f| %>
 | 
			
		||||
							<%= render :partial => 'form_file', :object => writing_conference_file, :locals => {:f => f, :i => i} %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
					<% end %>	
 | 
			
		||||
				</tbody>
 | 
			
		||||
			</table>
 | 
			
		||||
			
 | 
			
		||||
  </div>
 | 
			
		||||
 | 
			
		||||
</div> 
 | 
			
		||||
 | 
			
		||||
		
 | 
			
		||||
		
 | 
			
		||||
		
 | 
			
		||||
		
 | 
			
		||||
		
 | 
			
		||||
	</div>
 | 
			
		||||
	
 | 
			
		||||
<!--Post End-->
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
<!-- 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' %>
 | 
			
		||||
  <%= 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(){
 | 
			
		||||
    $(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_add_plugin_files", "g");
 | 
			
		||||
        var old_id = new RegExp("new_writing_conference_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).parents('table').append(("<%= escape_javascript(add_attribute 'form_file', f, :writing_conference_files) %>").replace(old_id, new_id));
 | 
			
		||||
        $(this).parent().siblings('.add-target').append(("<%= escape_javascript(add_attribute 'form_file', f, :writing_conference_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');
 | 
			
		||||
        });
 | 
			
		||||
		
 | 
			
		||||
		$('.add_plugin_files_block a.delete').live('click', function(){
 | 
			
		||||
		  $(this).parents('.list_item').remove();
 | 
			
		||||
        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();
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
		$('.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 %>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,50 +1,45 @@
 | 
			
		|||
<% # 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_valid_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>
 | 
			
		||||
  <div class="fileupload fileupload-new start-line" data-provides="fileupload">
 | 
			
		||||
<% 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' %>
 | 
			
		||||
  <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_valid_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>
 | 
			
		||||
			
 | 
			
		||||
			</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		
 | 
			
		||||
      <% 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>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,9 +1,4 @@
 | 
			
		|||
<tr id="<%= dom_id writing_conference %>" class="with_action">
 | 
			
		||||
	<td>
 | 
			
		||||
		<% if (writing_conference.create_user_id ==  current_user.id) || is_manager? %>
 | 
			
		||||
			<%= check_box_tag 'to_delete[]', writing_conference.id, false, :class => "checkbox_in_list" %>
 | 
			
		||||
		<% end -%>
 | 
			
		||||
	</td>
 | 
			
		||||
	<td><%= writing_conference.year %></td>
 | 
			
		||||
	<td>
 | 
			
		||||
	<%= link_to writing_conference.create_link, panel_personal_conference_front_end_writing_conference_path(writing_conference) %>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -8,8 +8,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<h1><%= t('personal_conference.editing_personal_conference') %></h1>
 | 
			
		||||
 | 
			
		||||
<%= form_for @writing_conference, :url => panel_personal_conference_back_end_writing_conference_path(@writing_conference), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @writing_conference, url: panel_personal_conference_back_end_writing_conference_path(@writing_conference), html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -13,10 +13,9 @@
 | 
			
		|||
<table class="table main-list">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"><%= t("personal_book.year") %></th>
 | 
			
		||||
			<th class="span7"><%= t("module_name.personal_conference") %></th>
 | 
			
		||||
			<th class="span1"><%= t("personal_plugins.author") %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody id="tbody_writing_conferences" class="sort-holder">
 | 
			
		||||
| 
						 | 
				
			
			@ -24,10 +23,12 @@
 | 
			
		|||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<div class="form-actions form-fixed pagination-right">  
 | 
			
		||||
<div class="bottomnav clearfix">
 | 
			
		||||
	<div class="action pull-right"> 
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-cog icon-white') + t('setting'), panel_personal_conference_back_end_writing_conference_setting_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t('announcement.add_new'), new_panel_personal_conference_back_end_writing_conference_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<div id="writing_conference_pagination" class="paginationFixed">
 | 
			
		||||
	<%= paginate @conferences, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @writing_conferences, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
</div>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -8,14 +8,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%= flash_messages %>
 | 
			
		||||
 | 
			
		||||
<div id="poststuff">
 | 
			
		||||
<h1><%= t('writing_conference.new_personal_conference') %></h1>
 | 
			
		||||
<%= form_for @writing_conference, :url => panel_personal_conference_back_end_writing_conferences_path, :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @writing_conference, url: panel_personal_conference_back_end_writing_conferences_path, html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%#= link_back %>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -15,7 +15,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_conference_back_end_writing_conference_paper_type_quick_add_path('add') %>#myModal1" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>論文型態</span>                        
 | 
			
		||||
                        <span><%= t("personal_conference.paper_type") %></span>                        
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			@ -41,7 +41,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">          
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_conference_back_end_writing_conference_author_type_quick_add_path('add') %>#myModal2" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>作者型態</span>
 | 
			
		||||
                        <span><%= t("personal_conference.author_type") %></span>
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,12 +1,21 @@
 | 
			
		|||
<%
 | 
			
		||||
  if @member
 | 
			
		||||
    @writing_conferences = WritingConference.where(:create_user_id => @member.id).desc(:year)
 | 
			
		||||
  else
 | 
			
		||||
    @writing_conferences = WritingConference.all.desc(:year)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
    @writing_conferences = WritingConference.where(is_hidden: false, :create_user_id => @member.id).desc(:year)
 | 
			
		||||
 | 
			
		||||
    @writing_conference_intro = !PersonalConferenceIntro.where(:user_id => @member.id).blank? ? PersonalConferenceIntro.where(:user_id => @member.id).first : PersonalConferenceIntro.new
 | 
			
		||||
%>
 | 
			
		||||
 | 
			
		||||
  <% if @writing_conference_intro.brief_intro and !@writing_conference_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <div class="info">
 | 
			
		||||
        <%= @writing_conference_intro.text.html_safe rescue '' %>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% if ( !@writing_conference_intro.blank? and @writing_conference_intro.complete_list ) or @writing_conference_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <% if !@writing_conferences.blank? %> 
 | 
			
		||||
 | 
			
		||||
      <table class="table">
 | 
			
		||||
| 
						 | 
				
			
			@ -34,9 +43,8 @@
 | 
			
		|||
        </tbody>
 | 
			
		||||
      </table>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<% else %> 
 | 
			
		||||
 | 
			
		||||
  <%= t('nothing')%>
 | 
			
		||||
    <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
<% end %> 
 | 
			
		||||
| 
						 | 
				
			
			@ -1,3 +1,10 @@
 | 
			
		|||
<% 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]
 | 
			
		||||
| 
						 | 
				
			
			@ -17,18 +24,29 @@
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  if @user
 | 
			
		||||
    @writing_conferences = WritingConference.where(:create_user_id => @user.id).page(params[:page]).per(10)
 | 
			
		||||
  if @user && is_admin?
 | 
			
		||||
    @writing_conferences = WritingConference.where(:create_user_id => @user.id).desc(:year).page(params[:page]).per(10)
 | 
			
		||||
  else
 | 
			
		||||
    @writing_conferences = WritingConference.all.page(params[:page]).per(10)
 | 
			
		||||
    @writing_conferences = WritingConference.where(is_hidden: false, :create_user_id => @user.id).desc(:year).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_conference_back_end_writing_conferences_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_conference_back_end_writing_conferences_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="span1"><%= t('personal_conference.year') %></th>
 | 
			
		||||
			<th><%= t('module_name.personal_conference') %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
| 
						 | 
				
			
			@ -37,7 +55,12 @@
 | 
			
		|||
		
 | 
			
		||||
	<% @writing_conferences.each do |writing_conference| %>	
 | 
			
		||||
			
 | 
			
		||||
    <tr>
 | 
			
		||||
    <tr class="<%= writing_conference.is_hidden ? "checkHide" : "" %>">
 | 
			
		||||
      <% if is_admin? %>
 | 
			
		||||
      <td>
 | 
			
		||||
        <%= check_box_tag 'to_change[]', writing_conference.id.to_s, false, :class => "list-check" %>
 | 
			
		||||
      </td>
 | 
			
		||||
      <% end -%>
 | 
			
		||||
			<td><%= writing_conference.year %></td>
 | 
			
		||||
			<td>
 | 
			
		||||
			<%= link_to writing_conference.create_link, panel_personal_conference_front_end_writing_conference_path(writing_conference) %>
 | 
			
		||||
| 
						 | 
				
			
			@ -49,11 +72,25 @@
 | 
			
		|||
  </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_conference_back_end_personal_conference_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_conference_back_end_writing_conference_path(:user_id => @user.id), :class => 'btn btn-primary' %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @writing_conferences, :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>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,7 +1,7 @@
 | 
			
		|||
en:
 | 
			
		||||
 | 
			
		||||
  module_name:
 | 
			
		||||
    personal_conference: Conference
 | 
			
		||||
    personal_conference: Conference Paper 
 | 
			
		||||
 | 
			
		||||
  personal_conference:
 | 
			
		||||
    year : "Year"
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -14,12 +14,14 @@ Rails.application.routes.draw do
 | 
			
		|||
        resources :writing_conferences do
 | 
			
		||||
          collection do
 | 
			
		||||
            get 'delete'
 | 
			
		||||
            get 'data_share'
 | 
			
		||||
          end
 | 
			
		||||
          match "author_type_quick_add" => "writing_conferences#author_type_quick_add" ,:as => :author_type_quick_add
 | 
			
		||||
          match "author_type_quick_edit" => "writing_conferences#author_type_quick_edit" ,:as => :author_type_quick_edit
 | 
			
		||||
          match "paper_type_quick_add" => "writing_conferences#paper_type_quick_add" ,:as => :paper_type_quick_add
 | 
			
		||||
          match "paper_type_quick_edit" => "writing_conferences#paper_type_quick_edit" ,:as => :paper_type_quick_edit
 | 
			
		||||
        end
 | 
			
		||||
        resources :personal_conference_intros
 | 
			
		||||
        resources :conference_paper_types
 | 
			
		||||
        resources :conference_author_types
 | 
			
		||||
        # resources :conference_level_types
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2,7 +2,7 @@ module PersonalConference
 | 
			
		|||
  OrbitApp.registration "PersonalConference",:type=> 'ModuleApp' do
 | 
			
		||||
    module_label 'module_name.personal_conference'
 | 
			
		||||
    base_url File.expand_path File.dirname(__FILE__)
 | 
			
		||||
    personal_plugin :enable => true,:path=>"panel/personal_conference/plugin/profile",:front_path=>"panel/personal_conference/front_end/profile",:admin_path=>"/panel/personal_conference/back_end/writing_conferences",:i18n=>'module_name.personal_conference'
 | 
			
		||||
    personal_plugin :enable => true, :app_name=>"WritingConference", :intro_app_name=>"PersonalConferenceIntro",:path=>"panel/personal_conference/plugin/profile",:front_path=>"panel/personal_conference/front_end/profile",:admin_path=>"/panel/personal_conference/back_end/writing_conferences",:i18n=>'module_name.personal_conference'
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -5,36 +5,18 @@ class Panel::PersonalDiploma::BackEnd::DiplomasController < OrbitBackendControll
 | 
			
		|||
  before_filter :authenticate_user!
 | 
			
		||||
 | 
			
		||||
  def index
 | 
			
		||||
  
 | 
			
		||||
    get_plugins
 | 
			
		||||
 | 
			
		||||
  @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
 | 
			
		||||
  
 | 
			
		||||
  
 | 
			
		||||
  @diplomas = (params[:sort] || @filter) ? get_sorted_and_filtered("diploma") : get_viewable("diploma")
 | 
			
		||||
  @diplomas_page = @diplomas.page params[:page]
 | 
			
		||||
 | 
			
		||||
  @tags = get_tags
 | 
			
		||||
    # @tags = get_tags
 | 
			
		||||
    # @categories = get_categories_for_index
 | 
			
		||||
    # @statuses = get_statuses
 | 
			
		||||
    # category_ids = @categories.collect{|t| t.id}
 | 
			
		||||
 | 
			
		||||
    @diplomas = get_sorted_and_filtered("diploma")
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      format.html # index.html.erb
 | 
			
		||||
      format.js { }
 | 
			
		||||
      format.xml  { render :xml => @diplomas }
 | 
			
		||||
      format.js
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -113,6 +95,7 @@ class Panel::PersonalDiploma::BackEnd::DiplomasController < OrbitBackendControll
 | 
			
		|||
        format.xml  { render :xml => @diploma.errors, :status => :unprocessable_entity }
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  # PUT /diplomas/1
 | 
			
		||||
| 
						 | 
				
			
			@ -135,6 +118,7 @@ class Panel::PersonalDiploma::BackEnd::DiplomasController < OrbitBackendControll
 | 
			
		|||
        format.xml  { render :xml => @diploma.errors, :status => :unprocessable_entity }
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  # DELETE /diplomas/1
 | 
			
		||||
| 
						 | 
				
			
			@ -157,6 +141,29 @@ class Panel::PersonalDiploma::BackEnd::DiplomasController < OrbitBackendControll
 | 
			
		|||
    redirect_to panel_personal_diploma_back_end_diplomas_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def data_share
 | 
			
		||||
 | 
			
		||||
    if params[:ids]
 | 
			
		||||
    
 | 
			
		||||
      @diplomas = Diploma.any_in(:_id => params[:ids])
 | 
			
		||||
      
 | 
			
		||||
      @diplomas.each do |diploma|
 | 
			
		||||
 | 
			
		||||
        diploma.is_hidden = params[:disable]
 | 
			
		||||
 | 
			
		||||
        diploma.save
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
    
 | 
			
		||||
      format.html { redirect_to(admin_users_new_interface_url(:id=>params[:user_id],:show_plugin_profile=>"Diploma")) }
 | 
			
		||||
      
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  protected
 | 
			
		||||
 
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,10 @@
 | 
			
		|||
class Panel::PersonalDiploma::BackEnd::PersonalDiplomaIntrosController < Admin::PersonalPluginIntrosController
 | 
			
		||||
 | 
			
		||||
  def initialize
 | 
			
		||||
    super
 | 
			
		||||
    @app_type = 'personal_diploma_intro'
 | 
			
		||||
    @app_type_name = 'personal_diploma'
 | 
			
		||||
    @reback_name = 'Diploma'
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
							
								
								
									
										4
									
								
								vendor/built_in_modules/personal_diploma/app/models/personal_diploma_intro.rb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										4
									
								
								vendor/built_in_modules/personal_diploma/app/models/personal_diploma_intro.rb
								
								
								
									vendored
								
								
									Normal file
								
							| 
						 | 
				
			
			@ -0,0 +1,4 @@
 | 
			
		|||
class PersonalDiplomaIntro < PersonalPluginIntro
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -1,9 +1,4 @@
 | 
			
		|||
<tr id="<%= dom_id diploma %>" class="with_action">
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
		<% if (diploma.create_user_id ==  current_user.id) || is_manager? %>
 | 
			
		||||
			<%= check_box_tag 'to_delete[]', diploma.id, false, :class => "checkbox_in_list" %>
 | 
			
		||||
		<% end -%>
 | 
			
		||||
	</td>
 | 
			
		||||
	<td class="span1"><%= diploma.start_date.strftime("%Y.%m") %> ~ <%= diploma.end_date.strftime("%Y.%m") %></td>
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
	<%= diploma.school_name %>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,136 +1,210 @@
 | 
			
		|||
<% # 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 %>
 | 
			
		||||
 | 
			
		||||
	<!--Widget start-->
 | 
			
		||||
<!-- Input Area -->
 | 
			
		||||
<div class="input-area">
 | 
			
		||||
 | 
			
		||||
	<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 'diploma[tag_ids][]', tag.id, @diploma.tag_ids.include?(tag.id)%>
 | 
			
		||||
						<%= tag.name %>
 | 
			
		||||
            <%= hidden_field_tag 'diploma[tag_ids][]', '' %>
 | 
			
		||||
  <!-- 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(@diploma) %>
 | 
			
		||||
      <li>
 | 
			
		||||
        <a href="#status" data-toggle="tab"><%= t(:status) %></a>
 | 
			
		||||
      </li>
 | 
			
		||||
    <% end %>
 | 
			
		||||
				<% end %>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>  
 | 
			
		||||
    <li>
 | 
			
		||||
      <a href="#tag" data-toggle="tab"><%= t(:tags) %></a>
 | 
			
		||||
    </li>
 | 
			
		||||
  </ul>
 | 
			
		||||
 | 
			
		||||
	</div>
 | 
			
		||||
  <!-- Module -->
 | 
			
		||||
  <div class="tab-content module-area">
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
<!--Wiget End-->
 | 
			
		||||
<!--Post Start-->
 | 
			
		||||
 | 
			
		||||
	<div id="post-body">
 | 
			
		||||
		<div id="post-body-content" class="clear">
 | 
			
		||||
    <!-- Basic Module -->
 | 
			
		||||
    <div class="tab-pane fade in active" id="basic">
 | 
			
		||||
 | 
			
		||||
      <% if !params[:user_id].blank? %>
 | 
			
		||||
      
 | 
			
		||||
			<div class="span6">
 | 
			
		||||
				<%= t("著作人")%>
 | 
			
		||||
      <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 %>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :start_date ,t("personal_diploma.start_date")%>
 | 
			
		||||
      <!-- start_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_diploma.start_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.date_select :start_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1890, :order => [:year, :month], :discard_day => true }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :end_date ,t("personal_diploma.end_date")%>
 | 
			
		||||
      <!-- end_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_diploma.end_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.date_select :end_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1890, :order => [:year, :month], :discard_day => true }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
			
 | 
			
		||||
			<ul class="nav nav-tabs">
 | 
			
		||||
				<% @site_valid_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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
				
 | 
			
		||||
				<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
					
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :school_name ,t("personal_diploma.school_name")%>
 | 
			
		||||
						<%= f.fields_for :school_name_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@diploma.school_name_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :country ,t("personal_diploma.country")%>
 | 
			
		||||
						<%= f.fields_for :country_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@diploma.country_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
      <!-- url -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_diploma.url") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_field :url , :class => "span6" %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :department ,t("personal_diploma.department")%>
 | 
			
		||||
						<%= f.fields_for :department_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@diploma.department_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
					</div>
 | 
			
		||||
					
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :degree ,t("personal_diploma.degree")%>
 | 
			
		||||
						<%= f.fields_for :degree_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@diploma.degree_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
					</div>
 | 
			
		||||
					
 | 
			
		||||
				</div>
 | 
			
		||||
 | 
			
		||||
				<% end %>
 | 
			
		||||
				
 | 
			
		||||
			</div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :url, t("personal_diploma.url") %>
 | 
			
		||||
				<%= f.text_field :url %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :keywords, t("personal_diploma.keywords") %>
 | 
			
		||||
      <!-- keywords -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_diploma.keywords") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_field :keywords %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div id="title">
 | 
			
		||||
				<%= f.label :language, t("personal_diploma.language") %>
 | 
			
		||||
      <!-- language -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_diploma.language") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.radio_button :language, "Chinese" %> <%= t("personal_diploma.Chinese") %>
 | 
			
		||||
          <%= f.radio_button :language, "English" %> <%= t("personal_diploma.English") %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :note, t("personal_diploma.note") %>
 | 
			
		||||
				<%= f.text_area :note, :size => "60x3" %>
 | 
			
		||||
      <!-- note -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_diploma.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(@diploma) %>
 | 
			
		||||
      <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 @diploma.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 @diploma.tag_ids.include?(tag.id) %>">
 | 
			
		||||
              <%= check_box_tag 'diploma[tag_ids][]', tag.id, @diploma.tag_ids.include?(tag.id) %> <%= tag.name %>
 | 
			
		||||
              <%= hidden_field_tag 'diploma[tag_ids][]', '' %>
 | 
			
		||||
            </label>
 | 
			
		||||
          <% end %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
<!--Post End-->
 | 
			
		||||
  </div>
 | 
			
		||||
 | 
			
		||||
  <!-- Language Tabs -->
 | 
			
		||||
  <div class="nav-name"><strong><%= t(:language) %></strong></div>
 | 
			
		||||
  <ul class="nav nav-pills language-nav">
 | 
			
		||||
    <% @site_valid_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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
    
 | 
			
		||||
      <div class="<%= locale %> tab-pane fade <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
 | 
			
		||||
        <!-- school_name-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_diploma.school_name") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :school_name_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_diploma.school_name"), value: (@diploma.school_name_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- country-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_diploma.country") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :country_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_diploma.country"), value: (@diploma.country_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- department-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_diploma.department") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :department_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_diploma.department"), value: (@diploma.department_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- degree-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_diploma.degree") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :degree_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_diploma.degree"), value: (@diploma.degree_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
    <% end %>
 | 
			
		||||
 | 
			
		||||
  </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' %>
 | 
			
		||||
  <%= f.submit t('submit'), class: 'btn btn-primary' %>
 | 
			
		||||
  <%= link_to t('cancel'), get_go_back, :class=>"btn" %>  
 | 
			
		||||
</div>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,12 +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' %>
 | 
			
		||||
 | 
			
		||||
<h1><%= t('personal_diploma.editing_personal_diploma') %></h1>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%= form_for @diploma, :url => panel_personal_diploma_back_end_diploma_path(@diploma), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @diploma, url: panel_personal_diploma_back_end_diploma_path(@diploma), html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -13,10 +13,9 @@
 | 
			
		|||
<table class="table main-list">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span2"><%= t('date_') %></th>
 | 
			
		||||
			<th class="span5"><%= t('personal_diploma.school_name') %></th>
 | 
			
		||||
			<th class="span1"><%= t("personal_plugins.author") %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody id="tbody_diplomas" class="sort-holder">
 | 
			
		||||
| 
						 | 
				
			
			@ -24,10 +23,12 @@
 | 
			
		|||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<div class="form-actions form-fixed pagination-right">
 | 
			
		||||
<div class="bottomnav clearfix">
 | 
			
		||||
	<div class="action pull-right">
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-cog icon-white') + t('setting'), panel_personal_diploma_back_end_diploma_setting_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t('announcement.add_new'), new_panel_personal_diploma_back_end_diploma_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<div id="diploma_pagination" class="paginationFixed">
 | 
			
		||||
	<%= paginate @diplomas_page, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
	  <%= paginate @diplomas, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
</div>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,18 +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' %>
 | 
			
		||||
 | 
			
		||||
<%= flash_messages %>
 | 
			
		||||
 | 
			
		||||
<div id="poststuff">
 | 
			
		||||
<h1><%= t('diploma.new_personal_diploma') %></h1>
 | 
			
		||||
<%= form_for @diploma, :url => panel_personal_diploma_back_end_diplomas_path, :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<% end %>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%#= link_back %>
 | 
			
		||||
 | 
			
		||||
<%= form_for @diploma, url: panel_personal_diploma_back_end_diplomas_path, html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,11 +1,21 @@
 | 
			
		|||
<%
 | 
			
		||||
  if @member
 | 
			
		||||
    @diplomas = Diploma.where(:create_user_id => @member.id).desc(:start_date)
 | 
			
		||||
  else
 | 
			
		||||
    @diplomas = Diploma.all.desc(:start_date)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
    @diplomas = Diploma.where(is_hidden: false, :create_user_id => @member.id).desc(:start_date)
 | 
			
		||||
 | 
			
		||||
    @diploma_intro = !PersonalDiplomaIntro.where(:user_id => @member.id).blank? ? PersonalDiplomaIntro.where(:user_id => @member.id).first : PersonalDiplomaIntro.new
 | 
			
		||||
%>
 | 
			
		||||
 | 
			
		||||
  <% if @diploma_intro.brief_intro and !@diploma_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <div class="info">
 | 
			
		||||
        <%= @diploma_intro.text.html_safe rescue '' %>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% if ( !@diploma_intro.blank? and @diploma_intro.complete_list ) or @diploma_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <% if !@diplomas.blank? %> 
 | 
			
		||||
 | 
			
		||||
      <table class="table">
 | 
			
		||||
| 
						 | 
				
			
			@ -31,8 +41,8 @@
 | 
			
		|||
        </tbody>
 | 
			
		||||
      </table>
 | 
			
		||||
 | 
			
		||||
<% else %> 
 | 
			
		||||
 | 
			
		||||
  <%= t('nothing')%>
 | 
			
		||||
    <% end %>
 | 
			
		||||
 | 
			
		||||
  <% end %>
 | 
			
		||||
 | 
			
		||||
<% end %> 
 | 
			
		||||
| 
						 | 
				
			
			@ -1,3 +1,10 @@
 | 
			
		|||
<% 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]
 | 
			
		||||
| 
						 | 
				
			
			@ -17,17 +24,29 @@
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  if @user
 | 
			
		||||
    @diplomas = Diploma.where(:create_user_id => @user.id).page(params[:page]).per(10)
 | 
			
		||||
  if @user && is_admin?
 | 
			
		||||
    @diplomas = Diploma.where(:create_user_id => @user.id).desc(:start_date).page(params[:page]).per(10)
 | 
			
		||||
  else
 | 
			
		||||
    @diplomas = Diploma.all.page(params[:page]).per(10)
 | 
			
		||||
    @diplomas = Diploma.where(is_hidden: false, :create_user_id => @user.id).desc(:start_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_diploma_back_end_diplomas_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_diploma_back_end_diplomas_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('date_') %></th>
 | 
			
		||||
			<th><%= t('personal_diploma.school_name') %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
| 
						 | 
				
			
			@ -36,7 +55,12 @@
 | 
			
		|||
		
 | 
			
		||||
	<% @diplomas.each do |diploma| %>	
 | 
			
		||||
			
 | 
			
		||||
    <tr>
 | 
			
		||||
    <tr class="<%= diploma.is_hidden ? "checkHide" : "" %>">
 | 
			
		||||
      <% if is_admin? %>
 | 
			
		||||
      <td>
 | 
			
		||||
        <%= check_box_tag 'to_change[]', diploma.id.to_s, false, :class => "list-check" %>
 | 
			
		||||
      </td>
 | 
			
		||||
      <% end -%>
 | 
			
		||||
			<td><%= diploma.start_date.strftime("%Y.%m") %> ~ <%= diploma.end_date.strftime("%Y.%m") %></td>
 | 
			
		||||
			<td>
 | 
			
		||||
			<%= link_to diploma.school_name, panel_personal_diploma_front_end_diploma_path(diploma) %>
 | 
			
		||||
| 
						 | 
				
			
			@ -48,11 +72,25 @@
 | 
			
		|||
  </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_diploma_back_end_personal_diploma_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_diploma_back_end_diploma_path(:user_id => @user.id), :class => 'btn btn-primary' %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @diplomas, :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>
 | 
			
		||||
| 
						 | 
				
			
			@ -13,9 +13,11 @@ Rails.application.routes.draw do
 | 
			
		|||
        resources :diplomas do
 | 
			
		||||
          collection do
 | 
			
		||||
            get 'delete'
 | 
			
		||||
            get 'data_share'
 | 
			
		||||
          end
 | 
			
		||||
        end
 | 
			
		||||
		
 | 
			
		||||
        resources :personal_diploma_intros
 | 
			
		||||
        resources :tags
 | 
			
		||||
      end
 | 
			
		||||
      namespace :front_end do
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2,7 +2,7 @@ module PersonalDiploma
 | 
			
		|||
  OrbitApp.registration "PersonalDiploma",:type=> 'ModuleApp' do
 | 
			
		||||
    module_label 'module_name.personal_diploma'
 | 
			
		||||
    base_url File.expand_path File.dirname(__FILE__)    
 | 
			
		||||
    personal_plugin :enable => true,:path=>"panel/personal_diploma/plugin/profile",:front_path=>"panel/personal_diploma/front_end/profile",:admin_path=>"/panel/personal_diploma/back_end/diplomas",:i18n=>'module_name.personal_diploma'
 | 
			
		||||
    personal_plugin :enable => true, :app_name=>"Diploma", :intro_app_name=>"PersonalDiplomaIntro",:path=>"panel/personal_diploma/plugin/profile",:front_path=>"panel/personal_diploma/front_end/profile",:admin_path=>"/panel/personal_diploma/back_end/diplomas",:i18n=>'module_name.personal_diploma'
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -10,40 +10,19 @@ class Panel::PersonalExperience::BackEnd::ExperiencesController < OrbitBackendCo
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
  def index
 | 
			
		||||
  
 | 
			
		||||
    get_plugins
 | 
			
		||||
 | 
			
		||||
  get_categorys("ExperienceCategory",params[:experience_category_ids])
 | 
			
		||||
  @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
 | 
			
		||||
  
 | 
			
		||||
  @experience_categorys =  get_categories_for_index("ExperienceCategory")
 | 
			
		||||
  @experience_category_ids = @experience_categorys.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
  @experiences = (params[:sort] || @filter) ? get_sorted_and_filtered("experience",:experience_category_id.in => @experience_category_ids) : get_viewable("experience",:experience_category_id.in => @experience_category_ids)
 | 
			
		||||
  @experience_pages = @experiences.page params[:page]
 | 
			
		||||
 | 
			
		||||
  @tags = get_tags
 | 
			
		||||
    # @tags = get_tags
 | 
			
		||||
    # @categories = get_categories_for_index
 | 
			
		||||
    # @statuses = get_statuses
 | 
			
		||||
    # category_ids = @categories.collect{|t| t.id}
 | 
			
		||||
    @experience_category_ids = ExperienceCategory.all.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
 | 
			
		||||
    @experiences = get_sorted_and_filtered("experience", :experience_category_id.in => @experience_category_ids)
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      format.html # index.html.erb
 | 
			
		||||
      format.js { }
 | 
			
		||||
      format.xml  { render :xml => @experiences }
 | 
			
		||||
      format.js
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -154,7 +133,7 @@ class Panel::PersonalExperience::BackEnd::ExperiencesController < OrbitBackendCo
 | 
			
		|||
      if @experience.save
 | 
			
		||||
	  
 | 
			
		||||
		    if params[:experience][:user_id]
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:experience][:user_id],:show_plugin_profile=>'Experience')) }
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:experience][:user_id],:show_plugin_profile=>"Experience")) }
 | 
			
		||||
        else
 | 
			
		||||
		      format.html { redirect_to(panel_personal_experience_back_end_experiences_url) }
 | 
			
		||||
        end
 | 
			
		||||
| 
						 | 
				
			
			@ -203,6 +182,7 @@ class Panel::PersonalExperience::BackEnd::ExperiencesController < OrbitBackendCo
 | 
			
		|||
        format.xml  { render :xml => @experience.errors, :status => :unprocessable_entity }
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  end
 | 
			
		||||
| 
						 | 
				
			
			@ -227,6 +207,29 @@ class Panel::PersonalExperience::BackEnd::ExperiencesController < OrbitBackendCo
 | 
			
		|||
    redirect_to panel_personal_experience_back_end_experiences_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def data_share
 | 
			
		||||
 | 
			
		||||
    if params[:ids]
 | 
			
		||||
    
 | 
			
		||||
      @experiences = Experience.any_in(:_id => params[:ids])
 | 
			
		||||
      
 | 
			
		||||
      @experiences.each do |experience|
 | 
			
		||||
 | 
			
		||||
        experience.is_hidden = params[:disable]
 | 
			
		||||
 | 
			
		||||
        experience.save
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
    
 | 
			
		||||
      format.html { redirect_to(admin_users_new_interface_url(:id=>params[:user_id],:show_plugin_profile=>"Experience")) }
 | 
			
		||||
      
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  protected
 | 
			
		||||
 
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,10 @@
 | 
			
		|||
class Panel::PersonalExperience::BackEnd::PersonalExperienceIntrosController < Admin::PersonalPluginIntrosController
 | 
			
		||||
 | 
			
		||||
  def initialize
 | 
			
		||||
    super
 | 
			
		||||
    @app_type = 'personal_experience_intro'
 | 
			
		||||
    @app_type_name = 'personal_experience'
 | 
			
		||||
    @reback_name = 'Experience'
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
							
								
								
									
										4
									
								
								vendor/built_in_modules/personal_experience/app/models/personal_experience_intro.rb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										4
									
								
								vendor/built_in_modules/personal_experience/app/models/personal_experience_intro.rb
								
								
								
									vendored
								
								
									Normal file
								
							| 
						 | 
				
			
			@ -0,0 +1,4 @@
 | 
			
		|||
class PersonalExperienceIntro < PersonalPluginIntro
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -1,9 +1,4 @@
 | 
			
		|||
<tr id="<%= dom_id experience %>" class="with_action">
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
		<% if (experience.create_user_id ==  current_user.id) || is_manager? %>
 | 
			
		||||
			<%= check_box_tag 'to_delete[]', experience.id, false, :class => "checkbox_in_list" %>
 | 
			
		||||
		<% end -%>
 | 
			
		||||
	</td>
 | 
			
		||||
	<td class="span1"><%= experience.start_date.strftime("%Y.%m") %> ~ <%= experience.end_date.strftime("%Y.%m") %></td>
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
	<%= experience.organizationt_title %>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,133 +1,208 @@
 | 
			
		|||
<% # 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 %>
 | 
			
		||||
 | 
			
		||||
	<!--Widget start-->
 | 
			
		||||
<!-- Input Area -->
 | 
			
		||||
<div class="input-area">
 | 
			
		||||
 | 
			
		||||
	<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 'experience[tag_ids][]', tag.id, @experience.tag_ids.include?(tag.id)%>
 | 
			
		||||
						<%= tag.name %>
 | 
			
		||||
            <%= hidden_field_tag 'experience[tag_ids][]', '' %>
 | 
			
		||||
  <!-- 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(@experience) %>
 | 
			
		||||
      <li>
 | 
			
		||||
        <a href="#status" data-toggle="tab"><%= t(:status) %></a>
 | 
			
		||||
      </li>
 | 
			
		||||
    <% end %>
 | 
			
		||||
				<% end %>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>  
 | 
			
		||||
    <li>
 | 
			
		||||
      <a href="#tag" data-toggle="tab"><%= t(:tags) %></a>
 | 
			
		||||
    </li>
 | 
			
		||||
  </ul>
 | 
			
		||||
 | 
			
		||||
	</div>
 | 
			
		||||
  <!-- Module -->
 | 
			
		||||
  <div class="tab-content module-area">
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
<!--Wiget End-->
 | 
			
		||||
<!--Post Start-->
 | 
			
		||||
 | 
			
		||||
	<div id="post-body">
 | 
			
		||||
		<div id="post-body-content" class="clear">
 | 
			
		||||
    <!-- Basic Module -->
 | 
			
		||||
    <div class="tab-pane fade in active" id="basic">
 | 
			
		||||
 | 
			
		||||
      <% if !params[:user_id].blank? %>
 | 
			
		||||
      
 | 
			
		||||
			<div class="span6">
 | 
			
		||||
				<%= t("著作人")%>
 | 
			
		||||
      <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 %>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :experience_category ,t("personal_experience.experience_category")%>
 | 
			
		||||
      <!-- experience_category -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_experience.experience_category") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.select :experience_category_id, @experience_categorys.collect {|t| [ t.title, t.id ]} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :start_date ,t("personal_experience.start_date")%>
 | 
			
		||||
      <!-- start_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_experience.start_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.date_select :start_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1890, :order => [:year, :month], :discard_day => true }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :end_date ,t("personal_experience.end_date")%>
 | 
			
		||||
      <!-- end_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_experience.end_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.date_select :end_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1890, :order => [:year, :month], :discard_day => true }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
			
 | 
			
		||||
			<ul class="nav nav-tabs">
 | 
			
		||||
				<% @site_valid_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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
				
 | 
			
		||||
				<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
					
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :organizationt_title ,t("personal_experience.organizationt_title")%>
 | 
			
		||||
						<%= f.fields_for :organizationt_title_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@experience.organizationt_title_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :department ,t("personal_experience.department")%>
 | 
			
		||||
						<%= f.fields_for :department_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@experience.department_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
      <!-- url -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_experience.url") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_field :url , :class => "span6" %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
					<div class="title">
 | 
			
		||||
						<%= f.label :job_title ,t("personal_experience.job_title")%>
 | 
			
		||||
						<%= f.fields_for :job_title_translations do |f| %>
 | 
			
		||||
							<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
							<%= f.text_field locale, :class=>'post-title', :value => (@experience.job_title_translations[locale] rescue nil) %>
 | 
			
		||||
						<% end %>
 | 
			
		||||
					</div>
 | 
			
		||||
					
 | 
			
		||||
				</div>
 | 
			
		||||
 | 
			
		||||
				<% end %>
 | 
			
		||||
				
 | 
			
		||||
			</div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :url, t("personal_experience.url") %>
 | 
			
		||||
				<%= f.text_field :url %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :keywords, t("personal_experience.keywords") %>
 | 
			
		||||
      <!-- keywords -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_experience.keywords") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_field :keywords %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div id="title">
 | 
			
		||||
				<%= f.label :language, t("personal_experience.language") %>
 | 
			
		||||
      <!-- language -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_experience.language") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.radio_button :language, "Chinese" %> <%= t("personal_experience.Chinese") %>
 | 
			
		||||
          <%= f.radio_button :language, "English" %> <%= t("personal_experience.English") %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :note, t("personal_experience.note") %>
 | 
			
		||||
				<%= f.text_area :note, :size => "60x3" %>
 | 
			
		||||
      <!-- note -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_experience.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(@experience) %>
 | 
			
		||||
      <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 @experience.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 @experience.tag_ids.include?(tag.id) %>">
 | 
			
		||||
              <%= check_box_tag 'experience[tag_ids][]', tag.id, @experience.tag_ids.include?(tag.id) %> <%= tag.name %>
 | 
			
		||||
              <%= hidden_field_tag 'experience[tag_ids][]', '' %>
 | 
			
		||||
            </label>
 | 
			
		||||
          <% end %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
<!--Post End-->
 | 
			
		||||
  </div>
 | 
			
		||||
 | 
			
		||||
  <!-- Language Tabs -->
 | 
			
		||||
  <div class="nav-name"><strong><%= t(:language) %></strong></div>
 | 
			
		||||
  <ul class="nav nav-pills language-nav">
 | 
			
		||||
    <% @site_valid_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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
    
 | 
			
		||||
      <div class="<%= locale %> tab-pane fade <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
 | 
			
		||||
        <!-- organizationt_title-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_experience.organizationt_title") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :organizationt_title_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_experience.organizationt_title"), value: (@experience.school_name_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- department-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_experience.department") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :department_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_experience.department"), value: (@experience.department_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- job_title-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_experience.job_title") %></label>
 | 
			
		||||
          <div class="controls">
 | 
			
		||||
            <%= f.fields_for :job_title_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_experience.job_title"), value: (@experience.job_title_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
    <% end %>
 | 
			
		||||
 | 
			
		||||
  </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' %>
 | 
			
		||||
  <%= f.submit t('submit'), class: 'btn btn-primary' %>
 | 
			
		||||
  <%= link_to t('cancel'), get_go_back, :class=>"btn" %>  
 | 
			
		||||
</div>
 | 
			
		||||
| 
						 | 
				
			
			@ -8,8 +8,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<h1><%= t('personal_experience.editing_personal_experience') %></h1>
 | 
			
		||||
 | 
			
		||||
<%= form_for @experience, :url => panel_personal_experience_back_end_experience_path(@experience), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @experience, url: panel_personal_experience_back_end_experience_path(@experience), html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -15,7 +15,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_experience_back_end_experience_experience_category_quick_add_path('add') %>#myModal1" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>機關類別</span>                        
 | 
			
		||||
                        <span><%= t("personal_experience.experience_category") %></span>                        
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -13,12 +13,11 @@
 | 
			
		|||
<table class="table main-list">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span2"><%= t('date_') %></th>
 | 
			
		||||
			<th class="span2"><%= t('personal_experience.organizationt_title') %></th>
 | 
			
		||||
			<th class="span2"><%= t('personal_experience.department') %></th>
 | 
			
		||||
			<th class="span2"><%= t('personal_experience.job_title') %></th>
 | 
			
		||||
			<th class="span1"><%= t("personal_plugins.author") %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody id="tbody_experiences" class="sort-holder">
 | 
			
		||||
| 
						 | 
				
			
			@ -26,10 +25,12 @@
 | 
			
		|||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<div class="form-actions form-fixed pagination-right">
 | 
			
		||||
<div class="bottomnav clearfix">
 | 
			
		||||
	<div class="action pull-right">
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-cog icon-white') + t('setting'), panel_personal_experience_back_end_experience_setting_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t('announcement.add_new'), new_panel_personal_experience_back_end_experience_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<div id="experience_pagination" class="paginationFixed">
 | 
			
		||||
	<%= paginate @experience_pages, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
	  <%= paginate @experiences, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
</div>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -8,14 +8,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%= flash_messages %>
 | 
			
		||||
 | 
			
		||||
<div id="poststuff">
 | 
			
		||||
<h1><%= t('experience.new_personal_experience') %></h1>
 | 
			
		||||
<%= form_for @experience, :url => panel_personal_experience_back_end_experiences_path, :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @experience, url: panel_personal_experience_back_end_experiences_path, html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%#= link_back %>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,11 +1,21 @@
 | 
			
		|||
<%
 | 
			
		||||
  if @member
 | 
			
		||||
    @experiences = Experience.where(:create_user_id => @member.id).desc(:start_date)
 | 
			
		||||
  else
 | 
			
		||||
    @experiences = Experience.all.desc(:start_date)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
    @experiences = Experience.where(is_hidden: false, :create_user_id => @member.id).desc(:start_date)
 | 
			
		||||
 | 
			
		||||
    @experience_intro = !PersonalExperienceIntro.where(:user_id => @member.id).blank? ? PersonalExperienceIntro.where(:user_id => @member.id).first : PersonalExperienceIntro.new
 | 
			
		||||
%>
 | 
			
		||||
 | 
			
		||||
  <% if @experience_intro.brief_intro and !@experience_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <div class="info">
 | 
			
		||||
        <%= @experience_intro.text.html_safe rescue '' %>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% if ( !@experience_intro.blank? and @experience_intro.complete_list ) or @experience_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <% if !@experiences.blank? %>  
 | 
			
		||||
 | 
			
		||||
      <table class="table">
 | 
			
		||||
| 
						 | 
				
			
			@ -31,8 +41,8 @@
 | 
			
		|||
        </tbody>
 | 
			
		||||
      </table>
 | 
			
		||||
 | 
			
		||||
<% else %> 
 | 
			
		||||
 | 
			
		||||
  <%= t('nothing')%>
 | 
			
		||||
    <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
<% end %> 
 | 
			
		||||
| 
						 | 
				
			
			@ -1,3 +1,10 @@
 | 
			
		|||
<% 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]
 | 
			
		||||
| 
						 | 
				
			
			@ -17,18 +24,29 @@
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  if @user
 | 
			
		||||
    @experiences = Experience.where(:create_user_id => @user.id).page(params[:page]).per(10)
 | 
			
		||||
  if @user && is_admin?
 | 
			
		||||
    @experiences = Experience.where(:create_user_id => @user.id).desc(:start_date).page(params[:page]).per(10)
 | 
			
		||||
  else
 | 
			
		||||
    @experiences = Experience.all.page(params[:page]).per(10)
 | 
			
		||||
    @experiences = Experience.where(is_hidden: false, :create_user_id => @user.id).desc(:start_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_experience_back_end_experiences_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_experience_back_end_experiences_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('date_') %></th>
 | 
			
		||||
			<th><%= t('personal_experience.organizationt_title') %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
| 
						 | 
				
			
			@ -37,7 +55,12 @@
 | 
			
		|||
		
 | 
			
		||||
	<% @experiences.each do |experience| %>	
 | 
			
		||||
			
 | 
			
		||||
    <tr>
 | 
			
		||||
    <tr class="<%= experience.is_hidden ? "checkHide" : "" %>">
 | 
			
		||||
      <% if is_admin? %>
 | 
			
		||||
      <td>
 | 
			
		||||
        <%= check_box_tag 'to_change[]', experience.id.to_s, false, :class => "list-check" %>
 | 
			
		||||
      </td>
 | 
			
		||||
      <% end -%>
 | 
			
		||||
			<td><%= experience.start_date.strftime("%Y.%m") %> ~ <%= experience.end_date.strftime("%Y.%m") %></td>
 | 
			
		||||
			<td>
 | 
			
		||||
			<%= link_to experience.organizationt_title, panel_personal_experience_front_end_experience_path(experience) %>
 | 
			
		||||
| 
						 | 
				
			
			@ -49,10 +72,24 @@
 | 
			
		|||
  </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_experience_back_end_personal_experience_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_experience_back_end_experience_path(:user_id => @user.id), :class => 'btn btn-primary' %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @experiences, :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>
 | 
			
		||||
| 
						 | 
				
			
			@ -13,11 +13,13 @@ Rails.application.routes.draw do
 | 
			
		|||
        resources :experiences do
 | 
			
		||||
          collection do
 | 
			
		||||
            get 'delete'
 | 
			
		||||
            get 'data_share'
 | 
			
		||||
          end
 | 
			
		||||
		  
 | 
			
		||||
          match "experience_category_quick_add" => "experiences#experience_category_quick_add" ,:as => :experience_category_quick_add
 | 
			
		||||
          match "experience_category_quick_edit" => "experiences#experience_category_quick_edit" ,:as => :experience_category_quick_edit
 | 
			
		||||
        end
 | 
			
		||||
        resources :personal_experience_intros
 | 
			
		||||
		    resources :experience_categorys
 | 
			
		||||
        resources :tags
 | 
			
		||||
      end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2,7 +2,7 @@ module PersonalExperience
 | 
			
		|||
  OrbitApp.registration "PersonalExperience",:type=> 'ModuleApp' do
 | 
			
		||||
    module_label 'module_name.personal_experience'
 | 
			
		||||
    base_url File.expand_path File.dirname(__FILE__)   
 | 
			
		||||
    personal_plugin :enable => true,:path=>"panel/personal_experience/plugin/profile",:front_path=>"panel/personal_experience/front_end/profile",:admin_path=>"/panel/personal_experience/back_end/experiences",:i18n=>'module_name.personal_experience'
 | 
			
		||||
    personal_plugin :enable => true, :app_name=>"Experience", :intro_app_name=>"PersonalExperienceIntro",:path=>"panel/personal_experience/plugin/profile",:front_path=>"panel/personal_experience/front_end/profile",:admin_path=>"/panel/personal_experience/back_end/experiences",:i18n=>'module_name.personal_experience'
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -9,40 +9,19 @@ class Panel::PersonalHonor::BackEnd::HonorsController < OrbitBackendController
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
  def index
 | 
			
		||||
  
 | 
			
		||||
    get_plugins
 | 
			
		||||
 | 
			
		||||
  get_categorys("HonorCategory",params[:honor_category_ids])
 | 
			
		||||
  @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
 | 
			
		||||
  
 | 
			
		||||
  @honor_categorys =  get_categories_for_index("HonorCategory")
 | 
			
		||||
  @honor_category_ids = @honor_categorys.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
  @honors = (params[:sort] || @filter) ? get_sorted_and_filtered("honor",:honor_category_id.in => @honor_category_ids) : get_viewable("honor",:honor_category_id.in => @honor_category_ids)
 | 
			
		||||
  @honor_pages = @honors.page params[:page]
 | 
			
		||||
 | 
			
		||||
  @tags = get_tags
 | 
			
		||||
    # @tags = get_tags
 | 
			
		||||
    # @categories = get_categories_for_index
 | 
			
		||||
    # @statuses = get_statuses
 | 
			
		||||
    # category_ids = @categories.collect{|t| t.id}
 | 
			
		||||
    @honor_category_ids = HonorCategory.all.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
 | 
			
		||||
    @honors = get_sorted_and_filtered("honor", :honor_category_id.in => @honor_category_ids)
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      format.html # index.html.erb
 | 
			
		||||
      format.js { }
 | 
			
		||||
      format.xml  { render :xml => @honors }
 | 
			
		||||
      format.js
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -156,7 +135,7 @@ class Panel::PersonalHonor::BackEnd::HonorsController < OrbitBackendController
 | 
			
		|||
      if @honor.save
 | 
			
		||||
	  
 | 
			
		||||
		    if params[:honor][:user_id]
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:honor][:user_id],:show_plugin_profile=>'Honor')) }
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:honor][:user_id],:show_plugin_profile=>"Honor")) }
 | 
			
		||||
        else
 | 
			
		||||
		      format.html { redirect_to(panel_personal_honor_back_end_honors_url) }
 | 
			
		||||
        end
 | 
			
		||||
| 
						 | 
				
			
			@ -229,6 +208,29 @@ class Panel::PersonalHonor::BackEnd::HonorsController < OrbitBackendController
 | 
			
		|||
    redirect_to panel_personal_honor_back_end_honors_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def data_share
 | 
			
		||||
 | 
			
		||||
    if params[:ids]
 | 
			
		||||
    
 | 
			
		||||
      @honors = Honor.any_in(:_id => params[:ids])
 | 
			
		||||
      
 | 
			
		||||
      @honors.each do |honor|
 | 
			
		||||
 | 
			
		||||
        honor.is_hidden = params[:disable]
 | 
			
		||||
 | 
			
		||||
        honor.save
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
    
 | 
			
		||||
      format.html { redirect_to(admin_users_new_interface_url(:id=>params[:user_id],:show_plugin_profile=>"Honor")) }
 | 
			
		||||
      
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  protected
 | 
			
		||||
 
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,10 @@
 | 
			
		|||
class Panel::PersonalHonor::BackEnd::PersonalHonorIntrosController < Admin::PersonalPluginIntrosController
 | 
			
		||||
 | 
			
		||||
  def initialize
 | 
			
		||||
    super
 | 
			
		||||
    @app_type = 'personal_honor_intro'
 | 
			
		||||
    @app_type_name = 'personal_honor'
 | 
			
		||||
    @reback_name = 'Honor'
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,4 @@
 | 
			
		|||
class PersonalHonorIntro < PersonalPluginIntro
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -1,97 +1,163 @@
 | 
			
		|||
<% # 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 %>
 | 
			
		||||
 | 
			
		||||
	<!--Widget start-->
 | 
			
		||||
<!-- Input Area -->
 | 
			
		||||
<div class="input-area">
 | 
			
		||||
 | 
			
		||||
	<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 'honor[tag_ids][]', tag.id, @honor.tag_ids.include?(tag.id)%>
 | 
			
		||||
						<%= tag.name %>
 | 
			
		||||
            <%= hidden_field_tag 'honor[tag_ids][]', '' %>
 | 
			
		||||
  <!-- 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(@honor) %>
 | 
			
		||||
      <li>
 | 
			
		||||
        <a href="#status" data-toggle="tab"><%= t(:status) %></a>
 | 
			
		||||
      </li>
 | 
			
		||||
    <% end %>
 | 
			
		||||
				<% end %>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>  
 | 
			
		||||
    <li>
 | 
			
		||||
      <a href="#tag" data-toggle="tab"><%= t(:tags) %></a>
 | 
			
		||||
    </li>
 | 
			
		||||
  </ul>
 | 
			
		||||
 | 
			
		||||
	</div>
 | 
			
		||||
  <!-- Module -->
 | 
			
		||||
  <div class="tab-content module-area">
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
<!--Wiget End-->
 | 
			
		||||
<!--Post Start-->
 | 
			
		||||
 | 
			
		||||
	<div id="post-body">
 | 
			
		||||
		<div id="post-body-content" class="clear">
 | 
			
		||||
    <!-- Basic Module -->
 | 
			
		||||
    <div class="tab-pane fade in active" id="basic">
 | 
			
		||||
 | 
			
		||||
      <% if !params[:user_id].blank? %>
 | 
			
		||||
      
 | 
			
		||||
			<div class="span6">
 | 
			
		||||
				<%= t("著作人")%>
 | 
			
		||||
      <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 %>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :year ,t("personal_honor.year")%>
 | 
			
		||||
				<%= select_year((@honor.year ? @honor.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'honor[year]'} ) %>
 | 
			
		||||
      <!-- personal_honor -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_honor.year") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= select_year((@honor.year ? @honor.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'honor[year]', :class => "span1"} ) %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :honor_category ,t("personal_honor.honor_category")%>
 | 
			
		||||
      <!-- honor_category -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_honor.honor_category") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.select :honor_category_id, @honor_categorys.collect {|t| [ t.title, t.id ]} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :award_name, t("personal_honor.award_name") %>
 | 
			
		||||
      <!-- award_name -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_honor.award_name") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_field :award_name %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :awarding_unit, t("personal_honor.awarding_unit") %>
 | 
			
		||||
      <!-- awarding_unit -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_honor.awarding_unit") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_field :awarding_unit %>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :url, t("personal_honor.url") %>
 | 
			
		||||
				<%= f.text_field :url %>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :keywords, t("personal_honor.keywords") %>
 | 
			
		||||
      <!-- url -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_honor.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_honor.keywords") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_field :keywords %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div id="title">
 | 
			
		||||
				<%= f.label :language, t("personal_honor.language") %>
 | 
			
		||||
      <!-- language -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_honor.language") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.radio_button :language, "Chinese" %> <%= t("personal_honor.Chinese") %>
 | 
			
		||||
          <%= f.radio_button :language, "English" %> <%= t("personal_honor.English") %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :note, t("personal_honor.note") %>
 | 
			
		||||
				<%= f.text_area :note, :size => "60x3" %>
 | 
			
		||||
      <!-- note -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_honor.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(@honor) %>
 | 
			
		||||
      <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 @honor.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 @honor.tag_ids.include?(tag.id) %>">
 | 
			
		||||
              <%= check_box_tag 'honor[tag_ids][]', tag.id, @honor.tag_ids.include?(tag.id) %> <%= tag.name %>
 | 
			
		||||
              <%= hidden_field_tag 'honor[tag_ids][]', '' %>
 | 
			
		||||
            </label>
 | 
			
		||||
          <% end %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
<!--Post End-->
 | 
			
		||||
  </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' %>
 | 
			
		||||
  <%= f.submit t('submit'), class: 'btn btn-primary' %>
 | 
			
		||||
  <%= link_to t('cancel'), get_go_back, :class=>"btn" %>  
 | 
			
		||||
</div>
 | 
			
		||||
	
 | 
			
		||||
| 
						 | 
				
			
			@ -1,9 +1,4 @@
 | 
			
		|||
<tr id="<%= dom_id honor %>" class="with_action">
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
		<% if (honor.create_user_id ==  current_user.id) || is_manager? %>
 | 
			
		||||
			<%= check_box_tag 'to_delete[]', honor.id, false, :class => "checkbox_in_list" %>
 | 
			
		||||
		<% end -%>
 | 
			
		||||
	</td>
 | 
			
		||||
	<td class="span1"><%= honor.year %></td>
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
	<%= link_to honor.award_name, panel_personal_honor_front_end_honor_path(honor) %>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -8,8 +8,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<h1><%= t('personal_honor.editing_personal_honor') %></h1>
 | 
			
		||||
 | 
			
		||||
<%= form_for @honor, :url => panel_personal_honor_back_end_honor_path(@honor), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @honor, url: panel_personal_honor_back_end_honor_path(@honor), html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -15,7 +15,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_honor_back_end_honor_honor_category_quick_add_path('add') %>#myModal1" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>類別</span>                        
 | 
			
		||||
                        <span><%= t("personal_honor.honor_category") %></span>                        
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -13,11 +13,10 @@
 | 
			
		|||
<table class="table main-list">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"><%= t('personal_honor.year') %></th>
 | 
			
		||||
			<th class="span3"><%= t('personal_honor.award_name') %></th>
 | 
			
		||||
			<th class="span2"><%= t('personal_honor.awarding_unit') %></th>
 | 
			
		||||
			<th class="span1"><%= t("personal_plugins.author") %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody id="tbody_honors" class="sort-holder">
 | 
			
		||||
| 
						 | 
				
			
			@ -25,9 +24,12 @@
 | 
			
		|||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<div class="form-actions form-fixed pagination-right">
 | 
			
		||||
<div class="bottomnav clearfix">
 | 
			
		||||
	<div class="action pull-right"> 
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-cog icon-white') + t('setting'), panel_personal_honor_back_end_honor_setting_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t('announcement.add_new'), new_panel_personal_honor_back_end_honor_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<div id="honor_pagination" class="paginationFixed">
 | 
			
		||||
	<%= paginate @honor_pages, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @honors, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
</div>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -8,14 +8,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%= flash_messages %>
 | 
			
		||||
 | 
			
		||||
<div id="poststuff">
 | 
			
		||||
<h1><%= t('honor.new_personal_honor') %></h1>
 | 
			
		||||
<%= form_for @honor, :url => panel_personal_honor_back_end_honors_path, :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @honor, url: panel_personal_honor_back_end_honors_path, html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%#= link_back %>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,11 +1,21 @@
 | 
			
		|||
<%
 | 
			
		||||
  if @member
 | 
			
		||||
    @honors = Honor.where(:create_user_id => @member.id).desc(:year)
 | 
			
		||||
  else
 | 
			
		||||
    @honors = Honor.all.desc(:year)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
    @honors = Honor.where(is_hidden: false, :create_user_id => @member.id).desc(:year)
 | 
			
		||||
 | 
			
		||||
    @honor_intro = !PersonalHonorIntro.where(:user_id => @member.id).blank? ? PersonalHonorIntro.where(:user_id => @member.id).first : PersonalHonorIntro.new
 | 
			
		||||
%>
 | 
			
		||||
 | 
			
		||||
  <% if @honor_intro.brief_intro and !@honor_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <div class="info">
 | 
			
		||||
        <%= @honor_intro.text.html_safe rescue '' %>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% if ( !@honor_intro.blank? and @honor_intro.complete_list ) or @honor_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <% if !@honors.blank? %> 
 | 
			
		||||
 | 
			
		||||
      <table class="table">
 | 
			
		||||
| 
						 | 
				
			
			@ -31,8 +41,9 @@
 | 
			
		|||
        </tbody>
 | 
			
		||||
      </table>
 | 
			
		||||
 | 
			
		||||
<% else %> 
 | 
			
		||||
 | 
			
		||||
  <%= t('nothing')%>
 | 
			
		||||
    <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
<% end %> 
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,3 +1,10 @@
 | 
			
		|||
<% 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]
 | 
			
		||||
| 
						 | 
				
			
			@ -17,18 +24,29 @@
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  if @user
 | 
			
		||||
    @honors = Honor.where(:create_user_id => @user.id).page(params[:page]).per(10)
 | 
			
		||||
  if @user && is_admin?
 | 
			
		||||
    @honors = Honor.where(:create_user_id => @user.id).desc(:year).page(params[:page]).per(10)
 | 
			
		||||
  else
 | 
			
		||||
    @honors = Honor.all.page(params[:page]).per(10)
 | 
			
		||||
    @honors = Honor.where(is_hidden: false, :create_user_id => @user.id).desc(:year).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_honor_back_end_honors_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_honor_back_end_honors_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="span1"><%= t('personal_honor.year') %></th>
 | 
			
		||||
			<th><%= t('personal_honor.award_name') %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
| 
						 | 
				
			
			@ -37,7 +55,12 @@
 | 
			
		|||
		
 | 
			
		||||
	<% @honors.each do |honor| %>	
 | 
			
		||||
			
 | 
			
		||||
    <tr>
 | 
			
		||||
    <tr class="<%= honor.is_hidden ? "checkHide" : "" %>">
 | 
			
		||||
      <% if is_admin? %>
 | 
			
		||||
      <td>
 | 
			
		||||
        <%= check_box_tag 'to_change[]', honor.id.to_s, false, :class => "list-check" %>
 | 
			
		||||
      </td>
 | 
			
		||||
      <% end -%>
 | 
			
		||||
			<td><%= honor.year %></td>
 | 
			
		||||
			<td>
 | 
			
		||||
		<%= link_to honor.award_name, panel_personal_honor_front_end_honor_path(honor) %>
 | 
			
		||||
| 
						 | 
				
			
			@ -49,11 +72,25 @@
 | 
			
		|||
  </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_honor_back_end_personal_honor_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_honor_back_end_honor_path(:user_id => @user.id), :class => 'btn btn-primary' %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @honors, :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>
 | 
			
		||||
| 
						 | 
				
			
			@ -14,11 +14,13 @@ Rails.application.routes.draw do
 | 
			
		|||
        resources :honors do
 | 
			
		||||
          collection do
 | 
			
		||||
            get 'delete'
 | 
			
		||||
            get 'data_share'
 | 
			
		||||
          end
 | 
			
		||||
		  
 | 
			
		||||
          match "honor_category_quick_add" => "honors#honor_category_quick_add" ,:as => :honor_category_quick_add
 | 
			
		||||
          match "honor_category_quick_edit" => "honors#honor_category_quick_edit" ,:as => :honor_category_quick_edit
 | 
			
		||||
        end
 | 
			
		||||
        resources :personal_honor_intros
 | 
			
		||||
        resources :honor_categorys
 | 
			
		||||
        resources :tags
 | 
			
		||||
      end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2,7 +2,7 @@ module PersonalHonor
 | 
			
		|||
  OrbitApp.registration "PersonalHonor",:type=> 'ModuleApp' do
 | 
			
		||||
    module_label 'module_name.personal_honor'
 | 
			
		||||
    base_url File.expand_path File.dirname(__FILE__)  
 | 
			
		||||
    personal_plugin :enable => true,:path=>"panel/personal_honor/plugin/profile",:front_path=>"panel/personal_honor/front_end/profile",:admin_path=>"/panel/personal_honor/back_end/honors",:i18n=>'module_name.personal_honor'
 | 
			
		||||
    personal_plugin :enable => true, :app_name=>"Honor", :intro_app_name=>"PersonalHonorIntro",:path=>"panel/personal_honor/plugin/profile",:front_path=>"panel/personal_honor/front_end/profile",:admin_path=>"/panel/personal_honor/back_end/honors",:i18n=>'module_name.personal_honor'
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,10 @@
 | 
			
		|||
class Panel::PersonalJournal::BackEnd::PersonalJournalIntrosController < Admin::PersonalPluginIntrosController
 | 
			
		||||
 | 
			
		||||
  def initialize
 | 
			
		||||
    super
 | 
			
		||||
    @app_type = 'personal_journal_intro'
 | 
			
		||||
    @app_type_name = 'personal_journal'
 | 
			
		||||
    @reback_name = 'WritingJournal'
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -9,43 +9,19 @@ class Panel::PersonalJournal::BackEnd::WritingJournalsController < OrbitBackendC
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
  def index
 | 
			
		||||
  
 | 
			
		||||
    get_plugins
 | 
			
		||||
 | 
			
		||||
  get_categorys("JournalPaperType",params[:journal_paper_type_id])
 | 
			
		||||
  @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
 | 
			
		||||
  
 | 
			
		||||
  @paper_types =  JournalPaperType.all
 | 
			
		||||
  @paper_type_ids = @paper_types.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
  
 | 
			
		||||
  @level_types = JournalLevelType.all
 | 
			
		||||
 | 
			
		||||
	# @writing_journals = WritingJournal.search(params[:category_id])
 | 
			
		||||
	#@writing_journals = (params[:sort] || @filter) ? get_sorted_and_filtered_writing_journals : WritingJournal.all.page(params[:page]).per(10)
 | 
			
		||||
  @writing_journals = (params[:sort] || @filter) ? get_sorted_and_filtered("writing_journal",:journal_paper_type_id.in => @paper_type_ids) : get_viewable("writing_journal",:journal_paper_type_id.in => @paper_type_ids)
 | 
			
		||||
  @writing_journal_pages = @writing_journals.page params[:page]
 | 
			
		||||
 | 
			
		||||
  @tags = get_tags
 | 
			
		||||
    # @tags = get_tags
 | 
			
		||||
    # @categories = get_categories_for_index
 | 
			
		||||
    # @statuses = get_statuses
 | 
			
		||||
    # category_ids = @categories.collect{|t| t.id}
 | 
			
		||||
    @paper_type_ids = JournalPaperType.all.collect{|t| t.id.to_s} + [nil]
 | 
			
		||||
 | 
			
		||||
    @writing_journals = get_sorted_and_filtered("writing_journal", :journal_paper_type_id.in => @paper_type_ids)
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      format.html # index.html.erb
 | 
			
		||||
      format.js { }
 | 
			
		||||
      format.xml  { render :xml => @writing_journals }
 | 
			
		||||
      format.js
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -235,7 +211,7 @@ class Panel::PersonalJournal::BackEnd::WritingJournalsController < OrbitBackendC
 | 
			
		|||
      if @writing_journal.save
 | 
			
		||||
	  
 | 
			
		||||
		    if params[:writing_journal][:user_id]
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:writing_journal][:user_id],:show_plugin_profile=>'Journal')) }
 | 
			
		||||
          format.html { redirect_to(admin_users_new_interface_url(:id=>params[:writing_journal][:user_id],:show_plugin_profile=>"WritingJournal")) }
 | 
			
		||||
        else
 | 
			
		||||
		      format.html { redirect_to(panel_personal_journal_back_end_writing_journals_url) }
 | 
			
		||||
        end
 | 
			
		||||
| 
						 | 
				
			
			@ -293,7 +269,6 @@ class Panel::PersonalJournal::BackEnd::WritingJournalsController < OrbitBackendC
 | 
			
		|||
		
 | 
			
		||||
  	else
 | 
			
		||||
	
 | 
			
		||||
	
 | 
			
		||||
      @writing_journal = WritingJournal.find(params[:id])
 | 
			
		||||
	
 | 
			
		||||
      @writing_journal.update_user_id = current_user.id
 | 
			
		||||
| 
						 | 
				
			
			@ -334,6 +309,29 @@ class Panel::PersonalJournal::BackEnd::WritingJournalsController < OrbitBackendC
 | 
			
		|||
    redirect_to panel_personal_journal_back_end_writing_journals_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def data_share
 | 
			
		||||
 | 
			
		||||
    if params[:ids]
 | 
			
		||||
    
 | 
			
		||||
      @writing_journals = WritingJournal.any_in(:_id => params[:ids])
 | 
			
		||||
      
 | 
			
		||||
      @writing_journals.each do |writing_journal|
 | 
			
		||||
 | 
			
		||||
        writing_journal.is_hidden = params[:disable]
 | 
			
		||||
 | 
			
		||||
        writing_journal.save
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
    
 | 
			
		||||
      format.html { redirect_to(admin_users_new_interface_url(:id=>params[:user_id],:show_plugin_profile=>"WritingJournal")) }
 | 
			
		||||
      
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
  protected
 | 
			
		||||
 
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										4
									
								
								vendor/built_in_modules/personal_journal/app/models/personal_journal_intro.rb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										4
									
								
								vendor/built_in_modules/personal_journal/app/models/personal_journal_intro.rb
								
								
								
									vendored
								
								
									Normal file
								
							| 
						 | 
				
			
			@ -0,0 +1,4 @@
 | 
			
		|||
class PersonalJournalIntro < PersonalPluginIntro
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -1,295 +1,345 @@
 | 
			
		|||
<% # 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 %>
 | 
			
		||||
 | 
			
		||||
	<!--Widget start-->
 | 
			
		||||
<!-- Input Area -->
 | 
			
		||||
<div class="input-area">
 | 
			
		||||
 | 
			
		||||
	<div id="sub-wiget">
 | 
			
		||||
	
 | 
			
		||||
		<div class="widget-box widget-size-300" id="widget-intro">
 | 
			
		||||
			<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="icon-book"></i><%= f.label :abstract, t("personal_journal.abstract") %></h3>
 | 
			
		||||
			<div class="widget-content clear form-horizontal">
 | 
			
		||||
				<%= f.text_area :abstract, :size => "60x3" %>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>
 | 
			
		||||
	
 | 
			
		||||
		<div class="widget-box widget-size-300" id="widget-intro">
 | 
			
		||||
			<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="icon-book"></i><%= f.label :abstract, t("personal_journal.note") %></h3>
 | 
			
		||||
			<div class="widget-content clear form-horizontal">
 | 
			
		||||
				<%= f.text_area :note, :size => "60x3" %>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>
 | 
			
		||||
  
 | 
			
		||||
 | 
			
		||||
		<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 'writing_journal[tag_ids][]', tag.id, @writing_journal.tag_ids.include?(tag.id)%>
 | 
			
		||||
						<%= tag.name %>
 | 
			
		||||
            <%= hidden_field_tag 'writing_journal[tag_ids][]', '' %>
 | 
			
		||||
  <!-- 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(@writing_journal) %>
 | 
			
		||||
      <li>
 | 
			
		||||
        <a href="#status" data-toggle="tab"><%= t(:status) %></a>
 | 
			
		||||
      </li>
 | 
			
		||||
    <% end %>
 | 
			
		||||
				<% end %>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>  
 | 
			
		||||
    <li>
 | 
			
		||||
      <a href="#tag" data-toggle="tab"><%= t(:tags) %></a>
 | 
			
		||||
    </li>
 | 
			
		||||
  </ul>
 | 
			
		||||
 | 
			
		||||
	</div>
 | 
			
		||||
  <!-- Module -->
 | 
			
		||||
  <div class="tab-content module-area">
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
<!--Wiget End-->
 | 
			
		||||
<!--Post Start-->
 | 
			
		||||
 | 
			
		||||
	<div id="post-body">
 | 
			
		||||
		<div id="post-body-content" class="clear">
 | 
			
		||||
    <!-- Basic Module -->
 | 
			
		||||
    <div class="tab-pane fade in active" id="basic">
 | 
			
		||||
 | 
			
		||||
      <% if !params[:user_id].blank? %>
 | 
			
		||||
      
 | 
			
		||||
			<div class="span6">
 | 
			
		||||
				<%= t("著作人")%>
 | 
			
		||||
      <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>
 | 
			
		||||
			
 | 
			
		||||
			<% end %>		
 | 
			
		||||
			
 | 
			
		||||
			<div class="span6">
 | 
			
		||||
				<%= f.label :year ,t("personal_journal.year")%>
 | 
			
		||||
				<%= select_year((@writing_journal.year ? @writing_journal.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'writing_journal[year]', :class => "span6"} ) %>
 | 
			
		||||
			</div>
 | 
			
		||||
 | 
			
		||||
			<div class="span6">
 | 
			
		||||
				<%= f.label :language, t("personal_journal.language") %>
 | 
			
		||||
				<%= f.select :language, WritingJournal::LANGUAGE_TYPES, :prompt => 'Select', :class => "span6" %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<ul class="nav nav-tabs">
 | 
			
		||||
				<% @site_valid_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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
				
 | 
			
		||||
				<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
				
 | 
			
		||||
					<%= f.label :paper_title ,t("personal_journal.paper_title")%>
 | 
			
		||||
					<%= f.fields_for :paper_title_translations do |f| %>
 | 
			
		||||
						<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
						<%= f.text_field locale, :class=>'span12', :value => (@writing_journal.paper_title_translations[locale] rescue nil) %>
 | 
			
		||||
					<% end %>
 | 
			
		||||
					<br>
 | 
			
		||||
				
 | 
			
		||||
					<%= f.label :journal_title ,t("personal_journal.journal_title")%>
 | 
			
		||||
					<%= f.fields_for :journal_title_translations do |f| %>
 | 
			
		||||
						<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
						<%= f.text_field locale, :class=>'span12', :value => (@writing_journal.journal_title_translations[locale] rescue nil) %>
 | 
			
		||||
					<% end %>
 | 
			
		||||
					<br>
 | 
			
		||||
					
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <% end %> 
 | 
			
		||||
 | 
			
		||||
                <%= f.label :level_type ,t("personal_journal.level_type")%>
 | 
			
		||||
                <div class="form-inline">
 | 
			
		||||
                    <ul class="nav nav-pills">
 | 
			
		||||
					<% @level_types.each_with_index do |level_type, i| %>
 | 
			
		||||
						<li class="pull-left">
 | 
			
		||||
						<%= check_box_tag 'writing_journal[journal_level_type_ids][]', level_type.id, @writing_journal.journal_level_type_ids.include?(level_type.id), :id => "field-#{i}" %>
 | 
			
		||||
						<label for="field-<%= i %>"><%= level_type.title %></label>
 | 
			
		||||
      <!-- year -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.year") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= select_year((@writing_journal.year ? @writing_journal.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'writing_journal[year]', :class => "span1"} ) %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- language -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.language") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.select :language, WritingJournal::LANGUAGE_TYPES, :prompt => 'Select', :class => "span3" %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- level_type -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.level_type") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<% @level_types.each do |level_type| %>
 | 
			
		||||
				<%= content_tag :label,:class => "checkbox inline" do -%>
 | 
			
		||||
					<%= check_box_tag 'writing_journal[journal_level_type_ids][]', level_type.id, @writing_journal.journal_level_type_ids.include?(level_type.id)%>
 | 
			
		||||
					<%= level_type.title %>
 | 
			
		||||
	   			    <%= hidden_field_tag 'writing_journal[journal_level_type_ids][]', '' %>
 | 
			
		||||
						</li>
 | 
			
		||||
				<% end %>
 | 
			
		||||
                    </ul>
 | 
			
		||||
			<% end %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
                <div class="row">
 | 
			
		||||
      <!-- paper_type -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.paper_type") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.select :journal_paper_type_id, @paper_types.collect {|t| [ t.title, t.id ]}, :class => "span3" %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
                    <div class="span3">
 | 
			
		||||
						<%= f.label :vol_no, t("personal_journal.vol_no") %>
 | 
			
		||||
      <!-- author_type -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.author_type") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<% @author_types.each do |author_type| %>
 | 
			
		||||
				<%= content_tag :label,:class => "checkbox inline" do -%>
 | 
			
		||||
					<%= check_box_tag 'writing_journal[journal_author_type_ids][]', author_type.id, @writing_journal.journal_author_type_ids.include?(author_type.id)%>
 | 
			
		||||
					<%= author_type.title %>
 | 
			
		||||
	   			    <%= hidden_field_tag 'writing_journal[journal_author_type_ids][]', '' %>
 | 
			
		||||
				<% end %>
 | 
			
		||||
			<% end %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- vol_no -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.vol_no") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :vol_no %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
                    <div class="span3">
 | 
			
		||||
						<%= f.label :issue_no, t("personal_journal.issue_no") %>
 | 
			
		||||
      <!-- issue_no -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.issue_no") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :issue_no %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
                    <div class="span3">
 | 
			
		||||
						<%= f.label :form_to, t("personal_journal.form_to") %>
 | 
			
		||||
      <!-- form_to -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.form_to") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :form_to_start, :class=>'span1' %> ~ <%= f.text_field :form_to_end, :class=>'span1' %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
                    <div class="span3">
 | 
			
		||||
						<%= f.label :total_pages, t("personal_journal.total_pages") %>
 | 
			
		||||
      <!-- total_pages -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.total_pages") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :total_pages %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- isbn -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.isbn") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :isbn %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- keywords -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.keywords") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :keywords %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- publication_date -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.publication_date") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.date_select :publication_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- url -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.url") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
			<%= f.text_field :url , :class => "span6" %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- abstract -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.abstract") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_area :abstract, rows: 2, class: "input-block-level" %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
      <!-- note -->
 | 
			
		||||
      <div class="control-group">
 | 
			
		||||
        <label class="control-label muted"><%= t("personal_journal.note") %></label>
 | 
			
		||||
        <div class="controls">
 | 
			
		||||
          <%= f.text_area :note, rows: 2, class: "input-block-level" %>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div> 
 | 
			
		||||
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
                <div class="row">
 | 
			
		||||
    <!-- Status Module -->
 | 
			
		||||
    <% if show_form_status_field(@writing_journal) %>
 | 
			
		||||
      <div class="tab-pane fade" id="status">
 | 
			
		||||
 | 
			
		||||
                    <div class="span5">
 | 
			
		||||
        <!-- 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 @writing_journal.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 @writing_journal.tag_ids.include?(tag.id) %>">
 | 
			
		||||
              <%= check_box_tag 'writing_journal[tag_ids][]', tag.id, @writing_journal.tag_ids.include?(tag.id) %> <%= tag.name %>
 | 
			
		||||
              <%= hidden_field_tag 'writing_journal[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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
						
 | 
			
		||||
						<div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
 | 
			
		||||
							<div class="title">
 | 
			
		||||
								<%= f.label :authors,t("web_resource.authors") %>
 | 
			
		||||
								<%= f.fields_for :authors_translations do |f| %>
 | 
			
		||||
										<%= I18nVariable.from_locale(locale) %>
 | 
			
		||||
										<%= f.text_field locale, :class=>'span5', :value => (@writing_journal.authors_translations[locale] rescue nil) %>
 | 
			
		||||
								<% end %>
 | 
			
		||||
							</div>
 | 
			
		||||
							
 | 
			
		||||
						</div>
 | 
			
		||||
 | 
			
		||||
						<% end %>
 | 
			
		||||
						
 | 
			
		||||
                    </div>
 | 
			
		||||
					
 | 
			
		||||
 | 
			
		||||
                    <div class="span7">
 | 
			
		||||
                        <label> </label>
 | 
			
		||||
                        <input type="text" name="" id="" class="span7">
 | 
			
		||||
                    </div>
 | 
			
		||||
					
 | 
			
		||||
                </div>
 | 
			
		||||
				
 | 
			
		||||
			</div>
 | 
			
		||||
 | 
			
		||||
			<div class="row">
 | 
			
		||||
				<div class="span5">
 | 
			
		||||
					<%= f.label :author_type ,t("personal_journal.author_type")%>
 | 
			
		||||
					
 | 
			
		||||
					<div class="form-inline">
 | 
			
		||||
						<ul class="nav nav-pills">
 | 
			
		||||
						<% @author_types.each_with_index do |author_type, i | %>
 | 
			
		||||
							<li class="pull-left">
 | 
			
		||||
							<%= check_box_tag 'writing_journal[journal_author_type_ids][]', author_type.id, @writing_journal.journal_author_type_ids.include?(author_type.id), :id => "field-#{i}" %>
 | 
			
		||||
							<label for="field-<%= i %>"><%= author_type.title %></label>
 | 
			
		||||
							<%= hidden_field_tag 'writing_journal[journal_author_type_ids][]', '' %>
 | 
			
		||||
      <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_valid_locales.each_with_index do |locale, i| %>
 | 
			
		||||
    
 | 
			
		||||
      <div class="<%= locale %> tab-pane fade <%= ( i == 0 ) ? "in active" : '' %>">
 | 
			
		||||
 | 
			
		||||
        <!-- paper_title-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_journal.paper_title") %></label>
 | 
			
		||||
          <div class="controls">          	
 | 
			
		||||
            <%= f.fields_for :paper_title_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_journal.paper_title"), value: (@writing_journal.paper_title_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
				<div class="span7">
 | 
			
		||||
					<%= f.label :paper_type ,t("personal_journal.paper_type")%>
 | 
			
		||||
					<%= f.select :journal_paper_type_id, @paper_types.collect {|t| [ t.title, t.id ]}, :class => "span7" %>
 | 
			
		||||
        <!-- journal_title-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_journal.journal_title") %></label>
 | 
			
		||||
          <div class="controls">          	
 | 
			
		||||
            <%= f.fields_for :journal_title_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_journal.journal_title"), value: (@writing_journal.journal_title_translations[locale] rescue nil) %>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- authors-->
 | 
			
		||||
        <div class="control-group input-title">
 | 
			
		||||
          <label class="control-label muted"><%= t("personal_journal.authors") %></label>
 | 
			
		||||
          <div class="controls">          	
 | 
			
		||||
            <%= f.fields_for :authors_translations do |f| %>
 | 
			
		||||
              <%= f.text_field locale, class: "input-block-level", placeholder: t("personal_journal.authors"), value: (@writing_journal.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">
 | 
			
		||||
 | 
			
		||||
			<%= f.label :isbn, t("personal_journal.isbn") %>
 | 
			
		||||
			<%= f.text_field :isbn , :class => "span12" %>
 | 
			
		||||
			<br>
 | 
			
		||||
			
 | 
			
		||||
			<%= f.label :keywords, t("personal_journal.keywords") %>
 | 
			
		||||
			<%= f.text_field :keywords , :class => "span12" %>
 | 
			
		||||
			<br>
 | 
			
		||||
			
 | 
			
		||||
			<div class="title">
 | 
			
		||||
				<%= f.label :publication_date ,t("personal_journal.publication_date")%>
 | 
			
		||||
				<%= f.date_select :publication_date, {:use_month_numbers => true, :start_year => Time.now.year, :end_year => 1930, :order => [:year, :month, :day] }, {:class => 'span1'} %>
 | 
			
		||||
			</div>
 | 
			
		||||
			
 | 
			
		||||
			<%= f.label :url, t("personal_journal.url") %>
 | 
			
		||||
			<%= f.text_field :url , :class => "span12" %>
 | 
			
		||||
			<br>
 | 
			
		||||
			
 | 
			
		||||
		</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', @writing_journal.writing_journal_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>
 | 
			
		||||
					
 | 
			
		||||
        <!-- Exist -->
 | 
			
		||||
        <% if @writing_journal && !@writing_journal.writing_journal_files.blank? %>
 | 
			
		||||
          <div class="exist">
 | 
			
		||||
            <% @writing_journal.writing_journal_files.each_with_index do |writing_journal_file, i| %>
 | 
			
		||||
              <%= f.fields_for :writing_journal_files, writing_journal_file do |f| %>
 | 
			
		||||
                <%= render :partial => 'form_file', :object => writing_journal_file, :locals => {:f => f, :i => i} %>
 | 
			
		||||
              <% end %>
 | 
			
		||||
            <% end %> 
 | 
			
		||||
				</tbody>
 | 
			
		||||
			</table>
 | 
			
		||||
            <hr>
 | 
			
		||||
          </div>
 | 
			
		||||
        <% end %>
 | 
			
		||||
 | 
			
		||||
        <!-- Add -->
 | 
			
		||||
        <div class="add-target">
 | 
			
		||||
        </div>
 | 
			
		||||
        <p class="add-btn">
 | 
			
		||||
          <%= hidden_field_tag 'plugin_file_field_count', @writing_journal.writing_journal_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>
 | 
			
		||||
 | 
			
		||||
<!--Post End-->
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
</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' %>
 | 
			
		||||
  <%= 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(){
 | 
			
		||||
    $(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_add_plugin_files", "g");
 | 
			
		||||
        var old_id = new RegExp("new_writing_journal_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).parents('table').append(("<%= escape_javascript(add_attribute 'form_file', f, :writing_journal_files) %>").replace(old_id, new_id));
 | 
			
		||||
        $(this).parent().siblings('.add-target').append(("<%= escape_javascript(add_attribute 'form_file', f, :writing_journal_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');
 | 
			
		||||
        });
 | 
			
		||||
		
 | 
			
		||||
		$('.add_plugin_files_block a.delete').live('click', function(){
 | 
			
		||||
		  $(this).parents('.list_item').remove();
 | 
			
		||||
        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();
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
		$('.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 %>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,50 +1,45 @@
 | 
			
		|||
<% # 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_valid_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>
 | 
			
		||||
  <div class="fileupload fileupload-new start-line" data-provides="fileupload">
 | 
			
		||||
<% 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' %>
 | 
			
		||||
  <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_valid_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>
 | 
			
		||||
			
 | 
			
		||||
			</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		
 | 
			
		||||
      <% 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>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,10 +1,6 @@
 | 
			
		|||
<tr id="<%= dom_id writing_journal %>" class="with_action">
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
		<% if (writing_journal.create_user_id ==  current_user.id) || is_manager? %>
 | 
			
		||||
			<%= check_box_tag 'to_delete[]', writing_journal.id, false, :class => "checkbox_in_list" %>
 | 
			
		||||
		<% end -%>
 | 
			
		||||
	</td>
 | 
			
		||||
	<td class="span1"><%= writing_journal.publication_date %></td>
 | 
			
		||||
 | 
			
		||||
	<td class="span1"><%= writing_journal.year %></td>
 | 
			
		||||
	<td class="span1">
 | 
			
		||||
	<%= link_to writing_journal.create_link , panel_personal_journal_front_end_writing_journal_path(writing_journal) %>
 | 
			
		||||
	<div class="quick-edit">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -8,8 +8,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<h1><%= t('personal_journal.editing_personal_journal') %></h1>
 | 
			
		||||
 | 
			
		||||
<%= form_for @writing_journal, :url => panel_personal_journal_back_end_writing_journal_path(@writing_journal), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @writing_journal, url: panel_personal_journal_back_end_writing_journal_path(@writing_journal), html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -13,10 +13,9 @@
 | 
			
		|||
<table class="table main-list">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"></th>
 | 
			
		||||
			<th class="span1"><%= t('personal_journal.year') %></th>
 | 
			
		||||
			<th class="span7"><%= t('module_name.personal_journal') %></th>
 | 
			
		||||
			<th class="span1"><%= t('personal_journal.authors') %></th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody id="tbody_writing_journals" class="sort-holder">
 | 
			
		||||
| 
						 | 
				
			
			@ -24,10 +23,12 @@
 | 
			
		|||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<div class="form-actions form-fixed pagination-right">
 | 
			
		||||
<div class="bottomnav clearfix">
 | 
			
		||||
	<div class="action pull-right">
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-cog icon-white') + t('setting'), panel_personal_journal_back_end_writing_journal_setting_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t('announcement.add_new'), new_panel_personal_journal_back_end_writing_journal_path, :class => 'btn btn-primary pull-right' %>
 | 
			
		||||
	<div id="writing_journal_pagination" class="paginationFixed">
 | 
			
		||||
	<%= paginate @writing_journal_pages, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
	  <%= paginate @writing_journals, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
 | 
			
		||||
	</div>
 | 
			
		||||
</div>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -8,14 +8,8 @@
 | 
			
		|||
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%= flash_messages %>
 | 
			
		||||
 | 
			
		||||
<div id="poststuff">
 | 
			
		||||
<h1><%= t('writing_journal.new_personal_journal') %></h1>
 | 
			
		||||
<%= form_for @writing_journal, :url => panel_personal_journal_back_end_writing_journals_path, :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
	<%= render :partial => 'form', :locals => {:f => f} %>
 | 
			
		||||
<%= form_for @writing_journal, url: panel_personal_journal_back_end_writing_journals_path, html: {class: "form-horizontal main-forms previewable"} do |f| %>
 | 
			
		||||
  <fieldset>
 | 
			
		||||
    <%= render partial: 'form', locals: {f: f} %>
 | 
			
		||||
  </fieldset>
 | 
			
		||||
<% end %>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<%#= link_back %>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -15,7 +15,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_journal_back_end_writing_journal_level_type_quick_add_path('add') %>#myModal1" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>等級</span>                        
 | 
			
		||||
                        <span><%= t("personal_journal.level_type") %></span>                        
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			@ -41,7 +41,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">          
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_journal_back_end_writing_journal_author_type_quick_add_path('add') %>#myModal2" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>作者型態</span>
 | 
			
		||||
                        <span><%= t("personal_journal.author_type") %></span>
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			@ -67,7 +67,7 @@
 | 
			
		|||
                <div class="detail w-a h-a">
 | 
			
		||||
                    <p class="totle">               
 | 
			
		||||
						<a class="btn btn-small btn-primary pull-right" href="<%= panel_personal_journal_back_end_writing_journal_author_type_quick_add_path('add') %>#myModal3" data-toggle="modal" data-remote="true"><i class="icon-plus"></i> <%= t('add')%></a>
 | 
			
		||||
                        <span>論文型態</span>
 | 
			
		||||
                        <span><%= t("personal_journal.paper_type") %></span>
 | 
			
		||||
                    </p>
 | 
			
		||||
                    <div class="detal-list my_scroll">
 | 
			
		||||
                        <div class="scrollbar">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,12 +1,21 @@
 | 
			
		|||
<%
 | 
			
		||||
  if @member
 | 
			
		||||
    @writing_journals = WritingJournal.where(:create_user_id => @member.id).desc(:year)
 | 
			
		||||
  else
 | 
			
		||||
    @writing_journals = WritingJournal.all.desc(:year)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
    @writing_journals = WritingJournal.where(is_hidden: false, :create_user_id => @member.id).desc(:year)
 | 
			
		||||
 | 
			
		||||
    @writing_journal_intro = !PersonalJournalIntro.where(:user_id => @member.id).blank? ? PersonalJournalIntro.where(:user_id => @member.id).first : PersonalJournalIntro.new
 | 
			
		||||
%>
 | 
			
		||||
 | 
			
		||||
  <% if @writing_journal_intro.brief_intro and !@writing_journal_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <div class="info">
 | 
			
		||||
      <%= @writing_journal_intro.text.html_safe rescue '' %>
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% if ( !@writing_journal_intro.blank? and @writing_journal_intro.complete_list ) or @writing_journal_intro.blank? %> 
 | 
			
		||||
 | 
			
		||||
    <% if !@writing_journals.blank? %> 
 | 
			
		||||
 | 
			
		||||
      <table class="table">
 | 
			
		||||
| 
						 | 
				
			
			@ -34,8 +43,8 @@
 | 
			
		|||
        </tbody>
 | 
			
		||||
      </table>
 | 
			
		||||
 | 
			
		||||
<% else %> 
 | 
			
		||||
 | 
			
		||||
  <%= t('nothing')%>
 | 
			
		||||
    <% end %> 
 | 
			
		||||
 | 
			
		||||
  <% end %> 
 | 
			
		||||
 | 
			
		||||
<% end %> 
 | 
			
		||||
| 
						 | 
				
			
			@ -1,3 +1,10 @@
 | 
			
		|||
<% 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]
 | 
			
		||||
| 
						 | 
				
			
			@ -16,17 +23,29 @@
 | 
			
		|||
    @filter = {new_filter[:type] => [new_filter[:id].to_s]}
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  if @user
 | 
			
		||||
    @writing_journals = WritingJournal.where(:create_user_id => @user.id).page(params[:page]).per(10)
 | 
			
		||||
  if @user && is_admin?
 | 
			
		||||
    @writing_journals = WritingJournal.where(:create_user_id => @user.id).desc(:year).page(params[:page]).per(10)
 | 
			
		||||
  else
 | 
			
		||||
    @writing_journals = WritingJournal.all.page(params[:page]).per(10)
 | 
			
		||||
    @writing_journals = WritingJournal.where(is_hidden: false, :create_user_id => @user.id).desc(:year).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_journal_back_end_writing_journals_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_journal_back_end_writing_journals_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="span1"><%= t('personal_journal.year') %></th>
 | 
			
		||||
			<th><%= t('module_name.personal_journal') %></th>
 | 
			
		||||
			<% if not @user%>
 | 
			
		||||
| 
						 | 
				
			
			@ -38,7 +57,12 @@
 | 
			
		|||
		
 | 
			
		||||
	<% @writing_journals.each do |writing_journal| %>	
 | 
			
		||||
			
 | 
			
		||||
    <tr>
 | 
			
		||||
    <tr class="<%= writing_journal.is_hidden ? "checkHide" : "" %>">
 | 
			
		||||
      <% if is_admin? %>
 | 
			
		||||
      <td>
 | 
			
		||||
        <%= check_box_tag 'to_change[]', writing_journal.id.to_s, false, :class => "list-check" %>
 | 
			
		||||
      </td>
 | 
			
		||||
      <% end -%>
 | 
			
		||||
			<td><%= writing_journal.year %></td>
 | 
			
		||||
			<td>
 | 
			
		||||
			<%= link_to writing_journal.create_link, panel_personal_journal_front_end_writing_journal_path(writing_journal) %>
 | 
			
		||||
| 
						 | 
				
			
			@ -53,11 +77,25 @@
 | 
			
		|||
  </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_journal_back_end_personal_journal_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_journal_back_end_writing_journal_path(:user_id => @user.id), :class => 'btn btn-primary' %>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div class="pagination pagination-centered">
 | 
			
		||||
		<%= paginate @writing_journals, :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>
 | 
			
		||||
Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
		Reference in New Issue