-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathExcelFileHelper.php
More file actions
55 lines (46 loc) · 1.77 KB
/
ExcelFileHelper.php
File metadata and controls
55 lines (46 loc) · 1.77 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<?php
require 'vendor/autoload.php';
require 'DownloadableFile.php';
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use PhpOffice\PhpSpreadsheet\Writer\Pdf\Mpdf;
class ExcelFileHelper extends DownloadableFile {
private $spreadsheet;
public function __construct(){
parent::__construct("", "xlsx");
}
public function createSpreadsheet($data){
$spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet();
$keys = array_keys($data[0]);
foreach($keys as $key=>$val){
$col = chr(ord('A') + $key);
$cell = $col . '1';
$sheet->getColumnDimension($col)->setAutoSize(true);
$sheet->setCellValue($cell, $val);
}
foreach($data as $key => $val){
print_r($key);
$col_n=0;
foreach($val as $key2 => $val2){
$cell = chr(ord('A') + $col_n) . ($key + 2);
$sheet->setCellValue($cell, ucfirst($val2));
$col_n++;
}
}
$this->spreadsheet = $spreadsheet;
return $spreadsheet;
}
public function exportToPdf($data){
$spreadsheet = $this->createSpreadsheet($data);
$writer = new Mpdf($spreadsheet);
$writer->save($this->getDirFile("pdf"));
return $this->getDirFile("pdf");
}
public function create($data){
$spreadsheet = $this->createSpreadsheet($data);
$writer = new Xlsx($spreadsheet);
$writer->save($this->getDirFile());
return $this->getDirFile();
}
}