ok

Mini Shell

Direktori : /home2/selectio/www/fms-worksuite/app/DataTables/
Upload File :
Current File : //home2/selectio/www/fms-worksuite/app/DataTables/SalesReportDataTable.php

<?php

namespace App\DataTables;

use App\DataTables\BaseDataTable;
use App\Models\Invoice;
use App\Models\InvoiceItems;
use App\Models\Payment;
use App\Models\Tax;
use Carbon\Carbon;
use Illuminate\Support\Facades\DB;
use Yajra\DataTables\Html\Button;

class SalesReportDataTable extends BaseDataTable
{

    /**
     * Build DataTable class.
     *
     * @param mixed $query Results from query() method.
     * @return \Yajra\DataTables\DataTableAbstract
     */

    public function dataTable($query) // phpcs:ignore
    {
        $taxes = Tax::all();

        $datatable = datatables()
            ->eloquent($query);

        $datatable->addColumn('paid_on', function ($row) {
            return $row->paid_on ? Carbon::parse($row->paid_on)->format($this->company->date_format) : '--';
        });
        $datatable->addColumn('invoice_number', function ($row) {
            return $row->custom_invoice_number ? $row->custom_invoice_number : '--';
        });
        $datatable->addColumn('client_name', function ($row) {
            return $row->client ? $row->client->name : '--';
        });
        $datatable->addColumn('invoice_value', function($row){
            return $row->total ? currency_format($row->total, company()->currency->currency_id) : '--';
        });
        $datatable->addColumn('bank_account', function($row){
            return !is_null($row->bankAccount) ? $row->bankAccount->bank_name : '--';
        });
        $datatable->addColumn('taxable_value', function($row){

            if($row->calculate_tax == 'after_discount')
            {
                if ($row->discount_type == 'percent') {
                    $discountAmount = (($row->sub_total / 100) * $row->discount);
                    $discountedAmount = ($row->sub_total - $discountAmount);
                }
                else {
                    $discountAmount = $row->discount;
                    $discountedAmount = ($row->sub_total - $row->discount);
                }

                return currency_format($discountedAmount, company()->currency->currency_id);

            }

            return currency_format($row->sub_total, company()->currency->currency_id);

        });

        $datatable->addColumn('discount', function($row){
            if($row->discount > 0)
            {
                if ($row->discount_type == 'percent') {
                    $discountAmount = (($row->sub_total / 100) * $row->discount);
                }
                else {
                    $discountAmount = $row->discount;
                }

                return currency_format($discountAmount, company()->currency->currency_id);
            }

            return 0;

        });

        $datatable->addColumn('amount_paid', function($row) {
            return currency_format($row->amountPaid(), $row->currency_id);
        });

        foreach($taxes as $taxName){
            $taxList = array();
            $discount = 0;
            $datatable->addColumn($taxName['tax_name'], function ($row) use ($taxName, $taxList, $discount, $taxes){

                if ($row->discount > 0) {
                    if ($row->discount_type == 'percent') {
                        $discount = (($row->discount / 100) * $row->sub_total);
                    }
                    else {
                        $discount = $row->discount;
                    }
                }

                foreach ($row->items as $item) {

                    if(!is_null($item->taxes)){
                        foreach (json_decode($item->taxes) as $taxId) {

                            $taxValue = $taxes->filter(function ($value, $key) use ($taxId) {
                                return $value->id == $taxId;
                            })->first();

                            if($taxName['tax_name'] == $taxValue->tax_name)
                            {
                                if (!isset($taxList[$taxValue->tax_name . ': ' . $taxValue->rate_percent . '%'])) {

                                    if ($row->calculate_tax == 'after_discount' && $discount > 0) {
                                        $taxList[$taxValue->tax_name . ': ' . $taxValue->rate_percent . '%'] = ($item->amount - ($item->amount / $row->sub_total) * $discount) * ($taxValue->rate_percent / 100);

                                    }
                                    else {
                                        $taxList[$taxValue->tax_name . ': ' . $taxValue->rate_percent . '%'] = $item->amount * ($taxValue->rate_percent / 100);
                                    }

                                }
                                else {

                                    if ($row->calculate_tax == 'after_discount' && $discount > 0) {
                                        $taxList[$taxValue->tax_name . ': ' . $taxValue->rate_percent . '%'] = $taxList[$taxValue->tax_name . ': ' . $taxValue->rate_percent . '%'] + (($item->amount - ($item->amount / $row->sub_total) * $discount) * ($taxValue->rate_percent / 100));

                                    }
                                    else {

                                        $taxList[$taxValue->tax_name . ': ' . $taxValue->rate_percent . '%'] = $taxList[$taxValue->tax_name . ': ' . $taxValue->rate_percent . '%'] + ($item->amount * ($taxValue->rate_percent / 100));
                                    }
                                }
                            }
                        }
                    }
                }

                foreach($taxList as $key => $taxListValue)
                {
                    return currency_format($taxListValue, $row->currency_id);
                }

                return 0;
            });
        }

        $datatable->addIndexColumn()
            ->setRowId(function ($row) {
                return 'row-' . $row->id;
            });
        $rawColumns = $taxes->pluck('tax_name')->toArray();
        $rawColumns[] = array_push($rawColumns, 'client_name', 'paid_on');
        $datatable->orderColumn('client_name', 'client_id $1');
        $datatable->orderColumn('paid_on', 'paid_on $1');
        $datatable->orderColumn('bank_account', 'paid_on $1');
        $datatable->orderColumn('invoice_value', 'total $1');
        $datatable->orderColumn('amount_paid', 'total $1');
        $datatable->orderColumn('taxable_value', 'total $1');
        $datatable->orderColumn('discount', 'total $1');
        $datatable->orderColumn('invoice_number', 'custom_invoice_number $1');
        $datatable->rawColumns($rawColumns)->make(true);
        return $datatable;
    }

