|
|
@@ -0,0 +1,97 @@
|
|
|
+<?php
|
|
|
+// +----------------------------------------------------------------------
|
|
|
+// | likeshop100%开源免费商用商城系统
|
|
|
+// +----------------------------------------------------------------------
|
|
|
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
|
|
|
+// | 开源版本可自由商用,可去除界面版权logo
|
|
|
+// | 商业版本务必购买商业授权,以免引起法律纠纷
|
|
|
+// | 禁止对系统程序代码以任何目的,任何形式的再发布
|
|
|
+// | gitee下载:https://gitee.com/likeshop_gitee
|
|
|
+// | github下载:https://github.com/likeshop-github
|
|
|
+// | 访问官网:https://www.likeshop.cn
|
|
|
+// | 访问社区:https://home.likeshop.cn
|
|
|
+// | 访问手册:http://doc.likeshop.cn
|
|
|
+// | 微信公众号:likeshop技术社区
|
|
|
+// | likeshop团队 版权所有 拥有最终解释权
|
|
|
+// +----------------------------------------------------------------------
|
|
|
+// | author: likeshopTeam
|
|
|
+// +----------------------------------------------------------------------
|
|
|
+
|
|
|
+namespace app\adminapi\validate\goods;
|
|
|
+
|
|
|
+class GoodsSpecPriceImport extends \think\Validate
|
|
|
+{
|
|
|
+ protected $rule = [
|
|
|
+ 'lists' => ['require', 'checkLists'],
|
|
|
+ ];
|
|
|
+
|
|
|
+ protected $message = [
|
|
|
+ 'lists.require' => '上传文件不能为空',
|
|
|
+ ];
|
|
|
+
|
|
|
+ function checkLists($lists, $rule, $data)
|
|
|
+ {
|
|
|
+ $nums = count($lists) - 1;
|
|
|
+ if ($nums < 1) {
|
|
|
+ return '导入的文件商品规格价格信息为空';
|
|
|
+ }
|
|
|
+
|
|
|
+ if ($nums > 2000) {
|
|
|
+ return '单次最多导入2000条商品规格价格信息';
|
|
|
+ }
|
|
|
+
|
|
|
+ foreach ($lists as $key => $info) {
|
|
|
+ // 跳过表头
|
|
|
+ if ($key == 1) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+
|
|
|
+ // 检查必填字段:商品ID(A列)和规格ID(D列)
|
|
|
+ if (empty(trim($info['A'])) || empty(trim($info['D']))) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行存在未填写的商品ID或规格ID';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 验证商品ID是否为数字
|
|
|
+ if (!is_numeric(trim($info['A']))) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行商品ID必须为数字';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 验证规格ID是否为数字
|
|
|
+ if (!is_numeric(trim($info['D']))) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行规格ID必须为数字';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 验证销售价格(F列)
|
|
|
+ if (!empty(trim($info['F'])) && !is_numeric(trim($info['F']))) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行销售价格必须为数字';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 验证划线价格(G列)
|
|
|
+ if (!empty(trim($info['G'])) && !is_numeric(trim($info['G']))) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行划线价格必须为数字';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 验证成本价格(H列)
|
|
|
+ if (!empty(trim($info['H'])) && !is_numeric(trim($info['H']))) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行成本价格必须为数字';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 验证库存数量(I列)
|
|
|
+ if (!empty(trim($info['I'])) && (!is_numeric(trim($info['I'])) || trim($info['I']) < 0)) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行库存数量必须为非负整数';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 验证重量(J列)
|
|
|
+ if (!empty(trim($info['J'])) && (!is_numeric(trim($info['J'])) || trim($info['J']) < 0)) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行重量必须为非负数';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 验证体积(K列)
|
|
|
+ if (!empty(trim($info['K'])) && (!is_numeric(trim($info['K'])) || trim($info['K']) < 0)) {
|
|
|
+ return '商品规格价格信息:第' . ($key) . '行体积必须为非负数';
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+}
|