| 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;    }}
 |