123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- <?php
- namespace app\admin\model\unishop;
- use addons\unishop\model\Product;
- use think\Db;
- use think\Exception;
- use think\Model;
- use traits\model\SoftDelete;
- class FlashSale extends Model
- {
- use SoftDelete;
- //数据库
- protected $connection = 'database';
- // 表名
- protected $name = 'unishop_flash_sale';
- // 自动写入时间戳字段
- protected $autoWriteTimestamp = 'int';
- // 定义时间戳字段名
- protected $createTime = 'createtime';
- protected $updateTime = 'updatetime';
- protected $deleteTime = 'deletetime';
- // 追加属性
- protected $append = [
- 'status_text',
- 'starttime_text',
- 'endtime_text',
- 'current_state'
- ];
- // 已归档
- const STATUS_YES = 1; // 是
- const STATUS_NO = 0; // 否
- // 已上架
- const SWITCH_YES = 1; // 是
- const SWITCH_NO = 0; // 否
- /**
- * 获取当前状态
- */
- public function getCurrentStateAttr($value, $data)
- {
- $time = time();
- switch (true) {
- case $data['starttime'] > $time:
- $result = __('Not started');
- break;
- case $data['starttime'] <= $time && $time < $data['endtime']:
- $result = __('On going');
- break;
- case $time >= $data['endtime']:
- $result = __('Has ended');
- break;
- default:
- $result = __('Nothing');
- }
- return $result;
- }
- public function getStatusList()
- {
- return ['0' => __('Status 0'), '1' => __('Status 1')];
- }
- public function getStatusTextAttr($value, $data)
- {
- $value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
- $list = $this->getStatusList();
- return isset($list[$value]) ? $list[$value] : '';
- }
- public function getStarttimeTextAttr($value, $data)
- {
- $value = $value ? $value : (isset($data['starttime']) ? $data['starttime'] : '');
- return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
- }
- public function getEndtimeTextAttr($value, $data)
- {
- $value = $value ? $value : (isset($data['endtime']) ? $data['endtime'] : '');
- return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
- }
- protected function setStarttimeAttr($value)
- {
- return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
- }
- protected function setEndtimeAttr($value)
- {
- return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
- }
- /**
- * 关联产品
- * @return \think\model\relation\HasMany
- */
- public function product()
- {
- return $this->hasMany('flashProduct', 'flash_id', 'id');
- }
- /**
- * 判断能不能修改
- * 已归档、已开始、上架状态的秒杀不能够修改。
- */
- public function checkItCanEdit()
- {
- if ($this['switch'] == self::SWITCH_YES || $this['status'] == self::STATUS_YES || $this['starttime'] < time()) {
- throw new Exception('已归档、已开始、上架状态的秒杀信息不能够修改。');
- }
- return true;
- }
- /**
- * 归档减库存
- */
- public function activityFiled($params, $specNumber)
- {
- $productExtend = new \addons\unishop\extend\Product;
- $key = 0;
- $prefix = \think\Config::get('database.prefix');
- foreach ($specNumber as $spec => $number) {
- $result = 0;
- if (is_numeric($spec) && $params[$key]['use_spec'] == Product::SPEC_OFF) {
- $result = Db::execute("UPDATE fa_unishop_product SET stock = stock-{$number}, real_sales = real_sales+{$number} WHERE id = {$params[$key]['id']}");
- } else if ($params[$key]['use_spec'] == Product::SPEC_ON) {
- $info = $productExtend->getBaseData($params[$key], $spec);
- // mysql<5.7.13时用
- //if (mysql < 5.7.13) {
- $spec = str_replace(',', '","', $spec);
- $search = '"stock":"' . $info['stock'] . '","value":["' . $spec . '"]';
- $stock = $info['stock'] - $number;
- $replace = '"stock":\"' . $stock . '\","value":["' . $spec . '"]';
- $sql = 'UPDATE ' . $prefix . "unishop_product SET stock = stock-{$number}, real_sales = real_sales+{$number}, `specTableList` = REPLACE(specTableList,'$search','$replace') WHERE id = {$params[$key]['id']}";
- $result = Db::execute($sql);
- //}
- //下面语句直接操作JSON
- //if (mysql >= 5.7.13) {
- //$info['stock'] -= $number;
- //$result = Db::execute("UPDATE fa_unishop_product SET stock = stock-{$number}, real_sales = real_sales+{$number}, specTableList = JSON_REPLACE(specTableList, '$[{$info['key']}].stock', {$info['stock']}) WHERE id = {$params[$key]['id']}");
- //}
- }
- if ($result == 0) { // 锁生效
- throw new Exception('失败');
- }
- $key++;
- }
- }
- }
|