mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-10 21:22:58 +01:00
66 lines
1.9 KiB
PHP
66 lines
1.9 KiB
PHP
<?php namespace app\Http\Controllers;
|
|
|
|
use Utils;
|
|
use View;
|
|
use Exception;
|
|
use Input;
|
|
use Session;
|
|
use Redirect;
|
|
use App\Services\ImportService;
|
|
use App\Http\Controllers\BaseController;
|
|
|
|
class ImportController extends BaseController
|
|
{
|
|
public function __construct(ImportService $importService)
|
|
{
|
|
parent::__construct();
|
|
|
|
$this->importService = $importService;
|
|
}
|
|
|
|
public function doImport()
|
|
{
|
|
$source = Input::get('source');
|
|
|
|
if ($source === IMPORT_CSV) {
|
|
$filename = Input::file('client_file')->getRealPath();
|
|
$data = $this->importService->mapFile($filename);
|
|
|
|
return View::make('accounts.import_map', $data);
|
|
} else {
|
|
$files = [];
|
|
foreach (ImportService::$entityTypes as $entityType) {
|
|
if (Input::file("{$entityType}_file")) {
|
|
$files[$entityType] = Input::file("{$entityType}_file")->getRealPath();
|
|
}
|
|
}
|
|
|
|
try {
|
|
$result = $this->importService->import($source, $files);
|
|
Session::flash('message', trans('texts.imported_file') . ' - ' . $result);
|
|
} catch (Exception $exception) {
|
|
Session::flash('error', $exception->getMessage());
|
|
}
|
|
|
|
return Redirect::to('/settings/' . ACCOUNT_IMPORT_EXPORT);
|
|
}
|
|
}
|
|
|
|
public function doImportCSV()
|
|
{
|
|
$map = Input::get('map');
|
|
$hasHeaders = Input::get('header_checkbox');
|
|
|
|
try {
|
|
$count = $this->importService->importCSV($map, $hasHeaders);
|
|
$message = Utils::pluralize('created_client', $count);
|
|
|
|
Session::flash('message', $message);
|
|
} catch (Exception $exception) {
|
|
Session::flash('error', $exception->getMessage());
|
|
}
|
|
|
|
return Redirect::to('/settings/' . ACCOUNT_IMPORT_EXPORT);
|
|
}
|
|
}
|