sarga/packages/Webkul/Admin/src/Http/Controllers/ExportController.php

80 lines
2.0 KiB
PHP
Raw Normal View History

2018-12-04 04:23:52 +00:00
<?php
namespace Webkul\Admin\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Webkul\Admin\Http\Controllers\Controller;
use Webkul\Admin\Exports\DataGridExport;
use Excel;
/**
* Export controlller
*
* @author Rahul Shukla <rahulshukla.symfony517@webkul.com>
* @copyright 2018 Webkul Software Pvt Ltd (http://www.webkul.com)
*/
class ExportController extends Controller
{
protected $exportableGrids = [
2019-03-12 06:49:28 +00:00
'OrderDataGrid', 'OrderInvoicesDataGrid', 'OrderShipmentsDataGrid', 'CustomerDataGrid', 'TaxRateDataGrid'
];
2018-12-04 04:23:52 +00:00
/**
* Create a new controller instance.
*
*/
public function __construct()
{
$this->middleware('admin');
}
/**
* function for export datagrid
*
* @return \Illuminate\Http\Response
*/
public function export()
{
$criteria = request()->all();
2019-03-12 06:43:48 +00:00
$format = $criteria['format'];
$gridName = explode('\\', $criteria['gridName']);
$path = '\Webkul\Admin\DataGrids'.'\\'.last($gridName);
2019-03-12 06:43:48 +00:00
$proceed = false;
foreach($this->exportableGrids as $exportableGrid) {
if(last($gridName) == $exportableGrid) {
$proceed = true;
}
}
2019-04-01 15:09:15 +00:00
if(! $proceed) {
return redirect()->back();
}
$gridInstance = new $path;
2019-04-01 15:09:15 +00:00
$records = $gridInstance->export();
2019-04-01 15:09:15 +00:00
if (count($records) == 0) {
session()->flash('warning', trans('admin::app.export.no-records'));
2019-01-16 11:13:36 +00:00
2019-04-01 15:09:15 +00:00
return redirect()->back();
}
2019-01-16 11:13:36 +00:00
2019-04-01 15:09:15 +00:00
if ($format == 'csv') {
return Excel::download(new DataGridExport($records), last($gridName).'.csv');
} else {
if ($format == 'xls') {
2019-03-12 06:43:48 +00:00
return Excel::download(new DataGridExport($records), last($gridName).'.xlsx');
} else {
session()->flash('warning', trans('admin::app.export.illegal-format'));
2018-12-04 04:23:52 +00:00
2019-03-12 06:43:48 +00:00
return redirect()->back();
}
}
2018-12-04 04:23:52 +00:00
2019-04-01 15:09:15 +00:00
2018-12-04 04:23:52 +00:00
}
}