feat: update
This commit is contained in:
@ -7,8 +7,9 @@ import { useCallback, useEffect, useRef, useState } from 'react';
|
||||
import HomePage from '@/components/home-page';
|
||||
import MessageCard from '@/components/message-card';
|
||||
import { MessageHelpDialog, MessageNoTimesDialog } from '@/components/message-dialog';
|
||||
import { APP_TAB_BAR_ID, EventName } from '@/constants/app';
|
||||
import { APP_TAB_BAR_ID, EventName, PageType } from '@/constants/app';
|
||||
import { REFRESH_CHAT_LIST_TIME } from '@/constants/message';
|
||||
import { MessageSubscribeIds, SubscribeTempId } from '@/constants/subscribe';
|
||||
import useListHeight, { IUseListHeightProps } from '@/hooks/use-list-height';
|
||||
import useRoleType from '@/hooks/user-role-type';
|
||||
import { MainMessage } from '@/types/message';
|
||||
@ -20,7 +21,10 @@ import {
|
||||
requestUnreadMessageCount,
|
||||
} from '@/utils/message';
|
||||
|
||||
import { isSubscribeRefused, postSubscribe } from '@/utils/subscribe';
|
||||
import './index.less';
|
||||
import { collectEvent } from '@/utils/event';
|
||||
import { CollectEventName } from '@/constants/event';
|
||||
|
||||
const PREFIX = 'page-message';
|
||||
const HEADER_CLASS = `${PREFIX}__header`;
|
||||
@ -58,12 +62,52 @@ export default function Message() {
|
||||
|
||||
const handleClickHelp = useCallback(() => setShowHelp(true), []);
|
||||
|
||||
const handleClickAddMessageTimes = useCallback(async () => {
|
||||
const addMessageTimes = useCallback(async () => {
|
||||
await postAddMessageTimes('message_page');
|
||||
const remain = await requestRemainPushTime();
|
||||
setTimes(remain);
|
||||
}, []);
|
||||
|
||||
const handleClickAddMessageTimes = useCallback(async () => {
|
||||
const [hasRefused, acceptIds] = await isSubscribeRefused(MessageSubscribeIds);
|
||||
if (hasRefused) {
|
||||
await Taro.showModal({
|
||||
title: '提示',
|
||||
content:
|
||||
'您未订阅消息提醒,不能及时获得招聘消息,请前往“设置”,将“新聊天消息”、“未读消息”“面试邀请”均设置为“接收”',
|
||||
showCancel: false,
|
||||
confirmText: '打开设置',
|
||||
});
|
||||
await Taro.openSetting({
|
||||
withSubscriptions: true,
|
||||
});
|
||||
const { subscriptionsSetting: { mainSwitch, itemSettings = {} } = {} } = await Taro.getSetting({
|
||||
withSubscriptions: true,
|
||||
});
|
||||
console.log('subscriptionsSetting:', mainSwitch, itemSettings);
|
||||
const successIds = mainSwitch
|
||||
? MessageSubscribeIds.reduce<SubscribeTempId[]>((acc, id) => {
|
||||
if ((!itemSettings[id] || itemSettings[id] === 'accept') && !acceptIds.includes(id)) {
|
||||
acc.push(id);
|
||||
}
|
||||
return acc;
|
||||
}, [])
|
||||
: [];
|
||||
if (!successIds.length) {
|
||||
return;
|
||||
}
|
||||
console.log('successIds:', successIds);
|
||||
collectEvent(CollectEventName.MESSAGE_DEV_LOG, {
|
||||
action: 'subscribe_new_message_reminder',
|
||||
source: 'message_page',
|
||||
successIds,
|
||||
});
|
||||
await postSubscribe(MessageSubscribeIds, successIds);
|
||||
} else {
|
||||
await addMessageTimes();
|
||||
}
|
||||
}, [addMessageTimes]);
|
||||
|
||||
useDidHide(() => (pageVisibleRef.current = false));
|
||||
|
||||
useDidShow(() => {
|
||||
@ -101,7 +145,7 @@ export default function Message() {
|
||||
}, [roleType]);
|
||||
|
||||
return (
|
||||
<HomePage>
|
||||
<HomePage type={PageType.Message}>
|
||||
<div className={PREFIX}>
|
||||
<div className={HEADER_CLASS}>
|
||||
<div className={`${HEADER_CLASS}__times`}>
|
||||
|
||||
Reference in New Issue
Block a user