2021-06-19 13:16:25 +02:00
|
|
|
<?php
|
|
|
|
echo $this->Html->scriptBlock(sprintf(
|
|
|
|
'var csrfToken = %s;',
|
|
|
|
json_encode($this->request->getAttribute('csrfToken'))
|
|
|
|
));
|
|
|
|
echo $this->element('genericElements/IndexTable/index_table', [
|
|
|
|
'data' => [
|
|
|
|
'data' => $data,
|
|
|
|
'top_bar' => [
|
|
|
|
'children' => [
|
2021-06-23 11:34:26 +02:00
|
|
|
[
|
2021-07-05 09:30:20 +02:00
|
|
|
'type' => 'multi_select_actions',
|
2021-06-23 11:34:26 +02:00
|
|
|
'children' => [
|
|
|
|
[
|
|
|
|
'text' => __('Delete messages'),
|
|
|
|
'variant' => 'danger',
|
|
|
|
'onclick' => 'deleteMessages',
|
|
|
|
]
|
|
|
|
],
|
2021-07-05 09:30:20 +02:00
|
|
|
'data' => [
|
|
|
|
'id' => [
|
|
|
|
'value_path' => 'id'
|
|
|
|
]
|
|
|
|
]
|
2021-06-23 11:34:26 +02:00
|
|
|
],
|
2021-06-19 13:16:25 +02:00
|
|
|
[
|
|
|
|
'type' => 'context_filters',
|
|
|
|
'context_filters' => !empty($filteringContexts) ? $filteringContexts : []
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'type' => 'search',
|
2021-11-10 15:31:09 +01:00
|
|
|
'button' => __('Search'),
|
2021-06-19 13:16:25 +02:00
|
|
|
'placeholder' => __('Enter value to search'),
|
|
|
|
'data' => '',
|
|
|
|
'searchKey' => 'value',
|
|
|
|
'allowFilering' => true
|
|
|
|
]
|
|
|
|
]
|
|
|
|
],
|
|
|
|
'fields' => [
|
|
|
|
[
|
|
|
|
'name' => '#',
|
|
|
|
'sort' => 'id',
|
|
|
|
'data_path' => 'id',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'created',
|
|
|
|
'sort' => 'created',
|
|
|
|
'data_path' => 'created',
|
|
|
|
'element' => 'datetime'
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'scope',
|
|
|
|
'sort' => 'scope',
|
|
|
|
'data_path' => 'scope',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'action',
|
|
|
|
'sort' => 'action',
|
|
|
|
'data_path' => 'action',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'title',
|
|
|
|
'sort' => 'title',
|
|
|
|
'data_path' => 'title',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'user',
|
|
|
|
'sort' => 'user_id',
|
|
|
|
'data_path' => 'user',
|
|
|
|
'element' => 'user'
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'description',
|
|
|
|
'sort' => 'description',
|
|
|
|
'data_path' => 'description',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'comment',
|
|
|
|
'sort' => 'comment',
|
|
|
|
'data_path' => 'comment',
|
|
|
|
],
|
|
|
|
],
|
|
|
|
'title' => __('Outbox'),
|
|
|
|
'description' => __('A list of requests to be manually processed'),
|
|
|
|
'actions' => [
|
|
|
|
[
|
|
|
|
'url' => '/outbox/view',
|
|
|
|
'url_params_data_paths' => ['id'],
|
|
|
|
'icon' => 'eye',
|
|
|
|
'title' => __('View request')
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'open_modal' => '/outbox/process/[onclick_params_data_path]',
|
|
|
|
'modal_params_data_path' => 'id',
|
|
|
|
'icon' => 'cogs',
|
|
|
|
'title' => __('Process request')
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'open_modal' => '/outbox/delete/[onclick_params_data_path]',
|
|
|
|
'modal_params_data_path' => 'id',
|
|
|
|
'icon' => 'trash',
|
|
|
|
'title' => __('Discard request')
|
|
|
|
],
|
|
|
|
]
|
|
|
|
]
|
|
|
|
]);
|
|
|
|
?>
|
2021-06-23 11:34:26 +02:00
|
|
|
|
|
|
|
<script>
|
|
|
|
function deleteMessages(idList, selectedData, $table) {
|
|
|
|
UI.submissionModalForIndex('/outbox/delete', '/outbox/index', $table).then(([modalObject, ajaxApi]) => {
|
|
|
|
const $idsInput = modalObject.$modal.find('form').find('input#ids-field')
|
|
|
|
$idsInput.val(JSON.stringify(idList))
|
|
|
|
const tableData = selectedData.map(row => {
|
|
|
|
return [row.id, row.scope, row.action, row.title]
|
|
|
|
});
|
|
|
|
handleMessageTable(
|
|
|
|
modalObject.$modal,
|
|
|
|
['<?= __('ID') ?>', '<?= __('Scope') ?>', '<?= __('Action') ?>', '<?= __('Title') ?>'],
|
|
|
|
tableData
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
|
|
|
function constructMessageTable(header, data) {
|
|
|
|
return HtmlHelper.table(
|
|
|
|
header,
|
|
|
|
data,
|
|
|
|
{
|
|
|
|
small: true,
|
|
|
|
borderless: true,
|
|
|
|
tableClass: ['message-table', 'mt-4 mb-0'],
|
|
|
|
}
|
|
|
|
)
|
|
|
|
}
|
|
|
|
function handleMessageTable($modal, header, data) {
|
|
|
|
const $modalBody = $modal.find('.modal-body')
|
|
|
|
const $messageTable = $modalBody.find('table.message-table')
|
|
|
|
const messageTableHTML = constructMessageTable(header, data)[0].outerHTML
|
|
|
|
if ($messageTable.length) {
|
|
|
|
$messageTable.html(messageTableHTML)
|
|
|
|
} else {
|
|
|
|
$modalBody.append(messageTableHTML)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|