feat: 广告还有角色异常报错

This commit is contained in:
chashaobao
2025-07-12 15:28:40 +08:00
parent 42d1208ee4
commit 80846d507f
10 changed files with 17 additions and 26 deletions

View File

@ -22,7 +22,7 @@ const GET_CONTACT_TYPE_OPTIONS = [
{ {
type: GET_CONTACT_TYPE.SHARE, type: GET_CONTACT_TYPE.SHARE,
icon: 'https://publiccdn.neighbourhood.com.cn/img/file.svg', icon: 'https://publiccdn.neighbourhood.com.cn/img/file.svg',
title: '完善资料', title: '转发推广',
desc: '转发给朋友可享推荐奖励', desc: '转发给朋友可享推荐奖励',
btnText: '分享', btnText: '分享',
}, },
@ -30,7 +30,7 @@ const GET_CONTACT_TYPE_OPTIONS = [
type: GET_CONTACT_TYPE.VIP, type: GET_CONTACT_TYPE.VIP,
icon: 'https://publiccdn.neighbourhood.com.cn/img/diamond.svg', icon: 'https://publiccdn.neighbourhood.com.cn/img/diamond.svg',
title: '播络会员', title: '播络会员',
desc: '开通会员每天可查看10个', desc: '开通会员每天可查看5个',
btnText: '开通', btnText: '开通',
}, },
{ {

View File

@ -15,7 +15,6 @@ import { DeclarationType, ProductType } from '@/constants/product';
import { JobDetails } from '@/types/job'; import { JobDetails } from '@/types/job';
import { ProductInfo } from '@/types/product'; import { ProductInfo } from '@/types/product';
import { logWithPrefix } from '@/utils/common'; import { logWithPrefix } from '@/utils/common';
import { getSkipPrejobAction, setSkipPrejobAction } from '@/utils/job';
import { import {
requestAllBuyProduct, requestAllBuyProduct,
requestProductBalance, requestProductBalance,
@ -49,6 +48,7 @@ function ProductJobDialog(props: Omit<IProps, 'visible'>) {
const handleClosePrejob = useCallback(() => { const handleClosePrejob = useCallback(() => {
setShowPrejob(false); setShowPrejob(false);
onClose();
}, []); }, []);
const handleConfirmPrejob = useCallback(async (type: GET_CONTACT_TYPE) => { const handleConfirmPrejob = useCallback(async (type: GET_CONTACT_TYPE) => {
@ -115,14 +115,9 @@ function ProductJobDialog(props: Omit<IProps, 'visible'>) {
const allowBuy = await requestAllBuyProduct(PRODUCT_CODE); const allowBuy = await requestAllBuyProduct(PRODUCT_CODE);
setShowContact(true); setShowContact(true);
setStatus(allowBuy ? DialogStatus.JOB_BUY : DialogStatus.JOB_UNABLE_UNLOCK); setStatus(allowBuy ? DialogStatus.JOB_BUY : DialogStatus.JOB_UNABLE_UNLOCK);
} } else if (isPaidVip || skipPreAction) {
// 创建模卡之后可以直接解锁一次, 分享后解锁一次
else if (isPaidVip || getSkipPrejobAction() || skipPreAction) {
const productInfo = await requestUseProduct(PRODUCT_CODE, { jobId: data.id }); const productInfo = await requestUseProduct(PRODUCT_CODE, { jobId: data.id });
setShowPrejob(false); setShowPrejob(false);
if (!skipPreAction) {
setSkipPrejobAction(false);
}
handleContact(productInfo.declarationTypeResult); handleContact(productInfo.declarationTypeResult);
} else { } else {
setShowPrejob(true); setShowPrejob(true);

View File

@ -15,5 +15,4 @@ export enum CacheKey {
JOIN_GROUP_CARD_CLICKED = '__join_group_card_clicked__', JOIN_GROUP_CARD_CLICKED = '__join_group_card_clicked__',
SHARE_TO_GET_JOB_CONTACT = '__share_to_get_job_contract__', SHARE_TO_GET_JOB_CONTACT = '__share_to_get_job_contract__',
SHARE_TO_GET_ANCHOR_CONTACT = '__share_to_get_anchor_contract__', SHARE_TO_GET_ANCHOR_CONTACT = '__share_to_get_anchor_contract__',
SKIP_PREACTION = '__skip_preaction__',
} }

View File

@ -26,6 +26,7 @@ export enum RESPONSE_ERROR_CODE {
INSUFFICIENT_BALANCE = 'INSUFFICIENT_BALANCE', // 聊天或者模卡查看超出限制 INSUFFICIENT_BALANCE = 'INSUFFICIENT_BALANCE', // 聊天或者模卡查看超出限制
INSUFFICIENT_FREE_BALANCE = 'INSUFFICIENT_FREE_BALANCE', // 免费查看次数(未购买会员)超限 INSUFFICIENT_FREE_BALANCE = 'INSUFFICIENT_FREE_BALANCE', // 免费查看次数(未购买会员)超限
BOSS_VIP_EXPIRED = 'BOSS_VIP_EXPIRED', // 会员过期 BOSS_VIP_EXPIRED = 'BOSS_VIP_EXPIRED', // 会员过期
CHAT_MSG_SEND_NOT_ALLOW = 'CHAT_MSG_SEND_NOT_ALLOW',
} }
export const RESPONSE_ERROR_INFO: { [key in RESPONSE_ERROR_CODE]?: string } = { export const RESPONSE_ERROR_INFO: { [key in RESPONSE_ERROR_CODE]?: string } = {

View File

@ -271,9 +271,11 @@ export default function JobDetail() {
}, []); }, []);
useLoad(async () => { useLoad(async () => {
switchRoleType(RoleType.Anchor); const query = getPageQuery<Pick<JobDetails, 'id'> & { c: string; share: string }>();
const query = getPageQuery<Pick<JobDetails, 'id'> & { c: string }>(); if (query?.share === 'true') {
switchRoleType(RoleType.Anchor);
}
getInviteCodeFromQueryAndUpdate(query); getInviteCodeFromQueryAndUpdate(query);
const jobId = query?.id; const jobId = query?.id;
if (!jobId) { if (!jobId) {

View File

@ -15,7 +15,7 @@ import useLocation from '@/hooks/use-location';
import { MaterialProfile } from '@/types/material'; import { MaterialProfile } from '@/types/material';
import { logWithPrefix } from '@/utils/common'; import { logWithPrefix } from '@/utils/common';
import { collectEvent } from '@/utils/event'; import { collectEvent } from '@/utils/event';
import { isFullTimePriceRequired, isPartTimePriceRequired, setSkipPrejobAction } from '@/utils/job'; import { isFullTimePriceRequired, isPartTimePriceRequired } from '@/utils/job';
import { updateProfile, subscribeMaterialMessage } from '@/utils/material'; import { updateProfile, subscribeMaterialMessage } from '@/utils/material';
import { navigateBack } from '@/utils/route'; import { navigateBack } from '@/utils/route';
import Toast from '@/utils/toast'; import Toast from '@/utils/toast';
@ -110,7 +110,6 @@ export default function MaterialCreateProfile() {
// 发起订阅不能在异步任务中,保证是第一个 // 发起订阅不能在异步任务中,保证是第一个
await Promise.all([subscribeMaterialMessage(), updateProfile(data)]); await Promise.all([subscribeMaterialMessage(), updateProfile(data)]);
} }
setSkipPrejobAction();
Taro.eventCenter.trigger(EventName.CREATE_PROFILE); Taro.eventCenter.trigger(EventName.CREATE_PROFILE);
nextType ? setGroupType(nextType) : navigateBack(2); nextType ? setGroupType(nextType) : navigateBack(2);
} catch (e) { } catch (e) {

View File

@ -167,6 +167,9 @@ export default function MessageChat() {
) { ) {
tips = '今日申请交换联系方式次数已用完当前每日限制为5次'; tips = '今日申请交换联系方式次数已用完当前每日限制为5次';
duration = 3000; duration = 3000;
} else if (errorCode === RESPONSE_ERROR_CODE.CHAT_MSG_SEND_NOT_ALLOW) {
tips = '账号已在另一台设备上切换身份,本条消息未发送成功,请在本设备重新切换身份后,再发送消息';
duration = 5000;
} }
tips.length > 7 ? Toast.info(tips, duration) : Toast.error(tips, duration); tips.length > 7 ? Toast.info(tips, duration) : Toast.error(tips, duration);
} }

View File

@ -21,9 +21,9 @@
padding-top: var(--tabs-wrap-height); padding-top: var(--tabs-wrap-height);
} }
.taroify-tabs__nav .taroify-tabs__tab:nth-child(2) .taroify-badge-wrapper { //.taroify-tabs__nav .taroify-tabs__tab:nth-child(2) .taroify-badge-wrapper {
left: 18px; // left: 18px;
} //}
} }
&__star { &__star {

View File

@ -106,7 +106,7 @@ export default function BizService() {
title={ title={
<> <>
<Image src={require('@/statics/svg/star.svg')} className={`${PREFIX}__star`} /> {/*<Image src={require('@/statics/svg/star.svg')} className={`${PREFIX}__star`} />*/}
</> </>
} }
> >

View File

@ -132,14 +132,6 @@ export function postCloseJob(jobId: string) {
return http.post(API.CLOSE_JOB, { data: { jobId }, contentType: 'application/x-www-form-urlencoded' }); return http.post(API.CLOSE_JOB, { data: { jobId }, contentType: 'application/x-www-form-urlencoded' });
} }
export function setSkipPrejobAction(skip = true) {
Taro.setStorageSync(CacheKey.SKIP_PREACTION, skip);
}
export function getSkipPrejobAction() {
return !!Taro.getStorageSync(CacheKey.SKIP_PREACTION);
}
export function setShareToGetContact(job = true) { export function setShareToGetContact(job = true) {
Taro.setStorageSync(job ? CacheKey.SHARE_TO_GET_JOB_CONTACT : CacheKey.SHARE_TO_GET_ANCHOR_CONTACT, true); Taro.setStorageSync(job ? CacheKey.SHARE_TO_GET_JOB_CONTACT : CacheKey.SHARE_TO_GET_ANCHOR_CONTACT, true);
} }