forked from saurabh/personal-book
343 lines
13 KiB
Plaintext
343 lines
13 KiB
Plaintext
|
<% # 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" %>
|
||
|
<%= javascript_include_tag "lib/bootstrap-datetimepicker.js" %>
|
||
|
<%= javascript_include_tag "lib/bootstrap-typeahead.js" %>
|
||
|
<%= javascript_include_tag "lib/datetimepicker/date.time.picker.js" %>
|
||
|
<%= javascript_include_tag "lib/datetimepicker/datetimepicker" %>
|
||
|
<% end %>
|
||
|
|
||
|
<!-- Input Area -->
|
||
|
<div class="input-area">
|
||
|
|
||
|
<!-- Module Tabs -->
|
||
|
<div class="nav-name"><strong><%= t(:module) %></strong></div>
|
||
|
<ul class="nav nav-pills module-nav">
|
||
|
<li></li>
|
||
|
<li class="active">
|
||
|
<a href="#basic" data-toggle="tab"><%= t(:basic) %></a>
|
||
|
</li>
|
||
|
<li>
|
||
|
<a href="#status" data-toggle="tab"><%= t(:status) %></a>
|
||
|
</li>
|
||
|
</ul>
|
||
|
|
||
|
<!-- Module -->
|
||
|
<div class="tab-content module-area">
|
||
|
|
||
|
<!-- Basic Module -->
|
||
|
<div class="tab-pane fade in active" id="basic">
|
||
|
|
||
|
<!-- Category -->
|
||
|
<div class="control-group">
|
||
|
<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 'book[book_author_type_ids][]', author_type.id, @book.book_author_type_ids.include?(author_type.id)%>
|
||
|
<%= author_type.title %>
|
||
|
<% end %>
|
||
|
<% end %>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<!-- authors-->
|
||
|
<div class="control-group input-title">
|
||
|
<label class="control-label muted"><%= t("personal_journal.author") %></label>
|
||
|
<div class="controls">
|
||
|
<%= f.text_field :member_profile_id, id: "member_autocomplete", autocomplete: "off", data: { provide: "typeahead"}, class: "input-block-level", value: (@book.member_profile.name rescue nil), placeholder: t("personal_journal.author")%>
|
||
|
|
||
|
<%= f.hidden_field :member_profile_id, value: (@book.member_profile_id ? @book.member_profile_id : ""), id: "member_value" %>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<!-- Category -->
|
||
|
<div class="control-group">
|
||
|
<label class="control-label muted"><%= t("personal_book.book_paper_type") %></label>
|
||
|
<div class="controls">
|
||
|
<%= f.select :book_type_id, @book_types.collect {|t| [ t.title, t.id ]} %>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<!-- year -->
|
||
|
<div class="control-group">
|
||
|
<label class="control-label muted"><%= t("personal_book.year") %></label>
|
||
|
<div class="controls">
|
||
|
<%= select_year((@book.year ? @book.year.to_i : DateTime.now.year), {:start_year => DateTime.now.year, :end_year => 1930}, {:name => 'writing_book[year]',:class => 'span1'} ) %>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<!-- publish_date -->
|
||
|
<div class="control-group">
|
||
|
<label class="control-label muted"><%= t("personal_book.publish_date") %></label>
|
||
|
<div class="controls">
|
||
|
<%= f.datetime_picker :publish_date, :no_label => true %>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<!-- publication_date -->
|
||
|
<div class="control-group">
|
||
|
<label class="control-label muted"><%= t("personal_book.publication_date") %></label>
|
||
|
<div class="controls">
|
||
|
<%= f.datetime_picker :publication_date, :no_label => true %>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<!-- 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>
|
||
|
|
||
|
<!-- pages -->
|
||
|
<div class="control-group">
|
||
|
<label class="control-label muted"><%= t("personal_book.pages") %></label>
|
||
|
<div class="controls">
|
||
|
<%= f.text_field :pages %>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<!-- 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>
|
||
|
|
||
|
<!-- 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 -->
|
||
|
<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 @book.is_hidden? %>">
|
||
|
<%= f.check_box :is_hidden %> <%= t(:hide) %>
|
||
|
</label>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
<!-- Language Tabs -->
|
||
|
<div class="nav-name"><strong><%= t(:language) %></strong></div>
|
||
|
<ul class="nav nav-pills language-nav">
|
||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||
|
<li class="<%= 'active' if i == 0 %>">
|
||
|
<a data-toggle="tab" href=".<%= locale %>"><%= t(locale) %></a>
|
||
|
</li>
|
||
|
<% end %>
|
||
|
</ul>
|
||
|
|
||
|
<!-- Language -->
|
||
|
<div class="tab-content language-area">
|
||
|
|
||
|
<% @site_in_use_locales.each_with_index do |locale, i| %>
|
||
|
|
||
|
<div class="<%= locale %> tab-pane fade <%= ( i == 0 ) ? "in active" : '' %>">
|
||
|
|
||
|
<!-- 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: (@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: (@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: (@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: (@book.editor_translations[locale] rescue nil) %>
|
||
|
<% end %>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
<% end %>
|
||
|
|
||
|
<!-- Authors-->
|
||
|
<div class="control-group">
|
||
|
<label class="control-label muted"><%= t("personal_journal.co-authors") %></label>
|
||
|
<div class="controls">
|
||
|
|
||
|
<% if @book && !@book.book_authors.blank? %>
|
||
|
<div class="exist">
|
||
|
<% @book.book_authors.each_with_index do |author, i| %>
|
||
|
<%= f.fields_for :book_authors, author do |f| %>
|
||
|
<%= render :partial => 'form_author', :object => author, :locals => {:f => f, :i => i} %>
|
||
|
<% end %>
|
||
|
<% end %>
|
||
|
<hr>
|
||
|
</div>
|
||
|
<% end %>
|
||
|
|
||
|
<!-- Add -->
|
||
|
<div class="add-target-box">
|
||
|
</div>
|
||
|
<p class="add-btn-box">
|
||
|
<a id="add_author" class="trigger btn btn-small btn-primary"><i class="icons-plus"></i> <%= t(:add) %></a>
|
||
|
</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
|
||
|
<!-- File -->
|
||
|
<div class="control-group">
|
||
|
<label class="control-label muted"><%= t(:file_) %></label>
|
||
|
<div class="controls">
|
||
|
|
||
|
<!-- Exist -->
|
||
|
<% if @book && !@book.book_files.blank? %>
|
||
|
<div class="exist">
|
||
|
<% @book.book_files.each_with_index do |book_file, i| %>
|
||
|
<%= f.fields_for :book_files, book_file do |f| %>
|
||
|
<%= render :partial => 'form_file', :object => book_file, :locals => {:f => f, :i => i} %>
|
||
|
<% end %>
|
||
|
<% end %>
|
||
|
<hr>
|
||
|
</div>
|
||
|
<% end %>
|
||
|
|
||
|
<!-- Add -->
|
||
|
<div class="add-target">
|
||
|
</div>
|
||
|
<p class="add-btn">
|
||
|
<%= hidden_field_tag 'plugin_file_field_count', @book.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>
|
||
|
|
||
|
|
||
|
|
||
|
</div>
|
||
|
|
||
|
<!-- Form Actions -->
|
||
|
<div class="form-actions">
|
||
|
<%= f.hidden_field :user_id, :value => params[:user_id] if !params[:user_id].blank? %>
|
||
|
<%= f.submit t('submit'), class: 'btn btn-primary' %>
|
||
|
<%= link_to t('cancel'), get_go_back, :class=>"btn" %>
|
||
|
</div>
|
||
|
|
||
|
<% content_for :page_specific_javascript do %>
|
||
|
<%= render 'author_autocomplete'%>
|
||
|
<script>
|
||
|
$(document).ready(function() {
|
||
|
$('.main-forms .add-on').tooltip();
|
||
|
$(document).on('click', '#add_file', function(){
|
||
|
var new_id = $(this).prev().attr('value');
|
||
|
var old_id = new RegExp("new_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).parent().siblings('.add-target').append(("<%= escape_javascript(add_attribute 'form_file', f, :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');
|
||
|
});
|
||
|
formTip();
|
||
|
});
|
||
|
$(document).on('click', '.delete_file', function(){
|
||
|
$(this).parents('.input-prepend').remove();
|
||
|
});
|
||
|
$(document).on('click', '.remove_existing_record', function(){
|
||
|
if(confirm("<%= I18n.t(:sure?)%>")){
|
||
|
$(this).children('.should_destroy').attr('value', 1);
|
||
|
$(this).parents('.start-line').hide();
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
</script>
|
||
|
<script>
|
||
|
$(document).ready(function() {
|
||
|
$('.main-forms .add-on').tooltip();
|
||
|
$(document).on('click', '#add_author', function(){
|
||
|
var new_id = $(this).prev().attr('value');
|
||
|
var old_id = new RegExp("new_authors", "g");
|
||
|
var on = $('.language-nav li.active').index();
|
||
|
var le = $(this).parent('.add-btn-box').prev('.add-target-box').children('.start-line').length;
|
||
|
$(this).prev().attr('value', parseInt(new_id) + 1);
|
||
|
$(this).parent().siblings('.add-target-box').append(("<%= escape_javascript(add_attribute 'form_author', f, :book_authors) %>").replace(old_id, new_id));
|
||
|
$(this).parent('.add-btn-box').prev('.add-target-box').children('.start-line').eq(le).children('.input-append').find('.tab-content').each(function() {
|
||
|
$(this).children('.tab-pane').eq(on).addClass('in active').siblings().removeClass('in active');
|
||
|
});
|
||
|
formTip();
|
||
|
});
|
||
|
$(document).on('click', '.delete_file', function(){
|
||
|
$(this).parents('.input-prepend').remove();
|
||
|
});
|
||
|
$(document).on('click', '.remove_existing_record', function(){
|
||
|
if(confirm("<%= I18n.t(:sure?)%>")){
|
||
|
$(this).children('.should_destroy').attr('value', 1);
|
||
|
$(this).parents('.start-line').hide();
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
</script>
|
||
|
<% end %>
|