明树Git Lab
Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
J
jt_backend
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
zengfanpei
jt_backend
Commits
b7ef98b1
Commit
b7ef98b1
authored
Nov 27, 2025
by
zfp1
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
update
parent
54333293
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
152 additions
and
6 deletions
+152
-6
messageController.js
controller/messageController.js
+121
-0
projectController.js
controller/projectController.js
+4
-0
index.js
db/index.js
+9
-1
flowRecord.js
db/model/system/flowRecord.js
+1
-2
index.js
router/index.js
+2
-0
messageRouter.js
router/messageRouter.js
+14
-0
resourceRouter.js
router/resourceRouter.js
+1
-3
No files found.
controller/messageController.js
0 → 100644
View file @
b7ef98b1
const
errorMessage
=
require
(
"../utils/errorMessage"
);
const
{
Op
}
=
require
(
"sequelize"
);
async
function
getMessageInfo
(
req
,
res
,
next
)
{
try
{
if
(
!
req
.
body
.
id
)
{
return
res
.
sendError
(
errorMessage
.
resourceNotFound
);
}
const
message
=
await
DB
.
Message
.
findOne
({
where
:
{
id
:
req
.
body
.
id
,
del
:
0
},
include
:
[
{
model
:
DB
.
User
,
as
:
'creatorInfo'
,
attributes
:
[
'id'
,
'name'
,
'avatar'
]
}
]
});
message
.
alreadyRead
=
message
.
alreadyRead
||
[];
message
.
alreadyRead
.
push
(
req
.
user
.
id
);
await
message
.
save
();
return
res
.
sendData
(
message
);
}
catch
(
error
)
{
next
(
error
);
}
}
async
function
deleteMessage
(
req
,
res
,
next
)
{
try
{
if
(
req
.
body
.
id
)
{
await
DB
.
Message
.
update
(
{
del
:
1
},
{
where
:
{
id
:
req
.
body
.
id
}
}
);
return
res
.
sendData
();
}
if
(
req
.
body
.
ids
&&
Array
.
isArray
(
req
.
body
.
ids
))
{
await
DB
.
Message
.
update
(
{
del
:
1
},
{
where
:
{
id
:
{
[
Op
.
in
]:
req
.
body
.
ids
}
}
}
);
return
res
.
sendData
();
}
}
catch
(
error
)
{
next
(
error
);
}
}
/**
* 获取信息列表
* @param {*} req
* @param {*} res
* @param {*} next
* @returns
*/
async
function
getUserMessages
(
req
,
res
,
next
)
{
try
{
const
messages
=
await
DB
.
Message
.
findAll
({
where
:
{
receivers
:
{
[
Op
.
contains
]:
[
req
.
user
.
id
]
},
del
:
0
},
include
:
[
{
model
:
DB
.
User
,
as
:
'creatorInfo'
,
attributes
:
[
'id'
,
'name'
,
'avatar'
]
}
],
raw
:
true
,
order
:
[[
'createdAt'
,
'DESC'
]],
});
let
newRet
=
[];
for
(
let
index
=
0
;
index
<
messages
.
length
;
index
++
)
{
const
element
=
messages
[
index
];
element
.
alreadyRead
=
element
.
alreadyRead
||
[];
element
.
isRead
=
false
;
if
(
element
.
alreadyRead
.
includes
(
req
.
user
.
id
))
{
element
.
isRead
=
true
;
}
newRet
.
push
(
element
);
}
return
res
.
sendData
(
newRet
);
}
catch
(
error
)
{
next
(
error
)
}
}
async
function
getMesCount
(
req
,
res
,
next
)
{
try
{
const
count
=
await
DB
.
Message
.
count
({
where
:
{
receivers
:
{
[
Op
.
contains
]:
[
req
.
user
.
id
]
},
del
:
0
,
alreadyRead
:
{
[
Op
.
not
]:
{[
Op
.
contains
]:
[
req
.
user
.
id
]}
}
}
});
return
res
.
sendData
({
count
});
}
catch
(
error
)
{
next
(
error
);
}
}
module
.
exports
=
{
getUserMessages
,
getMesCount
,
getMessageInfo
,
deleteMessage
,
};
\ No newline at end of file
controller/projectController.js
View file @
b7ef98b1
...
@@ -336,8 +336,10 @@ async function preJugProject(req, res, next) {
...
@@ -336,8 +336,10 @@ async function preJugProject(req, res, next) {
*/
*/
if
(
buttonType
===
'approve'
)
{
if
(
buttonType
===
'approve'
)
{
await
DB
.
Project
.
update
({
projectLiuZhuanType
:
3
},
{
where
:
{
id
}
});
await
DB
.
Project
.
update
({
projectLiuZhuanType
:
3
},
{
where
:
{
id
}
});
//处理项目流转记录 及消息发送TODO:
}
else
{
}
else
{
await
DB
.
Project
.
update
({
projectLiuZhuanType
:
1
},
{
where
:
{
id
}
});
await
DB
.
Project
.
update
({
projectLiuZhuanType
:
1
},
{
where
:
{
id
}
});
//处理项目流转记录 及消息发送TODO:
}
}
return
res
.
sendData
();
return
res
.
sendData
();
...
@@ -367,8 +369,10 @@ async function finalJugProject(req, res, next) {
...
@@ -367,8 +369,10 @@ async function finalJugProject(req, res, next) {
*/
*/
if
(
buttonType
===
'approve'
)
{
if
(
buttonType
===
'approve'
)
{
await
DB
.
Project
.
update
({
projectLiuZhuanType
:
7
},
{
where
:
{
id
}
});
await
DB
.
Project
.
update
({
projectLiuZhuanType
:
7
},
{
where
:
{
id
}
});
//处理项目流转记录 及消息发送TODO:
}
else
{
}
else
{
await
DB
.
Project
.
update
({
projectLiuZhuanType
:
1
},
{
where
:
{
id
}
});
await
DB
.
Project
.
update
({
projectLiuZhuanType
:
1
},
{
where
:
{
id
}
});
//处理项目流转记录 及消息发送TODO:
}
}
return
res
.
sendData
();
return
res
.
sendData
();
...
...
db/index.js
View file @
b7ef98b1
...
@@ -10,6 +10,8 @@ const UserDepart = require("./model/system/userDepart");
...
@@ -10,6 +10,8 @@ const UserDepart = require("./model/system/userDepart");
const
RequestLog
=
require
(
"./model/system/requestLog"
);
const
RequestLog
=
require
(
"./model/system/requestLog"
);
const
File
=
require
(
"./model/system/file"
);
const
File
=
require
(
"./model/system/file"
);
const
Position
=
require
(
"./model/system/position"
);
const
Position
=
require
(
"./model/system/position"
);
const
Message
=
require
(
"./model/system/message"
);
const
FlowRecord
=
require
(
"./model/system/flowRecord"
);
// 业务模型
// 业务模型
const
Project
=
require
(
"./model/jt/project"
);
const
Project
=
require
(
"./model/jt/project"
);
...
@@ -61,6 +63,8 @@ global.DB = {
...
@@ -61,6 +63,8 @@ global.DB = {
ProjectTzzjll
,
ProjectTzzjll
,
ProjectTzzt
,
ProjectTzzt
,
ProjectXmtzze
,
ProjectXmtzze
,
Message
,
FlowRecord
,
}
}
...
@@ -173,4 +177,8 @@ Project.hasMany(ProjectTzzt, { foreignKey: 'projectId', as: 'projectTzzts' });
...
@@ -173,4 +177,8 @@ Project.hasMany(ProjectTzzt, { foreignKey: 'projectId', as: 'projectTzzts' });
ProjectTzzt
.
belongsTo
(
Project
,
{
foreignKey
:
'projectId'
});
ProjectTzzt
.
belongsTo
(
Project
,
{
foreignKey
:
'projectId'
});
/**项目-项目投资总额 1:n */
/**项目-项目投资总额 1:n */
Project
.
hasMany
(
ProjectXmtzze
,
{
foreignKey
:
'projectId'
,
as
:
'projectXmtzzes'
});
Project
.
hasMany
(
ProjectXmtzze
,
{
foreignKey
:
'projectId'
,
as
:
'projectXmtzzes'
});
ProjectXmtzze
.
belongsTo
(
Project
,
{
foreignKey
:
'projectId'
});
ProjectXmtzze
.
belongsTo
(
Project
,
{
foreignKey
:
'projectId'
});
\ No newline at end of file
/**项目-项目流转记录 */
Project
.
hasMany
(
FlowRecord
,
{
foreignKey
:
'projectId'
,
as
:
'flowRecords'
});
FlowRecord
.
belongsTo
(
Project
,
{
foreignKey
:
'projectId'
});
\ No newline at end of file
db/model/system/flowRecord.js
View file @
b7ef98b1
// models/flowRecord.js
// models/flowRecord.js
const
{
DataTypes
}
=
require
(
'sequelize'
);
const
{
DataTypes
}
=
require
(
'sequelize'
);
const
sequelize
=
require
(
'../index'
);
const
sequelize
=
require
(
'../index'
);
const
User
=
require
(
'./system/user'
);
const
User
=
require
(
'../system/user'
);
const
{
act
}
=
require
(
'react'
);
/**
/**
* 记录流程动作记录
* 记录流程动作记录
*/
*/
...
...
router/index.js
View file @
b7ef98b1
...
@@ -12,6 +12,8 @@ router.use('/file', fileRouter); // 文件上传下载
...
@@ -12,6 +12,8 @@ router.use('/file', fileRouter); // 文件上传下载
router
.
use
(
'/project'
,
require
(
'./projectRouter.js'
));
// 项目管理
router
.
use
(
'/project'
,
require
(
'./projectRouter.js'
));
// 项目管理
router
.
use
(
'/resource'
,
require
(
'./resourceRouter.js'
));
// 资源管理
router
.
use
(
'/resource'
,
require
(
'./resourceRouter.js'
));
// 资源管理
router
.
use
(
'/message'
,
require
(
'./messageRouter.js'
));
// 消息管理
module
.
exports
=
router
;
module
.
exports
=
router
;
\ No newline at end of file
router/messageRouter.js
0 → 100644
View file @
b7ef98b1
const
express
=
require
(
'express'
);
const
router
=
express
.
Router
();
const
messageController
=
require
(
'../controller/messageController'
);
/**
* 消息
*/
router
.
post
(
'/getMesCount'
,
messageController
.
getMesCount
);
//获取用户未读消息数量
router
.
post
(
'/getUserMessages'
,
messageController
.
getUserMessages
);
//用户获取自己的消息列表
router
.
post
(
'/getMessageInfo'
,
messageController
.
getMessageInfo
);
//获取消息详情
router
.
post
(
'/deleteMessage'
,
messageController
.
deleteMessage
);
//删除消息
module
.
exports
=
router
;
\ No newline at end of file
router/resourceRouter.js
View file @
b7ef98b1
...
@@ -6,17 +6,15 @@ const resourceController = require('../controller/resourceController');
...
@@ -6,17 +6,15 @@ const resourceController = require('../controller/resourceController');
/**
/**
* 资源库
* 资源库
*/
*/
// router.post('/resource', resourceController.createResource);
router
.
post
(
'/createResource'
,
resourceController
.
createResource
);
router
.
post
(
'/createResource'
,
resourceController
.
createResource
);
router
.
post
(
'/deleteResource'
,
resourceController
.
deleteResource
);
router
.
post
(
'/deleteResource'
,
resourceController
.
deleteResource
);
router
.
post
(
'/updateResource'
,
resourceController
.
updateResource
);
router
.
post
(
'/updateResource'
,
resourceController
.
updateResource
);
router
.
post
(
'/listResource'
,
resourceController
.
listResource
);
router
.
post
(
'/listResource'
,
resourceController
.
listResource
);
// router.post('/getProjectFields', projectController.getProjectFields);
/**
/**
* 资源库字段详情
* 资源库字段详情
*/
*/
// router.post('/resourceInfo', resourceController.createResourceInfo);
router
.
post
(
'/createResourceInfo'
,
resourceController
.
createResourceInfo
);
router
.
post
(
'/createResourceInfo'
,
resourceController
.
createResourceInfo
);
router
.
post
(
'/deleteResourceInfo'
,
resourceController
.
deleteResourceInfo
);
router
.
post
(
'/deleteResourceInfo'
,
resourceController
.
deleteResourceInfo
);
router
.
post
(
'/updateResourceInfo'
,
resourceController
.
updateResourceInfo
);
router
.
post
(
'/updateResourceInfo'
,
resourceController
.
updateResourceInfo
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment