Dashboard sipadu mbip
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

MappedReader.php 1.3KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. <?php
  2. namespace Maatwebsite\Excel;
  3. use Illuminate\Support\Collection;
  4. use Maatwebsite\Excel\Concerns\ToArray;
  5. use Maatwebsite\Excel\Concerns\ToCollection;
  6. use Maatwebsite\Excel\Concerns\ToModel;
  7. use Maatwebsite\Excel\Concerns\WithCalculatedFormulas;
  8. use Maatwebsite\Excel\Concerns\WithMappedCells;
  9. use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
  10. class MappedReader
  11. {
  12. /**
  13. * @param WithMappedCells $import
  14. * @param Worksheet $worksheet
  15. *
  16. * @throws \PhpOffice\PhpSpreadsheet\Exception
  17. */
  18. public function map(WithMappedCells $import, Worksheet $worksheet)
  19. {
  20. $mapped = [];
  21. foreach ($import->mapping() as $name => $coordinate) {
  22. $cell = Cell::make($worksheet, $coordinate);
  23. $mapped[$name] = $cell->getValue(
  24. null,
  25. $import instanceof WithCalculatedFormulas
  26. );
  27. }
  28. if ($import instanceof ToModel) {
  29. $model = $import->model($mapped);
  30. if ($model) {
  31. $model->saveOrFail();
  32. }
  33. }
  34. if ($import instanceof ToCollection) {
  35. $import->collection(new Collection($mapped));
  36. }
  37. if ($import instanceof ToArray) {
  38. $import->array($mapped);
  39. }
  40. }
  41. }