mirror of
https://github.com/drakkan/sftpgo.git
synced 2024-11-29 02:50:29 +00:00
290 lines
No EOL
11 KiB
HTML
290 lines
No EOL
11 KiB
HTML
{{template "base" .}}
|
||
|
||
{{define "title"}}{{.Title}}{{end}}
|
||
|
||
{{define "extra_css"}}
|
||
<link href="{{.StaticURL}}/vendor/datatables/dataTables.bootstrap4.min.css" rel="stylesheet">
|
||
<link href="{{.StaticURL}}/vendor/datatables/buttons.bootstrap4.min.css" rel="stylesheet">
|
||
<link href="{{.StaticURL}}/vendor/datatables/fixedHeader.bootstrap4.min.css" rel="stylesheet">
|
||
<link href="{{.StaticURL}}/vendor/datatables/responsive.bootstrap4.min.css" rel="stylesheet">
|
||
<link href="{{.StaticURL}}/vendor/datatables/select.bootstrap4.min.css" rel="stylesheet">
|
||
{{end}}
|
||
|
||
{{define "page_body"}}
|
||
|
||
<div id="errorMsg" class="card mb-4 border-left-warning" style="display: none;">
|
||
<div id="errorTxt" class="card-body text-form-error"></div>
|
||
</div>
|
||
|
||
<div id="successMsg" class="card mb-4 border-left-success" style="display: none;">
|
||
<div id="successTxt" class="card-body"></div>
|
||
</div>
|
||
|
||
<div class="card shadow mb-4">
|
||
<div class="card-header py-3">
|
||
<h6 class="m-0 font-weight-bold text-primary">View and manage folders</h6>
|
||
</div>
|
||
<div class="card-body">
|
||
<div class="table-responsive">
|
||
<table class="table table-striped table-bordered nowrap" id="dataTable" width="100%" cellspacing="0">
|
||
<thead>
|
||
<tr>
|
||
<th>Name</th>
|
||
<th>Storage</th>
|
||
<th>Quota</th>
|
||
<th>Used by</th>
|
||
</tr>
|
||
</thead>
|
||
<tbody>
|
||
{{range .Folders}}
|
||
<tr>
|
||
<td>{{.Name}}</td>
|
||
<td>{{.GetStorageDescrition}}</td>
|
||
<td>{{.GetQuotaSummary}}</td>
|
||
<td>{{.GetUsersAsString}}</td>
|
||
</tr>
|
||
{{end}}
|
||
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
{{end}}
|
||
|
||
{{define "dialog"}}
|
||
<div class="modal fade" id="deleteModal" tabindex="-1" role="dialog" aria-labelledby="deleteModalLabel"
|
||
aria-hidden="true">
|
||
<div class="modal-dialog" role="document">
|
||
<div class="modal-content">
|
||
<div class="modal-header">
|
||
<h5 class="modal-title" id="deleteModalLabel">
|
||
Confirmation required
|
||
</h5>
|
||
<button class="close" type="button" data-dismiss="modal" aria-label="Close">
|
||
<span aria-hidden="true">×</span>
|
||
</button>
|
||
</div>
|
||
<div class="modal-body">Do you want to delete the selected virtual folder and any users mapping?</div>
|
||
<div class="modal-footer">
|
||
<button class="btn btn-secondary" type="button" data-dismiss="modal">
|
||
Cancel
|
||
</button>
|
||
<a class="btn btn-warning" href="#" onclick="deleteAction()">
|
||
Delete
|
||
</a>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
{{end}}
|
||
|
||
{{define "extra_js"}}
|
||
<script src="{{.StaticURL}}/vendor/datatables/jquery.dataTables.min.js"></script>
|
||
<script src="{{.StaticURL}}/vendor/datatables/dataTables.bootstrap4.min.js"></script>
|
||
<script src="{{.StaticURL}}/vendor/datatables/dataTables.buttons.min.js"></script>
|
||
<script src="{{.StaticURL}}/vendor/datatables/buttons.bootstrap4.min.js"></script>
|
||
<script src="{{.StaticURL}}/vendor/datatables/dataTables.fixedHeader.min.js"></script>
|
||
<script src="{{.StaticURL}}/vendor/datatables/dataTables.responsive.min.js"></script>
|
||
<script src="{{.StaticURL}}/vendor/datatables/responsive.bootstrap4.min.js"></script>
|
||
<script src="{{.StaticURL}}/vendor/datatables/dataTables.select.min.js"></script>
|
||
<script src="{{.StaticURL}}/vendor/datatables/ellipsis.js"></script>
|
||
<script type="text/javascript">
|
||
|
||
function deleteAction() {
|
||
var table = $('#dataTable').DataTable();
|
||
table.button('delete:name').enable(false);
|
||
var folderName = table.row({ selected: true }).data()[0];
|
||
var path = '{{.FolderURL}}' + "/" + fixedEncodeURIComponent(folderName);
|
||
$('#deleteModal').modal('hide');
|
||
$.ajax({
|
||
url: path,
|
||
type: 'DELETE',
|
||
dataType: 'json',
|
||
headers: {'X-CSRF-TOKEN' : '{{.CSRFToken}}'},
|
||
timeout: 15000,
|
||
success: function (result) {
|
||
table.button('delete:name').enable(true);
|
||
window.location.href = '{{.FoldersURL}}';
|
||
},
|
||
error: function ($xhr, textStatus, errorThrown) {
|
||
table.button('delete:name').enable(true);
|
||
var txt = "Unable to delete the selected folder";
|
||
if ($xhr) {
|
||
var json = $xhr.responseJSON;
|
||
if (json) {
|
||
txt += ": " + json.error;
|
||
}
|
||
}
|
||
$('#errorTxt').text(txt);
|
||
$('#errorMsg').show();
|
||
setTimeout(function () {
|
||
$('#errorMsg').hide();
|
||
}, 5000);
|
||
}
|
||
});
|
||
}
|
||
|
||
$(document).ready(function () {
|
||
$.fn.dataTable.ext.buttons.add = {
|
||
text: '<i class="fas fa-plus"></i>',
|
||
name: 'add',
|
||
titleAttr: "Add",
|
||
action: function (e, dt, node, config) {
|
||
window.location.href = '{{.FolderURL}}';
|
||
}
|
||
};
|
||
|
||
$.fn.dataTable.ext.buttons.edit = {
|
||
text: '<i class="fas fa-pen"></i>',
|
||
name: 'edit',
|
||
titleAttr: "Edit",
|
||
action: function (e, dt, node, config) {
|
||
var folderName = table.row({ selected: true }).data()[0];
|
||
var path = '{{.FolderURL}}' + "/" + fixedEncodeURIComponent(folderName);
|
||
window.location.href = path;
|
||
},
|
||
enabled: false
|
||
};
|
||
|
||
$.fn.dataTable.ext.buttons.template = {
|
||
text: 'Template',
|
||
name: 'template',
|
||
action: function (e, dt, node, config) {
|
||
var selectedRows = table.rows({ selected: true }).count();
|
||
if (selectedRows == 1){
|
||
var folderName = table.row({ selected: true }).data()[0];
|
||
var path = '{{.FolderTemplateURL}}' + "?from=" + fixedEncodeURIComponent(folderName);
|
||
window.location.href = path;
|
||
} else {
|
||
window.location.href = '{{.FolderTemplateURL}}';
|
||
}
|
||
}
|
||
};
|
||
|
||
$.fn.dataTable.ext.buttons.delete = {
|
||
text: '<i class="fas fa-trash"></i>',
|
||
name: 'delete',
|
||
titleAttr: "Delete",
|
||
action: function (e, dt, node, config) {
|
||
$('#deleteModal').modal('show');
|
||
},
|
||
enabled: false
|
||
};
|
||
|
||
$.fn.dataTable.ext.buttons.quota_scan = {
|
||
text: 'Quota scan',
|
||
name: 'quota_scan',
|
||
action: function (e, dt, node, config) {
|
||
dt.button('quota_scan:name').enable(false);
|
||
var folderName = dt.row({ selected: true }).data()[0];
|
||
var path = '{{.FolderQuotaScanURL}}'
|
||
$.ajax({
|
||
url: path,
|
||
type: 'POST',
|
||
dataType: 'json',
|
||
headers: {'X-CSRF-TOKEN' : '{{.CSRFToken}}'},
|
||
data: JSON.stringify({ "name": folderName }),
|
||
timeout: 15000,
|
||
success: function (result) {
|
||
dt.button('quota_scan:name').enable(true);
|
||
$('#successTxt').text("Quota scan started for the selected folder. Please reload the folders page to check when the scan ends");
|
||
$('#successMsg').show();
|
||
setTimeout(function () {
|
||
$('#successMsg').hide();
|
||
}, 5000);
|
||
},
|
||
error: function ($xhr, textStatus, errorThrown) {
|
||
dt.button('quota_scan:name').enable(true);
|
||
var txt = "Unable to update quota for the selected folder";
|
||
if ($xhr) {
|
||
var json = $xhr.responseJSON;
|
||
if (json) {
|
||
if (json.message) {
|
||
txt += ": " + json.message;
|
||
} else if (json.error) {
|
||
txt += ": " + json.error;
|
||
}
|
||
}
|
||
}
|
||
$('#errorTxt').text(txt);
|
||
$('#errorMsg').show();
|
||
setTimeout(function () {
|
||
$('#errorMsg').hide();
|
||
}, 5000);
|
||
}
|
||
});
|
||
},
|
||
enabled: false
|
||
};
|
||
|
||
var table = $('#dataTable').DataTable({
|
||
"select": true,
|
||
"stateSave": true,
|
||
"stateDuration": 3600,
|
||
"buttons": [],
|
||
"columnDefs": [
|
||
{
|
||
"targets": [1],
|
||
"render": $.fn.dataTable.render.ellipsis(50, true),
|
||
},
|
||
{
|
||
"targets": [2],
|
||
"render": $.fn.dataTable.render.ellipsis(50, true),
|
||
},
|
||
{
|
||
"targets": [3],
|
||
"render": $.fn.dataTable.render.ellipsis(40, true),
|
||
}
|
||
],
|
||
"scrollX": false,
|
||
"scrollY": false,
|
||
"responsive": true,
|
||
"language": {
|
||
"emptyTable": "No folder defined"
|
||
},
|
||
"order": [[0, 'asc']]
|
||
});
|
||
|
||
new $.fn.dataTable.FixedHeader( table );
|
||
|
||
{{if .LoggedAdmin.HasPermission "quota_scans"}}
|
||
table.button().add(0,'quota_scan');
|
||
{{end}}
|
||
|
||
{{if .LoggedAdmin.HasPermission "manage_system"}}
|
||
table.button().add(0,'template');
|
||
{{end}}
|
||
|
||
{{if .LoggedAdmin.HasPermission "del_users"}}
|
||
table.button().add(0,'delete');
|
||
{{end}}
|
||
|
||
{{if .LoggedAdmin.HasPermission "edit_users"}}
|
||
table.button().add(0,'edit');
|
||
{{end}}
|
||
|
||
{{if .LoggedAdmin.HasPermission "add_users"}}
|
||
table.button().add(0,'add');
|
||
{{end}}
|
||
|
||
table.buttons().container().appendTo('#dataTable_wrapper .col-md-6:eq(0)');
|
||
|
||
table.on('select deselect', function () {
|
||
var selectedRows = table.rows({ selected: true }).count();
|
||
{{if .LoggedAdmin.HasPermission "del_users"}}
|
||
table.button('delete:name').enable(selectedRows == 1);
|
||
{{end}}
|
||
{{if .LoggedAdmin.HasPermission "edit_users"}}
|
||
table.button('edit:name').enable(selectedRows == 1);
|
||
{{end}}
|
||
{{if .LoggedAdmin.HasPermission "quota_scans"}}
|
||
table.button('quota_scan:name').enable(selectedRows == 1);
|
||
{{end}}
|
||
});
|
||
|
||
});
|
||
|
||
</script>
|
||
{{end}} |