Merge branch 'main' of http://192.168.1.42/developOne/harmonyPool into main
* 'main' of http://192.168.1.42/developOne/harmonyPool: (22 commits) fix |> 19569 【8.0新需求】APP拉起换端,去掉广告页显示(从启动页直接跳详情页,返回到首页)功能未实现 fix |> 19569 【8.0新需求】APP拉起换端,去掉广告页显示(从启动页直接跳详情页,返回到首页)功能未实现 ref |>修复缺陷 20481- 进入拉流直播-whh6666直播间-点击全屏按钮,进入全屏,播放控件和标题未实现3s自动隐藏 fix: 进入视频详情,点击评论,缺省图文案偏淡 fix: 关闭网络,访问直播tab,不应展示暂无内容缺省页,应展示无网络缺省页 fix |> 20448 不能评论的稿件详情页面,最下方的推荐阅读,展示不完整 fix |> 19984 图文稿件详情页,播放稿件中的视频,进度滑块与已播放进度条重叠(隐藏过早) fix: 沉浸式视频增加播放中关闭,开启wifi视频流量提示逻辑 fix: 修改Card2Component无网络进入详情页 fix: 18167 UI还原问题-【uat】进入视频直播,打开4g 加载视频,然后关闭4g网络,断网滑动视频,网络缺缺省图没有显示文案 fix |> 20236 【底部导航】进入首页,首次安装包,会有概率新闻图标不展示 ref |> 调整横屏直播底部播放控制层背景渐变 fix |> 20541 搜索环球时报,搜索结果中采集的动态数据详情页不应展示人民日报logo fix |> 点击一键关注,按钮等待状态没显示 ref |> 按华为沟通结论,调整评论输入框键盘消失方法 fix: 20482 号主页>全部tab,直播中缺少lottie动画 fix |> 20448 不能评论的稿件详情页面,最下方的推荐阅读,展示不完整 fix: 20531 【生产环境】进入直播频道,直播中,直播中动图未展示 fix |> 修复【uat】进入竖屏直播-竖屏直播间。点击头像没有跳转到号主页 fix |> 修复直播详情直播间Tab点击图片查看后,返回后触发退出直播间详情问题 ...
Showing
30 changed files
with
216 additions
and
66 deletions
| @@ -64,4 +64,6 @@ export class SpConstants{ | @@ -64,4 +64,6 @@ export class SpConstants{ | ||
| 64 | // 个推推送 | 64 | // 个推推送 |
| 65 | static GETUI_PUSH_CID = "cid" | 65 | static GETUI_PUSH_CID = "cid" |
| 66 | static GETUI_PUSH_DEVICE_TOKEN = "deviceToken" | 66 | static GETUI_PUSH_DEVICE_TOKEN = "deviceToken" |
| 67 | + //link | ||
| 68 | + static HAS_LINK="has_link" | ||
| 67 | } | 69 | } |
| @@ -13,5 +13,7 @@ export const enum ViewType { | @@ -13,5 +13,7 @@ export const enum ViewType { | ||
| 13 | // 已加载结束/非失败/非空/可以是仅一页数据,即楼层数据列表PAGE_GROUP_LIST/ | 13 | // 已加载结束/非失败/非空/可以是仅一页数据,即楼层数据列表PAGE_GROUP_LIST/ |
| 14 | LOADED, | 14 | LOADED, |
| 15 | // 已加载的是tab导航数据(可嵌套page的楼层列表) | 15 | // 已加载的是tab导航数据(可嵌套page的楼层列表) |
| 16 | - NAV_BAR | 16 | + NAV_BAR, |
| 17 | + // 无网络 | ||
| 18 | + NoNetwork | ||
| 17 | } | 19 | } |
| 1 | -import { Logger } from 'wdKit' | 1 | +import { Logger, SPHelper, StringUtils } from 'wdKit' |
| 2 | import { Want } from '@kit.AbilityKit' | 2 | import { Want } from '@kit.AbilityKit' |
| 3 | import { url } from '@kit.ArkTS' | 3 | import { url } from '@kit.ArkTS' |
| 4 | import { AppInnerLinkGenerator } from './AppInnerLinkGenerator' | 4 | import { AppInnerLinkGenerator } from './AppInnerLinkGenerator' |
| @@ -6,6 +6,7 @@ import { ContentType } from '../common/ContentType' | @@ -6,6 +6,7 @@ import { ContentType } from '../common/ContentType' | ||
| 6 | import { AppInnerLink } from './AppInnerLink' | 6 | import { AppInnerLink } from './AppInnerLink' |
| 7 | import { HttpBizUtil, HttpUrlUtils, ResponseDTO } from 'wdNetwork' | 7 | import { HttpBizUtil, HttpUrlUtils, ResponseDTO } from 'wdNetwork' |
| 8 | import { ContentDetailDTO } from 'wdBean' | 8 | import { ContentDetailDTO } from 'wdBean' |
| 9 | +import { SpConstants } from 'wdConstant' | ||
| 9 | 10 | ||
| 10 | const TAG = "AppLinkingManager" | 11 | const TAG = "AppLinkingManager" |
| 11 | 12 | ||
| @@ -16,6 +17,7 @@ export class AppLinkingManager { | @@ -16,6 +17,7 @@ export class AppLinkingManager { | ||
| 16 | 17 | ||
| 17 | private hasEnterMain = false | 18 | private hasEnterMain = false |
| 18 | private lastUrlObj?: url.URL | 19 | private lastUrlObj?: url.URL |
| 20 | + private isJumpInnerLink:boolean = true | ||
| 19 | 21 | ||
| 20 | private static manager: AppLinkingManager | 22 | private static manager: AppLinkingManager |
| 21 | private constructor() { | 23 | private constructor() { |
| @@ -58,13 +60,19 @@ export class AppLinkingManager { | @@ -58,13 +60,19 @@ export class AppLinkingManager { | ||
| 58 | this.comsumeLastUriContent() | 60 | this.comsumeLastUriContent() |
| 59 | } | 61 | } |
| 60 | 62 | ||
| 61 | - comsumeLastUriContent() { | 63 | + comsumeLastUriContent(isJump:boolean = true) { |
| 64 | + this.isJumpInnerLink = isJump | ||
| 62 | Logger.debug(TAG, "尝试消费拉起链接: " + this.lastUrlObj?.toString()) | 65 | Logger.debug(TAG, "尝试消费拉起链接: " + this.lastUrlObj?.toString()) |
| 63 | if (!this.lastUrlObj) { | 66 | if (!this.lastUrlObj) { |
| 64 | return | 67 | return |
| 65 | } | 68 | } |
| 66 | let path = this.lastUrlObj?.pathname ?? "" | 69 | let path = this.lastUrlObj?.pathname ?? "" |
| 67 | 70 | ||
| 71 | + if(!this.isJumpInnerLink && StringUtils.isNotEmpty(path)){ | ||
| 72 | + SPHelper.default.save(SpConstants.HAS_LINK, true) | ||
| 73 | + return | ||
| 74 | + } | ||
| 75 | + | ||
| 68 | if (this.dealWithRMHArticle() | 76 | if (this.dealWithRMHArticle() |
| 69 | || this.dealWithNormalArticle() | 77 | || this.dealWithNormalArticle() |
| 70 | || this.dealWithCreator() | 78 | || this.dealWithCreator() |
| @@ -187,7 +195,9 @@ export class AppLinkingManager { | @@ -187,7 +195,9 @@ export class AppLinkingManager { | ||
| 187 | } | 195 | } |
| 188 | 196 | ||
| 189 | jumpInnerLink(innerLink: string) { | 197 | jumpInnerLink(innerLink: string) { |
| 190 | - Logger.debug(TAG, "即将跳转链接: " + innerLink) | ||
| 191 | - AppInnerLink.jumpWithLink(innerLink) | 198 | + if(this.isJumpInnerLink){ |
| 199 | + Logger.debug(TAG, "即将跳转链接: " + innerLink) | ||
| 200 | + AppInnerLink.jumpWithLink(innerLink) | ||
| 201 | + } | ||
| 192 | } | 202 | } |
| 193 | } | 203 | } |
| @@ -260,7 +260,7 @@ export struct WdWebLocalComponent { | @@ -260,7 +260,7 @@ export struct WdWebLocalComponent { | ||
| 260 | // animateTo({duration: 1000}, () => { | 260 | // animateTo({duration: 1000}, () => { |
| 261 | this.progressOpacity = 0 | 261 | this.progressOpacity = 0 |
| 262 | // }) | 262 | // }) |
| 263 | - }, 3000) | 263 | + }, 4000) |
| 264 | } | 264 | } |
| 265 | cancelProgressTimer() { | 265 | cancelProgressTimer() { |
| 266 | if (this.progressTimerNumber > 0) { | 266 | if (this.progressTimerNumber > 0) { |
| @@ -372,7 +372,7 @@ export struct WdWebLocalComponent { | @@ -372,7 +372,7 @@ export struct WdWebLocalComponent { | ||
| 372 | type: SliderBlockType.IMAGE, | 372 | type: SliderBlockType.IMAGE, |
| 373 | image: $r('app.media.slider_block') | 373 | image: $r('app.media.slider_block') |
| 374 | }) | 374 | }) |
| 375 | - .blockSize({ width: 18, height: 12 }) | 375 | + .blockSize({ width: 14, height: 10 }) |
| 376 | .onChange((value: number, mode: SliderChangeMode) => { | 376 | .onChange((value: number, mode: SliderChangeMode) => { |
| 377 | this.controller.setCurrentTime(value); | 377 | this.controller.setCurrentTime(value); |
| 378 | if (mode == SliderChangeMode.End) { | 378 | if (mode == SliderChangeMode.End) { |
| @@ -37,6 +37,7 @@ export struct CardParser { | @@ -37,6 +37,7 @@ export struct CardParser { | ||
| 37 | pageShowTime: number = 0; | 37 | pageShowTime: number = 0; |
| 38 | pageHideTime: number = 0; | 38 | pageHideTime: number = 0; |
| 39 | isPeopleShipHome: boolean = false; | 39 | isPeopleShipHome: boolean = false; |
| 40 | + isNeedDivider:boolean = true | ||
| 40 | 41 | ||
| 41 | aboutToAppear(): void { | 42 | aboutToAppear(): void { |
| 42 | console.log('CardParser-', JSON.stringify(this.contentDTO)) | 43 | console.log('CardParser-', JSON.stringify(this.contentDTO)) |
| @@ -66,11 +67,13 @@ export struct CardParser { | @@ -66,11 +67,13 @@ export struct CardParser { | ||
| 66 | 67 | ||
| 67 | @Builder | 68 | @Builder |
| 68 | getBehindDivider() { | 69 | getBehindDivider() { |
| 69 | - behindDivider({ | ||
| 70 | - compDTO: this.compDTO, | ||
| 71 | - nextCompDTO: this.nextCompDTO, | ||
| 72 | - compIndex: this.compIndex | ||
| 73 | - }) | 70 | + if(this.isNeedDivider){ |
| 71 | + behindDivider({ | ||
| 72 | + compDTO: this.compDTO, | ||
| 73 | + nextCompDTO: this.nextCompDTO, | ||
| 74 | + compIndex: this.compIndex | ||
| 75 | + }) | ||
| 76 | + } | ||
| 74 | } | 77 | } |
| 75 | 78 | ||
| 76 | @Builder | 79 | @Builder |
| @@ -229,7 +229,7 @@ export struct DynamicDetailComponent { | @@ -229,7 +229,7 @@ export struct DynamicDetailComponent { | ||
| 229 | .margin({ right: $r('app.float.margin_6') }) | 229 | .margin({ right: $r('app.float.margin_6') }) |
| 230 | 230 | ||
| 231 | Blank() | 231 | Blank() |
| 232 | - if (!StringUtils.isEmpty(this.followStatus)) { | 232 | + if ((this.contentDetailData.rmhPlatform == 1 && this.contentDetailData?.rmhInfo?.userType != "5") && !StringUtils.isEmpty(this.followStatus)) { |
| 233 | if (this.followStatus == '0') { | 233 | if (this.followStatus == '0') { |
| 234 | Row() { | 234 | Row() { |
| 235 | Blank().layoutWeight(1) | 235 | Blank().layoutWeight(1) |
| @@ -685,10 +685,24 @@ export struct DynamicDetailComponent { | @@ -685,10 +685,24 @@ export struct DynamicDetailComponent { | ||
| 685 | @Builder topNav() { | 685 | @Builder topNav() { |
| 686 | //logo、日期 | 686 | //logo、日期 |
| 687 | Row() { | 687 | Row() { |
| 688 | - Image($r('app.media.ic_article_rmh')) | ||
| 689 | - .width($r('app.float.margin_80')) | ||
| 690 | - .height($r('app.float.margin_28')) | ||
| 691 | - .margin({ left: $r('app.float.margin_16') }) | 688 | + if (this.contentDetailData.rmhPlatform == 1) { // 人民号 |
| 689 | + if (this.contentDetailData?.rmhInfo?.userType == "5") { // 内容源账号 | ||
| 690 | + Blank().height(1) | ||
| 691 | + } else { | ||
| 692 | + Image($r('app.media.ic_article_rmh')) | ||
| 693 | + .width($r('app.float.margin_80')) | ||
| 694 | + .height($r('app.float.margin_28')) | ||
| 695 | + .margin({ left: $r('app.float.margin_16') }) | ||
| 696 | + } | ||
| 697 | + } else if (this.contentDetailData.rmhPlatform == 2) { // 普通用户 | ||
| 698 | + Blank().height(1) | ||
| 699 | + } else { | ||
| 700 | + Image($r('app.media.logo_rmrb')) | ||
| 701 | + .width($r('app.float.margin_80')) | ||
| 702 | + .height($r('app.float.margin_28')) | ||
| 703 | + .margin({ left: $r('app.float.margin_16') }) | ||
| 704 | + } | ||
| 705 | + | ||
| 692 | Blank() | 706 | Blank() |
| 693 | Text(this.publishTime) | 707 | Text(this.publishTime) |
| 694 | .fontColor($r('app.color.color_B0B0B0')) | 708 | .fontColor($r('app.color.color_B0B0B0')) |
| @@ -189,7 +189,7 @@ export struct ImageAndTextPageComponent { | @@ -189,7 +189,7 @@ export struct ImageAndTextPageComponent { | ||
| 189 | Column(){ | 189 | Column(){ |
| 190 | Divider().strokeWidth(8).color('#f5f5f5') | 190 | Divider().strokeWidth(8).color('#f5f5f5') |
| 191 | RecommendList({ recommendList: this.recommendList }) | 191 | RecommendList({ recommendList: this.recommendList }) |
| 192 | - }.padding({bottom:this.contentDetailData?.openComment ? 0 : 44 }) | 192 | + }.padding({bottom:this.contentDetailData?.openComment ? 0 : 44 + 8 }) |
| 193 | } | 193 | } |
| 194 | // 评论 | 194 | // 评论 |
| 195 | if (this.contentDetailData?.openComment) { | 195 | if (this.contentDetailData?.openComment) { |
| @@ -123,7 +123,7 @@ export struct CardMediaInfo { | @@ -123,7 +123,7 @@ export struct CardMediaInfo { | ||
| 123 | .mediaText() | 123 | .mediaText() |
| 124 | } else if (this.contentDTO?.liveType === 'running') { | 124 | } else if (this.contentDTO?.liveType === 'running') { |
| 125 | LottieView({ | 125 | LottieView({ |
| 126 | - name: 'live_status_wait', | 126 | + name: 'live_status_wait-' + Math.random().toString().slice(2, 12), |
| 127 | path: "lottie/live_detail_living.json", | 127 | path: "lottie/live_detail_living.json", |
| 128 | lottieWidth: 14, | 128 | lottieWidth: 14, |
| 129 | lottieHeight: 14, | 129 | lottieHeight: 14, |
| @@ -162,7 +162,7 @@ export struct CardMediaInfo { | @@ -162,7 +162,7 @@ export struct CardMediaInfo { | ||
| 162 | } else if (this.contentDTO?.liveInfo?.liveState === 'running') { | 162 | } else if (this.contentDTO?.liveInfo?.liveState === 'running') { |
| 163 | Row(){ | 163 | Row(){ |
| 164 | LottieView({ | 164 | LottieView({ |
| 165 | - name: 'live_status_wait', | 165 | + name: 'live_status_wait-' + Math.random().toString().slice(2, 12), |
| 166 | path: "lottie/live_detail_living.json", | 166 | path: "lottie/live_detail_living.json", |
| 167 | lottieWidth: 14, | 167 | lottieWidth: 14, |
| 168 | lottieHeight: 14, | 168 | lottieHeight: 14, |
| @@ -211,7 +211,7 @@ export struct RmhTitle { | @@ -211,7 +211,7 @@ export struct RmhTitle { | ||
| 211 | .width('100%') | 211 | .width('100%') |
| 212 | 212 | ||
| 213 | Blank() | 213 | Blank() |
| 214 | - if (this.rmhInfo?.cnIsAttention) { | 214 | + if (this.rmhInfo?.cnIsAttention && this.rmhInfo?.userType != "5") { |
| 215 | Column() { | 215 | Column() { |
| 216 | Row(){ | 216 | Row(){ |
| 217 | if (Number(this.followStatus) === 0) { | 217 | if (Number(this.followStatus) === 0) { |
| @@ -142,6 +142,7 @@ export struct Card2Component { | @@ -142,6 +142,7 @@ export struct Card2Component { | ||
| 142 | this.clicked = true; | 142 | this.clicked = true; |
| 143 | } | 143 | } |
| 144 | persistentStorage(this.contentDTO.objectId); | 144 | persistentStorage(this.contentDTO.objectId); |
| 145 | + // console.log(TAG,'this.contentDTO.objectType', this.contentDTO.objectType) | ||
| 145 | this.jumpDetail() | 146 | this.jumpDetail() |
| 146 | }) | 147 | }) |
| 147 | } | 148 | } |
| @@ -153,11 +154,13 @@ export struct Card2Component { | @@ -153,11 +154,13 @@ export struct Card2Component { | ||
| 153 | MinePageDatasModel.getAssertDetailData(this.contentDTO.relId,this.contentDTO.objectId,this.contentDTO.relType).then((value) => { | 154 | MinePageDatasModel.getAssertDetailData(this.contentDTO.relId,this.contentDTO.objectId,this.contentDTO.relType).then((value) => { |
| 154 | if(value == "1"){ | 155 | if(value == "1"){ |
| 155 | ProcessUtils.processPage(this.contentDTO) | 156 | ProcessUtils.processPage(this.contentDTO) |
| 156 | - }else{ | 157 | + } else { |
| 157 | ToastUtils.shortToast("内容不存在") | 158 | ToastUtils.shortToast("内容不存在") |
| 158 | } | 159 | } |
| 159 | }).catch((err: Error) => { | 160 | }).catch((err: Error) => { |
| 160 | console.log(TAG, JSON.stringify(err)) | 161 | console.log(TAG, JSON.stringify(err)) |
| 162 | + // 网络出小差了进入详情页 | ||
| 163 | + ProcessUtils.processPage(this.contentDTO) | ||
| 161 | }) | 164 | }) |
| 162 | } | 165 | } |
| 163 | } | 166 | } |
| @@ -26,6 +26,10 @@ export struct LiveBigImage02Component { | @@ -26,6 +26,10 @@ export struct LiveBigImage02Component { | ||
| 26 | this.loadImg = await onlyWifiLoadImg(); | 26 | this.loadImg = await onlyWifiLoadImg(); |
| 27 | } | 27 | } |
| 28 | 28 | ||
| 29 | + async aboutToReuse() { | ||
| 30 | + this.loadImg = await onlyWifiLoadImg(); | ||
| 31 | + } | ||
| 32 | + | ||
| 29 | 33 | ||
| 30 | build() { | 34 | build() { |
| 31 | Column() { | 35 | Column() { |
| @@ -97,7 +101,7 @@ export struct LiveBigImage02Component { | @@ -97,7 +101,7 @@ export struct LiveBigImage02Component { | ||
| 97 | LiveImage(item: ContentDTO) { | 101 | LiveImage(item: ContentDTO) { |
| 98 | Row() { | 102 | Row() { |
| 99 | LottieView({ | 103 | LottieView({ |
| 100 | - name: 'live_status_wait', | 104 | + name: 'live_status_wait-' + Math.random().toString().slice(2, 12), |
| 101 | path: "lottie/live_detail_living.json", | 105 | path: "lottie/live_detail_living.json", |
| 102 | lottieWidth: 14, | 106 | lottieWidth: 14, |
| 103 | lottieHeight: 14, | 107 | lottieHeight: 14, |
| @@ -118,7 +118,6 @@ export struct MoreComponent { | @@ -118,7 +118,6 @@ export struct MoreComponent { | ||
| 118 | let contentDTO = MinePageDatasModel.dataTransform(rem,value, photos); | 118 | let contentDTO = MinePageDatasModel.dataTransform(rem,value, photos); |
| 119 | if(value.type != "13"){ | 119 | if(value.type != "13"){ |
| 120 | this.contentDTO.sameContentList.push(contentDTO) | 120 | this.contentDTO.sameContentList.push(contentDTO) |
| 121 | - console.log("ycg","123") | ||
| 122 | } | 121 | } |
| 123 | }) | 122 | }) |
| 124 | 123 |
| 1 | -import { inputMethodEngine } from '@kit.IMEKit' | 1 | +import { inputMethod, inputMethodEngine } from '@kit.IMEKit' |
| 2 | import { commentInfo } from 'wdBean/Index' | 2 | import { commentInfo } from 'wdBean/Index' |
| 3 | import { VoiceRecoginizer } from 'wdHwAbility' | 3 | import { VoiceRecoginizer } from 'wdHwAbility' |
| 4 | import { Logger, ToastUtils } from 'wdKit/Index' | 4 | import { Logger, ToastUtils } from 'wdKit/Index' |
| @@ -8,6 +8,7 @@ import { publishCommentModel } from '../model/PublishCommentModel' | @@ -8,6 +8,7 @@ import { publishCommentModel } from '../model/PublishCommentModel' | ||
| 8 | import commentViewModel from '../viewmodel/CommentViewModel' | 8 | import commentViewModel from '../viewmodel/CommentViewModel' |
| 9 | import { VoiceInputView } from './VoiceInputView' | 9 | import { VoiceInputView } from './VoiceInputView' |
| 10 | import { common, UIAbility } from '@kit.AbilityKit' | 10 | import { common, UIAbility } from '@kit.AbilityKit' |
| 11 | +import { BusinessError } from '@kit.BasicServicesKit' | ||
| 11 | 12 | ||
| 12 | const TAG = "CommentInputDialog" | 13 | const TAG = "CommentInputDialog" |
| 13 | 14 | ||
| @@ -154,7 +155,19 @@ export struct CommentCustomDialog { | @@ -154,7 +155,19 @@ export struct CommentCustomDialog { | ||
| 154 | this.voiceSwitch = !this.voiceSwitch | 155 | this.voiceSwitch = !this.voiceSwitch |
| 155 | this.emojiSwitch = false | 156 | this.emojiSwitch = false |
| 156 | if (this.voiceSwitch) { | 157 | if (this.voiceSwitch) { |
| 157 | - this.textInputController.stopEditing() | 158 | + // 按沟通结果,调整隐藏键盘方法 |
| 159 | + // http://192.168.1.3:8080/zentao/bug-view-20473.html | ||
| 160 | + // this.textInputController.stopEditing() | ||
| 161 | + inputMethod.getController().hideTextInput((err: BusinessError) => { | ||
| 162 | + if (err) { | ||
| 163 | + console.error(`Failed to hideTextInput: ${JSON.stringify(err)}`); | ||
| 164 | + return; | ||
| 165 | + } | ||
| 166 | + // console.log('Succeeded in hiding text input.'); | ||
| 167 | + }) | ||
| 168 | + // this.showKeyboardOnFocus = false | ||
| 169 | + // focusControl.requestFocus("textAreaId") // 弹起键盘 | ||
| 170 | + | ||
| 158 | } else { | 171 | } else { |
| 159 | focusControl.requestFocus("textAreaId") // 弹起键盘 | 172 | focusControl.requestFocus("textAreaId") // 弹起键盘 |
| 160 | // this.textInputController.caretPosition(this.textInputController.getTextContentRect().x) | 173 | // this.textInputController.caretPosition(this.textInputController.getTextContentRect().x) |
| @@ -170,7 +183,16 @@ export struct CommentCustomDialog { | @@ -170,7 +183,16 @@ export struct CommentCustomDialog { | ||
| 170 | this.emojiSwitch = !this.emojiSwitch | 183 | this.emojiSwitch = !this.emojiSwitch |
| 171 | this.voiceSwitch = false | 184 | this.voiceSwitch = false |
| 172 | if (this.emojiSwitch) { | 185 | if (this.emojiSwitch) { |
| 173 | - this.textInputController.stopEditing() | 186 | + // 按沟通结果,调整隐藏键盘方法 |
| 187 | + // http://192.168.1.3:8080/zentao/bug-view-20473.html | ||
| 188 | + // this.textInputController.stopEditing() | ||
| 189 | + inputMethod.getController().hideTextInput((err: BusinessError) => { | ||
| 190 | + if (err) { | ||
| 191 | + console.error(`Failed to hideTextInput: ${JSON.stringify(err)}`); | ||
| 192 | + return; | ||
| 193 | + } | ||
| 194 | + // console.log('Succeeded in hiding text input.'); | ||
| 195 | + }) | ||
| 174 | } else { | 196 | } else { |
| 175 | focusControl.requestFocus("textAreaId") // 弹起键盘 | 197 | focusControl.requestFocus("textAreaId") // 弹起键盘 |
| 176 | // this.textInputController.caretPosition(this.textInputController.getTextContentRect().x) | 198 | // this.textInputController.caretPosition(this.textInputController.getTextContentRect().x) |
| @@ -49,10 +49,10 @@ export struct PageComponent { | @@ -49,10 +49,10 @@ export struct PageComponent { | ||
| 49 | this.LoadingLayout() | 49 | this.LoadingLayout() |
| 50 | } else if (this.pageModel.viewType == ViewType.LOADED) { | 50 | } else if (this.pageModel.viewType == ViewType.LOADED) { |
| 51 | this.ListLayout() | 51 | this.ListLayout() |
| 52 | - } else if (this.pageModel.viewType == ViewType.EMPTY) { | 52 | + } else if (this.pageModel.viewType == ViewType.EMPTY || this.pageModel.viewType == ViewType.NoNetwork) { |
| 53 | //缺省页 | 53 | //缺省页 |
| 54 | EmptyComponent({ | 54 | EmptyComponent({ |
| 55 | - emptyType: this.pageModel.emptyType, | 55 | + emptyType: this.pageModel.viewType == ViewType.EMPTY ? this.pageModel.emptyType : this.pageModel.NoNetwork, |
| 56 | emptyButton: true, | 56 | emptyButton: true, |
| 57 | retry: () => { | 57 | retry: () => { |
| 58 | this.pageModel.viewType = ViewType.LOADING; | 58 | this.pageModel.viewType = ViewType.LOADING; |
| @@ -297,7 +297,7 @@ export struct PageComponent { | @@ -297,7 +297,7 @@ export struct PageComponent { | ||
| 297 | this.needload = false; | 297 | this.needload = false; |
| 298 | } | 298 | } |
| 299 | } else { | 299 | } else { |
| 300 | - this.pageModel.viewType = ViewType.EMPTY; | 300 | + this.pageModel.viewType = ViewType.NoNetwork; |
| 301 | } | 301 | } |
| 302 | } | 302 | } |
| 303 | 303 |
| 1 | import { PeopleShipRecommendHeadComponent } from './PeopleShipRecommendHeadComponent' | 1 | import { PeopleShipRecommendHeadComponent } from './PeopleShipRecommendHeadComponent' |
| 2 | import { RmhRecommendDTO } from 'wdBean'; | 2 | import { RmhRecommendDTO } from 'wdBean'; |
| 3 | import { ProcessUtils } from 'wdRouter'; | 3 | import { ProcessUtils } from 'wdRouter'; |
| 4 | +import { LottieView } from '../lottie/LottieView'; | ||
| 5 | +import { HttpUtils } from 'wdNetwork'; | ||
| 6 | +import { FastClickUtil } from 'wdKit'; | ||
| 4 | 7 | ||
| 5 | @Component | 8 | @Component |
| 6 | export struct PeopleShipRecommendComponent { | 9 | export struct PeopleShipRecommendComponent { |
| @@ -10,7 +13,16 @@ export struct PeopleShipRecommendComponent { | @@ -10,7 +13,16 @@ export struct PeopleShipRecommendComponent { | ||
| 10 | @Link oneKeyFollow: boolean | 13 | @Link oneKeyFollow: boolean |
| 11 | // 换一换 | 14 | // 换一换 |
| 12 | @Link changeButton: boolean | 15 | @Link changeButton: boolean |
| 16 | + @State showFollowAnimate:boolean = false | ||
| 17 | + private followAnimationTimer: number = 0 | ||
| 18 | + @State followAnimationLoop: boolean = true | ||
| 13 | 19 | ||
| 20 | + aboutToDisappear(): void { | ||
| 21 | + if (this.followAnimationTimer > 0) { | ||
| 22 | + clearTimeout(this.followAnimationTimer) | ||
| 23 | + this.followAnimationTimer = 0 | ||
| 24 | + } | ||
| 25 | + } | ||
| 14 | 26 | ||
| 15 | build() { | 27 | build() { |
| 16 | Column({ space: 0 }) { | 28 | Column({ space: 0 }) { |
| @@ -85,26 +97,47 @@ export struct PeopleShipRecommendComponent { | @@ -85,26 +97,47 @@ export struct PeopleShipRecommendComponent { | ||
| 85 | left: '20pv' | 97 | left: '20pv' |
| 86 | }) | 98 | }) |
| 87 | 99 | ||
| 88 | - // 为你推荐 | ||
| 89 | - Button(this.rmhSelectedList.length == 0 ? '一键关注' : `一键关注 (${this.rmhSelectedList.length})`, { type: ButtonType.Normal, stateEffect: this.rmhSelectedList.length != 0 }) | ||
| 90 | - .margin({ | ||
| 91 | - top: '10vp', | ||
| 92 | - bottom: '10vp' | ||
| 93 | - }) | ||
| 94 | - .width('120vp') | ||
| 95 | - .height('36vp') | ||
| 96 | - .backgroundColor(this.rmhSelectedList.length != 0 ? $r('app.color.color_ED2800') : $r('app.color.color_B0B0B0')) | ||
| 97 | - .borderRadius('3vp') | ||
| 98 | - .fontColor($r('app.color.color_999999')) | ||
| 99 | - .fontWeight(500) | ||
| 100 | - .fontSize($r('app.float.vp_13')) | ||
| 101 | - .fontColor(Color.White) | ||
| 102 | - .onClick(() => { | ||
| 103 | - // 点击一键关注 | ||
| 104 | - if (!this.oneKeyFollow && this.rmhSelectedList.length > 0 ){ | ||
| 105 | - this.oneKeyFollow = true | ||
| 106 | - } | ||
| 107 | - }) | 100 | + // 一键关注按钮 |
| 101 | + Stack({alignContent: Alignment.Center}) { | ||
| 102 | + Button(this.showFollowAnimate ? "" : (this.rmhSelectedList.length == 0 ? '一键关注' : `一键关注 (${this.rmhSelectedList.length})`) | ||
| 103 | + ,{ type: ButtonType.Normal, stateEffect: this.rmhSelectedList.length != 0 }) | ||
| 104 | + .backgroundColor(this.rmhSelectedList.length != 0 ? $r('app.color.color_ED2800') : $r('app.color.color_B0B0B0')) | ||
| 105 | + .width("100%").height("100%") | ||
| 106 | + .borderRadius('3vp') | ||
| 107 | + .fontColor($r('app.color.color_999999')) | ||
| 108 | + .fontWeight(500) | ||
| 109 | + .fontSize($r('app.float.vp_13')) | ||
| 110 | + .fontColor(Color.White) | ||
| 111 | + .onClick(() => { | ||
| 112 | + // 点击一键关注 | ||
| 113 | + if (!this.oneKeyFollow && this.rmhSelectedList.length > 0 ){ | ||
| 114 | + if (HttpUtils.isLogin()) { | ||
| 115 | + this.showFollowAnimate = true | ||
| 116 | + this.followAnimationTimer = setTimeout(() => { | ||
| 117 | + this.showFollowAnimate = false | ||
| 118 | + }, 11 * 1000) | ||
| 119 | + } | ||
| 120 | + this.oneKeyFollow = true | ||
| 121 | + } | ||
| 122 | + }) | ||
| 123 | + if (this.showFollowAnimate) { | ||
| 124 | + LottieView({ | ||
| 125 | + name: 'one_key_follow_all', | ||
| 126 | + path: "lottie/button_action_running_white.json", | ||
| 127 | + lottieWidth: 12, | ||
| 128 | + lottieHeight: 12, | ||
| 129 | + autoplay: true, | ||
| 130 | + loop: this.followAnimationLoop, | ||
| 131 | + // onComplete:() => { | ||
| 132 | + // this.playAnimationOne = false | ||
| 133 | + // } | ||
| 134 | + }) | ||
| 135 | + } | ||
| 136 | + }.margin({ | ||
| 137 | + top: '10vp', | ||
| 138 | + bottom: '10vp' | ||
| 139 | + }) | ||
| 140 | + .width('120vp').height('36vp') | ||
| 108 | } | 141 | } |
| 109 | .width('100%') | 142 | .width('100%') |
| 110 | .justifyContent(FlexAlign.Start) | 143 | .justifyContent(FlexAlign.Start) |
| @@ -147,7 +147,8 @@ export struct EmptyComponent { | @@ -147,7 +147,8 @@ export struct EmptyComponent { | ||
| 147 | .fontWeight(FontWeight.Normal) | 147 | .fontWeight(FontWeight.Normal) |
| 148 | .opacity(this.TEXT_OPACITY) | 148 | .opacity(this.TEXT_OPACITY) |
| 149 | .margin({ top: this.EMPTY_TIP_TEXT_MARGIN_TOP }) | 149 | .margin({ top: this.EMPTY_TIP_TEXT_MARGIN_TOP }) |
| 150 | - .fontColor(this.emptyType === WDViewDefaultType.WDViewDefaultType_NoComment1 ? '#999999' : '#666666') | 150 | + // .fontColor(this.emptyType === WDViewDefaultType.WDViewDefaultType_NoComment1 ? '#999999' : '#666666') |
| 151 | + .fontColor('#666666') | ||
| 151 | .onClick((event: ClickEvent) => { | 152 | .onClick((event: ClickEvent) => { |
| 152 | Logger.info(TAG, `noProgrammeData onClick event?.source: ${event.source}`); | 153 | Logger.info(TAG, `noProgrammeData onClick event?.source: ${event.source}`); |
| 153 | }) | 154 | }) |
| @@ -29,7 +29,7 @@ export struct RecommendList { | @@ -29,7 +29,7 @@ export struct RecommendList { | ||
| 29 | } | 29 | } |
| 30 | ForEach(this.recommendList, (item: ContentDTO, index: number) => { | 30 | ForEach(this.recommendList, (item: ContentDTO, index: number) => { |
| 31 | Row() { | 31 | Row() { |
| 32 | - CardParser({ compDTO:new CompDTO,contentDTO: item }); | 32 | + CardParser({ compDTO:new CompDTO,contentDTO: item ,isNeedDivider:false}); |
| 33 | }.padding({ left: 6, right: 6 }) | 33 | }.padding({ left: 6, right: 6 }) |
| 34 | if (this.recommendList.length !== index + 1) { | 34 | if (this.recommendList.length !== index + 1) { |
| 35 | Divider().strokeWidth(1).color('#f5f5f5').padding({ left: 16, right: 16 }) | 35 | Divider().strokeWidth(1).color('#f5f5f5').padding({ left: 16, right: 16 }) |
| @@ -55,6 +55,7 @@ export default class PageModel { | @@ -55,6 +55,7 @@ export default class PageModel { | ||
| 55 | offsetY: number = 0; | 55 | offsetY: number = 0; |
| 56 | viewType: number = ViewType.LOADING; | 56 | viewType: number = ViewType.LOADING; |
| 57 | emptyType: WDViewDefaultType = WDViewDefaultType.WDViewDefaultType_Default | 57 | emptyType: WDViewDefaultType = WDViewDefaultType.WDViewDefaultType_Default |
| 58 | + NoNetwork: WDViewDefaultType = WDViewDefaultType.WDViewDefaultType_NoNetwork | ||
| 58 | hasMore: boolean = true; | 59 | hasMore: boolean = true; |
| 59 | startIndex = 0; | 60 | startIndex = 0; |
| 60 | endIndex = 0; | 61 | endIndex = 0; |
| @@ -64,6 +64,8 @@ export struct DetailPlayLiveCommon { | @@ -64,6 +64,8 @@ export struct DetailPlayLiveCommon { | ||
| 64 | 64 | ||
| 65 | private AudioSuspension = new AudioSuspensionModel() | 65 | private AudioSuspension = new AudioSuspensionModel() |
| 66 | @State isShowAudioCom: boolean = false | 66 | @State isShowAudioCom: boolean = false |
| 67 | + ///是否已经执行过pageShow | ||
| 68 | + hasPageShow: boolean = false | ||
| 67 | 69 | ||
| 68 | build() { | 70 | build() { |
| 69 | Column() { | 71 | Column() { |
| @@ -89,6 +91,10 @@ export struct DetailPlayLiveCommon { | @@ -89,6 +91,10 @@ export struct DetailPlayLiveCommon { | ||
| 89 | */ | 91 | */ |
| 90 | getContentDetail(): Promise<void> { | 92 | getContentDetail(): Promise<void> { |
| 91 | return new Promise<void>((resolve, reject) => { | 93 | return new Promise<void>((resolve, reject) => { |
| 94 | + if (this.hasPageShow) { | ||
| 95 | + return | ||
| 96 | + } | ||
| 97 | + this.hasPageShow = true | ||
| 92 | this.liveViewModel.getContentDetail(this.contentId, this.relId, this.relType) | 98 | this.liveViewModel.getContentDetail(this.contentId, this.relId, this.relType) |
| 93 | .then(async (data: Array<ContentDetailDTO>) => { | 99 | .then(async (data: Array<ContentDetailDTO>) => { |
| 94 | // console.log(TAG, '查询视频详情用于评论展示 getContentDetail:', JSON.stringify(data)); | 100 | // console.log(TAG, '查询视频详情用于评论展示 getContentDetail:', JSON.stringify(data)); |
| @@ -132,7 +132,7 @@ export struct PlayUIComponent { | @@ -132,7 +132,7 @@ export struct PlayUIComponent { | ||
| 132 | //标题 | 132 | //标题 |
| 133 | Marquee({ | 133 | Marquee({ |
| 134 | start:true, | 134 | start:true, |
| 135 | - loop: 1, | 135 | + loop: -1, |
| 136 | src:this.contentDetailData.newsTitle | 136 | src:this.contentDetailData.newsTitle |
| 137 | }) | 137 | }) |
| 138 | .fontSize(this.displayDirection == DisplayDirection.VIDEO_HORIZONTAL ? '18vp' : '16vp') | 138 | .fontSize(this.displayDirection == DisplayDirection.VIDEO_HORIZONTAL ? '18vp' : '16vp') |
| @@ -363,7 +363,7 @@ export struct PlayUIComponent { | @@ -363,7 +363,7 @@ export struct PlayUIComponent { | ||
| 363 | 363 | ||
| 364 | } | 364 | } |
| 365 | .alignItems(VerticalAlign.Center) | 365 | .alignItems(VerticalAlign.Center) |
| 366 | - .linearGradient({ angle: 0, colors: [['#99000000', 0], ['#00000000', 1]] }) | 366 | + .linearGradient({ angle: 0, colors: [['#80000000', 0],['#50000000', 0.5] ,['#00000000', 1]] }) |
| 367 | .width('100%') | 367 | .width('100%') |
| 368 | .padding({ | 368 | .padding({ |
| 369 | left: this.displayDirection == DisplayDirection.VIDEO_HORIZONTAL ? '40vp' : '16vp', | 369 | left: this.displayDirection == DisplayDirection.VIDEO_HORIZONTAL ? '40vp' : '16vp', |
| 1 | -import { ContentDetailDTO, LiveDetailsBean, LiveRoomDataBean, postBatchAttentionStatusParams, } from 'wdBean/Index' | 1 | +import { ContentDetailDTO, LiveDetailsBean, LiveRoomDataBean, |
| 2 | + Params, | ||
| 3 | + postBatchAttentionStatusParams, } from 'wdBean/Index' | ||
| 2 | import { MultiPictureDetailViewModel } from 'wdComponent/src/main/ets/viewmodel/MultiPictureDetailViewModel' | 4 | import { MultiPictureDetailViewModel } from 'wdComponent/src/main/ets/viewmodel/MultiPictureDetailViewModel' |
| 3 | import { SpConstants } from 'wdConstant/Index' | 5 | import { SpConstants } from 'wdConstant/Index' |
| 4 | import { ContentDetailRequest, postInteractAccentionOperateParams } from 'wdDetailPlayApi/Index' | 6 | import { ContentDetailRequest, postInteractAccentionOperateParams } from 'wdDetailPlayApi/Index' |
| @@ -173,6 +175,16 @@ export struct PlayerEndView { | @@ -173,6 +175,16 @@ export struct PlayerEndView { | ||
| 173 | // .borderStyle(BorderStyle.Solid) | 175 | // .borderStyle(BorderStyle.Solid) |
| 174 | .position({ x: '50%', y: 0 }) | 176 | .position({ x: '50%', y: 0 }) |
| 175 | .markAnchor({ x: '50%', y: '50%' }) | 177 | .markAnchor({ x: '50%', y: '50%' }) |
| 178 | + .onClick(()=>{ | ||
| 179 | + // 跳转到号主页 | ||
| 180 | + if (this.contentDetailData.rmhInfo?.cnMainControl === 1) { | ||
| 181 | + const params: Params = { | ||
| 182 | + creatorId: this.contentDetailData.rmhInfo.rmhId, | ||
| 183 | + pageID: '' | ||
| 184 | + } | ||
| 185 | + WDRouterRule.jumpWithPage(WDRouterPage.peopleShipHomePage, params) | ||
| 186 | + } | ||
| 187 | + }) | ||
| 176 | } | 188 | } |
| 177 | } | 189 | } |
| 178 | .width(307) | 190 | .width(307) |
| @@ -13,9 +13,26 @@ import { DisplayDirection } from 'wdConstant'; | @@ -13,9 +13,26 @@ import { DisplayDirection } from 'wdConstant'; | ||
| 13 | export struct PlayerUIComponent { | 13 | export struct PlayerUIComponent { |
| 14 | private playerController?: WDAliPlayerController | 14 | private playerController?: WDAliPlayerController |
| 15 | @Provide isSmall:boolean = false | 15 | @Provide isSmall:boolean = false |
| 16 | - @Consume isShowControl: boolean | 16 | + @Consume @Watch('onChangeMenuVisible') isShowControl: boolean |
| 17 | @Consume isFullScreen: boolean | 17 | @Consume isFullScreen: boolean |
| 18 | @Consume displayDirection: DisplayDirection | 18 | @Consume displayDirection: DisplayDirection |
| 19 | + @State isPlayStatus: boolean = true; | ||
| 20 | + onChangeMenuVisible() { | ||
| 21 | + if (this.displayDirection == DisplayDirection.VERTICAL | ||
| 22 | + || !this.isShowControl | ||
| 23 | + || !this.isPlayStatus) { | ||
| 24 | + return | ||
| 25 | + } | ||
| 26 | + let time: number = 0 | ||
| 27 | + if (this.isShowControl) { | ||
| 28 | + setTimeout(() => { | ||
| 29 | + this.isShowControl = false | ||
| 30 | + }, 5 * 1000) | ||
| 31 | + } else { | ||
| 32 | + clearTimeout(time) | ||
| 33 | + } | ||
| 34 | + } | ||
| 35 | + | ||
| 19 | aboutToAppear() { | 36 | aboutToAppear() { |
| 20 | if (!this.playerController) { | 37 | if (!this.playerController) { |
| 21 | return | 38 | return |
| @@ -76,7 +93,7 @@ export struct PlayerUIComponent { | @@ -76,7 +93,7 @@ export struct PlayerUIComponent { | ||
| 76 | .position({ y: '100%' }) | 93 | .position({ y: '100%' }) |
| 77 | .markAnchor({ y: '100%' }) | 94 | .markAnchor({ y: '100%' }) |
| 78 | 95 | ||
| 79 | - PlayerVideoControlComponent({ playerController: this.playerController }) | 96 | + PlayerVideoControlComponent({ playerController: this.playerController,isPlayStatus: $isPlayStatus}) |
| 80 | .visibility(this.isShowControl ? Visibility.Visible : Visibility.Hidden) | 97 | .visibility(this.isShowControl ? Visibility.Visible : Visibility.Hidden) |
| 81 | .animation({ duration: 500 }) | 98 | .animation({ duration: 500 }) |
| 82 | .position({ y: '100%' }) | 99 | .position({ y: '100%' }) |
| @@ -13,7 +13,7 @@ export struct PlayerVideoControlComponent { | @@ -13,7 +13,7 @@ export struct PlayerVideoControlComponent { | ||
| 13 | @State totalTime: string = '' | 13 | @State totalTime: string = '' |
| 14 | @State progressVal: number = 0; | 14 | @State progressVal: number = 0; |
| 15 | //是否处于播放状态中 | 15 | //是否处于播放状态中 |
| 16 | - @State isPlayStatus: boolean = true | 16 | + @Link isPlayStatus?: boolean |
| 17 | @Consume displayDirection: DisplayDirection | 17 | @Consume displayDirection: DisplayDirection |
| 18 | @Consume contentDetailData: ContentDetailDTO | 18 | @Consume contentDetailData: ContentDetailDTO |
| 19 | @Consume isSmall:boolean | 19 | @Consume isSmall:boolean |
| @@ -245,6 +245,13 @@ export struct DetailPlayShortVideoPage { | @@ -245,6 +245,13 @@ export struct DetailPlayShortVideoPage { | ||
| 245 | // 注册监听网络连接 | 245 | // 注册监听网络连接 |
| 246 | if (this.currentIndex === this.index && type != NetworkType.TYPE_UNKNOWN) { | 246 | if (this.currentIndex === this.index && type != NetworkType.TYPE_UNKNOWN) { |
| 247 | console.log(TAG, '网络连接状态变化', type, 'this.currentIndex', this.currentIndex, 'this.index', this.index) | 247 | console.log(TAG, '网络连接状态变化', type, 'this.currentIndex', this.currentIndex, 'this.index', this.index) |
| 248 | + if(type == NetworkType.TYPE_CELLULAR) { | ||
| 249 | + this.toastTextVisible = true | ||
| 250 | + this.onlyWifiLoadVideo = false | ||
| 251 | + } else if(type == NetworkType.TYPE_WIFI) { | ||
| 252 | + this.toastTextVisible = false | ||
| 253 | + this.onlyWifiLoadVideo = true | ||
| 254 | + } | ||
| 248 | this.currentIndexChange() | 255 | this.currentIndexChange() |
| 249 | } | 256 | } |
| 250 | }, 1000) | 257 | }, 1000) |
| @@ -426,10 +433,7 @@ export struct DetailPlayShortVideoPage { | @@ -426,10 +433,7 @@ export struct DetailPlayShortVideoPage { | ||
| 426 | .onClick(() => { | 433 | .onClick(() => { |
| 427 | this.onlyWifiLoadVideo = true | 434 | this.onlyWifiLoadVideo = true |
| 428 | this.toastTextVisible = false | 435 | this.toastTextVisible = false |
| 429 | - this.playerController?.play() | ||
| 430 | - this.playerController.startRenderFrame(() => { | ||
| 431 | - this.imageVisible = false | ||
| 432 | - }) | 436 | + this.currentIndexChange() |
| 433 | }) | 437 | }) |
| 434 | } | 438 | } |
| 435 | .width('100%') | 439 | .width('100%') |
| @@ -289,12 +289,13 @@ export struct VideoChannelDetail { | @@ -289,12 +289,13 @@ export struct VideoChannelDetail { | ||
| 289 | Stack({ alignContent: Alignment.Center }) { | 289 | Stack({ alignContent: Alignment.Center }) { |
| 290 | if (this.netStatus !== undefined) { | 290 | if (this.netStatus !== undefined) { |
| 291 | EmptyComponent({ | 291 | EmptyComponent({ |
| 292 | - emptyType: 1, emptyButton: true, isBlack: true, retry: () => { | 292 | + emptyType: 1, emptyButton: true, isBlack: true, showBackButton: false, retry: () => { |
| 293 | this.getDetail() | 293 | this.getDetail() |
| 294 | } | 294 | } |
| 295 | }) | 295 | }) |
| 296 | } else if (this.isOffLine) { | 296 | } else if (this.isOffLine) { |
| 297 | EmptyComponent({ | 297 | EmptyComponent({ |
| 298 | + showBackButton: false, | ||
| 298 | emptyType: WDViewDefaultType.WDViewDefaultType_NoVideo, | 299 | emptyType: WDViewDefaultType.WDViewDefaultType_NoVideo, |
| 299 | retry: () => { | 300 | retry: () => { |
| 300 | this.getDetail() | 301 | this.getDetail() |
| @@ -7,6 +7,7 @@ import { BusinessError } from '@ohos.base'; | @@ -7,6 +7,7 @@ import { BusinessError } from '@ohos.base'; | ||
| 7 | import { DeviceUtil, EmitterEventId, EmitterUtils, Logger, SPHelper, WindowModel } from 'wdKit'; | 7 | import { DeviceUtil, EmitterEventId, EmitterUtils, Logger, SPHelper, WindowModel } from 'wdKit'; |
| 8 | import { ConfigurationConstant } from '@kit.AbilityKit'; | 8 | import { ConfigurationConstant } from '@kit.AbilityKit'; |
| 9 | import { StartupManager } from '../startupmanager/StartupManager'; | 9 | import { StartupManager } from '../startupmanager/StartupManager'; |
| 10 | +import { AppLinkingManager } from 'wdRouter'; | ||
| 10 | 11 | ||
| 11 | let floatWindowClass: window.Window | null = null; | 12 | let floatWindowClass: window.Window | null = null; |
| 12 | const TAG = 'EntryAbility' | 13 | const TAG = 'EntryAbility' |
| @@ -19,7 +20,8 @@ export default class EntryAbility extends UIAbility { | @@ -19,7 +20,8 @@ export default class EntryAbility extends UIAbility { | ||
| 19 | StartupManager.sharedInstance().appAgreedProtocol() | 20 | StartupManager.sharedInstance().appAgreedProtocol() |
| 20 | } | 21 | } |
| 21 | Logger.info(TAG, 'Ability onCreate'); | 22 | Logger.info(TAG, 'Ability onCreate'); |
| 22 | - | 23 | + //只判断不跳转 |
| 24 | + AppLinkingManager.sharedInstance().comsumeLastUriContent(false) | ||
| 23 | // 还没深色模式需求,暂直接不跟随系统。 | 25 | // 还没深色模式需求,暂直接不跟随系统。 |
| 24 | this.context.getApplicationContext().setColorMode(ConfigurationConstant.ColorMode.COLOR_MODE_LIGHT); | 26 | this.context.getApplicationContext().setColorMode(ConfigurationConstant.ColorMode.COLOR_MODE_LIGHT); |
| 25 | 27 |
| 1 | +{"v":"5.6.10","fr":60,"ip":0,"op":60,"w":128,"h":129,"nm":"上拉loding-旋转黑色","ddd":0,"assets":[{"id":"image_0","w":384,"h":384,"u":"","p":"","e":1},{"id":"comp_0","layers":[{"ddd":0,"ind":1,"ty":2,"nm":"loding2.png","cl":"png","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"t":60,"s":[360]}],"ix":10},"p":{"a":0,"k":[192,192,0],"ix":2},"a":{"a":0,"k":[192,192,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":60,"st":0,"bm":0}]}],"layers":[{"ddd":0,"ind":1,"ty":0,"nm":"loding2.png 合成 1","cl":"png","refId":"comp_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"t":60,"s":[360]}],"ix":10},"p":{"a":0,"k":[64,64.5,0],"ix":2},"a":{"a":0,"k":[192,192,0],"ix":1},"s":{"a":0,"k":[33.3,33.3,100],"ix":6}},"ao":0,"w":384,"h":384,"ip":0,"op":60,"st":0,"bm":0}],"markers":[]} |
| @@ -59,7 +59,14 @@ struct LaunchPage { | @@ -59,7 +59,14 @@ struct LaunchPage { | ||
| 59 | this.timerId = setTimeout(() => { | 59 | this.timerId = setTimeout(() => { |
| 60 | this.isJumpToAdvertising = true; | 60 | this.isJumpToAdvertising = true; |
| 61 | 61 | ||
| 62 | - WDRouterRule.jumpWithPage(WDRouterPage.launchAdvertisingPage) | 62 | + let hasLink = SPHelper.default.getSync(SpConstants.HAS_LINK,false) |
| 63 | + if(hasLink){ | ||
| 64 | + SPHelper.default.deleteSync(SpConstants.HAS_LINK) | ||
| 65 | + WDRouterRule.jumpWithPage(WDRouterPage.mainPage) | ||
| 66 | + }else{ | ||
| 67 | + WDRouterRule.jumpWithPage(WDRouterPage.launchAdvertisingPage) | ||
| 68 | + } | ||
| 69 | + | ||
| 63 | 70 | ||
| 64 | // router.pushUrl({ | 71 | // router.pushUrl({ |
| 65 | // url: 'pages/LaunchAdvertisingPage' | 72 | // url: 'pages/LaunchAdvertisingPage' |
| @@ -204,13 +204,18 @@ export struct BottomNavigationComponent { | @@ -204,13 +204,18 @@ export struct BottomNavigationComponent { | ||
| 204 | // 占位图使用本地资源 | 204 | // 占位图使用本地资源 |
| 205 | placeholderSrc: defaultIcon, | 205 | placeholderSrc: defaultIcon, |
| 206 | // 失败占位图使用本地资源 | 206 | // 失败占位图使用本地资源 |
| 207 | - // errorholderSrc: defaultIcon, | 207 | + errorholderSrc: defaultIcon, |
| 208 | // 是否开启一级内存缓存 | 208 | // 是否开启一级内存缓存 |
| 209 | isCacheable: true, | 209 | isCacheable: true, |
| 210 | // 磁盘缓存 | 210 | // 磁盘缓存 |
| 211 | strategy: new ALL(), | 211 | strategy: new ALL(), |
| 212 | gif: { | 212 | gif: { |
| 213 | playTimes: 1 | 213 | playTimes: 1 |
| 214 | + }, | ||
| 215 | + onLoadListener:{ | ||
| 216 | + onLoadFailed:(err)=>{ | ||
| 217 | + console.error("Load Failed Reason: " + err + " cost " + (new Date().getTime() ) + " milliseconds"); | ||
| 218 | + } | ||
| 214 | } | 219 | } |
| 215 | }; | 220 | }; |
| 216 | return imageKnifeOption | 221 | return imageKnifeOption |
| @@ -108,6 +108,7 @@ export class StartupManager { | @@ -108,6 +108,7 @@ export class StartupManager { | ||
| 108 | appOnDestory() { | 108 | appOnDestory() { |
| 109 | Logger.debug(TAG, "App onDestory") | 109 | Logger.debug(TAG, "App onDestory") |
| 110 | NetworkManager.getInstance().release() | 110 | NetworkManager.getInstance().release() |
| 111 | + SPHelper.default.deleteSync(SpConstants.HAS_LINK) | ||
| 111 | } | 112 | } |
| 112 | 113 | ||
| 113 | // 同意隐私协议之后,立即执行必要初始化 | 114 | // 同意隐私协议之后,立即执行必要初始化 |
-
Please register or login to post a comment