https://github.com/galaxyproject/galaxy
Tip revision: ae7fe38ea8b9fff70400398964299c4d89755e03 authored by Nate Coraor on 02 May 2023, 15:49:30 UTC
Update pulsar-galaxy-lib to 0.15.2 for test.galaxyproject.org
Update pulsar-galaxy-lib to 0.15.2 for test.galaxyproject.org
Tip revision: ae7fe38
page_base.mako
<%doc>
This file defines methods for displaying information about pagination
</%doc>
<%def name="get_page_url( sort_id, order, *args, **kwargs )">
%try:
%if str(by_destination).lower() == "true":
<a href="${h.url_for( controller=args[0], action=args[1], by_destination=True, sort_id=sort_id, order=order, **kwargs )}">${kwargs.get("page")}</a>
%endif
%except NameError:
<a href="${h.url_for( controller=args[0], action=args[1], sort_id=sort_id, order=order, **kwargs )}">${kwargs.get("page")}</a>
%endtry
</%def>
<%!
def get_raw_url(sort_id, order, *args, **kwargs):
return h.url_for( controller=args[0], action=args[1], sort_id=sort_id, order=order, **kwargs )
%>
<%def name="get_pages( sort_id, order, page_specs, *args, **kwargs )">
## Creates the page buttons
${get_page_script()}
<div id="page_selector">
<div id="back_button">↞</div>
%for x in range(-2,3):
<%
page = int(page_specs.page) + x
pages_found = int(page_specs.pages_found)
%>
%if page > 0:
%if x == 0:
<div id="curr_button">${page}</div>
%elif page < page_specs.page + pages_found:
<%
entries = page_specs.entries
offset = page_specs.entries * (page - 1)
%>
%if x == -2 and page > 1:
<div class="miss_pages">...</div>
%endif
<div class="page_button">${get_page_url( sort_id, order, *args, page=page, offset=offset, entries=entries, **kwargs )}</div>
%if x == 2 and pages_found == 4:
<div class="miss_pages">...</div>
%endif
%endif
%endif
%endfor
<div id="next_button">↠</div>
</div>
</%def>
<%def name="get_entry_selector(controller, action, entries, sort_id, order, by_destination=False)">
<div id="entry_form" >
<form method="post" controller=${controller} action=${action}>
<input type="hidden" value=${sort_id} name="sort_id">
<input type="hidden" value=${order} name="order">
<input type="hidden" value=${by_destination} name="by_destination">
%try:
%if spark_limit:
<input type="hidden" value=${spark_limit} name="spark_limit">
%endif
%except NameError:
%endtry
Max items:
<input id="entries_edit"
type="text"
name="entries"
value="${entries}">
</input>
<button id="entry_submit">Go</button>
</form>
</div>
</%def>
<%def name="get_page_script()">
<script>
$(document).ready( function(e) {
var drop_down = false;
//Close the dropdown in the event of focusout() from entries edit
$("#entries_edit").focusout( function(e) {
var speed = 50;
$("#entry_submit").css("cursor", "default");
$("#entry_submit").fadeTo(speed, 0.0);
$(".st4").animate({top: "-=18px"}, {duration: speed, queue: false, complete: function() {
$(".st3").animate({top: "-=18px"}, {duration: speed, queue: false, complete: function() {
$(".st2").animate({top: "-=18px"}, {duration: speed, queue: false, complete: function() {
$(".st1").animate({top: "-=18px"}, {duration: speed, queue: false, complete: function() {
$(".st1").remove()
}});
}});
}});
}});
drop_down = false;
});
//Make sure the elements stay correctly positioned
$("#formHeader").css("margin-left", $(".colored").css("margin-left"));
$("#formHeader").css("width", $(".colored").css("width"));
$(window).resize( function(e) {
$("#formHeader").css("margin-left", $(".colored").css("margin-left"));
$("#formHeader").css("width", $(".colored").css("width"));
//Remove drop down for entry amount selection
$(".st1").remove();
$("#entry_submit").css("cursor", "default");
$("#entry_submit").css("opacity", "0.0");
$("#entry_submit").blur();
drop_down = false;
});
//If there are pages to go back to, go back
if( $("#curr_button").html() == 1) {
$("#back_button").css( "cursor", "default" );
$("#back_button").css( "color", "grey" );
}
$("#back_button").click( function(e) {
if( $("#curr_button").html() != 1) {
window.open( $(".page_button:first").children().attr("href"), "_self" );
}
});
//If there is a next page, go to the next page
if( ${int(page_specs.pages_found)} == 1 ) {
$("#next_button").css( "cursor", "default" );
$("#next_button").css( "color", "grey" );
}
$("#next_button").click( function(e) {
if( ${int(page_specs.pages_found)} > 1 ) {
window.open( $(".page_button:last").children().attr("href"), "_self" );
}
});
//Select amount of entries per page
$("#entry_form").on( "mousedown", ".st1", function(e) {
e.preventDefault();
$("#entries_edit").val( $(this).html() );
});
$("#entry_form").on("mouseenter", ".st1", function(e) {
$(this).css({
"border-color": "black",
"background-color": "#ebd9b2",
})
});
$("#entry_form").on("mouseleave", ".st1", function(e) {
$(this).css({
"border-color": "grey",
"background-color": "white",
})
});
$("#entries_edit").click( function(e) {
if(!drop_down) {
//Initialize items
$("#entries_edit").parent().append("<div class=\"st1\"\">10</div>");
$("#entries_edit").parent().append("<div class=\"st1 st2\">25</div>");
$("#entries_edit").parent().append("<div class=\"st1 st2 st3\">50</div>");
$("#entries_edit").parent().append("<div class=\"st1 st2 st3 st4\">100</div>");
$("#entry_submit").css("cursor", "pointer");
var top_pos = $("#entries_edit").offset().top;
var left_pos = $("#entries_edit").offset().left;
$(".st1").css({
"cursor": "pointer",
"position": "absolute",
"text-align": "center",
"border": "1px solid grey",
"background-color": "white",
"margin-left": "3px",
"top": top_pos,
"left": left_pos,
"width": "30px",
"z-index": "4",
});
$(".st1").css({
"top": $("#entries_edit").offset().top,
});
$(".st2").css({"z-index": "3"})
$(".st3").css({"z-index": "2"})
$(".st4").css({
"z-index": "1",
"border-bottom-left-radius": "3px",
"border-bottom-right-radius": "3px",
});
//Anitmate items
var speed = 50;
$("#entry_submit").fadeTo(speed, 1.0);
$(".st1").animate({top: "+=18px"}, speed);
$(".st2").animate({top: "+=18px"}, speed);
$(".st3").animate({top: "+=18px"}, speed);
$(".st4").animate({top: "+=18px"}, speed);
}
drop_down = true;
});
});
</script>
</%def>