2021-04-03 16:23:52 +00:00
|
|
|
|
<h3 class="pull-left"><%= @seminar.title %></h3>
|
|
|
|
|
<div style="clear: both;"></div>
|
|
|
|
|
<% org_seminar_signups = @seminar_signups %>
|
|
|
|
|
<% session_translation = (@seminar.seminar_submission_field_sets.select{|v| v.field_name=='description'}[0]['name'][I18n.locale] rescue "Session") %>
|
2021-04-04 12:33:09 +00:00
|
|
|
|
<div style="float: left;width: 50%;" class="left_block">
|
2021-04-03 16:23:52 +00:00
|
|
|
|
<h4><%= session_translation %></h4>
|
|
|
|
|
<% session_show_ids = @seminar.session_show_ids %>
|
|
|
|
|
<% if session_show_ids.nil?
|
|
|
|
|
session_show_ids = (0...@seminar.summary_chioices.count).to_a[0..1]
|
|
|
|
|
@seminar.update(:session_show_ids=>session_show_ids)
|
|
|
|
|
end
|
|
|
|
|
%>
|
|
|
|
|
<% count = 0 %>
|
|
|
|
|
<% session_show_ids.each do |session_id| %>
|
|
|
|
|
<% next if session_id >= @seminar.summary_chioices.count %>
|
|
|
|
|
<% count += 1 %>
|
|
|
|
|
<div class="session_block" data-id="<%=session_id%>" data-count="<%=count%>">
|
|
|
|
|
<h5><%= @seminar.summary_chioices[session_id] %></h5>
|
|
|
|
|
<span class="zoom_out_btn">-</span>
|
|
|
|
|
<% seminar_session = @seminar.seminar_sessions.where(:key=>session_id).first %>
|
|
|
|
|
<% @seminar_signups = seminar_session.seminar_signups.sort_ordered %>
|
|
|
|
|
<% @seminar_signups = @seminar_signups.page(params["page_no#{count}"]).per(5) %>
|
|
|
|
|
<% @seminar_signups = @seminar_signups.page(0) if @seminar_signups.to_a.count == 0 %>
|
|
|
|
|
<%= render :partial => "seminar_signup_render_table",:locals=>{:@seminar_signups=>@seminar_signups,:@drag => true,:@include_blank=>true,:@reviewer_id=>session_id} %>
|
|
|
|
|
<%
|
|
|
|
|
pagination_html = content_tag :div, class: "bottomnav clearfix", style: "position: static;" do
|
|
|
|
|
content_tag :div, paginate(@seminar_signups), class: "pagination pagination-centered"
|
|
|
|
|
end
|
|
|
|
|
%>
|
|
|
|
|
<%= pagination_html.gsub(/page_no#{count}=\d*/,"").gsub('&&','&').gsub(/page=(\d*)/m){|ff| ff.gsub("page=#{$1}","page=#{params[:page]}&page_no#{count}=#{$1}")}.html_safe %>
|
|
|
|
|
</div>
|
|
|
|
|
<% end %>
|
|
|
|
|
<% if count != 2 && @seminar.summary_chioices.count >= 2 %>
|
|
|
|
|
<% (0...(2-count)).each do |i| %>
|
|
|
|
|
<div class="blank_block session_block">
|
|
|
|
|
<i class="fa fa-plus-circle add_btn"></i>
|
|
|
|
|
</div>
|
|
|
|
|
<% end %>
|
|
|
|
|
<% end %>
|
|
|
|
|
</div>
|
|
|
|
|
<% @seminar_signups = org_seminar_signups
|
|
|
|
|
@include_blank = false
|
|
|
|
|
@reviewer_id = nil
|
|
|
|
|
%>
|
|
|
|
|
<div style="float: right;width: 50%;" data-count="<%=count+=1%>">
|
|
|
|
|
<div id="main-table" style="overflow: scroll;">
|
|
|
|
|
<h5><%= t('seminar.unassigned_session_signups',{:session=>session_translation}) %></h5>
|
|
|
|
|
<%= render :partial => "seminar_signup_render_table" %>
|
|
|
|
|
</div>
|
|
|
|
|
<%=
|
|
|
|
|
content_tag :div, class: "bottomnav clearfix", style: "position: static;" do
|
|
|
|
|
content_tag :div, paginate(@seminar_signups), class: "pagination pagination-centered"
|
|
|
|
|
end
|
|
|
|
|
%>
|
|
|
|
|
</div>
|
|
|
|
|
<% unless request.xhr? %>
|
|
|
|
|
<div id='dialog-confirm' title="<%= t("seminar.select_session",{:session=>session_translation}) %>" style="display: none;">
|
|
|
|
|
<div style="clear:both;"></div>
|
|
|
|
|
<div id="info_texts">
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="bottomnav clearfix">
|
|
|
|
|
<div class="action pull-right">
|
|
|
|
|
<%= link_to content_tag(:i, nil, :class => 'icon-cog icon-white') + t("seminar.field_display_setting"), seminar_signup_admin_setting_admin_seminar_path(params[:id]) + "?page=session", :class => 'btn btn-primary' %>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<script type="text/javascript">
|
2021-04-04 12:33:09 +00:00
|
|
|
|
function add_obj(obj1,obj2){
|
|
|
|
|
var keys = Object.keys(obj1);
|
|
|
|
|
var obj = {};
|
|
|
|
|
keys.forEach(function(k){
|
|
|
|
|
obj[k] = obj1[k] + obj2[k];
|
|
|
|
|
});
|
|
|
|
|
return obj;
|
|
|
|
|
}
|
|
|
|
|
function sub_obj(obj1,obj2){
|
|
|
|
|
var keys = Object.keys(obj1);
|
|
|
|
|
var obj = {};
|
|
|
|
|
keys.forEach(function(k){
|
|
|
|
|
obj[k] = obj1[k] - obj2[k];
|
|
|
|
|
});
|
|
|
|
|
return obj;
|
|
|
|
|
}
|
2021-04-03 16:23:52 +00:00
|
|
|
|
function generate_pagination(session_id,index=1,start=1,end=1,active=1){
|
|
|
|
|
var pagination = $('<div class="pagination pagination-centered">');
|
|
|
|
|
pagination.append('<div class="pagination"><ul></ul></div>');
|
|
|
|
|
var href = "<%=get_session_block_admin_seminar_path(@seminar.id)%>?session_id="+session_id+"&page_no"+index+"=new_page_no";
|
|
|
|
|
if(active != start){
|
|
|
|
|
pagination.find("ul").append("<li class=\"first\"><a href=\""+href.replace('new_page_no',1)+"\">« First</a></li>");
|
|
|
|
|
pagination.find("ul").append("<li class=\"prev\"><a href=\""+href.replace('new_page_no',active-1)+"\">‹ Prev</a></li>");
|
|
|
|
|
}
|
|
|
|
|
for(var i=start;i<end;i++){
|
|
|
|
|
if(i == active){
|
|
|
|
|
pagination.find("ul").append("<li class=\"page active\"><a href=\""+href.replace('new_page_no',i)+"\">"+i+"</a></li>");
|
|
|
|
|
}else{
|
|
|
|
|
pagination.find("ul").append("<li class=\"page\"><a href=\""+href.replace('new_page_no',i)+"\">"+i+"</a></li>");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if(active != end && end != 1){
|
|
|
|
|
pagination.find("ul").append("<li class=\"next\"><a href=\""+href.replace('new_page_no',active+1)+"\">Next ›</a></li>");
|
|
|
|
|
pagination.find("ul").append("<li class=\"last\"><a href=\""+href.replace('new_page_no',end)+"\">Last »</a></li>");
|
|
|
|
|
}
|
|
|
|
|
return pagination.prop("outerHTML");
|
|
|
|
|
}
|
|
|
|
|
function adjust_height(){
|
|
|
|
|
var bottom_offset = $(".bottomnav").eq(1).offset().top;
|
|
|
|
|
var top_offset = [$('ul.pull-right').offset().top,$('h3.pull-left').offset().top];
|
|
|
|
|
var top_height = [$('ul.pull-right').height(),$("h3.pull-left").height()];
|
|
|
|
|
var top_all_offset_bottom = top_offset.map(function(d,i){return d+top_height[i]});
|
|
|
|
|
top_all_offset_bottom = Math.max.apply(null, top_all_offset_bottom);
|
|
|
|
|
var bottom_height = $(".bottomnav")[0].offsetHeight;
|
|
|
|
|
var block_height;// = bottom_offset - top_all_offset_bottom - bottom_height - 100;
|
|
|
|
|
block_height = $(window).height() - top_all_offset_bottom - bottom_height - 100;
|
|
|
|
|
$("#main-table").height(block_height);
|
|
|
|
|
$(".session_block").height(block_height / 2);
|
|
|
|
|
}
|
|
|
|
|
function a_tag_xhr_request(ele){
|
|
|
|
|
var href = $(ele).attr("href");
|
|
|
|
|
var div_block = $(ele).parents(".bottomnav").parent();
|
|
|
|
|
var index = div_block.data("count");
|
|
|
|
|
$.get(href).done(function(data){
|
|
|
|
|
var $d = $(data);
|
|
|
|
|
div_block.html($d.find('[data-count='+index+']').html());
|
|
|
|
|
$(".pagination a").attr("onclick","a_tag_xhr_request(this);return false;");
|
|
|
|
|
adjust_height();
|
|
|
|
|
window.history.pushState(data,null,href);
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
function init_func(){
|
|
|
|
|
adjust_height();
|
|
|
|
|
$(".zoom_out_btn").off("click").on("click",function(){
|
|
|
|
|
var parent = $(this).parent();
|
|
|
|
|
var session_id = parent.data("id");
|
|
|
|
|
$.post("<%=update_seminar_session_admin_seminar_path(params[:id])%>",{session_id: session_id,mode: "hide"}).done(function(data){
|
|
|
|
|
console.log(data);
|
|
|
|
|
parent.css("display","none");
|
|
|
|
|
parent.before('<div class="blank_block session_block">'+
|
|
|
|
|
'<i class="fa fa-plus-circle add_btn"></i>'+
|
|
|
|
|
'</div>');
|
|
|
|
|
init_func();
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
$(".blank_block .add_btn").off("click").on("click",function(){
|
|
|
|
|
var ele = $(this).parent();
|
|
|
|
|
$.get("<%=get_hide_session_admin_seminar_path(@seminar.id)%>").done(function(data){
|
|
|
|
|
$("#info_texts").html(data);
|
|
|
|
|
$( "#dialog-confirm" ).dialog({
|
|
|
|
|
resizable: true,
|
|
|
|
|
minHeight: 300,
|
|
|
|
|
maxHeight: 400,
|
|
|
|
|
modal: true,
|
|
|
|
|
width: '80%',
|
|
|
|
|
close: function(){$( this ).dialog( "close" );},
|
|
|
|
|
open: function(){
|
|
|
|
|
$(".selected_item").click(function(){
|
|
|
|
|
var session_id = $(this).data("id");
|
|
|
|
|
$.get("<%=get_session_block_admin_seminar_path(params[:id])%>",{session_id: session_id,type: "<%=params[:type]%>"}).done(function(data){
|
|
|
|
|
ele.prop("outerHTML",data);
|
|
|
|
|
init_func();
|
|
|
|
|
$( "#dialog-confirm" ).dialog( "close" );
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
$(".pagination a").attr("onclick","a_tag_xhr_request(this);return false;")
|
|
|
|
|
$( ".table tbody" ).sortable({
|
|
|
|
|
revert: true,
|
|
|
|
|
handle: ".brand",
|
|
|
|
|
connectWith: ".table tbody",
|
|
|
|
|
start: function(event, ui){
|
2021-04-04 12:33:09 +00:00
|
|
|
|
var target = $(event.target);
|
|
|
|
|
if(target.find("tr[data-id]").length <= 1){
|
|
|
|
|
target.find(".blank_tr").css("display","");
|
|
|
|
|
}else{
|
|
|
|
|
target.find(".blank_tr").css("display","none");
|
|
|
|
|
}
|
2021-04-03 16:23:52 +00:00
|
|
|
|
$(".session_block").css("overflow","hidden");
|
2021-04-04 12:33:09 +00:00
|
|
|
|
parent_left_block = ui.item.parents(".left_block");
|
|
|
|
|
if(parent_left_block.length != 0){
|
|
|
|
|
var parent_block = ui.item.parents(".session_block");
|
|
|
|
|
parent_left_block.before(ui.item);
|
|
|
|
|
window.parent_block = parent_block;
|
|
|
|
|
ui.item.css("background","#ffffff");
|
|
|
|
|
window.over_flag = false;
|
|
|
|
|
}else{
|
|
|
|
|
window.parent_block = undefined;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
sort: function(event, ui) {
|
|
|
|
|
if(window.parent_block != undefined){
|
|
|
|
|
var offset = ui.position;
|
|
|
|
|
var parent_offset = window.parent_block.offset();
|
|
|
|
|
if(!window.over_flag){
|
|
|
|
|
offset = add_obj(ui.position,parent_offset);
|
|
|
|
|
ui.item.offset(offset);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
over: function( event, ui ) {
|
|
|
|
|
if(window.parent_block != undefined && $(this).data("id") != window.parent_block.data("id")){
|
|
|
|
|
window.over_flag = true;
|
|
|
|
|
}
|
2021-04-03 16:23:52 +00:00
|
|
|
|
},
|
|
|
|
|
stop: function(event, ui){
|
|
|
|
|
$(".session_block").css("overflow","");
|
2021-04-04 12:33:09 +00:00
|
|
|
|
ui.item.css("background","");
|
|
|
|
|
console.log("stop")
|
2021-04-03 16:23:52 +00:00
|
|
|
|
},
|
|
|
|
|
update: function(event, ui) {
|
|
|
|
|
var target = $(event.target);
|
|
|
|
|
var mode = "";
|
|
|
|
|
var session_id = target.data("id");
|
|
|
|
|
var signup_id = ui.item.data("id");
|
|
|
|
|
if(ui.item.parent().data("id") == session_id){
|
|
|
|
|
mode = "append";
|
|
|
|
|
}else{
|
|
|
|
|
mode = "remove";
|
|
|
|
|
}
|
|
|
|
|
if(target.find("tr").not(".blank_tr").length == 0){
|
|
|
|
|
target.find(".blank_tr").css("display","");
|
|
|
|
|
}else{
|
|
|
|
|
target.find(".blank_tr").css("display","none");
|
|
|
|
|
}
|
|
|
|
|
if(session_id != undefined){
|
|
|
|
|
$.post("<%=update_seminar_session_admin_seminar_path(params[:id])%>",{session_id: session_id,mode: mode,signup_id: signup_id}).done(function(data){
|
|
|
|
|
console.log(data);
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
$(document).ready(function(){
|
2021-04-04 12:33:09 +00:00
|
|
|
|
$("tbody").each(function(i,v){
|
|
|
|
|
if($(v).find("tr[data-id]").length != 0){
|
|
|
|
|
$(v).find("tr.blank_tr").css("display","none");
|
|
|
|
|
}
|
|
|
|
|
})
|
2021-04-03 16:23:52 +00:00
|
|
|
|
init_func();
|
|
|
|
|
})
|
|
|
|
|
$(window).resize(function(){
|
|
|
|
|
adjust_height();
|
|
|
|
|
})
|
|
|
|
|
</script>
|
|
|
|
|
<style type="text/css">
|
|
|
|
|
.icons-list-2 {
|
|
|
|
|
cursor: all-scroll;
|
|
|
|
|
}
|
|
|
|
|
.session_block{
|
|
|
|
|
overflow: scroll;
|
|
|
|
|
border: 0.2em solid black;
|
|
|
|
|
position: relative;
|
|
|
|
|
}
|
|
|
|
|
.zoom_out_btn{
|
|
|
|
|
width: 1em;
|
|
|
|
|
height: 1em;
|
|
|
|
|
position: absolute;
|
|
|
|
|
top: 0;
|
|
|
|
|
right: 0;
|
|
|
|
|
background: #454545;
|
|
|
|
|
color: #FFFFFF;
|
|
|
|
|
font-size: 2em;
|
|
|
|
|
text-align: center;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
}
|
|
|
|
|
.blank_block .add_btn {
|
|
|
|
|
position: absolute;
|
|
|
|
|
top: 50%;
|
|
|
|
|
left: 50%;
|
|
|
|
|
font-size: 3em;
|
|
|
|
|
width: 20px;
|
|
|
|
|
height: 20px;
|
|
|
|
|
margin: -10px 0 0 -10px;
|
|
|
|
|
display: inline-block;
|
|
|
|
|
font-family: FontAwesome;
|
|
|
|
|
font-style: normal;
|
|
|
|
|
font-weight: normal;
|
|
|
|
|
line-height: 1;
|
|
|
|
|
-webkit-font-smoothing: antialiased;
|
|
|
|
|
-moz-osx-font-smoothing: grayscale;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
}
|
|
|
|
|
</style>
|
|
|
|
|
<% end %>
|