90 lines
3.2 KiB
PHP
90 lines
3.2 KiB
PHP
<?php
|
|
|
|
namespace App\Imports;
|
|
|
|
use Illuminate\Support\Collection;
|
|
use Maatwebsite\Excel\Concerns\ToCollection;
|
|
use App\Models\Product;
|
|
use App\Models\HighYieldFinance;
|
|
use App\Models\Table;
|
|
use Maatwebsite\Excel\Concerns\WithHeadingRow;
|
|
use Illuminate\Support\Str;
|
|
use Illuminate\Support\Facades\Validator;
|
|
|
|
class HighYieldFinanceImport 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 [
|
|
// '*.security_name' => 'required|unique:high_yield_finances,security_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.'.security_name.required'] = 'Security Name should not be empty at row ' . $key+1;
|
|
$messages[''.$key.'.security_name.unique'] = 'Security 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::HighYieldFinanceTable,
|
|
'categories_id' => $this->category_id,
|
|
'total_views' => 0,
|
|
'status' => 0,
|
|
'created_by' => auth()->user()->id
|
|
]);
|
|
|
|
|
|
HighYieldFinance::create([
|
|
'products_id' => $product->id,
|
|
'slug' => Str::slug($row['security_name']),
|
|
'security_name' => $row['security_name'],
|
|
'security_type' => $row['security_type'],
|
|
'isin' => $row['isin'],
|
|
'issuer_company' => $row['issuer_company'],
|
|
'issue_size' => $row['issue_size'],
|
|
'issue_type' => $row['issue_type'],
|
|
'listing_details' => $row['listing_details'],
|
|
'rating_category' => $row['rating_category'],
|
|
'minimum_investment' => $row['minimum_investment'],
|
|
'coupon_rate' => $row['coupon_rate'],
|
|
'yield_to_maturity' => $row['yield_to_maturity'],
|
|
'interest_payment_frequency' => $row['interest_payment_frequency'],
|
|
'allotment_date' => $row['allotment_date'],
|
|
'maturity_date' => $row['maturity_date'],
|
|
'minimum_investment_in_int' => $row['minimum_investment_in_int'],
|
|
]);
|
|
}
|
|
}
|
|
}
|