vd/app/Domains/Stats/Exports/AbstractExport.php
2018-12-29 17:36:56 +08:00

150 lines
3.5 KiB
PHP

<?php
namespace App\Domains\Stats\Exports;
use App\Models\Stats\Export;
use Illuminate\Support\Carbon;
use Dipper\Excel\Events\AfterStore;
use Dipper\Excel\Concerns\WithTitle;
use Dipper\Excel\Events\AfterExport;
use Dipper\Excel\Concerns\WithEvents;
use Dipper\Excel\Events\BeforeExport;
use Illuminate\Filesystem\Filesystem;
use Dipper\Excel\Events\BeforeWriting;
use Illuminate\Support\Facades\Request;
use Illuminate\Support\Facades\Storage;
abstract class AbstractExport implements WithEvents, WithTitle
{
public static $classes = [
\App\Domains\Stats\Exports\CompanyCountExport::class => '企业统计',
];
public $sn;
public $filename;
public function __construct()
{
$this->sn = $this->sn();
$this->filename = $this->filename();
}
/**
* @return array
*/
public function registerEvents(): array
{
return [
BeforeExport::class => [self::class, 'beforeExport'],
BeforeWriting::class => [self::class, 'beforeWriting'],
AfterExport::class => [self::class, 'afterExport'],
AfterStore::class => [self::class, 'afterStore'],
];
}
/**
* 开始导出
*
* @param BeforeExport $event
* @return void
*/
public static function beforeExport(BeforeExport $event)
{
$data = [
'sn' => $event->getConcernable()->sn,
'filename' => $event->getConcernable()->filename,
'filesize' => 0,
'conditions' => $event->getConcernable()->conditions ?: null,
'status' => 0,
'progress' => 0,
];
Export::create($data);
}
/**
* 写入数据
*
* @param BeforeWriting $event
* @return void
*/
public static function beforeWriting(BeforeWriting $event)
{
Export::where(['sn' => $event->getConcernable()->sn])->update([
'status' => 1,
'progress' => 50,
]);
}
/**
* 写入结束
*
* @param AfterExport $event
* @return void
*/
public static function afterExport(AfterExport $event)
{
Export::where(['sn' => $event->getConcernable()->sn])->update([
'status' => 2,
'progress' => 90,
]);
}
/**
* 保持结束
*
* @param AfterStore $event
* @return void
*/
public static function afterStore(AfterStore $event)
{
$disk = Storage::disk($event->getDisk());
if ($disk->exists($event->getFilePath())) {
Export::where(['sn' => $event->getConcernable()->sn])->update([
'filesize' => $disk->size($event->getFilePath()),
'status' => 3,
'progress' => 100,
]);
} else {
Export::where(['sn' => $event->getConcernable()->sn])->update([
'status' => 4,
'progress' => 100,
]);
}
}
/**
* 表格标题
*
* @return string
*/
public function title(): string
{
return self::$classes[get_class($this)] ?? '列表';
}
/**
* 序列号
*
* @return string
*/
private function sn(): string
{
return date('YmdHis') .sprintf('%04d', explode('.', microtime(true))[1]) . sprintf('%02d', rand(0, 99));
}
/**
* 文件名称
*
* @return string
*/
private function filename(): string
{
$filename = $this->title() . date('YmdHis');
return "export/{$filename}.xlsx";
}
}