Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/medad.corals.io/Corals/modules/Medad/DataTables/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/medad.corals.io/Corals/modules/Medad/DataTables/PurchaseOrdersDataTable.php
<?php

namespace Corals\Modules\Medad\DataTables;

use Corals\Foundation\DataTables\BaseDataTable;
use Corals\Modules\Medad\Constants\CompanyTypeConstants;
use Corals\Modules\Medad\DataTables\Scopes\AuthUserCompanyDataByProjectScope;
use Corals\Modules\Medad\DataTables\Scopes\AuthUserCompanyDataScope;
use Corals\Modules\Medad\DataTables\Scopes\CompanyListingScope;
use Corals\Modules\Medad\DataTables\Scopes\PurchaseOrdersWithoutInvoicesScope;
use Corals\Modules\Medad\Facades\Medad;
use Corals\Modules\Medad\Models\PurchaseOrder;
use Corals\Modules\Medad\Models\Quotation;
use Corals\Modules\Medad\Transformers\PurchaseOrderTransformer;
use Yajra\DataTables\EloquentDataTable;

class PurchaseOrdersDataTable extends BaseDataTable
{
    public function __construct()
    {
        if (user()->cannot('admin', PurchaseOrder::class)) {
            $this->addScope(new AuthUserCompanyDataScope('purchaseOrder'));
        }
        if (user()->hasRole('medad_project_manager')) {
            $this->addScope(new AuthUserCompanyDataByProjectScope());
        }
        parent::__construct();
    }

    /**
     * Build DataTable class.
     *
     * @param mixed $query Results from query() method.
     * @return \Yajra\DataTables\DataTableAbstract
     */
    public function dataTable($query)
    {
        $this->setResourceUrl(config('medad.models.purchase_order.resource_url'));

        $dataTable = new EloquentDataTable($query);

        return $dataTable->setTransformer(new PurchaseOrderTransformer());
    }

    /**
     * Get query source of dataTable.
     * @param PurchaseOrder $model
     * @return \Illuminate\Database\Eloquent\Builder|static
     */
    public function query(PurchaseOrder $model)
    {
        $model = $model->newQuery();

        $model = $model->orderByRaw("FIELD(status , 'open', 'draft', 'closed') ASC");

        return $model;
    }

    /**
     * Get columns.
     *
     * @return array
     */
    protected function getColumns()
    {
        return [
            'id' => ['visible' => false],
            'code' => ['title' => trans('Medad::attributes.code')],
            'address' => [
                'title' => trans('Utility::attributes.location.address'),
                'searchable' => false,
                'orderable' => false
            ],
            'notes' => ['title' => trans('Medad::attributes.notes')],
            'types_count' => ['title' => trans('Medad::attributes.types_count')],
            'total_quantity' => ['title' => trans('Medad::attributes.total_quantity')],
            'amount' => ['title' => trans('Medad::attributes.amount')],
            'status' => ['title' => trans('Medad::attributes.status')],
            'owner' => ['title' => trans('Medad::attributes.owner')],
            'customer' => ['title' => trans('Medad::attributes.customer')],
            'supplier' => ['title' => trans('Medad::attributes.supplier')],
            'recipients' => ['title' => trans('Medad::attributes.receivers')],

            'quotation' => ['title' => trans('Medad::attributes.purchase_order.quotation')],
            'project' => ['title' => trans('Medad::module.project.title_singular')],
            'updated_at' => ['title' => trans('Corals::attributes.updated_at')],
        ];
    }

    public function getFilters()
    {
        return [
            'code' => [
                'title' => trans('Medad::attributes.code'),
                'class' => 'col-md-2',
                'type' => 'text',
                'condition' => 'like',
                'active' => true
            ],
            'status' => [
                'title' => trans('Medad::attributes.status'),
                'class' => 'col-md-2',
                'type' => 'select2',
                'options' => trans('Medad::attributes.purchase_order.status_options'),
                'function'=>'in',
                'active' => true,
                'attributes' => [
                    'multiple' => true,
                ],
            ],
            'owner_id' => [
                'title' => trans('Medad::attributes.owner'),
                'class' => 'col-md-2',
                'type' => 'select2',
                'options' => Medad::getCompanyUsers(),
                'active' => true
            ],
            'customer_company_id' => [
                'title' => trans('Medad::attributes.branch.customer_company'),
                'class' => 'col-md-2',
                'type' => 'select2',
                'options' => Medad::getCompanies(CompanyTypeConstants::CUSTOMER),
                'active' => true
            ],
            'supplier_company_id' => [
                'title' => trans('Medad::attributes.branch.supplier_company'),
                'class' => 'col-md-2',
                'type' => 'select2',
                'options' => Medad::getCompanies(CompanyTypeConstants::SUPPLIER),
                'active' => true
            ],
            'quotation_id' => [
                'title' => trans('Medad::attributes.purchase_order.quotation'),
                'class' => 'col-md-2',
                'type' => 'select2-ajax',
                'model' => Quotation::class,
                'columns' => ['code'],
                'attributes' => [
                    'data' => [
                        'scopes' => json_encode([CompanyListingScope::class])
                    ],
                ],
                'active' => true
            ],
            'without_invoices' => [
                'title' => trans('Medad::attributes.without_invoices'),
                'type' => 'boolean',
                'active' => true,
                'builder' => PurchaseOrdersWithoutInvoicesScope::class,
            ],
            'project_id' => [
                'title' => 'project',
                'type' => 'number',
                'active' => false,
            ],
        ];
    }
}

Spamworldpro Mini