| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 | <?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\Station as stationModel;use catcher\library\excel\ExcelContract;use PhpOffice\PhpSpreadsheet\Style\Alignment;class StationExport implements ExcelContract{    public $memory = '1024M';    protected $badgeModel;    public function __construct(stationModel $stationModel)    {        $this->stationModel = $stationModel;    }    /**     * 设置头部     *     * @time 2020年09月08日     * @return string[]     */    public function headers(): array    {        // TODO: Implement headers() method.        return [            '部门','名称','Mac','简码','基站状态','在线时间', '开局时间','入库时间','开局员工','安装地址','备注'        ];    }    /**     * 处理数据     *     * @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->stationModel->getStationExportList();        foreach ($list as &$val) {            $val->mac ="\t".$val->mac."\t";            $val->shortmac ="\t".$val->shortmac."\t";            if($val->open_status){                $val->use_state = '已开局';            }else{                $val->use_state = '未开局';            }        }        return $list;    }    public function keys(): array    {        // TODO: Implement keys() method.        return [            'depart_name','name','mac','shortcode','use_state','online_time','open_time','created_at','open_user_name','address','remark'        ];    }    /**     * 设置开始行     *     * @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,            'F' => 20,            'G' => 20,            'H' => 20,            'I' => 20,            'J' => 30,            'K' => 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;    }}
 |