Showing
20 changed files
with
554 additions
and
403 deletions
| @@ -82,7 +82,6 @@ export struct CompParser { | @@ -82,7 +82,6 @@ export struct CompParser { | ||
| 82 | 82 | ||
| 83 | if (this.compDTO.operDataList[0]?.objectType !== '3' && | 83 | if (this.compDTO.operDataList[0]?.objectType !== '3' && |
| 84 | this.compDTO.operDataList[0]?.objectType !== '13') { //暂时屏蔽活动和音频详情入口 | 84 | this.compDTO.operDataList[0]?.objectType !== '13') { //暂时屏蔽活动和音频详情入口 |
| 85 | - | ||
| 86 | if (this.compDTO.compStyle === CompStyle.Label_03) { | 85 | if (this.compDTO.compStyle === CompStyle.Label_03) { |
| 87 | LabelComponent({ compDTO: this.compDTO }) | 86 | LabelComponent({ compDTO: this.compDTO }) |
| 88 | Divider().strokeWidth(5).color('#f5f5f5').padding({ left: 0, right: 0 }) | 87 | Divider().strokeWidth(5).color('#f5f5f5').padding({ left: 0, right: 0 }) |
| @@ -108,7 +107,7 @@ export struct CompParser { | @@ -108,7 +107,7 @@ export struct CompParser { | ||
| 108 | Divider().strokeWidth(1).color('#f5f5f5').padding({ left: 16, right: 16 }) | 107 | Divider().strokeWidth(1).color('#f5f5f5').padding({ left: 16, right: 16 }) |
| 109 | } else if (this.compDTO.compStyle === CompStyle.Zh_Single_Row_03) { | 108 | } else if (this.compDTO.compStyle === CompStyle.Zh_Single_Row_03) { |
| 110 | ZhSingleRow03({ compDTO: this.compDTO, pageId: this.pageId, pageName: this.pageName }) | 109 | ZhSingleRow03({ compDTO: this.compDTO, pageId: this.pageId, pageName: this.pageName }) |
| 111 | - Divider().strokeWidth(5).color('#f5f5f5').padding({ left: 0, right: 0 }) | 110 | + Divider().strokeWidth(1).color('#f5f5f5').padding({ left: 16, right: 16 }) |
| 112 | } else if (this.compDTO.compStyle === CompStyle.Zh_Grid_Layout_02) { //双列流小视频,一行两图卡 ->标题 | 111 | } else if (this.compDTO.compStyle === CompStyle.Zh_Grid_Layout_02) { //双列流小视频,一行两图卡 ->标题 |
| 113 | //ZhGridLayout02({ compDTO: this.compDTO }) | 112 | //ZhGridLayout02({ compDTO: this.compDTO }) |
| 114 | CompNormalTitle({ compDTO: this.compDTO }) | 113 | CompNormalTitle({ compDTO: this.compDTO }) |
| @@ -136,7 +135,7 @@ export struct CompParser { | @@ -136,7 +135,7 @@ export struct CompParser { | ||
| 136 | } else if (this.compDTO.compStyle === CompStyle.Zh_Single_Column_03) { | 135 | } else if (this.compDTO.compStyle === CompStyle.Zh_Single_Column_03) { |
| 137 | // 大图卡 | 136 | // 大图卡 |
| 138 | Card2Component({ compDTO: this.compDTO, contentDTO: this.compDTO.operDataList[0], pageId: this.pageId, pageName: this.pageName }) | 137 | Card2Component({ compDTO: this.compDTO, contentDTO: this.compDTO.operDataList[0], pageId: this.pageId, pageName: this.pageName }) |
| 139 | - Divider().strokeWidth(5).color('#f5f5f5').padding({ left: 0, right: 0 }) | 138 | + Divider().strokeWidth(1).color('#f5f5f5').padding({ left: 16, right: 16 }) |
| 140 | } else if (this.compDTO.compStyle === CompStyle.Card_09) { | 139 | } else if (this.compDTO.compStyle === CompStyle.Card_09) { |
| 141 | //时间链卡 | 140 | //时间链卡 |
| 142 | Card9Component({ compDTO: this.compDTO, contentDTO:this.compDTO.operDataList[0], pageId: this.pageId, pageName: this.pageName }) | 141 | Card9Component({ compDTO: this.compDTO, contentDTO:this.compDTO.operDataList[0], pageId: this.pageId, pageName: this.pageName }) |
| @@ -86,6 +86,7 @@ export struct TopNavigationComponentNew { | @@ -86,6 +86,7 @@ export struct TopNavigationComponentNew { | ||
| 86 | navIndex: index, | 86 | navIndex: index, |
| 87 | pageId: navItem?.pageId + '', | 87 | pageId: navItem?.pageId + '', |
| 88 | channelId: navItem?.channelId + '', | 88 | channelId: navItem?.channelId + '', |
| 89 | + autoRefresh: this.autoRefresh2Page | ||
| 89 | }) | 90 | }) |
| 90 | } else | 91 | } else |
| 91 | if (!this.isBroadcast(navItem) && !this.isLayout(navItem)) { | 92 | if (!this.isBroadcast(navItem) && !this.isLayout(navItem)) { |
| @@ -14,7 +14,6 @@ import { | @@ -14,7 +14,6 @@ import { | ||
| 14 | import { ViewType } from 'wdConstant/src/main/ets/enum/ViewType'; | 14 | import { ViewType } from 'wdConstant/src/main/ets/enum/ViewType'; |
| 15 | import { channelSkeleton } from '../skeleton/channelSkeleton' | 15 | import { channelSkeleton } from '../skeleton/channelSkeleton' |
| 16 | import { EmptyComponent } from '../view/EmptyComponent'; | 16 | import { EmptyComponent } from '../view/EmptyComponent'; |
| 17 | -import { ErrorComponent } from '../view/ErrorComponent'; | ||
| 18 | import { WDRouterPage, WDRouterRule } from 'wdRouter/Index' | 17 | import { WDRouterPage, WDRouterRule } from 'wdRouter/Index' |
| 19 | import MinePageDatasModel from '../../model/MinePageDatasModel'; | 18 | import MinePageDatasModel from '../../model/MinePageDatasModel'; |
| 20 | import { FollowListDetailRequestItem } from '../../viewmodel/FollowListDetailRequestItem'; | 19 | import { FollowListDetailRequestItem } from '../../viewmodel/FollowListDetailRequestItem'; |
| @@ -26,13 +25,14 @@ import PageHelper from '../../viewmodel/PageHelper'; | @@ -26,13 +25,14 @@ import PageHelper from '../../viewmodel/PageHelper'; | ||
| 26 | import { PeopleShipAttentionContentListTopComponent } from './PeopleShipAttentionContentListTopComponent' | 25 | import { PeopleShipAttentionContentListTopComponent } from './PeopleShipAttentionContentListTopComponent' |
| 27 | import { CardParser } from '../CardParser' | 26 | import { CardParser } from '../CardParser' |
| 28 | import { PeopleShipNoMoreData } from '../reusable/PeopleShipNoMoreData'; | 27 | import { PeopleShipNoMoreData } from '../reusable/PeopleShipNoMoreData'; |
| 29 | - | 28 | +const TAG = 'PeopleShipMainComponent'; |
| 30 | @Preview | 29 | @Preview |
| 31 | @Component | 30 | @Component |
| 32 | export struct PeopleShipMainComponent { | 31 | export struct PeopleShipMainComponent { |
| 33 | @State private pageModel: PageModel = new PageModel(); | 32 | @State private pageModel: PageModel = new PageModel(); |
| 34 | @State private pageAdvModel: PageAdModel = new PageAdModel(); | 33 | @State private pageAdvModel: PageAdModel = new PageAdModel(); |
| 35 | - | 34 | + // 自动刷新通知 |
| 35 | + @Prop @Watch('onAutoRefresh') autoRefresh: number = 0 | ||
| 36 | navIndex: number = 0; | 36 | navIndex: number = 0; |
| 37 | pageId: string = ""; | 37 | pageId: string = ""; |
| 38 | channelId: string = ""; | 38 | channelId: string = ""; |
| @@ -416,4 +416,13 @@ export struct PeopleShipMainComponent { | @@ -416,4 +416,13 @@ export struct PeopleShipMainComponent { | ||
| 416 | } | 416 | } |
| 417 | } | 417 | } |
| 418 | 418 | ||
| 419 | + onAutoRefresh(changedPropertyName: string) { | ||
| 420 | + if (this.navIndex != this.currentTopNavSelectedIndex) { | ||
| 421 | + return | ||
| 422 | + } | ||
| 423 | + // 当前页面,自动刷新数据 | ||
| 424 | + Logger.debug(TAG, 'page onAutoRefresh ' + this.autoRefresh) | ||
| 425 | + this.currentPage = 1 | ||
| 426 | + this.getData() | ||
| 427 | + } | ||
| 419 | } | 428 | } |
| @@ -40,8 +40,6 @@ export struct DetailPlayLivePage { | @@ -40,8 +40,6 @@ export struct DetailPlayLivePage { | ||
| 40 | @State lastInputedLiveComment: LiveRoomItemBean = {} as LiveRoomItemBean // 上次输入的直播间消息 | 40 | @State lastInputedLiveComment: LiveRoomItemBean = {} as LiveRoomItemBean // 上次输入的直播间消息 |
| 41 | @State lastInputedChatComment: LiveRoomItemBean = {} as LiveRoomItemBean // 上次输入的大家聊消息 | 41 | @State lastInputedChatComment: LiveRoomItemBean = {} as LiveRoomItemBean // 上次输入的大家聊消息 |
| 42 | 42 | ||
| 43 | - | ||
| 44 | - | ||
| 45 | aboutToAppear(): void { | 43 | aboutToAppear(): void { |
| 46 | Logger.info(TAG, `wyj-aboutToAppear`) | 44 | Logger.info(TAG, `wyj-aboutToAppear`) |
| 47 | 45 | ||
| @@ -69,9 +67,8 @@ export struct DetailPlayLivePage { | @@ -69,9 +67,8 @@ export struct DetailPlayLivePage { | ||
| 69 | build() { | 67 | build() { |
| 70 | Column() { | 68 | Column() { |
| 71 | 69 | ||
| 72 | - TopPlayComponent({ playerController: this.playerController }) | ||
| 73 | - .height(this.displayDirection == DisplayDirection.VERTICAL ? 211 : '100%') | ||
| 74 | - | 70 | + TopPlayComponent({ playerController: this.playerController }) |
| 71 | + .height(this.displayDirection == DisplayDirection.VERTICAL ? 211 : '100%') | ||
| 75 | 72 | ||
| 76 | TabComponent({ | 73 | TabComponent({ |
| 77 | tabs: this.tabs, | 74 | tabs: this.tabs, |
| 1 | -import { LiveRoomDataBean } from 'wdBean/Index'; | 1 | +import { ContentDetailDTO, LiveRoomDataBean } from 'wdBean/Index'; |
| 2 | import { LiveViewModel } from '../viewModel/LiveViewModel'; | 2 | import { LiveViewModel } from '../viewModel/LiveViewModel'; |
| 3 | import { WindowModel } from 'wdKit/Index'; | 3 | import { WindowModel } from 'wdKit/Index'; |
| 4 | import { PlayerComponent } from '../widgets/vertical/PlayerComponent'; | 4 | import { PlayerComponent } from '../widgets/vertical/PlayerComponent'; |
| @@ -22,6 +22,7 @@ export struct DetailPlayVLivePage { | @@ -22,6 +22,7 @@ export struct DetailPlayVLivePage { | ||
| 22 | private liveViewModel: LiveViewModel = new LiveViewModel() | 22 | private liveViewModel: LiveViewModel = new LiveViewModel() |
| 23 | private playerController: WDAliPlayerController = new WDAliPlayerController(); | 23 | private playerController: WDAliPlayerController = new WDAliPlayerController(); |
| 24 | private swiperController: SwiperController = new SwiperController() | 24 | private swiperController: SwiperController = new SwiperController() |
| 25 | + @Consume contentDetailData: ContentDetailDTO | ||
| 25 | @Provide bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 | 26 | @Provide bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 |
| 26 | @Provide topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 | 27 | @Provide topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 |
| 27 | @Provide liveRoomDataBean: LiveRoomDataBean = {} as LiveRoomDataBean | 28 | @Provide liveRoomDataBean: LiveRoomDataBean = {} as LiveRoomDataBean |
| @@ -36,6 +37,9 @@ export struct DetailPlayVLivePage { | @@ -36,6 +37,9 @@ export struct DetailPlayVLivePage { | ||
| 36 | @Consume contentId: string | 37 | @Consume contentId: string |
| 37 | @State swiperIndex: number = 1 | 38 | @State swiperIndex: number = 1 |
| 38 | @Consume liveDetailPageLogic: LiveDetailPageLogic | 39 | @Consume liveDetailPageLogic: LiveDetailPageLogic |
| 40 | + //播放错误 | ||
| 41 | + @State isPlayerError: boolean = false | ||
| 42 | + @State isCanplay: boolean = false | ||
| 39 | 43 | ||
| 40 | aboutToAppear(): void { | 44 | aboutToAppear(): void { |
| 41 | this.openFullScreen() | 45 | this.openFullScreen() |
| @@ -78,28 +82,27 @@ export struct DetailPlayVLivePage { | @@ -78,28 +82,27 @@ export struct DetailPlayVLivePage { | ||
| 78 | LiveEmptyComponent({ | 82 | LiveEmptyComponent({ |
| 79 | emptyType: WDLiveViewDefaultType.WDViewDefaultType_NoLiveSuspend | 83 | emptyType: WDLiveViewDefaultType.WDViewDefaultType_NoLiveSuspend |
| 80 | }) | 84 | }) |
| 81 | - .height('40%').margin({top:this.topSafeHeight }) | 85 | + .height('40%').margin({ top: this.topSafeHeight }) |
| 82 | } else { | 86 | } else { |
| 83 | 87 | ||
| 84 | if (this.liveDetailPageLogic.showPad) { | 88 | if (this.liveDetailPageLogic.showPad) { |
| 85 | // 有垫片 | 89 | // 有垫片 |
| 86 | - if(this.liveDetailPageLogic.padImageUri.length > 0){ | 90 | + if (this.liveDetailPageLogic.padImageUri.length > 0) { |
| 87 | // 配置了垫片资源 | 91 | // 配置了垫片资源 |
| 88 | Image(this.liveDetailPageLogic.padImageUri).objectFit(ImageFit.Fill).width('100%').height('100%') | 92 | Image(this.liveDetailPageLogic.padImageUri).objectFit(ImageFit.Fill).width('100%').height('100%') |
| 89 | 93 | ||
| 90 | - }else { | ||
| 91 | - // 没有配置垫片资源 | 94 | + } else { |
| 95 | + // 没有配置垫片资源 | ||
| 92 | LiveEmptyComponent({ | 96 | LiveEmptyComponent({ |
| 93 | emptyType: WDLiveViewDefaultType.WDViewDefaultType_NoLiveSuspend | 97 | emptyType: WDLiveViewDefaultType.WDViewDefaultType_NoLiveSuspend |
| 94 | }) | 98 | }) |
| 95 | - .height('40%').margin({top:this.topSafeHeight }) | 99 | + .height('40%').margin({ top: this.topSafeHeight }) |
| 96 | } | 100 | } |
| 97 | 101 | ||
| 98 | - | ||
| 99 | } else { | 102 | } else { |
| 100 | // 播放器 | 103 | // 播放器 |
| 101 | PlayerComponent({ | 104 | PlayerComponent({ |
| 102 | - playerController: this.playerController | 105 | + playerController: this.playerController, isPlayerError: this.isPlayerError, isCanplay: this.isCanplay |
| 103 | }) | 106 | }) |
| 104 | } | 107 | } |
| 105 | } | 108 | } |
| @@ -110,6 +113,44 @@ export struct DetailPlayVLivePage { | @@ -110,6 +113,44 @@ export struct DetailPlayVLivePage { | ||
| 110 | swiperController: this.swiperController, | 113 | swiperController: this.swiperController, |
| 111 | swiperIndex: $swiperIndex | 114 | swiperIndex: $swiperIndex |
| 112 | }) | 115 | }) |
| 116 | + | ||
| 117 | + // 直播资源加载失败 | ||
| 118 | + Column() { | ||
| 119 | + Text('直播加载中,请稍候重试') | ||
| 120 | + .fontSize('20fp') | ||
| 121 | + .fontWeight(500) | ||
| 122 | + .margin({ top: 16 }) | ||
| 123 | + .fontColor(Color.White) | ||
| 124 | + | ||
| 125 | + Button('点击重试') | ||
| 126 | + .type(ButtonType.Normal) | ||
| 127 | + .width(80) | ||
| 128 | + .height(28) | ||
| 129 | + .backgroundColor(Color.Transparent) | ||
| 130 | + .fontColor('#ffcccccc') | ||
| 131 | + .border({ width: 1 }) | ||
| 132 | + .borderColor('#4dffffff') | ||
| 133 | + .borderRadius(4) | ||
| 134 | + .fontSize($r('app.float.font_size_12')) | ||
| 135 | + .margin({ top: 16 }) | ||
| 136 | + .padding(0) | ||
| 137 | + .onClick(() => { | ||
| 138 | + | ||
| 139 | + this.isCanplay = false | ||
| 140 | + this.isPlayerError = false | ||
| 141 | + this.playerController?.firstPlay(this.playUrl, TrackConstants.PageName.Live_Detail, { | ||
| 142 | + 'contentType': `${this.contentDetailData.newsType}`, | ||
| 143 | + 'contentId': `${this.contentDetailData.newsId}`, | ||
| 144 | + 'contentName': `${this.contentDetailData.newsTitle || ''}`, | ||
| 145 | + }); | ||
| 146 | + }) | ||
| 147 | + } | ||
| 148 | + .width('100%') | ||
| 149 | + .margin({ top: 195 }) | ||
| 150 | + .justifyContent(FlexAlign.Center) | ||
| 151 | + .visibility(this.isPlayerError ? Visibility.Visible : | ||
| 152 | + Visibility.None) | ||
| 153 | + | ||
| 113 | // 清屏按钮 | 154 | // 清屏按钮 |
| 114 | Image($r('app.media.icon_live_more')) | 155 | Image($r('app.media.icon_live_more')) |
| 115 | .width(40) | 156 | .width(40) |
| @@ -25,7 +25,7 @@ export struct TopPlayComponent { | @@ -25,7 +25,7 @@ export struct TopPlayComponent { | ||
| 25 | //已结束直播 | 25 | //已结束直播 |
| 26 | @State isEnd: boolean = false | 26 | @State isEnd: boolean = false |
| 27 | //播放错误 | 27 | //播放错误 |
| 28 | - @State isError: boolean = false | 28 | + @State isPlayerError: boolean = false |
| 29 | // loading 控制字段 | 29 | // loading 控制字段 |
| 30 | @State isHideLoading: boolean = false | 30 | @State isHideLoading: boolean = false |
| 31 | // 获取播放资源能播放了 | 31 | // 获取播放资源能播放了 |
| @@ -50,14 +50,14 @@ export struct TopPlayComponent { | @@ -50,14 +50,14 @@ export struct TopPlayComponent { | ||
| 50 | this.playSourceState = status | 50 | this.playSourceState = status |
| 51 | Logger.debug(TAG, 'status==>' + status) | 51 | Logger.debug(TAG, 'status==>' + status) |
| 52 | if (status === PlayerConstants.STATUS_ERROR) { | 52 | if (status === PlayerConstants.STATUS_ERROR) { |
| 53 | - this.isError = true | 53 | + this.isPlayerError = true |
| 54 | this.isHideLoading = true | 54 | this.isHideLoading = true |
| 55 | this.isCanPlay = false | 55 | this.isCanPlay = false |
| 56 | } else if (status === PlayerConstants.STATUS_COMPLETION) { | 56 | } else if (status === PlayerConstants.STATUS_COMPLETION) { |
| 57 | // 播放完成 | 57 | // 播放完成 |
| 58 | 58 | ||
| 59 | } else { | 59 | } else { |
| 60 | - this.isError = false | 60 | + this.isPlayerError = false |
| 61 | } | 61 | } |
| 62 | 62 | ||
| 63 | } | 63 | } |
| @@ -186,7 +186,7 @@ export struct TopPlayComponent { | @@ -186,7 +186,7 @@ export struct TopPlayComponent { | ||
| 186 | onLoad: async () => { | 186 | onLoad: async () => { |
| 187 | if (StringUtils.isNotEmpty(this.playUrl)) { | 187 | if (StringUtils.isNotEmpty(this.playUrl)) { |
| 188 | this.isHideLoading = false | 188 | this.isHideLoading = false |
| 189 | - this.isError = false | 189 | + this.isPlayerError = false |
| 190 | this.xComponentIsLoaded = true | 190 | this.xComponentIsLoaded = true |
| 191 | Logger.debug(TAG, `---onLoad------>`) | 191 | Logger.debug(TAG, `---onLoad------>`) |
| 192 | this.tryToPlay() | 192 | this.tryToPlay() |
| @@ -265,12 +265,12 @@ export struct TopPlayComponent { | @@ -265,12 +265,12 @@ export struct TopPlayComponent { | ||
| 265 | .padding(0) | 265 | .padding(0) |
| 266 | .onClick(() => { | 266 | .onClick(() => { |
| 267 | this.isHideLoading = false | 267 | this.isHideLoading = false |
| 268 | - this.isError = false | 268 | + this.isPlayerError = false |
| 269 | this.xComponentIsLoaded = true | 269 | this.xComponentIsLoaded = true |
| 270 | this.tryToPlay() | 270 | this.tryToPlay() |
| 271 | 271 | ||
| 272 | }) | 272 | }) |
| 273 | - }.width('100%').visibility(this.isError ? Visibility.Visible : | 273 | + }.width('100%').visibility(this.isPlayerError ? Visibility.Visible : |
| 274 | Visibility.None) | 274 | Visibility.None) |
| 275 | 275 | ||
| 276 | } | 276 | } |
| 1 | import { ContentDetailDTO } from 'wdBean/Index'; | 1 | import { ContentDetailDTO } from 'wdBean/Index'; |
| 2 | -import { AliPlayerRenderView, WDAliPlayerController, WDPlayerRenderVLiveView } from 'wdPlayer/Index'; | 2 | +import { AliPlayerRenderView, PlayerConstants, WDAliPlayerController, WDPlayerRenderVLiveView } from 'wdPlayer/Index'; |
| 3 | import { ParamType, TrackConstants } from 'wdTracking/Index'; | 3 | import { ParamType, TrackConstants } from 'wdTracking/Index'; |
| 4 | import { PictureLoading } from './PictureLoading'; | 4 | import { PictureLoading } from './PictureLoading'; |
| 5 | 5 | ||
| @@ -20,8 +20,10 @@ export struct PlayerComponent { | @@ -20,8 +20,10 @@ export struct PlayerComponent { | ||
| 20 | // 0-横屏流画面,1-竖屏幕流画面 | 20 | // 0-横屏流画面,1-竖屏幕流画面 |
| 21 | @State liveStreamType: number | null = -1 | 21 | @State liveStreamType: number | null = -1 |
| 22 | @State playUrl: string = '' | 22 | @State playUrl: string = '' |
| 23 | - @State isCanplay: boolean = false | ||
| 24 | pageParam: ParamType = {} | 23 | pageParam: ParamType = {} |
| 24 | + // 播放失败 | ||
| 25 | + @Link isPlayerError: boolean | ||
| 26 | + @Link isCanplay: boolean | ||
| 25 | 27 | ||
| 26 | pageShowChange() { | 28 | pageShowChange() { |
| 27 | this.playerController?.play() | 29 | this.playerController?.play() |
| @@ -31,10 +33,33 @@ export struct PlayerComponent { | @@ -31,10 +33,33 @@ export struct PlayerComponent { | ||
| 31 | this.playerController?.pause() | 33 | this.playerController?.pause() |
| 32 | } | 34 | } |
| 33 | 35 | ||
| 34 | - async aboutToAppear(): Promise<void> { | 36 | + aboutToAppear(){ |
| 37 | + | ||
| 38 | + if (this.playerController) { | ||
| 39 | + this.playerController.onCanplay = () => { | ||
| 40 | + this.isCanplay = true | ||
| 41 | + this.playerController?.play() | ||
| 42 | + } | ||
| 43 | + this.playerController.onStatusChange = (status: number) => { | ||
| 44 | + if (status === PlayerConstants.STATUS_ERROR) { | ||
| 45 | + this.isPlayerError = true | ||
| 46 | + this.isCanplay = true | ||
| 47 | + } else if (status === PlayerConstants.STATUS_COMPLETION) { | ||
| 48 | + // 播放完成 | ||
| 49 | + | ||
| 50 | + } else { | ||
| 51 | + //this.isPlayerError = false | ||
| 52 | + } | ||
| 53 | + | ||
| 54 | + } | ||
| 55 | + } | ||
| 56 | + | ||
| 57 | + | ||
| 35 | setTimeout(() => { | 58 | setTimeout(() => { |
| 36 | this.updateData() | 59 | this.updateData() |
| 37 | }, 10) | 60 | }, 10) |
| 61 | + | ||
| 62 | + | ||
| 38 | } | 63 | } |
| 39 | 64 | ||
| 40 | async aboutToDisappear(): Promise<void> { | 65 | async aboutToDisappear(): Promise<void> { |
| @@ -65,49 +90,41 @@ export struct PlayerComponent { | @@ -65,49 +90,41 @@ export struct PlayerComponent { | ||
| 65 | this.liveStreamType = liveStreamType | 90 | this.liveStreamType = liveStreamType |
| 66 | this.playUrl = playUrl | 91 | this.playUrl = playUrl |
| 67 | } | 92 | } |
| 68 | - console.error("XXXXZZZZ", 'updateData ----liveState==>' + this.playUrl) | ||
| 69 | } | 93 | } |
| 70 | 94 | ||
| 71 | build() { | 95 | build() { |
| 72 | - Column() { | ||
| 73 | - Stack() { | ||
| 74 | - // TODO:判断横竖屏,liveStreamType=1竖屏铺满屏幕,裁剪不拉伸,liveStreamType=0横屏正常展示 | ||
| 75 | - if (this.liveStreamType == null || this.liveStreamType == 1) { | ||
| 76 | - WDPlayerRenderVLiveView({ | ||
| 77 | - playerController: this.playerController, | ||
| 78 | - onLoad: () => { | ||
| 79 | - this.isCanplay = true | ||
| 80 | - this.contentTrackingDict() | ||
| 81 | - this.playerController?.firstPlay(this.playUrl, TrackConstants.PageName.Live_Detail, this.pageParam); | ||
| 82 | - } | ||
| 83 | - }) | ||
| 84 | - } else if (this.liveStreamType == 0) { | ||
| 85 | - AliPlayerRenderView({ | ||
| 86 | - playerController: this.playerController, | ||
| 87 | - onLoad: () => { | ||
| 88 | - this.isCanplay = true | ||
| 89 | - this.contentTrackingDict() | ||
| 90 | - this.playerController?.firstPlay(this.playUrl, TrackConstants.PageName.Live_Detail, this.pageParam); | ||
| 91 | - } | ||
| 92 | - }).margin({ top: 195 }).height(211) | ||
| 93 | - } | 96 | + Stack() { |
| 97 | + // TODO:判断横竖屏,liveStreamType=1竖屏铺满屏幕,裁剪不拉伸,liveStreamType=0横屏正常展示 | ||
| 98 | + if (this.liveStreamType == null || this.liveStreamType == 1) { | ||
| 99 | + WDPlayerRenderVLiveView({ | ||
| 100 | + playerController: this.playerController, | ||
| 101 | + onLoad: () => { | ||
| 102 | + console.error("XXXXZZZZ", '-------------1--------' + this.playUrl) | ||
| 103 | + this.isCanplay = true | ||
| 104 | + this.contentTrackingDict() | ||
| 105 | + this.playerController?.firstPlay(this.playUrl, TrackConstants.PageName.Live_Detail, this.pageParam); | ||
| 106 | + } | ||
| 107 | + }) | ||
| 108 | + } else if (this.liveStreamType == 0) { | ||
| 109 | + AliPlayerRenderView({ | ||
| 110 | + playerController: this.playerController, | ||
| 111 | + onLoad: () => { | ||
| 112 | + this.isCanplay = true | ||
| 113 | + this.contentTrackingDict() | ||
| 114 | + this.playerController?.firstPlay(this.playUrl, TrackConstants.PageName.Live_Detail, this.pageParam); | ||
| 115 | + } | ||
| 116 | + }).margin({ top: 195 }).height(211) | ||
| 117 | + } | ||
| 94 | 118 | ||
| 95 | - PictureLoading().visibility(this.isCanplay ? Visibility.None : Visibility.Visible) | 119 | + PictureLoading().visibility(this.isCanplay ? Visibility.None : Visibility.Visible) |
| 96 | 120 | ||
| 97 | - } | ||
| 98 | - .height('100%') | ||
| 99 | - .width('100%') | ||
| 100 | - .align(Alignment.Top) | ||
| 101 | - .alignContent(Alignment.Top) | ||
| 102 | - .onClick(() => { | ||
| 103 | - if (this.liveState === 'end') { | ||
| 104 | - this.isShowControl = !this.isShowControl | ||
| 105 | - } | ||
| 106 | - }) | ||
| 107 | 121 | ||
| 108 | } | 122 | } |
| 109 | .height('100%') | 123 | .height('100%') |
| 110 | .width('100%') | 124 | .width('100%') |
| 125 | + .align(Alignment.Top) | ||
| 126 | + .alignContent(Alignment.Top) | ||
| 127 | + | ||
| 111 | } | 128 | } |
| 112 | 129 | ||
| 113 | contentTrackingDict() { | 130 | contentTrackingDict() { |
| @@ -24,6 +24,8 @@ struct ChangeBindPhonePage { | @@ -24,6 +24,8 @@ struct ChangeBindPhonePage { | ||
| 24 | lastTime: number = 0 | 24 | lastTime: number = 0 |
| 25 | pageShowTime:number = 0; | 25 | pageShowTime:number = 0; |
| 26 | pageHideTime:number = 0; | 26 | pageHideTime:number = 0; |
| 27 | + @State topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 | ||
| 28 | + @State bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 | ||
| 27 | 29 | ||
| 28 | 30 | ||
| 29 | onPageShow() { | 31 | onPageShow() { |
| @@ -58,103 +60,109 @@ struct ChangeBindPhonePage { | @@ -58,103 +60,109 @@ struct ChangeBindPhonePage { | ||
| 58 | 60 | ||
| 59 | 61 | ||
| 60 | build() { | 62 | build() { |
| 61 | - Column() { | ||
| 62 | - Image($r('app.media.login_back_icon')).width(24).height(24).margin({ left: 15, top: 10 }).onClick(() => { | ||
| 63 | - router.back() | ||
| 64 | - }) | 63 | + Column(){ |
| 64 | + Column() { | ||
| 65 | + Image($r('app.media.login_back_icon')).width(24).height(24).margin({ left: 15, top: 10 }).onClick(() => { | ||
| 66 | + router.back() | ||
| 67 | + }) | ||
| 65 | 68 | ||
| 66 | - Text(this.pageTitle).fontSize(22).fontColor('#333333').fontWeight(FontWeight.Bold).margin({ left: 25, top: 112 }) | 69 | + Text(this.pageTitle).fontSize(22).fontColor('#333333').fontWeight(FontWeight.Bold).margin({ left: 25, top: 112 }) |
| 67 | 70 | ||
| 68 | - Column(){ | ||
| 69 | - TextInput({text: this.phoneContent, placeholder: "请输入手机号" }) | ||
| 70 | - .fontSize(16) | ||
| 71 | - .height(48) | ||
| 72 | - .placeholderColor("#CCCCCC") | ||
| 73 | - .maxLength(11) | ||
| 74 | - .margin({ top: 36 }) | ||
| 75 | - .backgroundColor("#F5F5F5") | ||
| 76 | - .borderRadius(4) | ||
| 77 | - .type(InputType.Number) | ||
| 78 | - .onChange((content) => { | ||
| 79 | - this.phoneContent = content | ||
| 80 | - this.isSubmit = (this.phoneContent.length >= 11 && this.codeContent.length >= 4) | ||
| 81 | - | ||
| 82 | - if (content.length >= 11 ) { | ||
| 83 | - this.codeBtnState = true | ||
| 84 | - } else { | ||
| 85 | - this.codeBtnState = false | ||
| 86 | - } | ||
| 87 | - }) | ||
| 88 | - | ||
| 89 | - | ||
| 90 | - Row() { | ||
| 91 | - TextInput({ text: this.codeContent,placeholder: "验证码" }) | ||
| 92 | - .placeholderColor("#CCCCCC") | ||
| 93 | - .layoutWeight(1) | 71 | + Column(){ |
| 72 | + TextInput({text: this.phoneContent, placeholder: "请输入手机号" }) | ||
| 94 | .fontSize(16) | 73 | .fontSize(16) |
| 95 | .height(48) | 74 | .height(48) |
| 75 | + .placeholderColor("#CCCCCC") | ||
| 76 | + .maxLength(11) | ||
| 77 | + .margin({ top: 36 }) | ||
| 78 | + .backgroundColor("#F5F5F5") | ||
| 79 | + .borderRadius(4) | ||
| 96 | .type(InputType.Number) | 80 | .type(InputType.Number) |
| 97 | - .fontColor("#222222") | ||
| 98 | - .backgroundColor("#00000000") | ||
| 99 | - .borderRadius({ topLeft: 4, bottomLeft: 4 }) | ||
| 100 | - .onChange((value) => { | ||
| 101 | - this.codeContent = value | 81 | + .onChange((content) => { |
| 82 | + this.phoneContent = content | ||
| 102 | this.isSubmit = (this.phoneContent.length >= 11 && this.codeContent.length >= 4) | 83 | this.isSubmit = (this.phoneContent.length >= 11 && this.codeContent.length >= 4) |
| 103 | - }) | ||
| 104 | 84 | ||
| 105 | - Text(this.codeStateSuccess ? this.timeCount + "s" : this.isFirst?"发送验证码":'重新获取') | ||
| 106 | - .fontColor(this.codeBtnState?'#ED2800':'#80ED2800') | ||
| 107 | - .width(110) | ||
| 108 | - .fontSize(14) | ||
| 109 | - .fontWeight( FontWeight.Bold) | ||
| 110 | - .height(48) | ||
| 111 | - .textAlign(TextAlign.Center) | ||
| 112 | - .enabled(this.codeStateSuccess?false:true) | ||
| 113 | - .onClick(() => { | ||
| 114 | - if (this.phoneContent.length < 11) { | ||
| 115 | - return | 85 | + if (content.length >= 11 ) { |
| 86 | + this.codeBtnState = true | ||
| 87 | + } else { | ||
| 88 | + this.codeBtnState = false | ||
| 116 | } | 89 | } |
| 90 | + }) | ||
| 117 | 91 | ||
| 118 | - let currentTime = DateTimeUtils.getTimeStamp() | ||
| 119 | - if (currentTime - this.lastTime < 500) { | ||
| 120 | - return | ||
| 121 | - } | ||
| 122 | - this.lastTime = currentTime; | ||
| 123 | - this.isCodeSend = true | ||
| 124 | 92 | ||
| 93 | + Row() { | ||
| 94 | + TextInput({ text: this.codeContent,placeholder: "验证码" }) | ||
| 95 | + .placeholderColor("#CCCCCC") | ||
| 96 | + .layoutWeight(1) | ||
| 97 | + .fontSize(16) | ||
| 98 | + .height(48) | ||
| 99 | + .type(InputType.Number) | ||
| 100 | + .fontColor("#222222") | ||
| 101 | + .backgroundColor("#00000000") | ||
| 102 | + .borderRadius({ topLeft: 4, bottomLeft: 4 }) | ||
| 103 | + .onChange((value) => { | ||
| 104 | + this.codeContent = value | ||
| 105 | + this.isSubmit = (this.phoneContent.length >= 11 && this.codeContent.length >= 4) | ||
| 106 | + }) | ||
| 107 | + | ||
| 108 | + Text(this.codeStateSuccess ? this.timeCount + "s" : this.isFirst?"发送验证码":'重新获取') | ||
| 109 | + .fontColor(this.codeBtnState?'#ED2800':'#80ED2800') | ||
| 110 | + .width(110) | ||
| 111 | + .fontSize(14) | ||
| 112 | + .fontWeight( FontWeight.Bold) | ||
| 113 | + .height(48) | ||
| 114 | + .textAlign(TextAlign.Center) | ||
| 115 | + .enabled(this.codeStateSuccess?false:true) | ||
| 116 | + .onClick(() => { | ||
| 117 | + if (this.phoneContent.length < 11) { | ||
| 118 | + return | ||
| 119 | + } | ||
| 120 | + | ||
| 121 | + let currentTime = DateTimeUtils.getTimeStamp() | ||
| 122 | + if (currentTime - this.lastTime < 500) { | ||
| 123 | + return | ||
| 124 | + } | ||
| 125 | + this.lastTime = currentTime; | ||
| 126 | + this.isCodeSend = true | ||
| 127 | + | ||
| 128 | + }) | ||
| 129 | + | ||
| 130 | + | ||
| 131 | + }.margin({ top: 12 }) | ||
| 132 | + .height(48) | ||
| 133 | + .alignItems(VerticalAlign.Center) | ||
| 134 | + .justifyContent(FlexAlign.Start) | ||
| 135 | + .backgroundImage($r('app.media.code_login_bg')) | ||
| 136 | + .backgroundImageSize({width:'100%',height:48}) | ||
| 137 | + }.width('100%') | ||
| 138 | + .padding({ left: 25, right: 25 }) | ||
| 139 | + | ||
| 140 | + | ||
| 141 | + Row() { | ||
| 142 | + Text("确认") | ||
| 143 | + .layoutWeight(1) | ||
| 144 | + .fontColor("#FFFFFF") | ||
| 145 | + .borderRadius(4) | ||
| 146 | + .fontSize(18) | ||
| 147 | + .textAlign(TextAlign.Center) | ||
| 148 | + .fontWeight(FontWeight.Medium) | ||
| 149 | + .margin({ top: 26 }) | ||
| 150 | + .height(44) | ||
| 151 | + .backgroundColor("#ED2800") | ||
| 152 | + .enabled(this.isSubmit ? true : false) | ||
| 153 | + .opacity(this.isSubmit ? 1: 0.6) | ||
| 154 | + .onClick(() => { | ||
| 155 | + TrackingButton.click("changePhoneNumberPageConfirm",TrackConstants.PageName.Change_PhoneNum,TrackConstants.PageName.Change_PhoneNum) | ||
| 156 | + this.changeBindPhone() | ||
| 125 | }) | 157 | }) |
| 158 | + }.width('100%') | ||
| 159 | + .padding({ left: 25, right: 25 }) | ||
| 126 | 160 | ||
| 161 | + }.width('100%').height('100%').alignItems(HorizontalAlign.Start) | ||
| 162 | + }.width("100%") | ||
| 163 | + .height("100%") | ||
| 164 | + .padding({top:px2vp(this.topSafeHeight),bottom:px2vp(this.bottomSafeHeight)}) | ||
| 127 | 165 | ||
| 128 | - }.margin({ top: 12 }) | ||
| 129 | - .height(48) | ||
| 130 | - .alignItems(VerticalAlign.Center) | ||
| 131 | - .justifyContent(FlexAlign.Start) | ||
| 132 | - .backgroundImage($r('app.media.code_login_bg')) | ||
| 133 | - .backgroundImageSize({width:'100%',height:48}) | ||
| 134 | - }.width('100%') | ||
| 135 | - .padding({ left: 25, right: 25 }) | ||
| 136 | - | ||
| 137 | - | ||
| 138 | - Row() { | ||
| 139 | - Text("确认") | ||
| 140 | - .layoutWeight(1) | ||
| 141 | - .fontColor(this.isSubmit ?"#FFFFFFFF":"#66FFFFFF") | ||
| 142 | - .borderRadius(4) | ||
| 143 | - .fontSize(18) | ||
| 144 | - .textAlign(TextAlign.Center) | ||
| 145 | - .fontWeight(FontWeight.Medium) | ||
| 146 | - .margin({ top: 26 }) | ||
| 147 | - .height(44) | ||
| 148 | - .backgroundColor(this.isSubmit ?"#ED2800":"#99ED2800") | ||
| 149 | - .enabled(this.isSubmit ? true : false) | ||
| 150 | - .onClick(() => { | ||
| 151 | - TrackingButton.click("changePhoneNumberPageConfirm",TrackConstants.PageName.Change_PhoneNum,TrackConstants.PageName.Change_PhoneNum) | ||
| 152 | - this.changeBindPhone() | ||
| 153 | - }) | ||
| 154 | - }.width('100%') | ||
| 155 | - .padding({ left: 25, right: 25 }) | ||
| 156 | - | ||
| 157 | - }.width('100%').height('100%').alignItems(HorizontalAlign.Start) | ||
| 158 | } | 166 | } |
| 159 | 167 | ||
| 160 | //发送验证码 | 168 | //发送验证码 |
| @@ -23,6 +23,8 @@ struct ForgetPasswordPage { | @@ -23,6 +23,8 @@ struct ForgetPasswordPage { | ||
| 23 | @State pageTitle:string = '找回密码'; | 23 | @State pageTitle:string = '找回密码'; |
| 24 | @State isForgetPassword: number = 0 //是否是登录页忘记密码过来的,标题不一样 | 24 | @State isForgetPassword: number = 0 //是否是登录页忘记密码过来的,标题不一样 |
| 25 | @State codeStateSuccess:boolean=false | 25 | @State codeStateSuccess:boolean=false |
| 26 | + @State topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 | ||
| 27 | + @State bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 | ||
| 26 | onCodeSend() { | 28 | onCodeSend() { |
| 27 | if (this.isCodeSend) { | 29 | if (this.isCodeSend) { |
| 28 | this.sendVerifyCode() | 30 | this.sendVerifyCode() |
| @@ -43,41 +45,48 @@ struct ForgetPasswordPage { | @@ -43,41 +45,48 @@ struct ForgetPasswordPage { | ||
| 43 | 45 | ||
| 44 | 46 | ||
| 45 | build() { | 47 | build() { |
| 46 | - Column() { | ||
| 47 | - Image($r('app.media.login_back_icon')).width(24).height(24).margin({ left: 15, top: 10 }).onClick(() => { | ||
| 48 | - router.back() | ||
| 49 | - }) | 48 | + Column(){ |
| 49 | + Column() { | ||
| 50 | + Image($r('app.media.login_back_icon')).width(24).height(24).margin({ left: 15, top: 10 }).onClick(() => { | ||
| 51 | + router.back() | ||
| 52 | + }) | ||
| 53 | + | ||
| 54 | + Text(this.pageTitle).fontSize(22).fontColor('#333333').fontWeight(FontWeight.Bold).margin({ left: 25, top: 112 }) | ||
| 55 | + LoginInputComponent({ | ||
| 56 | + phoneContent: $phoneContent, | ||
| 57 | + codeContent: $codeContent, | ||
| 58 | + isSubmit: $isSubmit, | ||
| 59 | + isCodeSend: $isCodeSend, | ||
| 60 | + pageType:0, | ||
| 61 | + codeStateSuccess:$codeStateSuccess | ||
| 62 | + }) | ||
| 63 | + Row() { | ||
| 64 | + Text("确认") | ||
| 65 | + .layoutWeight(1) | ||
| 66 | + .fontColor("#FFFFFF") | ||
| 67 | + .borderRadius(4) | ||
| 68 | + .fontSize(18) | ||
| 69 | + .textAlign(TextAlign.Center) | ||
| 70 | + .fontWeight(FontWeight.Medium) | ||
| 71 | + .margin({ top: 26 }) | ||
| 72 | + .height(44) | ||
| 73 | + .backgroundColor("#ED2800") | ||
| 74 | + .enabled(this.isSubmit ? true : false) | ||
| 75 | + .opacity(this.isSubmit ? 1: 0.6) | ||
| 76 | + .onClick(() => { | ||
| 77 | + this.checkVerifyCode() | ||
| 78 | + }) | ||
| 79 | + }.padding({ left: 25, right: 25 }).width('100%') | ||
| 80 | + | ||
| 81 | + }.width('100%') | ||
| 82 | + .height('100%') | ||
| 83 | + .alignItems(HorizontalAlign.Start) | ||
| 84 | + .backgroundColor(Color.White) | ||
| 85 | + | ||
| 86 | + }.width("100%") | ||
| 87 | + .height("100%") | ||
| 88 | + .padding({top:px2vp(this.topSafeHeight),bottom:px2vp(this.bottomSafeHeight)}) | ||
| 50 | 89 | ||
| 51 | - Text(this.pageTitle).fontSize(22).fontColor('#333333').fontWeight(FontWeight.Bold).margin({ left: 25, top: 112 }) | ||
| 52 | - LoginInputComponent({ | ||
| 53 | - phoneContent: $phoneContent, | ||
| 54 | - codeContent: $codeContent, | ||
| 55 | - isSubmit: $isSubmit, | ||
| 56 | - isCodeSend: $isCodeSend, | ||
| 57 | - pageType:0, | ||
| 58 | - codeStateSuccess:$codeStateSuccess | ||
| 59 | - }) | ||
| 60 | - Row() { | ||
| 61 | - Text("确认") | ||
| 62 | - .layoutWeight(1) | ||
| 63 | - .fontColor(this.isSubmit ?"#FFFFFFFF":"#66FFFFFF") | ||
| 64 | - .borderRadius(4) | ||
| 65 | - .fontSize(18) | ||
| 66 | - .textAlign(TextAlign.Center) | ||
| 67 | - .fontWeight(FontWeight.Medium) | ||
| 68 | - .margin({ top: 26 }) | ||
| 69 | - .height(44) | ||
| 70 | - .backgroundColor(this.isSubmit ?"#ED2800":"#99ED2800") | ||
| 71 | - .enabled(this.isSubmit ? true : false) | ||
| 72 | - .onClick(() => { | ||
| 73 | - this.checkVerifyCode() | ||
| 74 | - }) | ||
| 75 | - }.padding({ left: 25, right: 25 }).width('100%') | ||
| 76 | - | ||
| 77 | - }.width('100%') | ||
| 78 | - .height('100%') | ||
| 79 | - .alignItems(HorizontalAlign.Start) | ||
| 80 | - .backgroundColor(Color.White) | ||
| 81 | } | 90 | } |
| 82 | 91 | ||
| 83 | aboutToAppear() { | 92 | aboutToAppear() { |
| @@ -27,6 +27,8 @@ const TAG = "LoginPage" | @@ -27,6 +27,8 @@ const TAG = "LoginPage" | ||
| 27 | @Entry | 27 | @Entry |
| 28 | @Component | 28 | @Component |
| 29 | struct LoginPage { | 29 | struct LoginPage { |
| 30 | + @State topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 | ||
| 31 | + @State bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 | ||
| 30 | @State codeBtnState: boolean = false | 32 | @State codeBtnState: boolean = false |
| 31 | @State timeCount: number = 60 | 33 | @State timeCount: number = 60 |
| 32 | phoneController: TextInputController = new TextInputController() | 34 | phoneController: TextInputController = new TextInputController() |
| @@ -104,7 +106,8 @@ struct LoginPage { | @@ -104,7 +106,8 @@ struct LoginPage { | ||
| 104 | } | 106 | } |
| 105 | 107 | ||
| 106 | build() { | 108 | build() { |
| 107 | - Stack() { | 109 | + Column(){ |
| 110 | + Stack() { | ||
| 108 | RelativeContainer() { | 111 | RelativeContainer() { |
| 109 | 112 | ||
| 110 | //注册内容 | 113 | //注册内容 |
| @@ -161,15 +164,16 @@ struct LoginPage { | @@ -161,15 +164,16 @@ struct LoginPage { | ||
| 161 | Row() { | 164 | Row() { |
| 162 | Text("登录") | 165 | Text("登录") |
| 163 | .borderRadius(4) | 166 | .borderRadius(4) |
| 164 | - .fontColor(this.isSubmit ? "#FFFFFFFF" : "#66FFFFFF") | 167 | + .fontColor("#FFFFFF") |
| 165 | .fontSize(`${this.calcHeight(31)}lpx`) | 168 | .fontSize(`${this.calcHeight(31)}lpx`) |
| 166 | .fontWeight(400) | 169 | .fontWeight(400) |
| 167 | .margin({ top: `${this.calcHeight(20)}` }) | 170 | .margin({ top: `${this.calcHeight(20)}` }) |
| 168 | .lineHeight(`${this.calcHeight(50)}lpx`) | 171 | .lineHeight(`${this.calcHeight(50)}lpx`) |
| 169 | - .height(44) | 172 | + .height(44) |
| 170 | .textAlign(TextAlign.Center) | 173 | .textAlign(TextAlign.Center) |
| 171 | .width("100%") | 174 | .width("100%") |
| 172 | - .backgroundColor(this.isSubmit ? "#FFED2800" : "#99ED2800") | 175 | + .backgroundColor("#ED2800") |
| 176 | + .opacity(this.isSubmit ? 1: 0.6) | ||
| 173 | .onClick(() => { | 177 | .onClick(() => { |
| 174 | if (!this.isSubmit) { | 178 | if (!this.isSubmit) { |
| 175 | return | 179 | return |
| @@ -241,8 +245,12 @@ struct LoginPage { | @@ -241,8 +245,12 @@ struct LoginPage { | ||
| 241 | .visibility(this.isProtocol ? Visibility.Visible : Visibility.None) | 245 | .visibility(this.isProtocol ? Visibility.Visible : Visibility.None) |
| 242 | 246 | ||
| 243 | }.width('100%') | 247 | }.width('100%') |
| 244 | - .height('100%') | 248 | + .height("100%") |
| 245 | .backgroundColor(Color.White) | 249 | .backgroundColor(Color.White) |
| 250 | + }.width("100%") | ||
| 251 | + .height("100%") | ||
| 252 | + .padding({top:px2vp(this.topSafeHeight),bottom:px2vp(this.bottomSafeHeight)}) | ||
| 253 | + | ||
| 246 | } | 254 | } |
| 247 | 255 | ||
| 248 | @Builder | 256 | @Builder |
| @@ -10,6 +10,8 @@ const TAG = 'LoginProtocolWebview'; | @@ -10,6 +10,8 @@ const TAG = 'LoginProtocolWebview'; | ||
| 10 | @Entry | 10 | @Entry |
| 11 | @Component | 11 | @Component |
| 12 | struct LoginProtocolWebview { | 12 | struct LoginProtocolWebview { |
| 13 | + @State topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 | ||
| 14 | + @State bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 | ||
| 13 | webUrl: string = '' | 15 | webUrl: string = '' |
| 14 | webviewController: webview.WebviewController = new webview.WebviewController() | 16 | webviewController: webview.WebviewController = new webview.WebviewController() |
| 15 | userProtocol = "https://cdnpeoplefrontuat.aikan.pdnews.cn/rmrb/rmrb-protocol-zh-web/0.0.1/app/protocol-1005.html" | 17 | userProtocol = "https://cdnpeoplefrontuat.aikan.pdnews.cn/rmrb/rmrb-protocol-zh-web/0.0.1/app/protocol-1005.html" |
| @@ -55,38 +57,42 @@ struct LoginProtocolWebview { | @@ -55,38 +57,42 @@ struct LoginProtocolWebview { | ||
| 55 | } | 57 | } |
| 56 | 58 | ||
| 57 | build() { | 59 | build() { |
| 60 | + Column(){ | ||
| 61 | + Column() { | ||
| 62 | + Row() { | ||
| 63 | + Image($r("app.media.login_back_icon")) | ||
| 64 | + .width(24) | ||
| 65 | + .aspectRatio(1) | ||
| 66 | + .onClick(() => { | ||
| 67 | + if(this.webviewController.accessBackward()){ | ||
| 68 | + this.webviewController.backward() | ||
| 69 | + return | ||
| 70 | + } | ||
| 71 | + router.back(); | ||
| 72 | + }).margin({ left: 16 }) | ||
| 73 | + Text() | ||
| 74 | + } | ||
| 75 | + .alignItems(VerticalAlign.Center) | ||
| 76 | + .width('100%') | ||
| 77 | + .height(44) | ||
| 58 | 78 | ||
| 59 | - Column() { | ||
| 60 | - Row() { | ||
| 61 | - Image($r("app.media.login_back_icon")) | ||
| 62 | - .width(24) | ||
| 63 | - .aspectRatio(1) | ||
| 64 | - .onClick(() => { | ||
| 65 | - if(this.webviewController.accessBackward()){ | ||
| 66 | - this.webviewController.backward() | ||
| 67 | - return | ||
| 68 | - } | ||
| 69 | - router.back(); | ||
| 70 | - }).margin({ left: 16 }) | ||
| 71 | - Text() | 79 | + Web({ src: this.webUrl, controller: this.webviewController }) |
| 80 | + .domStorageAccess(true) | ||
| 81 | + .databaseAccess(true) | ||
| 82 | + .javaScriptAccess(true) | ||
| 83 | + .zoomAccess(false) | ||
| 84 | + .horizontalScrollBarAccess(false) | ||
| 85 | + .verticalScrollBarAccess(false) | ||
| 86 | + .onHttpErrorReceive((event) => { | ||
| 87 | + //TODO 页面加载不成功的时候处理 | ||
| 88 | + Logger.info(TAG, 'onHttpErrorReceive event.request.getRequestUrl:' + event?.request.getRequestUrl()); | ||
| 89 | + Logger.info(TAG, 'onHttpErrorReceive event.response.getResponseCode:' + event?.response.getResponseCode()); | ||
| 90 | + }) | ||
| 91 | + .padding({bottom:this.contentID === "2" ? "40lpx" : 0 }) | ||
| 72 | } | 92 | } |
| 73 | - .alignItems(VerticalAlign.Center) | ||
| 74 | - .width('100%') | ||
| 75 | - .height(44) | 93 | + }.width("100%") |
| 94 | + .height("100%") | ||
| 95 | + .padding({top:px2vp(this.topSafeHeight),bottom:px2vp(this.bottomSafeHeight)}) | ||
| 76 | 96 | ||
| 77 | - Web({ src: this.webUrl, controller: this.webviewController }) | ||
| 78 | - .domStorageAccess(true) | ||
| 79 | - .databaseAccess(true) | ||
| 80 | - .javaScriptAccess(true) | ||
| 81 | - .zoomAccess(false) | ||
| 82 | - .horizontalScrollBarAccess(false) | ||
| 83 | - .verticalScrollBarAccess(false) | ||
| 84 | - .onHttpErrorReceive((event) => { | ||
| 85 | - //TODO 页面加载不成功的时候处理 | ||
| 86 | - Logger.info(TAG, 'onHttpErrorReceive event.request.getRequestUrl:' + event?.request.getRequestUrl()); | ||
| 87 | - Logger.info(TAG, 'onHttpErrorReceive event.response.getResponseCode:' + event?.response.getResponseCode()); | ||
| 88 | - }) | ||
| 89 | - .padding({bottom:this.contentID === "2" ? "40lpx" : 0 }) | ||
| 90 | - } | ||
| 91 | } | 97 | } |
| 92 | } | 98 | } |
| @@ -12,6 +12,8 @@ import { TrackingPageBrowse, TrackConstants, TrackingButton } from 'wdTracking/I | @@ -12,6 +12,8 @@ import { TrackingPageBrowse, TrackConstants, TrackingButton } from 'wdTracking/I | ||
| 12 | @Entry | 12 | @Entry |
| 13 | @Component | 13 | @Component |
| 14 | struct ModifyPasswordPage { | 14 | struct ModifyPasswordPage { |
| 15 | + @State topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 | ||
| 16 | + @State bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 | ||
| 15 | password_old: string = ''; | 17 | password_old: string = ''; |
| 16 | password_new: string = ''; | 18 | password_new: string = ''; |
| 17 | password_new_repeat: string = ''; | 19 | password_new_repeat: string = ''; |
| @@ -64,9 +66,13 @@ struct ModifyPasswordPage { | @@ -64,9 +66,13 @@ struct ModifyPasswordPage { | ||
| 64 | 66 | ||
| 65 | build() { | 67 | build() { |
| 66 | Column(){ | 68 | Column(){ |
| 67 | - this.TitleBackComponent('') | ||
| 68 | - this.ModifyPasswordLayout() | ||
| 69 | - } | 69 | + Column(){ |
| 70 | + this.TitleBackComponent('') | ||
| 71 | + this.ModifyPasswordLayout() | ||
| 72 | + } | ||
| 73 | + }.width("100%") | ||
| 74 | + .height("100%") | ||
| 75 | + .padding({top:px2vp(this.topSafeHeight),bottom:px2vp(this.bottomSafeHeight)}) | ||
| 70 | 76 | ||
| 71 | } | 77 | } |
| 72 | 78 | ||
| @@ -189,30 +195,30 @@ struct ModifyPasswordPage { | @@ -189,30 +195,30 @@ struct ModifyPasswordPage { | ||
| 189 | .height(`${this.calcHeight(85)}lpx`) | 195 | .height(`${this.calcHeight(85)}lpx`) |
| 190 | .alignItems(HorizontalAlign.Start) | 196 | .alignItems(HorizontalAlign.Start) |
| 191 | 197 | ||
| 198 | + | ||
| 192 | Row() { | 199 | Row() { |
| 193 | - Button( { type: ButtonType.Normal, stateEffect: true }){ | ||
| 194 | - Text("确认") | ||
| 195 | - .fontColor("#fff") | ||
| 196 | - .fontSize(`${this.calcHeight(35)}lpx`) | ||
| 197 | - .lineHeight(`${this.calcHeight(50)}lpx`) | ||
| 198 | - .opacity(this.btnStatus ?1:0.5) | ||
| 199 | - } | ||
| 200 | - .width('100%') | ||
| 201 | - .height(`${this.calcHeight(80)}lpx`) | ||
| 202 | - .backgroundColor(this.btnStatus ? '#ED2800' : '#99ED2800') | ||
| 203 | - .enabled(this.btnStatus ?true:false) | ||
| 204 | - .borderRadius('4vp') | 200 | + Text("确认") |
| 201 | + .layoutWeight(1) | ||
| 202 | + .fontColor("#FFFFFF") | ||
| 203 | + .borderRadius(4) | ||
| 204 | + .fontSize(18) | ||
| 205 | + .textAlign(TextAlign.Center) | ||
| 206 | + .fontWeight(FontWeight.Medium) | ||
| 207 | + .margin({ top: 26 }) | ||
| 208 | + .height(44) | ||
| 209 | + .backgroundColor("#ED2800") | ||
| 210 | + .enabled(this.btnStatus ? true : false) | ||
| 211 | + .opacity(this.btnStatus ? 1: 0.6) | ||
| 205 | .onClick(() => { | 212 | .onClick(() => { |
| 206 | if(this.btnStatus){ | 213 | if(this.btnStatus){ |
| 207 | TrackingButton.click("changePasswordPageConfirm",TrackConstants.PageName.Change_Passwd,TrackConstants.PageName.Change_Passwd) | 214 | TrackingButton.click("changePasswordPageConfirm",TrackConstants.PageName.Change_Passwd,TrackConstants.PageName.Change_Passwd) |
| 208 | this.submit() | 215 | this.submit() |
| 209 | } | 216 | } |
| 210 | }) | 217 | }) |
| 211 | - } | 218 | + }.width('100%') |
| 212 | .padding({top:`${this.calcHeight(25)}lpx`}) | 219 | .padding({top:`${this.calcHeight(25)}lpx`}) |
| 213 | .alignItems(VerticalAlign.Center) | 220 | .alignItems(VerticalAlign.Center) |
| 214 | .width('100%') | 221 | .width('100%') |
| 215 | - .height(`${this.calcHeight(120)}lpx`) | ||
| 216 | 222 | ||
| 217 | Column() { | 223 | Column() { |
| 218 | Text("忘记密码").fontSize(12).maxLines(3).fontColor(0x999999).padding({top:`${this.calcHeight(10)}lpx`}) | 224 | Text("忘记密码").fontSize(12).maxLines(3).fontColor(0x999999).padding({top:`${this.calcHeight(10)}lpx`}) |
| @@ -2,7 +2,7 @@ import ArrayList from '@ohos.util.ArrayList'; | @@ -2,7 +2,7 @@ import ArrayList from '@ohos.util.ArrayList'; | ||
| 2 | import { Params } from '../../../../../../../commons/wdRouter/oh_modules/wdBean/Index'; | 2 | import { Params } from '../../../../../../../commons/wdRouter/oh_modules/wdBean/Index'; |
| 3 | import router from '@ohos.router'; | 3 | import router from '@ohos.router'; |
| 4 | import { LoginViewModel } from './LoginViewModel'; | 4 | import { LoginViewModel } from './LoginViewModel'; |
| 5 | -import { CustomToast, DateTimeUtils, Logger, SPHelper, ToastUtils } from 'wdKit'; | 5 | +import { BreakpointSystem, CustomToast, DateTimeUtils, Logger, SPHelper, ToastUtils } from 'wdKit'; |
| 6 | import { | 6 | import { |
| 7 | SpConstants | 7 | SpConstants |
| 8 | } from '../../../../../../../commons/wdNetwork/oh_modules/wdConstant/src/main/ets/constants/SpConstants' | 8 | } from '../../../../../../../commons/wdNetwork/oh_modules/wdConstant/src/main/ets/constants/SpConstants' |
| @@ -74,6 +74,19 @@ export struct SettingPasswordPage { | @@ -74,6 +74,19 @@ export struct SettingPasswordPage { | ||
| 74 | pageHideResetTime:number = 0; | 74 | pageHideResetTime:number = 0; |
| 75 | pageShowSetTime:number = 0; | 75 | pageShowSetTime:number = 0; |
| 76 | pageHideSetTime:number = 0; | 76 | pageHideSetTime:number = 0; |
| 77 | + @StorageProp('currentBreakpoint') @Watch("currentChanged")currentBreakpoint: string = 'sm'; | ||
| 78 | + private breakpointSystem = new BreakpointSystem(); | ||
| 79 | + @State percent:number = 1 | ||
| 80 | + @State topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 | ||
| 81 | + @State bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 | ||
| 82 | + | ||
| 83 | + currentChanged(){ | ||
| 84 | + if(this.currentBreakpoint == "md" || this.currentBreakpoint == "lg"){ | ||
| 85 | + this.percent = 0.7 | ||
| 86 | + }else { | ||
| 87 | + this.percent = 1 | ||
| 88 | + } | ||
| 89 | + } | ||
| 77 | 90 | ||
| 78 | onPageShow(): void { | 91 | onPageShow(): void { |
| 79 | if (this.pageType === 0){//重置密码 | 92 | if (this.pageType === 0){//重置密码 |
| @@ -83,6 +96,10 @@ export struct SettingPasswordPage { | @@ -83,6 +96,10 @@ export struct SettingPasswordPage { | ||
| 83 | } | 96 | } |
| 84 | } | 97 | } |
| 85 | 98 | ||
| 99 | + calcHeight(value:number): number{ | ||
| 100 | + return value * this.percent | ||
| 101 | + } | ||
| 102 | + | ||
| 86 | onPageHide(): void { | 103 | onPageHide(): void { |
| 87 | if (this.pageType === 0){ | 104 | if (this.pageType === 0){ |
| 88 | this.pageHideResetTime = DateTimeUtils.getTimeStamp() | 105 | this.pageHideResetTime = DateTimeUtils.getTimeStamp() |
| @@ -104,7 +121,13 @@ export struct SettingPasswordPage { | @@ -104,7 +121,13 @@ export struct SettingPasswordPage { | ||
| 104 | } | 121 | } |
| 105 | } | 122 | } |
| 106 | 123 | ||
| 124 | + aboutToDisappear(): void { | ||
| 125 | + this.breakpointSystem.unregister(); | ||
| 126 | + } | ||
| 127 | + | ||
| 107 | aboutToAppear() { | 128 | aboutToAppear() { |
| 129 | + this.breakpointSystem.register(); | ||
| 130 | + this.currentChanged() | ||
| 108 | let params:SettingPasswordParams = router.getParams() as SettingPasswordParams; | 131 | let params:SettingPasswordParams = router.getParams() as SettingPasswordParams; |
| 109 | this.pageId = parseInt(params.pageID); | 132 | this.pageId = parseInt(params.pageID); |
| 110 | this.getPageListData(this.pageId) | 133 | this.getPageListData(this.pageId) |
| @@ -147,10 +170,48 @@ export struct SettingPasswordPage { | @@ -147,10 +170,48 @@ export struct SettingPasswordPage { | ||
| 147 | } | 170 | } |
| 148 | 171 | ||
| 149 | build() { | 172 | build() { |
| 150 | - Navigation() { | ||
| 151 | - this.settingList() //滑动区域 | ||
| 152 | - }.titleMode(NavigationTitleMode.Mini) | ||
| 153 | - .title('') | 173 | + Column(){ |
| 174 | + Column(){ | ||
| 175 | + this.TitleBackComponent('') | ||
| 176 | + this.settingList() //滑动区域 | ||
| 177 | + } | ||
| 178 | + }.width("100%") | ||
| 179 | + .height("100%") | ||
| 180 | + .padding({top:px2vp(this.topSafeHeight),bottom:px2vp(this.bottomSafeHeight)}) | ||
| 181 | + | ||
| 182 | + } | ||
| 183 | + | ||
| 184 | + @Builder TitleBackComponent(title:string){ | ||
| 185 | + RelativeContainer() { | ||
| 186 | + Text(title) | ||
| 187 | + .fontColor('#FF333333') | ||
| 188 | + .fontSize(`${this.calcHeight(18)}`) | ||
| 189 | + .textAlign(TextAlign.Center) | ||
| 190 | + .height(`${this.calcHeight(44)}`) | ||
| 191 | + .alignRules({ | ||
| 192 | + top: { anchor: "__container__", align: VerticalAlign.Top }, | ||
| 193 | + left: { anchor: "__container__", align: HorizontalAlign.Start }, | ||
| 194 | + right: { anchor: "__container__", align: HorizontalAlign.End }, | ||
| 195 | + | ||
| 196 | + }) | ||
| 197 | + .id('titleContent') | ||
| 198 | + Image($r("app.media.login_back_icon")) | ||
| 199 | + .objectFit(ImageFit.Auto) | ||
| 200 | + .height(`${this.calcHeight(24)}`) | ||
| 201 | + .width(`${this.calcHeight(24)}`) | ||
| 202 | + .margin({ | ||
| 203 | + left: `${this.calcHeight(16)}`, top: `${this.calcHeight(8)}` | ||
| 204 | + }) | ||
| 205 | + .alignRules({ | ||
| 206 | + top: { anchor: "__container__", align: VerticalAlign.Top }, | ||
| 207 | + left: { anchor: "__container__", align: HorizontalAlign.Start }, | ||
| 208 | + }) | ||
| 209 | + .onClick(() => { | ||
| 210 | + router.back() | ||
| 211 | + }) | ||
| 212 | + .id('backImage') | ||
| 213 | + | ||
| 214 | + }.height(`${this.calcHeight(44)}`) | ||
| 154 | } | 215 | } |
| 155 | 216 | ||
| 156 | // 页面布局 | 217 | // 页面布局 |
| @@ -176,7 +237,7 @@ export struct SettingPasswordPage { | @@ -176,7 +237,7 @@ export struct SettingPasswordPage { | ||
| 176 | }) | 237 | }) |
| 177 | } | 238 | } |
| 178 | }.width('100%') | 239 | }.width('100%') |
| 179 | - .padding({ left:"31lpx",right:"31lpx",top:"131lpx" }) | 240 | + .padding({ left:`${this.calcHeight(31)}lpx`,right:`${this.calcHeight(31)}lpx`,top:`${this.calcHeight(131)}lpx` }) |
| 180 | .height('100%') | 241 | .height('100%') |
| 181 | } | 242 | } |
| 182 | 243 | ||
| @@ -185,10 +246,10 @@ export struct SettingPasswordPage { | @@ -185,10 +246,10 @@ export struct SettingPasswordPage { | ||
| 185 | // 标题 | 246 | // 标题 |
| 186 | @Builder getTitleCell(item: AccoutPageDataModel, alignTitle: HorizontalAlign) { | 247 | @Builder getTitleCell(item: AccoutPageDataModel, alignTitle: HorizontalAlign) { |
| 187 | Column() { | 248 | Column() { |
| 188 | - Text(item.compTitle).fontWeight(FontWeight.Bold).fontSize(20).maxLines(1) | 249 | + Text(item.compTitle).fontWeight(FontWeight.Bold).fontSize(`${this.calcHeight(20)}`).maxLines(1) |
| 189 | } | 250 | } |
| 190 | .width('100%') | 251 | .width('100%') |
| 191 | - .height('75lpx') | 252 | + .height(`${this.calcHeight(75)}lpx`) |
| 192 | .alignItems(alignTitle) | 253 | .alignItems(alignTitle) |
| 193 | } | 254 | } |
| 194 | 255 | ||
| @@ -210,12 +271,12 @@ export struct SettingPasswordPage { | @@ -210,12 +271,12 @@ export struct SettingPasswordPage { | ||
| 210 | }) | 271 | }) |
| 211 | } | 272 | } |
| 212 | .alignItems(VerticalAlign.Center) | 273 | .alignItems(VerticalAlign.Center) |
| 213 | - .height('80lpx') | 274 | + .height(`${this.calcHeight(80)}lpx`) |
| 214 | .backgroundColor('#f5f5f5') | 275 | .backgroundColor('#f5f5f5') |
| 215 | - .borderRadius('4vp') | 276 | + .borderRadius(`${this.calcHeight(4)}`) |
| 216 | } | 277 | } |
| 217 | .width('100%') | 278 | .width('100%') |
| 218 | - .height('110lpx') | 279 | + .height(`${this.calcHeight(110)}lpx`) |
| 219 | .backgroundColor(0xffffff0) | 280 | .backgroundColor(0xffffff0) |
| 220 | .alignItems(VerticalAlign.Center) | 281 | .alignItems(VerticalAlign.Center) |
| 221 | } | 282 | } |
| @@ -235,12 +296,12 @@ export struct SettingPasswordPage { | @@ -235,12 +296,12 @@ export struct SettingPasswordPage { | ||
| 235 | }) | 296 | }) |
| 236 | } | 297 | } |
| 237 | .alignItems(VerticalAlign.Center) | 298 | .alignItems(VerticalAlign.Center) |
| 238 | - .height('80lpx') | 299 | + .height(`${this.calcHeight(80)}lpx`) |
| 239 | .backgroundColor('#f5f5f5') | 300 | .backgroundColor('#f5f5f5') |
| 240 | - .borderRadius('4vp') | 301 | + .borderRadius(`${this.calcHeight(4)}`) |
| 241 | } | 302 | } |
| 242 | .width('100%') | 303 | .width('100%') |
| 243 | - .height('110lpx') | 304 | + .height(`${this.calcHeight(110)}lpx`) |
| 244 | .backgroundColor(0xffffff0) | 305 | .backgroundColor(0xffffff0) |
| 245 | .alignItems(VerticalAlign.Center) | 306 | .alignItems(VerticalAlign.Center) |
| 246 | } | 307 | } |
| @@ -249,7 +310,7 @@ export struct SettingPasswordPage { | @@ -249,7 +310,7 @@ export struct SettingPasswordPage { | ||
| 249 | @Builder getCodeCell(item: AccoutPageDataModel) { | 310 | @Builder getCodeCell(item: AccoutPageDataModel) { |
| 250 | Row() { | 311 | Row() { |
| 251 | Stack() { | 312 | Stack() { |
| 252 | - Image($r('app.media.get_code_bg')).width('100%').borderRadius('4vp') | 313 | + Image($r('app.media.get_code_bg')).width('100%').borderRadius(`${this.calcHeight(4)}`) |
| 253 | Row() { | 314 | Row() { |
| 254 | TextInput({ placeholder: item.inputPlacholder }) | 315 | TextInput({ placeholder: item.inputPlacholder }) |
| 255 | .placeholderColor("#CCCCCC") | 316 | .placeholderColor("#CCCCCC") |
| @@ -264,10 +325,10 @@ export struct SettingPasswordPage { | @@ -264,10 +325,10 @@ export struct SettingPasswordPage { | ||
| 264 | .fontColor('#da3e22') | 325 | .fontColor('#da3e22') |
| 265 | } | 326 | } |
| 266 | .width('100%') | 327 | .width('100%') |
| 267 | - }.height('80lpx') | 328 | + }.height(`${this.calcHeight(80)}lpx`) |
| 268 | } | 329 | } |
| 269 | .width('100%') | 330 | .width('100%') |
| 270 | - .height('110lpx') | 331 | + .height(`${this.calcHeight(110)}lpx`) |
| 271 | .backgroundColor(0xffffff0) | 332 | .backgroundColor(0xffffff0) |
| 272 | .alignItems(VerticalAlign.Center) | 333 | .alignItems(VerticalAlign.Center) |
| 273 | } | 334 | } |
| @@ -275,7 +336,7 @@ export struct SettingPasswordPage { | @@ -275,7 +336,7 @@ export struct SettingPasswordPage { | ||
| 275 | // desc | 336 | // desc |
| 276 | @Builder getDescCell(item: AccoutPageDataModel, alignTitle: HorizontalAlign) { | 337 | @Builder getDescCell(item: AccoutPageDataModel, alignTitle: HorizontalAlign) { |
| 277 | Column() { | 338 | Column() { |
| 278 | - Text(item.compDesc).fontSize(12).maxLines(3).fontColor(0x999999).padding({top:'10lpx'}) | 339 | + Text(item.compDesc).fontSize(`${this.calcHeight(12)}`).maxLines(3).fontColor(0x999999).padding({top:`${this.calcHeight(10)}lpx`}) |
| 279 | .onClick(()=>{ | 340 | .onClick(()=>{ |
| 280 | if (item.compDesc == '忘记密码') { | 341 | if (item.compDesc == '忘记密码') { |
| 281 | this.showToastTip('密码不符合密码规范') | 342 | this.showToastTip('密码不符合密码规范') |
| @@ -283,37 +344,39 @@ export struct SettingPasswordPage { | @@ -283,37 +344,39 @@ export struct SettingPasswordPage { | ||
| 283 | }) | 344 | }) |
| 284 | } | 345 | } |
| 285 | .width('100%') | 346 | .width('100%') |
| 286 | - .height('85lpx') | 347 | + .height(`${this.calcHeight(85)}lpx`) |
| 287 | .alignItems(alignTitle) | 348 | .alignItems(alignTitle) |
| 288 | } | 349 | } |
| 289 | 350 | ||
| 290 | // 按钮 | 351 | // 按钮 |
| 291 | @Builder getButtonCell(item: AccoutPageDataModel) { | 352 | @Builder getButtonCell(item: AccoutPageDataModel) { |
| 292 | Row() { | 353 | Row() { |
| 293 | - Button(item.compButtonTitle, { type: ButtonType.Normal, stateEffect: true }) | ||
| 294 | - .width('100%') | ||
| 295 | - .height('80lpx') | ||
| 296 | - .backgroundColor(this.btnStatus ? '#da3e22' : '#e5856d') | ||
| 297 | - .enabled(this.btnStatus ?true:false) | ||
| 298 | - .fontColor('#fff') | ||
| 299 | - .borderRadius('4vp') | 354 | + Text(item.compButtonTitle) |
| 355 | + .layoutWeight(1) | ||
| 356 | + .fontColor("#FFFFFF") | ||
| 357 | + .borderRadius(`${this.calcHeight(4)}`) | ||
| 358 | + .fontSize(`${this.calcHeight(18)}`) | ||
| 359 | + .textAlign(TextAlign.Center) | ||
| 360 | + .fontWeight(FontWeight.Medium) | ||
| 361 | + .margin({ top: `${this.calcHeight(26)}` }) | ||
| 362 | + .height(`${this.calcHeight(44)}`) | ||
| 363 | + .backgroundColor("#ED2800") | ||
| 364 | + .enabled(this.btnStatus ? true : false) | ||
| 365 | + .opacity(this.btnStatus ? 1: 0.6) | ||
| 300 | .onClick(() => { | 366 | .onClick(() => { |
| 301 | this.buttonClick() | 367 | this.buttonClick() |
| 302 | }) | 368 | }) |
| 303 | - } | ||
| 304 | - .padding({top:'25lpx'}) | ||
| 305 | - .alignItems(VerticalAlign.Center) | 369 | + }.padding({top:`${this.calcHeight(25)}lpx`}) |
| 306 | .width('100%') | 370 | .width('100%') |
| 307 | - .height('120lpx') | ||
| 308 | } | 371 | } |
| 309 | 372 | ||
| 310 | // 标题 | 373 | // 标题 |
| 311 | @Builder getLogoCell(item: AccoutPageDataModel) { | 374 | @Builder getLogoCell(item: AccoutPageDataModel) { |
| 312 | Column() { | 375 | Column() { |
| 313 | - Image(item.compLogo).height('150lpx').width('150lpx') | 376 | + Image(item.compLogo).height(`${this.calcHeight(150)}lpx`).width(`${this.calcHeight(150)}lpx`) |
| 314 | } | 377 | } |
| 315 | .width('100%') | 378 | .width('100%') |
| 316 | - .height('200lpx') | 379 | + .height(`${this.calcHeight(200)}lpx`) |
| 317 | } | 380 | } |
| 318 | 381 | ||
| 319 | /***************************** 事件处理 ******************************************/ | 382 | /***************************** 事件处理 ******************************************/ |
| @@ -24,6 +24,8 @@ struct VerifyPhoneNumberPage { | @@ -24,6 +24,8 @@ struct VerifyPhoneNumberPage { | ||
| 24 | isFirst:boolean=true//是否第一次获取验证码 | 24 | isFirst:boolean=true//是否第一次获取验证码 |
| 25 | pageShowTime:number = 0; | 25 | pageShowTime:number = 0; |
| 26 | pageHideTime:number = 0; | 26 | pageHideTime:number = 0; |
| 27 | + @State topSafeHeight: number = AppStorage.get<number>('topSafeHeight') || 0 | ||
| 28 | + @State bottomSafeHeight: number = AppStorage.get<number>('bottomSafeHeight') || 0 | ||
| 27 | 29 | ||
| 28 | onCodeSend() { | 30 | onCodeSend() { |
| 29 | if (this.isCodeSend) { | 31 | if (this.isCodeSend) { |
| @@ -60,101 +62,105 @@ struct VerifyPhoneNumberPage { | @@ -60,101 +62,105 @@ struct VerifyPhoneNumberPage { | ||
| 60 | 62 | ||
| 61 | 63 | ||
| 62 | build() { | 64 | build() { |
| 63 | - Column() { | ||
| 64 | - Image($r('app.media.login_back_icon')).width(24).height(24).margin({ left: 15, top: 10 }).onClick(() => { | ||
| 65 | - router.back() | ||
| 66 | - }) | ||
| 67 | - | ||
| 68 | - Text(this.pageTitle).fontSize(22).fontColor('#333333').fontWeight(FontWeight.Bold).margin({ left: 25, top: 112 }) | ||
| 69 | - | 65 | + Column(){ |
| 70 | Column() { | 66 | Column() { |
| 71 | - TextInput({ text: this.securityPhone(this.phoneContent) }) | ||
| 72 | - .placeholderColor("#CCCCCC") | ||
| 73 | - .fontSize(16) | ||
| 74 | - .height(48) | ||
| 75 | - .maxLength(11) | ||
| 76 | - .margin({ top: 36 }) | ||
| 77 | - .backgroundColor("#F5F5F5") | ||
| 78 | - .borderRadius(4) | ||
| 79 | - .enabled(false) | ||
| 80 | - .type(InputType.PhoneNumber) | ||
| 81 | - .onChange((content) => { | ||
| 82 | - this.phoneContent = content | ||
| 83 | - this.isSubmit = (this.phoneContent.length >= 11 && this.codeContent.length >= 4) | ||
| 84 | - if (content.length >= 11) { | ||
| 85 | - this.codeBtnState = true | ||
| 86 | - } else { | ||
| 87 | - this.codeBtnState = false | ||
| 88 | - } | ||
| 89 | - }) | 67 | + Image($r('app.media.login_back_icon')).width(24).height(24).margin({ left: 15, top: 10 }).onClick(() => { |
| 68 | + router.back() | ||
| 69 | + }) | ||
| 90 | 70 | ||
| 91 | - Row() { | ||
| 92 | - TextInput({ text: this.codeContent,placeholder: "验证码" }) | 71 | + Text(this.pageTitle).fontSize(22).fontColor('#333333').fontWeight(FontWeight.Bold).margin({ left: 25, top: 112 }) |
| 72 | + | ||
| 73 | + Column() { | ||
| 74 | + TextInput({ text: this.securityPhone(this.phoneContent) }) | ||
| 93 | .placeholderColor("#CCCCCC") | 75 | .placeholderColor("#CCCCCC") |
| 94 | - .layoutWeight(1) | ||
| 95 | .fontSize(16) | 76 | .fontSize(16) |
| 96 | .height(48) | 77 | .height(48) |
| 97 | - .type(InputType.Number) | ||
| 98 | - .fontColor("#222222") | ||
| 99 | - .backgroundColor("#00000000") | ||
| 100 | - .borderRadius({ topLeft: 4, bottomLeft: 4 }) | ||
| 101 | - .onChange((value) => { | ||
| 102 | - this.codeContent = value | 78 | + .maxLength(11) |
| 79 | + .margin({ top: 36 }) | ||
| 80 | + .backgroundColor("#F5F5F5") | ||
| 81 | + .borderRadius(4) | ||
| 82 | + .enabled(false) | ||
| 83 | + .type(InputType.PhoneNumber) | ||
| 84 | + .onChange((content) => { | ||
| 85 | + this.phoneContent = content | ||
| 103 | this.isSubmit = (this.phoneContent.length >= 11 && this.codeContent.length >= 4) | 86 | this.isSubmit = (this.phoneContent.length >= 11 && this.codeContent.length >= 4) |
| 104 | - }) | ||
| 105 | - | ||
| 106 | - Text(this.codeStateSuccess ? this.timeCount + "s" : this.isFirst?"发送验证码":'重新获取') | ||
| 107 | - .fontColor(this.codeBtnState?'#ED2800':'#80ED2800') | ||
| 108 | - .width(110) | ||
| 109 | - .fontSize(14) | ||
| 110 | - .fontWeight( FontWeight.Bold) | ||
| 111 | - .height(48) | ||
| 112 | - .textAlign(TextAlign.Center) | ||
| 113 | - .enabled(this.codeStateSuccess?false:true) | ||
| 114 | - .onClick(() => { | ||
| 115 | - if (this.phoneContent.length < 11) { | ||
| 116 | - return | 87 | + if (content.length >= 11) { |
| 88 | + this.codeBtnState = true | ||
| 89 | + } else { | ||
| 90 | + this.codeBtnState = false | ||
| 117 | } | 91 | } |
| 118 | - | ||
| 119 | - let currentTime = DateTimeUtils.getTimeStamp() | ||
| 120 | - if (currentTime - this.lastTime < 500) { | ||
| 121 | - return | ||
| 122 | - } | ||
| 123 | - this.lastTime = currentTime; | ||
| 124 | - this.isCodeSend = true | ||
| 125 | - | ||
| 126 | }) | 92 | }) |
| 127 | 93 | ||
| 128 | - | ||
| 129 | - }.margin({ top: 12 }) | ||
| 130 | - .height(48) | ||
| 131 | - .alignItems(VerticalAlign.Center) | ||
| 132 | - .justifyContent(FlexAlign.Start) | ||
| 133 | - .backgroundImage($r('app.media.code_login_bg')) | ||
| 134 | - .backgroundImageSize({width:'100%',height:48}) | 94 | + Row() { |
| 95 | + TextInput({ text: this.codeContent,placeholder: "验证码" }) | ||
| 96 | + .placeholderColor("#CCCCCC") | ||
| 97 | + .layoutWeight(1) | ||
| 98 | + .fontSize(16) | ||
| 99 | + .height(48) | ||
| 100 | + .type(InputType.Number) | ||
| 101 | + .fontColor("#222222") | ||
| 102 | + .backgroundColor("#00000000") | ||
| 103 | + .borderRadius({ topLeft: 4, bottomLeft: 4 }) | ||
| 104 | + .onChange((value) => { | ||
| 105 | + this.codeContent = value | ||
| 106 | + this.isSubmit = (this.phoneContent.length >= 11 && this.codeContent.length >= 4) | ||
| 107 | + }) | ||
| 108 | + | ||
| 109 | + Text(this.codeStateSuccess ? this.timeCount + "s" : this.isFirst?"发送验证码":'重新获取') | ||
| 110 | + .fontColor(this.codeBtnState?'#ED2800':'#80ED2800') | ||
| 111 | + .width(110) | ||
| 112 | + .fontSize(14) | ||
| 113 | + .fontWeight( FontWeight.Bold) | ||
| 114 | + .height(48) | ||
| 115 | + .textAlign(TextAlign.Center) | ||
| 116 | + .enabled(this.codeStateSuccess?false:true) | ||
| 117 | + .onClick(() => { | ||
| 118 | + if (this.phoneContent.length < 11) { | ||
| 119 | + return | ||
| 120 | + } | ||
| 121 | + | ||
| 122 | + let currentTime = DateTimeUtils.getTimeStamp() | ||
| 123 | + if (currentTime - this.lastTime < 500) { | ||
| 124 | + return | ||
| 125 | + } | ||
| 126 | + this.lastTime = currentTime; | ||
| 127 | + this.isCodeSend = true | ||
| 128 | + | ||
| 129 | + }) | ||
| 130 | + | ||
| 131 | + | ||
| 132 | + }.margin({ top: 12 }) | ||
| 133 | + .height(48) | ||
| 134 | + .alignItems(VerticalAlign.Center) | ||
| 135 | + .justifyContent(FlexAlign.Start) | ||
| 136 | + .backgroundImage($r('app.media.code_login_bg')) | ||
| 137 | + .backgroundImageSize({width:'100%',height:48}) | ||
| 135 | 138 | ||
| 136 | 139 | ||
| 137 | 140 | ||
| 138 | - }.width('100%').padding({ left: 25, right: 25 }) | 141 | + }.width('100%').padding({ left: 25, right: 25 }) |
| 139 | 142 | ||
| 140 | - Row() { | ||
| 141 | - Text("确认") | ||
| 142 | - .layoutWeight(1) | ||
| 143 | - .fontColor(this.isSubmit ?"#FFFFFFFF":"#66FFFFFF") | ||
| 144 | - .borderRadius(4) | ||
| 145 | - .fontSize(18) | ||
| 146 | - .textAlign(TextAlign.Center) | ||
| 147 | - .fontWeight(FontWeight.Medium) | ||
| 148 | - .margin({ top: 26 }) | ||
| 149 | - .height(44) | ||
| 150 | - .backgroundColor(this.isSubmit ?"#ED2800":"#99ED2800") | ||
| 151 | - .enabled(this.isSubmit ? true : false) | ||
| 152 | - .onClick(() => { | ||
| 153 | - this.checkVerifyCode() | ||
| 154 | - }) | ||
| 155 | - }.padding({ left: 25, right: 25 }).width('100%') | 143 | + Row() { |
| 144 | + Text("确认") | ||
| 145 | + .layoutWeight(1) | ||
| 146 | + .fontColor(this.isSubmit ?"#FFFFFFFF":"#66FFFFFF") | ||
| 147 | + .borderRadius(4) | ||
| 148 | + .fontSize(18) | ||
| 149 | + .textAlign(TextAlign.Center) | ||
| 150 | + .fontWeight(FontWeight.Medium) | ||
| 151 | + .margin({ top: 26 }) | ||
| 152 | + .height(44) | ||
| 153 | + .backgroundColor(this.isSubmit ?"#ED2800":"#99ED2800") | ||
| 154 | + .enabled(this.isSubmit ? true : false) | ||
| 155 | + .onClick(() => { | ||
| 156 | + this.checkVerifyCode() | ||
| 157 | + }) | ||
| 158 | + }.padding({ left: 25, right: 25 }).width('100%') | ||
| 156 | 159 | ||
| 157 | - }.width('100%').height('100%').alignItems(HorizontalAlign.Start) | 160 | + }.width('100%').height('100%').alignItems(HorizontalAlign.Start) |
| 161 | + }.width("100%") | ||
| 162 | + .height("100%") | ||
| 163 | + .padding({top:px2vp(this.topSafeHeight),bottom:px2vp(this.bottomSafeHeight)}) | ||
| 158 | } | 164 | } |
| 159 | 165 | ||
| 160 | //发送验证码 | 166 | //发送验证码 |
| @@ -23,7 +23,7 @@ struct MorningEveningPaperPage { | @@ -23,7 +23,7 @@ struct MorningEveningPaperPage { | ||
| 23 | PageTransitionEnter({ type: RouteType.Push, duration: 300 }) | 23 | PageTransitionEnter({ type: RouteType.Push, duration: 300 }) |
| 24 | .slide(SlideEffect.Bottom).onEnter((type: RouteType, progress: number) => { | 24 | .slide(SlideEffect.Bottom).onEnter((type: RouteType, progress: number) => { |
| 25 | if (progress >= 0.99) { | 25 | if (progress >= 0.99) { |
| 26 | - WindowModel.shared.setWindowLayoutFullScreen(true) | 26 | + // WindowModel.shared.setWindowLayoutFullScreen(true) |
| 27 | WindowModel.shared.setWindowSystemBarProperties({ statusBarContentColor: '#ffffff', }) | 27 | WindowModel.shared.setWindowSystemBarProperties({ statusBarContentColor: '#ffffff', }) |
| 28 | } | 28 | } |
| 29 | }) | 29 | }) |
| @@ -43,14 +43,14 @@ struct MorningEveningPaperPage { | @@ -43,14 +43,14 @@ struct MorningEveningPaperPage { | ||
| 43 | onPageShow() { | 43 | onPageShow() { |
| 44 | Logger.info(TAG, 'onPageShow'); | 44 | Logger.info(TAG, 'onPageShow'); |
| 45 | if (this.isPageShow) { | 45 | if (this.isPageShow) { |
| 46 | - WindowModel.shared.setWindowLayoutFullScreen(true) | 46 | + // WindowModel.shared.setWindowLayoutFullScreen(true) |
| 47 | WindowModel.shared.setWindowSystemBarProperties({ statusBarContentColor: '#ffffff', }) | 47 | WindowModel.shared.setWindowSystemBarProperties({ statusBarContentColor: '#ffffff', }) |
| 48 | } | 48 | } |
| 49 | this.pageShowTime = DateTimeUtils.getTimeStamp() | 49 | this.pageShowTime = DateTimeUtils.getTimeStamp() |
| 50 | } | 50 | } |
| 51 | 51 | ||
| 52 | onPageHide() { | 52 | onPageHide() { |
| 53 | - WindowModel.shared.setWindowLayoutFullScreen(false) | 53 | + // WindowModel.shared.setWindowLayoutFullScreen(false) |
| 54 | WindowModel.shared.setWindowSystemBarProperties({ statusBarContentColor: '#000000', }) | 54 | WindowModel.shared.setWindowSystemBarProperties({ statusBarContentColor: '#000000', }) |
| 55 | this.isPageShow = true | 55 | this.isPageShow = true |
| 56 | Logger.info(TAG, 'onPageHide'); | 56 | Logger.info(TAG, 'onPageHide'); |
| @@ -48,7 +48,6 @@ struct MultiPictureDetailPage { | @@ -48,7 +48,6 @@ struct MultiPictureDetailPage { | ||
| 48 | } | 48 | } |
| 49 | 49 | ||
| 50 | aboutToAppear() { | 50 | aboutToAppear() { |
| 51 | - this.openFullScreen() | ||
| 52 | 51 | ||
| 53 | Logger.info(TAG, 'aboutToDisappear'); | 52 | Logger.info(TAG, 'aboutToDisappear'); |
| 54 | 53 | ||
| @@ -68,13 +67,11 @@ struct MultiPictureDetailPage { | @@ -68,13 +67,11 @@ struct MultiPictureDetailPage { | ||
| 68 | 67 | ||
| 69 | aboutToDisappear(): void { | 68 | aboutToDisappear(): void { |
| 70 | console.log(TAG, 'aboutToDisappear') | 69 | console.log(TAG, 'aboutToDisappear') |
| 71 | - this.closeFullScreen() | ||
| 72 | } | 70 | } |
| 73 | 71 | ||
| 74 | onPageShow(): void { | 72 | onPageShow(): void { |
| 75 | console.log(TAG, 'onPageShow') | 73 | console.log(TAG, 'onPageShow') |
| 76 | this.pageShowTime = DateTimeUtils.getTimeStamp() | 74 | this.pageShowTime = DateTimeUtils.getTimeStamp() |
| 77 | - this.openFullScreen() | ||
| 78 | 75 | ||
| 79 | } | 76 | } |
| 80 | 77 | ||
| @@ -84,25 +81,7 @@ struct MultiPictureDetailPage { | @@ -84,25 +81,7 @@ struct MultiPictureDetailPage { | ||
| 84 | let duration = 0 | 81 | let duration = 0 |
| 85 | duration = Math.floor((this.pageHideTime - this.pageShowTime)/1000) | 82 | duration = Math.floor((this.pageHideTime - this.pageShowTime)/1000) |
| 86 | TrackingPageBrowse.trackCommonPageExposureEnd(TrackConstants.PageName.Atlas_Detail,TrackConstants.PageName.Atlas_Detail,duration) | 83 | TrackingPageBrowse.trackCommonPageExposureEnd(TrackConstants.PageName.Atlas_Detail,TrackConstants.PageName.Atlas_Detail,duration) |
| 87 | - this.closeFullScreen() | ||
| 88 | } | 84 | } |
| 89 | 85 | ||
| 90 | - /** | ||
| 91 | - * 开启沉浸式 | ||
| 92 | - * TODO:颜色待根据业务接口修改 | ||
| 93 | - */ | ||
| 94 | - openFullScreen() { | ||
| 95 | - WindowModel.shared.setWindowLayoutFullScreen(true) | ||
| 96 | - WindowModel.shared.setWindowSystemBarProperties({ statusBarContentColor: '#ffffff', }) | ||
| 97 | - } | ||
| 98 | - | ||
| 99 | - /** | ||
| 100 | - * 关闭沉浸式 | ||
| 101 | - * TODO:颜色待根据业务接口修改 | ||
| 102 | - */ | ||
| 103 | - closeFullScreen() { | ||
| 104 | - WindowModel.shared.setWindowLayoutFullScreen(false) | ||
| 105 | - WindowModel.shared.setWindowSystemBarProperties({ statusBarContentColor: '#000000', }) | ||
| 106 | - } | ||
| 107 | 86 | ||
| 108 | } | 87 | } |
| @@ -7,6 +7,7 @@ import LaunchDataModel, { defaultLaunchModel } from '../viewModel/LaunchDataMode | @@ -7,6 +7,7 @@ import LaunchDataModel, { defaultLaunchModel } from '../viewModel/LaunchDataMode | ||
| 7 | 7 | ||
| 8 | import { ParamType, TrackConstants, TrackingButton, TrackingContent } from 'wdTracking/Index'; | 8 | import { ParamType, TrackConstants, TrackingButton, TrackingContent } from 'wdTracking/Index'; |
| 9 | import { ContentDTO } from 'wdBean/Index'; | 9 | import { ContentDTO } from 'wdBean/Index'; |
| 10 | +import { Core } from '@ohos/hypium'; | ||
| 10 | 11 | ||
| 11 | 12 | ||
| 12 | @Entry | 13 | @Entry |
| @@ -62,7 +63,7 @@ struct LaunchAdvertisingPage { | @@ -62,7 +63,7 @@ struct LaunchAdvertisingPage { | ||
| 62 | }else { | 63 | }else { |
| 63 | //显示图片 | 64 | //显示图片 |
| 64 | Image(this.defaultModel.bootScreenUrl) | 65 | Image(this.defaultModel.bootScreenUrl) |
| 65 | - .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM]) | 66 | + // .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM]) |
| 66 | .width('100%') | 67 | .width('100%') |
| 67 | .height('100%') | 68 | .height('100%') |
| 68 | } | 69 | } |
| @@ -74,11 +75,10 @@ struct LaunchAdvertisingPage { | @@ -74,11 +75,10 @@ struct LaunchAdvertisingPage { | ||
| 74 | bottom: 0 | 75 | bottom: 0 |
| 75 | }) | 76 | }) |
| 76 | 77 | ||
| 77 | - | ||
| 78 | Stack(){ | 78 | Stack(){ |
| 79 | Column(){ | 79 | Column(){ |
| 80 | Row(){ | 80 | Row(){ |
| 81 | - if (this.defaultModel.isAd === '1') { | 81 | + if (this.defaultModel.isAd == '1') { |
| 82 | Text('广告') | 82 | Text('广告') |
| 83 | .fontColor(Color.White) | 83 | .fontColor(Color.White) |
| 84 | .textAlign(TextAlign.Center) | 84 | .textAlign(TextAlign.Center) |
| @@ -108,7 +108,7 @@ struct LaunchAdvertisingPage { | @@ -108,7 +108,7 @@ struct LaunchAdvertisingPage { | ||
| 108 | this.trackingLaunchJumpOver() | 108 | this.trackingLaunchJumpOver() |
| 109 | }).margin({right:16}) | 109 | }).margin({right:16}) |
| 110 | 110 | ||
| 111 | - }.margin({top:10}).width('100%').height('56lpx') | 111 | + }.margin({top:50}).width('100%').height('56lpx') |
| 112 | 112 | ||
| 113 | Blank() | 113 | Blank() |
| 114 | 114 | ||
| @@ -132,18 +132,21 @@ struct LaunchAdvertisingPage { | @@ -132,18 +132,21 @@ struct LaunchAdvertisingPage { | ||
| 132 | .margin({ | 132 | .margin({ |
| 133 | bottom: '51lpx' | 133 | bottom: '51lpx' |
| 134 | }) | 134 | }) |
| 135 | + .borderWidth(1) | ||
| 136 | + .borderColor(Color.White) | ||
| 135 | .backgroundColor('#80000000') | 137 | .backgroundColor('#80000000') |
| 136 | .onClick(()=>{ | 138 | .onClick(()=>{ |
| 137 | this.action() | 139 | this.action() |
| 138 | }) | 140 | }) |
| 139 | } | 141 | } |
| 140 | - if(this.defaultModel.screenType === '1') { | 142 | + if(this.defaultModel.screenType == '1') { |
| 141 | Column(){ | 143 | Column(){ |
| 142 | Image($r('app.media.LaunchPage_logo')) | 144 | Image($r('app.media.LaunchPage_logo')) |
| 143 | .width('278lpx') | 145 | .width('278lpx') |
| 144 | .height('154lpx') | 146 | .height('154lpx') |
| 145 | .margin({top:20}) | 147 | .margin({top:20}) |
| 146 | - }.width('100%').height('16%').backgroundColor(Color.White).expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM]) | 148 | + }.width('100%').height('16%').backgroundColor(Color.White) |
| 149 | + // .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM]) | ||
| 147 | } | 150 | } |
| 148 | } | 151 | } |
| 149 | .width('100%') | 152 | .width('100%') |
| @@ -157,7 +160,7 @@ struct LaunchAdvertisingPage { | @@ -157,7 +160,7 @@ struct LaunchAdvertisingPage { | ||
| 157 | .height('100%') | 160 | .height('100%') |
| 158 | .margin({top:'0'}) | 161 | .margin({top:'0'}) |
| 159 | } | 162 | } |
| 160 | - .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM]) | 163 | + // .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM]) |
| 161 | .width('100%') | 164 | .width('100%') |
| 162 | .height('100%') | 165 | .height('100%') |
| 163 | .backgroundColor(Color.White) | 166 | .backgroundColor(Color.White) |
| @@ -212,7 +215,7 @@ struct LaunchAdvertisingPage { | @@ -212,7 +215,7 @@ struct LaunchAdvertisingPage { | ||
| 212 | this.defaultModel.screenName = dataModel.launchAdInfo[0].matInfo.advTitle | 215 | this.defaultModel.screenName = dataModel.launchAdInfo[0].matInfo.advTitle |
| 213 | this.defaultModel.durations = dataModel.launchAdInfo[0].displayDuration | 216 | this.defaultModel.durations = dataModel.launchAdInfo[0].displayDuration |
| 214 | this.defaultModel.linkUrl = dataModel.launchAdInfo[0].matInfo.linkUrl | 217 | this.defaultModel.linkUrl = dataModel.launchAdInfo[0].matInfo.linkUrl |
| 215 | - if (dataModel.launchAdInfo[0].matInfo.startStyle === '1') { | 218 | + if (dataModel.launchAdInfo[0].matInfo.startStyle == '1') { |
| 216 | this.defaultModel.screenType = '2' | 219 | this.defaultModel.screenType = '2' |
| 217 | }else { | 220 | }else { |
| 218 | this.defaultModel.screenType = '1' | 221 | this.defaultModel.screenType = '1' |
| 1 | import { insightIntent, InsightIntentExecutor } from '@kit.AbilityKit'; | 1 | import { insightIntent, InsightIntentExecutor } from '@kit.AbilityKit'; |
| 2 | import { window } from '@kit.ArkUI'; | 2 | import { window } from '@kit.ArkUI'; |
| 3 | import { BusinessError } from '@kit.BasicServicesKit'; | 3 | import { BusinessError } from '@kit.BasicServicesKit'; |
| 4 | +import { NetworkUtil, SPHelper, ToastUtils } from 'wdKit'; | ||
| 4 | import { ProcessUtils } from 'wdRouter'; | 5 | import { ProcessUtils } from 'wdRouter'; |
| 6 | +import DailyPaperTopicModel from 'wdComponent/src/main/ets/model/DailyPaperTopicModel' | ||
| 7 | + | ||
| 5 | /** | 8 | /** |
| 6 | * 意图调用 | 9 | * 意图调用 |
| 7 | */ | 10 | */ |
| @@ -19,7 +22,7 @@ export default class InsightIntentExecutorImpl extends InsightIntentExecutor { | @@ -19,7 +22,7 @@ export default class InsightIntentExecutorImpl extends InsightIntentExecutor { | ||
| 19 | */ | 22 | */ |
| 20 | onExecuteInUIAbilityForegroundMode(name: string, param: Record<string, Object>, pageLoader: window.WindowStage): | 23 | onExecuteInUIAbilityForegroundMode(name: string, param: Record<string, Object>, pageLoader: window.WindowStage): |
| 21 | Promise<insightIntent.ExecuteResult> { | 24 | Promise<insightIntent.ExecuteResult> { |
| 22 | - console.log('yzl onExecuteInUIAbilityForegroundMode',name,JSON.stringify(param)) | 25 | + console.log('yzl onExecuteInUIAbilityForegroundMode', name, JSON.stringify(param)) |
| 23 | // 根据意图名称分发处理逻辑 | 26 | // 根据意图名称分发处理逻辑 |
| 24 | switch (name) { | 27 | switch (name) { |
| 25 | case InsightIntentExecutorImpl.ViewBlog: | 28 | case InsightIntentExecutorImpl.ViewBlog: |
| @@ -36,19 +39,19 @@ export default class InsightIntentExecutorImpl extends InsightIntentExecutor { | @@ -36,19 +39,19 @@ export default class InsightIntentExecutorImpl extends InsightIntentExecutor { | ||
| 36 | } | 39 | } |
| 37 | } as insightIntent.ExecuteResult) | 40 | } as insightIntent.ExecuteResult) |
| 38 | } | 41 | } |
| 42 | + | ||
| 39 | /** | 43 | /** |
| 40 | * 实现习惯推荐功能 | 44 | * 实现习惯推荐功能 |
| 41 | * @param param 意图参数 | 45 | * @param param 意图参数 |
| 42 | * @param pageLoader 窗口 | 46 | * @param pageLoader 窗口 |
| 43 | */ | 47 | */ |
| 44 | - private jumpToViewBlog(param: Record<string, Object>, pageLoader: window.WindowStage): Promise<insightIntent.ExecuteResult> { | ||
| 45 | - console.log('yzl jumpToView',JSON.stringify(param)) | 48 | + private jumpToViewBlog(param: Record<string, Object>, |
| 49 | + pageLoader: window.WindowStage): Promise<insightIntent.ExecuteResult> { | ||
| 50 | + console.log('yzl jumpToView', JSON.stringify(param)) | ||
| 46 | return new Promise((resolve, reject) => { | 51 | return new Promise((resolve, reject) => { |
| 47 | - // TODO 实现意图调用,loadContent的入参为歌曲落地页路径,例如:pages/SongPage | ||
| 48 | // TODO 热启动是否切到主页 | 52 | // TODO 热启动是否切到主页 |
| 49 | pageLoader.loadContent('pages/MainPage') | 53 | pageLoader.loadContent('pages/MainPage') |
| 50 | .then(() => { | 54 | .then(() => { |
| 51 | - | ||
| 52 | resolve({ | 55 | resolve({ |
| 53 | code: 0, | 56 | code: 0, |
| 54 | result: { | 57 | result: { |
| @@ -72,12 +75,26 @@ export default class InsightIntentExecutorImpl extends InsightIntentExecutor { | @@ -72,12 +75,26 @@ export default class InsightIntentExecutorImpl extends InsightIntentExecutor { | ||
| 72 | * @param param 意图参数 | 75 | * @param param 意图参数 |
| 73 | * @param pageLoader 窗口 | 76 | * @param pageLoader 窗口 |
| 74 | */ | 77 | */ |
| 75 | - private jumpToViewColumnUpdate(param: Record<string, Object>, pageLoader: window.WindowStage): Promise<insightIntent.ExecuteResult> { | ||
| 76 | - console.log('yzl jumpToViewColum',JSON.stringify(param)) | 78 | + private jumpToViewColumnUpdate(param: Record<string, Object>, |
| 79 | + pageLoader: window.WindowStage): Promise<insightIntent.ExecuteResult> { | ||
| 77 | return new Promise((resolve, reject) => { | 80 | return new Promise((resolve, reject) => { |
| 78 | pageLoader.loadContent('pages/MainPage') | 81 | pageLoader.loadContent('pages/MainPage') |
| 79 | .then(() => { | 82 | .then(() => { |
| 80 | - ProcessUtils.gotoMorningEveningPaper() | 83 | + if (NetworkUtil.isNetConnected()) { |
| 84 | + DailyPaperTopicModel.getDailyPaperTopic().then(dailyPaperTopicBean => { | ||
| 85 | + if (dailyPaperTopicBean && dailyPaperTopicBean.id > 0) { | ||
| 86 | + SPHelper.default.saveSync('dailyPaperTopicPageId', dailyPaperTopicBean.id); | ||
| 87 | + ProcessUtils.gotoMorningEveningPaper() //跳转至早晚报页面 | ||
| 88 | + } else { | ||
| 89 | + ToastUtils.showToast('暂无早晚报信息', 1000) | ||
| 90 | + } | ||
| 91 | + }).catch((err: string) => { | ||
| 92 | + console.log('yzlerr',JSON.stringify(err)) | ||
| 93 | + ToastUtils.showToast('暂无早晚报信息', 1000) | ||
| 94 | + }) | ||
| 95 | + } else { | ||
| 96 | + ToastUtils.showToast('网络出小差了,请检查网络后重试', 1000) | ||
| 97 | + } | ||
| 81 | resolve({ | 98 | resolve({ |
| 82 | code: 0, | 99 | code: 0, |
| 83 | result: { | 100 | result: { |
-
Please register or login to post a comment