Toggle navigation
Toggle navigation
This project
Loading...
Sign in
2020-1-capstone-design1
/
Triz_Project1
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Graphs
Issues
1
Merge Requests
0
Wiki
Snippets
Network
Create a new issue
Builds
Commits
Issue Boards
Authored by
sdy
2020-06-01 05:21:51 +0900
Browse Files
Options
Browse Files
Download
Email Patches
Plain Diff
Commit
1f7067d596cec6efcfd437ae2fe2d49295b759f2
1f7067d5
1 parent
eaee8ec0
update Queries
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
18 deletions
front/src/Routes/Chat/ChatContainer.js
front/src/Routes/Chat/ChatContainer.js
View file @
1f7067d
import
React
from
"react"
;
import
{
useMutation
,
useQuery
}
from
"@apollo/react-hooks"
;
import
React
,
{
useEffect
}
from
"react"
;
import
{
useMutation
,
useQuery
,
useSubscription
}
from
"@apollo/react-hooks"
;
import
ChatPresenter
from
"./ChatPresenter"
;
import
{
withRouter
}
from
"react-router-dom"
;
import
{
CREATE_MESSAGE
,
GET_ROOM_BY_NAME
,
SEE_ALL_MESSAGE
,
SUBSCRIPTION_MSG
,
}
from
"./ChatQueries"
;
import
useInput
from
"../../Hooks/useInput"
;
import
{
toast
}
from
"react-toastify"
;
import
defaultProfile
from
"../imgs/defaultProfile.jpg"
;
export
default
withRouter
(({
location
})
=>
{
const
{
pathname
}
=
location
;
const
roomName
=
pathname
.
slice
(
1
,
pathname
.
length
);
const
[
createMsg
]
=
useMutation
(
CREATE_MESSAGE
);
//const { data
} = useSubscription(SUBSCRIPTION_MSG);
const
{
data
:
subScription
}
=
useSubscription
(
SUBSCRIPTION_MSG
);
const
message
=
useInput
(
""
);
let
messageObj
,
roomNum
,
message
Text
,
messageTime
,
newMsgObj
,
message
Array
;
let
messageObj
,
roomNum
,
messageArray
;
const
{
data
:
getRoom
}
=
useQuery
(
GET_ROOM_BY_NAME
,
{
variables
:
{
roomName
},
...
...
@@ -31,17 +31,37 @@ export default withRouter(({ location }) => {
roomNum
=
Number
(
roomId
);
}
const
{
data
:
messageList
}
=
useQuery
(
SEE_ALL_MESSAGE
,
{
const
{
subscribeToMore
,
data
:
messageList
}
=
useQuery
(
SEE_ALL_MESSAGE
,
{
variables
:
{
roomId
:
roomNum
},
});
if
(
messageList
!==
undefined
)
{
messageList
.
seeAllMessage
.
map
((
e
)
=>
{
if
(
e
.
sender
.
avatarUrl
===
""
)
{
e
.
sender
.
avatarUrl
=
"../../imgs/defaultProfile.jpg"
;
}
});
messageArray
=
messageList
;
}
let
testObj
;
testObj
=
subscribeToMore
({
document
:
SUBSCRIPTION_MSG
,
updateQuery
:
(
prev
,
{
subscriptionData
})
=>
{
console
.
log
(
"prev : "
,
prev
);
console
.
log
(
"subscriptionData : "
,
subscriptionData
);
if
(
!
subscriptionData
.
data
)
return
prev
;
const
newFeedItem
=
subscriptionData
.
data
.
subMessage
;
console
.
log
(
"newFeedItem : "
,
newFeedItem
);
return
Object
.
assign
({},
prev
,
{
seeAllMessage
:
{
id
,
},
});
},
});
console
.
log
(
testObj
);
const
onSubmit
=
async
(
e
)
=>
{
e
.
preventDefault
();
if
(
message
.
value
!==
undefined
||
message
.
value
!==
""
)
{
...
...
@@ -54,29 +74,20 @@ export default withRouter(({ location }) => {
});
if
(
!
messageObj
)
{
toast
.
error
(
"fail to create new message !, try again"
);
}
else
{
const
{
data
:
{
createMessage
:
{
text
,
createdAt
},
},
}
=
messageObj
;
messageText
=
text
;
messageTime
=
createdAt
;
newMsgObj
=
messageObj
;
}
}
catch
{
toast
.
error
(
"text must be not empty"
);
}
}
};
useEffect
(()
=>
{});
return
(
<
ChatPresenter
location
=
{
location
}
message
=
{
message
}
onSubmit
=
{
onSubmit
}
messageText
=
{
messageText
}
messageTime
=
{
messageTime
}
newMsgObj
=
{
newMsgObj
}
messageArray
=
{
messageArray
}
/
>
);
...
...
Please
register
or
login
to post a comment