?$G8-Q6A|H`rLO$)~zxn
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
Y$mJH7Jmz&TFarV^8(8R9>bXAnAHywfZ2$lO
literal 0
HcmV?d00001
diff --git a/public/favicon1.ico b/public/favicon1.ico
new file mode 100644
index 0000000000000000000000000000000000000000..e26376026420542212ed58d90d0ed34f554fa4ae
GIT binary patch
literal 5663
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
+
+
+
+
+ 随机内容生成器
+
+
+
+
+
随机内容生成器
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/App.vue b/src/App.vue
new file mode 100644
index 0000000..31839f2
--- /dev/null
+++ b/src/App.vue
@@ -0,0 +1,15 @@
+
+
+
+
+
diff --git a/src/api/Inventory/autoInventory.js b/src/api/Inventory/autoInventory.js
new file mode 100644
index 0000000..ba096d4
--- /dev/null
+++ b/src/api/Inventory/autoInventory.js
@@ -0,0 +1,64 @@
+import request from '@/utils/request'
+
+// 开始盘点
+export function getTaskCount(query) {
+ return request({
+ url: '/statistics/count',
+ method: 'get',
+ params: query
+ })
+}
+
+// 开始盘点
+export function getScan(query) {
+ return request({
+ url: '/AutoInventory/scan',
+ method: 'get',
+ params: query
+ })
+}
+
+// 开始匹配
+export function getMatch(data) {
+ return request({
+ url: '/AutoInventory/match',
+ method: 'post',
+ data: data
+ })
+}
+
+// 停止盘点
+export function stopScan(query) {
+ return request({
+ url: '/AutoInventory/stop',
+ method: 'get',
+ params: query
+ })
+}
+
+// 获取盘点结果
+export function getScanResult(query) {
+ return request({
+ url: '/MatchScan/countList',
+ method: 'get',
+ params: query
+ })
+}
+
+// 获取图表
+export function getChart(data) {
+ return request({
+ url: '/AutoInventory/chart',
+ method: 'post',
+ data: data
+ })
+}
+
+// 根据盘点结果,用存放位置查看具体内容
+export function getStockList(id) {
+ return request({
+ url: '/wisdom/stock/pcode/' + id,
+ method: 'get',
+ })
+}
+
diff --git a/src/api/Inventory/task.js b/src/api/Inventory/task.js
new file mode 100644
index 0000000..9d44d7d
--- /dev/null
+++ b/src/api/Inventory/task.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询盘点任务列表
+export function listTask(query) {
+ return request({
+ url: '/Inventory/task/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询盘点任务详细
+export function getTask(id) {
+ return request({
+ url: '/Inventory/task/' + id,
+ method: 'get'
+ })
+}
+
+// 新增盘点任务
+export function addTask(data) {
+ return request({
+ url: '/Inventory/task',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改盘点任务
+export function updateTask(data) {
+ return request({
+ url: '/Inventory/task',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除盘点任务
+export function delTask(id) {
+ return request({
+ url: '/Inventory/task/' + id,
+ method: 'delete'
+ })
+}
diff --git a/src/api/examine/process.js b/src/api/examine/process.js
new file mode 100644
index 0000000..1426578
--- /dev/null
+++ b/src/api/examine/process.js
@@ -0,0 +1,26 @@
+import request from '@/utils/request'
+//审核列表
+export function listProcess(query) {
+ return request({
+ url: '/wisdom/signature/list',
+ method: 'get',
+ params: query
+ })
+}
+//提交审核
+export function auditData(query) {
+ return request({
+ url: '/wisdom/signature/audit',
+ method: 'post',
+ // params: query
+ data:query
+ })
+ }
+ export function uploadPic(query) {
+ return request({
+ url: '/wisdom/signature/uploadBase64',
+ method: 'post',
+ // params: query,
+ data:query
+ })
+ }
\ No newline at end of file
diff --git a/src/api/examine/record.js b/src/api/examine/record.js
new file mode 100644
index 0000000..0fd1c1c
--- /dev/null
+++ b/src/api/examine/record.js
@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+//审核列表
+export function recordListFun(query) {
+ return request({
+ url: '/wisdom/signature/user/list',
+ method: 'get',
+ params: query
+ })
+}
\ No newline at end of file
diff --git a/src/api/index.js b/src/api/index.js
new file mode 100644
index 0000000..7e51c75
--- /dev/null
+++ b/src/api/index.js
@@ -0,0 +1,110 @@
+import request from '@/utils/request'
+
+// 入/出库数量
+export const getMonthCount = () => {
+ return request({
+ url: '/stat/month/summary',
+ method: 'get'
+ })
+}
+
+// 预警
+export const getInventoryAge = () => {
+ return request({
+ url: '/stat/age',
+ method: 'get'
+ })
+}
+
+// 库龄统计(库龄超过30/60天统计)
+export const getAgeLong = () => {
+ return request({
+ url: '/stat/age/count',
+ method: 'get'
+ })
+}
+
+// 仓库使用率
+export const getInventoryReview = () => {
+ return request({
+ url: '/stat/warehouseScene',
+ method: 'get'
+ })
+}
+
+// 待办事项(应到未到统计)
+export const getWaitIn = (params) => {
+ return request({
+ url: '/stat/undelivered',
+ method: 'get',
+ params
+ })
+}
+// 待办事项(应出未出统计)
+export const getWaitOut = (params) => {
+ return request({
+ url: '/stat/age/gt30',
+ method: 'get',
+ params
+ })
+}
+
+// 当前入库类型统计(根据入库类型统计项目数,条目数,总金额)
+export const getInStorage = () => {
+ return request({
+ url: '/stat/type/summary',
+ method: 'get'
+ })
+}
+
+// 物资类型统计
+export const getGoodsType = () => {
+ return request({
+ url: '/stat/stock/wlType',
+ method: 'get'
+ })
+}
+
+// 县局统计(根据县局统计项目数,条目数,总金额)
+// export const getCounty = () => {
+// return request({
+// url: '/stat/county/summary',
+// method: 'get'
+// })
+// }
+
+// 入/出库指标统计(天级出入库统计)
+export const getDailyInventory = (params) => {
+ return request({
+ url: '/stat/week/daily',
+ method: 'get',
+ params
+ })
+}
+
+// 根据出库类型,自定义时间筛选统计入库情况
+export const getInventoryType = (params) => {
+ return request({
+ url: '/stat/type/range',
+ method: 'get',
+ params
+ })
+}
+
+// 根据入库类型,自定义时间筛选统计出库情况
+export const getOutInventoryType = (params) => {
+ return request({
+ url: '/stat/type/out/range',
+ method: 'get',
+ params
+ })
+}
+
+// (每一种入库类型的统计)
+// export const getEveryInventory = () => {
+// return request({
+// url: '/stat/type/pie',
+// method: 'get'
+// })
+// }
+
diff --git a/src/api/information/construction.js b/src/api/information/construction.js
new file mode 100644
index 0000000..96bbaa9
--- /dev/null
+++ b/src/api/information/construction.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询施工队信息列表
+export function listConstruction(query) {
+ return request({
+ url: '/information/construction/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询施工队信息详细
+export function getConstruction(id) {
+ return request({
+ url: '/information/construction/' + id,
+ method: 'get'
+ })
+}
+
+// 新增施工队信息
+export function addConstruction(data) {
+ return request({
+ url: '/information/construction',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改施工队信息
+export function updateConstruction(data) {
+ return request({
+ url: '/information/construction',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除施工队信息
+export function delConstruction(id) {
+ return request({
+ url: '/information/construction/' + id,
+ method: 'delete'
+ })
+}
diff --git a/src/api/information/deliery.js b/src/api/information/deliery.js
new file mode 100644
index 0000000..39af973
--- /dev/null
+++ b/src/api/information/deliery.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询物料字典列表
+export function listMtd(query) {
+ return request({
+ url: '/information/delivery/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询物料字典详细
+export function getMtd(id) {
+ return request({
+ url: '/information/delivery/' + id,
+ method: 'get'
+ })
+}
+
+// 新增物料字典
+export function addMtd(data) {
+ return request({
+ url: '/information/delivery',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改物料字典
+export function updateMtd(data) {
+ return request({
+ url: '/information/delivery',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除物料字典
+export function delMtd(id) {
+ return request({
+ url: '/information/delivery/' + id,
+ method: 'delete'
+ })
+}
diff --git a/src/api/information/device.js b/src/api/information/device.js
new file mode 100644
index 0000000..a9a1958
--- /dev/null
+++ b/src/api/information/device.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询设备信息列表
+export function listDevice(query) {
+ return request({
+ url: '/information/device/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询设备信息详细
+export function getDevice(deviceId) {
+ return request({
+ url: '/information/device/' + deviceId,
+ method: 'get'
+ })
+}
+
+// 新增设备信息
+export function addDevice(data) {
+ return request({
+ url: '/information/device',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改设备信息
+export function updateDevice(data) {
+ return request({
+ url: '/information/device',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除设备信息
+export function delDevice(deviceId) {
+ return request({
+ url: '/information/device/' + deviceId,
+ method: 'delete'
+ })
+}
diff --git a/src/api/information/materialtype.js b/src/api/information/materialtype.js
new file mode 100644
index 0000000..f4d54a9
--- /dev/null
+++ b/src/api/information/materialtype.js
@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询物资类型列表
+export function listMaterialtype(query) {
+ return request({
+ url: '/information/materialtype/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询物资类型详细
+export function getMaterialtype(id) {
+ return request({
+ url: '/information/materialtype/' + id,
+ method: 'get'
+ })
+}
+
+// 新增物资类型
+export function addMaterialtype(data) {
+ return request({
+ url: '/information/materialtype',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改物资类型
+export function updateMaterialtype(data) {
+ return request({
+ url: '/information/materialtype',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除物资类型
+export function delMaterialtype(id) {
+ return request({
+ url: '/information/materialtype/' + id,
+ method: 'delete'
+ })
+}
+
+//获取物资类型下拉字典数据
+export function materialtypeDict() {
+ return request({
+ url: '/information/materialtype/getAll',
+ method: 'get'
+ })
+}
diff --git a/src/api/information/mtd.js b/src/api/information/mtd.js
new file mode 100644
index 0000000..cf8d6ed
--- /dev/null
+++ b/src/api/information/mtd.js
@@ -0,0 +1,51 @@
+import request from '@/utils/request'
+
+// 查询物料字典列表
+export function listMtd(query) {
+ return request({
+ url: '/information/mtd/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询物料字典详细
+export function getMtd(Id) {
+ return request({
+ url: '/information/mtd/' + Id,
+ method: 'get'
+ })
+}
+
+// 新增物料字典
+export function addMtd(data) {
+ return request({
+ url: '/information/mtd',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改物料字典
+export function updateMtd(data) {
+ return request({
+ url: '/information/mtd',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除物料字典
+export function delMtd(Id) {
+ return request({
+ url: '/information/mtd/' + Id,
+ method: 'delete'
+ })
+}
+
+export function mtdRenew() {
+ return request({
+ url: '/information/mtd/syncFromPlan',
+ method: 'get'
+ })
+}
diff --git a/src/api/information/outtype.js b/src/api/information/outtype.js
new file mode 100644
index 0000000..fcc918f
--- /dev/null
+++ b/src/api/information/outtype.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询出库类型列表
+export function listOuttype(query) {
+ return request({
+ url: '/information/outtype/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询出库类型详细
+export function getOuttype(id) {
+ return request({
+ url: '/information/outtype/' + id,
+ method: 'get'
+ })
+}
+
+// 新增出库类型
+export function addOuttype(data) {
+ return request({
+ url: '/information/outtype',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改出库类型
+export function updateOuttype(data) {
+ return request({
+ url: '/information/outtype',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除出库类型
+export function delOuttype(id) {
+ return request({
+ url: '/information/outtype/' + id,
+ method: 'delete'
+ })
+}
diff --git a/src/api/information/pcdedetail.js b/src/api/information/pcdedetail.js
new file mode 100644
index 0000000..6b4ead4
--- /dev/null
+++ b/src/api/information/pcdedetail.js
@@ -0,0 +1,69 @@
+import request from '@/utils/request'
+
+// 查询库位明细列表
+export function listPcdedetail(query) {
+ return request({
+ url: '/information/pcdedetail/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询库位明细详细
+export function getPcdedetail(id) {
+ return request({
+ url: '/information/pcdedetail/' + id,
+ method: 'get'
+ })
+}
+
+// 新增库位明细
+export function addPcdedetail(data) {
+ return request({
+ url: '/information/pcdedetail/add',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改库位明细
+export function updatePcdedetail(data) {
+ return request({
+ url: '/information/pcdedetail',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除库位明细
+export function delPcdedetail(id) {
+ return request({
+ url: '/information/pcdedetail/' + id,
+ method: 'delete'
+ })
+}
+
+// 查询所有场景编号列表
+export function getAllScenes() {
+ return request({
+ url: '/information/scene/getAll',
+ method: 'get'
+ })
+}
+
+//获取所有可用库位下拉数据 用于入库选择库位
+export function getKwList() {
+ return request({
+ url: '/information/pcdedetail/getAll',
+ method: 'get'
+ })
+}
+
+
+//获取当前仓库所有可用库位下拉数据 用于入库选择库位
+export function getKwAllList(id) {
+ return request({
+ url: 'information/pcdedetail/listByWarehouse/' + id,
+ method: 'get'
+ })
+}
diff --git a/src/api/information/print.js b/src/api/information/print.js
new file mode 100644
index 0000000..da7ffa8
--- /dev/null
+++ b/src/api/information/print.js
@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+export function printFun(query) {
+ return request({
+ url: '/AutoInventory/printlsf',
+ method: 'post',
+ data: query
+ })
+}
\ No newline at end of file
diff --git a/src/api/information/scene.js b/src/api/information/scene.js
new file mode 100644
index 0000000..a472832
--- /dev/null
+++ b/src/api/information/scene.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询场景编号列表
+export function listScene(query) {
+ return request({
+ url: '/information/scene/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询场景编号详细
+export function getScene(id) {
+ return request({
+ url: '/information/scene/' + id,
+ method: 'get'
+ })
+}
+
+// 新增场景编号
+export function addScene(data) {
+ return request({
+ url: '/information/scene',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改场景编号
+export function updateScene(data) {
+ return request({
+ url: '/information/scene',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除场景编号
+export function delScene(id) {
+ return request({
+ url: '/information/scene/' + id,
+ method: 'delete'
+ })
+}
\ No newline at end of file
diff --git a/src/api/information/warehouseinfo.js b/src/api/information/warehouseinfo.js
new file mode 100644
index 0000000..605762d
--- /dev/null
+++ b/src/api/information/warehouseinfo.js
@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询仓库信息列表
+export function listWarehouseinfo(query) {
+ return request({
+ url: '/information/warehouseinfo/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询仓库信息详细
+export function getWarehouseinfo(id) {
+ return request({
+ url: '/information/warehouseinfo/' + id,
+ method: 'get'
+ })
+}
+
+// 新增仓库信息
+export function addWarehouseinfo(data) {
+ return request({
+ url: '/information/warehouseinfo',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改仓库信息
+export function updateWarehouseinfo(data) {
+ return request({
+ url: '/information/warehouseinfo',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除仓库信息
+export function delWarehouseinfo(id) {
+ return request({
+ url: '/information/warehouseinfo/' + id,
+ method: 'delete'
+ })
+}
+
+//所属仓库下拉数据
+export function warehouseDict() {
+ return request({
+ url: '/information/warehouseinfo/getAll',
+ method: 'get'
+ })
+}
+
+//所属大仓和小仓下拉数据
+export function warehouseAll() {
+ return request({
+ url: '/information/warehouseinfo/tree',
+ method: 'get'
+ })
+}
diff --git a/src/api/information/warehousingtype.js b/src/api/information/warehousingtype.js
new file mode 100644
index 0000000..f67daa7
--- /dev/null
+++ b/src/api/information/warehousingtype.js
@@ -0,0 +1,53 @@
+import request from '@/utils/request'
+
+// 查询入库类型列表
+export function listWarehousingtype(query) {
+ return request({
+ url: '/information/warehousingtype/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询入库类型详细
+export function getWarehousingtype(id) {
+ return request({
+ url: '/information/warehousingtype/' + id,
+ method: 'get'
+ })
+}
+
+// 新增入库类型
+export function addWarehousingtype(data) {
+ return request({
+ url: '/information/warehousingtype',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改入库类型
+export function updateWarehousingtype(data) {
+ return request({
+ url: '/information/warehousingtype',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除入库类型
+export function delWarehousingtype(id) {
+ return request({
+ url: '/information/warehousingtype/' + id,
+ method: 'delete'
+ })
+}
+
+// 入库类型下拉字典数据
+export function warehousingDict(data) {
+ return request({
+ url: '/information/warehousingtype/getAll',
+ method: 'get',
+ data: data
+ })
+}
\ No newline at end of file
diff --git a/src/api/login.js b/src/api/login.js
new file mode 100644
index 0000000..7b7388f
--- /dev/null
+++ b/src/api/login.js
@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 登录方法
+export function login(username, password, code, uuid) {
+ const data = {
+ username,
+ password,
+ code,
+ uuid
+ }
+ return request({
+ url: '/login',
+ headers: {
+ isToken: false,
+ repeatSubmit: false
+ },
+ method: 'post',
+ data: data
+ })
+}
+
+// 注册方法
+export function register(data) {
+ return request({
+ url: '/register',
+ headers: {
+ isToken: false
+ },
+ method: 'post',
+ data: data
+ })
+}
+
+// 获取用户详细信息
+export function getInfo() {
+ return request({
+ url: '/getInfo',
+ method: 'get'
+ })
+}
+
+// 退出方法
+export function logout() {
+ return request({
+ url: '/logout',
+ method: 'post'
+ })
+}
+
+// 获取验证码
+export function getCodeImg() {
+ return request({
+ url: '/captchaImage',
+ headers: {
+ isToken: false
+ },
+ method: 'get',
+ timeout: 20000
+ })
+}
\ No newline at end of file
diff --git a/src/api/menu.js b/src/api/menu.js
new file mode 100644
index 0000000..faef101
--- /dev/null
+++ b/src/api/menu.js
@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+// 获取路由
+export const getRouters = () => {
+ return request({
+ url: '/getRouters',
+ method: 'get'
+ })
+}
\ No newline at end of file
diff --git a/src/api/monitor/cache.js b/src/api/monitor/cache.js
new file mode 100644
index 0000000..72c5f6a
--- /dev/null
+++ b/src/api/monitor/cache.js
@@ -0,0 +1,57 @@
+import request from '@/utils/request'
+
+// 查询缓存详细
+export function getCache() {
+ return request({
+ url: '/monitor/cache',
+ method: 'get'
+ })
+}
+
+// 查询缓存名称列表
+export function listCacheName() {
+ return request({
+ url: '/monitor/cache/getNames',
+ method: 'get'
+ })
+}
+
+// 查询缓存键名列表
+export function listCacheKey(cacheName) {
+ return request({
+ url: '/monitor/cache/getKeys/' + cacheName,
+ method: 'get'
+ })
+}
+
+// 查询缓存内容
+export function getCacheValue(cacheName, cacheKey) {
+ return request({
+ url: '/monitor/cache/getValue/' + cacheName + '/' + cacheKey,
+ method: 'get'
+ })
+}
+
+// 清理指定名称缓存
+export function clearCacheName(cacheName) {
+ return request({
+ url: '/monitor/cache/clearCacheName/' + cacheName,
+ method: 'delete'
+ })
+}
+
+// 清理指定键名缓存
+export function clearCacheKey(cacheKey) {
+ return request({
+ url: '/monitor/cache/clearCacheKey/' + cacheKey,
+ method: 'delete'
+ })
+}
+
+// 清理全部缓存
+export function clearCacheAll() {
+ return request({
+ url: '/monitor/cache/clearCacheAll',
+ method: 'delete'
+ })
+}
diff --git a/src/api/monitor/job.js b/src/api/monitor/job.js
new file mode 100644
index 0000000..3815569
--- /dev/null
+++ b/src/api/monitor/job.js
@@ -0,0 +1,71 @@
+import request from '@/utils/request'
+
+// 查询定时任务调度列表
+export function listJob(query) {
+ return request({
+ url: '/monitor/job/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询定时任务调度详细
+export function getJob(jobId) {
+ return request({
+ url: '/monitor/job/' + jobId,
+ method: 'get'
+ })
+}
+
+// 新增定时任务调度
+export function addJob(data) {
+ return request({
+ url: '/monitor/job',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改定时任务调度
+export function updateJob(data) {
+ return request({
+ url: '/monitor/job',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除定时任务调度
+export function delJob(jobId) {
+ return request({
+ url: '/monitor/job/' + jobId,
+ method: 'delete'
+ })
+}
+
+// 任务状态修改
+export function changeJobStatus(jobId, status) {
+ const data = {
+ jobId,
+ status
+ }
+ return request({
+ url: '/monitor/job/changeStatus',
+ method: 'put',
+ data: data
+ })
+}
+
+
+// 定时任务立即执行一次
+export function runJob(jobId, jobGroup) {
+ const data = {
+ jobId,
+ jobGroup
+ }
+ return request({
+ url: '/monitor/job/run',
+ method: 'put',
+ data: data
+ })
+}
\ No newline at end of file
diff --git a/src/api/monitor/jobLog.js b/src/api/monitor/jobLog.js
new file mode 100644
index 0000000..6e0be61
--- /dev/null
+++ b/src/api/monitor/jobLog.js
@@ -0,0 +1,26 @@
+import request from '@/utils/request'
+
+// 查询调度日志列表
+export function listJobLog(query) {
+ return request({
+ url: '/monitor/jobLog/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 删除调度日志
+export function delJobLog(jobLogId) {
+ return request({
+ url: '/monitor/jobLog/' + jobLogId,
+ method: 'delete'
+ })
+}
+
+// 清空调度日志
+export function cleanJobLog() {
+ return request({
+ url: '/monitor/jobLog/clean',
+ method: 'delete'
+ })
+}
diff --git a/src/api/monitor/logininfor.js b/src/api/monitor/logininfor.js
new file mode 100644
index 0000000..4d112b7
--- /dev/null
+++ b/src/api/monitor/logininfor.js
@@ -0,0 +1,34 @@
+import request from '@/utils/request'
+
+// 查询登录日志列表
+export function list(query) {
+ return request({
+ url: '/monitor/logininfor/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 删除登录日志
+export function delLogininfor(infoId) {
+ return request({
+ url: '/monitor/logininfor/' + infoId,
+ method: 'delete'
+ })
+}
+
+// 解锁用户登录状态
+export function unlockLogininfor(userName) {
+ return request({
+ url: '/monitor/logininfor/unlock/' + userName,
+ method: 'get'
+ })
+}
+
+// 清空登录日志
+export function cleanLogininfor() {
+ return request({
+ url: '/monitor/logininfor/clean',
+ method: 'delete'
+ })
+}
diff --git a/src/api/monitor/online.js b/src/api/monitor/online.js
new file mode 100644
index 0000000..bd22137
--- /dev/null
+++ b/src/api/monitor/online.js
@@ -0,0 +1,18 @@
+import request from '@/utils/request'
+
+// 查询在线用户列表
+export function list(query) {
+ return request({
+ url: '/monitor/online/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 强退用户
+export function forceLogout(tokenId) {
+ return request({
+ url: '/monitor/online/' + tokenId,
+ method: 'delete'
+ })
+}
diff --git a/src/api/monitor/operlog.js b/src/api/monitor/operlog.js
new file mode 100644
index 0000000..a04bca8
--- /dev/null
+++ b/src/api/monitor/operlog.js
@@ -0,0 +1,26 @@
+import request from '@/utils/request'
+
+// 查询操作日志列表
+export function list(query) {
+ return request({
+ url: '/monitor/operlog/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 删除操作日志
+export function delOperlog(operId) {
+ return request({
+ url: '/monitor/operlog/' + operId,
+ method: 'delete'
+ })
+}
+
+// 清空操作日志
+export function cleanOperlog() {
+ return request({
+ url: '/monitor/operlog/clean',
+ method: 'delete'
+ })
+}
diff --git a/src/api/monitor/server.js b/src/api/monitor/server.js
new file mode 100644
index 0000000..e1f9ca2
--- /dev/null
+++ b/src/api/monitor/server.js
@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+// 获取服务信息
+export function getServer() {
+ return request({
+ url: '/monitor/server',
+ method: 'get'
+ })
+}
\ No newline at end of file
diff --git a/src/api/plan/jh.js b/src/api/plan/jh.js
new file mode 100644
index 0000000..e6d5a9b
--- /dev/null
+++ b/src/api/plan/jh.js
@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询供应计划列表
+export function listJh(query) {
+ return request({
+ url: '/plan/jh/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询供应计划详细
+export function getJh(id) {
+ return request({
+ url: '/plan/jh/' + id,
+ method: 'get'
+ })
+}
+
+// 新增供应计划
+export function addJh(data) {
+ return request({
+ url: '/plan/jh',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改供应计划
+export function updateJh(data) {
+ return request({
+ url: '/plan/jh',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除供应计划
+export function delJh(id) {
+ return request({
+ url: '/plan/jh/' + id,
+ method: 'delete'
+ })
+}
+export function uploadPlan(data) {
+ return request({
+ url: '/plan/jh/importByMapping',
+ method: 'post',
+ data: data,
+ isUpload:true
+ })
+}
diff --git a/src/api/system/config.js b/src/api/system/config.js
new file mode 100644
index 0000000..a404d82
--- /dev/null
+++ b/src/api/system/config.js
@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询参数列表
+export function listConfig(query) {
+ return request({
+ url: '/system/config/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询参数详细
+export function getConfig(configId) {
+ return request({
+ url: '/system/config/' + configId,
+ method: 'get'
+ })
+}
+
+// 根据参数键名查询参数值
+export function getConfigKey(configKey) {
+ return request({
+ url: '/system/config/configKey/' + configKey,
+ method: 'get'
+ })
+}
+
+// 新增参数配置
+export function addConfig(data) {
+ return request({
+ url: '/system/config',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改参数配置
+export function updateConfig(data) {
+ return request({
+ url: '/system/config',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除参数配置
+export function delConfig(configId) {
+ return request({
+ url: '/system/config/' + configId,
+ method: 'delete'
+ })
+}
+
+// 刷新参数缓存
+export function refreshCache() {
+ return request({
+ url: '/system/config/refreshCache',
+ method: 'delete'
+ })
+}
diff --git a/src/api/system/dept.js b/src/api/system/dept.js
new file mode 100644
index 0000000..fc943cd
--- /dev/null
+++ b/src/api/system/dept.js
@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询部门列表
+export function listDept(query) {
+ return request({
+ url: '/system/dept/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询部门列表(排除节点)
+export function listDeptExcludeChild(deptId) {
+ return request({
+ url: '/system/dept/list/exclude/' + deptId,
+ method: 'get'
+ })
+}
+
+// 查询部门详细
+export function getDept(deptId) {
+ return request({
+ url: '/system/dept/' + deptId,
+ method: 'get'
+ })
+}
+
+// 新增部门
+export function addDept(data) {
+ return request({
+ url: '/system/dept',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改部门
+export function updateDept(data) {
+ return request({
+ url: '/system/dept',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除部门
+export function delDept(deptId) {
+ return request({
+ url: '/system/dept/' + deptId,
+ method: 'delete'
+ })
+}
\ No newline at end of file
diff --git a/src/api/system/dict/data.js b/src/api/system/dict/data.js
new file mode 100644
index 0000000..6c9eb79
--- /dev/null
+++ b/src/api/system/dict/data.js
@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询字典数据列表
+export function listData(query) {
+ return request({
+ url: '/system/dict/data/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询字典数据详细
+export function getData(dictCode) {
+ return request({
+ url: '/system/dict/data/' + dictCode,
+ method: 'get'
+ })
+}
+
+// 根据字典类型查询字典数据信息
+export function getDicts(dictType) {
+ return request({
+ url: '/system/dict/data/type/' + dictType,
+ method: 'get'
+ })
+}
+
+// 新增字典数据
+export function addData(data) {
+ return request({
+ url: '/system/dict/data',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改字典数据
+export function updateData(data) {
+ return request({
+ url: '/system/dict/data',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除字典数据
+export function delData(dictCode) {
+ return request({
+ url: '/system/dict/data/' + dictCode,
+ method: 'delete'
+ })
+}
diff --git a/src/api/system/dict/type.js b/src/api/system/dict/type.js
new file mode 100644
index 0000000..a0254ba
--- /dev/null
+++ b/src/api/system/dict/type.js
@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询字典类型列表
+export function listType(query) {
+ return request({
+ url: '/system/dict/type/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询字典类型详细
+export function getType(dictId) {
+ return request({
+ url: '/system/dict/type/' + dictId,
+ method: 'get'
+ })
+}
+
+// 新增字典类型
+export function addType(data) {
+ return request({
+ url: '/system/dict/type',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改字典类型
+export function updateType(data) {
+ return request({
+ url: '/system/dict/type',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除字典类型
+export function delType(dictId) {
+ return request({
+ url: '/system/dict/type/' + dictId,
+ method: 'delete'
+ })
+}
+
+// 刷新字典缓存
+export function refreshCache() {
+ return request({
+ url: '/system/dict/type/refreshCache',
+ method: 'delete'
+ })
+}
+
+// 获取字典选择框列表
+export function optionselect() {
+ return request({
+ url: '/system/dict/type/optionselect',
+ method: 'get'
+ })
+}
diff --git a/src/api/system/menu.js b/src/api/system/menu.js
new file mode 100644
index 0000000..f6415c6
--- /dev/null
+++ b/src/api/system/menu.js
@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询菜单列表
+export function listMenu(query) {
+ return request({
+ url: '/system/menu/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询菜单详细
+export function getMenu(menuId) {
+ return request({
+ url: '/system/menu/' + menuId,
+ method: 'get'
+ })
+}
+
+// 查询菜单下拉树结构
+export function treeselect() {
+ return request({
+ url: '/system/menu/treeselect',
+ method: 'get'
+ })
+}
+
+// 根据角色ID查询菜单下拉树结构
+export function roleMenuTreeselect(roleId) {
+ return request({
+ url: '/system/menu/roleMenuTreeselect/' + roleId,
+ method: 'get'
+ })
+}
+
+// 新增菜单
+export function addMenu(data) {
+ return request({
+ url: '/system/menu',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改菜单
+export function updateMenu(data) {
+ return request({
+ url: '/system/menu',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除菜单
+export function delMenu(menuId) {
+ return request({
+ url: '/system/menu/' + menuId,
+ method: 'delete'
+ })
+}
\ No newline at end of file
diff --git a/src/api/system/notice.js b/src/api/system/notice.js
new file mode 100644
index 0000000..c274ea5
--- /dev/null
+++ b/src/api/system/notice.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询公告列表
+export function listNotice(query) {
+ return request({
+ url: '/system/notice/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询公告详细
+export function getNotice(noticeId) {
+ return request({
+ url: '/system/notice/' + noticeId,
+ method: 'get'
+ })
+}
+
+// 新增公告
+export function addNotice(data) {
+ return request({
+ url: '/system/notice',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改公告
+export function updateNotice(data) {
+ return request({
+ url: '/system/notice',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除公告
+export function delNotice(noticeId) {
+ return request({
+ url: '/system/notice/' + noticeId,
+ method: 'delete'
+ })
+}
\ No newline at end of file
diff --git a/src/api/system/post.js b/src/api/system/post.js
new file mode 100644
index 0000000..1a8e9ca
--- /dev/null
+++ b/src/api/system/post.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询岗位列表
+export function listPost(query) {
+ return request({
+ url: '/system/post/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询岗位详细
+export function getPost(postId) {
+ return request({
+ url: '/system/post/' + postId,
+ method: 'get'
+ })
+}
+
+// 新增岗位
+export function addPost(data) {
+ return request({
+ url: '/system/post',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改岗位
+export function updatePost(data) {
+ return request({
+ url: '/system/post',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除岗位
+export function delPost(postId) {
+ return request({
+ url: '/system/post/' + postId,
+ method: 'delete'
+ })
+}
diff --git a/src/api/system/role.js b/src/api/system/role.js
new file mode 100644
index 0000000..f13e6f4
--- /dev/null
+++ b/src/api/system/role.js
@@ -0,0 +1,119 @@
+import request from '@/utils/request'
+
+// 查询角色列表
+export function listRole(query) {
+ return request({
+ url: '/system/role/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询角色详细
+export function getRole(roleId) {
+ return request({
+ url: '/system/role/' + roleId,
+ method: 'get'
+ })
+}
+
+// 新增角色
+export function addRole(data) {
+ return request({
+ url: '/system/role',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改角色
+export function updateRole(data) {
+ return request({
+ url: '/system/role',
+ method: 'put',
+ data: data
+ })
+}
+
+// 角色数据权限
+export function dataScope(data) {
+ return request({
+ url: '/system/role/dataScope',
+ method: 'put',
+ data: data
+ })
+}
+
+// 角色状态修改
+export function changeRoleStatus(roleId, status) {
+ const data = {
+ roleId,
+ status
+ }
+ return request({
+ url: '/system/role/changeStatus',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除角色
+export function delRole(roleId) {
+ return request({
+ url: '/system/role/' + roleId,
+ method: 'delete'
+ })
+}
+
+// 查询角色已授权用户列表
+export function allocatedUserList(query) {
+ return request({
+ url: '/system/role/authUser/allocatedList',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询角色未授权用户列表
+export function unallocatedUserList(query) {
+ return request({
+ url: '/system/role/authUser/unallocatedList',
+ method: 'get',
+ params: query
+ })
+}
+
+// 取消用户授权角色
+export function authUserCancel(data) {
+ return request({
+ url: '/system/role/authUser/cancel',
+ method: 'put',
+ data: data
+ })
+}
+
+// 批量取消用户授权角色
+export function authUserCancelAll(data) {
+ return request({
+ url: '/system/role/authUser/cancelAll',
+ method: 'put',
+ params: data
+ })
+}
+
+// 授权用户选择
+export function authUserSelectAll(data) {
+ return request({
+ url: '/system/role/authUser/selectAll',
+ method: 'put',
+ params: data
+ })
+}
+
+// 根据角色ID查询部门树结构
+export function deptTreeSelect(roleId) {
+ return request({
+ url: '/system/role/deptTree/' + roleId,
+ method: 'get'
+ })
+}
diff --git a/src/api/system/user.js b/src/api/system/user.js
new file mode 100644
index 0000000..1c10d27
--- /dev/null
+++ b/src/api/system/user.js
@@ -0,0 +1,144 @@
+import request from '@/utils/request'
+import { parseStrEmpty } from "@/utils/manage";
+
+// 查询用户列表
+export function listUser(query) {
+ return request({
+ url: '/system/user/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询用户详细
+export function getUser(userId) {
+ return request({
+ url: '/system/user/' + parseStrEmpty(userId),
+ method: 'get'
+ })
+}
+
+// 新增用户
+export function addUser(data) {
+ return request({
+ url: '/system/user',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改用户
+export function updateUser(data) {
+ return request({
+ url: '/system/user',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除用户
+export function delUser(userId) {
+ return request({
+ url: '/system/user/' + userId,
+ method: 'delete'
+ })
+}
+
+// 用户密码重置
+export function resetUserPwd(userId, password) {
+ const data = {
+ userId,
+ password
+ }
+ return request({
+ url: '/system/user/resetPwd',
+ method: 'put',
+ data: data
+ })
+}
+
+// 用户状态修改
+export function changeUserStatus(userId, status) {
+ const data = {
+ userId,
+ status
+ }
+ return request({
+ url: '/system/user/changeStatus',
+ method: 'put',
+ data: data
+ })
+}
+
+// 查询用户个人信息
+export function getUserProfile() {
+ return request({
+ url: '/system/user/profile',
+ method: 'get'
+ })
+}
+
+// 修改用户个人信息
+export function updateUserProfile(data) {
+ return request({
+ url: '/system/user/profile',
+ method: 'put',
+ data: data
+ })
+}
+
+// 用户密码重置
+export function updateUserPwd(oldPassword, newPassword) {
+ const data = {
+ oldPassword,
+ newPassword
+ }
+ return request({
+ url: '/system/user/profile/updatePwd',
+ method: 'put',
+ data: data
+ })
+}
+
+// 用户头像上传
+export function uploadAvatar(data) {
+ return request({
+ url: '/system/user/profile/avatar',
+ method: 'post',
+ headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
+ data: data
+ })
+}
+
+// 查询授权角色
+export function getAuthRole(userId) {
+ return request({
+ url: '/system/user/authRole/' + userId,
+ method: 'get'
+ })
+}
+
+// 保存授权角色
+export function updateAuthRole(data) {
+ return request({
+ url: '/system/user/authRole',
+ method: 'put',
+ params: data
+ })
+}
+
+// 查询部门下拉树结构
+export function deptTreeSelect() {
+ return request({
+ url: '/system/user/deptTree',
+ method: 'get'
+ })
+}
+
+//获取理货员下拉字典
+export function personListDict() {
+ return request({
+ url: '/information/user/getAll',
+ method: 'get'
+ })
+}
diff --git a/src/api/tool/gen.js b/src/api/tool/gen.js
new file mode 100644
index 0000000..2075677
--- /dev/null
+++ b/src/api/tool/gen.js
@@ -0,0 +1,85 @@
+import request from '@/utils/request'
+
+// 查询生成表数据
+export function listTable(query) {
+ return request({
+ url: '/tool/gen/list',
+ method: 'get',
+ params: query
+ })
+}
+// 查询db数据库列表
+export function listDbTable(query) {
+ return request({
+ url: '/tool/gen/db/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询表详细信息
+export function getGenTable(tableId) {
+ return request({
+ url: '/tool/gen/' + tableId,
+ method: 'get'
+ })
+}
+
+// 修改代码生成信息
+export function updateGenTable(data) {
+ return request({
+ url: '/tool/gen',
+ method: 'put',
+ data: data
+ })
+}
+
+// 导入表
+export function importTable(data) {
+ return request({
+ url: '/tool/gen/importTable',
+ method: 'post',
+ params: data
+ })
+}
+
+// 创建表
+export function createTable(data) {
+ return request({
+ url: '/tool/gen/createTable',
+ method: 'post',
+ params: data
+ })
+}
+
+// 预览生成代码
+export function previewTable(tableId) {
+ return request({
+ url: '/tool/gen/preview/' + tableId,
+ method: 'get'
+ })
+}
+
+// 删除表数据
+export function delTable(tableId) {
+ return request({
+ url: '/tool/gen/' + tableId,
+ method: 'delete'
+ })
+}
+
+// 生成代码(自定义路径)
+export function genCode(tableName) {
+ return request({
+ url: '/tool/gen/genCode/' + tableName,
+ method: 'get'
+ })
+}
+
+// 同步数据库
+export function synchDb(tableName) {
+ return request({
+ url: '/tool/gen/synchDb/' + tableName,
+ method: 'get'
+ })
+}
diff --git a/src/api/wisdom/borrow.js b/src/api/wisdom/borrow.js
new file mode 100644
index 0000000..6163686
--- /dev/null
+++ b/src/api/wisdom/borrow.js
@@ -0,0 +1,25 @@
+import request from '@/utils/request'
+//借料记录列表
+export function listOutbound(data) {
+ return request({
+ url: '/wisdom/stock/borrow/list',
+ method: 'post',
+ data: data
+ })
+}
+// 借料出库保存
+export function addOutbound(data) {
+ return request({
+ url: '/wisdom/stock/outStock',
+ method: 'put',
+ data: data
+ })
+}
+// 还料入库保存
+export function returnSubmit(data) {
+ return request({
+ url: '/wisdom/stock/refund',
+ method: 'post',
+ data: data
+ })
+ }
\ No newline at end of file
diff --git a/src/api/wisdom/dispatch.js b/src/api/wisdom/dispatch.js
new file mode 100644
index 0000000..2b1884e
--- /dev/null
+++ b/src/api/wisdom/dispatch.js
@@ -0,0 +1,68 @@
+import request from '@/utils/request'
+
+// 查询调度任务列表
+export function listTask(query) {
+ return request({
+ url: '/wisdom/dispatch/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询调度任务详细
+export function getTask(id) {
+ return request({
+ url: '/wisdom/dispatch/' + id,
+ method: 'get'
+ })
+}
+
+// 新增调度任务
+export function addTask(data) {
+ return request({
+ url: '/wisdom/dispatch',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改调度任务
+export function updateTask(data) {
+ return request({
+ url: '/wisdom/dispatch',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除调度任务
+export function delTask(id) {
+ return request({
+ url: '/wisdom/dispatch/' + id,
+ method: 'delete'
+ })
+}
+// 执行调度任务 下架
+export function executeTask1(data) {
+ return request({
+ url: '/wisdom/dispatch/execute',
+ method: 'post',
+ data: data
+ })
+}
+// 执行调度任务 上架
+export function wcsTask(data) {
+ return request({
+ url: '/wisdom/upGoods',
+ method: 'post',
+ data: data
+ })
+}
+//定时任务 查询立库执行状态
+export function wcsStatus(query) {
+ return request({
+ url: '/wisdom/wcs/query',
+ method: 'get',
+ params: query
+ })
+}
\ No newline at end of file
diff --git a/src/api/wisdom/inrevoke.js b/src/api/wisdom/inrevoke.js
new file mode 100644
index 0000000..cd672f0
--- /dev/null
+++ b/src/api/wisdom/inrevoke.js
@@ -0,0 +1,24 @@
+import request from '@/utils/request'
+// 查询列表数据
+export function listInrevoke(data) {
+ return request({
+ url: '/wisdom/stock/list',
+ method: 'post',
+ data: data
+ })
+}
+export function delStore(data) {
+ return request({
+ url: '/wisdom/stock/deleteByIds',
+ method: 'post',
+ data: data
+ })
+}
+export function storeFun(data) {
+ return request({
+ url: '/wisdom/stock/revertByIds',
+ method: 'post',
+ data: data
+ })
+}
+
diff --git a/src/api/wisdom/inventorySearch.js b/src/api/wisdom/inventorySearch.js
new file mode 100644
index 0000000..84773f3
--- /dev/null
+++ b/src/api/wisdom/inventorySearch.js
@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+export function updateStock(data) {
+ return request({
+ // url: '/wisdom/stock/page',
+ url: '/wisdom/stock/update',
+ method: 'post',
+ data: data
+ })
+}
\ No newline at end of file
diff --git a/src/api/wisdom/jh.js b/src/api/wisdom/jh.js
new file mode 100644
index 0000000..4192946
--- /dev/null
+++ b/src/api/wisdom/jh.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询供应计划列表
+export function listJh(query) {
+ return request({
+ url: '/wisdom/jh/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询供应计划详细
+export function getJh(id) {
+ return request({
+ url: '/wisdom/jh/' + id,
+ method: 'get'
+ })
+}
+
+// 新增供应计划
+export function addJh(data) {
+ return request({
+ url: '/wisdom/jh',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改供应计划
+export function updateJh(data) {
+ return request({
+ url: '/wisdom/jh',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除供应计划
+export function delJh(id) {
+ return request({
+ url: '/wisdom/jh/' + id,
+ method: 'delete'
+ })
+}
diff --git a/src/api/wisdom/move.js b/src/api/wisdom/move.js
new file mode 100644
index 0000000..e8d575d
--- /dev/null
+++ b/src/api/wisdom/move.js
@@ -0,0 +1,12 @@
+import request from '@/utils/request'
+
+// 查询移库记录列表
+export function listRecord(query) {
+ return request({
+ url: '/inventory/move/list',
+ method: 'get',
+ params: query
+ })
+}
+
+
diff --git a/src/api/wisdom/outbound.js b/src/api/wisdom/outbound.js
new file mode 100644
index 0000000..ed9cf4d
--- /dev/null
+++ b/src/api/wisdom/outbound.js
@@ -0,0 +1,49 @@
+import request from '@/utils/request'
+//出库记录列表
+export function listOutbound(data) {
+ return request({
+ url: '/wisdom/stock/list',
+ method: 'post',
+ data: data
+ })
+}
+// 出库保存
+export function addOutbound(data) {
+ return request({
+ url: '/wisdom/stock/outStock',
+ method: 'put',
+ data: data
+ })
+}
+// 查询库存单据主列表
+export function listBill(data) {
+ return request({
+ url: '/wisdom/stock/bill/groups',
+ method: 'post',
+ data: data
+ })
+}
+export function picDetail(data){
+ return request({
+ url: '/photo/list?billNo='+data.billNo+'&photoType='+data.photoType,
+ method: 'get',
+
+ })
+}
+//生成调度任务
+export function generateDispatch(data){
+ return request({
+ url: '/wisdom/dispatch/batchAdd',
+ method: 'post',
+ data: data
+ })
+}
+
+//左侧修改主单据
+export function editOutbound(data){
+ return request({
+ url: '/wisdom/stock/updateByBillNoCk',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/src/api/wisdom/outrevoke.js b/src/api/wisdom/outrevoke.js
new file mode 100644
index 0000000..f2c9349
--- /dev/null
+++ b/src/api/wisdom/outrevoke.js
@@ -0,0 +1,23 @@
+import request from '@/utils/request'
+// 查询列表数据
+export function listOutrevoke(data) {
+ return request({
+ url: '/wisdom/stock/list',
+ method: 'post',
+ data: data
+ })
+}
+export function delStore(data) {
+ return request({
+ url: '/wisdom/stock/deleteByIds',
+ method: 'post',
+ data: data
+ })
+}
+export function storeFun(data) {
+ return request({
+ url: '/wisdom/stock/revertByIds',
+ method: 'post',
+ data: data
+ })
+}
\ No newline at end of file
diff --git a/src/api/wisdom/return.js b/src/api/wisdom/return.js
new file mode 100644
index 0000000..a53caab
--- /dev/null
+++ b/src/api/wisdom/return.js
@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+//借料记录列表
+export function listOutbound(data) {
+ return request({
+ url: '/wisdom/stock/borrow/list',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/src/api/wisdom/stock.js b/src/api/wisdom/stock.js
new file mode 100644
index 0000000..36cb5ef
--- /dev/null
+++ b/src/api/wisdom/stock.js
@@ -0,0 +1,174 @@
+import request from '@/utils/request'
+
+// 查询库存单据主列表
+export function listBill(data) {
+ return request({
+ url: '/wisdom/stock/bill/groups',
+ method: 'post',
+ data: data
+ })
+}
+//明细列表
+export function listStock(data) {
+ return request({
+ url: '/wisdom/stock/list',
+ method: 'post',
+ data: data
+ })
+}
+
+// 查询库存单据主详细
+export function getStock(id) {
+ return request({
+ url: '/wisdom/stock/' + id,
+ method: 'get'
+ })
+}
+
+// 新增库存单据主
+export function addStock(data) {
+ return request({
+ url: '/wisdom/stock/add',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改库存单据主
+export function updateStock(data) {
+ return request({
+ url: '/wisdom/stock/update',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除库存单据主
+export function delStock(id) {
+ return request({
+ url: '/wisdom/stock/' + id,
+ method: 'delete'
+ })
+}
+
+//根据订单号获取供应计划
+export function getPlan(orderNum) {
+ // sapNo
+ return request({
+ url: '/plan/jh/getBySapNo?sapNo='+orderNum,
+ method: 'get'
+ })
+}
+
+//移库
+export function moveHouse(data) {
+ // sapNo
+ return request({
+ url: '/inventory/move/add',
+ method: 'post',
+ data: data
+ })
+}
+
+//是否开启审核
+export function getAudit(data){
+ return request({
+ url: '/system/config/configKey/rk.audit.enabled',
+ method: 'get',
+ data: data
+ })
+}
+
+//撤销入库 整笔
+
+// export function wisdomDelStock(data){
+// return request({
+// url: '/wisdom/stock/deleteByBillNo',
+// method: 'get',
+// data: data
+// })
+// }
+//撤销入库 单条
+export function wisdomDelStock(data){
+ return request({
+ url: '/wisdom/stock/cancel',
+ method: 'post',
+ data: data
+ })
+}
+export function ckDelStock(id){
+ return request({
+ url: '/wisdom/stock/cancelById/'+id,
+ method: 'post',
+
+ })
+}
+export function wlSearch(mid){
+ return request({
+ url: '/information/mtd/list?mid='+mid,
+ method: 'get',
+
+ })
+}
+export function uploadContract(data){
+ return request({
+ url: '/photo/upload/batch',
+ method: 'post',
+ data: data,
+ isUpload:true
+ })
+}
+// export function picDetail(data){
+// return request({
+// url: '/photo/list?billNo='+data.billNo+'&photoType='+data.photoType,
+// method: 'get',
+
+// })
+// }
+export function picDetail(data){
+ return request({
+ url: '/photo/listData?billNo='+data.billNo+'&photoType='+data.photoType,
+ method: 'get',
+
+ })
+}
+export function printTag(data){
+ return request({
+ url: '/pk/dat/batchAdd',
+ method: 'post',
+ data: data
+ })
+}
+export function delPicF(PicId){
+ return request({
+ url: '/photo/deleteById?id='+PicId,
+ method: 'get'
+
+ })
+}
+export function editBill(data){
+ return request({
+ url: '/wisdom/stock/editBill',
+ method: 'post',
+ data: data
+ })
+}
+export function addOneStock(data){
+ return request({
+ url: '/wisdom/stock/append',
+ method: 'post',
+ data: data
+ })
+}
+
+
+// 左侧修改查询
+export function getEditInfo(id){
+ return request({
+ url: '/wisdom/stock/header/'+id,
+ method: 'get'
+ })
+}
+
+
+
diff --git a/src/api/wisdom/stockSearch.js b/src/api/wisdom/stockSearch.js
new file mode 100644
index 0000000..cfccc00
--- /dev/null
+++ b/src/api/wisdom/stockSearch.js
@@ -0,0 +1,25 @@
+import request from '@/utils/request'
+export function listStock(data) {
+ return request({
+ // url: '/wisdom/stock/page',
+ // url: '/wisdom/stock/pageStatistics',
+ url: '/wisdom/stock/pageList',
+ method: 'post',
+ data: data
+ })
+}
+export function listSearch(data) {
+ return request({
+ // url: '/wisdom/stock/page',
+ url: '/wisdom/stock/pageStatistics',
+ method: 'post',
+ data: data
+ })
+}
+export function getSumInfoI(data) {
+ return request({
+ url: '/stat/statistics',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/src/api/wisdom/warehouse.js b/src/api/wisdom/warehouse.js
new file mode 100644
index 0000000..2bbfc0b
--- /dev/null
+++ b/src/api/wisdom/warehouse.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询入库单据列表
+export function listWarehouse(query) {
+ return request({
+ url: '/wisdom/warehouse/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询入库单据详细
+export function getWarehouse(id) {
+ return request({
+ url: '/wisdom/warehouse/' + id,
+ method: 'get'
+ })
+}
+
+// 新增入库单据
+export function addWarehouse(data) {
+ return request({
+ url: '/wisdom/warehouse',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改入库单据
+export function updateWarehouse(data) {
+ return request({
+ url: '/wisdom/warehouse',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除入库单据
+export function delWarehouse(id) {
+ return request({
+ url: '/wisdom/warehouse/' + id,
+ method: 'delete'
+ })
+}
diff --git a/src/assets/401_images/401.gif b/src/assets/401_images/401.gif
new file mode 100644
index 0000000000000000000000000000000000000000..cd6e0d9433421b3f29d0ec0c40f755e354728000
GIT binary patch
literal 164227
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