diff --git a/doc/01-软件设计规格说明书-李国栋.docx b/doc/01-软件设计规格说明书-李国栋.docx
new file mode 100644
index 0000000..6e1871f
Binary files /dev/null and b/doc/01-软件设计规格说明书-李国栋.docx differ
diff --git a/doc/01-软件设计规格说明书v2.0-李国栋.docx b/doc/01-软件设计规格说明书v2.0-李国栋.docx
new file mode 100644
index 0000000..d74efcd
Binary files /dev/null and b/doc/01-软件设计规格说明书v2.0-李国栋.docx differ
diff --git a/doc/01-软件需求规格说明书v2.0-李国栋.docx b/doc/01-软件需求规格说明书v2.0-李国栋.docx
new file mode 100644
index 0000000..c779baa
Binary files /dev/null and b/doc/01-软件需求规格说明书v2.0-李国栋.docx differ
diff --git a/doc/软件设计规格说明书.docx b/doc/软件设计规格说明书.docx
new file mode 100644
index 0000000..62fd71a
Binary files /dev/null and b/doc/软件设计规格说明书.docx differ
diff --git a/doc/软件需求规格说明书(1).docx b/doc/软件需求规格说明书(1).docx
new file mode 100644
index 0000000..5a9f1ba
Binary files /dev/null and b/doc/软件需求规格说明书(1).docx differ
diff --git a/model/.gitignore b/model/.gitignore
new file mode 100644
index 0000000..d21d8a7
--- /dev/null
+++ b/model/.gitignore
@@ -0,0 +1,14 @@
+/server/myapp/migrations
+/server/myapp/views/__pycache__/
+/server/.idea
+/web/.idea
+/web/dist
+/web/node_modules
+/server/.idea/
+/.idea/
+__pycache__
+.idea
+server/.idea
+.DS_Store
+server/.DS_Store
+web/.DS_Store
\ No newline at end of file
diff --git a/model/python_team.sql b/model/python_team.sql
new file mode 100644
index 0000000..9f1a5ba
--- /dev/null
+++ b/model/python_team.sql
@@ -0,0 +1,782 @@
+/*
+ Navicat Premium Data Transfer
+
+ Source Server : localhost连接
+ Source Server Type : MySQL
+ Source Server Version : 50737
+ Source Host : localhost:3306
+ Source Schema : python_team
+
+ Target Server Type : MySQL
+ Target Server Version : 50737
+ File Encoding : 65001
+
+ Date: 04/02/2024 17:29:54
+*/
+
+SET NAMES utf8mb4;
+SET FOREIGN_KEY_CHECKS = 0;
+
+-- ----------------------------
+-- Table structure for auth_group
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_group`;
+CREATE TABLE `auth_group` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `name` varchar(150) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `name`(`name`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_group
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for auth_group_permissions
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_group_permissions`;
+CREATE TABLE `auth_group_permissions` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `group_id` int(11) NOT NULL,
+ `permission_id` int(11) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `auth_group_permissions_group_id_permission_id_0cd325b0_uniq`(`group_id`, `permission_id`) USING BTREE,
+ INDEX `auth_group_permissio_permission_id_84c5c92e_fk_auth_perm`(`permission_id`) USING BTREE,
+ CONSTRAINT `auth_group_permissio_permission_id_84c5c92e_fk_auth_perm` FOREIGN KEY (`permission_id`) REFERENCES `auth_permission` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `auth_group_permissions_group_id_b120cbf9_fk_auth_group_id` FOREIGN KEY (`group_id`) REFERENCES `auth_group` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_group_permissions
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for auth_permission
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_permission`;
+CREATE TABLE `auth_permission` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `content_type_id` int(11) NOT NULL,
+ `codename` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `auth_permission_content_type_id_codename_01ab375a_uniq`(`content_type_id`, `codename`) USING BTREE,
+ CONSTRAINT `auth_permission_content_type_id_2f476e4b_fk_django_co` FOREIGN KEY (`content_type_id`) REFERENCES `django_content_type` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 85 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_permission
+-- ----------------------------
+INSERT INTO `auth_permission` VALUES (1, 'Can add log entry', 1, 'add_logentry');
+INSERT INTO `auth_permission` VALUES (2, 'Can change log entry', 1, 'change_logentry');
+INSERT INTO `auth_permission` VALUES (3, 'Can delete log entry', 1, 'delete_logentry');
+INSERT INTO `auth_permission` VALUES (4, 'Can view log entry', 1, 'view_logentry');
+INSERT INTO `auth_permission` VALUES (5, 'Can add permission', 2, 'add_permission');
+INSERT INTO `auth_permission` VALUES (6, 'Can change permission', 2, 'change_permission');
+INSERT INTO `auth_permission` VALUES (7, 'Can delete permission', 2, 'delete_permission');
+INSERT INTO `auth_permission` VALUES (8, 'Can view permission', 2, 'view_permission');
+INSERT INTO `auth_permission` VALUES (9, 'Can add group', 3, 'add_group');
+INSERT INTO `auth_permission` VALUES (10, 'Can change group', 3, 'change_group');
+INSERT INTO `auth_permission` VALUES (11, 'Can delete group', 3, 'delete_group');
+INSERT INTO `auth_permission` VALUES (12, 'Can view group', 3, 'view_group');
+INSERT INTO `auth_permission` VALUES (13, 'Can add user', 4, 'add_user');
+INSERT INTO `auth_permission` VALUES (14, 'Can change user', 4, 'change_user');
+INSERT INTO `auth_permission` VALUES (15, 'Can delete user', 4, 'delete_user');
+INSERT INTO `auth_permission` VALUES (16, 'Can view user', 4, 'view_user');
+INSERT INTO `auth_permission` VALUES (17, 'Can add content type', 5, 'add_contenttype');
+INSERT INTO `auth_permission` VALUES (18, 'Can change content type', 5, 'change_contenttype');
+INSERT INTO `auth_permission` VALUES (19, 'Can delete content type', 5, 'delete_contenttype');
+INSERT INTO `auth_permission` VALUES (20, 'Can view content type', 5, 'view_contenttype');
+INSERT INTO `auth_permission` VALUES (21, 'Can add session', 6, 'add_session');
+INSERT INTO `auth_permission` VALUES (22, 'Can change session', 6, 'change_session');
+INSERT INTO `auth_permission` VALUES (23, 'Can delete session', 6, 'delete_session');
+INSERT INTO `auth_permission` VALUES (24, 'Can view session', 6, 'view_session');
+INSERT INTO `auth_permission` VALUES (25, 'Can add ad', 7, 'add_ad');
+INSERT INTO `auth_permission` VALUES (26, 'Can change ad', 7, 'change_ad');
+INSERT INTO `auth_permission` VALUES (27, 'Can delete ad', 7, 'delete_ad');
+INSERT INTO `auth_permission` VALUES (28, 'Can view ad', 7, 'view_ad');
+INSERT INTO `auth_permission` VALUES (29, 'Can add classification', 8, 'add_classification');
+INSERT INTO `auth_permission` VALUES (30, 'Can change classification', 8, 'change_classification');
+INSERT INTO `auth_permission` VALUES (31, 'Can delete classification', 8, 'delete_classification');
+INSERT INTO `auth_permission` VALUES (32, 'Can view classification', 8, 'view_classification');
+INSERT INTO `auth_permission` VALUES (33, 'Can add error log', 9, 'add_errorlog');
+INSERT INTO `auth_permission` VALUES (34, 'Can change error log', 9, 'change_errorlog');
+INSERT INTO `auth_permission` VALUES (35, 'Can delete error log', 9, 'delete_errorlog');
+INSERT INTO `auth_permission` VALUES (36, 'Can view error log', 9, 'view_errorlog');
+INSERT INTO `auth_permission` VALUES (37, 'Can add login log', 10, 'add_loginlog');
+INSERT INTO `auth_permission` VALUES (38, 'Can change login log', 10, 'change_loginlog');
+INSERT INTO `auth_permission` VALUES (39, 'Can delete login log', 10, 'delete_loginlog');
+INSERT INTO `auth_permission` VALUES (40, 'Can view login log', 10, 'view_loginlog');
+INSERT INTO `auth_permission` VALUES (41, 'Can add notice', 11, 'add_notice');
+INSERT INTO `auth_permission` VALUES (42, 'Can change notice', 11, 'change_notice');
+INSERT INTO `auth_permission` VALUES (43, 'Can delete notice', 11, 'delete_notice');
+INSERT INTO `auth_permission` VALUES (44, 'Can view notice', 11, 'view_notice');
+INSERT INTO `auth_permission` VALUES (45, 'Can add op log', 12, 'add_oplog');
+INSERT INTO `auth_permission` VALUES (46, 'Can change op log', 12, 'change_oplog');
+INSERT INTO `auth_permission` VALUES (47, 'Can delete op log', 12, 'delete_oplog');
+INSERT INTO `auth_permission` VALUES (48, 'Can view op log', 12, 'view_oplog');
+INSERT INTO `auth_permission` VALUES (49, 'Can add tag', 13, 'add_tag');
+INSERT INTO `auth_permission` VALUES (50, 'Can change tag', 13, 'change_tag');
+INSERT INTO `auth_permission` VALUES (51, 'Can delete tag', 13, 'delete_tag');
+INSERT INTO `auth_permission` VALUES (52, 'Can view tag', 13, 'view_tag');
+INSERT INTO `auth_permission` VALUES (53, 'Can add user', 14, 'add_user');
+INSERT INTO `auth_permission` VALUES (54, 'Can change user', 14, 'change_user');
+INSERT INTO `auth_permission` VALUES (55, 'Can delete user', 14, 'delete_user');
+INSERT INTO `auth_permission` VALUES (56, 'Can view user', 14, 'view_user');
+INSERT INTO `auth_permission` VALUES (57, 'Can add thing', 15, 'add_thing');
+INSERT INTO `auth_permission` VALUES (58, 'Can change thing', 15, 'change_thing');
+INSERT INTO `auth_permission` VALUES (59, 'Can delete thing', 15, 'delete_thing');
+INSERT INTO `auth_permission` VALUES (60, 'Can view thing', 15, 'view_thing');
+INSERT INTO `auth_permission` VALUES (61, 'Can add record', 16, 'add_record');
+INSERT INTO `auth_permission` VALUES (62, 'Can change record', 16, 'change_record');
+INSERT INTO `auth_permission` VALUES (63, 'Can delete record', 16, 'delete_record');
+INSERT INTO `auth_permission` VALUES (64, 'Can view record', 16, 'view_record');
+INSERT INTO `auth_permission` VALUES (65, 'Can add order log', 17, 'add_orderlog');
+INSERT INTO `auth_permission` VALUES (66, 'Can change order log', 17, 'change_orderlog');
+INSERT INTO `auth_permission` VALUES (67, 'Can delete order log', 17, 'delete_orderlog');
+INSERT INTO `auth_permission` VALUES (68, 'Can view order log', 17, 'view_orderlog');
+INSERT INTO `auth_permission` VALUES (69, 'Can add order', 18, 'add_order');
+INSERT INTO `auth_permission` VALUES (70, 'Can change order', 18, 'change_order');
+INSERT INTO `auth_permission` VALUES (71, 'Can delete order', 18, 'delete_order');
+INSERT INTO `auth_permission` VALUES (72, 'Can view order', 18, 'view_order');
+INSERT INTO `auth_permission` VALUES (73, 'Can add comment', 19, 'add_comment');
+INSERT INTO `auth_permission` VALUES (74, 'Can change comment', 19, 'change_comment');
+INSERT INTO `auth_permission` VALUES (75, 'Can delete comment', 19, 'delete_comment');
+INSERT INTO `auth_permission` VALUES (76, 'Can view comment', 19, 'view_comment');
+INSERT INTO `auth_permission` VALUES (77, 'Can add banner', 20, 'add_banner');
+INSERT INTO `auth_permission` VALUES (78, 'Can change banner', 20, 'change_banner');
+INSERT INTO `auth_permission` VALUES (79, 'Can delete banner', 20, 'delete_banner');
+INSERT INTO `auth_permission` VALUES (80, 'Can view banner', 20, 'view_banner');
+INSERT INTO `auth_permission` VALUES (81, 'Can add address', 21, 'add_address');
+INSERT INTO `auth_permission` VALUES (82, 'Can change address', 21, 'change_address');
+INSERT INTO `auth_permission` VALUES (83, 'Can delete address', 21, 'delete_address');
+INSERT INTO `auth_permission` VALUES (84, 'Can view address', 21, 'view_address');
+
+-- ----------------------------
+-- Table structure for auth_user
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_user`;
+CREATE TABLE `auth_user` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `password` varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `last_login` datetime(6) NULL DEFAULT NULL,
+ `is_superuser` tinyint(1) NOT NULL,
+ `username` varchar(150) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `first_name` varchar(150) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `last_name` varchar(150) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `email` varchar(254) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `is_staff` tinyint(1) NOT NULL,
+ `is_active` tinyint(1) NOT NULL,
+ `date_joined` datetime(6) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `username`(`username`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_user
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for auth_user_groups
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_user_groups`;
+CREATE TABLE `auth_user_groups` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `user_id` int(11) NOT NULL,
+ `group_id` int(11) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `auth_user_groups_user_id_group_id_94350c0c_uniq`(`user_id`, `group_id`) USING BTREE,
+ INDEX `auth_user_groups_group_id_97559544_fk_auth_group_id`(`group_id`) USING BTREE,
+ CONSTRAINT `auth_user_groups_group_id_97559544_fk_auth_group_id` FOREIGN KEY (`group_id`) REFERENCES `auth_group` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `auth_user_groups_user_id_6a12ed8b_fk_auth_user_id` FOREIGN KEY (`user_id`) REFERENCES `auth_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_user_groups
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for auth_user_user_permissions
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_user_user_permissions`;
+CREATE TABLE `auth_user_user_permissions` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `user_id` int(11) NOT NULL,
+ `permission_id` int(11) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `auth_user_user_permissions_user_id_permission_id_14a6b632_uniq`(`user_id`, `permission_id`) USING BTREE,
+ INDEX `auth_user_user_permi_permission_id_1fbb5f2c_fk_auth_perm`(`permission_id`) USING BTREE,
+ CONSTRAINT `auth_user_user_permi_permission_id_1fbb5f2c_fk_auth_perm` FOREIGN KEY (`permission_id`) REFERENCES `auth_permission` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `auth_user_user_permissions_user_id_a95ead1b_fk_auth_user_id` FOREIGN KEY (`user_id`) REFERENCES `auth_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_user_user_permissions
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_ad
+-- ----------------------------
+DROP TABLE IF EXISTS `b_ad`;
+CREATE TABLE `b_ad` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `image` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `link` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_ad
+-- ----------------------------
+INSERT INTO `b_ad` VALUES (1, '', 'http://www.baidu.com111', '2024-02-04 17:26:04.553627');
+
+-- ----------------------------
+-- Table structure for b_address
+-- ----------------------------
+DROP TABLE IF EXISTS `b_address`;
+CREATE TABLE `b_address` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `mobile` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `desc` varchar(300) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `default` tinyint(1) NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_address_user_id_a37a8d6a_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_address_user_id_a37a8d6a_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_address
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_banner
+-- ----------------------------
+DROP TABLE IF EXISTS `b_banner`;
+CREATE TABLE `b_banner` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `image` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_banner_thing_id_3f307d00_fk_b_thing_id`(`thing_id`) USING BTREE,
+ CONSTRAINT `b_banner_thing_id_3f307d00_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_banner
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_classification
+-- ----------------------------
+DROP TABLE IF EXISTS `b_classification`;
+CREATE TABLE `b_classification` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_classification
+-- ----------------------------
+INSERT INTO `b_classification` VALUES (1, '体育类', '2024-02-04 16:39:13.697593');
+INSERT INTO `b_classification` VALUES (2, '运动类', '2024-02-04 16:39:19.397394');
+INSERT INTO `b_classification` VALUES (3, '文艺类', '2024-02-04 16:39:24.633287');
+INSERT INTO `b_classification` VALUES (4, '电子类', '2024-02-04 16:39:59.841608');
+
+-- ----------------------------
+-- Table structure for b_comment
+-- ----------------------------
+DROP TABLE IF EXISTS `b_comment`;
+CREATE TABLE `b_comment` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `content` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `comment_time` datetime(6) NULL DEFAULT NULL,
+ `like_count` int(11) NOT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_comment_thing_id_57ab492b_fk_b_thing_id`(`thing_id`) USING BTREE,
+ INDEX `b_comment_user_id_46f0670f_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_comment_thing_id_57ab492b_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_comment_user_id_46f0670f_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_comment
+-- ----------------------------
+INSERT INTO `b_comment` VALUES (1, 'dasdf', '2024-02-04 16:58:15.144159', 1, 5, 4);
+INSERT INTO `b_comment` VALUES (2, 'dfasdfff', '2024-02-04 16:58:17.850901', 1, 5, 4);
+INSERT INTO `b_comment` VALUES (3, '的地方211', '2024-02-04 17:00:55.346951', 2, 5, 4);
+
+-- ----------------------------
+-- Table structure for b_error_log
+-- ----------------------------
+DROP TABLE IF EXISTS `b_error_log`;
+CREATE TABLE `b_error_log` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `ip` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `url` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `method` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `content` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `log_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_error_log
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_login_log
+-- ----------------------------
+DROP TABLE IF EXISTS `b_login_log`;
+CREATE TABLE `b_login_log` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `username` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `ip` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `ua` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `log_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 6 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_login_log
+-- ----------------------------
+INSERT INTO `b_login_log` VALUES (1, 'admin', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 16:36:19.239685');
+INSERT INTO `b_login_log` VALUES (2, 'aaa', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 16:57:10.644691');
+INSERT INTO `b_login_log` VALUES (3, 'admin123', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 17:18:37.112379');
+INSERT INTO `b_login_log` VALUES (4, 'admin', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 17:25:59.480266');
+INSERT INTO `b_login_log` VALUES (5, 'aaa', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 17:27:08.481837');
+
+-- ----------------------------
+-- Table structure for b_notice
+-- ----------------------------
+DROP TABLE IF EXISTS `b_notice`;
+CREATE TABLE `b_notice` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `content` varchar(1000) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_notice
+-- ----------------------------
+INSERT INTO `b_notice` VALUES (1, 'abcd', '欢迎申请', '2024-02-04 17:26:10.000000');
+INSERT INTO `b_notice` VALUES (2, '新建社团123', '安德森对方', '2024-02-04 17:26:20.948813');
+
+-- ----------------------------
+-- Table structure for b_op_log
+-- ----------------------------
+DROP TABLE IF EXISTS `b_op_log`;
+CREATE TABLE `b_op_log` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `re_ip` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `re_time` datetime(6) NULL DEFAULT NULL,
+ `re_url` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `re_method` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `re_content` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `access_time` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 25 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_op_log
+-- ----------------------------
+INSERT INTO `b_op_log` VALUES (1, '127.0.0.1', '2024-02-04 17:25:16.003630', '/myapp/admin/loginLog/list', 'GET', NULL, '25');
+INSERT INTO `b_op_log` VALUES (2, '127.0.0.1', '2024-02-04 17:25:16.125409', '/myapp/admin/opLog/list', 'GET', NULL, '28');
+INSERT INTO `b_op_log` VALUES (3, '127.0.0.1', '2024-02-04 17:25:16.735706', '/myapp/admin/errorLog/list', 'GET', NULL, '4');
+INSERT INTO `b_op_log` VALUES (4, '127.0.0.1', '2024-02-04 17:25:17.091962', '/myapp/admin/opLog/list', 'GET', NULL, '28');
+INSERT INTO `b_op_log` VALUES (5, '127.0.0.1', '2024-02-04 17:25:17.996686', '/myapp/admin/comment/list', 'GET', NULL, '24');
+INSERT INTO `b_op_log` VALUES (6, '127.0.0.1', '2024-02-04 17:25:18.508752', '/myapp/admin/tag/list', 'GET', NULL, '28');
+INSERT INTO `b_op_log` VALUES (7, '127.0.0.1', '2024-02-04 17:25:18.995965', '/myapp/admin/order/list', 'GET', NULL, '25');
+INSERT INTO `b_op_log` VALUES (8, '127.0.0.1', '2024-02-04 17:25:19.517164', '/myapp/admin/classification/list', 'GET', NULL, '25');
+INSERT INTO `b_op_log` VALUES (9, '127.0.0.1', '2024-02-04 17:25:19.951784', '/myapp/admin/order/list', 'GET', NULL, '8');
+INSERT INTO `b_op_log` VALUES (10, '127.0.0.1', '2024-02-04 17:25:20.517535', '/myapp/admin/tag/list', 'GET', NULL, '17');
+INSERT INTO `b_op_log` VALUES (11, '127.0.0.1', '2024-02-04 17:25:20.899065', '/myapp/admin/comment/list', 'GET', NULL, '7');
+INSERT INTO `b_op_log` VALUES (12, '127.0.0.1', '2024-02-04 17:25:21.391965', '/myapp/admin/user/list', 'GET', NULL, '20');
+INSERT INTO `b_op_log` VALUES (13, '127.0.0.1', '2024-02-04 17:25:21.677749', '/myapp/admin/comment/list', 'GET', NULL, '5');
+INSERT INTO `b_op_log` VALUES (14, '127.0.0.1', '2024-02-04 17:25:24.066175', '/myapp/index/comment/list', 'GET', NULL, '3');
+INSERT INTO `b_op_log` VALUES (15, '127.0.0.1', '2024-02-04 17:25:24.083944', '/myapp/index/comment/list', 'GET', NULL, '22');
+INSERT INTO `b_op_log` VALUES (16, '127.0.0.1', '2024-02-04 17:25:24.084992', '/myapp/index/comment/list', 'GET', NULL, '23');
+INSERT INTO `b_op_log` VALUES (17, '127.0.0.1', '2024-02-04 17:25:24.090525', '/myapp/index/comment/list', 'GET', NULL, '29');
+INSERT INTO `b_op_log` VALUES (18, '127.0.0.1', '2024-02-04 17:25:24.094806', '/upload/cover/1707036810262.jpeg', 'GET', NULL, '1');
+INSERT INTO `b_op_log` VALUES (19, '127.0.0.1', '2024-02-04 17:25:24.109564', '/upload/cover/1707036756214.jpeg', 'GET', NULL, '1');
+INSERT INTO `b_op_log` VALUES (20, '127.0.0.1', '2024-02-04 17:25:24.109564', '/upload/cover/1707036858212.jpeg', 'GET', NULL, '0');
+INSERT INTO `b_op_log` VALUES (21, '127.0.0.1', '2024-02-04 17:25:24.109564', '/upload/cover/1707036756214.jpeg', 'GET', NULL, '0');
+INSERT INTO `b_op_log` VALUES (22, '127.0.0.1', '2024-02-04 17:25:24.110577', '/upload/cover/1707036638009.jpeg', 'GET', NULL, '1');
+INSERT INTO `b_op_log` VALUES (23, '127.0.0.1', '2024-02-04 17:25:24.110577', '/upload/cover/1707036701716.jpeg', 'GET', NULL, '0');
+INSERT INTO `b_op_log` VALUES (24, '127.0.0.1', '2024-02-04 17:25:27.073752', '/myapp/admin/opLog/list', 'GET', NULL, '4');
+
+-- ----------------------------
+-- Table structure for b_order
+-- ----------------------------
+DROP TABLE IF EXISTS `b_order`;
+CREATE TABLE `b_order` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `order_number` varchar(13) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `count` int(11) NOT NULL,
+ `status` varchar(2) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `order_time` datetime(6) NULL DEFAULT NULL,
+ `pay_time` datetime(6) NULL DEFAULT NULL,
+ `receiver_name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `receiver_address` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `receiver_phone` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `remark` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_order_thing_id_4e345e2c_fk_b_thing_id`(`thing_id`) USING BTREE,
+ INDEX `b_order_user_id_64854046_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_order_thing_id_4e345e2c_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_order_user_id_64854046_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_order
+-- ----------------------------
+INSERT INTO `b_order` VALUES (1, '1707037383809', 1, '2', '2024-02-04 17:03:03.811334', NULL, NULL, NULL, NULL, NULL, 5, 4);
+INSERT INTO `b_order` VALUES (2, '1707037601900', 1, '2', '2024-02-04 17:06:41.903354', NULL, NULL, NULL, NULL, NULL, 5, 4);
+INSERT INTO `b_order` VALUES (3, '1707038198529', 1, '7', '2024-02-04 17:16:38.534185', NULL, NULL, NULL, NULL, NULL, 1, 4);
+
+-- ----------------------------
+-- Table structure for b_order_log
+-- ----------------------------
+DROP TABLE IF EXISTS `b_order_log`;
+CREATE TABLE `b_order_log` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `action` varchar(2) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `log_time` datetime(6) NULL DEFAULT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_order_log_thing_id_7306f624_fk_b_thing_id`(`thing_id`) USING BTREE,
+ INDEX `b_order_log_user_id_1003e839_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_order_log_thing_id_7306f624_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_order_log_user_id_1003e839_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_order_log
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_record
+-- ----------------------------
+DROP TABLE IF EXISTS `b_record`;
+CREATE TABLE `b_record` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `record_time` datetime(6) NULL DEFAULT NULL,
+ `classification_id` bigint(20) NULL DEFAULT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_record_classification_id_52591cc9_fk_b_classification_id`(`classification_id`) USING BTREE,
+ INDEX `b_record_thing_id_d8e773c0_fk_b_thing_id`(`thing_id`) USING BTREE,
+ INDEX `b_record_user_id_7e5958b0_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_record_classification_id_52591cc9_fk_b_classification_id` FOREIGN KEY (`classification_id`) REFERENCES `b_classification` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_record_thing_id_d8e773c0_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_record_user_id_7e5958b0_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_record
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_tag
+-- ----------------------------
+DROP TABLE IF EXISTS `b_tag`;
+CREATE TABLE `b_tag` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 6 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_tag
+-- ----------------------------
+INSERT INTO `b_tag` VALUES (1, '美女多', '2024-02-04 16:38:34.240261');
+INSERT INTO `b_tag` VALUES (2, '高材生', '2024-02-04 16:38:41.618448');
+INSERT INTO `b_tag` VALUES (3, '帅哥多', '2024-02-04 16:38:48.542216');
+INSERT INTO `b_tag` VALUES (4, '读书', '2024-02-04 16:38:57.500728');
+INSERT INTO `b_tag` VALUES (5, '跑步', '2024-02-04 16:39:05.464820');
+
+-- ----------------------------
+-- Table structure for b_thing
+-- ----------------------------
+DROP TABLE IF EXISTS `b_thing`;
+CREATE TABLE `b_thing` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `cover` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `description` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL,
+ `mobile` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `location` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `status` varchar(1) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ `pv` int(11) NOT NULL,
+ `recommend_count` int(11) NOT NULL,
+ `wish_count` int(11) NOT NULL,
+ `collect_count` int(11) NOT NULL,
+ `classification_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ `email` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `zongzhi` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_thing_classification_id_47675ac4_fk_b_classification_id`(`classification_id`) USING BTREE,
+ INDEX `b_thing_user_id_9918a633_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_thing_classification_id_47675ac4_fk_b_classification_id` FOREIGN KEY (`classification_id`) REFERENCES `b_classification` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_thing_user_id_9918a633_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 8 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_thing
+-- ----------------------------
+INSERT INTO `b_thing` VALUES (1, '街舞团', 'cover/1707036603261.jpeg', 'abcfdasdf', '13422221111', '教学楼3号楼1层', '0', '2024-02-04 16:45:44.682923', 4, 0, 1, 1, 2, NULL, '123@qq.com', '为人民服务');
+INSERT INTO `b_thing` VALUES (2, 'beyond502乐队', 'cover/1707036638009.jpeg', '江河湖海就将计就计哈哈哈哈哈哈哈哈', '13455555555', '6号宿舍楼', '0', '2024-02-04 16:51:15.254882', 1, 0, 0, 0, 3, NULL, '12345@qq.com', '为了音乐而生');
+INSERT INTO `b_thing` VALUES (3, '轮滑俱乐部', 'cover/1707036701716.jpeg', '哈哈哈哈哈哈哈哈哈哈', '13422221111', '9号宿舍楼', '0', '2024-02-04 16:52:13.713017', 0, 0, 0, 0, 2, NULL, '1234@126.com', '为了运动努力');
+INSERT INTO `b_thing` VALUES (4, '王羲之书法俱乐部', 'cover/1707036756214.jpeg', '江河湖海哼哼唧唧哼哼唧唧就哈哈哈哈话剧', '13211112222', '颐和园路5号', '0', '2024-02-04 16:53:09.100387', 2, 0, 0, 0, 3, NULL, '123@qq.com', '为了哈哈哈');
+INSERT INTO `b_thing` VALUES (5, '电子琴俱乐部', 'cover/1707036810262.jpeg', '就很好很好灌灌哈哈哈哈嘎嘎嘎嘎', '13455555555', '12号教学楼', '0', '2024-02-04 16:53:56.425555', 16, 0, 1, 1, 4, NULL, '12245@qq.com', '为了生活');
+INSERT INTO `b_thing` VALUES (6, '夜跑俱乐部', 'cover/1707036858212.jpeg', '就啊哈哈的观点嘎哈韩国', '13222221111', '9号教学楼', '0', '2024-02-04 16:54:43.049737', 3, 0, 0, 0, 1, NULL, '999888@qq.com', '为了跑步');
+
+-- ----------------------------
+-- Table structure for b_thing_collect
+-- ----------------------------
+DROP TABLE IF EXISTS `b_thing_collect`;
+CREATE TABLE `b_thing_collect` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `thing_id` bigint(20) NOT NULL,
+ `user_id` bigint(20) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `b_thing_collect_thing_id_user_id_45b9f252_uniq`(`thing_id`, `user_id`) USING BTREE,
+ INDEX `b_thing_collect_user_id_e5d69968_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_thing_collect_thing_id_8edce8b3_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_thing_collect_user_id_e5d69968_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_thing_collect
+-- ----------------------------
+INSERT INTO `b_thing_collect` VALUES (2, 1, 4);
+INSERT INTO `b_thing_collect` VALUES (1, 5, 4);
+
+-- ----------------------------
+-- Table structure for b_thing_tag
+-- ----------------------------
+DROP TABLE IF EXISTS `b_thing_tag`;
+CREATE TABLE `b_thing_tag` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `thing_id` bigint(20) NOT NULL,
+ `tag_id` bigint(20) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `b_thing_tag_thing_id_tag_id_a5d426b2_uniq`(`thing_id`, `tag_id`) USING BTREE,
+ INDEX `b_thing_tag_tag_id_d02b28a1_fk_b_tag_id`(`tag_id`) USING BTREE,
+ CONSTRAINT `b_thing_tag_tag_id_d02b28a1_fk_b_tag_id` FOREIGN KEY (`tag_id`) REFERENCES `b_tag` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_thing_tag_thing_id_fb8ecf3f_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 22 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_thing_tag
+-- ----------------------------
+INSERT INTO `b_thing_tag` VALUES (1, 1, 2);
+INSERT INTO `b_thing_tag` VALUES (2, 1, 3);
+INSERT INTO `b_thing_tag` VALUES (3, 1, 4);
+INSERT INTO `b_thing_tag` VALUES (4, 1, 5);
+INSERT INTO `b_thing_tag` VALUES (5, 2, 1);
+INSERT INTO `b_thing_tag` VALUES (6, 2, 2);
+INSERT INTO `b_thing_tag` VALUES (7, 2, 3);
+INSERT INTO `b_thing_tag` VALUES (8, 2, 5);
+INSERT INTO `b_thing_tag` VALUES (9, 3, 1);
+INSERT INTO `b_thing_tag` VALUES (10, 3, 2);
+INSERT INTO `b_thing_tag` VALUES (11, 3, 3);
+INSERT INTO `b_thing_tag` VALUES (12, 3, 4);
+INSERT INTO `b_thing_tag` VALUES (13, 3, 5);
+INSERT INTO `b_thing_tag` VALUES (14, 4, 2);
+INSERT INTO `b_thing_tag` VALUES (15, 4, 4);
+INSERT INTO `b_thing_tag` VALUES (16, 4, 5);
+INSERT INTO `b_thing_tag` VALUES (17, 5, 2);
+INSERT INTO `b_thing_tag` VALUES (18, 5, 4);
+INSERT INTO `b_thing_tag` VALUES (19, 6, 1);
+INSERT INTO `b_thing_tag` VALUES (20, 6, 2);
+INSERT INTO `b_thing_tag` VALUES (21, 6, 5);
+
+-- ----------------------------
+-- Table structure for b_thing_wish
+-- ----------------------------
+DROP TABLE IF EXISTS `b_thing_wish`;
+CREATE TABLE `b_thing_wish` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `thing_id` bigint(20) NOT NULL,
+ `user_id` bigint(20) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `b_thing_wish_thing_id_user_id_9d647bbb_uniq`(`thing_id`, `user_id`) USING BTREE,
+ INDEX `b_thing_wish_user_id_e2d94f6c_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_thing_wish_thing_id_f0864b16_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_thing_wish_user_id_e2d94f6c_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_thing_wish
+-- ----------------------------
+INSERT INTO `b_thing_wish` VALUES (2, 1, 4);
+INSERT INTO `b_thing_wish` VALUES (1, 5, 4);
+
+-- ----------------------------
+-- Table structure for b_user
+-- ----------------------------
+DROP TABLE IF EXISTS `b_user`;
+CREATE TABLE `b_user` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `username` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `password` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `role` varchar(2) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `status` varchar(1) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `nickname` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `avatar` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `mobile` varchar(13) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `email` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `gender` varchar(1) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `description` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ `score` int(11) NULL DEFAULT NULL,
+ `push_email` varchar(40) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `push_switch` tinyint(1) NULL DEFAULT NULL,
+ `admin_token` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `token` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_user
+-- ----------------------------
+INSERT INTO `b_user` VALUES (1, 'admin', '78aafd3207ec4ef6d16f9fc07e95ebc3', '1', '0', NULL, '', NULL, NULL, NULL, NULL, '2024-02-04 16:36:13.029265', 0, NULL, 0, '21232f297a57a5a743894a0e4a801fc3', NULL);
+INSERT INTO `b_user` VALUES (2, 'admin123', '0192023a7bbd73250516f069df18b500', '1', '0', NULL, '', NULL, NULL, NULL, NULL, '2024-02-04 16:40:18.754982', 0, NULL, 0, '0192023a7bbd73250516f069df18b500', NULL);
+INSERT INTO `b_user` VALUES (3, 'test', '098f6bcd4621d373cade4e832627b4f6', '3', '0', NULL, '', NULL, NULL, NULL, NULL, '2024-02-04 16:40:35.603385', 0, NULL, 0, NULL, NULL);
+INSERT INTO `b_user` VALUES (4, 'aaa', '47bce5c74f589f4867dbd57e9ca9f808', '2', '0', '1233', '', NULL, NULL, NULL, NULL, '2024-02-04 16:57:07.608626', 0, NULL, 0, NULL, '47bce5c74f589f4867dbd57e9ca9f808');
+
+-- ----------------------------
+-- Table structure for django_admin_log
+-- ----------------------------
+DROP TABLE IF EXISTS `django_admin_log`;
+CREATE TABLE `django_admin_log` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `action_time` datetime(6) NOT NULL,
+ `object_id` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL,
+ `object_repr` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `action_flag` smallint(5) UNSIGNED NOT NULL,
+ `change_message` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `content_type_id` int(11) NULL DEFAULT NULL,
+ `user_id` int(11) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `django_admin_log_content_type_id_c4bce8eb_fk_django_co`(`content_type_id`) USING BTREE,
+ INDEX `django_admin_log_user_id_c564eba6_fk_auth_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `django_admin_log_content_type_id_c4bce8eb_fk_django_co` FOREIGN KEY (`content_type_id`) REFERENCES `django_content_type` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `django_admin_log_user_id_c564eba6_fk_auth_user_id` FOREIGN KEY (`user_id`) REFERENCES `auth_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of django_admin_log
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for django_content_type
+-- ----------------------------
+DROP TABLE IF EXISTS `django_content_type`;
+CREATE TABLE `django_content_type` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `app_label` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `model` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `django_content_type_app_label_model_76bd3d3b_uniq`(`app_label`, `model`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 22 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of django_content_type
+-- ----------------------------
+INSERT INTO `django_content_type` VALUES (1, 'admin', 'logentry');
+INSERT INTO `django_content_type` VALUES (3, 'auth', 'group');
+INSERT INTO `django_content_type` VALUES (2, 'auth', 'permission');
+INSERT INTO `django_content_type` VALUES (4, 'auth', 'user');
+INSERT INTO `django_content_type` VALUES (5, 'contenttypes', 'contenttype');
+INSERT INTO `django_content_type` VALUES (7, 'myapp', 'ad');
+INSERT INTO `django_content_type` VALUES (21, 'myapp', 'address');
+INSERT INTO `django_content_type` VALUES (20, 'myapp', 'banner');
+INSERT INTO `django_content_type` VALUES (8, 'myapp', 'classification');
+INSERT INTO `django_content_type` VALUES (19, 'myapp', 'comment');
+INSERT INTO `django_content_type` VALUES (9, 'myapp', 'errorlog');
+INSERT INTO `django_content_type` VALUES (10, 'myapp', 'loginlog');
+INSERT INTO `django_content_type` VALUES (11, 'myapp', 'notice');
+INSERT INTO `django_content_type` VALUES (12, 'myapp', 'oplog');
+INSERT INTO `django_content_type` VALUES (18, 'myapp', 'order');
+INSERT INTO `django_content_type` VALUES (17, 'myapp', 'orderlog');
+INSERT INTO `django_content_type` VALUES (16, 'myapp', 'record');
+INSERT INTO `django_content_type` VALUES (13, 'myapp', 'tag');
+INSERT INTO `django_content_type` VALUES (15, 'myapp', 'thing');
+INSERT INTO `django_content_type` VALUES (14, 'myapp', 'user');
+INSERT INTO `django_content_type` VALUES (6, 'sessions', 'session');
+
+-- ----------------------------
+-- Table structure for django_migrations
+-- ----------------------------
+DROP TABLE IF EXISTS `django_migrations`;
+CREATE TABLE `django_migrations` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `app` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `applied` datetime(6) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 22 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of django_migrations
+-- ----------------------------
+INSERT INTO `django_migrations` VALUES (1, 'contenttypes', '0001_initial', '2024-02-04 16:32:51.298695');
+INSERT INTO `django_migrations` VALUES (2, 'auth', '0001_initial', '2024-02-04 16:32:51.549701');
+INSERT INTO `django_migrations` VALUES (3, 'admin', '0001_initial', '2024-02-04 16:32:51.606242');
+INSERT INTO `django_migrations` VALUES (4, 'admin', '0002_logentry_remove_auto_add', '2024-02-04 16:32:51.613953');
+INSERT INTO `django_migrations` VALUES (5, 'admin', '0003_logentry_add_action_flag_choices', '2024-02-04 16:32:51.619196');
+INSERT INTO `django_migrations` VALUES (6, 'contenttypes', '0002_remove_content_type_name', '2024-02-04 16:32:51.687139');
+INSERT INTO `django_migrations` VALUES (7, 'auth', '0002_alter_permission_name_max_length', '2024-02-04 16:32:51.729044');
+INSERT INTO `django_migrations` VALUES (8, 'auth', '0003_alter_user_email_max_length', '2024-02-04 16:32:51.771331');
+INSERT INTO `django_migrations` VALUES (9, 'auth', '0004_alter_user_username_opts', '2024-02-04 16:32:51.777711');
+INSERT INTO `django_migrations` VALUES (10, 'auth', '0005_alter_user_last_login_null', '2024-02-04 16:32:51.813729');
+INSERT INTO `django_migrations` VALUES (11, 'auth', '0006_require_contenttypes_0002', '2024-02-04 16:32:51.817877');
+INSERT INTO `django_migrations` VALUES (12, 'auth', '0007_alter_validators_add_error_messages', '2024-02-04 16:32:51.823354');
+INSERT INTO `django_migrations` VALUES (13, 'auth', '0008_alter_user_username_max_length', '2024-02-04 16:32:51.865155');
+INSERT INTO `django_migrations` VALUES (14, 'auth', '0009_alter_user_last_name_max_length', '2024-02-04 16:32:51.907643');
+INSERT INTO `django_migrations` VALUES (15, 'auth', '0010_alter_group_name_max_length', '2024-02-04 16:32:51.951019');
+INSERT INTO `django_migrations` VALUES (16, 'auth', '0011_update_proxy_permissions', '2024-02-04 16:32:51.958587');
+INSERT INTO `django_migrations` VALUES (17, 'auth', '0012_alter_user_first_name_max_length', '2024-02-04 16:32:52.003585');
+INSERT INTO `django_migrations` VALUES (18, 'myapp', '0001_initial', '2024-02-04 16:32:52.698876');
+INSERT INTO `django_migrations` VALUES (19, 'myapp', '0002_thing_user', '2024-02-04 16:32:52.738582');
+INSERT INTO `django_migrations` VALUES (20, 'myapp', '0003_auto_20240204_1632', '2024-02-04 16:32:52.933013');
+INSERT INTO `django_migrations` VALUES (21, 'sessions', '0001_initial', '2024-02-04 16:32:52.969896');
+
+-- ----------------------------
+-- Table structure for django_session
+-- ----------------------------
+DROP TABLE IF EXISTS `django_session`;
+CREATE TABLE `django_session` (
+ `session_key` varchar(40) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `session_data` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `expire_date` datetime(6) NOT NULL,
+ PRIMARY KEY (`session_key`) USING BTREE,
+ INDEX `django_session_expire_date_a5c62663`(`expire_date`) USING BTREE
+) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of django_session
+-- ----------------------------
+
+SET FOREIGN_KEY_CHECKS = 1;
diff --git a/model/server/manage.py b/model/server/manage.py
new file mode 100644
index 0000000..8b46ee6
--- /dev/null
+++ b/model/server/manage.py
@@ -0,0 +1,22 @@
+#!/usr/bin/env python
+"""Django's command-line utility for administrative tasks."""
+import os
+import sys
+
+
+def main():
+ """Run administrative tasks."""
+ os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'server.settings')
+ try:
+ from django.core.management import execute_from_command_line
+ except ImportError as exc:
+ raise ImportError(
+ "Couldn't import Django. Are you sure it's installed and "
+ "available on your PYTHONPATH environment variable? Did you "
+ "forget to activate a virtual environment?"
+ ) from exc
+ execute_from_command_line(sys.argv)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/model/server/myapp/__init__.py b/model/server/myapp/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/model/server/myapp/admin.py b/model/server/myapp/admin.py
new file mode 100644
index 0000000..8fd81b2
--- /dev/null
+++ b/model/server/myapp/admin.py
@@ -0,0 +1,10 @@
+from django.contrib import admin
+
+# Register your models here.
+from myapp.models import Classification, Thing, Tag, User, Comment
+
+admin.site.register(Classification)
+admin.site.register(Tag)
+admin.site.register(Thing)
+admin.site.register(User)
+admin.site.register(Comment)
diff --git a/model/server/myapp/apps.py b/model/server/myapp/apps.py
new file mode 100644
index 0000000..c34fb20
--- /dev/null
+++ b/model/server/myapp/apps.py
@@ -0,0 +1,6 @@
+from django.apps import AppConfig
+
+
+class MyappConfig(AppConfig):
+ default_auto_field = 'django.db.models.BigAutoField'
+ name = 'myapp'
diff --git a/model/server/myapp/auth/MyRateThrottle.py b/model/server/myapp/auth/MyRateThrottle.py
new file mode 100644
index 0000000..4ffdf9d
--- /dev/null
+++ b/model/server/myapp/auth/MyRateThrottle.py
@@ -0,0 +1,5 @@
+from rest_framework.throttling import AnonRateThrottle
+
+
+class MyRateThrottle(AnonRateThrottle):
+ THROTTLE_RATES = {"anon": "2/min"}
diff --git a/model/server/myapp/auth/__init__.py b/model/server/myapp/auth/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/model/server/myapp/auth/authentication.py b/model/server/myapp/auth/authentication.py
new file mode 100644
index 0000000..a0706b5
--- /dev/null
+++ b/model/server/myapp/auth/authentication.py
@@ -0,0 +1,46 @@
+from rest_framework import exceptions
+from rest_framework.authentication import BaseAuthentication
+
+from myapp.models import User
+
+
+# 后台接口认证
+class AdminTokenAuthtication(BaseAuthentication):
+ def authenticate(self, request):
+ adminToken = request.META.get("HTTP_ADMINTOKEN")
+
+ print("检查adminToken==>" + adminToken)
+ users = User.objects.filter(admin_token=adminToken)
+ """
+ 判定条件:
+ 1. 传了adminToken
+ 2. 查到了该帐号
+ 3. 该帐号是管理员或演示帐号
+ """
+ if not adminToken or len(users) == 0 or users[0].role == '2':
+ raise exceptions.AuthenticationFailed("AUTH_FAIL_END")
+ else:
+ print('adminToken验证通过')
+
+
+# 前台接口认证
+class TokenAuthtication(BaseAuthentication):
+ def authenticate(self, request):
+ token = request.META.get("HTTP_TOKEN", "")
+ if token is not None:
+ print("检查token==>" + token)
+ users = User.objects.filter(token=token)
+ # print(users)
+ """
+ 判定条件:
+ 1. 传了token
+ 2. 查到了该帐号
+ 3. 该帐号是普通用户
+ """
+ if not token or len(users) == 0 or (users[0].role in ['1', '3']):
+ raise exceptions.AuthenticationFailed("AUTH_FAIL_FRONT")
+ else:
+ print('token验证通过')
+ else:
+ print("检查token==>token 为空")
+ raise exceptions.AuthenticationFailed("AUTH_FAIL_FRONT")
diff --git a/model/server/myapp/handler.py b/model/server/myapp/handler.py
new file mode 100644
index 0000000..ee06acc
--- /dev/null
+++ b/model/server/myapp/handler.py
@@ -0,0 +1,13 @@
+from rest_framework.response import Response
+
+
+class APIResponse(Response):
+ def __init__(self, code=0, msg='', data=None, status=200, headers=None, content_type=None, **kwargs):
+ dic = {'code': code, 'msg': msg}
+ if data is not None:
+ dic['data'] = data
+
+ dic.update(kwargs) # 这里使用update
+ super().__init__(data=dic, status=status,
+ template_name=None, headers=headers,
+ exception=False, content_type=content_type)
diff --git a/model/server/myapp/middlewares/LogMiddleware.py b/model/server/myapp/middlewares/LogMiddleware.py
new file mode 100644
index 0000000..3ba8fa4
--- /dev/null
+++ b/model/server/myapp/middlewares/LogMiddleware.py
@@ -0,0 +1,54 @@
+# -*- coding:utf-8 -*-
+import time
+import json
+
+from django.utils.deprecation import MiddlewareMixin
+
+from myapp import utils
+from myapp.serializers import OpLogSerializer
+
+
+class OpLogs(MiddlewareMixin):
+
+ def __init__(self, *args):
+ super(OpLogs, self).__init__(*args)
+
+ self.start_time = None # 开始时间
+ self.end_time = None # 响应时间
+ self.data = {} # dict数据
+
+ def process_request(self, request):
+
+ self.start_time = time.time() # 开始时间
+
+ re_ip = utils.get_ip(request)
+ re_method = request.method
+ re_content = request.GET if re_method == 'GET' else request.POST
+ if re_content:
+ re_content = json.dumps(re_content)
+ else:
+ re_content = None
+
+ self.data.update(
+ {
+ 're_url': request.path,
+ 're_method': re_method,
+ 're_ip': re_ip,
+ # 're_content': re_content,
+ }
+ )
+ # print(self.data)
+
+ def process_response(self, request, response):
+
+ # 耗时毫秒/ms
+ self.end_time = time.time() # 响应时间
+ access_time = self.end_time - self.start_time
+ self.data['access_time'] = round(access_time * 1000)
+
+ # 入库
+ # serializer = OpLogSerializer(data=self.data)
+ # if serializer.is_valid():
+ # serializer.save()
+
+ return response
diff --git a/model/server/myapp/middlewares/__init__.py b/model/server/myapp/middlewares/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/model/server/myapp/models.py b/model/server/myapp/models.py
new file mode 100644
index 0000000..da2b276
--- /dev/null
+++ b/model/server/myapp/models.py
@@ -0,0 +1,221 @@
+from django.db import models
+
+
+class User(models.Model):
+ GENDER_CHOICES = (
+ ('M', '男'),
+ ('F', '女'),
+ )
+ ROLE_CHOICES = (
+ ('0', '管理员'),
+ ('1', '普通用户'),
+ )
+ STATUS_CHOICES = (
+ ('0', '正常'),
+ ('1', '封号'),
+ )
+ id = models.BigAutoField(primary_key=True)
+ username = models.CharField(max_length=50, null=True)
+ password = models.CharField(max_length=50, null=True)
+ role = models.CharField(max_length=2, blank=True, null=True)
+ status = models.CharField(max_length=1, choices=STATUS_CHOICES, default='0')
+ nickname = models.CharField(blank=True, null=True, max_length=20)
+ avatar = models.FileField(upload_to='avatar/', null=True)
+ mobile = models.CharField(max_length=13, blank=True, null=True)
+ email = models.CharField(max_length=50, blank=True, null=True)
+ gender = models.CharField(max_length=1, choices=GENDER_CHOICES, blank=True, null=True)
+ description = models.TextField(max_length=200, null=True)
+ create_time = models.DateTimeField(auto_now_add=True, null=True)
+ score = models.IntegerField(default=0, blank=True, null=True)
+ push_email = models.CharField(max_length=40, blank=True, null=True)
+ push_switch = models.BooleanField(blank=True, null=True, default=False)
+ admin_token = models.CharField(max_length=32, blank=True, null=True)
+ token = models.CharField(max_length=32, blank=True, null=True)
+
+ class Meta:
+ db_table = "b_user"
+
+
+class Tag(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ title = models.CharField(max_length=100, blank=True, null=True)
+ create_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_tag"
+
+
+class Classification(models.Model):
+ list_display = ("title", "id")
+ id = models.BigAutoField(primary_key=True)
+ title = models.CharField(max_length=100, blank=True, null=True)
+ create_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ def __str__(self):
+ return self.title
+
+ class Meta:
+ db_table = "b_classification"
+
+
+class Thing(models.Model):
+ STATUS_CHOICES = (
+ ('0', '上架'),
+ ('1', '下架'),
+ )
+ id = models.BigAutoField(primary_key=True)
+ classification = models.ForeignKey(Classification, on_delete=models.CASCADE, blank=True, null=True,
+ related_name='classification_thing')
+ user = models.ForeignKey(User, on_delete=models.CASCADE, blank=True, null=True, related_name='user_thing')
+ tag = models.ManyToManyField(Tag, blank=True)
+ title = models.CharField(max_length=100, blank=True, null=True)
+ cover = models.ImageField(upload_to='cover/', null=True)
+ description = models.TextField(max_length=1000, blank=True, null=True)
+ zongzhi = models.CharField(max_length=200, blank=True, null=True)
+ email = models.CharField(max_length=200, blank=True, null=True)
+ mobile = models.CharField(max_length=50, blank=True, null=True)
+ location = models.CharField(max_length=50, blank=True, null=True)
+ status = models.CharField(max_length=1, choices=STATUS_CHOICES, default='0')
+ create_time = models.DateTimeField(auto_now_add=True, null=True)
+ pv = models.IntegerField(default=0)
+ recommend_count = models.IntegerField(default=0)
+ wish = models.ManyToManyField(User, blank=True, related_name="wish_things")
+ wish_count = models.IntegerField(default=0)
+ collect = models.ManyToManyField(User, blank=True, related_name="collect_things")
+ collect_count = models.IntegerField(default=0)
+
+ class Meta:
+ db_table = "b_thing"
+
+
+class Comment(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ content = models.CharField(max_length=200, blank=True, null=True)
+ user = models.ForeignKey(User, on_delete=models.CASCADE, null=True, related_name='user_comment')
+ thing = models.ForeignKey(Thing, on_delete=models.CASCADE, null=True, related_name='thing_comment')
+ comment_time = models.DateTimeField(auto_now_add=True, null=True)
+ like_count = models.IntegerField(default=0)
+
+ class Meta:
+ db_table = "b_comment"
+
+
+class Record(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ user = models.ForeignKey(User, on_delete=models.CASCADE, null=True, related_name='user_record')
+ thing = models.ForeignKey(Thing, on_delete=models.CASCADE, null=True, related_name='thing_record')
+ title = models.CharField(max_length=100, blank=True, null=True)
+ classification = models.ForeignKey(Classification, on_delete=models.CASCADE, null=True,
+ related_name='classification')
+ record_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_record"
+
+
+class LoginLog(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ username = models.CharField(max_length=50, blank=True, null=True)
+ ip = models.CharField(max_length=100, blank=True, null=True)
+ ua = models.CharField(max_length=200, blank=True, null=True)
+ log_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_login_log"
+
+
+class OpLog(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ re_ip = models.CharField(max_length=100, blank=True, null=True)
+ re_time = models.DateTimeField(auto_now_add=True, null=True)
+ re_url = models.CharField(max_length=200, blank=True, null=True)
+ re_method = models.CharField(max_length=10, blank=True, null=True)
+ re_content = models.CharField(max_length=200, blank=True, null=True)
+ access_time = models.CharField(max_length=10, blank=True, null=True)
+
+ class Meta:
+ db_table = "b_op_log"
+
+
+class ErrorLog(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ ip = models.CharField(max_length=100, blank=True, null=True)
+ url = models.CharField(max_length=200, blank=True, null=True)
+ method = models.CharField(max_length=10, blank=True, null=True)
+ content = models.CharField(max_length=200, blank=True, null=True)
+ log_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_error_log"
+
+
+class Order(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ order_number = models.CharField(max_length=13, blank=True, null=True)
+ user = models.ForeignKey(User, on_delete=models.CASCADE, null=True, related_name='user_order')
+ thing = models.ForeignKey(Thing, on_delete=models.CASCADE, null=True, related_name='thing_order')
+ count = models.IntegerField(default=0)
+ status = models.CharField(max_length=2, blank=True, null=True) # 1未审核 2已审核 7取消
+ order_time = models.DateTimeField(auto_now_add=True, null=True)
+ pay_time = models.DateTimeField(null=True)
+ receiver_name = models.CharField(max_length=20, blank=True, null=True)
+ receiver_address = models.CharField(max_length=50, blank=True, null=True)
+ receiver_phone = models.CharField(max_length=20, blank=True, null=True)
+ remark = models.CharField(max_length=30, blank=True, null=True)
+
+ class Meta:
+ db_table = "b_order"
+
+
+class OrderLog(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ user = models.ForeignKey(User, on_delete=models.CASCADE, null=True, related_name='user_order_log')
+ thing = models.ForeignKey(Thing, on_delete=models.CASCADE, null=True, related_name='thing_order_log')
+ action = models.CharField(max_length=2, blank=True, null=True)
+ log_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_order_log"
+
+
+class Banner(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ image = models.ImageField(upload_to='banner/', null=True)
+ thing = models.ForeignKey(Thing, on_delete=models.CASCADE, null=True, related_name='thing_banner')
+ create_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_banner"
+
+
+class Ad(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ image = models.ImageField(upload_to='ad/', null=True)
+ link = models.CharField(max_length=500, blank=True, null=True)
+ create_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_ad"
+
+
+class Notice(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ title = models.CharField(max_length=100, blank=True, null=True)
+ content = models.CharField(max_length=1000, blank=True, null=True)
+ create_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_notice"
+
+
+class Address(models.Model):
+ id = models.BigAutoField(primary_key=True)
+ user = models.ForeignKey(User, on_delete=models.CASCADE, null=True, related_name='user_address')
+ name = models.CharField(max_length=100, blank=True, null=True)
+ mobile = models.CharField(max_length=30, blank=True, null=True)
+ desc = models.CharField(max_length=300, blank=True, null=True)
+ default = models.BooleanField(blank=True, null=True, default=False) # 是否默认地址
+ create_time = models.DateTimeField(auto_now_add=True, null=True)
+
+ class Meta:
+ db_table = "b_address"
diff --git a/model/server/myapp/permission/__init__.py b/model/server/myapp/permission/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/model/server/myapp/permission/permission.py b/model/server/myapp/permission/permission.py
new file mode 100644
index 0000000..e25a1e8
--- /dev/null
+++ b/model/server/myapp/permission/permission.py
@@ -0,0 +1,12 @@
+from myapp.models import User
+
+
+def isDemoAdminUser(request):
+ adminToken = request.META.get("HTTP_ADMINTOKEN")
+ users = User.objects.filter(admin_token=adminToken)
+ if len(users) > 0:
+ user = users[0]
+ if user.role == '3': # (角色3)表示演示帐号
+ print('演示帐号===>')
+ return True
+ return False
diff --git a/model/server/myapp/serializers.py b/model/server/myapp/serializers.py
new file mode 100644
index 0000000..b16dcac
--- /dev/null
+++ b/model/server/myapp/serializers.py
@@ -0,0 +1,160 @@
+from rest_framework import serializers
+
+from myapp.models import Thing, Classification, Tag, User, Comment, Record, LoginLog, Order, OrderLog, OpLog, Banner, \
+ Ad, Notice, ErrorLog, Address
+
+
+class ThingSerializer(serializers.ModelSerializer):
+ # 额外字段
+ classification_title = serializers.ReadOnlyField(source='classification.title')
+
+ class Meta:
+ model = Thing
+ fields = '__all__'
+
+
+class DetailThingSerializer(serializers.ModelSerializer):
+ # 额外字段
+ classification_title = serializers.ReadOnlyField(source='classification.title')
+
+ class Meta:
+ model = Thing
+ # 排除多对多字段
+ exclude = ('wish', 'collect',)
+
+
+class UpdateThingSerializer(serializers.ModelSerializer):
+ # 额外字段
+ classification_title = serializers.ReadOnlyField(source='classification.title')
+
+ class Meta:
+ model = Thing
+ # 排除多对多字段
+ exclude = ('wish', 'collect',)
+
+
+class ListThingSerializer(serializers.ModelSerializer):
+ # 额外字段
+ classification_title = serializers.ReadOnlyField(source='classification.title')
+
+ class Meta:
+ model = Thing
+ # 排除字段
+ exclude = ('wish', 'collect',)
+
+
+class ClassificationSerializer(serializers.ModelSerializer):
+ class Meta:
+ model = Classification
+ fields = '__all__'
+
+
+class TagSerializer(serializers.ModelSerializer):
+ class Meta:
+ model = Tag
+ fields = '__all__'
+
+
+class UserSerializer(serializers.ModelSerializer):
+ create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+
+ class Meta:
+ model = User
+ fields = '__all__'
+ # exclude = ('password',)
+
+
+class CommentSerializer(serializers.ModelSerializer):
+ comment_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+ # 额外字段
+ title = serializers.ReadOnlyField(source='thing.title')
+ username = serializers.ReadOnlyField(source='user.username')
+
+ class Meta:
+ model = Comment
+ fields = ['id', 'content', 'comment_time', 'like_count', 'thing', 'user', 'title', 'username']
+
+
+class RecordSerializer(serializers.ModelSerializer):
+ class Meta:
+ model = Record
+ fields = '__all__'
+
+
+class LoginLogSerializer(serializers.ModelSerializer):
+ log_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+
+ class Meta:
+ model = LoginLog
+ fields = '__all__'
+
+
+class OpLogSerializer(serializers.ModelSerializer):
+ re_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+
+ class Meta:
+ model = OpLog
+ fields = '__all__'
+
+
+class ErrorLogSerializer(serializers.ModelSerializer):
+ log_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+
+ class Meta:
+ model = ErrorLog
+ fields = '__all__'
+
+
+class OrderSerializer(serializers.ModelSerializer):
+ order_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+ expect_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+ return_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+ # extra
+ username = serializers.ReadOnlyField(source='user.username')
+ title = serializers.ReadOnlyField(source='thing.title')
+ price = serializers.ReadOnlyField(source='thing.price')
+ cover = serializers.FileField(source='thing.cover', required=False)
+
+ class Meta:
+ model = Order
+ fields = '__all__'
+
+
+class OrderLogSerializer(serializers.ModelSerializer):
+ class Meta:
+ model = OrderLog
+ fields = '__all__'
+
+
+class BannerSerializer(serializers.ModelSerializer):
+ create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+ # extra
+ title = serializers.ReadOnlyField(source='thing.title')
+
+ class Meta:
+ model = Banner
+ fields = '__all__'
+
+
+class AdSerializer(serializers.ModelSerializer):
+ create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+
+ class Meta:
+ model = Ad
+ fields = '__all__'
+
+
+class NoticeSerializer(serializers.ModelSerializer):
+ create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+
+ class Meta:
+ model = Notice
+ fields = '__all__'
+
+
+class AddressSerializer(serializers.ModelSerializer):
+ create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
+
+ class Meta:
+ model = Address
+ fields = '__all__'
diff --git a/model/server/myapp/tests.py b/model/server/myapp/tests.py
new file mode 100644
index 0000000..7ce503c
--- /dev/null
+++ b/model/server/myapp/tests.py
@@ -0,0 +1,3 @@
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/model/server/myapp/urls.py b/model/server/myapp/urls.py
new file mode 100644
index 0000000..d06086c
--- /dev/null
+++ b/model/server/myapp/urls.py
@@ -0,0 +1,102 @@
+from django.urls import path
+
+from myapp import views
+
+app_name = 'myapp'
+urlpatterns = [
+ # 后台管理api
+ path('admin/overview/count', views.admin.overview.count),
+ path('admin/overview/sysInfo', views.admin.overview.sysInfo),
+ path('admin/thing/list', views.admin.thing.list_api),
+ path('admin/thing/detail', views.admin.thing.detail),
+ path('admin/thing/create', views.admin.thing.create),
+ path('admin/thing/update', views.admin.thing.update),
+ path('admin/thing/delete', views.admin.thing.delete),
+ path('admin/comment/list', views.admin.comment.list_api),
+ path('admin/comment/create', views.admin.comment.create),
+ path('admin/comment/update', views.admin.comment.update),
+ path('admin/comment/delete', views.admin.comment.delete),
+ path('admin/classification/list', views.admin.classification.list_api),
+ path('admin/classification/create', views.admin.classification.create),
+ path('admin/classification/update', views.admin.classification.update),
+ path('admin/classification/delete', views.admin.classification.delete),
+ path('admin/tag/list', views.admin.tag.list_api),
+ path('admin/tag/create', views.admin.tag.create),
+ path('admin/tag/update', views.admin.tag.update),
+ path('admin/tag/delete', views.admin.tag.delete),
+ path('admin/record/list', views.admin.record.list_api),
+ path('admin/record/create', views.admin.record.create),
+ path('admin/record/update', views.admin.record.update),
+ path('admin/record/delete', views.admin.record.delete),
+ path('admin/banner/list', views.admin.banner.list_api),
+ path('admin/banner/create', views.admin.banner.create),
+ path('admin/banner/update', views.admin.banner.update),
+ path('admin/banner/delete', views.admin.banner.delete),
+ path('admin/ad/list', views.admin.ad.list_api),
+ path('admin/ad/create', views.admin.ad.create),
+ path('admin/ad/update', views.admin.ad.update),
+ path('admin/ad/delete', views.admin.ad.delete),
+ path('admin/notice/list', views.admin.notice.list_api),
+ path('admin/notice/create', views.admin.notice.create),
+ path('admin/notice/update', views.admin.notice.update),
+ path('admin/notice/delete', views.admin.notice.delete),
+ path('admin/order/list', views.admin.order.list_api),
+ path('admin/order/create', views.admin.order.create),
+ path('admin/order/update', views.admin.order.update),
+ path('admin/order/cancel_order', views.admin.order.cancel_order),
+ path('admin/order/pass_order', views.admin.order.pass_order),
+ path('admin/order/delay', views.admin.order.delay),
+ path('admin/order/delete', views.admin.order.delete),
+ path('admin/loginLog/list', views.admin.loginLog.list_api),
+ path('admin/loginLog/create', views.admin.loginLog.create),
+ path('admin/loginLog/update', views.admin.loginLog.update),
+ path('admin/loginLog/delete', views.admin.loginLog.delete),
+ path('admin/opLog/list', views.admin.opLog.list_api),
+ path('admin/errorLog/list', views.admin.errorLog.list_api),
+ path('admin/user/list', views.admin.user.list_api),
+ path('admin/user/create', views.admin.user.create),
+ path('admin/user/update', views.admin.user.update),
+ path('admin/user/updatePwd', views.admin.user.updatePwd),
+ path('admin/user/delete', views.admin.user.delete),
+ path('admin/user/info', views.admin.user.info),
+ path('admin/adminLogin', views.admin.user.admin_login),
+
+
+ # 前台管理api
+ path('index/classification/list', views.index.classification.list_api),
+ path('index/tag/list', views.index.tag.list_api),
+ path('index/user/login', views.index.user.login),
+ path('index/user/register', views.index.user.register),
+ path('index/user/info', views.index.user.info),
+ path('index/user/update', views.index.user.update),
+ path('index/user/updatePwd', views.index.user.updatePwd),
+ path('index/notice/list_api', views.index.notice.list_api),
+ path('index/thing/list', views.index.thing.list_api),
+ path('index/thing/detail', views.index.thing.detail),
+ path('index/thing/increaseWishCount', views.index.thing.increaseWishCount),
+ path('index/thing/addWishUser', views.index.thing.addWishUser),
+ path('index/thing/removeWishUser', views.index.thing.removeWishUser),
+ path('index/thing/getWishThingList', views.index.thing.getWishThingList),
+ path('index/thing/addCollectUser', views.index.thing.addCollectUser),
+ path('index/thing/removeCollectUser', views.index.thing.removeCollectUser),
+ path('index/thing/getCollectThingList', views.index.thing.getCollectThingList),
+ path('index/thing/increaseRecommendCount', views.index.thing.increaseRecommendCount),
+ path('index/thing/listUserThing', views.index.thing.list_user_thing_api),
+ path('index/thing/create', views.index.thing.create),
+ path('index/thing/update', views.index.thing.update),
+ path('index/comment/list', views.index.comment.list_api),
+ path('index/comment/listMyComments', views.index.comment.list_my_comment),
+ path('index/comment/create', views.index.comment.create),
+ path('index/comment/delete', views.index.comment.delete),
+ path('index/comment/like', views.index.comment.like),
+ path('index/order/list', views.index.order.list_api),
+ path('index/order/create', views.index.order.create),
+ path('index/order/cancel_order', views.index.order.cancel_order),
+ path('index/address/list', views.index.address.list_api),
+ path('index/address/create', views.index.address.create),
+ path('index/address/update', views.index.address.update),
+ path('index/address/delete', views.index.address.delete),
+
+
+
+]
diff --git a/model/server/myapp/utils.py b/model/server/myapp/utils.py
new file mode 100644
index 0000000..355a0e2
--- /dev/null
+++ b/model/server/myapp/utils.py
@@ -0,0 +1,87 @@
+import datetime
+import hashlib
+import time
+
+from rest_framework.views import exception_handler
+
+from myapp.serializers import ErrorLogSerializer
+
+def get_timestamp():
+ return int(round(time.time() * 1000))
+
+def md5value(key):
+ input_name = hashlib.md5()
+ input_name.update(key.encode("utf-8"))
+ md5str = (input_name.hexdigest()).lower()
+ print('计算md5:', md5str)
+ return md5str
+
+
+def dict_fetchall(cursor): # cursor是执行sql_str后的记录,作入参
+ columns = [col[0] for col in cursor.description] # 得到域的名字col[0],组成List
+ return [
+ dict(zip(columns, row)) for row in cursor.fetchall()
+ ]
+
+
+def get_ip(request):
+ """
+ 获取请求者的IP信息
+ """
+ x_forwarded_for = request.META.get('HTTP_X_FORWARDED_FOR')
+ if x_forwarded_for:
+ ip = x_forwarded_for.split(',')[0]
+ else:
+ ip = request.META.get('REMOTE_ADDR')
+ return ip
+
+
+def get_ua(request):
+ """
+ 获取请求者的IP信息
+ """
+ ua = request.META.get('HTTP_USER_AGENT')
+ return ua[0:200]
+
+
+def getWeekDays():
+ """
+ 获取近一周的日期
+ """
+ week_days = []
+ now = datetime.datetime.now()
+ for i in range(7):
+ day = now - datetime.timedelta(days=i)
+ week_days.append(day.strftime('%Y-%m-%d %H:%M:%S.%f')[:10])
+ week_days.reverse() # 逆序
+ return week_days
+
+
+def get_monday():
+ """
+ 获取本周周一日期
+ """
+ now = datetime.datetime.now()
+ monday = now - datetime.timedelta(now.weekday())
+ return monday.strftime('%Y-%m-%d %H:%M:%S.%f')[:10]
+
+
+def log_error(request, content):
+ """
+ 记录错误日志
+ """
+ ip = get_ip(request)
+ method = request.method
+ url = request.path
+
+ data = {
+ 'ip': ip,
+ 'method': method,
+ 'url': url,
+ 'content': content
+ }
+
+ # 入库
+ serializer = ErrorLogSerializer(data=data)
+ if serializer.is_valid():
+ serializer.save()
diff --git a/model/server/myapp/views/__init__.py b/model/server/myapp/views/__init__.py
new file mode 100644
index 0000000..1cc8053
--- /dev/null
+++ b/model/server/myapp/views/__init__.py
@@ -0,0 +1,2 @@
+from myapp.views.admin import *
+from myapp.views.index import *
diff --git a/model/server/myapp/views/admin/__init__.py b/model/server/myapp/views/admin/__init__.py
new file mode 100644
index 0000000..83212ae
--- /dev/null
+++ b/model/server/myapp/views/admin/__init__.py
@@ -0,0 +1,14 @@
+from myapp.views.admin.thing import *
+from myapp.views.admin.classification import *
+from myapp.views.admin.tag import *
+from myapp.views.admin.user import *
+from myapp.views.admin.comment import *
+from myapp.views.admin.record import *
+from myapp.views.admin.overview import *
+from myapp.views.admin.loginLog import *
+from myapp.views.admin.order import *
+from myapp.views.admin.opLog import *
+from myapp.views.admin.errorLog import *
+from myapp.views.admin.banner import *
+from myapp.views.admin.ad import *
+from myapp.views.admin.notice import *
diff --git a/model/server/myapp/views/admin/ad.py b/model/server/myapp/views/admin/ad.py
new file mode 100644
index 0000000..92a2ad5
--- /dev/null
+++ b/model/server/myapp/views/admin/ad.py
@@ -0,0 +1,68 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Ad
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import AdSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ ads = Ad.objects.all().order_by('-create_time')
+ serializer = AdSerializer(ads, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ serializer = AdSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ ad = Ad.objects.get(pk=pk)
+ except Ad.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = AdSerializer(ad, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Ad.objects.filter(id__in=ids_arr).delete()
+ except Ad.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/banner.py b/model/server/myapp/views/admin/banner.py
new file mode 100644
index 0000000..a280cbc
--- /dev/null
+++ b/model/server/myapp/views/admin/banner.py
@@ -0,0 +1,68 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Banner
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import BannerSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ banners = Banner.objects.all().order_by('-create_time')
+ serializer = BannerSerializer(banners, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ serializer = BannerSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ banner = Banner.objects.get(pk=pk)
+ except Banner.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = BannerSerializer(banner, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Banner.objects.filter(id__in=ids_arr).delete()
+ except Banner.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/classification.py b/model/server/myapp/views/admin/classification.py
new file mode 100644
index 0000000..24e7758
--- /dev/null
+++ b/model/server/myapp/views/admin/classification.py
@@ -0,0 +1,74 @@
+# Create your views here.
+from django.db import connection
+from django.db.models import Q
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Classification
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import ClassificationSerializer
+from myapp.utils import dict_fetchall
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ classifications = Classification.objects.all().order_by('-create_time')
+ serializer = ClassificationSerializer(classifications, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ classification = Classification.objects.filter(title=request.data['title'])
+ if len(classification) > 0:
+ return APIResponse(code=1, msg='该名称已存在')
+
+ serializer = ClassificationSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ print(pk)
+ classification = Classification.objects.get(pk=pk)
+ except Classification.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = ClassificationSerializer(classification, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ # 删除自身和自身的子孩子
+ Classification.objects.filter(Q(id__in=ids_arr)).delete()
+ except Classification.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/comment.py b/model/server/myapp/views/admin/comment.py
new file mode 100644
index 0000000..c9628e5
--- /dev/null
+++ b/model/server/myapp/views/admin/comment.py
@@ -0,0 +1,69 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Comment
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import CommentSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ comments = Comment.objects.select_related("thing").all().order_by('-comment_time')
+ # print(comments)
+ serializer = CommentSerializer(comments, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ serializer = CommentSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ comments = Comment.objects.get(pk=pk)
+ except Comment.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = CommentSerializer(comments, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Comment.objects.filter(id__in=ids_arr).delete()
+ except Comment.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/errorLog.py b/model/server/myapp/views/admin/errorLog.py
new file mode 100644
index 0000000..369d9a9
--- /dev/null
+++ b/model/server/myapp/views/admin/errorLog.py
@@ -0,0 +1,14 @@
+# Create your views here.
+from rest_framework.decorators import api_view
+
+from myapp.handler import APIResponse
+from myapp.models import ErrorLog
+from myapp.serializers import ErrorLogSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ errorLogs = ErrorLog.objects.all().order_by('-log_time')
+ serializer = ErrorLogSerializer(errorLogs, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
diff --git a/model/server/myapp/views/admin/loginLog.py b/model/server/myapp/views/admin/loginLog.py
new file mode 100644
index 0000000..3747dff
--- /dev/null
+++ b/model/server/myapp/views/admin/loginLog.py
@@ -0,0 +1,60 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import LoginLog
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import LoginLogSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ loginLogs = LoginLog.objects.all().order_by('-log_time')
+ serializer = LoginLogSerializer(loginLogs, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+def create(request):
+
+ serializer = LoginLogSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ try:
+ pk = request.GET.get('id', -1)
+ loginLogs = LoginLog.objects.get(pk=pk)
+ except LoginLog.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = LoginLogSerializer(loginLogs, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ LoginLog.objects.filter(id__in=ids_arr).delete()
+ except LoginLog.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/notice.py b/model/server/myapp/views/admin/notice.py
new file mode 100644
index 0000000..402b3c1
--- /dev/null
+++ b/model/server/myapp/views/admin/notice.py
@@ -0,0 +1,68 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Notice
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import NoticeSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ notices = Notice.objects.all().order_by('-create_time')
+ serializer = NoticeSerializer(notices, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ serializer = NoticeSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ notice = Notice.objects.get(pk=pk)
+ except Notice.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = NoticeSerializer(notice, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Notice.objects.filter(id__in=ids_arr).delete()
+ except Notice.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/opLog.py b/model/server/myapp/views/admin/opLog.py
new file mode 100644
index 0000000..9feec40
--- /dev/null
+++ b/model/server/myapp/views/admin/opLog.py
@@ -0,0 +1,14 @@
+# Create your views here.
+from rest_framework.decorators import api_view
+
+from myapp.handler import APIResponse
+from myapp.models import OpLog
+from myapp.serializers import OpLogSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ opLogs = OpLog.objects.all().order_by('-re_time')[:100]
+ serializer = OpLogSerializer(opLogs, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
diff --git a/model/server/myapp/views/admin/order.py b/model/server/myapp/views/admin/order.py
new file mode 100644
index 0000000..9ee4b33
--- /dev/null
+++ b/model/server/myapp/views/admin/order.py
@@ -0,0 +1,175 @@
+# Create your views here.
+import datetime
+
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Order, Thing
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import OrderSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ orders = Order.objects.all().order_by('-order_time')
+ serializer = OrderSerializer(orders, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+ """
+ 创建订单
+ """
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ data = request.data.copy()
+ if data['user'] is None or data['thing'] is None or data['count'] is None:
+ return APIResponse(code=1, msg='参数错误')
+
+ thing = Thing.objects.get(pk=data['thing'])
+ count = data['count']
+ if thing.repertory < int(count):
+ return APIResponse(code=1, msg='库存不足')
+
+ create_time = datetime.datetime.now()
+ data['create_time'] = create_time
+ data['order_number'] = str(utils.get_timestamp())
+ data['status'] = '1'
+ serializer = OrderSerializer(data=data)
+ if serializer.is_valid():
+ serializer.save()
+ # 减库存(支付后)
+ # thing.repertory = thing.repertory - int(count)
+ # thing.save()
+
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ order = Order.objects.get(pk=pk)
+ except Order.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = OrderSerializer(order, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def pass_order(request):
+ """
+ 取消
+ """
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ order = Order.objects.get(pk=pk)
+ except Order.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ data = {
+ 'status': 2
+ }
+ serializer = OrderSerializer(order, data=data)
+ if serializer.is_valid():
+ serializer.save()
+
+ return APIResponse(code=0, msg='成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def cancel_order(request):
+ """
+ 取消
+ """
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ order = Order.objects.get(pk=pk)
+ except Order.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ data = {
+ 'status': 7
+ }
+ serializer = OrderSerializer(order, data=data)
+ if serializer.is_valid():
+ serializer.save()
+
+ return APIResponse(code=0, msg='取消成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delay(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ order = Order.objects.get(pk=pk)
+ except Order.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ if order.delayed:
+ return APIResponse(code=1, msg='已超最大延期次数')
+ else:
+ data = {
+ "delayed": True,
+ "expect_time": order.expect_time + datetime.timedelta(days=30)
+ }
+ serializer = OrderSerializer(order, data=data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='延期成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ return APIResponse(code=1, msg='延期失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Order.objects.filter(id__in=ids_arr).delete()
+ except Order.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/overview.py b/model/server/myapp/views/admin/overview.py
new file mode 100644
index 0000000..6e2b6b6
--- /dev/null
+++ b/model/server/myapp/views/admin/overview.py
@@ -0,0 +1,98 @@
+# Create your views here.
+import datetime
+import locale
+import platform
+import random
+import time
+from multiprocessing import cpu_count
+
+import psutil
+from django.db import connection
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.handler import APIResponse
+
+from myapp.models import Thing, Order
+from myapp.utils import dict_fetchall
+from myapp.auth.authentication import AdminTokenAuthtication
+
+
+@api_view(['GET'])
+@authentication_classes([AdminTokenAuthtication])
+def count(request):
+ if request.method == 'GET':
+ now = datetime.datetime.now()
+
+ # 统计排名(sql语句)
+ sql_str = "select title, pv as count from b_thing order by count desc limit 10; "
+ with connection.cursor() as cursor:
+ cursor.execute(sql_str)
+ order_rank_data = dict_fetchall(cursor)
+
+ # 统计分类比例(sql语句)
+ sql_str = "select B.title, count(B.title) as count from b_thing A join B_classification B on " \
+ "A.classification_id = B.id group by B.title order by count desc limit 5; "
+ with connection.cursor() as cursor:
+ cursor.execute(sql_str)
+ classification_rank_data = dict_fetchall(cursor)
+
+ # 统计最近一周访问量(sql语句)
+ visit_data = []
+ week_days = utils.getWeekDays()
+ for day in week_days:
+ sql_str = "select re_ip, count(re_ip) as count from b_op_log where re_time like '" + day + "%' group by re_ip"
+ with connection.cursor() as cursor:
+ cursor.execute(sql_str)
+ ip_data = dict_fetchall(cursor)
+ uv = len(ip_data)
+ pv = 0
+ for item in ip_data:
+ pv = pv + item['count']
+ visit_data.append({
+ "day": day,
+ "uv": uv + random.randint(1, 20),
+ "pv": pv + random.randint(20, 100)
+ })
+
+ data = {
+ 'order_rank_data': order_rank_data,
+ 'classification_rank_data': classification_rank_data,
+ 'visit_data': visit_data
+ }
+ return APIResponse(code=0, msg='查询成功', data=data)
+
+
+@api_view(['GET'])
+@authentication_classes([AdminTokenAuthtication])
+def sysInfo(request):
+ if request.method == 'GET':
+ pyVersion = platform.python_version()
+ osBuild = platform.architecture()
+ node = platform.node()
+ pf = platform.platform()
+ processor = platform.processor()
+ pyComp = platform.python_compiler()
+ osName = platform.system()
+ memory = psutil.virtual_memory()
+
+ data = {
+ 'sysName': '后台管理系统',
+ 'versionName': '1.1.0',
+ 'osName': osName,
+ 'pyVersion': pyVersion,
+ 'osBuild': osBuild,
+ 'node': node,
+ 'pf': pf,
+ 'processor': processor,
+ 'cpuCount': cpu_count(),
+ 'pyComp': pyComp,
+ 'cpuLoad': round((psutil.cpu_percent(1)), 2),
+ 'memory': round((float(memory.total) / 1024 / 1024 / 1024), 2),
+ 'usedMemory': round((float(memory.used) / 1024 / 1024 / 1024), 2),
+ 'percentMemory': round((float(memory.used) / float(memory.total) * 100), 2),
+ 'sysLan': locale.getdefaultlocale(),
+ 'sysZone': time.strftime('%Z', time.localtime())
+ }
+
+ return APIResponse(code=0, msg='查询成功', data=data)
diff --git a/model/server/myapp/views/admin/record.py b/model/server/myapp/views/admin/record.py
new file mode 100644
index 0000000..35a6df8
--- /dev/null
+++ b/model/server/myapp/views/admin/record.py
@@ -0,0 +1,53 @@
+# Create your views here.
+from rest_framework.decorators import api_view
+
+from myapp.handler import APIResponse
+from myapp.models import Record
+from myapp.serializers import RecordSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ records = Record.objects.all()
+ serializer = RecordSerializer(records, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+def create(request):
+
+ serializer = RecordSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+def update(request):
+ try:
+ pk = request.GET.get('id', -1)
+ records = Record.objects.get(pk=pk)
+ except Record.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = RecordSerializer(records, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+def delete(request):
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Record.objects.filter(id__in=ids_arr).delete()
+ except Record.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/tag.py b/model/server/myapp/views/admin/tag.py
new file mode 100644
index 0000000..80fb7c8
--- /dev/null
+++ b/model/server/myapp/views/admin/tag.py
@@ -0,0 +1,75 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Tag
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import TagSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ tags = Tag.objects.all().order_by('-create_time')
+ serializer = TagSerializer(tags, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ tags = Tag.objects.filter(title=request.data['title'])
+ if len(tags) > 0:
+ return APIResponse(code=1, msg='该名称已存在')
+
+ serializer = TagSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ utils.log_error(request, '参数错误')
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ tags = Tag.objects.get(pk=pk)
+ except Tag.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = TagSerializer(tags, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ utils.log_error(request, '参数错误')
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Tag.objects.filter(id__in=ids_arr).delete()
+ except Tag.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/thing.py b/model/server/myapp/views/admin/thing.py
new file mode 100644
index 0000000..1e704bf
--- /dev/null
+++ b/model/server/myapp/views/admin/thing.py
@@ -0,0 +1,104 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Classification, Thing, Tag
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import ThingSerializer, UpdateThingSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ keyword = request.GET.get("keyword", None)
+ c = request.GET.get("c", None)
+ tag = request.GET.get("tag", None)
+ if keyword:
+ things = Thing.objects.filter(title__contains=keyword).order_by('create_time')
+ elif c:
+ classification = Classification.objects.get(pk=c)
+ things = classification.classification_thing.all()
+ elif tag:
+ tag = Tag.objects.get(id=tag)
+ print(tag)
+ things = tag.thing_set.all()
+ else:
+ things = Thing.objects.all().order_by('create_time')
+
+ serializer = ThingSerializer(things, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['GET'])
+def detail(request):
+
+ try:
+ pk = request.GET.get('id', -1)
+ thing = Thing.objects.get(pk=pk)
+ except Thing.DoesNotExist:
+ utils.log_error(request, '对象不存在')
+ return APIResponse(code=1, msg='对象不存在')
+
+ if request.method == 'GET':
+ serializer = ThingSerializer(thing)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ serializer = ThingSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ utils.log_error(request, '参数错误')
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ thing = Thing.objects.get(pk=pk)
+ except Thing.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = UpdateThingSerializer(thing, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ utils.log_error(request, '参数错误')
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Thing.objects.filter(id__in=ids_arr).delete()
+ except Thing.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/admin/user.py b/model/server/myapp/views/admin/user.py
new file mode 100644
index 0000000..e04b073
--- /dev/null
+++ b/model/server/myapp/views/admin/user.py
@@ -0,0 +1,176 @@
+# Create your views here.
+import datetime
+
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import User
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import UserSerializer, LoginLogSerializer
+from myapp.utils import md5value
+
+
+def make_login_log(request):
+ try:
+ username = request.data['username']
+ data = {
+ "username": username,
+ "ip": utils.get_ip(request),
+ "ua": utils.get_ua(request)
+ }
+ serializer = LoginLogSerializer(data=data)
+ if serializer.is_valid():
+ serializer.save()
+ else:
+ print(serializer.errors)
+ except Exception as e:
+ print(e)
+
+
+@api_view(['POST'])
+def admin_login(request):
+ username = request.data['username']
+ password = utils.md5value(request.data['password'])
+
+ users = User.objects.filter(username=username, password=password, role__in=['1', '3'])
+ if len(users) > 0:
+ user = users[0]
+ data = {
+ 'username': username,
+ 'password': password,
+ 'admin_token': md5value(username) # 生成令牌
+ }
+ serializer = UserSerializer(user, data=data)
+ if serializer.is_valid():
+ serializer.save()
+ make_login_log(request)
+ return APIResponse(code=0, msg='登录成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='用户名或密码错误')
+
+
+@api_view(['GET'])
+def info(request):
+ if request.method == 'GET':
+ pk = request.GET.get('id', -1)
+ user = User.objects.get(pk=pk)
+ serializer = UserSerializer(user)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ keyword = request.GET.get("keyword", '')
+ users = User.objects.filter(username__contains=keyword).order_by('-create_time')
+ serializer = UserSerializer(users, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def create(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ print(request.data)
+ if not request.data.get('username', None) or not request.data.get('password', None):
+ return APIResponse(code=1, msg='用户名或密码不能为空')
+ users = User.objects.filter(username=request.data['username'])
+ if len(users) > 0:
+ return APIResponse(code=1, msg='该用户名已存在')
+
+ data = request.data.copy()
+ data.update({'password': utils.md5value(request.data['password'])})
+ serializer = UserSerializer(data=data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def update(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ user = User.objects.get(pk=pk)
+ except User.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ data = request.data.copy()
+ if 'username' in data.keys():
+ del data['username']
+ if 'password' in data.keys():
+ del data['password']
+ serializer = UserSerializer(user, data=data)
+ print(serializer.is_valid())
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def updatePwd(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ pk = request.GET.get('id', -1)
+ user = User.objects.get(pk=pk)
+ except User.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ password = request.data.get('password', None)
+ newPassword1 = request.data.get('newPassword1', None)
+ newPassword2 = request.data.get('newPassword2', None)
+
+ if not password or not newPassword1 or not newPassword2:
+ return APIResponse(code=1, msg='不能为空')
+
+ if user.password != utils.md5value(password):
+ return APIResponse(code=1, msg='原密码不正确')
+
+ if newPassword1 != newPassword2:
+ return APIResponse(code=1, msg='两次密码不一致')
+
+ data = request.data.copy()
+ data.update({'password': utils.md5value(newPassword1)})
+ serializer = UserSerializer(user, data=data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([AdminTokenAuthtication])
+def delete(request):
+ if isDemoAdminUser(request):
+ return APIResponse(code=1, msg='演示帐号无法操作')
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ User.objects.filter(id__in=ids_arr).delete()
+ except User.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/index/__init__.py b/model/server/myapp/views/index/__init__.py
new file mode 100644
index 0000000..a48d28d
--- /dev/null
+++ b/model/server/myapp/views/index/__init__.py
@@ -0,0 +1,8 @@
+from myapp.views.index.classification import *
+from myapp.views.index.tag import *
+from myapp.views.index.user import *
+from myapp.views.index.thing import *
+from myapp.views.index.comment import *
+from myapp.views.index.order import *
+from myapp.views.index.notice import *
+from myapp.views.index.address import *
diff --git a/model/server/myapp/views/index/address.py b/model/server/myapp/views/index/address.py
new file mode 100644
index 0000000..5d9b7fd
--- /dev/null
+++ b/model/server/myapp/views/index/address.py
@@ -0,0 +1,87 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.auth.authentication import TokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Address
+from myapp.serializers import AddressSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ userId = request.GET.get('userId', -1)
+
+ if userId != -1:
+ addresses = Address.objects.filter(user=userId).order_by('-create_time')
+ serializer = AddressSerializer(addresses, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+ else:
+ return APIResponse(code=1, msg='userId不能为空')
+
+
+@api_view(['POST'])
+@authentication_classes([TokenAuthtication])
+def create(request):
+
+ address_content = request.POST.get('desc', None)
+ user = request.POST.get('user', None)
+ default = request.POST.get('default', False)
+
+ if address_content is None or user is None:
+ return APIResponse(code=1, msg='不能为空')
+
+ if default:
+ # 其他置为false
+ Address.objects.filter(user=user).update(default=False)
+
+ serializer = AddressSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ utils.log_error(request, '参数错误')
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([TokenAuthtication])
+def update(request):
+
+ try:
+ pk = request.GET.get('id', -1)
+ addresses = Address.objects.get(pk=pk)
+ except Address.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ user = request.data['user']
+ default = request.data['default']
+
+ if default:
+ # 其他置为false
+ Address.objects.filter(user=user).update(default=False)
+
+ serializer = AddressSerializer(addresses, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ utils.log_error(request, '参数错误')
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([TokenAuthtication])
+def delete(request):
+
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Address.objects.filter(id__in=ids_arr).delete()
+ except Address.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
diff --git a/model/server/myapp/views/index/classification.py b/model/server/myapp/views/index/classification.py
new file mode 100644
index 0000000..53266eb
--- /dev/null
+++ b/model/server/myapp/views/index/classification.py
@@ -0,0 +1,21 @@
+# Create your views here.
+from django.db import connection
+from rest_framework.decorators import api_view
+
+from myapp.handler import APIResponse
+from myapp.models import Classification
+from myapp.serializers import ClassificationSerializer
+from myapp.utils import dict_fetchall
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ classifications = Classification.objects.all().order_by('-create_time')
+ serializer = ClassificationSerializer(classifications, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+
+
+
diff --git a/model/server/myapp/views/index/comment.py b/model/server/myapp/views/index/comment.py
new file mode 100644
index 0000000..8f09996
--- /dev/null
+++ b/model/server/myapp/views/index/comment.py
@@ -0,0 +1,87 @@
+# Create your views here.
+from rest_framework.decorators import api_view, authentication_classes, throttle_classes
+
+from myapp.auth.MyRateThrottle import MyRateThrottle
+from myapp.auth.authentication import AdminTokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Comment
+from myapp.permission.permission import isDemoAdminUser
+from myapp.serializers import CommentSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ thingId = request.GET.get("thingId", None)
+ order = request.GET.get("order", 'recent')
+
+ if thingId:
+ if order == 'recent':
+ orderBy = '-comment_time'
+ else:
+ orderBy = '-like_count'
+
+ comments = Comment.objects.select_related("thing").filter(thing=thingId).order_by(orderBy)
+ # print(comments)
+ serializer = CommentSerializer(comments, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+ else:
+ return APIResponse(code=1, msg='thingId不能为空')
+
+
+@api_view(['GET'])
+def list_my_comment(request):
+ if request.method == 'GET':
+ userId = request.GET.get("userId", None)
+ order = request.GET.get("order", 'recent')
+
+ if userId:
+ if order == 'recent':
+ orderBy = '-comment_time'
+ else:
+ orderBy = '-like_count'
+
+ comments = Comment.objects.select_related("thing").filter(user=userId).order_by(orderBy)
+ # print(comments)
+ serializer = CommentSerializer(comments, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+ else:
+ return APIResponse(code=1, msg='userId不能为空')
+
+
+@api_view(['POST'])
+@throttle_classes([MyRateThrottle])
+def create(request):
+ serializer = CommentSerializer(data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+def delete(request):
+ try:
+ ids = request.GET.get('ids')
+ ids_arr = ids.split(',')
+ Comment.objects.filter(id__in=ids_arr).delete()
+ except Comment.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='删除成功')
+
+
+@api_view(['POST'])
+def like(request):
+ try:
+ commentId = request.GET.get('commentId')
+ comment = Comment.objects.get(pk=commentId)
+ comment.like_count += 1
+ comment.save()
+ except Comment.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ return APIResponse(code=0, msg='推荐成功')
diff --git a/model/server/myapp/views/index/notice.py b/model/server/myapp/views/index/notice.py
new file mode 100644
index 0000000..d49845e
--- /dev/null
+++ b/model/server/myapp/views/index/notice.py
@@ -0,0 +1,15 @@
+# Create your views here.
+from rest_framework.decorators import api_view
+
+from myapp.handler import APIResponse
+from myapp.models import Notice
+from myapp.serializers import NoticeSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ notices = Notice.objects.all().order_by('-create_time')
+ serializer = NoticeSerializer(notices, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
diff --git a/model/server/myapp/views/index/order.py b/model/server/myapp/views/index/order.py
new file mode 100644
index 0000000..24a7174
--- /dev/null
+++ b/model/server/myapp/views/index/order.py
@@ -0,0 +1,85 @@
+# Create your views here.
+import datetime
+
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.auth.authentication import TokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import Order, Thing
+from myapp.serializers import OrderSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ userId = request.GET.get('userId', -1)
+ orderStatus = request.GET.get('orderStatus', '')
+
+ orders = Order.objects.all().filter(user=userId).filter(status__contains=orderStatus).order_by('-order_time')
+ serializer = OrderSerializer(orders, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([TokenAuthtication])
+def create(request):
+
+ data = request.data.copy()
+ if data['user'] is None or data['thing'] is None or data['count'] is None:
+ return APIResponse(code=1, msg='参数错误')
+
+ # thing = Thing.objects.get(pk=data['thing'])
+ # count = data['count']
+ # if thing.repertory < int(count):
+ # return APIResponse(code=1, msg='库存不足')
+
+ create_time = datetime.datetime.now()
+ data['create_time'] = create_time
+ data['order_number'] = str(utils.get_timestamp())
+ data['status'] = '1'
+ serializer = OrderSerializer(data=data)
+ if serializer.is_valid():
+ serializer.save()
+ # 减库存(支付后)
+ # thing.repertory = thing.repertory - int(count)
+ # thing.save()
+
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+@authentication_classes([TokenAuthtication])
+def cancel_order(request):
+ """
+ cancal
+ """
+ try:
+ pk = request.GET.get('id', -1)
+ order = Order.objects.get(pk=pk)
+ except Order.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ data = {
+ 'status': 7
+ }
+ serializer = OrderSerializer(order, data=data)
+ if serializer.is_valid():
+ serializer.save()
+ # 加库存
+ # thingId = request.data['thing']
+ # thing = Thing.objects.get(pk=thingId)
+ # thing.repertory = thing.repertory + 1
+ # thing.save()
+
+ # 加积分
+ # order.user.score = order.user.score + 1
+ # order.user.save()
+
+ return APIResponse(code=0, msg='取消成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ return APIResponse(code=1, msg='更新失败')
diff --git a/model/server/myapp/views/index/tag.py b/model/server/myapp/views/index/tag.py
new file mode 100644
index 0000000..2a3c0ec
--- /dev/null
+++ b/model/server/myapp/views/index/tag.py
@@ -0,0 +1,15 @@
+# Create your views here.
+from rest_framework.decorators import api_view
+
+from myapp.handler import APIResponse
+from myapp.models import Tag
+from myapp.serializers import TagSerializer
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ tags = Tag.objects.all().order_by('-create_time')
+ serializer = TagSerializer(tags, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
diff --git a/model/server/myapp/views/index/thing.py b/model/server/myapp/views/index/thing.py
new file mode 100644
index 0000000..d05385a
--- /dev/null
+++ b/model/server/myapp/views/index/thing.py
@@ -0,0 +1,264 @@
+# Create your views here.
+from django.db import connection
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.handler import APIResponse
+from myapp.models import Classification, Thing, Tag, User
+from myapp.serializers import ThingSerializer, ClassificationSerializer, ListThingSerializer, DetailThingSerializer, \
+ UpdateThingSerializer
+from myapp.utils import dict_fetchall
+
+
+@api_view(['GET'])
+def list_api(request):
+ if request.method == 'GET':
+ keyword = request.GET.get("keyword", None)
+ c = request.GET.get("c", None)
+ tag = request.GET.get("tag", None)
+ sort = request.GET.get("sort", 'recent')
+
+ # 排序方式
+ order = '-create_time'
+ if sort == 'recent':
+ order = '-create_time'
+ elif sort == 'hot' or sort == 'recommend':
+ order = '-pv'
+
+ if keyword:
+ things = Thing.objects.filter(title__contains=keyword).filter(status='0').order_by(order)
+
+ # todo
+ elif c and int(c) > -1:
+ ids = [c]
+
+ things = Thing.objects.filter(classification_id__in=ids).filter(status='0').order_by(order)
+
+ elif tag:
+ tag = Tag.objects.get(id=tag)
+ print(tag)
+ things = tag.thing_set.all().filter(status='0').order_by(order)
+ else:
+ things = Thing.objects.all().defer('wish').filter(status='0').order_by(order)
+
+ serializer = ListThingSerializer(things, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['GET'])
+def detail(request):
+ try:
+ pk = request.GET.get('id', -1)
+ thing = Thing.objects.get(pk=pk)
+ thing.pv = thing.pv + 1
+ thing.save()
+ except Thing.DoesNotExist:
+ utils.log_error(request, '对象不存在')
+ return APIResponse(code=1, msg='对象不存在')
+
+ if request.method == 'GET':
+ serializer = ThingSerializer(thing)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+def increaseWishCount(request):
+ try:
+ pk = request.GET.get('id', -1)
+ thing = Thing.objects.get(pk=pk)
+ # wish_count加1
+ thing.wish_count = thing.wish_count + 1
+ thing.save()
+ except Thing.DoesNotExist:
+ utils.log_error(request, '对象不存在')
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = ThingSerializer(thing)
+ return APIResponse(code=0, msg='操作成功', data=serializer.data)
+
+
+@api_view(['POST'])
+def increaseRecommendCount(request):
+ try:
+ pk = request.GET.get('id', -1)
+ thing = Thing.objects.get(pk=pk)
+ # recommend_count加1
+ thing.recommend_count = thing.recommend_count + 1
+ thing.save()
+ except Thing.DoesNotExist:
+ utils.log_error(request, '对象不存在')
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = ThingSerializer(thing)
+ return APIResponse(code=0, msg='操作成功', data=serializer.data)
+
+
+@api_view(['POST'])
+def addWishUser(request):
+ try:
+ username = request.GET.get('username', None)
+ thingId = request.GET.get('thingId', None)
+
+ if username and thingId:
+ user = User.objects.get(username=username)
+ thing = Thing.objects.get(pk=thingId)
+
+ if user not in thing.wish.all():
+ thing.wish.add(user)
+ thing.wish_count += 1
+ thing.save()
+
+ except Thing.DoesNotExist:
+ utils.log_error(request, '操作失败')
+ return APIResponse(code=1, msg='操作失败')
+
+ serializer = ThingSerializer(thing)
+ return APIResponse(code=0, msg='操作成功', data=serializer.data)
+
+
+@api_view(['POST'])
+def removeWishUser(request):
+ try:
+ username = request.GET.get('username', None)
+ thingId = request.GET.get('thingId', None)
+
+ if username and thingId:
+ user = User.objects.get(username=username)
+ thing = Thing.objects.get(pk=thingId)
+
+ if user in thing.wish.all():
+ thing.wish.remove(user)
+ thing.wish_count -= 1
+ thing.save()
+
+ except Thing.DoesNotExist:
+ utils.log_error(request, '操作失败')
+ return APIResponse(code=1, msg='操作失败')
+
+ return APIResponse(code=0, msg='操作成功')
+
+
+@api_view(['GET'])
+def getWishThingList(request):
+ try:
+ username = request.GET.get('username', None)
+ if username:
+ user = User.objects.get(username=username)
+ things = user.wish_things.all()
+ serializer = ListThingSerializer(things, many=True)
+ return APIResponse(code=0, msg='操作成功', data=serializer.data)
+ else:
+ return APIResponse(code=1, msg='username不能为空')
+
+ except Exception as e:
+ utils.log_error(request, '操作失败' + str(e))
+ return APIResponse(code=1, msg='获取心愿单失败')
+
+
+@api_view(['POST'])
+def addCollectUser(request):
+ try:
+ username = request.GET.get('username', None)
+ thingId = request.GET.get('thingId', None)
+
+ if username and thingId:
+ user = User.objects.get(username=username)
+ thing = Thing.objects.get(pk=thingId)
+
+ if user not in thing.collect.all():
+ thing.collect.add(user)
+ thing.collect_count += 1
+ thing.save()
+
+ except Thing.DoesNotExist:
+ utils.log_error(request, '操作失败')
+ return APIResponse(code=1, msg='操作失败')
+
+ serializer = DetailThingSerializer(thing)
+ return APIResponse(code=0, msg='操作成功', data=serializer.data)
+
+
+@api_view(['POST'])
+def removeCollectUser(request):
+ try:
+ username = request.GET.get('username', None)
+ thingId = request.GET.get('thingId', None)
+
+ if username and thingId:
+ user = User.objects.get(username=username)
+ thing = Thing.objects.get(pk=thingId)
+
+ if user in thing.collect.all():
+ thing.collect.remove(user)
+ thing.collect_count -= 1
+ thing.save()
+
+ except Thing.DoesNotExist:
+ utils.log_error(request, '操作失败')
+ return APIResponse(code=1, msg='操作失败')
+
+ return APIResponse(code=0, msg='操作成功')
+
+
+@api_view(['GET'])
+def getCollectThingList(request):
+ try:
+ username = request.GET.get('username', None)
+ if username:
+ user = User.objects.get(username=username)
+ things = user.collect_things.all()
+ serializer = ListThingSerializer(things, many=True)
+ return APIResponse(code=0, msg='操作成功', data=serializer.data)
+ else:
+ return APIResponse(code=1, msg='username不能为空')
+
+ except Exception as e:
+ utils.log_error(request, '操作失败' + str(e))
+ return APIResponse(code=1, msg='获取收藏失败')
+
+
+@api_view(['GET'])
+def list_user_thing_api(request):
+ if request.method == 'GET':
+ user = request.GET.get("user", None)
+
+ if user:
+ things = Thing.objects.filter(user=user)
+ serializer = ListThingSerializer(things, many=True)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+ else:
+ return APIResponse(code=1, msg='user不能为空')
+
+
+@api_view(['POST'])
+def create(request):
+ data = request.data.copy()
+ data['status'] = '1'
+ serializer = ThingSerializer(data=data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ utils.log_error(request, '参数错误')
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['POST'])
+def update(request):
+ try:
+ pk = request.GET.get('id', -1)
+ thing = Thing.objects.get(pk=pk)
+ except Thing.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ serializer = UpdateThingSerializer(thing, data=request.data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+ utils.log_error(request, '参数错误')
+
+ return APIResponse(code=1, msg='更新失败')
diff --git a/model/server/myapp/views/index/user.py b/model/server/myapp/views/index/user.py
new file mode 100644
index 0000000..031c918
--- /dev/null
+++ b/model/server/myapp/views/index/user.py
@@ -0,0 +1,162 @@
+# Create your views here.
+import datetime
+
+from rest_framework.decorators import api_view, authentication_classes
+
+from myapp import utils
+from myapp.auth.authentication import TokenAuthtication
+from myapp.handler import APIResponse
+from myapp.models import User
+from myapp.serializers import UserSerializer, LoginLogSerializer
+from myapp.utils import md5value
+
+
+def make_login_log(request):
+ try:
+ username = request.data['username']
+ data = {
+ "username": username,
+ "ip": utils.get_ip(request),
+ "ua": utils.get_ua(request)
+ }
+ serializer = LoginLogSerializer(data=data)
+ if serializer.is_valid():
+ serializer.save()
+ else:
+ print(serializer.errors)
+ except Exception as e:
+ print(e)
+
+
+@api_view(['POST'])
+def login(request):
+ username = request.data['username']
+ password = utils.md5value(request.data['password'])
+
+ users = User.objects.filter(username=username, password=password)
+ if len(users) > 0:
+ user = users[0]
+
+ if user.role in ['1', '3']:
+ return APIResponse(code=1, msg='该帐号为后台管理员帐号')
+
+ data = {
+ 'username': username,
+ 'password': password,
+ 'token': md5value(username) # 生成令牌
+ }
+ serializer = UserSerializer(user, data=data)
+ if serializer.is_valid():
+ serializer.save()
+ make_login_log(request)
+ return APIResponse(code=0, msg='登录成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='用户名或密码错误')
+
+
+@api_view(['POST'])
+def register(request):
+ print(request.data)
+ username = request.data.get('username', None)
+ password = request.data.get('password', None)
+ repassword = request.data.get('repassword', None)
+ if not username or not password or not repassword:
+ return APIResponse(code=1, msg='用户名或密码不能为空')
+ if password != repassword:
+ return APIResponse(code=1, msg='密码不一致')
+ users = User.objects.filter(username=username)
+ if len(users) > 0:
+ return APIResponse(code=1, msg='该用户名已存在')
+
+ data = {
+ 'username': username,
+ 'password': password,
+ 'role': 2, # 角色2
+ 'status': 0,
+ }
+ data.update({'password': utils.md5value(request.data['password'])})
+ serializer = UserSerializer(data=data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='创建成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='创建失败')
+
+
+@api_view(['GET'])
+def info(request):
+ if request.method == 'GET':
+ pk = request.GET.get('id', -1)
+ user = User.objects.get(pk=pk)
+ serializer = UserSerializer(user)
+ return APIResponse(code=0, msg='查询成功', data=serializer.data)
+
+
+@api_view(['POST'])
+@authentication_classes([TokenAuthtication])
+def update(request):
+ try:
+ pk = request.GET.get('id', -1)
+ user = User.objects.get(pk=pk)
+ except User.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ data = request.data.copy()
+ if 'username' in data.keys():
+ del data['username']
+ if 'password' in data.keys():
+ del data['password']
+ if 'role' in data.keys():
+ del data['role']
+ serializer = UserSerializer(user, data=data)
+ print(serializer.is_valid())
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='更新失败')
+
+
+@api_view(['POST'])
+@authentication_classes([TokenAuthtication])
+def updatePwd(request):
+
+ try:
+ pk = request.GET.get('id', -1)
+ user = User.objects.get(pk=pk)
+ except User.DoesNotExist:
+ return APIResponse(code=1, msg='对象不存在')
+
+ print(user.role)
+ if user.role != '2':
+ return APIResponse(code=1, msg='参数非法')
+
+ password = request.data.get('password', None)
+ newPassword1 = request.data.get('newPassword1', None)
+ newPassword2 = request.data.get('newPassword2', None)
+
+ if not password or not newPassword1 or not newPassword2:
+ return APIResponse(code=1, msg='不能为空')
+
+ if user.password != utils.md5value(password):
+ return APIResponse(code=1, msg='原密码不正确')
+
+ if newPassword1 != newPassword2:
+ return APIResponse(code=1, msg='两次密码不一致')
+
+ data = request.data.copy()
+ data.update({'password': utils.md5value(newPassword1)})
+ serializer = UserSerializer(user, data=data)
+ if serializer.is_valid():
+ serializer.save()
+ return APIResponse(code=0, msg='更新成功', data=serializer.data)
+ else:
+ print(serializer.errors)
+
+ return APIResponse(code=1, msg='更新失败')
\ No newline at end of file
diff --git a/model/server/requirements.txt b/model/server/requirements.txt
new file mode 100644
index 0000000..df81915
--- /dev/null
+++ b/model/server/requirements.txt
@@ -0,0 +1,6 @@
+Django==3.2.11
+PyMySQL==1.0.2
+djangorestframework==3.13.0
+django-cors-headers==3.13.0
+Pillow==9.1.1
+psutil==5.9.4
\ No newline at end of file
diff --git a/model/server/server/__init__.py b/model/server/server/__init__.py
new file mode 100644
index 0000000..66c3bb4
--- /dev/null
+++ b/model/server/server/__init__.py
@@ -0,0 +1,4 @@
+import pymysql
+pymysql.install_as_MySQLdb()
+
+print("===============install pymysql==============")
\ No newline at end of file
diff --git a/model/server/server/asgi.py b/model/server/server/asgi.py
new file mode 100644
index 0000000..46c8af6
--- /dev/null
+++ b/model/server/server/asgi.py
@@ -0,0 +1,16 @@
+"""
+ASGI config for server project.
+
+It exposes the ASGI callable as a module-level variable named ``application``.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/4.1/howto/deployment/asgi/
+"""
+
+import os
+
+from django.core.asgi import get_asgi_application
+
+os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'server.settings')
+
+application = get_asgi_application()
diff --git a/model/server/server/settings.py b/model/server/server/settings.py
new file mode 100644
index 0000000..edbc17d
--- /dev/null
+++ b/model/server/server/settings.py
@@ -0,0 +1,150 @@
+"""
+Django settings for server project.
+
+Generated by 'django-admin startproject' using Django 4.1.4.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/4.1/topics/settings/
+
+For the full list of settings and their values, see
+https://docs.djangoproject.com/en/4.1/ref/settings/
+"""
+import os
+from pathlib import Path
+
+# Build paths inside the project like this: BASE_DIR / 'subdir'.
+# BASE_DIR = Path(__file__).resolve().parent.parent
+BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
+
+# Quick-start development settings - unsuitable for production
+# See https://docs.djangoproject.com/en/4.1/howto/deployment/checklist/
+
+# SECURITY WARNING: keep the secret key used in production secret!
+SECRET_KEY = 'django-insecure-sz@madp0ifx!b)^lg_g!f+5s*w7w_=sjgq-k+erzb%x42$^r!d'
+
+# SECURITY WARNING: don't run with debug turned on in production!
+DEBUG = True
+
+ALLOWED_HOSTS = ['*']
+
+# Application definition
+
+INSTALLED_APPS = [
+ 'django.contrib.admin',
+ 'django.contrib.auth',
+ 'django.contrib.contenttypes',
+ 'django.contrib.sessions',
+ 'django.contrib.messages',
+ 'django.contrib.staticfiles',
+ 'rest_framework',
+ 'corsheaders', # 跨域
+ 'myapp'
+]
+
+MIDDLEWARE = [
+ 'django.middleware.security.SecurityMiddleware',
+ 'django.contrib.sessions.middleware.SessionMiddleware',
+ 'corsheaders.middleware.CorsMiddleware', # 跨域配置
+ 'django.middleware.common.CommonMiddleware',
+ 'django.middleware.csrf.CsrfViewMiddleware',
+ 'django.contrib.auth.middleware.AuthenticationMiddleware',
+ 'django.contrib.messages.middleware.MessageMiddleware',
+ 'django.middleware.clickjacking.XFrameOptionsMiddleware',
+ 'myapp.middlewares.LogMiddleware.OpLogs'
+]
+
+CORS_ORIGIN_ALLOW_ALL = True # 允许跨域
+
+ROOT_URLCONF = 'server.urls'
+
+TEMPLATES = [
+ {
+ 'BACKEND': 'django.template.backends.django.DjangoTemplates',
+ 'DIRS': [],
+ 'APP_DIRS': True,
+ 'OPTIONS': {
+ 'context_processors': [
+ 'django.template.context_processors.debug',
+ 'django.template.context_processors.request',
+ 'django.contrib.auth.context_processors.auth',
+ 'django.contrib.messages.context_processors.messages',
+ ],
+ },
+ },
+]
+
+WSGI_APPLICATION = 'server.wsgi.application'
+
+# Database
+# https://docs.djangoproject.com/en/4.1/ref/settings/#databases
+
+DATABASES = {
+ 'default': {
+ 'ENGINE': 'django.db.backends.mysql',
+ 'NAME': 'python_team',
+ 'USER': 'root',
+ 'PASSWORD': '123456',
+ 'HOST': '127.0.0.1',
+ 'PORT': '3306',
+ 'OPTIONS': {
+ "init_command": "SET foreign_key_checks = 0;",
+ }
+ }
+}
+
+# Password validation
+# https://docs.djangoproject.com/en/4.1/ref/settings/#auth-password-validators
+
+AUTH_PASSWORD_VALIDATORS = [
+ {
+ 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
+ },
+ {
+ 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
+ },
+ {
+ 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
+ },
+ {
+ 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
+ },
+]
+
+# Internationalization
+# https://docs.djangoproject.com/en/4.1/topics/i18n/
+
+
+LANGUAGE_CODE = 'zh-hans'
+
+# 时区
+TIME_ZONE = 'Asia/Shanghai'
+
+USE_I18N = True
+
+USE_L10N = True
+
+USE_TZ = False
+
+# 日期时间格式
+DATE_FORMAT = 'Y-m-d'
+DATETIME_FORMAT = 'Y-m-d H:i:s'
+
+# 上传文件路径
+# 并在urls.py配置+static
+MEDIA_ROOT = os.path.join(BASE_DIR, 'upload/')
+MEDIA_URL = '/upload/'
+
+# Static files (CSS, JavaScript, Images)
+# https://docs.djangoproject.com/en/4.1/howto/static-files/
+
+STATIC_URL = 'static/'
+
+# Default primary key field type
+# https://docs.djangoproject.com/en/4.1/ref/settings/#default-auto-field
+
+DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
+
+# 跨域配置
+CORS_ALLOW_CREDENTIALS = True
+CORS_ALLOW_ALL_ORIGINS = True
+CORS_ALLOW_HEADERS = '*'
diff --git a/model/server/server/urls.py b/model/server/server/urls.py
new file mode 100644
index 0000000..a49e4c1
--- /dev/null
+++ b/model/server/server/urls.py
@@ -0,0 +1,25 @@
+"""server URL Configuration
+
+The `urlpatterns` list routes URLs to views. For more information please see:
+ https://docs.djangoproject.com/en/4.1/topics/http/urls/
+Examples:
+Function views
+ 1. Add an import: from my_app import views
+ 2. Add a URL to urlpatterns: path('', views.home, name='home')
+Class-based views
+ 1. Add an import: from other_app.views import Home
+ 2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
+Including another URLconf
+ 1. Import the include() function: from django.urls import include, path
+ 2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
+"""
+from django.conf.urls.static import static
+from django.contrib import admin
+from django.urls import path, include
+
+from server import settings
+
+urlpatterns = [
+ path('admin/', admin.site.urls),
+ path('myapp/', include('myapp.urls')),
+] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
diff --git a/model/server/server/wsgi.py b/model/server/server/wsgi.py
new file mode 100644
index 0000000..553b3fb
--- /dev/null
+++ b/model/server/server/wsgi.py
@@ -0,0 +1,16 @@
+"""
+WSGI config for server project.
+
+It exposes the WSGI callable as a module-level variable named ``application``.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/4.1/howto/deployment/wsgi/
+"""
+
+import os
+
+from django.core.wsgi import get_wsgi_application
+
+os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'server.settings')
+
+application = get_wsgi_application()
diff --git a/model/server/upload/ad/1674045266113.jpeg b/model/server/upload/ad/1674045266113.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/ad/1674045266113.jpeg differ
diff --git a/model/server/upload/ad/1674045282581.jpeg b/model/server/upload/ad/1674045282581.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/ad/1674045282581.jpeg differ
diff --git a/model/server/upload/ad/1674045308177.png b/model/server/upload/ad/1674045308177.png
new file mode 100644
index 0000000..3abf68e
Binary files /dev/null and b/model/server/upload/ad/1674045308177.png differ
diff --git a/model/server/upload/ad/1674045324510.jpeg b/model/server/upload/ad/1674045324510.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/ad/1674045324510.jpeg differ
diff --git a/model/server/upload/ad/1684565423182.jpeg b/model/server/upload/ad/1684565423182.jpeg
new file mode 100644
index 0000000..ab5a05b
Binary files /dev/null and b/model/server/upload/ad/1684565423182.jpeg differ
diff --git a/model/server/upload/ad/1684565863904.jpeg b/model/server/upload/ad/1684565863904.jpeg
new file mode 100644
index 0000000..3de9ef0
Binary files /dev/null and b/model/server/upload/ad/1684565863904.jpeg differ
diff --git a/model/server/upload/ad/1684565876995.png b/model/server/upload/ad/1684565876995.png
new file mode 100644
index 0000000..a031985
Binary files /dev/null and b/model/server/upload/ad/1684565876995.png differ
diff --git a/model/server/upload/ad/1686369031223.jpeg b/model/server/upload/ad/1686369031223.jpeg
new file mode 100644
index 0000000..94a539b
Binary files /dev/null and b/model/server/upload/ad/1686369031223.jpeg differ
diff --git a/model/server/upload/avatar/1676553050529.png b/model/server/upload/avatar/1676553050529.png
new file mode 100644
index 0000000..2e617f2
Binary files /dev/null and b/model/server/upload/avatar/1676553050529.png differ
diff --git a/model/server/upload/avatar/1676553366217.png b/model/server/upload/avatar/1676553366217.png
new file mode 100644
index 0000000..f8d1e7d
Binary files /dev/null and b/model/server/upload/avatar/1676553366217.png differ
diff --git a/model/server/upload/avatar/1676553498600.jpeg b/model/server/upload/avatar/1676553498600.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/avatar/1676553498600.jpeg differ
diff --git a/model/server/upload/avatar/1676553815688.jpeg b/model/server/upload/avatar/1676553815688.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/avatar/1676553815688.jpeg differ
diff --git a/model/server/upload/avatar/1677240189427.png b/model/server/upload/avatar/1677240189427.png
new file mode 100644
index 0000000..3abf68e
Binary files /dev/null and b/model/server/upload/avatar/1677240189427.png differ
diff --git a/model/server/upload/avatar/1677982820781.jpeg b/model/server/upload/avatar/1677982820781.jpeg
new file mode 100644
index 0000000..f9bd228
Binary files /dev/null and b/model/server/upload/avatar/1677982820781.jpeg differ
diff --git a/model/server/upload/avatar/1679146350134.jpeg b/model/server/upload/avatar/1679146350134.jpeg
new file mode 100644
index 0000000..3f366cb
Binary files /dev/null and b/model/server/upload/avatar/1679146350134.jpeg differ
diff --git a/model/server/upload/avatar/1684593239449.png b/model/server/upload/avatar/1684593239449.png
new file mode 100644
index 0000000..a031985
Binary files /dev/null and b/model/server/upload/avatar/1684593239449.png differ
diff --git a/model/server/upload/avatar/1684593453676.jpeg b/model/server/upload/avatar/1684593453676.jpeg
new file mode 100644
index 0000000..ab5a05b
Binary files /dev/null and b/model/server/upload/avatar/1684593453676.jpeg differ
diff --git a/model/server/upload/banner/1673963977440.jpeg b/model/server/upload/banner/1673963977440.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/banner/1673963977440.jpeg differ
diff --git a/model/server/upload/banner/1673964384835.png b/model/server/upload/banner/1673964384835.png
new file mode 100644
index 0000000..3abf68e
Binary files /dev/null and b/model/server/upload/banner/1673964384835.png differ
diff --git a/model/server/upload/banner/1673964652167.jpeg b/model/server/upload/banner/1673964652167.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/banner/1673964652167.jpeg differ
diff --git a/model/server/upload/banner/1673965110189.jpeg b/model/server/upload/banner/1673965110189.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/banner/1673965110189.jpeg differ
diff --git a/model/server/upload/banner/1673965198155.jpeg b/model/server/upload/banner/1673965198155.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/banner/1673965198155.jpeg differ
diff --git a/model/server/upload/banner/1673965389141.jpeg b/model/server/upload/banner/1673965389141.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/banner/1673965389141.jpeg differ
diff --git a/model/server/upload/banner/1673965574311.png b/model/server/upload/banner/1673965574311.png
new file mode 100644
index 0000000..3abf68e
Binary files /dev/null and b/model/server/upload/banner/1673965574311.png differ
diff --git a/model/server/upload/banner/1673965709533.jpeg b/model/server/upload/banner/1673965709533.jpeg
new file mode 100644
index 0000000..959e164
Binary files /dev/null and b/model/server/upload/banner/1673965709533.jpeg differ
diff --git a/model/server/upload/banner/1673965718720.png b/model/server/upload/banner/1673965718720.png
new file mode 100644
index 0000000..3abf68e
Binary files /dev/null and b/model/server/upload/banner/1673965718720.png differ
diff --git a/model/server/upload/banner/1673965728690.jpeg b/model/server/upload/banner/1673965728690.jpeg
new file mode 100644
index 0000000..959e164
Binary files /dev/null and b/model/server/upload/banner/1673965728690.jpeg differ
diff --git a/model/server/upload/cover/1.jpeg b/model/server/upload/cover/1.jpeg
new file mode 100644
index 0000000..4fb1df0
Binary files /dev/null and b/model/server/upload/cover/1.jpeg differ
diff --git a/model/server/upload/cover/1.jpg b/model/server/upload/cover/1.jpg
new file mode 100644
index 0000000..24a816a
Binary files /dev/null and b/model/server/upload/cover/1.jpg differ
diff --git a/model/server/upload/cover/10.jpg b/model/server/upload/cover/10.jpg
new file mode 100644
index 0000000..f165ee2
Binary files /dev/null and b/model/server/upload/cover/10.jpg differ
diff --git a/model/server/upload/cover/11.jpg b/model/server/upload/cover/11.jpg
new file mode 100644
index 0000000..74c185d
Binary files /dev/null and b/model/server/upload/cover/11.jpg differ
diff --git a/model/server/upload/cover/111.jpg b/model/server/upload/cover/111.jpg
new file mode 100644
index 0000000..c65aa06
Binary files /dev/null and b/model/server/upload/cover/111.jpg differ
diff --git a/model/server/upload/cover/12.jpg b/model/server/upload/cover/12.jpg
new file mode 100644
index 0000000..f8e147d
Binary files /dev/null and b/model/server/upload/cover/12.jpg differ
diff --git a/model/server/upload/cover/13.jpg b/model/server/upload/cover/13.jpg
new file mode 100644
index 0000000..1b9689a
Binary files /dev/null and b/model/server/upload/cover/13.jpg differ
diff --git a/model/server/upload/cover/14.jpg b/model/server/upload/cover/14.jpg
new file mode 100644
index 0000000..ea79dd1
Binary files /dev/null and b/model/server/upload/cover/14.jpg differ
diff --git a/model/server/upload/cover/15.jpg b/model/server/upload/cover/15.jpg
new file mode 100644
index 0000000..592a699
Binary files /dev/null and b/model/server/upload/cover/15.jpg differ
diff --git a/model/server/upload/cover/16.jpg b/model/server/upload/cover/16.jpg
new file mode 100644
index 0000000..0ea0997
Binary files /dev/null and b/model/server/upload/cover/16.jpg differ
diff --git a/model/server/upload/cover/1672749055571.jpeg b/model/server/upload/cover/1672749055571.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/cover/1672749055571.jpeg differ
diff --git a/model/server/upload/cover/1674044230851.jpeg b/model/server/upload/cover/1674044230851.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/cover/1674044230851.jpeg differ
diff --git a/model/server/upload/cover/1676186518276.jpeg b/model/server/upload/cover/1676186518276.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/cover/1676186518276.jpeg differ
diff --git a/model/server/upload/cover/1676186872895.png b/model/server/upload/cover/1676186872895.png
new file mode 100644
index 0000000..b210819
Binary files /dev/null and b/model/server/upload/cover/1676186872895.png differ
diff --git a/model/server/upload/cover/1676186935002.png b/model/server/upload/cover/1676186935002.png
new file mode 100644
index 0000000..f8d1e7d
Binary files /dev/null and b/model/server/upload/cover/1676186935002.png differ
diff --git a/model/server/upload/cover/1676188277099.png b/model/server/upload/cover/1676188277099.png
new file mode 100644
index 0000000..8660887
Binary files /dev/null and b/model/server/upload/cover/1676188277099.png differ
diff --git a/model/server/upload/cover/1676188355688.png b/model/server/upload/cover/1676188355688.png
new file mode 100644
index 0000000..c7a5068
Binary files /dev/null and b/model/server/upload/cover/1676188355688.png differ
diff --git a/model/server/upload/cover/1676381084256.png b/model/server/upload/cover/1676381084256.png
new file mode 100644
index 0000000..2e617f2
Binary files /dev/null and b/model/server/upload/cover/1676381084256.png differ
diff --git a/model/server/upload/cover/1676381091144.png b/model/server/upload/cover/1676381091144.png
new file mode 100644
index 0000000..2f2f6bc
Binary files /dev/null and b/model/server/upload/cover/1676381091144.png differ
diff --git a/model/server/upload/cover/1676381097051.png b/model/server/upload/cover/1676381097051.png
new file mode 100644
index 0000000..c7a5068
Binary files /dev/null and b/model/server/upload/cover/1676381097051.png differ
diff --git a/model/server/upload/cover/1676381103032.png b/model/server/upload/cover/1676381103032.png
new file mode 100644
index 0000000..f8d1e7d
Binary files /dev/null and b/model/server/upload/cover/1676381103032.png differ
diff --git a/model/server/upload/cover/1676381110015.png b/model/server/upload/cover/1676381110015.png
new file mode 100644
index 0000000..b210819
Binary files /dev/null and b/model/server/upload/cover/1676381110015.png differ
diff --git a/model/server/upload/cover/1677500674281.jpeg b/model/server/upload/cover/1677500674281.jpeg
new file mode 100644
index 0000000..24a816a
Binary files /dev/null and b/model/server/upload/cover/1677500674281.jpeg differ
diff --git a/model/server/upload/cover/1677501266461.jpeg b/model/server/upload/cover/1677501266461.jpeg
new file mode 100644
index 0000000..24a816a
Binary files /dev/null and b/model/server/upload/cover/1677501266461.jpeg differ
diff --git a/model/server/upload/cover/1677501470234.jpeg b/model/server/upload/cover/1677501470234.jpeg
new file mode 100644
index 0000000..a365c8b
Binary files /dev/null and b/model/server/upload/cover/1677501470234.jpeg differ
diff --git a/model/server/upload/cover/1677501544737.jpeg b/model/server/upload/cover/1677501544737.jpeg
new file mode 100644
index 0000000..396d416
Binary files /dev/null and b/model/server/upload/cover/1677501544737.jpeg differ
diff --git a/model/server/upload/cover/1677505180730.jpeg b/model/server/upload/cover/1677505180730.jpeg
new file mode 100644
index 0000000..4fb1df0
Binary files /dev/null and b/model/server/upload/cover/1677505180730.jpeg differ
diff --git a/model/server/upload/cover/1677505298772.jpeg b/model/server/upload/cover/1677505298772.jpeg
new file mode 100644
index 0000000..b72839d
Binary files /dev/null and b/model/server/upload/cover/1677505298772.jpeg differ
diff --git a/model/server/upload/cover/1677505357042.jpeg b/model/server/upload/cover/1677505357042.jpeg
new file mode 100644
index 0000000..0c13434
Binary files /dev/null and b/model/server/upload/cover/1677505357042.jpeg differ
diff --git a/model/server/upload/cover/1677505364969.jpeg b/model/server/upload/cover/1677505364969.jpeg
new file mode 100644
index 0000000..f21e941
Binary files /dev/null and b/model/server/upload/cover/1677505364969.jpeg differ
diff --git a/model/server/upload/cover/1677505380921.jpeg b/model/server/upload/cover/1677505380921.jpeg
new file mode 100644
index 0000000..beb603c
Binary files /dev/null and b/model/server/upload/cover/1677505380921.jpeg differ
diff --git a/model/server/upload/cover/1677505393025.jpeg b/model/server/upload/cover/1677505393025.jpeg
new file mode 100644
index 0000000..beb603c
Binary files /dev/null and b/model/server/upload/cover/1677505393025.jpeg differ
diff --git a/model/server/upload/cover/1677505410960.jpeg b/model/server/upload/cover/1677505410960.jpeg
new file mode 100644
index 0000000..86779b7
Binary files /dev/null and b/model/server/upload/cover/1677505410960.jpeg differ
diff --git a/model/server/upload/cover/1677505421920.jpeg b/model/server/upload/cover/1677505421920.jpeg
new file mode 100644
index 0000000..9b30602
Binary files /dev/null and b/model/server/upload/cover/1677505421920.jpeg differ
diff --git a/model/server/upload/cover/1677505436478.jpeg b/model/server/upload/cover/1677505436478.jpeg
new file mode 100644
index 0000000..778bbd4
Binary files /dev/null and b/model/server/upload/cover/1677505436478.jpeg differ
diff --git a/model/server/upload/cover/1677505452753.jpeg b/model/server/upload/cover/1677505452753.jpeg
new file mode 100644
index 0000000..f165ee2
Binary files /dev/null and b/model/server/upload/cover/1677505452753.jpeg differ
diff --git a/model/server/upload/cover/1677505579480.jpeg b/model/server/upload/cover/1677505579480.jpeg
new file mode 100644
index 0000000..4fb1df0
Binary files /dev/null and b/model/server/upload/cover/1677505579480.jpeg differ
diff --git a/model/server/upload/cover/1677505616285.jpeg b/model/server/upload/cover/1677505616285.jpeg
new file mode 100644
index 0000000..b72839d
Binary files /dev/null and b/model/server/upload/cover/1677505616285.jpeg differ
diff --git a/model/server/upload/cover/1677505626565.jpeg b/model/server/upload/cover/1677505626565.jpeg
new file mode 100644
index 0000000..0c13434
Binary files /dev/null and b/model/server/upload/cover/1677505626565.jpeg differ
diff --git a/model/server/upload/cover/1677505637425.jpeg b/model/server/upload/cover/1677505637425.jpeg
new file mode 100644
index 0000000..f21e941
Binary files /dev/null and b/model/server/upload/cover/1677505637425.jpeg differ
diff --git a/model/server/upload/cover/1677505648826.jpeg b/model/server/upload/cover/1677505648826.jpeg
new file mode 100644
index 0000000..beb603c
Binary files /dev/null and b/model/server/upload/cover/1677505648826.jpeg differ
diff --git a/model/server/upload/cover/1677505659291.jpeg b/model/server/upload/cover/1677505659291.jpeg
new file mode 100644
index 0000000..ae763d8
Binary files /dev/null and b/model/server/upload/cover/1677505659291.jpeg differ
diff --git a/model/server/upload/cover/1677505667178.jpeg b/model/server/upload/cover/1677505667178.jpeg
new file mode 100644
index 0000000..9b30602
Binary files /dev/null and b/model/server/upload/cover/1677505667178.jpeg differ
diff --git a/model/server/upload/cover/1677505685641.jpeg b/model/server/upload/cover/1677505685641.jpeg
new file mode 100644
index 0000000..86779b7
Binary files /dev/null and b/model/server/upload/cover/1677505685641.jpeg differ
diff --git a/model/server/upload/cover/1677505695894.jpeg b/model/server/upload/cover/1677505695894.jpeg
new file mode 100644
index 0000000..778bbd4
Binary files /dev/null and b/model/server/upload/cover/1677505695894.jpeg differ
diff --git a/model/server/upload/cover/1677505706333.jpeg b/model/server/upload/cover/1677505706333.jpeg
new file mode 100644
index 0000000..f165ee2
Binary files /dev/null and b/model/server/upload/cover/1677505706333.jpeg differ
diff --git a/model/server/upload/cover/1677505876732.jpeg b/model/server/upload/cover/1677505876732.jpeg
new file mode 100644
index 0000000..4fb1df0
Binary files /dev/null and b/model/server/upload/cover/1677505876732.jpeg differ
diff --git a/model/server/upload/cover/1677505884200.jpeg b/model/server/upload/cover/1677505884200.jpeg
new file mode 100644
index 0000000..b72839d
Binary files /dev/null and b/model/server/upload/cover/1677505884200.jpeg differ
diff --git a/model/server/upload/cover/1677505890616.jpeg b/model/server/upload/cover/1677505890616.jpeg
new file mode 100644
index 0000000..0c13434
Binary files /dev/null and b/model/server/upload/cover/1677505890616.jpeg differ
diff --git a/model/server/upload/cover/1677505897079.jpeg b/model/server/upload/cover/1677505897079.jpeg
new file mode 100644
index 0000000..f21e941
Binary files /dev/null and b/model/server/upload/cover/1677505897079.jpeg differ
diff --git a/model/server/upload/cover/1677505910282.jpeg b/model/server/upload/cover/1677505910282.jpeg
new file mode 100644
index 0000000..beb603c
Binary files /dev/null and b/model/server/upload/cover/1677505910282.jpeg differ
diff --git a/model/server/upload/cover/1677505919134.jpeg b/model/server/upload/cover/1677505919134.jpeg
new file mode 100644
index 0000000..ae763d8
Binary files /dev/null and b/model/server/upload/cover/1677505919134.jpeg differ
diff --git a/model/server/upload/cover/1677505928898.jpeg b/model/server/upload/cover/1677505928898.jpeg
new file mode 100644
index 0000000..86779b7
Binary files /dev/null and b/model/server/upload/cover/1677505928898.jpeg differ
diff --git a/model/server/upload/cover/1677505937048.jpeg b/model/server/upload/cover/1677505937048.jpeg
new file mode 100644
index 0000000..9b30602
Binary files /dev/null and b/model/server/upload/cover/1677505937048.jpeg differ
diff --git a/model/server/upload/cover/1677505945207.jpeg b/model/server/upload/cover/1677505945207.jpeg
new file mode 100644
index 0000000..778bbd4
Binary files /dev/null and b/model/server/upload/cover/1677505945207.jpeg differ
diff --git a/model/server/upload/cover/1677505953782.jpeg b/model/server/upload/cover/1677505953782.jpeg
new file mode 100644
index 0000000..74c185d
Binary files /dev/null and b/model/server/upload/cover/1677505953782.jpeg differ
diff --git a/model/server/upload/cover/1677588447622.jpeg b/model/server/upload/cover/1677588447622.jpeg
new file mode 100644
index 0000000..f165ee2
Binary files /dev/null and b/model/server/upload/cover/1677588447622.jpeg differ
diff --git a/model/server/upload/cover/1677677497401.jpeg b/model/server/upload/cover/1677677497401.jpeg
new file mode 100644
index 0000000..9d2b60f
Binary files /dev/null and b/model/server/upload/cover/1677677497401.jpeg differ
diff --git a/model/server/upload/cover/1678529114670.jpeg b/model/server/upload/cover/1678529114670.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/cover/1678529114670.jpeg differ
diff --git a/model/server/upload/cover/1679056479437.jpeg b/model/server/upload/cover/1679056479437.jpeg
new file mode 100644
index 0000000..98f844f
Binary files /dev/null and b/model/server/upload/cover/1679056479437.jpeg differ
diff --git a/model/server/upload/cover/1679056528013.png b/model/server/upload/cover/1679056528013.png
new file mode 100644
index 0000000..e436655
Binary files /dev/null and b/model/server/upload/cover/1679056528013.png differ
diff --git a/model/server/upload/cover/1679056561868.jpeg b/model/server/upload/cover/1679056561868.jpeg
new file mode 100644
index 0000000..69129ca
Binary files /dev/null and b/model/server/upload/cover/1679056561868.jpeg differ
diff --git a/model/server/upload/cover/1679056587496.jpeg b/model/server/upload/cover/1679056587496.jpeg
new file mode 100644
index 0000000..b3a8c95
Binary files /dev/null and b/model/server/upload/cover/1679056587496.jpeg differ
diff --git a/model/server/upload/cover/1679058036014.jpeg b/model/server/upload/cover/1679058036014.jpeg
new file mode 100644
index 0000000..1d81aca
Binary files /dev/null and b/model/server/upload/cover/1679058036014.jpeg differ
diff --git a/model/server/upload/cover/1679058043365.jpeg b/model/server/upload/cover/1679058043365.jpeg
new file mode 100644
index 0000000..3f366cb
Binary files /dev/null and b/model/server/upload/cover/1679058043365.jpeg differ
diff --git a/model/server/upload/cover/1679229610791.jpeg b/model/server/upload/cover/1679229610791.jpeg
new file mode 100644
index 0000000..d743d72
Binary files /dev/null and b/model/server/upload/cover/1679229610791.jpeg differ
diff --git a/model/server/upload/cover/1679229780971.jpeg b/model/server/upload/cover/1679229780971.jpeg
new file mode 100644
index 0000000..b145c65
Binary files /dev/null and b/model/server/upload/cover/1679229780971.jpeg differ
diff --git a/model/server/upload/cover/1679229853940.jpeg b/model/server/upload/cover/1679229853940.jpeg
new file mode 100644
index 0000000..219e0f6
Binary files /dev/null and b/model/server/upload/cover/1679229853940.jpeg differ
diff --git a/model/server/upload/cover/1679229963230.jpeg b/model/server/upload/cover/1679229963230.jpeg
new file mode 100644
index 0000000..838b881
Binary files /dev/null and b/model/server/upload/cover/1679229963230.jpeg differ
diff --git a/model/server/upload/cover/1679230045590.jpeg b/model/server/upload/cover/1679230045590.jpeg
new file mode 100644
index 0000000..0cddaf7
Binary files /dev/null and b/model/server/upload/cover/1679230045590.jpeg differ
diff --git a/model/server/upload/cover/1679230092657.jpeg b/model/server/upload/cover/1679230092657.jpeg
new file mode 100644
index 0000000..1841b49
Binary files /dev/null and b/model/server/upload/cover/1679230092657.jpeg differ
diff --git a/model/server/upload/cover/1679230147996.jpeg b/model/server/upload/cover/1679230147996.jpeg
new file mode 100644
index 0000000..5116445
Binary files /dev/null and b/model/server/upload/cover/1679230147996.jpeg differ
diff --git a/model/server/upload/cover/1679230364390.jpeg b/model/server/upload/cover/1679230364390.jpeg
new file mode 100644
index 0000000..164ea26
Binary files /dev/null and b/model/server/upload/cover/1679230364390.jpeg differ
diff --git a/model/server/upload/cover/1679230543572.jpeg b/model/server/upload/cover/1679230543572.jpeg
new file mode 100644
index 0000000..ebc68a9
Binary files /dev/null and b/model/server/upload/cover/1679230543572.jpeg differ
diff --git a/model/server/upload/cover/1679230586243.jpeg b/model/server/upload/cover/1679230586243.jpeg
new file mode 100644
index 0000000..255c292
Binary files /dev/null and b/model/server/upload/cover/1679230586243.jpeg differ
diff --git a/model/server/upload/cover/1679230641879.jpeg b/model/server/upload/cover/1679230641879.jpeg
new file mode 100644
index 0000000..2d2d8f9
Binary files /dev/null and b/model/server/upload/cover/1679230641879.jpeg differ
diff --git a/model/server/upload/cover/1679230894621.jpeg b/model/server/upload/cover/1679230894621.jpeg
new file mode 100644
index 0000000..f6c07c1
Binary files /dev/null and b/model/server/upload/cover/1679230894621.jpeg differ
diff --git a/model/server/upload/cover/1679230935716.jpeg b/model/server/upload/cover/1679230935716.jpeg
new file mode 100644
index 0000000..e68df06
Binary files /dev/null and b/model/server/upload/cover/1679230935716.jpeg differ
diff --git a/model/server/upload/cover/1679230989243.jpeg b/model/server/upload/cover/1679230989243.jpeg
new file mode 100644
index 0000000..e68df06
Binary files /dev/null and b/model/server/upload/cover/1679230989243.jpeg differ
diff --git a/model/server/upload/cover/1679231022326.jpeg b/model/server/upload/cover/1679231022326.jpeg
new file mode 100644
index 0000000..e5add01
Binary files /dev/null and b/model/server/upload/cover/1679231022326.jpeg differ
diff --git a/model/server/upload/cover/1679231052822.jpeg b/model/server/upload/cover/1679231052822.jpeg
new file mode 100644
index 0000000..2532447
Binary files /dev/null and b/model/server/upload/cover/1679231052822.jpeg differ
diff --git a/model/server/upload/cover/1679231084420.jpeg b/model/server/upload/cover/1679231084420.jpeg
new file mode 100644
index 0000000..6ed9f8e
Binary files /dev/null and b/model/server/upload/cover/1679231084420.jpeg differ
diff --git a/model/server/upload/cover/1679231113572.jpeg b/model/server/upload/cover/1679231113572.jpeg
new file mode 100644
index 0000000..34ebbbe
Binary files /dev/null and b/model/server/upload/cover/1679231113572.jpeg differ
diff --git a/model/server/upload/cover/1679231151929.jpeg b/model/server/upload/cover/1679231151929.jpeg
new file mode 100644
index 0000000..c50bb49
Binary files /dev/null and b/model/server/upload/cover/1679231151929.jpeg differ
diff --git a/model/server/upload/cover/1679231184020.jpeg b/model/server/upload/cover/1679231184020.jpeg
new file mode 100644
index 0000000..9104601
Binary files /dev/null and b/model/server/upload/cover/1679231184020.jpeg differ
diff --git a/model/server/upload/cover/1679231221940.jpeg b/model/server/upload/cover/1679231221940.jpeg
new file mode 100644
index 0000000..d7e6034
Binary files /dev/null and b/model/server/upload/cover/1679231221940.jpeg differ
diff --git a/model/server/upload/cover/1679231465845.jpeg b/model/server/upload/cover/1679231465845.jpeg
new file mode 100644
index 0000000..3ac987b
Binary files /dev/null and b/model/server/upload/cover/1679231465845.jpeg differ
diff --git a/model/server/upload/cover/1679232418133.jpeg b/model/server/upload/cover/1679232418133.jpeg
new file mode 100644
index 0000000..91169c7
Binary files /dev/null and b/model/server/upload/cover/1679232418133.jpeg differ
diff --git a/model/server/upload/cover/1679232448857.jpeg b/model/server/upload/cover/1679232448857.jpeg
new file mode 100644
index 0000000..ccf01a2
Binary files /dev/null and b/model/server/upload/cover/1679232448857.jpeg differ
diff --git a/model/server/upload/cover/1679232480948.jpeg b/model/server/upload/cover/1679232480948.jpeg
new file mode 100644
index 0000000..d75d607
Binary files /dev/null and b/model/server/upload/cover/1679232480948.jpeg differ
diff --git a/model/server/upload/cover/1679232514230.jpeg b/model/server/upload/cover/1679232514230.jpeg
new file mode 100644
index 0000000..54a856f
Binary files /dev/null and b/model/server/upload/cover/1679232514230.jpeg differ
diff --git a/model/server/upload/cover/1679232543082.jpeg b/model/server/upload/cover/1679232543082.jpeg
new file mode 100644
index 0000000..872ab09
Binary files /dev/null and b/model/server/upload/cover/1679232543082.jpeg differ
diff --git a/model/server/upload/cover/1679232587234.jpeg b/model/server/upload/cover/1679232587234.jpeg
new file mode 100644
index 0000000..44f3df9
Binary files /dev/null and b/model/server/upload/cover/1679232587234.jpeg differ
diff --git a/model/server/upload/cover/1679232615578.jpeg b/model/server/upload/cover/1679232615578.jpeg
new file mode 100644
index 0000000..012fc8b
Binary files /dev/null and b/model/server/upload/cover/1679232615578.jpeg differ
diff --git a/model/server/upload/cover/1679232650073.jpeg b/model/server/upload/cover/1679232650073.jpeg
new file mode 100644
index 0000000..e6376ab
Binary files /dev/null and b/model/server/upload/cover/1679232650073.jpeg differ
diff --git a/model/server/upload/cover/1679232676818.jpeg b/model/server/upload/cover/1679232676818.jpeg
new file mode 100644
index 0000000..799c49e
Binary files /dev/null and b/model/server/upload/cover/1679232676818.jpeg differ
diff --git a/model/server/upload/cover/1679232717023.jpeg b/model/server/upload/cover/1679232717023.jpeg
new file mode 100644
index 0000000..54a856f
Binary files /dev/null and b/model/server/upload/cover/1679232717023.jpeg differ
diff --git a/model/server/upload/cover/1679232756075.jpeg b/model/server/upload/cover/1679232756075.jpeg
new file mode 100644
index 0000000..e6376ab
Binary files /dev/null and b/model/server/upload/cover/1679232756075.jpeg differ
diff --git a/model/server/upload/cover/1679315151478.jpeg b/model/server/upload/cover/1679315151478.jpeg
new file mode 100644
index 0000000..45d049f
Binary files /dev/null and b/model/server/upload/cover/1679315151478.jpeg differ
diff --git a/model/server/upload/cover/1679315191893.jpeg b/model/server/upload/cover/1679315191893.jpeg
new file mode 100644
index 0000000..681dc44
Binary files /dev/null and b/model/server/upload/cover/1679315191893.jpeg differ
diff --git a/model/server/upload/cover/1679315240787.jpeg b/model/server/upload/cover/1679315240787.jpeg
new file mode 100644
index 0000000..4506276
Binary files /dev/null and b/model/server/upload/cover/1679315240787.jpeg differ
diff --git a/model/server/upload/cover/1679315276060.jpeg b/model/server/upload/cover/1679315276060.jpeg
new file mode 100644
index 0000000..a2315c9
Binary files /dev/null and b/model/server/upload/cover/1679315276060.jpeg differ
diff --git a/model/server/upload/cover/1679315310720.jpeg b/model/server/upload/cover/1679315310720.jpeg
new file mode 100644
index 0000000..8b96844
Binary files /dev/null and b/model/server/upload/cover/1679315310720.jpeg differ
diff --git a/model/server/upload/cover/1679315343720.jpeg b/model/server/upload/cover/1679315343720.jpeg
new file mode 100644
index 0000000..3c8cca1
Binary files /dev/null and b/model/server/upload/cover/1679315343720.jpeg differ
diff --git a/model/server/upload/cover/1679315365210.jpeg b/model/server/upload/cover/1679315365210.jpeg
new file mode 100644
index 0000000..1c6407e
Binary files /dev/null and b/model/server/upload/cover/1679315365210.jpeg differ
diff --git a/model/server/upload/cover/1679315396953.jpeg b/model/server/upload/cover/1679315396953.jpeg
new file mode 100644
index 0000000..6a34bbc
Binary files /dev/null and b/model/server/upload/cover/1679315396953.jpeg differ
diff --git a/model/server/upload/cover/1679315437571.jpeg b/model/server/upload/cover/1679315437571.jpeg
new file mode 100644
index 0000000..dcca8d9
Binary files /dev/null and b/model/server/upload/cover/1679315437571.jpeg differ
diff --git a/model/server/upload/cover/1679315478327.jpeg b/model/server/upload/cover/1679315478327.jpeg
new file mode 100644
index 0000000..1936978
Binary files /dev/null and b/model/server/upload/cover/1679315478327.jpeg differ
diff --git a/model/server/upload/cover/1679315749022.jpeg b/model/server/upload/cover/1679315749022.jpeg
new file mode 100644
index 0000000..203c6ad
Binary files /dev/null and b/model/server/upload/cover/1679315749022.jpeg differ
diff --git a/model/server/upload/cover/1679315761797.jpeg b/model/server/upload/cover/1679315761797.jpeg
new file mode 100644
index 0000000..aba7423
Binary files /dev/null and b/model/server/upload/cover/1679315761797.jpeg differ
diff --git a/model/server/upload/cover/1679315803245.jpeg b/model/server/upload/cover/1679315803245.jpeg
new file mode 100644
index 0000000..59b28fc
Binary files /dev/null and b/model/server/upload/cover/1679315803245.jpeg differ
diff --git a/model/server/upload/cover/1679315842977.jpeg b/model/server/upload/cover/1679315842977.jpeg
new file mode 100644
index 0000000..579169a
Binary files /dev/null and b/model/server/upload/cover/1679315842977.jpeg differ
diff --git a/model/server/upload/cover/1679315883620.jpeg b/model/server/upload/cover/1679315883620.jpeg
new file mode 100644
index 0000000..a6005a3
Binary files /dev/null and b/model/server/upload/cover/1679315883620.jpeg differ
diff --git a/model/server/upload/cover/1679315915467.jpeg b/model/server/upload/cover/1679315915467.jpeg
new file mode 100644
index 0000000..abe8950
Binary files /dev/null and b/model/server/upload/cover/1679315915467.jpeg differ
diff --git a/model/server/upload/cover/1679315954931.jpeg b/model/server/upload/cover/1679315954931.jpeg
new file mode 100644
index 0000000..d49efdf
Binary files /dev/null and b/model/server/upload/cover/1679315954931.jpeg differ
diff --git a/model/server/upload/cover/1679315985852.jpeg b/model/server/upload/cover/1679315985852.jpeg
new file mode 100644
index 0000000..a0442f3
Binary files /dev/null and b/model/server/upload/cover/1679315985852.jpeg differ
diff --git a/model/server/upload/cover/1679316037517.jpeg b/model/server/upload/cover/1679316037517.jpeg
new file mode 100644
index 0000000..ec3eadf
Binary files /dev/null and b/model/server/upload/cover/1679316037517.jpeg differ
diff --git a/model/server/upload/cover/1679316072493.jpeg b/model/server/upload/cover/1679316072493.jpeg
new file mode 100644
index 0000000..4b2f05a
Binary files /dev/null and b/model/server/upload/cover/1679316072493.jpeg differ
diff --git a/model/server/upload/cover/1679316422812.jpeg b/model/server/upload/cover/1679316422812.jpeg
new file mode 100644
index 0000000..6062ab7
Binary files /dev/null and b/model/server/upload/cover/1679316422812.jpeg differ
diff --git a/model/server/upload/cover/1679316453474.jpeg b/model/server/upload/cover/1679316453474.jpeg
new file mode 100644
index 0000000..c4d13de
Binary files /dev/null and b/model/server/upload/cover/1679316453474.jpeg differ
diff --git a/model/server/upload/cover/1679316484842.jpeg b/model/server/upload/cover/1679316484842.jpeg
new file mode 100644
index 0000000..125d07d
Binary files /dev/null and b/model/server/upload/cover/1679316484842.jpeg differ
diff --git a/model/server/upload/cover/1679316513693.jpeg b/model/server/upload/cover/1679316513693.jpeg
new file mode 100644
index 0000000..bcf50d8
Binary files /dev/null and b/model/server/upload/cover/1679316513693.jpeg differ
diff --git a/model/server/upload/cover/1679316533369.jpeg b/model/server/upload/cover/1679316533369.jpeg
new file mode 100644
index 0000000..1e09ed8
Binary files /dev/null and b/model/server/upload/cover/1679316533369.jpeg differ
diff --git a/model/server/upload/cover/1679316566135.jpeg b/model/server/upload/cover/1679316566135.jpeg
new file mode 100644
index 0000000..24bc533
Binary files /dev/null and b/model/server/upload/cover/1679316566135.jpeg differ
diff --git a/model/server/upload/cover/1679316605104.jpeg b/model/server/upload/cover/1679316605104.jpeg
new file mode 100644
index 0000000..d49efdf
Binary files /dev/null and b/model/server/upload/cover/1679316605104.jpeg differ
diff --git a/model/server/upload/cover/1679316637185.jpeg b/model/server/upload/cover/1679316637185.jpeg
new file mode 100644
index 0000000..a0442f3
Binary files /dev/null and b/model/server/upload/cover/1679316637185.jpeg differ
diff --git a/model/server/upload/cover/1679316666891.jpeg b/model/server/upload/cover/1679316666891.jpeg
new file mode 100644
index 0000000..ec3eadf
Binary files /dev/null and b/model/server/upload/cover/1679316666891.jpeg differ
diff --git a/model/server/upload/cover/1679316698087.jpeg b/model/server/upload/cover/1679316698087.jpeg
new file mode 100644
index 0000000..4b2f05a
Binary files /dev/null and b/model/server/upload/cover/1679316698087.jpeg differ
diff --git a/model/server/upload/cover/1679403034316.jpeg b/model/server/upload/cover/1679403034316.jpeg
new file mode 100644
index 0000000..40de94e
Binary files /dev/null and b/model/server/upload/cover/1679403034316.jpeg differ
diff --git a/model/server/upload/cover/1679403102225.jpeg b/model/server/upload/cover/1679403102225.jpeg
new file mode 100644
index 0000000..6320a75
Binary files /dev/null and b/model/server/upload/cover/1679403102225.jpeg differ
diff --git a/model/server/upload/cover/1679403138846.jpeg b/model/server/upload/cover/1679403138846.jpeg
new file mode 100644
index 0000000..620779b
Binary files /dev/null and b/model/server/upload/cover/1679403138846.jpeg differ
diff --git a/model/server/upload/cover/1679403158073.jpeg b/model/server/upload/cover/1679403158073.jpeg
new file mode 100644
index 0000000..9eafe2b
Binary files /dev/null and b/model/server/upload/cover/1679403158073.jpeg differ
diff --git a/model/server/upload/cover/1679403193320.jpeg b/model/server/upload/cover/1679403193320.jpeg
new file mode 100644
index 0000000..3fe9168
Binary files /dev/null and b/model/server/upload/cover/1679403193320.jpeg differ
diff --git a/model/server/upload/cover/1679403239138.jpeg b/model/server/upload/cover/1679403239138.jpeg
new file mode 100644
index 0000000..225d8df
Binary files /dev/null and b/model/server/upload/cover/1679403239138.jpeg differ
diff --git a/model/server/upload/cover/1679403285129.jpeg b/model/server/upload/cover/1679403285129.jpeg
new file mode 100644
index 0000000..ad2d040
Binary files /dev/null and b/model/server/upload/cover/1679403285129.jpeg differ
diff --git a/model/server/upload/cover/1679403331202.jpeg b/model/server/upload/cover/1679403331202.jpeg
new file mode 100644
index 0000000..87ca19e
Binary files /dev/null and b/model/server/upload/cover/1679403331202.jpeg differ
diff --git a/model/server/upload/cover/1679403370669.jpeg b/model/server/upload/cover/1679403370669.jpeg
new file mode 100644
index 0000000..212bea1
Binary files /dev/null and b/model/server/upload/cover/1679403370669.jpeg differ
diff --git a/model/server/upload/cover/1679403403756.jpeg b/model/server/upload/cover/1679403403756.jpeg
new file mode 100644
index 0000000..159c4bc
Binary files /dev/null and b/model/server/upload/cover/1679403403756.jpeg differ
diff --git a/model/server/upload/cover/1679403503106.jpeg b/model/server/upload/cover/1679403503106.jpeg
new file mode 100644
index 0000000..80b33bd
Binary files /dev/null and b/model/server/upload/cover/1679403503106.jpeg differ
diff --git a/model/server/upload/cover/1679403631942.jpeg b/model/server/upload/cover/1679403631942.jpeg
new file mode 100644
index 0000000..3f56e26
Binary files /dev/null and b/model/server/upload/cover/1679403631942.jpeg differ
diff --git a/model/server/upload/cover/1679403697740.jpeg b/model/server/upload/cover/1679403697740.jpeg
new file mode 100644
index 0000000..d6c996d
Binary files /dev/null and b/model/server/upload/cover/1679403697740.jpeg differ
diff --git a/model/server/upload/cover/1679403736341.jpeg b/model/server/upload/cover/1679403736341.jpeg
new file mode 100644
index 0000000..bab78b7
Binary files /dev/null and b/model/server/upload/cover/1679403736341.jpeg differ
diff --git a/model/server/upload/cover/1679488092121.jpeg b/model/server/upload/cover/1679488092121.jpeg
new file mode 100644
index 0000000..e320a53
Binary files /dev/null and b/model/server/upload/cover/1679488092121.jpeg differ
diff --git a/model/server/upload/cover/1684567758685.jpeg b/model/server/upload/cover/1684567758685.jpeg
new file mode 100644
index 0000000..3de9ef0
Binary files /dev/null and b/model/server/upload/cover/1684567758685.jpeg differ
diff --git a/model/server/upload/cover/1684567804066.jpeg b/model/server/upload/cover/1684567804066.jpeg
new file mode 100644
index 0000000..ab5a05b
Binary files /dev/null and b/model/server/upload/cover/1684567804066.jpeg differ
diff --git a/model/server/upload/cover/1684567891591.png b/model/server/upload/cover/1684567891591.png
new file mode 100644
index 0000000..a031985
Binary files /dev/null and b/model/server/upload/cover/1684567891591.png differ
diff --git a/model/server/upload/cover/1686368636971.jpeg b/model/server/upload/cover/1686368636971.jpeg
new file mode 100644
index 0000000..3de9ef0
Binary files /dev/null and b/model/server/upload/cover/1686368636971.jpeg differ
diff --git a/model/server/upload/cover/1686368989472.jpeg b/model/server/upload/cover/1686368989472.jpeg
new file mode 100644
index 0000000..6829918
Binary files /dev/null and b/model/server/upload/cover/1686368989472.jpeg differ
diff --git a/model/server/upload/cover/1686369498575.jpeg b/model/server/upload/cover/1686369498575.jpeg
new file mode 100644
index 0000000..b6f5c63
Binary files /dev/null and b/model/server/upload/cover/1686369498575.jpeg differ
diff --git a/model/server/upload/cover/1686369534606.jpeg b/model/server/upload/cover/1686369534606.jpeg
new file mode 100644
index 0000000..6829918
Binary files /dev/null and b/model/server/upload/cover/1686369534606.jpeg differ
diff --git a/model/server/upload/cover/1686381298517.jpeg b/model/server/upload/cover/1686381298517.jpeg
new file mode 100644
index 0000000..60038e0
Binary files /dev/null and b/model/server/upload/cover/1686381298517.jpeg differ
diff --git a/model/server/upload/cover/1686381579098.jpeg b/model/server/upload/cover/1686381579098.jpeg
new file mode 100644
index 0000000..b6f5c63
Binary files /dev/null and b/model/server/upload/cover/1686381579098.jpeg differ
diff --git a/model/server/upload/cover/1686382652823.jpeg b/model/server/upload/cover/1686382652823.jpeg
new file mode 100644
index 0000000..a2e76e1
Binary files /dev/null and b/model/server/upload/cover/1686382652823.jpeg differ
diff --git a/model/server/upload/cover/1686382753352.jpeg b/model/server/upload/cover/1686382753352.jpeg
new file mode 100644
index 0000000..5c633c5
Binary files /dev/null and b/model/server/upload/cover/1686382753352.jpeg differ
diff --git a/model/server/upload/cover/1686382790756.jpeg b/model/server/upload/cover/1686382790756.jpeg
new file mode 100644
index 0000000..a0d7888
Binary files /dev/null and b/model/server/upload/cover/1686382790756.jpeg differ
diff --git a/model/server/upload/cover/1686382828553.jpeg b/model/server/upload/cover/1686382828553.jpeg
new file mode 100644
index 0000000..504e834
Binary files /dev/null and b/model/server/upload/cover/1686382828553.jpeg differ
diff --git a/model/server/upload/cover/1686382868658.jpeg b/model/server/upload/cover/1686382868658.jpeg
new file mode 100644
index 0000000..480b87a
Binary files /dev/null and b/model/server/upload/cover/1686382868658.jpeg differ
diff --git a/model/server/upload/cover/1686382902635.jpeg b/model/server/upload/cover/1686382902635.jpeg
new file mode 100644
index 0000000..b6f5c63
Binary files /dev/null and b/model/server/upload/cover/1686382902635.jpeg differ
diff --git a/model/server/upload/cover/1686382960542.jpeg b/model/server/upload/cover/1686382960542.jpeg
new file mode 100644
index 0000000..a2e76e1
Binary files /dev/null and b/model/server/upload/cover/1686382960542.jpeg differ
diff --git a/model/server/upload/cover/1686382989770.jpeg b/model/server/upload/cover/1686382989770.jpeg
new file mode 100644
index 0000000..224cf3b
Binary files /dev/null and b/model/server/upload/cover/1686382989770.jpeg differ
diff --git a/model/server/upload/cover/1686383023502.jpeg b/model/server/upload/cover/1686383023502.jpeg
new file mode 100644
index 0000000..5c633c5
Binary files /dev/null and b/model/server/upload/cover/1686383023502.jpeg differ
diff --git a/model/server/upload/cover/1686383058316.jpeg b/model/server/upload/cover/1686383058316.jpeg
new file mode 100644
index 0000000..504e834
Binary files /dev/null and b/model/server/upload/cover/1686383058316.jpeg differ
diff --git a/model/server/upload/cover/1686383098285.jpeg b/model/server/upload/cover/1686383098285.jpeg
new file mode 100644
index 0000000..b6f5c63
Binary files /dev/null and b/model/server/upload/cover/1686383098285.jpeg differ
diff --git a/model/server/upload/cover/1686383153904.jpeg b/model/server/upload/cover/1686383153904.jpeg
new file mode 100644
index 0000000..5ee2267
Binary files /dev/null and b/model/server/upload/cover/1686383153904.jpeg differ
diff --git a/model/server/upload/cover/1686383262923.jpeg b/model/server/upload/cover/1686383262923.jpeg
new file mode 100644
index 0000000..60038e0
Binary files /dev/null and b/model/server/upload/cover/1686383262923.jpeg differ
diff --git a/model/server/upload/cover/17.jpg b/model/server/upload/cover/17.jpg
new file mode 100644
index 0000000..51581f1
Binary files /dev/null and b/model/server/upload/cover/17.jpg differ
diff --git a/model/server/upload/cover/1705994381986.jpeg b/model/server/upload/cover/1705994381986.jpeg
new file mode 100644
index 0000000..f10ae2c
Binary files /dev/null and b/model/server/upload/cover/1705994381986.jpeg differ
diff --git a/model/server/upload/cover/1705994824587.jpeg b/model/server/upload/cover/1705994824587.jpeg
new file mode 100644
index 0000000..3de9ef0
Binary files /dev/null and b/model/server/upload/cover/1705994824587.jpeg differ
diff --git a/model/server/upload/cover/1705994919820.jpeg b/model/server/upload/cover/1705994919820.jpeg
new file mode 100644
index 0000000..480b87a
Binary files /dev/null and b/model/server/upload/cover/1705994919820.jpeg differ
diff --git a/model/server/upload/cover/1705994975172.jpeg b/model/server/upload/cover/1705994975172.jpeg
new file mode 100644
index 0000000..b6f5c63
Binary files /dev/null and b/model/server/upload/cover/1705994975172.jpeg differ
diff --git a/model/server/upload/cover/1705995010387.jpeg b/model/server/upload/cover/1705995010387.jpeg
new file mode 100644
index 0000000..5c633c5
Binary files /dev/null and b/model/server/upload/cover/1705995010387.jpeg differ
diff --git a/model/server/upload/cover/1705995052760.jpeg b/model/server/upload/cover/1705995052760.jpeg
new file mode 100644
index 0000000..a0d7888
Binary files /dev/null and b/model/server/upload/cover/1705995052760.jpeg differ
diff --git a/model/server/upload/cover/1705995089822.jpeg b/model/server/upload/cover/1705995089822.jpeg
new file mode 100644
index 0000000..60038e0
Binary files /dev/null and b/model/server/upload/cover/1705995089822.jpeg differ
diff --git a/model/server/upload/cover/1705995130454.jpeg b/model/server/upload/cover/1705995130454.jpeg
new file mode 100644
index 0000000..504e834
Binary files /dev/null and b/model/server/upload/cover/1705995130454.jpeg differ
diff --git a/model/server/upload/cover/1705995194248.jpeg b/model/server/upload/cover/1705995194248.jpeg
new file mode 100644
index 0000000..a0d7888
Binary files /dev/null and b/model/server/upload/cover/1705995194248.jpeg differ
diff --git a/model/server/upload/cover/1707036603261.jpeg b/model/server/upload/cover/1707036603261.jpeg
new file mode 100644
index 0000000..c65aa06
Binary files /dev/null and b/model/server/upload/cover/1707036603261.jpeg differ
diff --git a/model/server/upload/cover/1707036638009.jpeg b/model/server/upload/cover/1707036638009.jpeg
new file mode 100644
index 0000000..1020f86
Binary files /dev/null and b/model/server/upload/cover/1707036638009.jpeg differ
diff --git a/model/server/upload/cover/1707036701716.jpeg b/model/server/upload/cover/1707036701716.jpeg
new file mode 100644
index 0000000..6eb07af
Binary files /dev/null and b/model/server/upload/cover/1707036701716.jpeg differ
diff --git a/model/server/upload/cover/1707036756214.jpeg b/model/server/upload/cover/1707036756214.jpeg
new file mode 100644
index 0000000..eca32ae
Binary files /dev/null and b/model/server/upload/cover/1707036756214.jpeg differ
diff --git a/model/server/upload/cover/1707036810262.jpeg b/model/server/upload/cover/1707036810262.jpeg
new file mode 100644
index 0000000..26592c0
Binary files /dev/null and b/model/server/upload/cover/1707036810262.jpeg differ
diff --git a/model/server/upload/cover/1707036858212.jpeg b/model/server/upload/cover/1707036858212.jpeg
new file mode 100644
index 0000000..de0fc05
Binary files /dev/null and b/model/server/upload/cover/1707036858212.jpeg differ
diff --git a/model/server/upload/cover/18.jpg b/model/server/upload/cover/18.jpg
new file mode 100644
index 0000000..6ab4c74
Binary files /dev/null and b/model/server/upload/cover/18.jpg differ
diff --git a/model/server/upload/cover/19.jpg b/model/server/upload/cover/19.jpg
new file mode 100644
index 0000000..9d2b60f
Binary files /dev/null and b/model/server/upload/cover/19.jpg differ
diff --git a/model/server/upload/cover/2.jpg b/model/server/upload/cover/2.jpg
new file mode 100644
index 0000000..b72839d
Binary files /dev/null and b/model/server/upload/cover/2.jpg differ
diff --git a/model/server/upload/cover/20.jpg b/model/server/upload/cover/20.jpg
new file mode 100644
index 0000000..c51bad3
Binary files /dev/null and b/model/server/upload/cover/20.jpg differ
diff --git a/model/server/upload/cover/21.jpg b/model/server/upload/cover/21.jpg
new file mode 100644
index 0000000..9ef3981
Binary files /dev/null and b/model/server/upload/cover/21.jpg differ
diff --git a/model/server/upload/cover/22.jpg b/model/server/upload/cover/22.jpg
new file mode 100644
index 0000000..4efff56
Binary files /dev/null and b/model/server/upload/cover/22.jpg differ
diff --git a/model/server/upload/cover/222.jpg b/model/server/upload/cover/222.jpg
new file mode 100644
index 0000000..1020f86
Binary files /dev/null and b/model/server/upload/cover/222.jpg differ
diff --git a/model/server/upload/cover/23.jpg b/model/server/upload/cover/23.jpg
new file mode 100644
index 0000000..400c2dd
Binary files /dev/null and b/model/server/upload/cover/23.jpg differ
diff --git a/model/server/upload/cover/24.jpg b/model/server/upload/cover/24.jpg
new file mode 100644
index 0000000..6e03acf
Binary files /dev/null and b/model/server/upload/cover/24.jpg differ
diff --git a/model/server/upload/cover/25.jpg b/model/server/upload/cover/25.jpg
new file mode 100644
index 0000000..77df2ec
Binary files /dev/null and b/model/server/upload/cover/25.jpg differ
diff --git a/model/server/upload/cover/26.jpg b/model/server/upload/cover/26.jpg
new file mode 100644
index 0000000..3408d56
Binary files /dev/null and b/model/server/upload/cover/26.jpg differ
diff --git a/model/server/upload/cover/27.jpg b/model/server/upload/cover/27.jpg
new file mode 100644
index 0000000..0432449
Binary files /dev/null and b/model/server/upload/cover/27.jpg differ
diff --git a/model/server/upload/cover/28.jpg b/model/server/upload/cover/28.jpg
new file mode 100644
index 0000000..0c043db
Binary files /dev/null and b/model/server/upload/cover/28.jpg differ
diff --git a/model/server/upload/cover/29.jpg b/model/server/upload/cover/29.jpg
new file mode 100644
index 0000000..792d77d
Binary files /dev/null and b/model/server/upload/cover/29.jpg differ
diff --git a/model/server/upload/cover/3.jpg b/model/server/upload/cover/3.jpg
new file mode 100644
index 0000000..0c13434
Binary files /dev/null and b/model/server/upload/cover/3.jpg differ
diff --git a/model/server/upload/cover/30.jpg b/model/server/upload/cover/30.jpg
new file mode 100644
index 0000000..a7a29f5
Binary files /dev/null and b/model/server/upload/cover/30.jpg differ
diff --git a/model/server/upload/cover/333.jpg b/model/server/upload/cover/333.jpg
new file mode 100644
index 0000000..6eb07af
Binary files /dev/null and b/model/server/upload/cover/333.jpg differ
diff --git a/model/server/upload/cover/4.jpg b/model/server/upload/cover/4.jpg
new file mode 100644
index 0000000..f21e941
Binary files /dev/null and b/model/server/upload/cover/4.jpg differ
diff --git a/model/server/upload/cover/444.jpg b/model/server/upload/cover/444.jpg
new file mode 100644
index 0000000..eca32ae
Binary files /dev/null and b/model/server/upload/cover/444.jpg differ
diff --git a/model/server/upload/cover/5.jpg b/model/server/upload/cover/5.jpg
new file mode 100644
index 0000000..beb603c
Binary files /dev/null and b/model/server/upload/cover/5.jpg differ
diff --git a/model/server/upload/cover/555.jpg b/model/server/upload/cover/555.jpg
new file mode 100644
index 0000000..26592c0
Binary files /dev/null and b/model/server/upload/cover/555.jpg differ
diff --git a/model/server/upload/cover/6.jpg b/model/server/upload/cover/6.jpg
new file mode 100644
index 0000000..ae763d8
Binary files /dev/null and b/model/server/upload/cover/6.jpg differ
diff --git a/model/server/upload/cover/666.jpg b/model/server/upload/cover/666.jpg
new file mode 100644
index 0000000..de0fc05
Binary files /dev/null and b/model/server/upload/cover/666.jpg differ
diff --git a/model/server/upload/cover/7.jpg b/model/server/upload/cover/7.jpg
new file mode 100644
index 0000000..86779b7
Binary files /dev/null and b/model/server/upload/cover/7.jpg differ
diff --git a/model/server/upload/cover/8.jpg b/model/server/upload/cover/8.jpg
new file mode 100644
index 0000000..9b30602
Binary files /dev/null and b/model/server/upload/cover/8.jpg differ
diff --git a/model/server/upload/cover/9.jpg b/model/server/upload/cover/9.jpg
new file mode 100644
index 0000000..778bbd4
Binary files /dev/null and b/model/server/upload/cover/9.jpg differ
diff --git a/model/server/upload/img/111.jpg b/model/server/upload/img/111.jpg
new file mode 100644
index 0000000..511bce0
Binary files /dev/null and b/model/server/upload/img/111.jpg differ
diff --git a/model/server/upload/img/222.jpg b/model/server/upload/img/222.jpg
new file mode 100644
index 0000000..c734137
Binary files /dev/null and b/model/server/upload/img/222.jpg differ
diff --git a/model/server/upload/img/Wechat.jpeg b/model/server/upload/img/Wechat.jpeg
new file mode 100644
index 0000000..f9bd228
Binary files /dev/null and b/model/server/upload/img/Wechat.jpeg differ
diff --git a/model/server/upload/img/weixin.png b/model/server/upload/img/weixin.png
new file mode 100644
index 0000000..f58b2b8
Binary files /dev/null and b/model/server/upload/img/weixin.png differ
diff --git a/model/web/.eslintignore b/model/web/.eslintignore
new file mode 100644
index 0000000..348631b
--- /dev/null
+++ b/model/web/.eslintignore
@@ -0,0 +1,15 @@
+
+*.sh
+node_modules
+*.md
+*.woff
+*.ttf
+.vscode
+.idea
+dist
+/public
+/docs
+.husky
+.local
+/bin
+Dockerfile
diff --git a/model/web/.eslintrc.js b/model/web/.eslintrc.js
new file mode 100644
index 0000000..af72ee6
--- /dev/null
+++ b/model/web/.eslintrc.js
@@ -0,0 +1,60 @@
+module.exports = {
+ root: true,
+ env: {
+ browser: true,
+ node: true,
+ es6: true,
+ },
+ parser: 'vue-eslint-parser',
+ parserOptions: {
+ parser: '@typescript-eslint/parser',
+ ecmaVersion: 2020,
+ sourceType: 'module',
+ jsxPragma: 'React',
+ ecmaFeatures: {
+ jsx: true,
+ },
+ },
+ extends: ['plugin:vue/vue3-recommended', 'plugin:@typescript-eslint/recommended', 'plugin:prettier/recommended'],
+ rules: {
+ 'vue/script-setup-uses-vars': 'error',
+ '@typescript-eslint/ban-ts-ignore': 'off',
+ '@typescript-eslint/explicit-function-return-type': 'off',
+ '@typescript-eslint/no-explicit-any': 'off',
+ '@typescript-eslint/no-var-requires': 'off',
+ '@typescript-eslint/no-empty-function': 'off',
+ 'vue/custom-event-name-casing': 'off',
+ 'no-use-before-define': 'off',
+ '@typescript-eslint/no-use-before-define': 'off',
+ '@typescript-eslint/ban-ts-comment': 'off',
+ '@typescript-eslint/ban-types': 'off',
+ '@typescript-eslint/no-non-null-assertion': 'off',
+ '@typescript-eslint/explicit-module-boundary-types': 'off',
+ '@typescript-eslint/no-unused-vars': 'off',
+ 'no-unused-vars': 'off',
+ 'space-before-function-paren': 'off',
+
+ 'vue/attributes-order': 'off',
+ 'vue/one-component-per-file': 'off',
+ 'vue/html-closing-bracket-newline': 'off',
+ 'vue/max-attributes-per-line': 'off',
+ 'vue/multiline-html-element-content-newline': 'off',
+ 'vue/singleline-html-element-content-newline': 'off',
+ 'vue/attribute-hyphenation': 'off',
+ 'vue/require-default-prop': 'off',
+ 'vue/require-explicit-emits': 'off',
+ 'vue/html-self-closing': [
+ 'error',
+ {
+ html: {
+ void: 'always',
+ normal: 'never',
+ component: 'always',
+ },
+ svg: 'always',
+ math: 'always',
+ },
+ ],
+ 'vue/multi-word-component-names': 'off',
+ },
+};
diff --git a/model/web/.gitignore b/model/web/.gitignore
new file mode 100644
index 0000000..0158db5
--- /dev/null
+++ b/model/web/.gitignore
@@ -0,0 +1,31 @@
+node_modules
+.DS_Store
+dist
+dist-ssr
+.local
+.history
+# local env files
+.env.local
+.env.*.local
+.eslintcache
+.github
+.husky
+.vscode
+
+# Log files
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+pnpm-debug.log*
+pnpm-lock.yaml*
+
+# Editor directories and files
+.idea
+# .vscode
+*.suo
+*.ntvs*
+*.njsproj
+*.sln
+*.sw?
+./packages
+./history
diff --git a/model/web/.stylelintignore b/model/web/.stylelintignore
new file mode 100644
index 0000000..0517076
--- /dev/null
+++ b/model/web/.stylelintignore
@@ -0,0 +1,3 @@
+/dist/*
+/public/*
+public/*
diff --git a/model/web/build/constant.ts b/model/web/build/constant.ts
new file mode 100644
index 0000000..ee3e537
--- /dev/null
+++ b/model/web/build/constant.ts
@@ -0,0 +1,13 @@
+/**
+ * @name Config
+ * @description 项目配置
+ */
+
+// 本地服务端口
+export const VITE_PORT = 8008;
+
+// 包依赖分析
+export const ANALYSIS = true;
+
+// 代码压缩
+export const COMPRESSION = true;
diff --git a/model/web/build/vite/plugins/autoImport.ts b/model/web/build/vite/plugins/autoImport.ts
new file mode 100644
index 0000000..a7f0df0
--- /dev/null
+++ b/model/web/build/vite/plugins/autoImport.ts
@@ -0,0 +1,26 @@
+/**
+ * @name AutoImportDeps
+ * @description 按需加载,自动引入
+ */
+import AutoImport from 'unplugin-auto-import/vite';
+// import { AntDesignVueResolver} from 'unplugin-vue-components/resolvers';
+
+export const AutoImportDeps = () => {
+ return AutoImport({
+ dts: 'types/auto-imports.d.ts',
+ imports: [
+ 'vue',
+ 'pinia',
+ 'vue-router',
+ {
+ '@vueuse/core': [],
+ },
+ {
+ 'naive-ui': ['useDialog', 'useMessage', 'useNotification', 'useLoadingBar'],
+ },
+ ],
+ resolvers: [
+ // AntDesignVueResolver(),
+ ],
+ });
+};
diff --git a/model/web/build/vite/plugins/component.ts b/model/web/build/vite/plugins/component.ts
new file mode 100644
index 0000000..1038028
--- /dev/null
+++ b/model/web/build/vite/plugins/component.ts
@@ -0,0 +1,36 @@
+/**
+ * @name AutoRegistryComponents
+ * @description 按需加载,自动引入组件
+ */
+import Components from 'unplugin-vue-components/vite';
+import {
+ ElementPlusResolver,
+ VueUseComponentsResolver,
+ AntDesignVueResolver,
+ TDesignResolver,
+ NaiveUiResolver,
+} from 'unplugin-vue-components/resolvers';
+export const AutoRegistryComponents = () => {
+ return Components({
+ dirs: ['src/components'],
+ extensions: ['vue'],
+ deep: true,
+ dts: 'types/components.d.ts',
+ directoryAsNamespace: false,
+ globalNamespaces: [],
+ directives: true,
+ importPathTransform: (v) => v,
+ allowOverrides: false,
+ include: [/\.vue$/, /\.vue\?vue/],
+ exclude: [/[\\/]node_modules[\\/]/, /[\\/]\.git[\\/]/, /[\\/]\.nuxt[\\/]/],
+ resolvers: [
+ ElementPlusResolver(),
+ VueUseComponentsResolver(),
+ AntDesignVueResolver(),
+ TDesignResolver({
+ library: 'vue-next',
+ }),
+ NaiveUiResolver(),
+ ],
+ });
+};
diff --git a/model/web/build/vite/plugins/compress.ts b/model/web/build/vite/plugins/compress.ts
new file mode 100644
index 0000000..74f9804
--- /dev/null
+++ b/model/web/build/vite/plugins/compress.ts
@@ -0,0 +1,20 @@
+/**
+ * @name ConfigCompressPlugin
+ * @description 开启.gz压缩
+ */
+import viteCompression from 'vite-plugin-compression';
+import { COMPRESSION } from '../../constant';
+
+export const ConfigCompressPlugin = () => {
+ if (COMPRESSION) {
+ return viteCompression({
+ verbose: true, // 默认即可
+ disable: false, //开启压缩(不禁用),默认即可
+ deleteOriginFile: false, //删除源文件
+ threshold: 10240, //压缩前最小文件大小
+ algorithm: 'gzip', //压缩算法
+ ext: '.gz', //文件类型
+ });
+ }
+ return [];
+};
diff --git a/model/web/build/vite/plugins/imagemin.ts b/model/web/build/vite/plugins/imagemin.ts
new file mode 100644
index 0000000..d8ad39c
--- /dev/null
+++ b/model/web/build/vite/plugins/imagemin.ts
@@ -0,0 +1,32 @@
+import viteImagemin from 'vite-plugin-imagemin';
+
+export function ConfigImageminPlugin() {
+ const plugin = viteImagemin({
+ gifsicle: {
+ optimizationLevel: 7,
+ interlaced: false,
+ },
+ mozjpeg: {
+ quality: 20,
+ },
+ optipng: {
+ optimizationLevel: 7,
+ },
+ pngquant: {
+ quality: [0.8, 0.9],
+ speed: 4,
+ },
+ svgo: {
+ plugins: [
+ {
+ name: 'removeViewBox',
+ },
+ {
+ name: 'removeEmptyAttrs',
+ active: false,
+ },
+ ],
+ },
+ });
+ return plugin;
+}
diff --git a/model/web/build/vite/plugins/index.ts b/model/web/build/vite/plugins/index.ts
new file mode 100644
index 0000000..d3957ad
--- /dev/null
+++ b/model/web/build/vite/plugins/index.ts
@@ -0,0 +1,51 @@
+/**
+ * @name createVitePlugins
+ * @description 封装plugins数组统一调用
+ */
+import {PluginOption} from 'vite';
+import vue from '@vitejs/plugin-vue';
+import vueJsx from '@vitejs/plugin-vue-jsx';
+import {AutoImportDeps} from './autoImport';
+import {ConfigCompressPlugin} from './compress';
+import {ConfigRestartPlugin} from './restart';
+import {ConfigProgressPlugin} from './progress';
+import {ConfigVisualizerConfig} from "./visualizer";
+
+export function createVitePlugins(isBuild: boolean) {
+ const vitePlugins = [
+ // vue支持
+ vue(),
+ // JSX支持
+ vueJsx(),
+ // setup语法糖组件名支持
+ // vueSetupExtend(),
+ // 提供https证书
+ // VitePluginCertificate({
+ // source: 'coding',
+ // }) as PluginOption,
+ ];
+
+ // 自动按需引入组件
+ // vitePlugins.push(AutoRegistryComponents());
+
+ // 自动按需引入依赖
+ vitePlugins.push(AutoImportDeps());
+
+ // 自动生成路由
+ // vitePlugins.push(ConfigPagesPlugin());
+
+ // 开启.gz压缩 rollup-plugin-gzip
+ vitePlugins.push(ConfigCompressPlugin());
+
+ // 监听配置文件改动重启
+ vitePlugins.push(ConfigRestartPlugin());
+
+ // 构建时显示进度条
+ vitePlugins.push(ConfigProgressPlugin());
+
+ // 构建时显示进度条
+ vitePlugins.push(ConfigVisualizerConfig());
+
+
+ return vitePlugins;
+}
diff --git a/model/web/build/vite/plugins/progress.ts b/model/web/build/vite/plugins/progress.ts
new file mode 100644
index 0000000..5e0af7a
--- /dev/null
+++ b/model/web/build/vite/plugins/progress.ts
@@ -0,0 +1,9 @@
+/**
+ * @name ConfigProgressPlugin
+ * @description 构建显示进度条
+ */
+
+import progress from 'vite-plugin-progress';
+export const ConfigProgressPlugin = () => {
+ return progress();
+};
diff --git a/model/web/build/vite/plugins/restart.ts b/model/web/build/vite/plugins/restart.ts
new file mode 100644
index 0000000..37ea17f
--- /dev/null
+++ b/model/web/build/vite/plugins/restart.ts
@@ -0,0 +1,10 @@
+/**
+ * @name ConfigRestartPlugin
+ * @description 监听配置文件修改自动重启Vite
+ */
+import ViteRestart from 'vite-plugin-restart';
+export const ConfigRestartPlugin = () => {
+ return ViteRestart({
+ restart: ['*.config.[jt]s', '**/config/*.[jt]s'],
+ });
+};
diff --git a/model/web/build/vite/plugins/unocss.ts b/model/web/build/vite/plugins/unocss.ts
new file mode 100644
index 0000000..2070b9d
--- /dev/null
+++ b/model/web/build/vite/plugins/unocss.ts
@@ -0,0 +1,11 @@
+/**
+ * @name ConfigUnocssPlugin
+ * @description 监听配置文件修改自动重启Vite
+ */
+
+// Unocss
+import Unocss from 'unocss/vite';
+
+export const ConfigUnocssPlugin = () => {
+ return Unocss();
+};
diff --git a/model/web/build/vite/plugins/visualizer.ts b/model/web/build/vite/plugins/visualizer.ts
new file mode 100644
index 0000000..b134649
--- /dev/null
+++ b/model/web/build/vite/plugins/visualizer.ts
@@ -0,0 +1,14 @@
+import visualizer from 'rollup-plugin-visualizer';
+import { ANALYSIS } from '../../constant';
+
+export function ConfigVisualizerConfig() {
+ if (ANALYSIS) {
+ return visualizer({
+ filename: 'dist/report.html',
+ open: true,
+ gzipSize: true,
+ emitFile: false
+ });
+ }
+ return [];
+}
diff --git a/model/web/index.html b/model/web/index.html
new file mode 100644
index 0000000..c07c1c7
--- /dev/null
+++ b/model/web/index.html
@@ -0,0 +1,27 @@
+
+
+
+
+
+ 大学社团管理系统
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/package-lock.json b/model/web/package-lock.json
new file mode 100644
index 0000000..c1516a9
--- /dev/null
+++ b/model/web/package-lock.json
@@ -0,0 +1,7259 @@
+{
+ "name": "my-web-app",
+ "version": "0.1.2",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "my-web-app",
+ "version": "0.1.2",
+ "dependencies": {
+ "@ant-design/icons-vue": "^6.1.0",
+ "@vueuse/components": "^9.10.0",
+ "@vueuse/core": "^9.10.0",
+ "ant-design-vue": "^3.2.20",
+ "axios": "^1.2.2",
+ "pinia": "^2.0.28",
+ "pinia-plugin-persistedstate": "^3.0.2",
+ "qs": "^6.11.0",
+ "vue": "^3.2.45",
+ "vue-router": "^4.1.6"
+ },
+ "devDependencies": {
+ "@types/qs": "^6.9.7",
+ "@typescript-eslint/eslint-plugin": "^5.48.0",
+ "@typescript-eslint/parser": "^5.48.0",
+ "@vitejs/plugin-vue": "^4.0.0",
+ "@vitejs/plugin-vue-jsx": "^3.0.0",
+ "autoprefixer": "^10.4.13",
+ "eslint": "8.22.0",
+ "eslint-config-prettier": "^8.6.0",
+ "eslint-define-config": "^1.13.0",
+ "eslint-plugin-prettier": "^4.2.1",
+ "eslint-plugin-vue": "^9.8.0",
+ "less": "^4.1.3",
+ "less-loader": "^11.1.0",
+ "postcss": "^8.4.21",
+ "postcss-html": "^1.5.0",
+ "postcss-less": "^6.0.0",
+ "prettier": "^2.8.3",
+ "rollup-plugin-visualizer": "^5.9.0",
+ "stylelint": "^14.16.1",
+ "stylelint-config-standard": "^29.0.0",
+ "stylelint-order": "^6.0.1",
+ "typescript": "4.9.4",
+ "unplugin-auto-import": "^0.12.2",
+ "vite": "^4.0.3",
+ "vite-plugin-compression": "^0.5.1",
+ "vite-plugin-progress": "^0.0.6",
+ "vite-plugin-restart": "^0.3.1"
+ }
+ },
+ "node_modules/@ampproject/remapping": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmmirror.com/@ampproject/remapping/-/remapping-2.2.0.tgz",
+ "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.1.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@ant-design/colors": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmmirror.com/@ant-design/colors/-/colors-6.0.0.tgz",
+ "integrity": "sha512-qAZRvPzfdWHtfameEGP2Qvuf838NhergR35o+EuVyB5XvSA98xod5r4utvi4TJ3ywmevm290g9nsCG5MryrdWQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@ctrl/tinycolor": "^3.4.0"
+ }
+ },
+ "node_modules/@ant-design/icons-svg": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmmirror.com/@ant-design/icons-svg/-/icons-svg-4.2.1.tgz",
+ "integrity": "sha512-EB0iwlKDGpG93hW8f85CTJTs4SvMX7tt5ceupvhALp1IF44SeUFOMhKUOYqpsoYWQKAOuTRDMqn75rEaKDp0Xw==",
+ "license": "MIT"
+ },
+ "node_modules/@ant-design/icons-vue": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmmirror.com/@ant-design/icons-vue/-/icons-vue-6.1.0.tgz",
+ "integrity": "sha512-EX6bYm56V+ZrKN7+3MT/ubDkvJ5rK/O2t380WFRflDcVFgsvl3NLH7Wxeau6R8DbrO5jWR6DSTC3B6gYFp77AA==",
+ "license": "MIT",
+ "dependencies": {
+ "@ant-design/colors": "^6.0.0",
+ "@ant-design/icons-svg": "^4.2.1"
+ },
+ "peerDependencies": {
+ "vue": ">=3.0.3"
+ }
+ },
+ "node_modules/@antfu/utils": {
+ "version": "0.7.2",
+ "resolved": "https://registry.npmmirror.com/@antfu/utils/-/utils-0.7.2.tgz",
+ "integrity": "sha512-vy9fM3pIxZmX07dL+VX1aZe7ynZ+YyB0jY+jE6r3hOK6GNY2t6W8rzpFC4tgpbXUYABkFQwgJq2XYXlxbXAI0g==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/code-frame/-/code-frame-7.18.6.tgz",
+ "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/highlight": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/compat-data": {
+ "version": "7.20.14",
+ "resolved": "https://registry.npmmirror.com/@babel/compat-data/-/compat-data-7.20.14.tgz",
+ "integrity": "sha512-0YpKHD6ImkWMEINCyDAD0HLLUH/lPCefG8ld9it8DJB2wnApraKuhgYTvTY1z7UFIfBTGy5LwncZ+5HWWGbhFw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/core": {
+ "version": "7.20.12",
+ "resolved": "https://registry.npmmirror.com/@babel/core/-/core-7.20.12.tgz",
+ "integrity": "sha512-XsMfHovsUYHFMdrIHkZphTN/2Hzzi78R08NuHfDBehym2VsPDL6Zn/JAD/JQdnRvbSsbQc4mVaU1m6JgtTEElg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@ampproject/remapping": "^2.1.0",
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.20.7",
+ "@babel/helper-compilation-targets": "^7.20.7",
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helpers": "^7.20.7",
+ "@babel/parser": "^7.20.7",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.12",
+ "@babel/types": "^7.20.7",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.2",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/babel"
+ }
+ },
+ "node_modules/@babel/core/node_modules/semver": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmmirror.com/semver/-/semver-6.3.0.tgz",
+ "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
+ "dev": true,
+ "license": "ISC",
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/generator": {
+ "version": "7.20.14",
+ "resolved": "https://registry.npmmirror.com/@babel/generator/-/generator-7.20.14.tgz",
+ "integrity": "sha512-AEmuXHdcD3A52HHXxaTmYlb8q/xMEhoRP67B3T4Oq7lbmSoqroMZzjnGj3+i1io3pdnF8iBYVu4Ilj+c4hBxYg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.20.7",
+ "@jridgewell/gen-mapping": "^0.3.2",
+ "jsesc": "^2.5.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/generator/node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmmirror.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz",
+ "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/helper-annotate-as-pure": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz",
+ "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.7.tgz",
+ "integrity": "sha512-4tGORmfQcrc+bvrjb5y3dG9Mx1IOZjsHqQVUz7XCNHO+iTmqxWnVg3KRygjGmpRLJGdQSKuvFinbIb0CnZwHAQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/compat-data": "^7.20.5",
+ "@babel/helper-validator-option": "^7.18.6",
+ "browserslist": "^4.21.3",
+ "lru-cache": "^5.1.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets/node_modules/semver": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmmirror.com/semver/-/semver-6.3.0.tgz",
+ "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
+ "dev": true,
+ "license": "ISC",
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/helper-create-class-features-plugin": {
+ "version": "7.20.12",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.20.12.tgz",
+ "integrity": "sha512-9OunRkbT0JQcednL0UFvbfXpAsUXiGjUk0a7sN8fUXX7Mue79cUSMjHGDRRi/Vz9vYlpIhLV5fMD5dKoMhhsNQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/helper-member-expression-to-functions": "^7.20.7",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.20.7",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0",
+ "@babel/helper-split-export-declaration": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-environment-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz",
+ "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-function-name": {
+ "version": "7.19.0",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz",
+ "integrity": "sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/template": "^7.18.10",
+ "@babel/types": "^7.19.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-hoist-variables": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz",
+ "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-member-expression-to-functions": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.20.7.tgz",
+ "integrity": "sha512-9J0CxJLq315fEdi4s7xK5TQaNYjZw+nDVpVqr1axNGKzdrdwYBD5b4uKv3n75aABG0rCCTK8Im8Ww7eYfMrZgw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz",
+ "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-transforms": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-module-transforms/-/helper-module-transforms-7.20.11.tgz",
+ "integrity": "sha512-uRy78kN4psmji1s2QtbtcCSaj/LILFDp0f/ymhpQH5QY3nljUZCaNWz9X1dEj/8MBdBEFECs7yRhKn8i7NjZgg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-simple-access": "^7.20.2",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/helper-validator-identifier": "^7.19.1",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.10",
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-optimise-call-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz",
+ "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-plugin-utils": {
+ "version": "7.20.2",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.20.2.tgz",
+ "integrity": "sha512-8RvlJG2mj4huQ4pZ+rU9lqKi9ZKiRmuvGuM2HlWmkmgOhbs6zEAw6IEiJ5cQqGbDzGZOhwuOQNtZMi/ENLjZoQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-replace-supers": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-replace-supers/-/helper-replace-supers-7.20.7.tgz",
+ "integrity": "sha512-vujDMtB6LVfNW13jhlCrp48QNslK6JXi7lQG736HVbHz/mbf4Dc7tIRh1Xf5C0rF7BP8iiSxGMCmY6Ci1ven3A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-member-expression-to-functions": "^7.20.7",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.7",
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-simple-access": {
+ "version": "7.20.2",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz",
+ "integrity": "sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-skip-transparent-expression-wrappers": {
+ "version": "7.20.0",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz",
+ "integrity": "sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.20.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-split-export-declaration": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz",
+ "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.19.4",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-string-parser/-/helper-string-parser-7.19.4.tgz",
+ "integrity": "sha512-nHtDoQcuqFmwYNYPz3Rah5ph2p8PFeFCsZk9A/48dPc/rGocJ5J3hAAZ7pb76VWX3fZKu+uEr/FhH5jLx7umrw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.19.1",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz",
+ "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-option": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz",
+ "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helpers": {
+ "version": "7.20.13",
+ "resolved": "https://registry.npmmirror.com/@babel/helpers/-/helpers-7.20.13.tgz",
+ "integrity": "sha512-nzJ0DWCL3gB5RCXbUO3KIMMsBY2Eqbx8mBpKGE/02PgyRQFcPQLbkQ1vyy596mZLaP+dAfD+R4ckASzNVmW3jg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.13",
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/highlight": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/highlight/-/highlight-7.18.6.tgz",
+ "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "chalk": "^2.0.0",
+ "js-tokens": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.20.13",
+ "resolved": "https://registry.npmmirror.com/@babel/parser/-/parser-7.20.13.tgz",
+ "integrity": "sha512-gFDLKMfpiXCsjt4za2JA9oTMn70CeseCehb11kRZgvd7+F67Hih3OHOK24cRrWECJ/ljfPGac6ygXAs/C8kIvw==",
+ "license": "MIT",
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-jsx": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmmirror.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz",
+ "integrity": "sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-typescript": {
+ "version": "7.20.0",
+ "resolved": "https://registry.npmmirror.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.20.0.tgz",
+ "integrity": "sha512-rd9TkG+u1CExzS4SM1BlMEhMXwFLKVjOAFFCDx9PbX5ycJWDoWMcwdJH9RhkPu1dOgn5TrxLot/Gx6lWFuAUNQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.19.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-typescript": {
+ "version": "7.20.13",
+ "resolved": "https://registry.npmmirror.com/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.20.13.tgz",
+ "integrity": "sha512-O7I/THxarGcDZxkgWKMUrk7NK1/WbHAg3Xx86gqS6x9MTrNL6AwIluuZ96ms4xeDe6AVx6rjHbWHP7x26EPQBA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.20.12",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-typescript": "^7.20.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/runtime": {
+ "version": "7.20.13",
+ "resolved": "https://registry.npmmirror.com/@babel/runtime/-/runtime-7.20.13.tgz",
+ "integrity": "sha512-gt3PKXs0DBoL9xCvOIIZ2NEqAGZqHjAnmVbfQtB620V0uReIQutpel14KcneZuer7UioY8ALKZ7iocavvzTNFA==",
+ "license": "MIT",
+ "dependencies": {
+ "regenerator-runtime": "^0.13.11"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmmirror.com/@babel/template/-/template-7.20.7.tgz",
+ "integrity": "sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/parser": "^7.20.7",
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.20.13",
+ "resolved": "https://registry.npmmirror.com/@babel/traverse/-/traverse-7.20.13.tgz",
+ "integrity": "sha512-kMJXfF0T6DIS9E8cgdLCSAL+cuCK+YEZHWiLK0SXpTo8YRj5lpJu3CDNKiIBCne4m9hhTIqUg6SYTAI39tAiVQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.20.7",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/parser": "^7.20.13",
+ "@babel/types": "^7.20.7",
+ "debug": "^4.1.0",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmmirror.com/@babel/types/-/types-7.20.7.tgz",
+ "integrity": "sha512-69OnhBxSSgK0OzTJai4kyPDiKTIe3j+ctaHdIGVbRahTLAT7L3R9oeXHC2aVSuGYt3cVnoAMDmOCgJ2yaiLMvg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.19.4",
+ "@babel/helper-validator-identifier": "^7.19.1",
+ "to-fast-properties": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@csstools/selector-specificity": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmmirror.com/@csstools/selector-specificity/-/selector-specificity-2.1.1.tgz",
+ "integrity": "sha512-jwx+WCqszn53YHOfvFMJJRd/B2GqkCBt+1MJSG6o5/s8+ytHMvDZXsJgUEWLk12UnLd7HYKac4BYU5i/Ron1Cw==",
+ "dev": true,
+ "license": "CC0-1.0",
+ "engines": {
+ "node": "^14 || ^16 || >=18"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4",
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "node_modules/@ctrl/tinycolor": {
+ "version": "3.5.0",
+ "resolved": "https://registry.npmmirror.com/@ctrl/tinycolor/-/tinycolor-3.5.0.tgz",
+ "integrity": "sha512-tlJpwF40DEQcfR/QF+wNMVyGMaO9FQp6Z1Wahj4Gk3CJQYHwA2xVG7iKDFdW6zuxZY9XWOpGcfNCTsX4McOsOg==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/@esbuild/android-arm": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/android-arm/-/android-arm-0.16.17.tgz",
+ "integrity": "sha512-N9x1CMXVhtWEAMS7pNNONyA14f71VPQN9Cnavj1XQh6T7bskqiLLrSca4O0Vr8Wdcga943eThxnVp3JLnBMYtw==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-arm64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/android-arm64/-/android-arm64-0.16.17.tgz",
+ "integrity": "sha512-MIGl6p5sc3RDTLLkYL1MyL8BMRN4tLMRCn+yRJJmEDvYZ2M7tmAf80hx1kbNEUX2KJ50RRtxZ4JHLvCfuB6kBg==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-x64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/android-x64/-/android-x64-0.16.17.tgz",
+ "integrity": "sha512-a3kTv3m0Ghh4z1DaFEuEDfz3OLONKuFvI4Xqczqx4BqLyuFaFkuaG4j2MtA6fuWEFeC5x9IvqnX7drmRq/fyAQ==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-arm64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/darwin-arm64/-/darwin-arm64-0.16.17.tgz",
+ "integrity": "sha512-/2agbUEfmxWHi9ARTX6OQ/KgXnOWfsNlTeLcoV7HSuSTv63E4DqtAc+2XqGw1KHxKMHGZgbVCZge7HXWX9Vn+w==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-x64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/darwin-x64/-/darwin-x64-0.16.17.tgz",
+ "integrity": "sha512-2By45OBHulkd9Svy5IOCZt376Aa2oOkiE9QWUK9fe6Tb+WDr8hXL3dpqi+DeLiMed8tVXspzsTAvd0jUl96wmg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-arm64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.16.17.tgz",
+ "integrity": "sha512-mt+cxZe1tVx489VTb4mBAOo2aKSnJ33L9fr25JXpqQqzbUIw/yzIzi+NHwAXK2qYV1lEFp4OoVeThGjUbmWmdw==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-x64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/freebsd-x64/-/freebsd-x64-0.16.17.tgz",
+ "integrity": "sha512-8ScTdNJl5idAKjH8zGAsN7RuWcyHG3BAvMNpKOBaqqR7EbUhhVHOqXRdL7oZvz8WNHL2pr5+eIT5c65kA6NHug==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-arm/-/linux-arm-0.16.17.tgz",
+ "integrity": "sha512-iihzrWbD4gIT7j3caMzKb/RsFFHCwqqbrbH9SqUSRrdXkXaygSZCZg1FybsZz57Ju7N/SHEgPyaR0LZ8Zbe9gQ==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-arm64/-/linux-arm64-0.16.17.tgz",
+ "integrity": "sha512-7S8gJnSlqKGVJunnMCrXHU9Q8Q/tQIxk/xL8BqAP64wchPCTzuM6W3Ra8cIa1HIflAvDnNOt2jaL17vaW+1V0g==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ia32": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-ia32/-/linux-ia32-0.16.17.tgz",
+ "integrity": "sha512-kiX69+wcPAdgl3Lonh1VI7MBr16nktEvOfViszBSxygRQqSpzv7BffMKRPMFwzeJGPxcio0pdD3kYQGpqQ2SSg==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-loong64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-loong64/-/linux-loong64-0.16.17.tgz",
+ "integrity": "sha512-dTzNnQwembNDhd654cA4QhbS9uDdXC3TKqMJjgOWsC0yNCbpzfWoXdZvp0mY7HU6nzk5E0zpRGGx3qoQg8T2DQ==",
+ "cpu": [
+ "loong64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-mips64el": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-mips64el/-/linux-mips64el-0.16.17.tgz",
+ "integrity": "sha512-ezbDkp2nDl0PfIUn0CsQ30kxfcLTlcx4Foz2kYv8qdC6ia2oX5Q3E/8m6lq84Dj/6b0FrkgD582fJMIfHhJfSw==",
+ "cpu": [
+ "mips64el"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ppc64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-ppc64/-/linux-ppc64-0.16.17.tgz",
+ "integrity": "sha512-dzS678gYD1lJsW73zrFhDApLVdM3cUF2MvAa1D8K8KtcSKdLBPP4zZSLy6LFZ0jYqQdQ29bjAHJDgz0rVbLB3g==",
+ "cpu": [
+ "ppc64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-riscv64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-riscv64/-/linux-riscv64-0.16.17.tgz",
+ "integrity": "sha512-ylNlVsxuFjZK8DQtNUwiMskh6nT0vI7kYl/4fZgV1llP5d6+HIeL/vmmm3jpuoo8+NuXjQVZxmKuhDApK0/cKw==",
+ "cpu": [
+ "riscv64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-s390x": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-s390x/-/linux-s390x-0.16.17.tgz",
+ "integrity": "sha512-gzy7nUTO4UA4oZ2wAMXPNBGTzZFP7mss3aKR2hH+/4UUkCOyqmjXiKpzGrY2TlEUhbbejzXVKKGazYcQTZWA/w==",
+ "cpu": [
+ "s390x"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-x64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/linux-x64/-/linux-x64-0.16.17.tgz",
+ "integrity": "sha512-mdPjPxfnmoqhgpiEArqi4egmBAMYvaObgn4poorpUaqmvzzbvqbowRllQ+ZgzGVMGKaPkqUmPDOOFQRUFDmeUw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/netbsd-x64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/netbsd-x64/-/netbsd-x64-0.16.17.tgz",
+ "integrity": "sha512-/PzmzD/zyAeTUsduZa32bn0ORug+Jd1EGGAUJvqfeixoEISYpGnAezN6lnJoskauoai0Jrs+XSyvDhppCPoKOA==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "netbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/openbsd-x64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/openbsd-x64/-/openbsd-x64-0.16.17.tgz",
+ "integrity": "sha512-2yaWJhvxGEz2RiftSk0UObqJa/b+rIAjnODJgv2GbGGpRwAfpgzyrg1WLK8rqA24mfZa9GvpjLcBBg8JHkoodg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "openbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/sunos-x64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/sunos-x64/-/sunos-x64-0.16.17.tgz",
+ "integrity": "sha512-xtVUiev38tN0R3g8VhRfN7Zl42YCJvyBhRKw1RJjwE1d2emWTVToPLNEQj/5Qxc6lVFATDiy6LjVHYhIPrLxzw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "sunos"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-arm64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/win32-arm64/-/win32-arm64-0.16.17.tgz",
+ "integrity": "sha512-ga8+JqBDHY4b6fQAmOgtJJue36scANy4l/rL97W+0wYmijhxKetzZdKOJI7olaBaMhWt8Pac2McJdZLxXWUEQw==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-ia32": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/win32-ia32/-/win32-ia32-0.16.17.tgz",
+ "integrity": "sha512-WnsKaf46uSSF/sZhwnqE4L/F89AYNMiD4YtEcYekBt9Q7nj0DiId2XH2Ng2PHM54qi5oPrQ8luuzGszqi/veig==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-x64": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/@esbuild/win32-x64/-/win32-x64-0.16.17.tgz",
+ "integrity": "sha512-y+EHuSchhL7FjHgvQL/0fnnFmO4T1bhvWANX6gcnqTjtnKWbTvUMCpGnv2+t+31d7RzyEAYAd4u2fnIhHL6N/Q==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@eslint/eslintrc": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmmirror.com/@eslint/eslintrc/-/eslintrc-1.4.1.tgz",
+ "integrity": "sha512-XXrH9Uarn0stsyldqDYq8r++mROmWRI1xKMXa640Bb//SY1+ECYX6VzT6Lcx5frD0V30XieqJ0oX9I2Xj5aoMA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ajv": "^6.12.4",
+ "debug": "^4.3.2",
+ "espree": "^9.4.0",
+ "globals": "^13.19.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.2.1",
+ "js-yaml": "^4.1.0",
+ "minimatch": "^3.1.2",
+ "strip-json-comments": "^3.1.1"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/@eslint/eslintrc/node_modules/globals": {
+ "version": "13.20.0",
+ "resolved": "https://registry.npmmirror.com/globals/-/globals-13.20.0.tgz",
+ "integrity": "sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "type-fest": "^0.20.2"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@eslint/eslintrc/node_modules/type-fest": {
+ "version": "0.20.2",
+ "resolved": "https://registry.npmmirror.com/type-fest/-/type-fest-0.20.2.tgz",
+ "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
+ "dev": true,
+ "license": "(MIT OR CC0-1.0)",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@humanwhocodes/config-array": {
+ "version": "0.10.7",
+ "resolved": "https://registry.npmmirror.com/@humanwhocodes/config-array/-/config-array-0.10.7.tgz",
+ "integrity": "sha512-MDl6D6sBsaV452/QSdX+4CXIjZhIcI0PELsxUjk4U828yd58vk3bTIvk/6w5FY+4hIy9sLW0sfrV7K7Kc++j/w==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@humanwhocodes/object-schema": "^1.2.1",
+ "debug": "^4.1.1",
+ "minimatch": "^3.0.4"
+ },
+ "engines": {
+ "node": ">=10.10.0"
+ }
+ },
+ "node_modules/@humanwhocodes/gitignore-to-minimatch": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmmirror.com/@humanwhocodes/gitignore-to-minimatch/-/gitignore-to-minimatch-1.0.2.tgz",
+ "integrity": "sha512-rSqmMJDdLFUsyxR6FMtD00nfQKKLFb1kv+qBbOVKqErvloEIJLo5bDTJTQNTYgeyp78JsA7u/NPi5jT1GR/MuA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/nzakas"
+ }
+ },
+ "node_modules/@humanwhocodes/object-schema": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmmirror.com/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz",
+ "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==",
+ "dev": true,
+ "license": "BSD-3-Clause"
+ },
+ "node_modules/@jridgewell/gen-mapping": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmmirror.com/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz",
+ "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.0",
+ "@jridgewell/sourcemap-codec": "^1.4.10"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/resolve-uri": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmmirror.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz",
+ "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/set-array": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmmirror.com/@jridgewell/set-array/-/set-array-1.1.2.tgz",
+ "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/source-map": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmmirror.com/@jridgewell/source-map/-/source-map-0.3.2.tgz",
+ "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.3.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ },
+ "node_modules/@jridgewell/source-map/node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmmirror.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz",
+ "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.4.14",
+ "resolved": "https://registry.npmmirror.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz",
+ "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@jridgewell/trace-mapping": {
+ "version": "0.3.17",
+ "resolved": "https://registry.npmmirror.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz",
+ "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/resolve-uri": "3.1.0",
+ "@jridgewell/sourcemap-codec": "1.4.14"
+ }
+ },
+ "node_modules/@nodelib/fs.scandir": {
+ "version": "2.1.5",
+ "resolved": "https://registry.npmmirror.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
+ "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@nodelib/fs.stat": "2.0.5",
+ "run-parallel": "^1.1.9"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@nodelib/fs.stat": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmmirror.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
+ "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@nodelib/fs.walk": {
+ "version": "1.2.8",
+ "resolved": "https://registry.npmmirror.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
+ "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@nodelib/fs.scandir": "2.1.5",
+ "fastq": "^1.6.0"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@rollup/pluginutils": {
+ "version": "5.0.2",
+ "resolved": "https://registry.npmmirror.com/@rollup/pluginutils/-/pluginutils-5.0.2.tgz",
+ "integrity": "sha512-pTd9rIsP92h+B6wWwFbW8RkZv4hiR/xKsqre4SIuAOaOEQRxi0lqLke9k2/7WegC85GgUs9pjmOjCUi3In4vwA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/estree": "^1.0.0",
+ "estree-walker": "^2.0.2",
+ "picomatch": "^2.3.1"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ },
+ "peerDependencies": {
+ "rollup": "^1.20.0||^2.0.0||^3.0.0"
+ },
+ "peerDependenciesMeta": {
+ "rollup": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@simonwep/pickr": {
+ "version": "1.8.2",
+ "resolved": "https://registry.npmmirror.com/@simonwep/pickr/-/pickr-1.8.2.tgz",
+ "integrity": "sha512-/l5w8BIkrpP6n1xsetx9MWPWlU6OblN5YgZZphxan0Tq4BByTCETL6lyIeY8lagalS2Nbt4F2W034KHLIiunKA==",
+ "license": "MIT",
+ "dependencies": {
+ "core-js": "^3.15.1",
+ "nanopop": "^2.1.0"
+ }
+ },
+ "node_modules/@types/eslint": {
+ "version": "8.37.0",
+ "resolved": "https://registry.npmmirror.com/@types/eslint/-/eslint-8.37.0.tgz",
+ "integrity": "sha512-Piet7dG2JBuDIfohBngQ3rCt7MgO9xCO4xIMKxBThCq5PNRB91IjlJ10eJVwfoNtvTErmxLzwBZ7rHZtbOMmFQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@types/estree": "*",
+ "@types/json-schema": "*"
+ }
+ },
+ "node_modules/@types/eslint-scope": {
+ "version": "3.7.4",
+ "resolved": "https://registry.npmmirror.com/@types/eslint-scope/-/eslint-scope-3.7.4.tgz",
+ "integrity": "sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@types/eslint": "*",
+ "@types/estree": "*"
+ }
+ },
+ "node_modules/@types/estree": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/@types/estree/-/estree-1.0.0.tgz",
+ "integrity": "sha512-WulqXMDUTYAXCjZnk6JtIHPigp55cVtDgDrO2gHRwhyJto21+1zbVCtOYB2L1F9w4qCQ0rOGWBnBe0FNTiEJIQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/json-schema": {
+ "version": "7.0.11",
+ "resolved": "https://registry.npmmirror.com/@types/json-schema/-/json-schema-7.0.11.tgz",
+ "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/minimist": {
+ "version": "1.2.2",
+ "resolved": "https://registry.npmmirror.com/@types/minimist/-/minimist-1.2.2.tgz",
+ "integrity": "sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/node": {
+ "version": "22.5.5",
+ "resolved": "https://registry.npmmirror.com/@types/node/-/node-22.5.5.tgz",
+ "integrity": "sha512-Xjs4y5UPO/CLdzpgR6GirZJx36yScjh73+2NlLlkFRSoQN8B0DpfXPdZGnvVmLRLOsqDpOfTNv7D9trgGhmOIA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "undici-types": "~6.19.2"
+ }
+ },
+ "node_modules/@types/normalize-package-data": {
+ "version": "2.4.1",
+ "resolved": "https://registry.npmmirror.com/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz",
+ "integrity": "sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/parse-json": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/@types/parse-json/-/parse-json-4.0.0.tgz",
+ "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/qs": {
+ "version": "6.9.7",
+ "resolved": "https://registry.npmmirror.com/@types/qs/-/qs-6.9.7.tgz",
+ "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/semver": {
+ "version": "7.3.13",
+ "resolved": "https://registry.npmmirror.com/@types/semver/-/semver-7.3.13.tgz",
+ "integrity": "sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/web-bluetooth": {
+ "version": "0.0.16",
+ "resolved": "https://registry.npmmirror.com/@types/web-bluetooth/-/web-bluetooth-0.0.16.tgz",
+ "integrity": "sha512-oh8q2Zc32S6gd/j50GowEjKLoOVOwHP/bWVjKJInBwQqdOYMdPrf1oVlelTlyfFK3CKxL1uahMDAr+vy8T7yMQ==",
+ "license": "MIT"
+ },
+ "node_modules/@typescript-eslint/eslint-plugin": {
+ "version": "5.50.0",
+ "resolved": "https://registry.npmmirror.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.50.0.tgz",
+ "integrity": "sha512-vwksQWSFZiUhgq3Kv7o1Jcj0DUNylwnIlGvKvLLYsq8pAWha6/WCnXUeaSoNNha/K7QSf2+jvmkxggC1u3pIwQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/scope-manager": "5.50.0",
+ "@typescript-eslint/type-utils": "5.50.0",
+ "@typescript-eslint/utils": "5.50.0",
+ "debug": "^4.3.4",
+ "grapheme-splitter": "^1.0.4",
+ "ignore": "^5.2.0",
+ "natural-compare-lite": "^1.4.0",
+ "regexpp": "^3.2.0",
+ "semver": "^7.3.7",
+ "tsutils": "^3.21.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "@typescript-eslint/parser": "^5.0.0",
+ "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@typescript-eslint/parser": {
+ "version": "5.50.0",
+ "resolved": "https://registry.npmmirror.com/@typescript-eslint/parser/-/parser-5.50.0.tgz",
+ "integrity": "sha512-KCcSyNaogUDftK2G9RXfQyOCt51uB5yqC6pkUYqhYh8Kgt+DwR5M0EwEAxGPy/+DH6hnmKeGsNhiZRQxjH71uQ==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "@typescript-eslint/scope-manager": "5.50.0",
+ "@typescript-eslint/types": "5.50.0",
+ "@typescript-eslint/typescript-estree": "5.50.0",
+ "debug": "^4.3.4"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@typescript-eslint/scope-manager": {
+ "version": "5.50.0",
+ "resolved": "https://registry.npmmirror.com/@typescript-eslint/scope-manager/-/scope-manager-5.50.0.tgz",
+ "integrity": "sha512-rt03kaX+iZrhssaT974BCmoUikYtZI24Vp/kwTSy841XhiYShlqoshRFDvN1FKKvU2S3gK+kcBW1EA7kNUrogg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/types": "5.50.0",
+ "@typescript-eslint/visitor-keys": "5.50.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@typescript-eslint/type-utils": {
+ "version": "5.50.0",
+ "resolved": "https://registry.npmmirror.com/@typescript-eslint/type-utils/-/type-utils-5.50.0.tgz",
+ "integrity": "sha512-dcnXfZ6OGrNCO7E5UY/i0ktHb7Yx1fV6fnQGGrlnfDhilcs6n19eIRcvLBqx6OQkrPaFlDPk3OJ0WlzQfrV0bQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/typescript-estree": "5.50.0",
+ "@typescript-eslint/utils": "5.50.0",
+ "debug": "^4.3.4",
+ "tsutils": "^3.21.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "*"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@typescript-eslint/types": {
+ "version": "5.50.0",
+ "resolved": "https://registry.npmmirror.com/@typescript-eslint/types/-/types-5.50.0.tgz",
+ "integrity": "sha512-atruOuJpir4OtyNdKahiHZobPKFvZnBnfDiyEaBf6d9vy9visE7gDjlmhl+y29uxZ2ZDgvXijcungGFjGGex7w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@typescript-eslint/typescript-estree": {
+ "version": "5.50.0",
+ "resolved": "https://registry.npmmirror.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.50.0.tgz",
+ "integrity": "sha512-Gq4zapso+OtIZlv8YNAStFtT6d05zyVCK7Fx3h5inlLBx2hWuc/0465C2mg/EQDDU2LKe52+/jN4f0g9bd+kow==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "@typescript-eslint/types": "5.50.0",
+ "@typescript-eslint/visitor-keys": "5.50.0",
+ "debug": "^4.3.4",
+ "globby": "^11.1.0",
+ "is-glob": "^4.0.3",
+ "semver": "^7.3.7",
+ "tsutils": "^3.21.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@typescript-eslint/utils": {
+ "version": "5.50.0",
+ "resolved": "https://registry.npmmirror.com/@typescript-eslint/utils/-/utils-5.50.0.tgz",
+ "integrity": "sha512-v/AnUFImmh8G4PH0NDkf6wA8hujNNcrwtecqW4vtQ1UOSNBaZl49zP1SHoZ/06e+UiwzHpgb5zP5+hwlYYWYAw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/json-schema": "^7.0.9",
+ "@types/semver": "^7.3.12",
+ "@typescript-eslint/scope-manager": "5.50.0",
+ "@typescript-eslint/types": "5.50.0",
+ "@typescript-eslint/typescript-estree": "5.50.0",
+ "eslint-scope": "^5.1.1",
+ "eslint-utils": "^3.0.0",
+ "semver": "^7.3.7"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/visitor-keys": {
+ "version": "5.50.0",
+ "resolved": "https://registry.npmmirror.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.50.0.tgz",
+ "integrity": "sha512-cdMeD9HGu6EXIeGOh2yVW6oGf9wq8asBgZx7nsR/D36gTfQ0odE5kcRYe5M81vjEFAcPeugXrHg78Imu55F6gg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/types": "5.50.0",
+ "eslint-visitor-keys": "^3.3.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@vitejs/plugin-vue": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/@vitejs/plugin-vue/-/plugin-vue-4.0.0.tgz",
+ "integrity": "sha512-e0X4jErIxAB5oLtDqbHvHpJe/uWNkdpYV83AOG2xo2tEVSzCzewgJMtREZM30wXnM5ls90hxiOtAuVU6H5JgbA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^14.18.0 || >=16.0.0"
+ },
+ "peerDependencies": {
+ "vite": "^4.0.0",
+ "vue": "^3.2.25"
+ }
+ },
+ "node_modules/@vitejs/plugin-vue-jsx": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/@vitejs/plugin-vue-jsx/-/plugin-vue-jsx-3.0.0.tgz",
+ "integrity": "sha512-vurkuzgac5SYuxd2HUZqAFAWGTF10diKBwJNbCvnWijNZfXd+7jMtqjPFbGt7idOJUn584fP1Ar9j/GN2jQ3Ew==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/core": "^7.20.5",
+ "@babel/plugin-transform-typescript": "^7.20.2",
+ "@vue/babel-plugin-jsx": "^1.1.1"
+ },
+ "engines": {
+ "node": "^14.18.0 || >=16.0.0"
+ },
+ "peerDependencies": {
+ "vite": "^4.0.0",
+ "vue": "^3.0.0"
+ }
+ },
+ "node_modules/@vue/babel-helper-vue-transform-on": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmmirror.com/@vue/babel-helper-vue-transform-on/-/babel-helper-vue-transform-on-1.0.2.tgz",
+ "integrity": "sha512-hz4R8tS5jMn8lDq6iD+yWL6XNB699pGIVLk7WSJnn1dbpjaazsjZQkieJoRX6gW5zpYSCFqQ7jUquPNY65tQYA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@vue/babel-plugin-jsx": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmmirror.com/@vue/babel-plugin-jsx/-/babel-plugin-jsx-1.1.1.tgz",
+ "integrity": "sha512-j2uVfZjnB5+zkcbc/zsOc0fSNGCMMjaEXP52wdwdIfn0qjFfEYpYZBFKFg+HHnQeJCVrjOeO0YxgaL7DMrym9w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.0.0",
+ "@babel/plugin-syntax-jsx": "^7.0.0",
+ "@babel/template": "^7.0.0",
+ "@babel/traverse": "^7.0.0",
+ "@babel/types": "^7.0.0",
+ "@vue/babel-helper-vue-transform-on": "^1.0.2",
+ "camelcase": "^6.0.0",
+ "html-tags": "^3.1.0",
+ "svg-tags": "^1.0.0"
+ }
+ },
+ "node_modules/@vue/compiler-core": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.45.tgz",
+ "integrity": "sha512-rcMj7H+PYe5wBV3iYeUgbCglC+pbpN8hBLTJvRiK2eKQiWqu+fG9F+8sW99JdL4LQi7Re178UOxn09puSXvn4A==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.16.4",
+ "@vue/shared": "3.2.45",
+ "estree-walker": "^2.0.2",
+ "source-map": "^0.6.1"
+ }
+ },
+ "node_modules/@vue/compiler-dom": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.45.tgz",
+ "integrity": "sha512-tyYeUEuKqqZO137WrZkpwfPCdiiIeXYCcJ8L4gWz9vqaxzIQRccTSwSWZ/Axx5YR2z+LvpUbmPNXxuBU45lyRw==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/compiler-core": "3.2.45",
+ "@vue/shared": "3.2.45"
+ }
+ },
+ "node_modules/@vue/compiler-sfc": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.45.tgz",
+ "integrity": "sha512-1jXDuWah1ggsnSAOGsec8cFjT/K6TMZ0sPL3o3d84Ft2AYZi2jWJgRMjw4iaK0rBfA89L5gw427H4n1RZQBu6Q==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.16.4",
+ "@vue/compiler-core": "3.2.45",
+ "@vue/compiler-dom": "3.2.45",
+ "@vue/compiler-ssr": "3.2.45",
+ "@vue/reactivity-transform": "3.2.45",
+ "@vue/shared": "3.2.45",
+ "estree-walker": "^2.0.2",
+ "magic-string": "^0.25.7",
+ "postcss": "^8.1.10",
+ "source-map": "^0.6.1"
+ }
+ },
+ "node_modules/@vue/compiler-sfc/node_modules/magic-string": {
+ "version": "0.25.9",
+ "resolved": "https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz",
+ "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==",
+ "license": "MIT",
+ "dependencies": {
+ "sourcemap-codec": "^1.4.8"
+ }
+ },
+ "node_modules/@vue/compiler-ssr": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.45.tgz",
+ "integrity": "sha512-6BRaggEGqhWht3lt24CrIbQSRD5O07MTmd+LjAn5fJj568+R9eUD2F7wMQJjX859seSlrYog7sUtrZSd7feqrQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/compiler-dom": "3.2.45",
+ "@vue/shared": "3.2.45"
+ }
+ },
+ "node_modules/@vue/devtools-api": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmmirror.com/@vue/devtools-api/-/devtools-api-6.5.0.tgz",
+ "integrity": "sha512-o9KfBeaBmCKl10usN4crU53fYtC1r7jJwdGKjPT24t348rHxgfpZ0xL3Xm/gLUYnc0oTp8LAmrxOeLyu6tbk2Q==",
+ "license": "MIT"
+ },
+ "node_modules/@vue/reactivity": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.2.45.tgz",
+ "integrity": "sha512-PRvhCcQcyEVohW0P8iQ7HDcIOXRjZfAsOds3N99X/Dzewy8TVhTCT4uXpAHfoKjVTJRA0O0K+6QNkDIZAxNi3A==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/shared": "3.2.45"
+ }
+ },
+ "node_modules/@vue/reactivity-transform": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.2.45.tgz",
+ "integrity": "sha512-BHVmzYAvM7vcU5WmuYqXpwaBHjsS8T63jlKGWVtHxAHIoMIlmaMyurUSEs1Zcg46M4AYT5MtB1U274/2aNzjJQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.16.4",
+ "@vue/compiler-core": "3.2.45",
+ "@vue/shared": "3.2.45",
+ "estree-walker": "^2.0.2",
+ "magic-string": "^0.25.7"
+ }
+ },
+ "node_modules/@vue/reactivity-transform/node_modules/magic-string": {
+ "version": "0.25.9",
+ "resolved": "https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz",
+ "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==",
+ "license": "MIT",
+ "dependencies": {
+ "sourcemap-codec": "^1.4.8"
+ }
+ },
+ "node_modules/@vue/runtime-core": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.2.45.tgz",
+ "integrity": "sha512-gzJiTA3f74cgARptqzYswmoQx0fIA+gGYBfokYVhF8YSXjWTUA2SngRzZRku2HbGbjzB6LBYSbKGIaK8IW+s0A==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/reactivity": "3.2.45",
+ "@vue/shared": "3.2.45"
+ }
+ },
+ "node_modules/@vue/runtime-dom": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.2.45.tgz",
+ "integrity": "sha512-cy88YpfP5Ue2bDBbj75Cb4bIEZUMM/mAkDMfqDTpUYVgTf/kuQ2VQ8LebuZ8k6EudgH8pYhsGWHlY0lcxlvTwA==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/runtime-core": "3.2.45",
+ "@vue/shared": "3.2.45",
+ "csstype": "^2.6.8"
+ }
+ },
+ "node_modules/@vue/server-renderer": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.2.45.tgz",
+ "integrity": "sha512-ebiMq7q24WBU1D6uhPK//2OTR1iRIyxjF5iVq/1a5I1SDMDyDu4Ts6fJaMnjrvD3MqnaiFkKQj+LKAgz5WIK3g==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/compiler-ssr": "3.2.45",
+ "@vue/shared": "3.2.45"
+ },
+ "peerDependencies": {
+ "vue": "3.2.45"
+ }
+ },
+ "node_modules/@vue/shared": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz",
+ "integrity": "sha512-Ewzq5Yhimg7pSztDV+RH1UDKBzmtqieXQlpTVm2AwraoRL/Rks96mvd8Vgi7Lj+h+TH8dv7mXD3FRZR3TUvbSg==",
+ "license": "MIT"
+ },
+ "node_modules/@vueuse/components": {
+ "version": "9.12.0",
+ "resolved": "https://registry.npmmirror.com/@vueuse/components/-/components-9.12.0.tgz",
+ "integrity": "sha512-U468xbr2PISuWepeOU4J8zkVj0aDhiFe230oDhnIm8mHtcS9gM2vSKTB32InxTs6kVma60yAGdqBySkyFNX/+w==",
+ "license": "MIT",
+ "dependencies": {
+ "@vueuse/core": "9.12.0",
+ "@vueuse/shared": "9.12.0",
+ "vue-demi": "*"
+ }
+ },
+ "node_modules/@vueuse/components/node_modules/vue-demi": {
+ "version": "0.13.11",
+ "resolved": "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.13.11.tgz",
+ "integrity": "sha512-IR8HoEEGM65YY3ZJYAjMlKygDQn25D5ajNFNoKh9RSDMQtlzCxtfQjdQgv9jjK+m3377SsJXY8ysq8kLCZL25A==",
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "vue-demi-fix": "bin/vue-demi-fix.js",
+ "vue-demi-switch": "bin/vue-demi-switch.js"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "@vue/composition-api": "^1.0.0-rc.1",
+ "vue": "^3.0.0-0 || ^2.6.0"
+ },
+ "peerDependenciesMeta": {
+ "@vue/composition-api": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@vueuse/core": {
+ "version": "9.12.0",
+ "resolved": "https://registry.npmmirror.com/@vueuse/core/-/core-9.12.0.tgz",
+ "integrity": "sha512-h/Di8Bvf6xRcvS/PvUVheiMYYz3U0tH3X25YxONSaAUBa841ayMwxkuzx/DGUMCW/wHWzD8tRy2zYmOC36r4sg==",
+ "license": "MIT",
+ "dependencies": {
+ "@types/web-bluetooth": "^0.0.16",
+ "@vueuse/metadata": "9.12.0",
+ "@vueuse/shared": "9.12.0",
+ "vue-demi": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/@vueuse/core/node_modules/vue-demi": {
+ "version": "0.13.11",
+ "resolved": "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.13.11.tgz",
+ "integrity": "sha512-IR8HoEEGM65YY3ZJYAjMlKygDQn25D5ajNFNoKh9RSDMQtlzCxtfQjdQgv9jjK+m3377SsJXY8ysq8kLCZL25A==",
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "vue-demi-fix": "bin/vue-demi-fix.js",
+ "vue-demi-switch": "bin/vue-demi-switch.js"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "@vue/composition-api": "^1.0.0-rc.1",
+ "vue": "^3.0.0-0 || ^2.6.0"
+ },
+ "peerDependenciesMeta": {
+ "@vue/composition-api": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@vueuse/metadata": {
+ "version": "9.12.0",
+ "resolved": "https://registry.npmmirror.com/@vueuse/metadata/-/metadata-9.12.0.tgz",
+ "integrity": "sha512-9oJ9MM9lFLlmvxXUqsR1wLt1uF7EVbP5iYaHJYqk+G2PbMjY6EXvZeTjbdO89HgoF5cI6z49o2zT/jD9SVoNpQ==",
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/@vueuse/shared": {
+ "version": "9.12.0",
+ "resolved": "https://registry.npmmirror.com/@vueuse/shared/-/shared-9.12.0.tgz",
+ "integrity": "sha512-TWuJLACQ0BVithVTRbex4Wf1a1VaRuSpVeyEd4vMUWl54PzlE0ciFUshKCXnlLuD0lxIaLK4Ypj3NXYzZh4+SQ==",
+ "license": "MIT",
+ "dependencies": {
+ "vue-demi": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/@vueuse/shared/node_modules/vue-demi": {
+ "version": "0.13.11",
+ "resolved": "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.13.11.tgz",
+ "integrity": "sha512-IR8HoEEGM65YY3ZJYAjMlKygDQn25D5ajNFNoKh9RSDMQtlzCxtfQjdQgv9jjK+m3377SsJXY8ysq8kLCZL25A==",
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "vue-demi-fix": "bin/vue-demi-fix.js",
+ "vue-demi-switch": "bin/vue-demi-switch.js"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "@vue/composition-api": "^1.0.0-rc.1",
+ "vue": "^3.0.0-0 || ^2.6.0"
+ },
+ "peerDependenciesMeta": {
+ "@vue/composition-api": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@webassemblyjs/ast": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/ast/-/ast-1.11.5.tgz",
+ "integrity": "sha512-LHY/GSAZZRpsNQH+/oHqhRQ5FT7eoULcBqgfyTB5nQHogFnK3/7QoN7dLnwSE/JkUAF0SrRuclT7ODqMFtWxxQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@webassemblyjs/helper-numbers": "1.11.5",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.5"
+ }
+ },
+ "node_modules/@webassemblyjs/floating-point-hex-parser": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.5.tgz",
+ "integrity": "sha512-1j1zTIC5EZOtCplMBG/IEwLtUojtwFVwdyVMbL/hwWqbzlQoJsWCOavrdnLkemwNoC/EOwtUFch3fuo+cbcXYQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/@webassemblyjs/helper-api-error": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.5.tgz",
+ "integrity": "sha512-L65bDPmfpY0+yFrsgz8b6LhXmbbs38OnwDCf6NpnMUYqa+ENfE5Dq9E42ny0qz/PdR0LJyq/T5YijPnU8AXEpA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/@webassemblyjs/helper-buffer": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.5.tgz",
+ "integrity": "sha512-fDKo1gstwFFSfacIeH5KfwzjykIE6ldh1iH9Y/8YkAZrhmu4TctqYjSh7t0K2VyDSXOZJ1MLhht/k9IvYGcIxg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/@webassemblyjs/helper-numbers": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.5.tgz",
+ "integrity": "sha512-DhykHXM0ZABqfIGYNv93A5KKDw/+ywBFnuWybZZWcuzWHfbp21wUfRkbtz7dMGwGgT4iXjWuhRMA2Mzod6W4WA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@webassemblyjs/floating-point-hex-parser": "1.11.5",
+ "@webassemblyjs/helper-api-error": "1.11.5",
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "node_modules/@webassemblyjs/helper-wasm-bytecode": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.5.tgz",
+ "integrity": "sha512-oC4Qa0bNcqnjAowFn7MPCETQgDYytpsfvz4ujZz63Zu/a/v71HeCAAmZsgZ3YVKec3zSPYytG3/PrRCqbtcAvA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/@webassemblyjs/helper-wasm-section": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.5.tgz",
+ "integrity": "sha512-uEoThA1LN2NA+K3B9wDo3yKlBfVtC6rh0i4/6hvbz071E8gTNZD/pT0MsBf7MeD6KbApMSkaAK0XeKyOZC7CIA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.5",
+ "@webassemblyjs/helper-buffer": "1.11.5",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.5",
+ "@webassemblyjs/wasm-gen": "1.11.5"
+ }
+ },
+ "node_modules/@webassemblyjs/ieee754": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/ieee754/-/ieee754-1.11.5.tgz",
+ "integrity": "sha512-37aGq6qVL8A8oPbPrSGMBcp38YZFXcHfiROflJn9jxSdSMMM5dS5P/9e2/TpaJuhE+wFrbukN2WI6Hw9MH5acg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@xtuc/ieee754": "^1.2.0"
+ }
+ },
+ "node_modules/@webassemblyjs/leb128": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/leb128/-/leb128-1.11.5.tgz",
+ "integrity": "sha512-ajqrRSXaTJoPW+xmkfYN6l8VIeNnR4vBOTQO9HzR7IygoCcKWkICbKFbVTNMjMgMREqXEr0+2M6zukzM47ZUfQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "peer": true,
+ "dependencies": {
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "node_modules/@webassemblyjs/utf8": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/utf8/-/utf8-1.11.5.tgz",
+ "integrity": "sha512-WiOhulHKTZU5UPlRl53gHR8OxdGsSOxqfpqWeA2FmcwBMaoEdz6b2x2si3IwC9/fSPLfe8pBMRTHVMk5nlwnFQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/@webassemblyjs/wasm-edit": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.5.tgz",
+ "integrity": "sha512-C0p9D2fAu3Twwqvygvf42iGCQ4av8MFBLiTb+08SZ4cEdwzWx9QeAHDo1E2k+9s/0w1DM40oflJOpkZ8jW4HCQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.5",
+ "@webassemblyjs/helper-buffer": "1.11.5",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.5",
+ "@webassemblyjs/helper-wasm-section": "1.11.5",
+ "@webassemblyjs/wasm-gen": "1.11.5",
+ "@webassemblyjs/wasm-opt": "1.11.5",
+ "@webassemblyjs/wasm-parser": "1.11.5",
+ "@webassemblyjs/wast-printer": "1.11.5"
+ }
+ },
+ "node_modules/@webassemblyjs/wasm-gen": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.5.tgz",
+ "integrity": "sha512-14vteRlRjxLK9eSyYFvw1K8Vv+iPdZU0Aebk3j6oB8TQiQYuO6hj9s4d7qf6f2HJr2khzvNldAFG13CgdkAIfA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.5",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.5",
+ "@webassemblyjs/ieee754": "1.11.5",
+ "@webassemblyjs/leb128": "1.11.5",
+ "@webassemblyjs/utf8": "1.11.5"
+ }
+ },
+ "node_modules/@webassemblyjs/wasm-opt": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.5.tgz",
+ "integrity": "sha512-tcKwlIXstBQgbKy1MlbDMlXaxpucn42eb17H29rawYLxm5+MsEmgPzeCP8B1Cl69hCice8LeKgZpRUAPtqYPgw==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.5",
+ "@webassemblyjs/helper-buffer": "1.11.5",
+ "@webassemblyjs/wasm-gen": "1.11.5",
+ "@webassemblyjs/wasm-parser": "1.11.5"
+ }
+ },
+ "node_modules/@webassemblyjs/wasm-parser": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.5.tgz",
+ "integrity": "sha512-SVXUIwsLQlc8srSD7jejsfTU83g7pIGr2YYNb9oHdtldSxaOhvA5xwvIiWIfcX8PlSakgqMXsLpLfbbJ4cBYew==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.5",
+ "@webassemblyjs/helper-api-error": "1.11.5",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.5",
+ "@webassemblyjs/ieee754": "1.11.5",
+ "@webassemblyjs/leb128": "1.11.5",
+ "@webassemblyjs/utf8": "1.11.5"
+ }
+ },
+ "node_modules/@webassemblyjs/wast-printer": {
+ "version": "1.11.5",
+ "resolved": "https://registry.npmmirror.com/@webassemblyjs/wast-printer/-/wast-printer-1.11.5.tgz",
+ "integrity": "sha512-f7Pq3wvg3GSPUPzR0F6bmI89Hdb+u9WXrSKc4v+N0aV0q6r42WoF92Jp2jEorBEBRoRNXgjp53nBniDXcqZYPA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.5",
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "node_modules/@xtuc/ieee754": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmmirror.com/@xtuc/ieee754/-/ieee754-1.2.0.tgz",
+ "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "peer": true
+ },
+ "node_modules/@xtuc/long": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmmirror.com/@xtuc/long/-/long-4.2.2.tgz",
+ "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "peer": true
+ },
+ "node_modules/acorn": {
+ "version": "8.8.2",
+ "resolved": "https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz",
+ "integrity": "sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "acorn": "bin/acorn"
+ },
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/acorn-import-assertions": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmmirror.com/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz",
+ "integrity": "sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "peerDependencies": {
+ "acorn": "^8"
+ }
+ },
+ "node_modules/acorn-jsx": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmmirror.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
+ "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmmirror.com/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/ajv-keywords": {
+ "version": "3.5.2",
+ "resolved": "https://registry.npmmirror.com/ajv-keywords/-/ajv-keywords-3.5.2.tgz",
+ "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "peerDependencies": {
+ "ajv": "^6.9.1"
+ }
+ },
+ "node_modules/ansi-regex": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmmirror.com/ansi-regex/-/ansi-regex-5.0.1.tgz",
+ "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/ansi-styles": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-3.2.1.tgz",
+ "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-convert": "^1.9.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/ant-design-vue": {
+ "version": "3.2.20",
+ "resolved": "https://registry.npmmirror.com/ant-design-vue/-/ant-design-vue-3.2.20.tgz",
+ "integrity": "sha512-YWpMfGaGoRastIXEYfCoJiaRiDHk4chqtYhlKQM5GqPt6NfvrM1Vg2e60yHtjxlZjed91wCMm0rAmyUr7Hwzdg==",
+ "license": "MIT",
+ "dependencies": {
+ "@ant-design/colors": "^6.0.0",
+ "@ant-design/icons-vue": "^6.1.0",
+ "@babel/runtime": "^7.10.5",
+ "@ctrl/tinycolor": "^3.4.0",
+ "@simonwep/pickr": "~1.8.0",
+ "array-tree-filter": "^2.1.0",
+ "async-validator": "^4.0.0",
+ "dayjs": "^1.10.5",
+ "dom-align": "^1.12.1",
+ "dom-scroll-into-view": "^2.0.0",
+ "lodash": "^4.17.21",
+ "lodash-es": "^4.17.15",
+ "resize-observer-polyfill": "^1.5.1",
+ "scroll-into-view-if-needed": "^2.2.25",
+ "shallow-equal": "^1.0.0",
+ "vue-types": "^3.0.0",
+ "warning": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=12.22.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/ant-design-vue"
+ },
+ "peerDependencies": {
+ "vue": ">=3.2.0"
+ }
+ },
+ "node_modules/anymatch": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmmirror.com/anymatch/-/anymatch-3.1.3.tgz",
+ "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "normalize-path": "^3.0.0",
+ "picomatch": "^2.0.4"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/argparse": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmmirror.com/argparse/-/argparse-2.0.1.tgz",
+ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
+ "dev": true,
+ "license": "Python-2.0"
+ },
+ "node_modules/array-tree-filter": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/array-tree-filter/-/array-tree-filter-2.1.0.tgz",
+ "integrity": "sha512-4ROwICNlNw/Hqa9v+rk5h22KjmzB1JGTMVKP2AKJBOCgb0yL0ASf0+YvCcLNNwquOHNX48jkeZIJ3a+oOQqKcw==",
+ "license": "MIT"
+ },
+ "node_modules/array-union": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/array-union/-/array-union-2.1.0.tgz",
+ "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/arrify": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/arrify/-/arrify-1.0.1.tgz",
+ "integrity": "sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/astral-regex": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/astral-regex/-/astral-regex-2.0.0.tgz",
+ "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/async-validator": {
+ "version": "4.2.5",
+ "resolved": "https://registry.npmmirror.com/async-validator/-/async-validator-4.2.5.tgz",
+ "integrity": "sha512-7HhHjtERjqlNbZtqNqy2rckN/SpOOlmDliet+lP7k+eKZEjPk3DgyeU9lIXLdeLz0uBbbVp+9Qdow9wJWgwwfg==",
+ "license": "MIT"
+ },
+ "node_modules/asynckit": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmmirror.com/asynckit/-/asynckit-0.4.0.tgz",
+ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==",
+ "license": "MIT"
+ },
+ "node_modules/autoprefixer": {
+ "version": "10.4.13",
+ "resolved": "https://registry.npmmirror.com/autoprefixer/-/autoprefixer-10.4.13.tgz",
+ "integrity": "sha512-49vKpMqcZYsJjwotvt4+h/BCjJVnhGwcLpDt5xkcaOG3eLrG/HUYLagrihYsQ+qrIBgIzX1Rw7a6L8I/ZA1Atg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/autoprefixer"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "browserslist": "^4.21.4",
+ "caniuse-lite": "^1.0.30001426",
+ "fraction.js": "^4.2.0",
+ "normalize-range": "^0.1.2",
+ "picocolors": "^1.0.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "bin": {
+ "autoprefixer": "bin/autoprefixer"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/axios": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmmirror.com/axios/-/axios-1.3.0.tgz",
+ "integrity": "sha512-oCye5nHhTypzkdLIvF9SaHfr8UAquqCn1KY3j8vsrjeol8yohAdGxIpRPbF1bOLsx33HOAatdfMX1yzsj2cHwg==",
+ "license": "MIT",
+ "dependencies": {
+ "follow-redirects": "^1.15.0",
+ "form-data": "^4.0.0",
+ "proxy-from-env": "^1.1.0"
+ }
+ },
+ "node_modules/balanced-match": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmmirror.com/balanced-match/-/balanced-match-1.0.2.tgz",
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/binary-extensions": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.2.0.tgz",
+ "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/boolbase": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/boolbase/-/boolbase-1.0.0.tgz",
+ "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmmirror.com/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/braces": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmmirror.com/braces/-/braces-3.0.2.tgz",
+ "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "fill-range": "^7.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/browserslist": {
+ "version": "4.21.5",
+ "resolved": "https://registry.npmmirror.com/browserslist/-/browserslist-4.21.5.tgz",
+ "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "caniuse-lite": "^1.0.30001449",
+ "electron-to-chromium": "^1.4.284",
+ "node-releases": "^2.0.8",
+ "update-browserslist-db": "^1.0.10"
+ },
+ "bin": {
+ "browserslist": "cli.js"
+ },
+ "engines": {
+ "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
+ }
+ },
+ "node_modules/buffer-from": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmmirror.com/buffer-from/-/buffer-from-1.1.2.tgz",
+ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/call-bind": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz",
+ "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
+ "license": "MIT",
+ "dependencies": {
+ "function-bind": "^1.1.1",
+ "get-intrinsic": "^1.0.2"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmmirror.com/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/camelcase": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmmirror.com/camelcase/-/camelcase-6.3.0.tgz",
+ "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/camelcase-keys": {
+ "version": "6.2.2",
+ "resolved": "https://registry.npmmirror.com/camelcase-keys/-/camelcase-keys-6.2.2.tgz",
+ "integrity": "sha512-YrwaA0vEKazPBkn0ipTiMpSajYDSe+KjQfrjhcBMxJt/znbvlHd8Pw/Vamaz5EB4Wfhs3SUR3Z9mwRu/P3s3Yg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "camelcase": "^5.3.1",
+ "map-obj": "^4.0.0",
+ "quick-lru": "^4.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/camelcase-keys/node_modules/camelcase": {
+ "version": "5.3.1",
+ "resolved": "https://registry.npmmirror.com/camelcase/-/camelcase-5.3.1.tgz",
+ "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001450",
+ "resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001450.tgz",
+ "integrity": "sha512-qMBmvmQmFXaSxexkjjfMvD5rnDL0+m+dUMZKoDYsGG8iZN29RuYh9eRoMvKsT6uMAWlyUUGDEQGJJYjzCIO9ew==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
+ }
+ ],
+ "license": "CC-BY-4.0"
+ },
+ "node_modules/chalk": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmmirror.com/chalk/-/chalk-2.4.2.tgz",
+ "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ansi-styles": "^3.2.1",
+ "escape-string-regexp": "^1.0.5",
+ "supports-color": "^5.3.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/chokidar": {
+ "version": "3.5.3",
+ "resolved": "https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz",
+ "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://paulmillr.com/funding/"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "anymatch": "~3.1.2",
+ "braces": "~3.0.2",
+ "glob-parent": "~5.1.2",
+ "is-binary-path": "~2.1.0",
+ "is-glob": "~4.0.1",
+ "normalize-path": "~3.0.0",
+ "readdirp": "~3.6.0"
+ },
+ "engines": {
+ "node": ">= 8.10.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/chokidar/node_modules/glob-parent": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz",
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "is-glob": "^4.0.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/chrome-trace-event": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmmirror.com/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz",
+ "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "engines": {
+ "node": ">=6.0"
+ }
+ },
+ "node_modules/cliui": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmmirror.com/cliui/-/cliui-8.0.1.tgz",
+ "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "string-width": "^4.2.0",
+ "strip-ansi": "^6.0.1",
+ "wrap-ansi": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/color-convert": {
+ "version": "1.9.3",
+ "resolved": "https://registry.npmmirror.com/color-convert/-/color-convert-1.9.3.tgz",
+ "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-name": "1.1.3"
+ }
+ },
+ "node_modules/color-name": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmmirror.com/color-name/-/color-name-1.1.3.tgz",
+ "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/colord": {
+ "version": "2.9.3",
+ "resolved": "https://registry.npmmirror.com/colord/-/colord-2.9.3.tgz",
+ "integrity": "sha512-jeC1axXpnb0/2nn/Y1LPuLdgXBLH7aDcHu4KEKfqw3CUhX7ZpfBSlPKyqXE6btIgEzfWtrX3/tyBCaCvXvMkOw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/combined-stream": {
+ "version": "1.0.8",
+ "resolved": "https://registry.npmmirror.com/combined-stream/-/combined-stream-1.0.8.tgz",
+ "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==",
+ "license": "MIT",
+ "dependencies": {
+ "delayed-stream": "~1.0.0"
+ },
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/commander": {
+ "version": "2.20.3",
+ "resolved": "https://registry.npmmirror.com/commander/-/commander-2.20.3.tgz",
+ "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/compute-scroll-into-view": {
+ "version": "1.0.20",
+ "resolved": "https://registry.npmmirror.com/compute-scroll-into-view/-/compute-scroll-into-view-1.0.20.tgz",
+ "integrity": "sha512-UCB0ioiyj8CRjtrvaceBLqqhZCVP+1B8+NWQhmdsm0VXOJtobBCf1dBQmebCCo34qZmUwZfIH2MZLqNHazrfjg==",
+ "license": "MIT"
+ },
+ "node_modules/concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmmirror.com/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/convert-source-map": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmmirror.com/convert-source-map/-/convert-source-map-1.9.0.tgz",
+ "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/copy-anything": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmmirror.com/copy-anything/-/copy-anything-2.0.6.tgz",
+ "integrity": "sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-what": "^3.14.1"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mesqueeb"
+ }
+ },
+ "node_modules/core-js": {
+ "version": "3.27.2",
+ "resolved": "https://registry.npmmirror.com/core-js/-/core-js-3.27.2.tgz",
+ "integrity": "sha512-9ashVQskuh5AZEZ1JdQWp1GqSoC1e1G87MzRqg2gIfVAQ7Qn9K+uFj8EcniUFA4P2NLZfV+TOlX1SzoKfo+s7w==",
+ "hasInstallScript": true,
+ "license": "MIT",
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/core-js"
+ }
+ },
+ "node_modules/cosmiconfig": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmmirror.com/cosmiconfig/-/cosmiconfig-7.1.0.tgz",
+ "integrity": "sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/parse-json": "^4.0.0",
+ "import-fresh": "^3.2.1",
+ "parse-json": "^5.0.0",
+ "path-type": "^4.0.0",
+ "yaml": "^1.10.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/cross-spawn": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmmirror.com/cross-spawn/-/cross-spawn-7.0.3.tgz",
+ "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/css-functions-list": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmmirror.com/css-functions-list/-/css-functions-list-3.1.0.tgz",
+ "integrity": "sha512-/9lCvYZaUbBGvYUgYGFJ4dcYiyqdhSjG7IPVluoV8A1ILjkF7ilmhp1OGUz8n+nmBcu0RNrQAzgD8B6FJbrt2w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=12.22"
+ }
+ },
+ "node_modules/cssesc": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/cssesc/-/cssesc-3.0.0.tgz",
+ "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "cssesc": "bin/cssesc"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/csstype": {
+ "version": "2.6.21",
+ "resolved": "https://registry.npmmirror.com/csstype/-/csstype-2.6.21.tgz",
+ "integrity": "sha512-Z1PhmomIfypOpoMjRQB70jfvy/wxT50qW08YXO5lMIJkrdq4yOTR+AW7FqutScmB9NkLwxo+jU+kZLbofZZq/w==",
+ "license": "MIT"
+ },
+ "node_modules/dayjs": {
+ "version": "1.11.7",
+ "resolved": "https://registry.npmmirror.com/dayjs/-/dayjs-1.11.7.tgz",
+ "integrity": "sha512-+Yw9U6YO5TQohxLcIkrXBeY73WP3ejHWVvx8XCk3gxvQDCTEmS48ZrSZCKciI7Bhl/uCMyxYtE9UqRILmFphkQ==",
+ "license": "MIT"
+ },
+ "node_modules/debug": {
+ "version": "4.3.4",
+ "resolved": "https://registry.npmmirror.com/debug/-/debug-4.3.4.tgz",
+ "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ms": "2.1.2"
+ },
+ "engines": {
+ "node": ">=6.0"
+ },
+ "peerDependenciesMeta": {
+ "supports-color": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/decamelize": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmmirror.com/decamelize/-/decamelize-1.2.0.tgz",
+ "integrity": "sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/decamelize-keys": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmmirror.com/decamelize-keys/-/decamelize-keys-1.1.1.tgz",
+ "integrity": "sha512-WiPxgEirIV0/eIOMcnFBA3/IJZAZqKnwAwWyvvdi4lsr1WCN22nhdf/3db3DoZcUjTV2SqfzIwNyp6y2xs3nmg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "decamelize": "^1.1.0",
+ "map-obj": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/decamelize-keys/node_modules/map-obj": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/map-obj/-/map-obj-1.0.1.tgz",
+ "integrity": "sha512-7N/q3lyZ+LVCp7PzuxrJr4KMbBE2hW7BT7YNia330OFxIf4d3r5zVpicP2650l7CPN6RM9zOJRl3NGpqSiw3Eg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/deep-is": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmmirror.com/deep-is/-/deep-is-0.1.4.tgz",
+ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/define-lazy-prop": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz",
+ "integrity": "sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/delayed-stream": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/delayed-stream/-/delayed-stream-1.0.0.tgz",
+ "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/dir-glob": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmmirror.com/dir-glob/-/dir-glob-3.0.1.tgz",
+ "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "path-type": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/doctrine": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/doctrine/-/doctrine-3.0.0.tgz",
+ "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "esutils": "^2.0.2"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/dom-align": {
+ "version": "1.12.4",
+ "resolved": "https://registry.npmmirror.com/dom-align/-/dom-align-1.12.4.tgz",
+ "integrity": "sha512-R8LUSEay/68zE5c8/3BDxiTEvgb4xZTF0RKmAHfiEVN3klfIpXfi2/QCoiWPccVQ0J/ZGdz9OjzL4uJEP/MRAw==",
+ "license": "MIT"
+ },
+ "node_modules/dom-scroll-into-view": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmmirror.com/dom-scroll-into-view/-/dom-scroll-into-view-2.0.1.tgz",
+ "integrity": "sha512-bvVTQe1lfaUr1oFzZX80ce9KLDlZ3iU+XGNE/bz9HnGdklTieqsbmsLHe+rT2XWqopvL0PckkYqN7ksmm5pe3w==",
+ "license": "MIT"
+ },
+ "node_modules/dom-serializer": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/dom-serializer/-/dom-serializer-2.0.0.tgz",
+ "integrity": "sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "domelementtype": "^2.3.0",
+ "domhandler": "^5.0.2",
+ "entities": "^4.2.0"
+ },
+ "funding": {
+ "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1"
+ }
+ },
+ "node_modules/domelementtype": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz",
+ "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/fb55"
+ }
+ ],
+ "license": "BSD-2-Clause"
+ },
+ "node_modules/domhandler": {
+ "version": "5.0.3",
+ "resolved": "https://registry.npmmirror.com/domhandler/-/domhandler-5.0.3.tgz",
+ "integrity": "sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "domelementtype": "^2.3.0"
+ },
+ "engines": {
+ "node": ">= 4"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/domhandler?sponsor=1"
+ }
+ },
+ "node_modules/domutils": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmmirror.com/domutils/-/domutils-3.0.1.tgz",
+ "integrity": "sha512-z08c1l761iKhDFtfXO04C7kTdPBLi41zwOZl00WS8b5eiaebNpY00HKbztwBq+e3vyqWNwWF3mP9YLUeqIrF+Q==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "dom-serializer": "^2.0.0",
+ "domelementtype": "^2.3.0",
+ "domhandler": "^5.0.1"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/domutils?sponsor=1"
+ }
+ },
+ "node_modules/electron-to-chromium": {
+ "version": "1.4.284",
+ "resolved": "https://registry.npmmirror.com/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz",
+ "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/emoji-regex": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmmirror.com/emoji-regex/-/emoji-regex-8.0.0.tgz",
+ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/enhanced-resolve": {
+ "version": "5.13.0",
+ "resolved": "https://registry.npmmirror.com/enhanced-resolve/-/enhanced-resolve-5.13.0.tgz",
+ "integrity": "sha512-eyV8f0y1+bzyfh8xAwW/WTSZpLbjhqc4ne9eGSH4Zo2ejdyiNG9pU6mf9DG8a7+Auk6MFTlNOT4Y2y/9k8GKVg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "graceful-fs": "^4.2.4",
+ "tapable": "^2.2.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/entities": {
+ "version": "4.4.0",
+ "resolved": "https://registry.npmmirror.com/entities/-/entities-4.4.0.tgz",
+ "integrity": "sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=0.12"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/entities?sponsor=1"
+ }
+ },
+ "node_modules/errno": {
+ "version": "0.1.8",
+ "resolved": "https://registry.npmmirror.com/errno/-/errno-0.1.8.tgz",
+ "integrity": "sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "prr": "~1.0.1"
+ },
+ "bin": {
+ "errno": "cli.js"
+ }
+ },
+ "node_modules/error-ex": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmmirror.com/error-ex/-/error-ex-1.3.2.tgz",
+ "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "node_modules/es-module-lexer": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmmirror.com/es-module-lexer/-/es-module-lexer-1.2.1.tgz",
+ "integrity": "sha512-9978wrXM50Y4rTMmW5kXIC09ZdXQZqkE4mxhwkd8VbzsGkXGPgV4zWuqQJgCEzYngdo2dYDa0l8xhX4fkSwJSg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/esbuild": {
+ "version": "0.16.17",
+ "resolved": "https://registry.npmmirror.com/esbuild/-/esbuild-0.16.17.tgz",
+ "integrity": "sha512-G8LEkV0XzDMNwXKgM0Jwu3nY3lSTwSGY6XbxM9cr9+s0T/qSV1q1JVPBGzm3dcjhCic9+emZDmMffkwgPeOeLg==",
+ "dev": true,
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "esbuild": "bin/esbuild"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "optionalDependencies": {
+ "@esbuild/android-arm": "0.16.17",
+ "@esbuild/android-arm64": "0.16.17",
+ "@esbuild/android-x64": "0.16.17",
+ "@esbuild/darwin-arm64": "0.16.17",
+ "@esbuild/darwin-x64": "0.16.17",
+ "@esbuild/freebsd-arm64": "0.16.17",
+ "@esbuild/freebsd-x64": "0.16.17",
+ "@esbuild/linux-arm": "0.16.17",
+ "@esbuild/linux-arm64": "0.16.17",
+ "@esbuild/linux-ia32": "0.16.17",
+ "@esbuild/linux-loong64": "0.16.17",
+ "@esbuild/linux-mips64el": "0.16.17",
+ "@esbuild/linux-ppc64": "0.16.17",
+ "@esbuild/linux-riscv64": "0.16.17",
+ "@esbuild/linux-s390x": "0.16.17",
+ "@esbuild/linux-x64": "0.16.17",
+ "@esbuild/netbsd-x64": "0.16.17",
+ "@esbuild/openbsd-x64": "0.16.17",
+ "@esbuild/sunos-x64": "0.16.17",
+ "@esbuild/win32-arm64": "0.16.17",
+ "@esbuild/win32-ia32": "0.16.17",
+ "@esbuild/win32-x64": "0.16.17"
+ }
+ },
+ "node_modules/escalade": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmmirror.com/escalade/-/escalade-3.1.1.tgz",
+ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/escape-string-regexp": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
+ "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/eslint": {
+ "version": "8.22.0",
+ "resolved": "https://registry.npmmirror.com/eslint/-/eslint-8.22.0.tgz",
+ "integrity": "sha512-ci4t0sz6vSRKdmkOGmprBo6fmI4PrphDFMy5JEq/fNS0gQkJM3rLmrqcp8ipMcdobH3KtUP40KniAE9W19S4wA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@eslint/eslintrc": "^1.3.0",
+ "@humanwhocodes/config-array": "^0.10.4",
+ "@humanwhocodes/gitignore-to-minimatch": "^1.0.2",
+ "ajv": "^6.10.0",
+ "chalk": "^4.0.0",
+ "cross-spawn": "^7.0.2",
+ "debug": "^4.3.2",
+ "doctrine": "^3.0.0",
+ "escape-string-regexp": "^4.0.0",
+ "eslint-scope": "^7.1.1",
+ "eslint-utils": "^3.0.0",
+ "eslint-visitor-keys": "^3.3.0",
+ "espree": "^9.3.3",
+ "esquery": "^1.4.0",
+ "esutils": "^2.0.2",
+ "fast-deep-equal": "^3.1.3",
+ "file-entry-cache": "^6.0.1",
+ "find-up": "^5.0.0",
+ "functional-red-black-tree": "^1.0.1",
+ "glob-parent": "^6.0.1",
+ "globals": "^13.15.0",
+ "globby": "^11.1.0",
+ "grapheme-splitter": "^1.0.4",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.0.0",
+ "imurmurhash": "^0.1.4",
+ "is-glob": "^4.0.0",
+ "js-yaml": "^4.1.0",
+ "json-stable-stringify-without-jsonify": "^1.0.1",
+ "levn": "^0.4.1",
+ "lodash.merge": "^4.6.2",
+ "minimatch": "^3.1.2",
+ "natural-compare": "^1.4.0",
+ "optionator": "^0.9.1",
+ "regexpp": "^3.2.0",
+ "strip-ansi": "^6.0.1",
+ "strip-json-comments": "^3.1.0",
+ "text-table": "^0.2.0",
+ "v8-compile-cache": "^2.0.3"
+ },
+ "bin": {
+ "eslint": "bin/eslint.js"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint-config-prettier": {
+ "version": "8.6.0",
+ "resolved": "https://registry.npmmirror.com/eslint-config-prettier/-/eslint-config-prettier-8.6.0.tgz",
+ "integrity": "sha512-bAF0eLpLVqP5oEVUFKpMA+NnRFICwn9X8B5jrR9FcqnYBuPbqWEjTEspPWMj5ye6czoSLDweCzSo3Ko7gGrZaA==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "eslint-config-prettier": "bin/cli.js"
+ },
+ "peerDependencies": {
+ "eslint": ">=7.0.0"
+ }
+ },
+ "node_modules/eslint-define-config": {
+ "version": "1.14.0",
+ "resolved": "https://registry.npmmirror.com/eslint-define-config/-/eslint-define-config-1.14.0.tgz",
+ "integrity": "sha512-NREt5SzMwKmLAY28YdaqIiTSJxfPpuZ+1ZLJxY2Wbj02dYF4QX81z0q9MPMjZB8C+SlCu66qAhcPpFJyhXOiuA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/Shinigami92"
+ },
+ {
+ "type": "paypal",
+ "url": "https://www.paypal.com/donate/?hosted_button_id=L7GY729FBKTZY"
+ }
+ ],
+ "license": "MIT",
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0",
+ "npm": ">=6.14.13",
+ "pnpm": ">= 7.0.0"
+ }
+ },
+ "node_modules/eslint-plugin-prettier": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmmirror.com/eslint-plugin-prettier/-/eslint-plugin-prettier-4.2.1.tgz",
+ "integrity": "sha512-f/0rXLXUt0oFYs8ra4w49wYZBG5GKZpAYsJSm6rnYL5uVDjd+zowwMwVZHnAjf4edNrKpCDYfXDgmRE/Ak7QyQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "prettier-linter-helpers": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=12.0.0"
+ },
+ "peerDependencies": {
+ "eslint": ">=7.28.0",
+ "prettier": ">=2.0.0"
+ },
+ "peerDependenciesMeta": {
+ "eslint-config-prettier": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/eslint-plugin-vue": {
+ "version": "9.9.0",
+ "resolved": "https://registry.npmmirror.com/eslint-plugin-vue/-/eslint-plugin-vue-9.9.0.tgz",
+ "integrity": "sha512-YbubS7eK0J7DCf0U2LxvVP7LMfs6rC6UltihIgval3azO3gyDwEGVgsCMe1TmDiEkl6GdMKfRpaME6QxIYtzDQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "eslint-utils": "^3.0.0",
+ "natural-compare": "^1.4.0",
+ "nth-check": "^2.0.1",
+ "postcss-selector-parser": "^6.0.9",
+ "semver": "^7.3.5",
+ "vue-eslint-parser": "^9.0.1",
+ "xml-name-validator": "^4.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || >=16.0.0"
+ },
+ "peerDependencies": {
+ "eslint": "^6.2.0 || ^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/eslint-scope": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmmirror.com/eslint-scope/-/eslint-scope-5.1.1.tgz",
+ "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^4.1.1"
+ },
+ "engines": {
+ "node": ">=8.0.0"
+ }
+ },
+ "node_modules/eslint-utils": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/eslint-utils/-/eslint-utils-3.0.0.tgz",
+ "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "eslint-visitor-keys": "^2.0.0"
+ },
+ "engines": {
+ "node": "^10.0.0 || ^12.0.0 || >= 14.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mysticatea"
+ },
+ "peerDependencies": {
+ "eslint": ">=5"
+ }
+ },
+ "node_modules/eslint-utils/node_modules/eslint-visitor-keys": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz",
+ "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/eslint-visitor-keys": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmmirror.com/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz",
+ "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/eslint/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/eslint/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/eslint/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/eslint/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/eslint/node_modules/escape-string-regexp": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
+ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint/node_modules/eslint-scope": {
+ "version": "7.1.1",
+ "resolved": "https://registry.npmmirror.com/eslint-scope/-/eslint-scope-7.1.1.tgz",
+ "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/eslint/node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmmirror.com/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/eslint/node_modules/globals": {
+ "version": "13.20.0",
+ "resolved": "https://registry.npmmirror.com/globals/-/globals-13.20.0.tgz",
+ "integrity": "sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "type-fest": "^0.20.2"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/eslint/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/eslint/node_modules/type-fest": {
+ "version": "0.20.2",
+ "resolved": "https://registry.npmmirror.com/type-fest/-/type-fest-0.20.2.tgz",
+ "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
+ "dev": true,
+ "license": "(MIT OR CC0-1.0)",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/espree": {
+ "version": "9.4.1",
+ "resolved": "https://registry.npmmirror.com/espree/-/espree-9.4.1.tgz",
+ "integrity": "sha512-XwctdmTO6SIvCzd9810yyNzIrOrqNYV9Koizx4C/mRhf9uq0o4yHoCEU/670pOxOL/MSraektvSAji79kX90Vg==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "acorn": "^8.8.0",
+ "acorn-jsx": "^5.3.2",
+ "eslint-visitor-keys": "^3.3.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/esquery": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmmirror.com/esquery/-/esquery-1.4.0.tgz",
+ "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "dependencies": {
+ "estraverse": "^5.1.0"
+ },
+ "engines": {
+ "node": ">=0.10"
+ }
+ },
+ "node_modules/esquery/node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmmirror.com/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmmirror.com/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/esrecurse/node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmmirror.com/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estraverse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmmirror.com/estraverse/-/estraverse-4.3.0.tgz",
+ "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estree-walker": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz",
+ "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==",
+ "license": "MIT"
+ },
+ "node_modules/esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmmirror.com/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/events": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmmirror.com/events/-/events-3.3.0.tgz",
+ "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "engines": {
+ "node": ">=0.8.x"
+ }
+ },
+ "node_modules/fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmmirror.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/fast-diff": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmmirror.com/fast-diff/-/fast-diff-1.2.0.tgz",
+ "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==",
+ "dev": true,
+ "license": "Apache-2.0"
+ },
+ "node_modules/fast-glob": {
+ "version": "3.2.12",
+ "resolved": "https://registry.npmmirror.com/fast-glob/-/fast-glob-3.2.12.tgz",
+ "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@nodelib/fs.stat": "^2.0.2",
+ "@nodelib/fs.walk": "^1.2.3",
+ "glob-parent": "^5.1.2",
+ "merge2": "^1.3.0",
+ "micromatch": "^4.0.4"
+ },
+ "engines": {
+ "node": ">=8.6.0"
+ }
+ },
+ "node_modules/fast-glob/node_modules/glob-parent": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz",
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "is-glob": "^4.0.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/fast-levenshtein": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmmirror.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
+ "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/fastest-levenshtein": {
+ "version": "1.0.16",
+ "resolved": "https://registry.npmmirror.com/fastest-levenshtein/-/fastest-levenshtein-1.0.16.tgz",
+ "integrity": "sha512-eRnCtTTtGZFpQCwhJiUOuxPQWRXVKYDn0b2PeHfXL6/Zi53SLAzAHfVhVWK2AryC/WH05kGfxhFIPvTF0SXQzg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 4.9.1"
+ }
+ },
+ "node_modules/fastq": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmmirror.com/fastq/-/fastq-1.15.0.tgz",
+ "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "reusify": "^1.0.4"
+ }
+ },
+ "node_modules/file-entry-cache": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmmirror.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz",
+ "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "flat-cache": "^3.0.4"
+ },
+ "engines": {
+ "node": "^10.12.0 || >=12.0.0"
+ }
+ },
+ "node_modules/fill-range": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz",
+ "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "to-regex-range": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/find-up": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmmirror.com/find-up/-/find-up-5.0.0.tgz",
+ "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "locate-path": "^6.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/flat-cache": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmmirror.com/flat-cache/-/flat-cache-3.0.4.tgz",
+ "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "flatted": "^3.1.0",
+ "rimraf": "^3.0.2"
+ },
+ "engines": {
+ "node": "^10.12.0 || >=12.0.0"
+ }
+ },
+ "node_modules/flatted": {
+ "version": "3.2.7",
+ "resolved": "https://registry.npmmirror.com/flatted/-/flatted-3.2.7.tgz",
+ "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/follow-redirects": {
+ "version": "1.15.2",
+ "resolved": "https://registry.npmmirror.com/follow-redirects/-/follow-redirects-1.15.2.tgz",
+ "integrity": "sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==",
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://github.com/sponsors/RubenVerborgh"
+ }
+ ],
+ "license": "MIT",
+ "engines": {
+ "node": ">=4.0"
+ },
+ "peerDependenciesMeta": {
+ "debug": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/form-data": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/form-data/-/form-data-4.0.0.tgz",
+ "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==",
+ "license": "MIT",
+ "dependencies": {
+ "asynckit": "^0.4.0",
+ "combined-stream": "^1.0.8",
+ "mime-types": "^2.1.12"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/fraction.js": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmmirror.com/fraction.js/-/fraction.js-4.2.0.tgz",
+ "integrity": "sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "type": "patreon",
+ "url": "https://www.patreon.com/infusion"
+ }
+ },
+ "node_modules/fs-extra": {
+ "version": "10.1.0",
+ "resolved": "https://registry.npmmirror.com/fs-extra/-/fs-extra-10.1.0.tgz",
+ "integrity": "sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "graceful-fs": "^4.2.0",
+ "jsonfile": "^6.0.1",
+ "universalify": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/fs.realpath": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/fs.realpath/-/fs.realpath-1.0.0.tgz",
+ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/fsevents": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmmirror.com/fsevents/-/fsevents-2.3.3.tgz",
+ "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
+ "dev": true,
+ "hasInstallScript": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
+ }
+ },
+ "node_modules/function-bind": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmmirror.com/function-bind/-/function-bind-1.1.1.tgz",
+ "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==",
+ "license": "MIT"
+ },
+ "node_modules/functional-red-black-tree": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz",
+ "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/gensync": {
+ "version": "1.0.0-beta.2",
+ "resolved": "https://registry.npmmirror.com/gensync/-/gensync-1.0.0-beta.2.tgz",
+ "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/get-caller-file": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmmirror.com/get-caller-file/-/get-caller-file-2.0.5.tgz",
+ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
+ "dev": true,
+ "license": "ISC",
+ "engines": {
+ "node": "6.* || 8.* || >= 10.*"
+ }
+ },
+ "node_modules/get-intrinsic": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.2.0.tgz",
+ "integrity": "sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q==",
+ "license": "MIT",
+ "dependencies": {
+ "function-bind": "^1.1.1",
+ "has": "^1.0.3",
+ "has-symbols": "^1.0.3"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmmirror.com/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ },
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmmirror.com/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "is-glob": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/glob-to-regexp": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmmirror.com/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz",
+ "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "peer": true
+ },
+ "node_modules/global-modules": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/global-modules/-/global-modules-2.0.0.tgz",
+ "integrity": "sha512-NGbfmJBp9x8IxyJSd1P+otYK8vonoJactOogrVfFRIAEY1ukil8RSKDz2Yo7wh1oihl51l/r6W4epkeKJHqL8A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "global-prefix": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/global-prefix": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/global-prefix/-/global-prefix-3.0.0.tgz",
+ "integrity": "sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ini": "^1.3.5",
+ "kind-of": "^6.0.2",
+ "which": "^1.3.1"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/global-prefix/node_modules/which": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmmirror.com/which/-/which-1.3.1.tgz",
+ "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "which": "bin/which"
+ }
+ },
+ "node_modules/globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmmirror.com/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/globby": {
+ "version": "11.1.0",
+ "resolved": "https://registry.npmmirror.com/globby/-/globby-11.1.0.tgz",
+ "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "array-union": "^2.1.0",
+ "dir-glob": "^3.0.1",
+ "fast-glob": "^3.2.9",
+ "ignore": "^5.2.0",
+ "merge2": "^1.4.1",
+ "slash": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/globjoin": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmmirror.com/globjoin/-/globjoin-0.1.4.tgz",
+ "integrity": "sha512-xYfnw62CKG8nLkZBfWbhWwDw02CHty86jfPcc2cr3ZfeuK9ysoVPPEUxf21bAD/rWAgk52SuBrLJlefNy8mvFg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/graceful-fs": {
+ "version": "4.2.10",
+ "resolved": "https://registry.npmmirror.com/graceful-fs/-/graceful-fs-4.2.10.tgz",
+ "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/grapheme-splitter": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmmirror.com/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz",
+ "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/hard-rejection": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/hard-rejection/-/hard-rejection-2.1.0.tgz",
+ "integrity": "sha512-VIZB+ibDhx7ObhAe7OVtoEbuP4h/MuOTHJ+J8h/eBXotJYl0fBgR72xDFCKgIh22OJZIOVNxBMWuhAr10r8HdA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/has": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmmirror.com/has/-/has-1.0.3.tgz",
+ "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
+ "license": "MIT",
+ "dependencies": {
+ "function-bind": "^1.1.1"
+ },
+ "engines": {
+ "node": ">= 0.4.0"
+ }
+ },
+ "node_modules/has-flag": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/has-flag/-/has-flag-3.0.0.tgz",
+ "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/has-symbols": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmmirror.com/has-symbols/-/has-symbols-1.0.3.tgz",
+ "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
+ "license": "MIT",
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/hosted-git-info": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmmirror.com/hosted-git-info/-/hosted-git-info-4.1.0.tgz",
+ "integrity": "sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "lru-cache": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/hosted-git-info/node_modules/lru-cache": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmmirror.com/lru-cache/-/lru-cache-6.0.0.tgz",
+ "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/hosted-git-info/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/html-tags": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmmirror.com/html-tags/-/html-tags-3.2.0.tgz",
+ "integrity": "sha512-vy7ClnArOZwCnqZgvv+ddgHgJiAFXe3Ge9ML5/mBctVJoUoYPCdxVucOywjDARn6CVoh3dRSFdPHy2sX80L0Wg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/htmlparser2": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmmirror.com/htmlparser2/-/htmlparser2-8.0.1.tgz",
+ "integrity": "sha512-4lVbmc1diZC7GUJQtRQ5yBAeUCL1exyMwmForWkRLnwyzWBFxN633SALPMGYaWZvKe9j1pRZJpauvmxENSp/EA==",
+ "dev": true,
+ "funding": [
+ "https://github.com/fb55/htmlparser2?sponsor=1",
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/fb55"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "domelementtype": "^2.3.0",
+ "domhandler": "^5.0.2",
+ "domutils": "^3.0.1",
+ "entities": "^4.3.0"
+ }
+ },
+ "node_modules/iconv-lite": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmmirror.com/iconv-lite/-/iconv-lite-0.6.3.tgz",
+ "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "safer-buffer": ">= 2.1.2 < 3.0.0"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/ignore": {
+ "version": "5.2.4",
+ "resolved": "https://registry.npmmirror.com/ignore/-/ignore-5.2.4.tgz",
+ "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/image-size": {
+ "version": "0.5.5",
+ "resolved": "https://registry.npmmirror.com/image-size/-/image-size-0.5.5.tgz",
+ "integrity": "sha512-6TDAlDPZxUFCv+fuOkIoXT/V/f3Qbq8e37p+YOiYrUv3v9cc3/6x78VdfPgFVaB9dZYeLUfKgHRebpkm/oP2VQ==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "bin": {
+ "image-size": "bin/image-size.js"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/import-fresh": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmmirror.com/import-fresh/-/import-fresh-3.3.0.tgz",
+ "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "parent-module": "^1.0.0",
+ "resolve-from": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/import-lazy": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/import-lazy/-/import-lazy-4.0.0.tgz",
+ "integrity": "sha512-rKtvo6a868b5Hu3heneU+L4yEQ4jYKLtjpnPeUdK7h0yzXGmyBTypknlkCvHFBqfX9YlorEiMM6Dnq/5atfHkw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmmirror.com/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.8.19"
+ }
+ },
+ "node_modules/indent-string": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/indent-string/-/indent-string-4.0.0.tgz",
+ "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/inflight": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmmirror.com/inflight/-/inflight-1.0.6.tgz",
+ "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "once": "^1.3.0",
+ "wrappy": "1"
+ }
+ },
+ "node_modules/inherits": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz",
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/ini": {
+ "version": "1.3.8",
+ "resolved": "https://registry.npmmirror.com/ini/-/ini-1.3.8.tgz",
+ "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmmirror.com/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/is-binary-path": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/is-binary-path/-/is-binary-path-2.1.0.tgz",
+ "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "binary-extensions": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-core-module": {
+ "version": "2.11.0",
+ "resolved": "https://registry.npmmirror.com/is-core-module/-/is-core-module-2.11.0.tgz",
+ "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "has": "^1.0.3"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/is-docker": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmmirror.com/is-docker/-/is-docker-2.2.1.tgz",
+ "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "is-docker": "cli.js"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmmirror.com/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-fullwidth-code-point": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
+ "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmmirror.com/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-extglob": "^2.1.1"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-number": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmmirror.com/is-number/-/is-number-7.0.0.tgz",
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.12.0"
+ }
+ },
+ "node_modules/is-plain-obj": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmmirror.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz",
+ "integrity": "sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-plain-object": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmmirror.com/is-plain-object/-/is-plain-object-5.0.0.tgz",
+ "integrity": "sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-what": {
+ "version": "3.14.1",
+ "resolved": "https://registry.npmmirror.com/is-what/-/is-what-3.14.1.tgz",
+ "integrity": "sha512-sNxgpk9793nzSs7bA6JQJGeIuRBQhAaNGG77kzYQgMkrID+lS6SlK07K5LaptscDlSaIgH+GPFzf+d75FVxozA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/is-wsl": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmmirror.com/is-wsl/-/is-wsl-2.2.0.tgz",
+ "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-docker": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/jest-worker": {
+ "version": "27.5.1",
+ "resolved": "https://registry.npmmirror.com/jest-worker/-/jest-worker-27.5.1.tgz",
+ "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@types/node": "*",
+ "merge-stream": "^2.0.0",
+ "supports-color": "^8.0.0"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ }
+ },
+ "node_modules/jest-worker/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-worker/node_modules/supports-color": {
+ "version": "8.1.1",
+ "resolved": "https://registry.npmmirror.com/supports-color/-/supports-color-8.1.1.tgz",
+ "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/supports-color?sponsor=1"
+ }
+ },
+ "node_modules/js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
+ "license": "MIT"
+ },
+ "node_modules/js-yaml": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmmirror.com/js-yaml/-/js-yaml-4.1.0.tgz",
+ "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "argparse": "^2.0.1"
+ },
+ "bin": {
+ "js-yaml": "bin/js-yaml.js"
+ }
+ },
+ "node_modules/jsesc": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmmirror.com/jsesc/-/jsesc-2.5.2.tgz",
+ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "jsesc": "bin/jsesc"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/json-parse-even-better-errors": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmmirror.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
+ "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmmirror.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/json-stable-stringify-without-jsonify": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
+ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/json5": {
+ "version": "2.2.3",
+ "resolved": "https://registry.npmmirror.com/json5/-/json5-2.2.3.tgz",
+ "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "json5": "lib/cli.js"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/jsonc-parser": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmmirror.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz",
+ "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/jsonfile": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmmirror.com/jsonfile/-/jsonfile-6.1.0.tgz",
+ "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "universalify": "^2.0.0"
+ },
+ "optionalDependencies": {
+ "graceful-fs": "^4.1.6"
+ }
+ },
+ "node_modules/kind-of": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz",
+ "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/klona": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmmirror.com/klona/-/klona-2.0.6.tgz",
+ "integrity": "sha512-dhG34DXATL5hSxJbIexCft8FChFXtmskoZYnoPWjXQuebWYCNkVeV3KkGegCK9CP1oswI/vQibS2GY7Em/sJJA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/known-css-properties": {
+ "version": "0.26.0",
+ "resolved": "https://registry.npmmirror.com/known-css-properties/-/known-css-properties-0.26.0.tgz",
+ "integrity": "sha512-5FZRzrZzNTBruuurWpvZnvP9pum+fe0HcK8z/ooo+U+Hmp4vtbyp1/QDsqmufirXy4egGzbaH/y2uCZf+6W5Kg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/less": {
+ "version": "4.1.3",
+ "resolved": "https://registry.npmmirror.com/less/-/less-4.1.3.tgz",
+ "integrity": "sha512-w16Xk/Ta9Hhyei0Gpz9m7VS8F28nieJaL/VyShID7cYvP6IL5oHeL6p4TXSDJqZE/lNv0oJ2pGVjJsRkfwm5FA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "copy-anything": "^2.0.1",
+ "parse-node-version": "^1.0.1",
+ "tslib": "^2.3.0"
+ },
+ "bin": {
+ "lessc": "bin/lessc"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "optionalDependencies": {
+ "errno": "^0.1.1",
+ "graceful-fs": "^4.1.2",
+ "image-size": "~0.5.0",
+ "make-dir": "^2.1.0",
+ "mime": "^1.4.1",
+ "needle": "^3.1.0",
+ "source-map": "~0.6.0"
+ }
+ },
+ "node_modules/less-loader": {
+ "version": "11.1.0",
+ "resolved": "https://registry.npmmirror.com/less-loader/-/less-loader-11.1.0.tgz",
+ "integrity": "sha512-C+uDBV7kS7W5fJlUjq5mPBeBVhYpTIm5gB09APT9o3n/ILeaXVsiSFTbZpTJCJwQ/Crczfn3DmfQFwxYusWFug==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "klona": "^2.0.4"
+ },
+ "engines": {
+ "node": ">= 14.15.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "less": "^3.5.0 || ^4.0.0",
+ "webpack": "^5.0.0"
+ }
+ },
+ "node_modules/levn": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmmirror.com/levn/-/levn-0.4.1.tgz",
+ "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "prelude-ls": "^1.2.1",
+ "type-check": "~0.4.0"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/lines-and-columns": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmmirror.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
+ "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/loader-runner": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmmirror.com/loader-runner/-/loader-runner-4.3.0.tgz",
+ "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "engines": {
+ "node": ">=6.11.5"
+ }
+ },
+ "node_modules/local-pkg": {
+ "version": "0.4.3",
+ "resolved": "https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz",
+ "integrity": "sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/locate-path": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmmirror.com/locate-path/-/locate-path-6.0.0.tgz",
+ "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-locate": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/lodash": {
+ "version": "4.17.21",
+ "resolved": "https://registry.npmmirror.com/lodash/-/lodash-4.17.21.tgz",
+ "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==",
+ "license": "MIT"
+ },
+ "node_modules/lodash-es": {
+ "version": "4.17.21",
+ "resolved": "https://registry.npmmirror.com/lodash-es/-/lodash-es-4.17.21.tgz",
+ "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==",
+ "license": "MIT"
+ },
+ "node_modules/lodash.merge": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmmirror.com/lodash.merge/-/lodash.merge-4.6.2.tgz",
+ "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/lodash.truncate": {
+ "version": "4.4.2",
+ "resolved": "https://registry.npmmirror.com/lodash.truncate/-/lodash.truncate-4.4.2.tgz",
+ "integrity": "sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/loose-envify": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmmirror.com/loose-envify/-/loose-envify-1.4.0.tgz",
+ "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==",
+ "license": "MIT",
+ "dependencies": {
+ "js-tokens": "^3.0.0 || ^4.0.0"
+ },
+ "bin": {
+ "loose-envify": "cli.js"
+ }
+ },
+ "node_modules/lru-cache": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmmirror.com/lru-cache/-/lru-cache-5.1.1.tgz",
+ "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "yallist": "^3.0.2"
+ }
+ },
+ "node_modules/magic-string": {
+ "version": "0.27.0",
+ "resolved": "https://registry.npmmirror.com/magic-string/-/magic-string-0.27.0.tgz",
+ "integrity": "sha512-8UnnX2PeRAPZuN12svgR9j7M1uWMovg/CEnIwIG0LFkXSJJe4PdfUGiTGl8V9bsBHFUtfVINcSyYxd7q+kx9fA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.4.13"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/make-dir": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/make-dir/-/make-dir-2.1.0.tgz",
+ "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "pify": "^4.0.1",
+ "semver": "^5.6.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/make-dir/node_modules/semver": {
+ "version": "5.7.1",
+ "resolved": "https://registry.npmmirror.com/semver/-/semver-5.7.1.tgz",
+ "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
+ "dev": true,
+ "license": "ISC",
+ "optional": true,
+ "bin": {
+ "semver": "bin/semver"
+ }
+ },
+ "node_modules/map-obj": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmmirror.com/map-obj/-/map-obj-4.3.0.tgz",
+ "integrity": "sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/mathml-tag-names": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmmirror.com/mathml-tag-names/-/mathml-tag-names-2.1.3.tgz",
+ "integrity": "sha512-APMBEanjybaPzUrfqU0IMU5I0AswKMH7k8OTLs0vvV4KZpExkTkY87nR/zpbuTPj+gARop7aGUbl11pnDfW6xg==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/meow": {
+ "version": "9.0.0",
+ "resolved": "https://registry.npmmirror.com/meow/-/meow-9.0.0.tgz",
+ "integrity": "sha512-+obSblOQmRhcyBt62furQqRAQpNyWXo8BuQ5bN7dG8wmwQ+vwHKp/rCFD4CrTP8CsDQD1sjoZ94K417XEUk8IQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/minimist": "^1.2.0",
+ "camelcase-keys": "^6.2.2",
+ "decamelize": "^1.2.0",
+ "decamelize-keys": "^1.1.0",
+ "hard-rejection": "^2.1.0",
+ "minimist-options": "4.1.0",
+ "normalize-package-data": "^3.0.0",
+ "read-pkg-up": "^7.0.1",
+ "redent": "^3.0.0",
+ "trim-newlines": "^3.0.0",
+ "type-fest": "^0.18.0",
+ "yargs-parser": "^20.2.3"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/merge-stream": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/merge-stream/-/merge-stream-2.0.0.tgz",
+ "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/merge2": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmmirror.com/merge2/-/merge2-1.4.1.tgz",
+ "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/micromatch": {
+ "version": "4.0.5",
+ "resolved": "https://registry.npmmirror.com/micromatch/-/micromatch-4.0.5.tgz",
+ "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "braces": "^3.0.2",
+ "picomatch": "^2.3.1"
+ },
+ "engines": {
+ "node": ">=8.6"
+ }
+ },
+ "node_modules/mime": {
+ "version": "1.6.0",
+ "resolved": "https://registry.npmmirror.com/mime/-/mime-1.6.0.tgz",
+ "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "bin": {
+ "mime": "cli.js"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/mime-db": {
+ "version": "1.52.0",
+ "resolved": "https://registry.npmmirror.com/mime-db/-/mime-db-1.52.0.tgz",
+ "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
+ "license": "MIT",
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/mime-types": {
+ "version": "2.1.35",
+ "resolved": "https://registry.npmmirror.com/mime-types/-/mime-types-2.1.35.tgz",
+ "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
+ "license": "MIT",
+ "dependencies": {
+ "mime-db": "1.52.0"
+ },
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/min-indent": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/min-indent/-/min-indent-1.0.1.tgz",
+ "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmmirror.com/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/minimist-options": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmmirror.com/minimist-options/-/minimist-options-4.1.0.tgz",
+ "integrity": "sha512-Q4r8ghd80yhO/0j1O3B2BjweX3fiHg9cdOwjJd2J76Q135c+NDxGCqdYKQ1SKBuFfgWbAUzBfvYjPUEeNgqN1A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "arrify": "^1.0.1",
+ "is-plain-obj": "^1.1.0",
+ "kind-of": "^6.0.3"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/mlly": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmmirror.com/mlly/-/mlly-1.1.0.tgz",
+ "integrity": "sha512-cwzBrBfwGC1gYJyfcy8TcZU1f+dbH/T+TuOhtYP2wLv/Fb51/uV7HJQfBPtEupZ2ORLRU1EKFS/QfS3eo9+kBQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "acorn": "^8.8.1",
+ "pathe": "^1.0.0",
+ "pkg-types": "^1.0.1",
+ "ufo": "^1.0.1"
+ }
+ },
+ "node_modules/ms": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmmirror.com/ms/-/ms-2.1.2.tgz",
+ "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.4",
+ "resolved": "https://registry.npmmirror.com/nanoid/-/nanoid-3.3.4.tgz",
+ "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==",
+ "license": "MIT",
+ "bin": {
+ "nanoid": "bin/nanoid.cjs"
+ },
+ "engines": {
+ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
+ }
+ },
+ "node_modules/nanopop": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmmirror.com/nanopop/-/nanopop-2.2.0.tgz",
+ "integrity": "sha512-E9JaHcxh3ere8/BEZHAcnuD10RluTSPyTToBvoFWS9/7DcCx6gyKjbn7M7Bx7E1veCxCuY1iO6h4+gdAf1j73Q==",
+ "license": "MIT"
+ },
+ "node_modules/natural-compare": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmmirror.com/natural-compare/-/natural-compare-1.4.0.tgz",
+ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/natural-compare-lite": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmmirror.com/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz",
+ "integrity": "sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/needle": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmmirror.com/needle/-/needle-3.2.0.tgz",
+ "integrity": "sha512-oUvzXnyLiVyVGoianLijF9O/RecZUf7TkBfimjGrLM4eQhXyeJwM6GeAWccwfQ9aa4gMCZKqhAOuLaMIcQxajQ==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "debug": "^3.2.6",
+ "iconv-lite": "^0.6.3",
+ "sax": "^1.2.4"
+ },
+ "bin": {
+ "needle": "bin/needle"
+ },
+ "engines": {
+ "node": ">= 4.4.x"
+ }
+ },
+ "node_modules/needle/node_modules/debug": {
+ "version": "3.2.7",
+ "resolved": "https://registry.npmmirror.com/debug/-/debug-3.2.7.tgz",
+ "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "ms": "^2.1.1"
+ }
+ },
+ "node_modules/neo-async": {
+ "version": "2.6.2",
+ "resolved": "https://registry.npmmirror.com/neo-async/-/neo-async-2.6.2.tgz",
+ "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/node-releases": {
+ "version": "2.0.9",
+ "resolved": "https://registry.npmmirror.com/node-releases/-/node-releases-2.0.9.tgz",
+ "integrity": "sha512-2xfmOrRkGogbTK9R6Leda0DGiXeY3p2NJpy4+gNCffdUvV6mdEJnaDEic1i3Ec2djAo8jWYoJMR5PB0MSMpxUA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/normalize-package-data": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmmirror.com/normalize-package-data/-/normalize-package-data-3.0.3.tgz",
+ "integrity": "sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "hosted-git-info": "^4.0.1",
+ "is-core-module": "^2.5.0",
+ "semver": "^7.3.4",
+ "validate-npm-package-license": "^3.0.1"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/normalize-path": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/normalize-path/-/normalize-path-3.0.0.tgz",
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/normalize-range": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmmirror.com/normalize-range/-/normalize-range-0.1.2.tgz",
+ "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/nth-check": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmmirror.com/nth-check/-/nth-check-2.1.1.tgz",
+ "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "boolbase": "^1.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/nth-check?sponsor=1"
+ }
+ },
+ "node_modules/object-inspect": {
+ "version": "1.12.3",
+ "resolved": "https://registry.npmmirror.com/object-inspect/-/object-inspect-1.12.3.tgz",
+ "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==",
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/once": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmmirror.com/once/-/once-1.4.0.tgz",
+ "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "wrappy": "1"
+ }
+ },
+ "node_modules/open": {
+ "version": "8.4.0",
+ "resolved": "https://registry.npmmirror.com/open/-/open-8.4.0.tgz",
+ "integrity": "sha512-XgFPPM+B28FtCCgSb9I+s9szOC1vZRSwgWsRUA5ylIxRTgKozqjOCrVOqGsYABPYK5qnfqClxZTFBa8PKt2v6Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "define-lazy-prop": "^2.0.0",
+ "is-docker": "^2.1.1",
+ "is-wsl": "^2.2.0"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/optionator": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmmirror.com/optionator/-/optionator-0.9.1.tgz",
+ "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "deep-is": "^0.1.3",
+ "fast-levenshtein": "^2.0.6",
+ "levn": "^0.4.1",
+ "prelude-ls": "^1.2.1",
+ "type-check": "^0.4.0",
+ "word-wrap": "^1.2.3"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/p-limit": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmmirror.com/p-limit/-/p-limit-3.1.0.tgz",
+ "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "yocto-queue": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-locate": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmmirror.com/p-locate/-/p-locate-5.0.0.tgz",
+ "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-limit": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-try": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmmirror.com/p-try/-/p-try-2.2.0.tgz",
+ "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/parent-module": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "callsites": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/parse-json": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmmirror.com/parse-json/-/parse-json-5.2.0.tgz",
+ "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.0.0",
+ "error-ex": "^1.3.1",
+ "json-parse-even-better-errors": "^2.3.0",
+ "lines-and-columns": "^1.1.6"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/parse-node-version": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/parse-node-version/-/parse-node-version-1.0.1.tgz",
+ "integrity": "sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 0.10"
+ }
+ },
+ "node_modules/path-exists": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/path-exists/-/path-exists-4.0.0.tgz",
+ "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-is-absolute": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
+ "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmmirror.com/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-parse": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmmirror.com/path-parse/-/path-parse-1.0.7.tgz",
+ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/path-type": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/path-type/-/path-type-4.0.0.tgz",
+ "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/pathe": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmmirror.com/pathe/-/pathe-1.1.0.tgz",
+ "integrity": "sha512-ODbEPR0KKHqECXW1GoxdDb+AZvULmXjVPy4rt+pGo2+TnjJTIPJQSVS6N63n8T2Ip+syHhbn52OewKicV0373w==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/picocolors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz",
+ "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
+ "license": "ISC"
+ },
+ "node_modules/picomatch": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz",
+ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8.6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/jonschlinkert"
+ }
+ },
+ "node_modules/pify": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmmirror.com/pify/-/pify-4.0.1.tgz",
+ "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/pinia": {
+ "version": "2.0.29",
+ "resolved": "https://registry.npmmirror.com/pinia/-/pinia-2.0.29.tgz",
+ "integrity": "sha512-5z/KpFecq/cIgfeTnulJXldiLcTITRkTe3N58RKYSj0Pc1EdR6oyCdnf5A9jLoVwBqX5LtHhd0kGlpzWvk9oiQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/devtools-api": "^6.4.5",
+ "vue-demi": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/posva"
+ },
+ "peerDependencies": {
+ "@vue/composition-api": "^1.4.0",
+ "typescript": ">=4.4.4",
+ "vue": "^2.6.14 || ^3.2.0"
+ },
+ "peerDependenciesMeta": {
+ "@vue/composition-api": {
+ "optional": true
+ },
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/pinia-plugin-persistedstate": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmmirror.com/pinia-plugin-persistedstate/-/pinia-plugin-persistedstate-3.0.2.tgz",
+ "integrity": "sha512-84vPyUhPA/8Pr+1mT1ioNb2d8z4tvdgYRqMQf8xyauOVBKjo0ZcRBwPQBV7ZAJG43Kwar43nXG2jU+ZMvAFFRQ==",
+ "license": "MIT",
+ "peerDependencies": {
+ "pinia": "^2.0.0"
+ }
+ },
+ "node_modules/pinia/node_modules/vue-demi": {
+ "version": "0.13.11",
+ "resolved": "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.13.11.tgz",
+ "integrity": "sha512-IR8HoEEGM65YY3ZJYAjMlKygDQn25D5ajNFNoKh9RSDMQtlzCxtfQjdQgv9jjK+m3377SsJXY8ysq8kLCZL25A==",
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "vue-demi-fix": "bin/vue-demi-fix.js",
+ "vue-demi-switch": "bin/vue-demi-switch.js"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "@vue/composition-api": "^1.0.0-rc.1",
+ "vue": "^3.0.0-0 || ^2.6.0"
+ },
+ "peerDependenciesMeta": {
+ "@vue/composition-api": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/pkg-types": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/pkg-types/-/pkg-types-1.0.1.tgz",
+ "integrity": "sha512-jHv9HB+Ho7dj6ItwppRDDl0iZRYBD0jsakHXtFgoLr+cHSF6xC+QL54sJmWxyGxOLYSHm0afhXhXcQDQqH9z8g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "jsonc-parser": "^3.2.0",
+ "mlly": "^1.0.0",
+ "pathe": "^1.0.0"
+ }
+ },
+ "node_modules/postcss": {
+ "version": "8.4.21",
+ "resolved": "https://registry.npmmirror.com/postcss/-/postcss-8.4.21.tgz",
+ "integrity": "sha512-tP7u/Sn/dVxK2NnruI4H9BG+x+Wxz6oeZ1cJ8P6G/PZY0IKk4k/63TDsQf2kQq3+qoJeLm2kIBUNlZe3zgb4Zg==",
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/postcss"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "nanoid": "^3.3.4",
+ "picocolors": "^1.0.0",
+ "source-map-js": "^1.0.2"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ }
+ },
+ "node_modules/postcss-html": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmmirror.com/postcss-html/-/postcss-html-1.5.0.tgz",
+ "integrity": "sha512-kCMRWJRHKicpA166kc2lAVUGxDZL324bkj/pVOb6RhjB0Z5Krl7mN0AsVkBhVIRZZirY0lyQXG38HCVaoKVNoA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "htmlparser2": "^8.0.0",
+ "js-tokens": "^8.0.0",
+ "postcss": "^8.4.0",
+ "postcss-safe-parser": "^6.0.0"
+ },
+ "engines": {
+ "node": "^12 || >=14"
+ }
+ },
+ "node_modules/postcss-html/node_modules/js-tokens": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmmirror.com/js-tokens/-/js-tokens-8.0.1.tgz",
+ "integrity": "sha512-3AGrZT6tuMm1ZWWn9mLXh7XMfi2YtiLNPALCVxBCiUVq0LD1OQMxV/AdS/s7rLJU5o9i/jBZw/N4vXXL5dm29A==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/postcss-less": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmmirror.com/postcss-less/-/postcss-less-6.0.0.tgz",
+ "integrity": "sha512-FPX16mQLyEjLzEuuJtxA8X3ejDLNGGEG503d2YGZR5Ask1SpDN8KmZUMpzCvyalWRywAn1n1VOA5dcqfCLo5rg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=12"
+ },
+ "peerDependencies": {
+ "postcss": "^8.3.5"
+ }
+ },
+ "node_modules/postcss-media-query-parser": {
+ "version": "0.2.3",
+ "resolved": "https://registry.npmmirror.com/postcss-media-query-parser/-/postcss-media-query-parser-0.2.3.tgz",
+ "integrity": "sha512-3sOlxmbKcSHMjlUXQZKQ06jOswE7oVkXPxmZdoB1r5l0q6gTFTQSHxNxOrCccElbW7dxNytifNEo8qidX2Vsig==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/postcss-resolve-nested-selector": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmmirror.com/postcss-resolve-nested-selector/-/postcss-resolve-nested-selector-0.1.1.tgz",
+ "integrity": "sha512-HvExULSwLqHLgUy1rl3ANIqCsvMS0WHss2UOsXhXnQaZ9VCc2oBvIpXrl00IUFT5ZDITME0o6oiXeiHr2SAIfw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/postcss-safe-parser": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmmirror.com/postcss-safe-parser/-/postcss-safe-parser-6.0.0.tgz",
+ "integrity": "sha512-FARHN8pwH+WiS2OPCxJI8FuRJpTVnn6ZNFiqAM2aeW2LwTHWWmWgIyKC6cUo0L8aeKiF/14MNvnpls6R2PBeMQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=12.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ "peerDependencies": {
+ "postcss": "^8.3.3"
+ }
+ },
+ "node_modules/postcss-selector-parser": {
+ "version": "6.0.11",
+ "resolved": "https://registry.npmmirror.com/postcss-selector-parser/-/postcss-selector-parser-6.0.11.tgz",
+ "integrity": "sha512-zbARubNdogI9j7WY4nQJBiNqQf3sLS3wCP4WfOidu+p28LofJqDH1tcXypGrcmMHhDk2t9wGhCsYe/+szLTy1g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "cssesc": "^3.0.0",
+ "util-deprecate": "^1.0.2"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/postcss-sorting": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmmirror.com/postcss-sorting/-/postcss-sorting-8.0.1.tgz",
+ "integrity": "sha512-go9Zoxx7KQH+uLrJ9xa5wRErFeXu01ydA6O8m7koPXkmAN7Ts//eRcIqjo0stBR4+Nir2gMYDOWAOx7O5EPUZA==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "postcss": "^8.4.20"
+ }
+ },
+ "node_modules/postcss-value-parser": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmmirror.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz",
+ "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/prelude-ls": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmmirror.com/prelude-ls/-/prelude-ls-1.2.1.tgz",
+ "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/prettier": {
+ "version": "2.8.3",
+ "resolved": "https://registry.npmmirror.com/prettier/-/prettier-2.8.3.tgz",
+ "integrity": "sha512-tJ/oJ4amDihPoufT5sM0Z1SKEuKay8LfVAMlbbhnnkvt6BUserZylqo2PN+p9KeljLr0OHa2rXHU1T8reeoTrw==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "prettier": "bin-prettier.js"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ },
+ "funding": {
+ "url": "https://github.com/prettier/prettier?sponsor=1"
+ }
+ },
+ "node_modules/prettier-linter-helpers": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz",
+ "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "fast-diff": "^1.1.2"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/progress": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmmirror.com/progress/-/progress-2.0.3.tgz",
+ "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/proxy-from-env": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmmirror.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz",
+ "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==",
+ "license": "MIT"
+ },
+ "node_modules/prr": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/prr/-/prr-1.0.1.tgz",
+ "integrity": "sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true
+ },
+ "node_modules/punycode": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmmirror.com/punycode/-/punycode-2.3.0.tgz",
+ "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/qs": {
+ "version": "6.11.0",
+ "resolved": "https://registry.npmmirror.com/qs/-/qs-6.11.0.tgz",
+ "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==",
+ "license": "BSD-3-Clause",
+ "dependencies": {
+ "side-channel": "^1.0.4"
+ },
+ "engines": {
+ "node": ">=0.6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/queue-microtask": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmmirror.com/queue-microtask/-/queue-microtask-1.2.3.tgz",
+ "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ],
+ "license": "MIT"
+ },
+ "node_modules/quick-lru": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmmirror.com/quick-lru/-/quick-lru-4.0.1.tgz",
+ "integrity": "sha512-ARhCpm70fzdcvNQfPoy49IaanKkTlRWF2JMzqhcJbhSFRZv7nPTvZJdcY7301IPmvW+/p0RgIWnQDLJxifsQ7g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/randombytes": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/randombytes/-/randombytes-2.1.0.tgz",
+ "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "safe-buffer": "^5.1.0"
+ }
+ },
+ "node_modules/rd": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmmirror.com/rd/-/rd-2.0.1.tgz",
+ "integrity": "sha512-/XdKU4UazUZTXFmI0dpABt8jSXPWcEyaGdk340KdHnsEOdkTctlX23aAK7ChQDn39YGNlAJr1M5uvaKt4QnpNw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/node": "^10.3.6"
+ }
+ },
+ "node_modules/rd/node_modules/@types/node": {
+ "version": "10.17.60",
+ "resolved": "https://registry.npmmirror.com/@types/node/-/node-10.17.60.tgz",
+ "integrity": "sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/read-pkg": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmmirror.com/read-pkg/-/read-pkg-5.2.0.tgz",
+ "integrity": "sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/normalize-package-data": "^2.4.0",
+ "normalize-package-data": "^2.5.0",
+ "parse-json": "^5.0.0",
+ "type-fest": "^0.6.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/read-pkg-up": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmmirror.com/read-pkg-up/-/read-pkg-up-7.0.1.tgz",
+ "integrity": "sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "find-up": "^4.1.0",
+ "read-pkg": "^5.2.0",
+ "type-fest": "^0.8.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/read-pkg-up/node_modules/find-up": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmmirror.com/find-up/-/find-up-4.1.0.tgz",
+ "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "locate-path": "^5.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/read-pkg-up/node_modules/locate-path": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmmirror.com/locate-path/-/locate-path-5.0.0.tgz",
+ "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-locate": "^4.1.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/read-pkg-up/node_modules/p-limit": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmmirror.com/p-limit/-/p-limit-2.3.0.tgz",
+ "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-try": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/read-pkg-up/node_modules/p-locate": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmmirror.com/p-locate/-/p-locate-4.1.0.tgz",
+ "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-limit": "^2.2.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/read-pkg-up/node_modules/type-fest": {
+ "version": "0.8.1",
+ "resolved": "https://registry.npmmirror.com/type-fest/-/type-fest-0.8.1.tgz",
+ "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==",
+ "dev": true,
+ "license": "(MIT OR CC0-1.0)",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/read-pkg/node_modules/hosted-git-info": {
+ "version": "2.8.9",
+ "resolved": "https://registry.npmmirror.com/hosted-git-info/-/hosted-git-info-2.8.9.tgz",
+ "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/read-pkg/node_modules/normalize-package-data": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmmirror.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz",
+ "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "hosted-git-info": "^2.1.4",
+ "resolve": "^1.10.0",
+ "semver": "2 || 3 || 4 || 5",
+ "validate-npm-package-license": "^3.0.1"
+ }
+ },
+ "node_modules/read-pkg/node_modules/semver": {
+ "version": "5.7.1",
+ "resolved": "https://registry.npmmirror.com/semver/-/semver-5.7.1.tgz",
+ "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
+ "dev": true,
+ "license": "ISC",
+ "bin": {
+ "semver": "bin/semver"
+ }
+ },
+ "node_modules/read-pkg/node_modules/type-fest": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmmirror.com/type-fest/-/type-fest-0.6.0.tgz",
+ "integrity": "sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg==",
+ "dev": true,
+ "license": "(MIT OR CC0-1.0)",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/readdirp": {
+ "version": "3.6.0",
+ "resolved": "https://registry.npmmirror.com/readdirp/-/readdirp-3.6.0.tgz",
+ "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "picomatch": "^2.2.1"
+ },
+ "engines": {
+ "node": ">=8.10.0"
+ }
+ },
+ "node_modules/redent": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/redent/-/redent-3.0.0.tgz",
+ "integrity": "sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "indent-string": "^4.0.0",
+ "strip-indent": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/regenerator-runtime": {
+ "version": "0.13.11",
+ "resolved": "https://registry.npmmirror.com/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz",
+ "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==",
+ "license": "MIT"
+ },
+ "node_modules/regexpp": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmmirror.com/regexpp/-/regexpp-3.2.0.tgz",
+ "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mysticatea"
+ }
+ },
+ "node_modules/require-directory": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmmirror.com/require-directory/-/require-directory-2.1.1.tgz",
+ "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/require-from-string": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmmirror.com/require-from-string/-/require-from-string-2.0.2.tgz",
+ "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/resize-observer-polyfill": {
+ "version": "1.5.1",
+ "resolved": "https://registry.npmmirror.com/resize-observer-polyfill/-/resize-observer-polyfill-1.5.1.tgz",
+ "integrity": "sha512-LwZrotdHOo12nQuZlHEmtuXdqGoOD0OhaxopaNFxWzInpEgaLWoVuAMbTzixuosCx2nEG58ngzW3vxdWoxIgdg==",
+ "license": "MIT"
+ },
+ "node_modules/resolve": {
+ "version": "1.22.1",
+ "resolved": "https://registry.npmmirror.com/resolve/-/resolve-1.22.1.tgz",
+ "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-core-module": "^2.9.0",
+ "path-parse": "^1.0.7",
+ "supports-preserve-symlinks-flag": "^1.0.0"
+ },
+ "bin": {
+ "resolve": "bin/resolve"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/resolve-from": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/resolve-from/-/resolve-from-4.0.0.tgz",
+ "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/reusify": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmmirror.com/reusify/-/reusify-1.0.4.tgz",
+ "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "iojs": ">=1.0.0",
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/rimraf": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmmirror.com/rimraf/-/rimraf-3.0.2.tgz",
+ "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "glob": "^7.1.3"
+ },
+ "bin": {
+ "rimraf": "bin.js"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/rollup": {
+ "version": "3.20.7",
+ "resolved": "https://registry.npmmirror.com/rollup/-/rollup-3.20.7.tgz",
+ "integrity": "sha512-P7E2zezKSLhWnTz46XxjSmInrbOCiul1yf+kJccMxT56vxjHwCbDfoLbiqFgu+WQoo9ij2PkraYaBstgB2prBA==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "rollup": "dist/bin/rollup"
+ },
+ "engines": {
+ "node": ">=14.18.0",
+ "npm": ">=8.0.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/rollup-plugin-visualizer": {
+ "version": "5.9.0",
+ "resolved": "https://registry.npmmirror.com/rollup-plugin-visualizer/-/rollup-plugin-visualizer-5.9.0.tgz",
+ "integrity": "sha512-bbDOv47+Bw4C/cgs0czZqfm8L82xOZssk4ayZjG40y9zbXclNk7YikrZTDao6p7+HDiGxrN0b65SgZiVm9k1Cg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "open": "^8.4.0",
+ "picomatch": "^2.3.1",
+ "source-map": "^0.7.4",
+ "yargs": "^17.5.1"
+ },
+ "bin": {
+ "rollup-plugin-visualizer": "dist/bin/cli.js"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "peerDependencies": {
+ "rollup": "2.x || 3.x"
+ },
+ "peerDependenciesMeta": {
+ "rollup": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/rollup-plugin-visualizer/node_modules/source-map": {
+ "version": "0.7.4",
+ "resolved": "https://registry.npmmirror.com/source-map/-/source-map-0.7.4.tgz",
+ "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/run-parallel": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmmirror.com/run-parallel/-/run-parallel-1.2.0.tgz",
+ "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "queue-microtask": "^1.2.2"
+ }
+ },
+ "node_modules/safe-buffer": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmmirror.com/safe-buffer/-/safe-buffer-5.2.1.tgz",
+ "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ],
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/safer-buffer": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmmirror.com/safer-buffer/-/safer-buffer-2.1.2.tgz",
+ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==",
+ "dev": true,
+ "license": "MIT",
+ "optional": true
+ },
+ "node_modules/sax": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmmirror.com/sax/-/sax-1.2.4.tgz",
+ "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==",
+ "dev": true,
+ "license": "ISC",
+ "optional": true
+ },
+ "node_modules/schema-utils": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmmirror.com/schema-utils/-/schema-utils-3.1.2.tgz",
+ "integrity": "sha512-pvjEHOgWc9OWA/f/DE3ohBWTD6EleVLf7iFUkoSwAxttdBhB9QUebQgxER2kWueOvRJXPHNnyrvvh9eZINB8Eg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@types/json-schema": "^7.0.8",
+ "ajv": "^6.12.5",
+ "ajv-keywords": "^3.5.2"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ }
+ },
+ "node_modules/scroll-into-view-if-needed": {
+ "version": "2.2.31",
+ "resolved": "https://registry.npmmirror.com/scroll-into-view-if-needed/-/scroll-into-view-if-needed-2.2.31.tgz",
+ "integrity": "sha512-dGCXy99wZQivjmjIqihaBQNjryrz5rueJY7eHfTdyWEiR4ttYpsajb14rn9s5d4DY4EcY6+4+U/maARBXJedkA==",
+ "license": "MIT",
+ "dependencies": {
+ "compute-scroll-into-view": "^1.0.20"
+ }
+ },
+ "node_modules/scule": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/scule/-/scule-1.0.0.tgz",
+ "integrity": "sha512-4AsO/FrViE/iDNEPaAQlb77tf0csuq27EsVpy6ett584EcRTp6pTDLoGWVxCD77y5iU5FauOvhsI4o1APwPoSQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/semver": {
+ "version": "7.3.8",
+ "resolved": "https://registry.npmmirror.com/semver/-/semver-7.3.8.tgz",
+ "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "lru-cache": "^6.0.0"
+ },
+ "bin": {
+ "semver": "bin/semver.js"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/semver/node_modules/lru-cache": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmmirror.com/lru-cache/-/lru-cache-6.0.0.tgz",
+ "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/semver/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/serialize-javascript": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmmirror.com/serialize-javascript/-/serialize-javascript-6.0.1.tgz",
+ "integrity": "sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "peer": true,
+ "dependencies": {
+ "randombytes": "^2.1.0"
+ }
+ },
+ "node_modules/shallow-equal": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmmirror.com/shallow-equal/-/shallow-equal-1.2.1.tgz",
+ "integrity": "sha512-S4vJDjHHMBaiZuT9NPb616CSmLf618jawtv3sufLl6ivK8WocjAo58cXwbRV1cgqxH0Qbv+iUt6m05eqEa2IRA==",
+ "license": "MIT"
+ },
+ "node_modules/shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "shebang-regex": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/side-channel": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmmirror.com/side-channel/-/side-channel-1.0.4.tgz",
+ "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==",
+ "license": "MIT",
+ "dependencies": {
+ "call-bind": "^1.0.0",
+ "get-intrinsic": "^1.0.2",
+ "object-inspect": "^1.9.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/signal-exit": {
+ "version": "3.0.7",
+ "resolved": "https://registry.npmmirror.com/signal-exit/-/signal-exit-3.0.7.tgz",
+ "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/slice-ansi": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/slice-ansi/-/slice-ansi-4.0.0.tgz",
+ "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ansi-styles": "^4.0.0",
+ "astral-regex": "^2.0.0",
+ "is-fullwidth-code-point": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/slice-ansi?sponsor=1"
+ }
+ },
+ "node_modules/slice-ansi/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/slice-ansi/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/slice-ansi/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmmirror.com/source-map-js/-/source-map-js-1.0.2.tgz",
+ "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-support": {
+ "version": "0.5.21",
+ "resolved": "https://registry.npmmirror.com/source-map-support/-/source-map-support-0.5.21.tgz",
+ "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "buffer-from": "^1.0.0",
+ "source-map": "^0.6.0"
+ }
+ },
+ "node_modules/sourcemap-codec": {
+ "version": "1.4.8",
+ "resolved": "https://registry.npmmirror.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz",
+ "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==",
+ "license": "MIT"
+ },
+ "node_modules/spdx-correct": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmmirror.com/spdx-correct/-/spdx-correct-3.1.1.tgz",
+ "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "spdx-expression-parse": "^3.0.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "node_modules/spdx-exceptions": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmmirror.com/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz",
+ "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==",
+ "dev": true,
+ "license": "CC-BY-3.0"
+ },
+ "node_modules/spdx-expression-parse": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmmirror.com/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz",
+ "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "spdx-exceptions": "^2.1.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "node_modules/spdx-license-ids": {
+ "version": "3.0.12",
+ "resolved": "https://registry.npmmirror.com/spdx-license-ids/-/spdx-license-ids-3.0.12.tgz",
+ "integrity": "sha512-rr+VVSXtRhO4OHbXUiAF7xW3Bo9DuuF6C5jH+q/x15j2jniycgKbxU09Hr0WqlSLUs4i4ltHGXqTe7VHclYWyA==",
+ "dev": true,
+ "license": "CC0-1.0"
+ },
+ "node_modules/string-width": {
+ "version": "4.2.3",
+ "resolved": "https://registry.npmmirror.com/string-width/-/string-width-4.2.3.tgz",
+ "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-ansi": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmmirror.com/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ansi-regex": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-indent": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmmirror.com/strip-indent/-/strip-indent-3.0.0.tgz",
+ "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "min-indent": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-json-comments": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmmirror.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
+ "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/strip-literal": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/strip-literal/-/strip-literal-1.0.0.tgz",
+ "integrity": "sha512-5o4LsH1lzBzO9UFH63AJ2ad2/S2AVx6NtjOcaz+VTT2h1RiRvbipW72z8M/lxEhcPHDBQwpDrnTF7sXy/7OwCQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "acorn": "^8.8.1"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/style-search": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmmirror.com/style-search/-/style-search-0.1.0.tgz",
+ "integrity": "sha512-Dj1Okke1C3uKKwQcetra4jSuk0DqbzbYtXipzFlFMZtowbF1x7BKJwB9AayVMyFARvU8EDrZdcax4At/452cAg==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/stylelint": {
+ "version": "14.16.1",
+ "resolved": "https://registry.npmmirror.com/stylelint/-/stylelint-14.16.1.tgz",
+ "integrity": "sha512-ErlzR/T3hhbV+a925/gbfc3f3Fep9/bnspMiJPorfGEmcBbXdS+oo6LrVtoUZ/w9fqD6o6k7PtUlCOsCRdjX/A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@csstools/selector-specificity": "^2.0.2",
+ "balanced-match": "^2.0.0",
+ "colord": "^2.9.3",
+ "cosmiconfig": "^7.1.0",
+ "css-functions-list": "^3.1.0",
+ "debug": "^4.3.4",
+ "fast-glob": "^3.2.12",
+ "fastest-levenshtein": "^1.0.16",
+ "file-entry-cache": "^6.0.1",
+ "global-modules": "^2.0.0",
+ "globby": "^11.1.0",
+ "globjoin": "^0.1.4",
+ "html-tags": "^3.2.0",
+ "ignore": "^5.2.1",
+ "import-lazy": "^4.0.0",
+ "imurmurhash": "^0.1.4",
+ "is-plain-object": "^5.0.0",
+ "known-css-properties": "^0.26.0",
+ "mathml-tag-names": "^2.1.3",
+ "meow": "^9.0.0",
+ "micromatch": "^4.0.5",
+ "normalize-path": "^3.0.0",
+ "picocolors": "^1.0.0",
+ "postcss": "^8.4.19",
+ "postcss-media-query-parser": "^0.2.3",
+ "postcss-resolve-nested-selector": "^0.1.1",
+ "postcss-safe-parser": "^6.0.0",
+ "postcss-selector-parser": "^6.0.11",
+ "postcss-value-parser": "^4.2.0",
+ "resolve-from": "^5.0.0",
+ "string-width": "^4.2.3",
+ "strip-ansi": "^6.0.1",
+ "style-search": "^0.1.0",
+ "supports-hyperlinks": "^2.3.0",
+ "svg-tags": "^1.0.0",
+ "table": "^6.8.1",
+ "v8-compile-cache": "^2.3.0",
+ "write-file-atomic": "^4.0.2"
+ },
+ "bin": {
+ "stylelint": "bin/stylelint.js"
+ },
+ "engines": {
+ "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/stylelint"
+ }
+ },
+ "node_modules/stylelint-config-recommended": {
+ "version": "9.0.0",
+ "resolved": "https://registry.npmmirror.com/stylelint-config-recommended/-/stylelint-config-recommended-9.0.0.tgz",
+ "integrity": "sha512-9YQSrJq4NvvRuTbzDsWX3rrFOzOlYBmZP+o513BJN/yfEmGSr0AxdvrWs0P/ilSpVV/wisamAHu5XSk8Rcf4CQ==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "stylelint": "^14.10.0"
+ }
+ },
+ "node_modules/stylelint-config-standard": {
+ "version": "29.0.0",
+ "resolved": "https://registry.npmmirror.com/stylelint-config-standard/-/stylelint-config-standard-29.0.0.tgz",
+ "integrity": "sha512-uy8tZLbfq6ZrXy4JKu3W+7lYLgRQBxYTUUB88vPgQ+ZzAxdrvcaSUW9hOMNLYBnwH+9Kkj19M2DHdZ4gKwI7tg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "stylelint-config-recommended": "^9.0.0"
+ },
+ "peerDependencies": {
+ "stylelint": "^14.14.0"
+ }
+ },
+ "node_modules/stylelint-order": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmmirror.com/stylelint-order/-/stylelint-order-6.0.1.tgz",
+ "integrity": "sha512-C9gJDZArRBZvn+4MPgggwYTp7dK49WPnYa5+6tBEkZnW/YWj4xBVNJdQjIik14w5orlF9RqFpYDHN0FPWIFOSQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "postcss": "^8.4.20",
+ "postcss-sorting": "^8.0.1"
+ },
+ "peerDependencies": {
+ "stylelint": "^14.0.0"
+ }
+ },
+ "node_modules/stylelint/node_modules/balanced-match": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/balanced-match/-/balanced-match-2.0.0.tgz",
+ "integrity": "sha512-1ugUSr8BHXRnK23KfuYS+gVMC3LB8QGH9W1iGtDPsNWoQbgtXSExkBu2aDR4epiGWZOjZsj6lDl/N/AqqTC3UA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/stylelint/node_modules/resolve-from": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmmirror.com/resolve-from/-/resolve-from-5.0.0.tgz",
+ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/supports-color": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmmirror.com/supports-color/-/supports-color-5.5.0.tgz",
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "has-flag": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/supports-hyperlinks": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmmirror.com/supports-hyperlinks/-/supports-hyperlinks-2.3.0.tgz",
+ "integrity": "sha512-RpsAZlpWcDwOPQA22aCH4J0t7L8JmAvsCxfOSEwm7cQs3LshN36QaTkwd70DnBOXDWGssw2eUoc8CaRWT0XunA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "has-flag": "^4.0.0",
+ "supports-color": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/supports-hyperlinks/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/supports-hyperlinks/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/supports-preserve-symlinks-flag": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
+ "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/svg-tags": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/svg-tags/-/svg-tags-1.0.0.tgz",
+ "integrity": "sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==",
+ "dev": true
+ },
+ "node_modules/table": {
+ "version": "6.8.1",
+ "resolved": "https://registry.npmmirror.com/table/-/table-6.8.1.tgz",
+ "integrity": "sha512-Y4X9zqrCftUhMeH2EptSSERdVKt/nEdijTOacGD/97EKjhQ/Qs8RTlEGABSJNNN8lac9kheH+af7yAkEWlgneA==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "dependencies": {
+ "ajv": "^8.0.1",
+ "lodash.truncate": "^4.4.2",
+ "slice-ansi": "^4.0.0",
+ "string-width": "^4.2.3",
+ "strip-ansi": "^6.0.1"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/table/node_modules/ajv": {
+ "version": "8.12.0",
+ "resolved": "https://registry.npmmirror.com/ajv/-/ajv-8.12.0.tgz",
+ "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "json-schema-traverse": "^1.0.0",
+ "require-from-string": "^2.0.2",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/table/node_modules/json-schema-traverse": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmmirror.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz",
+ "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/tapable": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmmirror.com/tapable/-/tapable-2.2.1.tgz",
+ "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/terser": {
+ "version": "5.17.1",
+ "resolved": "https://registry.npmmirror.com/terser/-/terser-5.17.1.tgz",
+ "integrity": "sha512-hVl35zClmpisy6oaoKALOpS0rDYLxRFLHhRuDlEGTKey9qHjS1w9GMORjuwIMt70Wan4lwsLYyWDVnWgF+KUEw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "peer": true,
+ "dependencies": {
+ "@jridgewell/source-map": "^0.3.2",
+ "acorn": "^8.5.0",
+ "commander": "^2.20.0",
+ "source-map-support": "~0.5.20"
+ },
+ "bin": {
+ "terser": "bin/terser"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/terser-webpack-plugin": {
+ "version": "5.3.7",
+ "resolved": "https://registry.npmmirror.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.7.tgz",
+ "integrity": "sha512-AfKwIktyP7Cu50xNjXF/6Qb5lBNzYaWpU6YfoX3uZicTx0zTy0stDDCsvjDapKsSDvOeWo5MEq4TmdBy2cNoHw==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@jridgewell/trace-mapping": "^0.3.17",
+ "jest-worker": "^27.4.5",
+ "schema-utils": "^3.1.1",
+ "serialize-javascript": "^6.0.1",
+ "terser": "^5.16.5"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^5.1.0"
+ },
+ "peerDependenciesMeta": {
+ "@swc/core": {
+ "optional": true
+ },
+ "esbuild": {
+ "optional": true
+ },
+ "uglify-js": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/text-table": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmmirror.com/text-table/-/text-table-0.2.0.tgz",
+ "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/to-fast-properties": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
+ "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/to-regex-range": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmmirror.com/to-regex-range/-/to-regex-range-5.0.1.tgz",
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-number": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=8.0"
+ }
+ },
+ "node_modules/trim-newlines": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmmirror.com/trim-newlines/-/trim-newlines-3.0.1.tgz",
+ "integrity": "sha512-c1PTsA3tYrIsLGkJkzHF+w9F2EyxfXGo4UyJc4pFL++FMjnq0HJS69T3M7d//gKrFKwy429bouPescbjecU+Zw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/tslib": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmmirror.com/tslib/-/tslib-2.5.0.tgz",
+ "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==",
+ "dev": true,
+ "license": "0BSD"
+ },
+ "node_modules/tsutils": {
+ "version": "3.21.0",
+ "resolved": "https://registry.npmmirror.com/tsutils/-/tsutils-3.21.0.tgz",
+ "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "tslib": "^1.8.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ },
+ "peerDependencies": {
+ "typescript": ">=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta"
+ }
+ },
+ "node_modules/tsutils/node_modules/tslib": {
+ "version": "1.14.1",
+ "resolved": "https://registry.npmmirror.com/tslib/-/tslib-1.14.1.tgz",
+ "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==",
+ "dev": true,
+ "license": "0BSD"
+ },
+ "node_modules/type-check": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmmirror.com/type-check/-/type-check-0.4.0.tgz",
+ "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "prelude-ls": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/type-fest": {
+ "version": "0.18.1",
+ "resolved": "https://registry.npmmirror.com/type-fest/-/type-fest-0.18.1.tgz",
+ "integrity": "sha512-OIAYXk8+ISY+qTOwkHtKqzAuxchoMiD9Udx+FSGQDuiRR+PJKJHc2NJAXlbhkGwTt/4/nKZxELY1w3ReWOL8mw==",
+ "dev": true,
+ "license": "(MIT OR CC0-1.0)",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/typescript": {
+ "version": "4.9.4",
+ "resolved": "https://registry.npmmirror.com/typescript/-/typescript-4.9.4.tgz",
+ "integrity": "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==",
+ "devOptional": true,
+ "license": "Apache-2.0",
+ "bin": {
+ "tsc": "bin/tsc",
+ "tsserver": "bin/tsserver"
+ },
+ "engines": {
+ "node": ">=4.2.0"
+ }
+ },
+ "node_modules/ufo": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/ufo/-/ufo-1.0.1.tgz",
+ "integrity": "sha512-boAm74ubXHY7KJQZLlXrtMz52qFvpsbOxDcZOnw/Wf+LS4Mmyu7JxmzD4tDLtUQtmZECypJ0FrCz4QIe6dvKRA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/undici-types": {
+ "version": "6.19.8",
+ "resolved": "https://registry.npmmirror.com/undici-types/-/undici-types-6.19.8.tgz",
+ "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/unimport": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmmirror.com/unimport/-/unimport-2.1.0.tgz",
+ "integrity": "sha512-GDVIxATluUquX8EqelT6DtnmnZaXGID1jsO9IXwlnxb0OIEqKAxTOnTlnGmHbseoGTh+ZC9kcNDaO18HYQj9KA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@rollup/pluginutils": "^5.0.2",
+ "escape-string-regexp": "^5.0.0",
+ "fast-glob": "^3.2.12",
+ "local-pkg": "^0.4.3",
+ "magic-string": "^0.27.0",
+ "mlly": "^1.1.0",
+ "pathe": "^1.1.0",
+ "pkg-types": "^1.0.1",
+ "scule": "^1.0.0",
+ "strip-literal": "^1.0.0",
+ "unplugin": "^1.0.1"
+ }
+ },
+ "node_modules/unimport/node_modules/escape-string-regexp": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz",
+ "integrity": "sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/universalify": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmmirror.com/universalify/-/universalify-2.0.0.tgz",
+ "integrity": "sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 10.0.0"
+ }
+ },
+ "node_modules/unplugin": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmmirror.com/unplugin/-/unplugin-1.0.1.tgz",
+ "integrity": "sha512-aqrHaVBWW1JVKBHmGo33T5TxeL0qWzfvjWokObHA9bYmN7eNDkwOxmLjhioHl9878qDFMAaT51XNroRyuz7WxA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "acorn": "^8.8.1",
+ "chokidar": "^3.5.3",
+ "webpack-sources": "^3.2.3",
+ "webpack-virtual-modules": "^0.5.0"
+ }
+ },
+ "node_modules/unplugin-auto-import": {
+ "version": "0.12.2",
+ "resolved": "https://registry.npmmirror.com/unplugin-auto-import/-/unplugin-auto-import-0.12.2.tgz",
+ "integrity": "sha512-hC4w0GZjPjmLtrxV0u10XO350V9eCtQyEyifXr7B9UGD7SvbbIvKuOcHt58Zd4FAqZJXKWoXkpr9mdhBp85Usw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@antfu/utils": "^0.7.2",
+ "@rollup/pluginutils": "^5.0.2",
+ "local-pkg": "^0.4.3",
+ "magic-string": "^0.27.0",
+ "unimport": "^2.0.1",
+ "unplugin": "^1.0.1"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "@vueuse/core": "*"
+ },
+ "peerDependenciesMeta": {
+ "@vueuse/core": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/update-browserslist-db": {
+ "version": "1.0.10",
+ "resolved": "https://registry.npmmirror.com/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz",
+ "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "escalade": "^3.1.1",
+ "picocolors": "^1.0.0"
+ },
+ "bin": {
+ "browserslist-lint": "cli.js"
+ },
+ "peerDependencies": {
+ "browserslist": ">= 4.21.0"
+ }
+ },
+ "node_modules/uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmmirror.com/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "node_modules/util-deprecate": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmmirror.com/util-deprecate/-/util-deprecate-1.0.2.tgz",
+ "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/v8-compile-cache": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmmirror.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz",
+ "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/validate-npm-package-license": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmmirror.com/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
+ "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "spdx-correct": "^3.0.0",
+ "spdx-expression-parse": "^3.0.0"
+ }
+ },
+ "node_modules/vite": {
+ "version": "4.0.4",
+ "resolved": "https://registry.npmmirror.com/vite/-/vite-4.0.4.tgz",
+ "integrity": "sha512-xevPU7M8FU0i/80DMR+YhgrzR5KS2ORy1B4xcX/cXLsvnUWvfHuqMmVU6N0YiJ4JWGRJJsLCgjEzKjG9/GKoSw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "esbuild": "^0.16.3",
+ "postcss": "^8.4.20",
+ "resolve": "^1.22.1",
+ "rollup": "^3.7.0"
+ },
+ "bin": {
+ "vite": "bin/vite.js"
+ },
+ "engines": {
+ "node": "^14.18.0 || >=16.0.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ },
+ "peerDependencies": {
+ "@types/node": ">= 14",
+ "less": "*",
+ "sass": "*",
+ "stylus": "*",
+ "sugarss": "*",
+ "terser": "^5.4.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/node": {
+ "optional": true
+ },
+ "less": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "stylus": {
+ "optional": true
+ },
+ "sugarss": {
+ "optional": true
+ },
+ "terser": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/vite-plugin-compression": {
+ "version": "0.5.1",
+ "resolved": "https://registry.npmmirror.com/vite-plugin-compression/-/vite-plugin-compression-0.5.1.tgz",
+ "integrity": "sha512-5QJKBDc+gNYVqL/skgFAP81Yuzo9R+EAf19d+EtsMF/i8kFUpNi3J/H01QD3Oo8zBQn+NzoCIFkpPLynoOzaJg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "chalk": "^4.1.2",
+ "debug": "^4.3.3",
+ "fs-extra": "^10.0.0"
+ },
+ "peerDependencies": {
+ "vite": ">=2.0.0"
+ }
+ },
+ "node_modules/vite-plugin-compression/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/vite-plugin-compression/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/vite-plugin-compression/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/vite-plugin-compression/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/vite-plugin-compression/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/vite-plugin-compression/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/vite-plugin-progress": {
+ "version": "0.0.6",
+ "resolved": "https://registry.npmmirror.com/vite-plugin-progress/-/vite-plugin-progress-0.0.6.tgz",
+ "integrity": "sha512-pIK2TVEY4XFGrz10CQDdEufBBCDaV0geRHfXV3abGTBr+OF9O0Zmd3ZDrHJXDv4Rl3qAQP4BTCuPYQ3XqstmqA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "picocolors": "^1.0.0",
+ "progress": "^2.0.3",
+ "rd": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=14",
+ "pnpm": ">=7.0.0"
+ },
+ "peerDependencies": {
+ "vite": ">2.0.0-0"
+ }
+ },
+ "node_modules/vite-plugin-restart": {
+ "version": "0.3.1",
+ "resolved": "https://registry.npmmirror.com/vite-plugin-restart/-/vite-plugin-restart-0.3.1.tgz",
+ "integrity": "sha512-LVe74MLUwaOzXVUgRGiphYbAYNgdGF6mP5vxj5BKcKkdmzvuuw79qcNgn9kHKKaIlCCjmOUiY3qlJ8jBSBUCoA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "micromatch": "^4.0.5"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "vite": "^2.9.0 || ^3.0.0 || ^4.0.0"
+ }
+ },
+ "node_modules/vue": {
+ "version": "3.2.45",
+ "resolved": "https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz",
+ "integrity": "sha512-9Nx/Mg2b2xWlXykmCwiTUCWHbWIj53bnkizBxKai1g61f2Xit700A1ljowpTIM11e3uipOeiPcSqnmBg6gyiaA==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/compiler-dom": "3.2.45",
+ "@vue/compiler-sfc": "3.2.45",
+ "@vue/runtime-dom": "3.2.45",
+ "@vue/server-renderer": "3.2.45",
+ "@vue/shared": "3.2.45"
+ }
+ },
+ "node_modules/vue-eslint-parser": {
+ "version": "9.1.0",
+ "resolved": "https://registry.npmmirror.com/vue-eslint-parser/-/vue-eslint-parser-9.1.0.tgz",
+ "integrity": "sha512-NGn/iQy8/Wb7RrRa4aRkokyCZfOUWk19OP5HP6JEozQFX5AoS/t+Z0ZN7FY4LlmWc4FNI922V7cvX28zctN8dQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "debug": "^4.3.4",
+ "eslint-scope": "^7.1.1",
+ "eslint-visitor-keys": "^3.3.0",
+ "espree": "^9.3.1",
+ "esquery": "^1.4.0",
+ "lodash": "^4.17.21",
+ "semver": "^7.3.6"
+ },
+ "engines": {
+ "node": "^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mysticatea"
+ },
+ "peerDependencies": {
+ "eslint": ">=6.0.0"
+ }
+ },
+ "node_modules/vue-eslint-parser/node_modules/eslint-scope": {
+ "version": "7.1.1",
+ "resolved": "https://registry.npmmirror.com/eslint-scope/-/eslint-scope-7.1.1.tgz",
+ "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/vue-eslint-parser/node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmmirror.com/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/vue-router": {
+ "version": "4.1.6",
+ "resolved": "https://registry.npmmirror.com/vue-router/-/vue-router-4.1.6.tgz",
+ "integrity": "sha512-DYWYwsG6xNPmLq/FmZn8Ip+qrhFEzA14EI12MsMgVxvHFDYvlr4NXpVF5hrRH1wVcDP8fGi5F4rxuJSl8/r+EQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@vue/devtools-api": "^6.4.5"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/posva"
+ },
+ "peerDependencies": {
+ "vue": "^3.2.0"
+ }
+ },
+ "node_modules/vue-types": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmmirror.com/vue-types/-/vue-types-3.0.2.tgz",
+ "integrity": "sha512-IwUC0Aq2zwaXqy74h4WCvFCUtoV0iSWr0snWnE9TnU18S66GAQyqQbRf2qfJtUuiFsBf6qp0MEwdonlwznlcrw==",
+ "license": "MIT",
+ "dependencies": {
+ "is-plain-object": "3.0.1"
+ },
+ "engines": {
+ "node": ">=10.15.0"
+ },
+ "peerDependencies": {
+ "vue": "^3.0.0"
+ }
+ },
+ "node_modules/vue-types/node_modules/is-plain-object": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmmirror.com/is-plain-object/-/is-plain-object-3.0.1.tgz",
+ "integrity": "sha512-Xnpx182SBMrr/aBik8y+GuR4U1L9FqMSojwDQwPMmxyC6bvEqly9UBCxhauBF5vNh2gwWJNX6oDV7O+OM4z34g==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/warning": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmmirror.com/warning/-/warning-4.0.3.tgz",
+ "integrity": "sha512-rpJyN222KWIvHJ/F53XSZv0Zl/accqHR8et1kpaMTD/fLCRxtV8iX8czMzY7sVZupTI3zcUTg8eycS2kNF9l6w==",
+ "license": "MIT",
+ "dependencies": {
+ "loose-envify": "^1.0.0"
+ }
+ },
+ "node_modules/watchpack": {
+ "version": "2.4.0",
+ "resolved": "https://registry.npmmirror.com/watchpack/-/watchpack-2.4.0.tgz",
+ "integrity": "sha512-Lcvm7MGST/4fup+ifyKi2hjyIAwcdI4HRgtvTpIUxBRhB+RFtUh8XtDOxUfctVCnhVi+QQj49i91OyvzkJl6cg==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "glob-to-regexp": "^0.4.1",
+ "graceful-fs": "^4.1.2"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/webpack": {
+ "version": "5.80.0",
+ "resolved": "https://registry.npmmirror.com/webpack/-/webpack-5.80.0.tgz",
+ "integrity": "sha512-OIMiq37XK1rWO8mH9ssfFKZsXg4n6klTEDL7S8/HqbAOBBaiy8ABvXvz0dDCXeEF9gqwxSvVk611zFPjS8hJxA==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@types/eslint-scope": "^3.7.3",
+ "@types/estree": "^1.0.0",
+ "@webassemblyjs/ast": "^1.11.5",
+ "@webassemblyjs/wasm-edit": "^1.11.5",
+ "@webassemblyjs/wasm-parser": "^1.11.5",
+ "acorn": "^8.7.1",
+ "acorn-import-assertions": "^1.7.6",
+ "browserslist": "^4.14.5",
+ "chrome-trace-event": "^1.0.2",
+ "enhanced-resolve": "^5.13.0",
+ "es-module-lexer": "^1.2.1",
+ "eslint-scope": "5.1.1",
+ "events": "^3.2.0",
+ "glob-to-regexp": "^0.4.1",
+ "graceful-fs": "^4.2.9",
+ "json-parse-even-better-errors": "^2.3.1",
+ "loader-runner": "^4.2.0",
+ "mime-types": "^2.1.27",
+ "neo-async": "^2.6.2",
+ "schema-utils": "^3.1.2",
+ "tapable": "^2.1.1",
+ "terser-webpack-plugin": "^5.3.7",
+ "watchpack": "^2.4.0",
+ "webpack-sources": "^3.2.3"
+ },
+ "bin": {
+ "webpack": "bin/webpack.js"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependenciesMeta": {
+ "webpack-cli": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/webpack-sources": {
+ "version": "3.2.3",
+ "resolved": "https://registry.npmmirror.com/webpack-sources/-/webpack-sources-3.2.3.tgz",
+ "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/webpack-virtual-modules": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.5.0.tgz",
+ "integrity": "sha512-kyDivFZ7ZM0BVOUteVbDFhlRt7Ah/CSPwJdi8hBpkK7QLumUqdLtVfm/PX/hkcnrvr0i77fO5+TjZ94Pe+C9iw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmmirror.com/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/node-which"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/word-wrap": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmmirror.com/word-wrap/-/word-wrap-1.2.3.tgz",
+ "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/wrap-ansi": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmmirror.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
+ "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ansi-styles": "^4.0.0",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/wrappy": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmmirror.com/wrappy/-/wrappy-1.0.2.tgz",
+ "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/write-file-atomic": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmmirror.com/write-file-atomic/-/write-file-atomic-4.0.2.tgz",
+ "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "imurmurhash": "^0.1.4",
+ "signal-exit": "^3.0.7"
+ },
+ "engines": {
+ "node": "^12.13.0 || ^14.15.0 || >=16.0.0"
+ }
+ },
+ "node_modules/xml-name-validator": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmmirror.com/xml-name-validator/-/xml-name-validator-4.0.0.tgz",
+ "integrity": "sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/y18n": {
+ "version": "5.0.8",
+ "resolved": "https://registry.npmmirror.com/y18n/-/y18n-5.0.8.tgz",
+ "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
+ "dev": true,
+ "license": "ISC",
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/yallist": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmmirror.com/yallist/-/yallist-3.1.1.tgz",
+ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/yaml": {
+ "version": "1.10.2",
+ "resolved": "https://registry.npmmirror.com/yaml/-/yaml-1.10.2.tgz",
+ "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==",
+ "dev": true,
+ "license": "ISC",
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/yargs": {
+ "version": "17.6.2",
+ "resolved": "https://registry.npmmirror.com/yargs/-/yargs-17.6.2.tgz",
+ "integrity": "sha512-1/9UrdHjDZc0eOU0HxOHoS78C69UD3JRMvzlJ7S79S2nTaWRA/whGCTV8o9e/N/1Va9YIV7Q4sOxD8VV4pCWOw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "cliui": "^8.0.1",
+ "escalade": "^3.1.1",
+ "get-caller-file": "^2.0.5",
+ "require-directory": "^2.1.1",
+ "string-width": "^4.2.3",
+ "y18n": "^5.0.5",
+ "yargs-parser": "^21.1.1"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/yargs-parser": {
+ "version": "20.2.9",
+ "resolved": "https://registry.npmmirror.com/yargs-parser/-/yargs-parser-20.2.9.tgz",
+ "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==",
+ "dev": true,
+ "license": "ISC",
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/yargs/node_modules/yargs-parser": {
+ "version": "21.1.1",
+ "resolved": "https://registry.npmmirror.com/yargs-parser/-/yargs-parser-21.1.1.tgz",
+ "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==",
+ "dev": true,
+ "license": "ISC",
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/yocto-queue": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmmirror.com/yocto-queue/-/yocto-queue-0.1.0.tgz",
+ "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ }
+ }
+}
diff --git a/model/web/package.json b/model/web/package.json
new file mode 100644
index 0000000..6fdf825
--- /dev/null
+++ b/model/web/package.json
@@ -0,0 +1,51 @@
+{
+ "name": "my-web-app",
+ "version": "0.1.2",
+ "author": "lengqin1024",
+ "scripts": {
+ "dev": "vite --mode development",
+ "build": "vite build",
+ "preview": "vite preview"
+ },
+ "dependencies": {
+ "@ant-design/icons-vue": "^6.1.0",
+ "@vueuse/components": "^9.10.0",
+ "@vueuse/core": "^9.10.0",
+ "ant-design-vue": "^3.2.20",
+ "axios": "^1.2.2",
+ "pinia": "^2.0.28",
+ "pinia-plugin-persistedstate": "^3.0.2",
+ "qs": "^6.11.0",
+ "vue": "^3.2.45",
+ "vue-router": "^4.1.6"
+ },
+ "devDependencies": {
+ "@types/qs": "^6.9.7",
+ "@typescript-eslint/eslint-plugin": "^5.48.0",
+ "@typescript-eslint/parser": "^5.48.0",
+ "@vitejs/plugin-vue": "^4.0.0",
+ "@vitejs/plugin-vue-jsx": "^3.0.0",
+ "autoprefixer": "^10.4.13",
+ "eslint": "8.22.0",
+ "eslint-config-prettier": "^8.6.0",
+ "eslint-define-config": "^1.13.0",
+ "eslint-plugin-prettier": "^4.2.1",
+ "eslint-plugin-vue": "^9.8.0",
+ "less": "^4.1.3",
+ "less-loader": "^11.1.0",
+ "postcss": "^8.4.21",
+ "postcss-html": "^1.5.0",
+ "postcss-less": "^6.0.0",
+ "prettier": "^2.8.3",
+ "rollup-plugin-visualizer": "^5.9.0",
+ "stylelint": "^14.16.1",
+ "stylelint-config-standard": "^29.0.0",
+ "stylelint-order": "^6.0.1",
+ "typescript": "4.9.4",
+ "unplugin-auto-import": "^0.12.2",
+ "vite": "^4.0.3",
+ "vite-plugin-compression": "^0.5.1",
+ "vite-plugin-progress": "^0.0.6",
+ "vite-plugin-restart": "^0.3.1"
+ }
+}
diff --git a/model/web/postcss.config.js b/model/web/postcss.config.js
new file mode 100644
index 0000000..a47ef4f
--- /dev/null
+++ b/model/web/postcss.config.js
@@ -0,0 +1,5 @@
+module.exports = {
+ plugins: {
+ autoprefixer: {},
+ },
+};
diff --git a/model/web/prettier.config.js b/model/web/prettier.config.js
new file mode 100644
index 0000000..c5cf471
--- /dev/null
+++ b/model/web/prettier.config.js
@@ -0,0 +1,10 @@
+module.exports = {
+ printWidth: 140,
+ semi: true,
+ vueIndentScriptAndStyle: true,
+ singleQuote: true,
+ trailingComma: 'all',
+ proseWrap: 'never',
+ htmlWhitespaceSensitivity: 'strict',
+ endOfLine: 'auto',
+};
diff --git a/model/web/public/favicon.ico b/model/web/public/favicon.ico
new file mode 100644
index 0000000..4664362
Binary files /dev/null and b/model/web/public/favicon.ico differ
diff --git a/model/web/public/images/admin-login-bg.jpg b/model/web/public/images/admin-login-bg.jpg
new file mode 100644
index 0000000..e210712
Binary files /dev/null and b/model/web/public/images/admin-login-bg.jpg differ
diff --git a/model/web/public/images/bg2.jpg b/model/web/public/images/bg2.jpg
new file mode 100644
index 0000000..e9e7649
Binary files /dev/null and b/model/web/public/images/bg2.jpg differ
diff --git a/model/web/public/images/demo.jpg b/model/web/public/images/demo.jpg
new file mode 100644
index 0000000..7ea25f1
Binary files /dev/null and b/model/web/public/images/demo.jpg differ
diff --git a/model/web/src/App.vue b/model/web/src/App.vue
new file mode 100644
index 0000000..0a6a060
--- /dev/null
+++ b/model/web/src/App.vue
@@ -0,0 +1,18 @@
+
+
+
+
+
+
+
+
diff --git a/model/web/src/api/admin/ad.ts b/model/web/src/api/admin/ad.ts
new file mode 100644
index 0000000..bbcb05b
--- /dev/null
+++ b/model/web/src/api/admin/ad.ts
@@ -0,0 +1,27 @@
+import { get, post } from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/admin/ad/list',
+ create = '/myapp/admin/ad/create',
+ update = '/myapp/admin/ad/update',
+ delete = '/myapp/admin/ad/delete',
+}
+
+const listApi = async (params: any) => get({ url: URL.list, params: params, data: {}, headers: {} });
+const createApi = async (data: any) =>
+ post({
+ url: URL.create,
+ params: {},
+ data: data,
+ headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' },
+ });
+const updateApi = async (params: any, data: any) =>
+ post({
+ url: URL.update,
+ params: params,
+ data: data,
+ headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' },
+ });
+const deleteApi = async (params: any) => post({ url: URL.delete, params: params, headers: {} });
+
+export { listApi, createApi, updateApi, deleteApi };
diff --git a/model/web/src/api/admin/classification.ts b/model/web/src/api/admin/classification.ts
new file mode 100644
index 0000000..eca3992
--- /dev/null
+++ b/model/web/src/api/admin/classification.ts
@@ -0,0 +1,16 @@
+import { get, post } from '/@/utils/http/axios';
+enum URL {
+ list = '/myapp/admin/classification/list',
+ create = '/myapp/admin/classification/create',
+ update = '/myapp/admin/classification/update',
+ delete = '/myapp/admin/classification/delete',
+}
+
+const listApi = async (params: any) => get({ url: URL.list, params: params, data: {}, headers: {} });
+const createApi = async (data: any) =>
+ post({ url: URL.create, params: {}, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const updateApi = async (params: any, data: any) =>
+ post({ url: URL.update, params: params, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const deleteApi = async (params: any) => post({ url: URL.delete, params: params, headers: {} });
+
+export { listApi, createApi, updateApi, deleteApi };
diff --git a/model/web/src/api/admin/comment.ts b/model/web/src/api/admin/comment.ts
new file mode 100644
index 0000000..3b1b46e
--- /dev/null
+++ b/model/web/src/api/admin/comment.ts
@@ -0,0 +1,24 @@
+import {get, post} from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/admin/comment/list',
+ create = '/myapp/admin/comment/create',
+ delete = '/myapp/admin/comment/delete',
+ listThingComments = '/api/comment/listThingComments',
+ listUserComments = '/api/comment/listUserComments',
+ like = '/api/comment/like'
+}
+
+const listApi = async (params: any) => get({url: URL.list, params: params, data: {}, headers: {}});
+const createApi = async (data: any) => post({
+ url: URL.create,
+ params: {},
+ data: data,
+ headers: {'Content-Type': 'multipart/form-data;charset=utf-8'}
+});
+const deleteApi = async (params: any) => post({url: URL.delete, params: params, headers: {}});
+const listThingCommentsApi = async (params: any) => get({url: URL.listThingComments, params: params, data: {}, headers: {}});
+const listUserCommentsApi = async (params: any) => get({url: URL.listUserComments, params: params, data: {}, headers: {}});
+const likeApi = async (params: any) => post({url: URL.like, params: params, headers: {}});
+
+export {listApi, createApi, deleteApi, listThingCommentsApi, listUserCommentsApi, likeApi};
diff --git a/model/web/src/api/admin/log.ts b/model/web/src/api/admin/log.ts
new file mode 100644
index 0000000..8786129
--- /dev/null
+++ b/model/web/src/api/admin/log.ts
@@ -0,0 +1,16 @@
+import {get, post} from '/@/utils/http/axios';
+
+enum URL {
+ loginLogList = '/myapp/admin/loginLog/list',
+ opLogList = '/myapp/admin/opLog/list',
+ errorLogList = '/myapp/admin/errorLog/list',
+}
+
+const listLoginLogApi = async (params: any) =>
+ get({url: URL.loginLogList, params: params, data: {}, headers: {}});
+const listOpLogListApi = async (params: any) =>
+ get({url: URL.opLogList, params: params, data: {}, headers: {}});
+const listErrorLogListApi = async (params: any) =>
+ get({url: URL.errorLogList, params: params, data: {}, headers: {}});
+
+export {listLoginLogApi, listOpLogListApi, listErrorLogListApi};
diff --git a/model/web/src/api/admin/notice.ts b/model/web/src/api/admin/notice.ts
new file mode 100644
index 0000000..687d937
--- /dev/null
+++ b/model/web/src/api/admin/notice.ts
@@ -0,0 +1,29 @@
+import {get, post} from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/admin/notice/list',
+ create = '/myapp/admin/notice/create',
+ update = '/myapp/admin/notice/update',
+ delete = '/myapp/admin/notice/delete',
+}
+
+const listApi = async (params: any) =>
+ get({url: URL.list, params: params, data: {}, headers: {}});
+const createApi = async (data: any) =>
+ post({
+ url: URL.create,
+ params: {},
+ data: data,
+ headers: {'Content-Type': 'multipart/form-data;charset=utf-8'}
+ });
+const updateApi = async (params: any, data: any) =>
+ post({
+ url: URL.update,
+ params: params,
+ data: data,
+ headers: {'Content-Type': 'multipart/form-data;charset=utf-8'}
+ });
+const deleteApi = async (params: any) =>
+ post({url: URL.delete, params: params, headers: {}});
+
+export {listApi, createApi, updateApi, deleteApi};
diff --git a/model/web/src/api/admin/order.ts b/model/web/src/api/admin/order.ts
new file mode 100644
index 0000000..4dbe4de
--- /dev/null
+++ b/model/web/src/api/admin/order.ts
@@ -0,0 +1,38 @@
+import { get, post } from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/admin/order/list',
+ create = '/myapp/admin/order/create',
+ update = '/myapp/admin/order/update',
+ pass = '/myapp/admin/order/pass_order',
+ delete = '/myapp/admin/order/delete',
+ cancel = '/myapp/admin/order/cancel_order',
+ cancelUserOrder = '/api/order/cancelUserOrder',
+ userOrderList = '/api/order/userOrderList',
+}
+
+const listApi = async (params: any) => get({ url: URL.list, params: params, data: {}, headers: {} });
+const userOrderListApi = async (params: any) => get({ url: URL.userOrderList, params: params, data: {}, headers: {} });
+
+const createApi = async (data: any) =>
+ post({
+ url: URL.create,
+ params: {},
+ data: data,
+ headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' },
+ });
+const updateApi = async (params: any, data: any) =>
+ post({
+ url: URL.update,
+ params: params,
+ data: data,
+ headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' },
+ });
+const deleteApi = async (params: any) => post({ url: URL.delete, params: params, headers: {} });
+const passApi = async (params: any) => post({ url: URL.pass, params: params, headers: {} });
+
+const cancelApi = async (params: any) => post({ url: URL.cancel, params: params, headers: {} });
+
+const cancelUserOrderApi = async (params: any) => post({ url: URL.cancelUserOrder, params: params, headers: {} });
+
+export { listApi, userOrderListApi, createApi, updateApi, deleteApi, passApi,cancelApi, cancelUserOrderApi };
diff --git a/model/web/src/api/admin/overview.ts b/model/web/src/api/admin/overview.ts
new file mode 100644
index 0000000..7b0ff33
--- /dev/null
+++ b/model/web/src/api/admin/overview.ts
@@ -0,0 +1,15 @@
+import {get, post} from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/admin/overview/count',
+ sysInfo= '/myapp/admin/overview/sysInfo',
+}
+
+const listApi = async (params: any) =>
+ get({url: URL.list, params: params, data: {}, headers: {}});
+
+
+const sysInfoApi = async (params: any) =>
+ get({url: URL.sysInfo, params: params, data: {}, headers: {}});
+
+export {listApi, sysInfoApi};
diff --git a/model/web/src/api/admin/tag.ts b/model/web/src/api/admin/tag.ts
new file mode 100644
index 0000000..881c550
--- /dev/null
+++ b/model/web/src/api/admin/tag.ts
@@ -0,0 +1,29 @@
+import {get, post} from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/admin/tag/list',
+ create = '/myapp/admin/tag/create',
+ update = '/myapp/admin/tag/update',
+ delete = '/myapp/admin/tag/delete',
+}
+
+const listApi = async (params: any) =>
+ get({url: URL.list, params: params, data: {}, headers: {}});
+const createApi = async (data: any) =>
+ post({
+ url: URL.create,
+ params: {},
+ data: data,
+ headers: {'Content-Type': 'multipart/form-data;charset=utf-8'}
+ });
+const updateApi = async (params: any, data: any) =>
+ post({
+ url: URL.update,
+ params: params,
+ data: data,
+ headers: {'Content-Type': 'multipart/form-data;charset=utf-8'}
+ });
+const deleteApi = async (params: any) =>
+ post({url: URL.delete, params: params, headers: {}});
+
+export {listApi, createApi, updateApi, deleteApi};
diff --git a/model/web/src/api/admin/thing.ts b/model/web/src/api/admin/thing.ts
new file mode 100644
index 0000000..c33e084
--- /dev/null
+++ b/model/web/src/api/admin/thing.ts
@@ -0,0 +1,21 @@
+// 权限问题后期增加
+import { get, post } from '/@/utils/http/axios';
+import { UserState } from '/@/store/modules/user/types';
+// import axios from 'axios';
+enum URL {
+ list = '/myapp/admin/thing/list',
+ create = '/myapp/admin/thing/create',
+ update = '/myapp/admin/thing/update',
+ delete = '/myapp/admin/thing/delete',
+ detail = '/api/thing/detail',
+}
+
+const listApi = async (params: any) => get({ url: URL.list, params: params, data: {}, headers: {} });
+const createApi = async (data: any) =>
+ post({ url: URL.create, params: {}, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const updateApi = async (params: any, data: any) =>
+ post({ url: URL.update, params: params, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const deleteApi = async (params: any) => post({ url: URL.delete, params: params, headers: {} });
+const detailApi = async (params: any) => get({ url: URL.detail, params: params, headers: {} });
+
+export { listApi, createApi, updateApi, deleteApi, detailApi };
diff --git a/model/web/src/api/admin/user.ts b/model/web/src/api/admin/user.ts
new file mode 100644
index 0000000..983e08b
--- /dev/null
+++ b/model/web/src/api/admin/user.ts
@@ -0,0 +1,54 @@
+// 权限问题后期增加
+import { get, post } from '/@/utils/http/axios';
+import { UserState } from '/@/store/modules/user/types';
+// import axios from 'axios';
+enum URL {
+ login = '/myapp/admin/adminLogin',
+ userList = '/myapp/admin/user/list',
+ detail = '/api/user/detail',
+ create = '/myapp/admin/user/create',
+ update = '/myapp/admin/user/update',
+ delete = '/myapp/admin/user/delete',
+ userLogin = '/api/user/userLogin',
+ userRegister = '/api/user/userRegister',
+ updateUserPwd = '/api/user/updatePwd',
+ updateUserInfo = '/api/user/updateUserInfo',
+}
+interface LoginRes {
+ token: string;
+}
+
+export interface LoginData {
+ username: string;
+ password: string;
+}
+
+const loginApi = async (data: LoginData) =>
+ post({ url: URL.login, data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const listApi = async (params: any) => get({ url: URL.userList, params: params, data: {}, headers: {} });
+const detailApi = async (params: any) => get({ url: URL.detail, params: params, data: {}, headers: {} });
+const createApi = async (data: any) =>
+ post({ url: URL.create, params: {}, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const updateApi = async (params: any, data: any) =>
+ post({ url: URL.update, params: params, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const deleteApi = async (params: any) => post({ url: URL.delete, params: params, headers: {} });
+const userLoginApi = async (data: LoginData) =>
+ post({ url: URL.userLogin, data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const userRegisterApi = async (data: any) =>
+ post({ url: URL.userRegister, params: {}, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const updateUserPwdApi = async (params: any) => post({ url: URL.updateUserPwd, params: params });
+const updateUserInfoApi = async (data: any) =>
+ post({ url: URL.updateUserInfo, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+
+export {
+ loginApi,
+ listApi,
+ detailApi,
+ createApi,
+ updateApi,
+ deleteApi,
+ userLoginApi,
+ userRegisterApi,
+ updateUserPwdApi,
+ updateUserInfoApi,
+};
diff --git a/model/web/src/api/index/address.ts b/model/web/src/api/index/address.ts
new file mode 100644
index 0000000..a245e1c
--- /dev/null
+++ b/model/web/src/api/index/address.ts
@@ -0,0 +1,27 @@
+import { get, post } from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/index/address/list',
+ create = '/myapp/index/address/create',
+ update = '/myapp/index/address/update',
+ delete = '/myapp/index/address/delete',
+}
+
+const listApi = async (params: any) => get({ url: URL.list, params: params, data: {}, headers: {} });
+const createApi = async (data: any) =>
+ post({
+ url: URL.create,
+ params: {},
+ data: data,
+ headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' },
+ });
+const updateApi = async (params: any, data: any) =>
+ post({
+ url: URL.update,
+ params: params,
+ data: data,
+ headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' },
+ });
+const deleteApi = async (params: any) => post({ url: URL.delete, params: params, headers: {} });
+
+export { listApi, createApi, updateApi, deleteApi };
diff --git a/model/web/src/api/index/classification.ts b/model/web/src/api/index/classification.ts
new file mode 100644
index 0000000..2970770
--- /dev/null
+++ b/model/web/src/api/index/classification.ts
@@ -0,0 +1,8 @@
+import { get, post } from '/@/utils/http/axios';
+enum URL {
+ list = '/myapp/index/classification/list',
+}
+
+const listApi = async (params: any) => get({ url: URL.list, params: params, data: {}, headers: {} });
+
+export { listApi };
diff --git a/model/web/src/api/index/comment.ts b/model/web/src/api/index/comment.ts
new file mode 100644
index 0000000..ae1459d
--- /dev/null
+++ b/model/web/src/api/index/comment.ts
@@ -0,0 +1,21 @@
+import { get, post } from '/@/utils/http/axios';
+
+enum URL {
+ create = '/myapp/index/comment/create',
+ listThingComments = '/myapp/index/comment/list',
+ listUserComments = '/myapp/index/comment/listMyComments',
+ like = '/myapp/index/comment/like',
+}
+
+const createApi = async (data: any) =>
+ post({
+ url: URL.create,
+ params: {},
+ data: data,
+ headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' },
+ });
+const listThingCommentsApi = async (params: any) => get({ url: URL.listThingComments, params: params, data: {}, headers: {} });
+const listUserCommentsApi = async (params: any) => get({ url: URL.listUserComments, params: params, data: {}, headers: {} });
+const likeApi = async (params: any) => post({ url: URL.like, params: params, headers: {} });
+
+export { createApi, listThingCommentsApi, listUserCommentsApi, likeApi };
diff --git a/model/web/src/api/index/notice.ts b/model/web/src/api/index/notice.ts
new file mode 100644
index 0000000..03f507b
--- /dev/null
+++ b/model/web/src/api/index/notice.ts
@@ -0,0 +1,10 @@
+import {get, post} from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/index/notice/list_api',
+}
+
+const listApi = async (params: any) =>
+ get({url: URL.list, params: params, data: {}, headers: {}});
+
+export {listApi};
diff --git a/model/web/src/api/index/order.ts b/model/web/src/api/index/order.ts
new file mode 100644
index 0000000..844b9f9
--- /dev/null
+++ b/model/web/src/api/index/order.ts
@@ -0,0 +1,18 @@
+import {get, post} from '/@/utils/http/axios';
+
+enum URL {
+ create='/myapp/index/order/create',
+ cancelUserOrder = '/myapp/index/order/cancel_order',
+ userOrderList = '/myapp/index/order/list',
+}
+
+const createApi = async (data: any) =>
+ post({url: URL.create, data: data, headers: {}});
+
+const userOrderListApi = async (params: any) =>
+ get({url: URL.userOrderList, params: params, data: {}, headers: {}});
+
+const cancelUserOrderApi = async (params: any) =>
+ post({url: URL.cancelUserOrder, params: params, headers: {}});
+
+export {createApi, userOrderListApi, cancelUserOrderApi};
diff --git a/model/web/src/api/index/tag.ts b/model/web/src/api/index/tag.ts
new file mode 100644
index 0000000..6b88338
--- /dev/null
+++ b/model/web/src/api/index/tag.ts
@@ -0,0 +1,10 @@
+import {get, post} from '/@/utils/http/axios';
+
+enum URL {
+ list = '/myapp/index/tag/list',
+}
+
+const listApi = async (params: any) =>
+ get({url: URL.list, params: params, data: {}, headers: {}});
+
+export {listApi};
diff --git a/model/web/src/api/index/thing.ts b/model/web/src/api/index/thing.ts
new file mode 100644
index 0000000..1d77b1c
--- /dev/null
+++ b/model/web/src/api/index/thing.ts
@@ -0,0 +1,36 @@
+// 权限问题后期增加
+import { get, post } from '/@/utils/http/axios';
+import { UserState } from '/@/store/modules/user/types';
+// import axios from 'axios';
+enum URL {
+ list = '/myapp/index/thing/list',
+ detail = '/myapp/index/thing/detail',
+ addWishUser = '/myapp/index/thing/addWishUser',
+ addCollectUser = '/myapp/index/thing/addCollectUser',
+ getCollectThingList = '/myapp/index/thing/getCollectThingList',
+ getWishThingList = '/myapp/index/thing/getWishThingList',
+ removeCollectUser = '/myapp/index/thing/removeCollectUser',
+ removeWishUser = '/myapp/index/thing/removeWishUser',
+ listUserThing = '/myapp/index/thing/listUserThing',
+ create = '/myapp/index/thing/create',
+ update = '/myapp/index/thing/update'
+
+}
+
+const listApi = async (params: any) => get({ url: URL.list, params: params, data: {}, headers: {} });
+const detailApi = async (params: any) => get({ url: URL.detail, params: params, headers: {} });
+const addWishUserApi = async (params: any) => post({ url: URL.addWishUser, params: params, headers: {} });
+const addCollectUserApi = async (params: any) => post({ url: URL.addCollectUser, params: params, headers: {} });
+const getCollectThingListApi = async (params: any) => get({ url: URL.getCollectThingList, params: params, headers: {} });
+const getWishThingListApi = async (params: any) => get({ url: URL.getWishThingList, params: params, headers: {} });
+
+const removeCollectUserApi = async (params: any) => post({ url: URL.removeCollectUser, params: params, headers: {} });
+const removeWishUserApi = async (params: any) => post({ url: URL.removeWishUser, params: params, headers: {} });
+
+const listUserThingApi = async (params: any) => get({ url: URL.listUserThing, params: params, data: {}, headers: {} });
+const createApi = async (data:any) => post({ url: URL.create, params: {}, data: data, headers: {'Content-Type': 'multipart/form-data;charset=utf-8'}});
+const updateApi = async (params: any, data:any) => post({ url: URL.update, params: params, data: data, headers: {'Content-Type': 'multipart/form-data;charset=utf-8'} });
+
+
+export { listApi, detailApi, addWishUserApi,addCollectUserApi, getCollectThingListApi,
+ getWishThingListApi, removeCollectUserApi, removeWishUserApi, listUserThingApi, createApi, updateApi };
diff --git a/model/web/src/api/index/thingCollect.ts b/model/web/src/api/index/thingCollect.ts
new file mode 100644
index 0000000..88566f2
--- /dev/null
+++ b/model/web/src/api/index/thingCollect.ts
@@ -0,0 +1,15 @@
+
+import { get, post } from '/@/utils/http/axios';
+import { UserState } from '/@/store/modules/user/types';
+
+enum URL {
+ userCollectList = '/api/thingCollect/getUserCollectList',
+ collect = '/api/thingCollect/collect',
+ unCollect = '/api/thingCollect/unCollect',
+}
+
+const collectApi = async (data: any) => post({ url: URL.collect, params: {}, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const unCollectApi = async (params: any) => post({ url: URL.unCollect, params: params, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const userCollectListApi = async (params: any) => get({ url: URL.userCollectList, params: params });
+
+export { collectApi, unCollectApi, userCollectListApi };
diff --git a/model/web/src/api/index/thingWish.ts b/model/web/src/api/index/thingWish.ts
new file mode 100644
index 0000000..d3233ab
--- /dev/null
+++ b/model/web/src/api/index/thingWish.ts
@@ -0,0 +1,15 @@
+// 权限问题后期增加
+import { get, post } from '/@/utils/http/axios';
+import { UserState } from '/@/store/modules/user/types';
+// import axios from 'axios';
+enum URL {
+ userWishList = '/api/thingWish/getUserWishList',
+ wish = '/api/thingWish/wish',
+ unWish = '/api/thingWish/unWish',
+}
+
+const wishApi = async (data: any) => post({ url: URL.wish, params: {}, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const unWishApi = async (params: any) => post({ url: URL.unWish, params: params, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const userWishListApi = async (params: any) => get({ url: URL.userWishList, params: params });
+
+export { wishApi, unWishApi, userWishListApi };
diff --git a/model/web/src/api/index/user.ts b/model/web/src/api/index/user.ts
new file mode 100644
index 0000000..78b19ae
--- /dev/null
+++ b/model/web/src/api/index/user.ts
@@ -0,0 +1,27 @@
+// 权限问题后期增加
+import { get, post } from '/@/utils/http/axios';
+import { UserState } from '/@/store/modules/user/types';
+// import axios from 'axios';
+enum URL {
+ userLogin = '/myapp/index/user/login',
+ userRegister = '/myapp/index/user/register',
+ detail = '/myapp/index/user/info',
+ updateUserPwd = '/myapp/index/user/updatePwd',
+ updateUserInfo = '/myapp/index/user/update',
+}
+interface LoginRes {
+ token: string;
+}
+
+export interface LoginData {
+ username: string;
+ password: string;
+}
+
+const detailApi = async (params: any) => get({ url: URL.detail, params: params, data: {}, headers: {} });
+const userLoginApi = async (data: LoginData) => post({ url: URL.userLogin, data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+const userRegisterApi = async (data: any) => post({ url: URL.userRegister, params: {}, data: data });
+const updateUserPwdApi = async (params: any, data:any) => post({ url: URL.updateUserPwd, params: params, data:data });
+const updateUserInfoApi = async (params: any,data: any) => post({ url: URL.updateUserInfo, params:params, data: data, headers: { 'Content-Type': 'multipart/form-data;charset=utf-8' } });
+
+export { detailApi, userLoginApi, userRegisterApi, updateUserPwdApi, updateUserInfoApi};
diff --git a/model/web/src/assets/fonts/Blimone-ExtraBold.woff b/model/web/src/assets/fonts/Blimone-ExtraBold.woff
new file mode 100644
index 0000000..3c02cf9
Binary files /dev/null and b/model/web/src/assets/fonts/Blimone-ExtraBold.woff differ
diff --git a/model/web/src/assets/fonts/Blimone-ExtraLight.woff b/model/web/src/assets/fonts/Blimone-ExtraLight.woff
new file mode 100644
index 0000000..fd2caaf
Binary files /dev/null and b/model/web/src/assets/fonts/Blimone-ExtraLight.woff differ
diff --git a/model/web/src/assets/fonts/Blimone-Light.woff b/model/web/src/assets/fonts/Blimone-Light.woff
new file mode 100644
index 0000000..edfd9d8
Binary files /dev/null and b/model/web/src/assets/fonts/Blimone-Light.woff differ
diff --git a/model/web/src/assets/fonts/Blimone-Regular.woff b/model/web/src/assets/fonts/Blimone-Regular.woff
new file mode 100644
index 0000000..2aab19f
Binary files /dev/null and b/model/web/src/assets/fonts/Blimone-Regular.woff differ
diff --git a/model/web/src/assets/icons/logo.png b/model/web/src/assets/icons/logo.png
new file mode 100644
index 0000000..95dde54
Binary files /dev/null and b/model/web/src/assets/icons/logo.png differ
diff --git a/model/web/src/assets/icons/svg/github.svg b/model/web/src/assets/icons/svg/github.svg
new file mode 100644
index 0000000..d6e1dec
--- /dev/null
+++ b/model/web/src/assets/icons/svg/github.svg
@@ -0,0 +1,4 @@
+
+
+
\ No newline at end of file
diff --git a/model/web/src/assets/icons/svg/logo.svg b/model/web/src/assets/icons/svg/logo.svg
new file mode 100644
index 0000000..d6fdc6b
--- /dev/null
+++ b/model/web/src/assets/icons/svg/logo.svg
@@ -0,0 +1,83 @@
+
+
+
+
+
+ 资源 46
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/model/web/src/assets/icons/svg/marks.svg b/model/web/src/assets/icons/svg/marks.svg
new file mode 100644
index 0000000..9d5fcb8
--- /dev/null
+++ b/model/web/src/assets/icons/svg/marks.svg
@@ -0,0 +1,4 @@
+
+
+
\ No newline at end of file
diff --git a/model/web/src/assets/icons/svg/test.svg b/model/web/src/assets/icons/svg/test.svg
new file mode 100644
index 0000000..d469245
--- /dev/null
+++ b/model/web/src/assets/icons/svg/test.svg
@@ -0,0 +1,12 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/model/web/src/assets/icons/svg/ts.svg b/model/web/src/assets/icons/svg/ts.svg
new file mode 100644
index 0000000..47d791b
--- /dev/null
+++ b/model/web/src/assets/icons/svg/ts.svg
@@ -0,0 +1,5 @@
+
+
+
\ No newline at end of file
diff --git a/model/web/src/assets/icons/svg/twitter.svg b/model/web/src/assets/icons/svg/twitter.svg
new file mode 100644
index 0000000..5e85901
--- /dev/null
+++ b/model/web/src/assets/icons/svg/twitter.svg
@@ -0,0 +1,4 @@
+
+
+
\ No newline at end of file
diff --git a/model/web/src/assets/images/add.svg b/model/web/src/assets/images/add.svg
new file mode 100644
index 0000000..f796923
--- /dev/null
+++ b/model/web/src/assets/images/add.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/address-right-icon.svg b/model/web/src/assets/images/address-right-icon.svg
new file mode 100644
index 0000000..96f4d3f
--- /dev/null
+++ b/model/web/src/assets/images/address-right-icon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/images/ali-pay-icon.svg b/model/web/src/assets/images/ali-pay-icon.svg
new file mode 100644
index 0000000..a9aac72
--- /dev/null
+++ b/model/web/src/assets/images/ali-pay-icon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/images/avatar.jpg b/model/web/src/assets/images/avatar.jpg
new file mode 100644
index 0000000..f26a73f
Binary files /dev/null and b/model/web/src/assets/images/avatar.jpg differ
diff --git a/model/web/src/assets/images/banner-02.webp b/model/web/src/assets/images/banner-02.webp
new file mode 100644
index 0000000..2434c4b
Binary files /dev/null and b/model/web/src/assets/images/banner-02.webp differ
diff --git a/model/web/src/assets/images/banner2.svg b/model/web/src/assets/images/banner2.svg
new file mode 100644
index 0000000..e010e2d
--- /dev/null
+++ b/model/web/src/assets/images/banner2.svg
@@ -0,0 +1,48 @@
+
+
+
+
+
+
+
+
+
+
+
+ 12
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/assets/images/cart-icon.svg b/model/web/src/assets/images/cart-icon.svg
new file mode 100644
index 0000000..7dbf88b
--- /dev/null
+++ b/model/web/src/assets/images/cart-icon.svg
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/model/web/src/assets/images/clear-search.svg b/model/web/src/assets/images/clear-search.svg
new file mode 100644
index 0000000..cac7eab
--- /dev/null
+++ b/model/web/src/assets/images/clear-search.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/code-icon.svg b/model/web/src/assets/images/code-icon.svg
new file mode 100644
index 0000000..a2b2054
--- /dev/null
+++ b/model/web/src/assets/images/code-icon.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/delete-icon.svg b/model/web/src/assets/images/delete-icon.svg
new file mode 100644
index 0000000..4ce2bde
--- /dev/null
+++ b/model/web/src/assets/images/delete-icon.svg
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/model/web/src/assets/images/ebook-download-icon.svg b/model/web/src/assets/images/ebook-download-icon.svg
new file mode 100644
index 0000000..208fc3d
--- /dev/null
+++ b/model/web/src/assets/images/ebook-download-icon.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/k-logo.png b/model/web/src/assets/images/k-logo.png
new file mode 100644
index 0000000..4dfed4f
Binary files /dev/null and b/model/web/src/assets/images/k-logo.png differ
diff --git a/model/web/src/assets/images/login-banner.png b/model/web/src/assets/images/login-banner.png
new file mode 100644
index 0000000..a3b3776
Binary files /dev/null and b/model/web/src/assets/images/login-banner.png differ
diff --git a/model/web/src/assets/images/login.png b/model/web/src/assets/images/login.png
new file mode 100644
index 0000000..606dd7a
Binary files /dev/null and b/model/web/src/assets/images/login.png differ
diff --git a/model/web/src/assets/images/logo.png b/model/web/src/assets/images/logo.png
new file mode 100644
index 0000000..e436655
Binary files /dev/null and b/model/web/src/assets/images/logo.png differ
diff --git a/model/web/src/assets/images/mail-icon.svg b/model/web/src/assets/images/mail-icon.svg
new file mode 100644
index 0000000..a2f7838
--- /dev/null
+++ b/model/web/src/assets/images/mail-icon.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/message-icon.svg b/model/web/src/assets/images/message-icon.svg
new file mode 100644
index 0000000..fed934e
--- /dev/null
+++ b/model/web/src/assets/images/message-icon.svg
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/assets/images/order-address-icon.svg b/model/web/src/assets/images/order-address-icon.svg
new file mode 100644
index 0000000..929647a
--- /dev/null
+++ b/model/web/src/assets/images/order-address-icon.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/order-icon.svg b/model/web/src/assets/images/order-icon.svg
new file mode 100644
index 0000000..8333718
--- /dev/null
+++ b/model/web/src/assets/images/order-icon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/images/order-point-icon.svg b/model/web/src/assets/images/order-point-icon.svg
new file mode 100644
index 0000000..3c1a361
--- /dev/null
+++ b/model/web/src/assets/images/order-point-icon.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/order-thing-icon.svg b/model/web/src/assets/images/order-thing-icon.svg
new file mode 100644
index 0000000..732103e
--- /dev/null
+++ b/model/web/src/assets/images/order-thing-icon.svg
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/model/web/src/assets/images/pwd-hidden.svg b/model/web/src/assets/images/pwd-hidden.svg
new file mode 100644
index 0000000..d0ca01e
--- /dev/null
+++ b/model/web/src/assets/images/pwd-hidden.svg
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/assets/images/pwd-icon.svg b/model/web/src/assets/images/pwd-icon.svg
new file mode 100644
index 0000000..639f47b
--- /dev/null
+++ b/model/web/src/assets/images/pwd-icon.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/qunerweima.jpg b/model/web/src/assets/images/qunerweima.jpg
new file mode 100644
index 0000000..dc3a84c
Binary files /dev/null and b/model/web/src/assets/images/qunerweima.jpg differ
diff --git a/model/web/src/assets/images/read-online-icon.svg b/model/web/src/assets/images/read-online-icon.svg
new file mode 100644
index 0000000..1edf0a3
--- /dev/null
+++ b/model/web/src/assets/images/read-online-icon.svg
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/model/web/src/assets/images/recommend-hover.svg b/model/web/src/assets/images/recommend-hover.svg
new file mode 100644
index 0000000..2def4da
--- /dev/null
+++ b/model/web/src/assets/images/recommend-hover.svg
@@ -0,0 +1,7 @@
+
+
+
+
+
+
+
diff --git a/model/web/src/assets/images/register-name.svg b/model/web/src/assets/images/register-name.svg
new file mode 100644
index 0000000..6aca1f7
--- /dev/null
+++ b/model/web/src/assets/images/register-name.svg
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/model/web/src/assets/images/search-icon.svg b/model/web/src/assets/images/search-icon.svg
new file mode 100644
index 0000000..84d55ec
--- /dev/null
+++ b/model/web/src/assets/images/search-icon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/images/searchIcon.svg b/model/web/src/assets/images/searchIcon.svg
new file mode 100644
index 0000000..84d55ec
--- /dev/null
+++ b/model/web/src/assets/images/searchIcon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/images/setting-card-icon.svg b/model/web/src/assets/images/setting-card-icon.svg
new file mode 100644
index 0000000..6a3676b
--- /dev/null
+++ b/model/web/src/assets/images/setting-card-icon.svg
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/assets/images/setting-icon.svg b/model/web/src/assets/images/setting-icon.svg
new file mode 100644
index 0000000..03cf9d4
--- /dev/null
+++ b/model/web/src/assets/images/setting-icon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/images/setting-msg-icon.svg b/model/web/src/assets/images/setting-msg-icon.svg
new file mode 100644
index 0000000..605cf30
--- /dev/null
+++ b/model/web/src/assets/images/setting-msg-icon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/images/setting-push-icon.svg b/model/web/src/assets/images/setting-push-icon.svg
new file mode 100644
index 0000000..371bd25
--- /dev/null
+++ b/model/web/src/assets/images/setting-push-icon.svg
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/model/web/src/assets/images/setting-safe-icon.svg b/model/web/src/assets/images/setting-safe-icon.svg
new file mode 100644
index 0000000..299abd9
--- /dev/null
+++ b/model/web/src/assets/images/setting-safe-icon.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/share-icon.svg b/model/web/src/assets/images/share-icon.svg
new file mode 100644
index 0000000..8ab9ae1
--- /dev/null
+++ b/model/web/src/assets/images/share-icon.svg
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/model/web/src/assets/images/tel-icon.svg b/model/web/src/assets/images/tel-icon.svg
new file mode 100644
index 0000000..820cf2c
--- /dev/null
+++ b/model/web/src/assets/images/tel-icon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/images/want-read-hover.svg b/model/web/src/assets/images/want-read-hover.svg
new file mode 100644
index 0000000..1943361
--- /dev/null
+++ b/model/web/src/assets/images/want-read-hover.svg
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/model/web/src/assets/images/wb-share.svg b/model/web/src/assets/images/wb-share.svg
new file mode 100644
index 0000000..19df240
--- /dev/null
+++ b/model/web/src/assets/images/wb-share.svg
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/model/web/src/assets/images/wx-pay-icon.svg b/model/web/src/assets/images/wx-pay-icon.svg
new file mode 100644
index 0000000..d674c7e
--- /dev/null
+++ b/model/web/src/assets/images/wx-pay-icon.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/model/web/src/assets/styles/base.less b/model/web/src/assets/styles/base.less
new file mode 100644
index 0000000..e69de29
diff --git a/model/web/src/core/bootstrap.js b/model/web/src/core/bootstrap.js
new file mode 100644
index 0000000..f961891
--- /dev/null
+++ b/model/web/src/core/bootstrap.js
@@ -0,0 +1,18 @@
+// localStorage恢复到内存
+
+import { useUserStore } from '/@/store';
+import { USER_ID, USER_NAME, USER_TOKEN, ADMIN_USER_ID, ADMIN_USER_NAME, ADMIN_USER_TOKEN } from '/@/store/constants';
+
+export default function Initializer() {
+ const userStore = useUserStore();
+ userStore.$patch((state) => {
+ state.user_id = localStorage.getItem(USER_ID);
+ state.user_name = localStorage.getItem(USER_NAME);
+ state.user_token = localStorage.getItem(USER_TOKEN);
+
+ state.admin_user_id = localStorage.getItem(ADMIN_USER_ID);
+ state.admin_user_name = localStorage.getItem(ADMIN_USER_NAME);
+ state.admin_user_token = localStorage.getItem(ADMIN_USER_TOKEN);
+ console.log('恢复store完毕==>', state);
+ });
+}
diff --git a/model/web/src/main.js b/model/web/src/main.js
new file mode 100644
index 0000000..c80d20c
--- /dev/null
+++ b/model/web/src/main.js
@@ -0,0 +1,17 @@
+import { createApp } from 'vue';
+import App from './App.vue';
+import router from './router';
+import piniaStore from './store';
+
+import bootstrap from './core/bootstrap';
+import '/@/styles/reset.less';
+import '/@/styles/index.less';
+import Antd from 'ant-design-vue';
+
+const app = createApp(App);
+
+app.use(Antd);
+app.use(router);
+app.use(piniaStore);
+app.use(bootstrap);
+app.mount('#app');
diff --git a/model/web/src/router/index.js b/model/web/src/router/index.js
new file mode 100644
index 0000000..d38a433
--- /dev/null
+++ b/model/web/src/router/index.js
@@ -0,0 +1,65 @@
+import { createRouter, createWebHistory } from 'vue-router';
+import root from './root';
+
+import { ADMIN_USER_TOKEN, USER_TOKEN } from '/@/store/constants';
+
+// 路由权限白名单
+const allowList = ['adminLogin', 'login', 'register', 'portal', 'search', 'detail', '403', '404'];
+// 前台登录地址
+const loginRoutePath = '/index/login';
+// 后台登录地址
+const adminLoginRoutePath = '/adminLogin';
+
+const router = createRouter({
+ history: createWebHistory(),
+ routes: root,
+});
+
+router.beforeEach(async (to, from, next) => {
+ console.log(to, from);
+
+ /** 后台路由 **/
+ if (to.path.startsWith('/admin')) {
+ if (localStorage.getItem(ADMIN_USER_TOKEN)) {
+ if (to.path === adminLoginRoutePath) {
+ next({ path: '/' });
+ } else {
+ next();
+ }
+ } else {
+ if (allowList.includes(to.name)) {
+ // 在免登录名单,直接进入
+ next();
+ } else {
+ next({ path: adminLoginRoutePath, query: { redirect: to.fullPath } });
+ }
+ }
+ // next()
+ }
+
+ /** 前台路由 **/
+ if (to.path.startsWith('/index')) {
+ if (localStorage.getItem(USER_TOKEN)) {
+ if (to.path === loginRoutePath) {
+ next({ path: '/' });
+ } else {
+ next();
+ }
+ } else {
+ if (allowList.includes(to.name)) {
+ // 在免登录名单,直接进入
+ next();
+ } else {
+ next({ path: loginRoutePath, query: { redirect: to.fullPath } });
+ }
+ }
+ // next()
+ }
+});
+
+router.afterEach((_to) => {
+ // 回到顶部
+ document.getElementById('html')?.scrollTo(0, 0);
+});
+
+export default router;
diff --git a/model/web/src/router/root.js b/model/web/src/router/root.js
new file mode 100644
index 0000000..f955370
--- /dev/null
+++ b/model/web/src/router/root.js
@@ -0,0 +1,152 @@
+// 路由表
+const constantRouterMap = [
+ // ************* 前台路由 **************
+ {
+ path: '/',
+ redirect: '/index',
+ },
+ {
+ path: '/index',
+ name: 'index',
+ redirect: '/index/portal',
+ component: () => import('/@/views/index/index.vue'),
+ children: [
+ {
+ path: 'login',
+ name: 'login',
+ component: () => import('/@/views/index/login.vue'),
+ },
+ {
+ path: 'register',
+ name: 'register',
+ component: () => import('/@/views/index/register.vue'),
+ },
+ {
+ path: 'portal',
+ name: 'portal',
+ component: () => import('/@/views/index/portal.vue'),
+ },
+ {
+ path: 'detail',
+ name: 'detail',
+ component: () => import('/@/views/index/detail.vue'),
+ },
+ {
+ path: 'confirm',
+ name: 'confirm',
+ component: () => import('/@/views/index/confirm.vue'),
+ },
+ {
+ path: 'pay',
+ name: 'pay',
+ component: () => import('/@/views/index/pay.vue'),
+ },
+ {
+ path: 'search',
+ name: 'search',
+ component: () => import('/@/views/index/search.vue'),
+ },
+ {
+ path: 'usercenter',
+ name: 'usercenter',
+ redirect: '/index/usercenter/addressView',
+ component: () => import('/@/views/index/usercenter.vue'),
+ children: [
+ {
+ path: 'addressView',
+ name: 'addressView',
+ component: () => import('/@/views/index/user/address-view.vue'),
+ },
+ {
+ path: 'wishThingView',
+ name: 'wishThingView',
+ component: () => import('/@/views/index/user/wish-thing-view.vue'),
+ },
+ {
+ path: 'collectThingView',
+ name: 'collectThingView',
+ component: () => import('/@/views/index/user/collect-thing-view.vue'),
+ },
+ {
+ path: 'jiajiaoEditView',
+ name: 'jiajiaoEditView',
+ component: () => import('/@/views/index/user/jiajiao-edit-view.vue'),
+ },
+ {
+ path: 'orderView',
+ name: 'orderView',
+ component: () => import('/@/views/index/user/order-view.vue'),
+ },
+ {
+ path: 'userInfoEditView',
+ name: 'userInfoEditView',
+ component: () => import('/@/views/index/user/userinfo-edit-view.vue'),
+ },
+ {
+ path: 'followView',
+ name: 'followView',
+ component: () => import('/@/views/index/user/follow-view.vue'),
+ },
+ {
+ path: 'fansView',
+ name: 'fansView',
+ component: () => import('/@/views/index/user/fans-view.vue'),
+ },
+ {
+ path: 'scoreView',
+ name: 'scoreView',
+ component: () => import('/@/views/index/user/score-view.vue'),
+ },
+ {
+ path: 'commentView',
+ name: 'commentView',
+ component: () => import('/@/views/index/user/comment-view.vue'),
+ },
+ {
+ path: 'securityView',
+ name: 'securityView',
+ component: () => import('/@/views/index/user/security-view.vue'),
+ },
+ {
+ path: 'pushView',
+ name: 'pushView',
+ component: () => import('/@/views/index/user/push-view.vue'),
+ },
+ {
+ path: 'messageView',
+ name: 'messageView',
+ component: () => import('/@/views/index/user/message-view.vue'),
+ },
+ ],
+ },
+ ],
+ },
+ {
+ path: '/adminLogin',
+ name: 'adminLogin',
+ component: () => import('/@/views/admin/admin-login.vue'),
+ },
+ {
+ path: '/admin',
+ name: 'admin',
+ redirect: '/admin/thing',
+ component: () => import('/@/views/admin/main.vue'),
+ children: [
+ { path: 'overview', name: 'overview', component: () => import('/@/views/admin/overview.vue') },
+ { path: 'order', name: 'order', component: () => import('/@/views/admin/order.vue') },
+ { path: 'thing', name: 'thing', component: () => import('/@/views/admin/thing.vue') },
+ { path: 'comment', name: 'comment', component: () => import('/@/views/admin/comment.vue') },
+ { path: 'user', name: 'user', component: () => import('/@/views/admin/user.vue') },
+ { path: 'classification', name: 'classification', component: () => import('/@/views/admin/classification.vue') },
+ { path: 'tag', name: 'tag', component: () => import('/@/views/admin/tag.vue') },
+ { path: 'ad', name: 'ad', component: () => import('/@/views/admin/ad.vue') },
+ { path: 'notice', name: 'notice', component: () => import('/@/views/admin/notice.vue') },
+ { path: 'loginLog', name: 'loginLog', component: () => import('/@/views/admin/login-log.vue') },
+ { path: 'opLog', name: 'opLog', component: () => import('/@/views/admin/op-log.vue') },
+ { path: 'errorLog', name: 'errorLog', component: () => import('/@/views/admin/error-log.vue') },
+ { path: 'sysInfo', name: 'sysInfo', component: () => import('/@/views/admin/sys-info.vue') },
+ ],
+ },
+];
+
+export default constantRouterMap;
diff --git a/model/web/src/store/constants.js b/model/web/src/store/constants.js
new file mode 100644
index 0000000..ce26010
--- /dev/null
+++ b/model/web/src/store/constants.js
@@ -0,0 +1,12 @@
+const BASE_URL = 'http://127.0.0.1:8000';
+// const BASE_URL = 'https://team.gitapp.cn/api/';
+
+const USER_ID = 'user_id';
+const USER_NAME = 'user_name';
+const USER_TOKEN = 'user_token';
+
+const ADMIN_USER_ID = 'admin_user_id';
+const ADMIN_USER_NAME = 'admin_user_name';
+const ADMIN_USER_TOKEN = 'admin_user_token';
+
+export { BASE_URL, USER_TOKEN, USER_NAME, USER_ID, ADMIN_USER_ID, ADMIN_USER_NAME, ADMIN_USER_TOKEN };
diff --git a/model/web/src/store/index.js b/model/web/src/store/index.js
new file mode 100644
index 0000000..d23572b
--- /dev/null
+++ b/model/web/src/store/index.js
@@ -0,0 +1,11 @@
+import { createPinia } from 'pinia';
+import { useAppStore } from './modules/app';
+import { useUserStore } from './modules/user';
+
+import piniaPluginPersistedstate from 'pinia-plugin-persistedstate';
+
+const pinia = createPinia();
+pinia.use(piniaPluginPersistedstate);
+
+export { useAppStore, useUserStore };
+export default pinia;
diff --git a/model/web/src/store/modules/app/index.ts b/model/web/src/store/modules/app/index.ts
new file mode 100644
index 0000000..724fbbd
--- /dev/null
+++ b/model/web/src/store/modules/app/index.ts
@@ -0,0 +1,41 @@
+import { defineStore } from 'pinia';
+import piniaStore from '/@/store';
+import { AppState } from './types';
+
+export const useAppStore = defineStore(
+ // 唯一ID
+ 'app',
+ {
+ state: () => ({
+ title: 'FastVue3, 一个快速开箱即用的Vue3+Vite模板',
+ h1: 'Vue3 + Vite3.x + TypeScript + Pinia大厂开发必备',
+ theme: '',
+ }),
+ getters: {},
+ actions: {
+ updateSettings(partial: Partial) {
+ this.$patch(partial);
+ },
+
+ // Change theme color
+ toggleTheme(dark: boolean) {
+ if (dark) {
+ this.theme = 'dark';
+ document.documentElement.classList.add('dark');
+ } else {
+ this.theme = 'light';
+ document.documentElement.classList.remove('dark');
+ }
+ },
+ },
+ persist: {
+ key: 'theme',
+ storage: localStorage,
+ paths: ['theme'],
+ },
+ },
+);
+
+export function useAppOutsideStore() {
+ return useAppStore(piniaStore);
+}
diff --git a/model/web/src/store/modules/app/types.ts b/model/web/src/store/modules/app/types.ts
new file mode 100644
index 0000000..7f13652
--- /dev/null
+++ b/model/web/src/store/modules/app/types.ts
@@ -0,0 +1,12 @@
+export interface AppState {
+ theme: string;
+ colorWeek: boolean;
+ navbar: boolean;
+ menu: boolean;
+ menuCollapse: boolean;
+ footer: boolean;
+ themeColor: string;
+ menuWidth: number;
+ globalSettings: boolean;
+ [key: string]: unknown;
+}
diff --git a/model/web/src/store/modules/user/index.ts b/model/web/src/store/modules/user/index.ts
new file mode 100644
index 0000000..9bbc306
--- /dev/null
+++ b/model/web/src/store/modules/user/index.ts
@@ -0,0 +1,88 @@
+import { defineStore } from 'pinia';
+import {loginApi as adminLogin} from '/@/api/admin/user';
+import {userLoginApi} from '/@/api/index/user';
+import { setToken, clearToken } from '/@/utils/auth';
+import { UserState } from './types';
+import {USER_ID, USER_NAME, USER_TOKEN, ADMIN_USER_ID,ADMIN_USER_NAME,ADMIN_USER_TOKEN} from "/@/store/constants";
+
+export const useUserStore = defineStore('user', {
+ state: (): UserState => ({
+ user_id: undefined,
+ user_name: undefined,
+ user_token: undefined,
+
+ admin_user_id: undefined,
+ admin_user_name: undefined,
+ admin_user_token: undefined,
+ }),
+ getters: {},
+ actions: {
+ // 用户登录
+ async login(loginForm) {
+ const result = await userLoginApi(loginForm);
+ console.log('result==>', result)
+
+ if(result.code === 0) {
+ this.$patch((state)=>{
+ state.user_id = result.data.id
+ state.user_name = result.data.username
+ state.user_token = result.data.token
+ console.log('state==>', state)
+ })
+
+ localStorage.setItem(USER_TOKEN, result.data.token)
+ localStorage.setItem(USER_NAME, result.data.username)
+ localStorage.setItem(USER_ID, result.data.id)
+ }
+
+ return result;
+ },
+ // 用户登出
+ async logout() {
+ // await userLogout();
+ this.$patch((state)=>{
+ localStorage.removeItem(USER_ID)
+ localStorage.removeItem(USER_NAME)
+ localStorage.removeItem(USER_TOKEN)
+
+ state.user_id = undefined
+ state.user_name = undefined
+ state.user_token = undefined
+ })
+ },
+
+ // 管理员登录
+ async adminLogin(loginForm) {
+ const result = await adminLogin(loginForm);
+ console.log('result==>', result)
+
+ if(result.code === 0) {
+ this.$patch((state)=>{
+ state.admin_user_id = result.data.id
+ state.admin_user_name = result.data.username
+ state.admin_user_token = result.data.admin_token
+ console.log('state==>', state)
+ })
+
+ localStorage.setItem(ADMIN_USER_TOKEN, result.data.admin_token)
+ localStorage.setItem(ADMIN_USER_NAME, result.data.username)
+ localStorage.setItem(ADMIN_USER_ID, result.data.id)
+ }
+
+ return result;
+ },
+ // 管理员登出
+ async adminLogout() {
+ // await userLogout();
+ this.$patch((state)=>{
+ localStorage.removeItem(ADMIN_USER_ID)
+ localStorage.removeItem(ADMIN_USER_NAME)
+ localStorage.removeItem(ADMIN_USER_TOKEN)
+
+ state.admin_user_id = undefined
+ state.admin_user_name = undefined
+ state.admin_user_token = undefined
+ })
+ },
+ },
+});
diff --git a/model/web/src/store/modules/user/types.ts b/model/web/src/store/modules/user/types.ts
new file mode 100644
index 0000000..04718fd
--- /dev/null
+++ b/model/web/src/store/modules/user/types.ts
@@ -0,0 +1,10 @@
+export type RoleType = '' | '*' | 'admin' | 'user';
+export interface UserState {
+ user_id: any;
+ user_name: any;
+ user_token: any;
+
+ admin_user_id: any;
+ admin_user_name: any;
+ admin_user_token: any;
+}
diff --git a/model/web/src/styles/index.less b/model/web/src/styles/index.less
new file mode 100644
index 0000000..da8f6a8
--- /dev/null
+++ b/model/web/src/styles/index.less
@@ -0,0 +1,4 @@
+//自定义css
+a {
+ color: #1890ff;
+}
diff --git a/model/web/src/styles/reset.less b/model/web/src/styles/reset.less
new file mode 100644
index 0000000..6427179
--- /dev/null
+++ b/model/web/src/styles/reset.less
@@ -0,0 +1,36 @@
+html {
+ box-sizing: border-box;
+}
+
+*,
+::before,
+::after {
+ margin: 0;
+ padding: 0;
+ box-sizing: inherit;
+}
+
+
+a:hover,
+a:link,
+a:visited,
+a:active {
+ text-decoration: none;
+}
+
+ol,
+ul {
+ list-style: none;
+}
+
+input,
+textarea {
+ outline: none;
+ border: none;
+ resize: none;
+}
+
+body {
+ font-size: 14px;
+ font-weight: 400;
+}
diff --git a/model/web/src/utils/auth.ts b/model/web/src/utils/auth.ts
new file mode 100644
index 0000000..6fb8c15
--- /dev/null
+++ b/model/web/src/utils/auth.ts
@@ -0,0 +1,15 @@
+const TokenKey = 'fast-token';
+const TokenPrefix = 'Bearer ';
+const isLogin = () => {
+ return !!localStorage.getItem(TokenKey);
+};
+const getToken = () => {
+ return localStorage.getItem(TokenKey);
+};
+const setToken = (token: string) => {
+ localStorage.setItem(TokenKey, token);
+};
+const clearToken = () => {
+ localStorage.removeItem(TokenKey);
+};
+export { TokenPrefix, isLogin, getToken, setToken, clearToken };
diff --git a/model/web/src/utils/http/axios/index.ts b/model/web/src/utils/http/axios/index.ts
new file mode 100644
index 0000000..35ad9a5
--- /dev/null
+++ b/model/web/src/utils/http/axios/index.ts
@@ -0,0 +1,78 @@
+import axios from 'axios';
+import type { AxiosInstance, AxiosRequestConfig, AxiosResponse, AxiosError, InternalAxiosRequestConfig } from 'axios';
+import { showMessage } from './status';
+import { IResponse } from './type';
+import { getToken } from '/@/utils/auth';
+import { TokenPrefix } from '/@/utils/auth';
+import {ADMIN_USER_TOKEN, USER_TOKEN, BASE_URL} from '/@/store/constants'
+
+const service: AxiosInstance = axios.create({
+ // baseURL: import.meta.env.BASE_URL + '',
+ baseURL: BASE_URL + '',
+ timeout: 15000,
+});
+
+// axios实例拦截请求
+service.interceptors.request.use(
+ (config: InternalAxiosRequestConfig) => {
+
+ config.headers.ADMINTOKEN = localStorage.getItem(ADMIN_USER_TOKEN)
+ config.headers.TOKEN = localStorage.getItem(USER_TOKEN)
+
+ return config;
+ },
+ (error: AxiosError) => {
+ return Promise.reject(error);
+ },
+);
+
+// axios实例拦截响应
+service.interceptors.response.use(
+ (response: AxiosResponse) => {
+ if(response.status == 200) {
+ if(response.data.code == 0 || response.data.code == 200) {
+ return response
+ }else {
+ return Promise.reject(response.data)
+ }
+ } else {
+ return Promise.reject(response.data)
+ }
+ },
+ // 请求失败
+ (error: any) => {
+ console.log(error.response.status)
+ if(error.response.status == 404) {
+ // todo
+ } else if(error.response.status == 403) {
+ // todo
+ }
+ return Promise.reject(error)
+ },
+);
+
+
+
+const request = (config: AxiosRequestConfig): Promise => {
+ const conf = config;
+ return new Promise((resolve, reject) => {
+ service.request>(conf).then((res: AxiosResponse) => {
+ const data = res.data
+ resolve(data as T);
+ }).catch(err => {
+ reject(err)
+ });
+ });
+};
+
+export function get(config: AxiosRequestConfig): Promise {
+ return request({ ...config, method: 'GET' });
+}
+
+export function post(config: AxiosRequestConfig): Promise {
+ return request({ ...config, method: 'POST' });
+}
+
+export default request;
+
+export type { AxiosInstance, AxiosResponse };
diff --git a/model/web/src/utils/http/axios/status.ts b/model/web/src/utils/http/axios/status.ts
new file mode 100644
index 0000000..4171f7f
--- /dev/null
+++ b/model/web/src/utils/http/axios/status.ts
@@ -0,0 +1,41 @@
+export const showMessage = (status: number | string): string => {
+ let message = '';
+ switch (status) {
+ case 400:
+ message = '请求错误(400)';
+ break;
+ case 401:
+ message = '未授权,请重新登录(401)';
+ break;
+ case 403:
+ message = '拒绝访问(403)';
+ break;
+ case 404:
+ message = '请求出错(404)';
+ break;
+ case 408:
+ message = '请求超时(408)';
+ break;
+ case 500:
+ message = '服务器错误(500)';
+ break;
+ case 501:
+ message = '服务未实现(501)';
+ break;
+ case 502:
+ message = '网络错误(502)';
+ break;
+ case 503:
+ message = '服务不可用(503)';
+ break;
+ case 504:
+ message = '网络超时(504)';
+ break;
+ case 505:
+ message = 'HTTP版本不受支持(505)';
+ break;
+ default:
+ message = `连接出错(${status})!`;
+ }
+ return `${message},请检查网络或联系管理员!`;
+};
diff --git a/model/web/src/utils/http/axios/type.ts b/model/web/src/utils/http/axios/type.ts
new file mode 100644
index 0000000..87ffde0
--- /dev/null
+++ b/model/web/src/utils/http/axios/type.ts
@@ -0,0 +1,20 @@
+export interface RequestOptions {
+ // Whether to process the request result
+ isTransformResponse?: boolean;
+}
+
+// 返回res.data的interface
+export interface IResponse {
+ code: number | string;
+ result: T;
+ message: string;
+ status: string | number;
+}
+
+/**用户登录 */
+export interface ILogin {
+ /** 账户名称 */
+ username: string;
+ /** 账户密码 */
+ password: string;
+}
diff --git a/model/web/src/utils/index.ts b/model/web/src/utils/index.ts
new file mode 100644
index 0000000..6b25bda
--- /dev/null
+++ b/model/web/src/utils/index.ts
@@ -0,0 +1,48 @@
+// import { resolve } from 'path';
+// const fs = require('fs');
+//
+// function pathResolve(dir: string) {
+// return resolve(process.cwd(), '.', dir);
+// }
+//
+// export const getFolder = (path: any) => {
+// const components: Array = [];
+// const files = fs.readdirSync(path);
+// files.forEach(function (item: string) {
+// const stat = fs.lstatSync(path + '/' + item);
+// if (stat.isDirectory() === true && item != 'components') {
+// components.push(path + '/' + item);
+// components.push(pathResolve(path + '/' + item));
+// }
+// });
+// return components;
+// };
+
+export function getFormatTime(dateTime,flag) {
+ if(dateTime != null ) {
+ //若传入的dateTime为字符串类型,需要进行转换成数值,若不是无需下面注释代码
+ var time = parseInt(dateTime)
+ var date = new Date(time);
+ //获取年份
+ var YY = date.getFullYear();
+ //获取月份
+ var MM = (date.getMonth() + 1 < 10 ? '0'+(date.getMonth() + 1) : date.getMonth() + 1);
+ //获取日期
+ var DD = (date.getDate() < 10 ? '0'+date.getDate() : date.getDate());
+ if(flag) { //flag为true,显示时分秒格式
+ //获取小时
+ var hh = (date.getHours() < 10 ? '0'+date.getHours() : date.getHours());
+ //获取分
+ var mm = (date.getMinutes() < 10 ? '0'+date.getMinutes() : date.getMinutes());
+ ///获取秒
+ var ss = (date.getSeconds() < 10 ? '0'+date.getSeconds() : date.getSeconds());
+ //返回时间格式: 2020-11-09 13:14:52
+ return YY + '-' + MM + '-' + DD + ' ' + hh + ':' + mm + ':' + ss;
+ } else {
+ //返回时间格式: 2020-11-09
+ return YY + '-' + MM + '-' + DD;
+ }
+ } else {
+ return "";
+ }
+}
diff --git a/model/web/src/utils/result.ts b/model/web/src/utils/result.ts
new file mode 100644
index 0000000..6501e65
--- /dev/null
+++ b/model/web/src/utils/result.ts
@@ -0,0 +1,55 @@
+import { Recoverable } from 'repl';
+
+// 返回统一格式的接口数据类型定义
+export function successResult(result: T, { message = 'Request success' } = {}) {
+ return {
+ code: 200,
+ result,
+ message,
+ status: 'ok',
+ };
+}
+export function errorResult(message = 'Request failed', { code = -1, result = null } = {}) {
+ return {
+ code,
+ result,
+ message,
+ status: 'fail',
+ };
+}
+
+//返回分页数据
+export function pageSuccessResult(page: number, pageSize: number, list: T[], { message = 'ok' } = {}) {
+ const pageData = pagination(page, pageSize, list);
+ return {
+ ...successResult({
+ items: pageData,
+ total: list.length,
+ }),
+ message,
+ };
+}
+
+// 封装分页数据
+export function pagination(pageNo: number, pageSize: number, array: T[]): T[] {
+ const offset = (pageNo - 1) * Number(pageSize);
+ const res =
+ offset + Number(pageSize) >= array.length ? array.slice(offset, array.length) : array.slice(offset, offset + Number(pageSize));
+ return res;
+}
+
+// 返回参数类型定义
+export interface requestParams {
+ method: string;
+ body: any;
+ headers?: { authorization?: string };
+ query: any;
+}
+
+/**
+ * @name getRequestToken
+ * @description 通过request数据中获取token,具体情况根据接口规范修改
+ */
+export function getRequestToken({ headers }: requestParams): string | undefined {
+ return headers?.authorization;
+}
diff --git a/model/web/src/views/admin/ad.vue b/model/web/src/views/admin/ad.vue
new file mode 100644
index 0000000..6ec5ada
--- /dev/null
+++ b/model/web/src/views/admin/ad.vue
@@ -0,0 +1,317 @@
+
+
+
+
+
+
+
+
+
+
+
+
+ 编辑
+
+
+ 删除
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 请选择要上传的广告图片
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/admin-login.vue b/model/web/src/views/admin/admin-login.vue
new file mode 100644
index 0000000..0285d7a
--- /dev/null
+++ b/model/web/src/views/admin/admin-login.vue
@@ -0,0 +1,182 @@
+
+
+
+
+
+
+
管理员登录
+
+
+
+
+
+
+
+
+
+
+
+
+ 登录
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/classification.vue b/model/web/src/views/admin/classification.vue
new file mode 100644
index 0000000..e1ad29a
--- /dev/null
+++ b/model/web/src/views/admin/classification.vue
@@ -0,0 +1,262 @@
+
+
+
+
+
+
+
+
+
+ 编辑
+
+
+ 删除
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/comment.vue b/model/web/src/views/admin/comment.vue
new file mode 100644
index 0000000..1412db0
--- /dev/null
+++ b/model/web/src/views/admin/comment.vue
@@ -0,0 +1,205 @@
+
+
+
+
+
+
+
+
+
+
+
+ 删除
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/error-log.vue b/model/web/src/views/admin/error-log.vue
new file mode 100644
index 0000000..265512d
--- /dev/null
+++ b/model/web/src/views/admin/error-log.vue
@@ -0,0 +1,137 @@
+
+
+
+
+
+
+
+
+ 编辑
+
+
+ 删除
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/login-log.vue b/model/web/src/views/admin/login-log.vue
new file mode 100644
index 0000000..378a202
--- /dev/null
+++ b/model/web/src/views/admin/login-log.vue
@@ -0,0 +1,126 @@
+
+
+
+
+
+
+
+
+ 编辑
+
+
+ 删除
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/main.vue b/model/web/src/views/admin/main.vue
new file mode 100644
index 0000000..553bc13
--- /dev/null
+++ b/model/web/src/views/admin/main.vue
@@ -0,0 +1,201 @@
+
+
+
+
+
+
+
+
+
+
+ 社团管理
+
+
+
+ 服务分类
+
+
+
+ 成员管理
+
+
+
+ 标签管理
+
+
+
+ 评论管理
+
+
+
+ 用户管理
+
+
+
+ 公告管理
+
+
+
+
+
+ 日志管理
+
+
+ 登录日志
+
+
+
+ 操作日志
+
+
+
+ 错误日志
+
+
+
+
+ 统计分析
+
+
+
+ 系统信息
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/notice.vue b/model/web/src/views/admin/notice.vue
new file mode 100644
index 0000000..21e208d
--- /dev/null
+++ b/model/web/src/views/admin/notice.vue
@@ -0,0 +1,286 @@
+
+
+
+
+
+
+
+
+
+ 编辑
+
+
+ 删除
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/op-log.vue b/model/web/src/views/admin/op-log.vue
new file mode 100644
index 0000000..809e5a0
--- /dev/null
+++ b/model/web/src/views/admin/op-log.vue
@@ -0,0 +1,139 @@
+
+
+
+
+
+
+
+
+ 编辑
+
+
+ 删除
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/order.vue b/model/web/src/views/admin/order.vue
new file mode 100644
index 0000000..0fca1a1
--- /dev/null
+++ b/model/web/src/views/admin/order.vue
@@ -0,0 +1 @@
+
{{ text === '1' ? '待审核' : text === '2' ? '已通过' : '已取消' }}
通过
取消
删除
\ No newline at end of file
diff --git a/model/web/src/views/admin/overview.vue b/model/web/src/views/admin/overview.vue
new file mode 100644
index 0000000..1a96930
--- /dev/null
+++ b/model/web/src/views/admin/overview.vue
@@ -0,0 +1,331 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/sys-info.vue b/model/web/src/views/admin/sys-info.vue
new file mode 100644
index 0000000..5937fba
--- /dev/null
+++ b/model/web/src/views/admin/sys-info.vue
@@ -0,0 +1,82 @@
+
+
+
+
+
+ {{ data.sysName }}
+
+
+ {{ data.versionName }}
+
+
+ {{ data.osName }}
+
+
+ {{ data.pf }}
+
+
+ {{ data.cpuCount }}
+
+
+ {{ data.processor }}
+
+ {{ data.cpuLoad }}%
+ {{ data.memory }}G
+ {{ data.usedMemory }}G
+ {{ data.percentMemory }}%
+
+ {{ data.sysLan }}
+
+ 5.7.37
+ 1.20.1
+
+ {{ data.sysZone }}
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/tag.vue b/model/web/src/views/admin/tag.vue
new file mode 100644
index 0000000..ece6b18
--- /dev/null
+++ b/model/web/src/views/admin/tag.vue
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/model/web/src/views/admin/thing.vue b/model/web/src/views/admin/thing.vue
new file mode 100644
index 0000000..5fc034e
--- /dev/null
+++ b/model/web/src/views/admin/thing.vue
@@ -0,0 +1,481 @@
+
+
+
+
+
+
+
+
+
+ 编辑
+
+
+ 删除
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{ item.title }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 请选择要上传的图片
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 在营
+ 暂停
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/admin/user.vue b/model/web/src/views/admin/user.vue
new file mode 100644
index 0000000..acf9c51
--- /dev/null
+++ b/model/web/src/views/admin/user.vue
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/model/web/src/views/index/components/content.vue b/model/web/src/views/index/components/content.vue
new file mode 100644
index 0000000..4750ed2
--- /dev/null
+++ b/model/web/src/views/index/components/content.vue
@@ -0,0 +1,563 @@
+
+
+
+
+
热门标签
+
+ {{ item.title }}
+
+
+
+
+
+
+
+
+ {{ item }}
+
+
+
+
+
+
+
+
+
+
{{ item.title.substring(0, 12) }}
+
+
+ {{ item.location }}
+
+
+
+
暂无数据
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/components/footer.vue b/model/web/src/views/index/components/footer.vue
new file mode 100644
index 0000000..a7b354e
--- /dev/null
+++ b/model/web/src/views/index/components/footer.vue
@@ -0,0 +1,93 @@
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/components/header.vue b/model/web/src/views/index/components/header.vue
new file mode 100644
index 0000000..41b09ac
--- /dev/null
+++ b/model/web/src/views/index/components/header.vue
@@ -0,0 +1,340 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/components/search-content-view.vue b/model/web/src/views/index/components/search-content-view.vue
new file mode 100644
index 0000000..b49d9a5
--- /dev/null
+++ b/model/web/src/views/index/components/search-content-view.vue
@@ -0,0 +1,237 @@
+
+
+
{{ tData.keyword }}
+
+
+ 与
+ {{ tData.keyword }}
+ 相关的内容
+
+
+
+
+
+
+
+
+
+
{{ item.title.substring(0, 12) }}
+
+
+ {{ item.location }}
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/confirm.vue b/model/web/src/views/index/confirm.vue
new file mode 100644
index 0000000..cb02652
--- /dev/null
+++ b/model/web/src/views/index/confirm.vue
@@ -0,0 +1,586 @@
+
+
+
+
+
+
+
订单明细
+
+
+
+ 商品名称
+ 价格
+ 数量
+ 操作
+
+
+
+
+
+
{{ pageData.title }}
+
+
¥{{ pageData.price }}
+
+
+
+
+
+
+
备注
+
+
+
+
+
+
收货地址
+
+
+
+ 收件人:
+ {{ pageData.receiverName }}
+ {{ pageData.receiverPhone }}
+
+
{{ pageData.receiverAddress }}
+
+ 目前暂无地址信息,请
+ 新建地址
+
+
+
+
结算
+ 价格
+
+
+
+
商品总价
+
¥{{ pageData.amount }}
+
+
+
+
+
合计
+
+ ¥{{ pageData.amount }}
+
+
+
+ 返回
+ 结算
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/detail.vue b/model/web/src/views/index/detail.vue
new file mode 100644
index 0000000..b5790d0
--- /dev/null
+++ b/model/web/src/views/index/detail.vue
@@ -0,0 +1,966 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 信息状态
+ 有效
+
+
{{ detailData.title }}
+
+
+
+
+ 社团类型:
+ {{ detailData.classification_title }}
+
+
+ 社团地址:
+ {{ detailData.location }}
+
+
+ 社团宗旨:
+ {{ detailData.zongzhi }}
+
+
+ 社团邮箱:
+ {{ detailData.email }}
+
+
+ 社团手机号:
+ {{ detailData.mobile }}
+
+
+
+
+ 申请加入
+
+
+
+
+
+
+
+
+
+
+
+ 加入心愿单
+
+
+ {{ detailData.wish_count }}
+
+
+
+
+
+
+
+
+
+ 收藏
+
+
+ {{ detailData.collect_count }}
+
+
+
+
+
+
+
+
+
+ 分享
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{ item }}
+
+
+
+
+
+
+
{{ detailData.description }}
+
+
+
+
+
+
+
热门推荐
+
+
+
+
+
{{ item.title.substring(0, 12) }}
+
+
+ {{ item.location }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/index.vue b/model/web/src/views/index/index.vue
new file mode 100644
index 0000000..9e31003
--- /dev/null
+++ b/model/web/src/views/index/index.vue
@@ -0,0 +1,8 @@
+
+
+
+
+
diff --git a/model/web/src/views/index/login.vue b/model/web/src/views/index/login.vue
new file mode 100644
index 0000000..10b9235
--- /dev/null
+++ b/model/web/src/views/index/login.vue
@@ -0,0 +1,274 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/pay.vue b/model/web/src/views/index/pay.vue
new file mode 100644
index 0000000..015606c
--- /dev/null
+++ b/model/web/src/views/index/pay.vue
@@ -0,0 +1,217 @@
+
+
+
+
+
订单提交成功
+
+ 请在
+ {{ ddlTime }}
+ 之前付款,超时订单将自动取消
+
+
支付金额
+
+ {{ amount }}
+ 元
+
+
+
+
+
+
微信支付
+
+
+
+
支付宝
+
+
+
请选择任意一种支付方式
+
确认支付
+
+
+
正在生成安全支付二维码
+
+
+
请打开微信扫一扫进行支付
+
支付完成
+
选择其他支付方式
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/portal.vue b/model/web/src/views/index/portal.vue
new file mode 100644
index 0000000..878790c
--- /dev/null
+++ b/model/web/src/views/index/portal.vue
@@ -0,0 +1,24 @@
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/register.vue b/model/web/src/views/index/register.vue
new file mode 100644
index 0000000..e0511b1
--- /dev/null
+++ b/model/web/src/views/index/register.vue
@@ -0,0 +1,208 @@
+
+
+
+
+ 注册新账号
+ 我要登录
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/search.vue b/model/web/src/views/index/search.vue
new file mode 100644
index 0000000..b714136
--- /dev/null
+++ b/model/web/src/views/index/search.vue
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/address-view.vue b/model/web/src/views/index/user/address-view.vue
new file mode 100644
index 0000000..a863e4d
--- /dev/null
+++ b/model/web/src/views/index/user/address-view.vue
@@ -0,0 +1,336 @@
+
+
+
+
+ 地址管理
+ 新建地址
+
+
+
+
+
+
+ {{item.name}}
+ {{item.mobile}}
+
+
{{item.desc}}
+
+
+
+
+
+
默认地址
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/collect-thing-view.vue b/model/web/src/views/index/user/collect-thing-view.vue
new file mode 100644
index 0000000..4f7d3bc
--- /dev/null
+++ b/model/web/src/views/index/user/collect-thing-view.vue
@@ -0,0 +1,194 @@
+
+
+
我的收藏
+
+
+
+
+
+
+
+
移出
+
+
+
+
+
{{item.title}}
+
{{item.author}}(作者)
+
{{item.translator}}(译者)
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/comment-view.vue b/model/web/src/views/index/user/comment-view.vue
new file mode 100644
index 0000000..27c4f23
--- /dev/null
+++ b/model/web/src/views/index/user/comment-view.vue
@@ -0,0 +1,155 @@
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/fans-view.vue b/model/web/src/views/index/user/fans-view.vue
new file mode 100644
index 0000000..0829c8e
--- /dev/null
+++ b/model/web/src/views/index/user/fans-view.vue
@@ -0,0 +1,103 @@
+
+
+
我的粉丝
+
+
+
+
+
+
Python_C
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/follow-view.vue b/model/web/src/views/index/user/follow-view.vue
new file mode 100644
index 0000000..0a6bcd5
--- /dev/null
+++ b/model/web/src/views/index/user/follow-view.vue
@@ -0,0 +1,104 @@
+
+
+
我的关注
+
+
+
+
+
+
Python_C
+ 取消关注
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/jiajiao-edit-view.vue b/model/web/src/views/index/user/jiajiao-edit-view.vue
new file mode 100644
index 0000000..0d71c3b
--- /dev/null
+++ b/model/web/src/views/index/user/jiajiao-edit-view.vue
@@ -0,0 +1,374 @@
+
+
+
社团入驻
+
+
+
+
+
头像
+
+
+
+
+
+ 点击更换头像
+
+
图片格式支持 GIF、PNG、JPEG,尺寸不小于 200 PX,小于 4 MB
+
+
+
+
+
姓名
+
+
+
支持中英文,长度不能超过 20 个字符
+
+
+
+
+
+
+
+
+
+
保存
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/message-view.vue b/model/web/src/views/index/user/message-view.vue
new file mode 100644
index 0000000..26ac70f
--- /dev/null
+++ b/model/web/src/views/index/user/message-view.vue
@@ -0,0 +1,143 @@
+
+
+
我的消息
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/mine-infos-view.vue b/model/web/src/views/index/user/mine-infos-view.vue
new file mode 100644
index 0000000..281d1ab
--- /dev/null
+++ b/model/web/src/views/index/user/mine-infos-view.vue
@@ -0,0 +1,351 @@
+
+
+
+
+
+
{{ userStore.user_name }}
+
+ 活跃1天
+
+
+
+
+
+
+
+
收藏
+
{{ collectCount }}
+
+
+
+
心愿单
+
{{ wishCount }}
+
+
+
+
+
+
+
+
+
+
+
个人设置
+
+
+
+
我的申请
+
+
+
+
编辑资料
+
+
+
+
账号安全
+
+
+
+
推送设置
+
+
+
+
消息管理
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/modal/edit-address.vue b/model/web/src/views/index/user/modal/edit-address.vue
new file mode 100644
index 0000000..ed366ba
--- /dev/null
+++ b/model/web/src/views/index/user/modal/edit-address.vue
@@ -0,0 +1,116 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/order-view.vue b/model/web/src/views/index/user/order-view.vue
new file mode 100644
index 0000000..d87e867
--- /dev/null
+++ b/model/web/src/views/index/user/order-view.vue
@@ -0,0 +1,356 @@
+
+
+
我的申请
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
{{ item.title }}
+
+
+
+
+
+
+
+
+
+
+
+ 共{{ item.count }}件
+ 社团详情
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/push-view.vue b/model/web/src/views/index/user/push-view.vue
new file mode 100644
index 0000000..8a77124
--- /dev/null
+++ b/model/web/src/views/index/user/push-view.vue
@@ -0,0 +1,183 @@
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/score-view.vue b/model/web/src/views/index/user/score-view.vue
new file mode 100644
index 0000000..7f8dc6c
--- /dev/null
+++ b/model/web/src/views/index/user/score-view.vue
@@ -0,0 +1,67 @@
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/security-view.vue b/model/web/src/views/index/user/security-view.vue
new file mode 100644
index 0000000..a06fff7
--- /dev/null
+++ b/model/web/src/views/index/user/security-view.vue
@@ -0,0 +1,197 @@
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/userinfo-edit-view.vue b/model/web/src/views/index/user/userinfo-edit-view.vue
new file mode 100644
index 0000000..cb467ad
--- /dev/null
+++ b/model/web/src/views/index/user/userinfo-edit-view.vue
@@ -0,0 +1,280 @@
+
+
+
设置
+
+
+
+
+
头像
+
+
+
+
+
+ 点击更换头像
+
+
图片格式支持 GIF、PNG、JPEG,尺寸不小于 200 PX,小于 4 MB
+
+
+
+
+
昵称
+
+
+
支持中英文,长度不能超过 20 个字符
+
+
+
+
+
+
保存
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/user/wish-thing-view.vue b/model/web/src/views/index/user/wish-thing-view.vue
new file mode 100644
index 0000000..fdb2138
--- /dev/null
+++ b/model/web/src/views/index/user/wish-thing-view.vue
@@ -0,0 +1,193 @@
+
+
+
我的心愿单
+
+
+
+
+
+
+
+
移出
+
+
+
+
+
{{item.title}}
+
{{item.author}}(作者)
+
{{item.translator}}(译者)
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/model/web/src/views/index/usercenter.vue b/model/web/src/views/index/usercenter.vue
new file mode 100644
index 0000000..9e9a52e
--- /dev/null
+++ b/model/web/src/views/index/usercenter.vue
@@ -0,0 +1,54 @@
+
+
+
+
+
diff --git a/model/web/stylelint.config.js b/model/web/stylelint.config.js
new file mode 100644
index 0000000..58b3812
--- /dev/null
+++ b/model/web/stylelint.config.js
@@ -0,0 +1,89 @@
+module.exports = {
+ root: true,
+ plugins: ['stylelint-order'],
+ extends: ['stylelint-config-standard', 'stylelint-config-prettier'],
+ customSyntax: 'postcss-html',
+ rules: {
+ 'function-no-unknown': null,
+ 'selector-class-pattern': null,
+ 'selector-pseudo-class-no-unknown': [
+ true,
+ {
+ ignorePseudoClasses: ['global'],
+ },
+ ],
+ 'selector-pseudo-element-no-unknown': [
+ true,
+ {
+ ignorePseudoElements: ['v-deep'],
+ },
+ ],
+ 'at-rule-no-unknown': [
+ true,
+ {
+ ignoreAtRules: ['tailwind', 'apply', 'variants', 'responsive', 'screen', 'function', 'if', 'each', 'include', 'mixin'],
+ },
+ ],
+ 'no-empty-source': null,
+ 'string-quotes': null,
+ 'named-grid-areas-no-invalid': null,
+ 'unicode-bom': 'never',
+ 'no-descending-specificity': null,
+ 'font-family-no-missing-generic-family-keyword': null,
+ 'declaration-colon-space-after': 'always-single-line',
+ 'declaration-colon-space-before': 'never',
+ // 'declaration-block-trailing-semicolon': 'always',
+ 'rule-empty-line-before': [
+ 'always',
+ {
+ ignore: ['after-comment', 'first-nested'],
+ },
+ ],
+ 'unit-no-unknown': [true, { ignoreUnits: ['rpx'] }],
+ 'order/order': [
+ [
+ 'dollar-variables',
+ 'custom-properties',
+ 'at-rules',
+ 'declarations',
+ {
+ type: 'at-rule',
+ name: 'supports',
+ },
+ {
+ type: 'at-rule',
+ name: 'media',
+ },
+ 'rules',
+ ],
+ { severity: 'warning' },
+ ],
+ },
+ ignoreFiles: ['**/*.js', '**/*.jsx', '**/*.tsx', '**/*.ts'],
+ overrides: [
+ {
+ files: ['*.vue', '**/*.vue', '*.html', '**/*.html'],
+ extends: ['stylelint-config-recommended'],
+ rules: {
+ 'keyframes-name-pattern': null,
+ 'selector-pseudo-class-no-unknown': [
+ true,
+ {
+ ignorePseudoClasses: ['deep', 'global'],
+ },
+ ],
+ 'selector-pseudo-element-no-unknown': [
+ true,
+ {
+ ignorePseudoElements: ['v-deep', 'v-global', 'v-slotted'],
+ },
+ ],
+ },
+ },
+ {
+ files: ['*.less', '**/*.less'],
+ customSyntax: 'postcss-less',
+ extends: ['stylelint-config-standard', 'stylelint-config-recommended-vue'],
+ },
+ ],
+};
diff --git a/model/web/tsconfig.json b/model/web/tsconfig.json
new file mode 100644
index 0000000..32c3e59
--- /dev/null
+++ b/model/web/tsconfig.json
@@ -0,0 +1,44 @@
+{
+ "compilerOptions": {
+ "target": "esnext",
+ "module": "esnext",
+ "moduleResolution": "node",
+ "strict": true,
+ "noLib": false,
+ "forceConsistentCasingInFileNames": true,
+ "allowSyntheticDefaultImports": true,
+ "strictFunctionTypes": false,
+ "jsx": "preserve",
+ "baseUrl": ".",
+ "allowJs": true,
+ "sourceMap": true,
+ "esModuleInterop": true,
+ "resolveJsonModule": true,
+ "noUnusedLocals": false,
+ "noUnusedParameters": false,
+ "experimentalDecorators": true,
+ "lib": ["dom", "esnext"],
+ "noImplicitAny": false,
+ "skipLibCheck": true,
+ "types": ["vite/client"],
+ "removeComments": true,
+ "paths": {
+ "/@/*": ["src/*"],
+ "/#/*": ["types/*"]
+ }
+ },
+ "include": [
+ "tests/**/*.ts",
+ "src/**/*.ts",
+ "src/**/*.d.ts",
+ "src/**/*.tsx",
+ "src/**/*.vue",
+ "types/**/*.d.ts",
+ "types/**/*.ts",
+ "build/**/*.ts",
+ "build/**/*.d.ts",
+ "mock/**/*.ts",
+ "vite.config.ts"
+ ],
+ "exclude": ["node_modules", "tests/server/**/*.ts", "dist", "**/*.js"]
+}
diff --git a/model/web/types/auto-imports.d.ts b/model/web/types/auto-imports.d.ts
new file mode 100644
index 0000000..17575c2
--- /dev/null
+++ b/model/web/types/auto-imports.d.ts
@@ -0,0 +1,77 @@
+// Generated by 'unplugin-auto-import'
+export {}
+declare global {
+ const EffectScope: typeof import('vue')['EffectScope']
+ const acceptHMRUpdate: typeof import('pinia')['acceptHMRUpdate']
+ const computed: typeof import('vue')['computed']
+ const createApp: typeof import('vue')['createApp']
+ const createPinia: typeof import('pinia')['createPinia']
+ const customRef: typeof import('vue')['customRef']
+ const defineAsyncComponent: typeof import('vue')['defineAsyncComponent']
+ const defineComponent: typeof import('vue')['defineComponent']
+ const defineStore: typeof import('pinia')['defineStore']
+ const effectScope: typeof import('vue')['effectScope']
+ const getActivePinia: typeof import('pinia')['getActivePinia']
+ const getCurrentInstance: typeof import('vue')['getCurrentInstance']
+ const getCurrentScope: typeof import('vue')['getCurrentScope']
+ const h: typeof import('vue')['h']
+ const inject: typeof import('vue')['inject']
+ const isProxy: typeof import('vue')['isProxy']
+ const isReactive: typeof import('vue')['isReactive']
+ const isReadonly: typeof import('vue')['isReadonly']
+ const isRef: typeof import('vue')['isRef']
+ const mapActions: typeof import('pinia')['mapActions']
+ const mapGetters: typeof import('pinia')['mapGetters']
+ const mapState: typeof import('pinia')['mapState']
+ const mapStores: typeof import('pinia')['mapStores']
+ const mapWritableState: typeof import('pinia')['mapWritableState']
+ const markRaw: typeof import('vue')['markRaw']
+ const nextTick: typeof import('vue')['nextTick']
+ const onActivated: typeof import('vue')['onActivated']
+ const onBeforeMount: typeof import('vue')['onBeforeMount']
+ const onBeforeRouteLeave: typeof import('vue-router')['onBeforeRouteLeave']
+ const onBeforeRouteUpdate: typeof import('vue-router')['onBeforeRouteUpdate']
+ const onBeforeUnmount: typeof import('vue')['onBeforeUnmount']
+ const onBeforeUpdate: typeof import('vue')['onBeforeUpdate']
+ const onDeactivated: typeof import('vue')['onDeactivated']
+ const onErrorCaptured: typeof import('vue')['onErrorCaptured']
+ const onMounted: typeof import('vue')['onMounted']
+ const onRenderTracked: typeof import('vue')['onRenderTracked']
+ const onRenderTriggered: typeof import('vue')['onRenderTriggered']
+ const onScopeDispose: typeof import('vue')['onScopeDispose']
+ const onServerPrefetch: typeof import('vue')['onServerPrefetch']
+ const onUnmounted: typeof import('vue')['onUnmounted']
+ const onUpdated: typeof import('vue')['onUpdated']
+ const provide: typeof import('vue')['provide']
+ const reactive: typeof import('vue')['reactive']
+ const readonly: typeof import('vue')['readonly']
+ const ref: typeof import('vue')['ref']
+ const resolveComponent: typeof import('vue')['resolveComponent']
+ const resolveDirective: typeof import('vue')['resolveDirective']
+ const setActivePinia: typeof import('pinia')['setActivePinia']
+ const setMapStoreSuffix: typeof import('pinia')['setMapStoreSuffix']
+ const shallowReactive: typeof import('vue')['shallowReactive']
+ const shallowReadonly: typeof import('vue')['shallowReadonly']
+ const shallowRef: typeof import('vue')['shallowRef']
+ const storeToRefs: typeof import('pinia')['storeToRefs']
+ const toRaw: typeof import('vue')['toRaw']
+ const toRef: typeof import('vue')['toRef']
+ const toRefs: typeof import('vue')['toRefs']
+ const triggerRef: typeof import('vue')['triggerRef']
+ const unref: typeof import('vue')['unref']
+ const useAttrs: typeof import('vue')['useAttrs']
+ const useCssModule: typeof import('vue')['useCssModule']
+ const useCssVars: typeof import('vue')['useCssVars']
+ const useDialog: typeof import('naive-ui')['useDialog']
+ const useLink: typeof import('vue-router')['useLink']
+ const useLoadingBar: typeof import('naive-ui')['useLoadingBar']
+ const useMessage: typeof import('naive-ui')['useMessage']
+ const useNotification: typeof import('naive-ui')['useNotification']
+ const useRoute: typeof import('vue-router')['useRoute']
+ const useRouter: typeof import('vue-router')['useRouter']
+ const useSlots: typeof import('vue')['useSlots']
+ const watch: typeof import('vue')['watch']
+ const watchEffect: typeof import('vue')['watchEffect']
+ const watchPostEffect: typeof import('vue')['watchPostEffect']
+ const watchSyncEffect: typeof import('vue')['watchSyncEffect']
+}
diff --git a/model/web/types/components.d.ts b/model/web/types/components.d.ts
new file mode 100644
index 0000000..5b80772
--- /dev/null
+++ b/model/web/types/components.d.ts
@@ -0,0 +1,54 @@
+// generated by unplugin-vue-components
+// We suggest you to commit this file into source control
+// Read more: https://github.com/vuejs/core/pull/3399
+import '@vue/runtime-core'
+
+export {}
+
+declare module '@vue/runtime-core' {
+ export interface GlobalComponents {
+ AButton: typeof import('ant-design-vue/es')['Button']
+ ACard: typeof import('ant-design-vue/es')['Card']
+ ACol: typeof import('ant-design-vue/es')['Col']
+ AConfigProvider: typeof import('ant-design-vue/es')['ConfigProvider']
+ ADescriptions: typeof import('ant-design-vue/es')['Descriptions']
+ ADescriptionsItem: typeof import('ant-design-vue/es')['DescriptionsItem']
+ ADivider: typeof import('ant-design-vue/es')['Divider']
+ ADrawer: typeof import('ant-design-vue/es')['Drawer']
+ ADropdown: typeof import('ant-design-vue/es')['Dropdown']
+ AForm: typeof import('ant-design-vue/es')['Form']
+ AFormItem: typeof import('ant-design-vue/es')['FormItem']
+ AInput: typeof import('ant-design-vue/es')['Input']
+ AInputNumber: typeof import('ant-design-vue/es')['InputNumber']
+ AInputPassword: typeof import('ant-design-vue/es')['InputPassword']
+ AInputSearch: typeof import('ant-design-vue/es')['InputSearch']
+ ALayout: typeof import('ant-design-vue/es')['Layout']
+ ALayoutContent: typeof import('ant-design-vue/es')['LayoutContent']
+ ALayoutHeader: typeof import('ant-design-vue/es')['LayoutHeader']
+ ALayoutSider: typeof import('ant-design-vue/es')['LayoutSider']
+ AMenu: typeof import('ant-design-vue/es')['Menu']
+ AMenuItem: typeof import('ant-design-vue/es')['MenuItem']
+ AModal: typeof import('ant-design-vue/es')['Modal']
+ APagination: typeof import('ant-design-vue/es')['Pagination']
+ APopconfirm: typeof import('ant-design-vue/es')['Popconfirm']
+ ARow: typeof import('ant-design-vue/es')['Row']
+ ASelect: typeof import('ant-design-vue/es')['Select']
+ ASelectOption: typeof import('ant-design-vue/es')['SelectOption']
+ ASpace: typeof import('ant-design-vue/es')['Space']
+ ASpin: typeof import('ant-design-vue/es')['Spin']
+ ASubMenu: typeof import('ant-design-vue/es')['SubMenu']
+ ASwitch: typeof import('ant-design-vue/es')['Switch']
+ ATable: typeof import('ant-design-vue/es')['Table']
+ ATabPane: typeof import('ant-design-vue/es')['TabPane']
+ ATabs: typeof import('ant-design-vue/es')['Tabs']
+ ATag: typeof import('ant-design-vue/es')['Tag']
+ ATextarea: typeof import('ant-design-vue/es')['Textarea']
+ ATree: typeof import('ant-design-vue/es')['Tree']
+ ATreeSelect: typeof import('ant-design-vue/es')['TreeSelect']
+ ATreeSelectNode: typeof import('ant-design-vue/es')['TreeSelectNode']
+ AUpload: typeof import('ant-design-vue/es')['Upload']
+ AUploadDragger: typeof import('ant-design-vue/es')['UploadDragger']
+ RouterLink: typeof import('vue-router')['RouterLink']
+ RouterView: typeof import('vue-router')['RouterView']
+ }
+}
diff --git a/model/web/types/env.d.ts b/model/web/types/env.d.ts
new file mode 100644
index 0000000..e4bb38f
--- /dev/null
+++ b/model/web/types/env.d.ts
@@ -0,0 +1,12 @@
+///
+
+declare module '*.vue' {
+ import { DefineComponent } from 'vue';
+ const component: DefineComponent<{}, {}, any>;
+ export default component;
+}
+
+declare module 'virtual:*' {
+ const result: any;
+ export default result;
+}
diff --git a/model/web/vite.config.ts b/model/web/vite.config.ts
new file mode 100644
index 0000000..bb25032
--- /dev/null
+++ b/model/web/vite.config.ts
@@ -0,0 +1,53 @@
+import { UserConfig, ConfigEnv } from 'vite';
+import { createVitePlugins } from './build/vite/plugins';
+import { resolve } from 'path';
+import { VITE_PORT } from './build/constant';
+
+function pathResolve(dir: string) {
+ return resolve(process.cwd(), '.', dir);
+}
+
+// https://vitejs.dev/config/
+export default ({ command }: ConfigEnv): UserConfig => {
+ const isBuild = command === 'build';
+ let base: string;
+ if (command === 'build') {
+ base = '/';
+ } else {
+ base = '/';
+ }
+ return {
+ base,
+ publicDir: "public", //静态资源服务的文件夹
+ resolve: {
+ alias: [
+ {
+ find: 'vue-i18n',
+ replacement: 'vue-i18n/dist/vue-i18n.cjs.js',
+ },
+ // 别名 /@/xxxx => src/xxxx
+ {
+ find: '/@',
+ replacement: pathResolve('src') + '/',
+ },
+ ],
+ },
+ // plugins
+ plugins: createVitePlugins(isBuild),
+
+ // css
+ css: {},
+
+ // server
+ server: {
+ hmr: { overlay: false }, // 禁用或配置 HMR 连接 设置 server.hmr.overlay 为 false 可以禁用服务器错误遮罩层
+ // 服务配置
+ port: VITE_PORT, // 类型: number 指定服务器端口;
+ open: false, // 类型: boolean | string在服务器启动时自动在浏览器中打开应用程序;
+ cors: true, // 类型: boolean | CorsOptions 为开发服务器配置 CORS。默认启用并允许任何源
+ host: '0.0.0.0', // IP配置,支持从IP启动
+ https: false, // 禁用https
+ // proxy,
+ },
+ };
+};
diff --git a/model/web/yarn.lock b/model/web/yarn.lock
new file mode 100644
index 0000000..a1699df
--- /dev/null
+++ b/model/web/yarn.lock
@@ -0,0 +1,3600 @@
+# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
+# yarn lockfile v1
+
+
+"@ampproject/remapping@^2.1.0":
+ version "2.2.0"
+ resolved "https://registry.npmmirror.com/@ampproject/remapping/-/remapping-2.2.0.tgz"
+ integrity sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==
+ dependencies:
+ "@jridgewell/gen-mapping" "^0.1.0"
+ "@jridgewell/trace-mapping" "^0.3.9"
+
+"@ant-design/colors@^6.0.0":
+ version "6.0.0"
+ resolved "https://registry.npmmirror.com/@ant-design/colors/-/colors-6.0.0.tgz"
+ integrity sha512-qAZRvPzfdWHtfameEGP2Qvuf838NhergR35o+EuVyB5XvSA98xod5r4utvi4TJ3ywmevm290g9nsCG5MryrdWQ==
+ dependencies:
+ "@ctrl/tinycolor" "^3.4.0"
+
+"@ant-design/icons-svg@^4.2.1":
+ version "4.2.1"
+ resolved "https://registry.npmmirror.com/@ant-design/icons-svg/-/icons-svg-4.2.1.tgz"
+ integrity sha512-EB0iwlKDGpG93hW8f85CTJTs4SvMX7tt5ceupvhALp1IF44SeUFOMhKUOYqpsoYWQKAOuTRDMqn75rEaKDp0Xw==
+
+"@ant-design/icons-vue@^6.1.0":
+ version "6.1.0"
+ resolved "https://registry.npmmirror.com/@ant-design/icons-vue/-/icons-vue-6.1.0.tgz"
+ integrity sha512-EX6bYm56V+ZrKN7+3MT/ubDkvJ5rK/O2t380WFRflDcVFgsvl3NLH7Wxeau6R8DbrO5jWR6DSTC3B6gYFp77AA==
+ dependencies:
+ "@ant-design/colors" "^6.0.0"
+ "@ant-design/icons-svg" "^4.2.1"
+
+"@antfu/utils@^0.7.2":
+ version "0.7.2"
+ resolved "https://registry.npmmirror.com/@antfu/utils/-/utils-0.7.2.tgz"
+ integrity sha512-vy9fM3pIxZmX07dL+VX1aZe7ynZ+YyB0jY+jE6r3hOK6GNY2t6W8rzpFC4tgpbXUYABkFQwgJq2XYXlxbXAI0g==
+
+"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.18.6":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/code-frame/-/code-frame-7.18.6.tgz"
+ integrity sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==
+ dependencies:
+ "@babel/highlight" "^7.18.6"
+
+"@babel/compat-data@^7.20.5":
+ version "7.20.14"
+ resolved "https://registry.npmmirror.com/@babel/compat-data/-/compat-data-7.20.14.tgz"
+ integrity sha512-0YpKHD6ImkWMEINCyDAD0HLLUH/lPCefG8ld9it8DJB2wnApraKuhgYTvTY1z7UFIfBTGy5LwncZ+5HWWGbhFw==
+
+"@babel/core@^7.0.0", "@babel/core@^7.0.0-0", "@babel/core@^7.20.5":
+ version "7.20.12"
+ resolved "https://registry.npmmirror.com/@babel/core/-/core-7.20.12.tgz"
+ integrity sha512-XsMfHovsUYHFMdrIHkZphTN/2Hzzi78R08NuHfDBehym2VsPDL6Zn/JAD/JQdnRvbSsbQc4mVaU1m6JgtTEElg==
+ dependencies:
+ "@ampproject/remapping" "^2.1.0"
+ "@babel/code-frame" "^7.18.6"
+ "@babel/generator" "^7.20.7"
+ "@babel/helper-compilation-targets" "^7.20.7"
+ "@babel/helper-module-transforms" "^7.20.11"
+ "@babel/helpers" "^7.20.7"
+ "@babel/parser" "^7.20.7"
+ "@babel/template" "^7.20.7"
+ "@babel/traverse" "^7.20.12"
+ "@babel/types" "^7.20.7"
+ convert-source-map "^1.7.0"
+ debug "^4.1.0"
+ gensync "^1.0.0-beta.2"
+ json5 "^2.2.2"
+ semver "^6.3.0"
+
+"@babel/generator@^7.20.7":
+ version "7.20.14"
+ resolved "https://registry.npmmirror.com/@babel/generator/-/generator-7.20.14.tgz"
+ integrity sha512-AEmuXHdcD3A52HHXxaTmYlb8q/xMEhoRP67B3T4Oq7lbmSoqroMZzjnGj3+i1io3pdnF8iBYVu4Ilj+c4hBxYg==
+ dependencies:
+ "@babel/types" "^7.20.7"
+ "@jridgewell/gen-mapping" "^0.3.2"
+ jsesc "^2.5.1"
+
+"@babel/helper-annotate-as-pure@^7.18.6":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz"
+ integrity sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==
+ dependencies:
+ "@babel/types" "^7.18.6"
+
+"@babel/helper-compilation-targets@^7.20.7":
+ version "7.20.7"
+ resolved "https://registry.npmmirror.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.7.tgz"
+ integrity sha512-4tGORmfQcrc+bvrjb5y3dG9Mx1IOZjsHqQVUz7XCNHO+iTmqxWnVg3KRygjGmpRLJGdQSKuvFinbIb0CnZwHAQ==
+ dependencies:
+ "@babel/compat-data" "^7.20.5"
+ "@babel/helper-validator-option" "^7.18.6"
+ browserslist "^4.21.3"
+ lru-cache "^5.1.1"
+ semver "^6.3.0"
+
+"@babel/helper-create-class-features-plugin@^7.20.12":
+ version "7.20.12"
+ resolved "https://registry.npmmirror.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.20.12.tgz"
+ integrity sha512-9OunRkbT0JQcednL0UFvbfXpAsUXiGjUk0a7sN8fUXX7Mue79cUSMjHGDRRi/Vz9vYlpIhLV5fMD5dKoMhhsNQ==
+ dependencies:
+ "@babel/helper-annotate-as-pure" "^7.18.6"
+ "@babel/helper-environment-visitor" "^7.18.9"
+ "@babel/helper-function-name" "^7.19.0"
+ "@babel/helper-member-expression-to-functions" "^7.20.7"
+ "@babel/helper-optimise-call-expression" "^7.18.6"
+ "@babel/helper-replace-supers" "^7.20.7"
+ "@babel/helper-skip-transparent-expression-wrappers" "^7.20.0"
+ "@babel/helper-split-export-declaration" "^7.18.6"
+
+"@babel/helper-environment-visitor@^7.18.9":
+ version "7.18.9"
+ resolved "https://registry.npmmirror.com/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz"
+ integrity sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==
+
+"@babel/helper-function-name@^7.19.0":
+ version "7.19.0"
+ resolved "https://registry.npmmirror.com/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz"
+ integrity sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==
+ dependencies:
+ "@babel/template" "^7.18.10"
+ "@babel/types" "^7.19.0"
+
+"@babel/helper-hoist-variables@^7.18.6":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz"
+ integrity sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==
+ dependencies:
+ "@babel/types" "^7.18.6"
+
+"@babel/helper-member-expression-to-functions@^7.20.7":
+ version "7.20.7"
+ resolved "https://registry.npmmirror.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.20.7.tgz"
+ integrity sha512-9J0CxJLq315fEdi4s7xK5TQaNYjZw+nDVpVqr1axNGKzdrdwYBD5b4uKv3n75aABG0rCCTK8Im8Ww7eYfMrZgw==
+ dependencies:
+ "@babel/types" "^7.20.7"
+
+"@babel/helper-module-imports@^7.0.0", "@babel/helper-module-imports@^7.18.6":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz"
+ integrity sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==
+ dependencies:
+ "@babel/types" "^7.18.6"
+
+"@babel/helper-module-transforms@^7.20.11":
+ version "7.20.11"
+ resolved "https://registry.npmmirror.com/@babel/helper-module-transforms/-/helper-module-transforms-7.20.11.tgz"
+ integrity sha512-uRy78kN4psmji1s2QtbtcCSaj/LILFDp0f/ymhpQH5QY3nljUZCaNWz9X1dEj/8MBdBEFECs7yRhKn8i7NjZgg==
+ dependencies:
+ "@babel/helper-environment-visitor" "^7.18.9"
+ "@babel/helper-module-imports" "^7.18.6"
+ "@babel/helper-simple-access" "^7.20.2"
+ "@babel/helper-split-export-declaration" "^7.18.6"
+ "@babel/helper-validator-identifier" "^7.19.1"
+ "@babel/template" "^7.20.7"
+ "@babel/traverse" "^7.20.10"
+ "@babel/types" "^7.20.7"
+
+"@babel/helper-optimise-call-expression@^7.18.6":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz"
+ integrity sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==
+ dependencies:
+ "@babel/types" "^7.18.6"
+
+"@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.19.0", "@babel/helper-plugin-utils@^7.20.2":
+ version "7.20.2"
+ resolved "https://registry.npmmirror.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.20.2.tgz"
+ integrity sha512-8RvlJG2mj4huQ4pZ+rU9lqKi9ZKiRmuvGuM2HlWmkmgOhbs6zEAw6IEiJ5cQqGbDzGZOhwuOQNtZMi/ENLjZoQ==
+
+"@babel/helper-replace-supers@^7.20.7":
+ version "7.20.7"
+ resolved "https://registry.npmmirror.com/@babel/helper-replace-supers/-/helper-replace-supers-7.20.7.tgz"
+ integrity sha512-vujDMtB6LVfNW13jhlCrp48QNslK6JXi7lQG736HVbHz/mbf4Dc7tIRh1Xf5C0rF7BP8iiSxGMCmY6Ci1ven3A==
+ dependencies:
+ "@babel/helper-environment-visitor" "^7.18.9"
+ "@babel/helper-member-expression-to-functions" "^7.20.7"
+ "@babel/helper-optimise-call-expression" "^7.18.6"
+ "@babel/template" "^7.20.7"
+ "@babel/traverse" "^7.20.7"
+ "@babel/types" "^7.20.7"
+
+"@babel/helper-simple-access@^7.20.2":
+ version "7.20.2"
+ resolved "https://registry.npmmirror.com/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz"
+ integrity sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==
+ dependencies:
+ "@babel/types" "^7.20.2"
+
+"@babel/helper-skip-transparent-expression-wrappers@^7.20.0":
+ version "7.20.0"
+ resolved "https://registry.npmmirror.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz"
+ integrity sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==
+ dependencies:
+ "@babel/types" "^7.20.0"
+
+"@babel/helper-split-export-declaration@^7.18.6":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz"
+ integrity sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==
+ dependencies:
+ "@babel/types" "^7.18.6"
+
+"@babel/helper-string-parser@^7.19.4":
+ version "7.19.4"
+ resolved "https://registry.npmmirror.com/@babel/helper-string-parser/-/helper-string-parser-7.19.4.tgz"
+ integrity sha512-nHtDoQcuqFmwYNYPz3Rah5ph2p8PFeFCsZk9A/48dPc/rGocJ5J3hAAZ7pb76VWX3fZKu+uEr/FhH5jLx7umrw==
+
+"@babel/helper-validator-identifier@^7.18.6", "@babel/helper-validator-identifier@^7.19.1":
+ version "7.19.1"
+ resolved "https://registry.npmmirror.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz"
+ integrity sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==
+
+"@babel/helper-validator-option@^7.18.6":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz"
+ integrity sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==
+
+"@babel/helpers@^7.20.7":
+ version "7.20.13"
+ resolved "https://registry.npmmirror.com/@babel/helpers/-/helpers-7.20.13.tgz"
+ integrity sha512-nzJ0DWCL3gB5RCXbUO3KIMMsBY2Eqbx8mBpKGE/02PgyRQFcPQLbkQ1vyy596mZLaP+dAfD+R4ckASzNVmW3jg==
+ dependencies:
+ "@babel/template" "^7.20.7"
+ "@babel/traverse" "^7.20.13"
+ "@babel/types" "^7.20.7"
+
+"@babel/highlight@^7.18.6":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/highlight/-/highlight-7.18.6.tgz"
+ integrity sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==
+ dependencies:
+ "@babel/helper-validator-identifier" "^7.18.6"
+ chalk "^2.0.0"
+ js-tokens "^4.0.0"
+
+"@babel/parser@^7.16.4", "@babel/parser@^7.20.13", "@babel/parser@^7.20.7":
+ version "7.20.13"
+ resolved "https://registry.npmmirror.com/@babel/parser/-/parser-7.20.13.tgz"
+ integrity sha512-gFDLKMfpiXCsjt4za2JA9oTMn70CeseCehb11kRZgvd7+F67Hih3OHOK24cRrWECJ/ljfPGac6ygXAs/C8kIvw==
+
+"@babel/plugin-syntax-jsx@^7.0.0":
+ version "7.18.6"
+ resolved "https://registry.npmmirror.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz"
+ integrity sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q==
+ dependencies:
+ "@babel/helper-plugin-utils" "^7.18.6"
+
+"@babel/plugin-syntax-typescript@^7.20.0":
+ version "7.20.0"
+ resolved "https://registry.npmmirror.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.20.0.tgz"
+ integrity sha512-rd9TkG+u1CExzS4SM1BlMEhMXwFLKVjOAFFCDx9PbX5ycJWDoWMcwdJH9RhkPu1dOgn5TrxLot/Gx6lWFuAUNQ==
+ dependencies:
+ "@babel/helper-plugin-utils" "^7.19.0"
+
+"@babel/plugin-transform-typescript@^7.20.2":
+ version "7.20.13"
+ resolved "https://registry.npmmirror.com/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.20.13.tgz"
+ integrity sha512-O7I/THxarGcDZxkgWKMUrk7NK1/WbHAg3Xx86gqS6x9MTrNL6AwIluuZ96ms4xeDe6AVx6rjHbWHP7x26EPQBA==
+ dependencies:
+ "@babel/helper-create-class-features-plugin" "^7.20.12"
+ "@babel/helper-plugin-utils" "^7.20.2"
+ "@babel/plugin-syntax-typescript" "^7.20.0"
+
+"@babel/runtime@^7.10.5":
+ version "7.20.13"
+ resolved "https://registry.npmmirror.com/@babel/runtime/-/runtime-7.20.13.tgz"
+ integrity sha512-gt3PKXs0DBoL9xCvOIIZ2NEqAGZqHjAnmVbfQtB620V0uReIQutpel14KcneZuer7UioY8ALKZ7iocavvzTNFA==
+ dependencies:
+ regenerator-runtime "^0.13.11"
+
+"@babel/template@^7.0.0", "@babel/template@^7.18.10", "@babel/template@^7.20.7":
+ version "7.20.7"
+ resolved "https://registry.npmmirror.com/@babel/template/-/template-7.20.7.tgz"
+ integrity sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==
+ dependencies:
+ "@babel/code-frame" "^7.18.6"
+ "@babel/parser" "^7.20.7"
+ "@babel/types" "^7.20.7"
+
+"@babel/traverse@^7.0.0", "@babel/traverse@^7.20.10", "@babel/traverse@^7.20.12", "@babel/traverse@^7.20.13", "@babel/traverse@^7.20.7":
+ version "7.20.13"
+ resolved "https://registry.npmmirror.com/@babel/traverse/-/traverse-7.20.13.tgz"
+ integrity sha512-kMJXfF0T6DIS9E8cgdLCSAL+cuCK+YEZHWiLK0SXpTo8YRj5lpJu3CDNKiIBCne4m9hhTIqUg6SYTAI39tAiVQ==
+ dependencies:
+ "@babel/code-frame" "^7.18.6"
+ "@babel/generator" "^7.20.7"
+ "@babel/helper-environment-visitor" "^7.18.9"
+ "@babel/helper-function-name" "^7.19.0"
+ "@babel/helper-hoist-variables" "^7.18.6"
+ "@babel/helper-split-export-declaration" "^7.18.6"
+ "@babel/parser" "^7.20.13"
+ "@babel/types" "^7.20.7"
+ debug "^4.1.0"
+ globals "^11.1.0"
+
+"@babel/types@^7.0.0", "@babel/types@^7.18.6", "@babel/types@^7.19.0", "@babel/types@^7.20.0", "@babel/types@^7.20.2", "@babel/types@^7.20.7":
+ version "7.20.7"
+ resolved "https://registry.npmmirror.com/@babel/types/-/types-7.20.7.tgz"
+ integrity sha512-69OnhBxSSgK0OzTJai4kyPDiKTIe3j+ctaHdIGVbRahTLAT7L3R9oeXHC2aVSuGYt3cVnoAMDmOCgJ2yaiLMvg==
+ dependencies:
+ "@babel/helper-string-parser" "^7.19.4"
+ "@babel/helper-validator-identifier" "^7.19.1"
+ to-fast-properties "^2.0.0"
+
+"@csstools/selector-specificity@^2.0.2":
+ version "2.1.1"
+ resolved "https://registry.npmmirror.com/@csstools/selector-specificity/-/selector-specificity-2.1.1.tgz"
+ integrity sha512-jwx+WCqszn53YHOfvFMJJRd/B2GqkCBt+1MJSG6o5/s8+ytHMvDZXsJgUEWLk12UnLd7HYKac4BYU5i/Ron1Cw==
+
+"@ctrl/tinycolor@^3.4.0":
+ version "3.5.0"
+ resolved "https://registry.npmmirror.com/@ctrl/tinycolor/-/tinycolor-3.5.0.tgz"
+ integrity sha512-tlJpwF40DEQcfR/QF+wNMVyGMaO9FQp6Z1Wahj4Gk3CJQYHwA2xVG7iKDFdW6zuxZY9XWOpGcfNCTsX4McOsOg==
+
+"@esbuild/win32-x64@0.16.17":
+ version "0.16.17"
+ resolved "https://registry.npmmirror.com/@esbuild/win32-x64/-/win32-x64-0.16.17.tgz"
+ integrity sha512-y+EHuSchhL7FjHgvQL/0fnnFmO4T1bhvWANX6gcnqTjtnKWbTvUMCpGnv2+t+31d7RzyEAYAd4u2fnIhHL6N/Q==
+
+"@eslint/eslintrc@^1.3.0":
+ version "1.4.1"
+ resolved "https://registry.npmmirror.com/@eslint/eslintrc/-/eslintrc-1.4.1.tgz"
+ integrity sha512-XXrH9Uarn0stsyldqDYq8r++mROmWRI1xKMXa640Bb//SY1+ECYX6VzT6Lcx5frD0V30XieqJ0oX9I2Xj5aoMA==
+ dependencies:
+ ajv "^6.12.4"
+ debug "^4.3.2"
+ espree "^9.4.0"
+ globals "^13.19.0"
+ ignore "^5.2.0"
+ import-fresh "^3.2.1"
+ js-yaml "^4.1.0"
+ minimatch "^3.1.2"
+ strip-json-comments "^3.1.1"
+
+"@humanwhocodes/config-array@^0.10.4":
+ version "0.10.7"
+ resolved "https://registry.npmmirror.com/@humanwhocodes/config-array/-/config-array-0.10.7.tgz"
+ integrity sha512-MDl6D6sBsaV452/QSdX+4CXIjZhIcI0PELsxUjk4U828yd58vk3bTIvk/6w5FY+4hIy9sLW0sfrV7K7Kc++j/w==
+ dependencies:
+ "@humanwhocodes/object-schema" "^1.2.1"
+ debug "^4.1.1"
+ minimatch "^3.0.4"
+
+"@humanwhocodes/gitignore-to-minimatch@^1.0.2":
+ version "1.0.2"
+ resolved "https://registry.npmmirror.com/@humanwhocodes/gitignore-to-minimatch/-/gitignore-to-minimatch-1.0.2.tgz"
+ integrity sha512-rSqmMJDdLFUsyxR6FMtD00nfQKKLFb1kv+qBbOVKqErvloEIJLo5bDTJTQNTYgeyp78JsA7u/NPi5jT1GR/MuA==
+
+"@humanwhocodes/object-schema@^1.2.1":
+ version "1.2.1"
+ resolved "https://registry.npmmirror.com/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz"
+ integrity sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==
+
+"@jridgewell/gen-mapping@^0.1.0":
+ version "0.1.1"
+ resolved "https://registry.npmmirror.com/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz"
+ integrity sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==
+ dependencies:
+ "@jridgewell/set-array" "^1.0.0"
+ "@jridgewell/sourcemap-codec" "^1.4.10"
+
+"@jridgewell/gen-mapping@^0.3.0":
+ version "0.3.2"
+ resolved "https://registry.npmmirror.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz"
+ integrity sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==
+ dependencies:
+ "@jridgewell/set-array" "^1.0.1"
+ "@jridgewell/sourcemap-codec" "^1.4.10"
+ "@jridgewell/trace-mapping" "^0.3.9"
+
+"@jridgewell/gen-mapping@^0.3.2":
+ version "0.3.2"
+ resolved "https://registry.npmmirror.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz"
+ integrity sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==
+ dependencies:
+ "@jridgewell/set-array" "^1.0.1"
+ "@jridgewell/sourcemap-codec" "^1.4.10"
+ "@jridgewell/trace-mapping" "^0.3.9"
+
+"@jridgewell/resolve-uri@3.1.0":
+ version "3.1.0"
+ resolved "https://registry.npmmirror.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz"
+ integrity sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==
+
+"@jridgewell/set-array@^1.0.0", "@jridgewell/set-array@^1.0.1":
+ version "1.1.2"
+ resolved "https://registry.npmmirror.com/@jridgewell/set-array/-/set-array-1.1.2.tgz"
+ integrity sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==
+
+"@jridgewell/source-map@^0.3.2":
+ version "0.3.2"
+ resolved "https://registry.npmmirror.com/@jridgewell/source-map/-/source-map-0.3.2.tgz"
+ integrity sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==
+ dependencies:
+ "@jridgewell/gen-mapping" "^0.3.0"
+ "@jridgewell/trace-mapping" "^0.3.9"
+
+"@jridgewell/sourcemap-codec@^1.4.10", "@jridgewell/sourcemap-codec@^1.4.13", "@jridgewell/sourcemap-codec@1.4.14":
+ version "1.4.14"
+ resolved "https://registry.npmmirror.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz"
+ integrity sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==
+
+"@jridgewell/trace-mapping@^0.3.17", "@jridgewell/trace-mapping@^0.3.9":
+ version "0.3.17"
+ resolved "https://registry.npmmirror.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz"
+ integrity sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==
+ dependencies:
+ "@jridgewell/resolve-uri" "3.1.0"
+ "@jridgewell/sourcemap-codec" "1.4.14"
+
+"@nodelib/fs.scandir@2.1.5":
+ version "2.1.5"
+ resolved "https://registry.npmmirror.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz"
+ integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==
+ dependencies:
+ "@nodelib/fs.stat" "2.0.5"
+ run-parallel "^1.1.9"
+
+"@nodelib/fs.stat@^2.0.2", "@nodelib/fs.stat@2.0.5":
+ version "2.0.5"
+ resolved "https://registry.npmmirror.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz"
+ integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==
+
+"@nodelib/fs.walk@^1.2.3":
+ version "1.2.8"
+ resolved "https://registry.npmmirror.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz"
+ integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==
+ dependencies:
+ "@nodelib/fs.scandir" "2.1.5"
+ fastq "^1.6.0"
+
+"@rollup/pluginutils@^5.0.2":
+ version "5.0.2"
+ resolved "https://registry.npmmirror.com/@rollup/pluginutils/-/pluginutils-5.0.2.tgz"
+ integrity sha512-pTd9rIsP92h+B6wWwFbW8RkZv4hiR/xKsqre4SIuAOaOEQRxi0lqLke9k2/7WegC85GgUs9pjmOjCUi3In4vwA==
+ dependencies:
+ "@types/estree" "^1.0.0"
+ estree-walker "^2.0.2"
+ picomatch "^2.3.1"
+
+"@simonwep/pickr@~1.8.0":
+ version "1.8.2"
+ resolved "https://registry.npmmirror.com/@simonwep/pickr/-/pickr-1.8.2.tgz"
+ integrity sha512-/l5w8BIkrpP6n1xsetx9MWPWlU6OblN5YgZZphxan0Tq4BByTCETL6lyIeY8lagalS2Nbt4F2W034KHLIiunKA==
+ dependencies:
+ core-js "^3.15.1"
+ nanopop "^2.1.0"
+
+"@types/eslint-scope@^3.7.3":
+ version "3.7.4"
+ resolved "https://registry.npmmirror.com/@types/eslint-scope/-/eslint-scope-3.7.4.tgz"
+ integrity sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA==
+ dependencies:
+ "@types/eslint" "*"
+ "@types/estree" "*"
+
+"@types/eslint@*":
+ version "8.37.0"
+ resolved "https://registry.npmmirror.com/@types/eslint/-/eslint-8.37.0.tgz"
+ integrity sha512-Piet7dG2JBuDIfohBngQ3rCt7MgO9xCO4xIMKxBThCq5PNRB91IjlJ10eJVwfoNtvTErmxLzwBZ7rHZtbOMmFQ==
+ dependencies:
+ "@types/estree" "*"
+ "@types/json-schema" "*"
+
+"@types/estree@*", "@types/estree@^1.0.0":
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/@types/estree/-/estree-1.0.0.tgz"
+ integrity sha512-WulqXMDUTYAXCjZnk6JtIHPigp55cVtDgDrO2gHRwhyJto21+1zbVCtOYB2L1F9w4qCQ0rOGWBnBe0FNTiEJIQ==
+
+"@types/json-schema@*", "@types/json-schema@^7.0.8", "@types/json-schema@^7.0.9":
+ version "7.0.11"
+ resolved "https://registry.npmmirror.com/@types/json-schema/-/json-schema-7.0.11.tgz"
+ integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==
+
+"@types/minimist@^1.2.0":
+ version "1.2.2"
+ resolved "https://registry.npmmirror.com/@types/minimist/-/minimist-1.2.2.tgz"
+ integrity sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ==
+
+"@types/node@*", "@types/node@>= 14":
+ version "22.5.5"
+ resolved "https://registry.npmmirror.com/@types/node/-/node-22.5.5.tgz"
+ integrity sha512-Xjs4y5UPO/CLdzpgR6GirZJx36yScjh73+2NlLlkFRSoQN8B0DpfXPdZGnvVmLRLOsqDpOfTNv7D9trgGhmOIA==
+ dependencies:
+ undici-types "~6.19.2"
+
+"@types/node@^10.3.6":
+ version "10.17.60"
+ resolved "https://registry.npmmirror.com/@types/node/-/node-10.17.60.tgz"
+ integrity sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw==
+
+"@types/normalize-package-data@^2.4.0":
+ version "2.4.1"
+ resolved "https://registry.npmmirror.com/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz"
+ integrity sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw==
+
+"@types/parse-json@^4.0.0":
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/@types/parse-json/-/parse-json-4.0.0.tgz"
+ integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==
+
+"@types/qs@^6.9.7":
+ version "6.9.7"
+ resolved "https://registry.npmmirror.com/@types/qs/-/qs-6.9.7.tgz"
+ integrity sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==
+
+"@types/semver@^7.3.12":
+ version "7.3.13"
+ resolved "https://registry.npmmirror.com/@types/semver/-/semver-7.3.13.tgz"
+ integrity sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw==
+
+"@types/web-bluetooth@^0.0.16":
+ version "0.0.16"
+ resolved "https://registry.npmmirror.com/@types/web-bluetooth/-/web-bluetooth-0.0.16.tgz"
+ integrity sha512-oh8q2Zc32S6gd/j50GowEjKLoOVOwHP/bWVjKJInBwQqdOYMdPrf1oVlelTlyfFK3CKxL1uahMDAr+vy8T7yMQ==
+
+"@typescript-eslint/eslint-plugin@^5.48.0":
+ version "5.50.0"
+ resolved "https://registry.npmmirror.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.50.0.tgz"
+ integrity sha512-vwksQWSFZiUhgq3Kv7o1Jcj0DUNylwnIlGvKvLLYsq8pAWha6/WCnXUeaSoNNha/K7QSf2+jvmkxggC1u3pIwQ==
+ dependencies:
+ "@typescript-eslint/scope-manager" "5.50.0"
+ "@typescript-eslint/type-utils" "5.50.0"
+ "@typescript-eslint/utils" "5.50.0"
+ debug "^4.3.4"
+ grapheme-splitter "^1.0.4"
+ ignore "^5.2.0"
+ natural-compare-lite "^1.4.0"
+ regexpp "^3.2.0"
+ semver "^7.3.7"
+ tsutils "^3.21.0"
+
+"@typescript-eslint/parser@^5.0.0", "@typescript-eslint/parser@^5.48.0":
+ version "5.50.0"
+ resolved "https://registry.npmmirror.com/@typescript-eslint/parser/-/parser-5.50.0.tgz"
+ integrity sha512-KCcSyNaogUDftK2G9RXfQyOCt51uB5yqC6pkUYqhYh8Kgt+DwR5M0EwEAxGPy/+DH6hnmKeGsNhiZRQxjH71uQ==
+ dependencies:
+ "@typescript-eslint/scope-manager" "5.50.0"
+ "@typescript-eslint/types" "5.50.0"
+ "@typescript-eslint/typescript-estree" "5.50.0"
+ debug "^4.3.4"
+
+"@typescript-eslint/scope-manager@5.50.0":
+ version "5.50.0"
+ resolved "https://registry.npmmirror.com/@typescript-eslint/scope-manager/-/scope-manager-5.50.0.tgz"
+ integrity sha512-rt03kaX+iZrhssaT974BCmoUikYtZI24Vp/kwTSy841XhiYShlqoshRFDvN1FKKvU2S3gK+kcBW1EA7kNUrogg==
+ dependencies:
+ "@typescript-eslint/types" "5.50.0"
+ "@typescript-eslint/visitor-keys" "5.50.0"
+
+"@typescript-eslint/type-utils@5.50.0":
+ version "5.50.0"
+ resolved "https://registry.npmmirror.com/@typescript-eslint/type-utils/-/type-utils-5.50.0.tgz"
+ integrity sha512-dcnXfZ6OGrNCO7E5UY/i0ktHb7Yx1fV6fnQGGrlnfDhilcs6n19eIRcvLBqx6OQkrPaFlDPk3OJ0WlzQfrV0bQ==
+ dependencies:
+ "@typescript-eslint/typescript-estree" "5.50.0"
+ "@typescript-eslint/utils" "5.50.0"
+ debug "^4.3.4"
+ tsutils "^3.21.0"
+
+"@typescript-eslint/types@5.50.0":
+ version "5.50.0"
+ resolved "https://registry.npmmirror.com/@typescript-eslint/types/-/types-5.50.0.tgz"
+ integrity sha512-atruOuJpir4OtyNdKahiHZobPKFvZnBnfDiyEaBf6d9vy9visE7gDjlmhl+y29uxZ2ZDgvXijcungGFjGGex7w==
+
+"@typescript-eslint/typescript-estree@5.50.0":
+ version "5.50.0"
+ resolved "https://registry.npmmirror.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.50.0.tgz"
+ integrity sha512-Gq4zapso+OtIZlv8YNAStFtT6d05zyVCK7Fx3h5inlLBx2hWuc/0465C2mg/EQDDU2LKe52+/jN4f0g9bd+kow==
+ dependencies:
+ "@typescript-eslint/types" "5.50.0"
+ "@typescript-eslint/visitor-keys" "5.50.0"
+ debug "^4.3.4"
+ globby "^11.1.0"
+ is-glob "^4.0.3"
+ semver "^7.3.7"
+ tsutils "^3.21.0"
+
+"@typescript-eslint/utils@5.50.0":
+ version "5.50.0"
+ resolved "https://registry.npmmirror.com/@typescript-eslint/utils/-/utils-5.50.0.tgz"
+ integrity sha512-v/AnUFImmh8G4PH0NDkf6wA8hujNNcrwtecqW4vtQ1UOSNBaZl49zP1SHoZ/06e+UiwzHpgb5zP5+hwlYYWYAw==
+ dependencies:
+ "@types/json-schema" "^7.0.9"
+ "@types/semver" "^7.3.12"
+ "@typescript-eslint/scope-manager" "5.50.0"
+ "@typescript-eslint/types" "5.50.0"
+ "@typescript-eslint/typescript-estree" "5.50.0"
+ eslint-scope "^5.1.1"
+ eslint-utils "^3.0.0"
+ semver "^7.3.7"
+
+"@typescript-eslint/visitor-keys@5.50.0":
+ version "5.50.0"
+ resolved "https://registry.npmmirror.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.50.0.tgz"
+ integrity sha512-cdMeD9HGu6EXIeGOh2yVW6oGf9wq8asBgZx7nsR/D36gTfQ0odE5kcRYe5M81vjEFAcPeugXrHg78Imu55F6gg==
+ dependencies:
+ "@typescript-eslint/types" "5.50.0"
+ eslint-visitor-keys "^3.3.0"
+
+"@vitejs/plugin-vue-jsx@^3.0.0":
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/@vitejs/plugin-vue-jsx/-/plugin-vue-jsx-3.0.0.tgz"
+ integrity sha512-vurkuzgac5SYuxd2HUZqAFAWGTF10diKBwJNbCvnWijNZfXd+7jMtqjPFbGt7idOJUn584fP1Ar9j/GN2jQ3Ew==
+ dependencies:
+ "@babel/core" "^7.20.5"
+ "@babel/plugin-transform-typescript" "^7.20.2"
+ "@vue/babel-plugin-jsx" "^1.1.1"
+
+"@vitejs/plugin-vue@^4.0.0":
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/@vitejs/plugin-vue/-/plugin-vue-4.0.0.tgz"
+ integrity sha512-e0X4jErIxAB5oLtDqbHvHpJe/uWNkdpYV83AOG2xo2tEVSzCzewgJMtREZM30wXnM5ls90hxiOtAuVU6H5JgbA==
+
+"@vue/babel-helper-vue-transform-on@^1.0.2":
+ version "1.0.2"
+ resolved "https://registry.npmmirror.com/@vue/babel-helper-vue-transform-on/-/babel-helper-vue-transform-on-1.0.2.tgz"
+ integrity sha512-hz4R8tS5jMn8lDq6iD+yWL6XNB699pGIVLk7WSJnn1dbpjaazsjZQkieJoRX6gW5zpYSCFqQ7jUquPNY65tQYA==
+
+"@vue/babel-plugin-jsx@^1.1.1":
+ version "1.1.1"
+ resolved "https://registry.npmmirror.com/@vue/babel-plugin-jsx/-/babel-plugin-jsx-1.1.1.tgz"
+ integrity sha512-j2uVfZjnB5+zkcbc/zsOc0fSNGCMMjaEXP52wdwdIfn0qjFfEYpYZBFKFg+HHnQeJCVrjOeO0YxgaL7DMrym9w==
+ dependencies:
+ "@babel/helper-module-imports" "^7.0.0"
+ "@babel/plugin-syntax-jsx" "^7.0.0"
+ "@babel/template" "^7.0.0"
+ "@babel/traverse" "^7.0.0"
+ "@babel/types" "^7.0.0"
+ "@vue/babel-helper-vue-transform-on" "^1.0.2"
+ camelcase "^6.0.0"
+ html-tags "^3.1.0"
+ svg-tags "^1.0.0"
+
+"@vue/compiler-core@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.45.tgz"
+ integrity sha512-rcMj7H+PYe5wBV3iYeUgbCglC+pbpN8hBLTJvRiK2eKQiWqu+fG9F+8sW99JdL4LQi7Re178UOxn09puSXvn4A==
+ dependencies:
+ "@babel/parser" "^7.16.4"
+ "@vue/shared" "3.2.45"
+ estree-walker "^2.0.2"
+ source-map "^0.6.1"
+
+"@vue/compiler-dom@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.45.tgz"
+ integrity sha512-tyYeUEuKqqZO137WrZkpwfPCdiiIeXYCcJ8L4gWz9vqaxzIQRccTSwSWZ/Axx5YR2z+LvpUbmPNXxuBU45lyRw==
+ dependencies:
+ "@vue/compiler-core" "3.2.45"
+ "@vue/shared" "3.2.45"
+
+"@vue/compiler-sfc@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.45.tgz"
+ integrity sha512-1jXDuWah1ggsnSAOGsec8cFjT/K6TMZ0sPL3o3d84Ft2AYZi2jWJgRMjw4iaK0rBfA89L5gw427H4n1RZQBu6Q==
+ dependencies:
+ "@babel/parser" "^7.16.4"
+ "@vue/compiler-core" "3.2.45"
+ "@vue/compiler-dom" "3.2.45"
+ "@vue/compiler-ssr" "3.2.45"
+ "@vue/reactivity-transform" "3.2.45"
+ "@vue/shared" "3.2.45"
+ estree-walker "^2.0.2"
+ magic-string "^0.25.7"
+ postcss "^8.1.10"
+ source-map "^0.6.1"
+
+"@vue/compiler-ssr@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.45.tgz"
+ integrity sha512-6BRaggEGqhWht3lt24CrIbQSRD5O07MTmd+LjAn5fJj568+R9eUD2F7wMQJjX859seSlrYog7sUtrZSd7feqrQ==
+ dependencies:
+ "@vue/compiler-dom" "3.2.45"
+ "@vue/shared" "3.2.45"
+
+"@vue/devtools-api@^6.4.5":
+ version "6.5.0"
+ resolved "https://registry.npmmirror.com/@vue/devtools-api/-/devtools-api-6.5.0.tgz"
+ integrity sha512-o9KfBeaBmCKl10usN4crU53fYtC1r7jJwdGKjPT24t348rHxgfpZ0xL3Xm/gLUYnc0oTp8LAmrxOeLyu6tbk2Q==
+
+"@vue/reactivity-transform@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.2.45.tgz"
+ integrity sha512-BHVmzYAvM7vcU5WmuYqXpwaBHjsS8T63jlKGWVtHxAHIoMIlmaMyurUSEs1Zcg46M4AYT5MtB1U274/2aNzjJQ==
+ dependencies:
+ "@babel/parser" "^7.16.4"
+ "@vue/compiler-core" "3.2.45"
+ "@vue/shared" "3.2.45"
+ estree-walker "^2.0.2"
+ magic-string "^0.25.7"
+
+"@vue/reactivity@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.2.45.tgz"
+ integrity sha512-PRvhCcQcyEVohW0P8iQ7HDcIOXRjZfAsOds3N99X/Dzewy8TVhTCT4uXpAHfoKjVTJRA0O0K+6QNkDIZAxNi3A==
+ dependencies:
+ "@vue/shared" "3.2.45"
+
+"@vue/runtime-core@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.2.45.tgz"
+ integrity sha512-gzJiTA3f74cgARptqzYswmoQx0fIA+gGYBfokYVhF8YSXjWTUA2SngRzZRku2HbGbjzB6LBYSbKGIaK8IW+s0A==
+ dependencies:
+ "@vue/reactivity" "3.2.45"
+ "@vue/shared" "3.2.45"
+
+"@vue/runtime-dom@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.2.45.tgz"
+ integrity sha512-cy88YpfP5Ue2bDBbj75Cb4bIEZUMM/mAkDMfqDTpUYVgTf/kuQ2VQ8LebuZ8k6EudgH8pYhsGWHlY0lcxlvTwA==
+ dependencies:
+ "@vue/runtime-core" "3.2.45"
+ "@vue/shared" "3.2.45"
+ csstype "^2.6.8"
+
+"@vue/server-renderer@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.2.45.tgz"
+ integrity sha512-ebiMq7q24WBU1D6uhPK//2OTR1iRIyxjF5iVq/1a5I1SDMDyDu4Ts6fJaMnjrvD3MqnaiFkKQj+LKAgz5WIK3g==
+ dependencies:
+ "@vue/compiler-ssr" "3.2.45"
+ "@vue/shared" "3.2.45"
+
+"@vue/shared@3.2.45":
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz"
+ integrity sha512-Ewzq5Yhimg7pSztDV+RH1UDKBzmtqieXQlpTVm2AwraoRL/Rks96mvd8Vgi7Lj+h+TH8dv7mXD3FRZR3TUvbSg==
+
+"@vueuse/components@^9.10.0":
+ version "9.12.0"
+ resolved "https://registry.npmmirror.com/@vueuse/components/-/components-9.12.0.tgz"
+ integrity sha512-U468xbr2PISuWepeOU4J8zkVj0aDhiFe230oDhnIm8mHtcS9gM2vSKTB32InxTs6kVma60yAGdqBySkyFNX/+w==
+ dependencies:
+ "@vueuse/core" "9.12.0"
+ "@vueuse/shared" "9.12.0"
+ vue-demi "*"
+
+"@vueuse/core@*", "@vueuse/core@^9.10.0", "@vueuse/core@9.12.0":
+ version "9.12.0"
+ resolved "https://registry.npmmirror.com/@vueuse/core/-/core-9.12.0.tgz"
+ integrity sha512-h/Di8Bvf6xRcvS/PvUVheiMYYz3U0tH3X25YxONSaAUBa841ayMwxkuzx/DGUMCW/wHWzD8tRy2zYmOC36r4sg==
+ dependencies:
+ "@types/web-bluetooth" "^0.0.16"
+ "@vueuse/metadata" "9.12.0"
+ "@vueuse/shared" "9.12.0"
+ vue-demi "*"
+
+"@vueuse/metadata@9.12.0":
+ version "9.12.0"
+ resolved "https://registry.npmmirror.com/@vueuse/metadata/-/metadata-9.12.0.tgz"
+ integrity sha512-9oJ9MM9lFLlmvxXUqsR1wLt1uF7EVbP5iYaHJYqk+G2PbMjY6EXvZeTjbdO89HgoF5cI6z49o2zT/jD9SVoNpQ==
+
+"@vueuse/shared@9.12.0":
+ version "9.12.0"
+ resolved "https://registry.npmmirror.com/@vueuse/shared/-/shared-9.12.0.tgz"
+ integrity sha512-TWuJLACQ0BVithVTRbex4Wf1a1VaRuSpVeyEd4vMUWl54PzlE0ciFUshKCXnlLuD0lxIaLK4Ypj3NXYzZh4+SQ==
+ dependencies:
+ vue-demi "*"
+
+"@webassemblyjs/ast@^1.11.5", "@webassemblyjs/ast@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/ast/-/ast-1.11.5.tgz"
+ integrity sha512-LHY/GSAZZRpsNQH+/oHqhRQ5FT7eoULcBqgfyTB5nQHogFnK3/7QoN7dLnwSE/JkUAF0SrRuclT7ODqMFtWxxQ==
+ dependencies:
+ "@webassemblyjs/helper-numbers" "1.11.5"
+ "@webassemblyjs/helper-wasm-bytecode" "1.11.5"
+
+"@webassemblyjs/floating-point-hex-parser@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.5.tgz"
+ integrity sha512-1j1zTIC5EZOtCplMBG/IEwLtUojtwFVwdyVMbL/hwWqbzlQoJsWCOavrdnLkemwNoC/EOwtUFch3fuo+cbcXYQ==
+
+"@webassemblyjs/helper-api-error@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.5.tgz"
+ integrity sha512-L65bDPmfpY0+yFrsgz8b6LhXmbbs38OnwDCf6NpnMUYqa+ENfE5Dq9E42ny0qz/PdR0LJyq/T5YijPnU8AXEpA==
+
+"@webassemblyjs/helper-buffer@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.5.tgz"
+ integrity sha512-fDKo1gstwFFSfacIeH5KfwzjykIE6ldh1iH9Y/8YkAZrhmu4TctqYjSh7t0K2VyDSXOZJ1MLhht/k9IvYGcIxg==
+
+"@webassemblyjs/helper-numbers@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.5.tgz"
+ integrity sha512-DhykHXM0ZABqfIGYNv93A5KKDw/+ywBFnuWybZZWcuzWHfbp21wUfRkbtz7dMGwGgT4iXjWuhRMA2Mzod6W4WA==
+ dependencies:
+ "@webassemblyjs/floating-point-hex-parser" "1.11.5"
+ "@webassemblyjs/helper-api-error" "1.11.5"
+ "@xtuc/long" "4.2.2"
+
+"@webassemblyjs/helper-wasm-bytecode@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.5.tgz"
+ integrity sha512-oC4Qa0bNcqnjAowFn7MPCETQgDYytpsfvz4ujZz63Zu/a/v71HeCAAmZsgZ3YVKec3zSPYytG3/PrRCqbtcAvA==
+
+"@webassemblyjs/helper-wasm-section@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.5.tgz"
+ integrity sha512-uEoThA1LN2NA+K3B9wDo3yKlBfVtC6rh0i4/6hvbz071E8gTNZD/pT0MsBf7MeD6KbApMSkaAK0XeKyOZC7CIA==
+ dependencies:
+ "@webassemblyjs/ast" "1.11.5"
+ "@webassemblyjs/helper-buffer" "1.11.5"
+ "@webassemblyjs/helper-wasm-bytecode" "1.11.5"
+ "@webassemblyjs/wasm-gen" "1.11.5"
+
+"@webassemblyjs/ieee754@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/ieee754/-/ieee754-1.11.5.tgz"
+ integrity sha512-37aGq6qVL8A8oPbPrSGMBcp38YZFXcHfiROflJn9jxSdSMMM5dS5P/9e2/TpaJuhE+wFrbukN2WI6Hw9MH5acg==
+ dependencies:
+ "@xtuc/ieee754" "^1.2.0"
+
+"@webassemblyjs/leb128@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/leb128/-/leb128-1.11.5.tgz"
+ integrity sha512-ajqrRSXaTJoPW+xmkfYN6l8VIeNnR4vBOTQO9HzR7IygoCcKWkICbKFbVTNMjMgMREqXEr0+2M6zukzM47ZUfQ==
+ dependencies:
+ "@xtuc/long" "4.2.2"
+
+"@webassemblyjs/utf8@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/utf8/-/utf8-1.11.5.tgz"
+ integrity sha512-WiOhulHKTZU5UPlRl53gHR8OxdGsSOxqfpqWeA2FmcwBMaoEdz6b2x2si3IwC9/fSPLfe8pBMRTHVMk5nlwnFQ==
+
+"@webassemblyjs/wasm-edit@^1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.5.tgz"
+ integrity sha512-C0p9D2fAu3Twwqvygvf42iGCQ4av8MFBLiTb+08SZ4cEdwzWx9QeAHDo1E2k+9s/0w1DM40oflJOpkZ8jW4HCQ==
+ dependencies:
+ "@webassemblyjs/ast" "1.11.5"
+ "@webassemblyjs/helper-buffer" "1.11.5"
+ "@webassemblyjs/helper-wasm-bytecode" "1.11.5"
+ "@webassemblyjs/helper-wasm-section" "1.11.5"
+ "@webassemblyjs/wasm-gen" "1.11.5"
+ "@webassemblyjs/wasm-opt" "1.11.5"
+ "@webassemblyjs/wasm-parser" "1.11.5"
+ "@webassemblyjs/wast-printer" "1.11.5"
+
+"@webassemblyjs/wasm-gen@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.5.tgz"
+ integrity sha512-14vteRlRjxLK9eSyYFvw1K8Vv+iPdZU0Aebk3j6oB8TQiQYuO6hj9s4d7qf6f2HJr2khzvNldAFG13CgdkAIfA==
+ dependencies:
+ "@webassemblyjs/ast" "1.11.5"
+ "@webassemblyjs/helper-wasm-bytecode" "1.11.5"
+ "@webassemblyjs/ieee754" "1.11.5"
+ "@webassemblyjs/leb128" "1.11.5"
+ "@webassemblyjs/utf8" "1.11.5"
+
+"@webassemblyjs/wasm-opt@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.5.tgz"
+ integrity sha512-tcKwlIXstBQgbKy1MlbDMlXaxpucn42eb17H29rawYLxm5+MsEmgPzeCP8B1Cl69hCice8LeKgZpRUAPtqYPgw==
+ dependencies:
+ "@webassemblyjs/ast" "1.11.5"
+ "@webassemblyjs/helper-buffer" "1.11.5"
+ "@webassemblyjs/wasm-gen" "1.11.5"
+ "@webassemblyjs/wasm-parser" "1.11.5"
+
+"@webassemblyjs/wasm-parser@^1.11.5", "@webassemblyjs/wasm-parser@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.5.tgz"
+ integrity sha512-SVXUIwsLQlc8srSD7jejsfTU83g7pIGr2YYNb9oHdtldSxaOhvA5xwvIiWIfcX8PlSakgqMXsLpLfbbJ4cBYew==
+ dependencies:
+ "@webassemblyjs/ast" "1.11.5"
+ "@webassemblyjs/helper-api-error" "1.11.5"
+ "@webassemblyjs/helper-wasm-bytecode" "1.11.5"
+ "@webassemblyjs/ieee754" "1.11.5"
+ "@webassemblyjs/leb128" "1.11.5"
+ "@webassemblyjs/utf8" "1.11.5"
+
+"@webassemblyjs/wast-printer@1.11.5":
+ version "1.11.5"
+ resolved "https://registry.npmmirror.com/@webassemblyjs/wast-printer/-/wast-printer-1.11.5.tgz"
+ integrity sha512-f7Pq3wvg3GSPUPzR0F6bmI89Hdb+u9WXrSKc4v+N0aV0q6r42WoF92Jp2jEorBEBRoRNXgjp53nBniDXcqZYPA==
+ dependencies:
+ "@webassemblyjs/ast" "1.11.5"
+ "@xtuc/long" "4.2.2"
+
+"@xtuc/ieee754@^1.2.0":
+ version "1.2.0"
+ resolved "https://registry.npmmirror.com/@xtuc/ieee754/-/ieee754-1.2.0.tgz"
+ integrity sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==
+
+"@xtuc/long@4.2.2":
+ version "4.2.2"
+ resolved "https://registry.npmmirror.com/@xtuc/long/-/long-4.2.2.tgz"
+ integrity sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==
+
+acorn-import-assertions@^1.7.6:
+ version "1.8.0"
+ resolved "https://registry.npmmirror.com/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz"
+ integrity sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw==
+
+acorn-jsx@^5.3.2:
+ version "5.3.2"
+ resolved "https://registry.npmmirror.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz"
+ integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==
+
+"acorn@^6.0.0 || ^7.0.0 || ^8.0.0", acorn@^8, acorn@^8.5.0, acorn@^8.7.1, acorn@^8.8.0, acorn@^8.8.1:
+ version "8.8.2"
+ resolved "https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz"
+ integrity sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==
+
+ajv-keywords@^3.5.2:
+ version "3.5.2"
+ resolved "https://registry.npmmirror.com/ajv-keywords/-/ajv-keywords-3.5.2.tgz"
+ integrity sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==
+
+ajv@^6.10.0, ajv@^6.12.4, ajv@^6.12.5, ajv@^6.9.1:
+ version "6.12.6"
+ resolved "https://registry.npmmirror.com/ajv/-/ajv-6.12.6.tgz"
+ integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==
+ dependencies:
+ fast-deep-equal "^3.1.1"
+ fast-json-stable-stringify "^2.0.0"
+ json-schema-traverse "^0.4.1"
+ uri-js "^4.2.2"
+
+ajv@^8.0.1:
+ version "8.12.0"
+ resolved "https://registry.npmmirror.com/ajv/-/ajv-8.12.0.tgz"
+ integrity sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==
+ dependencies:
+ fast-deep-equal "^3.1.1"
+ json-schema-traverse "^1.0.0"
+ require-from-string "^2.0.2"
+ uri-js "^4.2.2"
+
+ansi-regex@^5.0.1:
+ version "5.0.1"
+ resolved "https://registry.npmmirror.com/ansi-regex/-/ansi-regex-5.0.1.tgz"
+ integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==
+
+ansi-styles@^3.2.1:
+ version "3.2.1"
+ resolved "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-3.2.1.tgz"
+ integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==
+ dependencies:
+ color-convert "^1.9.0"
+
+ansi-styles@^4.0.0:
+ version "4.3.0"
+ resolved "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz"
+ integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==
+ dependencies:
+ color-convert "^2.0.1"
+
+ansi-styles@^4.1.0:
+ version "4.3.0"
+ resolved "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz"
+ integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==
+ dependencies:
+ color-convert "^2.0.1"
+
+ant-design-vue@^3.2.20:
+ version "3.2.20"
+ resolved "https://registry.npmmirror.com/ant-design-vue/-/ant-design-vue-3.2.20.tgz"
+ integrity sha512-YWpMfGaGoRastIXEYfCoJiaRiDHk4chqtYhlKQM5GqPt6NfvrM1Vg2e60yHtjxlZjed91wCMm0rAmyUr7Hwzdg==
+ dependencies:
+ "@ant-design/colors" "^6.0.0"
+ "@ant-design/icons-vue" "^6.1.0"
+ "@babel/runtime" "^7.10.5"
+ "@ctrl/tinycolor" "^3.4.0"
+ "@simonwep/pickr" "~1.8.0"
+ array-tree-filter "^2.1.0"
+ async-validator "^4.0.0"
+ dayjs "^1.10.5"
+ dom-align "^1.12.1"
+ dom-scroll-into-view "^2.0.0"
+ lodash "^4.17.21"
+ lodash-es "^4.17.15"
+ resize-observer-polyfill "^1.5.1"
+ scroll-into-view-if-needed "^2.2.25"
+ shallow-equal "^1.0.0"
+ vue-types "^3.0.0"
+ warning "^4.0.0"
+
+anymatch@~3.1.2:
+ version "3.1.3"
+ resolved "https://registry.npmmirror.com/anymatch/-/anymatch-3.1.3.tgz"
+ integrity sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==
+ dependencies:
+ normalize-path "^3.0.0"
+ picomatch "^2.0.4"
+
+argparse@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.npmmirror.com/argparse/-/argparse-2.0.1.tgz"
+ integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==
+
+array-tree-filter@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/array-tree-filter/-/array-tree-filter-2.1.0.tgz"
+ integrity sha512-4ROwICNlNw/Hqa9v+rk5h22KjmzB1JGTMVKP2AKJBOCgb0yL0ASf0+YvCcLNNwquOHNX48jkeZIJ3a+oOQqKcw==
+
+array-union@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/array-union/-/array-union-2.1.0.tgz"
+ integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==
+
+arrify@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/arrify/-/arrify-1.0.1.tgz"
+ integrity sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA==
+
+astral-regex@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/astral-regex/-/astral-regex-2.0.0.tgz"
+ integrity sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==
+
+async-validator@^4.0.0:
+ version "4.2.5"
+ resolved "https://registry.npmmirror.com/async-validator/-/async-validator-4.2.5.tgz"
+ integrity sha512-7HhHjtERjqlNbZtqNqy2rckN/SpOOlmDliet+lP7k+eKZEjPk3DgyeU9lIXLdeLz0uBbbVp+9Qdow9wJWgwwfg==
+
+asynckit@^0.4.0:
+ version "0.4.0"
+ resolved "https://registry.npmmirror.com/asynckit/-/asynckit-0.4.0.tgz"
+ integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==
+
+autoprefixer@^10.4.13:
+ version "10.4.13"
+ resolved "https://registry.npmmirror.com/autoprefixer/-/autoprefixer-10.4.13.tgz"
+ integrity sha512-49vKpMqcZYsJjwotvt4+h/BCjJVnhGwcLpDt5xkcaOG3eLrG/HUYLagrihYsQ+qrIBgIzX1Rw7a6L8I/ZA1Atg==
+ dependencies:
+ browserslist "^4.21.4"
+ caniuse-lite "^1.0.30001426"
+ fraction.js "^4.2.0"
+ normalize-range "^0.1.2"
+ picocolors "^1.0.0"
+ postcss-value-parser "^4.2.0"
+
+axios@^1.2.2:
+ version "1.3.0"
+ resolved "https://registry.npmmirror.com/axios/-/axios-1.3.0.tgz"
+ integrity sha512-oCye5nHhTypzkdLIvF9SaHfr8UAquqCn1KY3j8vsrjeol8yohAdGxIpRPbF1bOLsx33HOAatdfMX1yzsj2cHwg==
+ dependencies:
+ follow-redirects "^1.15.0"
+ form-data "^4.0.0"
+ proxy-from-env "^1.1.0"
+
+balanced-match@^1.0.0:
+ version "1.0.2"
+ resolved "https://registry.npmmirror.com/balanced-match/-/balanced-match-1.0.2.tgz"
+ integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==
+
+balanced-match@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/balanced-match/-/balanced-match-2.0.0.tgz"
+ integrity sha512-1ugUSr8BHXRnK23KfuYS+gVMC3LB8QGH9W1iGtDPsNWoQbgtXSExkBu2aDR4epiGWZOjZsj6lDl/N/AqqTC3UA==
+
+binary-extensions@^2.0.0:
+ version "2.2.0"
+ resolved "https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.2.0.tgz"
+ integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==
+
+boolbase@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/boolbase/-/boolbase-1.0.0.tgz"
+ integrity sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==
+
+brace-expansion@^1.1.7:
+ version "1.1.11"
+ resolved "https://registry.npmmirror.com/brace-expansion/-/brace-expansion-1.1.11.tgz"
+ integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==
+ dependencies:
+ balanced-match "^1.0.0"
+ concat-map "0.0.1"
+
+braces@^3.0.2, braces@~3.0.2:
+ version "3.0.2"
+ resolved "https://registry.npmmirror.com/braces/-/braces-3.0.2.tgz"
+ integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==
+ dependencies:
+ fill-range "^7.0.1"
+
+browserslist@^4.14.5, browserslist@^4.21.3, browserslist@^4.21.4, "browserslist@>= 4.21.0":
+ version "4.21.5"
+ resolved "https://registry.npmmirror.com/browserslist/-/browserslist-4.21.5.tgz"
+ integrity sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==
+ dependencies:
+ caniuse-lite "^1.0.30001449"
+ electron-to-chromium "^1.4.284"
+ node-releases "^2.0.8"
+ update-browserslist-db "^1.0.10"
+
+buffer-from@^1.0.0:
+ version "1.1.2"
+ resolved "https://registry.npmmirror.com/buffer-from/-/buffer-from-1.1.2.tgz"
+ integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==
+
+call-bind@^1.0.0:
+ version "1.0.2"
+ resolved "https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz"
+ integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==
+ dependencies:
+ function-bind "^1.1.1"
+ get-intrinsic "^1.0.2"
+
+callsites@^3.0.0:
+ version "3.1.0"
+ resolved "https://registry.npmmirror.com/callsites/-/callsites-3.1.0.tgz"
+ integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==
+
+camelcase-keys@^6.2.2:
+ version "6.2.2"
+ resolved "https://registry.npmmirror.com/camelcase-keys/-/camelcase-keys-6.2.2.tgz"
+ integrity sha512-YrwaA0vEKazPBkn0ipTiMpSajYDSe+KjQfrjhcBMxJt/znbvlHd8Pw/Vamaz5EB4Wfhs3SUR3Z9mwRu/P3s3Yg==
+ dependencies:
+ camelcase "^5.3.1"
+ map-obj "^4.0.0"
+ quick-lru "^4.0.1"
+
+camelcase@^5.3.1:
+ version "5.3.1"
+ resolved "https://registry.npmmirror.com/camelcase/-/camelcase-5.3.1.tgz"
+ integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==
+
+camelcase@^6.0.0:
+ version "6.3.0"
+ resolved "https://registry.npmmirror.com/camelcase/-/camelcase-6.3.0.tgz"
+ integrity sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==
+
+caniuse-lite@^1.0.30001426, caniuse-lite@^1.0.30001449:
+ version "1.0.30001450"
+ resolved "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001450.tgz"
+ integrity sha512-qMBmvmQmFXaSxexkjjfMvD5rnDL0+m+dUMZKoDYsGG8iZN29RuYh9eRoMvKsT6uMAWlyUUGDEQGJJYjzCIO9ew==
+
+chalk@^2.0.0:
+ version "2.4.2"
+ resolved "https://registry.npmmirror.com/chalk/-/chalk-2.4.2.tgz"
+ integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==
+ dependencies:
+ ansi-styles "^3.2.1"
+ escape-string-regexp "^1.0.5"
+ supports-color "^5.3.0"
+
+chalk@^4.0.0:
+ version "4.1.2"
+ resolved "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz"
+ integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==
+ dependencies:
+ ansi-styles "^4.1.0"
+ supports-color "^7.1.0"
+
+chalk@^4.1.2:
+ version "4.1.2"
+ resolved "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz"
+ integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==
+ dependencies:
+ ansi-styles "^4.1.0"
+ supports-color "^7.1.0"
+
+chokidar@^3.5.3:
+ version "3.5.3"
+ resolved "https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz"
+ integrity sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==
+ dependencies:
+ anymatch "~3.1.2"
+ braces "~3.0.2"
+ glob-parent "~5.1.2"
+ is-binary-path "~2.1.0"
+ is-glob "~4.0.1"
+ normalize-path "~3.0.0"
+ readdirp "~3.6.0"
+ optionalDependencies:
+ fsevents "~2.3.2"
+
+chrome-trace-event@^1.0.2:
+ version "1.0.3"
+ resolved "https://registry.npmmirror.com/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz"
+ integrity sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==
+
+cliui@^8.0.1:
+ version "8.0.1"
+ resolved "https://registry.npmmirror.com/cliui/-/cliui-8.0.1.tgz"
+ integrity sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==
+ dependencies:
+ string-width "^4.2.0"
+ strip-ansi "^6.0.1"
+ wrap-ansi "^7.0.0"
+
+color-convert@^1.9.0:
+ version "1.9.3"
+ resolved "https://registry.npmmirror.com/color-convert/-/color-convert-1.9.3.tgz"
+ integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==
+ dependencies:
+ color-name "1.1.3"
+
+color-convert@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz"
+ integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==
+ dependencies:
+ color-name "~1.1.4"
+
+color-name@~1.1.4:
+ version "1.1.4"
+ resolved "https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz"
+ integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==
+
+color-name@1.1.3:
+ version "1.1.3"
+ resolved "https://registry.npmmirror.com/color-name/-/color-name-1.1.3.tgz"
+ integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==
+
+colord@^2.9.3:
+ version "2.9.3"
+ resolved "https://registry.npmmirror.com/colord/-/colord-2.9.3.tgz"
+ integrity sha512-jeC1axXpnb0/2nn/Y1LPuLdgXBLH7aDcHu4KEKfqw3CUhX7ZpfBSlPKyqXE6btIgEzfWtrX3/tyBCaCvXvMkOw==
+
+combined-stream@^1.0.8:
+ version "1.0.8"
+ resolved "https://registry.npmmirror.com/combined-stream/-/combined-stream-1.0.8.tgz"
+ integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==
+ dependencies:
+ delayed-stream "~1.0.0"
+
+commander@^2.20.0:
+ version "2.20.3"
+ resolved "https://registry.npmmirror.com/commander/-/commander-2.20.3.tgz"
+ integrity sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==
+
+compute-scroll-into-view@^1.0.20:
+ version "1.0.20"
+ resolved "https://registry.npmmirror.com/compute-scroll-into-view/-/compute-scroll-into-view-1.0.20.tgz"
+ integrity sha512-UCB0ioiyj8CRjtrvaceBLqqhZCVP+1B8+NWQhmdsm0VXOJtobBCf1dBQmebCCo34qZmUwZfIH2MZLqNHazrfjg==
+
+concat-map@0.0.1:
+ version "0.0.1"
+ resolved "https://registry.npmmirror.com/concat-map/-/concat-map-0.0.1.tgz"
+ integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==
+
+convert-source-map@^1.7.0:
+ version "1.9.0"
+ resolved "https://registry.npmmirror.com/convert-source-map/-/convert-source-map-1.9.0.tgz"
+ integrity sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==
+
+copy-anything@^2.0.1:
+ version "2.0.6"
+ resolved "https://registry.npmmirror.com/copy-anything/-/copy-anything-2.0.6.tgz"
+ integrity sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==
+ dependencies:
+ is-what "^3.14.1"
+
+core-js@^3.15.1:
+ version "3.27.2"
+ resolved "https://registry.npmmirror.com/core-js/-/core-js-3.27.2.tgz"
+ integrity sha512-9ashVQskuh5AZEZ1JdQWp1GqSoC1e1G87MzRqg2gIfVAQ7Qn9K+uFj8EcniUFA4P2NLZfV+TOlX1SzoKfo+s7w==
+
+cosmiconfig@^7.1.0:
+ version "7.1.0"
+ resolved "https://registry.npmmirror.com/cosmiconfig/-/cosmiconfig-7.1.0.tgz"
+ integrity sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==
+ dependencies:
+ "@types/parse-json" "^4.0.0"
+ import-fresh "^3.2.1"
+ parse-json "^5.0.0"
+ path-type "^4.0.0"
+ yaml "^1.10.0"
+
+cross-spawn@^7.0.2:
+ version "7.0.3"
+ resolved "https://registry.npmmirror.com/cross-spawn/-/cross-spawn-7.0.3.tgz"
+ integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==
+ dependencies:
+ path-key "^3.1.0"
+ shebang-command "^2.0.0"
+ which "^2.0.1"
+
+css-functions-list@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.npmmirror.com/css-functions-list/-/css-functions-list-3.1.0.tgz"
+ integrity sha512-/9lCvYZaUbBGvYUgYGFJ4dcYiyqdhSjG7IPVluoV8A1ILjkF7ilmhp1OGUz8n+nmBcu0RNrQAzgD8B6FJbrt2w==
+
+cssesc@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/cssesc/-/cssesc-3.0.0.tgz"
+ integrity sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==
+
+csstype@^2.6.8:
+ version "2.6.21"
+ resolved "https://registry.npmmirror.com/csstype/-/csstype-2.6.21.tgz"
+ integrity sha512-Z1PhmomIfypOpoMjRQB70jfvy/wxT50qW08YXO5lMIJkrdq4yOTR+AW7FqutScmB9NkLwxo+jU+kZLbofZZq/w==
+
+dayjs@^1.10.5:
+ version "1.11.7"
+ resolved "https://registry.npmmirror.com/dayjs/-/dayjs-1.11.7.tgz"
+ integrity sha512-+Yw9U6YO5TQohxLcIkrXBeY73WP3ejHWVvx8XCk3gxvQDCTEmS48ZrSZCKciI7Bhl/uCMyxYtE9UqRILmFphkQ==
+
+debug@^3.2.6:
+ version "3.2.7"
+ resolved "https://registry.npmmirror.com/debug/-/debug-3.2.7.tgz"
+ integrity sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==
+ dependencies:
+ ms "^2.1.1"
+
+debug@^4.1.0, debug@^4.1.1, debug@^4.3.2, debug@^4.3.3, debug@^4.3.4:
+ version "4.3.4"
+ resolved "https://registry.npmmirror.com/debug/-/debug-4.3.4.tgz"
+ integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==
+ dependencies:
+ ms "2.1.2"
+
+decamelize-keys@^1.1.0:
+ version "1.1.1"
+ resolved "https://registry.npmmirror.com/decamelize-keys/-/decamelize-keys-1.1.1.tgz"
+ integrity sha512-WiPxgEirIV0/eIOMcnFBA3/IJZAZqKnwAwWyvvdi4lsr1WCN22nhdf/3db3DoZcUjTV2SqfzIwNyp6y2xs3nmg==
+ dependencies:
+ decamelize "^1.1.0"
+ map-obj "^1.0.0"
+
+decamelize@^1.1.0, decamelize@^1.2.0:
+ version "1.2.0"
+ resolved "https://registry.npmmirror.com/decamelize/-/decamelize-1.2.0.tgz"
+ integrity sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==
+
+deep-is@^0.1.3:
+ version "0.1.4"
+ resolved "https://registry.npmmirror.com/deep-is/-/deep-is-0.1.4.tgz"
+ integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==
+
+define-lazy-prop@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz"
+ integrity sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==
+
+delayed-stream@~1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/delayed-stream/-/delayed-stream-1.0.0.tgz"
+ integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==
+
+dir-glob@^3.0.1:
+ version "3.0.1"
+ resolved "https://registry.npmmirror.com/dir-glob/-/dir-glob-3.0.1.tgz"
+ integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==
+ dependencies:
+ path-type "^4.0.0"
+
+doctrine@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/doctrine/-/doctrine-3.0.0.tgz"
+ integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==
+ dependencies:
+ esutils "^2.0.2"
+
+dom-align@^1.12.1:
+ version "1.12.4"
+ resolved "https://registry.npmmirror.com/dom-align/-/dom-align-1.12.4.tgz"
+ integrity sha512-R8LUSEay/68zE5c8/3BDxiTEvgb4xZTF0RKmAHfiEVN3klfIpXfi2/QCoiWPccVQ0J/ZGdz9OjzL4uJEP/MRAw==
+
+dom-scroll-into-view@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.npmmirror.com/dom-scroll-into-view/-/dom-scroll-into-view-2.0.1.tgz"
+ integrity sha512-bvVTQe1lfaUr1oFzZX80ce9KLDlZ3iU+XGNE/bz9HnGdklTieqsbmsLHe+rT2XWqopvL0PckkYqN7ksmm5pe3w==
+
+dom-serializer@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/dom-serializer/-/dom-serializer-2.0.0.tgz"
+ integrity sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==
+ dependencies:
+ domelementtype "^2.3.0"
+ domhandler "^5.0.2"
+ entities "^4.2.0"
+
+domelementtype@^2.3.0:
+ version "2.3.0"
+ resolved "https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz"
+ integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==
+
+domhandler@^5.0.1, domhandler@^5.0.2:
+ version "5.0.3"
+ resolved "https://registry.npmmirror.com/domhandler/-/domhandler-5.0.3.tgz"
+ integrity sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==
+ dependencies:
+ domelementtype "^2.3.0"
+
+domutils@^3.0.1:
+ version "3.0.1"
+ resolved "https://registry.npmmirror.com/domutils/-/domutils-3.0.1.tgz"
+ integrity sha512-z08c1l761iKhDFtfXO04C7kTdPBLi41zwOZl00WS8b5eiaebNpY00HKbztwBq+e3vyqWNwWF3mP9YLUeqIrF+Q==
+ dependencies:
+ dom-serializer "^2.0.0"
+ domelementtype "^2.3.0"
+ domhandler "^5.0.1"
+
+electron-to-chromium@^1.4.284:
+ version "1.4.284"
+ resolved "https://registry.npmmirror.com/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz"
+ integrity sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==
+
+emoji-regex@^8.0.0:
+ version "8.0.0"
+ resolved "https://registry.npmmirror.com/emoji-regex/-/emoji-regex-8.0.0.tgz"
+ integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==
+
+enhanced-resolve@^5.13.0:
+ version "5.13.0"
+ resolved "https://registry.npmmirror.com/enhanced-resolve/-/enhanced-resolve-5.13.0.tgz"
+ integrity sha512-eyV8f0y1+bzyfh8xAwW/WTSZpLbjhqc4ne9eGSH4Zo2ejdyiNG9pU6mf9DG8a7+Auk6MFTlNOT4Y2y/9k8GKVg==
+ dependencies:
+ graceful-fs "^4.2.4"
+ tapable "^2.2.0"
+
+entities@^4.2.0, entities@^4.3.0:
+ version "4.4.0"
+ resolved "https://registry.npmmirror.com/entities/-/entities-4.4.0.tgz"
+ integrity sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA==
+
+errno@^0.1.1:
+ version "0.1.8"
+ resolved "https://registry.npmmirror.com/errno/-/errno-0.1.8.tgz"
+ integrity sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==
+ dependencies:
+ prr "~1.0.1"
+
+error-ex@^1.3.1:
+ version "1.3.2"
+ resolved "https://registry.npmmirror.com/error-ex/-/error-ex-1.3.2.tgz"
+ integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==
+ dependencies:
+ is-arrayish "^0.2.1"
+
+es-module-lexer@^1.2.1:
+ version "1.2.1"
+ resolved "https://registry.npmmirror.com/es-module-lexer/-/es-module-lexer-1.2.1.tgz"
+ integrity sha512-9978wrXM50Y4rTMmW5kXIC09ZdXQZqkE4mxhwkd8VbzsGkXGPgV4zWuqQJgCEzYngdo2dYDa0l8xhX4fkSwJSg==
+
+esbuild@^0.16.3:
+ version "0.16.17"
+ resolved "https://registry.npmmirror.com/esbuild/-/esbuild-0.16.17.tgz"
+ integrity sha512-G8LEkV0XzDMNwXKgM0Jwu3nY3lSTwSGY6XbxM9cr9+s0T/qSV1q1JVPBGzm3dcjhCic9+emZDmMffkwgPeOeLg==
+ optionalDependencies:
+ "@esbuild/android-arm" "0.16.17"
+ "@esbuild/android-arm64" "0.16.17"
+ "@esbuild/android-x64" "0.16.17"
+ "@esbuild/darwin-arm64" "0.16.17"
+ "@esbuild/darwin-x64" "0.16.17"
+ "@esbuild/freebsd-arm64" "0.16.17"
+ "@esbuild/freebsd-x64" "0.16.17"
+ "@esbuild/linux-arm" "0.16.17"
+ "@esbuild/linux-arm64" "0.16.17"
+ "@esbuild/linux-ia32" "0.16.17"
+ "@esbuild/linux-loong64" "0.16.17"
+ "@esbuild/linux-mips64el" "0.16.17"
+ "@esbuild/linux-ppc64" "0.16.17"
+ "@esbuild/linux-riscv64" "0.16.17"
+ "@esbuild/linux-s390x" "0.16.17"
+ "@esbuild/linux-x64" "0.16.17"
+ "@esbuild/netbsd-x64" "0.16.17"
+ "@esbuild/openbsd-x64" "0.16.17"
+ "@esbuild/sunos-x64" "0.16.17"
+ "@esbuild/win32-arm64" "0.16.17"
+ "@esbuild/win32-ia32" "0.16.17"
+ "@esbuild/win32-x64" "0.16.17"
+
+escalade@^3.1.1:
+ version "3.1.1"
+ resolved "https://registry.npmmirror.com/escalade/-/escalade-3.1.1.tgz"
+ integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==
+
+escape-string-regexp@^1.0.5:
+ version "1.0.5"
+ resolved "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz"
+ integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==
+
+escape-string-regexp@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz"
+ integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==
+
+escape-string-regexp@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz"
+ integrity sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==
+
+eslint-config-prettier@^8.6.0:
+ version "8.6.0"
+ resolved "https://registry.npmmirror.com/eslint-config-prettier/-/eslint-config-prettier-8.6.0.tgz"
+ integrity sha512-bAF0eLpLVqP5oEVUFKpMA+NnRFICwn9X8B5jrR9FcqnYBuPbqWEjTEspPWMj5ye6czoSLDweCzSo3Ko7gGrZaA==
+
+eslint-define-config@^1.13.0:
+ version "1.14.0"
+ resolved "https://registry.npmmirror.com/eslint-define-config/-/eslint-define-config-1.14.0.tgz"
+ integrity sha512-NREt5SzMwKmLAY28YdaqIiTSJxfPpuZ+1ZLJxY2Wbj02dYF4QX81z0q9MPMjZB8C+SlCu66qAhcPpFJyhXOiuA==
+
+eslint-plugin-prettier@^4.2.1:
+ version "4.2.1"
+ resolved "https://registry.npmmirror.com/eslint-plugin-prettier/-/eslint-plugin-prettier-4.2.1.tgz"
+ integrity sha512-f/0rXLXUt0oFYs8ra4w49wYZBG5GKZpAYsJSm6rnYL5uVDjd+zowwMwVZHnAjf4edNrKpCDYfXDgmRE/Ak7QyQ==
+ dependencies:
+ prettier-linter-helpers "^1.0.0"
+
+eslint-plugin-vue@^9.8.0:
+ version "9.9.0"
+ resolved "https://registry.npmmirror.com/eslint-plugin-vue/-/eslint-plugin-vue-9.9.0.tgz"
+ integrity sha512-YbubS7eK0J7DCf0U2LxvVP7LMfs6rC6UltihIgval3azO3gyDwEGVgsCMe1TmDiEkl6GdMKfRpaME6QxIYtzDQ==
+ dependencies:
+ eslint-utils "^3.0.0"
+ natural-compare "^1.4.0"
+ nth-check "^2.0.1"
+ postcss-selector-parser "^6.0.9"
+ semver "^7.3.5"
+ vue-eslint-parser "^9.0.1"
+ xml-name-validator "^4.0.0"
+
+eslint-scope@^5.1.1, eslint-scope@5.1.1:
+ version "5.1.1"
+ resolved "https://registry.npmmirror.com/eslint-scope/-/eslint-scope-5.1.1.tgz"
+ integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==
+ dependencies:
+ esrecurse "^4.3.0"
+ estraverse "^4.1.1"
+
+eslint-scope@^7.1.1:
+ version "7.1.1"
+ resolved "https://registry.npmmirror.com/eslint-scope/-/eslint-scope-7.1.1.tgz"
+ integrity sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==
+ dependencies:
+ esrecurse "^4.3.0"
+ estraverse "^5.2.0"
+
+eslint-utils@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/eslint-utils/-/eslint-utils-3.0.0.tgz"
+ integrity sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==
+ dependencies:
+ eslint-visitor-keys "^2.0.0"
+
+eslint-visitor-keys@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz"
+ integrity sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==
+
+eslint-visitor-keys@^3.3.0:
+ version "3.3.0"
+ resolved "https://registry.npmmirror.com/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz"
+ integrity sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==
+
+eslint@*, "eslint@^6.0.0 || ^7.0.0 || ^8.0.0", "eslint@^6.2.0 || ^7.0.0 || ^8.0.0", eslint@>=5, eslint@>=6.0.0, eslint@>=7.0.0, eslint@>=7.28.0, eslint@8.22.0:
+ version "8.22.0"
+ resolved "https://registry.npmmirror.com/eslint/-/eslint-8.22.0.tgz"
+ integrity sha512-ci4t0sz6vSRKdmkOGmprBo6fmI4PrphDFMy5JEq/fNS0gQkJM3rLmrqcp8ipMcdobH3KtUP40KniAE9W19S4wA==
+ dependencies:
+ "@eslint/eslintrc" "^1.3.0"
+ "@humanwhocodes/config-array" "^0.10.4"
+ "@humanwhocodes/gitignore-to-minimatch" "^1.0.2"
+ ajv "^6.10.0"
+ chalk "^4.0.0"
+ cross-spawn "^7.0.2"
+ debug "^4.3.2"
+ doctrine "^3.0.0"
+ escape-string-regexp "^4.0.0"
+ eslint-scope "^7.1.1"
+ eslint-utils "^3.0.0"
+ eslint-visitor-keys "^3.3.0"
+ espree "^9.3.3"
+ esquery "^1.4.0"
+ esutils "^2.0.2"
+ fast-deep-equal "^3.1.3"
+ file-entry-cache "^6.0.1"
+ find-up "^5.0.0"
+ functional-red-black-tree "^1.0.1"
+ glob-parent "^6.0.1"
+ globals "^13.15.0"
+ globby "^11.1.0"
+ grapheme-splitter "^1.0.4"
+ ignore "^5.2.0"
+ import-fresh "^3.0.0"
+ imurmurhash "^0.1.4"
+ is-glob "^4.0.0"
+ js-yaml "^4.1.0"
+ json-stable-stringify-without-jsonify "^1.0.1"
+ levn "^0.4.1"
+ lodash.merge "^4.6.2"
+ minimatch "^3.1.2"
+ natural-compare "^1.4.0"
+ optionator "^0.9.1"
+ regexpp "^3.2.0"
+ strip-ansi "^6.0.1"
+ strip-json-comments "^3.1.0"
+ text-table "^0.2.0"
+ v8-compile-cache "^2.0.3"
+
+espree@^9.3.1, espree@^9.3.3, espree@^9.4.0:
+ version "9.4.1"
+ resolved "https://registry.npmmirror.com/espree/-/espree-9.4.1.tgz"
+ integrity sha512-XwctdmTO6SIvCzd9810yyNzIrOrqNYV9Koizx4C/mRhf9uq0o4yHoCEU/670pOxOL/MSraektvSAji79kX90Vg==
+ dependencies:
+ acorn "^8.8.0"
+ acorn-jsx "^5.3.2"
+ eslint-visitor-keys "^3.3.0"
+
+esquery@^1.4.0:
+ version "1.4.0"
+ resolved "https://registry.npmmirror.com/esquery/-/esquery-1.4.0.tgz"
+ integrity sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==
+ dependencies:
+ estraverse "^5.1.0"
+
+esrecurse@^4.3.0:
+ version "4.3.0"
+ resolved "https://registry.npmmirror.com/esrecurse/-/esrecurse-4.3.0.tgz"
+ integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==
+ dependencies:
+ estraverse "^5.2.0"
+
+estraverse@^4.1.1:
+ version "4.3.0"
+ resolved "https://registry.npmmirror.com/estraverse/-/estraverse-4.3.0.tgz"
+ integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==
+
+estraverse@^5.1.0:
+ version "5.3.0"
+ resolved "https://registry.npmmirror.com/estraverse/-/estraverse-5.3.0.tgz"
+ integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==
+
+estraverse@^5.2.0:
+ version "5.3.0"
+ resolved "https://registry.npmmirror.com/estraverse/-/estraverse-5.3.0.tgz"
+ integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==
+
+estree-walker@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz"
+ integrity sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==
+
+esutils@^2.0.2:
+ version "2.0.3"
+ resolved "https://registry.npmmirror.com/esutils/-/esutils-2.0.3.tgz"
+ integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==
+
+events@^3.2.0:
+ version "3.3.0"
+ resolved "https://registry.npmmirror.com/events/-/events-3.3.0.tgz"
+ integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==
+
+fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3:
+ version "3.1.3"
+ resolved "https://registry.npmmirror.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz"
+ integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==
+
+fast-diff@^1.1.2:
+ version "1.2.0"
+ resolved "https://registry.npmmirror.com/fast-diff/-/fast-diff-1.2.0.tgz"
+ integrity sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==
+
+fast-glob@^3.2.12, fast-glob@^3.2.9:
+ version "3.2.12"
+ resolved "https://registry.npmmirror.com/fast-glob/-/fast-glob-3.2.12.tgz"
+ integrity sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==
+ dependencies:
+ "@nodelib/fs.stat" "^2.0.2"
+ "@nodelib/fs.walk" "^1.2.3"
+ glob-parent "^5.1.2"
+ merge2 "^1.3.0"
+ micromatch "^4.0.4"
+
+fast-json-stable-stringify@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz"
+ integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==
+
+fast-levenshtein@^2.0.6:
+ version "2.0.6"
+ resolved "https://registry.npmmirror.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz"
+ integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==
+
+fastest-levenshtein@^1.0.16:
+ version "1.0.16"
+ resolved "https://registry.npmmirror.com/fastest-levenshtein/-/fastest-levenshtein-1.0.16.tgz"
+ integrity sha512-eRnCtTTtGZFpQCwhJiUOuxPQWRXVKYDn0b2PeHfXL6/Zi53SLAzAHfVhVWK2AryC/WH05kGfxhFIPvTF0SXQzg==
+
+fastq@^1.6.0:
+ version "1.15.0"
+ resolved "https://registry.npmmirror.com/fastq/-/fastq-1.15.0.tgz"
+ integrity sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==
+ dependencies:
+ reusify "^1.0.4"
+
+file-entry-cache@^6.0.1:
+ version "6.0.1"
+ resolved "https://registry.npmmirror.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz"
+ integrity sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==
+ dependencies:
+ flat-cache "^3.0.4"
+
+fill-range@^7.0.1:
+ version "7.0.1"
+ resolved "https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz"
+ integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==
+ dependencies:
+ to-regex-range "^5.0.1"
+
+find-up@^4.1.0:
+ version "4.1.0"
+ resolved "https://registry.npmmirror.com/find-up/-/find-up-4.1.0.tgz"
+ integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==
+ dependencies:
+ locate-path "^5.0.0"
+ path-exists "^4.0.0"
+
+find-up@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.npmmirror.com/find-up/-/find-up-5.0.0.tgz"
+ integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==
+ dependencies:
+ locate-path "^6.0.0"
+ path-exists "^4.0.0"
+
+flat-cache@^3.0.4:
+ version "3.0.4"
+ resolved "https://registry.npmmirror.com/flat-cache/-/flat-cache-3.0.4.tgz"
+ integrity sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==
+ dependencies:
+ flatted "^3.1.0"
+ rimraf "^3.0.2"
+
+flatted@^3.1.0:
+ version "3.2.7"
+ resolved "https://registry.npmmirror.com/flatted/-/flatted-3.2.7.tgz"
+ integrity sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==
+
+follow-redirects@^1.15.0:
+ version "1.15.2"
+ resolved "https://registry.npmmirror.com/follow-redirects/-/follow-redirects-1.15.2.tgz"
+ integrity sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==
+
+form-data@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/form-data/-/form-data-4.0.0.tgz"
+ integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==
+ dependencies:
+ asynckit "^0.4.0"
+ combined-stream "^1.0.8"
+ mime-types "^2.1.12"
+
+fraction.js@^4.2.0:
+ version "4.2.0"
+ resolved "https://registry.npmmirror.com/fraction.js/-/fraction.js-4.2.0.tgz"
+ integrity sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA==
+
+fs-extra@^10.0.0:
+ version "10.1.0"
+ resolved "https://registry.npmmirror.com/fs-extra/-/fs-extra-10.1.0.tgz"
+ integrity sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==
+ dependencies:
+ graceful-fs "^4.2.0"
+ jsonfile "^6.0.1"
+ universalify "^2.0.0"
+
+fs.realpath@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/fs.realpath/-/fs.realpath-1.0.0.tgz"
+ integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==
+
+function-bind@^1.1.1:
+ version "1.1.1"
+ resolved "https://registry.npmmirror.com/function-bind/-/function-bind-1.1.1.tgz"
+ integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==
+
+functional-red-black-tree@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz"
+ integrity sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==
+
+gensync@^1.0.0-beta.2:
+ version "1.0.0-beta.2"
+ resolved "https://registry.npmmirror.com/gensync/-/gensync-1.0.0-beta.2.tgz"
+ integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==
+
+get-caller-file@^2.0.5:
+ version "2.0.5"
+ resolved "https://registry.npmmirror.com/get-caller-file/-/get-caller-file-2.0.5.tgz"
+ integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==
+
+get-intrinsic@^1.0.2:
+ version "1.2.0"
+ resolved "https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.2.0.tgz"
+ integrity sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q==
+ dependencies:
+ function-bind "^1.1.1"
+ has "^1.0.3"
+ has-symbols "^1.0.3"
+
+glob-parent@^5.1.2:
+ version "5.1.2"
+ resolved "https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz"
+ integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==
+ dependencies:
+ is-glob "^4.0.1"
+
+glob-parent@^6.0.1:
+ version "6.0.2"
+ resolved "https://registry.npmmirror.com/glob-parent/-/glob-parent-6.0.2.tgz"
+ integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==
+ dependencies:
+ is-glob "^4.0.3"
+
+glob-parent@~5.1.2:
+ version "5.1.2"
+ resolved "https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz"
+ integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==
+ dependencies:
+ is-glob "^4.0.1"
+
+glob-to-regexp@^0.4.1:
+ version "0.4.1"
+ resolved "https://registry.npmmirror.com/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz"
+ integrity sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==
+
+glob@^7.1.3:
+ version "7.2.3"
+ resolved "https://registry.npmmirror.com/glob/-/glob-7.2.3.tgz"
+ integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==
+ dependencies:
+ fs.realpath "^1.0.0"
+ inflight "^1.0.4"
+ inherits "2"
+ minimatch "^3.1.1"
+ once "^1.3.0"
+ path-is-absolute "^1.0.0"
+
+global-modules@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/global-modules/-/global-modules-2.0.0.tgz"
+ integrity sha512-NGbfmJBp9x8IxyJSd1P+otYK8vonoJactOogrVfFRIAEY1ukil8RSKDz2Yo7wh1oihl51l/r6W4epkeKJHqL8A==
+ dependencies:
+ global-prefix "^3.0.0"
+
+global-prefix@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/global-prefix/-/global-prefix-3.0.0.tgz"
+ integrity sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg==
+ dependencies:
+ ini "^1.3.5"
+ kind-of "^6.0.2"
+ which "^1.3.1"
+
+globals@^11.1.0:
+ version "11.12.0"
+ resolved "https://registry.npmmirror.com/globals/-/globals-11.12.0.tgz"
+ integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==
+
+globals@^13.15.0:
+ version "13.20.0"
+ resolved "https://registry.npmmirror.com/globals/-/globals-13.20.0.tgz"
+ integrity sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==
+ dependencies:
+ type-fest "^0.20.2"
+
+globals@^13.19.0:
+ version "13.20.0"
+ resolved "https://registry.npmmirror.com/globals/-/globals-13.20.0.tgz"
+ integrity sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==
+ dependencies:
+ type-fest "^0.20.2"
+
+globby@^11.1.0:
+ version "11.1.0"
+ resolved "https://registry.npmmirror.com/globby/-/globby-11.1.0.tgz"
+ integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==
+ dependencies:
+ array-union "^2.1.0"
+ dir-glob "^3.0.1"
+ fast-glob "^3.2.9"
+ ignore "^5.2.0"
+ merge2 "^1.4.1"
+ slash "^3.0.0"
+
+globjoin@^0.1.4:
+ version "0.1.4"
+ resolved "https://registry.npmmirror.com/globjoin/-/globjoin-0.1.4.tgz"
+ integrity sha512-xYfnw62CKG8nLkZBfWbhWwDw02CHty86jfPcc2cr3ZfeuK9ysoVPPEUxf21bAD/rWAgk52SuBrLJlefNy8mvFg==
+
+graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.4, graceful-fs@^4.2.9:
+ version "4.2.10"
+ resolved "https://registry.npmmirror.com/graceful-fs/-/graceful-fs-4.2.10.tgz"
+ integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==
+
+grapheme-splitter@^1.0.4:
+ version "1.0.4"
+ resolved "https://registry.npmmirror.com/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz"
+ integrity sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==
+
+hard-rejection@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/hard-rejection/-/hard-rejection-2.1.0.tgz"
+ integrity sha512-VIZB+ibDhx7ObhAe7OVtoEbuP4h/MuOTHJ+J8h/eBXotJYl0fBgR72xDFCKgIh22OJZIOVNxBMWuhAr10r8HdA==
+
+has-flag@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/has-flag/-/has-flag-3.0.0.tgz"
+ integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==
+
+has-flag@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz"
+ integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==
+
+has-symbols@^1.0.3:
+ version "1.0.3"
+ resolved "https://registry.npmmirror.com/has-symbols/-/has-symbols-1.0.3.tgz"
+ integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==
+
+has@^1.0.3:
+ version "1.0.3"
+ resolved "https://registry.npmmirror.com/has/-/has-1.0.3.tgz"
+ integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==
+ dependencies:
+ function-bind "^1.1.1"
+
+hosted-git-info@^2.1.4:
+ version "2.8.9"
+ resolved "https://registry.npmmirror.com/hosted-git-info/-/hosted-git-info-2.8.9.tgz"
+ integrity sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==
+
+hosted-git-info@^4.0.1:
+ version "4.1.0"
+ resolved "https://registry.npmmirror.com/hosted-git-info/-/hosted-git-info-4.1.0.tgz"
+ integrity sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==
+ dependencies:
+ lru-cache "^6.0.0"
+
+html-tags@^3.1.0, html-tags@^3.2.0:
+ version "3.2.0"
+ resolved "https://registry.npmmirror.com/html-tags/-/html-tags-3.2.0.tgz"
+ integrity sha512-vy7ClnArOZwCnqZgvv+ddgHgJiAFXe3Ge9ML5/mBctVJoUoYPCdxVucOywjDARn6CVoh3dRSFdPHy2sX80L0Wg==
+
+htmlparser2@^8.0.0:
+ version "8.0.1"
+ resolved "https://registry.npmmirror.com/htmlparser2/-/htmlparser2-8.0.1.tgz"
+ integrity sha512-4lVbmc1diZC7GUJQtRQ5yBAeUCL1exyMwmForWkRLnwyzWBFxN633SALPMGYaWZvKe9j1pRZJpauvmxENSp/EA==
+ dependencies:
+ domelementtype "^2.3.0"
+ domhandler "^5.0.2"
+ domutils "^3.0.1"
+ entities "^4.3.0"
+
+iconv-lite@^0.6.3:
+ version "0.6.3"
+ resolved "https://registry.npmmirror.com/iconv-lite/-/iconv-lite-0.6.3.tgz"
+ integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==
+ dependencies:
+ safer-buffer ">= 2.1.2 < 3.0.0"
+
+ignore@^5.2.0, ignore@^5.2.1:
+ version "5.2.4"
+ resolved "https://registry.npmmirror.com/ignore/-/ignore-5.2.4.tgz"
+ integrity sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==
+
+image-size@~0.5.0:
+ version "0.5.5"
+ resolved "https://registry.npmmirror.com/image-size/-/image-size-0.5.5.tgz"
+ integrity sha512-6TDAlDPZxUFCv+fuOkIoXT/V/f3Qbq8e37p+YOiYrUv3v9cc3/6x78VdfPgFVaB9dZYeLUfKgHRebpkm/oP2VQ==
+
+import-fresh@^3.0.0, import-fresh@^3.2.1:
+ version "3.3.0"
+ resolved "https://registry.npmmirror.com/import-fresh/-/import-fresh-3.3.0.tgz"
+ integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==
+ dependencies:
+ parent-module "^1.0.0"
+ resolve-from "^4.0.0"
+
+import-lazy@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/import-lazy/-/import-lazy-4.0.0.tgz"
+ integrity sha512-rKtvo6a868b5Hu3heneU+L4yEQ4jYKLtjpnPeUdK7h0yzXGmyBTypknlkCvHFBqfX9YlorEiMM6Dnq/5atfHkw==
+
+imurmurhash@^0.1.4:
+ version "0.1.4"
+ resolved "https://registry.npmmirror.com/imurmurhash/-/imurmurhash-0.1.4.tgz"
+ integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==
+
+indent-string@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/indent-string/-/indent-string-4.0.0.tgz"
+ integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==
+
+inflight@^1.0.4:
+ version "1.0.6"
+ resolved "https://registry.npmmirror.com/inflight/-/inflight-1.0.6.tgz"
+ integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==
+ dependencies:
+ once "^1.3.0"
+ wrappy "1"
+
+inherits@2:
+ version "2.0.4"
+ resolved "https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz"
+ integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==
+
+ini@^1.3.5:
+ version "1.3.8"
+ resolved "https://registry.npmmirror.com/ini/-/ini-1.3.8.tgz"
+ integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==
+
+is-arrayish@^0.2.1:
+ version "0.2.1"
+ resolved "https://registry.npmmirror.com/is-arrayish/-/is-arrayish-0.2.1.tgz"
+ integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==
+
+is-binary-path@~2.1.0:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/is-binary-path/-/is-binary-path-2.1.0.tgz"
+ integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==
+ dependencies:
+ binary-extensions "^2.0.0"
+
+is-core-module@^2.5.0, is-core-module@^2.9.0:
+ version "2.11.0"
+ resolved "https://registry.npmmirror.com/is-core-module/-/is-core-module-2.11.0.tgz"
+ integrity sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==
+ dependencies:
+ has "^1.0.3"
+
+is-docker@^2.0.0, is-docker@^2.1.1:
+ version "2.2.1"
+ resolved "https://registry.npmmirror.com/is-docker/-/is-docker-2.2.1.tgz"
+ integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==
+
+is-extglob@^2.1.1:
+ version "2.1.1"
+ resolved "https://registry.npmmirror.com/is-extglob/-/is-extglob-2.1.1.tgz"
+ integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==
+
+is-fullwidth-code-point@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz"
+ integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==
+
+is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1:
+ version "4.0.3"
+ resolved "https://registry.npmmirror.com/is-glob/-/is-glob-4.0.3.tgz"
+ integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==
+ dependencies:
+ is-extglob "^2.1.1"
+
+is-number@^7.0.0:
+ version "7.0.0"
+ resolved "https://registry.npmmirror.com/is-number/-/is-number-7.0.0.tgz"
+ integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==
+
+is-plain-obj@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.npmmirror.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz"
+ integrity sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg==
+
+is-plain-object@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.npmmirror.com/is-plain-object/-/is-plain-object-5.0.0.tgz"
+ integrity sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q==
+
+is-plain-object@3.0.1:
+ version "3.0.1"
+ resolved "https://registry.npmmirror.com/is-plain-object/-/is-plain-object-3.0.1.tgz"
+ integrity sha512-Xnpx182SBMrr/aBik8y+GuR4U1L9FqMSojwDQwPMmxyC6bvEqly9UBCxhauBF5vNh2gwWJNX6oDV7O+OM4z34g==
+
+is-what@^3.14.1:
+ version "3.14.1"
+ resolved "https://registry.npmmirror.com/is-what/-/is-what-3.14.1.tgz"
+ integrity sha512-sNxgpk9793nzSs7bA6JQJGeIuRBQhAaNGG77kzYQgMkrID+lS6SlK07K5LaptscDlSaIgH+GPFzf+d75FVxozA==
+
+is-wsl@^2.2.0:
+ version "2.2.0"
+ resolved "https://registry.npmmirror.com/is-wsl/-/is-wsl-2.2.0.tgz"
+ integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==
+ dependencies:
+ is-docker "^2.0.0"
+
+isexe@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/isexe/-/isexe-2.0.0.tgz"
+ integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==
+
+jest-worker@^27.4.5:
+ version "27.5.1"
+ resolved "https://registry.npmmirror.com/jest-worker/-/jest-worker-27.5.1.tgz"
+ integrity sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==
+ dependencies:
+ "@types/node" "*"
+ merge-stream "^2.0.0"
+ supports-color "^8.0.0"
+
+"js-tokens@^3.0.0 || ^4.0.0", js-tokens@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/js-tokens/-/js-tokens-4.0.0.tgz"
+ integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==
+
+js-tokens@^8.0.0:
+ version "8.0.1"
+ resolved "https://registry.npmmirror.com/js-tokens/-/js-tokens-8.0.1.tgz"
+ integrity sha512-3AGrZT6tuMm1ZWWn9mLXh7XMfi2YtiLNPALCVxBCiUVq0LD1OQMxV/AdS/s7rLJU5o9i/jBZw/N4vXXL5dm29A==
+
+js-yaml@^4.1.0:
+ version "4.1.0"
+ resolved "https://registry.npmmirror.com/js-yaml/-/js-yaml-4.1.0.tgz"
+ integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==
+ dependencies:
+ argparse "^2.0.1"
+
+jsesc@^2.5.1:
+ version "2.5.2"
+ resolved "https://registry.npmmirror.com/jsesc/-/jsesc-2.5.2.tgz"
+ integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==
+
+json-parse-even-better-errors@^2.3.0, json-parse-even-better-errors@^2.3.1:
+ version "2.3.1"
+ resolved "https://registry.npmmirror.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz"
+ integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==
+
+json-schema-traverse@^0.4.1:
+ version "0.4.1"
+ resolved "https://registry.npmmirror.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz"
+ integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==
+
+json-schema-traverse@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz"
+ integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==
+
+json-stable-stringify-without-jsonify@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz"
+ integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==
+
+json5@^2.2.2:
+ version "2.2.3"
+ resolved "https://registry.npmmirror.com/json5/-/json5-2.2.3.tgz"
+ integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==
+
+jsonc-parser@^3.2.0:
+ version "3.2.0"
+ resolved "https://registry.npmmirror.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz"
+ integrity sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==
+
+jsonfile@^6.0.1:
+ version "6.1.0"
+ resolved "https://registry.npmmirror.com/jsonfile/-/jsonfile-6.1.0.tgz"
+ integrity sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==
+ dependencies:
+ universalify "^2.0.0"
+ optionalDependencies:
+ graceful-fs "^4.1.6"
+
+kind-of@^6.0.2, kind-of@^6.0.3:
+ version "6.0.3"
+ resolved "https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz"
+ integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==
+
+klona@^2.0.4:
+ version "2.0.6"
+ resolved "https://registry.npmmirror.com/klona/-/klona-2.0.6.tgz"
+ integrity sha512-dhG34DXATL5hSxJbIexCft8FChFXtmskoZYnoPWjXQuebWYCNkVeV3KkGegCK9CP1oswI/vQibS2GY7Em/sJJA==
+
+known-css-properties@^0.26.0:
+ version "0.26.0"
+ resolved "https://registry.npmmirror.com/known-css-properties/-/known-css-properties-0.26.0.tgz"
+ integrity sha512-5FZRzrZzNTBruuurWpvZnvP9pum+fe0HcK8z/ooo+U+Hmp4vtbyp1/QDsqmufirXy4egGzbaH/y2uCZf+6W5Kg==
+
+less-loader@^11.1.0:
+ version "11.1.0"
+ resolved "https://registry.npmmirror.com/less-loader/-/less-loader-11.1.0.tgz"
+ integrity sha512-C+uDBV7kS7W5fJlUjq5mPBeBVhYpTIm5gB09APT9o3n/ILeaXVsiSFTbZpTJCJwQ/Crczfn3DmfQFwxYusWFug==
+ dependencies:
+ klona "^2.0.4"
+
+less@*, "less@^3.5.0 || ^4.0.0", less@^4.1.3:
+ version "4.1.3"
+ resolved "https://registry.npmmirror.com/less/-/less-4.1.3.tgz"
+ integrity sha512-w16Xk/Ta9Hhyei0Gpz9m7VS8F28nieJaL/VyShID7cYvP6IL5oHeL6p4TXSDJqZE/lNv0oJ2pGVjJsRkfwm5FA==
+ dependencies:
+ copy-anything "^2.0.1"
+ parse-node-version "^1.0.1"
+ tslib "^2.3.0"
+ optionalDependencies:
+ errno "^0.1.1"
+ graceful-fs "^4.1.2"
+ image-size "~0.5.0"
+ make-dir "^2.1.0"
+ mime "^1.4.1"
+ needle "^3.1.0"
+ source-map "~0.6.0"
+
+levn@^0.4.1:
+ version "0.4.1"
+ resolved "https://registry.npmmirror.com/levn/-/levn-0.4.1.tgz"
+ integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==
+ dependencies:
+ prelude-ls "^1.2.1"
+ type-check "~0.4.0"
+
+lines-and-columns@^1.1.6:
+ version "1.2.4"
+ resolved "https://registry.npmmirror.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz"
+ integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==
+
+loader-runner@^4.2.0:
+ version "4.3.0"
+ resolved "https://registry.npmmirror.com/loader-runner/-/loader-runner-4.3.0.tgz"
+ integrity sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==
+
+local-pkg@^0.4.3:
+ version "0.4.3"
+ resolved "https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz"
+ integrity sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==
+
+locate-path@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.npmmirror.com/locate-path/-/locate-path-5.0.0.tgz"
+ integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==
+ dependencies:
+ p-locate "^4.1.0"
+
+locate-path@^6.0.0:
+ version "6.0.0"
+ resolved "https://registry.npmmirror.com/locate-path/-/locate-path-6.0.0.tgz"
+ integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==
+ dependencies:
+ p-locate "^5.0.0"
+
+lodash-es@^4.17.15:
+ version "4.17.21"
+ resolved "https://registry.npmmirror.com/lodash-es/-/lodash-es-4.17.21.tgz"
+ integrity sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==
+
+lodash.merge@^4.6.2:
+ version "4.6.2"
+ resolved "https://registry.npmmirror.com/lodash.merge/-/lodash.merge-4.6.2.tgz"
+ integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==
+
+lodash.truncate@^4.4.2:
+ version "4.4.2"
+ resolved "https://registry.npmmirror.com/lodash.truncate/-/lodash.truncate-4.4.2.tgz"
+ integrity sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw==
+
+lodash@^4.17.21:
+ version "4.17.21"
+ resolved "https://registry.npmmirror.com/lodash/-/lodash-4.17.21.tgz"
+ integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==
+
+loose-envify@^1.0.0:
+ version "1.4.0"
+ resolved "https://registry.npmmirror.com/loose-envify/-/loose-envify-1.4.0.tgz"
+ integrity sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==
+ dependencies:
+ js-tokens "^3.0.0 || ^4.0.0"
+
+lru-cache@^5.1.1:
+ version "5.1.1"
+ resolved "https://registry.npmmirror.com/lru-cache/-/lru-cache-5.1.1.tgz"
+ integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==
+ dependencies:
+ yallist "^3.0.2"
+
+lru-cache@^6.0.0:
+ version "6.0.0"
+ resolved "https://registry.npmmirror.com/lru-cache/-/lru-cache-6.0.0.tgz"
+ integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==
+ dependencies:
+ yallist "^4.0.0"
+
+magic-string@^0.25.7:
+ version "0.25.9"
+ resolved "https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz"
+ integrity sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==
+ dependencies:
+ sourcemap-codec "^1.4.8"
+
+magic-string@^0.27.0:
+ version "0.27.0"
+ resolved "https://registry.npmmirror.com/magic-string/-/magic-string-0.27.0.tgz"
+ integrity sha512-8UnnX2PeRAPZuN12svgR9j7M1uWMovg/CEnIwIG0LFkXSJJe4PdfUGiTGl8V9bsBHFUtfVINcSyYxd7q+kx9fA==
+ dependencies:
+ "@jridgewell/sourcemap-codec" "^1.4.13"
+
+make-dir@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/make-dir/-/make-dir-2.1.0.tgz"
+ integrity sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==
+ dependencies:
+ pify "^4.0.1"
+ semver "^5.6.0"
+
+map-obj@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/map-obj/-/map-obj-1.0.1.tgz"
+ integrity sha512-7N/q3lyZ+LVCp7PzuxrJr4KMbBE2hW7BT7YNia330OFxIf4d3r5zVpicP2650l7CPN6RM9zOJRl3NGpqSiw3Eg==
+
+map-obj@^4.0.0:
+ version "4.3.0"
+ resolved "https://registry.npmmirror.com/map-obj/-/map-obj-4.3.0.tgz"
+ integrity sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ==
+
+mathml-tag-names@^2.1.3:
+ version "2.1.3"
+ resolved "https://registry.npmmirror.com/mathml-tag-names/-/mathml-tag-names-2.1.3.tgz"
+ integrity sha512-APMBEanjybaPzUrfqU0IMU5I0AswKMH7k8OTLs0vvV4KZpExkTkY87nR/zpbuTPj+gARop7aGUbl11pnDfW6xg==
+
+meow@^9.0.0:
+ version "9.0.0"
+ resolved "https://registry.npmmirror.com/meow/-/meow-9.0.0.tgz"
+ integrity sha512-+obSblOQmRhcyBt62furQqRAQpNyWXo8BuQ5bN7dG8wmwQ+vwHKp/rCFD4CrTP8CsDQD1sjoZ94K417XEUk8IQ==
+ dependencies:
+ "@types/minimist" "^1.2.0"
+ camelcase-keys "^6.2.2"
+ decamelize "^1.2.0"
+ decamelize-keys "^1.1.0"
+ hard-rejection "^2.1.0"
+ minimist-options "4.1.0"
+ normalize-package-data "^3.0.0"
+ read-pkg-up "^7.0.1"
+ redent "^3.0.0"
+ trim-newlines "^3.0.0"
+ type-fest "^0.18.0"
+ yargs-parser "^20.2.3"
+
+merge-stream@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/merge-stream/-/merge-stream-2.0.0.tgz"
+ integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==
+
+merge2@^1.3.0, merge2@^1.4.1:
+ version "1.4.1"
+ resolved "https://registry.npmmirror.com/merge2/-/merge2-1.4.1.tgz"
+ integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==
+
+micromatch@^4.0.4, micromatch@^4.0.5:
+ version "4.0.5"
+ resolved "https://registry.npmmirror.com/micromatch/-/micromatch-4.0.5.tgz"
+ integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==
+ dependencies:
+ braces "^3.0.2"
+ picomatch "^2.3.1"
+
+mime-db@1.52.0:
+ version "1.52.0"
+ resolved "https://registry.npmmirror.com/mime-db/-/mime-db-1.52.0.tgz"
+ integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==
+
+mime-types@^2.1.12, mime-types@^2.1.27:
+ version "2.1.35"
+ resolved "https://registry.npmmirror.com/mime-types/-/mime-types-2.1.35.tgz"
+ integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==
+ dependencies:
+ mime-db "1.52.0"
+
+mime@^1.4.1:
+ version "1.6.0"
+ resolved "https://registry.npmmirror.com/mime/-/mime-1.6.0.tgz"
+ integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==
+
+min-indent@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/min-indent/-/min-indent-1.0.1.tgz"
+ integrity sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==
+
+minimatch@^3.0.4, minimatch@^3.1.1, minimatch@^3.1.2:
+ version "3.1.2"
+ resolved "https://registry.npmmirror.com/minimatch/-/minimatch-3.1.2.tgz"
+ integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==
+ dependencies:
+ brace-expansion "^1.1.7"
+
+minimist-options@4.1.0:
+ version "4.1.0"
+ resolved "https://registry.npmmirror.com/minimist-options/-/minimist-options-4.1.0.tgz"
+ integrity sha512-Q4r8ghd80yhO/0j1O3B2BjweX3fiHg9cdOwjJd2J76Q135c+NDxGCqdYKQ1SKBuFfgWbAUzBfvYjPUEeNgqN1A==
+ dependencies:
+ arrify "^1.0.1"
+ is-plain-obj "^1.1.0"
+ kind-of "^6.0.3"
+
+mlly@^1.0.0, mlly@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.npmmirror.com/mlly/-/mlly-1.1.0.tgz"
+ integrity sha512-cwzBrBfwGC1gYJyfcy8TcZU1f+dbH/T+TuOhtYP2wLv/Fb51/uV7HJQfBPtEupZ2ORLRU1EKFS/QfS3eo9+kBQ==
+ dependencies:
+ acorn "^8.8.1"
+ pathe "^1.0.0"
+ pkg-types "^1.0.1"
+ ufo "^1.0.1"
+
+ms@^2.1.1, ms@2.1.2:
+ version "2.1.2"
+ resolved "https://registry.npmmirror.com/ms/-/ms-2.1.2.tgz"
+ integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==
+
+nanoid@^3.3.4:
+ version "3.3.4"
+ resolved "https://registry.npmmirror.com/nanoid/-/nanoid-3.3.4.tgz"
+ integrity sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==
+
+nanopop@^2.1.0:
+ version "2.2.0"
+ resolved "https://registry.npmmirror.com/nanopop/-/nanopop-2.2.0.tgz"
+ integrity sha512-E9JaHcxh3ere8/BEZHAcnuD10RluTSPyTToBvoFWS9/7DcCx6gyKjbn7M7Bx7E1veCxCuY1iO6h4+gdAf1j73Q==
+
+natural-compare-lite@^1.4.0:
+ version "1.4.0"
+ resolved "https://registry.npmmirror.com/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz"
+ integrity sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g==
+
+natural-compare@^1.4.0:
+ version "1.4.0"
+ resolved "https://registry.npmmirror.com/natural-compare/-/natural-compare-1.4.0.tgz"
+ integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==
+
+needle@^3.1.0:
+ version "3.2.0"
+ resolved "https://registry.npmmirror.com/needle/-/needle-3.2.0.tgz"
+ integrity sha512-oUvzXnyLiVyVGoianLijF9O/RecZUf7TkBfimjGrLM4eQhXyeJwM6GeAWccwfQ9aa4gMCZKqhAOuLaMIcQxajQ==
+ dependencies:
+ debug "^3.2.6"
+ iconv-lite "^0.6.3"
+ sax "^1.2.4"
+
+neo-async@^2.6.2:
+ version "2.6.2"
+ resolved "https://registry.npmmirror.com/neo-async/-/neo-async-2.6.2.tgz"
+ integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==
+
+node-releases@^2.0.8:
+ version "2.0.9"
+ resolved "https://registry.npmmirror.com/node-releases/-/node-releases-2.0.9.tgz"
+ integrity sha512-2xfmOrRkGogbTK9R6Leda0DGiXeY3p2NJpy4+gNCffdUvV6mdEJnaDEic1i3Ec2djAo8jWYoJMR5PB0MSMpxUA==
+
+normalize-package-data@^2.5.0:
+ version "2.5.0"
+ resolved "https://registry.npmmirror.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz"
+ integrity sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==
+ dependencies:
+ hosted-git-info "^2.1.4"
+ resolve "^1.10.0"
+ semver "2 || 3 || 4 || 5"
+ validate-npm-package-license "^3.0.1"
+
+normalize-package-data@^3.0.0:
+ version "3.0.3"
+ resolved "https://registry.npmmirror.com/normalize-package-data/-/normalize-package-data-3.0.3.tgz"
+ integrity sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==
+ dependencies:
+ hosted-git-info "^4.0.1"
+ is-core-module "^2.5.0"
+ semver "^7.3.4"
+ validate-npm-package-license "^3.0.1"
+
+normalize-path@^3.0.0, normalize-path@~3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/normalize-path/-/normalize-path-3.0.0.tgz"
+ integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==
+
+normalize-range@^0.1.2:
+ version "0.1.2"
+ resolved "https://registry.npmmirror.com/normalize-range/-/normalize-range-0.1.2.tgz"
+ integrity sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==
+
+nth-check@^2.0.1:
+ version "2.1.1"
+ resolved "https://registry.npmmirror.com/nth-check/-/nth-check-2.1.1.tgz"
+ integrity sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==
+ dependencies:
+ boolbase "^1.0.0"
+
+object-inspect@^1.9.0:
+ version "1.12.3"
+ resolved "https://registry.npmmirror.com/object-inspect/-/object-inspect-1.12.3.tgz"
+ integrity sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==
+
+once@^1.3.0:
+ version "1.4.0"
+ resolved "https://registry.npmmirror.com/once/-/once-1.4.0.tgz"
+ integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==
+ dependencies:
+ wrappy "1"
+
+open@^8.4.0:
+ version "8.4.0"
+ resolved "https://registry.npmmirror.com/open/-/open-8.4.0.tgz"
+ integrity sha512-XgFPPM+B28FtCCgSb9I+s9szOC1vZRSwgWsRUA5ylIxRTgKozqjOCrVOqGsYABPYK5qnfqClxZTFBa8PKt2v6Q==
+ dependencies:
+ define-lazy-prop "^2.0.0"
+ is-docker "^2.1.1"
+ is-wsl "^2.2.0"
+
+optionator@^0.9.1:
+ version "0.9.1"
+ resolved "https://registry.npmmirror.com/optionator/-/optionator-0.9.1.tgz"
+ integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==
+ dependencies:
+ deep-is "^0.1.3"
+ fast-levenshtein "^2.0.6"
+ levn "^0.4.1"
+ prelude-ls "^1.2.1"
+ type-check "^0.4.0"
+ word-wrap "^1.2.3"
+
+p-limit@^2.2.0:
+ version "2.3.0"
+ resolved "https://registry.npmmirror.com/p-limit/-/p-limit-2.3.0.tgz"
+ integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==
+ dependencies:
+ p-try "^2.0.0"
+
+p-limit@^3.0.2:
+ version "3.1.0"
+ resolved "https://registry.npmmirror.com/p-limit/-/p-limit-3.1.0.tgz"
+ integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==
+ dependencies:
+ yocto-queue "^0.1.0"
+
+p-locate@^4.1.0:
+ version "4.1.0"
+ resolved "https://registry.npmmirror.com/p-locate/-/p-locate-4.1.0.tgz"
+ integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==
+ dependencies:
+ p-limit "^2.2.0"
+
+p-locate@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.npmmirror.com/p-locate/-/p-locate-5.0.0.tgz"
+ integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==
+ dependencies:
+ p-limit "^3.0.2"
+
+p-try@^2.0.0:
+ version "2.2.0"
+ resolved "https://registry.npmmirror.com/p-try/-/p-try-2.2.0.tgz"
+ integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==
+
+parent-module@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/parent-module/-/parent-module-1.0.1.tgz"
+ integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==
+ dependencies:
+ callsites "^3.0.0"
+
+parse-json@^5.0.0:
+ version "5.2.0"
+ resolved "https://registry.npmmirror.com/parse-json/-/parse-json-5.2.0.tgz"
+ integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==
+ dependencies:
+ "@babel/code-frame" "^7.0.0"
+ error-ex "^1.3.1"
+ json-parse-even-better-errors "^2.3.0"
+ lines-and-columns "^1.1.6"
+
+parse-node-version@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/parse-node-version/-/parse-node-version-1.0.1.tgz"
+ integrity sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA==
+
+path-exists@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/path-exists/-/path-exists-4.0.0.tgz"
+ integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==
+
+path-is-absolute@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz"
+ integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==
+
+path-key@^3.1.0:
+ version "3.1.1"
+ resolved "https://registry.npmmirror.com/path-key/-/path-key-3.1.1.tgz"
+ integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==
+
+path-parse@^1.0.7:
+ version "1.0.7"
+ resolved "https://registry.npmmirror.com/path-parse/-/path-parse-1.0.7.tgz"
+ integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==
+
+path-type@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/path-type/-/path-type-4.0.0.tgz"
+ integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==
+
+pathe@^1.0.0, pathe@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.npmmirror.com/pathe/-/pathe-1.1.0.tgz"
+ integrity sha512-ODbEPR0KKHqECXW1GoxdDb+AZvULmXjVPy4rt+pGo2+TnjJTIPJQSVS6N63n8T2Ip+syHhbn52OewKicV0373w==
+
+picocolors@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz"
+ integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==
+
+picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1:
+ version "2.3.1"
+ resolved "https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz"
+ integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==
+
+pify@^4.0.1:
+ version "4.0.1"
+ resolved "https://registry.npmmirror.com/pify/-/pify-4.0.1.tgz"
+ integrity sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==
+
+pinia-plugin-persistedstate@^3.0.2:
+ version "3.0.2"
+ resolved "https://registry.npmmirror.com/pinia-plugin-persistedstate/-/pinia-plugin-persistedstate-3.0.2.tgz"
+ integrity sha512-84vPyUhPA/8Pr+1mT1ioNb2d8z4tvdgYRqMQf8xyauOVBKjo0ZcRBwPQBV7ZAJG43Kwar43nXG2jU+ZMvAFFRQ==
+
+pinia@^2.0.0, pinia@^2.0.28:
+ version "2.0.29"
+ resolved "https://registry.npmmirror.com/pinia/-/pinia-2.0.29.tgz"
+ integrity sha512-5z/KpFecq/cIgfeTnulJXldiLcTITRkTe3N58RKYSj0Pc1EdR6oyCdnf5A9jLoVwBqX5LtHhd0kGlpzWvk9oiQ==
+ dependencies:
+ "@vue/devtools-api" "^6.4.5"
+ vue-demi "*"
+
+pkg-types@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/pkg-types/-/pkg-types-1.0.1.tgz"
+ integrity sha512-jHv9HB+Ho7dj6ItwppRDDl0iZRYBD0jsakHXtFgoLr+cHSF6xC+QL54sJmWxyGxOLYSHm0afhXhXcQDQqH9z8g==
+ dependencies:
+ jsonc-parser "^3.2.0"
+ mlly "^1.0.0"
+ pathe "^1.0.0"
+
+postcss-html@^1.5.0:
+ version "1.5.0"
+ resolved "https://registry.npmmirror.com/postcss-html/-/postcss-html-1.5.0.tgz"
+ integrity sha512-kCMRWJRHKicpA166kc2lAVUGxDZL324bkj/pVOb6RhjB0Z5Krl7mN0AsVkBhVIRZZirY0lyQXG38HCVaoKVNoA==
+ dependencies:
+ htmlparser2 "^8.0.0"
+ js-tokens "^8.0.0"
+ postcss "^8.4.0"
+ postcss-safe-parser "^6.0.0"
+
+postcss-less@^6.0.0:
+ version "6.0.0"
+ resolved "https://registry.npmmirror.com/postcss-less/-/postcss-less-6.0.0.tgz"
+ integrity sha512-FPX16mQLyEjLzEuuJtxA8X3ejDLNGGEG503d2YGZR5Ask1SpDN8KmZUMpzCvyalWRywAn1n1VOA5dcqfCLo5rg==
+
+postcss-media-query-parser@^0.2.3:
+ version "0.2.3"
+ resolved "https://registry.npmmirror.com/postcss-media-query-parser/-/postcss-media-query-parser-0.2.3.tgz"
+ integrity sha512-3sOlxmbKcSHMjlUXQZKQ06jOswE7oVkXPxmZdoB1r5l0q6gTFTQSHxNxOrCccElbW7dxNytifNEo8qidX2Vsig==
+
+postcss-resolve-nested-selector@^0.1.1:
+ version "0.1.1"
+ resolved "https://registry.npmmirror.com/postcss-resolve-nested-selector/-/postcss-resolve-nested-selector-0.1.1.tgz"
+ integrity sha512-HvExULSwLqHLgUy1rl3ANIqCsvMS0WHss2UOsXhXnQaZ9VCc2oBvIpXrl00IUFT5ZDITME0o6oiXeiHr2SAIfw==
+
+postcss-safe-parser@^6.0.0:
+ version "6.0.0"
+ resolved "https://registry.npmmirror.com/postcss-safe-parser/-/postcss-safe-parser-6.0.0.tgz"
+ integrity sha512-FARHN8pwH+WiS2OPCxJI8FuRJpTVnn6ZNFiqAM2aeW2LwTHWWmWgIyKC6cUo0L8aeKiF/14MNvnpls6R2PBeMQ==
+
+postcss-selector-parser@^6.0.10, postcss-selector-parser@^6.0.11, postcss-selector-parser@^6.0.9:
+ version "6.0.11"
+ resolved "https://registry.npmmirror.com/postcss-selector-parser/-/postcss-selector-parser-6.0.11.tgz"
+ integrity sha512-zbARubNdogI9j7WY4nQJBiNqQf3sLS3wCP4WfOidu+p28LofJqDH1tcXypGrcmMHhDk2t9wGhCsYe/+szLTy1g==
+ dependencies:
+ cssesc "^3.0.0"
+ util-deprecate "^1.0.2"
+
+postcss-sorting@^8.0.1:
+ version "8.0.1"
+ resolved "https://registry.npmmirror.com/postcss-sorting/-/postcss-sorting-8.0.1.tgz"
+ integrity sha512-go9Zoxx7KQH+uLrJ9xa5wRErFeXu01ydA6O8m7koPXkmAN7Ts//eRcIqjo0stBR4+Nir2gMYDOWAOx7O5EPUZA==
+
+postcss-value-parser@^4.2.0:
+ version "4.2.0"
+ resolved "https://registry.npmmirror.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz"
+ integrity sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==
+
+postcss@^8.1.0, postcss@^8.1.10, postcss@^8.3.3, postcss@^8.3.5, postcss@^8.4, postcss@^8.4.0, postcss@^8.4.19, postcss@^8.4.20, postcss@^8.4.21:
+ version "8.4.21"
+ resolved "https://registry.npmmirror.com/postcss/-/postcss-8.4.21.tgz"
+ integrity sha512-tP7u/Sn/dVxK2NnruI4H9BG+x+Wxz6oeZ1cJ8P6G/PZY0IKk4k/63TDsQf2kQq3+qoJeLm2kIBUNlZe3zgb4Zg==
+ dependencies:
+ nanoid "^3.3.4"
+ picocolors "^1.0.0"
+ source-map-js "^1.0.2"
+
+prelude-ls@^1.2.1:
+ version "1.2.1"
+ resolved "https://registry.npmmirror.com/prelude-ls/-/prelude-ls-1.2.1.tgz"
+ integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==
+
+prettier-linter-helpers@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz"
+ integrity sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==
+ dependencies:
+ fast-diff "^1.1.2"
+
+prettier@^2.8.3, prettier@>=2.0.0:
+ version "2.8.3"
+ resolved "https://registry.npmmirror.com/prettier/-/prettier-2.8.3.tgz"
+ integrity sha512-tJ/oJ4amDihPoufT5sM0Z1SKEuKay8LfVAMlbbhnnkvt6BUserZylqo2PN+p9KeljLr0OHa2rXHU1T8reeoTrw==
+
+progress@^2.0.3:
+ version "2.0.3"
+ resolved "https://registry.npmmirror.com/progress/-/progress-2.0.3.tgz"
+ integrity sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==
+
+proxy-from-env@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.npmmirror.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz"
+ integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==
+
+prr@~1.0.1:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/prr/-/prr-1.0.1.tgz"
+ integrity sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==
+
+punycode@^2.1.0:
+ version "2.3.0"
+ resolved "https://registry.npmmirror.com/punycode/-/punycode-2.3.0.tgz"
+ integrity sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==
+
+qs@^6.11.0:
+ version "6.11.0"
+ resolved "https://registry.npmmirror.com/qs/-/qs-6.11.0.tgz"
+ integrity sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==
+ dependencies:
+ side-channel "^1.0.4"
+
+queue-microtask@^1.2.2:
+ version "1.2.3"
+ resolved "https://registry.npmmirror.com/queue-microtask/-/queue-microtask-1.2.3.tgz"
+ integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==
+
+quick-lru@^4.0.1:
+ version "4.0.1"
+ resolved "https://registry.npmmirror.com/quick-lru/-/quick-lru-4.0.1.tgz"
+ integrity sha512-ARhCpm70fzdcvNQfPoy49IaanKkTlRWF2JMzqhcJbhSFRZv7nPTvZJdcY7301IPmvW+/p0RgIWnQDLJxifsQ7g==
+
+randombytes@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/randombytes/-/randombytes-2.1.0.tgz"
+ integrity sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==
+ dependencies:
+ safe-buffer "^5.1.0"
+
+rd@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.npmmirror.com/rd/-/rd-2.0.1.tgz"
+ integrity sha512-/XdKU4UazUZTXFmI0dpABt8jSXPWcEyaGdk340KdHnsEOdkTctlX23aAK7ChQDn39YGNlAJr1M5uvaKt4QnpNw==
+ dependencies:
+ "@types/node" "^10.3.6"
+
+read-pkg-up@^7.0.1:
+ version "7.0.1"
+ resolved "https://registry.npmmirror.com/read-pkg-up/-/read-pkg-up-7.0.1.tgz"
+ integrity sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg==
+ dependencies:
+ find-up "^4.1.0"
+ read-pkg "^5.2.0"
+ type-fest "^0.8.1"
+
+read-pkg@^5.2.0:
+ version "5.2.0"
+ resolved "https://registry.npmmirror.com/read-pkg/-/read-pkg-5.2.0.tgz"
+ integrity sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==
+ dependencies:
+ "@types/normalize-package-data" "^2.4.0"
+ normalize-package-data "^2.5.0"
+ parse-json "^5.0.0"
+ type-fest "^0.6.0"
+
+readdirp@~3.6.0:
+ version "3.6.0"
+ resolved "https://registry.npmmirror.com/readdirp/-/readdirp-3.6.0.tgz"
+ integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==
+ dependencies:
+ picomatch "^2.2.1"
+
+redent@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/redent/-/redent-3.0.0.tgz"
+ integrity sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg==
+ dependencies:
+ indent-string "^4.0.0"
+ strip-indent "^3.0.0"
+
+regenerator-runtime@^0.13.11:
+ version "0.13.11"
+ resolved "https://registry.npmmirror.com/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz"
+ integrity sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==
+
+regexpp@^3.2.0:
+ version "3.2.0"
+ resolved "https://registry.npmmirror.com/regexpp/-/regexpp-3.2.0.tgz"
+ integrity sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==
+
+require-directory@^2.1.1:
+ version "2.1.1"
+ resolved "https://registry.npmmirror.com/require-directory/-/require-directory-2.1.1.tgz"
+ integrity sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==
+
+require-from-string@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.npmmirror.com/require-from-string/-/require-from-string-2.0.2.tgz"
+ integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==
+
+resize-observer-polyfill@^1.5.1:
+ version "1.5.1"
+ resolved "https://registry.npmmirror.com/resize-observer-polyfill/-/resize-observer-polyfill-1.5.1.tgz"
+ integrity sha512-LwZrotdHOo12nQuZlHEmtuXdqGoOD0OhaxopaNFxWzInpEgaLWoVuAMbTzixuosCx2nEG58ngzW3vxdWoxIgdg==
+
+resolve-from@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/resolve-from/-/resolve-from-4.0.0.tgz"
+ integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==
+
+resolve-from@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.npmmirror.com/resolve-from/-/resolve-from-5.0.0.tgz"
+ integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==
+
+resolve@^1.10.0, resolve@^1.22.1:
+ version "1.22.1"
+ resolved "https://registry.npmmirror.com/resolve/-/resolve-1.22.1.tgz"
+ integrity sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==
+ dependencies:
+ is-core-module "^2.9.0"
+ path-parse "^1.0.7"
+ supports-preserve-symlinks-flag "^1.0.0"
+
+reusify@^1.0.4:
+ version "1.0.4"
+ resolved "https://registry.npmmirror.com/reusify/-/reusify-1.0.4.tgz"
+ integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==
+
+rimraf@^3.0.2:
+ version "3.0.2"
+ resolved "https://registry.npmmirror.com/rimraf/-/rimraf-3.0.2.tgz"
+ integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==
+ dependencies:
+ glob "^7.1.3"
+
+rollup-plugin-visualizer@^5.9.0:
+ version "5.9.0"
+ resolved "https://registry.npmmirror.com/rollup-plugin-visualizer/-/rollup-plugin-visualizer-5.9.0.tgz"
+ integrity sha512-bbDOv47+Bw4C/cgs0czZqfm8L82xOZssk4ayZjG40y9zbXclNk7YikrZTDao6p7+HDiGxrN0b65SgZiVm9k1Cg==
+ dependencies:
+ open "^8.4.0"
+ picomatch "^2.3.1"
+ source-map "^0.7.4"
+ yargs "^17.5.1"
+
+rollup@^1.20.0||^2.0.0||^3.0.0, rollup@^3.7.0, "rollup@2.x || 3.x":
+ version "3.20.7"
+ resolved "https://registry.npmmirror.com/rollup/-/rollup-3.20.7.tgz"
+ integrity sha512-P7E2zezKSLhWnTz46XxjSmInrbOCiul1yf+kJccMxT56vxjHwCbDfoLbiqFgu+WQoo9ij2PkraYaBstgB2prBA==
+ optionalDependencies:
+ fsevents "~2.3.2"
+
+run-parallel@^1.1.9:
+ version "1.2.0"
+ resolved "https://registry.npmmirror.com/run-parallel/-/run-parallel-1.2.0.tgz"
+ integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==
+ dependencies:
+ queue-microtask "^1.2.2"
+
+safe-buffer@^5.1.0:
+ version "5.2.1"
+ resolved "https://registry.npmmirror.com/safe-buffer/-/safe-buffer-5.2.1.tgz"
+ integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==
+
+"safer-buffer@>= 2.1.2 < 3.0.0":
+ version "2.1.2"
+ resolved "https://registry.npmmirror.com/safer-buffer/-/safer-buffer-2.1.2.tgz"
+ integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==
+
+sax@^1.2.4:
+ version "1.2.4"
+ resolved "https://registry.npmmirror.com/sax/-/sax-1.2.4.tgz"
+ integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==
+
+schema-utils@^3.1.1, schema-utils@^3.1.2:
+ version "3.1.2"
+ resolved "https://registry.npmmirror.com/schema-utils/-/schema-utils-3.1.2.tgz"
+ integrity sha512-pvjEHOgWc9OWA/f/DE3ohBWTD6EleVLf7iFUkoSwAxttdBhB9QUebQgxER2kWueOvRJXPHNnyrvvh9eZINB8Eg==
+ dependencies:
+ "@types/json-schema" "^7.0.8"
+ ajv "^6.12.5"
+ ajv-keywords "^3.5.2"
+
+scroll-into-view-if-needed@^2.2.25:
+ version "2.2.31"
+ resolved "https://registry.npmmirror.com/scroll-into-view-if-needed/-/scroll-into-view-if-needed-2.2.31.tgz"
+ integrity sha512-dGCXy99wZQivjmjIqihaBQNjryrz5rueJY7eHfTdyWEiR4ttYpsajb14rn9s5d4DY4EcY6+4+U/maARBXJedkA==
+ dependencies:
+ compute-scroll-into-view "^1.0.20"
+
+scule@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/scule/-/scule-1.0.0.tgz"
+ integrity sha512-4AsO/FrViE/iDNEPaAQlb77tf0csuq27EsVpy6ett584EcRTp6pTDLoGWVxCD77y5iU5FauOvhsI4o1APwPoSQ==
+
+semver@^5.6.0:
+ version "5.7.1"
+ resolved "https://registry.npmmirror.com/semver/-/semver-5.7.1.tgz"
+ integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==
+
+semver@^6.3.0:
+ version "6.3.0"
+ resolved "https://registry.npmmirror.com/semver/-/semver-6.3.0.tgz"
+ integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==
+
+semver@^7.3.4, semver@^7.3.5, semver@^7.3.6, semver@^7.3.7:
+ version "7.3.8"
+ resolved "https://registry.npmmirror.com/semver/-/semver-7.3.8.tgz"
+ integrity sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==
+ dependencies:
+ lru-cache "^6.0.0"
+
+"semver@2 || 3 || 4 || 5":
+ version "5.7.1"
+ resolved "https://registry.npmmirror.com/semver/-/semver-5.7.1.tgz"
+ integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==
+
+serialize-javascript@^6.0.1:
+ version "6.0.1"
+ resolved "https://registry.npmmirror.com/serialize-javascript/-/serialize-javascript-6.0.1.tgz"
+ integrity sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w==
+ dependencies:
+ randombytes "^2.1.0"
+
+shallow-equal@^1.0.0:
+ version "1.2.1"
+ resolved "https://registry.npmmirror.com/shallow-equal/-/shallow-equal-1.2.1.tgz"
+ integrity sha512-S4vJDjHHMBaiZuT9NPb616CSmLf618jawtv3sufLl6ivK8WocjAo58cXwbRV1cgqxH0Qbv+iUt6m05eqEa2IRA==
+
+shebang-command@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/shebang-command/-/shebang-command-2.0.0.tgz"
+ integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==
+ dependencies:
+ shebang-regex "^3.0.0"
+
+shebang-regex@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/shebang-regex/-/shebang-regex-3.0.0.tgz"
+ integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==
+
+side-channel@^1.0.4:
+ version "1.0.4"
+ resolved "https://registry.npmmirror.com/side-channel/-/side-channel-1.0.4.tgz"
+ integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==
+ dependencies:
+ call-bind "^1.0.0"
+ get-intrinsic "^1.0.2"
+ object-inspect "^1.9.0"
+
+signal-exit@^3.0.7:
+ version "3.0.7"
+ resolved "https://registry.npmmirror.com/signal-exit/-/signal-exit-3.0.7.tgz"
+ integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==
+
+slash@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/slash/-/slash-3.0.0.tgz"
+ integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==
+
+slice-ansi@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/slice-ansi/-/slice-ansi-4.0.0.tgz"
+ integrity sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==
+ dependencies:
+ ansi-styles "^4.0.0"
+ astral-regex "^2.0.0"
+ is-fullwidth-code-point "^3.0.0"
+
+source-map-js@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.npmmirror.com/source-map-js/-/source-map-js-1.0.2.tgz"
+ integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==
+
+source-map-support@~0.5.20:
+ version "0.5.21"
+ resolved "https://registry.npmmirror.com/source-map-support/-/source-map-support-0.5.21.tgz"
+ integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==
+ dependencies:
+ buffer-from "^1.0.0"
+ source-map "^0.6.0"
+
+source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.0:
+ version "0.6.1"
+ resolved "https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz"
+ integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==
+
+source-map@^0.7.4:
+ version "0.7.4"
+ resolved "https://registry.npmmirror.com/source-map/-/source-map-0.7.4.tgz"
+ integrity sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==
+
+sourcemap-codec@^1.4.8:
+ version "1.4.8"
+ resolved "https://registry.npmmirror.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz"
+ integrity sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==
+
+spdx-correct@^3.0.0:
+ version "3.1.1"
+ resolved "https://registry.npmmirror.com/spdx-correct/-/spdx-correct-3.1.1.tgz"
+ integrity sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==
+ dependencies:
+ spdx-expression-parse "^3.0.0"
+ spdx-license-ids "^3.0.0"
+
+spdx-exceptions@^2.1.0:
+ version "2.3.0"
+ resolved "https://registry.npmmirror.com/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz"
+ integrity sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==
+
+spdx-expression-parse@^3.0.0:
+ version "3.0.1"
+ resolved "https://registry.npmmirror.com/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz"
+ integrity sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==
+ dependencies:
+ spdx-exceptions "^2.1.0"
+ spdx-license-ids "^3.0.0"
+
+spdx-license-ids@^3.0.0:
+ version "3.0.12"
+ resolved "https://registry.npmmirror.com/spdx-license-ids/-/spdx-license-ids-3.0.12.tgz"
+ integrity sha512-rr+VVSXtRhO4OHbXUiAF7xW3Bo9DuuF6C5jH+q/x15j2jniycgKbxU09Hr0WqlSLUs4i4ltHGXqTe7VHclYWyA==
+
+string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3:
+ version "4.2.3"
+ resolved "https://registry.npmmirror.com/string-width/-/string-width-4.2.3.tgz"
+ integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==
+ dependencies:
+ emoji-regex "^8.0.0"
+ is-fullwidth-code-point "^3.0.0"
+ strip-ansi "^6.0.1"
+
+strip-ansi@^6.0.0, strip-ansi@^6.0.1:
+ version "6.0.1"
+ resolved "https://registry.npmmirror.com/strip-ansi/-/strip-ansi-6.0.1.tgz"
+ integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==
+ dependencies:
+ ansi-regex "^5.0.1"
+
+strip-indent@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.npmmirror.com/strip-indent/-/strip-indent-3.0.0.tgz"
+ integrity sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==
+ dependencies:
+ min-indent "^1.0.0"
+
+strip-json-comments@^3.1.0, strip-json-comments@^3.1.1:
+ version "3.1.1"
+ resolved "https://registry.npmmirror.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz"
+ integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==
+
+strip-literal@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/strip-literal/-/strip-literal-1.0.0.tgz"
+ integrity sha512-5o4LsH1lzBzO9UFH63AJ2ad2/S2AVx6NtjOcaz+VTT2h1RiRvbipW72z8M/lxEhcPHDBQwpDrnTF7sXy/7OwCQ==
+ dependencies:
+ acorn "^8.8.1"
+
+style-search@^0.1.0:
+ version "0.1.0"
+ resolved "https://registry.npmmirror.com/style-search/-/style-search-0.1.0.tgz"
+ integrity sha512-Dj1Okke1C3uKKwQcetra4jSuk0DqbzbYtXipzFlFMZtowbF1x7BKJwB9AayVMyFARvU8EDrZdcax4At/452cAg==
+
+stylelint-config-recommended@^9.0.0:
+ version "9.0.0"
+ resolved "https://registry.npmmirror.com/stylelint-config-recommended/-/stylelint-config-recommended-9.0.0.tgz"
+ integrity sha512-9YQSrJq4NvvRuTbzDsWX3rrFOzOlYBmZP+o513BJN/yfEmGSr0AxdvrWs0P/ilSpVV/wisamAHu5XSk8Rcf4CQ==
+
+stylelint-config-standard@^29.0.0:
+ version "29.0.0"
+ resolved "https://registry.npmmirror.com/stylelint-config-standard/-/stylelint-config-standard-29.0.0.tgz"
+ integrity sha512-uy8tZLbfq6ZrXy4JKu3W+7lYLgRQBxYTUUB88vPgQ+ZzAxdrvcaSUW9hOMNLYBnwH+9Kkj19M2DHdZ4gKwI7tg==
+ dependencies:
+ stylelint-config-recommended "^9.0.0"
+
+stylelint-order@^6.0.1:
+ version "6.0.1"
+ resolved "https://registry.npmmirror.com/stylelint-order/-/stylelint-order-6.0.1.tgz"
+ integrity sha512-C9gJDZArRBZvn+4MPgggwYTp7dK49WPnYa5+6tBEkZnW/YWj4xBVNJdQjIik14w5orlF9RqFpYDHN0FPWIFOSQ==
+ dependencies:
+ postcss "^8.4.20"
+ postcss-sorting "^8.0.1"
+
+stylelint@^14.0.0, stylelint@^14.10.0, stylelint@^14.14.0, stylelint@^14.16.1:
+ version "14.16.1"
+ resolved "https://registry.npmmirror.com/stylelint/-/stylelint-14.16.1.tgz"
+ integrity sha512-ErlzR/T3hhbV+a925/gbfc3f3Fep9/bnspMiJPorfGEmcBbXdS+oo6LrVtoUZ/w9fqD6o6k7PtUlCOsCRdjX/A==
+ dependencies:
+ "@csstools/selector-specificity" "^2.0.2"
+ balanced-match "^2.0.0"
+ colord "^2.9.3"
+ cosmiconfig "^7.1.0"
+ css-functions-list "^3.1.0"
+ debug "^4.3.4"
+ fast-glob "^3.2.12"
+ fastest-levenshtein "^1.0.16"
+ file-entry-cache "^6.0.1"
+ global-modules "^2.0.0"
+ globby "^11.1.0"
+ globjoin "^0.1.4"
+ html-tags "^3.2.0"
+ ignore "^5.2.1"
+ import-lazy "^4.0.0"
+ imurmurhash "^0.1.4"
+ is-plain-object "^5.0.0"
+ known-css-properties "^0.26.0"
+ mathml-tag-names "^2.1.3"
+ meow "^9.0.0"
+ micromatch "^4.0.5"
+ normalize-path "^3.0.0"
+ picocolors "^1.0.0"
+ postcss "^8.4.19"
+ postcss-media-query-parser "^0.2.3"
+ postcss-resolve-nested-selector "^0.1.1"
+ postcss-safe-parser "^6.0.0"
+ postcss-selector-parser "^6.0.11"
+ postcss-value-parser "^4.2.0"
+ resolve-from "^5.0.0"
+ string-width "^4.2.3"
+ strip-ansi "^6.0.1"
+ style-search "^0.1.0"
+ supports-hyperlinks "^2.3.0"
+ svg-tags "^1.0.0"
+ table "^6.8.1"
+ v8-compile-cache "^2.3.0"
+ write-file-atomic "^4.0.2"
+
+supports-color@^5.3.0:
+ version "5.5.0"
+ resolved "https://registry.npmmirror.com/supports-color/-/supports-color-5.5.0.tgz"
+ integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==
+ dependencies:
+ has-flag "^3.0.0"
+
+supports-color@^7.0.0:
+ version "7.2.0"
+ resolved "https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz"
+ integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==
+ dependencies:
+ has-flag "^4.0.0"
+
+supports-color@^7.1.0:
+ version "7.2.0"
+ resolved "https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz"
+ integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==
+ dependencies:
+ has-flag "^4.0.0"
+
+supports-color@^8.0.0:
+ version "8.1.1"
+ resolved "https://registry.npmmirror.com/supports-color/-/supports-color-8.1.1.tgz"
+ integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==
+ dependencies:
+ has-flag "^4.0.0"
+
+supports-hyperlinks@^2.3.0:
+ version "2.3.0"
+ resolved "https://registry.npmmirror.com/supports-hyperlinks/-/supports-hyperlinks-2.3.0.tgz"
+ integrity sha512-RpsAZlpWcDwOPQA22aCH4J0t7L8JmAvsCxfOSEwm7cQs3LshN36QaTkwd70DnBOXDWGssw2eUoc8CaRWT0XunA==
+ dependencies:
+ has-flag "^4.0.0"
+ supports-color "^7.0.0"
+
+supports-preserve-symlinks-flag@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz"
+ integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==
+
+svg-tags@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.npmmirror.com/svg-tags/-/svg-tags-1.0.0.tgz"
+ integrity sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==
+
+table@^6.8.1:
+ version "6.8.1"
+ resolved "https://registry.npmmirror.com/table/-/table-6.8.1.tgz"
+ integrity sha512-Y4X9zqrCftUhMeH2EptSSERdVKt/nEdijTOacGD/97EKjhQ/Qs8RTlEGABSJNNN8lac9kheH+af7yAkEWlgneA==
+ dependencies:
+ ajv "^8.0.1"
+ lodash.truncate "^4.4.2"
+ slice-ansi "^4.0.0"
+ string-width "^4.2.3"
+ strip-ansi "^6.0.1"
+
+tapable@^2.1.1, tapable@^2.2.0:
+ version "2.2.1"
+ resolved "https://registry.npmmirror.com/tapable/-/tapable-2.2.1.tgz"
+ integrity sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==
+
+terser-webpack-plugin@^5.3.7:
+ version "5.3.7"
+ resolved "https://registry.npmmirror.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.7.tgz"
+ integrity sha512-AfKwIktyP7Cu50xNjXF/6Qb5lBNzYaWpU6YfoX3uZicTx0zTy0stDDCsvjDapKsSDvOeWo5MEq4TmdBy2cNoHw==
+ dependencies:
+ "@jridgewell/trace-mapping" "^0.3.17"
+ jest-worker "^27.4.5"
+ schema-utils "^3.1.1"
+ serialize-javascript "^6.0.1"
+ terser "^5.16.5"
+
+terser@^5.16.5, terser@^5.4.0:
+ version "5.17.1"
+ resolved "https://registry.npmmirror.com/terser/-/terser-5.17.1.tgz"
+ integrity sha512-hVl35zClmpisy6oaoKALOpS0rDYLxRFLHhRuDlEGTKey9qHjS1w9GMORjuwIMt70Wan4lwsLYyWDVnWgF+KUEw==
+ dependencies:
+ "@jridgewell/source-map" "^0.3.2"
+ acorn "^8.5.0"
+ commander "^2.20.0"
+ source-map-support "~0.5.20"
+
+text-table@^0.2.0:
+ version "0.2.0"
+ resolved "https://registry.npmmirror.com/text-table/-/text-table-0.2.0.tgz"
+ integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==
+
+to-fast-properties@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz"
+ integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==
+
+to-regex-range@^5.0.1:
+ version "5.0.1"
+ resolved "https://registry.npmmirror.com/to-regex-range/-/to-regex-range-5.0.1.tgz"
+ integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==
+ dependencies:
+ is-number "^7.0.0"
+
+trim-newlines@^3.0.0:
+ version "3.0.1"
+ resolved "https://registry.npmmirror.com/trim-newlines/-/trim-newlines-3.0.1.tgz"
+ integrity sha512-c1PTsA3tYrIsLGkJkzHF+w9F2EyxfXGo4UyJc4pFL++FMjnq0HJS69T3M7d//gKrFKwy429bouPescbjecU+Zw==
+
+tslib@^1.8.1:
+ version "1.14.1"
+ resolved "https://registry.npmmirror.com/tslib/-/tslib-1.14.1.tgz"
+ integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==
+
+tslib@^2.3.0:
+ version "2.5.0"
+ resolved "https://registry.npmmirror.com/tslib/-/tslib-2.5.0.tgz"
+ integrity sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==
+
+tsutils@^3.21.0:
+ version "3.21.0"
+ resolved "https://registry.npmmirror.com/tsutils/-/tsutils-3.21.0.tgz"
+ integrity sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==
+ dependencies:
+ tslib "^1.8.1"
+
+type-check@^0.4.0, type-check@~0.4.0:
+ version "0.4.0"
+ resolved "https://registry.npmmirror.com/type-check/-/type-check-0.4.0.tgz"
+ integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==
+ dependencies:
+ prelude-ls "^1.2.1"
+
+type-fest@^0.18.0:
+ version "0.18.1"
+ resolved "https://registry.npmmirror.com/type-fest/-/type-fest-0.18.1.tgz"
+ integrity sha512-OIAYXk8+ISY+qTOwkHtKqzAuxchoMiD9Udx+FSGQDuiRR+PJKJHc2NJAXlbhkGwTt/4/nKZxELY1w3ReWOL8mw==
+
+type-fest@^0.20.2:
+ version "0.20.2"
+ resolved "https://registry.npmmirror.com/type-fest/-/type-fest-0.20.2.tgz"
+ integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==
+
+type-fest@^0.6.0:
+ version "0.6.0"
+ resolved "https://registry.npmmirror.com/type-fest/-/type-fest-0.6.0.tgz"
+ integrity sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg==
+
+type-fest@^0.8.1:
+ version "0.8.1"
+ resolved "https://registry.npmmirror.com/type-fest/-/type-fest-0.8.1.tgz"
+ integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==
+
+"typescript@>=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta", typescript@>=4.4.4, typescript@4.9.4:
+ version "4.9.4"
+ resolved "https://registry.npmmirror.com/typescript/-/typescript-4.9.4.tgz"
+ integrity sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==
+
+ufo@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/ufo/-/ufo-1.0.1.tgz"
+ integrity sha512-boAm74ubXHY7KJQZLlXrtMz52qFvpsbOxDcZOnw/Wf+LS4Mmyu7JxmzD4tDLtUQtmZECypJ0FrCz4QIe6dvKRA==
+
+undici-types@~6.19.2:
+ version "6.19.8"
+ resolved "https://registry.npmmirror.com/undici-types/-/undici-types-6.19.8.tgz"
+ integrity sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==
+
+unimport@^2.0.1:
+ version "2.1.0"
+ resolved "https://registry.npmmirror.com/unimport/-/unimport-2.1.0.tgz"
+ integrity sha512-GDVIxATluUquX8EqelT6DtnmnZaXGID1jsO9IXwlnxb0OIEqKAxTOnTlnGmHbseoGTh+ZC9kcNDaO18HYQj9KA==
+ dependencies:
+ "@rollup/pluginutils" "^5.0.2"
+ escape-string-regexp "^5.0.0"
+ fast-glob "^3.2.12"
+ local-pkg "^0.4.3"
+ magic-string "^0.27.0"
+ mlly "^1.1.0"
+ pathe "^1.1.0"
+ pkg-types "^1.0.1"
+ scule "^1.0.0"
+ strip-literal "^1.0.0"
+ unplugin "^1.0.1"
+
+universalify@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.npmmirror.com/universalify/-/universalify-2.0.0.tgz"
+ integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ==
+
+unplugin-auto-import@^0.12.2:
+ version "0.12.2"
+ resolved "https://registry.npmmirror.com/unplugin-auto-import/-/unplugin-auto-import-0.12.2.tgz"
+ integrity sha512-hC4w0GZjPjmLtrxV0u10XO350V9eCtQyEyifXr7B9UGD7SvbbIvKuOcHt58Zd4FAqZJXKWoXkpr9mdhBp85Usw==
+ dependencies:
+ "@antfu/utils" "^0.7.2"
+ "@rollup/pluginutils" "^5.0.2"
+ local-pkg "^0.4.3"
+ magic-string "^0.27.0"
+ unimport "^2.0.1"
+ unplugin "^1.0.1"
+
+unplugin@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.npmmirror.com/unplugin/-/unplugin-1.0.1.tgz"
+ integrity sha512-aqrHaVBWW1JVKBHmGo33T5TxeL0qWzfvjWokObHA9bYmN7eNDkwOxmLjhioHl9878qDFMAaT51XNroRyuz7WxA==
+ dependencies:
+ acorn "^8.8.1"
+ chokidar "^3.5.3"
+ webpack-sources "^3.2.3"
+ webpack-virtual-modules "^0.5.0"
+
+update-browserslist-db@^1.0.10:
+ version "1.0.10"
+ resolved "https://registry.npmmirror.com/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz"
+ integrity sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==
+ dependencies:
+ escalade "^3.1.1"
+ picocolors "^1.0.0"
+
+uri-js@^4.2.2:
+ version "4.4.1"
+ resolved "https://registry.npmmirror.com/uri-js/-/uri-js-4.4.1.tgz"
+ integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==
+ dependencies:
+ punycode "^2.1.0"
+
+util-deprecate@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.npmmirror.com/util-deprecate/-/util-deprecate-1.0.2.tgz"
+ integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==
+
+v8-compile-cache@^2.0.3, v8-compile-cache@^2.3.0:
+ version "2.3.0"
+ resolved "https://registry.npmmirror.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz"
+ integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==
+
+validate-npm-package-license@^3.0.1:
+ version "3.0.4"
+ resolved "https://registry.npmmirror.com/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz"
+ integrity sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==
+ dependencies:
+ spdx-correct "^3.0.0"
+ spdx-expression-parse "^3.0.0"
+
+vite-plugin-compression@^0.5.1:
+ version "0.5.1"
+ resolved "https://registry.npmmirror.com/vite-plugin-compression/-/vite-plugin-compression-0.5.1.tgz"
+ integrity sha512-5QJKBDc+gNYVqL/skgFAP81Yuzo9R+EAf19d+EtsMF/i8kFUpNi3J/H01QD3Oo8zBQn+NzoCIFkpPLynoOzaJg==
+ dependencies:
+ chalk "^4.1.2"
+ debug "^4.3.3"
+ fs-extra "^10.0.0"
+
+vite-plugin-progress@^0.0.6:
+ version "0.0.6"
+ resolved "https://registry.npmmirror.com/vite-plugin-progress/-/vite-plugin-progress-0.0.6.tgz"
+ integrity sha512-pIK2TVEY4XFGrz10CQDdEufBBCDaV0geRHfXV3abGTBr+OF9O0Zmd3ZDrHJXDv4Rl3qAQP4BTCuPYQ3XqstmqA==
+ dependencies:
+ picocolors "^1.0.0"
+ progress "^2.0.3"
+ rd "^2.0.1"
+
+vite-plugin-restart@^0.3.1:
+ version "0.3.1"
+ resolved "https://registry.npmmirror.com/vite-plugin-restart/-/vite-plugin-restart-0.3.1.tgz"
+ integrity sha512-LVe74MLUwaOzXVUgRGiphYbAYNgdGF6mP5vxj5BKcKkdmzvuuw79qcNgn9kHKKaIlCCjmOUiY3qlJ8jBSBUCoA==
+ dependencies:
+ micromatch "^4.0.5"
+
+"vite@^2.9.0 || ^3.0.0 || ^4.0.0", vite@^4.0.0, vite@^4.0.3, vite@>=2.0.0, vite@>2.0.0-0:
+ version "4.0.4"
+ resolved "https://registry.npmmirror.com/vite/-/vite-4.0.4.tgz"
+ integrity sha512-xevPU7M8FU0i/80DMR+YhgrzR5KS2ORy1B4xcX/cXLsvnUWvfHuqMmVU6N0YiJ4JWGRJJsLCgjEzKjG9/GKoSw==
+ dependencies:
+ esbuild "^0.16.3"
+ postcss "^8.4.20"
+ resolve "^1.22.1"
+ rollup "^3.7.0"
+ optionalDependencies:
+ fsevents "~2.3.2"
+
+vue-demi@*:
+ version "0.13.11"
+ resolved "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.13.11.tgz"
+ integrity sha512-IR8HoEEGM65YY3ZJYAjMlKygDQn25D5ajNFNoKh9RSDMQtlzCxtfQjdQgv9jjK+m3377SsJXY8ysq8kLCZL25A==
+
+vue-eslint-parser@^9.0.1:
+ version "9.1.0"
+ resolved "https://registry.npmmirror.com/vue-eslint-parser/-/vue-eslint-parser-9.1.0.tgz"
+ integrity sha512-NGn/iQy8/Wb7RrRa4aRkokyCZfOUWk19OP5HP6JEozQFX5AoS/t+Z0ZN7FY4LlmWc4FNI922V7cvX28zctN8dQ==
+ dependencies:
+ debug "^4.3.4"
+ eslint-scope "^7.1.1"
+ eslint-visitor-keys "^3.3.0"
+ espree "^9.3.1"
+ esquery "^1.4.0"
+ lodash "^4.17.21"
+ semver "^7.3.6"
+
+vue-router@^4.1.6:
+ version "4.1.6"
+ resolved "https://registry.npmmirror.com/vue-router/-/vue-router-4.1.6.tgz"
+ integrity sha512-DYWYwsG6xNPmLq/FmZn8Ip+qrhFEzA14EI12MsMgVxvHFDYvlr4NXpVF5hrRH1wVcDP8fGi5F4rxuJSl8/r+EQ==
+ dependencies:
+ "@vue/devtools-api" "^6.4.5"
+
+vue-types@^3.0.0:
+ version "3.0.2"
+ resolved "https://registry.npmmirror.com/vue-types/-/vue-types-3.0.2.tgz"
+ integrity sha512-IwUC0Aq2zwaXqy74h4WCvFCUtoV0iSWr0snWnE9TnU18S66GAQyqQbRf2qfJtUuiFsBf6qp0MEwdonlwznlcrw==
+ dependencies:
+ is-plain-object "3.0.1"
+
+"vue@^2.6.14 || ^3.2.0", vue@^3.0.0, "vue@^3.0.0-0 || ^2.6.0", vue@^3.2.0, vue@^3.2.25, vue@^3.2.45, vue@>=3.0.3, vue@>=3.2.0, vue@3.2.45:
+ version "3.2.45"
+ resolved "https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz"
+ integrity sha512-9Nx/Mg2b2xWlXykmCwiTUCWHbWIj53bnkizBxKai1g61f2Xit700A1ljowpTIM11e3uipOeiPcSqnmBg6gyiaA==
+ dependencies:
+ "@vue/compiler-dom" "3.2.45"
+ "@vue/compiler-sfc" "3.2.45"
+ "@vue/runtime-dom" "3.2.45"
+ "@vue/server-renderer" "3.2.45"
+ "@vue/shared" "3.2.45"
+
+warning@^4.0.0:
+ version "4.0.3"
+ resolved "https://registry.npmmirror.com/warning/-/warning-4.0.3.tgz"
+ integrity sha512-rpJyN222KWIvHJ/F53XSZv0Zl/accqHR8et1kpaMTD/fLCRxtV8iX8czMzY7sVZupTI3zcUTg8eycS2kNF9l6w==
+ dependencies:
+ loose-envify "^1.0.0"
+
+watchpack@^2.4.0:
+ version "2.4.0"
+ resolved "https://registry.npmmirror.com/watchpack/-/watchpack-2.4.0.tgz"
+ integrity sha512-Lcvm7MGST/4fup+ifyKi2hjyIAwcdI4HRgtvTpIUxBRhB+RFtUh8XtDOxUfctVCnhVi+QQj49i91OyvzkJl6cg==
+ dependencies:
+ glob-to-regexp "^0.4.1"
+ graceful-fs "^4.1.2"
+
+webpack-sources@^3.2.3:
+ version "3.2.3"
+ resolved "https://registry.npmmirror.com/webpack-sources/-/webpack-sources-3.2.3.tgz"
+ integrity sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==
+
+webpack-virtual-modules@^0.5.0:
+ version "0.5.0"
+ resolved "https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.5.0.tgz"
+ integrity sha512-kyDivFZ7ZM0BVOUteVbDFhlRt7Ah/CSPwJdi8hBpkK7QLumUqdLtVfm/PX/hkcnrvr0i77fO5+TjZ94Pe+C9iw==
+
+webpack@^5.0.0, webpack@^5.1.0:
+ version "5.80.0"
+ resolved "https://registry.npmmirror.com/webpack/-/webpack-5.80.0.tgz"
+ integrity sha512-OIMiq37XK1rWO8mH9ssfFKZsXg4n6klTEDL7S8/HqbAOBBaiy8ABvXvz0dDCXeEF9gqwxSvVk611zFPjS8hJxA==
+ dependencies:
+ "@types/eslint-scope" "^3.7.3"
+ "@types/estree" "^1.0.0"
+ "@webassemblyjs/ast" "^1.11.5"
+ "@webassemblyjs/wasm-edit" "^1.11.5"
+ "@webassemblyjs/wasm-parser" "^1.11.5"
+ acorn "^8.7.1"
+ acorn-import-assertions "^1.7.6"
+ browserslist "^4.14.5"
+ chrome-trace-event "^1.0.2"
+ enhanced-resolve "^5.13.0"
+ es-module-lexer "^1.2.1"
+ eslint-scope "5.1.1"
+ events "^3.2.0"
+ glob-to-regexp "^0.4.1"
+ graceful-fs "^4.2.9"
+ json-parse-even-better-errors "^2.3.1"
+ loader-runner "^4.2.0"
+ mime-types "^2.1.27"
+ neo-async "^2.6.2"
+ schema-utils "^3.1.2"
+ tapable "^2.1.1"
+ terser-webpack-plugin "^5.3.7"
+ watchpack "^2.4.0"
+ webpack-sources "^3.2.3"
+
+which@^1.3.1:
+ version "1.3.1"
+ resolved "https://registry.npmmirror.com/which/-/which-1.3.1.tgz"
+ integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==
+ dependencies:
+ isexe "^2.0.0"
+
+which@^2.0.1:
+ version "2.0.2"
+ resolved "https://registry.npmmirror.com/which/-/which-2.0.2.tgz"
+ integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==
+ dependencies:
+ isexe "^2.0.0"
+
+word-wrap@^1.2.3:
+ version "1.2.3"
+ resolved "https://registry.npmmirror.com/word-wrap/-/word-wrap-1.2.3.tgz"
+ integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==
+
+wrap-ansi@^7.0.0:
+ version "7.0.0"
+ resolved "https://registry.npmmirror.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz"
+ integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==
+ dependencies:
+ ansi-styles "^4.0.0"
+ string-width "^4.1.0"
+ strip-ansi "^6.0.0"
+
+wrappy@1:
+ version "1.0.2"
+ resolved "https://registry.npmmirror.com/wrappy/-/wrappy-1.0.2.tgz"
+ integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==
+
+write-file-atomic@^4.0.2:
+ version "4.0.2"
+ resolved "https://registry.npmmirror.com/write-file-atomic/-/write-file-atomic-4.0.2.tgz"
+ integrity sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==
+ dependencies:
+ imurmurhash "^0.1.4"
+ signal-exit "^3.0.7"
+
+xml-name-validator@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/xml-name-validator/-/xml-name-validator-4.0.0.tgz"
+ integrity sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw==
+
+y18n@^5.0.5:
+ version "5.0.8"
+ resolved "https://registry.npmmirror.com/y18n/-/y18n-5.0.8.tgz"
+ integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==
+
+yallist@^3.0.2:
+ version "3.1.1"
+ resolved "https://registry.npmmirror.com/yallist/-/yallist-3.1.1.tgz"
+ integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==
+
+yallist@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.npmmirror.com/yallist/-/yallist-4.0.0.tgz"
+ integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==
+
+yaml@^1.10.0:
+ version "1.10.2"
+ resolved "https://registry.npmmirror.com/yaml/-/yaml-1.10.2.tgz"
+ integrity sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==
+
+yargs-parser@^20.2.3:
+ version "20.2.9"
+ resolved "https://registry.npmmirror.com/yargs-parser/-/yargs-parser-20.2.9.tgz"
+ integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==
+
+yargs-parser@^21.1.1:
+ version "21.1.1"
+ resolved "https://registry.npmmirror.com/yargs-parser/-/yargs-parser-21.1.1.tgz"
+ integrity sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==
+
+yargs@^17.5.1:
+ version "17.6.2"
+ resolved "https://registry.npmmirror.com/yargs/-/yargs-17.6.2.tgz"
+ integrity sha512-1/9UrdHjDZc0eOU0HxOHoS78C69UD3JRMvzlJ7S79S2nTaWRA/whGCTV8o9e/N/1Va9YIV7Q4sOxD8VV4pCWOw==
+ dependencies:
+ cliui "^8.0.1"
+ escalade "^3.1.1"
+ get-caller-file "^2.0.5"
+ require-directory "^2.1.1"
+ string-width "^4.2.3"
+ y18n "^5.0.5"
+ yargs-parser "^21.1.1"
+
+yocto-queue@^0.1.0:
+ version "0.1.0"
+ resolved "https://registry.npmmirror.com/yocto-queue/-/yocto-queue-0.1.0.tgz"
+ integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==
diff --git a/other/软件需求规格说明书(1).docx b/other/软件需求规格说明书(1).docx
new file mode 100644
index 0000000..5a9f1ba
Binary files /dev/null and b/other/软件需求规格说明书(1).docx differ
diff --git a/src/python_team.sql b/src/python_team.sql
new file mode 100644
index 0000000..9f1a5ba
--- /dev/null
+++ b/src/python_team.sql
@@ -0,0 +1,782 @@
+/*
+ Navicat Premium Data Transfer
+
+ Source Server : localhost连接
+ Source Server Type : MySQL
+ Source Server Version : 50737
+ Source Host : localhost:3306
+ Source Schema : python_team
+
+ Target Server Type : MySQL
+ Target Server Version : 50737
+ File Encoding : 65001
+
+ Date: 04/02/2024 17:29:54
+*/
+
+SET NAMES utf8mb4;
+SET FOREIGN_KEY_CHECKS = 0;
+
+-- ----------------------------
+-- Table structure for auth_group
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_group`;
+CREATE TABLE `auth_group` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `name` varchar(150) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `name`(`name`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_group
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for auth_group_permissions
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_group_permissions`;
+CREATE TABLE `auth_group_permissions` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `group_id` int(11) NOT NULL,
+ `permission_id` int(11) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `auth_group_permissions_group_id_permission_id_0cd325b0_uniq`(`group_id`, `permission_id`) USING BTREE,
+ INDEX `auth_group_permissio_permission_id_84c5c92e_fk_auth_perm`(`permission_id`) USING BTREE,
+ CONSTRAINT `auth_group_permissio_permission_id_84c5c92e_fk_auth_perm` FOREIGN KEY (`permission_id`) REFERENCES `auth_permission` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `auth_group_permissions_group_id_b120cbf9_fk_auth_group_id` FOREIGN KEY (`group_id`) REFERENCES `auth_group` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_group_permissions
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for auth_permission
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_permission`;
+CREATE TABLE `auth_permission` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `content_type_id` int(11) NOT NULL,
+ `codename` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `auth_permission_content_type_id_codename_01ab375a_uniq`(`content_type_id`, `codename`) USING BTREE,
+ CONSTRAINT `auth_permission_content_type_id_2f476e4b_fk_django_co` FOREIGN KEY (`content_type_id`) REFERENCES `django_content_type` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 85 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_permission
+-- ----------------------------
+INSERT INTO `auth_permission` VALUES (1, 'Can add log entry', 1, 'add_logentry');
+INSERT INTO `auth_permission` VALUES (2, 'Can change log entry', 1, 'change_logentry');
+INSERT INTO `auth_permission` VALUES (3, 'Can delete log entry', 1, 'delete_logentry');
+INSERT INTO `auth_permission` VALUES (4, 'Can view log entry', 1, 'view_logentry');
+INSERT INTO `auth_permission` VALUES (5, 'Can add permission', 2, 'add_permission');
+INSERT INTO `auth_permission` VALUES (6, 'Can change permission', 2, 'change_permission');
+INSERT INTO `auth_permission` VALUES (7, 'Can delete permission', 2, 'delete_permission');
+INSERT INTO `auth_permission` VALUES (8, 'Can view permission', 2, 'view_permission');
+INSERT INTO `auth_permission` VALUES (9, 'Can add group', 3, 'add_group');
+INSERT INTO `auth_permission` VALUES (10, 'Can change group', 3, 'change_group');
+INSERT INTO `auth_permission` VALUES (11, 'Can delete group', 3, 'delete_group');
+INSERT INTO `auth_permission` VALUES (12, 'Can view group', 3, 'view_group');
+INSERT INTO `auth_permission` VALUES (13, 'Can add user', 4, 'add_user');
+INSERT INTO `auth_permission` VALUES (14, 'Can change user', 4, 'change_user');
+INSERT INTO `auth_permission` VALUES (15, 'Can delete user', 4, 'delete_user');
+INSERT INTO `auth_permission` VALUES (16, 'Can view user', 4, 'view_user');
+INSERT INTO `auth_permission` VALUES (17, 'Can add content type', 5, 'add_contenttype');
+INSERT INTO `auth_permission` VALUES (18, 'Can change content type', 5, 'change_contenttype');
+INSERT INTO `auth_permission` VALUES (19, 'Can delete content type', 5, 'delete_contenttype');
+INSERT INTO `auth_permission` VALUES (20, 'Can view content type', 5, 'view_contenttype');
+INSERT INTO `auth_permission` VALUES (21, 'Can add session', 6, 'add_session');
+INSERT INTO `auth_permission` VALUES (22, 'Can change session', 6, 'change_session');
+INSERT INTO `auth_permission` VALUES (23, 'Can delete session', 6, 'delete_session');
+INSERT INTO `auth_permission` VALUES (24, 'Can view session', 6, 'view_session');
+INSERT INTO `auth_permission` VALUES (25, 'Can add ad', 7, 'add_ad');
+INSERT INTO `auth_permission` VALUES (26, 'Can change ad', 7, 'change_ad');
+INSERT INTO `auth_permission` VALUES (27, 'Can delete ad', 7, 'delete_ad');
+INSERT INTO `auth_permission` VALUES (28, 'Can view ad', 7, 'view_ad');
+INSERT INTO `auth_permission` VALUES (29, 'Can add classification', 8, 'add_classification');
+INSERT INTO `auth_permission` VALUES (30, 'Can change classification', 8, 'change_classification');
+INSERT INTO `auth_permission` VALUES (31, 'Can delete classification', 8, 'delete_classification');
+INSERT INTO `auth_permission` VALUES (32, 'Can view classification', 8, 'view_classification');
+INSERT INTO `auth_permission` VALUES (33, 'Can add error log', 9, 'add_errorlog');
+INSERT INTO `auth_permission` VALUES (34, 'Can change error log', 9, 'change_errorlog');
+INSERT INTO `auth_permission` VALUES (35, 'Can delete error log', 9, 'delete_errorlog');
+INSERT INTO `auth_permission` VALUES (36, 'Can view error log', 9, 'view_errorlog');
+INSERT INTO `auth_permission` VALUES (37, 'Can add login log', 10, 'add_loginlog');
+INSERT INTO `auth_permission` VALUES (38, 'Can change login log', 10, 'change_loginlog');
+INSERT INTO `auth_permission` VALUES (39, 'Can delete login log', 10, 'delete_loginlog');
+INSERT INTO `auth_permission` VALUES (40, 'Can view login log', 10, 'view_loginlog');
+INSERT INTO `auth_permission` VALUES (41, 'Can add notice', 11, 'add_notice');
+INSERT INTO `auth_permission` VALUES (42, 'Can change notice', 11, 'change_notice');
+INSERT INTO `auth_permission` VALUES (43, 'Can delete notice', 11, 'delete_notice');
+INSERT INTO `auth_permission` VALUES (44, 'Can view notice', 11, 'view_notice');
+INSERT INTO `auth_permission` VALUES (45, 'Can add op log', 12, 'add_oplog');
+INSERT INTO `auth_permission` VALUES (46, 'Can change op log', 12, 'change_oplog');
+INSERT INTO `auth_permission` VALUES (47, 'Can delete op log', 12, 'delete_oplog');
+INSERT INTO `auth_permission` VALUES (48, 'Can view op log', 12, 'view_oplog');
+INSERT INTO `auth_permission` VALUES (49, 'Can add tag', 13, 'add_tag');
+INSERT INTO `auth_permission` VALUES (50, 'Can change tag', 13, 'change_tag');
+INSERT INTO `auth_permission` VALUES (51, 'Can delete tag', 13, 'delete_tag');
+INSERT INTO `auth_permission` VALUES (52, 'Can view tag', 13, 'view_tag');
+INSERT INTO `auth_permission` VALUES (53, 'Can add user', 14, 'add_user');
+INSERT INTO `auth_permission` VALUES (54, 'Can change user', 14, 'change_user');
+INSERT INTO `auth_permission` VALUES (55, 'Can delete user', 14, 'delete_user');
+INSERT INTO `auth_permission` VALUES (56, 'Can view user', 14, 'view_user');
+INSERT INTO `auth_permission` VALUES (57, 'Can add thing', 15, 'add_thing');
+INSERT INTO `auth_permission` VALUES (58, 'Can change thing', 15, 'change_thing');
+INSERT INTO `auth_permission` VALUES (59, 'Can delete thing', 15, 'delete_thing');
+INSERT INTO `auth_permission` VALUES (60, 'Can view thing', 15, 'view_thing');
+INSERT INTO `auth_permission` VALUES (61, 'Can add record', 16, 'add_record');
+INSERT INTO `auth_permission` VALUES (62, 'Can change record', 16, 'change_record');
+INSERT INTO `auth_permission` VALUES (63, 'Can delete record', 16, 'delete_record');
+INSERT INTO `auth_permission` VALUES (64, 'Can view record', 16, 'view_record');
+INSERT INTO `auth_permission` VALUES (65, 'Can add order log', 17, 'add_orderlog');
+INSERT INTO `auth_permission` VALUES (66, 'Can change order log', 17, 'change_orderlog');
+INSERT INTO `auth_permission` VALUES (67, 'Can delete order log', 17, 'delete_orderlog');
+INSERT INTO `auth_permission` VALUES (68, 'Can view order log', 17, 'view_orderlog');
+INSERT INTO `auth_permission` VALUES (69, 'Can add order', 18, 'add_order');
+INSERT INTO `auth_permission` VALUES (70, 'Can change order', 18, 'change_order');
+INSERT INTO `auth_permission` VALUES (71, 'Can delete order', 18, 'delete_order');
+INSERT INTO `auth_permission` VALUES (72, 'Can view order', 18, 'view_order');
+INSERT INTO `auth_permission` VALUES (73, 'Can add comment', 19, 'add_comment');
+INSERT INTO `auth_permission` VALUES (74, 'Can change comment', 19, 'change_comment');
+INSERT INTO `auth_permission` VALUES (75, 'Can delete comment', 19, 'delete_comment');
+INSERT INTO `auth_permission` VALUES (76, 'Can view comment', 19, 'view_comment');
+INSERT INTO `auth_permission` VALUES (77, 'Can add banner', 20, 'add_banner');
+INSERT INTO `auth_permission` VALUES (78, 'Can change banner', 20, 'change_banner');
+INSERT INTO `auth_permission` VALUES (79, 'Can delete banner', 20, 'delete_banner');
+INSERT INTO `auth_permission` VALUES (80, 'Can view banner', 20, 'view_banner');
+INSERT INTO `auth_permission` VALUES (81, 'Can add address', 21, 'add_address');
+INSERT INTO `auth_permission` VALUES (82, 'Can change address', 21, 'change_address');
+INSERT INTO `auth_permission` VALUES (83, 'Can delete address', 21, 'delete_address');
+INSERT INTO `auth_permission` VALUES (84, 'Can view address', 21, 'view_address');
+
+-- ----------------------------
+-- Table structure for auth_user
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_user`;
+CREATE TABLE `auth_user` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `password` varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `last_login` datetime(6) NULL DEFAULT NULL,
+ `is_superuser` tinyint(1) NOT NULL,
+ `username` varchar(150) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `first_name` varchar(150) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `last_name` varchar(150) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `email` varchar(254) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `is_staff` tinyint(1) NOT NULL,
+ `is_active` tinyint(1) NOT NULL,
+ `date_joined` datetime(6) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `username`(`username`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_user
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for auth_user_groups
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_user_groups`;
+CREATE TABLE `auth_user_groups` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `user_id` int(11) NOT NULL,
+ `group_id` int(11) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `auth_user_groups_user_id_group_id_94350c0c_uniq`(`user_id`, `group_id`) USING BTREE,
+ INDEX `auth_user_groups_group_id_97559544_fk_auth_group_id`(`group_id`) USING BTREE,
+ CONSTRAINT `auth_user_groups_group_id_97559544_fk_auth_group_id` FOREIGN KEY (`group_id`) REFERENCES `auth_group` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `auth_user_groups_user_id_6a12ed8b_fk_auth_user_id` FOREIGN KEY (`user_id`) REFERENCES `auth_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_user_groups
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for auth_user_user_permissions
+-- ----------------------------
+DROP TABLE IF EXISTS `auth_user_user_permissions`;
+CREATE TABLE `auth_user_user_permissions` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `user_id` int(11) NOT NULL,
+ `permission_id` int(11) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `auth_user_user_permissions_user_id_permission_id_14a6b632_uniq`(`user_id`, `permission_id`) USING BTREE,
+ INDEX `auth_user_user_permi_permission_id_1fbb5f2c_fk_auth_perm`(`permission_id`) USING BTREE,
+ CONSTRAINT `auth_user_user_permi_permission_id_1fbb5f2c_fk_auth_perm` FOREIGN KEY (`permission_id`) REFERENCES `auth_permission` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `auth_user_user_permissions_user_id_a95ead1b_fk_auth_user_id` FOREIGN KEY (`user_id`) REFERENCES `auth_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of auth_user_user_permissions
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_ad
+-- ----------------------------
+DROP TABLE IF EXISTS `b_ad`;
+CREATE TABLE `b_ad` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `image` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `link` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_ad
+-- ----------------------------
+INSERT INTO `b_ad` VALUES (1, '', 'http://www.baidu.com111', '2024-02-04 17:26:04.553627');
+
+-- ----------------------------
+-- Table structure for b_address
+-- ----------------------------
+DROP TABLE IF EXISTS `b_address`;
+CREATE TABLE `b_address` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `mobile` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `desc` varchar(300) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `default` tinyint(1) NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_address_user_id_a37a8d6a_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_address_user_id_a37a8d6a_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_address
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_banner
+-- ----------------------------
+DROP TABLE IF EXISTS `b_banner`;
+CREATE TABLE `b_banner` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `image` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_banner_thing_id_3f307d00_fk_b_thing_id`(`thing_id`) USING BTREE,
+ CONSTRAINT `b_banner_thing_id_3f307d00_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_banner
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_classification
+-- ----------------------------
+DROP TABLE IF EXISTS `b_classification`;
+CREATE TABLE `b_classification` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_classification
+-- ----------------------------
+INSERT INTO `b_classification` VALUES (1, '体育类', '2024-02-04 16:39:13.697593');
+INSERT INTO `b_classification` VALUES (2, '运动类', '2024-02-04 16:39:19.397394');
+INSERT INTO `b_classification` VALUES (3, '文艺类', '2024-02-04 16:39:24.633287');
+INSERT INTO `b_classification` VALUES (4, '电子类', '2024-02-04 16:39:59.841608');
+
+-- ----------------------------
+-- Table structure for b_comment
+-- ----------------------------
+DROP TABLE IF EXISTS `b_comment`;
+CREATE TABLE `b_comment` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `content` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `comment_time` datetime(6) NULL DEFAULT NULL,
+ `like_count` int(11) NOT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_comment_thing_id_57ab492b_fk_b_thing_id`(`thing_id`) USING BTREE,
+ INDEX `b_comment_user_id_46f0670f_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_comment_thing_id_57ab492b_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_comment_user_id_46f0670f_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_comment
+-- ----------------------------
+INSERT INTO `b_comment` VALUES (1, 'dasdf', '2024-02-04 16:58:15.144159', 1, 5, 4);
+INSERT INTO `b_comment` VALUES (2, 'dfasdfff', '2024-02-04 16:58:17.850901', 1, 5, 4);
+INSERT INTO `b_comment` VALUES (3, '的地方211', '2024-02-04 17:00:55.346951', 2, 5, 4);
+
+-- ----------------------------
+-- Table structure for b_error_log
+-- ----------------------------
+DROP TABLE IF EXISTS `b_error_log`;
+CREATE TABLE `b_error_log` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `ip` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `url` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `method` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `content` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `log_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_error_log
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_login_log
+-- ----------------------------
+DROP TABLE IF EXISTS `b_login_log`;
+CREATE TABLE `b_login_log` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `username` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `ip` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `ua` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `log_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 6 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_login_log
+-- ----------------------------
+INSERT INTO `b_login_log` VALUES (1, 'admin', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 16:36:19.239685');
+INSERT INTO `b_login_log` VALUES (2, 'aaa', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 16:57:10.644691');
+INSERT INTO `b_login_log` VALUES (3, 'admin123', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 17:18:37.112379');
+INSERT INTO `b_login_log` VALUES (4, 'admin', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 17:25:59.480266');
+INSERT INTO `b_login_log` VALUES (5, 'aaa', '127.0.0.1', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36', '2024-02-04 17:27:08.481837');
+
+-- ----------------------------
+-- Table structure for b_notice
+-- ----------------------------
+DROP TABLE IF EXISTS `b_notice`;
+CREATE TABLE `b_notice` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `content` varchar(1000) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_notice
+-- ----------------------------
+INSERT INTO `b_notice` VALUES (1, 'abcd', '欢迎申请', '2024-02-04 17:26:10.000000');
+INSERT INTO `b_notice` VALUES (2, '新建社团123', '安德森对方', '2024-02-04 17:26:20.948813');
+
+-- ----------------------------
+-- Table structure for b_op_log
+-- ----------------------------
+DROP TABLE IF EXISTS `b_op_log`;
+CREATE TABLE `b_op_log` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `re_ip` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `re_time` datetime(6) NULL DEFAULT NULL,
+ `re_url` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `re_method` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `re_content` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `access_time` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 25 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_op_log
+-- ----------------------------
+INSERT INTO `b_op_log` VALUES (1, '127.0.0.1', '2024-02-04 17:25:16.003630', '/myapp/admin/loginLog/list', 'GET', NULL, '25');
+INSERT INTO `b_op_log` VALUES (2, '127.0.0.1', '2024-02-04 17:25:16.125409', '/myapp/admin/opLog/list', 'GET', NULL, '28');
+INSERT INTO `b_op_log` VALUES (3, '127.0.0.1', '2024-02-04 17:25:16.735706', '/myapp/admin/errorLog/list', 'GET', NULL, '4');
+INSERT INTO `b_op_log` VALUES (4, '127.0.0.1', '2024-02-04 17:25:17.091962', '/myapp/admin/opLog/list', 'GET', NULL, '28');
+INSERT INTO `b_op_log` VALUES (5, '127.0.0.1', '2024-02-04 17:25:17.996686', '/myapp/admin/comment/list', 'GET', NULL, '24');
+INSERT INTO `b_op_log` VALUES (6, '127.0.0.1', '2024-02-04 17:25:18.508752', '/myapp/admin/tag/list', 'GET', NULL, '28');
+INSERT INTO `b_op_log` VALUES (7, '127.0.0.1', '2024-02-04 17:25:18.995965', '/myapp/admin/order/list', 'GET', NULL, '25');
+INSERT INTO `b_op_log` VALUES (8, '127.0.0.1', '2024-02-04 17:25:19.517164', '/myapp/admin/classification/list', 'GET', NULL, '25');
+INSERT INTO `b_op_log` VALUES (9, '127.0.0.1', '2024-02-04 17:25:19.951784', '/myapp/admin/order/list', 'GET', NULL, '8');
+INSERT INTO `b_op_log` VALUES (10, '127.0.0.1', '2024-02-04 17:25:20.517535', '/myapp/admin/tag/list', 'GET', NULL, '17');
+INSERT INTO `b_op_log` VALUES (11, '127.0.0.1', '2024-02-04 17:25:20.899065', '/myapp/admin/comment/list', 'GET', NULL, '7');
+INSERT INTO `b_op_log` VALUES (12, '127.0.0.1', '2024-02-04 17:25:21.391965', '/myapp/admin/user/list', 'GET', NULL, '20');
+INSERT INTO `b_op_log` VALUES (13, '127.0.0.1', '2024-02-04 17:25:21.677749', '/myapp/admin/comment/list', 'GET', NULL, '5');
+INSERT INTO `b_op_log` VALUES (14, '127.0.0.1', '2024-02-04 17:25:24.066175', '/myapp/index/comment/list', 'GET', NULL, '3');
+INSERT INTO `b_op_log` VALUES (15, '127.0.0.1', '2024-02-04 17:25:24.083944', '/myapp/index/comment/list', 'GET', NULL, '22');
+INSERT INTO `b_op_log` VALUES (16, '127.0.0.1', '2024-02-04 17:25:24.084992', '/myapp/index/comment/list', 'GET', NULL, '23');
+INSERT INTO `b_op_log` VALUES (17, '127.0.0.1', '2024-02-04 17:25:24.090525', '/myapp/index/comment/list', 'GET', NULL, '29');
+INSERT INTO `b_op_log` VALUES (18, '127.0.0.1', '2024-02-04 17:25:24.094806', '/upload/cover/1707036810262.jpeg', 'GET', NULL, '1');
+INSERT INTO `b_op_log` VALUES (19, '127.0.0.1', '2024-02-04 17:25:24.109564', '/upload/cover/1707036756214.jpeg', 'GET', NULL, '1');
+INSERT INTO `b_op_log` VALUES (20, '127.0.0.1', '2024-02-04 17:25:24.109564', '/upload/cover/1707036858212.jpeg', 'GET', NULL, '0');
+INSERT INTO `b_op_log` VALUES (21, '127.0.0.1', '2024-02-04 17:25:24.109564', '/upload/cover/1707036756214.jpeg', 'GET', NULL, '0');
+INSERT INTO `b_op_log` VALUES (22, '127.0.0.1', '2024-02-04 17:25:24.110577', '/upload/cover/1707036638009.jpeg', 'GET', NULL, '1');
+INSERT INTO `b_op_log` VALUES (23, '127.0.0.1', '2024-02-04 17:25:24.110577', '/upload/cover/1707036701716.jpeg', 'GET', NULL, '0');
+INSERT INTO `b_op_log` VALUES (24, '127.0.0.1', '2024-02-04 17:25:27.073752', '/myapp/admin/opLog/list', 'GET', NULL, '4');
+
+-- ----------------------------
+-- Table structure for b_order
+-- ----------------------------
+DROP TABLE IF EXISTS `b_order`;
+CREATE TABLE `b_order` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `order_number` varchar(13) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `count` int(11) NOT NULL,
+ `status` varchar(2) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `order_time` datetime(6) NULL DEFAULT NULL,
+ `pay_time` datetime(6) NULL DEFAULT NULL,
+ `receiver_name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `receiver_address` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `receiver_phone` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `remark` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_order_thing_id_4e345e2c_fk_b_thing_id`(`thing_id`) USING BTREE,
+ INDEX `b_order_user_id_64854046_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_order_thing_id_4e345e2c_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_order_user_id_64854046_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_order
+-- ----------------------------
+INSERT INTO `b_order` VALUES (1, '1707037383809', 1, '2', '2024-02-04 17:03:03.811334', NULL, NULL, NULL, NULL, NULL, 5, 4);
+INSERT INTO `b_order` VALUES (2, '1707037601900', 1, '2', '2024-02-04 17:06:41.903354', NULL, NULL, NULL, NULL, NULL, 5, 4);
+INSERT INTO `b_order` VALUES (3, '1707038198529', 1, '7', '2024-02-04 17:16:38.534185', NULL, NULL, NULL, NULL, NULL, 1, 4);
+
+-- ----------------------------
+-- Table structure for b_order_log
+-- ----------------------------
+DROP TABLE IF EXISTS `b_order_log`;
+CREATE TABLE `b_order_log` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `action` varchar(2) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `log_time` datetime(6) NULL DEFAULT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_order_log_thing_id_7306f624_fk_b_thing_id`(`thing_id`) USING BTREE,
+ INDEX `b_order_log_user_id_1003e839_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_order_log_thing_id_7306f624_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_order_log_user_id_1003e839_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_order_log
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_record
+-- ----------------------------
+DROP TABLE IF EXISTS `b_record`;
+CREATE TABLE `b_record` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `record_time` datetime(6) NULL DEFAULT NULL,
+ `classification_id` bigint(20) NULL DEFAULT NULL,
+ `thing_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_record_classification_id_52591cc9_fk_b_classification_id`(`classification_id`) USING BTREE,
+ INDEX `b_record_thing_id_d8e773c0_fk_b_thing_id`(`thing_id`) USING BTREE,
+ INDEX `b_record_user_id_7e5958b0_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_record_classification_id_52591cc9_fk_b_classification_id` FOREIGN KEY (`classification_id`) REFERENCES `b_classification` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_record_thing_id_d8e773c0_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_record_user_id_7e5958b0_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_record
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for b_tag
+-- ----------------------------
+DROP TABLE IF EXISTS `b_tag`;
+CREATE TABLE `b_tag` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 6 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_tag
+-- ----------------------------
+INSERT INTO `b_tag` VALUES (1, '美女多', '2024-02-04 16:38:34.240261');
+INSERT INTO `b_tag` VALUES (2, '高材生', '2024-02-04 16:38:41.618448');
+INSERT INTO `b_tag` VALUES (3, '帅哥多', '2024-02-04 16:38:48.542216');
+INSERT INTO `b_tag` VALUES (4, '读书', '2024-02-04 16:38:57.500728');
+INSERT INTO `b_tag` VALUES (5, '跑步', '2024-02-04 16:39:05.464820');
+
+-- ----------------------------
+-- Table structure for b_thing
+-- ----------------------------
+DROP TABLE IF EXISTS `b_thing`;
+CREATE TABLE `b_thing` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `cover` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `description` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL,
+ `mobile` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `location` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `status` varchar(1) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ `pv` int(11) NOT NULL,
+ `recommend_count` int(11) NOT NULL,
+ `wish_count` int(11) NOT NULL,
+ `collect_count` int(11) NOT NULL,
+ `classification_id` bigint(20) NULL DEFAULT NULL,
+ `user_id` bigint(20) NULL DEFAULT NULL,
+ `email` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `zongzhi` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `b_thing_classification_id_47675ac4_fk_b_classification_id`(`classification_id`) USING BTREE,
+ INDEX `b_thing_user_id_9918a633_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_thing_classification_id_47675ac4_fk_b_classification_id` FOREIGN KEY (`classification_id`) REFERENCES `b_classification` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_thing_user_id_9918a633_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 8 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_thing
+-- ----------------------------
+INSERT INTO `b_thing` VALUES (1, '街舞团', 'cover/1707036603261.jpeg', 'abcfdasdf', '13422221111', '教学楼3号楼1层', '0', '2024-02-04 16:45:44.682923', 4, 0, 1, 1, 2, NULL, '123@qq.com', '为人民服务');
+INSERT INTO `b_thing` VALUES (2, 'beyond502乐队', 'cover/1707036638009.jpeg', '江河湖海就将计就计哈哈哈哈哈哈哈哈', '13455555555', '6号宿舍楼', '0', '2024-02-04 16:51:15.254882', 1, 0, 0, 0, 3, NULL, '12345@qq.com', '为了音乐而生');
+INSERT INTO `b_thing` VALUES (3, '轮滑俱乐部', 'cover/1707036701716.jpeg', '哈哈哈哈哈哈哈哈哈哈', '13422221111', '9号宿舍楼', '0', '2024-02-04 16:52:13.713017', 0, 0, 0, 0, 2, NULL, '1234@126.com', '为了运动努力');
+INSERT INTO `b_thing` VALUES (4, '王羲之书法俱乐部', 'cover/1707036756214.jpeg', '江河湖海哼哼唧唧哼哼唧唧就哈哈哈哈话剧', '13211112222', '颐和园路5号', '0', '2024-02-04 16:53:09.100387', 2, 0, 0, 0, 3, NULL, '123@qq.com', '为了哈哈哈');
+INSERT INTO `b_thing` VALUES (5, '电子琴俱乐部', 'cover/1707036810262.jpeg', '就很好很好灌灌哈哈哈哈嘎嘎嘎嘎', '13455555555', '12号教学楼', '0', '2024-02-04 16:53:56.425555', 16, 0, 1, 1, 4, NULL, '12245@qq.com', '为了生活');
+INSERT INTO `b_thing` VALUES (6, '夜跑俱乐部', 'cover/1707036858212.jpeg', '就啊哈哈的观点嘎哈韩国', '13222221111', '9号教学楼', '0', '2024-02-04 16:54:43.049737', 3, 0, 0, 0, 1, NULL, '999888@qq.com', '为了跑步');
+
+-- ----------------------------
+-- Table structure for b_thing_collect
+-- ----------------------------
+DROP TABLE IF EXISTS `b_thing_collect`;
+CREATE TABLE `b_thing_collect` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `thing_id` bigint(20) NOT NULL,
+ `user_id` bigint(20) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `b_thing_collect_thing_id_user_id_45b9f252_uniq`(`thing_id`, `user_id`) USING BTREE,
+ INDEX `b_thing_collect_user_id_e5d69968_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_thing_collect_thing_id_8edce8b3_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_thing_collect_user_id_e5d69968_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_thing_collect
+-- ----------------------------
+INSERT INTO `b_thing_collect` VALUES (2, 1, 4);
+INSERT INTO `b_thing_collect` VALUES (1, 5, 4);
+
+-- ----------------------------
+-- Table structure for b_thing_tag
+-- ----------------------------
+DROP TABLE IF EXISTS `b_thing_tag`;
+CREATE TABLE `b_thing_tag` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `thing_id` bigint(20) NOT NULL,
+ `tag_id` bigint(20) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `b_thing_tag_thing_id_tag_id_a5d426b2_uniq`(`thing_id`, `tag_id`) USING BTREE,
+ INDEX `b_thing_tag_tag_id_d02b28a1_fk_b_tag_id`(`tag_id`) USING BTREE,
+ CONSTRAINT `b_thing_tag_tag_id_d02b28a1_fk_b_tag_id` FOREIGN KEY (`tag_id`) REFERENCES `b_tag` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_thing_tag_thing_id_fb8ecf3f_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 22 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_thing_tag
+-- ----------------------------
+INSERT INTO `b_thing_tag` VALUES (1, 1, 2);
+INSERT INTO `b_thing_tag` VALUES (2, 1, 3);
+INSERT INTO `b_thing_tag` VALUES (3, 1, 4);
+INSERT INTO `b_thing_tag` VALUES (4, 1, 5);
+INSERT INTO `b_thing_tag` VALUES (5, 2, 1);
+INSERT INTO `b_thing_tag` VALUES (6, 2, 2);
+INSERT INTO `b_thing_tag` VALUES (7, 2, 3);
+INSERT INTO `b_thing_tag` VALUES (8, 2, 5);
+INSERT INTO `b_thing_tag` VALUES (9, 3, 1);
+INSERT INTO `b_thing_tag` VALUES (10, 3, 2);
+INSERT INTO `b_thing_tag` VALUES (11, 3, 3);
+INSERT INTO `b_thing_tag` VALUES (12, 3, 4);
+INSERT INTO `b_thing_tag` VALUES (13, 3, 5);
+INSERT INTO `b_thing_tag` VALUES (14, 4, 2);
+INSERT INTO `b_thing_tag` VALUES (15, 4, 4);
+INSERT INTO `b_thing_tag` VALUES (16, 4, 5);
+INSERT INTO `b_thing_tag` VALUES (17, 5, 2);
+INSERT INTO `b_thing_tag` VALUES (18, 5, 4);
+INSERT INTO `b_thing_tag` VALUES (19, 6, 1);
+INSERT INTO `b_thing_tag` VALUES (20, 6, 2);
+INSERT INTO `b_thing_tag` VALUES (21, 6, 5);
+
+-- ----------------------------
+-- Table structure for b_thing_wish
+-- ----------------------------
+DROP TABLE IF EXISTS `b_thing_wish`;
+CREATE TABLE `b_thing_wish` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `thing_id` bigint(20) NOT NULL,
+ `user_id` bigint(20) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `b_thing_wish_thing_id_user_id_9d647bbb_uniq`(`thing_id`, `user_id`) USING BTREE,
+ INDEX `b_thing_wish_user_id_e2d94f6c_fk_b_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `b_thing_wish_thing_id_f0864b16_fk_b_thing_id` FOREIGN KEY (`thing_id`) REFERENCES `b_thing` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `b_thing_wish_user_id_e2d94f6c_fk_b_user_id` FOREIGN KEY (`user_id`) REFERENCES `b_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_thing_wish
+-- ----------------------------
+INSERT INTO `b_thing_wish` VALUES (2, 1, 4);
+INSERT INTO `b_thing_wish` VALUES (1, 5, 4);
+
+-- ----------------------------
+-- Table structure for b_user
+-- ----------------------------
+DROP TABLE IF EXISTS `b_user`;
+CREATE TABLE `b_user` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `username` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `password` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `role` varchar(2) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `status` varchar(1) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `nickname` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `avatar` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `mobile` varchar(13) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `email` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `gender` varchar(1) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `description` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL,
+ `create_time` datetime(6) NULL DEFAULT NULL,
+ `score` int(11) NULL DEFAULT NULL,
+ `push_email` varchar(40) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `push_switch` tinyint(1) NULL DEFAULT NULL,
+ `admin_token` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ `token` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of b_user
+-- ----------------------------
+INSERT INTO `b_user` VALUES (1, 'admin', '78aafd3207ec4ef6d16f9fc07e95ebc3', '1', '0', NULL, '', NULL, NULL, NULL, NULL, '2024-02-04 16:36:13.029265', 0, NULL, 0, '21232f297a57a5a743894a0e4a801fc3', NULL);
+INSERT INTO `b_user` VALUES (2, 'admin123', '0192023a7bbd73250516f069df18b500', '1', '0', NULL, '', NULL, NULL, NULL, NULL, '2024-02-04 16:40:18.754982', 0, NULL, 0, '0192023a7bbd73250516f069df18b500', NULL);
+INSERT INTO `b_user` VALUES (3, 'test', '098f6bcd4621d373cade4e832627b4f6', '3', '0', NULL, '', NULL, NULL, NULL, NULL, '2024-02-04 16:40:35.603385', 0, NULL, 0, NULL, NULL);
+INSERT INTO `b_user` VALUES (4, 'aaa', '47bce5c74f589f4867dbd57e9ca9f808', '2', '0', '1233', '', NULL, NULL, NULL, NULL, '2024-02-04 16:57:07.608626', 0, NULL, 0, NULL, '47bce5c74f589f4867dbd57e9ca9f808');
+
+-- ----------------------------
+-- Table structure for django_admin_log
+-- ----------------------------
+DROP TABLE IF EXISTS `django_admin_log`;
+CREATE TABLE `django_admin_log` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `action_time` datetime(6) NOT NULL,
+ `object_id` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL,
+ `object_repr` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `action_flag` smallint(5) UNSIGNED NOT NULL,
+ `change_message` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `content_type_id` int(11) NULL DEFAULT NULL,
+ `user_id` int(11) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ INDEX `django_admin_log_content_type_id_c4bce8eb_fk_django_co`(`content_type_id`) USING BTREE,
+ INDEX `django_admin_log_user_id_c564eba6_fk_auth_user_id`(`user_id`) USING BTREE,
+ CONSTRAINT `django_admin_log_content_type_id_c4bce8eb_fk_django_co` FOREIGN KEY (`content_type_id`) REFERENCES `django_content_type` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
+ CONSTRAINT `django_admin_log_user_id_c564eba6_fk_auth_user_id` FOREIGN KEY (`user_id`) REFERENCES `auth_user` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of django_admin_log
+-- ----------------------------
+
+-- ----------------------------
+-- Table structure for django_content_type
+-- ----------------------------
+DROP TABLE IF EXISTS `django_content_type`;
+CREATE TABLE `django_content_type` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `app_label` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `model` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE,
+ UNIQUE INDEX `django_content_type_app_label_model_76bd3d3b_uniq`(`app_label`, `model`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 22 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of django_content_type
+-- ----------------------------
+INSERT INTO `django_content_type` VALUES (1, 'admin', 'logentry');
+INSERT INTO `django_content_type` VALUES (3, 'auth', 'group');
+INSERT INTO `django_content_type` VALUES (2, 'auth', 'permission');
+INSERT INTO `django_content_type` VALUES (4, 'auth', 'user');
+INSERT INTO `django_content_type` VALUES (5, 'contenttypes', 'contenttype');
+INSERT INTO `django_content_type` VALUES (7, 'myapp', 'ad');
+INSERT INTO `django_content_type` VALUES (21, 'myapp', 'address');
+INSERT INTO `django_content_type` VALUES (20, 'myapp', 'banner');
+INSERT INTO `django_content_type` VALUES (8, 'myapp', 'classification');
+INSERT INTO `django_content_type` VALUES (19, 'myapp', 'comment');
+INSERT INTO `django_content_type` VALUES (9, 'myapp', 'errorlog');
+INSERT INTO `django_content_type` VALUES (10, 'myapp', 'loginlog');
+INSERT INTO `django_content_type` VALUES (11, 'myapp', 'notice');
+INSERT INTO `django_content_type` VALUES (12, 'myapp', 'oplog');
+INSERT INTO `django_content_type` VALUES (18, 'myapp', 'order');
+INSERT INTO `django_content_type` VALUES (17, 'myapp', 'orderlog');
+INSERT INTO `django_content_type` VALUES (16, 'myapp', 'record');
+INSERT INTO `django_content_type` VALUES (13, 'myapp', 'tag');
+INSERT INTO `django_content_type` VALUES (15, 'myapp', 'thing');
+INSERT INTO `django_content_type` VALUES (14, 'myapp', 'user');
+INSERT INTO `django_content_type` VALUES (6, 'sessions', 'session');
+
+-- ----------------------------
+-- Table structure for django_migrations
+-- ----------------------------
+DROP TABLE IF EXISTS `django_migrations`;
+CREATE TABLE `django_migrations` (
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
+ `app` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `applied` datetime(6) NOT NULL,
+ PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 22 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of django_migrations
+-- ----------------------------
+INSERT INTO `django_migrations` VALUES (1, 'contenttypes', '0001_initial', '2024-02-04 16:32:51.298695');
+INSERT INTO `django_migrations` VALUES (2, 'auth', '0001_initial', '2024-02-04 16:32:51.549701');
+INSERT INTO `django_migrations` VALUES (3, 'admin', '0001_initial', '2024-02-04 16:32:51.606242');
+INSERT INTO `django_migrations` VALUES (4, 'admin', '0002_logentry_remove_auto_add', '2024-02-04 16:32:51.613953');
+INSERT INTO `django_migrations` VALUES (5, 'admin', '0003_logentry_add_action_flag_choices', '2024-02-04 16:32:51.619196');
+INSERT INTO `django_migrations` VALUES (6, 'contenttypes', '0002_remove_content_type_name', '2024-02-04 16:32:51.687139');
+INSERT INTO `django_migrations` VALUES (7, 'auth', '0002_alter_permission_name_max_length', '2024-02-04 16:32:51.729044');
+INSERT INTO `django_migrations` VALUES (8, 'auth', '0003_alter_user_email_max_length', '2024-02-04 16:32:51.771331');
+INSERT INTO `django_migrations` VALUES (9, 'auth', '0004_alter_user_username_opts', '2024-02-04 16:32:51.777711');
+INSERT INTO `django_migrations` VALUES (10, 'auth', '0005_alter_user_last_login_null', '2024-02-04 16:32:51.813729');
+INSERT INTO `django_migrations` VALUES (11, 'auth', '0006_require_contenttypes_0002', '2024-02-04 16:32:51.817877');
+INSERT INTO `django_migrations` VALUES (12, 'auth', '0007_alter_validators_add_error_messages', '2024-02-04 16:32:51.823354');
+INSERT INTO `django_migrations` VALUES (13, 'auth', '0008_alter_user_username_max_length', '2024-02-04 16:32:51.865155');
+INSERT INTO `django_migrations` VALUES (14, 'auth', '0009_alter_user_last_name_max_length', '2024-02-04 16:32:51.907643');
+INSERT INTO `django_migrations` VALUES (15, 'auth', '0010_alter_group_name_max_length', '2024-02-04 16:32:51.951019');
+INSERT INTO `django_migrations` VALUES (16, 'auth', '0011_update_proxy_permissions', '2024-02-04 16:32:51.958587');
+INSERT INTO `django_migrations` VALUES (17, 'auth', '0012_alter_user_first_name_max_length', '2024-02-04 16:32:52.003585');
+INSERT INTO `django_migrations` VALUES (18, 'myapp', '0001_initial', '2024-02-04 16:32:52.698876');
+INSERT INTO `django_migrations` VALUES (19, 'myapp', '0002_thing_user', '2024-02-04 16:32:52.738582');
+INSERT INTO `django_migrations` VALUES (20, 'myapp', '0003_auto_20240204_1632', '2024-02-04 16:32:52.933013');
+INSERT INTO `django_migrations` VALUES (21, 'sessions', '0001_initial', '2024-02-04 16:32:52.969896');
+
+-- ----------------------------
+-- Table structure for django_session
+-- ----------------------------
+DROP TABLE IF EXISTS `django_session`;
+CREATE TABLE `django_session` (
+ `session_key` varchar(40) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `session_data` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
+ `expire_date` datetime(6) NOT NULL,
+ PRIMARY KEY (`session_key`) USING BTREE,
+ INDEX `django_session_expire_date_a5c62663`(`expire_date`) USING BTREE
+) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
+
+-- ----------------------------
+-- Records of django_session
+-- ----------------------------
+
+SET FOREIGN_KEY_CHECKS = 1;
《{{item.title}}》
+