From 8d341db9d2d5699d527c88c935f0c4ce255a57a4 Mon Sep 17 00:00:00 2001 From: hutongqing <hutongqing@hnkhzn.com> Date: 星期二, 10 十二月 2024 16:38:12 +0800 Subject: [PATCH] 代码提交 --- 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/ObjectExtension.cs | 9 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/options.js | 226 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalTaskService.cs | 210 代码管理/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/789398d4-ad10-4b21-9f9c-c017ed2e4aa0.vsidx | 0 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Program.cs | 8 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/SqlsugarSetup.cs | 4 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_Dictionary.tsv | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Attributes/SequenceAttirbute.cs | 4 代码管理/WMS/WIDESEA_WMSClient/src/views/inbound/inboundOrderDetail.vue | 221 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/CommonEnum/UploadStatusEnum.cs | 12 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_ReceiveOrder.cs | 86 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfo_HtyService.cs | 10 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Sys_Dictionary.vue | 316 代码管理/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/914d9c3f-57db-4637-bc40-52081424fde2.vsidx | 0 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/OperateTypeEnum.cs | 1 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/InboundRepository.cs | 14 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ParamsValidator.cs | 26 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ISystemService/ISys_RoleService.cs | 4 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/detailMethods.js | 102 代码管理/WMS/WIDESEA_WMSClient/src/views/basic/materielInfo.vue | 221 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_StockRepository/StockInfoRepository.cs | 2 代码管理/WMS/WIDESEA_WMSClient/src/main.js | 63 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/IRepository.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/WIDESEA_ICheckRepository.csproj | 13 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/ReceiveOrderEnum.cs | 51 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/ReceiveOrderController.cs | 24 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/AsyncLoading.vue | 10 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/flex.vue | 386 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/WIDESEA_CheckService.csproj | 15 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_RoleDataPermissionRepository.cs | 18 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_WMSServer.csproj | 13 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/PurchaseOrderRepository.cs | 18 代码管理/WMS/WIDESEA_WMSClient/src/components/redirect/401.vue | 19 代码管理/WMS/WIDESEA_WMSClient/vue.config.js | 59 代码管理/WMS/WIDESEA_WMSClient/src/extension/basic/areaRouter.js | 69 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/WIDESEA_Core.csproj | 1 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridCustomColumn.js | 151 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderDetail_HtyService.cs | 23 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/LocationInfoRepository.cs | 5 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_External/ERPService/ERPInvokeService.cs | 11 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IInboundRepository.cs | 8 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolElementMenu.vue | 198 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/IApprovalFlowService.cs | 14 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/LocationInfoService.cs | 20 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Basic/MatSerNumAnalysisModel.cs | 56 代码管理/WMS/WIDESEA_WMSClient/src/router/index.js | 82 代码管理/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/f3502ed8-fc43-47df-b9a2-74d7c2feb215.vsidx | 0 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseController/ApiBaseController.cs | 5 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/Icons.vue | 345 代码管理/WMS/WIDESEA_WMSClient/src/views/basic/cachePoint.vue | 209 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/HttpContextUser/AspNetUser.cs | 60 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/UploadExcel.vue | 221 代码管理/WMS/WIDESEA_WMSClient/src/views/stock/stockInfoDetail.vue | 200 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IReceiveOrderRepository.cs | 14 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Record/Dt_StockQuantityChangeRecord.cs | 6 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundService.cs | 5 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_UserRepository.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_DTO/ERP/ReceiveOrderModel.cs | 137 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/ReceiveOrderDetailRepository.cs | 18 代码管理/WMS/WIDESEA_WMSClient/src/uitils/common.js | 344 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalNodeRepository.cs | 14 代码管理/WMS/WIDESEA_WMSClient/src/assets/element-icon/fonts/element-icons.ttf | 0 代码管理/WMS/WIDESEA_WMSClient/tests/unit/example.spec.js | 13 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/IviewCircle.vue | 102 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IReceiveOrderService.cs | 16 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_ReceiveOrderDetail.cs | 95 代码管理/WMS/WIDESEA_WMSClient/src/extension/basic/areaInfo.js | 69 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderDetailAddDTO.cs | 35 代码管理/WMS/WIDESEA_WMSClient/src/components/redirect/404.vue | 21 代码管理/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/StockSelect.vue | 251 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrder.cs | 8 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridAudit.vue | 427 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolTable/VolTableRender.js | 14 代码管理/WMS/WIDESEA_WMSClient/src/views/record/stockQuantityChangeRecord.vue | 219 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/appsettings.json | 6 代码管理/WMS/WIDESEA_WMSClient/src/views/index/Message.vue | 104 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs | 155 代码管理/WMS/WIDESEA_WMSClient/src/extension/basic/materielInfo.js | 58 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/ERP/ErpController.cs | 51 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/SeedDataHostedService.cs | 15 代码管理/WMS/WIDESEA_WMSClient/src/extension/system/Sys_User.js | 86 代码管理/WMS/WIDESEA_WMSClient/src/router/charts.js | 17 代码管理/WMS/WIDESEA_WMSClient/src/api/permission.js | 53 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/formChart.vue | 118 代码管理/WMS/WIDESEA_WMSClient/src/views/home/home-chart-options.js | 248 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfoService.cs | 9 代码管理/WMS/WIDESEA_WMSClient/src/App.vue | 67 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_DTO/ERP/PurchaseOrderModel.cs | 98 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/ReceiveOrderRepository.cs | 18 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisCodeEnum.cs | 4 代码管理/WMS/WIDESEA_WMSClient/src/views/inbound/receiveOrder.vue | 376 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/ICheckOrderRepository.cs | 14 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/AuditHis.vue | 46 代码管理/WMS/WIDESEA_WMSClient/public/wms_d.png | 0 代码管理/WMS/WIDESEA_WMSClient/src/router/redirect.js | 22 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutStockLockInfoService.cs | 37 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/WarehouseService.cs | 4 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGrid.less | 178 代码管理/WMS/WIDESEA_WMSClient/src/views/index/index.less | 644 代码管理/WMS/WIDESEA_WMSClient/package.json | 67 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/index.js | 3 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/bigdata.vue | 258 代码管理/WMS/WIDESEA_WMSClient/src/extension/inbound/receiveOrder.js | 58 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Sys_User.vue | 369 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutStockLockInfoController.cs | 6 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/WIDESEA_ApprovalService.csproj | 15 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/ICheckOrderResultRepository.cs | 14 代码管理/WMS/WIDESEA_WMSClient/src/views/index/MessageConfig.js | 28 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer.sln | 134 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Sys_Role1.vue | 72 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/CustomProfile.cs | 7 代码管理/WMS/WIDESEA_WMSClient/src/store/index.js | 94 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderService.cs | 285 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridCustomColumn.vue | 95 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/methods.js | 1684 + 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/TaskInfo/TaskController.cs | 11 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/index.js | 7 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderAddDTO.cs | 54 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/MainDb.cs | 4 代码管理/WMS/WIDESEA_WMSClient/yarn.lock | 10203 ++++++++++ 代码管理/WMS/WIDESEA_WMSClient/src/views/record/locationStatusChangeRecord.vue | 191 代码管理/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Dictionary.js | 65 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/WarehouseRepository.cs | 2 代码管理/WMS/WIDESEA_WMSClient/src/views/basic/areaInfo.vue | 215 代码管理/WMS/WIDESEA_WMSClient/src/api/http.js | 324 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrder_HtyService.cs | 36 代码管理/WMS/WIDESEA_WMSClient/src/assets/imgs/error.png | 0 代码管理/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/outOrderDetail.vue | 371 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/PurchaseOrderService.cs | 228 代码管理/WMS/WIDESEA_WMSClient/src/extension/basic/locationInfo.js | 103 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_User.tsv | 4 代码管理/WMS/WIDESEA_WMSClient/src/extension/outbound/outboundOrder.js | 74 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/VolFormPreview.vue | 206 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/WIDESEA_ApprovalRepository.csproj | 13 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/Empty.vue | 3 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/LocationStatusChangeRecordSetvice.cs | 16 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IBasicRepository/ILocationInfoRepository.cs | 8 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_MaterielInfo.cs | 4 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseServices/ServiceBase.cs | 186 代码管理/WMS/WIDESEA_WMSClient/src/views/Index.vue | 834 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolHeader.vue | 67 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/CheckOrderRepository.cs | 18 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/AOP/SqlSugarAop.cs | 2 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/Audit.vue | 59 代码管理/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Role.js | 49 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/WIDESEA_SystemService.csproj | 1 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task.cs | 17 代码管理/WMS/WIDESEA_WMSClient/src/components/redirect/Message.vue | 39 代码管理/WMS/WIDESEA_WMSClient/src/extension/basic/extend/GetLocationStatus.vue | 261 代码管理/WMS/WIDESEA_WMSClient/src/extension/system/Sys_User/Sys_UserGridHeader.vue | 85 代码管理/WMS/WIDESEA_WMSClient/src/extension/record/stockQuantityChangeRecord.js | 58 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalFlowRepository.cs | 14 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/CheckOrderResultRepository.cs | 18 代码管理/WMS/WIDESEA_WMSClient/src/views/stock/stockInfo.vue | 140 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/ReceiveOrderService.cs | 143 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/WIDESEA_IApprovalService.csproj | 13 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/PurchaseOrderEnum.cs | 60 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/ReceiveOrderDetailService.cs | 159 代码管理/WMS/WIDESEA_WMSClient/src/assets/imgs/error-img.png | 0 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Check/Dt_CheckOrderResult.cs | 50 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/serviceFilter.js | 109 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/Task_HtyService.cs | 37 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderDetailService.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundService.cs | 9 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Approval/ApprovalFlowController.cs | 18 代码管理/WMS/WIDESEA_WMSClient/src/assets/imgs/wms_d.png | 0 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalTaskRepository.cs | 14 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/DownloadForm.js | 156 代码管理/WMS/WIDESEA_WMSClient/src/assets/script/common.js | 2 代码管理/WMS/WIDESEA_WMSClient/src/assets/logo.png | 0 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_DictionaryService.cs | 98 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalNodeService.cs | 12 代码管理/WMS/WIDESEA_WMSClient/src/views/system/test.vue | 18 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Permission.vue | 359 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Sys_Log.vue | 70 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderDetailService.cs | 23 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_Warehouse.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutboundOrderService.cs | 5 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalFlowService.cs | 27 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IReceiveOrderDetailService.cs | 16 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/chartOptions.js | 212 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ISystemRepository/ISys_RoleDataPermissionRepository.cs | 14 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/CheckOrderEnum.cs | 45 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InboundOrderMenu.cs | 93 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrderDetail.cs | 32 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/WIDESEA_ICheckService.csproj | 13 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/EntityProperties.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITaskService.cs | 3 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/App.cs | 5 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Approval/ApprovalTaskController.cs | 30 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/chart.vue | 101 代码管理/WMS/WIDESEA_WMSClient/src/views/basic/warehouse.vue | 179 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Sys_Menu.vue | 672 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_User.cs | 6 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderService.cs | 4 代码管理/WMS/WIDESEA_WMSClient/public/static/login_bg.png | 0 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolUpload.vue | 880 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_RoleDataPermission.cs | 27 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolForm/VolFormRender.js | 14 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/templateCode.js | 95 代码管理/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/SelectedStock.vue | 230 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisFormatTypeEnum.cs | 5 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/head_bg.png | 0 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/IApprovalTaskService.cs | 18 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/NodeTransitionRepository.cs | 18 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IPurchaseOrderRepository.cs | 14 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrder_HtyService.cs | 11 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/ILocationStatusChangeRecordSetvice.cs | 5 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IBasicService/ILocationInfoService.cs | 5 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/CheckOrderResultService.cs | 83 代码管理/WMS/WIDESEA_WMSClient/src/extension/inbound/inboundOrderDetail.js | 58 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/CommonEnum/AuditStatusEnum.cs | 36 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Check/Dt_CheckOrder.cs | 101 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfoDetail.cs | 7 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Log.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_DictionaryRepository.cs | 5 代码管理/WMS/WIDESEA_WMSClient/.eslintrc.js | 28 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/ReceiveOrderDetailController.cs | 25 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Service/StockInfoService.cs | 52 代码管理/WMS/WIDESEA_WMSClient/src/extension/system/system/Sys_Department.js | 152 代码管理/WMS/WIDESEA_WMSClient/public/wcslogo.png | 0 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGrid.vue | 806 代码管理/WMS/WIDESEA_WMSClient/src/extension/stock/stockView.js | 58 代码管理/WMS/WIDESEA_WMSClient/.gitignore | 23 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/StockQuantityChangeRecordService.cs | 16 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/formTemplate.js | 664 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/AuthorityScopeEnum.cs | 41 代码管理/WMS/WIDESEA_WMSClient/src/extension/record/locationStatusChangeRecord.js | 61 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ModelValidate.cs | 44 代码管理/WMS/WIDESEA_WMSClient/src/extension/basic/CachePoint.js | 69 代码管理/WMS/WIDESEA_WMSClient/src/views/inbound/inboundOrder.vue | 319 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Check/CheckOrderResultController.cs | 23 代码管理/WMS/WIDESEA_WMSClient/src/views/system/UserInfo.vue | 317 代码管理/WMS/WIDESEA_WMSClient/src/router/viewGird.js | 122 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutboundOrderEnum.cs | 96 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/LogHelper/Logger.cs | 1 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task_Hty.cs | 29 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolTable.vue | 1874 + 代码管理/WMS/WIDESEA_WMSClient/src/views/system/PermissionPDA.vue | 369 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_External/WIDESEA_External.csproj | 4 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_LocationInfo.cs | 8 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/PermissionDataHostService.cs | 155 代码管理/WMS/WIDESEA_WMSClient/public/index.html | 135 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_RoleService.cs | 92 代码管理/WMS/WIDESEA_WMSClient/src/views/outbound/outboundOrderDetail.vue | 221 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Basic/LocationInfoController.cs | 3 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/RepositoryBase.cs | 65 代码管理/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/eef0aa91-791e-44dd-b321-3146cf9e9a18.vsidx | 0 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseModels/PageDataOptions.cs | 2 代码管理/WMS/WIDESEA_WMSClient/src/extension/taskinfo/task_hty.js | 58 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolForm.vue | 1487 + 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/PurchaseOrderDetailRepository.cs | 18 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/Models/BaseWarehouseEntity.cs | 15 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/LocationEnum/LocationChangeType.cs | 41 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/VolFormDraggable.vue | 1159 + 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolBox.vue | 200 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalFlowRepository.cs | 18 代码管理/WMS/WIDESEA_WMSClient/src/extension/basic/roadwayInfo.js | 72 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_SupplierInfo.cs | 29 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetail_HtyService.cs | 13 代码管理/WMS/WIDESEA_WMSClient/src/views/taskinfo/task.vue | 231 代码管理/WMS/WIDESEA_WMSClient/src/assets/element-icon/icon.css | 1 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Check/CheckOrderController.cs | 24 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs | 64 代码管理/WMS/WIDESEA_WMSClient/src/views/outbound/outboundOrder.vue | 328 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Common/StockEnum/StockChangeTypeEnum.cs | 12 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/RuleCodeEnum.cs | 14 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_NodeTransition.cs | 26 代码管理/WMS/WIDESEA_WMSClient/src/extension/system/Sys_DictionaryList.js | 22 代码管理/WMS/WIDESEA_WMSClient/src/views/basic/locationInfo.vue | 205 代码管理/WMS/WIDESEA_WMSClient/src/extension/outbound/outboundOrderDetail.js | 58 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutStockLockInfoService.cs | 6 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/AutofacModuleRegister.cs | 9 代码管理/WMS/WIDESEA_WMSClient/src/views/taskinfo/task_hty.vue | 237 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/INodeTransitionRepository.cs | 14 代码管理/WMS/WIDESEA_WMSClient/src/api/useTest.js | 9 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITask_HtyService.cs | 7 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IPurchaseOrderDetailRepository.cs | 14 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/chart-options.js | 551 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalFlow.cs | 26 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/IStockQuantityChangeRecordService.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalTaskRepository.cs | 18 代码管理/WMS/WIDESEA_WMSClient/package-lock.json | 13937 ++++++++++++++ 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IReceiveOrderDetailRepository.cs | 14 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/WebSocketSetup.cs | 25 代码管理/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Role1.js | 61 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderService.cs | 162 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/ICheckOrderResultService.cs | 16 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/formOptions.js | 148 代码管理/WMS/WIDESEA_WMSClient/src/extension/stock/stockInfo.js | 58 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Sys_DictionaryList.vue | 65 代码管理/WMS/WIDESEA_WMSClient/src/views/basic/roadwayInfo.vue | 236 代码管理/WMS/WIDESEA_WMSClient/src/views/Login.vue | 408 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetailService.cs | 13 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ErrorMsg.vue | 3 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_External/IERPService/IERPInvokeService.cs | 3 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IPurchaseOrderService.cs | 17 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/RouterLoading.vue | 105 代码管理/WMS/WIDESEA_WMSClient/src/views/Home.vue | 24 代码管理/WMS/WIDESEA_WMSClient/src/extension/taskinfo/task.js | 96 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/WIDESEA_InboundService.csproj | 2 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/VolElementMenuChild.vue | 56 代码管理/WMS/WIDESEA_WMSClient/src/extension/stock/stockInfoDetail.js | 58 代码管理/WMS/WIDESEA_WMSClient/src/assets/css/common.less | 75 代码管理/WMS/WIDESEA_WMSClient/src/views/system/system/Sys_Department.vue | 71 代码管理/WMS/WIDESEA_WMSClient/src/views/stock/stockView.vue | 327 代码管理/WMS/WIDESEA_WMSClient/src/assets/imgs/wms_x.png | 0 代码管理/WMS/WIDESEA_WMSClient/src/views/basic/areaRouter.vue | 171 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/QuickSearch.vue | 152 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfo.cs | 7 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_PurchaseOrder.cs | 71 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_PurchaseOrderDetail.cs | 63 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/InboundOrderController.cs | 12 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalNodeRepository.cs | 18 代码管理/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/layout.less | 197 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs | 51 代码管理/WMS/WIDESEA_WMSClient/src/assets/element-icon/fonts/element-icons.woff | 0 代码管理/WMS/WIDESEA_WMSClient/README.md | 41 代码管理/WMS/WIDESEA_WMSClient/src/components/redirect/coding.vue | 25 代码管理/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/f91e73eb-1823-4174-b99b-0eb163ec64f8.vsidx | 0 代码管理/WMS/WIDESEA_WMSClient/src/extension/inbound/inboundOrder.js | 58 代码管理/WMS/WIDESEA_WMSClient/src/extension/basic/warehouse.js | 69 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Sys_Role.vue | 220 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockViewService.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/WIDESEA_IApprovalRepository.csproj | 13 代码管理/WMS/WIDESEA_WMSClient/src/components/redirect/RedirectError.vue | 59 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_DTO/System/VueDictionaryDTO.cs | 2 代码管理/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/props.js | 55 代码管理/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Log.js | 26 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Stock/StockViewDTO.cs | 2 /dev/null | 30 代码管理/WMS/WIDESEA_WMSClient/babel.config.js | 5 代码管理/WMS/WIDESEA_WMSClient/src/views/system/Permission/RoleTree.vue | 152 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalNode.cs | 32 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/ICheckOrderService.cs | 16 代码管理/WMS/WIDESEA_WMSClient/src/assets/script/testFormExtend.js | 15 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_UserService.cs | 9 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutboundOrderController.cs | 10 代码管理/WMS/WIDESEA_WMSClient/config/buttons.js | 159 代码管理/WMS/WIDESEA_WMSClient/src/assets/script/extend.js | 5 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Role.cs | 2 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/WIDESEA_CheckRepository.csproj | 13 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/CheckOrderService.cs | 125 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalTask.cs | 68 344 files changed, 57,743 insertions(+), 745 deletions(-) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/.eslintrc.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/.eslintrc.js" new file mode 100644 index 0000000..ab1a421 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/.eslintrc.js" @@ -0,0 +1,28 @@ +module.exports = { + root: true, + env: { + node: true + }, + 'extends': [ + 'plugin:vue/vue3-essential', + 'eslint:recommended' + ], + parserOptions: { + parser: 'babel-eslint' + }, + rules: { + 'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off', + 'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off' + }, + overrides: [ + { + files: [ + '**/__tests__/*.{j,t}s?(x)', + '**/tests/unit/**/*.spec.{j,t}s?(x)' + ], + env: { + mocha: true + } + } + ] +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/.gitignore" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/.gitignore" new file mode 100644 index 0000000..403adbc --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/.gitignore" @@ -0,0 +1,23 @@ +.DS_Store +node_modules +/dist + + +# local env files +.env.local +.env.*.local + +# Log files +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* + +# Editor directories and files +.idea +.vscode +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/README.md" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/README.md" new file mode 100644 index 0000000..1d81700 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/README.md" @@ -0,0 +1,41 @@ +# vol.vue3 + +## Project setup +``` +npm install +``` + +### Compiles and hot-reloads for development +``` +npm run serve +``` + +### Compiles and minifies for production +``` +npm run build +``` + +### Run your unit tests +``` +npm run test:unit +``` + +### Lints and fixes files +``` +npm run lint +``` + +### Customize configuration +See [Configuration Reference](https://cli.vuejs.org/config/). + + +### npm run serve鍚姩寮傚父锛� + 浣跨敤cmd杈撳叆node -v鏌ョ湅鐗堟湰锛屽鏋滄槸18.+鐗堟湰,璇峰皢package.json涓浜旇scripts涓殑鍐呭鏇挎崲涓猴細 + +"scripts": { + "serve": " SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service serve", + "build": "SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service build", + "test:unit": "vue-cli-service test:unit", + "lint": "vue-cli-service lint" +} + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/babel.config.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/babel.config.js" new file mode 100644 index 0000000..e955840 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/babel.config.js" @@ -0,0 +1,5 @@ +module.exports = { + presets: [ + '@vue/cli-plugin-babel/preset' + ] +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/config/buttons.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/config/buttons.js" new file mode 100644 index 0000000..dc84b3a --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/config/buttons.js" @@ -0,0 +1,159 @@ + +let buttons = [{ + name: "鏌� 璇�", + value: 'Search', + icon: 'el-icon-search', + class: '', + type: 'primary', + onClick: function () { + this.search(); + } +}, +{ + name: "鏂� 寤�", + icon: 'el-icon-plus', + value: 'Add', + class: '', + // plain:true, + type: 'success', + // plain:true, + onClick: function () { + this.add(); + } +}, +{ + name: "缂� 杈�", + icon: 'el-icon-edit', + value: 'Update', + // plain:true, + class: '', + type: 'primary', + onClick: function () { + this.edit(); + } +}, + +{ + name: "鍒� 闄�", + icon: 'el-icon-delete', + class: '', + value: 'Delete', + type: 'danger', + onClick: function () { + this.del(); + } +}, +{ + name: "瀹� 鏍�", + icon: 'el-icon-check', + class: '', + value: 'Audit', + plain: true, + type: 'primary', + onClick: function () { + this.audit(); + } +}, +{ + name: "瀵� 鍏�", + icon: 'el-icon-top', + class: '', + type: 'success', + plain: true, + value: 'Import', + onClick: function () { + this.import(); + } +}, +{ + name: "瀵� 鍑�", + icon: 'el-icon-bottom', + type: 'success', + plain: true, + value: 'Export', + onClick: function () { + this.export(); + } +},{ + name: "鍚� 鐢�", + icon: '', + class: '', + value: 'Enable', + type: 'primary', + onClick: function () { + } +}, +{ + name: "绂� 鐢�", + icon: '', + class: '', + value: 'Disable', + type: 'danger', + onClick: function () { + } +}, +{ + name: "鎵� 鍔� 瀹� 鎴�", + icon: '', + class: '', + value: 'TaskHandCompleted', + onClick: function () { + } +}, +{ + name: "鍙� 娑� 浠� 鍔�", + icon: '', + class: '', + value: 'TaskHandCancel', + onClick: function () { + } +}, +{ + name: "浠诲姟鎭㈠", + icon: '', + class: '', + value: 'TaskRecovery', + type: 'danger', + onClick: function () { + } +}, +{ + name: "鏌ョ湅瀹屾暣璺敱", + icon: '', + class: '', + value: 'ViewAllRouter', + type: 'info', + onClick: function () { + } +}, +{ + name: "璺敱閰嶇疆", + icon: '', + class: '', + value: 'AddRouters', + type: 'success', + onClick: function () { + } +}, +{ + name: "鍥炴粴鍒颁笂涓�姝�", + icon: '', + class: '', + value: 'Previous', + type: 'danger', + onClick: function () { + } +}, +{ + name: "璺宠浆鍒颁笅涓�姝�", + icon: '', + class: '', + value: 'Next', + type: 'warning', + onClick: function () { + } +}, + +] + +export default buttons \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/package-lock.json" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/package-lock.json" new file mode 100644 index 0000000..b2e2edd --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/package-lock.json" @@ -0,0 +1,13937 @@ +{ + "name": "wideseawcs", + "version": "0.1.0", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@achrinza/node-ipc": { + "version": "9.2.2", + "resolved": "https://registry.npmmirror.com/@achrinza/node-ipc/-/node-ipc-9.2.2.tgz", + "integrity": "sha512-b90U39dx0cU6emsOvy5hxU4ApNXnE3+Tuo8XQZfiKTGelDwpMwBVgBP7QX6dGTcJgu/miyJuNJ/2naFBliNWEw==", + "dev": true, + "requires": { + "@node-ipc/js-queue": "2.0.3", + "event-pubsub": "4.3.0", + "js-message": "1.0.7" + } + }, + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/code-frame/download/@babel/code-frame-7.14.5.tgz", + "integrity": "sha1-I7CNdA6D9JxeWZRfvxtD6Au/Tts=", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/compat-data": { + "version": "7.14.7", + "resolved": "https://registry.nlark.com/@babel/compat-data/download/@babel/compat-data-7.14.7.tgz", + "integrity": "sha1-ewR9ejqJpn0iWNxh9gTwmPG8fgg=", + "dev": true + }, + "@babel/core": { + "version": "7.14.6", + "resolved": "https://registry.nlark.com/@babel/core/download/@babel/core-7.14.6.tgz", + "integrity": "sha1-4IFOwalQAy/xbBOich3jmoQW/Ks=", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-compilation-targets": "^7.14.5", + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helpers": "^7.14.6", + "@babel/parser": "^7.14.6", + "@babel/template": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5", + "convert-source-map": "^1.7.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.1.2", + "semver": "^6.3.0", + "source-map": "^0.5.0" + } + }, + "@babel/generator": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/generator/download/@babel/generator-7.14.5.tgz", + "integrity": "sha1-hI17nwMcrKnQzQrwGwY/Im9S14U=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/helper-annotate-as-pure": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-annotate-as-pure/download/@babel/helper-annotate-as-pure-7.14.5.tgz", + "integrity": "sha1-e/R47Dtxcm1WqMpXdbBG/CmHnmE=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-builder-binary-assignment-operator-visitor/download/@babel/helper-builder-binary-assignment-operator-visitor-7.14.5.tgz?cache=0&sync_timestamp=1623280539341&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-builder-binary-assignment-operator-visitor%2Fdownload%2F%40babel%2Fhelper-builder-binary-assignment-operator-visitor-7.14.5.tgz", + "integrity": "sha1-uTm0P4w3dlRDoZrnStixWXjgoZE=", + "dev": true, + "requires": { + "@babel/helper-explode-assignable-expression": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-compilation-targets": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-compilation-targets/download/@babel/helper-compilation-targets-7.14.5.tgz?cache=0&sync_timestamp=1623280514256&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-compilation-targets%2Fdownload%2F%40babel%2Fhelper-compilation-targets-7.14.5.tgz", + "integrity": "sha1-epnF0JZ5Eely/iw0EffVtJhJjs8=", + "dev": true, + "requires": { + "@babel/compat-data": "^7.14.5", + "@babel/helper-validator-option": "^7.14.5", + "browserslist": "^4.16.6", + "semver": "^6.3.0" + } + }, + "@babel/helper-create-class-features-plugin": { + "version": "7.14.6", + "resolved": "https://registry.nlark.com/@babel/helper-create-class-features-plugin/download/@babel/helper-create-class-features-plugin-7.14.6.tgz", + "integrity": "sha1-8RRGm2wG+LXFnGxOdGIfUIU2JUI=", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-member-expression-to-functions": "^7.14.5", + "@babel/helper-optimise-call-expression": "^7.14.5", + "@babel/helper-replace-supers": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5" + } + }, + "@babel/helper-create-regexp-features-plugin": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-create-regexp-features-plugin/download/@babel/helper-create-regexp-features-plugin-7.14.5.tgz", + "integrity": "sha1-x9WsXpz2IcJgV3Ivt6ikxYiTWMQ=", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "regexpu-core": "^4.7.1" + } + }, + "@babel/helper-define-polyfill-provider": { + "version": "0.2.3", + "resolved": "https://registry.nlark.com/@babel/helper-define-polyfill-provider/download/@babel/helper-define-polyfill-provider-0.2.3.tgz?cache=0&sync_timestamp=1622025430652&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-define-polyfill-provider%2Fdownload%2F%40babel%2Fhelper-define-polyfill-provider-0.2.3.tgz", + "integrity": "sha1-BSXt7FCUZTooJojTTYRuTHXpwLY=", + "dev": true, + "requires": { + "@babel/helper-compilation-targets": "^7.13.0", + "@babel/helper-module-imports": "^7.12.13", + "@babel/helper-plugin-utils": "^7.13.0", + "@babel/traverse": "^7.13.0", + "debug": "^4.1.1", + "lodash.debounce": "^4.0.8", + "resolve": "^1.14.2", + "semver": "^6.1.2" + } + }, + "@babel/helper-explode-assignable-expression": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-explode-assignable-expression/download/@babel/helper-explode-assignable-expression-7.14.5.tgz", + "integrity": "sha1-iqcucIIFx7tkPkXHO0OGzfKh9kU=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-function-name/download/@babel/helper-function-name-7.14.5.tgz?cache=0&sync_timestamp=1623280544273&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-function-name%2Fdownload%2F%40babel%2Fhelper-function-name-7.14.5.tgz", + "integrity": "sha1-ieLEdJcvFdjiM7Uu6MSA4s/NUMQ=", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-get-function-arity/download/@babel/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha1-Jfv6V5sJN+7h87gF7OTOOYxDGBU=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-hoist-variables": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-hoist-variables/download/@babel/helper-hoist-variables-7.14.5.tgz", + "integrity": "sha1-4N0nwzp45XfXyIhJFqPn7x98f40=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-member-expression-to-functions": { + "version": "7.14.7", + "resolved": "https://registry.nlark.com/@babel/helper-member-expression-to-functions/download/@babel/helper-member-expression-to-functions-7.14.7.tgz", + "integrity": "sha1-l+ViRL65QhH+J3vYGOOjKcZveXA=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-module-imports": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-module-imports/download/@babel/helper-module-imports-7.14.5.tgz", + "integrity": "sha1-bRpE32o4yVeqfDEtoHZCnxG0IvM=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-module-transforms": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-module-transforms/download/@babel/helper-module-transforms-7.14.5.tgz?cache=0&sync_timestamp=1623280540631&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-module-transforms%2Fdownload%2F%40babel%2Fhelper-module-transforms-7.14.5.tgz", + "integrity": "sha1-feQvENeJtCPrkC69JAMcp3yx4Q4=", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.14.5", + "@babel/helper-replace-supers": "^7.14.5", + "@babel/helper-simple-access": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/helper-validator-identifier": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-optimise-call-expression": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-optimise-call-expression/download/@babel/helper-optimise-call-expression-7.14.5.tgz", + "integrity": "sha1-8nOVqGGeBmWz8DZM3bQcJdcbSZw=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-plugin-utils": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-plugin-utils/download/@babel/helper-plugin-utils-7.14.5.tgz", + "integrity": "sha1-WsgizpfuxGdBq3ClF5ceRDpwxak=", + "dev": true + }, + "@babel/helper-remap-async-to-generator": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-remap-async-to-generator/download/@babel/helper-remap-async-to-generator-7.14.5.tgz?cache=0&sync_timestamp=1623280541106&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-remap-async-to-generator%2Fdownload%2F%40babel%2Fhelper-remap-async-to-generator-7.14.5.tgz", + "integrity": "sha1-UUOckTYSlY9UqYek/8nuWHogRdY=", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "@babel/helper-wrap-function": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-replace-supers": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-replace-supers/download/@babel/helper-replace-supers-7.14.5.tgz?cache=0&sync_timestamp=1623280539767&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-replace-supers%2Fdownload%2F%40babel%2Fhelper-replace-supers-7.14.5.tgz", + "integrity": "sha1-DswLA8Qc1We0Ak6gFhNMKEFKu5Q=", + "dev": true, + "requires": { + "@babel/helper-member-expression-to-functions": "^7.14.5", + "@babel/helper-optimise-call-expression": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-simple-access": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-simple-access/download/@babel/helper-simple-access-7.14.5.tgz", + "integrity": "sha1-ZuqFz1O6C05Yi6d/yBP1OryqQcQ=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-skip-transparent-expression-wrappers": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-skip-transparent-expression-wrappers/download/@babel/helper-skip-transparent-expression-wrappers-7.14.5.tgz", + "integrity": "sha1-lvSGrAUMqfRLAJ++W305TKs6DuQ=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-split-export-declaration/download/@babel/helper-split-export-declaration-7.14.5.tgz?cache=0&sync_timestamp=1623280535830&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-split-export-declaration%2Fdownload%2F%40babel%2Fhelper-split-export-declaration-7.14.5.tgz", + "integrity": "sha1-IrI6VO9RwrdgXYUZMMGXbdC8aTo=", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-validator-identifier/download/@babel/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha1-0PDid8US4Mk4J3+qhaOWjJpEwOg=", + "dev": true + }, + "@babel/helper-validator-option": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-validator-option/download/@babel/helper-validator-option-7.14.5.tgz", + "integrity": "sha1-bnKh//GNXfy4eOHmLxoCHEty1aM=", + "dev": true + }, + "@babel/helper-wrap-function": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/helper-wrap-function/download/@babel/helper-wrap-function-7.14.5.tgz?cache=0&sync_timestamp=1623280540387&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-wrap-function%2Fdownload%2F%40babel%2Fhelper-wrap-function-7.14.5.tgz", + "integrity": "sha1-WRnRFb8P4yi4pdY7y2EPUWAfK/8=", + "dev": true, + "requires": { + "@babel/helper-function-name": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helpers": { + "version": "7.14.6", + "resolved": "https://registry.nlark.com/@babel/helpers/download/@babel/helpers-7.14.6.tgz", + "integrity": "sha1-W1gwa5XxtH4qAZlDT6hlj6bCFjU=", + "dev": true, + "requires": { + "@babel/template": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/highlight/download/@babel/highlight-7.14.5.tgz", + "integrity": "sha1-aGGlLwOWZAUAH2qlNKAaJNmejNk=", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.18.11", + "resolved": "https://registry.npmmirror.com/@babel/parser/-/parser-7.18.11.tgz", + "integrity": "sha512-9JKn5vN+hDt0Hdqn1PiJ2guflwP+B6Ga8qbDuoF0PzzVhrzsKIJo8yGqVk6CmMHiMei9w1C1Bp9IMJSIK+HPIQ==" + }, + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/download/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.14.5.tgz", + "integrity": "sha1-S0ZzAuFUjtOxvkO+rizJz0Xgu34=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.14.5", + "@babel/plugin-proposal-optional-chaining": "^7.14.5" + } + }, + "@babel/plugin-proposal-async-generator-functions": { + "version": "7.14.7", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-async-generator-functions/download/@babel/plugin-proposal-async-generator-functions-7.14.7.tgz", + "integrity": "sha1-eEpIw9jtBz9lrc8wtXvL9sgRms4=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-remap-async-to-generator": "^7.14.5", + "@babel/plugin-syntax-async-generators": "^7.8.4" + } + }, + "@babel/plugin-proposal-class-properties": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-class-properties/download/@babel/plugin-proposal-class-properties-7.14.5.tgz?cache=0&sync_timestamp=1623280542725&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-proposal-class-properties%2Fdownload%2F%40babel%2Fplugin-proposal-class-properties-7.14.5.tgz", + "integrity": "sha1-QNHuFAxbHjGjUPT17tlFCWVZtC4=", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-proposal-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-class-static-block/download/@babel/plugin-proposal-class-static-block-7.14.5.tgz", + "integrity": "sha1-FY6eENRJw4Se8+zelKA9nxhBtoE=", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-class-static-block": "^7.14.5" + } + }, + "@babel/plugin-proposal-decorators": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-decorators/download/@babel/plugin-proposal-decorators-7.14.5.tgz?cache=0&sync_timestamp=1623280534359&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-proposal-decorators%2Fdownload%2F%40babel%2Fplugin-proposal-decorators-7.14.5.tgz", + "integrity": "sha1-WbxN/B1mW1pnSc95j/Qil+0bLB0=", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-decorators": "^7.14.5" + } + }, + "@babel/plugin-proposal-dynamic-import": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-dynamic-import/download/@babel/plugin-proposal-dynamic-import-7.14.5.tgz", + "integrity": "sha1-DGYX30YcDB+P/ztHzVl3I2AQHSw=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3" + } + }, + "@babel/plugin-proposal-export-namespace-from": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-export-namespace-from/download/@babel/plugin-proposal-export-namespace-from-7.14.5.tgz", + "integrity": "sha1-260kQxDObM0IMHIWfYzqg6Uvr3Y=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3" + } + }, + "@babel/plugin-proposal-json-strings": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-json-strings/download/@babel/plugin-proposal-json-strings-7.14.5.tgz", + "integrity": "sha1-ON5g2zYug6PYyUSshY3fnwwiOes=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-json-strings": "^7.8.3" + } + }, + "@babel/plugin-proposal-logical-assignment-operators": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-logical-assignment-operators/download/@babel/plugin-proposal-logical-assignment-operators-7.14.5.tgz", + "integrity": "sha1-bmIpwqmbAqspFfglceDMZGpAxzg=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" + } + }, + "@babel/plugin-proposal-nullish-coalescing-operator": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-nullish-coalescing-operator/download/@babel/plugin-proposal-nullish-coalescing-operator-7.14.5.tgz", + "integrity": "sha1-7jhYnOAOLMWbKZ7D6kBvzToP2vY=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" + } + }, + "@babel/plugin-proposal-numeric-separator": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-numeric-separator/download/@babel/plugin-proposal-numeric-separator-7.14.5.tgz", + "integrity": "sha1-g2Mb8z2aUd8YTCECoGmsDFjAXxg=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-numeric-separator": "^7.10.4" + } + }, + "@babel/plugin-proposal-object-rest-spread": { + "version": "7.14.7", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-object-rest-spread/download/@babel/plugin-proposal-object-rest-spread-7.14.7.tgz", + "integrity": "sha1-WSCis99/eQHfAgWXTAZBsT/Z02M=", + "dev": true, + "requires": { + "@babel/compat-data": "^7.14.7", + "@babel/helper-compilation-targets": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-transform-parameters": "^7.14.5" + } + }, + "@babel/plugin-proposal-optional-catch-binding": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-optional-catch-binding/download/@babel/plugin-proposal-optional-catch-binding-7.14.5.tgz", + "integrity": "sha1-k53W7d7/Omf997PwRLU0cmJZjDw=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" + } + }, + "@babel/plugin-proposal-optional-chaining": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-optional-chaining/download/@babel/plugin-proposal-optional-chaining-7.14.5.tgz?cache=0&sync_timestamp=1623281177929&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-proposal-optional-chaining%2Fdownload%2F%40babel%2Fplugin-proposal-optional-chaining-7.14.5.tgz", + "integrity": "sha1-+oNlHmCjYOPxN5fu8AuNUZaVtgM=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.14.5", + "@babel/plugin-syntax-optional-chaining": "^7.8.3" + } + }, + "@babel/plugin-proposal-private-methods": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-private-methods/download/@babel/plugin-proposal-private-methods-7.14.5.tgz", + "integrity": "sha1-N0RklZlrKUXzD1vltg1eKqT1eS0=", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-proposal-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-private-property-in-object/download/@babel/plugin-proposal-private-property-in-object-7.14.5.tgz", + "integrity": "sha1-n2Wk0Ek6lAtMAfiqnT8YlKWH9jY=", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5" + } + }, + "@babel/plugin-proposal-unicode-property-regex": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-proposal-unicode-property-regex/download/@babel/plugin-proposal-unicode-property-regex-7.14.5.tgz?cache=0&sync_timestamp=1623280542681&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-proposal-unicode-property-regex%2Fdownload%2F%40babel%2Fplugin-proposal-unicode-property-regex-7.14.5.tgz", + "integrity": "sha1-D5XuDnV6XWR/N42qDsp+k/qou+g=", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.nlark.com/@babel/plugin-syntax-async-generators/download/@babel/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha1-qYP7Gusuw/btBCohD2QOkOeG/g0=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "resolved": "https://registry.npm.taobao.org/@babel/plugin-syntax-class-properties/download/@babel/plugin-syntax-class-properties-7.12.13.tgz", + "integrity": "sha1-tcmHJ0xKOoK4lxR5aTGmtTVErhA=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.12.13" + } + }, + "@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-syntax-class-static-block/download/@babel/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha1-GV34mxRrS3izv4l/16JXyEZZ1AY=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-decorators": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-syntax-decorators/download/@babel/plugin-syntax-decorators-7.14.5.tgz", + "integrity": "sha1-6vucDL4JyK/rlkujp7vWOUWnLyA=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-dynamic-import": { + "version": "7.8.3", + "resolved": "https://registry.nlark.com/@babel/plugin-syntax-dynamic-import/download/@babel/plugin-syntax-dynamic-import-7.8.3.tgz?cache=0&sync_timestamp=1618847125283&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-syntax-dynamic-import%2Fdownload%2F%40babel%2Fplugin-syntax-dynamic-import-7.8.3.tgz", + "integrity": "sha1-Yr+Ysto80h1iYVT8lu5bPLaOrLM=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-export-namespace-from": { + "version": "7.8.3", + "resolved": "https://registry.npm.taobao.org/@babel/plugin-syntax-export-namespace-from/download/@babel/plugin-syntax-export-namespace-from-7.8.3.tgz", + "integrity": "sha1-AolkqbqA28CUyRXEh618TnpmRlo=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npm.taobao.org/@babel/plugin-syntax-json-strings/download/@babel/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha1-AcohtmjNghjJ5kDLbdiMVBKyyWo=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-jsx": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-syntax-jsx/download/@babel/plugin-syntax-jsx-7.14.5.tgz?cache=0&sync_timestamp=1623280667234&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-syntax-jsx%2Fdownload%2F%40babel%2Fplugin-syntax-jsx-7.14.5.tgz", + "integrity": "sha1-AA4uJdhnPM5JMAUXo+2kTCY+QgE=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.nlark.com/@babel/plugin-syntax-logical-assignment-operators/download/@babel/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha1-ypHvRjA1MESLkGZSusLp/plB9pk=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npm.taobao.org/@babel/plugin-syntax-nullish-coalescing-operator/download/@babel/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha1-Fn7XA2iIYIH3S1w2xlqIwDtm0ak=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npm.taobao.org/@babel/plugin-syntax-numeric-separator/download/@babel/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha1-ubBws+M1cM2f0Hun+pHA3Te5r5c=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npm.taobao.org/@babel/plugin-syntax-object-rest-spread/download/@babel/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha1-YOIl7cvZimQDMqLnLdPmbxr1WHE=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npm.taobao.org/@babel/plugin-syntax-optional-catch-binding/download/@babel/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha1-YRGiZbz7Ag6579D9/X0mQCue1sE=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npm.taobao.org/@babel/plugin-syntax-optional-chaining/download/@babel/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha1-T2nCq5UWfgGAzVM2YT+MV4j31Io=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-syntax-private-property-in-object/download/@babel/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha1-DcZnHsDqIrbpShEU+FeXDNOd4a0=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-syntax-top-level-await/download/@babel/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha1-wc/a3DWmRiQAAfBhOCR7dBw02Uw=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-arrow-functions": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-arrow-functions/download/@babel/plugin-transform-arrow-functions-7.14.5.tgz", + "integrity": "sha1-9xh9lYinaN0IC/TJ/+EX6mL3hio=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-async-to-generator": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-async-to-generator/download/@babel/plugin-transform-async-to-generator-7.14.5.tgz?cache=0&sync_timestamp=1623280543644&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-async-to-generator%2Fdownload%2F%40babel%2Fplugin-transform-async-to-generator-7.14.5.tgz", + "integrity": "sha1-cseJCE2PIJSsuUVjOUPvhEPTnmc=", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-remap-async-to-generator": "^7.14.5" + } + }, + "@babel/plugin-transform-block-scoped-functions": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-block-scoped-functions/download/@babel/plugin-transform-block-scoped-functions-7.14.5.tgz", + "integrity": "sha1-5IZB2ZnUvBV6Z+8zautUvET9OtQ=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-block-scoping": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-block-scoping/download/@babel/plugin-transform-block-scoping-7.14.5.tgz", + "integrity": "sha1-jMY+YeUPQuB45vCb53WnXyPvmTk=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-classes": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-classes/download/@babel/plugin-transform-classes-7.14.5.tgz?cache=0&sync_timestamp=1623280541378&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-classes%2Fdownload%2F%40babel%2Fplugin-transform-classes-7.14.5.tgz", + "integrity": "sha1-DpjoIJezhVCwO0g/m1GnjeCsss8=", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-optimise-call-expression": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-replace-supers": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "globals": "^11.1.0" + } + }, + "@babel/plugin-transform-computed-properties": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-computed-properties/download/@babel/plugin-transform-computed-properties-7.14.5.tgz", + "integrity": "sha1-G514mHQg0RIj1BGVRhzEO5dLIE8=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-destructuring": { + "version": "7.14.7", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-destructuring/download/@babel/plugin-transform-destructuring-7.14.7.tgz", + "integrity": "sha1-CtWO034j4iCE0QnxhSYINeVVdXY=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-dotall-regex": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-dotall-regex/download/@babel/plugin-transform-dotall-regex-7.14.5.tgz?cache=0&sync_timestamp=1623280544588&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-dotall-regex%2Fdownload%2F%40babel%2Fplugin-transform-dotall-regex-7.14.5.tgz", + "integrity": "sha1-L2v3bka9+AQ7Tn4WzyRTJim6DHo=", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-duplicate-keys": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-duplicate-keys/download/@babel/plugin-transform-duplicate-keys-7.14.5.tgz", + "integrity": "sha1-NlpIRIgb3xUB46nwJw5/D5EXeVQ=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-exponentiation-operator": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-exponentiation-operator/download/@babel/plugin-transform-exponentiation-operator-7.14.5.tgz?cache=0&sync_timestamp=1623280545524&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-exponentiation-operator%2Fdownload%2F%40babel%2Fplugin-transform-exponentiation-operator-7.14.5.tgz", + "integrity": "sha1-UVS43Wo9/m2Qkj1hckvT3uuQtJM=", + "dev": true, + "requires": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-for-of": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-for-of/download/@babel/plugin-transform-for-of-7.14.5.tgz", + "integrity": "sha1-2uOEYT3o93wZaohpy/YCpE9/wOs=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-function-name": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-function-name/download/@babel/plugin-transform-function-name-7.14.5.tgz?cache=0&sync_timestamp=1623280538359&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-function-name%2Fdownload%2F%40babel%2Fplugin-transform-function-name-7.14.5.tgz", + "integrity": "sha1-6Bxl7LkAdG1/MYAva+0fUtkV1vI=", + "dev": true, + "requires": { + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-literals": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-literals/download/@babel/plugin-transform-literals-7.14.5.tgz", + "integrity": "sha1-QdBsf/XU0J489Fh70+zzkwxzD3g=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-member-expression-literals": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-member-expression-literals/download/@babel/plugin-transform-member-expression-literals-7.14.5.tgz", + "integrity": "sha1-s5zVISor8jWmF9Mg7CtIvMCRuKc=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-modules-amd": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-modules-amd/download/@babel/plugin-transform-modules-amd-7.14.5.tgz?cache=0&sync_timestamp=1623280543412&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-modules-amd%2Fdownload%2F%40babel%2Fplugin-transform-modules-amd-7.14.5.tgz", + "integrity": "sha1-T9nOfjQRy4uDhISAtwQdgwBIWPc=", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "babel-plugin-dynamic-import-node": "^2.3.3" + } + }, + "@babel/plugin-transform-modules-commonjs": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-modules-commonjs/download/@babel/plugin-transform-modules-commonjs-7.14.5.tgz?cache=0&sync_timestamp=1623280545201&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-modules-commonjs%2Fdownload%2F%40babel%2Fplugin-transform-modules-commonjs-7.14.5.tgz", + "integrity": "sha1-eq7g6pgoPelNqYso+MNXAUKdrZc=", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-simple-access": "^7.14.5", + "babel-plugin-dynamic-import-node": "^2.3.3" + } + }, + "@babel/plugin-transform-modules-systemjs": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-modules-systemjs/download/@babel/plugin-transform-modules-systemjs-7.14.5.tgz?cache=0&sync_timestamp=1623280544915&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-modules-systemjs%2Fdownload%2F%40babel%2Fplugin-transform-modules-systemjs-7.14.5.tgz", + "integrity": "sha1-x1NC74sw3N5CldNAGq4k5lY47Sk=", + "dev": true, + "requires": { + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-validator-identifier": "^7.14.5", + "babel-plugin-dynamic-import-node": "^2.3.3" + } + }, + "@babel/plugin-transform-modules-umd": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-modules-umd/download/@babel/plugin-transform-modules-umd-7.14.5.tgz?cache=0&sync_timestamp=1623280545520&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-modules-umd%2Fdownload%2F%40babel%2Fplugin-transform-modules-umd-7.14.5.tgz", + "integrity": "sha1-+2Yt/uaXzOJ0p82lJRkKeQlqpuA=", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.14.7", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-named-capturing-groups-regex/download/@babel/plugin-transform-named-capturing-groups-regex-7.14.7.tgz", + "integrity": "sha1-YMBokqz53yMeJWwkRkv+ywkI/U4=", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.14.5" + } + }, + "@babel/plugin-transform-new-target": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-new-target/download/@babel/plugin-transform-new-target-7.14.5.tgz", + "integrity": "sha1-Mb2ui5JdyEB26/zSqZQBQ67X2/g=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-object-super": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-object-super/download/@babel/plugin-transform-object-super-7.14.5.tgz?cache=0&sync_timestamp=1623280540862&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-object-super%2Fdownload%2F%40babel%2Fplugin-transform-object-super-7.14.5.tgz", + "integrity": "sha1-0LX66snphZehYanPeMUn7ZNM3EU=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-replace-supers": "^7.14.5" + } + }, + "@babel/plugin-transform-parameters": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-parameters/download/@babel/plugin-transform-parameters-7.14.5.tgz", + "integrity": "sha1-SWYuhqHz3cysY2On37H/ChWK/rM=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-property-literals": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-property-literals/download/@babel/plugin-transform-property-literals-7.14.5.tgz", + "integrity": "sha1-DduqH4PbNgbxzfSEb6HftHNFizQ=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-regenerator": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-regenerator/download/@babel/plugin-transform-regenerator-7.14.5.tgz", + "integrity": "sha1-lnb9VwftKPUicnxbPAqoVERAsE8=", + "dev": true, + "requires": { + "regenerator-transform": "^0.14.2" + } + }, + "@babel/plugin-transform-reserved-words": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-reserved-words/download/@babel/plugin-transform-reserved-words-7.14.5.tgz", + "integrity": "sha1-xEWJtmHP2++NQwDcx0ad/6kvgwQ=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-runtime": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-runtime/download/@babel/plugin-transform-runtime-7.14.5.tgz?cache=0&sync_timestamp=1623280540797&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-runtime%2Fdownload%2F%40babel%2Fplugin-transform-runtime-7.14.5.tgz", + "integrity": "sha1-MEkdrUnGBZ+Pj6XuiJagCJ6YdSM=", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "babel-plugin-polyfill-corejs2": "^0.2.2", + "babel-plugin-polyfill-corejs3": "^0.2.2", + "babel-plugin-polyfill-regenerator": "^0.2.2", + "semver": "^6.3.0" + } + }, + "@babel/plugin-transform-shorthand-properties": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-shorthand-properties/download/@babel/plugin-transform-shorthand-properties-7.14.5.tgz", + "integrity": "sha1-l/E4VfFAkzjYyty6ymcK154JGlg=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-spread": { + "version": "7.14.6", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-spread/download/@babel/plugin-transform-spread-7.14.6.tgz", + "integrity": "sha1-a9QOV/596UqpBIUZY7VhZlL3MUQ=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.14.5" + } + }, + "@babel/plugin-transform-sticky-regex": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-sticky-regex/download/@babel/plugin-transform-sticky-regex-7.14.5.tgz", + "integrity": "sha1-W2F1Qmdei3dhKUOB88KMYz9Arrk=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-template-literals": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-template-literals/download/@babel/plugin-transform-template-literals-7.14.5.tgz", + "integrity": "sha1-pfK8Izk32EU4hdxza92Nn/q/PZM=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-typeof-symbol": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-typeof-symbol/download/@babel/plugin-transform-typeof-symbol-7.14.5.tgz", + "integrity": "sha1-Oa8nOemJor0pG/a1PxaYFCPUV9Q=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-unicode-escapes": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-unicode-escapes/download/@babel/plugin-transform-unicode-escapes-7.14.5.tgz", + "integrity": "sha1-nUvSpoHjxdes9PV/qeURddkdDGs=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-unicode-regex": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/plugin-transform-unicode-regex/download/@babel/plugin-transform-unicode-regex-7.14.5.tgz?cache=0&sync_timestamp=1623280536838&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-unicode-regex%2Fdownload%2F%40babel%2Fplugin-transform-unicode-regex-7.14.5.tgz", + "integrity": "sha1-TNCbbIQl3YElXHzrP7GDbnQUOC4=", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/preset-env": { + "version": "7.14.7", + "resolved": "https://registry.nlark.com/@babel/preset-env/download/@babel/preset-env-7.14.7.tgz?cache=0&sync_timestamp=1624313309952&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fpreset-env%2Fdownload%2F%40babel%2Fpreset-env-7.14.7.tgz", + "integrity": "sha1-XHCyLUwtiTsD2MiGpcF0IlArkyo=", + "dev": true, + "requires": { + "@babel/compat-data": "^7.14.7", + "@babel/helper-compilation-targets": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-validator-option": "^7.14.5", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.14.5", + "@babel/plugin-proposal-async-generator-functions": "^7.14.7", + "@babel/plugin-proposal-class-properties": "^7.14.5", + "@babel/plugin-proposal-class-static-block": "^7.14.5", + "@babel/plugin-proposal-dynamic-import": "^7.14.5", + "@babel/plugin-proposal-export-namespace-from": "^7.14.5", + "@babel/plugin-proposal-json-strings": "^7.14.5", + "@babel/plugin-proposal-logical-assignment-operators": "^7.14.5", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.14.5", + "@babel/plugin-proposal-numeric-separator": "^7.14.5", + "@babel/plugin-proposal-object-rest-spread": "^7.14.7", + "@babel/plugin-proposal-optional-catch-binding": "^7.14.5", + "@babel/plugin-proposal-optional-chaining": "^7.14.5", + "@babel/plugin-proposal-private-methods": "^7.14.5", + "@babel/plugin-proposal-private-property-in-object": "^7.14.5", + "@babel/plugin-proposal-unicode-property-regex": "^7.14.5", + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5", + "@babel/plugin-transform-arrow-functions": "^7.14.5", + "@babel/plugin-transform-async-to-generator": "^7.14.5", + "@babel/plugin-transform-block-scoped-functions": "^7.14.5", + "@babel/plugin-transform-block-scoping": "^7.14.5", + "@babel/plugin-transform-classes": "^7.14.5", + "@babel/plugin-transform-computed-properties": "^7.14.5", + "@babel/plugin-transform-destructuring": "^7.14.7", + "@babel/plugin-transform-dotall-regex": "^7.14.5", + "@babel/plugin-transform-duplicate-keys": "^7.14.5", + "@babel/plugin-transform-exponentiation-operator": "^7.14.5", + "@babel/plugin-transform-for-of": "^7.14.5", + "@babel/plugin-transform-function-name": "^7.14.5", + "@babel/plugin-transform-literals": "^7.14.5", + "@babel/plugin-transform-member-expression-literals": "^7.14.5", + "@babel/plugin-transform-modules-amd": "^7.14.5", + "@babel/plugin-transform-modules-commonjs": "^7.14.5", + "@babel/plugin-transform-modules-systemjs": "^7.14.5", + "@babel/plugin-transform-modules-umd": "^7.14.5", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.14.7", + "@babel/plugin-transform-new-target": "^7.14.5", + "@babel/plugin-transform-object-super": "^7.14.5", + "@babel/plugin-transform-parameters": "^7.14.5", + "@babel/plugin-transform-property-literals": "^7.14.5", + "@babel/plugin-transform-regenerator": "^7.14.5", + "@babel/plugin-transform-reserved-words": "^7.14.5", + "@babel/plugin-transform-shorthand-properties": "^7.14.5", + "@babel/plugin-transform-spread": "^7.14.6", + "@babel/plugin-transform-sticky-regex": "^7.14.5", + "@babel/plugin-transform-template-literals": "^7.14.5", + "@babel/plugin-transform-typeof-symbol": "^7.14.5", + "@babel/plugin-transform-unicode-escapes": "^7.14.5", + "@babel/plugin-transform-unicode-regex": "^7.14.5", + "@babel/preset-modules": "^0.1.4", + "@babel/types": "^7.14.5", + "babel-plugin-polyfill-corejs2": "^0.2.2", + "babel-plugin-polyfill-corejs3": "^0.2.2", + "babel-plugin-polyfill-regenerator": "^0.2.2", + "core-js-compat": "^3.15.0", + "semver": "^6.3.0" + } + }, + "@babel/preset-modules": { + "version": "0.1.4", + "resolved": "https://registry.nlark.com/@babel/preset-modules/download/@babel/preset-modules-0.1.4.tgz", + "integrity": "sha1-Ni8raMZihClw/bXiVP/I/BwuQV4=", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", + "@babel/plugin-transform-dotall-regex": "^7.4.4", + "@babel/types": "^7.4.4", + "esutils": "^2.0.2" + } + }, + "@babel/runtime": { + "version": "7.14.6", + "resolved": "https://registry.nlark.com/@babel/runtime/download/@babel/runtime-7.14.6.tgz", + "integrity": "sha1-U1IDvAiS78fexgvcJ7Ls9uQJBi0=", + "dev": true, + "requires": { + "regenerator-runtime": "^0.13.4" + } + }, + "@babel/runtime-corejs2": { + "version": "7.14.6", + "resolved": "https://registry.nlark.com/@babel/runtime-corejs2/download/@babel/runtime-corejs2-7.14.6.tgz", + "integrity": "sha1-5dOhpaCPRJhzTdNwGvT9GN2Gd7U=", + "dev": true, + "requires": { + "core-js": "^2.6.5", + "regenerator-runtime": "^0.13.4" + }, + "dependencies": { + "core-js": { + "version": "2.6.12", + "resolved": "https://registry.nlark.com/core-js/download/core-js-2.6.12.tgz?cache=0&sync_timestamp=1624966012065&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcore-js%2Fdownload%2Fcore-js-2.6.12.tgz", + "integrity": "sha1-2TM9+nsGXjR8xWgiGdb2kIWcwuw=", + "dev": true + } + } + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/template/download/@babel/template-7.14.5.tgz?cache=0&sync_timestamp=1623280543555&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Ftemplate%2Fdownload%2F%40babel%2Ftemplate-7.14.5.tgz", + "integrity": "sha1-qbydizM1T/blWpxg0RCSAKaJdPQ=", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/traverse": { + "version": "7.14.7", + "resolved": "https://registry.nlark.com/@babel/traverse/download/@babel/traverse-7.14.7.tgz?cache=0&sync_timestamp=1624313310223&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Ftraverse%2Fdownload%2F%40babel%2Ftraverse-7.14.7.tgz", + "integrity": "sha1-ZAB8l3TP3Dq9I7B4C8GKPONjF1M=", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/parser": "^7.14.7", + "@babel/types": "^7.14.5", + "debug": "^4.1.0", + "globals": "^11.1.0" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.nlark.com/@babel/types/download/@babel/types-7.14.5.tgz", + "integrity": "sha1-O7mXuoKaIQTO2yBonEpbgSHTg/8=", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + }, + "@ctrl/tinycolor": { + "version": "3.4.1", + "resolved": "https://registry.npmmirror.com/@ctrl/tinycolor/-/tinycolor-3.4.1.tgz", + "integrity": "sha512-ej5oVy6lykXsvieQtqZxCOaLT+xD4+QNarq78cIYISHmZXshCvROLudpQN3lfL8G0NL7plMSSK+zlyvCaIJ4Iw==" + }, + "@element-plus/icons-vue": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@element-plus/icons-vue/-/icons-vue-2.1.0.tgz", + "integrity": "sha512-PSBn3elNoanENc1vnCfh+3WA9fimRC7n+fWkf3rE5jvv+aBohNHABC/KAR5KWPecxWxDTVT1ERpRbOMRcOV/vA==" + }, + "@floating-ui/core": { + "version": "0.7.3", + "resolved": "https://registry.npmmirror.com/@floating-ui/core/-/core-0.7.3.tgz", + "integrity": "sha512-buc8BXHmG9l82+OQXOFU3Kr2XQx9ys01U/Q9HMIrZ300iLc8HLMgh7dcCqgYzAzf4BkoQvDcXf5Y+CuEZ5JBYg==" + }, + "@floating-ui/dom": { + "version": "0.5.4", + "resolved": "https://registry.npmmirror.com/@floating-ui/dom/-/dom-0.5.4.tgz", + "integrity": "sha512-419BMceRLq0RrmTSDxn8hf9R3VCJv2K9PUfugh5JyEFmdjzDo+e8U5EdR8nzKq8Yj1htzLm3b6eQEEam3/rrtg==", + "requires": { + "@floating-ui/core": "^0.7.3" + } + }, + "@hapi/address": { + "version": "2.1.4", + "resolved": "https://registry.npm.taobao.org/@hapi/address/download/@hapi/address-2.1.4.tgz", + "integrity": "sha1-XWftQ/P9QaadS5/3tW58DR0KgeU=", + "dev": true + }, + "@hapi/bourne": { + "version": "1.3.2", + "resolved": "https://registry.npm.taobao.org/@hapi/bourne/download/@hapi/bourne-1.3.2.tgz", + "integrity": "sha1-CnCVreoGckPOMoPhtWuKj0U7JCo=", + "dev": true + }, + "@hapi/hoek": { + "version": "8.5.1", + "resolved": "https://registry.nlark.com/@hapi/hoek/download/@hapi/hoek-8.5.1.tgz", + "integrity": "sha1-/elgZMpEbeyMVajC8TCVewcMbgY=", + "dev": true + }, + "@hapi/joi": { + "version": "15.1.1", + "resolved": "https://registry.npm.taobao.org/@hapi/joi/download/@hapi/joi-15.1.1.tgz", + "integrity": "sha1-xnW4pxKW8Cgz+NbSQ7NMV7jOGdc=", + "dev": true, + "requires": { + "@hapi/address": "2.x.x", + "@hapi/bourne": "1.x.x", + "@hapi/hoek": "8.x.x", + "@hapi/topo": "3.x.x" + } + }, + "@hapi/topo": { + "version": "3.1.6", + "resolved": "https://registry.nlark.com/@hapi/topo/download/@hapi/topo-3.1.6.tgz", + "integrity": "sha1-aNk1+j6uf91asNf5U/MgXYsr/Ck=", + "dev": true, + "requires": { + "@hapi/hoek": "^8.3.0" + } + }, + "@intervolga/optimize-cssnano-plugin": { + "version": "1.0.6", + "resolved": "https://registry.npm.taobao.org/@intervolga/optimize-cssnano-plugin/download/@intervolga/optimize-cssnano-plugin-1.0.6.tgz", + "integrity": "sha1-vnx4RhKLiPapsdEmGgrQbrXA/fg=", + "dev": true, + "requires": { + "cssnano": "^4.0.0", + "cssnano-preset-default": "^4.0.0", + "postcss": "^7.0.0" + } + }, + "@microsoft/signalr": { + "version": "6.0.4", + "resolved": "https://registry.npmmirror.com/@microsoft/signalr/-/signalr-6.0.4.tgz", + "integrity": "sha512-YeWRh4LxfYnq4I5CKw17/HOq8rY+ouTv6Bq+s55122StE3pK29j8j2OpP+1PA3D1ksHPfy7dFIgC33yr/E+01A==", + "requires": { + "abort-controller": "^3.0.0", + "eventsource": "^1.0.7", + "fetch-cookie": "^0.11.0", + "node-fetch": "^2.6.7", + "ws": "^7.4.5" + } + }, + "@mrmlnc/readdir-enhanced": { + "version": "2.2.1", + "resolved": "https://registry.npm.taobao.org/@mrmlnc/readdir-enhanced/download/@mrmlnc/readdir-enhanced-2.2.1.tgz", + "integrity": "sha1-UkryQNGjYFJ7cwR17PoTRKpUDd4=", + "dev": true, + "requires": { + "call-me-maybe": "^1.0.1", + "glob-to-regexp": "^0.3.0" + } + }, + "@node-ipc/js-queue": { + "version": "2.0.3", + "resolved": "https://registry.npmmirror.com/@node-ipc/js-queue/-/js-queue-2.0.3.tgz", + "integrity": "sha512-fL1wpr8hhD5gT2dA1qifeVaoDFlQR5es8tFuKqjHX+kdOtdNHnxkVZbtIrR2rxnMFvehkjaZRNV2H/gPXlb0hw==", + "dev": true, + "requires": { + "easy-stack": "1.0.1" + } + }, + "@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.nlark.com/@nodelib/fs.scandir/download/@nodelib/fs.scandir-2.1.5.tgz", + "integrity": "sha1-dhnC6yGyVIP20WdUi0z9WnSIw9U=", + "dev": true, + "requires": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + }, + "dependencies": { + "@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.nlark.com/@nodelib/fs.stat/download/@nodelib/fs.stat-2.0.5.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40nodelib%2Ffs.stat%2Fdownload%2F%40nodelib%2Ffs.stat-2.0.5.tgz", + "integrity": "sha1-W9Jir5Tp0lvR5xsF3u1Eh2oiLos=", + "dev": true + } + } + }, + "@nodelib/fs.stat": { + "version": "1.1.3", + "resolved": "https://registry.nlark.com/@nodelib/fs.stat/download/@nodelib/fs.stat-1.1.3.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40nodelib%2Ffs.stat%2Fdownload%2F%40nodelib%2Ffs.stat-1.1.3.tgz", + "integrity": "sha1-K1o6s/kYzKSKjHVMCBaOPwPrphs=", + "dev": true + }, + "@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.nlark.com/@nodelib/fs.walk/download/@nodelib/fs.walk-1.2.8.tgz?cache=0&sync_timestamp=1625769855088&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40nodelib%2Ffs.walk%2Fdownload%2F%40nodelib%2Ffs.walk-1.2.8.tgz", + "integrity": "sha1-6Vc36LtnRt3t9pxVaVNJTxlv5po=", + "dev": true, + "requires": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + } + }, + "@parcel/watcher": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher/-/watcher-2.4.1.tgz", + "integrity": "sha512-HNjmfLQEVRZmHRET336f20H/8kOozUGwk7yajvsonjNxbj2wBTK1WsQuHkD5yYh9RxFGL2EyDHryOihOwUoKDA==", + "dev": true, + "requires": { + "@parcel/watcher-android-arm64": "2.4.1", + "@parcel/watcher-darwin-arm64": "2.4.1", + "@parcel/watcher-darwin-x64": "2.4.1", + "@parcel/watcher-freebsd-x64": "2.4.1", + "@parcel/watcher-linux-arm-glibc": "2.4.1", + "@parcel/watcher-linux-arm64-glibc": "2.4.1", + "@parcel/watcher-linux-arm64-musl": "2.4.1", + "@parcel/watcher-linux-x64-glibc": "2.4.1", + "@parcel/watcher-linux-x64-musl": "2.4.1", + "@parcel/watcher-win32-arm64": "2.4.1", + "@parcel/watcher-win32-ia32": "2.4.1", + "@parcel/watcher-win32-x64": "2.4.1", + "detect-libc": "^1.0.3", + "is-glob": "^4.0.3", + "micromatch": "^4.0.5", + "node-addon-api": "^7.0.0" + }, + "dependencies": { + "braces": { + "version": "3.0.3", + "resolved": "https://registry.npmmirror.com/braces/-/braces-3.0.3.tgz", + "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", + "dev": true, + "requires": { + "fill-range": "^7.1.1" + } + }, + "fill-range": { + "version": "7.1.1", + "resolved": "https://registry.npmmirror.com/fill-range/-/fill-range-7.1.1.tgz", + "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", + "dev": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "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, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "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 + }, + "micromatch": { + "version": "4.0.8", + "resolved": "https://registry.npmmirror.com/micromatch/-/micromatch-4.0.8.tgz", + "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==", + "dev": true, + "requires": { + "braces": "^3.0.3", + "picomatch": "^2.3.1" + } + }, + "picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true + }, + "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, + "requires": { + "is-number": "^7.0.0" + } + } + } + }, + "@parcel/watcher-android-arm64": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-android-arm64/-/watcher-android-arm64-2.4.1.tgz", + "integrity": "sha512-LOi/WTbbh3aTn2RYddrO8pnapixAziFl6SMxHM69r3tvdSm94JtCenaKgk1GRg5FJ5wpMCpHeW+7yqPlvZv7kg==", + "dev": true, + "optional": true + }, + "@parcel/watcher-darwin-arm64": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-darwin-arm64/-/watcher-darwin-arm64-2.4.1.tgz", + "integrity": "sha512-ln41eihm5YXIY043vBrrHfn94SIBlqOWmoROhsMVTSXGh0QahKGy77tfEywQ7v3NywyxBBkGIfrWRHm0hsKtzA==", + "dev": true, + "optional": true + }, + "@parcel/watcher-darwin-x64": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-darwin-x64/-/watcher-darwin-x64-2.4.1.tgz", + "integrity": "sha512-yrw81BRLjjtHyDu7J61oPuSoeYWR3lDElcPGJyOvIXmor6DEo7/G2u1o7I38cwlcoBHQFULqF6nesIX3tsEXMg==", + "dev": true, + "optional": true + }, + "@parcel/watcher-freebsd-x64": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-freebsd-x64/-/watcher-freebsd-x64-2.4.1.tgz", + "integrity": "sha512-TJa3Pex/gX3CWIx/Co8k+ykNdDCLx+TuZj3f3h7eOjgpdKM+Mnix37RYsYU4LHhiYJz3DK5nFCCra81p6g050w==", + "dev": true, + "optional": true + }, + "@parcel/watcher-linux-arm-glibc": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-linux-arm-glibc/-/watcher-linux-arm-glibc-2.4.1.tgz", + "integrity": "sha512-4rVYDlsMEYfa537BRXxJ5UF4ddNwnr2/1O4MHM5PjI9cvV2qymvhwZSFgXqbS8YoTk5i/JR0L0JDs69BUn45YA==", + "dev": true, + "optional": true + }, + "@parcel/watcher-linux-arm64-glibc": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-linux-arm64-glibc/-/watcher-linux-arm64-glibc-2.4.1.tgz", + "integrity": "sha512-BJ7mH985OADVLpbrzCLgrJ3TOpiZggE9FMblfO65PlOCdG++xJpKUJ0Aol74ZUIYfb8WsRlUdgrZxKkz3zXWYA==", + "dev": true, + "optional": true + }, + "@parcel/watcher-linux-arm64-musl": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-linux-arm64-musl/-/watcher-linux-arm64-musl-2.4.1.tgz", + "integrity": "sha512-p4Xb7JGq3MLgAfYhslU2SjoV9G0kI0Xry0kuxeG/41UfpjHGOhv7UoUDAz/jb1u2elbhazy4rRBL8PegPJFBhA==", + "dev": true, + "optional": true + }, + "@parcel/watcher-linux-x64-glibc": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-linux-x64-glibc/-/watcher-linux-x64-glibc-2.4.1.tgz", + "integrity": "sha512-s9O3fByZ/2pyYDPoLM6zt92yu6P4E39a03zvO0qCHOTjxmt3GHRMLuRZEWhWLASTMSrrnVNWdVI/+pUElJBBBg==", + "dev": true, + "optional": true + }, + "@parcel/watcher-linux-x64-musl": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-linux-x64-musl/-/watcher-linux-x64-musl-2.4.1.tgz", + "integrity": "sha512-L2nZTYR1myLNST0O632g0Dx9LyMNHrn6TOt76sYxWLdff3cB22/GZX2UPtJnaqQPdCRoszoY5rcOj4oMTtp5fQ==", + "dev": true, + "optional": true + }, + "@parcel/watcher-win32-arm64": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-win32-arm64/-/watcher-win32-arm64-2.4.1.tgz", + "integrity": "sha512-Uq2BPp5GWhrq/lcuItCHoqxjULU1QYEcyjSO5jqqOK8RNFDBQnenMMx4gAl3v8GiWa59E9+uDM7yZ6LxwUIfRg==", + "dev": true, + "optional": true + }, + "@parcel/watcher-win32-ia32": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-win32-ia32/-/watcher-win32-ia32-2.4.1.tgz", + "integrity": "sha512-maNRit5QQV2kgHFSYwftmPBxiuK5u4DXjbXx7q6eKjq5dsLXZ4FJiVvlcw35QXzk0KrUecJmuVFbj4uV9oYrcw==", + "dev": true, + "optional": true + }, + "@parcel/watcher-win32-x64": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/@parcel/watcher-win32-x64/-/watcher-win32-x64-2.4.1.tgz", + "integrity": "sha512-+DvS92F9ezicfswqrvIRM2njcYJbd5mb9CUgtrHCHmvn7pPPa+nMDRu1o1bYYz/l5IB2NVGNJWiH7h1E58IF2A==", + "dev": true, + "optional": true + }, + "@soda/friendly-errors-webpack-plugin": { + "version": "1.8.0", + "resolved": "https://registry.npm.taobao.org/@soda/friendly-errors-webpack-plugin/download/@soda/friendly-errors-webpack-plugin-1.8.0.tgz?cache=0&sync_timestamp=1607927406873&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40soda%2Ffriendly-errors-webpack-plugin%2Fdownload%2F%40soda%2Ffriendly-errors-webpack-plugin-1.8.0.tgz", + "integrity": "sha1-hHUdgqkwGdXJLAzw5FrFkIfNIkA=", + "dev": true, + "requires": { + "chalk": "^2.4.2", + "error-stack-parser": "^2.0.2", + "string-width": "^2.0.0", + "strip-ansi": "^5" + } + }, + "@soda/get-current-script": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/@soda/get-current-script/download/@soda/get-current-script-1.0.2.tgz", + "integrity": "sha1-pTUV2yXYA4N0OBtzryC7Ty5QjYc=", + "dev": true + }, + "@tootallnate/once": { + "version": "1.1.2", + "resolved": "https://registry.npmmirror.com/@tootallnate/once/-/once-1.1.2.tgz", + "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==" + }, + "@types/body-parser": { + "version": "1.19.1", + "resolved": "https://registry.nlark.com/@types/body-parser/download/@types/body-parser-1.19.1.tgz?cache=0&sync_timestamp=1625595908991&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fbody-parser%2Fdownload%2F%40types%2Fbody-parser-1.19.1.tgz", + "integrity": "sha1-DAF0xCp9AXuBgwPUtdlpywt1kpw=", + "dev": true, + "requires": { + "@types/connect": "*", + "@types/node": "*" + } + }, + "@types/connect": { + "version": "3.4.35", + "resolved": "https://registry.nlark.com/@types/connect/download/@types/connect-3.4.35.tgz", + "integrity": "sha1-X89q5EXkAh0fwiGaSHPMc6O7KtE=", + "dev": true, + "requires": { + "@types/node": "*" + } + }, + "@types/connect-history-api-fallback": { + "version": "1.3.5", + "resolved": "https://registry.nlark.com/@types/connect-history-api-fallback/download/@types/connect-history-api-fallback-1.3.5.tgz", + "integrity": "sha1-0feooJ0O1aV67lrpwYq5uAMgXa4=", + "dev": true, + "requires": { + "@types/express-serve-static-core": "*", + "@types/node": "*" + } + }, + "@types/express": { + "version": "4.17.13", + "resolved": "https://registry.nlark.com/@types/express/download/@types/express-4.17.13.tgz?cache=0&sync_timestamp=1625605304761&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fexpress%2Fdownload%2F%40types%2Fexpress-4.17.13.tgz", + "integrity": "sha1-p24plXKJmbq1GjP6vOHXBaNwkDQ=", + "dev": true, + "requires": { + "@types/body-parser": "*", + "@types/express-serve-static-core": "^4.17.18", + "@types/qs": "*", + "@types/serve-static": "*" + } + }, + "@types/express-serve-static-core": { + "version": "4.17.24", + "resolved": "https://registry.nlark.com/@types/express-serve-static-core/download/@types/express-serve-static-core-4.17.24.tgz?cache=0&sync_timestamp=1625762134763&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fexpress-serve-static-core%2Fdownload%2F%40types%2Fexpress-serve-static-core-4.17.24.tgz", + "integrity": "sha1-6kH5O/fg1ZzVp2ZlBo7WqraBXAc=", + "dev": true, + "requires": { + "@types/node": "*", + "@types/qs": "*", + "@types/range-parser": "*" + } + }, + "@types/glob": { + "version": "7.1.4", + "resolved": "https://registry.nlark.com/@types/glob/download/@types/glob-7.1.4.tgz?cache=0&sync_timestamp=1625605304235&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fglob%2Fdownload%2F%40types%2Fglob-7.1.4.tgz", + "integrity": "sha1-6lniHS7lxReRTLS8jkFTuZ5WZnI=", + "dev": true, + "requires": { + "@types/minimatch": "*", + "@types/node": "*" + } + }, + "@types/http-proxy": { + "version": "1.17.7", + "resolved": "https://registry.nlark.com/@types/http-proxy/download/@types/http-proxy-1.17.7.tgz", + "integrity": "sha1-MOqFzCyGg2g1Kjfw0NNYHiSDTG8=", + "dev": true, + "requires": { + "@types/node": "*" + } + }, + "@types/json-schema": { + "version": "7.0.8", + "resolved": "https://registry.nlark.com/@types/json-schema/download/@types/json-schema-7.0.8.tgz", + "integrity": "sha1-7fG/Hb9OBEE8qOWxezt9fVS1mBg=", + "dev": true + }, + "@types/lodash": { + "version": "4.14.184", + "resolved": "https://registry.npmmirror.com/@types/lodash/-/lodash-4.14.184.tgz", + "integrity": "sha512-RoZphVtHbxPZizt4IcILciSWiC6dcn+eZ8oX9IWEYfDMcocdd42f7NPI6fQj+6zI8y4E0L7gu2pcZKLGTRaV9Q==" + }, + "@types/lodash-es": { + "version": "4.17.6", + "resolved": "https://registry.npmmirror.com/@types/lodash-es/-/lodash-es-4.17.6.tgz", + "integrity": "sha512-R+zTeVUKDdfoRxpAryaQNRKk3105Rrgx2CFRClIgRGaqDTdjsm8h6IYA8ir584W3ePzkZfst5xIgDwYrlh9HLg==", + "requires": { + "@types/lodash": "*" + } + }, + "@types/mime": { + "version": "1.3.2", + "resolved": "https://registry.nlark.com/@types/mime/download/@types/mime-1.3.2.tgz", + "integrity": "sha1-k+Jb+e51/g/YC1lLxP6w6GIRG1o=", + "dev": true + }, + "@types/minimatch": { + "version": "3.0.5", + "resolved": "https://registry.nlark.com/@types/minimatch/download/@types/minimatch-3.0.5.tgz?cache=0&sync_timestamp=1625616310061&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fminimatch%2Fdownload%2F%40types%2Fminimatch-3.0.5.tgz", + "integrity": "sha1-EAHMXmo3BLg8I2An538vWOoBD0A=", + "dev": true + }, + "@types/minimist": { + "version": "1.2.2", + "resolved": "https://registry.nlark.com/@types/minimist/download/@types/minimist-1.2.2.tgz?cache=0&sync_timestamp=1625616254387&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fminimist%2Fdownload%2F%40types%2Fminimist-1.2.2.tgz", + "integrity": "sha1-7nceK6Sz3Fs3KTXVSf2WF780W4w=", + "dev": true + }, + "@types/node": { + "version": "16.3.2", + "resolved": "https://registry.nlark.com/@types/node/download/@types/node-16.3.2.tgz?cache=0&sync_timestamp=1626221012858&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fnode%2Fdownload%2F%40types%2Fnode-16.3.2.tgz", + "integrity": "sha1-ZVQygX+DtRrIacLVHdgwX7g0LhY=", + "dev": true + }, + "@types/normalize-package-data": { + "version": "2.4.1", + "resolved": "https://registry.nlark.com/@types/normalize-package-data/download/@types/normalize-package-data-2.4.1.tgz?cache=0&sync_timestamp=1625675733240&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fnormalize-package-data%2Fdownload%2F%40types%2Fnormalize-package-data-2.4.1.tgz", + "integrity": "sha1-0zV0eaD9/dWQf+Z+F+CoXJBuEwE=", + "dev": true + }, + "@types/q": { + "version": "1.5.5", + "resolved": "https://registry.nlark.com/@types/q/download/@types/q-1.5.5.tgz?cache=0&sync_timestamp=1625678452535&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fq%2Fdownload%2F%40types%2Fq-1.5.5.tgz", + "integrity": "sha1-daKo59irSyMEFFBdkjNdHctTpt8=", + "dev": true + }, + "@types/qs": { + "version": "6.9.7", + "resolved": "https://registry.nlark.com/@types/qs/download/@types/qs-6.9.7.tgz", + "integrity": "sha1-Y7t9Bn2xB8weRXwwO8JdUR/r9ss=", + "dev": true + }, + "@types/range-parser": { + "version": "1.2.4", + "resolved": "https://registry.nlark.com/@types/range-parser/download/@types/range-parser-1.2.4.tgz", + "integrity": "sha1-zWZ7z90CUhOq+3ylkVqTJZCs3Nw=", + "dev": true + }, + "@types/serve-static": { + "version": "1.13.10", + "resolved": "https://registry.nlark.com/@types/serve-static/download/@types/serve-static-1.13.10.tgz", + "integrity": "sha1-9eDOh5fS18xevtpIpSyWxPpHqNk=", + "dev": true, + "requires": { + "@types/mime": "^1", + "@types/node": "*" + } + }, + "@types/source-list-map": { + "version": "0.1.2", + "resolved": "https://registry.nlark.com/@types/source-list-map/download/@types/source-list-map-0.1.2.tgz", + "integrity": "sha1-AHiDYGP/rxdBI0m7o2QIfgrALsk=", + "dev": true + }, + "@types/tapable": { + "version": "1.0.8", + "resolved": "https://registry.nlark.com/@types/tapable/download/@types/tapable-1.0.8.tgz", + "integrity": "sha1-uUpDkchWZse3Mpn9OtedT6pDUxA=", + "dev": true + }, + "@types/uglify-js": { + "version": "3.13.1", + "resolved": "https://registry.nlark.com/@types/uglify-js/download/@types/uglify-js-3.13.1.tgz?cache=0&sync_timestamp=1625249395387&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fuglify-js%2Fdownload%2F%40types%2Fuglify-js-3.13.1.tgz", + "integrity": "sha1-XoienoHpQkXHW2RQYA4cXqKHiuo=", + "dev": true, + "requires": { + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "@types/web-bluetooth": { + "version": "0.0.15", + "resolved": "https://registry.npmmirror.com/@types/web-bluetooth/-/web-bluetooth-0.0.15.tgz", + "integrity": "sha512-w7hEHXnPMEZ+4nGKl/KDRVpxkwYxYExuHOYXyzIzCDzEZ9ZCGMAewulr9IqJu2LR4N37fcnb1XVeuZ09qgOxhA==" + }, + "@types/webpack": { + "version": "4.41.30", + "resolved": "https://registry.nlark.com/@types/webpack/download/@types/webpack-4.41.30.tgz?cache=0&sync_timestamp=1625251660875&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fwebpack%2Fdownload%2F%40types%2Fwebpack-4.41.30.tgz", + "integrity": "sha1-/T220NQeFFqO7q/NPEp8zekGjdw=", + "dev": true, + "requires": { + "@types/node": "*", + "@types/tapable": "^1", + "@types/uglify-js": "*", + "@types/webpack-sources": "*", + "anymatch": "^3.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "@types/webpack-dev-server": { + "version": "3.11.5", + "resolved": "https://registry.nlark.com/@types/webpack-dev-server/download/@types/webpack-dev-server-3.11.5.tgz?cache=0&sync_timestamp=1625251651898&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fwebpack-dev-server%2Fdownload%2F%40types%2Fwebpack-dev-server-3.11.5.tgz", + "integrity": "sha1-9KJUo90GZ8juSvkNQq/bStHWB/M=", + "dev": true, + "requires": { + "@types/connect-history-api-fallback": "*", + "@types/express": "*", + "@types/serve-static": "*", + "@types/webpack": "^4", + "http-proxy-middleware": "^1.0.0" + } + }, + "@types/webpack-sources": { + "version": "2.1.1", + "resolved": "https://registry.nlark.com/@types/webpack-sources/download/@types/webpack-sources-2.1.1.tgz?cache=0&sync_timestamp=1625251653385&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fwebpack-sources%2Fdownload%2F%40types%2Fwebpack-sources-2.1.1.tgz", + "integrity": "sha1-avF+Oj3tce7CuYAI18EvSYoKRQY=", + "dev": true, + "requires": { + "@types/node": "*", + "@types/source-list-map": "*", + "source-map": "^0.7.3" + }, + "dependencies": { + "source-map": { + "version": "0.7.3", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.7.3.tgz", + "integrity": "sha1-UwL4FpAxc1ImVECS5kmB91F1A4M=", + "dev": true + } + } + }, + "@vue/babel-helper-vue-jsx-merge-props": { + "version": "1.2.1", + "resolved": "https://registry.nlark.com/@vue/babel-helper-vue-jsx-merge-props/download/@vue/babel-helper-vue-jsx-merge-props-1.2.1.tgz", + "integrity": "sha1-MWJKelBfsU2h1YAjclpMXycOaoE=", + "dev": true + }, + "@vue/babel-helper-vue-transform-on": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/@vue/babel-helper-vue-transform-on/download/@vue/babel-helper-vue-transform-on-1.0.2.tgz", + "integrity": "sha1-m5xpHNBvyFUiGiR1w8yDHXdLx9w=", + "dev": true + }, + "@vue/babel-plugin-jsx": { + "version": "1.0.6", + "resolved": "https://registry.nlark.com/@vue/babel-plugin-jsx/download/@vue/babel-plugin-jsx-1.0.6.tgz", + "integrity": "sha1-GEvzVBq279vlB5q4sgwZ4q8QC/s=", + "dev": true, + "requires": { + "@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/babel-plugin-transform-vue-jsx": { + "version": "1.2.1", + "resolved": "https://registry.npm.taobao.org/@vue/babel-plugin-transform-vue-jsx/download/@vue/babel-plugin-transform-vue-jsx-1.2.1.tgz", + "integrity": "sha1-ZGBGxlLC8CQnJ/NFGdkXsGQEHtc=", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.0.0", + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-helper-vue-jsx-merge-props": "^1.2.1", + "html-tags": "^2.0.0", + "lodash.kebabcase": "^4.1.1", + "svg-tags": "^1.0.0" + }, + "dependencies": { + "html-tags": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/html-tags/download/html-tags-2.0.0.tgz", + "integrity": "sha1-ELMKOGCF9Dzt41PMj6fLDe7qZos=", + "dev": true + } + } + }, + "@vue/babel-preset-app": { + "version": "4.5.13", + "resolved": "https://registry.nlark.com/@vue/babel-preset-app/download/@vue/babel-preset-app-4.5.13.tgz?cache=0&sync_timestamp=1623215857834&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40vue%2Fbabel-preset-app%2Fdownload%2F%40vue%2Fbabel-preset-app-4.5.13.tgz", + "integrity": "sha1-y0dTIeTHP38RDawppIwqnLgK/rY=", + "dev": true, + "requires": { + "@babel/core": "^7.11.0", + "@babel/helper-compilation-targets": "^7.9.6", + "@babel/helper-module-imports": "^7.8.3", + "@babel/plugin-proposal-class-properties": "^7.8.3", + "@babel/plugin-proposal-decorators": "^7.8.3", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-jsx": "^7.8.3", + "@babel/plugin-transform-runtime": "^7.11.0", + "@babel/preset-env": "^7.11.0", + "@babel/runtime": "^7.11.0", + "@vue/babel-plugin-jsx": "^1.0.3", + "@vue/babel-preset-jsx": "^1.2.4", + "babel-plugin-dynamic-import-node": "^2.3.3", + "core-js": "^3.6.5", + "core-js-compat": "^3.6.5", + "semver": "^6.1.0" + } + }, + "@vue/babel-preset-jsx": { + "version": "1.2.4", + "resolved": "https://registry.npm.taobao.org/@vue/babel-preset-jsx/download/@vue/babel-preset-jsx-1.2.4.tgz", + "integrity": "sha1-kv6nnbbxOwHoDToAmeKSS9y+Toc=", + "dev": true, + "requires": { + "@vue/babel-helper-vue-jsx-merge-props": "^1.2.1", + "@vue/babel-plugin-transform-vue-jsx": "^1.2.1", + "@vue/babel-sugar-composition-api-inject-h": "^1.2.1", + "@vue/babel-sugar-composition-api-render-instance": "^1.2.4", + "@vue/babel-sugar-functional-vue": "^1.2.2", + "@vue/babel-sugar-inject-h": "^1.2.2", + "@vue/babel-sugar-v-model": "^1.2.3", + "@vue/babel-sugar-v-on": "^1.2.3" + } + }, + "@vue/babel-sugar-composition-api-inject-h": { + "version": "1.2.1", + "resolved": "https://registry.npm.taobao.org/@vue/babel-sugar-composition-api-inject-h/download/@vue/babel-sugar-composition-api-inject-h-1.2.1.tgz", + "integrity": "sha1-BdbgxDJxDjdYKyvppgSbaJtvA+s=", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0" + } + }, + "@vue/babel-sugar-composition-api-render-instance": { + "version": "1.2.4", + "resolved": "https://registry.nlark.com/@vue/babel-sugar-composition-api-render-instance/download/@vue/babel-sugar-composition-api-render-instance-1.2.4.tgz", + "integrity": "sha1-5MvGmXw0T6wnF4WteikyXFHWjRk=", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0" + } + }, + "@vue/babel-sugar-functional-vue": { + "version": "1.2.2", + "resolved": "https://registry.npm.taobao.org/@vue/babel-sugar-functional-vue/download/@vue/babel-sugar-functional-vue-1.2.2.tgz?cache=0&sync_timestamp=1602929625505&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40vue%2Fbabel-sugar-functional-vue%2Fdownload%2F%40vue%2Fbabel-sugar-functional-vue-1.2.2.tgz", + "integrity": "sha1-JnqayNeHyW7b8Dzj85LEnam9Jlg=", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0" + } + }, + "@vue/babel-sugar-inject-h": { + "version": "1.2.2", + "resolved": "https://registry.npm.taobao.org/@vue/babel-sugar-inject-h/download/@vue/babel-sugar-inject-h-1.2.2.tgz?cache=0&sync_timestamp=1602929625678&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40vue%2Fbabel-sugar-inject-h%2Fdownload%2F%40vue%2Fbabel-sugar-inject-h-1.2.2.tgz", + "integrity": "sha1-1zjTyJM2fshJHcu2abAAkZKT46o=", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0" + } + }, + "@vue/babel-sugar-v-model": { + "version": "1.2.3", + "resolved": "https://registry.npm.taobao.org/@vue/babel-sugar-v-model/download/@vue/babel-sugar-v-model-1.2.3.tgz", + "integrity": "sha1-+h8pulHr8KoabDX6ZtU5vEWaGPI=", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-helper-vue-jsx-merge-props": "^1.2.1", + "@vue/babel-plugin-transform-vue-jsx": "^1.2.1", + "camelcase": "^5.0.0", + "html-tags": "^2.0.0", + "svg-tags": "^1.0.0" + }, + "dependencies": { + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.nlark.com/camelcase/download/camelcase-5.3.1.tgz", + "integrity": "sha1-48mzFWnhBoEd8kL3FXJaH0xJQyA=", + "dev": true + }, + "html-tags": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/html-tags/download/html-tags-2.0.0.tgz", + "integrity": "sha1-ELMKOGCF9Dzt41PMj6fLDe7qZos=", + "dev": true + } + } + }, + "@vue/babel-sugar-v-on": { + "version": "1.2.3", + "resolved": "https://registry.npm.taobao.org/@vue/babel-sugar-v-on/download/@vue/babel-sugar-v-on-1.2.3.tgz?cache=0&sync_timestamp=1603181880042&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40vue%2Fbabel-sugar-v-on%2Fdownload%2F%40vue%2Fbabel-sugar-v-on-1.2.3.tgz", + "integrity": "sha1-NCNnF4WGpp85LwS/ujICHQKROto=", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-plugin-transform-vue-jsx": "^1.2.1", + "camelcase": "^5.0.0" + }, + "dependencies": { + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.nlark.com/camelcase/download/camelcase-5.3.1.tgz", + "integrity": "sha1-48mzFWnhBoEd8kL3FXJaH0xJQyA=", + "dev": true + } + } + }, + "@vue/cli-overlay": { + "version": "4.5.13", + "resolved": "https://registry.nlark.com/@vue/cli-overlay/download/@vue/cli-overlay-4.5.13.tgz", + "integrity": "sha1-Tx/SFhvo9p1suoB58/DX3E3uR6c=", + "dev": true + }, + "@vue/cli-plugin-babel": { + "version": "4.5.13", + "resolved": "https://registry.nlark.com/@vue/cli-plugin-babel/download/@vue/cli-plugin-babel-4.5.13.tgz", + "integrity": "sha1-qJxILtzE6h0TVkXOxQKn9f1MMOc=", + "dev": true, + "requires": { + "@babel/core": "^7.11.0", + "@vue/babel-preset-app": "^4.5.13", + "@vue/cli-shared-utils": "^4.5.13", + "babel-loader": "^8.1.0", + "cache-loader": "^4.1.0", + "thread-loader": "^2.1.3", + "webpack": "^4.0.0" + } + }, + "@vue/cli-plugin-eslint": { + "version": "4.5.13", + "resolved": "https://registry.nlark.com/@vue/cli-plugin-eslint/download/@vue/cli-plugin-eslint-4.5.13.tgz", + "integrity": "sha1-i68i0NltdnIMdQZka5b09iwFvfo=", + "dev": true, + "requires": { + "@vue/cli-shared-utils": "^4.5.13", + "eslint-loader": "^2.2.1", + "globby": "^9.2.0", + "inquirer": "^7.1.0", + "webpack": "^4.0.0", + "yorkie": "^2.0.0" + } + }, + "@vue/cli-plugin-router": { + "version": "4.5.19", + "resolved": "https://registry.npmmirror.com/@vue/cli-plugin-router/-/cli-plugin-router-4.5.19.tgz", + "integrity": "sha512-3icGzH1IbVYmMMsOwYa0lal/gtvZLebFXdE5hcQJo2mnTwngXGMTyYAzL56EgHBPjbMmRpyj6Iw9k4aVInVX6A==", + "dev": true, + "requires": { + "@vue/cli-shared-utils": "^4.5.19" + } + }, + "@vue/cli-plugin-unit-mocha": { + "version": "4.5.13", + "resolved": "https://registry.nlark.com/@vue/cli-plugin-unit-mocha/download/@vue/cli-plugin-unit-mocha-4.5.13.tgz?cache=0&sync_timestamp=1623216922909&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40vue%2Fcli-plugin-unit-mocha%2Fdownload%2F%40vue%2Fcli-plugin-unit-mocha-4.5.13.tgz", + "integrity": "sha1-GBCMawtx7psyvs+/dk9cvk112tY=", + "dev": true, + "requires": { + "@vue/cli-shared-utils": "^4.5.13", + "jsdom": "^15.2.1", + "jsdom-global": "^3.0.2", + "mocha": "^6.2.2", + "mochapack": "^1.1.15" + } + }, + "@vue/cli-plugin-vuex": { + "version": "4.5.19", + "resolved": "https://registry.npmmirror.com/@vue/cli-plugin-vuex/-/cli-plugin-vuex-4.5.19.tgz", + "integrity": "sha512-DUmfdkG3pCdkP7Iznd87RfE9Qm42mgp2hcrNcYQYSru1W1gX2dG/JcW8bxmeGSa06lsxi9LEIc/QD1yPajSCZw==", + "dev": true + }, + "@vue/cli-service": { + "version": "4.5.13", + "resolved": "https://registry.nlark.com/@vue/cli-service/download/@vue/cli-service-4.5.13.tgz", + "integrity": "sha1-oJ5oSoAWhLbiTlQUrTBlCXDuye0=", + "dev": true, + "requires": { + "@intervolga/optimize-cssnano-plugin": "^1.0.5", + "@soda/friendly-errors-webpack-plugin": "^1.7.1", + "@soda/get-current-script": "^1.0.0", + "@types/minimist": "^1.2.0", + "@types/webpack": "^4.0.0", + "@types/webpack-dev-server": "^3.11.0", + "@vue/cli-overlay": "^4.5.13", + "@vue/cli-plugin-router": "^4.5.13", + "@vue/cli-plugin-vuex": "^4.5.13", + "@vue/cli-shared-utils": "^4.5.13", + "@vue/component-compiler-utils": "^3.1.2", + "@vue/preload-webpack-plugin": "^1.1.0", + "@vue/web-component-wrapper": "^1.2.0", + "acorn": "^7.4.0", + "acorn-walk": "^7.1.1", + "address": "^1.1.2", + "autoprefixer": "^9.8.6", + "browserslist": "^4.12.0", + "cache-loader": "^4.1.0", + "case-sensitive-paths-webpack-plugin": "^2.3.0", + "cli-highlight": "^2.1.4", + "clipboardy": "^2.3.0", + "cliui": "^6.0.0", + "copy-webpack-plugin": "^5.1.1", + "css-loader": "^3.5.3", + "cssnano": "^4.1.10", + "debug": "^4.1.1", + "default-gateway": "^5.0.5", + "dotenv": "^8.2.0", + "dotenv-expand": "^5.1.0", + "file-loader": "^4.2.0", + "fs-extra": "^7.0.1", + "globby": "^9.2.0", + "hash-sum": "^2.0.0", + "html-webpack-plugin": "^3.2.0", + "launch-editor-middleware": "^2.2.1", + "lodash.defaultsdeep": "^4.6.1", + "lodash.mapvalues": "^4.6.0", + "lodash.transform": "^4.6.0", + "mini-css-extract-plugin": "^0.9.0", + "minimist": "^1.2.5", + "pnp-webpack-plugin": "^1.6.4", + "portfinder": "^1.0.26", + "postcss-loader": "^3.0.0", + "ssri": "^8.0.1", + "terser-webpack-plugin": "^1.4.4", + "thread-loader": "^2.1.3", + "url-loader": "^2.2.0", + "vue-loader": "^15.9.2", + "vue-loader-v16": "npm:vue-loader@^16.1.0", + "vue-style-loader": "^4.1.2", + "webpack": "^4.0.0", + "webpack-bundle-analyzer": "^3.8.0", + "webpack-chain": "^6.4.0", + "webpack-dev-server": "^3.11.0", + "webpack-merge": "^4.2.2" + }, + "dependencies": { + "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, + "optional": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "optional": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "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, + "optional": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "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, + "optional": true + }, + "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, + "optional": true + }, + "loader-utils": { + "version": "2.0.4", + "resolved": "https://registry.npmmirror.com/loader-utils/-/loader-utils-2.0.4.tgz", + "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==", + "dev": true, + "optional": true, + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^2.1.2" + } + }, + "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, + "optional": true, + "requires": { + "has-flag": "^4.0.0" + } + }, + "vue-loader-v16": { + "version": "npm:vue-loader@16.8.3", + "resolved": "https://registry.npmmirror.com/vue-loader/-/vue-loader-16.8.3.tgz", + "integrity": "sha512-7vKN45IxsKxe5GcVCbc2qFU5aWzyiLrYJyUuMz4BQLKctCj/fmCa0w6fGiiQ2cLFetNcek1ppGJQDCup0c1hpA==", + "dev": true, + "optional": true, + "requires": { + "chalk": "^4.1.0", + "hash-sum": "^2.0.0", + "loader-utils": "^2.0.0" + } + } + } + }, + "@vue/cli-shared-utils": { + "version": "4.5.19", + "resolved": "https://registry.npmmirror.com/@vue/cli-shared-utils/-/cli-shared-utils-4.5.19.tgz", + "integrity": "sha512-JYpdsrC/d9elerKxbEUtmSSU6QRM60rirVubOewECHkBHj+tLNznWq/EhCjswywtePyLaMUK25eTqnTSZlEE+g==", + "dev": true, + "requires": { + "@achrinza/node-ipc": "9.2.2", + "@hapi/joi": "^15.0.1", + "chalk": "^2.4.2", + "execa": "^1.0.0", + "launch-editor": "^2.2.1", + "lru-cache": "^5.1.1", + "open": "^6.3.0", + "ora": "^3.4.0", + "read-pkg": "^5.1.1", + "request": "^2.88.2", + "semver": "^6.1.0", + "strip-ansi": "^6.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-5.0.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-5.0.0.tgz", + "integrity": "sha1-OIU59VF5vzkznIGvMKZU1p+Hy3U=", + "dev": true + }, + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-6.0.0.tgz", + "integrity": "sha1-CxVx3XZpzNTz4G4U7x7tJiJa5TI=", + "dev": true, + "requires": { + "ansi-regex": "^5.0.0" + } + } + } + }, + "@vue/compiler-core": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.37.tgz", + "integrity": "sha512-81KhEjo7YAOh0vQJoSmAD68wLfYqJvoiD4ulyedzF+OEk/bk6/hx3fTNVfuzugIIaTrOx4PGx6pAiBRe5e9Zmg==", + "requires": { + "@babel/parser": "^7.16.4", + "@vue/shared": "3.2.37", + "estree-walker": "^2.0.2", + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=" + } + } + }, + "@vue/compiler-dom": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.37.tgz", + "integrity": "sha512-yxJLH167fucHKxaqXpYk7x8z7mMEnXOw3G2q62FTkmsvNxu4FQSu5+3UMb+L7fjKa26DEzhrmCxAgFLLIzVfqQ==", + "requires": { + "@vue/compiler-core": "3.2.37", + "@vue/shared": "3.2.37" + } + }, + "@vue/compiler-sfc": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.37.tgz", + "integrity": "sha512-+7i/2+9LYlpqDv+KTtWhOZH+pa8/HnX/905MdVmAcI/mPQOBwkHHIzrsEsucyOIZQYMkXUiTkmZq5am/NyXKkg==", + "requires": { + "@babel/parser": "^7.16.4", + "@vue/compiler-core": "3.2.37", + "@vue/compiler-dom": "3.2.37", + "@vue/compiler-ssr": "3.2.37", + "@vue/reactivity-transform": "3.2.37", + "@vue/shared": "3.2.37", + "estree-walker": "^2.0.2", + "magic-string": "^0.25.7", + "postcss": "^8.1.10", + "source-map": "^0.6.1" + }, + "dependencies": { + "postcss": { + "version": "8.3.5", + "resolved": "https://registry.nlark.com/postcss/download/postcss-8.3.5.tgz", + "integrity": "sha1-mCIWsRNBK8IKhiiekeuZSVKltwk=", + "requires": { + "colorette": "^1.2.2", + "nanoid": "^3.1.23", + "source-map-js": "^0.6.2" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=" + } + } + }, + "@vue/compiler-ssr": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.37.tgz", + "integrity": "sha512-7mQJD7HdXxQjktmsWp/J67lThEIcxLemz1Vb5I6rYJHR5vI+lON3nPGOH3ubmbvYGt8xEUaAr1j7/tIFWiEOqw==", + "requires": { + "@vue/compiler-dom": "3.2.37", + "@vue/shared": "3.2.37" + } + }, + "@vue/component-compiler-utils": { + "version": "3.2.2", + "resolved": "https://registry.nlark.com/@vue/component-compiler-utils/download/@vue/component-compiler-utils-3.2.2.tgz", + "integrity": "sha1-L37V/u2C/38ChKzBHVJe5+/yJGA=", + "dev": true, + "requires": { + "consolidate": "^0.15.1", + "hash-sum": "^1.0.2", + "lru-cache": "^4.1.2", + "merge-source-map": "^1.1.0", + "postcss": "^7.0.36", + "postcss-selector-parser": "^6.0.2", + "prettier": "^1.18.2", + "source-map": "~0.6.1", + "vue-template-es2015-compiler": "^1.9.0" + }, + "dependencies": { + "hash-sum": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/hash-sum/download/hash-sum-1.0.2.tgz", + "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=", + "dev": true + }, + "lru-cache": { + "version": "4.1.5", + "resolved": "https://registry.nlark.com/lru-cache/download/lru-cache-4.1.5.tgz", + "integrity": "sha1-i75Q6oW+1ZvJ4z3KuCNe6bz0Q80=", + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.nlark.com/yallist/download/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + } + } + }, + "@vue/devtools-api": { + "version": "6.0.0-beta.15", + "resolved": "https://registry.nlark.com/@vue/devtools-api/download/@vue/devtools-api-6.0.0-beta.15.tgz?cache=0&sync_timestamp=1624900514906&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40vue%2Fdevtools-api%2Fdownload%2F%40vue%2Fdevtools-api-6.0.0-beta.15.tgz", + "integrity": "sha1-rXyzhOBi8WW8+cg3MhJb/7wq2D0=" + }, + "@vue/preload-webpack-plugin": { + "version": "1.1.2", + "resolved": "https://registry.nlark.com/@vue/preload-webpack-plugin/download/@vue/preload-webpack-plugin-1.1.2.tgz", + "integrity": "sha1-zrkktOyzucQ4ccekKaAvhCPmIas=", + "dev": true + }, + "@vue/reactivity": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.2.37.tgz", + "integrity": "sha512-/7WRafBOshOc6m3F7plwzPeCu/RCVv9uMpOwa/5PiY1Zz+WLVRWiy0MYKwmg19KBdGtFWsmZ4cD+LOdVPcs52A==", + "requires": { + "@vue/shared": "3.2.37" + } + }, + "@vue/reactivity-transform": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.2.37.tgz", + "integrity": "sha512-IWopkKEb+8qpu/1eMKVeXrK0NLw9HicGviJzhJDEyfxTR9e1WtpnnbYkJWurX6WwoFP0sz10xQg8yL8lgskAZg==", + "requires": { + "@babel/parser": "^7.16.4", + "@vue/compiler-core": "3.2.37", + "@vue/shared": "3.2.37", + "estree-walker": "^2.0.2", + "magic-string": "^0.25.7" + } + }, + "@vue/runtime-core": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.2.37.tgz", + "integrity": "sha512-JPcd9kFyEdXLl/i0ClS7lwgcs0QpUAWj+SKX2ZC3ANKi1U4DOtiEr6cRqFXsPwY5u1L9fAjkinIdB8Rz3FoYNQ==", + "requires": { + "@vue/reactivity": "3.2.37", + "@vue/shared": "3.2.37" + } + }, + "@vue/runtime-dom": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.2.37.tgz", + "integrity": "sha512-HimKdh9BepShW6YozwRKAYjYQWg9mQn63RGEiSswMbW+ssIht1MILYlVGkAGGQbkhSh31PCdoUcfiu4apXJoPw==", + "requires": { + "@vue/runtime-core": "3.2.37", + "@vue/shared": "3.2.37", + "csstype": "^2.6.8" + } + }, + "@vue/server-renderer": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.2.37.tgz", + "integrity": "sha512-kLITEJvaYgZQ2h47hIzPh2K3jG8c1zCVbp/o/bzQOyvzaKiCquKS7AaioPI28GNxIsE/zSx+EwWYsNxDCX95MA==", + "requires": { + "@vue/compiler-ssr": "3.2.37", + "@vue/shared": "3.2.37" + } + }, + "@vue/shared": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/@vue/shared/-/shared-3.2.37.tgz", + "integrity": "sha512-4rSJemR2NQIo9Klm1vabqWjD8rs/ZaJSzMxkMNeJS6lHiUjjUeYFbooN19NgFjztubEKh3WlZUeOLVdbbUWHsw==" + }, + "@vue/test-utils": { + "version": "2.0.0-rc.10", + "resolved": "https://registry.nlark.com/@vue/test-utils/download/@vue/test-utils-2.0.0-rc.10.tgz", + "integrity": "sha1-ntaJzX1aHJ72aTgGAQ5GTS7ME7I=", + "dev": true + }, + "@vue/web-component-wrapper": { + "version": "1.3.0", + "resolved": "https://registry.npm.taobao.org/@vue/web-component-wrapper/download/@vue/web-component-wrapper-1.3.0.tgz?cache=0&sync_timestamp=1613216912643&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40vue%2Fweb-component-wrapper%2Fdownload%2F%40vue%2Fweb-component-wrapper-1.3.0.tgz", + "integrity": "sha1-trQKdiVCnSvXwigd26YB7QXcfxo=", + "dev": true + }, + "@vueuse/core": { + "version": "9.1.0", + "resolved": "https://registry.npmmirror.com/@vueuse/core/-/core-9.1.0.tgz", + "integrity": "sha512-BIroqvXEqt826aE9r3K5cox1zobuPuAzdYJ36kouC2TVhlXvFKIILgFVWrpp9HZPwB3aLzasmG3K87q7TSyXZg==", + "requires": { + "@types/web-bluetooth": "^0.0.15", + "@vueuse/metadata": "9.1.0", + "@vueuse/shared": "9.1.0", + "vue-demi": "*" + }, + "dependencies": { + "vue-demi": { + "version": "0.13.8", + "resolved": "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.13.8.tgz", + "integrity": "sha512-Vy1zbZhCOdsmvGR6tJhAvO5vhP7eiS8xkbYQSoVa7o6KlIy3W8Rc53ED4qI4qpeRDjv3mLfXSEpYU6Yq4pgXRg==" + } + } + }, + "@vueuse/metadata": { + "version": "9.1.0", + "resolved": "https://registry.npmmirror.com/@vueuse/metadata/-/metadata-9.1.0.tgz", + "integrity": "sha512-8OEhlog1iaAGTD3LICZ8oBGQdYeMwByvXetOtAOZCJOzyCRSwqwdggTsmVZZ1rkgYIEqgUBk942AsAPwM21s6A==" + }, + "@vueuse/shared": { + "version": "9.1.0", + "resolved": "https://registry.npmmirror.com/@vueuse/shared/-/shared-9.1.0.tgz", + "integrity": "sha512-pB/3njQu4tfJJ78ajELNda0yMG6lKfpToQW7Soe09CprF1k3QuyoNi1tBNvo75wBDJWD+LOnr+c4B5HZ39jY/Q==", + "requires": { + "vue-demi": "*" + }, + "dependencies": { + "vue-demi": { + "version": "0.13.8", + "resolved": "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.13.8.tgz", + "integrity": "sha512-Vy1zbZhCOdsmvGR6tJhAvO5vhP7eiS8xkbYQSoVa7o6KlIy3W8Rc53ED4qI4qpeRDjv3mLfXSEpYU6Yq4pgXRg==" + } + } + }, + "@webassemblyjs/ast": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/ast/download/@webassemblyjs/ast-1.9.0.tgz?cache=0&sync_timestamp=1625473466238&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fast%2Fdownload%2F%40webassemblyjs%2Fast-1.9.0.tgz", + "integrity": "sha1-vYUGBLQEJFmlpBzX0zjL7Wle2WQ=", + "dev": true, + "requires": { + "@webassemblyjs/helper-module-context": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/wast-parser": "1.9.0" + } + }, + "@webassemblyjs/floating-point-hex-parser": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/floating-point-hex-parser/download/@webassemblyjs/floating-point-hex-parser-1.9.0.tgz?cache=0&sync_timestamp=1625473463638&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Ffloating-point-hex-parser%2Fdownload%2F%40webassemblyjs%2Ffloating-point-hex-parser-1.9.0.tgz", + "integrity": "sha1-PD07Jxvd/ITesA9xNEQ4MR1S/7Q=", + "dev": true + }, + "@webassemblyjs/helper-api-error": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/helper-api-error/download/@webassemblyjs/helper-api-error-1.9.0.tgz?cache=0&sync_timestamp=1625473346773&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fhelper-api-error%2Fdownload%2F%40webassemblyjs%2Fhelper-api-error-1.9.0.tgz", + "integrity": "sha1-ID9nbjM7lsnaLuqzzO8zxFkotqI=", + "dev": true + }, + "@webassemblyjs/helper-buffer": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/helper-buffer/download/@webassemblyjs/helper-buffer-1.9.0.tgz?cache=0&sync_timestamp=1625473462686&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fhelper-buffer%2Fdownload%2F%40webassemblyjs%2Fhelper-buffer-1.9.0.tgz", + "integrity": "sha1-oUQtJpxf6yP8vJ73WdrDVH8p3gA=", + "dev": true + }, + "@webassemblyjs/helper-code-frame": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/helper-code-frame/download/@webassemblyjs/helper-code-frame-1.9.0.tgz", + "integrity": "sha1-ZH+Iks0gQ6gqwMjF51w28dkVnyc=", + "dev": true, + "requires": { + "@webassemblyjs/wast-printer": "1.9.0" + } + }, + "@webassemblyjs/helper-fsm": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/helper-fsm/download/@webassemblyjs/helper-fsm-1.9.0.tgz", + "integrity": "sha1-wFJWtxJEIUZx9LCOwQitY7cO3bg=", + "dev": true + }, + "@webassemblyjs/helper-module-context": { + "version": "1.9.0", + "resolved": "https://registry.npm.taobao.org/@webassemblyjs/helper-module-context/download/@webassemblyjs/helper-module-context-1.9.0.tgz", + "integrity": "sha1-JdiIS3aDmHGgimxvgGw5ee9xLwc=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0" + } + }, + "@webassemblyjs/helper-wasm-bytecode": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/helper-wasm-bytecode/download/@webassemblyjs/helper-wasm-bytecode-1.9.0.tgz", + "integrity": "sha1-T+2L6sm4wU+MWLcNEk1UndH+V5A=", + "dev": true + }, + "@webassemblyjs/helper-wasm-section": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/helper-wasm-section/download/@webassemblyjs/helper-wasm-section-1.9.0.tgz?cache=0&sync_timestamp=1625473466570&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fhelper-wasm-section%2Fdownload%2F%40webassemblyjs%2Fhelper-wasm-section-1.9.0.tgz", + "integrity": "sha1-WkE41aYpK6GLBMWuSXF+QWeWU0Y=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0" + } + }, + "@webassemblyjs/ieee754": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/ieee754/download/@webassemblyjs/ieee754-1.9.0.tgz?cache=0&sync_timestamp=1625473461909&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fieee754%2Fdownload%2F%40webassemblyjs%2Fieee754-1.9.0.tgz", + "integrity": "sha1-Fceg+6roP7JhQ7us9tbfFwKtOeQ=", + "dev": true, + "requires": { + "@xtuc/ieee754": "^1.2.0" + } + }, + "@webassemblyjs/leb128": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/leb128/download/@webassemblyjs/leb128-1.9.0.tgz?cache=0&sync_timestamp=1625473463971&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fleb128%2Fdownload%2F%40webassemblyjs%2Fleb128-1.9.0.tgz", + "integrity": "sha1-8Zygt2ptxVYjoJz/p2noOPoeHJU=", + "dev": true, + "requires": { + "@xtuc/long": "4.2.2" + } + }, + "@webassemblyjs/utf8": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/utf8/download/@webassemblyjs/utf8-1.9.0.tgz?cache=0&sync_timestamp=1625473462317&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Futf8%2Fdownload%2F%40webassemblyjs%2Futf8-1.9.0.tgz", + "integrity": "sha1-BNM7Y2945qaBMifoJAL3Y3tiKas=", + "dev": true + }, + "@webassemblyjs/wasm-edit": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/wasm-edit/download/@webassemblyjs/wasm-edit-1.9.0.tgz?cache=0&sync_timestamp=1625473468202&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwasm-edit%2Fdownload%2F%40webassemblyjs%2Fwasm-edit-1.9.0.tgz", + "integrity": "sha1-P+bXnT8PkiGDqoYALELdJWz+6c8=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/helper-wasm-section": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0", + "@webassemblyjs/wasm-opt": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0", + "@webassemblyjs/wast-printer": "1.9.0" + } + }, + "@webassemblyjs/wasm-gen": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/wasm-gen/download/@webassemblyjs/wasm-gen-1.9.0.tgz?cache=0&sync_timestamp=1625473464969&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwasm-gen%2Fdownload%2F%40webassemblyjs%2Fwasm-gen-1.9.0.tgz", + "integrity": "sha1-ULxw7Gje2OJ2OwGhQYv0NJGnpJw=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/ieee754": "1.9.0", + "@webassemblyjs/leb128": "1.9.0", + "@webassemblyjs/utf8": "1.9.0" + } + }, + "@webassemblyjs/wasm-opt": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/wasm-opt/download/@webassemblyjs/wasm-opt-1.9.0.tgz?cache=0&sync_timestamp=1625473467198&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwasm-opt%2Fdownload%2F%40webassemblyjs%2Fwasm-opt-1.9.0.tgz", + "integrity": "sha1-IhEYHlsxMmRDzIES658LkChyGmE=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0" + } + }, + "@webassemblyjs/wasm-parser": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/wasm-parser/download/@webassemblyjs/wasm-parser-1.9.0.tgz?cache=0&sync_timestamp=1625473464593&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwasm-parser%2Fdownload%2F%40webassemblyjs%2Fwasm-parser-1.9.0.tgz", + "integrity": "sha1-nUjkSCbfSmWYKUqmyHRp1kL/9l4=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-api-error": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/ieee754": "1.9.0", + "@webassemblyjs/leb128": "1.9.0", + "@webassemblyjs/utf8": "1.9.0" + } + }, + "@webassemblyjs/wast-parser": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/wast-parser/download/@webassemblyjs/wast-parser-1.9.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwast-parser%2Fdownload%2F%40webassemblyjs%2Fwast-parser-1.9.0.tgz", + "integrity": "sha1-MDERXXmsW9JhVWzsw/qQo+9FGRQ=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/floating-point-hex-parser": "1.9.0", + "@webassemblyjs/helper-api-error": "1.9.0", + "@webassemblyjs/helper-code-frame": "1.9.0", + "@webassemblyjs/helper-fsm": "1.9.0", + "@xtuc/long": "4.2.2" + } + }, + "@webassemblyjs/wast-printer": { + "version": "1.9.0", + "resolved": "https://registry.nlark.com/@webassemblyjs/wast-printer/download/@webassemblyjs/wast-printer-1.9.0.tgz?cache=0&sync_timestamp=1625473465901&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwast-printer%2Fdownload%2F%40webassemblyjs%2Fwast-printer-1.9.0.tgz", + "integrity": "sha1-STXVTIX+9jewDOn1I3dFHQDUeJk=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/wast-parser": "1.9.0", + "@xtuc/long": "4.2.2" + } + }, + "@xtuc/ieee754": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/@xtuc/ieee754/download/@xtuc/ieee754-1.2.0.tgz", + "integrity": "sha1-7vAUoxRa5Hehy8AM0eVSM23Ot5A=", + "dev": true + }, + "@xtuc/long": { + "version": "4.2.2", + "resolved": "https://registry.npm.taobao.org/@xtuc/long/download/@xtuc/long-4.2.2.tgz", + "integrity": "sha1-0pHGpOl5ibXGHZrPOWrk/hM6cY0=", + "dev": true + }, + "abab": { + "version": "2.0.5", + "resolved": "https://registry.npm.taobao.org/abab/download/abab-2.0.5.tgz", + "integrity": "sha1-wLZ4+zLWD8EhnHhNaoJv44Wut5o=", + "dev": true + }, + "abort-controller": { + "version": "3.0.0", + "resolved": "https://registry.npmmirror.com/abort-controller/-/abort-controller-3.0.0.tgz", + "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", + "requires": { + "event-target-shim": "^5.0.0" + } + }, + "accepts": { + "version": "1.3.7", + "resolved": "https://registry.npm.taobao.org/accepts/download/accepts-1.3.7.tgz", + "integrity": "sha1-UxvHJlF6OytB+FACHGzBXqq1B80=", + "dev": true, + "requires": { + "mime-types": "~2.1.24", + "negotiator": "0.6.2" + } + }, + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.nlark.com/acorn/download/acorn-7.4.1.tgz?cache=0&sync_timestamp=1624526907659&other_urls=https%3A%2F%2Fregistry.nlark.com%2Facorn%2Fdownload%2Facorn-7.4.1.tgz", + "integrity": "sha1-/q7SVZc9LndVW4PbwIhRpsY1IPo=", + "dev": true + }, + "acorn-globals": { + "version": "4.3.4", + "resolved": "https://registry.npm.taobao.org/acorn-globals/download/acorn-globals-4.3.4.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Facorn-globals%2Fdownload%2Facorn-globals-4.3.4.tgz", + "integrity": "sha1-n6GSat3BHJcwjE5m163Q1Awycuc=", + "dev": true, + "requires": { + "acorn": "^6.0.1", + "acorn-walk": "^6.0.1" + }, + "dependencies": { + "acorn": { + "version": "6.4.2", + "resolved": "https://registry.nlark.com/acorn/download/acorn-6.4.2.tgz?cache=0&sync_timestamp=1624526907659&other_urls=https%3A%2F%2Fregistry.nlark.com%2Facorn%2Fdownload%2Facorn-6.4.2.tgz", + "integrity": "sha1-NYZv1xBSjpLeEM8GAWSY5H454eY=", + "dev": true + }, + "acorn-walk": { + "version": "6.2.0", + "resolved": "https://registry.nlark.com/acorn-walk/download/acorn-walk-6.2.0.tgz", + "integrity": "sha1-Ejy487hMIXHx9/slJhWxx4prGow=", + "dev": true + } + } + }, + "acorn-walk": { + "version": "7.2.0", + "resolved": "https://registry.nlark.com/acorn-walk/download/acorn-walk-7.2.0.tgz", + "integrity": "sha1-DeiJpgEgOQmw++B7iTjcIdLpZ7w=", + "dev": true + }, + "address": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/address/download/address-1.1.2.tgz", + "integrity": "sha1-vxEWycdYxRt6kz0pa3LCIe2UKLY=" + }, + "agent-base": { + "version": "6.0.2", + "resolved": "https://registry.npmmirror.com/agent-base/-/agent-base-6.0.2.tgz", + "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "requires": { + "debug": "4" + } + }, + "agentkeepalive": { + "version": "3.5.2", + "resolved": "https://registry.npmmirror.com/agentkeepalive/-/agentkeepalive-3.5.2.tgz", + "integrity": "sha512-e0L/HNe6qkQ7H19kTlRRqUibEAwDK5AFk6y3PtMsuut2VAH6+Q4xZml1tNDJD7kSAyqmbG/K08K5WEJYtUrSlQ==", + "requires": { + "humanize-ms": "^1.2.1" + } + }, + "ajv": { + "version": "6.12.6", + "resolved": "https://registry.nlark.com/ajv/download/ajv-6.12.6.tgz", + "integrity": "sha1-uvWmLoArB9l3A0WG+MO69a3ybfQ=", + "dev": true, + "requires": { + "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-errors": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/ajv-errors/download/ajv-errors-1.0.1.tgz", + "integrity": "sha1-81mGrOuRr63sQQL72FAUlQzvpk0=", + "dev": true + }, + "ajv-keywords": { + "version": "3.5.2", + "resolved": "https://registry.npm.taobao.org/ajv-keywords/download/ajv-keywords-3.5.2.tgz?cache=0&sync_timestamp=1616882441894&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fajv-keywords%2Fdownload%2Fajv-keywords-3.5.2.tgz", + "integrity": "sha1-MfKdpatuANHC0yms97WSlhTVAU0=", + "dev": true + }, + "ali-oss": { + "version": "6.17.1", + "resolved": "https://registry.npmmirror.com/ali-oss/-/ali-oss-6.17.1.tgz", + "integrity": "sha512-v2oT3UhSJTH/LrsscVvi7iEGrnundydNaFzpYAKatqOl4JNcBV4UiwtlJU+ZHLys040JH2k+CutznA0GoE+P2w==", + "requires": { + "address": "^1.0.0", + "agentkeepalive": "^3.4.1", + "bowser": "^1.6.0", + "copy-to": "^2.0.1", + "dateformat": "^2.0.0", + "debug": "^2.2.0", + "destroy": "^1.0.4", + "end-or-error": "^1.0.1", + "get-ready": "^1.0.0", + "humanize-ms": "^1.2.0", + "is-type-of": "^1.0.0", + "js-base64": "^2.5.2", + "jstoxml": "^2.0.0", + "merge-descriptors": "^1.0.1", + "mime": "^2.4.5", + "mz-modules": "^2.1.0", + "platform": "^1.3.1", + "pump": "^3.0.0", + "sdk-base": "^2.0.1", + "stream-http": "2.8.2", + "stream-wormhole": "^1.0.4", + "urllib": "^2.33.1", + "utility": "^1.8.0", + "xml2js": "^0.4.16" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" + } + } + }, + "alphanum-sort": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/alphanum-sort/download/alphanum-sort-1.0.2.tgz", + "integrity": "sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM=", + "dev": true + }, + "ansi-colors": { + "version": "3.2.3", + "resolved": "https://registry.npm.taobao.org/ansi-colors/download/ansi-colors-3.2.3.tgz", + "integrity": "sha1-V9NbhoboUeLMBMQD8cACA5dqGBM=", + "dev": true + }, + "ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.nlark.com/ansi-escapes/download/ansi-escapes-4.3.2.tgz?cache=0&sync_timestamp=1618847144938&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-escapes%2Fdownload%2Fansi-escapes-4.3.2.tgz", + "integrity": "sha1-ayKR0dt9mLZSHV8e+kLQ86n+tl4=", + "dev": true, + "requires": { + "type-fest": "^0.21.3" + } + }, + "ansi-html": { + "version": "0.0.7", + "resolved": "https://registry.nlark.com/ansi-html/download/ansi-html-0.0.7.tgz?cache=0&sync_timestamp=1618846919541&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-html%2Fdownload%2Fansi-html-0.0.7.tgz", + "integrity": "sha1-gTWEAhliqenm/QOflA0S9WynhZ4=", + "dev": true + }, + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-4.1.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-4.1.0.tgz", + "integrity": "sha1-i5+PCM8ay4Q3Vqg5yox+MWjFGZc=", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.nlark.com/ansi-styles/download/ansi-styles-3.2.1.tgz?cache=0&sync_timestamp=1618995547052&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-styles%2Fdownload%2Fansi-styles-3.2.1.tgz", + "integrity": "sha1-QfuyAkPlCxK+DwS43tvwdSDOhB0=", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "any-promise": { + "version": "1.3.0", + "resolved": "https://registry.npm.taobao.org/any-promise/download/any-promise-1.3.0.tgz", + "integrity": "sha1-q8av7tzqUugJzcA3au0845Y10X8=" + }, + "anymatch": { + "version": "3.1.2", + "resolved": "https://registry.npm.taobao.org/anymatch/download/anymatch-3.1.2.tgz?cache=0&sync_timestamp=1617747806715&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fanymatch%2Fdownload%2Fanymatch-3.1.2.tgz", + "integrity": "sha1-wFV8CWrzLxBhmPT04qODU343hxY=", + "dev": true, + "requires": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + } + }, + "aproba": { + "version": "1.2.0", + "resolved": "https://registry.nlark.com/aproba/download/aproba-1.2.0.tgz", + "integrity": "sha1-aALmJk79GMeQobDVF/DyYnvyyUo=", + "dev": true + }, + "arch": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/arch/download/arch-2.2.0.tgz", + "integrity": "sha1-G8R4GPMFdk8jqzMGsL/AhsWinRE=", + "dev": true + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npm.taobao.org/argparse/download/argparse-1.0.10.tgz", + "integrity": "sha1-vNZ5HqWuCXJeF+WtmIE0zUCz2RE=", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.nlark.com/arr-diff/download/arr-diff-4.0.0.tgz?cache=0&sync_timestamp=1618847029174&other_urls=https%3A%2F%2Fregistry.nlark.com%2Farr-diff%2Fdownload%2Farr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", + "dev": true + }, + "arr-flatten": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/arr-flatten/download/arr-flatten-1.1.0.tgz", + "integrity": "sha1-NgSLv/TntH4TZkQxbJlmnqWukfE=", + "dev": true + }, + "arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npm.taobao.org/arr-union/download/arr-union-3.1.0.tgz", + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", + "dev": true + }, + "array-equal": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/array-equal/download/array-equal-1.0.0.tgz", + "integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=", + "dev": true + }, + "array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/array-flatten/download/array-flatten-1.1.1.tgz", + "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=", + "dev": true + }, + "array-union": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/array-union/download/array-union-1.0.2.tgz?cache=0&sync_timestamp=1614624861176&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Farray-union%2Fdownload%2Farray-union-1.0.2.tgz", + "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", + "dev": true, + "requires": { + "array-uniq": "^1.0.1" + } + }, + "array-uniq": { + "version": "1.0.3", + "resolved": "https://registry.nlark.com/array-uniq/download/array-uniq-1.0.3.tgz", + "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", + "dev": true + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npm.taobao.org/array-unique/download/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", + "dev": true + }, + "asn1": { + "version": "0.2.4", + "resolved": "https://registry.npm.taobao.org/asn1/download/asn1-0.2.4.tgz", + "integrity": "sha1-jSR136tVO7M+d7VOWeiAu4ziMTY=", + "dev": true, + "requires": { + "safer-buffer": "~2.1.0" + } + }, + "asn1.js": { + "version": "5.4.1", + "resolved": "https://registry.npm.taobao.org/asn1.js/download/asn1.js-5.4.1.tgz", + "integrity": "sha1-EamAuE67kXgc41sP3C7ilON4Pwc=", + "dev": true, + "requires": { + "bn.js": "^4.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0", + "safer-buffer": "^2.1.0" + }, + "dependencies": { + "bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz", + "integrity": "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=", + "dev": true + } + } + }, + "assert": { + "version": "1.5.0", + "resolved": "https://registry.npm.taobao.org/assert/download/assert-1.5.0.tgz", + "integrity": "sha1-VcEJqvbgrv2z3EtxJAxwv1dLGOs=", + "dev": true, + "requires": { + "object-assign": "^4.1.1", + "util": "0.10.3" + }, + "dependencies": { + "inherits": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/inherits/download/inherits-2.0.1.tgz", + "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=", + "dev": true + }, + "util": { + "version": "0.10.3", + "resolved": "https://registry.nlark.com/util/download/util-0.10.3.tgz?cache=0&sync_timestamp=1622212943994&other_urls=https%3A%2F%2Fregistry.nlark.com%2Futil%2Fdownload%2Futil-0.10.3.tgz", + "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", + "dev": true, + "requires": { + "inherits": "2.0.1" + } + } + } + }, + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/assert-plus/download/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + }, + "assertion-error": { + "version": "1.1.0", + "resolved": "https://registry.nlark.com/assertion-error/download/assertion-error-1.1.0.tgz", + "integrity": "sha1-5gtrDo8wG9l+U3UhW9pAbIURjAs=", + "dev": true + }, + "assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/assign-symbols/download/assign-symbols-1.0.0.tgz", + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", + "dev": true + }, + "ast-types": { + "version": "0.13.4", + "resolved": "https://registry.npmmirror.com/ast-types/-/ast-types-0.13.4.tgz", + "integrity": "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==", + "requires": { + "tslib": "^2.0.1" + } + }, + "async": { + "version": "2.6.3", + "resolved": "https://registry.nlark.com/async/download/async-2.6.3.tgz", + "integrity": "sha1-1yYl4jRKNlbjo61Pp0n6gymdgv8=", + "dev": true, + "requires": { + "lodash": "^4.17.14" + } + }, + "async-each": { + "version": "1.0.3", + "resolved": "https://registry.npm.taobao.org/async-each/download/async-each-1.0.3.tgz", + "integrity": "sha1-tyfb+H12UWAvBvTUrDh/R9kbDL8=", + "dev": true + }, + "async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/async-limiter/download/async-limiter-1.0.1.tgz", + "integrity": "sha1-3TeelPDbgxCwgpH51kwyCXZmF/0=", + "dev": true + }, + "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==" + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.nlark.com/asynckit/download/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", + "dev": true + }, + "atob": { + "version": "2.1.2", + "resolved": "https://registry.npm.taobao.org/atob/download/atob-2.1.2.tgz", + "integrity": "sha1-bZUX654DDSQ2ZmZR6GvZ9vE1M8k=", + "dev": true + }, + "autoprefixer": { + "version": "9.8.6", + "resolved": "https://registry.nlark.com/autoprefixer/download/autoprefixer-9.8.6.tgz?cache=0&sync_timestamp=1626111053301&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fautoprefixer%2Fdownload%2Fautoprefixer-9.8.6.tgz", + "integrity": "sha1-O3NZTKG/kmYyDFrPFYjXTep0IQ8=", + "dev": true, + "requires": { + "browserslist": "^4.12.0", + "caniuse-lite": "^1.0.30001109", + "colorette": "^1.2.1", + "normalize-range": "^0.1.2", + "num2fraction": "^1.2.2", + "postcss": "^7.0.32", + "postcss-value-parser": "^4.1.0" + } + }, + "aws-sign2": { + "version": "0.7.0", + "resolved": "https://registry.nlark.com/aws-sign2/download/aws-sign2-0.7.0.tgz", + "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", + "dev": true + }, + "aws4": { + "version": "1.11.0", + "resolved": "https://registry.npm.taobao.org/aws4/download/aws4-1.11.0.tgz?cache=0&sync_timestamp=1604101244098&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Faws4%2Fdownload%2Faws4-1.11.0.tgz", + "integrity": "sha1-1h9G2DslGSUOJ4Ta9bCUeai0HFk=", + "dev": true + }, + "axios": { + "version": "0.21.1", + "resolved": "https://registry.nlark.com/axios/download/axios-0.21.1.tgz", + "integrity": "sha1-IlY0gZYvTWvemnbVFu8OXTwJsrg=", + "requires": { + "follow-redirects": "^1.10.0" + } + }, + "babel-eslint": { + "version": "10.1.0", + "resolved": "https://registry.nlark.com/babel-eslint/download/babel-eslint-10.1.0.tgz", + "integrity": "sha1-aWjlaKkQt4+zd5zdi2rC9HmUMjI=", + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.7.0", + "@babel/traverse": "^7.7.0", + "@babel/types": "^7.7.0", + "eslint-visitor-keys": "^1.0.0", + "resolve": "^1.12.0" + } + }, + "babel-loader": { + "version": "8.2.2", + "resolved": "https://registry.nlark.com/babel-loader/download/babel-loader-8.2.2.tgz", + "integrity": "sha1-k2POhMEMmkDmx1N0jhRBtgyKC4E=", + "dev": true, + "requires": { + "find-cache-dir": "^3.3.1", + "loader-utils": "^1.4.0", + "make-dir": "^3.1.0", + "schema-utils": "^2.6.5" + } + }, + "babel-plugin-dynamic-import-node": { + "version": "2.3.3", + "resolved": "https://registry.npm.taobao.org/babel-plugin-dynamic-import-node/download/babel-plugin-dynamic-import-node-2.3.3.tgz", + "integrity": "sha1-hP2hnJduxcbe/vV/lCez3vZuF6M=", + "dev": true, + "requires": { + "object.assign": "^4.1.0" + } + }, + "babel-plugin-polyfill-corejs2": { + "version": "0.2.2", + "resolved": "https://registry.nlark.com/babel-plugin-polyfill-corejs2/download/babel-plugin-polyfill-corejs2-0.2.2.tgz", + "integrity": "sha1-6RJHheb9lPlLYYp5VOVpMFO/Uyc=", + "dev": true, + "requires": { + "@babel/compat-data": "^7.13.11", + "@babel/helper-define-polyfill-provider": "^0.2.2", + "semver": "^6.1.1" + } + }, + "babel-plugin-polyfill-corejs3": { + "version": "0.2.3", + "resolved": "https://registry.nlark.com/babel-plugin-polyfill-corejs3/download/babel-plugin-polyfill-corejs3-0.2.3.tgz?cache=0&sync_timestamp=1623878015630&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fbabel-plugin-polyfill-corejs3%2Fdownload%2Fbabel-plugin-polyfill-corejs3-0.2.3.tgz", + "integrity": "sha1-cq3WjPCKi/E5um5t/AsdUECY5Xs=", + "dev": true, + "requires": { + "@babel/helper-define-polyfill-provider": "^0.2.2", + "core-js-compat": "^3.14.0" + } + }, + "babel-plugin-polyfill-regenerator": { + "version": "0.2.2", + "resolved": "https://registry.nlark.com/babel-plugin-polyfill-regenerator/download/babel-plugin-polyfill-regenerator-0.2.2.tgz", + "integrity": "sha1-sxDI1kKsraNIwfo7Pmzg6FG+4Hc=", + "dev": true, + "requires": { + "@babel/helper-define-polyfill-provider": "^0.2.2" + } + }, + "balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/balanced-match/download/balanced-match-1.0.2.tgz?cache=0&sync_timestamp=1617714298273&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbalanced-match%2Fdownload%2Fbalanced-match-1.0.2.tgz", + "integrity": "sha1-6D46fj8wCzTLnYf2FfoMvzV2kO4=" + }, + "base": { + "version": "0.11.2", + "resolved": "https://registry.npm.taobao.org/base/download/base-0.11.2.tgz", + "integrity": "sha1-e95c7RRbbVUakNuH+DxVi060io8=", + "dev": true, + "requires": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + } + } + }, + "base64-js": { + "version": "1.5.1", + "resolved": "https://registry.npm.taobao.org/base64-js/download/base64-js-1.5.1.tgz", + "integrity": "sha1-GxtEAWClv3rUC2UPCVljSBkDkwo=", + "dev": true + }, + "batch": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/batch/download/batch-0.6.1.tgz", + "integrity": "sha1-3DQxT05nkxgJP8dgJyUl+UvyXBY=", + "dev": true + }, + "bcrypt-pbkdf": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/bcrypt-pbkdf/download/bcrypt-pbkdf-1.0.2.tgz", + "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", + "dev": true, + "requires": { + "tweetnacl": "^0.14.3" + } + }, + "bfj": { + "version": "6.1.2", + "resolved": "https://registry.npm.taobao.org/bfj/download/bfj-6.1.2.tgz", + "integrity": "sha1-MlyGGoIryzWKQceKM7jm4ght3n8=", + "dev": true, + "requires": { + "bluebird": "^3.5.5", + "check-types": "^8.0.3", + "hoopy": "^0.1.4", + "tryer": "^1.0.1" + } + }, + "big.js": { + "version": "5.2.2", + "resolved": "https://registry.nlark.com/big.js/download/big.js-5.2.2.tgz", + "integrity": "sha1-ZfCvOC9Xi83HQr2cKB6cstd2gyg=", + "dev": true + }, + "binary-extensions": { + "version": "1.13.1", + "resolved": "https://registry.npm.taobao.org/binary-extensions/download/binary-extensions-1.13.1.tgz?cache=0&sync_timestamp=1610299322955&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbinary-extensions%2Fdownload%2Fbinary-extensions-1.13.1.tgz", + "integrity": "sha1-WYr+VHVbKGilMw0q/51Ou1Mgm2U=", + "dev": true + }, + "bindings": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", + "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", + "dev": true, + "optional": true, + "requires": { + "file-uri-to-path": "1.0.0" + } + }, + "bluebird": { + "version": "3.7.2", + "resolved": "https://registry.nlark.com/bluebird/download/bluebird-3.7.2.tgz", + "integrity": "sha1-nyKcFb4nJFT/qXOs4NvueaGww28=", + "dev": true + }, + "bn.js": { + "version": "5.2.0", + "resolved": "https://registry.npm.taobao.org/bn.js/download/bn.js-5.2.0.tgz", + "integrity": "sha1-NYhgZ0OWxpl3canQUfzBtX1K4AI=", + "dev": true + }, + "body-parser": { + "version": "1.19.0", + "resolved": "https://registry.npm.taobao.org/body-parser/download/body-parser-1.19.0.tgz", + "integrity": "sha1-lrJwnlfJxOCab9Zqj9l5hE9p8Io=", + "dev": true, + "requires": { + "bytes": "3.1.0", + "content-type": "~1.0.4", + "debug": "2.6.9", + "depd": "~1.1.2", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", + "on-finished": "~2.3.0", + "qs": "6.7.0", + "raw-body": "2.4.0", + "type-is": "~1.6.17" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.nlark.com/debug/download/debug-2.6.9.tgz", + "integrity": "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "qs": { + "version": "6.7.0", + "resolved": "https://registry.npm.taobao.org/qs/download/qs-6.7.0.tgz", + "integrity": "sha1-QdwaAV49WB8WIXdr4xr7KHapsbw=", + "dev": true + } + } + }, + "bonjour": { + "version": "3.5.0", + "resolved": "https://registry.npm.taobao.org/bonjour/download/bonjour-3.5.0.tgz", + "integrity": "sha1-jokKGD2O6aI5OzhExpGkK897yfU=", + "dev": true, + "requires": { + "array-flatten": "^2.1.0", + "deep-equal": "^1.0.1", + "dns-equal": "^1.0.0", + "dns-txt": "^2.0.2", + "multicast-dns": "^6.0.1", + "multicast-dns-service-types": "^1.1.0" + }, + "dependencies": { + "array-flatten": { + "version": "2.1.2", + "resolved": "https://registry.npm.taobao.org/array-flatten/download/array-flatten-2.1.2.tgz", + "integrity": "sha1-JO+AoowaiTYX4hSbDG0NeIKTsJk=", + "dev": true + } + } + }, + "boolbase": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/boolbase/download/boolbase-1.0.0.tgz", + "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=", + "dev": true + }, + "bowser": { + "version": "1.9.4", + "resolved": "https://registry.npmmirror.com/bowser/-/bowser-1.9.4.tgz", + "integrity": "sha512-9IdMmj2KjigRq6oWhmwv1W36pDuA4STQZ8q6YO9um+x07xgYNCD3Oou+WP/3L1HNz7iqythGet3/p4wvc8AAwQ==" + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npm.taobao.org/brace-expansion/download/brace-expansion-1.1.11.tgz", + "integrity": "sha1-PH/L9SnYcibz0vUrlm/1Jx60Qd0=", + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "2.3.2", + "resolved": "https://registry.nlark.com/braces/download/braces-2.3.2.tgz", + "integrity": "sha1-WXn9PxTNUxVl5fot8av/8d+u5yk=", + "dev": true, + "requires": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + } + } + }, + "brorand": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/brorand/download/brorand-1.1.0.tgz", + "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=", + "dev": true + }, + "browser-process-hrtime": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/browser-process-hrtime/download/browser-process-hrtime-1.0.0.tgz", + "integrity": "sha1-PJtLfXgsgSHlbxAQbYTA0P/JRiY=", + "dev": true + }, + "browser-stdout": { + "version": "1.3.1", + "resolved": "https://registry.npm.taobao.org/browser-stdout/download/browser-stdout-1.3.1.tgz", + "integrity": "sha1-uqVZ7hTO1zRSIputcyZGfGH6vWA=", + "dev": true + }, + "browserify-aes": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/browserify-aes/download/browserify-aes-1.2.0.tgz", + "integrity": "sha1-Mmc0ZC9APavDADIJhTu3CtQo70g=", + "dev": true, + "requires": { + "buffer-xor": "^1.0.3", + "cipher-base": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.3", + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "browserify-cipher": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/browserify-cipher/download/browserify-cipher-1.0.1.tgz", + "integrity": "sha1-jWR0wbhwv9q807z8wZNKEOlPFfA=", + "dev": true, + "requires": { + "browserify-aes": "^1.0.4", + "browserify-des": "^1.0.0", + "evp_bytestokey": "^1.0.0" + } + }, + "browserify-des": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/browserify-des/download/browserify-des-1.0.2.tgz", + "integrity": "sha1-OvTx9Zg5QDVy8cZiBDdfen9wPpw=", + "dev": true, + "requires": { + "cipher-base": "^1.0.1", + "des.js": "^1.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "browserify-rsa": { + "version": "4.1.0", + "resolved": "https://registry.npm.taobao.org/browserify-rsa/download/browserify-rsa-4.1.0.tgz?cache=0&sync_timestamp=1605194257215&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbrowserify-rsa%2Fdownload%2Fbrowserify-rsa-4.1.0.tgz", + "integrity": "sha1-sv0Gtbda4pf3zi3GUfkY9b4VjI0=", + "dev": true, + "requires": { + "bn.js": "^5.0.0", + "randombytes": "^2.0.1" + } + }, + "browserify-sign": { + "version": "4.2.1", + "resolved": "https://registry.nlark.com/browserify-sign/download/browserify-sign-4.2.1.tgz", + "integrity": "sha1-6vSt1G3VS+O7OzbAzxWrvrp5VsM=", + "dev": true, + "requires": { + "bn.js": "^5.1.1", + "browserify-rsa": "^4.0.1", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "elliptic": "^6.5.3", + "inherits": "^2.0.4", + "parse-asn1": "^5.1.5", + "readable-stream": "^3.6.0", + "safe-buffer": "^5.2.0" + }, + "dependencies": { + "readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.nlark.com/readable-stream/download/readable-stream-3.6.0.tgz", + "integrity": "sha1-M3u9o63AcGvT4CRCaihtS0sskZg=", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + }, + "safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npm.taobao.org/safe-buffer/download/safe-buffer-5.2.1.tgz", + "integrity": "sha1-Hq+fqb2x/dTsdfWPnNtOa3gn7sY=", + "dev": true + } + } + }, + "browserify-zlib": { + "version": "0.2.0", + "resolved": "https://registry.nlark.com/browserify-zlib/download/browserify-zlib-0.2.0.tgz", + "integrity": "sha1-KGlFnZqjviRf6P4sofRuLn9U1z8=", + "dev": true, + "requires": { + "pako": "~1.0.5" + } + }, + "browserslist": { + "version": "4.16.6", + "resolved": "https://registry.nlark.com/browserslist/download/browserslist-4.16.6.tgz?cache=0&sync_timestamp=1619789072079&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fbrowserslist%2Fdownload%2Fbrowserslist-4.16.6.tgz", + "integrity": "sha1-15ASd6WojlVO0wWxg+ybDAj2b6I=", + "dev": true, + "requires": { + "caniuse-lite": "^1.0.30001219", + "colorette": "^1.2.2", + "electron-to-chromium": "^1.3.723", + "escalade": "^3.1.1", + "node-releases": "^1.1.71" + } + }, + "buffer": { + "version": "4.9.2", + "resolved": "https://registry.nlark.com/buffer/download/buffer-4.9.2.tgz", + "integrity": "sha1-Iw6tNEACmIZEhBqwJEr4xEu+Pvg=", + "dev": true, + "requires": { + "base64-js": "^1.0.2", + "ieee754": "^1.1.4", + "isarray": "^1.0.0" + } + }, + "buffer-from": { + "version": "1.1.1", + "resolved": "https://registry.nlark.com/buffer-from/download/buffer-from-1.1.1.tgz", + "integrity": "sha1-MnE7wCj3XAL9txDXx7zsHyxgcO8=", + "dev": true + }, + "buffer-indexof": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/buffer-indexof/download/buffer-indexof-1.1.1.tgz", + "integrity": "sha1-Uvq8xqYG0aADAoAmSO9o9jnaJow=", + "dev": true + }, + "buffer-json": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/buffer-json/download/buffer-json-2.0.0.tgz", + "integrity": "sha1-9z4TseQvGW/i/WfQAcfXEH7dfCM=", + "dev": true + }, + "buffer-xor": { + "version": "1.0.3", + "resolved": "https://registry.nlark.com/buffer-xor/download/buffer-xor-1.0.3.tgz", + "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=", + "dev": true + }, + "builtin-status-codes": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/builtin-status-codes/download/builtin-status-codes-3.0.0.tgz", + "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=" + }, + "bytes": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/bytes/download/bytes-3.1.0.tgz", + "integrity": "sha1-9s95M6Ng4FiPqf3oVlHNx/gF0fY=" + }, + "cacache": { + "version": "12.0.4", + "resolved": "https://registry.nlark.com/cacache/download/cacache-12.0.4.tgz?cache=0&sync_timestamp=1621949700715&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcacache%2Fdownload%2Fcacache-12.0.4.tgz", + "integrity": "sha1-ZovL0QWutfHZL+JVcOyVJcj6pAw=", + "dev": true, + "requires": { + "bluebird": "^3.5.5", + "chownr": "^1.1.1", + "figgy-pudding": "^3.5.1", + "glob": "^7.1.4", + "graceful-fs": "^4.1.15", + "infer-owner": "^1.0.3", + "lru-cache": "^5.1.1", + "mississippi": "^3.0.0", + "mkdirp": "^0.5.1", + "move-concurrently": "^1.0.1", + "promise-inflight": "^1.0.1", + "rimraf": "^2.6.3", + "ssri": "^6.0.1", + "unique-filename": "^1.1.1", + "y18n": "^4.0.0" + }, + "dependencies": { + "ssri": { + "version": "6.0.2", + "resolved": "https://registry.nlark.com/ssri/download/ssri-6.0.2.tgz?cache=0&sync_timestamp=1621364918494&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fssri%2Fdownload%2Fssri-6.0.2.tgz", + "integrity": "sha1-FXk5E08gRk5zAd26PpD/qPdyisU=", + "dev": true, + "requires": { + "figgy-pudding": "^3.5.1" + } + } + } + }, + "cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/cache-base/download/cache-base-1.0.1.tgz", + "integrity": "sha1-Cn9GQWgxyLZi7jb+TnxZ129marI=", + "dev": true, + "requires": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + } + }, + "cache-loader": { + "version": "4.1.0", + "resolved": "https://registry.nlark.com/cache-loader/download/cache-loader-4.1.0.tgz", + "integrity": "sha1-mUjK41OuwKH8ser9ojAIFuyFOH4=", + "dev": true, + "requires": { + "buffer-json": "^2.0.0", + "find-cache-dir": "^3.0.0", + "loader-utils": "^1.2.3", + "mkdirp": "^0.5.1", + "neo-async": "^2.6.1", + "schema-utils": "^2.0.0" + } + }, + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/call-bind/download/call-bind-1.0.2.tgz", + "integrity": "sha1-sdTonmiBGcPJqQOtMKuy9qkZvjw=", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "call-me-maybe": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/call-me-maybe/download/call-me-maybe-1.0.1.tgz", + "integrity": "sha1-JtII6onje1y95gJQoV8DHBak1ms=", + "dev": true + }, + "caller-callsite": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/caller-callsite/download/caller-callsite-2.0.0.tgz", + "integrity": "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=", + "dev": true, + "requires": { + "callsites": "^2.0.0" + } + }, + "caller-path": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/caller-path/download/caller-path-2.0.0.tgz?cache=0&sync_timestamp=1618738159926&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcaller-path%2Fdownload%2Fcaller-path-2.0.0.tgz", + "integrity": "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=", + "dev": true, + "requires": { + "caller-callsite": "^2.0.0" + } + }, + "callsites": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/callsites/download/callsites-2.0.0.tgz", + "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=", + "dev": true + }, + "camel-case": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/camel-case/download/camel-case-3.0.0.tgz?cache=0&sync_timestamp=1606867311564&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcamel-case%2Fdownload%2Fcamel-case-3.0.0.tgz", + "integrity": "sha1-yjw2iKTpzzpM2nd9xNy8cTJJz3M=", + "dev": true, + "requires": { + "no-case": "^2.2.0", + "upper-case": "^1.1.1" + } + }, + "camelcase": { + "version": "6.2.0", + "resolved": "https://registry.nlark.com/camelcase/download/camelcase-6.2.0.tgz", + "integrity": "sha1-kkr4gcnVJaydh/QNlk5c6pgqGAk=", + "dev": true + }, + "caniuse-api": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/caniuse-api/download/caniuse-api-3.0.0.tgz", + "integrity": "sha1-Xk2Q4idJYdRikZl99Znj7QCO5MA=", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "caniuse-lite": "^1.0.0", + "lodash.memoize": "^4.1.2", + "lodash.uniq": "^4.5.0" + } + }, + "caniuse-lite": { + "version": "1.0.30001245", + "resolved": "https://registry.nlark.com/caniuse-lite/download/caniuse-lite-1.0.30001245.tgz?cache=0&sync_timestamp=1626238653626&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcaniuse-lite%2Fdownload%2Fcaniuse-lite-1.0.30001245.tgz", + "integrity": "sha1-RblBu9gzyw+lOGH/K650azxspdQ=", + "dev": true + }, + "case-sensitive-paths-webpack-plugin": { + "version": "2.4.0", + "resolved": "https://registry.npm.taobao.org/case-sensitive-paths-webpack-plugin/download/case-sensitive-paths-webpack-plugin-2.4.0.tgz", + "integrity": "sha1-22QGbGQi7tLgjMFLmGykN5bbxtQ=", + "dev": true + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.nlark.com/caseless/download/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", + "dev": true + }, + "chai": { + "version": "4.3.4", + "resolved": "https://registry.npm.taobao.org/chai/download/chai-4.3.4.tgz", + "integrity": "sha1-tV5lWzHh6scJm+TAjCGWT84ubEk=", + "dev": true, + "requires": { + "assertion-error": "^1.1.0", + "check-error": "^1.0.2", + "deep-eql": "^3.0.1", + "get-func-name": "^2.0.0", + "pathval": "^1.1.1", + "type-detect": "^4.0.5" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.nlark.com/chalk/download/chalk-2.4.2.tgz?cache=0&sync_timestamp=1618995354302&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fchalk%2Fdownload%2Fchalk-2.4.2.tgz", + "integrity": "sha1-zUJUFnelQzPPVBpJEIwUMrRMlCQ=", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "chardet": { + "version": "0.7.0", + "resolved": "https://registry.npm.taobao.org/chardet/download/chardet-0.7.0.tgz", + "integrity": "sha1-kAlISfCTfy7twkJdDSip5fDLrZ4=", + "dev": true + }, + "check-error": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/check-error/download/check-error-1.0.2.tgz", + "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", + "dev": true + }, + "check-types": { + "version": "8.0.3", + "resolved": "https://registry.npm.taobao.org/check-types/download/check-types-8.0.3.tgz", + "integrity": "sha1-M1bMoZyIlUTy16le1JzlCKDs9VI=", + "dev": true + }, + "chokidar": { + "version": "2.1.8", + "resolved": "https://registry.nlark.com/chokidar/download/chokidar-2.1.8.tgz", + "integrity": "sha1-gEs6e2qZNYw8XGHnHYco8EHP+Rc=", + "dev": true, + "requires": { + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "fsevents": "^1.2.7", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" + }, + "dependencies": { + "anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/anymatch/download/anymatch-2.0.0.tgz?cache=0&sync_timestamp=1617747806715&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fanymatch%2Fdownload%2Fanymatch-2.0.0.tgz", + "integrity": "sha1-vLJLTzeTTZqnrBe0ra+J58du8us=", + "dev": true, + "requires": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + }, + "dependencies": { + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.nlark.com/normalize-path/download/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "dev": true, + "requires": { + "remove-trailing-separator": "^1.0.1" + } + } + } + } + } + }, + "chownr": { + "version": "1.1.4", + "resolved": "https://registry.npm.taobao.org/chownr/download/chownr-1.1.4.tgz", + "integrity": "sha1-b8nXtC0ypYNZYzdmbn0ICE2izGs=", + "dev": true + }, + "chrome-trace-event": { + "version": "1.0.3", + "resolved": "https://registry.nlark.com/chrome-trace-event/download/chrome-trace-event-1.0.3.tgz", + "integrity": "sha1-EBXs7UdB4V0GZkqVfbv1DQQeJqw=", + "dev": true + }, + "ci-info": { + "version": "1.6.0", + "resolved": "https://registry.nlark.com/ci-info/download/ci-info-1.6.0.tgz?cache=0&sync_timestamp=1622039942508&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fci-info%2Fdownload%2Fci-info-1.6.0.tgz", + "integrity": "sha1-LKINu5zrMtRSSmgzAzE/AwSx5Jc=", + "dev": true + }, + "cipher-base": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/cipher-base/download/cipher-base-1.0.4.tgz", + "integrity": "sha1-h2Dk7MJy9MNjUy+SbYdKriwTl94=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "class-utils": { + "version": "0.3.6", + "resolved": "https://registry.npm.taobao.org/class-utils/download/class-utils-0.3.6.tgz", + "integrity": "sha1-+TNprouafOAv1B+q0MqDAzGQxGM=", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-accessor-descriptor/download/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.nlark.com/is-data-descriptor/download/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-descriptor/download/is-descriptor-0.1.6.tgz", + "integrity": "sha1-Nm2CQN3kh8pRgjsaufB6EKeCUco=", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + } + }, + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-5.1.0.tgz", + "integrity": "sha1-cpyR4thXt6QZofmqZWhcTDP1hF0=", + "dev": true + } + } + }, + "clean-css": { + "version": "4.2.3", + "resolved": "https://registry.nlark.com/clean-css/download/clean-css-4.2.3.tgz?cache=0&sync_timestamp=1624616709466&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fclean-css%2Fdownload%2Fclean-css-4.2.3.tgz", + "integrity": "sha1-UHtd59l7SO5T2ErbAWD/YhY4D3g=", + "dev": true, + "requires": { + "source-map": "~0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "cli-cursor": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/cli-cursor/download/cli-cursor-3.1.0.tgz", + "integrity": "sha1-JkMFp65JDR0Dvwybp8kl0XU68wc=", + "dev": true, + "requires": { + "restore-cursor": "^3.1.0" + } + }, + "cli-highlight": { + "version": "2.1.11", + "resolved": "https://registry.npm.taobao.org/cli-highlight/download/cli-highlight-2.1.11.tgz?cache=0&sync_timestamp=1616955426054&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcli-highlight%2Fdownload%2Fcli-highlight-2.1.11.tgz", + "integrity": "sha1-SXNvpFLwqvT65YDjCssmgo0twb8=", + "dev": true, + "requires": { + "chalk": "^4.0.0", + "highlight.js": "^10.7.1", + "mz": "^2.4.0", + "parse5": "^5.1.1", + "parse5-htmlparser2-tree-adapter": "^6.0.0", + "yargs": "^16.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.nlark.com/ansi-styles/download/ansi-styles-4.3.0.tgz?cache=0&sync_timestamp=1618995547052&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-styles%2Fdownload%2Fansi-styles-4.3.0.tgz", + "integrity": "sha1-7dgDYornHATIWuegkG7a00tkiTc=", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.1", + "resolved": "https://registry.nlark.com/chalk/download/chalk-4.1.1.tgz?cache=0&sync_timestamp=1618995354302&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fchalk%2Fdownload%2Fchalk-4.1.1.tgz", + "integrity": "sha1-yAs/qyi/Y3HmhjMl7uZ+YYt35q0=", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/color-convert/download/color-convert-2.0.1.tgz", + "integrity": "sha1-ctOmjVmMm9s68q0ehPIdiWq9TeM=", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.nlark.com/color-name/download/color-name-1.1.4.tgz", + "integrity": "sha1-wqCah6y95pVD3m9j+jmVyCbFNqI=", + "dev": true + }, + "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 + }, + "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, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "cli-spinners": { + "version": "2.6.0", + "resolved": "https://registry.nlark.com/cli-spinners/download/cli-spinners-2.6.0.tgz", + "integrity": "sha1-NsfcmPtqmna9YjjsP3fiQlYn6Tk=", + "dev": true + }, + "cli-width": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/cli-width/download/cli-width-3.0.0.tgz", + "integrity": "sha1-ovSEN6LKqaIkNueUvwceyeYc7fY=", + "dev": true + }, + "clipboardy": { + "version": "2.3.0", + "resolved": "https://registry.npm.taobao.org/clipboardy/download/clipboardy-2.3.0.tgz", + "integrity": "sha1-PCkDZQxo5GqRs4iYW8J3QofbopA=", + "dev": true, + "requires": { + "arch": "^2.1.1", + "execa": "^1.0.0", + "is-wsl": "^2.1.1" + } + }, + "cliui": { + "version": "6.0.0", + "resolved": "https://registry.npm.taobao.org/cliui/download/cliui-6.0.0.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-6.0.0.tgz", + "integrity": "sha1-UR1wLAxOQcoVbX0OlgIfI+EyJbE=", + "dev": true, + "requires": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^6.2.0" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-5.0.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-5.0.0.tgz", + "integrity": "sha1-OIU59VF5vzkznIGvMKZU1p+Hy3U=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/is-fullwidth-code-point/download/is-fullwidth-code-point-3.0.0.tgz?cache=0&sync_timestamp=1618552469710&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-fullwidth-code-point%2Fdownload%2Fis-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha1-8Rb4Bk/pCz94RKOJl8C3UFEmnx0=", + "dev": true + }, + "string-width": { + "version": "4.2.2", + "resolved": "https://registry.nlark.com/string-width/download/string-width-4.2.2.tgz", + "integrity": "sha1-2v1PlVmnWFz7pSnGoKT3NIjr1MU=", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.0" + } + }, + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-6.0.0.tgz", + "integrity": "sha1-CxVx3XZpzNTz4G4U7x7tJiJa5TI=", + "dev": true, + "requires": { + "ansi-regex": "^5.0.0" + } + } + } + }, + "clone": { + "version": "1.0.4", + "resolved": "https://registry.nlark.com/clone/download/clone-1.0.4.tgz", + "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", + "dev": true + }, + "coa": { + "version": "2.0.2", + "resolved": "https://registry.nlark.com/coa/download/coa-2.0.2.tgz", + "integrity": "sha1-Q/bCEVG07yv1cYfbDXPeIp4+fsM=", + "dev": true, + "requires": { + "@types/q": "^1.5.1", + "chalk": "^2.4.1", + "q": "^1.1.2" + } + }, + "collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/collection-visit/download/collection-visit-1.0.0.tgz", + "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "dev": true, + "requires": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + } + }, + "color": { + "version": "3.1.3", + "resolved": "https://registry.npm.taobao.org/color/download/color-3.1.3.tgz", + "integrity": "sha1-ymf7TnuX1hHc3jns7tQiBn2RWW4=", + "dev": true, + "requires": { + "color-convert": "^1.9.1", + "color-string": "^1.5.4" + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npm.taobao.org/color-convert/download/color-convert-1.9.3.tgz", + "integrity": "sha1-u3GFBpDh8TZWfeYp0tVHHe2kweg=", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.nlark.com/color-name/download/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "dev": true + }, + "color-string": { + "version": "1.5.5", + "resolved": "https://registry.npm.taobao.org/color-string/download/color-string-1.5.5.tgz", + "integrity": "sha1-ZUdKjw50OWJfPSemoZ2J/EUiMBQ=", + "dev": true, + "requires": { + "color-name": "^1.0.0", + "simple-swizzle": "^0.2.2" + } + }, + "colorette": { + "version": "1.2.2", + "resolved": "https://registry.nlark.com/colorette/download/colorette-1.2.2.tgz?cache=0&sync_timestamp=1618847174680&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcolorette%2Fdownload%2Fcolorette-1.2.2.tgz", + "integrity": "sha1-y8x51emcrqLb8Q6zom/Ys+as+pQ=" + }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npm.taobao.org/combined-stream/download/combined-stream-1.0.8.tgz", + "integrity": "sha1-w9RaizT9cwYxoRCoolIGgrMdWn8=", + "dev": true, + "requires": { + "delayed-stream": "~1.0.0" + } + }, + "commander": { + "version": "2.17.1", + "resolved": "https://registry.nlark.com/commander/download/commander-2.17.1.tgz?cache=0&sync_timestamp=1624609533517&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcommander%2Fdownload%2Fcommander-2.17.1.tgz", + "integrity": "sha1-vXerfebelCBc6sxy8XFtKfIKd78=", + "dev": true + }, + "commondir": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/commondir/download/commondir-1.0.1.tgz", + "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", + "dev": true + }, + "component-emitter": { + "version": "1.3.0", + "resolved": "https://registry.nlark.com/component-emitter/download/component-emitter-1.3.0.tgz", + "integrity": "sha1-FuQHD7qK4ptnnyIVhT7hgasuq8A=", + "dev": true + }, + "compressible": { + "version": "2.0.18", + "resolved": "https://registry.npm.taobao.org/compressible/download/compressible-2.0.18.tgz", + "integrity": "sha1-r1PMprBw1MPAdQ+9dyhqbXzEb7o=", + "dev": true, + "requires": { + "mime-db": ">= 1.43.0 < 2" + } + }, + "compression": { + "version": "1.7.4", + "resolved": "https://registry.npm.taobao.org/compression/download/compression-1.7.4.tgz", + "integrity": "sha1-lVI+/xcMpXwpoMpB5v4TH0Hlu48=", + "dev": true, + "requires": { + "accepts": "~1.3.5", + "bytes": "3.0.0", + "compressible": "~2.0.16", + "debug": "2.6.9", + "on-headers": "~1.0.2", + "safe-buffer": "5.1.2", + "vary": "~1.1.2" + }, + "dependencies": { + "bytes": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/bytes/download/bytes-3.0.0.tgz", + "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=", + "dev": true + }, + "debug": { + "version": "2.6.9", + "resolved": "https://registry.nlark.com/debug/download/debug-2.6.9.tgz", + "integrity": "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + } + } + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npm.taobao.org/concat-map/download/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.nlark.com/concat-stream/download/concat-stream-1.6.2.tgz", + "integrity": "sha1-kEvfGUzTEi/Gdcd/xKw9T/D9GjQ=", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "connect-history-api-fallback": { + "version": "1.6.0", + "resolved": "https://registry.npm.taobao.org/connect-history-api-fallback/download/connect-history-api-fallback-1.6.0.tgz", + "integrity": "sha1-izIIk1kwjRERFdgcrT/Oq4iPl7w=", + "dev": true + }, + "console-browserify": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/console-browserify/download/console-browserify-1.2.0.tgz", + "integrity": "sha1-ZwY871fOts9Jk6KrOlWECujEkzY=", + "dev": true + }, + "consolidate": { + "version": "0.15.1", + "resolved": "https://registry.npm.taobao.org/consolidate/download/consolidate-0.15.1.tgz", + "integrity": "sha1-IasEMjXHGgfUXZqtmFk7DbpWurc=", + "dev": true, + "requires": { + "bluebird": "^3.1.1" + } + }, + "constants-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/constants-browserify/download/constants-browserify-1.0.0.tgz", + "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=", + "dev": true + }, + "content-disposition": { + "version": "0.5.3", + "resolved": "https://registry.npm.taobao.org/content-disposition/download/content-disposition-0.5.3.tgz", + "integrity": "sha1-4TDK9+cnkIfFYWwgB9BIVpiYT70=", + "dev": true, + "requires": { + "safe-buffer": "5.1.2" + } + }, + "content-type": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/content-type/download/content-type-1.0.4.tgz", + "integrity": "sha1-4TjMdeBAxyexlm/l5fjJruJW/js=" + }, + "convert-source-map": { + "version": "1.8.0", + "resolved": "https://registry.nlark.com/convert-source-map/download/convert-source-map-1.8.0.tgz", + "integrity": "sha1-8zc8MtIbTXgN2ABFFGhPt5HKQ2k=", + "dev": true, + "requires": { + "safe-buffer": "~5.1.1" + } + }, + "cookie": { + "version": "0.4.0", + "resolved": "https://registry.npm.taobao.org/cookie/download/cookie-0.4.0.tgz", + "integrity": "sha1-vrQ35wIrO21JAZ0IhmUwPr6cFLo=", + "dev": true + }, + "cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npm.taobao.org/cookie-signature/download/cookie-signature-1.0.6.tgz", + "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=", + "dev": true + }, + "copy-anything": { + "version": "2.0.3", + "resolved": "https://registry.npm.taobao.org/copy-anything/download/copy-anything-2.0.3.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcopy-anything%2Fdownload%2Fcopy-anything-2.0.3.tgz", + "integrity": "sha1-hCQHugJGaw34RIGbvjuuu+XUXYc=", + "requires": { + "is-what": "^3.12.0" + } + }, + "copy-concurrently": { + "version": "1.0.5", + "resolved": "https://registry.npm.taobao.org/copy-concurrently/download/copy-concurrently-1.0.5.tgz", + "integrity": "sha1-kilzmMrjSTf8r9bsgTnBgFHwteA=", + "dev": true, + "requires": { + "aproba": "^1.1.1", + "fs-write-stream-atomic": "^1.0.8", + "iferr": "^0.1.5", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.0" + } + }, + "copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/copy-descriptor/download/copy-descriptor-0.1.1.tgz", + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", + "dev": true + }, + "copy-to": { + "version": "2.0.1", + "resolved": "https://registry.npmmirror.com/copy-to/-/copy-to-2.0.1.tgz", + "integrity": "sha512-3DdaFaU/Zf1AnpLiFDeNCD4TOWe3Zl2RZaTzUvWiIk5ERzcCodOE20Vqq4fzCbNoHURFHT4/us/Lfq+S2zyY4w==" + }, + "copy-webpack-plugin": { + "version": "5.1.2", + "resolved": "https://registry.nlark.com/copy-webpack-plugin/download/copy-webpack-plugin-5.1.2.tgz?cache=0&sync_timestamp=1624628458516&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcopy-webpack-plugin%2Fdownload%2Fcopy-webpack-plugin-5.1.2.tgz", + "integrity": "sha1-ioieHcr6bJHGzUvhrRWPHTgjuuI=", + "dev": true, + "requires": { + "cacache": "^12.0.3", + "find-cache-dir": "^2.1.0", + "glob-parent": "^3.1.0", + "globby": "^7.1.1", + "is-glob": "^4.0.1", + "loader-utils": "^1.2.3", + "minimatch": "^3.0.4", + "normalize-path": "^3.0.0", + "p-limit": "^2.2.1", + "schema-utils": "^1.0.0", + "serialize-javascript": "^4.0.0", + "webpack-log": "^2.0.0" + }, + "dependencies": { + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/find-cache-dir/download/find-cache-dir-2.1.0.tgz", + "integrity": "sha1-jQ+UzRP+Q8bHwmGg2GEVypGMBfc=", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + } + }, + "globby": { + "version": "7.1.1", + "resolved": "https://registry.nlark.com/globby/download/globby-7.1.1.tgz", + "integrity": "sha1-+yzP+UAfhgCUXfral0QMypcrhoA=", + "dev": true, + "requires": { + "array-union": "^1.0.1", + "dir-glob": "^2.0.0", + "glob": "^7.1.2", + "ignore": "^3.3.5", + "pify": "^3.0.0", + "slash": "^1.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/pify/download/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "ignore": { + "version": "3.3.10", + "resolved": "https://registry.npm.taobao.org/ignore/download/ignore-3.3.10.tgz", + "integrity": "sha1-Cpf7h2mG6AgcYxFg+PnziRV/AEM=", + "dev": true + }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/make-dir/download/make-dir-2.1.0.tgz", + "integrity": "sha1-XwMQ4YuL6JjMBwCSlaMK5B6R5vU=", + "dev": true, + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + } + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/pkg-dir/download/pkg-dir-3.0.0.tgz?cache=0&sync_timestamp=1618847182947&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpkg-dir%2Fdownload%2Fpkg-dir-3.0.0.tgz", + "integrity": "sha1-J0kCDyOe2ZCIGx9xIQ1R62UjvqM=", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/schema-utils/download/schema-utils-1.0.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-1.0.0.tgz", + "integrity": "sha1-C3mpMgTXtgDUsoUNH2bCo0lRx3A=", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.nlark.com/semver/download/semver-5.7.1.tgz", + "integrity": "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=", + "dev": true + }, + "slash": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/slash/download/slash-1.0.0.tgz", + "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", + "dev": true + } + } + }, + "core-js": { + "version": "3.15.2", + "resolved": "https://registry.nlark.com/core-js/download/core-js-3.15.2.tgz?cache=0&sync_timestamp=1624966012065&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcore-js%2Fdownload%2Fcore-js-3.15.2.tgz", + "integrity": "sha1-dAZg0v9V7zTOZk1+JFURnFvdPWE=" + }, + "core-js-compat": { + "version": "3.15.2", + "resolved": "https://registry.nlark.com/core-js-compat/download/core-js-compat-3.15.2.tgz?cache=0&sync_timestamp=1624966048946&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcore-js-compat%2Fdownload%2Fcore-js-compat-3.15.2.tgz", + "integrity": "sha1-Rycvu0eYgN4UtOYIH3HzSS9b08s=", + "dev": true, + "requires": { + "browserslist": "^4.16.6", + "semver": "7.0.0" + }, + "dependencies": { + "semver": { + "version": "7.0.0", + "resolved": "https://registry.nlark.com/semver/download/semver-7.0.0.tgz", + "integrity": "sha1-XzyjV2HkfgWyBsba/yz4FPAxa44=", + "dev": true + } + } + }, + "core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/core-util-is/download/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" + }, + "cosmiconfig": { + "version": "5.2.1", + "resolved": "https://registry.npm.taobao.org/cosmiconfig/download/cosmiconfig-5.2.1.tgz", + "integrity": "sha1-BA9yaAnFked6F8CjYmykW08Wixo=", + "dev": true, + "requires": { + "import-fresh": "^2.0.0", + "is-directory": "^0.3.1", + "js-yaml": "^3.13.1", + "parse-json": "^4.0.0" + } + }, + "create-ecdh": { + "version": "4.0.4", + "resolved": "https://registry.nlark.com/create-ecdh/download/create-ecdh-4.0.4.tgz", + "integrity": "sha1-1uf0v/pmc2CFoHYv06YyaE2rzE4=", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "elliptic": "^6.5.3" + }, + "dependencies": { + "bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz", + "integrity": "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=", + "dev": true + } + } + }, + "create-hash": { + "version": "1.2.0", + "resolved": "https://registry.nlark.com/create-hash/download/create-hash-1.2.0.tgz", + "integrity": "sha1-iJB4rxGmN1a8+1m9IhmWvjqe8ZY=", + "dev": true, + "requires": { + "cipher-base": "^1.0.1", + "inherits": "^2.0.1", + "md5.js": "^1.3.4", + "ripemd160": "^2.0.1", + "sha.js": "^2.4.0" + } + }, + "create-hmac": { + "version": "1.1.7", + "resolved": "https://registry.npm.taobao.org/create-hmac/download/create-hmac-1.1.7.tgz", + "integrity": "sha1-aRcMeLOrlXFHsriwRXLkfq0iQ/8=", + "dev": true, + "requires": { + "cipher-base": "^1.0.3", + "create-hash": "^1.1.0", + "inherits": "^2.0.1", + "ripemd160": "^2.0.0", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "cross-env": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-env/-/cross-env-7.0.3.tgz", + "integrity": "sha512-+/HKd6EgcQCJGh2PSjZuUitQBQynKor4wrFbRg4DtAgS1aWO+gU52xpH7M9ScGgXSYmAVS9bIJ8EzuaGw0oNAw==", + "dev": true, + "requires": { + "cross-spawn": "^7.0.1" + } + }, + "cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "crypto-browserify": { + "version": "3.12.0", + "resolved": "https://registry.npm.taobao.org/crypto-browserify/download/crypto-browserify-3.12.0.tgz", + "integrity": "sha1-OWz58xN/A+S45TLFj2mCVOAPgOw=", + "dev": true, + "requires": { + "browserify-cipher": "^1.0.0", + "browserify-sign": "^4.0.0", + "create-ecdh": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.0", + "diffie-hellman": "^5.0.0", + "inherits": "^2.0.1", + "pbkdf2": "^3.0.3", + "public-encrypt": "^4.0.0", + "randombytes": "^2.0.0", + "randomfill": "^1.0.3" + } + }, + "css": { + "version": "2.2.4", + "resolved": "https://registry.npm.taobao.org/css/download/css-2.2.4.tgz", + "integrity": "sha1-xkZ1XHOXHyu6amAeLPL9cbEpiSk=", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "source-map": "^0.6.1", + "source-map-resolve": "^0.5.2", + "urix": "^0.1.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "css-color-names": { + "version": "0.0.4", + "resolved": "https://registry.npm.taobao.org/css-color-names/download/css-color-names-0.0.4.tgz", + "integrity": "sha1-gIrcLnnPhHOAabZGyyDsJ762KeA=", + "dev": true + }, + "css-declaration-sorter": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/css-declaration-sorter/download/css-declaration-sorter-4.0.1.tgz?cache=0&sync_timestamp=1620754845858&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcss-declaration-sorter%2Fdownload%2Fcss-declaration-sorter-4.0.1.tgz", + "integrity": "sha1-wZiUD2OnbX42wecQGLABchBUyyI=", + "dev": true, + "requires": { + "postcss": "^7.0.1", + "timsort": "^0.3.0" + } + }, + "css-loader": { + "version": "3.6.0", + "resolved": "https://registry.nlark.com/css-loader/download/css-loader-3.6.0.tgz", + "integrity": "sha1-Lkssfm4tJ/jI8o9hv/zS5ske9kU=", + "dev": true, + "requires": { + "camelcase": "^5.3.1", + "cssesc": "^3.0.0", + "icss-utils": "^4.1.1", + "loader-utils": "^1.2.3", + "normalize-path": "^3.0.0", + "postcss": "^7.0.32", + "postcss-modules-extract-imports": "^2.0.0", + "postcss-modules-local-by-default": "^3.0.2", + "postcss-modules-scope": "^2.2.0", + "postcss-modules-values": "^3.0.0", + "postcss-value-parser": "^4.1.0", + "schema-utils": "^2.7.0", + "semver": "^6.3.0" + }, + "dependencies": { + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.nlark.com/camelcase/download/camelcase-5.3.1.tgz", + "integrity": "sha1-48mzFWnhBoEd8kL3FXJaH0xJQyA=", + "dev": true + } + } + }, + "css-parse": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/css-parse/download/css-parse-2.0.0.tgz", + "integrity": "sha1-pGjuZnwW2BzPBcWMONKpfHgNv9Q=", + "dev": true, + "requires": { + "css": "^2.0.0" + } + }, + "css-select": { + "version": "4.1.3", + "resolved": "https://registry.nlark.com/css-select/download/css-select-4.1.3.tgz", + "integrity": "sha1-pwRA9wMX8maRGK10/xBeZYSccGc=", + "dev": true, + "requires": { + "boolbase": "^1.0.0", + "css-what": "^5.0.0", + "domhandler": "^4.2.0", + "domutils": "^2.6.0", + "nth-check": "^2.0.0" + } + }, + "css-select-base-adapter": { + "version": "0.1.1", + "resolved": "https://registry.npm.taobao.org/css-select-base-adapter/download/css-select-base-adapter-0.1.1.tgz", + "integrity": "sha1-Oy/0lyzDYquIVhUHqVQIoUMhNdc=", + "dev": true + }, + "css-tree": { + "version": "1.0.0-alpha.37", + "resolved": "https://registry.nlark.com/css-tree/download/css-tree-1.0.0-alpha.37.tgz", + "integrity": "sha1-mL69YsTB2flg7DQM+fdSLjBwmiI=", + "dev": true, + "requires": { + "mdn-data": "2.0.4", + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "css-what": { + "version": "5.0.1", + "resolved": "https://registry.nlark.com/css-what/download/css-what-5.0.1.tgz?cache=0&sync_timestamp=1622227630859&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcss-what%2Fdownload%2Fcss-what-5.0.1.tgz", + "integrity": "sha1-PvqCATH0ZpqKwkCPnDLnx96fTK0=", + "dev": true + }, + "cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/cssesc/download/cssesc-3.0.0.tgz", + "integrity": "sha1-N3QZGZA7hoVl4cCep0dEXNGJg+4=", + "dev": true + }, + "cssnano": { + "version": "4.1.11", + "resolved": "https://registry.nlark.com/cssnano/download/cssnano-4.1.11.tgz?cache=0&sync_timestamp=1623330418944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcssnano%2Fdownload%2Fcssnano-4.1.11.tgz", + "integrity": "sha1-x7X1uB2iacsf2YLLlgwSAJEMmpk=", + "dev": true, + "requires": { + "cosmiconfig": "^5.0.0", + "cssnano-preset-default": "^4.0.8", + "is-resolvable": "^1.0.0", + "postcss": "^7.0.0" + } + }, + "cssnano-preset-default": { + "version": "4.0.8", + "resolved": "https://registry.nlark.com/cssnano-preset-default/download/cssnano-preset-default-4.0.8.tgz?cache=0&sync_timestamp=1623330257156&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcssnano-preset-default%2Fdownload%2Fcssnano-preset-default-4.0.8.tgz", + "integrity": "sha1-kgYisfwelaNOiDggPxOXpQTy0/8=", + "dev": true, + "requires": { + "css-declaration-sorter": "^4.0.1", + "cssnano-util-raw-cache": "^4.0.1", + "postcss": "^7.0.0", + "postcss-calc": "^7.0.1", + "postcss-colormin": "^4.0.3", + "postcss-convert-values": "^4.0.1", + "postcss-discard-comments": "^4.0.2", + "postcss-discard-duplicates": "^4.0.2", + "postcss-discard-empty": "^4.0.1", + "postcss-discard-overridden": "^4.0.1", + "postcss-merge-longhand": "^4.0.11", + "postcss-merge-rules": "^4.0.3", + "postcss-minify-font-values": "^4.0.2", + "postcss-minify-gradients": "^4.0.2", + "postcss-minify-params": "^4.0.2", + "postcss-minify-selectors": "^4.0.2", + "postcss-normalize-charset": "^4.0.1", + "postcss-normalize-display-values": "^4.0.2", + "postcss-normalize-positions": "^4.0.2", + "postcss-normalize-repeat-style": "^4.0.2", + "postcss-normalize-string": "^4.0.2", + "postcss-normalize-timing-functions": "^4.0.2", + "postcss-normalize-unicode": "^4.0.1", + "postcss-normalize-url": "^4.0.1", + "postcss-normalize-whitespace": "^4.0.2", + "postcss-ordered-values": "^4.1.2", + "postcss-reduce-initial": "^4.0.3", + "postcss-reduce-transforms": "^4.0.2", + "postcss-svgo": "^4.0.3", + "postcss-unique-selectors": "^4.0.1" + } + }, + "cssnano-util-get-arguments": { + "version": "4.0.0", + "resolved": "https://registry.nlark.com/cssnano-util-get-arguments/download/cssnano-util-get-arguments-4.0.0.tgz", + "integrity": "sha1-7ToIKZ8h11dBsg87gfGU7UnMFQ8=", + "dev": true + }, + "cssnano-util-get-match": { + "version": "4.0.0", + "resolved": "https://registry.npm.taobao.org/cssnano-util-get-match/download/cssnano-util-get-match-4.0.0.tgz", + "integrity": "sha1-wOTKB/U4a7F+xeUiULT1lhNlFW0=", + "dev": true + }, + "cssnano-util-raw-cache": { + "version": "4.0.1", + "resolved": "https://registry.npm.taobao.org/cssnano-util-raw-cache/download/cssnano-util-raw-cache-4.0.1.tgz", + "integrity": "sha1-sm1f1fcqEd/np4RvtMZyYPlr8oI=", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "cssnano-util-same-parent": { + "version": "4.0.1", + "resolved": "https://registry.npm.taobao.org/cssnano-util-same-parent/download/cssnano-util-same-parent-4.0.1.tgz", + "integrity": "sha1-V0CC+yhZ0ttDOFWDXZqEVuoYu/M=", + "dev": true + }, + "csso": { + "version": "4.2.0", + "resolved": "https://registry.nlark.com/csso/download/csso-4.2.0.tgz", + "integrity": "sha1-6jpWE0bo3J9UbW/r7dUBh884lSk=", + "dev": true, + "requires": { + "css-tree": "^1.1.2" + }, + "dependencies": { + "css-tree": { + "version": "1.1.3", + "resolved": "https://registry.nlark.com/css-tree/download/css-tree-1.1.3.tgz", + "integrity": "sha1-60hw+2/XcHMn7JXC/yqwm16NuR0=", + "dev": true, + "requires": { + "mdn-data": "2.0.14", + "source-map": "^0.6.1" + } + }, + "mdn-data": { + "version": "2.0.14", + "resolved": "https://registry.nlark.com/mdn-data/download/mdn-data-2.0.14.tgz", + "integrity": "sha1-cRP8QoGRfWPOKbQ0RvcB5owlulA=", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "cssom": { + "version": "0.4.4", + "resolved": "https://registry.nlark.com/cssom/download/cssom-0.4.4.tgz?cache=0&sync_timestamp=1624219249710&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcssom%2Fdownload%2Fcssom-0.4.4.tgz", + "integrity": "sha1-WmbPk9LQtmHYC/akT7ZfXC5OChA=", + "dev": true + }, + "cssstyle": { + "version": "2.3.0", + "resolved": "https://registry.nlark.com/cssstyle/download/cssstyle-2.3.0.tgz", + "integrity": "sha1-/2ZaDdvcMYZLCWR/NBY0Q9kLCFI=", + "dev": true, + "requires": { + "cssom": "~0.3.6" + }, + "dependencies": { + "cssom": { + "version": "0.3.8", + "resolved": "https://registry.nlark.com/cssom/download/cssom-0.3.8.tgz?cache=0&sync_timestamp=1624219249710&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcssom%2Fdownload%2Fcssom-0.3.8.tgz", + "integrity": "sha1-nxJ29bK0Y/IRTT8sdSUK+MGjb0o=", + "dev": true + } + } + }, + "csstype": { + "version": "2.6.20", + "resolved": "https://registry.npmmirror.com/csstype/-/csstype-2.6.20.tgz", + "integrity": "sha512-/WwNkdXfckNgw6S5R125rrW8ez139lBHWouiBvX8dfMFtcn6V81REDqnH7+CRpRipfYlyU1CmOnOxrmGcFOjeA==" + }, + "cyclist": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/cyclist/download/cyclist-1.0.1.tgz", + "integrity": "sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk=", + "dev": true + }, + "dashdash": { + "version": "1.14.1", + "resolved": "https://registry.npm.taobao.org/dashdash/download/dashdash-1.14.1.tgz", + "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0" + } + }, + "data-uri-to-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmmirror.com/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz", + "integrity": "sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og==" + }, + "data-urls": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/data-urls/download/data-urls-1.1.0.tgz", + "integrity": "sha1-Fe4Fgrql4iu1nHcUDaj5x2lju/4=", + "dev": true, + "requires": { + "abab": "^2.0.0", + "whatwg-mimetype": "^2.2.0", + "whatwg-url": "^7.0.0" + } + }, + "dateformat": { + "version": "2.2.0", + "resolved": "https://registry.npmmirror.com/dateformat/-/dateformat-2.2.0.tgz", + "integrity": "sha512-GODcnWq3YGoTnygPfi02ygEiRxqUxpJwuRHjdhJYuxpcZmDq4rjBiXYmbCCzStxo176ixfLT6i4NPwQooRySnw==" + }, + "dayjs": { + "version": "1.11.5", + "resolved": "https://registry.npmmirror.com/dayjs/-/dayjs-1.11.5.tgz", + "integrity": "sha512-CAdX5Q3YW3Gclyo5Vpqkgpj8fSdLQcRuzfX6mC6Phy0nfJ0eGYOeS7m4mt2plDWLAtA4TqTakvbboHvUxfe4iA==" + }, + "debug": { + "version": "4.3.2", + "resolved": "https://registry.nlark.com/debug/download/debug-4.3.2.tgz", + "integrity": "sha1-8KScGKyHeeMdSgxgKd+3aHPHQos=", + "requires": { + "ms": "2.1.2" + } + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.nlark.com/decamelize/download/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", + "dev": true + }, + "decode-uri-component": { + "version": "0.2.0", + "resolved": "https://registry.npm.taobao.org/decode-uri-component/download/decode-uri-component-0.2.0.tgz", + "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", + "dev": true + }, + "deep-eql": { + "version": "3.0.1", + "resolved": "https://registry.npm.taobao.org/deep-eql/download/deep-eql-3.0.1.tgz", + "integrity": "sha1-38lARACtHI/gI+faHfHBR8S0RN8=", + "dev": true, + "requires": { + "type-detect": "^4.0.0" + } + }, + "deep-equal": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/deep-equal/download/deep-equal-1.1.1.tgz?cache=0&sync_timestamp=1606860101281&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdeep-equal%2Fdownload%2Fdeep-equal-1.1.1.tgz", + "integrity": "sha1-tcmMlCzv+vfLBR4k4UNKJaLmB2o=", + "dev": true, + "requires": { + "is-arguments": "^1.0.4", + "is-date-object": "^1.0.1", + "is-regex": "^1.0.4", + "object-is": "^1.0.1", + "object-keys": "^1.1.1", + "regexp.prototype.flags": "^1.2.0" + } + }, + "deep-is": { + "version": "0.1.3", + "resolved": "https://registry.npm.taobao.org/deep-is/download/deep-is-0.1.3.tgz", + "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" + }, + "deepmerge": { + "version": "1.5.2", + "resolved": "https://registry.npm.taobao.org/deepmerge/download/deepmerge-1.5.2.tgz?cache=0&sync_timestamp=1606805746825&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdeepmerge%2Fdownload%2Fdeepmerge-1.5.2.tgz", + "integrity": "sha1-EEmdhohEza1P7ghC34x/bwyVp1M=", + "dev": true + }, + "default-gateway": { + "version": "5.0.5", + "resolved": "https://registry.npm.taobao.org/default-gateway/download/default-gateway-5.0.5.tgz?cache=0&sync_timestamp=1610365816953&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdefault-gateway%2Fdownload%2Fdefault-gateway-5.0.5.tgz", + "integrity": "sha1-T9a9XShV05s0zFpZUFSG6ar8mxA=", + "dev": true, + "requires": { + "execa": "^3.3.0" + }, + "dependencies": { + "execa": { + "version": "3.4.0", + "resolved": "https://registry.nlark.com/execa/download/execa-3.4.0.tgz?cache=0&sync_timestamp=1622825859616&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fexeca%2Fdownload%2Fexeca-3.4.0.tgz", + "integrity": "sha1-wI7UVQ72XYWPrCaf/IVyRG8364k=", + "dev": true, + "requires": { + "cross-spawn": "^7.0.0", + "get-stream": "^5.0.0", + "human-signals": "^1.1.1", + "is-stream": "^2.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^4.0.0", + "onetime": "^5.1.0", + "p-finally": "^2.0.0", + "signal-exit": "^3.0.2", + "strip-final-newline": "^2.0.0" + } + }, + "get-stream": { + "version": "5.2.0", + "resolved": "https://registry.nlark.com/get-stream/download/get-stream-5.2.0.tgz", + "integrity": "sha1-SWaheV7lrOZecGxLe+txJX1uItM=", + "dev": true, + "requires": { + "pump": "^3.0.0" + } + }, + "is-stream": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/is-stream/download/is-stream-2.0.0.tgz", + "integrity": "sha1-venDJoDW+uBBKdasnZIc54FfeOM=", + "dev": true + }, + "npm-run-path": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/npm-run-path/download/npm-run-path-4.0.1.tgz", + "integrity": "sha1-t+zR5e1T2o43pV4cImnguX7XSOo=", + "dev": true, + "requires": { + "path-key": "^3.0.0" + } + }, + "p-finally": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/p-finally/download/p-finally-2.0.1.tgz", + "integrity": "sha1-vW/KqcVZoJa2gIBvTWV7Pw8kBWE=", + "dev": true + } + } + }, + "default-user-agent": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/default-user-agent/-/default-user-agent-1.0.0.tgz", + "integrity": "sha512-bDF7bg6OSNcSwFWPu4zYKpVkJZQYVrAANMYB8bc9Szem1D0yKdm4sa/rOCs2aC9+2GMqQ7KnwtZRvDhmLF0dXw==", + "requires": { + "os-name": "~1.0.3" + } + }, + "defaults": { + "version": "1.0.3", + "resolved": "https://registry.npm.taobao.org/defaults/download/defaults-1.0.3.tgz", + "integrity": "sha1-xlYFHpgX2f8I7YgUd/P+QBnz730=", + "dev": true, + "requires": { + "clone": "^1.0.2" + } + }, + "define-properties": { + "version": "1.1.3", + "resolved": "https://registry.nlark.com/define-properties/download/define-properties-1.1.3.tgz", + "integrity": "sha1-z4jabL7ib+bbcJT2HYcMvYTO6fE=", + "dev": true, + "requires": { + "object-keys": "^1.0.12" + } + }, + "define-property": { + "version": "2.0.2", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-2.0.2.tgz", + "integrity": "sha1-1Flono1lS6d+AqgX+HENcCyxbp0=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + } + }, + "degenerator": { + "version": "3.0.2", + "resolved": "https://registry.npmmirror.com/degenerator/-/degenerator-3.0.2.tgz", + "integrity": "sha512-c0mef3SNQo56t6urUU6tdQAs+ThoD0o9B9MJ8HEt7NQcGEILCRFqQb7ZbP9JAv+QF1Ky5plydhMR/IrqWDm+TQ==", + "requires": { + "ast-types": "^0.13.2", + "escodegen": "^1.8.1", + "esprima": "^4.0.0", + "vm2": "^3.9.8" + } + }, + "del": { + "version": "4.1.1", + "resolved": "https://registry.npm.taobao.org/del/download/del-4.1.1.tgz", + "integrity": "sha1-no8RciLqRKMf86FWwEm5kFKp8LQ=", + "dev": true, + "requires": { + "@types/glob": "^7.1.1", + "globby": "^6.1.0", + "is-path-cwd": "^2.0.0", + "is-path-in-cwd": "^2.0.0", + "p-map": "^2.0.0", + "pify": "^4.0.1", + "rimraf": "^2.6.3" + }, + "dependencies": { + "globby": { + "version": "6.1.0", + "resolved": "https://registry.nlark.com/globby/download/globby-6.1.0.tgz", + "integrity": "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=", + "dev": true, + "requires": { + "array-union": "^1.0.1", + "glob": "^7.0.3", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" + }, + "dependencies": { + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npm.taobao.org/pify/download/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", + "dev": true + } + } + } + } + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/delayed-stream/download/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", + "dev": true + }, + "depd": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/depd/download/depd-1.1.2.tgz", + "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" + }, + "des.js": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/des.js/download/des.js-1.0.1.tgz", + "integrity": "sha1-U4IULhvcU/hdhtU+X0qn3rkeCEM=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "destroy": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/destroy/download/destroy-1.0.4.tgz", + "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" + }, + "detect-libc": { + "version": "1.0.3", + "resolved": "https://registry.npmmirror.com/detect-libc/-/detect-libc-1.0.3.tgz", + "integrity": "sha512-pGjwhsmsp4kL2RTz08wcOlGN83otlqHeD/Z5T8GXZB+/YcpQ/dgo+lbU8ZsGxV0HIvqqxo9l7mqYwyYMD9bKDg==", + "dev": true + }, + "detect-node": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/detect-node/download/detect-node-2.1.0.tgz?cache=0&sync_timestamp=1621146954463&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fdetect-node%2Fdownload%2Fdetect-node-2.1.0.tgz", + "integrity": "sha1-yccHdaScPQO8LAbZpzvlUPl4+LE=", + "dev": true + }, + "diff": { + "version": "3.5.0", + "resolved": "https://registry.npm.taobao.org/diff/download/diff-3.5.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdiff%2Fdownload%2Fdiff-3.5.0.tgz", + "integrity": "sha1-gAwN0eCov7yVg1wgKtIg/jF+WhI=", + "dev": true + }, + "diffie-hellman": { + "version": "5.0.3", + "resolved": "https://registry.npm.taobao.org/diffie-hellman/download/diffie-hellman-5.0.3.tgz", + "integrity": "sha1-QOjumPVaIUlgcUaSHGPhrl89KHU=", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "miller-rabin": "^4.0.0", + "randombytes": "^2.0.0" + }, + "dependencies": { + "bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz", + "integrity": "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=", + "dev": true + } + } + }, + "digest-header": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/digest-header/-/digest-header-1.0.0.tgz", + "integrity": "sha512-sRTuakZ2PkOUCuAaVv+SLjhr/hRf8ldZP0XnGEQ69RFGxmll5fVaMsnRXWKKK4XsUTnJf8+eRPSFNgE/lWa9wQ==", + "requires": { + "utility": "^1.17.0" + } + }, + "dir-glob": { + "version": "2.2.2", + "resolved": "https://registry.nlark.com/dir-glob/download/dir-glob-2.2.2.tgz", + "integrity": "sha1-+gnwaUFTyJGLGLoN6vrpR2n8UMQ=", + "dev": true, + "requires": { + "path-type": "^3.0.0" + } + }, + "dns-equal": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/dns-equal/download/dns-equal-1.0.0.tgz", + "integrity": "sha1-s55/HabrCnW6nBcySzR1PEfgZU0=", + "dev": true + }, + "dns-packet": { + "version": "1.3.4", + "resolved": "https://registry.nlark.com/dns-packet/download/dns-packet-1.3.4.tgz", + "integrity": "sha1-40VQZYJKJQe6iGxVqJljuxB97G8=", + "dev": true, + "requires": { + "ip": "^1.1.0", + "safe-buffer": "^5.0.1" + } + }, + "dns-txt": { + "version": "2.0.2", + "resolved": "https://registry.npm.taobao.org/dns-txt/download/dns-txt-2.0.2.tgz", + "integrity": "sha1-uR2Ab10nGI5Ks+fRB9iBocxGQrY=", + "dev": true, + "requires": { + "buffer-indexof": "^1.0.0" + } + }, + "dom-converter": { + "version": "0.2.0", + "resolved": "https://registry.npm.taobao.org/dom-converter/download/dom-converter-0.2.0.tgz", + "integrity": "sha1-ZyGp2u4uKTaClVtq/kFncWJ7t2g=", + "dev": true, + "requires": { + "utila": "~0.4" + } + }, + "dom-serializer": { + "version": "1.3.2", + "resolved": "https://registry.nlark.com/dom-serializer/download/dom-serializer-1.3.2.tgz?cache=0&sync_timestamp=1621256819522&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fdom-serializer%2Fdownload%2Fdom-serializer-1.3.2.tgz", + "integrity": "sha1-YgZDfTLO767HFhgDIwx6ILwbTZE=", + "dev": true, + "requires": { + "domelementtype": "^2.0.1", + "domhandler": "^4.2.0", + "entities": "^2.0.0" + } + }, + "domain-browser": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/domain-browser/download/domain-browser-1.2.0.tgz", + "integrity": "sha1-PTH1AZGmdJ3RN1p/Ui6CPULlTto=", + "dev": true + }, + "domelementtype": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/domelementtype/download/domelementtype-2.2.0.tgz", + "integrity": "sha1-mgtsJ4LtahxzI9QiZxg9+b2LHVc=", + "dev": true + }, + "domexception": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/domexception/download/domexception-1.0.1.tgz", + "integrity": "sha1-k3RCZEymoxJh7zbj7Gd/6AVYLJA=", + "dev": true, + "requires": { + "webidl-conversions": "^4.0.2" + } + }, + "domhandler": { + "version": "4.2.0", + "resolved": "https://registry.nlark.com/domhandler/download/domhandler-4.2.0.tgz", + "integrity": "sha1-+XaKXwNL5gqJonwuTQ9066DYsFk=", + "dev": true, + "requires": { + "domelementtype": "^2.2.0" + } + }, + "domutils": { + "version": "2.7.0", + "resolved": "https://registry.nlark.com/domutils/download/domutils-2.7.0.tgz", + "integrity": "sha1-jrrwxB66/PVbC3LsMcVjI3EsVEI=", + "dev": true, + "requires": { + "dom-serializer": "^1.0.1", + "domelementtype": "^2.2.0", + "domhandler": "^4.2.0" + } + }, + "dot-prop": { + "version": "5.3.0", + "resolved": "https://registry.npm.taobao.org/dot-prop/download/dot-prop-5.3.0.tgz?cache=0&sync_timestamp=1605778235569&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdot-prop%2Fdownload%2Fdot-prop-5.3.0.tgz", + "integrity": "sha1-kMzOcIzZzYLMTcjD3dmr3VWyDog=", + "dev": true, + "requires": { + "is-obj": "^2.0.0" + } + }, + "dotenv": { + "version": "8.6.0", + "resolved": "https://registry.nlark.com/dotenv/download/dotenv-8.6.0.tgz", + "integrity": "sha1-Bhr2ZNGff02PxuT/m1hM4jety4s=", + "dev": true + }, + "dotenv-expand": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/dotenv-expand/download/dotenv-expand-5.1.0.tgz", + "integrity": "sha1-P7rwIL/XlIhAcuomsel5HUWmKfA=", + "dev": true + }, + "duplexer": { + "version": "0.1.2", + "resolved": "https://registry.nlark.com/duplexer/download/duplexer-0.1.2.tgz", + "integrity": "sha1-Or5DrvODX4rgd9E23c4PJ2sEAOY=", + "dev": true + }, + "duplexify": { + "version": "3.7.1", + "resolved": "https://registry.npm.taobao.org/duplexify/download/duplexify-3.7.1.tgz", + "integrity": "sha1-Kk31MX9sz9kfhtb9JdjYoQO4gwk=", + "dev": true, + "requires": { + "end-of-stream": "^1.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.0.0", + "stream-shift": "^1.0.0" + } + }, + "easy-stack": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/easy-stack/-/easy-stack-1.0.1.tgz", + "integrity": "sha512-wK2sCs4feiiJeFXn3zvY0p41mdU5VUgbgs1rNsc/y5ngFUijdWd+iIN8eoyuZHKB8xN6BL4PdWmzqFmxNg6V2w==", + "dev": true + }, + "ecc-jsbn": { + "version": "0.1.2", + "resolved": "https://registry.npm.taobao.org/ecc-jsbn/download/ecc-jsbn-0.1.2.tgz", + "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", + "dev": true, + "requires": { + "jsbn": "~0.1.0", + "safer-buffer": "^2.1.0" + } + }, + "echarts": { + "version": "5.0.2", + "resolved": "https://registry.nlark.com/echarts/download/echarts-5.0.2.tgz", + "integrity": "sha1-FybRelfPBdYs0FZ7QyXhIBpWuvY=", + "requires": { + "tslib": "2.0.3", + "zrender": "5.0.4" + } + }, + "ee-first": { + "version": "1.1.1", + "resolved": "https://registry.nlark.com/ee-first/download/ee-first-1.1.1.tgz", + "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" + }, + "ejs": { + "version": "2.7.4", + "resolved": "https://registry.npm.taobao.org/ejs/download/ejs-2.7.4.tgz?cache=0&sync_timestamp=1612644037163&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fejs%2Fdownload%2Fejs-2.7.4.tgz", + "integrity": "sha1-SGYSh1c9zFPjZsehrlLDoSDuybo=", + "dev": true + }, + "electron-to-chromium": { + "version": "1.3.775", + "resolved": "https://registry.nlark.com/electron-to-chromium/download/electron-to-chromium-1.3.775.tgz", + "integrity": "sha1-BGUX0fLOp1Pgb/9UmZW53EXiAII=", + "dev": true + }, + "element-plus": { + "version": "2.2.14", + "resolved": "https://registry.npmmirror.com/element-plus/-/element-plus-2.2.14.tgz", + "integrity": "sha512-V5Pis0OHhePg1RgVogZrcefaVl8vjVn4Pn9Qsh/t2CbFgjg9kKOYFqf/tuP3ObSXGm3X89hpe0W+nLVAsaFnpw==", + "requires": { + "@ctrl/tinycolor": "^3.4.1", + "@element-plus/icons-vue": "^2.0.6", + "@floating-ui/dom": "^0.5.4", + "@popperjs/core": "npm:@sxzz/popperjs-es@^2.11.7", + "@types/lodash": "^4.14.182", + "@types/lodash-es": "^4.17.6", + "@vueuse/core": "^9.1.0", + "async-validator": "^4.2.5", + "dayjs": "^1.11.3", + "escape-html": "^1.0.3", + "lodash": "^4.17.21", + "lodash-es": "^4.17.21", + "lodash-unified": "^1.0.2", + "memoize-one": "^6.0.0", + "normalize-wheel-es": "^1.2.0" + }, + "dependencies": { + "@popperjs/core": { + "version": "npm:@sxzz/popperjs-es@2.11.7", + "resolved": "https://registry.npmmirror.com/@sxzz/popperjs-es/-/popperjs-es-2.11.7.tgz", + "integrity": "sha512-Ccy0NlLkzr0Ex2FKvh2X+OyERHXJ88XJ1MXtsI9y9fGexlaXaVTPzBCRBwIxFkORuOb+uBqeu+RqnpgYTEZRUQ==" + } + } + }, + "elliptic": { + "version": "6.5.4", + "resolved": "https://registry.npm.taobao.org/elliptic/download/elliptic-6.5.4.tgz?cache=0&sync_timestamp=1612290836352&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Felliptic%2Fdownload%2Felliptic-6.5.4.tgz", + "integrity": "sha1-2jfOvTHnmhNn6UG1ku0fvr1Yq7s=", + "dev": true, + "requires": { + "bn.js": "^4.11.9", + "brorand": "^1.1.0", + "hash.js": "^1.0.0", + "hmac-drbg": "^1.0.1", + "inherits": "^2.0.4", + "minimalistic-assert": "^1.0.1", + "minimalistic-crypto-utils": "^1.0.1" + }, + "dependencies": { + "bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz", + "integrity": "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=", + "dev": true + } + } + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.nlark.com/emoji-regex/download/emoji-regex-8.0.0.tgz", + "integrity": "sha1-6Bj9ac5cz8tARZT4QpY79TFkzDc=", + "dev": true + }, + "emojis-list": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/emojis-list/download/emojis-list-3.0.0.tgz", + "integrity": "sha1-VXBmIEatKeLpFucariYKvf9Pang=", + "dev": true + }, + "encodeurl": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/encodeurl/download/encodeurl-1.0.2.tgz", + "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", + "dev": true + }, + "end-of-stream": { + "version": "1.4.4", + "resolved": "https://registry.npm.taobao.org/end-of-stream/download/end-of-stream-1.4.4.tgz", + "integrity": "sha1-WuZKX0UFe682JuwU2gyl5LJDHrA=", + "requires": { + "once": "^1.4.0" + } + }, + "end-or-error": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/end-or-error/-/end-or-error-1.0.1.tgz", + "integrity": "sha512-OclLMSug+k2A0JKuf494im25ANRBVW8qsjmwbgX7lQ8P82H21PQ1PWkoYwb9y5yMBS69BPlwtzdIFClo3+7kOQ==" + }, + "enhanced-resolve": { + "version": "4.5.0", + "resolved": "https://registry.nlark.com/enhanced-resolve/download/enhanced-resolve-4.5.0.tgz?cache=0&sync_timestamp=1620663831689&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fenhanced-resolve%2Fdownload%2Fenhanced-resolve-4.5.0.tgz", + "integrity": "sha1-Lzz9hNvjtIfxjy2y7x4GSlccpew=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "memory-fs": "^0.5.0", + "tapable": "^1.0.0" + }, + "dependencies": { + "memory-fs": { + "version": "0.5.0", + "resolved": "https://registry.npm.taobao.org/memory-fs/download/memory-fs-0.5.0.tgz", + "integrity": "sha1-MkwBKIuIZSlm0WHbd4OHIIRajjw=", + "dev": true, + "requires": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + } + } + } + }, + "entities": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/entities/download/entities-2.2.0.tgz?cache=0&sync_timestamp=1611535322406&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fentities%2Fdownload%2Fentities-2.2.0.tgz", + "integrity": "sha1-CY3JDruD2N/6CJ1VJWs1HTTE2lU=", + "dev": true + }, + "errno": { + "version": "0.1.8", + "resolved": "https://registry.npm.taobao.org/errno/download/errno-0.1.8.tgz", + "integrity": "sha1-i7Ppx9Rjvkl2/4iPdrSAnrwugR8=", + "requires": { + "prr": "~1.0.1" + } + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npm.taobao.org/error-ex/download/error-ex-1.3.2.tgz", + "integrity": "sha1-tKxAZIEH/c3PriQvQovqihTU8b8=", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "error-stack-parser": { + "version": "2.0.6", + "resolved": "https://registry.npm.taobao.org/error-stack-parser/download/error-stack-parser-2.0.6.tgz", + "integrity": "sha1-WpmnB716TFinl5AtSNgoA+3mqtg=", + "dev": true, + "requires": { + "stackframe": "^1.1.1" + } + }, + "es-abstract": { + "version": "1.18.3", + "resolved": "https://registry.nlark.com/es-abstract/download/es-abstract-1.18.3.tgz?cache=0&sync_timestamp=1622158101826&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fes-abstract%2Fdownload%2Fes-abstract-1.18.3.tgz", + "integrity": "sha1-JcTDOAonqiA8RLK2hbupTaMbY+A=", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "es-to-primitive": "^1.2.1", + "function-bind": "^1.1.1", + "get-intrinsic": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.2", + "is-callable": "^1.2.3", + "is-negative-zero": "^2.0.1", + "is-regex": "^1.1.3", + "is-string": "^1.0.6", + "object-inspect": "^1.10.3", + "object-keys": "^1.1.1", + "object.assign": "^4.1.2", + "string.prototype.trimend": "^1.0.4", + "string.prototype.trimstart": "^1.0.4", + "unbox-primitive": "^1.0.1" + } + }, + "es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npm.taobao.org/es-to-primitive/download/es-to-primitive-1.2.1.tgz", + "integrity": "sha1-5VzUyc3BiLzvsDs2bHNjI/xciYo=", + "dev": true, + "requires": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + } + }, + "escalade": { + "version": "3.1.1", + "resolved": "https://registry.npm.taobao.org/escalade/download/escalade-3.1.1.tgz", + "integrity": "sha1-2M/ccACWXFoBdLSoLqpcBVJ0LkA=", + "dev": true + }, + "escape-html": { + "version": "1.0.3", + "resolved": "https://registry.nlark.com/escape-html/download/escape-html-1.0.3.tgz", + "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.nlark.com/escape-string-regexp/download/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true + }, + "escodegen": { + "version": "1.14.3", + "resolved": "https://registry.nlark.com/escodegen/download/escodegen-1.14.3.tgz", + "integrity": "sha1-TnuB+6YVgdyXWC7XjKt/Do1j9QM=", + "requires": { + "esprima": "^4.0.1", + "estraverse": "^4.2.0", + "esutils": "^2.0.2", + "optionator": "^0.8.1", + "source-map": "~0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "optional": true + } + } + }, + "eslint-loader": { + "version": "2.2.1", + "resolved": "https://registry.npm.taobao.org/eslint-loader/download/eslint-loader-2.2.1.tgz", + "integrity": "sha1-KLnBLaVAV68IReKmEScBova/gzc=", + "dev": true, + "requires": { + "loader-fs-cache": "^1.0.0", + "loader-utils": "^1.0.2", + "object-assign": "^4.0.1", + "object-hash": "^1.1.4", + "rimraf": "^2.6.1" + } + }, + "eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.nlark.com/eslint-visitor-keys/download/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha1-MOvR73wv3/AcOk8VEESvJfqwUj4=", + "dev": true + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/esprima/download/esprima-4.0.1.tgz", + "integrity": "sha1-E7BM2z5sXRnfkatph6hpVhmwqnE=" + }, + "esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npm.taobao.org/esrecurse/download/esrecurse-4.3.0.tgz", + "integrity": "sha1-eteWTWeauyi+5yzsY3WLHF0smSE=", + "dev": true, + "requires": { + "estraverse": "^5.2.0" + }, + "dependencies": { + "estraverse": { + "version": "5.2.0", + "resolved": "https://registry.npm.taobao.org/estraverse/download/estraverse-5.2.0.tgz", + "integrity": "sha1-MH30JUfmzHMk088DwVXVzbjFOIA=", + "dev": true + } + } + }, + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npm.taobao.org/estraverse/download/estraverse-4.3.0.tgz", + "integrity": "sha1-OYrT88WiSUi+dyXoPRGn3ijNvR0=" + }, + "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==" + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.nlark.com/esutils/download/esutils-2.0.3.tgz", + "integrity": "sha1-dNLrTeC42hKTcRkQ1Qd1ubcQ72Q=" + }, + "etag": { + "version": "1.8.1", + "resolved": "https://registry.npm.taobao.org/etag/download/etag-1.8.1.tgz", + "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", + "dev": true + }, + "event-pubsub": { + "version": "4.3.0", + "resolved": "https://registry.npmmirror.com/event-pubsub/-/event-pubsub-4.3.0.tgz", + "integrity": "sha512-z7IyloorXvKbFx9Bpie2+vMJKKx1fH1EN5yiTfp8CiLOTptSYy1g8H4yDpGlEdshL1PBiFtBHepF2cNsqeEeFQ==", + "dev": true + }, + "event-target-shim": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/event-target-shim/-/event-target-shim-5.0.1.tgz", + "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==" + }, + "eventemitter3": { + "version": "4.0.7", + "resolved": "https://registry.npm.taobao.org/eventemitter3/download/eventemitter3-4.0.7.tgz", + "integrity": "sha1-Lem2j2Uo1WRO9cWVJqG0oHMGFp8=", + "dev": true + }, + "events": { + "version": "3.3.0", + "resolved": "https://registry.npm.taobao.org/events/download/events-3.3.0.tgz", + "integrity": "sha1-Mala0Kkk4tLEGagTrrLE6HjqdAA=", + "dev": true + }, + "eventsource": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/eventsource/download/eventsource-1.1.0.tgz?cache=0&sync_timestamp=1616041748498&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Feventsource%2Fdownload%2Feventsource-1.1.0.tgz", + "integrity": "sha1-AOjKfJIQnpSw3fMtrGd9hBAoz68=", + "requires": { + "original": "^1.0.0" + } + }, + "evp_bytestokey": { + "version": "1.0.3", + "resolved": "https://registry.nlark.com/evp_bytestokey/download/evp_bytestokey-1.0.3.tgz", + "integrity": "sha1-f8vbGY3HGVlDLv4ThCaE4FJaywI=", + "dev": true, + "requires": { + "md5.js": "^1.3.4", + "safe-buffer": "^5.1.1" + } + }, + "execa": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/execa/download/execa-1.0.0.tgz?cache=0&sync_timestamp=1622825859616&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fexeca%2Fdownload%2Fexeca-1.0.0.tgz", + "integrity": "sha1-xiNqW7TfbW8V6I5/AXeYIWdJ3dg=", + "dev": true, + "requires": { + "cross-spawn": "^6.0.0", + "get-stream": "^4.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + }, + "dependencies": { + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npm.taobao.org/cross-spawn/download/cross-spawn-6.0.5.tgz", + "integrity": "sha1-Sl7Hxk364iw6FBJNus3uhG2Ay8Q=", + "dev": true, + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/path-key/download/path-key-2.0.1.tgz?cache=0&sync_timestamp=1617971691339&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpath-key%2Fdownload%2Fpath-key-2.0.1.tgz", + "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", + "dev": true + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.nlark.com/semver/download/semver-5.7.1.tgz", + "integrity": "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=", + "dev": true + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/shebang-command/download/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/shebang-regex/download/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "dev": true + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npm.taobao.org/which/download/which-1.3.1.tgz", + "integrity": "sha1-pFBD1U9YBTFtqNYvn1CRjT2nCwo=", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npm.taobao.org/expand-brackets/download/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "dev": true, + "requires": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.nlark.com/debug/download/debug-2.6.9.tgz", + "integrity": "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-accessor-descriptor/download/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.nlark.com/is-data-descriptor/download/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-descriptor/download/is-descriptor-0.1.6.tgz", + "integrity": "sha1-Nm2CQN3kh8pRgjsaufB6EKeCUco=", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + }, + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-5.1.0.tgz", + "integrity": "sha1-cpyR4thXt6QZofmqZWhcTDP1hF0=", + "dev": true + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + } + } + }, + "express": { + "version": "4.17.1", + "resolved": "https://registry.npm.taobao.org/express/download/express-4.17.1.tgz", + "integrity": "sha1-RJH8OGBc9R+GKdOcK10Cb5ikwTQ=", + "dev": true, + "requires": { + "accepts": "~1.3.7", + "array-flatten": "1.1.1", + "body-parser": "1.19.0", + "content-disposition": "0.5.3", + "content-type": "~1.0.4", + "cookie": "0.4.0", + "cookie-signature": "1.0.6", + "debug": "2.6.9", + "depd": "~1.1.2", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "finalhandler": "~1.1.2", + "fresh": "0.5.2", + "merge-descriptors": "1.0.1", + "methods": "~1.1.2", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "path-to-regexp": "0.1.7", + "proxy-addr": "~2.0.5", + "qs": "6.7.0", + "range-parser": "~1.2.1", + "safe-buffer": "5.1.2", + "send": "0.17.1", + "serve-static": "1.14.1", + "setprototypeof": "1.1.1", + "statuses": "~1.5.0", + "type-is": "~1.6.18", + "utils-merge": "1.0.1", + "vary": "~1.1.2" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.nlark.com/debug/download/debug-2.6.9.tgz", + "integrity": "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "qs": { + "version": "6.7.0", + "resolved": "https://registry.npm.taobao.org/qs/download/qs-6.7.0.tgz", + "integrity": "sha1-QdwaAV49WB8WIXdr4xr7KHapsbw=", + "dev": true + } + } + }, + "extend": { + "version": "3.0.2", + "resolved": "https://registry.npm.taobao.org/extend/download/extend-3.0.2.tgz", + "integrity": "sha1-+LETa0Bx+9jrFAr/hYsQGewpFfo=", + "dev": true + }, + "extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-3.0.2.tgz", + "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "dev": true, + "requires": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + } + }, + "external-editor": { + "version": "3.1.0", + "resolved": "https://registry.npm.taobao.org/external-editor/download/external-editor-3.1.0.tgz", + "integrity": "sha1-ywP3QL764D6k0oPK7SdBqD8zVJU=", + "dev": true, + "requires": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + } + }, + "extglob": { + "version": "2.0.4", + "resolved": "https://registry.npm.taobao.org/extglob/download/extglob-2.0.4.tgz", + "integrity": "sha1-rQD+TcYSqSMuhxhxHcXLWrAoVUM=", + "dev": true, + "requires": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + } + } + }, + "extsprintf": { + "version": "1.3.0", + "resolved": "https://registry.nlark.com/extsprintf/download/extsprintf-1.3.0.tgz", + "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", + "dev": true + }, + "fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.nlark.com/fast-deep-equal/download/fast-deep-equal-3.1.3.tgz", + "integrity": "sha1-On1WtVnWy8PrUSMlJE5hmmXGxSU=", + "dev": true + }, + "fast-glob": { + "version": "2.2.7", + "resolved": "https://registry.nlark.com/fast-glob/download/fast-glob-2.2.7.tgz", + "integrity": "sha1-aVOFfDr6R1//ku5gFdUtpwpM050=", + "dev": true, + "requires": { + "@mrmlnc/readdir-enhanced": "^2.2.1", + "@nodelib/fs.stat": "^1.1.2", + "glob-parent": "^3.1.0", + "is-glob": "^4.0.0", + "merge2": "^1.2.3", + "micromatch": "^3.1.10" + } + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/fast-json-stable-stringify/download/fast-json-stable-stringify-2.1.0.tgz?cache=0&sync_timestamp=1618847186091&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffast-json-stable-stringify%2Fdownload%2Ffast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha1-h0v2nG9ATCtdmcSBNBOZ/VWJJjM=", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.nlark.com/fast-levenshtein/download/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" + }, + "fastq": { + "version": "1.11.1", + "resolved": "https://registry.nlark.com/fastq/download/fastq-1.11.1.tgz", + "integrity": "sha1-XYF1quF9thlH+LFiz8f2MmTSKAc=", + "dev": true, + "requires": { + "reusify": "^1.0.4" + } + }, + "faye-websocket": { + "version": "0.11.4", + "resolved": "https://registry.nlark.com/faye-websocket/download/faye-websocket-0.11.4.tgz?cache=0&sync_timestamp=1621894499766&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffaye-websocket%2Fdownload%2Ffaye-websocket-0.11.4.tgz", + "integrity": "sha1-fw2Sdc/dhqHJY9yLZfzEUe3Lsdo=", + "dev": true, + "requires": { + "websocket-driver": ">=0.5.1" + } + }, + "fetch-cookie": { + "version": "0.11.0", + "resolved": "https://registry.npmmirror.com/fetch-cookie/-/fetch-cookie-0.11.0.tgz", + "integrity": "sha512-BQm7iZLFhMWFy5CZ/162sAGjBfdNWb7a8LEqqnzsHFhxT/X/SVj/z2t2nu3aJvjlbQkrAlTUApplPRjWyH4mhA==", + "requires": { + "tough-cookie": "^2.3.3 || ^3.0.1 || ^4.0.0" + } + }, + "figgy-pudding": { + "version": "3.5.2", + "resolved": "https://registry.npm.taobao.org/figgy-pudding/download/figgy-pudding-3.5.2.tgz", + "integrity": "sha1-tO7oFIq7Adzx0aw0Nn1Z4S+mHW4=", + "dev": true + }, + "figures": { + "version": "3.2.0", + "resolved": "https://registry.nlark.com/figures/download/figures-3.2.0.tgz", + "integrity": "sha1-YlwYvSk8YE3EqN2y/r8MiDQXRq8=", + "dev": true, + "requires": { + "escape-string-regexp": "^1.0.5" + } + }, + "file-loader": { + "version": "4.3.0", + "resolved": "https://registry.npm.taobao.org/file-loader/download/file-loader-4.3.0.tgz", + "integrity": "sha1-eA8ED3KbPRgBnyBgX3I+hEuKWK8=", + "dev": true, + "requires": { + "loader-utils": "^1.2.3", + "schema-utils": "^2.5.0" + } + }, + "file-uri-to-path": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/file-uri-to-path/download/file-uri-to-path-1.0.0.tgz", + "integrity": "sha1-VTp7hEb/b2hDWcRF8eN6BdrMM90=", + "dev": true, + "optional": true + }, + "filesize": { + "version": "3.6.1", + "resolved": "https://registry.nlark.com/filesize/download/filesize-3.6.1.tgz?cache=0&sync_timestamp=1626007234928&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffilesize%2Fdownload%2Ffilesize-3.6.1.tgz", + "integrity": "sha1-CQuz7gG2+AGoqL6Z0xcQs0Irsxc=", + "dev": true + }, + "fill-range": { + "version": "4.0.0", + "resolved": "https://registry.nlark.com/fill-range/download/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + } + } + }, + "finalhandler": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/finalhandler/download/finalhandler-1.1.2.tgz", + "integrity": "sha1-t+fQAP/RGTjQ/bBTUG9uur6fWH0=", + "dev": true, + "requires": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "statuses": "~1.5.0", + "unpipe": "~1.0.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.nlark.com/debug/download/debug-2.6.9.tgz", + "integrity": "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + } + } + }, + "find-cache-dir": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/find-cache-dir/download/find-cache-dir-3.3.1.tgz", + "integrity": "sha1-ibM/rUpGcNqpT4Vff74x1thP6IA=", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^3.0.2", + "pkg-dir": "^4.1.0" + } + }, + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/find-up/download/find-up-3.0.0.tgz", + "integrity": "sha1-SRafHXmTQwZG2mHsxa41XCHJe3M=", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "flat": { + "version": "4.1.1", + "resolved": "https://registry.npm.taobao.org/flat/download/flat-4.1.1.tgz?cache=0&sync_timestamp=1602723427161&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fflat%2Fdownload%2Fflat-4.1.1.tgz", + "integrity": "sha1-o5IFnMOCiB/5hkL12k3eCpWfMJs=", + "dev": true, + "requires": { + "is-buffer": "~2.0.3" + } + }, + "flush-write-stream": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/flush-write-stream/download/flush-write-stream-1.1.1.tgz", + "integrity": "sha1-jdfYc6G6vCB9lOrQwuDkQnbr8ug=", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "readable-stream": "^2.3.6" + } + }, + "follow-redirects": { + "version": "1.14.1", + "resolved": "https://registry.nlark.com/follow-redirects/download/follow-redirects-1.14.1.tgz?cache=0&sync_timestamp=1620555246888&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffollow-redirects%2Fdownload%2Ffollow-redirects-1.14.1.tgz", + "integrity": "sha1-2RFN7Qoc/dM04WTmZirQK/2R/0M=" + }, + "for-in": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/for-in/download/for-in-1.0.2.tgz", + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", + "dev": true + }, + "forever-agent": { + "version": "0.6.1", + "resolved": "https://registry.nlark.com/forever-agent/download/forever-agent-0.6.1.tgz", + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", + "dev": true + }, + "form-data": { + "version": "2.3.3", + "resolved": "https://registry.nlark.com/form-data/download/form-data-2.3.3.tgz", + "integrity": "sha1-3M5SwF9kTymManq5Nr1yTO/786Y=", + "dev": true, + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + } + }, + "formstream": { + "version": "1.1.1", + "resolved": "https://registry.npmmirror.com/formstream/-/formstream-1.1.1.tgz", + "integrity": "sha512-yHRxt3qLFnhsKAfhReM4w17jP+U1OlhUjnKPPtonwKbIJO7oBP0MvoxkRUwb8AU9n0MIkYy5X5dK6pQnbj+R2Q==", + "requires": { + "destroy": "^1.0.4", + "mime": "^2.5.2", + "pause-stream": "~0.0.11" + } + }, + "forwarded": { + "version": "0.2.0", + "resolved": "https://registry.nlark.com/forwarded/download/forwarded-0.2.0.tgz?cache=0&sync_timestamp=1622503508967&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fforwarded%2Fdownload%2Fforwarded-0.2.0.tgz", + "integrity": "sha1-ImmTZCiq1MFcfr6XeahL8LKoGBE=", + "dev": true + }, + "fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npm.taobao.org/fragment-cache/download/fragment-cache-0.2.1.tgz", + "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "dev": true, + "requires": { + "map-cache": "^0.2.2" + } + }, + "fresh": { + "version": "0.5.2", + "resolved": "https://registry.npm.taobao.org/fresh/download/fresh-0.5.2.tgz", + "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", + "dev": true + }, + "from2": { + "version": "2.3.0", + "resolved": "https://registry.npm.taobao.org/from2/download/from2-2.3.0.tgz", + "integrity": "sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "readable-stream": "^2.0.0" + } + }, + "fs-extra": { + "version": "7.0.1", + "resolved": "https://registry.nlark.com/fs-extra/download/fs-extra-7.0.1.tgz?cache=0&sync_timestamp=1620079845472&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffs-extra%2Fdownload%2Ffs-extra-7.0.1.tgz", + "integrity": "sha1-TxicRKoSO4lfcigE9V6iPq3DSOk=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "fs-write-stream-atomic": { + "version": "1.0.10", + "resolved": "https://registry.npm.taobao.org/fs-write-stream-atomic/download/fs-write-stream-atomic-1.0.10.tgz", + "integrity": "sha1-tH31NJPvkR33VzHnCp3tAYnbQMk=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "iferr": "^0.1.5", + "imurmurhash": "^0.1.4", + "readable-stream": "1 || 2" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/fs.realpath/download/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" + }, + "fsevents": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz", + "integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==", + "dev": true, + "optional": true, + "requires": { + "bindings": "^1.5.0", + "nan": "^2.12.1" + } + }, + "ftp": { + "version": "0.3.10", + "resolved": "https://registry.npmmirror.com/ftp/-/ftp-0.3.10.tgz", + "integrity": "sha512-faFVML1aBx2UoDStmLwv2Wptt4vw5x03xxX172nhA5Y5HBshW5JweqQ2W4xL4dezQTG8inJsuYcpPHHU3X5OTQ==", + "requires": { + "readable-stream": "1.1.x", + "xregexp": "2.0.0" + }, + "dependencies": { + "isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmmirror.com/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ==" + }, + "readable-stream": { + "version": "1.1.14", + "resolved": "https://registry.npmmirror.com/readable-stream/-/readable-stream-1.1.14.tgz", + "integrity": "sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.1", + "isarray": "0.0.1", + "string_decoder": "~0.10.x" + } + }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmmirror.com/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ==" + } + } + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.nlark.com/function-bind/download/function-bind-1.1.1.tgz", + "integrity": "sha1-pWiZ0+o8m6uHS7l3O3xe3pL0iV0=", + "dev": true + }, + "gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npm.taobao.org/gensync/download/gensync-1.0.0-beta.2.tgz", + "integrity": "sha1-MqbudsPX9S1GsrGuXZP+qFgKJeA=", + "dev": true + }, + "get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npm.taobao.org/get-caller-file/download/get-caller-file-2.0.5.tgz", + "integrity": "sha1-T5RBKoLbMvNuOwuXQfipf+sDH34=", + "dev": true + }, + "get-func-name": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/get-func-name/download/get-func-name-2.0.0.tgz", + "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", + "dev": true + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.nlark.com/get-intrinsic/download/get-intrinsic-1.1.1.tgz", + "integrity": "sha1-FfWfN2+FXERpY5SPDSTNNje0q8Y=", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + }, + "get-ready": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/get-ready/-/get-ready-1.0.0.tgz", + "integrity": "sha512-mFXCZPJIlcYcth+N8267+mghfYN9h3EhsDa6JSnbA3Wrhh/XFpuowviFcsDeYZtKspQyWyJqfs4O6P8CHeTwzw==" + }, + "get-stream": { + "version": "4.1.0", + "resolved": "https://registry.nlark.com/get-stream/download/get-stream-4.1.0.tgz", + "integrity": "sha1-wbJVV189wh1Zv8ec09K0axw6VLU=", + "dev": true, + "requires": { + "pump": "^3.0.0" + } + }, + "get-uri": { + "version": "3.0.2", + "resolved": "https://registry.npmmirror.com/get-uri/-/get-uri-3.0.2.tgz", + "integrity": "sha512-+5s0SJbGoyiJTZZ2JTpFPLMPSch72KEqGOTvQsBqg0RBWvwhWUSYZFAtz3TPW0GXJuLBJPts1E241iHg+VRfhg==", + "requires": { + "@tootallnate/once": "1", + "data-uri-to-buffer": "3", + "debug": "4", + "file-uri-to-path": "2", + "fs-extra": "^8.1.0", + "ftp": "^0.3.10" + }, + "dependencies": { + "file-uri-to-path": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/file-uri-to-path/-/file-uri-to-path-2.0.0.tgz", + "integrity": "sha512-hjPFI8oE/2iQPVe4gbrJ73Pp+Xfub2+WI2LlXDbsaJBwT5wuMh35WNWVYYTpnz895shtwfyutMFLFywpQAFdLg==" + }, + "fs-extra": { + "version": "8.1.0", + "resolved": "https://registry.npmmirror.com/fs-extra/-/fs-extra-8.1.0.tgz", + "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", + "requires": { + "graceful-fs": "^4.2.0", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + } + } + }, + "get-value": { + "version": "2.0.6", + "resolved": "https://registry.nlark.com/get-value/download/get-value-2.0.6.tgz", + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", + "dev": true + }, + "getpass": { + "version": "0.1.7", + "resolved": "https://registry.npm.taobao.org/getpass/download/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0" + } + }, + "glob": { + "version": "7.1.7", + "resolved": "https://registry.nlark.com/glob/download/glob-7.1.7.tgz?cache=0&sync_timestamp=1620337498129&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob%2Fdownload%2Fglob-7.1.7.tgz", + "integrity": "sha1-Oxk+kjPwHULQs/eClLvutBj5SpA=", + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/glob-parent/download/glob-parent-3.1.0.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/is-glob/download/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "glob-to-regexp": { + "version": "0.3.0", + "resolved": "https://registry.npm.taobao.org/glob-to-regexp/download/glob-to-regexp-0.3.0.tgz", + "integrity": "sha1-jFoUlNIGbFcMw7/kSWF1rMTVAqs=", + "dev": true + }, + "globals": { + "version": "11.12.0", + "resolved": "https://registry.nlark.com/globals/download/globals-11.12.0.tgz", + "integrity": "sha1-q4eVM4hooLq9hSV1gBjCp+uVxC4=", + "dev": true + }, + "globby": { + "version": "9.2.0", + "resolved": "https://registry.nlark.com/globby/download/globby-9.2.0.tgz", + "integrity": "sha1-/QKacGxwPSm90XD0tts6P3p8tj0=", + "dev": true, + "requires": { + "@types/glob": "^7.1.1", + "array-union": "^1.0.2", + "dir-glob": "^2.2.2", + "fast-glob": "^2.2.6", + "glob": "^7.1.3", + "ignore": "^4.0.3", + "pify": "^4.0.1", + "slash": "^2.0.0" + } + }, + "graceful-fs": { + "version": "4.2.6", + "resolved": "https://registry.nlark.com/graceful-fs/download/graceful-fs-4.2.6.tgz", + "integrity": "sha1-/wQLKwhTsjw9MQJ1I3BvGIXXa+4=" + }, + "growl": { + "version": "1.10.5", + "resolved": "https://registry.npm.taobao.org/growl/download/growl-1.10.5.tgz", + "integrity": "sha1-8nNdwig2dPpnR4sQGBBZNVw2nl4=", + "dev": true + }, + "gzip-size": { + "version": "5.1.1", + "resolved": "https://registry.npm.taobao.org/gzip-size/download/gzip-size-5.1.1.tgz?cache=0&sync_timestamp=1605523260680&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fgzip-size%2Fdownload%2Fgzip-size-5.1.1.tgz", + "integrity": "sha1-y5vuaS+HwGErIyhAqHOQTkwTUnQ=", + "dev": true, + "requires": { + "duplexer": "^0.1.1", + "pify": "^4.0.1" + } + }, + "handle-thing": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/handle-thing/download/handle-thing-2.0.1.tgz", + "integrity": "sha1-hX95zjWVgMNA1DCBzGSJcNC7I04=", + "dev": true + }, + "har-schema": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/har-schema/download/har-schema-2.0.0.tgz", + "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", + "dev": true + }, + "har-validator": { + "version": "5.1.5", + "resolved": "https://registry.npm.taobao.org/har-validator/download/har-validator-5.1.5.tgz", + "integrity": "sha1-HwgDufjLIMD6E4It8ezds2veHv0=", + "dev": true, + "requires": { + "ajv": "^6.12.3", + "har-schema": "^2.0.0" + } + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.nlark.com/has/download/has-1.0.3.tgz", + "integrity": "sha1-ci18v8H2qoJB8W3YFOAR4fQeh5Y=", + "dev": true, + "requires": { + "function-bind": "^1.1.1" + } + }, + "has-bigints": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/has-bigints/download/has-bigints-1.0.1.tgz?cache=0&sync_timestamp=1615461293395&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhas-bigints%2Fdownload%2Fhas-bigints-1.0.1.tgz", + "integrity": "sha1-ZP5qywIGc+O3jbA1pa9pqp0HsRM=", + "dev": true + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/has-flag/download/has-flag-3.0.0.tgz?cache=0&sync_timestamp=1618559744568&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhas-flag%2Fdownload%2Fhas-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "dev": true + }, + "has-symbols": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/has-symbols/download/has-symbols-1.0.2.tgz", + "integrity": "sha1-Fl0wcMADCXUqEjakeTMeOsVvFCM=", + "dev": true + }, + "has-value": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/has-value/download/has-value-1.0.0.tgz", + "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", + "dev": true, + "requires": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + } + }, + "has-values": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/has-values/download/has-values-1.0.0.tgz", + "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "hash-base": { + "version": "3.1.0", + "resolved": "https://registry.npm.taobao.org/hash-base/download/hash-base-3.1.0.tgz", + "integrity": "sha1-VcOB2eBuHSmXqIO0o/3f5/DTrzM=", + "dev": true, + "requires": { + "inherits": "^2.0.4", + "readable-stream": "^3.6.0", + "safe-buffer": "^5.2.0" + }, + "dependencies": { + "readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.nlark.com/readable-stream/download/readable-stream-3.6.0.tgz", + "integrity": "sha1-M3u9o63AcGvT4CRCaihtS0sskZg=", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + }, + "safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npm.taobao.org/safe-buffer/download/safe-buffer-5.2.1.tgz", + "integrity": "sha1-Hq+fqb2x/dTsdfWPnNtOa3gn7sY=", + "dev": true + } + } + }, + "hash-sum": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/hash-sum/download/hash-sum-2.0.0.tgz", + "integrity": "sha1-gdAbtd6OpKIUrV1urRtSNGCwtFo=", + "dev": true + }, + "hash.js": { + "version": "1.1.7", + "resolved": "https://registry.npm.taobao.org/hash.js/download/hash.js-1.1.7.tgz", + "integrity": "sha1-C6vKU46NTuSg+JiNaIZlN6ADz0I=", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "minimalistic-assert": "^1.0.1" + } + }, + "he": { + "version": "1.2.0", + "resolved": "https://registry.nlark.com/he/download/he-1.2.0.tgz", + "integrity": "sha1-hK5l+n6vsWX922FWauFLrwVmTw8=", + "dev": true + }, + "hex-color-regex": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/hex-color-regex/download/hex-color-regex-1.1.0.tgz", + "integrity": "sha1-TAb8y0YC/iYCs8k9+C1+fb8aio4=", + "dev": true + }, + "highlight.js": { + "version": "10.7.3", + "resolved": "https://registry.nlark.com/highlight.js/download/highlight.js-10.7.3.tgz", + "integrity": "sha1-aXJy45kTVuQMPKxWanTu9oF1ZTE=", + "dev": true + }, + "hmac-drbg": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/hmac-drbg/download/hmac-drbg-1.0.1.tgz", + "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", + "dev": true, + "requires": { + "hash.js": "^1.0.3", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "hoopy": { + "version": "0.1.4", + "resolved": "https://registry.npm.taobao.org/hoopy/download/hoopy-0.1.4.tgz", + "integrity": "sha1-YJIH1mEQADOpqUAq096mdzgcGx0=", + "dev": true + }, + "hosted-git-info": { + "version": "2.8.9", + "resolved": "https://registry.nlark.com/hosted-git-info/download/hosted-git-info-2.8.9.tgz", + "integrity": "sha1-3/wL+aIcAiCQkPKqaUKeFBTa8/k=", + "dev": true + }, + "hpack.js": { + "version": "2.1.6", + "resolved": "https://registry.npm.taobao.org/hpack.js/download/hpack.js-2.1.6.tgz", + "integrity": "sha1-h3dMCUnlE/QuhFdbPEVoH63ioLI=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "obuf": "^1.0.0", + "readable-stream": "^2.0.1", + "wbuf": "^1.1.0" + } + }, + "hsl-regex": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/hsl-regex/download/hsl-regex-1.0.0.tgz", + "integrity": "sha1-1JMwx4ntgZ4nakwNJy3/owsY/m4=", + "dev": true + }, + "hsla-regex": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/hsla-regex/download/hsla-regex-1.0.0.tgz", + "integrity": "sha1-wc56MWjIxmFAM6S194d/OyJfnDg=", + "dev": true + }, + "html-encoding-sniffer": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/html-encoding-sniffer/download/html-encoding-sniffer-1.0.2.tgz", + "integrity": "sha1-5w2EuU2lOqN14R/jo1G+ZkLKRvg=", + "dev": true, + "requires": { + "whatwg-encoding": "^1.0.1" + } + }, + "html-entities": { + "version": "1.4.0", + "resolved": "https://registry.npm.taobao.org/html-entities/download/html-entities-1.4.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhtml-entities%2Fdownload%2Fhtml-entities-1.4.0.tgz", + "integrity": "sha1-z70bAdKvr5rcobEK59/6uYxx0tw=", + "dev": true + }, + "html-minifier": { + "version": "3.5.21", + "resolved": "https://registry.npm.taobao.org/html-minifier/download/html-minifier-3.5.21.tgz", + "integrity": "sha1-0AQOBUcw41TbAIRjWTGUAVIS0gw=", + "dev": true, + "requires": { + "camel-case": "3.0.x", + "clean-css": "4.2.x", + "commander": "2.17.x", + "he": "1.2.x", + "param-case": "2.1.x", + "relateurl": "0.2.x", + "uglify-js": "3.4.x" + } + }, + "html-tags": { + "version": "3.1.0", + "resolved": "https://registry.npm.taobao.org/html-tags/download/html-tags-3.1.0.tgz", + "integrity": "sha1-e15vfmZen7QfMAB+2eDUHpf7IUA=", + "dev": true + }, + "html-webpack-plugin": { + "version": "3.2.0", + "resolved": "https://registry.nlark.com/html-webpack-plugin/download/html-webpack-plugin-3.2.0.tgz", + "integrity": "sha1-sBq71yOsqqeze2r0SS69oD2d03s=", + "dev": true, + "requires": { + "html-minifier": "^3.2.3", + "loader-utils": "^0.2.16", + "lodash": "^4.17.3", + "pretty-error": "^2.0.2", + "tapable": "^1.0.0", + "toposort": "^1.0.0", + "util.promisify": "1.0.0" + }, + "dependencies": { + "big.js": { + "version": "3.2.0", + "resolved": "https://registry.nlark.com/big.js/download/big.js-3.2.0.tgz", + "integrity": "sha1-pfwpi4G54Nyi5FiCR4S2XFK6WI4=", + "dev": true + }, + "emojis-list": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/emojis-list/download/emojis-list-2.1.0.tgz", + "integrity": "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=", + "dev": true + }, + "json5": { + "version": "0.5.1", + "resolved": "https://registry.nlark.com/json5/download/json5-0.5.1.tgz", + "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=", + "dev": true + }, + "loader-utils": { + "version": "0.2.17", + "resolved": "https://registry.npm.taobao.org/loader-utils/download/loader-utils-0.2.17.tgz", + "integrity": "sha1-+G5jdNQyBabmxg6RlvF8Apm/s0g=", + "dev": true, + "requires": { + "big.js": "^3.1.3", + "emojis-list": "^2.0.0", + "json5": "^0.5.0", + "object-assign": "^4.0.1" + } + } + } + }, + "htmlparser2": { + "version": "6.1.0", + "resolved": "https://registry.npm.taobao.org/htmlparser2/download/htmlparser2-6.1.0.tgz?cache=0&sync_timestamp=1617915295732&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhtmlparser2%2Fdownload%2Fhtmlparser2-6.1.0.tgz", + "integrity": "sha1-xNditsM3GgXb5l6UrkOp+EX7j7c=", + "dev": true, + "requires": { + "domelementtype": "^2.0.1", + "domhandler": "^4.0.0", + "domutils": "^2.5.2", + "entities": "^2.0.0" + } + }, + "http-deceiver": { + "version": "1.2.7", + "resolved": "https://registry.npm.taobao.org/http-deceiver/download/http-deceiver-1.2.7.tgz", + "integrity": "sha1-+nFolEq5pRnTN8sL7HKE3D5yPYc=", + "dev": true + }, + "http-errors": { + "version": "1.7.2", + "resolved": "https://registry.npm.taobao.org/http-errors/download/http-errors-1.7.2.tgz", + "integrity": "sha1-T1ApzxMjnzEDblsuVSkrz7zIXI8=", + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.1", + "statuses": ">= 1.5.0 < 2", + "toidentifier": "1.0.0" + }, + "dependencies": { + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npm.taobao.org/inherits/download/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + } + } + }, + "http-parser-js": { + "version": "0.5.3", + "resolved": "https://registry.npm.taobao.org/http-parser-js/download/http-parser-js-0.5.3.tgz?cache=0&sync_timestamp=1609540073700&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhttp-parser-js%2Fdownload%2Fhttp-parser-js-0.5.3.tgz", + "integrity": "sha1-AdJwnHnUFpi7AdTezF6dpOSgM9k=", + "dev": true + }, + "http-proxy": { + "version": "1.18.1", + "resolved": "https://registry.nlark.com/http-proxy/download/http-proxy-1.18.1.tgz", + "integrity": "sha1-QBVB8FNIhLv5UmAzTnL4juOXZUk=", + "dev": true, + "requires": { + "eventemitter3": "^4.0.0", + "follow-redirects": "^1.0.0", + "requires-port": "^1.0.0" + } + }, + "http-proxy-agent": { + "version": "4.0.1", + "resolved": "https://registry.npmmirror.com/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", + "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", + "requires": { + "@tootallnate/once": "1", + "agent-base": "6", + "debug": "4" + } + }, + "http-proxy-middleware": { + "version": "1.3.1", + "resolved": "https://registry.nlark.com/http-proxy-middleware/download/http-proxy-middleware-1.3.1.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fhttp-proxy-middleware%2Fdownload%2Fhttp-proxy-middleware-1.3.1.tgz", + "integrity": "sha1-Q3ANbZ7st0Gb8IahKND3IF2etmU=", + "dev": true, + "requires": { + "@types/http-proxy": "^1.17.5", + "http-proxy": "^1.18.1", + "is-glob": "^4.0.1", + "is-plain-obj": "^3.0.0", + "micromatch": "^4.0.2" + }, + "dependencies": { + "braces": { + "version": "3.0.2", + "resolved": "https://registry.nlark.com/braces/download/braces-3.0.2.tgz", + "integrity": "sha1-NFThpGLujVmeI23zNs2epPiv4Qc=", + "dev": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.nlark.com/fill-range/download/fill-range-7.0.1.tgz", + "integrity": "sha1-GRmmp8df44ssfHflGYU12prN2kA=", + "dev": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npm.taobao.org/is-number/download/is-number-7.0.0.tgz", + "integrity": "sha1-dTU0W4lnNNX4DE0GxQlVUnoU8Ss=", + "dev": true + }, + "micromatch": { + "version": "4.0.4", + "resolved": "https://registry.npm.taobao.org/micromatch/download/micromatch-4.0.4.tgz?cache=0&sync_timestamp=1618054841521&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmicromatch%2Fdownload%2Fmicromatch-4.0.4.tgz", + "integrity": "sha1-iW1Rnf6dsl/OlM63pQCRm/iB6/k=", + "dev": true, + "requires": { + "braces": "^3.0.1", + "picomatch": "^2.2.3" + } + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.nlark.com/to-regex-range/download/to-regex-range-5.0.1.tgz", + "integrity": "sha1-FkjESq58jZiKMmAY7XL1tN0DkuQ=", + "dev": true, + "requires": { + "is-number": "^7.0.0" + } + } + } + }, + "http-signature": { + "version": "1.2.0", + "resolved": "https://registry.nlark.com/http-signature/download/http-signature-1.2.0.tgz", + "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0", + "jsprim": "^1.2.2", + "sshpk": "^1.7.0" + } + }, + "https-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/https-browserify/download/https-browserify-1.0.0.tgz", + "integrity": "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=", + "dev": true + }, + "https-proxy-agent": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", + "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", + "requires": { + "agent-base": "6", + "debug": "4" + } + }, + "human-signals": { + "version": "1.1.1", + "resolved": "https://registry.nlark.com/human-signals/download/human-signals-1.1.1.tgz", + "integrity": "sha1-xbHNFPUK6uCatsWf5jujOV/k36M=", + "dev": true + }, + "humanize-ms": { + "version": "1.2.1", + "resolved": "https://registry.npmmirror.com/humanize-ms/-/humanize-ms-1.2.1.tgz", + "integrity": "sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ==", + "requires": { + "ms": "^2.0.0" + } + }, + "iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.nlark.com/iconv-lite/download/iconv-lite-0.4.24.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ficonv-lite%2Fdownload%2Ficonv-lite-0.4.24.tgz", + "integrity": "sha1-ICK0sl+93CHS9SSXSkdKr+czkIs=", + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "icss-utils": { + "version": "4.1.1", + "resolved": "https://registry.npm.taobao.org/icss-utils/download/icss-utils-4.1.1.tgz?cache=0&sync_timestamp=1605801312995&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Ficss-utils%2Fdownload%2Ficss-utils-4.1.1.tgz", + "integrity": "sha1-IRcLU3ie4nRHwvR91oMIFAP5pGc=", + "dev": true, + "requires": { + "postcss": "^7.0.14" + } + }, + "ieee754": { + "version": "1.2.1", + "resolved": "https://registry.npm.taobao.org/ieee754/download/ieee754-1.2.1.tgz", + "integrity": "sha1-jrehCmP/8l0VpXsAFYbRd9Gw01I=", + "dev": true + }, + "iferr": { + "version": "0.1.5", + "resolved": "https://registry.npm.taobao.org/iferr/download/iferr-0.1.5.tgz", + "integrity": "sha1-xg7taebY/bazEEofy8ocGS3FtQE=", + "dev": true + }, + "ignore": { + "version": "4.0.6", + "resolved": "https://registry.npm.taobao.org/ignore/download/ignore-4.0.6.tgz", + "integrity": "sha1-dQ49tYYgh7RzfrrIIH/9HvJ7Jfw=", + "dev": true + }, + "image-size": { + "version": "0.5.5", + "resolved": "https://registry.npm.taobao.org/image-size/download/image-size-0.5.5.tgz?cache=0&sync_timestamp=1618422657851&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fimage-size%2Fdownload%2Fimage-size-0.5.5.tgz", + "integrity": "sha1-Cd/Uq50g4p6xw+gLiZA3jfnjy5w=", + "optional": true + }, + "immutable": { + "version": "4.3.7", + "resolved": "https://registry.npmmirror.com/immutable/-/immutable-4.3.7.tgz", + "integrity": "sha512-1hqclzwYwjRDFLjcFxOM5AYkkG0rpFPpr1RLPMEuGczoS7YA8gLhy8SWXYRAA/XwfEHpfo3cw5JGioS32fnMRw==", + "dev": true + }, + "import-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/import-cwd/download/import-cwd-2.1.0.tgz", + "integrity": "sha1-qmzzbnInYShcs3HsZRn1PiQ1sKk=", + "dev": true, + "requires": { + "import-from": "^2.1.0" + } + }, + "import-fresh": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/import-fresh/download/import-fresh-2.0.0.tgz?cache=0&sync_timestamp=1608469532269&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fimport-fresh%2Fdownload%2Fimport-fresh-2.0.0.tgz", + "integrity": "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=", + "dev": true, + "requires": { + "caller-path": "^2.0.0", + "resolve-from": "^3.0.0" + } + }, + "import-from": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/import-from/download/import-from-2.1.0.tgz", + "integrity": "sha1-M1238qev/VOqpHHUuAId7ja387E=", + "dev": true, + "requires": { + "resolve-from": "^3.0.0" + } + }, + "import-local": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/import-local/download/import-local-2.0.0.tgz", + "integrity": "sha1-VQcL44pZk88Y72236WH1vuXFoJ0=", + "dev": true, + "requires": { + "pkg-dir": "^3.0.0", + "resolve-cwd": "^2.0.0" + }, + "dependencies": { + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/pkg-dir/download/pkg-dir-3.0.0.tgz?cache=0&sync_timestamp=1618847182947&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpkg-dir%2Fdownload%2Fpkg-dir-3.0.0.tgz", + "integrity": "sha1-J0kCDyOe2ZCIGx9xIQ1R62UjvqM=", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + } + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npm.taobao.org/imurmurhash/download/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", + "dev": true + }, + "indexes-of": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/indexes-of/download/indexes-of-1.0.1.tgz", + "integrity": "sha1-8w9xbI4r00bHtn0985FVZqfAVgc=", + "dev": true + }, + "infer-owner": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/infer-owner/download/infer-owner-1.0.4.tgz", + "integrity": "sha1-xM78qo5RBRwqQLos6KPScpWvlGc=", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.nlark.com/inflight/download/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npm.taobao.org/inherits/download/inherits-2.0.4.tgz", + "integrity": "sha1-D6LGT5MpF8NDOg3tVTY6rjdBa3w=" + }, + "inquirer": { + "version": "7.3.3", + "resolved": "https://registry.nlark.com/inquirer/download/inquirer-7.3.3.tgz?cache=0&sync_timestamp=1623781150792&other_urls=https%3A%2F%2Fregistry.nlark.com%2Finquirer%2Fdownload%2Finquirer-7.3.3.tgz", + "integrity": "sha1-BNF2sq8Er8FXqD/XwQDpjuCq0AM=", + "dev": true, + "requires": { + "ansi-escapes": "^4.2.1", + "chalk": "^4.1.0", + "cli-cursor": "^3.1.0", + "cli-width": "^3.0.0", + "external-editor": "^3.0.3", + "figures": "^3.0.0", + "lodash": "^4.17.19", + "mute-stream": "0.0.8", + "run-async": "^2.4.0", + "rxjs": "^6.6.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0", + "through": "^2.3.6" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-5.0.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-5.0.0.tgz", + "integrity": "sha1-OIU59VF5vzkznIGvMKZU1p+Hy3U=", + "dev": true + }, + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.nlark.com/ansi-styles/download/ansi-styles-4.3.0.tgz?cache=0&sync_timestamp=1618995547052&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-styles%2Fdownload%2Fansi-styles-4.3.0.tgz", + "integrity": "sha1-7dgDYornHATIWuegkG7a00tkiTc=", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/color-convert/download/color-convert-2.0.1.tgz", + "integrity": "sha1-ctOmjVmMm9s68q0ehPIdiWq9TeM=", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.nlark.com/color-name/download/color-name-1.1.4.tgz", + "integrity": "sha1-wqCah6y95pVD3m9j+jmVyCbFNqI=", + "dev": true + }, + "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 + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/is-fullwidth-code-point/download/is-fullwidth-code-point-3.0.0.tgz?cache=0&sync_timestamp=1618552469710&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-fullwidth-code-point%2Fdownload%2Fis-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha1-8Rb4Bk/pCz94RKOJl8C3UFEmnx0=", + "dev": true + }, + "string-width": { + "version": "4.2.2", + "resolved": "https://registry.nlark.com/string-width/download/string-width-4.2.2.tgz", + "integrity": "sha1-2v1PlVmnWFz7pSnGoKT3NIjr1MU=", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.0" + } + }, + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-6.0.0.tgz", + "integrity": "sha1-CxVx3XZpzNTz4G4U7x7tJiJa5TI=", + "dev": true, + "requires": { + "ansi-regex": "^5.0.0" + } + }, + "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, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "internal-ip": { + "version": "4.3.0", + "resolved": "https://registry.npm.taobao.org/internal-ip/download/internal-ip-4.3.0.tgz", + "integrity": "sha1-hFRSuq2dLKO2nGNaE3rLmg2tCQc=", + "dev": true, + "requires": { + "default-gateway": "^4.2.0", + "ipaddr.js": "^1.9.0" + }, + "dependencies": { + "default-gateway": { + "version": "4.2.0", + "resolved": "https://registry.npm.taobao.org/default-gateway/download/default-gateway-4.2.0.tgz?cache=0&sync_timestamp=1610365816953&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdefault-gateway%2Fdownload%2Fdefault-gateway-4.2.0.tgz", + "integrity": "sha1-FnEEx1AMIRX23WmwpTa7jtcgVSs=", + "dev": true, + "requires": { + "execa": "^1.0.0", + "ip-regex": "^2.1.0" + } + } + } + }, + "interpret": { + "version": "1.4.0", + "resolved": "https://registry.npm.taobao.org/interpret/download/interpret-1.4.0.tgz", + "integrity": "sha1-Zlq4vE2iendKQFhOgS4+D6RbGh4=", + "dev": true + }, + "ip": { + "version": "1.1.5", + "resolved": "https://registry.nlark.com/ip/download/ip-1.1.5.tgz", + "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=" + }, + "ip-regex": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/ip-regex/download/ip-regex-2.1.0.tgz", + "integrity": "sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk=", + "dev": true + }, + "ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.nlark.com/ipaddr.js/download/ipaddr.js-1.9.1.tgz", + "integrity": "sha1-v/OFQ+64mEglB5/zoqjmy9RngbM=", + "dev": true + }, + "is-absolute-url": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/is-absolute-url/download/is-absolute-url-2.1.0.tgz", + "integrity": "sha1-UFMN+4T8yap9vnhS6Do3uTufKqY=", + "dev": true + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/is-accessor-descriptor/download/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha1-FpwvbT3x+ZJhgHI2XJsOofaHhlY=", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-arguments": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/is-arguments/download/is-arguments-1.1.0.tgz?cache=0&sync_timestamp=1607117404740&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-arguments%2Fdownload%2Fis-arguments-1.1.0.tgz", + "integrity": "sha1-YjUwMd++4HzrNGVqa95Z7+yujdk=", + "dev": true, + "requires": { + "call-bind": "^1.0.0" + } + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.nlark.com/is-arrayish/download/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", + "dev": true + }, + "is-bigint": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/is-bigint/download/is-bigint-1.0.2.tgz", + "integrity": "sha1-/7OBRCUDI1rSReqJ5Fs9v/BA7lo=", + "dev": true + }, + "is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/is-binary-path/download/is-binary-path-1.0.1.tgz", + "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "dev": true, + "requires": { + "binary-extensions": "^1.0.0" + } + }, + "is-boolean-object": { + "version": "1.1.1", + "resolved": "https://registry.nlark.com/is-boolean-object/download/is-boolean-object-1.1.1.tgz?cache=0&sync_timestamp=1620428521406&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-boolean-object%2Fdownload%2Fis-boolean-object-1.1.1.tgz", + "integrity": "sha1-PAh48DXLghIo01DS4eNnGXFqPeg=", + "dev": true, + "requires": { + "call-bind": "^1.0.2" + } + }, + "is-buffer": { + "version": "2.0.5", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-2.0.5.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-2.0.5.tgz", + "integrity": "sha1-68JS5ADSL/jXf6CYiIIaJKZYwZE=", + "dev": true + }, + "is-callable": { + "version": "1.2.3", + "resolved": "https://registry.npm.taobao.org/is-callable/download/is-callable-1.2.3.tgz", + "integrity": "sha1-ix4FALc6HXbHBIdjbzaOUZ3o244=", + "dev": true + }, + "is-ci": { + "version": "1.2.1", + "resolved": "https://registry.npm.taobao.org/is-ci/download/is-ci-1.2.1.tgz?cache=0&sync_timestamp=1613632097993&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-ci%2Fdownload%2Fis-ci-1.2.1.tgz", + "integrity": "sha1-43ecjuF/zPQoSI9uKBGH8uYyhBw=", + "dev": true, + "requires": { + "ci-info": "^1.5.0" + } + }, + "is-class-hotfix": { + "version": "0.0.6", + "resolved": "https://registry.npmmirror.com/is-class-hotfix/-/is-class-hotfix-0.0.6.tgz", + "integrity": "sha512-0n+pzCC6ICtVr/WXnN2f03TK/3BfXY7me4cjCAqT8TYXEl0+JBRoqBo94JJHXcyDSLUeWbNX8Fvy5g5RJdAstQ==" + }, + "is-color-stop": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/is-color-stop/download/is-color-stop-1.1.0.tgz", + "integrity": "sha1-z/9HGu5N1cnhWFmPvhKWe1za00U=", + "dev": true, + "requires": { + "css-color-names": "^0.0.4", + "hex-color-regex": "^1.1.0", + "hsl-regex": "^1.0.0", + "hsla-regex": "^1.0.0", + "rgb-regex": "^1.0.1", + "rgba-regex": "^1.0.0" + } + }, + "is-core-module": { + "version": "2.5.0", + "resolved": "https://registry.nlark.com/is-core-module/download/is-core-module-2.5.0.tgz?cache=0&sync_timestamp=1626158736739&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-core-module%2Fdownload%2Fis-core-module-2.5.0.tgz", + "integrity": "sha1-91SENhfHC/0pt72HMnQAzaXBhJE=", + "dev": true, + "requires": { + "has": "^1.0.3" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/is-data-descriptor/download/is-data-descriptor-1.0.0.tgz", + "integrity": "sha1-2Eh2Mh0Oet0DmQQGq7u9NrqSaMc=", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-date-object": { + "version": "1.0.4", + "resolved": "https://registry.nlark.com/is-date-object/download/is-date-object-1.0.4.tgz", + "integrity": "sha1-VQz8wDr62gXuo90wmBx7CVUfc+U=", + "dev": true + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/is-descriptor/download/is-descriptor-1.0.2.tgz", + "integrity": "sha1-OxWXRqZmBLBPjIFSS6NlxfFNhuw=", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "is-directory": { + "version": "0.3.1", + "resolved": "https://registry.npm.taobao.org/is-directory/download/is-directory-0.3.1.tgz", + "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=", + "dev": true + }, + "is-docker": { + "version": "2.2.1", + "resolved": "https://registry.npm.taobao.org/is-docker/download/is-docker-2.2.1.tgz?cache=0&sync_timestamp=1617958823824&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-docker%2Fdownload%2Fis-docker-2.2.1.tgz", + "integrity": "sha1-M+6r4jz+hvFL3kQIoCwM+4U6zao=", + "dev": true + }, + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-1.0.1.tgz", + "integrity": "sha1-p0cPnkJnM9gb2B4RVSZOOjUHyrQ=", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npm.taobao.org/is-extglob/download/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/is-fullwidth-code-point/download/is-fullwidth-code-point-2.0.0.tgz?cache=0&sync_timestamp=1618552469710&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-fullwidth-code-point%2Fdownload%2Fis-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + }, + "is-glob": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/is-glob/download/is-glob-4.0.1.tgz", + "integrity": "sha1-dWfb6fL14kZ7x3q4PEopSCQHpdw=", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-negative-zero": { + "version": "2.0.1", + "resolved": "https://registry.nlark.com/is-negative-zero/download/is-negative-zero-2.0.1.tgz", + "integrity": "sha1-PedGwY3aIxkkGlNnWQjY92bxHCQ=", + "dev": true + }, + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/is-number/download/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-number-object": { + "version": "1.0.5", + "resolved": "https://registry.nlark.com/is-number-object/download/is-number-object-1.0.5.tgz?cache=0&sync_timestamp=1620421575334&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-number-object%2Fdownload%2Fis-number-object-1.0.5.tgz", + "integrity": "sha1-bt+u7XlQz/Ga/tzp+/yp7m3Sies=", + "dev": true + }, + "is-obj": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/is-obj/download/is-obj-2.0.0.tgz", + "integrity": "sha1-Rz+wXZc3BeP9liBUUBjKjiLvSYI=", + "dev": true + }, + "is-path-cwd": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/is-path-cwd/download/is-path-cwd-2.2.0.tgz", + "integrity": "sha1-Z9Q7gmZKe1GR/ZEZEn6zAASKn9s=", + "dev": true + }, + "is-path-in-cwd": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/is-path-in-cwd/download/is-path-in-cwd-2.1.0.tgz?cache=0&sync_timestamp=1620047110449&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-path-in-cwd%2Fdownload%2Fis-path-in-cwd-2.1.0.tgz", + "integrity": "sha1-v+Lcomxp85cmWkAJljYCk1oFOss=", + "dev": true, + "requires": { + "is-path-inside": "^2.1.0" + } + }, + "is-path-inside": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/is-path-inside/download/is-path-inside-2.1.0.tgz?cache=0&sync_timestamp=1620046845369&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-path-inside%2Fdownload%2Fis-path-inside-2.1.0.tgz", + "integrity": "sha1-fJgQWH1lmkDSe8201WFuqwWUlLI=", + "dev": true, + "requires": { + "path-is-inside": "^1.0.2" + } + }, + "is-plain-obj": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/is-plain-obj/download/is-plain-obj-3.0.0.tgz?cache=0&sync_timestamp=1618600554597&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-plain-obj%2Fdownload%2Fis-plain-obj-3.0.0.tgz", + "integrity": "sha1-r28uoUrFpkYYOlu9tbqrvBVq2dc=", + "dev": true + }, + "is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npm.taobao.org/is-plain-object/download/is-plain-object-2.0.4.tgz", + "integrity": "sha1-LBY7P6+xtgbZ0Xko8FwqHDjgdnc=", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "is-regex": { + "version": "1.1.3", + "resolved": "https://registry.nlark.com/is-regex/download/is-regex-1.1.3.tgz", + "integrity": "sha1-0Cn5r/ZEi5Prvj8z2scVEf3L758=", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-symbols": "^1.0.2" + } + }, + "is-resolvable": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/is-resolvable/download/is-resolvable-1.1.0.tgz", + "integrity": "sha1-+xj4fOH+uSUWnJpAfBkxijIG7Yg=", + "dev": true + }, + "is-stream": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/is-stream/download/is-stream-1.1.0.tgz", + "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", + "dev": true + }, + "is-string": { + "version": "1.0.6", + "resolved": "https://registry.nlark.com/is-string/download/is-string-1.0.6.tgz?cache=0&sync_timestamp=1620448217105&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-string%2Fdownload%2Fis-string-1.0.6.tgz", + "integrity": "sha1-P+XVmS+w2TQE8yWE1LAXmnG1Sl8=", + "dev": true + }, + "is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.nlark.com/is-symbol/download/is-symbol-1.0.4.tgz?cache=0&sync_timestamp=1620502244179&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-symbol%2Fdownload%2Fis-symbol-1.0.4.tgz", + "integrity": "sha1-ptrJO2NbBjymhyI23oiRClevE5w=", + "dev": true, + "requires": { + "has-symbols": "^1.0.2" + } + }, + "is-type-of": { + "version": "1.2.1", + "resolved": "https://registry.npmmirror.com/is-type-of/-/is-type-of-1.2.1.tgz", + "integrity": "sha512-uK0kyX9LZYhSDS7H2sVJQJop1UnWPWmo5RvR3q2kFH6AUHYs7sOrVg0b4nyBHw29kRRNFofYN/JbHZDlHiItTA==", + "requires": { + "core-util-is": "^1.0.2", + "is-class-hotfix": "~0.0.6", + "isstream": "~0.1.2" + } + }, + "is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/is-typedarray/download/is-typedarray-1.0.0.tgz", + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", + "dev": true + }, + "is-what": { + "version": "3.14.1", + "resolved": "https://registry.npm.taobao.org/is-what/download/is-what-3.14.1.tgz?cache=0&sync_timestamp=1615169735707&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-what%2Fdownload%2Fis-what-3.14.1.tgz", + "integrity": "sha1-4SIvRt3ahd6tD9HJ3xMXYOd3VcE=" + }, + "is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/is-windows/download/is-windows-1.0.2.tgz", + "integrity": "sha1-0YUOuXkezRjmGCzhKjDzlmNLsZ0=", + "dev": true + }, + "is-wsl": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/is-wsl/download/is-wsl-2.2.0.tgz", + "integrity": "sha1-dKTHbnfKn9P5MvKQwX6jJs0VcnE=", + "dev": true, + "requires": { + "is-docker": "^2.0.0" + } + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/isarray/download/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/isexe/download/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", + "dev": true + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.nlark.com/isobject/download/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", + "dev": true + }, + "isstream": { + "version": "0.1.2", + "resolved": "https://registry.npm.taobao.org/isstream/download/isstream-0.1.2.tgz", + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" + }, + "javascript-stringify": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/javascript-stringify/download/javascript-stringify-2.1.0.tgz", + "integrity": "sha1-J8dlOb4U2L0Sghmi1zGwkzeQTnk=", + "dev": true + }, + "js-base64": { + "version": "2.6.4", + "resolved": "https://registry.npmmirror.com/js-base64/-/js-base64-2.6.4.tgz", + "integrity": "sha512-pZe//GGmwJndub7ZghVHz7vjb2LgC1m8B07Au3eYqeqv9emhESByMXxaEgkUkEqJe87oBbSniGYoQNIBklc7IQ==" + }, + "js-message": { + "version": "1.0.7", + "resolved": "https://registry.npmmirror.com/js-message/-/js-message-1.0.7.tgz", + "integrity": "sha512-efJLHhLjIyKRewNS9EGZ4UpI8NguuL6fKkhRxVuMmrGV2xN/0APGdQYwLFky5w9naebSZ0OwAGp0G6/2Cg90rA==", + "dev": true + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.nlark.com/js-tokens/download/js-tokens-4.0.0.tgz?cache=0&sync_timestamp=1619345098261&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fjs-tokens%2Fdownload%2Fjs-tokens-4.0.0.tgz", + "integrity": "sha1-GSA/tZmR35jjoocFDUZHzerzJJk=", + "dev": true + }, + "js-yaml": { + "version": "3.13.1", + "resolved": "https://registry.npm.taobao.org/js-yaml/download/js-yaml-3.13.1.tgz?cache=0&sync_timestamp=1618435151523&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjs-yaml%2Fdownload%2Fjs-yaml-3.13.1.tgz", + "integrity": "sha1-r/FRswv9+o5J4F2iLnQV6d+jeEc=", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsbn": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/jsbn/download/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", + "dev": true + }, + "jsdom": { + "version": "15.2.1", + "resolved": "https://registry.nlark.com/jsdom/download/jsdom-15.2.1.tgz", + "integrity": "sha1-0v6xrvcYP4a+UhuMaDP/UpbQfsU=", + "dev": true, + "requires": { + "abab": "^2.0.0", + "acorn": "^7.1.0", + "acorn-globals": "^4.3.2", + "array-equal": "^1.0.0", + "cssom": "^0.4.1", + "cssstyle": "^2.0.0", + "data-urls": "^1.1.0", + "domexception": "^1.0.1", + "escodegen": "^1.11.1", + "html-encoding-sniffer": "^1.0.2", + "nwsapi": "^2.2.0", + "parse5": "5.1.0", + "pn": "^1.1.0", + "request": "^2.88.0", + "request-promise-native": "^1.0.7", + "saxes": "^3.1.9", + "symbol-tree": "^3.2.2", + "tough-cookie": "^3.0.1", + "w3c-hr-time": "^1.0.1", + "w3c-xmlserializer": "^1.1.2", + "webidl-conversions": "^4.0.2", + "whatwg-encoding": "^1.0.5", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^7.0.0", + "ws": "^7.0.0", + "xml-name-validator": "^3.0.0" + }, + "dependencies": { + "parse5": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/parse5/download/parse5-5.1.0.tgz", + "integrity": "sha1-xZNByXI/QUxFKXVWTHwApo1YrNI=", + "dev": true + }, + "tough-cookie": { + "version": "3.0.1", + "resolved": "https://registry.npm.taobao.org/tough-cookie/download/tough-cookie-3.0.1.tgz", + "integrity": "sha1-nfT1fnOcJpMKAYGEiH9K233Kc7I=", + "dev": true, + "requires": { + "ip-regex": "^2.1.0", + "psl": "^1.1.28", + "punycode": "^2.1.1" + } + } + } + }, + "jsdom-global": { + "version": "3.0.2", + "resolved": "https://registry.npm.taobao.org/jsdom-global/download/jsdom-global-3.0.2.tgz", + "integrity": "sha1-a9KZwTsMRiay2iwDk81DhdYGrLk=", + "dev": true + }, + "jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npm.taobao.org/jsesc/download/jsesc-2.5.2.tgz?cache=0&sync_timestamp=1603891242793&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjsesc%2Fdownload%2Fjsesc-2.5.2.tgz", + "integrity": "sha1-gFZNLkg9rPbo7yCWUKZ98/DCg6Q=", + "dev": true + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/json-parse-better-errors/download/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha1-u4Z8+zRQ5pEHwTHRxRS6s9yLyqk=", + "dev": true + }, + "json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npm.taobao.org/json-parse-even-better-errors/download/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha1-fEeAWpQxmSjgV3dAXcEuH3pO4C0=", + "dev": true + }, + "json-schema": { + "version": "0.2.3", + "resolved": "https://registry.npm.taobao.org/json-schema/download/json-schema-0.2.3.tgz", + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", + "dev": true + }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.nlark.com/json-schema-traverse/download/json-schema-traverse-0.4.1.tgz", + "integrity": "sha1-afaofZUTq4u4/mO9sJecRI5oRmA=", + "dev": true + }, + "json-stringify-safe": { + "version": "5.0.1", + "resolved": "https://registry.nlark.com/json-stringify-safe/download/json-stringify-safe-5.0.1.tgz", + "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", + "dev": true + }, + "json3": { + "version": "3.3.3", + "resolved": "https://registry.nlark.com/json3/download/json3-3.3.3.tgz", + "integrity": "sha1-f8EON1/FrkLEcFpcwKpvYr4wW4E=", + "dev": true + }, + "json5": { + "version": "2.2.0", + "resolved": "https://registry.nlark.com/json5/download/json5-2.2.0.tgz", + "integrity": "sha1-Lf7+cgxrpSXZ69kJlQ8FFTFsiaM=", + "dev": true, + "requires": { + "minimist": "^1.2.5" + } + }, + "jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npm.taobao.org/jsonfile/download/jsonfile-4.0.0.tgz?cache=0&sync_timestamp=1604161937969&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjsonfile%2Fdownload%2Fjsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "requires": { + "graceful-fs": "^4.1.6" + } + }, + "jsprim": { + "version": "1.4.1", + "resolved": "https://registry.npm.taobao.org/jsprim/download/jsprim-1.4.1.tgz", + "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", + "dev": true, + "requires": { + "assert-plus": "1.0.0", + "extsprintf": "1.3.0", + "json-schema": "0.2.3", + "verror": "1.10.0" + } + }, + "jstoxml": { + "version": "2.2.9", + "resolved": "https://registry.npmmirror.com/jstoxml/-/jstoxml-2.2.9.tgz", + "integrity": "sha512-OYWlK0j+roh+eyaMROlNbS5cd5R25Y+IUpdl7cNdB8HNrkgwQzIS7L9MegxOiWNBj9dQhA/yAxiMwCC5mwNoBw==" + }, + "killable": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/killable/download/killable-1.0.1.tgz", + "integrity": "sha1-TIzkQRh6Bhx0dPuHygjipjgZSJI=", + "dev": true + }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-6.0.3.tgz", + "integrity": "sha1-B8BQNKbDSfoG4k+jWqdttFgM5N0=", + "dev": true + }, + "klona": { + "version": "2.0.4", + "resolved": "https://registry.npm.taobao.org/klona/download/klona-2.0.4.tgz", + "integrity": "sha1-e7Hjr/sMuGJFR+9+j2cI6i4538A=", + "dev": true + }, + "ko-sleep": { + "version": "1.1.4", + "resolved": "https://registry.npmmirror.com/ko-sleep/-/ko-sleep-1.1.4.tgz", + "integrity": "sha512-s05WGpvvzyTuRlRE8fM7ru2Z3O+InbJuBcckTWKg2W+2c1k6SnFa3IfiSSt0/peFrlYAXgNoxuJWWVNmWh+K/A==", + "requires": { + "ms": "*" + } + }, + "launch-editor": { + "version": "2.2.1", + "resolved": "https://registry.npm.taobao.org/launch-editor/download/launch-editor-2.2.1.tgz", + "integrity": "sha1-hxtaPuOdZoD8wm03kwtu7aidsMo=", + "dev": true, + "requires": { + "chalk": "^2.3.0", + "shell-quote": "^1.6.1" + } + }, + "launch-editor-middleware": { + "version": "2.2.1", + "resolved": "https://registry.nlark.com/launch-editor-middleware/download/launch-editor-middleware-2.2.1.tgz", + "integrity": "sha1-4UsH5scVSwpLhqD9NFeE5FgEwVc=", + "dev": true, + "requires": { + "launch-editor": "^2.2.1" + } + }, + "less": { + "version": "4.1.1", + "resolved": "https://registry.npm.taobao.org/less/download/less-4.1.1.tgz?cache=0&sync_timestamp=1612065808998&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fless%2Fdownload%2Fless-4.1.1.tgz", + "integrity": "sha1-Fb8lOpk5eR3GkIiMP/Qk8+bH7bo=", + "requires": { + "copy-anything": "^2.0.1", + "errno": "^0.1.1", + "graceful-fs": "^4.1.2", + "image-size": "~0.5.0", + "make-dir": "^2.1.0", + "mime": "^1.4.1", + "needle": "^2.5.2", + "parse-node-version": "^1.0.1", + "source-map": "~0.6.0", + "tslib": "^1.10.0" + }, + "dependencies": { + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/make-dir/download/make-dir-2.1.0.tgz", + "integrity": "sha1-XwMQ4YuL6JjMBwCSlaMK5B6R5vU=", + "optional": true, + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + } + }, + "mime": { + "version": "1.6.0", + "resolved": "https://registry.nlark.com/mime/download/mime-1.6.0.tgz", + "integrity": "sha1-Ms2eXGRVO9WNGaVor0Uqz/BJgbE=", + "optional": true + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.nlark.com/semver/download/semver-5.7.1.tgz", + "integrity": "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=", + "optional": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "optional": true + }, + "tslib": { + "version": "1.14.1", + "resolved": "https://registry.nlark.com/tslib/download/tslib-1.14.1.tgz", + "integrity": "sha1-zy04vcNKE0vK8QkcQfZhni9nLQA=" + } + } + }, + "less-loader": { + "version": "7.3.0", + "resolved": "https://registry.nlark.com/less-loader/download/less-loader-7.3.0.tgz", + "integrity": "sha1-+dbTbRhznWQgZ6Bftb1wyMYTF+U=", + "dev": true, + "requires": { + "klona": "^2.0.4", + "loader-utils": "^2.0.0", + "schema-utils": "^3.0.0" + }, + "dependencies": { + "loader-utils": { + "version": "2.0.2", + "resolved": "https://registry.npmmirror.com/loader-utils/-/loader-utils-2.0.2.tgz", + "integrity": "sha512-TM57VeHptv569d/GKh6TAYdzKblwDNiumOdkFnejjD0XwTH87K90w3O7AiJRqdQoXygvi1VQTJTLGhJl7WqA7A==", + "dev": true, + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^2.1.2" + } + }, + "schema-utils": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/schema-utils/download/schema-utils-3.1.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-3.1.0.tgz", + "integrity": "sha1-lZhutgT2bare7Vbjeb/np/ljzbk=", + "dev": true, + "requires": { + "@types/json-schema": "^7.0.7", + "ajv": "^6.12.5", + "ajv-keywords": "^3.5.2" + } + } + } + }, + "levn": { + "version": "0.3.0", + "resolved": "https://registry.npm.taobao.org/levn/download/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", + "requires": { + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" + } + }, + "lines-and-columns": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/lines-and-columns/download/lines-and-columns-1.1.6.tgz", + "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=", + "dev": true + }, + "loader-fs-cache": { + "version": "1.0.3", + "resolved": "https://registry.nlark.com/loader-fs-cache/download/loader-fs-cache-1.0.3.tgz", + "integrity": "sha1-8IZXZG1gcHi+LwoDL4vWndbyd9k=", + "dev": true, + "requires": { + "find-cache-dir": "^0.1.1", + "mkdirp": "^0.5.1" + }, + "dependencies": { + "find-cache-dir": { + "version": "0.1.1", + "resolved": "https://registry.npm.taobao.org/find-cache-dir/download/find-cache-dir-0.1.1.tgz", + "integrity": "sha1-yN765XyKUqinhPnjHFfHQumToLk=", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "mkdirp": "^0.5.1", + "pkg-dir": "^1.0.0" + } + }, + "find-up": { + "version": "1.1.2", + "resolved": "https://registry.nlark.com/find-up/download/find-up-1.1.2.tgz", + "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "dev": true, + "requires": { + "path-exists": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + }, + "path-exists": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/path-exists/download/path-exists-2.1.0.tgz", + "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", + "dev": true, + "requires": { + "pinkie-promise": "^2.0.0" + } + }, + "pkg-dir": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/pkg-dir/download/pkg-dir-1.0.0.tgz?cache=0&sync_timestamp=1618847182947&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpkg-dir%2Fdownload%2Fpkg-dir-1.0.0.tgz", + "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", + "dev": true, + "requires": { + "find-up": "^1.0.0" + } + } + } + }, + "loader-runner": { + "version": "2.4.0", + "resolved": "https://registry.nlark.com/loader-runner/download/loader-runner-2.4.0.tgz", + "integrity": "sha1-7UcGa/5TTX6ExMe5mYwqdWB9k1c=", + "dev": true + }, + "loader-utils": { + "version": "1.4.0", + "resolved": "https://registry.npm.taobao.org/loader-utils/download/loader-utils-1.4.0.tgz", + "integrity": "sha1-xXm140yzSxp07cbB+za/o3HVphM=", + "dev": true, + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^1.0.1" + }, + "dependencies": { + "json5": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/json5/download/json5-1.0.1.tgz", + "integrity": "sha1-d5+wAYYE+oVOrL9iUhgNg1Q+Pb4=", + "dev": true, + "requires": { + "minimist": "^1.2.0" + } + } + } + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/locate-path/download/locate-path-3.0.0.tgz", + "integrity": "sha1-2+w7OrdZdYBxtY/ln8QYca8hQA4=", + "dev": true, + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "lodash": { + "version": "4.17.21", + "resolved": "https://registry.npm.taobao.org/lodash/download/lodash-4.17.21.tgz", + "integrity": "sha1-Z5WRxWTDv/quhFTPCz3zcMPWkRw=" + }, + "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==" + }, + "lodash-unified": { + "version": "1.0.2", + "resolved": "https://registry.npmmirror.com/lodash-unified/-/lodash-unified-1.0.2.tgz", + "integrity": "sha512-OGbEy+1P+UT26CYi4opY4gebD8cWRDxAT6MAObIVQMiqYdxZr1g3QHWCToVsm31x2NkLS4K3+MC2qInaRMa39g==" + }, + "lodash.clonedeep": { + "version": "4.5.0", + "resolved": "https://registry.npm.taobao.org/lodash.clonedeep/download/lodash.clonedeep-4.5.0.tgz", + "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", + "dev": true + }, + "lodash.debounce": { + "version": "4.0.8", + "resolved": "https://registry.npm.taobao.org/lodash.debounce/download/lodash.debounce-4.0.8.tgz", + "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=", + "dev": true + }, + "lodash.defaultsdeep": { + "version": "4.6.1", + "resolved": "https://registry.npm.taobao.org/lodash.defaultsdeep/download/lodash.defaultsdeep-4.6.1.tgz", + "integrity": "sha1-US6b1yHSctlOPTpjZT+hdRZ0HKY=", + "dev": true + }, + "lodash.kebabcase": { + "version": "4.1.1", + "resolved": "https://registry.npm.taobao.org/lodash.kebabcase/download/lodash.kebabcase-4.1.1.tgz", + "integrity": "sha1-hImxyw0p/4gZXM7KRI/21swpXDY=", + "dev": true + }, + "lodash.mapvalues": { + "version": "4.6.0", + "resolved": "https://registry.npm.taobao.org/lodash.mapvalues/download/lodash.mapvalues-4.6.0.tgz", + "integrity": "sha1-G6+lAF3p3W9PJmaMMMo3IwzJaJw=", + "dev": true + }, + "lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npm.taobao.org/lodash.memoize/download/lodash.memoize-4.1.2.tgz", + "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=", + "dev": true + }, + "lodash.sortby": { + "version": "4.7.0", + "resolved": "https://registry.npm.taobao.org/lodash.sortby/download/lodash.sortby-4.7.0.tgz", + "integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=", + "dev": true + }, + "lodash.transform": { + "version": "4.6.0", + "resolved": "https://registry.npm.taobao.org/lodash.transform/download/lodash.transform-4.6.0.tgz", + "integrity": "sha1-EjBkIvYzJK7YSD0/ODMrX2cFR6A=", + "dev": true + }, + "lodash.uniq": { + "version": "4.5.0", + "resolved": "https://registry.npm.taobao.org/lodash.uniq/download/lodash.uniq-4.5.0.tgz", + "integrity": "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=", + "dev": true + }, + "log-symbols": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/log-symbols/download/log-symbols-2.2.0.tgz", + "integrity": "sha1-V0Dhxdbw39pK2TI7UzIQfva0xAo=", + "dev": true, + "requires": { + "chalk": "^2.0.1" + } + }, + "loglevel": { + "version": "1.7.1", + "resolved": "https://registry.npm.taobao.org/loglevel/download/loglevel-1.7.1.tgz?cache=0&sync_timestamp=1606312222145&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Floglevel%2Fdownload%2Floglevel-1.7.1.tgz", + "integrity": "sha1-AF/eL15uRwaPk1/yhXPhJe9y8Zc=", + "dev": true + }, + "lower-case": { + "version": "1.1.4", + "resolved": "https://registry.npm.taobao.org/lower-case/download/lower-case-1.1.4.tgz", + "integrity": "sha1-miyr0bno4K6ZOkv31YdcOcQujqw=", + "dev": true + }, + "lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.nlark.com/lru-cache/download/lru-cache-5.1.1.tgz", + "integrity": "sha1-HaJ+ZxAnGUdpXa9oSOhH8B2EuSA=", + "requires": { + "yallist": "^3.0.2" + } + }, + "magic-string": { + "version": "0.25.7", + "resolved": "https://registry.npm.taobao.org/magic-string/download/magic-string-0.25.7.tgz", + "integrity": "sha1-P0l9b9NMZpxnmNy4IfLvMfVEUFE=", + "requires": { + "sourcemap-codec": "^1.4.4" + } + }, + "make-dir": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/make-dir/download/make-dir-3.1.0.tgz", + "integrity": "sha1-QV6WcEazp/HRhSd9hKpYIDcmoT8=", + "dev": true, + "requires": { + "semver": "^6.0.0" + } + }, + "map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npm.taobao.org/map-cache/download/map-cache-0.2.2.tgz", + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", + "dev": true + }, + "map-visit": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/map-visit/download/map-visit-1.0.0.tgz", + "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "dev": true, + "requires": { + "object-visit": "^1.0.0" + } + }, + "md5.js": { + "version": "1.3.5", + "resolved": "https://registry.npm.taobao.org/md5.js/download/md5.js-1.3.5.tgz", + "integrity": "sha1-tdB7jjIW4+J81yjXL3DR5qNCAF8=", + "dev": true, + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "mdn-data": { + "version": "2.0.4", + "resolved": "https://registry.nlark.com/mdn-data/download/mdn-data-2.0.4.tgz", + "integrity": "sha1-aZs8OKxvHXKAkaZGULZdOIUC/Vs=", + "dev": true + }, + "media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npm.taobao.org/media-typer/download/media-typer-0.3.0.tgz", + "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", + "dev": true + }, + "memoize-one": { + "version": "6.0.0", + "resolved": "https://registry.npmmirror.com/memoize-one/-/memoize-one-6.0.0.tgz", + "integrity": "sha512-rkpe71W0N0c0Xz6QD0eJETuWAJGnJ9afsl1srmwPrI+yBCkge5EycXXbYRyvL29zZVUWQCY7InPRCv3GDXuZNw==" + }, + "memory-fs": { + "version": "0.4.1", + "resolved": "https://registry.npm.taobao.org/memory-fs/download/memory-fs-0.4.1.tgz", + "integrity": "sha1-OpoguEYlI+RHz7x+i7gO1me/xVI=", + "dev": true, + "requires": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + } + }, + "merge-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/merge-descriptors/download/merge-descriptors-1.0.1.tgz", + "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" + }, + "merge-source-map": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/merge-source-map/download/merge-source-map-1.1.0.tgz", + "integrity": "sha1-L93n5gIJOfcJBqaPLXrmheTIxkY=", + "dev": true, + "requires": { + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/merge-stream/download/merge-stream-2.0.0.tgz", + "integrity": "sha1-UoI2KaFN0AyXcPtq1H3GMQ8sH2A=", + "dev": true + }, + "merge2": { + "version": "1.4.1", + "resolved": "https://registry.npm.taobao.org/merge2/download/merge2-1.4.1.tgz", + "integrity": "sha1-Q2iJL4hekHRVpv19xVwMnUBJkK4=", + "dev": true + }, + "methods": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/methods/download/methods-1.1.2.tgz", + "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", + "dev": true + }, + "micromatch": { + "version": "3.1.10", + "resolved": "https://registry.npm.taobao.org/micromatch/download/micromatch-3.1.10.tgz?cache=0&sync_timestamp=1618054841521&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmicromatch%2Fdownload%2Fmicromatch-3.1.10.tgz", + "integrity": "sha1-cIWbyVyYQJUvNZoGij/En57PrCM=", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + } + }, + "miller-rabin": { + "version": "4.0.1", + "resolved": "https://registry.npm.taobao.org/miller-rabin/download/miller-rabin-4.0.1.tgz", + "integrity": "sha1-8IA1HIZbDcViqEYpZtqlNUPHik0=", + "dev": true, + "requires": { + "bn.js": "^4.0.0", + "brorand": "^1.0.1" + }, + "dependencies": { + "bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz", + "integrity": "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=", + "dev": true + } + } + }, + "mime": { + "version": "2.5.2", + "resolved": "https://registry.nlark.com/mime/download/mime-2.5.2.tgz", + "integrity": "sha1-bj3GzCuVEGQ4MOXxnVy3U9pe6r4=" + }, + "mime-db": { + "version": "1.48.0", + "resolved": "https://registry.nlark.com/mime-db/download/mime-db-1.48.0.tgz?cache=0&sync_timestamp=1622433567590&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fmime-db%2Fdownload%2Fmime-db-1.48.0.tgz", + "integrity": "sha1-41sxBF3X6to6qtU37YijOvvvLR0=", + "dev": true + }, + "mime-types": { + "version": "2.1.31", + "resolved": "https://registry.nlark.com/mime-types/download/mime-types-2.1.31.tgz?cache=0&sync_timestamp=1622569304088&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fmime-types%2Fdownload%2Fmime-types-2.1.31.tgz", + "integrity": "sha1-oA12t0MXxh+cLbIhi46fjpxcnms=", + "dev": true, + "requires": { + "mime-db": "1.48.0" + } + }, + "mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/mimic-fn/download/mimic-fn-2.1.0.tgz?cache=0&sync_timestamp=1617823674050&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmimic-fn%2Fdownload%2Fmimic-fn-2.1.0.tgz", + "integrity": "sha1-ftLCzMyvhNP/y3pptXcR/CCDQBs=", + "dev": true + }, + "mini-css-extract-plugin": { + "version": "0.9.0", + "resolved": "https://registry.nlark.com/mini-css-extract-plugin/download/mini-css-extract-plugin-0.9.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fmini-css-extract-plugin%2Fdownload%2Fmini-css-extract-plugin-0.9.0.tgz", + "integrity": "sha1-R/LPB6oWWrNXM7H8l9TEbAVkM54=", + "dev": true, + "requires": { + "loader-utils": "^1.1.0", + "normalize-url": "1.9.1", + "schema-utils": "^1.0.0", + "webpack-sources": "^1.1.0" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/schema-utils/download/schema-utils-1.0.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-1.0.0.tgz", + "integrity": "sha1-C3mpMgTXtgDUsoUNH2bCo0lRx3A=", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "minimalistic-assert": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/minimalistic-assert/download/minimalistic-assert-1.0.1.tgz", + "integrity": "sha1-LhlN4ERibUoQ5/f7wAznPoPk1cc=", + "dev": true + }, + "minimalistic-crypto-utils": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/minimalistic-crypto-utils/download/minimalistic-crypto-utils-1.0.1.tgz", + "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=", + "dev": true + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npm.taobao.org/minimatch/download/minimatch-3.0.4.tgz", + "integrity": "sha1-UWbihkV/AzBgZL5Ul+jbsMPTIIM=", + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.5", + "resolved": "https://registry.nlark.com/minimist/download/minimist-1.2.5.tgz", + "integrity": "sha1-Z9ZgFLZqaoqqDAg8X9WN9OTpdgI=" + }, + "minipass": { + "version": "3.1.3", + "resolved": "https://registry.npm.taobao.org/minipass/download/minipass-3.1.3.tgz", + "integrity": "sha1-fUL/HzljVILhX5zbUxhN7r1YFf0=", + "dev": true, + "requires": { + "yallist": "^4.0.0" + }, + "dependencies": { + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.nlark.com/yallist/download/yallist-4.0.0.tgz", + "integrity": "sha1-m7knkNnA7/7GO+c1GeEaNQGaOnI=", + "dev": true + } + } + }, + "mississippi": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/mississippi/download/mississippi-3.0.0.tgz", + "integrity": "sha1-6goykfl+C16HdrNj1fChLZTGcCI=", + "dev": true, + "requires": { + "concat-stream": "^1.5.0", + "duplexify": "^3.4.2", + "end-of-stream": "^1.1.0", + "flush-write-stream": "^1.0.0", + "from2": "^2.1.0", + "parallel-transform": "^1.1.0", + "pump": "^3.0.0", + "pumpify": "^1.3.3", + "stream-each": "^1.1.0", + "through2": "^2.0.0" + } + }, + "mixin-deep": { + "version": "1.3.2", + "resolved": "https://registry.npm.taobao.org/mixin-deep/download/mixin-deep-1.3.2.tgz", + "integrity": "sha1-ESC0PcNZp4Xc5ltVuC4lfM9HlWY=", + "dev": true, + "requires": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + } + }, + "mkdirp": { + "version": "0.5.5", + "resolved": "https://registry.nlark.com/mkdirp/download/mkdirp-0.5.5.tgz", + "integrity": "sha1-2Rzv1i0UNsoPQWIOJRKI1CAJne8=", + "requires": { + "minimist": "^1.2.5" + } + }, + "mocha": { + "version": "6.2.3", + "resolved": "https://registry.nlark.com/mocha/download/mocha-6.2.3.tgz", + "integrity": "sha1-5khDIYHYuZOTQQISZkRQpMHjGRI=", + "dev": true, + "requires": { + "ansi-colors": "3.2.3", + "browser-stdout": "1.3.1", + "debug": "3.2.6", + "diff": "3.5.0", + "escape-string-regexp": "1.0.5", + "find-up": "3.0.0", + "glob": "7.1.3", + "growl": "1.10.5", + "he": "1.2.0", + "js-yaml": "3.13.1", + "log-symbols": "2.2.0", + "minimatch": "3.0.4", + "mkdirp": "0.5.4", + "ms": "2.1.1", + "node-environment-flags": "1.0.5", + "object.assign": "4.1.0", + "strip-json-comments": "2.0.1", + "supports-color": "6.0.0", + "which": "1.3.1", + "wide-align": "1.1.3", + "yargs": "13.3.2", + "yargs-parser": "13.1.2", + "yargs-unparser": "1.6.0" + }, + "dependencies": { + "cliui": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/cliui/download/cliui-5.0.0.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-5.0.0.tgz", + "integrity": "sha1-3u/P2y6AB4SqNPRvoI4GhRx7u8U=", + "dev": true, + "requires": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + } + }, + "debug": { + "version": "3.2.6", + "resolved": "https://registry.nlark.com/debug/download/debug-3.2.6.tgz", + "integrity": "sha1-6D0X3hbYp++3cX7b5fsQE17uYps=", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + }, + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.nlark.com/emoji-regex/download/emoji-regex-7.0.3.tgz", + "integrity": "sha1-kzoEBShgyF6DwSJHnEdIqOTHIVY=", + "dev": true + }, + "glob": { + "version": "7.1.3", + "resolved": "https://registry.nlark.com/glob/download/glob-7.1.3.tgz?cache=0&sync_timestamp=1620337498129&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob%2Fdownload%2Fglob-7.1.3.tgz", + "integrity": "sha1-OWCDLT8VdBCDQtr9OmezMsCWnfE=", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "mkdirp": { + "version": "0.5.4", + "resolved": "https://registry.nlark.com/mkdirp/download/mkdirp-0.5.4.tgz", + "integrity": "sha1-/QFQSmeX7Fyb6B/0PSBJYe1kpRI=", + "dev": true, + "requires": { + "minimist": "^1.2.5" + } + }, + "ms": { + "version": "2.1.1", + "resolved": "https://registry.npm.taobao.org/ms/download/ms-2.1.1.tgz?cache=0&sync_timestamp=1607433856030&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fms%2Fdownload%2Fms-2.1.1.tgz", + "integrity": "sha1-MKWGTrPrsKZvLr5tcnrwagnYbgo=", + "dev": true + }, + "object.assign": { + "version": "4.1.0", + "resolved": "https://registry.nlark.com/object.assign/download/object.assign-4.1.0.tgz", + "integrity": "sha1-lovxEA15Vrs8oIbwBvhGs7xACNo=", + "dev": true, + "requires": { + "define-properties": "^1.1.2", + "function-bind": "^1.1.1", + "has-symbols": "^1.0.0", + "object-keys": "^1.0.11" + } + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/string-width/download/string-width-3.1.0.tgz", + "integrity": "sha1-InZ74htirxCBV0MG9prFG2IgOWE=", + "dev": true, + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/strip-json-comments/download/strip-json-comments-2.0.1.tgz", + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "dev": true + }, + "supports-color": { + "version": "6.0.0", + "resolved": "https://registry.nlark.com/supports-color/download/supports-color-6.0.0.tgz", + "integrity": "sha1-ds/nQs8fQbubHCmtAwaMBbTA5Ao=", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npm.taobao.org/which/download/which-1.3.1.tgz", + "integrity": "sha1-pFBD1U9YBTFtqNYvn1CRjT2nCwo=", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-5.1.0.tgz", + "integrity": "sha1-H9H2cjXVttD+54EFYAG/tpTAOwk=", + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + } + }, + "yargs": { + "version": "13.3.2", + "resolved": "https://registry.nlark.com/yargs/download/yargs-13.3.2.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-13.3.2.tgz", + "integrity": "sha1-rX/+/sGqWVZayRX4Lcyzipwxot0=", + "dev": true, + "requires": { + "cliui": "^5.0.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.2" + } + } + } + }, + "mochapack": { + "version": "1.1.15", + "resolved": "https://registry.nlark.com/mochapack/download/mochapack-1.1.15.tgz", + "integrity": "sha1-Qmx5O4ce0AbHgRctorFfYS8R8tw=", + "dev": true, + "requires": { + "@babel/runtime-corejs2": "^7.0.0", + "chalk": "^2.4.2", + "chokidar": "^2.0.0", + "glob-parent": "5.1.0", + "globby": "^10.0.1", + "interpret": "^1.2.0", + "is-glob": "^4.0.1", + "loader-utils": "^1.2.3", + "lodash": "^4.17.15", + "memory-fs": "^0.4.1", + "minimatch": "^3.0.4", + "nodent-runtime": "^3.2.1", + "normalize-path": "^3.0.0", + "progress": "^2.0.3", + "source-map-support": "^0.5.13", + "toposort": "^2.0.2", + "yargs": "14.0.0" + }, + "dependencies": { + "@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.nlark.com/@nodelib/fs.stat/download/@nodelib/fs.stat-2.0.5.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40nodelib%2Ffs.stat%2Fdownload%2F%40nodelib%2Ffs.stat-2.0.5.tgz", + "integrity": "sha1-W9Jir5Tp0lvR5xsF3u1Eh2oiLos=", + "dev": true + }, + "array-union": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/array-union/download/array-union-2.1.0.tgz?cache=0&sync_timestamp=1614624861176&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Farray-union%2Fdownload%2Farray-union-2.1.0.tgz", + "integrity": "sha1-t5hCCtvrHego2ErNii4j0+/oXo0=", + "dev": true + }, + "braces": { + "version": "3.0.2", + "resolved": "https://registry.nlark.com/braces/download/braces-3.0.2.tgz", + "integrity": "sha1-NFThpGLujVmeI23zNs2epPiv4Qc=", + "dev": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "cliui": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/cliui/download/cliui-5.0.0.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-5.0.0.tgz", + "integrity": "sha1-3u/P2y6AB4SqNPRvoI4GhRx7u8U=", + "dev": true, + "requires": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + } + }, + "dir-glob": { + "version": "3.0.1", + "resolved": "https://registry.nlark.com/dir-glob/download/dir-glob-3.0.1.tgz", + "integrity": "sha1-Vtv3PZkqSpO6FYT0U0Bj/S5BcX8=", + "dev": true, + "requires": { + "path-type": "^4.0.0" + } + }, + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.nlark.com/emoji-regex/download/emoji-regex-7.0.3.tgz", + "integrity": "sha1-kzoEBShgyF6DwSJHnEdIqOTHIVY=", + "dev": true + }, + "fast-glob": { + "version": "3.2.7", + "resolved": "https://registry.nlark.com/fast-glob/download/fast-glob-3.2.7.tgz", + "integrity": "sha1-/Wy3otfpqnp4RhEehaGW1rL3ZqE=", + "dev": true, + "requires": { + "@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" + }, + "dependencies": { + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.nlark.com/glob-parent/download/glob-parent-5.1.2.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-5.1.2.tgz", + "integrity": "sha1-hpgyxYA0/mikCTwX3BXoNA2EAcQ=", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + } + } + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.nlark.com/fill-range/download/fill-range-7.0.1.tgz", + "integrity": "sha1-GRmmp8df44ssfHflGYU12prN2kA=", + "dev": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "glob-parent": { + "version": "5.1.0", + "resolved": "https://registry.nlark.com/glob-parent/download/glob-parent-5.1.0.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-5.1.0.tgz", + "integrity": "sha1-X0wdHnSNMM1zrSlEs1d6gbCB6MI=", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "globby": { + "version": "10.0.2", + "resolved": "https://registry.nlark.com/globby/download/globby-10.0.2.tgz", + "integrity": "sha1-J3WT50WsqkZGw6tBEonsR6A5JUM=", + "dev": true, + "requires": { + "@types/glob": "^7.1.1", + "array-union": "^2.1.0", + "dir-glob": "^3.0.1", + "fast-glob": "^3.0.3", + "glob": "^7.1.3", + "ignore": "^5.1.1", + "merge2": "^1.2.3", + "slash": "^3.0.0" + } + }, + "ignore": { + "version": "5.1.8", + "resolved": "https://registry.npm.taobao.org/ignore/download/ignore-5.1.8.tgz", + "integrity": "sha1-8VCotQo0KJsz4i9YiavU2AFvDlc=", + "dev": true + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npm.taobao.org/is-number/download/is-number-7.0.0.tgz", + "integrity": "sha1-dTU0W4lnNNX4DE0GxQlVUnoU8Ss=", + "dev": true + }, + "micromatch": { + "version": "4.0.4", + "resolved": "https://registry.npm.taobao.org/micromatch/download/micromatch-4.0.4.tgz?cache=0&sync_timestamp=1618054841521&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmicromatch%2Fdownload%2Fmicromatch-4.0.4.tgz", + "integrity": "sha1-iW1Rnf6dsl/OlM63pQCRm/iB6/k=", + "dev": true, + "requires": { + "braces": "^3.0.1", + "picomatch": "^2.2.3" + } + }, + "path-type": { + "version": "4.0.0", + "resolved": "https://registry.npm.taobao.org/path-type/download/path-type-4.0.0.tgz", + "integrity": "sha1-hO0BwKe6OAr+CdkKjBgNzZ0DBDs=", + "dev": true + }, + "slash": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/slash/download/slash-3.0.0.tgz", + "integrity": "sha1-ZTm+hwwWWtvVJAIg2+Nh8bxNRjQ=", + "dev": true + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/string-width/download/string-width-3.1.0.tgz", + "integrity": "sha1-InZ74htirxCBV0MG9prFG2IgOWE=", + "dev": true, + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.nlark.com/to-regex-range/download/to-regex-range-5.0.1.tgz", + "integrity": "sha1-FkjESq58jZiKMmAY7XL1tN0DkuQ=", + "dev": true, + "requires": { + "is-number": "^7.0.0" + } + }, + "toposort": { + "version": "2.0.2", + "resolved": "https://registry.npm.taobao.org/toposort/download/toposort-2.0.2.tgz", + "integrity": "sha1-riF2gXXRVZ1IvvNUILL0li8JwzA=", + "dev": true + }, + "wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-5.1.0.tgz", + "integrity": "sha1-H9H2cjXVttD+54EFYAG/tpTAOwk=", + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + } + }, + "yargs": { + "version": "14.0.0", + "resolved": "https://registry.nlark.com/yargs/download/yargs-14.0.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-14.0.0.tgz", + "integrity": "sha1-ukysyAKzwLPjap55FyN2PVeoUGY=", + "dev": true, + "requires": { + "cliui": "^5.0.0", + "decamelize": "^1.2.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.1" + } + } + } + }, + "move-concurrently": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/move-concurrently/download/move-concurrently-1.0.1.tgz", + "integrity": "sha1-viwAX9oy4LKa8fBdfEszIUxwH5I=", + "dev": true, + "requires": { + "aproba": "^1.1.1", + "copy-concurrently": "^1.0.0", + "fs-write-stream-atomic": "^1.0.8", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.3" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npm.taobao.org/ms/download/ms-2.1.2.tgz?cache=0&sync_timestamp=1607433856030&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fms%2Fdownload%2Fms-2.1.2.tgz", + "integrity": "sha1-0J0fNXtEP0kzgqjrPM0YOHKuYAk=" + }, + "multicast-dns": { + "version": "6.2.3", + "resolved": "https://registry.nlark.com/multicast-dns/download/multicast-dns-6.2.3.tgz?cache=0&sync_timestamp=1621891072224&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fmulticast-dns%2Fdownload%2Fmulticast-dns-6.2.3.tgz", + "integrity": "sha1-oOx72QVcQoL3kMPIL04o2zsxsik=", + "dev": true, + "requires": { + "dns-packet": "^1.3.1", + "thunky": "^1.0.2" + } + }, + "multicast-dns-service-types": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/multicast-dns-service-types/download/multicast-dns-service-types-1.1.0.tgz", + "integrity": "sha1-iZ8R2WhuXgXLkbNdXw5jt3PPyQE=", + "dev": true + }, + "mute-stream": { + "version": "0.0.8", + "resolved": "https://registry.npm.taobao.org/mute-stream/download/mute-stream-0.0.8.tgz", + "integrity": "sha1-FjDEKyJR/4HiooPelqVJfqkuXg0=", + "dev": true + }, + "mz": { + "version": "2.7.0", + "resolved": "https://registry.npm.taobao.org/mz/download/mz-2.7.0.tgz", + "integrity": "sha1-lQCAV6Vsr63CvGPd5/n/aVWUjjI=", + "requires": { + "any-promise": "^1.0.0", + "object-assign": "^4.0.1", + "thenify-all": "^1.0.0" + } + }, + "mz-modules": { + "version": "2.1.0", + "resolved": "https://registry.npmmirror.com/mz-modules/-/mz-modules-2.1.0.tgz", + "integrity": "sha512-sjk8lcRW3vrVYnZ+W+67L/2rL+jbO5K/N6PFGIcLWTiYytNr22Ah9FDXFs+AQntTM1boZcoHi5qS+CV1seuPog==", + "requires": { + "glob": "^7.1.2", + "ko-sleep": "^1.0.3", + "mkdirp": "^0.5.1", + "pump": "^3.0.0", + "rimraf": "^2.6.1" + } + }, + "nan": { + "version": "2.17.0", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.17.0.tgz", + "integrity": "sha512-2ZTgtl0nJsO0KQCjEpxcIr5D+Yv90plTitZt9JBfQvVJDS5seMl3FOvsh3+9CoYWXf/1l5OaZzzF6nDm4cagaQ==", + "dev": true, + "optional": true + }, + "nanoid": { + "version": "3.1.23", + "resolved": "https://registry.nlark.com/nanoid/download/nanoid-3.1.23.tgz?cache=0&sync_timestamp=1620674856899&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fnanoid%2Fdownload%2Fnanoid-3.1.23.tgz", + "integrity": "sha1-90QIbOfCvEfuCoRyV01ceOQYOoE=" + }, + "nanomatch": { + "version": "1.2.13", + "resolved": "https://registry.npm.taobao.org/nanomatch/download/nanomatch-1.2.13.tgz", + "integrity": "sha1-uHqKpPwN6P5r6IiVs4mD/yZb0Rk=", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + } + }, + "needle": { + "version": "2.8.0", + "resolved": "https://registry.nlark.com/needle/download/needle-2.8.0.tgz", + "integrity": "sha1-HI75waLCncweg9c4Cde8aByAoEg=", + "optional": true, + "requires": { + "debug": "^3.2.6", + "iconv-lite": "^0.4.4", + "sax": "^1.2.4" + }, + "dependencies": { + "debug": { + "version": "3.2.7", + "resolved": "https://registry.nlark.com/debug/download/debug-3.2.7.tgz", + "integrity": "sha1-clgLfpFF+zm2Z2+cXl+xALk0F5o=", + "optional": true, + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "negotiator": { + "version": "0.6.2", + "resolved": "https://registry.npm.taobao.org/negotiator/download/negotiator-0.6.2.tgz", + "integrity": "sha1-/qz3zPUlp3rpY0Q2pkiD/+yjRvs=", + "dev": true + }, + "neo-async": { + "version": "2.6.2", + "resolved": "https://registry.npm.taobao.org/neo-async/download/neo-async-2.6.2.tgz", + "integrity": "sha1-tKr7k+OustgXTKU88WOrfXMIMF8=", + "dev": true + }, + "netmask": { + "version": "2.0.2", + "resolved": "https://registry.npmmirror.com/netmask/-/netmask-2.0.2.tgz", + "integrity": "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==" + }, + "nice-try": { + "version": "1.0.5", + "resolved": "https://registry.nlark.com/nice-try/download/nice-try-1.0.5.tgz", + "integrity": "sha1-ozeKdpbOfSI+iPybdkvX7xCJ42Y=", + "dev": true + }, + "no-case": { + "version": "2.3.2", + "resolved": "https://registry.npm.taobao.org/no-case/download/no-case-2.3.2.tgz", + "integrity": "sha1-YLgTOWvjmz8SiKTB7V0efSi0ZKw=", + "dev": true, + "requires": { + "lower-case": "^1.1.1" + } + }, + "node-addon-api": { + "version": "7.1.1", + "resolved": "https://registry.npmmirror.com/node-addon-api/-/node-addon-api-7.1.1.tgz", + "integrity": "sha512-5m3bsyrjFWE1xf7nz7YXdN4udnVtXK6/Yfgn5qnahL6bCkf2yKt4k3nuTKAtT4r3IG8JNR2ncsIMdZuAzJjHQQ==", + "dev": true + }, + "node-environment-flags": { + "version": "1.0.5", + "resolved": "https://registry.npm.taobao.org/node-environment-flags/download/node-environment-flags-1.0.5.tgz", + "integrity": "sha1-+pMCdfW/Xa4YjWGSsktMi7rD12o=", + "dev": true, + "requires": { + "object.getownpropertydescriptors": "^2.0.3", + "semver": "^5.7.0" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.nlark.com/semver/download/semver-5.7.1.tgz", + "integrity": "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=", + "dev": true + } + } + }, + "node-fetch": { + "version": "2.6.7", + "resolved": "https://registry.npmmirror.com/node-fetch/-/node-fetch-2.6.7.tgz", + "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", + "requires": { + "whatwg-url": "^5.0.0" + }, + "dependencies": { + "tr46": { + "version": "0.0.3", + "resolved": "https://registry.npmmirror.com/tr46/-/tr46-0.0.3.tgz", + "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" + }, + "webidl-conversions": { + "version": "3.0.1", + "resolved": "https://registry.npmmirror.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz", + "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" + }, + "whatwg-url": { + "version": "5.0.0", + "resolved": "https://registry.npmmirror.com/whatwg-url/-/whatwg-url-5.0.0.tgz", + "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", + "requires": { + "tr46": "~0.0.3", + "webidl-conversions": "^3.0.0" + } + } + } + }, + "node-forge": { + "version": "0.10.0", + "resolved": "https://registry.npm.taobao.org/node-forge/download/node-forge-0.10.0.tgz", + "integrity": "sha1-Mt6ir7Ppkm8C7lzoeUkCaRpna/M=", + "dev": true + }, + "node-libs-browser": { + "version": "2.2.1", + "resolved": "https://registry.npm.taobao.org/node-libs-browser/download/node-libs-browser-2.2.1.tgz", + "integrity": "sha1-tk9RPRgzhiX5A0bSew0jXmMfZCU=", + "dev": true, + "requires": { + "assert": "^1.1.1", + "browserify-zlib": "^0.2.0", + "buffer": "^4.3.0", + "console-browserify": "^1.1.0", + "constants-browserify": "^1.0.0", + "crypto-browserify": "^3.11.0", + "domain-browser": "^1.1.1", + "events": "^3.0.0", + "https-browserify": "^1.0.0", + "os-browserify": "^0.3.0", + "path-browserify": "0.0.1", + "process": "^0.11.10", + "punycode": "^1.2.4", + "querystring-es3": "^0.2.0", + "readable-stream": "^2.3.3", + "stream-browserify": "^2.0.1", + "stream-http": "^2.7.2", + "string_decoder": "^1.0.0", + "timers-browserify": "^2.0.4", + "tty-browserify": "0.0.0", + "url": "^0.11.0", + "util": "^0.11.0", + "vm-browserify": "^1.0.1" + }, + "dependencies": { + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npm.taobao.org/punycode/download/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "dev": true + } + } + }, + "node-releases": { + "version": "1.1.73", + "resolved": "https://registry.nlark.com/node-releases/download/node-releases-1.1.73.tgz", + "integrity": "sha1-3U6B3dUnf/hGuAtSu0DEnt96eyA=", + "dev": true + }, + "nodent-runtime": { + "version": "3.2.1", + "resolved": "https://registry.npm.taobao.org/nodent-runtime/download/nodent-runtime-3.2.1.tgz", + "integrity": "sha1-nidV2F4592Qojw1HUuvP4+VB4A4=", + "dev": true + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npm.taobao.org/normalize-package-data/download/normalize-package-data-2.5.0.tgz?cache=0&sync_timestamp=1616086930281&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fnormalize-package-data%2Fdownload%2Fnormalize-package-data-2.5.0.tgz", + "integrity": "sha1-5m2xg4sgDB38IzIl0SyzZSDiNKg=", + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.nlark.com/semver/download/semver-5.7.1.tgz", + "integrity": "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=", + "dev": true + } + } + }, + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/normalize-path/download/normalize-path-3.0.0.tgz", + "integrity": "sha1-Dc1p/yOhybEf0JeDFmRKA4ghamU=", + "dev": true + }, + "normalize-range": { + "version": "0.1.2", + "resolved": "https://registry.npm.taobao.org/normalize-range/download/normalize-range-0.1.2.tgz", + "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=", + "dev": true + }, + "normalize-url": { + "version": "1.9.1", + "resolved": "https://registry.nlark.com/normalize-url/download/normalize-url-1.9.1.tgz?cache=0&sync_timestamp=1625826704090&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fnormalize-url%2Fdownload%2Fnormalize-url-1.9.1.tgz", + "integrity": "sha1-LMDWazHqIwNkWENuNiDYWVTGbDw=", + "dev": true, + "requires": { + "object-assign": "^4.0.1", + "prepend-http": "^1.0.0", + "query-string": "^4.1.0", + "sort-keys": "^1.0.0" + } + }, + "normalize-wheel-es": { + "version": "1.2.0", + "resolved": "https://registry.npmmirror.com/normalize-wheel-es/-/normalize-wheel-es-1.2.0.tgz", + "integrity": "sha512-Wj7+EJQ8mSuXr2iWfnujrimU35R2W4FAErEyTmJoJ7ucwTn2hOUSsRehMb5RSYkxXGTM7Y9QpvPmp++w5ftoJw==" + }, + "npm-run-path": { + "version": "2.0.2", + "resolved": "https://registry.nlark.com/npm-run-path/download/npm-run-path-2.0.2.tgz", + "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", + "dev": true, + "requires": { + "path-key": "^2.0.0" + }, + "dependencies": { + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/path-key/download/path-key-2.0.1.tgz?cache=0&sync_timestamp=1617971691339&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpath-key%2Fdownload%2Fpath-key-2.0.1.tgz", + "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", + "dev": true + } + } + }, + "nth-check": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/nth-check/download/nth-check-2.0.0.tgz", + "integrity": "sha1-G7T22scAcvwxPoyc0UF7UHTAoSU=", + "dev": true, + "requires": { + "boolbase": "^1.0.0" + } + }, + "num2fraction": { + "version": "1.2.2", + "resolved": "https://registry.npm.taobao.org/num2fraction/download/num2fraction-1.2.2.tgz", + "integrity": "sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4=", + "dev": true + }, + "nwsapi": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/nwsapi/download/nwsapi-2.2.0.tgz", + "integrity": "sha1-IEh5qePQaP8qVROcLHcngGgaOLc=", + "dev": true + }, + "oauth-sign": { + "version": "0.9.0", + "resolved": "https://registry.nlark.com/oauth-sign/download/oauth-sign-0.9.0.tgz", + "integrity": "sha1-R6ewFrqmi1+g7PPe4IqFxnmsZFU=", + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npm.taobao.org/object-assign/download/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" + }, + "object-copy": { + "version": "0.1.0", + "resolved": "https://registry.nlark.com/object-copy/download/object-copy-0.1.0.tgz", + "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "dev": true, + "requires": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-accessor-descriptor/download/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.nlark.com/is-data-descriptor/download/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-descriptor/download/is-descriptor-0.1.6.tgz", + "integrity": "sha1-Nm2CQN3kh8pRgjsaufB6EKeCUco=", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-5.1.0.tgz", + "integrity": "sha1-cpyR4thXt6QZofmqZWhcTDP1hF0=", + "dev": true + } + } + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "object-hash": { + "version": "1.3.1", + "resolved": "https://registry.nlark.com/object-hash/download/object-hash-1.3.1.tgz?cache=0&sync_timestamp=1622019485009&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fobject-hash%2Fdownload%2Fobject-hash-1.3.1.tgz", + "integrity": "sha1-/eRSCYqVHLFF8Dm7fUVUSd3BJt8=", + "dev": true + }, + "object-inspect": { + "version": "1.11.0", + "resolved": "https://registry.nlark.com/object-inspect/download/object-inspect-1.11.0.tgz", + "integrity": "sha1-nc6xRs7dQUig2eUauI00z1CZIrE=", + "dev": true + }, + "object-is": { + "version": "1.1.5", + "resolved": "https://registry.npm.taobao.org/object-is/download/object-is-1.1.5.tgz?cache=0&sync_timestamp=1613857744782&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fobject-is%2Fdownload%2Fobject-is-1.1.5.tgz", + "integrity": "sha1-ud7qpfx/GEag+uzc7sE45XePU6w=", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + } + }, + "object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/object-keys/download/object-keys-1.1.1.tgz", + "integrity": "sha1-HEfyct8nfzsdrwYWd9nILiMixg4=", + "dev": true + }, + "object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/object-visit/download/object-visit-1.0.1.tgz", + "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "dev": true, + "requires": { + "isobject": "^3.0.0" + } + }, + "object.assign": { + "version": "4.1.2", + "resolved": "https://registry.nlark.com/object.assign/download/object.assign-4.1.2.tgz", + "integrity": "sha1-DtVKNC7Os3s4/3brgxoOeIy2OUA=", + "dev": true, + "requires": { + "call-bind": "^1.0.0", + "define-properties": "^1.1.3", + "has-symbols": "^1.0.1", + "object-keys": "^1.1.1" + } + }, + "object.getownpropertydescriptors": { + "version": "2.1.2", + "resolved": "https://registry.nlark.com/object.getownpropertydescriptors/download/object.getownpropertydescriptors-2.1.2.tgz", + "integrity": "sha1-G9Y66s8NXS0vMbXjk7A6fGAaI/c=", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3", + "es-abstract": "^1.18.0-next.2" + } + }, + "object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npm.taobao.org/object.pick/download/object.pick-1.3.0.tgz", + "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "object.values": { + "version": "1.1.4", + "resolved": "https://registry.nlark.com/object.values/download/object.values-1.1.4.tgz?cache=0&sync_timestamp=1622070650699&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fobject.values%2Fdownload%2Fobject.values-1.1.4.tgz", + "integrity": "sha1-DSc3YoM+gWtpOmN9MAc+cFFTWzA=", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3", + "es-abstract": "^1.18.2" + } + }, + "obuf": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/obuf/download/obuf-1.1.2.tgz", + "integrity": "sha1-Cb6jND1BhZ69RGKS0RydTbYZCE4=", + "dev": true + }, + "on-finished": { + "version": "2.3.0", + "resolved": "https://registry.nlark.com/on-finished/download/on-finished-2.3.0.tgz", + "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", + "dev": true, + "requires": { + "ee-first": "1.1.1" + } + }, + "on-headers": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/on-headers/download/on-headers-1.0.2.tgz", + "integrity": "sha1-dysK5qqlJcOZ5Imt+tkMQD6zwo8=", + "dev": true + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.nlark.com/once/download/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "requires": { + "wrappy": "1" + } + }, + "onetime": { + "version": "5.1.2", + "resolved": "https://registry.npm.taobao.org/onetime/download/onetime-5.1.2.tgz", + "integrity": "sha1-0Oluu1awdHbfHdnEgG5SN5hcpF4=", + "dev": true, + "requires": { + "mimic-fn": "^2.1.0" + } + }, + "open": { + "version": "6.4.0", + "resolved": "https://registry.nlark.com/open/download/open-6.4.0.tgz", + "integrity": "sha1-XBPpbQ3IlGhhZPGJZez+iJ7PyKk=", + "dev": true, + "requires": { + "is-wsl": "^1.1.0" + }, + "dependencies": { + "is-wsl": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/is-wsl/download/is-wsl-1.1.0.tgz", + "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=", + "dev": true + } + } + }, + "opener": { + "version": "1.5.2", + "resolved": "https://registry.nlark.com/opener/download/opener-1.5.2.tgz", + "integrity": "sha1-XTfh81B3udysQwE3InGv3rKhNZg=", + "dev": true + }, + "opn": { + "version": "5.5.0", + "resolved": "https://registry.npm.taobao.org/opn/download/opn-5.5.0.tgz", + "integrity": "sha1-/HFk+rVtI1kExRw7J9pnWMo7m/w=", + "dev": true, + "requires": { + "is-wsl": "^1.1.0" + }, + "dependencies": { + "is-wsl": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/is-wsl/download/is-wsl-1.1.0.tgz", + "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=", + "dev": true + } + } + }, + "optionator": { + "version": "0.8.3", + "resolved": "https://registry.nlark.com/optionator/download/optionator-0.8.3.tgz", + "integrity": "sha1-hPodA2/p08fiHZmIS2ARZ+yPtJU=", + "requires": { + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.6", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "word-wrap": "~1.2.3" + } + }, + "ora": { + "version": "3.4.0", + "resolved": "https://registry.nlark.com/ora/download/ora-3.4.0.tgz?cache=0&sync_timestamp=1623137978561&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fora%2Fdownload%2Fora-3.4.0.tgz", + "integrity": "sha1-vwdSSRBZo+8+1MhQl1Md6f280xg=", + "dev": true, + "requires": { + "chalk": "^2.4.2", + "cli-cursor": "^2.1.0", + "cli-spinners": "^2.0.0", + "log-symbols": "^2.2.0", + "strip-ansi": "^5.2.0", + "wcwidth": "^1.0.1" + }, + "dependencies": { + "cli-cursor": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/cli-cursor/download/cli-cursor-2.1.0.tgz", + "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", + "dev": true, + "requires": { + "restore-cursor": "^2.0.0" + } + }, + "mimic-fn": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/mimic-fn/download/mimic-fn-1.2.0.tgz?cache=0&sync_timestamp=1617823674050&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmimic-fn%2Fdownload%2Fmimic-fn-1.2.0.tgz", + "integrity": "sha1-ggyGo5M0ZA6ZUWkovQP8qIBX0CI=", + "dev": true + }, + "onetime": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/onetime/download/onetime-2.0.1.tgz", + "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", + "dev": true, + "requires": { + "mimic-fn": "^1.0.0" + } + }, + "restore-cursor": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/restore-cursor/download/restore-cursor-2.0.0.tgz", + "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", + "dev": true, + "requires": { + "onetime": "^2.0.0", + "signal-exit": "^3.0.2" + } + } + } + }, + "original": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/original/download/original-1.0.2.tgz", + "integrity": "sha1-5EKmHP/hxf0gpl8yYcJmY7MD8l8=", + "requires": { + "url-parse": "^1.4.3" + } + }, + "os-browserify": { + "version": "0.3.0", + "resolved": "https://registry.nlark.com/os-browserify/download/os-browserify-0.3.0.tgz", + "integrity": "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=", + "dev": true + }, + "os-name": { + "version": "1.0.3", + "resolved": "https://registry.npmmirror.com/os-name/-/os-name-1.0.3.tgz", + "integrity": "sha512-f5estLO2KN8vgtTRaILIgEGBoBrMnZ3JQ7W9TMZCnOIGwHe8TRGSpcagnWDo+Dfhd/z08k9Xe75hvciJJ8Qaew==", + "requires": { + "osx-release": "^1.0.0", + "win-release": "^1.0.0" + } + }, + "os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/os-tmpdir/download/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", + "dev": true + }, + "osx-release": { + "version": "1.1.0", + "resolved": "https://registry.npmmirror.com/osx-release/-/osx-release-1.1.0.tgz", + "integrity": "sha512-ixCMMwnVxyHFQLQnINhmIpWqXIfS2YOXchwQrk+OFzmo6nDjQ0E4KXAyyUh0T0MZgV4bUhkRrAbVqlE4yLVq4A==", + "requires": { + "minimist": "^1.1.0" + } + }, + "p-finally": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/p-finally/download/p-finally-1.0.0.tgz", + "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", + "dev": true + }, + "p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npm.taobao.org/p-limit/download/p-limit-2.3.0.tgz", + "integrity": "sha1-PdM8ZHohT9//2DWTPrCG2g3CHbE=", + "dev": true, + "requires": { + "p-try": "^2.0.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/p-locate/download/p-locate-3.0.0.tgz", + "integrity": "sha1-Mi1poFwCZLJZl9n0DNiokasAZKQ=", + "dev": true, + "requires": { + "p-limit": "^2.0.0" + } + }, + "p-map": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/p-map/download/p-map-2.1.0.tgz", + "integrity": "sha1-MQko/u+cnsxltosXaTAYpmXOoXU=", + "dev": true + }, + "p-retry": { + "version": "3.0.1", + "resolved": "https://registry.nlark.com/p-retry/download/p-retry-3.0.1.tgz", + "integrity": "sha1-MWtMiJPiyNwc+okfQGxLQivr8yg=", + "dev": true, + "requires": { + "retry": "^0.12.0" + } + }, + "p-try": { + "version": "2.2.0", + "resolved": "https://registry.nlark.com/p-try/download/p-try-2.2.0.tgz", + "integrity": "sha1-yyhoVA4xPWHeWPr741zpAE1VQOY=", + "dev": true + }, + "pac-proxy-agent": { + "version": "5.0.0", + "resolved": "https://registry.npmmirror.com/pac-proxy-agent/-/pac-proxy-agent-5.0.0.tgz", + "integrity": "sha512-CcFG3ZtnxO8McDigozwE3AqAw15zDvGH+OjXO4kzf7IkEKkQ4gxQ+3sdF50WmhQ4P/bVusXcqNE2S3XrNURwzQ==", + "requires": { + "@tootallnate/once": "1", + "agent-base": "6", + "debug": "4", + "get-uri": "3", + "http-proxy-agent": "^4.0.1", + "https-proxy-agent": "5", + "pac-resolver": "^5.0.0", + "raw-body": "^2.2.0", + "socks-proxy-agent": "5" + } + }, + "pac-resolver": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/pac-resolver/-/pac-resolver-5.0.1.tgz", + "integrity": "sha512-cy7u00ko2KVgBAjuhevqpPeHIkCIqPe1v24cydhWjmeuzaBfmUWFCZJ1iAh5TuVzVZoUzXIW7K8sMYOZ84uZ9Q==", + "requires": { + "degenerator": "^3.0.2", + "ip": "^1.1.5", + "netmask": "^2.0.2" + } + }, + "pako": { + "version": "1.0.11", + "resolved": "https://registry.npm.taobao.org/pako/download/pako-1.0.11.tgz?cache=0&sync_timestamp=1610208924901&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpako%2Fdownload%2Fpako-1.0.11.tgz", + "integrity": "sha1-bJWZ00DVTf05RjgCUqNXBaa5kr8=", + "dev": true + }, + "parallel-transform": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/parallel-transform/download/parallel-transform-1.2.0.tgz", + "integrity": "sha1-kEnKN9bLIYLDsdLHIL6U0UpYFPw=", + "dev": true, + "requires": { + "cyclist": "^1.0.1", + "inherits": "^2.0.3", + "readable-stream": "^2.1.5" + } + }, + "param-case": { + "version": "2.1.1", + "resolved": "https://registry.npm.taobao.org/param-case/download/param-case-2.1.1.tgz?cache=0&sync_timestamp=1606867311360&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fparam-case%2Fdownload%2Fparam-case-2.1.1.tgz", + "integrity": "sha1-35T9jPZTHs915r75oIWPvHK+Ikc=", + "dev": true, + "requires": { + "no-case": "^2.2.0" + } + }, + "parse-asn1": { + "version": "5.1.6", + "resolved": "https://registry.nlark.com/parse-asn1/download/parse-asn1-5.1.6.tgz", + "integrity": "sha1-OFCAo+wTy2KmLTlAnLPoiETNrtQ=", + "dev": true, + "requires": { + "asn1.js": "^5.2.0", + "browserify-aes": "^1.0.0", + "evp_bytestokey": "^1.0.0", + "pbkdf2": "^3.0.3", + "safe-buffer": "^5.1.1" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npm.taobao.org/parse-json/download/parse-json-4.0.0.tgz?cache=0&sync_timestamp=1610966676829&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fparse-json%2Fdownload%2Fparse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "parse-node-version": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/parse-node-version/download/parse-node-version-1.0.1.tgz", + "integrity": "sha1-4rXb7eAOf6m8NjYH9TMn6LBzGJs=" + }, + "parse5": { + "version": "5.1.1", + "resolved": "https://registry.npm.taobao.org/parse5/download/parse5-5.1.1.tgz", + "integrity": "sha1-9o5OW6GFKsLK3AD0VV//bCq7YXg=", + "dev": true + }, + "parse5-htmlparser2-tree-adapter": { + "version": "6.0.1", + "resolved": "https://registry.npm.taobao.org/parse5-htmlparser2-tree-adapter/download/parse5-htmlparser2-tree-adapter-6.0.1.tgz", + "integrity": "sha1-LN+a2CMyEUA3DU2/XT6Sx8jdxuY=", + "dev": true, + "requires": { + "parse5": "^6.0.1" + }, + "dependencies": { + "parse5": { + "version": "6.0.1", + "resolved": "https://registry.npm.taobao.org/parse5/download/parse5-6.0.1.tgz", + "integrity": "sha1-4aHAhcVps9wIMhGE8Zo5zCf3wws=", + "dev": true + } + } + }, + "parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npm.taobao.org/parseurl/download/parseurl-1.3.3.tgz", + "integrity": "sha1-naGee+6NEt/wUT7Vt2lXeTvC6NQ=", + "dev": true + }, + "pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npm.taobao.org/pascalcase/download/pascalcase-0.1.1.tgz", + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", + "dev": true + }, + "path-browserify": { + "version": "0.0.1", + "resolved": "https://registry.npm.taobao.org/path-browserify/download/path-browserify-0.0.1.tgz", + "integrity": "sha1-5sTd1+06onxoogzE5Q4aTug7vEo=", + "dev": true + }, + "path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/path-dirname/download/path-dirname-1.0.2.tgz", + "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", + "dev": true + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/path-exists/download/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/path-is-absolute/download/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" + }, + "path-is-inside": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/path-is-inside/download/path-is-inside-1.0.2.tgz", + "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", + "dev": true + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true + }, + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.nlark.com/path-parse/download/path-parse-1.0.7.tgz", + "integrity": "sha1-+8EUtgykKzDZ2vWFjkvWi77bZzU=", + "dev": true + }, + "path-to-regexp": { + "version": "0.1.7", + "resolved": "https://registry.nlark.com/path-to-regexp/download/path-to-regexp-0.1.7.tgz?cache=0&sync_timestamp=1618847711772&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpath-to-regexp%2Fdownload%2Fpath-to-regexp-0.1.7.tgz", + "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/path-type/download/path-type-3.0.0.tgz", + "integrity": "sha1-zvMdyOCho7sNEFwM2Xzzv0f0428=", + "dev": true, + "requires": { + "pify": "^3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/pify/download/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "pathval": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/pathval/download/pathval-1.1.1.tgz?cache=0&sync_timestamp=1611662006519&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpathval%2Fdownload%2Fpathval-1.1.1.tgz", + "integrity": "sha1-hTTnenfOesWiUS6iHg/bj89sPY0=", + "dev": true + }, + "pause-stream": { + "version": "0.0.11", + "resolved": "https://registry.npmmirror.com/pause-stream/-/pause-stream-0.0.11.tgz", + "integrity": "sha512-e3FBlXLmN/D1S+zHzanP4E/4Z60oFAa3O051qt1pxa7DEJWKAyil6upYVXCWadEnuoqa4Pkc9oUx9zsxYeRv8A==", + "requires": { + "through": "~2.3" + } + }, + "pbkdf2": { + "version": "3.1.2", + "resolved": "https://registry.npm.taobao.org/pbkdf2/download/pbkdf2-3.1.2.tgz", + "integrity": "sha1-3YIqoIh1gOUvGgOdw+2hCO+uMHU=", + "dev": true, + "requires": { + "create-hash": "^1.1.2", + "create-hmac": "^1.1.4", + "ripemd160": "^2.0.1", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "performance-now": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/performance-now/download/performance-now-2.1.0.tgz", + "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", + "dev": true + }, + "picomatch": { + "version": "2.3.0", + "resolved": "https://registry.nlark.com/picomatch/download/picomatch-2.3.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpicomatch%2Fdownload%2Fpicomatch-2.3.0.tgz", + "integrity": "sha1-8fBh3o9qS/AiiS4tEoI0+5gwKXI=", + "dev": true + }, + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npm.taobao.org/pify/download/pify-4.0.1.tgz", + "integrity": "sha1-SyzSXFDVmHNcUCkiJP2MbfQeMjE=" + }, + "pinkie": { + "version": "2.0.4", + "resolved": "https://registry.nlark.com/pinkie/download/pinkie-2.0.4.tgz", + "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", + "dev": true + }, + "pinkie-promise": { + "version": "2.0.1", + "resolved": "https://registry.nlark.com/pinkie-promise/download/pinkie-promise-2.0.1.tgz?cache=0&sync_timestamp=1618847023792&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpinkie-promise%2Fdownload%2Fpinkie-promise-2.0.1.tgz", + "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", + "dev": true, + "requires": { + "pinkie": "^2.0.0" + } + }, + "pkg-dir": { + "version": "4.2.0", + "resolved": "https://registry.nlark.com/pkg-dir/download/pkg-dir-4.2.0.tgz?cache=0&sync_timestamp=1618847182947&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpkg-dir%2Fdownload%2Fpkg-dir-4.2.0.tgz", + "integrity": "sha1-8JkTPfft5CLoHR2ESCcO6z5CYfM=", + "dev": true, + "requires": { + "find-up": "^4.0.0" + }, + "dependencies": { + "find-up": { + "version": "4.1.0", + "resolved": "https://registry.nlark.com/find-up/download/find-up-4.1.0.tgz", + "integrity": "sha1-l6/n1s3AvFkoWEt8jXsW6KmqXRk=", + "dev": true, + "requires": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + } + }, + "locate-path": { + "version": "5.0.0", + "resolved": "https://registry.nlark.com/locate-path/download/locate-path-5.0.0.tgz", + "integrity": "sha1-Gvujlq/WdqbUJQTQpno6frn2KqA=", + "dev": true, + "requires": { + "p-locate": "^4.1.0" + } + }, + "p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npm.taobao.org/p-locate/download/p-locate-4.1.0.tgz", + "integrity": "sha1-o0KLtwiLOmApL2aRkni3wpetTwc=", + "dev": true, + "requires": { + "p-limit": "^2.2.0" + } + }, + "path-exists": { + "version": "4.0.0", + "resolved": "https://registry.nlark.com/path-exists/download/path-exists-4.0.0.tgz", + "integrity": "sha1-UTvb4tO5XXdi6METfvoZXGxhtbM=", + "dev": true + } + } + }, + "platform": { + "version": "1.3.6", + "resolved": "https://registry.npmmirror.com/platform/-/platform-1.3.6.tgz", + "integrity": "sha512-fnWVljUchTro6RiCFvCXBbNhJc2NijN7oIQxbwsyL0buWJPG85v81ehlHI9fXrJsMNgTofEoWIQeClKpgxFLrg==" + }, + "pn": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/pn/download/pn-1.1.0.tgz", + "integrity": "sha1-4vTO8OIZ9GPBeas3Rj5OHs3Muvs=", + "dev": true + }, + "pnp-webpack-plugin": { + "version": "1.6.4", + "resolved": "https://registry.npm.taobao.org/pnp-webpack-plugin/download/pnp-webpack-plugin-1.6.4.tgz", + "integrity": "sha1-yXEaxNxIpoXauvyG+Lbdn434QUk=", + "dev": true, + "requires": { + "ts-pnp": "^1.1.6" + } + }, + "portfinder": { + "version": "1.0.28", + "resolved": "https://registry.npm.taobao.org/portfinder/download/portfinder-1.0.28.tgz", + "integrity": "sha1-Z8RiKFK9U3TdHdkA93n1NGL6x3g=", + "dev": true, + "requires": { + "async": "^2.6.2", + "debug": "^3.1.1", + "mkdirp": "^0.5.5" + }, + "dependencies": { + "debug": { + "version": "3.2.7", + "resolved": "https://registry.nlark.com/debug/download/debug-3.2.7.tgz", + "integrity": "sha1-clgLfpFF+zm2Z2+cXl+xALk0F5o=", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "posix-character-classes": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/posix-character-classes/download/posix-character-classes-0.1.1.tgz", + "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", + "dev": true + }, + "postcss": { + "version": "7.0.36", + "resolved": "https://registry.nlark.com/postcss/download/postcss-7.0.36.tgz", + "integrity": "sha1-BW+M/6k5ZiqPWQWVDAfVKFZE38s=", + "dev": true, + "requires": { + "chalk": "^2.4.2", + "source-map": "^0.6.1", + "supports-color": "^6.1.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + }, + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.nlark.com/supports-color/download/supports-color-6.1.0.tgz", + "integrity": "sha1-B2Srxpxj1ayELdSGfo0CXogN+PM=", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "postcss-calc": { + "version": "7.0.5", + "resolved": "https://registry.npm.taobao.org/postcss-calc/download/postcss-calc-7.0.5.tgz?cache=0&sync_timestamp=1609689191682&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpostcss-calc%2Fdownload%2Fpostcss-calc-7.0.5.tgz", + "integrity": "sha1-+KbpnxLmGcLrwjz2xIb9wVhgkz4=", + "dev": true, + "requires": { + "postcss": "^7.0.27", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.0.2" + } + }, + "postcss-colormin": { + "version": "4.0.3", + "resolved": "https://registry.nlark.com/postcss-colormin/download/postcss-colormin-4.0.3.tgz", + "integrity": "sha1-rgYLzpPteUrHEmTwgTLVUJVr04E=", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "color": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-convert-values": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/postcss-convert-values/download/postcss-convert-values-4.0.1.tgz", + "integrity": "sha1-yjgT7U2g+BL51DcDWE5Enr4Ymn8=", + "dev": true, + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-discard-comments": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-discard-comments/download/postcss-discard-comments-4.0.2.tgz?cache=0&sync_timestamp=1621449811540&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-discard-comments%2Fdownload%2Fpostcss-discard-comments-4.0.2.tgz", + "integrity": "sha1-H7q9LCRr/2qq15l7KwkY9NevQDM=", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-duplicates": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-discard-duplicates/download/postcss-discard-duplicates-4.0.2.tgz?cache=0&sync_timestamp=1621449811996&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-discard-duplicates%2Fdownload%2Fpostcss-discard-duplicates-4.0.2.tgz", + "integrity": "sha1-P+EzzTyCKC5VD8myORdqkge3hOs=", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-empty": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/postcss-discard-empty/download/postcss-discard-empty-4.0.1.tgz", + "integrity": "sha1-yMlR6fc+2UKAGUWERKAq2Qu592U=", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-overridden": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/postcss-discard-overridden/download/postcss-discard-overridden-4.0.1.tgz", + "integrity": "sha1-ZSrvipZybwKfXj4AFG7npOdV/1c=", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-load-config": { + "version": "2.1.2", + "resolved": "https://registry.nlark.com/postcss-load-config/download/postcss-load-config-2.1.2.tgz?cache=0&sync_timestamp=1623669505598&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-load-config%2Fdownload%2Fpostcss-load-config-2.1.2.tgz", + "integrity": "sha1-xepQTyxK7zPHNZo03jVzdyrXUCo=", + "dev": true, + "requires": { + "cosmiconfig": "^5.0.0", + "import-cwd": "^2.0.0" + } + }, + "postcss-loader": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/postcss-loader/download/postcss-loader-3.0.0.tgz?cache=0&sync_timestamp=1625142952652&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-loader%2Fdownload%2Fpostcss-loader-3.0.0.tgz", + "integrity": "sha1-a5eUPkfHLYRfqeA/Jzdz1OjdbC0=", + "dev": true, + "requires": { + "loader-utils": "^1.1.0", + "postcss": "^7.0.0", + "postcss-load-config": "^2.0.0", + "schema-utils": "^1.0.0" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/schema-utils/download/schema-utils-1.0.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-1.0.0.tgz", + "integrity": "sha1-C3mpMgTXtgDUsoUNH2bCo0lRx3A=", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "postcss-merge-longhand": { + "version": "4.0.11", + "resolved": "https://registry.nlark.com/postcss-merge-longhand/download/postcss-merge-longhand-4.0.11.tgz", + "integrity": "sha1-YvSaE+Sg7gTnuY9CuxYGLKJUniQ=", + "dev": true, + "requires": { + "css-color-names": "0.0.4", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "stylehacks": "^4.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-merge-rules": { + "version": "4.0.3", + "resolved": "https://registry.nlark.com/postcss-merge-rules/download/postcss-merge-rules-4.0.3.tgz", + "integrity": "sha1-NivqT/Wh+Y5AdacTxsslrv75plA=", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "cssnano-util-same-parent": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0", + "vendors": "^1.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.nlark.com/postcss-selector-parser/download/postcss-selector-parser-3.1.2.tgz?cache=0&sync_timestamp=1620753051451&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-selector-parser%2Fdownload%2Fpostcss-selector-parser-3.1.2.tgz", + "integrity": "sha1-sxD1xMD9r3b5SQK7qjDbaqhPUnA=", + "dev": true, + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-minify-font-values": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-minify-font-values/download/postcss-minify-font-values-4.0.2.tgz", + "integrity": "sha1-zUw0TM5HQ0P6xdgiBqssvLiv1aY=", + "dev": true, + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-minify-gradients": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-minify-gradients/download/postcss-minify-gradients-4.0.2.tgz?cache=0&sync_timestamp=1621449817860&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-minify-gradients%2Fdownload%2Fpostcss-minify-gradients-4.0.2.tgz", + "integrity": "sha1-k7KcL/UJnFNe7NpWxKpuZlpmNHE=", + "dev": true, + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "is-color-stop": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-minify-params": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-minify-params/download/postcss-minify-params-4.0.2.tgz", + "integrity": "sha1-a5zvAwwR41Jh+V9hjJADbWgNuHQ=", + "dev": true, + "requires": { + "alphanum-sort": "^1.0.0", + "browserslist": "^4.0.0", + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "uniqs": "^2.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-minify-selectors": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-minify-selectors/download/postcss-minify-selectors-4.0.2.tgz?cache=0&sync_timestamp=1621449812496&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-minify-selectors%2Fdownload%2Fpostcss-minify-selectors-4.0.2.tgz", + "integrity": "sha1-4uXrQL/uUA0M2SQ1APX46kJi+9g=", + "dev": true, + "requires": { + "alphanum-sort": "^1.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.nlark.com/postcss-selector-parser/download/postcss-selector-parser-3.1.2.tgz?cache=0&sync_timestamp=1620753051451&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-selector-parser%2Fdownload%2Fpostcss-selector-parser-3.1.2.tgz", + "integrity": "sha1-sxD1xMD9r3b5SQK7qjDbaqhPUnA=", + "dev": true, + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-modules-extract-imports": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/postcss-modules-extract-imports/download/postcss-modules-extract-imports-2.0.0.tgz?cache=0&sync_timestamp=1602588260997&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpostcss-modules-extract-imports%2Fdownload%2Fpostcss-modules-extract-imports-2.0.0.tgz", + "integrity": "sha1-gYcZoa4doyX5gyRGsBE27rSTzX4=", + "dev": true, + "requires": { + "postcss": "^7.0.5" + } + }, + "postcss-modules-local-by-default": { + "version": "3.0.3", + "resolved": "https://registry.npm.taobao.org/postcss-modules-local-by-default/download/postcss-modules-local-by-default-3.0.3.tgz", + "integrity": "sha1-uxTgzHgnnVBNvcv9fgyiiZP/u7A=", + "dev": true, + "requires": { + "icss-utils": "^4.1.1", + "postcss": "^7.0.32", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.1.0" + } + }, + "postcss-modules-scope": { + "version": "2.2.0", + "resolved": "https://registry.nlark.com/postcss-modules-scope/download/postcss-modules-scope-2.2.0.tgz", + "integrity": "sha1-OFyuATzHdD9afXYC0Qc6iequYu4=", + "dev": true, + "requires": { + "postcss": "^7.0.6", + "postcss-selector-parser": "^6.0.0" + } + }, + "postcss-modules-values": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/postcss-modules-values/download/postcss-modules-values-3.0.0.tgz?cache=0&sync_timestamp=1602586215124&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpostcss-modules-values%2Fdownload%2Fpostcss-modules-values-3.0.0.tgz", + "integrity": "sha1-W1AA1uuuKbQlUwG0o6VFdEI+fxA=", + "dev": true, + "requires": { + "icss-utils": "^4.0.0", + "postcss": "^7.0.6" + } + }, + "postcss-normalize-charset": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/postcss-normalize-charset/download/postcss-normalize-charset-4.0.1.tgz?cache=0&sync_timestamp=1621449813014&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-normalize-charset%2Fdownload%2Fpostcss-normalize-charset-4.0.1.tgz", + "integrity": "sha1-izWt067oOhNrBHHg1ZvlilAoXdQ=", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-normalize-display-values": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-normalize-display-values/download/postcss-normalize-display-values-4.0.2.tgz", + "integrity": "sha1-Db4EpM6QY9RmftK+R2u4MMglk1o=", + "dev": true, + "requires": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-normalize-positions": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-normalize-positions/download/postcss-normalize-positions-4.0.2.tgz", + "integrity": "sha1-BfdX+E8mBDc3g2ipH4ky1LECkX8=", + "dev": true, + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-normalize-repeat-style": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-normalize-repeat-style/download/postcss-normalize-repeat-style-4.0.2.tgz", + "integrity": "sha1-xOu8KJ85kaAo1EdRy90RkYsXkQw=", + "dev": true, + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-normalize-string": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-normalize-string/download/postcss-normalize-string-4.0.2.tgz", + "integrity": "sha1-zUTECrB6DHo23F6Zqs4eyk7CaQw=", + "dev": true, + "requires": { + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-normalize-timing-functions": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-normalize-timing-functions/download/postcss-normalize-timing-functions-4.0.2.tgz", + "integrity": "sha1-jgCcoqOUnNr4rSPmtquZy159KNk=", + "dev": true, + "requires": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-normalize-unicode": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/postcss-normalize-unicode/download/postcss-normalize-unicode-4.0.1.tgz", + "integrity": "sha1-hBvUj9zzAZrUuqdJOj02O1KuHPs=", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-normalize-url": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/postcss-normalize-url/download/postcss-normalize-url-4.0.1.tgz", + "integrity": "sha1-EOQ3+GvHx+WPe5ZS7YeNqqlfquE=", + "dev": true, + "requires": { + "is-absolute-url": "^2.0.0", + "normalize-url": "^3.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "normalize-url": { + "version": "3.3.0", + "resolved": "https://registry.nlark.com/normalize-url/download/normalize-url-3.3.0.tgz?cache=0&sync_timestamp=1625826704090&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fnormalize-url%2Fdownload%2Fnormalize-url-3.3.0.tgz", + "integrity": "sha1-suHE3E98bVd0PfczpPWXjRhlBVk=", + "dev": true + }, + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-normalize-whitespace": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-normalize-whitespace/download/postcss-normalize-whitespace-4.0.2.tgz", + "integrity": "sha1-vx1AcP5Pzqh9E0joJdjMDF+qfYI=", + "dev": true, + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-ordered-values": { + "version": "4.1.2", + "resolved": "https://registry.nlark.com/postcss-ordered-values/download/postcss-ordered-values-4.1.2.tgz", + "integrity": "sha1-DPdcgg7H1cTSgBiVWeC1ceusDu4=", + "dev": true, + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-reduce-initial": { + "version": "4.0.3", + "resolved": "https://registry.nlark.com/postcss-reduce-initial/download/postcss-reduce-initial-4.0.3.tgz?cache=0&sync_timestamp=1621449818195&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-reduce-initial%2Fdownload%2Fpostcss-reduce-initial-4.0.3.tgz", + "integrity": "sha1-f9QuvqXpyBRgljniwuhK4nC6SN8=", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0" + } + }, + "postcss-reduce-transforms": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/postcss-reduce-transforms/download/postcss-reduce-transforms-4.0.2.tgz", + "integrity": "sha1-F++kBerMbge+NBSlyi0QdGgdTik=", + "dev": true, + "requires": { + "cssnano-util-get-match": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-selector-parser": { + "version": "6.0.6", + "resolved": "https://registry.nlark.com/postcss-selector-parser/download/postcss-selector-parser-6.0.6.tgz?cache=0&sync_timestamp=1620753051451&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-selector-parser%2Fdownload%2Fpostcss-selector-parser-6.0.6.tgz", + "integrity": "sha1-LFu6gXSsL2mBq2MaQqsO5UrzMuo=", + "dev": true, + "requires": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + } + }, + "postcss-svgo": { + "version": "4.0.3", + "resolved": "https://registry.nlark.com/postcss-svgo/download/postcss-svgo-4.0.3.tgz", + "integrity": "sha1-NDos26yVBdQWJD1Jb3JPOIlMlB4=", + "dev": true, + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "svgo": "^1.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz", + "integrity": "sha1-n/giVH4okyE88cMO+lGsX9G6goE=", + "dev": true + } + } + }, + "postcss-unique-selectors": { + "version": "4.0.1", + "resolved": "https://registry.nlark.com/postcss-unique-selectors/download/postcss-unique-selectors-4.0.1.tgz?cache=0&sync_timestamp=1621449819576&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-unique-selectors%2Fdownload%2Fpostcss-unique-selectors-4.0.1.tgz", + "integrity": "sha1-lEaRHzKJv9ZMbWgPBzwDsfnuS6w=", + "dev": true, + "requires": { + "alphanum-sort": "^1.0.0", + "postcss": "^7.0.0", + "uniqs": "^2.0.0" + } + }, + "postcss-value-parser": { + "version": "4.1.0", + "resolved": "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-4.1.0.tgz", + "integrity": "sha1-RD9qIM7WSBor2k+oUypuVdeJoss=", + "dev": true + }, + "prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/prelude-ls/download/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" + }, + "prepend-http": { + "version": "1.0.4", + "resolved": "https://registry.nlark.com/prepend-http/download/prepend-http-1.0.4.tgz", + "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=", + "dev": true + }, + "prettier": { + "version": "1.19.1", + "resolved": "https://registry.nlark.com/prettier/download/prettier-1.19.1.tgz?cache=0&sync_timestamp=1624696259185&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fprettier%2Fdownload%2Fprettier-1.19.1.tgz", + "integrity": "sha1-99f1/4qc2HKnvkyhQglZVqYHl8s=", + "dev": true, + "optional": true + }, + "pretty-error": { + "version": "2.1.2", + "resolved": "https://registry.nlark.com/pretty-error/download/pretty-error-2.1.2.tgz?cache=0&sync_timestamp=1623342956536&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpretty-error%2Fdownload%2Fpretty-error-2.1.2.tgz", + "integrity": "sha1-von4LYGxyG7I/fvDhQRYgnJ/k7Y=", + "dev": true, + "requires": { + "lodash": "^4.17.20", + "renderkid": "^2.0.4" + } + }, + "process": { + "version": "0.11.10", + "resolved": "https://registry.npm.taobao.org/process/download/process-0.11.10.tgz", + "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=", + "dev": true + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.nlark.com/process-nextick-args/download/process-nextick-args-2.0.1.tgz", + "integrity": "sha1-eCDZsWEgzFXKmud5JoCufbptf+I=" + }, + "progress": { + "version": "2.0.3", + "resolved": "https://registry.npm.taobao.org/progress/download/progress-2.0.3.tgz", + "integrity": "sha1-foz42PW48jnBvGi+tOt4Vn1XLvg=", + "dev": true + }, + "promise-inflight": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/promise-inflight/download/promise-inflight-1.0.1.tgz", + "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM=", + "dev": true + }, + "proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.nlark.com/proxy-addr/download/proxy-addr-2.0.7.tgz", + "integrity": "sha1-8Z/mnOqzEe65S0LnDowgcPm6ECU=", + "dev": true, + "requires": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + } + }, + "proxy-agent": { + "version": "5.0.0", + "resolved": "https://registry.npmmirror.com/proxy-agent/-/proxy-agent-5.0.0.tgz", + "integrity": "sha512-gkH7BkvLVkSfX9Dk27W6TyNOWWZWRilRfk1XxGNWOYJ2TuedAv1yFpCaU9QSBmBe716XOTNpYNOzhysyw8xn7g==", + "requires": { + "agent-base": "^6.0.0", + "debug": "4", + "http-proxy-agent": "^4.0.0", + "https-proxy-agent": "^5.0.0", + "lru-cache": "^5.1.1", + "pac-proxy-agent": "^5.0.0", + "proxy-from-env": "^1.0.0", + "socks-proxy-agent": "^5.0.0" + } + }, + "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==" + }, + "prr": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/prr/download/prr-1.0.1.tgz", + "integrity": "sha1-0/wRS6BplaRexok/SEzrHXj19HY=" + }, + "pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/pseudomap/download/pseudomap-1.0.2.tgz", + "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", + "dev": true + }, + "psl": { + "version": "1.8.0", + "resolved": "https://registry.nlark.com/psl/download/psl-1.8.0.tgz", + "integrity": "sha1-kyb4vPsBOtzABf3/BWrM4CDlHCQ=" + }, + "public-encrypt": { + "version": "4.0.3", + "resolved": "https://registry.npm.taobao.org/public-encrypt/download/public-encrypt-4.0.3.tgz", + "integrity": "sha1-T8ydd6B+SLp1J+fL4N4z0HATMeA=", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "parse-asn1": "^5.0.0", + "randombytes": "^2.0.1", + "safe-buffer": "^5.1.2" + }, + "dependencies": { + "bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz", + "integrity": "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=", + "dev": true + } + } + }, + "pump": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/pump/download/pump-3.0.0.tgz", + "integrity": "sha1-tKIRaBW94vTh6mAjVOjHVWUQemQ=", + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "pumpify": { + "version": "1.5.1", + "resolved": "https://registry.npm.taobao.org/pumpify/download/pumpify-1.5.1.tgz", + "integrity": "sha1-NlE74karJ1cLGjdKXOJ4v9dDcM4=", + "dev": true, + "requires": { + "duplexify": "^3.6.0", + "inherits": "^2.0.3", + "pump": "^2.0.0" + }, + "dependencies": { + "pump": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/pump/download/pump-2.0.1.tgz", + "integrity": "sha1-Ejma3W5M91Jtlzy8i1zi4pCLOQk=", + "dev": true, + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + } + } + }, + "punycode": { + "version": "2.1.1", + "resolved": "https://registry.npm.taobao.org/punycode/download/punycode-2.1.1.tgz", + "integrity": "sha1-tYsBCsQMIsVldhbI0sLALHv0eew=" + }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.nlark.com/q/download/q-1.5.1.tgz", + "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=", + "dev": true + }, + "qs": { + "version": "6.5.2", + "resolved": "https://registry.npm.taobao.org/qs/download/qs-6.5.2.tgz", + "integrity": "sha1-yzroBuh0BERYTvFUzo7pjUA/PjY=" + }, + "query-string": { + "version": "4.3.4", + "resolved": "https://registry.nlark.com/query-string/download/query-string-4.3.4.tgz?cache=0&sync_timestamp=1624297084219&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fquery-string%2Fdownload%2Fquery-string-4.3.4.tgz", + "integrity": "sha1-u7aTucqRXCMlFbIosaArYJBD2+s=", + "dev": true, + "requires": { + "object-assign": "^4.1.0", + "strict-uri-encode": "^1.0.0" + } + }, + "querystring": { + "version": "0.2.0", + "resolved": "https://registry.nlark.com/querystring/download/querystring-0.2.0.tgz?cache=0&sync_timestamp=1626179435543&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fquerystring%2Fdownload%2Fquerystring-0.2.0.tgz", + "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", + "dev": true + }, + "querystring-es3": { + "version": "0.2.1", + "resolved": "https://registry.npm.taobao.org/querystring-es3/download/querystring-es3-0.2.1.tgz", + "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=", + "dev": true + }, + "querystringify": { + "version": "2.2.0", + "resolved": "https://registry.nlark.com/querystringify/download/querystringify-2.2.0.tgz", + "integrity": "sha1-M0WUG0FTy50ILY7uTNogFqmu9/Y=" + }, + "queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npm.taobao.org/queue-microtask/download/queue-microtask-1.2.3.tgz?cache=0&sync_timestamp=1616391548624&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fqueue-microtask%2Fdownload%2Fqueue-microtask-1.2.3.tgz", + "integrity": "sha1-SSkii7xyTfrEPg77BYyve2z7YkM=", + "dev": true + }, + "randombytes": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/randombytes/download/randombytes-2.1.0.tgz", + "integrity": "sha1-32+ENy8CcNxlzfYpE0mrekc9Tyo=", + "dev": true, + "requires": { + "safe-buffer": "^5.1.0" + } + }, + "randomfill": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/randomfill/download/randomfill-1.0.4.tgz", + "integrity": "sha1-ySGW/IarQr6YPxvzF3giSTHWFFg=", + "dev": true, + "requires": { + "randombytes": "^2.0.5", + "safe-buffer": "^5.1.0" + } + }, + "range-parser": { + "version": "1.2.1", + "resolved": "https://registry.nlark.com/range-parser/download/range-parser-1.2.1.tgz", + "integrity": "sha1-PPNwI9GZ4cJNGlW4SADC8+ZGgDE=", + "dev": true + }, + "raw-body": { + "version": "2.4.0", + "resolved": "https://registry.nlark.com/raw-body/download/raw-body-2.4.0.tgz", + "integrity": "sha1-oc5vucm8NWylLoklarWQWeE9AzI=", + "requires": { + "bytes": "3.1.0", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + } + }, + "read-pkg": { + "version": "5.2.0", + "resolved": "https://registry.npm.taobao.org/read-pkg/download/read-pkg-5.2.0.tgz?cache=0&sync_timestamp=1616914967500&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fread-pkg%2Fdownload%2Fread-pkg-5.2.0.tgz", + "integrity": "sha1-e/KVQ4yloz5WzTDgU7NO5yUMk8w=", + "dev": true, + "requires": { + "@types/normalize-package-data": "^2.4.0", + "normalize-package-data": "^2.5.0", + "parse-json": "^5.0.0", + "type-fest": "^0.6.0" + }, + "dependencies": { + "parse-json": { + "version": "5.2.0", + "resolved": "https://registry.npm.taobao.org/parse-json/download/parse-json-5.2.0.tgz?cache=0&sync_timestamp=1610966676829&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fparse-json%2Fdownload%2Fparse-json-5.2.0.tgz", + "integrity": "sha1-x2/Gbe5UIxyWKyK8yKcs8vmXU80=", + "dev": true, + "requires": { + "@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" + } + }, + "type-fest": { + "version": "0.6.0", + "resolved": "https://registry.nlark.com/type-fest/download/type-fest-0.6.0.tgz?cache=0&sync_timestamp=1625745286088&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ftype-fest%2Fdownload%2Ftype-fest-0.6.0.tgz", + "integrity": "sha1-jSojcNPfiG61yQraHFv2GIrPg4s=", + "dev": true + } + } + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.nlark.com/readable-stream/download/readable-stream-2.3.7.tgz", + "integrity": "sha1-Hsoc9xGu+BTAT2IlKjamL2yyO1c=", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "readdirp": { + "version": "2.2.1", + "resolved": "https://registry.npm.taobao.org/readdirp/download/readdirp-2.2.1.tgz", + "integrity": "sha1-DodiKjMlqjPokihcr4tOhGUppSU=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" + } + }, + "regenerate": { + "version": "1.4.2", + "resolved": "https://registry.nlark.com/regenerate/download/regenerate-1.4.2.tgz", + "integrity": "sha1-uTRtiCfo9aMve6KWN9OYtpAUhIo=", + "dev": true + }, + "regenerate-unicode-properties": { + "version": "8.2.0", + "resolved": "https://registry.nlark.com/regenerate-unicode-properties/download/regenerate-unicode-properties-8.2.0.tgz", + "integrity": "sha1-5d5xEdZV57pgwFfb6f83yH5lzew=", + "dev": true, + "requires": { + "regenerate": "^1.4.0" + } + }, + "regenerator-runtime": { + "version": "0.13.7", + "resolved": "https://registry.nlark.com/regenerator-runtime/download/regenerator-runtime-0.13.7.tgz", + "integrity": "sha1-ysLazIoepnX+qrrriugziYrkb1U=", + "dev": true + }, + "regenerator-transform": { + "version": "0.14.5", + "resolved": "https://registry.nlark.com/regenerator-transform/download/regenerator-transform-0.14.5.tgz", + "integrity": "sha1-yY2hVGg2ccnE3LFuznNlF+G3/rQ=", + "dev": true, + "requires": { + "@babel/runtime": "^7.8.4" + } + }, + "regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/regex-not/download/regex-not-1.0.2.tgz", + "integrity": "sha1-H07OJ+ALC2XgJHpoEOaoXYOldSw=", + "dev": true, + "requires": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + } + }, + "regexp.prototype.flags": { + "version": "1.3.1", + "resolved": "https://registry.nlark.com/regexp.prototype.flags/download/regexp.prototype.flags-1.3.1.tgz", + "integrity": "sha1-fvNSro0VnnWMDq3Kb4/LTu8HviY=", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + } + }, + "regexpu-core": { + "version": "4.7.1", + "resolved": "https://registry.npm.taobao.org/regexpu-core/download/regexpu-core-4.7.1.tgz", + "integrity": "sha1-LepamgcjMpj78NuR+pq8TG4PitY=", + "dev": true, + "requires": { + "regenerate": "^1.4.0", + "regenerate-unicode-properties": "^8.2.0", + "regjsgen": "^0.5.1", + "regjsparser": "^0.6.4", + "unicode-match-property-ecmascript": "^1.0.4", + "unicode-match-property-value-ecmascript": "^1.2.0" + } + }, + "regjsgen": { + "version": "0.5.2", + "resolved": "https://registry.npm.taobao.org/regjsgen/download/regjsgen-0.5.2.tgz", + "integrity": "sha1-kv8pX7He7L9uzaslQ9IH6RqjNzM=", + "dev": true + }, + "regjsparser": { + "version": "0.6.9", + "resolved": "https://registry.nlark.com/regjsparser/download/regjsparser-0.6.9.tgz", + "integrity": "sha1-tInu98mizkNydicBFCnPgzpxg+Y=", + "dev": true, + "requires": { + "jsesc": "~0.5.0" + }, + "dependencies": { + "jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npm.taobao.org/jsesc/download/jsesc-0.5.0.tgz?cache=0&sync_timestamp=1603891242793&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjsesc%2Fdownload%2Fjsesc-0.5.0.tgz", + "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", + "dev": true + } + } + }, + "relateurl": { + "version": "0.2.7", + "resolved": "https://registry.npm.taobao.org/relateurl/download/relateurl-0.2.7.tgz", + "integrity": "sha1-VNvzd+UUQKypCkzSdGANP/LYiKk=", + "dev": true + }, + "remove-trailing-separator": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/remove-trailing-separator/download/remove-trailing-separator-1.1.0.tgz", + "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", + "dev": true + }, + "renderkid": { + "version": "2.0.7", + "resolved": "https://registry.nlark.com/renderkid/download/renderkid-2.0.7.tgz?cache=0&sync_timestamp=1623343631807&other_urls=https%3A%2F%2Fregistry.nlark.com%2Frenderkid%2Fdownload%2Frenderkid-2.0.7.tgz", + "integrity": "sha1-Rk8namvc7mBvShWZP5sp/HTKhgk=", + "dev": true, + "requires": { + "css-select": "^4.1.3", + "dom-converter": "^0.2.0", + "htmlparser2": "^6.1.0", + "lodash": "^4.17.21", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-2.1.1.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + } + } + }, + "repeat-element": { + "version": "1.1.4", + "resolved": "https://registry.nlark.com/repeat-element/download/repeat-element-1.1.4.tgz", + "integrity": "sha1-vmgVIIR6tYx1aKx1+/rSjtQtOek=", + "dev": true + }, + "repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npm.taobao.org/repeat-string/download/repeat-string-1.6.1.tgz", + "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", + "dev": true + }, + "request": { + "version": "2.88.2", + "resolved": "https://registry.npm.taobao.org/request/download/request-2.88.2.tgz", + "integrity": "sha1-1zyRhzHLWofaBH4gcjQUb2ZNErM=", + "dev": true, + "requires": { + "aws-sign2": "~0.7.0", + "aws4": "^1.8.0", + "caseless": "~0.12.0", + "combined-stream": "~1.0.6", + "extend": "~3.0.2", + "forever-agent": "~0.6.1", + "form-data": "~2.3.2", + "har-validator": "~5.1.3", + "http-signature": "~1.2.0", + "is-typedarray": "~1.0.0", + "isstream": "~0.1.2", + "json-stringify-safe": "~5.0.1", + "mime-types": "~2.1.19", + "oauth-sign": "~0.9.0", + "performance-now": "^2.1.0", + "qs": "~6.5.2", + "safe-buffer": "^5.1.2", + "tough-cookie": "~2.5.0", + "tunnel-agent": "^0.6.0", + "uuid": "^3.3.2" + } + }, + "request-promise-core": { + "version": "1.1.4", + "resolved": "https://registry.npm.taobao.org/request-promise-core/download/request-promise-core-1.1.4.tgz", + "integrity": "sha1-Pu3UIjII1BmGe3jOgVFn0QWToi8=", + "dev": true, + "requires": { + "lodash": "^4.17.19" + } + }, + "request-promise-native": { + "version": "1.0.9", + "resolved": "https://registry.nlark.com/request-promise-native/download/request-promise-native-1.0.9.tgz?cache=0&sync_timestamp=1618846813899&other_urls=https%3A%2F%2Fregistry.nlark.com%2Frequest-promise-native%2Fdownload%2Frequest-promise-native-1.0.9.tgz", + "integrity": "sha1-5AcSBSal79yaObKKVnm/R7nZ3Cg=", + "dev": true, + "requires": { + "request-promise-core": "1.1.4", + "stealthy-require": "^1.1.1", + "tough-cookie": "^2.3.3" + } + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.nlark.com/require-directory/download/require-directory-2.1.1.tgz", + "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", + "dev": true + }, + "require-main-filename": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/require-main-filename/download/require-main-filename-2.0.0.tgz", + "integrity": "sha1-0LMp7MfMD2Fkn2IhW+aa9UqomJs=", + "dev": true + }, + "requires-port": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/requires-port/download/requires-port-1.0.0.tgz", + "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=" + }, + "resolve": { + "version": "1.20.0", + "resolved": "https://registry.npm.taobao.org/resolve/download/resolve-1.20.0.tgz?cache=0&sync_timestamp=1613054862388&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fresolve%2Fdownload%2Fresolve-1.20.0.tgz", + "integrity": "sha1-YpoBP7P3B1XW8LeTXMHCxTeLGXU=", + "dev": true, + "requires": { + "is-core-module": "^2.2.0", + "path-parse": "^1.0.6" + } + }, + "resolve-cwd": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/resolve-cwd/download/resolve-cwd-2.0.0.tgz", + "integrity": "sha1-AKn3OHVW4nA46uIyyqNypqWbZlo=", + "dev": true, + "requires": { + "resolve-from": "^3.0.0" + } + }, + "resolve-from": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/resolve-from/download/resolve-from-3.0.0.tgz", + "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=", + "dev": true + }, + "resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.nlark.com/resolve-url/download/resolve-url-0.2.1.tgz", + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", + "dev": true + }, + "restore-cursor": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/restore-cursor/download/restore-cursor-3.1.0.tgz", + "integrity": "sha1-OfZ8VLOnpYzqUjbZXPADQjljH34=", + "dev": true, + "requires": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + } + }, + "ret": { + "version": "0.1.15", + "resolved": "https://registry.npm.taobao.org/ret/download/ret-0.1.15.tgz?cache=0&sync_timestamp=1613002640681&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fret%2Fdownload%2Fret-0.1.15.tgz", + "integrity": "sha1-uKSCXVvbH8P29Twrwz+BOIaBx7w=", + "dev": true + }, + "retry": { + "version": "0.12.0", + "resolved": "https://registry.nlark.com/retry/download/retry-0.12.0.tgz", + "integrity": "sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs=", + "dev": true + }, + "reusify": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/reusify/download/reusify-1.0.4.tgz", + "integrity": "sha1-kNo4Kx4SbvwCFG6QhFqI2xKSXXY=", + "dev": true + }, + "rgb-regex": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/rgb-regex/download/rgb-regex-1.0.1.tgz", + "integrity": "sha1-wODWiC3w4jviVKR16O3UGRX+rrE=", + "dev": true + }, + "rgba-regex": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/rgba-regex/download/rgba-regex-1.0.0.tgz", + "integrity": "sha1-QzdOLiyglosO8VI0YLfXMP8i7rM=", + "dev": true + }, + "rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npm.taobao.org/rimraf/download/rimraf-2.7.1.tgz", + "integrity": "sha1-NXl/E6f9rcVmFCwp1PB8ytSD4+w=", + "requires": { + "glob": "^7.1.3" + } + }, + "ripemd160": { + "version": "2.0.2", + "resolved": "https://registry.npm.taobao.org/ripemd160/download/ripemd160-2.0.2.tgz", + "integrity": "sha1-ocGm9iR1FXe6XQeRTLyShQWFiQw=", + "dev": true, + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1" + } + }, + "run-async": { + "version": "2.4.1", + "resolved": "https://registry.npm.taobao.org/run-async/download/run-async-2.4.1.tgz", + "integrity": "sha1-hEDsz5nqPnC9QJ1JqriOEMGJpFU=", + "dev": true + }, + "run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/run-parallel/download/run-parallel-1.2.0.tgz?cache=0&sync_timestamp=1612925912322&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Frun-parallel%2Fdownload%2Frun-parallel-1.2.0.tgz", + "integrity": "sha1-ZtE2jae9+SHrnZW9GpIp5/IaQ+4=", + "dev": true, + "requires": { + "queue-microtask": "^1.2.2" + } + }, + "run-queue": { + "version": "1.0.3", + "resolved": "https://registry.npm.taobao.org/run-queue/download/run-queue-1.0.3.tgz", + "integrity": "sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec=", + "dev": true, + "requires": { + "aproba": "^1.1.1" + } + }, + "rxjs": { + "version": "6.6.7", + "resolved": "https://registry.nlark.com/rxjs/download/rxjs-6.6.7.tgz", + "integrity": "sha1-kKwBisq/SRv2UEQjXVhjxNq4BMk=", + "dev": true, + "requires": { + "tslib": "^1.9.0" + }, + "dependencies": { + "tslib": { + "version": "1.14.1", + "resolved": "https://registry.nlark.com/tslib/download/tslib-1.14.1.tgz", + "integrity": "sha1-zy04vcNKE0vK8QkcQfZhni9nLQA=", + "dev": true + } + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npm.taobao.org/safe-buffer/download/safe-buffer-5.1.2.tgz", + "integrity": "sha1-mR7GnSluAxN0fVm9/St0XDX4go0=" + }, + "safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.nlark.com/safe-regex/download/safe-regex-1.1.0.tgz", + "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "dev": true, + "requires": { + "ret": "~0.1.10" + } + }, + "safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.nlark.com/safer-buffer/download/safer-buffer-2.1.2.tgz", + "integrity": "sha1-RPoWGwGHuVSd2Eu5GAL5vYOFzWo=" + }, + "sass": { + "version": "1.80.3", + "resolved": "https://registry.npmmirror.com/sass/-/sass-1.80.3.tgz", + "integrity": "sha512-ptDWyVmDMVielpz/oWy3YP3nfs7LpJTHIJZboMVs8GEC9eUmtZTZhMHlTW98wY4aEorDfjN38+Wr/XjskFWcfA==", + "dev": true, + "requires": { + "@parcel/watcher": "^2.4.1", + "chokidar": "^4.0.0", + "immutable": "^4.0.0", + "source-map-js": ">=0.6.2 <2.0.0" + }, + "dependencies": { + "chokidar": { + "version": "4.0.1", + "resolved": "https://registry.npmmirror.com/chokidar/-/chokidar-4.0.1.tgz", + "integrity": "sha512-n8enUVCED/KVRQlab1hr3MVpcVMvxtZjmEa956u+4YijlmQED223XMSYj2tLuKvr4jcCTzNNMpQDUer72MMmzA==", + "dev": true, + "requires": { + "readdirp": "^4.0.1" + } + }, + "readdirp": { + "version": "4.0.2", + "resolved": "https://registry.npmmirror.com/readdirp/-/readdirp-4.0.2.tgz", + "integrity": "sha512-yDMz9g+VaZkqBYS/ozoBJwaBhTbZo3UNYQHNRw1D3UFQB8oHB4uS/tAODO+ZLjGWmUbKnIlOWO+aaIiAxrUWHA==", + "dev": true + } + } + }, + "sass-loader": { + "version": "16.0.2", + "resolved": "https://registry.npmmirror.com/sass-loader/-/sass-loader-16.0.2.tgz", + "integrity": "sha512-Ll6iXZ1EYwYT19SqW4mSBb76vSSi8JgzElmzIerhEGgzB5hRjDQIWsPmuk1UrAXkR16KJHqVY0eH+5/uw9Tmfw==", + "dev": true, + "requires": { + "neo-async": "^2.6.2" + } + }, + "sax": { + "version": "1.2.4", + "resolved": "https://registry.nlark.com/sax/download/sax-1.2.4.tgz", + "integrity": "sha1-KBYjTiN4vdxOU1T6tcqold9xANk=" + }, + "saxes": { + "version": "3.1.11", + "resolved": "https://registry.npm.taobao.org/saxes/download/saxes-3.1.11.tgz", + "integrity": "sha1-1Z0f0zLskq2YouCy7mRHAjhLHFs=", + "dev": true, + "requires": { + "xmlchars": "^2.1.1" + } + }, + "schema-utils": { + "version": "2.7.1", + "resolved": "https://registry.nlark.com/schema-utils/download/schema-utils-2.7.1.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-2.7.1.tgz", + "integrity": "sha1-HKTzLRskxZDCA7jnpQvw6kzTlNc=", + "dev": true, + "requires": { + "@types/json-schema": "^7.0.5", + "ajv": "^6.12.4", + "ajv-keywords": "^3.5.2" + } + }, + "sdk-base": { + "version": "2.0.1", + "resolved": "https://registry.npmmirror.com/sdk-base/-/sdk-base-2.0.1.tgz", + "integrity": "sha512-eeG26wRwhtwYuKGCDM3LixCaxY27Pa/5lK4rLKhQa7HBjJ3U3Y+f81MMZQRsDw/8SC2Dao/83yJTXJ8aULuN8Q==", + "requires": { + "get-ready": "~1.0.0" + } + }, + "select-hose": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/select-hose/download/select-hose-2.0.0.tgz", + "integrity": "sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo=", + "dev": true + }, + "selfsigned": { + "version": "1.10.11", + "resolved": "https://registry.nlark.com/selfsigned/download/selfsigned-1.10.11.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fselfsigned%2Fdownload%2Fselfsigned-1.10.11.tgz", + "integrity": "sha1-JJKc2Qb+D0S20B+yOZmnOVN6y+k=", + "dev": true, + "requires": { + "node-forge": "^0.10.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.nlark.com/semver/download/semver-6.3.0.tgz", + "integrity": "sha1-7gpkyK9ejO6mdoexM3YeG+y9HT0=", + "dev": true + }, + "send": { + "version": "0.17.1", + "resolved": "https://registry.npm.taobao.org/send/download/send-0.17.1.tgz", + "integrity": "sha1-wdiwWfeQD3Rm3Uk4vcROEd2zdsg=", + "dev": true, + "requires": { + "debug": "2.6.9", + "depd": "~1.1.2", + "destroy": "~1.0.4", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "~1.7.2", + "mime": "1.6.0", + "ms": "2.1.1", + "on-finished": "~2.3.0", + "range-parser": "~1.2.1", + "statuses": "~1.5.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.nlark.com/debug/download/debug-2.6.9.tgz", + "integrity": "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=", + "dev": true, + "requires": { + "ms": "2.0.0" + }, + "dependencies": { + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + } + } + }, + "mime": { + "version": "1.6.0", + "resolved": "https://registry.nlark.com/mime/download/mime-1.6.0.tgz", + "integrity": "sha1-Ms2eXGRVO9WNGaVor0Uqz/BJgbE=", + "dev": true + }, + "ms": { + "version": "2.1.1", + "resolved": "https://registry.npm.taobao.org/ms/download/ms-2.1.1.tgz?cache=0&sync_timestamp=1607433856030&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fms%2Fdownload%2Fms-2.1.1.tgz", + "integrity": "sha1-MKWGTrPrsKZvLr5tcnrwagnYbgo=", + "dev": true + } + } + }, + "serialize-javascript": { + "version": "4.0.0", + "resolved": "https://registry.nlark.com/serialize-javascript/download/serialize-javascript-4.0.0.tgz", + "integrity": "sha1-tSXhI4SJpez8Qq+sw/6Z5mb0sao=", + "dev": true, + "requires": { + "randombytes": "^2.1.0" + } + }, + "serve-index": { + "version": "1.9.1", + "resolved": "https://registry.npm.taobao.org/serve-index/download/serve-index-1.9.1.tgz", + "integrity": "sha1-03aNabHn2C5c4FD/9bRTvqEqkjk=", + "dev": true, + "requires": { + "accepts": "~1.3.4", + "batch": "0.6.1", + "debug": "2.6.9", + "escape-html": "~1.0.3", + "http-errors": "~1.6.2", + "mime-types": "~2.1.17", + "parseurl": "~1.3.2" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.nlark.com/debug/download/debug-2.6.9.tgz", + "integrity": "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "http-errors": { + "version": "1.6.3", + "resolved": "https://registry.npm.taobao.org/http-errors/download/http-errors-1.6.3.tgz", + "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", + "dev": true, + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.0", + "statuses": ">= 1.4.0 < 2" + } + }, + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npm.taobao.org/inherits/download/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "setprototypeof": { + "version": "1.1.0", + "resolved": "https://registry.nlark.com/setprototypeof/download/setprototypeof-1.1.0.tgz", + "integrity": "sha1-0L2FU2iHtv58DYGMuWLZ2RxU5lY=", + "dev": true + } + } + }, + "serve-static": { + "version": "1.14.1", + "resolved": "https://registry.npm.taobao.org/serve-static/download/serve-static-1.14.1.tgz", + "integrity": "sha1-Zm5jbcTwEPfvKZcKiKZ0MgiYsvk=", + "dev": true, + "requires": { + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.17.1" + } + }, + "set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/set-blocking/download/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", + "dev": true + }, + "set-value": { + "version": "2.0.1", + "resolved": "https://registry.nlark.com/set-value/download/set-value-2.0.1.tgz", + "integrity": "sha1-oY1AUw5vB95CKMfe/kInr4ytAFs=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + } + } + }, + "setimmediate": { + "version": "1.0.5", + "resolved": "https://registry.npm.taobao.org/setimmediate/download/setimmediate-1.0.5.tgz", + "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=", + "dev": true + }, + "setprototypeof": { + "version": "1.1.1", + "resolved": "https://registry.nlark.com/setprototypeof/download/setprototypeof-1.1.1.tgz", + "integrity": "sha1-fpWsskqpL1iF4KvvW6ExMw1K5oM=" + }, + "sha.js": { + "version": "2.4.11", + "resolved": "https://registry.npm.taobao.org/sha.js/download/sha.js-2.4.11.tgz", + "integrity": "sha1-N6XPC4HsvGlD3hCbopYNGyZYSuc=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true + }, + "shell-quote": { + "version": "1.7.2", + "resolved": "https://registry.npm.taobao.org/shell-quote/download/shell-quote-1.7.2.tgz", + "integrity": "sha1-Z6fQLHbJ2iT5nSCAj8re0ODgS+I=", + "dev": true + }, + "signal-exit": { + "version": "3.0.3", + "resolved": "https://registry.npm.taobao.org/signal-exit/download/signal-exit-3.0.3.tgz", + "integrity": "sha1-oUEMLt2PB3sItOJTyOrPyvBXRhw=", + "dev": true + }, + "simple-swizzle": { + "version": "0.2.2", + "resolved": "https://registry.nlark.com/simple-swizzle/download/simple-swizzle-0.2.2.tgz", + "integrity": "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=", + "dev": true, + "requires": { + "is-arrayish": "^0.3.1" + }, + "dependencies": { + "is-arrayish": { + "version": "0.3.2", + "resolved": "https://registry.nlark.com/is-arrayish/download/is-arrayish-0.3.2.tgz", + "integrity": "sha1-RXSirlb3qyBolvtDHq7tBm/fjwM=", + "dev": true + } + } + }, + "slash": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/slash/download/slash-2.0.0.tgz", + "integrity": "sha1-3lUoUaF1nfOo8gZTVEL17E3eq0Q=", + "dev": true + }, + "smart-buffer": { + "version": "4.2.0", + "resolved": "https://registry.npmmirror.com/smart-buffer/-/smart-buffer-4.2.0.tgz", + "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" + }, + "snapdragon": { + "version": "0.8.2", + "resolved": "https://registry.npm.taobao.org/snapdragon/download/snapdragon-0.8.2.tgz", + "integrity": "sha1-ZJIufFZbDhQgS6GqfWlkJ40lGC0=", + "dev": true, + "requires": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-accessor-descriptor/download/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.nlark.com/is-data-descriptor/download/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-descriptor/download/is-descriptor-0.1.6.tgz", + "integrity": "sha1-Nm2CQN3kh8pRgjsaufB6EKeCUco=", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + }, + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-5.1.0.tgz", + "integrity": "sha1-cpyR4thXt6QZofmqZWhcTDP1hF0=", + "dev": true + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + } + } + }, + "snapdragon-node": { + "version": "2.1.1", + "resolved": "https://registry.nlark.com/snapdragon-node/download/snapdragon-node-2.1.1.tgz", + "integrity": "sha1-bBdfhv8UvbByRWPo88GwIaKGhTs=", + "dev": true, + "requires": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + } + } + }, + "snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npm.taobao.org/snapdragon-util/download/snapdragon-util-3.0.1.tgz", + "integrity": "sha1-+VZHlIbyrNeXAGk/b3uAXkWrVuI=", + "dev": true, + "requires": { + "kind-of": "^3.2.0" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "sockjs": { + "version": "0.3.21", + "resolved": "https://registry.nlark.com/sockjs/download/sockjs-0.3.21.tgz", + "integrity": "sha1-s0/7mOeWkwtgoM+hGQTWozmn1Bc=", + "dev": true, + "requires": { + "faye-websocket": "^0.11.3", + "uuid": "^3.4.0", + "websocket-driver": "^0.7.4" + } + }, + "sockjs-client": { + "version": "1.5.1", + "resolved": "https://registry.npm.taobao.org/sockjs-client/download/sockjs-client-1.5.1.tgz", + "integrity": "sha1-JWkI9tWt+5Tau9vQLGY2LMoPnqY=", + "dev": true, + "requires": { + "debug": "^3.2.6", + "eventsource": "^1.0.7", + "faye-websocket": "^0.11.3", + "inherits": "^2.0.4", + "json3": "^3.3.3", + "url-parse": "^1.5.1" + }, + "dependencies": { + "debug": { + "version": "3.2.7", + "resolved": "https://registry.nlark.com/debug/download/debug-3.2.7.tgz", + "integrity": "sha1-clgLfpFF+zm2Z2+cXl+xALk0F5o=", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "socks": { + "version": "2.7.1", + "resolved": "https://registry.npmmirror.com/socks/-/socks-2.7.1.tgz", + "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", + "requires": { + "ip": "^2.0.0", + "smart-buffer": "^4.2.0" + }, + "dependencies": { + "ip": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ip/-/ip-2.0.0.tgz", + "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" + } + } + }, + "socks-proxy-agent": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/socks-proxy-agent/-/socks-proxy-agent-5.0.1.tgz", + "integrity": "sha512-vZdmnjb9a2Tz6WEQVIurybSwElwPxMZaIc7PzqbJTrezcKNznv6giT7J7tZDZ1BojVaa1jvO/UiUdhDVB0ACoQ==", + "requires": { + "agent-base": "^6.0.2", + "debug": "4", + "socks": "^2.3.3" + } + }, + "sort-keys": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/sort-keys/download/sort-keys-1.1.2.tgz", + "integrity": "sha1-RBttTTRnmPG05J6JIK37oOVD+a0=", + "dev": true, + "requires": { + "is-plain-obj": "^1.0.0" + }, + "dependencies": { + "is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/is-plain-obj/download/is-plain-obj-1.1.0.tgz?cache=0&sync_timestamp=1618600554597&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-plain-obj%2Fdownload%2Fis-plain-obj-1.1.0.tgz", + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=", + "dev": true + } + } + }, + "source-list-map": { + "version": "2.0.1", + "resolved": "https://registry.nlark.com/source-list-map/download/source-list-map-2.0.1.tgz", + "integrity": "sha1-OZO9hzv8SEecyp6jpUeDXHwVSzQ=", + "dev": true + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", + "dev": true + }, + "source-map-js": { + "version": "0.6.2", + "resolved": "https://registry.npm.taobao.org/source-map-js/download/source-map-js-0.6.2.tgz", + "integrity": "sha1-C7XeYxtBz72mz7qL0FqA79/SOF4=" + }, + "source-map-resolve": { + "version": "0.5.3", + "resolved": "https://registry.nlark.com/source-map-resolve/download/source-map-resolve-0.5.3.tgz", + "integrity": "sha1-GQhmvs51U+H48mei7oLGBrVQmho=", + "dev": true, + "requires": { + "atob": "^2.1.2", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } + }, + "source-map-support": { + "version": "0.5.19", + "resolved": "https://registry.nlark.com/source-map-support/download/source-map-support-0.5.19.tgz", + "integrity": "sha1-qYti+G3K9PZzmWSMCFKRq56P7WE=", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "source-map-url": { + "version": "0.4.1", + "resolved": "https://registry.npm.taobao.org/source-map-url/download/source-map-url-0.4.1.tgz?cache=0&sync_timestamp=1612210508484&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fsource-map-url%2Fdownload%2Fsource-map-url-0.4.1.tgz", + "integrity": "sha1-CvZmBadFpaL5HPG7+KevvCg97FY=", + "dev": true + }, + "sourcemap-codec": { + "version": "1.4.8", + "resolved": "https://registry.npm.taobao.org/sourcemap-codec/download/sourcemap-codec-1.4.8.tgz", + "integrity": "sha1-6oBL2UhXQC5pktBaOO8a41qatMQ=" + }, + "spdx-correct": { + "version": "3.1.1", + "resolved": "https://registry.npm.taobao.org/spdx-correct/download/spdx-correct-3.1.1.tgz", + "integrity": "sha1-3s6BrJweZxPl99G28X1Gj6U9iak=", + "dev": true, + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.3.0", + "resolved": "https://registry.npm.taobao.org/spdx-exceptions/download/spdx-exceptions-2.3.0.tgz", + "integrity": "sha1-PyjOGnegA3JoPq3kpDMYNSeiFj0=", + "dev": true + }, + "spdx-expression-parse": { + "version": "3.0.1", + "resolved": "https://registry.npm.taobao.org/spdx-expression-parse/download/spdx-expression-parse-3.0.1.tgz", + "integrity": "sha1-z3D1BILu/cmOPOCmgz5KU87rpnk=", + "dev": true, + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.9", + "resolved": "https://registry.nlark.com/spdx-license-ids/download/spdx-license-ids-3.0.9.tgz", + "integrity": "sha1-illRNd75WSvaaXCUdPHL7qfCRn8=", + "dev": true + }, + "spdy": { + "version": "4.0.2", + "resolved": "https://registry.npm.taobao.org/spdy/download/spdy-4.0.2.tgz", + "integrity": "sha1-t09GYgOj7aRSwCSSuR+56EonZ3s=", + "dev": true, + "requires": { + "debug": "^4.1.0", + "handle-thing": "^2.0.0", + "http-deceiver": "^1.2.7", + "select-hose": "^2.0.0", + "spdy-transport": "^3.0.0" + } + }, + "spdy-transport": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/spdy-transport/download/spdy-transport-3.0.0.tgz", + "integrity": "sha1-ANSGOmQArXXfkzYaFghgXl3NzzE=", + "dev": true, + "requires": { + "debug": "^4.1.0", + "detect-node": "^2.0.4", + "hpack.js": "^2.1.6", + "obuf": "^1.1.2", + "readable-stream": "^3.0.6", + "wbuf": "^1.7.3" + }, + "dependencies": { + "readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.nlark.com/readable-stream/download/readable-stream-3.6.0.tgz", + "integrity": "sha1-M3u9o63AcGvT4CRCaihtS0sskZg=", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + } + } + }, + "split-string": { + "version": "3.1.0", + "resolved": "https://registry.npm.taobao.org/split-string/download/split-string-3.1.0.tgz", + "integrity": "sha1-fLCd2jqGWFcFxks5pkZgOGguj+I=", + "dev": true, + "requires": { + "extend-shallow": "^3.0.0" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.nlark.com/sprintf-js/download/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + }, + "sshpk": { + "version": "1.16.1", + "resolved": "https://registry.nlark.com/sshpk/download/sshpk-1.16.1.tgz", + "integrity": "sha1-+2YcC+8ps520B2nuOfpwCT1vaHc=", + "dev": true, + "requires": { + "asn1": "~0.2.3", + "assert-plus": "^1.0.0", + "bcrypt-pbkdf": "^1.0.0", + "dashdash": "^1.12.0", + "ecc-jsbn": "~0.1.1", + "getpass": "^0.1.1", + "jsbn": "~0.1.0", + "safer-buffer": "^2.0.2", + "tweetnacl": "~0.14.0" + } + }, + "ssri": { + "version": "8.0.1", + "resolved": "https://registry.nlark.com/ssri/download/ssri-8.0.1.tgz?cache=0&sync_timestamp=1621364918494&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fssri%2Fdownload%2Fssri-8.0.1.tgz", + "integrity": "sha1-Y45OQ54v+9LNKJd21cpFfE9Roq8=", + "dev": true, + "requires": { + "minipass": "^3.1.1" + } + }, + "stable": { + "version": "0.1.8", + "resolved": "https://registry.npm.taobao.org/stable/download/stable-0.1.8.tgz", + "integrity": "sha1-g26zyDgv4pNv6vVEYxAXzn1Ho88=", + "dev": true + }, + "stackframe": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/stackframe/download/stackframe-1.2.0.tgz", + "integrity": "sha1-UkKUktY8YuuYmATBFVLj0i53kwM=", + "dev": true + }, + "static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npm.taobao.org/static-extend/download/static-extend-0.1.2.tgz", + "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "dev": true, + "requires": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npm.taobao.org/define-property/download/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-accessor-descriptor/download/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.nlark.com/is-data-descriptor/download/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npm.taobao.org/is-descriptor/download/is-descriptor-0.1.6.tgz", + "integrity": "sha1-Nm2CQN3kh8pRgjsaufB6EKeCUco=", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + } + }, + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-5.1.0.tgz", + "integrity": "sha1-cpyR4thXt6QZofmqZWhcTDP1hF0=", + "dev": true + } + } + }, + "statuses": { + "version": "1.5.0", + "resolved": "https://registry.nlark.com/statuses/download/statuses-1.5.0.tgz", + "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" + }, + "stealthy-require": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/stealthy-require/download/stealthy-require-1.1.1.tgz", + "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=", + "dev": true + }, + "stream-browserify": { + "version": "2.0.2", + "resolved": "https://registry.npm.taobao.org/stream-browserify/download/stream-browserify-2.0.2.tgz", + "integrity": "sha1-h1IdOKRKp+6RzhzSpH3wy0ndZgs=", + "dev": true, + "requires": { + "inherits": "~2.0.1", + "readable-stream": "^2.0.2" + } + }, + "stream-each": { + "version": "1.2.3", + "resolved": "https://registry.npm.taobao.org/stream-each/download/stream-each-1.2.3.tgz", + "integrity": "sha1-6+J6DDibBPvMIzZClS4Qcxr6m64=", + "dev": true, + "requires": { + "end-of-stream": "^1.1.0", + "stream-shift": "^1.0.0" + } + }, + "stream-http": { + "version": "2.8.2", + "resolved": "https://registry.npmmirror.com/stream-http/-/stream-http-2.8.2.tgz", + "integrity": "sha512-QllfrBhqF1DPcz46WxKTs6Mz1Bpc+8Qm6vbqOpVav5odAXwbyzwnEczoWqtxrsmlO+cJqtPrp/8gWKWjaKLLlA==", + "requires": { + "builtin-status-codes": "^3.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.3.6", + "to-arraybuffer": "^1.0.0", + "xtend": "^4.0.0" + } + }, + "stream-shift": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/stream-shift/download/stream-shift-1.0.1.tgz", + "integrity": "sha1-1wiCgVWasneEJCebCHfaPDktWj0=", + "dev": true + }, + "stream-wormhole": { + "version": "1.1.0", + "resolved": "https://registry.npmmirror.com/stream-wormhole/-/stream-wormhole-1.1.0.tgz", + "integrity": "sha512-gHFfL3px0Kctd6Po0M8TzEvt3De/xu6cnRrjlfYNhwbhLPLwigI2t1nc6jrzNuaYg5C4YF78PPFuQPzRiqn9ew==" + }, + "strict-uri-encode": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/strict-uri-encode/download/strict-uri-encode-1.1.0.tgz", + "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=", + "dev": true + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.nlark.com/string-width/download/string-width-2.1.1.tgz", + "integrity": "sha1-q5Pyeo3BPSjKyBXEYhQ6bZASrp4=", + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-3.0.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "string.prototype.trimend": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/string.prototype.trimend/download/string.prototype.trimend-1.0.4.tgz", + "integrity": "sha1-51rpDClCxjUEaGwYsoe0oLGkX4A=", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + } + }, + "string.prototype.trimstart": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/string.prototype.trimstart/download/string.prototype.trimstart-1.0.4.tgz?cache=0&sync_timestamp=1614127357785&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fstring.prototype.trimstart%2Fdownload%2Fstring.prototype.trimstart-1.0.4.tgz", + "integrity": "sha1-s2OZr0qymZtMnGSL16P7K7Jv7u0=", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.nlark.com/string_decoder/download/string_decoder-1.1.1.tgz", + "integrity": "sha1-nPFhG6YmhdcDCunkujQUnDrwP8g=", + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-5.2.0.tgz", + "integrity": "sha1-jJpTb+tq/JYr36WxBKUJHBrZwK4=", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + }, + "strip-eof": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/strip-eof/download/strip-eof-1.0.0.tgz", + "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", + "dev": true + }, + "strip-final-newline": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/strip-final-newline/download/strip-final-newline-2.0.0.tgz", + "integrity": "sha1-ibhS+y/L6Tb29LMYevsKEsGrWK0=", + "dev": true + }, + "strip-indent": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/strip-indent/download/strip-indent-2.0.0.tgz?cache=0&sync_timestamp=1620053263051&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fstrip-indent%2Fdownload%2Fstrip-indent-2.0.0.tgz", + "integrity": "sha1-XvjbKV0B5u1sv3qrlpmNeCJSe2g=", + "dev": true + }, + "stylehacks": { + "version": "4.0.3", + "resolved": "https://registry.nlark.com/stylehacks/download/stylehacks-4.0.3.tgz", + "integrity": "sha1-Zxj8r00eB9ihMYaQiB6NlnJqcdU=", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.nlark.com/postcss-selector-parser/download/postcss-selector-parser-3.1.2.tgz?cache=0&sync_timestamp=1620753051451&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-selector-parser%2Fdownload%2Fpostcss-selector-parser-3.1.2.tgz", + "integrity": "sha1-sxD1xMD9r3b5SQK7qjDbaqhPUnA=", + "dev": true, + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "stylus": { + "version": "0.54.8", + "resolved": "https://registry.npm.taobao.org/stylus/download/stylus-0.54.8.tgz?cache=0&sync_timestamp=1594901358297&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fstylus%2Fdownload%2Fstylus-0.54.8.tgz", + "integrity": "sha1-PaPmWWa8Vnp7BEv+DuzmU+CZ0Uc=", + "dev": true, + "requires": { + "css-parse": "~2.0.0", + "debug": "~3.1.0", + "glob": "^7.1.6", + "mkdirp": "~1.0.4", + "safer-buffer": "^2.1.2", + "sax": "~1.2.4", + "semver": "^6.3.0", + "source-map": "^0.7.3" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/debug/download/debug-3.1.0.tgz", + "integrity": "sha1-W7WgZyYotkFJVmuhaBnmFRjGcmE=", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "mkdirp": { + "version": "1.0.4", + "resolved": "https://registry.nlark.com/mkdirp/download/mkdirp-1.0.4.tgz", + "integrity": "sha1-PrXtYmInVteaXw4qIh3+utdcL34=", + "dev": true + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "source-map": { + "version": "0.7.3", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.7.3.tgz", + "integrity": "sha1-UwL4FpAxc1ImVECS5kmB91F1A4M=", + "dev": true + } + } + }, + "stylus-loader": { + "version": "3.0.2", + "resolved": "https://registry.nlark.com/stylus-loader/download/stylus-loader-3.0.2.tgz", + "integrity": "sha1-J6cGQgsFo44DjnyssVNXjUUFE8Y=", + "dev": true, + "requires": { + "loader-utils": "^1.0.2", + "lodash.clonedeep": "^4.5.0", + "when": "~3.6.x" + } + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.nlark.com/supports-color/download/supports-color-5.5.0.tgz", + "integrity": "sha1-4uaaRKyHcveKHsCzW2id9lMO/I8=", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "svg-tags": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/svg-tags/download/svg-tags-1.0.0.tgz", + "integrity": "sha1-WPcc7jvVGbWdSyqEO2x95krAR2Q=", + "dev": true + }, + "svgo": { + "version": "1.3.2", + "resolved": "https://registry.nlark.com/svgo/download/svgo-1.3.2.tgz", + "integrity": "sha1-ttxRHAYzRsnkFbgeQ0ARRbltQWc=", + "dev": true, + "requires": { + "chalk": "^2.4.1", + "coa": "^2.0.2", + "css-select": "^2.0.0", + "css-select-base-adapter": "^0.1.1", + "css-tree": "1.0.0-alpha.37", + "csso": "^4.0.2", + "js-yaml": "^3.13.1", + "mkdirp": "~0.5.1", + "object.values": "^1.1.0", + "sax": "~1.2.4", + "stable": "^0.1.8", + "unquote": "~1.1.1", + "util.promisify": "~1.0.0" + }, + "dependencies": { + "css-select": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/css-select/download/css-select-2.1.0.tgz", + "integrity": "sha1-ajRlM1ZjWTSoG6ymjQJVQyEF2+8=", + "dev": true, + "requires": { + "boolbase": "^1.0.0", + "css-what": "^3.2.1", + "domutils": "^1.7.0", + "nth-check": "^1.0.2" + } + }, + "css-what": { + "version": "3.4.2", + "resolved": "https://registry.nlark.com/css-what/download/css-what-3.4.2.tgz?cache=0&sync_timestamp=1622227630859&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcss-what%2Fdownload%2Fcss-what-3.4.2.tgz", + "integrity": "sha1-6nAm/LAXd+295SEk4h8yfnrpUOQ=", + "dev": true + }, + "dom-serializer": { + "version": "0.2.2", + "resolved": "https://registry.nlark.com/dom-serializer/download/dom-serializer-0.2.2.tgz?cache=0&sync_timestamp=1621256819522&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fdom-serializer%2Fdownload%2Fdom-serializer-0.2.2.tgz", + "integrity": "sha1-GvuB9TNxcXXUeGVd68XjMtn5u1E=", + "dev": true, + "requires": { + "domelementtype": "^2.0.1", + "entities": "^2.0.0" + } + }, + "domutils": { + "version": "1.7.0", + "resolved": "https://registry.nlark.com/domutils/download/domutils-1.7.0.tgz", + "integrity": "sha1-Vuo0HoNOBuZ0ivehyyXaZ+qfjCo=", + "dev": true, + "requires": { + "dom-serializer": "0", + "domelementtype": "1" + }, + "dependencies": { + "domelementtype": { + "version": "1.3.1", + "resolved": "https://registry.npm.taobao.org/domelementtype/download/domelementtype-1.3.1.tgz", + "integrity": "sha1-0EjESzew0Qp/Kj1f7j9DM9eQSB8=", + "dev": true + } + } + }, + "nth-check": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/nth-check/download/nth-check-1.0.2.tgz", + "integrity": "sha1-sr0pXDfj3VijvwcAN2Zjuk2c8Fw=", + "dev": true, + "requires": { + "boolbase": "~1.0.0" + } + } + } + }, + "symbol-tree": { + "version": "3.2.4", + "resolved": "https://registry.npm.taobao.org/symbol-tree/download/symbol-tree-3.2.4.tgz", + "integrity": "sha1-QwY30ki6d+B4iDlR+5qg7tfGP6I=", + "dev": true + }, + "tapable": { + "version": "1.1.3", + "resolved": "https://registry.nlark.com/tapable/download/tapable-1.1.3.tgz", + "integrity": "sha1-ofzMBrWNth/XpF2i2kT186Pme6I=", + "dev": true + }, + "terser": { + "version": "4.8.0", + "resolved": "https://registry.nlark.com/terser/download/terser-4.8.0.tgz", + "integrity": "sha1-YwVjQ9fHC7KfOvZlhlpG/gOg3xc=", + "dev": true, + "requires": { + "commander": "^2.20.0", + "source-map": "~0.6.1", + "source-map-support": "~0.5.12" + }, + "dependencies": { + "commander": { + "version": "2.20.3", + "resolved": "https://registry.nlark.com/commander/download/commander-2.20.3.tgz?cache=0&sync_timestamp=1624609533517&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcommander%2Fdownload%2Fcommander-2.20.3.tgz", + "integrity": "sha1-/UhehMA+tIgcIHIrpIA16FMa6zM=", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "terser-webpack-plugin": { + "version": "1.4.5", + "resolved": "https://registry.nlark.com/terser-webpack-plugin/download/terser-webpack-plugin-1.4.5.tgz?cache=0&sync_timestamp=1624624486956&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fterser-webpack-plugin%2Fdownload%2Fterser-webpack-plugin-1.4.5.tgz", + "integrity": "sha1-oheu+uozDnNP+sthIOwfoxLWBAs=", + "dev": true, + "requires": { + "cacache": "^12.0.2", + "find-cache-dir": "^2.1.0", + "is-wsl": "^1.1.0", + "schema-utils": "^1.0.0", + "serialize-javascript": "^4.0.0", + "source-map": "^0.6.1", + "terser": "^4.1.2", + "webpack-sources": "^1.4.0", + "worker-farm": "^1.7.0" + }, + "dependencies": { + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npm.taobao.org/find-cache-dir/download/find-cache-dir-2.1.0.tgz", + "integrity": "sha1-jQ+UzRP+Q8bHwmGg2GEVypGMBfc=", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + } + }, + "is-wsl": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/is-wsl/download/is-wsl-1.1.0.tgz", + "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=", + "dev": true + }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/make-dir/download/make-dir-2.1.0.tgz", + "integrity": "sha1-XwMQ4YuL6JjMBwCSlaMK5B6R5vU=", + "dev": true, + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + } + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/pkg-dir/download/pkg-dir-3.0.0.tgz?cache=0&sync_timestamp=1618847182947&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpkg-dir%2Fdownload%2Fpkg-dir-3.0.0.tgz", + "integrity": "sha1-J0kCDyOe2ZCIGx9xIQ1R62UjvqM=", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/schema-utils/download/schema-utils-1.0.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-1.0.0.tgz", + "integrity": "sha1-C3mpMgTXtgDUsoUNH2bCo0lRx3A=", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.nlark.com/semver/download/semver-5.7.1.tgz", + "integrity": "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "thenify": { + "version": "3.3.1", + "resolved": "https://registry.npm.taobao.org/thenify/download/thenify-3.3.1.tgz", + "integrity": "sha1-iTLmhqQGYDigFt2eLKRq3Zg4qV8=", + "requires": { + "any-promise": "^1.0.0" + } + }, + "thenify-all": { + "version": "1.6.0", + "resolved": "https://registry.npm.taobao.org/thenify-all/download/thenify-all-1.6.0.tgz", + "integrity": "sha1-GhkY1ALY/D+Y+/I02wvMjMEOlyY=", + "requires": { + "thenify": ">= 3.1.0 < 4" + } + }, + "thread-loader": { + "version": "2.1.3", + "resolved": "https://registry.nlark.com/thread-loader/download/thread-loader-2.1.3.tgz?cache=0&sync_timestamp=1620664384427&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fthread-loader%2Fdownload%2Fthread-loader-2.1.3.tgz", + "integrity": "sha1-y9LBOfwrLebp0o9iKGq3cMGsvdo=", + "dev": true, + "requires": { + "loader-runner": "^2.3.1", + "loader-utils": "^1.1.0", + "neo-async": "^2.6.0" + } + }, + "through": { + "version": "2.3.8", + "resolved": "https://registry.nlark.com/through/download/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" + }, + "through2": { + "version": "2.0.5", + "resolved": "https://registry.npm.taobao.org/through2/download/through2-2.0.5.tgz", + "integrity": "sha1-AcHjnrMdB8t9A6lqcIIyYLIxMs0=", + "dev": true, + "requires": { + "readable-stream": "~2.3.6", + "xtend": "~4.0.1" + } + }, + "thunky": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/thunky/download/thunky-1.1.0.tgz", + "integrity": "sha1-Wrr3FKlAXbBQRzK7zNLO3Z75U30=", + "dev": true + }, + "timers-browserify": { + "version": "2.0.12", + "resolved": "https://registry.npm.taobao.org/timers-browserify/download/timers-browserify-2.0.12.tgz", + "integrity": "sha1-RKRcEfv0B/NPl7zNFXfGUjYbAO4=", + "dev": true, + "requires": { + "setimmediate": "^1.0.4" + } + }, + "timsort": { + "version": "0.3.0", + "resolved": "https://registry.npm.taobao.org/timsort/download/timsort-0.3.0.tgz", + "integrity": "sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q=", + "dev": true + }, + "tmp": { + "version": "0.0.33", + "resolved": "https://registry.nlark.com/tmp/download/tmp-0.0.33.tgz", + "integrity": "sha1-bTQzWIl2jSGyvNoKonfO07G/rfk=", + "dev": true, + "requires": { + "os-tmpdir": "~1.0.2" + } + }, + "to-arraybuffer": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/to-arraybuffer/download/to-arraybuffer-1.0.1.tgz", + "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=" + }, + "to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/to-fast-properties/download/to-fast-properties-2.0.0.tgz", + "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", + "dev": true + }, + "to-object-path": { + "version": "0.3.0", + "resolved": "https://registry.npm.taobao.org/to-object-path/download/to-object-path-0.3.0.tgz", + "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz", + "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npm.taobao.org/to-regex/download/to-regex-3.0.2.tgz", + "integrity": "sha1-E8/dmzNlUvMLUfM6iuG0Knp1mc4=", + "dev": true, + "requires": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + } + }, + "to-regex-range": { + "version": "2.1.1", + "resolved": "https://registry.nlark.com/to-regex-range/download/to-regex-range-2.1.1.tgz", + "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + } + }, + "toidentifier": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/toidentifier/download/toidentifier-1.0.0.tgz", + "integrity": "sha1-fhvjRw8ed5SLxD2Uo8j013UrpVM=" + }, + "toposort": { + "version": "1.0.7", + "resolved": "https://registry.npm.taobao.org/toposort/download/toposort-1.0.7.tgz", + "integrity": "sha1-LmhELZ9k7HILjMieZEOsbKqVACk=", + "dev": true + }, + "tough-cookie": { + "version": "2.5.0", + "resolved": "https://registry.npm.taobao.org/tough-cookie/download/tough-cookie-2.5.0.tgz", + "integrity": "sha1-zZ+yoKodWhK0c72fuW+j3P9lreI=", + "requires": { + "psl": "^1.1.28", + "punycode": "^2.1.1" + } + }, + "tr46": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/tr46/download/tr46-1.0.1.tgz", + "integrity": "sha1-qLE/1r/SSJUZZ0zN5VujaTtwbQk=", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "tryer": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/tryer/download/tryer-1.0.1.tgz", + "integrity": "sha1-8shUBoALmw90yfdGW4HqrSQSUvg=", + "dev": true + }, + "ts-pnp": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/ts-pnp/download/ts-pnp-1.2.0.tgz", + "integrity": "sha1-pQCtCEsHmPHDBxrzkeZZEshrypI=", + "dev": true + }, + "tslib": { + "version": "2.0.3", + "resolved": "https://registry.nlark.com/tslib/download/tslib-2.0.3.tgz", + "integrity": "sha1-jgdBrEX8DCJuWKF7/D5kubxsphw=" + }, + "tty-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npm.taobao.org/tty-browserify/download/tty-browserify-0.0.0.tgz", + "integrity": "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=", + "dev": true + }, + "tunnel-agent": { + "version": "0.6.0", + "resolved": "https://registry.npm.taobao.org/tunnel-agent/download/tunnel-agent-0.6.0.tgz", + "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "dev": true, + "requires": { + "safe-buffer": "^5.0.1" + } + }, + "tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.nlark.com/tweetnacl/download/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", + "dev": true + }, + "type-check": { + "version": "0.3.2", + "resolved": "https://registry.npm.taobao.org/type-check/download/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "requires": { + "prelude-ls": "~1.1.2" + } + }, + "type-detect": { + "version": "4.0.8", + "resolved": "https://registry.npm.taobao.org/type-detect/download/type-detect-4.0.8.tgz", + "integrity": "sha1-dkb7XxiHHPu3dJ5pvTmmOI63RQw=", + "dev": true + }, + "type-fest": { + "version": "0.21.3", + "resolved": "https://registry.nlark.com/type-fest/download/type-fest-0.21.3.tgz?cache=0&sync_timestamp=1625745286088&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ftype-fest%2Fdownload%2Ftype-fest-0.21.3.tgz", + "integrity": "sha1-0mCiSwGYQ24TP6JqUkptZfo7Ljc=", + "dev": true + }, + "type-is": { + "version": "1.6.18", + "resolved": "https://registry.npm.taobao.org/type-is/download/type-is-1.6.18.tgz", + "integrity": "sha1-TlUs0F3wlGfcvE73Od6J8s83wTE=", + "dev": true, + "requires": { + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + } + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npm.taobao.org/typedarray/download/typedarray-0.0.6.tgz", + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", + "dev": true + }, + "uglify-js": { + "version": "3.4.10", + "resolved": "https://registry.nlark.com/uglify-js/download/uglify-js-3.4.10.tgz?cache=0&sync_timestamp=1624812318797&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fuglify-js%2Fdownload%2Fuglify-js-3.4.10.tgz", + "integrity": "sha1-mtlWPY6zrN+404WX0q8dgV9qdV8=", + "dev": true, + "requires": { + "commander": "~2.19.0", + "source-map": "~0.6.1" + }, + "dependencies": { + "commander": { + "version": "2.19.0", + "resolved": "https://registry.nlark.com/commander/download/commander-2.19.0.tgz?cache=0&sync_timestamp=1624609533517&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcommander%2Fdownload%2Fcommander-2.19.0.tgz", + "integrity": "sha1-9hmKqE5bg8RgVLlN3tv+1e6f8So=", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "unbox-primitive": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/unbox-primitive/download/unbox-primitive-1.0.1.tgz?cache=0&sync_timestamp=1616706427948&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Funbox-primitive%2Fdownload%2Funbox-primitive-1.0.1.tgz", + "integrity": "sha1-CF4hViXsMWJXTciFmr7nilmxRHE=", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has-bigints": "^1.0.1", + "has-symbols": "^1.0.2", + "which-boxed-primitive": "^1.0.2" + } + }, + "unescape": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/unescape/-/unescape-1.0.1.tgz", + "integrity": "sha512-O0+af1Gs50lyH1nUu3ZyYS1cRh01Q/kUKatTOkSs7jukXE6/NebucDVxyiDsA9AQ4JC1V1jUH9EO8JX2nMDgGQ==", + "requires": { + "extend-shallow": "^2.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" + } + } + }, + "unicode-canonical-property-names-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/unicode-canonical-property-names-ecmascript/download/unicode-canonical-property-names-ecmascript-1.0.4.tgz", + "integrity": "sha1-JhmADEyCWADv3YNDr33Zkzy+KBg=", + "dev": true + }, + "unicode-match-property-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/unicode-match-property-ecmascript/download/unicode-match-property-ecmascript-1.0.4.tgz", + "integrity": "sha1-jtKjJWmWG86SJ9Cc0/+7j+1fAgw=", + "dev": true, + "requires": { + "unicode-canonical-property-names-ecmascript": "^1.0.4", + "unicode-property-aliases-ecmascript": "^1.0.4" + } + }, + "unicode-match-property-value-ecmascript": { + "version": "1.2.0", + "resolved": "https://registry.nlark.com/unicode-match-property-value-ecmascript/download/unicode-match-property-value-ecmascript-1.2.0.tgz", + "integrity": "sha1-DZH2AO7rMJaqlisdb8iIduZOpTE=", + "dev": true + }, + "unicode-property-aliases-ecmascript": { + "version": "1.1.0", + "resolved": "https://registry.npm.taobao.org/unicode-property-aliases-ecmascript/download/unicode-property-aliases-ecmascript-1.1.0.tgz", + "integrity": "sha1-3Vepn2IHvt/0Yoq++5TFDblByPQ=", + "dev": true + }, + "union-value": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/union-value/download/union-value-1.0.1.tgz", + "integrity": "sha1-C2/nuDWuzaYcbqTU8CwUIh4QmEc=", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^2.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + } + } + }, + "uniq": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/uniq/download/uniq-1.0.1.tgz", + "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", + "dev": true + }, + "uniqs": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/uniqs/download/uniqs-2.0.0.tgz", + "integrity": "sha1-/+3ks2slKQaW5uFl1KWe25mOawI=", + "dev": true + }, + "unique-filename": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/unique-filename/download/unique-filename-1.1.1.tgz", + "integrity": "sha1-HWl2k2mtoFgxA6HmrodoG1ZXMjA=", + "dev": true, + "requires": { + "unique-slug": "^2.0.0" + } + }, + "unique-slug": { + "version": "2.0.2", + "resolved": "https://registry.npm.taobao.org/unique-slug/download/unique-slug-2.0.2.tgz", + "integrity": "sha1-uqvOkQg/xk6UWw861hPiZPfNTmw=", + "dev": true, + "requires": { + "imurmurhash": "^0.1.4" + } + }, + "universalify": { + "version": "0.1.2", + "resolved": "https://registry.nlark.com/universalify/download/universalify-0.1.2.tgz", + "integrity": "sha1-tkb2m+OULavOzJ1mOcgNwQXvqmY=" + }, + "unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/unpipe/download/unpipe-1.0.0.tgz", + "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" + }, + "unquote": { + "version": "1.1.1", + "resolved": "https://registry.npm.taobao.org/unquote/download/unquote-1.1.1.tgz", + "integrity": "sha1-j97XMk7G6IoP+LkF58CYzcCG1UQ=", + "dev": true + }, + "unset-value": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/unset-value/download/unset-value-1.0.0.tgz?cache=0&sync_timestamp=1616088640915&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Funset-value%2Fdownload%2Funset-value-1.0.0.tgz", + "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", + "dev": true, + "requires": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "dependencies": { + "has-value": { + "version": "0.3.1", + "resolved": "https://registry.npm.taobao.org/has-value/download/has-value-0.3.1.tgz", + "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "dev": true, + "requires": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "dependencies": { + "isobject": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/isobject/download/isobject-2.1.0.tgz", + "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "dev": true, + "requires": { + "isarray": "1.0.0" + } + } + } + }, + "has-values": { + "version": "0.1.4", + "resolved": "https://registry.npm.taobao.org/has-values/download/has-values-0.1.4.tgz", + "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", + "dev": true + } + } + }, + "upath": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/upath/download/upath-1.2.0.tgz", + "integrity": "sha1-j2bbzVWog6za5ECK+LA1pQRMGJQ=", + "dev": true + }, + "upper-case": { + "version": "1.1.3", + "resolved": "https://registry.npm.taobao.org/upper-case/download/upper-case-1.1.3.tgz?cache=0&sync_timestamp=1606859943902&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fupper-case%2Fdownload%2Fupper-case-1.1.3.tgz", + "integrity": "sha1-9rRQHC7EzdJrp4vnIilh3ndiFZg=", + "dev": true + }, + "uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npm.taobao.org/uri-js/download/uri-js-4.4.1.tgz?cache=0&sync_timestamp=1610237530009&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Furi-js%2Fdownload%2Furi-js-4.4.1.tgz", + "integrity": "sha1-mxpSWVIlhZ5V9mnZKPiMbFfyp34=", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "urix": { + "version": "0.1.0", + "resolved": "https://registry.npm.taobao.org/urix/download/urix-0.1.0.tgz", + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", + "dev": true + }, + "url": { + "version": "0.11.0", + "resolved": "https://registry.npm.taobao.org/url/download/url-0.11.0.tgz", + "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "dev": true, + "requires": { + "punycode": "1.3.2", + "querystring": "0.2.0" + }, + "dependencies": { + "punycode": { + "version": "1.3.2", + "resolved": "https://registry.npm.taobao.org/punycode/download/punycode-1.3.2.tgz", + "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", + "dev": true + } + } + }, + "url-loader": { + "version": "2.3.0", + "resolved": "https://registry.npm.taobao.org/url-loader/download/url-loader-2.3.0.tgz", + "integrity": "sha1-4OLvZY8APvuMpBsPP/v3a6uIZYs=", + "dev": true, + "requires": { + "loader-utils": "^1.2.3", + "mime": "^2.4.4", + "schema-utils": "^2.5.0" + } + }, + "url-parse": { + "version": "1.5.1", + "resolved": "https://registry.npm.taobao.org/url-parse/download/url-parse-1.5.1.tgz", + "integrity": "sha1-1fqYkK+KXh8nSiyYN2UQ9kJfbjs=", + "requires": { + "querystringify": "^2.1.1", + "requires-port": "^1.0.0" + } + }, + "urllib": { + "version": "2.40.0", + "resolved": "https://registry.npmmirror.com/urllib/-/urllib-2.40.0.tgz", + "integrity": "sha512-XDZjoijtzsbkXTXgM+A/sJM002nwoYsc46YOYr6MNH2jUUw1nCBf2ywT1WaPsVEWJX4Yr+9isGmYj4+yofFn9g==", + "requires": { + "any-promise": "^1.3.0", + "content-type": "^1.0.2", + "debug": "^2.6.9", + "default-user-agent": "^1.0.0", + "digest-header": "^1.0.0", + "ee-first": "~1.1.1", + "formstream": "^1.1.0", + "humanize-ms": "^1.2.0", + "iconv-lite": "^0.4.15", + "ip": "^1.1.5", + "proxy-agent": "^5.0.0", + "pump": "^3.0.0", + "qs": "^6.4.0", + "statuses": "^1.3.1", + "utility": "^1.16.1" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" + } + } + }, + "use": { + "version": "3.1.1", + "resolved": "https://registry.npm.taobao.org/use/download/use-3.1.1.tgz", + "integrity": "sha1-1QyMrHmhn7wg8pEfVuuXP04QBw8=", + "dev": true + }, + "util": { + "version": "0.11.1", + "resolved": "https://registry.nlark.com/util/download/util-0.11.1.tgz?cache=0&sync_timestamp=1622212943994&other_urls=https%3A%2F%2Fregistry.nlark.com%2Futil%2Fdownload%2Futil-0.11.1.tgz", + "integrity": "sha1-MjZzNyDsZLsn9uJvQhqqLhtYjWE=", + "dev": true, + "requires": { + "inherits": "2.0.3" + }, + "dependencies": { + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npm.taobao.org/inherits/download/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true + } + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/util-deprecate/download/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" + }, + "util.promisify": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/util.promisify/download/util.promisify-1.0.0.tgz?cache=0&sync_timestamp=1610159885628&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Futil.promisify%2Fdownload%2Futil.promisify-1.0.0.tgz", + "integrity": "sha1-RA9xZaRZyaFtwUXrjnLzVocJcDA=", + "dev": true, + "requires": { + "define-properties": "^1.1.2", + "object.getownpropertydescriptors": "^2.0.3" + } + }, + "utila": { + "version": "0.4.0", + "resolved": "https://registry.npm.taobao.org/utila/download/utila-0.4.0.tgz", + "integrity": "sha1-ihagXURWV6Oupe7MWxKk+lN5dyw=", + "dev": true + }, + "utility": { + "version": "1.17.0", + "resolved": "https://registry.npmmirror.com/utility/-/utility-1.17.0.tgz", + "integrity": "sha512-KdVkF9An/0239BJ4+dqOa7NPrPIOeQE9AGfx0XS16O9DBiHNHRJMoeU5nL6pRGAkgJOqdOu8R4gBRcXnAocJKw==", + "requires": { + "copy-to": "^2.0.1", + "escape-html": "^1.0.3", + "mkdirp": "^0.5.1", + "mz": "^2.7.0", + "unescape": "^1.0.1" + } + }, + "utils-merge": { + "version": "1.0.1", + "resolved": "https://registry.npm.taobao.org/utils-merge/download/utils-merge-1.0.1.tgz", + "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", + "dev": true + }, + "uuid": { + "version": "3.4.0", + "resolved": "https://registry.nlark.com/uuid/download/uuid-3.4.0.tgz?cache=0&sync_timestamp=1622213086354&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fuuid%2Fdownload%2Fuuid-3.4.0.tgz", + "integrity": "sha1-sj5DWK+oogL+ehAK8fX4g/AgB+4=", + "dev": true + }, + "validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npm.taobao.org/validate-npm-package-license/download/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha1-/JH2uce6FchX9MssXe/uw51PQQo=", + "dev": true, + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "vary": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/vary/download/vary-1.1.2.tgz", + "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", + "dev": true + }, + "vendors": { + "version": "1.0.4", + "resolved": "https://registry.npm.taobao.org/vendors/download/vendors-1.0.4.tgz?cache=0&sync_timestamp=1615203486079&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fvendors%2Fdownload%2Fvendors-1.0.4.tgz", + "integrity": "sha1-4rgApT56Kbk1BsPPQRANFsTErY4=", + "dev": true + }, + "verror": { + "version": "1.10.0", + "resolved": "https://registry.nlark.com/verror/download/verror-1.10.0.tgz", + "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0", + "core-util-is": "1.0.2", + "extsprintf": "^1.2.0" + } + }, + "vm-browserify": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/vm-browserify/download/vm-browserify-1.1.2.tgz", + "integrity": "sha1-eGQcSIuObKkadfUR56OzKobl3aA=", + "dev": true + }, + "vm2": { + "version": "3.9.14", + "resolved": "https://registry.npmmirror.com/vm2/-/vm2-3.9.14.tgz", + "integrity": "sha512-HgvPHYHeQy8+QhzlFryvSteA4uQLBCOub02mgqdR+0bN/akRZ48TGB1v0aCv7ksyc0HXx16AZtMHKS38alc6TA==", + "requires": { + "acorn": "^8.7.0", + "acorn-walk": "^8.2.0" + }, + "dependencies": { + "acorn": { + "version": "8.8.2", + "resolved": "https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz", + "integrity": "sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==" + }, + "acorn-walk": { + "version": "8.2.0", + "resolved": "https://registry.npmmirror.com/acorn-walk/-/acorn-walk-8.2.0.tgz", + "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==" + } + } + }, + "vue": { + "version": "3.2.37", + "resolved": "https://registry.npmmirror.com/vue/-/vue-3.2.37.tgz", + "integrity": "sha512-bOKEZxrm8Eh+fveCqS1/NkG/n6aMidsI6hahas7pa0w/l7jkbssJVsRhVDs07IdDq7h9KHswZOgItnwJAgtVtQ==", + "requires": { + "@vue/compiler-dom": "3.2.37", + "@vue/compiler-sfc": "3.2.37", + "@vue/runtime-dom": "3.2.37", + "@vue/server-renderer": "3.2.37", + "@vue/shared": "3.2.37" + } + }, + "vue-draggable-next": { + "version": "2.0.1", + "resolved": "https://registry.nlark.com/vue-draggable-next/download/vue-draggable-next-2.0.1.tgz", + "integrity": "sha1-u2TvswLHuOdZ/T8hQnhxeJtiTGc=" + }, + "vue-hot-reload-api": { + "version": "2.3.4", + "resolved": "https://registry.nlark.com/vue-hot-reload-api/download/vue-hot-reload-api-2.3.4.tgz", + "integrity": "sha1-UylVzB6yCKPZkLOp+acFdGV+CPI=", + "dev": true + }, + "vue-loader": { + "version": "15.9.7", + "resolved": "https://registry.nlark.com/vue-loader/download/vue-loader-15.9.7.tgz?cache=0&sync_timestamp=1624996813170&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fvue-loader%2Fdownload%2Fvue-loader-15.9.7.tgz", + "integrity": "sha1-FbBXdcPgw4QHZ5OTws5t9nOwEEQ=", + "dev": true, + "requires": { + "@vue/component-compiler-utils": "^3.1.0", + "hash-sum": "^1.0.2", + "loader-utils": "^1.1.0", + "vue-hot-reload-api": "^2.3.0", + "vue-style-loader": "^4.1.0" + }, + "dependencies": { + "hash-sum": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/hash-sum/download/hash-sum-1.0.2.tgz", + "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=", + "dev": true + } + } + }, + "vue-router": { + "version": "4.0.10", + "resolved": "https://registry.nlark.com/vue-router/download/vue-router-4.0.10.tgz?cache=0&sync_timestamp=1624286995690&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fvue-router%2Fdownload%2Fvue-router-4.0.10.tgz", + "integrity": "sha1-7I/aAylJsqMdMnMXD483bobrUqw=", + "requires": { + "@vue/devtools-api": "^6.0.0-beta.14" + } + }, + "vue-style-loader": { + "version": "4.1.3", + "resolved": "https://registry.npm.taobao.org/vue-style-loader/download/vue-style-loader-4.1.3.tgz", + "integrity": "sha1-bVWGOlH6dXqyTonZNxRlByqnvDU=", + "dev": true, + "requires": { + "hash-sum": "^1.0.2", + "loader-utils": "^1.0.2" + }, + "dependencies": { + "hash-sum": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/hash-sum/download/hash-sum-1.0.2.tgz", + "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=", + "dev": true + } + } + }, + "vue-template-es2015-compiler": { + "version": "1.9.1", + "resolved": "https://registry.npm.taobao.org/vue-template-es2015-compiler/download/vue-template-es2015-compiler-1.9.1.tgz", + "integrity": "sha1-HuO8mhbsv1EYvjNLsV+cRvgvWCU=", + "dev": true + }, + "vuex": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/vuex/download/vuex-4.0.2.tgz", + "integrity": "sha1-+Jbb1b8qDpY/AMZ+m2EN50nMrMk=", + "requires": { + "@vue/devtools-api": "^6.0.0-beta.11" + } + }, + "w3c-hr-time": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/w3c-hr-time/download/w3c-hr-time-1.0.2.tgz", + "integrity": "sha1-ConN9cwVgi35w2BUNnaWPgzDCM0=", + "dev": true, + "requires": { + "browser-process-hrtime": "^1.0.0" + } + }, + "w3c-xmlserializer": { + "version": "1.1.2", + "resolved": "https://registry.npm.taobao.org/w3c-xmlserializer/download/w3c-xmlserializer-1.1.2.tgz", + "integrity": "sha1-MEhcp9cKb9BSQgo9Ev2Q5jOc55Q=", + "dev": true, + "requires": { + "domexception": "^1.0.1", + "webidl-conversions": "^4.0.2", + "xml-name-validator": "^3.0.0" + } + }, + "watchpack": { + "version": "1.7.5", + "resolved": "https://registry.nlark.com/watchpack/download/watchpack-1.7.5.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fwatchpack%2Fdownload%2Fwatchpack-1.7.5.tgz", + "integrity": "sha1-EmfmxV4Lm1vkTCAjrtVDeiwmxFM=", + "dev": true, + "requires": { + "chokidar": "^3.4.1", + "graceful-fs": "^4.1.2", + "neo-async": "^2.5.0", + "watchpack-chokidar2": "^2.0.1" + }, + "dependencies": { + "binary-extensions": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/binary-extensions/download/binary-extensions-2.2.0.tgz?cache=0&sync_timestamp=1610299322955&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbinary-extensions%2Fdownload%2Fbinary-extensions-2.2.0.tgz", + "integrity": "sha1-dfUC7q+f/eQvyYgpZFvk6na9ni0=", + "dev": true, + "optional": true + }, + "braces": { + "version": "3.0.2", + "resolved": "https://registry.nlark.com/braces/download/braces-3.0.2.tgz", + "integrity": "sha1-NFThpGLujVmeI23zNs2epPiv4Qc=", + "dev": true, + "optional": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "chokidar": { + "version": "3.5.2", + "resolved": "https://registry.nlark.com/chokidar/download/chokidar-3.5.2.tgz", + "integrity": "sha1-26OXb8rbAW9m/TZQIdkWANAcHnU=", + "dev": true, + "optional": true, + "requires": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "fsevents": "~2.3.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" + } + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.nlark.com/fill-range/download/fill-range-7.0.1.tgz", + "integrity": "sha1-GRmmp8df44ssfHflGYU12prN2kA=", + "dev": true, + "optional": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "fsevents": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", + "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "dev": true, + "optional": true + }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.nlark.com/glob-parent/download/glob-parent-5.1.2.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-5.1.2.tgz", + "integrity": "sha1-hpgyxYA0/mikCTwX3BXoNA2EAcQ=", + "dev": true, + "optional": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.nlark.com/is-binary-path/download/is-binary-path-2.1.0.tgz", + "integrity": "sha1-6h9/O4DwZCNug0cPhsCcJU+0Wwk=", + "dev": true, + "optional": true, + "requires": { + "binary-extensions": "^2.0.0" + } + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npm.taobao.org/is-number/download/is-number-7.0.0.tgz", + "integrity": "sha1-dTU0W4lnNNX4DE0GxQlVUnoU8Ss=", + "dev": true, + "optional": true + }, + "readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npm.taobao.org/readdirp/download/readdirp-3.6.0.tgz", + "integrity": "sha1-dKNwvYVxFuJFspzJc0DNQxoCpsc=", + "dev": true, + "optional": true, + "requires": { + "picomatch": "^2.2.1" + } + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.nlark.com/to-regex-range/download/to-regex-range-5.0.1.tgz", + "integrity": "sha1-FkjESq58jZiKMmAY7XL1tN0DkuQ=", + "dev": true, + "optional": true, + "requires": { + "is-number": "^7.0.0" + } + } + } + }, + "watchpack-chokidar2": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/watchpack-chokidar2/download/watchpack-chokidar2-2.0.1.tgz?cache=0&sync_timestamp=1604989085906&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fwatchpack-chokidar2%2Fdownload%2Fwatchpack-chokidar2-2.0.1.tgz", + "integrity": "sha1-OFAAcu5uzmbzdpk2lQ6hdxvhyVc=", + "dev": true, + "optional": true, + "requires": { + "chokidar": "^2.1.8" + } + }, + "wbuf": { + "version": "1.7.3", + "resolved": "https://registry.npm.taobao.org/wbuf/download/wbuf-1.7.3.tgz", + "integrity": "sha1-wdjRSTFtPqhShIiVy2oL/oh7h98=", + "dev": true, + "requires": { + "minimalistic-assert": "^1.0.0" + } + }, + "wcwidth": { + "version": "1.0.1", + "resolved": "https://registry.nlark.com/wcwidth/download/wcwidth-1.0.1.tgz", + "integrity": "sha1-8LDc+RW8X/FSivrbLA4XtTLaL+g=", + "dev": true, + "requires": { + "defaults": "^1.0.3" + } + }, + "webidl-conversions": { + "version": "4.0.2", + "resolved": "https://registry.npm.taobao.org/webidl-conversions/download/webidl-conversions-4.0.2.tgz", + "integrity": "sha1-qFWYCx8LazWbodXZ+zmulB+qY60=", + "dev": true + }, + "webpack": { + "version": "4.46.0", + "resolved": "https://registry.nlark.com/webpack/download/webpack-4.46.0.tgz", + "integrity": "sha1-v5tEBOogoHNgXgoBHRiNd8tq1UI=", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-module-context": "1.9.0", + "@webassemblyjs/wasm-edit": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0", + "acorn": "^6.4.1", + "ajv": "^6.10.2", + "ajv-keywords": "^3.4.1", + "chrome-trace-event": "^1.0.2", + "enhanced-resolve": "^4.5.0", + "eslint-scope": "^4.0.3", + "json-parse-better-errors": "^1.0.2", + "loader-runner": "^2.4.0", + "loader-utils": "^1.2.3", + "memory-fs": "^0.4.1", + "micromatch": "^3.1.10", + "mkdirp": "^0.5.3", + "neo-async": "^2.6.1", + "node-libs-browser": "^2.2.1", + "schema-utils": "^1.0.0", + "tapable": "^1.1.3", + "terser-webpack-plugin": "^1.4.3", + "watchpack": "^1.7.4", + "webpack-sources": "^1.4.1" + }, + "dependencies": { + "acorn": { + "version": "6.4.2", + "resolved": "https://registry.nlark.com/acorn/download/acorn-6.4.2.tgz?cache=0&sync_timestamp=1624526907659&other_urls=https%3A%2F%2Fregistry.nlark.com%2Facorn%2Fdownload%2Facorn-6.4.2.tgz", + "integrity": "sha1-NYZv1xBSjpLeEM8GAWSY5H454eY=", + "dev": true + }, + "eslint-scope": { + "version": "4.0.3", + "resolved": "https://registry.npm.taobao.org/eslint-scope/download/eslint-scope-4.0.3.tgz", + "integrity": "sha1-ygODMxD2iJoyZHgaqC5j65z+eEg=", + "dev": true, + "requires": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/schema-utils/download/schema-utils-1.0.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-1.0.0.tgz", + "integrity": "sha1-C3mpMgTXtgDUsoUNH2bCo0lRx3A=", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "webpack-bundle-analyzer": { + "version": "3.9.0", + "resolved": "https://registry.nlark.com/webpack-bundle-analyzer/download/webpack-bundle-analyzer-3.9.0.tgz?cache=0&sync_timestamp=1621259036556&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fwebpack-bundle-analyzer%2Fdownload%2Fwebpack-bundle-analyzer-3.9.0.tgz", + "integrity": "sha1-9vlNsQj7V05BWtMT3kGicH0z7zw=", + "dev": true, + "requires": { + "acorn": "^7.1.1", + "acorn-walk": "^7.1.1", + "bfj": "^6.1.1", + "chalk": "^2.4.1", + "commander": "^2.18.0", + "ejs": "^2.6.1", + "express": "^4.16.3", + "filesize": "^3.6.1", + "gzip-size": "^5.0.0", + "lodash": "^4.17.19", + "mkdirp": "^0.5.1", + "opener": "^1.5.1", + "ws": "^6.0.0" + }, + "dependencies": { + "commander": { + "version": "2.20.3", + "resolved": "https://registry.nlark.com/commander/download/commander-2.20.3.tgz?cache=0&sync_timestamp=1624609533517&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcommander%2Fdownload%2Fcommander-2.20.3.tgz", + "integrity": "sha1-/UhehMA+tIgcIHIrpIA16FMa6zM=", + "dev": true + }, + "ws": { + "version": "6.2.2", + "resolved": "https://registry.nlark.com/ws/download/ws-6.2.2.tgz?cache=0&sync_timestamp=1625897053615&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fws%2Fdownload%2Fws-6.2.2.tgz", + "integrity": "sha1-3Vzb1XqZeZFgl2UtePHMX66gwy4=", + "dev": true, + "requires": { + "async-limiter": "~1.0.0" + } + } + } + }, + "webpack-chain": { + "version": "6.5.1", + "resolved": "https://registry.npm.taobao.org/webpack-chain/download/webpack-chain-6.5.1.tgz", + "integrity": "sha1-TycoTLu2N+PI+970Pu9YjU2GEgY=", + "dev": true, + "requires": { + "deepmerge": "^1.5.2", + "javascript-stringify": "^2.0.1" + } + }, + "webpack-dev-middleware": { + "version": "3.7.3", + "resolved": "https://registry.nlark.com/webpack-dev-middleware/download/webpack-dev-middleware-3.7.3.tgz", + "integrity": "sha1-Bjk3KxQyYuK4SrldO5GnWXBhwsU=", + "dev": true, + "requires": { + "memory-fs": "^0.4.1", + "mime": "^2.4.4", + "mkdirp": "^0.5.1", + "range-parser": "^1.2.1", + "webpack-log": "^2.0.0" + } + }, + "webpack-dev-server": { + "version": "3.11.2", + "resolved": "https://registry.nlark.com/webpack-dev-server/download/webpack-dev-server-3.11.2.tgz", + "integrity": "sha1-aV687Xakkp8NXef9c/r+GF/jNwg=", + "dev": true, + "requires": { + "ansi-html": "0.0.7", + "bonjour": "^3.5.0", + "chokidar": "^2.1.8", + "compression": "^1.7.4", + "connect-history-api-fallback": "^1.6.0", + "debug": "^4.1.1", + "del": "^4.1.1", + "express": "^4.17.1", + "html-entities": "^1.3.1", + "http-proxy-middleware": "0.19.1", + "import-local": "^2.0.0", + "internal-ip": "^4.3.0", + "ip": "^1.1.5", + "is-absolute-url": "^3.0.3", + "killable": "^1.0.1", + "loglevel": "^1.6.8", + "opn": "^5.5.0", + "p-retry": "^3.0.1", + "portfinder": "^1.0.26", + "schema-utils": "^1.0.0", + "selfsigned": "^1.10.8", + "semver": "^6.3.0", + "serve-index": "^1.9.1", + "sockjs": "^0.3.21", + "sockjs-client": "^1.5.0", + "spdy": "^4.0.2", + "strip-ansi": "^3.0.1", + "supports-color": "^6.1.0", + "url": "^0.11.0", + "webpack-dev-middleware": "^3.7.2", + "webpack-log": "^2.0.0", + "ws": "^6.2.1", + "yargs": "^13.3.2" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-2.1.1.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "cliui": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/cliui/download/cliui-5.0.0.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-5.0.0.tgz", + "integrity": "sha1-3u/P2y6AB4SqNPRvoI4GhRx7u8U=", + "dev": true, + "requires": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-4.1.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-4.1.0.tgz", + "integrity": "sha1-i5+PCM8ay4Q3Vqg5yox+MWjFGZc=", + "dev": true + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-5.2.0.tgz", + "integrity": "sha1-jJpTb+tq/JYr36WxBKUJHBrZwK4=", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.nlark.com/emoji-regex/download/emoji-regex-7.0.3.tgz", + "integrity": "sha1-kzoEBShgyF6DwSJHnEdIqOTHIVY=", + "dev": true + }, + "http-proxy-middleware": { + "version": "0.19.1", + "resolved": "https://registry.nlark.com/http-proxy-middleware/download/http-proxy-middleware-0.19.1.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fhttp-proxy-middleware%2Fdownload%2Fhttp-proxy-middleware-0.19.1.tgz", + "integrity": "sha1-GDx9xKoUeRUDBkmMIQza+WCApDo=", + "dev": true, + "requires": { + "http-proxy": "^1.17.0", + "is-glob": "^4.0.0", + "lodash": "^4.17.11", + "micromatch": "^3.1.10" + } + }, + "is-absolute-url": { + "version": "3.0.3", + "resolved": "https://registry.npm.taobao.org/is-absolute-url/download/is-absolute-url-3.0.3.tgz", + "integrity": "sha1-lsaiK2ojkpsR6gr7GDbDatSl1pg=", + "dev": true + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/schema-utils/download/schema-utils-1.0.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-1.0.0.tgz", + "integrity": "sha1-C3mpMgTXtgDUsoUNH2bCo0lRx3A=", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/string-width/download/string-width-3.1.0.tgz", + "integrity": "sha1-InZ74htirxCBV0MG9prFG2IgOWE=", + "dev": true, + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-4.1.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-4.1.0.tgz", + "integrity": "sha1-i5+PCM8ay4Q3Vqg5yox+MWjFGZc=", + "dev": true + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-5.2.0.tgz", + "integrity": "sha1-jJpTb+tq/JYr36WxBKUJHBrZwK4=", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.nlark.com/supports-color/download/supports-color-6.1.0.tgz", + "integrity": "sha1-B2Srxpxj1ayELdSGfo0CXogN+PM=", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-5.1.0.tgz", + "integrity": "sha1-H9H2cjXVttD+54EFYAG/tpTAOwk=", + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-4.1.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-4.1.0.tgz", + "integrity": "sha1-i5+PCM8ay4Q3Vqg5yox+MWjFGZc=", + "dev": true + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-5.2.0.tgz", + "integrity": "sha1-jJpTb+tq/JYr36WxBKUJHBrZwK4=", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "ws": { + "version": "6.2.2", + "resolved": "https://registry.nlark.com/ws/download/ws-6.2.2.tgz?cache=0&sync_timestamp=1625897053615&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fws%2Fdownload%2Fws-6.2.2.tgz", + "integrity": "sha1-3Vzb1XqZeZFgl2UtePHMX66gwy4=", + "dev": true, + "requires": { + "async-limiter": "~1.0.0" + } + }, + "yargs": { + "version": "13.3.2", + "resolved": "https://registry.nlark.com/yargs/download/yargs-13.3.2.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-13.3.2.tgz", + "integrity": "sha1-rX/+/sGqWVZayRX4Lcyzipwxot0=", + "dev": true, + "requires": { + "cliui": "^5.0.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.2" + } + } + } + }, + "webpack-log": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/webpack-log/download/webpack-log-2.0.0.tgz?cache=0&sync_timestamp=1615477493300&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fwebpack-log%2Fdownload%2Fwebpack-log-2.0.0.tgz", + "integrity": "sha1-W3ko4GN1k/EZ0y9iJ8HgrDHhtH8=", + "dev": true, + "requires": { + "ansi-colors": "^3.0.0", + "uuid": "^3.3.2" + } + }, + "webpack-merge": { + "version": "4.2.2", + "resolved": "https://registry.nlark.com/webpack-merge/download/webpack-merge-4.2.2.tgz", + "integrity": "sha1-onxS6ng9E5iv0gh/VH17nS9DY00=", + "dev": true, + "requires": { + "lodash": "^4.17.15" + } + }, + "webpack-sources": { + "version": "1.4.3", + "resolved": "https://registry.nlark.com/webpack-sources/download/webpack-sources-1.4.3.tgz", + "integrity": "sha1-7t2OwLko+/HL/plOItLYkPMwqTM=", + "dev": true, + "requires": { + "source-list-map": "^2.0.0", + "source-map": "~0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz", + "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", + "dev": true + } + } + }, + "websocket-driver": { + "version": "0.7.4", + "resolved": "https://registry.npm.taobao.org/websocket-driver/download/websocket-driver-0.7.4.tgz?cache=0&sync_timestamp=1591289007652&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fwebsocket-driver%2Fdownload%2Fwebsocket-driver-0.7.4.tgz", + "integrity": "sha1-ia1Slbv2S0gKvLox5JU6ynBvV2A=", + "dev": true, + "requires": { + "http-parser-js": ">=0.5.1", + "safe-buffer": ">=5.1.0", + "websocket-extensions": ">=0.1.1" + } + }, + "websocket-extensions": { + "version": "0.1.4", + "resolved": "https://registry.npm.taobao.org/websocket-extensions/download/websocket-extensions-0.1.4.tgz", + "integrity": "sha1-f4RzvIOd/YdgituV1+sHUhFXikI=", + "dev": true + }, + "whatwg-encoding": { + "version": "1.0.5", + "resolved": "https://registry.npm.taobao.org/whatwg-encoding/download/whatwg-encoding-1.0.5.tgz", + "integrity": "sha1-WrrPd3wyFmpR0IXWtPPn0nET3bA=", + "dev": true, + "requires": { + "iconv-lite": "0.4.24" + } + }, + "whatwg-mimetype": { + "version": "2.3.0", + "resolved": "https://registry.npm.taobao.org/whatwg-mimetype/download/whatwg-mimetype-2.3.0.tgz", + "integrity": "sha1-PUseAxLSB5h5+Cav8Y2+7KWWD78=", + "dev": true + }, + "whatwg-url": { + "version": "7.1.0", + "resolved": "https://registry.nlark.com/whatwg-url/download/whatwg-url-7.1.0.tgz?cache=0&sync_timestamp=1624742873749&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fwhatwg-url%2Fdownload%2Fwhatwg-url-7.1.0.tgz", + "integrity": "sha1-wsSS8eymEpiO/T0iZr4bn8YXDQY=", + "dev": true, + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + }, + "when": { + "version": "3.6.4", + "resolved": "https://registry.npm.taobao.org/when/download/when-3.6.4.tgz", + "integrity": "sha1-RztRfsFZ4rhQBUl6E5g/CVQS404=", + "dev": true + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npm.taobao.org/which-boxed-primitive/download/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha1-E3V7yJsgmwSf5dhkMOIc9AqJqOY=", + "dev": true, + "requires": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + } + }, + "which-module": { + "version": "2.0.0", + "resolved": "https://registry.nlark.com/which-module/download/which-module-2.0.0.tgz", + "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", + "dev": true + }, + "wide-align": { + "version": "1.1.3", + "resolved": "https://registry.npm.taobao.org/wide-align/download/wide-align-1.1.3.tgz", + "integrity": "sha1-rgdOa9wMFKQx6ATmJFScYzsABFc=", + "dev": true, + "requires": { + "string-width": "^1.0.2 || 2" + } + }, + "win-release": { + "version": "1.1.1", + "resolved": "https://registry.npmmirror.com/win-release/-/win-release-1.1.1.tgz", + "integrity": "sha512-iCRnKVvGxOQdsKhcQId2PXV1vV3J/sDPXKA4Oe9+Eti2nb2ESEsYHRYls/UjoUW3bIc5ZDO8dTH50A/5iVN+bw==", + "requires": { + "semver": "^5.0.1" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmmirror.com/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.nlark.com/word-wrap/download/word-wrap-1.2.3.tgz", + "integrity": "sha1-YQY29rH3A4kb00dxzLF/uTtHB5w=" + }, + "worker-farm": { + "version": "1.7.0", + "resolved": "https://registry.npm.taobao.org/worker-farm/download/worker-farm-1.7.0.tgz", + "integrity": "sha1-JqlMU5G7ypJhUgAvabhKS/dy5ag=", + "dev": true, + "requires": { + "errno": "~0.1.7" + } + }, + "wrap-ansi": { + "version": "6.2.0", + "resolved": "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-6.2.0.tgz", + "integrity": "sha1-6Tk7oHEC5skaOyIUePAlfNKFblM=", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-5.0.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-5.0.0.tgz", + "integrity": "sha1-OIU59VF5vzkznIGvMKZU1p+Hy3U=", + "dev": true + }, + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.nlark.com/ansi-styles/download/ansi-styles-4.3.0.tgz?cache=0&sync_timestamp=1618995547052&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-styles%2Fdownload%2Fansi-styles-4.3.0.tgz", + "integrity": "sha1-7dgDYornHATIWuegkG7a00tkiTc=", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/color-convert/download/color-convert-2.0.1.tgz", + "integrity": "sha1-ctOmjVmMm9s68q0ehPIdiWq9TeM=", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.nlark.com/color-name/download/color-name-1.1.4.tgz", + "integrity": "sha1-wqCah6y95pVD3m9j+jmVyCbFNqI=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/is-fullwidth-code-point/download/is-fullwidth-code-point-3.0.0.tgz?cache=0&sync_timestamp=1618552469710&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-fullwidth-code-point%2Fdownload%2Fis-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha1-8Rb4Bk/pCz94RKOJl8C3UFEmnx0=", + "dev": true + }, + "string-width": { + "version": "4.2.2", + "resolved": "https://registry.nlark.com/string-width/download/string-width-4.2.2.tgz", + "integrity": "sha1-2v1PlVmnWFz7pSnGoKT3NIjr1MU=", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.0" + } + }, + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-6.0.0.tgz", + "integrity": "sha1-CxVx3XZpzNTz4G4U7x7tJiJa5TI=", + "dev": true, + "requires": { + "ansi-regex": "^5.0.0" + } + } + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.nlark.com/wrappy/download/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" + }, + "ws": { + "version": "7.5.3", + "resolved": "https://registry.nlark.com/ws/download/ws-7.5.3.tgz?cache=0&sync_timestamp=1625897053615&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fws%2Fdownload%2Fws-7.5.3.tgz", + "integrity": "sha1-Fgg1tjx9l7+rQY/BuKn87SrAGnQ=" + }, + "xml-name-validator": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/xml-name-validator/download/xml-name-validator-3.0.0.tgz", + "integrity": "sha1-auc+Bt5NjG5H+fsYH3jWSK1FfGo=", + "dev": true + }, + "xml2js": { + "version": "0.4.23", + "resolved": "https://registry.npmmirror.com/xml2js/-/xml2js-0.4.23.tgz", + "integrity": "sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug==", + "requires": { + "sax": ">=0.6.0", + "xmlbuilder": "~11.0.0" + } + }, + "xmlbuilder": { + "version": "11.0.1", + "resolved": "https://registry.npmmirror.com/xmlbuilder/-/xmlbuilder-11.0.1.tgz", + "integrity": "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==" + }, + "xmlchars": { + "version": "2.2.0", + "resolved": "https://registry.npm.taobao.org/xmlchars/download/xmlchars-2.2.0.tgz", + "integrity": "sha1-Bg/hvLf5x2/ioX24apvDq4lCEMs=", + "dev": true + }, + "xregexp": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/xregexp/-/xregexp-2.0.0.tgz", + "integrity": "sha512-xl/50/Cf32VsGq/1R8jJE5ajH1yMCQkpmoS10QbFZWl2Oor4H0Me64Pu2yxvsRWK3m6soJbmGfzSR7BYmDcWAA==" + }, + "xtend": { + "version": "4.0.2", + "resolved": "https://registry.nlark.com/xtend/download/xtend-4.0.2.tgz", + "integrity": "sha1-u3J3n1+kZRhrH0OPZ0+jR/2121Q=" + }, + "y18n": { + "version": "4.0.3", + "resolved": "https://registry.nlark.com/y18n/download/y18n-4.0.3.tgz", + "integrity": "sha1-tfJZyCzW4zaSHv17/Yv1YN6e7t8=", + "dev": true + }, + "yallist": { + "version": "3.1.1", + "resolved": "https://registry.nlark.com/yallist/download/yallist-3.1.1.tgz", + "integrity": "sha1-27fa+b/YusmrRev2ArjLrQ1dCP0=" + }, + "yargs": { + "version": "16.2.0", + "resolved": "https://registry.nlark.com/yargs/download/yargs-16.2.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-16.2.0.tgz", + "integrity": "sha1-HIK/D2tqZur85+8w43b0mhJHf2Y=", + "dev": true, + "requires": { + "cliui": "^7.0.2", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.0", + "y18n": "^5.0.5", + "yargs-parser": "^20.2.2" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-5.0.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-5.0.0.tgz", + "integrity": "sha1-OIU59VF5vzkznIGvMKZU1p+Hy3U=", + "dev": true + }, + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.nlark.com/ansi-styles/download/ansi-styles-4.3.0.tgz?cache=0&sync_timestamp=1618995547052&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-styles%2Fdownload%2Fansi-styles-4.3.0.tgz", + "integrity": "sha1-7dgDYornHATIWuegkG7a00tkiTc=", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "cliui": { + "version": "7.0.4", + "resolved": "https://registry.npm.taobao.org/cliui/download/cliui-7.0.4.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-7.0.4.tgz", + "integrity": "sha1-oCZe5lVHb8gHrqnfPfjfd4OAi08=", + "dev": true, + "requires": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^7.0.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npm.taobao.org/color-convert/download/color-convert-2.0.1.tgz", + "integrity": "sha1-ctOmjVmMm9s68q0ehPIdiWq9TeM=", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.nlark.com/color-name/download/color-name-1.1.4.tgz", + "integrity": "sha1-wqCah6y95pVD3m9j+jmVyCbFNqI=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npm.taobao.org/is-fullwidth-code-point/download/is-fullwidth-code-point-3.0.0.tgz?cache=0&sync_timestamp=1618552469710&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-fullwidth-code-point%2Fdownload%2Fis-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha1-8Rb4Bk/pCz94RKOJl8C3UFEmnx0=", + "dev": true + }, + "string-width": { + "version": "4.2.2", + "resolved": "https://registry.nlark.com/string-width/download/string-width-4.2.2.tgz", + "integrity": "sha1-2v1PlVmnWFz7pSnGoKT3NIjr1MU=", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.0" + } + }, + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.nlark.com/strip-ansi/download/strip-ansi-6.0.0.tgz", + "integrity": "sha1-CxVx3XZpzNTz4G4U7x7tJiJa5TI=", + "dev": true, + "requires": { + "ansi-regex": "^5.0.0" + } + }, + "wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-7.0.0.tgz", + "integrity": "sha1-Z+FFz/UQpqaYS98RUpEdadLrnkM=", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + } + }, + "y18n": { + "version": "5.0.8", + "resolved": "https://registry.nlark.com/y18n/download/y18n-5.0.8.tgz", + "integrity": "sha1-f0k00PfKjFb5UxSTndzS3ZHOHVU=", + "dev": true + }, + "yargs-parser": { + "version": "20.2.9", + "resolved": "https://registry.nlark.com/yargs-parser/download/yargs-parser-20.2.9.tgz", + "integrity": "sha1-LrfcOwKJcY/ClfNidThFxBoMlO4=", + "dev": true + } + } + }, + "yargs-parser": { + "version": "13.1.2", + "resolved": "https://registry.nlark.com/yargs-parser/download/yargs-parser-13.1.2.tgz", + "integrity": "sha1-Ew8JcC667vJlDVTObj5XBvek+zg=", + "dev": true, + "requires": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + }, + "dependencies": { + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.nlark.com/camelcase/download/camelcase-5.3.1.tgz", + "integrity": "sha1-48mzFWnhBoEd8kL3FXJaH0xJQyA=", + "dev": true + } + } + }, + "yargs-unparser": { + "version": "1.6.0", + "resolved": "https://registry.npm.taobao.org/yargs-unparser/download/yargs-unparser-1.6.0.tgz", + "integrity": "sha1-7yXCx2n/a9CeSw+dfGBfsnhG6p8=", + "dev": true, + "requires": { + "flat": "^4.1.0", + "lodash": "^4.17.15", + "yargs": "^13.3.0" + }, + "dependencies": { + "cliui": { + "version": "5.0.0", + "resolved": "https://registry.npm.taobao.org/cliui/download/cliui-5.0.0.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-5.0.0.tgz", + "integrity": "sha1-3u/P2y6AB4SqNPRvoI4GhRx7u8U=", + "dev": true, + "requires": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + } + }, + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.nlark.com/emoji-regex/download/emoji-regex-7.0.3.tgz", + "integrity": "sha1-kzoEBShgyF6DwSJHnEdIqOTHIVY=", + "dev": true + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.nlark.com/string-width/download/string-width-3.1.0.tgz", + "integrity": "sha1-InZ74htirxCBV0MG9prFG2IgOWE=", + "dev": true, + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + }, + "wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-5.1.0.tgz", + "integrity": "sha1-H9H2cjXVttD+54EFYAG/tpTAOwk=", + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + } + }, + "yargs": { + "version": "13.3.2", + "resolved": "https://registry.nlark.com/yargs/download/yargs-13.3.2.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-13.3.2.tgz", + "integrity": "sha1-rX/+/sGqWVZayRX4Lcyzipwxot0=", + "dev": true, + "requires": { + "cliui": "^5.0.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.2" + } + } + } + }, + "yorkie": { + "version": "2.0.0", + "resolved": "https://registry.npm.taobao.org/yorkie/download/yorkie-2.0.0.tgz", + "integrity": "sha1-kkEZEtQ1IU4SxRwq4Qk+VLa7g9k=", + "dev": true, + "requires": { + "execa": "^0.8.0", + "is-ci": "^1.0.10", + "normalize-path": "^1.0.0", + "strip-indent": "^2.0.0" + }, + "dependencies": { + "cross-spawn": { + "version": "5.1.0", + "resolved": "https://registry.npm.taobao.org/cross-spawn/download/cross-spawn-5.1.0.tgz", + "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", + "dev": true, + "requires": { + "lru-cache": "^4.0.1", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "execa": { + "version": "0.8.0", + "resolved": "https://registry.nlark.com/execa/download/execa-0.8.0.tgz?cache=0&sync_timestamp=1622825859616&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fexeca%2Fdownload%2Fexeca-0.8.0.tgz", + "integrity": "sha1-2NdrvBtVIX7RkP1t1J08d07PyNo=", + "dev": true, + "requires": { + "cross-spawn": "^5.0.1", + "get-stream": "^3.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + }, + "get-stream": { + "version": "3.0.0", + "resolved": "https://registry.nlark.com/get-stream/download/get-stream-3.0.0.tgz", + "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", + "dev": true + }, + "lru-cache": { + "version": "4.1.5", + "resolved": "https://registry.nlark.com/lru-cache/download/lru-cache-4.1.5.tgz", + "integrity": "sha1-i75Q6oW+1ZvJ4z3KuCNe6bz0Q80=", + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "normalize-path": { + "version": "1.0.0", + "resolved": "https://registry.nlark.com/normalize-path/download/normalize-path-1.0.0.tgz", + "integrity": "sha1-MtDkcvkf80VwHBWoMRAY07CpA3k=", + "dev": true + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/shebang-command/download/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npm.taobao.org/shebang-regex/download/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "dev": true + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npm.taobao.org/which/download/which-1.3.1.tgz", + "integrity": "sha1-pFBD1U9YBTFtqNYvn1CRjT2nCwo=", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.nlark.com/yallist/download/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + } + } + }, + "zrender": { + "version": "5.0.4", + "resolved": "https://registry.nlark.com/zrender/download/zrender-5.0.4.tgz", + "integrity": "sha1-icNVr5CLn2SjAbOPdRt5UfLIqVo=", + "requires": { + "tslib": "2.0.3" + } + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/package.json" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/package.json" new file mode 100644 index 0000000..42cd9e5 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/package.json" @@ -0,0 +1,67 @@ +{ + "name": "wideseawcs", + "version": "0.1.0", + "private": true, + "scripts": { + "serve": "vue-cli-service serve", + "build": "vue-cli-service build", + "test:unit": "vue-cli-service test:unit", + "lint": "vue-cli-service lint" + }, + "dependencies": { + "@element-plus/icons-vue": "^2.1.0", + "@microsoft/signalr": "^6.0.4", + "ali-oss": "^6.17.1", + "axios": "^0.21.1", + "core-js": "^3.6.5", + "echarts": "^5.0.2", + "element-plus": "^2.2.14", + "less": "^4.1.1", + "vue": "^3.2.37", + "vue-draggable-next": "^2.0.1", + "vue-router": "^4.0.0-0", + "vuex": "^4.0.0-0" + }, + "devDependencies": { + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@vue/cli-plugin-babel": "~4.5.0", + "@vue/cli-plugin-eslint": "~4.5.0", + "@vue/cli-plugin-router": "~4.5.0", + "@vue/cli-plugin-unit-mocha": "~4.5.0", + "@vue/cli-plugin-vuex": "~4.5.0", + "@vue/cli-service": "~4.5.0", + "@vue/compiler-sfc": "^3.0.0", + "@vue/test-utils": "^2.0.0-0", + "babel-eslint": "^10.1.0", + "chai": "^4.1.2", + "cross-env": "^7.0.3", + "less": "^4.1.1", + "less-loader": "^7.3.0", + "sass": "^1.78.0", + "sass-loader": "^16.0.1", + "stylus": "^0.54.7", + "stylus-loader": "^3.0.2" + }, + "eslintConfig": { + "root": true, + "env": { + "node": true + }, + "extends": [ + "plugin:vue/essential", + "@vue/standard" + ], + "rules": { + "indent": [ + 1, + 4 + ] + }, + "parserOptions": { + "parser": "babel-eslint" + } + }, + "eslintIgnore": [ + "*" + ] +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/index.html" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/index.html" new file mode 100644 index 0000000..c902847 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/index.html" @@ -0,0 +1,135 @@ +<!DOCTYPE html> +<html lang=""> + +<head> + <meta charset="utf-8"> + <meta http-equiv="X-UA-Compatible" content="IE=edge"> + <meta name="viewport" content="width=device-width,initial-scale=1.0"> + <meta name="keywords" content=".netccore,dotnet core,vue,element,element plus,vue3" /> + <meta name="description" content="" /> + <link rel="icon" href="<%= BASE_URL %>wms_d.png"> + <title><%= htmlWebpackPlugin.options.title %></title> +</head> + +<body> + <noscript> + <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. + Please enable it to continue.</strong> + </noscript> + <div id="app"></div> + <!-- built files will be auto injected --> +</body> + +</html> +<style> + html, + body { + margin: 0; + padding: 0; + height: 100%; + width: 100%; + } + + * { + box-sizing: border-box; + } + + .el-loading { + z-index: 999999; + } + + .el-table th { + display: table-cell !important; + } + + .el-loading .el-loading-spinner { + padding: 7px; + background: #ececec; + width: 200px; + color: red; + left: 0; + right: 0; + margin: 0 auto; + border-radius: 5px; + border: 1px solid #a0a0a0; + + } + + h1, + h2, + h3, + h4 { + margin: 0; + } + + .v-dialog { + border-radius: 5px; + top: 50%; + /* margin-top: -220px !important; */ + } + + .v-dialog .el-dialog__header { + border-top-left-radius: 4px; + border-top-right-radius: 4px; + padding: 0px 13px; + line-height: 53px; + border-bottom: 1px solid #e2e2e2; + height: 50px; + color: white; + font-weight: bold; + font-size: 14px; + background-image: linear-gradient(135deg, #0cd7bd 10%, #50c3f7); + } + + .v-dialog .el-dialog__header .el-dialog__headerbtn { + top: 3px; + right: 0px; + } + + .v-dialog .el-dialog__header .el-dialog__headerbtn .el-dialog__close { + font-size: 19px; + color: white; + } + + .v-dialog .el-dialog__body { + padding: 0; + } + + .el-message { + z-index: 3500 !important; + } + + .v-date-range .el-input__inner { + padding: 0 15px 0 8px + } + + .v-date-range .el-input__suffix .el-input__icon { + display: table-caption; + background: white; + margin: 1px; + height: auto; + margin-right: -4px; + height: 33px; + width: 19px; + font-size: 13px; + border-top-right-radius: 3px; + border-bottom-right-radius: 3px; + } + + .v-date-range .el-icon-circle-check { + display: none !important; + } + + .v-dialog .el-dialog__header { + margin-right: 0; + } + + .el-button { + font-size: 12px !important; + } + + .el-button--small { + padding: 0px 15px !important; + height: 32px; + } +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/static/login_bg.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/static/login_bg.png" new file mode 100644 index 0000000..925a5da --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/static/login_bg.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/wcslogo.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/wcslogo.png" new file mode 100644 index 0000000..2ef8e9b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/wcslogo.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/wms_d.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/wms_d.png" new file mode 100644 index 0000000..1e198e9 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/public/wms_d.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/App.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/App.vue" new file mode 100644 index 0000000..c46407f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/App.vue" @@ -0,0 +1,67 @@ +<template> + <div id="nav"></div> + <el-config-provider :locale="locale"> + <router-view /> + </el-config-provider> +</template> +<script> +import { ElConfigProvider } from "element-plus"; +import zhCn from "element-plus/lib/locale/lang/zh-cn"; +export default { + name: "vol_app", + components: { + [ElConfigProvider.name]: ElConfigProvider, //娣诲姞缁勪欢 + }, + data() { + return { + locale: zhCn, + }; + }, + created() { + }, + methods: { + }, +}; +</script> +<style lang="stylus"> +#app { + font-family: Avenir, Helvetica, Arial, sans-serif; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + height: 100%; + width: 100%; +} + +.el-alert--error.is-light { + border: 1px solid #ffe0e0; +} + +.el-alert--error.is-light { + color: #f74444 !important; +} + +.el-alert--warning.is-light { + border: 1px solid #ffe6c1; +} + +.el-alert--info.is-light { + border: 1px solid #e6e5e5; +} + +.el-alert--info .el-alert__description { + color: #6b6b6b !important; +} + +.el-alert--warning.is-light { + background-color: #fdf6ec; + color: #d68409 !important; +} + +.el-alert--success.is-light { + border: 1px solid #cdf7b8; +} + +.el-alert--success.is-light .el-alert__description { + color: #3baf02 !important; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/http.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/http.js" new file mode 100644 index 0000000..f72cad1 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/http.js" @@ -0,0 +1,324 @@ +import axios from 'axios' +import store from '../store/index' +// import {getCurrentInstance} from 'vue' +import { useRouter, useRoute } from 'vue-router' +const router = useRouter(); +axios.defaults.timeout = 50000; +axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'; + +import { ElLoading as Loading, ElMessage as Message } from 'element-plus'; + + +let loadingInstance; +let loadingStatus = false; +if (process.env.NODE_ENV == 'development') { + axios.defaults.baseURL = 'http://127.0.0.1:9293/'; +} +else if (process.env.NODE_ENV == 'debug') { + axios.defaults.baseURL = 'http://127.0.0.1:8098/'; +} + +else if (process.env.NODE_ENV == 'production') { + axios.defaults.baseURL = 'http://115.159.85.185:9291/'; +} +if (!axios.defaults.baseURL.endsWith('/')) { + axios.defaults.baseURL+="/"; +} + + +let ipAddress = axios.defaults.baseURL; +axios.interceptors.request.use((config) => { + return config; +}, (error) => { + return Promise.reject(error); +}); + +axios.interceptors.response.use((res) => { + + closeLoading(); + + checkResponse(res); + + return Promise.resolve(res); +}, (error) => { + closeLoading(); + let httpMessage = ''; + if (error.response) { + if (error.response.status == '401') { + if (error.response.data && error.response.data.code == 401) { + if (!localStorage.getItem('user')) { + Message.error({ + showClose: true, + message: '鐧婚檰宸茶繃鏈�', + type: 'error' + }); + } + toLogin(); + return; + } + + } + if (error.response.status == '404') { + httpMessage = "鏈壘鍒拌姹傚湴鍧�"; + } + else if (error.response.data && error.response.data.message) { + httpMessage = error.response.data.message; + } + } + else { + httpMessage = '鏈嶅姟鍣ㄥ鐞嗗紓甯�' + } + redirect(httpMessage); + return Promise.reject(error.response || {}, httpMessage); +}); +function closeLoading () { + if (loadingInstance) { + loadingInstance.close(); + } + if (loadingStatus) { + loadingStatus = false; + if (loadingInstance) { + loadingInstance.close(); + } + } + +} +function checkResponse (res) { + //鍒锋柊token + if (!res.headers) { + if (res.getResponseHeader("widesea_exp") == "1") { + replaceToken(); + } + } + else if (res.headers.widesea_exp == "1") { + replaceToken(); + } +} + +const _Authorization = 'Authorization'; + +function showLoading (loading) { + if (!loading || loadingStatus) { + return; + } + loadingInstance = Loading.service({ + lock: true, + text: 'Loading', + customClass:"http-loading", + background: typeof loading == "string" ? loading : '姝e湪澶勭悊.....', + background: 'rgba(58, 61, 63, 0.32)' + }); +} + +function getToken () { + return store.getters.getToken(); +} + +/* + url + params璇锋眰鍚庡彴鐨勫弬鏁�,濡傦細{name:123,values:['a','b','c']} + loading鏄惁鏄剧ず閬僵灞�,鍙互浼犲叆true.false.鍙婃彁绀烘枃鏈� + config閰嶇疆淇℃伅,濡倇timeout:3000,headers:{token:123}} +*/ +function post (url, params, loading, config) { + showLoading(loading); + axios.defaults.headers[_Authorization] = getToken(); + return new Promise((resolve, reject) => { + axios.post(url, params, config) + .then(response => { + resolve(response.data); + }, err => { + reject(err && err.data && err.data.message ? err.data.message : '鏈嶅姟鍣ㄥ鐞嗗紓甯�'); + }) + .catch((error) => { + reject(error) + }) + }) +} + +//=true寮傛璇锋眰鏃朵細鏄剧ず閬僵灞�,=瀛楃涓诧紝寮傛璇锋眰鏃堕伄缃╁眰鏄剧ず褰撳墠瀛楃涓� +function get (url, param, loading, config) { + showLoading(loading); + axios.defaults.headers[_Authorization] = getToken(); + return new Promise((resolve, reject) => { + axios.get(url, config) + .then(response => { + // console.log(response) + resolve(response.data) + }, err => { + reject(err) + }) + .catch((error) => { + reject(error) + }) + }) +} + +//url:url鍦板潃 +//params:璇锋眰鍙傛暟 +//fileName:涓嬭浇鐨勬枃浠跺悕 +//loading:鏄惁鏄剧ず鍔犺浇鐘舵�� +function download (url, params, fileName, loading,callback) { + fileName = fileName.replace(">", "锛�").replace("<", "锛�"); + post(url, params, loading, { responseType: 'blob' }).then(content => { + const blob = new Blob([content]) + if ('download' in document.createElement('a')) { // 闈濱E涓嬭浇 + const elink = document.createElement('a') + elink.download = fileName + elink.style.display = 'none' + elink.href = URL.createObjectURL(blob) + document.body.appendChild(elink) + elink.click() + URL.revokeObjectURL(elink.href) // 閲婃斁URL 瀵硅薄 + document.body.removeChild(elink) + } else { // IE10+涓嬭浇 + navigator.msSaveBlob(blob, fileName) + } + callback&&callback(); + }) +} + + +function createXHR () { + if (XMLHttpRequest) { + return new XMLHttpRequest(); + } + if (ActiveXObject) { + if (typeof arguments.callee.activeXString != "string") { + var versions = [ + "MSXML2.XMLHttp.6.0", + "MSXML2.XMLHttp", + "MSXML2.XMLHttp.3.0" + ]; + for (var i = 0; i < versions.length; i++) { + try { + new ActiveXObject(versions[i]); + arguments.callee.activeXString = versions[i]; + break; + } catch (e) { + console.log(e); + } + } + } + return new ActiveXObject(arguments.callee.activeXString); + } +} + +function redirect (responseText, message) { + try { + let responseData = typeof responseText == 'string' ? JSON.parse(responseText) : responseText; + if ((responseData.hasOwnProperty('code') && responseData.code == 401) + || (responseData.data && responseData.data.code == 401)) { + closeLoading(); + toLogin(); + } else { + if (message) { + Message.error({ + showClose: true, + message: message, + type: 'error' + }); + } + } + } catch (error) { + console.log(error); + Message.error({ + showClose: true, + message: responseText, + type: 'error' + }); + } +} + + +function toLogin () { + // const vueinstance= getCurrentInstance(); + if (window.location.hash) { + window.location.href = window.location.origin + '/#/login' + return + } + window.location.href = window.location.origin + '/login' + // router.push({ path: '/login', params: { r: Math.random() } }); +} +//鍔ㄦ�佸埛鏂皌oken +function replaceToken () { + ajax({ + url: "/api/User/replaceToken", + param: {}, + json: true, + success: function (x) { + if (x.status) { + let userInfo = store.getters.getUserInfo(); + userInfo.token = x.data; + store.commit('setUserInfo', userInfo); + } else { + console.log(x.message); + toLogin(); + } + }, + errror: function (ex) { + console.log(ex); + toLogin(); + }, + type: "post", + async: false + }); + + +} + +function ajax (param) { + let httpParam = + Object.assign({ + url: '', headers: {}, + param: {}, json: true, + success: function () { }, + errror: function () { }, + type: 'post', async: true + }, param); + + httpParam.url = axios.defaults.baseURL + httpParam.url.replace(/\/?/, ''); + httpParam.headers[_Authorization] = getToken(); + var xhr = createXHR(); + xhr.onreadystatechange = function () { + if (xhr.status == 403 || xhr.status == 401) { + redirect(xhr.responseText); + return; + } + checkResponse(xhr); + if (xhr.readyState == 4 && xhr.status == 200) { + httpParam.success(httpParam.json ? JSON.parse(xhr.responseText) : xhr.responseText); + return; + } + if (xhr.status != 0 && xhr.readyState != 1) { + httpParam.errror(xhr); + } + }; + //鍒濆鍖栬姹� + xhr.open( + httpParam.type, + httpParam.url, + httpParam.async + ); + xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); + for (const key in httpParam.headers) { + xhr.setRequestHeader(key, httpParam.headers[key]); + } + let dataStr = ''; + for (const key in httpParam.param) { + dataStr += key + "=" + httpParam.param[key]; + } + try { + xhr.send(dataStr); + } catch (error) { + toLogin(); + } +} + +ajax.post = function (url, param, success, errror) { + ajax({ url: url, param: param, success: success, error: errror, type: 'post' }) +} +ajax.get = function (url, param, success, errror) { + ajax({ url: url, param: param, success: success, error: errror, type: 'get' }) +} +export default { post, get,download, ajax, ipAddress } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/permission.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/permission.js" new file mode 100644 index 0000000..8dc7b02 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/permission.js" @@ -0,0 +1,53 @@ + +import http from '@/../src/api/http.js' +import buttons from '@/../config/buttons.js' +import store from '../store/index' +import { useRouter } from 'vue-router' +let permission = { + getMenu() { + return http.get("/api/getTreeMenu"); + }, getButtons(path, extra, table, tableName) {//extra鑷畾棰濆鎸夐挳 + //extra鑷畾棰濆鎸夐挳 + //table鑾峰彇鎸囧畾琛ㄧ殑鏉冮檺 + if (table) { + table = '/' + table; + } + let permission = store.getters.getPermission(table || path); + if (!permission) { + permission = store.getters.getPermission(path.substring(1)); + if (!permission) { + if ((tableName || '').indexOf('/') != -1) { + let arr = tableName.split('/'); + tableName = arr[arr.length - 1]; + } + permission = store.getters.getPermission('/' + tableName); + if (!permission) { + permission = (store.state.permission||[]).find(x => x.tableName ==tableName); + if (!permission) { + to401(); + return; + } + } + } + } + + let permissions = permission.permission; //.split(','); + let gridButtons = buttons.filter((item) => { + return !item.value || permissions.indexOf(item.value) != -1; + }); + if (extra && extra instanceof Array) { + gridButtons.push(...extra); + } + return gridButtons; + }, to401() { + to401(); + } +} +function to401() { + const router = useRouter(); + router.push({ + path: '/401' + }); +} + +export default permission; \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/useTest.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/useTest.js" new file mode 100644 index 0000000..d4d7be1 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/api/useTest.js" @@ -0,0 +1,9 @@ +const tipxx = { + install: function (vue) { + alert(1); + vue.prototype.$tip = function () { + alert('娴嬭瘯use') + }; + } +} +export default { tipxx } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/css/common.less" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/css/common.less" new file mode 100644 index 0000000..ac7a179 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/css/common.less" @@ -0,0 +1,75 @@ +*{ + box-sizing:border-box; + -moz-box-sizing:border-box; /* Firefox */ + -webkit-box-sizing:border-box; /* Safari */ +} +.el-pager li{ + font-weight: 100; + margin-right: 9px; + border: 1px solid #eee; + border-radius: 3px; + min-width: 28px; +} +.el-pager li.active,.el-pager li:hover{ + background: #ed4014; + color: white; +} +.el-pagination__editor.el-input .el-input__inner{ + height: 23px; +} + + +.animated { + -webkit-animation-duration: 0.5s; + animation-duration: 0.5s; + -webkit-animation-fill-mode: both; + animation-fill-mode: both; + } + + @media (print), (prefers-reduced-motion) { + .animated { + -webkit-animation: unset !important; + animation: unset !important; + -webkit-transition: none !important; + transition: none !important; + } + } + + @-webkit-keyframes fadeInDown { + from { + opacity: 1; + -webkit-transform: translate3d(0, -100%, 0); + transform: translate3d(0, -100%, 0); + } + + to { + opacity: 1; + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + } + } + + @keyframes fadeInDown { + from { + opacity: 0; + -webkit-transform: translate3d(0, -100%, 0); + transform: translate3d(0, -100%, 0); + } + + to { + opacity: 1; + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + } + } + + .fadeInDown { + -webkit-animation-name: fadeInDown; + animation-name: fadeInDown; + } + .ivu-message{ + z-index: 999999999 !important; + } + .ivu-form-item-content{ + text-align: left; + } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/fonts/element-icons.ttf" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/fonts/element-icons.ttf" new file mode 100644 index 0000000..91b74de --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/fonts/element-icons.ttf" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/fonts/element-icons.woff" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/fonts/element-icons.woff" new file mode 100644 index 0000000..02b9a25 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/fonts/element-icons.woff" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/icon.css" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/icon.css" new file mode 100644 index 0000000..bf3ae3e --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/element-icon/icon.css" @@ -0,0 +1 @@ +@font-face{font-family:element-icons;src:url(fonts/element-icons.woff) format("woff"),url(fonts/element-icons.ttf) format("truetype");font-weight:400;font-display:"auto";font-style:normal}[class*=" el-icon-"],[class^=el-icon-]{font-family:element-icons!important;speak:none;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;line-height:1;vertical-align:baseline;display:inline-block;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.el-icon-ice-cream-round:before{content:"\e6a0"}.el-icon-ice-cream-square:before{content:"\e6a3"}.el-icon-lollipop:before{content:"\e6a4"}.el-icon-potato-strips:before{content:"\e6a5"}.el-icon-milk-tea:before{content:"\e6a6"}.el-icon-ice-drink:before{content:"\e6a7"}.el-icon-ice-tea:before{content:"\e6a9"}.el-icon-coffee:before{content:"\e6aa"}.el-icon-orange:before{content:"\e6ab"}.el-icon-pear:before{content:"\e6ac"}.el-icon-apple:before{content:"\e6ad"}.el-icon-cherry:before{content:"\e6ae"}.el-icon-watermelon:before{content:"\e6af"}.el-icon-grape:before{content:"\e6b0"}.el-icon-refrigerator:before{content:"\e6b1"}.el-icon-goblet-square-full:before{content:"\e6b2"}.el-icon-goblet-square:before{content:"\e6b3"}.el-icon-goblet-full:before{content:"\e6b4"}.el-icon-goblet:before{content:"\e6b5"}.el-icon-cold-drink:before{content:"\e6b6"}.el-icon-coffee-cup:before{content:"\e6b8"}.el-icon-water-cup:before{content:"\e6b9"}.el-icon-hot-water:before{content:"\e6ba"}.el-icon-ice-cream:before{content:"\e6bb"}.el-icon-dessert:before{content:"\e6bc"}.el-icon-sugar:before{content:"\e6bd"}.el-icon-tableware:before{content:"\e6be"}.el-icon-burger:before{content:"\e6bf"}.el-icon-knife-fork:before{content:"\e6c1"}.el-icon-fork-spoon:before{content:"\e6c2"}.el-icon-chicken:before{content:"\e6c3"}.el-icon-food:before{content:"\e6c4"}.el-icon-dish-1:before{content:"\e6c5"}.el-icon-dish:before{content:"\e6c6"}.el-icon-moon-night:before{content:"\e6ee"}.el-icon-moon:before{content:"\e6f0"}.el-icon-cloudy-and-sunny:before{content:"\e6f1"}.el-icon-partly-cloudy:before{content:"\e6f2"}.el-icon-cloudy:before{content:"\e6f3"}.el-icon-sunny:before{content:"\e6f6"}.el-icon-sunset:before{content:"\e6f7"}.el-icon-sunrise-1:before{content:"\e6f8"}.el-icon-sunrise:before{content:"\e6f9"}.el-icon-heavy-rain:before{content:"\e6fa"}.el-icon-lightning:before{content:"\e6fb"}.el-icon-light-rain:before{content:"\e6fc"}.el-icon-wind-power:before{content:"\e6fd"}.el-icon-baseball:before{content:"\e712"}.el-icon-soccer:before{content:"\e713"}.el-icon-football:before{content:"\e715"}.el-icon-basketball:before{content:"\e716"}.el-icon-ship:before{content:"\e73f"}.el-icon-truck:before{content:"\e740"}.el-icon-bicycle:before{content:"\e741"}.el-icon-mobile-phone:before{content:"\e6d3"}.el-icon-service:before{content:"\e6d4"}.el-icon-key:before{content:"\e6e2"}.el-icon-unlock:before{content:"\e6e4"}.el-icon-lock:before{content:"\e6e5"}.el-icon-watch:before{content:"\e6fe"}.el-icon-watch-1:before{content:"\e6ff"}.el-icon-timer:before{content:"\e702"}.el-icon-alarm-clock:before{content:"\e703"}.el-icon-map-location:before{content:"\e704"}.el-icon-delete-location:before{content:"\e705"}.el-icon-add-location:before{content:"\e706"}.el-icon-location-information:before{content:"\e707"}.el-icon-location-outline:before{content:"\e708"}.el-icon-location:before{content:"\e79e"}.el-icon-place:before{content:"\e709"}.el-icon-discover:before{content:"\e70a"}.el-icon-first-aid-kit:before{content:"\e70b"}.el-icon-trophy-1:before{content:"\e70c"}.el-icon-trophy:before{content:"\e70d"}.el-icon-medal:before{content:"\e70e"}.el-icon-medal-1:before{content:"\e70f"}.el-icon-stopwatch:before{content:"\e710"}.el-icon-mic:before{content:"\e711"}.el-icon-copy-document:before{content:"\e718"}.el-icon-full-screen:before{content:"\e719"}.el-icon-switch-button:before{content:"\e71b"}.el-icon-aim:before{content:"\e71c"}.el-icon-crop:before{content:"\e71d"}.el-icon-odometer:before{content:"\e71e"}.el-icon-time:before{content:"\e71f"}.el-icon-bangzhu:before{content:"\e724"}.el-icon-close-notification:before{content:"\e726"}.el-icon-microphone:before{content:"\e727"}.el-icon-turn-off-microphone:before{content:"\e728"}.el-icon-position:before{content:"\e729"}.el-icon-postcard:before{content:"\e72a"}.el-icon-message:before{content:"\e72b"}.el-icon-chat-line-square:before{content:"\e72d"}.el-icon-chat-dot-square:before{content:"\e72e"}.el-icon-chat-dot-round:before{content:"\e72f"}.el-icon-chat-square:before{content:"\e730"}.el-icon-chat-line-round:before{content:"\e731"}.el-icon-chat-round:before{content:"\e732"}.el-icon-set-up:before{content:"\e733"}.el-icon-turn-off:before{content:"\e734"}.el-icon-open:before{content:"\e735"}.el-icon-connection:before{content:"\e736"}.el-icon-link:before{content:"\e737"}.el-icon-cpu:before{content:"\e738"}.el-icon-thumb:before{content:"\e739"}.el-icon-female:before{content:"\e73a"}.el-icon-male:before{content:"\e73b"}.el-icon-guide:before{content:"\e73c"}.el-icon-news:before{content:"\e73e"}.el-icon-price-tag:before{content:"\e744"}.el-icon-discount:before{content:"\e745"}.el-icon-wallet:before{content:"\e747"}.el-icon-coin:before{content:"\e748"}.el-icon-money:before{content:"\e749"}.el-icon-bank-card:before{content:"\e74a"}.el-icon-box:before{content:"\e74b"}.el-icon-present:before{content:"\e74c"}.el-icon-sell:before{content:"\e6d5"}.el-icon-sold-out:before{content:"\e6d6"}.el-icon-shopping-bag-2:before{content:"\e74d"}.el-icon-shopping-bag-1:before{content:"\e74e"}.el-icon-shopping-cart-2:before{content:"\e74f"}.el-icon-shopping-cart-1:before{content:"\e750"}.el-icon-shopping-cart-full:before{content:"\e751"}.el-icon-smoking:before{content:"\e752"}.el-icon-no-smoking:before{content:"\e753"}.el-icon-house:before{content:"\e754"}.el-icon-table-lamp:before{content:"\e755"}.el-icon-school:before{content:"\e756"}.el-icon-office-building:before{content:"\e757"}.el-icon-toilet-paper:before{content:"\e758"}.el-icon-notebook-2:before{content:"\e759"}.el-icon-notebook-1:before{content:"\e75a"}.el-icon-files:before{content:"\e75b"}.el-icon-collection:before{content:"\e75c"}.el-icon-receiving:before{content:"\e75d"}.el-icon-suitcase-1:before{content:"\e760"}.el-icon-suitcase:before{content:"\e761"}.el-icon-film:before{content:"\e763"}.el-icon-collection-tag:before{content:"\e765"}.el-icon-data-analysis:before{content:"\e766"}.el-icon-pie-chart:before{content:"\e767"}.el-icon-data-board:before{content:"\e768"}.el-icon-data-line:before{content:"\e76d"}.el-icon-reading:before{content:"\e769"}.el-icon-magic-stick:before{content:"\e76a"}.el-icon-coordinate:before{content:"\e76b"}.el-icon-mouse:before{content:"\e76c"}.el-icon-brush:before{content:"\e76e"}.el-icon-headset:before{content:"\e76f"}.el-icon-umbrella:before{content:"\e770"}.el-icon-scissors:before{content:"\e771"}.el-icon-mobile:before{content:"\e773"}.el-icon-attract:before{content:"\e774"}.el-icon-monitor:before{content:"\e775"}.el-icon-search:before{content:"\e778"}.el-icon-takeaway-box:before{content:"\e77a"}.el-icon-paperclip:before{content:"\e77d"}.el-icon-printer:before{content:"\e77e"}.el-icon-document-add:before{content:"\e782"}.el-icon-document:before{content:"\e785"}.el-icon-document-checked:before{content:"\e786"}.el-icon-document-copy:before{content:"\e787"}.el-icon-document-delete:before{content:"\e788"}.el-icon-document-remove:before{content:"\e789"}.el-icon-tickets:before{content:"\e78b"}.el-icon-folder-checked:before{content:"\e77f"}.el-icon-folder-delete:before{content:"\e780"}.el-icon-folder-remove:before{content:"\e781"}.el-icon-folder-add:before{content:"\e783"}.el-icon-folder-opened:before{content:"\e784"}.el-icon-folder:before{content:"\e78a"}.el-icon-edit-outline:before{content:"\e764"}.el-icon-edit:before{content:"\e78c"}.el-icon-date:before{content:"\e78e"}.el-icon-c-scale-to-original:before{content:"\e7c6"}.el-icon-view:before{content:"\e6ce"}.el-icon-loading:before{content:"\e6cf"}.el-icon-rank:before{content:"\e6d1"}.el-icon-sort-down:before{content:"\e7c4"}.el-icon-sort-up:before{content:"\e7c5"}.el-icon-sort:before{content:"\e6d2"}.el-icon-finished:before{content:"\e6cd"}.el-icon-refresh-left:before{content:"\e6c7"}.el-icon-refresh-right:before{content:"\e6c8"}.el-icon-refresh:before{content:"\e6d0"}.el-icon-video-play:before{content:"\e7c0"}.el-icon-video-pause:before{content:"\e7c1"}.el-icon-d-arrow-right:before{content:"\e6dc"}.el-icon-d-arrow-left:before{content:"\e6dd"}.el-icon-arrow-up:before{content:"\e6e1"}.el-icon-arrow-down:before{content:"\e6df"}.el-icon-arrow-right:before{content:"\e6e0"}.el-icon-arrow-left:before{content:"\e6de"}.el-icon-top-right:before{content:"\e6e7"}.el-icon-top-left:before{content:"\e6e8"}.el-icon-top:before{content:"\e6e6"}.el-icon-bottom:before{content:"\e6eb"}.el-icon-right:before{content:"\e6e9"}.el-icon-back:before{content:"\e6ea"}.el-icon-bottom-right:before{content:"\e6ec"}.el-icon-bottom-left:before{content:"\e6ed"}.el-icon-caret-top:before{content:"\e78f"}.el-icon-caret-bottom:before{content:"\e790"}.el-icon-caret-right:before{content:"\e791"}.el-icon-caret-left:before{content:"\e792"}.el-icon-d-caret:before{content:"\e79a"}.el-icon-share:before{content:"\e793"}.el-icon-menu:before{content:"\e798"}.el-icon-s-grid:before{content:"\e7a6"}.el-icon-s-check:before{content:"\e7a7"}.el-icon-s-data:before{content:"\e7a8"}.el-icon-s-opportunity:before{content:"\e7aa"}.el-icon-s-custom:before{content:"\e7ab"}.el-icon-s-claim:before{content:"\e7ad"}.el-icon-s-finance:before{content:"\e7ae"}.el-icon-s-comment:before{content:"\e7af"}.el-icon-s-flag:before{content:"\e7b0"}.el-icon-s-marketing:before{content:"\e7b1"}.el-icon-s-shop:before{content:"\e7b4"}.el-icon-s-open:before{content:"\e7b5"}.el-icon-s-management:before{content:"\e7b6"}.el-icon-s-ticket:before{content:"\e7b7"}.el-icon-s-release:before{content:"\e7b8"}.el-icon-s-home:before{content:"\e7b9"}.el-icon-s-promotion:before{content:"\e7ba"}.el-icon-s-operation:before{content:"\e7bb"}.el-icon-s-unfold:before{content:"\e7bc"}.el-icon-s-fold:before{content:"\e7a9"}.el-icon-s-platform:before{content:"\e7bd"}.el-icon-s-order:before{content:"\e7be"}.el-icon-s-cooperation:before{content:"\e7bf"}.el-icon-bell:before{content:"\e725"}.el-icon-message-solid:before{content:"\e799"}.el-icon-video-camera:before{content:"\e772"}.el-icon-video-camera-solid:before{content:"\e796"}.el-icon-camera:before{content:"\e779"}.el-icon-camera-solid:before{content:"\e79b"}.el-icon-download:before{content:"\e77c"}.el-icon-upload2:before{content:"\e77b"}.el-icon-upload:before{content:"\e7c3"}.el-icon-picture-outline-round:before{content:"\e75f"}.el-icon-picture-outline:before{content:"\e75e"}.el-icon-picture:before{content:"\e79f"}.el-icon-close:before{content:"\e6db"}.el-icon-check:before{content:"\e6da"}.el-icon-plus:before{content:"\e6d9"}.el-icon-minus:before{content:"\e6d8"}.el-icon-help:before{content:"\e73d"}.el-icon-s-help:before{content:"\e7b3"}.el-icon-circle-close:before{content:"\e78d"}.el-icon-circle-check:before{content:"\e720"}.el-icon-circle-plus-outline:before{content:"\e723"}.el-icon-remove-outline:before{content:"\e722"}.el-icon-zoom-out:before{content:"\e776"}.el-icon-zoom-in:before{content:"\e777"}.el-icon-error:before{content:"\e79d"}.el-icon-success:before{content:"\e79c"}.el-icon-circle-plus:before{content:"\e7a0"}.el-icon-remove:before{content:"\e7a2"}.el-icon-info:before{content:"\e7a1"}.el-icon-question:before{content:"\e7a4"}.el-icon-warning-outline:before{content:"\e6c9"}.el-icon-warning:before{content:"\e7a3"}.el-icon-goods:before{content:"\e7c2"}.el-icon-s-goods:before{content:"\e7b2"}.el-icon-star-off:before{content:"\e717"}.el-icon-star-on:before{content:"\e797"}.el-icon-more-outline:before{content:"\e6cc"}.el-icon-more:before{content:"\e794"}.el-icon-phone-outline:before{content:"\e6cb"}.el-icon-phone:before{content:"\e795"}.el-icon-user:before{content:"\e6e3"}.el-icon-user-solid:before{content:"\e7a5"}.el-icon-setting:before{content:"\e6ca"}.el-icon-s-tools:before{content:"\e7ac"}.el-icon-delete:before{content:"\e6d7"}.el-icon-delete-solid:before{content:"\e7c9"}.el-icon-eleme:before{content:"\e7c7"}.el-icon-platform-eleme:before{content:"\e7ca"}.el-icon-loading{-webkit-animation:rotating 2s linear infinite;animation:rotating 2s linear infinite}.el-icon--right{margin-left:5px}.el-icon--left{margin-right:5px}@-webkit-keyframes rotating{0%{-webkit-transform:rotateZ(0);transform:rotateZ(0)}100%{-webkit-transform:rotateZ(360deg);transform:rotateZ(360deg)}}@keyframes rotating{0%{-webkit-transform:rotateZ(0);transform:rotateZ(0)}100%{-webkit-transform:rotateZ(360deg);transform:rotateZ(360deg)}} \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/error-img.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/error-img.png" new file mode 100644 index 0000000..d479f96 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/error-img.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/error.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/error.png" new file mode 100644 index 0000000..d479f96 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/error.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/wms_d.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/wms_d.png" new file mode 100644 index 0000000..1e198e9 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/wms_d.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/wms_x.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/wms_x.png" new file mode 100644 index 0000000..a6a28ca --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/imgs/wms_x.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/logo.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/logo.png" new file mode 100644 index 0000000..f3d2503 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/logo.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/common.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/common.js" new file mode 100644 index 0000000..8e8e8eb --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/common.js" @@ -0,0 +1,2 @@ +var test1 = function () { alert(11) } +export { test1 } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/extend.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/extend.js" new file mode 100644 index 0000000..d34da65 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/extend.js" @@ -0,0 +1,5 @@ +//瀵箆ue鍙傛暟杩涜鎵╁睍 +var extend = function (param) { + console.log(param) + } +export { extend } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/testFormExtend.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/testFormExtend.js" new file mode 100644 index 0000000..67216df --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/assets/script/testFormExtend.js" @@ -0,0 +1,15 @@ +//瀵箆ue鍙傛暟杩涜鎵╁睍 +var extend = function ($vueParam) { + $vueParam.methods.volBoxFrom = function () { + this.$Message.info("鎵╁睍js,澧炲姞寮瑰嚭娑堟伅"); + this.$refs.volBoxFrom.show(); + } + //淇敼data灞炴��: + let data = $vueParam.data(); + data.formFileds['extend'] = "鍔ㄦ�佹墿灞曞瓧娈�"; + data.formOptions.splice(0,0,{ filed: "extend", title: "鍔ㄦ�佸鍔犲瓧娈�", type: "text", required: true }); + $vueParam.data = function () { + return data; + } +} +export { extend } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/AsyncLoading.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/AsyncLoading.vue" new file mode 100644 index 0000000..1ccf5c7 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/AsyncLoading.vue" @@ -0,0 +1,10 @@ +<template> + <div style="text-align: center;font-size: 16px;padding: 20px;">姝e湪鍔犺浇璧勬簮...</div> +</template> +<script> +export default { + created() { + // console.log('loading') + } +}; +</script> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Audit.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Audit.vue" new file mode 100644 index 0000000..431d6c5 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Audit.vue" @@ -0,0 +1,59 @@ +<template> + <el-alert + :title="'褰撳墠閫変腑' + auditParam.rows + '鏉¤褰曞緟瀹℃牳..'" + type="success" + :closable="false" + > + </el-alert> + <div class="item"> + <label>瀹℃牳缁撴灉锛�</label> + <el-radio-group v-model="auditParam.status"> + <el-radio + v-for="item in auditParam.data" + :key="item.status" + :label="item.status" + > + <span>{{ item.text }}</span> + </el-radio> + </el-radio-group> + </div> + <div class="item"> + <label style="margin-right: 13px;">澶� 娉細</label> + <el-input + v-model="auditParam.reason" + type="textarea" + style="margin-right: 13px;" + :autosize="{ minRows: 4, maxRows: 10 }" + placeholder="瀹℃牳澶囨敞..." + ></el-input> + </div> +</template> +<script> +export default { + props: { + auditParam: { + type: Object, + default: () => { + return { + auditParam: { + rows: 0, + model: false, + status: -1, + reason: "", + data: [], //[{ text: "閫氳繃", status: 1 }, { text: "鎷掔粷", status: 2 }] + }, + }; + }, + }, + }, +}; +</script> +<style lang="less" scoped> +.item{ + margin-top: 20px; + display: flex; + > label{ + width: 86px; + } +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Empty.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Empty.vue" new file mode 100644 index 0000000..e5e6a79 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Empty.vue" @@ -0,0 +1,3 @@ +<template> + <div></div> +</template> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ErrorMsg.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ErrorMsg.vue" new file mode 100644 index 0000000..3885ed5 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ErrorMsg.vue" @@ -0,0 +1,3 @@ +<template> + <div id="test"></div> +</template> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Icons.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Icons.vue" new file mode 100644 index 0000000..a5c6cf6 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/Icons.vue" @@ -0,0 +1,345 @@ +<template> + <div data-v-394040b0 class="icons"> + <div + @click="select(index)" + v-for="(item, index) in icons" + :key="index" + class="icons-item" + > + <i + :class="[item, selectIndex == index ? 'active' : '']" + style="font-size: 32px" + ></i> + <p>{{ item }}</p> + </div> + </div> +</template> +<script> +export default { + props: { + onSelect: { + type: Function, + default: () => { + return ""; + }, + }, + }, + methods: { + select(index) { + this.selectIndex = index; + this.onSelect(index < 0 ? "" : this.icons[index]); + }, + }, + data() { + return { + selectIndex: -1, + icons: [ + //ivu-icon ivu-icon-ios-add + "el-icon-menu", + "el-icon-platform-eleme", + "el-icon-eleme", + "el-icon-delete-solid", + "el-icon-delete", + "el-icon-s-tools", + "el-icon-setting", + "el-icon-user-solid", + "el-icon-user", + "el-icon-phone", + "el-icon-phone-outline", + "el-icon-more", + "el-icon-more-outline", + "el-icon-star-on", + "el-icon-star-off", + "el-icon-s-goods", + "el-icon-goods", + "el-icon-warning", + "el-icon-warning-outline", + "el-icon-question", + "el-icon-info", + "el-icon-remove", + "el-icon-circle-plus", + "el-icon-success", + "el-icon-error", + "el-icon-zoom-in", + "el-icon-zoom-out", + "el-icon-remove-outline", + "el-icon-circle-plus-outline", + "el-icon-circle-check", + "el-icon-circle-close", + "el-icon-s-help", + "el-icon-help", + "el-icon-minus", + "el-icon-plus", + "el-icon-check", + "el-icon-close", + "el-icon-picture", + "el-icon-picture-outline", + "el-icon-picture-outline-round", + "el-icon-upload", + "el-icon-upload2", + "el-icon-download", + "el-icon-camera-solid", + "el-icon-camera", + "el-icon-video-camera-solid", + "el-icon-video-camera", + "el-icon-message-solid", + "el-icon-bell", + "el-icon-s-cooperation", + "el-icon-s-order", + "el-icon-s-platform", + "el-icon-s-fold", + "el-icon-s-unfold", + "el-icon-s-operation", + "el-icon-s-promotion", + "el-icon-s-home", + "el-icon-s-release", + "el-icon-s-ticket", + "el-icon-s-management", + "el-icon-s-open", + "el-icon-s-shop", + "el-icon-s-marketing", + "el-icon-s-flag", + "el-icon-s-comment", + "el-icon-s-finance", + "el-icon-s-claim", + "el-icon-s-custom", + "el-icon-s-opportunity", + "el-icon-s-data", + "el-icon-s-check", + "el-icon-s-grid", + "el-icon-share", + "el-icon-d-caret", + "el-icon-caret-left", + "el-icon-caret-right", + "el-icon-caret-bottom", + "el-icon-caret-top", + "el-icon-bottom-left", + "el-icon-bottom-right", + "el-icon-back", + "el-icon-right", + "el-icon-bottom", + "el-icon-top", + "el-icon-top-left", + "el-icon-top-right", + "el-icon-arrow-left", + "el-icon-arrow-right", + "el-icon-arrow-down", + "el-icon-arrow-up", + "el-icon-d-arrow-left", + "el-icon-d-arrow-right", + "el-icon-video-pause", + "el-icon-video-play", + "el-icon-refresh", + "el-icon-refresh-right", + "el-icon-refresh-left", + "el-icon-finished", + "el-icon-sort", + "el-icon-sort-up", + "el-icon-sort-down", + "el-icon-rank", + "el-icon-loading", + "el-icon-view", + "el-icon-c-scale-to-original", + "el-icon-date", + "el-icon-edit", + "el-icon-edit-outline", + "el-icon-folder", + "el-icon-folder-opened", + "el-icon-folder-add", + "el-icon-folder-remove", + "el-icon-folder-delete", + "el-icon-folder-checked", + "el-icon-tickets", + "el-icon-document-remove", + "el-icon-document-delete", + "el-icon-document-copy", + "el-icon-document-checked", + "el-icon-document", + "el-icon-document-add", + "el-icon-printer", + "el-icon-paperclip", + "el-icon-takeaway-box", + "el-icon-search", + "el-icon-monitor", + "el-icon-attract", + "el-icon-mobile", + "el-icon-scissors", + "el-icon-umbrella", + "el-icon-headset", + "el-icon-brush", + "el-icon-mouse", + "el-icon-coordinate", + "el-icon-magic-stick", + "el-icon-reading", + "el-icon-data-line", + "el-icon-data-board", + "el-icon-pie-chart", + "el-icon-data-analysis", + "el-icon-collection-tag", + "el-icon-film", + "el-icon-suitcase", + "el-icon-suitcase-1", + "el-icon-receiving", + "el-icon-collection", + "el-icon-files", + "el-icon-notebook-1", + "el-icon-notebook-2", + "el-icon-toilet-paper", + "el-icon-office-building", + "el-icon-school", + "el-icon-table-lamp", + "el-icon-house", + "el-icon-no-smoking", + "el-icon-smoking", + "el-icon-shopping-cart-full", + "el-icon-shopping-cart-1", + "el-icon-shopping-cart-2", + "el-icon-shopping-bag-1", + "el-icon-shopping-bag-2", + "el-icon-sold-out", + "el-icon-sell", + "el-icon-present", + "el-icon-box", + "el-icon-bank-card", + "el-icon-money", + "el-icon-coin", + "el-icon-wallet", + "el-icon-discount", + "el-icon-price-tag", + "el-icon-news", + "el-icon-guide", + "el-icon-male", + "el-icon-female", + "el-icon-thumb", + "el-icon-cpu", + "el-icon-link", + "el-icon-connection", + "el-icon-open", + "el-icon-turn-off", + "el-icon-set-up", + "el-icon-chat-round", + "el-icon-chat-line-round", + "el-icon-chat-square", + "el-icon-chat-dot-round", + "el-icon-chat-dot-square", + "el-icon-chat-line-square", + "el-icon-message", + "el-icon-postcard", + "el-icon-position", + "el-icon-turn-off-microphone", + "el-icon-microphone", + "el-icon-close-notification", + "el-icon-bangzhu", + "el-icon-time", + "el-icon-odometer", + "el-icon-crop", + "el-icon-aim", + "el-icon-switch-button", + "el-icon-full-screen", + "el-icon-copy-document", + "el-icon-mic", + "el-icon-stopwatch", + "el-icon-medal-1", + "el-icon-medal", + "el-icon-trophy", + "el-icon-trophy-1", + "el-icon-first-aid-kit", + "el-icon-discover", + "el-icon-place", + "el-icon-location", + "el-icon-location-outline", + "el-icon-location-information", + "el-icon-add-location", + "el-icon-delete-location", + "el-icon-map-location", + "el-icon-alarm-clock", + "el-icon-timer", + "el-icon-watch-1", + "el-icon-watch", + "el-icon-lock", + "el-icon-unlock", + "el-icon-key", + "el-icon-service", + "el-icon-mobile-phone", + "el-icon-bicycle", + "el-icon-truck", + "el-icon-ship", + "el-icon-basketball", + "el-icon-football", + "el-icon-soccer", + "el-icon-baseball", + "el-icon-wind-power", + "el-icon-light-rain", + "el-icon-lightning", + "el-icon-heavy-rain", + "el-icon-sunrise", + "el-icon-sunrise-1", + "el-icon-sunset", + "el-icon-sunny", + "el-icon-cloudy", + "el-icon-partly-cloudy", + "el-icon-cloudy-and-sunny", + "el-icon-moon", + "el-icon-moon-night", + "el-icon-dish", + "el-icon-dish-1", + "el-icon-food", + "el-icon-chicken", + "el-icon-fork-spoon", + "el-icon-knife-fork", + "el-icon-burger", + "el-icon-tableware", + "el-icon-sugar", + "el-icon-dessert", + "el-icon-ice-cream", + "el-icon-hot-water", + "el-icon-water-cup", + "el-icon-coffee-cup", + "el-icon-cold-drink", + "el-icon-goblet", + "el-icon-goblet-full", + "el-icon-goblet-square", + "el-icon-goblet-square-full", + "el-icon-refrigerator", + "el-icon-grape", + "el-icon-watermelon", + "el-icon-cherry", + "el-icon-apple", + "el-icon-pear", + "el-icon-orange", + "el-icon-coffee", + "el-icon-ice-tea", + "el-icon-ice-drink", + "el-icon-milk-tea", + "el-icon-potato-strips", + "el-icon-lollipop", + "el-icon-ice-cream-square", + "el-icon-ice-cream-round", + ], + }; + }, +}; +</script> + + +<style lang="less" scoped> +.icons-item { + float: left; + margin: 6px 6px 6px 0; + width: 115px; + text-align: center; + list-style: none; + cursor: pointer; + height: 100px; + color: #5c6b77; + transition: all 0.2s ease; + position: relative; + padding-top: 10px; +} +.active { + border: 1px solid; + background: #f44336; + color: white; + font-size: 32px; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/QuickSearch.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/QuickSearch.vue" new file mode 100644 index 0000000..185cbf2 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/QuickSearch.vue" @@ -0,0 +1,152 @@ +<template> + <div> + <el-select + style="width: 150px" + v-if="['select', 'selectList'].indexOf(singleSearch.type) != -1" + v-model="searchFormFields[singleSearch.field]" + :filterable=" + singleSearch.filter || singleSearch.data.length > 10 ? true : false + " + :placeholder="'璇烽�夋嫨' + singleSearch.title" + clearable + > + <el-option + v-for="item in singleSearch.data" + :key="item.key" + :label="item.value" + :value="item.key" + > + </el-option> + </el-select> + <div + class="date-range" + v-else-if="['date', 'datetime'].indexOf(singleSearch.type) != -1" + > + <el-date-picker + style="width: 210px" + :clearable="false" + unlink-panels + v-model="searchFormFields[singleSearch.field]" + type="daterange" + :value-format="getDateFormat(singleSearch)" + :placeholder="singleSearch.title" + > + </el-date-picker> + <i + class="el-icon-circle-close" + @click="dateRangeClear(singleSearch.field)" + ></i> + </div> + <el-cascader + style="width: 210px" + clearable + v-model="searchFormFields[singleSearch.field]" + v-else-if="singleSearch.type == 'cascader'" + :options="singleSearch.data" + :props="{ checkStrictly: true }" + > + </el-cascader> + <el-input + clearable + v-else + style="width: 150px" + size="default" + v-model="searchFormFields[singleSearch.field]" + :placeholder="singleSearch.title" + @keypress="tiggerPress" + /> + </div> +</template> +<script> +export default { + props: { + singleSearch: { + type: Object, + default: {}, + }, + searchFormFields: { + type: Object, + default: () => { + return {}; + }, + }, + tiggerPress: { + type: Function, + default: () => {}, + }, + }, + methods: { + compareDate(date1, date2) { + if (!date2) { + return true; + } + return ( + date1.valueOf() < + (typeof date2 == "number" ? date2 : new Date(date2).valueOf()) + ); + }, + getDateFormat(item) { + //瑙乭ttps://day.js.org/docs/zh-CN/display/format + return item.type == "date" ? "YYYY-MM-DD" : "YYYY-MM-DD HH:mm:ss"; + }, + getDateOptions(date, item) { + if ((!item.min && !item.max) || !date) { + return false; + } + if (item.min && item.min.indexOf(" ") == -1) { + //涓嶈缃椂鍒嗙锛屽悗闈細鑷姩鍔犱笂 08:00 + item.min = item.min + " 00:00:000"; + } + return ( + this.compareDate(date, item.min) || !this.compareDate(date, item.max) + ); + }, + dateRangeClear(field) { + this.searchFormFields[field]=[undefined,undefined]; + }, + }, + created() { + this.singleSearch.dateType = this.singleSearch.type + "range"; + if ( + this.singleSearch.type == "date" || + this.singleSearch.type == "datetime" + ) { + var _dateVal = this.searchFormFields[this.singleSearch.field]; + if ( + typeof this.singleSearch.range == "boolean" && + !this.singleSearch.range + ) { + this.searchFormFields[this.singleSearch.field] = ""; + this.singleSearch.dateType = this.singleSearch.type; + return this.singleSearch.dateType; + } else if (!(_dateVal instanceof Array)) { + this.searchFormFields[this.singleSearch.field] = ["", ""]; + } else if (_dateVal.length != 2) { + _dateVal.splice(0); + _dateVal.push(...["", ""]); + } + } + }, +}; +</script> +<style lang="less" scoped> +.date-range{ + position: relative; + > i{ + display: none; + height: 27px; + line-height: 27px; + right: 1px; + top: 3px; + font-size: 13px; + color: #b4adad; + position: absolute; + padding: 0 6px 0 3px; + background: #ffff; + cursor: pointer; + } +} +.date-range:hover > i{ + display: inline-block; +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/RouterLoading.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/RouterLoading.vue" new file mode 100644 index 0000000..134a454 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/RouterLoading.vue" @@ -0,0 +1,105 @@ +<template> + <div class="router-loading" style="background: #eeeeee5c;"> + <div class="spanner"> + <span></span> + <span></span> + <span></span> + <span></span> + <span></span> + <span></span> + <span></span> + <span></span> + </div> + </div> +</template> + +<script> +export default { + data() { + return {}; + } +}; +</script> +<style scoped> +.router-loading { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + font-size: 100px; + text-align: center; + padding-top: 200px; + color: #808080; + z-index: 9999; +} +.spanner { + width: 100px; + height: 100px; + position: relative; + margin: 0 auto; +} +.router-loading span { + display: inline-block; + width: 20px; + height: 20px; + border-radius: 50%; + background: #66b1ff; + position: absolute; + animation: r_load 1.04s ease infinite; +} +@keyframes r_load { + 0% { + transform: scale(1.2); + opacity: 1; + } + 100% { + transform: scale(0.3); + opacity: 0.5; + } +} +.router-loading span:nth-child(1) { + left: 0; + top: 50%; + margin-top: -10px; + animation-delay: 0.13s; +} +.router-loading span:nth-child(2) { + left: 14px; + top: 14px; + animation-delay: 0.26s; +} +.router-loading span:nth-child(3) { + left: 50%; + top: 0; + margin-left: -10px; + animation-delay: 0.39s; +} +.router-loading span:nth-child(4) { + top: 14px; + right: 14px; + animation-delay: 0.52s; +} +.router-loading span:nth-child(5) { + right: 0; + top: 50%; + margin-top: -10px; + animation-delay: 0.65s; +} +.router-loading span:nth-child(6) { + right: 14px; + bottom: 14px; + animation-delay: 0.78s; +} +.router-loading span:nth-child(7) { + bottom: 0; + left: 50%; + margin-left: -10px; + animation-delay: 0.91s; +} +.router-loading span:nth-child(8) { + bottom: 14px; + left: 14px; + animation-delay: 1.04s; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/UploadExcel.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/UploadExcel.vue" new file mode 100644 index 0000000..230fdad --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/UploadExcel.vue" @@ -0,0 +1,221 @@ +<template> + <div class="upload-container"> + <a :href="template.url" ref="template"></a> + <div class="button-group"> + <el-upload + style="float: left" + ref="uploadFile" + :max-size="maxSize" + :on-change="clearMsg" + :before-upload="beforeUpload" + :action="url" + > + <el-button size="small" + ><i class="el-icon-folder-opened"></i>閫夋嫨鏂囦欢</el-button + > + </el-upload> + <el-button + v-if="template.url" + style="margin-left: 10px" + type="primary" + size="small" + @click="dowloadTemplate" + :loading="loadingStatus" + > + <i class="el-icon-bottom"></i> + 涓嬭浇妯℃澘</el-button + > + <el-button + type="success" + size="small" + @click="upload" + :loading="loadingStatus" + > + <i class="el-icon-top"></i> + 涓婁紶鏂囦欢</el-button + > + </div> + <div class="alert"> + <el-alert title="涓婁紶璇存槑" type="warning" :closable="false" show-icon + >鍙兘涓婁紶excel鏂囦欢,鏂囦欢澶у皬涓嶈秴杩噞{ maxSize }}M</el-alert + > + </div> + + <div v-if="file"> + <h3>鏂囦欢鍒楄〃</h3> + <div class="file-info"> + <span>鏂囦欢鍚嶏細{{ file.name }}</span> + <span>澶у皬{{ (file.size / 1024).toFixed(2) }}KB</span> + </div> + </div> + <div v-show="message" class="v-r-message"> + <h3 class="title">涓婁紶缁撴灉</h3> + <div class="text" :class="resultClass" v-html="message"></div> + </div> + <slot></slot> + </div> +</template> +<script> +//鐩墠鍙敮鎸佸崟涓狤xcel涓婁紶锛屽叾浠栧姛鑳藉紑鍙戜腑... +export default { + components: {}, + props: { + url: { + type: String, + default: '' + }, + template: { + //涓嬭浇妯℃澘閰嶇疆 + type: Object, + default: () => { + return { + url: '', //妯℃澘涓嬭浇璺緞锛屽鏋滄病鏈夋ā鏉胯矾寰勶紝鍒欎笉鏄剧ず涓嬭浇妯℃澘鍔熻兘 + fileName: '鏈畾涔夋枃浠跺悕' //涓嬭浇妯℃澘鐨勬枃浠跺悕 + }; + } + }, + importExcelBefore: { + type: Function, + default: (file) => { + return true; + } + } + }, + data() { + return { + maxSize: 100, + model: true, + file: null, + loadingStatus: false, + message: '', + resultClass: '' + }; + }, + methods: { + clearMsg() { + this.message = ''; + }, + reset() { + this.file = null; + this.message = ''; + this.resultClass = ''; + }, + getFileType() { + let fileName = + this.file.name + .split('.') + .pop() + .toLocaleLowerCase() || ''; + if (['numbers', 'csv', 'xls', 'xlsx'].indexOf(fileName) == -1) { + this.$Message.error('鍙兘閫夋嫨excel鏂囦欢'); + return false; + } + return true; + }, + beforeUpload(file) { + this.file = file; + if (!this.getFileType()) { + return false; + } + return false; + }, + upload() { + let _url = this.url; + if (!_url) { + return this.$Message.error('娌℃湁閰嶇疆濂経rl'); + } + + if (!this.file) { + return this.$Message.error('璇烽�夋嫨鏂囦欢'); + } + var formData = new FormData(); + formData.append('fileInput', this.file); + if (!this.importExcelBefore(formData)) { + return; + } + this.loadingStatus = true; + this.http.post(_url, formData).then( + (x) => { + // this.$refs.uploadFile.clearFiles(); + this.loadingStatus = false; + this.file = null; + if (x.status) { + this.$emit('importExcelAfter', x); + } + + this.message = x.message; + this.resultClass = x.status ? 'v-r-success' : 'v-r-error'; + }, + (error) => { + this.loadingStatus = false; + } + ); + }, + dowloadTemplate() { + let url = this.template.url; + let xmlResquest = new XMLHttpRequest(); + xmlResquest.open('GET', url, true); + xmlResquest.setRequestHeader('Content-type', 'application/json'); + xmlResquest.setRequestHeader( + 'Authorization', + this.$store.getters.getToken() + ); + let fileName = this.template.fileName + '.xlsx'; + let elink = this.$refs.template; + xmlResquest.responseType = 'blob'; + let $_vue = this; + this.loadingStatus = true; + xmlResquest.onload = function(oEvent) { + $_vue.loadingStatus = false; + if (xmlResquest.response.type == 'application/json') { + return $_vue.message.error('鏈壘鍒颁笅杞芥枃浠�'); + } + let content = xmlResquest.response; + elink.download = fileName; + let blob = new Blob([content]); + elink.href = URL.createObjectURL(blob); + elink.click(); + }; + xmlResquest.send(); + } + } +}; +</script> +<style lang="less" scoped> +.upload-container { + min-height: 270px !important; + display: inline-block; + width: 100%; + padding: 10px; + border: 1px dashed #989898; + min-height: 250px; + border-radius: 5px; + .alert { + margin-top: 12px; + } + .el-button-group > * { + display: flex; + } + h3 { + margin: 9px 0px; + } + .file-info > span { + margin-right: 20px; + } + .v-r-message { + margin-top: 10px; + .title { + margin-bottom: 2px; + } + > .text { + font-size: 13px; + } + .v-r-success { + color: #02b702; + } + .v-r-error { + color: #dc0909; + } + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/AuditHis.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/AuditHis.vue" new file mode 100644 index 0000000..d1fcb48 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/AuditHis.vue" @@ -0,0 +1,46 @@ +<template> + <vol-table + :tableData="tableData" + :columns="columns" + :height="411" + :pagination-hide="true" + :load-key="false" + :text-inline="false" + :ck="false" + ></vol-table> +</template> +<script> +import VolTable from '@/components/basic/VolTable.vue'; +import { + defineComponent, + ref, + reactive, + toRefs, + getCurrentInstance +} from 'vue'; +export default defineComponent({ + components: { + VolTable + }, + props: { + tableData: { + type: Array, + default: () => { + return []; + } + } + }, + setup() { + const columns = reactive([ + { title: '鑺傜偣', field: 'stepName' }, + { title: '瀹℃壒浜�', field: 'auditor' }, + { title: '瀹℃壒缁撴灉', field: 'auditStatus' }, + { title: '瀹℃壒鏃堕棿', field: 'auditDate',width:150 }, + { title: '澶囨敞', field: 'remark' } + ]); + return { + columns + } + } +}); +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGrid.less" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGrid.less" new file mode 100644 index 0000000..adc13c3 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGrid.less" @@ -0,0 +1,178 @@ +.view-container { + // padding: 15px; + background: white; + .grid-search { + padding-top: 15px; + //padding: 15px 15px 0 15px; + } + .grid-container, + .grid-body { + padding: 0 15px; + } + .view-header { + padding-left: 15px; + padding-right: 15px; + } + .fs-line { + height: 9px; + background: #f1f1f1; + margin-top: -10px; + margin-bottom: 10px; + } +} +.view-header { + height: 45px; + position: relative; + padding-bottom: 11px; + display: flex; + .search-line { + min-width: 150px; + } + .search-line > div { + margin-left: 5px; + margin-right: 10px; + } + .search-line > div > div { + width: 200px; + text-align: left; + } + .search-line > div:first-child { + flex: 1; + } + .search-line > div .ivu-select-dropdown { + max-height: 300px; + } + .btn-group { + white-space: nowrap; + button { + margin-left: 10px; + // padding: 5px 16px; + } + } + .btn-group .ivu-dropdown-item { + text-align: left !important; + } + .btn-group .ivu-dropdown-item:not(:last-child) { + border-bottom: 1px dotted #eee; + } + .desc-text { + margin-top: 5px; + font-weight: bold; + margin-bottom: 3px; + font-size: 14px; + color: #313131; + white-space: nowrap; + border-bottom: 2px solid #646565; + i { + font-size: 16px; + position: relative; + top: 1px; + margin-right: 2px; + } + } + .search-box { + background: #fefefe; + margin-top: 45px; + border: 1px solid #ececec; + position: absolute; + z-index: 999; + left: 0; + right: 0; + padding: 25px 40px; + padding-bottom: 0; + box-shadow: 0px 7px 18px -12px #bdc0bb; + } + .notice { + font-size: 13px; + color: #6b6b6b; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + position: relative; + top: 12px; + flex: 1; + left: 10px; + margin-right: 20px; + } +} + +.table-info-cell-title { + background-color: #f5f5f5 !important; +} +.box-com { + > div.item { + // margin-bottom: 10px; + padding: 15px 17px 0 8px; + margin-bottom: 12px; + background: white; + } + > div.form-item { + padding: 19px 16px 0px 5px; + //box-shadow: 0 1px 7px rgb(199, 199, 199); + } + > div.table-item { + padding: 0 10px; + border-top: 1.5px solid #eaeaea; + } + .v-text { + line-height: 27px; + } + .form-text { + position: relative; + border-bottom: 1px solid #eee; + font-size: 14px; + margin-bottom: 14px; + } +} + +.form-closex { + text-align: right; + padding-bottom: 24px; +} +.form-closex button { + margin-left: 10px; + padding: 4px 13px; +} +.toolbar { + padding: 3px 0px; + width: 100%; + display: flex; + .title { + line-height: 29px; + border-bottom: none; + font-size: 13px; + font-weight: bolder; + margin-bottom: 0; + color: #5d5c5c; + .icon { + color: #009688; + font-size: 18px; + } + + i { + line-height: 29px; + border-bottom: none; + font-weight: bolder; + margin-bottom: 0; + color: #5d5c5c; + position: relative; + margin-top: -4px; + font-size: 14px; + } + } + .btns { + line-height: 28px; + flex: 1; + text-align: right; + button { + // border: none; + // margin-left:15px; + border: 0px; + padding: 0px 9px; + color: #292929; + } + button:hover{ + color: #0089f6; + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGrid.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGrid.vue" new file mode 100644 index 0000000..e4bbcd3 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGrid.vue" @@ -0,0 +1,806 @@ +<template> + <div class="layout-container"> + <a :href="exportHref" ref="export"></a> + <!--寮�鍚噿鍔犺浇2020.12.06 --> + <vol-box + :on-model-close="closeCustomModel" + v-model="viewModel" + :height="520" + :width="500" + :padding="0" + :lazy="true" + title="璁剧疆" + > + <template #content> + <custom-column :view-columns="viewColumns"></custom-column> + </template> + <template #footer> + <div style="text-align: center"> + <el-button type="default" size="small" @click="closeCustomModel" + ><i class="el-icon-close"></i>鍙栨秷</el-button + > + <el-button type="success" size="small" @click="initViewColumns(true)" + ><i class="el-icon-refresh"></i>閲嶇疆</el-button + > + <el-button type="primary" size="small" @click="saveColumnConfig" + ><i class="el-icon-check"></i>纭畾</el-button + > + </div> + </template> + </vol-box> + <ViewGridAudit @auditClick="saveAudit" :option="table" ref="audit"> + + </ViewGridAudit> + <!--寮�鍚噿鍔犺浇2020.12.06 --> + <!--瀹℃牳(寮傛鐐瑰嚮鎸夐挳鏃舵墠鍔犺浇寰呭畬)--> + <!-- <vol-box + v-model="auditParam.model" + :height="auditParam.height" + :width="750" + :lazy="true" + :padding="0" + title="瀹℃壒" + > + <template #content> + <el-tabs type="card"> + <el-tab-pane label="褰撳墠瀹℃壒"> + <div class="v-steps"> + <div + :class="{ 'step-current': item.isCurrent }" + class="step-item" + v-for="(item, index) in workFlowSteps" + :key="index" + > + <div class="left-item"> + <div>瀹℃壒鏃堕棿</div> + <div class="left-date">{{ item.auditDate || '寰呭鎵�' }}</div> + </div> + <div class="right-item"> + <div class="step-line"></div> + <i class="step-circle"></i> + <div class="step-title"> + {{ item.stepName }} + </div> + <div class="step-text">瀹℃壒浜猴細{{ item.auditor }}</div> + <div class="step-text"> + 鐘� 鎬侊細 {{ getAuditStatus(item.auditStatus) }} + </div> + <div class="step-text">澶� 娉細 {{ item.remark || '-' }}</div> + </div> + </div> + <div + :style="{ + 'margin-top': workFlowSteps.length ? '20px' : '-17px' + }" + class="audit-content" + v-show="auditParam.showAction" + > + <div style="margin-bottom:10px;"> + 瀹℃壒锛� + <el-radio-group + style="margin-left:15px" + v-model="auditParam.value" + > + <el-radio + v-for="item in auditParam.data" + :key="item.value" + :label="item.value" + > + <span>{{ item.text }}</span> + </el-radio> + </el-radio-group> + </div> + + <el-input + v-model="auditParam.reason" + type="textarea" + style="margin-right: 13px;" + :autosize="{ minRows: 4, maxRows: 10 }" + placeholder="璇疯緭鍏ュ娉�..." + ></el-input> + </div> + </div> + </el-tab-pane> + <el-tab-pane v-if="workFlowSteps.length" label="瀹℃壒璁板綍"> + <audit-his :table-data="auditParam.auditHis"></audit-his> + </el-tab-pane> + </el-tabs> + </template> + <template #footer> + <div style="text-align: center;"> + <el-button size="small" @click="auditParam.model = false" + ><i class="el-icon-close"></i>鍏抽棴</el-button + > + <el-button + type="primary" + v-show="auditParam.showAction" + size="small" + @click="saveAudit" + ><i class="el-icon-check"></i>瀹℃牳</el-button + > + </div> + </template> + </vol-box> --> + + <!--瀵煎叆excel鍔熻兘--> + <!--2020.10.31娣诲姞瀵煎叆鍓嶇殑鏂规硶--> + <!--寮�鍚噿鍔犺浇2020.12.06 --> + <!-- 2022.01.08澧炲姞鏄庣粏琛ㄥ鍏ュ垽鏂� --> + <vol-box + v-if="upload.url" + v-model="upload.excel" + :height="350" + :width="600" + :lazy="true" + :title="(boxModel ? detailOptions.cnName : table.cnName) + '-瀵煎叆'" + > + <UploadExcel + ref="upload_excel" + @importExcelAfter="importExcelAfter" + :importExcelBefore="importExcelBefore" + :url="upload.url" + :template="upload.template" + ></UploadExcel> + </vol-box> + <!--澶撮儴鑷畾涔夌粍浠�--> + <component + :is="dynamicComponent.gridHeader" + ref="gridHeader" + @parentCall="parentCall" + ></component> + <!--涓荤晫闈㈡煡璇笌table琛ㄥ崟甯冨眬--> + <div class="view-container"> + <!-- 2020.09.11澧炲姞鍥哄畾鏌ヨ琛ㄥ崟 --> + <!--鏌ヨ鏉′欢--> + <div class="grid-search"> + <div + :class="[fiexdSearchForm ? 'fiexd-search-box' : 'search-box']" + v-show="searchBoxShow" + > + <!-- 2020.09.13澧炲姞formFileds鎷煎啓閿欒鍏煎澶勭悊 --> + <vol-form + ref="searchForm" + :load-key="false" + style="padding: 0 15px" + :label-width="labelWidth" + :formRules="searchFormOptions" + :formFields="searchFormFields" + :select2Count="select2Count" + > + <template #footer> + <div v-if="!fiexdSearchForm" class="form-closex"> + <el-button size="small" type="primary" plain @click="search"> + <i class="el-icon-search" />鏌ヨ + </el-button> + + <el-button + size="small" + type="success" + plain + @click="resetSearch" + > + <i class="el-icon-refresh-right" />閲嶇疆 + </el-button> + <el-button + size="small" + plain + @click="searchBoxShow = !searchBoxShow" + > + <i class="el-icon-switch-button" />鍏抽棴 + </el-button> + </div> + </template> + </vol-form> + <div v-if="fiexdSearchForm" class="fs-line"></div> + </div> + <div class="view-header"> + <div class="desc-text"> + <i class="el-icon-s-grid" /> + <span>{{ table.cnName }}</span> + </div> + <div class="notice"> + <a class="text" :title="extend.text">{{ extend.text }}</a> + </div> + <!--蹇�熸煡璇㈠瓧娈�--> + <div class="search-line" v-if="!fiexdSearchForm"> + <QuickSearch + v-if="singleSearch" + :singleSearch="singleSearch" + :searchFormFields="searchFormFields" + :tiggerPress="quickSearchKeyPress" + ></QuickSearch> + </div> + <!--鎿嶄綔鎸夐挳缁�--> + <!-- 2020.11.29澧炲姞鏌ヨ鐣岄潰hidden灞炴�� --> + + <div class="btn-group"> + <template + :key="bIndex" + v-for="(btn, bIndex) in buttons.slice(0, maxBtnLength)" + > + <el-dropdown size="small" v-if="btn.data" :split-button="false"> + <el-button + :color="btn.color" + :dark="false" + :type="btn.type" + :plain="btn.plain" + > + {{ btn.name }}<i class="el-icon-arrow-down el-icon--right"></i + ></el-button> + <template #dropdown> + <el-dropdown-menu> + <el-dropdown-item + v-for="(item, index) in btn.data" + :key="index" + > + <div @click="onClick(item.onClick)"> + <i :class="item.icon"></i> + {{ item.name }} + </div> + </el-dropdown-item> + </el-dropdown-menu> + </template> + </el-dropdown> + <el-button + v-else + :type="btn.type" + size="small" + :color="btn.color" + :dark="false" + :class="btn.class" + :plain="btn.plain" + v-show="!btn.hidden" + @click="onClick(btn.onClick)" + > + <i :class="btn.icon"></i> {{ btn.name }} + </el-button> + </template> + <!-- 璁剧疆鍒楁寜閽� --> + <el-button + type="default" + style="padding: 0px 10px" + size="small" + :plain="true" + v-if="showCustom" + @click="showCustomModel" + > + <i class="el-icon-s-grid"></i> + </el-button> + <el-dropdown + size="small" + @click="changeDropdown" + v-if="buttons.length > maxBtnLength" + > + <el-button type="primary" plain size="small"> + 鏇村<i class="el-icon-arrow-down el-icon--right"></i> + </el-button> + <template #dropdown> + <el-dropdown-menu> + <el-dropdown-item + @click="changeDropdown(item.name)" + :name="item.name" + v-show="!item.hidden" + v-for="(item, dIndex) in buttons.slice( + maxBtnLength, + buttons.length + )" + :key="dIndex" + > + <i :class="item.icon"></i> {{ item.name }}</el-dropdown-item + > + </el-dropdown-menu> + </template> + </el-dropdown> + </div> + </div> + + <!-- 鍒嗗壊浣嶇疆 --> + <vol-box + v-if="boxInit" + v-model="boxModel" + :title="boxOptions.title" + :width="boxOptions.width" + :height="boxOptions.height" + :modal="boxOptions.modal" + :draggable="boxOptions.draggable" + :padding="0" + :on-model-close="onGridModelClose" + @fullscreen="fullscreen" + > + <!--鏄庣粏澶撮儴鑷畾涔夌粍浠�--> + <template #content> + <div class="box-com"> + <component + :is="dynamicComponent.modelHeader" + ref="modelHeader" + @parentCall="parentCall" + ></component> + <!-- <div v-show="isBoxAudit" class="flow-step"> + <div v-for="(item, index) in workFlowSteps" :key="index"> + {{ item.stepName }} + </div> + </div> --> + <div class="item form-item"> + <vol-form + ref="form" + :editor="editor" + :load-key="false" + :label-width="boxOptions.labelWidth" + :formRules="editFormOptions" + :formFields="editFormFields" + :select2Count="select2Count" + ></vol-form> + </div> + <!--鏄庣粏body鑷畾涔夌粍浠�--> + <component + :is="dynamicComponent.modelBody" + ref="modelBody" + @parentCall="parentCall" + ></component> + <div + v-show="hasDetail" + v-if="detail.columns && detail.columns.length > 0" + class="grid-detail table-item item" + > + <div class="toolbar"> + <div class="title form-text"> + <span> + <i class="el-icon-menu" /> + {{ detail.cnName }} + </span> + </div> + <!--鏄庣粏琛ㄦ牸鎸夐挳--> + <div class="btns" v-show="!isBoxAudit"> + <el-button + v-for="(btn, bIndex) in detailOptions.buttons" + :key="bIndex" + :plain="btn.plain" + v-show="!(typeof btn.hidden == 'boolean' && btn.hidden)" + @click="onClick(btn.onClick)" + size="small" + ><i :class="btn.icon"></i>{{ btn.name }}</el-button + > + </div> + </div> + <vol-table + ref="detail" + @loadBefore="loadInternalDetailTableBefore" + @loadAfter="loadDetailTableAfter" + @rowChange="detailRowOnChange" + @rowClick="detailRowOnClick" + :url="detailOptions.url" + :load-key="false" + :index="true" + :tableData="detailOptions.data" + :columns="detailOptions.columns" + :pagination="detailOptions.pagination" + :height="detailOptions.height" + :single="detailOptions.single" + :pagination-hide="false" + :defaultLoadPage="detailOptions.load" + :beginEdit="detailOptions.beginEdit" + :endEditBefore="detailOptions.endEditBefore" + :endEditAfter="detailOptions.endEditAfter" + :summary="detailOptions.summary" + :click-edit="detailOptions.clickEdit" + :double-edit="detailOptions.doubleEdit" + :column-index="detailOptions.columnIndex" + :ck="detailOptions.ck" + :text-inline="detailOptions.textInline" + :select2Count="select2Count" + :selectable="detailSelectable" + ></vol-table> + </div> + <!--鏄庣粏footer鑷畾涔夌粍浠�--> + <component + :is="dynamicComponent.modelFooter" + ref="modelFooter" + @parentCall="parentCall" + ></component> + </div> + </template> + <template #footer> + <div style="text-align: center;" v-show="isBoxAudit"> + <el-button + size="small" + type="primary" + plain + @click="onGridModelClose(false)" + > + <i class="el-icon-close">鍏抽棴</i> + </el-button> + <el-button + size="small" + type="primary" + v-show="auditParam.showViewButton" + @click="auditParam.model = true" + > + <i class="el-icon-view">瀹℃壒</i> + </el-button> + </div> + <div v-show="!isBoxAudit"> + <el-button + v-for="(btn, bIndex) in boxButtons" + :key="bIndex" + :type="btn.type" + size="small" + :plain="btn.plain" + v-show="!(typeof btn.hidden == 'boolean' && btn.hidden)" + :disabled="btn.hasOwnProperty('disabled') && !!btn.disabled" + @click="onClick(btn.onClick)" + > + <i :class="btn.icon"> {{ btn.name }}</i> + </el-button> + <el-button + size="small" + type="primary" + plain + @click="onGridModelClose(false)" + > + <i class="el-icon-close">鍏抽棴</i> + </el-button> + </div> + </template> + </vol-box> + </div> + <!--body鑷畾涔夌粍浠�--> + <div class="grid-body"> + <component + :is="dynamicComponent.gridBody" + ref="gridBody" + @parentCall="parentCall" + ></component> + </div> + + <!--table琛ㄦ牸--> + <div class="grid-container"> + <!-- 2021.05.02澧炲姞鏍戝舰缁撴瀯 rowKey --> + <vol-table + ref="table" + :single="single" + :rowKey="rowKey" + :loadTreeChildren="loadTreeTableChildren" + @loadBefore="loadTableBefore" + @loadAfter="loadTableAfter" + @rowChange="rowOnChange" + @rowClick="rowOnClick" + @rowDbClick="rowOnDbClick" + :tableData="[]" + :linkView="linkData" + :columns="columns" + :pagination="pagination" + :height="height" + :max-height="tableMaxHeight" + :pagination-hide="false" + :url="url" + :load-key="false" + :defaultLoadPage="load" + :summary="summary" + :double-edit="doubleEdit" + :index="doubleEdit" + :beginEdit="tableBeginEdit" + :endEditBefore="tableEndEditBefore" + :click-edit="true" + :column-index="columnIndex" + :text-inline="textInline" + :ck="ck" + :select2Count="select2Count" + :selectable="selectable" + ></vol-table> + </div> + </div> + + <!--footer鑷畾涔夌粍浠�--> + <component + :is="dynamicComponent.gridFooter" + ref="gridFooter" + @parentCall="parentCall" + ></component> + </div> +</template> + +<script> +const _const = { + EDIT: 'update', + ADD: 'Add', + VIEW: 'view', + PAGE: 'getPageData', + AUDIT: 'audit', + DEL: 'del', + EXPORT: 'Export', //瀵煎嚭鎿嶄綔杩斿洖鍔犲瘑鍚庣殑璺緞 + DOWNLOAD: 'DownLoadFile', //瀵煎嚭鏂囦欢 + DOWNLOADTEMPLATE: 'DownLoadTemplate', //涓嬭浇瀵煎叆妯℃澘 + IMPORT: 'Import', //瀵煎叆(瀵煎叆琛ㄧ殑Excel鍔熻兘) + UPLOAD: 'Upload' //涓婁紶鏂囦欢 +}; +import Empty from '@/components/basic/Empty.vue'; + +import VolTable from '@/components/basic/VolTable.vue'; +import VolForm from '@/components/basic/VolForm.vue'; +import { + defineAsyncComponent, + defineComponent, + ref, + shallowRef, + toRaw +} from 'vue'; +var vueParam = { + components: { + 'vol-form': VolForm, + 'vol-table': VolTable, + VolBox: defineAsyncComponent(() => import('@/components/basic/VolBox.vue')), + QuickSearch: defineAsyncComponent(() => + import('@/components/basic/QuickSearch.vue') + ), + Audit: defineAsyncComponent(() => import('@/components/basic/Audit.vue')), + UploadExcel: defineAsyncComponent(() => + import('@/components/basic/UploadExcel.vue') + ), + 'custom-column': defineAsyncComponent(() => + import('./ViewGridCustomColumn.vue') + ), + 'vol-header': defineAsyncComponent(() => import('./../VolHeader.vue')), + ViewGridAudit: defineAsyncComponent(() => import('./ViewGridAudit.vue')) + }, + props: {}, + setup(props) { + //2021.07.17璋冩暣鎵╁睍缁勪欢缁勪欢 + const dynamicCom = { + gridHeader: Empty, + gridBody: Empty, + gridFooter: Empty, + modelHeader: Empty, + modelBody: Empty, + modelFooter: Empty + }; + //鍚堝苟鎵╁睍缁勪欢 + if (props.extend.components) { + for (const key in props.extend.components) { + if (props.extend.components[key]) { + dynamicCom[key] = toRaw(props.extend.components[key]); + } + } + } + const dynamicComponent = shallowRef(dynamicCom); + return { dynamicComponent }; + }, + data() { + return { + isBoxAudit: false, + formFieldsType: [], + workFlowSteps: [], + //鏍戝舰缁撴瀯鐨勪富閿瓧娈碉紝濡傛灉璁剧疆鍊奸粯璁や細寮�鍚爲褰able锛涙敞鎰弐owKey瀛楁鐨勫�煎繀椤绘槸鍞竴锛�2021.05.02锛� + rowKey: undefined, + fiexdSearchForm: false, //2020.09.011鏄惁鍥哄畾鏌ヨ琛ㄥ崟锛宼rue鏌ヨ琛ㄥ崟灏嗗浐瀹氭樉绀哄湪琛ㄥ崟鐨勬渶涓婇潰 + _inited: false, + doubleEdit: false, //2021.03.19鏄惁寮�鍚煡璇㈢晫闈㈣〃鏍煎弻鍑荤紪杈� + single: false, //琛ㄦ槸鍚﹀崟閫� + const: _const, //澧炲垹鏀规煡瀵煎叆瀵煎嚭绛夊搴旂殑action + boxInit: false, //鏂板缓鎴栫紪杈戠殑寮瑰嚭妗嗗垵鍖栫姸鎬侊紝榛樿涓嶅仛鍒濆鍖栵紝鐐瑰嚮鏂板缓鎴栫紪杈戞墠鍒濆鍖栧脊鍑烘 + searchBoxShow: false, //楂樼骇鏌ヨ(鐣岄潰鏌ヨ鍚庣殑涓嬫媺妗嗙偣鍑昏Е鍙�) + singleSearch: {}, //蹇�熸煡璇㈠瓧娈� + exportHref: '', + currentAction: _const.ADD, //褰撴柊寤烘垨缂栬緫鏃讹紝璁板綍褰撳墠鐨勭姸鎬�:濡傚綋鍓嶆搷浣滄槸鏂板缓 + currentRow: {}, //褰撳墠缂栬緫鎴栨煡鐪嬫暟鎹殑琛� + closable: false, + boxModel: false, //寮瑰嚭鏂板缓銆佺紪杈戞 + width: 700, //寮瑰嚭妗嗘煡鐪嬭〃鏁版嵁缁撴瀯 + labelWidth: 100, //楂樼骇鏌ヨ鐨勬爣绛惧搴� + viewModel: false, //鏌ョ湅琛ㄧ粨鏋勭殑寮瑰嚭妗� + viewColumns: [], //鏌ョ湅琛ㄧ粨鏋勭殑鍒楁暟鎹� + viewColumnsClone: [], + showCustom: true, //鏄惁鏄剧ず鑷畾涔夐厤缃垪鎸夐挳2022.05.27 + // viewData: [], //鏌ョ湅琛ㄧ粨鏋勪俊鎭� + maxBtnLength: 8, //鐣岄潰鎸夐挳鏈�澶氭樉绀虹殑涓暟锛岃秴杩囩殑鏁伴噺閮芥樉绀哄湪鏇村涓� + buttons: [], //鏌ヨ鐣岄潰鎸夐挳 濡傞渶瑕佸叾浠栨搷浣滄寜閽紝鍙湪琛ㄥ搴旂殑.js涓坊鍔�(濡�:Sys_User.js涓璪uttons娣诲姞鍏朵粬鎸夐挳) + splitButtons: [], + uploadfiled: [], //涓婁紶鏂囦欢鍥剧墖鐨勫瓧娈� + boxButtons: [], //寮瑰嚭妗嗘寜閽� 濡傞渶瑕佸叾浠栨搷浣滄寜閽紝鍙湪琛ㄥ搴旂殑.js涓坊鍔� + dicKeys: [], //褰撳墠鐣岄潰鎵�鏈夌殑涓嬫媺妗嗗瓧鍏哥紪鍙峰強鏁版嵁婧� + hasKeyField: [], //鏈夊瓧鍏告暟鎹簮鐨勫瓧娈� + keyValueType: { _dinit: false }, + url: '', //鐣岄潰琛ㄦ煡璇㈢殑鏁版嵁婧愮殑url + hasDetail: false, //鏄惁鏈変粠琛�(鏄庣粏)琛ㄦ牸鏁版嵁 + initActivated: false, + load: true, //鏄惁榛樿鍔犺浇琛ㄦ暟鎹� + activatedLoad: false, //椤甸潰瑙﹀彂actived鏃舵槸鍚﹀埛鏂伴〉闈㈡暟鎹� + summary: false, //鏌ヨ鐣岄潰table鏄惁鏄剧ず鍚堣 + //闇�瑕佷粠杩滅▼缁戝畾鏁版嵁婧愮殑瀛楀吀缂栧彿,濡傛灉瀛楀吀鏁版嵁婧愮殑鏌ヨ缁撴灉杈冨锛岃鍦╫nInit涓皢瀛楀吀缂栧彿娣诲姞杩涙潵 + //鍙鑷畾sql鏈夋晥 + remoteKeys: [], + columnIndex: true, //2020.11.01鏄惁鏄剧ず琛屽彿 + ck: true, //2020.11.01鏄惁鏄剧ずcheckbox + continueAdd: false, //2021.04.11鏂板缓鏃舵槸鍚﹀彲浠ヨ繛缁柊寤烘搷浣� + continueAddName: '淇濆瓨鍚庣户缁坊鍔�', //2021.04.11鎸夐挳鍚嶇О + // detailUrl: "", + detailOptions: { + //寮瑰嚭妗嗕粠琛�(鏄庣粏)瀵硅薄 + //浠庤〃閰嶇疆 + buttons: [], //寮瑰嚭妗嗕粠琛ㄨ〃鏍兼搷浣滄寜閽�,鐩墠鏈夊垹闄よ锛屾坊鍔犺锛屽埛鏂版搷浣滐紝濡傞渶瑕佸叾浠栨搷浣滄寜閽紝鍙湪琛ㄥ搴旂殑.js涓坊鍔� + cnName: '', //浠庤〃鍚嶇О + key: '', //浠庤〃涓婚敭鍚� + data: [], //鏁版嵁婧� + columns: [], //浠庤〃鍒椾俊鎭� + edit: true, //鏄庣粏鏄惁鍙互缂栬緫 + single: false, //鏄庣粏琛ㄦ槸鍚﹀崟閫� + load: false, // + delKeys: [], //褰撶紪杈戞椂鍒犻櫎褰撳墠鏄庣粏鐨勮涓婚敭鍊� + url: '', //浠庤〃鍔犺浇鏁版嵁鐨剈rl + pagination: { total: 0, size: 100, sortName: '' }, //浠庤〃鍒嗛〉閰嶇疆鏁版嵁 + height: 0, //榛樿浠庤〃楂樺害 + textInline: true, //鏄庣粏琛ㄨ鍐呭鏄剧ず鍦ㄤ竴琛屼笂锛屽鏋滈渶瑕佹崲琛屾樉绀猴紝璇疯缃负false + doubleEdit: true, //浣跨敤鍙屽嚮缂栬緫 + clickEdit: false, //鏄惁寮�鍚偣鍑诲崟鍏冩牸缂栬緫锛岀偣鍑诲叾浠栬鏃剁粨鏉熺紪杈� + currentReadonly: false, //褰撳墠鐢ㄦ埛娌℃湁缂栬緫鎴栨柊寤烘潈闄愭椂锛岃〃鍗曞彧璇�(鍙敤浜庡垽鏂敤鎴锋槸鍚︽湁缂栬緫鎴栨柊寤烘潈闄�) + //寮�鍚紪杈戞椂 + beginEdit: (row, column, index) => { + return true; + }, + //缁撴潫缂栬緫鍓� + endEditBefore: (row, column, index) => { + return true; + }, + //缁撴潫缂栬緫鍚� + endEditAfter: (row, column, index) => { + return true; + }, + columnIndex: false, //2020.11.01鏄庣粏鏄惁鏄剧ず琛屽彿 + ck: true //2020.11.01鏄庣粏鏄惁鏄剧ずcheckbox + }, + auditParam: { + //瀹℃牳瀵硅薄 + rows: 0, //褰撳墠閫変腑瀹℃牳鐨勮鏁� + model: false, //瀹℃牳寮瑰嚭妗� + value: -1, //瀹℃牳缁撴灉 + status: -1, + reason: '', //瀹℃牳鍘熷洜 + height: 500, + showViewButton: true, + auditHis: [], + showAction: false, //鏄惁鏄剧ず瀹℃壒鎿嶄綔(褰撳墠鑺傜偣涓虹敤鎴峰鎵规椂鏄剧ず) + //瀹℃牳閫夐」(鍙嚜琛屽啀娣诲姞) + data: [ + { text: '閫氳繃', value: 1 }, + { text: '鎷掔粷', value: 2 }, + { text: '椹冲洖', value: 3 } + ] + }, + upload: { + //瀵煎叆涓婁紶excel瀵硅薄 + excel: false, //瀵煎叆鐨勫脊鍑烘鏄惁鏄剧ず + url: '', //瀵煎叆鐨勮矾寰�,濡傛灉娌℃湁鍊硷紝鍒欎笉娓叉煋瀵煎叆鍔熻兘 + template: { + //涓嬭浇妯℃澘瀵硅薄 + url: '', //涓嬭浇妯℃澘璺緞 + fileName: '' //妯℃澘涓嬭浇鐨勪腑鏂囧悕 + }, + init: false //鏄惁鏈夊鍏ユ潈闄愶紝鏈夋墠娓叉煋瀵煎叆缁勪欢 + }, + height: 0, //琛ㄩ珮搴� + tableHeight: 0, //鏌ヨ椤甸潰table鐨勯珮搴� + tableMaxHeight: 0, //鏌ヨ椤甸潰table鐨勬渶澶ч珮搴� + textInline: true, //table鍐呭瓒呭嚭鍚庢槸鍚︿笉鎹㈣2020.01.16 + pagination: { total: 0, size: 30, sortName: '' }, //浠庡垎椤甸厤缃暟鎹� + boxOptions: { + title: '', //寮瑰嚭妗嗘樉绀虹殑鏍囬2022.08.01 + saveClose: true, + labelWidth: 100, + height: 0, + width: 0, + summary: false, //寮瑰嚭妗嗘槑缁唗able鏄惁鏄剧ず鍚堣 + draggable: false, //2022.09.12寮瑰嚭妗嗘嫋鍔ㄥ姛鑳� + modal: true //2022.09.12寮瑰嚭妗嗚儗鏅伄缃╁眰 + }, //saveClose鏂板缓鎴栫紪杈戞垚鍔熷悗鏄惁鍏抽棴寮瑰嚭妗�//寮瑰嚭妗嗙殑鏍囩瀹藉害labelWidth + editor: { + uploadImgUrl: '', //涓婁紶璺緞 + upload: null //涓婁紶鏂规硶 + }, + numberFields: [], + //2022.09.26澧炲姞鑷畾涔夊鍑烘枃浠跺悕 + downloadFileName: null, + select2Count: 500 //瓒呭嚭500鏁伴噺鏄剧ずselect2缁勪欢 + }; + }, + methods: {}, + activated() { + this.initFlowQuery(); + //2020.06.25澧炲姞activated鏂规硶 + this.onActivated && this.onActivated(); + if (!this._inited) { + this._inited = true; + return; + } + if (this.activatedLoad) { + this.refresh(); + } + }, + mounted() { + this.mounted(); + // this.$refs.searchForm.forEach() + }, + unmounted() { + this.destroyed(); + }, + created: function() { + //鍚堝苟鑷畾涔変笟鍔℃墿灞曟柟娉� + Object.assign(this, this.extend.methods); + //濡傛灉娌℃湁鎸囧畾鎺掑簭瀛楁锛屽垯鐢ㄤ富閿綔涓洪粯璁ゆ帓搴忓瓧娈� + this.pagination.sortName = this.table.sortName || this.table.key; + this.initBoxButtons(); //鍒濆鍖栧脊鍑烘涓庢槑缁嗚〃鏍兼寜閽� + this.initAuditColumn(); + this.onInit(); //鍒濆鍖栧墠锛屽鏋滈渶瑕佸仛鍏朵粬澶勭悊鍦ㄦ墿灞曟柟娉曚腑瑕嗙洊姝ゆ柟娉� + this.getButtons(); + //鍒濆鍖栬嚜瀹氫箟琛ㄦ牸鍒� + this.initViewColumns(); + //鍒濆缂栬緫妗嗙瓑鏁版嵁 + this.initBoxHeightWidth(); + this.initDicKeys(); //鍒濆涓嬫鏁版嵁婧� + this.onInited(); //鍒濆鍖栧悗锛屽鏋滈渶瑕佸仛鍏朵粬澶勭悊鍦ㄦ墿灞曟柟娉曚腑瑕嗙洊姝ゆ柟娉� + }, + beforeUpdate: function() {}, + updated: function() {} +}; + +import props from './props.js'; +import methods from './methods.js'; + +//鍚堝苟灞炴�� +vueParam.props = Object.assign(vueParam.props, props); +//鍚堝苟鏂规硶 +vueParam.methods = Object.assign( + vueParam.methods, + methods, + props.extend.methods +); +export default defineComponent(vueParam); +</script> +<style lang="less" scoped> +@import './ViewGrid.less'; +</style> +<style lang="less" scoped> +.btn-group ::v-deep(.ivu-select-dropdown) { + padding: 0px !important; + right: 3px; +} + +.btn-group ::v-deep(.ivu-select-dropdown .ivu-dropdown-menu) { + min-width: 100px; + right: -2px; + position: absolute; + background: white; + width: 130px; + border-radius: 5px; + border: 1px solid #e7e5e5; +} + +.vertical-center-modal ::v-deep(.srcoll-content) { + padding: 0; +} + +.view-model-content { + background: #eee; +} + +.grid-detail ::v-deep(.v-table .el-table__header th) { + height: 44px; +} +</style> +<style lang="less" scoped> +.grid-search { + position: relative; + + .search-box { + background: #fefefe; + margin-top: 33px; + border: 1px solid #eae8e8; + position: absolute; + z-index: 999; + left: 15px; + right: 15px; + padding: 25px 20px; + padding-bottom: 0; + border-top: 0; + box-shadow: 0 7px 18px -12px #bdc0bb; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridAudit.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridAudit.vue" new file mode 100644 index 0000000..24cddc7 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridAudit.vue" @@ -0,0 +1,427 @@ +<template> + <vol-box :footer="false" v-model="model" :height="height" :width="width" :padding="0" :lazy="true" title="瀹℃牳"> + + <div class="audit-model-content" :style="{ height: height - 100 + 'px' }"> + <el-descriptions class="desc-top" :column="3" size="default" :border="true"> + <el-descriptions-item v-for="(item, index) in formData" :key="index"> + <template #label> + <div class="cell-item"> + {{ item.name }} + </div> + </template> + {{ item.value }} + </el-descriptions-item> + </el-descriptions> + <el-radio-group v-show="hasFlow" style="padding-left: 15px;" v-model="activeName" class="ml-4"> + <el-radio label="audit" size="large">瀹℃牳</el-radio> + <el-radio label="log" size="large">瀹℃牳璁板綍</el-radio> + </el-radio-group> + <div v-show="activeName == 'audit' || !hasFlow" class="audit-content"> + <div class="fx-left" v-if="hasFlow"> + <div class="v-steps"> + <div v-for="(item, index) in workFlowSteps" :key="index"> + <div class="step-item" :class="{'step-item-ad':item.auditId||item.stepAttrType=='start'}" v-if="item.stepAttrType == 'start'"> + <div class="left-item"> + <div>娴佺▼寮�濮�</div> + <div class="left-date">{{ item.createDate }}</div> + </div> + <div class="right-item"> + <div class="step-line"></div> + <i class="step-circle"></i> + <div class="step-title"> + {{ item.stepName }} + </div> + <div class="step-text">鍙戣捣浜猴細{{ item.creator }}</div> + </div> + </div> + <div class="step-item" v-else-if="item.stepAttrType == 'end'"> + <div class="left-item"> + <div>娴佺▼缁撴潫</div> + </div> + <div class="right-item"> + <div class="step-line"></div> + <i class="step-circle"></i> + <div class="step-title"> + {{ item.stepName }} + </div> + </div> + </div> + <div v-else :class="{ 'step-current': item.isCurrent }" class="step-item"> + <div class="left-item"> + <div>瀹℃壒鏃堕棿</div> + <div class="left-date">{{ item.auditDate || '寰呭鎵�' }}</div> + </div> + <div class="right-item"> + <div class="step-line"></div> + <i class="step-circle"></i> + <div class="step-title"> + {{ item.stepName }} + </div> + <div class="step-text">瀹℃壒浜猴細{{ item.auditor }}</div> + <div class="step-text"> + 鐘� 鎬侊細 {{ getAuditStatus(item.auditStatus) }} + </div> + <div class="step-text">澶� 娉細 {{ item.remark || '-' }}</div> + </div> + </div> + </div> + </div> + </div> + <div class="fx-right" :style="{ width: !hasFlow ? '100%' : '400px' }" v-if="isCurrentUser || !hasFlow"> + + <div v-if="!hasFlow"> + <el-alert :title="'褰撳墠閫変腑銆�' + rowLen + '銆戞潯璁板綍寰呭鏍�..'" type="success" :closable="false" /> + </div> + <div class="rd"> + <span>瀹℃壒锛�</span> + <el-radio-group style="margin-left:15px" v-model="auditParam.value"> + <el-radio v-for="item in auditParam.data" :key="item.value" :label="item.value"> + <span>{{ item.text }}</span> + </el-radio> + </el-radio-group> + </div> + <el-input style="padding-top: 10px;" v-model="auditParam.reason" type="textarea" + :autosize="{ minRows: 4, maxRows: 10 }" placeholder="璇疯緭鍏ュ娉�..."></el-input> + <div class="btn"> + <el-button type="primary" @click="auditClick" icon="Check">瀹℃壒</el-button> + </div> + </div> + </div> + <div v-show="activeName == 'log'"> + <vol-table :tableData="tableData" :columns="columns" :height="height - 250" :pagination-hide="true" + :load-key="false" :text-inline="false" :ck="false"></vol-table> + </div> + </div> + </vol-box> +</template> +<script> +import VolTable from '@/components/basic/VolTable.vue'; +import VolBox from '@/components/basic/VolBox.vue'; +import http from '@/../src/api/http.js'; +import { defineComponent, ref, reactive, getCurrentInstance } from 'vue'; +export default defineComponent({ + components: { + VolTable, + VolBox + }, + props: { + option: { //鐢熸垚vue鏂囦欢鐨則able鍙傛暟 + type: Object, + default: { + key: '', + cnName: '', + name: '', + url: "" + } + } + }, + setup(props, { emit }) { + const height = ref(500); + const width = ref(820); + const model = ref(false) + const workFlowSteps = reactive([]); + + const hasFlow = ref(false) + const formData = reactive([]); + + const auditParam = reactive({ + //瀹℃牳瀵硅薄 + rows: 0, //褰撳墠閫変腑瀹℃牳鐨勮鏁� + model: false, //瀹℃牳寮瑰嚭妗� + value: -1, //瀹℃牳缁撴灉 + reason: '', //瀹℃牳鍘熷洜 + //瀹℃牳閫夐」(main.js閲岄潰鍙互娣诲姞鍏朵粬閫夐」) + data: [] + }) + const { proxy } = getCurrentInstance(); + auditParam.data = proxy.$global.audit.data; + const tableData = reactive([]); + const columns = reactive([ + { title: '鑺傜偣', field: 'stepName', width: 100 }, + { title: '瀹℃壒浜�', field: 'auditor', width: 80 }, + { title: '瀹℃壒缁撴灉', field: 'auditStatus', width: 70, bind: { data: [] } }, + { title: '瀹℃壒鏃堕棿', field: 'auditDate', width: 145 }, + { title: '澶囨敞', field: 'remark', width: 120 } + ]); + + const isCurrentUser = ref(null); + const activeName = ref('audit') + + const auditDic = reactive([]); + const getAuditStatus = (key) => { + return (auditDic.find(x => { return x.key === key + '' }) || { value: key }).value; + } + const rowLen = ref(0) + let currentRows = [] + const getAuditInfo = (option) => { + const table = option.table; //props.option.url.replaceAll('/', ''); + const url = `api/Sys_WorkFlow/getSteps?tableName=${table}` + // let ids = currentRows.map(x => { return x[props.option.key] }); + let ids = currentRows.map(x => { return x[option.key] }); + // ['498043c1-fbd0-4a35-a870-523823912a9b'] + http.post(url, ids, true).then(result => { + if (!result.status) { + proxy.$message.error(result.message); + return; + } + + hasFlow.value = !!(result.list || []).length; + if (!hasFlow.value) { + + let auditStatus = Object.keys(currentRows[0]).find(x => { return x.toLowerCase() === 'auditstatus' }); + + let checkStatus = currentRows.every((x) => { + return proxy.$global.audit.status.some(c => { return c === x[auditStatus] || !x[auditStatus] }) + }); + if (!checkStatus) { + proxy.$message.error('鍙兘閫夋嫨寰呭鎵规垨瀹℃牳涓殑鏁版嵁'); + return; + } + rowLen.value = currentRows.length; + model.value = true; + width.value = 430; + height.value = 330; + isCurrentUser.value = true; + //娌℃湁瀹℃壒娴佺▼鐨勬暟鎹彧鏄剧ず + return; + } + model.value = true; + height.value = document.body.clientHeight * 0.95; + width.value = 820; + if (!auditDic.length) { + auditDic.push(...(result.auditDic || [])) + columns.forEach(item => { + if (item.field == 'auditStatus') { + item.bind.data = auditDic; + } + }) + } + isCurrentUser.value = result.list.some(x => { return x.isCurrentUser }) + workFlowSteps.length = 0; + workFlowSteps.push(...result.list); + tableData.length = 0; + tableData.push(...result.log) + formData.length = 0; + formData.push(...(result.form || [])) + }) + } + // + + const auditClick = () => { + if (auditParam.value == -1) { + proxy.$message.error('璇烽�夋嫨瀹℃壒椤�'); + return; + } + + if (!isFlow.value) { + emit("auditClick", auditParam, currentRows, (result) => { + if (result.status) { + model.value = false; + tableData.length = 0; + } + }); + return; + } + //鎴戠殑娴佺▼涓偣鍑诲鎵� + //淇濆瓨瀹℃牳 + let keys = currentRows.map(x => { return x[currentOption.key] }); + let url = `api/${currentOption.table}/audit?auditReason=${auditParam.reason}&auditStatus=${auditParam.value}` + http.post(url, keys, '瀹℃牳涓�....').then((x) => { + if (!x.status) { + proxy.$message.error(x.message); + return; + } + model.value = false; + proxy.$parent.search() + proxy.$message.success(x.message) + }); + } + const isFlow = ref(false); + let currentOption = {}; + const open = (rows, flow) => { + isFlow.value = !!flow; + currentRows = rows; + activeName.value = 'audit' + auditParam.reason = ''; + auditParam.value = -1; + + if (flow) { + currentOption = { + table: rows[0].WorkTable, + key: "WorkTableKey"// rows[0].WorkTableKey + } + } else { + currentOption = { + table: props.option.url.replaceAll('/', ''), + key: props.option.key + } + } + getAuditInfo(currentOption); + + } + + return { + columns, + height, + width, + model, + workFlowSteps, + getAuditInfo, + getAuditStatus, + activeName, + reactive, + tableData, + auditParam, + auditClick, + open, + isCurrentUser, + hasFlow, + rowLen, + formData, + isFlow + } + } +}); +</script> + +<style lang="less" scoped> +.audit-model-content { + padding: 10px; +} + +.step-item { + background: #fff; + display: flex; +} + +.left-item { + min-width: 180px; + text-align: right; + padding-right: 25px; + padding-top: 8px; + + .left-date { + font-size: 13px; + padding-top: 7px; + color: #6c6c6c; + } +} + +.right-item { + cursor: pointer; + position: relative; + border-bottom: 1px solid #f3f3f3; + padding: 5px 0 5px 5px; +} + +.left-item, +.right-item { + padding-bottom: 10px; +} + +.right-item:last-child { + border-bottom: 0; +} + +.step-line { + top: 16px; + left: -10px; + width: 1px; + height: 100%; + position: absolute; + background-color: #ebedf0; +} + +.step-circle { + position: absolute; + top: 17px; + left: -9px; + z-index: 2; + font-size: 12px; + line-height: 1; + transform: translate(-50%, -50%); + width: 7px; + height: 7px; + background-color: #a1a1a1; + border-radius: 50%; +} + +.right-item::before { + content: ''; +} + +.step-content { + padding-top: 2px; + font-size: 14px; + color: #828282; + line-height: 1.5; +} + +.step-title { + font-weight: bold; + padding-top: 3px; +} + +.step-text { + font-size: 13px; + color: #999999; + padding-top: 6px; +} + +.step-current { + * { + color: #2f95ff !important; + } + + .step-circle { + background: #2f95ff !important; + } + + // border-radius: 5px; + // border: 1px solid #d6eaff; + font-size: 13px; + padding-top: 6px; + // background-color: #eff7ffd9; + color: black; +} + +.audit-content { + // background: #f9f9f9; + padding: 10px; + border-radius: 4px; + display: flex; + + .fx-left { + flex: 1; + width: 0; + + .rd { + display: flex; + align-items: baseline; + } + } + + .fx-right { + // width: 400px; + + .btn { + margin-top: 10px; + text-align: center; + } + } + +} + +.cell-item { + font-weight: 500; +} + +.desc-top { + padding: 5px 10px 0 10px; +} +.step-item-ad{ + *{ + color: #9f9898 !important; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridCustomColumn.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridCustomColumn.js" new file mode 100644 index 0000000..16a49e0 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridCustomColumn.js" @@ -0,0 +1,151 @@ +export default { + initViewColumns(isReset) { + //鍒濆鍖栬嚜瀹氬垪閰嶇疆 + if (isReset) { + this.resetViewColumns(); + } + if (!this.orginColumnFields) { + this.orginColumnFields = this.columns.map((c) => { + return c.field; + }); + } + this.viewColumns = this.columns + .filter((c) => { + return !c.hidden && !c.render; + }) + .map((c) => { + return { field: c.field, title: c.title, show: !c.hidden }; + }); + if (isReset) { + return; + } + this.getCacheViewColumn(); + }, + getViewCacheKey(){ + return 'custom:column'+this.table.name; + }, + getCacheViewColumn() { + try { + let columns = localStorage.getItem(this.getViewCacheKey()); + if (!columns) return; + columns = JSON.parse(columns); + if (columns.some(x=>{return !this.viewColumns.some(c=> {return c.field==x.field})})|| + this.viewColumns.some(x=>{return !columns.some(c=> {return c.field==x.field})}) + ) { + localStorage.removeItem(this.getViewCacheKey()) + return; + } + let sortTableColumns = []; + //寮瑰嚭妗嗙殑鍒� + let _viewColumns = []; + columns.forEach((column) => { + let _column = this.viewColumns.find((c) => { + return c.field == column.field; + }); + if (_column) { + _column.show = column.show; + _viewColumns.push(_column); + } + let tableColumn = this.columns.find((c) => { + return c.field == column.field; + }); + if (tableColumn) { + tableColumn.hidden = !column.show; + sortTableColumns.push(tableColumn); + } + }); + //閲嶆柊鎺掔増寮瑰嚭妗嗚嚜瀹氫箟鍒� + let otherColumns = this.viewColumns.filter((c) => { + return !_viewColumns.some((s) => { + return c.field == s.field; + }); + }); + //閲嶆柊鎺掔増寮瑰嚭妗嗚嚜瀹氫箟鍒� + _viewColumns.push(...otherColumns); + this.viewColumns.splice(0); + this.viewColumns.push(..._viewColumns); + + this.sortViewColumns(sortTableColumns); + } catch (error) { + console.log('璁剧疆榛樿鑷畾涔夊垪寮傚父:' + error.message); + } + }, + sortViewColumns(sortColumns) { + if (sortColumns.length) { + let hiddenColumns = this.columns.filter((c) => { + return !sortColumns.some((s) => { + return c.field == s.field; + }); + }); + sortColumns.push(...hiddenColumns); + this.columns.splice(0); + this.columns.push(...sortColumns); + } + }, + resetViewColumns() { + if (!this.orginColumnFields) { + return; + } + let _columns = []; + this.orginColumnFields.forEach((x) => { + _columns.push( + this.columns.find((c) => { + return c.field == x; + }) + ); + }); + let otherColumns = this.columns.filter((c) => { + return !this.orginColumnFields.some((s) => { + return c.field == s; + }); + }); + _columns.push(...otherColumns); + this.columns.splice(0); + this.columns.push(..._columns); + }, + showCustomModel() { + if (!this.viewColumns.length) { + this.initViewColumns(); + } + this.viewColumnsClone = JSON.parse(JSON.stringify(this.viewColumns)); + this.viewModel = true; + }, + closeCustomModel() { + this.viewModel=false; + if (this.checkColumnChanged()) { + this.viewColumns = JSON.parse(JSON.stringify(this.viewColumnsClone)); + } + }, + checkColumnChanged() { + return ( + JSON.stringify(this.viewColumns) != JSON.stringify(this.viewColumnsClone) + ); + }, + saveColumnConfig() { + let hasShowColumn = this.viewColumns.some((x) => { + return x.show; + }); + if (!hasShowColumn) { + return this.$message.error('鑷冲皯閫夋嫨涓�鍒楁樉绀�'); + } + this.viewModel = false; + if (this.checkColumnChanged()) { + let sortColumns = []; + this.viewColumns.forEach((column) => { + let _column = this.columns.find((c) => { + return c.field == column.field; + }); + if (_column) { + _column.hidden = !column.show; + sortColumns.push(_column); + } + }); + this.sortViewColumns(sortColumns); + } + try { + localStorage.setItem(this.getViewCacheKey(), JSON.stringify(this.viewColumns)); + } catch (error) { + console.log('鑾峰彇鑷畾涔夊垪寮傚父:' + error.message); + } + } +}; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridCustomColumn.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridCustomColumn.vue" new file mode 100644 index 0000000..97feb80 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/ViewGridCustomColumn.vue" @@ -0,0 +1,95 @@ +<template> + <el-alert + title="鎷栧姩鍒楀悕鍙皟鏁磋〃鏍煎垪鏄剧ず椤哄簭" + type="success" + :show-icon="false" + > + </el-alert> + <div class="view-column view-column-title"> + <div class="view-column-index">#</div> + <div class="view-column-left">鍒楀悕</div> + <div class="view-column-right">鏄惁鏄剧ず</div> + </div> + <draggable + class="list-group" + tag="transition-group" + :component-data="componentData" + :list="viewColumns" + v-bind="dragOptions" + item-key="order" + > + <transition-group class="drag-center-item"> + <div + class="view-column" + v-for="(column, index) in viewColumns" + :key="index" + > + <div class="view-column-index">{{ index + 1 }}</div> + <div class="view-column-left">{{ column.title }}</div> + <div class="view-column-right"> + <el-checkbox v-model="column.show"> + <div style="height: 100%; width: 250px"></div + ></el-checkbox> + </div> + </div> + </transition-group> + </draggable> +</template> +<script> +import { VueDraggableNext } from 'vue-draggable-next'; +import { defineComponent, ref, reactive } from 'vue'; + +export default defineComponent({ + props: { + viewColumns: { + type: Array, + default: () => { + return []; + } + } + }, + components: { + draggable: VueDraggableNext + }, + data() { + return {}; + }, + setup(props, context) { + const dragOptions = reactive({ + animation: 200, + group: 'description', + disabled: false, + ghostClass: 'ghost' + }); + const componentData = reactive({ + tag: 'ul', + type: 'transition-group' + }); + return { dragOptions, componentData }; + } +}); +</script> +<style lang="less" scoped> +.view-column { + cursor: pointer; + display: flex; + padding: 10px; + border-bottom: 1px solid #f3f3f3; + .view-column-index { + width: 50px; + } + .view-column-left { + width: 120px; + padding: 0 10px; + } + .view-column-right { + flex: 1; + } +} +.view-column-title { + font-weight: bold; +} +.view-column:last-child { + border-bottom: 0; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/detailMethods.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/detailMethods.js" new file mode 100644 index 0000000..77d3907 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/detailMethods.js" @@ -0,0 +1,102 @@ +//浠庤〃鏂规硶 +let detailMethods = { + //鏌ヨ浠庤〃鍓嶅厛鍋氬唴閮ㄥ鐞� + loadInternalDetailTableBefore(param, callBack) { + //鍔犺浇鏄庣粏琛ㄦ暟鎹箣鍓�,闇�瑕佽瀹氭煡璇㈢殑涓昏〃鐨処D + //姣忔鍙鍔犺浇鏄庣粏琛ㄦ牸鏁版嵁灏遍噸缃垹闄ゆ槑缁嗙殑鍊� + if (this.detailOptions.delKeys.length > 0) { + this.detailOptions.delKeys = []; + } + let key = this.table.key; + if (this.currentRow && this.currentRow.hasOwnProperty(key)) { + param.value = this.currentRow[key]; + } + return this.loadDetailTableBefore(param, callBack); + }, + detailRowOnChange(row) { + this.detailRowChange(row); + }, + detailRowChange(row) { + //checkbox閫変腑琛屼簨浠� + }, + detailRowOnClick({ row, column, event }) { + //鏄庣粏琛ㄧ偣鍑昏浜嬩欢2020.11.07 + this.detailRowClick({ row, column, event }); + }, + detailRowClick({ row, column, event }) {}, + resetDetailTable(row) { + //缂栬緫鍜屾煡鐪嬫槑缁嗘椂閲嶇疆浠庤〃鏁版嵁 + if (!this.detailOptions.columns || this.detailOptions.columns.length == 0) { + return; + } + let key = this.table.key; + let query = { value: row ? row[key] : this.currentRow[key] }; + this.$nextTick(() => { + if (this.$refs.detail) { + this.$refs.detail.reset(); + this.$refs.detail.load(query); + } + }); + }, + //浠庡悗闈㈠姞杞戒粠琛ㄦ暟鎹� + refreshRow() { + this.resetDetailTable(); + }, + addRow() { + this.$refs.detail.addRow({}); + this.$refs.detail.edit.rowIndex=-1; + this.updateDetailTableSummaryTotal(); + }, + delRow() { + let rows = this.$refs.detail.getSelected(); + if (!rows || rows.length == 0) { + return this.$message.error('璇烽�夋嫨瑕佸垹闄ょ殑琛�!'); + } + if (!this.delDetailRow(rows)) { + return false; + } + + let tigger = false; + this.$confirm('纭瑕佸垹闄ら�夋嫨鐨勬暟鎹悧?', '璀﹀憡', { + confirmButtonText: '纭畾', + cancelButtonText: '鍙栨秷', + type: 'warning', + center: true + }).then(() => { + if (tigger) return; + tigger = true; + rows = this.$refs.detail.delRow(); + let key = this.detailOptions.key; + //璁板綍鍒犻櫎鐨勮鏁版嵁 + rows.forEach((x) => { + if (x.hasOwnProperty(key) && x[key]) { + this.detailOptions.delKeys.push(x[key]); + } + }); + this.updateDetailTableSummaryTotal(); + }); + }, + updateDetailTableSummaryTotal() { + //2021.09.25澧炲姞鏄庣粏琛ㄥ垹闄ゃ�佷慨鏀规椂閲嶆柊璁$畻琛屾暟涓庢眹鎬� + //2021.12.12澧炲姞鏄庣粏琛ㄥ垽鏂�(寮哄埗鍒锋柊鍚堣鏃朵細鐢ㄥ埌) + if (!this.$refs.detail) { + return; + } + //鍒犻櫎鎴栨柊澧炶鏃堕噸鏂拌缃樉绀虹殑鎬昏鏁� + this.$refs.detail.paginations.total = this.$refs.detail.rowData.length; + //閲嶆柊璁剧疆鍚堣 + if (this.$refs.detail.summary) { + this.$refs.detail.columns.forEach((column) => { + if (column.summary) { + this.$refs.detail.getInputSummaries(null, null, null, column); + } + }); + } + }, + detailSelectable(row, index){ + //鏄庣粏琛–heckBox 鏄惁鍙互鍕鹃�� + return true; + } +}; + +export default detailMethods; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/index.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/index.js" new file mode 100644 index 0000000..bd90205 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/index.js" @@ -0,0 +1,7 @@ +import Grid from './ViewGrid.vue' +const ViewGrid = { + install: function (app) { + app.component('ViewGrid', Grid) + } +} +export default ViewGrid \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/methods.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/methods.js" new file mode 100644 index 0000000..fa02eca --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/methods.js" @@ -0,0 +1,1684 @@ +import detailMethods from './detailMethods.js'; +//涓氬姟澶勭悊鏂规硶,鍏ㄩ儴鍙互鐢卞紑鍙戣鐩� +import serviceFilter from './serviceFilter.js'; +let methods = { + //褰撴坊鍔犳墿灞曠粍浠秅ridHeader/gridBody/gridFooter鍙婃槑缁唌odelHeader/modelBody/modelFooter鏃讹紝 + //濡傛灉瑕佽幏鍙栫埗绾ue瀵硅薄,璇蜂娇鐢ㄦ鏂规硶杩涜鍥炶皟 + parentCall(fun) { + if (typeof fun != 'function') { + return console.log('鎵╁睍缁勪欢闇�瑕佷紶鍏ヤ竴涓洖璋冩柟娉曟墠鑳借幏鍙栫埗绾ue瀵硅薄'); + } + fun(this); + }, + getCurrentAction() { + if (this.currentReadonly) { + return ''; + } + return '--' + (this.currentAction == this.const.ADD ? '鏂板' : '缂栬緫'); + }, + quickSearchKeyPress($event) { + //鏌ヨ瀛楁涓篿nput鏃讹紝鎸夊洖杞︽煡璇� + if ($event.keyCode == 13) { + if (this.searchFormFields[this.singleSearch.field] != '') { + this.search(); + } + } + }, + getButtons() { + //鐢熸垚ViewGrid鐣岄潰鐨勬搷浣滄寜閽強鏇村閫夐」 + let searchIndex = this.buttons.findIndex((x) => { + return x.value == 'Search'; + }); + //娣诲姞楂樼骇鏌ヨ + let hasOneFormItem = + this.searchFormOptions.length == 1 && + this.searchFormOptions[0].length == 1; + if (searchIndex != -1 && !hasOneFormItem) { + this.buttons.splice(searchIndex + 1, 0, { + icon: this.fiexdSearchForm ? 'el-icon-refresh-left' : 'el-icon-search', + name: this.fiexdSearchForm ? '閲嶇疆' : '楂樼骇鏌ヨ', + plain: true, + type: this.buttons[searchIndex].type, + onClick: () => { + if (this.fiexdSearchForm) { + return this.resetSearch(); + } + this.searchBoxShow = !this.searchBoxShow; + } + }); + } + if (hasOneFormItem) { + this.fiexdSearchForm = false; + } + this.maxBtnLength += searchIndex == -1 ? 0 : 1; + // if (this.buttons.length <= this.maxBtnLength) { + // return this.buttons; + // } + // let btns = this.buttons.slice(0, this.maxBtnLength); + // btns[this.maxBtnLength - 1].last = true; + // return btns; + }, + extendBtn(btns, source) { + //btns鏉冮檺鎸夐挳锛宻ource涓烘墿灞曟寜閽� + if (!btns || !(source && source instanceof Array)) { + return; + } + //source閫氳繃鍦ㄨ〃鐨勬墿灞昷s鏂囦欢涓璪uttons瀵瑰簲鎸夐挳鐨勫睘鎬ndex鍐冲畾鎸夐挳鎵�鏀句綅缃� + source.forEach((x) => { + //閫氳繃鎸夐挳鐨処ndex灞炴�э紝鏀惧埌鎸囧畾鐨勪綅缃� + btns.splice(x.index == undefined ? btns.length : x.index, 0, x); + }); + // if (this.extend.buttons.view) { + // this.extend.buttons.view.forEach((x) => { + // //閫氳繃鎸夐挳鐨処ndex灞炴�э紝鏀惧埌鎸囧畾鐨勪綅缃� + // this.buttons.splice(x.index == undefined ? this.buttons.length : x.index, 0, x); + // }) + // } + }, + initBoxButtons() { + //鍒濆鍖朧iewGird涓庡脊鍑烘/鏄庣粏琛ㄦ寜閽� + let path = this.$route.path; + //閫氳繃鑿滃崟鑾峰彇鐢ㄦ埛鎵�瀵瑰簲鑿滃崟闇�瑕佹樉绀虹殑鎸夐挳 + let permissionButtons = this.permission.getButtons( + path, + null, + this.extend.tableAction, + this.table.name + ); + if (permissionButtons) { + //2020.03.31娣诲姞娣辨嫹璐濇寜閽粍 + permissionButtons.forEach((p) => { + let _obj = {}; + for (const key in p) { + _obj[key] = p[key]; + } + this.buttons.push(_obj); + }); + // this.buttons.push(...permissionButtons); + } + if (!this.extend) { + this.extend = {}; + } + if (!this.extend.buttons) { + this.extend.buttons = {}; + } + //鏌ヨ鐣岄潰鎵╁睍鎸夐挳(鎵╁睍鎸夐挳鍙嚜琛岄�氳繃璁剧疆鎸夐挳鐨処ndex灞炴�ф樉绀哄埌鍏蜂綋浣嶇疆) + if (this.extend.buttons.view) { + this.extendBtn(this.buttons, this.extend.buttons.view); + } + + //寮瑰嚭妗嗘寜閽� + let boxButtons = []; + + let saveBtn = this.buttons.some((x) => { + if ( + x.value && + (x.value.toLowerCase() == this.const.ADD.toLowerCase() || + x.value.toLowerCase() == this.const.EDIT.toLowerCase()) + ) + return true; + }); + this.currentReadonly = !saveBtn; + //浠庤〃琛ㄦ牸鎿嶄綔鎸夐挳 + let detailGridButtons = { + name: '鍒锋柊', + type: 'info', + icon: 'el-icon-refresh', + onClick() { + //濡傛灉鏄庣粏琛ㄥ綋鍓嶇殑鐘舵�佷负鏂板缓鏃讹紝绂佹鍒锋柊 + if (this.currentAction == this.const.ADD) { + return; + } + this.refreshRow(); + } + }; + + let importExcel = this.buttons.some((x) => { + if (x.value == this.const.IMPORT) return true; + }); + //濡傛灉鏈夊鍏ユ潈闄�,鍒欓渶瑕佸垵濮嬪寲瀵煎叆缁勪欢 + if (importExcel) { + this.upload.url = this.getUrl(this.const.IMPORT); + //瀹氫箟涓嬭浇妯℃澘鐨勬枃浠跺悕 + this.upload.template.fileName = this.table.cnName; + //瀹氫箟涓嬭浇妯℃澘鐨刄rl璺緞 + this.upload.template.url = + this.http.ipAddress + this.getUrl(this.const.DOWNLOADTEMPLATE, true); + } + + // disabled + //濡傛灉褰撳墠瑙掕壊娌℃湁缂栬緫鎴栨柊寤哄姛鑳斤紝鏌ョ湅鏄庣粏鏃跺瓧娈佃缃叏閮ㄥ彧璇� + //鍙湁鏄庣粏琛紝灏嗘槑缁嗚〃涔熻缃负涓嶅彲鑳界紪杈戯紝骞朵笖涓嶆樉绀烘坊鍔犺銆佸垹闄よ + if (!saveBtn) { + this.editFormOptions.forEach((row) => { + row.forEach((x) => { + x.disabled = true; + }); + }); + //娌℃湁鏂板缂栬緫鏉冮檺鐨勶紝寮瑰嚭妗嗛兘璁剧疆涓哄彧璇� + this.detail.columns.forEach((column) => { + if (column.hasOwnProperty('edit')) { + column.readonly = true; + // row['edit'] = false; + } + }); + //寮瑰嚭妗嗘墿灞曟寜閽� + this.extendBtn(boxButtons, this.extend.buttons.box); + //寮瑰嚭寮规鎸夐挳(2020.04.21),娌℃湁缂栬緫鎴栨柊寤烘潈闄愭椂锛屼篃鍙互閫氳繃buttons灞炴�ф坊鍔犺嚜瀹氫箟寮瑰嚭妗嗘寜閽� + this.boxButtons.push(...boxButtons); + this.detailOptions.buttons.push(detailGridButtons); + this.detailOptions.buttons.forEach((button) => { + if (!button.hasOwnProperty('hidden')) { + button.hidden = false; + } + }); + //寮瑰嚭妗嗘墿灞曟槑缁嗚〃鎸夐挳 + this.extendBtn(this.detailOptions.buttons, this.extend.buttons.detail); + + return boxButtons; + } + + this.detailOptions.edit = true; + boxButtons.push( + ...[ + { + name: '淇� 瀛�', + icon: 'el-icon-check', + type: 'danger', + disabled: false, + value: 'save', + onClick() { + this.save(); + } + } + // { + // name: '閲� 缃�', + // icon: 'el-icon-refresh-right', + // type: 'primary', + // disabled: false, + // onClick() { + // this.resetEdit(); + // } + // } + ] + ); + //浠庤〃琛ㄦ牸鎿嶄綔鎸夐挳 + this.detailOptions.buttons.push( + ...[ + { + name: '娣诲姞琛�', + icon: 'el-icon-plus', + type: 'primary', + hidden: false, + plain: true, + onClick() { + this.addRow(); + } + }, + { + type: 'danger', + plain: true, + name: '鍒犻櫎琛�', + hidden: false, + icon: 'el-icon-delete', + onClick() { + this.delRow(); + } + }, + //2022.01.08澧炲姞鏄庣粏琛ㄥ鍏ュ鍑哄姛鑳� + //娉ㄦ剰闇�瑕侀噸鍐欏悗鍙版槑缁嗚〃鎺ュ彛鐨勫鍏ヤ笌涓嬭浇妯℃澘銆佸鍑虹殑鏉冮檺,Sys_DictionaryListController.cs/SellOrderListController.cs + { + type: 'danger', + plain: true, + name: '瀵煎叆', + value: 'import', + hidden: false, + icon: 'el-icon-upload2', + onClick() { + this.upload.url = `${this.http.ipAddress}api/${this.detail.table}/${this.const.IMPORT}?table=1`; + this.upload.template.url = `${this.http.ipAddress}api/${this.detail.table}/${this.const.DOWNLOADTEMPLATE}`; + //瀹氫箟涓嬭浇妯℃澘鐨勬枃浠跺悕 + this.upload.template.fileName = this.detail.cnName; + this.upload.excel = true; + } + }, + { + type: 'danger', + plain: true, + name: '瀵煎嚭', + value: 'export', + icon: 'el-icon-download', + hidden: false, + onClick() { + this.export(true); + } + } + ] + ); + this.detailOptions.buttons.forEach((button) => { + if (button.hasOwnProperty('hidden')) { + button.hidden = false; + } + }); + //寮瑰嚭妗嗘墿灞曟寜閽� + this.extendBtn(boxButtons, this.extend.buttons.box); + + //寮瑰嚭妗嗘墿灞曟槑缁嗚〃鎸夐挳 + this.detailOptions.buttons.push(detailGridButtons); + this.extendBtn(this.detailOptions.buttons, this.extend.buttons.detail); + + //寮瑰嚭寮规鎸夐挳 + this.boxButtons.push(...boxButtons); + }, + onClick(click) { + click.apply(this); + }, + changeDropdown(btnName, v1) { + let button = this.buttons.filter((x) => { + return x.name == btnName; + }); + if (button && button.length > 0) { + button[0].onClick.apply(this); + } + }, + emptyValue(value) { + if (typeof value == 'string' && value.trim() === '') { + return true; + } + if (value instanceof Array && !value.length) { + return true; + } + return value === null || value === undefined || value === ''; + }, + getSearchParameters() { + //鑾峰彇鏌ヨ鍙傛暟 + // 2020.09.11澧炲姞鍥哄畾鏌ヨ琛ㄥ崟,濡傛灉璁剧疆鍥哄畾浜嗘煡璇㈣〃鍗曪紝鐐瑰嚮鏌ヨ鏃讹紝涓嶅啀鍏抽棴 + if (!this.fiexdSearchForm) { + this.searchBoxShow = false; + } + + let query = { wheres: [] }; + for (const key in this.searchFormFields) { + let value = this.searchFormFields[key]; + if (this.emptyValue(value)) continue; + + if (typeof value == 'number') { + value = value + ''; + } + let displayType = this.getSearchItem(key); + + //鑱旂骇鍙繚鐣欓�変腑鑺傜偣鐨勬渶鍚庝竴涓�� + if (displayType == 'cascader') { + //鏌ヨ涓嬮潰鎵�鏈夌殑瀛愯妭鐐癸紝濡傦細閫変腑鐨勬槸鐖惰妭鐐癸紝搴旇鏌ヨ涓嬮潰鎵�鏈夌殑鑺傜偣鏁版嵁--寰呭畬 + value = value.length ? value[value.length - 1] + '' : ''; + } + //2021.05.02澧炲姞鍖洪棿鏌ヨ + if ( + typeof value == 'string' || + ['date', 'datetime', 'range'].indexOf(displayType) == -1 + ) { + query.wheres.push({ + name: key, + value: + typeof value == 'string' ? (value + '').trim() : value.join(','), + displayType: displayType + }); + continue; + } + for (let index = 0; index < value.length; index++) { + if (!this.emptyValue(value[index])) { + query.wheres.push({ + name: key, + value: (value[index] + '').trim(), + displayType: (() => { + if (['date', 'datetime', 'range'].indexOf(displayType) != -1) { + return index ? 'lessorequal' : 'thanorequal'; + } + return displayType; + })() + }); + } + } + } + return query; + }, + search() { + //鏌ヨ + // let query = this.getSearchParameters(); + // this.$refs.table.load(query, true); + this.$refs.table.load(null, true); + }, + loadTableBefore(param, callBack) { + //鏌ヨ鍓嶈缃煡璇㈡潯浠跺強鍒嗛〉淇℃伅 + let query = this.getSearchParameters(); + if (query) { + param = Object.assign(param, query); + } + + if (this.$route.query.viewflow && this.$route.query.id) { + param.wheres.push({ + name: this.table.key, + value: this.$route.query.id + }); + } + // if (this.isViewFlow() && data && data.length) { + // let query = JSON.parse(JSON.stringify(this.$route.query)); + // query.viewflow = 0; + // this.$router.replace({ path: this.$route.path, query: query }); + // this.$nextTick(() => { + // this.getWorkFlowSteps(data[0]); + // }); + // } + let status = this.searchBefore(param); + callBack(status); + }, + + loadTableAfter(data, callBack, result) { + //鏌ヨ鍚� + //2020.10.30澧炲姞鏌ヨ鍚庤繑鍥炴墍鏈夌殑鏌ヨ淇℃伅 + let status = this.searchAfter(data, result); + callBack(status); + //鑷姩寮瑰嚭妗嗗鎵硅鎯� + }, + loadDetailTableBefore(param, callBack) { + //鏄庣粏鏌ヨ鍓� + //鏂板缓鏃剁姝㈠姞杞芥槑缁� + if (this.currentAction == this.const.ADD) { + callBack(false); + return false; + } + let status = this.searchDetailBefore(param); + callBack(status); + }, + loadDetailTableAfter(data, callBack) { + //鏄庣粏鏌ヨ鍚� + let status = this.searchDetailAfter(data); + callBack(status); + }, + getSearchItem(field) { + //鑾峰彇鏌ヨ鐨勫弬鏁� + let data; + for (let index = 0; index < this.searchFormOptions.length; index++) { + if (data) return data.type; + const item = this.searchFormOptions[index]; + data = item.find((x) => { + return x.field == field; + }); + } + + return (data || {}).type; + }, + resetSearch() { + //閲嶇疆鏌ヨ瀵硅薄 + this.resetSearchForm(); + //2020.10.17澧炲姞閲嶇疆鍚庢柟娉� + this.resetSearchFormAfter && this.resetSearchFormAfter(); + }, + resetEdit() { + //閲嶇疆缂栬緫鐨勬暟鎹� + let isEdit = this.currentAction != this.const.ADD; + //閲嶇疆涔嬪墠 + if (!this[isEdit ? 'resetUpdateFormBefore' : 'resetAddFormBefore']()) { + return; + } + let objKey = {}; + //缂栬緫鐘舵�佷笅,涓嶉渶瑕侀噸缃富閿�,鍒涘缓鏃堕棿鍒涘缓浜� + if (isEdit) { + objKey[this.table.key] = this.editFormFields[this.table.key]; + } + this.resetEditForm(objKey); + //閲嶇疆涔嬪悗 + + if (!this[isEdit ? 'resetUpdateFormAfter' : 'resetAddFormAfter']()) { + return; + } + }, + resetSearchForm(sourceObj) { + //閲嶇疆鏌ヨ琛� + this.resetForm('searchForm', sourceObj); + }, + resetEditForm(sourceObj) { + if (this.hasDetail && this.$refs.detail) { + // this.$refs.detail.rowData.splice(0); + this.$refs.detail.reset(); + } + this.resetForm('form', sourceObj); + if (this.$refs.form && this.$refs.form.$refs.volform) { + setTimeout(() => { + this.$refs.form.$refs.volform.clearValidate(); + }, 100); + } + }, + getKeyValueType(formData, isEditForm) { + try { + let keyLeft = (isEditForm ? 'e' : 's') + '_b_'; + formData.forEach((item) => { + item.forEach((x) => { + if (this.keyValueType.hasOwnProperty(keyLeft + x.field)) { + return true; + } + let data; + if (x.type == 'switch') { + this.keyValueType[x.field] = 1; + } else if (x.bind && x.bind.data) { + data = x.bind.data; + } else if (x.data) { + if (x.data instanceof Array) { + data = x.data; + } else if (x.data.data && x.data.data instanceof Array) { + data = x.data.data; + } + } + if ( + data && + data.length > 0 && + !this.keyValueType.hasOwnProperty(x.field) + ) { + this.keyValueType[x.field] = data[0].key; + this.keyValueType[keyLeft + x.field] = x.type; + } + }); + }); + } catch (error) { + console.log(error.message); + } + }, + resetForm(formName, sourceObj) { + // return; + //閲嶇疆琛ㄥ崟鏁版嵁 + if (this.$refs[formName]) { + this.$refs[formName].reset(); + } + + if (!sourceObj) return; + let form, keyLeft; + if (formName == 'searchForm') { + form = this.searchFormFields; + keyLeft = 's' + '_b_'; + } else { + form = this.editFormFields; + keyLeft = 'e' + '_b_'; + } + //鑾峰彇鏁版嵁婧愮殑data绫诲瀷锛屽惁鍒欏鏋滄暟鎹簮data鐨刱ey鏄暟瀛楋紝閲嶇疆鐨勫�兼槸瀛楃涓插氨鏃犳硶缁戝畾鍊� + if (!this.keyValueType._dinit) { + this.getKeyValueType(this.editFormOptions, true); + this.getKeyValueType(this.searchFormOptions, false); + this.keyValueType._dinit = true; + } + var _cascaderParentTree; + for (const key in form) { + if (sourceObj.hasOwnProperty(key)) { + let newVal = sourceObj[key]; + let kv_type = this.keyValueType[keyLeft + key]; + + if ( + kv_type == 'selectList' || + kv_type == 'checkbox' || + kv_type == 'cascader' || + kv_type == 'treeSelect' + ) { + // 2020.05.31澧炲姞iview缁勪欢Cascader + // 2020.11.01澧炲姞iview缁勪欢Cascader琛ㄥ崟閲嶇疆鏃舵煡璇㈡墍鏈夌殑鐖惰妭鐐� + if (kv_type == 'cascader' || kv_type == 'treeSelect') { + var treeDic = this.dicKeys.find((dic) => { + return dic.fileds && dic.fileds.indexOf(key) != -1; + }); + + if (treeDic && treeDic.orginData && treeDic.orginData.length) { + let keyIsNum = typeof treeDic.orginData[0].id == 'number'; + + if (kv_type == 'cascader') { + newVal = keyIsNum ? newVal * 1 || 0 : newVal + ''; + if (kv_type == 'cascader') { + _cascaderParentTree = this.base.getTreeAllParent( + newVal, + treeDic.orginData + ); + if (_cascaderParentTree) { + newVal = _cascaderParentTree.map((x) => { + return x.id; + }); + } + } + } else { + if (newVal === null || newVal === undefined) { + newVal = []; + } else if (typeof newVal == 'string') { + newVal = newVal.split(','); + } + if (keyIsNum) { + if (Array.isArray(newVal)) { + newVal = newVal.map((x) => { + return x * 1 || 0; + }); + } + } else if (typeof newVal == 'number') { + newVal = [newVal + '']; + } + } + } else { + newVal = [newVal]; + } + } else if ( + newVal != '' && + newVal != undefined && + typeof newVal == 'string' + ) { + newVal = newVal.split(','); + } else if (kv_type == 'checkbox') { + newVal = []; + } + } else if ( + this.keyValueType.hasOwnProperty(key) && + typeof this.keyValueType[key] == 'number' && + newVal * 1 == newVal + ) { + newVal = newVal * 1; + } else { + if (newVal == null || newVal == undefined) { + newVal = ''; + } else if (this.numberFields.indexOf(key) != -1) { + newVal = newVal * 1 || 0; + } else { + newVal += ''; + } + } + if (newVal instanceof Array) { + if (form[key]) { + form[key] = []; + } + form[key] = newVal; + } else { + form[key] = newVal; + } + } else { + form[key] = form[key] instanceof Array ? [] : ''; + } + } + }, + onBtnClick(param) { + this[param.method](param.data); + }, + refresh() { + //鍒锋柊 + this.search(); + // this.$refs.table.load(); + }, + saveBefore(formData) { + return true; + }, + saveAfter(formData, result) { + return true; + }, + save() { + //鏂板鎴栫紪杈戞椂淇濆瓨 + // if (!this.$refs.form.validate()) return; + this.$refs.form.validate((result) => { + if (result) { + this.saveExecute(); + } + }); + }, + async saveExecute() { + let editFormFields = {}; + //涓婁紶鏂囦欢浠ラ�楀彿闅斿紑 + for (const key in this.editFormFields) { + if ( + this.uploadfiled && + this.uploadfiled.length > 0 && + this.uploadfiled.indexOf(key) != -1 && + this.editFormFields[key] instanceof Array + ) { + let allPath = this.editFormFields[key].map((x) => { + return x.path; + }); + editFormFields[key] = allPath.join(','); + } else if (typeof this.editFormFields[key] == 'function') { + try { + editFormFields[key] = this.editFormFields[key](); + } catch (error) { } + } else { + //2021.05.30淇涓嬫媺妗嗘竻闄ゆ暟鎹悗鍚庡彴涓嶈兘淇濆瓨鐨勯棶棰� + if ( + this.editFormFields[key] === undefined && + this.dicKeys.some((x) => { + return x.fileds && x.fileds.indexOf(key) != -1; + }) + ) { + editFormFields[key] = null; + } else { + editFormFields[key] = this.editFormFields[key]; + } + } + } + //灏嗘暟缁勮浆鎹㈡垚string + //2020.11.01澧炲姞绾ц仈澶勭悊 + for (const key in editFormFields) { + if (editFormFields[key] instanceof Array) { + var iscascader = this.dicKeys.some((x) => { + return ( + x.type == 'cascader' && x.fileds && x.fileds.indexOf(key) != -1 + ); + }); + if (iscascader && editFormFields[key].length) { + editFormFields[key] = + editFormFields[key][editFormFields[key].length - 1]; + } else { + editFormFields[key] = editFormFields[key].join(','); + } + } + } + + let formData = { + mainData: editFormFields, + detailData: null, + delKeys: null + }; + + //鑾峰彇鏄庣粏鏁版嵁(鍓嶅彴鏁版嵁鏄庣粏鏈仛鏍¢獙锛屽緟瀹�.鍚庡彴宸茬粡鏍¢獙) + if (this.hasDetail) { + formData.detailData = this.$refs.detail.rowData; + let _fields = this.detail.columns + .filter((c) => { + return ( + c.type == 'selectList' || (c.edit && c.edit.type == 'selectList') + ); + }) + .map((c) => { + return c.field; + }); + //2022.06.20澧炲姞淇濆瓨鏃跺鏄庣粏琛ㄤ笅鎷夋澶氶�夌殑鍒ゆ柇 + if (_fields.length) { + formData.detailData = JSON.parse(JSON.stringify(formData.detailData)); + formData.detailData.forEach((row) => { + for (let index = 0; index < _fields.length; index++) { + const _field = _fields[index]; + if (Array.isArray(row[_field])) { + row[_field] = row[_field].join(','); + } + } + }); + } + } + if (this.detailOptions.delKeys.length > 0) { + formData.delKeys = this.detailOptions.delKeys; + } + //淇濆瓨鍓嶆嫤鎴� + let _currentIsAdd = this.currentAction == this.const.ADD; + if (_currentIsAdd) { + //2020.12.06澧炲姞鏂板缓鍓嶅紓姝ュ鐞嗘柟娉� + //2021.08.16淇寮傛璇硶鍐欓敊鐨勯棶棰� + if (!this.addBefore(formData) || !(await this.addBeforeAsync(formData))) + return; + } else { + //2020.12.06澧炲姞淇敼鍓嶅紓姝ュ鐞嗘柟娉� + if ( + !this.updateBefore(formData) || + !(await this.updateBeforeAsync(formData)) + ) + return; + } + let url = this.getUrl(this.currentAction); + this.http.post(url, formData, true).then((x) => { + //淇濆瓨鍚� + if (_currentIsAdd) { + if (!this.addAfter(x)) return; + //杩炵画娣诲姞 + if (this.continueAdd && x.status) { + this.$success(x.message); + //鏂板缓 + this.currentAction = this.const.ADD; + this.currentRow = {}; + this.resetAdd(); + this.refresh(); + return; + } + } else { + if (!this.updateAfter(x)) return; + } + if (!x.status) return this.$error(x.message); + this.$success(x.message || '鎿嶄綔鎴愬姛'); + //濡傛灉淇濆瓨鎴愬姛鍚庨渶瑕佸叧闂紪杈戞锛岀洿鎺ヨ繑鍥炰笉澶勭悊鍚庨潰 + if (this.boxOptions.saveClose) { + this.boxModel = false; + //2020.12.27濡傛灉鏄紪杈戜繚瀛樺悗涓嶉噸缃垎椤甸〉鏁帮紝鍒锋柊椤甸潰鏃惰繕鏄樉绀哄綋鍓嶉〉鐨勬暟鎹� + this.$refs.table.load(null, _currentIsAdd); + //this.refresh(); + return; + } + let resultRow; + if (typeof x.data == 'string' && x.data != '') { + resultRow = JSON.parse(x.data); + } else { + resultRow = x.data; + } + + if (this.currentAction == this.const.ADD) { + // this.currentRow=x.data; + this.editFormFields[this.table.key] = ''; + this.currentAction = this.const.EDIT; + this.currentRow = resultRow.data; + } + this.resetEditForm(resultRow.data); + // console.log(resultRow); + if (this.hasDetail) { + this.detailOptions.delKeys = []; + if (resultRow.list) { + this.$refs.detail.rowData.push(...resultRow.list); + } + } + this.$refs.table.load(null, _currentIsAdd); + // this.refresh(); + }); + }, + del(rows) { + if (rows) { + if (!(rows instanceof Array)) { + rows = [rows]; + } + } else { + rows = this.$refs.table.getSelected(); + } + //鍒犻櫎鏁版嵁 + + if (!rows || rows.length == 0) return this.$error('璇烽�夋嫨瑕佸垹闄ょ殑琛�!'); + let delKeys = rows.map((x) => { + return x[this.table.key]; + }); + if (!delKeys || delKeys.length == 0) + return this.$error('娌℃湁鑾峰彇瑕佸垹闄ょ殑琛屾暟鎹�!'); + //鍒犻櫎鍓� + if (!this.delBefore(delKeys, rows)) { + return; + } + let tigger = false; + this.$confirm('纭瑕佸垹闄ら�夋嫨鐨勬暟鎹悧?', '璀﹀憡', { + confirmButtonText: '纭畾', + cancelButtonText: '鍙栨秷', + type: 'warning', + center: true + }).then(() => { + if (tigger) return; + tigger = true; + let url = this.getUrl(this.const.DEL); + this.http.post(url, delKeys, '姝e湪鍒犻櫎鏁版嵁....').then((x) => { + if (!x.status) return this.$error(x.message); + this.$success("鍒犻櫎鎴愬姛"); + //鍒犻櫎鍚� + if (!this.delAfter(x)) { + return; + } + this.refresh(); + }); + }); + }, + async modelOpenBeforeAsync(row) { + return true; + }, + async initBox() { + //2022.01.08澧炲姞鏂板缓鏃堕殣钘忔槑缁嗚〃瀵煎嚭鍔熻兘 + this.detailOptions.buttons.forEach((x) => { + if (x.value == 'export') { + x.hidden = this.currentAction == 'Add'; + } + }); + //鍒濆鍖栨柊寤恒�佺紪杈戠殑寮瑰嚭妗� + if (!(await this.modelOpenBeforeAsync(this.currentRow))) return false; + this.modelOpenBefore(this.currentRow); + if (!this.boxInit) { + this.boxInit = true; + this.boxModel = true; + // this.detailUrl = this.url; + } + return true; + }, + setEditForm(row) { + // if (this.remoteColumns.length == 0 || !rows || rows.length == 0) return; + let remoteColumns = this.$refs.table.remoteColumns; + remoteColumns.forEach((column) => { + this.editFormOptions.forEach((option) => { + option.forEach((x) => { + if (x.field == column.field) { + x.data.data = Object.assign([], x.data, column.bind.data); + } + }); + }); + }); + this.editFormFields; + //閲嶇疆缂栬緫琛ㄥ崟鏁版嵁 + this.editFormFields[this.table.key] = row[this.table.key]; + + this.resetEditForm(row); + this.currentAction = this.const.EDIT; + this.boxModel = true; + }, + async linkData(row, column) { + this.boxOptions.title = this.table.cnName + '(缂栬緫)'; + //鐐瑰嚮table鍗曞厓鏍煎揩鎹烽摼鎺ユ樉绀虹紪杈戞暟鎹� + this.currentAction = this.const.EDIT; + this.currentRow = row; + if (!(await this.initBox())) return; + this.resetDetailTable(row); + this.setEditForm(row); + this.setContinueAdd(false); + //璁剧疆杩滅▼鏌ヨ琛ㄥ崟鐨勯粯璁ey/value + this.getRemoteFormDefaultKeyValue(); + //鐐瑰嚮缂栬緫鎸夐挳寮瑰嚭妗嗗悗锛屽彲浠ュ湪姝ゅ鍐欓�昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + this.modelOpenProcess(row); + }, + setContinueAdd(isAdd) { + if (!this.continueAdd) return; + var _button = this.boxButtons.find((x) => { + return x.value == 'save'; + }); + if (_button) { + _button.name = isAdd ? this.continueAddName : '淇� 瀛�'; + } + }, + resetAdd() { + if (this.hasDetail) { + this.$refs.detail && + // this.$refs.detail.rowData && + this.$refs.detail.reset(); + } + let obj = {}; + //濡傛灉鏈塻witch鏍囩锛岄粯璁ら兘璁剧疆涓哄惁 + this.editFormOptions.forEach((x) => { + x.forEach((item) => { + if (item.type == 'switch') { + obj[item.field] = 0; + } + }); + }); + this.resetEditForm(obj); + }, + async add() { + this.boxOptions.title = this.table.cnName + '(鏂板缓)'; + //鏂板缓 + this.currentAction = this.const.ADD; + this.currentRow = {}; + if (!(await this.initBox())) return; + + this.resetAdd(); + this.setContinueAdd(true); + // this.resetEditForm(); + this.boxModel = true; + //鐐瑰嚮鏂板缓鎸夐挳寮瑰嚭妗嗗悗锛屽彲浠ュ湪姝ゅ鍐欓�昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + this.modelOpenProcess(); + // this.modelOpenAfter(); + }, + async edit(rows) { + this.boxOptions.title = '缂栬緫'; + //缂栬緫 + this.currentAction = this.const.EDIT; + if (rows) { + if (!(rows instanceof Array)) { + rows = [rows]; + } + } else { + rows = this.$refs.table.getSelected(); + } + if (rows.length == 0) { + return this.$error('璇烽�夋嫨瑕佺紪杈戠殑琛�!'); + } + if (rows.length != 1) { + return this.$error('鍙兘閫夋嫨涓�琛屾暟鎹繘琛岀紪杈�!'); + } + //璁板綍褰撳墠缂栬緫鐨勮 + this.currentRow = rows[0]; + //鍒濆鍖栧脊鍑烘 + if (!(await this.initBox())) return; + this.setContinueAdd(false); + //閲嶇疆琛ㄥ崟 + this.resetDetailTable(); + + //璁剧疆褰撳墠鐨勬暟鎹埌琛ㄥ崟涓� + this.setEditForm(rows[0]); + //璁剧疆杩滅▼鏌ヨ琛ㄥ崟鐨勯粯璁ey/value + this.getRemoteFormDefaultKeyValue(); + //鐐瑰嚮缂栬緫鎸夐挳寮瑰嚭妗嗗悗锛屽彲浠ュ湪姝ゅ鍐欓�昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + this.modelOpenProcess(rows[0]); + // this.modelOpenAfter(rows[0]); + }, + getRemoteFormDefaultKeyValue() { + //璁剧疆琛ㄥ崟杩滅▼鏁版嵁婧愮殑榛樿key.value + if (this.currentAction != this.const.EDIT || this.remoteKeys.length == 0) + return; + this.editFormOptions.forEach((x, xIndex) => { + x.forEach((item, yIndex) => { + if (item.remote) { + let column = this.columns.find((x) => { + return x.bind && x.bind.key == item.dataKey; + }); + if (!column) return; + let key = this.currentRow[item.field]; + let obj = column.bind.data.find((x) => { + return x.key == key; + }); + // obj ? obj.value : key濡傛灉娌℃湁鏌ュ埌鏁版嵁婧愶紝鐩存帴浣跨敤鍘熸暟鎹� + item.data = [{ key: key, value: obj ? obj.value : key }]; + this.editFormOptions[xIndex].splice(yIndex, 1, item); + // this.$set(item, 'data', [{ key: key + '', value: obj.value }]) + // item.data = [{ key: key + '', value: obj.value }]; + } + }); + }); + }, + modelOpenProcess(row) { + this.$nextTick(() => { + this.modelOpenAfter(row); + }); + return; + // if (!this.$refs.form) { + // let timeOut = setTimeout(x => { + // this.modelOpenAfter(row); + // }, 500) + // return; + // } + // this.modelOpenAfter(row); + }, + import() { + //瀵煎叆(涓婁紶excel),寮瑰嚭瀵煎叆缁勪欢UploadExcel.vue + this.upload.excel = true; + this.$refs.upload_excel && this.$refs.upload_excel.reset(); + }, + download(url, fileName) { + //涓嬭浇瀵煎嚭鐨勬枃浠� + let xmlResquest = new XMLHttpRequest(); + xmlResquest.open('GET', url, true); + xmlResquest.setRequestHeader('Content-type', 'application/json'); + xmlResquest.setRequestHeader( + 'Authorization', + this.$store.getters.getToken() + ); + let elink = this.$refs.export; + xmlResquest.responseType = 'blob'; + xmlResquest.onload = function (oEvent) { + if (xmlResquest.status != 200) { + this.$error('涓嬭浇鏂囦欢鍑洪敊浜�..'); + return; + } + let content = xmlResquest.response; + // let elink = this.$refs.export;//document.createElement("a"); + elink.download = fileName; //+".xlsx"; + // elink.style.display = "none"; + let blob = new Blob([content]); + elink.href = URL.createObjectURL(blob); + // document.body.appendChild(elink); + elink.click(); + // document.body.removeChild(elink); + }; + xmlResquest.send(); + }, + getFileName(isDetail) { + //2021.01.08澧炲姞瀵煎嚭excel鏃惰嚜瀹氫箟鏂囦欢鍚� + if (isDetail) { + return this.detail.cnName + '.xlsx'; + } + return this.table.cnName + '.xlsx'; + }, + export(isDetail) { + //瀵煎嚭 + let url, query, param; + if (isDetail) { + //鏄庣粏琛ㄥ鍑烘椂濡傛灉鏄柊寤虹姸鎬侊紝绂佹瀵煎嚭 + if (this.currentAction == 'Add') { + return; + } + url = `api/${this.detail.table}/${this.const.EXPORT}`; + param = { + wheres: [ + { name: this.table.key, value: this.editFormFields[this.table.key] } + ] + }; + } else { + //涓昏〃瀵煎嚭 + url = this.getUrl(this.const.EXPORT); + query = this.getSearchParameters(); + param = { order: this.pagination.order, wheres: query.wheres || [] }; + } + //2020.06.25澧炲姞瀵煎嚭鍓嶅鐞� + if (!isDetail && !this.exportBefore(param)) { + return; + } + + if (param.wheres && typeof param.wheres == 'object') { + param.wheres = JSON.stringify(param.wheres); + } + let $http = this.http; + //2022.09.26澧炲姞鑷畾涔夊鍑烘枃浠跺悕 + let fileName = this.downloadFileName || this.getFileName(isDetail); + //2021.01.08浼樺寲瀵煎嚭鍔熻兘 + $http + .post(url, param, '姝e湪瀵煎嚭鏁版嵁....', { responseType: 'blob' }) + .then((content) => { + const blob = new Blob([content]); + if ('download' in document.createElement('a')) { + // 闈濱E涓嬭浇 + const elink = document.createElement('a'); + elink.download = fileName; + elink.style.display = 'none'; + elink.href = URL.createObjectURL(blob); + document.body.appendChild(elink); + elink.click(); + URL.revokeObjectURL(elink.href); + document.body.removeChild(elink); + } else { + // IE10+涓嬭浇 + navigator.msSaveBlob(blob, fileName); + } + }); + //.then(result => { + // if (!result.status) { + // return this.$error(result.message); + // } + // let path = this.getUrl(this.const.DOWNLOAD); + // path = path[0] == "/" ? path.substring(1) : path; + // this.download( + // $http.ipAddress + path + "?path=" + result.data, + // this.table.cnName + ".xlsx" // filePath + // ); + /// window.open($http.ipAddress + path + "?fileName=" + filePath, "_self"); + // }); + }, + getSelectRows() { + //鑾峰彇閫変腑鐨勮 + return this.$refs.table.getSelected(); + }, + getDetailSelectRows() { + //鎴栬幏鍙栨槑缁嗛�変腑鐨勮 + if (!this.$refs.detail) { + return []; + } + return this.$refs.detail.getSelected(); + }, + audit() { + //瀹℃牳寮瑰嚭妗� + let rows = this.$refs.table.getSelected(); + if (rows.length == 0) return this.$error('璇烽�夋嫨瑕佸鏍哥殑琛�!'); + let auditStatus = Object.keys(rows[0]).find(x => { return x.toLowerCase() === 'auditstatus' }); + if (!auditStatus) { + return this.$message.error(`琛ㄥ繀椤诲寘鎷鏍稿瓧娈点�怉uditStatus銆�,骞朵笖鏄痠nt绫诲瀷`) + } + // let checkStatus = rows.every((x) => { + // return this.$global.audit.status.some(c => { return c === x[auditStatus] || !x[auditStatus] }) + // }); + // if (!checkStatus) return this.$error('鍙兘閫夋嫨寰呭鎵规垨瀹℃牳涓殑鏁版嵁!'); + this.$refs.audit.open(rows); + }, + saveAudit(params, rows, callback) { + + //淇濆瓨瀹℃牳 + let keys = rows.map(x => { return x[this.table.key] }); + if (!this.auditBefore(keys, rows)) { + return; + } + let url = `${this.getUrl(this.const.AUDIT)}?auditReason=${params.reason}&auditStatus=${params.value}` + this.http.post(url, keys, '瀹℃牳涓�....').then((x) => { + if (!this.auditAfter(x, keys)) { + return; + } + if (!x.status) return this.$error(x.message); + + callback && callback(x); + this.$success(x.message); + this.refresh(); + }); + }, + viewModelCancel() { + //鏌ョ湅琛ㄧ粨鏋� + this.viewModel = false; + }, + initFormOptions(formOptions, keys, formFields, isEdit) { + //鍒濆鍖栨煡璇€�佺紪杈戝璞$殑涓嬫媺妗嗘暟鎹簮銆佸浘鐗囦笂浼犻摼鎺ュ湴鍧� + //let defaultOption = { key: "", value: "璇烽�夋嫨" }; + //鏈変笂浼犵殑瀛楁 + //2020.05.03鏂板 + //缂栬緫鏁版嵁婧愮殑绫诲瀷 + formOptions.forEach((item) => { + item.forEach((d) => { + if (d.type == 'number') { + //2022.08.22浼樺寲琛ㄥ崟绫诲瀷涓簄umber鏃剁殑榛樿鍊� + if (formFields[d.field] === '') { + formFields[d.field] = undefined; + } + this.numberFields.push(d.field); + } + if ( + d.type == 'img' || + d.type == 'excel' || + d.type == 'file' || + d.columnType == 'img' + ) { + d.url = this.http.ipAddress + 'api' + this.table.url + 'Upload'; + this.uploadfiled.push(d.field); + } + if (!d.dataKey) return true; + //2022.02.20寮哄埗寮�鍚仈绾у彲浠ラ�夋嫨鏌愪釜鑺傜偣 + if (d.type == 'cascader' && !d.hasOwnProperty('changeOnSelect')) { + //寮哄埗寮�鍚仈绾у彲浠ラ�夋嫨鏌愪釜鑺傜偣 + d.changeOnSelect = true; + } + //寮�鍚繙绋嬫悳绱� + if (d.remote) { + this.remoteKeys.push(d.dataKey); + d.data = []; //{ dicNo: d.dataKey, data: [] }; + return true; + } + //2020.05.03澧炲姞缂栬緫琛ㄥ崟瀵筩heckbox鐨勬敮鎸� + if (d.type == 'checkbox' && !(formFields[d.field] instanceof Array)) { + formFields[d.field] = []; + } + if (keys.indexOf(d.dataKey) == -1) { + //2020.05.03澧炲姞璁板綍缂栬緫瀛楁鐨勬暟鎹簮绫诲瀷 + + keys.push(d.dataKey); + //2020.05.03淇鏌ヨ琛ㄥ崟涓庣紪杈戣〃鍗晅ype绫诲瀷鍙樻垚寮轰竴鑷存�х殑闂 + //this.dicKeys.push({ dicNo: d.dataKey, data: [], type: d.type }); + // 2020.11.01澧炲姞iview缁勪欢Cascader鏁版嵁婧愬瓨鍌� + let _dic = { + dicNo: d.dataKey, + data: [], + fileds: [d.field], + orginData: [] + }; + if (d.type == 'cascader') { + _dic.type = 'cascader'; + } + if (isEdit) { + _dic['e_type'] = d.type; + } + this.dicKeys.push(_dic); + } else if (d.type == 'cascader') { + this.dicKeys.forEach((x) => { + if (x.dicNo == d.dataKey) { + x.type = 'cascader'; + x.fileds.push(d.field); + } + }); + } + if (d.type != 'cascader') { + //2020.01.30绉婚櫎鍐呴儴琛ㄥ崟formOptions鏁版嵁婧愰厤缃牸寮廳ata.data锛屾墍鏈夊弬鏁版敼涓轰笌缁勪欢api鏍煎紡鐩稿悓 + Object.assign( + d, + this.dicKeys.filter((f) => { + return f.dicNo == d.dataKey; + })[0], + { type: d.type } + ); + } + }); + }); + }, + //鍒濆table涓庢槑缁嗚〃鐨勬暟鎹簮鎸囧悜dicKeys瀵硅薄锛屽啀鍘诲悗鍙板姞杞芥暟鎹簮 + initColumns(scoure, dicKeys, keys) { + if (!scoure || !(scoure instanceof Array)) return; + scoure.forEach((item) => { + if (!item.bind || (item.bind.data && item.bind.data.length > 0)) + return true; + let key = item.bind.key || item.bind.dicNo; + if (this.remoteKeys.indexOf(key) != -1) { + item.bind.remote = true; + return true; + } + if (this.hasKeyField.indexOf(item.field) == -1) { + this.hasKeyField.push(item.field); + } + var dic = dicKeys.filter((x) => { + return x.dicNo == key; + }); + if (!dic || dic.length == 0) { + dicKeys.push({ dicNo: key, data: [] }); + dic = [dicKeys[dicKeys.length - 1]]; + keys.push(key); + } + //2020.11.01澧炲姞绾ц仈澶勭悊 + if (dic[0].type == 'cascader' || dic[0].type == 'treeSelect') { + item.bind = { data: dic[0].orginData, type: 'select', key: key }; + } else { + item.bind = dic[0]; + } + //2020.05.03浼樺寲table鏁版嵁婧恈heckbox涓巗elect绫诲瀷浠庣紪杈戝垪涓�夊彇 + item.bind.type = item.bind.e_type || 'string'; + }); + }, + bindOptions(dic) { + //缁戝畾涓嬫媺妗嗙殑鏁版嵁婧� + //缁戝畾鍚庡彴鐨勫瓧鍏告暟鎹� + dic.forEach((d) => { + if (d.data.length >= (this.select2Count || 500)) { + if ( + !this.dicKeys.some((x) => { + return ( + x.dicNo == d.dicNo && + (x.type == 'cascader' || x.type == 'treeSelect') + ); + }) + ) { + d.data.forEach((item) => { + item.label = item.value; + item.value = item.key; + }); + } + } + this.dicKeys.forEach((x) => { + if (x.dicNo != d.dicNo) return true; + //2020.10.26澧炲姞绾ц仈鏁版嵁婧愮粦瀹氬鐞� + if (x.type == 'cascader' || x.type == 'treeSelect') { + // x.data=d.data; + //鐢熸垚tree缁撴瀯 + let _data = JSON.parse(JSON.stringify(d.data)); + //2022.04.04澧炲姞绾ц仈瀛楀吀鏁版嵁婧愬埛鏂板悗table娌℃湁鍙樺寲鐨勯棶棰� + this.columns.forEach((column) => { + if (column.bind && column.bind.key == d.dicNo) { + column.bind.data = d.data; + } + }); + let arr = this.base.convertTree(_data, (node, data, isRoot) => { + if (!node.inited) { + node.inited = true; + node.label = node.value; + node.value = node.key; + } + }); + x.data.push(...arr); + x.orginData.push(...d.data); + //2021.10.17淇鏌ヨ绾ц仈涓嶈兘缁戝畾鏁版嵁婧愮殑闂 + this.searchFormOptions.forEach((searhcOption) => { + searhcOption.forEach((_option) => { + if (_option.type == 'cascader' && _option.dataKey == x.dicNo) { + _option.data = arr; + _option.orginData = d.data; + } + }); + }); + //2021.10.17淇绾ц仈涓嶈兘浜岀骇鍒锋柊鐨勯棶棰� + this.editFormOptions.forEach((editOption) => { + editOption.forEach((_option) => { + if ( + (_option.type == 'cascader' || _option.type == 'treeSelect') && + _option.dataKey == x.dicNo + ) { + _option.data = arr; + _option.orginData = d.data; + } + }); + }); + } else if (d.data.length > 0 && !d.data[0].hasOwnProperty('key')) { + let source = d.data, + newSource = new Array(source.length); + for (let index = 0; index < source.length; index++) { + newSource[index] = { + //榛樿浠庡瓧鍏告暟鎹鍑烘潵鐨刱ey閮芥槸string绫诲瀷,浣嗗鏋滄暟鎹粠sql涓煡璇㈢殑鍙兘涓洪潪string,鍚︽槸async-validator闇�瑕侀噸缃缃牸寮� + key: source['key'] + '', //source[index][x.config.valueField] + "", + value: source['value'] //source[index][x.config.textField] + }; + } + + x.data.push(...newSource); + } else { + //2020.06.06锛屽鏋滄槸selectList鏁版嵁婧愪娇鐢ㄧ殑鑷畾涔塻ql骞朵笖key鏄暟瀛楋紝寮哄埗杞崲鎴愬瓧绗︿覆 + if ( + x.e_type == 'selectList' && + d.data.length > 0 && + typeof d.data[0].key == 'number' + ) { + d.data.forEach((c) => { + c.key = c.key + ''; + }); + } + x.data.push(...d.data); + } + if ( + this.singleSearch && + this.singleSearch.dataKey && + this.singleSearch.dataKey == x.dicNo + ) { + this.singleSearch.data.splice(0, 1, ...x.data); + } + }); + }); + }, + getUrl(action, ingorPrefix) { + //鏄惁蹇界暐鍓嶇紑/ 鑾峰彇鎿嶄綔鐨剈rl + return (!ingorPrefix ? '/' : '') + 'api' + this.table.url + action; + }, + + initDicKeys() { + //鍒濆鍖栧瓧鍏告暟鎹� + let keys = []; + //2022.04.17浼樺寲閲嶆柊鍔犺浇鏁版嵁婧� + this.dicKeys.forEach((item) => { + item.data.splice(0); + item.orginData && item.orginData.splice(0); + }); + //this.dicKeys.splice(0); + //鍒濆鍖栫紪杈戞暟鎹簮,榛樿涓轰竴涓┖鏁扮粍锛屽鏋滆姹傚繀濉缃畉ype=number/decimal鐨勬渶灏忓�� + this.initFormOptions(this.editFormOptions, keys, this.editFormFields, true); + //鍒濆鍖栨煡璇㈡暟鎹簮,榛樿涓轰竴涓┖鏁扮粍 + this.initFormOptions( + this.searchFormOptions, + keys, + this.searchFormFields, + false + ); + //鏌ヨ鏃ユ湡璁剧疆涓哄彲閫夊紑濮嬩笌缁撴灉鏃ユ湡 + this.searchFormOptions.forEach((item) => { + item.forEach((x) => { + if (x.type == 'date' || x.type == 'datetime') x.range = true; + }); + }); + //鍒濆鍖杁atatable琛ㄦ暟鎹簮,榛樿涓轰竴涓┖鏁扮粍,dicKeys涓虹晫闈㈡墍鏈夌殑鏁版嵁瀛楀吀缂栧彿 + this.initColumns(this.columns, this.dicKeys, keys); + //2021.05.23榛樿寮�鍚煡璇㈤〉闈㈡墍鏈夊瓧娈垫帓搴�,濡傛灉涓嶉渶瑕佹帓搴忥紝鍦╫nInited閬嶅巻columns璁剧疆sort=false + //2021.09.25绉婚櫎寮哄埗鎺掑簭鍔熻兘 + // this.columns.forEach(x => { + // x.sort = x.render ? false : true; + // }) + if (this.detailOptions && this.detailOptions.columns) { + this.initColumns(this.detailOptions.columns, this.dicKeys, keys); + } + //鍒濆鍖栧揩閫熸煡璇㈠瓧娈�,榛樿浣跨敤浠g爜鐢熸垚鍣ㄩ厤缃殑绗竴涓煡璇㈠瓧娈� + if (this.searchFormOptions.length > 0) { + this.singleSearch = { + dataKey: this.searchFormOptions[0][0].dataKey, + dicNo: this.searchFormOptions[0][0].dicNo, + field: this.searchFormOptions[0][0].field, + title: this.searchFormOptions[0][0].title, + type: this.searchFormOptions[0][0].type, + data: [] + }; + // this.singleSearch = this.searchFormOptions[0][0]; + } + if (keys.length == 0) return; + let $this = this; + this.http.post('/api/Sys_Dictionary/GetVueDictionary', keys).then((dic) => { + + $this.bindOptions(dic); + //2022.04.04澧炲姞瀛楀吀鍔犺浇瀹屾垚鏂规硶 + $this.dicInited && $this.dicInited(dic); + }); + }, + setFiexdColumn(columns, containerWidth) { + //璁$畻鏁翠釜table鐨勫搴︼紝鏍规嵁瀹藉害鍐冲畾鏄惁鍚敤绗竴琛屾樉绀虹殑鍒椾负鍥哄畾鍒� + //2021.09.21绉婚櫎寮哄埗鍥哄畾绗竴鍒� + // let columnsWidth = 0; + // columns.forEach(x => { + // if (!x.hidden && x.width) { + // columnsWidth += x.width; + // } + // }); + // //鍚敤绗竴鍒椾负鍥哄畾鍒� + // if (columnsWidth > containerWidth) { + // let firstColumn = columns.find(x => !x.hidden); + // if (firstColumn) { + // firstColumn.fixed = true; + // } + // } + }, + initBoxHeightWidth() { + //鍒濆鍖栧脊鍑烘鐨勯珮搴︿笌瀹藉害 + let clientHeight = document.documentElement.clientHeight; + //寮瑰嚭妗嗛珮搴﹁嚦灏�250px + clientHeight = clientHeight < 250 ? 250 : clientHeight; + let clientWidth = document.documentElement.clientWidth; + if ( + this.editFormOptions.some((x) => { + return x.some((item) => { + return item.type == 'editor'; + }); + }) + ) { + this.editor.uploadImgUrl = this.getUrl('upload'); + this.boxOptions.height = clientHeight * 0.8; + this.boxOptions.width = clientWidth * 0.8; + } else { + if (this.boxOptions.height) { + //濡傛灉楂樺害涓庡搴﹁秴杩囦簡鑾峰彇鍒扮殑鍙楂樺搴︼紝鍒欒涓洪粯璁ょ殑90%楂樺 + if (this.boxOptions.height > clientHeight * 0.8) { + this.boxOptions.height = clientHeight * 0.8; + } + } + if (this.boxOptions.width) { + //濡傛灉楂樺害涓庡搴﹁秴杩囦簡鑾峰彇鍒扮殑鍙楂樺搴︼紝鍒欒涓洪粯璁ょ殑90%楂樺 + if (this.boxOptions.width > clientWidth * 0.8) { + this.boxOptions.width = clientWidth * 0.8; + } + } + } + //璁$畻鏁翠釜table鐨勫搴︼紝鏍规嵁瀹藉害鍐冲畾鏄惁鍚敤绗竴琛屾樉绀虹殑鍒椾负鍥哄畾鍒� + let maxTableWidth = clientWidth - 270; + this.setFiexdColumn(this.columns, maxTableWidth); + + this.height = this.tableHeight || clientHeight - 206; + this.url = this.getUrl(this.const.PAGE); + //璁$畻寮瑰嚭妗嗙殑楂樹笌瀹藉害 + //濡傛灉鏈夋槑缁嗚〃锛岄珮搴︿笌瀹藉甫璁剧疆涓�0.9/0.82 + if (this.detail.columns && this.detail.columns.length > 0) { + this.hasDetail = true; + clientWidth = clientWidth * 0.8; + clientHeight = clientHeight * 0.85; + if (!this.detailOptions.height) { + this.detailOptions.height = + clientHeight - this.editFormOptions.length * 36 - 234; + this.detailOptions.height = + this.detailOptions.height < 240 ? 240 : this.detailOptions.height; + } + + this.detailOptions.columns = this.detail.columns; + this.detailOptions.pagination.sortName = this.detail.sortName; + this.detailOptions.cnName = this.detail.cnName; + this.detailOptions.key = this.detail.key; + this.detailOptions.url = this.getUrl('getDetailPage'); + //璁$畻寮瑰嚭妗嗘暣涓猼able鐨勫搴︼紝鏍规嵁瀹藉害鍐冲畾鏄惁鍚敤绗竴琛屾樉绀虹殑鍒椾负鍥哄畾鍒� + this.setFiexdColumn(this.detail.columns, clientWidth); + } else { + let maxColumns = 1; //鏈�澶у垪鏁帮紝鏍规嵁鍒楄绠楀脊妗嗙殑瀹藉害 + this.editFormOptions.forEach((x) => { + if (x.length > maxColumns) maxColumns = x.length; + }); + let maxHeightRate = 0.7, + maxWidthRate = 0.5; + maxWidthRate = maxColumns / 10 + 0.3; + maxHeightRate = (this.editFormOptions.length || 1) * 0.1 + 0.03; + maxHeightRate = maxHeightRate > 0.9 ? 0.9 : maxHeightRate; + clientWidth = clientWidth * maxWidthRate; + clientHeight = clientHeight * maxHeightRate; + // this.boxOptions.width = clientWidth * maxWidthRate; + // this.boxOptions.height = clientHeight * maxHeightRate; + } + if (!this.boxOptions.height) { + this.boxOptions.height = clientHeight + 10; + } + if (!this.boxOptions.width) { + this.boxOptions.width = clientWidth + 30; + } + }, + rowOnChange(row) { + this.rowChange(row); + }, + rowChange(row) { + //閫変腑琛宑heckbox琛屼簨浠� + }, + rowOnClick({ row, column, event }) { + this.rowClick({ row, column, event }); + }, + rowClick({ row, column, event }) { + // 鐐瑰嚮琛屼簨浠�(2020.11.07) + }, + rowOnDbClick({ row, column, event }) { + this.rowDbClick({ row, column, event }); + }, + rowDbClick({ row, column, event }) { + // 鍙屽嚮鍑昏浜嬩欢(2021.05.23) + }, + $error(message) { + this.$message.error(message); + // this.$message({ + // type: 'error', + // content: message, + // duration: 5 + // }); + }, + $success(message) { + this.$message.success(message); + }, + setFiexdSearchForm(visiable) { + //2020.09.011澧炲姞鍥哄畾鏌ヨ琛ㄥ崟鍔熻兘,visiable=true榛樿灏嗘煡璇㈣〃鍗曞睍寮� + this.fiexdSearchForm = true; + let refreshBtn = this.buttons.find((x) => x.name == '鍒� 鏂�'); + if (visiable) { + this.searchBoxShow = true; + } + if (refreshBtn) { + refreshBtn.name = '閲� 缃�'; + refreshBtn.onClick = function () { + this.resetSearch(); + }; + } + }, + tableBeginEdit(row, column, index) { + //2021.03.19鏄惁寮�鍚煡璇㈢晫闈㈣〃鏍煎弻鍑荤紪杈戠粨鏉熸柟娉�,杩斿洖false涓嶄細缁撴潫缂栬緫 + return this.beginEdit(row, column, index); + }, + beginEdit(row, column, index) { + //2021.03.19鏄惁寮�鍚煡璇㈢晫闈㈣〃鏍煎弻鍑荤紪杈戠粨鏉熸柟娉�,杩斿洖false涓嶄細缁撴潫缂栬緫 + return true; + }, + tableEndEditBefore(row, column, index) { + return this.endEditBefore(row, column, index); + }, + endEditBefore(row, column, index) { + //2021.03.19鏄惁寮�鍚煡璇㈢晫闈㈣〃鏍煎弻鍑荤紪杈戠粨鏉熸柟娉�,杩斿洖false涓嶄細缁撴潫缂栬緫 + return true; + }, + filterPermission(tableName, permission) { + //2021.03.19鍒ゆ柇鏄惁鏈夋煇涓〃鐨勬寜閽潈闄� + //:["Search","Add","Delete","Update","Import","Export","Upload","Audit"] + const _result = (this.$store.state.permission || []).find((x) => { + return x.url == '/' + tableName; + }); + return _result && _result.permission.some((x) => x == permission); + }, + destroyed() { + //2021.04.11澧炲姞vue椤甸潰閿�姣佹柟娉�,璺敱蹇呴』璁剧疆keepLive:false锛岃缃柟娉曡锛氬墠绔紑鍙戞枃妗�-銆媅绂佺敤椤甸潰缂撳瓨keepAlive] + }, + loadTreeTableChildren(tree, treeNode, resolve) { + this.loadTreeChildren.call(this, tree, treeNode, resolve); + }, + loadTreeChildren(tree, treeNode, resolve) { + //鏍戝舰缁撴瀯鍔犺浇瀛愯妭鐐�(2021.05.02),鍦╫nInit涓缃簡rowKey涓婚敭瀛楁鍚庢墠浼氱敓鏁� + return resolve([]); + }, + importDetailAfter(data) { + //2022.01.08澧炲姞鏄庣粏琛ㄥ鍏ュ悗澶勭悊 + }, + importExcelAfter(data) { + //2022.01.08澧炲姞鏄庣粏琛ㄥ鍏ュ悗鏂规硶鍒ゆ柇 + + if (!data.status) { + return; // this.$message.error(data.message); + } + //鏄庣粏琛ㄥ鍏� + if (this.boxModel) { + if (data.data) { + data.data = JSON.parse(data.data); + } else { + data.data = []; + } + data.data.forEach((x) => { + x[this.detail.key] = undefined; + x[this.table.key] = undefined; + }); + this.importDetailAfter(data); //澧炲姞鏄庣粏琛ㄥ鍏ュ悗澶勭悊 + this.$refs.detail.rowData.unshift(...data.data); + this.upload.excel = false; + return; + } + this.importAfter(data); + }, + onGridModelClose(iconClick) { + if (this.isBoxAudit) { + this.initFormOptionType(false); + } + this.isBoxAudit = false; + this.onModelClose(iconClick); + }, + initAuditColumn() { + + }, + getWorkFlowSteps(row) { + let table = this.table.url.replaceAll('/', ''); + let url = `api/Sys_WorkFlow/getSteps?tableName=${table}&id=${row[this.table.key] + }`; + this.http.get(url, {}, true).then((result) => { + this.workFlowSteps.splice(0); + //鏈夊彲鑳芥病鏈夐厤缃鎵规祦绋� + if (!result.list || !result.list.length) { + result.list = []; + this.auditParam.showAction = true; + this.auditParam.height = 240; + this.auditParam.showViewButton = row.AuditStatus == 0; + } else { + this.auditParam.showAction = result.list.some((c) => { + return c.isCurrentUser; + }); + this.auditParam.height = 511; + this.auditParam.showViewButton = true; + } + this.auditParam.reason = ''; + this.auditParam.status = -1; + this.auditParam.value = -1; + if (result.his) { + result.his.forEach((item) => { + item.auditStatus = this.getAuditStatus(item.auditStatus); + }); + } + + this.auditParam.auditHis = result.his; + this.workFlowSteps.push(...result.list); + this.isBoxAudit = true; + this.initFormOptionType(true); + this.edit(row); + this.boxOptions.title = '瀹℃牳'; + }); + }, + initFormOptionType(isReadonly) { + this.editFormOptions.forEach((options) => { + options.forEach((option) => { + if (isReadonly) { + if (!option.readonly) { + this.formFieldsType.push(option.field); + option.readonly = true; + } + } else { + if (this.formFieldsType.indexOf(option.field) != -1) { + option.readonly = false; + } + } + }); + }); + }, + getAuditStatus(status) { + let data = this.auditParam.data.find((x) => { + return x.value == status; + }); + if (!data) { + return '-'; + // return `瀹℃牳鍊间笉姝g‘:${status}` + } + return data.text; + }, + initFlowQuery() { + if (this.$route.query.viewflow) { + this.$refs.table && this.search(); + } + }, + fullscreen(full) { //寮瑰嚭妗嗗叏灞忔柟娉� + + } +}; +import customColumns from './ViewGridCustomColumn.js'; +//鍚堝苟鎵╁睍鏂规硶 +methods = Object.assign(methods, detailMethods, serviceFilter, customColumns); +export default methods; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/props.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/props.js" new file mode 100644 index 0000000..5d0ebc6 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/props.js" @@ -0,0 +1,55 @@ +let props = { + columns: {//褰撳墠琛ㄧ殑閰嶇疆淇℃伅 + type: Array, + default: () => { + return []; + } + }, + detail: {//浠庤〃鏄庣粏閰嶇疆 + type: Object, + default: () => { + return { + columns: [],//浠庤〃鍒� + sortName: ""//浠庤〃鎺掑簭瀛楁 + }; + } + }, + editFormFields: {//鏂板缓銆佺紪杈戝瓧娈�(key/value) + type: Object, + default: () => { + return {}; + } + }, + editFormOptions: {//鏂板缓銆佺紪杈戦厤缃俊鎭� + type: Array, + default: () => { + return []; + } + }, + searchFormFields: {//鏌ヨ瀛楁(key/value) + type: Object, + default: () => { + return {}; + } + }, + searchFormOptions: {//鏌ヨ閰嶇疆淇℃伅(key/value) + type: Array, + default: () => { + return []; + } + }, + table: {//琛ㄧ殑閰嶇疆淇℃伅锛氫富閿�佹帓搴忕瓑 + type: Object, + default: () => { + return {}; + } + }, + extend: {//琛ㄧ殑鎵╁睍鏂规硶涓庣粍浠堕兘鍚堝苟鍒版灞炴�т腑 + type: Object, + default: () => { + return {}; + } + } +} + +export default props; \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/serviceFilter.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/serviceFilter.js" new file mode 100644 index 0000000..5d3b21f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/ViewGrid/serviceFilter.js" @@ -0,0 +1,109 @@ + + +let serviceFilter = { + onInit () { //瀵瑰簲created + console.log('Create鎵ц鍓�') + }, + onInited () { //瀵瑰簲created锛屽湪onInit涓巓nInited涓棿浼氬垵濮嬪寲鐣岄潰鏁版嵁瀵硅薄 + console.log('Create鎵ц鍚�') + }, + mounted () { + console.log('mounted'); + }, + searchBefore (param) { //鏌ヨViewGird琛ㄦ暟鎹墠,param鏌ヨ鍙傛暟 + // console.log('琛�' + this.table.cnName + '瑙﹀彂loadTableBefore'); + return true; + }, + //2020.10.30澧炲姞鏌ヨ鍚庤繑鍥炴墍鏈夌殑鏌ヨ淇℃伅 + searchAfter (param, result) { //鏌ヨViewGird琛ㄦ暟鎹悗param鏌ヨ鍙傛暟,result鍥炶繑鏌ヨ鐨勭粨鏋� + // console.log('琛�' + this.table.cnName + '瑙﹀彂loadTableAfter'); + return true; + }, + searchDetailBefore (param) {//鏌ヨ浠庤〃琛ㄦ暟鎹墠,param鏌ヨ鍙傛暟 + //console.log(this.detailOptions.cnName + '瑙﹀彂loadDetailTableBefore'); + return true; + }, + searchDetailAfter (param, data) {//鏌ヨ浠庤〃鍚巔aram鏌ヨ鍙傛暟,result鍥炶繑鏌ヨ鐨勭粨鏋� + // console.log(this.detailOptions.cnName + '瑙﹀彂loadDetailTableAfter'); + return true; + }, + delBefore (ids, rows) { //鏌ヨ鐣岄潰鐨勮〃鍒犻櫎鍓� ids涓哄垹闄ょ殑id鏁扮粍,,rows鍒犻櫎鐨勮 + return true; + }, + delAfter (result) {//鏌ヨ鐣岄潰鐨勮〃鍒犻櫎鍚� + return true; + }, + delDetailRow (rows) { //寮瑰嚭妗嗗垹闄ゆ槑缁嗚〃鐨勮鏁版嵁(鍙槸瀵箃able鎿嶄綔锛屽苟娌℃湁鎿嶄綔鍚庡彴) + return true; + }, + addBefore (formData) { //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛� + return true; + }, + async addBeforeAsync (formData) { //寮傛澶勭悊,鍔熻兘鍚屼笂(2020.12.06) + return true; + }, + addAfter (result) {//鏂板缓淇濆瓨鍚巖esult杩斿洖鐨勭姸鎬佸強琛ㄥ崟瀵硅薄 + return true; + }, + updateBefore (formData) { //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + async updateBeforeAsync (formData) { //寮傛澶勭悊,鍔熻兘鍚屼笂(2020.12.06) + return true; + }, + updateAfter (result) {//缂栬緫淇濆瓨鍚巖esult杩斿洖鐨勭姸鎬佸強琛ㄥ崟瀵硅薄 + return true; + }, + auditBefore (ids, rows) {//瀹℃牳鍓� + return true; + }, + auditAfter (result, rows) {// 瀹℃牳鍚� + return true; + }, + resetAddFormBefore () { //閲嶇疆鏂板缓琛ㄥ崟鍓嶇殑鍐呭 + return true; + }, + resetAddFormAfter () { //閲嶇疆鏂板缓琛ㄥ崟鍚庣殑鍐呭 + return true; + }, + resetUpdateFormBefore () { //閲嶇疆缂栬緫琛ㄥ崟鍓嶇殑鍐呭 + return true; + }, + resetUpdateFormAfter () { //閲嶇疆缂栬緫琛ㄥ崟鍚庣殑鍐呭 + return true; + }, + modelOpenBefore (row) { //鐐瑰嚮缂栬緫/鏂板缓鎸夐挳寮瑰嚭妗嗗墠锛屽彲浠ュ湪姝ゅ鍐欓�昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + + }, + modelOpenAfter (row) { //鐐瑰嚮缂栬緫/鏂板缓鎸夐挳寮瑰嚭妗嗗悗锛屽彲浠ュ湪姝ゅ鍐欓�昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + + }, + importAfter (data) { //瀵煎叆excel鍚庡埛鏂皌able琛ㄦ牸鏁版嵁 + this.search(); + }, + //2020.10.31娣诲姞瀵煎叆鍓嶇殑鏂规硶 + importExcelBefore (formData) { //瀵煎叆excel瀵煎叆鍓� + //寰�formData鍐欎竴浜涘叾浠栧弬鏁版彁浜ゅ埌鍚庡彴锛� + // formData.append("val2", "xxx"); + //鍚庡彴鎸変笅闈㈡柟娉曡幏鍙栬姹傜殑鍙傛暟 + // Core.Utilities.HttpContext.Current.Request("val2"); + return true; + }, + reloadDicSource () { //閲嶆柊鍔犺浇瀛楀吀缁戝畾鐨勬暟鎹簮 + this.initDicKeys(); + }, + exportBefore (param) { //2020.06.25澧炲姞瀵煎嚭鍓嶅鐞� + return true; + }, + onModelClose(iconClick){ + //iconClick=true涓虹偣鍑诲乏涓笂瑙扻瑙﹀彂鐨勫叧闂簨浠� + //濡傛灉杩斿洖 false涓嶄細鍏抽棴寮瑰嚭妗� + //return false; + this.boxModel=false; + }, + selectable(row, index){ + //琛–heckBox 鏄惁鍙互鍕鹃�� + return true; + } +} +export default serviceFilter; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolBox.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolBox.vue" new file mode 100644 index 0000000..8893643 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolBox.vue" @@ -0,0 +1,200 @@ +<template> + <div class="vol-dialog"> + + <el-dialog v-model="vmodel" :close-on-click-modal="false" :close-on-press-escape="false" :width="width" + :fullscreen="fullscreen" :draggable="draggable" :modal="modal" :before-close="handleClose"> + <template #header> + <i :class="icon"></i> {{ title }} + <button class="el-dialog__headerbtn" type="button" style="right: 35px; color: var(--el-color-info)" @click="handleFullScreen"> + <i class="el-icon el-icon-full-screen"></i> + </button> + </template> + <el-scrollbar :max-height="contentHeight"> + <div v-if="inited" style="min-height: 50px;" class="srcoll-content" :style="{ padding: padding + 'px' }"> + <slot name="content"></slot> + <slot></slot> + </div> + </el-scrollbar> + <template #footer> + <div class="dia-footer" v-if="footer"> + <slot name="footer"></slot> + <el-button type="primary" v-if="!footer" size="mini" @click="handleClose()"><i + class="el-icon-close"></i>鍏抽棴</el-button> + </div> + </template> + </el-dialog> + </div> +</template> + +<script> +import { defineComponent, ref, watch, watchEffect } from 'vue'; + +export default defineComponent({ + props: { + modelValue: false, + lazy: { + //鏄惁寮�鍚噿鍔犺浇2020.12.06 + type: Boolean, + default: false, + }, + icon: { + type: String, + default: "el-icon-warning-outline", + }, + title: { + type: String, + default: "鍩烘湰淇℃伅", + }, + height: { + type: Number, + default: 200, + }, + width: { + type: Number, + default: 650, + }, + padding: { + type: Number, + default: 16, + }, + modal: { + //鏄惁闇�瑕侀伄缃╁眰 + type: Boolean, + default: true, + }, + draggable: { + //鍚敤鍙嫋鎷藉姛鑳� + type: Boolean, + default: false, + }, + mask: { + type: Boolean, + default: true, + }, + onModelClose: { + //2021.07.11澧炲姞寮瑰嚭妗嗗叧闂簨浠� + type: Function, + default: (iconClick) => { + return true; + } + }, + footer:{ //鏄惁鏄剧ず搴曢儴鎸夐挳 + type: Boolean, + default: true + } + + }, + setup(props, context) { + const clientHeight = document.body.clientHeight * 0.95 - 60; + const inited = ref(true); + const vmodel = ref(false); + const footer = ref(false); + const top = ref(100); + vmodel.value = props.modelValue; + footer.value = !!context.slots.footer; + const contentHeight = ref(200); + contentHeight.value = props.height; + const handleClose = (done, iconClose) => { + let result = props.onModelClose(!!iconClose); + if (result === false) return; + vmodel.value = false; + context.emit("update:modelValue", false); + done && done(); + }; + const calcHeight = (val) => { + // if (props.height > clientHeight) { + // if(true){ + contentHeight.value = clientHeight - 30; + return clientHeight / -2 + 'px'; + // } + // contentHeight.value = val || props.height; + // return (props.height + 56) / -2 + 'px'; + }; + top.value = calcHeight(); + watch( + () => props.modelValue, + (newVal, oldVal) => { + vmodel.value = newVal; + } + ); + watch( + () => props.height, + (newVal, oldVal) => { + top.value = calcHeight(); + } + ); + const fullscreen=ref(false); + const handleFullScreen=()=> { + fullscreen.value = !fullscreen.value; + context.emit("fullscreen", fullscreen.value); + } + return { + handleClose, + inited, + vmodel, + footer, + top, + calcHeight, + contentHeight, + fullscreen, + handleFullScreen + }; + } +}); +</script> + +<style lang="less" scoped> +.dia-footer { + text-align: right; + width: 100%; + border-top: 1px solid #e2e2e2; + text-align: right; + padding: 6px 8px; +} +</style> + +<style scoped lang="less"> +.vol-dialog ::v-deep(.el-overlay-dialog) { + display: flex !important; +} + +.vol-dialog ::v-deep(.el-dialog) { + margin: auto; +} + +.vol-dialog ::v-deep(.el-dialog) { + border-top-left-radius: 4px; + border-top-right-radius: 4px; +} + +.vol-dialog ::v-deep(.el-dialog__header) { + border-top-left-radius: 4px; + border-top-right-radius: 4px; + padding: 0px 13px; + line-height: 53px; + border-bottom: 1px solid #e6e6e6; + height: 50px; + color: rgb(79, 79, 79); + font-weight: bold; + font-size: 14px; + margin: 0; + // background-image: linear-gradient(135deg, #0cd7bd 10%, #50c3f7); +} + +.vol-dialog ::v-deep(.el-dialog__footer), +.vol-dialog ::v-deep(.el-dialog__body) { + padding: 0; +} + +.vol-dialog ::v-deep(.el-dialog__headerbtn) { + top: 0; + padding-top: 8px; + height: 50px; + width: 0; + padding-right: 30px; + padding-left: 5px; +} +// .vol-dialog ::v-deep(.el-dialog__headerbtn .el-dialog__close) { +// color: #fff; +// } +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolElementMenu.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolElementMenu.vue" new file mode 100644 index 0000000..66a9779 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolElementMenu.vue" @@ -0,0 +1,198 @@ +<template> + <div class="vol-el-menu"> + <el-menu + close="vol-el-menu--vertical" + :default-openeds="openedIds" + :default-active="defaultActive" + :unique-opened="true" + @select="select" + :collapse="isCollapse" + @open="handleOpen" + @close="handleClose" + @contextmenu.prevent="bindRightClickMenu" + > + <template v-for="item in convertTree(list)"> + <el-sub-menu + :key="item.id" + :index="'' + item.id" + v-if="item.children.length && (!enable || item.enable == 1)" + > + <template #title> + <i class="menu-icon" :class="item.icon"></i> + <span> {{ item.name }}</span> + </template> + <vol-element-menu-child + :enable="enable" + :list="item.children" + ></vol-element-menu-child> + </el-sub-menu> + <template v-else> + <el-menu-item + class="menu-item-lv1" + v-if="!enable || item.enable == 1" + :key="item.id" + :index="'' + item.id" + > + <i :class="item.icon"></i> + <span> {{ item.name }}</span> + </el-menu-item> + </template> + </template> + </el-menu> + </div> +</template> + +<script> +import VolElementMenuChild from './VolElementMenuChild'; +import { useRouter } from 'vue-router'; + +import { + defineComponent, + reactive, + watch, + ref, + toRef, + toRefs, + getCurrentInstance + // onMounted, +} from 'vue'; +export default defineComponent({ + components: { + 'vol-element-menu-child': VolElementMenuChild + }, + props: { + enable: { + type: Boolean, + default: false //鏄惁鍒ゆ柇enable=1 + }, + isCollapse: { + type: Boolean, + default: false + }, + onSelect: { + type: Function, + default: (x) => {} + }, + openSelect: { + //鎵撳紑鐨勬椂鍊欐槸鍚﹁Е鍙戦�変腑浜嬩欢 + type: Boolean, + default: true + }, + list: { + type: Array, + default: [] + }, + rootId: { + type: String, + default: '0' + }, + currentMenuId: { + type: Number, + default: 0 + } + }, + setup(props) { + // const { list } = toRefs(props); + // const treeList = ref([]); + const getTree = (id, node, data) => { + if (!node.children) { + node.children = []; + } + data.forEach((x) => { + if (x.parentId == id && !node.children.some((c) => c.id === x.id)) { + node.children.push(x); + getTree(x.id, x, data); + } + }); + }; + let rootTreeId = !isNaN(props.rootId) ? ~~props.rootId : props.rootId; + props.list.forEach((x) => { + if (!x.icon || x.icon.substring(0, 3) != 'el-') { + x.icon = 'el-icon-menu'; + } + x.children = []; + x.isRoot = x.parentId === rootTreeId; + }); + const convertTree = (data) => { + var root_data = []; + data.forEach((x) => { + if (x.parentId === rootTreeId) { + if (!x.hasOwnProperty('enable')) x.enable = 1; + root_data.push(x); + getTree(x.id, x, data); + } + }); + return root_data; + }; + const openedIds = reactive([props.currentMenuId]); + const defaultActive = ref(props.currentMenuId + ''); + let _base = getCurrentInstance().appContext.config.globalProperties.base; + watch( + () => props.currentMenuId, + (newVal, oldVal) => { + defaultActive.value = newVal + ''; + openedIds.splice(0); + openedIds.push( + ..._base.getTreeAllParent(newVal, props.list).map((c) => { + return c.id; + }) + ); + } + ); + const router = useRouter(); + let eventSelect = false; + const select = (index, path) => { + if (eventSelect) { + return; + } + eventSelect = true; + setTimeout(() => { + eventSelect = false; + }, 20); + + let _item = props.list.find((x) => { + return x.id == index; + }); + props.onSelect(index, _item); + router.push({ path: _item.path || '' }); + }; + + const handleOpen = (index, path) => { + if (props.openSelect) { + select(index, path); + } + }; + const handleClose = () => {}; + + /** + * 鑿滃崟瀵艰埅鍙抽敭浜嬩欢 + * @param {*} enable 鏄惁鍚敤鍙抽敭浜嬩欢[true:鍚敤;false:绂佺敤;] + */ + const bindRightClickMenu = (enable) => { + if (!enable) return; + }; + + return { + // treeList, + // list, + select, + convertTree, + handleOpen, + handleClose, + bindRightClickMenu, + openedIds, + defaultActive + }; + } +}); +</script> +<style lang="less" scoped> +.vol-el-menu { + box-sizing: content-box; + width: 100%; + .menu-icon { + font-size: 18px; + margin-right: 6px; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolElementMenuChild.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolElementMenuChild.vue" new file mode 100644 index 0000000..ccea321 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolElementMenuChild.vue" @@ -0,0 +1,56 @@ +<template> + <div class="vol-el-menu-item"> + <template v-for="(item) in list"> + <template v-if="item.children&&item.children.length"> + <el-menu-item :key="item.id" + :index="'' + item.id" + v-if="!item.children.length && (!enable || item.enable == 1)"> + <template #title></template> + <span> {{ item.name }}</span> + </el-menu-item> + <el-sub-menu :key="item.id" + :index="'' + item.id" + v-if="item.children.length && (!enable || item.enable == 1)"> + <template #title> + <span> {{ item.name }}</span> + </template> + <vol-element-menu-child :enable="enable" :list="item.children" /> + </el-sub-menu> + </template> + <template v-else> + <el-menu-item :key="item.id" + :index="'' + item.id" + v-if="(!enable || item.enable == 1)"> + <template #title></template> + <span> {{item.name }}</span> + </el-menu-item> + </template> + </template> + </div> +</template> + +<script> +export default { + name: "vol-element-menu-child", + props: { + list: { + type: Array, + default: [], + }, + enable: { + type: Boolean, + default: false, //鏄惁鍒ゆ柇enable=1 + }, + }, +}; +</script> + +<style scoped lang="less"> +.vol-el-menu-item ::v-deep(.el-menu-item) { + height: 42px !important; + line-height: 42px !important; +} +</style> + + + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolForm.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolForm.vue" new file mode 100644 index 0000000..3c54951 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolForm.vue" @@ -0,0 +1,1487 @@ +<template> + <el-form + style="display: inline-block; width: 100%" + :inline="true" + ref="volform" + @submit.prevent + :model="formFields" + :label-width="labelWidth" + :rules="rules" + > + <template v-for="(row, findex) in formRules" :key="findex"> + <div class="vol-form-item"> + <el-form-item + :label="item.title ? item.title + '锛�' : ''" + v-show="!item.hidden" + v-for="(item, index) in row" + :prop="item.field" + :key="item.field + index" + :style="{ width: getColWidth(item) + '%' }" + > + <!-- render --> + <form-expand + v-if="item.render && typeof item.render == 'function'" + :render="item.render" + :par="12" + ></form-expand> + <!-- 2021.10.17澧炲姞琛ㄥ崟瀹炴椂鏂规硶璁$畻 --> + <span + v-else-if=" + item.readonly && typeof formFields[item.field] == 'function' + " + >{{ formFields[item.field]() }}</span + > + <!-- 鍙鍥剧墖鎴栨枃浠� --> + <div v-else-if="isReadonlyImgFile(item, formFields)"> + <div v-if="item.type == 'img'" class="form-imgs"> + <div + class="img-item" + v-for="(img, imgIndex) in formFields[item.field]" + :key="imgIndex" + > + <img + :src="getSrc(img.path)" + :onerror="errorImg" + @click="previewImg(img.path)" + /> + </div> + </div> + <div + v-else + class="form-file-list" + v-for="(file, fileIndex) in formFields[item.field]" + :key="fileIndex" + > + <a @click="dowloadFile(formFields[item.field][fileIndex])">{{ + file.name + }}</a> + </div> + </div> + + <div v-else :class="{ 'form-item-extra': item.extra }"> + <!-- 鍙灞炴�� --> + <label + :style="item.inputStyle" + v-if="item.type == 'label'" + class="readonly-input" + >{{ getText(formFields, item) }}</label + > + <!-- 20223.05.13闆嗘垚el-tree-select --> + <!-- :filter-method="(value)=>{filterMethod(value,item.data)}" --> + <!-- :filterable="true" --> + <el-tree-select + style="width: 100%" + v-else-if="item.type == 'treeSelect'" + v-model="formFields[item.field]" + :data="item.data" + :multiple="item.multiple" + :render-after-expand="false" + :show-checkbox="false" + :check-strictly="true" + check-on-click-node + node-key="key" + :props="{ label: 'label' }" + > + <template #default="{data,node }"> + <!-- <el-checkbox v-model="node.checked"></el-checkbox> --> + <!-- {{getNode(node, data)}} --> + <!-- {{node.checked}} --> + <!-- 杩欓噷杩樻湁鐐归棶棰橈紝鍚庨潰澶勭悊 --> + {{ data.label}}</template + > + </el-tree-select> + <template + v-else-if="['select', 'selectList'].indexOf(item.type) != -1" + > + <el-select-v2 + :disabled="item.readonly || item.disabled" + v-show="!item.hidden" + style="width: 100%" + :size="size" + v-if="item.data.length > select2Count" + v-model="formFields[item.field]" + filterable + :multiple="item.type == 'select' ? false : true" + :placeholder="item.placeholder ? item.placeholder : item.title" + :allow-create="item.autocomplete" + :options="item.data" + @change=" + (val) => { + item.onChange(val, item.data); + } + " + clearable + > + <template #default="{ item }"> + {{ item.label }} + </template> + </el-select-v2> + <el-select + :disabled="item.readonly || item.disabled" + v-show="!item.hidden" + style="width: 100%" + :size="size" + v-else-if="item.remote || item.url" + v-model="formFields[item.field]" + filterable + :multiple="item.type == 'select' ? false : true" + :placeholder="item.placeholder ? item.placeholder : item.title" + clearable + :remote-method=" + (val) => { + remoteSearch(item, formFields, val); + } + " + > + <el-option + v-for="item in item.data" + :key="item.key" + :label="item.value" + :value="item.key" + > + </el-option> + </el-select> + <el-select + :disabled="item.readonly || item.disabled" + v-show="!item.hidden" + style="width: 100%" + :size="size" + v-else + v-model="formFields[item.field]" + filterable + :multiple="item.type == 'select' ? false : true" + :placeholder="item.placeholder ? item.placeholder : item.title" + :allow-create="item.autocomplete" + @change=" + (val) => { + item.onChange(val, item.data); + } + " + clearable + > + <el-option + v-show="!item.hidden" + :disabled="item.disabled" + v-for="item in item.data" + :key="item.key" + :label="item.value" + :value="item.key" + > + </el-option> + </el-select> + </template> + + <el-switch + v-show="!item.hidden" + v-else-if="item.type == 'switch'" + v-model="formFields[item.field]" + :disabled="item.readonly || item.disabled" + active-color="#0f84ff" + @change="item.onChange" + inactive-color="rgb(194 194 194)" + :active-value=" + typeof formFields[item.field] == 'boolean' + ? true + : typeof formFields[item.field] == 'string' + ? '1' + : 1 + " + :inactive-value=" + typeof formFields[item.field] == 'boolean' + ? false + : typeof formFields[item.field] == 'string' + ? '0' + : 0 + " + > + </el-switch> + + <el-radio-group + :disabled="item.readonly || item.disabled" + v-show="!item.hidden" + v-model="formFields[item.field]" + v-else-if="item.type == 'radio'" + @change="item.onChange" + > + <el-radio + v-for="kv in item.data" + :disabled="item.readonly || item.disabled" + :key="kv.key" + :label="kv.key" + >{{ kv.value }}</el-radio + > + </el-radio-group> + + <el-checkbox-group + :disabled="item.readonly || item.disabled" + v-show="!item.hidden" + v-model="formFields[item.field]" + v-else-if="item.type == 'checkbox'" + @change="item.onChange" + > + <el-checkbox + v-for="kv in item.data" + :key="kv.key" + :disabled="item.readonly || item.disabled" + :label="kv.key" + >{{ kv.value }}</el-checkbox + > + </el-checkbox-group> + <div + class="v-date-range" + style="display: flex" + v-else-if=" + ['date', 'datetime'].indexOf(item.type) != -1 && item.range + " + > + <el-date-picker + :size="size" + :disabled="item.readonly || item.disabled" + style="flex: 1; width: auto" + v-model="formFields[item.field][0]" + :type="item.type == 'date' ? 'date' : 'datetime'" + :disabledDate="(val) => getDateOptions(val, item)" + placeholder="寮�濮嬫椂闂�" + @change=" + (val) => { + dateRangeChange(val, item); + } + " + :value-format="getDateFormat(item)" + > + </el-date-picker> + <span style="margin: 0px 5px; font-size: 13px; color: #6f6b6b" + >鑷�</span + > + <el-date-picker + :size="size" + :disabled="item.readonly || item.disabled" + style="flex: 1; width: auto" + v-model="formFields[item.field][1]" + placeholder="缁撴潫鏃堕棿" + :type="item.type == 'date' ? 'date' : 'datetime'" + :disabledDate="(val) => getDateOptions(val, item)" + @change=" + (val) => { + dateRangeChange(val, item); + } + " + :value-format="getDateFormat(item)" + > + </el-date-picker> + </div> + <!-- v-show涓嶆坊鍔犳牴鑺傜偣灏变細鎶ラ敊娌℃湁鏍圭偣鑺� --> + <div + v-show="!item.hidden" + style="width: 100%" + v-else-if="['date', 'datetime', 'month'].indexOf(item.type) != -1" + > + <el-date-picker + :size="size" + clearable + :disabled="item.readonly || item.disabled" + style="width: 100%" + v-model="formFields[item.field]" + @change="item.onChange" + :type="item.type" + :placeholder=" + item.placeholder ? item.placeholder : '璇烽�夋嫨' + item.title + " + :disabledDate="(val) => getDateOptions(val, item)" + :value-format="getDateFormat(item)" + > + </el-date-picker> + </div> + + <el-time-picker + :size="size" + v-else-if="item.type == 'time'" + v-model="formFields[item.field]" + :disabled="item.readonly || item.disabled" + placeholder="璇烽�夋嫨鏃堕棿" + :value-format="item.format || 'HH:mm:ss'" + :format="item.format" + style="width: 100%" + > + </el-time-picker> + + <el-scrollbar + style="border: 1px solid #c7d8db; border-radius: 5px" + :height="item.height || 150" + v-else-if=" + item.type == 'editor' && (item.readonly || item.disabled) + " + > + <div ref="editor" v-html="formFields[item.field]"></div> + </el-scrollbar> + + <vol-wang-editor + ref="editor" + v-else-if="item.type == 'editor'" + :url="item.url || editor.uploadImgUrl" + :upload="item.upload || editor.upload" + v-model="formFields[item.field]" + :height="item.height || 350" + ></vol-wang-editor> + + <vol-upload + v-show="!item.hidden" + v-else-if="isFile(item, formFields)" + :desc="item.desc" + :multiple="item.multiple" + :max-file="item.maxFile" + :max-size="item.maxSize" + :autoUpload="item.autoUpload" + :fileInfo="formFields[item.field]" + :url="item.url" + :img="item.type == 'img' || item.columnType == 'img'" + :excel="item.type == 'excel'" + :fileTypes="item.fileTypes ? item.fileTypes : []" + :upload-before="item.uploadBefore" + :upload-after="item.uploadAfter" + :append="item.multiple" + :on-change=" + (files) => { + return fileOnChange(files, item); + } + " + :file-click="item.fileClick" + :remove-before="item.removeBefore" + :downLoad="item.downLoad ? true : false" + ></vol-upload> + <el-cascader + :size="size" + clearable + style="width: 100%; margin-top: -3px" + v-model="formFields[item.field]" + :disabled="item.readonly || item.disabled" + v-else-if="item.type == 'cascader'" + :options="item.data" + :props="{ + checkStrictly: item.changeOnSelect || item.checkStrictly + }" + @change="item.onChange" + > + </el-cascader> + <el-rate + v-else-if="item.type == 'rate'" + @change=" + (val) => { + item.onChange && item.onChange(val); + } + " + :max="item.max" + v-model="formFields[item.field]" + /> + <div + style="display: flex" + v-else-if="item.type == 'range' || item.range" + > + <el-input + :size="size" + :disabled="item.readonly || item.disabled" + style="flex: 1" + v-model="formFields[item.field][0]" + clearable + /> + <span style="margin: 0 5px">-</span> + <el-input + :size="size" + :disabled="item.readonly || item.disabled" + style="flex: 1" + v-model="formFields[item.field][1]" + clearable + /> + </div> + <el-input + :size="size" + clearable + :ref="item.field" + :input-style="item.inputStyle" + :disabled="item.readonly || item.disabled" + v-else-if="item.type == 'textarea'" + v-model="formFields[item.field]" + type="textarea" + :autosize="{ + minRows: item.minRows || 2, + maxRows: item.maxRows || 10 + }" + :placeholder="item.placeholder ? item.placeholder : item.title" + /> + <el-input-number + :size="size" + style="width: 100%" + :ref="item.field" + :input-style="item.inputStyle" + v-else-if="item.type == 'number'" + v-model="formFields[item.field]" + :min="item.min" + :disabled="item.readonly || item.disabled" + :max="item.max" + controls-position="right" + /> + <el-input + :size="size" + clearable + :input-style="item.inputStyle" + v-else-if="item.type == 'password'" + type="password" + v-model="formFields[item.field]" + :disabled="item.readonly || item.disabled" + v-show="!item.hidden" + :placeholder="item.placeholder ? item.placeholder : item.title" + /> + <!-- 2021.11.18淇el-input娌℃湁榛樿enter浜嬩欢鏃跺洖杞﹀紓甯� --> + <el-input + :size="size" + clearable + :ref="item.field" + :input-style="item.inputStyle" + v-else-if="item.onKeyPress" + :placeholder="item.placeholder ? item.placeholder : item.title" + :disabled="item.readonly || item.disabled" + v-show="!item.hidden" + v-model="formFields[item.field]" + @keypress=" + ($event) => { + onKeyPress($event, item); + } + " + @change="item.onKeyPress" + @keyup.enter="item.onKeyPress" + ></el-input> + <el-input + :size="size" + clearable + v-else + :ref="item.field" + :input-style="item.inputStyle" + :placeholder="item.placeholder ? item.placeholder : item.title" + :disabled="item.readonly || item.disabled" + v-show="!item.hidden" + v-model="formFields[item.field]" + ></el-input> + + <div class="form-extra" v-if="item.extra"> + <form-expand + v-if="item.extra.render" + :render="item.extra.render" + ></form-expand> + <a + v-else-if="item.extra.click" + :style="item.extra.style" + @click="item.extra.click(item, formFields[item.field])" + > + <i v-if="item.extra.icon" :class="item.extra.icon" /> + {{ item.extra.text }} + </a> + <a v-else :style="item.extra.style"> + <i v-if="item.extra.icon" :class="item.extra.icon" /> + {{ item.extra.text }} + </a> + </div> + </div> + </el-form-item> + </div> + </template> + <slot></slot> + <div style="width: 100%"> + <slot name="footer"></slot> + </div> + </el-form> +</template> +<script> +const rule = { + change: [ + 'checkbox', + 'select', + 'date', + 'datetime', + 'drop', + 'radio', + 'cascader' + ], // 2020.05.31澧炲姞绾ц仈绫诲瀷 + phone: /^[1][3,4,5,6,7,8,9][0-9]{9}$/, + decimal: /(^[\-0-9][0-9]*(.[0-9]+)?)$/, + number: /(^[\-0-9][0-9]*([0-9]+)?)$/ +}; +const inputTypeArr = ['text', 'string', 'mail', 'textarea', 'password']; +const types = { + int: 'number', + byte: 'number', + decimal: 'number', // "float", + string: 'string', + bool: 'boolean', + date: 'datetime', + date: 'date', + mail: 'email' +}; +//琛ㄥ崟楠岃瘉娉ㄦ剰锛氭瘡娆¢獙璇侀兘蹇呴』鎵цcallback,鍚﹀垯楠岃瘉涓嶆墽琛屽洖璋冩柟娉� +const colPow = Math.pow(10, 3); +import FormExpand from './VolForm/VolFormRender'; +import { + defineAsyncComponent, + defineComponent, + ref, + reactive, + toRefs, + getCurrentInstance, + onMounted, + watch +} from 'vue'; +export default defineComponent({ + components: { + FormExpand, + 'vol-upload': defineAsyncComponent(() => + import('@/components/basic/VolUpload.vue') + ), + // 'vol-wang-editor': defineAsyncComponent(() => + // import('@/components/editor/VolWangEditor.vue') + // ) + }, + props: { + loadKey: { + // 鏄惁鍔犺浇formRules瀛楁閰嶇疆鐨勬暟鎹簮 + type: Boolean, + default: true + }, + width: { + // 琛ㄥ崟瀹藉害 + type: Number, + default: 0 + }, + labelWidth: { + // 琛ㄥ崟宸﹁竟label鏂囧瓧鏍囩鐨勫搴� + type: Number, + default: 100 + }, + formRules: { + // 琛ㄥ崟閰嶇疆瑙勫垯锛屽瀛楁绫诲瀷锛屾槸鍚﹀繀濉� + type: Array, + default: [] + }, + formFields: { + type: Object, + default: () => { + return {}; + } + }, + editor: { + // 2021.01.16缂栬緫鍣ㄤ俊鎭� {uploadImgUrl:"",upload:null//涓婁紶鏂规硶} + type: Object, + default: () => { + return {}; + } + }, + size: { + type: String, //large / default / small + default: 'large' + }, + select2Count: { + //瓒呭嚭鏁伴噺鏄剧ずselect2缁勪欢 + type: Number, + default: 500 + } + }, + computed: { + rules() { + let ruleResult = {}; + this.formRules.forEach((option, xIndex) => { + option.forEach((item) => { + ruleResult[item.field] = [this.getRule(item, this.formFields)]; + }); + }); + if (this.$refs.volform) { + setTimeout(() => { + this.$refs.volform.clearValidate(); + }, 100); + } + return ruleResult; + } + }, + setup(props, context) { + const { appContext, proxy } = getCurrentInstance(); + const remoteCall = ref(true); + const span = ref(1); + const rangeFields = toRefs([]); + const volform = ref(null); + const numberFields = toRefs([]); + onMounted(() => {}); + const initFormRules = (init) => { + if (props.loadKey) { + initSource(); + } + props.formRules.forEach((row, xIndex) => { + if (row.length > span.value) span.value = row.length; + let _count = 0, + _size = 0; + row.forEach((x) => { + if (x.colSize > 0) { + _size = _size + x.colSize; + _count++; + } + }); + if (_count > 0 && row.length - _count > 0) { + let _cellSize = (12 - _size) / (row.length - _count); + row.forEach((x) => { + if (!x.colSize) { + x.colSize = _cellSize; + } + }); + } + row.forEach((item, yIndex) => { + if (item.type == 'number') { + numberFields.push(item.field); + } + // 鐩墠鍙敮鎸乻elect鍗曢�夎繙绋嬫悳绱紝remote杩滅▼浠庡悗鍙板瓧鍏告暟鎹簮杩涜鎼滅储锛寀rl浠庢寚瀹氱殑url鎼滅储 + if (item.remote || item.url) { + // item.remoteData = []; + item.loading = false; + item.point = { x: xIndex, y: yIndex }; + } + // 鍒濆鍖栦笂浼犳枃浠朵俊鎭� + initUpload(item, init); + // 鍒濆鍖栨暟鎹簮绌哄璞� + if (item.dataKey) { + // 涓嬫媺妗嗛兘寮哄埗璁剧疆涓哄瓧绗︿覆绫诲瀷 + item.columnType = 'string'; + if (!item.data) { + item.data = []; + } + } + + if (item.range || item.type == 'range') { + if ( + !(props.formFields[item.field] instanceof Array) || + props.formFields[item.field].length != 2 + ) { + props.formFields[item.field] = ['', '']; + } + rangeFields.push(item.field); + } + }); + }); + }; + + const initSource = () => { + let keys = [], + binds = []; + // 鍒濆鍖栧瓧鍏告暟鎹簮 + props.formRules.forEach((item) => { + item.forEach((x) => { + if (x.dataKey && (!x.data || x.data.length == 0) && !x.remote) { + x.data = []; + binds.push({ key: x.dataKey, data: x.data, type: x.type }); + if (keys.indexOf(x.dataKey) == -1) { + keys.push(x.dataKey); + } + } + }); + }); + + if (keys.length == 0) return; + appContext.config.globalProperties.http + .post('/api/Sys_Dictionary/GetVueDictionary', keys) + .then((dic) => { + bindOptions(dic, binds); + proxy.$emit('dicInited', dic); + }); + }; + const bindOptions = (dic, binds) => { + dic.forEach((d) => { + if (d.data.length > props.select2Count) { + if ( + !binds.some((x) => { + return x.key == d.dicNo && x.type == 'cascader'; + }) + ) { + d.data.forEach((item) => { + item.label = item.value; + item.value = item.key; + }); + } + } + binds.forEach((x) => { + if (x.key != d.dicNo) return true; + // 濡傛灉鏈夋暟鎹殑鍒欎笉鏌ヨ + if (x.data.length > 0) return true; + //2022.03.13澧炲姞绾ц仈鏁版嵁婧愯嚜鍔ㄨ浆鎹� + if (x.type == 'cascader' || x.type == 'treeSelect') { + let _data = JSON.parse(JSON.stringify(d.data)); + let cascaderArr = appContext.config.globalProperties.base.convertTree( + _data, + (node, data, isRoot) => { + if (!node.inited) { + node.inited = true; + node.label = node.value; + node.value = node.key; + } + } + ); + props.formRules.forEach((option) => { + option.forEach((item) => { + if (item.dataKey == x.key) { + item.orginData = x.data; + item.data = cascaderArr; + } + }); + }); + } else if (d.data.length > 0 && !d.data[0].hasOwnProperty('key')) { + let source = d.data, + newSource = new Array(source.length); + for (let index = 0; index < source.length; index++) { + newSource[index] = { + key: source['key'] + '', + value: source['value'] + }; + } + x.data.push(...newSource); + } else { + x.data.push(...d.data); + } + }); + }); + }; + + const initUpload = (item, init) => { + if (!init) return; + if ( + ['img', 'excel', 'file'].indexOf(item.type != -1) || + item.columnType == 'img' + ) { + // 鍙槸娌¤缃槸鍚﹁嚜鍔ㄤ笂浼犵殑锛岄粯璁ら兘鏄�夋嫨鏂囦欢鍚庤嚜鍔ㄤ笂浼� + if (!item.hasOwnProperty('autoUpload')) { + item.autoUpload = true; + } + if (!item.hasOwnProperty('fileList')) { + item.fileList = true; + } + if (!item.hasOwnProperty('downLoad')) { + item.downLoad = true; + } + if (!item.removeBefore) { + item.removeBefore = (index, file, files) => { + return true; + }; + } + if (!item.fileClick) { + item.fileClick = (index, file, files) => { + return true; + }; + } + if (!item.onChange) { + item.onChange = (files) => { + return true; + }; + } + if (!item.uploadAfter) { + item.uploadAfter = (result, files) => { + return true; + }; + } + if (!item.uploadBefore) { + item.uploadBefore = (files) => { + return true; + }; + } + } + }; + const validate = (callback) => { + let result = true; + volform.value.validate((valid) => { + if (!valid) { + appContext.config.globalProperties.$message.error('鏁版嵁楠岃瘉鏈�氳繃!'); + result = false; + } else if (typeof callback === 'function') { + try { + callback(valid); + } catch (error) { + let msg = `琛ㄥ崟楠岃瘉鍥炶皟鏂规硶寮傚父锛�${error.message}`; + appContext.config.globalProperties.$message.error(msg); + console.log(msg); + } + } + }); + return result; + }; + + initFormRules(true); + return { + remoteCall, + span, + rangeFields, + numberFields, + validate, + volform + // initFormRules, + // initSource + }; + }, + created() { + this.formRules.forEach((rules) => { + rules.forEach((option) => { + if (option.type == 'treeSelect' && option.multiple === undefined) { + option.multiple = true; + } + }); + }); + }, + + data() { + return { + // remoteCall: true, + errorImg: 'this.src="' + require('@/assets/imgs/error-img.png') + '"' + // span: 1, + // rangeFields: [], + }; + }, + methods: { + getColWidth(item) { + //2021.08.30 澧炲姞鍔ㄦ�佽绠楄〃鍗曞搴� + let _span = 0; + this.formRules.forEach((row, xIndex) => { + //2022.05.06 杩藉姞琛ㄥ崟涓殣钘忕殑鍏冪礌涓嶅弬涓庡姩鎬佽绠楄〃鍗曞搴� + let rowLength = row.filter((item) => { + return !item.hidden; + }).length; + if (rowLength > _span) _span = rowLength; + }); + let rete = + Math.round(((item.colSize || 12 / _span) / 0.12) * colPow, 10.0) / + colPow; + if (item.colSize) return rete.toFixed(3); + return rete.toFixed(3); + // return (100 - rete).toFixed(3); + }, + previewImg(url) { + this.base.previewImg(url, this.http.ipAddress); + }, + getSrc(path) { + if (!path) return; + if (!this.base.isUrl(path) && path.indexOf('.') != -1) { + return this.http.ipAddress + path; + } + return path; + }, + // 鏄惁涓哄浘鐗囨枃浠剁瓑鏍煎紡骞跺瀛楁鐨勮浆鎹㈡垚鏁扮粍锛歔{name:'1.jpg',path:'127.0.0.1/ff/1.jpg'}] + isFile(item, formFields) { + if ( + item.type == 'img' || + item.columnType == 'img' || + item.type == 'excel' || + item.type == 'file' + ) { + this.convertFileToArray(item, formFields); + return true; + } + return false; + }, + isReadonlyImgFile(item, formFields) { + if ((item.disabled || item.readonly) && this.isFile(item, formFields)) { + return true; + } + return false; + }, + convertFileToArray(item, formFields) { + if (!item.maxFile) { + item.maxFile = 1; // 榛樿鍙兘涓婁紶涓�涓枃浠讹紝鍙互鍦╫nInit涓缃� + } + + let fileInfo = formFields[item.field]; + if (fileInfo instanceof Array) { + return; + } + if (fileInfo === null || fileInfo === undefined) { + formFields[item.field] = []; + return; + } + // 灏嗕互閫楀彿闅斿紑鐨勬枃浠跺垎鍓叉垚鏁扮粍127.0.0.1/aa/1.jpg,灏�127.0.0.1/aa/2.jpg + if (typeof fileInfo === 'string') { + if (fileInfo.trim() === '') { + formFields[item.field] = []; + return; + } + // 濡傛灉鏂囦欢璺緞鏄瓧绗︿覆锛屽垯浣跨敤锛屾媶鍒� + fileInfo = fileInfo.replace(/\\/g, '/'); + let files = fileInfo.split(','); + formFields[item.field] = []; + for (let index = 0; index < files.length; index++) { + let file = files[index]; + let splitFile = file.split('/'); + formFields[item.field].push({ + name: splitFile.length > 0 ? splitFile[splitFile.length - 1] : file, + path: file // this.base.isUrl(file) ? file : this.http.ipAddress + file, + }); + } + } + }, + dowloadFile(file) { + this.base.dowloadFile( + file.path, + file.name, + { + Authorization: this.$store.getters.getToken() + }, + this.http.ipAddress + ); + }, + validatorPhone(ruleOption, value, callback) { + if (!ruleOption.required && !value && value != '0') { + return callback(); + } + if (!rule.phone.test((value || '').trim())) { + return callback(new Error('璇疯緭鍏ユ纭殑鎵嬫満鍙�')); + } + callback(); + }, + validatorPwd(ruleOption, value, callback) { + if (!ruleOption.required && !value && value != '0') { + return callback(); + } + if ((value + '').trim().length < 6) { + return callback(new Error('瀵嗙爜闀垮害涓嶈兘灏忎簬6浣�')); + } + callback(); + }, + convertArrayValue(data, val) { + // 2020.12.13澧炲姞琛ㄥ崟澶氶�夊彧杞崲瀛楀吀 + // 缂栬緫澶氶�塼able鏄剧ず + //2023.04.20淇鍙涓簂abel鏃跺師鏁版嵁琚瓧鍏告浛鎹簡鐨勯棶棰� + let valArr = Array.isArray(val) + ? val.map((x) => { + return x; + }) + : val.split(','); + for (let index = 0; index < valArr.length; index++) { + var _item = data.find((x) => { + return x.key && x.key != '0' && x.key + '' == valArr[index] + ''; + }); + if (_item) { + valArr[index] = _item.value; + } + } + return valArr.join(','); + }, + getText(formFields, item) { + // 2019.10.24淇琛ㄥ崟select缁勪欢涓哄彧璇荤殑灞炴�ф椂娌℃湁缁戝畾鏁版嵁婧� + let text = formFields[item.field]; + if (typeof text === 'function') return text(formFields); + if (text === 'null' || text === '' || text === null || text === undefined) + return '--'; + //2021.03.02澧炲姞鍙鏃舵棩鏈熷鐞� + if (item.type == 'date') { + return text.replace('T', ' ').split(' ')[0]; + } + //2021.03.31淇琛ㄥ崟switch鍙鏃舵病鏈夎浆鎹㈠�肩殑闂 + if (item.type == 'switch') { + return text ? '鏄�' : '鍚�'; + } + if (!item.data) return text; + if (item.type == 'selectList' || item.type == 'checkbox') { + return this.convertArrayValue(item.data, text); + } + var _item = item.data.find((x) => { + return x.key == text; + }); + return _item ? _item.value : text; + }, + onClear(item, formFields) { + // 杩滅▼select鏍囩娓呯┖閫夐」 + item.data.splice(0); + // console.log(2); + }, + onChange(item, value) { + if (item.onChange && typeof item.onChange === 'function') { + item.onChange(value, item); + } + }, + onRemoteChange(item, value) { + // 绗簩娆℃墦寮�鏃讹紝榛樿鍊兼垚浜唘ndefined锛屽緟鏌iewgrid涓噸缃唬鐮� + if (value == undefined && item.data.length > 0) { + this.formFields[item.field] = item.data[0].key; + // console.log('undefined'); + } + this.remoteCall = false; + if (item.onChange && typeof item.onChange === 'function') { + item.onChange(value, item); + } + }, + getData(item) { + return item.data; + }, + + // 杩滅▼鎼滅储(鎵撳紑寮瑰嚭妗嗘椂搴旇绂佹鎼滅储) + remoteSearch(item, formFields, val) { + if (!item.remote && !item.url) { + return; + } + if ( + val == '' || + (item.data.length == 1 && + (val == item.data[0].key || val == item.data[0].value)) + ) { + return; + } + // 寮瑰嚭妗嗘垨鍒濆鍖栬〃鍗曟椂缁檇ata璁剧疆鏁扮粍榛樿鍊�2 + // 2020.09.26淇杩滅▼鎼滅储鑷畾涔塽rl涓嶈捣浣滅敤鐨勯棶棰� + let url; + if (typeof item.url === 'function') { + url = item.url(val, item.dataKey, item); + } else { + url = + (item.url || '/api/Sys_Dictionary/GetSearchDictionary') + + '?dicNo=' + + item.dataKey + + '&value=' + + val; + } + this.http.post(url).then((dicData) => { + //this.$set(item, "loading", false); + item.loading = false; + item.data = dicData; + this.formRules[item.point.x].splice(item.point.y, 1, item); + }); + }, + getObject(date) { + if (typeof date === 'object') { + return date; + } + return new Date(date); + }, + reset(sourceObj) { + // 閲嶇疆琛ㄥ崟鏃讹紝绂佺敤杩滅▼鏌ヨ + this.$refs['volform'].resetFields(); + if (this.rangeFields.length) { + this.rangeFields.forEach((key) => { + this.formFields[key].splice(0); + this.formFields[key] = [null, null]; + }); + } + if (!sourceObj) return; + for (const key in this.formFields) { + if (sourceObj.hasOwnProperty(key)) { + this.formFields[key] = sourceObj[key]; + if (this.numberFields.indexOf(key) != -1) { + this.formFields[key] = sourceObj[key] * 1 || 0; + } + } + } + // this.remoteCall = true; + }, + + fileOnChange(files, item) { + this.$refs.volform.clearValidate(item.field); + if (item.onChange) { + return item.onChange(files); + } + return true; + }, + isReadonly(item) { + return item.readonly || item.disabled; + }, + getRule(item, formFields) { + //2021.07.17澧炲姞鍙琛ㄥ崟涓嶉獙璇� + //range涓巗wtich鏆傛椂涓嶅仛鏍¢獙 + if ( + // item.readonly || + // item.disabled || + item.type == 'switch' || + item.type == 'range' + ) + return { required: false }; + // 鐢ㄦ埛璁剧疆鐨勮嚜瀹氫箟鏂规硶 + if (item.validator && typeof item.validator === 'function') { + return { + validator: (rule, val, callback) => { + // 鐢ㄦ埛鑷畾涔夌殑鏂规硶锛屽鏋滆繑鍥炰簡鍊硷紝鐩存帴鏄剧ず杩斿洖鐨勫�硷紝楠岃瘉涓嶉�氳繃 + let message = item.validator(rule, val); + if (message) return callback(new Error(message + '')); + return callback(); + }, + required: item.required, + trigger: rule.change.indexOf(item.type) != -1 ? 'change' : 'blur' + }; + } + if (['img', 'excel', 'file'].indexOf(item.type) != -1) { + return { + validator: (rule, val, callback) => { + //2021.09.05绉婚櫎鏂囦欢涓婁紶榛樿蹇呭~ + if ( + item.required && + !this.isReadonly(item) && + (!val || !val.length) + ) { + return callback( + new Error(item.type == 'img' ? '璇蜂笂浼犵収鐗�' : '璇蜂笂浼犳枃浠�') + ); + } + return callback(); + }, + required: item.required, + trigger: 'change' + }; + } + // 璁剧疆鏁板瓧鐨勬渶澶у�兼皯鏈�灏忓�� + if ( + item.type == 'number' || + item.columnType == 'number' || + item.columnType == 'int' || + item.type == 'decimal' + ) { + // 濡傛灉鏄繀濉」鐨勬暟瀛楋紝璁剧疆涓�涓粯璁ゆ渶澶т笌鏈�鍊煎皬 + if (item.required && typeof item.min !== 'number') { + item.min = 0; //item.type == "decimal" ? 0.1 : 1; + } + + return { + required: item.required, + message: item.title + '鍙兘鏄暟瀛�', + title: item.title, + trigger: 'blur', + min: item.min, + max: item.max, + type: item.columnType || item.type, + validator: (ruleObj, value, callback) => { + if (!ruleObj.min && !ruleObj.max) { + if (ruleObj.required) { + if ((!value && value != '0') || !rule.decimal.test(value)) { + return callback(new Error('鍙兘鏄暟瀛�')); + } + } + return callback(); + } + if (this.isReadonly(item)) return callback(); + if (ruleObj.type == 'number') { + if (!rule.number.test(value)) { + ruleObj.message = ruleObj.title + '鍙兘鏄暣鏁�'; + return callback(new Error(ruleObj.message)); + } + } else { + if (!rule.decimal.test(value)) { + ruleObj.message = ruleObj.title + '鍙兘鏄暟瀛�'; + return callback(new Error(ruleObj.message)); + } + } + if ( + ruleObj.min !== undefined && + typeof ruleObj.min === 'number' && + value < ruleObj.min + ) { + ruleObj.message = ruleObj.title + '涓嶈兘灏忎簬' + ruleObj.min; + return callback(new Error(ruleObj.message)); + } + if ( + ruleObj.max !== undefined && + typeof ruleObj.max === 'number' && + value > ruleObj.max + ) { + ruleObj.message = ruleObj.title + '涓嶈兘澶т簬' + ruleObj.max; + return callback(new Error(ruleObj.message)); + } + return callback(); + } + }; + } + + // 鎵嬫満銆佸瘑鐮侀獙璇� + if (item.type == 'password' || item.type == 'phone') { + return { + validator: + item.type == 'phone' ? this.validatorPhone : this.validatorPwd, + required: item.required, + trigger: 'blur' + }; + } + + if (!item.required && item.type != 'mail') return { required: false }; + + if (!item.hasOwnProperty('type')) item.type = 'text'; + + if (inputTypeArr.indexOf(item.type) != -1) { + let message = + item.title + + (item.type == 'mail' ? '蹇呴』鏄竴涓偖绠卞湴鍧�' : '涓嶈兘涓虹┖'); + let type = item.type == 'mail' ? 'email' : types[item.columnType]; + let _rule = { + required: true, + message: message, + trigger: 'blur', + type: type, + validator: (ruleObj, value, callback) => { + if ( + !this.isReadonly(item) && + (value === '' || value === undefined || value === null) + ) { + return callback(new Error(ruleObj.message)); + } + return callback(); + } + }; + if (item.type == 'mail') { + _rule.validator = undefined; + return _rule; + } + if (item.min) { + _rule.min = item.min; + _rule.message = item.title + '鑷冲皯' + item.min + '涓瓧绗�!'; + } + if (item.max) { + return [ + _rule, + { + max: item.max, + required: true, + message: item.title + '鏈�澶�' + item.max + '涓瓧绗�!', + trigger: 'blur' + } + ]; + } + return _rule; + } + + if (item.type == 'radio') { + return { + required: item.required, + message: '璇烽�夋嫨' + item.title, + trigger: 'change', + type: 'string' + }; + } + if ( + item.type == 'date' || + item.type == 'datetime' || + item.type == 'month' || + item.type == 'time' + ) { + return { + required: true, + message: '璇烽�夋嫨' + item.title, + trigger: 'change', + type: item.range ? 'array' : 'string', + validator: (rule, val, callback) => { + if (this.isReadonly(item)) return callback(); + // 鐢ㄦ埛鑷畾涔夌殑鏂规硶锛屽鏋滆繑鍥炰簡鍊硷紝鐩存帴鏄剧ず杩斿洖鐨勫�硷紝楠岃瘉涓嶉�氳繃 + if (!val || (item.range && !val.length)) { + return callback(new Error('璇烽�夋嫨鏃ユ湡')); + } + return callback(); + } + }; + } + + if (item.type == 'cascader') { + return { + type: 'array', + required: true, + min: item.min || 1, + // message: "璇烽�夋嫨" + item.title, + trigger: 'change', + validator: (rule, val, callback) => { + if (this.isReadonly(item)) return callback(); + // 鐢ㄦ埛鑷畾涔夌殑鏂规硶锛屽鏋滆繑鍥炰簡鍊硷紝鐩存帴鏄剧ず杩斿洖鐨勫�硷紝楠岃瘉涓嶉�氳繃 + let _arr = this.formFields[item.field]; + if (!_arr || !_arr.length) { + return callback(new Error('璇烽�夋嫨' + item.title)); + } + return callback(); + } + }; + } + + if ( + ['select', 'selectList', 'checkbox', 'cascader', 'treeSelect'].indexOf( + item.type + ) != -1 + ) { + let _rule = { + type: item.type == 'select' ? 'string' : 'array', + required: true, + min: item.min || 1, + message: '璇烽�夋嫨' + item.title, + trigger: 'change', + validator: (rule, value, callback) => { + if (this.isReadonly(item)) return callback(); + //2021.11.27淇澶氶�夋病鏈夋彁绀虹殑闂 + if (value == undefined || value === '') { + return callback(new Error(rule.message)); + } else if ( + (item.type == 'checkbox' || + item.type == 'selectList' || + item.type == 'treeSelect') && + (!(value instanceof Array) || !value.length) + ) { + return callback(new Error(rule.message)); + } + return callback(); + } + }; + + if (_rule.max) { + _rule.nax = item.max; + _rule.message = '鏈�澶氬彧鑳介�夋嫨' + item.max + '椤�'; + } + return _rule; + } + return {}; + }, + compareDate(date1, date2) { + if (!date2) { + return true; + } + return ( + date1.valueOf() < + (typeof date2 == 'number' ? date2 : new Date(date2).valueOf()) + ); + }, + getDateOptions(date, item) { + //2021.07.17璁剧疆鏃堕棿鍙�夎寖鍥� + if ((!item.min && !item.max) || !date) { + return false; + } + if (item.min && item.min.indexOf(' ') == -1) { + //涓嶈缃椂鍒嗙锛屽悗闈細鑷姩鍔犱笂 08:00 + item.min = item.min + ' 00:00:000'; + } + return ( + this.compareDate(date, item.min) || !this.compareDate(date, item.max) + ); + }, + getDateFormat(item) { + if (item.type == 'month') { + return 'YYYY-MM'; + } + // if (item.type=='time') { + // return 'HH:mm:ss' + // } + //瑙乭ttps://day.js.org/docs/zh-CN/display/format + return item.type == 'date' ? 'YYYY-MM-DD' : 'YYYY-MM-DD HH:mm:ss'; + }, + dateRangeChange(val, item) { + if (!val) { + this.$emit('update:formFields'); + return; + } + item.onChange && item.onChange(val); + }, + onKeyPress($event, item) { + if ($event.keyCode == 13) { + return; + } + item.onKeyPress($event); + }, + filterMethod(value, data) { + return data.label.includes(value); + }, + getNode( label,node, data){ + console.log(label) + } + } +}); +</script> +<style lang="less" scoped> +.el-form-item { + margin-right: 0; +} +.el-form-item { + .form-imgs { + img { + float: left; + cursor: pointer; + object-fit: cover; + margin: 0 10px 10px 0; + width: 65px; + height: 65px; + border: 1px solid #c7c7c7; + overflow: hidden; + border-radius: 5px; + box-sizing: content-box; + } + } +} +.el-form-item ::v-deep(.el-form-item__label) { + padding: 0 0px 0 4px; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.el-form-item ::v-deep(.el-range-separator) { + text-align: center; + width: 13px; + padding: 0px 1px; + font-size: 12px; +} +.el-form-item ::v-deep(.el-range__close-icon) { + margin-right: -10px; +} +.form-item-extra { + > *:first-child { + flex: 1; + } + display: flex; + .form-extra { + padding-left: 7px; + line-height: 36px; + } +} +.vol-form-item { + width: 100%; +} +.vol-form-item ::v-deep(.el-form-item__content) { + display: unset !important; +} +.vol-form-item ::v-deep(.el-input--large .el-input__inner) { + height: 34px !important; +} +.vol-form-item ::v-deep(.el-input-number--large .el-input-number__increase) { + border-top: 1px solid #d4d4d4; +} +.vol-form-item ::v-deep(.el-input-number--large .el-input-number__decrease) { + border-bottom: 1px solid #d4d4d4; +} +.vol-form-item ::v-deep(.el-input--large.el-date-editor) { + height: 36px; +} +.v-date-range ::v-deep(.el-input__prefix) { + display: none; +} +.v-date-range ::v-deep(.el-input__inner) { + padding: 0; +} + +.el-form-item ::v-deep(.el-checkbox) { + margin-right: 8px; +} +.el-form-item ::v-deep(.el-checkbox .el-checkbox__label) { + padding-left: 5px; +} +.el-form-item ::v-deep(textarea) { + font-family: 'Helvetica Neue', Helvetica, 'PingFang SC', 'Hiragino Sans GB', + 'Microsoft YaHei', '寰蒋闆呴粦', Arial, sans-serif !important; +} +.el-form-item ::v-deep(.el-select .el-select__tags > span) { + display: flex; +} +.el-form-item ::v-deep(.el-select-v2__combobox-input) { + height: 30px; +} +.el-form-item ::v-deep(.el-select__tags) { + overflow: hidden; + height: 30px; +} +.el-form-item ::v-deep(.el-select-tags-wrapper) { + position: absolute; +} + +.el-form-item { + vertical-align: top !important; +} +.form-file-list { + a { + color: #3ea9ff; + } + a:hover { + cursor: pointer; + color: #0281e7; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolForm/VolFormRender.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolForm/VolFormRender.js" new file mode 100644 index 0000000..ef7459e --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolForm/VolFormRender.js" @@ -0,0 +1,14 @@ +import { h } from 'vue'; + +export default { + name: "FormExpand", + functional: true, + props: { + render: Function, + par: {}//娴嬭瘯鍙傛暟 + }, + render: ({ render, par }) => { + return render(h, { par }); //h(); + } +}; + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/DownloadForm.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/DownloadForm.js" new file mode 100644 index 0000000..69bf098 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/DownloadForm.js" @@ -0,0 +1,156 @@ +import templateCode from './templateCode' +export default function () { + let code = templateCode; + let _formOptions = this.options.formOptions.map(m => { + let _op = m.map((m1, i) => { + let _obj; + //.data[0].hasOwnProperty("key") + if (m1.data && m1.data.length && !m1.dataKey) { + let m2 = JSON.parse(JSON.stringify(m1)); + m2.data = m2.data.map(c => { + return { key: c.label || c.key, value: c.label } + }) + _obj = JSON.stringify(m2) + } else { + _obj = JSON.stringify(m1) + } + return (i === 0 ? '' : '\n\t\t\t\t') + _obj + }).join(','); + //return JSON.stringify(m, null, '') + return _op; + }) + code = code.replace('{#fields}', JSON.stringify(this.options.fields)) + .replace('{#formOptions}', '[' + _formOptions.join('],\n\t\t\t\t[') + ']'); + code = code.replace('}],', '\t\t\t\t\t}],') + .replace("[{#tableOptions}]", JSON.stringify(this.options.tables, null, '\t')) + .replace("[{#tabsOptions}]", JSON.stringify(this.options.tabs, null, '\t')) + // fields: {#fields}, + // formOptions: [{#formOptions}], + // tables: [{#tables}], + // tabs: [{#tabs}] + var tabsText = this.options.tabs.length ? ` <div class="tables" + style="padding-bottom: 10px"> + <el-tabs v-model="tabsModel" + @tab-click="() => {}"> + <el-tab-pane style="padding: 0" + class="table-item" + v-for="(item, index) in tabs" + :label="item.name" + :name="index+''" + :key="index"> + <div class="table-header"> + <div class="header-text"> + {{ item.name }} + </div> + <div class="header-btns"> + <el-button type="primary" + size="mini" + :key="bindex" + :icon="btnItem.icon" + plain + @click="tabsTableBtnClick(item, bindex, index)" + v-for="(btnItem, bindex) in item.buttons"> + {{ btnItem.name }} + </el-button> + </div> + </div> + <vol-table :url="item.url" + :load-key="false" + :index="true" + :ref="'tabsTable' + index" + :tableData="item.tableData" + :columns="item.columns" + :max-height="250" + :pagination-hide="item.pagination" + :column-index="true" + :ck="true"></vol-table> + </el-tab-pane> + </el-tabs> +</div>`: '' + code = code.replace('{#tabs}', tabsText); + if (this.options.tables.length || this.options.tabs.length) { + code = code.replace("{import_VolTable}", "import VolTable from '@/components/basic/VolTable'") + code = code.replace(",{component_table}", ",'vol-table': VolTable") + } else { + code = code.replace("{import_VolTable}", '') + code = code.replace("{component_table}", '') + } + + if (this.options.tables.length) { + + code = code.replace('{table_ms}', ` + tableBtnClick (item, btnIndex, index) { + if (item.buttons[btnIndex].value == "add") { + this.$refs["table" + index][0].addRow({}); + return; + } + if (item.buttons[btnIndex].value == "del") { + this.$refs["table" + index][0].delRow(); + return; + } + }, + tabsTableBtnClick (item, btnIndex, index) { + if (item.buttons[btnIndex].value == "add") { + this.$refs["tabsTable" + index][0].addRow({}); + return; + } + if (item.buttons[btnIndex].value == "del") { + this.$refs["tabsTable" + index][0].delRow(); + return; + } + },`) + code = code.replace('{#tables}', + ` + <!--table閰嶇疆 --> + <div class="tables"> + <div class="table-item" + v-for="(item, index) in tables" + :key="index"> + <div class="table-header"> + <div class="header-text"> + {{ item.name }} + </div> + <div class="header-btns"> + <el-button type="primary" + size="mini" + :key="bindex" + plain + @click="tableBtnClick(item, bindex, index)" + :icon="btnItem.icon" + v-for="(btnItem, bindex) in item.buttons"> + {{ btnItem.name }} + </el-button> + </div> + </div> + <vol-table :url="item.url" + :load-key="false" + :index="true" + :ref="'table' + index" + :tableData="item.tableData" + :columns="item.columns" + :max-height="250" + :pagination-hide="item.pagination" + :column-index="true" + :ck="true"></vol-table> + </div> + </div>`); + + } else { + + code = code.replace('{table_ms}', '') + code = code.replace('{#tables}', ''); + } + const blob = new Blob([code], { type: "text/plain;charset=utf-8" }) + if ('download' in document.createElement('a')) { // 闈濱E涓嬭浇 + const elink = document.createElement('a') + elink.download = `code${new Date().valueOf()}.vue`; + elink.style.display = 'none' + elink.href = URL.createObjectURL(blob) + document.body.appendChild(elink) + elink.click() + URL.revokeObjectURL(elink.href) // 閲婃斁URL 瀵硅薄 + document.body.removeChild(elink) + } else { + navigator.msSaveBlob(blob, fileName) + } +} \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/VolFormDraggable.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/VolFormDraggable.vue" new file mode 100644 index 0000000..1e64910 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/VolFormDraggable.vue" @@ -0,0 +1,1159 @@ +<template> + <div class="drag-container"> + <!-- @start="onStart" --> + <div class="drag-left"> + <div class="left-title">缁勪欢鍒楄〃</div> + <draggable + v-model="components" + @end="end1" + class="left-draggable-item" + :group="{ name: 'componentsGroup', pull: 'clone', put: false }" + animation="300" + @start="onStart" + :sort="false" + :move="onMove1" + > + <transition-group> + <div + :class="item.id == 1 ? 'item forbid' : 'item'" + v-for="item in components" + :key="item.id" + > + <i :class="item.icon"></i> {{ item.name }} + </div> + </transition-group> + </draggable> + <div class="example"> + <div @click="example1">绀轰緥涓�<i class="el-icon-arrow-right"></i></div> + <div @click="example2">绀轰緥浜�<i class="el-icon-arrow-right"></i></div> + <div @click="example3">绀轰緥涓�<i class="el-icon-arrow-right"></i></div> + </div> + </div> + + <div class="drag-center"> + <div class="center-top"> + <span> + <!-- <i class="el-icon-warning-outline"></i>楂樻晥鐨勮〃鍗曢厤缃� --> + </span> + <el-button type="primary" size="mini" plain @click="save" + ><i class="el-icon-check"> </i>淇濆瓨</el-button + > + <el-button type="primary" size="mini" plain @click="preview(true)" + ><i class="el-icon-view"> </i>棰勮</el-button + > + <el-button type="primary" size="mini" plain @click="download" + ><i class="el-icon-view"> </i>涓嬭浇</el-button + > + <el-button type="primary" @click="clearItems" size="mini" plain + ><i class="el-icon-delete"> </i>娓呯┖</el-button + > + <a + style="margin-left: 15px" + href="http://v2.volcore.xyz/document/api" + target="_blank" + >璁捐鍣ㄥ熀浜庢鏋秜olform銆乿oltable銆乿olupload銆乿olbox瀹氬埗寮�鍙�</a + > + </div> + <div> + <el-alert + title="鍏充簬琛ㄥ崟璁捐鍣�" + type="success" + :show-icon="true" + :closable="false" + > + <div> + 1銆佽〃鍗曡璁″櫒鍩轰簬draggable寮�鍙�,涓烘湰妗嗘灦鑷畾涔夐〉闈㈠姛鑳界殑琛ュ厖,妗嗘灦浠嶄互鍙鍖栦唬鐮佺敓鎴愬櫒涓烘牳蹇� + </div> + <div> + 2銆佹敮鎸佸彲瑙嗗寲璁捐1瀵�1銆�1瀵瑰鍙婅〃鍗曚笅鎷夋鑷姩缁戝畾銆乼able鑷姩鍔犺浇鏁版嵁(鍒嗛〉銆佺紪杈�)銆佽嚜鍔ㄤ笂浼犳枃浠躲�佸瘜鏂囨湰缂栬緫 + </div> + </el-alert> + </div> + <el-scrollbar style="flex: 1"> + <div class="tips" key="empty" v-show="!currentComponents.length"> + 璇峰皢宸﹁竟缁勪欢鎷栧叆姝ゅ鍣ㄤ腑 + </div> + <el-form label-position="top"> + <draggable + class="draggable-container" + v-model="currentComponents" + @end="end2" + animation="300" + :move="onMove" + group="componentsGroup" + > + <transition-group class="drag-center-item"> + <div + class="item2" + :class="{ actived: index === currentIndex }" + @click="itemClick(item, index)" + :style="{ width: item.width + '%' }" + v-for="(item, index) in currentComponents" + :key="index" + > + <i + class="el-icon-document-copy" + @click.stop="copyItem(item)" + ></i> + <i class="el-icon-delete" @click.stop="removeItem(index)"> </i> + <el-form-item + :required="item.required" + label-position="top" + style="width: 100%" + :label="item.type == 'line' ? '' : item.name" + > + <el-col> + <!-- <div></div> --> + <!-- {{ item.name }} --> + <el-input + v-if="item.type == 'text'" + placeholder="璇疯緭鍏ュ唴瀹�" + v-model="item.value" + :disabled="item.readonly" + size="medium" + ></el-input> + <el-input + v-else-if="item.type == 'textarea'" + type="textarea" + v-model="item.value" + :disabled="item.readonly" + placeholder="璇疯緭鍏ュ唴瀹�" + ></el-input> + <el-date-picker + v-else-if="item.type == 'date'" + align="right" + v-model="item.value" + type="date" + :disabled="item.readonly" + size="medium" + placeholder="閫夋嫨鏃ユ湡" + > + </el-date-picker> + <el-radio-group + :disabled="item.readonly" + v-else-if="item.type == 'radio'" + v-model="item.value" + > + <el-radio + v-for="item in item.data" + :key="item.key" + :label="item.value" + :value="item.key" + > + </el-radio> + <!-- <el-radio :label="1">鏄�</el-radio> + <el-radio :label="0">鍚�</el-radio> --> + </el-radio-group> + + <el-checkbox-group + v-model="item.values" + :disabled="item.readonly" + style="width: 100%; display: inline-block" + v-else-if="item.type == 'checkbox'" + > + <el-checkbox + v-for="item in item.data" + :key="item.key" + :label="item.value" + :value="item.key" + > + </el-checkbox> + <!-- <el-checkbox label="澶嶉�夋 A"></el-checkbox> + <el-checkbox label="澶嶉�夋 B"></el-checkbox> + <el-checkbox label="澶嶉�夋 C"></el-checkbox> --> + </el-checkbox-group> + + <el-select + style="width: 100%" + :disabled="item.readonly" + v-model="item.value" + size="medium" + v-else-if="item.type == 'select'" + placeholder="璇烽�夋嫨" + > + <el-option + v-for="item in item.data" + :key="item.value" + :label="item.label" + :value="item.value" + > + </el-option> + </el-select> + <el-select + style="width: 100%" + :disabled="item.readonly" + v-model="item.values" + size="medium" + :multiple="true" + v-else-if="item.type == 'selectList'" + placeholder="璇烽�夋嫨" + > + <el-option + v-for="item in item.data" + :key="item.value" + :label="item.label" + :value="item.value" + > + </el-option> + </el-select> + <el-cascader + :disabled="item.readonly" + style="width: 100%" + v-else-if="item.type == 'cascader'" + v-model="item.values" + :options="item.data" + @change="() => {}" + ></el-cascader> + + <el-switch + :disabled="item.readonly" + v-model="item.value" + style="width: 100%" + v-else-if="item.type == 'switch'" + active-color="#13ce66" + inactive-color="#0e7ef3" + :active-value="1" + :inactive-value="0" + > + </el-switch> + <div class="col-line" v-else-if="item.type == 'line'"> + {{ item.name }} + </div> + + <vol-upload + v-else-if=" + item.type == 'img' || + item.type == 'excel' || + item.type == 'file' + " + :fileInfo="item.fileInfo" + :url="item.url" + :img="item.type == 'img'" + :excel="item.type == 'excel'" + :multiple="item.multiple" + :max-size="item.maxSize" + :max-file="item.maxFile" + :autoUpload="item.autoUpload" + > + </vol-upload> + <vol-wang-editor + v-else-if="item.type == 'editor'" + :url="item.url" + v-model="item.value" + :height="item.height" + ></vol-wang-editor> + + <vol-table + v-else-if="item.type == 'table'" + :url="item.url" + :load-key="true" + :index="item.edit" + :tableData="item.tableData" + :columns="item.columns" + :height="item.height" + :pagination-hide="true" + :column-index="item.columnIndex" + :ck="item.ck" + ></vol-table> + <el-button + @click="model = true" + v-else-if="item.type == 'box'" + type="primary" + size="small" + >{{ item.name }}</el-button + > + </el-col> + </el-form-item> + </div> + </transition-group> + </draggable> + </el-form> + </el-scrollbar> + </div> + <div class="drag-right"> + <div class="left-title">缁勪欢灞炴��</div> + <div class="attr" v-show="currentIndex != -1"> + <div class="attr-item"> + <div class="text">瀛楁鍚嶇О</div> + <el-input size="medium" v-model="currentItem.name" /> + </div> + <div class="attr-item"> + <div class="text">瀛楁(鍞竴瀛楁)</div> + <el-input size="medium" v-model="currentItem.field" /> + </div> + <div class="attr-item" v-show="currentItem.type == 'table'"> + <div class="text">鍚庡彴杩斿洖鏁版嵁鎺ュ彛鍦板潃</div> + <el-input + size="medium" + placeholder="渚�:api/琛ㄥ悕/getPageData" + v-model="currentItem.url" + /> + </div> + <div + class="attr-item" + v-show=" + currentItem.type != 'table' && currentItem.hasOwnProperty('url') + " + > + <div class="text">涓婁紶鎺ュ彛鍦板潃(鍚庡彴鎺ュ彛)</div> + <el-input + size="medium" + placeholder="鍙敤妗嗘灦鍦板潃:api/琛ㄥ悕/upload" + v-model="currentItem.url" + /> + <div class="text" style="margin-top: 10px">鏂囦欢澶у皬闄愬埗(M)</div> + <el-input size="medium" v-model="currentItem.maxSize" /> + <div class="text" style="margin-top: 10px">鏄惁澶氭枃浠朵笂浼�</div> + <el-switch + v-model="currentItem.multiple" + style="width: 100%" + active-color="#13ce66" + inactive-color="rgb(165 165 165)" + :active-value="true" + :inactive-value="false" + > + </el-switch> + <div class="text" style="margin-top: 10px">鏄惁鑷姩涓婁紶</div> + <el-switch + v-model="currentItem.autoUpload" + style="width: 100%" + active-color="#13ce66" + inactive-color="rgb(165 165 165)" + :active-value="true" + :inactive-value="false" + > + </el-switch> + </div> + <div class="attr-item" v-show="currentItem.data"> + <div class="text">鏁版嵁婧�(涓嬫媺妗嗙粦瀹氳缃腑缁存姢)</div> + + <!-- dicList --> + <el-select + style="width: 100%" + v-model="currentItem.key" + size="medium" + @change="dicChange" + placeholder="璇烽�夋嫨鏁版嵁婧愬瓧鍏�" + > + <el-option + v-for="item in dicList" + :key="item.key" + :label="item.value" + :value="item.key" + > + </el-option> + </el-select> + </div> + <div class="attr-item" v-show="currentItem.type != 'table'"> + <div class="text">鏍囩瀹藉害</div> + <el-slider + style="width: 90%" + :min="20" + v-model="colWidth" + :step="10" + show-stops + > + </el-slider> + </div> + <div class="attr-item attr2" v-show="currentItem.type != 'table'"> + <div> + <div class="text">蹇呭~</div> + <el-switch + v-model="currentItem.required" + style="width: 100%" + active-color="#13ce66" + inactive-color="rgb(165 165 165)" + :active-value="true" + :inactive-value="false" + > + </el-switch> + </div> + + <div> + <!-- active-text="鏄�" + inactive-text="鍚�" --> + <div class="text">鍙</div> + <el-switch + v-model="currentItem.readonly" + style="width: 100%" + active-color="#13ce66" + inactive-color="rgb(165 165 165)" + :active-value="true" + :inactive-value="false" + > + </el-switch> + </div> + </div> + <div v-show="currentItem.type == 'table'"> + <div class="attr-item"> + <div class="text">鏄惁浣跨敤閫夐」鍗�(tabs)</div> + <div> + <el-switch + v-model="currentItem.tabs" + style="width: 100%" + active-text="鏄�" + inactive-text="鍚�" + active-color="#13ce66" + inactive-color="rgb(165 165 165)" + :active-value="true" + :inactive-value="false" + > + </el-switch> + </div> + </div> + <div class="attr-item attr2"> + <el-button + style="width: 100%" + @click="openTableModel" + type="primary" + size="medium" + >table閰嶇疆</el-button + > + </div> + </div> + </div> + </div> + </div> + <vol-box + v-model="model" + :height="300" + :width="550" + :lazy="true" + title="寮瑰嚭妗�" + > + <template #content> + <div>寮瑰嚭妗嗗唴瀹�</div> + </template> + <template #footer> + <div> + <el-button type="primary" size="mini" @click="model = false" + ><i class="el-icon-close"></i>鐐瑰嚮鍏抽棴</el-button + > + <el-button size="mini" @click="model = false" + ><i class="el-icon-close"></i>鍏抽棴</el-button + > + </div> + </template> + </vol-box> + + <vol-box + v-model="previewModel" + :height="600" + :width="1300" + :lazy="true" + :padding="1" + :close="false" + title="棰勮" + > + <preview style="height:600px" :options="viewFormData"></preview> + </vol-box> + + <vol-box + v-model="tableModel" + :height="600" + :width="1300" + :lazy="true" + :padding="0" + :title="currentItem.name" + > + <template #content> + <div style="height:600px" > + <el-alert title="鍏充簬table閰嶇疆" type="info" :closable="false" show-icon> + 姝ゅtable鏄妗嗘灦voltable鍩烘湰鎿嶄綔鐨勯厤缃�,濡傛灉闇�瑕佷簨浠惰Е鍙戙�佹暟鎹姞杞界瓑鏇村鍔熻兘锛岃鍦ㄧ敓鎴愬悗鐨勪唬鐮佹坊鍔犻渶瑕佺殑鍔熻兘锛屽畬鏁撮厤缃鏂囨。<a + href="http://v2.volcore.xyz/document/api" + style="color: #1e88e5; margin-left: 9px" + target="_blank" + >voltable</a + > + </el-alert> + <div class="btns"> + <div class="btns-left"> + 琛ㄦ牸榛樿鍔熻兘鎸夐挳锛� + <el-checkbox + v-for="item in currentItem.buttons" + :label="item.name" + :key="item.name" + >{{ item.name }}</el-checkbox + > + </div> + <div class="btns-right"> + <el-button type="primary" size="mini" @click="addRow" + ><i class="el-icon-plus"></i>娣诲姞瀛楁</el-button + > + <el-button type="primary" size="mini" @click="delRow" + ><i class="el-icon-delete"></i>鍒犻櫎瀛楁</el-button + > + <el-button type="primary" size="mini" @click="sortRow" + ><i class="el-icon-sort"></i>閲嶆柊鎺掑垪</el-button + > + </div> + </div> + <vol-table + :load-key="true" + :tableData="currnetTableData" + :columns="currentTableOption" + :height="448" + ref="table" + :index="true" + :pagination-hide="true" + :column-index="true" + :ck="true" + ></vol-table> + </div> + </template> + <template #footer> + <div style="text-align: center"> + <el-button size="mini" @click="tableModel = false" + ><i class="el-icon-close"></i>鍏抽棴</el-button + > + <el-button type="primary" size="mini" @click="saveConfigOptions" + ><i class="el-icon-check"></i>淇濆瓨</el-button + > + </div> + </template> + </vol-box> +</template> + +<script> +import { h, resolveComponent } from "vue"; +// import draggable from "vuedraggable"; +import { VueDraggableNext } from "vue-draggable-next"; +// import VolWangEditor from "@/components/editor/VolWangEditor.vue"; +import VolUpload from "./../VolUpload"; +import VolTable from "./../VolTable"; +import VolBox from "./../VolBox"; +import VolFormPreview from "./VolFormPreview"; +import { components, tableOption } from "./options"; +import { options1, options2, options3 } from "./formTemplate"; +import downloadForm from "./DownloadForm"; +export default { + props: { + userComponents: { + type: Array, + default: () => { + return []; + }, + }, + }, + components: { + draggable: VueDraggableNext, + "vol-upload": VolUpload, + // "vol-wang-editor": VolWangEditor, + "vol-table": VolTable, + "vol-box": VolBox, + preview: VolFormPreview, + }, + data() { + return { + options:{}, + options1: options1, + options2: options2, + options3: options3, + colWidth: 100, + currentIndex: -1, + currentItem: {}, + currnetTableData: [], + currentTableOption: tableOption, + //瀹氫箟瑕佽鎷栨嫿瀵硅薄鐨勬暟缁� + components: components, + currentComponents: [], + dicList: [], + model: false, + tableModel: false, + previewModel: false, + viewFormData: { fields: {}, formOptions: [], tables: [] }, + }; + }, + watch: { + colWidth(newVal) { + if (this.currentIndex != -1) { + this.currentComponents[this.currentIndex].width = newVal; + } + }, + userComponents: { + handler(newVal) { + this.currentComponents = newVal; + }, + immediate: true, + deep: true, + }, + }, + created() { + this.currentComponents = this.userComponents; + this.http + .post("api/Sys_Dictionary/GetBuilderDictionary", {}, false) + .then((x) => { + this.dicList = x.map((c) => { + return { key: c, value: c }; + }); + }); + }, + methods: { + getFormOptions(item) { + let _option = {}; + _option.field = item.field; + _option.title = item.name; + _option.type = item.type; + _option.required = item.required; + _option.readonly = item.readonly; + if (item.type == "line") { + _option.title = ""; + let title = item.name; + _option.render = (h) => { + return h( + "div", + { + style: { + "line-height": "25px", + "font-weight": "bold", + "margin-left": "15px", + "border-bottom": "1px solid #dadada", + }, + }, + title + //涔熷彲浠ュ湪杩欓噷鏀句竴浜涚粍浠讹紝渚嬪锛� + // resolveComponent("el-tooltip"), + // { + // content: "杩欓噷鏄彁绀虹殑鍐呭", + // props: { effect: "dark", placement: "top-start" }, + // style: {}, + // }, + // [h("a", { style: { color: "#2a92ff" } }, "鎻愮ず淇℃伅")] + ); + }; + } + if (item.type == "editor") { + _option.height = item.height; + } + if (item.width == 100) { + _option.colSize = 12; + } else { + _option.colSize = (_option.width * 12) / 100; + } + if (["img", "excel", "file"].indexOf(item.type) != -1) { + _option.maxSize = item.maxSize; + _option.fileInfo = item.fileInfo; + _option.multiple = item.multiple; + _option.autoUpload = item.autoUpload; + _option.maxFile = item.maxFile; + } + if ( + ["img", "excel", "file", "editor", "table"].indexOf(item.type) != -1 + ) { + _option.url = item.url; + } + if (item.data) { + _option.data = item.data; + _option.dataKey = item.key; + } + return _option; + }, + getLineFormOptions(index) { + let _index = index; + let endIndex = index; + let width = 0; + let _options = []; + for (index; index < this.filterCurrentComponents().length; index++) { + const item = this.currentComponents[index]; + if (item.width + width <= 100) { + width = item.width + width; + endIndex = index; + _options.push(this.getFormOptions(item)); + } + } + return { options: _options, index: _index, endIndex: endIndex }; + }, + filterCurrentComponents() { + return this.currentComponents.filter((x) => { + return x.type != "table"; + }); + }, + setSpan() {}, + preview(isPre) { + let _fields = {}; + let _formOptions = []; + let endIndex = -1; + this.filterCurrentComponents().forEach((item, index) => { + if (item.hasOwnProperty("values")) { + _fields[item.field] = []; + } else { + _fields[item.field] = null; + } + + if (item.width == 100) { + _formOptions.push([this.getFormOptions(item)]); + } else { + if (endIndex == -1) { + let lineOptions = this.getLineFormOptions(index); + endIndex = lineOptions.endIndex; + _formOptions.push(lineOptions.options); + endIndex--; + } else { + endIndex--; + } + } + // _fields[item.field] = null;xc + // let _option = {}; + // _option.field = item.field; + // _option.title = item.name; + // _option.type = item.type; + // _option.required = item.required; + // _option.readonly = item.readonly; + // if (["img", "excel", "file"].indexOf(item.type) != -1) { + // _option.maxSize = item.maxSize; + // _option.fileInfo = item.fileInfo; + // _option.multiple = item.multiple; + // _option.autoUpload = item.autoUpload; + // _option.maxFile = item.maxFile; + // } + // if ( + // ["img", "excel", "file", "editor", "table"].indexOf(item.type) != -1 + // ) { + // _option.url = item.url; + // } + // if (item.data) { + // _option.data = item.data; + // _option.dataKey = item.key; + // } + // _formOptions.push(_option); + }); + this.viewFormData.fields = _fields; + // console.log(JSON.stringify(_formOptions)) + this.viewFormData.formOptions = _formOptions; + if (isPre) { + this.previewModel = true; + } + let tableIndex = 0; + let keys = []; + let tables = this.currentComponents + .filter((x) => { + return x.type == "table"; + }) + .map((m) => { + m.pagination = !m.url; + if (m.name == "琛ㄦ牸") { + tableIndex++; + } + return { + name: m.name + (m.name == "琛ㄦ牸" ? tableIndex : ""), + url: m.url, + tabs: m.tabs, + pagination: m.pagination, + buttons: m.buttons, + columns: m.columns.map((c) => { + let obj = { + title: c.title, + field: c.field, + hidden: !c.show, + width: c.width, + required: c.required, + }; + + if (c.dataSource) { + obj.bind = { key: c.dataSource, data: [] }; + } + if (c.dataSource) { + keys.push(c.dataSource); + } + if (c.edit) { + if (!obj.bind) { + obj.bind = { key: "", data: [] }; + } + obj.edit = { type: c.editType }; + } + return obj; + }), + tableData: [{}, {}, {}], + }; + }); + this.viewFormData.tables = tables.filter((x) => { + return !x.tabs; + }); + this.viewFormData.tabs = tables.filter((x) => { + return x.tabs; + }); + this.getDicKeys(keys); + this.options = this.viewFormData; + }, + getDicKeys(keys) { + if (!keys.length) { + return; + } + debugger + this.http + .post("api/Sys_Dictionary/GetVueDictionary", keys, true) + .then((result) => { + result.forEach((c) => { + this.viewFormData.tables.forEach((t) => { + let _option = t.columns.find((x) => { + return x.bind && x.bind.key == c.dicNo; + }); + if (_option) { + _option.bind.data = c.data; + } + }); + this.viewFormData.tabs.forEach((t) => { + let _option = t.columns.find((x) => { + return x.bind && x.bind.key == c.dicNo; + }); + if (_option) { + _option.bind.data = c.data; + } + }); + }); + }); + }, + save() { + this.preview(false); + this.$emit("save", { + daraggeOptions: this.currentComponents, + formOptions: this.viewFormData, + }); + }, + download() { + this.preview(false); + downloadForm.call(this); + }, + openTableModel() { + let dataSource = this.currentTableOption.find((x) => { + return x.field == "dataSource"; + }); + if (!dataSource.bind.data.length) { + dataSource.bind.data = this.dicList; + } + this.currnetTableData = JSON.parse( + JSON.stringify(this.currentItem.columns) + ); + this.tableModel = true; + }, + addRow() { + this.currnetTableData.push({ field: this.getField() }); + }, + delRow() { + this.$confirm("纭瑕佸垹闄ら�夋嫨鐨勬暟鎹悧?", "璀﹀憡", { + confirmButtonText: "纭畾", + cancelButtonText: "鍙栨秷", + type: "warning", + center: true, + }).then(() => { + this.$refs.table.delRow(); + }); + }, + sortRow() { + this.currnetTableData = this.currnetTableData.sort((a, b) => { + return a.orderNo - b.orderNo; + }); //.reverse(); + this.$Message.success("鍒楁樉绀洪『搴忓凡閲嶆柊鎺掑垪,鐐瑰嚮棰勮鍙煡鐪�"); + }, + saveConfigOptions() { + this.currentItem.columns = JSON.parse( + JSON.stringify(this.currnetTableData) + ); + this.tableModel = false; + }, + copyItem(item) { + let itemClone = JSON.parse(JSON.stringify(item)); + itemClone.field = "field" + new Date().valueOf(); + this.currentComponents.push(itemClone); + }, + removeItem(index) { + this.currentComponents.splice(index, 1); + this.colWidth = 100; + this.currentIndex = -1; + this.currentItem = {}; + }, + clearItems() { + this.currentComponents.length = 0; + this.colWidth = 100; + this.currentIndex = -1; + this.currentItem = {}; + }, + itemClick(item, index) { + this.currentIndex = index; + this.colWidth = this.currentComponents[this.currentIndex].width; + this.currentItem = this.currentComponents[this.currentIndex]; + }, + //寮�濮嬫嫋鎷戒簨浠� + onStart(e, e1) { + this.drag = true; + }, + getField() { + return "field" + new Date().valueOf(); + }, + //宸﹁竟寰�鍙宠竟鎷栧姩鏃剁殑浜嬩欢 + end1(e) { + if (1 == 1 && e.from !== e.to) { + let obj = JSON.parse(JSON.stringify(this.components[e.oldIndex])); + obj.field = this.getField(); + obj.width = 100; + obj.readonly = false; + obj.required = false; + this.currentComponents.splice(e.newIndex, 1, obj); + this.userComponents.splice(0); + this.userComponents.push(...this.currentComponents); + // this.currentComponents = this.currentComponents.filter((x) => { + // return x.hasOwnProperty("field"); + // }); + this.colWidth = 100; + this.currentIndex = e.newIndex; //this.currentComponents.length - 1; + this.currentItem = this.currentComponents[this.currentIndex]; + } + }, + //鍙宠竟寰�宸﹁竟鎷栧姩鏃剁殑浜嬩欢 + end2(e) {}, + onMove1(e, originalEvent) { + // this.moveId = e.relatedContext.element.id; + return true; + }, + //move鍥炶皟鏂规硶 + onMove(e, originalEvent) { + console.log(JSON.stringify(this.currentComponents)); + return true; + }, + dicChange(key) { + debugger + this.http + .post("api/Sys_Dictionary/GetVueDictionary", [key], true) + .then((result) => { + this.currentItem.data = result[0].data; + if (result[0].data.length) { + if (this.currentItem.type == "select") { + this.currentItem.value = result[0].data[0].value; + } else { + this.currentItem.values = [result[0].data[0].value]; + } + } + }); + }, + example1() { + this.currentComponents = this.options1; + }, + example2() { + this.currentComponents = this.options2; + }, + example3() { + this.currentComponents = this.options3; + }, + }, + computed: { + tabsTable() { + return this.currentComponents.filter((x) => { + return x.type == "table" && x.tabs == true; + }); + }, + }, +}; +</script> +<style lang="less" scoped> +* { + box-sizing: border-box; +} +.drag-container { + /* padding: 20px; */ + display: flex; + height: 100%; + position: absolute; + width: 100%; + box-sizing: border-box; +} +.drag-left { + width: 250px; + display: flex; + border-right: 1px solid #eee; + flex-direction: column; +} +.left-title { + height: 42px; + text-align: left; + border-right: 1px solid #eee; + padding: 10px 0 10px 11px; + border-bottom: 1px solid #eee; +} +.drag-center { + display: flex; + flex-direction: column; + flex: 1; +} +.left-draggable-item { + // flex: 1; + display: inline-block; + padding: 5px; + // border-right: 1px solid #eee; +} + +.left-draggable-item .item { + cursor: move; + float: left; + width: 111px; + /* height: 20px; */ + text-align: center; + border: 1px solid #eeeeee; + padding: 2px 13px; + text-align: left; + line-height: 28px; + margin: 4px; + border-radius: 3px; + background: #f0f9eb; + font-size: 13px; +} +// .drag-center-item { +// display: inline-block; +// width: 100%; +// height: calc(100vh - 122px); +// padding: 10px; +// } +.draggable-container { + display: inline-block; + width: 100%; + height: calc(100vh - 215px); + padding: 10px 0; +} + +.item2 { + position: relative; + cursor: move; + padding: 18px 10px 10px 10px; + text-align: left; + float: left; + margin-bottom: 10px; +} +.item2 .el-icon-delete, +.item2 .el-icon-document-copy { + position: absolute; + right: 10px; + top: 2px; + padding: 5px; + display: none; + color: red; + cursor: pointer; +} +.item2 .el-icon-document-copy { + right: 35px; +} +.item2:hover, +.actived { + background: #f0f9eb; +} +.item:hover { + border: 1px dashed #787be8; + color: #787be8; +} +.item2:hover .el-icon-delete, +.item2:hover .el-icon-document-copy { + display: block; +} + +.drag-right { + background: #f7fbff3d; + width: 250px; + border-left: 1px solid #eee; +} + +.center-top { + height: 42px; + line-height: 41px; + background: #f2f5fb; + border-bottom: 1px solid #eee; + text-align: left; + padding: 0 10px; + font-size: 12px; + color: #3391f3; +} +.center-top span { + margin-right: 10px; +} +.attr { + padding: 0px 15px 15px 15px; +} +.attr-item { + text-align: left; + margin-top: 12px; + font-size: 14px; +} +.attr-item .text { + padding: 0 0 5px 5px; +} +.attr2 { + display: flex; +} +.attr2 > div { + flex: 1; +} +.tips { + position: absolute; + font-size: 26px; + letter-spacing: 6px; + left: 0px; + right: 0px; + top: 150px; + width: 500px; + margin: auto; + color: #c5c5c5; +} +.col-line { + line-height: 25px; + font-weight: bold; + border-bottom: 1px solid rgb(218 218 218); +} +.drag-container ::v-deep(.el-col) { + width: 100%; +} +.drag-center ::v-deep(.el-form-item__label) { + line-height: 0 !important; +} +.drag-center ::v-deep(.el-scrollbar__wrap) { + overflow-x: hidden; +} +.drag-center ::v-deep(.el-form-item) { + margin-bottom: 10px; +} +.drag-center ::v-deep(.el-date-editor) { + width: 100%; +} +.drag-center ::v-deep(.el-checkbox) { + margin-right: 15px; +} +.drag-center ::v-deep(.el-checkbox__label) { + padding-left: 5px; +} +.drag-center ::v-deep(.hello > div) { + z-index: 500 !important; +} +.drag-center ::v-deep(th), +.drag-center ::v-deep(td) { + padding: 6px 0; +} +.example { + margin-top: 8px; + > div { + cursor: pointer; + padding: 14px 20px; + border-top: 1px solid #eee; + font-size: 13px; + color: #646465; + position: relative; + } + > div:hover { + background: rgb(231, 231, 231); + } + i { + position: absolute; + right: 20px; + } +} +.btns { + padding: 8px 0; + display: flex; + > div { + flex: 1; + } + .btns-left { + padding-top: 8px; + color: black; + font-weight: bold; + } + .btns-right { + text-align: right; + } +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/VolFormPreview.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/VolFormPreview.vue" new file mode 100644 index 0000000..7d8aa93 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/VolFormPreview.vue" @@ -0,0 +1,206 @@ +<template> + <div style="padding: 15px 20px 15px 5px"> + <div class="pre-text">{{ text }}</div> + <vol-form + ref="form" + :labelWidth="80" + :load-key="false" + :formFields="options.fields" + :formRules="options.formOptions" + > + </vol-form> + <div class="tables"> + <div + class="table-item" + v-for="(item, index) in options.tables" + :key="index" + > + <div class="table-header"> + <div class="header-text"> + {{ item.name }} + </div> + <div class="header-btns"> + <el-button + type="primary" + size="small" + :key="bindex" + plain + @click="tableBtnClick(item, bindex, index)" + :icon="btnItem.icon" + v-for="(btnItem, bindex) in item.buttons" + > + {{ btnItem.name }} + </el-button> + </div> + </div> + <vol-table + :url="item.url" + :load-key="false" + :index="true" + :ref="'table' + index" + :tableData="item.tableData" + :columns="item.columns" + :max-height="250" + :pagination-hide="item.pagination" + :column-index="true" + :ck="true" + ></vol-table> + </div> + </div> + + <div class="tables" style="padding-bottom: 10px"> + <el-tabs + v-model="tabsModel" + v-show="options.tabs.length" + @tab-click="() => {}" + > + <el-tab-pane + style="padding: 0" + class="table-item" + v-for="(item, index) in options.tabs" + :label="item.name" + :name="index" + :key="index" + > + <div class="table-header"> + <div class="header-text"> + {{ item.name }} + </div> + <div class="header-btns"> + <el-button + type="primary" + size="small" + :key="bindex" + :icon="btnItem.icon" + plain + @click="tabsTableBtnClick(item, bindex, index)" + v-for="(btnItem, bindex) in item.buttons" + > + {{ btnItem.name }} + </el-button> + </div> + </div> + <vol-table + :url="item.url" + :load-key="false" + :index="true" + :ref="'tabsTable' + index" + :tableData="item.tableData" + :columns="item.columns" + :max-height="250" + :pagination-hide="item.pagination" + :column-index="true" + :ck="true" + ></vol-table> + </el-tab-pane> + </el-tabs> + </div> + + <div class="form-btns"> + <el-button type="primary" @click="submit" icon="el-icon-check" size="small" + >鎻愪氦</el-button + > + <el-button + type="primary" + @click="reset" + plain + icon="el-icon-refresh-right" + size="small" + >閲嶇疆</el-button + > + <el-button + type="primary" + @click="download" + plain + icon="el-icon-refresh-right" + size="small" + >涓嬭浇浠g爜</el-button + > + </div> + </div> +</template> + +<script> +import VolTable from "./../VolTable"; +import VolBox from "./../VolBox"; +import VolForm from "./../VolForm"; +import downloadForm from "./DownloadForm"; +export default { + props: { + options: { + type: Object, + default: () => { + return { fields: {}, formOptions: [], tables: [], tabs: [] }; + }, + }, + }, + data() { + return { + text: "", + tabsModel: 0, + }; + }, + created() {}, + methods: { + tableBtnClick(item, btnIndex, index) { + if (item.buttons[btnIndex].value == "add") { + this.$refs["table" + index].addRow({}); + return; + } + if (item.buttons[btnIndex].value == "del") { + this.$refs["table" + index].delRow(); + return; + } + }, + tabsTableBtnClick(item, btnIndex, index) { + if (item.buttons[btnIndex].value == "add") { + this.$refs["tabsTable" + index].addRow({}); + return; + } + if (item.buttons[btnIndex].value == "del") { + this.$refs["tabsTable" + index].delRow(); + return; + } + }, + submit() {}, + reset() { + this.$refs.form.reset(); + this.$Message.success("琛ㄥ崟宸查噸缃�"); + }, + download() { + downloadForm.call(this); + }, + }, + components: { + "vol-table": VolTable, + "vol-box": VolBox, + "vol-form": VolForm, + }, +}; + +VolForm; +</script> +<style lang="less" scoped> +.form-btns { + text-align: center; +} +.tables { + padding-left: 15px; + .table-item { + padding: 10px; + } + .table-header { + display: flex; + margin-bottom: 8px; + } + .header-text { + position: relative; + bottom: -9px; + flex: 1; + font-weight: bold; + } + .header-btns { + text-align: right; + } +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/formTemplate.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/formTemplate.js" new file mode 100644 index 0000000..e8dca27 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/formTemplate.js" @@ -0,0 +1,664 @@ + + +let options1 = [ + { + "id": 1, + "name": "杈撳叆妗�", + "type": "text", + "value": "", + "icon": "el-icon-document", + "field": "field1630258884671", + "width": 20, + "readonly": false, + "required": false + }, + { + "id": 3, + "name": "鏃ユ湡", + "type": "date", + "icon": "el-icon-date", + "value": null, + "field": "field1630258891760", + "width": 20, + "readonly": false, + "required": false + }, + { + "id": 7, + "name": "涓嬫媺妗�", + "value": null, + "key": "", + "data": [ + { + "label": "璇疯缃暟鎹簮", + "value": "璇疯缃暟鎹簮" + } + ], + "type": "select", + "icon": "el-icon-arrow-down", + "field": "field1630258904862", + "width": 30, + "readonly": false, + "required": false + }, + { + "id": 8, + "name": "涓嬫媺澶氶��", + "type": "selectList", + "key": "", + "values": [], + "data": [ + { + "label": "璇疯缃暟鎹簮", + "value": "璇疯缃暟鎹簮" + } + ], + "icon": "el-icon-arrow-down", + "field": "field1630258924442", + "width": 30, + "readonly": false, + "required": false + }, + { + "id": 81, + "name": "绾ц仈", + "type": "cascader", + "icon": "el-icon-share", + "values": [], + "key": "", + "data": [ + { + "value": "璇烽厤缃暟鎹簮", + "label": "璇烽厤缃暟鎹簮", + "children": [ + { + "value": "鍏蜂綋", + "label": "鑿滃崟:涓嬫媺妗嗙粦瀹氳缃�" + }, + { + "value": "color", + "label": "鍙弬鐓у瓧鍏哥紪鍙穂tree_roles]" + } + ] + } + ], + "field": "field1630259518082", + "width": 20, + "readonly": false, + "required": false + }, + { + "id": 6, + "name": "澶氶��", + "values": [ + "鍙戣揣" + ], + "type": "checkbox", + "key": "ordertype", + "data": [ + { + "key": "1", + "value": "鍙戣揣" + }, + { + "key": "2", + "value": "閫�璐�" + }, + { + "key": "3", + "value": "杩斿崟" + } + ], + "icon": "el-icon-circle-check", + "field": "field1630259033241", + "width": 30, + "readonly": false, + "required": false + }, + { + "id": 5, + "name": "鍗曢��", + "type": "radio", + "icon": "el-icon-aim", + "value": 0, + "data": [ + { + "key": "0", + "value": "鍚�" + }, + { + "key": "2", + "value": "xx11" + }, + { + "key": "1", + "value": "鏄�" + } + ], + "key": "enable", + "field": "field1630259538490", + "width": 30, + "readonly": false, + "required": false, + "values": [ + "鍚�" + ] + }, + { + "id": 4, + "name": "switch", + "type": "switch", + "icon": "el-icon-turn-off", + "value": 0, + "field": "field1630259172794", + "width": 20, + "readonly": false, + "required": false + }, + { + "id": 12, + "name": "鍒嗘淇℃伅", + "type": "line", + "icon": "el-icon-guide", + "field": "field1630259600186", + "width": 100, + "readonly": false, + "required": false + }, + { + "id": 9, + "name": "鍥剧墖", + "type": "img", + "url": "api/SellOrder/upload", + "maxSize": 3, + "fileInfo": [], + "multiple": false, + "autoUpload": false, + "maxFile": 5, + "icon": "el-icon-picture-outline", + "field": "field1630259295154", + "width": 100, + "readonly": false, + "required": false + }, + { + "id": 10, + "name": "excel", + "url": "api/SellOrder/upload", + "maxSize": 3, + "multiple": false, + "autoUpload": true, + "maxFile": 5, + "fileInfo": [], + "type": "excel", + "icon": "el-icon-upload", + "field": "field1630259610476", + "width": 100, + "readonly": false, + "required": false + }, + { + "id": 5, + "name": "鍗曢��", + "type": "radio", + "icon": "el-icon-aim", + "value": 0, + "data": [ + { + "key": "0", + "value": "瀹℃牳涓�" + }, + { + "key": "1", + "value": "瀹℃牳閫氳繃" + }, + { + "key": "2", + "value": "瀹℃牳鏈�氳繃" + } + ], + "key": "audit", + "field": "field1630258969346", + "width": 40, + "readonly": false, + "required": false, + "values": [ + "瀹℃牳涓�" + ] + } +]; +let options2=[ + { + "id": 1, + "name": "杈撳叆妗�", + "type": "text", + "value": "", + "icon": "el-icon-document", + "field": "field1630258884671", + "width": 20, + "readonly": false, + "required": false + }, + { + "id": 3, + "name": "鏃ユ湡", + "type": "date", + "icon": "el-icon-date", + "value": null, + "field": "field1630258891760", + "width": 20, + "readonly": false, + "required": false + }, + { + "id": 7, + "name": "涓嬫媺妗�", + "value": null, + "key": "", + "data": [ + { + "label": "璇疯缃暟鎹簮", + "value": "璇疯缃暟鎹簮" + } + ], + "type": "select", + "icon": "el-icon-arrow-down", + "field": "field1630258904862", + "width": 30, + "readonly": false, + "required": false + }, + { + "id": 8, + "name": "涓嬫媺澶氶��", + "type": "selectList", + "key": "", + "values": [], + "data": [ + { + "label": "璇疯缃暟鎹簮", + "value": "璇疯缃暟鎹簮" + } + ], + "icon": "el-icon-arrow-down", + "field": "field1630258924442", + "width": 30, + "readonly": false, + "required": false + }, + { + "id": 2, + "name": "textarea", + "type": "textarea", + "value": "", + "icon": "el-icon-document-copy", + "field": "field1630260207393", + "width": 100, + "readonly": false, + "required": false + }, + { + "id": 13, + "name": "琛ㄦ牸", + "type": "table", + "tabs": true, + "columns": [ + { + "title": "杩愬崟鍙�", + "field": "TranNo", + "show": true, + "required": false, + "edit": true, + "dataType": null, + "dataSource": null, + "width": "140", + "orderNo": null, + "elementIndex": 0 + }, + { + "title": "閿�鍞鍗曞彿", + "field": "SellNo", + "show": true, + "required": false, + "edit": true, + "dataType": null, + "dataSource": null, + "width": "140", + "orderNo": null, + "elementIndex": 1 + }, + { + "title": "璁㈠崟绫诲瀷", + "field": "OrderType", + "show": true, + "required": false, + "edit": true, + "dataType": null, + "dataSource": "ordertype", + "width": 120, + "orderNo": null, + "elementIndex": 2, + "editType": "select" + }, + { + "title": "閿�鍞暟閲�", + "field": "Qty", + "show": true, + "required": false, + "edit": true, + "dataType": null, + "dataSource": null, + "width": "80", + "orderNo": null, + "elementIndex": 3 + }, + { + "field": "CreateDate", + "elementIndex": 4, + "show": 1, + "required": 0, + "edit": 0, + "title": "璁㈠崟鏃堕棿", + "dataType": "date", + "width": "100" + } + ], + "tableData": [ + { + "field1": "field1", + "field2": "field2", + "field3": "field3", + "field4": "field4" + }, + { + "field1": "field1", + "field2": "field2", + "field3": "field3", + "field4": "field4" + }, + { + "field1": "field1", + "field2": "field2", + "field3": "field3", + "field4": "field4" + } + ], + "height": 200, + "icon": "el-icon-c-scale-to-original", + "url": "api/SellOrder/getPageData", + "index": false, + "columnIndex": false, + "ck": true, + "buttons": [ + { + "name": "娣诲姞琛�", + "ck": false, + "icon": "el-icon-plus", + "value": "add" + }, + { + "name": "鍒犻櫎琛�", + "ck": false, + "icon": "el-icon-delete", + "value": "del" + }, + { + "name": "鍒锋柊", + "ck": false, + "icon": "el-icon-refresh-right", + "value": "ref" + } + ], + "field": "field1630260242867", + "width": 100, + "readonly": false, + "required": false, + "pagination": false + }, + { + "id": 13, + "name": "琛ㄦ牸", + "type": "table", + "tabs": true, + "columns": [ + { + "title": "瀛楁1", + "field": "field1", + "show": true, + "required": false, + "edit": false, + "dataType": null, + "dataSource": null, + "width": 120, + "orderNo": null + }, + { + "title": "瀛楁2", + "field": "field2", + "show": true, + "required": false, + "edit": false, + "dataType": null, + "dataSource": null, + "width": 120, + "orderNo": null + }, + { + "title": "瀛楁3", + "field": "field3", + "show": true, + "required": false, + "edit": false, + "dataType": null, + "dataSource": null, + "width": 120, + "orderNo": null + }, + { + "title": "瀛楁4", + "field": "field4", + "show": true, + "required": false, + "edit": false, + "dataType": null, + "dataSource": null, + "width": 120, + "orderNo": null + } + ], + "tableData": [ + { + "field1": "field1", + "field2": "field2", + "field3": "field3", + "field4": "field4" + }, + { + "field1": "field1", + "field2": "field2", + "field3": "field3", + "field4": "field4" + }, + { + "field1": "field1", + "field2": "field2", + "field3": "field3", + "field4": "field4" + } + ], + "height": 200, + "icon": "el-icon-c-scale-to-original", + "url": null, + "index": false, + "columnIndex": false, + "ck": true, + "buttons": [ + { + "name": "娣诲姞琛�", + "ck": false, + "icon": "el-icon-plus", + "value": "add" + }, + { + "name": "鍒犻櫎琛�", + "ck": false, + "icon": "el-icon-delete", + "value": "del" + }, + { + "name": "鍒锋柊", + "ck": false, + "icon": "el-icon-refresh-right", + "value": "ref" + } + ], + "field": "field1630260481283", + "width": 100, + "readonly": false, + "required": false, + "pagination": true + } +] + +let options3=[ + { + "id": 1, + "name": "杈撳叆妗�", + "type": "text", + "value": "", + "icon": "el-icon-document", + "field": "field1630258884671", + "width": 20, + "readonly": false, + "required": false + }, + { + "id": 3, + "name": "鏃ユ湡", + "type": "date", + "icon": "el-icon-date", + "value": null, + "field": "field1630258891760", + "width": 20, + "readonly": false, + "required": false + }, + { + "id": 7, + "name": "涓嬫媺妗�", + "value": null, + "key": "", + "data": [ + { + "label": "璇疯缃暟鎹簮", + "value": "璇疯缃暟鎹簮" + } + ], + "type": "select", + "icon": "el-icon-arrow-down", + "field": "field1630258904862", + "width": 30, + "readonly": false, + "required": false + }, + { + "id": 8, + "name": "涓嬫媺澶氶��", + "type": "selectList", + "key": "", + "values": [], + "data": [ + { + "label": "璇疯缃暟鎹簮", + "value": "璇疯缃暟鎹簮" + } + ], + "icon": "el-icon-arrow-down", + "field": "field1630258924442", + "width": 30, + "readonly": false, + "required": false + }, + { + "id": 5, + "name": "鍗曢��", + "type": "radio", + "icon": "el-icon-aim", + "value": 0, + "data": [ + { + "key": "0", + "value": "鍚�" + }, + { + "key": "2", + "value": "xx11" + }, + { + "key": "1", + "value": "鏄�" + } + ], + "key": "enable", + "field": "field1630260669595", + "width": 50, + "readonly": false, + "required": false, + "values": [ + "鍚�" + ] + }, + { + "id": 6, + "name": "澶氶��", + "values": [ + "鍚�" + ], + "type": "checkbox", + "key": "enable", + "data": [ + { + "key": "0", + "value": "鍚�" + }, + { + "key": "2", + "value": "xx11" + }, + { + "key": "1", + "value": "鏄�" + } + ], + "icon": "el-icon-circle-check", + "field": "field1630260695322", + "width": 50, + "readonly": false, + "required": false + }, + { + "id": 2, + "name": "textarea", + "type": "textarea", + "value": "", + "icon": "el-icon-document-copy", + "field": "field1630260207393", + "width": 100, + "readonly": false, + "required": false + }, + { + "id": 13, + "name": "缂栬緫鍣�", + "type": "editor", + "value": "", + "url": "", + "height": 200, + "icon": "el-icon-notebook-2", + "field": "field1630260646842", + "width": 100, + "readonly": false, + "required": false + } +] +export { options1, options2,options3 } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/index.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/index.js" new file mode 100644 index 0000000..9872583 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/index.js" @@ -0,0 +1,3 @@ +import VolFormDraggable from './VolFormDraggable' + + export default VolFormDraggable; \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/options.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/options.js" new file mode 100644 index 0000000..c60047c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/options.js" @@ -0,0 +1,226 @@ +const components = [ + { + id: 1, + name: "杈撳叆妗�", + type: "text", + value: "", + icon: "el-icon-document", + }, + { + id: 2, + name: "textarea", + type: "textarea", + value: "", + icon: "el-icon-document-copy", + }, + { + id: 3, + name: "鏃ユ湡", + type: "date", + icon: "el-icon-date", + value: null, + }, + { + id: 4, + name: "switch", + type: "switch", + icon: "el-icon-turn-off", + value: 0, + }, + { id: 5, name: "鍗曢��", type: "radio", icon: "el-icon-aim", value: 0, data: [{ label: "0", value: "璇疯缃暟鎹簮1" }, { label: "1", value: "璇疯缃暟鎹簮2" }], key: "" }, + { + id: 6, + name: "澶氶��", + values: [], + type: "checkbox", + key: "", + data: [{ label: "璇疯缃暟鎹簮", value: "璇疯缃暟鎹簮" }], + icon: "el-icon-circle-check", + }, + { + id: 7, + name: "涓嬫媺妗�", + value: null, + key: "", + data: [{ label: "璇疯缃暟鎹簮", value: "璇疯缃暟鎹簮" }], + type: "select", + icon: "el-icon-arrow-down", + }, + { + id: 8, + name: "涓嬫媺妗嗗閫�", + type: "selectList", + key: "", + values: [], + data: [{ label: "璇疯缃暟鎹簮", value: "璇疯缃暟鎹簮" }], + icon: "el-icon-arrow-down", + }, + { + id: 81, + name: "绾ц仈", + type: "cascader", + icon: "el-icon-share", + values: [], + key: "", + data: [ + { + value: "璇烽厤缃暟鎹簮", + label: "璇烽厤缃暟鎹簮", + children: [ + { + value: "鍏蜂綋", + label: "鑿滃崟:涓嬫媺妗嗙粦瀹氳缃�", + }, + { + value: "color", + label: "鍙弬鐓у瓧鍏哥紪鍙穂tree_roles]", + } + ], + }, + ], + }, + { + id: 9, + name: "鍥剧墖涓婁紶", + type: "img", + url: "", + maxSize: 3, + fileInfo: [], + multiple: false, + autoUpload: false, + maxFile: 5, + icon: "el-icon-picture-outline", + }, + { + id: 10, + name: "excel涓婁紶", + url: "", + maxSize: 3, + multiple: false, + autoUpload: false, + maxFile: 5, //鏈�澶氬彲涓婁紶5涓枃浠� + fileInfo: [], + type: "excel", + icon: "el-icon-upload", + }, + { + id: 11, + name: "鏂囦欢涓婁紶", + type: "file", + url: "", + maxSize: 3, + multiple: false, + autoUpload: false, + maxFile: 5, + fileInfo: [], + icon: "el-icon-folder-opened", + }, + { + id: 12, + name: "鍒嗘淇℃伅", + type: "line", + icon: "el-icon-guide", + }, + { + id: 13, + name: "缂栬緫鍣�", + type: "editor", + value: "", + url: "", + height: 200, + icon: "el-icon-notebook-2", + }, + { + id: 13, + name: "寮瑰嚭妗�", + type: "box", + value: "", + url: "", + height: 250, + icon: "el-icon-notebook-2", + }, + { + id: 13, + name: "琛ㄦ牸", + type: "table", + tabs: false, + columns: [ + { title: "瀛楁1", field: "field1", show: true, required: false, edit: false, dataType: null, dataSource: null, width: 120, orderNo: null }, + { title: "瀛楁2", field: "field2", show: true, required: false, edit: false, dataType: null, dataSource: null, width: 120, orderNo: null }, + { title: "瀛楁3", field: "field3", show: true, required: false, edit: false, dataType: null, dataSource: null, width: 120, orderNo: null }, + { title: "瀛楁4", field: "field4", show: true, required: false, edit: false, dataType: null, dataSource: null, width: 120, orderNo: null }, + // { title: "瀛楁5", field: "Field5", width: 120 }, + ], + tableData: [ + { + field1: "field1", + field2: "field2", + field3: "field3", + field4: "field4", + }, + { + field1: "field1", + field2: "field2", + field3: "field3", + field4: "field4", + }, + { + field1: "field1", + field2: "field2", + field3: "field3", + field4: "field4", + }, + ], + height: 150, + icon: "el-icon-c-scale-to-original", + url: null, + index: false, //item.index, + height: 200, + index: false, + columnIndex: false, + ck: true, + buttons: [ + { name: '娣诲姞琛�', ck: false, icon: 'el-icon-plus',value:'add' }, + { name: '鍒犻櫎琛�', ck: false, icon: 'el-icon-delete',value:'del' }, + { name: '鍒锋柊', ck: false ,icon:'el-icon-refresh-right',value:'ref'}], + }, +] +const tableOption = [ + { field: 'field', title: '瀛楁', edit: { type: "text", keep: true }, width: 160 }, + { field: 'title', title: '瀛楁涓枃鍚�', edit: { type: "text", keep: true }, width: 120 }, + { field: 'show', title: '鏄惁鏄剧ず', edit: { type: "switch", keep: true }, width: 90 }, + { + field: 'dataType', title: '鏄剧ず绫诲瀷', edit: { type: "select", keep: true }, width: 120, bind: { + key: '', data: [ + { "key": "switch", "value": "鍗曢��" }, + { "key": "date", "value": "骞存湀鏃�" }, + { "key": "img", "value": "鍥剧墖" }, + { "key": "excel", "value": "excel" }, + { "key": "file", "value": "鏂囦欢" } + ] + } + }, + + { field: 'required', title: '鏄惁蹇呭~', edit: { type: "switch", keep: true }, width: 90 }, + { field: 'edit', title: '鏄惁鍙紪杈�', edit: { type: "switch", keep: true }, width: 90 }, + { + field: 'editType', title: '缂栬緫绫诲瀷', edit: { type: "select", keep: true, }, width: 120, bind: { + key: '', data: [{ "key": "text", "value": "杈撳叆妗�" }, + { "key": "switch", "value": "鍗曢��" }, + { "key": "select", "value": "涓嬫媺妗�" }, + { "key": "selectList", "value": "涓嬫媺妗嗗閫�" }, + { "key": "date", "value": "鏃ユ湡" }, + { "key": "datetime", "value": "鏃ユ湡鏃跺垎绉�" }, + { "key": "checkbox", "value": "澶嶉�夋澶氶��" }, + { "key": "mail", "value": "閭鍦板潃" }, + { "key": "number", "value": "鏁板瓧" }, + { "key": "decimal", "value": "灏忔暟" }, + { "key": "phone", "value": "鎵嬫満鍙�" }, + ] + } + }, + { field: 'dataSource', title: '鏁版嵁婧�', edit: { type: "select", keep: true, data: [] }, bind: { key: '', data: [] }, width: 120 }, + { field: 'width', title: '鍒楀搴�', edit: { type: "text", keep: true }, width: 80 }, + { field: 'orderNo', title: '鍒楁樉绀洪『搴�', edit: { type: "text", keep: true }, width: 100 } +]; +export { components, tableOption } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/templateCode.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/templateCode.js" new file mode 100644 index 0000000..41b8744 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolFormDraggable/templateCode.js" @@ -0,0 +1,95 @@ +var code = `<template> +<div style="padding: 15px 20px 15px 5px"> + <div class="pre-text">{{ text }}</div> + <vol-form ref="form" + :labelWidth="80" + :load-key="false" + :formFields="fields" + :formRules="formOptions"> + </vol-form> + {#tables} + {#tabs} + + <div class="form-btns"> + <el-button type="primary" + @click="submit" + icon="el-icon-check" + size="mini">鎻愪氦</el-button> + <el-button type="primary" + @click="reset" + plain + icon="el-icon-refresh-right" + size="mini">閲嶇疆</el-button> + </div> +</div> +</template> + +<script> +// 浣跨敤鏂瑰紡锛� +// 1銆佹柊寤轰竴涓獀ue椤甸潰锛屾妸姝ら〉闈㈠唴瀹瑰鍒惰繘鍘� +// 2銆乺outer->index.js閰嶇疆璺敱锛岄〉闈笂杈撳叆鍦板潃鍗冲彲鐪嬪埌鏁版嵁(涔熷彲浠ユ妸鑿滃崟閰嶇疆涓�) +// 3銆佹垨鑰呭弬鐓ц〃鍗曡璁¢〉闈㈠仛鍔ㄦ�侀〉闈� +//**琛ㄥ崟璁捐鍣ㄧ殑table涓嬭浇杩樺湪寮�鍙戜腑 +{import_VolTable} +import VolForm from '@/components/basic/VolForm' +export default { + components: {"vol-form": VolForm,{component_table}}, + data () { + return { + text: "", + tabsModel: "0", + fields: {#fields}, + formOptions: [{#formOptions}], + tables: [{#tableOptions}], + tabs: [{#tabsOptions}] + }; + }, + created () { + + }, + methods: {{table_ms} + submit () { + this.$Message.success("submit") + return; + this.http.post("url",this.fields,true).then(result=>{ + + }) + }, + reset () { + this.$refs.form.reset(); + this.$Message.success("琛ㄥ崟宸查噸缃�") + }, + download () { + this.$Message.info("111") + } + } +}; + +VolForm; +</script> +<style lang="less" scoped> +.form-btns { +text-align: center; +} +.tables { +padding-left: 15px; +.table-item { + padding: 10px; +} +.table-header { + display: flex; + margin-bottom: 8px; +} +.header-text { + position: relative; + bottom: -9px; + flex: 1; + font-weight: bold; +} +.header-btns { + text-align: right; +} +} +</style>` + +export default code \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolHeader.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolHeader.vue" new file mode 100644 index 0000000..cbe64e7 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolHeader.vue" @@ -0,0 +1,67 @@ +<template> + <div class="v-header"> + <div class="v-left-text"> + <!-- <i size="20" :class="icon" class="h-icon"/> --> + <span>{{ title || text }}</span> + </div> + <div class="content"> + <slot name="content"></slot> + </div> + <div class="v-right-content"> + <slot></slot> + </div> + </div> +</template> +<script> +export default { + props: { + icon: { + type: String, + default: '' + }, + title: { + type: String, + default: '' + }, + text: { + type: String, + default: '鏈畾涔夊悕绉�' + } + } +}; +</script> +<style lang="less" scoped> +.v-header { + display: flex; + border-bottom: 1px solid #dcdee2; + .v-left-text { + margin-top: 3px; + padding-bottom: 6px; + font-weight: bold; + font-size: 15px; + color: #484848; + white-space: nowrap; + border-bottom: 2px solid #676767; + margin-bottom: -1px; + letter-spacing: 1px; + > span { + position: relative; + top: 2px; + } + } + .content { + line-height: 25px; + padding-left: 10px; + padding: 6px 0 0 10px; + } + .v-right-content { + flex: 1; + text-align: right; + } + .h-icon { + position: relative; + top: 2px; + margin-right: 3px; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolTable.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolTable.vue" new file mode 100644 index 0000000..0622c7c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolTable.vue" @@ -0,0 +1,1874 @@ +<template> + <!-- 2021.11.18绉婚櫎voltable鏂规硶@cell-mouse-leave="rowEndEdit" --> + <div + class="vol-table" + :class="[ + textInline ? 'text-inline' : '', + fxRight ? 'fx-right' : '', + isChrome ? 'chrome' : '', + ]" + > + <div class="mask" v-show="loading"></div> + <div class="message" v-show="loading">鍔犺浇涓�.....</div> + <el-table + :show-summary="summary" + :summary-method="getSummaryData" + :row-key="rowKey" + :key="randomTableKey" + lazy + stripe + :load="loadTreeChildren" + @select="userSelect" + @select-all="userSelect" + @selection-change="selectionChange" + @row-dblclick="rowDbClick" + @row-click="rowClick" + @header-click="headerClick" + :highlight-current-row="highlightCurrentRow" + ref="table" + class="v-table" + @sort-change="sortChange" + tooltip-effect="dark" + :height="realHeight" + :max-height="realMaxHeight" + :data="url ? rowData : tableData" + border + :row-class-name="initIndex" + :cell-style="getCellStyle" + style="width: 100%" + :scrollbar-always-on="true" + > + <el-table-column + v-if="ck" + type="selection" + :fixed="fixed" + :selectable="selectable" + width="55" + ></el-table-column> + <el-table-column + v-if="columnIndex" + type="index" + :fixed="fixed" + label="搴忓彿" + width="55" + ></el-table-column> + + <!-- 2020.10.10绉婚櫎table绗竴琛屽己鍒舵帓搴� --> + <el-table-column + v-for="(column, cindex) in filterColumns" + :prop="column.field" + :label="column.title" + :min-width="column.width" + :formatter="formatter" + :fixed="column.fixed" + :key="column.field + cindex" + :align="column.align" + :sortable="column.sort ? 'custom' : false" + :show-overflow-tooltip="true" + > + <template #header> + <span + v-if="(column.require || column.required) && column.edit" + class="column-required" + >*</span + >{{ column.title }} + </template> + + <template #default="scope"> + <!-- 2022.01.08澧炲姞澶氳〃澶达紝鐜板湪鍙敮鎸佸父鐢ㄥ姛鑳芥覆鏌擄紝涓嶆敮鎸佺紪杈戝姛鑳�(娑夊強鍒扮粍浠堕噸鍐�) --> + <el-table-column + style="border: none" + v-for="columnChildren in filterChildrenColumn(column.children)" + :key="columnChildren.field" + :min-width="columnChildren.width" + :class-name="columnChildren.class" + :prop="columnChildren.field" + :align="columnChildren.align" + :label="columnChildren.title" + > + <template #default="scopeChildren"> + <a + href="javascript:void(0)" + style="text-decoration: none" + @click="link(scopeChildren.row, columnChildren, $event)" + v-if="column.link" + v-text="scopeChildren.row[columnChildren.field]" + ></a> + <div + v-else-if="columnChildren.formatter" + @click=" + columnChildren.click && + columnChildren.click( + scopeChildren.row, + columnChildren, + scopeChildren.$index + ) + " + v-html=" + columnChildren.formatter( + scopeChildren.row, + columnChildren, + scopeChildren.$index + ) + " + ></div> + <div v-else-if="column.bind"> + {{ formatter(scopeChildren.row, columnChildren, true) }} + </div> + <span v-else-if="column.type == 'date'">{{ + formatterDate(scopeChildren.row, columnChildren) + }}</span> + <template v-else> + {{ scopeChildren.row[columnChildren.field] }} + </template> + </template> + </el-table-column> + <!-- 2020.06.18澧炲姞render娓叉煋鑷畾涔夊唴瀹� --> + <table-render + v-if="column.render && typeof column.render == 'function'" + :row="scope.row" + key="rd-01" + :index="scope.$index" + :column="column" + :render="column.render" + ></table-render> + <!-- 鍚敤鍙屽嚮缂栬緫鍔熻兘锛屽甫缂栬緫鍔熻兘鐨勪笉浼氭覆鏌撲笅鎷夋鏂囨湰鑳屾櫙棰滆壊 --> + <!-- @click="rowBeginEdit(scope.$index,cindex)" --> + <!-- 2021.09.21澧炲姞缂栬緫鏃跺readonly灞炴�у垽鏂� --> + <template + v-else-if=" + column.edit && + !column.readonly && + ['file', 'img', 'excel'].indexOf(column.edit.type) != -1 + " + > + <div style="display: flex; align-items: center" @click.stop> + <i + style=" + padding: 3px; + margin-right: 10px; + color: #8f9293; + cursor: pointer; + " + @click="showUpload(scope.row, column)" + class="el-icon-upload" + ></i> + <img + v-show="column.edit.type == 'img'" + v-for="(file, imgIndex) in getFilePath( + scope.row[column.field], + column + )" + :key="imgIndex" + :onerror="defaultImg" + @click="viewImg(scope.row, column, file.path, $event)" + class="table-img" + :src="file.path" + /> + <a + style="margin-right: 8px" + v-show="column.edit.type != 'img'" + class="t-file" + v-for="(file, fIndex) in getFilePath( + scope.row[column.field], + column + )" + :key="fIndex" + @click="dowloadFile(file)" + >{{ file.name }}</a + > + </div> + </template> + <div + v-else-if=" + column.edit && + !column.readonly && + (column.edit.keep || edit.rowIndex == scope.$index) + " + class="edit-el" + > + <div @click.stop class="e-item"> + <div> + <!-- 2020.07.24澧炲姞鏃ユ湡onChange浜嬩欢 --> + <el-date-picker + clearable + size="default" + style="width: 100%" + v-if="['date', 'datetime'].indexOf(column.edit.type) != -1" + v-model="scope.row[column.field]" + @change=" + (val) => { + column.onChange && + column.onChange(scope.row, column, val); + } + " + :type="column.edit.type" + :placeholder="column.placeholder || column.title" + :disabledDate="(val) => getDateOptions(val, column)" + :value-format="getDateFormat(column)" + :disabled="initColumnDisabled(scope.row, column)" + > + </el-date-picker> + <el-time-picker + clearable + size="default" + style="width: 100%" + v-else-if="column.edit.type == 'time'" + v-model="scope.row[column.field]" + @change=" + (val) => { + column.onChange && + column.onChange(scope.row, column, val); + } + " + :placeholder="column.placeholder || column.title" + :value-format="column.format || 'HH:mm:ss'" + :disabled="initColumnDisabled(scope.row, column)" + > + </el-time-picker> + <el-switch + v-else-if="column.edit.type == 'switch'" + v-model="scope.row[column.field]" + active-color="#0f84ff" + inactive-color="rgb(194 194 194)" + @change=" + (val) => { + switchChange(val, scope.row, column); + } + " + :active-value=" + typeof scope.row[column.field] == 'boolean' + ? true + : typeof scope.row[column.field] == 'string' + ? '1' + : 1 + " + :inactive-value=" + typeof scope.row[column.field] == 'boolean' + ? false + : typeof scope.row[column.field] == 'string' + ? '0' + : 0 + " + :disabled="initColumnDisabled(scope.row, column)" + > + </el-switch> + <template + v-else-if=" + ['select', 'selectList'].indexOf(column.edit.type) != -1 + " + > + <el-select-v2 + style="width: 100%" + :size="size" + v-if="column.bind.data.length >= select2Count" + v-model="scope.row[column.field]" + filterable + :multiple="column.edit.type == 'select' ? false : true" + :placeholder="column.placeholder || column.title" + :autocomplete="column.autocomplete" + :options="column.bind.data" + @change=" + column.onChange && column.onChange(scope.row, column) + " + clearable + :disabled="initColumnDisabled(scope.row, column)" + > + <template #default="{ item }"> + {{ item.label }} + </template> + </el-select-v2> + + <el-select + size="default" + style="width: 100%" + v-else + v-model="scope.row[column.field]" + :filterable=" + column.filter || column.bind.data.length > 10 + ? true + : false + " + :multiple="column.edit.type == 'select'" + :placeholder="column.placeholder || column.title" + :autocomplete="column.autocomplete" + @change=" + column.onChange && column.onChange(scope.row, column) + " + clearable + :disabled="initColumnDisabled(scope.row, column)" + > + <el-option + v-for="item in column.bind.data" + :key="item.key" + v-show="!item.hidden" + :disabled="item.disabled" + :label="item.value" + :value="item.key" + >{{ item.value }} + </el-option> + </el-select> + </template> + <el-input + v-else-if="column.edit.type == 'textarea'" + type="textarea" + :placeholder="column.placeholder || column.title" + v-model="scope.row[column.field]" + :disabled="initColumnDisabled(scope.row, column)" + > + </el-input> + <input + class="table-input" + v-else-if="!column.summary && !column.onKeyPress" + v-model.lazy="scope.row[column.field]" + :disabled="initColumnDisabled(scope.row, column)" + /> + <el-input + v-else + @change="inputKeyPress(scope.row, column, $event)" + @input="inputKeyPress(scope.row, column, $event)" + @keyup.enter="inputKeyPress(scope.row, column, $event)" + size="default" + v-model="scope.row[column.field]" + :placeholder="column.placeholder || column.title" + :disabled="initColumnDisabled(scope.row, column)" + ></el-input> + </div> + <div + class="extra" + v-if="column.extra && edit.rowIndex == scope.$index" + > + <a + :style="column.extra.style" + style="text-decoration: none" + @click="extraClick(scope.row, column)" + > + <i v-if="column.extra.icon" :class="[column.extra.icon]" /> + {{ column.extra.text }} + </a> + </div> + </div> + </div> + <!--娌℃湁缂栬緫鍔熻兘鐨勭洿鎺ユ覆鏌撴爣绛�--> + <template v-else> + <a + href="javascript:void(0)" + style="text-decoration: none" + @click="link(scope.row, column, $event)" + v-if="column.link" + v-text="scope.row[column.field]" + ></a> + <img + v-else-if="column.type == 'img'" + v-for="(file, imgIndex) in getFilePath( + scope.row[column.field], + column + )" + :key="imgIndex" + :onerror="defaultImg" + @click="viewImg(scope.row, column, file.path, $event)" + class="table-img" + :src="file.path" + /> + <a + style="margin-right: 8px" + v-else-if="column.type == 'file' || column.type == 'excel'" + class="t-file" + v-for="(file, fIndex) in getFilePath( + scope.row[column.field], + column + )" + :key="fIndex" + @click="dowloadFile(file)" + >{{ file.name }}</a + > + <span v-else-if="column.type == 'date'">{{ + formatterDate(scope.row, column) + }}</span> + <div + v-else-if="column.formatter" + @click="formatterClick(scope.row, column, $event)" + v-html="column.formatter(scope.row, column)" + ></div> + <!-- 2021.11.18淇table鏁版嵁婧愯缃负normal鍚庣偣鍑昏$event缂哄け鐨勯棶棰� --> + <div + v-else-if="column.bind && (column.normal || column.edit)" + @click="formatterClick(scope.row, column, $event)" + :style="column.getStyle && column.getStyle(scope.row, column)" + > + {{ formatter(scope.row, column, true) }} + </div> + <div + v-else-if="column.click && !column.bind" + @click="formatterClick(scope.row, column)" + > + {{ scope.row[column.field] }} + </div> + <div + @click=" + () => { + column.click && formatterClick(scope.row, column); + } + " + v-else-if="column.bind" + > + <el-tag + v-if="useTag" + :class="[isEmptyTag(scope.row, column)]" + :type="getColor(scope.row, column)" + :effect="column.effect" + >{{ formatter(scope.row, column, true) }}</el-tag + > + <template v-else>{{ + formatter(scope.row, column, true) + }}</template> + </div> + + <span v-else>{{ formatter(scope.row, column, true) }}</span> + </template> + </template> + </el-table-column> + </el-table> + <template v-if="!paginationHide"> + <div class="block pagination" key="pagination-01" style="display: flex"> + <div style="flex: 1"></div> + <el-pagination + key="pagination-02" + @size-change="handleSizeChange" + @current-change="handleCurrentChange" + :current-page="paginations.page" + :page-sizes="paginations.sizes" + :page-size="paginations.size" + layout="total, sizes, prev, pager, next, jumper" + :total="paginations.total" + ></el-pagination> + </div> + </template> + </div> + + <VolBox + v-model="uploadModel" + title="涓婁紶" + :height="228" + :width="500" + :padding="15" + lazy + > + <!-- 涓婁紶鍥剧墖銆乪xcel鎴栧叾浠栨枃浠躲�佹枃浠舵暟閲忋�佸ぇ灏忛檺鍒堕兘鍙互锛屽弬鐓olupload缁勪欢api --> + <div style="height: 200px; display: flex; align-items: center"> + <VolUpload + style="text-align: center" + :autoUpload="currentColumn.edit.autoUpload" + :multiple="currentColumn.edit.multiple" + :url="uploadUrl" + :max-file="currentColumn.edit.maxFile" + :img="currentColumn.edit.type == 'img'" + :excel="currentColumn.edit.type == 'excel'" + :fileTypes=" + currentColumn.edit.fileTypes ? currentColumn.edit.fileTypes : [] + " + :fileInfo="fileInfo" + :upload-after="uploadAfter" + > + <div>{{ currentColumn.message }}</div> + </VolUpload> + </div> + <template #footer> + <div style="text-align: center"> + <el-button type="default" size="small" @click="uploadModel = false" + >鍏抽棴</el-button + > + <el-button type="primary" size="small" @click="saveUpload" + >淇濆瓨</el-button + > + </div> + </template> + </VolBox> +</template> +<script> +import VolTableRender from "./VolTable/VolTableRender"; +let _errMsg; +import { defineComponent, defineAsyncComponent } from "vue"; +export default defineComponent({ + //https://github.com/element-plus/element-plus/issues/1483 + //娌℃湁鍘熷厛鐨剆election灞炴�т簡锛岀湅issue涓婁娇鐢╯elect/selectall鑾峰彇 + //鐩戝惉鏁扮粍闀垮害锛屽鏋滃垹闄や簡鏁版嵁锛岀幇鍦ㄥ彧鑳借杩竻闄ゆ墍鏈夐�変腑鐨勮 + watch: { + "tableData.length": { + handler(newLen, oldLen) { + this.watchRowSelectChange(newLen, oldLen); + }, + }, + "rowData.length": { + handler(newLen, oldLen) { + this.watchRowSelectChange(newLen, oldLen); + }, + }, + }, + components: { + "table-render": VolTableRender, + VolUpload: defineAsyncComponent(() => + import("@/components/basic/VolUpload.vue") + ), + VolBox: defineAsyncComponent(() => import("@/components/basic/VolBox.vue")), + }, + props: { + rowKey: { + // 鏍戝舰缁撴瀯鐨勪富閿瓧娈碉紝濡傛灉璁剧疆鍊奸粯璁や細寮�鍚爲褰able锛涙敞鎰弐owKey瀛楁鐨勫�煎繀椤绘槸鍞竴锛�2021.05.02锛� + typeof: String, + default: undefined, + }, + loadTreeChildren: { + // 鏍戝舰缁撴瀯鍔犺浇瀛愯妭鐐� + type: Function, + default: (tree, treeNode, resolve) => { + return resolve([]); + }, + }, + textInline: { + // 琛ㄦ牸鍐呭瓒呭嚭鍚庢槸鍚︽崲琛屾樉绀猴紙2020.01.16锛� + type: Boolean, + default: true, + }, + tableData: { + // 琛ㄦ暟鎹簮,閰嶇疆浜唘rl灏变笉鐢ㄤ紶杩欎釜鍙傛暟浜� + type: Array, + default: () => { + return []; + }, + }, + columns: { + type: Array, + default: [], + }, + height: { + type: Number, + default: 0, + }, + maxHeight: { + type: Number, + default: 0, + }, + linkView: { + type: Function, + default: function () { + return 1; + }, + }, + pagination: { + type: Object, + default: function () { + return { total: 0, size: 30, sortName: "" }; + }, + }, + url: { + type: String, + default: "", + }, + paginationHide: { + type: Boolean, + default: true, + }, + color: { + type: Boolean, + default: true, + }, + index: { + // 鏄惁鍒涘缓绱㈠紩鍙�,濡傛灉闇�瑕佽〃鏍肩紪杈戝姛鑳斤紝杩欓噷闇�瑕佽缃负true + type: Boolean, + default: false, + }, + allowEmpty: { + // 琛ㄦ牸鏁版嵁涓虹┖鏃舵槸鍚﹂粯璁や负-- + type: Boolean, + default: true, + }, + defaultLoadPage: { + // 浼犲叆浜唘rl锛屾槸鍚﹂粯璁ゅ姞杞借〃鏍兼暟鎹� + type: Boolean, + default: true, + }, + loadKey: { + // 鏄惁鑷姩浠庡悗鍙板姞杞芥暟鎹簮 + type: Boolean, + default: true, + }, + single: { + type: Boolean, // 鏄惁鍗曢�� + default: false, + }, + doubleEdit: { + type: Boolean, // 鏄惁鍙屽嚮鍚敤缂栬緫鍔熻兘 + default: true, + }, + beginEdit: { + // 缂栬緫寮�濮� + type: Function, + default: function (row, column, index) { + return true; + }, + }, + endEditBefore: { + // 缁撴潫缂栬緫鍓� + type: Function, + default: function (row, column, index) { + return true; + }, + }, + endEditAfter: { + // 缁撴潫缂栬緫鍓� + type: Function, + default: function (row, column, index) { + return true; + }, + }, + ck: { + // 鏄惁鏄剧ずcheckbox + type: Boolean, + default: true, + }, + columnIndex: { + // 鏄惁鏄剧ず琛屽彿(2020..11.1) + type: Boolean, + default: true, + }, + highlightCurrentRow: { + //澧炲姞閫変腑琛岄珮浜樉绀�(2022.10.07) + type: Boolean, + default: true, + }, + select2Count: { + //瓒呭嚭鏁伴噺鏄剧ずselect2缁勪欢 + type: Number, + default: 500, + }, + selectable: { + type: Function, + default: (row, index) => { + return true; + }, + }, + }, + data() { + return { + fixed: false, //鏄浐瀹氳鍙蜂笌checkbox + clickEdit: true, //2021.07.17璁剧疆涓虹偣鍑昏缁撴潫缂栬緫 + randomTableKey: 1, + visiblyColumns: [], + key: "", + realHeight: 0, + realMaxHeight: 0, + enableEdit: false, // 鏄惁鍚〃鏍肩敤缂栬緫鍔熻兘 + empty: this.allowEmpty ? "" : "--", + defaultImg: 'this.src="' + require("@/assets/imgs/error.png") + '"', + loading: false, + footer: {}, + total: 0, + formatConfig: {}, + // defaultColor: "", + // 2020.09.06璋冩暣table鍒楁暟鎹簮鐨勮儗鏅鑹� + colors: ["", "warning", "success", "danger", "info"], + rule: { + phone: /^[1][3,4,5,6,7,8,9][0-9]{9}$/, + decimal: /(^[\-0-9][0-9]*(.[0-9]+)?)$/, + number: /(^[\-0-9][0-9]*([0-9]+)?)$/, + }, + columnNames: [], + rowData: [], + paginations: { + sort: "", + order: "desc", + Foots: "", + total: 0, + // 2020.08.29澧炲姞鑷畾涔夊垎椤垫潯澶у皬 + sizes: [30, 60, 100, 120], + size: 30, // 榛樿鍒嗛〉澶у皬 + Wheres: [], + page: 1, + rows: 30, + }, + errorFiled: "", + edit: { columnIndex: -1, rowIndex: -1 }, // 褰撳墠鍙屽嚮缂栬緫鐨勮涓庡垪鍧愭爣 + editStatus: {}, + summary: false, // 鏄惁鏄剧ず鍚堣 + // 鐩墠鍙敮鎸佷粠鍚庡彴杩斿洖鐨剆ummaryData鏁版嵁 + summaryData: [], + summaryIndex: {}, + remoteColumns: [], // 闇�瑕佹瘡娆″埛鏂版垨鍒嗛〉鍚庝粠鍚庡彴鍔犺浇瀛楀吀鏁版嵁婧愮殑鍒楅厤缃� + cellStyleColumns: {}, // 鏈夎儗鏅鑹茬殑閰嶇疆 + fxRight: false, //鏄惁鏈夊彸杈瑰浐瀹氳〃澶� + selectRows: [], //褰撳墠閫変腑鐨勮 + isChrome: false, + //vol-table甯︽暟鎹簮鐨勫崟鍏冩牸鏄惁鍚敤tag鏍囩(涓嬫媺妗嗙瓑鍗曞厓鏍间互tag鏍囩鏄剧ず) + //2023.04.02鏇存柊voltable涓巑ain.js + useTag: true, + currentRow: {}, + currentColumn: [], + fileInfo: [], + uploadUrl: "", + uploadModel: false, + }; + }, + created() { + try { + this.useTag = this.$global.table.useTag; + } catch (error) { + console.log(error.message); + } + //2021.06.19鍒ゆ柇璋锋瓕鍐呮牳娴忚閲嶆柊璁$畻table楂樺害 + // if ( + // navigator.userAgent.indexOf('Chrome') != -1 || + // navigator.userAgent.indexOf('Edge') != -1 + // ) { + // this.isChrome = true; + // } + this.realHeight = this.getHeight(); + this.realMaxHeight = this.getMaxHeight(); + this.fxRight = this.columns.some((x) => { + return x.fixed == "right"; + }); + //2021.09.21绉婚櫎寮哄埗鍥哄畾琛屽彿涓巆heckbox鍒� + if ( + this.columns.some((x) => { + return x.fixed && x.fixed != "right"; + }) + ) { + this.fixed = true; + } + //2022.04.06浼樺寲table鍚堣鍥哄畾鍒楁樉绀� + // if ( + // this.columns.some((x) => { + // return x.summary; + // }) + // ) { + // this.columns.forEach((x) => { + // if (x.fixed && x.fixed != 'right') { + // x.fixed = false; + // } + // }); + // this.fixed = false; + // } + + // 浠庡悗鍙板姞涓嬫媺妗嗙殑[鏄惁鍚敤鐨刔鏁版嵁婧� + let keys = []; + let columnBind = []; + this.summaryData.push("鍚堣"); + if (this.columnIndex) { + this.summaryData.push(" "); + } + this.columns.forEach((x, _index) => { + if (x.cellStyle) { + this.cellStyleColumns[x.field] = x.cellStyle; + } + if (!x.hidden) { + // this.summaryIndex[x.field] = _index; + // 2020.10.11淇姹傚拰鍒楅敊浣嶇殑闂 + this.summaryData.push(""); + this.summaryIndex[x.field] = this.summaryData.length - 1; + } + // 姹傚拰 + if (x.summary && !this.summary) { + this.summary = true; + } + if (x.bind && x.bind.key && (!x.bind.data || x.bind.data.length == 0)) { + // 鍐欏叆杩滅▼ + if (!x.bind.data) x.bind.data = []; + if (x.bind.remote) { + this.remoteColumns.push(x); + } else if (this.loadKey) { + keys.push(x.bind.key); + x.bind.valueTyoe = x.type; + columnBind.push(x.bind); + } + } + }); + if (keys.length > 0) { + this.http + .post("/api/Sys_Dictionary/GetVueDictionary", keys) + .then((dic) => { + dic.forEach((x) => { + if (x.data.length > this.select2Count) { + x.data.forEach((item) => { + item.label = item.value; + item.value = item.key; + }); + } + columnBind.forEach((c) => { + // 杞崲鏁版嵁婧愮殑绫诲瀷涓庡垪鐨勭被鍨嬩竴鑷�(2020.04.04) + if ( + c.key == x.dicNo && + (c.valueTyoe == "int" || c.valueTyoe == "sbyte") + ) { + x.data.forEach((d) => { + // 2020.09.01澧炲姞瀵规暟瀛楃被鍨嬬殑浜屾鍒ゆ柇 + if (!isNaN(d.key)) { + d.key = ~~d.key; + } + }); + } + if (c.key == x.dicNo) c.data.push(...x.data); + }); + }); + }); + } + + this.paginations.sort = this.pagination.sortName; + // 2020.08.29澧炲姞鑷畾涔夊垎椤垫潯澶у皬 + Object.assign(this.paginations, this.pagination); + if (this.pagination.size) { + this.paginations.rows = this.pagination.size; + } + this.enableEdit = this.columns.some((x) => { + return x.hasOwnProperty("edit"); + }); + let keyColumn = this.columns.find((x) => { + return x.isKey; + }); + if (keyColumn) { + this.key = keyColumn.field; + } + this.defaultLoadPage && this.load(); + }, + computed: { + filterColumns() { + return this.columns.filter((x, index) => { + if (!x.field) { + x.field = x.title + index; + } + return !x.hidden; + }); + }, + }, + methods: { + watchRowSelectChange(newLen, oldLen) { + if (newLen < oldLen && this.selectRows.length) { + this.selectRows = []; + this.$refs.table.clearSelection(); + } + }, + switchChange(val, row, column) { + //杩欓噷鍦ㄥ垵濮嬪寲鐨勬椂鍊欎篃浼氳Е鍙慶hange浜嬩欢 + if (Object.keys(row).length <= 1) { + return; + } + if (column.onChange) { + column.onChange(val, row, column); + } + }, + inputKeyPress(row, column, $event, $e) { + column.onKeyPress && column.onKeyPress(row, column, $event); + this.getInputSummaries(null, null, $event, column); + }, + extraClick(row, column) { + column.extra.click && + column.extra.click( + row, + column, + this.url ? this.rowData : this.tableData + ); + }, + headerClick(column, event) { + if (this.clickEdit && this.edit.rowIndex != -1) { + if ( + this.rowEndEdit( + this.url + ? this.rowData[this.edit.rowIndex] + : this.tableData[this.edit.rowIndex], + column + ) + ) { + this.edit.rowIndex = -1; + } + } + // this.edit.rowIndex = -1; + }, + rowDbClick(row, column, event) { + //2021.05.23澧炲姞鍙屽嚮琛屼簨浠� + this.$emit("rowDbClick", { row, column, event }); + }, + rowClick(row, column, event) { + //2022.02.20澧炲姞鐐瑰嚮鏃惰〃鏍煎弬鏁板垽鏂� + if (!column) { + return; + } + //姝e湪缂栬緫鏃讹紝绂佹鍑哄彂rowClick浜嬩欢 + if (this.edit.rowIndex == -1) { + this.$emit("rowClick", { row, column, event }); + } + // 鐐瑰嚮琛屼簨浠�(2020.11.07) + + if (!this.doubleEdit) { + return; + } + // 鐐瑰嚮鍏朵粬琛屾椂锛屽鏋滅偣鍑荤殑琛屼笌姝e湪缂栬緫鐨勮鐩稿悓锛屼繚鎸佺紪杈戠姸鎬� + if (this.clickEdit && this.edit.rowIndex != -1) { + if (row.elementIndex == this.edit.rowIndex) { + // 鐐瑰嚮鐨勫崟鍏冩牸濡傛灉涓嶅彲浠ョ紪杈戯紝鐩存帴缁撴潫缂栬緫 + // 2020.10.12淇缁撴潫缂栬緫鏃讹紝element table楂樼増鏈睘鎬ц幏鍙栦笉鍒扮殑闂 + let _col = this.columns.find((x) => { + return x.field == ((event && event.property) || column.property); + }); + if (_col && (!_col.edit || _col.readonly)) { + if (this.rowEndEdit(row, event)) { + this.edit.rowIndex = -1; + } + } + return; + } + if (this.rowEndEdit(row, event && event.property ? event : column)) { + this.edit.rowIndex = -1; + } + //褰撴鍦ㄧ紪杈戯紝涓旂偣鍑诲埌鍏朵粬琛屾椂锛屽湪鍘熺紪杈戠殑琛岀粨鏉熺紪杈戝悗锛岃Е鍙戞柊琛岀殑rowClick浜嬩欢 + //姝e湪缂栬緫鏃讹紝绂佹鍑哄彂rowClick浜嬩欢 + if (this.edit.rowIndex == -1) { + this.$emit("rowClick", { row, column, event }); + } + } + this.rowBeginEdit(row, column); + }, + dowloadFile(file) { + this.base.dowloadFile( + file.path, + file.name, + { + Authorization: this.$store.getters.getToken(), + }, + this.http.ipAddress + ); + }, + getFilePath(pathSring, column) { + // 鑾峰彇琛ㄧ殑鍥剧墖涓庢枃浠舵樉绀� + if (!pathSring) return []; + // 澧炲姞鍥剧墖鑷畾涔夋搷浣� + // 杩斿洖鏍煎紡蹇呴』鏄痆{name:"鏂囦欢鍚�",path:"鍥剧墖鍏ㄨ矾寰勬垨base64鏍煎紡"}] + if (column.formatter) { + return column.formatter(pathSring); + } + let filePath; + if (column.base64 && pathSring.indexOf("data") != -1) { + filePath = ("," + pathSring) + .split(",data") + .filter((x) => { + return x; + }) + .map((m) => { + return "data" + m; + }); + } else { + filePath = pathSring.replace(/\\/g, "/").split(","); + } + + let fileInfo = []; + for (let index = 0; index < filePath.length; index++) { + let file = filePath[index]; + // 2020.12.19澧炲姞base64鍥剧墖鏄剧ず + if (column.base64) { + fileInfo.push({ + name: "", + path: + (file.indexOf("data") == -1 ? "data:image/png;base64," : "") + + file, + }); + } else if (file.indexOf(".") != -1) { + let splitFile = file.split("/"); + if (splitFile.length > 0) { + fileInfo.push({ + name: splitFile[splitFile.length - 1], + path: this.base.isUrl(file) ? file : this.http.ipAddress + file, + }); + } + } + } + return fileInfo; + }, + // 閲嶇疆table + reset() { + if (this.tableData && this.tableData.length > 0) { + this.tableData.splice(0); + } + if (this.rowData && this.rowData.length > 0) { + this.rowData.splice(0); + } + if (!this.paginationHide) { + this.paginations.page = 1; + // this.paginations.rows = 30; + if (this.paginations.wheres && this.paginations.wheres.length > 0) { + this.paginations.wheres.splice(0); + } + } + this.errorFiled = ""; + this.edit.columnIndex = -1; + this.edit.rowIndex = -1; + }, + getHeight() { + // 娌℃湁瀹氫箟楂樺害涓庢渶澶ч珮搴︼紝浣跨敤table榛樿鍊� + if (!this.height && !this.maxHeight) { + return null; + } + // 瀹氫箟浜嗘渶澶ч珮搴﹀垯涓嶄娇鐢ㄩ珮搴� + if (this.maxHeight) { + return null; + } + // 浣跨敤褰撳墠瀹氫箟鐨勯珮搴� + return this.height; + }, + getMaxHeight() { + // 娌℃湁瀹氫箟楂樺害涓庢渶澶ч珮搴︼紝浣跨敤table榛樿鍊� + if (!this.height && !this.maxHeight) { + return null; + } + // 瀹氫箟浜嗘渶澶ч珮搴︿娇鐢ㄦ渶澶ч珮搴� + if (this.maxHeight) { + return this.maxHeight; + } + // 涓嶄娇鐢ㄦ渶澶ч珮搴� + return null; + }, + getSelectedOptions(column) { + if (column.bind && column.bind.data && column.bind.data.length > 0) { + return column.bind.data; + } + return []; + }, + formatterClick(row, column, event) { + if (column.click) { + column.click(row, column, event); + event.stopPropagation && event.stopPropagation(); + } else { + this.rowClick(row, column, event); + } + }, + initIndex({ row, rowIndex }) { + if (this.index) { + row.elementIndex = rowIndex; + } + // if (rowIndex%2!==0) { + // return "even-row"; + // } + return; + }, + toggleEdit(event) {}, + setEditStatus(status) { + // this.columns.forEach((x) => { + // if (x.hasOwnProperty("edit")) { + // this.$set(x.edit, "status", status); + // } + // }); + }, + // 閫氳繃button鎸夐挳鍚敤缂栬緫 + beginWithButtonEdit(scope) { + // url?rowData:tableData + this.rowBeginEdit(scope.row, this.columns[scope.$index]); + }, + rowBeginEdit(row, column) { + if (this.edit.rowIndex != -1) { + return; + } + let _row = this.columns.find((x) => x.field == column.property); + if (_row) { + if (_row.readonly) { + return; + } + if ( + //涓嶈兘缂栬緫鐨勫瓧娈点�乻witch锛岀偣鍑讳笉寮�鍚惎缂栬緫鍔熻兘 + !_row.edit || + (_row.edit.keep && _row.edit.type == "switch") + ) { + return; + } + } + if (!this.enableEdit) return; + _errMsg = ""; + // 缂栬緫鍓� + this.columns + .filter((x) => { + return x.bind && x.bind.data && x.bind.data.length; + }) + .forEach((column) => { + let val = row[column.field]; + if (typeof column.bind.data[0].key == "string") { + if (typeof val == "number") { + row[column.field] = row[column.field] + ""; + } + } else { + if (typeof val == "string" && val) { + let _val = val * 1; + if (_val + "" === val) { + row[column.field] = _val; + } + } + } + }); + if (!this.beginEdit(row, column, row.elementIndex)) return; + if (row.hasOwnProperty("elementIndex")) { + if (this.edit.rowIndex == row.elementIndex) { + return; + } + this.edit.rowIndex = row.elementIndex; + } + }, + rowEndEdit(row, column, event) { + if (this.clickEdit && event) { + return true; + } + if (!this.enableEdit) { + if (!this.errorFiled) { + if ( + this.edit.rowIndex != -1 && + !this.endEditAfter(row, column, this.edit.rowIndex) + ) { + return false; + } + this.edit.rowIndex = -1; + } + return true; + } + if (!this.doubleEdit && event) { + return true; + } + let _row = this.url + ? this.rowData[this.edit.rowIndex] + : this.tableData[this.edit.rowIndex]; + // 缁撴潫缂栬緫鍓� + if (!this.endEditBefore(_row, column, this.edit.rowIndex)) return false; + if (this.edit.rowIndex != -1) { + //2022.06.26淇琛ㄦ牸鍐呭鍒囨崲鍚庤鏁颁笉涓�鑷存椂涓嶈兘缂栬緫鐨勯棶棰� + if (this.edit.rowIndex - 1 > (this.rowData || this.tableData).length) { + this.edit.rowIndex = -1; + return; + } + let row = (this.url ? this.rowData : this.tableData)[ + this.edit.rowIndex + ]; + for (let index = 0; index < this.columns.length; index++) { + const _column = this.columns[index]; + if (_column.edit) { + if (!this.validateRow(row, _column)) { + return; + } + } + } + } + if (!this.endEditAfter(_row, column, this.edit.rowIndex)) return false; + this.edit.rowIndex = -1; + return true; + }, + validateRow(row, option1) { + if (!this.validateColum(option1, row)) { + this.errorFiled = option1.field; + // 2022.05.06 淇敼閿欒淇℃伅閲嶅鐨勯棶棰� + this.$message.error(option1.title + _errMsg); + return false; + } + this.errorFiled = ""; + return true; + }, + validateColum(option, data) { + if (option.hidden || option.bind) return true; + let val = data[option.field]; + if (option.require || option.required) { + if (val != "0" && (val === "" || val === undefined)) { + if (!this.errorFiled) { + _errMsg = "涓嶈兘涓虹┖"; + } + return false; + } + } + if (!option.edit) { + return true; + } + let editType = option.edit.type; + // 楠岃瘉鏁板瓧 + if (editType == "int" || editType == "decimal" || editType == "number") { + if (val == "" || val == undefined) return true; + if (editType == "decimal") { + if (!this.rule.decimal.test(val)) { + _errMsg = "鍙兘鏄暟瀛�"; + return false; + } + } else if (!this.rule.decimal.test(val)) { + _errMsg = "鍙兘鏄暟瀛�"; + return false; + } + if ( + option.edit.min != undefined && + typeof option.edit.min === "number" && + val < option.edit.min + ) { + _errMsg = "涓嶈兘灏忎簬" + option.edit.min; + return false; + } + if ( + option.edit.max != undefined && + typeof option.edit.max === "number" && + val > option.edit.max + ) { + _errMsg = "涓嶈兘澶т簬" + option.edit.max; + return false; + } + return true; + } + + // 楠岃瘉瀛楃涓� + if (val && (editType == "text" || editType == "string")) { + if ( + option.edit.min != undefined && + typeof option.edit.min === "number" && + val.length < option.edit.min + ) { + _errMsg = "鑷冲皯" + option.edit.min + "涓瓧绗�"; + return false; + } + if ( + option.edit.max != undefined && + typeof option.edit.max === "number" && + val.length > option.edit.max + ) { + _errMsg = "鏈�澶�" + option.edit.max + "涓瓧绗�"; + return false; + } + } + return true; + }, + delRow() { + let rows = this.getSelected(); + if (rows.length == 0) return this.$Message.error("璇烽�夋嫨瑕佸垹闄ょ殑琛�!"); + + let data = this.url ? this.rowData : this.tableData; + let indexArr = this.getSelectedIndex(); + if (indexArr.length == 0) { + return this.$Message.error( + "鍒犻櫎鎿嶄綔蹇呴』璁剧疆VolTable鐨勫睘鎬ndex='true'" + ); + } + // if (indexArr.length == 0 || !this.key) { + // return this.$message.error( + // "璇疯缃甶ndex=true灞炴�ф垨鎸嘽olumns鐨勫瓧娈典负key" + // ); + // } + if (indexArr.length == 0) { + // let keyValues=[] + // rows.forEach(x=>{ + // if (x[this.key]) { + // } + // keyValues.push(x[this.key]) + // }) + // data.find(x=>) + } else { + for (let i = data.length - 1; i >= 0; i--) { + if (indexArr.indexOf(i) != -1) { + data.splice(i, 1); + } + } + } + this.edit.rowIndex = -1; + return rows; + }, + addRow(row) { + if (!row) { + row = {}; + } + this.columns.forEach((x) => { + // 2022.05.06 娣诲姞琛屾椂锛屽鏋滃垪鏈夌紪杈戝睘鎬э紝璁剧疆寮�鍚紪杈�(閬垮厤鍏抽棴缂栬緫鍚庯紝鏃犳硶鍐嶆鍚敤缂栬緫)?? + //x.readonly = false; + if (!row.hasOwnProperty(x.field)) { + if (x.edit && x.edit.type == "switch") { + row[x.field] = x.type == "bool" ? false : 0; + } else if (!row.hidden) { + // 2020.09.06娣诲姞琛屾椂锛岃缃粯璁ゅ瓧娈� + row[x.field] = undefined; + } + } + }); + if (!this.url) { + this.tableData.push(row); + return; + } + this.rowData.push(row); + }, + viewImg(row, column, url, $event) { + $event.stopPropagation(); + this.base.previewImg(url); + // window.open(row[column.field]); + }, + link(row, column, $e) { + $e.stopPropagation(); + this.$props.linkView(row, column); + }, + getSelected() { + return this.selectRows; + }, + getSelectedIndex() { + if (!this.index) { + // 鍙湁璁剧疆浜嗗睘鎬ndex鎵嶆湁绱㈠紩琛� + return []; + } + let indexArr = this.selectRows.map((x) => { + return x.elementIndex; + }); + return indexArr || []; + }, + GetTableDictionary(rows) { + // 鍒嗛〉鎴栧埛鏂版垨閲嶆柊缁戝畾鏁版嵁婧� + if (this.remoteColumns.length == 0 || !rows || rows.length == 0) return; + let remoteInfo = {}; + for (let index = 0; index < this.remoteColumns.length; index++) { + const column = this.remoteColumns[index]; + // column.bind.data.splice(0); + let key = column.bind.key; + let data = []; + rows.forEach((row) => { + if (row[column.field] || row[column.field] == "0") { + if (data.indexOf(row[column.field]) == -1) { + data.push(row[column.field]); + } + } + }); + if (data.length > 0) { + remoteInfo[key] = data; + } + } + if (remoteInfo.length == 0) return; + // ha= Object.assign([], ha, hb) + this.http + .post("/api/Sys_Dictionary/GetTableDictionary", remoteInfo) + .then((dic) => { + dic.forEach((x) => { + this.remoteColumns.forEach((column) => { + if (column.bind.key == x.key) { + column.bind.data = Object.assign([], column.bind.data, x.data); + // column.bind.data.push(...x.data); + } + }); + }); + this.$emit("dicInited", dic); + }); + }, + load(query, isResetPage) { + // isResetPage閲嶇疆鍒嗛〉鏁版嵁 + if (!this.url) return; + if (isResetPage) { + this.resetPage(); + } + let param = { + page: this.paginations.page, + rows: this.paginations.rows, + sort: this.paginations.sort, + order: this.paginations.order, + wheres: [], // 鏌ヨ鏉′欢锛屾牸寮忎负[{ name: "瀛楁", value: "xx" }] + }; + let status = true; + // 鍚堝苟鏌ヨ淇℃伅(鍖呮煡璇㈠垎椤点�佹帓搴忋�佹煡璇㈡潯浠剁瓑) + if (query) { + param = Object.assign(param, query); + } + /* 鏌ヨ鍓嶅鐞�(濡傛灉闇�瑕佹煡璇㈡潯浠讹紝瀹炵幇缁勪欢鏂规硶loadBefore鏂规硶鍗冲彲: + loadBefore=(param, callBack)=>{ + param.wheres = [{ name: "PhoneNo", value: "13419098211" }]; + callBack(true); + }) + */ + this.$emit("loadBefore", param, (result) => { + status = result; + }); + if (!status) return; + + if (param.wheres && param.wheres instanceof Array) { + param.wheres = JSON.stringify(param.wheres); + } + this.loading = true; + this.http.post(this.url, param).then( + (data) => { + //2021.06.04淇tree涓嶅埛鏂扮殑闂 + if (this.rowKey) { + this.randomTableKey++; + this.rowData.splice(0); + } + this.loading = false; + // 鏌ヨ杩斿洖缁撴灉鍚庡鐞� + // 2020.10.30澧炲姞鏌ヨ鍚庤繑鍥炴墍鏈夌殑鏌ヨ淇℃伅 + this.$emit( + "loadAfter", + data.rows || [], + (result) => { + status = result; + }, + data + ); + if (!status) return; + this.GetTableDictionary(data.rows); + this.rowData = data.rows || []; + this.paginations.total = data.total; + // 鍚堣 + this.getSummaries(data); + // this.$nextTick(() => { + // this.$refs.table.doLayout(); + // }); + }, + (error) => { + this.loading = false; + // this.$Message.error(error || "缃戠粶寮傚父"); + } + ); + }, // 鑾峰彇缁熻 + getSummaries(data) { + if (!this.summary || !data.summary) return; + this.summaryData.splice(0); + // 寮�鍚簡琛屽彿鐨勶紝+1 + if (this.columnIndex) { + this.summaryData.push(""); + } + // 濡傛灉鏈塩heckbox锛屽簲璇ョ畻浣滄槸绗竴琛� + if (this.ck) { + this.summaryData.push(""); + } + + this.columns.forEach((col) => { + if (col.children && col.children.length) { + col.children.forEach((item) => { + this.getColumnSummaries(item, data); + }); + } else { + this.getColumnSummaries(col, data); + } + }); + if (this.summaryData.length > 0 && this.summaryData[0] == "") { + this.summaryData[0] = "鍚堣"; + } + }, + getColumnSummaries(col, data) { + if (!col.hidden) { + if (data.summary.hasOwnProperty(col.field)) { + let sum = data.summary[col.field]; + if (sum) { + sum = + (sum * 1.0).toFixed(col.numberLength || 2).replace(".00", "") * + 1.0; + } + this.summaryData.push(sum); + } else { + this.summaryData.push(""); + } + } + }, + getInputChangeSummaries() {}, + handleSizeChange(val) { + this.paginations.size = val; + this.paginations.rows = val; + this.load(); + }, + handleCurrentChange(val) { + this.paginations.page = val; + this.load(); + }, + sortChange(sort) { + this.paginations.sort = sort.prop; + this.paginations.order = sort.order == "ascending" ? "asc" : "desc"; + this.load(); + }, + resetPage() { + // 閲嶇疆鏌ヨ鍒嗛〉 + // this.paginations.rows = 30; + this.paginations.page = 1; + }, + selectionChange(selection) { + // console.log(selection); + // 閫夋嫨琛屼簨浠�,鍙湁鍗曢�夋墠瑙﹀彂 + this.selectRows = selection; + if (this.single) { + if (selection.length == 1) { + this.$emit("rowChange", selection[0]); + } + if (selection.length > 1) { + let _row = selection[selection.length - 1]; + this.$refs.table.toggleRowSelection(selection[0]); + this.selectRows = [_row]; + } + } + // 灏唖electionchange鏆撮湶鍑哄幓 + this.$emit("selectionChange", selection); + }, + getColor(row, column) { + let val = row[column.field]; + if (column.getColor && typeof column.getColor === "function") { + let _color = column.getColor(row, column); + if (_color) { + return _color; + } + } + if (!val && val != "0") { + return ""; + } + if (!this.formatConfig[column.field]) { + this.formatConfig[column.field] = [val]; + return this.colors[0]; + } + let index = this.formatConfig[column.field].indexOf(val); + if (index != -1) { + return this.colors[index]; + } + if (this.formatConfig[column.field].length > 5) { + return ""; + } + + if (index == -1) { + this.formatConfig[column.field].push(val); + index = this.formatConfig[column.field].length - 1; + } + return this.colors[index]; + }, + formatterDate(row, column) { + return (row[column.field] || "").substr(0, 10); + }, + formatter(row, column, template) { + if (!template) return row[column.property]; + let val = row[column.field]; + if (!val && val != 0) return val; + // 鏄惁鍊� + if (column.edit && column.edit.type == "switch") { + return val ? "鏄�" : "鍚�"; + } + if (!column.bind || !column.bind.data) { + return row[column.field]; + } + + if ( + column.edit && + (column.edit.type == "selectList" || column.edit.type == "treeSelect") + ) { + if (!Array.isArray(val)) { + row[column.field] = val.split(","); + } else { + val = val.join(","); + } + return this.getSelectFormatter(column, val); + } + // 缂栬緫澶氶�塼able鏄剧ず + if ( + column.bind.type == "selectList" || + column.bind.type == "checkbox" || + column.bind.type == "treeSelect" + ) { + // if (typeof val === 'string' && val.indexOf(',') != -1) { + return this.getSelectFormatter(column, val + ""); + // } + } + let source = column.bind.data.filter((x) => { + // return x.key != "" && x.key == val; + // 2020.06.06淇鍗曠嫭浣跨敤table缁勪欢鏃�,key涓烘暟瀛�0鏃惰浆鎹㈡垚鏂囨湰澶辫触鐨勯棶棰� + return x.key !== "" && x.key !== undefined && x.key + "" === val + ""; + }); + if (source && source.length > 0) val = source[0].label || source[0].value; + return val; + }, + getSelectFormatter(column, val) { + // 缂栬緫澶氶�塼able鏄剧ず + let valArr = val.split(","); + for (let index = 0; index < valArr.length; index++) { + (column.bind.orginData && column.bind.orginData.length + ? column.bind.orginData + : column.bind.data + ).forEach((x) => { + // 2020.06.06淇鏁版嵁婧愪负selectList鏃�,key涓烘暟瀛�0鏃朵笉鑳借浆鎹㈡枃鏈殑闂 + if ( + x.key !== "" && + x.key !== undefined && + x.key + "" == valArr[index] + "" + ) { + valArr[index] = x.label || x.value; + } + }); + } + return valArr.join(","); + }, + onChange(scope, val, event, column) { + // 2020.09.03淇onChange涓嶈Е鍙戠殑闂 + let row = scope.row; + if (column.onChange && !column.onChange(row, val, event)) { + return; + } + // 杈撳叆妗嗘眰鍜屽疄鏃惰绠� + this.getInputSummaries(scope, val, event, column); + }, + // input杈撳叆瀹炴椂姹傚拰 + getInputSummaries(scope, val, event, column) { + // column鍒楄缃簡summary灞炴�х殑鎵嶈绠楀�� + if (!column.summary) return; + let sum = 0; + // let _index = 0; + (this.url ? this.rowData : this.tableData).forEach((x, index) => { + if (x.hasOwnProperty(column.field) && !isNaN(x[column.field])) { + // _index = index; + sum += x[column.field] * 1; + } + }); + if (sum) { + if (column.summary == "avg") { + sum = sum / (this.rowData.length || this.tableData.length || 1); + } + sum = + (sum * 1.0).toFixed(column.numberLength || 2).replace(".00", "") * + 1.0; + } + this.summaryData[this.summaryIndex[column.field]] = sum; + }, + getSummaryData({ columns, data }) { + return this.summaryData; + }, + getCellStyle(row) { + // 2020.12.13澧炲姞璁剧疆鍗曞厓鏍奸鑹� + if (row.column.property) { + return ( + this.cellStyleColumns[row.column.property] && + this.cellStyleColumns[row.column.property]( + row.row, + row.rowIndex, + row.columnIndex + ) + ); + } + }, + compareDate(date1, date2) { + if (!date2) { + return true; + } + return ( + date1.valueOf() < + (typeof date2 == "number" ? date2 : new Date(date2).valueOf()) + ); + }, + getDateOptions(date, item) { + //2021.07.17璁剧疆鏃堕棿鍙�夎寖鍥� + if ((!item.min && !item.max) || !date) { + return false; + } + if (item.min && item.min.indexOf(" ") == -1) { + //涓嶈缃椂鍒嗙锛屽悗闈細鑷姩鍔犱笂 08:00 + item.min = item.min + " 00:00:000"; + } + return ( + this.compareDate(date, item.min) || !this.compareDate(date, item.max) + ); + }, + getDateFormat(column) { + //瑙乭ttps://day.js.org/docs/zh-CN/display/format + return column.edit.type == "date" ? "YYYY-MM-DD" : "YYYY-MM-DD HH:mm:ss"; + }, + userSelect(selection, row) { + this.selectRows = selection; + if (!this.single) { + this.$emit("rowChange", { row, selection }); + } + }, + isEmptyTag(row, column) { + if (!row[column.field] && row[column.field] != "0") { + return "empty-tag"; + } + return ""; + }, + filterChildrenColumn(children) { + if (!children) { + return []; + } + return children.filter((x) => { + return !x.hidden; + }); + }, + initColumnDisabled(row, column) { + return column.getDisabled && column.getDisabled(row, column); + }, + showUpload(row, column) { + this.fileInfo = (row[column.field] || "") + .split(",") + .filter((x) => { + return x; + }) + .map((item) => { + return { path: item, name: "" }; + }); + this.currentRow = row; + this.currentColumn = column; + if (this.currentColumn.edit.autoUpload === undefined) { + this.currentColumn.edit.autoUpload = true; + } + if (this.currentColumn.edit.multiple === undefined) { + this.currentColumn.edit.multiple = false; + } + + if (this.currentColumn.edit.url === undefined) { + this.uploadUrl = + "api/" + + (this.url || "").replace("/api", "api").split("/")[1] + + "/upload"; + } else { + this.uploadUrl = this.currentColumn.edit.url; + } + this.uploadModel = true; + }, + uploadAfter(result, files) { + this.currentColumn.uploadAfter && + this.currentColumn.uploadAfter(result, files); + return true; + }, + saveUpload() { + //鐢熸垚淇濆瓨鍚庤繑鍥炵殑璺緞 + let arr = this.fileInfo.map((x) => { + if (x.path) { + return x.path; + } + return result.data + x.name; + }); + + this.currentRow[this.currentColumn.field] = arr.join(","); + this.uploadModel = false; + return true; + }, + }, +}); +</script> +<style lang="less" scoped> +.vol-table { + position: relative; + .mask { + opacity: 0.2; + position: absolute; + width: 100%; + height: 100%; + background: #d0d0d0; + z-index: 100; + } + .message { + text-align: center; + color: #635c5c; + font-size: 15px; + font-weight: 600; + background: #eee; + transform: translateY(-50%); + top: 50%; + position: absolute; + z-index: 200; + left: 0; + right: 0; + width: 150px; + margin: 0 auto; + line-height: 40px; + border-radius: 4px; + border: 1px solid #a09e9e; + } +} +.e-item { + display: flex; + > div:first-child { + flex: 1; + } +} +.vol-table ::v-deep(.el-pager .number) { + padding: 0 7px; + border-radius: 5px; + border: 1px solid #e6e6e6; + margin-left: 8px; + font-weight: 500; + min-width: 28px; +} +.vol-table ::v-deep(.el-pager .number.active) { + background: #ed4014; + color: #fff; +} +.vol-table .t-file { + color: #1e8cff; + cursor: pointer; + border-bottom: 1px solid; + padding-bottom: 2px; +} +.vol-table .empty-tag { + border: none; + background: none; +} +.v-table ::v-deep(.el-date-editor .el-icon-date), +.v-table ::v-deep(.el-date-editor .el-icon-time) { + width: 10px; +} + +.column-required { + position: relative; + color: #f20303; + font-size: 14px; + top: 2px; + right: 2px; +} +</style> + +<style scoped> +/* .v-table ::v-deep(.even-row){ + background: rgb(245,247,250); +} */ +.pagination { + text-align: right; + padding: 2px 28px; + border: 1px solid #eee; + border-top: 0px; +} +/* .v-table ::v-deep(.el-input .el-input__inner) { + padding: 0 7px; +} */ +.v-table ::v-deep(.el-table__header th) { + /* padding: 0px !important; */ + background-color: #f8f8f9 !important; + font-size: 13px; + height: 46px; + color: #616161; +} + +.v-table ::v-deep(.el-table__header th.is-sortable) { + padding: 3px !important; +} +.vol-table.text-inline ::v-deep(.el-table__body .cell), +.vol-table.text-inline ::v-deep(.el-table__header-wrapper .cell) { + word-break: inherit !important; + white-space: nowrap !important; +} +/* .v-table ::v-deep(.el-table__body td) { + padding: 9px 0 !important; +} */ + +.v-table ::v-deep(.el-table__footer td) { + padding: 7px 0 !important; +} + +.vol-table ::v-deep(.el-table-column--selection .cell) { + display: inline; +} +.vol-table.text-inline ::v-deep(.el-table th > .cell) { + white-space: nowrap !important; +} + +.vol-table .table-img { + height: 40px; + border-radius: 5px; + margin-right: 10px; + width: 40px; + object-fit: cover; +} +.vol-table .table-img:hover { + cursor: pointer; +} + +.vol-table ::v-deep(.cell) { + padding: 2px 10px; +} +.vol-table ::v-deep(.cell .el-tag) { + padding: 5px 9px; +} +.table-input { + color: rgb(104, 103, 103); + padding: 3px 10px; + height: 32px; + line-height: 32px; + width: 100%; + border-radius: 4px; + border: 1px solid #dcdcdc; +} +.table-input:focus { + outline: 1px solid #49a3fd; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolTable/VolTableRender.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolTable/VolTableRender.js" new file mode 100644 index 0000000..988a672 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolTable/VolTableRender.js" @@ -0,0 +1,14 @@ +import { h } from 'vue'; +export default { + name: "TableExpand", + functional: true, + props: { + render: Function, + row: {},//褰撳墠琛岀殑鏁版嵁 + column: {},//褰撳墠琛岀殑閰嶇疆淇℃伅 + index: { type: Number, default: 0 }//褰撳墠鎵�鍦ㄨ + }, + render: ({ render,row ,column,index }) => { + return render(h, {row ,column,index}); //h(); + } +}; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolUpload.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolUpload.vue" new file mode 100644 index 0000000..4c7d696 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/basic/VolUpload.vue" @@ -0,0 +1,880 @@ +<template> + <div class="upload-container"> + <div> + <div class="input-btns" style="margin-bottom: 10px"> + <input + ref="input" + type="file" + style="display: none" + @change="handleChange" + :multiple="multiple" + /> + <div v-if="img" class="upload-img"> + <!-- v-for="(file,index) in fileInfo.length>0?fileInfo: files" --> + <div v-for="(file, index) in files" :key="index" class="img-item"> + <div class="operation"> + <div class="action"> + <i class="el-icon-view view" @click="previewImg(index)"></i> + <i class="el-icon-delete remove" @click="removeFile(index)"></i> + </div> + <div class="mask"></div> + </div> + + <img :src="getImgSrc(file, index)" :onerror="errorImg" /> + </div> + <div + v-show="!autoUpload || (autoUpload && files.length < maxFile)" + class="img-selector" + :class="getSelector()" + > + <div class="selector" @click="handleClick"> + <i class="el-icon-camera-solid"></i> + </div> + <div + v-if="!autoUpload" + class="s-btn" + :class="{ readonly: changed }" + @click="upload" + > + <div>{{ loadText }}</div> + </div> + </div> + </div> + <el-button v-else @click="handleClick" + >閫夋嫨{{ img ? '鍥剧墖' : '鏂囦欢' }}</el-button + > + + <el-button + v-if="!autoUpload && !img" + type="info" + :disabled="changed" + @click="upload(true)" + :loading="loadingStatus" + >涓婁紶鏂囦欢</el-button + > + </div> + <slot></slot> + <div v-if="desc"> + <el-alert + :title="getText() + '鏂囦欢澶у皬涓嶈秴杩�' + (maxSize || 50) + 'M'" + type="info" + show-icon + > + </el-alert> + </div> + <slot name="content"></slot> + <div v-if="!img"> + <ul class="upload-list" v-show="fileList"> + <li class="list-file" v-for="(file, index) in files" :key="index"> + <a> + <span @click="fileOnClick(index, file)"> + <i :class="format(file)"></i> + {{ file.name }} + </span> + </a> + <span @click="removeFile(index)" class="file-remove"> + <i class="el-icon-close"></i> + </span> + </li> + </ul> + </div> + <slot name="tip"></slot> + </div> + </div> +</template> +<script> +let OSS = require('ali-oss'); +export default { + components: {}, + props: { + desc: { + //鏄惁鏄剧ず榛樿浠嬬粛 + //鏄惁澶氶�� + type: Boolean, + default: false + }, + fileInfo: { + //鐢ㄤ簬鎺ユ敹涓婁紶鐨勬枃浠讹紝涔熷彲浠ュ姞浠ラ粯璁ゅ�硷紝鏄剧ず宸蹭笂浼犵殑鏂囦欢锛岀敤鎴蜂笂浼犲悗浼氳鐩栭粯璁ゅ�� + type: Array, + default: () => { + return []; + } //鏍煎紡[{name:'1.jpg',path:'127.0.01/1.jpg'}] + }, + downLoad: { + //鏄惁鍙互鐐瑰嚮鏂囦欢涓嬭浇 + type: Boolean, + default: true + }, + multiple: { + //鏄惁澶氶�� + type: Boolean, + default: false + }, + maxFile: { + //鏈�澶氬彲閫夋枃浠舵暟閲忥紝蹇呴』multiple=true锛屾墠浼氱敓鏁� + type: Number, + default: 5 + }, + maxSize: { + //鏂囦欢闄愬埗澶у皬3M + type: Number, + default: 50 + }, + + autoUpload: { + //閫夋嫨鏂囦欢鍚庢槸鍚﹁嚜鍔ㄤ笂浼� + type: Boolean, + default: true + }, + img: { + //鍥剧墖绫诲瀷 img>excel>fileTypes涓夌鏂囦欢绫诲瀷浼樺厛绾� + type: Boolean, + default: false + }, + excel: { + //excel鏂囦欢 + type: Boolean, + default: false + }, + fileTypes: { + //鎸囧畾涓婁紶鏂囦欢鐨勭被鍨� + type: Array, + default: () => { + return []; + } + }, + url: { + //涓婁紶鐨剈rl + type: String, + default: '' + }, + uploadBefore: { + //杩斿洖false浼氫腑姝㈡墽琛� + //涓婁紶鍓� + type: Function, + default: (files) => { + return true; + } + }, + uploadAfter: { + //杩斿洖false浼氫腑姝㈡墽琛� + //涓婁紶鍚� + type: Function, + default: (result, files) => { + return true; + } + }, + onChange: { + //閫夋嫨鏂囦欢鏃� //杩斿洖false浼氫腑姝㈡墽琛� + type: Function, + default: (files) => { + return true; + } + }, + // clear: { + // //涓婁紶瀹屾垚鍚庢槸鍚︽竻绌烘枃浠跺垪琛� + // type: Boolean, + // default: true + // }, + fileList: { + //鏄惁鏄剧ず閫夋嫨鐨勬枃浠跺垪琛� + type: Boolean, + default: true + }, + fileClick: { + //鐐瑰嚮鏂囦欢浜嬩欢 + type: Function, + default: (index, file, files) => { + return true; + } + }, + removeBefore: { + //绉婚櫎鏂囦欢浜嬩欢 + type: Function, + default: (index, file, files) => { + return true; + } + }, + append: { + //姝ゅ睘鎬у凡搴熷純锛屽鏂囦欢涓婁紶锛岄粯璁よ拷鍔犳枃浠� + type: Boolean, + default: false + }, + compress: { + //寮�鍚浘鐗囧帇缂�,鍚庨潰鏍规嵁闇�瑕佸啀瀹屽杽 + type: Boolean, + default: true + }, + compressMinSize: { + //鍘嬬缉鐨勬渶灏忔瘮渚� + type: Number, + default: 0.1 + } + }, + data() { + return { + errorImg: 'this.src="' + require('@/assets/imgs/error-img.png') + '"', + changed: false, //鎵嬪姩涓婁紶鎴愬姛鍚庣姝㈤噸澶嶄笂浼狅紝蹇呴』閲嶆柊閫夋嫨 + model: true, + files: [], + bigImg: '', + imgTypes: ['gif', 'jpg', 'jpeg', 'png', 'bmp', 'webp', 'jfif'], + loadingStatus: false, + loadText: '涓婁紶鏂囦欢' + }; + }, + created() { + //榛樿鏈夊浘鐗囩殑绂佹涓婁紶鎿嶄綔 + if (this.fileInfo) { + this.changed = true; + } + this.cloneFile(this.fileInfo); + }, + watch: { + fileInfo: { + handler(files) { + this.cloneFile(files); + }, + deep: true + } + }, + methods: { + cloneFile(files) { + this.files = files.map((x) => { + return { + name: x.name || this.getFileName(x.path), + path: x.path + }; + }); + }, + getFileName(path) { + if (!path) { + return '鏈畾涔夋枃浠跺悕'; + } + let _index = path.lastIndexOf('/'); + return path.substring(_index + 1); + }, + previewImg(index) { + //鏌ョ湅澶у浘棰勮妯″紡寰呭畬 + this.base.previewImg(this.getImgSrc(this.files[index])); + // window.open(this.getImgSrc((this.files.length>0?this.files:this.fileInfo)[index])); + }, + getSelector() { + if (this.autoUpload) { + return 'auto-selector'; + } + return 'submit-selector'; + }, + getImgSrc(file, index) { + if (file.hasOwnProperty('path')) { + if (this.base.isUrl(file.path)) { + return file.path; + } + //2020.12.27澧炲姞base64鍥剧墖鎿嶄綔 + if (file.path.indexOf('/9j/') != -1) { + return 'data:image/jpeg;base64,' + file.path; + } + if (file.path.substr(0, 1) == '/') { + file.path = file.path.substr(1); + } + return this.http.ipAddress + file.path; + } + return window.URL.createObjectURL(file); + }, + fileOnClick(index, file) { + if (!this.fileClick(index, file, this.files)) { + return; + } + //鐐瑰嚮涓嶄笅杞� + if (!this.downLoad) { + return; + } + if (!file.path) { + this.$message.error('璇峰厛涓婁紶鏂囦欢'); + return; + } + this.base.dowloadFile( + file.path, + file.name, + { + Authorization: this.$store.getters.getToken() + }, + this.http.ipAddress + ); + }, + getText() { + if (this.img) { + return '鍙兘涓婁紶鍥剧墖,'; + } else if (this.excel) { + return '鍙兘涓婁紶excel鏂囦欢,'; + } + }, + handleClick() { + this.$refs.input.click(); + }, + handleChange(e) { + //this.compress寮�鍚浘鐗囧帇缂�,鍚庨潰鏍规嵁闇�瑕佸啀瀹屽杽 + // this.clearFiles(); + var result = this.checkFile(e.target.files); + if (!result) { + return; + } + + this.changed = false; + //濡傛灉浼犲叆浜咶ileInfo闇�瑕佽嚜琛屽鐞嗙Щ闄ileInfo + if (!this.onChange(e.target.files)) { + return; + } + for (let index = 0; index < e.target.files.length; index++) { + const element = e.target.files[index]; + element.input = true; + } + if (!this.multiple) { + this.files.splice(0); + } + this.files.push(...e.target.files); + + this.$refs.input.value = null; + if (this.autoUpload && result) { + this.upload(false); + } + }, + removeFile(index) { + //濡傛灉浼犲叆浜咶ileInfo闇�瑕佽嚜琛屽鐞嗙Щ闄ileInfo + //t绉婚櫎鏂囦欢 + let removeFile = this.files[index]; + //鍒犻櫎鐨勮繕娌′笂浼犵殑鏂囦欢 + if (removeFile.input) { + this.files.splice(index, 1); + } else { + this.fileInfo.splice(index, 1); + } + if (!this.removeBefore(index, removeFile, this.fileInfo)) { + return; + } + }, + clearFiles() { + this.files.splice(0); + }, + getFiles() { + return this.files; + }, + convertToFile(dataurl, filename) { + let arr = dataurl.split(','); + let mime = arr[0].match(/:(.*?);/)[1]; + let suffix = mime.split('/')[1]; + let bstr = atob(arr[1]); + let n = bstr.length; + let u8arr = new Uint8Array(n); + while (n--) { + u8arr[n] = bstr.charCodeAt(n); + } + // new File杩斿洖File瀵硅薄 绗竴涓弬鏁版槸 ArraryBuffer 鎴� Bolb 鎴朅rrary 绗簩涓弬鏁版槸鏂囦欢鍚� + // 绗笁涓弬鏁版槸 瑕佹斁鍒版枃浠朵腑鐨勫唴瀹圭殑 MIME 绫诲瀷 + return new File([u8arr], `${filename}.${suffix}`, { + type: mime, + input: true + }); + }, + async compressImg(file) { + let fileSize = file.size / 1024 / 1024; + let read = new FileReader(); + read.readAsDataURL(file); + return new Promise((resolve, reject) => { + read.onload = (e) => { + let img = new Image(); + img.src = e.target.result; + let _this = this; + img.onload = function() { + //榛樿鎸夋瘮渚嬪帇缂� + let w = this.width; + let h = this.height; + let canvas = document.createElement('canvas'); + let ctx = canvas.getContext('2d'); + canvas.setAttribute('width', w); + canvas.setAttribute('height', h); + ctx.drawImage(this, 0, 0, w, h); + let rate = 0.3; + if (fileSize > 2) { + rate = 0.1; + } else if (fileSize > 1) { + rate = 0.1; + } + if (_this.compressMinSize > rate) { + rate = _this.compressMinSize; + } + // rate=1; + let base64 = canvas.toDataURL('image/jpeg', rate); + resolve(_this.convertToFile(base64, file.name)); + }; + }; + }); + }, + async uploadOSS() { + this.http.get('api/alioss/getAccessToken', {}, false).then(async (x) => { + if (!x.status) return this.$Message.error(x.message); + let client = new OSS({ + // yourRegion濉啓Bucket鎵�鍦ㄥ湴鍩熴�備互鍗庝笢1锛堟澀宸烇級涓轰緥锛孯egion濉啓涓簅ss-cn-hangzhou銆� + region: x.data.region, + // 浠嶴TS鏈嶅姟鑾峰彇鐨勪复鏃惰闂瘑閽ワ紙AccessKey ID鍜孉ccessKey Secret锛夈�� + accessKeyId: x.data.accessKeyId, + accessKeySecret: x.data.accessKeySecret, + // 浠嶴TS鏈嶅姟鑾峰彇鐨勫畨鍏ㄤ护鐗岋紙SecurityToken锛夈�� + stsToken: x.data.securityToken, + // 濉啓Bucket鍚嶇О銆� + bucket: x.data.bucket + }); + console.log(this.files); + for (let index = 0; index < this.files.length; index++) { + const file = this.files[index]; + if (file.input) { + let result = await client.put( + x.data.bucketFolder + '/' + x.data.unique + file.name, + file + ); + file.path = result.url; + file.newName = x.data.unique + file.name; + } + } + + this.fileInfo.splice(0); + // } + let _files = this.files.map((file) => { + return { + name: file.newName || file.name, + path: file.path + }; + }); + this.fileInfo.push(..._files); + //2021.09.25淇鏂囦欢涓婁紶鍚庝笉鑳藉悓鏃朵笅杞界殑闂 + this.files = _files; + }); + return; + }, + async upload(vail) { + if (vail && !this.checkFile()) return false; + if (!this.url) { + return this.$message.error('娌℃湁閰嶇疆濂経rl'); + } + if (!this.files || this.files.length == 0) { + return this.$message.error('璇烽�夋嫨鏂囦欢'); + } + //澧炲姞涓婁紶鏃惰嚜瀹氫箟鍙傛暟锛屽悗鍙颁娇鐢ㄨ幏鍙朥tilities.HttpContext.Current.Request.Query["瀛楁"] + let params={}; + if (!this.uploadBefore(this.files,params)) { + return; + } + let paramText=""; + if (Object.keys(params).length) { + paramText="?1=1"; + for (const key in params) { + let value=params[key]; + if(typeof(value)=='object'){ + value=JSON.stringify(value) + } + paramText+=`&${key}=${value}` + } + } + + this.loadingStatus = true; + this.loadText = '涓婁紶涓�..'; + if (window.oss && window.oss.ali.use) { + await this.uploadOSS(); + this.loadingStatus = false; + this.loadText = '涓婁紶鏂囦欢'; + if (!this.uploadAfter({status:true}, this.files)) { + this.changed = false; + return; + } else { + this.changed = true; + } + this.$message.success('涓婁紶鎴愬姛'); + return; + } + + var forms = new FormData(); + for (let index = 0; index < this.files.length; index++) { + let file = this.files[index]; + if (file.input) { + let name = file.name.split('.'); + name = name[name.length - 1].toLocaleLowerCase(); + let isImg = this.imgTypes.indexOf(name) != -1; + if (isImg && (name == 'jpg' || name == 'jpeg')) { + //>200KB鐨勫紑鍚帇缂� + if (isImg && file.size / 1024 / 1024 > 0.2) { + console.log('鍘嬬缉鍓�' + file.size); + file = await this.compressImg(file); + file.compress = true; + this.files[index] = file; + this.files[index].input = true; + console.log('鍘嬬缉鍚�' + file.size); + } + } + forms.append('fileInput', file, file.name); + } + } + // forms.append("fileInput", this.files); + + this.http + .post(this.url+paramText, forms, this.autoUpload ? '姝e湪涓婁紶鏂囦欢' : '') + .then( + (x) => { + // this.$refs.uploadFile.clearFiles(); + this.loadingStatus = false; + this.loadText = '涓婁紶鏂囦欢'; + if (!this.uploadAfter(x, this.files)) { + this.changed = false; + return; + } else { + this.changed = true; + } + this.$message.success(x.message); + this.changed = x.status; + if (!x.status) { + // this.files = null; + return; + } + //鍗曢�夋竻闄や互鍓嶇殑鏁版嵁 + // if (!this.multiple) { + this.fileInfo.splice(0); + // } + let _files = this.files.map((file) => { + return { + name: file.name, + path: file.path || x.data + file.name + }; + }); + this.fileInfo.push(..._files); + //2021.09.25淇鏂囦欢涓婁紶鍚庝笉鑳藉悓鏃朵笅杞界殑闂 + this.files = _files; + }, + (error) => { + this.loadText = '涓婁紶鏂囦欢'; + this.loadingStatus = false; + } + ); + }, + format(file, checkFileType) { + const format = + file.name + .split('.') + .pop() + .toLocaleLowerCase() || ''; + let fileIcon = 'el-icon-document'; + if (this.fileTypes.length > 0 && checkFileType != undefined) { + if (this.fileTypes.indexOf(format) != -1) { + return true; + } + return false; + } + if ( + checkFileType && + !(checkFileType instanceof Array) && + checkFileType != 'img' && + checkFileType != 'excel' + ) { + if (checkFileType.indexOf(format) > -1) { + return true; + } else { + return false; + } + } + + if (checkFileType == 'img' || this.imgTypes.indexOf(format) > -1) { + if (checkFileType == 'img') { + if (this.imgTypes.indexOf(format) > -1) { + return true; + } else { + return false; + } + } + fileIcon = 'el-icon-picture-outline'; + } + if ( + ['mp4', 'm3u8', 'rmvb', 'avi', 'swf', '3gp', 'mkv', 'flv'].indexOf( + format + ) > -1 + ) { + fileIcon = 'el-icon-document'; + } + if (['mp3', 'wav', 'wma', 'ogg', 'aac', 'flac'].indexOf(format) > -1) { + fileIcon = 'el-icon-document'; + } + if (['doc', 'txt', 'docx', 'pages', 'epub', 'pdf'].indexOf(format) > -1) { + fileIcon = 'el-icon-document'; + } + if ( + checkFileType == 'excel' || + ['numbers', 'csv', 'xls', 'xlsx'].indexOf(format) > -1 + ) { + if (checkFileType == 'excel') { + if (['numbers', 'csv', 'xls', 'xlsx'].indexOf(format) > -1) { + return true; + } else { + return false; + } + } + fileIcon = 'el-icon-document'; + } + return fileIcon; + }, + beforeUpload() {}, + checkFile(inputFiles) { + const files = this.files; + + if ( + this.multiple && + files.length + (inputFiles || []).length > (this.maxFile || 5) + ) { + this.$message.error( + '鏈�澶氬彧鑳介�夈��' + + (this.maxFile || 5) + + '銆�' + + (this.img ? '寮犲浘鐗�' : '涓枃浠�') + + '' + ); + return false; + } + if (!inputFiles) { + inputFiles = this.files.filter((x) => { + return x.input; + }); + } + let names = []; + for (let index = 0; index < inputFiles.length; index++) { + const file = inputFiles[index]; + if (names.indexOf(file.name) != -1) { + file.name = '(' + index + ')' + file.name; + } + names.push(file.name); + if (this.img && !this.format(file, 'img')) { + this.$message.error('閫夋嫨鐨勬枃浠躲��' + file.name + '銆戝彧鑳芥槸鍥剧墖鏍煎紡'); + return false; + } + if (this.excel && !this.format(file, 'excel')) { + this.$message.error('閫夋嫨鐨勬枃浠躲��' + file.name + '銆戝彧鑳芥槸excel鏂囦欢'); + return false; + } + if ( + this.fileTypes && + this.fileTypes.length > 0 && + !this.format(file, this.fileTypes) + ) { + this.$message.error( + '閫夋嫨鐨勬枃浠躲��' + + file.name + + '銆戝彧鑳芥槸銆�' + + this.fileTypes.join(',') + + '銆戞牸寮�' + ); + return false; + } + if (file.size > (this.maxSize || 50) * 1024 * 1024) { + this.$message.error( + '閫夋嫨鐨勬枃浠躲��' + + file.name + + '銆戜笉鑳借秴杩�:' + + (this.maxSize || 50) + + 'M' + ); + return false; + } + } + return true; + } + } +}; +</script> +<style lang="less" scoped> +.upload-list { + padding-left: 0; + list-style: none; + .list-file { + line-height: 20px; + padding: 4px; + color: #515a6e; + border-radius: 4px; + transition: background-color 0.2s ease-in-out; + overflow: hidden; + position: relative; + + font-size: 13px; + .file-remove { + display: none; + right: 0; + // margin-left: 50px; + color: #0e9286; + } + } + .list-file:hover { + cursor: pointer; + .file-remove { + display: initial; + } + color: #2d8cf0; + } +} +.upload-container { + display: inline-block; + width: 100%; + // padding: 10px; + + // min-height: 250px; + border-radius: 5px; + .alert { + margin-top: 43px; + } + .button-group > * { + float: left; + margin-right: 10px; + } + .file-info > span { + margin-right: 20px; + } +} +.upload-img { + display: inline-block; + .img-item:hover .operation { + display: block; + } + .img-item, + .img-selector { + position: relative; + cursor: pointer; + margin: 0 10px 10px 0; + float: left; + width: 65px; + height: 65px; + border: 1px solid #c7c7c7; + overflow: hidden; + border-radius: 5px; + box-sizing: content-box; + img { + margin: 0; + padding: 0; + width: 100%; + height: 100%; + object-fit: cover; + } + + .operation { + display: none; + position: absolute; + top: 0; + bottom: 0; + left: 0; + right: 0; + .action { + opacity: 0.6; + text-align: center; + background: #151515de; + font-size: 14px; + position: absolute; + z-index: 90; + width: 100%; + bottom: 3px; + bottom: 0; + color: #ded5d5; + padding-right: 7px; + padding-bottom: 3px; + line-height: 20px; + .el-icon-view { + margin: 0 10px; + } + } + .mask { + opacity: 0.6; + background: #9e9e9e; + top: 0; + width: 100%; + height: 100%; + position: absolute; + } + } + } + .img-selector { + font-size: 50px; + text-align: center; + i { + position: relative; + font-size: 40px; + color: #6f6f6f; + } + } + + .auto-selector { + .selector { + line-height: 64px; + } + } + .selector { + color: #a0a0a0; + } + .submit-selector { + .s-btn { + line-height: 22px; + font-size: 12px; + top: -6px; + // padding: 2px; + position: relative; + background: #2db7f5; + color: white; + } + .selector { + line-height: 50px; + } + .readonly { + background: #8c8c8c; + } + } +} +.big-model { + width: 100%; + height: 100%; + position: relative; + .m-img { + } + .mask { + position: absolute; + opacity: 0.6; + background: #eee; + top: 0; + width: 100%; + height: 100%; + position: absolute; + } +} + +.auto-upload { + z-index: 9999999; + width: 100%; + height: 100%; + position: fixed; + top: 0; + left: 0; + .j-content { + text-align: center; + font-size: 17px; + top: 40%; + position: absolute; + z-index: 999; + left: 0; + right: 0; + width: 240px; + /* height: 100%; */ + margin: auto; + background: white; + /* bottom: 30px; */ + line-height: 50px; + border-radius: 6px; + border: 1px solid #d2d2d2; + } + .mask { + cursor: pointer; + opacity: 0.6; + width: 100%; + height: 100%; + background: #101010; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/401.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/401.vue" new file mode 100644 index 0000000..33e44fb --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/401.vue" @@ -0,0 +1,19 @@ +<template> + <div style="height: 100%"> + <redirect-error :text="text" message="璇锋眰纭鏄惁閰嶇疆鏉冮檺" :errorNumber="errorNumber"></redirect-error> + </div> +</template> + <script> +import RedirectError from "./RedirectError"; +export default { + components: { + RedirectError, + }, + data() { + return { + errorNumber: "401", + text: "鎶辨瓑锛屾偍娌℃湁鏉冮檺杩涜姝ゆ搷浣渵", + }; + }, +}; +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/404.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/404.vue" new file mode 100644 index 0000000..bd6db8f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/404.vue" @@ -0,0 +1,21 @@ +<template> + <div style="height:100%;"> + <redirect-error :text="text" :errorNumber="errorNumber"></redirect-error> + </div> +</template> + <script> +import RedirectError from "./RedirectError"; +export default { + components: { + RedirectError + }, + data() { + return { + errorNumber:'404', + text: "鎶辨瓑锛岄〉闈㈠ソ鍍忓幓鐏槦浜唦" + }; + } +}; +</script> + + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/Message.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/Message.vue" new file mode 100644 index 0000000..8952162 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/Message.vue" @@ -0,0 +1,39 @@ +<template> + <div class="middle-box"> + <div class="text-center animated fadeInDown"> + <i style="font-size: 50px;color: #67c23a;margin-top:40px;" class="el-icon-circle-check"></i> + <div style="font-size: 20px;margin-top: 10px;" class="error-desc">{{ text }}</div> + </div> + </div> +</template> + <script> +export default { + props: { + text: { + type: String, + default: "鎿嶄綔鎴愬姛锛�", + }, + }, + methods: { + }, +}; +</script> +<style lang="less" scoped> +body { + background-color: #fff; +} +.middle-box { + text-align: center; + padding-top: 80px; + height: 100%; + // background: #eee; + h1 { + font-size: 140px; + font-weight: 100; + } + .back { + padding: 10px; + } +} +</style> + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/RedirectError.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/RedirectError.vue" new file mode 100644 index 0000000..5457065 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/RedirectError.vue" @@ -0,0 +1,59 @@ +<template> + <div class="middle-box"> + <div class="text-center animated fadeInDown"> + <h1>{{ errorNumber }}</h1> + <h3 class="font-bold">{{message}}</h3> + <slot></slot> + <div class="error-desc">{{ text }}</div> + <div class="back"> + <el-button type="primary" @click="backHome" icon="md-arrow-round-back" + >杩斿洖棣栭〉</el-button > + </div> + </div> + </div> +</template> + <script> +import { Script } from "vm"; +export default { + props: { + errorNumber: { + type: String, + default: "500", + }, + message: { + type: String, + default: "椤甸潰鏈壘鍒帮紒", + }, + text: { + type: String, + default: "鍞�...濂藉儚鍑轰簡鐐归棶棰榽", + }, + }, + methods: { + backHome: function () { + this.$router.push({ + path: "/home", + }); + }, + }, +}; +</script> +<style lang="less" scoped> +body { + background-color: #fff; +} +.middle-box { + text-align: center; + padding-top: 80px; + height: 100%; + // background: #eee; + h1 { + font-size: 140px; + font-weight: 100; + } + .back { + padding: 10px; + } +} +</style> + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/coding.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/coding.vue" new file mode 100644 index 0000000..5569483 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/components/redirect/coding.vue" @@ -0,0 +1,25 @@ +<template> + <div style="height:100%;"> + <redirect-error :text="text" :errorNumber="errorNumber"> + <div> + <router-link to="SellOrder"> + <Button>鐐瑰嚮鏌ョ湅[娴嬭瘯瀹屾暣绀轰緥]</Button> + </router-link> + </div> + </redirect-error> + </div> +</template> + <script> +import RedirectError from "./RedirectError"; +export default { + components: { + RedirectError + }, + data() { + return { + errorNumber: "鐢ㄤ緥姝e湪鏁寸悊涓�", + text: "璇︾粏鐢ㄤ緥鍦ㄦ鍑嗗涓�,鐩墠鍙弬鑰僛娴嬭瘯瀹屾暣绀轰緥]鐨勪娇鐢ㄦ柟娉�" + }; + } +}; +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/CachePoint.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/CachePoint.js" new file mode 100644 index 0000000..151c927 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/CachePoint.js" @@ -0,0 +1,69 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + let enableBtn = this.buttons.find(x => x.value == 'Enable'); + if (enableBtn) { + enableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + let disableBtn = this.buttons.find(x => x.value == 'Disable'); + if (disableBtn) { + disableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/areaInfo.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/areaInfo.js" new file mode 100644 index 0000000..151c927 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/areaInfo.js" @@ -0,0 +1,69 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + let enableBtn = this.buttons.find(x => x.value == 'Enable'); + if (enableBtn) { + enableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + let disableBtn = this.buttons.find(x => x.value == 'Disable'); + if (disableBtn) { + disableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/areaRouter.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/areaRouter.js" new file mode 100644 index 0000000..151c927 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/areaRouter.js" @@ -0,0 +1,69 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + let enableBtn = this.buttons.find(x => x.value == 'Enable'); + if (enableBtn) { + enableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + let disableBtn = this.buttons.find(x => x.value == 'Disable'); + if (disableBtn) { + disableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/extend/GetLocationStatus.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/extend/GetLocationStatus.vue" new file mode 100644 index 0000000..9e14d8e --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/extend/GetLocationStatus.vue" @@ -0,0 +1,261 @@ +<template> + <div> + <vol-box v-model="showDetialBox" :lazy="true" width="1500px" :padding="15" title="鍏ュ簱鍗曟嵁鏄庣粏"> + <div class="box-table" style="margin-top: 1%"> + <el-table ref="singleTable" :data="tableData" style="width: 100%; height: 100%" highlight-current-row + @row-click="handleRowClick" height="500px" @selection-change="handleSelectionChange"> + > + <el-table-column type="selection" width="55"> </el-table-column> + <el-table-column label="搴忓彿" type="index" fixed="left" width="55" align="center"></el-table-column> + <el-table-column v-for="(item, index) in tableColumns.filter((x) => !x.hidden)" :key="index" + :prop="item.field" :label="item.title" :width="item.width" align="center"> + <template #default="scoped"> + <div v-if="item.type == 'icon'"> + <el-tooltip class="item" effect="dark" :content="item.title" + placement="bottom"><el-button type="text" + @click="tableButtonClick(scoped.row, item)"><i :class="item.icon" + style="font-size: 22px"></i></el-button></el-tooltip> + </div> + <div v-else-if="item.type == 'tag'"> + <el-tag size="small"> + {{ getDictionary(scoped.row, item) }} + </el-tag> + </div> + </template> + </el-table-column> + </el-table> + </div> + </vol-box> + </div> +</template> + +<script> +import VolBox from "@/components/basic/VolBox.vue"; +export default { + components: { VolBox }, + data() { + return { + showDetialBox: false, + row: null, + tableData: [], + tableColumns: [ + { + field: "locationId", + title: "璐т綅涓婚敭", + type: "string", + width: 90, + align: "left", + }, + { + field: "locationCode", + title: "璐т綅缂栧彿", + type: "string", + width: 160, + align: "left", + }, + { + field: "beforeStatus", + title: "鍙樺姩鍓嶈揣浣嶇姸鎬�", + type: "tag", + width: 150, + align: "left", + bindKey: "locationStatusEnum" + }, + { + field: "afterStatus", + title: "鍙樺姩鍚庤揣浣嶇姸鎬�", + type: "tag", + width: 150, + align: "left", + bindKey: "locationStatusEnum" + }, + { + field: "changeType", + title: "鍙樺姩绫诲瀷", + type: "tag", + width: 100, + align: "left", + bindKey: "stockChangeType", + }, + { + field: "orderId", + title: "鍗曟嵁涓婚敭", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "int", + width: 160, + align: "left", + }, + { + field: "orderDetailId", + title: "鍗曟嵁鏄庣粏涓婚敭", + type: "string", + width: 200, + align: "left", + hidden: true, + }, + { + field: "taskNum", + title: "浠诲姟鍙�", + type: "string", + width: 180, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + hidden: true, + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + hidden: true, + sort: true, + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + hidden: true, + }, + ], + paginations: { + sort: "CreateDate", + order: "desc", + Foots: "", + total: 0, + // 2020.08.29澧炲姞鑷畾涔夊垎椤垫潯澶у皬 + sizes: [30, 60, 100, 120], + size: 30, // 榛樿鍒嗛〉澶у皬 + Wheres: [], + page: 1, + rows: 30, + }, + dictionaryList: null, + }; + }, + methods: { + open(row) { + this.row = row; + this.showDetialBox = true; + this.getDetailData(); + this.getDictionaryData(); + }, + getDetailData() { + this.http + .post( + "/api/LocationStatusChangeRecord/GetLocationState?id=" + this.row.id, + {}, + true + ) + .then((x) => { + if (!x.status) return this.$message.error(x.message); + this.tableData = x.data; + }); + }, + getDictionaryData() { + if (this.dictionaryList) { + return; + } + var param = []; + this.tableColumns.forEach((x) => { + if (x.type == "tag" && x.bindKey != "") { + param.push(x.bindKey); + } + }); + this.http + .post("api/Sys_Dictionary/GetVueDictionary", param, "鏌ヨ涓�") + .then((x) => { + if (x.length > 0) { + this.dictionaryList = x; + } + }); + }, + getDictionary(row, column) { + if (this.dictionaryList) { + var item = this.dictionaryList.find((x) => x.dicNo == column.bindKey); + if (item) { + var dicItem = item.data.find((x) => x.key == row[column.field]); + console.log(dicItem); + if (dicItem) { + return dicItem.value; + } + else { + return row[column.field]; + } + } else { + return row[column.field]; + } + } + }, + }, + + + created() { }, +}; +</script> + +<style scoped> +.el-col { + border-radius: 4px; +} + +.grid-content { + border-radius: 4px; + min-height: 36px; +} + +.content-text { + display: flex; + align-items: center; + justify-content: center; +} + +.right-text { + display: flex; + align-items: center; + justify-content: flex-end; +} +</style> +<style> +.el-table .warning-row { + background: #e6a23c; +} + +.el-table .success-row { + background: #f0f9eb; +} + +.el-table .error-row { + background: #f56c6c; +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/locationInfo.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/locationInfo.js" new file mode 100644 index 0000000..d805115 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/locationInfo.js" @@ -0,0 +1,103 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 +import gridBody from './extend/GetLocationStatus.vue' +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: gridBody, + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + let EnableBtn = this.buttons.find(x => x.value == 'Enable'); + if (EnableBtn) { + EnableBtn.onClick = function () { + let rows = this.$refs.table.getSelected(); + if (rows.length == 0) return this.$error("璇烽�夋嫨鏁版嵁!"); + var keys = rows.map(x => { return x.id }); + this.http + .post("api/LocationInfo/LocationEnableStatus", keys, "鏁版嵁澶勭悊涓�") + .then((x) => { + if (!x.status) return this.$message.error(x.message); + this.$message.success("鎿嶄綔鎴愬姛"); + this.refresh(); + }); + } + } + let DisableBtn = this.buttons.find(x => x.value == 'Disable'); + if (DisableBtn) { + DisableBtn.onClick = function () { + let rows = this.$refs.table.getSelected(); + if (rows.length == 0) return this.$error("璇烽�夋嫨鏁版嵁!"); + var keys = rows.map(x => { return x.id }); + this.http + .post("api/LocationInfo/LocationDisableStatus", keys, "鏁版嵁澶勭悊涓�") + .then((x) => { + if (!x.status) return this.$message.error(x.message); + this.$message.success("鎿嶄綔鎴愬姛"); + this.refresh(); + }); + } + } + + this.columns.push({ + field: '鎿嶄綔', + title: '鎿嶄綔', + width: 90, + fixed: 'right', + align: 'center', + formatter: (row) => { + return ( + '<i style="cursor: pointer;color: #2d8cf0;"class="el-icon-view">鏌ョ湅鏄庣粏</i>' + ); + }, + click: (row) => { + this.$refs.gridBody.open(row); + } + }); + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/materielInfo.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/materielInfo.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/materielInfo.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/roadwayInfo.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/roadwayInfo.js" new file mode 100644 index 0000000..4f198a3 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/roadwayInfo.js" @@ -0,0 +1,72 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + this.boxOptions.labelWidth = 150; + this.labelWidth=200; + + let enableBtn = this.buttons.find(x => x.value == 'Enable'); + if (enableBtn) { + enableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + let disableBtn = this.buttons.find(x => x.value == 'Disable'); + if (disableBtn) { + disableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/warehouse.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/warehouse.js" new file mode 100644 index 0000000..151c927 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/basic/warehouse.js" @@ -0,0 +1,69 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + let enableBtn = this.buttons.find(x => x.value == 'Enable'); + if (enableBtn) { + enableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + let disableBtn = this.buttons.find(x => x.value == 'Disable'); + if (disableBtn) { + disableBtn.onClick = function () { + this.$message.success('鑷畾涔夋寜閽偣鍑讳簨浠�'); + } + } + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/inboundOrder.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/inboundOrder.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/inboundOrder.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/inboundOrderDetail.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/inboundOrderDetail.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/inboundOrderDetail.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/receiveOrder.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/receiveOrder.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/inbound/receiveOrder.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/SelectedStock.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/SelectedStock.vue" new file mode 100644 index 0000000..b6bdde8 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/SelectedStock.vue" @@ -0,0 +1,230 @@ +<template> + <div> + <vol-box + v-model="showDetialBox" + :lazy="true" + width="75%" + :padding="15" + title="鍑哄簱璇︽儏" + > + <div class="box-head"> + <el-alert :closable="false" style="width: 100%"> + <el-row> + <el-col :span="24"> + <span class="less-style">鐗╂枡鍚嶇О锛� {{ row.materielName }} </span> + <el-divider direction="vertical"></el-divider> + <span class="less-style">鐗╂枡缂栧彿锛� {{ row.materielCode }} </span> + <el-divider direction="vertical"></el-divider> + <span class="less-style" + >闇�姹傛暟閲忥細 {{ row.orderQuantity }} + </span> + <el-divider direction="vertical"></el-divider> + <span class="less-style" + >宸插垎閰嶆暟閲忥細 {{ row.lockQuantity }} + </span> + </el-col> + </el-row> + </el-alert> + </div> + <div class="box-table" style="margin-top: 1%"> + <el-table + ref="singleTable" + :data="tableData" + style="width: 100%; height: 100%" + highlight-current-row + height="500px" + > + > + <el-table-column + label="搴忓彿" + type="index" + fixed="left" + width="55" + align="center" + ></el-table-column> + <el-table-column + v-for="(item, index) in tableColumns.filter((x) => !x.hidden)" + :key="index" + :prop="item.prop" + :label="item.title" + :width="item.width" + align="center" + > + <template #default="scoped" v-if="item.type == 'icon'"> + <el-tooltip + class="item" + effect="dark" + :content="item.title" + placement="bottom" + ><el-button + type="text" + @click="tableButtonClick(scoped.row, item)" + ><i :class="item.icon" style="font-size: 22px"></i></el-button + ></el-tooltip> + </template> + </el-table-column> + </el-table> + </div> + <template #footer> + <!-- <el-button type="primary" size="small" @click="submit">纭</el-button> --> + <el-button type="danger" size="small" @click="showDetialBox = false" + >鍏抽棴</el-button + > + </template> + </vol-box> + </div> +</template> + <script> +import VolBox from "@/components/basic/VolBox.vue"; +export default { + components: { VolBox }, + data() { + return { + row: null, + showDetialBox: false, + tableData: [], + tableColumns: [ + { + prop: "id", + title: "涓婚敭", + type: "string", + width: 150, + hidden: true, + }, + { + prop: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "string", + width: 150, + }, + { + prop: "orderDetailId", + title: "鍗曟嵁鏄庣粏涓婚敭", + type: "string", + width: 150, + hidden: true, + }, + { + prop: "orderType", + title: "鍗曟嵁绫诲瀷", + type: "string", + width: 90, + }, + { + prop: "batchNo", + title: "鎵规鍙�", + type: "string", + width: 120, + }, + { + prop: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + }, + { + prop: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + }, + { + prop: "stockId", + title: "搴撳瓨涓婚敭", + type: "string", + width: 150, + hidden: true, + }, + { + prop: "originalQuantity", + title: "鍘熷搴撳瓨閲�", + type: "string", + width: 100, + }, + { + prop: "assignQuantity", + title: "鍒嗛厤鍑哄簱閲�", + type: "string", + width: 100, + }, + { + prop: "palletCode", + title: "鎵樼洏缂栧彿", + type: "string", + width: 150, + }, + { + prop: "locationCode", + title: "璐т綅缂栧彿", + type: "string", + width: 180, + }, + { + prop: "status", + title: "鐘舵��", + type: "string", + }, + ], + }; + }, + methods: { + open(row) { + this.row = row; + this.showDetialBox = true; + this.getData(); + }, + getData() { + this.http + .post( + "api/OutStockLockInfo/GetByOrderDetailId?orderDetailId=" + + this.row.id, + null, + "鏌ヨ涓�" + ) + .then((x) => { + this.tableData = x; + }); + }, + }, +}; +</script> + <style scoped> +.less-style { + color: black; +} +.equle-style { + color: green; +} +.more-style { + color: red; +} +</style> + + <style> +.text-button:hover { + background-color: #f0f9eb !important; +} +.el-table .warning-row { + background: oldlace; +} +.box-table .el-table tbody tr:hover > td { + background-color: #d8e0d4 !important; + /* color: #ffffff; */ +} + +.box-table .el-table tbody tr.current-row > td { + background-color: #f0f9eb !important; + /* color: #ffffff; */ +} + +.el-table .success-row { + background: #f0f9eb; +} + +.box-table .el-table { + border: 1px solid #ebeef5; +} +.box-head .el-alert__content { + width: 100%; +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/StockSelect.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/StockSelect.vue" new file mode 100644 index 0000000..1a2ce9d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/StockSelect.vue" @@ -0,0 +1,251 @@ +<template> + <div> + <vol-box v-model="showDetialBox" :lazy="true" width="60%" :padding="15" title="鎸囧畾搴撳瓨"> + <div class="box-head"> + <el-alert :closable="false" style="width: 100%"> + <el-row> + <el-col :span="20"> + <span class="less-style">鐗╂枡鍚嶇О锛� {{ row.materielName }} </span> + <el-divider direction="vertical"></el-divider> + <span class="less-style">鐗╂枡缂栧彿锛� {{ row.materielCode }} </span> + <el-divider direction="vertical"></el-divider> + <span class="less-style">闇�姹傛暟閲忥細 {{ row.orderQuantity }} + </span> + <el-divider direction="vertical"></el-divider> + <span :class="selectionClass">宸查�夋暟閲忥細 {{ selectionSum }} + </span> + </el-col> + <el-col :span="2"> + <el-link type="primary" size="small" style="float: right; height: 20px" + @click="getData">鍒锋柊</el-link></el-col> + <el-col :span="2"> + <el-link type="primary" size="small" style="float: right; height: 20px" + @click="revokeAssign">鎾ら攢鍒嗛厤</el-link></el-col> + </el-row> + </el-alert> + </div> + <div class="box-table" style="margin-top: 1%"> + <el-table ref="singleTable" :data="tableData" style="width: 100%; height: 100%" highlight-current-row + @row-click="handleRowClick" height="500px" @selection-change="handleSelectionChange"> + > + <el-table-column type="selection" width="55"> </el-table-column> + <el-table-column label="搴忓彿" type="index" fixed="left" width="55" align="center"></el-table-column> + <el-table-column v-for="(item, index) in tableColumns.filter((x) => !x.hidden)" :key="index" :prop="item.prop" + :label="item.title" :width="item.width" align="center"> + <template #default="scoped" v-if="item.type == 'icon'"> + <el-tooltip class="item" effect="dark" :content="item.title" placement="bottom"><el-button type="text" + @click="tableButtonClick(scoped.row, item)"><i :class="item.icon" + style="font-size: 22px"></i></el-button></el-tooltip> + </template> + </el-table-column> + </el-table> + </div> + <template #footer> + <el-button type="primary" size="small" @click="outbound">鐩存帴鍑哄簱</el-button> + <el-button type="primary" size="small" @click="lockStock">閿佸畾搴撳瓨</el-button> + <el-button type="danger" size="small" @click="showDetialBox = false">鍏抽棴</el-button> + </template> + </vol-box> + </div> +</template> +<script> +import VolBox from "@/components/basic/VolBox.vue"; +export default { + components: { VolBox }, + data() { + return { + row: null, + showDetialBox: false, + tableData: [], + tableColumns: [ + { + prop: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + }, + { + prop: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + }, + { + prop: "palletCode", + title: "鎵樼洏缂栧彿", + type: "string", + width: 150, + }, + { + prop: "locationCode", + title: "璐т綅缂栧彿", + type: "string", + width: 180, + }, + { + prop: "useableQuantity", + title: "鍙敤鏁伴噺", + type: "string", + }, + ], + selection: [], + selectionSum: 0, + selectionClass: "less-style", + originalQuantity: 0, + }; + }, + methods: { + open(row) { + this.row = row; + this.showDetialBox = true; + this.originalQuantity = this.row.lockQuantity; + this.selectionSum = this.row.lockQuantity; + this.getData(); + if (this.selectionSum == this.row.orderQuantity) { + this.selectionClass = "equle-style"; + } else if (this.selectionSum < this.row.orderQuantity) { + this.selectionClass = "less-style"; + } else { + this.selectionClass = "more-style"; + } + }, + lockStock() { + this.http + .post( + "api/OutboundOrderDetail/LockOutboundStock?id=" + this.row.id, + this.selection, + "鏁版嵁澶勭悊涓�" + ) + .then((x) => { + if (!x.status) return this.$message.error(x.message); + this.$message.success("鎿嶄綔鎴愬姛"); + this.showDetialBox = false; + this.$emit("parentCall", ($vue) => { + $vue.getData(); + }); + }); + }, + outbound() { + this.http + .post( + "api/Task/GenerateOutboundTask?id=" + this.row.id, + this.selection, + "鏁版嵁澶勭悊涓�" + ) + .then((x) => { + if (!x.status) return this.$message.error(x.message); + this.$message.success("鎿嶄綔鎴愬姛"); + this.showDetialBox = false; + this.$emit("parentCall", ($vue) => { + $vue.getData(); + }); + }); + }, + getData() { + this.http + .post( + "api/StockInfo/GetStockSelectViews?materielCode=" + + this.row.materielCode, + null, + "鏌ヨ涓�" + ) + .then((x) => { + this.tableData = x; + }); + }, + revokeAssign() { + console.log(this.row); + this.http + .post( + "api/OutboundOrderDetail/RevokeLockOutboundStock?id=" + this.row.id, + null, + "鏁版嵁澶勭悊涓�" + ) + .then((x) => { + if (!x.status) return this.$message.error(x.message); + this.$message.success("鎿嶄綔鎴愬姛"); + this.showDetialBox = false; + this.$emit("parentCall", ($vue) => { + $vue.getData(); + }); + }); + }, + handleSelectionChange(val) { + this.selection = val; + this.selectionSum = + val.reduce( + (accumulator, currentValue) => + accumulator + currentValue["useableQuantity"], + 0 + ) + this.originalQuantity; + if (this.selectionSum == this.row.orderQuantity) { + this.selectionClass = "equle-style"; + } else if (this.selectionSum < this.row.orderQuantity) { + this.selectionClass = "less-style"; + } else { + this.selectionClass = "more-style"; + } + }, + toggleSelection(rows) { + if (rows) { + rows.forEach((row) => { + this.$refs.singleTable.toggleRowSelection(row); + }); + } else { + this.$refs.singleTable.clearSelection(); + } + }, + clearSelection() { + this.$refs.singleTable.clearSelection(); + }, + handleRowClick(row) { + this.$refs.singleTable.toggleRowSelection(row); + }, + }, +}; +</script> +<style scoped> +.less-style { + color: black; +} + +.equle-style { + color: green; +} + +.more-style { + color: red; +} +</style> + +<style> +.text-button:hover { + background-color: #f0f9eb !important; +} + +.el-table .warning-row { + background: oldlace; +} + +.box-table .el-table tbody tr:hover>td { + background-color: #d8e0d4 !important; + /* color: #ffffff; */ +} + +.box-table .el-table tbody tr.current-row>td { + background-color: #f0f9eb !important; + /* color: #ffffff; */ +} + +.el-table .success-row { + background: #f0f9eb; +} + +.box-table .el-table { + border: 1px solid #ebeef5; +} + +.box-head .el-alert__content { + width: 100%; +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/outOrderDetail.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/outOrderDetail.vue" new file mode 100644 index 0000000..40096ab --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/extend/outOrderDetail.vue" @@ -0,0 +1,371 @@ +<template> + <div> + <vol-box v-model="showDetialBox" :lazy="true" width="75%" :padding="15" title="鍗曟嵁鏄庣粏淇℃伅"> + <div class="box-head"> + <el-alert :closable="false" style="width: 100%"> + <el-row> + <el-col :span="16"> + <span>宸查�変腑 {{ selection.length }} 椤�</span> + </el-col> + <el-col :span="8"> + <el-link type="primary" size="small" style="float: right; height: 20px" @click="lockstocks">閿佸畾搴撳瓨</el-link> + <el-link type="primary" size="small" style="float: right; height: 20px; margin-right: 10px" + @click="outbound">鐩存帴鍑哄簱</el-link> + <el-link type="primary" size="small" style="float: right; height: 20px; margin-right: 10px" + @click="getData">鍒锋柊</el-link></el-col> + </el-row> + </el-alert> + </div> + <div class="box-table" style="margin-top: 1%"> + <el-table ref="singleTable" :data="tableData" style="width: 100%; height: 100%" highlight-current-row + @current-change="handleCurrentChange" height="500px" @row-click="handleRowClick" + @selection-change="handleSelectionChange"> + <el-table-column type="selection" width="55"> </el-table-column> + <el-table-column label="搴忓彿" type="index" fixed="left" width="55" align="center"></el-table-column> + <el-table-column v-for="(item, index) in tableColumns.filter((x) => !x.hidden)" :key="index" :prop="item.prop" + :label="item.title" :width="item.width" align="center"> + <template #default="scoped"> + <div v-if="item.type == 'icon'"> + <el-tooltip class="item" effect="dark" :content="item.title" placement="bottom"><el-link type="primary" + :disabled="getButtonEnable(item.prop, scoped.row)" @click="tableButtonClick(scoped.row, item)"><i + :class="item.icon" style="font-size: 22px"></i></el-link></el-tooltip> + </div> + + <div v-else-if="item.type == 'tag'"> + <el-tag size="small"> + {{ getDictionary(scoped.row, item) }} + </el-tag> + </div> + </template> + </el-table-column> + </el-table> + </div> + </vol-box> + <stock-select ref="child" @parentCall="parentCall"></stock-select> + <selected-stock ref="selectedStock" @parentCall="parentCall"></selected-stock> + </div> +</template> +<script> +import VolBox from "@/components/basic/VolBox.vue"; +import VolForm from "@/components/basic/VolForm.vue"; +import StockSelect from "./StockSelect.vue"; +import SelectedStock from "./SelectedStock.vue"; +export default { + components: { VolBox, VolForm, StockSelect, SelectedStock }, + data() { + return { + row: null, + showDetialBox: false, + flag: false, + currentRow: null, + selection: [], + tableData: [], + tableColumns: [ + { + prop: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + }, + { + prop: "orderId", + title: "鍑哄簱鍗曚富閿�", + type: "string", + width: 90, + hidden: true, + }, + { + prop: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + }, + { + prop: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + }, + { + prop: "batchNo", + title: "鎵规鍙�", + type: "string", + width: 90, + }, + { + prop: "orderQuantity", + title: "鍗曟嵁鏁伴噺", + type: "string", + width: 90, + }, + { + prop: "lockQuantity", + title: "閿佸畾鏁伴噺", + type: "int", + width: 90, + }, + { + prop: "overOutQuantity", + title: "宸插嚭鏁伴噺", + type: "string", + width: 90, + }, + { + prop: "orderDetailStatus", + title: "璁㈠崟鏄庣粏鐘舵��", + type: "tag", + width: 180, + bindKey: "orderDetailStatusEnum" + }, + { + prop: "assignStock", + title: "鎸囧畾搴撳瓨", + type: "icon", + width: 90, + icon: "el-icon-s-grid", + }, + { + prop: "viewDetail", + title: "鍑哄簱璇︾粏", + type: "icon", + width: 90, + icon: "el-icon-s-operation", + }, + { + prop: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + }, + { + prop: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + }, + { + prop: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + }, + { + prop: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + }, + { + prop: "remark", + title: "澶囨敞", + type: "string", + }, + ], + paginations: { + sort: "id", + order: "desc", + Foots: "", + total: 0, + // 2020.08.29澧炲姞鑷畾涔夊垎椤垫潯澶у皬 + sizes: [30, 60, 100, 120], + size: 30, // 榛樿鍒嗛〉澶у皬 + Wheres: [], + page: 1, + rows: 30, + }, + searchFormOptions: [ + [ + { + title: "鍗曟嵁缂栧彿", + field: "allocation_code", + type: "like", + }, + { + title: "鍗曟嵁绫诲瀷", + field: "allocation_type", + type: "select", + dataKey: "OrderType", + data: [], + }, + { + title: "鍗曟嵁鐘舵��", + field: "allocation_state", + type: "select", + dataKey: "OrderState", + data: [], + }, + ], + ], + searchFormFields: { + allocation_code: "", + allocation_type: "", + allocation_state: "", + }, + dictionaryList: null, + }; + }, + methods: { + open(row) { + this.row = row; + this.showDetialBox = true; + this.getDictionaryData(); + this.getData(); + }, + getData() { + var wheres = [{ name: "orderId", value: this.row.id }]; + var param = { + page: this.paginations.page, + rows: this.paginations.rows, + sort: this.paginations.sort, + order: this.paginations.order, + wheres: JSON.stringify(wheres), // 鏌ヨ鏉′欢锛屾牸寮忎负[{ name: "瀛楁", value: "xx" }] + }; + this.http + .post("api/OutboundOrderDetail/GetPageData", param, "鏌ヨ涓�") + .then((x) => { + this.tableData = x.rows; + }); + }, + tableButtonClick(row, column) { + if (column.prop == "assignStock") { + this.$refs.child.open(row); + } else { + this.$refs.selectedStock.open(row); + } + }, + lockstocks() { + if (this.selection.length === 0) { + return this.$message.error("璇烽�夋嫨鍗曟嵁鏄庣粏"); + } + var keys = this.selection.map((item) => item.id); // 鑾峰彇閫変腑琛岀殑id + this.http + .post("api/OutboundOrderDetail/LockOutboundStocks", keys, "鏁版嵁澶勭悊涓�") + .then((x) => { + if (!x.status) return this.$message.error(x.message); + this.$message.success("鎿嶄綔鎴愬姛"); + this.showDetialBox = false; + this.$emit("parentCall", ($vue) => { + $vue.getData(); + }); + }); + }, + outbound() { + if (this.selection.length === 0) { + return this.$message.error("璇烽�夋嫨鍗曟嵁鏄庣粏"); + } + var keys = this.selection.map((item) => item.id); // 鑾峰彇閫変腑琛岀殑id + + this.http + .post("api/Task/GenerateOutboundTasks", keys, "鏁版嵁澶勭悊涓�") + .then((x) => { + if (!x.status) return this.$message.error(x.message); + this.$message.success("鎿嶄綔鎴愬姛"); + this.showDetialBox = false; + this.$emit("parentCall", ($vue) => { + $vue.getData(); + }); + }); + }, + setCurrent(row) { + this.$refs.singleTable.setCurrentRow(row); + }, + handleCurrentChange(val) { + this.currentRow = val; + }, + getButtonEnable(propName, row) { + if (propName == "assignStock") { + if ( + row.orderDetailStatus !== 0 && + row.orderDetailStatus !== 60 && + row.orderDetailStatus !== 70 + ) { + return true; + } else { + return false; + } + } + return false; + }, + parentCall(fun) { + if (typeof fun != "function") { + return console.log("鎵╁睍缁勪欢闇�瑕佷紶鍏ヤ竴涓洖璋冩柟娉曟墠鑳借幏鍙栫埗绾ue瀵硅薄"); + } + fun(this); + }, + handleRowClick(row) { + this.$refs.singleTable.toggleRowSelection(row); + }, + handleSelectionChange(val) { + this.selection = val; + }, + getDictionaryData() { + if (this.dictionaryList) { + return; + } + var param = []; + this.tableColumns.forEach((x) => { + if (x.type == "tag" && x.bindKey != "") { + param.push(x.bindKey); + } + }); + this.http + .post("api/Sys_Dictionary/GetVueDictionary", param, "鏌ヨ涓�") + .then((x) => { + if (x.length > 0) { + this.dictionaryList = x; + } + }); + }, + getDictionary(row, column) { + if (this.dictionaryList) { + var item = this.dictionaryList.find((x) => x.dicNo == column.bindKey); + if (item) { + var dicItem = item.data.find((x) => x.key == row[column.prop]); + console.log(dicItem); + if (dicItem) { + return dicItem.value; + } else { + return row[column.prop]; + } + } else { + return row[column.prop]; + } + } + }, + }, +}; +</script> +<style scoped> +.text-button { + border: 0px; +} +</style> + +<style> +.text-button:hover { + background-color: #f0f9eb !important; +} + +.el-table .warning-row { + background: oldlace; +} + +.box-table .el-table tbody tr:hover>td { + background-color: #d8e0d4 !important; + /* color: #ffffff; */ +} + +.box-table .el-table tbody tr.current-row>td { + background-color: #f0f9eb !important; + /* color: #ffffff; */ +} + +.el-table .success-row { + background: #f0f9eb; +} + +.box-table .el-table { + border: 1px solid #ebeef5; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/outboundOrder.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/outboundOrder.js" new file mode 100644 index 0000000..122b98c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/outboundOrder.js" @@ -0,0 +1,74 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 +import gridBody from './extend/outOrderDetail.vue' +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: gridBody, + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + //鎵╁睍椤甸潰鍒濆鍖栨搷浣� + this.columns.push({ + field: '鎿嶄綔', + title: '鎿嶄綔', + width: 90, + fixed: 'right', + align: 'center', + formatter: (row) => { + return ( + '<i style="cursor: pointer;color: #2d8cf0;"class="el-icon-view">鏌ョ湅鏄庣粏</i>' + ); + }, + click: (row) => { + this.$refs.gridBody.open(row); + } + }); + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/outboundOrderDetail.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/outboundOrderDetail.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/outbound/outboundOrderDetail.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/record/locationStatusChangeRecord.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/record/locationStatusChangeRecord.js" new file mode 100644 index 0000000..1b38800 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/record/locationStatusChangeRecord.js" @@ -0,0 +1,61 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + this.boxOptions.labelWidth = 180; + this.labelWidth=150; + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/record/stockQuantityChangeRecord.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/record/stockQuantityChangeRecord.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/record/stockQuantityChangeRecord.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockInfo.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockInfo.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockInfo.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockInfoDetail.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockInfoDetail.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockInfoDetail.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockView.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockView.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/stock/stockView.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Dictionary.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Dictionary.js" new file mode 100644 index 0000000..e37ecf6 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Dictionary.js" @@ -0,0 +1,65 @@ +import { h, resolveComponent } from 'vue'; +let extension = { + components: { //鍔ㄦ�佹墿鍏呯粍浠舵垨缁勪欢璺緞 + //琛ㄥ崟header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + //鎵╁睍缁勪欢寮曞叆鏂瑰紡 + gridHeader: '', + gridBody: '', + gridFooter: '', + //寮瑰嚭妗�(淇敼銆佺紪杈戙�佹煡鐪�)header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + buttons: [], //鎵╁睍鐨勬寜閽� + methods: { //浜嬩欢鎵╁睍 + onInit() { + //鐐瑰嚮鍗曞厓鏍肩紪杈戜笌缁撴潫缂栬緫(榛樿鏄偣鍑诲崟鍏冩牸缂栬緫锛岄紶鏍囩寮�缁撴潫缂栬緫) + this.detailOptions.clickEdit = true; + this.editFormOptions.forEach(x => { + x.forEach(item => { + if (item.field == 'ParentId') { + item.min = 0; + } + if (item.field == "DbSql") { + item.placeholder = "濡傛灉浠庢暟鎹簱鍔犺浇鏁版嵁婧愶紝璇锋寜姝ゆ牸寮忛厤缃畇ql璇彞锛歴elect orderType as key,orderName as value from order 濡傛灉闇�瑕佹牴鎹敤鎴蜂俊鎭姞杞芥暟鎹簮锛岃閰嶇疆濂芥sql,鍐嶄慨鏀瑰悗鍙癉ictionaryHandler.GetCustomDBSql鏂规硶"; + } + }) + }) + this.detailOptions.columns.forEach(x => { + if (x.field == 'OrderNo') { + x.summary = true; + } + }) + //淇濆瓨鍚庝笉鍏抽棴缂栬緫妗� + this.boxOptions.saveClose = false; + }, + onInited() { + this.boxOptions.height = document.body.clientHeight * 0.87 + this.height = this.height - 45; + }, + addBefore(formData) { + return this.saveBefore(formData); + }, + updateBefore(formData) { + return this.saveBefore(formData); + }, + saveBefore(formData) { + if (this.editFormFields.DbSql && + (this.editFormFields.DbSql.indexOf('value') == -1 || + this.editFormFields.DbSql.indexOf('key') == -1) + ) { + this.$message.error("sql璇彞蹇呴』鍖呮嫭key/value瀛楁,濡�:select orderType as key,orderName as value from order"); + return false; + } + return true; + }, + searchBefore(param) { + return true; + }, + searchAfter(result) { + return true; + } + } +}; +export default extension; \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_DictionaryList.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_DictionaryList.js" new file mode 100644 index 0000000..da94487 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_DictionaryList.js" @@ -0,0 +1,22 @@ + + +let extension = { + components: {//鍔ㄦ�佹墿鍏呯粍浠舵垨缁勪欢璺緞 + //琛ㄥ崟header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + gridHeader:'', + gridbody:'', + gridFooter: '', + //寮瑰嚭妗�(淇敼銆佺紪杈戙�佹煡鐪�)header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + buttons: [],//鎵╁睍鐨勬寜閽� + methods: {//浜嬩欢鎵╁睍 + onInit() { + }, + onInited() { + } + } +}; +export default extension; \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Log.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Log.js" new file mode 100644 index 0000000..5b05c40 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Log.js" @@ -0,0 +1,26 @@ +import { h, resolveComponent } from 'vue'; +let extension = { + components: { + //鍔ㄦ�佹墿鍏呯粍浠舵垨缁勪欢璺緞 + //琛ㄥ崟header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + gridHeader: "", //{ template: "<div>鎵╁睍缁剎x浠�</div>" }, + gridBody: '', + gridFooter: "", + //寮瑰嚭妗�(淇敼銆佺紪杈戙�佹煡鐪�)header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + modelHeader: "", + modelBody: "", + modelFooter: "" + }, + buttons: [], //鎵╁睍鐨勬寜閽� + methods: { + //浜嬩欢鎵╁睍 + onInit() { + console.log("sys_log") + this.setFiexdSearchForm(true); + }, + onInited() { + this.height = this.height - 170; + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Role.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Role.js" new file mode 100644 index 0000000..5ba4845 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Role.js" @@ -0,0 +1,49 @@ + +let extension = { + components: {//鍔ㄦ�佹墿鍏呯粍浠舵垨缁勪欢璺緞 + //琛ㄥ崟header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + gridHeader: '', + gridBody: '', + gridFooter: '', + //寮瑰嚭妗�(淇敼銆佺紪杈戙�佹煡鐪�)header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + buttons: [],//鎵╁睍鐨勬寜閽� + tableAction:"Sys_Role", + methods: {//浜嬩欢鎵╁睍 + onInited () { + this.height = this.height - 80; + this.editFormOptions.forEach(x => { + x.forEach(item => { + if (item.field == 'ParentId') { + item.title = "涓婄骇瑙掕壊"; + //璁剧疆浠绘剰鑺傜偣閮借兘閫変腑(榛樿鍙兘閫変腑鏈�鍚庝竴涓妭鐐�) + item.changeOnSelect = true; + } + }) + }) + }, + onInit() { + //璁剧疆treetable鐨勫敮涓�鍊煎瓧娈�(杩欎釜瀛楁鐨勫�煎湪琛ㄩ噷闈㈠繀椤绘槸鍞竴鐨�) + this.rowKey="Role_Id"; + }, + /***鍔犺浇鍚庡彴鏁版嵁瑙丼ys_RoleController.cs鏂囦欢***/ + loadTreeChildren(tree, treeNode, resolve) { //鍔犺浇瀛愯妭鐐� + let url=`api/role/getTreeTableChildrenData?roleId=${tree.Role_Id}`; + this.http.post(url,{}).then(result=>{ + resolve(result.rows) + }) + }, + /***鍔犺浇鍚庡彴鏁版嵁瑙丼ys_RoleController.cs鏂囦欢***/ + searchBefore(params){//鍒ゆ柇鍔犺浇鏍硅妭鐐规垨瀛愯妭鐐� + //娌℃湁鏌ヨ鏉′欢锛岄粯璁ゆ煡璇㈣繑鍥炴墍鏈夋牴鑺傜偣鏁版嵁 + if (!params.wheres.length) { + params.value=1; + } + return true; + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Role1.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Role1.js" new file mode 100644 index 0000000..d6715be --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_Role1.js" @@ -0,0 +1,61 @@ + +import { h, resolveComponent } from 'vue'; +let extension = { + components: {//鍔ㄦ�佹墿鍏呯粍浠舵垨缁勪欢璺緞 + //琛ㄥ崟header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + gridHeader: '', + gridBody: { + render () { + return [ + h(resolveComponent('el-alert'), { + style: { 'margin-bottom': '12px' }, + 'show-icon': true, type: 'error', + closable: false, title: '鍏充簬TreeTable浣跨敤' + }, ' treetable鍚屾牱鍏ㄩ儴浠g爜鑷姩鐢熸垚锛岄〉闈㈢敓鎴愬悗璁剧疆this.rowKe="xxx" tree涓婚敭瀛楁,鍗冲彲瀹屾垚鏍戝舰table閰嶇疆,鍏蜂綋璇存槑瑙丼ys_Role1.js'), + ] + } + }, + + gridFooter: '', + //寮瑰嚭妗�(淇敼銆佺紪杈戙�佹煡鐪�)header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + buttons: [],//鎵╁睍鐨勬寜閽� + tableAction:"Sys_Role", + methods: {//浜嬩欢鎵╁睍 + onInited () { + this.height = this.height - 80; + this.editFormOptions.forEach(x => { + x.forEach(item => { + if (item.field == 'ParentId') { + item.title = "涓婄骇瑙掕壊"; + //璁剧疆浠绘剰鑺傜偣閮借兘閫変腑(榛樿鍙兘閫変腑鏈�鍚庝竴涓妭鐐�) + item.changeOnSelect = true; + } + }) + }) + }, + onInit() { + //璁剧疆treetable鐨勫敮涓�鍊煎瓧娈�(杩欎釜瀛楁鐨勫�煎湪琛ㄩ噷闈㈠繀椤绘槸鍞竴鐨�) + this.rowKey="Role_Id"; + }, + /***鍔犺浇鍚庡彴鏁版嵁瑙丼ys_RoleController.cs鏂囦欢***/ + loadTreeChildren(tree, treeNode, resolve) { //鍔犺浇瀛愯妭鐐� + let url=`api/role/getTreeTableChildrenData?roleId=${tree.Role_Id}`; + this.http.post(url,{}).then(result=>{ + resolve(result.rows) + }) + }, + /***鍔犺浇鍚庡彴鏁版嵁瑙丼ys_RoleController.cs鏂囦欢***/ + searchBefore(params){//鍒ゆ柇鍔犺浇鏍硅妭鐐规垨瀛愯妭鐐� + //娌℃湁鏌ヨ鏉′欢锛岄粯璁ゆ煡璇㈣繑鍥炴墍鏈夋牴鑺傜偣鏁版嵁 + if (!params.wheres.length) { + params.value=1; + } + return true; + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_User.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_User.js" new file mode 100644 index 0000000..4be7155 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_User.js" @@ -0,0 +1,86 @@ +import { defineAsyncComponent } from "vue"; +let extension = { + components: { //鍔ㄦ�佹墿鍏呯粍浠舵垨缁勪欢璺緞 + //琛ㄥ崟header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + gridHeader: defineAsyncComponent(() => + import("./Sys_User/Sys_UserGridHeader.vue")), + gridBody: '', + gridFooter: '', + //寮瑰嚭妗�(淇敼銆佺紪杈戙�佹煡鐪�)header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠� + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + text: "鍙兘鐪嬪埌褰撳墠瑙掕壊涓嬬殑鎵�鏈夊笎鍙�", + buttons: [], //鎵╁睍鐨勬寜閽� + methods: { //浜嬩欢鎵╁睍 + onInit() { + this.boxOptions.height = 530; + this.columns.push({ + title: '鎿嶄綔', + hidden: false, + align: "center", + fixed: 'right', + width: 120, + render: (h, { row, column, index }) => { + return h( + "div", { style: { 'font-size': '13px', 'cursor': 'pointer', 'color': '#409eff' } }, [ + h( + "a", { + style: { 'margin-right': '15px' }, + onClick: (e) => { + e.stopPropagation() + this.$refs.gridHeader.open(row); + } + }, "淇敼瀵嗙爜" + ), + h( + "a", { + style: {}, + onClick: (e) => { + e.stopPropagation() + this.edit(row); + } + }, + "缂栬緫" + ), + ]) + } + }) + }, + onInited() { }, + addAfter(result) { //鐢ㄦ埛鏂板缓鍚庯紝鏄剧ず闅忔満鐢熸垚鐨勫瘑鐮� + if (!result.status) { + return true; + } + //鏄剧ず鏂板缓鐢ㄦ埛鐨勫瘑鐮� + //2020.08.28浼樺寲鏂板缓鎴愬悗鎻愮ず鏂瑰紡 + this.$confirm(result.message, '鏂板缓鐢ㄦ埛鎴愬姛', { + confirmButtonText: '纭畾', + type: 'success', + center: true + }).then(() => { }) + + this.boxModel = false; + this.refresh(); + return false; + }, + modelOpenAfter() { + //鐐瑰嚮寮瑰嚭妗嗗悗锛屽鏋滄槸缂栬緫鐘舵�侊紝绂佹缂栬緫鐢ㄦ埛鍚嶏紝濡傛灉鏂板缓鐘舵�侊紝灏嗙敤鎴峰悕瀛楁璁剧疆涓哄彲缂栬緫 + let isEDIT = this.currentAction == this.const.EDIT; + this.editFormOptions.forEach(item => { + item.forEach(x => { + if (x.field == "UserName") { + x.disabled=isEDIT; + } + }) + //涓嶆槸鏂板缓锛屾�у埆榛樿鍊艰缃负鐢� + if (!isEDIT) { + this.editFormFields.Gender = "0"; + } + }) + } + + } +}; +export default extension; \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_User/Sys_UserGridHeader.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_User/Sys_UserGridHeader.vue" new file mode 100644 index 0000000..f6f59be --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/Sys_User/Sys_UserGridHeader.vue" @@ -0,0 +1,85 @@ +<template> + <div> + <vol-box + v-model="model" + :padding="30" + title="淇敼瀵嗙爜" + :width="500" + :height="250" + > + <el-alert type="success"> + <h3> + <span>甯愬彿锛歿{ row.userName }}</span> + <span>鐢ㄦ埛锛歿{ row.userTrueName }}</span> + </h3> + </el-alert> + <div> + <el-input + placeholder="璇疯緭鍏ュ瘑鐮�" + v-model="password" + size="large" + style="width: 100%; margin-top: 15px" + /> + </div> + <template #footer> + <el-button + type="primary" + @click="savePwd()" + >淇敼瀵嗙爜</el-button + > + <el-button + @click="model = false" + >鍏抽棴</el-button + > + </template> + </vol-box> + </div> +</template> +<script> +import { defineComponent, defineAsyncComponent } from "vue"; +export default defineComponent({ + components: { + VolBox: defineAsyncComponent(() => import("@/components/basic/VolBox.vue")) + }, + data() { + return { + row: {}, + password: "", + model: false, + }; + }, + methods: { + open(row) { + this.password = ""; + this.row = row; + this.model = true; + }, + savePwd() { + if (!this.password) return this.$Message.error("璇疯緭瀵嗙爜"); + if (this.password.length < 6) + return this.$Message.error("瀵嗙爜闀垮害鑷冲皯6浣�"); + let url = + "/api/user/modifyUserPwd?password=" + + this.password + + "&userName=" + + this.row.UserName; + this.http.post(url, {}, true).then((x) => { + if (!x.status) { + return this.$message.error(x.message); + } + this.model = false; + this.$Message.success(x.message); + }); + }, + }, + created() {}, +}) +</script> +<style lang="less" scoped> +h3 { + font-weight: 500; + > span:last-child { + margin-left: 30px; + } +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/system/Sys_Department.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/system/Sys_Department.js" new file mode 100644 index 0000000..5c19061 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/system/system/Sys_Department.js" @@ -0,0 +1,152 @@ +/***************************************************************************************** +** Author:jxx 2022 +** QQ:283591387 +**瀹屾暣鏂囨。瑙侊細http://v2.volcore.xyz/document/api 銆愪唬鐮佺敓鎴愰〉闈iewGrid銆� +**甯哥敤绀轰緥瑙侊細http://v2.volcore.xyz/document/vueDev +**鍚庡彴鎿嶄綔瑙侊細http://v2.volcore.xyz/document/netCoreDev +*****************************************************************************************/ +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { //妗嗘灦鍒濆鍖栭厤缃墠锛� + this.rowKey = "DepartmentId"; + }, + loadTreeChildren(tree, treeNode, resolve) { //鍔犺浇瀛愯妭鐐� + let url = `api/Sys_Department/getTreeTableChildrenData?departmentId=${tree.DepartmentId}`; + this.http.post(url, {}).then(result => { + resolve(result.rows) + }) + }, + /***鍔犺浇鍚庡彴鏁版嵁瑙丼ys_RoleController.cs鏂囦欢***/ + searchBefore(params) {//鍒ゆ柇鍔犺浇鏍硅妭鐐规垨瀛愯妭鐐� + //娌℃湁鏌ヨ鏉′欢锛岄粯璁ゆ煡璇㈣繑鍥炴墍鏈夋牴鑺傜偣鏁版嵁 + if (!params.wheres.length) { + params.value = 1; + } + return true; + }, + onInited() { + let hasUpdate, hasDel, hasAdd; + this.buttons.forEach((x) => { + if (x.value == 'Update') { + x.hidden = true; + hasUpdate = true; + } else if (x.value == 'Delete') { + hasDel = true; + x.hidden = true;//闅愯棌鎸夐挳 + } + else if (x.value == 'Add') { + x.type="primary"; + hasAdd = true; + } + }); + if (!(hasUpdate || hasDel || hasAdd)) { + return; + } + this.columns.push({ + title: '鎿嶄綔', + field: '鎿嶄綔', + width: 80, + fixed: 'right', + align: 'center', + render: (h, { row, column, index }) => { + return ( + <div> + <el-button + onClick={($e) => { + this.addBtnClick(row) + }} + type="primary" + link + v-show={hasAdd} + icon="Plus" + > + </el-button> + <el-button + onClick={($e) => { + this.edit(row); + }} + type="success" + link + v-show={hasUpdate} + icon="Edit" + > + </el-button> + <el-tooltip + class="box-item" + effect="dark" + content="鍒犻櫎" + placement="top" + > + <el-button + link + onClick={($e) => { + this.del(row); + }} + v-show={hasDel} + type="danger" + icon="Delete" + > + </el-button> + </el-tooltip> + </div> + ); + } + }); + }, + addBtnClick(row) { + //杩欓噷鏄姩鎬乤ddCurrnetRow灞炴�ц褰曞綋鍓嶇偣鍑荤殑琛屾暟鎹�,涓嬮潰modelOpenAfter璁剧疆榛樿鍊� + this.addCurrnetRow = row; + this.add(); + }, + addAfter() {//娣诲姞鍚庡埛鏂板瓧鍏� + this.initDicKeys(); + return true; + }, + updateAfter() { + this.initDicKeys(); + return true; + }, + delAfter(result) {//鏌ヨ鐣岄潰鐨勮〃鍒犻櫎鍚� + this.initDicKeys(); + return true; + }, + modelOpenAfter(row) { + //鐐瑰嚮琛屼笂鐨勬坊鍔犳寜閽簨浠� + if (this.addCurrnetRow) { + + //鑾峰彇褰撳墠缁勭粐鏋勬灦鐨勬墍鏈夌埗绾d,鐢ㄤ簬璁剧疆鏂板缓鏃剁埗绾d鐨勯粯璁ゅ�� + + //鑾峰彇鏁版嵁鏁版嵁婧� + let data = []; + this.editFormOptions.forEach(options => { + options.forEach(option => { + if (option.field == 'ParentId') { + data = option.orginData; + } + }) + }) + let parentIds = this.base.getTreeAllParent(this.addCurrnetRow.DepartmentId, data).map(x => { return x.id }); + //璁剧疆缂栬緫琛ㄥ崟涓婄骇缁勭粐鐨勯粯璁ゅ�� + this.editFormFields.ParentId = parentIds; + this.addCurrnetRow = null; + + } + } + } +}; +export default extension; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/taskinfo/task.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/taskinfo/task.js" new file mode 100644 index 0000000..4e7fe7d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/taskinfo/task.js" @@ -0,0 +1,96 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + let TaskHandCancelBtn = this.buttons.find(x => x.value == 'TaskHandCancel'); + if (TaskHandCancelBtn) { + TaskHandCancelBtn.onClick = function () { + let rows = this.$refs.table.getSelected(); + if (rows.length == 0) return this.$error("璇烽�夋嫨鏁版嵁!"); + if (rows.length > 1) return this.$error("璇烽�夋嫨涓�鏉℃暟鎹�!"); + var param = rows[0].taskNum; + this.http + .post("api/Task/TaskCancel?taskNum="+param, "鏁版嵁澶勭悊涓�...") + .then((x) => { + if (x.status) { + this.$Message.success('浠诲姟鍙栨秷鎴愬姛.'); + this.refresh(); + } else { + return this.$error(x.message); + } + }); + } + } + let TaskHandCompletedBtn = this.buttons.find(x => x.value == 'TaskHandCompleted'); + if (TaskHandCompletedBtn) { + TaskHandCompletedBtn.onClick = function () { + let rows = this.$refs.table.getSelected(); + if (rows.length == 0) return this.$error("璇烽�夋嫨鏁版嵁!"); + if (rows.length > 1) return this.$error("璇烽�夋嫨涓�鏉℃暟鎹�!"); + var param = rows[0].taskNum; + this.http + .post("api/Task/TaskCompleted?taskNum="+param, "鏁版嵁澶勭悊涓�...") + .then((x) => { + if (x.status) { + this.$Message.success('浠诲姟鎵嬪姩瀹屾垚'); + this.refresh(); + } else { + return this.$error(x.message); + } + }); + } + } + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/taskinfo/task_hty.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/taskinfo/task_hty.js" new file mode 100644 index 0000000..24e1d94 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/extension/taskinfo/task_hty.js" @@ -0,0 +1,58 @@ + +//姝s鏂囦欢鏄敤鏉ヨ嚜瀹氫箟鎵╁睍涓氬姟浠g爜锛屽彲浠ユ墿灞曚竴浜涜嚜瀹氫箟椤甸潰鎴栬�呴噸鏂伴厤缃敓鎴愮殑浠g爜 + +let extension = { + components: { + //鏌ヨ鐣岄潰鎵╁睍缁勪欢 + gridHeader: '', + gridBody: '', + gridFooter: '', + //鏂板缓銆佺紪杈戝脊鍑烘鎵╁睍缁勪欢 + modelHeader: '', + modelBody: '', + modelFooter: '' + }, + tableAction: '', //鎸囧畾鏌愬紶琛ㄧ殑鏉冮檺(杩欓噷濉啓琛ㄥ悕,榛樿涓嶇敤濉啓) + buttons: { view: [], box: [], detail: [] }, //鎵╁睍鐨勬寜閽� + methods: { + //涓嬮潰杩欎簺鏂规硶鍙互淇濈暀涔熷彲浠ュ垹闄� + onInit() { + }, + onInited() { + //妗嗘灦鍒濆鍖栭厤缃悗 + //濡傛灉瑕侀厤缃槑缁嗚〃,鍦ㄦ鏂规硶鎿嶄綔 + //this.detailOptions.columns.forEach(column=>{ }); + }, + searchBefore(param) { + //鐣岄潰鏌ヨ鍓�,鍙互缁檖aram.wheres娣诲姞鏌ヨ鍙傛暟 + //杩斿洖false锛屽垯涓嶄細鎵ц鏌ヨ + return true; + }, + searchAfter(result) { + //鏌ヨ鍚庯紝result杩斿洖鐨勬煡璇㈡暟鎹�,鍙互鍦ㄦ樉绀哄埌琛ㄦ牸鍓嶅鐞嗚〃鏍肩殑鍊� + return true; + }, + addBefore(formData) { + //鏂板缓淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛紝鍙互缁欑粰琛ㄥ崟璁剧疆鍊硷紝鑷繁杈撳嚭鐪媐ormData鐨勫�� + return true; + }, + updateBefore(formData) { + //缂栬緫淇濆瓨鍓峟ormData涓哄璞★紝鍖呮嫭鏄庣粏琛ㄣ�佸垹闄よ鐨処d + return true; + }, + rowClick({ row, column, event }) { + //鏌ヨ鐣岄潰鐐瑰嚮琛屼簨浠� + this.$refs.table.$refs.table.toggleRowSelection(row); //鍗曞嚮琛屾椂閫変腑褰撳墠琛�; + }, + modelOpenAfter(row) { + //鐐瑰嚮缂栬緫銆佹柊寤烘寜閽脊鍑烘鍚庯紝鍙互鍦ㄦ澶勫啓閫昏緫锛屽锛屼粠鍚庡彴鑾峰彇鏁版嵁 + //(1)鍒ゆ柇鏄紪杈戣繕鏄柊寤烘搷浣滐細 this.currentAction=='Add'; + //(2)缁欏脊鍑烘璁剧疆榛樿鍊� + //(3)this.editFormFields.瀛楁='xxx'; + //濡傛灉闇�瑕佺粰涓嬫媺妗嗚缃粯璁ゅ�硷紝璇烽亶鍘唗his.editFormOptions鎵惧埌瀛楁閰嶇疆瀵瑰簲data灞炴�х殑key鍊� + //鐪嬩笉鎳傚氨鎶婅緭鍑虹湅锛歝onsole.log(this.editFormOptions) + } + } + }; + export default extension; + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/main.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/main.js" new file mode 100644 index 0000000..40c4c4f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/main.js" @@ -0,0 +1,63 @@ +import { createApp } from 'vue' +import App from './App.vue' +import router from './router' +import store from './store' +import ElementPlus from 'element-plus'; +// import 'element-plus/lib/theme-chalk/index.css'; +import 'element-plus/dist/index.css' +import './assets/element-icon/icon.css' +import base from './uitils/common' +import http from './api/http' +// import 'dayjs/locale/zh-cn' +// import locale from 'element-plus/lib/locale/lang/zh-cn' +import * as ElementPlusIconsVue from '@element-plus/icons-vue' + + + +import permission from './api/permission' +import viewgird from './components/basic/ViewGrid'; +const app = createApp(App); +for (const [key, component] of Object.entries(ElementPlusIconsVue)) { + app.component(key, component) +} +app.config.globalProperties.base = base; +app.config.globalProperties.http = http; +app.config.globalProperties.$tabs = {}; +app.config.globalProperties.permission = permission; +app.config.globalProperties.$global = { + signalR: false, //鏄惁寮�鍚痵ignalR + table: { + //vol-table甯︽暟鎹簮鐨勫崟鍏冩牸鏄惁鍚敤tag鏍囩(涓嬫媺妗嗙瓑鍗曞厓鏍间互tag鏍囩鏄剧ず) + useTag: true + }, + audit: { //瀹℃牳閫夐」 + data: [ + { text: '閫氳繃', value: 1 }, + { text: '鎷掔粷', value: 3 }, + { text: '椹冲洖', value: 4 } + ], + status:[0,2] //瀹℃牳涓殑鏁版嵁 + // 寰呭鏍� = 0, + // 瀹℃牳閫氳繃 = 1, + // 瀹℃牳涓� = 2, + // 瀹℃牳鏈�氳繃 = 3, + // 椹冲洖 = 4 + } +} +//2023.03.13锛� +//淇敼瑙侊細volupload.vue锛屽悗鍙癆liOSSController.cs锛岄樋閲屼簯OSS閰嶇疆.doc +window.oss = { + ali: { //闃块噷浜� + use: false,//浣跨敤闃块噷浜戜笂浼犳枃浠� + //闃块噷缂╃暐鍥惧帇缂╁ぇ灏� + //.aliyuncs.com + small: "?x-oss-process=image/resize,m_lfit,w_200" + } +} +app.use(store) + .use(ElementPlus, { size: 'default' }) + .use(router) + .use(viewgird) + .mount('#app'); +app.config.globalProperties.$Message = app.config.globalProperties.$message; + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/charts.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/charts.js" new file mode 100644 index 0000000..55cac54 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/charts.js" @@ -0,0 +1,17 @@ +let charts=[ + { + path: '/chart', + name: 'chart', + component: () => import('@/views/charts/chart.vue') + }, + { + path: '/formChart', + name: 'formChart', + component: () => import('@/views/charts/formChart.vue') + }, + { + path: '/flex', + name: 'flex', + component: () => import('@/views/charts/flex.vue') + }] +export default charts diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/index.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/index.js" new file mode 100644 index 0000000..febef0c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/index.js" @@ -0,0 +1,82 @@ +import { createRouter, createWebHistory, createWebHashHistory } from 'vue-router' +import viewgird from './viewGird' +import store from '../store/index' +import redirect from './redirect' +import charts from './charts' +const routes = [ + { + path: '/', + name: 'Index', + component: () => import('@/views/Index'), + redirect: '/home', + children: [ + ...viewgird, + ...redirect, + ...charts, + { + path: '/home', + name: 'home', + component: () => import('@/views/Home.vue') + }, { + path: '/UserInfo', + name: 'UserInfo', + component: () => import('@/views/system/UserInfo.vue') + }, + { + path: '/sysMenu', + name: 'sysMenu', + component: () => import('@/views/system/Sys_Menu.vue') + } + ] + }, + { + path: '/login', + name: 'login', + component: () => import('@/views/Login.vue'), + meta:{ + anonymous:true + } + }, + { + path: '/bigdata', + name: 'bigdata', + component: () => import('@/views/charts/bigdata.vue'), + meta: { + keepAlive: false + } + } +] + +const router = createRouter({ + history: createWebHashHistory(), //createWebHistory(process.env.BASE_URL), + routes +}) + + +router.beforeEach((to, from, next) => { + if (to.matched.length == 0) return next({ path: '/404' }); + //2020.06.03澧炲姞璺敱鍒囨崲鏃跺姞杞芥彁绀� + store.dispatch("onLoading", true); + if ((to.hasOwnProperty('meta') && to.meta.anonymous) || store.getters.isLogin() || to.path == '/login') { + return next(); + } + + next({ path: '/login', query: { redirect: Math.random() } }); +}) +router.afterEach((to, from) => { + store.dispatch("onLoading", false); +}) +router.onError((error) => { + // const targetPath = router.currentRoute.value.matched; + try { + console.log(error.message); + if (process.env.NODE_ENV == 'development') { + alert(error.message) + } + localStorage.setItem("route_error", error.message) + } catch (e) { + + } + window.location.href = '/' +}); +export default router diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/redirect.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/redirect.js" new file mode 100644 index 0000000..144beb8 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/redirect.js" @@ -0,0 +1,22 @@ + +let redirect = [{ + path: '/404', + name: '404', + component: () => import('@/components/redirect/404'), + meta:{ + anonymous:true + } +}, { + path: '/401', + name: '401', + component: () => import('@/components/redirect/401') +}, { + path: '/coding', + name: 'coding', + component: () => import('@/components/redirect/coding') +}, { + path: '/message', + name: 'message', + component: () => import('@/components/redirect/Message.vue') +}] +export default redirect; \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/viewGird.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/viewGird.js" new file mode 100644 index 0000000..8bc32ac --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/router/viewGird.js" @@ -0,0 +1,122 @@ + +let viewgird = [ + { + path: '/Sys_Log', + name: 'sys_Log', + component: () => import('@/views/system/Sys_Log.vue') + }, + { + path: '/Sys_User', + name: 'Sys_User', + component: () => import('@/views/system/Sys_User.vue') + }, + { + path: '/permission', + name: 'permission', + component: () => import('@/views/system/Permission.vue') + }, + { + path: '/permissionPDA', + name: 'permissionPDA', + component: () => import('@/views/system/PermissionPDA.vue') + }, + { + path: '/Sys_Dictionary', + name: 'Sys_Dictionary', + component: () => import('@/views/system/Sys_Dictionary.vue') + }, + { + path: '/Sys_Role', + name: 'Sys_Role', + component: () => import('@/views/system/Sys_Role.vue') + }, { + path: '/Sys_Role1', + name: 'Sys_Role1', + component: () => import('@/views/system/Sys_Role1.vue') + }, { + path: '/Sys_DictionaryList', + name: 'Sys_DictionaryList', + component: () => import('@/views/system/Sys_DictionaryList.vue') + }, { + path: '/areaInfo', + name: 'areaInfo', + component: () => import('@/views/basic/areaInfo.vue') + }, + { + path: '/areaRouter', + name: 'areaRouter', + component: () => import('@/views/basic/areaRouter.vue') + }, { + path: '/locationInfo', + name: 'locationInfo', + component: () => import('@/views/basic/locationInfo.vue') + }, { + path: '/materielInfo', + name: 'materielInfo', + component: () => import('@/views/basic/materielInfo.vue') + }, + { + path: '/cachePoint', + name: 'cachePoint', + component: () => import('@/views/basic/cachePoint.vue') + }, + { + path: '/roadwayInfo', + name: 'roadwayInfo', + component: () => import('@/views/basic/roadwayInfo.vue') + }, { + path: '/warehouse', + name: 'warehouse', + component: () => import('@/views/basic/warehouse.vue') + }, { + path: '/inboundOrder', + name: 'inboundOrder', + component: () => import('@/views/inbound/inboundOrder.vue') + }, { + path: '/inboundOrderDetail', + name: 'inboundOrderDetail', + component: () => import('@/views/inbound/inboundOrderDetail.vue') + }, { + path: '/outboundOrder', + name: 'outboundOrder', + component: () => import('@/views/outbound/outboundOrder.vue') + }, { + path: '/outboundOrderDetail', + name: 'outboundOrderDetail', + component: () => import('@/views/outbound/outboundOrderDetail.vue') + }, { + path: '/stockInfo', + name: 'stockInfo', + component: () => import('@/views/stock/stockInfo.vue') + }, { + path: '/stockInfoDetail', + name: 'stockInfoDetail', + component: () => import('@/views/stock/stockInfoDetail.vue') + }, { + path: '/task', + name: 'task', + component: () => import('@/views/taskinfo/task.vue') + }, + { + path: '/task_hty', + name: 'task_hty', + component: () => import('@/views/taskinfo/task_hty.vue') + },{ + path: '/stockView', + name: 'stockView', + component: () => import('@/views/stock/stockView.vue') + },{ + path: '/StockQuantityChangeRecord', + name: 'StockQuantityChangeRecord', + component: () => import('@/views/record/stockQuantityChangeRecord.vue') + },{ + path: '/locationStatusChangeRecord', + name: 'locationStatusChangeRecord', + component: () => import('@/views/record/locationStatusChangeRecord.vue') + },{ + path: '/receiveOrder', + name: 'receiveOrder', + component: () => import('@/views/inbound/receiveOrder.vue') + }] + +export default viewgird diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/store/index.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/store/index.js" new file mode 100644 index 0000000..5e02795 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/store/index.js" @@ -0,0 +1,94 @@ +import { createStore } from 'vuex' +const keys = { USER: 'user' } +function getUserInfo(state) { + if (state.userInfo) return state.userInfo; + let userInfo = localStorage.getItem(keys.USER); + if (userInfo) { + state.userInfo = JSON.parse(userInfo); + } + return state.userInfo; +} +export default createStore({ + state: { + data: {}, + permission: [], + isLoading: false,//2020.06.03澧炲姞璺敱鍒囨崲鏃跺姞杞芥彁绀� + userInfo: null, + websocke: null,//websocket + // wcsState: true//wcs鏈嶅姟鐘舵�� + }, + mutations: { + setPermission(state, data) { //璋冪敤鏂瑰紡 this.$store.commit('setPermission', data) + if (!data || typeof data != 'object') return; + if (data instanceof Array) { + state.permission.push(...data); + } else { + state.permission = data; + } + }, setUserInfo(state, data) { + state.userInfo = data; + localStorage.setItem(keys.USER, JSON.stringify(data)); + }, + clearUserInfo(state) { + state.permission = []; + state.userInfo = null; + localStorage.removeItem(keys.USER); + }, + test(state) { + return 113344; + }, + updateLoadingState(state, flag) { + state.isLoading = flag + }, + setWebsocket(state, data) { + state.websocke = data; + } + }, getters: { + getPermission: (state) => (path) => { //璋冪敤鏂瑰紡 store.getters.getPermission('sys_User') + if (!path) return state.permission; + return state.permission.find(x => x.path == path); + }, + getUserInfo: (state) => () => { + getUserInfo(state); + return state.userInfo; + }, getUserName: (state) => () => { + getUserInfo(state); + if (state.userInfo) { + return state.userInfo.userName; + } + return '鏈幏鍙栧埌鐧婚檰淇℃伅'; + }, + getToken: (state) => () => { + getUserInfo(state); + if (state.userInfo) { + return 'Bearer ' + state.userInfo.token; + } + return ''; + }, + isLogin: (state) => () => { + if (getUserInfo(state)) { + return true; + } + return false; + }, + isLoading: (state) => () => { + return state.isLoading; + }, + data: (state) => () => { + return state.data; + }, + getData: (state) => () => { + return state.data; + }, + }, actions: { + setPermission(context, data) { + context.commit('setPermission', data); //璋冪敤鏂瑰紡 store.dispatch('push') + }, + toDo(context) { + return context.Store.m; + }, + onLoading(context, flag) { + context.commit("updateLoadingState", flag); + } + } +}) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/uitils/common.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/uitils/common.js" new file mode 100644 index 0000000..a745d8d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/uitils/common.js" @@ -0,0 +1,344 @@ +let base = { + addDays(date, days) { + //缁欐寚瀹氭棩鏈熷鍔犲ぉ鏁� + if (!days) { + return date; + } + let dateArr = date.split(' '); + date = new Date(new Date(date).setDate(new Date(date).getDate() + days)); + var year = date.getFullYear(); + var month = date.getMonth() + 1; + if (month < 10) { + month = '0' + month; + } + var day = date.getDate(); + if (day < 10) { + day = '0' + day; + } + date = year + '-' + month + '-' + day; + if (dateArr.length == 1) { + return date; + } + return date + ' ' + dateArr[1]; + }, + //鑾峰彇褰撳墠鏃堕棿锛宼ime鏄惁甯︽椂鍒嗙 + getDate(time) { + let date = new Date(); + let year = date.getFullYear(); + let month = date.getMonth() + 1; + let day = date.getDate(); + + let datetime = + year + + '-' + + (month < 10 ? '0' + month : month) + + '-' + + (day < 10 ? '0' + day : day); + + if (!time) { + return datetime; + } + + let hour = date.getHours(); + let minutes = date.getMinutes(); + let second = date.getSeconds(); + + return ( + datetime + + '' + + ' ' + + (hour < 10 ? '0' + hour : hour) + + ':' + + (minutes < 10 ? '0' + minutes : minutes) + + ':' + + (second < 10 ? '0' + second : second) + ); + }, + isPhone(val) { + return /^[1][3,4,5,6,7,8,9][0-9]{9}$/.test(val); + }, + isDecimal(val) { + return /(^[\-0-9][0-9]*(.[0-9]+)?)$/.test(val); + }, + isNumber(val) { + return /(^[\-0-9][0-9]*([0-9]+)?)$/.test(val); + }, + isMail(val) { + return /^(\w-*\.*)+@(\w-?)+(\.\w{2,})+$/.test(val); + }, + isUrl(url) { + return this.checkUrl(url); + }, + checkUrl(url) { + // url= 鍗忚://(ftp鐨勭櫥褰曚俊鎭�)[IP|鍩熷悕](:绔彛鍙�)(/鎴�?璇锋眰鍙傛暟) + var strRegex = + '^((https|http|ftp)://)?' + // (https鎴杊ttp鎴杅tp):// 鍙湁鍙棤 + "(([\\w_!~*'()\\.&=+$%-]+: )?[\\w_!~*'()\\.&=+$%-]+@)?" + // ftp鐨剈ser@ 鍙湁鍙棤 + '(([0-9]{1,3}\\.){3}[0-9]{1,3}' + // IP褰㈠紡鐨刄RL- 3浣嶆暟瀛�.3浣嶆暟瀛�.3浣嶆暟瀛�.3浣嶆暟瀛� + '|' + // 鍏佽IP鍜孌OMAIN锛堝煙鍚嶏級 + '(localhost)|' + // 鍖归厤localhost + "([\\w_!~*'()-]+\\.)*" + // 鍩熷悕- 鑷冲皯涓�涓猍鑻辨枃鎴栨暟瀛梍!~*\'()-]鍔犱笂. + '\\w+\\.' + // 涓�绾у煙鍚� -鑻辨枃鎴栨暟瀛� 鍔犱笂. + '[a-zA-Z]{1,6})' + // 椤剁骇鍩熷悕- 1-6浣嶈嫳鏂� + '(:[0-9]{1,5})?' + // 绔彛- :80 ,1-5浣嶆暟瀛� + '((/?)|' + // url鏃犲弬鏁扮粨灏� - 鏂滄潌鎴栬繖娌℃湁 + "(/[\\w_!~*'()\\.;?:@&=+$,%#-]+)+/?)$"; // 璇锋眰鍙傛暟缁撳熬- 鑻辨枃鎴栨暟瀛楀拰[]鍐呯殑鍚勭瀛楃 + var re = new RegExp(strRegex, 'i'); // i涓嶅尯鍒嗗ぇ灏忓啓 + // 灏唘rl鍋歶ri杞爜鍚庡啀鍖归厤锛岃В闄よ姹傚弬鏁颁腑鐨勪腑鏂囧拰绌哄瓧绗﹀奖鍝� + if (re.test(encodeURI(url))) { + return true; + } + return false; + }, + matchUrlIp(url, ip) { + // url浣跨敤鏄惁浣跨敤鐨勫綋鍓峣p + if (!url || !ip) { + return false; + } + return url.indexOf(ip.replace('https://', '').replace('http://', '')) >= 0; + }, + getImgSrc(src, httpUrl) { + if (this.isUrl(src)) { + return src; + } + if (httpUrl) { + return httpUrl + src; + } + return src; + }, + previewImg(src, httpUrl) { + // 鍥剧墖棰勮锛岀洰鍓嶅彧鏀寔鍗曞浘鐗囬瑙� + if (src && !this.isUrl(src) && httpUrl) { + if ( + src.substr(0, 1) == '/' && + httpUrl.substr(httpUrl.length - 1, 1) == '/' + ) { + src = src.substr(1); + } + src = httpUrl + src; + } + let id = 'vol-preview'; + let $div = document.getElementById(id); + if (!$div) { + $div = document.createElement('div'); + $div.setAttribute('id', 'vol-preview'); + let $mask = document.createElement('div'); + $mask.style.position = 'absolute'; + $mask.style.width = '100%'; + $mask.style.height = '100%'; + $mask.style.background = 'black'; + $mask.style.opacity = '0.6'; + $div.appendChild($mask); + $div.style.position = 'fixed'; + $div.style.width = '100%'; + $div.style.height = '100%'; + // $div.style.overflow = "scroll"; + $div.style.top = 0; + $div.style['z-index'] = 9999999; + let $img = document.createElement('img'); + $img.setAttribute('class', 'vol-preview-img'); + $img.style.position = 'absolute'; + $img.style.top = '50%'; + $img.style.left = '50%'; + $img.style['max-width'] = '90%'; + $img.style['max-height'] = '90%'; + $img.style.transform = 'translate(-50%,-50%)'; + // $img.src = src; + $img.setAttribute('src', src); + $div.appendChild($img); + $div.addEventListener('click', function() { + this.style.display = 'none'; + }); + document.body.appendChild($div); + return; + } + let $img1 = document.body + .appendChild($div) + .querySelector('.vol-preview-img'); + // img.src = src; + $img1.setAttribute('src', src); + $div.style.display = 'block'; + }, + // 涓嬭浇鏂囦欢 $element 鏍囩, url瀹屾暣url, fileName 鏂囦欢鍚�, header 浠ey/value浼犲�� + // backGroundUrl 鍚庡彴url锛屽鏋滃悗鍙皍rl鐩存帴浠庡悗鍙颁笅杞斤紝鍏朵粬鍏ㄩ儴閫氳繃鐐瑰嚮a鏍囩涓嬭浇 + dowloadFile(url, fileName, header, backGroundUrl) { + if (!url) return alert('姝ゆ枃浠舵病鏈塽rl涓嶈兘涓嬭浇'); + if (!this.isUrl(url)) { + url = backGroundUrl + url; + } + window.open(url); + }, + downloadImg(data) { + if (!data.url || !data.callback || typeof data.callback !== 'function') { + return; + } + // url, backGroundUrl, header, callback + if ( + this.isUrl(data.url) && + !this.matchUrlIp(data.url, data.backGroundUrl) + ) { + return data.url; + } + // 閫氳繃鍚庡彴api鏈嶅姟鍣ㄤ笅杞� + if (!this.isUrl(data.url)) { + if (!this.isUrl(data.backGroundUrl + data.url)) { + return; + } + data.url = data.backGroundUrl + data.url; + } + var xmlResquest = new XMLHttpRequest(); + xmlResquest.open('get', data.url, true); + xmlResquest.responseType = 'blob'; + xmlResquest.setRequestHeader('Content-Type', 'application/json'); + if (data.header && typeof data.header === 'object') { + for (const key in data.header) { + xmlResquest.setRequestHeader(key, data.header[key]); + } + } + xmlResquest.onload = function() { + if (this.status == 200) { + var blob = this.response; + callback(window.URL.createObjectURL(blob)); + } + }; + xmlResquest.send(); + }, + // 2020.06.01澧炲姞閫氱敤鏂规硶锛屽皢鏅�氬璞¤浆鎹负tree缁撴瀯 + // data鏁版嵁鏍煎紡[ + // { name: 'tree1', id: 1, parentId: 0 }, + // { name: 'tree2', id: 2, parentId: 0 }] + + // 1銆乮d涓巔arentId杩欎袱涓瓧娈靛繀椤绘湁 + // 2銆佹爲褰ree闇�瑕佹敞鎰廔d涓巔arentId寰幆渚濊禆鐨勯棶棰� + // 3銆乧allback姣忔鐢熸垚涓�鏂扮殑鑺傜偣鐨勬椂鍥炶皟鐨勬柟娉� + + convertTree(data, callback) { + var treeIds = []; + var root_data = []; + if (data.length>100) { + data = JSON.parse(JSON.stringify(data)); + } + data.forEach((x) => { + // if (!x.children) { + // x.children = [] + // } + if ( + !x.hidden && + x.id !== undefined && + x.id !== x.parentId && + !data.some((s) => { + return x.parentId == s.id; + }) + ) { + x.isRoot = true; + callback && callback(x, data, true, treeIds); + root_data.push(x); + getTree(x.id, x, data, callback, treeIds); + } else { + callback && callback(x, data, true, treeIds); + } + }); + var exceptionNodes = data.filter((f) => { + return treeIds.indexOf(f.id) == -1 && !f.hidden; + }); + + root_data.push(...exceptionNodes); + return root_data; + }, + getTreeAllParent(id, data) { + // 鑾峰彇鏌愪釜鑺傜偣鐨勬墍鏈夌埗鑺傜偣淇℃伅2020.11.01 + var nodes = []; + if (!(data instanceof Array)) { + return nodes; + } + if (data.length>100) { + data = JSON.parse(JSON.stringify(data)); + } + data.forEach((x) => { + if (x.id === x.parentId) { + x.parentId = 0; + } else if (data.some((c) => c.parentId === x.id && c.id === x.parentId)) { + x.parentId = 0; + } + }); + + var _child = data.find((x) => { + return x.id === id; + }); + if (!_child) { + return []; + } + nodes.push(_child); + var _parentIds = [_child.parentId]; + for (let index = 0; index < _parentIds.length; index++) { + var _node = data.find((x) => { + return x.id === _parentIds[index] && x.id !== x.parentId; + }); + if (!_node) { + return nodes; + } + _parentIds.push(_node.parentId); + nodes.unshift(_node); + } + return nodes; + }, + //鑾峰彇鎵�鏈夎妭鐐圭殑瀛愯妭鐐� + // data鏁版嵁鏍煎紡[ + // { name: 'tree1', id: 1, parentId: 0 }, + // { name: 'tree2', id: 2, parentId: 0 }] + getTreeAllChildren(id, data) { + //閫掑綊鑾峰彇鏌愪釜鑺傜偣鐨勬墍鏈夊瓙鑺傜偣淇℃伅 + var nodes = []; + if (!(data instanceof Array)) { + return nodes; + } + if (data.length>100) { + data = JSON.parse(JSON.stringify(data)); + } + var _child = data.find((x) => { + return x.id === id; + }); + if (!_child) { + return []; + } + nodes.push(_child); + var _parentIds = [_child.id]; + for (let index = 0; index < _parentIds.length; index++) { + data.forEach((_node) => { + if ( + _node.parentId === _parentIds[index] && + _node.parentId !== _node.id + ) { + _parentIds.push(_node.id); + nodes.unshift(_node); + } + }); + } + return nodes; + }, + //鑾峰彇鎵�鏈夊瓙鑺傜偣鐨刬d + // data鏁版嵁鏍煎紡[ + // { name: 'tree1', id: 1, parentId: 0 }, + // { name: 'tree2', id: 2, parentId: 0 }] + getTreeAllChildrenId(id, data) { + return this.getTreeAllChildren(id, data).map((c) => { + return c.id; + }); + } +}; +export default base; + +// 2020.06.01澧炲姞閫氱敤鏂规硶锛屽皢鏅�氬璞¤浆鎹负tree缁撴瀯 +function getTree(id, node, data, callback, treeIds) { + if (treeIds.indexOf(id) == -1) { + treeIds.push(id); + } + data.forEach((x) => { + if (!x.hidden && x.parentId == id) { + if (!node.children) node.children = []; + callback && callback(x, node, false); + node.children.push(x); + getTree(x.id, x, data, callback, treeIds); + } + }); +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Home.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Home.vue" new file mode 100644 index 0000000..820437a --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Home.vue" @@ -0,0 +1,24 @@ +<template> + <div class="title"></div> +</template> + +<script> +import { ref, reactive } from 'vue' + +export default { + setup() { + return { + + } + } +} +</script> + +<style scoped> +.title { + line-height: 70vh; + text-align: center; + font-size: 28px; + color: orange; +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Index.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Index.vue" new file mode 100644 index 0000000..1bb1051 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Index.vue" @@ -0,0 +1,834 @@ +<template> + <div id="vol-container" :class="['vol-theme-' + theme]"> + <div class="vol-aside" :style="{ width: menuWidth + 'px' }"> + <div class="header" :style="{ width: menuWidth - 1 + 'px' }"> + <img v-show="!isCollapse" v-bind:src="logo" /> + <i + @click="toggleLeft" + class="collapse-menu" + :class="isCollapse ? 'el-icon-s-unfold' : 'el-icon-s-fold'" + /> + </div> + <div class="vol-menu"> + <el-scrollbar style="height: 100%"> + <VolMenu + :currentMenuId="currentMenuId" + :on-select="onSelect" + :enable="true" + :open-select="false" + :isCollapse="isCollapse" + :list="menuOptions" + ></VolMenu> + </el-scrollbar> + </div> + </div> + <div class="vol-container" :style="{ left: menuWidth - 1 + 'px' }"> + <div class="vol-header"> + <div class="project-name">WMS</div> + <div class="header-text"> + <div class="h-link"> + <a + href="javascript:void(0)" + @click="to(item)" + v-for="(item, index) in links.filter((c) => { + return !c.icon; + })" + :key="index" + > + <span v-if="!item.icon"> {{ item.text }}</span> + <i v-else :class="item.icon"></i> + </a> + </div> + </div> + <div class="header-info"> + <div class="h-link"> + <a + href="javascript:void(0)" + @click="to(item)" + v-for="(item, index) in links.filter((c) => { + return c.icon; + })" + :key="index" + > + <span v-if="!item.icon"> {{ item.text }}</span> + <i v-else :class="item.icon"></i> + </a> + </div> + <!--娑堟伅绠$悊--> + + <div class="h-link" @click="messageModel = true"> + <a + ><i class="el-icon-message-solid" + ><el-badge + :value="messageList.length" + :type="messageList.length > 0 ? 'danger' : 'success'" + class="item" + style="width: 10px" + ></el-badge></i + ></a> + </div> + <div> + <img class="user-header" :src="userImg" :onerror="errorImg" /> + </div> + <div class="user"> + <span>{{ userName }}</span> + <span id="index-date"></span> + </div> + <div class="settings"> + <i + style="font-size: 20px" + class="el-icon-s-tools" + @click="drawer_model = true" + /> + </div> + </div> + </div> + <div class="vol-path"> + <el-tabs + @tab-click="selectNav" + @tab-remove="removeNav" + @contextmenu.prevent="bindRightClickMenu(false)" + type="border-card" + class="header-navigation" + v-model="selectId" + :strtch="false" + > + <el-tab-pane + v-for="(item, navIndex) in navigation" + type="card" + :name="navIndex + ''" + :closable="navIndex > 0" + :key="navIndex" + :label="item.name" + > + <span style="display: none">{{ navIndex }}</span> + </el-tab-pane> + </el-tabs> + <!-- 鍙抽敭鑿滃崟 --> + <div v-show="contextMenuVisible"> + <ul + :style="{ left: menuLeft + 'px', top: menuTop + 'px' }" + class="contextMenu" + > + <li v-show="visibleItem.all"> + <el-button link @click="closeTabs()"> + <i class="el-icon-close"></i> + {{ + navigation.length == 2 ? "鍏抽棴鑿滃崟" : "鍏抽棴鎵�鏈�" + }}</el-button + > + </li> + <li v-show="visibleItem.left"> + <el-button link @click="closeTabs('left')" + ><i class="el-icon-back"></i>鍏抽棴宸﹁竟</el-button + > + </li> + <li v-show="visibleItem.right"> + <el-button link @click="closeTabs('right')"> + <i class="el-icon-right"></i>鍏抽棴鍙宠竟</el-button + > + </li> + <li v-show="visibleItem.other"> + <el-button link @click="closeTabs('other')" + ><i class="el-icon-right"></i>鍏抽棴鍏朵粬 + </el-button> + </li> + </ul> + </div> + </div> + <div class="vol-main" id="vol-main"> + <el-scrollbar style="height: 100%" v-if="permissionInited"> + <loading v-show="$store.getters.isLoading()"></loading> + <router-view v-slot="{ Component }"> + <keep-alive> + <component + :is="Component" + :key="$route.name" + v-if=" + !$route.meta || + ($route.meta && !$route.meta.hasOwnProperty('keepAlive')) + " + /> + </keep-alive> + <component + :is="Component" + :key="$route.name" + v-if="$route.meta && $route.meta.hasOwnProperty('keepAlive')" + /> + </router-view> + </el-scrollbar> + </div> + </div> + <el-drawer + title="閫夋嫨涓婚" + v-model="drawer_model" + direction="rtl" + destroy-on-close + > + <div class="theme-selector"> + <div + @click="changeTheme(item.name)" + class="item" + v-for="(item, index) in theme_color" + :key="index" + :style="{ background: item.color }" + > + <div + v-show="item.leftColor" + :style="{ background: item.leftColor }" + style="height: 100%; width: 20px" + class="t-left" + ></div> + <div class="t-right"></div> + </div> + </div> + </el-drawer> + + <el-drawer + title="娑堟伅鍒楄〃" + v-model="messageModel" + direction="rtl" + destroy-on-close + size="40%" + > + <Message :list="messageList"></Message> + </el-drawer> + </div> +</template> +<style lang="less" scoped> +@import "./index/index.less"; +</style> +<script> +import loading from "@/components/basic/RouterLoading"; +import VolMenu from "@/components/basic/VolElementMenu.vue"; +import Message from "./index/Message.vue"; +import MessageConfig from "./index/MessageConfig.js"; +var imgUrl = require("@/assets/imgs/wms_x.png"); +var $this; +var $interval; +var $indexDate; +import { + defineComponent, + reactive, + ref, + watch, + onMounted, + getCurrentInstance, + h +} from "vue"; +import { useRouter, useRoute } from "vue-router"; +import store from "../store/index"; +import http from "@/../src/api/http.js"; +import { ElNotification } from "element-plus"; +export default defineComponent({ + components: { + VolMenu, + loading, + Message, + }, + + data() { + return { + allTabs: true, + leftTabs: true, + rightTabs: true, + otherTabs: true, + menuLeft: 0, + menuTop: 0, + client: null, + // contextMenuVisible: false, // 鍙抽敭鍏抽棴鏄�/闅� + }; + }, + setup(props, context) { + let client = ref(null); + + // 鑾峰彇鍏ㄥ眬灞炴�у拰鏂规硶 + const { proxy } = getCurrentInstance(); + + // 鑿滃崟瀵艰埅榛樿瀹藉害 + const menuWidth = ref(200); + const contextMenuVisible = ref(false); + const isCollapse = ref(false); + const drawer_model = ref(false); + const messageModel = ref(false); + const theme_color = ref([ + { name: "blue", color: "rgb(45, 140, 240)" }, + { name: "blue2", color: "rgb(45, 140, 240)", leftColor: "#0068d6" }, + { name: "red", color: "rgb(237, 64, 20)" }, + { name: "red2", color: "rgb(237, 64, 20)", leftColor: "#a90000" }, + { name: "dark", color: "#272929" }, + { name: "orange", color: "#ff9900" }, + { name: "orange2", color: "#ff9900", leftColor: "rgb(232 141 5)" }, + { name: "green", color: "rgb(25, 190, 107)" }, + { name: "green2", color: "rgb(25, 190, 107)", leftColor: "#019e4f" }, + { name: "white", color: "#fff" }, + ]); + const links = ref([ + { text: "涓汉涓績", path: "/UserInfo", id: -1, icon: "el-icon-s-custom" }, + { + text: "瀹夊叏閫�鍑�", + path: "/login", + id: -4, + icon: "el-icon-switch-button", + }, + ]); + const errorImg = ref( + 'this.src="' + require("@/assets/imgs/error-img.png") + '"' + ); + const selectId = ref("1"); + // 銆愰椤点�戞爣绛惧簭鍙�(褰撳墠鍙抽敭閫変腑鐨勮彍鍗�) + const selectMenuIndex = ref("0"); + //2022.05.29澧炲姞tab閫夐」涓庤彍鍗曡仈鍔ㄥ姛鑳� + const currentMenuId = ref(0); + const userName = ref("--"); + const userInfo = ref({}); + const visibleItem = reactive({ + left: false, + right: false, + all: false, + other: false, + }); + const userImg = ref(""); + const navigation = reactive([ + { orderNo: "0", id: "1", name: "棣栭〉", path: "/home" }, + ]); + const logo = ref(imgUrl); + const theme = ref("blue2"); + const menuOptions = ref([]); + const permissionInited = ref(false); + const messageList = reactive([]); + let _config = getCurrentInstance().appContext.config.globalProperties; + let router = useRouter(); + const toggleLeft = () => { + isCollapse.value = !isCollapse.value; + menuWidth.value = isCollapse.value ? 63 : 200; + }; + //2021.08.28寮�鏀炬墜鍔ㄦ姌鍙犺彍鍗曟柟娉� + _config.menu = { + show() { + toggleLeft(); + }, + hide() { + toggleLeft(); + }, + }; + + const handleMessage = (e) => { + let data = JSON.parse(e.data); + messageList.push(data); + ElNotification({ + title: data.title, + message: h("i", { style: "color: teal" }, data.message), + }); + }; + + const createSocket = (url) => { + // 鍒涘缓WebSocket杩炴帴 + //"ws://127.0.0.1:9295/admin" + client = new WebSocket(url); + + client.onopen = function () { + client.onmessage = handleMessage; + store.commit("setWebsocket", client); + console.log("WebSocket 杩炴帴鎴愬姛"); + }; + + client.onclose = function () { + console.log("WebSocket 杩炴帴鍏抽棴"); + setTimeout(createSocket, 10000); + }; + + client.onerror = function () { + + }; + }; + + const changeTheme = (name) => { + if (theme.value != name) { + theme.value = name; + } + localStorage.setItem("vol3_theme", name); + }; + const to = (item) => { + /* 2020.07.31澧炲姞鎵嬪姩鎵撳紑tabs*/ + if (item.path == "#") { + window.open("https://github.com/cq-panda/Vue.NetCore"); + return; + } + if (item.path.indexOf("http") != -1) { + window.open(item.path); + return; + } + if (typeof item == "string" || item.path == "/login") { + if (item == "/login" || item.path == "/login") { + store.commit("clearUserInfo", ""); + window.location.href = "/"; + return; + } + router.push({ path: item }); + return; + } + if (item.path == "#") return; + open(item); + }; + const open = (item, useRoute) => { + /* 2020.07.31澧炲姞鎵嬪姩鎵撳紑tabs*/ + let _index = navigation.findIndex((x) => { + return x.path == item.path; + }); + if (_index == -1) { + navigation.push({ + // orderNo: String(navigation.length),// 搴忓彿 + id: item.id + "", + name: item.name || item.text || "鏃犳爣棰�", + path: item.path, + query: item.query, //2021.03.20淇鑷畾涔変簩娆℃墦寮�$tabs鏃跺弬鏁颁涪澶辩殑闂 + }); + //鏂版墦寮�鐨則ab绉昏嚦鏈�鍚庝竴涓�夐」 + selectId.value = navigation.length - 1 + ""; + } else { + selectId.value = _index + ""; + } + if (useRoute === undefined) { + //闈炴爣鍑嗚彍鍗曪紝璁板綍鏈�鍚庝竴娆¤烦杞殑椤甸潰锛岀敤浜庡埛鏂� + setItem(item); + router.push(item); + // this.$router.push(item); + } + currentMenuId.value = item.id * 1; + // tab鑿滃崟缁戝畾鍙抽敭浜嬩欢 + proxy.$nextTick(function (e) { + proxy.bindRightClickMenu(true); + }); + }; + const close = (path) => { + /* 2020.07.31澧炲姞鎵嬪姩鎵撳紑tabs*/ + let index = navigation.findIndex((x) => { + return x.path == path; + }); + if (index == -1) { + return _config.$Message.error("鏈壘鍒拌彍鍗�"); + } + removeNav(index); + }; + const setItem = (item) => { + /* 2020.07.31澧炲姞鎵嬪姩鎵撳紑tabs*/ + localStorage.setItem( + window.location.origin + "_tabs", + JSON.stringify(item) + ); + }; + const getItem = () => { + /* 2020.07.31澧炲姞鎵嬪姩鎵撳紑tabs*/ + let nav = localStorage.getItem(window.location.origin + "_tabs"); + return nav ? JSON.parse(nav) : null; + }; + const selectNav = (item) => { + //鍗囩骇element姝e紡鐗堜慨鏀� + selectId.value = item.props.name; + let _path = navigation[item.index].path; + currentMenuId.value = ( + menuOptions.value.find((c) => { + return c.path == _path; + }) || { id: 0 } + ).id; + + router.push({ + path: navigation[item.index].path, + query: navigation[item.index].query, + }); + }; + + const removeNav = (_index) => { + return new Promise(() => { + //鍏抽棴鐨勫綋鍓嶉」,璺宠浆鍒板墠涓�涓〉闈� + if (selectId.value == _index + "") { + console.log(navigation[_index - 1]); + setItem(navigation[_index - 1]); + router.push({ + path: navigation[_index - 1].path, + //2022.06.27淇tabs浜屾鍒囨崲鍚庡弬鏁颁涪澶辩殑闂 + query: navigation[_index - 1].query, + }); + navigation.splice(_index, 1); + selectId.value = selectId.value - 1 + ""; + return; + } + if (_index < selectId.value) { + selectId.value = selectId.value - 1 + ""; + } + navigation.splice(_index, 1); + currentMenuId.value = ( + menuOptions.value.find((c) => { + return c.path == navigation[selectId.value * 1].path; + }) || { id: 0 } + ).id; + }); + }; + + const getSelectMenuName = (id) => { + return menuOptions.value.find(function (x) { + return x.id == id; + }); + }; + const onSelect = (treeId) => { + /* 2020.07.31澧炲姞鎵嬪姩鎵撳紑tabs*/ + var item = getSelectMenuName(treeId); + open(item, false); + }; + + /** + * 鏄剧ず鍙抽敭鑿滃崟 + * @param {*} e 浜嬩欢瀵硅薄 + */ + const openTabsMenu = function (e) { + e.preventDefault(); // 闃叉榛樿鑿滃崟寮瑰嚭 + let tabId = e.target.id.split("-")[1] * 1; + + //璁板綍褰撳墠閫変腑鐨勮彍鍗昳ndex + selectMenuIndex.value = + document.getElementById("pane-" + tabId).children[0].textContent * 1; + //鍙湁棣栭〉鏃朵笉鏄剧ず + if (navigation.length == 1) { + return; + } + + //棣栭〉璁剧疆鏄剧ず鍏抽棴鍙宠竟鑿滃崟 + if (!selectMenuIndex.value) { + visibleItem.all = false; + visibleItem.right = true; + visibleItem.left = false; + visibleItem.other = false; + } else { + visibleItem.all = true; + //涓嶆槸鏈�鍚庝竴涓樉绀哄叧闂彸杈硅彍鍗� + visibleItem.right = selectMenuIndex.value != navigation.length - 1; + //鍙湁涓や釜鑿滃崟鏃朵笉鏄剧ず鍏抽棴宸﹁竟 + visibleItem.left = navigation.length != 2; + //鍙湁涓や釜鑿滃崟鏃朵笉鏄剧ず鍏抽棴鍏朵粬 + visibleItem.other = navigation.length != 2; + } + contextMenuVisible.value = true; + // 璁剧疆鍙抽敭鑿滃崟鏄剧ず鐨勪綅缃� + proxy.menuLeft = + e.target.getBoundingClientRect().left - (isCollapse.value ? 63 : 198); //-e.target.clientWidth + proxy.menuTop = 36; + }; + + /** + * 鍏抽棴鍙抽敭鑿滃崟 + */ + const closeTabsMenu = () => { + contextMenuVisible.value = false; + }; + const toHome = () => { + open({ + text: navigation[0].name, + path: navigation[0].path, + }); + }; + /** + * 鍏抽棴鍏跺畠鏍囩椤� + * @param {*} par 鍏抽棴绫诲瀷(left,right,other) + */ + const closeTabs = (value) => { + let _menuId = navigation[selectId.value * 1].id; + let currnetIndex = selectId.value * 1; // navigation.findIndex(c => { return c.id == selectId.value }); + switch (value) { + case "left": { + // 鍒犻櫎宸︿晶tab鏍囩 + navigation.splice(1, currnetIndex - 1); // 鍒犻櫎宸︿晶tab鏍囩 + break; + } + case "right": { + // 鍒犻櫎鍙充晶tab鏍囩 + if (selectMenuIndex.value == 0) { + navigation.splice(currnetIndex); // 鍒犻櫎鍙充晶tab鏍囩 + toHome(); + } else { + navigation.splice(currnetIndex + 1); // 鍒犻櫎鍙充晶tab鏍囩 + if (selectMenuIndex.value < currnetIndex) { + navigation.splice( + selectMenuIndex.value, + currnetIndex - selectMenuIndex.value + ); + } + } + break; + } + case "other": { + // 鍒犻櫎鍏朵粬鎵�鏈塼ab鏍囩 + navigation.splice(currnetIndex + 1); // 鍒犻櫎鍙充晶tab鏍囩(杩欓噷蹇呴』鎸夌収鍙斥啋宸﹂『搴忓垹闄�) + navigation.splice(1, currnetIndex - 1); // 鍒犻櫎宸︿晶tab鏍囩 + break; + } + default: { + //鍏抽棴鎵�鏈� + navigation.splice(1, navigation.length); + toHome(); + break; + } + } + selectId.value = + navigation.findIndex((c) => { + return c.id == _menuId; + }) + ""; + closeTabsMenu(); + }; + + watch( + () => contextMenuVisible.value, + (newVal, oldVal) => { + // 鐩戣 + if (newVal) { + document.body.addEventListener("click", closeTabsMenu); + } else { + document.body.removeEventListener("click", closeTabsMenu); + } + } + ); + + /** + * 绯荤粺鍒涘缓寮�濮� + */ + const created = () => { + let _theme = localStorage.getItem("vol3_theme"); + if (_theme) { + theme.value = _theme; + } + + let _userInfo = store.getters.getUserInfo(); + if (_userInfo) { + userName.value = _userInfo.userName; + if (_userInfo.img) { + userImg.value = _config.base.getImgSrc(_userInfo.img, http.ipAddress); + } + } + + createSocket("ws://127.0.0.1:9295/" + _userInfo.userName); + + Object.assign(_config.$tabs, { open: open, close: close }); + + http.get("api/Sys_Menu/getTreeMenu", {}, true).then((data) => { + data.push({ id: "1", name: "棣栭〉", url: "/home" }); // 涓轰簡鑾峰彇閫変腑id浣跨敤 + data.forEach((d) => { + d.path = (d.url || "").replace("/Manager", ""); + d.to = (d.url || "").replace("/Manager", ""); + if (!d.icon || d.icon.substring(0, 3) != "el-") { + d.icon = "el-icon-menu"; + } + }); + store.dispatch("setPermission", data); + menuOptions.value = data; + permissionInited.value = true; + + //寮�鍚秷鎭帹閫侊紙main.js涓缃槸鍚﹀紑鍚痵ignalR锛�2022.05.05 + if (_config.$global.signalR) { + MessageConfig(http, (result) => { + messageList.unshift(result); + // console.log(result) + }); + } + + //褰撳墠鍒锋柊鏄笉鏄椤� + if (router.currentRoute.value.path != navigation[0].path) { + //鏌ユ壘绯荤粺鑿滃崟 + let item = menuOptions.value.find((x) => { + return x.path == router.currentRoute.value.path; //this.$route.path; + }); + if (item) return onSelect(item.id); + //鏌ユ壘椤堕儴蹇嵎杩炴帴 + item = links.value.find((x) => { + return x.path == router.currentRoute.value.path; //this.$route.path; + }); + //鏌ユ壘鏈�鍚庝竴娆¤烦杞殑椤甸潰 + if (!item) { + item = getItem(); + } + if (item) { + return open(item, false); + } + } + selectId.value = "1"; + }); + }; + created(); + return { + menuWidth, + isCollapse, + drawer_model, + theme_color, + errorImg, + userInfo, + userName, + userImg, + selectId, + selectMenuIndex, + navigation, + links, + onSelect, + openTabsMenu, + selectNav, + getSelectMenuName, + removeNav, + logo, + theme, + menuOptions, + permissionInited, + changeTheme, + to, + toggleLeft, + messageModel, + messageList, + contextMenuVisible, + visibleItem, + closeTabsMenu, + closeTabs, + currentMenuId, + }; + }, + /** + * 鎸傝浇閽╁瓙鍑芥暟 + */ + mounted() { + let _date = showTime(); + $indexDate = document.getElementById("index-date"); + $indexDate.innerText = _date; + $interval = setInterval(function () { + $indexDate.innerText = showTime(); + }, 1000); + + this.bindRightClickMenu(true); + }, + + methods: { + /** + * 缁戝畾鍙抽敭浜嬩欢 + * @param {*} enable 鏄惁鍚敤鍙抽敭浜嬩欢[true:鍚敤;false:绂佺敤;] + * @param {*} $event 浜嬩欢 + */ + bindRightClickMenu(enable) { + if (!enable) return; + let that = this; + // 浣跨敤鍘熺敓js 涓哄崟涓猟om缁戝畾榧犳爣鍙冲嚮浜嬩欢 + that.$nextTick(() => { + let tab_top_dom = Object.assign( + [], + document.getElementsByClassName("el-tabs__item is-top") + ); + tab_top_dom.forEach((item, index) => { + item.oncontextmenu = that.openTabsMenu; + }); + }); + }, + }, + + /** + * 閿�姣侀挬瀛愬嚱鏁� + */ + destroyed() { + $this = null; + clearInterval($interval); + }, +}); +const week = new Array( + "鏄熸湡涓�", + "鏄熸湡浜�", + "鏄熸湡涓�", + "鏄熸湡鍥�", + "鏄熸湡浜�", + "鏄熸湡鍏�", + "鏄熸湡鏃�" +); +function showTime() { + let date = new Date(); + let year = date.getFullYear(); + let month = date.getMonth() + 1; + let day = date.getDate(); + let hour = date.getHours(); + let minutes = date.getMinutes(); + let second = date.getSeconds(); + + return ( + year + + "." + + (month < 10 ? "0" + month : month) + + "." + + (day < 10 ? "0" + day : day) + //202.08.08淇鏃ユ湡澶╂暟灏忎簬10鏃舵坊鍔�0 + "" + + " " + + (hour < 10 ? "0" + hour : hour) + + ":" + + (minutes < 10 ? "0" + minutes : minutes) + + ":" + + (second < 10 ? "0" + second : second) + + " " + //2020.08.30淇棣栭〉鏃ユ湡鏄熸湡澶╀笉鏄剧ず鐨勯棶棰� + (week[date.getDay() - 1] || week[6]) + ); +} +</script> + +<style lang="less" scoped> +.vol-container .vol-path ::v-deep(.el-tabs__content) { + padding: 0; +} + +.item { + margin-top: -20px; + margin-right: 40px; +} + +.contextMenu { + width: 120px; + margin: 0; + border: 1px solid #eaeaea; + background: #fff; + z-index: 30000; + position: absolute; + list-style-type: none; + padding: 5px 0; + border-radius: 4px; + font-size: 14px; + color: #333; + box-shadow: 2px 2px 3px 0 rgb(182 182 182 / 20%); + i, + button { + font-size: 14px !important; + } +} + +.contextMenu li { + margin: 0; + padding: 5px 17px; +} + +.contextMenu li:hover { + background: #fafafa; + cursor: pointer; +} + +.contextMenu li button { + color: #626060; + font-size: 14px; + letter-spacing: 1px; +} + +.el-tabs.el-tabs--top.el-tabs--border-card.header-navigation + > .el-tabs__header + .el-tabs__item:last-child, +.el-tabs--top.el-tabs--border-card.header-navigation + > .el-tabs__header + .el-tabs__item:nth-child(2) { + padding: 0; +} + +.header-navigation ::v-deep(.el-tabs__item.is-top) { + padding: 0 15px; +} +</style> +<style> +.horizontal-collapse-transition { + transition: 0s width ease-in-out, 0s padding-left ease-in-out, + 0s padding-right ease-in-out; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Login.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Login.vue" new file mode 100644 index 0000000..d303005 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/Login.vue" @@ -0,0 +1,408 @@ +<template> + <div class="login-container"> + <div class="project-name">WIDESEA_WMS</div> + <div class="login-form"> + <div class="form-user" @keypress="loginPress"> + <div class="login-text"> + <div> + <div>娆㈣繋鐧诲綍...</div> + <div class="login-line"></div> + </div> + <div style="flex: 1"></div> + </div> + <div class="login-text-small">WELCOME TO LOGIN</div> + <div class="item"> + <div class="input-icon el-icon-user"></div> + <input + type="text" + v-focus + v-model="userInfo.userName" + placeholder="璇疯緭鍏ヨ处鍙�" + /> + </div> + <div class="item"> + <div class="input-icon el-icon-lock"></div> + <input + type="password" + v-focus + v-model="userInfo.password" + placeholder="璇疯緭鍏ュ瘑鐮�" + /> + </div> + <div class="item"> + <div class="input-icon el-icon-mobile"></div> + + <input + v-focus + type="text" + v-model="userInfo.verificationCode" + placeholder="杈撳叆楠岃瘉鐮�" + /> + <div class="code" @click="getVierificationCode"> + <img v-show="codeImgSrc != ''" :src="codeImgSrc" /> + </div> + </div> + </div> + <div class="loging-btn"> + <el-button + size="large" + :loading="loading" + color="#3a6cd1" + :dark="true" + @click="login" + long + > + <span v-if="!loading">鐧诲綍</span> + <span v-else>姝e湪鐧诲綍...</span> + </el-button> + </div> + + <!-- 璐﹀彿淇℃伅 --> + <!-- <div class="account-info"> + <p>婕旂ず璐﹀彿锛歛dmin666 瀵嗙爜:123456</p> + <p>鏈湴璐﹀彿锛歛dmin 瀵嗙爜:123456</p> + <p><a href="https://jq.qq.com/?_wv=1027&k=Sqstuy0M" style="text-decoration: none" + target="_blank">QQ3缇�:743852316</a> + + <a href="http://v2.volcore.xyz/document/guide" style="text-decoration: none" target="_blank">妗嗘灦鏂囨。</a> + </p> + </div> --> + <!-- 閾炬帴浣嶇疆 --> + <!-- <div class="app-link" > + <a href="#" style="text-decoration: none">绉诲姩绔壂鐮�</a> + <a> + <i class="el-icon-chat-dot-round"></i> 灏忕▼搴� + <img src="https://app-1256993465.cos.ap-nanjing.myqcloud.com/wechat.jpg" /></a> + <a> + <i class="el-icon-apple"></i> + Android + <img src="https://app-1256993465.cos.ap-nanjing.myqcloud.com/Android.png" /></a> + <a> + <i class="el-icon-document"></i> + H5 + <img src="https://app-1256993465.cos.ap-nanjing.myqcloud.com/H5.png" /></a> + </div> --> + </div> + + <!-- 椤甸潰搴曢儴 --> + <!-- <div class="login-footer"> + <a style="text-decoration: none" href="https://beian.miit.gov.cn/" target="_blank">浜琁CP澶�19056538鍙�-1</a> + + + <a href="https://dotnet9.com/" style="text-decoration: none" target="blank">Dotnet9</a> + <a href="https://space.bilibili.com/525836469" style="text-decoration: none" target="blank">NET瑙嗛鏁欑▼(寰蒋MVP-ACE褰曞埗)</a> + <a href="https://www.cctalk.com/m/group/90268531" style="text-decoration: none" target="blank">VOL妗嗘灦瑙嗛</a> + <a href="http://120.48.115.252:9990" style="text-decoration: none" target="blank">瑙嗛婕旂ず鍦板潃</a> + </div> --> + + <img class="login-bg" src="/static/login_bg.png" /> + </div> +</template> + + +<script > +import { + defineComponent, + ref, + reactive, + toRefs, + getCurrentInstance, +} from "vue"; +import { useRouter, useRoute } from "vue-router"; +import store from "../store/index"; +import http from "@/../src/api/http.js"; +export default defineComponent({ + setup(props, context) { + store.commit("clearUserInfo", ""); + const loading = ref(false); + const codeImgSrc = ref(""); + const userInfo = reactive({ + userName: "admin", + password: "123456", + verificationCode: "1234", + UUID: undefined, + }); + + const getVierificationCode = () => { + http.get("/api/User/getVierificationCode").then((x) => { + codeImgSrc.value = "data:image/png;base64," + x.img; + userInfo.UUID = x.uuid; + }); + }; + getVierificationCode(); + + let appContext = getCurrentInstance().appContext; + let $message = appContext.config.globalProperties.$message; + let router = useRouter(); + + const login = () => { + if (!userInfo.userName) return $message.error("璇疯緭鍏ョ敤鎴峰悕"); + if (!userInfo.password) return $message.error("璇疯緭鍏ュ瘑鐮�"); + if (!userInfo.verificationCode) { + return $message.error("璇疯緭鍏ラ獙璇佺爜"); + } + loading.value = true; + http.post("/api/User/login", userInfo, "姝e湪鐧诲綍....").then((result) => { + if (!result.status) { + loading.value = false; + getVierificationCode(); + return $message.error(result.message); + } + $message.success("鐧诲綍鎴愬姛,姝e湪璺宠浆!"); + store.commit("setUserInfo", result.data); + + router.push({ path: "/" }); + }); + }; + const loginPress = (e) => { + if (e.keyCode == 13) { + login(); + } + }; + const openUrl = (url) => { + window.open(url, "_blank"); + }; + return { + loading, + codeImgSrc, + getVierificationCode, + login, + userInfo, + loginPress, + openUrl, + }; + }, + directives: { + focus: { + inserted: function (el) { + el.focus(); + }, + }, + }, +}); +</script> +<style lang="less" scoped> +.login-container { + display: flex; + width: 100%; + height: 100%; + background: rgb(246, 247, 252); + justify-content: flex-end; + align-items: center; +} + +.login-form { + align-items: center; + width: 50%; + display: flex; + flex-direction: column; + // margin-right: 150px; + z-index: 999; + + .form-user { + // margin: 25px 0; + + .item { + border-radius: 5px; + border: 1px solid #ececec; + display: flex; + margin-bottom: 30px; + background: #ffff; + height: 45px; + padding-left: 20px; + display: flex; + + .code { + position: relative; + cursor: pointer; + width: 74px; + padding: 5px 10px 0 0; + } + + .input-icon { + line-height: 45px; + color: #7a7a7a; + padding-right: 20px; + } + } + } + + input:-webkit-autofill { + box-shadow: 0 0 0px 1000px white inset; + -webkit-box-shadow: 0 0 0px 1000px white inset !important; + } + + input { + background: white; + display: block; + box-sizing: border-box; + width: 100%; + min-width: 0; + margin: 0; + padding: 0; + color: #323233; + line-height: inherit; + text-align: left; + border: 0; + outline: none; + font-size: 16px; + line-height: 20px; + } +} + +.form-user, +.loging-btn { + width: 400px; +} + +.loging-btn { + box-shadow: 2px 4px 11px #a4c2ff; + margin-top: 10px; + + button { + padding: 21px; + font-size: 14px !important; + width: 100%; + } +} + +.login-text { + font-weight: bolder; + font-size: 20px; + letter-spacing: 2px; + + position: relative; + display: flex; + + .login-line { + z-index: -1; + padding: 5px; + position: relative; + top: -8px; + width: 100%; + background-image: linear-gradient(to right, #6598ff, white); + } +} + +.login-text-small { + margin-bottom: 20px; + font-size: 13px; + color: #7d7c7c; +} + +.login-bg { + left: 0; + position: absolute; + height: 100%; + width: 50%; + z-index: 0; +} + +.project-name { + position: absolute; + top: 40px; + left: 40px; + z-index: 9999; + font-weight: bolder; + background-image: linear-gradient(to right, #1850c1, #9c009c); + -webkit-background-clip: text; + color: transparent; + font-size: 25px; +} +</style> +<style lang="less" scoped> +.app-link { + // font-weight: bolder; + text-align: center; + padding-top: 5px; + font-size: 12px; + width: 400px; + padding-left: 40px; + display: flex; + + a { + flex: 1; + position: relative; + cursor: pointer; + width: 70px; + color: #666666; + margin: 2px 10px 0 0; + } + + img { + display: none; + } + + a:hover { + color: #0545f6 !important; + + img { + display: block; + position: absolute; + z-index: 999999999; + top: -130px; + width: 120px; + left: -22px; + + border: 1px solid #b1b1b1; + } + } +} + +.login-footer { + position: absolute; + width: 50%; + bottom: 0.5rem; + font-size: 12px; + text-align: center; + padding-bottom: 10px; + color: #4f4f4f; + + a { + margin-right: 10px; + font-size: 12px; + color: #4f4f4f; + } + + div { + margin-bottom: 5px; + } + + a:hover { + cursor: pointer; + color: #0540e3 !important; + } +} + +.account-info { + font-size: 12px; + color: #636363; + margin-top: 15px; +} +</style> + +<style lang="less" scoped> +@media screen and (max-width: 700px) { + .login-bg, + .account-info, + .app-link, + .login-footer, + .project-name { + display: none; + } + + .login-container { + padding: 2rem; + justify-content: center; + } + + .login-form { + width: 100%; + } + + .form-user, + .loging-btn { + width: 100%; + } +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/areaInfo.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/areaInfo.vue" new file mode 100644 index 0000000..33c1729 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/areaInfo.vue" @@ -0,0 +1,215 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/basic/areaInfo.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "鍖哄煙淇℃伅", + name: "areaInfo", + url: "/AreaInfo/", + sortName: "id", + }); + const editFormFields = ref({ + areaCode: "", + areaName: "", + warehouseId: "", + areaDes: "", + }); + const editFormOptions = ref([ + [ + { + title: "鍖哄煙缂栧彿", + required: true, + field: "areaCode", + type: "string", + }, + { + title: "鍖哄煙鍚嶇О", + required: true, + field: "areaName", + type: "string", + }, + { + title: "浠撳簱涓婚敭", + required: true, + field: "warehouseId", + type: "select", + dataKey: "warehouse", + data: [], + }, + + ], + [ + { + title: "鍖哄煙绫诲瀷", + required: true, + field: "areaType", + type: "int", + }, + { + title: "鍖哄煙鎻忚堪", + field: "areaDes", + type: "textarea", + }, + { title: "鍖哄煙鐘舵��", field: "areaStatus" ,type: "select",dataKey: "enableEnum",data: [],}, + ], + ]); + const searchFormFields = ref({ + areaCode: "", + areaName: "", + warehouseId: "", + areaDes: "", + }); + const searchFormOptions = ref([ + [ + { title: "鍖哄煙缂栧彿", field: "areaCode", type: "like" }, + { title: "鍖哄煙鍚嶇О", field: "areaName", type: "like" }, + + { + title: "鍖哄煙鐘舵��", + field: "areaStatus", + type: "select", + dataKey: "enableEnum", + data: [], + }, + ], + [ + { + title: "浠撳簱涓婚敭", + field: "warehouseId", + type: "select", + dataKey: "warehouse", + data: [], + },{ title: "鍖哄煙绫诲瀷", field: "areaType" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "areaCode", + title: "鍖哄煙缂栧彿", + type: "string", + width: 80, + align: "left", + }, + { + field: "warehouseId", + title: "浠撳簱涓婚敭", + type: "string", + width: 90, + align: "left", + bind:{ key: "warehouse", data: [] }, + }, + { + field: "areaName", + title: "鍖哄煙鍚嶇О", + type: "string", + width: 150, + align: "left", + }, + { + field: "areaType", + title: "鍖哄煙绫诲瀷", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "areaStatus", + title: "鍖哄煙鐘舵��", + type: "string", + width: 90, + align: "left", + bind: { key: "enableEnum", data: [] }, + }, + { + field: "areaDes", + title: "鍖哄煙鎻忚堪", + type: "int", + width: 120, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/areaRouter.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/areaRouter.vue" new file mode 100644 index 0000000..3d3cbf1 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/areaRouter.vue" @@ -0,0 +1,171 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/basic/areaRouter.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "缂撳瓨鐐�", + name: "areaRouter", + url: "/areaRouter/", + sortName: "id", + }); + const editFormFields = ref({ + areaId: "", + startArea: "", + nextArea: "", + routerType: "", + isEnd: "", + }); + const editFormOptions = ref([ + [ + {title: "璧风偣",required: true,field: "startArea",type: "string",}, + {title: "缁堢偣鍖哄煙ID",required: true,field: "nextArea",type: "select",dataKey: "areainfo",data: [],}, + + ], + [ + {title: "璺敱绫诲瀷",field: "routerType",type: "like"}, + {title: "鏄惁涓虹粓鐐�",field: "isEnd",type: "select",dataKey: "enable",data: [],} + ], + ]); + const searchFormFields = ref({ + areaId: "", + pointCode: "", + pointStatus: "", + enableStatus: "", + pointType: "", + }); + const searchFormOptions = ref([ + [ + {title: "璧风偣",required: true,field: "startArea",type: "string",}, + {title: "缁堢偣鍖哄煙ID",field: "nextArea",type: "select",dataKey: "areainfo",data: [],}, + // {title: "缁堢偣鍖哄煙ID",required: true,field: "nextArea",type: "string",}, + ], + [ + {title: "璺敱绫诲瀷",field: "routerType",type: "like"}, + {title: "鏄惁涓虹粓鐐�",field: "isEnd",type: "select",dataKey: "enable",data: [],} + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "startArea", + title: "璧风偣", + type: "string", + width: 90, + align: "left", + }, + { + field: "nextArea", + title: "缁堢偣鍖哄煙ID", + type: "string", + width: 150, + align: "left", + bind:{ key: "areainfo", data: [] }, + }, + { + field: "routerType", + title: "璺敱绫诲瀷", + type: "string", + width: 90, + align: "left", + // bind: { key: "locationStatusEnum", data: [] }, + }, + { + field: "isEnd", + title: "鏄惁鏄粓鐐�", + type: "byte", + width: 90, + align: "left", + bind: { key: "enable", data: [] }, + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 90, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/cachePoint.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/cachePoint.vue" new file mode 100644 index 0000000..e448d8c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/cachePoint.vue" @@ -0,0 +1,209 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/basic/CachePoint.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "缂撳瓨鐐�", + name: "CachePoint", + url: "/CachePoint/", + sortName: "id", + }); + const editFormFields = ref({ + areaId: "", + pointCode: "", + pointStatus: "", + enableStatus: "", + pointType: "", + row: "", + column: "", + depth: "", + }); + const editFormOptions = ref([ + [ + {title: "缂撳瓨鐐圭紪鍙�",required: true,field: "pointCode",type: "string",}, + {title: "鍖哄煙涓婚敭",required: true,field: "areaId",type: "select",dataKey: "areainfo", data: [] ,}, + {title: "缂撳瓨鐐圭姸鎬�",field: "pointStatus",type: "select",dataKey: "locationStatusEnum",data: [],}, + {title: "鏄惁绂佺敤",field: "enableStatus",type: "select",dataKey: "enableStatusEnum",data: [],}, + ],[ + { title: "琛�", field: "row", type: "string" }, + { title: "鍒�", field: "column", type: "string" }, + { title: "娣卞害", field: "depth", type: "string" }, + { title: "缂撳瓨鐐圭被鍨�", field: "pointType", type: "string"}, + ], + ]); + const searchFormFields = ref({ + areaId: "", + pointCode: "", + pointStatus: "", + enableStatus: "", + pointType: "", + row: "", + column: "", + depth: "", + }); + const searchFormOptions = ref([ + [ + {title: "缂撳瓨鐐圭紪鍙�",field: "pointCode",type: "string",}, + {title: "鍖哄煙涓婚敭",field: "areaId",type: "select",dataKey: "areainfo",data: [],}, + {title: "缂撳瓨鐐圭姸鎬�",field: "pointStatus",type: "select",dataKey: "locationStatusEnum",data: [],}, + {title: "鏄惁绂佺敤",field: "enableStatus",type: "select",dataKey: "enableStatusEnum",data: [],}, + ],[ + { title: "琛�", field: "row", type: "string" }, + { title: "鍒�", field: "column", type: "string" }, + { title: "娣卞害", field: "depth", type: "string" }, + { title: "缂撳瓨鐐圭被鍨�", field: "pointType", type: "string"}, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "areaId", + title: "鍖哄煙涓婚敭", + type: "int", + width: 120, + align: "left", + bind:{ key: "areainfo", data: [] }, + }, + { + field: "pointCode", + title: "缂撳瓨鐐圭紪鍙�", + type: "string", + width: 150, + align: "left", + }, + { + field: "pointStatus", + title: "缂撳瓨鐐圭姸鎬�", + type: "string", + width: 90, + align: "left", + bind: { key: "locationStatusEnum", data: [] }, + }, + { + field: "enableStatus", + title: "鏄惁绂佺敤", + type: "decimal", + width: 90, + align: "left", + bind: { key: "enableStatusEnum", data: [] }, + }, + { + field: "row", + title: "琛�", + type: "string", + width: 90, + align: "left", + }, + { + field: "column", + title: "鍒�", + type: "string", + width: 90, + align: "left", + }, + { + field: "depth", + title: "娣卞害", + type: "string", + width: 90, + align: "left", + }, + { + field: "pointType", + title: "缂撳瓨鐐圭被鍨�", + type: "string", + width: 90, + align: "left", + }, + { + field: "Remark", + title: "澶囨敞", + type: "string", + width: 90, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/locationInfo.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/locationInfo.vue" new file mode 100644 index 0000000..d78f6e2 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/locationInfo.vue" @@ -0,0 +1,205 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/basic/locationInfo.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "璐т綅淇℃伅", + name: "locationInfo", + url: "/LocationInfo/", + sortName: "id", + }); + const editFormFields = ref({ + locationStatus: "", + }); + const editFormOptions = ref([ + [ + { title: "璐т綅鐘舵��", field: "locationStatus" ,type: "select",dataKey: "locationStatusEnum",data: [],}, + ], + ]); + const searchFormFields = ref({ + locationCode: "", + roadwayNo: "", + }); + const searchFormOptions = ref([ + [ + { title: "璐т綅缂栧彿", field: "locationCode", type: "like" }, + { title: "宸烽亾缂栧彿", field: "roadwayNo" }, + { title: "璐т綅绫诲瀷", field: "locationType",type: "select",dataKey: "locationTypeEnum",data: [], }, + { title: "绂佺敤鐘舵��", field: "enableStatus" ,type: "select",dataKey: "enableStatusEnum",data: [],}, + ], + [ + { title: "璐т綅鐘舵��", field: "locationStatus" ,type: "selectList",dataKey: "locationStatusEnum",data: [],}, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + // { + // field: "areaId", + // title: "鍖哄煙涓婚敭", + // type: "string", + // width: 90, + // align: "left", + // bind: {key: "areainfo",data: []} + // }, + { + field: "locationCode", + title: "璐т綅缂栧彿", + type: "string", + width: 180, + align: "left", + }, + { + field: "locationName", + title: "璐т綅鍚嶇О", + type: "string", + width: 220, + align: "left", + }, + { + field: "roadwayNo", + title: "宸烽亾缂栧彿", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "row", + title: "璐т綅琛�", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "column", + title: "璐т綅鍒�", + type: "int", + width: 120, + align: "left", + hidden: true, + }, + { + field: "layer", + title: "璐т綅灞�", + type: "string", + width: 200, + align: "left", + hidden: true, + }, + { + field: "depth", + title: "璐т綅娣卞害", + type: "string", + width: 180, + align: "left", + hidden: true, + }, + { + field: "locationType", + title: "璐т綅绫诲瀷", + type: "string", + width: 120, + align: "left", + bind:{key: "locationTypeEnum", data: []} + }, + { + field: "locationStatus", + title: "璐т綅鐘舵��", + type: "string", + width: 200, + align: "left", + bind: { key: "locationStatusEnum", data: [] }, + }, + { + field: "enableStatus", + title: "绂佺敤鐘舵��", + type: "string", + width: 180, + align: "left", + bind: { key: "enableStatusEnum", data: [] }, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + sort: true, + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/materielInfo.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/materielInfo.vue" new file mode 100644 index 0000000..c0490f8 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/materielInfo.vue" @@ -0,0 +1,221 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/basic/materielInfo.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "鐗╂枡淇℃伅", + name: "materielInfo", + url: "/MaterielInfo/", + sortName: "id", + }); + const editFormFields = ref({ + areaId: "", + materielCode: "", + materielName: "", + materielDes: "", + isMixBatch: "", + isMixMateriel: "", + }); + const editFormOptions = ref([ + [ + { + title: "鍖哄煙", + required: true, + field: "areaId", + type: "string", + }, + { + title: "鐗╂枡缂栧彿", + required: true, + field: "materielCode", + type: "string", + }, + { + title: "鐗╂枡鍚嶇О", + required: true, + field: "materielName", + type: "string", + }, + { + title: "璁¢噺鍗曚綅", + required: true, + field: "unit", + type: "string", + }, + ], + [ + + { + title: "鐗╂枡鎻忚堪", + field: "materielDes", + type: "textarea", + }, + ], + ]); + const searchFormFields = ref({ + materielCode: "", + materielName: "", + areaId: "", + }); + const searchFormOptions = ref([ + [ + { title: "鐗╂枡缂栧彿", field: "materielCode", type: "like" }, + { title: "鐗╂枡鍚嶇О", field: "materielName", type: "like" }, + { title: "璁惧鐘舵��", field: "deviceStatus" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "areaId", + title: "鍖哄煙涓婚敭", + type: "string", + width: 90, + align: "left", + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + align: "left", + }, + { + field: "materielDes", + title: "鐗╂枡鎻忚堪", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "cotainerType", + title: "瀹瑰櫒绫诲瀷", + type: "string", + width: 90, + align: "left", + }, + { + field: "packspes", + title: "鍖呰瑙勬牸", + type: "int", + width: 120, + align: "left", + }, + { + field: "attribute", + title: "鐗╂枡灞炴��", + type: "string", + width: 200, + align: "left", + }, + { + field: "unit", + title: "璁¢噺鍗曚綅", + type: "string", + width: 180, + align: "left", + }, + { + field: "validity", + title: "鏈夋晥鏈�", + type: "string", + width: 120, + align: "left", + }, + { + field: "safetyStock", + title: "瀹夊叏搴撳瓨", + type: "string", + width: 120, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/roadwayInfo.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/roadwayInfo.vue" new file mode 100644 index 0000000..dea7725 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/roadwayInfo.vue" @@ -0,0 +1,236 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/basic/roadwayInfo.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "宸烽亾淇℃伅", + name: "roadwayInfo", + url: "/roadwayInfo/", + sortName: "id", + }); + const editFormFields = ref({ + roadwayNo: "", + areaId: "", + enalbeStatus: "", + deviceNo: "", + inStationCode: "", + inSCStationCode: "", + outStationCode: "", + outSCStationCode: "", + }); + const editFormOptions = ref([ + [ + {title: "鍖哄煙涓婚敭",field: "areaId",type: "select",dataKey: "areainfo",data: [],}, + { + title: "宸烽亾缂栧彿", + required: true, + field: "roadwayNo", + type: "string", + }, + { + title: "璁惧缂栧彿", + required: true, + field: "deviceNo", + type: "string", + }, + { + title: "绂佺敤鐘舵��", + required: true, + field: "enalbeStatus", + type: "select", + dataKey: "enableStatusEnum", + data: [], + }, + ], + [ + { + title: "鍏ュ簱绔欏彴缂栧彿", + field: "inStationCode", + type: "string", + }, + { + title: "鍫嗗灈鏈哄叆搴撶珯鍙扮紪鍙�", + field: "inSCStationCode", + type: "string", + }, + { + title: "鍑哄簱绔欏彴缂栧彿", + field: "outStationCode", + type: "string", + }, + { + title: "鍫嗗灈鏈哄嚭搴撶珯鍙扮紪鍙�", + field: "outSCStationCode", + type: "string", + }, + ], + ]); + const searchFormFields = ref({ + roadwayNo: "", + areaId: "", + enableStatus: "", + deviceNo: "", + inStationCode: "", + inSCStationCode: "", + outStationCode: "", + outSCStationCode: "", + }); + const searchFormOptions = ref([ + [ + { title: "宸烽亾缂栧彿", field: "roadwayNo", type: "like" }, + {title: "鍖哄煙涓婚敭",field: "areaId",type: "select",dataKey: "areainfo",data: [],}, + { title: "绂佺敤鐘舵��", field: "enableStatus",type: "select",dataKey: "enableStatusEnum",data: [],}, + ], + [ + { title: "鍏ュ簱绔欏彴缂栧彿", field: "inStationCode", type: "like" }, + { title: "鍫嗗灈鏈哄叆搴撶珯鍙扮紪鍙�", field: "inSCStationCode", type: "like" }, + { title: "璁惧缂栧彿", field: "deviceNo", type: "like" }, + ], + [ + { title: "鍑哄簱绔欏彴缂栧彿", field: "outStationCode", type: "like" }, + { title: "鍫嗗灈鏈哄嚭搴撶珯鍙扮紪鍙�",field: "outSCStationCode",type: "like",}, + ] + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "roadwayNo", + title: "宸烽亾缂栧彿", + type: "string", + width: 90, + align: "left", + }, + { + field: "areaId", + title: "鍖哄煙涓婚敭", + type: "int", + width: 150, + align: "left", + bind:{ key: "areainfo", data: [] }, + }, + { + field: "enableStatus", + title: "绂佺敤鐘舵��", + type: "select", + width: 150, + align: "left", + bind: { key: "enableStatusEnum", data: [] }, + }, + { + field: "deviceNo", + title: "璁惧缂栧彿", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "inStationCode", + title: "鍏ュ簱绔欏彴缂栧彿", + type: "string", + width: 120, + align: "left", + }, + { + field: "inSCStationCode", + title: "鍫嗗灈鏈哄叆搴撶珯鍙扮紪鍙�", + type: "string", + width: 150, + align: "left", + }, + { + field: "outStationCode", + title: "鍑哄簱绔欏彴缂栧彿", + type: "decimal", + width: 120, + align: "left", + }, + { + field: "outSCStationCode", + title: "鍫嗗灈鏈哄嚭搴撶珯鍙扮紪鍙�", + type: "string", + width: 150, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/warehouse.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/warehouse.vue" new file mode 100644 index 0000000..5a25672 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/basic/warehouse.vue" @@ -0,0 +1,179 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/basic/warehouse.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "浠撳簱淇℃伅", + name: "warehouse", + url: "/Warehouse/", + sortName: "id", + }); + const editFormFields = ref({ + warehouseCode: "", + warehouseName: "", + warehouseType: "", + warehouseStatus: "", + warehouseDes: "", + }); + const editFormOptions = ref([ + [ + { + title: "浠撳簱缂栧彿", + required: true, + field: "warehouseCode", + type: "string", + }, + { + title: "浠撳簱鍚嶇О", + required: true, + field: "warehouseName", + type: "string", + }, + { + title: "浠撳簱鎻忚堪", + field: "warehouseDes", + type: "textarea", + }, + ], + ]); + const searchFormFields = ref({ + warehouseCode: "", + warehouseName: "", + warehouseType: "", + warehouseStatus: "", + }); + const searchFormOptions = ref([ + [ + { title: "浠撳簱缂栧彿", field: "warehouseCode", type: "like" }, + { title: "浠撳簱鍚嶇О", field: "warehouseName", type: "like" }, + { title: "浠撳簱绫诲瀷", field: "warehouseType", type: "like" }, + { + title: "浠撳簱鐘舵��", + field: "warehouseStatus", + type: "select", + dataKey: "enableEnum", + data: [], + }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "warehouseCode", + title: "浠撳簱缂栧彿", + type: "string", + width: 90, + align: "left", + }, + { + field: "warehouseName", + title: "浠撳簱鍚嶇О", + type: "string", + width: 150, + align: "left", + }, + { + field: "warehouseType", + title: "浠撳簱绫诲瀷", + type: "string", + width: 150, + align: "left", + }, + { + field: "warehouseStatus", + title: "浠撳簱鐘舵��", + type: "decimal", + width: 90, + align: "left", + bind: { key: "enableEnum", data: [] }, + }, + { + field: "warehouseDes", + title: "浠撳簱鎻忚堪", + type: "string", + width: 90, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata.vue" new file mode 100644 index 0000000..e75b6f9 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata.vue" @@ -0,0 +1,258 @@ + +<template> + <div id="big-data-container" class="big-data-container"> + <div class="head"> + <h1>澶у睆鏁版嵁缁熻鍒嗘瀽鏄剧ず</h1> + </div> + <div class="data-container"> + <div class="data-left"> + <div class="data-left-item"> + <div class="title">鍟嗗搧閿�閲忓垎绫�</div> + <div id="chart-vleft-1" style="height: calc(100% - 30px)"></div> + <div class="data-foot-line"></div> + </div> + <div class="data-left-item"> + <div class="title">鏈湀鍟嗗搧閿�閲�</div> + <div id="chart-vleft-3" style="height: calc(100% - 30px)"></div> + + <div class="data-foot-line"></div> + </div> + <div class="data-left-item"> + <div class="title">7鏃ヨ鍗曢攢閲�</div> + <div id="chart-vleft-2" style="height: calc(100% - 30px)"></div> + <div class="data-foot-line"></div> + </div> + </div> + <div class="data-center"> + <!-- <div class="title">涓棿浣嶇疆</div> --> + <div class="center-top-num"> + <div class="item"> + <div class="text">绱閿�閲�</div> + <div class="num">220,000</div> + </div> + <div class="item"> + <div class="text">绱閿�鍞噾棰�</div> + <div class="num">58,000,000</div> + </div> + <div class="item"> + <div class="text">璐拱鐢ㄦ埛浜烘暟</div> + <div class="num">15,000</div> + </div> + <div class="data-foot-line"></div> + </div> + <div + class="center-top" + style="height: 260px; padding-top: 25px; overflow: hidden" + > + <!-- <div class="title">鐢ㄦ埛娲昏穬淇℃伅-1</div> --> + <div id="chart-vgauge-1" style="height: 400px"></div> + <!-- <iview-circle :size="200" style="padding: 8px 0;"></iview-circle> --> + <div class="data-foot-line"></div> + </div> + <div class="title">璁㈠崟閿�鍞粺璁�</div> + <div id="chart-vcenter" style="height:400px;" class="chart-vcenter"></div> + </div> + <div class="data-right"> + <div class="data-right-item"> + <div class="title">閿�鍞儏鍐佃蛋鍔�</div> + <div id="chart-vright-1" style="height: calc(100% - 30px)"></div> + <div class="data-foot-line"></div> + </div> + <div class="data-right-item" style="height: 220px; padding-top: 25px"> + <!-- <div class="title">鐢ㄦ埛娲昏穬淇℃伅</div> --> + <!-- <iview-circle></iview-circle> --> + <div id="chart-vgauge-2" style="height: 300px"></div> + <div class="data-foot-line"></div> + </div> + <div class="data-right-item right-3"> + <div class="title">鍟嗗搧閿�鍞帓琛�</div> + <div id="chart-vright-3" class="right-item"> + <div class="item"> + <div class="top">鎺掑悕</div> + <div class="pro-name">鍟嗗搧鍚嶇О</div> + <div class="num">閿�閲�</div> + <div class="num">閿�鍞噾棰�</div> + </div> + <div class="item"> + <div class="top top-1"> + <span>1</span> + </div> + <div class="pro-name">鍗″笣涔愰硠楸�</div> + <div class="num">2,200</div> + <div class="num">360,00</div> + </div> + <div class="item"> + <div class="top top-2"> + <span>2</span> + </div> + <div class="pro-name">鏄ュ鐢稵鎭�</div> + <div class="num">1,700</div> + <div class="num">24,500</div> + </div> + <div class="item"> + <div class="top top-3"> + <span>3</span> + </div> + <div class="pro-name">鐢峰コ鍚屾浼戦棽闉�</div> + <div class="num">1,120</div> + <div class="num">12,700</div> + </div> + </div> + <div class="boxfoot"></div> + </div> + </div> + </div> + </div> +</template> +<script> +var echarts = require("echarts"); +let $chartLeft1, + $chartLeft2, + $chartLeft3, + $chartCenter, + $chartRight1, + $chartGauge1, + $chartGauge2; +import { + chartLeft1, + chartLeft2, + chartLeft3, + chartRight1, + gauge, +} from "./bigdata/chart-options"; +// import IviewCircle from "./bigdata/IviewCircle"; +import "./bigdata/layout.less"; +export default { + components: { + // "iview-circle": IviewCircle + }, + data() { + return {}; + }, + created() { + console.log("chart"); + }, + mounted() { + if ($chartLeft1) { + $chartLeft1.dispose(); + $chartLeft2.dispose(); + $chartLeft3.dispose(); + $chartCenter.dispose(); + $chartRight1.dispose(); + $chartGauge1.dispose(); + $chartGauge2.dispose(); + } + $chartLeft1 = echarts.init(document.getElementById("chart-vleft-1")); + $chartLeft1.setOption(chartLeft1, true); + + $chartLeft2 = echarts.init(document.getElementById("chart-vleft-2")); + $chartLeft2.setOption(chartLeft2, true); + + $chartLeft3 = echarts.init(document.getElementById("chart-vleft-3")); + $chartLeft3.setOption(chartLeft3, true); + + $chartCenter = echarts.init(document.getElementById("chart-vcenter")); + $chartCenter.setOption(chartRight1, true); + + $chartRight1 = echarts.init(document.getElementById("chart-vright-1")); + $chartRight1.setOption(chartRight1, true); + + $chartGauge1 = echarts.init(document.getElementById("chart-vgauge-1")); + $chartGauge1.setOption(gauge, true); + + $chartGauge2 = echarts.init(document.getElementById("chart-vgauge-2")); + $chartGauge2.setOption(gauge); + }, + destroyed() { + $chartLeft1 = null; + $chartLeft2 = null; + $chartLeft3 = null; + $chartCenter = null; + $chartRight1 = null; + $chartGauge1 = null; + $chartGauge2 = null; + }, +}; +</script> +<style scoped> +/* .chart-center { + display: flex; + border: 1px solid #0000ff; + height: 200px; + flex-direction: column; + margin-top: 20px; +} +.chart-center .item { + text-align: center; + border: 1px solid #00c1b3; + flex: 1; +} */ +.right-3 { + display: flex; + flex-direction: column; + /* margin-top: 20px; */ +} + +.right-3 .right-item { + flex: 1; + display: flex; + flex-direction: column; +} + +.right-3 .item { + text-align: left; + border-bottom: 1px solid #549069; + flex: 1; + display: flex; + padding: 5px 10px; + margin: 0 10px; + font-size: 14px; + line-height: 30px; +} + +.right-3 .item:last-child { + border-bottom: 0; +} + +.right-3 .item > div { + color: white; +} + +.right-3 .top { + width: 60px; + position: relative; +} + +.right-3 .top span { + position: absolute; + width: 20px; + line-height: 20px; + top: 5px; + text-align: center; + border-radius: 5px; +} + +.right-3 .top-1 span { + background: #e80d0d; +} + +.right-3 .top-2 span { + background: #00c935; +} + +.right-3 .top-3 span { + background: #0083f4; +} + +.right-3 .num { + width: 88px; +} + +.right-3 .pro-name { + flex: 1; +} +</style> + + + + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/IviewCircle.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/IviewCircle.vue" new file mode 100644 index 0000000..c166d91 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/IviewCircle.vue" @@ -0,0 +1,102 @@ +<template> + <div class="demo-Circle"> + <div style> + <i-circle + :size="size" + :trail-width="4" + :stroke-width="5" + :percent="75" + stroke-linecap="square" + stroke-color="#43a3fb" + > + <div class="demo-Circle-custom"> + <h1>1500</h1> + <p>鏄ㄦ棩娲昏穬鐢ㄦ埛鏁伴噺</p> + <span> + 鍗犳瘮 + <i>{{1500/20000}}%</i> + </span> + </div> + </i-circle> + </div> + <div style> + <i-circle + :size="size" + :trail-width="4" + :stroke-width="5" + :percent="75" + stroke-linecap="square" + stroke-color="#43a3fb" + > + <div class="demo-Circle-custom"> + <h1>12000</h1> + <p>涓婃湀娲昏穬鐢ㄦ埛鏁伴噺</p> + <span> + 鍗犳瘮 + <i>{{12000/150000}}%</i> + </span> + </div> + </i-circle> + </div> + </div> +</template> +<script> +export default { + props:{ + size:{ + type:Number, + default:150 + } + } +} +</script> +<style scoped> +.demo-Circle { + display: flex; +} +.demo-Circle > div { + flex: 1; + text-align: center; +} +.demo-Circle > div:first-child{ + padding-left:10%; +} + +.demo-Circle > div:last-child{ + padding-right:10%; +} +</style> +<style lang="less" scoped> +.demo-Circle-custom { + & h1 { + color:#ffffff; + font-size: 28px; + font-weight: normal; + } + & p { + color: #ece8e8; + font-size: 14px; + margin: 10px 0 15px; + } + & span { + display: block; + padding-top: 15px; + color: wheat; + font-size: 14px; + &:before { + content: ""; + display: block; + width: 50px; + height: 1px; + margin: 0 auto; + background: #e0e3e6; + position: relative; + top: -15px; + } + } + & span i { + font-style: normal; + color: white; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/chart-options.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/chart-options.js" new file mode 100644 index 0000000..fe30d3e --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/chart-options.js" @@ -0,0 +1,551 @@ +var echarts = require("echarts"); +let chartLeft1 = { + tooltip: { + trigger: "axis", + axisPointer: { + type: "shadow" + } + }, + grid: { + left: "0%", + top: "10px", + right: "0%", + bottom: "4%", + containLabel: true + }, + xAxis: [ + { + type: "category", + data: [ + "鍟嗚秴闂ㄥ簵", + "鏁欒偛鍩硅", + "鎴垮湴浜�", + "鐢熸椿鏈嶅姟", + "姹借溅閿�鍞�", + "鏃呮父閰掑簵", + "浜旈噾寤烘潗" + ], + axisLine: { + show: true, + lineStyle: { + color: "rgba(255,255,255,.1)", + width: 1, + type: "solid" + } + }, + + axisTick: { + show: false + }, + axisLabel: { + interval: 0, + show: true, + splitNumber: 15, + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: "12" + } + } + } + ], + yAxis: [ + { + type: "value", + axisLabel: { + show: true, + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: "12" + } + }, + axisTick: { + show: false + }, + axisLine: { + show: true, + lineStyle: { + color: "rgba(255,255,255,.1 )", + width: 1, + type: "solid" + } + }, + splitLine: { + lineStyle: { + color: "rgba(255,255,255,.1)" + } + } + } + ], + series: [ + { + type: "bar", + data: [200, 600, 300, 900, 1500, 1200, 600], + barWidth: "35%", + itemStyle: { + normal: { + color: "#2f89cf", + opacity: 1, + barBorderRadius: 5 + } + } + } + ] +}; + + +let chartLeft2 = { + tooltip: { + trigger: "axis", + axisPointer: { + type: "shadow" + } + }, + grid: { + left: "0%", + top: "10px", + right: "0%", + bottom: "4%", + containLabel: true + }, + xAxis: [ + { + type: "category", + data: [ + "07.01", + "07.02", + "07.03", + "07.04", + "07.05", + "07.06", + ], + axisLine: { + show: true, + lineStyle: { + color: "rgba(255,255,255,.1)", + width: 1, + type: "solid" + } + }, + axisTick: { + show: false + }, + axisLabel: { + interval: 0, + // rotate:50, + show: true, + splitNumber: 15, + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: "12" + } + } + } + ], + yAxis: [ + { + type: "value", + axisLabel: { + show: true, + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: "12" + } + }, + axisTick: { + show: false + }, + axisLine: { + show: true, + lineStyle: { + color: "rgba(255,255,255,.1 )", + width: 1, + type: "solid" + } + }, + splitLine: { + lineStyle: { + color: "rgba(255,255,255,.1)" + } + } + }, + { + type: "value", + axisLabel: { + show: true, + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: "12" + } + }, + axisTick: { + show: false + }, + axisLine: { + show: true, + lineStyle: { + color: "rgba(255,255,255,.1 )", + width: 1, + type: "solid" + } + }, + splitLine: { + lineStyle: { + color: "rgba(255,255,255,.1)" + } + } + } + ], series: [ + { + type: "bar", + name: "閿�閲�", + data: [1200, 800, 300, 500, 560, 220], + barWidth: "25%", + itemStyle: { + normal: { + color: "#2f89cf", + opacity: 1, + barBorderRadius: 5 + } + } + }, { + type: "bar", + name: "璁㈠崟", + data: [1000, 750, 380, 450, 450, 120], + barWidth: "25%", + itemStyle: { + normal: { + color: "#46d000", + opacity: 1, + barBorderRadius: 5 + } + } + } + ] +}; + +let chartLeft3 = { + tooltip: { + trigger: 'axis', + axisPointer: { // 鍧愭爣杞存寚绀哄櫒锛屽潗鏍囪酱瑙﹀彂鏈夋晥 + type: 'shadow' // 榛樿涓虹洿绾匡紝鍙�変负锛�'line' | 'shadow' + } + }, + grid: { + left: "0%", + top: "-5px", + right: "3%", + bottom: "4%", + containLabel: true + }, + xAxis: { + type: 'value', + axisLabel: { + show: true, + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: "12" + } + }, + axisTick: { + show: false + }, + axisLine: { + show: true, + lineStyle: { + color: "rgba(255,255,255,.1 )", + width: 1, + type: "solid" + } + }, + splitLine: { + lineStyle: { + color: "rgba(255,255,255,.1)" + } + } + }, + yAxis: { + type: 'category', + axisLabel: { + show: true, + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: "12" + } + }, + axisTick: { + show: false + }, + axisLine: { + show: true, + lineStyle: { + color: "rgba(255,255,255,.1 )", + width: 1, + type: "solid" + } + }, + splitLine: { + lineStyle: { + color: "rgba(255,255,255,.1)" + } + }, + data: ['鍛ㄤ竴', '鍛ㄤ簩', '鍛ㄤ笁', '鍛ㄥ洓', '鍛ㄤ簲'] + }, + series: [ + { + name: '鐩存帴璁块棶', + type: 'bar', + stack: '鎬婚噺', + label: { + show: true, + position: 'insideRight' + }, + barWidth: "55%", + itemStyle: { + normal: { + color: "#2f89cf", + opacity: 1, + barBorderRadius: 5 + } + }, + data: [120, 302, 400, 200, 700] + } + ] +}; + +let chartRight1 = { + title: {}, + tooltip: { + trigger: "axis", + axisPointer: { + type: "cross", + label: { + backgroundColor: "#6a7985" + } + } + }, + + color: ["#ffab6f", "#09b916", "#83cddc"], //鍥句緥棰滆壊 + legend: { + top: "0%", + icon: "roundRect", + data: ["閿�鍞鍗�", "閫�璐ц鍗�", "鎶樻墸璁㈠崟"], + textStyle: { + color: "rgba(255,255,255,.5)", + fontSize: "12" + } + }, + toolbox: { + feature: {} + }, + grid: { + left: "10", + top: "20", + right: "10", + bottom: "10", + containLabel: true + }, + xAxis: [ + { + type: "category", + boundaryGap: false, + axisLabel: { + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: 12 + } + }, + axisLine: { + lineStyle: { + color: "rgba(255,255,255,.2)" + } + }, + data: [ + "2020.06.15", + "2020.06.16", + "2020.06.17", + "2020.06.18", + "2020.06.19", + "2020.06.20", + "2020.06.21", + "2020.06.22" + ] + } + ], + yAxis: [ + { + type: "value", + axisTick: { show: false }, + minInterval: 60, + axisLine: { + lineStyle: { + color: "rgba(255,255,255,.1)" + } + }, + axisLabel: { + textStyle: { + color: "rgba(255,255,255,.6)", + fontSize: 12 + } + }, + + splitLine: { + lineStyle: { + color: "rgba(255,255,255,.1)" + } + } + } + ], + series: [ + { + name: "閿�鍞鍗�", + type: "line", + smooth: true, + lineStyle: { + color: "#45d4ba", + width: 1 + }, //绾挎潯鐨勬牱寮� + areaStyle: { + color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ + { + offset: 0, + color: "#83cddc" + }, + { + offset: 1, + color: "#bfdffbb5" + } + ]) + }, + data: [5, 22, 150, 54, 1, 230, 4, 1] + }, + { + name: "閫�璐ц鍗�", + type: "line", + + smooth: true, + lineStyle: { + color: "#04a710", + width: 1 + }, // + areaStyle: { + color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ + { + offset: 0, + color: "#0cbf22" + }, + { + offset: 1, + color: "#b8f7d1b5" + } + ]) + }, + data: [10, 150, 1, 250, 20, 100, 10, 150] + }, + { + name: "鎶樻墸璁㈠崟", + type: "line", + + lineStyle: { + color: "#0864c3", + width: 1 + }, //绾挎潯鐨勬牱寮� + smooth: true, + areaStyle: { + color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ + { + offset: 0, + color: "#29d7ff" + }, + { + offset: 1, + color: "#34ccef85" + } + ]) + }, + data: [100, 2, 260, 1, 200, 30, 101, 40] + } + ] +}; + +var gauge = { + series: [{ + radius: '90%', + type: 'gauge', + startAngle: 180, + endAngle: 0, + min: 0, + max: 1, + splitNumber: 8, + axisLine: { + lineStyle: { + width: 3, + color: [ + [0.25, '#FF6E76'], + [0.5, '#FDDD60'], + [0.75, '#58D9F9'], + [1, '#7CFFB2'] + ] + } + }, + pointer: { + icon: 'path://M12.8,0.7l12,40.1H0.7L12.8,0.7z', + length: '12%', + width: 20, + offsetCenter: [0, '-60%'], + itemStyle: { + color: 'auto' + } + }, + axisTick: { + length: 12, + lineStyle: { + color: 'auto', + width: 2 + } + }, + splitLine: { + length: 20, + lineStyle: { + color: 'auto', + width: 5 + } + }, + axisLabel: { + color: '#464646', + fontSize: 20, + distance: -60, + formatter: function (value) { + if (value === 0.875) { + return '浼�'; + } + else if (value === 0.625) { + return '涓�'; + } + else if (value === 0.375) { + return '鑹�'; + } + else if (value === 0.125) { + return '宸�'; + } + } + }, + title: { + offsetCenter: [0, '-20%'], + fontSize: 20 + }, + detail: { + fontSize: 30, + offsetCenter: [0, '0%'], + valueAnimation: true, + formatter: function (value) { + return Math.round(value * 100) + '鍒�'; + }, + color: 'auto' + }, + data: [{ + value: 0.70, + name: '鎴愮哗璇勫畾' + }] + }] +} +export { chartLeft1, chartLeft2, chartLeft3, chartRight1, gauge } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/head_bg.png" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/head_bg.png" new file mode 100644 index 0000000..a2e45f6 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/head_bg.png" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/layout.less" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/layout.less" new file mode 100644 index 0000000..3f6cffd --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/bigdata/layout.less" @@ -0,0 +1,197 @@ + +.big-data-container { + position: absolute; + overflow: hidden; + height: 100%; + width: 100%; + background-color: #1400a8; + background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25' viewBox='0 0 1200 800'%3E%3Cdefs%3E%3CradialGradient id='a' cx='0' cy='800' r='800' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%230e0077'/%3E%3Cstop offset='1' stop-color='%230e0077' stop-opacity='0'/%3E%3C/radialGradient%3E%3CradialGradient id='b' cx='1200' cy='800' r='800' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%2314057c'/%3E%3Cstop offset='1' stop-color='%2314057c' stop-opacity='0'/%3E%3C/radialGradient%3E%3CradialGradient id='c' cx='600' cy='0' r='600' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%230d0524'/%3E%3Cstop offset='1' stop-color='%230d0524' stop-opacity='0'/%3E%3C/radialGradient%3E%3CradialGradient id='d' cx='600' cy='800' r='600' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%231400a8'/%3E%3Cstop offset='1' stop-color='%231400a8' stop-opacity='0'/%3E%3C/radialGradient%3E%3CradialGradient id='e' cx='0' cy='0' r='800' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%23000000'/%3E%3Cstop offset='1' stop-color='%23000000' stop-opacity='0'/%3E%3C/radialGradient%3E%3CradialGradient id='f' cx='1200' cy='0' r='800' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%23130733'/%3E%3Cstop offset='1' stop-color='%23130733' stop-opacity='0'/%3E%3C/radialGradient%3E%3C/defs%3E%3Crect fill='url(%23a)' width='1200' height='800'/%3E%3Crect fill='url(%23b)' width='1200' height='800'/%3E%3Crect fill='url(%23c)' width='1200' height='800'/%3E%3Crect fill='url(%23d)' width='1200' height='800'/%3E%3Crect fill='url(%23e)' width='1200' height='800'/%3E%3Crect fill='url(%23f)' width='1200' height='800'/%3E%3C/svg%3E"); + background-attachment: fixed; + background-size: cover; + .head { + height: 75px; + /* height: 1.05rem; */ + background: url(./head_bg.png) no-repeat center center; + background-size: 100% 100%; + position: relative; + z-index: 100; + } +} + +.head h1 { + margin: 0; + color: #fff; + text-align: center; + /* font-size: .4rem; */ + /* line-height: .8rem; */ + line-height: 71px; +} + +.data-container { + /* margin: 5px 15px; + height:100%; */ + + margin: 0px 15px; + position: absolute; + left: 0; + right: 0; + top: 76px; + bottom: 0; +} + +.data-container > div { + float: left; + /* border: 1px solid white; */ + height: 100%; +} + +.data-center { + padding: 0 0.9rem; + width: 40%; + display: flex; + flex-direction: column; + // .center-top{ + // height: 210px; + // background: red; + // } +.chart-center{ + flex: 1; +} +} +.chart-center{ + width: 100%; +display: flex; +// background: white; +} +.data-left, +.data-right { + width: 30%; + display: flex; + + flex-direction: column; +} + +.data-left-item, +.data-right-item,.center-top,.center-top-num,.chart-center { + border: 1px solid rgba(25, 186, 139, 0.17); + padding: 0 0.2rem 0.4rem 0.15rem; + background: rgba(255, 255, 255, 0.04); + background-size: 100% auto; + position: relative; + margin-bottom: 0.15rem; + z-index: 10; +} + +.data-foot-line { + position: absolute; + bottom: 0; + width: 100%; + left: 0; +} + +.data-foot-line:before, +.data-foot-line:after { + position: absolute; + width: 10px; + height:10px; + content: ""; + border-bottom: 2px solid #02a6b5; + bottom: 0; +} + +.boxall:before, +.data-foot-line:before { + border-left: 2px solid #02a6b5; + left: 0; +} + +.boxall:after, +.data-foot-line:after { + border-right: 2px solid #02a6b5; + right: 0; +} + +.boxall:before, +.boxall:after { + position: absolute; + width: 10px; + height: 10px; + content: ""; + border-top: 2px solid #02a6b5; + top: 0; +} + +.data-left-item:before, +.data-right-item:before, +.center-top-num:before, +.center-top:before{ + border-left: 2px solid #02a6b5; + left: 0; + position: absolute; + width: 10px; + height:10px; + content: ""; + border-top: 2px solid #02a6b5; + top: 0; +} + +.data-left-item:after, +.data-right-item:after, +.center-top-num:after, +.center-top:after { + border-right: 2px solid #02a6b5; + right: 0; + position: absolute; + width: 10px; + height: 10px; + content: ""; + border-top: 2px solid #02a6b5; + top: 0; +} + +.data-left, +.data-right { + /* display: flex; */ +} + +.data-left > .data-left-item, +.data-right > .data-right-item { + flex: 1; + margin-bottom: 0.9rem; +} + +.data-center .title, +.data-left > .data-left-item .title, +.data-right > .data-right-item .title { + /* font-size: .2rem; */ + font-size: 1rem; + padding: 7px 0; + color: #fff; + text-align: center; + /* line-height: .5rem; */ +} + +.data-center .chart-center{ + width: 100%; +} + +.center-top-num{ + height: 80px; + padding-top: 7px; + margin-bottom: 0.8rem; + display: flex; + .item{ + flex: 1; + text-align: center; + } + .text{ + color: #fcf0d8; + font-size: 14px; + } + .num{ + font-size: 34px; + font-family: -apple-system, BlinkMacSystemFont, Segoe UI, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Helvetica Neue, Helvetica, Arial, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol; + font-weight: bold; + color: #67caca; + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/chart.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/chart.vue" new file mode 100644 index 0000000..3b0695a --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/chart.vue" @@ -0,0 +1,101 @@ +<template> + <div class="m-charts"> + <el-tabs + v-model="name" + @tab-click="tabClick" + type="border-card" + style="height: 100%; width: 100%; box-shadow: none" + > + <el-tab-pane name="bar"> + <template #label> + <span><i class="el-icon-date"></i> 鏌辩姸鍥� </span> + </template> + <div + :style="{ height: heigth + 'px', width: width + 'px' }" + id="bar-0001" + ></div> + </el-tab-pane> + <el-tab-pane name="pie" :lazy="false" label="娑堟伅涓績"> + <template #label> + <span><i class="el-icon-date"></i> 楗肩姸鍥� </span> + </template> + <div + :style="{ height: heigth + 'px', width: width + 'px' }" + id="pie-0001" + ></div> + </el-tab-pane> + <el-tab-pane name="line" :lazy="false" label="瑙掕壊绠$悊"> + <template #label> + <span><i class="el-icon-date"></i> 鎶樼嚎鍥� </span> + </template> + <div + :style="{ height: heigth + 'px', width: width + 'px' }" + id="line-0001" + ></div> + </el-tab-pane> + </el-tabs> + </div> +</template> +<script> +let echarts = require("echarts"); +import options from "./chartOptions"; +let $bar; +let $pie; +let $line; +export default { + mounted() { + $bar = echarts.init(document.getElementById("bar-0001")); + $bar.setOption(this.options.bar); + }, + created() { + this.heigth = document.documentElement.clientHeight - 190; + this.width = document.documentElement.clientWidth - 240; + }, + methods: { + tabClick(name) { + if (name.props.name == "pie") { + if (!$pie) { + $pie = echarts.init(document.getElementById("pie-0001")); + $pie.setOption(this.options.pie); + + } + } else if (name.props.name == "line") { + if (!$line) { + $line = echarts.init(document.getElementById("line-0001")); + $line.setOption(this.options.line); + + } + } + }, + }, + data() { + return { + name: "bar", + heigth: 450, + width: 1000, + options: options, + }; + }, +}; +</script> +<style lang="less" scoped> +.m-charts { + position: absolute; + top: 0; + left: 0; + right: 0; + bottom: 0; + background: #f1f1f1; + margin: auto 0; + padding: 12px; + .m-tabs { + background: white; + } +} +.m-charts ::v-deep(.el-tabs__content) { + height: calc(100% - 45px); +} +.m-charts ::v-deep(.el-tab-pane) { + height: 100%; +} +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/chartOptions.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/chartOptions.js" new file mode 100644 index 0000000..2ec6bda --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/chartOptions.js" @@ -0,0 +1,212 @@ +let options= { + bar:{ + // title: { + // text: 'World Population' + // }, + tooltip: { + trigger: 'axis', + axisPointer: { + type: 'shadow' + } + }, + // legend: {}, + grid: { + top:10, + left: '3%', + right: '4%', + bottom: '3%', + containLabel: true + }, + xAxis: { + type: 'value', + boundaryGap: [0, 0.01] + }, + yAxis: { + type: 'category', + data: ['Brazil', 'Indonesia', 'USA', 'India', 'China', 'World'] + }, + series: [ + { + name: '2011', + type: 'bar', + data: [18203, 23489, 29034, 14970, 31744, 60230] + }, + { + name: '2012', + type: 'bar', + data: [19325, 23438, 31000, 11594, 24141, 6807] + } + ] + }, + pie: { + tooltip: { + trigger: "item", + formatter: "{a} <br/>{b} : {c} ({d}%)" + }, + legend: { + top: 20, + // orient: "vertical", + // right: 300, + // top: 200, + // bottom: 20, + data: [ + "鍥句緥1", + "鍥句緥2", + "鍥句緥3", + "鍥句緥4", + "鍥句緥5", + "鍥句緥6", + "鍥句緥7" + ] + }, + series: [ + { + name: "鍥句緥1", + type: "pie", + radius: ['40%', '70%'], + selectedMode: "single", + itemStyle: { + borderRadius: 6, + borderColor: '#fff', + borderWidth: 2 + }, + data: [ + { + value: 2563, + name: "鍥句緥1", + itemStyle: { + color: "rgb(45, 140, 240)" + } + }, + { + value: 727, + name: "鍥句緥2", + itemStyle: { + color: "rgb(92, 173, 255)" + } + }, + { + value: 2182, + name: "鍥句緥3", + itemStyle: { + color: "rgb(25, 190, 107)" + } + }, + { + value: 1419, + name: "鍥句緥4", + itemStyle: { + color: "#00e5ff" + } + }, + { + value: 984, + name: "鍥句緥5", + itemStyle: { + color: "#ff80ab" + } + }, + { + value: 870, + name: "鍥句緥6", + itemStyle: { + color: "rgb(237, 64, 20)" + } + }, + { + value: 1670, + name: "鍥句緥7", + itemStyle: { + color: "#ffb445" + } + } + ] + } + ] + }, + line: { + legend: { + data: ["閭欢钀ラ攢", "鑱旂洘骞垮憡"] + }, + grid: { + left: "3%", + right: "4%", + bottom: "3%", + containLabel: true + }, + toolbox: { + feature: { + saveAsImage: {} + } + }, + xAxis: { + type: "category", + boundaryGap: false, + data: [ + "1鏈�", + "2鏈�", + "3鏈�", + "4鏈�", + "5鏈�", + "6鏈�", + "7鏈�", + "8鏈�", + "9鏈�", + "10鏈�", + "11鏈�", + "12鏈�" + ] + }, + yAxis: { + type: "value" + }, + series: [ + { + name: "閭欢钀ラ攢", + type: "line", + stack: "鎬婚噺", + itemStyle: { + color: "rgb(25, 190, 107)" + }, + smooth: true, + data: [ + 7.0, + 6.9, + 9.5, + 12.5, + 18.2, + 21.5, + 22.5, + 23.3, + 18.3, + 13.9, + 9.6 + ] + }, + { + name: "鑱旂洘骞垮憡", + type: "line", + stack: "鎬婚噺", + smooth: true, + itemStyle: { + color: "rgb(92, 173, 255)" + }, + data: [ + 7.0, + 6.9, + 9.5, + 14.5, + 18.2, + 21.5, + 22.5, + 21.3, + 18.3, + 13.9, + 9.6 + ] + } + ] + } + } + + export default options; \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/flex.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/flex.vue" new file mode 100644 index 0000000..e94823a --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/flex.vue" @@ -0,0 +1,386 @@ +<template> + <div class="home-contianer"> + <div> + <div class="order-title"> + <h2>璁㈠崟缁熻</h2> + </div> + <div + data-v-542f4644 + class="ivu-row" + style="padding: 15px; background: white" + > + <div + v-for="item in topColor" + :key="item.name" + class="ivu-col ivu-col-span-6" + style="padding-left: 8px; padding-right: 8px" + > + <div + data-v-542f4644 + class="ivu-card" + :style="{ background: item.background }" + > + <div class="icon-left"> + <i :class="item.icon" /> + </div> + <div class="ivu-card-body"> + <div class="demo-color-name">{{ item.name }}</div> + <div class="demo-color-desc">#{{ item.qty }}</div> + </div> + </div> + </div> + </div> + + <div class="numbers"> + + <div class="item" v-for="index in 8" :key="index"> + <div class="number"> + <!-- {{value}} --> + {{index * 1000}} + </div> + <div>Order total</div> + </div> + </div> + + <div class="order-title"> + <h2>璁㈠崟鏌ヨ</h2> + </div> + + <div class="order-range"> + <div + class="order-item" + v-for="(item, index) in totalRange" + :key="index" + > + <div class="total"> + <div class="number"> + {{item.qty}} + </div> + </div> + <div class="name">{{ titleLeft + item.name }}</div> + <div class="date"> + {{ beginDate.replace(/-/g, ".") }} -- + {{ endDate.replace(/-/g, ".") }} + </div> + </div> + </div> + </div> + </div> +</template> +<script> + + +export default { + data() { + return { + beginDate: "", + endDate: "", + n: 90, + topColor: [ + { + name: "璁㈠崟鏁�", + desc: "#205", + background: "rgb(25, 190, 107)", + icon: "el-icon-shopping-cart-full", + qty: 6000, + key: "total", + }, + { + name: "宸蹭粯娆�", + desc: "#412", + background: "rgb(45, 183, 245)", + icon: "el-icon-wallet", + qty: 7100, + key: "total", + }, + { + name: "寰呭彂璐�", + desc: "#412", + background: "#f2b458", + icon: "el-icon-shopping-cart-1", + qty: 500, + key: "hasPay", + }, + { + name: "閰嶉�佷腑", + desc: "#412", + background: "rgb(84, 110, 122)", + icon: "el-icon-shopping-cart-2", + qty: 800, + key: "notShip", + }, + { + name: "宸插畬鎴�", + desc: "#412", + background: "rgb(45, 183, 245)", + icon: "el-icon-set-up", + qty: 1880, + key: "completed", + }, + { + name: "閫�璐ц鍗�", + desc: "#12", + background: "rgb(237, 64, 20)", + icon: "el-icon-data-analysis", + qty: 2290, + key: "refund", + }, + ], + totalRange: [ + { + name: "璁㈠崟鏁�", + desc: "#205", + background: "rgb(25, 190, 107)", + icon: "ios-cart", + qty: 1290, + key: "total", + }, + { + name: "宸蹭粯娆�", + desc: "#412", + background: "rgb(45, 183, 245)", + icon: "ios-cash", + qty: 3450, + key: "total", + }, + { + name: "寰呭彂璐�", + desc: "#412", + background: "rgb(255, 153, 0)", + icon: "md-bus", + qty: 200, + key: "hasPay", + }, + { + name: "閰嶉�佷腑", + desc: "#412", + background: " rgb(84, 110, 122)", + icon: "md-pin", + qty: 7000, + key: "notShip", + }, + { + name: "浜ゆ槗瀹屾垚", + desc: "#412", + background: "rgb(45, 183, 245)", + icon: "ios-help-buoy", + qty: 8900, + key: "completed", + }, + { + name: "閫�璐ц鍗�", + desc: "#12", + background: "rgb(237, 64, 20)", + icon: "ios-navigate", + qty: 2450, + key: "refund", + }, + ], + value1: "1", + titleLeft: "", + dateNow: "", + }; + }, + methods: { + getDate() { + var date = new Date(); + var year = date.getFullYear(); + var month = date.getMonth() + 1; + var day = date.getDate(); + var hour = date.getHours(); + var minutes = date.getMinutes(); + var second = date.getSeconds(); + this.beginDate = + year + + "-" + + (month < 10 ? "0" + month : month) + + "-" + + (day < 10 ? "0" + day : day); + this.endDate = this.beginDate; + this.dateNow = this.beginDate; + }, + search() { + if (this.dateNow == this.beginDate && this.dateNow == this.endDate) { + this.titleLeft = "浠婃棩"; + } else { + this.titleLeft = "褰撴湡"; + } + }, + }, + created() { + this.getDate(); + }, + mounted() {}, +}; +</script> +<style scoped> +.home-contianer { + background: #efefef; + width: 100%; + height: 100%; + /* padding: 20px; */ +} + +.ivu-card-body { + text-align: center; + padding: 20px 5px; + /* padding-left: 80px; */ + font-size: 16px; +} +.demo-color-name { + color: #fff; + font-size: 14px; +} +.demo-color-desc { + color: white; + /* opacity: 0.7; */ + font-size: 20px; + margin-top: 2px; +} +.ivu-card { + box-shadow: 0 3px 13px rgba(117, 114, 114, 0.47); + display: flex; + position: relative; + padding-top: 10px; + border-radius: 5px; +} +.ivu-card .icon-left { + width: 85px; +} +.ivu-card .ivu-card-body { + flex: 1; +} +.ivu-card .icon-left { + text-align: center; + border-right: 1px solid; + padding: 8px 0px; + height: 100%; + + font-size: 50px; + color: white; +} +.ivu-row { + border-bottom: 2px dotted #eee; + padding: 15px; + margin-bottom: 15px; + display: flex; +} + +.ivu-row > div { + flex: 1; +} + +.h5-desc { + padding-top: 10px; +} +</style> + +<style lang="less" scoped> +.jn-day-total { + display: flex; + padding: 15px; + background: white; + .date-text { + line-height: 36px; + padding: 0 15px; + } + .date { + margin-right: 20px; + } + .btn { + margin-left: 10px; + } +} +.order-title { + h2 { + padding: 7px 15px; + font-weight: 500; + background: white; + border-bottom: 1px dotted #d4d4d4; + } +} + +.order-range { + padding: 0 15px; + background: white; + background: white; + display: flex; + // flex-direction: row-reverse; +} + +.order-range .order-item { + box-shadow: 0 3px 13px rgba(117, 114, 114, 0.47); + flex: 1; + border-radius: 6px; + font-size: 14px; + text-align: center; + border: 1px solid #e6e6e6; + margin: 7px; +} + +.order-range .total { + color: white; + font-size: 50px; + font-weight: bold; + line-height: 100px; + background: #55ce80; + font-family: "Helvetica Neue", Helvetica, "PingFang SC", "Hiragino Sans GB", + "Microsoft YaHei", "寰蒋闆呴粦", Arial, sans-serif; +} +.order-range .number { + transition: transform 0.8s; +} +.order-range .number:hover { + cursor: pointer; + transform: scale(1.2); +} +.order-range .name { + font-size: 20px; + padding: 10px; +} + +.order-range .date { + padding: 1px 0 20px 0; + color: #9e9e9e; + font-size: 13px; +} +</style> + + +<style lang="less" scoped> +.numbers { + margin-bottom: 15px; + border-radius: 5px; + border: 1px solid #eaeaea; + background: white; + display: flex; + + padding: 20px 0px; + .item { + flex: 1; + text-align: center; + border-right: 1px solid #e5e5e5; + } + .item > 銆�div:first-child { + word-break: break-all; + color: #282727; + font-size: 30px; + // padding-bottom: 12px; + } + .item > 銆�div:last-child { + font-size: 13px; + color: #777; + } + .item:last-child { + border-right: none; + } + .number { + cursor: pointer; + transition: transform 0.8s; + } + .number:hover { + transform: scale(1.2); + color: #03c10b !important; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/formChart.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/formChart.vue" new file mode 100644 index 0000000..25d4f10 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/formChart.vue" @@ -0,0 +1,118 @@ +<template> + <div class="c-container"> + <div class="item"> + <div class="left"> + <VolHeader + icon="md-apps" + text="鏌辩姸鍥�" + style="padding-left: 10px; margin-bottom: 5px" + ></VolHeader> + <div style="height: calc(100% - 45px)" :id="bar"></div> + </div> + <div class="right"> + <VolHeader + icon="md-apps" + text="鍩虹琛ㄥ崟" + style="padding-left: 10px; margin-bottom: 20px" + ></VolHeader> + <VolForm + style="padding-right: 30px" + ref="myform1" + :loadKey="true" + :label-width="80" + :formFields="formFields1" + :formRules="formRules1" + ></VolForm> + </div> + </div> + + <div class="item"> + <div class="left"> + <VolHeader + icon="md-apps" + text="琛ㄥ崟灞炴�у瓧娈靛彧璇�" + style="padding-left: 10px; margin-bottom: 20px" + ></VolHeader> + <VolForm + style="padding-right: 30px" + ref="myform1" + :loadKey="true" + :formFields="formFields2" + :formRules="formRules2" + ></VolForm> + </div> + <div class="right"> + <VolHeader + icon="md-apps" + text="楗肩姸鍥捐〃" + style="padding-left: 10px" + ></VolHeader> + <div style="height: calc(100% - 30px)" :id="pie"></div> + </div> + </div> + </div> +</template> +<script> +import VolHeader from '@/components/basic/VolHeader.vue'; +import VolForm from '@/components/basic/VolForm.vue'; +let echarts = require('echarts'); +import options from './chartOptions'; +import { + formFields1, + formRules1, + formFields2, + formRules2 +} from './formOptions'; +export default { + components: { VolForm, VolHeader }, + data() { + return { + formFields1: formFields1, + formRules1: formRules1, + formFields2: formFields2, + formRules2: formRules2, + bar: 'b-' + ~~(Math.random(10000, 100000) * 100000), + pie: 'p-' + ~~(Math.random(10000, 100000) * 100000), + options: options + }; + }, + mounted() { + let $bar = echarts.init(document.getElementById(this.bar)); + $bar.setOption(this.options.bar); + + this.options.pie.legend.top = 50; + this.options.pie.legend.right = 80; + this.options.pie.legend.orient = 'vertical'; + let $pie = echarts.init(document.getElementById(this.pie)); + $pie.setOption(this.options.pie); + } +}; +</script> +<style lang="less" scoped> +.c-container { + position: absolute; + height: 100%; + width: 100%; + background: #f1f1f1; + display: flex; + flex-direction: column; + padding: 3px; + .item { + flex:1; + height:0; + display: flex; + > div { + flex: 1; + width: 0; + // margin: 10px; + background: #fff; + } + .left { + margin: 4px; + } + .right { + margin: 4px; + } + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/formOptions.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/formOptions.js" new file mode 100644 index 0000000..8e17aa9 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/charts/formOptions.js" @@ -0,0 +1,148 @@ +let formFields1 = { + Variety: "", + AgeRange: "", + DateRange: [], + City: "", + AvgPrice: 8.88, + Date: "", + IsTop: "杩樻病鎯冲ソ..." +} +let formRules1 = [ + //涓ゅ垪鐨勮〃鍗曪紝formRules鏁版嵁鏍煎紡涓�:[[{},{}]] + [ + { + link:true, + dataKey: "city", + title: "鍩庡競", + required: true, + field: "City", + data: [], + type: "select" + }, + { + title: "澶氶�夋棩鏈�", + range: true, //璁剧疆涓簍rue鍙互閫夋嫨寮�濮嬩笌缁撴潫鏃ユ湡 + required: false, + field: "DateRange", + // colSize: 4,//璁剧疆瀹藉害涓�1/3 + type: "date" + } + ], + [ + { + dataKey: "age", //鍚庡彴涓嬫媺妗嗗搴旂殑鏁版嵁瀛楀吀缂栧彿 + data: [], //loadKey璁剧疆涓簍rue,浼氭牴鎹甦ataKey浠庡悗鍙扮殑涓嬫媺妗嗘暟鎹簮涓嚜鍔ㄥ姞杞芥暟鎹� + title: "涓嬫媺", + required: true, //璁剧疆涓哄繀閫夐」 + field: "AgeRange", + type: "select" + }, + { + title: "鏃ユ湡", + required: true, + field: "Date", + placeholder: "浣犲彲浠ヨ缃甤olSize灞炴�у喅瀹氭爣绛剧殑闀垮害锛屽彲閫夊��12/8/6/4", + // colSize: 8,//璁剧疆瀹藉害涓�2/3 + type: "datetime" + } + ], + [ + { + title: "娴嬭瘯", + dataKey: "age", + placeholder: "姝ゅ鏁版嵁婧愪负鎵嬪姩缁戝畾", + //濡傛灉杩欓噷缁戝畾浜哾ata鏁版嵁锛屽悗鍙颁笉浼氬姞杞芥鏁版嵁婧� + data: [{ key: "1", value: "娴嬭瘯1" }, { key: "2", value: "娴嬭瘯2" }], + required: false, + field: "Variety", + type: "select" + }, + { + type: "decimal", + title: "浠锋牸", + required: true, + placeholder: "浣犲彲浠ヨ嚜宸卞畾涔塸laceholder鏄剧ず鐨勬枃瀛�", + field: "AvgPrice" + } + ], + [ + { + title: "澶囨敞", + required: true, + field: "IsTop", + colSize: 12, //璁剧疆12锛屾鍒楀崰100%瀹藉害 + type: "textarea" + } + ] +] + +let formFields2 = { + Variety: "涓�娆℃�х敤鍝�", + City: "鍖椾含甯�", + DateRange: "2019-09-01", + AvgPrice: 8.88, + Variety1: "", + DateRange1: "2019-09-02", + AvgPrice1: 7.72, + Address:"鍖椾含甯傛捣娣�鍖�001鍙�", + IsChange: 1 +} +let formRules2 = [ + //涓ゅ垪鐨勮〃鍗曪紝formRules鏁版嵁鏍煎紡涓�:[[{},{}]] + [ + { + title: "鍟嗗搧绫诲瀷", + dataKey: "age", + //濡傛灉杩欓噷缁戝畾浜哾ata鏁版嵁锛屽悗鍙颁笉浼氬姞杞芥鏁版嵁婧� + data: [{ key: "1", value: "1" }, { key: "2", value: "2" }], + field: "Variety", + disabled: true, + type: "select" + }, + { + dataKey: "city", + title: "鎵�鍦ㄥ煄甯�", + field: "City", + disabled: true, + type: "select", + data: [] + }], + [ + { + title: "閿�鍞棩鏈�", + field: "DateRange", + disabled: true, + }, + { + title: "閿�鍞环鏍�", + field: "AvgPrice", + disabled: true + }], + [ + { + title: "鐢熶骇鏃ユ湡", + field: "DateRange1", + disabled: true, + }, + { + title: "涓棿浠锋牸", + field: "AvgPrice1", + disabled: true + }], + [ + { + title: "閿�鍞湴鍧�", + field: "Address", + disabled: true, + }, + { + title: "鏄惁鎴愪氦", + field: "IsChange", + dataKey: "enable",//杩欓噷璁剧疆浜嗘暟鎹瓧鍏告簮鐨勭紪鍙蜂細鑷姩浠庡悗鍙板姞杞芥暟鎹簮鐨刱ey/value + data: [], + disabled: true + }] +] + + +export { formFields1, formRules1, formFields2, formRules2 } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/home/home-chart-options.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/home/home-chart-options.js" new file mode 100644 index 0000000..3eaf63d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/home/home-chart-options.js" @@ -0,0 +1,248 @@ +var chart1 = { + title: { + text: "妗嗘灦闆嗘垚鍙婂紑鍙戠幆澧�", + left: 'center', + padding: 15, + }, + tooltip: { + trigger: 'item' + }, + legend: { + top: 'bottom', + icon: "circle", // 杩欎釜瀛楁鎺у埗褰㈢姸 绫诲瀷鍖呮嫭 circle锛宺ect 锛宺oundRect锛宼riangle锛宒iamond锛宲in锛宎rrow锛宯one + itemWidth: 10, // 璁剧疆瀹藉害 + itemHeight: 10, // 璁剧疆楂樺害 + itemGap: 7,// 璁剧疆闂磋窛 + padding: [0, 0, 15, 0] //鍥句緥璺濈 + }, + series: [ + { + name: '妗嗘灦', + type: 'pie', + radius: ['40%', '65%'], + avoidLabelOverlap: false, + itemStyle: { + borderRadius: 10, + borderColor: '#fff', + borderWidth: 2 + }, + label: { + show: false, + position: 'center' + }, + emphasis: { + label: { + show: true, + fontSize: '40', + fontWeight: 'bold' + } + }, + labelLine: { + show: false + }, + data: [ + { value: 1048, name: '.NetCore' }, + { value: 735, name: 'Dapper' }, + + { value: 735, name: 'EntityFramework' }, + // { value: 735, name: 'JWT' }, + { value: 735, name: 'Redis' }, + { value: 735, name: 'Vue3.0' }, + { value: 580, name: 'Vuex' }, + { value: 484, name: 'Element plus' } + ] + } + ] +} + +var chart2 = { + title: { + text: '杩欓噷鏄椤�' + }, + tooltip: { + trigger: 'axis', + axisPointer: { // 鍧愭爣杞存寚绀哄櫒锛屽潗鏍囪酱瑙﹀彂鏈夋晥 + type: 'shadow' // 榛樿涓虹洿绾匡紝鍙�変负锛�'line' | 'shadow' + } + }, + legend: { + data: ['2.0涓嬭浇閲�', '3.0涓嬭浇閲�'], + padding: [0, 0, 15, 0] //鍥句緥璺濈 + }, + grid: { + left: '3%', + right: '4%', + bottom: '3%', + top:'13%', + containLabel: true + }, + xAxis: [ + { + type: 'category', + data: [ '2015', '2016', '2017', '2018', '2019', '2020', '2021'] + } + ], + yAxis: [ + { + type: 'value' + } + ], + series: [ + { + name: '2.0涓嬭浇閲�', + type: 'bar', + showBackground: true, + backgroundStyle: { + color: 'rgba(180, 180, 180, 0.2)' + }, + itemStyle: { + + normal: { + barBorderRadius: [4, 4, 0, 0] + } + }, + data: [ 730, 620, 420, 932, 701, 834, 890] + }, + { + name: '3.0涓嬭浇閲�', + type: 'bar', + + showBackground: true, + backgroundStyle: { + color: 'rgba(180, 180, 180, 0.2)' + }, + data: [230, 210, 120, 132, 101, 134, 90] + } + ] +} +var chart3 = { + title: { + text: '妗嗘灦鏀寔鍔熻兘(Vue2.0銆乂ue3.0鐗堟湰)', + left: 'center' + }, + tooltip: { + trigger: 'item' + }, + legend: { + top: 'bottom', + icon: "circle", // 杩欎釜瀛楁鎺у埗褰㈢姸 绫诲瀷鍖呮嫭 circle锛宺ect 锛宺oundRect锛宼riangle锛宒iamond锛宲in锛宎rrow锛宯one + itemWidth: 10, // 璁剧疆瀹藉害 + itemHeight: 10, // 璁剧疆楂樺害 + itemGap: 7,// 璁剧疆闂磋窛 + padding: [0, 0, 10, 0] //鍥句緥璺濈 + }, + series: [ + { + + name: '妗嗘灦鏀寔鍔熻兘(Vue2.0銆乂ue3鐗堟湰)', + type: 'pie', + radius: '55%', + data: [ + { value: 748, name: '澶氱鎴�' }, + { value: 435, name: '澶氳鑹�' }, + { value: 580, name: '澶氭暟鎹簱' }, + { value: 280, name: '涓讳粠鍒嗗簱' }, + { value: 284, name: '鍥介檯鍖�' }, + { value: 300, name: 'App/H5寮�鍙�' }, + { value: 200, name: 'Redis' }, + { value: 600, name: 'Sqlserver' }, + { value: 400, name: 'Mysql' }, + { value: 100, name: 'Oracle' }, + ], + emphasis: { + itemStyle: { + shadowBlur: 10, + shadowOffsetX: 0, + shadowColor: 'rgba(0, 0, 0, 0.5)' + } + } + } + ] +} +var chart4={ + tooltip: { + trigger: 'axis', + axisPointer: { + // Use axis to trigger tooltip + type: 'shadow' // 'shadow' as default; can also be 'line' or 'shadow' + } + }, + legend: {}, + grid: { + left: '3%', + right: '4%', + bottom: '3%', + top:'13%', + containLabel: true + }, + xAxis: { + type: 'value' + }, + yAxis: { + type: 'category', + data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] + }, + series: [ + { + name: 'Direct', + type: 'bar', + stack: 'total', + label: { + show: true + }, + emphasis: { + focus: 'series' + }, + data: [320, 302, 301, 334, 390, 330, 320] + }, + { + name: 'Mail Ad', + type: 'bar', + stack: 'total', + label: { + show: true + }, + emphasis: { + focus: 'series' + }, + data: [120, 132, 101, 134, 90, 230, 210] + }, + { + name: 'Affiliate Ad', + type: 'bar', + stack: 'total', + label: { + show: true + }, + emphasis: { + focus: 'series' + }, + data: [220, 182, 191, 234, 290, 330, 310] + }, + { + name: 'Video Ad', + type: 'bar', + stack: 'total', + label: { + show: true + }, + emphasis: { + focus: 'series' + }, + data: [150, 212, 201, 154, 190, 330, 410] + }, + { + name: 'Search Engine', + type: 'bar', + stack: 'total', + label: { + show: true + }, + emphasis: { + focus: 'series' + }, + data: [820, 832, 901, 934, 1290, 1330, 1320] + } + ] + } +export { chart1, chart2, chart3,chart4 } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/inboundOrder.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/inboundOrder.vue" new file mode 100644 index 0000000..f4929a5 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/inboundOrder.vue" @@ -0,0 +1,319 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/inbound/inboundOrder.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "鍏ュ簱鍗�", + name: "inboundOrder", + url: "/InboundOrder/", + sortName: "CreateDate", + }); + const editFormFields = ref({ + orderType: "", + orderNo:"", + upperOrderNo: "", + remark: "", + }); + const editFormOptions = ref([ + [ + { + title: "鍗曟嵁绫诲瀷", + required: true, + field: "orderType", + type: "select", + dataKey: "inOrderType", + data: [], + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "string", + }, + { + title: "涓婃父鍗曟嵁缂栧彿", + field: "upperOrderNo", + type: "string", + }, + { + title: "澶囨敞", + field: "remark", + type: "textarea", + }, + ], + ]); + const searchFormFields = ref({ + orderNo: "", + upperOrderNo: "", + orderType: "", + orderStatus: "", + createType: "", + creater: "", + createDate: "", + }); + const searchFormOptions = ref([ + [ + { title: "鍗曟嵁缂栧彿", field: "orderNo", type: "like" }, + { title: "涓婃父鍗曟嵁缂栧彿", field: "upperOrderNo", type: "like" }, + { + title: "鍗曟嵁绫诲瀷", + field: "orderType", + type: "select", + dataKey: "inOrderType", + data: [], + }, + { + title: "鍗曟嵁鐘舵��", + field: "orderStatus", + type: "select", + dataKey: "inboundState", + data: [], + }, + ], + [ + { + title: "鍒涘缓鏂瑰紡", + field: "createType", + type: "select", + dataKey: "createType", + data: [], + }, + { title: "鍒涘缓鑰�", field: "creater", type: "like" }, + { title: "鍒涘缓鏃堕棿", field: "createDate", type: "datetime" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "string", + width: 120, + align: "left", + link: true, + }, + { + field: "upperOrderNo", + title: "涓婃父鍗曟嵁缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "orderType", + title: "鍗曟嵁绫诲瀷", + type: "string", + width: 150, + align: "left", + bind: { key: "inOrderType", data: [] }, + }, + { + field: "orderStatus", + title: "鍗曟嵁鐘舵��", + type: "decimal", + width: 90, + align: "left", + bind: { key: "inboundState", data: [] }, + }, + { + field: "createType", + title: "鍒涘缓鏂瑰紡", + type: "string", + width: 90, + align: "left", + bind: { key: "createType", data: [] }, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "鍏ュ簱鍗曟槑缁�", + table: "InboundOrderDetail", + columns: [ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "orderId", + title: "鍏ュ簱鍗曚富閿�", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "select", + width: 150, + align: "left", + edit: { type: "" }, + required: true, + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + align: "left", + edit: { type: "" }, + }, + { + field: "batchNo", + title: "鎵规鍙�", + type: "decimal", + width: 90, + align: "left", + edit: { type: "" }, + required: true, + }, + { + field: "orderQuantity", + title: "鍗曟嵁鏁伴噺", + type: "decimal", + width: 90, + align: "left", + edit: { type: "number" }, + required: true, + }, + { + field: "receiptQuantity", + title: "缁勭洏鏁伴噺", + type: "int", + width: 120, + align: "left", + }, + { + field: "overInQuantity", + title: "涓婃灦鏁伴噺", + type: "string", + width: 200, + align: "left", + }, + { + field: "orderDetailStatus", + title: "璁㈠崟鏄庣粏鐘舵��", + type: "string", + width: 180, + align: "left", + bind: { key: "orderDetailStatusEnum", data: [] }, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ], + sortName: "id", + key: "id", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/inboundOrderDetail.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/inboundOrderDetail.vue" new file mode 100644 index 0000000..5046820 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/inboundOrderDetail.vue" @@ -0,0 +1,221 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> + </template> + <script> + import extend from "@/extension/inbound/inboundOrderDetail.js"; + import { ref, defineComponent } from "vue"; + export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "鍏ュ簱鍗曟槑缁�", + name: "inboundOrderDetail", + url: "/InboundOrderDetail/", + sortName: "id", + }); + const editFormFields = ref({ + deviceCode: "", + deviceName: "", + deviceType: "", + deviceStatus: "", + deviceIp: "", + devicePort: "", + devicePlcType: "", + deviceRemark: "", + }); + const editFormOptions = ref([ + [ + { + title: "璁惧缂栧彿", + required: true, + field: "deviceCode", + type: "string", + }, + { + title: "璁惧鍚嶇О", + required: true, + field: "deviceName", + type: "string", + }, + { + title: "璁惧绫诲瀷", + required: true, + field: "deviceType", + type: "string", + }, + { + title: "璁惧鐘舵��", + required: true, + field: "deviceStatus", + type: "string", + }, + ], + [ + { title: "璁惧IP", required: true, field: "deviceIp", type: "string" }, + { + title: "璁惧绔彛", + required: true, + field: "devicePort", + type: "string", + }, + { + title: "PLC绫诲瀷", + required: true, + field: "devicePlcType", + type: "string", + }, + { + title: "澶囨敞", + field: "deviceRemark", + type: "string", + }, + ], + ]); + const searchFormFields = ref({ + deviceCode: "", + deviceType: "", + deviceStatus: "", + }); + const searchFormOptions = ref([ + [ + { title: "璁惧缂栧彿", field: "deviceCode" }, + { title: "璁惧绫诲瀷", field: "deviceType" }, + { title: "璁惧鐘舵��", field: "deviceStatus" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "orderId", + title: "鍏ュ簱鍗曚富閿�", + type: "string", + width: 90, + align: "left", + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + align: "left", + }, + { + field: "batchNo", + title: "鎵规鍙�", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "orderQuantity", + title: "鍗曟嵁鏁伴噺", + type: "string", + width: 90, + align: "left", + }, + { + field: "receiptQuantity", + title: "缁勭洏鏁伴噺", + type: "int", + width: 120, + align: "left", + }, + { + field: "overInQuantity", + title: "涓婃灦鏁伴噺", + type: "string", + width: 200, + align: "left", + }, + { + field: "orderDetailStatus", + title: "璁㈠崟鏄庣粏鐘舵��", + type: "string", + width: 180, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, + }); + </script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/receiveOrder.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/receiveOrder.vue" new file mode 100644 index 0000000..bfcb977 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/inbound/receiveOrder.vue" @@ -0,0 +1,376 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/inbound/receiveOrder.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "receiveOrderId", + footer: "Foots", + cnName: "鏀惰揣鍗�", + name: "receiveOrder", + url: "/ReceiveOrder/", + sortName: "CreateDate", + }); + + const searchFormFields = ref({ + orderNo: "", + upperOrderNo: "", + orderType: "", + orderStatus: "", + createType: "", + creater: "", + createDate: "", + }); + const searchFormOptions = ref([ + [ + { title: "鍗曟嵁缂栧彿", field: "orderNo", type: "like" }, + { + title: "鍗曟嵁绫诲瀷", + field: "orderType", + type: "select", + dataKey: "inOrderType", + data: [], + }, + { + title: "鍗曟嵁鐘舵��", + field: "orderStatus", + type: "select", + dataKey: "inboundState", + data: [], + }, + ], + [ + { title: "鍒涘缓鑰�", field: "creater", type: "like" }, + { title: "鍒涘缓鏃堕棿", field: "createDate", type: "datetime" }, + ], + ]); + + const editFormFields = ref({ + receiveOrderNo: "", + receiveOrderType: "", + suppliersId: "", + warehouseId: "", + deliveryCode: "", + }); + const editFormOptions = ref([ + [ + { + field: "receiveOrderNo", + title: "鍗曟嵁缂栧彿", + type: "string", + readonly: "true", + }, + { + title: "鍗曟嵁绫诲瀷", + required: true, + field: "receiveOrderType", + type: "select", + dataKey: "receiveOrderTypeEnum", + data: [], + }, + { + title: "渚涘簲鍟�", + field: "suppliersId", + type: "select", + dataKey: "suppliers", + data: [], + required: true, + }, + { + title: "浠撳簱", + field: "warehouseId", + type: "select", + dataKey: "warehouses", + data: [], + required: true, + }, + ], + [ + { + title: "閫佽揣鍗曞彿", + field: "deliveryCode", + type: "string", + }, + ], + ]); + const columns = ref([ + { + field: "receiveOrderId", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "receiveOrderNo", + title: "鏀惰揣鍗曞彿", + type: "string", + width: 150, + align: "left", + link: true, + }, + { + field: "receiveOrderType", + title: "璁㈠崟绫诲瀷", + type: "string", + width: 150, + align: "left", + bind: { key: "receiveOrderTypeEnum", data: [] }, + }, + { + field: "receiveOrderStatus", + title: "璁㈠崟鐘舵��", + type: "string", + width: 150, + align: "left", + }, + { + field: "customerId", + title: "瀹㈡埛浠e彿", + type: "string", + width: 90, + align: "left", + }, + { + field: "suppliersId", + title: "渚涘簲鍟嗕唬鍙�", + type: "string", + width: 90, + align: "left", + }, + { + field: "warehouseId", + title: "浠撳簱涓婚敭", + type: "string", + width: 90, + align: "left", + }, + { + field: "receiveDate", + title: "鏀惰揣鏃ユ湡", + type: "string", + width: 90, + align: "left", + }, + { + field: "deliveryCode", + title: "閫佽揣鍗曞彿", + type: "string", + width: 90, + align: "left", + }, + { + field: "uploadStatus", + title: "涓婁紶鐘舵��", + type: "string", + width: 90, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "鏀惰揣鍗曟槑缁�", + table: "Dt_ReceiveOrderDetail", + columns: [ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "orderId", + title: "鏀惰揣鍗曚富閿�", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "rowNo", + title: "琛屽彿", + type: "string", + width: 60, + align: "left", + }, + { + field: "purchaseOrderNo", + title: "閲囪喘鍗曞彿", + type: "select", + width: 160, + align: "left", + edit: { type: "" }, + required: true, + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "select", + width: 150, + align: "left", + edit: { type: "" }, + required: true, + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + align: "left", + edit: { type: "" }, + }, + { + field: "lotNo", + title: "鎵规鍙�", + type: "decimal", + width: 90, + align: "left", + edit: { type: "" }, + required: true, + }, + { + field: "receivedQty", + title: "鏀惰揣鏁伴噺", + type: "decimal", + width: 90, + align: "left", + edit: { type: "number" }, + required: true, + }, + { + field: "ifInspection", + title: "鏄惁妫�楠�", + type: "int", + width: 90, + align: "left", + }, + { + field: "priceInTax", + title: "鍚◣浠锋牸", + type: "string", + width: 90, + align: "left", + }, + { + field: "taxRate", + title: "绋庣巼", + type: "string", + width: 90, + align: "left", + }, + { + field: "currCode", + title: "甯佸埆缂栫爜", + type: "string", + width: 90, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ], + sortName: "id", + key: "id", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/Message.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/Message.vue" new file mode 100644 index 0000000..136d07b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/Message.vue" @@ -0,0 +1,104 @@ +<template> + <div class="message-container"> + <div class="item" v-for="(item, index) in list" :key="index"> + <div class="title">{{ item.title }}({{ item.date }})</div> + <div class="content"> + <el-row> + <el-col :span="6"> + <label>鏀惰揣鍗曞彿锛歿{ item.formData.receiveOrderNo }}</label> + </el-col> + <el-col :span="6"> + <label>璐ㄦ鍗曞彿锛歿{ item.formData.checkOrderNo }}</label> + </el-col> + <el-col :span="6"> + <label>鏀惰揣鏄庣粏琛屽彿锛歿{ item.formData.receiveDetailRowNo }}</label> + </el-col> + <el-col :span="6"> + <label>鐗╂枡缂栧彿锛歿{ item.formData.materielCode }}</label> + </el-col> + </el-row> + <el-row> + <el-col :span="6"> + <label>鍚堟牸鏁伴噺锛歿{ item.formData.qualifiedQuantity }}</label> + </el-col> + <el-col :span="6"> + <label>鐗归噰鏁伴噺锛歿{ item.formData.defectedQuantity }}</label> + </el-col> + <el-col :span="6"> + <label>閫�璐ф暟閲忥細{{ item.formData.returnQuantity }}</label> + </el-col> + <el-col :span="6"> + <label>鎶ュ簾鏁伴噺锛歿{ item.formData.scrappedQuantity }}</label> + </el-col> + </el-row> + <el-row> + <el-col :span="6"> + <label>璐ㄦ鎬绘暟锛歿{ item.formData.receivedQuantity }}</label> + </el-col> + <el-col :span="6"> + <label>鐗归噰璇存槑锛歿{ item.formData.defectedNote }}</label> + </el-col> + <el-col :span="6"> + <label>妫�楠屼汉锛歿{ item.formData.checkUserName }}</label> + </el-col> + </el-row> + </div> + <div style="margin-top: 20px"> + <el-button type="primary">鍚屾剰</el-button + ><el-button type="danger">椹冲洖</el-button> + </div> + </div> + </div> +</template> + +<script> +export default { + props: { + list: { + type: Array, + default: () => { + return []; + }, + }, + }, + created() { + if (!this.list.length) { + this.list.push({ + title: "IQC璐ㄦ缁撴灉瀹℃壒", + formData: { + receiveOrderNo: "鏀惰揣鍗曞彿", + checkOrderNo: "璐ㄦ鍗曞彿", + receiveDetailRowNo: "鏀惰揣鏄庣粏琛屽彿", + materielCode: "鐗╂枡缂栧彿", + qualifiedQuantity: "鍚堟牸鏁伴噺", + defectedQuantity: "鐗归噰鏁伴噺", + returnQuantity: "閫�璐ф暟閲�", + scrappedQuantity: "鎶ュ簾鏁伴噺", + receivedQuantity: "璐ㄦ鎬绘暟", + defectedNote: "鐗归噰璇存槑", + checkUserName: "妫�楠屼汉", + message: "娑堟伅娴嬭瘯鍐呭娑堟伅娴嬭瘯鍐呭娑堟伅娴嬭瘯鍐呭娑堟伅娴嬭瘯鍐呭", + }, + + date: "2022-05-02 03:10", + }); + } + }, +}; +</script> +<style scoped lang="less"> +.message-container { + .title { + padding-bottom: 10px; + font-weight: bold; + } + .item { + border-bottom: 1px solid #eee; + padding: 10px 20px; + } + .content { + color: #1b1b1b; + font-size: 14px; + } +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/MessageConfig.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/MessageConfig.js" new file mode 100644 index 0000000..0f18350 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/MessageConfig.js" @@ -0,0 +1,28 @@ +import * as signalR from '@microsoft/signalr'; +import { ElNotification } from 'element-plus'; + +export default function (http, receive) { + let connection; + http.post('api/User/GetCurrentUserInfo').then((result) => { + connection = new signalR.HubConnectionBuilder() + .withAutomaticReconnect() + .withUrl(`${http.ipAddress}message?userName=${result.data.userName}`) + //.withUrl(`${http.ipAddress}message`) + .build(); + + connection.start().catch((err) => console.log(ex.message)); + //鑷姩閲嶈繛鎴愬姛鍚庣殑澶勭悊 + connection.onreconnected((connectionId) => { + console.log(connectionId); + }); + connection.on('ReceiveHomePageMessage', function (data) { + console.log(data) + ElNotification.success({ + title:data.title, + message: data.message + '', + type: 'info' + }); + receive && receive(data); + }); + }); +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/index.less" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/index.less" new file mode 100644 index 0000000..c872e91 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/index/index.less" @@ -0,0 +1,644 @@ +.vol-aside { + height: 100%; + position: absolute; + float: left; + overflow: hidden; +} + +.vol-menu { + border: 0 !important; +} + +.vol-aside .tac { + text-align: left; +} + +.vol-aside .header { + text-align: center; + position: absolute; + height: 60px; + position: relative; + line-height: 60px; +} + +.vol-aside .vol-menu { + position: absolute; + width: 100%; + top: 60px; + bottom: 0; + background: white; + border-right: 1px solid #e3e3e3; +} + +.vol-aside .vol-menu ::v-deep(.ivu-menu) { + text-align: left; + position: unset; + width: 100% !important; +} + +.vol-aside .vol-menu ::v-deep(.is-horizontal) { + display: none !important; +} + +.vol-aside .vol-menu ::v-deep(.is-vertical) { + width: 2px; + right: -1px; +} + +.vol-container { + min-width: 800px; + right: 0; + display: inline-block; + position: absolute; + margin: 0; + box-sizing: border-box; + height: 100%; +} + +.vol-container .vol-path { + position: relative; + width: 100%; + display: inline-block; + border-bottom: 1px solid #eee; +} + +.vol-container .vol-path span { + position: relative; + margin-right: 10px; + color: #969696; +} + +.vol-header { + height: 61px; + width: 100%; + position: relative; + display: flex; + border-bottom: 1px solid #eee; +} + +.vol-main { + border-left: 1px solid #eee; + position: absolute; + width: 100%; + bottom: 0; + top: 95px; + margin: 0; + overflow: auto; +} + +.header { + padding: 5px; +} + +.header img { + height: 100%; + margin-right: 25px; +} + +.header-info { + padding-right: 20px; + display: inline-block; + // position: absolute; + height: 100%; +} + +.header-info > div { + float: left; + height: 100%; +} + +.user-header { + background: white; + height: 52px; + width: 52px; + border-radius: 50%; + margin-right: 0px; + top: 4px; + left: 7px; + position: relative; + border: 1px solid #dfdfdf; +} + +.project-name { + line-height: 60px; + padding: 0 50px 0 20px; + color: #fff; + font-size: 16px; + letter-spacing: 1px; +} + +.header-text { + vertical-align: middle; + height: 100%; + // position: absolute; + flex: 1; + text-align: left; + font-size: 15px; + left: 21px; + line-height: 60px; + letter-spacing: 1px; +} + +.vol-header .user { + text-align: left; + padding: 0 12px; + position: relative; + height: 100%; + display: flex; + flex-direction: column; + // height: 60px; + justify-content: center; + span:last-child { + font-size: 12px; + } +} + +.vol-header .settings { + padding-top: 10px; + color: #d4d2d2; +} + +.vol-header .user span { + position: relative; +} + +.header-info:hover { + cursor: pointer; +} + +.header-navigation { + cursor: pointer; + box-shadow: none; + border-bottom: 1px solid #eee; + height: 34px; + /* overflow: hidden; */ + line-height: 35px; + display: block; + margin: 0; + padding: 0; + outline: 0; + list-style: none; + position: relative; + z-index: 900; + font-weight: initial; + margin-top: -1px; +} + +.el-tabs--border-card { + border: none; +} + +.header-navigation ::v-deep(.el-tabs__item) { + height: 34px; + font-size: 14px; + line-height: 34px; + padding-bottom: 6px; + color: #525252 !important; + position: relative; + margin: 0 4px; + border: 1px solid #e2e2e2; + border-top-right-radius: 4px; + border-top-left-radius: 4px; + // border-bottom: 0px; +} + +.header-navigation ::v-deep(.el-tabs__item.is-active) { + color: #1a81ea !important; +} + +.header-navigation ::v-deep(.el-tabs__nav-prev), +.header-navigation ::v-deep(.el-tabs__nav-next) { + line-height: 35px; + padding-left: 4px; +} + +.vol-header .user span:first-child { + font-size: 15px; + font-weight: bolder; +} + +.h-link { + line-height: 59px; +} + +.h-link a { + font-size: 14px; + text-decoration: none; + padding: 0px 15px; + /* height: 60px; */ + display: inline-block; +} + +img[src=''], +img:not([src]) { + opacity: 0; +} + +//榛戣壊 +.vol-theme-dark { + .header { + background: #101010; + } + + .header-text { + color: white; + } + + .vol-header { + background-color: #272929; + } + + .h-link a:hover { + background: #0c0202; + } + + a { + color: #f2f2f2; + } + + .h-link a:hover { + color: #dfdfdf; + } + + .h-link .actived { + border-bottom: 2px solid white; + } + + .h-link .actived a { + color: white !important; + } + + .vol-header .user { + color: #ececec; + } + + .vol-header .settings { + color: #d4d2d2; + } + + .vol-aside .vol-menu { + background: black; + } +} + +.vol-theme-white .vol-aside ::v-deep(.vol-el-menu-item) { + background: #2e333b; + color: white; +} + +.vol-theme-dark .vol-aside ::v-deep(.vol-menu .el-submenu) { + background: black; +} + +.vol-theme-dark .vol-aside ::v-deep(.vol-menu .el-sub-menu__title *) { + color: #d6d6d6; +} + +.vol-theme-dark .vol-aside ::v-deep(.vol-el-menu-item .el-menu-item) { + color: #eee; + background: #1f1f1f; +} + +.vol-theme-dark .vol-aside ::v-deep(.vol-el-menu-item .el-menu-item.is-active), +.vol-theme-dark .vol-aside ::v-deep(.menu-item-lv1) { + background: black; +} + +.vol-theme-dark .vol-aside ::v-deep(.menu-item-lv1) { + background: black; + color: #d6d6d6; +} + +.vol-theme-dark .vol-aside ::v-deep(.vol-el-menu-item .el-menu-item:hover) { + background: black; +} + +.vol-theme-dark .vol-aside ::v-deep(.el-sub-menu__title) { + background-color: black; +} + +.vol-theme-dark .vol-aside ::v-deep(.el-sub-menu__title:hover) { + background-color: rgb(25, 25, 25); +} + +.vol-theme-dark .vol-aside ::v-deep(.el-sub-menu__title:hover *) { + color: white; +} + +.vol-theme-red, +.vol-theme-red2 { + .vol-header { + background-color: rgb(237, 64, 20); + } + + .header-text { + color: #dcdfe6; + } + + .h-link a:hover { + background: #d71212; + } + + .h-link .actived { + border-bottom: 2px solid white; + } + + .h-link a, + .h-link .actived a, + .vol-header .settings, + .vol-header .user { + color: white; + } + + .vol-header .header-text { + color: #fbfbfb; + } +} + +.vol-theme-red { + .header { + background-color: rgb(237, 64, 20); + } +} + +.vol-theme-red2 { + .header { + background-color: #a90000; + } +} + +.vol-theme-orange, +.vol-theme-orange2 { + .header-text { + color: #dcdfe6; + } + + .vol-header { + background-color: rgb(255, 153, 0); + } + + .h-link a:hover { + background: #c97901; + } + + .h-link .actived { + border-bottom: 2px solid white; + } + + .h-link a, + .h-link .actived a, + .vol-header .settings, + .vol-header .user { + color: white; + } + + .vol-header .header-text { + color: #fbfbfb; + } +} + +.vol-theme-orange { + .header { + background: rgb(255, 153, 0); + } +} + +.vol-theme-orange2 { + .header { + background-color: rgb(232, 141, 5); + } +} + +//缁胯壊 +.vol-theme-green, +.vol-theme-green2 { + .header-text { + color: #dcdfe6; + } + + .vol-header { + background-color: rgb(25, 190, 107); + } + + .h-link a:hover { + background: #329103; + } + + .h-link .actived { + border-bottom: 2px solid white; + } + + .h-link a, + .h-link .actived a, + .vol-header .settings, + .vol-header .user { + color: white; + } + + .vol-header .header-text { + color: #fbfbfb; + } +} + +.vol-theme-green { + .header { + background: rgb(25, 190, 107); + } +} + +.vol-theme-green2 { + .header { + background-color: rgb(1, 158, 79); + } +} + +//钃濊壊 +.vol-theme-blue, +.vol-theme-blue2 { + .header-text { + color: #dcdfe6; + } + + .vol-header { + background-color: rgb(45, 140, 240); + } + + .h-link a:hover { + background: #0170e3; + } + + .h-link .actived { + border-bottom: 2px solid white; + } + + .h-link a, + .h-link .actived a, + .vol-header .settings, + .vol-header .user { + color: white; + } + + .vol-header .header-text { + color: #fbfbfb; + } +} + +.vol-theme-blue { + .header { + background-color: rgb(45, 140, 240); + } +} + +.vol-theme-blue2 { + .header { + background-color: rgb(0, 104, 214); + } +} + +//鐧借壊 +.vol-theme-white { + .header { + background-color: #434956; + } + + .h-link a:hover { + background: #eeeeee; + } + + .h-link a { + color: #211f1f; + } + + .header-navigation { + // box-shadow: -7px 11px 10px -13px #678aa7; + border-bottom: 1px solid #eee; + height: 32px; + overflow: hidden; + line-height: 32px; + display: block; + margin: 0; + padding: 0; + outline: 0; + list-style: none; + position: relative; + z-index: 900; + font-weight: 400; + } + + .vol-aside .vol-menu { + background: #353941; + } +} + +.vol-theme-white .project-name { + color: #505050; +} + +.vol-theme-white .vol-aside::v-deep(.vol-el-menu-item .el-menu-item.is-active), +.vol-theme-white .vol-aside ::v-deep(.menu-item-lv1) { + background: #353941; +} + +.vol-theme-white .vol-aside ::v-deep(.menu-item-lv1) { + background: #353941; + color: #d6d6d6; +} + +.vol-theme-white .vol-aside ::v-deep(.vol-el-menu-item .el-menu-item:hover) { + background: #353941; +} + +.vol-theme-white .vol-aside ::v-deep(.el-sub-menu__title) { + background-color: #353941; +} + +.vol-theme-white .vol-aside ::v-deep(.el-sub-menu__title:hover) { + background-color: rgb(47, 46, 46); +} + +.vol-theme-white .vol-aside ::v-deep(.el-sub-menu__title), +.vol-theme-white .vol-aside ::v-deep(.el-menu-item), +.vol-theme-white .vol-aside ::v-deep(.el-sub-menu__title:hover *) { + color: #bababa; +} + +// .vol-theme-white .vol-aside ::v-deep(.vol-el-menu-item) { +// background: #363e4f; +// color: white; +// } +// .vol-theme-white .vol-aside ::v-deep(.vol-menu .el-submenu), +// .vol-theme-white .vol-aside ::v-deep(.menu-item-lv1) { +// background: #515a6e; +// } +// .vol-theme-white .vol-aside ::v-deep(.vol-menu) { +// background: #515a6e; +// } +// .vol-theme-white .vol-aside ::v-deep(.vol-menu .el-sub-menu__title *), +// .vol-theme-white .vol-aside ::v-deep(.menu-item-lv1 *) { +// color: #d6d6d6; +// } +// .vol-theme-white .vol-aside ::v-deep(.vol-el-menu-item .el-menu-item) { +// color: #eee; +// } +// .vol-theme-white .vol-aside ::v-deep(.vol-el-menu-item .el-menu-item.is-active), +// .vol-theme-white .vol-aside ::v-deep(.menu-item-lv1.is-active) { +// background: #59647b; +// color: #fff; +// } +// .vol-theme-white .vol-aside ::v-deep(.vol-el-menu-item .el-menu-item:hover) { +// background: #6a758c; +// } +// .vol-theme-white .vol-aside ::v-deep(.el-sub-menu__title:hover) { +// background-color: #525865; +// } +// .vol-theme-white .vol-aside ::v-deep(.el-sub-menu__title:hover *) { +// color: white; +// } + +// .vol-theme-red ::v-deep(.el-menu-item.is-active), +// .vol-theme-red2 ::v-deep(.el-menu-item.is-active) +// { +// background-color: #d71212; +// } +// .vol-theme-blue ::v-deep(.el-menu-item.is-active), +// .vol-theme-blue2 ::v-deep(.el-menu-item.is-active) +// { +// background-color: #2d8cf0; +// } +// .vol-theme-orange ::v-deep(.el-menu-item.is-active), +// .vol-theme-orange2 ::v-deep(.el-menu-item.is-active) +// { +// background-color: #ff9900; +// } + +// .vol-theme-green ::v-deep(.el-menu-item.is-active), +// .vol-theme-green2 ::v-deep(.el-menu-item.is-active) +// { +// background-color: #19be6b; +// } + +.theme-selector { + height: 100%; + padding-left: 16px; + + .item { + cursor: pointer; + width: 60px; + height: 60px; + border-radius: 5px; + margin-bottom: 17px; + border: 1px solid #d4d2d2; + float: left; + margin-right: 13px; + } +} + +.collapse-menu { + font-size: 21px; + color: #fff; + line-height: 60px; + position: absolute; + top: 0; + right: 5px; + cursor: pointer; +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/outbound/outboundOrder.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/outbound/outboundOrder.vue" new file mode 100644 index 0000000..0a1977b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/outbound/outboundOrder.vue" @@ -0,0 +1,328 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/outbound/outboundOrder.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "鍑哄簱鍗�", + name: "outboundOrder", + url: "/OutboundOrder/", + sortName: "CreateDate", + }); + const editFormFields = ref({ + orderType: "", + orderNo:"", + upperOrderNo: "", + orderStatus: "", + remark: "", + }); + const editFormOptions = ref([ + [ + { + title: "鍗曟嵁绫诲瀷", + required: true, + field: "orderType", + type: "select", + dataKey: "outOrderType", + data: [], + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "string", + }, + { + title: "涓婃父鍗曟嵁缂栧彿", + field: "upperOrderNo", + type: "string", + }, + { + title: "鍗曟嵁鐘舵��", + field: "orderStatus", + type: "select", + dataKey: "inboundState", + data: [], + readonly: true, + }, + { + title: "澶囨敞", + field: "remark", + type: "textarea", + }, + ], + ]); + const searchFormFields = ref({ + orderNo: "", + upperOrderNo: "", + orderType: "", + orderStatus: "", + createType: "", + creater: "", + createDate: "", + }); + const searchFormOptions = ref([ + [ + { title: "鍗曟嵁缂栧彿", field: "orderNo", type: "like" }, + { title: "涓婃父鍗曟嵁缂栧彿", field: "upperOrderNo", type: "like" }, + { + title: "鍗曟嵁绫诲瀷", + field: "orderType", + type: "select", + dataKey: "outOrderType", + data: [], + }, + { + title: "鍗曟嵁鐘舵��", + field: "orderStatus", + type: "select", + dataKey: "inboundState", + data: [], + }, + ], + [ + { + title: "鍒涘缓鏂瑰紡", + field: "createType", + type: "select", + dataKey: "createType", + data: [], + }, + { title: "鍒涘缓鑰�", field: "creater", type: "like" }, + { title: "鍒涘缓鏃堕棿", field: "createDate", type: "datetime" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "string", + width: 120, + align: "left", + link: true, + }, + { + field: "upperOrderNo", + title: "涓婃父鍗曟嵁缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "orderType", + title: "鍗曟嵁绫诲瀷", + type: "string", + width: 150, + align: "left", + bind: { key: "outOrderType", data: [] }, + }, + { + field: "orderStatus", + title: "鍗曟嵁鐘舵��", + type: "decimal", + width: 90, + align: "left", + bind: { key: "outboundStatusEnum", data: [] }, + }, + { + field: "createType", + title: "鍒涘缓鏂瑰紡", + type: "string", + width: 90, + align: "left", + bind: { key: "createType", data: [] }, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "鍑哄簱鏄庣粏鍗�", + table: "OnboundOrderDetail", + columns: [ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "orderId", + title: "鍑哄簱鍗曚富閿�", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + align: "left", + edit: { type: "string" }, + required: true, + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + align: "left", + edit: { type: "string" }, + }, + { + field: "batchNo", + title: "鎵规鍙�", + type: "decimal", + width: 90, + align: "left", + edit: { type: "string" }, + required: true, + }, + { + field: "orderQuantity", + title: "鍗曟嵁鏁伴噺", + type: "string", + width: 90, + align: "left", + edit: { type: "number" }, + required: true, + }, + { + field: "lockQuantity", + title: "閿佸畾鏁伴噺", + type: "int", + width: 120, + align: "left", + }, + { + field: "overOutQuantity", + title: "宸插嚭鏁伴噺", + type: "string", + width: 200, + align: "left", + }, + { + field: "orderDetailStatus", + title: "璁㈠崟鏄庣粏鐘舵��", + type: "string", + width: 180, + align: "left", + bind: { key: "orderDetailStatusEnum", data: [] }, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ], + sortName: "id", + key: "id", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/outbound/outboundOrderDetail.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/outbound/outboundOrderDetail.vue" new file mode 100644 index 0000000..e992c4c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/outbound/outboundOrderDetail.vue" @@ -0,0 +1,221 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> + </template> + <script> + import extend from "@/extension/outbound/outboundOrderDetail.js"; + import { ref, defineComponent } from "vue"; + export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "鍑哄簱鍗曟槑缁�", + name: "outboundOrderDetail", + url: "/OutboundOrderDetail/", + sortName: "id", + }); + const editFormFields = ref({ + deviceCode: "", + deviceName: "", + deviceType: "", + deviceStatus: "", + deviceIp: "", + devicePort: "", + devicePlcType: "", + deviceRemark: "", + }); + const editFormOptions = ref([ + [ + { + title: "璁惧缂栧彿", + required: true, + field: "deviceCode", + type: "string", + }, + { + title: "璁惧鍚嶇О", + required: true, + field: "deviceName", + type: "string", + }, + { + title: "璁惧绫诲瀷", + required: true, + field: "deviceType", + type: "string", + }, + { + title: "璁惧鐘舵��", + required: true, + field: "deviceStatus", + type: "string", + }, + ], + [ + { title: "璁惧IP", required: true, field: "deviceIp", type: "string" }, + { + title: "璁惧绔彛", + required: true, + field: "devicePort", + type: "string", + }, + { + title: "PLC绫诲瀷", + required: true, + field: "devicePlcType", + type: "string", + }, + { + title: "澶囨敞", + field: "deviceRemark", + type: "string", + }, + ], + ]); + const searchFormFields = ref({ + deviceCode: "", + deviceType: "", + deviceStatus: "", + }); + const searchFormOptions = ref([ + [ + { title: "璁惧缂栧彿", field: "deviceCode" }, + { title: "璁惧绫诲瀷", field: "deviceType" }, + { title: "璁惧鐘舵��", field: "deviceStatus" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + align: "left", + }, + { + field: "orderId", + title: "鍑哄簱鍗曚富閿�", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + align: "left", + }, + { + field: "batchNo", + title: "鎵规鍙�", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "orderQuantity", + title: "鍗曟嵁鏁伴噺", + type: "string", + width: 90, + align: "left", + }, + { + field: "lockQuantity", + title: "閿佸畾鏁伴噺", + type: "int", + width: 120, + align: "left", + }, + { + field: "overOutQuantity", + title: "宸插嚭鏁伴噺", + type: "string", + width: 200, + align: "left", + }, + { + field: "orderDetailStatus", + title: "璁㈠崟鏄庣粏鐘舵��", + type: "string", + width: 180, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, + }); + </script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/record/locationStatusChangeRecord.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/record/locationStatusChangeRecord.vue" new file mode 100644 index 0000000..036d4f3 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/record/locationStatusChangeRecord.vue" @@ -0,0 +1,191 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> + </template> + <script> + import extend from "@/extension/record/locationStatusChangeRecord.js"; + import { ref, defineComponent } from "vue"; + export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "璐т綅鐘舵�佸彉鍔ㄨ褰�", + name: "locationStatusChangeRecord", + url: "/LocationStatusChangeRecord/", + sortName: "CreateDate", + }); + const editFormFields = ref({ + deviceCode: "", + deviceName: "", + deviceType: "", + deviceStatus: "", + deviceIp: "", + devicePort: "", + devicePlcType: "", + deviceRemark: "", + }); + const editFormOptions = ref([ + + ]); + const searchFormFields = ref({ + locationCode: "", + orderNo: "", + taskNum: "", + }); + const searchFormOptions = ref([ + [ + { title: "璐т綅鍙�", field: "locationCode" }, + { title: "鍗曟嵁缂栧彿", field: "orderNo" }, + { title: "浠诲姟鍙�", field: "taskNum" }, + ], + [ + { title: "鍙樺姩鍓嶈揣浣嶇姸鎬�", field: "beforeStatus" ,type: "selectList",dataKey: "locationStatusEnum",data: [],}, + { title: "鍙樺姩鍚庤揣浣嶇姸鎬�", field: "afterStatus" ,type: "selectList",dataKey: "locationStatusEnum",data: [],}, + { title: "鍙樺姩绫诲瀷", field: "changeType" ,type: "selectList",dataKey: "stockChangeType",data: [],}, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "locationId", + title: "璐т綅涓婚敭", + type: "string", + width: 90, + align: "left", + }, + { + field: "taskNum", + title: "浠诲姟鍙�", + type: "string", + width: 90, + align: "left", + }, + { + field: "locationCode", + title: "璐т綅缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "beforeStatus", + title: "鍙樺姩鍓嶈揣浣嶇姸鎬�", + type: "string", + width: 150, + align: "left", + bind: { key: "locationStatusEnum", data: [] }, + }, + { + field: "afterStatus", + title: "鍙樺姩鍚庤揣浣嶇姸鎬�", + type: "decimal", + width: 150, + align: "left", + bind: { key: "locationStatusEnum", data: [] }, + }, + { + field: "changeType", + title: "鍙樺姩绫诲瀷", + type: "string", + width: 90, + align: "left", + bind: { key: "stockChangeType", data: [] }, + }, + { + field: "orderId", + title: "鍗曟嵁涓婚敭", + type: "string", + width: 90, + align: "left", + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "int", + width: 120, + align: "left", + }, + { + field: "orderDetailId", + title: "鍗曟嵁鏄庣粏涓婚敭", + type: "string", + width: 200, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, + }); + </script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/record/stockQuantityChangeRecord.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/record/stockQuantityChangeRecord.vue" new file mode 100644 index 0000000..ea40703 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/record/stockQuantityChangeRecord.vue" @@ -0,0 +1,219 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> + </template> + <script> + import extend from "@/extension/record/stockQuantityChangeRecord.js"; + import { ref, defineComponent } from "vue"; + export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "搴撳瓨鍙樺姩淇℃伅璁板綍", + name: "stockQuantityChangeRecord", + url: "/StockQuantityChangeRecord/", + sortName: "CreateDate", + }); + const editFormFields = ref({ + + }); + const editFormOptions = ref([ + + ]); + const searchFormFields = ref({ + palleCode: "", + materielCode: "", + orderNo: "", + }); + const searchFormOptions = ref([ + [ + { title: "鎵樼洏鍙�", field: "palleCode" }, + { title: "鐗╂枡缂栧彿", field: "materielCode" }, + { title: "鍗曟嵁缂栧彿", field: "orderNo" }, + { title: "鍙樺姩绫诲瀷", field: "changeType" ,type: "selectList",dataKey: "stockChangeType",data: [],}, + ], + [ + { title: "鎵规鍙�", field: "batchNo" }, + { title: "浠诲姟鍙�", field: "taskNum" }, + { title: "搴忓垪鍙�", field: "serilNumber" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "stockDetailId", + title: "搴撳瓨鏄庣粏ID", + type: "string", + width: 90, + align: "left", + }, + { + field: "palleCode", + title: "鎵樼洏缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "batchNo", + title: "鎵规鍙�", + type: "string", + width: 90, + align: "left", + }, + { + field: "serilNumber", + title: "搴忓垪鍙�", + type: "int", + width: 280, + align: "left", + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "string", + width: 150, + align: "left", + }, + + { + field: "taskNum", + title: "浠诲姟鍙�", + type: "string", + width: 90, + align: "left", + }, + { + field: "changeType", + title: "鍙樺姩绫诲瀷", + type: "int", + width: 120, + align: "left", + bind: { key: "stockChangeType", data: [] }, + }, + { + field: "changeQuantity", + title: "鍙樺姩鏁伴噺", + type: "string", + width: 100, + align: "left", + }, + { + field: "beforeQuantity", + title: "鍙樺姩鍓嶅簱瀛橀噺", + type: "string", + width: 100, + align: "left", + }, + { + field: "afterQuantity", + title: "鍙樺姩鍚庡簱瀛橀噺", + type: "string", + width: 100, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "orderId", + title: "鍗曟嵁涓婚敭", + type: "string", + width: 180, + align: "left", + }, + { + field: "orderDetailId", + title: "鍗曟嵁鏄庣粏涓婚敭", + type: "string", + width: 120, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, + }); + </script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockInfo.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockInfo.vue" new file mode 100644 index 0000000..eed82b6 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockInfo.vue" @@ -0,0 +1,140 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> + </template> + <script> + import extend from "@/extension/stock/stockInfo.js"; + import { ref, defineComponent } from "vue"; + export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "搴撳瓨淇℃伅", + name: "stockInfo", + url: "/StockInfo/", + sortName: "CreateDate", + }); + const editFormFields = ref({ + deviceCode: "", + deviceName: "", + deviceType: "", + deviceStatus: "", + deviceIp: "", + devicePort: "", + devicePlcType: "", + deviceRemark: "", + }); + const editFormOptions = ref([ + + ]); + const searchFormFields = ref({ + palletCode: "", + locationCode: "", + }); + const searchFormOptions = ref([ + [ + { title: "鎵樼洏缂栧彿", field: "palletCode" }, + { title: "璐т綅缂栧彿", field: "locationCode" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "palletCode", + title: "鎵樼洏缂栧彿", + type: "string", + width: 90, + align: "left", + }, + { + field: "locationCode", + title: "璐т綅缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "isFull", + title: "鏄惁婊$洏", + type: "string", + width: 150, + align: "left", + bind: { key: "yesno", data: [] }, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, + }); + </script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockInfoDetail.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockInfoDetail.vue" new file mode 100644 index 0000000..fdb2428 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockInfoDetail.vue" @@ -0,0 +1,200 @@ +<template> + <view-grid ref="grid" :columns="columns" :detail="detail" :editFormFields="editFormFields" + :editFormOptions="editFormOptions" :searchFormFields="searchFormFields" :searchFormOptions="searchFormOptions" + :table="table" :extend="extend"> + </view-grid> +</template> +<script> +import extend from "@/extension/stock/stockInfoDetail.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "id", + footer: "Foots", + cnName: "搴撳瓨淇℃伅鏄庣粏", + name: "stockInfoDetail", + url: "/StockInfoDetail/", + sortName: "id", + }); + const editFormFields = ref({ + deviceCode: "", + deviceName: "", + deviceType: "", + deviceStatus: "", + deviceIp: "", + devicePort: "", + devicePlcType: "", + deviceRemark: "", + }); + const editFormOptions = ref([ + [ + { + title: "鐗╂枡缂栧彿", + required: true, + field: "materielCode", + type: "string", + }, + { + title: "鍗曟嵁缂栧彿", + required: true, + field: "materielName", + type: "string", + }, + { + title: "鎵规鍙�", + required: true, + field: "orderNo", + type: "string", + }, + { + title: "搴忓垪鍙�", + required: true, + field: "serialNumber", + type: "string", + }, + ], + + ]); + const searchFormFields = ref({ + materielCode: "", + materielName: "", + orderNo: "", + }); + const searchFormOptions = ref([ + [ + { title: "鐗╂枡缂栧彿", field: "materielCode" }, + { title: "鐗╂枡鍚嶇О", field: "materielName" }, + { title: "鍗曟嵁缂栧彿", field: "orderNo" }, + ], + ]); + const columns = ref([ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "stockId", + title: "搴撳瓨淇℃伅涓婚敭", + type: "string", + width: 90, + align: "left", + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + align: "left", + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "batchNo", + title: "鎵规鍙�", + type: "string", + width: 90, + align: "left", + }, + { + field: "serialNumber", + title: "搴忓垪鍙�", + type: "int", + width: 120, + align: "left", + }, + { + field: "stockQuantity", + title: "搴撳瓨鏁伴噺", + type: "string", + width: 200, + align: "left", + }, + { + field: "outboundQuantity", + title: "鍑哄簱鏁伴噺", + type: "string", + width: 180, + align: "left", + }, + { + field: "status", + title: "搴撳瓨鏄庣粏鐘舵��", + type: "string", + width: 120, + align: "left", + bind: { key: "outStockStatus", data: [] }, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockView.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockView.vue" new file mode 100644 index 0000000..eb1d413 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/stock/stockView.vue" @@ -0,0 +1,327 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/stock/stockView.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "stockId", + footer: "Foots", + cnName: "搴撳瓨瑙嗗浘", + name: "stockView", + url: "/stockView/", + sortName: "CreateDate", + }); + const editFormFields = ref({ + palletCode: "", + locationCode: "", + locationName: "", + }); + const editFormOptions = ref([ + + ]); + const searchFormFields = ref({ + palletCode: "", + locationCode: "", + }); + const searchFormOptions = ref([ + [ + { title: "鎵樼洏缂栧彿", field: "palletCode" }, + { title: "璐т綅缂栧彿", field: "locationCode" }, + { title: "璐т綅鐘舵��", field: "locationStatus" ,type: "selectList",dataKey: "locationStatusEnum",data: [],}, + { title: "搴撳瓨鐘舵��", field: "stockStatus" ,type: "selectList",dataKey: "stockStatusEmun",data: [],}, + ], + ]); + const columns = ref([ + { + field: "stockId", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "palletCode", + title: "鎵樼洏缂栧彿", + type: "string", + width: 150, + link: true, + align: "left", + }, + { + field: "locationCode", + title: "璐т綅缂栧彿", + type: "string", + width: 180, + align: "left", + }, + { + field: "locationName", + title: "璐т綅鍚嶇О", + type: "string", + width: 220, + align: "left", + }, + { + field: "roadwayNo", + title: "宸烽亾缂栧彿", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "row", + title: "璐т綅琛�", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "column", + title: "璐т綅鍒�", + type: "int", + width: 120, + align: "left", + hidden: true, + }, + { + field: "layer", + title: "璐т綅灞�", + type: "string", + width: 200, + align: "left", + hidden: true, + }, + { + field: "depth", + title: "璐т綅娣卞害", + type: "string", + width: 180, + align: "left", + hidden: true, + }, + { + field: "stockStatus", + title: "搴撳瓨鐘舵��", + type: "string", + width: 200, + align: "left", + bind: { key: "stockStatusEmun", data: [] }, + }, + { + field: "locationType", + title: "璐т綅绫诲瀷", + type: "string", + width: 120, + align: "left", + bind:{key: "locationTypeEnum", data: []} + }, + { + field: "locationStatus", + title: "璐т綅鐘舵��", + type: "string", + width: 200, + align: "left", + bind: { key: "locationStatusEnum", data: [] }, + }, + { + field: "enalbeStatus", + title: "绂佺敤鐘舵��", + type: "string", + width: 180, + align: "left", + bind: { key: "enableStatusEnum", data: [] }, + }, + { + field: "isFull", + title: "鏄惁婊$洏", + type: "string", + width: 150, + align: "left", + hidden: true, + bind: { key: "yesno", data: [] }, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ]); + const detail = ref({ + cnName: "搴撳瓨鏄庣粏淇℃伅", + table: "StockInfoDetail", + columns: [ + { + field: "id", + title: "Id", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "stockId", + title: "搴撳瓨淇℃伅涓婚敭", + type: "string", + width: 90, + align: "left", + }, + { + field: "materielCode", + title: "鐗╂枡缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "materielName", + title: "鐗╂枡鍚嶇О", + type: "string", + width: 150, + align: "left", + }, + { + field: "orderNo", + title: "鍗曟嵁缂栧彿", + type: "decimal", + width: 90, + align: "left", + }, + { + field: "batchNo", + title: "鎵规鍙�", + type: "string", + width: 90, + align: "left", + }, + { + field: "serialNumber", + title: "搴忓垪鍙�", + type: "int", + width: 120, + align: "left", + }, + { + field: "stockQuantity", + title: "搴撳瓨鏁伴噺", + type: "string", + width: 200, + align: "left", + }, + { + field: "outboundQuantity", + title: "鍑哄簱鏁伴噺", + type: "string", + width: 180, + align: "left", + }, + { + field: "status", + title: "搴撳瓨鏄庣粏鐘舵��", + type: "string", + width: 120, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + ], + sortName: "id", + key: "id", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Permission.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Permission.vue" new file mode 100644 index 0000000..dd62254 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Permission.vue" @@ -0,0 +1,359 @@ +<template> + <div class="role-container"> + <div class="role-tree-left flex-col"> + <div class="title"><i class="el-icon-user"></i>瑙掕壊鍒楄〃</div> + <el-scrollbar class="el-role-list"> + <el-tree + :data="tree" + @node-click="nodeClick" + node-key="id" + :default-expanded-keys="openKeys" + :expand-on-click-node="false" + style="padding: 5px 0; margin-right: 2px" + > + <template #default="{ data }"> + <div class="action-group"> + <div class="action-text"> + {{ data.roleName }} + </div> + </div> + </template> + </el-tree> + </el-scrollbar> + </div> + <div class="role-tree-right flex-col"> + <div class="title"> + <div><i class="el-icon-folder-opened"></i>鑿滃崟鏉冮檺</div> + <el-button type="primary" @click="save">淇濆瓨</el-button> + </div> + <el-scrollbar class="el-role-list"> + <el-tree + @check-change="leftCheckChange" + @check="nodeCheck" + :data="roleTree" + :show-checkbox="false" + style="padding: 15px" + node-key="id" + default-expand-all + :expand-on-click-node="false" + > + <template #default="{ data }"> + <div class="action-group"> + <div + class="action-text" + :style="{ width: (4 - data.lv) * 18 + 150 + 'px' }" + > + <el-checkbox v-model="data.leftCk" @change="allChange(data)">{{ + // data.text + (data.isApp ? "(app)" : "") + data.text + }}</el-checkbox> + </div> + <div class="action-item"> + <el-checkbox + v-for="(item, index) in data.actions" + :key="index" + v-model="item.checked" + @change="actionChange(data, item.checked)" + >{{ item.text }}</el-checkbox + > + </div> + </div> + </template> + </el-tree> + </el-scrollbar> + </div> + </div> +</template> + +<script> +import { defineComponent, ref, reactive, getCurrentInstance } from "vue"; +import http from "@/../src/api/http.js"; +export default defineComponent({ + setup() { + const selectId = ref(-1); + const checked = ref(false); + const tree = reactive([]); + const list = reactive([]); + const roles = reactive([]); + const roleList = reactive([]); + const roleTree = reactive([]); + const openKeys = reactive([]); + + const leftCheckChange = (node, selected) => { + node.actions.forEach((x, index) => { + x.checked = selected; + }); + }; + const nodeCheck = (node, data) => { + let rootData = roleList.find((x) => { + return x.id === node.pid; + }); + if (rootData && rootData.actions.length) { + rootData.actions[0].checked = + node.actions.some((x) => { + return x.checked; + }) || + data.halfCheckedNodes.some((x) => { + return x.id === node.pid; + }); + } + }; + + const allChange = (data) => { + data.actions.forEach((item) => { + item.checked = data.leftCk; + }); + if (!data.children) { + return; + } + setChildrenChecked(data, data.leftCk); + }; + const setChildrenChecked = (data, ck) => { + data.children.forEach((item) => { + item.leftCk = ck; + item.actions.forEach((c) => { + c.checked = ck; + }); + if (item.children) { + setChildrenChecked(item, ck); + } + }); + }; + const actionChange = (data, ck) => { + ck = + data.actions.filter((x) => { + return x.checked; + }).length == data.actions.length; + data.leftCk = ck; + }; + + const load = () => { + const url = "api/Sys_Role/getUserChildRoles"; + http.post(url, {}, true).then((result) => { + + if (!result.status) return; + list.splice(0); + list.push(...result.data); + list.forEach((x) => { + if (x.parentId == 0) { + x.lv = 1; + x.children = []; + tree.push(x); + getTree(x.id, x); + } + }); + openKeys.push(tree[0].id); + selectId.value = openKeys[0]; + }); + }; + const getTree = (id, data) => { + list.forEach((x) => { + if (x.parentId == id) { + x.lv = data.lv + 1; + if (!data.children) data.children = []; + data.children.push(x); + getTree(x.id, x); + } + }); + }; + const nodeClick = (node, selected) => { + selectId.value = node.id; + getUserRole(node); + }; + const getUserRole = (item) => { + selectId.value = item.id; + roleList.forEach((x) => { + x.actions.forEach((a) => { + a.checked = false; + }); + }); + let url = `/api/Sys_Role/getUserTreePermission?roleId=${item.id}`; + http.post(url, {}, true).then((result) => { + if (!result.status) return; + result.data.forEach((item) => { + if (item.actions.length == 0) return; + let sourceItem = roleList.find((f) => f.id == item.id); + if (!sourceItem) return; + item.actions.forEach((actions) => { + sourceItem.actions.forEach((soure) => { + if (soure.value == actions.value) { + soure.checked = true; + } + }); + }); + }); + }); + }; + + const getRoleTree = (id, data, isRootId) => { + roleList.forEach((x) => { + if (x.pid == id) { + x.lv = data.lv + 1; + if (isRootId) { + x.rootId = id; + } + if (!data.children) data.children = []; + data.children.push(x); + getRoleTree(x.id, x, isRootId); + } + }); + }; + + const getCurrentTreePermission = () => { + let url = "/api/Sys_Role/getCurrentTreePermission"; + http.post(url, {}, true).then((result) => { + if (!result.status) return; + roleList.splice(0); + roles.splice(0); + roleList.push(...result.data.tree); + roles.push(...result.data.roles); + roleList.forEach((x) => { + if (x.pid == 0) { + x.lv = 1; + x.children = []; + roleTree.push(x); + getRoleTree(x.id, x); + } + }); + }); + }; + let $message = + getCurrentInstance().appContext.config.globalProperties.$message; + const save = () => { + if (selectId.value <= 0) { + return $message.error("璇烽�夋嫨瑙掕壊!"); + } + let userPermissions = []; + roleList.forEach((x) => { + let checkedPermission = x.actions.filter((f) => { + return f.checked; + }); + if (checkedPermission.length > 0) { + let actions = checkedPermission.map((m) => { + return { text: m.text, value: m.value }; + }); + userPermissions.push({ + id: x.id, + actions: actions, + }); + } + }); + let url = `api/Sys_Role/SavePermission?roleId=${selectId.value}`; + http.post(url, userPermissions, true).then((result) => { + $message[result.status ? "success" : "error"](result.message); + }); + }; + + load(); + getCurrentTreePermission(); + return { + list, + nodeClick, + checked, + tree, + selectId, + openKeys, + getUserRole, + roles, + roleList, + getCurrentTreePermission, + leftCheckChange, + nodeCheck, + roleTree, + allChange, + actionChange, + save, + }; + }, +}); +</script> +<style lang="less" scoped> +.role-container { + position: absolute; + background: #f6f6f6; + height: 100%; + width: 100%; + padding: 10px; + display: flex; + .flex-col { + display: flex; + flex-direction: column; + } + .role-tree-left { + border: 1px solid #f2f2f2; + background: #fff; + width: 230px; + margin-right: 10px; + .title { + i { + margin-left: 10px; + } + } + } + .role-tree-right { + background: #fff; + border: 1px solid #f2f2f2; + width: 0; + flex: 1; + .title { + display: flex; + i { + margin-left: 10px; + } + div { + flex: 1; + } + } + .action-group { + display: flex; + // line-height: 32px; + justify-content: center; + align-items: center; + label { + float: left; + } + .action-text { + line-height: 33px; + label { + margin-right: 5px; + } + } + } + } + .title { + padding: 10px; + background: rgb(246 250 255); + font-weight: bold; + font-size: 14px; + letter-spacing: 2px; + } + .el-role-list { + flex: 1; + height: 0; + overflow-x: hidden; + } +} +.role-tree-left ::v-deep(.el-tree-node__content) { + cursor: pointer; + height: auto; + padding: 5px; + margin: 2px 10px; + font-size: 15px; +} +.role-tree-left ::v-deep(.el-tree-node__content:hover) { + background: #f4f4f4; + border-radius: 20px; +} +.role-tree-left ::v-deep(.is-current > .el-tree-node__content:first-child) { + background: #f2f2f2; + border-radius: 20px; +} +.role-tree-right ::v-deep(.el-tree-node__content) { + margin-bottom: 5px; + height: auto; +} +.role-tree-right ::v-deep(.el-checkbox__label) { + position: relative; + top: 2px; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Permission/RoleTree.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Permission/RoleTree.vue" new file mode 100644 index 0000000..9ae4e6b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Permission/RoleTree.vue" @@ -0,0 +1,152 @@ +<template> + <div class="com-el-tree"> + + <div class="m-title"><i class="el-icon-warning-outline"></i>瑙掕壊鍒楄〃</div> + + <el-scrollbar style="height: 100%; width: 200px" class="el-role-tree"> + <el-tree + :data="tree" + @node-click="nodeClick" + node-key="id" + :default-expanded-keys="openKeys" + :expand-on-click-node="false" + style="padding: 5px 0; margin-right: 2px" + > + <template #default="{ node, data }"> + <div class="action-group"> + <div + class="action-text" + :class="{ + actived: data.id == selectId, + 'node-text': data.parentId !== 0, + }" + :style="{ width: (4 - data.lv) * 18 + 150 + 'px' }" + > + <Icon + v-if="data.parentId !== 0" + :type="data.id == selectId ? 'ios-paper' : 'ios-paper-outline'" + /> + {{ data.roleName }} + </div> + </div> + </template> + </el-tree> + </el-scrollbar> + </div> +</template> + +<script> +export default { + props: { + // roles: { + // type: Object, + // default: () => { + // return []; + // } + // }, + onChange: { + type: Function, + default: (treeId) => {}, + }, + }, + data() { + return { + selectId: -1, + checked: false, + openKeys: [], + data: [], + tree: [], + }; + }, + created() { + this.load(); + }, + methods: { + load() { + this.http.post("/api/Sys_Role/getUserChildRoles", {}, true).then((result) => { + if (!result.status) return this.$message.error(result.message); + this.data.splice(0); + this.data = result.data; + this.data.forEach((x) => { + if (x.parentId == 0) { + x.lv = 1; + x.children = []; + this.tree.push(x); + this.getTree(x.id, x); + } + }); + this.openKeys.push(this.tree[0].id); + this.selectId = this.openKeys[0]; + //榛樿鍔犺浇绗竴涓爲褰㈣彍鍗曚笅闈㈢殑鏁版嵁 + + //this.onChange(this.selectId); + }); + }, + getTree(id, data) { + this.data.forEach((x) => { + if (x.parentId == id) { + x.lv = data.lv + 1; + if (!data.children) data.children = []; + data.children.push(x); + this.getTree(x.id, x); + } + }); + }, + nodeClick(node, selected) { + // console.log(node); + this.selectId = node.id; + //缂撳瓨褰撳墠閫変腑鐨勮妭鐐� + // this.$store.getters.data().treeDemo1.treeId = node.id; + this.onChange(node); + }, + }, +}; +</script> +<style lang="less" scoped> +.com-el-tree { + //2020.06.03澧炲姞宸︿晶tree鍥哄畾瀹藉害 + width: 200px; + display: flex; + flex-direction: column; + height: 100%; + border-radius: 3px; + background: white; + .el-role-tree { + flex: 1; + // border-right: 1px solid #eee; + } + .actived { + } + .action-text { + font-size: 14px; + } +} +.role-list { + color: white; + line-height: 40px; + padding: 0 13px; + font-size: 16px; + top: 2px; + width: 200px; +} +.m-title { + line-height: 30px; + font-size: 15px; + background: #66b1ff0f; + font-weight: bold; + padding: 6px 16px; + border-bottom: 1px solid #eee; + i { + padding-right: 5px; + } +} +.com-el-tree ::v-dee(.el-tree-node) { + padding: 3px 0; +} +.com-el-tree ::v-dee(.el-scrollbar .el-scrollbar__thumb) { + width: 0 !important; +} +</style> +<style scoped> + +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/PermissionPDA.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/PermissionPDA.vue" new file mode 100644 index 0000000..92d5227 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/PermissionPDA.vue" @@ -0,0 +1,369 @@ +<template> + <div class="role-container"> + <div class="role-tree-left flex-col"> + <div class="title"><i class="el-icon-user"></i>瑙掕壊鍒楄〃</div> + <el-scrollbar class="el-role-list"> + <el-tree + :data="tree" + @node-click="nodeClick" + node-key="id" + :default-expanded-keys="openKeys" + :expand-on-click-node="false" + style="padding: 5px 0; margin-right: 2px" + > + <template #default="{ data }"> + <div class="action-group"> + <div class="action-text"> + {{ data.roleName }} + </div> + </div> + </template> + </el-tree> + </el-scrollbar> + </div> + <div class="role-tree-right flex-col"> + <div class="title"> + <div><i class="el-icon-folder-opened"></i>PDA鑿滃崟鏉冮檺</div> + <el-button type="primary" @click="save">淇濆瓨</el-button> + </div> + <el-scrollbar class="el-role-list"> + <el-tree + ref="eltreerole" + @check-change="leftCheckChange" + @check="nodeCheck" + :data="roleTree" + :show-checkbox="false" + style="padding: 15px" + node-key="id" + default-expand-all + :expand-on-click-node="false" + > + <template #default="{ data }"> + <div class="action-group"> + <div + class="action-text" + :style="{ width: (4 - data.lv) * 18 + 150 + 'px' }" + > + <el-checkbox v-model="data.leftCk" @change="allChange(data)">{{ + // data.text + (data.isApp ? "(app)" : "") + data.text + }}</el-checkbox> + </div> + <div class="action-item"> + <el-checkbox + v-for="(item, index) in data.actions" + :key="index" + v-model="item.checked" + @change="actionChange(data, item.checked)" + >{{ item.text }}</el-checkbox + > + </div> + </div> + </template> + </el-tree> + </el-scrollbar> + </div> + </div> +</template> + +<script> +import { defineComponent, ref, reactive, getCurrentInstance } from "vue"; +import http from "@/../src/api/http.js"; +export default defineComponent({ + setup() { + const selectId = ref(-1); + const checked = ref(false); + const tree = reactive([]); + const list = reactive([]); + const roles = reactive([]); + const roleList = reactive([]); + const roleTree = reactive([]); + const openKeys = reactive([]); + + const leftCheckChange = (node, selected) => { + node.actions.forEach((x, index) => { + x.checked = selected; + }); + }; + const nodeCheck = (node, data) => { + let rootData = roleList.find((x) => { + return x.id === node.pid; + }); + if (rootData && rootData.actions.length) { + rootData.actions[0].checked = + node.actions.some((x) => { + return x.checked; + }) || + data.halfCheckedNodes.some((x) => { + return x.id === node.pid; + }); + } + }; + + const allChange = (data) => { + data.actions.forEach((item) => { + item.checked = data.leftCk; + }); + if (!data.children) { + return; + } + setChildrenChecked(data, data.leftCk); + }; + const setChildrenChecked = (data, ck) => { + data.children.forEach((item) => { + item.leftCk = ck; + item.actions.forEach((c) => { + c.checked = ck; + }); + if (item.children) { + setChildrenChecked(item, ck); + } + }); + }; + const actionChange = (data, ck) => { + ck = + data.actions.filter((x) => { + return x.checked; + }).length == data.actions.length; + data.leftCk = ck; + }; + + const load = () => { + const url = "api/Sys_Role/getUserChildRoles"; + http.post(url, {}, true).then((result) => { + + if (!result.status) return; + list.splice(0); + list.push(...result.data); + list.forEach((x) => { + if (x.parentId == 0) { + x.lv = 1; + x.children = []; + tree.push(x); + getTree(x.id, x); + } + }); + openKeys.push(tree[0].id); + selectId.value = openKeys[0]; + }); + }; + const getTree = (id, data) => { + list.forEach((x) => { + if (x.parentId == id) { + x.lv = data.lv + 1; + if (!data.children) data.children = []; + data.children.push(x); + getTree(x.id, x); + } + }); + }; + const nodeClick = (node, selected) => { + selectId.value = node.id; + getUserRole(node); + }; + const getUserRole = (item) => { + selectId.value = item.id; + roleList.forEach((x) => { + x.actions.forEach((a) => { + a.checked = false; + }); + }); + let url = `/api/Sys_Role/getUserTreePermissionPDA?roleId=${item.id}`; + http.post(url, {}, true).then((result) => { + if (!result.status) return; + result.data.forEach((item) => { + if (item.actions.length == 0) return; + let sourceItem = roleList.find((f) => f.id == item.id); + if (!sourceItem) return; + item.actions.forEach((actions) => { + sourceItem.actions.forEach((soure) => { + if (soure.value == actions.value) { + soure.checked = true; + } + }); + }); + }); + }); + }; + + const getRoleTree = (id, data, isRootId) => { + roleList.forEach((x) => { + if (x.pid == id) { + x.lv = data.lv + 1; + if (isRootId) { + x.rootId = id; + } + if (!data.children) data.children = []; + data.children.push(x); + getRoleTree(x.id, x, isRootId); + } + }); + }; + + const getCurrentTreePermission = () => { + let url = "/api/Sys_Role/getCurrentTreePermissionPDA"; + http.post(url, {}, true).then((result) => { + if (!result.status) return; + roleList.splice(0); + roles.splice(0); + roleList.push(...result.data.tree); + roles.push(...result.data.roles); + roleList.forEach((x) => { + if (x.pid == 0) { + x.lv = 1; + x.children = []; + roleTree.push(x); + getRoleTree(x.id, x); + } + }); + }); + }; + let $message = + getCurrentInstance().appContext.config.globalProperties.$message; + const save = () => { + if (selectId.value <= 0) { + return $message.error("璇烽�夋嫨瑙掕壊!"); + } + // var keys = this.$refs.eltreerole.getCheckedKeys().concat(this.$refs.eltreerole.getHalfCheckedKeys()); + // console.log(keys) + let userPermissions = []; + // keys.forEach((x) => { + // userPermissions.push({ + // id: x, + // actions: null, + // text: "PDA", + // }); + // }); + roleList.forEach((x) => { + let checkedPermission = x.actions.filter((f) => { + return f.checked; + }); + if (checkedPermission.length > 0) { + let actions = checkedPermission.map((m) => { + return { text: m.text, value: m.value }; + }); + userPermissions.push({ + id: x.id, + actions: actions, + }); + } + }); + let url = `api/Sys_Role/SavePermission?roleId=${selectId.value}`; + http.post(url, userPermissions, true).then((result) => { + $message[result.status ? "success" : "error"](result.message); + }); + }; + + load(); + getCurrentTreePermission(); + return { + list, + nodeClick, + checked, + tree, + selectId, + openKeys, + getUserRole, + roles, + roleList, + getCurrentTreePermission, + leftCheckChange, + nodeCheck, + roleTree, + allChange, + actionChange, + save, + }; + }, +}); +</script> +<style lang="less" scoped> +.role-container { + position: absolute; + background: #f6f6f6; + height: 100%; + width: 100%; + padding: 10px; + display: flex; + .flex-col { + display: flex; + flex-direction: column; + } + .role-tree-left { + border: 1px solid #f2f2f2; + background: #fff; + width: 230px; + margin-right: 10px; + .title { + i { + margin-left: 10px; + } + } + } + .role-tree-right { + background: #fff; + border: 1px solid #f2f2f2; + width: 0; + flex: 1; + .title { + display: flex; + i { + margin-left: 10px; + } + div { + flex: 1; + } + } + .action-group { + display: flex; + // line-height: 32px; + justify-content: center; + align-items: center; + label { + float: left; + } + .action-text { + line-height: 33px; + label { + margin-right: 5px; + } + } + } + } + .title { + padding: 10px; + background: rgb(246 250 255); + font-weight: bold; + font-size: 14px; + letter-spacing: 2px; + } + .el-role-list { + flex: 1; + height: 0; + overflow-x: hidden; + } +} +.role-tree-left ::v-deep(.el-tree-node__content) { + cursor: pointer; + height: auto; + padding: 5px; + margin: 2px 10px; + font-size: 15px; +} +.role-tree-left ::v-deep(.el-tree-node__content:hover) { + background: #f4f4f4; + border-radius: 20px; +} +.role-tree-left ::v-deep(.is-current > .el-tree-node__content:first-child) { + background: #f2f2f2; + border-radius: 20px; +} +.role-tree-right ::v-deep(.el-tree-node__content) { + margin-bottom: 5px; + height: auto; +} +.role-tree-right ::v-deep(.el-checkbox__label) { + position: relative; + top: 2px; +} +</style> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Dictionary.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Dictionary.vue" new file mode 100644 index 0000000..51df000 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Dictionary.vue" @@ -0,0 +1,316 @@ +<!-- +*Author锛歫xx + *Contact锛�283591387@qq.com + *浠g爜鐢辨鏋剁敓鎴�,浠讳綍鏇存敼閮藉彲鑳藉鑷磋浠g爜鐢熸垚鍣ㄨ鐩� + *涓氬姟璇峰湪@/extension/system/Sys_Dictionary.js姝ゅ缂栧啓 + --> +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> +<script> +import extend from "@/extension/system/Sys_Dictionary.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "dicId", + footer: "Foots", + cnName: "瀛楀吀鏁版嵁", + name: "Sys_Dictionary", + url: "/Sys_Dictionary/", + sortName: "dicId", + }); + const editFormFields = ref({ + dicNo: "", + dicName: "", + parentId: "", + orderNo: "", + enable: "", + sql: "", + remark: "", + }); + const editFormOptions = ref([ + [ + { title: "瀛楀吀缂栧彿", required: true, field: "dicNo" }, + { title: "瀛楀吀鍚嶇О", required: true, field: "dicName" }, + { title: "鐖剁骇ID", required: true, field: "parentId", type: "number" }, + ], + [ + { title: "鎺掑簭鍙�", field: "orderNo", type: "number" }, + { + dataKey: "enable", + data: [], + title: "鏄惁鍚敤", + required: true, + field: "enable", + type: "select", + }, + ], + [ + { title: "sql璇彞", field: "sql", colSize: 8, type: "textarea" }, + { title: "澶囨敞", field: "remark", type: "textarea" }, + ], + ]); + const searchFormFields = ref({ + dicNo: "", + dicName: "", + parentId: "", + enable: "", + createDate: "", + modifyDate: "", + }); + const searchFormOptions = ref([ + [ + { title: "瀛楀吀缂栧彿", field: "dicNo" }, + { title: "瀛楀吀鍚嶇О", field: "dicName", type: "textarea" }, + { title: "鐖剁骇ID", field: "parentId", type: "number" }, + ], + [ + { + dataKey: "enable", + data: [], + title: "鏄惁鍚敤", + field: "enable", + type: "select", + }, + { title: "鍒涘缓鏃堕棿", field: "createDate", type: "datetime" }, + { title: "淇敼鏃堕棿", field: "modifyDate", type: "datetime" }, + ], + ]); + const columns = ref([ + { + field: "dicId", + title: "瀛楀吀ID", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "dicNo", + title: "瀛楀吀缂栧彿", + type: "string", + width: 90, + require: true, + align: "left", + sort: true, + }, + { + field: "dicName", + title: "瀛楀吀鍚嶇О", + type: "string", + link: true, + width: 140, + require: true, + align: "left", + }, + { + field: "parentId", + title: "鐖剁骇ID", + type: "int", + width: 90, + require: true, + align: "left", + }, + { + field: "config", + title: "閰嶇疆椤�", + type: "string", + width: 300, + hidden: true, + align: "left", + }, + { + field: "sql", + title: "sql璇彞", + type: "string", + width: 200, + align: "left", + }, + { + field: "orderNo", + title: "鎺掑簭鍙�", + type: "int", + width: 90, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 90, + align: "left", + }, + { + field: "enable", + title: "鏄惁鍚敤", + type: "byte", + bind: { key: "enable", data: [] }, + width: 90, + require: true, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 130, + hidden: true, + readonly: true, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 150, + readonly: true, + align: "left", + sort: true, + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 130, + hidden: true, + readonly: true, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 150, + readonly: true, + align: "left", + sort: true, + }, + ]); + const detail = ref({ + cnName: "瀛楀吀鏄庣粏", + table: "Sys_DictionaryList", + columns: [ + { + field: "dicList_ID", + title: "DicList_ID", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "dicId", + title: "鏁版嵁婧怚D", + type: "int", + width: 90, + readonly: true, + align: "left", + sort: true, + }, + { + field: "dicValue", + title: "鏁版嵁婧怴alue", + type: "string", + width: 90, + edit: { type: "text" }, + align: "left", + }, + { + field: "dicName", + title: "鏁版嵁婧怲ext", + type: "string", + width: 90, + edit: { type: "text" }, + align: "left", + }, + { + field: "orderNo", + title: "鎺掑簭鍙�", + type: "int", + width: 90, + edit: { type: "text" }, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 90, + edit: { type: "text" }, + align: "left", + }, + + { + field: "createID", + title: "CreateID", + type: "int", + width: 90, + hidden: true, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 130, + readonly: true, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 90, + readonly: true, + align: "left", + sort: true, + }, + + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 130, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 90, + align: "left", + sort: true, + }, + ], + sortName: "dicId", + key: "dicId", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_DictionaryList.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_DictionaryList.vue" new file mode 100644 index 0000000..02427fb --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_DictionaryList.vue" @@ -0,0 +1,65 @@ +<!-- +*Author锛歫xx + *Contact锛�283591387@qq.com + *浠g爜鐢辨鏋剁敓鎴�,浠讳綍鏇存敼閮藉彲鑳藉鑷磋浠g爜鐢熸垚鍣ㄨ鐩� + *涓氬姟璇峰湪@/extension/system/Sys_DictionaryList.js姝ゅ缂栧啓 + --> +<template> + <div> + <view-grid :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend"> + </view-grid> + </div> +</template> + +<script> + import extend from "@/extension/system/Sys_DictionaryList.js"; + var vueParam = { + data() { + return { + table: { + key: 'DicList_ID', + footer: "Foots", + cnName: '瀛楀吀鏄庣粏', + name: 'Sys_DictionaryList', + url: "/Sys_DictionaryList/", + sortName: "DicList_ID" + }, + extend: extend, + editFormFields: {"DicValue":"","DicName":"","OrderNo":"","Remark":"","Enable":""}, + editFormOptions: [[{"columnType":"string","title":"鏁版嵁婧怴alue","field":"DicValue","type":"text"}, + {"columnType":"string","title":"鏁版嵁婧怲ext","field":"DicName","type":"text"}, + {"columnType":"int","title":"鎺掑簭鍙�","field":"OrderNo","type":"text"}, + {"columnType":"int","title":"澶囨敞","field":"Remark","type":"text"}, + {"columnType":"byte","dataKey":"enable","title":"鏄惁鍙敤","field":"Enable","type":"switch"}]], + searchFormFields: {}, + searchFormOptions: [], + columns: [{field:'DicList_ID',title:'DicList_ID',type:'int',width:90,hidden:true,readonly:true,require:true,align:'left'}, + {field:'Dic_ID',title:'鏁版嵁婧怚D',type:'int',width:90,readonly:true,align:'left',sortable:true}, + {field:'DicValue',title:'鏁版嵁婧怴alue',type:'string',width:90,align:'left'}, + {field:'DicName',title:'鏁版嵁婧怲ext',type:'string',width:90,align:'left'}, + {field:'OrderNo',title:'鎺掑簭鍙�',type:'int',width:90,align:'left'}, + {field:'Remark',title:'澶囨敞',type:'int',width:90,align:'left'}, + {field:'Enable',title:'鏄惁鍙敤',type:'byte',bind:{ key:'enable',data:[]},width:90,align:'left'}, + {field:'CreateID',title:'CreateID',type:'int',width:90,hidden:true,align:'left'}, + {field:'Creator',title:'鍒涘缓浜�',type:'string',width:130,readonly:true,align:'left'}, + {field:'CreateDate',title:'鍒涘缓鏃堕棿',type:'datetime',width:90,readonly:true,align:'left',sortable:true}, + {field:'ModifyID',title:'ModifyID',type:'int',width:90,hidden:true,align:'left'}, + {field:'Modifier',title:'淇敼浜�',type:'string',width:130,align:'left'}, + {field:'ModifyDate',title:'淇敼鏃堕棿',type:'datetime',width:90,align:'left',sortable:true}], + detail: { + cnName:"#detailCnName", + columns: [], + sortName: "#detailSortName" + } + }; + } + }; + export default vueParam; +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Log.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Log.vue" new file mode 100644 index 0000000..9742628 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Log.vue" @@ -0,0 +1,70 @@ +<!-- +*Author锛歫xx + *Contact锛�283591387@qq.com + *浠g爜鐢辨鏋剁敓鎴�,浠讳綍鏇存敼閮藉彲鑳藉鑷磋浠g爜鐢熸垚鍣ㄨ鐩� + *涓氬姟璇峰湪@/extension/system/Sys_Log.js姝ゅ缂栧啓 + --> +<template> + <view-grid ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend"> + </view-grid> +</template> +<script> + import extend from "@/extension/system/Sys_Log.js"; + import { ref, defineComponent } from "vue"; + export default defineComponent({ + setup() { + const table = ref({ + key: 'Id', + footer: "Foots", + cnName: '绯荤粺鏃ュ織', + name: 'Sys_Log', + url: "/Sys_Log/", + sortName: "Id" + }); + const editFormFields = ref({}); + const editFormOptions = ref([]); + const searchFormFields = ref({"BeginDate":"","Url":"","LogType":[],"Success":[],"UserIP":"","ServiceIP":"","Role_Id":""}); + const searchFormOptions = ref([[{"title":"璇锋眰鍦板潃","field":"Url","type":"text"},{"title":"鐢ㄦ埛IP","field":"UserIP","type":"text"},{"title":"鏈嶅姟鍣↖P","field":"ServiceIP","type":"text"}],[{"title":"寮�濮嬫椂闂�","field":"BeginDate","type":"datetime"},{"dataKey":"restatus","data":[],"title":"鍝嶅簲鐘舵��","field":"Success","type":"selectList"},{"dataKey":"roles","data":[],"title":"瑙掕壊ID","field":"Role_Id","type":"select"}],[{"dataKey":"log","data":[],"title":"鏃ュ織绫诲瀷","field":"LogType","colSize":12,"type":"checkbox"}]]); + const columns = ref([{field:'Id',title:'Id',type:'int',width:90,hidden:true,readonly:true,require:true,align:'left'}, + {field:'BeginDate',title:'寮�濮嬫椂闂�',type:'datetime',width:140,align:'left',sortable:true}, + {field:'UserName',title:'鐢ㄦ埛鍚嶇О',type:'string',width:90,align:'left'}, + {field:'Url',title:'璇锋眰鍦板潃',type:'string',width:110,align:'left'}, + {field:'LogType',title:'鏃ュ織绫诲瀷',type:'string',bind:{ key:'log',data:[]},width:80,align:'left'}, + {field:'Success',title:'鍝嶅簲鐘舵��',type:'int',bind:{ key:'restatus',data:[]},width:80,align:'left'}, + {field:'ElapsedTime',title:'鏃堕暱',type:'int',width:60,align:'left'}, + {field:'RequestParameter',title:'璇锋眰鍙傛暟',type:'string',width:70,align:'left'}, + {field:'ResponseParameter',title:'鍝嶅簲鍙傛暟',type:'string',width:70,align:'left'}, + {field:'ExceptionInfo',title:'寮傚父淇℃伅',type:'string',width:70,align:'left'}, + {field:'UserIP',title:'鐢ㄦ埛IP',type:'string',width:90,align:'left'}, + {field:'ServiceIP',title:'鏈嶅姟鍣↖P',type:'string',width:90,hidden:true,align:'left'}, + {field:'BrowserType',title:'娴忚鍣ㄧ被鍨�',type:'string',width:90,align:'left'}, + {field:'User_Id',title:'鐢ㄦ埛ID',type:'int',width:90,hidden:true,align:'left'}, + {field:'Role_Id',title:'瑙掕壊ID',type:'int',bind:{ key:'roles',data:[]},width:90,hidden:true,align:'left'}, + {field:'EndDate',title:'缁撴潫鏃堕棿',type:'datetime',width:150,hidden:true,align:'left',sortable:true}]); + const detail = ref({ + cnName: "#detailCnName", + columns: [], + sortName: "", + key: "" + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, + }); +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Menu.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Menu.vue" new file mode 100644 index 0000000..4eee23d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Menu.vue" @@ -0,0 +1,672 @@ +<template> + <div class="menu-container"> + <!-- <el-input/> --> + <vol-box + :width="940" + :mask="true" + :height="500" + title="鍥炬爣鍒楄〃" + v-model="model" + > + <Icons :onSelect="onSelect"></Icons> + <template #footer> + <el-button type="primary" size="mini" @click="model = false" + >纭� 璁�</el-button + > + </template> + </vol-box> + <vol-box + :width="600" + :mask="true" + :height="270" + title="鍏朵粬鏉冮檺" + v-model="actionModel" + > + <vol-form + ref="actionForm" + :formRules="actionOptions" + :formFields="actionFields" + > + <template #header> + <div> + <el-alert show-icon type="success"> + 閰嶇疆鐨勫叾浠栨潈闄� + <br />1銆佹坊鍔犳柊鐨勬潈闄愬悗璇峰湪vue椤圭洰涓璫onfig鏂囦欢澶逛笅buttns.js娣诲姞姝ゆ潈闄愮殑鎸夐挳銆� + <br />2銆佸鏋滄潈闄愬彧鍦ㄦ煇灏戞暟鍑犱釜鍔熻兘涓娇鐢�,鍦╲ue鐨勫搴旈〉闈㈡墿灞昬xtension鏂囦欢鎵惧埌瀵瑰簲js,娣诲姞鍒癳l-buttons瀵硅薄涓�,鏍煎紡鍚宑onfig鏂囦欢澶逛笅buttns.js涓�鏍枫�� + </el-alert> + </div> + </template> + </vol-form> + <template #footer> + <el-button type="primary" size="mini" @click="otherAction" + >纭� 璁�</el-button + > + </template> + </vol-box> + + <!-- v-if="tree.length" --> + <div class="menu-left"> + <div class="m-title"><i class="el-icon-warning-outline"></i>鑿滃崟鍒楄〃</div> + <el-scrollbar style="height: 100%; width: 200px"> + <VolMenu + :onSelect="getTreeItem" + :list="tree" + :isCollapse="false" + ></VolMenu> + </el-scrollbar> + </div> + <div class="menu-right"> + <el-scrollbar style="height: 100%"> + <el-alert + title="鑿滃崟閰嶇疆璇存槑" + type="warning" + :closable="false" + show-icon + > + <div> + 1銆佸鏋滄槸鐢ㄤ唬鐮佺敓鍣ㄧ敓鎴愮殑Vue椤甸潰,Url涓篤ue椤圭洰涓璼rc->router->viewGrid.js瀵瑰簲琛ㄥ悕鐨刾ath灞炴�� + </div> + <div style="padding-top: 5px"> + 2銆� 濡傛灉鍙槸寤轰竴绾ц彍鍗曟垨绌鸿彍鍗晆rl涓嶇敤濉啓,銆愯鍥�/琛ㄥ悕銆戝~鍐�.鎴栬��/ + </div> + </el-alert> + <div style="padding: 0px 30px 0 20px"> + <vol-form + class="form-content" + ref="form" + :formRules="options" + :formFields="fields" + > + </vol-form> + <div> + <div class="auth-group"> + <label style="width: 100px">鏉冮檺鎸夐挳锛�</label> + <div class="ck"> + <el-checkbox-group v-model="actions"> + <el-checkbox + v-for="(item, index) in action" + :key="index" + :label="item.value" + >{{ item.text + "(" + item.value + ")" }}</el-checkbox + > + </el-checkbox-group> + </div> + </div> + </div> + <div style="padding-left: 100px"> + <el-button @click="handleCheckAll" size="mini" type="success" plain + ><i class="el-icon-check"></i>鍏� 閫�</el-button + > + <el-button + @click="actionModel = true" + size="mini" + type="primary" + plain + ><i class="el-icon-plus"></i>鍏朵粬鏉冮檺</el-button + > + </div> + <div class="m-btn"> + <el-button type="primary" @click="save" + ><i class="el-icon-check"></i>淇濆瓨</el-button + > + <el-button type="success" @click="add" + ><i class="el-icon-plus"></i>鏂板缓</el-button + > + <el-button type="warning" @click="addChild" + ><i class="el-icon-plus"></i>娣诲姞瀛愮骇</el-button + > + <el-button type="primary" plain @click="addBrother" + ><i class="el-icon-circle-plus"></i> 娣诲姞鍚岀骇</el-button + > + <el-button type="warning" plain @click="delMenu" + ><i class="el-icon-delete"></i> 鍒犻櫎鑿滃崟</el-button + > + </div> + </div> + </el-scrollbar> + </div> + </div> +</template> +<script> +import VolForm from "@/components/basic/VolForm.vue"; +import VolBox from "@/components/basic/VolBox.vue"; +import Icons from "@/components/basic/Icons.vue"; +import VolMenu from "@/components/basic/VolElementMenu.vue"; +import { + defineComponent, + reactive, + ref, + toRefs, + onMounted, + h, + resolveComponent, +} from "vue"; + +import http from "@/api/http"; +export default defineComponent({ + components: { + VolForm: VolForm, + VolBox: VolBox, + Icons: Icons, + VolMenu, + }, + methods: { + otherAction() { + this.$refs.actionForm.validate(() => { + let exist = this.action.some((x) => { + return ( + x.text == this.actionFields.name || + x.value == this.actionFields.value + ); + }); + if (exist) { + return this.$message.error("鏉冮檺鍚嶇О鎴栨潈闄愬�煎凡瀛樺湪"); + } + this.actionModel = false; + this.action.push({ + text: this.actionFields.name, + value: this.actionFields.value, + }); + }); + }, + handleCheckAll() { + if (this.actions == this.action.length) { + this.checkAll = false; + } else { + this.checkAll = !this.checkAll; + } + if (this.checkAll) { + this.actions = this.action.map((x) => { + return x.value; + }); + } else { + this.actions = []; + } + }, + checkAllGroupChange(data) { + if (data.length === this.action.length) { + this.checkAll = true; + } else if (data.length > 0) { + this.checkAll = false; + } else { + this.checkAll = false; + } + }, + add(obj) { + this.$refs.form.reset( + Object.assign({ enable: 1 }, obj || { parentId: 0 }) + ); + this.icon = ""; + // this.actions = []; + //2020.08.07鏂板缓鑿滃崟鏃讹紝榛樿閫変腑鏌ヨ鎸夐挳鏉冮檺 + this.actions = ["Search"]; + }, + addChild() { + if (!this.isSelect()) return; + this.add({ parentId: this.fields.menuId }); + }, + addBrother() { + if (!this.isSelect()) return; + this.add({ parentId: this.fields.parentId }); + }, + delMenu() { + //2020.08.07澧炲姞鑿滃崟鍒犻櫎鍔熻兘 + if (this.fields.menuId == 0) { + return this.$Message.error("璇烽�夋嫨鑿滃崟"); + } + + let tigger = false; + this.$confirm( + "纭瑕佸垹闄ゃ��" + this.fields.menuName + "銆戣彍鍗曞悧锛�", + "璀﹀憡", + { + confirmButtonText: "纭畾", + cancelButtonText: "鍙栨秷", + type: "warning", + center: true, + } + ).then(() => { + if (tigger) return; + tigger = true; + let menuId = this.fields.menuId; + this.http + .post( + "/api/Sys_Menu/delMenu?menuId=" + menuId, + {}, + "姝e湪鍒犻櫎鏁版嵁...." + ) + .then((x) => { + if (!x.status) return this.$Message.error(x.message); + this.$refs.form.reset(); + this.$Message.info(x.message); + this.initTree(); + }); + }); + }, + save() { + this.$refs.form.validate(() => { + this.fields.auth = ""; + if (this.actions) { + this.fields.auth = this.action.filter((x) => { + return this.actions.indexOf(x.value) != -1; + }); + } + if ( + this.fields.auth && + this.fields.auth instanceof Array && + this.fields.auth.length > 0 + ) { + this.fields.auth = JSON.stringify(this.fields.auth); + } else { + this.fields.auth = ""; + } + this.http.post("/api/Sys_Menu/save", this.fields, true).then((x) => { + if (!x.status) { + this.$Message.error(x.message); + return; + } + + this.$Message.info(x.message); + if (this.fields.menuId) { + this.tree.forEach((t) => { + if (t.id == this.fields.menuId) { + t.name = this.fields.menuName; + t.orderNo = this.fields.orderNo; + t.parentId = this.fields.parentId; + } + }); + return; + } + this.fields.menuId = x.data.menuId; + this.fields.createDate = x.data.createDate; + this.tree.push({ + id: x.data.menuId, + name: this.fields.menuName, + orderNo: this.fields.orderNo, + parentId: this.fields.parentId, + }); + console.log(this.tree); + }); + }); + }, + isSelect() { + let id = this.fields.menuId; + if (!id) { + this.$message.error("璇烽�夋嫨鑺傜偣"); + return false; + } + return true; + }, + onSelect(icon) { + this.fields.icon = icon; + this.$message.info(icon); + }, + onOpenChange(node) { + if (node.length == 0) return; + this.getTreeItem(node[node.length > 1 ? node.length - 1 : 0]); + }, + }, + created() {}, + setup() { + const tree = ref([]); + const actionValues = ref([]); + const action = ref([ + { text: "鏌ヨ", value: "Search" }, + { text: "鏂板缓", value: "Add" }, + { text: "鍒犻櫎", value: "Delete" }, + { text: "缂栬緫", value: "Update" }, + { text: "瀵煎叆", value: "Import" }, + { text: "瀵煎嚭", value: "Export" }, + // { text: "涓婁紶", value: "Upload" }, + // { text: "瀹℃牳", value: "Audit" }, + ]); + const actions = ref([]); + actionValues.value = action.value.map((x) => { + return x.value; + }); + const initTree = () => { + http.post("/api/Sys_Menu/getMenu", {}, true).then((x) => { + x.forEach((item) => { + item.icon = "el-icon-menu"; + }); + + tree.value = x; + }); + }; + onMounted(() => { + initTree(); + }); + const actionModel = ref(false); + const checkAll = ref(false); + const model = ref(false); + + const fields = ref({ + menuId: 0, + parentId: 0, + menuName: "", + tableName: "", + url: "", + auth: "", + icon: "", + orderNo: "", + enable: 1, + menuType: 0, + }); + + const actionFields = ref({ + name: "", + value: "", + }); + const actionOptions = ref([ + [ + { + title: "鏉冮檺鍚嶇О", + field: "name", + placeholder: "鏉冮檺鍚嶇О,濡傦細鏂板", + required: true, + }, + ], + [ + { + title: "鏉� 闄� 鍊�", + field: "value", + placeholder: "鏉冮檺鍊�,濡傦細Add", + required: true, + }, + ], + ]); + + const options = ref([ + [ + { + title: "鑿� 鍗� ID", + field: "menuId", + placeholder: "鑿滃崟ID", + min: 0, + disabled: true, + }, + { + title: "鐖� 绾� ID", + required: true, + type: "number", + min: 0, + field: "parentId", + // min: 0, max: 50 + }, + { + title: "鑿滃崟鍚嶇О", + field: "menuName", + required: true, + }, + ], + [ + { + title: "瑙嗗浘/琛ㄥ悕", + field: "tableName", + placeholder: "涓庝唬鐮佺敓鎴愬櫒浣跨敤鐨勫悕绉扮浉鍚�", + required: true, + }, + { + title: "(璺敱)Url", + field: "url", + placeholder: "瑙�:涓婇潰鑿滃崟閰嶇疆璇存槑", + }, + { + title: "鎺掑簭鍙�", + field: "orderNo", + type: "number", + min: 0, + placeholder: "鍊艰秺澶ф樉绀鸿秺闈犲墠", + required: true, + }, + ], + [ + { + title: "鏄惁鍚敤", + field: "enable", + required: true, + type: "select", + colSize: 4, + data: [ + { key: 1, value: "鍚敤" }, + { key: 2, value: "鍚敤涓嶆樉绀�" }, + { key: 0, value: "绂佺敤" }, + ], + }, + { + title: "鑿滃崟绫诲瀷", + field: "menuType", + required: true, + type: "select", + colSize: 4, + data: [ + { key: 0, value: "PC绔彍鍗�" }, + { key: 1, value: "绉诲姩绔彍鍗�" }, + ], + }, + { + title: "鍥炬爣Icon", + field: "icon", + render: (h) => { + return h("div", {}, [ + h("i", { + style: { + "font-size": "25px", + margin: "0px 9px", + position: "relative", + top: "4px", + }, + class: [fields.value.icon], + }), + h( + resolveComponent("el-button"), + { + size: "small", + style: { padding: "0px 9px" }, + type: "primary", + plain: true, + onClick: () => { + model.value = true; + }, + }, + "閫夋嫨鍥炬爣" + ), + ]); + }, + }, + ], + ]); + const refForm = ref(); + const getTreeItem = (node) => { + http + .post("api/Sys_Menu/getTreeItem?menuId=" + node, {}, true) + .then((x) => { + try { + fields.value.icon = x.icon; + if (x.auth) { + x.auth = JSON.parse(x.auth); + action.value.splice(8, action.value.length); + + actions.value = x.auth.map((element) => { + if (actionValues.value.indexOf(element.value) == -1) { + action.value.push(element); + } + return element.value; + }); + } else { + action.value.splice(8, action.value.length); + x.auth = []; + fields.value.icon = ""; + actions.value = []; + } + } catch (error) { + console.log("鑿滃崟鍔熻兘鏉冮檺杞崲鎴怞SON澶辫触:" + x.auth); + x.auth = []; + // this.icon = ""; + actions.value = []; + } + refForm.value.reset(x); + }); + }; + return { + tree, + initTree, + action, + actions, + actionValues, + actionModel, + checkAll, + model, + fields, + actionFields, + actionOptions, + options, + form: refForm, + getTreeItem, + }; + }, + data() { + return {}; + }, +}); +</script> + +<style lang="less" scoped> +.on-icon { + line-height: 20px; + position: relative; + + .remove { + display: none; + color: red; + right: 7px; + position: absolute; + top: -14px; + font-size: 13px; + } +} + +.on-icon:hover { + cursor: pointer; + + .remove { + display: block; + } +} + +.action { + width: 100%; + display: flex; + + margin-bottom: 15px; + + .ivu-checkbox-wrapper { + margin-right: 20px; + } + + .ck { + line-height: 33px; + display: inline-block; + display: flex; + + label:first-child { + min-width: 58px; + float: left; + margin-top: 1px; + } + + > div { + float: left; + } + } +} + +.menu-container { + display: flex; + position: absolute; + width: 100%; + height: 100%; + padding: 8px; + background: #f7f7f7; + + .menu-left { + height: 100%; + width: 201px; + border: 1px solid #eee; + display: flex; + background: white; + flex-direction: column; + + .module-name { + border-radius: 0px; + /* height: 5%; */ + line-height: 21px; + margin-bottom: 0; + } + } + + .menu-right { + flex: 1; + border-radius: 3px; + border: 1px solid #eee; + background: white; + margin-left: 9px; + margin-right: 3px; + } +} + +.m-btn { + margin-top: 20px; + text-align: center; +} + +.m-title { + line-height: 40px; + font-size: 15px; + background: #66b1ff0f; + font-weight: bold; + padding: 6px 16px; + border-bottom: 1px solid #eee; + + i { + padding-right: 5px; + } +} + +.form-content { + margin-top: 30px; +} + +.menu-left ::v-deep(.el-scrollbar__bar.is-vertical) { + width: 2px; +} + +.auth-group { + display: flex; + + label { + display: inline-block; + width: 100px; + text-align: right; + color: #797979; + font-size: 14px; + } + + .ck { + flex: 1; + } + + .el-checkbox { + min-width: 105px; + width: auto !important; + margin-right: 5px; + display: inline-block; + padding-bottom: 10px; + } +} + +.auth-group ::v-deep(.el-checkbox__label) { + padding-left: 4px; +} +</style> + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Role.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Role.vue" new file mode 100644 index 0000000..7da98d2 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Role.vue" @@ -0,0 +1,220 @@ +<!-- +*Author锛歫xx + *Contact锛�283591387@qq.com + *浠g爜鐢辨鏋剁敓鎴�,浠讳綍鏇存敼閮藉彲鑳藉鑷磋浠g爜鐢熸垚鍣ㄨ鐩� + *涓氬姟璇峰湪@/extension/system/Sys_Role.js姝ゅ缂栧啓 + --> +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> +<script> +import extend from "@/extension/system/Sys_Role.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "roleId", + footer: "Foots", + cnName: "瑙掕壊绠$悊", + name: "Sys_Role", + url: "/Sys_Role/", + sortName: "roleId", + }); + const editFormFields = ref({ + parentId: "", + roleName: "", + deptId: "", + enable: "", + // creater: "", + // createDate: "", + // modifier: "", + // modifyDate: "", + }); + const editFormOptions = ref([ + [ + { + dataKey: "tree_roles", + data: [], + title: "鐖剁骇ID", + required: true, + field: "parentId", + type: "select", + }, + { title: "瑙掕壊鍚嶇О", required: true, field: "roleName" }, + { + title: "鏁版嵁鏉冮檺", + field: "authorityScope", + type: "selectList", + dataKey: "authorityScope", + data: [], + }, + ], + [ + { title: "閮ㄩ棬ID", field: "deptId" }, + { + dataKey: "enable", + data: [], + title: "鏄惁鍚敤", + field: "enable", + type: "switch", + }, + ], + ]); + const searchFormFields = ref({ + roleName: "", + deptId: "", + enable: "", + createDate: "", + modifyDate: "", + }); + const searchFormOptions = ref([ + [ + { title: "瑙掕壊鍚嶇О", field: "roleName", type: "text" }, + { title: "閮ㄩ棬ID", field: "deptId", type: "text" }, + { + dataKey: "enable", + data: [], + title: "鏄惁鍚敤", + field: "enable", + type: "select", + }, + ], + [ + { title: "鍒涘缓鏃堕棿", field: "createDate", type: "datetime" }, + { title: "淇敼鏃堕棿", field: "modifyDate", type: "datetime" }, + ], + ]); + const columns = ref([ + { + field: "roleId", + title: "瑙掕壊ID", + type: "int", + width: 70, + readonly: true, + require: true, + align: "left", + sortable: true, + }, + { + field: "parentId", + title: "鐖剁骇ID", + type: "int", + bind: { key: "tree_roles", data: [] }, + width: 70, + require: true, + align: "left", + }, + { + field: "roleName", + title: "瑙掕壊鍚嶇О", + type: "string", + link: true, + width: 90, + require: true, + align: "left", + }, + { + field: "roleId", + title: "鏁版嵁鏉冮檺", + type: "string", + width: 90, + require: true, + align: "left", + bind: { key: "authorityScopes", data: [] }, + }, + { + field: "deptId", + title: "閮ㄩ棬ID", + type: "int", + width: 90, + // hidden: true, + align: "left", + }, + // { + // field: "deptName", + // title: "閮ㄩ棬鍚嶇О", + // type: "string", + // width: 90, + // align: "left", + // }, + { + field: "enable", + title: "鏄惁鍚敤", + type: "byte", + bind: { key: "enable", data: [] }, + width: 90, + align: "left", + }, + { + field: "orderNo", + title: "鎺掑簭", + type: "int", + width: 90, + hidden: true, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 130, + readonly: true, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 90, + readonly: true, + align: "left", + sortable: true, + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 130, + readonly: true, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 90, + readonly: true, + align: "left", + sortable: true, + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + columns: [], + sortName: "", + key: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Role1.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Role1.vue" new file mode 100644 index 0000000..19ed48a --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_Role1.vue" @@ -0,0 +1,72 @@ +<!-- +*Author锛歫xx + *Contact锛�283591387@qq.com + *浠g爜鐢辨鏋剁敓鎴�,浠讳綍鏇存敼閮藉彲鑳藉鑷磋浠g爜鐢熸垚鍣ㄨ鐩� + *涓氬姟璇峰湪@/extension/system/Sys_Role.js姝ゅ缂栧啓 + --> +<template> + <view-grid ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend"> + </view-grid> +</template> +<script> + import extend from "@/extension/system/Sys_Role1.js"; + import { ref, defineComponent } from "vue"; + export default defineComponent({ + setup() { + const table = ref({ + key: 'Role_Id', + footer: "Foots", + cnName: '瑙掕壊绠$悊', + name: 'Sys_Role', + url: "/Sys_Role/", + sortName: "Role_Id" + }); + const editFormFields = ref({"ParentId":[],"RoleName":"","DeptName":"","Enable":"","Creator":"","CreateDate":"","Modifier":"","ModifyDate":""}); + const editFormOptions = ref([[{"dataKey":"tree_roles","data":[],"title":"鐖剁骇ID","required":true,"field":"ParentId","type":"cascader"}, + {"title":"瑙掕壊鍚嶇О","required":true,"field":"RoleName"}], + [{"title":"閮ㄩ棬鍚嶇О","field":"DeptName"}, + {"dataKey":"enable","data":[],"title":"鏄惁鍚敤","field":"Enable","type":"switch"}], + [{"title":"鍒涘缓浜�","field":"Creator","disabled":true}, + {"title":"鍒涘缓鏃堕棿","field":"CreateDate","disabled":true,"type":"datetime"}], + [{"title":"淇敼浜�","field":"Modifier","disabled":true}, + {"title":"淇敼鏃堕棿","field":"ModifyDate","disabled":true}]]); + const searchFormFields = ref({"RoleName":"","DeptName":"","Enable":"","CreateDate":"","ModifyDate":""}); + const searchFormOptions = ref([[{"title":"瑙掕壊鍚嶇О","field":"RoleName","type":"text"},{"title":"閮ㄩ棬鍚嶇О","field":"DeptName","type":"text"},{"dataKey":"enable","data":[],"title":"鏄惁鍚敤","field":"Enable","type":"select"}],[{"title":"鍒涘缓鏃堕棿","field":"CreateDate","type":"datetime"},{"title":"淇敼鏃堕棿","field":"ModifyDate","type":"datetime"}]]); + const columns = ref([{field:'Role_Id',title:'瑙掕壊ID',type:'int',width:70,readonly:true,require:true,align:'left',sortable:true}, + // {field:'ParentId',title:'鐖剁骇ID',type:'int',bind:{ key:'tree_roles',data:[]},width:70,require:true,align:'left'}, + {field:'RoleName',title:'瑙掕壊鍚嶇О',type:'string',link:true,width:90,require:true,align:'left'}, + {field:'Dept_Id',title:'閮ㄩ棬ID',type:'int',width:90,hidden:true,align:'left'}, + {field:'DeptName',title:'閮ㄩ棬鍚嶇О',type:'string',width:90,align:'left'}, + {field:'Enable',title:'鏄惁鍚敤',type:'byte',bind:{ key:'enable',data:[]},width:90,align:'left'}, + {field:'OrderNo',title:'鎺掑簭',type:'int',width:90,hidden:true,align:'left'}, + {field:'Creator',title:'鍒涘缓浜�',type:'string',width:130,readonly:true,align:'left'}, + {field:'CreateDate',title:'鍒涘缓鏃堕棿',type:'datetime',width:90,readonly:true,align:'left',sortable:true}, + {field:'Modifier',title:'淇敼浜�',type:'string',width:130,readonly:true,align:'left'}, + {field:'ModifyDate',title:'淇敼鏃堕棿',type:'datetime',width:90,readonly:true,align:'left',sortable:true}]); + const detail = ref({ + cnName: "#detailCnName", + columns: [], + sortName: "", + key: "" + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, + }); +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_User.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_User.vue" new file mode 100644 index 0000000..f3f8885 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/Sys_User.vue" @@ -0,0 +1,369 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> +<script> +import extend from "@/extension/system/Sys_User.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "user_Id", + footer: "Foots", + cnName: "鐢ㄦ埛绠$悊", + name: "Sys_User", + url: "/User/", + sortName: "user_Id", + }); + const editFormFields = ref({ + systemType: "0", + userName: "", + userTrueName: "", + roleId: [], + deptIds: "", + enable: "", + gender: "", + remark: "", + headImageUrl: "", + }); + const editFormOptions = ref([ + [{ title: "甯愬彿", required: true, field: "userName"}], + [{ title: "濮撳悕", required: true, field: "userTrueName", type: "text" }], + [ + { + dataKey: "tree_roles", + data: [], + title: "瑙掕壊", + required: true, + field: "roleId", + type: "cascader", + }, + ], + // [ + // { + // dataKey: "缁勭粐鏈烘瀯", + // data: [], + // title: "缁勭粐鏋勬灦", + // field: "deptIds", + // colSize: 12, + // type: "treeSelect", + // }, + // ], + [ + { + dataKey: "enable", + data: [], + title: "鏄惁鍙敤", + required: true, + field: "enable", + type: "select", + }, + ], + [ + { + dataKey: "gender", + data: [], + title: "鎬у埆", + field: "gender", + type: "select", + }, + ], + [{ title: "澶囨敞", field: "remark", colSize: 12, type: "textarea" }], + [{ title: "澶村儚", field: "headImageUrl", type: "img" }], + ]); + const searchFormFields = ref({ + systemType: "0", + userName: "", + userTrueName: "", + gender: "", + deptName: "", + role_Id: [], + token: "", + appType: [], + createDate: "", + isRegregisterPhone: "", + phoneNo: "", + enable: "", + lastLoginDate: "", + address: "", + email: "", + }); + const searchFormOptions = ref([ + [ + { title: "甯愬彿", field: "userName" }, + { title: "濮撳悕", field: "userTrueName" }, + { + dataKey: "gender", + data: [], + title: "鎬у埆", + field: "gender", + type: "select", + }, + ], + [ + { + dataKey: "enable", + data: [], + title: "鏄惁鍙敤", + field: "enable", + type: "select", + }, + { title: "娉ㄥ唽鏃堕棿", field: "createDate", type: "datetime" }, + ], + ]); + const columns = ref([ + { + field: "userId", + title: "UserId", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "userName", + title: "甯愬彿", + type: "string", + link: true, + width: 120, + readonly: true, + require: true, + align: "left", + sort: true, + }, + { + field: "userTrueName", + title: "濮撳悕", + type: "string", + width: 120, + require: true, + align: "left", + }, + { + field: "gender", + title: "鎬у埆", + type: "int", + bind: { key: "gender", data: [] }, + width: 80, + align: "left", + }, + { + field: "headImageUrl", + title: "澶村儚", + type: "img", + width: 90, + align: "left", + }, + { + field: "deptId", + title: "涓嶇敤", + type: "int", + width: 90, + hidden: true, + align: "left", + }, + { + field: "deptName", + title: "涓嶇敤", + type: "string", + width: 150, + hidden: true, + align: "left", + }, + { + field: "roleId", + title: "瑙掕壊", + type: "int", + bind: { key: "tree_roles", data: [] }, + width: 130, + require: true, + align: "left", + }, + { + field: "roleName", + title: "涓嶇敤", + type: "string", + width: 90, + hidden: true, + align: "left", + }, + { + field: "token", + title: "Token", + type: "string", + width: 180, + hidden: true, + align: "left", + }, + { + field: "appType", + title: "绫诲瀷", + type: "int", + bind: { key: "ut", data: [] }, + width: 150, + hidden: true, + align: "left", + }, + // { + // field: "deptIds", + // title: "缁勭粐鏋勬灦", + // type: "string", + // bind: { key: "缁勭粐鏈烘瀯", data: [] }, + // width: 140, + // hidden: true, + // align: "left", + // }, + { + field: "createDate", + title: "娉ㄥ唽鏃堕棿", + type: "datetime", + width: 150, + readonly: true, + align: "left", + sort: true, + }, + { + field: "phoneNo", + title: "鎵嬫満鍙�", + type: "string", + width: 150, + hidden: true, + align: "left", + }, + { + field: "tel", + title: "Tel", + type: "string", + width: 90, + hidden: true, + align: "left", + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 130, + readonly: true, + align: "left", + }, + { + field: "enable", + title: "鏄惁鍙敤", + type: "byte", + bind: { key: "enable", data: [] }, + width: 90, + require: true, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 130, + hidden: true, + readonly: true, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 90, + hidden: true, + readonly: true, + align: "left", + sort: true, + }, + { + field: "auditStatus", + title: "瀹℃牳鐘舵��", + type: "int", + bind: { key: "audit", data: [] }, + width: 90, + hidden: true, + align: "left", + }, + { + field: "auditor", + title: "瀹℃牳浜�", + type: "string", + width: 90, + hidden: true, + align: "left", + }, + { + field: "auditDate", + title: "瀹℃牳鏃堕棿", + type: "datetime", + width: 150, + hidden: true, + align: "left", + sort: true, + }, + { + field: "lastModifyPwdDate", + title: "鏈�鍚庡瘑鐮佷慨鏀规椂闂�", + type: "datetime", + width: 150, + hidden: true, + align: "left", + sort: true, + }, + { + field: "address", + title: "鍦板潃", + type: "string", + width: 190, + hidden: true, + align: "left", + }, + { + field: "email", + title: "Email", + type: "string", + width: 140, + hidden: true, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 180, + hidden: true, + align: "left", + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "#detailTable", + columns: [], + sortName: "", + key: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/UserInfo.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/UserInfo.vue" new file mode 100644 index 0000000..aeeaf2e --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/UserInfo.vue" @@ -0,0 +1,317 @@ +<template> + <VolBox :width="500" :height="270" v-model="modifyOptions.model" title="淇敼瀵嗙爜"> + <div style="padding:10px;20px;"> + <VolForm ref="pwd" :formRules="modifyOptions.data" :formFields="modifyOptions.fields"></VolForm> + </div> + <template #footer> + <div style="text-align: center;"> + <el-button type="primary" size="mini" icon="md-checkmark-circle" long @click="savePwd">淇濆瓨</el-button> + </div> + </template> + </VolBox> + <div class="user-info"> + <div class="left"> + <div> + <img class="header-img" :src="userInfo.img" :onerror="errorImg" /> + <div class="text"> + <p class="name"> + <span style="font-size: 13px">{{ userInfo.userName }}</span> + </p> + <p class="date"> + <span>娉ㄥ唽鏃ユ湡锛歿{ userInfo.createDate }}</span> + </p> + <p> + <el-button type="error" @click="modifyPwd" size="small" icon="md-lock" long>淇敼瀵嗙爜</el-button> + <!-- <el-button + style="padding: 3px 16px" + @click="modifyImg" + type="primary" + size="mini" + ghost + >淇敼澶村儚</el-button + > --> + </p> + </div> + </div> + </div> + <div class="right"> + <vol-form ref="form" :load-key="true" :width="500" :formRules="editFormOptions" :formFields="editFormFields"> + <div class="footer"> + <!-- <el-button + style="margin-top: 2px" + type="primary" + size="small" + icon="md-checkmark-circle" + long + @click="modifyInfo" + >淇濆瓨</el-button + > --> + </div> + </vol-form> + </div> + + </div> +</template> +<script> +import VolForm from "@/components/basic/VolForm.vue"; +import VolBox from "@/components/basic/VolBox.vue"; +export default { + components: { + VolForm, + VolBox, + }, + methods: { + modifyImg() { + this.$message.info("淇敼澶村儚"); + }, + modifyEmail() { + this.$message.info("淇敼閭"); + }, + modifyPhone() { + this.$message.info("淇敼鐢佃瘽"); + }, + modifyPwd() { + this.modifyOptions.model = true; + }, + savePwd() { + if (!this.$refs.pwd.validate()) return; + if ( + this.modifyOptions.fields.newPwd != this.modifyOptions.fields.newPwd1 + ) { + return this.$message.error("涓ゆ瀵嗙爜涓嶄竴鑷�"); + } + let url = + "/api/User/modifyPwd?oldPwd=" + + this.modifyOptions.fields.oldPwd + + "&newPwd=" + + this.modifyOptions.fields.newPwd; + this.http.post(url, {}, true).then((x) => { + if (!x.status) { + return this.$message.error(x.message); + } + this.modifyOptions.model = false; + this.$Message.success(x.message); + this.$refs.pwd.reset(); + }); + }, + modifyInfo() { + this.$message.info("淇敼涓汉淇℃伅"); + }, + }, + created() { + this.http.post("/api/User/getCurrentUserInfo", {}, true).then((x) => { + if (!x.status) { + return this.$message(x.message); + } + x.data.createDate = (x.data.createDate || "").replace("T", " "); + x.data.gender = x.data.gender + ""; + this.$refs.form.reset(x.data); + this.userInfo.img = this.base.getImgSrc( + x.data.headImageUrl, + this.http.ipAddress + ); + this.userInfo.createDate = x.data.createDate; + this.userInfo.userName = x.data.userTrueName; + this.userInfo.phoneNo = x.data.phoneNo; + this.userInfo.email = x.data.email; + // this.editFormFields = x.data; + }); + }, + data() { + return { + errorImg: 'this.src="' + require("@/assets/imgs/error-img.png") + '"', + modifyOptions: { + model: false, + fields: { oldPwd: "", newPwd: "", newPwd1: "" }, + data: [ + [ + { + columnType: "string", + required: true, + title: "鏃у瘑鐮�", + field: "oldPwd", + }, + ], + [ + { + type: "password", + required: true, + title: "鏂板瘑鐮�", + field: "newPwd", + }, + ], + [ + { + type: "password", + required: true, + title: "纭瀵嗙爜", + field: "newPwd1", + }, + ], + ], + }, + binging: [{}], + userInfo: { + img: "", + createDate: "--", + userName: "--", + email: "", + phoneNo: "", + }, + editFormFields: { + roleName: "", + userName: "", + userTrueName: "", + address: "", + gender: "", + remark: "", + }, + editFormOptions: [ + [ + { + columnType: "string", + title: "鐢ㄦ埛鍚�", + field: "userName", + disabled: true, + }, + ], + [ + { + columnType: "string", + title: "瑙掕壊", + field: "roleName", + disabled: true, + type: "text", + }, + ], + [ + { + columnType: "string", + title: "鐪熷疄濮撳悕", + field: "userTrueName", + required: true, + disabled: true, + type: "text", + }, + ], + [ + { + columnType: "string", + title: "鍦板潃", + field: "address", + disabled: true, + type: "text", + }, + ], + [ + { + dataKey: "gender", + title: "鎬у埆", + field: "gender", + disabled: true, + data: [], + type: "select", + }, + ], + [ + { + columnType: "string", + title: "澶囨敞", + field: "remark", + disabled: true, + colSize: 12, + type: "textarea", + }, + ], + ], + }; + }, +}; +</script> +<style scoped> +.binding-group { + width: 100%; + padding-bottom: 20px; +} + +.binding-group>>>.ivu-cell-link { + text-align: left; +} + +.binding-group>>>.ivu-card-body { + padding: 0 16px; +} + +.binding-group>>>.ivu-cell-title { + line-height: 24px; + font-size: 12px; +} +</style> + +<style lang="less" scoped> +img[src=""], +img:not([src]) { + opacity: 0; +} + +.user-info { + box-shadow: #d6d6d6 0px 4px 21px; + position: absolute; + transform: translateY(-40%); + top: 40%; + /* position: relative; */ + margin: 0 auto; + left: 0; + width: 950px; + right: 0; + text-align: center; + padding: 0px; + padding: 20px; + + .text { + padding: 5px; + + .name { + font-weight: bolder; + font-size: 15px; + font-weight: 900; + } + + >p { + padding-top: 5px; + } + } + + .header-img { + height: 150px; + width: 150px; + border-radius: 50%; + margin-right: 0px; + top: 4px; + position: relative; + border: 3px solid #dfdfdf; + } + + >div { + float: left; + // height: 480px; + padding-top: 10px; + } + + .left { + width: 320px; + border-right: 1px solid #eee; + // box-shadow: #d6d6d6 7px 4px 20px; + // flex: 1; + } + + .right { + padding-left: 30px; + width: 570px; + // background: #fefefe; + // flex: 3; + } +} +</style> + + diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/system/Sys_Department.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/system/Sys_Department.vue" new file mode 100644 index 0000000..0ee20af --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/system/Sys_Department.vue" @@ -0,0 +1,71 @@ +<!-- +*Author锛歫xx + *Contact锛�283591387@qq.com + *浠g爜鐢辨鏋剁敓鎴�,浠讳綍鏇存敼閮藉彲鑳藉鑷磋浠g爜鐢熸垚鍣ㄨ鐩� + *涓氬姟璇峰湪@/extension/system/system/Sys_Department.js姝ゅ缂栧啓 + --> +<template> + <view-grid ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend"> + </view-grid> +</template> +<script> + import extend from "@/extension/system/system/Sys_Department.js"; + import { ref, defineComponent } from "vue"; + export default defineComponent({ + setup() { + const table = ref({ + key: 'DepartmentId', + footer: "Foots", + cnName: '缁勭粐鏋舵瀯', + name: 'system/Sys_Department', + url: "/Sys_Department/", + sortName: "CreateDate" + }); + const editFormFields = ref({"DepartmentName":"","DepartmentCode":"","ParentId":[],"Remark":""}); + const editFormOptions = ref([[{"title":"缁勭粐鍚嶇О","required":true,"field":"DepartmentName"}], + [{"title":"缁勭粐缂栧彿","field":"DepartmentCode"}], + [{"dataKey":"缁勭粐鏈烘瀯","data":[],"title":"涓婄骇缁勭粐","field":"ParentId","type":"cascader"}], + [{"title":"澶囨敞","field":"Remark","type":"textarea"}]]); + const searchFormFields = ref({"DepartmentName":"","DepartmentCode":"","Creator":"","CreateDate":""}); + const searchFormOptions = ref([[{"title":"缁勭粐鍚嶇О","field":"DepartmentName","type":"like"},{"title":"缁勭粐缂栧彿","field":"DepartmentCode"},{"title":"鍒涘缓浜�","field":"Creator"},{"title":"鍒涘缓鏃堕棿","field":"CreateDate","type":"datetime"}]]); + const columns = ref([{field:'DepartmentId',title:'DepartmentId',type:'guid',width:110,hidden:true,readonly:true,require:true,align:'left'}, + {field:'DepartmentName',title:'缁勭粐鍚嶇О',type:'string',link:true,width:180,require:true,align:'left',sort:true}, + {field:'DepartmentCode',title:'缁勭粐缂栧彿',type:'string',width:90,align:'left'}, + {field:'ParentId',title:'涓婄骇缁勭粐',type:'guid',bind:{ key:'缁勭粐鏈烘瀯',data:[]},width:110,hidden:true,align:'left'}, + {field:'DepartmentType',title:'缁勭粐绫诲瀷',type:'string',width:110,hidden:true,align:'left'}, + {field:'Enable',title:'鏄惁鍙敤',type:'int',width:110,hidden:true,align:'left'}, + {field:'Remark',title:'澶囨敞',type:'string',width:100,align:'left'}, + {field:'CreateID',title:'CreateID',type:'int',width:100,hidden:true,align:'left'}, + {field:'Creator',title:'鍒涘缓浜�',type:'string',width:90,align:'left'}, + {field:'CreateDate',title:'鍒涘缓鏃堕棿',type:'datetime',width:145,align:'left',sort:true}, + {field:'ModifyID',title:'ModifyID',type:'int',width:100,hidden:true,align:'left'}, + {field:'Modifier',title:'淇敼浜�',type:'string',width:90,align:'left'}, + {field:'ModifyDate',title:'淇敼鏃堕棿',type:'datetime',width:140,align:'left',sort:true}]); + const detail = ref({ + cnName: "#detailCnName", + table: "#detailTable", + columns: [], + sortName: "", + key: "" + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, + }); +</script> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/test.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/test.vue" new file mode 100644 index 0000000..64786be --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/system/test.vue" @@ -0,0 +1,18 @@ +<template> + +</template> + +<script> +export default { + props:{ + list: { + type: Array, + default: [], + }, + } +} +</script> + +<style> + +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/taskinfo/task.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/taskinfo/task.vue" new file mode 100644 index 0000000..b684958 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/taskinfo/task.vue" @@ -0,0 +1,231 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/taskinfo/task.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "taskId", + footer: "Foots", + cnName: "浠诲姟淇℃伅", + name: "task", + url: "/Task/", + sortName: "CreateDate", + }); + const editFormFields = ref({}); + const editFormOptions = ref([]); + const searchFormFields = ref({ + taskNum: "", + palletCode: "", + roadway: "", + taskStatus: "", + taskType: "", + sourceAddress: "", + targetAddress: "", + currentAddress: "", + nextAddress: "", + creater: "", + createDate: "", + }); + const searchFormOptions = ref([ + [ + { title: "浠诲姟鍙�", field: "taskNum", type: "int" }, + { title: "鎵樼洏缂栧彿", field: "palletCode", type: "like" }, + { title: "鍒涘缓浜�", field: "creater", type: "like" }, + ], + [ + { title: "浠诲姟绫诲瀷",field: "taskType",type: "selectList",dataKey: "taskTypeEnum",data: [],}, + { title: "浠诲姟鐘舵��",field: "taskStatus",type: "selectList",dataKey: "taskStatusEnum",data: [],}, + { title: "宸烽亾鍙�", field: "roadway", type: "like" }, + ], + [ + { title: "璧峰鍦板潃", field: "sourceAddress", type: "like" }, + { title: "鐩爣鍦板潃", field: "targetAddress", type: "like" }, + { title: "鍒涘缓鏃堕棿", field: "createDate", type: "datetime" }, + ], + ]); + const columns = ref([ + { + field: "taskId", + title: "taskId", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "taskNum", + title: "浠诲姟鍙�", + type: "int", + width: 80, + align: "left", + }, + { + field: "palletCode", + title: "鎵樼洏缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "roadway", + title: "宸烽亾鍙�", + type: "string", + width: 90, + align: "left", + }, + { + field: "taskType", + title: "浠诲姟绫诲瀷", + type: "int", + width: 90, + align: "left", + bind: { key: "taskTypeEnum", data: [] }, + }, + { + field: "taskStatus", + title: "浠诲姟鐘舵��", + type: "int", + width: 150, + align: "left", + bind: { key: "taskStatusEnum", data: [] }, + }, + { + field: "sourceAddress", + title: "璧峰鍦板潃", + type: "int", + width: 120, + align: "left", + }, + { + field: "targetAddress", + title: "鐩爣鍦板潃", + type: "string", + width: 120, + align: "left", + }, + // { + // field: "currentAddress", + // title: "褰撳墠浣嶇疆", + // type: "string", + // width: 120, + // align: "left", + // }, + // { + // field: "nextAddress", + // title: "涓嬩竴浣嶇疆", + // type: "string", + // width: 120, + // align: "left", + // }, + { + field: "exceptionMessage", + title: "寮傚父淇℃伅", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "grade", + title: "浼樺厛绾�", + type: "int", + width: 80, + align: "left", + }, + { + field: "depth", + title: "娣卞害", + type: "int", + width: 80, + align: "left", + }, + { + field: "dispatchertime", + title: "浠诲姟涓嬪彂鏃堕棿", + type: "datetime", + width: 150, + align: "left", + hidden:true, + }, + { + field: "wMSId", + title: "WMS浠诲姟涓婚敭", + type: "int", + width: 120, + align: "left", + hidden: true, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 150, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + hidden: true, + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/taskinfo/task_hty.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/taskinfo/task_hty.vue" new file mode 100644 index 0000000..d24a17b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/src/views/taskinfo/task_hty.vue" @@ -0,0 +1,237 @@ + +<template> + <view-grid + ref="grid" + :columns="columns" + :detail="detail" + :editFormFields="editFormFields" + :editFormOptions="editFormOptions" + :searchFormFields="searchFormFields" + :searchFormOptions="searchFormOptions" + :table="table" + :extend="extend" + > + </view-grid> +</template> + <script> +import extend from "@/extension/taskinfo/task_hty.js"; +import { ref, defineComponent } from "vue"; +export default defineComponent({ + setup() { + const table = ref({ + key: "taskId", + footer: "Foots", + cnName: "浠诲姟鍘嗗彶淇℃伅", + name: "task", + url: "/Task_Hty/", + sortName: "CreateDate", + }); + const editFormFields = ref({}); + const editFormOptions = ref([]); + const searchFormFields = ref({ + taskNum: "", + palletCode: "", + roadway: "", + taskStatus: "", + taskType: "", + sourceAddress: "", + targetAddress: "", + currentAddress: "", + nextAddress: "", + creater: "", + createDate: "", + }); + const searchFormOptions = ref([ + [ + { title: "浠诲姟鍙�", field: "taskNum", type: "int" }, + { title: "鎵樼洏缂栧彿", field: "palletCode", type: "like" }, + { title: "鍒涘缓浜�", field: "creater", type: "like" }, + ], + [ + { title: "浠诲姟绫诲瀷",field: "taskType",type: "selectList",dataKey: "taskTypeEnum",data: [],}, + { title: "浠诲姟鐘舵��",field: "taskStatus",type: "selectList",dataKey: "taskStatusEnum",data: [],}, + { title: "宸烽亾鍙�", field: "roadway", type: "like" }, + ], + [ + { title: "璧峰鍦板潃", field: "sourceAddress", type: "like" }, + { title: "鐩爣鍦板潃", field: "targetAddress", type: "like" }, + { title: "鍒涘缓鏃堕棿", field: "createDate", type: "datetime" }, + ], + ]); + const columns = ref([ + { + field: "taskId", + title: "taskId", + type: "int", + width: 90, + hidden: true, + readonly: true, + require: true, + align: "left", + }, + { + field: "taskNum", + title: "浠诲姟鍙�", + type: "int", + width: 80, + align: "left", + }, + { + field: "palletCode", + title: "鎵樼洏缂栧彿", + type: "string", + width: 150, + align: "left", + }, + { + field: "roadway", + title: "宸烽亾鍙�", + type: "string", + width: 90, + align: "left", + }, + { + field: "taskType", + title: "浠诲姟绫诲瀷", + type: "int", + width: 90, + align: "left", + bind: { key: "taskTypeEnum", data: [] }, + }, + { + field: "taskStatus", + title: "浠诲姟鐘舵��", + type: "int", + width: 150, + align: "left", + bind: { key: "taskStatusEnum", data: [] }, + }, + { + field: "sourceAddress", + title: "璧峰鍦板潃", + type: "int", + width: 120, + align: "left", + }, + { + field: "targetAddress", + title: "鐩爣鍦板潃", + type: "string", + width: 120, + align: "left", + }, + // { + // field: "currentAddress", + // title: "褰撳墠浣嶇疆", + // type: "string", + // width: 120, + // align: "left", + // }, + // { + // field: "nextAddress", + // title: "涓嬩竴浣嶇疆", + // type: "string", + // width: 120, + // align: "left", + // }, + { + field: "exceptionMessage", + title: "寮傚父淇℃伅", + type: "string", + width: 90, + align: "left", + hidden: true, + }, + { + field: "grade", + title: "浼樺厛绾�", + type: "int", + width: 80, + align: "left", + }, + { + field: "depth", + title: "娣卞害", + type: "int", + width: 80, + align: "left", + }, + { + field: "dispatchertime", + title: "浠诲姟涓嬪彂鏃堕棿", + type: "datetime", + width: 150, + align: "left", + }, + { + field: "wMSId", + title: "WMS浠诲姟涓婚敭", + type: "int", + width: 120, + align: "left", + hidden: true, + }, + { + field: "creater", + title: "鍒涘缓浜�", + type: "string", + width: 90, + align: "left", + }, + { + field: "createDate", + title: "鍒涘缓鏃堕棿", + type: "datetime", + width: 150, + align: "left", + }, + { + field: "modifier", + title: "淇敼浜�", + type: "string", + width: 100, + align: "left", + }, + { + field: "modifyDate", + title: "淇敼鏃堕棿", + type: "datetime", + width: 160, + align: "left", + }, + { + field: "operateType", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + }, + { + field: "remark", + title: "澶囨敞", + type: "string", + width: 100, + align: "left", + hidden: true, + }, + ]); + const detail = ref({ + cnName: "#detailCnName", + table: "", + columns: [], + sortName: "", + }); + return { + table, + extend, + editFormFields, + editFormOptions, + searchFormFields, + searchFormOptions, + columns, + detail, + }; + }, +}); +</script> + \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/tests/unit/example.spec.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/tests/unit/example.spec.js" new file mode 100644 index 0000000..bc9939b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/tests/unit/example.spec.js" @@ -0,0 +1,13 @@ +import { expect } from 'chai' +import { shallowMount } from '@vue/test-utils' +import HelloWorld from '@/components/HelloWorld.vue' + +describe('HelloWorld.vue', () => { + it('renders props.msg when passed', () => { + const msg = 'new message' + const wrapper = shallowMount(HelloWorld, { + props: { msg } + }) + expect(wrapper.text()).to.include(msg) + }) +}) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/vue.config.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/vue.config.js" new file mode 100644 index 0000000..2d3d8d5 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/vue.config.js" @@ -0,0 +1,59 @@ +// const webpack = require("webpack"); + +module.exports = { + productionSourceMap: false, + lintOnSave: false, + devServer: { + port: 8080, + overlay: { + warning: false, + errors: false + } + }, + css: { + //鏌ョ湅CSS灞炰簬鍝釜css鏂囦欢 + sourceMap: true + }, + configureWebpack: { + module: { + rules: [ + { + test: /\.mjs$/, + include: /node_modules/, + type: "javascript/auto" + }, + { + test: /\.s[ac]ss$/, + use: [ + 'sass-loader' + ] + } + ] + } + }, + //https://cli.vuejs.org/zh/guide/html-and-static-assets.html#html + chainWebpack: (config) => { + // 绉婚櫎 prefetch 鎻掍欢 + config.plugins.delete('prefetch'); + //鑷笅瀹氫箟title + config.plugin('html').tap((args) => { + args[0].title = 'WMS'; + return args; + }); + + // 鎴栬�� + // 淇敼瀹冪殑閫夐」锛� + // config.plugin('prefetch').tap(options => { + // options[0].fileBlacklist = options[0].fileBlacklist || [] + // options[0].fileBlacklist.push(/myasyncRoute(.)+?\.js$/) + // return options + // }) + } + // configureWebpack: { + // plugins: [ + // new webpack.optimize.MinChunkSizePlugin({ + // minChunkSize: 100000 // 閫氳繃鍚堝苟灏忎簬 minChunkSize 澶у皬鐨� chunk锛屽皢 chunk 浣撶Н淇濇寔鍦ㄦ寚瀹氬ぇ灏忛檺鍒朵互涓� + // }) + // ] + // } +}; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/yarn.lock" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/yarn.lock" new file mode 100644 index 0000000..c510891 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSClient/yarn.lock" @@ -0,0 +1,10203 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@achrinza/node-ipc@9.2.2": + "integrity" "sha512-b90U39dx0cU6emsOvy5hxU4ApNXnE3+Tuo8XQZfiKTGelDwpMwBVgBP7QX6dGTcJgu/miyJuNJ/2naFBliNWEw==" + "resolved" "https://registry.npmmirror.com/@achrinza/node-ipc/-/node-ipc-9.2.2.tgz" + "version" "9.2.2" + dependencies: + "@node-ipc/js-queue" "2.0.3" + "event-pubsub" "4.3.0" + "js-message" "1.0.7" + +"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.14.5": + "integrity" "sha1-I7CNdA6D9JxeWZRfvxtD6Au/Tts=" + "resolved" "https://registry.nlark.com/@babel/code-frame/download/@babel/code-frame-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/highlight" "^7.14.5" + +"@babel/compat-data@^7.13.11", "@babel/compat-data@^7.14.5", "@babel/compat-data@^7.14.7": + "integrity" "sha1-ewR9ejqJpn0iWNxh9gTwmPG8fgg=" + "resolved" "https://registry.nlark.com/@babel/compat-data/download/@babel/compat-data-7.14.7.tgz" + "version" "7.14.7" + +"@babel/core@^7.0.0", "@babel/core@^7.0.0-0", "@babel/core@^7.11.0", "@babel/core@^7.12.0", "@babel/core@^7.13.0", "@babel/core@^7.4.0-0": + "integrity" "sha1-4IFOwalQAy/xbBOich3jmoQW/Ks=" + "resolved" "https://registry.nlark.com/@babel/core/download/@babel/core-7.14.6.tgz" + "version" "7.14.6" + dependencies: + "@babel/code-frame" "^7.14.5" + "@babel/generator" "^7.14.5" + "@babel/helper-compilation-targets" "^7.14.5" + "@babel/helper-module-transforms" "^7.14.5" + "@babel/helpers" "^7.14.6" + "@babel/parser" "^7.14.6" + "@babel/template" "^7.14.5" + "@babel/traverse" "^7.14.5" + "@babel/types" "^7.14.5" + "convert-source-map" "^1.7.0" + "debug" "^4.1.0" + "gensync" "^1.0.0-beta.2" + "json5" "^2.1.2" + "semver" "^6.3.0" + "source-map" "^0.5.0" + +"@babel/generator@^7.14.5": + "integrity" "sha1-hI17nwMcrKnQzQrwGwY/Im9S14U=" + "resolved" "https://registry.nlark.com/@babel/generator/download/@babel/generator-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + "jsesc" "^2.5.1" + "source-map" "^0.5.0" + +"@babel/helper-annotate-as-pure@^7.14.5": + "integrity" "sha1-e/R47Dtxcm1WqMpXdbBG/CmHnmE=" + "resolved" "https://registry.nlark.com/@babel/helper-annotate-as-pure/download/@babel/helper-annotate-as-pure-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-builder-binary-assignment-operator-visitor@^7.14.5": + "integrity" "sha1-uTm0P4w3dlRDoZrnStixWXjgoZE=" + "resolved" "https://registry.nlark.com/@babel/helper-builder-binary-assignment-operator-visitor/download/@babel/helper-builder-binary-assignment-operator-visitor-7.14.5.tgz?cache=0&sync_timestamp=1623280539341&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-builder-binary-assignment-operator-visitor%2Fdownload%2F%40babel%2Fhelper-builder-binary-assignment-operator-visitor-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-explode-assignable-expression" "^7.14.5" + "@babel/types" "^7.14.5" + +"@babel/helper-compilation-targets@^7.13.0", "@babel/helper-compilation-targets@^7.14.5", "@babel/helper-compilation-targets@^7.9.6": + "integrity" "sha1-epnF0JZ5Eely/iw0EffVtJhJjs8=" + "resolved" "https://registry.nlark.com/@babel/helper-compilation-targets/download/@babel/helper-compilation-targets-7.14.5.tgz?cache=0&sync_timestamp=1623280514256&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-compilation-targets%2Fdownload%2F%40babel%2Fhelper-compilation-targets-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/compat-data" "^7.14.5" + "@babel/helper-validator-option" "^7.14.5" + "browserslist" "^4.16.6" + "semver" "^6.3.0" + +"@babel/helper-create-class-features-plugin@^7.14.5": + "integrity" "sha1-8RRGm2wG+LXFnGxOdGIfUIU2JUI=" + "resolved" "https://registry.nlark.com/@babel/helper-create-class-features-plugin/download/@babel/helper-create-class-features-plugin-7.14.6.tgz" + "version" "7.14.6" + dependencies: + "@babel/helper-annotate-as-pure" "^7.14.5" + "@babel/helper-function-name" "^7.14.5" + "@babel/helper-member-expression-to-functions" "^7.14.5" + "@babel/helper-optimise-call-expression" "^7.14.5" + "@babel/helper-replace-supers" "^7.14.5" + "@babel/helper-split-export-declaration" "^7.14.5" + +"@babel/helper-create-regexp-features-plugin@^7.14.5": + "integrity" "sha1-x9WsXpz2IcJgV3Ivt6ikxYiTWMQ=" + "resolved" "https://registry.nlark.com/@babel/helper-create-regexp-features-plugin/download/@babel/helper-create-regexp-features-plugin-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-annotate-as-pure" "^7.14.5" + "regexpu-core" "^4.7.1" + +"@babel/helper-define-polyfill-provider@^0.2.2": + "integrity" "sha1-BSXt7FCUZTooJojTTYRuTHXpwLY=" + "resolved" "https://registry.nlark.com/@babel/helper-define-polyfill-provider/download/@babel/helper-define-polyfill-provider-0.2.3.tgz?cache=0&sync_timestamp=1622025430652&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-define-polyfill-provider%2Fdownload%2F%40babel%2Fhelper-define-polyfill-provider-0.2.3.tgz" + "version" "0.2.3" + dependencies: + "@babel/helper-compilation-targets" "^7.13.0" + "@babel/helper-module-imports" "^7.12.13" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/traverse" "^7.13.0" + "debug" "^4.1.1" + "lodash.debounce" "^4.0.8" + "resolve" "^1.14.2" + "semver" "^6.1.2" + +"@babel/helper-explode-assignable-expression@^7.14.5": + "integrity" "sha1-iqcucIIFx7tkPkXHO0OGzfKh9kU=" + "resolved" "https://registry.nlark.com/@babel/helper-explode-assignable-expression/download/@babel/helper-explode-assignable-expression-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-function-name@^7.14.5": + "integrity" "sha1-ieLEdJcvFdjiM7Uu6MSA4s/NUMQ=" + "resolved" "https://registry.nlark.com/@babel/helper-function-name/download/@babel/helper-function-name-7.14.5.tgz?cache=0&sync_timestamp=1623280544273&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-function-name%2Fdownload%2F%40babel%2Fhelper-function-name-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-get-function-arity" "^7.14.5" + "@babel/template" "^7.14.5" + "@babel/types" "^7.14.5" + +"@babel/helper-get-function-arity@^7.14.5": + "integrity" "sha1-Jfv6V5sJN+7h87gF7OTOOYxDGBU=" + "resolved" "https://registry.nlark.com/@babel/helper-get-function-arity/download/@babel/helper-get-function-arity-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-hoist-variables@^7.14.5": + "integrity" "sha1-4N0nwzp45XfXyIhJFqPn7x98f40=" + "resolved" "https://registry.nlark.com/@babel/helper-hoist-variables/download/@babel/helper-hoist-variables-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-member-expression-to-functions@^7.14.5": + "integrity" "sha1-l+ViRL65QhH+J3vYGOOjKcZveXA=" + "resolved" "https://registry.nlark.com/@babel/helper-member-expression-to-functions/download/@babel/helper-member-expression-to-functions-7.14.7.tgz" + "version" "7.14.7" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-module-imports@^7.0.0", "@babel/helper-module-imports@^7.12.13", "@babel/helper-module-imports@^7.14.5", "@babel/helper-module-imports@^7.8.3": + "integrity" "sha1-bRpE32o4yVeqfDEtoHZCnxG0IvM=" + "resolved" "https://registry.nlark.com/@babel/helper-module-imports/download/@babel/helper-module-imports-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-module-transforms@^7.14.5": + "integrity" "sha1-feQvENeJtCPrkC69JAMcp3yx4Q4=" + "resolved" "https://registry.nlark.com/@babel/helper-module-transforms/download/@babel/helper-module-transforms-7.14.5.tgz?cache=0&sync_timestamp=1623280540631&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-module-transforms%2Fdownload%2F%40babel%2Fhelper-module-transforms-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-module-imports" "^7.14.5" + "@babel/helper-replace-supers" "^7.14.5" + "@babel/helper-simple-access" "^7.14.5" + "@babel/helper-split-export-declaration" "^7.14.5" + "@babel/helper-validator-identifier" "^7.14.5" + "@babel/template" "^7.14.5" + "@babel/traverse" "^7.14.5" + "@babel/types" "^7.14.5" + +"@babel/helper-optimise-call-expression@^7.14.5": + "integrity" "sha1-8nOVqGGeBmWz8DZM3bQcJdcbSZw=" + "resolved" "https://registry.nlark.com/@babel/helper-optimise-call-expression/download/@babel/helper-optimise-call-expression-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.13.0", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": + "integrity" "sha1-WsgizpfuxGdBq3ClF5ceRDpwxak=" + "resolved" "https://registry.nlark.com/@babel/helper-plugin-utils/download/@babel/helper-plugin-utils-7.14.5.tgz" + "version" "7.14.5" + +"@babel/helper-remap-async-to-generator@^7.14.5": + "integrity" "sha1-UUOckTYSlY9UqYek/8nuWHogRdY=" + "resolved" "https://registry.nlark.com/@babel/helper-remap-async-to-generator/download/@babel/helper-remap-async-to-generator-7.14.5.tgz?cache=0&sync_timestamp=1623280541106&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-remap-async-to-generator%2Fdownload%2F%40babel%2Fhelper-remap-async-to-generator-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-annotate-as-pure" "^7.14.5" + "@babel/helper-wrap-function" "^7.14.5" + "@babel/types" "^7.14.5" + +"@babel/helper-replace-supers@^7.14.5": + "integrity" "sha1-DswLA8Qc1We0Ak6gFhNMKEFKu5Q=" + "resolved" "https://registry.nlark.com/@babel/helper-replace-supers/download/@babel/helper-replace-supers-7.14.5.tgz?cache=0&sync_timestamp=1623280539767&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-replace-supers%2Fdownload%2F%40babel%2Fhelper-replace-supers-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-member-expression-to-functions" "^7.14.5" + "@babel/helper-optimise-call-expression" "^7.14.5" + "@babel/traverse" "^7.14.5" + "@babel/types" "^7.14.5" + +"@babel/helper-simple-access@^7.14.5": + "integrity" "sha1-ZuqFz1O6C05Yi6d/yBP1OryqQcQ=" + "resolved" "https://registry.nlark.com/@babel/helper-simple-access/download/@babel/helper-simple-access-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-skip-transparent-expression-wrappers@^7.14.5": + "integrity" "sha1-lvSGrAUMqfRLAJ++W305TKs6DuQ=" + "resolved" "https://registry.nlark.com/@babel/helper-skip-transparent-expression-wrappers/download/@babel/helper-skip-transparent-expression-wrappers-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-split-export-declaration@^7.14.5": + "integrity" "sha1-IrI6VO9RwrdgXYUZMMGXbdC8aTo=" + "resolved" "https://registry.nlark.com/@babel/helper-split-export-declaration/download/@babel/helper-split-export-declaration-7.14.5.tgz?cache=0&sync_timestamp=1623280535830&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-split-export-declaration%2Fdownload%2F%40babel%2Fhelper-split-export-declaration-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/types" "^7.14.5" + +"@babel/helper-validator-identifier@^7.14.5": + "integrity" "sha1-0PDid8US4Mk4J3+qhaOWjJpEwOg=" + "resolved" "https://registry.nlark.com/@babel/helper-validator-identifier/download/@babel/helper-validator-identifier-7.14.5.tgz" + "version" "7.14.5" + +"@babel/helper-validator-option@^7.14.5": + "integrity" "sha1-bnKh//GNXfy4eOHmLxoCHEty1aM=" + "resolved" "https://registry.nlark.com/@babel/helper-validator-option/download/@babel/helper-validator-option-7.14.5.tgz" + "version" "7.14.5" + +"@babel/helper-wrap-function@^7.14.5": + "integrity" "sha1-WRnRFb8P4yi4pdY7y2EPUWAfK/8=" + "resolved" "https://registry.nlark.com/@babel/helper-wrap-function/download/@babel/helper-wrap-function-7.14.5.tgz?cache=0&sync_timestamp=1623280540387&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fhelper-wrap-function%2Fdownload%2F%40babel%2Fhelper-wrap-function-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-function-name" "^7.14.5" + "@babel/template" "^7.14.5" + "@babel/traverse" "^7.14.5" + "@babel/types" "^7.14.5" + +"@babel/helpers@^7.14.6": + "integrity" "sha1-W1gwa5XxtH4qAZlDT6hlj6bCFjU=" + "resolved" "https://registry.nlark.com/@babel/helpers/download/@babel/helpers-7.14.6.tgz" + "version" "7.14.6" + dependencies: + "@babel/template" "^7.14.5" + "@babel/traverse" "^7.14.5" + "@babel/types" "^7.14.5" + +"@babel/highlight@^7.14.5": + "integrity" "sha1-aGGlLwOWZAUAH2qlNKAaJNmejNk=" + "resolved" "https://registry.nlark.com/@babel/highlight/download/@babel/highlight-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-validator-identifier" "^7.14.5" + "chalk" "^2.0.0" + "js-tokens" "^4.0.0" + +"@babel/parser@^7.14.5", "@babel/parser@^7.14.6", "@babel/parser@^7.14.7", "@babel/parser@^7.16.4", "@babel/parser@^7.7.0": + "integrity" "sha512-9JKn5vN+hDt0Hdqn1PiJ2guflwP+B6Ga8qbDuoF0PzzVhrzsKIJo8yGqVk6CmMHiMei9w1C1Bp9IMJSIK+HPIQ==" + "resolved" "https://registry.npmmirror.com/@babel/parser/-/parser-7.18.11.tgz" + "version" "7.18.11" + +"@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.14.5": + "integrity" "sha1-S0ZzAuFUjtOxvkO+rizJz0Xgu34=" + "resolved" "https://registry.nlark.com/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/download/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-skip-transparent-expression-wrappers" "^7.14.5" + "@babel/plugin-proposal-optional-chaining" "^7.14.5" + +"@babel/plugin-proposal-async-generator-functions@^7.14.7": + "integrity" "sha1-eEpIw9jtBz9lrc8wtXvL9sgRms4=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-async-generator-functions/download/@babel/plugin-proposal-async-generator-functions-7.14.7.tgz" + "version" "7.14.7" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-remap-async-to-generator" "^7.14.5" + "@babel/plugin-syntax-async-generators" "^7.8.4" + +"@babel/plugin-proposal-class-properties@^7.14.5", "@babel/plugin-proposal-class-properties@^7.8.3": + "integrity" "sha1-QNHuFAxbHjGjUPT17tlFCWVZtC4=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-class-properties/download/@babel/plugin-proposal-class-properties-7.14.5.tgz?cache=0&sync_timestamp=1623280542725&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-proposal-class-properties%2Fdownload%2F%40babel%2Fplugin-proposal-class-properties-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-create-class-features-plugin" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-proposal-class-static-block@^7.14.5": + "integrity" "sha1-FY6eENRJw4Se8+zelKA9nxhBtoE=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-class-static-block/download/@babel/plugin-proposal-class-static-block-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-create-class-features-plugin" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-class-static-block" "^7.14.5" + +"@babel/plugin-proposal-decorators@^7.8.3": + "integrity" "sha1-WbxN/B1mW1pnSc95j/Qil+0bLB0=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-decorators/download/@babel/plugin-proposal-decorators-7.14.5.tgz?cache=0&sync_timestamp=1623280534359&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-proposal-decorators%2Fdownload%2F%40babel%2Fplugin-proposal-decorators-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-create-class-features-plugin" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-decorators" "^7.14.5" + +"@babel/plugin-proposal-dynamic-import@^7.14.5": + "integrity" "sha1-DGYX30YcDB+P/ztHzVl3I2AQHSw=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-dynamic-import/download/@babel/plugin-proposal-dynamic-import-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-dynamic-import" "^7.8.3" + +"@babel/plugin-proposal-export-namespace-from@^7.14.5": + "integrity" "sha1-260kQxDObM0IMHIWfYzqg6Uvr3Y=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-export-namespace-from/download/@babel/plugin-proposal-export-namespace-from-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + +"@babel/plugin-proposal-json-strings@^7.14.5": + "integrity" "sha1-ON5g2zYug6PYyUSshY3fnwwiOes=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-json-strings/download/@babel/plugin-proposal-json-strings-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-json-strings" "^7.8.3" + +"@babel/plugin-proposal-logical-assignment-operators@^7.14.5": + "integrity" "sha1-bmIpwqmbAqspFfglceDMZGpAxzg=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-logical-assignment-operators/download/@babel/plugin-proposal-logical-assignment-operators-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" + +"@babel/plugin-proposal-nullish-coalescing-operator@^7.14.5": + "integrity" "sha1-7jhYnOAOLMWbKZ7D6kBvzToP2vY=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-nullish-coalescing-operator/download/@babel/plugin-proposal-nullish-coalescing-operator-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + +"@babel/plugin-proposal-numeric-separator@^7.14.5": + "integrity" "sha1-g2Mb8z2aUd8YTCECoGmsDFjAXxg=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-numeric-separator/download/@babel/plugin-proposal-numeric-separator-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + +"@babel/plugin-proposal-object-rest-spread@^7.14.7": + "integrity" "sha1-WSCis99/eQHfAgWXTAZBsT/Z02M=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-object-rest-spread/download/@babel/plugin-proposal-object-rest-spread-7.14.7.tgz" + "version" "7.14.7" + dependencies: + "@babel/compat-data" "^7.14.7" + "@babel/helper-compilation-targets" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-transform-parameters" "^7.14.5" + +"@babel/plugin-proposal-optional-catch-binding@^7.14.5": + "integrity" "sha1-k53W7d7/Omf997PwRLU0cmJZjDw=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-optional-catch-binding/download/@babel/plugin-proposal-optional-catch-binding-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + +"@babel/plugin-proposal-optional-chaining@^7.14.5": + "integrity" "sha1-+oNlHmCjYOPxN5fu8AuNUZaVtgM=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-optional-chaining/download/@babel/plugin-proposal-optional-chaining-7.14.5.tgz?cache=0&sync_timestamp=1623281177929&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-proposal-optional-chaining%2Fdownload%2F%40babel%2Fplugin-proposal-optional-chaining-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-skip-transparent-expression-wrappers" "^7.14.5" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + +"@babel/plugin-proposal-private-methods@^7.14.5": + "integrity" "sha1-N0RklZlrKUXzD1vltg1eKqT1eS0=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-private-methods/download/@babel/plugin-proposal-private-methods-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-create-class-features-plugin" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-proposal-private-property-in-object@^7.14.5": + "integrity" "sha1-n2Wk0Ek6lAtMAfiqnT8YlKWH9jY=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-private-property-in-object/download/@babel/plugin-proposal-private-property-in-object-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-annotate-as-pure" "^7.14.5" + "@babel/helper-create-class-features-plugin" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/plugin-syntax-private-property-in-object" "^7.14.5" + +"@babel/plugin-proposal-unicode-property-regex@^7.14.5", "@babel/plugin-proposal-unicode-property-regex@^7.4.4": + "integrity" "sha1-D5XuDnV6XWR/N42qDsp+k/qou+g=" + "resolved" "https://registry.nlark.com/@babel/plugin-proposal-unicode-property-regex/download/@babel/plugin-proposal-unicode-property-regex-7.14.5.tgz?cache=0&sync_timestamp=1623280542681&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-proposal-unicode-property-regex%2Fdownload%2F%40babel%2Fplugin-proposal-unicode-property-regex-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-async-generators@^7.8.4": + "integrity" "sha1-qYP7Gusuw/btBCohD2QOkOeG/g0=" + "resolved" "https://registry.nlark.com/@babel/plugin-syntax-async-generators/download/@babel/plugin-syntax-async-generators-7.8.4.tgz" + "version" "7.8.4" + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-class-properties@^7.12.13": + "integrity" "sha1-tcmHJ0xKOoK4lxR5aTGmtTVErhA=" + "resolved" "https://registry.npm.taobao.org/@babel/plugin-syntax-class-properties/download/@babel/plugin-syntax-class-properties-7.12.13.tgz" + "version" "7.12.13" + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-class-static-block@^7.14.5": + "integrity" "sha1-GV34mxRrS3izv4l/16JXyEZZ1AY=" + "resolved" "https://registry.nlark.com/@babel/plugin-syntax-class-static-block/download/@babel/plugin-syntax-class-static-block-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-decorators@^7.14.5": + "integrity" "sha1-6vucDL4JyK/rlkujp7vWOUWnLyA=" + "resolved" "https://registry.nlark.com/@babel/plugin-syntax-decorators/download/@babel/plugin-syntax-decorators-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-dynamic-import@^7.8.3": + "integrity" "sha1-Yr+Ysto80h1iYVT8lu5bPLaOrLM=" + "resolved" "https://registry.nlark.com/@babel/plugin-syntax-dynamic-import/download/@babel/plugin-syntax-dynamic-import-7.8.3.tgz?cache=0&sync_timestamp=1618847125283&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-syntax-dynamic-import%2Fdownload%2F%40babel%2Fplugin-syntax-dynamic-import-7.8.3.tgz" + "version" "7.8.3" + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-export-namespace-from@^7.8.3": + "integrity" "sha1-AolkqbqA28CUyRXEh618TnpmRlo=" + "resolved" "https://registry.npm.taobao.org/@babel/plugin-syntax-export-namespace-from/download/@babel/plugin-syntax-export-namespace-from-7.8.3.tgz" + "version" "7.8.3" + dependencies: + "@babel/helper-plugin-utils" "^7.8.3" + +"@babel/plugin-syntax-json-strings@^7.8.3": + "integrity" "sha1-AcohtmjNghjJ5kDLbdiMVBKyyWo=" + "resolved" "https://registry.npm.taobao.org/@babel/plugin-syntax-json-strings/download/@babel/plugin-syntax-json-strings-7.8.3.tgz" + "version" "7.8.3" + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-jsx@^7.0.0", "@babel/plugin-syntax-jsx@^7.2.0", "@babel/plugin-syntax-jsx@^7.8.3": + "integrity" "sha1-AA4uJdhnPM5JMAUXo+2kTCY+QgE=" + "resolved" "https://registry.nlark.com/@babel/plugin-syntax-jsx/download/@babel/plugin-syntax-jsx-7.14.5.tgz?cache=0&sync_timestamp=1623280667234&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-syntax-jsx%2Fdownload%2F%40babel%2Fplugin-syntax-jsx-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-logical-assignment-operators@^7.10.4": + "integrity" "sha1-ypHvRjA1MESLkGZSusLp/plB9pk=" + "resolved" "https://registry.nlark.com/@babel/plugin-syntax-logical-assignment-operators/download/@babel/plugin-syntax-logical-assignment-operators-7.10.4.tgz" + "version" "7.10.4" + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-nullish-coalescing-operator@^7.8.3": + "integrity" "sha1-Fn7XA2iIYIH3S1w2xlqIwDtm0ak=" + "resolved" "https://registry.npm.taobao.org/@babel/plugin-syntax-nullish-coalescing-operator/download/@babel/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz" + "version" "7.8.3" + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-numeric-separator@^7.10.4": + "integrity" "sha1-ubBws+M1cM2f0Hun+pHA3Te5r5c=" + "resolved" "https://registry.npm.taobao.org/@babel/plugin-syntax-numeric-separator/download/@babel/plugin-syntax-numeric-separator-7.10.4.tgz" + "version" "7.10.4" + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-object-rest-spread@^7.8.3": + "integrity" "sha1-YOIl7cvZimQDMqLnLdPmbxr1WHE=" + "resolved" "https://registry.npm.taobao.org/@babel/plugin-syntax-object-rest-spread/download/@babel/plugin-syntax-object-rest-spread-7.8.3.tgz" + "version" "7.8.3" + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-catch-binding@^7.8.3": + "integrity" "sha1-YRGiZbz7Ag6579D9/X0mQCue1sE=" + "resolved" "https://registry.npm.taobao.org/@babel/plugin-syntax-optional-catch-binding/download/@babel/plugin-syntax-optional-catch-binding-7.8.3.tgz" + "version" "7.8.3" + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-chaining@^7.8.3": + "integrity" "sha1-T2nCq5UWfgGAzVM2YT+MV4j31Io=" + "resolved" "https://registry.npm.taobao.org/@babel/plugin-syntax-optional-chaining/download/@babel/plugin-syntax-optional-chaining-7.8.3.tgz" + "version" "7.8.3" + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-private-property-in-object@^7.14.5": + "integrity" "sha1-DcZnHsDqIrbpShEU+FeXDNOd4a0=" + "resolved" "https://registry.nlark.com/@babel/plugin-syntax-private-property-in-object/download/@babel/plugin-syntax-private-property-in-object-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-top-level-await@^7.14.5": + "integrity" "sha1-wc/a3DWmRiQAAfBhOCR7dBw02Uw=" + "resolved" "https://registry.nlark.com/@babel/plugin-syntax-top-level-await/download/@babel/plugin-syntax-top-level-await-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-arrow-functions@^7.14.5": + "integrity" "sha1-9xh9lYinaN0IC/TJ/+EX6mL3hio=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-arrow-functions/download/@babel/plugin-transform-arrow-functions-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-async-to-generator@^7.14.5": + "integrity" "sha1-cseJCE2PIJSsuUVjOUPvhEPTnmc=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-async-to-generator/download/@babel/plugin-transform-async-to-generator-7.14.5.tgz?cache=0&sync_timestamp=1623280543644&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-async-to-generator%2Fdownload%2F%40babel%2Fplugin-transform-async-to-generator-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-module-imports" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-remap-async-to-generator" "^7.14.5" + +"@babel/plugin-transform-block-scoped-functions@^7.14.5": + "integrity" "sha1-5IZB2ZnUvBV6Z+8zautUvET9OtQ=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-block-scoped-functions/download/@babel/plugin-transform-block-scoped-functions-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-block-scoping@^7.14.5": + "integrity" "sha1-jMY+YeUPQuB45vCb53WnXyPvmTk=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-block-scoping/download/@babel/plugin-transform-block-scoping-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-classes@^7.14.5": + "integrity" "sha1-DpjoIJezhVCwO0g/m1GnjeCsss8=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-classes/download/@babel/plugin-transform-classes-7.14.5.tgz?cache=0&sync_timestamp=1623280541378&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-classes%2Fdownload%2F%40babel%2Fplugin-transform-classes-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-annotate-as-pure" "^7.14.5" + "@babel/helper-function-name" "^7.14.5" + "@babel/helper-optimise-call-expression" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-replace-supers" "^7.14.5" + "@babel/helper-split-export-declaration" "^7.14.5" + "globals" "^11.1.0" + +"@babel/plugin-transform-computed-properties@^7.14.5": + "integrity" "sha1-G514mHQg0RIj1BGVRhzEO5dLIE8=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-computed-properties/download/@babel/plugin-transform-computed-properties-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-destructuring@^7.14.7": + "integrity" "sha1-CtWO034j4iCE0QnxhSYINeVVdXY=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-destructuring/download/@babel/plugin-transform-destructuring-7.14.7.tgz" + "version" "7.14.7" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-dotall-regex@^7.14.5", "@babel/plugin-transform-dotall-regex@^7.4.4": + "integrity" "sha1-L2v3bka9+AQ7Tn4WzyRTJim6DHo=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-dotall-regex/download/@babel/plugin-transform-dotall-regex-7.14.5.tgz?cache=0&sync_timestamp=1623280544588&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-dotall-regex%2Fdownload%2F%40babel%2Fplugin-transform-dotall-regex-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-duplicate-keys@^7.14.5": + "integrity" "sha1-NlpIRIgb3xUB46nwJw5/D5EXeVQ=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-duplicate-keys/download/@babel/plugin-transform-duplicate-keys-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-exponentiation-operator@^7.14.5": + "integrity" "sha1-UVS43Wo9/m2Qkj1hckvT3uuQtJM=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-exponentiation-operator/download/@babel/plugin-transform-exponentiation-operator-7.14.5.tgz?cache=0&sync_timestamp=1623280545524&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-exponentiation-operator%2Fdownload%2F%40babel%2Fplugin-transform-exponentiation-operator-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-builder-binary-assignment-operator-visitor" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-for-of@^7.14.5": + "integrity" "sha1-2uOEYT3o93wZaohpy/YCpE9/wOs=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-for-of/download/@babel/plugin-transform-for-of-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-function-name@^7.14.5": + "integrity" "sha1-6Bxl7LkAdG1/MYAva+0fUtkV1vI=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-function-name/download/@babel/plugin-transform-function-name-7.14.5.tgz?cache=0&sync_timestamp=1623280538359&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-function-name%2Fdownload%2F%40babel%2Fplugin-transform-function-name-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-function-name" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-literals@^7.14.5": + "integrity" "sha1-QdBsf/XU0J489Fh70+zzkwxzD3g=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-literals/download/@babel/plugin-transform-literals-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-member-expression-literals@^7.14.5": + "integrity" "sha1-s5zVISor8jWmF9Mg7CtIvMCRuKc=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-member-expression-literals/download/@babel/plugin-transform-member-expression-literals-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-modules-amd@^7.14.5": + "integrity" "sha1-T9nOfjQRy4uDhISAtwQdgwBIWPc=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-modules-amd/download/@babel/plugin-transform-modules-amd-7.14.5.tgz?cache=0&sync_timestamp=1623280543412&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-modules-amd%2Fdownload%2F%40babel%2Fplugin-transform-modules-amd-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-module-transforms" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "babel-plugin-dynamic-import-node" "^2.3.3" + +"@babel/plugin-transform-modules-commonjs@^7.14.5": + "integrity" "sha1-eq7g6pgoPelNqYso+MNXAUKdrZc=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-modules-commonjs/download/@babel/plugin-transform-modules-commonjs-7.14.5.tgz?cache=0&sync_timestamp=1623280545201&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-modules-commonjs%2Fdownload%2F%40babel%2Fplugin-transform-modules-commonjs-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-module-transforms" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-simple-access" "^7.14.5" + "babel-plugin-dynamic-import-node" "^2.3.3" + +"@babel/plugin-transform-modules-systemjs@^7.14.5": + "integrity" "sha1-x1NC74sw3N5CldNAGq4k5lY47Sk=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-modules-systemjs/download/@babel/plugin-transform-modules-systemjs-7.14.5.tgz?cache=0&sync_timestamp=1623280544915&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-modules-systemjs%2Fdownload%2F%40babel%2Fplugin-transform-modules-systemjs-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-hoist-variables" "^7.14.5" + "@babel/helper-module-transforms" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-validator-identifier" "^7.14.5" + "babel-plugin-dynamic-import-node" "^2.3.3" + +"@babel/plugin-transform-modules-umd@^7.14.5": + "integrity" "sha1-+2Yt/uaXzOJ0p82lJRkKeQlqpuA=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-modules-umd/download/@babel/plugin-transform-modules-umd-7.14.5.tgz?cache=0&sync_timestamp=1623280545520&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-modules-umd%2Fdownload%2F%40babel%2Fplugin-transform-modules-umd-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-module-transforms" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-named-capturing-groups-regex@^7.14.7": + "integrity" "sha1-YMBokqz53yMeJWwkRkv+ywkI/U4=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-named-capturing-groups-regex/download/@babel/plugin-transform-named-capturing-groups-regex-7.14.7.tgz" + "version" "7.14.7" + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.14.5" + +"@babel/plugin-transform-new-target@^7.14.5": + "integrity" "sha1-Mb2ui5JdyEB26/zSqZQBQ67X2/g=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-new-target/download/@babel/plugin-transform-new-target-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-object-super@^7.14.5": + "integrity" "sha1-0LX66snphZehYanPeMUn7ZNM3EU=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-object-super/download/@babel/plugin-transform-object-super-7.14.5.tgz?cache=0&sync_timestamp=1623280540862&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-object-super%2Fdownload%2F%40babel%2Fplugin-transform-object-super-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-replace-supers" "^7.14.5" + +"@babel/plugin-transform-parameters@^7.14.5": + "integrity" "sha1-SWYuhqHz3cysY2On37H/ChWK/rM=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-parameters/download/@babel/plugin-transform-parameters-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-property-literals@^7.14.5": + "integrity" "sha1-DduqH4PbNgbxzfSEb6HftHNFizQ=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-property-literals/download/@babel/plugin-transform-property-literals-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-regenerator@^7.14.5": + "integrity" "sha1-lnb9VwftKPUicnxbPAqoVERAsE8=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-regenerator/download/@babel/plugin-transform-regenerator-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "regenerator-transform" "^0.14.2" + +"@babel/plugin-transform-reserved-words@^7.14.5": + "integrity" "sha1-xEWJtmHP2++NQwDcx0ad/6kvgwQ=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-reserved-words/download/@babel/plugin-transform-reserved-words-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-runtime@^7.11.0": + "integrity" "sha1-MEkdrUnGBZ+Pj6XuiJagCJ6YdSM=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-runtime/download/@babel/plugin-transform-runtime-7.14.5.tgz?cache=0&sync_timestamp=1623280540797&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-runtime%2Fdownload%2F%40babel%2Fplugin-transform-runtime-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-module-imports" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "babel-plugin-polyfill-corejs2" "^0.2.2" + "babel-plugin-polyfill-corejs3" "^0.2.2" + "babel-plugin-polyfill-regenerator" "^0.2.2" + "semver" "^6.3.0" + +"@babel/plugin-transform-shorthand-properties@^7.14.5": + "integrity" "sha1-l/E4VfFAkzjYyty6ymcK154JGlg=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-shorthand-properties/download/@babel/plugin-transform-shorthand-properties-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-spread@^7.14.6": + "integrity" "sha1-a9QOV/596UqpBIUZY7VhZlL3MUQ=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-spread/download/@babel/plugin-transform-spread-7.14.6.tgz" + "version" "7.14.6" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-skip-transparent-expression-wrappers" "^7.14.5" + +"@babel/plugin-transform-sticky-regex@^7.14.5": + "integrity" "sha1-W2F1Qmdei3dhKUOB88KMYz9Arrk=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-sticky-regex/download/@babel/plugin-transform-sticky-regex-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-template-literals@^7.14.5": + "integrity" "sha1-pfK8Izk32EU4hdxza92Nn/q/PZM=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-template-literals/download/@babel/plugin-transform-template-literals-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-typeof-symbol@^7.14.5": + "integrity" "sha1-Oa8nOemJor0pG/a1PxaYFCPUV9Q=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-typeof-symbol/download/@babel/plugin-transform-typeof-symbol-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-unicode-escapes@^7.14.5": + "integrity" "sha1-nUvSpoHjxdes9PV/qeURddkdDGs=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-unicode-escapes/download/@babel/plugin-transform-unicode-escapes-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-transform-unicode-regex@^7.14.5": + "integrity" "sha1-TNCbbIQl3YElXHzrP7GDbnQUOC4=" + "resolved" "https://registry.nlark.com/@babel/plugin-transform-unicode-regex/download/@babel/plugin-transform-unicode-regex-7.14.5.tgz?cache=0&sync_timestamp=1623280536838&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fplugin-transform-unicode-regex%2Fdownload%2F%40babel%2Fplugin-transform-unicode-regex-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/preset-env@^7.11.0": + "integrity" "sha1-XHCyLUwtiTsD2MiGpcF0IlArkyo=" + "resolved" "https://registry.nlark.com/@babel/preset-env/download/@babel/preset-env-7.14.7.tgz?cache=0&sync_timestamp=1624313309952&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fpreset-env%2Fdownload%2F%40babel%2Fpreset-env-7.14.7.tgz" + "version" "7.14.7" + dependencies: + "@babel/compat-data" "^7.14.7" + "@babel/helper-compilation-targets" "^7.14.5" + "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-validator-option" "^7.14.5" + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.14.5" + "@babel/plugin-proposal-async-generator-functions" "^7.14.7" + "@babel/plugin-proposal-class-properties" "^7.14.5" + "@babel/plugin-proposal-class-static-block" "^7.14.5" + "@babel/plugin-proposal-dynamic-import" "^7.14.5" + "@babel/plugin-proposal-export-namespace-from" "^7.14.5" + "@babel/plugin-proposal-json-strings" "^7.14.5" + "@babel/plugin-proposal-logical-assignment-operators" "^7.14.5" + "@babel/plugin-proposal-nullish-coalescing-operator" "^7.14.5" + "@babel/plugin-proposal-numeric-separator" "^7.14.5" + "@babel/plugin-proposal-object-rest-spread" "^7.14.7" + "@babel/plugin-proposal-optional-catch-binding" "^7.14.5" + "@babel/plugin-proposal-optional-chaining" "^7.14.5" + "@babel/plugin-proposal-private-methods" "^7.14.5" + "@babel/plugin-proposal-private-property-in-object" "^7.14.5" + "@babel/plugin-proposal-unicode-property-regex" "^7.14.5" + "@babel/plugin-syntax-async-generators" "^7.8.4" + "@babel/plugin-syntax-class-properties" "^7.12.13" + "@babel/plugin-syntax-class-static-block" "^7.14.5" + "@babel/plugin-syntax-dynamic-import" "^7.8.3" + "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + "@babel/plugin-syntax-json-strings" "^7.8.3" + "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + "@babel/plugin-syntax-private-property-in-object" "^7.14.5" + "@babel/plugin-syntax-top-level-await" "^7.14.5" + "@babel/plugin-transform-arrow-functions" "^7.14.5" + "@babel/plugin-transform-async-to-generator" "^7.14.5" + "@babel/plugin-transform-block-scoped-functions" "^7.14.5" + "@babel/plugin-transform-block-scoping" "^7.14.5" + "@babel/plugin-transform-classes" "^7.14.5" + "@babel/plugin-transform-computed-properties" "^7.14.5" + "@babel/plugin-transform-destructuring" "^7.14.7" + "@babel/plugin-transform-dotall-regex" "^7.14.5" + "@babel/plugin-transform-duplicate-keys" "^7.14.5" + "@babel/plugin-transform-exponentiation-operator" "^7.14.5" + "@babel/plugin-transform-for-of" "^7.14.5" + "@babel/plugin-transform-function-name" "^7.14.5" + "@babel/plugin-transform-literals" "^7.14.5" + "@babel/plugin-transform-member-expression-literals" "^7.14.5" + "@babel/plugin-transform-modules-amd" "^7.14.5" + "@babel/plugin-transform-modules-commonjs" "^7.14.5" + "@babel/plugin-transform-modules-systemjs" "^7.14.5" + "@babel/plugin-transform-modules-umd" "^7.14.5" + "@babel/plugin-transform-named-capturing-groups-regex" "^7.14.7" + "@babel/plugin-transform-new-target" "^7.14.5" + "@babel/plugin-transform-object-super" "^7.14.5" + "@babel/plugin-transform-parameters" "^7.14.5" + "@babel/plugin-transform-property-literals" "^7.14.5" + "@babel/plugin-transform-regenerator" "^7.14.5" + "@babel/plugin-transform-reserved-words" "^7.14.5" + "@babel/plugin-transform-shorthand-properties" "^7.14.5" + "@babel/plugin-transform-spread" "^7.14.6" + "@babel/plugin-transform-sticky-regex" "^7.14.5" + "@babel/plugin-transform-template-literals" "^7.14.5" + "@babel/plugin-transform-typeof-symbol" "^7.14.5" + "@babel/plugin-transform-unicode-escapes" "^7.14.5" + "@babel/plugin-transform-unicode-regex" "^7.14.5" + "@babel/preset-modules" "^0.1.4" + "@babel/types" "^7.14.5" + "babel-plugin-polyfill-corejs2" "^0.2.2" + "babel-plugin-polyfill-corejs3" "^0.2.2" + "babel-plugin-polyfill-regenerator" "^0.2.2" + "core-js-compat" "^3.15.0" + "semver" "^6.3.0" + +"@babel/preset-modules@^0.1.4": + "integrity" "sha1-Ni8raMZihClw/bXiVP/I/BwuQV4=" + "resolved" "https://registry.nlark.com/@babel/preset-modules/download/@babel/preset-modules-0.1.4.tgz" + "version" "0.1.4" + dependencies: + "@babel/helper-plugin-utils" "^7.0.0" + "@babel/plugin-proposal-unicode-property-regex" "^7.4.4" + "@babel/plugin-transform-dotall-regex" "^7.4.4" + "@babel/types" "^7.4.4" + "esutils" "^2.0.2" + +"@babel/runtime-corejs2@^7.0.0": + "integrity" "sha1-5dOhpaCPRJhzTdNwGvT9GN2Gd7U=" + "resolved" "https://registry.nlark.com/@babel/runtime-corejs2/download/@babel/runtime-corejs2-7.14.6.tgz" + "version" "7.14.6" + dependencies: + "core-js" "^2.6.5" + "regenerator-runtime" "^0.13.4" + +"@babel/runtime-corejs3@^7.11.2": + "integrity" "sha1-+yGxzxFlDcuPz03i5rO4z0Edo/M=" + "resolved" "https://registry.nlark.com/@babel/runtime-corejs3/download/@babel/runtime-corejs3-7.14.9.tgz?cache=0&sync_timestamp=1627804572552&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Fruntime-corejs3%2Fdownload%2F%40babel%2Fruntime-corejs3-7.14.9.tgz" + "version" "7.14.9" + dependencies: + "core-js-pure" "^3.16.0" + "regenerator-runtime" "^0.13.4" + +"@babel/runtime@^7.11.0", "@babel/runtime@^7.11.2", "@babel/runtime@^7.8.4": + "integrity" "sha1-U1IDvAiS78fexgvcJ7Ls9uQJBi0=" + "resolved" "https://registry.nlark.com/@babel/runtime/download/@babel/runtime-7.14.6.tgz" + "version" "7.14.6" + dependencies: + "regenerator-runtime" "^0.13.4" + +"@babel/template@^7.0.0", "@babel/template@^7.14.5": + "integrity" "sha1-qbydizM1T/blWpxg0RCSAKaJdPQ=" + "resolved" "https://registry.nlark.com/@babel/template/download/@babel/template-7.14.5.tgz?cache=0&sync_timestamp=1623280543555&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Ftemplate%2Fdownload%2F%40babel%2Ftemplate-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/code-frame" "^7.14.5" + "@babel/parser" "^7.14.5" + "@babel/types" "^7.14.5" + +"@babel/traverse@^7.0.0", "@babel/traverse@^7.13.0", "@babel/traverse@^7.14.5", "@babel/traverse@^7.7.0": + "integrity" "sha1-ZAB8l3TP3Dq9I7B4C8GKPONjF1M=" + "resolved" "https://registry.nlark.com/@babel/traverse/download/@babel/traverse-7.14.7.tgz?cache=0&sync_timestamp=1624313310223&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40babel%2Ftraverse%2Fdownload%2F%40babel%2Ftraverse-7.14.7.tgz" + "version" "7.14.7" + dependencies: + "@babel/code-frame" "^7.14.5" + "@babel/generator" "^7.14.5" + "@babel/helper-function-name" "^7.14.5" + "@babel/helper-hoist-variables" "^7.14.5" + "@babel/helper-split-export-declaration" "^7.14.5" + "@babel/parser" "^7.14.7" + "@babel/types" "^7.14.5" + "debug" "^4.1.0" + "globals" "^11.1.0" + +"@babel/types@^7.0.0", "@babel/types@^7.14.5", "@babel/types@^7.4.4", "@babel/types@^7.7.0": + "integrity" "sha1-O7mXuoKaIQTO2yBonEpbgSHTg/8=" + "resolved" "https://registry.nlark.com/@babel/types/download/@babel/types-7.14.5.tgz" + "version" "7.14.5" + dependencies: + "@babel/helper-validator-identifier" "^7.14.5" + "to-fast-properties" "^2.0.0" + +"@ctrl/tinycolor@^3.4.1": + "integrity" "sha512-ej5oVy6lykXsvieQtqZxCOaLT+xD4+QNarq78cIYISHmZXshCvROLudpQN3lfL8G0NL7plMSSK+zlyvCaIJ4Iw==" + "resolved" "https://registry.npmmirror.com/@ctrl/tinycolor/-/tinycolor-3.4.1.tgz" + "version" "3.4.1" + +"@element-plus/icons-vue@^2.0.6", "@element-plus/icons-vue@^2.1.0": + "integrity" "sha512-PSBn3elNoanENc1vnCfh+3WA9fimRC7n+fWkf3rE5jvv+aBohNHABC/KAR5KWPecxWxDTVT1ERpRbOMRcOV/vA==" + "resolved" "https://registry.npmjs.org/@element-plus/icons-vue/-/icons-vue-2.1.0.tgz" + "version" "2.1.0" + +"@floating-ui/core@^0.7.3": + "integrity" "sha512-buc8BXHmG9l82+OQXOFU3Kr2XQx9ys01U/Q9HMIrZ300iLc8HLMgh7dcCqgYzAzf4BkoQvDcXf5Y+CuEZ5JBYg==" + "resolved" "https://registry.npmmirror.com/@floating-ui/core/-/core-0.7.3.tgz" + "version" "0.7.3" + +"@floating-ui/dom@^0.5.4": + "integrity" "sha512-419BMceRLq0RrmTSDxn8hf9R3VCJv2K9PUfugh5JyEFmdjzDo+e8U5EdR8nzKq8Yj1htzLm3b6eQEEam3/rrtg==" + "resolved" "https://registry.npmmirror.com/@floating-ui/dom/-/dom-0.5.4.tgz" + "version" "0.5.4" + dependencies: + "@floating-ui/core" "^0.7.3" + +"@hapi/address@2.x.x": + "integrity" "sha1-XWftQ/P9QaadS5/3tW58DR0KgeU=" + "resolved" "https://registry.npm.taobao.org/@hapi/address/download/@hapi/address-2.1.4.tgz" + "version" "2.1.4" + +"@hapi/bourne@1.x.x": + "integrity" "sha1-CnCVreoGckPOMoPhtWuKj0U7JCo=" + "resolved" "https://registry.npm.taobao.org/@hapi/bourne/download/@hapi/bourne-1.3.2.tgz" + "version" "1.3.2" + +"@hapi/hoek@^8.3.0", "@hapi/hoek@8.x.x": + "integrity" "sha1-/elgZMpEbeyMVajC8TCVewcMbgY=" + "resolved" "https://registry.nlark.com/@hapi/hoek/download/@hapi/hoek-8.5.1.tgz" + "version" "8.5.1" + +"@hapi/joi@^15.0.1": + "integrity" "sha1-xnW4pxKW8Cgz+NbSQ7NMV7jOGdc=" + "resolved" "https://registry.npm.taobao.org/@hapi/joi/download/@hapi/joi-15.1.1.tgz" + "version" "15.1.1" + dependencies: + "@hapi/address" "2.x.x" + "@hapi/bourne" "1.x.x" + "@hapi/hoek" "8.x.x" + "@hapi/topo" "3.x.x" + +"@hapi/topo@3.x.x": + "integrity" "sha1-aNk1+j6uf91asNf5U/MgXYsr/Ck=" + "resolved" "https://registry.nlark.com/@hapi/topo/download/@hapi/topo-3.1.6.tgz" + "version" "3.1.6" + dependencies: + "@hapi/hoek" "^8.3.0" + +"@intervolga/optimize-cssnano-plugin@^1.0.5": + "integrity" "sha1-vnx4RhKLiPapsdEmGgrQbrXA/fg=" + "resolved" "https://registry.npm.taobao.org/@intervolga/optimize-cssnano-plugin/download/@intervolga/optimize-cssnano-plugin-1.0.6.tgz" + "version" "1.0.6" + dependencies: + "cssnano" "^4.0.0" + "cssnano-preset-default" "^4.0.0" + "postcss" "^7.0.0" + +"@microsoft/signalr@^6.0.4": + "integrity" "sha512-YeWRh4LxfYnq4I5CKw17/HOq8rY+ouTv6Bq+s55122StE3pK29j8j2OpP+1PA3D1ksHPfy7dFIgC33yr/E+01A==" + "resolved" "https://registry.npmmirror.com/@microsoft/signalr/-/signalr-6.0.4.tgz" + "version" "6.0.4" + dependencies: + "abort-controller" "^3.0.0" + "eventsource" "^1.0.7" + "fetch-cookie" "^0.11.0" + "node-fetch" "^2.6.7" + "ws" "^7.4.5" + +"@mrmlnc/readdir-enhanced@^2.2.1": + "integrity" "sha1-UkryQNGjYFJ7cwR17PoTRKpUDd4=" + "resolved" "https://registry.npm.taobao.org/@mrmlnc/readdir-enhanced/download/@mrmlnc/readdir-enhanced-2.2.1.tgz" + "version" "2.2.1" + dependencies: + "call-me-maybe" "^1.0.1" + "glob-to-regexp" "^0.3.0" + +"@node-ipc/js-queue@2.0.3": + "integrity" "sha512-fL1wpr8hhD5gT2dA1qifeVaoDFlQR5es8tFuKqjHX+kdOtdNHnxkVZbtIrR2rxnMFvehkjaZRNV2H/gPXlb0hw==" + "resolved" "https://registry.npmmirror.com/@node-ipc/js-queue/-/js-queue-2.0.3.tgz" + "version" "2.0.3" + dependencies: + "easy-stack" "1.0.1" + +"@nodelib/fs.scandir@2.1.5": + "integrity" "sha1-dhnC6yGyVIP20WdUi0z9WnSIw9U=" + "resolved" "https://registry.nlark.com/@nodelib/fs.scandir/download/@nodelib/fs.scandir-2.1.5.tgz" + "version" "2.1.5" + dependencies: + "@nodelib/fs.stat" "2.0.5" + "run-parallel" "^1.1.9" + +"@nodelib/fs.stat@^1.1.2": + "integrity" "sha1-K1o6s/kYzKSKjHVMCBaOPwPrphs=" + "resolved" "https://registry.nlark.com/@nodelib/fs.stat/download/@nodelib/fs.stat-1.1.3.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40nodelib%2Ffs.stat%2Fdownload%2F%40nodelib%2Ffs.stat-1.1.3.tgz" + "version" "1.1.3" + +"@nodelib/fs.stat@^2.0.2": + "integrity" "sha1-W9Jir5Tp0lvR5xsF3u1Eh2oiLos=" + "resolved" "https://registry.nlark.com/@nodelib/fs.stat/download/@nodelib/fs.stat-2.0.5.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40nodelib%2Ffs.stat%2Fdownload%2F%40nodelib%2Ffs.stat-2.0.5.tgz" + "version" "2.0.5" + +"@nodelib/fs.stat@2.0.5": + "integrity" "sha1-W9Jir5Tp0lvR5xsF3u1Eh2oiLos=" + "resolved" "https://registry.nlark.com/@nodelib/fs.stat/download/@nodelib/fs.stat-2.0.5.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40nodelib%2Ffs.stat%2Fdownload%2F%40nodelib%2Ffs.stat-2.0.5.tgz" + "version" "2.0.5" + +"@nodelib/fs.walk@^1.2.3": + "integrity" "sha1-6Vc36LtnRt3t9pxVaVNJTxlv5po=" + "resolved" "https://registry.nlark.com/@nodelib/fs.walk/download/@nodelib/fs.walk-1.2.8.tgz?cache=0&sync_timestamp=1625769855088&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40nodelib%2Ffs.walk%2Fdownload%2F%40nodelib%2Ffs.walk-1.2.8.tgz" + "version" "1.2.8" + dependencies: + "@nodelib/fs.scandir" "2.1.5" + "fastq" "^1.6.0" + +"@popperjs/core@npm:@sxzz/popperjs-es@^2.11.7": + "integrity" "sha512-Ccy0NlLkzr0Ex2FKvh2X+OyERHXJ88XJ1MXtsI9y9fGexlaXaVTPzBCRBwIxFkORuOb+uBqeu+RqnpgYTEZRUQ==" + "resolved" "https://registry.npmmirror.com/@sxzz/popperjs-es/-/popperjs-es-2.11.7.tgz" + "version" "2.11.7" + +"@soda/friendly-errors-webpack-plugin@^1.7.1": + "integrity" "sha1-hHUdgqkwGdXJLAzw5FrFkIfNIkA=" + "resolved" "https://registry.npm.taobao.org/@soda/friendly-errors-webpack-plugin/download/@soda/friendly-errors-webpack-plugin-1.8.0.tgz?cache=0&sync_timestamp=1607927406873&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40soda%2Ffriendly-errors-webpack-plugin%2Fdownload%2F%40soda%2Ffriendly-errors-webpack-plugin-1.8.0.tgz" + "version" "1.8.0" + dependencies: + "chalk" "^2.4.2" + "error-stack-parser" "^2.0.2" + "string-width" "^2.0.0" + "strip-ansi" "^5" + +"@soda/get-current-script@^1.0.0": + "integrity" "sha1-pTUV2yXYA4N0OBtzryC7Ty5QjYc=" + "resolved" "https://registry.npm.taobao.org/@soda/get-current-script/download/@soda/get-current-script-1.0.2.tgz" + "version" "1.0.2" + +"@tootallnate/once@1": + "integrity" "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==" + "resolved" "https://registry.npmmirror.com/@tootallnate/once/-/once-1.1.2.tgz" + "version" "1.1.2" + +"@types/body-parser@*": + "integrity" "sha1-DAF0xCp9AXuBgwPUtdlpywt1kpw=" + "resolved" "https://registry.nlark.com/@types/body-parser/download/@types/body-parser-1.19.1.tgz?cache=0&sync_timestamp=1625595908991&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fbody-parser%2Fdownload%2F%40types%2Fbody-parser-1.19.1.tgz" + "version" "1.19.1" + dependencies: + "@types/connect" "*" + "@types/node" "*" + +"@types/connect-history-api-fallback@*": + "integrity" "sha1-0feooJ0O1aV67lrpwYq5uAMgXa4=" + "resolved" "https://registry.nlark.com/@types/connect-history-api-fallback/download/@types/connect-history-api-fallback-1.3.5.tgz" + "version" "1.3.5" + dependencies: + "@types/express-serve-static-core" "*" + "@types/node" "*" + +"@types/connect@*": + "integrity" "sha1-X89q5EXkAh0fwiGaSHPMc6O7KtE=" + "resolved" "https://registry.nlark.com/@types/connect/download/@types/connect-3.4.35.tgz" + "version" "3.4.35" + dependencies: + "@types/node" "*" + +"@types/express-serve-static-core@*", "@types/express-serve-static-core@^4.17.18": + "integrity" "sha1-6kH5O/fg1ZzVp2ZlBo7WqraBXAc=" + "resolved" "https://registry.nlark.com/@types/express-serve-static-core/download/@types/express-serve-static-core-4.17.24.tgz?cache=0&sync_timestamp=1625762134763&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fexpress-serve-static-core%2Fdownload%2F%40types%2Fexpress-serve-static-core-4.17.24.tgz" + "version" "4.17.24" + dependencies: + "@types/node" "*" + "@types/qs" "*" + "@types/range-parser" "*" + +"@types/express@*": + "integrity" "sha1-p24plXKJmbq1GjP6vOHXBaNwkDQ=" + "resolved" "https://registry.nlark.com/@types/express/download/@types/express-4.17.13.tgz?cache=0&sync_timestamp=1625605304761&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fexpress%2Fdownload%2F%40types%2Fexpress-4.17.13.tgz" + "version" "4.17.13" + dependencies: + "@types/body-parser" "*" + "@types/express-serve-static-core" "^4.17.18" + "@types/qs" "*" + "@types/serve-static" "*" + +"@types/glob@^7.1.1": + "integrity" "sha1-6lniHS7lxReRTLS8jkFTuZ5WZnI=" + "resolved" "https://registry.nlark.com/@types/glob/download/@types/glob-7.1.4.tgz?cache=0&sync_timestamp=1625605304235&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fglob%2Fdownload%2F%40types%2Fglob-7.1.4.tgz" + "version" "7.1.4" + dependencies: + "@types/minimatch" "*" + "@types/node" "*" + +"@types/http-proxy@^1.17.5": + "integrity" "sha1-MOqFzCyGg2g1Kjfw0NNYHiSDTG8=" + "resolved" "https://registry.nlark.com/@types/http-proxy/download/@types/http-proxy-1.17.7.tgz" + "version" "1.17.7" + dependencies: + "@types/node" "*" + +"@types/json-schema@^7.0.5", "@types/json-schema@^7.0.7": + "integrity" "sha1-7fG/Hb9OBEE8qOWxezt9fVS1mBg=" + "resolved" "https://registry.nlark.com/@types/json-schema/download/@types/json-schema-7.0.8.tgz" + "version" "7.0.8" + +"@types/lodash-es@*", "@types/lodash-es@^4.17.6": + "integrity" "sha512-R+zTeVUKDdfoRxpAryaQNRKk3105Rrgx2CFRClIgRGaqDTdjsm8h6IYA8ir584W3ePzkZfst5xIgDwYrlh9HLg==" + "resolved" "https://registry.npmmirror.com/@types/lodash-es/-/lodash-es-4.17.6.tgz" + "version" "4.17.6" + dependencies: + "@types/lodash" "*" + +"@types/lodash@*", "@types/lodash@^4.14.182": + "integrity" "sha512-RoZphVtHbxPZizt4IcILciSWiC6dcn+eZ8oX9IWEYfDMcocdd42f7NPI6fQj+6zI8y4E0L7gu2pcZKLGTRaV9Q==" + "resolved" "https://registry.npmmirror.com/@types/lodash/-/lodash-4.14.184.tgz" + "version" "4.14.184" + +"@types/mime@^1": + "integrity" "sha1-k+Jb+e51/g/YC1lLxP6w6GIRG1o=" + "resolved" "https://registry.nlark.com/@types/mime/download/@types/mime-1.3.2.tgz" + "version" "1.3.2" + +"@types/minimatch@*": + "integrity" "sha1-EAHMXmo3BLg8I2An538vWOoBD0A=" + "resolved" "https://registry.nlark.com/@types/minimatch/download/@types/minimatch-3.0.5.tgz?cache=0&sync_timestamp=1625616310061&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fminimatch%2Fdownload%2F%40types%2Fminimatch-3.0.5.tgz" + "version" "3.0.5" + +"@types/minimist@^1.2.0": + "integrity" "sha1-7nceK6Sz3Fs3KTXVSf2WF780W4w=" + "resolved" "https://registry.nlark.com/@types/minimist/download/@types/minimist-1.2.2.tgz?cache=0&sync_timestamp=1625616254387&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fminimist%2Fdownload%2F%40types%2Fminimist-1.2.2.tgz" + "version" "1.2.2" + +"@types/node@*": + "integrity" "sha1-ZVQygX+DtRrIacLVHdgwX7g0LhY=" + "resolved" "https://registry.nlark.com/@types/node/download/@types/node-16.3.2.tgz?cache=0&sync_timestamp=1626221012858&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fnode%2Fdownload%2F%40types%2Fnode-16.3.2.tgz" + "version" "16.3.2" + +"@types/normalize-package-data@^2.4.0": + "integrity" "sha1-0zV0eaD9/dWQf+Z+F+CoXJBuEwE=" + "resolved" "https://registry.nlark.com/@types/normalize-package-data/download/@types/normalize-package-data-2.4.1.tgz?cache=0&sync_timestamp=1625675733240&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fnormalize-package-data%2Fdownload%2F%40types%2Fnormalize-package-data-2.4.1.tgz" + "version" "2.4.1" + +"@types/q@^1.5.1": + "integrity" "sha1-daKo59irSyMEFFBdkjNdHctTpt8=" + "resolved" "https://registry.nlark.com/@types/q/download/@types/q-1.5.5.tgz?cache=0&sync_timestamp=1625678452535&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fq%2Fdownload%2F%40types%2Fq-1.5.5.tgz" + "version" "1.5.5" + +"@types/qs@*": + "integrity" "sha1-Y7t9Bn2xB8weRXwwO8JdUR/r9ss=" + "resolved" "https://registry.nlark.com/@types/qs/download/@types/qs-6.9.7.tgz" + "version" "6.9.7" + +"@types/range-parser@*": + "integrity" "sha1-zWZ7z90CUhOq+3ylkVqTJZCs3Nw=" + "resolved" "https://registry.nlark.com/@types/range-parser/download/@types/range-parser-1.2.4.tgz" + "version" "1.2.4" + +"@types/serve-static@*": + "integrity" "sha1-9eDOh5fS18xevtpIpSyWxPpHqNk=" + "resolved" "https://registry.nlark.com/@types/serve-static/download/@types/serve-static-1.13.10.tgz" + "version" "1.13.10" + dependencies: + "@types/mime" "^1" + "@types/node" "*" + +"@types/source-list-map@*": + "integrity" "sha1-AHiDYGP/rxdBI0m7o2QIfgrALsk=" + "resolved" "https://registry.nlark.com/@types/source-list-map/download/@types/source-list-map-0.1.2.tgz" + "version" "0.1.2" + +"@types/tapable@^1": + "integrity" "sha1-uUpDkchWZse3Mpn9OtedT6pDUxA=" + "resolved" "https://registry.nlark.com/@types/tapable/download/@types/tapable-1.0.8.tgz" + "version" "1.0.8" + +"@types/uglify-js@*": + "integrity" "sha1-XoienoHpQkXHW2RQYA4cXqKHiuo=" + "resolved" "https://registry.nlark.com/@types/uglify-js/download/@types/uglify-js-3.13.1.tgz?cache=0&sync_timestamp=1625249395387&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fuglify-js%2Fdownload%2F%40types%2Fuglify-js-3.13.1.tgz" + "version" "3.13.1" + dependencies: + "source-map" "^0.6.1" + +"@types/web-bluetooth@^0.0.15": + "integrity" "sha512-w7hEHXnPMEZ+4nGKl/KDRVpxkwYxYExuHOYXyzIzCDzEZ9ZCGMAewulr9IqJu2LR4N37fcnb1XVeuZ09qgOxhA==" + "resolved" "https://registry.npmmirror.com/@types/web-bluetooth/-/web-bluetooth-0.0.15.tgz" + "version" "0.0.15" + +"@types/webpack-dev-server@^3.11.0": + "integrity" "sha1-9KJUo90GZ8juSvkNQq/bStHWB/M=" + "resolved" "https://registry.nlark.com/@types/webpack-dev-server/download/@types/webpack-dev-server-3.11.5.tgz?cache=0&sync_timestamp=1625251651898&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fwebpack-dev-server%2Fdownload%2F%40types%2Fwebpack-dev-server-3.11.5.tgz" + "version" "3.11.5" + dependencies: + "@types/connect-history-api-fallback" "*" + "@types/express" "*" + "@types/serve-static" "*" + "@types/webpack" "^4" + "http-proxy-middleware" "^1.0.0" + +"@types/webpack-sources@*": + "integrity" "sha1-avF+Oj3tce7CuYAI18EvSYoKRQY=" + "resolved" "https://registry.nlark.com/@types/webpack-sources/download/@types/webpack-sources-2.1.1.tgz?cache=0&sync_timestamp=1625251653385&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fwebpack-sources%2Fdownload%2F%40types%2Fwebpack-sources-2.1.1.tgz" + "version" "2.1.1" + dependencies: + "@types/node" "*" + "@types/source-list-map" "*" + "source-map" "^0.7.3" + +"@types/webpack@^4", "@types/webpack@^4.0.0": + "integrity" "sha1-/T220NQeFFqO7q/NPEp8zekGjdw=" + "resolved" "https://registry.nlark.com/@types/webpack/download/@types/webpack-4.41.30.tgz?cache=0&sync_timestamp=1625251660875&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40types%2Fwebpack%2Fdownload%2F%40types%2Fwebpack-4.41.30.tgz" + "version" "4.41.30" + dependencies: + "@types/node" "*" + "@types/tapable" "^1" + "@types/uglify-js" "*" + "@types/webpack-sources" "*" + "anymatch" "^3.0.0" + "source-map" "^0.6.0" + +"@vue/babel-helper-vue-jsx-merge-props@^1.2.1": + "integrity" "sha1-MWJKelBfsU2h1YAjclpMXycOaoE=" + "resolved" "https://registry.nlark.com/@vue/babel-helper-vue-jsx-merge-props/download/@vue/babel-helper-vue-jsx-merge-props-1.2.1.tgz" + "version" "1.2.1" + +"@vue/babel-helper-vue-transform-on@^1.0.2": + "integrity" "sha1-m5xpHNBvyFUiGiR1w8yDHXdLx9w=" + "resolved" "https://registry.nlark.com/@vue/babel-helper-vue-transform-on/download/@vue/babel-helper-vue-transform-on-1.0.2.tgz" + "version" "1.0.2" + +"@vue/babel-plugin-jsx@^1.0.3": + "integrity" "sha1-GEvzVBq279vlB5q4sgwZ4q8QC/s=" + "resolved" "https://registry.nlark.com/@vue/babel-plugin-jsx/download/@vue/babel-plugin-jsx-1.0.6.tgz" + "version" "1.0.6" + 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/babel-plugin-transform-vue-jsx@^1.2.1": + "integrity" "sha1-ZGBGxlLC8CQnJ/NFGdkXsGQEHtc=" + "resolved" "https://registry.npm.taobao.org/@vue/babel-plugin-transform-vue-jsx/download/@vue/babel-plugin-transform-vue-jsx-1.2.1.tgz" + "version" "1.2.1" + dependencies: + "@babel/helper-module-imports" "^7.0.0" + "@babel/plugin-syntax-jsx" "^7.2.0" + "@vue/babel-helper-vue-jsx-merge-props" "^1.2.1" + "html-tags" "^2.0.0" + "lodash.kebabcase" "^4.1.1" + "svg-tags" "^1.0.0" + +"@vue/babel-preset-app@^4.5.13": + "integrity" "sha1-y0dTIeTHP38RDawppIwqnLgK/rY=" + "resolved" "https://registry.nlark.com/@vue/babel-preset-app/download/@vue/babel-preset-app-4.5.13.tgz?cache=0&sync_timestamp=1623215857834&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40vue%2Fbabel-preset-app%2Fdownload%2F%40vue%2Fbabel-preset-app-4.5.13.tgz" + "version" "4.5.13" + dependencies: + "@babel/core" "^7.11.0" + "@babel/helper-compilation-targets" "^7.9.6" + "@babel/helper-module-imports" "^7.8.3" + "@babel/plugin-proposal-class-properties" "^7.8.3" + "@babel/plugin-proposal-decorators" "^7.8.3" + "@babel/plugin-syntax-dynamic-import" "^7.8.3" + "@babel/plugin-syntax-jsx" "^7.8.3" + "@babel/plugin-transform-runtime" "^7.11.0" + "@babel/preset-env" "^7.11.0" + "@babel/runtime" "^7.11.0" + "@vue/babel-plugin-jsx" "^1.0.3" + "@vue/babel-preset-jsx" "^1.2.4" + "babel-plugin-dynamic-import-node" "^2.3.3" + "core-js" "^3.6.5" + "core-js-compat" "^3.6.5" + "semver" "^6.1.0" + +"@vue/babel-preset-jsx@^1.2.4": + "integrity" "sha1-kv6nnbbxOwHoDToAmeKSS9y+Toc=" + "resolved" "https://registry.npm.taobao.org/@vue/babel-preset-jsx/download/@vue/babel-preset-jsx-1.2.4.tgz" + "version" "1.2.4" + dependencies: + "@vue/babel-helper-vue-jsx-merge-props" "^1.2.1" + "@vue/babel-plugin-transform-vue-jsx" "^1.2.1" + "@vue/babel-sugar-composition-api-inject-h" "^1.2.1" + "@vue/babel-sugar-composition-api-render-instance" "^1.2.4" + "@vue/babel-sugar-functional-vue" "^1.2.2" + "@vue/babel-sugar-inject-h" "^1.2.2" + "@vue/babel-sugar-v-model" "^1.2.3" + "@vue/babel-sugar-v-on" "^1.2.3" + +"@vue/babel-sugar-composition-api-inject-h@^1.2.1": + "integrity" "sha1-BdbgxDJxDjdYKyvppgSbaJtvA+s=" + "resolved" "https://registry.npm.taobao.org/@vue/babel-sugar-composition-api-inject-h/download/@vue/babel-sugar-composition-api-inject-h-1.2.1.tgz" + "version" "1.2.1" + dependencies: + "@babel/plugin-syntax-jsx" "^7.2.0" + +"@vue/babel-sugar-composition-api-render-instance@^1.2.4": + "integrity" "sha1-5MvGmXw0T6wnF4WteikyXFHWjRk=" + "resolved" "https://registry.nlark.com/@vue/babel-sugar-composition-api-render-instance/download/@vue/babel-sugar-composition-api-render-instance-1.2.4.tgz" + "version" "1.2.4" + dependencies: + "@babel/plugin-syntax-jsx" "^7.2.0" + +"@vue/babel-sugar-functional-vue@^1.2.2": + "integrity" "sha1-JnqayNeHyW7b8Dzj85LEnam9Jlg=" + "resolved" "https://registry.npm.taobao.org/@vue/babel-sugar-functional-vue/download/@vue/babel-sugar-functional-vue-1.2.2.tgz?cache=0&sync_timestamp=1602929625505&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40vue%2Fbabel-sugar-functional-vue%2Fdownload%2F%40vue%2Fbabel-sugar-functional-vue-1.2.2.tgz" + "version" "1.2.2" + dependencies: + "@babel/plugin-syntax-jsx" "^7.2.0" + +"@vue/babel-sugar-inject-h@^1.2.2": + "integrity" "sha1-1zjTyJM2fshJHcu2abAAkZKT46o=" + "resolved" "https://registry.npm.taobao.org/@vue/babel-sugar-inject-h/download/@vue/babel-sugar-inject-h-1.2.2.tgz?cache=0&sync_timestamp=1602929625678&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40vue%2Fbabel-sugar-inject-h%2Fdownload%2F%40vue%2Fbabel-sugar-inject-h-1.2.2.tgz" + "version" "1.2.2" + dependencies: + "@babel/plugin-syntax-jsx" "^7.2.0" + +"@vue/babel-sugar-v-model@^1.2.3": + "integrity" "sha1-+h8pulHr8KoabDX6ZtU5vEWaGPI=" + "resolved" "https://registry.npm.taobao.org/@vue/babel-sugar-v-model/download/@vue/babel-sugar-v-model-1.2.3.tgz" + "version" "1.2.3" + dependencies: + "@babel/plugin-syntax-jsx" "^7.2.0" + "@vue/babel-helper-vue-jsx-merge-props" "^1.2.1" + "@vue/babel-plugin-transform-vue-jsx" "^1.2.1" + "camelcase" "^5.0.0" + "html-tags" "^2.0.0" + "svg-tags" "^1.0.0" + +"@vue/babel-sugar-v-on@^1.2.3": + "integrity" "sha1-NCNnF4WGpp85LwS/ujICHQKROto=" + "resolved" "https://registry.npm.taobao.org/@vue/babel-sugar-v-on/download/@vue/babel-sugar-v-on-1.2.3.tgz?cache=0&sync_timestamp=1603181880042&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40vue%2Fbabel-sugar-v-on%2Fdownload%2F%40vue%2Fbabel-sugar-v-on-1.2.3.tgz" + "version" "1.2.3" + dependencies: + "@babel/plugin-syntax-jsx" "^7.2.0" + "@vue/babel-plugin-transform-vue-jsx" "^1.2.1" + "camelcase" "^5.0.0" + +"@vue/cli-overlay@^4.5.13": + "integrity" "sha1-Tx/SFhvo9p1suoB58/DX3E3uR6c=" + "resolved" "https://registry.nlark.com/@vue/cli-overlay/download/@vue/cli-overlay-4.5.13.tgz" + "version" "4.5.13" + +"@vue/cli-plugin-babel@~4.5.0": + "integrity" "sha1-qJxILtzE6h0TVkXOxQKn9f1MMOc=" + "resolved" "https://registry.nlark.com/@vue/cli-plugin-babel/download/@vue/cli-plugin-babel-4.5.13.tgz" + "version" "4.5.13" + dependencies: + "@babel/core" "^7.11.0" + "@vue/babel-preset-app" "^4.5.13" + "@vue/cli-shared-utils" "^4.5.13" + "babel-loader" "^8.1.0" + "cache-loader" "^4.1.0" + "thread-loader" "^2.1.3" + "webpack" "^4.0.0" + +"@vue/cli-plugin-eslint@~4.5.0": + "integrity" "sha1-i68i0NltdnIMdQZka5b09iwFvfo=" + "resolved" "https://registry.nlark.com/@vue/cli-plugin-eslint/download/@vue/cli-plugin-eslint-4.5.13.tgz" + "version" "4.5.13" + dependencies: + "@vue/cli-shared-utils" "^4.5.13" + "eslint-loader" "^2.2.1" + "globby" "^9.2.0" + "inquirer" "^7.1.0" + "webpack" "^4.0.0" + "yorkie" "^2.0.0" + +"@vue/cli-plugin-router@^4.5.13", "@vue/cli-plugin-router@~4.5.0": + "integrity" "sha512-3icGzH1IbVYmMMsOwYa0lal/gtvZLebFXdE5hcQJo2mnTwngXGMTyYAzL56EgHBPjbMmRpyj6Iw9k4aVInVX6A==" + "resolved" "https://registry.npmmirror.com/@vue/cli-plugin-router/-/cli-plugin-router-4.5.19.tgz" + "version" "4.5.19" + dependencies: + "@vue/cli-shared-utils" "^4.5.19" + +"@vue/cli-plugin-unit-mocha@~4.5.0": + "integrity" "sha1-GBCMawtx7psyvs+/dk9cvk112tY=" + "resolved" "https://registry.nlark.com/@vue/cli-plugin-unit-mocha/download/@vue/cli-plugin-unit-mocha-4.5.13.tgz?cache=0&sync_timestamp=1623216922909&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40vue%2Fcli-plugin-unit-mocha%2Fdownload%2F%40vue%2Fcli-plugin-unit-mocha-4.5.13.tgz" + "version" "4.5.13" + dependencies: + "@vue/cli-shared-utils" "^4.5.13" + "jsdom" "^15.2.1" + "jsdom-global" "^3.0.2" + "mocha" "^6.2.2" + "mochapack" "^1.1.15" + +"@vue/cli-plugin-vuex@^4.5.13", "@vue/cli-plugin-vuex@~4.5.0": + "integrity" "sha512-DUmfdkG3pCdkP7Iznd87RfE9Qm42mgp2hcrNcYQYSru1W1gX2dG/JcW8bxmeGSa06lsxi9LEIc/QD1yPajSCZw==" + "resolved" "https://registry.npmmirror.com/@vue/cli-plugin-vuex/-/cli-plugin-vuex-4.5.19.tgz" + "version" "4.5.19" + +"@vue/cli-service@^3.0.0 || ^4.0.0-0", "@vue/cli-service@~4.5.0": + "integrity" "sha1-oJ5oSoAWhLbiTlQUrTBlCXDuye0=" + "resolved" "https://registry.nlark.com/@vue/cli-service/download/@vue/cli-service-4.5.13.tgz" + "version" "4.5.13" + dependencies: + "@intervolga/optimize-cssnano-plugin" "^1.0.5" + "@soda/friendly-errors-webpack-plugin" "^1.7.1" + "@soda/get-current-script" "^1.0.0" + "@types/minimist" "^1.2.0" + "@types/webpack" "^4.0.0" + "@types/webpack-dev-server" "^3.11.0" + "@vue/cli-overlay" "^4.5.13" + "@vue/cli-plugin-router" "^4.5.13" + "@vue/cli-plugin-vuex" "^4.5.13" + "@vue/cli-shared-utils" "^4.5.13" + "@vue/component-compiler-utils" "^3.1.2" + "@vue/preload-webpack-plugin" "^1.1.0" + "@vue/web-component-wrapper" "^1.2.0" + "acorn" "^7.4.0" + "acorn-walk" "^7.1.1" + "address" "^1.1.2" + "autoprefixer" "^9.8.6" + "browserslist" "^4.12.0" + "cache-loader" "^4.1.0" + "case-sensitive-paths-webpack-plugin" "^2.3.0" + "cli-highlight" "^2.1.4" + "clipboardy" "^2.3.0" + "cliui" "^6.0.0" + "copy-webpack-plugin" "^5.1.1" + "css-loader" "^3.5.3" + "cssnano" "^4.1.10" + "debug" "^4.1.1" + "default-gateway" "^5.0.5" + "dotenv" "^8.2.0" + "dotenv-expand" "^5.1.0" + "file-loader" "^4.2.0" + "fs-extra" "^7.0.1" + "globby" "^9.2.0" + "hash-sum" "^2.0.0" + "html-webpack-plugin" "^3.2.0" + "launch-editor-middleware" "^2.2.1" + "lodash.defaultsdeep" "^4.6.1" + "lodash.mapvalues" "^4.6.0" + "lodash.transform" "^4.6.0" + "mini-css-extract-plugin" "^0.9.0" + "minimist" "^1.2.5" + "pnp-webpack-plugin" "^1.6.4" + "portfinder" "^1.0.26" + "postcss-loader" "^3.0.0" + "ssri" "^8.0.1" + "terser-webpack-plugin" "^1.4.4" + "thread-loader" "^2.1.3" + "url-loader" "^2.2.0" + "vue-loader" "^15.9.2" + "vue-style-loader" "^4.1.2" + "webpack" "^4.0.0" + "webpack-bundle-analyzer" "^3.8.0" + "webpack-chain" "^6.4.0" + "webpack-dev-server" "^3.11.0" + "webpack-merge" "^4.2.2" + optionalDependencies: + "vue-loader-v16" "npm:vue-loader@^16.1.0" + +"@vue/cli-shared-utils@^4.5.13", "@vue/cli-shared-utils@^4.5.19": + "integrity" "sha512-JYpdsrC/d9elerKxbEUtmSSU6QRM60rirVubOewECHkBHj+tLNznWq/EhCjswywtePyLaMUK25eTqnTSZlEE+g==" + "resolved" "https://registry.npmmirror.com/@vue/cli-shared-utils/-/cli-shared-utils-4.5.19.tgz" + "version" "4.5.19" + dependencies: + "@achrinza/node-ipc" "9.2.2" + "@hapi/joi" "^15.0.1" + "chalk" "^2.4.2" + "execa" "^1.0.0" + "launch-editor" "^2.2.1" + "lru-cache" "^5.1.1" + "open" "^6.3.0" + "ora" "^3.4.0" + "read-pkg" "^5.1.1" + "request" "^2.88.2" + "semver" "^6.1.0" + "strip-ansi" "^6.0.0" + +"@vue/compiler-core@3.2.37": + "integrity" "sha512-81KhEjo7YAOh0vQJoSmAD68wLfYqJvoiD4ulyedzF+OEk/bk6/hx3fTNVfuzugIIaTrOx4PGx6pAiBRe5e9Zmg==" + "resolved" "https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@babel/parser" "^7.16.4" + "@vue/shared" "3.2.37" + "estree-walker" "^2.0.2" + "source-map" "^0.6.1" + +"@vue/compiler-dom@3.2.37": + "integrity" "sha512-yxJLH167fucHKxaqXpYk7x8z7mMEnXOw3G2q62FTkmsvNxu4FQSu5+3UMb+L7fjKa26DEzhrmCxAgFLLIzVfqQ==" + "resolved" "https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@vue/compiler-core" "3.2.37" + "@vue/shared" "3.2.37" + +"@vue/compiler-sfc@^3.0.0", "@vue/compiler-sfc@^3.0.0-beta.14", "@vue/compiler-sfc@3.2.37": + "integrity" "sha512-+7i/2+9LYlpqDv+KTtWhOZH+pa8/HnX/905MdVmAcI/mPQOBwkHHIzrsEsucyOIZQYMkXUiTkmZq5am/NyXKkg==" + "resolved" "https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@babel/parser" "^7.16.4" + "@vue/compiler-core" "3.2.37" + "@vue/compiler-dom" "3.2.37" + "@vue/compiler-ssr" "3.2.37" + "@vue/reactivity-transform" "3.2.37" + "@vue/shared" "3.2.37" + "estree-walker" "^2.0.2" + "magic-string" "^0.25.7" + "postcss" "^8.1.10" + "source-map" "^0.6.1" + +"@vue/compiler-ssr@3.2.37": + "integrity" "sha512-7mQJD7HdXxQjktmsWp/J67lThEIcxLemz1Vb5I6rYJHR5vI+lON3nPGOH3ubmbvYGt8xEUaAr1j7/tIFWiEOqw==" + "resolved" "https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@vue/compiler-dom" "3.2.37" + "@vue/shared" "3.2.37" + +"@vue/component-compiler-utils@^3.1.0", "@vue/component-compiler-utils@^3.1.2": + "integrity" "sha1-L37V/u2C/38ChKzBHVJe5+/yJGA=" + "resolved" "https://registry.nlark.com/@vue/component-compiler-utils/download/@vue/component-compiler-utils-3.2.2.tgz" + "version" "3.2.2" + dependencies: + "consolidate" "^0.15.1" + "hash-sum" "^1.0.2" + "lru-cache" "^4.1.2" + "merge-source-map" "^1.1.0" + "postcss" "^7.0.36" + "postcss-selector-parser" "^6.0.2" + "source-map" "~0.6.1" + "vue-template-es2015-compiler" "^1.9.0" + optionalDependencies: + "prettier" "^1.18.2" + +"@vue/devtools-api@^6.0.0-beta.11", "@vue/devtools-api@^6.0.0-beta.14": + "integrity" "sha1-rXyzhOBi8WW8+cg3MhJb/7wq2D0=" + "resolved" "https://registry.nlark.com/@vue/devtools-api/download/@vue/devtools-api-6.0.0-beta.15.tgz?cache=0&sync_timestamp=1624900514906&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40vue%2Fdevtools-api%2Fdownload%2F%40vue%2Fdevtools-api-6.0.0-beta.15.tgz" + "version" "6.0.0-beta.15" + +"@vue/preload-webpack-plugin@^1.1.0": + "integrity" "sha1-zrkktOyzucQ4ccekKaAvhCPmIas=" + "resolved" "https://registry.nlark.com/@vue/preload-webpack-plugin/download/@vue/preload-webpack-plugin-1.1.2.tgz" + "version" "1.1.2" + +"@vue/reactivity-transform@3.2.37": + "integrity" "sha512-IWopkKEb+8qpu/1eMKVeXrK0NLw9HicGviJzhJDEyfxTR9e1WtpnnbYkJWurX6WwoFP0sz10xQg8yL8lgskAZg==" + "resolved" "https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@babel/parser" "^7.16.4" + "@vue/compiler-core" "3.2.37" + "@vue/shared" "3.2.37" + "estree-walker" "^2.0.2" + "magic-string" "^0.25.7" + +"@vue/reactivity@3.2.37": + "integrity" "sha512-/7WRafBOshOc6m3F7plwzPeCu/RCVv9uMpOwa/5PiY1Zz+WLVRWiy0MYKwmg19KBdGtFWsmZ4cD+LOdVPcs52A==" + "resolved" "https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@vue/shared" "3.2.37" + +"@vue/runtime-core@3.2.37": + "integrity" "sha512-JPcd9kFyEdXLl/i0ClS7lwgcs0QpUAWj+SKX2ZC3ANKi1U4DOtiEr6cRqFXsPwY5u1L9fAjkinIdB8Rz3FoYNQ==" + "resolved" "https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@vue/reactivity" "3.2.37" + "@vue/shared" "3.2.37" + +"@vue/runtime-dom@3.2.37": + "integrity" "sha512-HimKdh9BepShW6YozwRKAYjYQWg9mQn63RGEiSswMbW+ssIht1MILYlVGkAGGQbkhSh31PCdoUcfiu4apXJoPw==" + "resolved" "https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@vue/runtime-core" "3.2.37" + "@vue/shared" "3.2.37" + "csstype" "^2.6.8" + +"@vue/server-renderer@3.2.37": + "integrity" "sha512-kLITEJvaYgZQ2h47hIzPh2K3jG8c1zCVbp/o/bzQOyvzaKiCquKS7AaioPI28GNxIsE/zSx+EwWYsNxDCX95MA==" + "resolved" "https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@vue/compiler-ssr" "3.2.37" + "@vue/shared" "3.2.37" + +"@vue/shared@3.2.37": + "integrity" "sha512-4rSJemR2NQIo9Klm1vabqWjD8rs/ZaJSzMxkMNeJS6lHiUjjUeYFbooN19NgFjztubEKh3WlZUeOLVdbbUWHsw==" + "resolved" "https://registry.npmmirror.com/@vue/shared/-/shared-3.2.37.tgz" + "version" "3.2.37" + +"@vue/test-utils@^2.0.0-0": + "integrity" "sha1-ntaJzX1aHJ72aTgGAQ5GTS7ME7I=" + "resolved" "https://registry.nlark.com/@vue/test-utils/download/@vue/test-utils-2.0.0-rc.10.tgz" + "version" "2.0.0-rc.10" + +"@vue/web-component-wrapper@^1.2.0": + "integrity" "sha1-trQKdiVCnSvXwigd26YB7QXcfxo=" + "resolved" "https://registry.npm.taobao.org/@vue/web-component-wrapper/download/@vue/web-component-wrapper-1.3.0.tgz?cache=0&sync_timestamp=1613216912643&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40vue%2Fweb-component-wrapper%2Fdownload%2F%40vue%2Fweb-component-wrapper-1.3.0.tgz" + "version" "1.3.0" + +"@vueuse/core@^9.1.0": + "integrity" "sha512-BIroqvXEqt826aE9r3K5cox1zobuPuAzdYJ36kouC2TVhlXvFKIILgFVWrpp9HZPwB3aLzasmG3K87q7TSyXZg==" + "resolved" "https://registry.npmmirror.com/@vueuse/core/-/core-9.1.0.tgz" + "version" "9.1.0" + dependencies: + "@types/web-bluetooth" "^0.0.15" + "@vueuse/metadata" "9.1.0" + "@vueuse/shared" "9.1.0" + "vue-demi" "*" + +"@vueuse/metadata@9.1.0": + "integrity" "sha512-8OEhlog1iaAGTD3LICZ8oBGQdYeMwByvXetOtAOZCJOzyCRSwqwdggTsmVZZ1rkgYIEqgUBk942AsAPwM21s6A==" + "resolved" "https://registry.npmmirror.com/@vueuse/metadata/-/metadata-9.1.0.tgz" + "version" "9.1.0" + +"@vueuse/shared@9.1.0": + "integrity" "sha512-pB/3njQu4tfJJ78ajELNda0yMG6lKfpToQW7Soe09CprF1k3QuyoNi1tBNvo75wBDJWD+LOnr+c4B5HZ39jY/Q==" + "resolved" "https://registry.npmmirror.com/@vueuse/shared/-/shared-9.1.0.tgz" + "version" "9.1.0" + dependencies: + "vue-demi" "*" + +"@webassemblyjs/ast@1.9.0": + "integrity" "sha1-vYUGBLQEJFmlpBzX0zjL7Wle2WQ=" + "resolved" "https://registry.nlark.com/@webassemblyjs/ast/download/@webassemblyjs/ast-1.9.0.tgz?cache=0&sync_timestamp=1625473466238&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fast%2Fdownload%2F%40webassemblyjs%2Fast-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/helper-module-context" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/wast-parser" "1.9.0" + +"@webassemblyjs/floating-point-hex-parser@1.9.0": + "integrity" "sha1-PD07Jxvd/ITesA9xNEQ4MR1S/7Q=" + "resolved" "https://registry.nlark.com/@webassemblyjs/floating-point-hex-parser/download/@webassemblyjs/floating-point-hex-parser-1.9.0.tgz?cache=0&sync_timestamp=1625473463638&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Ffloating-point-hex-parser%2Fdownload%2F%40webassemblyjs%2Ffloating-point-hex-parser-1.9.0.tgz" + "version" "1.9.0" + +"@webassemblyjs/helper-api-error@1.9.0": + "integrity" "sha1-ID9nbjM7lsnaLuqzzO8zxFkotqI=" + "resolved" "https://registry.nlark.com/@webassemblyjs/helper-api-error/download/@webassemblyjs/helper-api-error-1.9.0.tgz?cache=0&sync_timestamp=1625473346773&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fhelper-api-error%2Fdownload%2F%40webassemblyjs%2Fhelper-api-error-1.9.0.tgz" + "version" "1.9.0" + +"@webassemblyjs/helper-buffer@1.9.0": + "integrity" "sha1-oUQtJpxf6yP8vJ73WdrDVH8p3gA=" + "resolved" "https://registry.nlark.com/@webassemblyjs/helper-buffer/download/@webassemblyjs/helper-buffer-1.9.0.tgz?cache=0&sync_timestamp=1625473462686&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fhelper-buffer%2Fdownload%2F%40webassemblyjs%2Fhelper-buffer-1.9.0.tgz" + "version" "1.9.0" + +"@webassemblyjs/helper-code-frame@1.9.0": + "integrity" "sha1-ZH+Iks0gQ6gqwMjF51w28dkVnyc=" + "resolved" "https://registry.nlark.com/@webassemblyjs/helper-code-frame/download/@webassemblyjs/helper-code-frame-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/wast-printer" "1.9.0" + +"@webassemblyjs/helper-fsm@1.9.0": + "integrity" "sha1-wFJWtxJEIUZx9LCOwQitY7cO3bg=" + "resolved" "https://registry.nlark.com/@webassemblyjs/helper-fsm/download/@webassemblyjs/helper-fsm-1.9.0.tgz" + "version" "1.9.0" + +"@webassemblyjs/helper-module-context@1.9.0": + "integrity" "sha1-JdiIS3aDmHGgimxvgGw5ee9xLwc=" + "resolved" "https://registry.npm.taobao.org/@webassemblyjs/helper-module-context/download/@webassemblyjs/helper-module-context-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + +"@webassemblyjs/helper-wasm-bytecode@1.9.0": + "integrity" "sha1-T+2L6sm4wU+MWLcNEk1UndH+V5A=" + "resolved" "https://registry.nlark.com/@webassemblyjs/helper-wasm-bytecode/download/@webassemblyjs/helper-wasm-bytecode-1.9.0.tgz" + "version" "1.9.0" + +"@webassemblyjs/helper-wasm-section@1.9.0": + "integrity" "sha1-WkE41aYpK6GLBMWuSXF+QWeWU0Y=" + "resolved" "https://registry.nlark.com/@webassemblyjs/helper-wasm-section/download/@webassemblyjs/helper-wasm-section-1.9.0.tgz?cache=0&sync_timestamp=1625473466570&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fhelper-wasm-section%2Fdownload%2F%40webassemblyjs%2Fhelper-wasm-section-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-buffer" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/wasm-gen" "1.9.0" + +"@webassemblyjs/ieee754@1.9.0": + "integrity" "sha1-Fceg+6roP7JhQ7us9tbfFwKtOeQ=" + "resolved" "https://registry.nlark.com/@webassemblyjs/ieee754/download/@webassemblyjs/ieee754-1.9.0.tgz?cache=0&sync_timestamp=1625473461909&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fieee754%2Fdownload%2F%40webassemblyjs%2Fieee754-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@xtuc/ieee754" "^1.2.0" + +"@webassemblyjs/leb128@1.9.0": + "integrity" "sha1-8Zygt2ptxVYjoJz/p2noOPoeHJU=" + "resolved" "https://registry.nlark.com/@webassemblyjs/leb128/download/@webassemblyjs/leb128-1.9.0.tgz?cache=0&sync_timestamp=1625473463971&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fleb128%2Fdownload%2F%40webassemblyjs%2Fleb128-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@xtuc/long" "4.2.2" + +"@webassemblyjs/utf8@1.9.0": + "integrity" "sha1-BNM7Y2945qaBMifoJAL3Y3tiKas=" + "resolved" "https://registry.nlark.com/@webassemblyjs/utf8/download/@webassemblyjs/utf8-1.9.0.tgz?cache=0&sync_timestamp=1625473462317&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Futf8%2Fdownload%2F%40webassemblyjs%2Futf8-1.9.0.tgz" + "version" "1.9.0" + +"@webassemblyjs/wasm-edit@1.9.0": + "integrity" "sha1-P+bXnT8PkiGDqoYALELdJWz+6c8=" + "resolved" "https://registry.nlark.com/@webassemblyjs/wasm-edit/download/@webassemblyjs/wasm-edit-1.9.0.tgz?cache=0&sync_timestamp=1625473468202&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwasm-edit%2Fdownload%2F%40webassemblyjs%2Fwasm-edit-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-buffer" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/helper-wasm-section" "1.9.0" + "@webassemblyjs/wasm-gen" "1.9.0" + "@webassemblyjs/wasm-opt" "1.9.0" + "@webassemblyjs/wasm-parser" "1.9.0" + "@webassemblyjs/wast-printer" "1.9.0" + +"@webassemblyjs/wasm-gen@1.9.0": + "integrity" "sha1-ULxw7Gje2OJ2OwGhQYv0NJGnpJw=" + "resolved" "https://registry.nlark.com/@webassemblyjs/wasm-gen/download/@webassemblyjs/wasm-gen-1.9.0.tgz?cache=0&sync_timestamp=1625473464969&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwasm-gen%2Fdownload%2F%40webassemblyjs%2Fwasm-gen-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/ieee754" "1.9.0" + "@webassemblyjs/leb128" "1.9.0" + "@webassemblyjs/utf8" "1.9.0" + +"@webassemblyjs/wasm-opt@1.9.0": + "integrity" "sha1-IhEYHlsxMmRDzIES658LkChyGmE=" + "resolved" "https://registry.nlark.com/@webassemblyjs/wasm-opt/download/@webassemblyjs/wasm-opt-1.9.0.tgz?cache=0&sync_timestamp=1625473467198&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwasm-opt%2Fdownload%2F%40webassemblyjs%2Fwasm-opt-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-buffer" "1.9.0" + "@webassemblyjs/wasm-gen" "1.9.0" + "@webassemblyjs/wasm-parser" "1.9.0" + +"@webassemblyjs/wasm-parser@1.9.0": + "integrity" "sha1-nUjkSCbfSmWYKUqmyHRp1kL/9l4=" + "resolved" "https://registry.nlark.com/@webassemblyjs/wasm-parser/download/@webassemblyjs/wasm-parser-1.9.0.tgz?cache=0&sync_timestamp=1625473464593&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwasm-parser%2Fdownload%2F%40webassemblyjs%2Fwasm-parser-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-api-error" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/ieee754" "1.9.0" + "@webassemblyjs/leb128" "1.9.0" + "@webassemblyjs/utf8" "1.9.0" + +"@webassemblyjs/wast-parser@1.9.0": + "integrity" "sha1-MDERXXmsW9JhVWzsw/qQo+9FGRQ=" + "resolved" "https://registry.nlark.com/@webassemblyjs/wast-parser/download/@webassemblyjs/wast-parser-1.9.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwast-parser%2Fdownload%2F%40webassemblyjs%2Fwast-parser-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/floating-point-hex-parser" "1.9.0" + "@webassemblyjs/helper-api-error" "1.9.0" + "@webassemblyjs/helper-code-frame" "1.9.0" + "@webassemblyjs/helper-fsm" "1.9.0" + "@xtuc/long" "4.2.2" + +"@webassemblyjs/wast-printer@1.9.0": + "integrity" "sha1-STXVTIX+9jewDOn1I3dFHQDUeJk=" + "resolved" "https://registry.nlark.com/@webassemblyjs/wast-printer/download/@webassemblyjs/wast-printer-1.9.0.tgz?cache=0&sync_timestamp=1625473465901&other_urls=https%3A%2F%2Fregistry.nlark.com%2F%40webassemblyjs%2Fwast-printer%2Fdownload%2F%40webassemblyjs%2Fwast-printer-1.9.0.tgz" + "version" "1.9.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/wast-parser" "1.9.0" + "@xtuc/long" "4.2.2" + +"@xtuc/ieee754@^1.2.0": + "integrity" "sha1-7vAUoxRa5Hehy8AM0eVSM23Ot5A=" + "resolved" "https://registry.npm.taobao.org/@xtuc/ieee754/download/@xtuc/ieee754-1.2.0.tgz" + "version" "1.2.0" + +"@xtuc/long@4.2.2": + "integrity" "sha1-0pHGpOl5ibXGHZrPOWrk/hM6cY0=" + "resolved" "https://registry.npm.taobao.org/@xtuc/long/download/@xtuc/long-4.2.2.tgz" + "version" "4.2.2" + +"abab@^2.0.0": + "integrity" "sha1-wLZ4+zLWD8EhnHhNaoJv44Wut5o=" + "resolved" "https://registry.npm.taobao.org/abab/download/abab-2.0.5.tgz" + "version" "2.0.5" + +"abort-controller@^3.0.0": + "integrity" "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==" + "resolved" "https://registry.npmmirror.com/abort-controller/-/abort-controller-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "event-target-shim" "^5.0.0" + +"accepts@~1.3.4", "accepts@~1.3.5", "accepts@~1.3.7": + "integrity" "sha1-UxvHJlF6OytB+FACHGzBXqq1B80=" + "resolved" "https://registry.npm.taobao.org/accepts/download/accepts-1.3.7.tgz" + "version" "1.3.7" + dependencies: + "mime-types" "~2.1.24" + "negotiator" "0.6.2" + +"acorn-globals@^4.3.2": + "integrity" "sha1-n6GSat3BHJcwjE5m163Q1Awycuc=" + "resolved" "https://registry.npm.taobao.org/acorn-globals/download/acorn-globals-4.3.4.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Facorn-globals%2Fdownload%2Facorn-globals-4.3.4.tgz" + "version" "4.3.4" + dependencies: + "acorn" "^6.0.1" + "acorn-walk" "^6.0.1" + +"acorn-jsx@^5.2.0": + "integrity" "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==" + "resolved" "https://registry.npmmirror.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz" + "version" "5.3.2" + +"acorn-walk@^6.0.1": + "integrity" "sha1-Ejy487hMIXHx9/slJhWxx4prGow=" + "resolved" "https://registry.nlark.com/acorn-walk/download/acorn-walk-6.2.0.tgz" + "version" "6.2.0" + +"acorn-walk@^7.1.1": + "integrity" "sha1-DeiJpgEgOQmw++B7iTjcIdLpZ7w=" + "resolved" "https://registry.nlark.com/acorn-walk/download/acorn-walk-7.2.0.tgz" + "version" "7.2.0" + +"acorn-walk@^8.2.0": + "integrity" "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==" + "resolved" "https://registry.npmmirror.com/acorn-walk/-/acorn-walk-8.2.0.tgz" + "version" "8.2.0" + +"acorn@^6.0.0 || ^7.0.0 || ^8.0.0", "acorn@^7.1.0", "acorn@^7.1.1", "acorn@^7.4.0": + "integrity" "sha1-/q7SVZc9LndVW4PbwIhRpsY1IPo=" + "resolved" "https://registry.nlark.com/acorn/download/acorn-7.4.1.tgz?cache=0&sync_timestamp=1624526907659&other_urls=https%3A%2F%2Fregistry.nlark.com%2Facorn%2Fdownload%2Facorn-7.4.1.tgz" + "version" "7.4.1" + +"acorn@^6.0.1": + "integrity" "sha1-NYZv1xBSjpLeEM8GAWSY5H454eY=" + "resolved" "https://registry.nlark.com/acorn/download/acorn-6.4.2.tgz?cache=0&sync_timestamp=1624526907659&other_urls=https%3A%2F%2Fregistry.nlark.com%2Facorn%2Fdownload%2Facorn-6.4.2.tgz" + "version" "6.4.2" + +"acorn@^6.4.1": + "integrity" "sha1-NYZv1xBSjpLeEM8GAWSY5H454eY=" + "resolved" "https://registry.nlark.com/acorn/download/acorn-6.4.2.tgz?cache=0&sync_timestamp=1624526907659&other_urls=https%3A%2F%2Fregistry.nlark.com%2Facorn%2Fdownload%2Facorn-6.4.2.tgz" + "version" "6.4.2" + +"acorn@^8.7.0": + "integrity" "sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==" + "resolved" "https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz" + "version" "8.8.2" + +"address@^1.0.0", "address@^1.1.2": + "integrity" "sha1-vxEWycdYxRt6kz0pa3LCIe2UKLY=" + "resolved" "https://registry.npm.taobao.org/address/download/address-1.1.2.tgz" + "version" "1.1.2" + +"agent-base@^6.0.0", "agent-base@^6.0.2", "agent-base@6": + "integrity" "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==" + "resolved" "https://registry.npmmirror.com/agent-base/-/agent-base-6.0.2.tgz" + "version" "6.0.2" + dependencies: + "debug" "4" + +"agentkeepalive@^3.4.1": + "integrity" "sha512-e0L/HNe6qkQ7H19kTlRRqUibEAwDK5AFk6y3PtMsuut2VAH6+Q4xZml1tNDJD7kSAyqmbG/K08K5WEJYtUrSlQ==" + "resolved" "https://registry.npmmirror.com/agentkeepalive/-/agentkeepalive-3.5.2.tgz" + "version" "3.5.2" + dependencies: + "humanize-ms" "^1.2.1" + +"ajv-errors@^1.0.0": + "integrity" "sha1-81mGrOuRr63sQQL72FAUlQzvpk0=" + "resolved" "https://registry.npm.taobao.org/ajv-errors/download/ajv-errors-1.0.1.tgz" + "version" "1.0.1" + +"ajv-keywords@^3.1.0", "ajv-keywords@^3.4.1", "ajv-keywords@^3.5.2": + "integrity" "sha1-MfKdpatuANHC0yms97WSlhTVAU0=" + "resolved" "https://registry.npm.taobao.org/ajv-keywords/download/ajv-keywords-3.5.2.tgz?cache=0&sync_timestamp=1616882441894&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fajv-keywords%2Fdownload%2Fajv-keywords-3.5.2.tgz" + "version" "3.5.2" + +"ajv@^6.1.0", "ajv@^6.10.0", "ajv@^6.10.2", "ajv@^6.12.3", "ajv@^6.12.4", "ajv@^6.12.5", "ajv@^6.9.1", "ajv@>=5.0.0": + "integrity" "sha1-uvWmLoArB9l3A0WG+MO69a3ybfQ=" + "resolved" "https://registry.nlark.com/ajv/download/ajv-6.12.6.tgz" + "version" "6.12.6" + 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" + +"ali-oss@^6.17.1": + "integrity" "sha512-v2oT3UhSJTH/LrsscVvi7iEGrnundydNaFzpYAKatqOl4JNcBV4UiwtlJU+ZHLys040JH2k+CutznA0GoE+P2w==" + "resolved" "https://registry.npmmirror.com/ali-oss/-/ali-oss-6.17.1.tgz" + "version" "6.17.1" + dependencies: + "address" "^1.0.0" + "agentkeepalive" "^3.4.1" + "bowser" "^1.6.0" + "copy-to" "^2.0.1" + "dateformat" "^2.0.0" + "debug" "^2.2.0" + "destroy" "^1.0.4" + "end-or-error" "^1.0.1" + "get-ready" "^1.0.0" + "humanize-ms" "^1.2.0" + "is-type-of" "^1.0.0" + "js-base64" "^2.5.2" + "jstoxml" "^2.0.0" + "merge-descriptors" "^1.0.1" + "mime" "^2.4.5" + "mz-modules" "^2.1.0" + "platform" "^1.3.1" + "pump" "^3.0.0" + "sdk-base" "^2.0.1" + "stream-http" "2.8.2" + "stream-wormhole" "^1.0.4" + "urllib" "^2.33.1" + "utility" "^1.8.0" + "xml2js" "^0.4.16" + +"alphanum-sort@^1.0.0": + "integrity" "sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM=" + "resolved" "https://registry.npm.taobao.org/alphanum-sort/download/alphanum-sort-1.0.2.tgz" + "version" "1.0.2" + +"ansi-colors@^3.0.0", "ansi-colors@3.2.3": + "integrity" "sha1-V9NbhoboUeLMBMQD8cACA5dqGBM=" + "resolved" "https://registry.npm.taobao.org/ansi-colors/download/ansi-colors-3.2.3.tgz" + "version" "3.2.3" + +"ansi-escapes@^4.2.1": + "integrity" "sha1-ayKR0dt9mLZSHV8e+kLQ86n+tl4=" + "resolved" "https://registry.nlark.com/ansi-escapes/download/ansi-escapes-4.3.2.tgz?cache=0&sync_timestamp=1618847144938&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-escapes%2Fdownload%2Fansi-escapes-4.3.2.tgz" + "version" "4.3.2" + dependencies: + "type-fest" "^0.21.3" + +"ansi-html@0.0.7": + "integrity" "sha1-gTWEAhliqenm/QOflA0S9WynhZ4=" + "resolved" "https://registry.nlark.com/ansi-html/download/ansi-html-0.0.7.tgz?cache=0&sync_timestamp=1618846919541&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-html%2Fdownload%2Fansi-html-0.0.7.tgz" + "version" "0.0.7" + +"ansi-regex@^2.0.0": + "integrity" "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + "resolved" "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-2.1.1.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-2.1.1.tgz" + "version" "2.1.1" + +"ansi-regex@^3.0.0": + "integrity" "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" + "resolved" "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-3.0.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-3.0.0.tgz" + "version" "3.0.0" + +"ansi-regex@^4.1.0": + "integrity" "sha1-i5+PCM8ay4Q3Vqg5yox+MWjFGZc=" + "resolved" "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-4.1.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-4.1.0.tgz" + "version" "4.1.0" + +"ansi-regex@^5.0.0": + "integrity" "sha1-OIU59VF5vzkznIGvMKZU1p+Hy3U=" + "resolved" "https://registry.npm.taobao.org/ansi-regex/download/ansi-regex-5.0.0.tgz?cache=0&sync_timestamp=1618552978881&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fansi-regex%2Fdownload%2Fansi-regex-5.0.0.tgz" + "version" "5.0.0" + +"ansi-styles@^3.2.0", "ansi-styles@^3.2.1": + "integrity" "sha1-QfuyAkPlCxK+DwS43tvwdSDOhB0=" + "resolved" "https://registry.nlark.com/ansi-styles/download/ansi-styles-3.2.1.tgz?cache=0&sync_timestamp=1618995547052&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-styles%2Fdownload%2Fansi-styles-3.2.1.tgz" + "version" "3.2.1" + dependencies: + "color-convert" "^1.9.0" + +"ansi-styles@^4.0.0": + "integrity" "sha1-7dgDYornHATIWuegkG7a00tkiTc=" + "resolved" "https://registry.nlark.com/ansi-styles/download/ansi-styles-4.3.0.tgz?cache=0&sync_timestamp=1618995547052&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-styles%2Fdownload%2Fansi-styles-4.3.0.tgz" + "version" "4.3.0" + dependencies: + "color-convert" "^2.0.1" + +"ansi-styles@^4.1.0": + "integrity" "sha1-7dgDYornHATIWuegkG7a00tkiTc=" + "resolved" "https://registry.nlark.com/ansi-styles/download/ansi-styles-4.3.0.tgz?cache=0&sync_timestamp=1618995547052&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-styles%2Fdownload%2Fansi-styles-4.3.0.tgz" + "version" "4.3.0" + dependencies: + "color-convert" "^2.0.1" + +"any-promise@^1.0.0", "any-promise@^1.3.0": + "integrity" "sha1-q8av7tzqUugJzcA3au0845Y10X8=" + "resolved" "https://registry.npm.taobao.org/any-promise/download/any-promise-1.3.0.tgz" + "version" "1.3.0" + +"anymatch@^2.0.0": + "integrity" "sha1-vLJLTzeTTZqnrBe0ra+J58du8us=" + "resolved" "https://registry.npm.taobao.org/anymatch/download/anymatch-2.0.0.tgz?cache=0&sync_timestamp=1617747806715&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fanymatch%2Fdownload%2Fanymatch-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "micromatch" "^3.1.4" + "normalize-path" "^2.1.1" + +"anymatch@^3.0.0", "anymatch@~3.1.2": + "integrity" "sha1-wFV8CWrzLxBhmPT04qODU343hxY=" + "resolved" "https://registry.npm.taobao.org/anymatch/download/anymatch-3.1.2.tgz?cache=0&sync_timestamp=1617747806715&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fanymatch%2Fdownload%2Fanymatch-3.1.2.tgz" + "version" "3.1.2" + dependencies: + "normalize-path" "^3.0.0" + "picomatch" "^2.0.4" + +"aproba@^1.1.1": + "integrity" "sha1-aALmJk79GMeQobDVF/DyYnvyyUo=" + "resolved" "https://registry.nlark.com/aproba/download/aproba-1.2.0.tgz" + "version" "1.2.0" + +"arch@^2.1.1": + "integrity" "sha1-G8R4GPMFdk8jqzMGsL/AhsWinRE=" + "resolved" "https://registry.npm.taobao.org/arch/download/arch-2.2.0.tgz" + "version" "2.2.0" + +"argparse@^1.0.7": + "integrity" "sha1-vNZ5HqWuCXJeF+WtmIE0zUCz2RE=" + "resolved" "https://registry.npm.taobao.org/argparse/download/argparse-1.0.10.tgz" + "version" "1.0.10" + dependencies: + "sprintf-js" "~1.0.2" + +"arr-diff@^4.0.0": + "integrity" "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=" + "resolved" "https://registry.nlark.com/arr-diff/download/arr-diff-4.0.0.tgz?cache=0&sync_timestamp=1618847029174&other_urls=https%3A%2F%2Fregistry.nlark.com%2Farr-diff%2Fdownload%2Farr-diff-4.0.0.tgz" + "version" "4.0.0" + +"arr-flatten@^1.1.0": + "integrity" "sha1-NgSLv/TntH4TZkQxbJlmnqWukfE=" + "resolved" "https://registry.npm.taobao.org/arr-flatten/download/arr-flatten-1.1.0.tgz" + "version" "1.1.0" + +"arr-union@^3.1.0": + "integrity" "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=" + "resolved" "https://registry.npm.taobao.org/arr-union/download/arr-union-3.1.0.tgz" + "version" "3.1.0" + +"array-equal@^1.0.0": + "integrity" "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=" + "resolved" "https://registry.npm.taobao.org/array-equal/download/array-equal-1.0.0.tgz" + "version" "1.0.0" + +"array-flatten@^2.1.0": + "integrity" "sha1-JO+AoowaiTYX4hSbDG0NeIKTsJk=" + "resolved" "https://registry.npm.taobao.org/array-flatten/download/array-flatten-2.1.2.tgz" + "version" "2.1.2" + +"array-flatten@1.1.1": + "integrity" "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" + "resolved" "https://registry.npm.taobao.org/array-flatten/download/array-flatten-1.1.1.tgz" + "version" "1.1.1" + +"array-union@^1.0.1", "array-union@^1.0.2": + "integrity" "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=" + "resolved" "https://registry.npm.taobao.org/array-union/download/array-union-1.0.2.tgz?cache=0&sync_timestamp=1614624861176&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Farray-union%2Fdownload%2Farray-union-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "array-uniq" "^1.0.1" + +"array-union@^2.1.0": + "integrity" "sha1-t5hCCtvrHego2ErNii4j0+/oXo0=" + "resolved" "https://registry.npm.taobao.org/array-union/download/array-union-2.1.0.tgz?cache=0&sync_timestamp=1614624861176&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Farray-union%2Fdownload%2Farray-union-2.1.0.tgz" + "version" "2.1.0" + +"array-uniq@^1.0.1": + "integrity" "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=" + "resolved" "https://registry.nlark.com/array-uniq/download/array-uniq-1.0.3.tgz" + "version" "1.0.3" + +"array-unique@^0.3.2": + "integrity" "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=" + "resolved" "https://registry.npm.taobao.org/array-unique/download/array-unique-0.3.2.tgz" + "version" "0.3.2" + +"asn1.js@^5.2.0": + "integrity" "sha1-EamAuE67kXgc41sP3C7ilON4Pwc=" + "resolved" "https://registry.npm.taobao.org/asn1.js/download/asn1.js-5.4.1.tgz" + "version" "5.4.1" + dependencies: + "bn.js" "^4.0.0" + "inherits" "^2.0.1" + "minimalistic-assert" "^1.0.0" + "safer-buffer" "^2.1.0" + +"asn1@~0.2.3": + "integrity" "sha1-jSR136tVO7M+d7VOWeiAu4ziMTY=" + "resolved" "https://registry.npm.taobao.org/asn1/download/asn1-0.2.4.tgz" + "version" "0.2.4" + dependencies: + "safer-buffer" "~2.1.0" + +"assert-plus@^1.0.0", "assert-plus@1.0.0": + "integrity" "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" + "resolved" "https://registry.nlark.com/assert-plus/download/assert-plus-1.0.0.tgz" + "version" "1.0.0" + +"assert@^1.1.1": + "integrity" "sha1-VcEJqvbgrv2z3EtxJAxwv1dLGOs=" + "resolved" "https://registry.npm.taobao.org/assert/download/assert-1.5.0.tgz" + "version" "1.5.0" + dependencies: + "object-assign" "^4.1.1" + "util" "0.10.3" + +"assertion-error@^1.1.0": + "integrity" "sha1-5gtrDo8wG9l+U3UhW9pAbIURjAs=" + "resolved" "https://registry.nlark.com/assertion-error/download/assertion-error-1.1.0.tgz" + "version" "1.1.0" + +"assign-symbols@^1.0.0": + "integrity" "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=" + "resolved" "https://registry.nlark.com/assign-symbols/download/assign-symbols-1.0.0.tgz" + "version" "1.0.0" + +"ast-types@^0.13.2": + "integrity" "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==" + "resolved" "https://registry.npmmirror.com/ast-types/-/ast-types-0.13.4.tgz" + "version" "0.13.4" + dependencies: + "tslib" "^2.0.1" + +"astral-regex@^1.0.0": + "integrity" "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==" + "resolved" "https://registry.npmmirror.com/astral-regex/-/astral-regex-1.0.0.tgz" + "version" "1.0.0" + +"async-each@^1.0.1": + "integrity" "sha1-tyfb+H12UWAvBvTUrDh/R9kbDL8=" + "resolved" "https://registry.npm.taobao.org/async-each/download/async-each-1.0.3.tgz" + "version" "1.0.3" + +"async-limiter@~1.0.0": + "integrity" "sha1-3TeelPDbgxCwgpH51kwyCXZmF/0=" + "resolved" "https://registry.npm.taobao.org/async-limiter/download/async-limiter-1.0.1.tgz" + "version" "1.0.1" + +"async-validator@^4.2.5": + "integrity" "sha512-7HhHjtERjqlNbZtqNqy2rckN/SpOOlmDliet+lP7k+eKZEjPk3DgyeU9lIXLdeLz0uBbbVp+9Qdow9wJWgwwfg==" + "resolved" "https://registry.npmmirror.com/async-validator/-/async-validator-4.2.5.tgz" + "version" "4.2.5" + +"async@^2.6.2": + "integrity" "sha1-1yYl4jRKNlbjo61Pp0n6gymdgv8=" + "resolved" "https://registry.nlark.com/async/download/async-2.6.3.tgz" + "version" "2.6.3" + dependencies: + "lodash" "^4.17.14" + +"asynckit@^0.4.0": + "integrity" "sha1-x57Zf380y48robyXkLzDZkdLS3k=" + "resolved" "https://registry.nlark.com/asynckit/download/asynckit-0.4.0.tgz" + "version" "0.4.0" + +"atob@^2.1.2": + "integrity" "sha1-bZUX654DDSQ2ZmZR6GvZ9vE1M8k=" + "resolved" "https://registry.npm.taobao.org/atob/download/atob-2.1.2.tgz" + "version" "2.1.2" + +"autoprefixer@^9.8.6": + "integrity" "sha1-O3NZTKG/kmYyDFrPFYjXTep0IQ8=" + "resolved" "https://registry.nlark.com/autoprefixer/download/autoprefixer-9.8.6.tgz?cache=0&sync_timestamp=1626111053301&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fautoprefixer%2Fdownload%2Fautoprefixer-9.8.6.tgz" + "version" "9.8.6" + dependencies: + "browserslist" "^4.12.0" + "caniuse-lite" "^1.0.30001109" + "colorette" "^1.2.1" + "normalize-range" "^0.1.2" + "num2fraction" "^1.2.2" + "postcss" "^7.0.32" + "postcss-value-parser" "^4.1.0" + +"aws-sign2@~0.7.0": + "integrity" "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" + "resolved" "https://registry.nlark.com/aws-sign2/download/aws-sign2-0.7.0.tgz" + "version" "0.7.0" + +"aws4@^1.8.0": + "integrity" "sha1-1h9G2DslGSUOJ4Ta9bCUeai0HFk=" + "resolved" "https://registry.npm.taobao.org/aws4/download/aws4-1.11.0.tgz?cache=0&sync_timestamp=1604101244098&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Faws4%2Fdownload%2Faws4-1.11.0.tgz" + "version" "1.11.0" + +"axios@^0.21.1": + "integrity" "sha1-IlY0gZYvTWvemnbVFu8OXTwJsrg=" + "resolved" "https://registry.nlark.com/axios/download/axios-0.21.1.tgz" + "version" "0.21.1" + dependencies: + "follow-redirects" "^1.10.0" + +"babel-eslint@^10.1.0": + "integrity" "sha1-aWjlaKkQt4+zd5zdi2rC9HmUMjI=" + "resolved" "https://registry.nlark.com/babel-eslint/download/babel-eslint-10.1.0.tgz" + "version" "10.1.0" + dependencies: + "@babel/code-frame" "^7.0.0" + "@babel/parser" "^7.7.0" + "@babel/traverse" "^7.7.0" + "@babel/types" "^7.7.0" + "eslint-visitor-keys" "^1.0.0" + "resolve" "^1.12.0" + +"babel-loader@^8.1.0": + "integrity" "sha1-k2POhMEMmkDmx1N0jhRBtgyKC4E=" + "resolved" "https://registry.nlark.com/babel-loader/download/babel-loader-8.2.2.tgz" + "version" "8.2.2" + dependencies: + "find-cache-dir" "^3.3.1" + "loader-utils" "^1.4.0" + "make-dir" "^3.1.0" + "schema-utils" "^2.6.5" + +"babel-plugin-dynamic-import-node@^2.3.3": + "integrity" "sha1-hP2hnJduxcbe/vV/lCez3vZuF6M=" + "resolved" "https://registry.npm.taobao.org/babel-plugin-dynamic-import-node/download/babel-plugin-dynamic-import-node-2.3.3.tgz" + "version" "2.3.3" + dependencies: + "object.assign" "^4.1.0" + +"babel-plugin-polyfill-corejs2@^0.2.2": + "integrity" "sha1-6RJHheb9lPlLYYp5VOVpMFO/Uyc=" + "resolved" "https://registry.nlark.com/babel-plugin-polyfill-corejs2/download/babel-plugin-polyfill-corejs2-0.2.2.tgz" + "version" "0.2.2" + dependencies: + "@babel/compat-data" "^7.13.11" + "@babel/helper-define-polyfill-provider" "^0.2.2" + "semver" "^6.1.1" + +"babel-plugin-polyfill-corejs3@^0.2.2": + "integrity" "sha1-cq3WjPCKi/E5um5t/AsdUECY5Xs=" + "resolved" "https://registry.nlark.com/babel-plugin-polyfill-corejs3/download/babel-plugin-polyfill-corejs3-0.2.3.tgz?cache=0&sync_timestamp=1623878015630&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fbabel-plugin-polyfill-corejs3%2Fdownload%2Fbabel-plugin-polyfill-corejs3-0.2.3.tgz" + "version" "0.2.3" + dependencies: + "@babel/helper-define-polyfill-provider" "^0.2.2" + "core-js-compat" "^3.14.0" + +"babel-plugin-polyfill-regenerator@^0.2.2": + "integrity" "sha1-sxDI1kKsraNIwfo7Pmzg6FG+4Hc=" + "resolved" "https://registry.nlark.com/babel-plugin-polyfill-regenerator/download/babel-plugin-polyfill-regenerator-0.2.2.tgz" + "version" "0.2.2" + dependencies: + "@babel/helper-define-polyfill-provider" "^0.2.2" + +"balanced-match@^1.0.0": + "integrity" "sha1-6D46fj8wCzTLnYf2FfoMvzV2kO4=" + "resolved" "https://registry.npm.taobao.org/balanced-match/download/balanced-match-1.0.2.tgz?cache=0&sync_timestamp=1617714298273&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbalanced-match%2Fdownload%2Fbalanced-match-1.0.2.tgz" + "version" "1.0.2" + +"base@^0.11.1": + "integrity" "sha1-e95c7RRbbVUakNuH+DxVi060io8=" + "resolved" "https://registry.npm.taobao.org/base/download/base-0.11.2.tgz" + "version" "0.11.2" + dependencies: + "cache-base" "^1.0.1" + "class-utils" "^0.3.5" + "component-emitter" "^1.2.1" + "define-property" "^1.0.0" + "isobject" "^3.0.1" + "mixin-deep" "^1.2.0" + "pascalcase" "^0.1.1" + +"base64-js@^1.0.2": + "integrity" "sha1-GxtEAWClv3rUC2UPCVljSBkDkwo=" + "resolved" "https://registry.npm.taobao.org/base64-js/download/base64-js-1.5.1.tgz" + "version" "1.5.1" + +"batch@0.6.1": + "integrity" "sha1-3DQxT05nkxgJP8dgJyUl+UvyXBY=" + "resolved" "https://registry.npm.taobao.org/batch/download/batch-0.6.1.tgz" + "version" "0.6.1" + +"bcrypt-pbkdf@^1.0.0": + "integrity" "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=" + "resolved" "https://registry.npm.taobao.org/bcrypt-pbkdf/download/bcrypt-pbkdf-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "tweetnacl" "^0.14.3" + +"bfj@^6.1.1": + "integrity" "sha1-MlyGGoIryzWKQceKM7jm4ght3n8=" + "resolved" "https://registry.npm.taobao.org/bfj/download/bfj-6.1.2.tgz" + "version" "6.1.2" + dependencies: + "bluebird" "^3.5.5" + "check-types" "^8.0.3" + "hoopy" "^0.1.4" + "tryer" "^1.0.1" + +"big.js@^3.1.3": + "integrity" "sha1-pfwpi4G54Nyi5FiCR4S2XFK6WI4=" + "resolved" "https://registry.nlark.com/big.js/download/big.js-3.2.0.tgz" + "version" "3.2.0" + +"big.js@^5.2.2": + "integrity" "sha1-ZfCvOC9Xi83HQr2cKB6cstd2gyg=" + "resolved" "https://registry.nlark.com/big.js/download/big.js-5.2.2.tgz" + "version" "5.2.2" + +"binary-extensions@^1.0.0": + "integrity" "sha1-WYr+VHVbKGilMw0q/51Ou1Mgm2U=" + "resolved" "https://registry.npm.taobao.org/binary-extensions/download/binary-extensions-1.13.1.tgz?cache=0&sync_timestamp=1610299322955&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbinary-extensions%2Fdownload%2Fbinary-extensions-1.13.1.tgz" + "version" "1.13.1" + +"binary-extensions@^2.0.0": + "integrity" "sha1-dfUC7q+f/eQvyYgpZFvk6na9ni0=" + "resolved" "https://registry.npm.taobao.org/binary-extensions/download/binary-extensions-2.2.0.tgz?cache=0&sync_timestamp=1610299322955&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbinary-extensions%2Fdownload%2Fbinary-extensions-2.2.0.tgz" + "version" "2.2.0" + +"bluebird@^3.1.1", "bluebird@^3.5.5": + "integrity" "sha1-nyKcFb4nJFT/qXOs4NvueaGww28=" + "resolved" "https://registry.nlark.com/bluebird/download/bluebird-3.7.2.tgz" + "version" "3.7.2" + +"bn.js@^4.0.0": + "integrity" "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=" + "resolved" "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz" + "version" "4.12.0" + +"bn.js@^4.1.0": + "integrity" "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=" + "resolved" "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz" + "version" "4.12.0" + +"bn.js@^4.11.9": + "integrity" "sha1-d1s/J477uXGO7HNh9IP7Nvu/6og=" + "resolved" "https://registry.npm.taobao.org/bn.js/download/bn.js-4.12.0.tgz" + "version" "4.12.0" + +"bn.js@^5.0.0", "bn.js@^5.1.1": + "integrity" "sha1-NYhgZ0OWxpl3canQUfzBtX1K4AI=" + "resolved" "https://registry.npm.taobao.org/bn.js/download/bn.js-5.2.0.tgz" + "version" "5.2.0" + +"body-parser@1.19.0": + "integrity" "sha1-lrJwnlfJxOCab9Zqj9l5hE9p8Io=" + "resolved" "https://registry.npm.taobao.org/body-parser/download/body-parser-1.19.0.tgz" + "version" "1.19.0" + dependencies: + "bytes" "3.1.0" + "content-type" "~1.0.4" + "debug" "2.6.9" + "depd" "~1.1.2" + "http-errors" "1.7.2" + "iconv-lite" "0.4.24" + "on-finished" "~2.3.0" + "qs" "6.7.0" + "raw-body" "2.4.0" + "type-is" "~1.6.17" + +"bonjour@^3.5.0": + "integrity" "sha1-jokKGD2O6aI5OzhExpGkK897yfU=" + "resolved" "https://registry.npm.taobao.org/bonjour/download/bonjour-3.5.0.tgz" + "version" "3.5.0" + dependencies: + "array-flatten" "^2.1.0" + "deep-equal" "^1.0.1" + "dns-equal" "^1.0.0" + "dns-txt" "^2.0.2" + "multicast-dns" "^6.0.1" + "multicast-dns-service-types" "^1.1.0" + +"boolbase@^1.0.0", "boolbase@~1.0.0": + "integrity" "sha1-aN/1++YMUes3cl6p4+0xDcwed24=" + "resolved" "https://registry.nlark.com/boolbase/download/boolbase-1.0.0.tgz" + "version" "1.0.0" + +"bowser@^1.6.0": + "integrity" "sha512-9IdMmj2KjigRq6oWhmwv1W36pDuA4STQZ8q6YO9um+x07xgYNCD3Oou+WP/3L1HNz7iqythGet3/p4wvc8AAwQ==" + "resolved" "https://registry.npmmirror.com/bowser/-/bowser-1.9.4.tgz" + "version" "1.9.4" + +"brace-expansion@^1.1.7": + "integrity" "sha1-PH/L9SnYcibz0vUrlm/1Jx60Qd0=" + "resolved" "https://registry.npm.taobao.org/brace-expansion/download/brace-expansion-1.1.11.tgz" + "version" "1.1.11" + dependencies: + "balanced-match" "^1.0.0" + "concat-map" "0.0.1" + +"braces@^2.3.1", "braces@^2.3.2": + "integrity" "sha1-WXn9PxTNUxVl5fot8av/8d+u5yk=" + "resolved" "https://registry.nlark.com/braces/download/braces-2.3.2.tgz" + "version" "2.3.2" + dependencies: + "arr-flatten" "^1.1.0" + "array-unique" "^0.3.2" + "extend-shallow" "^2.0.1" + "fill-range" "^4.0.0" + "isobject" "^3.0.1" + "repeat-element" "^1.1.2" + "snapdragon" "^0.8.1" + "snapdragon-node" "^2.0.1" + "split-string" "^3.0.2" + "to-regex" "^3.0.1" + +"braces@^3.0.1": + "integrity" "sha1-NFThpGLujVmeI23zNs2epPiv4Qc=" + "resolved" "https://registry.nlark.com/braces/download/braces-3.0.2.tgz" + "version" "3.0.2" + dependencies: + "fill-range" "^7.0.1" + +"braces@~3.0.2": + "integrity" "sha1-NFThpGLujVmeI23zNs2epPiv4Qc=" + "resolved" "https://registry.nlark.com/braces/download/braces-3.0.2.tgz" + "version" "3.0.2" + dependencies: + "fill-range" "^7.0.1" + +"brorand@^1.0.1", "brorand@^1.1.0": + "integrity" "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=" + "resolved" "https://registry.npm.taobao.org/brorand/download/brorand-1.1.0.tgz" + "version" "1.1.0" + +"browser-process-hrtime@^1.0.0": + "integrity" "sha1-PJtLfXgsgSHlbxAQbYTA0P/JRiY=" + "resolved" "https://registry.npm.taobao.org/browser-process-hrtime/download/browser-process-hrtime-1.0.0.tgz" + "version" "1.0.0" + +"browser-stdout@1.3.1": + "integrity" "sha1-uqVZ7hTO1zRSIputcyZGfGH6vWA=" + "resolved" "https://registry.npm.taobao.org/browser-stdout/download/browser-stdout-1.3.1.tgz" + "version" "1.3.1" + +"browserify-aes@^1.0.0", "browserify-aes@^1.0.4": + "integrity" "sha1-Mmc0ZC9APavDADIJhTu3CtQo70g=" + "resolved" "https://registry.npm.taobao.org/browserify-aes/download/browserify-aes-1.2.0.tgz" + "version" "1.2.0" + dependencies: + "buffer-xor" "^1.0.3" + "cipher-base" "^1.0.0" + "create-hash" "^1.1.0" + "evp_bytestokey" "^1.0.3" + "inherits" "^2.0.1" + "safe-buffer" "^5.0.1" + +"browserify-cipher@^1.0.0": + "integrity" "sha1-jWR0wbhwv9q807z8wZNKEOlPFfA=" + "resolved" "https://registry.npm.taobao.org/browserify-cipher/download/browserify-cipher-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "browserify-aes" "^1.0.4" + "browserify-des" "^1.0.0" + "evp_bytestokey" "^1.0.0" + +"browserify-des@^1.0.0": + "integrity" "sha1-OvTx9Zg5QDVy8cZiBDdfen9wPpw=" + "resolved" "https://registry.nlark.com/browserify-des/download/browserify-des-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "cipher-base" "^1.0.1" + "des.js" "^1.0.0" + "inherits" "^2.0.1" + "safe-buffer" "^5.1.2" + +"browserify-rsa@^4.0.0", "browserify-rsa@^4.0.1": + "integrity" "sha1-sv0Gtbda4pf3zi3GUfkY9b4VjI0=" + "resolved" "https://registry.npm.taobao.org/browserify-rsa/download/browserify-rsa-4.1.0.tgz?cache=0&sync_timestamp=1605194257215&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbrowserify-rsa%2Fdownload%2Fbrowserify-rsa-4.1.0.tgz" + "version" "4.1.0" + dependencies: + "bn.js" "^5.0.0" + "randombytes" "^2.0.1" + +"browserify-sign@^4.0.0": + "integrity" "sha1-6vSt1G3VS+O7OzbAzxWrvrp5VsM=" + "resolved" "https://registry.nlark.com/browserify-sign/download/browserify-sign-4.2.1.tgz" + "version" "4.2.1" + dependencies: + "bn.js" "^5.1.1" + "browserify-rsa" "^4.0.1" + "create-hash" "^1.2.0" + "create-hmac" "^1.1.7" + "elliptic" "^6.5.3" + "inherits" "^2.0.4" + "parse-asn1" "^5.1.5" + "readable-stream" "^3.6.0" + "safe-buffer" "^5.2.0" + +"browserify-zlib@^0.2.0": + "integrity" "sha1-KGlFnZqjviRf6P4sofRuLn9U1z8=" + "resolved" "https://registry.nlark.com/browserify-zlib/download/browserify-zlib-0.2.0.tgz" + "version" "0.2.0" + dependencies: + "pako" "~1.0.5" + +"browserslist@^4.0.0", "browserslist@^4.12.0", "browserslist@^4.16.6": + "integrity" "sha1-15ASd6WojlVO0wWxg+ybDAj2b6I=" + "resolved" "https://registry.nlark.com/browserslist/download/browserslist-4.16.6.tgz?cache=0&sync_timestamp=1619789072079&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fbrowserslist%2Fdownload%2Fbrowserslist-4.16.6.tgz" + "version" "4.16.6" + dependencies: + "caniuse-lite" "^1.0.30001219" + "colorette" "^1.2.2" + "electron-to-chromium" "^1.3.723" + "escalade" "^3.1.1" + "node-releases" "^1.1.71" + +"buffer-from@^1.0.0": + "integrity" "sha1-MnE7wCj3XAL9txDXx7zsHyxgcO8=" + "resolved" "https://registry.nlark.com/buffer-from/download/buffer-from-1.1.1.tgz" + "version" "1.1.1" + +"buffer-indexof@^1.0.0": + "integrity" "sha1-Uvq8xqYG0aADAoAmSO9o9jnaJow=" + "resolved" "https://registry.npm.taobao.org/buffer-indexof/download/buffer-indexof-1.1.1.tgz" + "version" "1.1.1" + +"buffer-json@^2.0.0": + "integrity" "sha1-9z4TseQvGW/i/WfQAcfXEH7dfCM=" + "resolved" "https://registry.nlark.com/buffer-json/download/buffer-json-2.0.0.tgz" + "version" "2.0.0" + +"buffer-xor@^1.0.3": + "integrity" "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=" + "resolved" "https://registry.nlark.com/buffer-xor/download/buffer-xor-1.0.3.tgz" + "version" "1.0.3" + +"buffer@^4.3.0": + "integrity" "sha1-Iw6tNEACmIZEhBqwJEr4xEu+Pvg=" + "resolved" "https://registry.nlark.com/buffer/download/buffer-4.9.2.tgz" + "version" "4.9.2" + dependencies: + "base64-js" "^1.0.2" + "ieee754" "^1.1.4" + "isarray" "^1.0.0" + +"builtin-status-codes@^3.0.0": + "integrity" "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=" + "resolved" "https://registry.nlark.com/builtin-status-codes/download/builtin-status-codes-3.0.0.tgz" + "version" "3.0.0" + +"bytes@3.0.0": + "integrity" "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" + "resolved" "https://registry.nlark.com/bytes/download/bytes-3.0.0.tgz" + "version" "3.0.0" + +"bytes@3.1.0": + "integrity" "sha1-9s95M6Ng4FiPqf3oVlHNx/gF0fY=" + "resolved" "https://registry.nlark.com/bytes/download/bytes-3.1.0.tgz" + "version" "3.1.0" + +"cacache@^12.0.2", "cacache@^12.0.3": + "integrity" "sha1-ZovL0QWutfHZL+JVcOyVJcj6pAw=" + "resolved" "https://registry.nlark.com/cacache/download/cacache-12.0.4.tgz?cache=0&sync_timestamp=1621949700715&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcacache%2Fdownload%2Fcacache-12.0.4.tgz" + "version" "12.0.4" + dependencies: + "bluebird" "^3.5.5" + "chownr" "^1.1.1" + "figgy-pudding" "^3.5.1" + "glob" "^7.1.4" + "graceful-fs" "^4.1.15" + "infer-owner" "^1.0.3" + "lru-cache" "^5.1.1" + "mississippi" "^3.0.0" + "mkdirp" "^0.5.1" + "move-concurrently" "^1.0.1" + "promise-inflight" "^1.0.1" + "rimraf" "^2.6.3" + "ssri" "^6.0.1" + "unique-filename" "^1.1.1" + "y18n" "^4.0.0" + +"cache-base@^1.0.1": + "integrity" "sha1-Cn9GQWgxyLZi7jb+TnxZ129marI=" + "resolved" "https://registry.npm.taobao.org/cache-base/download/cache-base-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "collection-visit" "^1.0.0" + "component-emitter" "^1.2.1" + "get-value" "^2.0.6" + "has-value" "^1.0.0" + "isobject" "^3.0.1" + "set-value" "^2.0.0" + "to-object-path" "^0.3.0" + "union-value" "^1.0.0" + "unset-value" "^1.0.0" + +"cache-loader@^4.1.0": + "integrity" "sha1-mUjK41OuwKH8ser9ojAIFuyFOH4=" + "resolved" "https://registry.nlark.com/cache-loader/download/cache-loader-4.1.0.tgz" + "version" "4.1.0" + dependencies: + "buffer-json" "^2.0.0" + "find-cache-dir" "^3.0.0" + "loader-utils" "^1.2.3" + "mkdirp" "^0.5.1" + "neo-async" "^2.6.1" + "schema-utils" "^2.0.0" + +"call-bind@^1.0.0", "call-bind@^1.0.2": + "integrity" "sha1-sdTonmiBGcPJqQOtMKuy9qkZvjw=" + "resolved" "https://registry.nlark.com/call-bind/download/call-bind-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "function-bind" "^1.1.1" + "get-intrinsic" "^1.0.2" + +"call-me-maybe@^1.0.1": + "integrity" "sha1-JtII6onje1y95gJQoV8DHBak1ms=" + "resolved" "https://registry.npm.taobao.org/call-me-maybe/download/call-me-maybe-1.0.1.tgz" + "version" "1.0.1" + +"caller-callsite@^2.0.0": + "integrity" "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=" + "resolved" "https://registry.npm.taobao.org/caller-callsite/download/caller-callsite-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "callsites" "^2.0.0" + +"caller-path@^2.0.0": + "integrity" "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=" + "resolved" "https://registry.npm.taobao.org/caller-path/download/caller-path-2.0.0.tgz?cache=0&sync_timestamp=1618738159926&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcaller-path%2Fdownload%2Fcaller-path-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "caller-callsite" "^2.0.0" + +"callsites@^2.0.0": + "integrity" "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=" + "resolved" "https://registry.nlark.com/callsites/download/callsites-2.0.0.tgz" + "version" "2.0.0" + +"callsites@^3.0.0": + "integrity" "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" + "resolved" "https://registry.npmmirror.com/callsites/-/callsites-3.1.0.tgz" + "version" "3.1.0" + +"camel-case@3.0.x": + "integrity" "sha1-yjw2iKTpzzpM2nd9xNy8cTJJz3M=" + "resolved" "https://registry.npm.taobao.org/camel-case/download/camel-case-3.0.0.tgz?cache=0&sync_timestamp=1606867311564&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcamel-case%2Fdownload%2Fcamel-case-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "no-case" "^2.2.0" + "upper-case" "^1.1.1" + +"camelcase@^5.0.0": + "integrity" "sha1-48mzFWnhBoEd8kL3FXJaH0xJQyA=" + "resolved" "https://registry.nlark.com/camelcase/download/camelcase-5.3.1.tgz" + "version" "5.3.1" + +"camelcase@^5.3.1": + "integrity" "sha1-48mzFWnhBoEd8kL3FXJaH0xJQyA=" + "resolved" "https://registry.nlark.com/camelcase/download/camelcase-5.3.1.tgz" + "version" "5.3.1" + +"camelcase@^6.0.0": + "integrity" "sha1-kkr4gcnVJaydh/QNlk5c6pgqGAk=" + "resolved" "https://registry.nlark.com/camelcase/download/camelcase-6.2.0.tgz" + "version" "6.2.0" + +"caniuse-api@^3.0.0": + "integrity" "sha1-Xk2Q4idJYdRikZl99Znj7QCO5MA=" + "resolved" "https://registry.nlark.com/caniuse-api/download/caniuse-api-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "browserslist" "^4.0.0" + "caniuse-lite" "^1.0.0" + "lodash.memoize" "^4.1.2" + "lodash.uniq" "^4.5.0" + +"caniuse-lite@^1.0.0", "caniuse-lite@^1.0.30001109", "caniuse-lite@^1.0.30001219": + "integrity" "sha1-RblBu9gzyw+lOGH/K650azxspdQ=" + "resolved" "https://registry.nlark.com/caniuse-lite/download/caniuse-lite-1.0.30001245.tgz?cache=0&sync_timestamp=1626238653626&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcaniuse-lite%2Fdownload%2Fcaniuse-lite-1.0.30001245.tgz" + "version" "1.0.30001245" + +"case-sensitive-paths-webpack-plugin@^2.3.0": + "integrity" "sha1-22QGbGQi7tLgjMFLmGykN5bbxtQ=" + "resolved" "https://registry.npm.taobao.org/case-sensitive-paths-webpack-plugin/download/case-sensitive-paths-webpack-plugin-2.4.0.tgz" + "version" "2.4.0" + +"caseless@~0.12.0": + "integrity" "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" + "resolved" "https://registry.nlark.com/caseless/download/caseless-0.12.0.tgz" + "version" "0.12.0" + +"chai@^4.1.2": + "integrity" "sha1-tV5lWzHh6scJm+TAjCGWT84ubEk=" + "resolved" "https://registry.npm.taobao.org/chai/download/chai-4.3.4.tgz" + "version" "4.3.4" + dependencies: + "assertion-error" "^1.1.0" + "check-error" "^1.0.2" + "deep-eql" "^3.0.1" + "get-func-name" "^2.0.0" + "pathval" "^1.1.1" + "type-detect" "^4.0.5" + +"chalk@^2.0.0", "chalk@^2.0.1", "chalk@^2.1.0", "chalk@^2.3.0", "chalk@^2.4.1", "chalk@^2.4.2": + "integrity" "sha1-zUJUFnelQzPPVBpJEIwUMrRMlCQ=" + "resolved" "https://registry.nlark.com/chalk/download/chalk-2.4.2.tgz?cache=0&sync_timestamp=1618995354302&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fchalk%2Fdownload%2Fchalk-2.4.2.tgz" + "version" "2.4.2" + dependencies: + "ansi-styles" "^3.2.1" + "escape-string-regexp" "^1.0.5" + "supports-color" "^5.3.0" + +"chalk@^4.0.0": + "integrity" "sha1-yAs/qyi/Y3HmhjMl7uZ+YYt35q0=" + "resolved" "https://registry.nlark.com/chalk/download/chalk-4.1.1.tgz?cache=0&sync_timestamp=1618995354302&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fchalk%2Fdownload%2Fchalk-4.1.1.tgz" + "version" "4.1.1" + dependencies: + "ansi-styles" "^4.1.0" + "supports-color" "^7.1.0" + +"chalk@^4.1.0": + "integrity" "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==" + "resolved" "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz" + "version" "4.1.2" + dependencies: + "ansi-styles" "^4.1.0" + "supports-color" "^7.1.0" + +"chardet@^0.7.0": + "integrity" "sha1-kAlISfCTfy7twkJdDSip5fDLrZ4=" + "resolved" "https://registry.npm.taobao.org/chardet/download/chardet-0.7.0.tgz" + "version" "0.7.0" + +"check-error@^1.0.2": + "integrity" "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=" + "resolved" "https://registry.npm.taobao.org/check-error/download/check-error-1.0.2.tgz" + "version" "1.0.2" + +"check-types@^8.0.3": + "integrity" "sha1-M1bMoZyIlUTy16le1JzlCKDs9VI=" + "resolved" "https://registry.npm.taobao.org/check-types/download/check-types-8.0.3.tgz" + "version" "8.0.3" + +"chokidar@^2.0.0", "chokidar@^2.1.8": + "integrity" "sha1-gEs6e2qZNYw8XGHnHYco8EHP+Rc=" + "resolved" "https://registry.nlark.com/chokidar/download/chokidar-2.1.8.tgz" + "version" "2.1.8" + dependencies: + "anymatch" "^2.0.0" + "async-each" "^1.0.1" + "braces" "^2.3.2" + "glob-parent" "^3.1.0" + "inherits" "^2.0.3" + "is-binary-path" "^1.0.0" + "is-glob" "^4.0.0" + "normalize-path" "^3.0.0" + "path-is-absolute" "^1.0.0" + "readdirp" "^2.2.1" + "upath" "^1.1.1" + optionalDependencies: + "fsevents" "^1.2.7" + +"chokidar@^3.4.1": + "integrity" "sha1-26OXb8rbAW9m/TZQIdkWANAcHnU=" + "resolved" "https://registry.nlark.com/chokidar/download/chokidar-3.5.2.tgz" + "version" "3.5.2" + 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" + +"chownr@^1.1.1": + "integrity" "sha1-b8nXtC0ypYNZYzdmbn0ICE2izGs=" + "resolved" "https://registry.npm.taobao.org/chownr/download/chownr-1.1.4.tgz" + "version" "1.1.4" + +"chrome-trace-event@^1.0.2": + "integrity" "sha1-EBXs7UdB4V0GZkqVfbv1DQQeJqw=" + "resolved" "https://registry.nlark.com/chrome-trace-event/download/chrome-trace-event-1.0.3.tgz" + "version" "1.0.3" + +"ci-info@^1.5.0": + "integrity" "sha1-LKINu5zrMtRSSmgzAzE/AwSx5Jc=" + "resolved" "https://registry.nlark.com/ci-info/download/ci-info-1.6.0.tgz?cache=0&sync_timestamp=1622039942508&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fci-info%2Fdownload%2Fci-info-1.6.0.tgz" + "version" "1.6.0" + +"cipher-base@^1.0.0", "cipher-base@^1.0.1", "cipher-base@^1.0.3": + "integrity" "sha1-h2Dk7MJy9MNjUy+SbYdKriwTl94=" + "resolved" "https://registry.npm.taobao.org/cipher-base/download/cipher-base-1.0.4.tgz" + "version" "1.0.4" + dependencies: + "inherits" "^2.0.1" + "safe-buffer" "^5.0.1" + +"class-utils@^0.3.5": + "integrity" "sha1-+TNprouafOAv1B+q0MqDAzGQxGM=" + "resolved" "https://registry.npm.taobao.org/class-utils/download/class-utils-0.3.6.tgz" + "version" "0.3.6" + dependencies: + "arr-union" "^3.1.0" + "define-property" "^0.2.5" + "isobject" "^3.0.0" + "static-extend" "^0.1.1" + +"clean-css@4.2.x": + "integrity" "sha1-UHtd59l7SO5T2ErbAWD/YhY4D3g=" + "resolved" "https://registry.nlark.com/clean-css/download/clean-css-4.2.3.tgz?cache=0&sync_timestamp=1624616709466&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fclean-css%2Fdownload%2Fclean-css-4.2.3.tgz" + "version" "4.2.3" + dependencies: + "source-map" "~0.6.0" + +"cli-cursor@^2.1.0": + "integrity" "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=" + "resolved" "https://registry.nlark.com/cli-cursor/download/cli-cursor-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "restore-cursor" "^2.0.0" + +"cli-cursor@^3.1.0": + "integrity" "sha1-JkMFp65JDR0Dvwybp8kl0XU68wc=" + "resolved" "https://registry.nlark.com/cli-cursor/download/cli-cursor-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "restore-cursor" "^3.1.0" + +"cli-highlight@^2.1.4": + "integrity" "sha1-SXNvpFLwqvT65YDjCssmgo0twb8=" + "resolved" "https://registry.npm.taobao.org/cli-highlight/download/cli-highlight-2.1.11.tgz?cache=0&sync_timestamp=1616955426054&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcli-highlight%2Fdownload%2Fcli-highlight-2.1.11.tgz" + "version" "2.1.11" + dependencies: + "chalk" "^4.0.0" + "highlight.js" "^10.7.1" + "mz" "^2.4.0" + "parse5" "^5.1.1" + "parse5-htmlparser2-tree-adapter" "^6.0.0" + "yargs" "^16.0.0" + +"cli-spinners@^2.0.0": + "integrity" "sha1-NsfcmPtqmna9YjjsP3fiQlYn6Tk=" + "resolved" "https://registry.nlark.com/cli-spinners/download/cli-spinners-2.6.0.tgz" + "version" "2.6.0" + +"cli-width@^3.0.0": + "integrity" "sha1-ovSEN6LKqaIkNueUvwceyeYc7fY=" + "resolved" "https://registry.nlark.com/cli-width/download/cli-width-3.0.0.tgz" + "version" "3.0.0" + +"clipboardy@^2.3.0": + "integrity" "sha1-PCkDZQxo5GqRs4iYW8J3QofbopA=" + "resolved" "https://registry.npm.taobao.org/clipboardy/download/clipboardy-2.3.0.tgz" + "version" "2.3.0" + dependencies: + "arch" "^2.1.1" + "execa" "^1.0.0" + "is-wsl" "^2.1.1" + +"cliui@^5.0.0": + "integrity" "sha1-3u/P2y6AB4SqNPRvoI4GhRx7u8U=" + "resolved" "https://registry.npm.taobao.org/cliui/download/cliui-5.0.0.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-5.0.0.tgz" + "version" "5.0.0" + dependencies: + "string-width" "^3.1.0" + "strip-ansi" "^5.2.0" + "wrap-ansi" "^5.1.0" + +"cliui@^6.0.0": + "integrity" "sha1-UR1wLAxOQcoVbX0OlgIfI+EyJbE=" + "resolved" "https://registry.npm.taobao.org/cliui/download/cliui-6.0.0.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-6.0.0.tgz" + "version" "6.0.0" + dependencies: + "string-width" "^4.2.0" + "strip-ansi" "^6.0.0" + "wrap-ansi" "^6.2.0" + +"cliui@^7.0.2": + "integrity" "sha1-oCZe5lVHb8gHrqnfPfjfd4OAi08=" + "resolved" "https://registry.npm.taobao.org/cliui/download/cliui-7.0.4.tgz?cache=0&sync_timestamp=1604880017635&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-7.0.4.tgz" + "version" "7.0.4" + dependencies: + "string-width" "^4.2.0" + "strip-ansi" "^6.0.0" + "wrap-ansi" "^7.0.0" + +"clone@^1.0.2": + "integrity" "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=" + "resolved" "https://registry.nlark.com/clone/download/clone-1.0.4.tgz" + "version" "1.0.4" + +"coa@^2.0.2": + "integrity" "sha1-Q/bCEVG07yv1cYfbDXPeIp4+fsM=" + "resolved" "https://registry.nlark.com/coa/download/coa-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "@types/q" "^1.5.1" + "chalk" "^2.4.1" + "q" "^1.1.2" + +"collection-visit@^1.0.0": + "integrity" "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=" + "resolved" "https://registry.nlark.com/collection-visit/download/collection-visit-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "map-visit" "^1.0.0" + "object-visit" "^1.0.0" + +"color-convert@^1.9.0", "color-convert@^1.9.1": + "integrity" "sha1-u3GFBpDh8TZWfeYp0tVHHe2kweg=" + "resolved" "https://registry.npm.taobao.org/color-convert/download/color-convert-1.9.3.tgz" + "version" "1.9.3" + dependencies: + "color-name" "1.1.3" + +"color-convert@^2.0.1": + "integrity" "sha1-ctOmjVmMm9s68q0ehPIdiWq9TeM=" + "resolved" "https://registry.npm.taobao.org/color-convert/download/color-convert-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "color-name" "~1.1.4" + +"color-name@^1.0.0", "color-name@1.1.3": + "integrity" "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" + "resolved" "https://registry.nlark.com/color-name/download/color-name-1.1.3.tgz" + "version" "1.1.3" + +"color-name@~1.1.4": + "integrity" "sha1-wqCah6y95pVD3m9j+jmVyCbFNqI=" + "resolved" "https://registry.nlark.com/color-name/download/color-name-1.1.4.tgz" + "version" "1.1.4" + +"color-string@^1.5.4": + "integrity" "sha1-ZUdKjw50OWJfPSemoZ2J/EUiMBQ=" + "resolved" "https://registry.npm.taobao.org/color-string/download/color-string-1.5.5.tgz" + "version" "1.5.5" + dependencies: + "color-name" "^1.0.0" + "simple-swizzle" "^0.2.2" + +"color@^3.0.0": + "integrity" "sha1-ymf7TnuX1hHc3jns7tQiBn2RWW4=" + "resolved" "https://registry.npm.taobao.org/color/download/color-3.1.3.tgz" + "version" "3.1.3" + dependencies: + "color-convert" "^1.9.1" + "color-string" "^1.5.4" + +"colorette@^1.2.1", "colorette@^1.2.2": + "integrity" "sha1-y8x51emcrqLb8Q6zom/Ys+as+pQ=" + "resolved" "https://registry.nlark.com/colorette/download/colorette-1.2.2.tgz?cache=0&sync_timestamp=1618847174680&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcolorette%2Fdownload%2Fcolorette-1.2.2.tgz" + "version" "1.2.2" + +"combined-stream@^1.0.6", "combined-stream@~1.0.6": + "integrity" "sha1-w9RaizT9cwYxoRCoolIGgrMdWn8=" + "resolved" "https://registry.npm.taobao.org/combined-stream/download/combined-stream-1.0.8.tgz" + "version" "1.0.8" + dependencies: + "delayed-stream" "~1.0.0" + +"commander@^2.18.0": + "integrity" "sha1-/UhehMA+tIgcIHIrpIA16FMa6zM=" + "resolved" "https://registry.nlark.com/commander/download/commander-2.20.3.tgz?cache=0&sync_timestamp=1624609533517&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcommander%2Fdownload%2Fcommander-2.20.3.tgz" + "version" "2.20.3" + +"commander@^2.20.0": + "integrity" "sha1-/UhehMA+tIgcIHIrpIA16FMa6zM=" + "resolved" "https://registry.nlark.com/commander/download/commander-2.20.3.tgz?cache=0&sync_timestamp=1624609533517&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcommander%2Fdownload%2Fcommander-2.20.3.tgz" + "version" "2.20.3" + +"commander@~2.19.0": + "integrity" "sha1-9hmKqE5bg8RgVLlN3tv+1e6f8So=" + "resolved" "https://registry.nlark.com/commander/download/commander-2.19.0.tgz?cache=0&sync_timestamp=1624609533517&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcommander%2Fdownload%2Fcommander-2.19.0.tgz" + "version" "2.19.0" + +"commander@2.17.x": + "integrity" "sha1-vXerfebelCBc6sxy8XFtKfIKd78=" + "resolved" "https://registry.nlark.com/commander/download/commander-2.17.1.tgz?cache=0&sync_timestamp=1624609533517&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcommander%2Fdownload%2Fcommander-2.17.1.tgz" + "version" "2.17.1" + +"commondir@^1.0.1": + "integrity" "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=" + "resolved" "https://registry.npm.taobao.org/commondir/download/commondir-1.0.1.tgz" + "version" "1.0.1" + +"component-emitter@^1.2.1": + "integrity" "sha1-FuQHD7qK4ptnnyIVhT7hgasuq8A=" + "resolved" "https://registry.nlark.com/component-emitter/download/component-emitter-1.3.0.tgz" + "version" "1.3.0" + +"compressible@~2.0.16": + "integrity" "sha1-r1PMprBw1MPAdQ+9dyhqbXzEb7o=" + "resolved" "https://registry.npm.taobao.org/compressible/download/compressible-2.0.18.tgz" + "version" "2.0.18" + dependencies: + "mime-db" ">= 1.43.0 < 2" + +"compression@^1.7.4": + "integrity" "sha1-lVI+/xcMpXwpoMpB5v4TH0Hlu48=" + "resolved" "https://registry.npm.taobao.org/compression/download/compression-1.7.4.tgz" + "version" "1.7.4" + dependencies: + "accepts" "~1.3.5" + "bytes" "3.0.0" + "compressible" "~2.0.16" + "debug" "2.6.9" + "on-headers" "~1.0.2" + "safe-buffer" "5.1.2" + "vary" "~1.1.2" + +"concat-map@0.0.1": + "integrity" "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + "resolved" "https://registry.npm.taobao.org/concat-map/download/concat-map-0.0.1.tgz" + "version" "0.0.1" + +"concat-stream@^1.5.0": + "integrity" "sha1-kEvfGUzTEi/Gdcd/xKw9T/D9GjQ=" + "resolved" "https://registry.nlark.com/concat-stream/download/concat-stream-1.6.2.tgz" + "version" "1.6.2" + dependencies: + "buffer-from" "^1.0.0" + "inherits" "^2.0.3" + "readable-stream" "^2.2.2" + "typedarray" "^0.0.6" + +"connect-history-api-fallback@^1.6.0": + "integrity" "sha1-izIIk1kwjRERFdgcrT/Oq4iPl7w=" + "resolved" "https://registry.npm.taobao.org/connect-history-api-fallback/download/connect-history-api-fallback-1.6.0.tgz" + "version" "1.6.0" + +"console-browserify@^1.1.0": + "integrity" "sha1-ZwY871fOts9Jk6KrOlWECujEkzY=" + "resolved" "https://registry.npm.taobao.org/console-browserify/download/console-browserify-1.2.0.tgz" + "version" "1.2.0" + +"consolidate@^0.15.1": + "integrity" "sha1-IasEMjXHGgfUXZqtmFk7DbpWurc=" + "resolved" "https://registry.npm.taobao.org/consolidate/download/consolidate-0.15.1.tgz" + "version" "0.15.1" + dependencies: + "bluebird" "^3.1.1" + +"constants-browserify@^1.0.0": + "integrity" "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=" + "resolved" "https://registry.npm.taobao.org/constants-browserify/download/constants-browserify-1.0.0.tgz" + "version" "1.0.0" + +"content-disposition@0.5.3": + "integrity" "sha1-4TDK9+cnkIfFYWwgB9BIVpiYT70=" + "resolved" "https://registry.npm.taobao.org/content-disposition/download/content-disposition-0.5.3.tgz" + "version" "0.5.3" + dependencies: + "safe-buffer" "5.1.2" + +"content-type@^1.0.2", "content-type@~1.0.4": + "integrity" "sha1-4TjMdeBAxyexlm/l5fjJruJW/js=" + "resolved" "https://registry.npm.taobao.org/content-type/download/content-type-1.0.4.tgz" + "version" "1.0.4" + +"convert-source-map@^1.7.0": + "integrity" "sha1-8zc8MtIbTXgN2ABFFGhPt5HKQ2k=" + "resolved" "https://registry.nlark.com/convert-source-map/download/convert-source-map-1.8.0.tgz" + "version" "1.8.0" + dependencies: + "safe-buffer" "~5.1.1" + +"cookie-signature@1.0.6": + "integrity" "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" + "resolved" "https://registry.npm.taobao.org/cookie-signature/download/cookie-signature-1.0.6.tgz" + "version" "1.0.6" + +"cookie@0.4.0": + "integrity" "sha1-vrQ35wIrO21JAZ0IhmUwPr6cFLo=" + "resolved" "https://registry.npm.taobao.org/cookie/download/cookie-0.4.0.tgz" + "version" "0.4.0" + +"copy-anything@^2.0.1": + "integrity" "sha1-hCQHugJGaw34RIGbvjuuu+XUXYc=" + "resolved" "https://registry.npm.taobao.org/copy-anything/download/copy-anything-2.0.3.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcopy-anything%2Fdownload%2Fcopy-anything-2.0.3.tgz" + "version" "2.0.3" + dependencies: + "is-what" "^3.12.0" + +"copy-concurrently@^1.0.0": + "integrity" "sha1-kilzmMrjSTf8r9bsgTnBgFHwteA=" + "resolved" "https://registry.npm.taobao.org/copy-concurrently/download/copy-concurrently-1.0.5.tgz" + "version" "1.0.5" + dependencies: + "aproba" "^1.1.1" + "fs-write-stream-atomic" "^1.0.8" + "iferr" "^0.1.5" + "mkdirp" "^0.5.1" + "rimraf" "^2.5.4" + "run-queue" "^1.0.0" + +"copy-descriptor@^0.1.0": + "integrity" "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=" + "resolved" "https://registry.nlark.com/copy-descriptor/download/copy-descriptor-0.1.1.tgz" + "version" "0.1.1" + +"copy-to@^2.0.1": + "integrity" "sha512-3DdaFaU/Zf1AnpLiFDeNCD4TOWe3Zl2RZaTzUvWiIk5ERzcCodOE20Vqq4fzCbNoHURFHT4/us/Lfq+S2zyY4w==" + "resolved" "https://registry.npmmirror.com/copy-to/-/copy-to-2.0.1.tgz" + "version" "2.0.1" + +"copy-webpack-plugin@^5.1.1": + "integrity" "sha1-ioieHcr6bJHGzUvhrRWPHTgjuuI=" + "resolved" "https://registry.nlark.com/copy-webpack-plugin/download/copy-webpack-plugin-5.1.2.tgz?cache=0&sync_timestamp=1624628458516&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcopy-webpack-plugin%2Fdownload%2Fcopy-webpack-plugin-5.1.2.tgz" + "version" "5.1.2" + dependencies: + "cacache" "^12.0.3" + "find-cache-dir" "^2.1.0" + "glob-parent" "^3.1.0" + "globby" "^7.1.1" + "is-glob" "^4.0.1" + "loader-utils" "^1.2.3" + "minimatch" "^3.0.4" + "normalize-path" "^3.0.0" + "p-limit" "^2.2.1" + "schema-utils" "^1.0.0" + "serialize-javascript" "^4.0.0" + "webpack-log" "^2.0.0" + +"core-js-compat@^3.14.0", "core-js-compat@^3.15.0", "core-js-compat@^3.6.5": + "integrity" "sha1-Rycvu0eYgN4UtOYIH3HzSS9b08s=" + "resolved" "https://registry.nlark.com/core-js-compat/download/core-js-compat-3.15.2.tgz?cache=0&sync_timestamp=1624966048946&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcore-js-compat%2Fdownload%2Fcore-js-compat-3.15.2.tgz" + "version" "3.15.2" + dependencies: + "browserslist" "^4.16.6" + "semver" "7.0.0" + +"core-js-pure@^3.16.0": + "integrity" "sha1-IY4HrdPxhE5T+rGVxHhx/Fuhjeg=" + "resolved" "https://registry.nlark.com/core-js-pure/download/core-js-pure-3.16.0.tgz?cache=0&sync_timestamp=1627616508554&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcore-js-pure%2Fdownload%2Fcore-js-pure-3.16.0.tgz" + "version" "3.16.0" + +"core-js@^2.6.5": + "integrity" "sha1-2TM9+nsGXjR8xWgiGdb2kIWcwuw=" + "resolved" "https://registry.nlark.com/core-js/download/core-js-2.6.12.tgz?cache=0&sync_timestamp=1624966012065&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcore-js%2Fdownload%2Fcore-js-2.6.12.tgz" + "version" "2.6.12" + +"core-js@^3.6.5": + "integrity" "sha1-dAZg0v9V7zTOZk1+JFURnFvdPWE=" + "resolved" "https://registry.nlark.com/core-js/download/core-js-3.15.2.tgz?cache=0&sync_timestamp=1624966012065&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcore-js%2Fdownload%2Fcore-js-3.15.2.tgz" + "version" "3.15.2" + +"core-util-is@^1.0.2", "core-util-is@~1.0.0", "core-util-is@1.0.2": + "integrity" "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" + "resolved" "https://registry.nlark.com/core-util-is/download/core-util-is-1.0.2.tgz" + "version" "1.0.2" + +"cosmiconfig@^5.0.0": + "integrity" "sha1-BA9yaAnFked6F8CjYmykW08Wixo=" + "resolved" "https://registry.npm.taobao.org/cosmiconfig/download/cosmiconfig-5.2.1.tgz" + "version" "5.2.1" + dependencies: + "import-fresh" "^2.0.0" + "is-directory" "^0.3.1" + "js-yaml" "^3.13.1" + "parse-json" "^4.0.0" + +"create-ecdh@^4.0.0": + "integrity" "sha1-1uf0v/pmc2CFoHYv06YyaE2rzE4=" + "resolved" "https://registry.nlark.com/create-ecdh/download/create-ecdh-4.0.4.tgz" + "version" "4.0.4" + dependencies: + "bn.js" "^4.1.0" + "elliptic" "^6.5.3" + +"create-hash@^1.1.0", "create-hash@^1.1.2", "create-hash@^1.2.0": + "integrity" "sha1-iJB4rxGmN1a8+1m9IhmWvjqe8ZY=" + "resolved" "https://registry.nlark.com/create-hash/download/create-hash-1.2.0.tgz" + "version" "1.2.0" + dependencies: + "cipher-base" "^1.0.1" + "inherits" "^2.0.1" + "md5.js" "^1.3.4" + "ripemd160" "^2.0.1" + "sha.js" "^2.4.0" + +"create-hmac@^1.1.0", "create-hmac@^1.1.4", "create-hmac@^1.1.7": + "integrity" "sha1-aRcMeLOrlXFHsriwRXLkfq0iQ/8=" + "resolved" "https://registry.npm.taobao.org/create-hmac/download/create-hmac-1.1.7.tgz" + "version" "1.1.7" + dependencies: + "cipher-base" "^1.0.3" + "create-hash" "^1.1.0" + "inherits" "^2.0.1" + "ripemd160" "^2.0.0" + "safe-buffer" "^5.0.1" + "sha.js" "^2.4.8" + +"cross-env@^7.0.3": + "integrity" "sha512-+/HKd6EgcQCJGh2PSjZuUitQBQynKor4wrFbRg4DtAgS1aWO+gU52xpH7M9ScGgXSYmAVS9bIJ8EzuaGw0oNAw==" + "resolved" "https://registry.npmjs.org/cross-env/-/cross-env-7.0.3.tgz" + "version" "7.0.3" + dependencies: + "cross-spawn" "^7.0.1" + +"cross-spawn@^5.0.1": + "integrity" "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=" + "resolved" "https://registry.npm.taobao.org/cross-spawn/download/cross-spawn-5.1.0.tgz" + "version" "5.1.0" + dependencies: + "lru-cache" "^4.0.1" + "shebang-command" "^1.2.0" + "which" "^1.2.9" + +"cross-spawn@^6.0.0": + "integrity" "sha1-Sl7Hxk364iw6FBJNus3uhG2Ay8Q=" + "resolved" "https://registry.npm.taobao.org/cross-spawn/download/cross-spawn-6.0.5.tgz" + "version" "6.0.5" + dependencies: + "nice-try" "^1.0.4" + "path-key" "^2.0.1" + "semver" "^5.5.0" + "shebang-command" "^1.2.0" + "which" "^1.2.9" + +"cross-spawn@^6.0.5": + "integrity" "sha1-Sl7Hxk364iw6FBJNus3uhG2Ay8Q=" + "resolved" "https://registry.npm.taobao.org/cross-spawn/download/cross-spawn-6.0.5.tgz" + "version" "6.0.5" + dependencies: + "nice-try" "^1.0.4" + "path-key" "^2.0.1" + "semver" "^5.5.0" + "shebang-command" "^1.2.0" + "which" "^1.2.9" + +"cross-spawn@^7.0.0", "cross-spawn@^7.0.1": + "integrity" "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==" + "resolved" "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz" + "version" "7.0.3" + dependencies: + "path-key" "^3.1.0" + "shebang-command" "^2.0.0" + "which" "^2.0.1" + +"crypto-browserify@^3.11.0": + "integrity" "sha1-OWz58xN/A+S45TLFj2mCVOAPgOw=" + "resolved" "https://registry.npm.taobao.org/crypto-browserify/download/crypto-browserify-3.12.0.tgz" + "version" "3.12.0" + dependencies: + "browserify-cipher" "^1.0.0" + "browserify-sign" "^4.0.0" + "create-ecdh" "^4.0.0" + "create-hash" "^1.1.0" + "create-hmac" "^1.1.0" + "diffie-hellman" "^5.0.0" + "inherits" "^2.0.1" + "pbkdf2" "^3.0.3" + "public-encrypt" "^4.0.0" + "randombytes" "^2.0.0" + "randomfill" "^1.0.3" + +"css-color-names@^0.0.4", "css-color-names@0.0.4": + "integrity" "sha1-gIrcLnnPhHOAabZGyyDsJ762KeA=" + "resolved" "https://registry.npm.taobao.org/css-color-names/download/css-color-names-0.0.4.tgz" + "version" "0.0.4" + +"css-declaration-sorter@^4.0.1": + "integrity" "sha1-wZiUD2OnbX42wecQGLABchBUyyI=" + "resolved" "https://registry.nlark.com/css-declaration-sorter/download/css-declaration-sorter-4.0.1.tgz?cache=0&sync_timestamp=1620754845858&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcss-declaration-sorter%2Fdownload%2Fcss-declaration-sorter-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "postcss" "^7.0.1" + "timsort" "^0.3.0" + +"css-loader@*", "css-loader@^3.5.3": + "integrity" "sha1-Lkssfm4tJ/jI8o9hv/zS5ske9kU=" + "resolved" "https://registry.nlark.com/css-loader/download/css-loader-3.6.0.tgz" + "version" "3.6.0" + dependencies: + "camelcase" "^5.3.1" + "cssesc" "^3.0.0" + "icss-utils" "^4.1.1" + "loader-utils" "^1.2.3" + "normalize-path" "^3.0.0" + "postcss" "^7.0.32" + "postcss-modules-extract-imports" "^2.0.0" + "postcss-modules-local-by-default" "^3.0.2" + "postcss-modules-scope" "^2.2.0" + "postcss-modules-values" "^3.0.0" + "postcss-value-parser" "^4.1.0" + "schema-utils" "^2.7.0" + "semver" "^6.3.0" + +"css-parse@~2.0.0": + "integrity" "sha1-pGjuZnwW2BzPBcWMONKpfHgNv9Q=" + "resolved" "https://registry.npm.taobao.org/css-parse/download/css-parse-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "css" "^2.0.0" + +"css-select-base-adapter@^0.1.1": + "integrity" "sha1-Oy/0lyzDYquIVhUHqVQIoUMhNdc=" + "resolved" "https://registry.npm.taobao.org/css-select-base-adapter/download/css-select-base-adapter-0.1.1.tgz" + "version" "0.1.1" + +"css-select@^2.0.0": + "integrity" "sha1-ajRlM1ZjWTSoG6ymjQJVQyEF2+8=" + "resolved" "https://registry.nlark.com/css-select/download/css-select-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "boolbase" "^1.0.0" + "css-what" "^3.2.1" + "domutils" "^1.7.0" + "nth-check" "^1.0.2" + +"css-select@^4.1.3": + "integrity" "sha1-pwRA9wMX8maRGK10/xBeZYSccGc=" + "resolved" "https://registry.nlark.com/css-select/download/css-select-4.1.3.tgz" + "version" "4.1.3" + dependencies: + "boolbase" "^1.0.0" + "css-what" "^5.0.0" + "domhandler" "^4.2.0" + "domutils" "^2.6.0" + "nth-check" "^2.0.0" + +"css-tree@^1.1.2": + "integrity" "sha1-60hw+2/XcHMn7JXC/yqwm16NuR0=" + "resolved" "https://registry.nlark.com/css-tree/download/css-tree-1.1.3.tgz" + "version" "1.1.3" + dependencies: + "mdn-data" "2.0.14" + "source-map" "^0.6.1" + +"css-tree@1.0.0-alpha.37": + "integrity" "sha1-mL69YsTB2flg7DQM+fdSLjBwmiI=" + "resolved" "https://registry.nlark.com/css-tree/download/css-tree-1.0.0-alpha.37.tgz" + "version" "1.0.0-alpha.37" + dependencies: + "mdn-data" "2.0.4" + "source-map" "^0.6.1" + +"css-what@^3.2.1": + "integrity" "sha1-6nAm/LAXd+295SEk4h8yfnrpUOQ=" + "resolved" "https://registry.nlark.com/css-what/download/css-what-3.4.2.tgz?cache=0&sync_timestamp=1622227630859&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcss-what%2Fdownload%2Fcss-what-3.4.2.tgz" + "version" "3.4.2" + +"css-what@^5.0.0": + "integrity" "sha1-PvqCATH0ZpqKwkCPnDLnx96fTK0=" + "resolved" "https://registry.nlark.com/css-what/download/css-what-5.0.1.tgz?cache=0&sync_timestamp=1622227630859&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcss-what%2Fdownload%2Fcss-what-5.0.1.tgz" + "version" "5.0.1" + +"css@^2.0.0": + "integrity" "sha1-xkZ1XHOXHyu6amAeLPL9cbEpiSk=" + "resolved" "https://registry.npm.taobao.org/css/download/css-2.2.4.tgz" + "version" "2.2.4" + dependencies: + "inherits" "^2.0.3" + "source-map" "^0.6.1" + "source-map-resolve" "^0.5.2" + "urix" "^0.1.0" + +"cssesc@^3.0.0": + "integrity" "sha1-N3QZGZA7hoVl4cCep0dEXNGJg+4=" + "resolved" "https://registry.npm.taobao.org/cssesc/download/cssesc-3.0.0.tgz" + "version" "3.0.0" + +"cssnano-preset-default@^4.0.0", "cssnano-preset-default@^4.0.8": + "integrity" "sha1-kgYisfwelaNOiDggPxOXpQTy0/8=" + "resolved" "https://registry.nlark.com/cssnano-preset-default/download/cssnano-preset-default-4.0.8.tgz?cache=0&sync_timestamp=1623330257156&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcssnano-preset-default%2Fdownload%2Fcssnano-preset-default-4.0.8.tgz" + "version" "4.0.8" + dependencies: + "css-declaration-sorter" "^4.0.1" + "cssnano-util-raw-cache" "^4.0.1" + "postcss" "^7.0.0" + "postcss-calc" "^7.0.1" + "postcss-colormin" "^4.0.3" + "postcss-convert-values" "^4.0.1" + "postcss-discard-comments" "^4.0.2" + "postcss-discard-duplicates" "^4.0.2" + "postcss-discard-empty" "^4.0.1" + "postcss-discard-overridden" "^4.0.1" + "postcss-merge-longhand" "^4.0.11" + "postcss-merge-rules" "^4.0.3" + "postcss-minify-font-values" "^4.0.2" + "postcss-minify-gradients" "^4.0.2" + "postcss-minify-params" "^4.0.2" + "postcss-minify-selectors" "^4.0.2" + "postcss-normalize-charset" "^4.0.1" + "postcss-normalize-display-values" "^4.0.2" + "postcss-normalize-positions" "^4.0.2" + "postcss-normalize-repeat-style" "^4.0.2" + "postcss-normalize-string" "^4.0.2" + "postcss-normalize-timing-functions" "^4.0.2" + "postcss-normalize-unicode" "^4.0.1" + "postcss-normalize-url" "^4.0.1" + "postcss-normalize-whitespace" "^4.0.2" + "postcss-ordered-values" "^4.1.2" + "postcss-reduce-initial" "^4.0.3" + "postcss-reduce-transforms" "^4.0.2" + "postcss-svgo" "^4.0.3" + "postcss-unique-selectors" "^4.0.1" + +"cssnano-util-get-arguments@^4.0.0": + "integrity" "sha1-7ToIKZ8h11dBsg87gfGU7UnMFQ8=" + "resolved" "https://registry.nlark.com/cssnano-util-get-arguments/download/cssnano-util-get-arguments-4.0.0.tgz" + "version" "4.0.0" + +"cssnano-util-get-match@^4.0.0": + "integrity" "sha1-wOTKB/U4a7F+xeUiULT1lhNlFW0=" + "resolved" "https://registry.npm.taobao.org/cssnano-util-get-match/download/cssnano-util-get-match-4.0.0.tgz" + "version" "4.0.0" + +"cssnano-util-raw-cache@^4.0.1": + "integrity" "sha1-sm1f1fcqEd/np4RvtMZyYPlr8oI=" + "resolved" "https://registry.npm.taobao.org/cssnano-util-raw-cache/download/cssnano-util-raw-cache-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "postcss" "^7.0.0" + +"cssnano-util-same-parent@^4.0.0": + "integrity" "sha1-V0CC+yhZ0ttDOFWDXZqEVuoYu/M=" + "resolved" "https://registry.npm.taobao.org/cssnano-util-same-parent/download/cssnano-util-same-parent-4.0.1.tgz" + "version" "4.0.1" + +"cssnano@^4.0.0", "cssnano@^4.1.10": + "integrity" "sha1-x7X1uB2iacsf2YLLlgwSAJEMmpk=" + "resolved" "https://registry.nlark.com/cssnano/download/cssnano-4.1.11.tgz?cache=0&sync_timestamp=1623330418944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcssnano%2Fdownload%2Fcssnano-4.1.11.tgz" + "version" "4.1.11" + dependencies: + "cosmiconfig" "^5.0.0" + "cssnano-preset-default" "^4.0.8" + "is-resolvable" "^1.0.0" + "postcss" "^7.0.0" + +"csso@^4.0.2": + "integrity" "sha1-6jpWE0bo3J9UbW/r7dUBh884lSk=" + "resolved" "https://registry.nlark.com/csso/download/csso-4.2.0.tgz" + "version" "4.2.0" + dependencies: + "css-tree" "^1.1.2" + +"cssom@^0.4.1": + "integrity" "sha1-WmbPk9LQtmHYC/akT7ZfXC5OChA=" + "resolved" "https://registry.nlark.com/cssom/download/cssom-0.4.4.tgz?cache=0&sync_timestamp=1624219249710&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcssom%2Fdownload%2Fcssom-0.4.4.tgz" + "version" "0.4.4" + +"cssom@~0.3.6": + "integrity" "sha1-nxJ29bK0Y/IRTT8sdSUK+MGjb0o=" + "resolved" "https://registry.nlark.com/cssom/download/cssom-0.3.8.tgz?cache=0&sync_timestamp=1624219249710&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fcssom%2Fdownload%2Fcssom-0.3.8.tgz" + "version" "0.3.8" + +"cssstyle@^2.0.0": + "integrity" "sha1-/2ZaDdvcMYZLCWR/NBY0Q9kLCFI=" + "resolved" "https://registry.nlark.com/cssstyle/download/cssstyle-2.3.0.tgz" + "version" "2.3.0" + dependencies: + "cssom" "~0.3.6" + +"csstype@^2.6.8": + "integrity" "sha512-/WwNkdXfckNgw6S5R125rrW8ez139lBHWouiBvX8dfMFtcn6V81REDqnH7+CRpRipfYlyU1CmOnOxrmGcFOjeA==" + "resolved" "https://registry.npmmirror.com/csstype/-/csstype-2.6.20.tgz" + "version" "2.6.20" + +"cyclist@^1.0.1": + "integrity" "sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk=" + "resolved" "https://registry.npm.taobao.org/cyclist/download/cyclist-1.0.1.tgz" + "version" "1.0.1" + +"dashdash@^1.12.0": + "integrity" "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=" + "resolved" "https://registry.npm.taobao.org/dashdash/download/dashdash-1.14.1.tgz" + "version" "1.14.1" + dependencies: + "assert-plus" "^1.0.0" + +"data-uri-to-buffer@3": + "integrity" "sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og==" + "resolved" "https://registry.npmmirror.com/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz" + "version" "3.0.1" + +"data-urls@^1.1.0": + "integrity" "sha1-Fe4Fgrql4iu1nHcUDaj5x2lju/4=" + "resolved" "https://registry.npm.taobao.org/data-urls/download/data-urls-1.1.0.tgz" + "version" "1.1.0" + dependencies: + "abab" "^2.0.0" + "whatwg-mimetype" "^2.2.0" + "whatwg-url" "^7.0.0" + +"dateformat@^2.0.0": + "integrity" "sha512-GODcnWq3YGoTnygPfi02ygEiRxqUxpJwuRHjdhJYuxpcZmDq4rjBiXYmbCCzStxo176ixfLT6i4NPwQooRySnw==" + "resolved" "https://registry.npmmirror.com/dateformat/-/dateformat-2.2.0.tgz" + "version" "2.2.0" + +"dayjs@^1.11.3": + "integrity" "sha512-CAdX5Q3YW3Gclyo5Vpqkgpj8fSdLQcRuzfX6mC6Phy0nfJ0eGYOeS7m4mt2plDWLAtA4TqTakvbboHvUxfe4iA==" + "resolved" "https://registry.npmmirror.com/dayjs/-/dayjs-1.11.5.tgz" + "version" "1.11.5" + +"debug@^2.2.0": + "integrity" "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==" + "resolved" "https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz" + "version" "2.6.9" + dependencies: + "ms" "2.0.0" + +"debug@^2.3.3": + "integrity" "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=" + "resolved" "https://registry.nlark.com/debug/download/debug-2.6.9.tgz" + "version" "2.6.9" + dependencies: + "ms" "2.0.0" + +"debug@^2.6.9": + "integrity" "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==" + "resolved" "https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz" + "version" "2.6.9" + dependencies: + "ms" "2.0.0" + +"debug@^3.1.1": + "integrity" "sha1-clgLfpFF+zm2Z2+cXl+xALk0F5o=" + "resolved" "https://registry.nlark.com/debug/download/debug-3.2.7.tgz" + "version" "3.2.7" + dependencies: + "ms" "^2.1.1" + +"debug@^3.2.6": + "integrity" "sha1-clgLfpFF+zm2Z2+cXl+xALk0F5o=" + "resolved" "https://registry.nlark.com/debug/download/debug-3.2.7.tgz" + "version" "3.2.7" + dependencies: + "ms" "^2.1.1" + +"debug@^4.0.1", "debug@^4.1.0", "debug@^4.1.1", "debug@4": + "integrity" "sha1-8KScGKyHeeMdSgxgKd+3aHPHQos=" + "resolved" "https://registry.nlark.com/debug/download/debug-4.3.2.tgz" + "version" "4.3.2" + dependencies: + "ms" "2.1.2" + +"debug@~3.1.0": + "integrity" "sha1-W7WgZyYotkFJVmuhaBnmFRjGcmE=" + "resolved" "https://registry.nlark.com/debug/download/debug-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "ms" "2.0.0" + +"debug@2.6.9": + "integrity" "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=" + "resolved" "https://registry.nlark.com/debug/download/debug-2.6.9.tgz" + "version" "2.6.9" + dependencies: + "ms" "2.0.0" + +"debug@3.2.6": + "integrity" "sha1-6D0X3hbYp++3cX7b5fsQE17uYps=" + "resolved" "https://registry.nlark.com/debug/download/debug-3.2.6.tgz" + "version" "3.2.6" + dependencies: + "ms" "^2.1.1" + +"decamelize@^1.2.0": + "integrity" "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" + "resolved" "https://registry.nlark.com/decamelize/download/decamelize-1.2.0.tgz" + "version" "1.2.0" + +"decode-uri-component@^0.2.0": + "integrity" "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=" + "resolved" "https://registry.npm.taobao.org/decode-uri-component/download/decode-uri-component-0.2.0.tgz" + "version" "0.2.0" + +"deep-eql@^3.0.1": + "integrity" "sha1-38lARACtHI/gI+faHfHBR8S0RN8=" + "resolved" "https://registry.npm.taobao.org/deep-eql/download/deep-eql-3.0.1.tgz" + "version" "3.0.1" + dependencies: + "type-detect" "^4.0.0" + +"deep-equal@^1.0.1": + "integrity" "sha1-tcmMlCzv+vfLBR4k4UNKJaLmB2o=" + "resolved" "https://registry.npm.taobao.org/deep-equal/download/deep-equal-1.1.1.tgz?cache=0&sync_timestamp=1606860101281&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdeep-equal%2Fdownload%2Fdeep-equal-1.1.1.tgz" + "version" "1.1.1" + dependencies: + "is-arguments" "^1.0.4" + "is-date-object" "^1.0.1" + "is-regex" "^1.0.4" + "object-is" "^1.0.1" + "object-keys" "^1.1.1" + "regexp.prototype.flags" "^1.2.0" + +"deep-is@~0.1.3": + "integrity" "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" + "resolved" "https://registry.npm.taobao.org/deep-is/download/deep-is-0.1.3.tgz" + "version" "0.1.3" + +"deepmerge@^1.5.2": + "integrity" "sha1-EEmdhohEza1P7ghC34x/bwyVp1M=" + "resolved" "https://registry.npm.taobao.org/deepmerge/download/deepmerge-1.5.2.tgz?cache=0&sync_timestamp=1606805746825&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdeepmerge%2Fdownload%2Fdeepmerge-1.5.2.tgz" + "version" "1.5.2" + +"default-gateway@^4.2.0": + "integrity" "sha1-FnEEx1AMIRX23WmwpTa7jtcgVSs=" + "resolved" "https://registry.npm.taobao.org/default-gateway/download/default-gateway-4.2.0.tgz?cache=0&sync_timestamp=1610365816953&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdefault-gateway%2Fdownload%2Fdefault-gateway-4.2.0.tgz" + "version" "4.2.0" + dependencies: + "execa" "^1.0.0" + "ip-regex" "^2.1.0" + +"default-gateway@^5.0.5": + "integrity" "sha1-T9a9XShV05s0zFpZUFSG6ar8mxA=" + "resolved" "https://registry.npm.taobao.org/default-gateway/download/default-gateway-5.0.5.tgz?cache=0&sync_timestamp=1610365816953&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdefault-gateway%2Fdownload%2Fdefault-gateway-5.0.5.tgz" + "version" "5.0.5" + dependencies: + "execa" "^3.3.0" + +"default-user-agent@^1.0.0": + "integrity" "sha512-bDF7bg6OSNcSwFWPu4zYKpVkJZQYVrAANMYB8bc9Szem1D0yKdm4sa/rOCs2aC9+2GMqQ7KnwtZRvDhmLF0dXw==" + "resolved" "https://registry.npmmirror.com/default-user-agent/-/default-user-agent-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "os-name" "~1.0.3" + +"defaults@^1.0.3": + "integrity" "sha1-xlYFHpgX2f8I7YgUd/P+QBnz730=" + "resolved" "https://registry.npm.taobao.org/defaults/download/defaults-1.0.3.tgz" + "version" "1.0.3" + dependencies: + "clone" "^1.0.2" + +"define-properties@^1.1.2", "define-properties@^1.1.3": + "integrity" "sha1-z4jabL7ib+bbcJT2HYcMvYTO6fE=" + "resolved" "https://registry.nlark.com/define-properties/download/define-properties-1.1.3.tgz" + "version" "1.1.3" + dependencies: + "object-keys" "^1.0.12" + +"define-property@^0.2.5": + "integrity" "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=" + "resolved" "https://registry.npm.taobao.org/define-property/download/define-property-0.2.5.tgz" + "version" "0.2.5" + dependencies: + "is-descriptor" "^0.1.0" + +"define-property@^1.0.0": + "integrity" "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=" + "resolved" "https://registry.npm.taobao.org/define-property/download/define-property-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "is-descriptor" "^1.0.0" + +"define-property@^2.0.2": + "integrity" "sha1-1Flono1lS6d+AqgX+HENcCyxbp0=" + "resolved" "https://registry.npm.taobao.org/define-property/download/define-property-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "is-descriptor" "^1.0.2" + "isobject" "^3.0.1" + +"degenerator@^3.0.2": + "integrity" "sha512-c0mef3SNQo56t6urUU6tdQAs+ThoD0o9B9MJ8HEt7NQcGEILCRFqQb7ZbP9JAv+QF1Ky5plydhMR/IrqWDm+TQ==" + "resolved" "https://registry.npmmirror.com/degenerator/-/degenerator-3.0.2.tgz" + "version" "3.0.2" + dependencies: + "ast-types" "^0.13.2" + "escodegen" "^1.8.1" + "esprima" "^4.0.0" + "vm2" "^3.9.8" + +"del@^4.1.1": + "integrity" "sha1-no8RciLqRKMf86FWwEm5kFKp8LQ=" + "resolved" "https://registry.npm.taobao.org/del/download/del-4.1.1.tgz" + "version" "4.1.1" + dependencies: + "@types/glob" "^7.1.1" + "globby" "^6.1.0" + "is-path-cwd" "^2.0.0" + "is-path-in-cwd" "^2.0.0" + "p-map" "^2.0.0" + "pify" "^4.0.1" + "rimraf" "^2.6.3" + +"delayed-stream@~1.0.0": + "integrity" "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" + "resolved" "https://registry.npm.taobao.org/delayed-stream/download/delayed-stream-1.0.0.tgz" + "version" "1.0.0" + +"depd@~1.1.2": + "integrity" "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" + "resolved" "https://registry.npm.taobao.org/depd/download/depd-1.1.2.tgz" + "version" "1.1.2" + +"des.js@^1.0.0": + "integrity" "sha1-U4IULhvcU/hdhtU+X0qn3rkeCEM=" + "resolved" "https://registry.npm.taobao.org/des.js/download/des.js-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "inherits" "^2.0.1" + "minimalistic-assert" "^1.0.0" + +"destroy@^1.0.4", "destroy@~1.0.4": + "integrity" "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" + "resolved" "https://registry.npm.taobao.org/destroy/download/destroy-1.0.4.tgz" + "version" "1.0.4" + +"detect-node@^2.0.4": + "integrity" "sha1-yccHdaScPQO8LAbZpzvlUPl4+LE=" + "resolved" "https://registry.nlark.com/detect-node/download/detect-node-2.1.0.tgz?cache=0&sync_timestamp=1621146954463&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fdetect-node%2Fdownload%2Fdetect-node-2.1.0.tgz" + "version" "2.1.0" + +"diff@3.5.0": + "integrity" "sha1-gAwN0eCov7yVg1wgKtIg/jF+WhI=" + "resolved" "https://registry.npm.taobao.org/diff/download/diff-3.5.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdiff%2Fdownload%2Fdiff-3.5.0.tgz" + "version" "3.5.0" + +"diffie-hellman@^5.0.0": + "integrity" "sha1-QOjumPVaIUlgcUaSHGPhrl89KHU=" + "resolved" "https://registry.npm.taobao.org/diffie-hellman/download/diffie-hellman-5.0.3.tgz" + "version" "5.0.3" + dependencies: + "bn.js" "^4.1.0" + "miller-rabin" "^4.0.0" + "randombytes" "^2.0.0" + +"digest-header@^1.0.0": + "integrity" "sha512-sRTuakZ2PkOUCuAaVv+SLjhr/hRf8ldZP0XnGEQ69RFGxmll5fVaMsnRXWKKK4XsUTnJf8+eRPSFNgE/lWa9wQ==" + "resolved" "https://registry.npmmirror.com/digest-header/-/digest-header-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "utility" "^1.17.0" + +"dir-glob@^2.0.0", "dir-glob@^2.2.2": + "integrity" "sha1-+gnwaUFTyJGLGLoN6vrpR2n8UMQ=" + "resolved" "https://registry.nlark.com/dir-glob/download/dir-glob-2.2.2.tgz" + "version" "2.2.2" + dependencies: + "path-type" "^3.0.0" + +"dir-glob@^3.0.1": + "integrity" "sha1-Vtv3PZkqSpO6FYT0U0Bj/S5BcX8=" + "resolved" "https://registry.nlark.com/dir-glob/download/dir-glob-3.0.1.tgz" + "version" "3.0.1" + dependencies: + "path-type" "^4.0.0" + +"dns-equal@^1.0.0": + "integrity" "sha1-s55/HabrCnW6nBcySzR1PEfgZU0=" + "resolved" "https://registry.npm.taobao.org/dns-equal/download/dns-equal-1.0.0.tgz" + "version" "1.0.0" + +"dns-packet@^1.3.1": + "integrity" "sha1-40VQZYJKJQe6iGxVqJljuxB97G8=" + "resolved" "https://registry.nlark.com/dns-packet/download/dns-packet-1.3.4.tgz" + "version" "1.3.4" + dependencies: + "ip" "^1.1.0" + "safe-buffer" "^5.0.1" + +"dns-txt@^2.0.2": + "integrity" "sha1-uR2Ab10nGI5Ks+fRB9iBocxGQrY=" + "resolved" "https://registry.npm.taobao.org/dns-txt/download/dns-txt-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "buffer-indexof" "^1.0.0" + +"doctrine@^3.0.0": + "integrity" "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==" + "resolved" "https://registry.npmmirror.com/doctrine/-/doctrine-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "esutils" "^2.0.2" + +"dom-converter@^0.2.0": + "integrity" "sha1-ZyGp2u4uKTaClVtq/kFncWJ7t2g=" + "resolved" "https://registry.npm.taobao.org/dom-converter/download/dom-converter-0.2.0.tgz" + "version" "0.2.0" + dependencies: + "utila" "~0.4" + +"dom-serializer@^1.0.1": + "integrity" "sha1-YgZDfTLO767HFhgDIwx6ILwbTZE=" + "resolved" "https://registry.nlark.com/dom-serializer/download/dom-serializer-1.3.2.tgz?cache=0&sync_timestamp=1621256819522&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fdom-serializer%2Fdownload%2Fdom-serializer-1.3.2.tgz" + "version" "1.3.2" + dependencies: + "domelementtype" "^2.0.1" + "domhandler" "^4.2.0" + "entities" "^2.0.0" + +"dom-serializer@0": + "integrity" "sha1-GvuB9TNxcXXUeGVd68XjMtn5u1E=" + "resolved" "https://registry.nlark.com/dom-serializer/download/dom-serializer-0.2.2.tgz?cache=0&sync_timestamp=1621256819522&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fdom-serializer%2Fdownload%2Fdom-serializer-0.2.2.tgz" + "version" "0.2.2" + dependencies: + "domelementtype" "^2.0.1" + "entities" "^2.0.0" + +"domain-browser@^1.1.1": + "integrity" "sha1-PTH1AZGmdJ3RN1p/Ui6CPULlTto=" + "resolved" "https://registry.npm.taobao.org/domain-browser/download/domain-browser-1.2.0.tgz" + "version" "1.2.0" + +"domelementtype@^2.0.1", "domelementtype@^2.2.0": + "integrity" "sha1-mgtsJ4LtahxzI9QiZxg9+b2LHVc=" + "resolved" "https://registry.npm.taobao.org/domelementtype/download/domelementtype-2.2.0.tgz" + "version" "2.2.0" + +"domelementtype@1": + "integrity" "sha1-0EjESzew0Qp/Kj1f7j9DM9eQSB8=" + "resolved" "https://registry.npm.taobao.org/domelementtype/download/domelementtype-1.3.1.tgz" + "version" "1.3.1" + +"domexception@^1.0.1": + "integrity" "sha1-k3RCZEymoxJh7zbj7Gd/6AVYLJA=" + "resolved" "https://registry.nlark.com/domexception/download/domexception-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "webidl-conversions" "^4.0.2" + +"domhandler@^4.0.0", "domhandler@^4.2.0": + "integrity" "sha1-+XaKXwNL5gqJonwuTQ9066DYsFk=" + "resolved" "https://registry.nlark.com/domhandler/download/domhandler-4.2.0.tgz" + "version" "4.2.0" + dependencies: + "domelementtype" "^2.2.0" + +"domutils@^1.7.0": + "integrity" "sha1-Vuo0HoNOBuZ0ivehyyXaZ+qfjCo=" + "resolved" "https://registry.nlark.com/domutils/download/domutils-1.7.0.tgz" + "version" "1.7.0" + dependencies: + "dom-serializer" "0" + "domelementtype" "1" + +"domutils@^2.5.2", "domutils@^2.6.0": + "integrity" "sha1-jrrwxB66/PVbC3LsMcVjI3EsVEI=" + "resolved" "https://registry.nlark.com/domutils/download/domutils-2.7.0.tgz" + "version" "2.7.0" + dependencies: + "dom-serializer" "^1.0.1" + "domelementtype" "^2.2.0" + "domhandler" "^4.2.0" + +"dot-prop@^5.2.0": + "integrity" "sha1-kMzOcIzZzYLMTcjD3dmr3VWyDog=" + "resolved" "https://registry.npm.taobao.org/dot-prop/download/dot-prop-5.3.0.tgz?cache=0&sync_timestamp=1605778235569&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdot-prop%2Fdownload%2Fdot-prop-5.3.0.tgz" + "version" "5.3.0" + dependencies: + "is-obj" "^2.0.0" + +"dotenv-expand@^5.1.0": + "integrity" "sha1-P7rwIL/XlIhAcuomsel5HUWmKfA=" + "resolved" "https://registry.npm.taobao.org/dotenv-expand/download/dotenv-expand-5.1.0.tgz" + "version" "5.1.0" + +"dotenv@^8.2.0": + "integrity" "sha1-Bhr2ZNGff02PxuT/m1hM4jety4s=" + "resolved" "https://registry.nlark.com/dotenv/download/dotenv-8.6.0.tgz" + "version" "8.6.0" + +"duplexer@^0.1.1": + "integrity" "sha1-Or5DrvODX4rgd9E23c4PJ2sEAOY=" + "resolved" "https://registry.nlark.com/duplexer/download/duplexer-0.1.2.tgz" + "version" "0.1.2" + +"duplexify@^3.4.2", "duplexify@^3.6.0": + "integrity" "sha1-Kk31MX9sz9kfhtb9JdjYoQO4gwk=" + "resolved" "https://registry.npm.taobao.org/duplexify/download/duplexify-3.7.1.tgz" + "version" "3.7.1" + dependencies: + "end-of-stream" "^1.0.0" + "inherits" "^2.0.1" + "readable-stream" "^2.0.0" + "stream-shift" "^1.0.0" + +"easy-stack@1.0.1": + "integrity" "sha512-wK2sCs4feiiJeFXn3zvY0p41mdU5VUgbgs1rNsc/y5ngFUijdWd+iIN8eoyuZHKB8xN6BL4PdWmzqFmxNg6V2w==" + "resolved" "https://registry.npmmirror.com/easy-stack/-/easy-stack-1.0.1.tgz" + "version" "1.0.1" + +"ecc-jsbn@~0.1.1": + "integrity" "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=" + "resolved" "https://registry.npm.taobao.org/ecc-jsbn/download/ecc-jsbn-0.1.2.tgz" + "version" "0.1.2" + dependencies: + "jsbn" "~0.1.0" + "safer-buffer" "^2.1.0" + +"echarts@^5.0.2": + "integrity" "sha1-FybRelfPBdYs0FZ7QyXhIBpWuvY=" + "resolved" "https://registry.nlark.com/echarts/download/echarts-5.0.2.tgz" + "version" "5.0.2" + dependencies: + "tslib" "2.0.3" + "zrender" "5.0.4" + +"ee-first@~1.1.1", "ee-first@1.1.1": + "integrity" "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" + "resolved" "https://registry.nlark.com/ee-first/download/ee-first-1.1.1.tgz" + "version" "1.1.1" + +"ejs@^2.6.1": + "integrity" "sha1-SGYSh1c9zFPjZsehrlLDoSDuybo=" + "resolved" "https://registry.npm.taobao.org/ejs/download/ejs-2.7.4.tgz?cache=0&sync_timestamp=1612644037163&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fejs%2Fdownload%2Fejs-2.7.4.tgz" + "version" "2.7.4" + +"electron-to-chromium@^1.3.723": + "integrity" "sha1-BGUX0fLOp1Pgb/9UmZW53EXiAII=" + "resolved" "https://registry.nlark.com/electron-to-chromium/download/electron-to-chromium-1.3.775.tgz" + "version" "1.3.775" + +"element-plus@^2.2.14": + "integrity" "sha512-V5Pis0OHhePg1RgVogZrcefaVl8vjVn4Pn9Qsh/t2CbFgjg9kKOYFqf/tuP3ObSXGm3X89hpe0W+nLVAsaFnpw==" + "resolved" "https://registry.npmmirror.com/element-plus/-/element-plus-2.2.14.tgz" + "version" "2.2.14" + dependencies: + "@ctrl/tinycolor" "^3.4.1" + "@element-plus/icons-vue" "^2.0.6" + "@floating-ui/dom" "^0.5.4" + "@popperjs/core" "npm:@sxzz/popperjs-es@^2.11.7" + "@types/lodash" "^4.14.182" + "@types/lodash-es" "^4.17.6" + "@vueuse/core" "^9.1.0" + "async-validator" "^4.2.5" + "dayjs" "^1.11.3" + "escape-html" "^1.0.3" + "lodash" "^4.17.21" + "lodash-es" "^4.17.21" + "lodash-unified" "^1.0.2" + "memoize-one" "^6.0.0" + "normalize-wheel-es" "^1.2.0" + +"elliptic@^6.5.3": + "integrity" "sha1-2jfOvTHnmhNn6UG1ku0fvr1Yq7s=" + "resolved" "https://registry.npm.taobao.org/elliptic/download/elliptic-6.5.4.tgz?cache=0&sync_timestamp=1612290836352&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Felliptic%2Fdownload%2Felliptic-6.5.4.tgz" + "version" "6.5.4" + dependencies: + "bn.js" "^4.11.9" + "brorand" "^1.1.0" + "hash.js" "^1.0.0" + "hmac-drbg" "^1.0.1" + "inherits" "^2.0.4" + "minimalistic-assert" "^1.0.1" + "minimalistic-crypto-utils" "^1.0.1" + +"emoji-regex@^7.0.1": + "integrity" "sha1-kzoEBShgyF6DwSJHnEdIqOTHIVY=" + "resolved" "https://registry.nlark.com/emoji-regex/download/emoji-regex-7.0.3.tgz" + "version" "7.0.3" + +"emoji-regex@^8.0.0": + "integrity" "sha1-6Bj9ac5cz8tARZT4QpY79TFkzDc=" + "resolved" "https://registry.nlark.com/emoji-regex/download/emoji-regex-8.0.0.tgz" + "version" "8.0.0" + +"emojis-list@^2.0.0": + "integrity" "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=" + "resolved" "https://registry.npm.taobao.org/emojis-list/download/emojis-list-2.1.0.tgz" + "version" "2.1.0" + +"emojis-list@^3.0.0": + "integrity" "sha1-VXBmIEatKeLpFucariYKvf9Pang=" + "resolved" "https://registry.npm.taobao.org/emojis-list/download/emojis-list-3.0.0.tgz" + "version" "3.0.0" + +"encodeurl@~1.0.2": + "integrity" "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" + "resolved" "https://registry.npm.taobao.org/encodeurl/download/encodeurl-1.0.2.tgz" + "version" "1.0.2" + +"end-of-stream@^1.0.0", "end-of-stream@^1.1.0": + "integrity" "sha1-WuZKX0UFe682JuwU2gyl5LJDHrA=" + "resolved" "https://registry.npm.taobao.org/end-of-stream/download/end-of-stream-1.4.4.tgz" + "version" "1.4.4" + dependencies: + "once" "^1.4.0" + +"end-or-error@^1.0.1": + "integrity" "sha512-OclLMSug+k2A0JKuf494im25ANRBVW8qsjmwbgX7lQ8P82H21PQ1PWkoYwb9y5yMBS69BPlwtzdIFClo3+7kOQ==" + "resolved" "https://registry.npmmirror.com/end-or-error/-/end-or-error-1.0.1.tgz" + "version" "1.0.1" + +"enhanced-resolve@^4.5.0": + "integrity" "sha1-Lzz9hNvjtIfxjy2y7x4GSlccpew=" + "resolved" "https://registry.nlark.com/enhanced-resolve/download/enhanced-resolve-4.5.0.tgz?cache=0&sync_timestamp=1620663831689&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fenhanced-resolve%2Fdownload%2Fenhanced-resolve-4.5.0.tgz" + "version" "4.5.0" + dependencies: + "graceful-fs" "^4.1.2" + "memory-fs" "^0.5.0" + "tapable" "^1.0.0" + +"entities@^2.0.0": + "integrity" "sha1-CY3JDruD2N/6CJ1VJWs1HTTE2lU=" + "resolved" "https://registry.npm.taobao.org/entities/download/entities-2.2.0.tgz?cache=0&sync_timestamp=1611535322406&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fentities%2Fdownload%2Fentities-2.2.0.tgz" + "version" "2.2.0" + +"errno@^0.1.1", "errno@^0.1.3", "errno@~0.1.7": + "integrity" "sha1-i7Ppx9Rjvkl2/4iPdrSAnrwugR8=" + "resolved" "https://registry.npm.taobao.org/errno/download/errno-0.1.8.tgz" + "version" "0.1.8" + dependencies: + "prr" "~1.0.1" + +"error-ex@^1.3.1": + "integrity" "sha1-tKxAZIEH/c3PriQvQovqihTU8b8=" + "resolved" "https://registry.npm.taobao.org/error-ex/download/error-ex-1.3.2.tgz" + "version" "1.3.2" + dependencies: + "is-arrayish" "^0.2.1" + +"error-stack-parser@^2.0.2": + "integrity" "sha1-WpmnB716TFinl5AtSNgoA+3mqtg=" + "resolved" "https://registry.npm.taobao.org/error-stack-parser/download/error-stack-parser-2.0.6.tgz" + "version" "2.0.6" + dependencies: + "stackframe" "^1.1.1" + +"es-abstract@^1.18.0-next.2", "es-abstract@^1.18.2": + "integrity" "sha1-JcTDOAonqiA8RLK2hbupTaMbY+A=" + "resolved" "https://registry.nlark.com/es-abstract/download/es-abstract-1.18.3.tgz?cache=0&sync_timestamp=1622158101826&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fes-abstract%2Fdownload%2Fes-abstract-1.18.3.tgz" + "version" "1.18.3" + dependencies: + "call-bind" "^1.0.2" + "es-to-primitive" "^1.2.1" + "function-bind" "^1.1.1" + "get-intrinsic" "^1.1.1" + "has" "^1.0.3" + "has-symbols" "^1.0.2" + "is-callable" "^1.2.3" + "is-negative-zero" "^2.0.1" + "is-regex" "^1.1.3" + "is-string" "^1.0.6" + "object-inspect" "^1.10.3" + "object-keys" "^1.1.1" + "object.assign" "^4.1.2" + "string.prototype.trimend" "^1.0.4" + "string.prototype.trimstart" "^1.0.4" + "unbox-primitive" "^1.0.1" + +"es-to-primitive@^1.2.1": + "integrity" "sha1-5VzUyc3BiLzvsDs2bHNjI/xciYo=" + "resolved" "https://registry.npm.taobao.org/es-to-primitive/download/es-to-primitive-1.2.1.tgz" + "version" "1.2.1" + dependencies: + "is-callable" "^1.1.4" + "is-date-object" "^1.0.1" + "is-symbol" "^1.0.2" + +"escalade@^3.1.1": + "integrity" "sha1-2M/ccACWXFoBdLSoLqpcBVJ0LkA=" + "resolved" "https://registry.npm.taobao.org/escalade/download/escalade-3.1.1.tgz" + "version" "3.1.1" + +"escape-html@^1.0.3", "escape-html@~1.0.3": + "integrity" "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" + "resolved" "https://registry.nlark.com/escape-html/download/escape-html-1.0.3.tgz" + "version" "1.0.3" + +"escape-string-regexp@^1.0.5", "escape-string-regexp@1.0.5": + "integrity" "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" + "resolved" "https://registry.nlark.com/escape-string-regexp/download/escape-string-regexp-1.0.5.tgz" + "version" "1.0.5" + +"escodegen@^1.11.1", "escodegen@^1.8.1": + "integrity" "sha1-TnuB+6YVgdyXWC7XjKt/Do1j9QM=" + "resolved" "https://registry.nlark.com/escodegen/download/escodegen-1.14.3.tgz" + "version" "1.14.3" + dependencies: + "esprima" "^4.0.1" + "estraverse" "^4.2.0" + "esutils" "^2.0.2" + "optionator" "^0.8.1" + optionalDependencies: + "source-map" "~0.6.1" + +"eslint-loader@^2.2.1": + "integrity" "sha1-KLnBLaVAV68IReKmEScBova/gzc=" + "resolved" "https://registry.npm.taobao.org/eslint-loader/download/eslint-loader-2.2.1.tgz" + "version" "2.2.1" + dependencies: + "loader-fs-cache" "^1.0.0" + "loader-utils" "^1.0.2" + "object-assign" "^4.0.1" + "object-hash" "^1.1.4" + "rimraf" "^2.6.1" + +"eslint-scope@^4.0.3": + "integrity" "sha1-ygODMxD2iJoyZHgaqC5j65z+eEg=" + "resolved" "https://registry.npm.taobao.org/eslint-scope/download/eslint-scope-4.0.3.tgz" + "version" "4.0.3" + dependencies: + "esrecurse" "^4.1.0" + "estraverse" "^4.1.1" + +"eslint-scope@^5.0.0": + "integrity" "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==" + "resolved" "https://registry.npmmirror.com/eslint-scope/-/eslint-scope-5.1.1.tgz" + "version" "5.1.1" + dependencies: + "esrecurse" "^4.3.0" + "estraverse" "^4.1.1" + +"eslint-utils@^1.4.3": + "integrity" "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==" + "resolved" "https://registry.npmmirror.com/eslint-utils/-/eslint-utils-1.4.3.tgz" + "version" "1.4.3" + dependencies: + "eslint-visitor-keys" "^1.1.0" + +"eslint-visitor-keys@^1.0.0", "eslint-visitor-keys@^1.1.0": + "integrity" "sha1-MOvR73wv3/AcOk8VEESvJfqwUj4=" + "resolved" "https://registry.nlark.com/eslint-visitor-keys/download/eslint-visitor-keys-1.3.0.tgz" + "version" "1.3.0" + +"eslint@>= 1.6.0 < 7.0.0", "eslint@>= 4.12.1", "eslint@>=1.6.0 <7.0.0": + "integrity" "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==" + "resolved" "https://registry.npmmirror.com/eslint/-/eslint-6.8.0.tgz" + "version" "6.8.0" + dependencies: + "@babel/code-frame" "^7.0.0" + "ajv" "^6.10.0" + "chalk" "^2.1.0" + "cross-spawn" "^6.0.5" + "debug" "^4.0.1" + "doctrine" "^3.0.0" + "eslint-scope" "^5.0.0" + "eslint-utils" "^1.4.3" + "eslint-visitor-keys" "^1.1.0" + "espree" "^6.1.2" + "esquery" "^1.0.1" + "esutils" "^2.0.2" + "file-entry-cache" "^5.0.1" + "functional-red-black-tree" "^1.0.1" + "glob-parent" "^5.0.0" + "globals" "^12.1.0" + "ignore" "^4.0.6" + "import-fresh" "^3.0.0" + "imurmurhash" "^0.1.4" + "inquirer" "^7.0.0" + "is-glob" "^4.0.0" + "js-yaml" "^3.13.1" + "json-stable-stringify-without-jsonify" "^1.0.1" + "levn" "^0.3.0" + "lodash" "^4.17.14" + "minimatch" "^3.0.4" + "mkdirp" "^0.5.1" + "natural-compare" "^1.4.0" + "optionator" "^0.8.3" + "progress" "^2.0.0" + "regexpp" "^2.0.1" + "semver" "^6.1.2" + "strip-ansi" "^5.2.0" + "strip-json-comments" "^3.0.1" + "table" "^5.2.3" + "text-table" "^0.2.0" + "v8-compile-cache" "^2.0.3" + +"espree@^6.1.2": + "integrity" "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==" + "resolved" "https://registry.npmmirror.com/espree/-/espree-6.2.1.tgz" + "version" "6.2.1" + dependencies: + "acorn" "^7.1.1" + "acorn-jsx" "^5.2.0" + "eslint-visitor-keys" "^1.1.0" + +"esprima@^4.0.0", "esprima@^4.0.1": + "integrity" "sha1-E7BM2z5sXRnfkatph6hpVhmwqnE=" + "resolved" "https://registry.nlark.com/esprima/download/esprima-4.0.1.tgz" + "version" "4.0.1" + +"esquery@^1.0.1": + "integrity" "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==" + "resolved" "https://registry.npmmirror.com/esquery/-/esquery-1.4.0.tgz" + "version" "1.4.0" + dependencies: + "estraverse" "^5.1.0" + +"esrecurse@^4.1.0", "esrecurse@^4.3.0": + "integrity" "sha1-eteWTWeauyi+5yzsY3WLHF0smSE=" + "resolved" "https://registry.npm.taobao.org/esrecurse/download/esrecurse-4.3.0.tgz" + "version" "4.3.0" + dependencies: + "estraverse" "^5.2.0" + +"estraverse@^4.1.1", "estraverse@^4.2.0": + "integrity" "sha1-OYrT88WiSUi+dyXoPRGn3ijNvR0=" + "resolved" "https://registry.npm.taobao.org/estraverse/download/estraverse-4.3.0.tgz" + "version" "4.3.0" + +"estraverse@^5.1.0": + "integrity" "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==" + "resolved" "https://registry.npmmirror.com/estraverse/-/estraverse-5.3.0.tgz" + "version" "5.3.0" + +"estraverse@^5.2.0": + "integrity" "sha1-MH30JUfmzHMk088DwVXVzbjFOIA=" + "resolved" "https://registry.npm.taobao.org/estraverse/download/estraverse-5.2.0.tgz" + "version" "5.2.0" + +"estree-walker@^2.0.2": + "integrity" "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==" + "resolved" "https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz" + "version" "2.0.2" + +"esutils@^2.0.2": + "integrity" "sha1-dNLrTeC42hKTcRkQ1Qd1ubcQ72Q=" + "resolved" "https://registry.nlark.com/esutils/download/esutils-2.0.3.tgz" + "version" "2.0.3" + +"etag@~1.8.1": + "integrity" "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" + "resolved" "https://registry.npm.taobao.org/etag/download/etag-1.8.1.tgz" + "version" "1.8.1" + +"event-pubsub@4.3.0": + "integrity" "sha512-z7IyloorXvKbFx9Bpie2+vMJKKx1fH1EN5yiTfp8CiLOTptSYy1g8H4yDpGlEdshL1PBiFtBHepF2cNsqeEeFQ==" + "resolved" "https://registry.npmmirror.com/event-pubsub/-/event-pubsub-4.3.0.tgz" + "version" "4.3.0" + +"event-target-shim@^5.0.0": + "integrity" "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==" + "resolved" "https://registry.npmmirror.com/event-target-shim/-/event-target-shim-5.0.1.tgz" + "version" "5.0.1" + +"eventemitter3@^4.0.0": + "integrity" "sha1-Lem2j2Uo1WRO9cWVJqG0oHMGFp8=" + "resolved" "https://registry.npm.taobao.org/eventemitter3/download/eventemitter3-4.0.7.tgz" + "version" "4.0.7" + +"events@^3.0.0": + "integrity" "sha1-Mala0Kkk4tLEGagTrrLE6HjqdAA=" + "resolved" "https://registry.npm.taobao.org/events/download/events-3.3.0.tgz" + "version" "3.3.0" + +"eventsource@^1.0.7": + "integrity" "sha1-AOjKfJIQnpSw3fMtrGd9hBAoz68=" + "resolved" "https://registry.npm.taobao.org/eventsource/download/eventsource-1.1.0.tgz?cache=0&sync_timestamp=1616041748498&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Feventsource%2Fdownload%2Feventsource-1.1.0.tgz" + "version" "1.1.0" + dependencies: + "original" "^1.0.0" + +"evp_bytestokey@^1.0.0", "evp_bytestokey@^1.0.3": + "integrity" "sha1-f8vbGY3HGVlDLv4ThCaE4FJaywI=" + "resolved" "https://registry.nlark.com/evp_bytestokey/download/evp_bytestokey-1.0.3.tgz" + "version" "1.0.3" + dependencies: + "md5.js" "^1.3.4" + "safe-buffer" "^5.1.1" + +"execa@^0.8.0": + "integrity" "sha1-2NdrvBtVIX7RkP1t1J08d07PyNo=" + "resolved" "https://registry.nlark.com/execa/download/execa-0.8.0.tgz?cache=0&sync_timestamp=1622825859616&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fexeca%2Fdownload%2Fexeca-0.8.0.tgz" + "version" "0.8.0" + dependencies: + "cross-spawn" "^5.0.1" + "get-stream" "^3.0.0" + "is-stream" "^1.1.0" + "npm-run-path" "^2.0.0" + "p-finally" "^1.0.0" + "signal-exit" "^3.0.0" + "strip-eof" "^1.0.0" + +"execa@^1.0.0": + "integrity" "sha1-xiNqW7TfbW8V6I5/AXeYIWdJ3dg=" + "resolved" "https://registry.nlark.com/execa/download/execa-1.0.0.tgz?cache=0&sync_timestamp=1622825859616&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fexeca%2Fdownload%2Fexeca-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "cross-spawn" "^6.0.0" + "get-stream" "^4.0.0" + "is-stream" "^1.1.0" + "npm-run-path" "^2.0.0" + "p-finally" "^1.0.0" + "signal-exit" "^3.0.0" + "strip-eof" "^1.0.0" + +"execa@^3.3.0": + "integrity" "sha1-wI7UVQ72XYWPrCaf/IVyRG8364k=" + "resolved" "https://registry.nlark.com/execa/download/execa-3.4.0.tgz?cache=0&sync_timestamp=1622825859616&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fexeca%2Fdownload%2Fexeca-3.4.0.tgz" + "version" "3.4.0" + dependencies: + "cross-spawn" "^7.0.0" + "get-stream" "^5.0.0" + "human-signals" "^1.1.1" + "is-stream" "^2.0.0" + "merge-stream" "^2.0.0" + "npm-run-path" "^4.0.0" + "onetime" "^5.1.0" + "p-finally" "^2.0.0" + "signal-exit" "^3.0.2" + "strip-final-newline" "^2.0.0" + +"expand-brackets@^2.1.4": + "integrity" "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=" + "resolved" "https://registry.npm.taobao.org/expand-brackets/download/expand-brackets-2.1.4.tgz" + "version" "2.1.4" + dependencies: + "debug" "^2.3.3" + "define-property" "^0.2.5" + "extend-shallow" "^2.0.1" + "posix-character-classes" "^0.1.0" + "regex-not" "^1.0.0" + "snapdragon" "^0.8.1" + "to-regex" "^3.0.1" + +"express@^4.16.3", "express@^4.17.1": + "integrity" "sha1-RJH8OGBc9R+GKdOcK10Cb5ikwTQ=" + "resolved" "https://registry.npm.taobao.org/express/download/express-4.17.1.tgz" + "version" "4.17.1" + dependencies: + "accepts" "~1.3.7" + "array-flatten" "1.1.1" + "body-parser" "1.19.0" + "content-disposition" "0.5.3" + "content-type" "~1.0.4" + "cookie" "0.4.0" + "cookie-signature" "1.0.6" + "debug" "2.6.9" + "depd" "~1.1.2" + "encodeurl" "~1.0.2" + "escape-html" "~1.0.3" + "etag" "~1.8.1" + "finalhandler" "~1.1.2" + "fresh" "0.5.2" + "merge-descriptors" "1.0.1" + "methods" "~1.1.2" + "on-finished" "~2.3.0" + "parseurl" "~1.3.3" + "path-to-regexp" "0.1.7" + "proxy-addr" "~2.0.5" + "qs" "6.7.0" + "range-parser" "~1.2.1" + "safe-buffer" "5.1.2" + "send" "0.17.1" + "serve-static" "1.14.1" + "setprototypeof" "1.1.1" + "statuses" "~1.5.0" + "type-is" "~1.6.18" + "utils-merge" "1.0.1" + "vary" "~1.1.2" + +"extend-shallow@^2.0.1": + "integrity" "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=" + "resolved" "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "is-extendable" "^0.1.0" + +"extend-shallow@^3.0.0", "extend-shallow@^3.0.2": + "integrity" "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=" + "resolved" "https://registry.npm.taobao.org/extend-shallow/download/extend-shallow-3.0.2.tgz" + "version" "3.0.2" + dependencies: + "assign-symbols" "^1.0.0" + "is-extendable" "^1.0.1" + +"extend@~3.0.2": + "integrity" "sha1-+LETa0Bx+9jrFAr/hYsQGewpFfo=" + "resolved" "https://registry.npm.taobao.org/extend/download/extend-3.0.2.tgz" + "version" "3.0.2" + +"external-editor@^3.0.3": + "integrity" "sha1-ywP3QL764D6k0oPK7SdBqD8zVJU=" + "resolved" "https://registry.npm.taobao.org/external-editor/download/external-editor-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "chardet" "^0.7.0" + "iconv-lite" "^0.4.24" + "tmp" "^0.0.33" + +"extglob@^2.0.4": + "integrity" "sha1-rQD+TcYSqSMuhxhxHcXLWrAoVUM=" + "resolved" "https://registry.npm.taobao.org/extglob/download/extglob-2.0.4.tgz" + "version" "2.0.4" + dependencies: + "array-unique" "^0.3.2" + "define-property" "^1.0.0" + "expand-brackets" "^2.1.4" + "extend-shallow" "^2.0.1" + "fragment-cache" "^0.2.1" + "regex-not" "^1.0.0" + "snapdragon" "^0.8.1" + "to-regex" "^3.0.1" + +"extsprintf@^1.2.0", "extsprintf@1.3.0": + "integrity" "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" + "resolved" "https://registry.nlark.com/extsprintf/download/extsprintf-1.3.0.tgz" + "version" "1.3.0" + +"fast-deep-equal@^3.1.1": + "integrity" "sha1-On1WtVnWy8PrUSMlJE5hmmXGxSU=" + "resolved" "https://registry.nlark.com/fast-deep-equal/download/fast-deep-equal-3.1.3.tgz" + "version" "3.1.3" + +"fast-glob@^2.2.6": + "integrity" "sha1-aVOFfDr6R1//ku5gFdUtpwpM050=" + "resolved" "https://registry.nlark.com/fast-glob/download/fast-glob-2.2.7.tgz" + "version" "2.2.7" + dependencies: + "@mrmlnc/readdir-enhanced" "^2.2.1" + "@nodelib/fs.stat" "^1.1.2" + "glob-parent" "^3.1.0" + "is-glob" "^4.0.0" + "merge2" "^1.2.3" + "micromatch" "^3.1.10" + +"fast-glob@^3.0.3": + "integrity" "sha1-/Wy3otfpqnp4RhEehaGW1rL3ZqE=" + "resolved" "https://registry.nlark.com/fast-glob/download/fast-glob-3.2.7.tgz" + "version" "3.2.7" + 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": + "integrity" "sha1-h0v2nG9ATCtdmcSBNBOZ/VWJJjM=" + "resolved" "https://registry.nlark.com/fast-json-stable-stringify/download/fast-json-stable-stringify-2.1.0.tgz?cache=0&sync_timestamp=1618847186091&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffast-json-stable-stringify%2Fdownload%2Ffast-json-stable-stringify-2.1.0.tgz" + "version" "2.1.0" + +"fast-levenshtein@~2.0.6": + "integrity" "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" + "resolved" "https://registry.nlark.com/fast-levenshtein/download/fast-levenshtein-2.0.6.tgz" + "version" "2.0.6" + +"fastq@^1.6.0": + "integrity" "sha1-XYF1quF9thlH+LFiz8f2MmTSKAc=" + "resolved" "https://registry.nlark.com/fastq/download/fastq-1.11.1.tgz" + "version" "1.11.1" + dependencies: + "reusify" "^1.0.4" + +"faye-websocket@^0.11.3": + "integrity" "sha1-fw2Sdc/dhqHJY9yLZfzEUe3Lsdo=" + "resolved" "https://registry.nlark.com/faye-websocket/download/faye-websocket-0.11.4.tgz?cache=0&sync_timestamp=1621894499766&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffaye-websocket%2Fdownload%2Ffaye-websocket-0.11.4.tgz" + "version" "0.11.4" + dependencies: + "websocket-driver" ">=0.5.1" + +"fetch-cookie@^0.11.0": + "integrity" "sha512-BQm7iZLFhMWFy5CZ/162sAGjBfdNWb7a8LEqqnzsHFhxT/X/SVj/z2t2nu3aJvjlbQkrAlTUApplPRjWyH4mhA==" + "resolved" "https://registry.npmmirror.com/fetch-cookie/-/fetch-cookie-0.11.0.tgz" + "version" "0.11.0" + dependencies: + "tough-cookie" "^2.3.3 || ^3.0.1 || ^4.0.0" + +"figgy-pudding@^3.5.1": + "integrity" "sha1-tO7oFIq7Adzx0aw0Nn1Z4S+mHW4=" + "resolved" "https://registry.npm.taobao.org/figgy-pudding/download/figgy-pudding-3.5.2.tgz" + "version" "3.5.2" + +"figures@^3.0.0": + "integrity" "sha1-YlwYvSk8YE3EqN2y/r8MiDQXRq8=" + "resolved" "https://registry.nlark.com/figures/download/figures-3.2.0.tgz" + "version" "3.2.0" + dependencies: + "escape-string-regexp" "^1.0.5" + +"file-entry-cache@^5.0.1": + "integrity" "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==" + "resolved" "https://registry.npmmirror.com/file-entry-cache/-/file-entry-cache-5.0.1.tgz" + "version" "5.0.1" + dependencies: + "flat-cache" "^2.0.1" + +"file-loader@*", "file-loader@^4.2.0": + "integrity" "sha1-eA8ED3KbPRgBnyBgX3I+hEuKWK8=" + "resolved" "https://registry.npm.taobao.org/file-loader/download/file-loader-4.3.0.tgz" + "version" "4.3.0" + dependencies: + "loader-utils" "^1.2.3" + "schema-utils" "^2.5.0" + +"file-uri-to-path@2": + "integrity" "sha512-hjPFI8oE/2iQPVe4gbrJ73Pp+Xfub2+WI2LlXDbsaJBwT5wuMh35WNWVYYTpnz895shtwfyutMFLFywpQAFdLg==" + "resolved" "https://registry.npmmirror.com/file-uri-to-path/-/file-uri-to-path-2.0.0.tgz" + "version" "2.0.0" + +"filesize@^3.6.1": + "integrity" "sha1-CQuz7gG2+AGoqL6Z0xcQs0Irsxc=" + "resolved" "https://registry.nlark.com/filesize/download/filesize-3.6.1.tgz?cache=0&sync_timestamp=1626007234928&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffilesize%2Fdownload%2Ffilesize-3.6.1.tgz" + "version" "3.6.1" + +"fill-range@^4.0.0": + "integrity" "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=" + "resolved" "https://registry.nlark.com/fill-range/download/fill-range-4.0.0.tgz" + "version" "4.0.0" + dependencies: + "extend-shallow" "^2.0.1" + "is-number" "^3.0.0" + "repeat-string" "^1.6.1" + "to-regex-range" "^2.1.0" + +"fill-range@^7.0.1": + "integrity" "sha1-GRmmp8df44ssfHflGYU12prN2kA=" + "resolved" "https://registry.nlark.com/fill-range/download/fill-range-7.0.1.tgz" + "version" "7.0.1" + dependencies: + "to-regex-range" "^5.0.1" + +"finalhandler@~1.1.2": + "integrity" "sha1-t+fQAP/RGTjQ/bBTUG9uur6fWH0=" + "resolved" "https://registry.npm.taobao.org/finalhandler/download/finalhandler-1.1.2.tgz" + "version" "1.1.2" + dependencies: + "debug" "2.6.9" + "encodeurl" "~1.0.2" + "escape-html" "~1.0.3" + "on-finished" "~2.3.0" + "parseurl" "~1.3.3" + "statuses" "~1.5.0" + "unpipe" "~1.0.0" + +"find-cache-dir@^0.1.1": + "integrity" "sha1-yN765XyKUqinhPnjHFfHQumToLk=" + "resolved" "https://registry.npm.taobao.org/find-cache-dir/download/find-cache-dir-0.1.1.tgz" + "version" "0.1.1" + dependencies: + "commondir" "^1.0.1" + "mkdirp" "^0.5.1" + "pkg-dir" "^1.0.0" + +"find-cache-dir@^2.1.0": + "integrity" "sha1-jQ+UzRP+Q8bHwmGg2GEVypGMBfc=" + "resolved" "https://registry.npm.taobao.org/find-cache-dir/download/find-cache-dir-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "commondir" "^1.0.1" + "make-dir" "^2.0.0" + "pkg-dir" "^3.0.0" + +"find-cache-dir@^3.0.0", "find-cache-dir@^3.3.1": + "integrity" "sha1-ibM/rUpGcNqpT4Vff74x1thP6IA=" + "resolved" "https://registry.npm.taobao.org/find-cache-dir/download/find-cache-dir-3.3.1.tgz" + "version" "3.3.1" + dependencies: + "commondir" "^1.0.1" + "make-dir" "^3.0.2" + "pkg-dir" "^4.1.0" + +"find-up@^1.0.0": + "integrity" "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=" + "resolved" "https://registry.nlark.com/find-up/download/find-up-1.1.2.tgz" + "version" "1.1.2" + dependencies: + "path-exists" "^2.0.0" + "pinkie-promise" "^2.0.0" + +"find-up@^3.0.0", "find-up@3.0.0": + "integrity" "sha1-SRafHXmTQwZG2mHsxa41XCHJe3M=" + "resolved" "https://registry.nlark.com/find-up/download/find-up-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "locate-path" "^3.0.0" + +"find-up@^4.0.0": + "integrity" "sha1-l6/n1s3AvFkoWEt8jXsW6KmqXRk=" + "resolved" "https://registry.nlark.com/find-up/download/find-up-4.1.0.tgz" + "version" "4.1.0" + dependencies: + "locate-path" "^5.0.0" + "path-exists" "^4.0.0" + +"flat-cache@^2.0.1": + "integrity" "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==" + "resolved" "https://registry.npmmirror.com/flat-cache/-/flat-cache-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "flatted" "^2.0.0" + "rimraf" "2.6.3" + "write" "1.0.3" + +"flat@^4.1.0": + "integrity" "sha1-o5IFnMOCiB/5hkL12k3eCpWfMJs=" + "resolved" "https://registry.npm.taobao.org/flat/download/flat-4.1.1.tgz?cache=0&sync_timestamp=1602723427161&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fflat%2Fdownload%2Fflat-4.1.1.tgz" + "version" "4.1.1" + dependencies: + "is-buffer" "~2.0.3" + +"flatted@^2.0.0": + "integrity" "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==" + "resolved" "https://registry.npmmirror.com/flatted/-/flatted-2.0.2.tgz" + "version" "2.0.2" + +"flush-write-stream@^1.0.0": + "integrity" "sha1-jdfYc6G6vCB9lOrQwuDkQnbr8ug=" + "resolved" "https://registry.npm.taobao.org/flush-write-stream/download/flush-write-stream-1.1.1.tgz" + "version" "1.1.1" + dependencies: + "inherits" "^2.0.3" + "readable-stream" "^2.3.6" + +"follow-redirects@^1.0.0", "follow-redirects@^1.10.0": + "integrity" "sha1-2RFN7Qoc/dM04WTmZirQK/2R/0M=" + "resolved" "https://registry.nlark.com/follow-redirects/download/follow-redirects-1.14.1.tgz?cache=0&sync_timestamp=1620555246888&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffollow-redirects%2Fdownload%2Ffollow-redirects-1.14.1.tgz" + "version" "1.14.1" + +"for-in@^1.0.2": + "integrity" "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" + "resolved" "https://registry.npm.taobao.org/for-in/download/for-in-1.0.2.tgz" + "version" "1.0.2" + +"forever-agent@~0.6.1": + "integrity" "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" + "resolved" "https://registry.nlark.com/forever-agent/download/forever-agent-0.6.1.tgz" + "version" "0.6.1" + +"form-data@~2.3.2": + "integrity" "sha1-3M5SwF9kTymManq5Nr1yTO/786Y=" + "resolved" "https://registry.nlark.com/form-data/download/form-data-2.3.3.tgz" + "version" "2.3.3" + dependencies: + "asynckit" "^0.4.0" + "combined-stream" "^1.0.6" + "mime-types" "^2.1.12" + +"formstream@^1.1.0": + "integrity" "sha512-yHRxt3qLFnhsKAfhReM4w17jP+U1OlhUjnKPPtonwKbIJO7oBP0MvoxkRUwb8AU9n0MIkYy5X5dK6pQnbj+R2Q==" + "resolved" "https://registry.npmmirror.com/formstream/-/formstream-1.1.1.tgz" + "version" "1.1.1" + dependencies: + "destroy" "^1.0.4" + "mime" "^2.5.2" + "pause-stream" "~0.0.11" + +"forwarded@0.2.0": + "integrity" "sha1-ImmTZCiq1MFcfr6XeahL8LKoGBE=" + "resolved" "https://registry.nlark.com/forwarded/download/forwarded-0.2.0.tgz?cache=0&sync_timestamp=1622503508967&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fforwarded%2Fdownload%2Fforwarded-0.2.0.tgz" + "version" "0.2.0" + +"fragment-cache@^0.2.1": + "integrity" "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=" + "resolved" "https://registry.npm.taobao.org/fragment-cache/download/fragment-cache-0.2.1.tgz" + "version" "0.2.1" + dependencies: + "map-cache" "^0.2.2" + +"fresh@0.5.2": + "integrity" "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" + "resolved" "https://registry.npm.taobao.org/fresh/download/fresh-0.5.2.tgz" + "version" "0.5.2" + +"from2@^2.1.0": + "integrity" "sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8=" + "resolved" "https://registry.npm.taobao.org/from2/download/from2-2.3.0.tgz" + "version" "2.3.0" + dependencies: + "inherits" "^2.0.1" + "readable-stream" "^2.0.0" + +"fs-extra@^7.0.1": + "integrity" "sha1-TxicRKoSO4lfcigE9V6iPq3DSOk=" + "resolved" "https://registry.nlark.com/fs-extra/download/fs-extra-7.0.1.tgz?cache=0&sync_timestamp=1620079845472&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ffs-extra%2Fdownload%2Ffs-extra-7.0.1.tgz" + "version" "7.0.1" + dependencies: + "graceful-fs" "^4.1.2" + "jsonfile" "^4.0.0" + "universalify" "^0.1.0" + +"fs-extra@^8.1.0": + "integrity" "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==" + "resolved" "https://registry.npmmirror.com/fs-extra/-/fs-extra-8.1.0.tgz" + "version" "8.1.0" + dependencies: + "graceful-fs" "^4.2.0" + "jsonfile" "^4.0.0" + "universalify" "^0.1.0" + +"fs-write-stream-atomic@^1.0.8": + "integrity" "sha1-tH31NJPvkR33VzHnCp3tAYnbQMk=" + "resolved" "https://registry.npm.taobao.org/fs-write-stream-atomic/download/fs-write-stream-atomic-1.0.10.tgz" + "version" "1.0.10" + dependencies: + "graceful-fs" "^4.1.2" + "iferr" "^0.1.5" + "imurmurhash" "^0.1.4" + "readable-stream" "1 || 2" + +"fs.realpath@^1.0.0": + "integrity" "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" + "resolved" "https://registry.nlark.com/fs.realpath/download/fs.realpath-1.0.0.tgz" + "version" "1.0.0" + +"ftp@^0.3.10": + "integrity" "sha512-faFVML1aBx2UoDStmLwv2Wptt4vw5x03xxX172nhA5Y5HBshW5JweqQ2W4xL4dezQTG8inJsuYcpPHHU3X5OTQ==" + "resolved" "https://registry.npmmirror.com/ftp/-/ftp-0.3.10.tgz" + "version" "0.3.10" + dependencies: + "readable-stream" "1.1.x" + "xregexp" "2.0.0" + +"function-bind@^1.1.1": + "integrity" "sha1-pWiZ0+o8m6uHS7l3O3xe3pL0iV0=" + "resolved" "https://registry.nlark.com/function-bind/download/function-bind-1.1.1.tgz" + "version" "1.1.1" + +"functional-red-black-tree@^1.0.1": + "integrity" "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==" + "resolved" "https://registry.npmmirror.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz" + "version" "1.0.1" + +"gensync@^1.0.0-beta.2": + "integrity" "sha1-MqbudsPX9S1GsrGuXZP+qFgKJeA=" + "resolved" "https://registry.npm.taobao.org/gensync/download/gensync-1.0.0-beta.2.tgz" + "version" "1.0.0-beta.2" + +"get-caller-file@^2.0.1", "get-caller-file@^2.0.5": + "integrity" "sha1-T5RBKoLbMvNuOwuXQfipf+sDH34=" + "resolved" "https://registry.npm.taobao.org/get-caller-file/download/get-caller-file-2.0.5.tgz" + "version" "2.0.5" + +"get-func-name@^2.0.0": + "integrity" "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=" + "resolved" "https://registry.npm.taobao.org/get-func-name/download/get-func-name-2.0.0.tgz" + "version" "2.0.0" + +"get-intrinsic@^1.0.2", "get-intrinsic@^1.1.1": + "integrity" "sha1-FfWfN2+FXERpY5SPDSTNNje0q8Y=" + "resolved" "https://registry.nlark.com/get-intrinsic/download/get-intrinsic-1.1.1.tgz" + "version" "1.1.1" + dependencies: + "function-bind" "^1.1.1" + "has" "^1.0.3" + "has-symbols" "^1.0.1" + +"get-ready@^1.0.0", "get-ready@~1.0.0": + "integrity" "sha512-mFXCZPJIlcYcth+N8267+mghfYN9h3EhsDa6JSnbA3Wrhh/XFpuowviFcsDeYZtKspQyWyJqfs4O6P8CHeTwzw==" + "resolved" "https://registry.npmmirror.com/get-ready/-/get-ready-1.0.0.tgz" + "version" "1.0.0" + +"get-stream@^3.0.0": + "integrity" "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=" + "resolved" "https://registry.nlark.com/get-stream/download/get-stream-3.0.0.tgz" + "version" "3.0.0" + +"get-stream@^4.0.0": + "integrity" "sha1-wbJVV189wh1Zv8ec09K0axw6VLU=" + "resolved" "https://registry.nlark.com/get-stream/download/get-stream-4.1.0.tgz" + "version" "4.1.0" + dependencies: + "pump" "^3.0.0" + +"get-stream@^5.0.0": + "integrity" "sha1-SWaheV7lrOZecGxLe+txJX1uItM=" + "resolved" "https://registry.nlark.com/get-stream/download/get-stream-5.2.0.tgz" + "version" "5.2.0" + dependencies: + "pump" "^3.0.0" + +"get-uri@3": + "integrity" "sha512-+5s0SJbGoyiJTZZ2JTpFPLMPSch72KEqGOTvQsBqg0RBWvwhWUSYZFAtz3TPW0GXJuLBJPts1E241iHg+VRfhg==" + "resolved" "https://registry.npmmirror.com/get-uri/-/get-uri-3.0.2.tgz" + "version" "3.0.2" + dependencies: + "@tootallnate/once" "1" + "data-uri-to-buffer" "3" + "debug" "4" + "file-uri-to-path" "2" + "fs-extra" "^8.1.0" + "ftp" "^0.3.10" + +"get-value@^2.0.3", "get-value@^2.0.6": + "integrity" "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=" + "resolved" "https://registry.nlark.com/get-value/download/get-value-2.0.6.tgz" + "version" "2.0.6" + +"getpass@^0.1.1": + "integrity" "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=" + "resolved" "https://registry.npm.taobao.org/getpass/download/getpass-0.1.7.tgz" + "version" "0.1.7" + dependencies: + "assert-plus" "^1.0.0" + +"glob-parent@^3.1.0": + "integrity" "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=" + "resolved" "https://registry.nlark.com/glob-parent/download/glob-parent-3.1.0.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "is-glob" "^3.1.0" + "path-dirname" "^1.0.0" + +"glob-parent@^5.0.0": + "integrity" "sha1-hpgyxYA0/mikCTwX3BXoNA2EAcQ=" + "resolved" "https://registry.nlark.com/glob-parent/download/glob-parent-5.1.2.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-5.1.2.tgz" + "version" "5.1.2" + dependencies: + "is-glob" "^4.0.1" + +"glob-parent@^5.1.2": + "integrity" "sha1-hpgyxYA0/mikCTwX3BXoNA2EAcQ=" + "resolved" "https://registry.nlark.com/glob-parent/download/glob-parent-5.1.2.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-5.1.2.tgz" + "version" "5.1.2" + dependencies: + "is-glob" "^4.0.1" + +"glob-parent@~5.1.2": + "integrity" "sha1-hpgyxYA0/mikCTwX3BXoNA2EAcQ=" + "resolved" "https://registry.nlark.com/glob-parent/download/glob-parent-5.1.2.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-5.1.2.tgz" + "version" "5.1.2" + dependencies: + "is-glob" "^4.0.1" + +"glob-parent@5.1.0": + "integrity" "sha1-X0wdHnSNMM1zrSlEs1d6gbCB6MI=" + "resolved" "https://registry.nlark.com/glob-parent/download/glob-parent-5.1.0.tgz?cache=0&sync_timestamp=1620073303944&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob-parent%2Fdownload%2Fglob-parent-5.1.0.tgz" + "version" "5.1.0" + dependencies: + "is-glob" "^4.0.1" + +"glob-to-regexp@^0.3.0": + "integrity" "sha1-jFoUlNIGbFcMw7/kSWF1rMTVAqs=" + "resolved" "https://registry.npm.taobao.org/glob-to-regexp/download/glob-to-regexp-0.3.0.tgz" + "version" "0.3.0" + +"glob@^7.0.3", "glob@^7.1.2", "glob@^7.1.3", "glob@^7.1.4", "glob@^7.1.6": + "integrity" "sha1-Oxk+kjPwHULQs/eClLvutBj5SpA=" + "resolved" "https://registry.nlark.com/glob/download/glob-7.1.7.tgz?cache=0&sync_timestamp=1620337498129&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob%2Fdownload%2Fglob-7.1.7.tgz" + "version" "7.1.7" + dependencies: + "fs.realpath" "^1.0.0" + "inflight" "^1.0.4" + "inherits" "2" + "minimatch" "^3.0.4" + "once" "^1.3.0" + "path-is-absolute" "^1.0.0" + +"glob@7.1.3": + "integrity" "sha1-OWCDLT8VdBCDQtr9OmezMsCWnfE=" + "resolved" "https://registry.nlark.com/glob/download/glob-7.1.3.tgz?cache=0&sync_timestamp=1620337498129&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglob%2Fdownload%2Fglob-7.1.3.tgz" + "version" "7.1.3" + dependencies: + "fs.realpath" "^1.0.0" + "inflight" "^1.0.4" + "inherits" "2" + "minimatch" "^3.0.4" + "once" "^1.3.0" + "path-is-absolute" "^1.0.0" + +"globals@^11.1.0": + "integrity" "sha1-q4eVM4hooLq9hSV1gBjCp+uVxC4=" + "resolved" "https://registry.nlark.com/globals/download/globals-11.12.0.tgz" + "version" "11.12.0" + +"globals@^12.1.0": + "integrity" "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==" + "resolved" "https://registry.npmmirror.com/globals/-/globals-12.4.0.tgz" + "version" "12.4.0" + dependencies: + "type-fest" "^0.8.1" + +"globby@^10.0.1": + "integrity" "sha1-J3WT50WsqkZGw6tBEonsR6A5JUM=" + "resolved" "https://registry.nlark.com/globby/download/globby-10.0.2.tgz" + "version" "10.0.2" + dependencies: + "@types/glob" "^7.1.1" + "array-union" "^2.1.0" + "dir-glob" "^3.0.1" + "fast-glob" "^3.0.3" + "glob" "^7.1.3" + "ignore" "^5.1.1" + "merge2" "^1.2.3" + "slash" "^3.0.0" + +"globby@^6.1.0": + "integrity" "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=" + "resolved" "https://registry.nlark.com/globby/download/globby-6.1.0.tgz" + "version" "6.1.0" + dependencies: + "array-union" "^1.0.1" + "glob" "^7.0.3" + "object-assign" "^4.0.1" + "pify" "^2.0.0" + "pinkie-promise" "^2.0.0" + +"globby@^7.1.1": + "integrity" "sha1-+yzP+UAfhgCUXfral0QMypcrhoA=" + "resolved" "https://registry.nlark.com/globby/download/globby-7.1.1.tgz" + "version" "7.1.1" + dependencies: + "array-union" "^1.0.1" + "dir-glob" "^2.0.0" + "glob" "^7.1.2" + "ignore" "^3.3.5" + "pify" "^3.0.0" + "slash" "^1.0.0" + +"globby@^9.2.0": + "integrity" "sha1-/QKacGxwPSm90XD0tts6P3p8tj0=" + "resolved" "https://registry.nlark.com/globby/download/globby-9.2.0.tgz" + "version" "9.2.0" + dependencies: + "@types/glob" "^7.1.1" + "array-union" "^1.0.2" + "dir-glob" "^2.2.2" + "fast-glob" "^2.2.6" + "glob" "^7.1.3" + "ignore" "^4.0.3" + "pify" "^4.0.1" + "slash" "^2.0.0" + +"graceful-fs@^4.1.11", "graceful-fs@^4.1.15", "graceful-fs@^4.1.2", "graceful-fs@^4.1.6", "graceful-fs@^4.2.0": + "integrity" "sha1-/wQLKwhTsjw9MQJ1I3BvGIXXa+4=" + "resolved" "https://registry.nlark.com/graceful-fs/download/graceful-fs-4.2.6.tgz" + "version" "4.2.6" + +"growl@1.10.5": + "integrity" "sha1-8nNdwig2dPpnR4sQGBBZNVw2nl4=" + "resolved" "https://registry.npm.taobao.org/growl/download/growl-1.10.5.tgz" + "version" "1.10.5" + +"gzip-size@^5.0.0": + "integrity" "sha1-y5vuaS+HwGErIyhAqHOQTkwTUnQ=" + "resolved" "https://registry.npm.taobao.org/gzip-size/download/gzip-size-5.1.1.tgz?cache=0&sync_timestamp=1605523260680&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fgzip-size%2Fdownload%2Fgzip-size-5.1.1.tgz" + "version" "5.1.1" + dependencies: + "duplexer" "^0.1.1" + "pify" "^4.0.1" + +"handle-thing@^2.0.0": + "integrity" "sha1-hX95zjWVgMNA1DCBzGSJcNC7I04=" + "resolved" "https://registry.npm.taobao.org/handle-thing/download/handle-thing-2.0.1.tgz" + "version" "2.0.1" + +"har-schema@^2.0.0": + "integrity" "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" + "resolved" "https://registry.npm.taobao.org/har-schema/download/har-schema-2.0.0.tgz" + "version" "2.0.0" + +"har-validator@~5.1.3": + "integrity" "sha1-HwgDufjLIMD6E4It8ezds2veHv0=" + "resolved" "https://registry.npm.taobao.org/har-validator/download/har-validator-5.1.5.tgz" + "version" "5.1.5" + dependencies: + "ajv" "^6.12.3" + "har-schema" "^2.0.0" + +"has-bigints@^1.0.1": + "integrity" "sha1-ZP5qywIGc+O3jbA1pa9pqp0HsRM=" + "resolved" "https://registry.npm.taobao.org/has-bigints/download/has-bigints-1.0.1.tgz?cache=0&sync_timestamp=1615461293395&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhas-bigints%2Fdownload%2Fhas-bigints-1.0.1.tgz" + "version" "1.0.1" + +"has-flag@^3.0.0": + "integrity" "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" + "resolved" "https://registry.npm.taobao.org/has-flag/download/has-flag-3.0.0.tgz?cache=0&sync_timestamp=1618559744568&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhas-flag%2Fdownload%2Fhas-flag-3.0.0.tgz" + "version" "3.0.0" + +"has-flag@^4.0.0": + "integrity" "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" + "resolved" "https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz" + "version" "4.0.0" + +"has-symbols@^1.0.0", "has-symbols@^1.0.1", "has-symbols@^1.0.2": + "integrity" "sha1-Fl0wcMADCXUqEjakeTMeOsVvFCM=" + "resolved" "https://registry.nlark.com/has-symbols/download/has-symbols-1.0.2.tgz" + "version" "1.0.2" + +"has-value@^0.3.1": + "integrity" "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=" + "resolved" "https://registry.npm.taobao.org/has-value/download/has-value-0.3.1.tgz" + "version" "0.3.1" + dependencies: + "get-value" "^2.0.3" + "has-values" "^0.1.4" + "isobject" "^2.0.0" + +"has-value@^1.0.0": + "integrity" "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=" + "resolved" "https://registry.npm.taobao.org/has-value/download/has-value-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "get-value" "^2.0.6" + "has-values" "^1.0.0" + "isobject" "^3.0.0" + +"has-values@^0.1.4": + "integrity" "sha1-bWHeldkd/Km5oCCJrThL/49it3E=" + "resolved" "https://registry.npm.taobao.org/has-values/download/has-values-0.1.4.tgz" + "version" "0.1.4" + +"has-values@^1.0.0": + "integrity" "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=" + "resolved" "https://registry.npm.taobao.org/has-values/download/has-values-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "is-number" "^3.0.0" + "kind-of" "^4.0.0" + +"has@^1.0.0", "has@^1.0.3": + "integrity" "sha1-ci18v8H2qoJB8W3YFOAR4fQeh5Y=" + "resolved" "https://registry.nlark.com/has/download/has-1.0.3.tgz" + "version" "1.0.3" + dependencies: + "function-bind" "^1.1.1" + +"hash-base@^3.0.0": + "integrity" "sha1-VcOB2eBuHSmXqIO0o/3f5/DTrzM=" + "resolved" "https://registry.npm.taobao.org/hash-base/download/hash-base-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "inherits" "^2.0.4" + "readable-stream" "^3.6.0" + "safe-buffer" "^5.2.0" + +"hash-sum@^1.0.2": + "integrity" "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=" + "resolved" "https://registry.npm.taobao.org/hash-sum/download/hash-sum-1.0.2.tgz" + "version" "1.0.2" + +"hash-sum@^2.0.0": + "integrity" "sha1-gdAbtd6OpKIUrV1urRtSNGCwtFo=" + "resolved" "https://registry.npm.taobao.org/hash-sum/download/hash-sum-2.0.0.tgz" + "version" "2.0.0" + +"hash.js@^1.0.0", "hash.js@^1.0.3": + "integrity" "sha1-C6vKU46NTuSg+JiNaIZlN6ADz0I=" + "resolved" "https://registry.npm.taobao.org/hash.js/download/hash.js-1.1.7.tgz" + "version" "1.1.7" + dependencies: + "inherits" "^2.0.3" + "minimalistic-assert" "^1.0.1" + +"he@1.2.0", "he@1.2.x": + "integrity" "sha1-hK5l+n6vsWX922FWauFLrwVmTw8=" + "resolved" "https://registry.nlark.com/he/download/he-1.2.0.tgz" + "version" "1.2.0" + +"hex-color-regex@^1.1.0": + "integrity" "sha1-TAb8y0YC/iYCs8k9+C1+fb8aio4=" + "resolved" "https://registry.npm.taobao.org/hex-color-regex/download/hex-color-regex-1.1.0.tgz" + "version" "1.1.0" + +"highlight.js@^10.7.1": + "integrity" "sha1-aXJy45kTVuQMPKxWanTu9oF1ZTE=" + "resolved" "https://registry.nlark.com/highlight.js/download/highlight.js-10.7.3.tgz" + "version" "10.7.3" + +"hmac-drbg@^1.0.1": + "integrity" "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=" + "resolved" "https://registry.npm.taobao.org/hmac-drbg/download/hmac-drbg-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "hash.js" "^1.0.3" + "minimalistic-assert" "^1.0.0" + "minimalistic-crypto-utils" "^1.0.1" + +"hoopy@^0.1.4": + "integrity" "sha1-YJIH1mEQADOpqUAq096mdzgcGx0=" + "resolved" "https://registry.npm.taobao.org/hoopy/download/hoopy-0.1.4.tgz" + "version" "0.1.4" + +"hosted-git-info@^2.1.4": + "integrity" "sha1-3/wL+aIcAiCQkPKqaUKeFBTa8/k=" + "resolved" "https://registry.nlark.com/hosted-git-info/download/hosted-git-info-2.8.9.tgz" + "version" "2.8.9" + +"hpack.js@^2.1.6": + "integrity" "sha1-h3dMCUnlE/QuhFdbPEVoH63ioLI=" + "resolved" "https://registry.npm.taobao.org/hpack.js/download/hpack.js-2.1.6.tgz" + "version" "2.1.6" + dependencies: + "inherits" "^2.0.1" + "obuf" "^1.0.0" + "readable-stream" "^2.0.1" + "wbuf" "^1.1.0" + +"hsl-regex@^1.0.0": + "integrity" "sha1-1JMwx4ntgZ4nakwNJy3/owsY/m4=" + "resolved" "https://registry.npm.taobao.org/hsl-regex/download/hsl-regex-1.0.0.tgz" + "version" "1.0.0" + +"hsla-regex@^1.0.0": + "integrity" "sha1-wc56MWjIxmFAM6S194d/OyJfnDg=" + "resolved" "https://registry.npm.taobao.org/hsla-regex/download/hsla-regex-1.0.0.tgz" + "version" "1.0.0" + +"html-encoding-sniffer@^1.0.2": + "integrity" "sha1-5w2EuU2lOqN14R/jo1G+ZkLKRvg=" + "resolved" "https://registry.npm.taobao.org/html-encoding-sniffer/download/html-encoding-sniffer-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "whatwg-encoding" "^1.0.1" + +"html-entities@^1.3.1": + "integrity" "sha1-z70bAdKvr5rcobEK59/6uYxx0tw=" + "resolved" "https://registry.npm.taobao.org/html-entities/download/html-entities-1.4.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhtml-entities%2Fdownload%2Fhtml-entities-1.4.0.tgz" + "version" "1.4.0" + +"html-minifier@^3.2.3": + "integrity" "sha1-0AQOBUcw41TbAIRjWTGUAVIS0gw=" + "resolved" "https://registry.npm.taobao.org/html-minifier/download/html-minifier-3.5.21.tgz" + "version" "3.5.21" + dependencies: + "camel-case" "3.0.x" + "clean-css" "4.2.x" + "commander" "2.17.x" + "he" "1.2.x" + "param-case" "2.1.x" + "relateurl" "0.2.x" + "uglify-js" "3.4.x" + +"html-tags@^2.0.0": + "integrity" "sha1-ELMKOGCF9Dzt41PMj6fLDe7qZos=" + "resolved" "https://registry.npm.taobao.org/html-tags/download/html-tags-2.0.0.tgz" + "version" "2.0.0" + +"html-tags@^3.1.0": + "integrity" "sha1-e15vfmZen7QfMAB+2eDUHpf7IUA=" + "resolved" "https://registry.npm.taobao.org/html-tags/download/html-tags-3.1.0.tgz" + "version" "3.1.0" + +"html-webpack-plugin@^3.2.0", "html-webpack-plugin@>=2.26.0": + "integrity" "sha1-sBq71yOsqqeze2r0SS69oD2d03s=" + "resolved" "https://registry.nlark.com/html-webpack-plugin/download/html-webpack-plugin-3.2.0.tgz" + "version" "3.2.0" + dependencies: + "html-minifier" "^3.2.3" + "loader-utils" "^0.2.16" + "lodash" "^4.17.3" + "pretty-error" "^2.0.2" + "tapable" "^1.0.0" + "toposort" "^1.0.0" + "util.promisify" "1.0.0" + +"htmlparser2@^6.1.0": + "integrity" "sha1-xNditsM3GgXb5l6UrkOp+EX7j7c=" + "resolved" "https://registry.npm.taobao.org/htmlparser2/download/htmlparser2-6.1.0.tgz?cache=0&sync_timestamp=1617915295732&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhtmlparser2%2Fdownload%2Fhtmlparser2-6.1.0.tgz" + "version" "6.1.0" + dependencies: + "domelementtype" "^2.0.1" + "domhandler" "^4.0.0" + "domutils" "^2.5.2" + "entities" "^2.0.0" + +"http-deceiver@^1.2.7": + "integrity" "sha1-+nFolEq5pRnTN8sL7HKE3D5yPYc=" + "resolved" "https://registry.npm.taobao.org/http-deceiver/download/http-deceiver-1.2.7.tgz" + "version" "1.2.7" + +"http-errors@~1.6.2": + "integrity" "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=" + "resolved" "https://registry.npm.taobao.org/http-errors/download/http-errors-1.6.3.tgz" + "version" "1.6.3" + dependencies: + "depd" "~1.1.2" + "inherits" "2.0.3" + "setprototypeof" "1.1.0" + "statuses" ">= 1.4.0 < 2" + +"http-errors@~1.7.2", "http-errors@1.7.2": + "integrity" "sha1-T1ApzxMjnzEDblsuVSkrz7zIXI8=" + "resolved" "https://registry.npm.taobao.org/http-errors/download/http-errors-1.7.2.tgz" + "version" "1.7.2" + dependencies: + "depd" "~1.1.2" + "inherits" "2.0.3" + "setprototypeof" "1.1.1" + "statuses" ">= 1.5.0 < 2" + "toidentifier" "1.0.0" + +"http-parser-js@>=0.5.1": + "integrity" "sha1-AdJwnHnUFpi7AdTezF6dpOSgM9k=" + "resolved" "https://registry.npm.taobao.org/http-parser-js/download/http-parser-js-0.5.3.tgz?cache=0&sync_timestamp=1609540073700&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fhttp-parser-js%2Fdownload%2Fhttp-parser-js-0.5.3.tgz" + "version" "0.5.3" + +"http-proxy-agent@^4.0.0", "http-proxy-agent@^4.0.1": + "integrity" "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==" + "resolved" "https://registry.npmmirror.com/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "@tootallnate/once" "1" + "agent-base" "6" + "debug" "4" + +"http-proxy-middleware@^1.0.0": + "integrity" "sha1-Q3ANbZ7st0Gb8IahKND3IF2etmU=" + "resolved" "https://registry.nlark.com/http-proxy-middleware/download/http-proxy-middleware-1.3.1.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fhttp-proxy-middleware%2Fdownload%2Fhttp-proxy-middleware-1.3.1.tgz" + "version" "1.3.1" + dependencies: + "@types/http-proxy" "^1.17.5" + "http-proxy" "^1.18.1" + "is-glob" "^4.0.1" + "is-plain-obj" "^3.0.0" + "micromatch" "^4.0.2" + +"http-proxy-middleware@0.19.1": + "integrity" "sha1-GDx9xKoUeRUDBkmMIQza+WCApDo=" + "resolved" "https://registry.nlark.com/http-proxy-middleware/download/http-proxy-middleware-0.19.1.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fhttp-proxy-middleware%2Fdownload%2Fhttp-proxy-middleware-0.19.1.tgz" + "version" "0.19.1" + dependencies: + "http-proxy" "^1.17.0" + "is-glob" "^4.0.0" + "lodash" "^4.17.11" + "micromatch" "^3.1.10" + +"http-proxy@^1.17.0", "http-proxy@^1.18.1": + "integrity" "sha1-QBVB8FNIhLv5UmAzTnL4juOXZUk=" + "resolved" "https://registry.nlark.com/http-proxy/download/http-proxy-1.18.1.tgz" + "version" "1.18.1" + dependencies: + "eventemitter3" "^4.0.0" + "follow-redirects" "^1.0.0" + "requires-port" "^1.0.0" + +"http-signature@~1.2.0": + "integrity" "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=" + "resolved" "https://registry.nlark.com/http-signature/download/http-signature-1.2.0.tgz" + "version" "1.2.0" + dependencies: + "assert-plus" "^1.0.0" + "jsprim" "^1.2.2" + "sshpk" "^1.7.0" + +"https-browserify@^1.0.0": + "integrity" "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=" + "resolved" "https://registry.npm.taobao.org/https-browserify/download/https-browserify-1.0.0.tgz" + "version" "1.0.0" + +"https-proxy-agent@^5.0.0", "https-proxy-agent@5": + "integrity" "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==" + "resolved" "https://registry.npmmirror.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz" + "version" "5.0.1" + dependencies: + "agent-base" "6" + "debug" "4" + +"human-signals@^1.1.1": + "integrity" "sha1-xbHNFPUK6uCatsWf5jujOV/k36M=" + "resolved" "https://registry.nlark.com/human-signals/download/human-signals-1.1.1.tgz" + "version" "1.1.1" + +"humanize-ms@^1.2.0", "humanize-ms@^1.2.1": + "integrity" "sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ==" + "resolved" "https://registry.npmmirror.com/humanize-ms/-/humanize-ms-1.2.1.tgz" + "version" "1.2.1" + dependencies: + "ms" "^2.0.0" + +"iconv-lite@^0.4.15", "iconv-lite@^0.4.24", "iconv-lite@^0.4.4", "iconv-lite@0.4.24": + "integrity" "sha1-ICK0sl+93CHS9SSXSkdKr+czkIs=" + "resolved" "https://registry.nlark.com/iconv-lite/download/iconv-lite-0.4.24.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ficonv-lite%2Fdownload%2Ficonv-lite-0.4.24.tgz" + "version" "0.4.24" + dependencies: + "safer-buffer" ">= 2.1.2 < 3" + +"icss-utils@^4.0.0", "icss-utils@^4.1.1": + "integrity" "sha1-IRcLU3ie4nRHwvR91oMIFAP5pGc=" + "resolved" "https://registry.npm.taobao.org/icss-utils/download/icss-utils-4.1.1.tgz?cache=0&sync_timestamp=1605801312995&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Ficss-utils%2Fdownload%2Ficss-utils-4.1.1.tgz" + "version" "4.1.1" + dependencies: + "postcss" "^7.0.14" + +"ieee754@^1.1.4": + "integrity" "sha1-jrehCmP/8l0VpXsAFYbRd9Gw01I=" + "resolved" "https://registry.npm.taobao.org/ieee754/download/ieee754-1.2.1.tgz" + "version" "1.2.1" + +"iferr@^0.1.5": + "integrity" "sha1-xg7taebY/bazEEofy8ocGS3FtQE=" + "resolved" "https://registry.npm.taobao.org/iferr/download/iferr-0.1.5.tgz" + "version" "0.1.5" + +"ignore@^3.3.5": + "integrity" "sha1-Cpf7h2mG6AgcYxFg+PnziRV/AEM=" + "resolved" "https://registry.npm.taobao.org/ignore/download/ignore-3.3.10.tgz" + "version" "3.3.10" + +"ignore@^4.0.3", "ignore@^4.0.6": + "integrity" "sha1-dQ49tYYgh7RzfrrIIH/9HvJ7Jfw=" + "resolved" "https://registry.npm.taobao.org/ignore/download/ignore-4.0.6.tgz" + "version" "4.0.6" + +"ignore@^5.1.1": + "integrity" "sha1-8VCotQo0KJsz4i9YiavU2AFvDlc=" + "resolved" "https://registry.npm.taobao.org/ignore/download/ignore-5.1.8.tgz" + "version" "5.1.8" + +"image-size@~0.5.0": + "integrity" "sha1-Cd/Uq50g4p6xw+gLiZA3jfnjy5w=" + "resolved" "https://registry.npm.taobao.org/image-size/download/image-size-0.5.5.tgz?cache=0&sync_timestamp=1618422657851&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fimage-size%2Fdownload%2Fimage-size-0.5.5.tgz" + "version" "0.5.5" + +"import-cwd@^2.0.0": + "integrity" "sha1-qmzzbnInYShcs3HsZRn1PiQ1sKk=" + "resolved" "https://registry.npm.taobao.org/import-cwd/download/import-cwd-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "import-from" "^2.1.0" + +"import-fresh@^2.0.0": + "integrity" "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=" + "resolved" "https://registry.npm.taobao.org/import-fresh/download/import-fresh-2.0.0.tgz?cache=0&sync_timestamp=1608469532269&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fimport-fresh%2Fdownload%2Fimport-fresh-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "caller-path" "^2.0.0" + "resolve-from" "^3.0.0" + +"import-fresh@^3.0.0": + "integrity" "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==" + "resolved" "https://registry.npmmirror.com/import-fresh/-/import-fresh-3.3.0.tgz" + "version" "3.3.0" + dependencies: + "parent-module" "^1.0.0" + "resolve-from" "^4.0.0" + +"import-from@^2.1.0": + "integrity" "sha1-M1238qev/VOqpHHUuAId7ja387E=" + "resolved" "https://registry.nlark.com/import-from/download/import-from-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "resolve-from" "^3.0.0" + +"import-local@^2.0.0": + "integrity" "sha1-VQcL44pZk88Y72236WH1vuXFoJ0=" + "resolved" "https://registry.npm.taobao.org/import-local/download/import-local-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "pkg-dir" "^3.0.0" + "resolve-cwd" "^2.0.0" + +"imurmurhash@^0.1.4": + "integrity" "sha1-khi5srkoojixPcT7a21XbyMUU+o=" + "resolved" "https://registry.npm.taobao.org/imurmurhash/download/imurmurhash-0.1.4.tgz" + "version" "0.1.4" + +"indexes-of@^1.0.1": + "integrity" "sha1-8w9xbI4r00bHtn0985FVZqfAVgc=" + "resolved" "https://registry.npm.taobao.org/indexes-of/download/indexes-of-1.0.1.tgz" + "version" "1.0.1" + +"infer-owner@^1.0.3": + "integrity" "sha1-xM78qo5RBRwqQLos6KPScpWvlGc=" + "resolved" "https://registry.npm.taobao.org/infer-owner/download/infer-owner-1.0.4.tgz" + "version" "1.0.4" + +"inflight@^1.0.4": + "integrity" "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=" + "resolved" "https://registry.nlark.com/inflight/download/inflight-1.0.6.tgz" + "version" "1.0.6" + dependencies: + "once" "^1.3.0" + "wrappy" "1" + +"inherits@^2.0.1", "inherits@^2.0.3", "inherits@^2.0.4", "inherits@~2.0.1", "inherits@~2.0.3", "inherits@2": + "integrity" "sha1-D6LGT5MpF8NDOg3tVTY6rjdBa3w=" + "resolved" "https://registry.npm.taobao.org/inherits/download/inherits-2.0.4.tgz" + "version" "2.0.4" + +"inherits@2.0.1": + "integrity" "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=" + "resolved" "https://registry.npm.taobao.org/inherits/download/inherits-2.0.1.tgz" + "version" "2.0.1" + +"inherits@2.0.3": + "integrity" "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + "resolved" "https://registry.npm.taobao.org/inherits/download/inherits-2.0.3.tgz" + "version" "2.0.3" + +"inquirer@^7.0.0", "inquirer@^7.1.0": + "integrity" "sha1-BNF2sq8Er8FXqD/XwQDpjuCq0AM=" + "resolved" "https://registry.nlark.com/inquirer/download/inquirer-7.3.3.tgz?cache=0&sync_timestamp=1623781150792&other_urls=https%3A%2F%2Fregistry.nlark.com%2Finquirer%2Fdownload%2Finquirer-7.3.3.tgz" + "version" "7.3.3" + dependencies: + "ansi-escapes" "^4.2.1" + "chalk" "^4.1.0" + "cli-cursor" "^3.1.0" + "cli-width" "^3.0.0" + "external-editor" "^3.0.3" + "figures" "^3.0.0" + "lodash" "^4.17.19" + "mute-stream" "0.0.8" + "run-async" "^2.4.0" + "rxjs" "^6.6.0" + "string-width" "^4.1.0" + "strip-ansi" "^6.0.0" + "through" "^2.3.6" + +"internal-ip@^4.3.0": + "integrity" "sha1-hFRSuq2dLKO2nGNaE3rLmg2tCQc=" + "resolved" "https://registry.npm.taobao.org/internal-ip/download/internal-ip-4.3.0.tgz" + "version" "4.3.0" + dependencies: + "default-gateway" "^4.2.0" + "ipaddr.js" "^1.9.0" + +"interpret@^1.2.0": + "integrity" "sha1-Zlq4vE2iendKQFhOgS4+D6RbGh4=" + "resolved" "https://registry.npm.taobao.org/interpret/download/interpret-1.4.0.tgz" + "version" "1.4.0" + +"ip-regex@^2.1.0": + "integrity" "sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk=" + "resolved" "https://registry.npm.taobao.org/ip-regex/download/ip-regex-2.1.0.tgz" + "version" "2.1.0" + +"ip@^1.1.0", "ip@^1.1.5": + "integrity" "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=" + "resolved" "https://registry.nlark.com/ip/download/ip-1.1.5.tgz" + "version" "1.1.5" + +"ip@^2.0.0": + "integrity" "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" + "resolved" "https://registry.npmmirror.com/ip/-/ip-2.0.0.tgz" + "version" "2.0.0" + +"ipaddr.js@^1.9.0", "ipaddr.js@1.9.1": + "integrity" "sha1-v/OFQ+64mEglB5/zoqjmy9RngbM=" + "resolved" "https://registry.nlark.com/ipaddr.js/download/ipaddr.js-1.9.1.tgz" + "version" "1.9.1" + +"is-absolute-url@^2.0.0": + "integrity" "sha1-UFMN+4T8yap9vnhS6Do3uTufKqY=" + "resolved" "https://registry.npm.taobao.org/is-absolute-url/download/is-absolute-url-2.1.0.tgz" + "version" "2.1.0" + +"is-absolute-url@^3.0.3": + "integrity" "sha1-lsaiK2ojkpsR6gr7GDbDatSl1pg=" + "resolved" "https://registry.npm.taobao.org/is-absolute-url/download/is-absolute-url-3.0.3.tgz" + "version" "3.0.3" + +"is-accessor-descriptor@^0.1.6": + "integrity" "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=" + "resolved" "https://registry.npm.taobao.org/is-accessor-descriptor/download/is-accessor-descriptor-0.1.6.tgz" + "version" "0.1.6" + dependencies: + "kind-of" "^3.0.2" + +"is-accessor-descriptor@^1.0.0": + "integrity" "sha1-FpwvbT3x+ZJhgHI2XJsOofaHhlY=" + "resolved" "https://registry.npm.taobao.org/is-accessor-descriptor/download/is-accessor-descriptor-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "kind-of" "^6.0.0" + +"is-arguments@^1.0.4": + "integrity" "sha1-YjUwMd++4HzrNGVqa95Z7+yujdk=" + "resolved" "https://registry.npm.taobao.org/is-arguments/download/is-arguments-1.1.0.tgz?cache=0&sync_timestamp=1607117404740&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-arguments%2Fdownload%2Fis-arguments-1.1.0.tgz" + "version" "1.1.0" + dependencies: + "call-bind" "^1.0.0" + +"is-arrayish@^0.2.1": + "integrity" "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" + "resolved" "https://registry.nlark.com/is-arrayish/download/is-arrayish-0.2.1.tgz" + "version" "0.2.1" + +"is-arrayish@^0.3.1": + "integrity" "sha1-RXSirlb3qyBolvtDHq7tBm/fjwM=" + "resolved" "https://registry.nlark.com/is-arrayish/download/is-arrayish-0.3.2.tgz" + "version" "0.3.2" + +"is-bigint@^1.0.1": + "integrity" "sha1-/7OBRCUDI1rSReqJ5Fs9v/BA7lo=" + "resolved" "https://registry.nlark.com/is-bigint/download/is-bigint-1.0.2.tgz" + "version" "1.0.2" + +"is-binary-path@^1.0.0": + "integrity" "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=" + "resolved" "https://registry.nlark.com/is-binary-path/download/is-binary-path-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "binary-extensions" "^1.0.0" + +"is-binary-path@~2.1.0": + "integrity" "sha1-6h9/O4DwZCNug0cPhsCcJU+0Wwk=" + "resolved" "https://registry.nlark.com/is-binary-path/download/is-binary-path-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "binary-extensions" "^2.0.0" + +"is-boolean-object@^1.1.0": + "integrity" "sha1-PAh48DXLghIo01DS4eNnGXFqPeg=" + "resolved" "https://registry.nlark.com/is-boolean-object/download/is-boolean-object-1.1.1.tgz?cache=0&sync_timestamp=1620428521406&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-boolean-object%2Fdownload%2Fis-boolean-object-1.1.1.tgz" + "version" "1.1.1" + dependencies: + "call-bind" "^1.0.2" + +"is-buffer@^1.1.5": + "integrity" "sha1-76ouqdqg16suoTqXsritUf776L4=" + "resolved" "https://registry.npm.taobao.org/is-buffer/download/is-buffer-1.1.6.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-1.1.6.tgz" + "version" "1.1.6" + +"is-buffer@~2.0.3": + "integrity" "sha1-68JS5ADSL/jXf6CYiIIaJKZYwZE=" + "resolved" "https://registry.npm.taobao.org/is-buffer/download/is-buffer-2.0.5.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-buffer%2Fdownload%2Fis-buffer-2.0.5.tgz" + "version" "2.0.5" + +"is-callable@^1.1.4", "is-callable@^1.2.3": + "integrity" "sha1-ix4FALc6HXbHBIdjbzaOUZ3o244=" + "resolved" "https://registry.npm.taobao.org/is-callable/download/is-callable-1.2.3.tgz" + "version" "1.2.3" + +"is-ci@^1.0.10": + "integrity" "sha1-43ecjuF/zPQoSI9uKBGH8uYyhBw=" + "resolved" "https://registry.npm.taobao.org/is-ci/download/is-ci-1.2.1.tgz?cache=0&sync_timestamp=1613632097993&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-ci%2Fdownload%2Fis-ci-1.2.1.tgz" + "version" "1.2.1" + dependencies: + "ci-info" "^1.5.0" + +"is-class-hotfix@~0.0.6": + "integrity" "sha512-0n+pzCC6ICtVr/WXnN2f03TK/3BfXY7me4cjCAqT8TYXEl0+JBRoqBo94JJHXcyDSLUeWbNX8Fvy5g5RJdAstQ==" + "resolved" "https://registry.npmmirror.com/is-class-hotfix/-/is-class-hotfix-0.0.6.tgz" + "version" "0.0.6" + +"is-color-stop@^1.0.0": + "integrity" "sha1-z/9HGu5N1cnhWFmPvhKWe1za00U=" + "resolved" "https://registry.npm.taobao.org/is-color-stop/download/is-color-stop-1.1.0.tgz" + "version" "1.1.0" + dependencies: + "css-color-names" "^0.0.4" + "hex-color-regex" "^1.1.0" + "hsl-regex" "^1.0.0" + "hsla-regex" "^1.0.0" + "rgb-regex" "^1.0.1" + "rgba-regex" "^1.0.0" + +"is-core-module@^2.2.0": + "integrity" "sha1-91SENhfHC/0pt72HMnQAzaXBhJE=" + "resolved" "https://registry.nlark.com/is-core-module/download/is-core-module-2.5.0.tgz?cache=0&sync_timestamp=1626158736739&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-core-module%2Fdownload%2Fis-core-module-2.5.0.tgz" + "version" "2.5.0" + dependencies: + "has" "^1.0.3" + +"is-data-descriptor@^0.1.4": + "integrity" "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=" + "resolved" "https://registry.nlark.com/is-data-descriptor/download/is-data-descriptor-0.1.4.tgz" + "version" "0.1.4" + dependencies: + "kind-of" "^3.0.2" + +"is-data-descriptor@^1.0.0": + "integrity" "sha1-2Eh2Mh0Oet0DmQQGq7u9NrqSaMc=" + "resolved" "https://registry.nlark.com/is-data-descriptor/download/is-data-descriptor-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "kind-of" "^6.0.0" + +"is-date-object@^1.0.1": + "integrity" "sha1-VQz8wDr62gXuo90wmBx7CVUfc+U=" + "resolved" "https://registry.nlark.com/is-date-object/download/is-date-object-1.0.4.tgz" + "version" "1.0.4" + +"is-descriptor@^0.1.0": + "integrity" "sha1-Nm2CQN3kh8pRgjsaufB6EKeCUco=" + "resolved" "https://registry.npm.taobao.org/is-descriptor/download/is-descriptor-0.1.6.tgz" + "version" "0.1.6" + dependencies: + "is-accessor-descriptor" "^0.1.6" + "is-data-descriptor" "^0.1.4" + "kind-of" "^5.0.0" + +"is-descriptor@^1.0.0", "is-descriptor@^1.0.2": + "integrity" "sha1-OxWXRqZmBLBPjIFSS6NlxfFNhuw=" + "resolved" "https://registry.npm.taobao.org/is-descriptor/download/is-descriptor-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "is-accessor-descriptor" "^1.0.0" + "is-data-descriptor" "^1.0.0" + "kind-of" "^6.0.2" + +"is-directory@^0.3.1": + "integrity" "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=" + "resolved" "https://registry.npm.taobao.org/is-directory/download/is-directory-0.3.1.tgz" + "version" "0.3.1" + +"is-docker@^2.0.0": + "integrity" "sha1-M+6r4jz+hvFL3kQIoCwM+4U6zao=" + "resolved" "https://registry.npm.taobao.org/is-docker/download/is-docker-2.2.1.tgz?cache=0&sync_timestamp=1617958823824&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-docker%2Fdownload%2Fis-docker-2.2.1.tgz" + "version" "2.2.1" + +"is-extendable@^0.1.0", "is-extendable@^0.1.1": + "integrity" "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" + "resolved" "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz" + "version" "0.1.1" + +"is-extendable@^0.1.1": + "integrity" "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" + "resolved" "https://registry.nlark.com/is-extendable/download/is-extendable-0.1.1.tgz" + "version" "0.1.1" + +"is-extendable@^1.0.1": + "integrity" "sha1-p0cPnkJnM9gb2B4RVSZOOjUHyrQ=" + "resolved" "https://registry.nlark.com/is-extendable/download/is-extendable-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "is-plain-object" "^2.0.4" + +"is-extglob@^2.1.0", "is-extglob@^2.1.1": + "integrity" "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" + "resolved" "https://registry.npm.taobao.org/is-extglob/download/is-extglob-2.1.1.tgz" + "version" "2.1.1" + +"is-fullwidth-code-point@^2.0.0": + "integrity" "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + "resolved" "https://registry.npm.taobao.org/is-fullwidth-code-point/download/is-fullwidth-code-point-2.0.0.tgz?cache=0&sync_timestamp=1618552469710&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-fullwidth-code-point%2Fdownload%2Fis-fullwidth-code-point-2.0.0.tgz" + "version" "2.0.0" + +"is-fullwidth-code-point@^3.0.0": + "integrity" "sha1-8Rb4Bk/pCz94RKOJl8C3UFEmnx0=" + "resolved" "https://registry.npm.taobao.org/is-fullwidth-code-point/download/is-fullwidth-code-point-3.0.0.tgz?cache=0&sync_timestamp=1618552469710&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-fullwidth-code-point%2Fdownload%2Fis-fullwidth-code-point-3.0.0.tgz" + "version" "3.0.0" + +"is-glob@^3.1.0": + "integrity" "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=" + "resolved" "https://registry.nlark.com/is-glob/download/is-glob-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "is-extglob" "^2.1.0" + +"is-glob@^4.0.0", "is-glob@^4.0.1", "is-glob@~4.0.1": + "integrity" "sha1-dWfb6fL14kZ7x3q4PEopSCQHpdw=" + "resolved" "https://registry.nlark.com/is-glob/download/is-glob-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "is-extglob" "^2.1.1" + +"is-negative-zero@^2.0.1": + "integrity" "sha1-PedGwY3aIxkkGlNnWQjY92bxHCQ=" + "resolved" "https://registry.nlark.com/is-negative-zero/download/is-negative-zero-2.0.1.tgz" + "version" "2.0.1" + +"is-number-object@^1.0.4": + "integrity" "sha1-bt+u7XlQz/Ga/tzp+/yp7m3Sies=" + "resolved" "https://registry.nlark.com/is-number-object/download/is-number-object-1.0.5.tgz?cache=0&sync_timestamp=1620421575334&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-number-object%2Fdownload%2Fis-number-object-1.0.5.tgz" + "version" "1.0.5" + +"is-number@^3.0.0": + "integrity" "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=" + "resolved" "https://registry.npm.taobao.org/is-number/download/is-number-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "kind-of" "^3.0.2" + +"is-number@^7.0.0": + "integrity" "sha1-dTU0W4lnNNX4DE0GxQlVUnoU8Ss=" + "resolved" "https://registry.npm.taobao.org/is-number/download/is-number-7.0.0.tgz" + "version" "7.0.0" + +"is-obj@^2.0.0": + "integrity" "sha1-Rz+wXZc3BeP9liBUUBjKjiLvSYI=" + "resolved" "https://registry.nlark.com/is-obj/download/is-obj-2.0.0.tgz" + "version" "2.0.0" + +"is-path-cwd@^2.0.0": + "integrity" "sha1-Z9Q7gmZKe1GR/ZEZEn6zAASKn9s=" + "resolved" "https://registry.npm.taobao.org/is-path-cwd/download/is-path-cwd-2.2.0.tgz" + "version" "2.2.0" + +"is-path-in-cwd@^2.0.0": + "integrity" "sha1-v+Lcomxp85cmWkAJljYCk1oFOss=" + "resolved" "https://registry.nlark.com/is-path-in-cwd/download/is-path-in-cwd-2.1.0.tgz?cache=0&sync_timestamp=1620047110449&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-path-in-cwd%2Fdownload%2Fis-path-in-cwd-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "is-path-inside" "^2.1.0" + +"is-path-inside@^2.1.0": + "integrity" "sha1-fJgQWH1lmkDSe8201WFuqwWUlLI=" + "resolved" "https://registry.nlark.com/is-path-inside/download/is-path-inside-2.1.0.tgz?cache=0&sync_timestamp=1620046845369&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-path-inside%2Fdownload%2Fis-path-inside-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "path-is-inside" "^1.0.2" + +"is-plain-obj@^1.0.0": + "integrity" "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=" + "resolved" "https://registry.npm.taobao.org/is-plain-obj/download/is-plain-obj-1.1.0.tgz?cache=0&sync_timestamp=1618600554597&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-plain-obj%2Fdownload%2Fis-plain-obj-1.1.0.tgz" + "version" "1.1.0" + +"is-plain-obj@^3.0.0": + "integrity" "sha1-r28uoUrFpkYYOlu9tbqrvBVq2dc=" + "resolved" "https://registry.npm.taobao.org/is-plain-obj/download/is-plain-obj-3.0.0.tgz?cache=0&sync_timestamp=1618600554597&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-plain-obj%2Fdownload%2Fis-plain-obj-3.0.0.tgz" + "version" "3.0.0" + +"is-plain-object@^2.0.3", "is-plain-object@^2.0.4": + "integrity" "sha1-LBY7P6+xtgbZ0Xko8FwqHDjgdnc=" + "resolved" "https://registry.npm.taobao.org/is-plain-object/download/is-plain-object-2.0.4.tgz" + "version" "2.0.4" + dependencies: + "isobject" "^3.0.1" + +"is-regex@^1.0.4", "is-regex@^1.1.3": + "integrity" "sha1-0Cn5r/ZEi5Prvj8z2scVEf3L758=" + "resolved" "https://registry.nlark.com/is-regex/download/is-regex-1.1.3.tgz" + "version" "1.1.3" + dependencies: + "call-bind" "^1.0.2" + "has-symbols" "^1.0.2" + +"is-resolvable@^1.0.0": + "integrity" "sha1-+xj4fOH+uSUWnJpAfBkxijIG7Yg=" + "resolved" "https://registry.npm.taobao.org/is-resolvable/download/is-resolvable-1.1.0.tgz" + "version" "1.1.0" + +"is-stream@^1.1.0": + "integrity" "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" + "resolved" "https://registry.npm.taobao.org/is-stream/download/is-stream-1.1.0.tgz" + "version" "1.1.0" + +"is-stream@^2.0.0": + "integrity" "sha1-venDJoDW+uBBKdasnZIc54FfeOM=" + "resolved" "https://registry.npm.taobao.org/is-stream/download/is-stream-2.0.0.tgz" + "version" "2.0.0" + +"is-string@^1.0.5", "is-string@^1.0.6": + "integrity" "sha1-P+XVmS+w2TQE8yWE1LAXmnG1Sl8=" + "resolved" "https://registry.nlark.com/is-string/download/is-string-1.0.6.tgz?cache=0&sync_timestamp=1620448217105&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-string%2Fdownload%2Fis-string-1.0.6.tgz" + "version" "1.0.6" + +"is-symbol@^1.0.2", "is-symbol@^1.0.3": + "integrity" "sha1-ptrJO2NbBjymhyI23oiRClevE5w=" + "resolved" "https://registry.nlark.com/is-symbol/download/is-symbol-1.0.4.tgz?cache=0&sync_timestamp=1620502244179&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fis-symbol%2Fdownload%2Fis-symbol-1.0.4.tgz" + "version" "1.0.4" + dependencies: + "has-symbols" "^1.0.2" + +"is-type-of@^1.0.0": + "integrity" "sha512-uK0kyX9LZYhSDS7H2sVJQJop1UnWPWmo5RvR3q2kFH6AUHYs7sOrVg0b4nyBHw29kRRNFofYN/JbHZDlHiItTA==" + "resolved" "https://registry.npmmirror.com/is-type-of/-/is-type-of-1.2.1.tgz" + "version" "1.2.1" + dependencies: + "core-util-is" "^1.0.2" + "is-class-hotfix" "~0.0.6" + "isstream" "~0.1.2" + +"is-typedarray@~1.0.0": + "integrity" "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" + "resolved" "https://registry.npm.taobao.org/is-typedarray/download/is-typedarray-1.0.0.tgz" + "version" "1.0.0" + +"is-what@^3.12.0": + "integrity" "sha1-4SIvRt3ahd6tD9HJ3xMXYOd3VcE=" + "resolved" "https://registry.npm.taobao.org/is-what/download/is-what-3.14.1.tgz?cache=0&sync_timestamp=1615169735707&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fis-what%2Fdownload%2Fis-what-3.14.1.tgz" + "version" "3.14.1" + +"is-windows@^1.0.2": + "integrity" "sha1-0YUOuXkezRjmGCzhKjDzlmNLsZ0=" + "resolved" "https://registry.npm.taobao.org/is-windows/download/is-windows-1.0.2.tgz" + "version" "1.0.2" + +"is-wsl@^1.1.0": + "integrity" "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=" + "resolved" "https://registry.npm.taobao.org/is-wsl/download/is-wsl-1.1.0.tgz" + "version" "1.1.0" + +"is-wsl@^2.1.1": + "integrity" "sha1-dKTHbnfKn9P5MvKQwX6jJs0VcnE=" + "resolved" "https://registry.npm.taobao.org/is-wsl/download/is-wsl-2.2.0.tgz" + "version" "2.2.0" + dependencies: + "is-docker" "^2.0.0" + +"isarray@^1.0.0", "isarray@~1.0.0", "isarray@1.0.0": + "integrity" "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" + "resolved" "https://registry.npm.taobao.org/isarray/download/isarray-1.0.0.tgz" + "version" "1.0.0" + +"isarray@0.0.1": + "integrity" "sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ==" + "resolved" "https://registry.npmmirror.com/isarray/-/isarray-0.0.1.tgz" + "version" "0.0.1" + +"isexe@^2.0.0": + "integrity" "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" + "resolved" "https://registry.npm.taobao.org/isexe/download/isexe-2.0.0.tgz" + "version" "2.0.0" + +"isobject@^2.0.0": + "integrity" "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=" + "resolved" "https://registry.nlark.com/isobject/download/isobject-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "isarray" "1.0.0" + +"isobject@^3.0.0", "isobject@^3.0.1": + "integrity" "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + "resolved" "https://registry.nlark.com/isobject/download/isobject-3.0.1.tgz" + "version" "3.0.1" + +"isstream@~0.1.2": + "integrity" "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" + "resolved" "https://registry.npm.taobao.org/isstream/download/isstream-0.1.2.tgz" + "version" "0.1.2" + +"javascript-stringify@^2.0.1": + "integrity" "sha1-J8dlOb4U2L0Sghmi1zGwkzeQTnk=" + "resolved" "https://registry.nlark.com/javascript-stringify/download/javascript-stringify-2.1.0.tgz" + "version" "2.1.0" + +"js-base64@^2.5.2": + "integrity" "sha512-pZe//GGmwJndub7ZghVHz7vjb2LgC1m8B07Au3eYqeqv9emhESByMXxaEgkUkEqJe87oBbSniGYoQNIBklc7IQ==" + "resolved" "https://registry.npmmirror.com/js-base64/-/js-base64-2.6.4.tgz" + "version" "2.6.4" + +"js-message@1.0.7": + "integrity" "sha512-efJLHhLjIyKRewNS9EGZ4UpI8NguuL6fKkhRxVuMmrGV2xN/0APGdQYwLFky5w9naebSZ0OwAGp0G6/2Cg90rA==" + "resolved" "https://registry.npmmirror.com/js-message/-/js-message-1.0.7.tgz" + "version" "1.0.7" + +"js-tokens@^4.0.0": + "integrity" "sha1-GSA/tZmR35jjoocFDUZHzerzJJk=" + "resolved" "https://registry.nlark.com/js-tokens/download/js-tokens-4.0.0.tgz?cache=0&sync_timestamp=1619345098261&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fjs-tokens%2Fdownload%2Fjs-tokens-4.0.0.tgz" + "version" "4.0.0" + +"js-yaml@^3.13.1", "js-yaml@3.13.1": + "integrity" "sha1-r/FRswv9+o5J4F2iLnQV6d+jeEc=" + "resolved" "https://registry.npm.taobao.org/js-yaml/download/js-yaml-3.13.1.tgz?cache=0&sync_timestamp=1618435151523&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjs-yaml%2Fdownload%2Fjs-yaml-3.13.1.tgz" + "version" "3.13.1" + dependencies: + "argparse" "^1.0.7" + "esprima" "^4.0.0" + +"jsbn@~0.1.0": + "integrity" "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" + "resolved" "https://registry.nlark.com/jsbn/download/jsbn-0.1.1.tgz" + "version" "0.1.1" + +"jsdom-global@^3.0.2": + "integrity" "sha1-a9KZwTsMRiay2iwDk81DhdYGrLk=" + "resolved" "https://registry.npm.taobao.org/jsdom-global/download/jsdom-global-3.0.2.tgz" + "version" "3.0.2" + +"jsdom@^15.2.1", "jsdom@>=10.0.0": + "integrity" "sha1-0v6xrvcYP4a+UhuMaDP/UpbQfsU=" + "resolved" "https://registry.nlark.com/jsdom/download/jsdom-15.2.1.tgz" + "version" "15.2.1" + dependencies: + "abab" "^2.0.0" + "acorn" "^7.1.0" + "acorn-globals" "^4.3.2" + "array-equal" "^1.0.0" + "cssom" "^0.4.1" + "cssstyle" "^2.0.0" + "data-urls" "^1.1.0" + "domexception" "^1.0.1" + "escodegen" "^1.11.1" + "html-encoding-sniffer" "^1.0.2" + "nwsapi" "^2.2.0" + "parse5" "5.1.0" + "pn" "^1.1.0" + "request" "^2.88.0" + "request-promise-native" "^1.0.7" + "saxes" "^3.1.9" + "symbol-tree" "^3.2.2" + "tough-cookie" "^3.0.1" + "w3c-hr-time" "^1.0.1" + "w3c-xmlserializer" "^1.1.2" + "webidl-conversions" "^4.0.2" + "whatwg-encoding" "^1.0.5" + "whatwg-mimetype" "^2.3.0" + "whatwg-url" "^7.0.0" + "ws" "^7.0.0" + "xml-name-validator" "^3.0.0" + +"jsesc@^2.5.1": + "integrity" "sha1-gFZNLkg9rPbo7yCWUKZ98/DCg6Q=" + "resolved" "https://registry.npm.taobao.org/jsesc/download/jsesc-2.5.2.tgz?cache=0&sync_timestamp=1603891242793&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjsesc%2Fdownload%2Fjsesc-2.5.2.tgz" + "version" "2.5.2" + +"jsesc@~0.5.0": + "integrity" "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=" + "resolved" "https://registry.npm.taobao.org/jsesc/download/jsesc-0.5.0.tgz?cache=0&sync_timestamp=1603891242793&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjsesc%2Fdownload%2Fjsesc-0.5.0.tgz" + "version" "0.5.0" + +"json-parse-better-errors@^1.0.1", "json-parse-better-errors@^1.0.2": + "integrity" "sha1-u4Z8+zRQ5pEHwTHRxRS6s9yLyqk=" + "resolved" "https://registry.nlark.com/json-parse-better-errors/download/json-parse-better-errors-1.0.2.tgz" + "version" "1.0.2" + +"json-parse-even-better-errors@^2.3.0": + "integrity" "sha1-fEeAWpQxmSjgV3dAXcEuH3pO4C0=" + "resolved" "https://registry.npm.taobao.org/json-parse-even-better-errors/download/json-parse-even-better-errors-2.3.1.tgz" + "version" "2.3.1" + +"json-schema-traverse@^0.4.1": + "integrity" "sha1-afaofZUTq4u4/mO9sJecRI5oRmA=" + "resolved" "https://registry.nlark.com/json-schema-traverse/download/json-schema-traverse-0.4.1.tgz" + "version" "0.4.1" + +"json-schema@0.2.3": + "integrity" "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" + "resolved" "https://registry.npm.taobao.org/json-schema/download/json-schema-0.2.3.tgz" + "version" "0.2.3" + +"json-stable-stringify-without-jsonify@^1.0.1": + "integrity" "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==" + "resolved" "https://registry.npmmirror.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz" + "version" "1.0.1" + +"json-stringify-safe@~5.0.1": + "integrity" "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" + "resolved" "https://registry.nlark.com/json-stringify-safe/download/json-stringify-safe-5.0.1.tgz" + "version" "5.0.1" + +"json3@^3.3.3": + "integrity" "sha1-f8EON1/FrkLEcFpcwKpvYr4wW4E=" + "resolved" "https://registry.nlark.com/json3/download/json3-3.3.3.tgz" + "version" "3.3.3" + +"json5@^0.5.0": + "integrity" "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=" + "resolved" "https://registry.nlark.com/json5/download/json5-0.5.1.tgz" + "version" "0.5.1" + +"json5@^1.0.1": + "integrity" "sha1-d5+wAYYE+oVOrL9iUhgNg1Q+Pb4=" + "resolved" "https://registry.nlark.com/json5/download/json5-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "minimist" "^1.2.0" + +"json5@^2.1.2": + "integrity" "sha1-Lf7+cgxrpSXZ69kJlQ8FFTFsiaM=" + "resolved" "https://registry.nlark.com/json5/download/json5-2.2.0.tgz" + "version" "2.2.0" + dependencies: + "minimist" "^1.2.5" + +"jsonfile@^4.0.0": + "integrity" "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=" + "resolved" "https://registry.npm.taobao.org/jsonfile/download/jsonfile-4.0.0.tgz?cache=0&sync_timestamp=1604161937969&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjsonfile%2Fdownload%2Fjsonfile-4.0.0.tgz" + "version" "4.0.0" + optionalDependencies: + "graceful-fs" "^4.1.6" + +"jsprim@^1.2.2": + "integrity" "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=" + "resolved" "https://registry.npm.taobao.org/jsprim/download/jsprim-1.4.1.tgz" + "version" "1.4.1" + dependencies: + "assert-plus" "1.0.0" + "extsprintf" "1.3.0" + "json-schema" "0.2.3" + "verror" "1.10.0" + +"jstoxml@^2.0.0": + "integrity" "sha512-OYWlK0j+roh+eyaMROlNbS5cd5R25Y+IUpdl7cNdB8HNrkgwQzIS7L9MegxOiWNBj9dQhA/yAxiMwCC5mwNoBw==" + "resolved" "https://registry.npmmirror.com/jstoxml/-/jstoxml-2.2.9.tgz" + "version" "2.2.9" + +"killable@^1.0.1": + "integrity" "sha1-TIzkQRh6Bhx0dPuHygjipjgZSJI=" + "resolved" "https://registry.nlark.com/killable/download/killable-1.0.1.tgz" + "version" "1.0.1" + +"kind-of@^3.0.2", "kind-of@^3.0.3": + "integrity" "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=" + "resolved" "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz" + "version" "3.2.2" + dependencies: + "is-buffer" "^1.1.5" + +"kind-of@^3.2.0": + "integrity" "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=" + "resolved" "https://registry.npm.taobao.org/kind-of/download/kind-of-3.2.2.tgz" + "version" "3.2.2" + dependencies: + "is-buffer" "^1.1.5" + +"kind-of@^4.0.0": + "integrity" "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=" + "resolved" "https://registry.npm.taobao.org/kind-of/download/kind-of-4.0.0.tgz" + "version" "4.0.0" + dependencies: + "is-buffer" "^1.1.5" + +"kind-of@^5.0.0": + "integrity" "sha1-cpyR4thXt6QZofmqZWhcTDP1hF0=" + "resolved" "https://registry.npm.taobao.org/kind-of/download/kind-of-5.1.0.tgz" + "version" "5.1.0" + +"kind-of@^6.0.0", "kind-of@^6.0.2": + "integrity" "sha1-B8BQNKbDSfoG4k+jWqdttFgM5N0=" + "resolved" "https://registry.npm.taobao.org/kind-of/download/kind-of-6.0.3.tgz" + "version" "6.0.3" + +"klona@^2.0.4": + "integrity" "sha1-e7Hjr/sMuGJFR+9+j2cI6i4538A=" + "resolved" "https://registry.npm.taobao.org/klona/download/klona-2.0.4.tgz" + "version" "2.0.4" + +"ko-sleep@^1.0.3": + "integrity" "sha512-s05WGpvvzyTuRlRE8fM7ru2Z3O+InbJuBcckTWKg2W+2c1k6SnFa3IfiSSt0/peFrlYAXgNoxuJWWVNmWh+K/A==" + "resolved" "https://registry.npmmirror.com/ko-sleep/-/ko-sleep-1.1.4.tgz" + "version" "1.1.4" + dependencies: + "ms" "*" + +"launch-editor-middleware@^2.2.1": + "integrity" "sha1-4UsH5scVSwpLhqD9NFeE5FgEwVc=" + "resolved" "https://registry.nlark.com/launch-editor-middleware/download/launch-editor-middleware-2.2.1.tgz" + "version" "2.2.1" + dependencies: + "launch-editor" "^2.2.1" + +"launch-editor@^2.2.1": + "integrity" "sha1-hxtaPuOdZoD8wm03kwtu7aidsMo=" + "resolved" "https://registry.npm.taobao.org/launch-editor/download/launch-editor-2.2.1.tgz" + "version" "2.2.1" + dependencies: + "chalk" "^2.3.0" + "shell-quote" "^1.6.1" + +"less-loader@^7.3.0": + "integrity" "sha1-+dbTbRhznWQgZ6Bftb1wyMYTF+U=" + "resolved" "https://registry.nlark.com/less-loader/download/less-loader-7.3.0.tgz" + "version" "7.3.0" + dependencies: + "klona" "^2.0.4" + "loader-utils" "^2.0.0" + "schema-utils" "^3.0.0" + +"less@^3.5.0 || ^4.0.0", "less@^4.1.1": + "integrity" "sha1-Fb8lOpk5eR3GkIiMP/Qk8+bH7bo=" + "resolved" "https://registry.npm.taobao.org/less/download/less-4.1.1.tgz?cache=0&sync_timestamp=1612065808998&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fless%2Fdownload%2Fless-4.1.1.tgz" + "version" "4.1.1" + dependencies: + "copy-anything" "^2.0.1" + "parse-node-version" "^1.0.1" + "tslib" "^1.10.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" "^2.5.2" + "source-map" "~0.6.0" + +"levn@^0.3.0", "levn@~0.3.0": + "integrity" "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=" + "resolved" "https://registry.npm.taobao.org/levn/download/levn-0.3.0.tgz" + "version" "0.3.0" + dependencies: + "prelude-ls" "~1.1.2" + "type-check" "~0.3.2" + +"lines-and-columns@^1.1.6": + "integrity" "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=" + "resolved" "https://registry.npm.taobao.org/lines-and-columns/download/lines-and-columns-1.1.6.tgz" + "version" "1.1.6" + +"loader-fs-cache@^1.0.0": + "integrity" "sha1-8IZXZG1gcHi+LwoDL4vWndbyd9k=" + "resolved" "https://registry.nlark.com/loader-fs-cache/download/loader-fs-cache-1.0.3.tgz" + "version" "1.0.3" + dependencies: + "find-cache-dir" "^0.1.1" + "mkdirp" "^0.5.1" + +"loader-runner@^2.3.1", "loader-runner@^2.4.0": + "integrity" "sha1-7UcGa/5TTX6ExMe5mYwqdWB9k1c=" + "resolved" "https://registry.nlark.com/loader-runner/download/loader-runner-2.4.0.tgz" + "version" "2.4.0" + +"loader-utils@^0.2.16": + "integrity" "sha1-+G5jdNQyBabmxg6RlvF8Apm/s0g=" + "resolved" "https://registry.npm.taobao.org/loader-utils/download/loader-utils-0.2.17.tgz" + "version" "0.2.17" + dependencies: + "big.js" "^3.1.3" + "emojis-list" "^2.0.0" + "json5" "^0.5.0" + "object-assign" "^4.0.1" + +"loader-utils@^1.0.2", "loader-utils@^1.1.0", "loader-utils@^1.2.3", "loader-utils@^1.4.0": + "integrity" "sha1-xXm140yzSxp07cbB+za/o3HVphM=" + "resolved" "https://registry.npm.taobao.org/loader-utils/download/loader-utils-1.4.0.tgz" + "version" "1.4.0" + dependencies: + "big.js" "^5.2.2" + "emojis-list" "^3.0.0" + "json5" "^1.0.1" + +"loader-utils@^2.0.0": + "integrity" "sha512-TM57VeHptv569d/GKh6TAYdzKblwDNiumOdkFnejjD0XwTH87K90w3O7AiJRqdQoXygvi1VQTJTLGhJl7WqA7A==" + "resolved" "https://registry.npmmirror.com/loader-utils/-/loader-utils-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "big.js" "^5.2.2" + "emojis-list" "^3.0.0" + "json5" "^2.1.2" + +"locate-path@^3.0.0": + "integrity" "sha1-2+w7OrdZdYBxtY/ln8QYca8hQA4=" + "resolved" "https://registry.nlark.com/locate-path/download/locate-path-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "p-locate" "^3.0.0" + "path-exists" "^3.0.0" + +"locate-path@^5.0.0": + "integrity" "sha1-Gvujlq/WdqbUJQTQpno6frn2KqA=" + "resolved" "https://registry.nlark.com/locate-path/download/locate-path-5.0.0.tgz" + "version" "5.0.0" + dependencies: + "p-locate" "^4.1.0" + +"lodash-es@*", "lodash-es@^4.17.21": + "integrity" "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==" + "resolved" "https://registry.npmmirror.com/lodash-es/-/lodash-es-4.17.21.tgz" + "version" "4.17.21" + +"lodash-unified@^1.0.2": + "integrity" "sha512-OGbEy+1P+UT26CYi4opY4gebD8cWRDxAT6MAObIVQMiqYdxZr1g3QHWCToVsm31x2NkLS4K3+MC2qInaRMa39g==" + "resolved" "https://registry.npmmirror.com/lodash-unified/-/lodash-unified-1.0.2.tgz" + "version" "1.0.2" + +"lodash.clonedeep@^4.5.0": + "integrity" "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=" + "resolved" "https://registry.npm.taobao.org/lodash.clonedeep/download/lodash.clonedeep-4.5.0.tgz" + "version" "4.5.0" + +"lodash.debounce@^4.0.8": + "integrity" "sha1-gteb/zCmfEAF/9XiUVMArZyk168=" + "resolved" "https://registry.npm.taobao.org/lodash.debounce/download/lodash.debounce-4.0.8.tgz" + "version" "4.0.8" + +"lodash.defaultsdeep@^4.6.1": + "integrity" "sha1-US6b1yHSctlOPTpjZT+hdRZ0HKY=" + "resolved" "https://registry.npm.taobao.org/lodash.defaultsdeep/download/lodash.defaultsdeep-4.6.1.tgz" + "version" "4.6.1" + +"lodash.kebabcase@^4.1.1": + "integrity" "sha1-hImxyw0p/4gZXM7KRI/21swpXDY=" + "resolved" "https://registry.npm.taobao.org/lodash.kebabcase/download/lodash.kebabcase-4.1.1.tgz" + "version" "4.1.1" + +"lodash.mapvalues@^4.6.0": + "integrity" "sha1-G6+lAF3p3W9PJmaMMMo3IwzJaJw=" + "resolved" "https://registry.npm.taobao.org/lodash.mapvalues/download/lodash.mapvalues-4.6.0.tgz" + "version" "4.6.0" + +"lodash.memoize@^4.1.2": + "integrity" "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=" + "resolved" "https://registry.npm.taobao.org/lodash.memoize/download/lodash.memoize-4.1.2.tgz" + "version" "4.1.2" + +"lodash.sortby@^4.7.0": + "integrity" "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=" + "resolved" "https://registry.npm.taobao.org/lodash.sortby/download/lodash.sortby-4.7.0.tgz" + "version" "4.7.0" + +"lodash.transform@^4.6.0": + "integrity" "sha1-EjBkIvYzJK7YSD0/ODMrX2cFR6A=" + "resolved" "https://registry.npm.taobao.org/lodash.transform/download/lodash.transform-4.6.0.tgz" + "version" "4.6.0" + +"lodash.uniq@^4.5.0": + "integrity" "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=" + "resolved" "https://registry.npm.taobao.org/lodash.uniq/download/lodash.uniq-4.5.0.tgz" + "version" "4.5.0" + +"lodash@*", "lodash@^4.17.11", "lodash@^4.17.14", "lodash@^4.17.15", "lodash@^4.17.19", "lodash@^4.17.20", "lodash@^4.17.21", "lodash@^4.17.3": + "integrity" "sha1-Z5WRxWTDv/quhFTPCz3zcMPWkRw=" + "resolved" "https://registry.npm.taobao.org/lodash/download/lodash-4.17.21.tgz" + "version" "4.17.21" + +"log-symbols@^2.2.0", "log-symbols@2.2.0": + "integrity" "sha1-V0Dhxdbw39pK2TI7UzIQfva0xAo=" + "resolved" "https://registry.npm.taobao.org/log-symbols/download/log-symbols-2.2.0.tgz" + "version" "2.2.0" + dependencies: + "chalk" "^2.0.1" + +"loglevel@^1.6.8": + "integrity" "sha1-AF/eL15uRwaPk1/yhXPhJe9y8Zc=" + "resolved" "https://registry.npm.taobao.org/loglevel/download/loglevel-1.7.1.tgz?cache=0&sync_timestamp=1606312222145&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Floglevel%2Fdownload%2Floglevel-1.7.1.tgz" + "version" "1.7.1" + +"lower-case@^1.1.1": + "integrity" "sha1-miyr0bno4K6ZOkv31YdcOcQujqw=" + "resolved" "https://registry.npm.taobao.org/lower-case/download/lower-case-1.1.4.tgz" + "version" "1.1.4" + +"lru-cache@^4.0.1": + "integrity" "sha1-i75Q6oW+1ZvJ4z3KuCNe6bz0Q80=" + "resolved" "https://registry.nlark.com/lru-cache/download/lru-cache-4.1.5.tgz" + "version" "4.1.5" + dependencies: + "pseudomap" "^1.0.2" + "yallist" "^2.1.2" + +"lru-cache@^4.1.2": + "integrity" "sha1-i75Q6oW+1ZvJ4z3KuCNe6bz0Q80=" + "resolved" "https://registry.nlark.com/lru-cache/download/lru-cache-4.1.5.tgz" + "version" "4.1.5" + dependencies: + "pseudomap" "^1.0.2" + "yallist" "^2.1.2" + +"lru-cache@^5.1.1": + "integrity" "sha1-HaJ+ZxAnGUdpXa9oSOhH8B2EuSA=" + "resolved" "https://registry.nlark.com/lru-cache/download/lru-cache-5.1.1.tgz" + "version" "5.1.1" + dependencies: + "yallist" "^3.0.2" + +"magic-string@^0.25.7": + "integrity" "sha1-P0l9b9NMZpxnmNy4IfLvMfVEUFE=" + "resolved" "https://registry.npm.taobao.org/magic-string/download/magic-string-0.25.7.tgz" + "version" "0.25.7" + dependencies: + "sourcemap-codec" "^1.4.4" + +"make-dir@^2.0.0": + "integrity" "sha1-XwMQ4YuL6JjMBwCSlaMK5B6R5vU=" + "resolved" "https://registry.nlark.com/make-dir/download/make-dir-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "pify" "^4.0.1" + "semver" "^5.6.0" + +"make-dir@^2.1.0": + "integrity" "sha1-XwMQ4YuL6JjMBwCSlaMK5B6R5vU=" + "resolved" "https://registry.nlark.com/make-dir/download/make-dir-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "pify" "^4.0.1" + "semver" "^5.6.0" + +"make-dir@^3.0.2", "make-dir@^3.1.0": + "integrity" "sha1-QV6WcEazp/HRhSd9hKpYIDcmoT8=" + "resolved" "https://registry.nlark.com/make-dir/download/make-dir-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "semver" "^6.0.0" + +"map-cache@^0.2.2": + "integrity" "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=" + "resolved" "https://registry.npm.taobao.org/map-cache/download/map-cache-0.2.2.tgz" + "version" "0.2.2" + +"map-visit@^1.0.0": + "integrity" "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=" + "resolved" "https://registry.nlark.com/map-visit/download/map-visit-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "object-visit" "^1.0.0" + +"md5.js@^1.3.4": + "integrity" "sha1-tdB7jjIW4+J81yjXL3DR5qNCAF8=" + "resolved" "https://registry.npm.taobao.org/md5.js/download/md5.js-1.3.5.tgz" + "version" "1.3.5" + dependencies: + "hash-base" "^3.0.0" + "inherits" "^2.0.1" + "safe-buffer" "^5.1.2" + +"mdn-data@2.0.14": + "integrity" "sha1-cRP8QoGRfWPOKbQ0RvcB5owlulA=" + "resolved" "https://registry.nlark.com/mdn-data/download/mdn-data-2.0.14.tgz" + "version" "2.0.14" + +"mdn-data@2.0.4": + "integrity" "sha1-aZs8OKxvHXKAkaZGULZdOIUC/Vs=" + "resolved" "https://registry.nlark.com/mdn-data/download/mdn-data-2.0.4.tgz" + "version" "2.0.4" + +"media-typer@0.3.0": + "integrity" "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" + "resolved" "https://registry.npm.taobao.org/media-typer/download/media-typer-0.3.0.tgz" + "version" "0.3.0" + +"memoize-one@^6.0.0": + "integrity" "sha512-rkpe71W0N0c0Xz6QD0eJETuWAJGnJ9afsl1srmwPrI+yBCkge5EycXXbYRyvL29zZVUWQCY7InPRCv3GDXuZNw==" + "resolved" "https://registry.npmmirror.com/memoize-one/-/memoize-one-6.0.0.tgz" + "version" "6.0.0" + +"memory-fs@^0.4.1": + "integrity" "sha1-OpoguEYlI+RHz7x+i7gO1me/xVI=" + "resolved" "https://registry.npm.taobao.org/memory-fs/download/memory-fs-0.4.1.tgz" + "version" "0.4.1" + dependencies: + "errno" "^0.1.3" + "readable-stream" "^2.0.1" + +"memory-fs@^0.5.0": + "integrity" "sha1-MkwBKIuIZSlm0WHbd4OHIIRajjw=" + "resolved" "https://registry.npm.taobao.org/memory-fs/download/memory-fs-0.5.0.tgz" + "version" "0.5.0" + dependencies: + "errno" "^0.1.3" + "readable-stream" "^2.0.1" + +"merge-descriptors@^1.0.1", "merge-descriptors@1.0.1": + "integrity" "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" + "resolved" "https://registry.npm.taobao.org/merge-descriptors/download/merge-descriptors-1.0.1.tgz" + "version" "1.0.1" + +"merge-source-map@^1.1.0": + "integrity" "sha1-L93n5gIJOfcJBqaPLXrmheTIxkY=" + "resolved" "https://registry.npm.taobao.org/merge-source-map/download/merge-source-map-1.1.0.tgz" + "version" "1.1.0" + dependencies: + "source-map" "^0.6.1" + +"merge-stream@^2.0.0": + "integrity" "sha1-UoI2KaFN0AyXcPtq1H3GMQ8sH2A=" + "resolved" "https://registry.npm.taobao.org/merge-stream/download/merge-stream-2.0.0.tgz" + "version" "2.0.0" + +"merge2@^1.2.3", "merge2@^1.3.0": + "integrity" "sha1-Q2iJL4hekHRVpv19xVwMnUBJkK4=" + "resolved" "https://registry.npm.taobao.org/merge2/download/merge2-1.4.1.tgz" + "version" "1.4.1" + +"methods@~1.1.2": + "integrity" "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" + "resolved" "https://registry.npm.taobao.org/methods/download/methods-1.1.2.tgz" + "version" "1.1.2" + +"micromatch@^3.1.10", "micromatch@^3.1.4": + "integrity" "sha1-cIWbyVyYQJUvNZoGij/En57PrCM=" + "resolved" "https://registry.npm.taobao.org/micromatch/download/micromatch-3.1.10.tgz?cache=0&sync_timestamp=1618054841521&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmicromatch%2Fdownload%2Fmicromatch-3.1.10.tgz" + "version" "3.1.10" + dependencies: + "arr-diff" "^4.0.0" + "array-unique" "^0.3.2" + "braces" "^2.3.1" + "define-property" "^2.0.2" + "extend-shallow" "^3.0.2" + "extglob" "^2.0.4" + "fragment-cache" "^0.2.1" + "kind-of" "^6.0.2" + "nanomatch" "^1.2.9" + "object.pick" "^1.3.0" + "regex-not" "^1.0.0" + "snapdragon" "^0.8.1" + "to-regex" "^3.0.2" + +"micromatch@^4.0.2": + "integrity" "sha1-iW1Rnf6dsl/OlM63pQCRm/iB6/k=" + "resolved" "https://registry.npm.taobao.org/micromatch/download/micromatch-4.0.4.tgz?cache=0&sync_timestamp=1618054841521&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmicromatch%2Fdownload%2Fmicromatch-4.0.4.tgz" + "version" "4.0.4" + dependencies: + "braces" "^3.0.1" + "picomatch" "^2.2.3" + +"micromatch@^4.0.4": + "integrity" "sha1-iW1Rnf6dsl/OlM63pQCRm/iB6/k=" + "resolved" "https://registry.npm.taobao.org/micromatch/download/micromatch-4.0.4.tgz?cache=0&sync_timestamp=1618054841521&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmicromatch%2Fdownload%2Fmicromatch-4.0.4.tgz" + "version" "4.0.4" + dependencies: + "braces" "^3.0.1" + "picomatch" "^2.2.3" + +"miller-rabin@^4.0.0": + "integrity" "sha1-8IA1HIZbDcViqEYpZtqlNUPHik0=" + "resolved" "https://registry.npm.taobao.org/miller-rabin/download/miller-rabin-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "bn.js" "^4.0.0" + "brorand" "^1.0.1" + +"mime-db@>= 1.43.0 < 2", "mime-db@1.48.0": + "integrity" "sha1-41sxBF3X6to6qtU37YijOvvvLR0=" + "resolved" "https://registry.nlark.com/mime-db/download/mime-db-1.48.0.tgz?cache=0&sync_timestamp=1622433567590&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fmime-db%2Fdownload%2Fmime-db-1.48.0.tgz" + "version" "1.48.0" + +"mime-types@^2.1.12", "mime-types@~2.1.17", "mime-types@~2.1.19", "mime-types@~2.1.24": + "integrity" "sha1-oA12t0MXxh+cLbIhi46fjpxcnms=" + "resolved" "https://registry.nlark.com/mime-types/download/mime-types-2.1.31.tgz?cache=0&sync_timestamp=1622569304088&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fmime-types%2Fdownload%2Fmime-types-2.1.31.tgz" + "version" "2.1.31" + dependencies: + "mime-db" "1.48.0" + +"mime@^1.4.1": + "integrity" "sha1-Ms2eXGRVO9WNGaVor0Uqz/BJgbE=" + "resolved" "https://registry.nlark.com/mime/download/mime-1.6.0.tgz" + "version" "1.6.0" + +"mime@^2.4.4", "mime@^2.4.5", "mime@^2.5.2": + "integrity" "sha1-bj3GzCuVEGQ4MOXxnVy3U9pe6r4=" + "resolved" "https://registry.nlark.com/mime/download/mime-2.5.2.tgz" + "version" "2.5.2" + +"mime@1.6.0": + "integrity" "sha1-Ms2eXGRVO9WNGaVor0Uqz/BJgbE=" + "resolved" "https://registry.nlark.com/mime/download/mime-1.6.0.tgz" + "version" "1.6.0" + +"mimic-fn@^1.0.0": + "integrity" "sha1-ggyGo5M0ZA6ZUWkovQP8qIBX0CI=" + "resolved" "https://registry.npm.taobao.org/mimic-fn/download/mimic-fn-1.2.0.tgz?cache=0&sync_timestamp=1617823674050&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmimic-fn%2Fdownload%2Fmimic-fn-1.2.0.tgz" + "version" "1.2.0" + +"mimic-fn@^2.1.0": + "integrity" "sha1-ftLCzMyvhNP/y3pptXcR/CCDQBs=" + "resolved" "https://registry.npm.taobao.org/mimic-fn/download/mimic-fn-2.1.0.tgz?cache=0&sync_timestamp=1617823674050&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fmimic-fn%2Fdownload%2Fmimic-fn-2.1.0.tgz" + "version" "2.1.0" + +"mini-css-extract-plugin@^0.9.0": + "integrity" "sha1-R/LPB6oWWrNXM7H8l9TEbAVkM54=" + "resolved" "https://registry.nlark.com/mini-css-extract-plugin/download/mini-css-extract-plugin-0.9.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fmini-css-extract-plugin%2Fdownload%2Fmini-css-extract-plugin-0.9.0.tgz" + "version" "0.9.0" + dependencies: + "loader-utils" "^1.1.0" + "normalize-url" "1.9.1" + "schema-utils" "^1.0.0" + "webpack-sources" "^1.1.0" + +"minimalistic-assert@^1.0.0", "minimalistic-assert@^1.0.1": + "integrity" "sha1-LhlN4ERibUoQ5/f7wAznPoPk1cc=" + "resolved" "https://registry.npm.taobao.org/minimalistic-assert/download/minimalistic-assert-1.0.1.tgz" + "version" "1.0.1" + +"minimalistic-crypto-utils@^1.0.1": + "integrity" "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=" + "resolved" "https://registry.nlark.com/minimalistic-crypto-utils/download/minimalistic-crypto-utils-1.0.1.tgz" + "version" "1.0.1" + +"minimatch@^3.0.4", "minimatch@3.0.4": + "integrity" "sha1-UWbihkV/AzBgZL5Ul+jbsMPTIIM=" + "resolved" "https://registry.npm.taobao.org/minimatch/download/minimatch-3.0.4.tgz" + "version" "3.0.4" + dependencies: + "brace-expansion" "^1.1.7" + +"minimist@^1.1.0", "minimist@^1.2.0", "minimist@^1.2.5": + "integrity" "sha1-Z9ZgFLZqaoqqDAg8X9WN9OTpdgI=" + "resolved" "https://registry.nlark.com/minimist/download/minimist-1.2.5.tgz" + "version" "1.2.5" + +"minipass@^3.1.1": + "integrity" "sha1-fUL/HzljVILhX5zbUxhN7r1YFf0=" + "resolved" "https://registry.npm.taobao.org/minipass/download/minipass-3.1.3.tgz" + "version" "3.1.3" + dependencies: + "yallist" "^4.0.0" + +"mississippi@^3.0.0": + "integrity" "sha1-6goykfl+C16HdrNj1fChLZTGcCI=" + "resolved" "https://registry.npm.taobao.org/mississippi/download/mississippi-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "concat-stream" "^1.5.0" + "duplexify" "^3.4.2" + "end-of-stream" "^1.1.0" + "flush-write-stream" "^1.0.0" + "from2" "^2.1.0" + "parallel-transform" "^1.1.0" + "pump" "^3.0.0" + "pumpify" "^1.3.3" + "stream-each" "^1.1.0" + "through2" "^2.0.0" + +"mixin-deep@^1.2.0": + "integrity" "sha1-ESC0PcNZp4Xc5ltVuC4lfM9HlWY=" + "resolved" "https://registry.npm.taobao.org/mixin-deep/download/mixin-deep-1.3.2.tgz" + "version" "1.3.2" + dependencies: + "for-in" "^1.0.2" + "is-extendable" "^1.0.1" + +"mkdirp@^0.5.1", "mkdirp@^0.5.3", "mkdirp@^0.5.5", "mkdirp@~0.5.1": + "integrity" "sha1-2Rzv1i0UNsoPQWIOJRKI1CAJne8=" + "resolved" "https://registry.nlark.com/mkdirp/download/mkdirp-0.5.5.tgz" + "version" "0.5.5" + dependencies: + "minimist" "^1.2.5" + +"mkdirp@~1.0.4": + "integrity" "sha1-PrXtYmInVteaXw4qIh3+utdcL34=" + "resolved" "https://registry.nlark.com/mkdirp/download/mkdirp-1.0.4.tgz" + "version" "1.0.4" + +"mkdirp@0.5.4": + "integrity" "sha1-/QFQSmeX7Fyb6B/0PSBJYe1kpRI=" + "resolved" "https://registry.nlark.com/mkdirp/download/mkdirp-0.5.4.tgz" + "version" "0.5.4" + dependencies: + "minimist" "^1.2.5" + +"mocha@^6.2.2", "mocha@>=4 <=7": + "integrity" "sha1-5khDIYHYuZOTQQISZkRQpMHjGRI=" + "resolved" "https://registry.nlark.com/mocha/download/mocha-6.2.3.tgz" + "version" "6.2.3" + dependencies: + "ansi-colors" "3.2.3" + "browser-stdout" "1.3.1" + "debug" "3.2.6" + "diff" "3.5.0" + "escape-string-regexp" "1.0.5" + "find-up" "3.0.0" + "glob" "7.1.3" + "growl" "1.10.5" + "he" "1.2.0" + "js-yaml" "3.13.1" + "log-symbols" "2.2.0" + "minimatch" "3.0.4" + "mkdirp" "0.5.4" + "ms" "2.1.1" + "node-environment-flags" "1.0.5" + "object.assign" "4.1.0" + "strip-json-comments" "2.0.1" + "supports-color" "6.0.0" + "which" "1.3.1" + "wide-align" "1.1.3" + "yargs" "13.3.2" + "yargs-parser" "13.1.2" + "yargs-unparser" "1.6.0" + +"mochapack@^1.1.15": + "integrity" "sha1-Qmx5O4ce0AbHgRctorFfYS8R8tw=" + "resolved" "https://registry.nlark.com/mochapack/download/mochapack-1.1.15.tgz" + "version" "1.1.15" + dependencies: + "@babel/runtime-corejs2" "^7.0.0" + "chalk" "^2.4.2" + "chokidar" "^2.0.0" + "glob-parent" "5.1.0" + "globby" "^10.0.1" + "interpret" "^1.2.0" + "is-glob" "^4.0.1" + "loader-utils" "^1.2.3" + "lodash" "^4.17.15" + "memory-fs" "^0.4.1" + "minimatch" "^3.0.4" + "nodent-runtime" "^3.2.1" + "normalize-path" "^3.0.0" + "progress" "^2.0.3" + "source-map-support" "^0.5.13" + "toposort" "^2.0.2" + "yargs" "14.0.0" + +"move-concurrently@^1.0.1": + "integrity" "sha1-viwAX9oy4LKa8fBdfEszIUxwH5I=" + "resolved" "https://registry.npm.taobao.org/move-concurrently/download/move-concurrently-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "aproba" "^1.1.1" + "copy-concurrently" "^1.0.0" + "fs-write-stream-atomic" "^1.0.8" + "mkdirp" "^0.5.1" + "rimraf" "^2.5.4" + "run-queue" "^1.0.3" + +"ms@*", "ms@^2.0.0", "ms@^2.1.1", "ms@2.1.2": + "integrity" "sha1-0J0fNXtEP0kzgqjrPM0YOHKuYAk=" + "resolved" "https://registry.npm.taobao.org/ms/download/ms-2.1.2.tgz?cache=0&sync_timestamp=1607433856030&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fms%2Fdownload%2Fms-2.1.2.tgz" + "version" "2.1.2" + +"ms@2.0.0": + "integrity" "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" + "resolved" "https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz" + "version" "2.0.0" + +"ms@2.1.1": + "integrity" "sha1-MKWGTrPrsKZvLr5tcnrwagnYbgo=" + "resolved" "https://registry.npm.taobao.org/ms/download/ms-2.1.1.tgz?cache=0&sync_timestamp=1607433856030&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fms%2Fdownload%2Fms-2.1.1.tgz" + "version" "2.1.1" + +"multicast-dns-service-types@^1.1.0": + "integrity" "sha1-iZ8R2WhuXgXLkbNdXw5jt3PPyQE=" + "resolved" "https://registry.npm.taobao.org/multicast-dns-service-types/download/multicast-dns-service-types-1.1.0.tgz" + "version" "1.1.0" + +"multicast-dns@^6.0.1": + "integrity" "sha1-oOx72QVcQoL3kMPIL04o2zsxsik=" + "resolved" "https://registry.nlark.com/multicast-dns/download/multicast-dns-6.2.3.tgz?cache=0&sync_timestamp=1621891072224&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fmulticast-dns%2Fdownload%2Fmulticast-dns-6.2.3.tgz" + "version" "6.2.3" + dependencies: + "dns-packet" "^1.3.1" + "thunky" "^1.0.2" + +"mute-stream@0.0.8": + "integrity" "sha1-FjDEKyJR/4HiooPelqVJfqkuXg0=" + "resolved" "https://registry.npm.taobao.org/mute-stream/download/mute-stream-0.0.8.tgz" + "version" "0.0.8" + +"mz-modules@^2.1.0": + "integrity" "sha512-sjk8lcRW3vrVYnZ+W+67L/2rL+jbO5K/N6PFGIcLWTiYytNr22Ah9FDXFs+AQntTM1boZcoHi5qS+CV1seuPog==" + "resolved" "https://registry.npmmirror.com/mz-modules/-/mz-modules-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "glob" "^7.1.2" + "ko-sleep" "^1.0.3" + "mkdirp" "^0.5.1" + "pump" "^3.0.0" + "rimraf" "^2.6.1" + +"mz@^2.4.0", "mz@^2.7.0": + "integrity" "sha1-lQCAV6Vsr63CvGPd5/n/aVWUjjI=" + "resolved" "https://registry.npm.taobao.org/mz/download/mz-2.7.0.tgz" + "version" "2.7.0" + dependencies: + "any-promise" "^1.0.0" + "object-assign" "^4.0.1" + "thenify-all" "^1.0.0" + +"nanoid@^3.1.23": + "integrity" "sha1-90QIbOfCvEfuCoRyV01ceOQYOoE=" + "resolved" "https://registry.nlark.com/nanoid/download/nanoid-3.1.23.tgz?cache=0&sync_timestamp=1620674856899&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fnanoid%2Fdownload%2Fnanoid-3.1.23.tgz" + "version" "3.1.23" + +"nanomatch@^1.2.9": + "integrity" "sha1-uHqKpPwN6P5r6IiVs4mD/yZb0Rk=" + "resolved" "https://registry.npm.taobao.org/nanomatch/download/nanomatch-1.2.13.tgz" + "version" "1.2.13" + dependencies: + "arr-diff" "^4.0.0" + "array-unique" "^0.3.2" + "define-property" "^2.0.2" + "extend-shallow" "^3.0.2" + "fragment-cache" "^0.2.1" + "is-windows" "^1.0.2" + "kind-of" "^6.0.2" + "object.pick" "^1.3.0" + "regex-not" "^1.0.0" + "snapdragon" "^0.8.1" + "to-regex" "^3.0.1" + +"natural-compare@^1.4.0": + "integrity" "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==" + "resolved" "https://registry.npmmirror.com/natural-compare/-/natural-compare-1.4.0.tgz" + "version" "1.4.0" + +"needle@^2.5.2": + "integrity" "sha1-HI75waLCncweg9c4Cde8aByAoEg=" + "resolved" "https://registry.nlark.com/needle/download/needle-2.8.0.tgz" + "version" "2.8.0" + dependencies: + "debug" "^3.2.6" + "iconv-lite" "^0.4.4" + "sax" "^1.2.4" + +"negotiator@0.6.2": + "integrity" "sha1-/qz3zPUlp3rpY0Q2pkiD/+yjRvs=" + "resolved" "https://registry.npm.taobao.org/negotiator/download/negotiator-0.6.2.tgz" + "version" "0.6.2" + +"neo-async@^2.5.0", "neo-async@^2.6.0", "neo-async@^2.6.1": + "integrity" "sha1-tKr7k+OustgXTKU88WOrfXMIMF8=" + "resolved" "https://registry.npm.taobao.org/neo-async/download/neo-async-2.6.2.tgz" + "version" "2.6.2" + +"netmask@^2.0.2": + "integrity" "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==" + "resolved" "https://registry.npmmirror.com/netmask/-/netmask-2.0.2.tgz" + "version" "2.0.2" + +"nice-try@^1.0.4": + "integrity" "sha1-ozeKdpbOfSI+iPybdkvX7xCJ42Y=" + "resolved" "https://registry.nlark.com/nice-try/download/nice-try-1.0.5.tgz" + "version" "1.0.5" + +"no-case@^2.2.0": + "integrity" "sha1-YLgTOWvjmz8SiKTB7V0efSi0ZKw=" + "resolved" "https://registry.npm.taobao.org/no-case/download/no-case-2.3.2.tgz" + "version" "2.3.2" + dependencies: + "lower-case" "^1.1.1" + +"node-environment-flags@1.0.5": + "integrity" "sha1-+pMCdfW/Xa4YjWGSsktMi7rD12o=" + "resolved" "https://registry.npm.taobao.org/node-environment-flags/download/node-environment-flags-1.0.5.tgz" + "version" "1.0.5" + dependencies: + "object.getownpropertydescriptors" "^2.0.3" + "semver" "^5.7.0" + +"node-fetch@^2.6.7": + "integrity" "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==" + "resolved" "https://registry.npmmirror.com/node-fetch/-/node-fetch-2.6.7.tgz" + "version" "2.6.7" + dependencies: + "whatwg-url" "^5.0.0" + +"node-forge@^0.10.0": + "integrity" "sha1-Mt6ir7Ppkm8C7lzoeUkCaRpna/M=" + "resolved" "https://registry.npm.taobao.org/node-forge/download/node-forge-0.10.0.tgz" + "version" "0.10.0" + +"node-libs-browser@^2.2.1": + "integrity" "sha1-tk9RPRgzhiX5A0bSew0jXmMfZCU=" + "resolved" "https://registry.npm.taobao.org/node-libs-browser/download/node-libs-browser-2.2.1.tgz" + "version" "2.2.1" + dependencies: + "assert" "^1.1.1" + "browserify-zlib" "^0.2.0" + "buffer" "^4.3.0" + "console-browserify" "^1.1.0" + "constants-browserify" "^1.0.0" + "crypto-browserify" "^3.11.0" + "domain-browser" "^1.1.1" + "events" "^3.0.0" + "https-browserify" "^1.0.0" + "os-browserify" "^0.3.0" + "path-browserify" "0.0.1" + "process" "^0.11.10" + "punycode" "^1.2.4" + "querystring-es3" "^0.2.0" + "readable-stream" "^2.3.3" + "stream-browserify" "^2.0.1" + "stream-http" "^2.7.2" + "string_decoder" "^1.0.0" + "timers-browserify" "^2.0.4" + "tty-browserify" "0.0.0" + "url" "^0.11.0" + "util" "^0.11.0" + "vm-browserify" "^1.0.1" + +"node-releases@^1.1.71": + "integrity" "sha1-3U6B3dUnf/hGuAtSu0DEnt96eyA=" + "resolved" "https://registry.nlark.com/node-releases/download/node-releases-1.1.73.tgz" + "version" "1.1.73" + +"nodent-runtime@^3.2.1": + "integrity" "sha1-nidV2F4592Qojw1HUuvP4+VB4A4=" + "resolved" "https://registry.npm.taobao.org/nodent-runtime/download/nodent-runtime-3.2.1.tgz" + "version" "3.2.1" + +"normalize-package-data@^2.5.0": + "integrity" "sha1-5m2xg4sgDB38IzIl0SyzZSDiNKg=" + "resolved" "https://registry.npm.taobao.org/normalize-package-data/download/normalize-package-data-2.5.0.tgz?cache=0&sync_timestamp=1616086930281&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fnormalize-package-data%2Fdownload%2Fnormalize-package-data-2.5.0.tgz" + "version" "2.5.0" + dependencies: + "hosted-git-info" "^2.1.4" + "resolve" "^1.10.0" + "semver" "2 || 3 || 4 || 5" + "validate-npm-package-license" "^3.0.1" + +"normalize-path@^1.0.0": + "integrity" "sha1-MtDkcvkf80VwHBWoMRAY07CpA3k=" + "resolved" "https://registry.nlark.com/normalize-path/download/normalize-path-1.0.0.tgz" + "version" "1.0.0" + +"normalize-path@^2.1.1": + "integrity" "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=" + "resolved" "https://registry.nlark.com/normalize-path/download/normalize-path-2.1.1.tgz" + "version" "2.1.1" + dependencies: + "remove-trailing-separator" "^1.0.1" + +"normalize-path@^3.0.0", "normalize-path@~3.0.0": + "integrity" "sha1-Dc1p/yOhybEf0JeDFmRKA4ghamU=" + "resolved" "https://registry.nlark.com/normalize-path/download/normalize-path-3.0.0.tgz" + "version" "3.0.0" + +"normalize-range@^0.1.2": + "integrity" "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=" + "resolved" "https://registry.npm.taobao.org/normalize-range/download/normalize-range-0.1.2.tgz" + "version" "0.1.2" + +"normalize-url@^3.0.0": + "integrity" "sha1-suHE3E98bVd0PfczpPWXjRhlBVk=" + "resolved" "https://registry.nlark.com/normalize-url/download/normalize-url-3.3.0.tgz?cache=0&sync_timestamp=1625826704090&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fnormalize-url%2Fdownload%2Fnormalize-url-3.3.0.tgz" + "version" "3.3.0" + +"normalize-url@1.9.1": + "integrity" "sha1-LMDWazHqIwNkWENuNiDYWVTGbDw=" + "resolved" "https://registry.nlark.com/normalize-url/download/normalize-url-1.9.1.tgz?cache=0&sync_timestamp=1625826704090&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fnormalize-url%2Fdownload%2Fnormalize-url-1.9.1.tgz" + "version" "1.9.1" + dependencies: + "object-assign" "^4.0.1" + "prepend-http" "^1.0.0" + "query-string" "^4.1.0" + "sort-keys" "^1.0.0" + +"normalize-wheel-es@^1.2.0": + "integrity" "sha512-Wj7+EJQ8mSuXr2iWfnujrimU35R2W4FAErEyTmJoJ7ucwTn2hOUSsRehMb5RSYkxXGTM7Y9QpvPmp++w5ftoJw==" + "resolved" "https://registry.npmmirror.com/normalize-wheel-es/-/normalize-wheel-es-1.2.0.tgz" + "version" "1.2.0" + +"npm-run-path@^2.0.0": + "integrity" "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=" + "resolved" "https://registry.nlark.com/npm-run-path/download/npm-run-path-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "path-key" "^2.0.0" + +"npm-run-path@^4.0.0": + "integrity" "sha1-t+zR5e1T2o43pV4cImnguX7XSOo=" + "resolved" "https://registry.nlark.com/npm-run-path/download/npm-run-path-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "path-key" "^3.0.0" + +"nth-check@^1.0.2": + "integrity" "sha1-sr0pXDfj3VijvwcAN2Zjuk2c8Fw=" + "resolved" "https://registry.npm.taobao.org/nth-check/download/nth-check-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "boolbase" "~1.0.0" + +"nth-check@^2.0.0": + "integrity" "sha1-G7T22scAcvwxPoyc0UF7UHTAoSU=" + "resolved" "https://registry.npm.taobao.org/nth-check/download/nth-check-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "boolbase" "^1.0.0" + +"num2fraction@^1.2.2": + "integrity" "sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4=" + "resolved" "https://registry.npm.taobao.org/num2fraction/download/num2fraction-1.2.2.tgz" + "version" "1.2.2" + +"nwsapi@^2.2.0": + "integrity" "sha1-IEh5qePQaP8qVROcLHcngGgaOLc=" + "resolved" "https://registry.npm.taobao.org/nwsapi/download/nwsapi-2.2.0.tgz" + "version" "2.2.0" + +"oauth-sign@~0.9.0": + "integrity" "sha1-R6ewFrqmi1+g7PPe4IqFxnmsZFU=" + "resolved" "https://registry.nlark.com/oauth-sign/download/oauth-sign-0.9.0.tgz" + "version" "0.9.0" + +"object-assign@^4.0.1", "object-assign@^4.1.0", "object-assign@^4.1.1": + "integrity" "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" + "resolved" "https://registry.npm.taobao.org/object-assign/download/object-assign-4.1.1.tgz" + "version" "4.1.1" + +"object-copy@^0.1.0": + "integrity" "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=" + "resolved" "https://registry.nlark.com/object-copy/download/object-copy-0.1.0.tgz" + "version" "0.1.0" + dependencies: + "copy-descriptor" "^0.1.0" + "define-property" "^0.2.5" + "kind-of" "^3.0.3" + +"object-hash@^1.1.4": + "integrity" "sha1-/eRSCYqVHLFF8Dm7fUVUSd3BJt8=" + "resolved" "https://registry.nlark.com/object-hash/download/object-hash-1.3.1.tgz?cache=0&sync_timestamp=1622019485009&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fobject-hash%2Fdownload%2Fobject-hash-1.3.1.tgz" + "version" "1.3.1" + +"object-inspect@^1.10.3": + "integrity" "sha1-nc6xRs7dQUig2eUauI00z1CZIrE=" + "resolved" "https://registry.nlark.com/object-inspect/download/object-inspect-1.11.0.tgz" + "version" "1.11.0" + +"object-is@^1.0.1": + "integrity" "sha1-ud7qpfx/GEag+uzc7sE45XePU6w=" + "resolved" "https://registry.npm.taobao.org/object-is/download/object-is-1.1.5.tgz?cache=0&sync_timestamp=1613857744782&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fobject-is%2Fdownload%2Fobject-is-1.1.5.tgz" + "version" "1.1.5" + dependencies: + "call-bind" "^1.0.2" + "define-properties" "^1.1.3" + +"object-keys@^1.0.11", "object-keys@^1.0.12", "object-keys@^1.1.1": + "integrity" "sha1-HEfyct8nfzsdrwYWd9nILiMixg4=" + "resolved" "https://registry.npm.taobao.org/object-keys/download/object-keys-1.1.1.tgz" + "version" "1.1.1" + +"object-visit@^1.0.0": + "integrity" "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=" + "resolved" "https://registry.npm.taobao.org/object-visit/download/object-visit-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "isobject" "^3.0.0" + +"object.assign@^4.1.0", "object.assign@^4.1.2": + "integrity" "sha1-DtVKNC7Os3s4/3brgxoOeIy2OUA=" + "resolved" "https://registry.nlark.com/object.assign/download/object.assign-4.1.2.tgz" + "version" "4.1.2" + dependencies: + "call-bind" "^1.0.0" + "define-properties" "^1.1.3" + "has-symbols" "^1.0.1" + "object-keys" "^1.1.1" + +"object.assign@4.1.0": + "integrity" "sha1-lovxEA15Vrs8oIbwBvhGs7xACNo=" + "resolved" "https://registry.nlark.com/object.assign/download/object.assign-4.1.0.tgz" + "version" "4.1.0" + dependencies: + "define-properties" "^1.1.2" + "function-bind" "^1.1.1" + "has-symbols" "^1.0.0" + "object-keys" "^1.0.11" + +"object.getownpropertydescriptors@^2.0.3": + "integrity" "sha1-G9Y66s8NXS0vMbXjk7A6fGAaI/c=" + "resolved" "https://registry.nlark.com/object.getownpropertydescriptors/download/object.getownpropertydescriptors-2.1.2.tgz" + "version" "2.1.2" + dependencies: + "call-bind" "^1.0.2" + "define-properties" "^1.1.3" + "es-abstract" "^1.18.0-next.2" + +"object.pick@^1.3.0": + "integrity" "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=" + "resolved" "https://registry.npm.taobao.org/object.pick/download/object.pick-1.3.0.tgz" + "version" "1.3.0" + dependencies: + "isobject" "^3.0.1" + +"object.values@^1.1.0": + "integrity" "sha1-DSc3YoM+gWtpOmN9MAc+cFFTWzA=" + "resolved" "https://registry.nlark.com/object.values/download/object.values-1.1.4.tgz?cache=0&sync_timestamp=1622070650699&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fobject.values%2Fdownload%2Fobject.values-1.1.4.tgz" + "version" "1.1.4" + dependencies: + "call-bind" "^1.0.2" + "define-properties" "^1.1.3" + "es-abstract" "^1.18.2" + +"obuf@^1.0.0", "obuf@^1.1.2": + "integrity" "sha1-Cb6jND1BhZ69RGKS0RydTbYZCE4=" + "resolved" "https://registry.npm.taobao.org/obuf/download/obuf-1.1.2.tgz" + "version" "1.1.2" + +"on-finished@~2.3.0": + "integrity" "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=" + "resolved" "https://registry.nlark.com/on-finished/download/on-finished-2.3.0.tgz" + "version" "2.3.0" + dependencies: + "ee-first" "1.1.1" + +"on-headers@~1.0.2": + "integrity" "sha1-dysK5qqlJcOZ5Imt+tkMQD6zwo8=" + "resolved" "https://registry.nlark.com/on-headers/download/on-headers-1.0.2.tgz" + "version" "1.0.2" + +"once@^1.3.0", "once@^1.3.1", "once@^1.4.0": + "integrity" "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=" + "resolved" "https://registry.nlark.com/once/download/once-1.4.0.tgz" + "version" "1.4.0" + dependencies: + "wrappy" "1" + +"onetime@^2.0.0": + "integrity" "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=" + "resolved" "https://registry.npm.taobao.org/onetime/download/onetime-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "mimic-fn" "^1.0.0" + +"onetime@^5.1.0": + "integrity" "sha1-0Oluu1awdHbfHdnEgG5SN5hcpF4=" + "resolved" "https://registry.npm.taobao.org/onetime/download/onetime-5.1.2.tgz" + "version" "5.1.2" + dependencies: + "mimic-fn" "^2.1.0" + +"open@^6.3.0": + "integrity" "sha1-XBPpbQ3IlGhhZPGJZez+iJ7PyKk=" + "resolved" "https://registry.nlark.com/open/download/open-6.4.0.tgz" + "version" "6.4.0" + dependencies: + "is-wsl" "^1.1.0" + +"opener@^1.5.1": + "integrity" "sha1-XTfh81B3udysQwE3InGv3rKhNZg=" + "resolved" "https://registry.nlark.com/opener/download/opener-1.5.2.tgz" + "version" "1.5.2" + +"opn@^5.5.0": + "integrity" "sha1-/HFk+rVtI1kExRw7J9pnWMo7m/w=" + "resolved" "https://registry.npm.taobao.org/opn/download/opn-5.5.0.tgz" + "version" "5.5.0" + dependencies: + "is-wsl" "^1.1.0" + +"optionator@^0.8.1", "optionator@^0.8.3": + "integrity" "sha1-hPodA2/p08fiHZmIS2ARZ+yPtJU=" + "resolved" "https://registry.nlark.com/optionator/download/optionator-0.8.3.tgz" + "version" "0.8.3" + dependencies: + "deep-is" "~0.1.3" + "fast-levenshtein" "~2.0.6" + "levn" "~0.3.0" + "prelude-ls" "~1.1.2" + "type-check" "~0.3.2" + "word-wrap" "~1.2.3" + +"ora@^3.4.0": + "integrity" "sha1-vwdSSRBZo+8+1MhQl1Md6f280xg=" + "resolved" "https://registry.nlark.com/ora/download/ora-3.4.0.tgz?cache=0&sync_timestamp=1623137978561&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fora%2Fdownload%2Fora-3.4.0.tgz" + "version" "3.4.0" + dependencies: + "chalk" "^2.4.2" + "cli-cursor" "^2.1.0" + "cli-spinners" "^2.0.0" + "log-symbols" "^2.2.0" + "strip-ansi" "^5.2.0" + "wcwidth" "^1.0.1" + +"original@^1.0.0": + "integrity" "sha1-5EKmHP/hxf0gpl8yYcJmY7MD8l8=" + "resolved" "https://registry.npm.taobao.org/original/download/original-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "url-parse" "^1.4.3" + +"os-browserify@^0.3.0": + "integrity" "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=" + "resolved" "https://registry.nlark.com/os-browserify/download/os-browserify-0.3.0.tgz" + "version" "0.3.0" + +"os-name@~1.0.3": + "integrity" "sha512-f5estLO2KN8vgtTRaILIgEGBoBrMnZ3JQ7W9TMZCnOIGwHe8TRGSpcagnWDo+Dfhd/z08k9Xe75hvciJJ8Qaew==" + "resolved" "https://registry.npmmirror.com/os-name/-/os-name-1.0.3.tgz" + "version" "1.0.3" + dependencies: + "osx-release" "^1.0.0" + "win-release" "^1.0.0" + +"os-tmpdir@~1.0.2": + "integrity" "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" + "resolved" "https://registry.npm.taobao.org/os-tmpdir/download/os-tmpdir-1.0.2.tgz" + "version" "1.0.2" + +"osx-release@^1.0.0": + "integrity" "sha512-ixCMMwnVxyHFQLQnINhmIpWqXIfS2YOXchwQrk+OFzmo6nDjQ0E4KXAyyUh0T0MZgV4bUhkRrAbVqlE4yLVq4A==" + "resolved" "https://registry.npmmirror.com/osx-release/-/osx-release-1.1.0.tgz" + "version" "1.1.0" + dependencies: + "minimist" "^1.1.0" + +"p-finally@^1.0.0": + "integrity" "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" + "resolved" "https://registry.npm.taobao.org/p-finally/download/p-finally-1.0.0.tgz" + "version" "1.0.0" + +"p-finally@^2.0.0": + "integrity" "sha1-vW/KqcVZoJa2gIBvTWV7Pw8kBWE=" + "resolved" "https://registry.npm.taobao.org/p-finally/download/p-finally-2.0.1.tgz" + "version" "2.0.1" + +"p-limit@^2.0.0", "p-limit@^2.2.0", "p-limit@^2.2.1": + "integrity" "sha1-PdM8ZHohT9//2DWTPrCG2g3CHbE=" + "resolved" "https://registry.npm.taobao.org/p-limit/download/p-limit-2.3.0.tgz" + "version" "2.3.0" + dependencies: + "p-try" "^2.0.0" + +"p-locate@^3.0.0": + "integrity" "sha1-Mi1poFwCZLJZl9n0DNiokasAZKQ=" + "resolved" "https://registry.npm.taobao.org/p-locate/download/p-locate-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "p-limit" "^2.0.0" + +"p-locate@^4.1.0": + "integrity" "sha1-o0KLtwiLOmApL2aRkni3wpetTwc=" + "resolved" "https://registry.npm.taobao.org/p-locate/download/p-locate-4.1.0.tgz" + "version" "4.1.0" + dependencies: + "p-limit" "^2.2.0" + +"p-map@^2.0.0": + "integrity" "sha1-MQko/u+cnsxltosXaTAYpmXOoXU=" + "resolved" "https://registry.nlark.com/p-map/download/p-map-2.1.0.tgz" + "version" "2.1.0" + +"p-retry@^3.0.1": + "integrity" "sha1-MWtMiJPiyNwc+okfQGxLQivr8yg=" + "resolved" "https://registry.nlark.com/p-retry/download/p-retry-3.0.1.tgz" + "version" "3.0.1" + dependencies: + "retry" "^0.12.0" + +"p-try@^2.0.0": + "integrity" "sha1-yyhoVA4xPWHeWPr741zpAE1VQOY=" + "resolved" "https://registry.nlark.com/p-try/download/p-try-2.2.0.tgz" + "version" "2.2.0" + +"pac-proxy-agent@^5.0.0": + "integrity" "sha512-CcFG3ZtnxO8McDigozwE3AqAw15zDvGH+OjXO4kzf7IkEKkQ4gxQ+3sdF50WmhQ4P/bVusXcqNE2S3XrNURwzQ==" + "resolved" "https://registry.npmmirror.com/pac-proxy-agent/-/pac-proxy-agent-5.0.0.tgz" + "version" "5.0.0" + dependencies: + "@tootallnate/once" "1" + "agent-base" "6" + "debug" "4" + "get-uri" "3" + "http-proxy-agent" "^4.0.1" + "https-proxy-agent" "5" + "pac-resolver" "^5.0.0" + "raw-body" "^2.2.0" + "socks-proxy-agent" "5" + +"pac-resolver@^5.0.0": + "integrity" "sha512-cy7u00ko2KVgBAjuhevqpPeHIkCIqPe1v24cydhWjmeuzaBfmUWFCZJ1iAh5TuVzVZoUzXIW7K8sMYOZ84uZ9Q==" + "resolved" "https://registry.npmmirror.com/pac-resolver/-/pac-resolver-5.0.1.tgz" + "version" "5.0.1" + dependencies: + "degenerator" "^3.0.2" + "ip" "^1.1.5" + "netmask" "^2.0.2" + +"pako@~1.0.5": + "integrity" "sha1-bJWZ00DVTf05RjgCUqNXBaa5kr8=" + "resolved" "https://registry.npm.taobao.org/pako/download/pako-1.0.11.tgz?cache=0&sync_timestamp=1610208924901&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpako%2Fdownload%2Fpako-1.0.11.tgz" + "version" "1.0.11" + +"parallel-transform@^1.1.0": + "integrity" "sha1-kEnKN9bLIYLDsdLHIL6U0UpYFPw=" + "resolved" "https://registry.npm.taobao.org/parallel-transform/download/parallel-transform-1.2.0.tgz" + "version" "1.2.0" + dependencies: + "cyclist" "^1.0.1" + "inherits" "^2.0.3" + "readable-stream" "^2.1.5" + +"param-case@2.1.x": + "integrity" "sha1-35T9jPZTHs915r75oIWPvHK+Ikc=" + "resolved" "https://registry.npm.taobao.org/param-case/download/param-case-2.1.1.tgz?cache=0&sync_timestamp=1606867311360&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fparam-case%2Fdownload%2Fparam-case-2.1.1.tgz" + "version" "2.1.1" + dependencies: + "no-case" "^2.2.0" + +"parent-module@^1.0.0": + "integrity" "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==" + "resolved" "https://registry.npmmirror.com/parent-module/-/parent-module-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "callsites" "^3.0.0" + +"parse-asn1@^5.0.0", "parse-asn1@^5.1.5": + "integrity" "sha1-OFCAo+wTy2KmLTlAnLPoiETNrtQ=" + "resolved" "https://registry.nlark.com/parse-asn1/download/parse-asn1-5.1.6.tgz" + "version" "5.1.6" + dependencies: + "asn1.js" "^5.2.0" + "browserify-aes" "^1.0.0" + "evp_bytestokey" "^1.0.0" + "pbkdf2" "^3.0.3" + "safe-buffer" "^5.1.1" + +"parse-json@^4.0.0": + "integrity" "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=" + "resolved" "https://registry.npm.taobao.org/parse-json/download/parse-json-4.0.0.tgz?cache=0&sync_timestamp=1610966676829&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fparse-json%2Fdownload%2Fparse-json-4.0.0.tgz" + "version" "4.0.0" + dependencies: + "error-ex" "^1.3.1" + "json-parse-better-errors" "^1.0.1" + +"parse-json@^5.0.0": + "integrity" "sha1-x2/Gbe5UIxyWKyK8yKcs8vmXU80=" + "resolved" "https://registry.npm.taobao.org/parse-json/download/parse-json-5.2.0.tgz?cache=0&sync_timestamp=1610966676829&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fparse-json%2Fdownload%2Fparse-json-5.2.0.tgz" + "version" "5.2.0" + 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": + "integrity" "sha1-4rXb7eAOf6m8NjYH9TMn6LBzGJs=" + "resolved" "https://registry.npm.taobao.org/parse-node-version/download/parse-node-version-1.0.1.tgz" + "version" "1.0.1" + +"parse5-htmlparser2-tree-adapter@^6.0.0": + "integrity" "sha1-LN+a2CMyEUA3DU2/XT6Sx8jdxuY=" + "resolved" "https://registry.npm.taobao.org/parse5-htmlparser2-tree-adapter/download/parse5-htmlparser2-tree-adapter-6.0.1.tgz" + "version" "6.0.1" + dependencies: + "parse5" "^6.0.1" + +"parse5@^5.1.1": + "integrity" "sha1-9o5OW6GFKsLK3AD0VV//bCq7YXg=" + "resolved" "https://registry.npm.taobao.org/parse5/download/parse5-5.1.1.tgz" + "version" "5.1.1" + +"parse5@^6.0.1": + "integrity" "sha1-4aHAhcVps9wIMhGE8Zo5zCf3wws=" + "resolved" "https://registry.npm.taobao.org/parse5/download/parse5-6.0.1.tgz" + "version" "6.0.1" + +"parse5@5.1.0": + "integrity" "sha1-xZNByXI/QUxFKXVWTHwApo1YrNI=" + "resolved" "https://registry.npm.taobao.org/parse5/download/parse5-5.1.0.tgz" + "version" "5.1.0" + +"parseurl@~1.3.2", "parseurl@~1.3.3": + "integrity" "sha1-naGee+6NEt/wUT7Vt2lXeTvC6NQ=" + "resolved" "https://registry.npm.taobao.org/parseurl/download/parseurl-1.3.3.tgz" + "version" "1.3.3" + +"pascalcase@^0.1.1": + "integrity" "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=" + "resolved" "https://registry.npm.taobao.org/pascalcase/download/pascalcase-0.1.1.tgz" + "version" "0.1.1" + +"path-browserify@0.0.1": + "integrity" "sha1-5sTd1+06onxoogzE5Q4aTug7vEo=" + "resolved" "https://registry.npm.taobao.org/path-browserify/download/path-browserify-0.0.1.tgz" + "version" "0.0.1" + +"path-dirname@^1.0.0": + "integrity" "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=" + "resolved" "https://registry.npm.taobao.org/path-dirname/download/path-dirname-1.0.2.tgz" + "version" "1.0.2" + +"path-exists@^2.0.0": + "integrity" "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=" + "resolved" "https://registry.nlark.com/path-exists/download/path-exists-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "pinkie-promise" "^2.0.0" + +"path-exists@^3.0.0": + "integrity" "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=" + "resolved" "https://registry.nlark.com/path-exists/download/path-exists-3.0.0.tgz" + "version" "3.0.0" + +"path-exists@^4.0.0": + "integrity" "sha1-UTvb4tO5XXdi6METfvoZXGxhtbM=" + "resolved" "https://registry.nlark.com/path-exists/download/path-exists-4.0.0.tgz" + "version" "4.0.0" + +"path-is-absolute@^1.0.0": + "integrity" "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" + "resolved" "https://registry.nlark.com/path-is-absolute/download/path-is-absolute-1.0.1.tgz" + "version" "1.0.1" + +"path-is-inside@^1.0.2": + "integrity" "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=" + "resolved" "https://registry.nlark.com/path-is-inside/download/path-is-inside-1.0.2.tgz" + "version" "1.0.2" + +"path-key@^2.0.0": + "integrity" "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" + "resolved" "https://registry.npm.taobao.org/path-key/download/path-key-2.0.1.tgz?cache=0&sync_timestamp=1617971691339&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpath-key%2Fdownload%2Fpath-key-2.0.1.tgz" + "version" "2.0.1" + +"path-key@^2.0.1": + "integrity" "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" + "resolved" "https://registry.npm.taobao.org/path-key/download/path-key-2.0.1.tgz?cache=0&sync_timestamp=1617971691339&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpath-key%2Fdownload%2Fpath-key-2.0.1.tgz" + "version" "2.0.1" + +"path-key@^3.0.0", "path-key@^3.1.0": + "integrity" "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==" + "resolved" "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz" + "version" "3.1.1" + +"path-parse@^1.0.6": + "integrity" "sha1-+8EUtgykKzDZ2vWFjkvWi77bZzU=" + "resolved" "https://registry.nlark.com/path-parse/download/path-parse-1.0.7.tgz" + "version" "1.0.7" + +"path-to-regexp@0.1.7": + "integrity" "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" + "resolved" "https://registry.nlark.com/path-to-regexp/download/path-to-regexp-0.1.7.tgz?cache=0&sync_timestamp=1618847711772&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpath-to-regexp%2Fdownload%2Fpath-to-regexp-0.1.7.tgz" + "version" "0.1.7" + +"path-type@^3.0.0": + "integrity" "sha1-zvMdyOCho7sNEFwM2Xzzv0f0428=" + "resolved" "https://registry.npm.taobao.org/path-type/download/path-type-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "pify" "^3.0.0" + +"path-type@^4.0.0": + "integrity" "sha1-hO0BwKe6OAr+CdkKjBgNzZ0DBDs=" + "resolved" "https://registry.npm.taobao.org/path-type/download/path-type-4.0.0.tgz" + "version" "4.0.0" + +"pathval@^1.1.1": + "integrity" "sha1-hTTnenfOesWiUS6iHg/bj89sPY0=" + "resolved" "https://registry.npm.taobao.org/pathval/download/pathval-1.1.1.tgz?cache=0&sync_timestamp=1611662006519&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpathval%2Fdownload%2Fpathval-1.1.1.tgz" + "version" "1.1.1" + +"pause-stream@~0.0.11": + "integrity" "sha512-e3FBlXLmN/D1S+zHzanP4E/4Z60oFAa3O051qt1pxa7DEJWKAyil6upYVXCWadEnuoqa4Pkc9oUx9zsxYeRv8A==" + "resolved" "https://registry.npmmirror.com/pause-stream/-/pause-stream-0.0.11.tgz" + "version" "0.0.11" + dependencies: + "through" "~2.3" + +"pbkdf2@^3.0.3": + "integrity" "sha1-3YIqoIh1gOUvGgOdw+2hCO+uMHU=" + "resolved" "https://registry.npm.taobao.org/pbkdf2/download/pbkdf2-3.1.2.tgz" + "version" "3.1.2" + dependencies: + "create-hash" "^1.1.2" + "create-hmac" "^1.1.4" + "ripemd160" "^2.0.1" + "safe-buffer" "^5.0.1" + "sha.js" "^2.4.8" + +"performance-now@^2.1.0": + "integrity" "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" + "resolved" "https://registry.npm.taobao.org/performance-now/download/performance-now-2.1.0.tgz" + "version" "2.1.0" + +"picomatch@^2.0.4", "picomatch@^2.2.1", "picomatch@^2.2.3": + "integrity" "sha1-8fBh3o9qS/AiiS4tEoI0+5gwKXI=" + "resolved" "https://registry.nlark.com/picomatch/download/picomatch-2.3.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpicomatch%2Fdownload%2Fpicomatch-2.3.0.tgz" + "version" "2.3.0" + +"pify@^2.0.0": + "integrity" "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" + "resolved" "https://registry.npm.taobao.org/pify/download/pify-2.3.0.tgz" + "version" "2.3.0" + +"pify@^3.0.0": + "integrity" "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + "resolved" "https://registry.npm.taobao.org/pify/download/pify-3.0.0.tgz" + "version" "3.0.0" + +"pify@^4.0.1": + "integrity" "sha1-SyzSXFDVmHNcUCkiJP2MbfQeMjE=" + "resolved" "https://registry.npm.taobao.org/pify/download/pify-4.0.1.tgz" + "version" "4.0.1" + +"pinkie-promise@^2.0.0": + "integrity" "sha1-ITXW36ejWMBprJsXh3YogihFD/o=" + "resolved" "https://registry.nlark.com/pinkie-promise/download/pinkie-promise-2.0.1.tgz?cache=0&sync_timestamp=1618847023792&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpinkie-promise%2Fdownload%2Fpinkie-promise-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "pinkie" "^2.0.0" + +"pinkie@^2.0.0": + "integrity" "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=" + "resolved" "https://registry.nlark.com/pinkie/download/pinkie-2.0.4.tgz" + "version" "2.0.4" + +"pkg-dir@^1.0.0": + "integrity" "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=" + "resolved" "https://registry.nlark.com/pkg-dir/download/pkg-dir-1.0.0.tgz?cache=0&sync_timestamp=1618847182947&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpkg-dir%2Fdownload%2Fpkg-dir-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "find-up" "^1.0.0" + +"pkg-dir@^3.0.0": + "integrity" "sha1-J0kCDyOe2ZCIGx9xIQ1R62UjvqM=" + "resolved" "https://registry.nlark.com/pkg-dir/download/pkg-dir-3.0.0.tgz?cache=0&sync_timestamp=1618847182947&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpkg-dir%2Fdownload%2Fpkg-dir-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "find-up" "^3.0.0" + +"pkg-dir@^4.1.0": + "integrity" "sha1-8JkTPfft5CLoHR2ESCcO6z5CYfM=" + "resolved" "https://registry.nlark.com/pkg-dir/download/pkg-dir-4.2.0.tgz?cache=0&sync_timestamp=1618847182947&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpkg-dir%2Fdownload%2Fpkg-dir-4.2.0.tgz" + "version" "4.2.0" + dependencies: + "find-up" "^4.0.0" + +"platform@^1.3.1": + "integrity" "sha512-fnWVljUchTro6RiCFvCXBbNhJc2NijN7oIQxbwsyL0buWJPG85v81ehlHI9fXrJsMNgTofEoWIQeClKpgxFLrg==" + "resolved" "https://registry.npmmirror.com/platform/-/platform-1.3.6.tgz" + "version" "1.3.6" + +"pn@^1.1.0": + "integrity" "sha1-4vTO8OIZ9GPBeas3Rj5OHs3Muvs=" + "resolved" "https://registry.npm.taobao.org/pn/download/pn-1.1.0.tgz" + "version" "1.1.0" + +"pnp-webpack-plugin@^1.6.4": + "integrity" "sha1-yXEaxNxIpoXauvyG+Lbdn434QUk=" + "resolved" "https://registry.npm.taobao.org/pnp-webpack-plugin/download/pnp-webpack-plugin-1.6.4.tgz" + "version" "1.6.4" + dependencies: + "ts-pnp" "^1.1.6" + +"portfinder@^1.0.26": + "integrity" "sha1-Z8RiKFK9U3TdHdkA93n1NGL6x3g=" + "resolved" "https://registry.npm.taobao.org/portfinder/download/portfinder-1.0.28.tgz" + "version" "1.0.28" + dependencies: + "async" "^2.6.2" + "debug" "^3.1.1" + "mkdirp" "^0.5.5" + +"posix-character-classes@^0.1.0": + "integrity" "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=" + "resolved" "https://registry.nlark.com/posix-character-classes/download/posix-character-classes-0.1.1.tgz" + "version" "0.1.1" + +"postcss-calc@^7.0.1": + "integrity" "sha1-+KbpnxLmGcLrwjz2xIb9wVhgkz4=" + "resolved" "https://registry.npm.taobao.org/postcss-calc/download/postcss-calc-7.0.5.tgz?cache=0&sync_timestamp=1609689191682&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpostcss-calc%2Fdownload%2Fpostcss-calc-7.0.5.tgz" + "version" "7.0.5" + dependencies: + "postcss" "^7.0.27" + "postcss-selector-parser" "^6.0.2" + "postcss-value-parser" "^4.0.2" + +"postcss-colormin@^4.0.3": + "integrity" "sha1-rgYLzpPteUrHEmTwgTLVUJVr04E=" + "resolved" "https://registry.nlark.com/postcss-colormin/download/postcss-colormin-4.0.3.tgz" + "version" "4.0.3" + dependencies: + "browserslist" "^4.0.0" + "color" "^3.0.0" + "has" "^1.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-convert-values@^4.0.1": + "integrity" "sha1-yjgT7U2g+BL51DcDWE5Enr4Ymn8=" + "resolved" "https://registry.nlark.com/postcss-convert-values/download/postcss-convert-values-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-discard-comments@^4.0.2": + "integrity" "sha1-H7q9LCRr/2qq15l7KwkY9NevQDM=" + "resolved" "https://registry.nlark.com/postcss-discard-comments/download/postcss-discard-comments-4.0.2.tgz?cache=0&sync_timestamp=1621449811540&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-discard-comments%2Fdownload%2Fpostcss-discard-comments-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "postcss" "^7.0.0" + +"postcss-discard-duplicates@^4.0.2": + "integrity" "sha1-P+EzzTyCKC5VD8myORdqkge3hOs=" + "resolved" "https://registry.nlark.com/postcss-discard-duplicates/download/postcss-discard-duplicates-4.0.2.tgz?cache=0&sync_timestamp=1621449811996&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-discard-duplicates%2Fdownload%2Fpostcss-discard-duplicates-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "postcss" "^7.0.0" + +"postcss-discard-empty@^4.0.1": + "integrity" "sha1-yMlR6fc+2UKAGUWERKAq2Qu592U=" + "resolved" "https://registry.nlark.com/postcss-discard-empty/download/postcss-discard-empty-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "postcss" "^7.0.0" + +"postcss-discard-overridden@^4.0.1": + "integrity" "sha1-ZSrvipZybwKfXj4AFG7npOdV/1c=" + "resolved" "https://registry.nlark.com/postcss-discard-overridden/download/postcss-discard-overridden-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "postcss" "^7.0.0" + +"postcss-load-config@^2.0.0": + "integrity" "sha1-xepQTyxK7zPHNZo03jVzdyrXUCo=" + "resolved" "https://registry.nlark.com/postcss-load-config/download/postcss-load-config-2.1.2.tgz?cache=0&sync_timestamp=1623669505598&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-load-config%2Fdownload%2Fpostcss-load-config-2.1.2.tgz" + "version" "2.1.2" + dependencies: + "cosmiconfig" "^5.0.0" + "import-cwd" "^2.0.0" + +"postcss-loader@^3.0.0": + "integrity" "sha1-a5eUPkfHLYRfqeA/Jzdz1OjdbC0=" + "resolved" "https://registry.nlark.com/postcss-loader/download/postcss-loader-3.0.0.tgz?cache=0&sync_timestamp=1625142952652&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-loader%2Fdownload%2Fpostcss-loader-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "loader-utils" "^1.1.0" + "postcss" "^7.0.0" + "postcss-load-config" "^2.0.0" + "schema-utils" "^1.0.0" + +"postcss-merge-longhand@^4.0.11": + "integrity" "sha1-YvSaE+Sg7gTnuY9CuxYGLKJUniQ=" + "resolved" "https://registry.nlark.com/postcss-merge-longhand/download/postcss-merge-longhand-4.0.11.tgz" + "version" "4.0.11" + dependencies: + "css-color-names" "0.0.4" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + "stylehacks" "^4.0.0" + +"postcss-merge-rules@^4.0.3": + "integrity" "sha1-NivqT/Wh+Y5AdacTxsslrv75plA=" + "resolved" "https://registry.nlark.com/postcss-merge-rules/download/postcss-merge-rules-4.0.3.tgz" + "version" "4.0.3" + dependencies: + "browserslist" "^4.0.0" + "caniuse-api" "^3.0.0" + "cssnano-util-same-parent" "^4.0.0" + "postcss" "^7.0.0" + "postcss-selector-parser" "^3.0.0" + "vendors" "^1.0.0" + +"postcss-minify-font-values@^4.0.2": + "integrity" "sha1-zUw0TM5HQ0P6xdgiBqssvLiv1aY=" + "resolved" "https://registry.nlark.com/postcss-minify-font-values/download/postcss-minify-font-values-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-minify-gradients@^4.0.2": + "integrity" "sha1-k7KcL/UJnFNe7NpWxKpuZlpmNHE=" + "resolved" "https://registry.nlark.com/postcss-minify-gradients/download/postcss-minify-gradients-4.0.2.tgz?cache=0&sync_timestamp=1621449817860&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-minify-gradients%2Fdownload%2Fpostcss-minify-gradients-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "cssnano-util-get-arguments" "^4.0.0" + "is-color-stop" "^1.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-minify-params@^4.0.2": + "integrity" "sha1-a5zvAwwR41Jh+V9hjJADbWgNuHQ=" + "resolved" "https://registry.nlark.com/postcss-minify-params/download/postcss-minify-params-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "alphanum-sort" "^1.0.0" + "browserslist" "^4.0.0" + "cssnano-util-get-arguments" "^4.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + "uniqs" "^2.0.0" + +"postcss-minify-selectors@^4.0.2": + "integrity" "sha1-4uXrQL/uUA0M2SQ1APX46kJi+9g=" + "resolved" "https://registry.nlark.com/postcss-minify-selectors/download/postcss-minify-selectors-4.0.2.tgz?cache=0&sync_timestamp=1621449812496&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-minify-selectors%2Fdownload%2Fpostcss-minify-selectors-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "alphanum-sort" "^1.0.0" + "has" "^1.0.0" + "postcss" "^7.0.0" + "postcss-selector-parser" "^3.0.0" + +"postcss-modules-extract-imports@^2.0.0": + "integrity" "sha1-gYcZoa4doyX5gyRGsBE27rSTzX4=" + "resolved" "https://registry.npm.taobao.org/postcss-modules-extract-imports/download/postcss-modules-extract-imports-2.0.0.tgz?cache=0&sync_timestamp=1602588260997&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpostcss-modules-extract-imports%2Fdownload%2Fpostcss-modules-extract-imports-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "postcss" "^7.0.5" + +"postcss-modules-local-by-default@^3.0.2": + "integrity" "sha1-uxTgzHgnnVBNvcv9fgyiiZP/u7A=" + "resolved" "https://registry.npm.taobao.org/postcss-modules-local-by-default/download/postcss-modules-local-by-default-3.0.3.tgz" + "version" "3.0.3" + dependencies: + "icss-utils" "^4.1.1" + "postcss" "^7.0.32" + "postcss-selector-parser" "^6.0.2" + "postcss-value-parser" "^4.1.0" + +"postcss-modules-scope@^2.2.0": + "integrity" "sha1-OFyuATzHdD9afXYC0Qc6iequYu4=" + "resolved" "https://registry.nlark.com/postcss-modules-scope/download/postcss-modules-scope-2.2.0.tgz" + "version" "2.2.0" + dependencies: + "postcss" "^7.0.6" + "postcss-selector-parser" "^6.0.0" + +"postcss-modules-values@^3.0.0": + "integrity" "sha1-W1AA1uuuKbQlUwG0o6VFdEI+fxA=" + "resolved" "https://registry.npm.taobao.org/postcss-modules-values/download/postcss-modules-values-3.0.0.tgz?cache=0&sync_timestamp=1602586215124&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fpostcss-modules-values%2Fdownload%2Fpostcss-modules-values-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "icss-utils" "^4.0.0" + "postcss" "^7.0.6" + +"postcss-normalize-charset@^4.0.1": + "integrity" "sha1-izWt067oOhNrBHHg1ZvlilAoXdQ=" + "resolved" "https://registry.nlark.com/postcss-normalize-charset/download/postcss-normalize-charset-4.0.1.tgz?cache=0&sync_timestamp=1621449813014&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-normalize-charset%2Fdownload%2Fpostcss-normalize-charset-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "postcss" "^7.0.0" + +"postcss-normalize-display-values@^4.0.2": + "integrity" "sha1-Db4EpM6QY9RmftK+R2u4MMglk1o=" + "resolved" "https://registry.nlark.com/postcss-normalize-display-values/download/postcss-normalize-display-values-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "cssnano-util-get-match" "^4.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-normalize-positions@^4.0.2": + "integrity" "sha1-BfdX+E8mBDc3g2ipH4ky1LECkX8=" + "resolved" "https://registry.nlark.com/postcss-normalize-positions/download/postcss-normalize-positions-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "cssnano-util-get-arguments" "^4.0.0" + "has" "^1.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-normalize-repeat-style@^4.0.2": + "integrity" "sha1-xOu8KJ85kaAo1EdRy90RkYsXkQw=" + "resolved" "https://registry.nlark.com/postcss-normalize-repeat-style/download/postcss-normalize-repeat-style-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "cssnano-util-get-arguments" "^4.0.0" + "cssnano-util-get-match" "^4.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-normalize-string@^4.0.2": + "integrity" "sha1-zUTECrB6DHo23F6Zqs4eyk7CaQw=" + "resolved" "https://registry.nlark.com/postcss-normalize-string/download/postcss-normalize-string-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "has" "^1.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-normalize-timing-functions@^4.0.2": + "integrity" "sha1-jgCcoqOUnNr4rSPmtquZy159KNk=" + "resolved" "https://registry.nlark.com/postcss-normalize-timing-functions/download/postcss-normalize-timing-functions-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "cssnano-util-get-match" "^4.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-normalize-unicode@^4.0.1": + "integrity" "sha1-hBvUj9zzAZrUuqdJOj02O1KuHPs=" + "resolved" "https://registry.nlark.com/postcss-normalize-unicode/download/postcss-normalize-unicode-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "browserslist" "^4.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-normalize-url@^4.0.1": + "integrity" "sha1-EOQ3+GvHx+WPe5ZS7YeNqqlfquE=" + "resolved" "https://registry.nlark.com/postcss-normalize-url/download/postcss-normalize-url-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "is-absolute-url" "^2.0.0" + "normalize-url" "^3.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-normalize-whitespace@^4.0.2": + "integrity" "sha1-vx1AcP5Pzqh9E0joJdjMDF+qfYI=" + "resolved" "https://registry.nlark.com/postcss-normalize-whitespace/download/postcss-normalize-whitespace-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-ordered-values@^4.1.2": + "integrity" "sha1-DPdcgg7H1cTSgBiVWeC1ceusDu4=" + "resolved" "https://registry.nlark.com/postcss-ordered-values/download/postcss-ordered-values-4.1.2.tgz" + "version" "4.1.2" + dependencies: + "cssnano-util-get-arguments" "^4.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-reduce-initial@^4.0.3": + "integrity" "sha1-f9QuvqXpyBRgljniwuhK4nC6SN8=" + "resolved" "https://registry.nlark.com/postcss-reduce-initial/download/postcss-reduce-initial-4.0.3.tgz?cache=0&sync_timestamp=1621449818195&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-reduce-initial%2Fdownload%2Fpostcss-reduce-initial-4.0.3.tgz" + "version" "4.0.3" + dependencies: + "browserslist" "^4.0.0" + "caniuse-api" "^3.0.0" + "has" "^1.0.0" + "postcss" "^7.0.0" + +"postcss-reduce-transforms@^4.0.2": + "integrity" "sha1-F++kBerMbge+NBSlyi0QdGgdTik=" + "resolved" "https://registry.nlark.com/postcss-reduce-transforms/download/postcss-reduce-transforms-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "cssnano-util-get-match" "^4.0.0" + "has" "^1.0.0" + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + +"postcss-selector-parser@^3.0.0": + "integrity" "sha1-sxD1xMD9r3b5SQK7qjDbaqhPUnA=" + "resolved" "https://registry.nlark.com/postcss-selector-parser/download/postcss-selector-parser-3.1.2.tgz?cache=0&sync_timestamp=1620753051451&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-selector-parser%2Fdownload%2Fpostcss-selector-parser-3.1.2.tgz" + "version" "3.1.2" + dependencies: + "dot-prop" "^5.2.0" + "indexes-of" "^1.0.1" + "uniq" "^1.0.1" + +"postcss-selector-parser@^6.0.0", "postcss-selector-parser@^6.0.2": + "integrity" "sha1-LFu6gXSsL2mBq2MaQqsO5UrzMuo=" + "resolved" "https://registry.nlark.com/postcss-selector-parser/download/postcss-selector-parser-6.0.6.tgz?cache=0&sync_timestamp=1620753051451&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-selector-parser%2Fdownload%2Fpostcss-selector-parser-6.0.6.tgz" + "version" "6.0.6" + dependencies: + "cssesc" "^3.0.0" + "util-deprecate" "^1.0.2" + +"postcss-svgo@^4.0.3": + "integrity" "sha1-NDos26yVBdQWJD1Jb3JPOIlMlB4=" + "resolved" "https://registry.nlark.com/postcss-svgo/download/postcss-svgo-4.0.3.tgz" + "version" "4.0.3" + dependencies: + "postcss" "^7.0.0" + "postcss-value-parser" "^3.0.0" + "svgo" "^1.0.0" + +"postcss-unique-selectors@^4.0.1": + "integrity" "sha1-lEaRHzKJv9ZMbWgPBzwDsfnuS6w=" + "resolved" "https://registry.nlark.com/postcss-unique-selectors/download/postcss-unique-selectors-4.0.1.tgz?cache=0&sync_timestamp=1621449819576&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpostcss-unique-selectors%2Fdownload%2Fpostcss-unique-selectors-4.0.1.tgz" + "version" "4.0.1" + dependencies: + "alphanum-sort" "^1.0.0" + "postcss" "^7.0.0" + "uniqs" "^2.0.0" + +"postcss-value-parser@^3.0.0": + "integrity" "sha1-n/giVH4okyE88cMO+lGsX9G6goE=" + "resolved" "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-3.3.1.tgz" + "version" "3.3.1" + +"postcss-value-parser@^4.0.2", "postcss-value-parser@^4.1.0": + "integrity" "sha1-RD9qIM7WSBor2k+oUypuVdeJoss=" + "resolved" "https://registry.npm.taobao.org/postcss-value-parser/download/postcss-value-parser-4.1.0.tgz" + "version" "4.1.0" + +"postcss@^7.0.0", "postcss@^7.0.1", "postcss@^7.0.14", "postcss@^7.0.27", "postcss@^7.0.32", "postcss@^7.0.36", "postcss@^7.0.5", "postcss@^7.0.6": + "integrity" "sha1-BW+M/6k5ZiqPWQWVDAfVKFZE38s=" + "resolved" "https://registry.nlark.com/postcss/download/postcss-7.0.36.tgz" + "version" "7.0.36" + dependencies: + "chalk" "^2.4.2" + "source-map" "^0.6.1" + "supports-color" "^6.1.0" + +"postcss@^8.1.10": + "integrity" "sha1-mCIWsRNBK8IKhiiekeuZSVKltwk=" + "resolved" "https://registry.nlark.com/postcss/download/postcss-8.3.5.tgz" + "version" "8.3.5" + dependencies: + "colorette" "^1.2.2" + "nanoid" "^3.1.23" + "source-map-js" "^0.6.2" + +"prelude-ls@~1.1.2": + "integrity" "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" + "resolved" "https://registry.npm.taobao.org/prelude-ls/download/prelude-ls-1.1.2.tgz" + "version" "1.1.2" + +"prepend-http@^1.0.0": + "integrity" "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=" + "resolved" "https://registry.nlark.com/prepend-http/download/prepend-http-1.0.4.tgz" + "version" "1.0.4" + +"prettier@^1.18.2": + "integrity" "sha1-99f1/4qc2HKnvkyhQglZVqYHl8s=" + "resolved" "https://registry.nlark.com/prettier/download/prettier-1.19.1.tgz?cache=0&sync_timestamp=1624696259185&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fprettier%2Fdownload%2Fprettier-1.19.1.tgz" + "version" "1.19.1" + +"pretty-error@^2.0.2": + "integrity" "sha1-von4LYGxyG7I/fvDhQRYgnJ/k7Y=" + "resolved" "https://registry.nlark.com/pretty-error/download/pretty-error-2.1.2.tgz?cache=0&sync_timestamp=1623342956536&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fpretty-error%2Fdownload%2Fpretty-error-2.1.2.tgz" + "version" "2.1.2" + dependencies: + "lodash" "^4.17.20" + "renderkid" "^2.0.4" + +"process-nextick-args@~2.0.0": + "integrity" "sha1-eCDZsWEgzFXKmud5JoCufbptf+I=" + "resolved" "https://registry.nlark.com/process-nextick-args/download/process-nextick-args-2.0.1.tgz" + "version" "2.0.1" + +"process@^0.11.10": + "integrity" "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=" + "resolved" "https://registry.npm.taobao.org/process/download/process-0.11.10.tgz" + "version" "0.11.10" + +"progress@^2.0.0", "progress@^2.0.3": + "integrity" "sha1-foz42PW48jnBvGi+tOt4Vn1XLvg=" + "resolved" "https://registry.npm.taobao.org/progress/download/progress-2.0.3.tgz" + "version" "2.0.3" + +"promise-inflight@^1.0.1": + "integrity" "sha1-mEcocL8igTL8vdhoEputEsPAKeM=" + "resolved" "https://registry.npm.taobao.org/promise-inflight/download/promise-inflight-1.0.1.tgz" + "version" "1.0.1" + +"proxy-addr@~2.0.5": + "integrity" "sha1-8Z/mnOqzEe65S0LnDowgcPm6ECU=" + "resolved" "https://registry.nlark.com/proxy-addr/download/proxy-addr-2.0.7.tgz" + "version" "2.0.7" + dependencies: + "forwarded" "0.2.0" + "ipaddr.js" "1.9.1" + +"proxy-agent@^5.0.0": + "integrity" "sha512-gkH7BkvLVkSfX9Dk27W6TyNOWWZWRilRfk1XxGNWOYJ2TuedAv1yFpCaU9QSBmBe716XOTNpYNOzhysyw8xn7g==" + "resolved" "https://registry.npmmirror.com/proxy-agent/-/proxy-agent-5.0.0.tgz" + "version" "5.0.0" + dependencies: + "agent-base" "^6.0.0" + "debug" "4" + "http-proxy-agent" "^4.0.0" + "https-proxy-agent" "^5.0.0" + "lru-cache" "^5.1.1" + "pac-proxy-agent" "^5.0.0" + "proxy-from-env" "^1.0.0" + "socks-proxy-agent" "^5.0.0" + +"proxy-from-env@^1.0.0": + "integrity" "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" + "resolved" "https://registry.npmmirror.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz" + "version" "1.1.0" + +"prr@~1.0.1": + "integrity" "sha1-0/wRS6BplaRexok/SEzrHXj19HY=" + "resolved" "https://registry.nlark.com/prr/download/prr-1.0.1.tgz" + "version" "1.0.1" + +"pseudomap@^1.0.2": + "integrity" "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" + "resolved" "https://registry.npm.taobao.org/pseudomap/download/pseudomap-1.0.2.tgz" + "version" "1.0.2" + +"psl@^1.1.28": + "integrity" "sha1-kyb4vPsBOtzABf3/BWrM4CDlHCQ=" + "resolved" "https://registry.nlark.com/psl/download/psl-1.8.0.tgz" + "version" "1.8.0" + +"public-encrypt@^4.0.0": + "integrity" "sha1-T8ydd6B+SLp1J+fL4N4z0HATMeA=" + "resolved" "https://registry.npm.taobao.org/public-encrypt/download/public-encrypt-4.0.3.tgz" + "version" "4.0.3" + dependencies: + "bn.js" "^4.1.0" + "browserify-rsa" "^4.0.0" + "create-hash" "^1.1.0" + "parse-asn1" "^5.0.0" + "randombytes" "^2.0.1" + "safe-buffer" "^5.1.2" + +"pump@^2.0.0": + "integrity" "sha1-Ejma3W5M91Jtlzy8i1zi4pCLOQk=" + "resolved" "https://registry.npm.taobao.org/pump/download/pump-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "end-of-stream" "^1.1.0" + "once" "^1.3.1" + +"pump@^3.0.0": + "integrity" "sha1-tKIRaBW94vTh6mAjVOjHVWUQemQ=" + "resolved" "https://registry.npm.taobao.org/pump/download/pump-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "end-of-stream" "^1.1.0" + "once" "^1.3.1" + +"pumpify@^1.3.3": + "integrity" "sha1-NlE74karJ1cLGjdKXOJ4v9dDcM4=" + "resolved" "https://registry.npm.taobao.org/pumpify/download/pumpify-1.5.1.tgz" + "version" "1.5.1" + dependencies: + "duplexify" "^3.6.0" + "inherits" "^2.0.3" + "pump" "^2.0.0" + +"punycode@^1.2.4": + "integrity" "sha1-wNWmOycYgArY4esPpSachN1BhF4=" + "resolved" "https://registry.npm.taobao.org/punycode/download/punycode-1.4.1.tgz" + "version" "1.4.1" + +"punycode@^2.1.0", "punycode@^2.1.1": + "integrity" "sha1-tYsBCsQMIsVldhbI0sLALHv0eew=" + "resolved" "https://registry.npm.taobao.org/punycode/download/punycode-2.1.1.tgz" + "version" "2.1.1" + +"punycode@1.3.2": + "integrity" "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" + "resolved" "https://registry.npm.taobao.org/punycode/download/punycode-1.3.2.tgz" + "version" "1.3.2" + +"q@^1.1.2": + "integrity" "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=" + "resolved" "https://registry.nlark.com/q/download/q-1.5.1.tgz" + "version" "1.5.1" + +"qs@^6.4.0", "qs@~6.5.2": + "integrity" "sha1-yzroBuh0BERYTvFUzo7pjUA/PjY=" + "resolved" "https://registry.npm.taobao.org/qs/download/qs-6.5.2.tgz" + "version" "6.5.2" + +"qs@6.7.0": + "integrity" "sha1-QdwaAV49WB8WIXdr4xr7KHapsbw=" + "resolved" "https://registry.npm.taobao.org/qs/download/qs-6.7.0.tgz" + "version" "6.7.0" + +"query-string@^4.1.0": + "integrity" "sha1-u7aTucqRXCMlFbIosaArYJBD2+s=" + "resolved" "https://registry.nlark.com/query-string/download/query-string-4.3.4.tgz?cache=0&sync_timestamp=1624297084219&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fquery-string%2Fdownload%2Fquery-string-4.3.4.tgz" + "version" "4.3.4" + dependencies: + "object-assign" "^4.1.0" + "strict-uri-encode" "^1.0.0" + +"querystring-es3@^0.2.0": + "integrity" "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=" + "resolved" "https://registry.npm.taobao.org/querystring-es3/download/querystring-es3-0.2.1.tgz" + "version" "0.2.1" + +"querystring@0.2.0": + "integrity" "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=" + "resolved" "https://registry.nlark.com/querystring/download/querystring-0.2.0.tgz?cache=0&sync_timestamp=1626179435543&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fquerystring%2Fdownload%2Fquerystring-0.2.0.tgz" + "version" "0.2.0" + +"querystringify@^2.1.1": + "integrity" "sha1-M0WUG0FTy50ILY7uTNogFqmu9/Y=" + "resolved" "https://registry.nlark.com/querystringify/download/querystringify-2.2.0.tgz" + "version" "2.2.0" + +"queue-microtask@^1.2.2": + "integrity" "sha1-SSkii7xyTfrEPg77BYyve2z7YkM=" + "resolved" "https://registry.npm.taobao.org/queue-microtask/download/queue-microtask-1.2.3.tgz?cache=0&sync_timestamp=1616391548624&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fqueue-microtask%2Fdownload%2Fqueue-microtask-1.2.3.tgz" + "version" "1.2.3" + +"randombytes@^2.0.0", "randombytes@^2.0.1", "randombytes@^2.0.5", "randombytes@^2.1.0": + "integrity" "sha1-32+ENy8CcNxlzfYpE0mrekc9Tyo=" + "resolved" "https://registry.npm.taobao.org/randombytes/download/randombytes-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "safe-buffer" "^5.1.0" + +"randomfill@^1.0.3": + "integrity" "sha1-ySGW/IarQr6YPxvzF3giSTHWFFg=" + "resolved" "https://registry.npm.taobao.org/randomfill/download/randomfill-1.0.4.tgz" + "version" "1.0.4" + dependencies: + "randombytes" "^2.0.5" + "safe-buffer" "^5.1.0" + +"range-parser@^1.2.1", "range-parser@~1.2.1": + "integrity" "sha1-PPNwI9GZ4cJNGlW4SADC8+ZGgDE=" + "resolved" "https://registry.nlark.com/range-parser/download/range-parser-1.2.1.tgz" + "version" "1.2.1" + +"raw-body@^2.2.0", "raw-body@2.4.0": + "integrity" "sha1-oc5vucm8NWylLoklarWQWeE9AzI=" + "resolved" "https://registry.nlark.com/raw-body/download/raw-body-2.4.0.tgz" + "version" "2.4.0" + dependencies: + "bytes" "3.1.0" + "http-errors" "1.7.2" + "iconv-lite" "0.4.24" + "unpipe" "1.0.0" + +"read-pkg@^5.1.1": + "integrity" "sha1-e/KVQ4yloz5WzTDgU7NO5yUMk8w=" + "resolved" "https://registry.npm.taobao.org/read-pkg/download/read-pkg-5.2.0.tgz?cache=0&sync_timestamp=1616914967500&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fread-pkg%2Fdownload%2Fread-pkg-5.2.0.tgz" + "version" "5.2.0" + dependencies: + "@types/normalize-package-data" "^2.4.0" + "normalize-package-data" "^2.5.0" + "parse-json" "^5.0.0" + "type-fest" "^0.6.0" + +"readable-stream@^2.0.0", "readable-stream@^2.0.1", "readable-stream@^2.0.2", "readable-stream@^2.1.5", "readable-stream@^2.2.2", "readable-stream@^2.3.3", "readable-stream@^2.3.6", "readable-stream@~2.3.6", "readable-stream@1 || 2": + "integrity" "sha1-Hsoc9xGu+BTAT2IlKjamL2yyO1c=" + "resolved" "https://registry.nlark.com/readable-stream/download/readable-stream-2.3.7.tgz" + "version" "2.3.7" + dependencies: + "core-util-is" "~1.0.0" + "inherits" "~2.0.3" + "isarray" "~1.0.0" + "process-nextick-args" "~2.0.0" + "safe-buffer" "~5.1.1" + "string_decoder" "~1.1.1" + "util-deprecate" "~1.0.1" + +"readable-stream@^3.0.6": + "integrity" "sha1-M3u9o63AcGvT4CRCaihtS0sskZg=" + "resolved" "https://registry.nlark.com/readable-stream/download/readable-stream-3.6.0.tgz" + "version" "3.6.0" + dependencies: + "inherits" "^2.0.3" + "string_decoder" "^1.1.1" + "util-deprecate" "^1.0.1" + +"readable-stream@^3.6.0": + "integrity" "sha1-M3u9o63AcGvT4CRCaihtS0sskZg=" + "resolved" "https://registry.nlark.com/readable-stream/download/readable-stream-3.6.0.tgz" + "version" "3.6.0" + dependencies: + "inherits" "^2.0.3" + "string_decoder" "^1.1.1" + "util-deprecate" "^1.0.1" + +"readable-stream@1.1.x": + "integrity" "sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ==" + "resolved" "https://registry.npmmirror.com/readable-stream/-/readable-stream-1.1.14.tgz" + "version" "1.1.14" + dependencies: + "core-util-is" "~1.0.0" + "inherits" "~2.0.1" + "isarray" "0.0.1" + "string_decoder" "~0.10.x" + +"readdirp@^2.2.1": + "integrity" "sha1-DodiKjMlqjPokihcr4tOhGUppSU=" + "resolved" "https://registry.npm.taobao.org/readdirp/download/readdirp-2.2.1.tgz" + "version" "2.2.1" + dependencies: + "graceful-fs" "^4.1.11" + "micromatch" "^3.1.10" + "readable-stream" "^2.0.2" + +"readdirp@~3.6.0": + "integrity" "sha1-dKNwvYVxFuJFspzJc0DNQxoCpsc=" + "resolved" "https://registry.npm.taobao.org/readdirp/download/readdirp-3.6.0.tgz" + "version" "3.6.0" + dependencies: + "picomatch" "^2.2.1" + +"regenerate-unicode-properties@^8.2.0": + "integrity" "sha1-5d5xEdZV57pgwFfb6f83yH5lzew=" + "resolved" "https://registry.nlark.com/regenerate-unicode-properties/download/regenerate-unicode-properties-8.2.0.tgz" + "version" "8.2.0" + dependencies: + "regenerate" "^1.4.0" + +"regenerate@^1.4.0": + "integrity" "sha1-uTRtiCfo9aMve6KWN9OYtpAUhIo=" + "resolved" "https://registry.nlark.com/regenerate/download/regenerate-1.4.2.tgz" + "version" "1.4.2" + +"regenerator-runtime@^0.13.4": + "integrity" "sha1-ysLazIoepnX+qrrriugziYrkb1U=" + "resolved" "https://registry.nlark.com/regenerator-runtime/download/regenerator-runtime-0.13.7.tgz" + "version" "0.13.7" + +"regenerator-transform@^0.14.2": + "integrity" "sha1-yY2hVGg2ccnE3LFuznNlF+G3/rQ=" + "resolved" "https://registry.nlark.com/regenerator-transform/download/regenerator-transform-0.14.5.tgz" + "version" "0.14.5" + dependencies: + "@babel/runtime" "^7.8.4" + +"regex-not@^1.0.0", "regex-not@^1.0.2": + "integrity" "sha1-H07OJ+ALC2XgJHpoEOaoXYOldSw=" + "resolved" "https://registry.npm.taobao.org/regex-not/download/regex-not-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "extend-shallow" "^3.0.2" + "safe-regex" "^1.1.0" + +"regexp.prototype.flags@^1.2.0": + "integrity" "sha1-fvNSro0VnnWMDq3Kb4/LTu8HviY=" + "resolved" "https://registry.nlark.com/regexp.prototype.flags/download/regexp.prototype.flags-1.3.1.tgz" + "version" "1.3.1" + dependencies: + "call-bind" "^1.0.2" + "define-properties" "^1.1.3" + +"regexpp@^2.0.1": + "integrity" "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==" + "resolved" "https://registry.npmmirror.com/regexpp/-/regexpp-2.0.1.tgz" + "version" "2.0.1" + +"regexpu-core@^4.7.1": + "integrity" "sha1-LepamgcjMpj78NuR+pq8TG4PitY=" + "resolved" "https://registry.npm.taobao.org/regexpu-core/download/regexpu-core-4.7.1.tgz" + "version" "4.7.1" + dependencies: + "regenerate" "^1.4.0" + "regenerate-unicode-properties" "^8.2.0" + "regjsgen" "^0.5.1" + "regjsparser" "^0.6.4" + "unicode-match-property-ecmascript" "^1.0.4" + "unicode-match-property-value-ecmascript" "^1.2.0" + +"regjsgen@^0.5.1": + "integrity" "sha1-kv8pX7He7L9uzaslQ9IH6RqjNzM=" + "resolved" "https://registry.npm.taobao.org/regjsgen/download/regjsgen-0.5.2.tgz" + "version" "0.5.2" + +"regjsparser@^0.6.4": + "integrity" "sha1-tInu98mizkNydicBFCnPgzpxg+Y=" + "resolved" "https://registry.nlark.com/regjsparser/download/regjsparser-0.6.9.tgz" + "version" "0.6.9" + dependencies: + "jsesc" "~0.5.0" + +"relateurl@0.2.x": + "integrity" "sha1-VNvzd+UUQKypCkzSdGANP/LYiKk=" + "resolved" "https://registry.npm.taobao.org/relateurl/download/relateurl-0.2.7.tgz" + "version" "0.2.7" + +"remove-trailing-separator@^1.0.1": + "integrity" "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=" + "resolved" "https://registry.npm.taobao.org/remove-trailing-separator/download/remove-trailing-separator-1.1.0.tgz" + "version" "1.1.0" + +"renderkid@^2.0.4": + "integrity" "sha1-Rk8namvc7mBvShWZP5sp/HTKhgk=" + "resolved" "https://registry.nlark.com/renderkid/download/renderkid-2.0.7.tgz?cache=0&sync_timestamp=1623343631807&other_urls=https%3A%2F%2Fregistry.nlark.com%2Frenderkid%2Fdownload%2Frenderkid-2.0.7.tgz" + "version" "2.0.7" + dependencies: + "css-select" "^4.1.3" + "dom-converter" "^0.2.0" + "htmlparser2" "^6.1.0" + "lodash" "^4.17.21" + "strip-ansi" "^3.0.1" + +"repeat-element@^1.1.2": + "integrity" "sha1-vmgVIIR6tYx1aKx1+/rSjtQtOek=" + "resolved" "https://registry.nlark.com/repeat-element/download/repeat-element-1.1.4.tgz" + "version" "1.1.4" + +"repeat-string@^1.6.1": + "integrity" "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" + "resolved" "https://registry.npm.taobao.org/repeat-string/download/repeat-string-1.6.1.tgz" + "version" "1.6.1" + +"request-promise-core@1.1.4": + "integrity" "sha1-Pu3UIjII1BmGe3jOgVFn0QWToi8=" + "resolved" "https://registry.npm.taobao.org/request-promise-core/download/request-promise-core-1.1.4.tgz" + "version" "1.1.4" + dependencies: + "lodash" "^4.17.19" + +"request-promise-native@^1.0.7": + "integrity" "sha1-5AcSBSal79yaObKKVnm/R7nZ3Cg=" + "resolved" "https://registry.nlark.com/request-promise-native/download/request-promise-native-1.0.9.tgz?cache=0&sync_timestamp=1618846813899&other_urls=https%3A%2F%2Fregistry.nlark.com%2Frequest-promise-native%2Fdownload%2Frequest-promise-native-1.0.9.tgz" + "version" "1.0.9" + dependencies: + "request-promise-core" "1.1.4" + "stealthy-require" "^1.1.1" + "tough-cookie" "^2.3.3" + +"request@^2.34", "request@^2.88.0", "request@^2.88.2": + "integrity" "sha1-1zyRhzHLWofaBH4gcjQUb2ZNErM=" + "resolved" "https://registry.npm.taobao.org/request/download/request-2.88.2.tgz" + "version" "2.88.2" + dependencies: + "aws-sign2" "~0.7.0" + "aws4" "^1.8.0" + "caseless" "~0.12.0" + "combined-stream" "~1.0.6" + "extend" "~3.0.2" + "forever-agent" "~0.6.1" + "form-data" "~2.3.2" + "har-validator" "~5.1.3" + "http-signature" "~1.2.0" + "is-typedarray" "~1.0.0" + "isstream" "~0.1.2" + "json-stringify-safe" "~5.0.1" + "mime-types" "~2.1.19" + "oauth-sign" "~0.9.0" + "performance-now" "^2.1.0" + "qs" "~6.5.2" + "safe-buffer" "^5.1.2" + "tough-cookie" "~2.5.0" + "tunnel-agent" "^0.6.0" + "uuid" "^3.3.2" + +"require-directory@^2.1.1": + "integrity" "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" + "resolved" "https://registry.nlark.com/require-directory/download/require-directory-2.1.1.tgz" + "version" "2.1.1" + +"require-main-filename@^2.0.0": + "integrity" "sha1-0LMp7MfMD2Fkn2IhW+aa9UqomJs=" + "resolved" "https://registry.npm.taobao.org/require-main-filename/download/require-main-filename-2.0.0.tgz" + "version" "2.0.0" + +"requires-port@^1.0.0": + "integrity" "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=" + "resolved" "https://registry.npm.taobao.org/requires-port/download/requires-port-1.0.0.tgz" + "version" "1.0.0" + +"resolve-cwd@^2.0.0": + "integrity" "sha1-AKn3OHVW4nA46uIyyqNypqWbZlo=" + "resolved" "https://registry.nlark.com/resolve-cwd/download/resolve-cwd-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "resolve-from" "^3.0.0" + +"resolve-from@^3.0.0": + "integrity" "sha1-six699nWiBvItuZTM17rywoYh0g=" + "resolved" "https://registry.nlark.com/resolve-from/download/resolve-from-3.0.0.tgz" + "version" "3.0.0" + +"resolve-from@^4.0.0": + "integrity" "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" + "resolved" "https://registry.npmmirror.com/resolve-from/-/resolve-from-4.0.0.tgz" + "version" "4.0.0" + +"resolve-url@^0.2.1": + "integrity" "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=" + "resolved" "https://registry.nlark.com/resolve-url/download/resolve-url-0.2.1.tgz" + "version" "0.2.1" + +"resolve@^1.10.0", "resolve@^1.12.0", "resolve@^1.14.2": + "integrity" "sha1-YpoBP7P3B1XW8LeTXMHCxTeLGXU=" + "resolved" "https://registry.npm.taobao.org/resolve/download/resolve-1.20.0.tgz?cache=0&sync_timestamp=1613054862388&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fresolve%2Fdownload%2Fresolve-1.20.0.tgz" + "version" "1.20.0" + dependencies: + "is-core-module" "^2.2.0" + "path-parse" "^1.0.6" + +"restore-cursor@^2.0.0": + "integrity" "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=" + "resolved" "https://registry.nlark.com/restore-cursor/download/restore-cursor-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "onetime" "^2.0.0" + "signal-exit" "^3.0.2" + +"restore-cursor@^3.1.0": + "integrity" "sha1-OfZ8VLOnpYzqUjbZXPADQjljH34=" + "resolved" "https://registry.nlark.com/restore-cursor/download/restore-cursor-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "onetime" "^5.1.0" + "signal-exit" "^3.0.2" + +"ret@~0.1.10": + "integrity" "sha1-uKSCXVvbH8P29Twrwz+BOIaBx7w=" + "resolved" "https://registry.npm.taobao.org/ret/download/ret-0.1.15.tgz?cache=0&sync_timestamp=1613002640681&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fret%2Fdownload%2Fret-0.1.15.tgz" + "version" "0.1.15" + +"retry@^0.12.0": + "integrity" "sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs=" + "resolved" "https://registry.nlark.com/retry/download/retry-0.12.0.tgz" + "version" "0.12.0" + +"reusify@^1.0.4": + "integrity" "sha1-kNo4Kx4SbvwCFG6QhFqI2xKSXXY=" + "resolved" "https://registry.npm.taobao.org/reusify/download/reusify-1.0.4.tgz" + "version" "1.0.4" + +"rgb-regex@^1.0.1": + "integrity" "sha1-wODWiC3w4jviVKR16O3UGRX+rrE=" + "resolved" "https://registry.nlark.com/rgb-regex/download/rgb-regex-1.0.1.tgz" + "version" "1.0.1" + +"rgba-regex@^1.0.0": + "integrity" "sha1-QzdOLiyglosO8VI0YLfXMP8i7rM=" + "resolved" "https://registry.npm.taobao.org/rgba-regex/download/rgba-regex-1.0.0.tgz" + "version" "1.0.0" + +"rimraf@^2.5.4", "rimraf@^2.6.1", "rimraf@^2.6.3": + "integrity" "sha1-NXl/E6f9rcVmFCwp1PB8ytSD4+w=" + "resolved" "https://registry.npm.taobao.org/rimraf/download/rimraf-2.7.1.tgz" + "version" "2.7.1" + dependencies: + "glob" "^7.1.3" + +"rimraf@2.6.3": + "integrity" "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==" + "resolved" "https://registry.npmmirror.com/rimraf/-/rimraf-2.6.3.tgz" + "version" "2.6.3" + dependencies: + "glob" "^7.1.3" + +"ripemd160@^2.0.0", "ripemd160@^2.0.1": + "integrity" "sha1-ocGm9iR1FXe6XQeRTLyShQWFiQw=" + "resolved" "https://registry.npm.taobao.org/ripemd160/download/ripemd160-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "hash-base" "^3.0.0" + "inherits" "^2.0.1" + +"run-async@^2.4.0": + "integrity" "sha1-hEDsz5nqPnC9QJ1JqriOEMGJpFU=" + "resolved" "https://registry.npm.taobao.org/run-async/download/run-async-2.4.1.tgz" + "version" "2.4.1" + +"run-parallel@^1.1.9": + "integrity" "sha1-ZtE2jae9+SHrnZW9GpIp5/IaQ+4=" + "resolved" "https://registry.npm.taobao.org/run-parallel/download/run-parallel-1.2.0.tgz?cache=0&sync_timestamp=1612925912322&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Frun-parallel%2Fdownload%2Frun-parallel-1.2.0.tgz" + "version" "1.2.0" + dependencies: + "queue-microtask" "^1.2.2" + +"run-queue@^1.0.0", "run-queue@^1.0.3": + "integrity" "sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec=" + "resolved" "https://registry.npm.taobao.org/run-queue/download/run-queue-1.0.3.tgz" + "version" "1.0.3" + dependencies: + "aproba" "^1.1.1" + +"rxjs@^6.6.0": + "integrity" "sha1-kKwBisq/SRv2UEQjXVhjxNq4BMk=" + "resolved" "https://registry.nlark.com/rxjs/download/rxjs-6.6.7.tgz" + "version" "6.6.7" + dependencies: + "tslib" "^1.9.0" + +"safe-buffer@^5.0.1", "safe-buffer@^5.1.0", "safe-buffer@^5.1.1", "safe-buffer@^5.1.2", "safe-buffer@>=5.1.0", "safe-buffer@~5.1.0", "safe-buffer@~5.1.1", "safe-buffer@5.1.2": + "integrity" "sha1-mR7GnSluAxN0fVm9/St0XDX4go0=" + "resolved" "https://registry.npm.taobao.org/safe-buffer/download/safe-buffer-5.1.2.tgz" + "version" "5.1.2" + +"safe-buffer@^5.2.0": + "integrity" "sha1-Hq+fqb2x/dTsdfWPnNtOa3gn7sY=" + "resolved" "https://registry.npm.taobao.org/safe-buffer/download/safe-buffer-5.2.1.tgz" + "version" "5.2.1" + +"safe-regex@^1.1.0": + "integrity" "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=" + "resolved" "https://registry.nlark.com/safe-regex/download/safe-regex-1.1.0.tgz" + "version" "1.1.0" + dependencies: + "ret" "~0.1.10" + +"safer-buffer@^2.0.2", "safer-buffer@^2.1.0", "safer-buffer@^2.1.2", "safer-buffer@>= 2.1.2 < 3", "safer-buffer@~2.1.0": + "integrity" "sha1-RPoWGwGHuVSd2Eu5GAL5vYOFzWo=" + "resolved" "https://registry.nlark.com/safer-buffer/download/safer-buffer-2.1.2.tgz" + "version" "2.1.2" + +"sax@^1.2.4", "sax@>=0.6.0", "sax@~1.2.4": + "integrity" "sha1-KBYjTiN4vdxOU1T6tcqold9xANk=" + "resolved" "https://registry.nlark.com/sax/download/sax-1.2.4.tgz" + "version" "1.2.4" + +"saxes@^3.1.9": + "integrity" "sha1-1Z0f0zLskq2YouCy7mRHAjhLHFs=" + "resolved" "https://registry.npm.taobao.org/saxes/download/saxes-3.1.11.tgz" + "version" "3.1.11" + dependencies: + "xmlchars" "^2.1.1" + +"schema-utils@^1.0.0": + "integrity" "sha1-C3mpMgTXtgDUsoUNH2bCo0lRx3A=" + "resolved" "https://registry.nlark.com/schema-utils/download/schema-utils-1.0.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "ajv" "^6.1.0" + "ajv-errors" "^1.0.0" + "ajv-keywords" "^3.1.0" + +"schema-utils@^2.0.0", "schema-utils@^2.5.0", "schema-utils@^2.6.5", "schema-utils@^2.7.0": + "integrity" "sha1-HKTzLRskxZDCA7jnpQvw6kzTlNc=" + "resolved" "https://registry.nlark.com/schema-utils/download/schema-utils-2.7.1.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-2.7.1.tgz" + "version" "2.7.1" + dependencies: + "@types/json-schema" "^7.0.5" + "ajv" "^6.12.4" + "ajv-keywords" "^3.5.2" + +"schema-utils@^3.0.0": + "integrity" "sha1-lZhutgT2bare7Vbjeb/np/ljzbk=" + "resolved" "https://registry.nlark.com/schema-utils/download/schema-utils-3.1.0.tgz?cache=0&sync_timestamp=1625484933876&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fschema-utils%2Fdownload%2Fschema-utils-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "@types/json-schema" "^7.0.7" + "ajv" "^6.12.5" + "ajv-keywords" "^3.5.2" + +"sdk-base@^2.0.1": + "integrity" "sha512-eeG26wRwhtwYuKGCDM3LixCaxY27Pa/5lK4rLKhQa7HBjJ3U3Y+f81MMZQRsDw/8SC2Dao/83yJTXJ8aULuN8Q==" + "resolved" "https://registry.npmmirror.com/sdk-base/-/sdk-base-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "get-ready" "~1.0.0" + +"select-hose@^2.0.0": + "integrity" "sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo=" + "resolved" "https://registry.npm.taobao.org/select-hose/download/select-hose-2.0.0.tgz" + "version" "2.0.0" + +"selfsigned@^1.10.8": + "integrity" "sha1-JJKc2Qb+D0S20B+yOZmnOVN6y+k=" + "resolved" "https://registry.nlark.com/selfsigned/download/selfsigned-1.10.11.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fselfsigned%2Fdownload%2Fselfsigned-1.10.11.tgz" + "version" "1.10.11" + dependencies: + "node-forge" "^0.10.0" + +"semver@^5.0.1": + "integrity" "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + "resolved" "https://registry.npmmirror.com/semver/-/semver-5.7.1.tgz" + "version" "5.7.1" + +"semver@^5.5.0": + "integrity" "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=" + "resolved" "https://registry.nlark.com/semver/download/semver-5.7.1.tgz" + "version" "5.7.1" + +"semver@^5.6.0": + "integrity" "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=" + "resolved" "https://registry.nlark.com/semver/download/semver-5.7.1.tgz" + "version" "5.7.1" + +"semver@^5.7.0": + "integrity" "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=" + "resolved" "https://registry.nlark.com/semver/download/semver-5.7.1.tgz" + "version" "5.7.1" + +"semver@^6.0.0", "semver@^6.1.0", "semver@^6.1.1", "semver@^6.1.2", "semver@^6.3.0": + "integrity" "sha1-7gpkyK9ejO6mdoexM3YeG+y9HT0=" + "resolved" "https://registry.nlark.com/semver/download/semver-6.3.0.tgz" + "version" "6.3.0" + +"semver@2 || 3 || 4 || 5": + "integrity" "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=" + "resolved" "https://registry.nlark.com/semver/download/semver-5.7.1.tgz" + "version" "5.7.1" + +"semver@7.0.0": + "integrity" "sha1-XzyjV2HkfgWyBsba/yz4FPAxa44=" + "resolved" "https://registry.nlark.com/semver/download/semver-7.0.0.tgz" + "version" "7.0.0" + +"send@0.17.1": + "integrity" "sha1-wdiwWfeQD3Rm3Uk4vcROEd2zdsg=" + "resolved" "https://registry.npm.taobao.org/send/download/send-0.17.1.tgz" + "version" "0.17.1" + dependencies: + "debug" "2.6.9" + "depd" "~1.1.2" + "destroy" "~1.0.4" + "encodeurl" "~1.0.2" + "escape-html" "~1.0.3" + "etag" "~1.8.1" + "fresh" "0.5.2" + "http-errors" "~1.7.2" + "mime" "1.6.0" + "ms" "2.1.1" + "on-finished" "~2.3.0" + "range-parser" "~1.2.1" + "statuses" "~1.5.0" + +"serialize-javascript@^4.0.0": + "integrity" "sha1-tSXhI4SJpez8Qq+sw/6Z5mb0sao=" + "resolved" "https://registry.nlark.com/serialize-javascript/download/serialize-javascript-4.0.0.tgz" + "version" "4.0.0" + dependencies: + "randombytes" "^2.1.0" + +"serve-index@^1.9.1": + "integrity" "sha1-03aNabHn2C5c4FD/9bRTvqEqkjk=" + "resolved" "https://registry.npm.taobao.org/serve-index/download/serve-index-1.9.1.tgz" + "version" "1.9.1" + dependencies: + "accepts" "~1.3.4" + "batch" "0.6.1" + "debug" "2.6.9" + "escape-html" "~1.0.3" + "http-errors" "~1.6.2" + "mime-types" "~2.1.17" + "parseurl" "~1.3.2" + +"serve-static@1.14.1": + "integrity" "sha1-Zm5jbcTwEPfvKZcKiKZ0MgiYsvk=" + "resolved" "https://registry.npm.taobao.org/serve-static/download/serve-static-1.14.1.tgz" + "version" "1.14.1" + dependencies: + "encodeurl" "~1.0.2" + "escape-html" "~1.0.3" + "parseurl" "~1.3.3" + "send" "0.17.1" + +"set-blocking@^2.0.0": + "integrity" "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" + "resolved" "https://registry.nlark.com/set-blocking/download/set-blocking-2.0.0.tgz" + "version" "2.0.0" + +"set-value@^2.0.0", "set-value@^2.0.1": + "integrity" "sha1-oY1AUw5vB95CKMfe/kInr4ytAFs=" + "resolved" "https://registry.nlark.com/set-value/download/set-value-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "extend-shallow" "^2.0.1" + "is-extendable" "^0.1.1" + "is-plain-object" "^2.0.3" + "split-string" "^3.0.1" + +"setimmediate@^1.0.4": + "integrity" "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=" + "resolved" "https://registry.npm.taobao.org/setimmediate/download/setimmediate-1.0.5.tgz" + "version" "1.0.5" + +"setprototypeof@1.1.0": + "integrity" "sha1-0L2FU2iHtv58DYGMuWLZ2RxU5lY=" + "resolved" "https://registry.nlark.com/setprototypeof/download/setprototypeof-1.1.0.tgz" + "version" "1.1.0" + +"setprototypeof@1.1.1": + "integrity" "sha1-fpWsskqpL1iF4KvvW6ExMw1K5oM=" + "resolved" "https://registry.nlark.com/setprototypeof/download/setprototypeof-1.1.1.tgz" + "version" "1.1.1" + +"sha.js@^2.4.0", "sha.js@^2.4.8": + "integrity" "sha1-N6XPC4HsvGlD3hCbopYNGyZYSuc=" + "resolved" "https://registry.npm.taobao.org/sha.js/download/sha.js-2.4.11.tgz" + "version" "2.4.11" + dependencies: + "inherits" "^2.0.1" + "safe-buffer" "^5.0.1" + +"shebang-command@^1.2.0": + "integrity" "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=" + "resolved" "https://registry.npm.taobao.org/shebang-command/download/shebang-command-1.2.0.tgz" + "version" "1.2.0" + dependencies: + "shebang-regex" "^1.0.0" + +"shebang-command@^2.0.0": + "integrity" "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==" + "resolved" "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "shebang-regex" "^3.0.0" + +"shebang-regex@^1.0.0": + "integrity" "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" + "resolved" "https://registry.npm.taobao.org/shebang-regex/download/shebang-regex-1.0.0.tgz" + "version" "1.0.0" + +"shebang-regex@^3.0.0": + "integrity" "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==" + "resolved" "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz" + "version" "3.0.0" + +"shell-quote@^1.6.1": + "integrity" "sha1-Z6fQLHbJ2iT5nSCAj8re0ODgS+I=" + "resolved" "https://registry.npm.taobao.org/shell-quote/download/shell-quote-1.7.2.tgz" + "version" "1.7.2" + +"signal-exit@^3.0.0", "signal-exit@^3.0.2": + "integrity" "sha1-oUEMLt2PB3sItOJTyOrPyvBXRhw=" + "resolved" "https://registry.npm.taobao.org/signal-exit/download/signal-exit-3.0.3.tgz" + "version" "3.0.3" + +"simple-swizzle@^0.2.2": + "integrity" "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=" + "resolved" "https://registry.nlark.com/simple-swizzle/download/simple-swizzle-0.2.2.tgz" + "version" "0.2.2" + dependencies: + "is-arrayish" "^0.3.1" + +"slash@^1.0.0": + "integrity" "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=" + "resolved" "https://registry.npm.taobao.org/slash/download/slash-1.0.0.tgz" + "version" "1.0.0" + +"slash@^2.0.0": + "integrity" "sha1-3lUoUaF1nfOo8gZTVEL17E3eq0Q=" + "resolved" "https://registry.npm.taobao.org/slash/download/slash-2.0.0.tgz" + "version" "2.0.0" + +"slash@^3.0.0": + "integrity" "sha1-ZTm+hwwWWtvVJAIg2+Nh8bxNRjQ=" + "resolved" "https://registry.npm.taobao.org/slash/download/slash-3.0.0.tgz" + "version" "3.0.0" + +"slice-ansi@^2.1.0": + "integrity" "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==" + "resolved" "https://registry.npmmirror.com/slice-ansi/-/slice-ansi-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "ansi-styles" "^3.2.0" + "astral-regex" "^1.0.0" + "is-fullwidth-code-point" "^2.0.0" + +"smart-buffer@^4.2.0": + "integrity" "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" + "resolved" "https://registry.npmmirror.com/smart-buffer/-/smart-buffer-4.2.0.tgz" + "version" "4.2.0" + +"snapdragon-node@^2.0.1": + "integrity" "sha1-bBdfhv8UvbByRWPo88GwIaKGhTs=" + "resolved" "https://registry.nlark.com/snapdragon-node/download/snapdragon-node-2.1.1.tgz" + "version" "2.1.1" + dependencies: + "define-property" "^1.0.0" + "isobject" "^3.0.0" + "snapdragon-util" "^3.0.1" + +"snapdragon-util@^3.0.1": + "integrity" "sha1-+VZHlIbyrNeXAGk/b3uAXkWrVuI=" + "resolved" "https://registry.npm.taobao.org/snapdragon-util/download/snapdragon-util-3.0.1.tgz" + "version" "3.0.1" + dependencies: + "kind-of" "^3.2.0" + +"snapdragon@^0.8.1": + "integrity" "sha1-ZJIufFZbDhQgS6GqfWlkJ40lGC0=" + "resolved" "https://registry.npm.taobao.org/snapdragon/download/snapdragon-0.8.2.tgz" + "version" "0.8.2" + dependencies: + "base" "^0.11.1" + "debug" "^2.2.0" + "define-property" "^0.2.5" + "extend-shallow" "^2.0.1" + "map-cache" "^0.2.2" + "source-map" "^0.5.6" + "source-map-resolve" "^0.5.0" + "use" "^3.1.0" + +"sockjs-client@^1.5.0": + "integrity" "sha1-JWkI9tWt+5Tau9vQLGY2LMoPnqY=" + "resolved" "https://registry.npm.taobao.org/sockjs-client/download/sockjs-client-1.5.1.tgz" + "version" "1.5.1" + dependencies: + "debug" "^3.2.6" + "eventsource" "^1.0.7" + "faye-websocket" "^0.11.3" + "inherits" "^2.0.4" + "json3" "^3.3.3" + "url-parse" "^1.5.1" + +"sockjs@^0.3.21": + "integrity" "sha1-s0/7mOeWkwtgoM+hGQTWozmn1Bc=" + "resolved" "https://registry.nlark.com/sockjs/download/sockjs-0.3.21.tgz" + "version" "0.3.21" + dependencies: + "faye-websocket" "^0.11.3" + "uuid" "^3.4.0" + "websocket-driver" "^0.7.4" + +"socks-proxy-agent@^5.0.0", "socks-proxy-agent@5": + "integrity" "sha512-vZdmnjb9a2Tz6WEQVIurybSwElwPxMZaIc7PzqbJTrezcKNznv6giT7J7tZDZ1BojVaa1jvO/UiUdhDVB0ACoQ==" + "resolved" "https://registry.npmmirror.com/socks-proxy-agent/-/socks-proxy-agent-5.0.1.tgz" + "version" "5.0.1" + dependencies: + "agent-base" "^6.0.2" + "debug" "4" + "socks" "^2.3.3" + +"socks@^2.3.3": + "integrity" "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==" + "resolved" "https://registry.npmmirror.com/socks/-/socks-2.7.1.tgz" + "version" "2.7.1" + dependencies: + "ip" "^2.0.0" + "smart-buffer" "^4.2.0" + +"sort-keys@^1.0.0": + "integrity" "sha1-RBttTTRnmPG05J6JIK37oOVD+a0=" + "resolved" "https://registry.npm.taobao.org/sort-keys/download/sort-keys-1.1.2.tgz" + "version" "1.1.2" + dependencies: + "is-plain-obj" "^1.0.0" + +"sortablejs@^1.13.0": + "integrity" "sha512-bv9qgVMjUMf89wAvM6AxVvS/4MX3sPeN0+agqShejLU5z5GX4C75ow1O2e5k4L6XItUyAK3gH6AxSbXrOM5e8w==" + "resolved" "https://registry.npmmirror.com/sortablejs/-/sortablejs-1.15.0.tgz" + "version" "1.15.0" + +"source-list-map@^2.0.0": + "integrity" "sha1-OZO9hzv8SEecyp6jpUeDXHwVSzQ=" + "resolved" "https://registry.nlark.com/source-list-map/download/source-list-map-2.0.1.tgz" + "version" "2.0.1" + +"source-map-js@^0.6.2": + "integrity" "sha1-C7XeYxtBz72mz7qL0FqA79/SOF4=" + "resolved" "https://registry.npm.taobao.org/source-map-js/download/source-map-js-0.6.2.tgz" + "version" "0.6.2" + +"source-map-resolve@^0.5.0", "source-map-resolve@^0.5.2": + "integrity" "sha1-GQhmvs51U+H48mei7oLGBrVQmho=" + "resolved" "https://registry.nlark.com/source-map-resolve/download/source-map-resolve-0.5.3.tgz" + "version" "0.5.3" + dependencies: + "atob" "^2.1.2" + "decode-uri-component" "^0.2.0" + "resolve-url" "^0.2.1" + "source-map-url" "^0.4.0" + "urix" "^0.1.0" + +"source-map-support@^0.5.13", "source-map-support@~0.5.12": + "integrity" "sha1-qYti+G3K9PZzmWSMCFKRq56P7WE=" + "resolved" "https://registry.nlark.com/source-map-support/download/source-map-support-0.5.19.tgz" + "version" "0.5.19" + dependencies: + "buffer-from" "^1.0.0" + "source-map" "^0.6.0" + +"source-map-url@^0.4.0": + "integrity" "sha1-CvZmBadFpaL5HPG7+KevvCg97FY=" + "resolved" "https://registry.npm.taobao.org/source-map-url/download/source-map-url-0.4.1.tgz?cache=0&sync_timestamp=1612210508484&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fsource-map-url%2Fdownload%2Fsource-map-url-0.4.1.tgz" + "version" "0.4.1" + +"source-map@^0.5.0", "source-map@^0.5.6": + "integrity" "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" + "resolved" "https://registry.npm.taobao.org/source-map/download/source-map-0.5.7.tgz" + "version" "0.5.7" + +"source-map@^0.6.0": + "integrity" "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=" + "resolved" "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz" + "version" "0.6.1" + +"source-map@^0.6.1": + "integrity" "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=" + "resolved" "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz" + "version" "0.6.1" + +"source-map@^0.7.3": + "integrity" "sha1-UwL4FpAxc1ImVECS5kmB91F1A4M=" + "resolved" "https://registry.npm.taobao.org/source-map/download/source-map-0.7.3.tgz" + "version" "0.7.3" + +"source-map@~0.6.0": + "integrity" "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=" + "resolved" "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz" + "version" "0.6.1" + +"source-map@~0.6.1": + "integrity" "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=" + "resolved" "https://registry.npm.taobao.org/source-map/download/source-map-0.6.1.tgz" + "version" "0.6.1" + +"sourcemap-codec@^1.4.4": + "integrity" "sha1-6oBL2UhXQC5pktBaOO8a41qatMQ=" + "resolved" "https://registry.npm.taobao.org/sourcemap-codec/download/sourcemap-codec-1.4.8.tgz" + "version" "1.4.8" + +"spdx-correct@^3.0.0": + "integrity" "sha1-3s6BrJweZxPl99G28X1Gj6U9iak=" + "resolved" "https://registry.npm.taobao.org/spdx-correct/download/spdx-correct-3.1.1.tgz" + "version" "3.1.1" + dependencies: + "spdx-expression-parse" "^3.0.0" + "spdx-license-ids" "^3.0.0" + +"spdx-exceptions@^2.1.0": + "integrity" "sha1-PyjOGnegA3JoPq3kpDMYNSeiFj0=" + "resolved" "https://registry.npm.taobao.org/spdx-exceptions/download/spdx-exceptions-2.3.0.tgz" + "version" "2.3.0" + +"spdx-expression-parse@^3.0.0": + "integrity" "sha1-z3D1BILu/cmOPOCmgz5KU87rpnk=" + "resolved" "https://registry.npm.taobao.org/spdx-expression-parse/download/spdx-expression-parse-3.0.1.tgz" + "version" "3.0.1" + dependencies: + "spdx-exceptions" "^2.1.0" + "spdx-license-ids" "^3.0.0" + +"spdx-license-ids@^3.0.0": + "integrity" "sha1-illRNd75WSvaaXCUdPHL7qfCRn8=" + "resolved" "https://registry.nlark.com/spdx-license-ids/download/spdx-license-ids-3.0.9.tgz" + "version" "3.0.9" + +"spdy-transport@^3.0.0": + "integrity" "sha1-ANSGOmQArXXfkzYaFghgXl3NzzE=" + "resolved" "https://registry.npm.taobao.org/spdy-transport/download/spdy-transport-3.0.0.tgz" + "version" "3.0.0" + dependencies: + "debug" "^4.1.0" + "detect-node" "^2.0.4" + "hpack.js" "^2.1.6" + "obuf" "^1.1.2" + "readable-stream" "^3.0.6" + "wbuf" "^1.7.3" + +"spdy@^4.0.2": + "integrity" "sha1-t09GYgOj7aRSwCSSuR+56EonZ3s=" + "resolved" "https://registry.npm.taobao.org/spdy/download/spdy-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "debug" "^4.1.0" + "handle-thing" "^2.0.0" + "http-deceiver" "^1.2.7" + "select-hose" "^2.0.0" + "spdy-transport" "^3.0.0" + +"split-string@^3.0.1", "split-string@^3.0.2": + "integrity" "sha1-fLCd2jqGWFcFxks5pkZgOGguj+I=" + "resolved" "https://registry.npm.taobao.org/split-string/download/split-string-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "extend-shallow" "^3.0.0" + +"sprintf-js@~1.0.2": + "integrity" "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" + "resolved" "https://registry.nlark.com/sprintf-js/download/sprintf-js-1.0.3.tgz" + "version" "1.0.3" + +"sshpk@^1.7.0": + "integrity" "sha1-+2YcC+8ps520B2nuOfpwCT1vaHc=" + "resolved" "https://registry.nlark.com/sshpk/download/sshpk-1.16.1.tgz" + "version" "1.16.1" + dependencies: + "asn1" "~0.2.3" + "assert-plus" "^1.0.0" + "bcrypt-pbkdf" "^1.0.0" + "dashdash" "^1.12.0" + "ecc-jsbn" "~0.1.1" + "getpass" "^0.1.1" + "jsbn" "~0.1.0" + "safer-buffer" "^2.0.2" + "tweetnacl" "~0.14.0" + +"ssri@^6.0.1": + "integrity" "sha1-FXk5E08gRk5zAd26PpD/qPdyisU=" + "resolved" "https://registry.nlark.com/ssri/download/ssri-6.0.2.tgz?cache=0&sync_timestamp=1621364918494&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fssri%2Fdownload%2Fssri-6.0.2.tgz" + "version" "6.0.2" + dependencies: + "figgy-pudding" "^3.5.1" + +"ssri@^8.0.1": + "integrity" "sha1-Y45OQ54v+9LNKJd21cpFfE9Roq8=" + "resolved" "https://registry.nlark.com/ssri/download/ssri-8.0.1.tgz?cache=0&sync_timestamp=1621364918494&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fssri%2Fdownload%2Fssri-8.0.1.tgz" + "version" "8.0.1" + dependencies: + "minipass" "^3.1.1" + +"stable@^0.1.8": + "integrity" "sha1-g26zyDgv4pNv6vVEYxAXzn1Ho88=" + "resolved" "https://registry.npm.taobao.org/stable/download/stable-0.1.8.tgz" + "version" "0.1.8" + +"stackframe@^1.1.1": + "integrity" "sha1-UkKUktY8YuuYmATBFVLj0i53kwM=" + "resolved" "https://registry.npm.taobao.org/stackframe/download/stackframe-1.2.0.tgz" + "version" "1.2.0" + +"static-extend@^0.1.1": + "integrity" "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=" + "resolved" "https://registry.npm.taobao.org/static-extend/download/static-extend-0.1.2.tgz" + "version" "0.1.2" + dependencies: + "define-property" "^0.2.5" + "object-copy" "^0.1.0" + +"statuses@^1.3.1", "statuses@>= 1.4.0 < 2", "statuses@>= 1.5.0 < 2", "statuses@~1.5.0": + "integrity" "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" + "resolved" "https://registry.nlark.com/statuses/download/statuses-1.5.0.tgz" + "version" "1.5.0" + +"stealthy-require@^1.1.1": + "integrity" "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=" + "resolved" "https://registry.npm.taobao.org/stealthy-require/download/stealthy-require-1.1.1.tgz" + "version" "1.1.1" + +"stream-browserify@^2.0.1": + "integrity" "sha1-h1IdOKRKp+6RzhzSpH3wy0ndZgs=" + "resolved" "https://registry.npm.taobao.org/stream-browserify/download/stream-browserify-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "inherits" "~2.0.1" + "readable-stream" "^2.0.2" + +"stream-each@^1.1.0": + "integrity" "sha1-6+J6DDibBPvMIzZClS4Qcxr6m64=" + "resolved" "https://registry.npm.taobao.org/stream-each/download/stream-each-1.2.3.tgz" + "version" "1.2.3" + dependencies: + "end-of-stream" "^1.1.0" + "stream-shift" "^1.0.0" + +"stream-http@^2.7.2", "stream-http@2.8.2": + "integrity" "sha512-QllfrBhqF1DPcz46WxKTs6Mz1Bpc+8Qm6vbqOpVav5odAXwbyzwnEczoWqtxrsmlO+cJqtPrp/8gWKWjaKLLlA==" + "resolved" "https://registry.npmmirror.com/stream-http/-/stream-http-2.8.2.tgz" + "version" "2.8.2" + dependencies: + "builtin-status-codes" "^3.0.0" + "inherits" "^2.0.1" + "readable-stream" "^2.3.6" + "to-arraybuffer" "^1.0.0" + "xtend" "^4.0.0" + +"stream-shift@^1.0.0": + "integrity" "sha1-1wiCgVWasneEJCebCHfaPDktWj0=" + "resolved" "https://registry.npm.taobao.org/stream-shift/download/stream-shift-1.0.1.tgz" + "version" "1.0.1" + +"stream-wormhole@^1.0.4": + "integrity" "sha512-gHFfL3px0Kctd6Po0M8TzEvt3De/xu6cnRrjlfYNhwbhLPLwigI2t1nc6jrzNuaYg5C4YF78PPFuQPzRiqn9ew==" + "resolved" "https://registry.npmmirror.com/stream-wormhole/-/stream-wormhole-1.1.0.tgz" + "version" "1.1.0" + +"strict-uri-encode@^1.0.0": + "integrity" "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=" + "resolved" "https://registry.npm.taobao.org/strict-uri-encode/download/strict-uri-encode-1.1.0.tgz" + "version" "1.1.0" + +"string_decoder@^1.0.0", "string_decoder@^1.1.1", "string_decoder@~1.1.1": + "integrity" "sha1-nPFhG6YmhdcDCunkujQUnDrwP8g=" + "resolved" "https://registry.nlark.com/string_decoder/download/string_decoder-1.1.1.tgz" + "version" "1.1.1" + dependencies: + "safe-buffer" "~5.1.0" + +"string_decoder@~0.10.x": + "integrity" "sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ==" + "resolved" "https://registry.npmmirror.com/string_decoder/-/string_decoder-0.10.31.tgz" + "version" "0.10.31" + +"string-width@^1.0.2 || 2", "string-width@^2.0.0": + "integrity" "sha1-q5Pyeo3BPSjKyBXEYhQ6bZASrp4=" + "resolved" "https://registry.nlark.com/string-width/download/string-width-2.1.1.tgz" + "version" "2.1.1" + dependencies: + "is-fullwidth-code-point" "^2.0.0" + "strip-ansi" "^4.0.0" + +"string-width@^3.0.0", "string-width@^3.1.0": + "integrity" "sha1-InZ74htirxCBV0MG9prFG2IgOWE=" + "resolved" "https://registry.nlark.com/string-width/download/string-width-3.1.0.tgz" + "version" "3.1.0" + dependencies: + "emoji-regex" "^7.0.1" + "is-fullwidth-code-point" "^2.0.0" + "strip-ansi" "^5.1.0" + +"string-width@^4.1.0", "string-width@^4.2.0": + "integrity" "sha1-2v1PlVmnWFz7pSnGoKT3NIjr1MU=" + "resolved" "https://registry.nlark.com/string-width/download/string-width-4.2.2.tgz" + "version" "4.2.2" + dependencies: + "emoji-regex" "^8.0.0" + "is-fullwidth-code-point" "^3.0.0" + "strip-ansi" "^6.0.0" + +"string.prototype.trimend@^1.0.4": + "integrity" "sha1-51rpDClCxjUEaGwYsoe0oLGkX4A=" + "resolved" "https://registry.npm.taobao.org/string.prototype.trimend/download/string.prototype.trimend-1.0.4.tgz" + "version" "1.0.4" + dependencies: + "call-bind" "^1.0.2" + "define-properties" "^1.1.3" + +"string.prototype.trimstart@^1.0.4": + "integrity" "sha1-s2OZr0qymZtMnGSL16P7K7Jv7u0=" + "resolved" "https://registry.npm.taobao.org/string.prototype.trimstart/download/string.prototype.trimstart-1.0.4.tgz?cache=0&sync_timestamp=1614127357785&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fstring.prototype.trimstart%2Fdownload%2Fstring.prototype.trimstart-1.0.4.tgz" + "version" "1.0.4" + dependencies: + "call-bind" "^1.0.2" + "define-properties" "^1.1.3" + +"strip-ansi@^3.0.1": + "integrity" "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=" + "resolved" "https://registry.nlark.com/strip-ansi/download/strip-ansi-3.0.1.tgz" + "version" "3.0.1" + dependencies: + "ansi-regex" "^2.0.0" + +"strip-ansi@^4.0.0": + "integrity" "sha1-qEeQIusaw2iocTibY1JixQXuNo8=" + "resolved" "https://registry.nlark.com/strip-ansi/download/strip-ansi-4.0.0.tgz" + "version" "4.0.0" + dependencies: + "ansi-regex" "^3.0.0" + +"strip-ansi@^5", "strip-ansi@^5.0.0", "strip-ansi@^5.1.0", "strip-ansi@^5.2.0": + "integrity" "sha1-jJpTb+tq/JYr36WxBKUJHBrZwK4=" + "resolved" "https://registry.nlark.com/strip-ansi/download/strip-ansi-5.2.0.tgz" + "version" "5.2.0" + dependencies: + "ansi-regex" "^4.1.0" + +"strip-ansi@^6.0.0": + "integrity" "sha1-CxVx3XZpzNTz4G4U7x7tJiJa5TI=" + "resolved" "https://registry.nlark.com/strip-ansi/download/strip-ansi-6.0.0.tgz" + "version" "6.0.0" + dependencies: + "ansi-regex" "^5.0.0" + +"strip-eof@^1.0.0": + "integrity" "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=" + "resolved" "https://registry.npm.taobao.org/strip-eof/download/strip-eof-1.0.0.tgz" + "version" "1.0.0" + +"strip-final-newline@^2.0.0": + "integrity" "sha1-ibhS+y/L6Tb29LMYevsKEsGrWK0=" + "resolved" "https://registry.nlark.com/strip-final-newline/download/strip-final-newline-2.0.0.tgz" + "version" "2.0.0" + +"strip-indent@^2.0.0": + "integrity" "sha1-XvjbKV0B5u1sv3qrlpmNeCJSe2g=" + "resolved" "https://registry.nlark.com/strip-indent/download/strip-indent-2.0.0.tgz?cache=0&sync_timestamp=1620053263051&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fstrip-indent%2Fdownload%2Fstrip-indent-2.0.0.tgz" + "version" "2.0.0" + +"strip-json-comments@^3.0.1": + "integrity" "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==" + "resolved" "https://registry.npmmirror.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz" + "version" "3.1.1" + +"strip-json-comments@2.0.1": + "integrity" "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" + "resolved" "https://registry.npm.taobao.org/strip-json-comments/download/strip-json-comments-2.0.1.tgz" + "version" "2.0.1" + +"stylehacks@^4.0.0": + "integrity" "sha1-Zxj8r00eB9ihMYaQiB6NlnJqcdU=" + "resolved" "https://registry.nlark.com/stylehacks/download/stylehacks-4.0.3.tgz" + "version" "4.0.3" + dependencies: + "browserslist" "^4.0.0" + "postcss" "^7.0.0" + "postcss-selector-parser" "^3.0.0" + +"stylus-loader@^3.0.2": + "integrity" "sha1-J6cGQgsFo44DjnyssVNXjUUFE8Y=" + "resolved" "https://registry.nlark.com/stylus-loader/download/stylus-loader-3.0.2.tgz" + "version" "3.0.2" + dependencies: + "loader-utils" "^1.0.2" + "lodash.clonedeep" "^4.5.0" + "when" "~3.6.x" + +"stylus@^0.54.7", "stylus@>=0.52.4": + "integrity" "sha1-PaPmWWa8Vnp7BEv+DuzmU+CZ0Uc=" + "resolved" "https://registry.npm.taobao.org/stylus/download/stylus-0.54.8.tgz?cache=0&sync_timestamp=1594901358297&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fstylus%2Fdownload%2Fstylus-0.54.8.tgz" + "version" "0.54.8" + dependencies: + "css-parse" "~2.0.0" + "debug" "~3.1.0" + "glob" "^7.1.6" + "mkdirp" "~1.0.4" + "safer-buffer" "^2.1.2" + "sax" "~1.2.4" + "semver" "^6.3.0" + "source-map" "^0.7.3" + +"supports-color@^5.3.0": + "integrity" "sha1-4uaaRKyHcveKHsCzW2id9lMO/I8=" + "resolved" "https://registry.nlark.com/supports-color/download/supports-color-5.5.0.tgz" + "version" "5.5.0" + dependencies: + "has-flag" "^3.0.0" + +"supports-color@^6.1.0": + "integrity" "sha1-B2Srxpxj1ayELdSGfo0CXogN+PM=" + "resolved" "https://registry.nlark.com/supports-color/download/supports-color-6.1.0.tgz" + "version" "6.1.0" + dependencies: + "has-flag" "^3.0.0" + +"supports-color@^7.1.0": + "integrity" "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==" + "resolved" "https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz" + "version" "7.2.0" + dependencies: + "has-flag" "^4.0.0" + +"supports-color@6.0.0": + "integrity" "sha1-ds/nQs8fQbubHCmtAwaMBbTA5Ao=" + "resolved" "https://registry.nlark.com/supports-color/download/supports-color-6.0.0.tgz" + "version" "6.0.0" + dependencies: + "has-flag" "^3.0.0" + +"svg-tags@^1.0.0": + "integrity" "sha1-WPcc7jvVGbWdSyqEO2x95krAR2Q=" + "resolved" "https://registry.nlark.com/svg-tags/download/svg-tags-1.0.0.tgz" + "version" "1.0.0" + +"svgo@^1.0.0": + "integrity" "sha1-ttxRHAYzRsnkFbgeQ0ARRbltQWc=" + "resolved" "https://registry.nlark.com/svgo/download/svgo-1.3.2.tgz" + "version" "1.3.2" + dependencies: + "chalk" "^2.4.1" + "coa" "^2.0.2" + "css-select" "^2.0.0" + "css-select-base-adapter" "^0.1.1" + "css-tree" "1.0.0-alpha.37" + "csso" "^4.0.2" + "js-yaml" "^3.13.1" + "mkdirp" "~0.5.1" + "object.values" "^1.1.0" + "sax" "~1.2.4" + "stable" "^0.1.8" + "unquote" "~1.1.1" + "util.promisify" "~1.0.0" + +"symbol-tree@^3.2.2": + "integrity" "sha1-QwY30ki6d+B4iDlR+5qg7tfGP6I=" + "resolved" "https://registry.npm.taobao.org/symbol-tree/download/symbol-tree-3.2.4.tgz" + "version" "3.2.4" + +"table@^5.2.3": + "integrity" "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==" + "resolved" "https://registry.npmmirror.com/table/-/table-5.4.6.tgz" + "version" "5.4.6" + dependencies: + "ajv" "^6.10.2" + "lodash" "^4.17.14" + "slice-ansi" "^2.1.0" + "string-width" "^3.0.0" + +"tapable@^1.0.0", "tapable@^1.1.3": + "integrity" "sha1-ofzMBrWNth/XpF2i2kT186Pme6I=" + "resolved" "https://registry.nlark.com/tapable/download/tapable-1.1.3.tgz" + "version" "1.1.3" + +"terser-webpack-plugin@^1.4.3", "terser-webpack-plugin@^1.4.4": + "integrity" "sha1-oheu+uozDnNP+sthIOwfoxLWBAs=" + "resolved" "https://registry.nlark.com/terser-webpack-plugin/download/terser-webpack-plugin-1.4.5.tgz?cache=0&sync_timestamp=1624624486956&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fterser-webpack-plugin%2Fdownload%2Fterser-webpack-plugin-1.4.5.tgz" + "version" "1.4.5" + dependencies: + "cacache" "^12.0.2" + "find-cache-dir" "^2.1.0" + "is-wsl" "^1.1.0" + "schema-utils" "^1.0.0" + "serialize-javascript" "^4.0.0" + "source-map" "^0.6.1" + "terser" "^4.1.2" + "webpack-sources" "^1.4.0" + "worker-farm" "^1.7.0" + +"terser@^4.1.2": + "integrity" "sha1-YwVjQ9fHC7KfOvZlhlpG/gOg3xc=" + "resolved" "https://registry.nlark.com/terser/download/terser-4.8.0.tgz" + "version" "4.8.0" + dependencies: + "commander" "^2.20.0" + "source-map" "~0.6.1" + "source-map-support" "~0.5.12" + +"text-table@^0.2.0": + "integrity" "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==" + "resolved" "https://registry.npmmirror.com/text-table/-/text-table-0.2.0.tgz" + "version" "0.2.0" + +"thenify-all@^1.0.0": + "integrity" "sha1-GhkY1ALY/D+Y+/I02wvMjMEOlyY=" + "resolved" "https://registry.npm.taobao.org/thenify-all/download/thenify-all-1.6.0.tgz" + "version" "1.6.0" + dependencies: + "thenify" ">= 3.1.0 < 4" + +"thenify@>= 3.1.0 < 4": + "integrity" "sha1-iTLmhqQGYDigFt2eLKRq3Zg4qV8=" + "resolved" "https://registry.npm.taobao.org/thenify/download/thenify-3.3.1.tgz" + "version" "3.3.1" + dependencies: + "any-promise" "^1.0.0" + +"thread-loader@^2.1.3": + "integrity" "sha1-y9LBOfwrLebp0o9iKGq3cMGsvdo=" + "resolved" "https://registry.nlark.com/thread-loader/download/thread-loader-2.1.3.tgz?cache=0&sync_timestamp=1620664384427&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fthread-loader%2Fdownload%2Fthread-loader-2.1.3.tgz" + "version" "2.1.3" + dependencies: + "loader-runner" "^2.3.1" + "loader-utils" "^1.1.0" + "neo-async" "^2.6.0" + +"through@^2.3.6", "through@~2.3": + "integrity" "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" + "resolved" "https://registry.nlark.com/through/download/through-2.3.8.tgz" + "version" "2.3.8" + +"through2@^2.0.0": + "integrity" "sha1-AcHjnrMdB8t9A6lqcIIyYLIxMs0=" + "resolved" "https://registry.npm.taobao.org/through2/download/through2-2.0.5.tgz" + "version" "2.0.5" + dependencies: + "readable-stream" "~2.3.6" + "xtend" "~4.0.1" + +"thunky@^1.0.2": + "integrity" "sha1-Wrr3FKlAXbBQRzK7zNLO3Z75U30=" + "resolved" "https://registry.npm.taobao.org/thunky/download/thunky-1.1.0.tgz" + "version" "1.1.0" + +"timers-browserify@^2.0.4": + "integrity" "sha1-RKRcEfv0B/NPl7zNFXfGUjYbAO4=" + "resolved" "https://registry.npm.taobao.org/timers-browserify/download/timers-browserify-2.0.12.tgz" + "version" "2.0.12" + dependencies: + "setimmediate" "^1.0.4" + +"timsort@^0.3.0": + "integrity" "sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q=" + "resolved" "https://registry.npm.taobao.org/timsort/download/timsort-0.3.0.tgz" + "version" "0.3.0" + +"tmp@^0.0.33": + "integrity" "sha1-bTQzWIl2jSGyvNoKonfO07G/rfk=" + "resolved" "https://registry.nlark.com/tmp/download/tmp-0.0.33.tgz" + "version" "0.0.33" + dependencies: + "os-tmpdir" "~1.0.2" + +"to-arraybuffer@^1.0.0": + "integrity" "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=" + "resolved" "https://registry.npm.taobao.org/to-arraybuffer/download/to-arraybuffer-1.0.1.tgz" + "version" "1.0.1" + +"to-fast-properties@^2.0.0": + "integrity" "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=" + "resolved" "https://registry.npm.taobao.org/to-fast-properties/download/to-fast-properties-2.0.0.tgz" + "version" "2.0.0" + +"to-object-path@^0.3.0": + "integrity" "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=" + "resolved" "https://registry.npm.taobao.org/to-object-path/download/to-object-path-0.3.0.tgz" + "version" "0.3.0" + dependencies: + "kind-of" "^3.0.2" + +"to-regex-range@^2.1.0": + "integrity" "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=" + "resolved" "https://registry.nlark.com/to-regex-range/download/to-regex-range-2.1.1.tgz" + "version" "2.1.1" + dependencies: + "is-number" "^3.0.0" + "repeat-string" "^1.6.1" + +"to-regex-range@^5.0.1": + "integrity" "sha1-FkjESq58jZiKMmAY7XL1tN0DkuQ=" + "resolved" "https://registry.nlark.com/to-regex-range/download/to-regex-range-5.0.1.tgz" + "version" "5.0.1" + dependencies: + "is-number" "^7.0.0" + +"to-regex@^3.0.1", "to-regex@^3.0.2": + "integrity" "sha1-E8/dmzNlUvMLUfM6iuG0Knp1mc4=" + "resolved" "https://registry.npm.taobao.org/to-regex/download/to-regex-3.0.2.tgz" + "version" "3.0.2" + dependencies: + "define-property" "^2.0.2" + "extend-shallow" "^3.0.2" + "regex-not" "^1.0.2" + "safe-regex" "^1.1.0" + +"toidentifier@1.0.0": + "integrity" "sha1-fhvjRw8ed5SLxD2Uo8j013UrpVM=" + "resolved" "https://registry.nlark.com/toidentifier/download/toidentifier-1.0.0.tgz" + "version" "1.0.0" + +"toposort@^1.0.0": + "integrity" "sha1-LmhELZ9k7HILjMieZEOsbKqVACk=" + "resolved" "https://registry.npm.taobao.org/toposort/download/toposort-1.0.7.tgz" + "version" "1.0.7" + +"toposort@^2.0.2": + "integrity" "sha1-riF2gXXRVZ1IvvNUILL0li8JwzA=" + "resolved" "https://registry.npm.taobao.org/toposort/download/toposort-2.0.2.tgz" + "version" "2.0.2" + +"tough-cookie@^2.3.3", "tough-cookie@^2.3.3 || ^3.0.1 || ^4.0.0", "tough-cookie@~2.5.0": + "integrity" "sha1-zZ+yoKodWhK0c72fuW+j3P9lreI=" + "resolved" "https://registry.npm.taobao.org/tough-cookie/download/tough-cookie-2.5.0.tgz" + "version" "2.5.0" + dependencies: + "psl" "^1.1.28" + "punycode" "^2.1.1" + +"tough-cookie@^3.0.1": + "integrity" "sha1-nfT1fnOcJpMKAYGEiH9K233Kc7I=" + "resolved" "https://registry.npm.taobao.org/tough-cookie/download/tough-cookie-3.0.1.tgz" + "version" "3.0.1" + dependencies: + "ip-regex" "^2.1.0" + "psl" "^1.1.28" + "punycode" "^2.1.1" + +"tr46@^1.0.1": + "integrity" "sha1-qLE/1r/SSJUZZ0zN5VujaTtwbQk=" + "resolved" "https://registry.nlark.com/tr46/download/tr46-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "punycode" "^2.1.0" + +"tr46@~0.0.3": + "integrity" "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" + "resolved" "https://registry.npmmirror.com/tr46/-/tr46-0.0.3.tgz" + "version" "0.0.3" + +"tryer@^1.0.1": + "integrity" "sha1-8shUBoALmw90yfdGW4HqrSQSUvg=" + "resolved" "https://registry.nlark.com/tryer/download/tryer-1.0.1.tgz" + "version" "1.0.1" + +"ts-pnp@^1.1.6": + "integrity" "sha1-pQCtCEsHmPHDBxrzkeZZEshrypI=" + "resolved" "https://registry.npm.taobao.org/ts-pnp/download/ts-pnp-1.2.0.tgz" + "version" "1.2.0" + +"tslib@^1.10.0": + "integrity" "sha1-zy04vcNKE0vK8QkcQfZhni9nLQA=" + "resolved" "https://registry.nlark.com/tslib/download/tslib-1.14.1.tgz" + "version" "1.14.1" + +"tslib@^1.9.0": + "integrity" "sha1-zy04vcNKE0vK8QkcQfZhni9nLQA=" + "resolved" "https://registry.nlark.com/tslib/download/tslib-1.14.1.tgz" + "version" "1.14.1" + +"tslib@^2.0.1", "tslib@2.0.3": + "integrity" "sha1-jgdBrEX8DCJuWKF7/D5kubxsphw=" + "resolved" "https://registry.nlark.com/tslib/download/tslib-2.0.3.tgz" + "version" "2.0.3" + +"tslib@^2.1.0": + "integrity" "sha1-gDuM2rPhK6WBpMpByIObuw2ssJ4=" + "resolved" "https://registry.nlark.com/tslib/download/tslib-2.3.0.tgz" + "version" "2.3.0" + +"tty-browserify@0.0.0": + "integrity" "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=" + "resolved" "https://registry.npm.taobao.org/tty-browserify/download/tty-browserify-0.0.0.tgz" + "version" "0.0.0" + +"tunnel-agent@^0.6.0": + "integrity" "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=" + "resolved" "https://registry.npm.taobao.org/tunnel-agent/download/tunnel-agent-0.6.0.tgz" + "version" "0.6.0" + dependencies: + "safe-buffer" "^5.0.1" + +"tweetnacl@^0.14.3", "tweetnacl@~0.14.0": + "integrity" "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" + "resolved" "https://registry.nlark.com/tweetnacl/download/tweetnacl-0.14.5.tgz" + "version" "0.14.5" + +"type-check@~0.3.2": + "integrity" "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=" + "resolved" "https://registry.npm.taobao.org/type-check/download/type-check-0.3.2.tgz" + "version" "0.3.2" + dependencies: + "prelude-ls" "~1.1.2" + +"type-detect@^4.0.0", "type-detect@^4.0.5": + "integrity" "sha1-dkb7XxiHHPu3dJ5pvTmmOI63RQw=" + "resolved" "https://registry.npm.taobao.org/type-detect/download/type-detect-4.0.8.tgz" + "version" "4.0.8" + +"type-fest@^0.21.3": + "integrity" "sha1-0mCiSwGYQ24TP6JqUkptZfo7Ljc=" + "resolved" "https://registry.nlark.com/type-fest/download/type-fest-0.21.3.tgz?cache=0&sync_timestamp=1625745286088&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ftype-fest%2Fdownload%2Ftype-fest-0.21.3.tgz" + "version" "0.21.3" + +"type-fest@^0.6.0": + "integrity" "sha1-jSojcNPfiG61yQraHFv2GIrPg4s=" + "resolved" "https://registry.nlark.com/type-fest/download/type-fest-0.6.0.tgz?cache=0&sync_timestamp=1625745286088&other_urls=https%3A%2F%2Fregistry.nlark.com%2Ftype-fest%2Fdownload%2Ftype-fest-0.6.0.tgz" + "version" "0.6.0" + +"type-fest@^0.8.1": + "integrity" "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==" + "resolved" "https://registry.npmmirror.com/type-fest/-/type-fest-0.8.1.tgz" + "version" "0.8.1" + +"type-is@~1.6.17", "type-is@~1.6.18": + "integrity" "sha1-TlUs0F3wlGfcvE73Od6J8s83wTE=" + "resolved" "https://registry.npm.taobao.org/type-is/download/type-is-1.6.18.tgz" + "version" "1.6.18" + dependencies: + "media-typer" "0.3.0" + "mime-types" "~2.1.24" + +"typedarray@^0.0.6": + "integrity" "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" + "resolved" "https://registry.npm.taobao.org/typedarray/download/typedarray-0.0.6.tgz" + "version" "0.0.6" + +"uglify-js@3.4.x": + "integrity" "sha1-mtlWPY6zrN+404WX0q8dgV9qdV8=" + "resolved" "https://registry.nlark.com/uglify-js/download/uglify-js-3.4.10.tgz?cache=0&sync_timestamp=1624812318797&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fuglify-js%2Fdownload%2Fuglify-js-3.4.10.tgz" + "version" "3.4.10" + dependencies: + "commander" "~2.19.0" + "source-map" "~0.6.1" + +"unbox-primitive@^1.0.1": + "integrity" "sha1-CF4hViXsMWJXTciFmr7nilmxRHE=" + "resolved" "https://registry.npm.taobao.org/unbox-primitive/download/unbox-primitive-1.0.1.tgz?cache=0&sync_timestamp=1616706427948&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Funbox-primitive%2Fdownload%2Funbox-primitive-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "function-bind" "^1.1.1" + "has-bigints" "^1.0.1" + "has-symbols" "^1.0.2" + "which-boxed-primitive" "^1.0.2" + +"unescape@^1.0.1": + "integrity" "sha512-O0+af1Gs50lyH1nUu3ZyYS1cRh01Q/kUKatTOkSs7jukXE6/NebucDVxyiDsA9AQ4JC1V1jUH9EO8JX2nMDgGQ==" + "resolved" "https://registry.npmmirror.com/unescape/-/unescape-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "extend-shallow" "^2.0.1" + +"unicode-canonical-property-names-ecmascript@^1.0.4": + "integrity" "sha1-JhmADEyCWADv3YNDr33Zkzy+KBg=" + "resolved" "https://registry.npm.taobao.org/unicode-canonical-property-names-ecmascript/download/unicode-canonical-property-names-ecmascript-1.0.4.tgz" + "version" "1.0.4" + +"unicode-match-property-ecmascript@^1.0.4": + "integrity" "sha1-jtKjJWmWG86SJ9Cc0/+7j+1fAgw=" + "resolved" "https://registry.npm.taobao.org/unicode-match-property-ecmascript/download/unicode-match-property-ecmascript-1.0.4.tgz" + "version" "1.0.4" + dependencies: + "unicode-canonical-property-names-ecmascript" "^1.0.4" + "unicode-property-aliases-ecmascript" "^1.0.4" + +"unicode-match-property-value-ecmascript@^1.2.0": + "integrity" "sha1-DZH2AO7rMJaqlisdb8iIduZOpTE=" + "resolved" "https://registry.nlark.com/unicode-match-property-value-ecmascript/download/unicode-match-property-value-ecmascript-1.2.0.tgz" + "version" "1.2.0" + +"unicode-property-aliases-ecmascript@^1.0.4": + "integrity" "sha1-3Vepn2IHvt/0Yoq++5TFDblByPQ=" + "resolved" "https://registry.npm.taobao.org/unicode-property-aliases-ecmascript/download/unicode-property-aliases-ecmascript-1.1.0.tgz" + "version" "1.1.0" + +"union-value@^1.0.0": + "integrity" "sha1-C2/nuDWuzaYcbqTU8CwUIh4QmEc=" + "resolved" "https://registry.npm.taobao.org/union-value/download/union-value-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "arr-union" "^3.1.0" + "get-value" "^2.0.6" + "is-extendable" "^0.1.1" + "set-value" "^2.0.1" + +"uniq@^1.0.1": + "integrity" "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=" + "resolved" "https://registry.npm.taobao.org/uniq/download/uniq-1.0.1.tgz" + "version" "1.0.1" + +"uniqs@^2.0.0": + "integrity" "sha1-/+3ks2slKQaW5uFl1KWe25mOawI=" + "resolved" "https://registry.npm.taobao.org/uniqs/download/uniqs-2.0.0.tgz" + "version" "2.0.0" + +"unique-filename@^1.1.1": + "integrity" "sha1-HWl2k2mtoFgxA6HmrodoG1ZXMjA=" + "resolved" "https://registry.npm.taobao.org/unique-filename/download/unique-filename-1.1.1.tgz" + "version" "1.1.1" + dependencies: + "unique-slug" "^2.0.0" + +"unique-slug@^2.0.0": + "integrity" "sha1-uqvOkQg/xk6UWw861hPiZPfNTmw=" + "resolved" "https://registry.npm.taobao.org/unique-slug/download/unique-slug-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "imurmurhash" "^0.1.4" + +"universalify@^0.1.0": + "integrity" "sha1-tkb2m+OULavOzJ1mOcgNwQXvqmY=" + "resolved" "https://registry.nlark.com/universalify/download/universalify-0.1.2.tgz" + "version" "0.1.2" + +"unpipe@~1.0.0", "unpipe@1.0.0": + "integrity" "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" + "resolved" "https://registry.npm.taobao.org/unpipe/download/unpipe-1.0.0.tgz" + "version" "1.0.0" + +"unquote@~1.1.1": + "integrity" "sha1-j97XMk7G6IoP+LkF58CYzcCG1UQ=" + "resolved" "https://registry.npm.taobao.org/unquote/download/unquote-1.1.1.tgz" + "version" "1.1.1" + +"unset-value@^1.0.0": + "integrity" "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=" + "resolved" "https://registry.npm.taobao.org/unset-value/download/unset-value-1.0.0.tgz?cache=0&sync_timestamp=1616088640915&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Funset-value%2Fdownload%2Funset-value-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "has-value" "^0.3.1" + "isobject" "^3.0.0" + +"upath@^1.1.1": + "integrity" "sha1-j2bbzVWog6za5ECK+LA1pQRMGJQ=" + "resolved" "https://registry.npm.taobao.org/upath/download/upath-1.2.0.tgz" + "version" "1.2.0" + +"upper-case@^1.1.1": + "integrity" "sha1-9rRQHC7EzdJrp4vnIilh3ndiFZg=" + "resolved" "https://registry.npm.taobao.org/upper-case/download/upper-case-1.1.3.tgz?cache=0&sync_timestamp=1606859943902&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fupper-case%2Fdownload%2Fupper-case-1.1.3.tgz" + "version" "1.1.3" + +"uri-js@^4.2.2": + "integrity" "sha1-mxpSWVIlhZ5V9mnZKPiMbFfyp34=" + "resolved" "https://registry.npm.taobao.org/uri-js/download/uri-js-4.4.1.tgz?cache=0&sync_timestamp=1610237530009&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Furi-js%2Fdownload%2Furi-js-4.4.1.tgz" + "version" "4.4.1" + dependencies: + "punycode" "^2.1.0" + +"urix@^0.1.0": + "integrity" "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=" + "resolved" "https://registry.npm.taobao.org/urix/download/urix-0.1.0.tgz" + "version" "0.1.0" + +"url-loader@^2.2.0": + "integrity" "sha1-4OLvZY8APvuMpBsPP/v3a6uIZYs=" + "resolved" "https://registry.npm.taobao.org/url-loader/download/url-loader-2.3.0.tgz" + "version" "2.3.0" + dependencies: + "loader-utils" "^1.2.3" + "mime" "^2.4.4" + "schema-utils" "^2.5.0" + +"url-parse@^1.4.3", "url-parse@^1.5.1": + "integrity" "sha1-1fqYkK+KXh8nSiyYN2UQ9kJfbjs=" + "resolved" "https://registry.npm.taobao.org/url-parse/download/url-parse-1.5.1.tgz" + "version" "1.5.1" + dependencies: + "querystringify" "^2.1.1" + "requires-port" "^1.0.0" + +"url@^0.11.0": + "integrity" "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=" + "resolved" "https://registry.npm.taobao.org/url/download/url-0.11.0.tgz" + "version" "0.11.0" + dependencies: + "punycode" "1.3.2" + "querystring" "0.2.0" + +"urllib@^2.33.1": + "integrity" "sha512-XDZjoijtzsbkXTXgM+A/sJM002nwoYsc46YOYr6MNH2jUUw1nCBf2ywT1WaPsVEWJX4Yr+9isGmYj4+yofFn9g==" + "resolved" "https://registry.npmmirror.com/urllib/-/urllib-2.40.0.tgz" + "version" "2.40.0" + dependencies: + "any-promise" "^1.3.0" + "content-type" "^1.0.2" + "debug" "^2.6.9" + "default-user-agent" "^1.0.0" + "digest-header" "^1.0.0" + "ee-first" "~1.1.1" + "formstream" "^1.1.0" + "humanize-ms" "^1.2.0" + "iconv-lite" "^0.4.15" + "ip" "^1.1.5" + "proxy-agent" "^5.0.0" + "pump" "^3.0.0" + "qs" "^6.4.0" + "statuses" "^1.3.1" + "utility" "^1.16.1" + +"use@^3.1.0": + "integrity" "sha1-1QyMrHmhn7wg8pEfVuuXP04QBw8=" + "resolved" "https://registry.npm.taobao.org/use/download/use-3.1.1.tgz" + "version" "3.1.1" + +"util-deprecate@^1.0.1", "util-deprecate@^1.0.2", "util-deprecate@~1.0.1": + "integrity" "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" + "resolved" "https://registry.nlark.com/util-deprecate/download/util-deprecate-1.0.2.tgz" + "version" "1.0.2" + +"util.promisify@~1.0.0", "util.promisify@1.0.0": + "integrity" "sha1-RA9xZaRZyaFtwUXrjnLzVocJcDA=" + "resolved" "https://registry.npm.taobao.org/util.promisify/download/util.promisify-1.0.0.tgz?cache=0&sync_timestamp=1610159885628&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Futil.promisify%2Fdownload%2Futil.promisify-1.0.0.tgz" + "version" "1.0.0" + dependencies: + "define-properties" "^1.1.2" + "object.getownpropertydescriptors" "^2.0.3" + +"util@^0.11.0": + "integrity" "sha1-MjZzNyDsZLsn9uJvQhqqLhtYjWE=" + "resolved" "https://registry.nlark.com/util/download/util-0.11.1.tgz?cache=0&sync_timestamp=1622212943994&other_urls=https%3A%2F%2Fregistry.nlark.com%2Futil%2Fdownload%2Futil-0.11.1.tgz" + "version" "0.11.1" + dependencies: + "inherits" "2.0.3" + +"util@0.10.3": + "integrity" "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=" + "resolved" "https://registry.nlark.com/util/download/util-0.10.3.tgz?cache=0&sync_timestamp=1622212943994&other_urls=https%3A%2F%2Fregistry.nlark.com%2Futil%2Fdownload%2Futil-0.10.3.tgz" + "version" "0.10.3" + dependencies: + "inherits" "2.0.1" + +"utila@~0.4": + "integrity" "sha1-ihagXURWV6Oupe7MWxKk+lN5dyw=" + "resolved" "https://registry.npm.taobao.org/utila/download/utila-0.4.0.tgz" + "version" "0.4.0" + +"utility@^1.16.1", "utility@^1.17.0", "utility@^1.8.0": + "integrity" "sha512-KdVkF9An/0239BJ4+dqOa7NPrPIOeQE9AGfx0XS16O9DBiHNHRJMoeU5nL6pRGAkgJOqdOu8R4gBRcXnAocJKw==" + "resolved" "https://registry.npmmirror.com/utility/-/utility-1.17.0.tgz" + "version" "1.17.0" + dependencies: + "copy-to" "^2.0.1" + "escape-html" "^1.0.3" + "mkdirp" "^0.5.1" + "mz" "^2.7.0" + "unescape" "^1.0.1" + +"utils-merge@1.0.1": + "integrity" "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" + "resolved" "https://registry.npm.taobao.org/utils-merge/download/utils-merge-1.0.1.tgz" + "version" "1.0.1" + +"uuid@^3.3.2", "uuid@^3.4.0": + "integrity" "sha1-sj5DWK+oogL+ehAK8fX4g/AgB+4=" + "resolved" "https://registry.nlark.com/uuid/download/uuid-3.4.0.tgz?cache=0&sync_timestamp=1622213086354&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fuuid%2Fdownload%2Fuuid-3.4.0.tgz" + "version" "3.4.0" + +"v8-compile-cache@^2.0.3": + "integrity" "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==" + "resolved" "https://registry.npmmirror.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz" + "version" "2.3.0" + +"validate-npm-package-license@^3.0.1": + "integrity" "sha1-/JH2uce6FchX9MssXe/uw51PQQo=" + "resolved" "https://registry.npm.taobao.org/validate-npm-package-license/download/validate-npm-package-license-3.0.4.tgz" + "version" "3.0.4" + dependencies: + "spdx-correct" "^3.0.0" + "spdx-expression-parse" "^3.0.0" + +"vary@~1.1.2": + "integrity" "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" + "resolved" "https://registry.npm.taobao.org/vary/download/vary-1.1.2.tgz" + "version" "1.1.2" + +"vendors@^1.0.0": + "integrity" "sha1-4rgApT56Kbk1BsPPQRANFsTErY4=" + "resolved" "https://registry.npm.taobao.org/vendors/download/vendors-1.0.4.tgz?cache=0&sync_timestamp=1615203486079&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fvendors%2Fdownload%2Fvendors-1.0.4.tgz" + "version" "1.0.4" + +"verror@1.10.0": + "integrity" "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=" + "resolved" "https://registry.nlark.com/verror/download/verror-1.10.0.tgz" + "version" "1.10.0" + dependencies: + "assert-plus" "^1.0.0" + "core-util-is" "1.0.2" + "extsprintf" "^1.2.0" + +"vm-browserify@^1.0.1": + "integrity" "sha1-eGQcSIuObKkadfUR56OzKobl3aA=" + "resolved" "https://registry.npm.taobao.org/vm-browserify/download/vm-browserify-1.1.2.tgz" + "version" "1.1.2" + +"vm2@^3.9.8": + "integrity" "sha512-HgvPHYHeQy8+QhzlFryvSteA4uQLBCOub02mgqdR+0bN/akRZ48TGB1v0aCv7ksyc0HXx16AZtMHKS38alc6TA==" + "resolved" "https://registry.npmmirror.com/vm2/-/vm2-3.9.14.tgz" + "version" "3.9.14" + dependencies: + "acorn" "^8.7.0" + "acorn-walk" "^8.2.0" + +"vue-demi@*": + "integrity" "sha512-Vy1zbZhCOdsmvGR6tJhAvO5vhP7eiS8xkbYQSoVa7o6KlIy3W8Rc53ED4qI4qpeRDjv3mLfXSEpYU6Yq4pgXRg==" + "resolved" "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.13.8.tgz" + "version" "0.13.8" + +"vue-draggable-next@^2.0.1": + "integrity" "sha1-u2TvswLHuOdZ/T8hQnhxeJtiTGc=" + "resolved" "https://registry.nlark.com/vue-draggable-next/download/vue-draggable-next-2.0.1.tgz" + "version" "2.0.1" + +"vue-hot-reload-api@^2.3.0": + "integrity" "sha1-UylVzB6yCKPZkLOp+acFdGV+CPI=" + "resolved" "https://registry.nlark.com/vue-hot-reload-api/download/vue-hot-reload-api-2.3.4.tgz" + "version" "2.3.4" + +"vue-loader-v16@npm:vue-loader@^16.1.0": + "integrity" "sha512-7vKN45IxsKxe5GcVCbc2qFU5aWzyiLrYJyUuMz4BQLKctCj/fmCa0w6fGiiQ2cLFetNcek1ppGJQDCup0c1hpA==" + "resolved" "https://registry.npmmirror.com/vue-loader/-/vue-loader-16.8.3.tgz" + "version" "16.8.3" + dependencies: + "chalk" "^4.1.0" + "hash-sum" "^2.0.0" + "loader-utils" "^2.0.0" + +"vue-loader@^15.9.2": + "integrity" "sha1-FbBXdcPgw4QHZ5OTws5t9nOwEEQ=" + "resolved" "https://registry.nlark.com/vue-loader/download/vue-loader-15.9.7.tgz?cache=0&sync_timestamp=1624996813170&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fvue-loader%2Fdownload%2Fvue-loader-15.9.7.tgz" + "version" "15.9.7" + dependencies: + "@vue/component-compiler-utils" "^3.1.0" + "hash-sum" "^1.0.2" + "loader-utils" "^1.1.0" + "vue-hot-reload-api" "^2.3.0" + "vue-style-loader" "^4.1.0" + +"vue-router@^4.0.0-0": + "integrity" "sha1-7I/aAylJsqMdMnMXD483bobrUqw=" + "resolved" "https://registry.nlark.com/vue-router/download/vue-router-4.0.10.tgz?cache=0&sync_timestamp=1624286995690&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fvue-router%2Fdownload%2Fvue-router-4.0.10.tgz" + "version" "4.0.10" + dependencies: + "@vue/devtools-api" "^6.0.0-beta.14" + +"vue-style-loader@^4.1.0", "vue-style-loader@^4.1.2": + "integrity" "sha1-bVWGOlH6dXqyTonZNxRlByqnvDU=" + "resolved" "https://registry.npm.taobao.org/vue-style-loader/download/vue-style-loader-4.1.3.tgz" + "version" "4.1.3" + dependencies: + "hash-sum" "^1.0.2" + "loader-utils" "^1.0.2" + +"vue-template-es2015-compiler@^1.9.0": + "integrity" "sha1-HuO8mhbsv1EYvjNLsV+cRvgvWCU=" + "resolved" "https://registry.npm.taobao.org/vue-template-es2015-compiler/download/vue-template-es2015-compiler-1.9.1.tgz" + "version" "1.9.1" + +"vue@^2 || ^3.0.0-0", "vue@^3.0.0", "vue@^3.0.0-0 || ^2.6.0", "vue@^3.0.1", "vue@^3.0.2", "vue@^3.0.5", "vue@^3.2.0", "vue@^3.2.37", "vue@3.2.37": + "integrity" "sha512-bOKEZxrm8Eh+fveCqS1/NkG/n6aMidsI6hahas7pa0w/l7jkbssJVsRhVDs07IdDq7h9KHswZOgItnwJAgtVtQ==" + "resolved" "https://registry.npmmirror.com/vue/-/vue-3.2.37.tgz" + "version" "3.2.37" + dependencies: + "@vue/compiler-dom" "3.2.37" + "@vue/compiler-sfc" "3.2.37" + "@vue/runtime-dom" "3.2.37" + "@vue/server-renderer" "3.2.37" + "@vue/shared" "3.2.37" + +"vuex@^4.0.0-0": + "integrity" "sha1-+Jbb1b8qDpY/AMZ+m2EN50nMrMk=" + "resolved" "https://registry.nlark.com/vuex/download/vuex-4.0.2.tgz" + "version" "4.0.2" + dependencies: + "@vue/devtools-api" "^6.0.0-beta.11" + +"w3c-hr-time@^1.0.1": + "integrity" "sha1-ConN9cwVgi35w2BUNnaWPgzDCM0=" + "resolved" "https://registry.npm.taobao.org/w3c-hr-time/download/w3c-hr-time-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "browser-process-hrtime" "^1.0.0" + +"w3c-xmlserializer@^1.1.2": + "integrity" "sha1-MEhcp9cKb9BSQgo9Ev2Q5jOc55Q=" + "resolved" "https://registry.npm.taobao.org/w3c-xmlserializer/download/w3c-xmlserializer-1.1.2.tgz" + "version" "1.1.2" + dependencies: + "domexception" "^1.0.1" + "webidl-conversions" "^4.0.2" + "xml-name-validator" "^3.0.0" + +"wangeditor@^4.7.6": + "integrity" "sha1-0ubd7PJHTsJsQnc74vrEM9Hguq8=" + "resolved" "https://registry.nlark.com/wangeditor/download/wangeditor-4.7.6.tgz?cache=0&sync_timestamp=1627614400149&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fwangeditor%2Fdownload%2Fwangeditor-4.7.6.tgz" + "version" "4.7.6" + dependencies: + "@babel/runtime" "^7.11.2" + "@babel/runtime-corejs3" "^7.11.2" + "tslib" "^2.1.0" + +"watchpack-chokidar2@^2.0.1": + "integrity" "sha1-OFAAcu5uzmbzdpk2lQ6hdxvhyVc=" + "resolved" "https://registry.npm.taobao.org/watchpack-chokidar2/download/watchpack-chokidar2-2.0.1.tgz?cache=0&sync_timestamp=1604989085906&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fwatchpack-chokidar2%2Fdownload%2Fwatchpack-chokidar2-2.0.1.tgz" + "version" "2.0.1" + dependencies: + "chokidar" "^2.1.8" + +"watchpack@^1.7.4": + "integrity" "sha1-EmfmxV4Lm1vkTCAjrtVDeiwmxFM=" + "resolved" "https://registry.nlark.com/watchpack/download/watchpack-1.7.5.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fwatchpack%2Fdownload%2Fwatchpack-1.7.5.tgz" + "version" "1.7.5" + dependencies: + "graceful-fs" "^4.1.2" + "neo-async" "^2.5.0" + optionalDependencies: + "chokidar" "^3.4.1" + "watchpack-chokidar2" "^2.0.1" + +"wbuf@^1.1.0", "wbuf@^1.7.3": + "integrity" "sha1-wdjRSTFtPqhShIiVy2oL/oh7h98=" + "resolved" "https://registry.npm.taobao.org/wbuf/download/wbuf-1.7.3.tgz" + "version" "1.7.3" + dependencies: + "minimalistic-assert" "^1.0.0" + +"wcwidth@^1.0.1": + "integrity" "sha1-8LDc+RW8X/FSivrbLA4XtTLaL+g=" + "resolved" "https://registry.nlark.com/wcwidth/download/wcwidth-1.0.1.tgz" + "version" "1.0.1" + dependencies: + "defaults" "^1.0.3" + +"webidl-conversions@^3.0.0": + "integrity" "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" + "resolved" "https://registry.npmmirror.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz" + "version" "3.0.1" + +"webidl-conversions@^4.0.2": + "integrity" "sha1-qFWYCx8LazWbodXZ+zmulB+qY60=" + "resolved" "https://registry.npm.taobao.org/webidl-conversions/download/webidl-conversions-4.0.2.tgz" + "version" "4.0.2" + +"webpack-bundle-analyzer@^3.8.0": + "integrity" "sha1-9vlNsQj7V05BWtMT3kGicH0z7zw=" + "resolved" "https://registry.nlark.com/webpack-bundle-analyzer/download/webpack-bundle-analyzer-3.9.0.tgz?cache=0&sync_timestamp=1621259036556&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fwebpack-bundle-analyzer%2Fdownload%2Fwebpack-bundle-analyzer-3.9.0.tgz" + "version" "3.9.0" + dependencies: + "acorn" "^7.1.1" + "acorn-walk" "^7.1.1" + "bfj" "^6.1.1" + "chalk" "^2.4.1" + "commander" "^2.18.0" + "ejs" "^2.6.1" + "express" "^4.16.3" + "filesize" "^3.6.1" + "gzip-size" "^5.0.0" + "lodash" "^4.17.19" + "mkdirp" "^0.5.1" + "opener" "^1.5.1" + "ws" "^6.0.0" + +"webpack-chain@^6.4.0": + "integrity" "sha1-TycoTLu2N+PI+970Pu9YjU2GEgY=" + "resolved" "https://registry.npm.taobao.org/webpack-chain/download/webpack-chain-6.5.1.tgz" + "version" "6.5.1" + dependencies: + "deepmerge" "^1.5.2" + "javascript-stringify" "^2.0.1" + +"webpack-dev-middleware@^3.7.2": + "integrity" "sha1-Bjk3KxQyYuK4SrldO5GnWXBhwsU=" + "resolved" "https://registry.nlark.com/webpack-dev-middleware/download/webpack-dev-middleware-3.7.3.tgz" + "version" "3.7.3" + dependencies: + "memory-fs" "^0.4.1" + "mime" "^2.4.4" + "mkdirp" "^0.5.1" + "range-parser" "^1.2.1" + "webpack-log" "^2.0.0" + +"webpack-dev-server@^3.11.0": + "integrity" "sha1-aV687Xakkp8NXef9c/r+GF/jNwg=" + "resolved" "https://registry.nlark.com/webpack-dev-server/download/webpack-dev-server-3.11.2.tgz" + "version" "3.11.2" + dependencies: + "ansi-html" "0.0.7" + "bonjour" "^3.5.0" + "chokidar" "^2.1.8" + "compression" "^1.7.4" + "connect-history-api-fallback" "^1.6.0" + "debug" "^4.1.1" + "del" "^4.1.1" + "express" "^4.17.1" + "html-entities" "^1.3.1" + "http-proxy-middleware" "0.19.1" + "import-local" "^2.0.0" + "internal-ip" "^4.3.0" + "ip" "^1.1.5" + "is-absolute-url" "^3.0.3" + "killable" "^1.0.1" + "loglevel" "^1.6.8" + "opn" "^5.5.0" + "p-retry" "^3.0.1" + "portfinder" "^1.0.26" + "schema-utils" "^1.0.0" + "selfsigned" "^1.10.8" + "semver" "^6.3.0" + "serve-index" "^1.9.1" + "sockjs" "^0.3.21" + "sockjs-client" "^1.5.0" + "spdy" "^4.0.2" + "strip-ansi" "^3.0.1" + "supports-color" "^6.1.0" + "url" "^0.11.0" + "webpack-dev-middleware" "^3.7.2" + "webpack-log" "^2.0.0" + "ws" "^6.2.1" + "yargs" "^13.3.2" + +"webpack-log@^2.0.0": + "integrity" "sha1-W3ko4GN1k/EZ0y9iJ8HgrDHhtH8=" + "resolved" "https://registry.npm.taobao.org/webpack-log/download/webpack-log-2.0.0.tgz?cache=0&sync_timestamp=1615477493300&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fwebpack-log%2Fdownload%2Fwebpack-log-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "ansi-colors" "^3.0.0" + "uuid" "^3.3.2" + +"webpack-merge@^4.2.2": + "integrity" "sha1-onxS6ng9E5iv0gh/VH17nS9DY00=" + "resolved" "https://registry.nlark.com/webpack-merge/download/webpack-merge-4.2.2.tgz" + "version" "4.2.2" + dependencies: + "lodash" "^4.17.15" + +"webpack-sources@^1.1.0", "webpack-sources@^1.4.0", "webpack-sources@^1.4.1": + "integrity" "sha1-7t2OwLko+/HL/plOItLYkPMwqTM=" + "resolved" "https://registry.nlark.com/webpack-sources/download/webpack-sources-1.4.3.tgz" + "version" "1.4.3" + dependencies: + "source-list-map" "^2.0.0" + "source-map" "~0.6.1" + +"webpack@^1.0.0 || ^2.0.0 || ^3.0.0 || ^4.0.0", "webpack@^2.0.0 || ^3.0.0 || ^4.0.0", "webpack@^3.0.0 || ^4.1.0 || ^5.0.0-0", "webpack@^4.0.0", "webpack@^4.0.0 || ^5.0.0", "webpack@^4.1.0 || ^5.0.0-0", "webpack@^4.4.0", "webpack@>=2", "webpack@>=2.0.0 <5.0.0", "webpack@>=4.0.0": + "integrity" "sha1-v5tEBOogoHNgXgoBHRiNd8tq1UI=" + "resolved" "https://registry.nlark.com/webpack/download/webpack-4.46.0.tgz" + "version" "4.46.0" + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-module-context" "1.9.0" + "@webassemblyjs/wasm-edit" "1.9.0" + "@webassemblyjs/wasm-parser" "1.9.0" + "acorn" "^6.4.1" + "ajv" "^6.10.2" + "ajv-keywords" "^3.4.1" + "chrome-trace-event" "^1.0.2" + "enhanced-resolve" "^4.5.0" + "eslint-scope" "^4.0.3" + "json-parse-better-errors" "^1.0.2" + "loader-runner" "^2.4.0" + "loader-utils" "^1.2.3" + "memory-fs" "^0.4.1" + "micromatch" "^3.1.10" + "mkdirp" "^0.5.3" + "neo-async" "^2.6.1" + "node-libs-browser" "^2.2.1" + "schema-utils" "^1.0.0" + "tapable" "^1.1.3" + "terser-webpack-plugin" "^1.4.3" + "watchpack" "^1.7.4" + "webpack-sources" "^1.4.1" + +"websocket-driver@^0.7.4", "websocket-driver@>=0.5.1": + "integrity" "sha1-ia1Slbv2S0gKvLox5JU6ynBvV2A=" + "resolved" "https://registry.npm.taobao.org/websocket-driver/download/websocket-driver-0.7.4.tgz?cache=0&sync_timestamp=1591289007652&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fwebsocket-driver%2Fdownload%2Fwebsocket-driver-0.7.4.tgz" + "version" "0.7.4" + dependencies: + "http-parser-js" ">=0.5.1" + "safe-buffer" ">=5.1.0" + "websocket-extensions" ">=0.1.1" + +"websocket-extensions@>=0.1.1": + "integrity" "sha1-f4RzvIOd/YdgituV1+sHUhFXikI=" + "resolved" "https://registry.npm.taobao.org/websocket-extensions/download/websocket-extensions-0.1.4.tgz" + "version" "0.1.4" + +"whatwg-encoding@^1.0.1", "whatwg-encoding@^1.0.5": + "integrity" "sha1-WrrPd3wyFmpR0IXWtPPn0nET3bA=" + "resolved" "https://registry.npm.taobao.org/whatwg-encoding/download/whatwg-encoding-1.0.5.tgz" + "version" "1.0.5" + dependencies: + "iconv-lite" "0.4.24" + +"whatwg-mimetype@^2.2.0", "whatwg-mimetype@^2.3.0": + "integrity" "sha1-PUseAxLSB5h5+Cav8Y2+7KWWD78=" + "resolved" "https://registry.npm.taobao.org/whatwg-mimetype/download/whatwg-mimetype-2.3.0.tgz" + "version" "2.3.0" + +"whatwg-url@^5.0.0": + "integrity" "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==" + "resolved" "https://registry.npmmirror.com/whatwg-url/-/whatwg-url-5.0.0.tgz" + "version" "5.0.0" + dependencies: + "tr46" "~0.0.3" + "webidl-conversions" "^3.0.0" + +"whatwg-url@^7.0.0": + "integrity" "sha1-wsSS8eymEpiO/T0iZr4bn8YXDQY=" + "resolved" "https://registry.nlark.com/whatwg-url/download/whatwg-url-7.1.0.tgz?cache=0&sync_timestamp=1624742873749&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fwhatwg-url%2Fdownload%2Fwhatwg-url-7.1.0.tgz" + "version" "7.1.0" + dependencies: + "lodash.sortby" "^4.7.0" + "tr46" "^1.0.1" + "webidl-conversions" "^4.0.2" + +"when@~3.6.x": + "integrity" "sha1-RztRfsFZ4rhQBUl6E5g/CVQS404=" + "resolved" "https://registry.npm.taobao.org/when/download/when-3.6.4.tgz" + "version" "3.6.4" + +"which-boxed-primitive@^1.0.2": + "integrity" "sha1-E3V7yJsgmwSf5dhkMOIc9AqJqOY=" + "resolved" "https://registry.npm.taobao.org/which-boxed-primitive/download/which-boxed-primitive-1.0.2.tgz" + "version" "1.0.2" + dependencies: + "is-bigint" "^1.0.1" + "is-boolean-object" "^1.1.0" + "is-number-object" "^1.0.4" + "is-string" "^1.0.5" + "is-symbol" "^1.0.3" + +"which-module@^2.0.0": + "integrity" "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" + "resolved" "https://registry.nlark.com/which-module/download/which-module-2.0.0.tgz" + "version" "2.0.0" + +"which@^1.2.9": + "integrity" "sha1-pFBD1U9YBTFtqNYvn1CRjT2nCwo=" + "resolved" "https://registry.npm.taobao.org/which/download/which-1.3.1.tgz" + "version" "1.3.1" + dependencies: + "isexe" "^2.0.0" + +"which@^2.0.1": + "integrity" "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==" + "resolved" "https://registry.npmjs.org/which/-/which-2.0.2.tgz" + "version" "2.0.2" + dependencies: + "isexe" "^2.0.0" + +"which@1.3.1": + "integrity" "sha1-pFBD1U9YBTFtqNYvn1CRjT2nCwo=" + "resolved" "https://registry.npm.taobao.org/which/download/which-1.3.1.tgz" + "version" "1.3.1" + dependencies: + "isexe" "^2.0.0" + +"wide-align@1.1.3": + "integrity" "sha1-rgdOa9wMFKQx6ATmJFScYzsABFc=" + "resolved" "https://registry.npm.taobao.org/wide-align/download/wide-align-1.1.3.tgz" + "version" "1.1.3" + dependencies: + "string-width" "^1.0.2 || 2" + +"win-release@^1.0.0": + "integrity" "sha512-iCRnKVvGxOQdsKhcQId2PXV1vV3J/sDPXKA4Oe9+Eti2nb2ESEsYHRYls/UjoUW3bIc5ZDO8dTH50A/5iVN+bw==" + "resolved" "https://registry.npmmirror.com/win-release/-/win-release-1.1.1.tgz" + "version" "1.1.1" + dependencies: + "semver" "^5.0.1" + +"word-wrap@~1.2.3": + "integrity" "sha1-YQY29rH3A4kb00dxzLF/uTtHB5w=" + "resolved" "https://registry.nlark.com/word-wrap/download/word-wrap-1.2.3.tgz" + "version" "1.2.3" + +"worker-farm@^1.7.0": + "integrity" "sha1-JqlMU5G7ypJhUgAvabhKS/dy5ag=" + "resolved" "https://registry.npm.taobao.org/worker-farm/download/worker-farm-1.7.0.tgz" + "version" "1.7.0" + dependencies: + "errno" "~0.1.7" + +"wrap-ansi@^5.1.0": + "integrity" "sha1-H9H2cjXVttD+54EFYAG/tpTAOwk=" + "resolved" "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-5.1.0.tgz" + "version" "5.1.0" + dependencies: + "ansi-styles" "^3.2.0" + "string-width" "^3.0.0" + "strip-ansi" "^5.0.0" + +"wrap-ansi@^6.2.0": + "integrity" "sha1-6Tk7oHEC5skaOyIUePAlfNKFblM=" + "resolved" "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-6.2.0.tgz" + "version" "6.2.0" + dependencies: + "ansi-styles" "^4.0.0" + "string-width" "^4.1.0" + "strip-ansi" "^6.0.0" + +"wrap-ansi@^7.0.0": + "integrity" "sha1-Z+FFz/UQpqaYS98RUpEdadLrnkM=" + "resolved" "https://registry.npm.taobao.org/wrap-ansi/download/wrap-ansi-7.0.0.tgz" + "version" "7.0.0" + dependencies: + "ansi-styles" "^4.0.0" + "string-width" "^4.1.0" + "strip-ansi" "^6.0.0" + +"wrappy@1": + "integrity" "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" + "resolved" "https://registry.nlark.com/wrappy/download/wrappy-1.0.2.tgz" + "version" "1.0.2" + +"write@1.0.3": + "integrity" "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==" + "resolved" "https://registry.npmmirror.com/write/-/write-1.0.3.tgz" + "version" "1.0.3" + dependencies: + "mkdirp" "^0.5.1" + +"ws@^6.0.0": + "integrity" "sha1-3Vzb1XqZeZFgl2UtePHMX66gwy4=" + "resolved" "https://registry.nlark.com/ws/download/ws-6.2.2.tgz?cache=0&sync_timestamp=1625897053615&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fws%2Fdownload%2Fws-6.2.2.tgz" + "version" "6.2.2" + dependencies: + "async-limiter" "~1.0.0" + +"ws@^6.2.1": + "integrity" "sha1-3Vzb1XqZeZFgl2UtePHMX66gwy4=" + "resolved" "https://registry.nlark.com/ws/download/ws-6.2.2.tgz?cache=0&sync_timestamp=1625897053615&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fws%2Fdownload%2Fws-6.2.2.tgz" + "version" "6.2.2" + dependencies: + "async-limiter" "~1.0.0" + +"ws@^7.0.0", "ws@^7.4.5": + "integrity" "sha1-Fgg1tjx9l7+rQY/BuKn87SrAGnQ=" + "resolved" "https://registry.nlark.com/ws/download/ws-7.5.3.tgz?cache=0&sync_timestamp=1625897053615&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fws%2Fdownload%2Fws-7.5.3.tgz" + "version" "7.5.3" + +"xml-name-validator@^3.0.0": + "integrity" "sha1-auc+Bt5NjG5H+fsYH3jWSK1FfGo=" + "resolved" "https://registry.npm.taobao.org/xml-name-validator/download/xml-name-validator-3.0.0.tgz" + "version" "3.0.0" + +"xml2js@^0.4.16": + "integrity" "sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug==" + "resolved" "https://registry.npmmirror.com/xml2js/-/xml2js-0.4.23.tgz" + "version" "0.4.23" + dependencies: + "sax" ">=0.6.0" + "xmlbuilder" "~11.0.0" + +"xmlbuilder@~11.0.0": + "integrity" "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==" + "resolved" "https://registry.npmmirror.com/xmlbuilder/-/xmlbuilder-11.0.1.tgz" + "version" "11.0.1" + +"xmlchars@^2.1.1": + "integrity" "sha1-Bg/hvLf5x2/ioX24apvDq4lCEMs=" + "resolved" "https://registry.npm.taobao.org/xmlchars/download/xmlchars-2.2.0.tgz" + "version" "2.2.0" + +"xregexp@2.0.0": + "integrity" "sha512-xl/50/Cf32VsGq/1R8jJE5ajH1yMCQkpmoS10QbFZWl2Oor4H0Me64Pu2yxvsRWK3m6soJbmGfzSR7BYmDcWAA==" + "resolved" "https://registry.npmmirror.com/xregexp/-/xregexp-2.0.0.tgz" + "version" "2.0.0" + +"xtend@^4.0.0", "xtend@~4.0.1": + "integrity" "sha1-u3J3n1+kZRhrH0OPZ0+jR/2121Q=" + "resolved" "https://registry.nlark.com/xtend/download/xtend-4.0.2.tgz" + "version" "4.0.2" + +"y18n@^4.0.0": + "integrity" "sha1-tfJZyCzW4zaSHv17/Yv1YN6e7t8=" + "resolved" "https://registry.nlark.com/y18n/download/y18n-4.0.3.tgz" + "version" "4.0.3" + +"y18n@^5.0.5": + "integrity" "sha1-f0k00PfKjFb5UxSTndzS3ZHOHVU=" + "resolved" "https://registry.nlark.com/y18n/download/y18n-5.0.8.tgz" + "version" "5.0.8" + +"yallist@^2.1.2": + "integrity" "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" + "resolved" "https://registry.nlark.com/yallist/download/yallist-2.1.2.tgz" + "version" "2.1.2" + +"yallist@^3.0.2": + "integrity" "sha1-27fa+b/YusmrRev2ArjLrQ1dCP0=" + "resolved" "https://registry.nlark.com/yallist/download/yallist-3.1.1.tgz" + "version" "3.1.1" + +"yallist@^4.0.0": + "integrity" "sha1-m7knkNnA7/7GO+c1GeEaNQGaOnI=" + "resolved" "https://registry.nlark.com/yallist/download/yallist-4.0.0.tgz" + "version" "4.0.0" + +"yargs-parser@^13.1.1", "yargs-parser@^13.1.2", "yargs-parser@13.1.2": + "integrity" "sha1-Ew8JcC667vJlDVTObj5XBvek+zg=" + "resolved" "https://registry.nlark.com/yargs-parser/download/yargs-parser-13.1.2.tgz" + "version" "13.1.2" + dependencies: + "camelcase" "^5.0.0" + "decamelize" "^1.2.0" + +"yargs-parser@^20.2.2": + "integrity" "sha1-LrfcOwKJcY/ClfNidThFxBoMlO4=" + "resolved" "https://registry.nlark.com/yargs-parser/download/yargs-parser-20.2.9.tgz" + "version" "20.2.9" + +"yargs-unparser@1.6.0": + "integrity" "sha1-7yXCx2n/a9CeSw+dfGBfsnhG6p8=" + "resolved" "https://registry.npm.taobao.org/yargs-unparser/download/yargs-unparser-1.6.0.tgz" + "version" "1.6.0" + dependencies: + "flat" "^4.1.0" + "lodash" "^4.17.15" + "yargs" "^13.3.0" + +"yargs@^13.3.0": + "integrity" "sha1-rX/+/sGqWVZayRX4Lcyzipwxot0=" + "resolved" "https://registry.nlark.com/yargs/download/yargs-13.3.2.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-13.3.2.tgz" + "version" "13.3.2" + dependencies: + "cliui" "^5.0.0" + "find-up" "^3.0.0" + "get-caller-file" "^2.0.1" + "require-directory" "^2.1.1" + "require-main-filename" "^2.0.0" + "set-blocking" "^2.0.0" + "string-width" "^3.0.0" + "which-module" "^2.0.0" + "y18n" "^4.0.0" + "yargs-parser" "^13.1.2" + +"yargs@^13.3.2": + "integrity" "sha1-rX/+/sGqWVZayRX4Lcyzipwxot0=" + "resolved" "https://registry.nlark.com/yargs/download/yargs-13.3.2.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-13.3.2.tgz" + "version" "13.3.2" + dependencies: + "cliui" "^5.0.0" + "find-up" "^3.0.0" + "get-caller-file" "^2.0.1" + "require-directory" "^2.1.1" + "require-main-filename" "^2.0.0" + "set-blocking" "^2.0.0" + "string-width" "^3.0.0" + "which-module" "^2.0.0" + "y18n" "^4.0.0" + "yargs-parser" "^13.1.2" + +"yargs@^16.0.0": + "integrity" "sha1-HIK/D2tqZur85+8w43b0mhJHf2Y=" + "resolved" "https://registry.nlark.com/yargs/download/yargs-16.2.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-16.2.0.tgz" + "version" "16.2.0" + dependencies: + "cliui" "^7.0.2" + "escalade" "^3.1.1" + "get-caller-file" "^2.0.5" + "require-directory" "^2.1.1" + "string-width" "^4.2.0" + "y18n" "^5.0.5" + "yargs-parser" "^20.2.2" + +"yargs@13.3.2": + "integrity" "sha1-rX/+/sGqWVZayRX4Lcyzipwxot0=" + "resolved" "https://registry.nlark.com/yargs/download/yargs-13.3.2.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-13.3.2.tgz" + "version" "13.3.2" + dependencies: + "cliui" "^5.0.0" + "find-up" "^3.0.0" + "get-caller-file" "^2.0.1" + "require-directory" "^2.1.1" + "require-main-filename" "^2.0.0" + "set-blocking" "^2.0.0" + "string-width" "^3.0.0" + "which-module" "^2.0.0" + "y18n" "^4.0.0" + "yargs-parser" "^13.1.2" + +"yargs@14.0.0": + "integrity" "sha1-ukysyAKzwLPjap55FyN2PVeoUGY=" + "resolved" "https://registry.nlark.com/yargs/download/yargs-14.0.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fyargs%2Fdownload%2Fyargs-14.0.0.tgz" + "version" "14.0.0" + dependencies: + "cliui" "^5.0.0" + "decamelize" "^1.2.0" + "find-up" "^3.0.0" + "get-caller-file" "^2.0.1" + "require-directory" "^2.1.1" + "require-main-filename" "^2.0.0" + "set-blocking" "^2.0.0" + "string-width" "^3.0.0" + "which-module" "^2.0.0" + "y18n" "^4.0.0" + "yargs-parser" "^13.1.1" + +"yorkie@^2.0.0": + "integrity" "sha1-kkEZEtQ1IU4SxRwq4Qk+VLa7g9k=" + "resolved" "https://registry.npm.taobao.org/yorkie/download/yorkie-2.0.0.tgz" + "version" "2.0.0" + dependencies: + "execa" "^0.8.0" + "is-ci" "^1.0.10" + "normalize-path" "^1.0.0" + "strip-indent" "^2.0.0" + +"zrender@5.0.4": + "integrity" "sha1-icNVr5CLn2SjAbOPdRt5UfLIqVo=" + "resolved" "https://registry.nlark.com/zrender/download/zrender-5.0.4.tgz" + "version" "5.0.4" + dependencies: + "tslib" "2.0.3" diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/5719e6ae-bc65-4344-93bf-c0d23dd5d595.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/5719e6ae-bc65-4344-93bf-c0d23dd5d595.vsidx" deleted file mode 100644 index c8ec076..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/5719e6ae-bc65-4344-93bf-c0d23dd5d595.vsidx" +++ /dev/null Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/6c6ca66c-f03a-48f7-9fb7-7620f4736346.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/6c6ca66c-f03a-48f7-9fb7-7620f4736346.vsidx" deleted file mode 100644 index 53f8c53..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/6c6ca66c-f03a-48f7-9fb7-7620f4736346.vsidx" +++ /dev/null Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/789398d4-ad10-4b21-9f9c-c017ed2e4aa0.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/789398d4-ad10-4b21-9f9c-c017ed2e4aa0.vsidx" new file mode 100644 index 0000000..d734286 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/789398d4-ad10-4b21-9f9c-c017ed2e4aa0.vsidx" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/7dfb58b4-b4db-4726-99ab-289029af1540.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/7dfb58b4-b4db-4726-99ab-289029af1540.vsidx" deleted file mode 100644 index d234e4a..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/7dfb58b4-b4db-4726-99ab-289029af1540.vsidx" +++ /dev/null Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/914d9c3f-57db-4637-bc40-52081424fde2.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/914d9c3f-57db-4637-bc40-52081424fde2.vsidx" new file mode 100644 index 0000000..3007b7e --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/914d9c3f-57db-4637-bc40-52081424fde2.vsidx" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/e2441919-0f15-4240-aa6e-d0b378dfd0ba.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/e2441919-0f15-4240-aa6e-d0b378dfd0ba.vsidx" deleted file mode 100644 index 966097a..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/e2441919-0f15-4240-aa6e-d0b378dfd0ba.vsidx" +++ /dev/null Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/eef0aa91-791e-44dd-b321-3146cf9e9a18.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/eef0aa91-791e-44dd-b321-3146cf9e9a18.vsidx" new file mode 100644 index 0000000..c712292 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/eef0aa91-791e-44dd-b321-3146cf9e9a18.vsidx" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/f3502ed8-fc43-47df-b9a2-74d7c2feb215.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/f3502ed8-fc43-47df-b9a2-74d7c2feb215.vsidx" new file mode 100644 index 0000000..3c31860 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/f3502ed8-fc43-47df-b9a2-74d7c2feb215.vsidx" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/f91e73eb-1823-4174-b99b-0eb163ec64f8.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/f91e73eb-1823-4174-b99b-0eb163ec64f8.vsidx" new file mode 100644 index 0000000..2f1d0a1 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/f91e73eb-1823-4174-b99b-0eb163ec64f8.vsidx" Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/fed10872-4afc-4516-bd7e-bb67d0b38147.vsidx" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/fed10872-4afc-4516-bd7e-bb67d0b38147.vsidx" deleted file mode 100644 index cb71409..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/.vs/WIDESEA_WMSServer/FileContentIndex/fed10872-4afc-4516-bd7e-bb67d0b38147.vsidx" +++ /dev/null Binary files differ diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalFlowRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalFlowRepository.cs" new file mode 100644 index 0000000..2be0716 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalFlowRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_IApprovalRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_ApprovalRepository +{ + public class ApprovalFlowRepository : RepositoryBase<Dt_ApprovalFlow>, IApprovalFlowRepository + { + public ApprovalFlowRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalNodeRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalNodeRepository.cs" new file mode 100644 index 0000000..902bfc0 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalNodeRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_IApprovalRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_ApprovalRepository +{ + public class ApprovalNodeRepository : RepositoryBase<Dt_ApprovalNode>, IApprovalNodeRepository + { + public ApprovalNodeRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalTaskRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalTaskRepository.cs" new file mode 100644 index 0000000..ffc5d70 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/ApprovalTaskRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_IApprovalRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_ApprovalRepository +{ + public class ApprovalTaskRepository : RepositoryBase<Dt_ApprovalTask>, IApprovalTaskRepository + { + public ApprovalTaskRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/NodeTransitionRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/NodeTransitionRepository.cs" new file mode 100644 index 0000000..0d7018d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/NodeTransitionRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_IApprovalRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_ApprovalRepository +{ + public class NodeTransitionRepository : RepositoryBase<Dt_NodeTransition>, INodeTransitionRepository + { + public NodeTransitionRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/WIDESEA_ApprovalRepository.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/WIDESEA_ApprovalRepository.csproj" new file mode 100644 index 0000000..39e5b50 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalRepository/WIDESEA_ApprovalRepository.csproj" @@ -0,0 +1,13 @@ +<Project Sdk="Microsoft.NET.Sdk"> + + <PropertyGroup> + <TargetFramework>net6.0</TargetFramework> + <ImplicitUsings>enable</ImplicitUsings> + <Nullable>enable</Nullable> + </PropertyGroup> + + <ItemGroup> + <ProjectReference Include="..\WIDESEA_IApprovalRepository\WIDESEA_IApprovalRepository.csproj" /> + </ItemGroup> + +</Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalFlowService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalFlowService.cs" new file mode 100644 index 0000000..266acae --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalFlowService.cs" @@ -0,0 +1,27 @@ +锘縰sing HslCommunication.WebSocket; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Helper; +using WIDESEA_IApprovalRepository; +using WIDESEA_IApprovalService; +using WIDESEA_Model.Models; + +namespace ApprovalService +{ + public class ApprovalFlowService : ServiceBase<Dt_ApprovalFlow, IApprovalFlowRepository>, IApprovalFlowService + { + public ApprovalFlowService(IApprovalFlowRepository BaseDal) : base(BaseDal) + { + } + + public override WebResponseContent AddData(Dt_ApprovalFlow entity) + { + return base.AddData(entity); + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalNodeService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalNodeService.cs" new file mode 100644 index 0000000..4e57d40 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalNodeService.cs" @@ -0,0 +1,12 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace ApprovalService +{ + public class ApprovalNodeService + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalTaskService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalTaskService.cs" new file mode 100644 index 0000000..0c47e9a --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/ApprovalTaskService.cs" @@ -0,0 +1,210 @@ +锘縰sing HslCommunication.WebSocket; +using NetTaste; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_ApprovalRepository; +using WIDESEA_Common.CommonEnum; +using WIDESEA_Core; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Helper; +using WIDESEA_IApprovalRepository; +using WIDESEA_IApprovalService; +using WIDESEA_ICheckRepository; +using WIDESEA_ISystemRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_ApprovalService +{ + public class ApprovalTaskService : ServiceBase<Dt_ApprovalTask, IApprovalTaskRepository>, IApprovalTaskService + { + private readonly IUnitOfWorkManage _unitOfWorkManage; + private readonly IApprovalFlowRepository _approvalFlowRepository; + private readonly IApprovalNodeRepository _approvalNodeRepository; + private readonly ICheckOrderRepository _checkOrderRepository; + private readonly WebSocketServer _webSocketServer; + private readonly ISys_UserRepository _userRepository; + + public ApprovalTaskService(IApprovalTaskRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, IApprovalFlowRepository approvalFlowRepository, IApprovalNodeRepository approvalNodeRepository, ICheckOrderRepository checkOrderRepository, WebSocketServer webSocketServer, ISys_UserRepository userRepository) : base(BaseDal) + { + _unitOfWorkManage = unitOfWorkManage; + _approvalFlowRepository = approvalFlowRepository; + _approvalNodeRepository = approvalNodeRepository; + _checkOrderRepository = checkOrderRepository; + _webSocketServer = webSocketServer; + _userRepository = userRepository; + } + + public WebResponseContent AuditAgree(int sourceKey) + { + try + { + Dt_ApprovalFlow approvalFlow = _approvalFlowRepository.QueryFirst(x => x.FlowCode == "IQC"); + if (approvalFlow == null) + { + return WebResponseContent.Instance.Error($"鏈畾涔夎瀹℃壒娴�"); + } + List<Dt_ApprovalNode> approvalNodes = _approvalNodeRepository.QueryData(x => x.FlowId == approvalFlow.Id); + if (approvalNodes == null || approvalNodes.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈畾涔夎瀹℃壒娴佺▼鑺傜偣"); + } + + Dt_ApprovalNode? currentNode = approvalNodes.FirstOrDefault(x => x.ApproverRole == App.User.RoleId); + if (currentNode == null) + { + return WebResponseContent.Instance.OK($"鏈壘鍒板綋鍓嶈鑹插鎵硅妭鐐�"); + } + + Dt_ApprovalTask approvalTask = BaseDal.QueryFirst(x => x.SourceKey == sourceKey && x.NodeId == currentNode.Id); + if (approvalTask == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌瀹℃壒鏁版嵁"); + } + + if (approvalTask.Status != AuditStatusEnum.Auditing.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ュ鎵瑰凡瀹屾垚"); + } + + Dt_CheckOrder checkOrder = _checkOrderRepository.QueryFirst(x => x.CheckOrderId == sourceKey); + if (checkOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒版潵婧愭暟鎹�(璐ㄦ鍗�)"); + } + + Dt_ApprovalNode? nextNode = approvalNodes.Where(x => x.NodeSequence > currentNode.NodeSequence).OrderBy(x => x.NodeSequence).FirstOrDefault(); + if (nextNode == null)//瀹℃壒娴佺▼缁撴潫 + { + approvalTask.Status = AuditStatusEnum.Agree.ObjToInt(); + + checkOrder.AuditStatus = AuditStatusEnum.Agree.ObjToInt(); + _unitOfWorkManage.BeginTran(); + _checkOrderRepository.UpdateData(checkOrder); + + BaseDal.UpdateData(approvalTask); + //BaseDal.DeleteAndMoveIntoHty(approvalTask, WIDESEA_Core.Enums.OperateTypeEnum.鑷姩瀹屾垚); + + WebSocketSession? webSocketSession = _webSocketServer.OnlineSessions.FirstOrDefault(x => x.Url.Contains(approvalTask.ApplicantUserName)); + if (webSocketSession != null) + { + _webSocketServer.SendClientPayload(webSocketSession, "鍚屾剰"); + } + _unitOfWorkManage.CommitTran(); + } + else//杩涘叆涓嬩竴绾у鎵硅妭鐐� + { + object obj = new + { + title = "IQC璐ㄦ缁撴灉瀹℃壒", + formData = checkOrder, + tableData = checkOrder.Details, + message = "鎺ㄩ�佹祴璇曚俊鎭綋", + date = DateTime.Now.ToString(), + }; + List<Dt_ApprovalTask> approvalTasks = new List<Dt_ApprovalTask>(); + List<string> userNames = new List<string>(); + List<Sys_User> users = _userRepository.QueryData(x => x.RoleId == nextNode.ApproverRole); + foreach (Sys_User user in users) + { + Dt_ApprovalTask newApprovalTask = new Dt_ApprovalTask() + { + FlowId = approvalFlow.Id, + NodeId = nextNode.Id, + ApplicantUserId = App.User.UserId, + ApplicantUserName = user.UserName, + Status = AuditStatusEnum.Auditing.ObjToInt(), + AuditUser = user.UserName, + SourceKey = approvalTask.SourceKey + }; + approvalTasks.Add(newApprovalTask); + userNames.Add(user.UserName); + } + + approvalTask.Status = AuditStatusEnum.Agree.ObjToInt(); + BaseDal.UpdateData(approvalTask); + BaseDal.AddData(approvalTasks); + foreach (string userName in userNames) + { + WebSocketSession? socketSessions = _webSocketServer.OnlineSessions.FirstOrDefault(x => x.Url.Contains(userName)); + if (socketSessions != null) + { + _webSocketServer.SendClientPayload(socketSessions, obj.Serialize()); + } + } + } + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } + + public WebResponseContent AuditReject(int sourceKey) + { + try + { + Dt_ApprovalFlow approvalFlow = _approvalFlowRepository.QueryFirst(x => x.FlowCode == "IQC"); + if (approvalFlow == null) + { + return WebResponseContent.Instance.Error($"鏈畾涔夎瀹℃壒娴�"); + } + List<Dt_ApprovalNode> approvalNodes = _approvalNodeRepository.QueryData(x => x.FlowId == approvalFlow.Id); + if (approvalNodes == null || approvalNodes.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈畾涔夎瀹℃壒娴佺▼鑺傜偣"); + } + + Dt_ApprovalNode? currentNode = approvalNodes.FirstOrDefault(x => x.ApproverRole == App.User.RoleId); + if (currentNode == null) + { + return WebResponseContent.Instance.OK($"鏈壘鍒板綋鍓嶈鑹插鎵硅妭鐐�"); + } + + Dt_ApprovalTask approvalTask = BaseDal.QueryFirst(x => x.SourceKey == sourceKey); + if (approvalTask == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌瀹℃壒鏁版嵁"); + } + + if (approvalTask.Status != AuditStatusEnum.Auditing.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ュ鎵瑰凡瀹屾垚"); + } + + Dt_CheckOrder checkOrder = _checkOrderRepository.QueryFirst(x => x.CheckOrderId == sourceKey); + if (checkOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒版潵婧愭暟鎹�(璐ㄦ鍗�)"); + } + + approvalTask.Status = AuditStatusEnum.Reject.ObjToInt(); + + checkOrder.AuditStatus = AuditStatusEnum.Reject.ObjToInt(); + _unitOfWorkManage.BeginTran(); + _checkOrderRepository.UpdateData(checkOrder); + + BaseDal.UpdateData(approvalTask); + //BaseDal.DeleteAndMoveIntoHty(approvalTask, WIDESEA_Core.Enums.OperateTypeEnum.鑷姩瀹屾垚); + + WebSocketSession? webSocketSession = _webSocketServer.OnlineSessions.FirstOrDefault(x => x.Url.Contains(approvalTask.ApplicantUserName)); + if (webSocketSession != null) + { + _webSocketServer.SendClientPayload(webSocketSession, "椹冲洖"); + } + _unitOfWorkManage.CommitTran(); + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/WIDESEA_ApprovalService.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/WIDESEA_ApprovalService.csproj" new file mode 100644 index 0000000..586cd10 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ApprovalService/WIDESEA_ApprovalService.csproj" @@ -0,0 +1,15 @@ +<Project Sdk="Microsoft.NET.Sdk"> + + <PropertyGroup> + <TargetFramework>net6.0</TargetFramework> + <ImplicitUsings>enable</ImplicitUsings> + <Nullable>enable</Nullable> + </PropertyGroup> + + <ItemGroup> + <ProjectReference Include="..\WIDESEA_IApprovalService\WIDESEA_IApprovalService.csproj" /> + <ProjectReference Include="..\WIDESEA_ICheckRepository\WIDESEA_ICheckRepository.csproj" /> + <ProjectReference Include="..\WIDESEA_ISystemRepository\WIDESEA_ISystemRepository.csproj" /> + </ItemGroup> + +</Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/LocationInfoRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/LocationInfoRepository.cs" index 7508d1f..d7e8f20 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/LocationInfoRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/LocationInfoRepository.cs" @@ -41,11 +41,6 @@ return base.UpdateData(entity); } - public List<string> GetCanOutLocationCodes(List<string> roadways, List<int> areaIds) - { - return QueryData(x => x.LocationCode, x => roadways.Contains(x.RoadwayNo) && (areaIds.Contains(x.AreaId) || x.AreaId == 0) && x.LocationStatus == LocationStatusEnum.InStock.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyOut.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt())).Distinct().ToList(); - } - public List<Dt_LocationInfo> GetLocationInfos(List<string> locationCodes) { return QueryData(x => locationCodes.Contains(x.LocationCode)); diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/WarehouseRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/WarehouseRepository.cs" index b80d8f0..4e20a81 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/WarehouseRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicRepository/WarehouseRepository.cs" @@ -18,6 +18,6 @@ { } - public List<int> EnableWarehouseIds => QueryData(x => x.Id, x => x.WarehouseStatus == EnableEnum.Enable.ObjToInt()).Distinct().ToList(); + public List<int> EnableWarehouseIds => QueryData(x => x.WarehouseId, x => x.WarehouseStatus == EnableEnum.Enable.ObjToInt()).Distinct().ToList(); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/LocationInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/LocationInfoService.cs" index 677a7a6..1505e43 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/LocationInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/LocationInfoService.cs" @@ -1,4 +1,5 @@ -锘縰sing OfficeOpenXml.FormulaParsing.Excel.Functions.Text; +锘縰sing HslCommunication.WebSocket; +using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; using SqlSugar; using System; using System.Collections.Generic; @@ -7,6 +8,7 @@ using System.Threading.Tasks; using WIDESEA_Common.LocationEnum; using WIDESEA_Core; +using WIDESEA_Core.BaseRepository; using WIDESEA_Core.BaseServices; using WIDESEA_Core.Enums; using WIDESEA_Core.Helper; @@ -20,12 +22,18 @@ { public partial class LocationInfoService : ServiceBase<Dt_LocationInfo, ILocationInfoRepository>, ILocationInfoService { - private readonly IBasicRepository _basicRepository; + private readonly IUnitOfWorkManage _unitOfWorkManage; + public ILocationInfoRepository Repository => BaseDal; - public LocationInfoService(ILocationInfoRepository BaseDal, IBasicRepository basicRepository) : base(BaseDal) + public LocationInfoService(ILocationInfoRepository BaseDal, IUnitOfWorkManage unitOfWorkManage) : base(BaseDal) { - _basicRepository = basicRepository; + _unitOfWorkManage = unitOfWorkManage; + } + + public override PageGridData<Dt_LocationInfo> GetPageData(PageDataOptions options) + { + return base.GetPageData(options); } public override WebResponseContent AddData(SaveModel saveModel) @@ -89,7 +97,7 @@ List<Dt_LocationInfo> locationInfos = new List<Dt_LocationInfo>(); for (int i = 0; i < initializationLocationDTO.MaxRow; i++) { - if((i + 1) % initializationLocationDTO.MaxRow == 1) + if ((i + 1) % initializationLocationDTO.MaxRow == 1) { depth = initializationLocationDTO.Depth; } @@ -111,7 +119,7 @@ { Dt_LocationInfo locationInfo = new Dt_LocationInfo() { - AreaId = 0, + WarehouseId = 0, Column = j + 1, EnableStatus = EnableStatusEnum.Normal.ObjToInt(), Layer = k + 1, diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/WarehouseService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/WarehouseService.cs" index 4528779..2384e6a 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/WarehouseService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Base/WarehouseService.cs" @@ -40,7 +40,7 @@ public WebResponseContent WarehouseEnableStatus(int[] keys) { - List<Dt_Warehouse> warehouses = Repository.QueryData(x => keys.Contains(x.Id)); + List<Dt_Warehouse> warehouses = Repository.QueryData(x => keys.Contains(x.WarehouseId)); warehouses.ForEach(x => { x.WarehouseStatus = EnableEnum.Enable.ObjToInt(); @@ -52,7 +52,7 @@ public WebResponseContent WarehouseDisableStatus(int[] keys) { - List<Dt_Warehouse> warehouses = Repository.QueryData(x => keys.Contains(x.Id)); + List<Dt_Warehouse> warehouses = Repository.QueryData(x => keys.Contains(x.WarehouseId)); warehouses.ForEach(x => { x.WarehouseStatus = EnableEnum.Disable.ObjToInt(); diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" index 679c7cd..176c147 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" @@ -23,13 +23,6 @@ { public partial class LocationInfoService : ServiceBase<Dt_LocationInfo, ILocationInfoRepository>, ILocationInfoService { - private readonly IRecordService _recordService; - public LocationInfoService(ILocationInfoRepository BaseDal, IBasicRepository basicRepository, IRecordService recordService) : base(BaseDal) - { - _basicRepository = basicRepository; - _recordService = recordService; - } - double weightValue = 0.5; private readonly static object _locker = new object(); @@ -148,8 +141,9 @@ return null; } - public void UpdateLocationStatus(string locationCode, PalletTypeEnum palletType, LocationStatusEnum locationStatus, string taskNum = "", string orderNo = "") + public void UpdateLocationStatus(string locationCode, PalletTypeEnum palletType, LocationStatusEnum locationStatus) { + Dt_LocationInfo location = Repository.QueryFirst(x => x.LocationCode == locationCode); List<Dt_LocationInfo> locationInfos = Repository.QueryData(x => x.RoadwayNo == location.RoadwayNo); @@ -188,6 +182,47 @@ Repository.UpdateData(locations); } + public void UpdateLocationStatus(Dt_LocationInfo location, PalletTypeEnum palletType, LocationStatusEnum locationStatus) + { + + + List<Dt_LocationInfo> locationInfos = Repository.QueryData(x => x.RoadwayNo == location.RoadwayNo); + + List<Dt_LocationInfo> locations = GetGroupLocations(locationInfos, location); + if (locationInfos.Max(x => x.Depth) < 3) + { + for (int i = 0; i < locations.Count; i++) + { + locations[i].LocationStatus = locationStatus.ObjToInt(); + locations[i].LocationType = palletType.ObjToInt(); + } + + Dt_LocationInfo? nearLocation = locationInfos.FirstOrDefault(x => x.Row == location.Row && x.Layer == location.Layer && x.Depth == location.Depth && x.Column == location.Column + 1); + if (nearLocation != null) + { + List<Dt_LocationInfo> nearLocations = GetGroupLocations(locationInfos, nearLocation); + for (int i = 0; i < nearLocations.Count; i++) + { + nearLocations[i].LocationType = palletType.ObjToInt(); + if (palletType == PalletTypeEnum.LargePallet) + { + nearLocations[i].LocationStatus = locationStatus.ObjToInt(); + } + } + locations.AddRange(nearLocations); + } + } + else + { + for (int i = 0; i < locations.Count; i++) + { + locations[i].LocationStatus = locationStatus.ObjToInt(); + locations[i].LocationType = palletType.ObjToInt(); + } + } + Repository.UpdateData(locations); + } + private List<Dt_LocationInfo> GetGroupLocations(List<Dt_LocationInfo> locationInfos, Dt_LocationInfo location) { List<Dt_LocationInfo> groupLocations = new List<Dt_LocationInfo>() { location }; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/CheckOrderRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/CheckOrderRepository.cs" new file mode 100644 index 0000000..adc22ff --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/CheckOrderRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_ICheckRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_CheckRepository +{ + public class CheckOrderRepository : RepositoryBase<Dt_CheckOrder>, ICheckOrderRepository + { + public CheckOrderRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/CheckOrderResultRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/CheckOrderResultRepository.cs" new file mode 100644 index 0000000..42fd3b8 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/CheckOrderResultRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_ICheckRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_CheckRepository +{ + public class CheckOrderResultRepository : RepositoryBase<Dt_CheckOrderResult>, ICheckOrderResultRepository + { + public CheckOrderResultRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/WIDESEA_CheckRepository.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/WIDESEA_CheckRepository.csproj" new file mode 100644 index 0000000..10c789c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckRepository/WIDESEA_CheckRepository.csproj" @@ -0,0 +1,13 @@ +<Project Sdk="Microsoft.NET.Sdk"> + + <PropertyGroup> + <TargetFramework>net6.0</TargetFramework> + <ImplicitUsings>enable</ImplicitUsings> + <Nullable>enable</Nullable> + </PropertyGroup> + + <ItemGroup> + <ProjectReference Include="..\WIDESEA_ICheckRepository\WIDESEA_ICheckRepository.csproj" /> + </ItemGroup> + +</Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/CheckOrderResultService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/CheckOrderResultService.cs" new file mode 100644 index 0000000..d03eaa7 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/CheckOrderResultService.cs" @@ -0,0 +1,83 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Common.OrderEnum; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Helper; +using WIDESEA_IApprovalRepository; +using WIDESEA_ICheckRepository; +using WIDESEA_ICheckService; +using WIDESEA_Model.Models; + +namespace WIDESEA_CheckService +{ + public class CheckOrderResultService : ServiceBase<Dt_CheckOrderResult, ICheckOrderResultRepository>, ICheckOrderResultService + { + private readonly ICheckOrderRepository _checkOrderRepository; + + public CheckOrderResultService(ICheckOrderResultRepository BaseDal, ICheckOrderRepository checkOrderRepository) : base(BaseDal) + { + _checkOrderRepository = checkOrderRepository; + } + + public WebResponseContent CommitCheckResult(int checkOrderId, Dt_CheckOrderResult checkResult) + { + WebResponseContent content = new WebResponseContent(); + try + { + Dt_CheckOrder checkOrder = _checkOrderRepository.QueryFirst(x => x.CheckOrderId == checkOrderId); + if (checkOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌璐ㄦ鍗�"); + } + if (checkOrder.CheckOrderStatus == CheckOrderStatusEnum.Checked.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ュ崟鎹凡缁忔楠屽畬鎴�"); + } + if (checkResult.Quantity < 0 || checkResult.Quantity > checkOrder.ReceivedQuantity || checkOrder.ReceivedQuantity - checkOrder.ScrappedQuantity - checkOrder.DefectedQuantity - checkOrder.ReturnQuantity < checkResult.Quantity) + { + return WebResponseContent.Instance.Error($"鏁伴噺杈撳叆閿欒"); + } + if (checkResult.Result == CheckResultEnum.Defect.ToString())//鐗归噰 + { + checkOrder.DefectedNote = checkResult.Note; + checkOrder.DefectedQuantity += checkResult.Quantity; + checkOrder.QualifiedQuantity -= checkResult.Quantity; + } + else if (checkResult.Result == CheckResultEnum.Return.ToString())//閫�璐� + { + checkOrder.DefectedNote = checkResult.Note; + checkOrder.ReturnQuantity += checkResult.Quantity; + checkOrder.QualifiedQuantity -= checkResult.Quantity; + } + else if (checkResult.Result == CheckResultEnum.Scrapped.ToString())//鎶ュ簾 + { + checkOrder.DefectedNote = checkResult.Note; + checkOrder.ScrappedQuantity += checkResult.Quantity; + checkOrder.QualifiedQuantity -= checkResult.Quantity; + } + + checkOrder.CheckOrderStatus = CheckOrderStatusEnum.Checked.ObjToInt(); + + Dt_CheckOrderResult checkOrderResult = new Dt_CheckOrderResult() + { + Quantity = checkResult.Quantity, + CheckOrderId = checkOrderId, + DefectCode = checkResult.DefectCode, + Result = checkResult.Result, + Note = checkResult.Note + }; + _checkOrderRepository.UpdateData(checkOrder); + BaseDal.AddData(checkOrderResult); + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + return WebResponseContent.Instance.Error($"{ex.Message}"); + } + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/CheckOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/CheckOrderService.cs" new file mode 100644 index 0000000..6e4dce7 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/CheckOrderService.cs" @@ -0,0 +1,125 @@ +锘縰sing HslCommunication.WebSocket; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Common.CommonEnum; +using WIDESEA_Common.OrderEnum; +using WIDESEA_Core; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Helper; +using WIDESEA_IApprovalRepository; +using WIDESEA_ICheckRepository; +using WIDESEA_ICheckService; +using WIDESEA_ISystemRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_CheckService +{ + public class CheckOrderService : ServiceBase<Dt_CheckOrder, ICheckOrderRepository>, ICheckOrderService + { + private readonly IUnitOfWorkManage _unitOfWorkManage; + private readonly IApprovalFlowRepository _approvalFlowRepository; + private readonly IApprovalNodeRepository _approvalNodeRepository; + private readonly IApprovalTaskRepository _approvalTaskRepository; + private readonly ISys_UserRepository _userRepository; + private readonly WebSocketServer _webSocketServer; + + public CheckOrderService(ICheckOrderRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, IApprovalFlowRepository approvalFlowRepository, IApprovalNodeRepository approvalNodeRepository, IApprovalTaskRepository approvalTaskRepository, ISys_UserRepository userRepository, WebSocketServer webSocketServer) : base(BaseDal) + { + _unitOfWorkManage = unitOfWorkManage; + _approvalFlowRepository = approvalFlowRepository; + _approvalNodeRepository = approvalNodeRepository; + _approvalTaskRepository = approvalTaskRepository; + _userRepository = userRepository; + _webSocketServer = webSocketServer; + } + + public WebResponseContent CommitAudit(int checkOrderId) + { + try + { + Dt_CheckOrder checkOrder = BaseDal.Db.Queryable<Dt_CheckOrder>().Where(x => x.CheckOrderId == checkOrderId).Includes(x => x.Details).First(); + if (checkOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌璐ㄦ鍗�"); + } + if(checkOrder.CheckOrderStatus != CheckOrderStatusEnum.Checked.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ヨ川妫�鍗曡繕鏈楠屽畬鎴�"); + } + + if (checkOrder.AuditStatus != AuditStatusEnum.NotCommited.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ユ暟鎹笉鍙啀娆℃彁浜ゅ鎵�"); + } + + Dt_ApprovalFlow approvalFlow = _approvalFlowRepository.QueryFirst(x => x.FlowCode == "IQC"); + if (approvalFlow == null) + { + return WebResponseContent.Instance.Error($"鏈畾涔夎瀹℃壒娴�"); + } + List<Dt_ApprovalNode> approvalNodes = _approvalNodeRepository.QueryData(x => x.FlowId == approvalFlow.Id); + if (approvalNodes == null || approvalNodes.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈畾涔夎瀹℃壒娴佺▼鑺傜偣"); + } + + Dt_ApprovalNode? approvalNode = approvalNodes.OrderBy(x => x.NodeSequence).FirstOrDefault(); + if (approvalNode == null) + { + return WebResponseContent.Instance.Error($"鏁版嵁閿欒"); + } + + List<Dt_ApprovalTask> approvalTasks = new List<Dt_ApprovalTask>(); + List<string> userNames = new List<string>(); + List<Sys_User> users = _userRepository.QueryData(x => x.RoleId == approvalNode.ApproverRole); + foreach (Sys_User user in users) + { + Dt_ApprovalTask approvalTask = new Dt_ApprovalTask() + { + FlowId = approvalFlow.Id, + NodeId = approvalNode.Id, + ApplicantUserId = App.User.UserId, + ApplicantUserName = user.UserName, + Status = AuditStatusEnum.Auditing.ObjToInt(), + AuditUser = user.UserName + }; + approvalTasks.Add(approvalTask); + userNames.Add(user.UserName); + } + _unitOfWorkManage.BeginTran(); + _approvalTaskRepository.AddData(approvalTasks); + checkOrder.AuditStatus = AuditStatusEnum.Auditing.ObjToInt(); + BaseDal.UpdateData(checkOrder); + + object obj = new + { + title = "IQC璐ㄦ缁撴灉瀹℃壒", + formData = checkOrder, + tableData = checkOrder.Details, + message = "鎺ㄩ�佹祴璇曚俊鎭綋", + date = DateTime.Now.ToString(), + }; + + foreach (string userName in userNames) + { + WebSocketSession? socketSessions = _webSocketServer.OnlineSessions.FirstOrDefault(x => x.Url.Contains(userName)); + if (socketSessions != null) + { + _webSocketServer.SendClientPayload(socketSessions, obj.Serialize()); + } + } + _unitOfWorkManage.CommitTran(); + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/WIDESEA_CheckService.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/WIDESEA_CheckService.csproj" new file mode 100644 index 0000000..96a5228 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_CheckService/WIDESEA_CheckService.csproj" @@ -0,0 +1,15 @@ +<Project Sdk="Microsoft.NET.Sdk"> + + <PropertyGroup> + <TargetFramework>net6.0</TargetFramework> + <ImplicitUsings>enable</ImplicitUsings> + <Nullable>enable</Nullable> + </PropertyGroup> + + <ItemGroup> + <ProjectReference Include="..\WIDESEA_IApprovalRepository\WIDESEA_IApprovalRepository.csproj" /> + <ProjectReference Include="..\WIDESEA_ICheckService\WIDESEA_ICheckService.csproj" /> + <ProjectReference Include="..\WIDESEA_ISystemRepository\WIDESEA_ISystemRepository.csproj" /> + </ItemGroup> + +</Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/CommonEnum/AuditStatusEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/CommonEnum/AuditStatusEnum.cs" new file mode 100644 index 0000000..ff76e24 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/CommonEnum/AuditStatusEnum.cs" @@ -0,0 +1,36 @@ +锘縰sing System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Common.CommonEnum +{ + public enum AuditStatusEnum + { + /// <summary> + /// 寰呮彁浜� + /// </summary> + [Description("寰呮彁浜�")] + NotCommited = 0, + + /// <summary> + /// 瀹℃壒涓� + /// </summary> + [Description("瀹℃壒涓�")] + Auditing = 1, + + /// <summary> + /// 鍚屾剰 + /// </summary> + [Description("鍚屾剰")] + Agree = 100, + + /// <summary> + /// 椹冲洖 + /// </summary> + [Description("椹冲洖")] + Reject = 101 + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/CommonEnum/UploadStatusEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/CommonEnum/UploadStatusEnum.cs" new file mode 100644 index 0000000..931f6f9 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/CommonEnum/UploadStatusEnum.cs" @@ -0,0 +1,12 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Common.CommonEnum +{ + internal class UploadStatusEnum + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/LocationEnum/LocationChangeType.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/LocationEnum/LocationChangeType.cs" index e83ba96..1ecb000 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/LocationEnum/LocationChangeType.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/LocationEnum/LocationChangeType.cs" @@ -1,5 +1,6 @@ 锘縰sing System; using System.Collections.Generic; +using System.ComponentModel; using System.Linq; using System.Text; using System.Threading.Tasks; @@ -11,6 +12,46 @@ /// </summary> public enum LocationChangeType { + /// <summary> + /// 鍏ュ簱鍒嗛厤 + /// </summary> + [Description("鍏ュ簱鍒嗛厤")] + InboundAssignLocation, + /// <summary> + /// 鍑哄簱鍒嗛厤 + /// </summary> + [Description("鍑哄簱鍒嗛厤")] + OutboundAssignLocation, + + /// <summary> + /// 绉诲簱鍒嗛厤 + /// </summary> + [Description("绉诲簱鍒嗛厤")] + RelocationAssignLocation, + + /// <summary> + /// 鍏ュ簱浠诲姟瀹屾垚 + /// </summary> + [Description("鍏ュ簱浠诲姟瀹屾垚")] + InboundCompleted, + + /// <summary> + /// 鍑哄簱浠诲姟瀹屾垚 + /// </summary> + [Description("鍑哄簱浠诲姟瀹屾垚")] + OutboundCompleted, + + /// <summary> + /// 绉诲簱浠诲姟瀹屾垚 + /// </summary> + [Description("绉诲簱浠诲姟瀹屾垚")] + RelocationCompleted, + + /// <summary> + /// 鎵嬪姩淇敼 + /// </summary> + [Description("鎵嬪姩淇敼")] + HandUpdate } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/CheckOrderEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/CheckOrderEnum.cs" new file mode 100644 index 0000000..8915b4c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/CheckOrderEnum.cs" @@ -0,0 +1,45 @@ +锘縰sing System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Common.OrderEnum +{ + public enum CheckOrderStatusEnum + { + /// <summary> + /// 寰呮 + /// </summary> + [Description("寰呮")] + NotCheck = 0, + + /// <summary> + /// 宸叉 + /// </summary> + [Description("宸叉")] + Checked = 1 + } + + public enum CheckResultEnum + { + /// <summary> + /// 閫�璐� + /// </summary> + [Description("閫�璐�")] + Return, + + /// <summary> + /// 鐗归噰 + /// </summary> + [Description("鐗归噰")] + Defect, + + /// <summary> + /// 鎶ュ簾 + /// </summary> + [Description("鎶ュ簾")] + Scrapped + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InOrderStatusEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InOrderStatusEnum.cs" deleted file mode 100644 index afe02e1..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InOrderStatusEnum.cs" +++ /dev/null @@ -1,45 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.ComponentModel; -using System.Linq; -using System.Text; -using System.Threading.Tasks; - -namespace WIDESEA_Common.OrderEnum -{ - /// <summary> - /// 鍏ュ簱鍗曟嵁鐘舵�� 0锛屾湭寮�濮� 1锛屽叆搴撲腑 2锛屽叆搴撳畬鎴� - /// </summary> - public enum InOrderStatusEnum - { - /// <summary> - /// 鏈紑濮� - /// </summary> - [Description("鏈紑濮�")] - 鏈紑濮� = 0, - - /// <summary> - /// 鍏ュ簱涓� - /// </summary> - [Description("鍏ュ簱涓�")] - 鍏ュ簱涓� = 1, - - /// <summary> - /// 鍏ュ簱瀹屾垚 - /// </summary> - [Description("鍏ュ簱瀹屾垚")] - 鍏ュ簱瀹屾垚 = 2, - - /// <summary> - /// 鍏抽棴 - /// </summary> - [Description("鍏抽棴")] - 鍏抽棴 = 99, - - /// <summary> - /// 鍙栨秷 - /// </summary> - [Description("鍙栨秷")] - 鍙栨秷 = 98 - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InOrderTypeEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InOrderTypeEnum.cs" deleted file mode 100644 index 2cbacec..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InOrderTypeEnum.cs" +++ /dev/null @@ -1,57 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.ComponentModel; -using System.Linq; -using System.Text; -using System.Threading.Tasks; - -namespace WIDESEA_Common.OrderEnum -{ - /// <summary> - /// 鍏ュ簱鍗曠被鍨� 100 鐢熶骇鍏ュ簱鍗�;200 鐢熶骇閫�鏂欏崟;300 閲囪喘鍏ュ簱鍗�;400 璋冩嫧鍏ュ簱鍗�;500 閿�鍞��璐у崟;600 绌虹洏鍏ュ簱鍗�;700 鍏朵粬鍏ュ簱鍗� - /// </summary> - public enum InOrderTypeEnum - { - /// <summary> - /// 鐢熶骇鍏ュ簱鍗� - /// </summary> - [Description("鐢熶骇鍏ュ簱鍗�")] - Product = 100, - - /// <summary> - /// 鐢熶骇閫�鏂欏崟 - /// </summary> - [Description("鐢熶骇閫�鏂欏崟")] - Return = 105, - - /// <summary> - /// 閲囪喘鍏ュ簱鍗� - /// </summary> - [Description("閲囪喘鍏ュ簱鍗�")] - Purchase = 110, - - /// <summary> - /// 璋冩嫧鍏ュ簱鍗� - /// </summary> - [Description("璋冩嫧鍏ュ簱鍗�")] - Allocat = 115, - - /// <summary> - /// 閿�鍞��璐у崟 - /// </summary> - [Description("閿�鍞��璐у崟")] - SaleReturn = 120, - - /// <summary> - /// 绌虹洏鍏ュ簱鍗� - /// </summary> - [Description("绌虹洏鍏ュ簱鍗�")] - EmptyDisk = 125, - - /// <summary> - /// 鍏朵粬鍏ュ簱鍗� - /// </summary> - [Description("鍏朵粬鍏ュ簱鍗�")] - Other = 130 - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InboundOrderMenu.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InboundOrderMenu.cs" new file mode 100644 index 0000000..904222d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/InboundOrderMenu.cs" @@ -0,0 +1,93 @@ +锘縰sing System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Common.OrderEnum +{ + /// <summary> + /// 鍏ュ簱鍗曟嵁鐘舵�� 0锛屾湭寮�濮� 1锛屽叆搴撲腑 2锛屽叆搴撳畬鎴� + /// </summary> + public enum InOrderStatusEnum + { + /// <summary> + /// 鏈紑濮� + /// </summary> + [Description("鏈紑濮�")] + 鏈紑濮� = 0, + + /// <summary> + /// 鍏ュ簱涓� + /// </summary> + [Description("鍏ュ簱涓�")] + 鍏ュ簱涓� = 1, + + /// <summary> + /// 鍏ュ簱瀹屾垚 + /// </summary> + [Description("鍏ュ簱瀹屾垚")] + 鍏ュ簱瀹屾垚 = 2, + + /// <summary> + /// 鍏抽棴 + /// </summary> + [Description("鍏抽棴")] + 鍏抽棴 = 99, + + /// <summary> + /// 鍙栨秷 + /// </summary> + [Description("鍙栨秷")] + 鍙栨秷 = 98 + } + + /// <summary> + /// 鍏ュ簱鍗曠被鍨� 100 鐢熶骇鍏ュ簱鍗�;200 鐢熶骇閫�鏂欏崟;300 閲囪喘鍏ュ簱鍗�;400 璋冩嫧鍏ュ簱鍗�;500 閿�鍞��璐у崟;600 绌虹洏鍏ュ簱鍗�;700 鍏朵粬鍏ュ簱鍗� + /// </summary> + public enum InOrderTypeEnum + { + /// <summary> + /// 鐢熶骇鍏ュ簱鍗� + /// </summary> + [Description("鐢熶骇鍏ュ簱鍗�")] + Product = 100, + + /// <summary> + /// 鐢熶骇閫�鏂欏崟 + /// </summary> + [Description("鐢熶骇閫�鏂欏崟")] + Return = 105, + + /// <summary> + /// 閲囪喘鍏ュ簱鍗� + /// </summary> + [Description("閲囪喘鍏ュ簱鍗�")] + Purchase = 110, + + /// <summary> + /// 璋冩嫧鍏ュ簱鍗� + /// </summary> + [Description("璋冩嫧鍏ュ簱鍗�")] + Allocat = 115, + + /// <summary> + /// 閿�鍞��璐у崟 + /// </summary> + [Description("閿�鍞��璐у崟")] + SaleReturn = 120, + + /// <summary> + /// 绌虹洏鍏ュ簱鍗� + /// </summary> + [Description("绌虹洏鍏ュ簱鍗�")] + EmptyDisk = 125, + + /// <summary> + /// 鍏朵粬鍏ュ簱鍗� + /// </summary> + [Description("鍏朵粬鍏ュ簱鍗�")] + Other = 130 + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutOrderStatusEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutOrderStatusEnum.cs" deleted file mode 100644 index d63cb60..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutOrderStatusEnum.cs" +++ /dev/null @@ -1,42 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.ComponentModel; -using System.Linq; -using System.Text; -using System.Threading.Tasks; - -namespace WIDESEA_Common.OrderEnum -{ - public enum OutOrderStatusEnum - { - /// <summary> - /// 鏈紑濮� - /// </summary> - [Description("鏈紑濮�")] - 鏈紑濮� = 0, - - /// <summary> - /// 鍑哄簱涓� - /// </summary> - [Description("鍑哄簱涓�")] - 鍑哄簱涓� = 1, - - /// <summary> - /// 鍑哄簱瀹屾垚 - /// </summary> - [Description("鍑哄簱瀹屾垚")] - 鍑哄簱瀹屾垚 = 2, - - /// <summary> - /// 鍏抽棴 - /// </summary> - [Description("鍏抽棴")] - 鍏抽棴 = 99, - - /// <summary> - /// 鍙栨秷 - /// </summary> - [Description("鍙栨秷")] - 鍙栨秷 = 98 - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutOrderTypeEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutOrderTypeEnum.cs" deleted file mode 100644 index 66b5aea..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutOrderTypeEnum.cs" +++ /dev/null @@ -1,63 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.ComponentModel; -using System.Linq; -using System.Text; -using System.Threading.Tasks; - -namespace WIDESEA_Common.OrderEnum -{ - /// <summary> - /// 鍑哄簱鍗曠被鍨� - /// </summary> - public enum OutOrderTypeEnum - { - /// <summary> - /// 鐢熶骇杩斿伐鍗� - /// </summary> - [Description("鐢熶骇杩斿伐鍗�")] - Rework = 200, - - /// <summary> - /// 鐢熶骇鍙戞枡鍗� - /// </summary> - [Description("鐢熶骇鍙戞枡鍗�")] - Issue = 205, - - /// <summary> - /// 閲囪喘閫�璐у崟 - /// </summary> - [Description("閲囪喘閫�璐у崟")] - ProcureReturn = 210, - - /// <summary> - /// 璋冩嫧鍑哄簱鍗� - /// </summary> - [Description("璋冩嫧鍑哄簱鍗�")] - Allocate = 215, - - /// <summary> - /// 閿�鍞嚭搴撳崟 - /// </summary> - [Description("閿�鍞嚭搴撳崟")] - SaleOut = 220, - - /// <summary> - /// 绌虹洏鍑哄簱鍗� - /// </summary> - [Description("绌虹洏鍑哄簱鍗�")] - EmptyDisk = 225, - - /// <summary> - /// 璐ㄦ鍑哄簱鍗� - /// </summary> - [Description("璐ㄦ鍑哄簱鍗�")] - Quality = 230, - - /// <summary> - /// 鍏朵粬鍑哄簱鍗� - /// </summary> - [Description("鍏朵粬鍑哄簱鍗�")] - Other = 235 - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutboundOrderEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutboundOrderEnum.cs" new file mode 100644 index 0000000..3b43f33 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/OutboundOrderEnum.cs" @@ -0,0 +1,96 @@ +锘縰sing System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Common.OrderEnum +{ + public enum OutOrderStatusEnum + { + /// <summary> + /// 鏈紑濮� + /// </summary> + [Description("鏈紑濮�")] + 鏈紑濮� = 0, + + /// <summary> + /// 鍑哄簱涓� + /// </summary> + [Description("鍑哄簱涓�")] + 鍑哄簱涓� = 1, + + /// <summary> + /// 鍑哄簱瀹屾垚 + /// </summary> + [Description("鍑哄簱瀹屾垚")] + 鍑哄簱瀹屾垚 = 2, + + /// <summary> + /// 鍏抽棴 + /// </summary> + [Description("鍏抽棴")] + 鍏抽棴 = 99, + + /// <summary> + /// 鍙栨秷 + /// </summary> + [Description("鍙栨秷")] + 鍙栨秷 = 98 + } + + /// <summary> + /// 鍑哄簱鍗曠被鍨� + /// </summary> + public enum OutOrderTypeEnum + { + /// <summary> + /// 鐢熶骇杩斿伐鍗� + /// </summary> + [Description("鐢熶骇杩斿伐鍗�")] + Rework = 200, + + /// <summary> + /// 鐢熶骇鍙戞枡鍗� + /// </summary> + [Description("鐢熶骇鍙戞枡鍗�")] + Issue = 205, + + /// <summary> + /// 閲囪喘閫�璐у崟 + /// </summary> + [Description("閲囪喘閫�璐у崟")] + ProcureReturn = 210, + + /// <summary> + /// 璋冩嫧鍑哄簱鍗� + /// </summary> + [Description("璋冩嫧鍑哄簱鍗�")] + Allocate = 215, + + /// <summary> + /// 閿�鍞嚭搴撳崟 + /// </summary> + [Description("閿�鍞嚭搴撳崟")] + SaleOut = 220, + + /// <summary> + /// 绌虹洏鍑哄簱鍗� + /// </summary> + [Description("绌虹洏鍑哄簱鍗�")] + EmptyDisk = 225, + + /// <summary> + /// 璐ㄦ鍑哄簱鍗� + /// </summary> + [Description("璐ㄦ鍑哄簱鍗�")] + Quality = 230, + + /// <summary> + /// 鍏朵粬鍑哄簱鍗� + /// </summary> + [Description("鍏朵粬鍑哄簱鍗�")] + Other = 235 + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/PurchaseOrderEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/PurchaseOrderEnum.cs" new file mode 100644 index 0000000..d46b378 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/PurchaseOrderEnum.cs" @@ -0,0 +1,60 @@ +锘縰sing System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Common.OrderEnum +{ + public enum PurchaseOrderStatusEnum + { + /// <summary> + /// 鏈敹璐� + /// </summary> + [Description("鏈敹璐�")] + NotReceived = 0, + + /// <summary> + /// 鏀惰揣涓� + /// </summary> + [Description("鏀惰揣涓�")] + Receiving = 1, + + /// <summary> + /// 鏀惰揣瀹屾垚 + /// </summary> + [Description("鏀惰揣瀹屾垚")] + Received = 2 + } + + public enum PurchaseOrderDetailStatusEnum + { + /// <summary> + /// 鏈敹璐� + /// </summary> + [Description("鏈敹璐�")] + NotReceived = 0, + + /// <summary> + /// 鏀惰揣瀹屾垚 + /// </summary> + [Description("鏀惰揣瀹屾垚")] + Received = 2 + } + + public enum PurchaseOrderTypeEnum + { + /// <summary> + /// 鏍囧噯鍏ュ簱 + /// </summary> + [Description("鏍囧噯鍏ュ簱")] + S = 1, + + /// <summary> + /// 瀵勫敭琛ョ粰鍏ュ簱 + /// </summary> + [Description("瀵勫敭琛ョ粰鍏ュ簱")] + V = 2 + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/ReceiveOrderEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/ReceiveOrderEnum.cs" new file mode 100644 index 0000000..3ac452b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/ReceiveOrderEnum.cs" @@ -0,0 +1,51 @@ +锘縰sing System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Common.OrderEnum +{ + public enum ReceiveOrderTypeEnum + { + /// <summary> + /// 閲囪喘鎺ユ敹 + /// </summary> + [Description("閲囪喘鎺ユ敹")] + PO = 1, + + /// <summary> + /// 鏃犻噰璐帴鏀� + /// </summary> + [Description("鏃犻噰璐帴鏀�")] + NPO = 2, + + /// <summary> + /// 瀹緵鏂欐帴鏀� + /// </summary> + [Description("瀹緵鏂欐帴鏀�")] + CustomerSupply = 3 + } + + public enum ReceiveOrderStatusEnum + { + /// <summary> + /// 鏈紑濮� + /// </summary> + [Description("鏈紑濮�")] + NotStarted, + + /// <summary> + /// 鏀惰揣涓� + /// </summary> + [Description("鏀惰揣涓�")] + Receiving, + + /// <summary> + /// 鏀惰揣瀹屾垚 + /// </summary> + [Description("鏀惰揣瀹屾垚")] + Completed + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/SynchronizationFlagEmun.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/SynchronizationFlagEmun.cs" deleted file mode 100644 index 8ee4907..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/OrderEnum/SynchronizationFlagEmun.cs" +++ /dev/null @@ -1,33 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.ComponentModel; -using System.Linq; -using System.Text; -using System.Threading.Tasks; - -namespace WIDESEA_Common.OrderEnum -{ - /// <summary> - /// 鍚屾鏍囧織 0:鏈悓姝� 1锛氬悓姝ユ垚鍔� 2锛氬悓姝ュけ璐� - /// </summary> - public enum SynchronizationFlagEmun - { - /// <summary> - /// 瀹屾垚 - /// </summary> - [Description("鏈悓姝�")] - 鏈悓姝� = 0, - - /// <summary> - /// 瀹屾垚 - /// </summary> - [Description("鍚屾鎴愬姛")] - 鍚屾鎴愬姛 = 1, - - /// <summary> - /// 瀹屾垚 - /// </summary> - [Description("鍚屾澶辫触")] - 鍚屾澶辫触 = 2 - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/StockEnum/StockChangeTypeEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/StockEnum/StockChangeTypeEnum.cs" index ec29ec8..30fbfca 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/StockEnum/StockChangeTypeEnum.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Common/StockEnum/StockChangeTypeEnum.cs" @@ -31,17 +31,5 @@ /// </summary> [Description("绉诲簱")] Relocation, - - /// <summary> - /// 鍏ュ簱閿佸畾 - /// </summary> - [Description("閿佸畾")] - Lock, - - /// <summary> - /// 搴撳瓨閿佸畾 - /// </summary> - [Description("搴撳瓨閿佸畾")] - StockLock, } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/AOP/SqlSugarAop.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/AOP/SqlSugarAop.cs" index 2732123..aa8cc06 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/AOP/SqlSugarAop.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/AOP/SqlSugarAop.cs" @@ -45,7 +45,7 @@ } } - SequenceAttirbute? sequenceAttirbute = propertyInfo.GetCustomAttribute<SequenceAttirbute>(); + SequenceAttribute? sequenceAttirbute = propertyInfo.GetCustomAttribute<SequenceAttribute>(); if (sequenceAttirbute != null) { if (propertyInfo.GetValue(entityInfo.EntityValue)?.ObjToInt() <= 0) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/App.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/App.cs" index 2c5653e..a6b0317 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/App.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/App.cs" @@ -1,4 +1,5 @@ -锘縰sing Microsoft.AspNetCore.Hosting; +锘縰sing HslCommunication.WebSocket; +using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; @@ -21,6 +22,8 @@ static App() { EffectiveTypes = Assemblies.SelectMany(GetTypes); + //SocketServer = new WebSocketServer(); + //SocketServer.ServerStart(9295); } private static bool _isRun; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Attributes/SequenceAttirbute.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Attributes/SequenceAttirbute.cs" index d00354d..bee2047 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Attributes/SequenceAttirbute.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Attributes/SequenceAttirbute.cs" @@ -7,7 +7,7 @@ namespace WIDESEA_Core.Attributes { [AttributeUsage(AttributeTargets.Property)] - public class SequenceAttirbute : Attribute + public class SequenceAttribute : Attribute { public string SequenceName { get; set; } @@ -21,7 +21,7 @@ public bool IsCycle { get; set; } = true; - public SequenceAttirbute(string sequenceName, int seqMaxValue) + public SequenceAttribute(string sequenceName, int seqMaxValue) { SequenceName = sequenceName; SeqMaxValue = seqMaxValue; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseController/ApiBaseController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseController/ApiBaseController.cs" index 4ecf1f0..c038bf7 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseController/ApiBaseController.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseController/ApiBaseController.cs" @@ -8,6 +8,7 @@ using System.Reflection; using System.Text; using System.Threading.Tasks; +using WIDESEA_Core.Attributes; using WIDESEA_Core.BaseServices; namespace WIDESEA_Core.BaseController @@ -40,13 +41,13 @@ return Json(InvokeService("AddData", new object[] { options })); } - [HttpPost, Route("Add")] + [HttpPost, Route("Add"), MethodParamsValidate] public virtual ActionResult Add([FromBody] SaveModel options) { return Json(InvokeService("AddData", new object[] { options })); } - [HttpPost, Route("Update")] + [HttpPost, Route("Update"), MethodParamsValidate] public virtual ActionResult Update([FromBody] SaveModel options) { return Json(InvokeService("UpdateData", new object[] { options })); diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseModels/PageDataOptions.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseModels/PageDataOptions.cs" index 7a7b531..1fff57b 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseModels/PageDataOptions.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseModels/PageDataOptions.cs" @@ -31,6 +31,8 @@ /// </summary> public List<SearchParameters> Filter { get; set; } + + public string ValidatePageOptions(PropertyInfo[] entityProperties) { string where = string.Empty; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/IRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/IRepository.cs" index 35ded01..c22ec14 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/IRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/IRepository.cs" @@ -51,6 +51,8 @@ /// <returns>褰卞搷琛屾暟</returns> int AddData(TEntity entity); + bool AddData<TChild>(TEntity entity, Expression<Func<TEntity, List<TChild>>> expression) where TChild : class, new(); + Task<int> AddDataAsync(TEntity entity); /// <summary> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/RepositoryBase.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/RepositoryBase.cs" index ed69c09..dc269d7 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/RepositoryBase.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseRepository/RepositoryBase.cs" @@ -36,38 +36,38 @@ ISqlSugarClient db = _dbBase; //澶氱鎴� - var mta = typeof(TEntity).GetCustomAttribute<MultiTenantAttribute>(); - if (mta is { TenantType: TenantTypeEnum.Db }) - { - //鑾峰彇绉熸埛淇℃伅 绉熸埛淇℃伅鍙互鎻愬墠缂撳瓨涓嬫潵 - if (App.User is { TenantId: > 0 }) - { - dynamic tenant = db.Queryable(MainDb.TenantTableName, "x").Where(MainDb.TenantId, "=", App.User.TenantId).First(); - if (tenant != null) - { - var iTenant = db.AsTenant(); - if (!iTenant.IsAnyConnection(tenant.TenantId)) - { - string conStr = tenant.ConnectionString; - ConnectionConfig connectionConfig = new ConnectionConfig() - { - ConfigId = tenant.TenantId, - ConnectionString = conStr.DecryptDES(AppSecret.DB), - DbType = (SqlSugar.DbType)tenant.DbType, - IsAutoCloseConnection = true, - AopEvents = new AopEvents() - { - DataExecuting = SqlSugarAop.DataExecuting, + //var mta = typeof(TEntity).GetCustomAttribute<MultiTenantAttribute>(); + //if (mta is { TenantType: TenantTypeEnum.Db }) + //{ + // //鑾峰彇绉熸埛淇℃伅 绉熸埛淇℃伅鍙互鎻愬墠缂撳瓨涓嬫潵 + // if (App.User is { TenantId: > 0 }) + // { + // dynamic tenant = db.Queryable(MainDb.TenantTableName, "x").Where(MainDb.TenantId, "=", App.User.TenantId).First(); + // if (tenant != null) + // { + // var iTenant = db.AsTenant(); + // if (!iTenant.IsAnyConnection(tenant.TenantId)) + // { + // string conStr = tenant.ConnectionString; + // ConnectionConfig connectionConfig = new ConnectionConfig() + // { + // ConfigId = tenant.TenantId, + // ConnectionString = conStr.DecryptDES(AppSecret.DB), + // DbType = (SqlSugar.DbType)tenant.DbType, + // IsAutoCloseConnection = true, + // AopEvents = new AopEvents() + // { + // DataExecuting = SqlSugarAop.DataExecuting, - } - }; - iTenant.AddConnection(connectionConfig); - } + // } + // }; + // iTenant.AddConnection(connectionConfig); + // } - return iTenant.GetConnection(tenant.TenantId); - } - } - } + // return iTenant.GetConnection(tenant.TenantId); + // } + // } + //} return db; } @@ -124,6 +124,11 @@ return insert.ExecuteReturnIdentity(); } + public virtual bool AddData<TChild>(TEntity entity, Expression<Func<TEntity, List<TChild>>> expression) where TChild : class, new() + { + return _db.InsertNav(entity).Include(expression).ExecuteCommand(); + } + /// <summary> /// 娣诲姞澶氭潯鏁版嵁 /// </summary> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseServices/ServiceBase.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseServices/ServiceBase.cs" index b0f77a5..d03fb56 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseServices/ServiceBase.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/BaseServices/ServiceBase.cs" @@ -1,21 +1,25 @@ -锘縰sing Magicodes.ExporterAndImporter.Core; +锘縰sing AutoMapper.Execution; +using Magicodes.ExporterAndImporter.Core; using Magicodes.ExporterAndImporter.Core.Models; using Magicodes.ExporterAndImporter.Excel; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc.RazorPages; using Microsoft.Extensions.Options; using Newtonsoft.Json; -using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; using SqlSugar; using System.Drawing.Drawing2D; using System.Dynamic; using System.Linq.Expressions; using System.Reflection; +using System.Reflection.Metadata; using WIDESEA_Core.BaseRepository; +using WIDESEA_Core.Const; +using WIDESEA_Core.DB.Models; using WIDESEA_Core.Enums; using WIDESEA_Core.Helper; +using WIDESEA_Core.HostedService; using WIDESEA_Core.Utilities; -using static OfficeOpenXml.ExcelErrorValue; +using ICacheService = WIDESEA_Core.Caches.ICacheService; namespace WIDESEA_Core.BaseServices { @@ -50,15 +54,187 @@ public virtual PageGridData<TEntity> GetPageData(PageDataOptions options) { string wheres = options.ValidatePageOptions(TProperties); + + + //Expression<Func<TEntity, bool>> test = ValidatePageOptions(options, _propertyInfo); + //鑾峰彇鎺掑簭瀛楁 Dictionary<string, OrderByType> orderbyDic = options.GetPageDataSort(TProperties); - PageGridData<TEntity> pageGridData = new PageGridData<TEntity>(); - pageGridData = BaseDal.QueryPage(wheres, options.Page, options.Rows, orderbyDic); + string dataWheres = GetDataRole(typeof(TEntity)); + if (!string.IsNullOrEmpty(wheres)) + { + dataWheres += " and "; + } + pageGridData = BaseDal.QueryPage(dataWheres + wheres, options.Page, options.Rows, orderbyDic); + //int count = 0; + //ISugarQueryable<TEntity> sugarQueryable = BaseDal.Db.Queryable<TEntity>().Where(dataWheres); + //ValidatePageOptions(options, _propertyInfo, ref sugarQueryable); + //List<TEntity> rows = sugarQueryable.ToPageList(options.Page, options.Rows, ref count); + //PageGridData<TEntity> pageGridData = new PageGridData<TEntity>() + //{ + // Rows = rows, + // Total = count, + //}; return pageGridData; } + void ValidatePageOptions(PageDataOptions options, PropertyInfo[] entityProperties, ref ISugarQueryable<TEntity> sugarQueryable) + { + string where = string.Empty; + List<SearchParameters> searchParametersList = new List<SearchParameters>(); + if (options.Filter != null && options.Filter.Count > 0) + { + searchParametersList.AddRange(options.Filter); + } + else if (!string.IsNullOrEmpty(options.Wheres)) + { + try + { + searchParametersList = options.Wheres.DeserializeObject<List<SearchParameters>>(); + options.Filter = searchParametersList; + } + catch { } + } + for (int i = 0; i < searchParametersList.Count; i++) + { + if (string.IsNullOrEmpty(searchParametersList[i].Value)) + { + continue; + } + + PropertyInfo? property = entityProperties.Where(c => c.Name.ToUpper() == searchParametersList[i].Name.ToUpper()).FirstOrDefault(); + + if (property == null) continue; + + List<(bool, string, object)> results = property.ValidationValueForDbType(searchParametersList[i].Value.Split(',')).ToList(); + if (results == null || results.Count() == 0) + { + continue; + } + for (int j = 0; j < results.Count(); j++) + { + LinqExpressionType expressionType = searchParametersList[i].DisplayType.GetLinqCondition(); + Expression<Func<TEntity, bool>> expression = GetWhereExpression(property.Name, results[j].Item3, null, expressionType); + sugarQueryable = sugarQueryable.Where(expression); + } + } + } + + private Expression<Func<TEntity, bool>> GetWhereExpression(string propertyName, object propertyValue, ParameterExpression parameter, LinqExpressionType expressionType) + { + Type proType = typeof(TEntity).GetProperty(propertyName).PropertyType; + ConstantExpression constant = proType.ToString() == "System.String" + ? Expression.Constant(propertyValue) : Expression.Constant(propertyValue.ToString().ChangeType(proType)); + + // DateTime鍙�夋嫨浜嗘棩鏈熺殑鏃跺�欒嚜鍔ㄥ湪缁撴潫鏃ユ湡鍔犱竴澶╋紝淇DateTime绫诲瀷浣跨敤鏃ユ湡鍖洪棿鏌ヨ鏃犳硶鏌ヨ鍒扮粨鏉熸棩鏈熺殑闂 + if ((proType == typeof(DateTime) || proType == typeof(DateTime?)) && expressionType == LinqExpressionType.LessThanOrEqual && propertyValue.ToString().Length == 10) + { + constant = Expression.Constant(Convert.ToDateTime(propertyValue.ToString()).AddDays(1)); + } + parameter = parameter ?? Expression.Parameter(typeof(TEntity), "x"); + //鍒涘缓鑺傜偣鐨勫睘鎬=>p.name 灞炴�ame + MemberExpression memberProperty = Expression.PropertyOrField(parameter, propertyName); + UnaryExpression member = Expression.Convert(memberProperty, constant.Type); + Expression<Func<TEntity, bool>> expression = p => false; + switch (expressionType) + { + //p=>p.propertyName == propertyValue + case LinqExpressionType.Equal: + expression = Expression.Lambda<Func<TEntity, bool>>(Expression.Equal(member, constant), parameter); + break; + //p=>p.propertyName != propertyValue + case LinqExpressionType.NotEqual: + expression = Expression.Lambda<Func<TEntity, bool>>(Expression.NotEqual(member, constant), parameter); + break; + // p => p.propertyName > propertyValue + case LinqExpressionType.GreaterThan: + expression = Expression.Lambda<Func<TEntity, bool>>(Expression.GreaterThan(member, constant), parameter); + break; + // p => p.propertyName < propertyValue + case LinqExpressionType.LessThan: + expression = Expression.Lambda<Func<TEntity, bool>>(Expression.LessThan(member, constant), parameter); + break; + // p => p.propertyName >= propertyValue + case LinqExpressionType.ThanOrEqual: + expression = Expression.Lambda<Func<TEntity, bool>>(Expression.GreaterThanOrEqual(member, constant), parameter); + break; + // p => p.propertyName <= propertyValue + case LinqExpressionType.LessThanOrEqual: + expression = Expression.Lambda<Func<TEntity, bool>>(Expression.LessThanOrEqual(member, constant), parameter); + break; + // p => p.propertyName.Contains(propertyValue) + // p => !p.propertyName.Contains(propertyValue) + case LinqExpressionType.Contains: + case LinqExpressionType.NotContains: + MethodInfo method = typeof(string).GetMethod("Contains", new[] { typeof(string) }); + constant = Expression.Constant(propertyValue, typeof(string)); + if (expressionType == LinqExpressionType.Contains) + { + expression = Expression.Lambda<Func<TEntity, bool>>(Expression.Call(member, method, constant), parameter); + } + else + { + expression = Expression.Lambda<Func<TEntity, bool>>(Expression.Not(Expression.Call(member, method, constant)), parameter); + } + break; + default: + // + expression = p => false; + break; + } + return expression; + } + + private string GetDataRole(Type type) + { + try + { + UserRole? userRole = PermissionDataHostService.UserRoles.FirstOrDefault(x => x.UserId == App.User.UserId); + if (userRole == null) + throw new Exception($"鏃犳潈闄�"); + + if (type.IsAssignableFrom(typeof(BaseWarehouseEntity)) || type.GetProperty(nameof(BaseWarehouseEntity.WarehouseId)) != null) + { + if (userRole.WarehouseIds.Count > 0) + { + return $"{nameof(BaseWarehouseEntity.WarehouseId)} in ({userRole.WarehouseIds.Serialize().Replace("[", "").Replace("]", "")})"; + } + + else + return $"1 != 1"; + } + else + { + return ""; + } + + //UserRole? userRole = PermissionDataHostService.UserRoles.FirstOrDefault(x => x.UserId == App.User.UserId); + //if (userRole == null) + // throw new Exception($"鏃犳潈闄�"); + + //if (userRole.AuthorityScope == (int)AuthorityScopeEnum.CurrentRole) + //{ + // List<int> userId = PermissionDataHostService.UserRoles.Where(x => x.RoleId == userRole.RoleId).Select(x => x.UserId).ToList(); + // return $"creater in ({userId.Serialize()})"; + //} + //else if (userRole.AuthorityScope == (int)AuthorityScopeEnum.OnlySelf) + //{ + // return $"creater = '{userRole.UserName}'"; + //} + //else if (userRole.AuthorityScope == (int)AuthorityScopeEnum.None) + //{ + // return $"1 != 1"; + //} + //return ""; + } + catch (Exception ex) + { + throw new Exception($"鏃犳潈闄愶紝{ex.Message}"); + } + } + public virtual object GetDetailPage(PageDataOptions pageData) { Type t = typeof(TEntity); diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisCodeEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisCodeEnum.cs" index fb8bc35..8067ce6 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisCodeEnum.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisCodeEnum.cs" @@ -22,6 +22,8 @@ /// 澶栫鐮� /// </summary> [Description("澶栫鐮�")] - OutterCode + OutterCode, + + MatSerNumAnalysis } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisFormatTypeEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisFormatTypeEnum.cs" index 1499225..a994796 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisFormatTypeEnum.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/AnalysisFormatTypeEnum.cs" @@ -21,7 +21,7 @@ /// 鐢熶骇鏃ユ湡 /// </summary> [Description("鐢熶骇鏃ユ湡")] - MTPT, + MTPD, /// <summary> /// 鎵规鍙� /// </summary> @@ -37,6 +37,9 @@ /// </summary> [Description("璁㈠崟鍙�")] ODN, + + [Description("鏈夋晥鏈�")] + ED, /// <summary> /// 鍘熷鏁版嵁 /// </summary> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/RuleCodeEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/RuleCodeEnum.cs" index d3c7857..f90f331 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/RuleCodeEnum.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/CodeConfigEnum/RuleCodeEnum.cs" @@ -22,6 +22,18 @@ /// 鍑哄簱鍗曞彿缂栫爜瑙勫垯缂栧彿 /// </summary> [Description("鍑哄簱鍗曞彿缂栫爜瑙勫垯缂栧彿")] - OutboundOrderRule + OutboundOrderRule, + + /// <summary> + /// 鏀惰揣鍗曞彿缂栫爜瑙勫垯缂栧彿 + /// </summary> + [Description("鏀惰揣鍗曞彿缂栫爜瑙勫垯缂栧彿")] + ReceiveOrderRule, + + /// <summary> + /// 璐ㄦ鍗曞彿缂栫爜瑙勫垯 + /// </summary> + [Description("璐ㄦ鍗曞彿缂栫爜瑙勫垯")] + CheckOrderRule } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/MainDb.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/MainDb.cs" index 457e8ce..4319cb3 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/MainDb.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/MainDb.cs" @@ -21,9 +21,9 @@ public const string AssemblyName = "WIDESEA_Model.dll"; public static DbType DbType = DbType.SqlServer; public const string UserTableName = "Sys_User"; - public const string RoleId = "Role_Id"; + public const string RoleId = "RoleId"; public const string UserName = "UserName"; - public const string UserId = "User_Id"; + public const string UserId = "UserId"; public const string CodeRuleConfig = "Dt_CodeRuleConfig"; public const string RuleCode = "RuleCode"; public const string AnalysisRuleConfig = "Dt_AnalysisRuleConfig"; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/Models/BaseWarehouseEntity.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/Models/BaseWarehouseEntity.cs" new file mode 100644 index 0000000..0839833 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/Models/BaseWarehouseEntity.cs" @@ -0,0 +1,15 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Core.DB.Models +{ + public interface BaseWarehouseEntity + { + [SugarColumn(IsNullable = false)] + int WarehouseId { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/AuthorityScopeEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/AuthorityScopeEnum.cs" new file mode 100644 index 0000000..1950004 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/AuthorityScopeEnum.cs" @@ -0,0 +1,41 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Core.Enums +{ + public enum AuthorityScopeEnum + { + /// <summary> + /// 鏃� + /// </summary> + None = -1, + + /// <summary> + /// 浠呰嚜宸� + /// </summary> + OnlySelf = 1, + + /// <summary> + /// 褰撳墠瑙掕壊 + /// </summary> + CurrentRole = 2, + + /// <summary> + /// 褰撳墠瑙掕壊鍙婁互涓� + /// </summary> + CurrentRoleAndDown = 3, + + /// <summary> + /// 鑷畾涔� + /// </summary> + Custom = 4, + + /// <summary> + /// 鎵�鏈� + /// </summary> + All = 10 + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/OperateTypeEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/OperateTypeEnum.cs" index b7402b1..9c09173 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/OperateTypeEnum.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Enums/OperateTypeEnum.cs" @@ -14,5 +14,6 @@ 鑷姩鎭㈠ = 4, 浜哄伐瀹屾垚 = 5, 鑷姩瀹屾垚 = 6, + 鍏抽棴 = 7 } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/AutofacModuleRegister.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/AutofacModuleRegister.cs" index efdb638..fe9c711 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/AutofacModuleRegister.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/AutofacModuleRegister.cs" @@ -1,5 +1,6 @@ 锘縰sing Autofac; using Autofac.Extras.DynamicProxy; +using HslCommunication.WebSocket; using Microsoft.Extensions.DependencyModel; using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; using System; @@ -25,8 +26,11 @@ var cacheType = new List<Type>(); builder.RegisterType<LogAOP>(); - cacheType.Add(typeof(LogAOP)); - + if (AppSettings.Get("LogAopEnable").ObjToBool()) + { + cacheType.Add(typeof(LogAOP)); + } + builder.RegisterGeneric(typeof(RepositoryBase<>)).As(typeof(IRepository<>)).InstancePerDependency();//娉ㄥ唽浠撳偍 builder.RegisterGeneric(typeof(ServiceBase<,>)).As(typeof(IService<>)).InstancePerDependency();//娉ㄥ唽鏈嶅姟 @@ -68,6 +72,7 @@ .AsImplementedInterfaces() .InstancePerLifetimeScope() .PropertiesAutowired(); + } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/SqlsugarSetup.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/SqlsugarSetup.cs" index 3fa4e19..ebc105e 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/SqlsugarSetup.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/SqlsugarSetup.cs" @@ -51,8 +51,8 @@ Parallel.For(0, 1, e => { MiniProfiler.Current.CustomTiming("SQL锛�", GetParas(p) + "銆怱QL璇彞銆戯細" + sql); - //Console.Out.WriteLine(sql); - //Console.Out.WriteLine(); + Console.Out.WriteLine(sql); + Console.Out.WriteLine(); }); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/WebSocketSetup.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/WebSocketSetup.cs" new file mode 100644 index 0000000..31e888f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Extensions/WebSocketSetup.cs" @@ -0,0 +1,25 @@ +锘縰sing HslCommunication.WebSocket; +using Microsoft.Extensions.DependencyInjection; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_Core.Extensions +{ + public static class WebSocketSetup + { + public static void AddWebSocketSetup(this IServiceCollection services) + { + if (services == null) throw new ArgumentNullException(nameof(services)); + + services.AddSingleton(x => + { + WebSocketServer socketServer = new WebSocketServer(); + socketServer.ServerStart(9295); + return socketServer; + }); + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs" index 4bfa6e3..3150e8c 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs" @@ -1,4 +1,5 @@ 锘縰sing OfficeOpenXml.FormulaParsing.Excel.Functions.RefAndLookup; +using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; using SqlSugar; using System; using System.Collections.Generic; @@ -11,6 +12,7 @@ using WIDESEA_Core.DB; using WIDESEA_Core.Enums; using WIDESEA_Core.Seed; +using WIDESEA_Core.Utilities; namespace WIDESEA_Core.Helper { @@ -61,14 +63,37 @@ AnalysisItemRuleAttribute? analysisItemRule = propertyInfo.GetCustomAttribute<AnalysisItemRuleAttribute>(); if (analysisItemRule != null) { - int index = items.IndexOf($"[{analysisItemRule.AnalysisFormaType}]"); - if (index != -1) - propertyInfo.SetValue(result, codes[index]); + if (analysisItemRule.AnalysisFormaType == AnalysisFormatTypeEnum.BD) + { + propertyInfo.SetValue(result, code.ChangeType(propertyInfo.PropertyType)); + } + else + { + int index = items.IndexOf($"[{analysisItemRule.AnalysisFormaType}]"); + if (index != -1) + { + propertyInfo.SetValue(result, codes[index]); + } + else + { + string? codeItem = items.FirstOrDefault(x => x.Contains($"[{analysisItemRule.AnalysisFormaType}]")); + if (!string.IsNullOrEmpty(codeItem)) + { + index = items.IndexOf(codeItem); + if (index != -1) + { + string value = codes[index]; + string replaceStr = codeItem.Replace($"[{analysisItemRule.AnalysisFormaType}]", ""); + + propertyInfo.SetValue(result, value.Replace(replaceStr, "").ChangeType(propertyInfo.PropertyType)); + } + } + } + } } } } } - } } } @@ -76,6 +101,13 @@ { } + + (bool, string, object?) validateResult = ModelValidate.ValidateModelData(result, type); + if (!validateResult.Item1) + { + throw new Exception($"瑙f瀽閿欒,{validateResult.Item2}"); + } + return result; } @@ -90,7 +122,7 @@ { Type type = typeof(T); List<T> list = new List<T>(); - + try { AnalysisRuleAttribute? analysisRule = type.GetCustomAttribute<AnalysisRuleAttribute>(); @@ -126,7 +158,7 @@ AnalysisItemRuleAttribute? analysisItemRule = propertyInfo.GetCustomAttribute<AnalysisItemRuleAttribute>(); if (analysisItemRule != null) { - if(analysisItemRule.AnalysisFormaType == AnalysisFormatTypeEnum.BD) + if (analysisItemRule.AnalysisFormaType == AnalysisFormatTypeEnum.BD) { propertyInfo.SetValue(result, code.ChangeType(propertyInfo.PropertyType)); } @@ -134,9 +166,25 @@ { int index = items.IndexOf($"[{analysisItemRule.AnalysisFormaType}]"); if (index != -1) - propertyInfo.SetValue(result, codes[index].ChangeType(propertyInfo.PropertyType)); + { + propertyInfo.SetValue(result, codes[index]); + } + else + { + string? codeItem = items.FirstOrDefault(x => x.Contains($"[{analysisItemRule.AnalysisFormaType}]")); + if (!string.IsNullOrEmpty(codeItem)) + { + index = items.IndexOf(codeItem); + if (index != -1) + { + string value = codes[index]; + string replaceStr = codeItem.Replace($"[{analysisItemRule.AnalysisFormaType}]", ""); + + propertyInfo.SetValue(result, value.Replace(replaceStr, "").ChangeType(propertyInfo.PropertyType)); + } + } + } } - } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/ObjectExtension.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/ObjectExtension.cs" index 5bbc2d2..b051c14 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/ObjectExtension.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/ObjectExtension.cs" @@ -43,8 +43,15 @@ { continue; } - if (value != null && sugarColumn != null && !sugarColumn.IsNullable) + //if (value != null && sugarColumn != null && !sugarColumn.IsNullable) + try + { property.SetValue(model, value.ChangeType(property.PropertyType)); + } + catch + { + + } } return model; } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/PermissionDataHostService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/PermissionDataHostService.cs" new file mode 100644 index 0000000..f583a3a --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/PermissionDataHostService.cs" @@ -0,0 +1,155 @@ +锘縰sing HslCommunication.WebSocket; +using Microsoft.Extensions.Hosting; +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Dynamic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.Helper; +using WIDESEA_Core.Seed; +using ICacheService = WIDESEA_Core.Caches.ICacheService; + +namespace WIDESEA_Core.HostedService +{ + public class PermissionDataHostService : IHostedService + { + private readonly DBContext _dbContext; + private readonly ICacheService _cacheService; + private readonly WebSocketServer _server; + + public static List<UserRole> UserRoles; + + public PermissionDataHostService(DBContext dbContext, ICacheService cacheService, WebSocketServer server) + { + _dbContext = dbContext; + _cacheService = cacheService; + _server = server; + } + + public Task StartAsync(CancellationToken cancellationToken) + { + List<ExpandoObject> roles = _dbContext.Db.Queryable("Sys_Role", "x").Select(RoleSelectModes).ToList(); + List<dynamic> roleDynamics = new List<dynamic>(); + foreach (var item in roles) + { + roleDynamics.Add(item); + } + + List<dynamic> roleDataDynamics = new List<dynamic>(); + List<ExpandoObject> roleDatas = _dbContext.Db.Queryable("Sys_RoleDataPermission", "x").Select(RoleDataSelectModes).ToList(); + foreach (var item in roleDatas) + { + roleDataDynamics.Add(item); + } + + List<ExpandoObject> users = _dbContext.Db.Queryable("Sys_User", "x").Select(UserSelectModes).ToList(); + + List<UserRole> userRoles = new List<UserRole>(); + foreach (var item in users) + { + dynamic user = item; + dynamic? role = roleDynamics.FirstOrDefault(x => x.RoleId == user.RoleId); + List<object> warehouseIds = roleDataDynamics.Where(x => x.RoleId == user.RoleId).Select(x => x.WarehouseId).ToList(); + List<int> ids = new List<int>(); + for (int i = 0; i < warehouseIds.Count; i++) + { + ids.Add(Convert.ToInt32(warehouseIds[i])); + } + if (role != null) + { + userRoles.Add(new UserRole + { + AuthorityScope = role.AuthorityScope, + RoleId = role.RoleId, + RoleName = role.RoleName, + ParentId = role.ParentId, + UserId = user.UserId, + UserName = user.UserName, + WarehouseIds = ids + }); + } + } + + UserRoles = userRoles; + _cacheService.AddOrUpdate("UserRoles", userRoles.Serialize()); + + return Task.CompletedTask; + } + + public Task StopAsync(CancellationToken cancellationToken) + { + throw new NotImplementedException(); + } + + List<SelectModel> RoleSelectModes = new List<SelectModel>() + { + new SelectModel() + { + FieldName = "RoleId", + }, + new SelectModel() + { + FieldName = "ParentId", + }, + new SelectModel() + { + FieldName = "RoleName", + }, + new SelectModel() + { + FieldName = "AuthorityScope", + } + }; + + List<SelectModel> UserSelectModes = new List<SelectModel>() + { + new SelectModel() + { + FieldName = "UserId", + }, + new SelectModel() + { + FieldName = "UserName", + }, + new SelectModel() + { + FieldName = "RoleId", + }, + new SelectModel() + { + FieldName = "RoleName", + } + }; + + List<SelectModel> RoleDataSelectModes = new List<SelectModel>() + { + new SelectModel() + { + FieldName = "RoleId", + }, + new SelectModel() + { + FieldName = "WarehouseId", + } + }; + } + + public class UserRole + { + public int UserId { get; set; } + + public int RoleId { get; set; } + + public string RoleName { get; set; } + + public string UserName { get; set; } + + public int ParentId { get; set; } + + public int AuthorityScope { get; set; } + + public List<int> WarehouseIds { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/SeedDataHostedService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/SeedDataHostedService.cs" index 2b7ddd3..8c9863e 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/SeedDataHostedService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HostedService/SeedDataHostedService.cs" @@ -1,4 +1,5 @@ -锘縰sing Microsoft.AspNetCore.Hosting; +锘縰sing HslCommunication.WebSocket; +using Microsoft.AspNetCore.Hosting; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Logging; @@ -17,21 +18,11 @@ private readonly DBContext _dbContext; private readonly ILogger<SeedDataHostedService> _logger; private readonly string _webRootPath; - private readonly IServiceProvider _serviceProvider; - public SeedDataHostedService( - IServiceProvider serviceProvider, - IWebHostEnvironment webHostEnvironment, - ILogger<SeedDataHostedService> logger) + public SeedDataHostedService(IServiceProvider serviceProvider, IWebHostEnvironment webHostEnvironment, ILogger<SeedDataHostedService> logger, DBContext dbContext) { - _serviceProvider = serviceProvider; _logger = logger; _webRootPath = webHostEnvironment.WebRootPath; - - using var scope = _serviceProvider.CreateScope(); - - var dbContext = scope.ServiceProvider.GetService<DBContext>(); - //dbContext.Db.Aop.DataExecuting = SqlSugarAop.DataExecuting; _dbContext = dbContext; } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HttpContextUser/AspNetUser.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HttpContextUser/AspNetUser.cs" index 1bf7f75..15b0ead 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HttpContextUser/AspNetUser.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/HttpContextUser/AspNetUser.cs" @@ -9,12 +9,7 @@ using System.Security.Claims; using System.Text; using System.Threading.Tasks; -using WIDESEA_Core.Authorization; -using WIDESEA_Core.Caches; -using WIDESEA_Core.Const; -using WIDESEA_Core.DB; using WIDESEA_Core.Helper; -using WIDESEA_Core.Seed; using ICacheService = WIDESEA_Core.Caches.ICacheService; namespace WIDESEA_Core.HttpContextUser @@ -51,9 +46,39 @@ public string GetToken() { - string token = _cacheService.Get(UserId.ToString()); + string token = _accessor.HttpContext?.Request?.Headers["Authorization"].ObjToString().Replace("Bearer ", "") ?? ""; + if (!token.IsNullOrEmpty()) + { + return token; + } + //if (_accessor.HttpContext?.IsSuccessSwagger() == true) + //{ + // token = _accessor.HttpContext.GetSuccessSwaggerJwt(); + // if (token.IsNotEmptyOrNull()) + // { + // //UserInfo userInfo = JwtHelper.SerializeJwt(token); + // //if (userInfo.UserId > 0) + // //{ + // // return token; + // //} + // List<Claim> claims1 = _accessor.HttpContext.User.Claims.ToList(); + // if (_accessor.HttpContext.User.Claims.Any(s => s.Type == JwtRegisteredClaimNames.Jti)) + // { + // return token; + // } + + // var claims = new ClaimsIdentity(GetClaimsIdentity(token)); + // _accessor.HttpContext.User.AddIdentity(claims); + // return token; + // } + //} + token = _cacheService.Get(UserId.ToString()); if (!string.IsNullOrEmpty(token)) { return token; } - return string.Empty; + return token; + + // string token = _cacheService.Get(UserId.ToString()); + //if (!string.IsNullOrEmpty(token)) { return token; } + //return string.Empty; //return _accessor.HttpContext?.Request?.Headers["Authorization"].ObjToString().Replace("Bearer ", "") ?? ""; } @@ -75,9 +100,10 @@ { JwtSecurityToken jwtToken = jwtHandler.ReadJwtToken(token); - return (from item in jwtToken.Claims - where item.Type == ClaimType - select item.Value).ToList(); + List<string> items = (from item in jwtToken.Claims + where item.Type == ClaimType + select item.Value).ToList(); + return items; } return new List<string>() { }; @@ -99,6 +125,20 @@ return ArraySegment<Claim>.Empty; } + public IEnumerable<Claim> GetClaimsIdentity(string token) + { + var jwtHandler = new JwtSecurityTokenHandler(); + // token鏍¢獙 + if (token.IsNotEmptyOrNull() && jwtHandler.CanReadToken(token)) + { + var jwtToken = jwtHandler.ReadJwtToken(token); + + return jwtToken.Claims; + } + + return new List<Claim>(); + } + public List<string> GetClaimValueByType(string ClaimType) { return (from item in GetClaimsIdentity() diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/LogHelper/Logger.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/LogHelper/Logger.cs" index 7ce4580..a8e99dd 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/LogHelper/Logger.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/LogHelper/Logger.cs" @@ -1,5 +1,6 @@ 锘� using Microsoft.AspNetCore.Http; +using Microsoft.Extensions.Logging; using Newtonsoft.Json; using SqlSugar; using System; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/EntityProperties.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/EntityProperties.cs" index c351b8b..d0b698a 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/EntityProperties.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/EntityProperties.cs" @@ -184,7 +184,7 @@ continue; //涓嶅湪缂栬緫涓殑鍒楋紝鏄惁涔熻蹇呭~ - if (!dic.ContainsKey(property.Name.FirstLetterToLower()) /*&& !dic.ContainsKey(property.Name.FirstLetterToUpper())*/) + if (!dic.ContainsKey(property.Name.FirstLetterToLower())) { if (!sugarColumn.IsNullable) { diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ModelValidate.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ModelValidate.cs" index 76e5aaf..b8bb9a9 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ModelValidate.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ModelValidate.cs" @@ -77,35 +77,49 @@ if (propertyAttribute == null) continue; object? value = propertyInfo.GetValue(data, null); + if (value is IList) + { + IList list = (IList)value; + Type? t = list.GetType().GetGenericArguments().FirstOrDefault(); + if (t != null && t.IsClass) + { + foreach (var item in list) + { + (bool, string, object?) result = ValidateModelData(item, t); + if (!result.Item1) return result; + } + } + } + if (propertyAttribute.NotNullAndEmpty) { - if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}涓嶅彲涓簄ull", data); - if (string.IsNullOrEmpty(value.ToString())) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}涓嶅彲涓虹┖瀛楃涓�", data); + if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})涓嶅彲涓簄ull", data); + if (string.IsNullOrEmpty(value.ToString())) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})涓嶅彲涓虹┖瀛楃涓�", data); } if (propertyAttribute.MinValue > int.MinValue) { - if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}涓嶅彲涓簄ull", data); + if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})涓嶅彲涓簄ull", data); if (propertyAttribute.IsContainMinValue) { - if (Convert.ToInt32(value.ToString()) < propertyAttribute.MinValue) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}鐨勫�笺�恵value}銆戜笉鍙皬浜庛�恵propertyAttribute.MinValue}銆�", data); + if (Convert.ToInt32(value.ToString()) < propertyAttribute.MinValue) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})鐨勫�笺�恵value}銆戜笉鍙皬浜庛�恵propertyAttribute.MinValue}銆�", data); } else { - if (Convert.ToInt32(value.ToString()) <= propertyAttribute.MinValue) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}鐨勫�笺�恵value}銆戣澶т簬銆恵propertyAttribute.MinValue}銆�", data); + if (Convert.ToInt32(value.ToString()) <= propertyAttribute.MinValue) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})鐨勫�笺�恵value}銆戣澶т簬銆恵propertyAttribute.MinValue}銆�", data); } } if (propertyAttribute.MaxValue < int.MaxValue) { - if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}涓嶅彲涓簄ull", data); + if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})涓嶅彲涓簄ull", data); if (propertyAttribute.IsContainMaxValue) { - if (Convert.ToInt32(value.ToString()) >= propertyAttribute.MaxValue) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}鐨勫�笺�恵value}銆戜笉鍙ぇ浜庛�恵propertyAttribute.MaxValue}銆�", data); + if (Convert.ToInt32(value.ToString()) >= propertyAttribute.MaxValue) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})鐨勫�笺�恵value}銆戜笉鍙ぇ浜庛�恵propertyAttribute.MaxValue}銆�", data); } else { - if (Convert.ToInt32(value.ToString()) > propertyAttribute.MaxValue) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}鐨勫�笺�恵value}銆戣灏忎簬銆恵propertyAttribute.MaxValue}銆�", data); + if (Convert.ToInt32(value.ToString()) > propertyAttribute.MaxValue) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})鐨勫�笺�恵value}銆戣灏忎簬銆恵propertyAttribute.MaxValue}銆�", data); } } @@ -184,25 +198,25 @@ if (propertyAttribute.Check != null && propertyAttribute.Check.Length > 0) { - if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}涓嶅彲涓簄ull", data); - if (propertyAttribute.Check.FirstOrDefault(x => x.ToString() == value.ToString()) == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}浣跨敤浜咰heck绾︽潫锛屼紶鍏ョ殑鍊间笉鍦▄propertyAttribute.Check.Serialize()}涓�", data); + if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})涓嶅彲涓簄ull", data); + if (propertyAttribute.Check.FirstOrDefault(x => x.ToString() == value.ToString()) == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})浣跨敤浜咰heck绾︽潫锛屼紶鍏ョ殑鍊间笉鍦▄propertyAttribute.Check.Serialize()}涓�", data); } if (!string.IsNullOrEmpty(propertyAttribute.StartWith) && !string.IsNullOrWhiteSpace(propertyAttribute.EndWith)) { - if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}涓嶅彲涓簄ull", data); + if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})涓嶅彲涓簄ull", data); else { - if (value.ToString().StartsWith(propertyAttribute.StartWith.Trim())) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}蹇呴』浠propertyAttribute.StartWith}寮�澶�", data); + if (value.ToString().StartsWith(propertyAttribute.StartWith.Trim())) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})蹇呴』浠propertyAttribute.StartWith}寮�澶�", data); } } if (!string.IsNullOrEmpty(propertyAttribute.EndWith) && !string.IsNullOrWhiteSpace(propertyAttribute.EndWith)) { - if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}涓嶅彲涓簄ull", data); + if (value == null) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})涓嶅彲涓簄ull", data); else { - if (value.ToString().EndsWith(propertyAttribute.EndWith.Trim())) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}蹇呴』浠propertyAttribute.EndWith}缁撳熬", data); + if (value.ToString().EndsWith(propertyAttribute.EndWith.Trim())) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}({propertyInfo.Name})蹇呴』浠propertyAttribute.EndWith}缁撳熬", data); } } @@ -213,8 +227,6 @@ if (value.ToString().Length < propertyAttribute.MinLength) return (false, $"{(string.IsNullOrEmpty(propertyAttribute.Description) ? propertyInfo.Name : propertyAttribute.Description)}鐨勫�煎皬浜庢渶灏忛暱搴︺�恵propertyAttribute.MinLength}銆戯紝鏁版嵁:{value}", data); } - - } } catch (Exception ex) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ParamsValidator.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ParamsValidator.cs" index 9416db9..1be56f5 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ParamsValidator.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/Utilities/ParamsValidator.cs" @@ -21,22 +21,26 @@ foreach (var param in context.ActionDescriptor.Parameters) { ModelValidateAttribute? modelValidate = param.ParameterType.GetCustomAttribute<ModelValidateAttribute>(); - if (modelValidate != null && context.ActionArguments.TryGetValue(param.Name, out object? value)) + if (modelValidate != null && context.ActionArguments.TryGetValue(param.Name, out object? value) && value != null) { - if (value != null) + (bool, string, object?) result = ModelValidate.ValidateModelData(value, param.ParameterType); + if (!result.Item1) { - (bool, string, object?) result = ModelValidate.ValidateModelData(value, param.ParameterType); - if (!result.Item1) + context.Result = new JsonResult(new WebResponseContent() { - context.Result = new JsonResult(new WebResponseContent() - { - Status = false, - Data = result.Item3, - Message = result.Item2 - }); - } + Status = false, + Data = result.Item3, + Message = result.Item2 + }); } } + //else + //{ + // if (param.ParameterType == typeof(SaveModel) && context.ActionArguments.TryGetValue(param.Name, out value) && value != null) + // { + + // } + //} } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/WIDESEA_Core.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/WIDESEA_Core.csproj" index 043be90..39cc725 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/WIDESEA_Core.csproj" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Core/WIDESEA_Core.csproj" @@ -14,6 +14,7 @@ <PackageReference Include="Autofac.Extensions.DependencyInjection" Version="9.0.0" /> <PackageReference Include="Autofac.Extras.DynamicProxy" Version="7.1.0" /> <PackageReference Include="AutoMapper" Version="13.0.1" /> + <PackageReference Include="HslCommunication" Version="12.1.3" /> <PackageReference Include="Magicodes.IE.EPPlus" Version="2.7.5.1" /> <PackageReference Include="Magicodes.IE.Excel" Version="2.7.5.1" /> <PackageReference Include="MailKit" Version="4.7.1.1" /> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Basic/MatSerNumAnalysisModel.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Basic/MatSerNumAnalysisModel.cs" new file mode 100644 index 0000000..bd88b18 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Basic/MatSerNumAnalysisModel.cs" @@ -0,0 +1,56 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.Attributes; +using WIDESEA_Core.CodeConfigEnum; + +namespace WIDESEA_DTO.Basic +{ + [AnalysisRule, ModelValidate] + public class MatSerNumAnalysisModel + { + /// <summary> + /// 鐗╂枡缂栧彿 + /// </summary> + [AnalysisItemRule(AnalysisFormatTypeEnum.MTC), PropertyValidate("鐗╂枡缂栧彿", NotNullAndEmpty = true)] + public string MaterielCode { get; set; } + + /// <summary> + /// 鎵规鍙� + /// </summary> + [AnalysisItemRule(AnalysisFormatTypeEnum.BHN), PropertyValidate("鎵规鍙�", NotNullAndEmpty = true)] + public string LotNo { get; set; } + + /// <summary> + /// 鐢熶骇鏃ユ湡 + /// </summary> + [AnalysisItemRule(AnalysisFormatTypeEnum.MTPD), PropertyValidate("鐢熶骇鏃ユ湡", NotNullAndEmpty = true)] + public string ProductionDate { get; set; } + + /// <summary> + /// 鏈夋晥鏈� + /// </summary> + [AnalysisItemRule(AnalysisFormatTypeEnum.ED), PropertyValidate("鏈夋晥鏈�", NotNullAndEmpty = true)] + public string EffectiveDate { get; set; } + + /// <summary> + /// 閲囪喘鍗曞彿 + /// </summary> + [AnalysisItemRule(AnalysisFormatTypeEnum.ODN), PropertyValidate("閲囪喘鍗曞彿", NotNullAndEmpty = true)] + public string PurchaseOrderNo { get; set; } + + /// <summary> + /// 鏁伴噺 + /// </summary> + [AnalysisItemRule(AnalysisFormatTypeEnum.MTQ), PropertyValidate("鏁伴噺", NotNullAndEmpty = true)] + public float Quantity { get; set; } + + /// <summary> + /// 鍘熷鏁版嵁 + /// </summary> + [AnalysisItemRule(AnalysisFormatTypeEnum.BD), PropertyValidate("鍘熷鏁版嵁", NotNullAndEmpty = true)] + public string SerialNumber { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/ERP/PurchaseOrderModel.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/ERP/PurchaseOrderModel.cs" new file mode 100644 index 0000000..f00d56f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/ERP/PurchaseOrderModel.cs" @@ -0,0 +1,98 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.Attributes; +using WIDESEA_Core.BaseRepository; +using WIDESEA_DTO.Inbound; +using WIDESEA_Model.Models; + +namespace WIDESEA_DTO +{ + /// <summary> + /// 閲囪喘鍗曟ā鍨� + /// </summary> + [ModelValidate] + public class PurchaseOrderModel + { + /// <summary> + /// 鎿嶄綔绫诲瀷(1:鏂板銆�2:淇敼銆�3:鍒犻櫎銆�4:鍏抽棴[鍒犻櫎銆佸叧闂彧瑕佸崟鍙凤紝宸茬敓鎴愭敹璐у崟鐨勪笉鑳藉垹闄) + /// </summary> + [PropertyValidate("鎿嶄綔绫诲瀷", Check = new object[] { 1, 2, 3, 4 })] + public int Way { get; set; } + + /// <summary> + /// 閲囪喘鍗曞彿 + /// </summary> + [PropertyValidate("閲囪喘鍗曞彿", NotNullAndEmpty = true)] + public string OrderNo { get; set; } + + /// <summary> + /// 鍗曟嵁绫诲瀷(S:鏍囧噯鍏ュ簱銆乂:瀵勫敭琛ョ粰鍏ュ簱) + /// </summary> + [PropertyValidate("鍗曟嵁绫诲瀷", NotNullAndEmpty = true, Check = new[] { "S", "V" })] + public string Type { get; set; } + + /// <summary> + /// 渚涘簲鍟嗙紪鍙� + /// </summary> + [PropertyValidate("渚涘簲鍟嗙紪鍙�", NotNullAndEmpty = true)] + public string SCode { get; set; } + + /// <summary> + /// 閲囪喘鏁伴噺 + /// </summary> + [PropertyValidate("閲囪喘鏁伴噺", MinValue = 0, IsContainMinValue = false)] + public float Amount { get; set; } + + /// <summary> + /// 涓嬪崟鏃ユ湡 + /// </summary> + [PropertyValidate("涓嬪崟鏃ユ湡", NotNullAndEmpty = true)] + public string OrderDate { get; set; } + + /// <summary> + /// 澶囨敞 + /// </summary> + public string Note { get; set; } + + /// <summary> + /// 鐗╂枡鍒楄〃 + /// </summary> + [PropertyValidate("鐗╂枡鍒楄〃", NotNullAndEmpty = true)] + public List<PurchaseOrderDetailModel> MList { get; set; } + } + + /// <summary> + /// 閲囪喘鍗曟槑缁嗘ā鍨� + /// </summary> + public class PurchaseOrderDetailModel + { + /// <summary> + /// 琛屽彿 + /// </summary> + public int RowId { get; set; } + + [PropertyValidate("鐗╂枡缂栧彿", NotNullAndEmpty = true)] + public string MCode { get; set; } + + /// <summary> + /// 浠撳簱缂栧彿 + /// </summary> + [PropertyValidate("浠撳簱缂栧彿", NotNullAndEmpty = true)] + public int WaId { get; set; } + + /// <summary> + /// 鏁伴噺 + /// </summary> + [PropertyValidate("閲囪喘鏁伴噺", MinValue = 0, IsContainMinValue = false)] + public float Qty { get; set; } + + /// <summary> + /// 鍗曚綅 + /// </summary> + [PropertyValidate("鍗曚綅", NotNullAndEmpty = true)] + public string Unit { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/ERP/ReceiveOrderModel.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/ERP/ReceiveOrderModel.cs" new file mode 100644 index 0000000..dc93238 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/ERP/ReceiveOrderModel.cs" @@ -0,0 +1,137 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace WIDESEA_DTO +{ + /// <summary> + /// + /// </summary> + public class ReceiveOrderModel + { + /// <summary> + /// 鎿嶄綔绫诲瀷 + /// </summary> + public int Way { get; set; } + + /// <summary> + /// WMS涓诲仴鍊� + /// </summary> + public string UniqueTag { get; set; } + + /// <summary> + /// 鏀惰揣鍗曞彿 + /// </summary> + public string Code { get; set; } + + /// <summary> + /// 鍗曟嵁绫诲瀷 + /// </summary> + public string Type { get; set; } + + /// <summary> + /// 鍏徃浠e彿 + /// </summary> + public string CompanyId { get; set; } = "CompanyId"; + + /// <summary> + /// 宸ュ巶浠e彿 + /// </summary> + public string PlantsId { get; set; } = "PlantsId"; + + /// <summary> + /// 瀹㈡埛浠e彿 + /// </summary> + public string CustomerId { get; set; } = ""; + + /// <summary> + /// 渚涘簲鍟嗕唬鍙� + /// </summary> + public string SuppliersId { get; set; } = ""; + + /// <summary> + /// 鏀惰揣鏃ユ湡 + /// </summary> + public DateTime ReceiveDate { get; set; } + + /// <summary> + /// 閫佽揣鍗曞彿 + /// </summary> + public string DeliveryCode { get; set; } = "/"; + + /// <summary> + /// 浠撳簱浠e彿 + /// </summary> + public string WarehouseCode { get; set; } = ""; + + /// <summary> + /// 鍒涘缓浜轰唬鍙� + /// </summary> + public string CreatorId { get; set; } = ""; + + /// <summary> + /// 鍒涘缓鏃堕棿 + /// </summary> + public DateTime EndDate { get; set; } + } + + public class RecevieOrderDetailModel + { + /// <summary> + /// 閲囪喘鍗曞彿 + /// </summary> + public string PurchaseOrderCode { get; set; } + + /// <summary> + /// 閲囪喘鏄庣粏琛屽彿 + /// </summary> + public int PurchaseOrderSerno { get; set; } + + /// <summary> + /// 鏀惰揣鏄庣粏琛屽彿 + /// </summary> + public int Serno { get; set; } + + /// <summary> + /// 鏉愭枡缂栫爜 + /// </summary> + public string MaterialsId { get; set; } + + /// <summary> + /// 鏀惰揣鏁伴噺 + /// </summary> + public float QtyReceived { get; set; } + + /// <summary> + /// 鏀惰揣鎵规 + /// </summary> + public string Lotno { get; set; } + + /// <summary> + /// 渚涘簲鍟嗘壒娆� + /// </summary> + public string Supplotno { get; set; } + + /// <summary> + /// 鏄惁瑕佹楠� + /// </summary> + public int IfInspection { get; set; } + + /// <summary> + /// 鍚◣浠锋牸 + /// </summary> + public double PriceInTax { get; set; } = 0; + + /// <summary> + /// 绋庣巼 + /// </summary> + public string Taxrate { get; set; } = ""; + + /// <summary> + /// 甯佸埆缂栫爜 + /// </summary> + public string Currcode { get; set; } = ""; + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderAddDTO.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderAddDTO.cs" index 978f3ac..8665342 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderAddDTO.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderAddDTO.cs" @@ -13,31 +13,67 @@ /// <summary> /// 涓婃父鍗曟嵁缂栧彿 /// </summary> - public string UpperOrderNo { get; set; } - - /// <summary> - /// 鍗曟嵁缂栧彿 - /// </summary> + [PropertyValidate("涓婃父鍗曟嵁缂栧彿", NotNullAndEmpty = true)] public string OrderNo { get; set; } /// <summary> /// 鍗曟嵁绫诲瀷 /// </summary> [PropertyValidate("鍗曟嵁绫诲瀷", NotNullAndEmpty = true)] - public int OrderType { get; set; } + public int Type { get; set; } - public string OperateType { get; set; } + /// <summary> + /// 鎿嶄綔绫诲瀷 + /// </summary> + [PropertyValidate("鎿嶄綔绫诲瀷", Check = new object[] { 1, 2, 3, 4 })] + public int OperateType { get; set; } + /// <summary> + /// 閲囪喘鏁伴噺 + /// </summary> + [PropertyValidate("閲囪喘鏁伴噺", MinValue = 0, IsContainMinValue = false)] public float Amount { get; set; } + /// <summary> + /// 涓嬪崟鏃ユ湡 + /// </summary> + [PropertyValidate("涓嬪崟鏃ユ湡", NotNullAndEmpty = true)] public string OrderDate { get; set; } /// <summary> /// 澶囨敞 /// </summary> - public string Remark { get; set; } + public string Note { get; set; } [PropertyValidate("鍗曟嵁鏄庣粏淇℃伅", NotNullAndEmpty = true)] - public List<InboundOrderDetailAddDTO> Details { get; set; } + public List<InboundOrderDetailAddDTO> MList { get; set; } + } + + [ModelValidate] + public class InboundOrderDetailAddDTO + { + /// <summary> + /// 鐗╂枡缂栧彿 + /// </summary> + [PropertyValidate("鐗╂枡缂栧彿", NotNullAndEmpty = true)] + public string MaterielCode { get; set; } + + /// <summary> + /// 鏁伴噺 + /// </summary> + [PropertyValidate("鏁伴噺", NotNullAndEmpty = true, MinValue = 0, IsContainMinValue = false)] + public float Qty { get; set; } + + /// <summary> + /// 浠撳簱缂栧彿 + /// </summary> + [PropertyValidate("浠撳簱缂栧彿", NotNullAndEmpty = true)] + public int WaId { get; set; } + + /// <summary> + /// 鍗曚綅 + /// </summary> + [PropertyValidate("鍗曚綅", NotNullAndEmpty = true)] + public string Unit { get; set; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderDetailAddDTO.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderDetailAddDTO.cs" index df7161f..37aca4d 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderDetailAddDTO.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Inbound/InboundOrderDetailAddDTO.cs" @@ -7,38 +7,5 @@ namespace WIDESEA_DTO.Inbound { - [ModelValidate] - public class InboundOrderDetailAddDTO - { - /// <summary> - /// 鐗╂枡缂栧彿 - /// </summary> - [PropertyValidate("鐗╂枡缂栧彿", NotNullAndEmpty = true)] - public string MaterielCode { get; set; } - - /// <summary> - /// 鐗╂枡鍚嶇О - /// </summary> - public string MaterielName { get; set; } - - /// <summary> - /// 鎵规鍙� - /// </summary> - public string BatchNo { get; set; } - - /// <summary> - /// 鍗曟嵁鏁伴噺 - /// </summary> - [PropertyValidate("鍗曟嵁鏁伴噺", NotNullAndEmpty = true, MinValue = 0, IsContainMinValue = false)] - public decimal OrderQuantity { get; set; } - - public int WaId { get; set; } - - public string Unit { get; set; } - - /// <summary> - /// 澶囨敞 - /// </summary> - public string Remark { get; set; } - } + } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/MatSerialNumberDTO.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/MatSerialNumberDTO.cs" deleted file mode 100644 index 0eacb9d..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/MatSerialNumberDTO.cs" +++ /dev/null @@ -1,31 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.Linq; -using System.Text; -using System.Threading.Tasks; -using WIDESEA_Core.Attributes; - -namespace WIDESEA_DTO -{ - [AnalysisRule, ModelValidate] - public class MatSerialNumberDTO - { - [AnalysisItemRule(WIDESEA_Core.CodeConfigEnum.AnalysisFormatTypeEnum.MTC), PropertyValidate("鐗╂枡缂栧彿", NotNullAndEmpty = true)] - public string MaterielCode { get; set; } - - [AnalysisItemRule(WIDESEA_Core.CodeConfigEnum.AnalysisFormatTypeEnum.MTPT), PropertyValidate("鐢熶骇鏃ユ湡", NotNullAndEmpty = true)] - public string ProductionDate { get; set; } - - [AnalysisItemRule(WIDESEA_Core.CodeConfigEnum.AnalysisFormatTypeEnum.BHN), PropertyValidate("鎵规鍙�", NotNullAndEmpty = true)] - public string BatchNo { get; set; } - - [AnalysisItemRule(WIDESEA_Core.CodeConfigEnum.AnalysisFormatTypeEnum.MTQ), PropertyValidate("鏁伴噺", NotNullAndEmpty = true)] - public decimal MaterielQuantity { get; set; } - - [AnalysisItemRule(WIDESEA_Core.CodeConfigEnum.AnalysisFormatTypeEnum.ODN), PropertyValidate("璁㈠崟缂栧彿", NotNullAndEmpty = true)] - public string OrderNo { get; set; } - - [AnalysisItemRule(WIDESEA_Core.CodeConfigEnum.AnalysisFormatTypeEnum.BD), PropertyValidate("搴忓垪鍙�", NotNullAndEmpty = true)] - public string SerialNumber { get; set; } - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Stock/StockViewDTO.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Stock/StockViewDTO.cs" index ae06f8b..1ccdb56 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Stock/StockViewDTO.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/Stock/StockViewDTO.cs" @@ -12,8 +12,6 @@ { public class StockViewDTO { - public int AreaId { get; set; } - public string LocationCode { get; set; } public string LocationName { get; set; } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/System/VueDictionaryDTO.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/System/VueDictionaryDTO.cs" index 65d9e80..ffa7f3b 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/System/VueDictionaryDTO.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_DTO/System/VueDictionaryDTO.cs" @@ -13,5 +13,7 @@ public string Config { get; set; } public object Data { get; set; } + + public bool SaveCache { get; set; } = true; } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/ERPService/ERPInvokeService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/ERPService/ERPInvokeService.cs" index 21ba432..48a6530 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/ERPService/ERPInvokeService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/ERPService/ERPInvokeService.cs" @@ -5,7 +5,8 @@ using System.Threading.Tasks; using WIDESEA_Core; using WIDESEA_Core.Attributes; -using WIDESEA_External.Model; +using WIDESEA_DTO; +using WIDESEA_IInboundService; namespace WIDESEA_External.ERPService { @@ -14,12 +15,10 @@ /// </summary> public class ERPInvokeService : IERPInvokeService { - - public WebResponseContent ReceivePurchaseOrder(PurchaseOrderModel model) + private readonly IInboundOrderService _inboundOrderService; + public ERPInvokeService(IInboundOrderService inboundOrderService) { - return WebResponseContent.Instance.OK(); + _inboundOrderService = inboundOrderService; } - - } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/IERPService/IERPInvokeService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/IERPService/IERPInvokeService.cs" index bc85b57..5a34e9c 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/IERPService/IERPInvokeService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/IERPService/IERPInvokeService.cs" @@ -4,7 +4,7 @@ using System.Text; using System.Threading.Tasks; using WIDESEA_Core; -using WIDESEA_External.Model; +using WIDESEA_DTO; namespace WIDESEA_External.ERPService { @@ -13,6 +13,5 @@ /// </summary> public interface IERPInvokeService : IDependency { - WebResponseContent ReceivePurchaseOrder(PurchaseOrderModel model); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/Model/PurchaseOrderModel.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/Model/PurchaseOrderModel.cs" deleted file mode 100644 index 5113117..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/Model/PurchaseOrderModel.cs" +++ /dev/null @@ -1,95 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.Linq; -using System.Text; -using System.Threading.Tasks; -using WIDESEA_Core.Attributes; -using WIDESEA_Core.BaseRepository; -using WIDESEA_DTO.Inbound; -using WIDESEA_InboundService; -using WIDESEA_Model.Models; - -namespace WIDESEA_External.Model -{ - /// <summary> - /// 閲囪喘鍗曟ā鍨� - /// </summary> - [ModelValidate] - public class PurchaseOrderModel - { - /// <summary> - /// 鎿嶄綔绫诲瀷(1:鏂板銆�2:淇敼銆�3:鍒犻櫎銆�4:鍏抽棴[鍒犻櫎銆佸叧闂彧瑕佸崟鍙凤紝宸茬敓鎴愭敹璐у崟鐨勪笉鑳藉垹闄) - /// </summary> - [PropertyValidate("鎿嶄綔绫诲瀷", Check = new object[] { 1, 2, 3, 4 })] - public int Way { get; set; } - - /// <summary> - /// 閲囪喘鍗曞彿 - /// </summary> - [PropertyValidate("閲囪喘鍗曞彿", NotNullAndEmpty = true)] - public string OrderNo { get; set; } - - /// <summary> - /// 鍗曟嵁绫诲瀷(S:鏍囧噯鍏ュ簱銆乂:瀵勫敭琛ョ粰鍏ュ簱) - /// </summary> - [PropertyValidate("鍗曟嵁绫诲瀷", NotNullAndEmpty = true, Check = new[] { "S", "V" })] - public string Type { get; set; } - - /// <summary> - /// 渚涘簲鍟嗙紪鍙� - /// </summary> - [PropertyValidate("渚涘簲鍟嗙紪鍙�", NotNullAndEmpty = true)] - public string SCode { get; set; } - - /// <summary> - /// 閲囪喘鏁伴噺 - /// </summary> - [PropertyValidate("閲囪喘鏁伴噺", MinValue = 0, IsContainMinValue = false)] - public float Amount { get; set; } - - /// <summary> - /// 涓嬪崟鏃ユ湡 - /// </summary> - [PropertyValidate("涓嬪崟鏃ユ湡", NotNullAndEmpty = true)] - public string OrderDate { get; set; } - - /// <summary> - /// 澶囨敞 - /// </summary> - public string Note { get; set; } - - /// <summary> - /// 鐗╂枡鍒楄〃 - /// </summary> - public List<PurchaseOrderDetailModel> MList { get; set; } - } - - /// <summary> - /// 閲囪喘鍗曟槑缁嗘ā鍨� - /// </summary> - public class PurchaseOrderDetailModel - { - /// <summary> - /// 琛屽彿 - /// </summary> - public int RowId { get; set; } - - /// <summary> - /// 浠撳簱缂栧彿 - /// </summary> - [PropertyValidate("浠撳簱缂栧彿", NotNullAndEmpty = true)] - public int WaId { get; set; } - - /// <summary> - /// 鏁伴噺 - /// </summary> - [PropertyValidate("閲囪喘鏁伴噺", MinValue = 0, IsContainMinValue = false)] - public float Qty { get; set; } - - /// <summary> - /// 鍗曚綅 - /// </summary> - [PropertyValidate("鍗曚綅", NotNullAndEmpty = true)] - public string Unit { get; set; } - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/WIDESEA_External.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/WIDESEA_External.csproj" index 2e808ad..ae35cbe 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/WIDESEA_External.csproj" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_External/WIDESEA_External.csproj" @@ -11,4 +11,8 @@ <ProjectReference Include="..\WIDESEA_InboundService\WIDESEA_InboundService.csproj" /> </ItemGroup> + <ItemGroup> + <Folder Include="Model\" /> + </ItemGroup> + </Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalFlowRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalFlowRepository.cs" new file mode 100644 index 0000000..b1eb17b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalFlowRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_IApprovalRepository +{ + public interface IApprovalFlowRepository : IRepository<Dt_ApprovalFlow> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalNodeRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalNodeRepository.cs" new file mode 100644 index 0000000..f70f29d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalNodeRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_IApprovalRepository +{ + public interface IApprovalNodeRepository : IRepository<Dt_ApprovalNode> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalTaskRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalTaskRepository.cs" new file mode 100644 index 0000000..f2057dd --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/IApprovalTaskRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_IApprovalRepository +{ + public interface IApprovalTaskRepository : IRepository<Dt_ApprovalTask> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/INodeTransitionRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/INodeTransitionRepository.cs" new file mode 100644 index 0000000..3ad7371 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/INodeTransitionRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_IApprovalRepository +{ + public interface INodeTransitionRepository : IRepository<Dt_NodeTransition> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/WIDESEA_IApprovalRepository.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/WIDESEA_IApprovalRepository.csproj" new file mode 100644 index 0000000..a70161f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalRepository/WIDESEA_IApprovalRepository.csproj" @@ -0,0 +1,13 @@ +<Project Sdk="Microsoft.NET.Sdk"> + + <PropertyGroup> + <TargetFramework>net6.0</TargetFramework> + <ImplicitUsings>enable</ImplicitUsings> + <Nullable>enable</Nullable> + </PropertyGroup> + + <ItemGroup> + <ProjectReference Include="..\WIDESEA_DTO\WIDESEA_DTO.csproj" /> + </ItemGroup> + +</Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/IApprovalFlowService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/IApprovalFlowService.cs" new file mode 100644 index 0000000..ca06db0 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/IApprovalFlowService.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseServices; +using WIDESEA_Model.Models; + +namespace WIDESEA_IApprovalService +{ + public interface IApprovalFlowService : IService<Dt_ApprovalFlow> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/IApprovalTaskService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/IApprovalTaskService.cs" new file mode 100644 index 0000000..6750ba4 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/IApprovalTaskService.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_Model.Models; + +namespace WIDESEA_IApprovalService +{ + public interface IApprovalTaskService : IService<Dt_ApprovalTask> + { + WebResponseContent AuditAgree(int sourceKey); + + WebResponseContent AuditReject(int sourceKey); + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/WIDESEA_IApprovalService.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/WIDESEA_IApprovalService.csproj" new file mode 100644 index 0000000..64d4fbb --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IApprovalService/WIDESEA_IApprovalService.csproj" @@ -0,0 +1,13 @@ +<Project Sdk="Microsoft.NET.Sdk"> + + <PropertyGroup> + <TargetFramework>net6.0</TargetFramework> + <ImplicitUsings>enable</ImplicitUsings> + <Nullable>enable</Nullable> + </PropertyGroup> + + <ItemGroup> + <ProjectReference Include="..\WIDESEA_ApprovalRepository\WIDESEA_ApprovalRepository.csproj" /> + </ItemGroup> + +</Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IBasicRepository/ILocationInfoRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IBasicRepository/ILocationInfoRepository.cs" index 91f4cd2..a5154b4 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IBasicRepository/ILocationInfoRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IBasicRepository/ILocationInfoRepository.cs" @@ -30,14 +30,6 @@ List<LocationGroupDTO> GetLocationGroups(string roadway, LocationStatusEnum locationAStatus, LocationStatusEnum locationBStatus); /// <summary> - /// 鏍规嵁宸烽亾鍙烽泦鍚堛�佸尯鍩熼泦鍚堣幏鍙栧彲鍑哄簱鐨勮揣浣嶇紪鍙烽泦鍚� - /// </summary> - /// <param name="roadways">宸烽亾鍙烽泦鍚�</param> - /// <param name="areaIds">鍖哄煙闆嗗悎</param> - /// <returns></returns> - List<string> GetCanOutLocationCodes(List<string> roadways, List<int> areaIds); - - /// <summary> /// 鏍规嵁璐т綅缂栧彿闆嗗悎鑾峰彇璐т綅瀹炰綋闆嗗悎 /// </summary> /// <param name="locationCodes">璐т綅缂栧彿闆嗗悎</param> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IBasicService/ILocationInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IBasicService/ILocationInfoService.cs" index da8ea7c..e32d8bb 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IBasicService/ILocationInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IBasicService/ILocationInfoService.cs" @@ -4,6 +4,7 @@ using System.Text; using System.Threading.Tasks; using WIDESEA_Common.CommonEnum; +using WIDESEA_Common.LocationEnum; using WIDESEA_Core; using WIDESEA_Core.BaseServices; using WIDESEA_DTO.Basic; @@ -19,5 +20,9 @@ WebResponseContent InitializationLocation(InitializationLocationDTO initializationLocationDTO); Dt_LocationInfo? AssignLocation(string roadwayNo, PalletTypeEnum palletType); + + void UpdateLocationStatus(string locationCode, PalletTypeEnum palletType, LocationStatusEnum locationStatus); + + void UpdateLocationStatus(Dt_LocationInfo location, PalletTypeEnum palletType, LocationStatusEnum locationStatus); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/ICheckOrderRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/ICheckOrderRepository.cs" new file mode 100644 index 0000000..bb67159 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/ICheckOrderRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_ICheckRepository +{ + public interface ICheckOrderRepository : IRepository<Dt_CheckOrder> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/ICheckOrderResultRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/ICheckOrderResultRepository.cs" new file mode 100644 index 0000000..e6da58d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/ICheckOrderResultRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_ICheckRepository +{ + public interface ICheckOrderResultRepository : IRepository<Dt_CheckOrderResult> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/WIDESEA_ICheckRepository.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/WIDESEA_ICheckRepository.csproj" new file mode 100644 index 0000000..a70161f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckRepository/WIDESEA_ICheckRepository.csproj" @@ -0,0 +1,13 @@ +<Project Sdk="Microsoft.NET.Sdk"> + + <PropertyGroup> + <TargetFramework>net6.0</TargetFramework> + <ImplicitUsings>enable</ImplicitUsings> + <Nullable>enable</Nullable> + </PropertyGroup> + + <ItemGroup> + <ProjectReference Include="..\WIDESEA_DTO\WIDESEA_DTO.csproj" /> + </ItemGroup> + +</Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/ICheckOrderResultService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/ICheckOrderResultService.cs" new file mode 100644 index 0000000..069e1b5 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/ICheckOrderResultService.cs" @@ -0,0 +1,16 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_Model.Models; + +namespace WIDESEA_ICheckService +{ + public interface ICheckOrderResultService : IService<Dt_CheckOrderResult> + { + WebResponseContent CommitCheckResult(int checkOrderId, Dt_CheckOrderResult checkResult); + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/ICheckOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/ICheckOrderService.cs" new file mode 100644 index 0000000..51a9bec --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/ICheckOrderService.cs" @@ -0,0 +1,16 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_Model.Models; + +namespace WIDESEA_ICheckService +{ + public interface ICheckOrderService : IService<Dt_CheckOrder> + { + WebResponseContent CommitAudit(int checkOrderId); + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/WIDESEA_ICheckService.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/WIDESEA_ICheckService.csproj" new file mode 100644 index 0000000..9987a92 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ICheckService/WIDESEA_ICheckService.csproj" @@ -0,0 +1,13 @@ +<Project Sdk="Microsoft.NET.Sdk"> + + <PropertyGroup> + <TargetFramework>net6.0</TargetFramework> + <ImplicitUsings>enable</ImplicitUsings> + <Nullable>enable</Nullable> + </PropertyGroup> + + <ItemGroup> + <ProjectReference Include="..\WIDESEA_CheckRepository\WIDESEA_CheckRepository.csproj" /> + </ItemGroup> + +</Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IInboundRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IInboundRepository.cs" index cd77bda..ec7fdbe 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IInboundRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IInboundRepository.cs" @@ -12,5 +12,13 @@ IInboundOrderDetailRepository InboundOrderDetailRepository { get; } IInboundOrderRepository InboundOrderRepository { get; } + + IReceiveOrderDetailRepository ReceiveOrderDetailRepository { get; } + + IReceiveOrderRepository ReceiveOrderRepository { get; } + + IPurchaseOrderDetailRepository PurchaseOrderDetailRepository { get; } + + IPurchaseOrderRepository PurchaseOrderRepository { get; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IPurchaseOrderDetailRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IPurchaseOrderDetailRepository.cs" new file mode 100644 index 0000000..6080ba3 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IPurchaseOrderDetailRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_IInboundRepository +{ + public interface IPurchaseOrderDetailRepository : IRepository<Dt_PurchaseOrderDetail> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IPurchaseOrderRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IPurchaseOrderRepository.cs" new file mode 100644 index 0000000..70adcf0 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IPurchaseOrderRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_IInboundRepository +{ + public interface IPurchaseOrderRepository : IRepository<Dt_PurchaseOrder> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IReceiveOrderDetailRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IReceiveOrderDetailRepository.cs" new file mode 100644 index 0000000..da9f0cf --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IReceiveOrderDetailRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_IInboundRepository +{ + public interface IReceiveOrderDetailRepository : IRepository<Dt_ReceiveOrderDetail> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IReceiveOrderRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IReceiveOrderRepository.cs" new file mode 100644 index 0000000..ba12796 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundRepository/IReceiveOrderRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_IInboundRepository +{ + public interface IReceiveOrderRepository : IRepository<Dt_ReceiveOrder> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderDetailService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderDetailService.cs" index e25fd55..da67953 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderDetailService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderDetailService.cs" @@ -12,7 +12,5 @@ public interface IInboundOrderDetailService : IService<Dt_InboundOrderDetail> { IInboundOrderDetailRepository Repository { get; } - - List<Dt_InboundOrderDetail> UpdateReceiptQuantity(List<Dt_InboundOrderDetail> inboundOrderDetails, decimal receiptQuantity); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderService.cs" index d5c8bfa..3a45629 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundOrderService.cs" @@ -5,6 +5,7 @@ using System.Threading.Tasks; using WIDESEA_Core; using WIDESEA_Core.BaseServices; +using WIDESEA_DTO; using WIDESEA_DTO.Inbound; using WIDESEA_IInboundRepository; using WIDESEA_Model.Models; @@ -15,5 +16,8 @@ { IInboundOrderRepository Repository { get; } + WebResponseContent MaterielGroup(int inboundOrderId, string palletCode, string serNum); + + WebResponseContent MaterielGroup(int inboundOrderId, string palletCode, List<string> serNums); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundService.cs" index a70183e..fea1b5b 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IInboundService.cs" @@ -4,6 +4,7 @@ using System.Text; using System.Threading.Tasks; using WIDESEA_Core; +using WIDESEA_IInboundRepository; namespace WIDESEA_IInboundService { @@ -12,5 +13,9 @@ IInboundOrderDetailService InboundOrderDetailService { get; } IInboundOrderService InbounOrderService { get; } + + IReceiveOrderDetailService ReceiveOrderDetailService { get; } + + IReceiveOrderService ReceiveOrderService { get; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IPurchaseOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IPurchaseOrderService.cs" new file mode 100644 index 0000000..733f4e7 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IPurchaseOrderService.cs" @@ -0,0 +1,17 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_DTO; +using WIDESEA_Model.Models; + +namespace WIDESEA_IInboundService +{ + public interface IPurchaseOrderService : IService<Dt_PurchaseOrder> + { + WebResponseContent ReceivePurchaseOrderSingle(PurchaseOrderModel model); + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IReceiveOrderDetailService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IReceiveOrderDetailService.cs" new file mode 100644 index 0000000..c8db06f --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IReceiveOrderDetailService.cs" @@ -0,0 +1,16 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_Model.Models; + +namespace WIDESEA_IInboundService +{ + public interface IReceiveOrderDetailService : IService<Dt_ReceiveOrderDetail> + { + WebResponseContent AddReceiveOrderDetail(string serNum, string orderNo); + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IReceiveOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IReceiveOrderService.cs" new file mode 100644 index 0000000..89396ec --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IInboundService/IReceiveOrderService.cs" @@ -0,0 +1,16 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_Model.Models; + +namespace WIDESEA_IInboundService +{ + public interface IReceiveOrderService : IService<Dt_ReceiveOrder> + { + WebResponseContent CreateInboundOrder(int receiveOrderId); + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutStockLockInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutStockLockInfoService.cs" index 9e0169e..6bdb926 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutStockLockInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutStockLockInfoService.cs" @@ -14,11 +14,5 @@ public interface IOutStockLockInfoService : IService<Dt_OutStockLockInfo> { IOutStockLockInfoRepository Repository { get; } - - List<Dt_OutStockLockInfo> GetOutStockLockInfos(Dt_OutboundOrder outboundOrder, Dt_OutboundOrderDetail outboundOrderDetail, List<Dt_StockInfo> outStocks, int? taskNum = null); - - List<Dt_OutStockLockInfo> GetByOrderDetailId(int orderDetailId); - - List<Dt_OutStockLockInfo> GetByOrderDetailId(int orderDetailId, OutLockStockStatusEnum outStockStatus); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutboundOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutboundOrderService.cs" index e86bcfd..1f9c2d3 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutboundOrderService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IOutboundService/IOutboundOrderService.cs" @@ -15,10 +15,5 @@ public interface IOutboundOrderService : IService<Dt_OutboundOrder> { IOutboundOrderRepository Repository { get; } - - WebResponseContent AddOutboundOrder(OutboundOrderAddDTO orderAddDTO); - - WebResponseContent GetOutboundOrder(OutboundOrderGetDTO outboundOrderGetDTO); - WebResponseContent GetOutboundOrderDetail(string OrderNo); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/ILocationStatusChangeRecordSetvice.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/ILocationStatusChangeRecordSetvice.cs" index 379f4b5..8dd2cb3 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/ILocationStatusChangeRecordSetvice.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/ILocationStatusChangeRecordSetvice.cs" @@ -3,6 +3,7 @@ using System.Linq; using System.Text; using System.Threading.Tasks; +using WIDESEA_Common.LocationEnum; using WIDESEA_Core; using WIDESEA_Core.BaseServices; using WIDESEA_IRecordRepository; @@ -14,9 +15,9 @@ { ILocationStatusChangeRecordRepository Repository { get; } - void AddLocationStatusChangeRecord(Dt_LocationInfo locationInfo, int lastStatus, int changeType, string orderNo, int? taskNum); + void AddLocationStatusChangeRecord(Dt_LocationInfo locationInfo, LocationStatusEnum lastStatus, LocationChangeType changeType, string? orderNo = null, int? taskNum = null); - void AddLocationStatusChangeRecord(List<Dt_LocationInfo> locationInfos, int newStatus, int changeType, string? orderNo, List<int>? taskNums); + void AddLocationStatusChangeRecord(List<Dt_LocationInfo> locationInfos, LocationStatusEnum newStatus, LocationChangeType changeType, string? orderNo, List<int>? taskNums); WebResponseContent GetLocationState(int id); } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/IStockQuantityChangeRecordService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/IStockQuantityChangeRecordService.cs" index 12e6908..8550885 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/IStockQuantityChangeRecordService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_IRecordService/IStockQuantityChangeRecordService.cs" @@ -15,6 +15,6 @@ { IStockQuantityChangeRecordRepository Repository { get; } - void AddStockChangeRecord(Dt_StockInfo stockInfo, List<Dt_StockInfoDetail> stockInfoDetails, decimal beforeQuantity, decimal totalQuantity, StockChangeTypeEnum changeType,int taskNum); + void AddStockChangeRecord(Dt_StockInfo stockInfo, List<Dt_StockInfoDetail> stockInfoDetails, float beforeQuantity, float totalQuantity, StockChangeTypeEnum changeType, int? taskNum = null); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ISystemRepository/ISys_RoleDataPermissionRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ISystemRepository/ISys_RoleDataPermissionRepository.cs" new file mode 100644 index 0000000..5dbada6 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ISystemRepository/ISys_RoleDataPermissionRepository.cs" @@ -0,0 +1,14 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_ISystemRepository +{ + public interface ISys_RoleDataPermissionRepository : IRepository<Sys_RoleDataPermission> + { + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ISystemService/ISys_RoleService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ISystemService/ISys_RoleService.cs" index 66e210f..ecf033c 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ISystemService/ISys_RoleService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ISystemService/ISys_RoleService.cs" @@ -20,11 +20,11 @@ WebResponseContent GetCurrentTreePermission(); - WebResponseContent GetUserTreePermission(int role_Id); + WebResponseContent GetUserTreePermission(int RoleId); WebResponseContent GetCurrentTreePermissionPDA(); - WebResponseContent GetUserTreePermissionPDA(int role_Id); + WebResponseContent GetUserTreePermissionPDA(int RoleId); WebResponseContent SavePermission(List<UserPermissionDTO> userPermissions, int roleId); } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITaskService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITaskService.cs" index c6e742f..ef679ce 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITaskService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITaskService.cs" @@ -35,5 +35,8 @@ { ITaskRepository Repository { get; } + WebResponseContent RequestInboundTask(string palletCode, string stationCode); + + WebResponseContent InboundTaskCompleted(int taskNum); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITask_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITask_HtyService.cs" index 85eacae..7a83fc0 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITask_HtyService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_ITaskInfoService/ITask_HtyService.cs" @@ -16,11 +16,4 @@ public interface ITask_HtyService : IService<Dt_Task_Hty> { - /// <summary> - /// 娣诲姞鍘嗗彶浠诲姟 - /// </summary> - /// <param name="task">鍘嗗彶浠诲姟Model</param> - /// <returns>鎴愬姛/澶辫触</returns> - bool InsertTask(Dt_Task_Hty task); - WebResponseContent AddTaskHty(Dt_Task task); } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/InboundRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/InboundRepository.cs" index 511585a..b5d5b45 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/InboundRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/InboundRepository.cs" @@ -13,10 +13,22 @@ public IInboundOrderRepository InboundOrderRepository { get; } - public InboundRepository(IInboundOrderDetailRepository inboundOrderDetailRepository, IInboundOrderRepository inboundOrderRepository) + public IReceiveOrderDetailRepository ReceiveOrderDetailRepository { get; } + + public IReceiveOrderRepository ReceiveOrderRepository { get; } + + public IPurchaseOrderDetailRepository PurchaseOrderDetailRepository { get; } + + public IPurchaseOrderRepository PurchaseOrderRepository { get; } + + public InboundRepository(IInboundOrderDetailRepository inboundOrderDetailRepository, IInboundOrderRepository inboundOrderRepository, IReceiveOrderDetailRepository receiveOrderDetailRepository, IReceiveOrderRepository receiveOrderRepository, IPurchaseOrderDetailRepository purchaseOrderDetailRepository, IPurchaseOrderRepository purchaseOrderRepository) { InboundOrderDetailRepository = inboundOrderDetailRepository; InboundOrderRepository = inboundOrderRepository; + ReceiveOrderDetailRepository = receiveOrderDetailRepository; + ReceiveOrderRepository = receiveOrderRepository; + PurchaseOrderDetailRepository = purchaseOrderDetailRepository; + PurchaseOrderRepository = purchaseOrderRepository; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/PurchaseOrderDetailRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/PurchaseOrderDetailRepository.cs" new file mode 100644 index 0000000..cf09843 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/PurchaseOrderDetailRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_IInboundRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundRepository +{ + public class PurchaseOrderDetailRepository : RepositoryBase<Dt_PurchaseOrderDetail>, IPurchaseOrderDetailRepository + { + public PurchaseOrderDetailRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/PurchaseOrderRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/PurchaseOrderRepository.cs" new file mode 100644 index 0000000..0dc7e6a --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/PurchaseOrderRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_IInboundRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundRepository +{ + public class PurchaseOrderRepository : RepositoryBase<Dt_PurchaseOrder>, IPurchaseOrderRepository + { + public PurchaseOrderRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/ReceiveOrderDetailRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/ReceiveOrderDetailRepository.cs" new file mode 100644 index 0000000..2ef674c --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/ReceiveOrderDetailRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_IInboundRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundRepository +{ + public class ReceiveOrderDetailRepository : RepositoryBase<Dt_ReceiveOrderDetail>, IReceiveOrderDetailRepository + { + public ReceiveOrderDetailRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/ReceiveOrderRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/ReceiveOrderRepository.cs" new file mode 100644 index 0000000..ab1cd7b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundRepository/ReceiveOrderRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_IInboundRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundRepository +{ + public class ReceiveOrderRepository : RepositoryBase<Dt_ReceiveOrder>, IReceiveOrderRepository + { + public ReceiveOrderRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderDetailService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderDetailService.cs" deleted file mode 100644 index d3387d2..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderDetailService.cs" +++ /dev/null @@ -1,23 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.Linq; -using System.Text; -using System.Threading.Tasks; -using WIDESEA_Core.BaseServices; -using WIDESEA_Core.Enums; -using WIDESEA_Core.Helper; -using WIDESEA_IInboundRepository; -using WIDESEA_IInboundService; -using WIDESEA_Model.Models; - -namespace WIDESEA_InboundService -{ - public partial class InboundOrderDetailService : ServiceBase<Dt_InboundOrderDetail, IInboundOrderDetailRepository>, IInboundOrderDetailService - { - public IInboundOrderDetailRepository Repository => BaseDal; - - public InboundOrderDetailService(IInboundOrderDetailRepository BaseDal) : base(BaseDal) - { - } - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderDetail_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderDetail_HtyService.cs" deleted file mode 100644 index 4a1c5a0..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderDetail_HtyService.cs" +++ /dev/null @@ -1,23 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.Linq; -using System.Text; -using System.Threading.Tasks; -using WIDESEA_Core.BaseServices; -using WIDESEA_Core.Enums; -using WIDESEA_Core.Helper; -using WIDESEA_IInboundRepository; -using WIDESEA_IInboundService; -using WIDESEA_Model.Models; - -namespace WIDESEA_InboundService -{ - public partial class InboundOrderDetail_HtyService : ServiceBase<Dt_InboundOrderDetail_Hty, IInboundOrderDetail_HtyRepository>, IInboundOrderDetail_HtyService - { - public IInboundOrderDetail_HtyRepository Repository => BaseDal; - - public InboundOrderDetail_HtyService(IInboundOrderDetail_HtyRepository BaseDal) : base(BaseDal) - { - } - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderService.cs" deleted file mode 100644 index 7be5b2c..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrderService.cs" +++ /dev/null @@ -1,174 +0,0 @@ -锘縰sing AutoMapper; -using SqlSugar; -using System; -using System.Collections.Generic; -using System.Linq; -using System.Linq.Expressions; -using System.Reflection.Metadata; -using System.Text; -using System.Threading.Tasks; -using WIDESEA_Common.OrderEnum; -using WIDESEA_Core; -using WIDESEA_Core.BaseRepository; -using WIDESEA_Core.BaseServices; -using WIDESEA_Core.Enums; -using WIDESEA_Core.Helper; -using WIDESEA_Core.Utilities; -using WIDESEA_DTO; -using WIDESEA_DTO.Inbound; -using WIDESEA_IBasicService; -using WIDESEA_IInboundRepository; -using WIDESEA_IInboundService; -using WIDESEA_IStockService; -using WIDESEA_ITaskInfoRepository; -using WIDESEA_Model.Models; - -namespace WIDESEA_InboundService -{ - public partial class InboundOrderService : ServiceBase<Dt_InboundOrder, IInboundOrderRepository>, IInboundOrderService - { - private readonly IMapper _mapper; - private readonly IUnitOfWorkManage _unitOfWorkManage; - private readonly ITaskRepository _taskRepository; - - private IBasicService _basicService; - private IStockService _stockService; - private IInboundOrderDetailService _inboundOrderDetailService; - - public IInboundOrderRepository Repository => BaseDal; - - public InboundOrderService(IInboundOrderRepository BaseDal, IMapper mapper, IUnitOfWorkManage unitOfWorkManage, ITaskRepository taskRepository, IBasicService basicService, IStockService stockService, IInboundOrderDetailService inboundOrderDetailService) : base(BaseDal) - { - _mapper = mapper; - _unitOfWorkManage = unitOfWorkManage; - _taskRepository = taskRepository; - _basicService = basicService; - _stockService = stockService; - _inboundOrderDetailService = inboundOrderDetailService; - } - - /// <summary> - /// 娣诲姞鍗曟嵁 - /// </summary> - /// <param name="saveModel"></param> - /// <returns></returns> - public override WebResponseContent AddData(SaveModel saveModel) - { - InboundOrderAddDTO orderAddDTO = saveModel.MainData.DicToModel<InboundOrderAddDTO>(); - orderAddDTO.Details = saveModel.DetailData.DicToIEnumerable<InboundOrderDetailAddDTO>(); - return AddInboundOrder(orderAddDTO); - } - - /// <summary> - /// 娣诲姞鍗曟嵁 - /// </summary> - /// <param name="orderAddDTO">鍗曟嵁娣诲姞DTO</param> - /// <returns></returns> - public WebResponseContent AddInboundOrder(InboundOrderAddDTO orderAddDTO) - { - WebResponseContent content = new(); - try - { - #region 楠岃瘉鏁版嵁 - (bool, string, object?) result = CheckInboundOrderAddData(orderAddDTO); - if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); - #endregion - - Dt_InboundOrder inboundOrder = _mapper.Map<Dt_InboundOrder>(orderAddDTO); - inboundOrder.OrderStatus = InOrderStatusEnum.鏈紑濮�.ObjToInt(); - bool a = BaseDal.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); - content = WebResponseContent.Instance.OK(); - } - catch (Exception ex) - { - content = WebResponseContent.Instance.Error(ex.Message); - } - finally - { - - } - return content; - } - - /// <summary> - /// 楠岃瘉鍗曟嵁娣诲姞DTO瀵硅薄 - /// </summary> - /// <param name="inboundOrderAddDTO">鍗曟嵁娣诲姞DTO</param> - /// <returns></returns> - private (bool, string, object?) CheckInboundOrderAddData(InboundOrderAddDTO inboundOrderAddDTO) - { - (bool, string, object?) result1 = ModelValidate.ValidateModelData(inboundOrderAddDTO); - if (!result1.Item1) return result1; - - (bool, string, object?) result2 = ModelValidate.ValidateModelData(inboundOrderAddDTO.Details); - if (!result2.Item1) return result2; - - IEnumerable<int> inOrderTypes = Enum.GetValues<InOrderTypeEnum>().Cast<int>(); - if (!inOrderTypes.Contains(inboundOrderAddDTO.OrderType)) - { - return (false, "鏈壘鍒拌鍗曟嵁绫诲瀷", inboundOrderAddDTO); - } - - List<string> materielCodes = inboundOrderAddDTO.Details.Select(x => x.MaterielCode).ToList(); - if (!_basicService.MaterielInfoService.ExsitMateriels(materielCodes)) - { - return (false, "鏈夌墿鏂欎俊鎭湭褰曞叆锛岃褰曞叆鐗╂枡淇℃伅", inboundOrderAddDTO); - } - - if (BaseDal.QueryFirst(x => x.UpperOrderNo == inboundOrderAddDTO.UpperOrderNo && !string.IsNullOrEmpty(x.UpperOrderNo)) != null) - { - return (false, "鍗曟嵁宸插瓨鍦�", inboundOrderAddDTO); - } - return (true, "鎴愬姛", inboundOrderAddDTO); - } - - public WebResponseContent GetInboundOrder(InboundOrderGetDTO inboundOrderGetDTO) - { - WebResponseContent content = new WebResponseContent(); - try - { - Expression<Func<Dt_InboundOrder, bool>> expressionOrder = x => true; - if (!string.IsNullOrEmpty(inboundOrderGetDTO.OrderNo)) - { - expressionOrder = x => x.OrderNo.Contains(inboundOrderGetDTO.OrderNo); - } - int count = BaseDal.QueryData(x => x.OrderStatus == InOrderStatusEnum.鏈紑濮�.ObjToInt()).ToList().Count(); - int maxPage = Convert.ToInt32(Math.Ceiling(count / 10.0)); - if (inboundOrderGetDTO.pageNo <= maxPage) - { - var inboundOrder = BaseDal.Db.Queryable<Dt_InboundOrder>().Where(expressionOrder).OrderByDescending(x => x.CreateDate).Skip((inboundOrderGetDTO.pageNo - 1) * 10).Take(10).Select(x => new Dt_InboundOrder { OrderNo = x.OrderNo, Id = x.Id, CreateDate = x.CreateDate,Creater=x.Creater }).ToList(); - - content = WebResponseContent.Instance.OK(data: inboundOrder); - } - else - { - content = WebResponseContent.Instance.OK(data: null, message: "宸插埌鏈�鍚庝竴椤�"); - } - } - catch (Exception ex) - { - content = WebResponseContent.Instance.Error($"鏌ヨ鍏ュ簱鍗曟嵁閿欒,閿欒淇℃伅:{ex.Message}"); - } - - return content; - } - - public WebResponseContent GetInboundOrderDetail(string OrderNo) - { - WebResponseContent content = new WebResponseContent(); - try - { - Dt_InboundOrder inboundOrder = BaseDal.QueryFirst(x => x.OrderNo==OrderNo); - - var inboundOrderDetail = BaseDal.Db.Queryable<Dt_InboundOrderDetail>().Where(x=>x.OrderId==inboundOrder.Id).Take(10).Select(x => new Dt_InboundOrderDetail { MaterielCode = x.MaterielCode, MaterielName = x.MaterielName, OrderQuantity = x.OrderQuantity, ReceiptQuantity = x.ReceiptQuantity, OverInQuantity=x.OverInQuantity }).ToList(); - - content = WebResponseContent.Instance.OK(data: inboundOrderDetail); - } - catch (Exception ex) - { - content = WebResponseContent.Instance.Error($"鏌ヨ鍏ュ簱鍗曟嵁鏄庣粏閿欒,閿欒淇℃伅:{ex.Message}"); - } - return content; - } - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrder_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrder_HtyService.cs" deleted file mode 100644 index 794761b..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Base/InboundOrder_HtyService.cs" +++ /dev/null @@ -1,36 +0,0 @@ -锘縰sing AutoMapper; -using SqlSugar; -using System; -using System.Collections.Generic; -using System.Linq; -using System.Reflection.Metadata; -using System.Text; -using System.Threading.Tasks; -using WIDESEA_Core; -using WIDESEA_Core.BaseRepository; -using WIDESEA_Core.BaseServices; -using WIDESEA_Core.Enums; -using WIDESEA_Core.Helper; -using WIDESEA_Core.Utilities; -using WIDESEA_DTO; -using WIDESEA_DTO.Inbound; -using WIDESEA_IBasicService; -using WIDESEA_IInboundRepository; -using WIDESEA_IInboundService; -using WIDESEA_IStockService; -using WIDESEA_ITaskInfoRepository; -using WIDESEA_Model.Models; - -namespace WIDESEA_InboundService -{ - public partial class InboundOrder_HtyService : ServiceBase<Dt_InboundOrder_Hty, IInboundOrder_HtyRepository>, IInboundOrder_HtyService - { - - - public InboundOrder_HtyService(IInboundOrder_HtyRepository BaseDal) : base(BaseDal) - { - - } - - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderDetailService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderDetailService.cs" new file mode 100644 index 0000000..872ffa9 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderDetailService.cs" @@ -0,0 +1,23 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Enums; +using WIDESEA_Core.Helper; +using WIDESEA_IInboundRepository; +using WIDESEA_IInboundService; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundService +{ + public class InboundOrderDetailService : ServiceBase<Dt_InboundOrderDetail, IInboundOrderDetailRepository>, IInboundOrderDetailService + { + public IInboundOrderDetailRepository Repository => BaseDal; + + public InboundOrderDetailService(IInboundOrderDetailRepository BaseDal) : base(BaseDal) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderDetail_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderDetail_HtyService.cs" new file mode 100644 index 0000000..366c165 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderDetail_HtyService.cs" @@ -0,0 +1,23 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Enums; +using WIDESEA_Core.Helper; +using WIDESEA_IInboundRepository; +using WIDESEA_IInboundService; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundService +{ + public class InboundOrderDetail_HtyService : ServiceBase<Dt_InboundOrderDetail_Hty, IInboundOrderDetail_HtyRepository>, IInboundOrderDetail_HtyService + { + public IInboundOrderDetail_HtyRepository Repository => BaseDal; + + public InboundOrderDetail_HtyService(IInboundOrderDetail_HtyRepository BaseDal) : base(BaseDal) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderService.cs" new file mode 100644 index 0000000..faedbcf --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderService.cs" @@ -0,0 +1,285 @@ +锘縰sing AutoMapper; +using HslCommunication.WebSocket; +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Linq.Expressions; +using System.Reflection.Metadata; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Common.CommonEnum; +using WIDESEA_Common.OrderEnum; +using WIDESEA_Common.StockEnum; +using WIDESEA_Core; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.CodeConfigEnum; +using WIDESEA_Core.Enums; +using WIDESEA_Core.Helper; +using WIDESEA_Core.Utilities; +using WIDESEA_DTO; +using WIDESEA_DTO.Basic; +using WIDESEA_DTO.Inbound; +using WIDESEA_IBasicRepository; +using WIDESEA_IBasicService; +using WIDESEA_IInboundRepository; +using WIDESEA_IInboundService; +using WIDESEA_IRecordService; +using WIDESEA_IStockRepository; +using WIDESEA_IStockService; +using WIDESEA_ITaskInfoRepository; +using WIDESEA_Model.Models; +using WIDESEA_StockRepository; + +namespace WIDESEA_InboundService +{ + public class InboundOrderService : ServiceBase<Dt_InboundOrder, IInboundOrderRepository>, IInboundOrderService + { + private readonly IMapper _mapper; + private readonly IUnitOfWorkManage _unitOfWorkManage; + private readonly IInboundRepository _inboundRepository; + private readonly IBasicRepository _basicRepository; + private readonly IStockRepository _stockRepository; + private readonly IRecordService _recordService; + + public IInboundOrderRepository Repository => BaseDal; + + public InboundOrderService(IInboundOrderRepository BaseDal, IMapper mapper, IUnitOfWorkManage unitOfWorkManage, IInboundRepository inboundRepository, IBasicRepository basicRepository, IStockRepository stockRepository, IRecordService recordService) : base(BaseDal) + { + _mapper = mapper; + _unitOfWorkManage = unitOfWorkManage; + _inboundRepository = inboundRepository; + _basicRepository = basicRepository; + _stockRepository = stockRepository; + _recordService = recordService; + } + + public WebResponseContent MaterielGroup(int inboundOrderId, string palletCode, string serNum) + { + try + { + Dt_InboundOrder inboundOrder = BaseDal.Db.Queryable<Dt_InboundOrder>().Where(x => x.Id == inboundOrderId).Includes(x => x.Details).First(); + if (inboundOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒板叆搴撳崟淇℃伅"); + } + if (inboundOrder.Details == null || inboundOrder.Details.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒板叆搴撳崟鏄庣粏淇℃伅"); + } + + Dt_ReceiveOrder receiveOrder = _inboundRepository.ReceiveOrderRepository.Db.Queryable<Dt_ReceiveOrder>().Where(x => x.ReceiveOrderNo == inboundOrder.UpperOrderNo).Includes(x => x.Details).First(); + if (receiveOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒板搴旂殑鏀惰揣鍗�"); + } + if (receiveOrder.Details == null || receiveOrder.Details.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒板搴旂殑鏀惰揣鍗曟槑缁�"); + } + + List<string> purchaseOrderNos = receiveOrder.Details.Select(x => x.PurchaseOrderNo).ToList(); + + MatSerNumAnalysisModel model = CodeAnalysisHelper.CodeAnalysis<MatSerNumAnalysisModel>(AnalysisCodeEnum.MatSerNumAnalysis, serNum); + + List<Dt_InboundOrderDetail> inboundOrderDetails = inboundOrder.Details.Where(x => x.MaterielCode == model.MaterielCode).ToList(); + + if (inboundOrderDetails == null || inboundOrderDetails.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈湪鍏ュ簱鍗曟槑缁嗕腑鎵惧埌璇ョ墿鏂欎俊鎭�"); + } + if (receiveOrder.Details.FirstOrDefault(x => x.MaterielCode == model.MaterielCode) == null) + { + return WebResponseContent.Instance.Error($"鏈湪鏀惰揣鍗曟槑缁嗕腑鎵惧埌璇ョ墿鏂欎俊鎭�"); + } + if (purchaseOrderNos.FirstOrDefault(x => x == model.PurchaseOrderNo) == null) + { + return WebResponseContent.Instance.Error($"鏈湪鏀惰揣鍗曟槑缁嗕腑鎵惧埌璇ラ噰璐崟"); + } + + Dt_InboundOrderDetail? notGroupDetail = inboundOrderDetails.Where(x => x.OrderDetailStatus == OrderDetailStatusEnum.New.ObjToInt() && x.OrderQuantity == model.Quantity).FirstOrDefault(); + + if (notGroupDetail == null) + { + return WebResponseContent.Instance.Error($"璇ョ墿鏂欏湪璇ュ叆搴撳崟涓凡鍏ㄩ儴缁勭洏瀹屾垚"); + } + + Dt_MaterielInfo materielInfo = _basicRepository.MaterielInfoRepository.QueryFirst(x => x.MaterielCode == model.MaterielCode); + if (materielInfo == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌鐗╂枡鐨勪俊鎭�"); + } + + Dt_StockInfo stockInfo = new Dt_StockInfo() + { + PalletCode = palletCode, + StockStatus = StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt(), + WarehouseId = inboundOrder.WarehouseId + }; + + Dt_StockInfoDetail stockInfoDetail = new Dt_StockInfoDetail() + { + BatchNo = model.LotNo, + MaterielCode = materielInfo.MaterielCode, + MaterielName = materielInfo.MaterielName, + OrderNo = inboundOrder.InboundOrderNo, + SerialNumber = model.SerialNumber, + StockQuantity = model.Quantity, + OutboundQuantity = 0, + Status = StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt() + }; + + _stockRepository.StockInfoRepository.Db.InsertNav(stockInfo).Include(x => x.Details).ExecuteCommand(); + _inboundRepository.InboundOrderDetailRepository.UpdateData(inboundOrderDetails); + + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + return WebResponseContent.Instance.Error(ex.Message); + } + } + + public WebResponseContent MaterielGroup(int inboundOrderId, string palletCode, List<string> serNums) + { + try + { + Dt_InboundOrder inboundOrder = BaseDal.Db.Queryable<Dt_InboundOrder>().Where(x => x.Id == inboundOrderId).Includes(x => x.Details).First(); + if (inboundOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒板叆搴撳崟淇℃伅"); + } + if (inboundOrder.Details == null || inboundOrder.Details.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒板叆搴撳崟鏄庣粏淇℃伅"); + } + + Dt_ReceiveOrder receiveOrder = _inboundRepository.ReceiveOrderRepository.Db.Queryable<Dt_ReceiveOrder>().Where(x => x.ReceiveOrderNo == inboundOrder.UpperOrderNo).Includes(x => x.Details).First(); + if (receiveOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒板搴旂殑鏀惰揣鍗�"); + } + if (receiveOrder.Details == null || receiveOrder.Details.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒板搴旂殑鏀惰揣鍗曟槑缁�"); + } + + List<string> purchaseOrderNos = receiveOrder.Details.Select(x => x.PurchaseOrderNo).ToList(); + + List<MatSerNumAnalysisModel> models = CodeAnalysisHelper.CodeAnalysis<MatSerNumAnalysisModel>(AnalysisCodeEnum.MatSerNumAnalysis, serNums); + + if (models.Select(x => x.MaterielCode).Distinct().Count() > 1) + { + return WebResponseContent.Instance.Error($"鐗╂枡涓嶅彲娣锋斁"); + } + + string materielCode = models.FirstOrDefault()?.MaterielCode ?? ""; + Dt_MaterielInfo materielInfo = _basicRepository.MaterielInfoRepository.QueryFirst(x => x.MaterielCode == materielCode); + if (materielInfo == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌鐗╂枡鐨勪俊鎭�"); + } + + List<Dt_InboundOrderDetail> inboundOrderDetails = inboundOrder.Details.Where(x => x.MaterielCode == materielCode).ToList(); + + if (inboundOrderDetails == null || inboundOrderDetails.Count <= 0) + { + return WebResponseContent.Instance.Error($"鏈湪鍏ュ簱鍗曟槑缁嗕腑鎵惧埌璇ョ墿鏂欎俊鎭�"); + } + if (receiveOrder.Details.FirstOrDefault(x => x.MaterielCode == materielCode) == null) + { + return WebResponseContent.Instance.Error($"鏈湪鏀惰揣鍗曟槑缁嗕腑鎵惧埌璇ョ墿鏂欎俊鎭�"); + } + + float beforeQuantity = 0; + + Dt_StockInfo stockInfo = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Where(x => x.PalletCode == palletCode).Includes(x => x.Details).First(); + if (stockInfo == null) + { + stockInfo = new Dt_StockInfo() + { + PalletCode = palletCode, + StockStatus = StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt(), + WarehouseId = inboundOrder.WarehouseId, + PalletType = PalletTypeEnum.SmallPallet.ObjToInt(), + Details = new List<Dt_StockInfoDetail>() + }; + } + else + { + if (stockInfo.StockStatus != StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt()) + { + return WebResponseContent.Instance.Error($"鎵樼洏鍙烽噸澶�"); + } + beforeQuantity = stockInfo.Details.Sum(x => x.StockQuantity); + } + + List<Dt_StockInfoDetail> stockInfoDetails = new List<Dt_StockInfoDetail>(); + List<int> detailKeys = new List<int>(); + foreach (var model in models) + { + if (purchaseOrderNos.FirstOrDefault(x => x == model.PurchaseOrderNo) == null) + { + return WebResponseContent.Instance.Error($"鏈湪鏀惰揣鍗曟槑缁嗕腑鎵惧埌璇ラ噰璐崟"); + } + + Dt_InboundOrderDetail? notGroupDetail = inboundOrderDetails.Where(x => x.OrderDetailStatus == OrderDetailStatusEnum.New.ObjToInt() && x.OrderQuantity == model.Quantity && !detailKeys.Contains(x.Id) && x.OrderQuantity > x.ReceiptQuantity).FirstOrDefault(); + + if (notGroupDetail == null) + { + return WebResponseContent.Instance.Error($"璇ョ墿鏂欏湪璇ュ叆搴撳崟涓凡鍏ㄩ儴缁勭洏瀹屾垚"); + } + detailKeys.Add(notGroupDetail.Id); + Dt_StockInfoDetail stockInfoDetail = new Dt_StockInfoDetail() + { + BatchNo = model.LotNo, + MaterielCode = materielInfo.MaterielCode, + MaterielName = materielInfo.MaterielName, + OrderNo = inboundOrder.InboundOrderNo, + SerialNumber = model.SerialNumber, + StockQuantity = model.Quantity, + OutboundQuantity = 0, + Status = StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt() + }; + + if (stockInfo.Id > 0) + { + stockInfoDetail.StockId = stockInfo.Id; + } + stockInfo.Details.Add(stockInfoDetail); + + stockInfoDetails.Add(stockInfoDetail); + + notGroupDetail.ReceiptQuantity = model.Quantity; + notGroupDetail.OrderDetailStatus = OrderDetailStatusEnum.GroupAndInbound.ObjToInt(); + } + + float totalQuantity = stockInfo.Details.Sum(x => x.StockQuantity); + + inboundOrder.OrderStatus = InOrderStatusEnum.鍏ュ簱涓�.ObjToInt(); + + _unitOfWorkManage.BeginTran(); + if (stockInfo.Id == 0) + { + _stockRepository.StockInfoRepository.Db.InsertNav(stockInfo).Include(x => x.Details).ExecuteCommand(); + } + else + { + _stockRepository.StockInfoRepository.Db.UpdateNav(stockInfo).Include(x => x.Details, new UpdateNavOptions() { OneToManyInsertOrUpdate = true }).ExecuteCommand(); + } + _inboundRepository.InboundOrderDetailRepository.UpdateData(inboundOrderDetails); + _inboundRepository.InboundOrderRepository.UpdateData(inboundOrder); + _recordService.StockQuantityChangeRecordService.AddStockChangeRecord(stockInfo, stockInfoDetails, beforeQuantity, totalQuantity, StockChangeTypeEnum.MaterielGroup); + _unitOfWorkManage.CommitTran(); + + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrder_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrder_HtyService.cs" new file mode 100644 index 0000000..939e975 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrder_HtyService.cs" @@ -0,0 +1,36 @@ +锘縰sing AutoMapper; +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Reflection.Metadata; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Enums; +using WIDESEA_Core.Helper; +using WIDESEA_Core.Utilities; +using WIDESEA_DTO; +using WIDESEA_DTO.Inbound; +using WIDESEA_IBasicService; +using WIDESEA_IInboundRepository; +using WIDESEA_IInboundService; +using WIDESEA_IStockService; +using WIDESEA_ITaskInfoRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundService +{ + public class InboundOrder_HtyService : ServiceBase<Dt_InboundOrder_Hty, IInboundOrder_HtyRepository>, IInboundOrder_HtyService + { + + + public InboundOrder_HtyService(IInboundOrder_HtyRepository BaseDal) : base(BaseDal) + { + + } + + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundService.cs" index 97a2766..7936dcd 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/InboundService.cs" @@ -3,6 +3,7 @@ using System.Linq; using System.Text; using System.Threading.Tasks; +using WIDESEA_IInboundRepository; using WIDESEA_IInboundService; namespace WIDESEA_InboundService @@ -13,10 +14,16 @@ public IInboundOrderService InbounOrderService { get; } - public InboundService(IInboundOrderDetailService inboundOrderDetailService, IInboundOrderService inbounOrderService) + public IReceiveOrderDetailService ReceiveOrderDetailService { get; } + + public IReceiveOrderService ReceiveOrderService { get; } + + public InboundService(IInboundOrderDetailService inboundOrderDetailService, IInboundOrderService inbounOrderService, IReceiveOrderDetailService receiveOrderDetailService, IReceiveOrderService receiveOrderService) { InboundOrderDetailService = inboundOrderDetailService; InbounOrderService = inbounOrderService; + ReceiveOrderDetailService = receiveOrderDetailService; + ReceiveOrderService = receiveOrderService; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/PurchaseOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/PurchaseOrderService.cs" new file mode 100644 index 0000000..4262788 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/PurchaseOrderService.cs" @@ -0,0 +1,228 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Common.OrderEnum; +using WIDESEA_Core; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Enums; +using WIDESEA_Core.Helper; +using WIDESEA_DTO; +using WIDESEA_IInboundRepository; +using WIDESEA_IInboundService; +using WIDESEA_InboundRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundService +{ + public class PurchaseOrderService : ServiceBase<Dt_PurchaseOrder, IPurchaseOrderRepository>, IPurchaseOrderService + { + private readonly IUnitOfWorkManage _unitOfWorkManage; + private readonly IPurchaseOrderDetailRepository _purchaseOrderDetailRepository; + + public PurchaseOrderService(IPurchaseOrderRepository BaseDal, IPurchaseOrderDetailRepository purchaseOrderDetailRepository, IUnitOfWorkManage unitOfWorkManage) : base(BaseDal) + { + _purchaseOrderDetailRepository = purchaseOrderDetailRepository; + _unitOfWorkManage = unitOfWorkManage; + } + + public WebResponseContent ReceivePurchaseOrderSingle(PurchaseOrderModel model) + { + try + { + switch (model.Way) + { + case 1: + return AddPurchaseOrder(model); + case 2: + return UpdatePurchaseOrder(model); + case 3: + return DeletePurchaseOrder(model); + case 4: + return ClosePurchaseOrder(model); + } + + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + return WebResponseContent.Instance.Error(ex.Message); + } + } + + public WebResponseContent AddPurchaseOrder(PurchaseOrderModel model) + { + try + { + if (BaseDal.QueryFirst(x => x.PurchaseOrderNo == model.OrderNo) != null) + { + return WebResponseContent.Instance.Error($"閲囪喘鍗曞彿閲嶅"); + } + + List<Dt_PurchaseOrderDetail> purchaseOrderDetails = new List<Dt_PurchaseOrderDetail>(); + foreach (var item in model.MList) + { + Dt_PurchaseOrderDetail purchaseOrderDetail = new Dt_PurchaseOrderDetail() + { + MaterielCode = item.MCode, + PurchaseDetailQuantity = item.Qty, + PurchaseDetailStatus = PurchaseOrderDetailStatusEnum.NotReceived.ObjToInt(), + Unit = item.Unit, + WarehouseId = item.WaId, + RowNo = item.RowId, + }; + purchaseOrderDetails.Add(purchaseOrderDetail); + } + + Dt_PurchaseOrder purchaseOrder = new Dt_PurchaseOrder() + { + OrderQuantity = model.Amount, + OrderDate = model.OrderDate, + PurchaseOrderNo = model.OrderNo, + PurchaseOrderStatus = PurchaseOrderStatusEnum.NotReceived.ObjToInt(), + PurchaseOrderType = model.Type, + SupplierCode = model.SCode, + Details = purchaseOrderDetails + }; + + Db.InsertNav(purchaseOrder).Include(x => x.Details).ExecuteCommand(); + + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + return WebResponseContent.Instance.Error(ex.Message); + } + } + + public WebResponseContent UpdatePurchaseOrder(PurchaseOrderModel model) + { + try + { + Dt_PurchaseOrder purchaseOrder = Db.Queryable<Dt_PurchaseOrder>().First(x => x.PurchaseOrderNo == model.OrderNo); + if (purchaseOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒伴噰璐崟淇℃伅"); + } + if (purchaseOrder.Details == null || purchaseOrder.Details.Count == 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒伴噰璐崟鏄庣粏淇℃伅"); + } + + List<Dt_PurchaseOrderDetail> purchaseOrderDetails = new List<Dt_PurchaseOrderDetail>(); + List<Dt_PurchaseOrderDetail> updatePurchaseOrderDetails = new List<Dt_PurchaseOrderDetail>(); + List<int> detailIds = new List<int>(); + foreach (var item in model.MList) + { + Dt_PurchaseOrderDetail? purchaseOrderDetail = purchaseOrder.Details.FirstOrDefault(x => x.RowNo == item.RowId); + if (purchaseOrderDetail == null) + { + purchaseOrderDetail = new Dt_PurchaseOrderDetail() + { + MaterielCode = item.MCode, + PurchaseDetailQuantity = item.Qty, + PurchaseDetailStatus = PurchaseOrderDetailStatusEnum.NotReceived.ObjToInt(), + Unit = item.Unit, + WarehouseId = item.WaId, + RowNo = item.RowId, + }; + purchaseOrderDetails.Add(purchaseOrderDetail); + } + else + { + purchaseOrderDetail.MaterielCode = item.MCode; + purchaseOrderDetail.PurchaseDetailQuantity = item.Qty; + purchaseOrderDetail.PurchaseDetailStatus = PurchaseOrderDetailStatusEnum.NotReceived.ObjToInt(); + purchaseOrderDetail.Unit = item.Unit; + purchaseOrderDetail.WarehouseId = item.WaId; + purchaseOrderDetail.RowNo = item.RowId; + updatePurchaseOrderDetails.Add(purchaseOrderDetail); + detailIds.Add(purchaseOrderDetail.Id); + } + } + + purchaseOrder.OrderQuantity = model.Amount; + purchaseOrder.OrderDate = model.OrderDate; + purchaseOrder.PurchaseOrderNo = model.OrderNo; + purchaseOrder.PurchaseOrderStatus = PurchaseOrderStatusEnum.NotReceived.ObjToInt(); + purchaseOrder.PurchaseOrderType = model.Type; + purchaseOrder.SupplierCode = model.SCode; + + List<Dt_PurchaseOrderDetail> deletePurchaseOrderDetails = purchaseOrder.Details.Where(x => !detailIds.Contains(x.Id)).ToList(); + + _unitOfWorkManage.BeginTran(); + foreach (var item in deletePurchaseOrderDetails) + { + _purchaseOrderDetailRepository.DeleteAndMoveIntoHty(item, OperateTypeEnum.浜哄伐鍒犻櫎); + } + + _purchaseOrderDetailRepository.UpdateData(updatePurchaseOrderDetails); + _purchaseOrderDetailRepository.AddData(purchaseOrderDetails); + + BaseDal.UpdateData(purchaseOrder); + _unitOfWorkManage.CommitTran(); + + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } + + public WebResponseContent DeletePurchaseOrder(PurchaseOrderModel model) + { + try + { + Dt_PurchaseOrder purchaseOrder = Db.Queryable<Dt_PurchaseOrder>().First(x => x.PurchaseOrderNo == model.OrderNo); + if (purchaseOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒伴噰璐崟淇℃伅"); + } + if (purchaseOrder.Details == null || purchaseOrder.Details.Count == 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒伴噰璐崟鏄庣粏淇℃伅"); + } + Db.DeleteNav(purchaseOrder).Include(x => x.Details).ExecuteCommand(); + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + return WebResponseContent.Instance.Error(ex.Message); + } + } + + public WebResponseContent ClosePurchaseOrder(PurchaseOrderModel model) + { + try + { + Dt_PurchaseOrder purchaseOrder = Db.Queryable<Dt_PurchaseOrder>().First(x => x.PurchaseOrderNo == model.OrderNo); + if (purchaseOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒伴噰璐崟淇℃伅"); + } + if (purchaseOrder.Details == null || purchaseOrder.Details.Count == 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒伴噰璐崟鏄庣粏淇℃伅"); + } + + _unitOfWorkManage.BeginTran(); + BaseDal.DeleteAndMoveIntoHty(purchaseOrder, OperateTypeEnum.鍏抽棴); + foreach (var item in purchaseOrder.Details) + { + _purchaseOrderDetailRepository.DeleteAndMoveIntoHty(item, OperateTypeEnum.鍏抽棴); + } + _unitOfWorkManage.CommitTran(); + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/ReceiveOrderDetailService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/ReceiveOrderDetailService.cs" new file mode 100644 index 0000000..d29ac01 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/ReceiveOrderDetailService.cs" @@ -0,0 +1,159 @@ +锘� +using AutoMapper; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Common.OrderEnum; +using WIDESEA_Core; +using WIDESEA_Core.BaseRepository; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.CodeConfigEnum; +using WIDESEA_Core.Helper; +using WIDESEA_DTO.Basic; +using WIDESEA_IBasicRepository; +using WIDESEA_ICheckRepository; +using WIDESEA_IInboundRepository; +using WIDESEA_IInboundService; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundService +{ + public class ReceiveOrderDetailService : ServiceBase<Dt_ReceiveOrderDetail, IReceiveOrderDetailRepository>, IReceiveOrderDetailService + { + private readonly IMapper _mapper; + private readonly IUnitOfWorkManage _unitOfWorkManage; + private readonly IInboundRepository _inboundRepository; + private readonly IBasicRepository _basicRepository; + private readonly ICheckOrderRepository _checkOrderRepository; + + public ReceiveOrderDetailService(IReceiveOrderDetailRepository BaseDal, IMapper mapper, IUnitOfWorkManage unitOfWorkManage, IInboundRepository inboundRepository, IBasicRepository basicRepository, ICheckOrderRepository checkOrderRepository) : base(BaseDal) + { + _mapper = mapper; + _unitOfWorkManage = unitOfWorkManage; + _inboundRepository = inboundRepository; + _basicRepository = basicRepository; + _checkOrderRepository = checkOrderRepository; + } + + private static object _rowNoLocker = new object(); + public WebResponseContent AddReceiveOrderDetail(string serNum, string orderNo) + { + try + { + Dt_ReceiveOrder receiveOrder = _inboundRepository.ReceiveOrderRepository.QueryFirst(x => x.ReceiveOrderNo == orderNo); + if (receiveOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌鏀惰揣鍗�"); + } + + if (receiveOrder.ReceiveOrderStatus == ReceiveOrderStatusEnum.Completed.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ュ崟鎹凡鏀惰揣瀹屾垚"); + } + + MatSerNumAnalysisModel model = CodeAnalysisHelper.CodeAnalysis<MatSerNumAnalysisModel>(AnalysisCodeEnum.MatSerNumAnalysis, serNum); + + Dt_MaterielInfo materielInfo = _basicRepository.MaterielInfoRepository.QueryFirst(x => x.MaterielCode == model.MaterielCode); + if (materielInfo == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌鐗╂枡鐨勪俊鎭�"); + } + + Dt_PurchaseOrder purchaseOrder = _inboundRepository.PurchaseOrderRepository.QueryFirst(x => x.PurchaseOrderNo == model.PurchaseOrderNo); + if (purchaseOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌閲囪喘鍗�"); + } + + if (purchaseOrder.SupplierCode != receiveOrder.SuppliersId) + { + return WebResponseContent.Instance.Error($"渚涘簲鍟嗕笉涓�鑷�,璇锋柊寤烘敹璐у崟"); + } + + if (purchaseOrder.PurchaseOrderStatus == PurchaseOrderStatusEnum.Received.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ラ噰璐崟鏀惰揣宸插畬鎴�"); + } + + List<Dt_PurchaseOrderDetail> purchaseOrderDetails = _inboundRepository.PurchaseOrderDetailRepository.QueryData(x => x.PurchaseOrderId == purchaseOrder.Id); + if (purchaseOrderDetails == null || purchaseOrderDetails.Count == 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌閲囪喘鍗曟槑缁嗘暟鎹�"); + } + + Dt_PurchaseOrderDetail? purchaseOrderDetail = purchaseOrderDetails.FirstOrDefault(x => x.PurchaseDetailQuantity == model.Quantity && x.MaterielCode == model.MaterielCode && x.PurchaseDetailStatus == PurchaseOrderDetailStatusEnum.NotReceived.ObjToInt()); + if (purchaseOrderDetail == null) + { + if (purchaseOrderDetails.Count > 0) + { + return WebResponseContent.Instance.Error($"璇ユ槑缁嗘敹璐у凡瀹屾垚"); + } + return WebResponseContent.Instance.Error($"鏈壘鍒板搴旂殑閲囪喘鍗曟槑缁嗘暟鎹�"); + } + Dt_ReceiveOrderDetail detail = BaseDal.QueryFirst(x => x.PurchaseOrderNo == model.PurchaseOrderNo && x.PurchaseOrderDetailRowNo == purchaseOrderDetail.RowNo); + if (detail != null) + { + return WebResponseContent.Instance.Error($"璇ユ槑缁嗘敹璐у凡瀹屾垚"); + } + + lock (_rowNoLocker) + { + int rowNo = 0; + List<Dt_ReceiveOrderDetail> receiveOrderDetails = BaseDal.QueryData(x => x.ReceiveOrderId == receiveOrder.ReceiveOrderId); + if (receiveOrderDetails != null && receiveOrderDetails.Count > 0) + { + rowNo = receiveOrderDetails.Max(x => x.RowNo); + } + + Dt_ReceiveOrderDetail receiveOrderDetail = new Dt_ReceiveOrderDetail() + { + PurchaseOrderNo = model.PurchaseOrderNo, + ReceivedQuantity = model.Quantity, + MaterielCode = model.MaterielCode, + LotNo = model.LotNo, + ReceiveOrderId = receiveOrder.ReceiveOrderId, + PurchaseOrderDetailRowNo = purchaseOrderDetail.RowNo, + IfInspection = materielInfo.IsCheck.ObjToInt(), + CurrCode = "", + PriceInTax = 0, + TaxRate = "", + RowNo = rowNo + 1, + Unit = purchaseOrderDetail.Unit + }; + + if (receiveOrder.ReceiveOrderStatus == ReceiveOrderStatusEnum.NotStarted.ObjToInt()) + { + receiveOrder.ReceiveOrderStatus = ReceiveOrderStatusEnum.Receiving.ObjToInt(); + } + purchaseOrderDetail.PurchaseDetailStatus = PurchaseOrderDetailStatusEnum.Received.ObjToInt(); + + _unitOfWorkManage.BeginTran(); + BaseDal.AddData(receiveOrderDetail); + _inboundRepository.ReceiveOrderRepository.UpdateData(receiveOrder); + _inboundRepository.PurchaseOrderDetailRepository.UpdateData(purchaseOrderDetail); + + if (materielInfo.IsCheck == WIDESEA_Common.CommonEnum.WhetherEnum.True) + { + Dt_CheckOrder checkOrder = _mapper.Map<Dt_CheckOrder>(receiveOrderDetail); + checkOrder.ReceiveOrderNo = receiveOrder.ReceiveOrderNo; + checkOrder.QualifiedQuantity = receiveOrderDetail.ReceivedQuantity; + checkOrder.ScrappedQuantity = 0; + checkOrder.ReturnQuantity = 0; + checkOrder.DefectedQuantity = 0; + _checkOrderRepository.AddData(checkOrder); + } + + _unitOfWorkManage.CommitTran(); + return WebResponseContent.Instance.OK(); + } + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/ReceiveOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/ReceiveOrderService.cs" new file mode 100644 index 0000000..9f09eff --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/ReceiveOrderService.cs" @@ -0,0 +1,143 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Common.CommonEnum; +using WIDESEA_Common.OrderEnum; +using WIDESEA_Core; +using WIDESEA_Core.BaseServices; +using WIDESEA_Core.Helper; +using WIDESEA_ICheckRepository; +using WIDESEA_IInboundRepository; +using WIDESEA_IInboundService; +using WIDESEA_Model.Models; + +namespace WIDESEA_InboundService +{ + public class ReceiveOrderService : ServiceBase<Dt_ReceiveOrder, IReceiveOrderRepository>, IReceiveOrderService + { + private readonly ICheckOrderRepository _checkOrderRepository; + private readonly IInboundRepository _inboundRepository; + + public ReceiveOrderService(IReceiveOrderRepository BaseDal, ICheckOrderRepository checkOrderRepository, IInboundRepository inboundRepository) : base(BaseDal) + { + _checkOrderRepository = checkOrderRepository; + _inboundRepository = inboundRepository; + } + + public override WebResponseContent AddData(SaveModel saveModel) + { + if (saveModel.MainData.ContainsKey(nameof(Dt_ReceiveOrder.ReceiveOrderStatus).FirstLetterToLower())) + { + saveModel.MainData[nameof(Dt_ReceiveOrder.ReceiveOrderStatus).FirstLetterToLower()] = ReceiveOrderStatusEnum.NotStarted.ObjToInt(); + } + else + { + saveModel.MainData.Add(nameof(Dt_ReceiveOrder.ReceiveOrderStatus).FirstLetterToLower(), ReceiveOrderStatusEnum.NotStarted.ObjToInt()); + } + if (saveModel.MainData.ContainsKey(nameof(Dt_ReceiveOrder.UploadStatus).FirstLetterToLower())) + { + saveModel.MainData[nameof(Dt_ReceiveOrder.UploadStatus).FirstLetterToLower()] = WhetherEnum.False.ObjToInt(); + } + else + { + saveModel.MainData.Add(nameof(Dt_ReceiveOrder.UploadStatus).FirstLetterToLower(), WhetherEnum.False.ObjToInt()); + } + if (saveModel.MainData.ContainsKey(nameof(Dt_ReceiveOrder.ReceiveDate).FirstLetterToLower())) + { + saveModel.MainData[nameof(Dt_ReceiveOrder.ReceiveDate).FirstLetterToLower()] = DateTime.Now; + } + else + { + saveModel.MainData.Add(nameof(Dt_ReceiveOrder.ReceiveDate).FirstLetterToLower(), DateTime.Now); + } + + if (saveModel.MainData.TryGetValue(nameof(Dt_ReceiveOrder.SuppliersId).FirstLetterToLower(), out object? suppliersId) && suppliersId != null && !string.IsNullOrEmpty(suppliersId.ToString())) + { + Dt_ReceiveOrder receiveOrder = BaseDal.QueryFirst(x => x.SuppliersId == suppliersId.ToString() && x.WarehouseId == Convert.ToInt32(saveModel.MainData[nameof(Dt_ReceiveOrder.WarehouseId).FirstLetterToLower()])); + if (receiveOrder != null && receiveOrder.ReceiveOrderStatus != ReceiveOrderStatusEnum.Completed.ObjToInt()) + { + return WebResponseContent.Instance.Error("璇ヤ緵搴斿晢鏈夋湭瀹屾垚鐨勬敹璐у崟"); + } + } + + return base.AddData(saveModel); + } + + public WebResponseContent CreateInboundOrder(int receiveOrderId) + { + try + { + Dt_ReceiveOrder receiveOrder = Db.Queryable<Dt_ReceiveOrder>().Where(x => x.ReceiveOrderId == receiveOrderId).Includes(x => x.Details).First(); + if (receiveOrder == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌鏀惰揣鍗曚俊鎭�"); + } + if (receiveOrder.Details == null || receiveOrder.Details.Count() <= 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌鏀惰揣鍗曟槑缁嗕俊鎭�"); + } + if (receiveOrder.ReceiveOrderStatus != ReceiveOrderStatusEnum.Completed.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ユ敹璐у崟鏈畬鎴�"); + } + + List<Dt_CheckOrder> checkOrders = _checkOrderRepository.QueryData(x => x.ReceiveOrderNo == receiveOrder.ReceiveOrderNo); + if (checkOrders.FirstOrDefault(x => x.CheckOrderStatus == CheckOrderStatusEnum.NotCheck.ObjToInt()) != null) + { + return WebResponseContent.Instance.Error($"璇ユ敹璐у崟鏈川妫�瀹屾垚"); + } + + if (checkOrders.FirstOrDefault(x => x.AuditStatus != AuditStatusEnum.Agree.ObjToInt()) != null) + { + return WebResponseContent.Instance.Error($"璇ユ敹璐у崟璐ㄦ缁撴灉瀹℃壒鏈畬鎴�"); + } + + Dt_InboundOrder inboundOrder = new Dt_InboundOrder() + { + UpperOrderNo = receiveOrder.ReceiveOrderNo, + CreateType = OrderCreateTypeEnum.UpperSystemPush.ObjToInt(), + OrderStatus = InOrderStatusEnum.鏈紑濮�.ObjToInt(), + OrderType = InOrderTypeEnum.Purchase.ObjToInt(), + WarehouseId = receiveOrder.WarehouseId, + SupplierId = receiveOrder.SuppliersId, + Details = new List<Dt_InboundOrderDetail>() + }; + + foreach (var item in receiveOrder.Details) + { + float quantity = item.ReceivedQuantity; + if (item.IfInspection == WhetherEnum.True.ObjToInt()) + { + Dt_CheckOrder? checkOrder = checkOrders.FirstOrDefault(x => x.ReceiveOrderNo == receiveOrder.ReceiveOrderNo && x.ReceiveDetailRowNo == item.RowNo); + if (checkOrder == null) + { + return WebResponseContent.Instance.Error($"璐ㄦ鍗曟暟鎹敊璇�"); + } + quantity = checkOrder.QualifiedQuantity.GetValueOrDefault() + checkOrder.DefectedQuantity.GetValueOrDefault(); + } + Dt_InboundOrderDetail detail = new Dt_InboundOrderDetail() + { + MaterielCode = item.MaterielCode, + OrderDetailStatus = OrderDetailStatusEnum.New.ObjToInt(), + OrderQuantity = quantity, + OverInQuantity = 0, + ReceiptQuantity = 0, + RowNo = item.RowNo, + Unit = item.Unit + }; + inboundOrder.Details.Add(detail); + } + + _inboundRepository.InboundOrderRepository.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); + + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + return WebResponseContent.Instance.Error(ex.Message); + } + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Service/InboundOrderDetailService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Service/InboundOrderDetailService.cs" deleted file mode 100644 index 78a36ab..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Service/InboundOrderDetailService.cs" +++ /dev/null @@ -1,53 +0,0 @@ -锘縰sing System; -using System.Collections.Generic; -using System.Linq; -using System.Text; -using System.Threading.Tasks; -using WIDESEA_Common.OrderEnum; -using WIDESEA_Core.BaseServices; -using WIDESEA_Core.Enums; -using WIDESEA_Core.Helper; -using WIDESEA_IInboundRepository; -using WIDESEA_IInboundService; -using WIDESEA_Model.Models; - -namespace WIDESEA_InboundService -{ - public partial class InboundOrderDetailService : ServiceBase<Dt_InboundOrderDetail, IInboundOrderDetailRepository>, IInboundOrderDetailService - { - - public List<Dt_InboundOrderDetail> UpdateReceiptQuantity(List<Dt_InboundOrderDetail> inboundOrderDetails, decimal receiptQuantity) - { - List<Dt_InboundOrderDetail> orderDetails = inboundOrderDetails.Where(x => x.ReceiptQuantity < x.OrderQuantity).ToList(); - List<Dt_InboundOrderDetail> updateOrderDetails = new List<Dt_InboundOrderDetail>(); - decimal quantity = receiptQuantity; - for (int i = 0; i < orderDetails.Count; i++) - { - if (quantity > 0) - { - decimal residue = orderDetails[i].OrderQuantity - orderDetails[i].ReceiptQuantity; - if (residue < quantity) - { - orderDetails[i].ReceiptQuantity = orderDetails[i].OrderQuantity; - orderDetails[i].OrderDetailStatus = OrderDetailStatusEnum.Over.ObjToInt(); - quantity -= residue; - } - else - { - orderDetails[i].ReceiptQuantity += quantity; - if (quantity == residue) - orderDetails[i].OrderDetailStatus = OrderDetailStatusEnum.Over.ObjToInt(); - quantity = 0; - } - updateOrderDetails.Add(orderDetails[i]); - } - } - return (updateOrderDetails); - } - - public void UpdateOverInQuantity(List<Dt_InboundOrderDetail> inboundOrderDetails, decimal overInQuantity) - { - - } - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Service/InboundOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Service/InboundOrderService.cs" deleted file mode 100644 index 2a7df83..0000000 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/Service/InboundOrderService.cs" +++ /dev/null @@ -1,30 +0,0 @@ -锘縰sing AutoMapper; -using SqlSugar; -using System; -using System.Collections.Generic; -using System.Linq; -using System.Reflection.Metadata; -using System.Text; -using System.Threading.Tasks; -using WIDESEA_Core; -using WIDESEA_Core.BaseRepository; -using WIDESEA_Core.BaseServices; -using WIDESEA_Core.Enums; -using WIDESEA_Core.Helper; -using WIDESEA_Core.Utilities; -using WIDESEA_DTO; -using WIDESEA_DTO.Inbound; -using WIDESEA_IBasicService; -using WIDESEA_IInboundRepository; -using WIDESEA_IInboundService; -using WIDESEA_IStockService; -using WIDESEA_ITaskInfoRepository; -using WIDESEA_Model.Models; - -namespace WIDESEA_InboundService -{ - public partial class InboundOrderService : ServiceBase<Dt_InboundOrder, IInboundOrderRepository>, IInboundOrderService - { - - } -} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/WIDESEA_InboundService.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/WIDESEA_InboundService.csproj" index 61191b5..7cc354c 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/WIDESEA_InboundService.csproj" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_InboundService/WIDESEA_InboundService.csproj" @@ -8,7 +8,9 @@ <ItemGroup> <ProjectReference Include="..\WIDESEA_IBasicService\WIDESEA_IBasicService.csproj" /> + <ProjectReference Include="..\WIDESEA_ICheckRepository\WIDESEA_ICheckRepository.csproj" /> <ProjectReference Include="..\WIDESEA_IInboundService\WIDESEA_IInboundService.csproj" /> + <ProjectReference Include="..\WIDESEA_IRecordService\WIDESEA_IRecordService.csproj" /> <ProjectReference Include="..\WIDESEA_IStockService\WIDESEA_IStockService.csproj" /> <ProjectReference Include="..\WIDESEA_ITaskInfoRepository\WIDESEA_ITaskInfoRepository.csproj" /> </ItemGroup> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalFlow.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalFlow.cs" new file mode 100644 index 0000000..b69f057 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalFlow.cs" @@ -0,0 +1,26 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_ApprovalFlow), "瀹℃壒娴佺▼琛�")] + public class Dt_ApprovalFlow : BaseEntity + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "瀹℃壒娴佺▼缂栧彿锛屼富閿�")] + public int Id { get; set; } + + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "瀹℃壒娴佺▼缂栧彿")] + public string FlowCode { get; set; } + + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "瀹℃壒娴佺▼鍚嶇О")] + public string FlowName { get; set; } + + [SugarColumn(IsNullable = true, Length = 200, ColumnDescription = "瀹℃壒娴佺▼鎻忚堪")] + public string FlowDes { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalNode.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalNode.cs" new file mode 100644 index 0000000..03ae7f3 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalNode.cs" @@ -0,0 +1,32 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_ApprovalNode), "瀹℃壒鑺傜偣琛�")] + public class Dt_ApprovalNode : BaseEntity + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "瀹℃壒鑺傜偣缂栧彿锛屼富閿�")] + public int Id { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "瀹℃壒娴佺▼缂栧彿锛屽閿�")] + public int FlowId { get; set; } + + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "瀹℃壒鑺傜偣鍚嶇О")] + public string NodeName { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "鑺傜偣绫诲瀷锛堝鍗曚汉瀹℃壒銆佸浜哄鎵广�佷細绛剧瓑锛�")] + public int NodeType { get; set; } + + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "瀹℃壒浜鸿鑹诧紙濡傞儴闂ㄧ粡鐞嗐�佹�荤粡鐞嗙瓑锛�")] + public int ApproverRole { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "鑺傜偣椤哄簭")] + public int NodeSequence { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalTask.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalTask.cs" new file mode 100644 index 0000000..45ae9e2 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_ApprovalTask.cs" @@ -0,0 +1,68 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_ApprovalTask), "瀹℃壒浠诲姟琛�")] + public class Dt_ApprovalTask : BaseEntity + { + /// <summary> + /// 瀹℃壒浠诲姟缂栧彿锛屼富閿� + /// </summary> + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "瀹℃壒浠诲姟缂栧彿锛屼富閿�")] + public int Id { get; set; } + + /// <summary> + /// 瀹℃壒娴佺▼缂栧彿锛屽閿� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "瀹℃壒娴佺▼缂栧彿锛屽閿�")] + public int FlowId { get; set; } + + /// <summary> + /// 瀹℃壒鑺傜偣缂栧彿锛屽閿� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "瀹℃壒鑺傜偣缂栧彿锛屽閿�")] + public int NodeId { get; set; } + + /// <summary> + /// 鐢宠浜虹敤鎴风紪鍙� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "鐢宠浜虹敤鎴风紪鍙�")] + public int ApplicantUserId { get; set; } + + /// <summary> + /// 鐢宠浜虹敤鎴峰悕绉� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "鐢宠浜虹敤鎴峰悕绉�")] + public string ApplicantUserName { get; set; } + + /// <summary> + /// 浠诲姟鐘舵�侊紙濡傚緟瀹℃壒銆佸凡瀹℃壒銆佸凡椹冲洖绛夛級 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "浠诲姟鐘舵�侊紙濡傚緟瀹℃壒銆佸凡瀹℃壒銆佸凡椹冲洖绛夛級")] + public int Status { get; set; } + + /// <summary> + /// 瀹℃壒鎰忚鍐呭 + /// </summary> + [SugarColumn(IsNullable = true, Length = 200, ColumnDescription = "瀹℃壒鎰忚鍐呭")] + public string OpinionContent { get; set; } + + /// <summary> + /// 瀹℃壒浜� + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "瀹℃壒浜�")] + public string AuditUser { get; set; } + + /// <summary> + /// + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "")] + public int SourceKey { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_NodeTransition.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_NodeTransition.cs" new file mode 100644 index 0000000..5cfe388 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/ApprovalFlow/Dt_NodeTransition.cs" @@ -0,0 +1,26 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_NodeTransition), "鑺傜偣璺宠浆琛�")] + public class Dt_NodeTransition : BaseEntity + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "璺宠浆缂栧彿锛屼富閿�")] + public int Id { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "璧峰鑺傜偣缂栧彿锛屽閿�")] + public int FromNodeId { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "鐩爣鑺傜偣缂栧彿锛屽閿�")] + public int ToNodeId { get; set; } + + [SugarColumn(IsNullable = false, Length = 200, ColumnDescription = "璺宠浆鏉′欢锛堝鈥滃悓鎰忓垯璺宠浆鍒颁笅涓�鑺傜偣鈥濓紝鈥滄嫆缁濆垯缁撴潫娴佺▼鈥濈瓑锛�")] + public string Condition { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_LocationInfo.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_LocationInfo.cs" index 9670987..ec5e4e9 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_LocationInfo.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_LocationInfo.cs" @@ -9,13 +9,10 @@ namespace WIDESEA_Model.Models { [SugarTable(nameof(Dt_LocationInfo), "璐т綅淇℃伅")] - public class Dt_LocationInfo : BaseEntity + public class Dt_LocationInfo : BaseEntity, BaseWarehouseEntity { [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] public int Id { get; set; } - - [SugarColumn(IsNullable = true, ColumnDescription = "鍖哄煙涓婚敭")] - public int AreaId { get; set; } [SugarColumn(IsNullable = true, Length = 20, ColumnDescription = "璐т綅缂栧彿")] public string LocationCode { get; set; } @@ -52,5 +49,8 @@ [SugarColumn(IsNullable = true, Length = 200, ColumnDescription = "澶囨敞")] public string Remark { get; set; } + + + public int WarehouseId { get ; set ; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_MaterielInfo.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_MaterielInfo.cs" index 92f56a7..d842122 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_MaterielInfo.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_MaterielInfo.cs" @@ -12,7 +12,7 @@ { [SugarTable(nameof(Dt_MaterielInfo), "鐗╂枡淇℃伅")] [SugarIndex("unique_materielinfo_materielcode", nameof(MaterielCode), OrderByType.Asc, true)] - public class Dt_MaterielInfo : BaseEntity + public class Dt_MaterielInfo : BaseEntity, BaseWarehouseEntity { /// <summary> /// 涓婚敭 @@ -121,5 +121,7 @@ /// </summary> [SugarColumn(IsNullable = true, Length = 200, ColumnDescription = "澶囨敞")] public string Remark { get; set; } + + public int WarehouseId { get; set; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_SupplierInfo.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_SupplierInfo.cs" new file mode 100644 index 0000000..91f9182 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_SupplierInfo.cs" @@ -0,0 +1,29 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_SupplierInfo), "渚涘簲鍟嗕俊鎭�")] + public class Dt_SupplierInfo : BaseEntity + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] + public int Id { get; set; } + + [SugarColumn(IsNullable = true, Length = 50, ColumnDescription = "渚涘簲鍟嗙紪鐮�")] + public string SupplierCode { get; set; } + + [SugarColumn(IsNullable = true, Length = 200, ColumnDescription = "渚涘簲鍟嗗悕绉�")] + public string SupplierName { get; set; } + + [SugarColumn(IsNullable = true, Length = 50, ColumnDescription = "渚涘簲鍟嗙畝绉�")] + public string SupplierShortName { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "鐘舵��")] + public int Status { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_Warehouse.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_Warehouse.cs" index c3adb39..7965eb1 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_Warehouse.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Basic/Dt_Warehouse.cs" @@ -12,7 +12,7 @@ public class Dt_Warehouse : BaseEntity { [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] - public int Id { get; set; } + public int WarehouseId { get; set; } [SugarColumn(IsNullable = false, Length = 20, ColumnDescription = "浠撳簱缂栧彿")] public string WarehouseCode { get; set; } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Check/Dt_CheckOrder.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Check/Dt_CheckOrder.cs" new file mode 100644 index 0000000..f720d11 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Check/Dt_CheckOrder.cs" @@ -0,0 +1,101 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.Attributes; +using WIDESEA_Core.CodeConfigEnum; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable] + public class Dt_CheckOrder : BaseEntity + { + /// <summary> + /// 涓婚敭 + /// </summary> + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] + public int CheckOrderId { get; set; } + + /// <summary> + /// 妫�楠屽崟鍙� + /// </summary> + [CodeRule(RuleCodeEnum.InboundOrderRule)] + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "妫�楠屽崟鍙�")] + public string CheckOrderNo { get; set; } + + /// <summary> + /// 鏀惰揣鍗曞彿 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鏀惰揣鍗曞彿")] + public string ReceiveOrderNo { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "璐ㄦ鍗曠姸鎬�")] + public int CheckOrderStatus { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "瀹℃壒鐘舵��")] + public int AuditStatus { get; set; } + + /// <summary> + /// 鏀惰揣鍗曟槑缁嗚鍙� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "鏀惰揣鍗曟槑缁嗚鍙�")] + public int ReceiveDetailRowNo { get; set; } + + /// <summary> + /// 鐗╂枡缂栧彿 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鐗╂枡缂栧彿")] + public string MaterielCode { get; set; } + + /// <summary> + /// 鍚堟牸鏁伴噺 + /// </summary> + [SugarColumn(IsNullable = true, ColumnDescription = "鍚堟牸鏁伴噺")] + public float? QualifiedQuantity { get; set; } + + /// <summary> + /// 鐗归噰鏁伴噺 + /// </summary> + [SugarColumn(IsNullable = true, ColumnDescription = "鐗归噰鏁伴噺")] + public float? DefectedQuantity { get; set; } + + /// <summary> + /// 閫�璐ф暟閲� + /// </summary> + [SugarColumn(IsNullable = true, ColumnDescription = "閫�璐ф暟閲�")] + public float? ReturnQuantity { get; set; } + + /// <summary> + /// 鎶ュ簾鏁伴噺 + /// </summary> + [SugarColumn(IsNullable = true, ColumnDescription = "鎶ュ簾鏁伴噺")] + public float? ScrappedQuantity { get; set; } + + /// <summary> + /// 妫�楠屾�绘暟(鏀惰揣鏁伴噺) + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "妫�楠屾�绘暟")] + public float ReceivedQuantity { get; set; } + + /// <summary> + /// 妫�楠岀粨鏋� + /// </summary> + [SugarColumn(IsNullable = true, Length = 50, ColumnDescription = "妫�楠岀粨鏋�")] + public string Result { get; set; } + + /// <summary> + /// 鐗归噰璇存槑 + /// </summary> + [SugarColumn(IsNullable = true, Length = 50, ColumnDescription = "鐗归噰璇存槑")] + public string DefectedNote { get; set; } + + [SugarColumn(IsNullable = true, Length = 50, ColumnDescription = "妫�楠屼汉")] + public string CheckUserName { get; set; } + + [Navigate(NavigateType.OneToMany, nameof(Dt_CheckOrderResult.CheckOrderId), nameof(CheckOrderId))] + public List<Dt_CheckOrderResult> Details { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Check/Dt_CheckOrderResult.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Check/Dt_CheckOrderResult.cs" new file mode 100644 index 0000000..7eecde4 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Check/Dt_CheckOrderResult.cs" @@ -0,0 +1,50 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_CheckOrderResult), "妫�楠岀粨鏋�")] + public class Dt_CheckOrderResult : BaseEntity + { + /// <summary> + /// 涓婚敭 + /// </summary> + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] + public int Id { get; set; } + + /// <summary> + /// 妫�楠屽崟涓婚敭 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "妫�楠屽崟涓婚敭")] + public int CheckOrderId { get; set; } + + /// <summary> + /// 缂洪櫡浠g爜 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "缂洪櫡浠g爜")] + public string DefectCode { get; set; } + + /// <summary> + /// 妫�楠岀粨鏋� + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "妫�楠岀粨鏋�")] + public string Result { get; set; } + + /// <summary> + /// 鏁伴噺 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鏁伴噺")] + public float Quantity { get; set; } + + /// <summary> + /// 澶囨敞 + /// </summary> + [SugarColumn(IsNullable = true, Length = 500, ColumnDescription = "澶囨敞")] + public string Note { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrder.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrder.cs" index 1a33a58..eb69f09 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrder.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrder.cs" @@ -18,11 +18,17 @@ [CodeRule(RuleCodeEnum.InboundOrderRule)] [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鍗曟嵁缂栧彿")] - public string OrderNo { get; set; } + public string InboundOrderNo { get; set; } [SugarColumn(IsNullable = true, Length = 50, ColumnDescription = "涓婃父鍗曟嵁缂栧彿")] public string UpperOrderNo { get; set; } + [SugarColumn(IsNullable = false, ColumnDescription = "")] + public int WarehouseId { get; set; } + + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "")] + public string SupplierId { get; set; } + [SugarColumn(IsNullable = false, ColumnDescription = "鍗曟嵁绫诲瀷")] public int OrderType { get; set; } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrderDetail.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrderDetail.cs" index 3de596a..217765a 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrderDetail.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_InboundOrderDetail.cs" @@ -12,33 +12,33 @@ public class Dt_InboundOrderDetail : BaseEntity { [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] - public int Id { get; set; } + public int Id { get; set; } [SugarColumn(IsNullable = false, ColumnDescription = "鍏ュ簱鍗曚富閿�")] public int OrderId { get; set; } [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鐗╂枡缂栧彿")] - public string MaterielCode { get; set; } + public string MaterielCode { get; set; } - [SugarColumn(IsNullable = false, Length = 200, ColumnDescription = "鐗╂枡鍚嶇О")] - public string MaterielName { get; set; } + [SugarColumn(IsNullable = false, ColumnDescription = "鍗曟嵁鏁伴噺")] + public float OrderQuantity { get; set; } - [SugarColumn(IsNullable = false, Length = 20, ColumnDescription = "鎵规鍙�")] - public string BatchNo { get; set; } + [SugarColumn(IsNullable = false, ColumnDescription = "缁勭洏鏁伴噺", DefaultValue = "0")] + public float ReceiptQuantity { get; set; } - [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "鍗曟嵁鏁伴噺")] - public decimal OrderQuantity { get; set; } - - [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "缁勭洏鏁伴噺", DefaultValue = "0")] - public decimal ReceiptQuantity { get; set; } - - [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "涓婃灦鏁伴噺", DefaultValue = "0")] - public decimal OverInQuantity { get; set; } + [SugarColumn(IsNullable = false, ColumnDescription = "涓婃灦鏁伴噺", DefaultValue = "0")] + public float OverInQuantity { get; set; } [SugarColumn(IsNullable = false, ColumnDescription = "璁㈠崟鏄庣粏鐘舵��")] - public int OrderDetailStatus { get; set; } + public int OrderDetailStatus { get; set; } + + [SugarColumn(IsNullable = false, Length = 20, ColumnDescription = "鍗曚綅")] + public string Unit { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "琛屽彿")] + public int RowNo { get; set; } [SugarColumn(IsNullable = true, ColumnDescription = "澶囨敞")] - public string Remark { get; set; } + public string Remark { get; set; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_PurchaseOrder.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_PurchaseOrder.cs" new file mode 100644 index 0000000..b8acae7 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_PurchaseOrder.cs" @@ -0,0 +1,71 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.Attributes; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_PurchaseOrder), "閲囪喘璁㈠崟"), ModelValidate] + public class Dt_PurchaseOrder : BaseEntity + { + /// <summary> + /// 涓婚敭 + /// </summary> + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "")] + public int Id { get; set; } + + /// <summary> + /// 閲囪喘鍗曞彿 + /// </summary> + [PropertyValidate("閲囪喘鍗曞彿", NotNullAndEmpty = true)] + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "")] + public string PurchaseOrderNo { get; set; } + + /// <summary> + /// 鍗曟嵁绫诲瀷(S:鏍囧噯鍏ュ簱銆乂:瀵勫敭琛ョ粰鍏ュ簱) + /// </summary> + [PropertyValidate("鍗曟嵁绫诲瀷", NotNullAndEmpty = true, Check = new[] { "S", "V" })] + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "")] + public string PurchaseOrderType { get; set; } + + /// <summary> + /// 渚涘簲鍟嗙紪鍙� + /// </summary> + [PropertyValidate("渚涘簲鍟嗙紪鍙�", NotNullAndEmpty = true)] + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "")] + public string SupplierCode { get; set; } + + /// <summary> + /// 閲囪喘鏁伴噺 + /// </summary> + [PropertyValidate("閲囪喘鏁伴噺", MinValue = 0, IsContainMinValue = false)] + [SugarColumn(IsNullable = false, ColumnDescription = "")] + public float OrderQuantity { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "")] + public int PurchaseOrderStatus { get; set; } + + /// <summary> + /// 涓嬪崟鏃ユ湡 + /// </summary> + [PropertyValidate("涓嬪崟鏃ユ湡", NotNullAndEmpty = true)] + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "")] + public string OrderDate { get; set; } + + /// <summary> + /// 澶囨敞 + /// </summary> + [SugarColumn(IsNullable = false, Length = 200, ColumnDescription = "")] + public string Remark { get; set; } + + /// <summary> + /// 鐗╂枡鍒楄〃 + /// </summary> + [PropertyValidate("鐗╂枡鍒楄〃", NotNullAndEmpty = true), Navigate(NavigateType.OneToMany, nameof(Dt_PurchaseOrderDetail.PurchaseOrderId), nameof(Id))] + public List<Dt_PurchaseOrderDetail> Details { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_PurchaseOrderDetail.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_PurchaseOrderDetail.cs" new file mode 100644 index 0000000..2cf844d --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_PurchaseOrderDetail.cs" @@ -0,0 +1,63 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.Attributes; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_PurchaseOrderDetail), "閲囪喘鍗曟槑缁�"), ModelValidate] + public class Dt_PurchaseOrderDetail : BaseEntity + { + /// <summary> + /// 涓婚敭 + /// </summary> + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] + public int Id { get; set; } + + /// <summary> + /// 澶磋〃涓婚敭 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "澶磋〃涓婚敭")] + public int PurchaseOrderId { get; set; } + + /// <summary> + /// 琛屽彿 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "琛屽彿")] + public int RowNo { get; set; } + + /// <summary> + /// 鐗╂枡缂栧彿 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鐗╂枡缂栧彿")] + public string MaterielCode { get; set; } + + /// <summary> + /// 閲囪喘鍗曟槑缁嗙姸鎬� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "閲囪喘鍗曟槑缁嗙姸鎬�")] + public int PurchaseDetailStatus { get; set; } + + /// <summary> + /// 浠撳簱缂栧彿 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnName = "WarehouseId", ColumnDescription = "")] + public int WarehouseId { get; set; } + + /// <summary> + /// 鏁伴噺 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "")] + public float PurchaseDetailQuantity { get; set; } + + /// <summary> + /// 鍗曚綅 + /// </summary> + [SugarColumn(IsNullable = false, Length = 20, ColumnDescription = "")] + public string Unit { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_ReceiveOrder.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_ReceiveOrder.cs" new file mode 100644 index 0000000..0480c18 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_ReceiveOrder.cs" @@ -0,0 +1,86 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.Attributes; +using WIDESEA_Core.CodeConfigEnum; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_ReceiveOrder), "鏀惰揣鍗�")] + public class Dt_ReceiveOrder : BaseEntity + { + /// <summary> + /// 涓婚敭 + /// </summary> + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] + public int ReceiveOrderId { get; set; } + + /// <summary> + /// 鏀惰揣鍗曞彿 + /// </summary> + [CodeRule(RuleCodeEnum.ReceiveOrderRule)] + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鏀惰揣鍗曞彿")] + public string ReceiveOrderNo { get; set; } + + /// <summary> + /// 璁㈠崟绫诲瀷 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "璁㈠崟绫诲瀷")] + public int ReceiveOrderType { get; set; } + + /// <summary> + /// 璁㈠崟鐘舵�� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "璁㈠崟鐘舵��")] + public int ReceiveOrderStatus { get; set; } + + /// <summary> + /// 涓婁紶鐘舵�� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "涓婁紶鐘舵��")] + public int UploadStatus { get; set; } + + /// <summary> + /// 瀹㈡埛浠e彿 + /// </summary> + [SugarColumn(IsNullable = true, Length = 50, ColumnDescription = "瀹㈡埛浠e彿")] + public string CustomerId { get; set; } + + /// <summary> + /// 渚涘簲鍟嗕唬鍙� + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "渚涘簲鍟嗕唬鍙�")] + public string SuppliersId { get; set; } + + /// <summary> + /// 浠撳簱涓婚敭 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "浠撳簱涓婚敭")] + public int WarehouseId { get; set; } + + /// <summary> + /// 鏀惰揣鏃ユ湡 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鏀惰揣鏃ユ湡")] + public DateTime ReceiveDate { get; set; } + + /// <summary> + /// 閫佽揣鍗曞彿 + /// </summary> + [SugarColumn(IsNullable = true, Length = 50, ColumnDescription = "閫佽揣鍗曞彿")] + public string DeliveryCode { get; set; } + + /// <summary> + /// 澶囨敞 + /// </summary> + [SugarColumn(IsNullable = true, Length = 500, ColumnDescription = "澶囨敞")] + public string Remark { get; set; } + + [Navigate(NavigateType.OneToMany, nameof(Dt_ReceiveOrderDetail.ReceiveOrderId), nameof(ReceiveOrderId))] + public List<Dt_ReceiveOrderDetail> Details { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_ReceiveOrderDetail.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_ReceiveOrderDetail.cs" new file mode 100644 index 0000000..815a973 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Inbound/Dt_ReceiveOrderDetail.cs" @@ -0,0 +1,95 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Dt_ReceiveOrderDetail), "鏀惰揣鍗曟槑缁�")] + public class Dt_ReceiveOrderDetail : BaseEntity + { + /// <summary> + /// 涓婚敭 + /// </summary> + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")] + public int Id { get; set; } + + /// <summary> + /// 鏀惰揣鍗曚富閿� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "鏀惰揣鍗曚富閿�")] + public int ReceiveOrderId { get; set; } + + /// <summary> + /// 閲囪喘鍗曞彿 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "閲囪喘鍗曞彿")] + public string PurchaseOrderNo { get; set; } + + [SugarColumn(IsNullable = false, ColumnDescription = "閲囪喘鍗曟槑缁嗚鍙�")] + public int PurchaseOrderDetailRowNo { get; set; } + + /// <summary> + /// 琛屽彿 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "琛屽彿")] + public int RowNo { get; set; } + + /// <summary> + /// 鐗╂枡缂栧彿 + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鐗╂枡缂栧彿")] + public string MaterielCode { get; set; } + + /// <summary> + /// 鎵规鍙� + /// </summary> + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鎵规鍙�")] + public string LotNo { get; set; } + + /// <summary> + /// 鏀惰揣鏁伴噺 + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "鏀惰揣鏁伴噺")] + public float ReceivedQuantity { get; set; } + + /// <summary> + /// 鏄惁瑕佹楠� + /// </summary> + [SugarColumn(IsNullable = false, ColumnDescription = "鏄惁瑕佹楠�")] + public int IfInspection { get; set; } + + /// <summary> + /// 鍚◣浠锋牸 + /// </summary> + [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "鍚◣浠锋牸")] + public decimal PriceInTax { get; set; } + + /// <summary> + /// 绋庣巼 + /// </summary> + [SugarColumn(IsNullable = true, Length = 20, ColumnDescription = "绋庣巼")] + public string TaxRate { get; set; } + + /// <summary> + /// 甯佸埆缂栫爜 + /// </summary> + [SugarColumn(IsNullable = true, Length = 20, ColumnDescription = "甯佸埆缂栫爜")] + public string CurrCode { get; set; } + + /// <summary> + /// 澶囨敞 + /// </summary> + [SugarColumn(IsNullable = true, Length = 500, ColumnDescription = "澶囨敞")] + public string Remark { get; set; } + + /// <summary> + /// 鍗曚綅 + /// </summary> + [SugarColumn(IsNullable = false, Length = 20, ColumnDescription = "")] + public string Unit { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Record/Dt_StockQuantityChangeRecord.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Record/Dt_StockQuantityChangeRecord.cs" index a196757..f6d5e27 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Record/Dt_StockQuantityChangeRecord.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Record/Dt_StockQuantityChangeRecord.cs" @@ -42,13 +42,13 @@ public int ChangeType { get; set; } [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "鍙樺姩鏁伴噺锛堟鏁拌〃绀哄鍔狅紝璐熸暟琛ㄧず鍑忓皯锛�")] - public decimal ChangeQuantity { get; set; } + public float ChangeQuantity { get; set; } [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "鍙樺姩鍓嶅簱瀛橀噺", DefaultValue = "0")] - public decimal BeforeQuantity { get; set; } + public float BeforeQuantity { get; set; } [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "鍙樺姩鍚庡簱瀛橀噺", DefaultValue = "0")] - public decimal AfterQuantity { get; set; } + public float AfterQuantity { get; set; } [SugarColumn(IsNullable = true, ColumnDescription = "澶囨敞")] public string Remark { get; set; } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfo.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfo.cs" index 950691e..07b7820 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfo.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfo.cs" @@ -20,8 +20,8 @@ [SugarColumn(IsNullable = true, Length = 20, ColumnDescription = "璐т綅缂栧彿")] public string LocationCode { get; set; } - [SugarColumn(IsNullable = false, ColumnDescription = "鏄惁婊$洏", DefaultValue = "0")] - public bool IsFull { get; set; } + [SugarColumn(IsNullable = false, ColumnDescription = "")] + public int WarehouseId { get; set; } [SugarColumn(IsNullable = false, ColumnDescription = "搴撳瓨鐘舵��")] public int StockStatus { get; set; } @@ -29,6 +29,9 @@ [SugarColumn(IsNullable = true, ColumnDescription = "澶囨敞")] public string Remark { get; set; } + [SugarColumn(IsNullable = false, ColumnDescription = "")] + public int PalletType { get; set; } + [Navigate(NavigateType.OneToMany, nameof(Dt_StockInfoDetail.StockId), nameof(Id))] public List<Dt_StockInfoDetail> Details { get; set; } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfoDetail.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfoDetail.cs" index 018e2d6..f267062 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfoDetail.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/Stock/Dt_StockInfoDetail.cs" @@ -33,18 +33,15 @@ public string SerialNumber { get; set; } [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "搴撳瓨鏁伴噺")] - public decimal StockQuantity { get; set; } + public float StockQuantity { get; set; } [SugarColumn(IsNullable = false, DecimalDigits = 2, ColumnDescription = "鍑哄簱鏁伴噺", DefaultValue = "0")] - public decimal OutboundQuantity { get; set; } + public float OutboundQuantity { get; set; } [SugarColumn(IsNullable = false, ColumnDescription = "搴撳瓨鏄庣粏鐘舵��")] public int Status { get; set; } [SugarColumn(IsNullable = true, ColumnDescription = "澶囨敞")] public string Remark { get; set; } - - [Navigate(NavigateType.OneToOne, nameof(Dt_StockQuantityChangeRecord.StockDetailId), nameof(Id))] - public Dt_StockQuantityChangeRecord StockQuantityChangeRecord { get; set; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Log.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Log.cs" index ed75231..d5d22b8 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Log.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Log.cs" @@ -81,6 +81,6 @@ /// 鐢ㄦ埛涓婚敭 /// </summary> [SugarColumn(IsNullable = true, ColumnDescription = "鐢ㄦ埛涓婚敭")] - public int? User_Id { get; set; } + public int? UserId { get; set; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Role.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Role.cs" index cd54e64..00dcd63 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Role.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_Role.cs" @@ -21,7 +21,7 @@ /// <summary> /// 閮ㄩ棬鍚嶇О /// </summary> - [SugarColumn(IsNullable = true,IsIgnore = true, Length = 50, ColumnDescription = "閮ㄩ棬鍚嶇О")] + [SugarColumn(IsNullable = true, IsIgnore = true, Length = 50, ColumnDescription = "閮ㄩ棬鍚嶇О")] public string DeptName { get; set; } /// <summary> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_RoleDataPermission.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_RoleDataPermission.cs" new file mode 100644 index 0000000..02dc7f0 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_RoleDataPermission.cs" @@ -0,0 +1,27 @@ +锘縰sing SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.DB.Models; + +namespace WIDESEA_Model.Models +{ + [SugarTable(nameof(Sys_RoleDataPermission))] + public class Sys_RoleDataPermission : BaseEntity + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + + public int RoleId { get; set; } + + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "瑙掕壊鍚嶇О")] + public string RoleName { get; set; } + + public int WarehouseId { get; set; } + + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "")] + public string WarehouseName { get; set; } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_User.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_User.cs" index a38981a..99c6a1e 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_User.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/System/Sys_User.cs" @@ -20,7 +20,7 @@ /// 鐢ㄦ埛ID /// </summary> [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "鐢ㄦ埛ID")] - public int User_Id { get; set; } + public int UserId { get; set; } /// <summary> ///甯愬彿 @@ -32,7 +32,7 @@ /// 瑙掕壊ID /// </summary> [SugarColumn(IsNullable = false, ColumnDescription = "瑙掕壊ID")] - public int Role_Id { get; set; } + public int RoleId { get; set; } /// <summary> /// 瑙掕壊鍚嶇О @@ -74,7 +74,7 @@ /// 閮ㄩ棬ID /// </summary> [SugarColumn(IsNullable = true, ColumnDescription = "閮ㄩ棬ID")] - public int? Dept_Id { get; set; } + public int? DeptId { get; set; } /// <summary> /// 閭 diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task.cs" index 5f7ad7f..8ea64db 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task.cs" @@ -11,7 +11,7 @@ namespace WIDESEA_Model.Models { - [SugarTable(nameof(Dt_Task), "浠诲姟淇℃伅")] + [SugarTable(nameof(Dt_Task), "浠诲姟淇℃伅"), SugarIndex("unique_task_taskNum", nameof(TaskNum), OrderByType.Asc, true)] public class Dt_Task : BaseEntity { /// <summary> @@ -27,7 +27,7 @@ /// </summary> [ImporterHeader(Name = "浠诲姟鍙�")] [ExporterHeader(DisplayName = "浠诲姟鍙�")] - [SugarColumn(IsNullable = false, ColumnDescription = "浠诲姟鍙�"), SequenceAttirbute(nameof(SequenceEnum.SeqTaskNum), 999999999)] + [SugarColumn(IsNullable = false, ColumnDescription = "浠诲姟鍙�"), Sequence(nameof(SequenceEnum.SeqTaskNum), 100000000)] public int TaskNum { get; set; } /// <summary> @@ -95,12 +95,12 @@ public string NextAddress { get; set; } /// <summary> - /// 娣卞害 + /// 浠撳簱涓婚敭 /// </summary> - [ImporterHeader(Name = "娣卞害")] - [ExporterHeader(DisplayName = "娣卞害")] - [SugarColumn(IsNullable = true, ColumnDescription = "娣卞害")] - public int Depth { get; set; } + [ImporterHeader(Name = "浠撳簱涓婚敭")] + [ExporterHeader(DisplayName = "浠撳簱涓婚敭")] + [SugarColumn(IsNullable = true, ColumnDescription = "浠撳簱涓婚敭")] + public int WarehouseId { get; set; } /// <summary> /// 鍗曟嵁缂栧彿 @@ -117,9 +117,6 @@ [ExporterHeader(DisplayName = "浼樺厛绾�")] [SugarColumn(IsNullable = false, ColumnDescription = "浼樺厛绾�")] public int Grade { get; set; } - - [SugarColumn(IsNullable = false, DefaultValue = "0", ColumnDescription = "婧愪富閿�")] - public int SourceKey { get; set; } /// <summary> /// 浠诲姟涓嬪彂鏃堕棿 diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task_Hty.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task_Hty.cs" index b459906..e1d8226 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task_Hty.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_Model/Models/TaskInfo/Dt_Task_Hty.cs" @@ -26,7 +26,7 @@ /// </summary> [ImporterHeader(Name = "浠诲姟鍙�")] [ExporterHeader(DisplayName = "浠诲姟鍙�")] - [SugarColumn(IsNullable = false, ColumnDescription = "浠诲姟鍙�"), SequenceAttirbute(nameof(SequenceEnum.SeqTaskNum), 6000)] + [SugarColumn(IsNullable = false, ColumnDescription = "浠诲姟鍙�")] public int TaskNum { get; set; } /// <summary> @@ -109,9 +109,6 @@ [SugarColumn(IsNullable = false, ColumnDescription = "浼樺厛绾�")] public int Grade { get; set; } - [SugarColumn(IsNullable = false, DefaultValue = "0", ColumnDescription = "婧愪富閿�")] - public int SourceKey { get; set; } - /// <summary> /// 浠诲姟涓嬪彂鏃堕棿 /// </summary> @@ -121,12 +118,12 @@ public DateTime? Dispatchertime { get; set; } /// <summary> - /// 娣卞害 + /// 浠撳簱涓婚敭 /// </summary> - [ImporterHeader(Name = "娣卞害")] - [ExporterHeader(DisplayName = "娣卞害")] - [SugarColumn(IsNullable = true, ColumnDescription = "娣卞害")] - public int Depth { get; set; } + [ImporterHeader(Name = "浠撳簱涓婚敭")] + [ExporterHeader(DisplayName = "浠撳簱涓婚敭")] + [SugarColumn(IsNullable = true, ColumnDescription = "浠撳簱涓婚敭")] + public int WarehouseId { get; set; } /// <summary> /// 澶囨敞 @@ -136,10 +133,20 @@ [SugarColumn(IsNullable = true, Length = 255, ColumnDescription = "澶囨敞")] public string Remark { get; set; } - [SugarColumn(IsNullable = false, DefaultValue = "0", ColumnDescription = "婧愪富閿�")] + /// <summary> + /// 鍘熻〃涓婚敭 + /// </summary> + [ImporterHeader(Name = "鍘熻〃涓婚敭")] + [ExporterHeader(DisplayName = "鍘熻〃涓婚敭")] + [SugarColumn(IsNullable = false, DefaultValue = "0", ColumnDescription = "鍘熻〃涓婚敭")] public int SourceId { get; set; } - [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "澶囨敞")] + /// <summary> + /// 鎿嶄綔绫诲瀷 + /// </summary> + [ImporterHeader(Name = "鎿嶄綔绫诲瀷")] + [ExporterHeader(DisplayName = "鎿嶄綔绫诲瀷")] + [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "鎿嶄綔绫诲瀷")] public string OperateType { get; set; } /// <summary> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutStockLockInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutStockLockInfoService.cs" index 9ba5786..d8e0216 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutStockLockInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutStockLockInfoService.cs" @@ -20,42 +20,5 @@ { } - public List<Dt_OutStockLockInfo> GetOutStockLockInfos(Dt_OutboundOrder outboundOrder, Dt_OutboundOrderDetail outboundOrderDetail, List<Dt_StockInfo> outStocks, int? taskNum = null) - { - List<Dt_OutStockLockInfo> outStockLockInfos = new List<Dt_OutStockLockInfo>(); - - foreach (var item in outStocks) - { - Dt_OutStockLockInfo outStockLockInfo = new Dt_OutStockLockInfo() - { - PalletCode = item.PalletCode, - AssignQuantity = item.Details.Where(x => x.MaterielCode == outboundOrderDetail.MaterielCode).Sum(x => x.OutboundQuantity), - MaterielCode = outboundOrderDetail.MaterielCode, - BatchNo = outboundOrderDetail.BatchNo, - LocationCode = item.LocationCode, - MaterielName = outboundOrderDetail.MaterielName, - OrderDetailId = outboundOrderDetail.Id, - OrderNo = outboundOrder.OrderNo, - OrderType = outboundOrder.OrderType, - OriginalQuantity = item.Details.Where(x => x.MaterielCode == outboundOrderDetail.MaterielCode).Sum(x => x.StockQuantity), - Status = taskNum == null ? OutLockStockStatusEnum.宸插垎閰�.ObjToInt() : OutLockStockStatusEnum.鍑哄簱涓�.ObjToInt(), - StockId = item.Id, - TaskNum = taskNum - }; - outStockLockInfos.Add(outStockLockInfo); - } - - return outStockLockInfos; - } - - public List<Dt_OutStockLockInfo> GetByOrderDetailId(int orderDetailId) - { - return BaseDal.QueryData(x => x.OrderDetailId == orderDetailId); - } - - public List<Dt_OutStockLockInfo> GetByOrderDetailId(int orderDetailId, OutLockStockStatusEnum outStockStatus) - { - return BaseDal.QueryData(x => x.OrderDetailId == orderDetailId && x.Status == outStockStatus.ObjToInt()); - } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetailService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetailService.cs" index d7ef4d1..e7babd1 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetailService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetailService.cs" @@ -27,22 +27,11 @@ { private readonly IUnitOfWorkManage _unitOfWorkManage; - private readonly IStockService _stockService; - private readonly IBasicService _basicService; - private readonly IRecordService _recordService; - private readonly IOutboundRepository _outboundRepository; - private readonly IOutStockLockInfoService _outStockLockInfoService; - public IOutboundOrderDetailRepository Repository => BaseDal; - public OutboundOrderDetailService(IOutboundOrderDetailRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, IStockService stockService, IBasicService basicService, IRecordService recordService, IOutboundRepository outboundRepository, IOutStockLockInfoService outStockLockInfoService) : base(BaseDal) + public OutboundOrderDetailService(IOutboundOrderDetailRepository BaseDal, IUnitOfWorkManage unitOfWorkManage) : base(BaseDal) { _unitOfWorkManage = unitOfWorkManage; - _stockService = stockService; - _basicService = basicService; - _recordService = recordService; - _outboundRepository = outboundRepository; - _outStockLockInfoService = outStockLockInfoService; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetail_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetail_HtyService.cs" index 8404d65..ccc2b13 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetail_HtyService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderDetail_HtyService.cs" @@ -27,22 +27,11 @@ { private readonly IUnitOfWorkManage _unitOfWorkManage; - private readonly IStockService _stockService; - private readonly IBasicService _basicService; - private readonly IRecordService _recordService; - private readonly IOutboundRepository _outboundRepository; - private readonly IOutStockLockInfoService _outStockLockInfoService; - public IOutboundOrderDetail_HtyRepository Repository => BaseDal; - public OutboundOrderDetail_HtyService(IOutboundOrderDetail_HtyRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, IStockService stockService, IBasicService basicService, IRecordService recordService, IOutboundRepository outboundRepository, IOutStockLockInfoService outStockLockInfoService) : base(BaseDal) + public OutboundOrderDetail_HtyService(IOutboundOrderDetail_HtyRepository BaseDal, IUnitOfWorkManage unitOfWorkManage) : base(BaseDal) { _unitOfWorkManage = unitOfWorkManage; - _stockService = stockService; - _basicService = basicService; - _recordService = recordService; - _outboundRepository = outboundRepository; - _outStockLockInfoService = outStockLockInfoService; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderService.cs" index 65b8bf5..153d7bb 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrderService.cs" @@ -26,172 +26,12 @@ public partial class OutboundOrderService : ServiceBase<Dt_OutboundOrder, IOutboundOrderRepository>, IOutboundOrderService { private readonly IMapper _mapper; - private readonly IMaterielInfoService _materielInfoService; - private readonly IStockInfoService _stockService; - private readonly IStockInfoDetailService _stockDetailService; public IOutboundOrderRepository Repository => BaseDal; - public OutboundOrderService(IOutboundOrderRepository BaseDal, IMapper mapper, IMaterielInfoService materielInfoService, IStockInfoDetailService stockDetailService, IStockInfoService stockInfoService) : base(BaseDal) + public OutboundOrderService(IOutboundOrderRepository BaseDal, IMapper mapper) : base(BaseDal) { _mapper = mapper; - _materielInfoService = materielInfoService; - _stockDetailService = stockDetailService; - _stockService = stockInfoService; - } - - public override WebResponseContent AddData(SaveModel saveModel) - { - OutboundOrderAddDTO outboundOrder = saveModel.MainData.DicToModel<OutboundOrderAddDTO>(); - List<OutboundOrderDetailAddDTO> orderDetailAddDTOs = saveModel.DetailData.DicToIEnumerable<OutboundOrderDetailAddDTO>(); - outboundOrder.Details = orderDetailAddDTOs.GroupBy(x => x.MaterielCode).Select(x => new OutboundOrderDetailAddDTO - { - BatchNo = x.FirstOrDefault()?.BatchNo ?? "", - MaterielCode = x.Key, - OrderQuantity = x.Sum(x => x.OrderQuantity), - MaterielName= x.FirstOrDefault()?.MaterielName ?? "", - Remark = x.FirstOrDefault(v => !string.IsNullOrEmpty(v.Remark))?.Remark ?? "" - }).ToList(); - return AddOutboundOrder(outboundOrder); - } - - public override WebResponseContent UpdateData(SaveModel saveModel) - { - List<Dt_OutboundOrderDetail> outboundOrderDetails = saveModel.DetailData.DicToIEnumerable<Dt_OutboundOrderDetail>(); - if (outboundOrderDetails.GroupBy(x => x.MaterielCode).Select(x => x.Count()).Any(x => x > 1)) - { - return WebResponseContent.Instance.Error("鐗╂枡閲嶅"); - } - outboundOrderDetails = outboundOrderDetails.Where(x => (x.Id > 0 && x.OrderDetailStatus == OrderDetailStatusEnum.New.ObjToInt()) || x.Id == 0).ToList(); - - List<Dictionary<string, object>> dics = new List<Dictionary<string, object>>(); - JsonSerializerSettings settings = new JsonSerializerSettings(); - settings.ContractResolver = new CamelCasePropertyNamesContractResolver(); - foreach (var item in outboundOrderDetails) - { - string str = JsonConvert.SerializeObject(item, settings); - Dictionary<string, object>? dic = JsonConvert.DeserializeObject<Dictionary<string, object>>(str); - if (dic != null) - dics.Add(dic); - } - saveModel.DetailData = dics; - return base.UpdateData(saveModel); - } - - public WebResponseContent AddOutboundOrder(OutboundOrderAddDTO orderAddDTO) - { - WebResponseContent content = new(); - try - { - #region 楠岃瘉鏁版嵁 - (bool, string, object?) result = CheckOutboundOrderAddData(orderAddDTO); - if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); - #endregion - - Dt_OutboundOrder outboundOrder = _mapper.Map<Dt_OutboundOrder>(orderAddDTO); - outboundOrder.OrderStatus = OutOrderStatusEnum.鏈紑濮�.ObjToInt(); - bool a = BaseDal.Db.InsertNav(outboundOrder).Include(x => x.Details).ExecuteCommand(); - content = WebResponseContent.Instance.OK(); - } - catch (Exception ex) - { - content = WebResponseContent.Instance.Error(ex.Message); - } - finally - { - - } - return content; - } - - private (bool, string, object?) CheckOutboundOrderAddData(OutboundOrderAddDTO outboundOrderAddDTO) - { - (bool, string, object?) result1 = ModelValidate.ValidateModelData(outboundOrderAddDTO); - if (!result1.Item1) return result1; - - (bool, string, object?) result2 = ModelValidate.ValidateModelData(outboundOrderAddDTO.Details); - if (!result2.Item1) return result2; - - IEnumerable<int> inOrderTypes = Enum.GetValues<OutOrderTypeEnum>().Cast<int>(); - if (!inOrderTypes.Contains(outboundOrderAddDTO.OrderType)) - { - return (false, "鏈壘鍒拌鍗曟嵁绫诲瀷", outboundOrderAddDTO); - } - - List<string> materielCodes = outboundOrderAddDTO.Details.Select(x => x.MaterielCode).ToList(); - if (!_materielInfoService.ExsitMateriels(materielCodes)) - { - return (false, "鏈夌墿鏂欎俊鎭湭褰曞叆锛岃褰曞叆鐗╂枡淇℃伅", outboundOrderAddDTO); - } - - if (BaseDal.QueryFirst(x => x.UpperOrderNo == outboundOrderAddDTO.UpperOrderNo && !string.IsNullOrEmpty(x.UpperOrderNo)) != null) - { - return (false, "鍗曟嵁宸插瓨鍦�", outboundOrderAddDTO); - } - return (true, "鎴愬姛", outboundOrderAddDTO); - } - - public WebResponseContent ReleaseOutOrder(int orderId) - { - WebResponseContent content = new WebResponseContent(); - try - { - - } - catch (Exception ex) - { - - } - return content; - } - - public WebResponseContent GetOutboundOrder(OutboundOrderGetDTO outboundOrderGetDTO) - { - WebResponseContent content = new WebResponseContent(); - try - { - Expression<Func<Dt_OutboundOrder, bool>> expressionOrder = x => true; - if (!string.IsNullOrEmpty(outboundOrderGetDTO.OrderNo)) - { - expressionOrder = x => x.OrderNo.Contains(outboundOrderGetDTO.OrderNo); - } - int count = BaseDal.QueryData(x => x.OrderStatus == OutOrderStatusEnum.鏈紑濮�.ObjToInt()).ToList().Count(); - int maxPage = Convert.ToInt32(Math.Ceiling(count / 10.0)); - if (outboundOrderGetDTO.pageNo <= maxPage) - { - var outboundOrder = BaseDal.Db.Queryable<Dt_OutboundOrder>().Where(expressionOrder).OrderByDescending(x => x.CreateDate).Skip((outboundOrderGetDTO.pageNo - 1) * 10).Take(10).Select(x => new Dt_OutboundOrder { OrderNo = x.OrderNo, Id = x.Id, CreateDate = x.CreateDate, Creater = x.Creater }).ToList(); - - content = WebResponseContent.Instance.OK(data: outboundOrder); - } - else - { - content = WebResponseContent.Instance.OK(data: null, message: "宸插埌鏈�鍚庝竴椤�"); - } - } - catch (Exception ex) - { - content = WebResponseContent.Instance.Error($"鏌ヨ鍑哄簱鍗曟嵁閿欒,閿欒淇℃伅:{ex.Message}"); - } - - return content; - } - - public WebResponseContent GetOutboundOrderDetail(string OrderNo) - { - WebResponseContent content = new WebResponseContent(); - try - { - Dt_OutboundOrder outboundOrder = BaseDal.QueryFirst(x => x.OrderNo == OrderNo); - - var outboundOrderDetail = BaseDal.Db.Queryable<Dt_OutboundOrderDetail>().Where(x => x.OrderId == outboundOrder.Id).Take(10).Select(x => new Dt_OutboundOrderDetail {Id=x.Id, MaterielCode = x.MaterielCode, MaterielName = x.MaterielName, OrderQuantity = x.OrderQuantity, OverOutQuantity = x.OverOutQuantity, LockQuantity = x.LockQuantity }).ToList(); - - content = WebResponseContent.Instance.OK(data: outboundOrderDetail); - } - catch (Exception ex) - { - content = WebResponseContent.Instance.Error($"鏌ヨ鍑哄簱鍗曟嵁鏄庣粏閿欒,閿欒淇℃伅:{ex.Message}"); - } - return content; } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrder_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrder_HtyService.cs" index e032734..1df7138 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrder_HtyService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/Base/OutboundOrder_HtyService.cs" @@ -24,20 +24,11 @@ public partial class OutboundOrder_HtyService : ServiceBase<Dt_OutboundOrder_Hty, IOutboundOrder_HtyRepository>, IOutboundOrder_HtyService { private readonly IMapper _mapper; - private readonly IMaterielInfoService _materielInfoService; - private readonly IStockInfoService _stockService; - private readonly IStockInfoDetailService _stockDetailService; - public IOutboundOrder_HtyRepository Repository => BaseDal; - public OutboundOrder_HtyService(IOutboundOrder_HtyRepository BaseDal, IMapper mapper, IMaterielInfoService materielInfoService, IStockInfoDetailService stockDetailService, IStockInfoService stockInfoService) : base(BaseDal) + public OutboundOrder_HtyService(IOutboundOrder_HtyRepository BaseDal, IMapper mapper) : base(BaseDal) { _mapper = mapper; - _materielInfoService = materielInfoService; - _stockDetailService = stockDetailService; - _stockService = stockInfoService; } - - } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/LocationStatusChangeRecordSetvice.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/LocationStatusChangeRecordSetvice.cs" index 219a70a..92b885c 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/LocationStatusChangeRecordSetvice.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/LocationStatusChangeRecordSetvice.cs" @@ -4,10 +4,12 @@ using System.Linq; using System.Text; using System.Threading.Tasks; +using WIDESEA_Common.LocationEnum; using WIDESEA_Core; using WIDESEA_Core.BaseServices; using WIDESEA_Core.DB; using WIDESEA_Core.Enums; +using WIDESEA_Core.Helper; using WIDESEA_Core.Seed; using WIDESEA_IRecordRepository; using WIDESEA_IRecordService; @@ -17,15 +19,15 @@ { public partial class LocationStatusChangeRecordSetvice : ServiceBase<Dt_LocationStatusChangeRecord, ILocationStatusChangeRecordRepository>, ILocationStatusChangeRecordSetvice { - public void AddLocationStatusChangeRecord(Dt_LocationInfo locationInfo, int lastStatus, int changeType, string? orderNo, int? taskNum) + public void AddLocationStatusChangeRecord(Dt_LocationInfo locationInfo, LocationStatusEnum lastStatus, LocationChangeType changeType, string? orderNo = null, int? taskNum = null) { try { Dt_LocationStatusChangeRecord locationStatusChangeRecord = new Dt_LocationStatusChangeRecord() { AfterStatus = locationInfo.LocationStatus, - BeforeStatus = lastStatus, - ChangeType = changeType, + BeforeStatus = lastStatus.ObjToInt(), + ChangeType = changeType.ObjToInt(), LocationCode = locationInfo.LocationCode, LocationId = locationInfo.Id, TaskNum = taskNum, @@ -42,7 +44,7 @@ } } - public void AddLocationStatusChangeRecord(List<Dt_LocationInfo> locationInfos, int newStatus, int changeType, string? orderNo, List<int>? taskNums) + public void AddLocationStatusChangeRecord(List<Dt_LocationInfo> locationInfos, LocationStatusEnum newStatus, LocationChangeType changeType, string? orderNo, List<int>? taskNums) { try { @@ -53,9 +55,9 @@ int? taskNum = (taskNums != null && taskNums.Count > 0 && taskNums.Count == locationInfos.Count) ? taskNums[i] : null; Dt_LocationStatusChangeRecord locationStatusChangeRecord = new Dt_LocationStatusChangeRecord() { - AfterStatus = newStatus, + AfterStatus = newStatus.ObjToInt(), BeforeStatus = locationInfo.LocationStatus, - ChangeType = changeType, + ChangeType = changeType.ObjToInt(), LocationCode = locationInfo.LocationCode, LocationId = locationInfo.Id, TaskNum = taskNum, @@ -78,7 +80,7 @@ WebResponseContent content = new WebResponseContent(); try { - List<Dt_LocationStatusChangeRecord> location=BaseDal.QueryData(x=>x.LocationId== id).OrderByDescending(x=>x.CreateDate).ToList(); + List<Dt_LocationStatusChangeRecord> location = BaseDal.QueryData(x => x.LocationId == id).OrderByDescending(x => x.CreateDate).ToList(); return content = WebResponseContent.Instance.OK(data: location); } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/StockQuantityChangeRecordService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/StockQuantityChangeRecordService.cs" index 58b1f41..be97eb1 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/StockQuantityChangeRecordService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_RecordService/Service/StockQuantityChangeRecordService.cs" @@ -16,14 +16,14 @@ { public partial class StockQuantityChangeRecordService : ServiceBase<Dt_StockQuantityChangeRecord, IStockQuantityChangeRecordRepository>, IStockQuantityChangeRecordService { - public void AddStockChangeRecord(Dt_StockInfo stockInfo, List<Dt_StockInfoDetail> stockInfoDetails, decimal beforeQuantity, decimal totalQuantity, StockChangeTypeEnum changeType,int taskNum) + public void AddStockChangeRecord(Dt_StockInfo stockInfo, List<Dt_StockInfoDetail> stockInfoDetails, float beforeQuantity, float totalQuantity, StockChangeTypeEnum changeType, int? taskNum = null) { - try - { + try + { List<Dt_StockQuantityChangeRecord> stockQuantityChangeRecords = new List<Dt_StockQuantityChangeRecord>(); stockQuantityChangeRecords = _mapper.Map<List<Dt_StockQuantityChangeRecord>>(stockInfoDetails); int index = 0; - decimal currentQuantity = 0; + float currentQuantity = 0; stockQuantityChangeRecords.ForEach(x => { x.PalleCode = stockInfo.PalletCode; @@ -47,10 +47,10 @@ }); BaseDal.AddData(stockQuantityChangeRecords); } - catch (Exception ex) - { - throw new Exception(ex.Message); - } + catch (Exception ex) + { + throw new Exception(ex.Message); + } } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockRepository/StockInfoRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockRepository/StockInfoRepository.cs" index 4acbcb8..a8c6814 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockRepository/StockInfoRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockRepository/StockInfoRepository.cs" @@ -30,14 +30,12 @@ return sugarQueryable.InnerJoin(sugarQueryable1, (a, b) => a.LocationCode == b.LocationCode).Select((a, b) => new StockViewDTO { - AreaId = a.AreaId, LocationCode = b.LocationCode, Column = a.Column, CreateDate = b.CreateDate, Creater = b.Creater, Depth = a.Depth, EnalbeStatus = a.EnableStatus, - IsFull = b.IsFull, Layer = a.Layer, LocationName = a.LocationName, LocationStatus = a.LocationStatus, diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfoService.cs" index 241afde..38019c6 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfoService.cs" @@ -24,18 +24,11 @@ { private readonly IMapper _mapper; - private readonly IBasicRepository _basicRepository; - private readonly IStockRepository _stockRepository; - private readonly IRecordService _recordService; - public IStockInfoRepository Repository => BaseDal; - public StockInfoService(IStockInfoRepository BaseDal, IMapper mapper, IBasicRepository basicRepository, IStockRepository stockRepository,IRecordService recordService) : base(BaseDal) + public StockInfoService(IStockInfoRepository BaseDal, IMapper mapper) : base(BaseDal) { _mapper = mapper; - _basicRepository = basicRepository; - _stockRepository = stockRepository; - _recordService = recordService; } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfo_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfo_HtyService.cs" index d268ece..316624f 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfo_HtyService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockInfo_HtyService.cs" @@ -23,19 +23,11 @@ public partial class StockInfo_HtyService : ServiceBase<Dt_StockInfo_Hty, IStockInfo_HtyRepository>, IStockInfo_HtyService { private readonly IMapper _mapper; - - private readonly IBasicRepository _basicRepository; - private readonly IStockRepository _stockRepository; - private readonly IRecordService _recordService; - public IStockInfo_HtyRepository Repository => BaseDal; - public StockInfo_HtyService(IStockInfo_HtyRepository BaseDal, IMapper mapper, IBasicRepository basicRepository, IStockRepository stockRepository, IRecordService recordService) : base(BaseDal) + public StockInfo_HtyService(IStockInfo_HtyRepository BaseDal, IMapper mapper) : base(BaseDal) { _mapper = mapper; - _basicRepository = basicRepository; - _stockRepository = stockRepository; - _recordService = recordService; } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockViewService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockViewService.cs" index e05fd63..9ecf3fd 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockViewService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Base/StockViewService.cs" @@ -55,14 +55,12 @@ List<StockViewDTO> list = sugarQueryable1.InnerJoin(sugarQueryable, (b, a) => a.LocationCode == b.LocationCode).WhereIF(!string.IsNullOrEmpty(where), where).Select((b, a) => new StockViewDTO { - AreaId = a.AreaId, LocationCode = b.LocationCode, Column = a.Column, CreateDate = b.CreateDate, Creater = b.Creater, Depth = a.Depth, EnalbeStatus = a.EnableStatus, - IsFull = b.IsFull, Layer = a.Layer, LocationName = a.LocationName, LocationStatus = a.LocationStatus, diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Service/StockInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Service/StockInfoService.cs" index 0fa3887..9203ffa 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Service/StockInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Service/StockInfoService.cs" @@ -23,53 +23,11 @@ { public partial class StockInfoService : ServiceBase<Dt_StockInfo, IStockInfoRepository>, IStockInfoService { - /// <summary> - /// 鏍规嵁鎵樼洏鍙锋煡璇㈠簱瀛� - /// </summary> - /// <param name="palletCode"></param> - /// <returns></returns> - public Dt_StockInfo? GetStockByPalletCode(string palletCode) - { - Dt_StockInfo stockInfo = BaseDal.QueryFirst(x => x.PalletCode == palletCode); - if (stockInfo != null) - { - stockInfo.Details = _stockRepository.StockInfoDetailRepository.QueryData(x => x.StockId == stockInfo.Id); - } - return stockInfo; - } - - public void AddMaterielGroup(Dt_StockInfo stockInfo) - { - decimal beforeQuantity = 0; - List<Dt_StockInfoDetail> details = new List<Dt_StockInfoDetail>(); - if (stockInfo.Id == 0) - { - BaseDal.Db.InsertNav(stockInfo).Include(x => x.Details).ExecuteCommand(); - details = stockInfo.Details; - } - else - { - beforeQuantity = stockInfo.Details.Where(x => x.Id != 0).Sum(x => x.StockQuantity); - - for (int i = 0; i < stockInfo.Details.Count; i++) - { - if (stockInfo.Details[i].Id == 0) - { - details.Add(_stockRepository.StockInfoDetailRepository.Db.Insertable(stockInfo.Details[i]).ExecuteReturnEntity()); - } - - } - - } - stockInfo.Details = details; - _recordService.StockQuantityChangeRecordService.AddStockChangeRecord(stockInfo, stockInfo.Details, beforeQuantity, stockInfo.Details.Sum(x => x.StockQuantity) + beforeQuantity, StockChangeTypeEnum.MaterielGroup,0); - } - - - public List<Dt_StockInfo> GetOutboundStocks(List<Dt_StockInfo> stockInfos, string materielCode, decimal needQuantity, out decimal residueQuantity) + + public List<Dt_StockInfo> GetOutboundStocks(List<Dt_StockInfo> stockInfos, string materielCode, float needQuantity, out float residueQuantity) { List<Dt_StockInfo> outStocks = new List<Dt_StockInfo>(); - decimal stockTotalQuantity = stockInfos.Select(x => x.Details.Sum(v => v.StockQuantity - v.OutboundQuantity)).Sum(x => x); + float stockTotalQuantity = stockInfos.Select(x => x.Details.Sum(v => v.StockQuantity - v.OutboundQuantity)).Sum(x => x); stockInfos = stockInfos.OrderBy(x => x.Id).ToList(); if (stockTotalQuantity >= needQuantity)//搴撳瓨澶� { @@ -78,7 +36,7 @@ { Dt_StockInfo stockInfo = stockInfos[index]; - decimal useableStockQuantity = stockInfo.Details.Where(x => x.MaterielCode == materielCode).Sum(x => x.StockQuantity - x.OutboundQuantity); + float useableStockQuantity = stockInfo.Details.Where(x => x.MaterielCode == materielCode).Sum(x => x.StockQuantity - x.OutboundQuantity); if (useableStockQuantity < needQuantity) { stockInfo.Details.ForEach(x => x.OutboundQuantity = x.StockQuantity); @@ -112,7 +70,7 @@ for (int i = 0; i < stockInfos.Count; i++) { Dt_StockInfo stockInfo = stockInfos[i]; - decimal useableStockQuantity = stockInfo.Details.Where(x => x.MaterielCode == materielCode).Sum(x => x.StockQuantity - x.OutboundQuantity); + float useableStockQuantity = stockInfo.Details.Where(x => x.MaterielCode == materielCode).Sum(x => x.StockQuantity - x.OutboundQuantity); if (useableStockQuantity < needQuantity) { stockInfo.Details.ForEach(x => x.OutboundQuantity = x.StockQuantity); diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_DictionaryRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_DictionaryRepository.cs" index a235134..21056ac 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_DictionaryRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_DictionaryRepository.cs" @@ -13,11 +13,8 @@ { public class Sys_DictionaryRepository : RepositoryBase<Sys_Dictionary>, ISys_DictionaryRepository { - - public Sys_DictionaryRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) { - } /// <summary> @@ -58,7 +55,7 @@ } catch (Exception ex) { - throw ex; + return new List<Sys_DictionaryList>(); } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_RoleDataPermissionRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_RoleDataPermissionRepository.cs" new file mode 100644 index 0000000..ac429c2 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_RoleDataPermissionRepository.cs" @@ -0,0 +1,18 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEA_Core.BaseRepository; +using WIDESEA_ISystemRepository; +using WIDESEA_Model.Models; + +namespace WIDESEA_SystemRepository +{ + public class Sys_RoleDataPermissionRepository : RepositoryBase<Sys_RoleDataPermission>, ISys_RoleDataPermissionRepository + { + public Sys_RoleDataPermissionRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage) + { + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_UserRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_UserRepository.cs" index b9d6a7a..e712524 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_UserRepository.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemRepository/Sys_UserRepository.cs" @@ -20,7 +20,7 @@ public UserInfo GetUserInfo(string userName, string password) { - return QueryFirst(x => x.UserName == userName && x.UserPwd == password, x => new UserInfo { HeadImageUrl = x.HeadImageUrl, RoleId = x.Role_Id, TenantId = x.TenantId, UserId = x.User_Id, UserName = x.UserName, UserTrueName = x.UserTrueName }); + return QueryFirst(x => x.UserName == userName && x.UserPwd == password, x => new UserInfo { HeadImageUrl = x.HeadImageUrl, RoleId = x.RoleId, TenantId = x.TenantId, UserId = x.UserId, UserName = x.UserName, UserTrueName = x.UserTrueName }); } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_DictionaryService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_DictionaryService.cs" index 469aaf4..effa323 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_DictionaryService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_DictionaryService.cs" @@ -1,5 +1,6 @@ 锘縰sing Newtonsoft.Json; using OfficeOpenXml.FormulaParsing.Excel.Functions.Information; +using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; using System; using System.Collections.Generic; using System.ComponentModel; @@ -19,7 +20,9 @@ using WIDESEA_Core.DB; using WIDESEA_Core.Enums; using WIDESEA_Core.Helper; +using WIDESEA_Core.Utilities; using WIDESEA_DTO.System; +using WIDESEA_IBasicRepository; using WIDESEA_ISystemRepository; using WIDESEA_ISystemService; using WIDESEA_Model.Models; @@ -30,19 +33,31 @@ { private readonly IUnitOfWorkManage _unitOfWorkManage; private readonly ICacheService _cacheService; + private readonly IBasicRepository _basicRepository; + private readonly ISys_RoleDataPermissionRepository _roleDataPermissionRepository; - public Sys_DictionaryService(ISys_DictionaryRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, ICacheService cacheService) : base(BaseDal) + public Sys_DictionaryService(ISys_DictionaryRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, ICacheService cacheService, IBasicRepository basicRepository, ISys_RoleDataPermissionRepository roleDataPermissionRepository) : base(BaseDal) { _unitOfWorkManage = unitOfWorkManage; _cacheService = cacheService; + _basicRepository = basicRepository; + _roleDataPermissionRepository = roleDataPermissionRepository; } public ISys_DictionaryRepository Repository => BaseDal; public override WebResponseContent AddData(SaveModel saveModel) { + string validResult = typeof(Sys_Dictionary).ValidateDicInEntity(saveModel.MainData, true, TProperties); + + if (!string.IsNullOrEmpty(validResult)) + { + return WebResponseContent.Instance.Error(validResult); + } + Sys_Dictionary dictionary = saveModel.MainData.DicToModel<Sys_Dictionary>(); - _cacheService.Remove(dictionary.DicNo); + if (!string.IsNullOrEmpty(_cacheService.Get(dictionary.DicNo))) + _cacheService.Remove(dictionary.DicNo); return base.AddData(saveModel); } @@ -80,12 +95,13 @@ DicNo = s.DicNo, Config = s.Config, //dbSql = s.Sql, - Data = s.DicList.OrderByDescending(o => o.OrderNo).Select(list => new { key = list.DicValue, value = list.DicName }) + Data = s.DicList.OrderByDescending(o => o.OrderNo).Select(list => new { key = list.DicValue, value = list.DicName }), + SaveCache = false }).ToList(); foreach (var item in selectDics) { - if (!_cacheService.Exists(item.DicNo)) + if (!_cacheService.Exists(item.DicNo) && item.SaveCache) { _cacheService.Add(item.DicNo, item.Serialize()); } @@ -122,8 +138,11 @@ foreach (var item in dics) { - dicList.Remove(item); - cusDics.Add(item); + if (dicNos.Contains(item) && !cacheDicNos.Contains(item)) + { + dicList.Remove(item); + cusDics.Add(item); + } } foreach (var item in cusDics) @@ -132,7 +151,7 @@ if (vueDictionaryDTO != null) { vueDictionaryDTOs.Add(vueDictionaryDTO); - if (!_cacheService.Exists(item)) + if (!_cacheService.Exists(item) && vueDictionaryDTO.SaveCache) { _cacheService.Add(item, vueDictionaryDTO.Serialize()); } @@ -564,6 +583,71 @@ result = new VueDictionaryDTO { DicNo = key, Config = "", Data = data }; } break; + case "receiveOrderTypeEnum": + { + List<object> data = new List<object>(); + + { + Type type = typeof(ReceiveOrderTypeEnum); + List<int> enums = Enum.GetValues(typeof(ReceiveOrderTypeEnum)).Cast<int>().ToList(); + int index = 0; + foreach (var item in enums) + { + FieldInfo? fieldInfo = typeof(ReceiveOrderTypeEnum).GetField(((ReceiveOrderTypeEnum)item).ToString()); + DescriptionAttribute? description = fieldInfo.GetCustomAttribute<DescriptionAttribute>(); + if (description != null) + { + data.Add(new { key = item.ToString(), value = description.Description }); + } + else + { + data.Add(new { key = item.ToString(), value = item.ToString() }); + } + index++; + } + } + + result = new VueDictionaryDTO { DicNo = key, Config = "", Data = data }; + } + break; + case "authorityScope": + { + if (App.User.IsSuperAdmin) + { + List<Dt_Warehouse> warehouses = _basicRepository.WarehouseRepository.QueryData(x => true); + var data = warehouses.Select(x => new { key = x.WarehouseId, value = x.WarehouseName }); + result = new VueDictionaryDTO { DicNo = key, Config = "", Data = data }; + } + else + { + List<Sys_RoleDataPermission> roleDataPermissions = _roleDataPermissionRepository.QueryData(x => x.RoleId == App.User.RoleId); + var data = roleDataPermissions.Select(x => new { key = x.WarehouseId, value = x.WarehouseName }); + result = new VueDictionaryDTO { DicNo = key, Config = "", Data = data }; + } + } + break; + case "authorityScopes": + { + List<Sys_Role> roles = Repository.Db.Queryable<Sys_Role>().ToList(); + List<object> data = new List<object>(); + foreach (var item in roles) + { + List<Sys_RoleDataPermission> roleDataPermissions = _roleDataPermissionRepository.QueryData(x => x.RoleId == item.RoleId); + string value = ""; + foreach (var roleDataPermission in roleDataPermissions) + { + value += (roleDataPermission.WarehouseName + ","); + } + if (roleDataPermissions.Count > 0) + data.Add(new { key = item.RoleId, value = value.Substring(0, value.Length - 1) }); + else + data.Add(new { key = item.RoleId, value = "鏃犳潈闄�" }); + } + data.Add(new { key = -1, value = "鏃犳潈闄�" }); + result = new VueDictionaryDTO { DicNo = key, Config = "", Data = data, SaveCache = false }; + } + + break; } return result; } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_RoleService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_RoleService.cs" index 030a5ea..ff749a1 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_RoleService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_RoleService.cs" @@ -15,6 +15,7 @@ using WIDESEA_Model.Models; using WIDESEA_Model.Models.System; using WIDESEA_SystemRepository; +using WIDESEA_Core.Helper; namespace WIDESEA_SystemService { @@ -35,6 +36,89 @@ _RoleAuthRepository = roleAuthRepository; } + public override WebResponseContent AddData(SaveModel saveModel) + { + string authorityScope = saveModel.MainData["authorityScope"].ToString(); + Sys_Role role = saveModel.MainData.DicToModel<Sys_Role>(); + if (BaseDal.QueryFirst(x => x.RoleName == role.RoleName) != null) + { + return WebResponseContent.Instance.Error($"瑙掕壊鍚嶉噸澶�"); + } + List<Dt_Warehouse> warehouses = BaseDal.Db.Queryable<Dt_Warehouse>().Where(x => true).ToList(); + List<Sys_RoleDataPermission> roleDataPermissions = new List<Sys_RoleDataPermission>(); + if (!string.IsNullOrEmpty(authorityScope)) + { + string[] scopes = authorityScope.Split(','); + foreach (string scope in scopes) + { + Dt_Warehouse? warehouse = warehouses.FirstOrDefault(x => x.WarehouseId == Convert.ToInt32(scope)); + if (warehouse != null) + { + roleDataPermissions.Add(new Sys_RoleDataPermission + { + WarehouseId = warehouse.WarehouseId, + WarehouseName = warehouse.WarehouseName, + RoleName = role.RoleName + }); + } + } + } + + int roleId = BaseDal.AddData(role); + if (roleDataPermissions.Count > 0) + { + roleDataPermissions.ForEach(x => { x.RoleId = roleId; }); + BaseDal.Db.Insertable(roleDataPermissions).ExecuteCommand(); + } + + return WebResponseContent.Instance.OK(); + } + + public override WebResponseContent UpdateData(SaveModel saveModel) + { + string authorityScope = saveModel.MainData["authorityScope"].ToString(); + Sys_Role role = saveModel.MainData.DicToModel<Sys_Role>(); + if (BaseDal.QueryFirst(x => x.RoleId == role.RoleId) == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌鏁版嵁"); + } + List<Dt_Warehouse> warehouses = BaseDal.Db.Queryable<Dt_Warehouse>().Where(x => true).ToList(); + + List<Sys_RoleDataPermission> oldDatas = BaseDal.Db.Queryable<Sys_RoleDataPermission>().Where(x => x.RoleId == role.RoleId).ToList(); + List<Sys_RoleDataPermission> roleDataPermissions = new List<Sys_RoleDataPermission>(); + if (!string.IsNullOrEmpty(authorityScope)) + { + string[] scopes = authorityScope.Split(','); + foreach (string scope in scopes) + { + Sys_RoleDataPermission? oldData = oldDatas.FirstOrDefault(x => x.WarehouseId == Convert.ToInt32(scope)); + if (oldData == null) + { + Dt_Warehouse? warehouse = warehouses.FirstOrDefault(x => x.WarehouseId == Convert.ToInt32(scope)); + if (warehouse != null) + { + roleDataPermissions.Add(new Sys_RoleDataPermission + { + WarehouseId = warehouse.WarehouseId, + WarehouseName = warehouse.WarehouseName, + RoleName = role.RoleName + }); + } + } + else + { + oldDatas.Remove(oldData); + } + } + } + + roleDataPermissions.ForEach(x => { x.RoleId = role.RoleId; }); + BaseDal.Db.Insertable(roleDataPermissions).ExecuteCommand(); + BaseDal.Db.Deleteable(oldDatas).ExecuteCommand(); + + return WebResponseContent.Instance.OK(); + } + public List<RoleNodes> GetAllChildren(int roleId) { if (roleId <= 0) return new List<RoleNodes>() { }; @@ -45,7 +129,7 @@ return list; } - public List<RoleNodes> GetAllRoleId() + public List<RoleNodes> GetAllRoleId() { List<RoleNodes> roles = BaseDal.QueryData().Select(s => new RoleNodes() { Id = s.RoleId, ParentId = s.ParentId, RoleName = s.RoleName }).ToList(); @@ -110,7 +194,7 @@ //鑾峰彇鐢ㄦ埛鏉冮檺 List<Permissions> permissions = _MenuRepository.GetPermissions(roleId); //鏉冮檺鐢ㄦ埛鏉冮檺鏌ヨ鎵�鏈夌殑鑿滃崟淇℃伅 - List<MenuDTO> menus = _MenuService.GetUserMenuList(roleId); + List<MenuDTO> menus = _MenuService.GetUserMenuList(roleId); //鑾峰彇褰撳墠鐢ㄦ埛鏉冮檺濡�:(Add,Search)瀵瑰簲鐨勬樉绀烘枃鏈俊鎭:Add锛氭坊鍔狅紝Search:鏌ヨ var data = menus.Select(x => new { @@ -156,7 +240,7 @@ List<MenuDTO> menus = _MenuService.GetUserMenuListPDA(roleId); //鑾峰彇褰撳墠鐢ㄦ埛鏉冮檺濡�:(Add,Search)瀵瑰簲鐨勬樉绀烘枃鏈俊鎭:Add锛氭坊鍔狅紝Search:鏌ヨ - var data = menus.Where(x => x.MenuType==1).Select(x => new + var data = menus.Where(x => x.MenuType == 1).Select(x => new { Id = x.MenuId, Pid = x.ParentId, @@ -243,7 +327,7 @@ int addCount = updateAuths.Where(x => x.AuthId <= 0).Count(); int updateCount = updateAuths.Where(x => x.AuthId > 0).Count(); - + string _version = DateTime.Now.ToString("yyyyMMddHHMMssfff"); diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_UserService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_UserService.cs" index 11f2d94..d62b1ee 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_UserService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/Sys_UserService.cs" @@ -13,6 +13,7 @@ using WIDESEA_Core.Caches; using SqlSugar; using ICacheService = WIDESEA_Core.Caches.ICacheService; +using HslCommunication.WebSocket; namespace WIDESEA_SystemService { @@ -74,7 +75,7 @@ _cacheService.AddOrUpdate(user.UserId.ToString(), token); - content = WebResponseContent.Instance.OK(data: new { token, userName = user.UserTrueName, img = user.HeadImageUrl }); + content = WebResponseContent.Instance.OK(data: new { token, userName = user.UserName, img = user.HeadImageUrl }); } else { @@ -125,7 +126,7 @@ /// <returns></returns> public WebResponseContent GetCurrentUserInfo() { - var data = BaseDal.QueryFirst(x => x.User_Id == App.User.UserId, s => new + var data = BaseDal.QueryFirst(x => x.UserId == App.User.UserId, s => new { s.UserName, s.UserTrueName, @@ -159,7 +160,7 @@ if (newPwd.Length < 6) return WebResponseContent.Instance.Error("瀵嗙爜涓嶈兘灏戜簬6浣�"); int userId = App.User.UserId; - string userCurrentPwd = BaseDal.QueryFirst(x => x.User_Id == userId, s => s.UserPwd); + string userCurrentPwd = BaseDal.QueryFirst(x => x.UserId == userId, s => s.UserPwd); string _oldPwd = oldPwd.EncryptDES(AppSecret.User); if (_oldPwd != userCurrentPwd) return WebResponseContent.Instance.Error("鏃у瘑鐮佷笉姝g‘"); @@ -170,7 +171,7 @@ BaseDal.UpdateData(new Sys_User { - User_Id = userId, + UserId = userId, UserPwd = _newPwd, LastModifyPwdDate = DateTime.Now }, new List<string> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/WIDESEA_SystemService.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/WIDESEA_SystemService.csproj" index 37aa4de..32c2e5c 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/WIDESEA_SystemService.csproj" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_SystemService/WIDESEA_SystemService.csproj" @@ -7,6 +7,7 @@ </PropertyGroup> <ItemGroup> + <ProjectReference Include="..\WIDESEA_IBasicRepository\WIDESEA_IBasicRepository.csproj" /> <ProjectReference Include="..\WIDESEA_ISystemService\WIDESEA_ISystemService.csproj" /> </ItemGroup> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs" index 7198373..979eedc 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs" @@ -16,6 +16,7 @@ #endregion << 鐗� 鏈� 娉� 閲� >> using AutoMapper; +using HslCommunication.WebSocket; using MailKit.Search; using Newtonsoft.Json; using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; @@ -31,6 +32,10 @@ using System.Reflection.Metadata; using System.Text; using System.Threading.Tasks; +using WIDESEA_Common.CommonEnum; +using WIDESEA_Common.LocationEnum; +using WIDESEA_Common.StockEnum; +using WIDESEA_Common.TaskEnum; using WIDESEA_Core; using WIDESEA_Core.BaseRepository; using WIDESEA_Core.BaseServices; @@ -58,30 +63,154 @@ { private readonly IMapper _mapper; private readonly IUnitOfWorkManage _unitOfWorkManage; - + private readonly IStockRepository _stockRepository; private readonly IBasicService _basicService; - private readonly IOutboundService _outboundService; - private readonly IInboundService _inboundService; private readonly IRecordService _recordService; - private readonly IStockService _stockService; - private readonly ITask_HtyService _taskHtyService; - private readonly ILocationInfoService _locationInfoService; public ITaskRepository Repository => BaseDal; - public TaskService(ITaskRepository BaseDal, IMapper mapper, IUnitOfWorkManage unitOfWorkManage, IBasicService basicService, IOutboundService outboundService, IInboundService inboundService, IRecordService recordService, IStockService stockService, ITask_HtyService taskHtyService, ILocationInfoService locationInfoService) : base(BaseDal) + public TaskService(ITaskRepository BaseDal, IMapper mapper, IUnitOfWorkManage unitOfWorkManage, IStockRepository stockRepository, IBasicService basicService, IRecordService recordService) : base(BaseDal) { _mapper = mapper; _unitOfWorkManage = unitOfWorkManage; + _stockRepository = stockRepository; _basicService = basicService; - _outboundService = outboundService; - _inboundService = inboundService; _recordService = recordService; - _stockService = stockService; - _taskHtyService = taskHtyService; - _locationInfoService = locationInfoService; } - + public WebResponseContent RequestInboundTask(string palletCode, string stationCode) + { + try + { + Dt_Task task = Repository.QueryFirst(x => x.PalletCode == palletCode); + if (task != null) + { + return WebResponseContent.Instance.Error($"璇ユ墭鐩樺凡鐢熸垚浠诲姟"); + } + + Dt_StockInfo stockInfo = _stockRepository.StockInfoRepository.QueryFirst(x => x.PalletCode == palletCode); + if (stockInfo == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒扮粍鐩樹俊鎭�"); + } + if (stockInfo.StockStatus != StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璇ユ墭鐩樼姸鎬佷笉姝g‘,涓嶅彲鐢宠鍏ュ簱"); + } + if (!string.IsNullOrEmpty(stockInfo.LocationCode)) + { + return WebResponseContent.Instance.Error($"璇ユ墭鐩樺凡缁戝畾璐т綅"); + } + + //todo 閫氳繃绔欏彴鍙锋壘宸烽亾鍙� + string roadwayNo = "RSC01"; + + PalletTypeEnum palletType = PalletTypeEnum.SmallPallet; + + Dt_LocationInfo? locationInfo = _basicService.LocationInfoService.AssignLocation(roadwayNo, palletType); + if (locationInfo == null) + { + return WebResponseContent.Instance.Error($"璐т綅鍒嗛厤澶辫触,鏈壘鍒板彲鍒嗛厤璐т綅"); + } + Dt_Task newTask = new Dt_Task() + { + CurrentAddress = stationCode, + Grade = 0, + NextAddress = "", + PalletCode = palletCode, + Roadway = roadwayNo, + SourceAddress = stationCode, + TargetAddress = locationInfo.LocationCode, + TaskType = TaskTypeEnum.Inbound.ObjToInt(), + TaskStatus = InTaskStatusEnum.InNew.ObjToInt(), + }; + + LocationStatusEnum lastStatus = (LocationStatusEnum)locationInfo.LocationStatus; + + stockInfo.StockStatus = StockStatusEmun.鍏ュ簱纭.ObjToInt(); + + _unitOfWorkManage.BeginTran(); + int taskId = BaseDal.AddData(newTask); + newTask.TaskId = taskId; + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, lastStatus, LocationChangeType.InboundAssignLocation); + _basicService.LocationInfoService.UpdateLocationStatus(locationInfo, palletType, LocationStatusEnum.Lock); + _stockRepository.StockInfoRepository.UpdateData(stockInfo); + _unitOfWorkManage.CommitTran(); + + return WebResponseContent.Instance.OK(data: newTask); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } + + public WebResponseContent InboundTaskCompleted(int taskNum) + { + try + { + Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); + if (task == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌浠诲姟淇℃伅"); + } + + if (task.TaskType != TaskTypeEnum.Inbound.ObjToInt()) + { + return WebResponseContent.Instance.Error($"浠诲姟绫诲瀷閿欒"); + } + + Dt_StockInfo stockInfo = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Where(x => x.PalletCode == task.PalletCode).Includes(x => x.Details).First(); + if (stockInfo == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒版墭鐩樺搴旂殑缁勭洏淇℃伅"); + } + + if (!string.IsNullOrEmpty(stockInfo.LocationCode)) + { + return WebResponseContent.Instance.Error($"璇ユ墭鐩樺凡缁戝畾璐т綅"); + } + + if (stockInfo.Details == null || stockInfo.Details.Count == 0) + { + return WebResponseContent.Instance.Error($"鏈壘鍒拌鎵樼洏搴撳瓨鏄庣粏淇℃伅"); + } + + Dt_LocationInfo locationInfo = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == task.TargetAddress); + if (locationInfo == null) + { + return WebResponseContent.Instance.Error($"鏈壘鍒扮洰鏍囪揣浣嶄俊鎭�"); + } + + if (locationInfo.LocationStatus == LocationStatusEnum.InStock.ObjToInt()) + { + return WebResponseContent.Instance.Error($"璐т綅鐘舵�佷笉姝g‘"); + } + + + LocationStatusEnum lastStatus = (LocationStatusEnum)locationInfo.LocationStatus; + locationInfo.LocationStatus = LocationStatusEnum.InStock.ObjToInt(); + + stockInfo.StockStatus = StockStatusEmun.鍏ュ簱瀹屾垚.ObjToInt(); + stockInfo.LocationCode = locationInfo.LocationCode; + + _unitOfWorkManage.BeginTran(); + BaseDal.DeleteAndMoveIntoHty(task, App.User.UserId > 0 ? OperateTypeEnum.浜哄伐瀹屾垚 : OperateTypeEnum.鑷姩瀹屾垚); + + _basicService.LocationInfoService.Repository.UpdateData(locationInfo); + + _stockRepository.StockInfoRepository.UpdateData(stockInfo); + + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, lastStatus, LocationChangeType.InboundAssignLocation); + _unitOfWorkManage.CommitTran(); + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/Task_HtyService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/Task_HtyService.cs" index cb9a605..4c19bec 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/Task_HtyService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/Task_HtyService.cs" @@ -36,44 +36,9 @@ public class Task_HtyService : ServiceBase<Dt_Task_Hty, ITask_HtyRepository>, ITask_HtyService { - public Task_HtyService(ITask_HtyRepository BaseDal - ) : base(BaseDal) + public Task_HtyService(ITask_HtyRepository BaseDal) : base(BaseDal) { } - /// <summary> - /// 娣诲姞鍘嗗彶浠诲姟 - /// </summary> - /// <param name="task">鍘嗗彶浠诲姟Model</param> - /// <returns>鎴愬姛/澶辫触</returns> - public bool InsertTask(Dt_Task_Hty task) - { - return BaseDal.InsertTask(task); - } - public WebResponseContent AddTaskHty(Dt_Task task) - { - WebResponseContent content = new WebResponseContent(); - Dt_Task_Hty task_Hty = new Dt_Task_Hty() - { - TaskNum = task.TaskNum, - PalletCode = task.PalletCode, - Roadway = task.Roadway, - TaskType = task.TaskType, - TaskStatus = task.TaskStatus, - SourceAddress = task.SourceAddress, - TargetAddress = task.TargetAddress, - CurrentAddress = task.CurrentAddress, - NextAddress = task.NextAddress, - Grade = task.Grade, - Dispatchertime = task.Dispatchertime, - Creater =task.Creater, - CreateDate = task.CreateDate, - ModifyDate = DateTime.Now, - Modifier = task.Modifier, - Remark = task.Remark - }; - BaseDal.AddData(task_Hty); - return content; - } } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer.sln" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer.sln" index 47f67cc..d4f7b94 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer.sln" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer.sln" @@ -106,7 +106,31 @@ EndProject Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WIDESEA_RecordService", "WIDESEA_RecordService\WIDESEA_RecordService.csproj", "{A343A2C5-995D-45F1-A3E5-20495DD3F615}" EndProject -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "WIDESEA_External", "WIDESEA_External\WIDESEA_External.csproj", "{057A7FCF-C9E8-4F73-8420-D05DCB2F235A}" +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WIDESEA_External", "WIDESEA_External\WIDESEA_External.csproj", "{057A7FCF-C9E8-4F73-8420-D05DCB2F235A}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Approval", "Approval", "{34DAE761-8A96-4115-B8DC-1383E2BC1A9B}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Approval", "Approval", "{A4B02B5A-17C9-42A1-B100-7BA30AE2044E}" +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WIDESEA_ApprovalRepository", "WIDESEA_ApprovalRepository\WIDESEA_ApprovalRepository.csproj", "{FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}" +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WIDESEA_IApprovalRepository", "WIDESEA_IApprovalRepository\WIDESEA_IApprovalRepository.csproj", "{444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}" +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WIDESEA_ApprovalService", "WIDESEA_ApprovalService\WIDESEA_ApprovalService.csproj", "{C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}" +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WIDESEA_IApprovalService", "WIDESEA_IApprovalService\WIDESEA_IApprovalService.csproj", "{E94ACE0E-654C-4497-8630-BA58D3FC2352}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Check", "Check", "{74ED4D60-A957-45E5-AA8E-D3CEFCA623FF}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Check", "Check", "{294A53A4-1311-4B71-A812-378A2BCB8346}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "WIDESEA_ICheckRepository", "WIDESEA_ICheckRepository\WIDESEA_ICheckRepository.csproj", "{99CC638D-C804-4FC0-95C1-E110A53C3DAE}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "WIDESEA_CheckRepository", "WIDESEA_CheckRepository\WIDESEA_CheckRepository.csproj", "{99AD01D6-5942-449E-9E73-10501C570066}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "WIDESEA_ICheckService", "WIDESEA_ICheckService\WIDESEA_ICheckService.csproj", "{82EBBC95-FD6E-4E30-9F21-625DE1991C2C}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "WIDESEA_CheckService", "WIDESEA_CheckService\WIDESEA_CheckService.csproj", "{C57C16CE-88A7-499A-8CE1-855D55482891}" EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution @@ -526,6 +550,102 @@ {057A7FCF-C9E8-4F73-8420-D05DCB2F235A}.Release|Any CPU.Build.0 = Release|Any CPU {057A7FCF-C9E8-4F73-8420-D05DCB2F235A}.Release|x86.ActiveCfg = Release|Any CPU {057A7FCF-C9E8-4F73-8420-D05DCB2F235A}.Release|x86.Build.0 = Release|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Debug|Any CPU.Build.0 = Debug|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Debug|x86.ActiveCfg = Debug|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Debug|x86.Build.0 = Debug|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Dev|Any CPU.ActiveCfg = Debug|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Dev|Any CPU.Build.0 = Debug|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Dev|x86.ActiveCfg = Debug|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Dev|x86.Build.0 = Debug|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Release|Any CPU.ActiveCfg = Release|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Release|Any CPU.Build.0 = Release|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Release|x86.ActiveCfg = Release|Any CPU + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8}.Release|x86.Build.0 = Release|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Debug|Any CPU.Build.0 = Debug|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Debug|x86.ActiveCfg = Debug|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Debug|x86.Build.0 = Debug|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Dev|Any CPU.ActiveCfg = Debug|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Dev|Any CPU.Build.0 = Debug|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Dev|x86.ActiveCfg = Debug|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Dev|x86.Build.0 = Debug|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Release|Any CPU.ActiveCfg = Release|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Release|Any CPU.Build.0 = Release|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Release|x86.ActiveCfg = Release|Any CPU + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133}.Release|x86.Build.0 = Release|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Debug|x86.ActiveCfg = Debug|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Debug|x86.Build.0 = Debug|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Dev|Any CPU.ActiveCfg = Debug|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Dev|Any CPU.Build.0 = Debug|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Dev|x86.ActiveCfg = Debug|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Dev|x86.Build.0 = Debug|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Release|Any CPU.ActiveCfg = Release|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Release|Any CPU.Build.0 = Release|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Release|x86.ActiveCfg = Release|Any CPU + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086}.Release|x86.Build.0 = Release|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Debug|Any CPU.Build.0 = Debug|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Debug|x86.ActiveCfg = Debug|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Debug|x86.Build.0 = Debug|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Dev|Any CPU.ActiveCfg = Debug|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Dev|Any CPU.Build.0 = Debug|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Dev|x86.ActiveCfg = Debug|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Dev|x86.Build.0 = Debug|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Release|Any CPU.ActiveCfg = Release|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Release|Any CPU.Build.0 = Release|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Release|x86.ActiveCfg = Release|Any CPU + {E94ACE0E-654C-4497-8630-BA58D3FC2352}.Release|x86.Build.0 = Release|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Debug|Any CPU.Build.0 = Debug|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Debug|x86.ActiveCfg = Debug|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Debug|x86.Build.0 = Debug|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Dev|Any CPU.ActiveCfg = Debug|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Dev|Any CPU.Build.0 = Debug|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Dev|x86.ActiveCfg = Debug|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Dev|x86.Build.0 = Debug|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Release|Any CPU.ActiveCfg = Release|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Release|Any CPU.Build.0 = Release|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Release|x86.ActiveCfg = Release|Any CPU + {99CC638D-C804-4FC0-95C1-E110A53C3DAE}.Release|x86.Build.0 = Release|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Debug|Any CPU.Build.0 = Debug|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Debug|x86.ActiveCfg = Debug|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Debug|x86.Build.0 = Debug|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Dev|Any CPU.ActiveCfg = Debug|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Dev|Any CPU.Build.0 = Debug|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Dev|x86.ActiveCfg = Debug|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Dev|x86.Build.0 = Debug|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Release|Any CPU.ActiveCfg = Release|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Release|Any CPU.Build.0 = Release|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Release|x86.ActiveCfg = Release|Any CPU + {99AD01D6-5942-449E-9E73-10501C570066}.Release|x86.Build.0 = Release|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Debug|Any CPU.Build.0 = Debug|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Debug|x86.ActiveCfg = Debug|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Debug|x86.Build.0 = Debug|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Dev|Any CPU.ActiveCfg = Debug|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Dev|Any CPU.Build.0 = Debug|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Dev|x86.ActiveCfg = Debug|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Dev|x86.Build.0 = Debug|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Release|Any CPU.ActiveCfg = Release|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Release|Any CPU.Build.0 = Release|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Release|x86.ActiveCfg = Release|Any CPU + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C}.Release|x86.Build.0 = Release|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Debug|x86.ActiveCfg = Debug|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Debug|x86.Build.0 = Debug|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Dev|Any CPU.ActiveCfg = Debug|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Dev|Any CPU.Build.0 = Debug|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Dev|x86.ActiveCfg = Debug|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Dev|x86.Build.0 = Debug|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Release|Any CPU.ActiveCfg = Release|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Release|Any CPU.Build.0 = Release|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Release|x86.ActiveCfg = Release|Any CPU + {C57C16CE-88A7-499A-8CE1-855D55482891}.Release|x86.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE @@ -573,6 +693,18 @@ {E2B7D8DF-7063-4FD7-B131-FF0D6F618F82} = {9EA9D98F-8AA3-444B-B08D-9F5727C3D1C2} {6E0E5856-A399-4791-9EAD-84ABC43F35AA} = {551C56D1-8642-4391-B478-A1BC51D63F98} {A343A2C5-995D-45F1-A3E5-20495DD3F615} = {551C56D1-8642-4391-B478-A1BC51D63F98} + {34DAE761-8A96-4115-B8DC-1383E2BC1A9B} = {56D014A3-EB8D-4EF5-A751-3BAA084519D0} + {A4B02B5A-17C9-42A1-B100-7BA30AE2044E} = {60DE2920-37C6-4C2B-A053-6B1B2DAF047A} + {FB8C37E4-0AE6-4D97-A2DF-E98AB88D6EB8} = {34DAE761-8A96-4115-B8DC-1383E2BC1A9B} + {444FB2E0-20C4-4D01-BB8E-DDDAF7C58133} = {34DAE761-8A96-4115-B8DC-1383E2BC1A9B} + {C9B26364-F5BE-4F5B-BB23-E0B1C2E08086} = {A4B02B5A-17C9-42A1-B100-7BA30AE2044E} + {E94ACE0E-654C-4497-8630-BA58D3FC2352} = {A4B02B5A-17C9-42A1-B100-7BA30AE2044E} + {74ED4D60-A957-45E5-AA8E-D3CEFCA623FF} = {56D014A3-EB8D-4EF5-A751-3BAA084519D0} + {294A53A4-1311-4B71-A812-378A2BCB8346} = {60DE2920-37C6-4C2B-A053-6B1B2DAF047A} + {99CC638D-C804-4FC0-95C1-E110A53C3DAE} = {74ED4D60-A957-45E5-AA8E-D3CEFCA623FF} + {99AD01D6-5942-449E-9E73-10501C570066} = {74ED4D60-A957-45E5-AA8E-D3CEFCA623FF} + {82EBBC95-FD6E-4E30-9F21-625DE1991C2C} = {294A53A4-1311-4B71-A812-378A2BCB8346} + {C57C16CE-88A7-499A-8CE1-855D55482891} = {294A53A4-1311-4B71-A812-378A2BCB8346} EndGlobalSection GlobalSection(ExtensibilityGlobals) = postSolution SolutionGuid = {599A7267-7402-4143-84AE-9B407FC2BB69} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Approval/ApprovalFlowController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Approval/ApprovalFlowController.cs" new file mode 100644 index 0000000..647acf8 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Approval/ApprovalFlowController.cs" @@ -0,0 +1,18 @@ +锘縰sing Microsoft.AspNetCore.Http; +using Microsoft.AspNetCore.Mvc; +using WIDESEA_Core.BaseController; +using WIDESEA_IApprovalService; +using WIDESEA_Model.Models; + +namespace WIDESEA_WMSServer.Controllers.Approval +{ + [Route("api/ApprovalFlow")] + [ApiController] + public class ApprovalFlowController : ApiBaseController<IApprovalFlowService, Dt_ApprovalFlow> + { + public ApprovalFlowController(IApprovalFlowService service) : base(service) + { + + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Approval/ApprovalTaskController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Approval/ApprovalTaskController.cs" new file mode 100644 index 0000000..d9c631b --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Approval/ApprovalTaskController.cs" @@ -0,0 +1,30 @@ +锘縰sing Microsoft.AspNetCore.Http; +using Microsoft.AspNetCore.Mvc; +using WIDESEA_Core; +using WIDESEA_Core.BaseController; +using WIDESEA_IApprovalService; +using WIDESEA_Model.Models; + +namespace WIDESEA_WMSServer.Controllers.Approval +{ + [Route("api/[controller]")] + [ApiController] + public class ApprovalTaskController : ApiBaseController<IApprovalTaskService, Dt_ApprovalTask> + { + public ApprovalTaskController(IApprovalTaskService service) : base(service) + { + } + + [HttpGet, HttpPost, Route("AuditAgree")] + public WebResponseContent AuditAgree(int sourceKey) + { + return Service.AuditAgree(sourceKey); + } + + [HttpGet, HttpPost, Route("AuditReject")] + public WebResponseContent AuditReject(int sourceKey) + { + return Service.AuditReject(sourceKey); + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Basic/LocationInfoController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Basic/LocationInfoController.cs" index e89e2e9..68946b4 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Basic/LocationInfoController.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Basic/LocationInfoController.cs" @@ -1,4 +1,5 @@ -锘縰sing Microsoft.AspNetCore.Authorization; +锘縰sing HslCommunication.WebSocket; +using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using System.Collections.Generic; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Check/CheckOrderController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Check/CheckOrderController.cs" new file mode 100644 index 0000000..51449cb --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Check/CheckOrderController.cs" @@ -0,0 +1,24 @@ +锘縰sing Microsoft.AspNetCore.Http; +using Microsoft.AspNetCore.Mvc; +using WIDESEA_Core; +using WIDESEA_Core.BaseController; +using WIDESEA_ICheckService; +using WIDESEA_Model.Models; + +namespace WIDESEA_WMSServer.Controllers.Check +{ + [Route("api/[controller]")] + [ApiController] + public class CheckOrderController : ApiBaseController<ICheckOrderService, Dt_CheckOrder> + { + public CheckOrderController(ICheckOrderService service) : base(service) + { + } + + [HttpGet, HttpPost, Route("CommitAudit")] + public WebResponseContent CommitAudit(int checkOrderId) + { + return Service.CommitAudit(checkOrderId); + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Check/CheckOrderResultController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Check/CheckOrderResultController.cs" new file mode 100644 index 0000000..f02e5b7 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Check/CheckOrderResultController.cs" @@ -0,0 +1,23 @@ +锘縰sing Microsoft.AspNetCore.Http; +using Microsoft.AspNetCore.Mvc; +using WIDESEA_Core; +using WIDESEA_Core.BaseController; +using WIDESEA_ICheckService; +using WIDESEA_Model.Models; + +namespace WIDESEA_WMSServer.Controllers.Check +{ + [Route("api/[controller]")] + [ApiController] + public class CheckOrderResultController : ApiBaseController<ICheckOrderResultService, Dt_CheckOrderResult> + { + public CheckOrderResultController(ICheckOrderResultService service) : base(service) + { + } + [HttpPost, Route("CommitCheckResult")] + public WebResponseContent CommitCheckResult(int checkOrderId, Dt_CheckOrderResult checkResult) + { + return Service.CommitCheckResult(checkOrderId, checkResult); + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/ERP/ErpController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/ERP/ErpController.cs" index 93eb1fa..3a1f79d 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/ERP/ErpController.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/ERP/ErpController.cs" @@ -1,10 +1,16 @@ 锘縰sing Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; +using WIDESEA_Common.OrderEnum; using WIDESEA_Core; using WIDESEA_Core.Attributes; +using WIDESEA_Core.Helper; +using WIDESEA_DTO; +using WIDESEA_DTO.Basic; using WIDESEA_External.ERPService; -using WIDESEA_External.Model; +using WIDESEA_IInboundRepository; +using WIDESEA_IInboundService; +using WIDESEA_Model.Models; namespace WIDESEA_WMSServer.Controllers.ERP { @@ -12,23 +18,52 @@ [ApiController] public class ErpController : ControllerBase { - private readonly IERPInvokeService _service; - public ErpController(IERPInvokeService service) + private readonly IPurchaseOrderRepository _purchaseOrderRepository; + private readonly IPurchaseOrderService _purchaseOrderService; + + public ErpController(IPurchaseOrderRepository purchaseOrderRepository, IPurchaseOrderService purchaseOrderService) { - _service = service; + _purchaseOrderRepository = purchaseOrderRepository; + _purchaseOrderService = purchaseOrderService; } - [HttpPost, Route("ReceivePurchaseOrder"), AllowAnonymous] - public WebResponseContent ReceivePurchaseOrder([FromBody] PurchaseOrderModel model) + [HttpPost, Route("ReceivePurchaseOrder"), AllowAnonymous, MethodParamsValidate] + public WebResponseContent ReceivePurchaseOrder([FromBody] Dt_PurchaseOrder model) { try { - return _service.ReceivePurchaseOrder(model); + _purchaseOrderRepository.AddData(model, x => x.Details); + + foreach (var item in model.Details) + { + Dt_ReceiveOrder receiveOrder = new Dt_ReceiveOrder() + { + ReceiveOrderStatus = InOrderStatusEnum.鏈紑濮�.ObjToInt(), + WarehouseId = item.WarehouseId, + SuppliersId = model.SupplierCode, + ReceiveOrderType = InOrderTypeEnum.Purchase.ObjToInt(), + ReceiveDate = DateTime.Now, + }; + } + + return WebResponseContent.Instance.OK(); } - catch (Exception ex) + catch (Exception ex) { return WebResponseContent.Instance.Error(ex.Message); } } + + public WebResponseContent ReceivePurchaseOrderSingle(PurchaseOrderModel model) + { + return _purchaseOrderService.ReceivePurchaseOrderSingle(model); + } + + [HttpPost, Route("Test"), AllowAnonymous] + public WebResponseContent Test(string str) + { + MatSerNumAnalysisModel model = CodeAnalysisHelper.CodeAnalysis<MatSerNumAnalysisModel>(WIDESEA_Core.CodeConfigEnum.AnalysisCodeEnum.MatSerNumAnalysis, str); + return WebResponseContent.Instance.OK(model.Serialize()); + } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/InboundOrderController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/InboundOrderController.cs" index e4d6971..04442f9 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/InboundOrderController.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/InboundOrderController.cs" @@ -16,5 +16,17 @@ public InboundOrderController(IInboundOrderService service) : base(service) { } + + [HttpPost, HttpGet, Route("MaterielGroupSingle")] + public WebResponseContent MaterielGroup(int inboundOrderId, string palletCode, string serNum) + { + return Service.MaterielGroup(inboundOrderId, palletCode, serNum); + } + + [HttpPost, HttpGet, Route("MaterielGroup")] + public WebResponseContent MaterielGroup(int inboundOrderId, string palletCode, List<string> serNums) + { + return Service.MaterielGroup(inboundOrderId, palletCode, serNums); + } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/ReceiveOrderController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/ReceiveOrderController.cs" new file mode 100644 index 0000000..da54377 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/ReceiveOrderController.cs" @@ -0,0 +1,24 @@ +锘縰sing Microsoft.AspNetCore.Http; +using Microsoft.AspNetCore.Mvc; +using WIDESEA_Core; +using WIDESEA_Core.BaseController; +using WIDESEA_IInboundService; +using WIDESEA_Model.Models; + +namespace WIDESEA_WMSServer.Controllers.Inbound +{ + [Route("api/[controller]")] + [ApiController] + public class ReceiveOrderController : ApiBaseController<IReceiveOrderService, Dt_ReceiveOrder> + { + public ReceiveOrderController(IReceiveOrderService service) : base(service) + { + } + + [HttpPost, HttpGet, Route("CreateInboundOrder")] + public WebResponseContent CreateInboundOrder(int receiveOrderId) + { + return Service.CreateInboundOrder(receiveOrderId); + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/ReceiveOrderDetailController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/ReceiveOrderDetailController.cs" new file mode 100644 index 0000000..ccc8b88 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Inbound/ReceiveOrderDetailController.cs" @@ -0,0 +1,25 @@ +锘縰sing Microsoft.AspNetCore.Http; +using Microsoft.AspNetCore.Mvc; +using WIDESEA_Core; +using WIDESEA_Core.BaseController; +using WIDESEA_IInboundService; +using WIDESEA_InboundService; +using WIDESEA_Model.Models; + +namespace WIDESEA_WMSServer.Controllers.Inbound +{ + [Route("api/[controller]")] + [ApiController] + public class ReceiveOrderDetailController : ApiBaseController<IReceiveOrderDetailService, Dt_ReceiveOrderDetail> + { + public ReceiveOrderDetailController(IReceiveOrderDetailService service) : base(service) + { + } + + [HttpPost, HttpGet, Route("AddReceiveOrderDetail")] + public WebResponseContent AddReceiveOrderDetail(string serNum, string orderNo) + { + return Service.AddReceiveOrderDetail(serNum, orderNo); + } + } +} diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutStockLockInfoController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutStockLockInfoController.cs" index 7339731..804c583 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutStockLockInfoController.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutStockLockInfoController.cs" @@ -13,11 +13,5 @@ public OutStockLockInfoController(IOutStockLockInfoService service) : base(service) { } - - [HttpPost, Route("GetByOrderDetailId")] - public List<Dt_OutStockLockInfo> GetByOrderDetailId(int orderDetailId) - { - return Service.GetByOrderDetailId(orderDetailId); - } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutboundOrderController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutboundOrderController.cs" index 0fc367f..02391d2 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutboundOrderController.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/Outbound/OutboundOrderController.cs" @@ -20,15 +20,5 @@ } - [HttpPost, Route("GetOutboundOrder"), AllowAnonymous] - public WebResponseContent GetOutboundOrder([FromBody] OutboundOrderGetDTO outboundOrderGetDTO) - { - return Service.GetOutboundOrder(outboundOrderGetDTO); - } - [HttpPost, Route("GetOutboundOrderDetail"), AllowAnonymous] - public WebResponseContent GetOutboundOrderDetail([FromBody] string OrderNo) - { - return Service.GetOutboundOrderDetail(OrderNo); - } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/TaskInfo/TaskController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/TaskInfo/TaskController.cs" index ea5eb3e..63e15e9 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/TaskInfo/TaskController.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Controllers/TaskInfo/TaskController.cs" @@ -17,5 +17,16 @@ { } + [HttpPost, HttpGet, Route("RequestInboundTask")] + public WebResponseContent RequestInboundTask(string palletCode, string stationCode) + { + return Service.RequestInboundTask(palletCode, stationCode); + } + + [HttpPost, HttpGet, Route("InboundTaskCompleted")] + public WebResponseContent InboundTaskCompleted(int taskNum) + { + return Service.InboundTaskCompleted(taskNum); + } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/CustomProfile.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/CustomProfile.cs" index 7ae3f61..c4442ac 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/CustomProfile.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/CustomProfile.cs" @@ -5,6 +5,8 @@ using System.Linq; using System.Text; using System.Threading.Tasks; +using WIDESEA_Common.OrderEnum; +using WIDESEA_Core.Helper; using WIDESEA_DTO; using WIDESEA_DTO.Inbound; using WIDESEA_DTO.Outbound; @@ -23,10 +25,11 @@ CreateMap<Sys_Menu, MenuDTO>(); CreateMap<InboundOrderDetailAddDTO, Dt_InboundOrderDetail>().ForMember(x => x.OrderDetailStatus, b => b.MapFrom(b => 0)); CreateMap<InboundOrderAddDTO, Dt_InboundOrder>(); - CreateMap<MatSerialNumberDTO, Dt_StockInfoDetail>().ForMember(x => x.StockQuantity, b => b.MapFrom(b => b.MaterielQuantity)); - CreateMap<Dt_StockInfoDetail, Dt_StockQuantityChangeRecord>().ForMember(x => x.SerilNumber, b => b.MapFrom(b => b.SerialNumber)).ForMember(x => x.StockDetailId, b => b.MapFrom(b => b.Id)); + + CreateMap<Dt_StockInfoDetail, Dt_StockQuantityChangeRecord>().ForMember(x => x.SerilNumber, b => b.MapFrom(b => b.SerialNumber)).ForMember(x => x.StockDetailId, b => b.MapFrom(b => b.Id)); CreateMap<OutboundOrderDetailAddDTO, Dt_OutboundOrderDetail>().ForMember(x => x.OrderDetailStatus, b => b.MapFrom(b => 0)); CreateMap<OutboundOrderAddDTO, Dt_OutboundOrder>(); + CreateMap<Dt_ReceiveOrderDetail, Dt_CheckOrder>().ForMember(a => a.ReceivedQuantity, b => b.MapFrom(x => x.ReceivedQuantity)).ForMember(a => a.MaterielCode, b => b.MapFrom(x => x.MaterielCode)).ForMember(a => a.CheckOrderStatus, b => b.MapFrom(x => CheckOrderStatusEnum.NotCheck.ObjToInt())); } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Program.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Program.cs" index 1ac7b13..2a23123 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Program.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Program.cs" @@ -19,12 +19,13 @@ using WIDESEA_Core.Core; using Autofac.Core; using Microsoft.AspNetCore.Builder; +using WIDESEA_Core.HostedService; var builder = WebApplication.CreateBuilder(args); builder.Host.UseServiceProviderFactory(new AutofacServiceProviderFactory()).ConfigureContainer<ContainerBuilder>(builder => { - builder.RegisterModule(new AutofacModuleRegister());//带有接口层的服务注入 + builder.RegisterModule<AutofacModuleRegister>();//带有接口层的服务注入 builder.RegisterModule<AutofacPropertityModuleReg>();// }).ConfigureAppConfiguration((hostingContext, config) => { @@ -39,10 +40,11 @@ builder.Services.AddSingleton(new AppSettings(builder.Configuration));//注册 builder.Services.AddAllOptionRegister();//读取配置文件 builder.Services.AddMemoryCacheSetup();//缓存 +builder.Services.AddWebSocketSetup(); builder.Services.AddSqlsugarSetup();//SqlSugar 启动服务 -//builder.Services.AddInitializationHostServiceSetup();//应用初始化服务注入 builder.Services.AddDbSetup();//Db 启动服务 - +//builder.Services.AddInitializationHostServiceSetup();//应用初始化服务注入 +builder.Services.AddHostedService<PermissionDataHostService>();//应用初始化服务注入 builder.Services.AddAutoMapperSetup(); builder.Services.AddCorsSetup(); diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_WMSServer.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_WMSServer.csproj" index 74947aa..3fe5140 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_WMSServer.csproj" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_WMSServer.csproj" @@ -16,6 +16,13 @@ </PropertyGroup> <ItemGroup> + <Compile Remove="wwwroot\Upload\**" /> + <Content Remove="wwwroot\Upload\**" /> + <EmbeddedResource Remove="wwwroot\Upload\**" /> + <None Remove="wwwroot\Upload\**" /> + </ItemGroup> + + <ItemGroup> <Content Remove="wwwroot\swg-login.html" /> <Content Remove="wwwroot\WIDESEA_DB.DBSeed.Json\Sys_Tenant.tsv" /> </ItemGroup> @@ -47,7 +54,9 @@ </ItemGroup> <ItemGroup> + <ProjectReference Include="..\WIDESEA_ApprovalService\WIDESEA_ApprovalService.csproj" /> <ProjectReference Include="..\WIDESEA_BasicService\WIDESEA_BasicService.csproj" /> + <ProjectReference Include="..\WIDESEA_CheckService\WIDESEA_CheckService.csproj" /> <ProjectReference Include="..\WIDESEA_External\WIDESEA_External.csproj" /> <ProjectReference Include="..\WIDESEA_InboundService\WIDESEA_InboundService.csproj" /> <ProjectReference Include="..\WIDESEA_OutboundService\WIDESEA_OutboundService.csproj" /> @@ -73,9 +82,5 @@ <Content Update="wwwroot\WIDESEA_DB.DBSeed.Json\Sys_RoleAuth.tsv"> <CopyToOutputDirectory>Always</CopyToOutputDirectory> </Content> - </ItemGroup> - - <ItemGroup> - <Folder Include="wwwroot\Upload\" /> </ItemGroup> </Project> diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/appsettings.json" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/appsettings.json" index b54ea05..baf10ad 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/appsettings.json" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/appsettings.json" @@ -1,12 +1,12 @@ { - "urls": "http://*:9291", //web鏈嶅姟绔彛锛屽鏋滅敤IIS閮ㄧ讲锛屾妸杩欎釜鍘绘帀 + "urls": "http://*:9293", //web鏈嶅姟绔彛锛屽鏋滅敤IIS閮ㄧ讲锛屾妸杩欎釜鍘绘帀 "Logging": { "LogLevel": { "Default": "Information", "Microsoft.AspNetCore": "Warning" } }, - "dics": "inOrderType,outOrderType,inboundState,createType,enableEnum,enableStatusEnum,locationStatusEnum,locationTypeEnum,taskTypeEnum,taskStatusEnum,outboundStatusEnum,orderDetailStatusEnum,stockStatusEmun,stockChangeType,outStockStatus", + "dics": "inOrderType,outOrderType,inboundState,createType,enableEnum,enableStatusEnum,locationStatusEnum,locationTypeEnum,taskTypeEnum,taskStatusEnum,outboundStatusEnum,orderDetailStatusEnum,stockStatusEmun,stockChangeType,outStockStatus,receiveOrderTypeEnum,authorityScope,authorityScopes", "AllowedHosts": "*", "ConnectionStringsEncryption": false, "MainDB": "DB_WIDESEA", //褰撳墠椤圭洰鐨勪富搴擄紝鎵�瀵瑰簲鐨勮繛鎺ュ瓧绗︿覆鐨凟nabled蹇呴』涓簍rue @@ -23,7 +23,7 @@ }, "WCS": "http://localhost:9291/api/Task/", - + "LogAopEnable": false, "ApiName": "WIDESEA", "ExpMinutes": 120, "QuartzJobAutoStart": true, diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_Dictionary.tsv" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_Dictionary.tsv" index 2519a2e..7cd8502 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_Dictionary.tsv" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_Dictionary.tsv" @@ -49,7 +49,7 @@ }, { "DicId": 32, - "Config": "{valueField: 'Role_Id',\r\n textField: 'RoleName', \r\n containField: ['Role_Id','RoleName'],\r\n handler: null }\r\n", + "Config": "{valueField: 'RoleId',\r\n textField: 'RoleName', \r\n containField: ['RoleId','RoleName'],\r\n handler: null }\r\n", "Sql": "SELECT RoleId as 'key',RoleName as 'value' FROM Sys_Role WHERE Enable=1", "DicName": "瑙掕壊鍒楄〃", "DicNo": "roles", diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_User.tsv" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_User.tsv" index 83070a8..c45c2d2 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_User.tsv" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/wwwroot/WIDESEA_DB.DBSeed.Json/Sys_User.tsv" @@ -1,8 +1,8 @@ 锘縖 { - "User_Id": 1, + "UserId": 1, "UserName": "admin", - "Role_Id": 1, + "RoleId": 1, "RoleName": "瓒呯骇绠$悊鍛�", "PhoneNo": "", "Remark": "", -- Gitblit v1.9.3