/** * First we will load all of this project's JavaScript dependencies which * includes Vue and other libraries. It is a great starting point when * building robust, powerful web applications using Vue and Laravel. */ require('./../../bootstrap'); import Vue from 'vue'; import DashboardPlugin from './../../plugins/dashboard-plugin'; import Global from './../../mixins/global'; import Form from './../../plugins/form'; import Error from './../../plugins/error'; import BulkAction from './../../plugins/bulk-action'; // plugin setup Vue.use(DashboardPlugin); const app = new Vue({ el: '#app', mixins: [ Global ], data: function () { return { form: new Form('invoice'), bulk_action: new BulkAction('invoices'), totals: { sub: 0, discount: '', discount_text: false, tax: 0, total: 0 }, transaction_form: new Form('transaction'), payment: { modal: false, amount: 0, title: '', message: '', html: '', errors: new Error() }, transaction: [], items: '', discount: false } }, mounted() { this.form.items = []; if (this.form.method) { this.onAddItem(); } if (typeof invoice_items !== 'undefined' && invoice_items) { let items = []; let currency_code = this.form.currency_code; invoice_items.forEach(function(item) { items.push({ show: false, currency: currency_code, item_id: item.item_id, name: item.name, price: (item.price).toFixed(2), quantity: item.quantity, tax_id: item.tax_id, total: (item.total).toFixed(2) }); }); this.form.items = items; } }, methods:{ onChangeContact(contact_id) { axios.get(url + '/sales/customers/' + contact_id + '/currency') .then(response => { this.form.contact_name = response.data.name; this.form.contact_email = response.data.email; this.form.contact_tax_number = response.data.tax_number; this.form.contact_phone = response.data.phone; this.form.contact_address = response.data.address; this.form.currency_code = response.data.currency_code; this.form.currency_rate = response.data.currency_rate; }) .catch(error => { }); }, onChangeCurrency(currency_code) { axios.get(url + '/settings/currencies/currency', { params: { code: currency_code } }) .then(response => { this.form.currency_code = response.data.currency_code; this.form.currency_rate = response.data.currency_rate; }) .catch(error => { }); }, onCalculateTotal() { axios.post(url + '/common/items/total', { items: this.form.items, discount: this.form.discount, currency_code: this.form.currency_code }) .then(response => { let items = this.form.items; response.data.items.forEach(function(value, index) { items[index].total = value; }); this.form.items = items; this.totals.sub = response.data.sub_total; this.totals.discount = response.data.discount_total; this.totals.tax = response.data.tax_total; this.totals.total = response.data.grand_total; this.totals.discount_text = response.data.discount_text; }) .catch(error => { }); }, onAddItem() { let row = []; let keys = Object.keys(this.form.item_backup[0]); let currency_code = this.form.currency_code; keys.forEach(function(item) { if (item == 'currency') { row[item] = currency_code; } else { row[item] = ''; } }); this.form.items.push(Object.assign({}, row)); }, onGetItem(event, index) { let name = event.target.value; this.form.items[index].show = false; axios.get(url + '/common/items/autocomplete', { params: { query: name, type: 'invoice', currency_code: this.form.currency_code } }) .then(response => { this.items = response.data; if (this.items.length) { this.form.items[index].show = true; } }) .catch(error => { }); }, onSelectItem(item, index) { this.form.items[index].item_id = item.id; this.form.items[index].name = item.name; this.form.items[index].price = (item.purchase_price).toFixed(2); this.form.items[index].quantity = 1; this.form.items[index].total = item.total; this.form.items[index].show = false; }, onDeleteItem(index) { this.form.items.splice(index, 1); }, onAddDiscount() { let discount = document.getElementById('pre-discount').value; this.form.discount = discount; this.discount = false; }, onPayment() { this.payment.modal = true; let form = this.transaction_form; this.transaction_form = new Form('transaction'); this.transaction_form.paid_at = form.paid_at; this.transaction_form.account_id = form.account_id; this.transaction_form.payment_method = form.payment_method; this.transaction_form.amount = form.amount; }, addPayment() { this.transaction_form.submit(); this.payment.errors = this.transaction_form.errors; }, closePayment() { this.payment = { modal: false, amount: 0, title: '', message: '', errors: this.transaction_form.errors }; }, // Change bank account get money and currency rate onChangePaymentAccount(account_id) { axios.get(url + '/banking/accounts/currency', { params: { account_id: account_id } }) .then(response => { this.transaction_form.currency = response.data.currency_name; this.transaction_form.currency_code = response.data.currency_code; this.transaction_form.currency_rate = response.data.currency_rate; this.money.decimal = response.data.decimal_mark; this.money.thousands = response.data.thousands_separator; this.money.prefix = (response.data.symbol_first) ? response.data.symbol : ''; this.money.suffix = !(response.data.symbol_first) ? response.data.symbol : ''; this.money.precision = response.data.precision; }) .catch(error => { }); }, onDeleteTransaction(form_id) { this.transaction = new Form(form_id); this.confirm.url = this.transaction.action; this.confirm.title = this.transaction.title; this.confirm.message = this.transaction.message; this.confirm.button_cancel = this.transaction.cancel; this.confirm.button_delete = this.transaction.delete; this.confirm.show = true; } } });