/
create-source.phtml
63 lines (52 loc) · 1.7 KB
/
create-source.phtml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
<?php
use Fisharebest\Webtrees\Http\RequestHandlers\CreateSourceAction;
use Fisharebest\Webtrees\I18N;
use Fisharebest\Webtrees\Tree;
/**
* @var Tree $tree
*/
?>
<form method="post" action="<?= e(route(CreateSourceAction::class, ['tree' => $tree->name()])) ?>" id="wt-modal-form">
<?= csrf_field() ?>
<?= view('modals/header', ['title' => I18N::translate('Create a source')]) ?>
<div class="modal-body">
<?= view('modals/source-fields', ['tree' => $tree]) ?>
</div>
<?= view('modals/footer-save-cancel') ?>
</form>
<script>
// Submit the modal form using AJAX
document.getElementById('wt-modal-form').addEventListener('submit', function (event) {
event.preventDefault();
let form = event.target;
let modal_content = document.querySelector('#wt-ajax-modal .modal-content');
let select = document.getElementById(modal_content.dataset.wtSelectId);
$.ajax({
url: form.action,
type: form.method,
data: new FormData(form),
async: false,
cache: false,
contentType: false,
processData: false,
success: function (data) {
if (select) {
// If this modal was activated by the "new" button in a select2
// edit control, then insert the result and select it.
let option = new Option(data.text, data.id, true, true);
$(select)
.select2({ escapeMarkup: (x) => x })
.empty()
.append(option)
.trigger('change');
$('#wt-ajax-modal').modal('hide');
} else {
modal_content.innerHTML = data.html;
}
},
failure: function (data) {
modal_content.innerHTML = data.html;
},
});
});
</script>