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

@ -6,12 +6,18 @@ use App\Abstracts\Http\Response;
use App\Traits\Jobs;
use App\Traits\Permissions;
use App\Traits\Relationships;
use Exception;
use ErrorException;
use Illuminate\Database\Eloquent\Collection;
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
use Illuminate\Foundation\Validation\ValidatesRequests;
use Illuminate\Pagination\Paginator;
use Illuminate\Pagination\LengthAwarePaginator;
use Illuminate\Routing\Controller as BaseController;
use Illuminate\Support\Str;
use Maatwebsite\Excel\Exceptions\SheetNotFoundException;
use Maatwebsite\Excel\Facades\Excel;
use Throwable;
abstract class Controller extends BaseController
{
@ -66,4 +72,45 @@ abstract class Controller extends BaseController
return $response;
}
/**
* Import the excel file or catch errors
*
* @param $class
* @param $request
* @param $url
*
* @return mixed
*/
public function importExcel($class, $request, $url)
{
try {
Excel::import($class, $request->file('import'));
} catch (SheetNotFoundException | ErrorException | Exception | Throwable $e) {
flash($e->getMessage())->error()->important();
return redirect()->route('import.create', explode('/', $url));
}
return true;
}
/**
* Export the excel file or catch errors
*
* @param $class
* @param $file_name
*
* @return mixed
*/
public function exportExcel($class, $file_name, $extension = 'xlsx')
{
try {
return Excel::download($class, Str::filename($file_name) . '.' . $extension);
} catch (ErrorException | Exception | Throwable $e) {
flash($e->getMessage())->error()->important();
return back();
}
}
}