Skip to content

Commit

Permalink
fix: fixed some errors from error logs and added stack trace parse to…
Browse files Browse the repository at this point in the history
… error log
  • Loading branch information
web-mi committed Dec 16, 2021
1 parent d1c204b commit 1e5b853
Show file tree
Hide file tree
Showing 8 changed files with 80 additions and 23 deletions.
34 changes: 34 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@
"sass-loader": "^10.1.1",
"semver": "7.3.5",
"sockjs-client": "1.5.1",
"stacktrace-js": "^2.0.2",
"style-loader": "2.0.0",
"terser-webpack-plugin": "4.2.3",
"ts-pnp": "1.2.0",
Expand Down
27 changes: 24 additions & 3 deletions src/components/app/ErrorBoundary.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import React, { ReactNode, Component } from 'react';
import StackTrace from 'stacktrace-js';
import { apiPostError } from '../../api/apiPostError';
import { redirectToErrorPage } from '../error/errorHandling';
import { Loading } from './Loading';
Expand All @@ -21,6 +22,7 @@ export type ErrorBoundaryError = {
'Referer'?: string;
};
stack: string;
parsedStack?: string;
};

class ErrorBoundary extends Component<ErrorBoundaryProps, ErrorBoundaryState> {
Expand All @@ -29,6 +31,8 @@ class ErrorBoundary extends Component<ErrorBoundaryProps, ErrorBoundaryState> {
window: null
};

prevError: null | Error = null;

componentDidMount() {
this.setState({
window: typeof window !== 'undefined' ? window : null
Expand All @@ -38,6 +42,13 @@ class ErrorBoundary extends Component<ErrorBoundaryProps, ErrorBoundaryState> {
componentDidCatch(error, info) {
const { window } = this.state;

const isNewError =
!this.prevError || error.toString() !== this.prevError.toString();

if (!isNewError) return;

this.prevError = error;

const errorBoundaryError: ErrorBoundaryError = {
name: error.name,
message: error.message,
Expand All @@ -58,9 +69,19 @@ class ErrorBoundary extends Component<ErrorBoundaryProps, ErrorBoundaryState> {
};
}

apiPostError(errorBoundaryError, info).finally(() => {
redirectToErrorPage(500);
});
StackTrace.fromError(error)
.then((stackFrames) => {
errorBoundaryError.parsedStack = stackFrames
.map((sf) => {
return sf.toString();
})
.join('\n');
})
.finally(() => {
apiPostError(errorBoundaryError, info).finally(() => {
redirectToErrorPage(500);
});
});
}

static getDerivedStateFromError() {
Expand Down
2 changes: 1 addition & 1 deletion src/components/askerInfo/AskerInfo.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ export const AskerInfo = () => {
const isLiveChat = isAnonymousSession(activeSession?.session);
const isGroupChat = isGroupChatForSessionItem(activeSession);
const sessionListType = getTypeOfLocation();
const isPeerChat = activeSession.session?.isPeerChat;
const isPeerChat = activeSession?.session?.isPeerChat;

if (!activeSession) {
return <Loading></Loading>;
Expand Down
4 changes: 2 additions & 2 deletions src/components/askerInfo/AskerInfoData.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ export const AskerInfoData = () => {
const isLiveChat = isAnonymousSession(activeSession?.session);

const consultingType = useConsultingType(
activeSession.session.consultingType
activeSession?.session.consultingType
);

const userSessionData = getContact(activeSession).sessionData;
Expand All @@ -48,7 +48,7 @@ export const AskerInfoData = () => {
{consultingType.titles.default}
</p>
</div>
{activeSession.session.consultingType === 0 && !isLiveChat && (
{activeSession?.session.consultingType === 0 && !isLiveChat && (
<div className="profile__data__item">
<p className="profile__data__label">
{translate('userProfile.data.postcode')}
Expand Down
8 changes: 4 additions & 4 deletions src/components/askerInfo/AskerInfoMonitoring.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ export const AskerInfoMonitoring = () => {
);

useEffect(() => {
apiGetMonitoring(activeSession.session.id)
apiGetMonitoring(activeSession?.session.id)
.then((monitoringData) => {
setMonitoringData(monitoringData);
})
Expand All @@ -52,12 +52,12 @@ export const AskerInfoMonitoring = () => {
cleanMonitoringData = deleteKeyFromObject(cleanMonitoringData, 'meta');

const resort =
activeSession.session.consultingType === 0
activeSession?.session.consultingType === 0
? 'monitoringAddiction'
: 'monitoringU25';
const monitoringLink = `${getSessionListPathForLocation()}/${
activeSession.session.groupId
}/${activeSession.session.id}/userProfile/monitoring${
activeSession?.session.groupId
}/${activeSession?.session.id}/userProfile/monitoring${
sessionListTab ? `?sessionListTab=${sessionListTab}` : ''
}`;

Expand Down
2 changes: 1 addition & 1 deletion src/components/message/MessageItemComponent.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,7 @@ export const MessageItemComponent = ({
const showForwardMessage = () =>
hasRenderedMessage &&
activeSession.type !== SESSION_LIST_TYPES.ENQUIRY &&
chatItem.feedbackGroupId &&
chatItem?.feedbackGroupId &&
hasUserAuthority(AUTHORITIES.USE_FEEDBACK, userData) &&
!activeSession?.isFeedbackSession;

Expand Down
25 changes: 13 additions & 12 deletions src/components/session/SessionItemComponent.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -93,8 +93,10 @@ export const SessionItemComponent = (props: SessionItemProps) => {
const getSessionListTab = () =>
`${sessionListTab ? `?sessionListTab=${sessionListTab}` : ''}`;

const { isAnonymousEnquiry } = props;

const resetUnreadCount = () => {
if (!props.isAnonymousEnquiry) {
if (!isAnonymousEnquiry) {
setNewMessages(0);
initMessageCount = messages?.length;
scrollContainerRef.current
Expand All @@ -104,13 +106,13 @@ export const SessionItemComponent = (props: SessionItemProps) => {
};

useEffect(() => {
if (!props.isAnonymousEnquiry) {
if (scrollContainerRef.current) {
resetUnreadCount();
}
}, []); // eslint-disable-line
}, [scrollContainerRef]); // eslint-disable-line

useEffect(() => {
if (!props.isAnonymousEnquiry && messages) {
if (!isAnonymousEnquiry && messages) {
if (
initialScrollCompleted &&
isMyMessage(messages[messages.length - 1]?.userId)
Expand Down Expand Up @@ -193,7 +195,7 @@ export const SessionItemComponent = (props: SessionItemProps) => {
}
setIsRequestInProgress(true);

apiEnquiryAcceptance(sessionId, props.isAnonymousEnquiry)
apiEnquiryAcceptance(sessionId, isAnonymousEnquiry)
.then(() => {
setOverlayItem(enquirySuccessfullyAcceptedOverlayItem);
setCurrentGroupId(sessionGroupId);
Expand Down Expand Up @@ -284,7 +286,7 @@ export const SessionItemComponent = (props: SessionItemProps) => {
const isOnlyEnquiry = typeIsEnquiry(getTypeOfLocation());

const buttonItem: ButtonItem = {
label: props.isAnonymousEnquiry
label: isAnonymousEnquiry
? translate('enquiry.acceptButton.anonymous')
: translate('enquiry.acceptButton'),
type: BUTTON_TYPES.PRIMARY
Expand Down Expand Up @@ -351,7 +353,7 @@ export const SessionItemComponent = (props: SessionItemProps) => {
legalComponent={props.legalComponent}
/>

{!props.isAnonymousEnquiry && (
{!isAnonymousEnquiry && (
<div
id="session-scroll-container"
className="session__content"
Expand All @@ -361,9 +363,8 @@ export const SessionItemComponent = (props: SessionItemProps) => {
{messages &&
resortData &&
messages.map((message: MessageItem, index) => (
<>
<React.Fragment key={index}>
<MessageItemComponent
key={index}
clientName={
getContact(activeSession).username
}
Expand All @@ -376,7 +377,7 @@ export const SessionItemComponent = (props: SessionItemProps) => {
/>
{index === messages.length - 1 &&
enableInitialScroll()}
</>
</React.Fragment>
))}
<div
className={`session__scrollToBottom ${
Expand All @@ -401,7 +402,7 @@ export const SessionItemComponent = (props: SessionItemProps) => {
</div>
)}

{props.isAnonymousEnquiry && (
{isAnonymousEnquiry && (
<div className="session__content session__content--anonymousEnquiry">
<Headline
semanticLevel="3"
Expand Down Expand Up @@ -452,7 +453,7 @@ export const SessionItemComponent = (props: SessionItemProps) => {
</div>
) : null}

{!props.isAnonymousEnquiry &&
{!isAnonymousEnquiry &&
(!typeIsEnquiry(getTypeOfLocation()) ||
(typeIsEnquiry(getTypeOfLocation()) &&
hasUserAuthority(
Expand Down

0 comments on commit 1e5b853

Please sign in to comment.