##// END OF EJS Templates
feat(remap and rescan): added more relient remap and removal option, and also split the logic to either add or cleanup
feat(remap and rescan): added more relient remap and removal option, and also split the logic to either add or cleanup

File last commit:

r5170:a77dd674 default
r5619:c9e499e7 default
Show More
my_account_pullrequests.mako
170 lines | 5.9 KiB | application/x-mako | MakoHtmlLexer
<%namespace name="base" file="/base/base.mako"/>
<div class="panel panel-default">
<div class="panel-heading">
<h3 class="panel-title">${_('Pull Requests You Participate In')}</h3>
</div>
<div class="panel-body panel-body-min-height">
<div class="title">
<ul class="button-links">
<li><a class="btn ${h.is_active('all', c.selected_filter)}"
href="${h.route_path('my_account_pullrequests', _query={})}">
${_('Open')}
</a>
</li>
<li><a class="btn ${h.is_active('all_closed', c.selected_filter)}"
href="${h.route_path('my_account_pullrequests', _query={'closed':1})}">
${_('All + Closed')}
</a>
</li>
<li><a class="btn ${h.is_active('awaiting_my_review', c.selected_filter)}"
href="${h.route_path('my_account_pullrequests', _query={'awaiting_my_review':1})}">
${_('Awaiting my review')}
</a>
</li>
</ul>
<div class="grid-quick-filter">
<ul class="grid-filter-box">
<li class="grid-filter-box-icon">
<i class="icon-search"></i>
</li>
<li class="grid-filter-box-input">
<input class="q_filter_box" id="q_filter" size="15" type="text" name="filter"
placeholder="${_('quick filter...')}" value=""/>
</li>
</ul>
</div>
</div>
<table id="pull_request_list_table" class="rctable table-bordered"></table>
</div>
</div>
<script type="text/javascript">
$(document).ready(function () {
var $pullRequestListTable = $('#pull_request_list_table');
// participating object list
$pullRequestListTable.DataTable({
processing: true,
serverSide: true,
stateSave: true,
stateDuration: -1,
ajax: {
"url": "${h.route_path('my_account_pullrequests_data')}",
"data": function (d) {
d.closed = "${c.closed}";
d.awaiting_my_review = "${c.awaiting_my_review}";
},
"dataSrc": function (json) {
return json.data;
}
},
dom: 'rtp',
pageLength: ${c.visual.dashboard_items},
order: [[2, "desc"]],
columns: [
{
data: {
"_": "status",
"sort": "status"
}, title: "PR", className: "td-status", orderable: false
},
{
data: {
"_": "my_status",
"sort": "status"
}, title: "You", className: "td-status", orderable: false
},
{
data: {
"_": "name",
"sort": "name_raw"
}, title: "${_('Id')}", className: "td-componentname", "type": "num"
},
{
data: {
"_": "title",
"sort": "title"
}, title: "${_('Title')}", className: "td-description"
},
{
data: {
"_": "pr_flow",
"sort": "pr_flow"
}, title: "${_('Flow')}", className: "td-componentname"
},
{
data: {
"_": "author",
"sort": "author_raw"
}, title: "${_('Author')}", className: "td-user", orderable: false
},
{
data: {
"_": "comments",
"sort": "comments_raw"
}, title: "", className: "td-comments", orderable: false
},
{
data: {
"_": "updated_on",
"sort": "updated_on_raw"
}, title: "${_('Last Update')}", className: "td-time"
},
{
data: {
"_": "target_repo",
"sort": "target_repo"
}, title: "${_('Target Repo')}", className: "td-targetrepo", orderable: false
},
],
language: {
paginate: DEFAULT_GRID_PAGINATION,
sProcessing: _gettext('loading...'),
emptyTable: _gettext("There are currently no open pull requests requiring your participation.")
},
"drawCallback": function (settings, json) {
timeagoActivate();
tooltipActivate();
},
"createdRow": function (row, data, index) {
if (data['closed']) {
$(row).addClass('closed');
}
if (data['owned']) {
$(row).addClass('owned');
}
},
"stateSaveParams": function (settings, data) {
data.search.search = ""; // Don't save search
data.start = 0; // don't save pagination
}
});
$pullRequestListTable.on('xhr.dt', function (e, settings, json, xhr) {
$pullRequestListTable.css('opacity', 1);
});
$pullRequestListTable.on('preXhr.dt', function (e, settings, data) {
$pullRequestListTable.css('opacity', 0.3);
});
// filter
$('#q_filter').on('keyup',
$.debounce(250, function () {
$pullRequestListTable.DataTable().search(
$('#q_filter').val()
).draw();
})
);
});
</script>