123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- <?php
- // +----------------------------------------------------------------------
- // | CatchAdmin [Just Like ~ ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2017~2020 http://catchadmin.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed ( https://github.com/yanwenwu/catch-admin/blob/master/LICENSE.txt )
- // +----------------------------------------------------------------------
- // | Author: JaguarJack [ njphper@gmail.com ]
- // +----------------------------------------------------------------------
- namespace catchAdmin\device\excel;
- use catcher\base\CatchRequest as Request;
- use catchAdmin\device\model\Device as deviceModel;
- use catcher\library\excel\ExcelContract;
- use PhpOffice\PhpSpreadsheet\Style\Alignment;
- class CardsExport implements ExcelContract
- {
- public $memory = '1024M';
- protected $badgeModel;
- public function __construct(deviceModel $deviceModel)
- {
- $this->deviceModel = $deviceModel;
- }
- /**
- * 设置头部
- *
- * @time 2020年09月08日
- * @return string[]
- */
- public function headers(): array
- {
- // TODO: Implement headers() method.
- return [
- '部门','imei','设备RFID','设备类型','使用状态','在线时间', '录入时间'
- ];
- }
- /**
- * 处理数据
- *
- * @time 2020年09月08日
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\DbException
- * @throws \think\db\exception\ModelNotFoundException
- * @return \think\Collection
- */
- public function sheets()
- {
- $list = $this->deviceModel->getCardExportList();
- foreach ($list as &$val) {
- $val->user_no ="\t".$val->user_no."\t";
- $val->imei ="\t".$val->imei."\t";
- $val->rfid ="\t".$val->rfid."\t";
-
- }
- return $list;
- }
- public function keys(): array
- {
- // TODO: Implement keys() method.
- return [
- 'depart_name','imei','rfid','device_type_text','use_state','online_time','created_at'
- ];
- }
- /**
- * 设置开始行
- *
- * @time 2020年09月08日
- * @return int
- */
- public function setRow()
- {
- return 2;
- }
- /**
- * 设置标题
- *
- * @time 2020年09月08日
- * @return array
- */
- public function setTitle()
- {
- return [
- 'A1:I1', '导出徽章用户', Alignment::HORIZONTAL_CENTER
- ];
- }
- /**
- * 设置宽度
- *
- * @time 2020年09月08日
- * @return array
- */
- public function setWidth()
- {
- return [
- 'A' => 20,
- 'B' => 20,
- 'C' => 20,
- 'D' => 20,
- 'E' => 20
- ];
- }
- public function getWorksheet($sheet)
- {
- // $sheet->getStyle('B')->getNumberFormat()->setFormatCode(\PhpOffice\PhpSpreadsheet\Style\NumberFormat::FORMAT_TEXT);
- // $sheet->getColumnDimension('B')->setAutoSize(true);
- // $sheet->getColumnDimension('C')->setAutoSize(true);
- // $sheet->getColumnDimension('D')->setAutoSize(true);
- // $sheet->getActiveSheet()->getColumnDimension('C')->setAutoSize(true);
- // $sheet->getActiveSheet()->getColumnDimension('D')->setAutoSize(true);
- return $sheet;
- }
- }
|