mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-10-24 16:39:21 -04:00
Script to handle statments in the client portal
This commit is contained in:
parent
9c0559a334
commit
76804fc37b
@ -12,22 +12,22 @@
|
|||||||
<div class="flex">
|
<div class="flex">
|
||||||
<label for="from" class="block w-full flex items-center mr-4">
|
<label for="from" class="block w-full flex items-center mr-4">
|
||||||
<span class="mr-2">{{ ctrans('texts.from') }}:</span>
|
<span class="mr-2">{{ ctrans('texts.from') }}:</span>
|
||||||
<input type="date" class="input w-full">
|
<input id="date-from" type="date" class="input w-full" data-field="startDate" value="{{ now()->startOfYear()->format('Y-m-d') }}">
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
<label for="to" class="block w-full flex items-center mr-4">
|
<label for="to" class="block w-full flex items-center mr-4">
|
||||||
<span class="mr-2">{{ ctrans('texts.to') }}:</span>
|
<span class="mr-2">{{ ctrans('texts.to') }}:</span>
|
||||||
<input type="date" class="input w-full">
|
<input id="date-to" type="date" class="input w-full" data-field="endDate" value="{{ now()->format('Y-m-d') }}">
|
||||||
</label>
|
</label>
|
||||||
</div> <!-- End date range -->
|
</div> <!-- End date range -->
|
||||||
|
|
||||||
<label for="show_payments" class="block flex items-center mr-4 mt-4 md:mt-0">
|
<label for="show_payments" class="block flex items-center mr-4 mt-4 md:mt-0">
|
||||||
<input type="checkbox" class="form-checkbox" autocomplete="off">
|
<input id="show-payments-table" type="checkbox" data-field="showPaymentsTable" class="form-checkbox" autocomplete="off">
|
||||||
<span class="ml-2">{{ ctrans('texts.show_payments') }}</span>
|
<span class="ml-2">{{ ctrans('texts.show_payments') }}</span>
|
||||||
</label> <!-- End show payments checkbox -->
|
</label> <!-- End show payments checkbox -->
|
||||||
|
|
||||||
<label for="show_aging" class="block flex items-center">
|
<label for="show_aging" class="block flex items-center">
|
||||||
<input type="checkbox" class="form-checkbox" autocomplete="off">
|
<input id="show-aging-table" type="checkbox" data-field="showAgingTable" class="form-checkbox" autocomplete="off">
|
||||||
<span class="ml-2">{{ ctrans('texts.show_aging') }}</span>
|
<span class="ml-2">{{ ctrans('texts.show_aging') }}</span>
|
||||||
</label> <!-- End show aging checkbox -->
|
</label> <!-- End show aging checkbox -->
|
||||||
</div>
|
</div>
|
||||||
@ -39,12 +39,70 @@
|
|||||||
|
|
||||||
@push('footer')
|
@push('footer')
|
||||||
<script>
|
<script>
|
||||||
document.addEventListener('DOMContentLoaded', () => {
|
class Statement {
|
||||||
// document
|
constructor() {
|
||||||
// .querySelector('meta[name=pdf-url]')
|
this.url = new URL(document.querySelector('meta[name=pdf-url]').content);
|
||||||
// .content = 'https://google.com';
|
this.startDate = '';
|
||||||
|
this.endDate = '';
|
||||||
|
this.showPaymentsTable = false;
|
||||||
|
this.showAgingTable = false;
|
||||||
|
}
|
||||||
|
|
||||||
// document.querySelector('meta[name=pdf-url]').dispatchEvent(new Event('change'));
|
bindEventListeners() {
|
||||||
});
|
['#date-from', '#date-to', '#show-payments-table', '#show-aging-table'].forEach(selector => {
|
||||||
|
document
|
||||||
|
.querySelector(selector)
|
||||||
|
.addEventListener('change', (event) => this.handleValueChange(event));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
handleValueChange(event) {
|
||||||
|
if (event.target.type === 'checkbox') {
|
||||||
|
console.log(1);
|
||||||
|
this[event.target.dataset.field] = event.target.checked;
|
||||||
|
} else {
|
||||||
|
this[event.target.dataset.field] = event.target.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.updatePdf();
|
||||||
|
}
|
||||||
|
|
||||||
|
get composedUrl() {
|
||||||
|
this.url.search = '';
|
||||||
|
|
||||||
|
if (this.startDate.length > 0) {
|
||||||
|
this.url.searchParams.append('start_date', this.startDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.endDate.length > 0) {
|
||||||
|
this.url.searchParams.append('end_date', this.endDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.url.searchParams.append('show_payments_table', +this.showPaymentsTable);
|
||||||
|
this.url.searchParams.append('show_aging_table', +this.showAgingTable);
|
||||||
|
|
||||||
|
return this.url.href;
|
||||||
|
}
|
||||||
|
|
||||||
|
updatePdf() {
|
||||||
|
document
|
||||||
|
.querySelector('meta[name=pdf-url]')
|
||||||
|
.content = this.composedUrl;
|
||||||
|
|
||||||
|
let iframe = document.querySelector('#pdf-iframe');
|
||||||
|
|
||||||
|
if (iframe) {
|
||||||
|
iframe.src = this.composedUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
document.querySelector('meta[name=pdf-url]').dispatchEvent(new Event('change'));
|
||||||
|
}
|
||||||
|
|
||||||
|
handle() {
|
||||||
|
this.bindEventListeners();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
new Statement().handle();
|
||||||
</script>
|
</script>
|
||||||
@endpush
|
@endpush
|
Loading…
x
Reference in New Issue
Block a user