v2 first commit

This commit is contained in:
denisdulici
2019-11-16 10:21:14 +03:00
parent 5b23e9c2c4
commit 6d50fa8442
3075 changed files with 3451681 additions and 65594 deletions

View File

@ -0,0 +1,117 @@
<?php
namespace App\BulkActions\Common;
use App\Abstracts\BulkAction;
use App\Models\Common\Company;
class Companies extends BulkAction
{
public $model = Company::class;
public $actions = [
'enable' => [
'name' => 'general.enable',
'message' => 'bulk_actions.message.enable',
'permission' => 'update-common-companies'
],
'disable' => [
'name' => 'general.disable',
'message' => 'bulk_actions.message.disable',
'permission' => 'update-common-companies'
],
'delete' => [
'name' => 'general.delete',
'message' => 'bulk_actions.message.deletes',
'permission' => 'delete-common-companies'
]
];
public function enable($request)
{
try {
$selected = $request->get('selected', []);
$companies = $this->model::find($selected);
foreach ($companies as $company) {
// Check if user can access company
$this->owner($company);
$company->enabled = 1;
$company->save();
}
$message = trans('messages.success.enabled', ['type' => $company->name]);
return $this->itemResponse($company->fresh(), new Transformer(), $message);
} catch (\HttpException $e) {
$this->response->errorUnauthorized(trans('companies.error.not_user_company'));
}
}
public function disable($request)
{
try {
$selected = $request->get('selected', []);
$companies = $this->model::find($selected);
foreach ($companies as $company) {
// Check if user can access company
$this->owner($company);
$company->enabled = 0;
$company->save();
}
} catch (\HttpException $e) {
$this->response->errorUnauthorized(trans('companies.error.not_user_company'));
}
}
public function delete($request)
{
$this->destroy($request);
}
public function destroy($request)
{
$selected = $request->get('selected', []);
$companies = $this->model::find($selected);
foreach ($companies as $company) {
// Can't delete active company
if ($company->id == session('company_id')) {
$content = trans('companies.error.delete_active');
return new Response($content, 422);
}
try {
// Check if user can access company
$this->owner($company);
$company->delete();
$message = trans('messages.success.deleted', ['type' => $company->name]);
return new Response($message);
} catch (\HttpException $e) {
$this->response->errorUnauthorized(trans('companies.error.not_user_company'));
}
}
}
public function owner(Company $company)
{
$companies = user()->companies()->pluck('id')->toArray();
if (in_array($company->id, $companies)) {
return new Response('');
}
$this->response->errorUnauthorized(trans('companies.error.not_user_company'));
}
}

View File

@ -0,0 +1,91 @@
<?php
namespace App\BulkActions\Common;
use App\Abstracts\BulkAction;
use App\Exports\Common\Items as Export;
use App\Models\Common\Item;
class Items extends BulkAction
{
public $model = Item::class;
public $actions = [
'enable' => [
'name' => 'general.enable',
'message' => 'bulk_actions.message.enable',
'permission' => 'update-common-items'
],
'disable' => [
'name' => 'general.disable',
'message' => 'bulk_actions.message.disable',
'permission' => 'update-common-items'
],
'duplicate' => [
'name' => 'general.duplicate',
'message' => 'bulk_actions.message.duplicate',
'permission' => 'create-common-items',
'multiple' => true
],
'export' => [
'name' => 'general.export',
'message' => 'bulk_actions.message.exports',
],
'delete' => [
'name' => 'general.delete',
'message' => 'bulk_actions.message.deletes',
'permission' => 'delete-common-items'
]
];
/**
* Remove the specified resource from storage.
*
* @param $id
*
* @return Response
*/
public function delete($request)
{
$this->destroy($request);
}
public function destroy($request)
{
$selected = $request->get('selected', []);
$items = $this->model::find($selected);
foreach ($items as $item) {
$relationships = $this->countRelationships($item, [
'invoice_items' => 'invoices',
'bill_items' => 'bills',
]);
if (empty($relationships)) {
$item->delete();
$message = trans('messages.success.deleted', ['type' => $item->name]);
return new Response($message);
} else {
$message = trans('messages.warning.deleted', ['name' => $item->name, 'text' => implode(', ', $relationships)]);
$this->response->errorUnauthorized($message);
}
}
}
/**
* Export the specified resource.
*
* @return Response
*/
public function export($request)
{
$selected = $request->get('selected', []);
return \Excel::download(new Export($selected), trans_choice('general.items', 2) . '.xlsx');
}
}