mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-04-06 03:58:04 +08:00
[更新]修改系统权限管理,支持驼峰命名控制器
This commit is contained in:
parent
ca69ea07f5
commit
7b6a7cdd54
534
admin_v3.sql
534
admin_v3.sql
@ -1,25 +1,135 @@
|
|||||||
/*
|
/*
|
||||||
Navicat MySQL Data Transfer
|
Navicat MySQL Data Transfer
|
||||||
|
|
||||||
Source Server : ctolog.com
|
Source Server : server.cuci.cc
|
||||||
Source Server Version : 50559
|
Source Server Version : 50558
|
||||||
Source Host : ctolog.com:3306
|
Source Host : server.cuci.cc:3306
|
||||||
Source Database : admin_v3
|
Source Database : admin_v3
|
||||||
|
|
||||||
Target Server Type : MYSQL
|
Target Server Type : MYSQL
|
||||||
Target Server Version : 50559
|
Target Server Version : 50558
|
||||||
File Encoding : 65001
|
File Encoding : 65001
|
||||||
|
|
||||||
Date: 2018-03-23 17:07:39
|
Date: 2018-05-04 11:40:19
|
||||||
*/
|
*/
|
||||||
|
|
||||||
SET FOREIGN_KEY_CHECKS=0;
|
SET FOREIGN_KEY_CHECKS=0;
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Table structure for goods
|
-- Table structure for store_express
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
DROP TABLE IF EXISTS `goods`;
|
DROP TABLE IF EXISTS `store_express`;
|
||||||
CREATE TABLE `goods` (
|
CREATE TABLE `store_express` (
|
||||||
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
|
`express_title` varchar(50) DEFAULT '' COMMENT '快递公司名称',
|
||||||
|
`express_code` varchar(50) DEFAULT '' COMMENT '快递公司代码',
|
||||||
|
`express_desc` text COMMENT '快递公司描述',
|
||||||
|
`status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0.无效,1.有效)',
|
||||||
|
`sort` bigint(20) unsigned DEFAULT '0' COMMENT '排序',
|
||||||
|
`is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)',
|
||||||
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB AUTO_INCREMENT=95 DEFAULT CHARSET=utf8 COMMENT='商城快递配置';
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Records of store_express
|
||||||
|
-- ----------------------------
|
||||||
|
INSERT INTO `store_express` VALUES ('5', 'AAE全球专递', 'aae', '顺丰快递公司', '0', '0', '0', '2017-09-12 11:53:40');
|
||||||
|
INSERT INTO `store_express` VALUES ('6', '安捷快递', 'anjie', '', '0', '0', '0', '2017-09-13 15:27:26');
|
||||||
|
INSERT INTO `store_express` VALUES ('7', '安信达快递', 'anxindakuaixi', null, '0', '0', '0', '2017-09-13 16:05:19');
|
||||||
|
INSERT INTO `store_express` VALUES ('8', '彪记快递', 'biaojikuaidi', null, '0', '0', '0', '2017-09-13 16:05:26');
|
||||||
|
INSERT INTO `store_express` VALUES ('9', 'BHT', 'bht', '', '0', '0', '0', '2017-09-13 16:05:37');
|
||||||
|
INSERT INTO `store_express` VALUES ('10', '百福东方国际物流', 'baifudongfang', null, '0', '0', '0', '2017-09-13 16:05:41');
|
||||||
|
INSERT INTO `store_express` VALUES ('11', '中国东方(COE)', 'coe', null, '0', '0', '0', '2017-09-13 16:05:48');
|
||||||
|
INSERT INTO `store_express` VALUES ('12', '长宇物流', 'changyuwuliu', null, '0', '0', '0', '2017-09-13 16:05:58');
|
||||||
|
INSERT INTO `store_express` VALUES ('13', '大田物流', 'datianwuliu', null, '0', '0', '0', '2017-09-13 16:06:06');
|
||||||
|
INSERT INTO `store_express` VALUES ('14', '德邦物流', 'debangwuliu', null, '1', '1', '0', '2017-09-13 16:06:14');
|
||||||
|
INSERT INTO `store_express` VALUES ('15', 'DHL', 'dhl', null, '0', '0', '0', '2017-09-13 16:06:24');
|
||||||
|
INSERT INTO `store_express` VALUES ('16', 'DPEX', 'dpex', null, '0', '0', '0', '2017-09-13 16:06:29');
|
||||||
|
INSERT INTO `store_express` VALUES ('17', 'd速快递', 'dsukuaidi', null, '0', '0', '0', '2017-09-13 16:06:34');
|
||||||
|
INSERT INTO `store_express` VALUES ('18', '递四方', 'disifang', null, '0', '0', '0', '2017-09-13 16:06:40');
|
||||||
|
INSERT INTO `store_express` VALUES ('19', 'EMS快递', 'ems', '', '1', '0', '0', '2017-09-13 16:06:47');
|
||||||
|
INSERT INTO `store_express` VALUES ('20', 'FEDEX(国外)', 'fedex', null, '0', '0', '0', '2017-09-13 16:06:56');
|
||||||
|
INSERT INTO `store_express` VALUES ('21', '飞康达物流', 'feikangda', null, '0', '0', '0', '2017-09-13 16:07:03');
|
||||||
|
INSERT INTO `store_express` VALUES ('22', '凤凰快递', 'fenghuangkuaidi', null, '0', '0', '0', '2017-09-13 16:07:10');
|
||||||
|
INSERT INTO `store_express` VALUES ('23', '飞快达', 'feikuaida', null, '0', '0', '0', '2017-09-13 16:07:16');
|
||||||
|
INSERT INTO `store_express` VALUES ('24', '国通快递', 'guotongkuaidi', null, '0', '0', '0', '2017-09-13 16:07:27');
|
||||||
|
INSERT INTO `store_express` VALUES ('25', '港中能达物流', 'ganzhongnengda', null, '0', '0', '0', '2017-09-13 16:07:33');
|
||||||
|
INSERT INTO `store_express` VALUES ('26', '广东邮政物流', 'guangdongyouzhengwuliu', null, '0', '0', '0', '2017-09-13 16:08:22');
|
||||||
|
INSERT INTO `store_express` VALUES ('27', '共速达', 'gongsuda', null, '0', '0', '0', '2017-09-13 16:08:48');
|
||||||
|
INSERT INTO `store_express` VALUES ('28', '汇通快运', 'huitongkuaidi', null, '0', '0', '0', '2017-09-13 16:08:56');
|
||||||
|
INSERT INTO `store_express` VALUES ('29', '恒路物流', 'hengluwuliu', null, '0', '0', '0', '2017-09-13 16:09:02');
|
||||||
|
INSERT INTO `store_express` VALUES ('30', '华夏龙物流', 'huaxialongwuliu', null, '0', '0', '0', '2017-09-13 16:09:12');
|
||||||
|
INSERT INTO `store_express` VALUES ('31', '海红', 'haihongwangsong', null, '0', '0', '0', '2017-09-13 16:09:20');
|
||||||
|
INSERT INTO `store_express` VALUES ('32', '海外环球', 'haiwaihuanqiu', null, '0', '0', '0', '2017-09-13 16:09:27');
|
||||||
|
INSERT INTO `store_express` VALUES ('33', '佳怡物流', 'jiayiwuliu', null, '0', '0', '0', '2017-09-13 16:09:35');
|
||||||
|
INSERT INTO `store_express` VALUES ('34', '京广速递', 'jinguangsudikuaijian', null, '0', '0', '0', '2017-09-13 16:09:42');
|
||||||
|
INSERT INTO `store_express` VALUES ('35', '急先达', 'jixianda', null, '0', '0', '0', '2017-09-13 16:09:49');
|
||||||
|
INSERT INTO `store_express` VALUES ('36', '佳吉物流', 'jjwl', null, '0', '0', '0', '2017-09-13 16:10:01');
|
||||||
|
INSERT INTO `store_express` VALUES ('37', '加运美物流', 'jymwl', null, '0', '0', '0', '2017-09-13 16:10:13');
|
||||||
|
INSERT INTO `store_express` VALUES ('38', '金大物流', 'jindawuliu', null, '0', '0', '0', '2017-09-13 16:10:22');
|
||||||
|
INSERT INTO `store_express` VALUES ('39', '嘉里大通', 'jialidatong', null, '0', '0', '0', '2017-09-13 16:10:33');
|
||||||
|
INSERT INTO `store_express` VALUES ('40', '晋越快递', 'jykd', null, '0', '0', '0', '2017-09-13 16:10:40');
|
||||||
|
INSERT INTO `store_express` VALUES ('41', '快捷速递', 'kuaijiesudi', null, '0', '0', '0', '2017-09-13 16:10:49');
|
||||||
|
INSERT INTO `store_express` VALUES ('42', '联邦快递(国内)', 'lianb', null, '0', '0', '0', '2017-09-13 16:10:58');
|
||||||
|
INSERT INTO `store_express` VALUES ('43', '联昊通物流', 'lianhaowuliu', null, '0', '0', '0', '2017-09-13 16:11:07');
|
||||||
|
INSERT INTO `store_express` VALUES ('44', '龙邦物流', 'longbanwuliu', null, '0', '0', '0', '2017-09-13 16:11:15');
|
||||||
|
INSERT INTO `store_express` VALUES ('45', '立即送', 'lijisong', null, '0', '0', '0', '2017-09-13 16:11:25');
|
||||||
|
INSERT INTO `store_express` VALUES ('46', '乐捷递', 'lejiedi', null, '0', '0', '0', '2017-09-13 16:11:36');
|
||||||
|
INSERT INTO `store_express` VALUES ('47', '民航快递', 'minghangkuaidi', null, '0', '0', '0', '2017-09-13 16:11:45');
|
||||||
|
INSERT INTO `store_express` VALUES ('48', '美国快递', 'meiguokuaidi', null, '0', '0', '0', '2017-09-13 16:11:53');
|
||||||
|
INSERT INTO `store_express` VALUES ('49', '门对门', 'menduimen', null, '0', '0', '0', '2017-09-13 16:12:01');
|
||||||
|
INSERT INTO `store_express` VALUES ('50', 'OCS', 'ocs', null, '0', '0', '0', '2017-09-13 16:12:10');
|
||||||
|
INSERT INTO `store_express` VALUES ('51', '配思货运', 'peisihuoyunkuaidi', null, '0', '0', '0', '2017-09-13 16:12:18');
|
||||||
|
INSERT INTO `store_express` VALUES ('52', '全晨快递', 'quanchenkuaidi', null, '0', '0', '0', '2017-09-13 16:12:26');
|
||||||
|
INSERT INTO `store_express` VALUES ('53', '全峰快递', 'quanfengkuaidi', null, '0', '0', '0', '2017-09-13 16:12:34');
|
||||||
|
INSERT INTO `store_express` VALUES ('54', '全际通物流', 'quanjitong', null, '0', '0', '0', '2017-09-13 16:12:41');
|
||||||
|
INSERT INTO `store_express` VALUES ('55', '全日通快递', 'quanritongkuaidi', null, '0', '0', '0', '2017-09-13 16:12:49');
|
||||||
|
INSERT INTO `store_express` VALUES ('56', '全一快递', 'quanyikuaidi', null, '0', '0', '0', '2017-09-13 16:12:56');
|
||||||
|
INSERT INTO `store_express` VALUES ('57', '如风达', 'rufengda', null, '0', '0', '0', '2017-09-13 16:13:03');
|
||||||
|
INSERT INTO `store_express` VALUES ('58', '三态速递', 'santaisudi', null, '0', '0', '0', '2017-09-13 16:13:15');
|
||||||
|
INSERT INTO `store_express` VALUES ('59', '盛辉物流', 'shenghuiwuliu', null, '0', '0', '0', '2017-09-13 16:13:22');
|
||||||
|
INSERT INTO `store_express` VALUES ('60', '申通', 'shentong', null, '0', '0', '0', '2017-09-13 16:13:34');
|
||||||
|
INSERT INTO `store_express` VALUES ('61', '顺丰', 'shunfeng', '', '1', '0', '0', '2017-09-13 16:13:41');
|
||||||
|
INSERT INTO `store_express` VALUES ('62', '速尔物流', 'sue', null, '0', '0', '0', '2017-09-13 16:13:48');
|
||||||
|
INSERT INTO `store_express` VALUES ('63', '盛丰物流', 'shengfeng', null, '0', '0', '0', '2017-09-13 16:13:55');
|
||||||
|
INSERT INTO `store_express` VALUES ('64', '赛澳递', 'saiaodi', null, '0', '0', '0', '2017-09-13 16:14:02');
|
||||||
|
INSERT INTO `store_express` VALUES ('65', '天地华宇', 'tiandihuayu', null, '0', '0', '0', '2017-09-13 16:14:11');
|
||||||
|
INSERT INTO `store_express` VALUES ('66', '天天快递', 'tiantian', null, '0', '0', '0', '2017-09-13 16:14:19');
|
||||||
|
INSERT INTO `store_express` VALUES ('67', 'TNT', 'tnt', null, '0', '0', '0', '2017-09-13 16:14:26');
|
||||||
|
INSERT INTO `store_express` VALUES ('68', 'UPS', 'ups', null, '0', '0', '0', '2017-09-13 16:14:29');
|
||||||
|
INSERT INTO `store_express` VALUES ('69', '万家物流', 'wanjiawuliu', null, '0', '0', '0', '2017-09-13 16:14:37');
|
||||||
|
INSERT INTO `store_express` VALUES ('70', '文捷航空速递', 'wenjiesudi', null, '0', '0', '0', '2017-09-13 16:14:46');
|
||||||
|
INSERT INTO `store_express` VALUES ('71', '伍圆', 'wuyuan', null, '0', '0', '0', '2017-09-13 16:14:52');
|
||||||
|
INSERT INTO `store_express` VALUES ('72', '万象物流', 'wxwl', null, '0', '0', '0', '2017-09-13 16:15:00');
|
||||||
|
INSERT INTO `store_express` VALUES ('73', '新邦物流', 'xinbangwuliu', null, '0', '0', '0', '2017-09-13 16:15:06');
|
||||||
|
INSERT INTO `store_express` VALUES ('74', '信丰物流', 'xinfengwuliu', null, '0', '0', '0', '2017-09-13 16:15:15');
|
||||||
|
INSERT INTO `store_express` VALUES ('75', '亚风速递', 'yafengsudi', null, '0', '0', '0', '2017-09-13 16:15:23');
|
||||||
|
INSERT INTO `store_express` VALUES ('76', '一邦速递', 'yibangwuliu', null, '0', '0', '0', '2017-09-13 16:15:30');
|
||||||
|
INSERT INTO `store_express` VALUES ('77', '优速物流', 'youshuwuliu', null, '0', '0', '0', '2017-09-13 16:15:36');
|
||||||
|
INSERT INTO `store_express` VALUES ('78', '邮政包裹挂号信', 'youzhengguonei', null, '0', '3', '0', '2017-09-13 16:15:44');
|
||||||
|
INSERT INTO `store_express` VALUES ('79', '邮政国际包裹挂号信', 'youzhengguoji', null, '0', '2', '0', '2017-09-13 16:15:51');
|
||||||
|
INSERT INTO `store_express` VALUES ('80', '远成物流', 'yuanchengwuliu', null, '0', '0', '0', '2017-09-13 16:15:57');
|
||||||
|
INSERT INTO `store_express` VALUES ('81', '圆通速递', 'yuantong', null, '1', '1', '0', '2017-09-13 16:16:03');
|
||||||
|
INSERT INTO `store_express` VALUES ('82', '源伟丰快递', 'yuanweifeng', null, '0', '0', '0', '2017-09-13 16:16:10');
|
||||||
|
INSERT INTO `store_express` VALUES ('83', '元智捷诚快递', 'yuanzhijiecheng', null, '0', '0', '0', '2017-09-13 16:16:17');
|
||||||
|
INSERT INTO `store_express` VALUES ('84', '韵达快运', 'yunda', null, '0', '0', '0', '2017-09-13 16:16:24');
|
||||||
|
INSERT INTO `store_express` VALUES ('85', '运通快递', 'yuntongkuaidi', null, '0', '0', '0', '2017-09-13 16:16:33');
|
||||||
|
INSERT INTO `store_express` VALUES ('86', '越丰物流', 'yuefengwuliu', null, '0', '0', '0', '2017-09-13 16:16:40');
|
||||||
|
INSERT INTO `store_express` VALUES ('87', '源安达', 'yad', null, '0', '0', '0', '2017-09-13 16:16:47');
|
||||||
|
INSERT INTO `store_express` VALUES ('88', '银捷速递', 'yinjiesudi', null, '0', '0', '0', '2017-09-13 16:16:56');
|
||||||
|
INSERT INTO `store_express` VALUES ('89', '宅急送', 'zhaijisong', null, '0', '0', '0', '2017-09-13 16:17:03');
|
||||||
|
INSERT INTO `store_express` VALUES ('90', '中铁快运', 'zhongtiekuaiyun', null, '0', '0', '0', '2017-09-13 16:17:10');
|
||||||
|
INSERT INTO `store_express` VALUES ('91', '中通速递', 'zhongtong', '', '0', '0', '0', '2017-09-13 16:17:16');
|
||||||
|
INSERT INTO `store_express` VALUES ('92', '中邮物流', 'zhongyouwuliu', null, '0', '0', '0', '2017-09-13 16:17:27');
|
||||||
|
INSERT INTO `store_express` VALUES ('93', '忠信达', 'zhongxinda', null, '0', '0', '0', '2017-09-13 16:17:34');
|
||||||
|
INSERT INTO `store_express` VALUES ('94', '芝麻开门', 'zhimakaimen', null, '0', '0', '0', '2017-09-13 16:17:41');
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Table structure for store_goods
|
||||||
|
-- ----------------------------
|
||||||
|
DROP TABLE IF EXISTS `store_goods`;
|
||||||
|
CREATE TABLE `store_goods` (
|
||||||
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
`brand_id` bigint(20) unsigned DEFAULT '0' COMMENT '品牌ID',
|
`brand_id` bigint(20) unsigned DEFAULT '0' COMMENT '品牌ID',
|
||||||
`cate_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品分类id',
|
`cate_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品分类id',
|
||||||
@ -44,14 +154,14 @@ CREATE TABLE `goods` (
|
|||||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品主表';
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品主表';
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of goods
|
-- Records of store_goods
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Table structure for goods_brand
|
-- Table structure for store_goods_brand
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
DROP TABLE IF EXISTS `goods_brand`;
|
DROP TABLE IF EXISTS `store_goods_brand`;
|
||||||
CREATE TABLE `goods_brand` (
|
CREATE TABLE `store_goods_brand` (
|
||||||
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
|
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
`brand_logo` varchar(1024) DEFAULT '' COMMENT '品牌logo',
|
`brand_logo` varchar(1024) DEFAULT '' COMMENT '品牌logo',
|
||||||
`brand_cover` varchar(1024) DEFAULT '' COMMENT '品牌封面',
|
`brand_cover` varchar(1024) DEFAULT '' COMMENT '品牌封面',
|
||||||
@ -63,17 +173,17 @@ CREATE TABLE `goods_brand` (
|
|||||||
`is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)',
|
`is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)',
|
||||||
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
PRIMARY KEY (`id`)
|
PRIMARY KEY (`id`)
|
||||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商品产品品牌';
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='产品品牌';
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of goods_brand
|
-- Records of store_goods_brand
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Table structure for goods_cate
|
-- Table structure for store_goods_cate
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
DROP TABLE IF EXISTS `goods_cate`;
|
DROP TABLE IF EXISTS `store_goods_cate`;
|
||||||
CREATE TABLE `goods_cate` (
|
CREATE TABLE `store_goods_cate` (
|
||||||
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
`pid` bigint(20) unsigned DEFAULT '0' COMMENT '上级分类编号',
|
`pid` bigint(20) unsigned DEFAULT '0' COMMENT '上级分类编号',
|
||||||
`brand_id` bigint(20) DEFAULT '0' COMMENT '品牌ID',
|
`brand_id` bigint(20) DEFAULT '0' COMMENT '品牌ID',
|
||||||
@ -87,14 +197,14 @@ CREATE TABLE `goods_cate` (
|
|||||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品分类';
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品分类';
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of goods_cate
|
-- Records of store_goods_cate
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Table structure for goods_list
|
-- Table structure for store_goods_list
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
DROP TABLE IF EXISTS `goods_list`;
|
DROP TABLE IF EXISTS `store_goods_list`;
|
||||||
CREATE TABLE `goods_list` (
|
CREATE TABLE `store_goods_list` (
|
||||||
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
`goods_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品ID',
|
`goods_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品ID',
|
||||||
`goods_spec` varchar(255) DEFAULT '' COMMENT '商品规格名称',
|
`goods_spec` varchar(255) DEFAULT '' COMMENT '商品规格名称',
|
||||||
@ -110,14 +220,14 @@ CREATE TABLE `goods_list` (
|
|||||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品列表';
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品列表';
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of goods_list
|
-- Records of store_goods_list
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Table structure for goods_spec
|
-- Table structure for store_goods_spec
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
DROP TABLE IF EXISTS `goods_spec`;
|
DROP TABLE IF EXISTS `store_goods_spec`;
|
||||||
CREATE TABLE `goods_spec` (
|
CREATE TABLE `store_goods_spec` (
|
||||||
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
`mch_id` bigint(20) unsigned DEFAULT '0' COMMENT '商户ID',
|
`mch_id` bigint(20) unsigned DEFAULT '0' COMMENT '商户ID',
|
||||||
`spec_title` varchar(255) DEFAULT '' COMMENT '商品规格名称',
|
`spec_title` varchar(255) DEFAULT '' COMMENT '商品规格名称',
|
||||||
@ -132,7 +242,152 @@ CREATE TABLE `goods_spec` (
|
|||||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品规格';
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品规格';
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of goods_spec
|
-- Records of store_goods_spec
|
||||||
|
-- ----------------------------
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Table structure for store_member
|
||||||
|
-- ----------------------------
|
||||||
|
DROP TABLE IF EXISTS `store_member`;
|
||||||
|
CREATE TABLE `store_member` (
|
||||||
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
|
`openid` varchar(100) DEFAULT '' COMMENT '会员微信OPENID',
|
||||||
|
`phone` varchar(16) DEFAULT '' COMMENT '会员手机号',
|
||||||
|
`password` varchar(64) NOT NULL DEFAULT '' COMMENT '登录密码',
|
||||||
|
`nickname` varchar(20) DEFAULT '' COMMENT '会员昵称',
|
||||||
|
`headimg` varchar(500) DEFAULT '' COMMENT '会员头像',
|
||||||
|
`sex` char(2) DEFAULT '' COMMENT '性别',
|
||||||
|
`level` tinyint(2) unsigned DEFAULT '1' COMMENT '会员级别',
|
||||||
|
`remark` varchar(500) DEFAULT '' COMMENT '会员个性签名',
|
||||||
|
`status` tinyint(1) unsigned DEFAULT '1' COMMENT '会员状态(1有效,0无效)',
|
||||||
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
UNIQUE KEY `index_store_member_openid` (`openid`) USING BTREE,
|
||||||
|
KEY `index_store_member_phone` (`phone`) USING BTREE
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城会员信息';
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Records of store_member
|
||||||
|
-- ----------------------------
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Table structure for store_member_address
|
||||||
|
-- ----------------------------
|
||||||
|
DROP TABLE IF EXISTS `store_member_address`;
|
||||||
|
CREATE TABLE `store_member_address` (
|
||||||
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
|
`mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID',
|
||||||
|
`username` varchar(20) DEFAULT '' COMMENT '收货人姓名',
|
||||||
|
`phone` varchar(16) DEFAULT '' COMMENT '收货手机号',
|
||||||
|
`province` varchar(50) DEFAULT '' COMMENT '收货地址省份',
|
||||||
|
`city` varchar(50) DEFAULT '' COMMENT '收货地址城市',
|
||||||
|
`area` varchar(255) DEFAULT '' COMMENT '收货地址区域',
|
||||||
|
`address` varchar(255) DEFAULT '' COMMENT '收货详细地址',
|
||||||
|
`status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0无效, 1新快递)',
|
||||||
|
`is_default` tinyint(1) unsigned DEFAULT '1' COMMENT '默认收货地址',
|
||||||
|
`is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)',
|
||||||
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城会员收货地址';
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Records of store_member_address
|
||||||
|
-- ----------------------------
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Table structure for store_order
|
||||||
|
-- ----------------------------
|
||||||
|
DROP TABLE IF EXISTS `store_order`;
|
||||||
|
CREATE TABLE `store_order` (
|
||||||
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
|
`type` tinyint(1) unsigned DEFAULT '1' COMMENT '订单类型(1普通订单,2积分订单)',
|
||||||
|
`mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID',
|
||||||
|
`order_no` char(10) DEFAULT '' COMMENT '订单号',
|
||||||
|
`freight_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '快递费',
|
||||||
|
`goods_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '商品总金额(不含快递费)',
|
||||||
|
`real_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '真实支付金额(商品金额+快递金额)',
|
||||||
|
`is_pay` tinyint(1) unsigned DEFAULT '0' COMMENT '订单支付状态(0.未支付,1.已支付)',
|
||||||
|
`pay_type` varchar(255) DEFAULT '' COMMENT '支付方式 (wechat微信支付, alipay支付宝支付)',
|
||||||
|
`pay_no` varchar(100) DEFAULT '' COMMENT '商户交易号',
|
||||||
|
`pay_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '实际支付金额',
|
||||||
|
`pay_at` datetime DEFAULT NULL COMMENT '支付时间',
|
||||||
|
`desc` text COMMENT '订单描述',
|
||||||
|
`status` bigint(1) unsigned DEFAULT '1' COMMENT '订单状态(0.无效,1.新订单,2.待发货,3.已发货,4.已收货,5.已完成,6.已退货及退款)',
|
||||||
|
`is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)',
|
||||||
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
KEY `index_store_order_order_no` (`order_no`) USING BTREE,
|
||||||
|
KEY `index_store_order_status` (`status`) USING BTREE
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单主表';
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Records of store_order
|
||||||
|
-- ----------------------------
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Table structure for store_order_express
|
||||||
|
-- ----------------------------
|
||||||
|
DROP TABLE IF EXISTS `store_order_express`;
|
||||||
|
CREATE TABLE `store_order_express` (
|
||||||
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
|
`mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID',
|
||||||
|
`type` tinyint(1) unsigned DEFAULT '0' COMMENT '快递类型(0.订单快递,1.退货快递)',
|
||||||
|
`order_no` char(10) DEFAULT '' COMMENT '订单编号',
|
||||||
|
`company_title` varchar(50) DEFAULT '' COMMENT '物流公司名称',
|
||||||
|
`company_code` varchar(50) DEFAULT '' COMMENT '物流公司编码',
|
||||||
|
`username` varchar(20) DEFAULT '' COMMENT '收货人姓名',
|
||||||
|
`phone` varchar(16) DEFAULT '' COMMENT '收货手机号',
|
||||||
|
`province` varchar(50) DEFAULT NULL COMMENT '收货地址省份',
|
||||||
|
`city` varchar(50) DEFAULT '' COMMENT '收货地址城市',
|
||||||
|
`area` varchar(255) DEFAULT '' COMMENT '收货地址区域',
|
||||||
|
`address` varchar(255) DEFAULT '' COMMENT '收货详细地址',
|
||||||
|
`send_no` varchar(50) DEFAULT '' COMMENT '实际物流公司单号',
|
||||||
|
`send_company_title` varchar(50) DEFAULT '' COMMENT '实际发货快递公司',
|
||||||
|
`send_company_code` varchar(50) DEFAULT '' COMMENT '实际发货快递代码',
|
||||||
|
`send_username` varchar(255) DEFAULT '' COMMENT '寄件人名称',
|
||||||
|
`send_phone` varchar(16) DEFAULT '' COMMENT '寄件人手机号',
|
||||||
|
`send_province` varchar(50) DEFAULT '' COMMENT '寄件人地址省份',
|
||||||
|
`send_city` varchar(50) DEFAULT '' COMMENT '寄件人地址城市',
|
||||||
|
`send_area` varchar(255) DEFAULT '' COMMENT '寄件人地址区域',
|
||||||
|
`send_address` varchar(255) DEFAULT '' COMMENT '寄件人详细地址',
|
||||||
|
`send_at` datetime DEFAULT NULL COMMENT '快递发货时间',
|
||||||
|
`desc` text COMMENT '发货描述',
|
||||||
|
`status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0.无效,1.新快递,2.已签收,3.签收失败)',
|
||||||
|
`is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)',
|
||||||
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单快递';
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Records of store_order_express
|
||||||
|
-- ----------------------------
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Table structure for store_order_goods
|
||||||
|
-- ----------------------------
|
||||||
|
DROP TABLE IF EXISTS `store_order_goods`;
|
||||||
|
CREATE TABLE `store_order_goods` (
|
||||||
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
|
`mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID',
|
||||||
|
`order_no` char(10) DEFAULT '' COMMENT '订单编号',
|
||||||
|
`goods_id` bigint(20) DEFAULT '0' COMMENT '商品ID',
|
||||||
|
`goods_title` varchar(255) DEFAULT '' COMMENT '商品标签',
|
||||||
|
`goods_spec` varchar(255) DEFAULT '' COMMENT '商品规格',
|
||||||
|
`goods_logo` varchar(255) DEFAULT '' COMMENT '商品LOGO',
|
||||||
|
`goods_image` text COMMENT '商品图片地址',
|
||||||
|
`market_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '市场价格',
|
||||||
|
`selling_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '商品销售价格',
|
||||||
|
`price_field` varchar(20) DEFAULT 'selling_price' COMMENT '计价字段',
|
||||||
|
`number` bigint(20) unsigned DEFAULT '0' COMMENT '订单商品数量',
|
||||||
|
`status` bigint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)',
|
||||||
|
`is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)',
|
||||||
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
KEY `index_store_order_list_order_no` (`order_no`)
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单关联商品';
|
||||||
|
|
||||||
|
-- ----------------------------
|
||||||
|
-- Records of store_order_goods
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
@ -183,7 +438,7 @@ CREATE TABLE `system_config` (
|
|||||||
`value` varchar(500) DEFAULT NULL COMMENT '配置值',
|
`value` varchar(500) DEFAULT NULL COMMENT '配置值',
|
||||||
PRIMARY KEY (`id`),
|
PRIMARY KEY (`id`),
|
||||||
KEY `index_system_config_name` (`name`)
|
KEY `index_system_config_name` (`name`)
|
||||||
) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='系统参数配置';
|
) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 COMMENT='系统参数配置';
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of system_config
|
-- Records of system_config
|
||||||
@ -191,8 +446,8 @@ CREATE TABLE `system_config` (
|
|||||||
INSERT INTO `system_config` VALUES ('1', 'app_name', 'ThinkAdmin');
|
INSERT INTO `system_config` VALUES ('1', 'app_name', 'ThinkAdmin');
|
||||||
INSERT INTO `system_config` VALUES ('2', 'site_name', 'ThinkAdmin');
|
INSERT INTO `system_config` VALUES ('2', 'site_name', 'ThinkAdmin');
|
||||||
INSERT INTO `system_config` VALUES ('3', 'app_version', '3.0 dev');
|
INSERT INTO `system_config` VALUES ('3', 'app_version', '3.0 dev');
|
||||||
INSERT INTO `system_config` VALUES ('4', 'site_copy', '©版权所有 2014-2018 楚才科技');
|
INSERT INTO `system_config` VALUES ('4', 'site_copy', '©版权所有 2014-2018 楚才科技');
|
||||||
INSERT INTO `system_config` VALUES ('5', 'browser_icon', 'http://service.thinkadmin.top/static/upload/f47b8fe06e38ae99/08e8398da45583b9.png');
|
INSERT INTO `system_config` VALUES ('5', 'browser_icon', 'http://localhost/ThinkAdmin/static/upload/f47b8fe06e38ae99/08e8398da45583b9.png');
|
||||||
INSERT INTO `system_config` VALUES ('6', 'tongji_baidu_key', '');
|
INSERT INTO `system_config` VALUES ('6', 'tongji_baidu_key', '');
|
||||||
INSERT INTO `system_config` VALUES ('7', 'miitbeian', '粤ICP备16006642号-2');
|
INSERT INTO `system_config` VALUES ('7', 'miitbeian', '粤ICP备16006642号-2');
|
||||||
INSERT INTO `system_config` VALUES ('8', 'storage_type', 'local');
|
INSERT INTO `system_config` VALUES ('8', 'storage_type', 'local');
|
||||||
@ -209,7 +464,7 @@ INSERT INTO `system_config` VALUES ('18', 'storage_oss_secret', '用你自己的
|
|||||||
INSERT INTO `system_config` VALUES ('34', 'wechat_appid', 'wx60a43dd8161666d4');
|
INSERT INTO `system_config` VALUES ('34', 'wechat_appid', 'wx60a43dd8161666d4');
|
||||||
INSERT INTO `system_config` VALUES ('35', 'wechat_appkey', '9890a0d7c91801a609d151099e95b61a');
|
INSERT INTO `system_config` VALUES ('35', 'wechat_appkey', '9890a0d7c91801a609d151099e95b61a');
|
||||||
INSERT INTO `system_config` VALUES ('36', 'storage_oss_is_https', 'http');
|
INSERT INTO `system_config` VALUES ('36', 'storage_oss_is_https', 'http');
|
||||||
INSERT INTO `system_config` VALUES ('37', 'wechat_type', 'api');
|
INSERT INTO `system_config` VALUES ('37', 'wechat_type', 'thr');
|
||||||
INSERT INTO `system_config` VALUES ('38', 'wechat_token', 'test');
|
INSERT INTO `system_config` VALUES ('38', 'wechat_token', 'test');
|
||||||
INSERT INTO `system_config` VALUES ('39', 'wechat_appsecret', 'a041bec98ed015d52b99acea5c6a16ef');
|
INSERT INTO `system_config` VALUES ('39', 'wechat_appsecret', 'a041bec98ed015d52b99acea5c6a16ef');
|
||||||
INSERT INTO `system_config` VALUES ('40', 'wechat_encodingaeskey', 'BJIUzE0gqlWy0GxfPp4J1oPTBmOrNDIGPNav1YFH5Z5');
|
INSERT INTO `system_config` VALUES ('40', 'wechat_encodingaeskey', 'BJIUzE0gqlWy0GxfPp4J1oPTBmOrNDIGPNav1YFH5Z5');
|
||||||
@ -254,7 +509,7 @@ CREATE TABLE `system_menu` (
|
|||||||
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
PRIMARY KEY (`id`),
|
PRIMARY KEY (`id`),
|
||||||
KEY `index_system_menu_node` (`node`) USING BTREE
|
KEY `index_system_menu_node` (`node`) USING BTREE
|
||||||
) ENGINE=InnoDB AUTO_INCREMENT=32 DEFAULT CHARSET=utf8 COMMENT='系统菜单表';
|
) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 COMMENT='系统菜单表';
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of system_menu
|
-- Records of system_menu
|
||||||
@ -268,22 +523,33 @@ INSERT INTO `system_menu` VALUES ('6', '11', '访问节点', '', 'fa fa-fort-awe
|
|||||||
INSERT INTO `system_menu` VALUES ('7', '0', '后台首页', '', '', 'admin/index/main', '', '_self', '1000', '1', '0', '2018-01-23 13:42:30');
|
INSERT INTO `system_menu` VALUES ('7', '0', '后台首页', '', '', 'admin/index/main', '', '_self', '1000', '1', '0', '2018-01-23 13:42:30');
|
||||||
INSERT INTO `system_menu` VALUES ('8', '16', '系统日志', '', 'fa fa-code', 'admin/log/index', '', '_self', '10', '1', '0', '2018-01-24 13:52:58');
|
INSERT INTO `system_menu` VALUES ('8', '16', '系统日志', '', 'fa fa-code', 'admin/log/index', '', '_self', '10', '1', '0', '2018-01-24 13:52:58');
|
||||||
INSERT INTO `system_menu` VALUES ('9', '10', '文件存储', '', 'fa fa-stop-circle', 'admin/config/file', '', '_self', '30', '1', '0', '2018-01-25 10:54:28');
|
INSERT INTO `system_menu` VALUES ('9', '10', '文件存储', '', 'fa fa-stop-circle', 'admin/config/file', '', '_self', '30', '1', '0', '2018-01-25 10:54:28');
|
||||||
INSERT INTO `system_menu` VALUES ('10', '1', '系统管理', '', 'fa fa-scribd', '#', '', '_self', '200', '1', '0', '2018-01-25 18:14:28');
|
INSERT INTO `system_menu` VALUES ('10', '1', '系统管理', '', '', '#', '', '_self', '200', '1', '0', '2018-01-25 18:14:28');
|
||||||
INSERT INTO `system_menu` VALUES ('11', '1', '访问权限', '', 'fa fa-anchor', '#', '', '_self', '300', '1', '0', '2018-01-25 18:15:08');
|
INSERT INTO `system_menu` VALUES ('11', '1', '访问权限', '', '', '#', '', '_self', '300', '1', '0', '2018-01-25 18:15:08');
|
||||||
INSERT INTO `system_menu` VALUES ('16', '1', '日志管理', '', 'fa fa-hashtag', '#', '', '_self', '400', '1', '0', '2018-02-10 16:31:15');
|
INSERT INTO `system_menu` VALUES ('16', '1', '日志管理', '', '', '#', '', '_self', '400', '1', '0', '2018-02-10 16:31:15');
|
||||||
INSERT INTO `system_menu` VALUES ('17', '0', '微信管理', '', '', '#', '', '_self', '8000', '1', '0', '2018-03-06 14:42:49');
|
INSERT INTO `system_menu` VALUES ('17', '0', '微信管理', '', '', '#', '', '_self', '8000', '1', '0', '2018-03-06 14:42:49');
|
||||||
INSERT INTO `system_menu` VALUES ('18', '17', '公众号配置', '', 'fa fa-cogs', '#', '', '_self', '0', '1', '0', '2018-03-06 14:43:05');
|
INSERT INTO `system_menu` VALUES ('18', '17', '公众号配置', '', '', '#', '', '_self', '0', '1', '0', '2018-03-06 14:43:05');
|
||||||
INSERT INTO `system_menu` VALUES ('19', '18', '微信授权绑定', '', 'fa fa-cog', 'wechat/config/index', '', '_self', '0', '1', '0', '2018-03-06 14:43:26');
|
INSERT INTO `system_menu` VALUES ('19', '18', '微信授权绑定', '', 'fa fa-cog', 'wechat/config/index', '', '_self', '0', '1', '0', '2018-03-06 14:43:26');
|
||||||
INSERT INTO `system_menu` VALUES ('20', '18', '关注默认回复', '', 'fa fa-comment-o', 'wechat/keys/subscribe', '', '_self', '0', '1', '0', '2018-03-06 14:44:45');
|
INSERT INTO `system_menu` VALUES ('20', '18', '关注默认回复', '', 'fa fa-comment-o', 'wechat/keys/subscribe', '', '_self', '0', '1', '0', '2018-03-06 14:44:45');
|
||||||
INSERT INTO `system_menu` VALUES ('21', '18', '无反馈默认回复', '', 'fa fa-commenting', 'wechat/keys/defaults', '', '_self', '0', '1', '0', '2018-03-06 14:45:55');
|
INSERT INTO `system_menu` VALUES ('21', '18', '无反馈默认回复', '', 'fa fa-commenting', 'wechat/keys/defaults', '', '_self', '0', '1', '0', '2018-03-06 14:45:55');
|
||||||
INSERT INTO `system_menu` VALUES ('22', '18', '微信关键字管理', '', 'fa fa-hashtag', 'wechat/keys/index', '', '_self', '0', '1', '0', '2018-03-06 14:46:23');
|
INSERT INTO `system_menu` VALUES ('22', '18', '微信关键字管理', '', 'fa fa-hashtag', 'wechat/keys/index', '', '_self', '0', '1', '0', '2018-03-06 14:46:23');
|
||||||
INSERT INTO `system_menu` VALUES ('23', '17', '微信服务定制', '', 'fa fa-cubes', '#', '', '_self', '0', '1', '0', '2018-03-06 14:47:11');
|
INSERT INTO `system_menu` VALUES ('23', '17', '微信服务定制', '', '', '#', '', '_self', '0', '1', '0', '2018-03-06 14:47:11');
|
||||||
INSERT INTO `system_menu` VALUES ('24', '23', '微信菜单管理', '', 'fa fa-gg-circle', 'wechat/menu/index', '', '_self', '0', '1', '0', '2018-03-06 14:47:39');
|
INSERT INTO `system_menu` VALUES ('24', '23', '微信菜单管理', '', 'fa fa-gg-circle', 'wechat/menu/index', '', '_self', '0', '1', '0', '2018-03-06 14:47:39');
|
||||||
INSERT INTO `system_menu` VALUES ('25', '23', '微信图文管理', '', 'fa fa-map-o', 'wechat/news/index', '', '_self', '0', '1', '0', '2018-03-06 14:48:14');
|
INSERT INTO `system_menu` VALUES ('25', '23', '微信图文管理', '', 'fa fa-map-o', 'wechat/news/index', '', '_self', '0', '1', '0', '2018-03-06 14:48:14');
|
||||||
INSERT INTO `system_menu` VALUES ('26', '17', '微信粉丝管理', '', 'fa fa-user', '#', '', '_self', '0', '1', '0', '2018-03-06 14:48:33');
|
INSERT INTO `system_menu` VALUES ('26', '17', '微信粉丝管理', '', 'fa fa-user', '#', '', '_self', '0', '1', '0', '2018-03-06 14:48:33');
|
||||||
INSERT INTO `system_menu` VALUES ('27', '26', '微信粉丝列表', '', 'fa fa-users', 'wechat/fans/index', '', '_self', '20', '1', '0', '2018-03-06 14:49:04');
|
INSERT INTO `system_menu` VALUES ('27', '26', '微信粉丝列表', '', 'fa fa-users', 'wechat/fans/index', '', '_self', '20', '1', '0', '2018-03-06 14:49:04');
|
||||||
INSERT INTO `system_menu` VALUES ('28', '26', '微信黑名单管理', '', 'fa fa-user-times', 'wechat/block/index', '', '_self', '30', '1', '0', '2018-03-06 14:49:22');
|
INSERT INTO `system_menu` VALUES ('28', '26', '微信黑名单管理', '', 'fa fa-user-times', 'wechat/fans_block/index', '', '_self', '30', '1', '0', '2018-03-06 14:49:22');
|
||||||
INSERT INTO `system_menu` VALUES ('29', '26', '微信标签管理', '', 'fa fa-tags', 'wechat/tags/index', '', '_self', '10', '1', '0', '2018-03-06 14:49:39');
|
INSERT INTO `system_menu` VALUES ('29', '26', '微信标签管理', '', 'fa fa-tags', 'wechat/tags/index', '', '_self', '10', '1', '0', '2018-03-06 14:49:39');
|
||||||
|
INSERT INTO `system_menu` VALUES ('32', '0', '商城管理', '', '', '#', '', '_self', '2000', '1', '0', '2018-03-20 16:46:07');
|
||||||
|
INSERT INTO `system_menu` VALUES ('33', '32', '商品管理', '', '', '#', '', '_self', '0', '1', '0', '2018-03-20 16:46:21');
|
||||||
|
INSERT INTO `system_menu` VALUES ('34', '33', '产品管理', '', 'fa fa-modx', 'store/goods/index', '', '_self', '0', '1', '0', '2018-03-20 16:46:45');
|
||||||
|
INSERT INTO `system_menu` VALUES ('35', '33', '规格管理', '', 'fa fa-hashtag', 'store/goods_spec/index', '', '_self', '0', '1', '0', '2018-03-20 16:47:08');
|
||||||
|
INSERT INTO `system_menu` VALUES ('36', '33', '分类管理', '', 'fa fa-product-hunt', 'store/goods_cate/index', '', '_self', '0', '1', '0', '2018-03-20 16:47:50');
|
||||||
|
INSERT INTO `system_menu` VALUES ('37', '33', '品牌管理', '', 'fa fa-scribd', 'store/goods_brand/index', '', '_self', '0', '1', '0', '2018-03-20 16:48:05');
|
||||||
|
INSERT INTO `system_menu` VALUES ('38', '32', '订单管理', '', '', '#', '', '_self', '0', '1', '0', '2018-04-21 15:07:36');
|
||||||
|
INSERT INTO `system_menu` VALUES ('39', '38', '订单列表', '', 'fa fa-adjust', 'store/order/index', '', '_self', '0', '1', '0', '2018-04-21 15:07:54');
|
||||||
|
INSERT INTO `system_menu` VALUES ('40', '32', '商城配置', '', '', '#', '', '_self', '0', '1', '0', '2018-04-21 15:08:17');
|
||||||
|
INSERT INTO `system_menu` VALUES ('41', '40', '参数管理', '', '', '#', '', '_self', '0', '0', '0', '2018-04-21 15:08:25');
|
||||||
|
INSERT INTO `system_menu` VALUES ('42', '40', '快递公司', '', 'fa fa-mixcloud', 'store/express/index', '', '_self', '0', '1', '0', '2018-04-21 15:08:50');
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Table structure for system_node
|
-- Table structure for system_node
|
||||||
@ -299,87 +565,125 @@ CREATE TABLE `system_node` (
|
|||||||
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
`create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
PRIMARY KEY (`id`),
|
PRIMARY KEY (`id`),
|
||||||
KEY `index_system_node_node` (`node`)
|
KEY `index_system_node_node` (`node`)
|
||||||
) ENGINE=InnoDB AUTO_INCREMENT=230 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='系统节点表';
|
) ENGINE=InnoDB AUTO_INCREMENT=145 DEFAULT CHARSET=utf8 COMMENT='系统节点表';
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of system_node
|
-- Records of system_node
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
INSERT INTO `system_node` VALUES ('1', 'admin', '系统管理', '0', '1', '1', '2018-01-23 12:39:13');
|
INSERT INTO `system_node` VALUES ('13', 'admin', '系统设置', '0', '1', '1', '2018-05-04 11:02:34');
|
||||||
INSERT INTO `system_node` VALUES ('2', 'admin/auth', '权限管理', '0', '1', '1', '2018-01-23 12:39:14');
|
INSERT INTO `system_node` VALUES ('14', 'admin/auth', '权限管理', '0', '1', '1', '2018-05-04 11:06:55');
|
||||||
INSERT INTO `system_node` VALUES ('3', 'admin/auth/index', '权限列表', '1', '1', '1', '2018-01-23 12:39:14');
|
INSERT INTO `system_node` VALUES ('15', 'admin/auth/index', '权限列表', '1', '1', '1', '2018-05-04 11:06:56');
|
||||||
INSERT INTO `system_node` VALUES ('4', 'admin/auth/apply', '访问授权', '0', '1', '1', '2018-01-23 12:39:19');
|
INSERT INTO `system_node` VALUES ('16', 'admin/auth/apply', '权限配置', '0', '1', '1', '2018-05-04 11:06:56');
|
||||||
INSERT INTO `system_node` VALUES ('5', 'admin/auth/add', '添加权限', '0', '1', '1', '2018-01-23 12:39:22');
|
INSERT INTO `system_node` VALUES ('17', 'admin/auth/add', '添加权限', '0', '1', '1', '2018-05-04 11:06:56');
|
||||||
INSERT INTO `system_node` VALUES ('6', 'admin/auth/edit', '编辑权限', '0', '1', '1', '2018-01-23 12:39:23');
|
INSERT INTO `system_node` VALUES ('18', 'admin/auth/edit', '编辑权限', '0', '1', '1', '2018-05-04 11:06:56');
|
||||||
INSERT INTO `system_node` VALUES ('7', 'admin/auth/forbid', '禁用权限', '0', '1', '1', '2018-01-23 12:39:23');
|
INSERT INTO `system_node` VALUES ('19', 'admin/auth/forbid', '禁用权限', '0', '1', '1', '2018-05-04 11:06:56');
|
||||||
INSERT INTO `system_node` VALUES ('8', 'admin/auth/resume', '启用权限', '0', '1', '1', '2018-01-23 12:39:24');
|
INSERT INTO `system_node` VALUES ('20', 'admin/auth/resume', '启用权限', '0', '1', '1', '2018-05-04 11:06:56');
|
||||||
INSERT INTO `system_node` VALUES ('9', 'admin/auth/del', '删除权限', '0', '1', '1', '2018-01-23 12:39:25');
|
INSERT INTO `system_node` VALUES ('21', 'admin/auth/del', '删除权限', '0', '1', '1', '2018-05-04 11:06:56');
|
||||||
INSERT INTO `system_node` VALUES ('10', 'admin/config/index', '系统参数', '1', '1', '1', '2018-01-23 12:39:25');
|
INSERT INTO `system_node` VALUES ('22', 'admin/config', '系统配置', '0', '1', '1', '2018-05-04 11:08:18');
|
||||||
INSERT INTO `system_node` VALUES ('11', 'admin/config/file', '文件存储', '0', '1', '1', '2018-01-23 12:39:26');
|
INSERT INTO `system_node` VALUES ('23', 'admin/config/index', '系统参数', '1', '1', '1', '2018-05-04 11:08:25');
|
||||||
INSERT INTO `system_node` VALUES ('13', 'admin/log/index', '日志记录', '1', '1', '1', '2018-01-23 12:39:28');
|
INSERT INTO `system_node` VALUES ('24', 'admin/config/file', '文件存储', '1', '1', '1', '2018-05-04 11:08:27');
|
||||||
INSERT INTO `system_node` VALUES ('14', 'admin/log/sms', '短信记录', '0', '1', '1', '2018-01-23 12:39:29');
|
INSERT INTO `system_node` VALUES ('25', 'admin/log', '日志管理', '0', '1', '1', '2018-05-04 11:08:43');
|
||||||
INSERT INTO `system_node` VALUES ('15', 'admin/log/del', '日志删除', '0', '1', '1', '2018-01-23 12:39:29');
|
INSERT INTO `system_node` VALUES ('26', 'admin/log/index', '日志管理', '1', '1', '1', '2018-05-04 11:08:43');
|
||||||
INSERT INTO `system_node` VALUES ('16', 'admin/menu/index', '系统菜单列表', '1', '1', '1', '2018-01-23 12:39:31');
|
INSERT INTO `system_node` VALUES ('28', 'admin/log/del', '日志删除', '0', '1', '1', '2018-05-04 11:08:43');
|
||||||
INSERT INTO `system_node` VALUES ('17', 'admin/menu/add', '添加系统菜单', '0', '1', '1', '2018-01-23 12:39:31');
|
INSERT INTO `system_node` VALUES ('29', 'admin/menu', '系统菜单', '0', '1', '1', '2018-05-04 11:09:54');
|
||||||
INSERT INTO `system_node` VALUES ('18', 'admin/menu/edit', '编辑系统菜单', '0', '1', '1', '2018-01-23 12:39:32');
|
INSERT INTO `system_node` VALUES ('30', 'admin/menu/index', '菜单列表', '1', '1', '1', '2018-05-04 11:09:54');
|
||||||
INSERT INTO `system_node` VALUES ('19', 'admin/menu/del', '删除系统菜单', '0', '1', '1', '2018-01-23 12:39:33');
|
INSERT INTO `system_node` VALUES ('31', 'admin/menu/add', '添加菜单', '0', '1', '1', '2018-05-04 11:09:55');
|
||||||
INSERT INTO `system_node` VALUES ('20', 'admin/menu/forbid', '禁用系统菜单', '0', '1', '1', '2018-01-23 12:39:33');
|
INSERT INTO `system_node` VALUES ('32', 'admin/menu/edit', '编辑菜单', '0', '1', '1', '2018-05-04 11:09:55');
|
||||||
INSERT INTO `system_node` VALUES ('21', 'admin/menu/resume', '启用系统菜单', '0', '1', '1', '2018-01-23 12:39:34');
|
INSERT INTO `system_node` VALUES ('33', 'admin/menu/del', '删除菜单', '0', '1', '1', '2018-05-04 11:09:55');
|
||||||
INSERT INTO `system_node` VALUES ('22', 'admin/node/index', '系统节点列表', '1', '1', '1', '2018-01-23 12:39:36');
|
INSERT INTO `system_node` VALUES ('34', 'admin/menu/forbid', '禁用菜单', '0', '1', '1', '2018-05-04 11:09:55');
|
||||||
INSERT INTO `system_node` VALUES ('23', 'admin/node/save', '保存节点信息', '0', '1', '1', '2018-01-23 12:39:36');
|
INSERT INTO `system_node` VALUES ('35', 'admin/menu/resume', '启用菜单', '0', '1', '1', '2018-05-04 11:09:55');
|
||||||
INSERT INTO `system_node` VALUES ('24', 'admin/user/index', '系统用户列表', '1', '1', '1', '2018-01-23 12:39:37');
|
INSERT INTO `system_node` VALUES ('36', 'admin/node', '节点管理', '0', '1', '1', '2018-05-04 11:10:20');
|
||||||
INSERT INTO `system_node` VALUES ('25', 'admin/user/auth', '用户授权操作', '0', '1', '1', '2018-01-23 12:39:38');
|
INSERT INTO `system_node` VALUES ('37', 'admin/node/index', '节点列表', '1', '1', '1', '2018-05-04 11:10:20');
|
||||||
INSERT INTO `system_node` VALUES ('26', 'admin/user/add', '添加系统用户', '0', '1', '1', '2018-01-23 12:39:39');
|
INSERT INTO `system_node` VALUES ('38', 'admin/node/clear', '清理节点', '0', '1', '1', '2018-05-04 11:10:21');
|
||||||
INSERT INTO `system_node` VALUES ('27', 'admin/user/edit', '编辑系统用户', '0', '1', '1', '2018-01-23 12:39:39');
|
INSERT INTO `system_node` VALUES ('39', 'admin/node/save', '更新节点', '0', '1', '1', '2018-05-04 11:10:21');
|
||||||
INSERT INTO `system_node` VALUES ('28', 'admin/user/pass', '修改用户密码', '0', '1', '1', '2018-01-23 12:39:40');
|
INSERT INTO `system_node` VALUES ('40', 'admin/user', '系统用户', '0', '1', '1', '2018-05-04 11:10:43');
|
||||||
INSERT INTO `system_node` VALUES ('29', 'admin/user/del', '删除系统用户', '0', '1', '1', '2018-01-23 12:39:41');
|
INSERT INTO `system_node` VALUES ('41', 'admin/user/index', '用户列表', '1', '1', '1', '2018-05-04 11:10:43');
|
||||||
INSERT INTO `system_node` VALUES ('30', 'admin/user/forbid', '禁用系统用户', '0', '1', '1', '2018-01-23 12:39:41');
|
INSERT INTO `system_node` VALUES ('42', 'admin/user/auth', '用户授权', '0', '1', '1', '2018-05-04 11:10:43');
|
||||||
INSERT INTO `system_node` VALUES ('31', 'admin/user/resume', '启用系统用户', '0', '1', '1', '2018-01-23 12:39:42');
|
INSERT INTO `system_node` VALUES ('43', 'admin/user/add', '添加用户', '0', '1', '1', '2018-05-04 11:10:43');
|
||||||
INSERT INTO `system_node` VALUES ('32', 'admin/config', '系统配置', '0', '1', '1', '2018-01-23 13:34:37');
|
INSERT INTO `system_node` VALUES ('44', 'admin/user/edit', '编辑用户', '0', '1', '1', '2018-05-04 11:10:43');
|
||||||
INSERT INTO `system_node` VALUES ('33', 'admin/log', '日志管理', '0', '1', '1', '2018-01-23 13:34:48');
|
INSERT INTO `system_node` VALUES ('45', 'admin/user/pass', '修改密码', '0', '1', '1', '2018-05-04 11:10:43');
|
||||||
INSERT INTO `system_node` VALUES ('34', 'admin/menu', '系统菜单管理', '0', '1', '1', '2018-01-23 13:34:58');
|
INSERT INTO `system_node` VALUES ('46', 'admin/user/del', '删除用户', '0', '1', '1', '2018-05-04 11:10:43');
|
||||||
INSERT INTO `system_node` VALUES ('35', 'admin/node', '系统节点管理', '0', '1', '1', '2018-01-23 13:35:17');
|
INSERT INTO `system_node` VALUES ('47', 'admin/user/forbid', '禁用启用', '0', '1', '1', '2018-05-04 11:10:43');
|
||||||
INSERT INTO `system_node` VALUES ('36', 'admin/user', '系统用户管理', '0', '1', '1', '2018-01-23 13:35:26');
|
INSERT INTO `system_node` VALUES ('48', 'admin/user/resume', '启用用户', '0', '1', '1', '2018-05-04 11:10:44');
|
||||||
INSERT INTO `system_node` VALUES ('37', 'wechat', '微信管理', '0', '1', '1', '2018-02-06 11:53:21');
|
INSERT INTO `system_node` VALUES ('49', 'store', '商城管理', '0', '1', '1', '2018-05-04 11:11:28');
|
||||||
INSERT INTO `system_node` VALUES ('38', 'wechat/config', '公众号对接', '0', '1', '1', '2018-02-06 11:53:32');
|
INSERT INTO `system_node` VALUES ('50', 'store/express', '快递公司管理', '0', '1', '1', '2018-05-04 11:11:39');
|
||||||
INSERT INTO `system_node` VALUES ('39', 'wechat/config/index', '公众号对接', '1', '1', '1', '2018-02-06 11:53:32');
|
INSERT INTO `system_node` VALUES ('51', 'store/express/index', '快递公司列表', '1', '1', '1', '2018-05-04 11:11:39');
|
||||||
INSERT INTO `system_node` VALUES ('45', 'wechat/block', '黑名单', '0', '1', '1', '2018-03-06 14:37:37');
|
INSERT INTO `system_node` VALUES ('52', 'store/express/add', '添加快递公司', '0', '1', '1', '2018-05-04 11:11:39');
|
||||||
INSERT INTO `system_node` VALUES ('46', 'wechat/block/index', '黑名单列表', '1', '1', '1', '2018-03-06 14:37:47');
|
INSERT INTO `system_node` VALUES ('53', 'store/express/edit', '编辑快递公司', '0', '1', '1', '2018-05-04 11:11:39');
|
||||||
INSERT INTO `system_node` VALUES ('47', 'wechat/block/backdel', '移出黑名单', '0', '1', '1', '2018-03-06 14:37:49');
|
INSERT INTO `system_node` VALUES ('54', 'store/express/del', '删除快递公司', '0', '1', '1', '2018-05-04 11:11:39');
|
||||||
INSERT INTO `system_node` VALUES ('48', 'wechat/fans', '粉丝管理', '0', '1', '1', '2018-03-06 14:38:06');
|
INSERT INTO `system_node` VALUES ('55', 'store/express/forbid', '禁用快递公司', '0', '1', '1', '2018-05-04 11:11:39');
|
||||||
INSERT INTO `system_node` VALUES ('49', 'wechat/fans/index', '粉丝列表', '1', '1', '1', '2018-03-06 14:38:25');
|
INSERT INTO `system_node` VALUES ('56', 'store/express/resume', '启用快递公司', '0', '1', '1', '2018-05-04 11:11:40');
|
||||||
INSERT INTO `system_node` VALUES ('50', 'wechat/fans/backadd', '移入黑名单', '0', '1', '1', '2018-03-06 14:38:35');
|
INSERT INTO `system_node` VALUES ('57', 'store/order', '订单管理', '0', '1', '1', '2018-05-04 11:12:14');
|
||||||
INSERT INTO `system_node` VALUES ('51', 'wechat/fans/tagset', '标签设置', '0', '1', '1', '2018-03-06 14:38:36');
|
INSERT INTO `system_node` VALUES ('58', 'store/order/index', '订单列表', '1', '1', '1', '2018-05-04 11:12:17');
|
||||||
INSERT INTO `system_node` VALUES ('52', 'wechat/fans/tagadd', '添加标签', '0', '1', '1', '2018-03-06 14:38:37');
|
INSERT INTO `system_node` VALUES ('59', 'store/order/address', '修改地址', '0', '1', '1', '2018-05-04 11:12:19');
|
||||||
INSERT INTO `system_node` VALUES ('53', 'wechat/fans/tagdel', '删除标签', '0', '1', '1', '2018-03-06 14:38:38');
|
INSERT INTO `system_node` VALUES ('76', 'wechat', '微信管理', '0', '1', '1', '2018-05-04 11:14:59');
|
||||||
INSERT INTO `system_node` VALUES ('54', 'wechat/fans/sync', '同步粉丝', '0', '1', '1', '2018-03-06 14:38:38');
|
INSERT INTO `system_node` VALUES ('78', 'wechat/config', '微信对接管理', '0', '1', '1', '2018-05-04 11:16:20');
|
||||||
INSERT INTO `system_node` VALUES ('55', 'wechat/keys', '关键字管理', '0', '1', '1', '2018-03-06 14:39:21');
|
INSERT INTO `system_node` VALUES ('79', 'wechat/config/index', '微信对接配置', '1', '1', '1', '2018-05-04 11:16:23');
|
||||||
INSERT INTO `system_node` VALUES ('56', 'wechat/keys/index', '关键字列表', '1', '1', '1', '2018-03-06 14:39:25');
|
INSERT INTO `system_node` VALUES ('80', 'wechat/fans', '微信粉丝管理', '0', '1', '1', '2018-05-04 11:16:31');
|
||||||
INSERT INTO `system_node` VALUES ('57', 'wechat/keys/add', '添加关键字', '0', '1', '1', '2018-03-06 14:39:27');
|
INSERT INTO `system_node` VALUES ('81', 'wechat/fans/index', '微信粉丝列表', '1', '1', '1', '2018-05-04 11:16:32');
|
||||||
INSERT INTO `system_node` VALUES ('58', 'wechat/keys/edit', '编辑关键字', '0', '1', '1', '2018-03-06 14:39:28');
|
INSERT INTO `system_node` VALUES ('82', 'wechat/fans/backadd', '微信粉丝拉黑', '0', '1', '1', '2018-05-04 11:16:32');
|
||||||
INSERT INTO `system_node` VALUES ('59', 'wechat/keys/del', '删除关键字', '0', '1', '1', '2018-03-06 14:39:42');
|
INSERT INTO `system_node` VALUES ('83', 'wechat/fans/tagset', '设置粉丝标签', '0', '1', '1', '2018-05-04 11:16:32');
|
||||||
INSERT INTO `system_node` VALUES ('60', 'wechat/keys/forbid', '禁用关键字', '0', '1', '1', '2018-03-06 14:39:55');
|
INSERT INTO `system_node` VALUES ('84', 'wechat/fans/tagadd', '添加粉丝标签', '0', '1', '1', '2018-05-04 11:16:32');
|
||||||
INSERT INTO `system_node` VALUES ('61', 'wechat/keys/resume', '启用关键字', '0', '1', '1', '2018-03-06 14:40:01');
|
INSERT INTO `system_node` VALUES ('85', 'wechat/fans/tagdel', '删除粉丝标签', '0', '1', '1', '2018-05-04 11:16:32');
|
||||||
INSERT INTO `system_node` VALUES ('62', 'wechat/keys/subscribe', '关注默认回复', '1', '1', '1', '2018-03-06 14:40:12');
|
INSERT INTO `system_node` VALUES ('86', 'wechat/fans/sync', '同步粉丝列表', '0', '1', '1', '2018-05-04 11:16:32');
|
||||||
INSERT INTO `system_node` VALUES ('63', 'wechat/keys/defaults', '无反馈默认回复', '1', '1', '1', '2018-03-06 14:40:27');
|
INSERT INTO `system_node` VALUES ('87', 'wechat/fans_block', '粉丝黑名单管理', '0', '1', '1', '2018-05-04 11:17:25');
|
||||||
INSERT INTO `system_node` VALUES ('64', 'wechat/menu', '微信菜单管理', '0', '1', '1', '2018-03-06 14:40:37');
|
INSERT INTO `system_node` VALUES ('88', 'wechat/fans_block/index', '粉丝黑名单列表', '1', '1', '1', '2018-05-04 11:17:50');
|
||||||
INSERT INTO `system_node` VALUES ('65', 'wechat/menu/index', '微信菜单管理', '1', '1', '1', '2018-03-06 14:40:41');
|
INSERT INTO `system_node` VALUES ('89', 'wechat/fans_block/backdel', '移除粉丝黑名单', '0', '1', '1', '2018-05-04 11:17:51');
|
||||||
INSERT INTO `system_node` VALUES ('66', 'wechat/menu/edit', '编辑发布菜单', '0', '1', '1', '2018-03-06 14:40:53');
|
INSERT INTO `system_node` VALUES ('90', 'wechat/keys', '微信关键字', '0', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('67', 'wechat/menu/cancel', '取消发布菜单', '0', '1', '1', '2018-03-06 14:41:01');
|
INSERT INTO `system_node` VALUES ('91', 'wechat/keys/index', '关键字列表', '1', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('68', 'wechat/news', '图文内容管理', '0', '1', '1', '2018-03-06 14:41:13');
|
INSERT INTO `system_node` VALUES ('92', 'wechat/keys/add', '添加关键字', '0', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('69', 'wechat/news/index', '图文内容管理', '1', '1', '1', '2018-03-06 14:41:20');
|
INSERT INTO `system_node` VALUES ('93', 'wechat/keys/edit', '编辑关键字', '0', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('70', 'wechat/news/select', '图文选择器', '0', '1', '1', '2018-03-06 14:41:22');
|
INSERT INTO `system_node` VALUES ('94', 'wechat/keys/del', '删除关键字', '0', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('71', 'wechat/news/image', '图文选择器', '0', '1', '1', '2018-03-06 14:41:22');
|
INSERT INTO `system_node` VALUES ('95', 'wechat/keys/forbid', '禁用关键字', '0', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('72', 'wechat/news/add', '添加图文', '0', '1', '1', '2018-03-06 14:41:23');
|
INSERT INTO `system_node` VALUES ('96', 'wechat/keys/resume', '启用关键字', '0', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('73', 'wechat/news/del', '删除图文', '0', '1', '1', '2018-03-06 14:41:23');
|
INSERT INTO `system_node` VALUES ('97', 'wechat/keys/subscribe', '关注回复', '1', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('74', 'wechat/news/push', '推荐图文', '0', '1', '1', '2018-03-06 14:41:24');
|
INSERT INTO `system_node` VALUES ('98', 'wechat/keys/defaults', '默认回复', '1', '1', '1', '2018-05-04 11:18:09');
|
||||||
INSERT INTO `system_node` VALUES ('75', 'wechat/news/edit', '编辑图文', '0', '1', '1', '2018-03-06 14:41:25');
|
INSERT INTO `system_node` VALUES ('99', 'wechat/menu', '微信菜单管理', '0', '1', '1', '2018-05-04 11:18:57');
|
||||||
INSERT INTO `system_node` VALUES ('76', 'wechat/tags', '标签管理', '0', '1', '1', '2018-03-06 14:42:06');
|
INSERT INTO `system_node` VALUES ('100', 'wechat/menu/index', '微信菜单展示', '1', '1', '1', '2018-05-04 11:19:10');
|
||||||
INSERT INTO `system_node` VALUES ('77', 'wechat/tags/index', '标签列表', '1', '1', '1', '2018-03-06 14:42:09');
|
INSERT INTO `system_node` VALUES ('101', 'wechat/menu/edit', '编辑微信菜单', '0', '1', '1', '2018-05-04 11:19:22');
|
||||||
INSERT INTO `system_node` VALUES ('78', 'wechat/tags/add', '添加标签', '0', '1', '1', '2018-03-06 14:42:14');
|
INSERT INTO `system_node` VALUES ('102', 'wechat/menu/cancel', '取消微信菜单', '0', '1', '1', '2018-05-04 11:19:26');
|
||||||
INSERT INTO `system_node` VALUES ('79', 'wechat/tags/edit', '编辑标签', '0', '1', '1', '2018-03-06 14:42:17');
|
INSERT INTO `system_node` VALUES ('103', 'wechat/news/index', '微信图文列表', '1', '1', '1', '2018-05-04 11:19:28');
|
||||||
INSERT INTO `system_node` VALUES ('80', 'wechat/tags/del', '删除标签', '0', '1', '1', '2018-03-06 14:42:20');
|
INSERT INTO `system_node` VALUES ('104', 'wechat/news/select', '微信图文选择', '0', '1', '1', '2018-05-04 11:19:28');
|
||||||
INSERT INTO `system_node` VALUES ('81', 'wechat/tags/sync', '同步标签', '0', '1', '1', '2018-03-06 14:42:23');
|
INSERT INTO `system_node` VALUES ('105', 'wechat/news/image', '微信图片选择', '0', '1', '1', '2018-05-04 11:19:28');
|
||||||
INSERT INTO `system_node` VALUES ('229', 'admin/node/clear', '清理无效记录', '0', '1', '1', '2018-03-09 12:24:31');
|
INSERT INTO `system_node` VALUES ('106', 'wechat/news/add', '添加微信图文', '0', '1', '1', '2018-05-04 11:19:28');
|
||||||
|
INSERT INTO `system_node` VALUES ('107', 'wechat/news/edit', '编辑微信图文', '0', '1', '1', '2018-05-04 11:19:28');
|
||||||
|
INSERT INTO `system_node` VALUES ('108', 'wechat/news/del', '删除微信图文', '0', '1', '1', '2018-05-04 11:19:28');
|
||||||
|
INSERT INTO `system_node` VALUES ('109', 'wechat/news/push', '推送微信图文', '0', '1', '1', '2018-05-04 11:19:28');
|
||||||
|
INSERT INTO `system_node` VALUES ('110', 'wechat/news', '微信图文管理', '0', '1', '1', '2018-05-04 11:19:35');
|
||||||
|
INSERT INTO `system_node` VALUES ('111', 'wechat/tags', '微信粉丝标签管理', '0', '1', '1', '2018-05-04 11:20:28');
|
||||||
|
INSERT INTO `system_node` VALUES ('112', 'wechat/tags/index', '粉丝标签列表', '1', '1', '1', '2018-05-04 11:20:28');
|
||||||
|
INSERT INTO `system_node` VALUES ('113', 'wechat/tags/add', '添加粉丝标签', '0', '1', '1', '2018-05-04 11:20:28');
|
||||||
|
INSERT INTO `system_node` VALUES ('114', 'wechat/tags/edit', '编辑粉丝标签', '0', '1', '1', '2018-05-04 11:20:29');
|
||||||
|
INSERT INTO `system_node` VALUES ('115', 'wechat/tags/del', '删除粉丝标签', '0', '1', '1', '2018-05-04 11:20:29');
|
||||||
|
INSERT INTO `system_node` VALUES ('116', 'wechat/tags/sync', '同步粉丝标签', '0', '1', '1', '2018-05-04 11:20:29');
|
||||||
|
INSERT INTO `system_node` VALUES ('117', 'store/goods', '商品管理', '0', '1', '1', '2018-05-04 11:29:55');
|
||||||
|
INSERT INTO `system_node` VALUES ('118', 'store/goods/index', '商品列表', '1', '1', '1', '2018-05-04 11:29:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('119', 'store/goods/add', '添加商品', '0', '1', '1', '2018-05-04 11:29:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('120', 'store/goods/edit', '编辑商品', '0', '1', '1', '2018-05-04 11:29:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('121', 'store/goods/del', '删除商品', '0', '1', '1', '2018-05-04 11:29:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('122', 'store/goods/forbid', '下架商品', '0', '1', '1', '2018-05-04 11:29:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('123', 'store/goods/resume', '上架商品', '0', '1', '1', '2018-05-04 11:29:57');
|
||||||
|
INSERT INTO `system_node` VALUES ('124', 'store/goods_brand', '商品品牌管理', '0', '1', '1', '2018-05-04 11:30:44');
|
||||||
|
INSERT INTO `system_node` VALUES ('125', 'store/goods_brand/index', '商品品牌列表', '1', '1', '1', '2018-05-04 11:30:52');
|
||||||
|
INSERT INTO `system_node` VALUES ('126', 'store/goods_brand/add', '添加商品品牌', '0', '1', '1', '2018-05-04 11:30:55');
|
||||||
|
INSERT INTO `system_node` VALUES ('127', 'store/goods_brand/edit', '编辑商品品牌', '0', '1', '1', '2018-05-04 11:30:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('128', 'store/goods_brand/del', '删除商品品牌', '0', '1', '1', '2018-05-04 11:30:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('129', 'store/goods_brand/forbid', '禁用商品品牌', '0', '1', '1', '2018-05-04 11:30:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('130', 'store/goods_brand/resume', '启用商品品牌', '0', '1', '1', '2018-05-04 11:30:56');
|
||||||
|
INSERT INTO `system_node` VALUES ('131', 'store/goods_cate', '商品分类管理', '0', '1', '1', '2018-05-04 11:31:19');
|
||||||
|
INSERT INTO `system_node` VALUES ('132', 'store/goods_cate/index', '商品分类列表', '1', '1', '1', '2018-05-04 11:31:23');
|
||||||
|
INSERT INTO `system_node` VALUES ('133', 'store/goods_cate/add', '添加商品分类', '0', '1', '1', '2018-05-04 11:31:23');
|
||||||
|
INSERT INTO `system_node` VALUES ('134', 'store/goods_cate/edit', '编辑商品分类', '0', '1', '1', '2018-05-04 11:31:23');
|
||||||
|
INSERT INTO `system_node` VALUES ('135', 'store/goods_cate/del', '删除商品分类', '0', '1', '1', '2018-05-04 11:31:24');
|
||||||
|
INSERT INTO `system_node` VALUES ('136', 'store/goods_cate/forbid', '禁用商品分类', '0', '1', '1', '2018-05-04 11:31:24');
|
||||||
|
INSERT INTO `system_node` VALUES ('137', 'store/goods_cate/resume', '启用商品分类', '0', '1', '1', '2018-05-04 11:31:24');
|
||||||
|
INSERT INTO `system_node` VALUES ('138', 'store/goods_spec', '商品规格管理', '0', '1', '1', '2018-05-04 11:31:47');
|
||||||
|
INSERT INTO `system_node` VALUES ('139', 'store/goods_spec/index', '商品规格列表', '1', '1', '1', '2018-05-04 11:31:47');
|
||||||
|
INSERT INTO `system_node` VALUES ('140', 'store/goods_spec/add', '添加商品规格', '0', '1', '1', '2018-05-04 11:31:47');
|
||||||
|
INSERT INTO `system_node` VALUES ('141', 'store/goods_spec/edit', '编辑商品规格', '0', '1', '1', '2018-05-04 11:31:48');
|
||||||
|
INSERT INTO `system_node` VALUES ('142', 'store/goods_spec/del', '删除商品规格', '0', '1', '1', '2018-05-04 11:31:48');
|
||||||
|
INSERT INTO `system_node` VALUES ('143', 'store/goods_spec/forbid', '禁用商品规格', '0', '1', '1', '2018-05-04 11:31:48');
|
||||||
|
INSERT INTO `system_node` VALUES ('144', 'store/goods_spec/resume', '启用商品规格', '0', '1', '1', '2018-05-04 11:31:48');
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Table structure for system_sequence
|
-- Table structure for system_sequence
|
||||||
@ -426,7 +730,7 @@ CREATE TABLE `system_user` (
|
|||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Records of system_user
|
-- Records of system_user
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
INSERT INTO `system_user` VALUES ('10000', 'admin', '21232f297a57a5a743894a0e4a801fc3', '22222222', '', '18993368867', '', '23296', '2018-03-23 17:05:40', '1', '2,4', '0', null, '2015-11-13 15:14:22');
|
INSERT INTO `system_user` VALUES ('10000', 'admin', '21232f297a57a5a743894a0e4a801fc3', '22222222', '', '', '', '22973', '2018-03-26 17:06:48', '1', '2,4', '0', null, '2015-11-13 15:14:22');
|
||||||
|
|
||||||
-- ----------------------------
|
-- ----------------------------
|
||||||
-- Table structure for wechat_fans
|
-- Table structure for wechat_fans
|
||||||
|
@ -75,30 +75,6 @@ class Log extends BasicAdmin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 短信发送记录
|
|
||||||
* @return array|string
|
|
||||||
* @throws \think\Exception
|
|
||||||
* @throws \think\db\exception\DataNotFoundException
|
|
||||||
* @throws \think\db\exception\ModelNotFoundException
|
|
||||||
* @throws \think\exception\DbException
|
|
||||||
*/
|
|
||||||
public function sms()
|
|
||||||
{
|
|
||||||
// 日志数据库对象
|
|
||||||
$this->title = '短信发送日志';
|
|
||||||
$get = $this->request->get();
|
|
||||||
$db = Db::name('MemberSmsHistory');
|
|
||||||
foreach (['phone', 'content', 'result'] as $key) {
|
|
||||||
(isset($get[$key]) && $get[$key] !== '') && $db->whereLike($key, "%{$get[$key]}%");
|
|
||||||
}
|
|
||||||
if (isset($get['date']) && $get['date'] !== '') {
|
|
||||||
list($start, $end) = explode(' - ', $get['date']);
|
|
||||||
$db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]);
|
|
||||||
}
|
|
||||||
return parent::_list($db->order('id desc'));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 日志删除操作
|
* 日志删除操作
|
||||||
* @throws \think\Exception
|
* @throws \think\Exception
|
||||||
|
265
application/store/controller/Goods.php
Normal file
265
application/store/controller/Goods.php
Normal file
@ -0,0 +1,265 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | ThinkAdmin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 版权所有 2014~2017 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 官方网站: http://think.ctolog.com
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 开源协议 ( https://mit-license.org )
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | github开源项目:https://github.com/zoujingli/ThinkAdmin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace app\store\controller;
|
||||||
|
|
||||||
|
use app\store\service\GoodsService;
|
||||||
|
use controller\BasicAdmin;
|
||||||
|
use service\DataService;
|
||||||
|
use service\ToolsService;
|
||||||
|
use think\Db;
|
||||||
|
use think\exception\HttpResponseException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商店商品管理
|
||||||
|
* Class Goods
|
||||||
|
* @package app\store\controller
|
||||||
|
* @author Anyon <zoujingli@qq.com>
|
||||||
|
* @date 2017/03/27 14:43
|
||||||
|
*/
|
||||||
|
class Goods extends BasicAdmin
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 定义当前操作表名
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
public $table = 'StoreGoods';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 普通商品
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$this->title = '商品管理';
|
||||||
|
$get = $this->request->get();
|
||||||
|
$db = Db::name($this->table)->where(['is_deleted' => '0']);
|
||||||
|
if (isset($get['tags_id']) && $get['tags_id'] !== '') {
|
||||||
|
$db->whereLike('tags_id', "%,{$get['tags_id']},%");
|
||||||
|
}
|
||||||
|
if (isset($get['goods_title']) && $get['goods_title'] !== '') {
|
||||||
|
$db->whereLike('goods_title', "%{$get['goods_title']}%");
|
||||||
|
}
|
||||||
|
foreach (['cate_id', 'brand_id'] as $field) {
|
||||||
|
(isset($get[$field]) && $get[$field] !== '') && $db->where($field, $get[$field]);
|
||||||
|
}
|
||||||
|
if (isset($get['create_at']) && $get['create_at'] !== '') {
|
||||||
|
list($start, $end) = explode(' - ', $get['create_at']);
|
||||||
|
$db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]);
|
||||||
|
}
|
||||||
|
return parent::_list($db->order('status desc,sort asc,id desc'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商城数据处理
|
||||||
|
* @param array $data
|
||||||
|
*/
|
||||||
|
protected function _data_filter(&$data)
|
||||||
|
{
|
||||||
|
$result = GoodsService::buildGoodsList($data);
|
||||||
|
$this->assign([
|
||||||
|
'brands' => $result['brand'],
|
||||||
|
'cates' => ToolsService::arr2table($result['cate']),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 添加商品
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
* @throws \think\Exception
|
||||||
|
*/
|
||||||
|
public function add()
|
||||||
|
{
|
||||||
|
if ($this->request->isGet()) {
|
||||||
|
$this->title = '添加商品';
|
||||||
|
$this->_form_assign();
|
||||||
|
return $this->_form($this->table, 'form');
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
$data = $this->_form_build_data();
|
||||||
|
Db::transaction(function () use ($data) {
|
||||||
|
$goodsID = Db::name($this->table)->insertGetId($data['main']);
|
||||||
|
foreach ($data['list'] as &$vo) {
|
||||||
|
$vo['goods_id'] = $goodsID;
|
||||||
|
}
|
||||||
|
Db::name('StoreGoodsList')->insertAll($data['list']);
|
||||||
|
});
|
||||||
|
} catch (HttpResponseException $exception) {
|
||||||
|
return $exception->getResponse();
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
$this->error('商品添加失败,请稍候再试!');
|
||||||
|
}
|
||||||
|
list($base, $spm, $url) = [url('@admin'), $this->request->get('spm'), url('store/goods/index')];
|
||||||
|
$this->success('添加商品成功!', "{$base}#{$url}?spm={$spm}");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 编辑商品
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
public function edit()
|
||||||
|
{
|
||||||
|
if (!$this->request->isPost()) {
|
||||||
|
$goods_id = $this->request->get('id');
|
||||||
|
$goods = Db::name($this->table)->where(['id' => $goods_id, 'is_deleted' => '0'])->find();
|
||||||
|
empty($goods) && $this->error('需要编辑的商品不存在!');
|
||||||
|
$goods['list'] = Db::name('StoreGoodsList')->where(['goods_id' => $goods_id, 'is_deleted' => '0'])->select();
|
||||||
|
$this->_form_assign();
|
||||||
|
return $this->fetch('form', ['vo' => $goods, 'title' => '编辑商品']);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
$data = $this->_form_build_data();
|
||||||
|
$goods_id = $this->request->post('id');
|
||||||
|
$goods = Db::name($this->table)->where(['id' => $goods_id, 'is_deleted' => '0'])->find();
|
||||||
|
empty($goods) && $this->error('商品编辑失败,请稍候再试!');
|
||||||
|
foreach ($data['list'] as &$vo) {
|
||||||
|
$vo['goods_id'] = $goods_id;
|
||||||
|
}
|
||||||
|
Db::transaction(function () use ($data, $goods_id, $goods) {
|
||||||
|
// 更新商品主表
|
||||||
|
$where = ['id' => $goods_id, 'is_deleted' => '0'];
|
||||||
|
Db::name('StoreGoods')->where($where)->update(array_merge($goods, $data['main']));
|
||||||
|
// 更新商品详细
|
||||||
|
Db::name('StoreGoodsList')->where(['goods_id' => $goods_id])->delete();
|
||||||
|
Db::name('StoreGoodsList')->insertAll($data['list']);
|
||||||
|
});
|
||||||
|
} catch (HttpResponseException $exception) {
|
||||||
|
return $exception->getResponse();
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
$this->error('商品编辑失败,请稍候再试!' . $e->getMessage());
|
||||||
|
}
|
||||||
|
list($base, $spm, $url) = [url('@admin'), $this->request->get('spm'), url('store/goods/index')];
|
||||||
|
$this->success('商品编辑成功!', "{$base}#{$url}?spm={$spm}");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 表单数据处理
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
protected function _form_assign()
|
||||||
|
{
|
||||||
|
list($where, $order) = [['status' => '1', 'is_deleted' => '0'], 'sort asc,id desc'];
|
||||||
|
$specs = (array)Db::name('StoreGoodsSpec')->where($where)->order($order)->select();
|
||||||
|
$brands = (array)Db::name('StoreGoodsBrand')->where($where)->order($order)->select();
|
||||||
|
$cates = (array)Db::name('StoreGoodsCate')->where($where)->order($order)->select();
|
||||||
|
// 所有的商品信息
|
||||||
|
$where = ['is_deleted' => '0', 'status' => '1'];
|
||||||
|
$goodsListField = 'goods_id,goods_spec,goods_stock,goods_sale';
|
||||||
|
$goods = Db::name('StoreGoods')->field('id,goods_title')->where($where)->select();
|
||||||
|
$list = Db::name('StoreGoodsList')->field($goodsListField)->where($where)->select();
|
||||||
|
foreach ($goods as $k => $g) {
|
||||||
|
$goods[$k]['list'] = [];
|
||||||
|
foreach ($list as $v) {
|
||||||
|
($g['id'] === $v['goods_id']) && $goods[$k]['list'][] = $v;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
array_unshift($specs, ['spec_title' => ' - 不使用规格模板 -', 'spec_param' => '[]', 'id' => '0']);
|
||||||
|
$this->assign([
|
||||||
|
'specs' => $specs,
|
||||||
|
'cates' => ToolsService::arr2table($cates),
|
||||||
|
'brands' => $brands,
|
||||||
|
'all' => $goods,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 读取POST表单数据
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
protected function _form_build_data()
|
||||||
|
{
|
||||||
|
list($main, $list, $post, $verify) = [[], [], $this->request->post(), false];
|
||||||
|
empty($post['goods_logo']) && $this->error('商品LOGO不能为空,请上传后再提交数据!');
|
||||||
|
// 商品主数据组装
|
||||||
|
$main['cate_id'] = $this->request->post('cate_id', '0');
|
||||||
|
$main['spec_id'] = $this->request->post('spec_id', '0');
|
||||||
|
$main['brand_id'] = $this->request->post('brand_id', '0');
|
||||||
|
$main['goods_logo'] = $this->request->post('goods_logo', '');
|
||||||
|
$main['goods_title'] = $this->request->post('goods_title', '');
|
||||||
|
$main['goods_video'] = $this->request->post('goods_video', '');
|
||||||
|
$main['goods_image'] = $this->request->post('goods_image', '');
|
||||||
|
$main['goods_desc'] = $this->request->post('goods_desc', '', null);
|
||||||
|
$main['goods_content'] = $this->request->post('goods_content', '');
|
||||||
|
$main['tags_id'] = ',' . join(',', isset($post['tags_id']) ? $post['tags_id'] : []) . ',';
|
||||||
|
// 商品从数据组装
|
||||||
|
if (!empty($post['goods_spec'])) {
|
||||||
|
foreach ($post['goods_spec'] as $key => $value) {
|
||||||
|
$goods = [];
|
||||||
|
$goods['goods_spec'] = $value;
|
||||||
|
$goods['market_price'] = $post['market_price'][$key];
|
||||||
|
$goods['selling_price'] = $post['selling_price'][$key];
|
||||||
|
$goods['status'] = intval(!empty($post['spec_status'][$key]));
|
||||||
|
!empty($goods['status']) && $verify = true;
|
||||||
|
$list[] = $goods;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$this->error('没有商品规格或套餐信息哦!');
|
||||||
|
}
|
||||||
|
!$verify && $this->error('没有设置有效的商品规格!');
|
||||||
|
return ['main' => $main, 'list' => $list];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除商品
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function del()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品删除成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品删除失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品禁用
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function forbid()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品下架成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品下架失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品禁用
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function resume()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品上架成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品上架失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
151
application/store/controller/GoodsBrand.php
Normal file
151
application/store/controller/GoodsBrand.php
Normal file
@ -0,0 +1,151 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | Think.Admin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 版权所有 2014~2017 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 官方网站: http://think.ctolog.com
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 开源协议 ( https://mit-license.org )
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | github开源项目:https://github.com/zoujingli/Think.Admin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace app\store\controller;
|
||||||
|
|
||||||
|
use controller\BasicAdmin;
|
||||||
|
use service\DataService;
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商店品牌管理
|
||||||
|
* Class Brand
|
||||||
|
* @package app\store\controller
|
||||||
|
* @author Anyon <zoujingli@qq.com>
|
||||||
|
* @date 2017/03/27 14:43
|
||||||
|
*/
|
||||||
|
class GoodsBrand extends BasicAdmin
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 定义当前操作表名
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
public $table = 'StoreGoodsBrand';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 品牌列表
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$this->title = '品牌管理';
|
||||||
|
$get = $this->request->get();
|
||||||
|
$db = Db::name($this->table)->where(['is_deleted' => '0']);
|
||||||
|
if (isset($get['brand_title']) && $get['brand_title'] !== '') {
|
||||||
|
$db->whereLike('brand_title', "%{$get['brand_title']}%");
|
||||||
|
}
|
||||||
|
if (isset($get['create_at']) && $get['create_at'] !== '') {
|
||||||
|
list($start, $end) = explode(' - ', $get['create_at']);
|
||||||
|
$db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]);
|
||||||
|
}
|
||||||
|
return parent::_list($db->order('sort asc,id desc'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 添加品牌
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
* @throws \think\Exception
|
||||||
|
*/
|
||||||
|
public function add()
|
||||||
|
{
|
||||||
|
$this->title = '添加品牌';
|
||||||
|
return $this->_form($this->table, 'form');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 编辑品牌
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
* @throws \think\Exception
|
||||||
|
*/
|
||||||
|
public function edit()
|
||||||
|
{
|
||||||
|
$this->title = '编辑品牌';
|
||||||
|
return $this->_form($this->table, 'form');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 表单提交数据处理
|
||||||
|
* @param array $data
|
||||||
|
*/
|
||||||
|
protected function _form_filter($data)
|
||||||
|
{
|
||||||
|
if ($this->request->isPost()) {
|
||||||
|
empty($data['brand_logo']) && $this->error('请上传品牌Logo图片');
|
||||||
|
empty($data['brand_cover']) && $this->error('请上传品牌封面图片');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 添加成功回跳处理
|
||||||
|
* @param bool $result
|
||||||
|
*/
|
||||||
|
protected function _form_result($result)
|
||||||
|
{
|
||||||
|
if ($result !== false) {
|
||||||
|
list($base, $spm, $url) = [url('@admin'), $this->request->get('spm'), url('goods/brand/index')];
|
||||||
|
$this->success('数据保存成功!', "{$base}#{$url}?spm={$spm}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除品牌
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function del()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("品牌删除成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("品牌删除失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 品牌禁用
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function forbid()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("品牌禁用成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("品牌禁用失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 品牌签禁用
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function resume()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("品牌启用成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("品牌启用失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
157
application/store/controller/GoodsCate.php
Normal file
157
application/store/controller/GoodsCate.php
Normal file
@ -0,0 +1,157 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | ThinkAdmin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 版权所有 2014~2017 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 官方网站: http://think.ctolog.com
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 开源协议 ( https://mit-license.org )
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | github开源项目:https://github.com/zoujingli/ThinkAdmin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace app\store\controller;
|
||||||
|
|
||||||
|
use controller\BasicAdmin;
|
||||||
|
use service\DataService;
|
||||||
|
use service\ToolsService;
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商店商品分类管理
|
||||||
|
* Class Cate
|
||||||
|
* @package app\store\controller
|
||||||
|
* @author Anyon <zoujingli@qq.com>
|
||||||
|
* @date 2017/03/27 14:43
|
||||||
|
*/
|
||||||
|
class GoodsCate extends BasicAdmin
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 定义当前操作表名
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
public $table = 'StoreGoodsCate';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品分类列表
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$this->title = '商品分类';
|
||||||
|
$db = Db::name($this->table)->where(['is_deleted' => '0']);
|
||||||
|
return parent::_list($db->order('sort asc,id asc'), false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 列表数据处理
|
||||||
|
* @param array $data
|
||||||
|
*/
|
||||||
|
protected function _index_data_filter(&$data)
|
||||||
|
{
|
||||||
|
foreach ($data as &$vo) {
|
||||||
|
$vo['ids'] = join(',', ToolsService::getArrSubIds($data, $vo['id']));
|
||||||
|
}
|
||||||
|
$data = ToolsService::arr2table($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 添加菜单
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
public function add()
|
||||||
|
{
|
||||||
|
return $this->_form($this->table, 'form');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 编辑菜单
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
public function edit()
|
||||||
|
{
|
||||||
|
return $this->_form($this->table, 'form');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 表单数据前缀方法
|
||||||
|
* @param array $vo
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
protected function _form_filter(&$vo)
|
||||||
|
{
|
||||||
|
if ($this->request->isGet()) {
|
||||||
|
// 读取上级分类
|
||||||
|
$where = ['status' => '1', 'is_deleted' => '0'];
|
||||||
|
$_cates = (array)Db::name($this->table)->where($where)->order('sort desc,id desc')->select();
|
||||||
|
array_unshift($_cates, ['id' => 0, 'pid' => -1, 'cate_title' => '--- 顶级分类 ---']);
|
||||||
|
$cates = ToolsService::arr2table($_cates);
|
||||||
|
foreach ($cates as $key => &$cate) {
|
||||||
|
if (isset($vo['pid'])) {
|
||||||
|
$path = "-{$vo['pid']}-{$vo['id']}";
|
||||||
|
if ($vo['pid'] !== '' && (stripos("{$cate['path']}-", "{$path}-") !== false || $cate['path'] === $path)) {
|
||||||
|
unset($cates[$key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$this->assign('cates', $cates);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除商品分类
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function del()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品分类删除成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品分类删除失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品分类禁用
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function forbid()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品分类禁用成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品分类禁用失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品分类禁用
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function resume()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品分类启用成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品分类启用失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
157
application/store/controller/GoodsSpec.php
Normal file
157
application/store/controller/GoodsSpec.php
Normal file
@ -0,0 +1,157 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | ThinkAdmin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 版权所有 2014~2017 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 官方网站: http://think.ctolog.com
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 开源协议 ( https://mit-license.org )
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | github开源项目:https://github.com/zoujingli/ThinkAdmin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace app\store\controller;
|
||||||
|
|
||||||
|
use controller\BasicAdmin;
|
||||||
|
use service\DataService;
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商店规格管理
|
||||||
|
* Class Spec
|
||||||
|
* @package app\store\controller
|
||||||
|
* @author Anyon <zoujingli@qq.com>
|
||||||
|
* @date 2017/03/27 14:43
|
||||||
|
*/
|
||||||
|
class GoodsSpec extends BasicAdmin
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 定义当前操作表名
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
public $table = 'StoreGoodsSpec';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品列表
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$this->title = '规格管理(请勿随意修改或删除)';
|
||||||
|
$get = $this->request->get();
|
||||||
|
$db = Db::name($this->table)->where(['is_deleted' => '0']);
|
||||||
|
if (isset($get['spec_title']) && $get['spec_title'] !== '') {
|
||||||
|
$db->whereLike('spec_title', "%{$get['spec_title']}%");
|
||||||
|
}
|
||||||
|
if (isset($get['date']) && $get['date'] !== '') {
|
||||||
|
list($start, $end) = explode(' - ', $get['date']);
|
||||||
|
$db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]);
|
||||||
|
}
|
||||||
|
return parent::_list($db->order('sort asc,id desc'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 列表数据处理
|
||||||
|
* @param array $data
|
||||||
|
*/
|
||||||
|
protected function _index_data_filter(&$data)
|
||||||
|
{
|
||||||
|
foreach ($data as &$vo) {
|
||||||
|
$vo['spec_param'] = json_decode($vo['spec_param'], true);
|
||||||
|
$vo['spec_param'] = is_array($vo['spec_param']) ? $vo['spec_param'] : [];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 添加商品
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
* @throws \think\Exception
|
||||||
|
*/
|
||||||
|
public function add()
|
||||||
|
{
|
||||||
|
$this->title = '添加规格';
|
||||||
|
return $this->_form($this->table, 'form');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 编辑商品
|
||||||
|
* @return array|string
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
* @throws \think\Exception
|
||||||
|
*/
|
||||||
|
public function edit()
|
||||||
|
{
|
||||||
|
$this->title = '编辑规格';
|
||||||
|
return $this->_form($this->table, 'form');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 表单数据处理
|
||||||
|
* @param array $vo
|
||||||
|
*/
|
||||||
|
protected function _form_filter(&$vo)
|
||||||
|
{
|
||||||
|
if ($this->request->isPost()) {
|
||||||
|
$param = json_decode($this->request->post('spec_param', '[]', null), true);
|
||||||
|
foreach ($param as &$v) {
|
||||||
|
$count = 1;
|
||||||
|
while ($count) {
|
||||||
|
$v['value'] = trim(str_replace([' ', '_', ',', ',', ';', ';'], ' ', $v['value'], $count));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$vo['spec_param'] = json_encode($param, JSON_UNESCAPED_UNICODE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除商品规格
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function del()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品规格删除成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品规格删除失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品规格禁用
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function forbid()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品规格禁用成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品规格禁用失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品规格禁用
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public function resume()
|
||||||
|
{
|
||||||
|
if (DataService::update($this->table)) {
|
||||||
|
$this->success("商品规格启用成功!", '');
|
||||||
|
}
|
||||||
|
$this->error("商品规格启用失败,请稍候再试!");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
24
application/store/controller/wechat/Index.php
Normal file
24
application/store/controller/wechat/Index.php
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Created by PhpStorm.
|
||||||
|
* User: Anyon
|
||||||
|
* Date: 2018/5/3
|
||||||
|
* Time: 18:42
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace app\store\controller\wechat;
|
||||||
|
|
||||||
|
|
||||||
|
class Index
|
||||||
|
{
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
return 'fasdfas';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function pay()
|
||||||
|
{
|
||||||
|
return 'fsdfasfsa';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
134
application/store/service/GoodsService.php
Normal file
134
application/store/service/GoodsService.php
Normal file
@ -0,0 +1,134 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | ThinkAdmin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 版权所有 2014~2017 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 官方网站: http://think.ctolog.com
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | 开源协议 ( https://mit-license.org )
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | github开源项目:https://github.com/zoujingli/ThinkAdmin
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace app\store\service;
|
||||||
|
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品数据服务支持
|
||||||
|
* Class ProductService
|
||||||
|
* @package app\goods\service
|
||||||
|
*/
|
||||||
|
class GoodsService
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 主商品表数据处理
|
||||||
|
* @param array $goodsList
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public static function buildGoodsList(&$goodsList)
|
||||||
|
{
|
||||||
|
// 商品分类处理
|
||||||
|
$cateField = 'id,pid,cate_title,cate_desc';
|
||||||
|
$cateWhere = ['status' => '1', 'is_deleted' => '0'];
|
||||||
|
$cateList = Db::name('StoreGoodsCate')->where($cateWhere)->order('sort asc,id desc')->column($cateField);
|
||||||
|
// 商品品牌处理
|
||||||
|
$brandWhere = ['status' => '1', 'is_deleted' => '0'];
|
||||||
|
$brandField = 'id,brand_logo,brand_cover,brand_title,brand_desc,brand_detail';
|
||||||
|
$brandList = Db::name('StoreGoodsBrand')->where($brandWhere)->order('sort asc,id desc')->column($brandField);
|
||||||
|
// 无商品列表时
|
||||||
|
if (empty($goodsList)) {
|
||||||
|
return ['list' => $goodsList, 'cate' => $cateList, 'brand' => $brandList];
|
||||||
|
}
|
||||||
|
// 读取商品详情列表
|
||||||
|
$specWhere = [['status', 'eq', '1'], ['is_deleted', 'eq', '0'], ['goods_id', 'in', array_column($goodsList, 'id')]];
|
||||||
|
$specField = 'id,goods_id,goods_spec,goods_number,market_price,selling_price,goods_stock,goods_sale';
|
||||||
|
$specList = Db::name('StoreGoodsList')->where($specWhere)->column($specField);
|
||||||
|
foreach ($specList as $key => $spec) {
|
||||||
|
foreach ($goodsList as $goods) {
|
||||||
|
if ($goods['id'] === $spec['goods_id']) {
|
||||||
|
$specList[$key]['goods_title'] = $goods['goods_title'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($spec['goods_spec'] === 'default:default') {
|
||||||
|
$specList[$key]['goods_spec_alias'] = '<span class="color-desc">默认规格</span>';
|
||||||
|
} else {
|
||||||
|
$specList[$key]['goods_spec_alias'] = str_replace([':', ','], [': ', ', '], $spec['goods_spec']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 商品数据组装
|
||||||
|
foreach ($goodsList as $key => $vo) {
|
||||||
|
// 商品内容处理
|
||||||
|
$goodsList[$key]['goods_content'] = $vo['goods_content'];
|
||||||
|
// 商品品牌处理
|
||||||
|
$goodsList[$key]['brand'] = isset($brandList[$vo['brand_id']]) ? $brandList[$vo['brand_id']] : [];
|
||||||
|
// 商品分类关联
|
||||||
|
$goodsList[$key]['cate'] = [];
|
||||||
|
if (isset($cateList[$vo['cate_id']])) {
|
||||||
|
$goodsList[$key]['cate'][] = ($tcate = $cateList[$vo['cate_id']]);
|
||||||
|
while (isset($tcate['pid']) && $tcate['pid'] > 0 && isset($cateList[$tcate['pid']])) {
|
||||||
|
$goodsList[$key]['cate'][] = ($tcate = $cateList[$tcate['pid']]);
|
||||||
|
}
|
||||||
|
$goodsList[$key]['cate'] = array_reverse($goodsList[$key]['cate']);
|
||||||
|
}
|
||||||
|
// 商品详细列表关联
|
||||||
|
$goodsList[$key]['spec'] = [];
|
||||||
|
foreach ($specList as $spec) {
|
||||||
|
if ($vo['id'] === $spec['goods_id']) {
|
||||||
|
$goodsList[$key]['spec'][] = $spec;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ['list' => $goodsList, 'cate' => $cateList, 'brand' => $brandList];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 同步更新商品库存及售出(@todo 需要重新做库存统计)
|
||||||
|
* @param int $goods_id 商品ID
|
||||||
|
* @return array
|
||||||
|
* @throws \think\Exception
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
* @throws \think\exception\PDOException
|
||||||
|
*/
|
||||||
|
public static function syncGoodsStock($goods_id)
|
||||||
|
{
|
||||||
|
// 检查商品是否需要更新库存
|
||||||
|
$map = ['id' => $goods_id, 'is_deleted' => '0'];
|
||||||
|
if (!($goods = Db::name('Goods')->where($map)->find())) {
|
||||||
|
return ['code' => 0, 'msg' => '指定商品信息无法同步库存!'];
|
||||||
|
}
|
||||||
|
// 统计入库信息
|
||||||
|
$stockField = 'goods_id,goods_spec,ifnull(sum(goods_stock), 0) goods_stock';
|
||||||
|
$stockWhere = ['status' => '1', 'is_deleted' => '0', 'goods_id' => $goods_id, 'mch_id' => $mch_id];
|
||||||
|
$stockList = (array)Db::name('StoreGoodsStock')->field($stockField)->where($stockWhere)->group('goods_id,goods_spec')->select();
|
||||||
|
// 统计销售信息
|
||||||
|
$saleField = 'goods_id,goods_spec,ifnull(sum(number), 0) goods_sale';
|
||||||
|
$saleWhere = ['status' => '1', 'is_deleted' => '0', 'goods_id' => $goods_id, 'mch_id' => $mch_id];
|
||||||
|
$saleList = (array)Db::name('StoreOrderList')->field($saleField)->where($saleWhere)->group('goods_id,goods_spec')->select();
|
||||||
|
// 库存置零
|
||||||
|
list($where, $total_stock, $total_sale) = [['goods_id' => $goods_id], 0, 0];
|
||||||
|
Db::name('StoreGoodsList')->where($where)->update(['goods_stock' => 0, 'goods_sale' => 0, 'mch_id' => $mch_id]);
|
||||||
|
// 更新商品库存
|
||||||
|
foreach ($stockList as $stock) {
|
||||||
|
$total_stock += intval($stock['goods_stock']);
|
||||||
|
$where = ['goods_id' => $goods_id, 'goods_spec' => $stock['goods_spec'], 'mch_id' => $mch_id];
|
||||||
|
Db::name('StoreGoodsList')->where($where)->update(['goods_stock' => $stock['goods_stock']]);
|
||||||
|
}
|
||||||
|
// 更新商品销量
|
||||||
|
foreach ($saleList as $sale) {
|
||||||
|
$total_sale += intval($sale['goods_sale']);
|
||||||
|
$where = ['goods_id' => $goods_id, 'goods_spec' => $sale['goods_spec'], 'mch_id' => $mch_id];
|
||||||
|
Db::name('StoreGoodsList')->where($where)->update(['goods_sale' => $sale['goods_sale']]);
|
||||||
|
}
|
||||||
|
// 更新总库存及总销量
|
||||||
|
$update = ['package_stock' => $total_stock, 'package_sale' => $total_sale, 'mch_id' => $mch_id];
|
||||||
|
Db::name('Goods')->where(['id' => $goods_id])->update($update);
|
||||||
|
return ['code' => 1, 'msg' => '同步商品库存成功!'];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
357
application/store/view/goods/form.html
Normal file
357
application/store/view/goods/form.html
Normal file
@ -0,0 +1,357 @@
|
|||||||
|
{extend name='admin@public/content'}
|
||||||
|
|
||||||
|
{block name="content"}
|
||||||
|
<form onsubmit="return false;" action="{:request()->url()}" data-auto="true" method="post" id="ProductForm" class='form-horizontal layui-form padding-top-20'>
|
||||||
|
|
||||||
|
<!--{if !empty($brands)}-->
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">商品品牌</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<select required class="layui-select full-width" name="brand_id">
|
||||||
|
{foreach $brands as $brand}
|
||||||
|
<!--{eq name='$brand.id' value='$vo.brand_id|default=0'}-->
|
||||||
|
<option selected="selected" value="{$brand.id}">{$brand.brand_title}</option>
|
||||||
|
<!--{else}-->
|
||||||
|
<option value="{$brand.id}">{$brand.brand_title}</option>
|
||||||
|
<!--{/eq}-->
|
||||||
|
{/foreach}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if !empty($cates)}-->
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">商品分类</label>
|
||||||
|
<div class='col-sm-8 text-top'>
|
||||||
|
<select required class="layui-select full-width" name="cate_id">
|
||||||
|
{foreach $cates as $cate}
|
||||||
|
<!--{if isset($vo.cate_id) and $cate.id eq $vo.cate_id}-->
|
||||||
|
<option selected value="{$cate.id}">{$cate.spl|raw}{$cate.cate_title}</option>
|
||||||
|
<!--{else}-->
|
||||||
|
<option value="{$cate.id}">{$cate.spl|raw}{$cate.cate_title}</option>
|
||||||
|
<!--{/if}-->
|
||||||
|
{/foreach}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">商品名称</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<input name="goods_title" required value="{$vo.goods_title|default=''}" class="layui-input" title="请输入商品名称" placeholder="请输入商品名称">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{if !empty($tags)}
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">商品标签</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<div class="background-item">
|
||||||
|
{foreach $tags as $tag}
|
||||||
|
<label class="nowrap margin-right-10 line-height-18">
|
||||||
|
<!--{if isset($vo.tags_id) && in_array($tag.id,$vo.tags_id)}-->
|
||||||
|
<input type="checkbox" value="{$tag.id}" name="tags_id[]" checked="checked" lay-ignore>
|
||||||
|
<!--{else}-->
|
||||||
|
<input type="checkbox" value="{$tag.id}" name="tags_id[]" lay-ignore>
|
||||||
|
<!--{/if}-->
|
||||||
|
{$tag.tags_title}
|
||||||
|
</label>
|
||||||
|
{/foreach}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label label-required">商品图片</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<table class="layui-table background-item margin-none" lay-size="sm" lay-skin="nob">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<td>商品LOGO</td>
|
||||||
|
<td>商品图片</td>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td class="text-top" style="width:100px">
|
||||||
|
<input type="hidden" name="goods_logo" value="{$vo.goods_logo|default=''}">
|
||||||
|
</td>
|
||||||
|
<td class="text-top">
|
||||||
|
<input type="hidden" name="goods_image" value="{$vo.goods_image|default=''}">
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- 普通商品及积分商品 开始 -->
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">商品规格</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<select required class="layui-select full-width block" name="spec_id" lay-ignore>
|
||||||
|
{foreach $specs as $spec}
|
||||||
|
{php}$param=str_replace('"',"'",$spec['spec_param']);{/php}
|
||||||
|
<!--{eq name='spec.id' value='$vo.spec_id|default=0'}-->
|
||||||
|
<option data-param="{$param}" selected="selected" value="{$spec.id}">{$spec.spec_title}</option>
|
||||||
|
<!--{else}-->
|
||||||
|
<option data-param="{$param}" value="{$spec.id}">{$spec.spec_title}</option>
|
||||||
|
<!--{/eq}-->
|
||||||
|
{/foreach}
|
||||||
|
</select>
|
||||||
|
<table class="layui-table notevent" lay-size="sm" ng-if="specs.length>0">
|
||||||
|
<tr>
|
||||||
|
<th>可选规格</th>
|
||||||
|
<th>规格内容</th>
|
||||||
|
</tr>
|
||||||
|
<tr ng-repeat="x in specs">
|
||||||
|
<td ng-bind="x.name"></td>
|
||||||
|
<td>
|
||||||
|
<label ng-repeat="m in x.param" class="nowrap margin-right-10 line-height-18">
|
||||||
|
<input data-spec="{{x.name}}_{{m.value}}" ng-model="m.checked" class="inline-block" type="checkbox" lay-ignore>
|
||||||
|
<span ng-bind="m.value"></span>
|
||||||
|
</label>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
<table class="layui-table notevent" lay-size="sm">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>商品规格</th>
|
||||||
|
<th>市场价格</th>
|
||||||
|
<th>销售价格</th>
|
||||||
|
<th>规格状态</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr ng-class="x.status?'':'layui-bg-gray'" ng-repeat="x in specdata">
|
||||||
|
<td class="nowrap">
|
||||||
|
<input type="hidden" name="goods_spec[]" value="{{x.spec_name}}">
|
||||||
|
<span ng-repeat="a in x.spec_attrs">
|
||||||
|
<span class="layui-badge layui-bg-blue" ng-bind="a.name"></span>
|
||||||
|
<span ng-if="b" class="layui-badge layui-bg-green" ng-repeat="b in a.value" ng-bind="b"></span>
|
||||||
|
</span>
|
||||||
|
</td>
|
||||||
|
<td class="price-input-td">
|
||||||
|
<input onblur="this.value=(parseFloat(this.value)||0).toFixed(2)" class="layui-input" placeholder="0.00" name="market_price[]" value="{{x.market_price}}">
|
||||||
|
</td>
|
||||||
|
<td class="price-input-td">
|
||||||
|
<input onblur="this.value=(parseFloat(this.value)||0).toFixed(2)" class="layui-input" placeholder="0.00" name="selling_price[]" value="{{x.selling_price}}">
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<label class="nowrap line-height-18">
|
||||||
|
<input type="hidden" name="spec_status[]" value="{{x.status?1:0}}">
|
||||||
|
<input ng-checked="x.status" ng-model="x.status" value="1" lay-ignore class="inline-block" type="checkbox"/> 启用
|
||||||
|
</label>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- 普通商品及积分商品 结束 -->
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">视频展示</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-10 padding-right-0">
|
||||||
|
<input style="border-right:none" name="goods_video" value="{$vo.goods_video|default=''}" class="layui-input" title="请输入链接或上传视频展示文件" placeholder="请输入链接或上传视频展示文件">
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-2 padding-left-0">
|
||||||
|
<button data-file="one" data-type="mp4" data-field="goods_video" type="button" class="layui-btn layui-btn-sm" style="height:38px;line-height:38px;width:100%">上传视频文件</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">展示描述</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<textarea class="layui-textarea" name="goods_desc" placeholder="请输入展示描述">{$vo.goods_desc|default=''}</textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label label-required">商品内容</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<textarea name="goods_content">{$vo.goods_content|default=''|htmlspecialchars_decode}</textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="hr-line-dashed"></div>
|
||||||
|
|
||||||
|
<div class="col-sm-7 col-sm-offset-2">
|
||||||
|
<div class="layui-form-item text-center">
|
||||||
|
{if !empty($vo.id)}<input type="hidden" name="id" value="{$vo.id}">{/if}
|
||||||
|
<button class="layui-btn" type="submit">保存配置</button>
|
||||||
|
<button class="layui-btn layui-btn-danger" type='button' onclick="window.history.back()">取消编辑</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
require(['jquery', 'ckeditor', 'angular'], function () {
|
||||||
|
window.form.render();
|
||||||
|
window.createEditor('[name="goods_content"]', {height: 500});
|
||||||
|
var app = angular.module("ProductForm", []).run(callback);
|
||||||
|
angular.bootstrap(document.getElementById(app.name), [app.name]);
|
||||||
|
|
||||||
|
function callback($rootScope) {
|
||||||
|
// 绑定规格列表
|
||||||
|
$rootScope.specs = [];
|
||||||
|
// 规格默认数据
|
||||||
|
var specdata = JSON.parse('{$vo.list|default=[]|json_encode=###,256|raw}');
|
||||||
|
// 单图片上传处理
|
||||||
|
$('#ProductForm [name="goods_logo"]').uploadOneImage();
|
||||||
|
// 多图片上传处理
|
||||||
|
$('#ProductForm [name="goods_image"]').uploadMultipleImage();
|
||||||
|
// 规格显示切换
|
||||||
|
$('#ProductForm').on('click', '[data-spec]', applySpecData);
|
||||||
|
// 商品规格切换
|
||||||
|
$('#ProductForm').on('change', '[name="spec_id"]', function () {
|
||||||
|
var specs = eval(this.options[this.selectedIndex].getAttribute('data-param'));
|
||||||
|
for (var i in specs) {
|
||||||
|
specs[i].param = [];
|
||||||
|
var values = specs[i].value.split(' ');
|
||||||
|
for (var j in values) {
|
||||||
|
specs[i].param.push({
|
||||||
|
name: specs[i].name, value: values[j],
|
||||||
|
checked: getSpecStatus(specs[i].name, values[j])
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$rootScope.$apply(function () {
|
||||||
|
$rootScope.specs = specs;
|
||||||
|
setTimeout(applySpecData, 10);
|
||||||
|
});
|
||||||
|
}).find('[name="spec_id"]').trigger('change');
|
||||||
|
|
||||||
|
// 规格属性切换
|
||||||
|
function applySpecData() {
|
||||||
|
var params = {};
|
||||||
|
for (var i in $rootScope.specs) {
|
||||||
|
var isChecked = false;
|
||||||
|
for (var j in $rootScope.specs[i].param) {
|
||||||
|
if ($rootScope.specs[i].param[j].checked) {
|
||||||
|
isChecked = true;
|
||||||
|
var name = $rootScope.specs[i].param[j].name;
|
||||||
|
var value = $rootScope.specs[i].param[j].value;
|
||||||
|
(params[name] || (params[name] = [])).push({name: name, value: value});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!isChecked) {
|
||||||
|
$rootScope.specs[i].param[0].checked = true;
|
||||||
|
var name = $rootScope.specs[i].param[0].name;
|
||||||
|
var value = $rootScope.specs[i].param[0].value;
|
||||||
|
(params[name] || (params[name] = [])).push({name: name, value: value});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$rootScope.$apply(function () {
|
||||||
|
$rootScope.specdata = DataArray.render(params);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取规格选择状态
|
||||||
|
function getSpecStatus(name, spec) {
|
||||||
|
for (var i in specdata) {
|
||||||
|
if (specdata[i].goods_spec.indexOf(name + ':' + spec) > -1) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 数据处理
|
||||||
|
var DataArray = new function () {
|
||||||
|
// 编译生成规格数据
|
||||||
|
this.render = function (data) {
|
||||||
|
var specs = [], list = [];
|
||||||
|
for (var i in data) {
|
||||||
|
specs = this.joinArray(data[i], specs, i);
|
||||||
|
}
|
||||||
|
(specs.length < 1) && (specs = ['default:default']);
|
||||||
|
for (var i in specs) {
|
||||||
|
var specName = specs[i];
|
||||||
|
var specTitle = (specName === 'default:default') ? '默认规格' : specName.replace(/,/ig, ';').replace(/:/ig, ':');
|
||||||
|
var specAttrs = [], lines = specTitle.split(';');
|
||||||
|
for (var j in lines) {
|
||||||
|
var line = lines[j].split(':');
|
||||||
|
specAttrs.push({name: line[0], value: (line[1] || '').split(',')});
|
||||||
|
}
|
||||||
|
list.push({
|
||||||
|
spec_name: specName, spec_title: specTitle, spec_attrs: specAttrs,
|
||||||
|
market_price: parseFloat(this.getData(specs[i], 'market_price') || '0').toFixed(2),
|
||||||
|
selling_price: parseFloat(this.getData(specs[i], 'selling_price') || '0').toFixed(2),
|
||||||
|
status: this.getData(specName, 'status') !== '0'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
};
|
||||||
|
// 读取规格默认数据
|
||||||
|
this.getData = function (spec, field) {
|
||||||
|
for (var i in specdata) {
|
||||||
|
if (specdata[i].goods_spec === spec) {
|
||||||
|
return specdata[i][field] || '0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return '1';
|
||||||
|
};
|
||||||
|
// 数组交叉计算
|
||||||
|
this.joinArray = function (item, list, pk) {
|
||||||
|
var _list = [];
|
||||||
|
for (var i in item) {
|
||||||
|
if (list.length > 0) {
|
||||||
|
for (var j in list) {
|
||||||
|
_list.push(list[j] + ',' + pk + ':' + item[i].value);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
_list.push(pk + ':' + item[i].value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return _list;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
{/block}
|
||||||
|
|
||||||
|
{block name="style"}
|
||||||
|
<style>
|
||||||
|
|
||||||
|
.background-item {
|
||||||
|
padding: 15px;
|
||||||
|
background: #efefef;
|
||||||
|
}
|
||||||
|
|
||||||
|
.background-item thead tr {
|
||||||
|
background: #e0e0e0
|
||||||
|
}
|
||||||
|
|
||||||
|
.price-input-td {
|
||||||
|
padding: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.price-input-td:before {
|
||||||
|
margin: 4px;
|
||||||
|
width: 35px;
|
||||||
|
height: 22px;
|
||||||
|
content: "金额";
|
||||||
|
line-height: 20px;
|
||||||
|
text-align: center;
|
||||||
|
position: absolute;
|
||||||
|
background: #e2e2e2;
|
||||||
|
}
|
||||||
|
|
||||||
|
.price-input-td input {
|
||||||
|
height: 30px;
|
||||||
|
padding-left: 50px;
|
||||||
|
border: none !important;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
{/block}
|
189
application/store/view/goods/index.html
Normal file
189
application/store/view/goods/index.html
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
{extend name='admin@public/content'}
|
||||||
|
|
||||||
|
{block name="button"}
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/add")}-->
|
||||||
|
<button data-open='{:url("$classuri/add")}' data-title="添加商品" class='layui-btn layui-btn-sm layui-btn-primary'>添加商品</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/forbid")}-->
|
||||||
|
<button data-update data-field='status' data-value='0' data-action='{:url("$classuri/forbid")}' class='layui-btn layui-btn-sm layui-btn-primary'>批量下架</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/resume")}-->
|
||||||
|
<button data-update data-field='status' data-value='1' data-action='{:url("$classuri/resume")}' class='layui-btn layui-btn-sm layui-btn-primary'>批量上架</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/del")}-->
|
||||||
|
<button data-update data-field='delete' data-action='{:url("$classuri/del")}' class='layui-btn layui-btn-sm layui-btn-primary'>批量删除</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
{/block}
|
||||||
|
|
||||||
|
{block name="content"}
|
||||||
|
|
||||||
|
<!-- 表单搜索 开始 -->
|
||||||
|
<form class="layui-form layui-form-pane form-search" action="{:request()->url()}" onsubmit="return false" method="get">
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<label class="layui-form-label">商品名称</label>
|
||||||
|
<div class="layui-input-inline">
|
||||||
|
<input name="goods_title" value="{$Think.get.goods_title}" placeholder="请输入商品名称" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--{if !empty($cates)}-->
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<label class="layui-form-label">商品品牌</label>
|
||||||
|
<div class="layui-input-inline">
|
||||||
|
<select name="brand_id" lay-search>
|
||||||
|
<option value="">商品品牌</option>
|
||||||
|
{foreach $brands as $brand}
|
||||||
|
<!--{if $Think.get.brand_id eq $brand.id}-->
|
||||||
|
<option selected="selected" value="{$brand.id}">{$brand.brand_title}</option>
|
||||||
|
<!--{else}-->
|
||||||
|
<option value="{$brand.id}">{$brand.brand_title}</option>
|
||||||
|
<!--{/if}-->
|
||||||
|
{/foreach}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if !empty($cates)}-->
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<label class="layui-form-label">商品分类</label>
|
||||||
|
<div class="layui-input-inline">
|
||||||
|
<select name="cate_id" lay-search>
|
||||||
|
<option value="">所有分类</option>
|
||||||
|
{foreach $cates as $cate}
|
||||||
|
<!--{if $Think.get.cate_id eq $cate.id}-->
|
||||||
|
<option selected="selected" value="{$cate.id}">{$cate.spl|raw}{$cate.cate_title}</option>
|
||||||
|
<!--{else}-->
|
||||||
|
<option value="{$cate.id}">{$cate.spl|raw}{$cate.cate_title}</option>
|
||||||
|
<!--{/if}-->
|
||||||
|
{/foreach}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<label class="layui-form-label">发布时间</label>
|
||||||
|
<div class="layui-input-inline">
|
||||||
|
<input name="create_at" id="create_at" value="{$Think.get.create_at}" placeholder="请选择发布时间" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<button class="layui-btn layui-btn-primary"><i class="layui-icon"></i> 搜 索</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
<!-- 表单搜索 结束 -->
|
||||||
|
|
||||||
|
<form onsubmit="return false;" data-auto="true" method="post">
|
||||||
|
<!--{if empty($list)}-->
|
||||||
|
<p class="help-block text-center well">没 有 记 录 哦!</p>
|
||||||
|
<!--{else}-->
|
||||||
|
<input type="hidden" value="resort" name="action">
|
||||||
|
<table class="layui-table notevent" lay-skin="line">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class='list-table-check-td'>
|
||||||
|
<input data-auto-none="none" data-check-target='.list-check-box' type='checkbox'>
|
||||||
|
</th>
|
||||||
|
<th class='list-table-sort-td'>
|
||||||
|
<button type="submit" class="layui-btn layui-btn-normal layui-btn-xs">排 序</button>
|
||||||
|
</th>
|
||||||
|
<th class="nowrap">品牌分类</th>
|
||||||
|
<th class="padding-none">
|
||||||
|
<table class="think-inner-table layui-table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<td>商品信息</td>
|
||||||
|
<td class="text-right nowrap">售价 ( 标价 ) / 库存 ( 剩余, 已售 )</td>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
</th>
|
||||||
|
<th class="text-left">添加时间 / 状态</th>
|
||||||
|
<th class='text-center'></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{foreach $list as $key=>$vo}
|
||||||
|
<tr>
|
||||||
|
<td class='list-table-check-td text-top'>
|
||||||
|
<input class="list-check-box" value='{$vo.id}' type='checkbox'>
|
||||||
|
</td>
|
||||||
|
<td class='list-table-sort-td text-top'>
|
||||||
|
<input name="_{$vo.id}" value="{$vo.sort}" class="list-sort-input">
|
||||||
|
</td>
|
||||||
|
<td class="text-left nowrap text-top">
|
||||||
|
品牌:{$vo.brand.brand_title|default='<span class="color-desc">未配置品牌</span>'|raw}<br>
|
||||||
|
分类:{if empty($vo.cate)}<span class="color-desc">未配置分类</span>{else}
|
||||||
|
{foreach $vo.cate as $k=>$cate}{$cate.cate_title}
|
||||||
|
{if $k+1 < count($vo.cate)}<span class="layui-icon font-s12"></span>{/if}
|
||||||
|
{/foreach}
|
||||||
|
{/if}
|
||||||
|
</td>
|
||||||
|
<td class="text-left nowrap text-top" style="padding:2px">
|
||||||
|
<table class="think-inner-table layui-table notevent">
|
||||||
|
<colgroup>
|
||||||
|
<col width="60%">
|
||||||
|
</colgroup>
|
||||||
|
{foreach $vo.spec as $spec}
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
[{$spec.goods_id}] {$spec.goods_title|default=''|raw}
|
||||||
|
<span class="layui-badge layui-bg-gray">{$spec.goods_spec_alias|raw}</span>
|
||||||
|
</td>
|
||||||
|
<td class="text-right nowrap">
|
||||||
|
<span class="layui-badge layui-bg-gray">售 {$spec.selling_price} ( 市 {$spec.market_price} ) </span>
|
||||||
|
<span class="layui-badge layui-bg-gray">存 {$spec.goods_stock} ( 剩 {$spec.goods_stock-$spec.goods_sale}, 售 {$spec.goods_sale} ) </span>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{/foreach}
|
||||||
|
</table>
|
||||||
|
</td>
|
||||||
|
<td class='text-left nowrap text-top'>
|
||||||
|
{$vo.create_at|format_datetime|str_replace=' ','<br>',###|raw}
|
||||||
|
{if $vo.status eq '0'}<span class="color-red margin-left-10">已下架</span>{elseif $vo.status eq '1'}<span class="color-green margin-left-10">销售中</span>{/if}
|
||||||
|
</td>
|
||||||
|
|
||||||
|
<td class='text-center nowrap text-top'>
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/edit")}-->
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-open='{:url("$classuri/edit")}?id={$vo.id}'>编辑</a>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if $vo.status eq 1 and auth("$classuri/forbid")}-->
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='status' data-value='0' data-action='{:url("$classuri/forbid")}'>下架</a>
|
||||||
|
<!--{elseif auth("$classuri/resume")}-->
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='status' data-value='1' data-action='{:url("$classuri/resume")}'>上架</a>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/del")}-->
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='delete' data-action='{:url("$classuri/del")}'>删除</a>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{/foreach}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
{if isset($page)}<p>{$page|raw}</p>{/if}
|
||||||
|
<!--{/if}-->
|
||||||
|
</form>
|
||||||
|
<script>
|
||||||
|
(function () {
|
||||||
|
window.form.render();
|
||||||
|
window.laydate.render({range: true, elem: '#create_at'});
|
||||||
|
})();
|
||||||
|
</script>
|
||||||
|
{/block}
|
82
application/store/view/goods_brand/form.html
Normal file
82
application/store/view/goods_brand/form.html
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
{extend name='admin@public/content'}
|
||||||
|
|
||||||
|
{block name="content"}
|
||||||
|
<form onsubmit="return false;" action="{:request()->url()}" data-auto="true" method="post" class='form-horizontal layui-form padding-top-20'>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">品牌名称</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<input autofocus name="brand_title" value='{$vo.brand_title|default=""}' required="required" title="请输入品牌名称" placeholder="请输入品牌名称" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label label-required">品牌图片</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<table class="layui-table background-item margin-none" lay-size="sm" lay-skin="nob">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<td>品牌LOGO</td>
|
||||||
|
<td>品牌图片</td>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td class="text-top" style="width:100px">
|
||||||
|
<input type="hidden" name="brand_logo" value="{$vo.brand_logo|default=''}">
|
||||||
|
<script>$('[name=brand_logo]').uploadOneImage()</script>
|
||||||
|
</td>
|
||||||
|
<td class="text-top">
|
||||||
|
<input type="hidden" name="brand_cover" value="{$vo.brand_cover|default=''}">
|
||||||
|
<script>$('[name=brand_cover]').uploadOneImage()</script>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">品牌描述</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<textarea placeholder="请输入品牌描述" title="请输入品牌描述" class="layui-textarea" name="brand_desc">{$vo.brand_desc|default=""}</textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-2 control-label">品牌内容</label>
|
||||||
|
<div class='col-sm-8'>
|
||||||
|
<textarea name="brand_detail">{$vo.brand_detail|default=''|raw}</textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="hr-line-dashed"></div>
|
||||||
|
|
||||||
|
<div class="col-sm-7 col-sm-offset-2">
|
||||||
|
<div class="layui-form-item text-center">
|
||||||
|
{if !empty($vo.id)}<input type="hidden" name="id" value="{$vo.id}">{/if}
|
||||||
|
<button class="layui-btn" type="submit">保存配置</button>
|
||||||
|
<button class="layui-btn layui-btn-danger" type='button' onclick="window.history.back()">取消编辑</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script>window.form.render();</script>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
/*! 实例富文本编辑器 */
|
||||||
|
require(['ckeditor'], function () {
|
||||||
|
window.createEditor('[name="brand_detail"]', {height: 500});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
<style>
|
||||||
|
.background-item {
|
||||||
|
padding: 15px;
|
||||||
|
background: #efefef;
|
||||||
|
}
|
||||||
|
|
||||||
|
.background-item thead tr {
|
||||||
|
background: #e0e0e0
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</form>
|
||||||
|
{/block}
|
108
application/store/view/goods_brand/index.html
Normal file
108
application/store/view/goods_brand/index.html
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
{extend name='admin@public/content'}
|
||||||
|
|
||||||
|
{block name="button"}
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/add")}-->
|
||||||
|
<button data-open='{:url("$classuri/add")}' data-title="添加品牌" class='layui-btn layui-btn-sm layui-btn-primary'>添加品牌</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/del")}-->
|
||||||
|
<button data-update="" data-field='delete' data-action='{:url("$classuri/del")}' class='layui-btn layui-btn-sm layui-btn-primary'>删除品牌</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
{/block}
|
||||||
|
|
||||||
|
{block name="content"}
|
||||||
|
|
||||||
|
<!-- 表单搜索 开始 -->
|
||||||
|
<form class="layui-form layui-form-pane form-search" action="{:request()->url()}" onsubmit="return false" method="get">
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<label class="layui-form-label">品牌名称</label>
|
||||||
|
<div class="layui-input-inline">
|
||||||
|
<input name="brand_title" value="{$Think.get.brand_title}" placeholder="请输入品牌名称" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<label class="layui-form-label">添加时间</label>
|
||||||
|
<div class="layui-input-inline">
|
||||||
|
<input name="create_at" id="create_at" value="{$Think.get.create_at}" placeholder="请选择添加时间" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<button class="layui-btn layui-btn-primary"><i class="layui-icon"></i> 搜 索</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
window.laydate.render({range: true, elem: '#create_at'});
|
||||||
|
window.form.render();
|
||||||
|
</script>
|
||||||
|
<!-- 表单搜索 结束 -->
|
||||||
|
|
||||||
|
<form onsubmit="return false;" data-auto="true" method="post">
|
||||||
|
{if empty($list)}
|
||||||
|
<p class="help-block text-center well">没 有 记 录 哦!</p>
|
||||||
|
{else}
|
||||||
|
<input type="hidden" value="resort" name="action"/>
|
||||||
|
<table class="layui-table" lay-skin="line">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class='list-table-check-td'>
|
||||||
|
<input data-auto-none="none" data-check-target='.list-check-box' type='checkbox'/>
|
||||||
|
</th>
|
||||||
|
<th class='list-table-sort-td'>
|
||||||
|
<button type="submit" class="layui-btn layui-btn-normal layui-btn-xs">排 序</button>
|
||||||
|
</th>
|
||||||
|
<th class='text-left nowrap'>商品品牌</th>
|
||||||
|
<th class='text-left nowrap'>添加时间</th>
|
||||||
|
<th class='text-left nowrap'>品牌状态</th>
|
||||||
|
<th class='text-left'></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{foreach $list as $key=>$vo}
|
||||||
|
<tr>
|
||||||
|
<td class='list-table-check-td'>
|
||||||
|
<input class="list-check-box" value='{$vo.id}' type='checkbox'/>
|
||||||
|
</td>
|
||||||
|
<td class='list-table-sort-td'>
|
||||||
|
<input name="_{$vo.id}" value="{$vo.sort}" class="list-sort-input"/>
|
||||||
|
</td>
|
||||||
|
<td class='text-left nowrap'>{$vo.brand_title}</td>
|
||||||
|
<td class='text-left nowrap'>{$vo.create_at|format_datetime}</td>
|
||||||
|
<td class='text-left nowrap'>
|
||||||
|
{if $vo.status eq 0}<span class="color-red">已禁用</span>{elseif $vo.status eq 1}<span class="color-green">使用中</span>{/if}
|
||||||
|
</td>
|
||||||
|
<td class='text-left nowrap'>
|
||||||
|
|
||||||
|
{if auth("$classuri/edit")}
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-title="编辑品牌" data-open='{:url("$classuri/edit")}?id={$vo.id}'>编辑</a>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
{if $vo.status eq 1 and auth("$classuri/forbid")}
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='status' data-value='0' data-action='{:url("$classuri/forbid")}'>禁用</a>
|
||||||
|
{elseif auth("$classuri/resume")}
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='status' data-value='1' data-action='{:url("$classuri/resume")}'>启用</a>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
{if auth("$classuri/del")}
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='delete' data-action='{:url("$classuri/del")}'>删除</a>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{/foreach}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
{if isset($page)}<p>{$page|raw}</p>{/if}
|
||||||
|
{/if}
|
||||||
|
</form>
|
||||||
|
{/block}
|
39
application/store/view/goods_cate/form.html
Normal file
39
application/store/view/goods_cate/form.html
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<form class="layui-form layui-box modal-form-box" action="{:request()->url()}" data-auto="true" method="post">
|
||||||
|
|
||||||
|
<div class="layui-form-item">
|
||||||
|
<label class="layui-form-label">商品主分类</label>
|
||||||
|
<div class="layui-input-block">
|
||||||
|
<select name='pid' class='layui-select full-width block'>
|
||||||
|
<!--{foreach cates as $cate}-->
|
||||||
|
<!--{eq name='cate.id' value='$vo.pid|default=0'}-->
|
||||||
|
<option selected value='{$cate.id}'>{$cate.spl|raw}{$cate.cate_title|default=''}</option>
|
||||||
|
<!--{else}-->
|
||||||
|
<option value='{$cate.id}'>{$cate.spl|raw}{$cate.cate_title}</option>
|
||||||
|
<!--{/eq}-->
|
||||||
|
<!--{/foreach}-->
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item">
|
||||||
|
<label class="layui-form-label">商品分类</label>
|
||||||
|
<div class="layui-input-block">
|
||||||
|
<input autofocus name="cate_title" value='{$vo.cate_title|default=""}' required title="请输入商品分类" placeholder="请输入商品分类" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item">
|
||||||
|
<label class="layui-form-label">分类描述</label>
|
||||||
|
<div class="layui-input-block">
|
||||||
|
<textarea placeholder="请输入分类描述" title="请输入分类描述" class="layui-textarea" name="cate_desc">{$vo.cate_desc|default=""}</textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="hr-line-dashed"></div>
|
||||||
|
|
||||||
|
<div class="layui-form-item text-center">
|
||||||
|
{if isset($vo['id'])}<input type='hidden' value='{$vo.id}' name='id'/>{/if}
|
||||||
|
<button class="layui-btn" type='submit'>保存数据</button>
|
||||||
|
<button class="layui-btn layui-btn-danger" type='button' data-confirm="确定要取消编辑吗?" data-close>取消编辑</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
83
application/store/view/goods_cate/index.html
Normal file
83
application/store/view/goods_cate/index.html
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
{extend name='admin@public/content'}
|
||||||
|
|
||||||
|
{block name="button"}
|
||||||
|
<!--{if auth("$classuri/add")}-->
|
||||||
|
<button data-modal='{:url("@$classuri/add")}' data-title="添加分类" class='layui-btn layui-btn-sm layui-btn-primary'>添加分类</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
<!--{if auth("$classuri/del")}-->
|
||||||
|
<button data-update="" data-field='delete' data-action='{:url("@$classuri/del")}' class='layui-btn layui-btn-sm layui-btn-primary'>删除分类</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
{/block}
|
||||||
|
|
||||||
|
{block name="content"}
|
||||||
|
<form onsubmit="return false;" data-auto="true" method="post">
|
||||||
|
<!--{if empty($list)}-->
|
||||||
|
<p class="help-block text-center well">没 有 记 录 哦!</p>
|
||||||
|
<!--{else}-->
|
||||||
|
<input type="hidden" value="resort" name="action">
|
||||||
|
<table class="layui-table" lay-skin="line">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class='list-table-check-td'>
|
||||||
|
<input data-auto-none="none" data-check-target='.list-check-box' type='checkbox'>
|
||||||
|
</th>
|
||||||
|
<th class='list-table-sort-td'>
|
||||||
|
<button type="submit" class="layui-btn layui-btn-normal layui-btn-xs">排 序</button>
|
||||||
|
</th>
|
||||||
|
<th class='text-left nowrap'>商品分类</th>
|
||||||
|
<th class='text-left nowrap'>分类描述</th>
|
||||||
|
<th class='text-left nowrap'>添加时间</th>
|
||||||
|
<th class='text-center nowrap'>分类状态</th>
|
||||||
|
<th class='text-center'></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{foreach $list as $key=>$vo}
|
||||||
|
<tr>
|
||||||
|
<td class='list-table-check-td'>
|
||||||
|
<input class="list-check-box" value='{$vo.ids}' type='checkbox'>
|
||||||
|
</td>
|
||||||
|
<td class='list-table-sort-td'>
|
||||||
|
<input name="_{$vo.id}" value="{$vo.sort}" class="list-sort-input">
|
||||||
|
</td>
|
||||||
|
<td class='text-left nowrap'>
|
||||||
|
<span class="color-desc">{$vo.spl|raw}</span> {$vo.cate_title}
|
||||||
|
</td>
|
||||||
|
<td class='text-left nowrap'>
|
||||||
|
{$vo.cate_desc|default='<span class="color-desc">未设置分类描述</span>'|raw}
|
||||||
|
</td>
|
||||||
|
<td class='text-left nowrap'>
|
||||||
|
{$vo.create_at|format_datetime}
|
||||||
|
</td>
|
||||||
|
<td class='text-center nowrap'>
|
||||||
|
{if $vo.status eq 0}<span>已禁用</span>{elseif $vo.status eq 1}<span class="color-green">使用中</span>{/if}
|
||||||
|
</td>
|
||||||
|
<td class='text-center nowrap'>
|
||||||
|
|
||||||
|
{if auth("$classuri/edit")}
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-title="编辑分类" data-modal='{:url("@$classuri/edit")}?id={$vo.id}'>编辑</a>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
{if $vo.status eq 1 and auth("$classuri/forbid")}
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.ids}" data-field='status' data-value='0' data-action='{:url("$classuri/forbid")}'>禁用</a>
|
||||||
|
{elseif auth("$classuri/resume")}
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.ids}" data-field='status' data-value='1' data-action='{:url("$classuri/resume")}'>启用</a>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
{if auth("$classuri/del")}
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.ids}" data-field='delete' data-action='{:url("$classuri/del")}'>删除</a>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{/foreach}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
{if isset($page)}<p>{$page|raw}</p>{/if}
|
||||||
|
<!--{/if}-->
|
||||||
|
</form>
|
||||||
|
{/block}
|
200
application/store/view/goods_spec/form.html
Normal file
200
application/store/view/goods_spec/form.html
Normal file
@ -0,0 +1,200 @@
|
|||||||
|
<form class="layui-form layui-box" style='padding:25px 30px 20px 0' method="post" id="spec-form">
|
||||||
|
|
||||||
|
<div class="layui-form-item">
|
||||||
|
<label class="layui-form-label">规格名称</label>
|
||||||
|
<div class="layui-input-block">
|
||||||
|
<input name="spec_title" ng-model="spec_title" required title="请输入规格名称" placeholder="请输入规格名称" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item">
|
||||||
|
<label class="layui-form-label label-required">规格参数</label>
|
||||||
|
<div class="layui-input-block">
|
||||||
|
<textarea class="hide" ng-model="spec_param"></textarea>
|
||||||
|
<div class="param-table-list">
|
||||||
|
<table class="layui-table margin-none">
|
||||||
|
<tbody class="param-table-list">
|
||||||
|
<tr ng-repeat="x in paramList" class="transition">
|
||||||
|
<td class="param-input-td one nowrap">
|
||||||
|
<input required placeholder="分组" title="请输入属性分组" ng-model="x.name" class="layui-input">
|
||||||
|
</td>
|
||||||
|
<td class="param-input-td two nowrap">
|
||||||
|
<input required placeholder="名称" title="请输入属性名称" ng-model="x.value" class="layui-input">
|
||||||
|
</td>
|
||||||
|
<td class="param-input-td thr nowrap">
|
||||||
|
<a ng-if="$index<1" class="color-desc">删除</a>
|
||||||
|
<a ng-if="$index>0" ng-click="delParam($index)">删除</a>
|
||||||
|
<a ng-if="$index<1" class="color-desc">上移</a>
|
||||||
|
<a ng-if="$index>0" ng-click="moveToUp($index)">上移</a>
|
||||||
|
<a ng-if="$index+1<paramList.length" ng-click="moveToDn($index)">下移</a>
|
||||||
|
<a ng-if="$index+1>=paramList.length" class="color-desc">下移</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<table class="layui-table">
|
||||||
|
<tr>
|
||||||
|
<td class="text-center notselect padding-none border-none">
|
||||||
|
<button type="button" class="layui-btn full-width layui-btn-primary" ng-click="addParam()">添加属性</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
<p class="help-block">设置多个内容值时请使用空格键或英文逗号隔开。</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item">
|
||||||
|
<label class="layui-form-label">规格描述</label>
|
||||||
|
<div class="layui-input-block">
|
||||||
|
<textarea placeholder="请输入规格描述" title="请输入规格描述" class="layui-textarea" ng-model="spec_desc" name="spec_desc"></textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="hr-line-dashed"></div>
|
||||||
|
|
||||||
|
<div class="layui-form-item text-center">
|
||||||
|
{if isset($vo['id'])}<input type='hidden' value='{$vo.id}' name='id'/>{/if}
|
||||||
|
<button class="layui-btn" type='submit'>保存数据</button>
|
||||||
|
<button class="layui-btn layui-btn-danger" type='button' data-confirm="确定要取消编辑吗?" data-close>取消编辑</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
require(['angular'], function () {
|
||||||
|
// 应用创建与初始化
|
||||||
|
var app = angular.module("SpecForm", []).run(callback);
|
||||||
|
angular.bootstrap(document.getElementById('spec-form'), [app.name]);
|
||||||
|
|
||||||
|
// 应用事件处理
|
||||||
|
function callback($rootScope) {
|
||||||
|
// 属性参数
|
||||||
|
$rootScope.paramList = filterParamList(JSON.parse('{$vo.spec_param|default="[]"|raw}') || []);
|
||||||
|
$rootScope.spec_title = '{$vo.spec_title|default=""}';
|
||||||
|
$rootScope.spec_desc = '{$vo.sepc_desc|default=""}';
|
||||||
|
|
||||||
|
// 删除菜单
|
||||||
|
$rootScope.delParam = function (x) {
|
||||||
|
var dialogIndex = $.msg.confirm('确定移除参数吗?', function () {
|
||||||
|
$rootScope.$apply(function () {
|
||||||
|
var tmp = [];
|
||||||
|
for (var i in $rootScope.paramList) {
|
||||||
|
(parseInt(i) !== parseInt(x)) && tmp.push($rootScope.paramList[i]);
|
||||||
|
}
|
||||||
|
$rootScope.paramList = filterParamList(tmp);
|
||||||
|
$.msg.close(dialogIndex);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// 添加参数
|
||||||
|
$rootScope.addParam = function () {
|
||||||
|
$rootScope.paramList.push({name: '', value: ''});
|
||||||
|
setTimeout(function () {
|
||||||
|
$('.param-table-list').scrollTop('10000')
|
||||||
|
}, 10);
|
||||||
|
};
|
||||||
|
|
||||||
|
// 属性参数下移
|
||||||
|
$rootScope.moveToDn = function (index) {
|
||||||
|
var tmp = [], cur = $rootScope.paramList[index];
|
||||||
|
if (index > $rootScope.paramList.length - 2) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
for (var i in $rootScope.paramList) {
|
||||||
|
(parseInt(i) !== parseInt(index)) && tmp.push($rootScope.paramList[i]);
|
||||||
|
(parseInt(i) === parseInt(index) + 1) && tmp.push(cur);
|
||||||
|
}
|
||||||
|
$rootScope.paramList = tmp;
|
||||||
|
};
|
||||||
|
|
||||||
|
// 属性参数上移
|
||||||
|
$rootScope.moveToUp = function (index) {
|
||||||
|
var tmp = [], cur = $rootScope.paramList[index];
|
||||||
|
if (index < 1) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
for (var i in $rootScope.paramList) {
|
||||||
|
(parseInt(i) === parseInt(index) - 1) && tmp.push(cur);
|
||||||
|
(parseInt(i) !== parseInt(index)) && tmp.push($rootScope.paramList[i]);
|
||||||
|
}
|
||||||
|
$rootScope.paramList = tmp;
|
||||||
|
};
|
||||||
|
|
||||||
|
// 表单验证
|
||||||
|
$('#spec-form').vali(function (ret) {
|
||||||
|
try {
|
||||||
|
var spect_param = [];
|
||||||
|
for (var i in $rootScope.paramList) {
|
||||||
|
spect_param.push({
|
||||||
|
name: $rootScope.paramList[i].name,
|
||||||
|
value: $rootScope.paramList[i].value
|
||||||
|
});
|
||||||
|
}
|
||||||
|
var data = {
|
||||||
|
spec_title: $rootScope.spec_title || '',
|
||||||
|
spec_desc: $rootScope.spec_desc || '',
|
||||||
|
spec_param: JSON.stringify(spect_param)
|
||||||
|
};
|
||||||
|
var id = '{$vo.id|default=0}';
|
||||||
|
id > 0 && (data.id = id);
|
||||||
|
$.form.load('{:request()->url()}', data, 'post');
|
||||||
|
} catch ($e) {
|
||||||
|
console.log($e);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 过滤规格参数列表
|
||||||
|
function filterParamList(list) {
|
||||||
|
return list.length < 1 ? [{name: '', value: ''}] : list;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.param-table-list {
|
||||||
|
overflow: auto;
|
||||||
|
max-height: 200px;
|
||||||
|
position: relative;
|
||||||
|
overflow-y: scroll;
|
||||||
|
}
|
||||||
|
|
||||||
|
.param-input-td {
|
||||||
|
position: relative;
|
||||||
|
padding: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.param-input-td.one {
|
||||||
|
width: 30%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.param-input-td.thr {
|
||||||
|
width: 20%;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.param-input-td.one:before {
|
||||||
|
content: '分组'
|
||||||
|
}
|
||||||
|
|
||||||
|
.param-input-td.two:before {
|
||||||
|
content: '规格'
|
||||||
|
}
|
||||||
|
|
||||||
|
.param-input-td:before {
|
||||||
|
margin: 4px;
|
||||||
|
width: 40px;
|
||||||
|
height: 30px;
|
||||||
|
line-height: 30px;
|
||||||
|
text-align: center;
|
||||||
|
position: absolute;
|
||||||
|
background: #e2e2e2;
|
||||||
|
}
|
||||||
|
|
||||||
|
.param-input-td input {
|
||||||
|
padding-left: 50px;
|
||||||
|
border: none !important;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</form>
|
116
application/store/view/goods_spec/index.html
Normal file
116
application/store/view/goods_spec/index.html
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
{extend name='admin@public/content'}
|
||||||
|
|
||||||
|
{block name="button"}
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/add")}-->
|
||||||
|
<button data-modal='{:url("$classuri/add")}' data-title="添加规格" class='layui-btn layui-btn-sm layui-btn-primary'>添加规格</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/del")}-->
|
||||||
|
<button data-update data-field='delete' data-action='{:url("$classuri/del")}' class='layui-btn layui-btn-sm layui-btn-primary'>删除规格</button>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
{/block}
|
||||||
|
|
||||||
|
{block name="content"}
|
||||||
|
|
||||||
|
<!-- 表单搜索 开始 -->
|
||||||
|
<form class="layui-form layui-form-pane form-search" action="{:request()->url()}" onsubmit="return false" method="get">
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<label class="layui-form-label">规格分组</label>
|
||||||
|
<div class="layui-input-inline">
|
||||||
|
<input name="spec_title" value="{$Think.get.spec_title|default=''}" placeholder="请输入规格分组" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<label class="layui-form-label">添加时间</label>
|
||||||
|
<div class="layui-input-inline">
|
||||||
|
<input name="date" id="range-date" value="{$Think.get.date}" placeholder="请选择添加时间" class="layui-input">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="layui-form-item layui-inline">
|
||||||
|
<button class="layui-btn layui-btn-primary"><i class="layui-icon"></i> 搜 索</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
window.laydate.render({range: true, elem: '#range-date'});
|
||||||
|
window.form.render();
|
||||||
|
</script>
|
||||||
|
<!-- 表单搜索 结束 -->
|
||||||
|
|
||||||
|
<form onsubmit="return false;" data-auto="true" method="post">
|
||||||
|
{if empty($list)}
|
||||||
|
<p class="help-block text-center well">没 有 记 录 哦!</p>
|
||||||
|
{else}
|
||||||
|
<input type="hidden" value="resort" name="action"/>
|
||||||
|
<table class="layui-table" lay-skin="line" lay-size="sm">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class='list-table-check-td'>
|
||||||
|
<input data-auto-none="none" data-check-target='.list-check-box' type='checkbox'/>
|
||||||
|
</th>
|
||||||
|
<th class='list-table-sort-td'>
|
||||||
|
<button type="submit" class="layui-btn layui-btn-normal layui-btn-xs">排 序</button>
|
||||||
|
</th>
|
||||||
|
<th class='text-left nowrap'>规格分组</th>
|
||||||
|
<th class='text-left nowrap'>规格内容</th>
|
||||||
|
<th class='text-left nowrap'>添加时间</th>
|
||||||
|
<th class='text-left nowrap'>标签状态</th>
|
||||||
|
<th class='text-left'></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{foreach $list as $key=>$vo}
|
||||||
|
<tr>
|
||||||
|
<td class='list-table-check-td text-top'>
|
||||||
|
<input class="list-check-box" value='{$vo.id}' type='checkbox'/>
|
||||||
|
</td>
|
||||||
|
<td class='list-table-sort-td text-top'>
|
||||||
|
<input name="_{$vo.id}" value="{$vo.sort}" class="list-sort-input"/>
|
||||||
|
</td>
|
||||||
|
<td class='text-left text-top nowrap'>{$vo.spec_title}</td>
|
||||||
|
<td class='text-left text-top nowrap'>
|
||||||
|
{foreach $vo.spec_param as $param}
|
||||||
|
<p><b>{$param.name}</b> : {$param.value}</p>
|
||||||
|
{/foreach}
|
||||||
|
</td>
|
||||||
|
<td class='text-left text-top nowrap'>
|
||||||
|
{$vo.create_at|format_datetime|raw}
|
||||||
|
</td>
|
||||||
|
<td class='text-left text-top nowrap'>
|
||||||
|
{if $vo.status eq 0}<span class="color-red">已禁用</span>{elseif $vo.status eq 1}<span class="color-green">使用中</span>{/if}
|
||||||
|
</td>
|
||||||
|
<td class='text-left text-top nowrap'>
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/edit")}-->
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-title="编辑规格" data-modal='{:url("$classuri/edit")}?id={$vo.id}'>编辑</a>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if $vo.status eq 1 and auth("$classuri/forbid")}-->
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='status' data-value='0' data-action='{:url("$classuri/forbid")}'>禁用</a>
|
||||||
|
<!--{elseif auth("$classuri/resume")}-->
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='status' data-value='1' data-action='{:url("$classuri/resume")}'>启用</a>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
<!--{if auth("$classuri/del")}-->
|
||||||
|
<span class="text-explode">|</span>
|
||||||
|
<a data-update="{$vo.id}" data-field='delete' data-action='{:url("$classuri/del")}'>删除</a>
|
||||||
|
<!--{/if}-->
|
||||||
|
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{/foreach}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
{if isset($page)}<p>{$page|raw}</p>{/if}
|
||||||
|
{/if}
|
||||||
|
</form>
|
||||||
|
{/block}
|
@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
namespace think;
|
namespace think;
|
||||||
|
|
||||||
|
use service\NodeService;
|
||||||
use think\exception\HttpResponseException;
|
use think\exception\HttpResponseException;
|
||||||
|
|
||||||
return [
|
return [
|
||||||
@ -21,7 +22,7 @@ return [
|
|||||||
'action_begin' => function () {
|
'action_begin' => function () {
|
||||||
$request = app('request');
|
$request = app('request');
|
||||||
list($module, $controller, $action) = [$request->module(), $request->controller(), $request->action()];
|
list($module, $controller, $action) = [$request->module(), $request->controller(), $request->action()];
|
||||||
$node = strtolower("{$module}/{$controller}/{$action}");
|
$node = NodeService::parseNodeStr("{$module}/{$controller}/{$action}");
|
||||||
$info = Db::name('SystemNode')->cache(true, 30)->where(['node' => $node])->find();
|
$info = Db::name('SystemNode')->cache(true, 30)->where(['node' => $node])->find();
|
||||||
$access = ['is_menu' => intval(!empty($info['is_menu'])), 'is_auth' => intval(!empty($info['is_auth'])), 'is_login' => empty($info['is_auth']) ? intval(!empty($info['is_login'])) : 1];
|
$access = ['is_menu' => intval(!empty($info['is_menu'])), 'is_auth' => intval(!empty($info['is_auth'])), 'is_login' => empty($info['is_auth']) ? intval(!empty($info['is_login'])) : 1];
|
||||||
// 登录状态检查
|
// 登录状态检查
|
||||||
@ -34,6 +35,6 @@ return [
|
|||||||
throw new HttpResponseException(json(['code' => 0, 'msg' => '抱歉,您没有访问该模块的权限!']));
|
throw new HttpResponseException(json(['code' => 0, 'msg' => '抱歉,您没有访问该模块的权限!']));
|
||||||
}
|
}
|
||||||
// 模板常量声明
|
// 模板常量声明
|
||||||
app('view')->init(config('template.'))->assign(['classuri' => "{$module}/{$controller}"]);
|
app('view')->init(config('template.'))->assign(['classuri' => NodeService::parseNodeStr("{$module}/{$controller}")]);
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
@ -26,7 +26,7 @@ use think\Db;
|
|||||||
* @author Anyon <zoujingli@qq.com>
|
* @author Anyon <zoujingli@qq.com>
|
||||||
* @date 2017/03/27 14:43
|
* @date 2017/03/27 14:43
|
||||||
*/
|
*/
|
||||||
class Block extends BasicAdmin
|
class FansBlock extends BasicAdmin
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
@ -73,7 +73,7 @@ class NodeService
|
|||||||
public static function checkAuthNode($node)
|
public static function checkAuthNode($node)
|
||||||
{
|
{
|
||||||
list($module, $controller, $action) = explode('/', str_replace(['?', '=', '&'], '/', $node . '///'));
|
list($module, $controller, $action) = explode('/', str_replace(['?', '=', '&'], '/', $node . '///'));
|
||||||
$currentNode = strtolower(trim("{$module}/{$controller}/{$action}", '/'));
|
$currentNode = self::parseNodeStr("{$module}/{$controller}/{$action}");
|
||||||
if (session('user.username') === 'admin' || stripos($node, 'admin/index') === 0) {
|
if (session('user.username') === 'admin' || stripos($node, 'admin/index') === 0) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -129,13 +129,27 @@ class NodeService
|
|||||||
}
|
}
|
||||||
foreach (get_class_methods($className) as $funcName) {
|
foreach (get_class_methods($className) as $funcName) {
|
||||||
if (strpos($funcName, '_') !== 0 && $funcName !== 'initialize') {
|
if (strpos($funcName, '_') !== 0 && $funcName !== 'initialize') {
|
||||||
$nodes[] = strtolower("{$matches[1]}/{$matches[2]}/{$funcName}");
|
$nodes[] = self::parseNodeStr("{$matches[1]}/{$matches[2]}/{$funcName}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return $nodes;
|
return $nodes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 驼峰转下划线规则
|
||||||
|
* @param string $node
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function parseNodeStr($node)
|
||||||
|
{
|
||||||
|
$tmp = [];
|
||||||
|
foreach (explode('/', $node) as $name) {
|
||||||
|
$tmp[] = strtolower(trim(preg_replace("/[A-Z]/", "_\\0", $name), "_"));
|
||||||
|
}
|
||||||
|
return trim(join('/', $tmp), '/');
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取所有PHP文件
|
* 获取所有PHP文件
|
||||||
* @param string $dirPath 目录
|
* @param string $dirPath 目录
|
||||||
|
@ -12,9 +12,17 @@
|
|||||||
// | github开源项目:https://github.com/zoujingli/ThinkAdmin
|
// | github开源项目:https://github.com/zoujingli/ThinkAdmin
|
||||||
// +----------------------------------------------------------------------
|
// +----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use think\facade\App;
|
||||||
use think\facade\Route;
|
use think\facade\Route;
|
||||||
|
use think\Request;
|
||||||
|
|
||||||
|
/* 注册微信端路由支持 */
|
||||||
|
Route::rule('wx-<controller>-<action>', function (Request $request, $controller, $action) {
|
||||||
|
$params = explode('-', $request->pathinfo());
|
||||||
|
[array_shift($params), array_shift($params), array_shift($params)];
|
||||||
|
return App::action("store/wechat.{$controller}/{$action}", $params);
|
||||||
|
});
|
||||||
|
|
||||||
/* 去除下面注释可启用禁用功能 */
|
|
||||||
return [];
|
return [];
|
||||||
|
|
||||||
/* 测试环境禁止操作路由绑定 */
|
/* 测试环境禁止操作路由绑定 */
|
||||||
|
2
vendor/autoload.php
vendored
2
vendor/autoload.php
vendored
@ -4,4 +4,4 @@
|
|||||||
|
|
||||||
require_once __DIR__ . '/composer/autoload_real.php';
|
require_once __DIR__ . '/composer/autoload_real.php';
|
||||||
|
|
||||||
return ComposerAutoloaderInitfbb01b03828af73cff04bee933bd6172::getLoader();
|
return ComposerAutoloaderInit9e628bddedd690e20fe8b6cad9d0489b::getLoader();
|
||||||
|
1
vendor/composer/autoload_classmap.php
vendored
1
vendor/composer/autoload_classmap.php
vendored
@ -163,6 +163,7 @@ return array(
|
|||||||
'app\\index\\controller\\Index' => $baseDir . '/application/index/controller/Index.php',
|
'app\\index\\controller\\Index' => $baseDir . '/application/index/controller/Index.php',
|
||||||
'app\\store\\controller\\Express' => $baseDir . '/application/store/controller/Express.php',
|
'app\\store\\controller\\Express' => $baseDir . '/application/store/controller/Express.php',
|
||||||
'app\\store\\controller\\Order' => $baseDir . '/application/store/controller/Order.php',
|
'app\\store\\controller\\Order' => $baseDir . '/application/store/controller/Order.php',
|
||||||
|
'app\\store\\controller\\wechat\\Index' => $baseDir . '/application/store/controller/wechat/Index.php',
|
||||||
'app\\store\\service\\OrderService' => $baseDir . '/application/store/service/OrderService.php',
|
'app\\store\\service\\OrderService' => $baseDir . '/application/store/service/OrderService.php',
|
||||||
'app\\wechat\\controller\\Block' => $baseDir . '/application/wechat/controller/Block.php',
|
'app\\wechat\\controller\\Block' => $baseDir . '/application/wechat/controller/Block.php',
|
||||||
'app\\wechat\\controller\\Config' => $baseDir . '/application/wechat/controller/Config.php',
|
'app\\wechat\\controller\\Config' => $baseDir . '/application/wechat/controller/Config.php',
|
||||||
|
14
vendor/composer/autoload_real.php
vendored
14
vendor/composer/autoload_real.php
vendored
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
// autoload_real.php @generated by Composer
|
// autoload_real.php @generated by Composer
|
||||||
|
|
||||||
class ComposerAutoloaderInitfbb01b03828af73cff04bee933bd6172
|
class ComposerAutoloaderInit9e628bddedd690e20fe8b6cad9d0489b
|
||||||
{
|
{
|
||||||
private static $loader;
|
private static $loader;
|
||||||
|
|
||||||
@ -19,15 +19,15 @@ class ComposerAutoloaderInitfbb01b03828af73cff04bee933bd6172
|
|||||||
return self::$loader;
|
return self::$loader;
|
||||||
}
|
}
|
||||||
|
|
||||||
spl_autoload_register(array('ComposerAutoloaderInitfbb01b03828af73cff04bee933bd6172', 'loadClassLoader'), true, true);
|
spl_autoload_register(array('ComposerAutoloaderInit9e628bddedd690e20fe8b6cad9d0489b', 'loadClassLoader'), true, true);
|
||||||
self::$loader = $loader = new \Composer\Autoload\ClassLoader();
|
self::$loader = $loader = new \Composer\Autoload\ClassLoader();
|
||||||
spl_autoload_unregister(array('ComposerAutoloaderInitfbb01b03828af73cff04bee933bd6172', 'loadClassLoader'));
|
spl_autoload_unregister(array('ComposerAutoloaderInit9e628bddedd690e20fe8b6cad9d0489b', 'loadClassLoader'));
|
||||||
|
|
||||||
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
|
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
|
||||||
if ($useStaticLoader) {
|
if ($useStaticLoader) {
|
||||||
require_once __DIR__ . '/autoload_static.php';
|
require_once __DIR__ . '/autoload_static.php';
|
||||||
|
|
||||||
call_user_func(\Composer\Autoload\ComposerStaticInitfbb01b03828af73cff04bee933bd6172::getInitializer($loader));
|
call_user_func(\Composer\Autoload\ComposerStaticInit9e628bddedd690e20fe8b6cad9d0489b::getInitializer($loader));
|
||||||
} else {
|
} else {
|
||||||
$map = require __DIR__ . '/autoload_namespaces.php';
|
$map = require __DIR__ . '/autoload_namespaces.php';
|
||||||
foreach ($map as $namespace => $path) {
|
foreach ($map as $namespace => $path) {
|
||||||
@ -48,19 +48,19 @@ class ComposerAutoloaderInitfbb01b03828af73cff04bee933bd6172
|
|||||||
$loader->register(true);
|
$loader->register(true);
|
||||||
|
|
||||||
if ($useStaticLoader) {
|
if ($useStaticLoader) {
|
||||||
$includeFiles = Composer\Autoload\ComposerStaticInitfbb01b03828af73cff04bee933bd6172::$files;
|
$includeFiles = Composer\Autoload\ComposerStaticInit9e628bddedd690e20fe8b6cad9d0489b::$files;
|
||||||
} else {
|
} else {
|
||||||
$includeFiles = require __DIR__ . '/autoload_files.php';
|
$includeFiles = require __DIR__ . '/autoload_files.php';
|
||||||
}
|
}
|
||||||
foreach ($includeFiles as $fileIdentifier => $file) {
|
foreach ($includeFiles as $fileIdentifier => $file) {
|
||||||
composerRequirefbb01b03828af73cff04bee933bd6172($fileIdentifier, $file);
|
composerRequire9e628bddedd690e20fe8b6cad9d0489b($fileIdentifier, $file);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $loader;
|
return $loader;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function composerRequirefbb01b03828af73cff04bee933bd6172($fileIdentifier, $file)
|
function composerRequire9e628bddedd690e20fe8b6cad9d0489b($fileIdentifier, $file)
|
||||||
{
|
{
|
||||||
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
|
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
|
||||||
require $file;
|
require $file;
|
||||||
|
9
vendor/composer/autoload_static.php
vendored
9
vendor/composer/autoload_static.php
vendored
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
namespace Composer\Autoload;
|
namespace Composer\Autoload;
|
||||||
|
|
||||||
class ComposerStaticInitfbb01b03828af73cff04bee933bd6172
|
class ComposerStaticInit9e628bddedd690e20fe8b6cad9d0489b
|
||||||
{
|
{
|
||||||
public static $files = array (
|
public static $files = array (
|
||||||
'1cfd2761b63b0a29ed23657ea394cb2d' => __DIR__ . '/..' . '/topthink/think-captcha/src/helper.php',
|
'1cfd2761b63b0a29ed23657ea394cb2d' => __DIR__ . '/..' . '/topthink/think-captcha/src/helper.php',
|
||||||
@ -246,6 +246,7 @@ class ComposerStaticInitfbb01b03828af73cff04bee933bd6172
|
|||||||
'app\\index\\controller\\Index' => __DIR__ . '/../..' . '/application/index/controller/Index.php',
|
'app\\index\\controller\\Index' => __DIR__ . '/../..' . '/application/index/controller/Index.php',
|
||||||
'app\\store\\controller\\Express' => __DIR__ . '/../..' . '/application/store/controller/Express.php',
|
'app\\store\\controller\\Express' => __DIR__ . '/../..' . '/application/store/controller/Express.php',
|
||||||
'app\\store\\controller\\Order' => __DIR__ . '/../..' . '/application/store/controller/Order.php',
|
'app\\store\\controller\\Order' => __DIR__ . '/../..' . '/application/store/controller/Order.php',
|
||||||
|
'app\\store\\controller\\wechat\\Index' => __DIR__ . '/../..' . '/application/store/controller/wechat/Index.php',
|
||||||
'app\\store\\service\\OrderService' => __DIR__ . '/../..' . '/application/store/service/OrderService.php',
|
'app\\store\\service\\OrderService' => __DIR__ . '/../..' . '/application/store/service/OrderService.php',
|
||||||
'app\\wechat\\controller\\Block' => __DIR__ . '/../..' . '/application/wechat/controller/Block.php',
|
'app\\wechat\\controller\\Block' => __DIR__ . '/../..' . '/application/wechat/controller/Block.php',
|
||||||
'app\\wechat\\controller\\Config' => __DIR__ . '/../..' . '/application/wechat/controller/Config.php',
|
'app\\wechat\\controller\\Config' => __DIR__ . '/../..' . '/application/wechat/controller/Config.php',
|
||||||
@ -272,9 +273,9 @@ class ComposerStaticInitfbb01b03828af73cff04bee933bd6172
|
|||||||
public static function getInitializer(ClassLoader $loader)
|
public static function getInitializer(ClassLoader $loader)
|
||||||
{
|
{
|
||||||
return \Closure::bind(function () use ($loader) {
|
return \Closure::bind(function () use ($loader) {
|
||||||
$loader->prefixLengthsPsr4 = ComposerStaticInitfbb01b03828af73cff04bee933bd6172::$prefixLengthsPsr4;
|
$loader->prefixLengthsPsr4 = ComposerStaticInit9e628bddedd690e20fe8b6cad9d0489b::$prefixLengthsPsr4;
|
||||||
$loader->prefixDirsPsr4 = ComposerStaticInitfbb01b03828af73cff04bee933bd6172::$prefixDirsPsr4;
|
$loader->prefixDirsPsr4 = ComposerStaticInit9e628bddedd690e20fe8b6cad9d0489b::$prefixDirsPsr4;
|
||||||
$loader->classMap = ComposerStaticInitfbb01b03828af73cff04bee933bd6172::$classMap;
|
$loader->classMap = ComposerStaticInit9e628bddedd690e20fe8b6cad9d0489b::$classMap;
|
||||||
|
|
||||||
}, null, ClassLoader::class);
|
}, null, ClassLoader::class);
|
||||||
}
|
}
|
||||||
|
20
vendor/composer/installed.json
vendored
20
vendor/composer/installed.json
vendored
@ -10,7 +10,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/top-think/think-installer/zipball/1be326e68f63de4e95977ed50f46ae75f017556d",
|
"url": "https://files.phpcomposer.com/files/top-think/think-installer/1be326e68f63de4e95977ed50f46ae75f017556d.zip",
|
||||||
"reference": "1be326e68f63de4e95977ed50f46ae75f017556d",
|
"reference": "1be326e68f63de4e95977ed50f46ae75f017556d",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -53,7 +53,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/zoujingli/ip2region/zipball/5d981fbf3b574bad7fe9652e7aecba0920f54325",
|
"url": "https://files.phpcomposer.com/files/zoujingli/ip2region/5d981fbf3b574bad7fe9652e7aecba0920f54325.zip",
|
||||||
"reference": "5d981fbf3b574bad7fe9652e7aecba0920f54325",
|
"reference": "5d981fbf3b574bad7fe9652e7aecba0920f54325",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -89,7 +89,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/zoujingli/WeChatDeveloper/zipball/4b1112e8d4723ce5e6ef0d6eee41a02e588b60ab",
|
"url": "https://files.phpcomposer.com/files/zoujingli/WeChatDeveloper/4b1112e8d4723ce5e6ef0d6eee41a02e588b60ab.zip",
|
||||||
"reference": "4b1112e8d4723ce5e6ef0d6eee41a02e588b60ab",
|
"reference": "4b1112e8d4723ce5e6ef0d6eee41a02e588b60ab",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -137,7 +137,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/zoujingli/WeOpenDeveloper/zipball/8bb75bc08488a43964c00f027b21b93ed58e8d5a",
|
"url": "https://files.phpcomposer.com/files/zoujingli/WeOpenDeveloper/8bb75bc08488a43964c00f027b21b93ed58e8d5a.zip",
|
||||||
"reference": "8bb75bc08488a43964c00f027b21b93ed58e8d5a",
|
"reference": "8bb75bc08488a43964c00f027b21b93ed58e8d5a",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -185,7 +185,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/top-think/framework/zipball/f879603ee321af8fde56d8855445cf98bc81b042",
|
"url": "https://files.phpcomposer.com/files/top-think/framework/f879603ee321af8fde56d8855445cf98bc81b042.zip",
|
||||||
"reference": "f879603ee321af8fde56d8855445cf98bc81b042",
|
"reference": "f879603ee321af8fde56d8855445cf98bc81b042",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -238,7 +238,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/top-think/think-captcha/zipball/54c8a51552f99ff9ea89ea9c272383a8f738ceee",
|
"url": "https://files.phpcomposer.com/files/top-think/think-captcha/54c8a51552f99ff9ea89ea9c272383a8f738ceee.zip",
|
||||||
"reference": "54c8a51552f99ff9ea89ea9c272383a8f738ceee",
|
"reference": "54c8a51552f99ff9ea89ea9c272383a8f738ceee",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -279,7 +279,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/symfony/options-resolver/zipball/f3109a6aedd20e35c3a33190e932c2b063b7b50e",
|
"url": "https://files.phpcomposer.com/files/symfony/options-resolver/f3109a6aedd20e35c3a33190e932c2b063b7b50e.zip",
|
||||||
"reference": "f3109a6aedd20e35c3a33190e932c2b063b7b50e",
|
"reference": "f3109a6aedd20e35c3a33190e932c2b063b7b50e",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -335,7 +335,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/endroid/qr-code/zipball/c9644bec2a9cc9318e98d1437de3c628dcd1ef93",
|
"url": "https://files.phpcomposer.com/files/endroid/qr-code/c9644bec2a9cc9318e98d1437de3c628dcd1ef93.zip",
|
||||||
"reference": "c9644bec2a9cc9318e98d1437de3c628dcd1ef93",
|
"reference": "c9644bec2a9cc9318e98d1437de3c628dcd1ef93",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -397,7 +397,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/aliyun/aliyun-oss-php-sdk/zipball/e69f57916678458642ac9d2fd341ae78a56996c8",
|
"url": "https://files.phpcomposer.com/files/aliyun/aliyun-oss-php-sdk/e69f57916678458642ac9d2fd341ae78a56996c8.zip",
|
||||||
"reference": "e69f57916678458642ac9d2fd341ae78a56996c8",
|
"reference": "e69f57916678458642ac9d2fd341ae78a56996c8",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
@ -440,7 +440,7 @@
|
|||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/qiniu/php-sdk/zipball/67852ba9cdd7f48e0e080961abebafee134fb329",
|
"url": "https://files.phpcomposer.com/files/qiniu/php-sdk/67852ba9cdd7f48e0e080961abebafee134fb329.zip",
|
||||||
"reference": "67852ba9cdd7f48e0e080961abebafee134fb329",
|
"reference": "67852ba9cdd7f48e0e080961abebafee134fb329",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
|
Loading…
x
Reference in New Issue
Block a user