improved error handler of import/export

This commit is contained in:
Denis Duliçi
2021-01-31 23:47:36 +03:00
parent c08106418c
commit 0320df1c9b
11 changed files with 95 additions and 46 deletions

View File

@ -84,6 +84,6 @@ class Transactions extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.transactions', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.transactions', 2));
}
}

View File

@ -139,6 +139,26 @@ class Transfers extends Controller
return response()->json($response);
}
/**
* Import the specified resource.
*
* @param ImportRequest $request
*
* @return Response
*/
public function import(ImportRequest $request)
{
if (true !== $result = $this->importExcel(new Import, $request, 'banking/transfers')) {
return $result;
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.transfers', 2)]);
flash($message)->success();
return redirect()->route('transfers.index');
}
/**
* Show the form for editing the specified resource.
*
@ -222,24 +242,6 @@ class Transfers extends Controller
return response()->json($response);
}
/**
* Import the specified resource.
*
* @param ImportRequest $request
*
* @return Response
*/
public function import(ImportRequest $request)
{
\Excel::import(new Import(), $request->file('import'));
$message = trans('messages.success.imported', ['type' => trans_choice('general.transfers', 2)]);
flash($message)->success();
return redirect()->route('transfers.index');
}
/**
* Export the specified resource.
*
@ -247,6 +249,6 @@ class Transfers extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.transfers', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.transfers', 2));
}
}

View File

@ -111,7 +111,9 @@ class Items extends Controller
*/
public function import(ImportRequest $request)
{
\Excel::import(new Import(), $request->file('import'));
if (true !== $result = $this->importExcel(new Import, $request, 'common/items')) {
return $result;
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.items', 2)]);
@ -237,7 +239,7 @@ class Items extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.items', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.items', 2));
}
public function autocomplete()

View File

@ -128,12 +128,8 @@ class Bills extends Controller
*/
public function import(ImportRequest $request)
{
try {
\Excel::import(new Import(), $request->file('import'));
} catch (\Maatwebsite\Excel\Exceptions\SheetNotFoundException $e) {
flash($e->getMessage())->error()->important();
return redirect()->route('import.create', ['purchases', 'bills']);
if (true !== $result = $this->importExcel(new Import, $request, 'purchases/bills')) {
return $result;
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.bills', 2)]);
@ -217,7 +213,7 @@ class Bills extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.bills', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.bills', 2));
}
/**

View File

@ -124,7 +124,9 @@ class Payments extends Controller
*/
public function import(ImportRequest $request)
{
\Excel::import(new Import(), $request->file('import'));
if (true !== $result = $this->importExcel(new Import, $request, 'purchases/payments')) {
return $result;
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.payments', 2)]);
@ -229,6 +231,6 @@ class Payments extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.payments', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.payments', 2));
}
}

View File

@ -161,7 +161,9 @@ class Vendors extends Controller
*/
public function import(ImportRequest $request)
{
\Excel::import(new Import(), $request->file('import'));
if (true !== $result = $this->importExcel(new Import, $request, 'purchases/vendors')) {
return $result;
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.vendors', 2)]);
@ -282,7 +284,7 @@ class Vendors extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.vendors', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.vendors', 2));
}
public function currency(Contact $vendor)

View File

@ -159,7 +159,9 @@ class Customers extends Controller
*/
public function import(ImportRequest $request)
{
\Excel::import(new Import(), $request->file('import'));
if (true !== $result = $this->importExcel(new Import, $request, 'sales/customers')) {
return $result;
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.customers', 2)]);
@ -280,7 +282,7 @@ class Customers extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.customers', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.customers', 2));
}
public function currency(Contact $customer)

View File

@ -13,7 +13,6 @@ use App\Jobs\Document\DuplicateDocument;
use App\Jobs\Document\UpdateDocument;
use App\Models\Document\Document;
use App\Notifications\Sale\Invoice as Notification;
use App\Models\Setting\Currency;
use App\Traits\Documents;
use File;
@ -128,12 +127,8 @@ class Invoices extends Controller
*/
public function import(ImportRequest $request)
{
try {
\Excel::import(new Import(), $request->file('import'));
} catch (\Maatwebsite\Excel\Exceptions\SheetNotFoundException $e) {
flash($e->getMessage())->error()->important();
return redirect()->route('import.create', ['sales', 'invoices']);
if (true !== $result = $this->importExcel(new Import, $request, 'sales/invoices')) {
return $result;
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.invoices', 2)]);
@ -217,7 +212,7 @@ class Invoices extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.invoices', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.invoices', 2));
}
/**

View File

@ -124,7 +124,9 @@ class Revenues extends Controller
*/
public function import(ImportRequest $request)
{
\Excel::import(new Import(), $request->file('import'));
if (true !== $result = $this->importExcel(new Import, $request, 'sales/revenues')) {
return $result;
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.revenues', 2)]);
@ -229,6 +231,6 @@ class Revenues extends Controller
*/
public function export()
{
return \Excel::download(new Export(), \Str::filename(trans_choice('general.revenues', 2)) . '.xlsx');
return $this->exportExcel(new Export, trans_choice('general.revenues', 2));
}
}