Files
freeu-project/app/Imports/CleanAndGreenAssetImport.php
Ritikesh yadav c661166e1d first commit
2024-03-28 14:52:40 +05:30

82 lines
2.9 KiB
PHP

<?php
namespace App\Imports;
use Illuminate\Support\Collection;
use Maatwebsite\Excel\Concerns\ToCollection;
use App\Models\Product;
use App\Models\CleanAndGreenAsset;
use App\Models\Table;
use Maatwebsite\Excel\Concerns\WithHeadingRow;
use Illuminate\Support\Str;
use Illuminate\Support\Facades\Validator;
class CleanAndGreenAssetImport implements ToCollection, WithHeadingRow
{
/**
* @param Collection $collection
*/
protected $category_id;
public function __construct($category_id)
{
$this->category_id= $category_id;
}
public function rules(): array
{
// return null;
return [
// '*.project_name' => 'required|unique:clean_and_green_assets,project_name'
// '*.property_name' => 'required|unique:fractional_real_estates,property_name'
// '*.min_investment' => 'required',
// '*.return_rate' => 'required',
];
}
public function customValidationMessages(Collection $rows)
{
$messages = [];
foreach ($rows as $key => $val) {
$messages[''.$key.'.project_name.required'] = 'Project Name should not be empty at row ' . $key+1;
$messages[''.$key.'.project_name.unique'] = 'Project Name is not unique at row ' . $key+1;
}
return $messages;
// return [
// '*.property_name.required' => 'Property name must not be empty!'
// // '*.min_investment.required' => 'Minimun Investment must not be empty!',
// // '*.return_rate.required' => 'Return Rate must not be empty!'
// ];
}
public function collection(Collection $rows)
{
Validator::make($rows->toArray(), $this->rules(), $this->customValidationMessages($rows))->validate();
foreach ($rows as $row) {
$product = Product::create([
'tables_id' => Table::CleanAndGreenAssetsTable,
'categories_id' => $this->category_id,
'total_views' => 0,
'status' => 0,
'created_by' => auth()->user()->id
]);
CleanAndGreenAsset::create([
'products_id' => $product->id,
'slug' => Str::slug($row['project_name']),
'project_name' => $row['project_name'],
'focus_area' => $row['focus_area'],
'asset_value' => $row['asset_value'],
'asset_life' => $row['asset_life'],
'entry_load' => $row['entry_load'],
'lockin_period' => $row['lockin_period'],
'minimum_investment' => $row['minimum_investment'],
'maximum_investment' => $row['maximum_investment'],
'expected_returns_irr' => $row['expected_returns_irr'],
'payouts' => $row['payouts'],
'minimum_investment_in_int' => $row['minimum_investment_in_int'],
]);
}
}
}