-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtask.js
107 lines (85 loc) · 2.56 KB
/
task.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
const {combineResolvers} = require('graphql-resolvers')
const {stringToBase64, base64ToString } = require('../helper')
const Task = require('../database/Models/task')
const User = require('../database/Models/user')
const { isAuthenticated, isTaskOwner} = require('./middleware')
const task = require('../typeDefs/task')
module.exports = {
Query: {
tasks:combineResolvers(isAuthenticated,async (_,{ cursor,limit=10 },{loggedInUserId}) => {
try {
const query = { user: loggedInUserId}
if(cursor){
query['_id'] = {
'$lt': base64ToString(cursor)
}
}
let tasks = await Task.find(query).sort({_id: -1}).limit(limit + 1)
const hasNextPage = tasks.length > limit
tasks = hasNextPage ? tasks.slice(0, -1) : tasks
return {
taskFeed: tasks,
pageInfo: {
nextPageCursor: hasNextPage ? stringToBase64(tasks[tasks.length - 1].id) : null,
hasNextPage
}
}
} catch (error) {
console.log(error)
throw error
}
}),
task:combineResolvers(isAuthenticated,isTaskOwner, async(_, { id }) => {
try {
const task = await Task.findById(id)
return task
} catch (error) {
console.log(error)
throw error
}
}) ,
},
Mutation: {
createTask: combineResolvers(isAuthenticated,async(_, { input }, {email}) => {
try {
const user = await User.findOne({email})
const task = new Task({...input, user:user.id})
const result = await task.save();
user.tasks.push(result.id)
await user.save();
return result
} catch (error) {
}
}),
updateTask: combineResolvers(isAuthenticated, isTaskOwner, async (_, {id, input})=>{
try {
const task = await Task.findByIdAndUpdate(id, {...input},{new: true})
return task
} catch (error) {
console.log(error)
throw error
}
}),
deleteTask: combineResolvers(isAuthenticated,isTaskOwner,async (_,{id},{loggedInUserId}) =>{
try {
const task = await Task.findByIdAndDelete(id)
await User.updateOne({_id: loggedInUserId },{$pull: {tasks: task.id}})
return task;
} catch (error) {
console.log(error)
throw error
}
})
},
Task: {
user: async(parent) => {
try {
const user = await User.findById(parent.user)
return user
} catch (error) {
console.log(error)
throw error
}
}
}
}