1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-09-20 08:21:34 +02:00
invoiceninja/app/Services/VendorService.php

116 lines
3.3 KiB
PHP
Raw Normal View History

2016-01-06 15:23:58 +01:00
<?php namespace App\Services;
use Utils;
use URL;
use Auth;
2016-03-16 00:08:00 +01:00
use App\Models\Vendor;
use App\Models\Expense;
2016-01-06 15:23:58 +01:00
use App\Services\BaseService;
use App\Ninja\Repositories\VendorRepository;
use App\Ninja\Repositories\NinjaRepository;
2016-01-19 14:01:19 +01:00
2016-01-06 15:23:58 +01:00
class VendorService extends BaseService
{
protected $vendorRepo;
protected $datatableService;
public function __construct(VendorRepository $vendorRepo, DatatableService $datatableService, NinjaRepository $ninjaRepo)
{
2016-01-19 14:01:19 +01:00
$this->vendorRepo = $vendorRepo;
$this->ninjaRepo = $ninjaRepo;
2016-01-06 15:23:58 +01:00
$this->datatableService = $datatableService;
}
protected function getRepo()
{
return $this->vendorRepo;
}
public function save($data)
{
if (Auth::user()->account->isNinjaAccount() && isset($data['plan'])) {
$this->ninjaRepo->updatePlanDetails($data['public_id'], $data);
2016-01-06 15:23:58 +01:00
}
return $this->vendorRepo->save($data);
}
public function getDatatable($search)
{
$query = $this->vendorRepo->find($search);
if(!Utils::hasPermission('view_all')){
$query->where('vendors.user_id', '=', Auth::user()->id);
}
2016-01-06 15:23:58 +01:00
return $this->createDatatable(ENTITY_VENDOR, $query);
}
protected function getDatatableColumns($entityType, $hideVendor)
{
return [
[
'name',
function ($model) {
2016-03-02 14:36:42 +01:00
return link_to("vendors/{$model->public_id}", $model->name ?: '')->toHtml();
2016-01-06 15:23:58 +01:00
}
],
[
2016-01-26 21:22:33 +01:00
'city',
2016-01-06 15:23:58 +01:00
function ($model) {
2016-01-26 21:22:33 +01:00
return $model->city;
}
],
[
'work_phone',
function ($model) {
return $model->work_phone;
2016-01-06 15:23:58 +01:00
}
],
[
'email',
function ($model) {
2016-03-02 14:36:42 +01:00
return link_to("vendors/{$model->public_id}", $model->email ?: '')->toHtml();
2016-01-06 15:23:58 +01:00
}
],
[
'vendors.created_at',
function ($model) {
return Utils::timestampToDateString(strtotime($model->created_at));
}
],
];
}
protected function getDatatableActions($entityType)
{
return [
[
trans('texts.edit_vendor'),
function ($model) {
return URL::to("vendors/{$model->public_id}/edit");
2016-03-16 00:08:00 +01:00
},
function ($model) {
2016-04-26 03:53:39 +02:00
return Auth::user()->can('editByOwner', [ENTITY_VENDOR, $model->user_id]);
2016-03-16 00:08:00 +01:00
}
],
[
'--divider--', function(){return false;},
function ($model) {
2016-04-26 03:53:39 +02:00
return Auth::user()->can('editByOwner', [ENTITY_VENDOR, $model->user_id]) && Auth::user()->can('create', ENTITY_EXPENSE);
2016-01-06 15:23:58 +01:00
}
2016-03-16 00:08:00 +01:00
2016-01-06 15:23:58 +01:00
],
[
trans('texts.enter_expense'),
function ($model) {
return URL::to("expenses/create/{$model->public_id}");
2016-03-16 00:08:00 +01:00
},
function ($model) {
2016-04-26 03:53:39 +02:00
return Auth::user()->can('create', ENTITY_EXPENSE);
2016-01-06 15:23:58 +01:00
}
]
];
}
}