    /**
     * @param Payment $model
     * @return \Illuminate\Database\Eloquent\Builder
     */
    public function query(Invoice $model)
    {
        $request = $this->request();

        $model = $model->with('items', 'client', 'bankAccount')->select('payments.paid_on', 'invoices.*')
            ->join('payments', 'payments.invoice_id', 'invoices.id')
            ->whereNotNull('payments.invoice_id');

        if ($request->startDate !== null && $request->startDate != 'null' && $request->startDate != '') {
            $startDate = Carbon::createFromFormat($this->company->date_format, $request->startDate)->toDateString();

            if (!is_null($startDate)) {
                $model = $model->where(DB::raw('DATE(payments.`created_at`)'), '>=', $startDate);
            }
        }

        if ($request->endDate !== null && $request->endDate != 'null' && $request->endDate != '') {
            $endDate = Carbon::createFromFormat($this->company->date_format, $request->endDate)->toDateString();

            if (!is_null($endDate)) {
                $model = $model->where(function ($query) use ($endDate) {
                    $query->where(DB::raw('DATE(payments.`created_at`)'), '<=', $endDate);
                });
            }
        }

        if ($request->clientID != 'all' && !is_null($request->clientID)) {
            $clientId = $request->clientID;
            $model = $model->where(function ($query) use ($clientId) {
                $query->where('invoices.client_id', $clientId);
            });
        }

        $model->groupBy('payments.id');

        return $model;
    }

    /**
     * Optional method if you want to use html builder.
     *
     * @return \Yajra\DataTables\Html\Builder
     */
    public function html()
    {
        return $this->builder()
            ->setTableId('sales-report-table')
            ->columns($this->getColumns())
            ->minifiedAjax()
            ->orderBy(5)
            ->destroy(true)
            ->responsive(true)
            ->serverSide(true)
            ->stateSave(true)
            ->processing(true)
            ->dom($this->domHtml)
            ->language(__('app.datatable'))
            ->parameters([
                'initComplete' => 'function () {
                    window.LaravelDataTables["sales-report-table"].buttons().container()
                     .appendTo( "#table-actions")
                 }',
                'fnDrawCallback' => 'function( oSettings ) {
                   //
                   $(".select-picker").selectpicker();
                 }',
            ])
            ->buttons(Button::make(['extend' => 'excel', 'text' => '<i class="fa fa-file-export"></i> ' . trans('app.exportExcel')]));
    }

    /**
     * Get columns.
     *
     * @return array
     */
    protected function getColumns()
    {
        $columns = Tax::all();
        $newColumns = [];

        $newColumns['#'] = ['data' => 'DT_RowIndex',  'orderable' => false, 'searchable' => false, 'visible' => false];
        $newColumns[__('app.id')] = ['data' => 'id', 'name' => 'id', 'visible' => false, 'exportable' => false, 'title' => __('app.id')];
        $newColumns[__('modules.payments.paidOn')] = ['data' => 'paid_on', 'name' => 'paid_on', 'title' => __('modules.payments.paidOn')];
        $newColumns[__('app.invoiceNumber')] = ['data' => 'invoice_number', 'name' => 'invoice_number', 'title' => __('app.invoiceNumber')];
        $newColumns[__('app.clientName')] = ['data' => 'client_name', 'name' => 'client_name', 'title' => __('app.clientName')];
        $newColumns[__('modules.invoices.invoiceValue')] = ['data' => 'invoice_value', 'name' => 'invoice_value', 'title' => __('modules.invoices.invoiceValue')];
        $newColumns[__('modules.invoices.amountPaid')] = ['data' => 'amount_paid', 'name' => 'amount_paid', 'title' => __('modules.invoices.amountPaid')];
        $newColumns[__('modules.invoices.taxableValue')] = ['data' => 'taxable_value', 'name' => 'taxable_value', 'title' => __('modules.invoices.taxableValue')];
        $newColumns[__('modules.invoices.discount')] = ['data' => 'discount', 'name' => 'discount', 'title' => __('modules.invoices.discount')];

        foreach ($columns as $column) {
            $newColumns[$column->tax_name] = ['data' => $column->tax_name, 'name' => $column->tax_name, 'orderable' => false, 'searchable' => false, 'visible' => true];
        }

        $newColumns[__('app.bankaccount')] = ['data' => 'bank_account', 'name' => 'bank_account', 'title' => __('app.bankaccount')];

        return $newColumns;
    }

}

Zerion Mini Shell 1.0