/*
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import ScreenUtil from '../common/util/ScreenUtil';
import { HomeConstants } from '../common/constants/HomeConstants';
import { CommonConstants } from '../common/constants/CommonConstants';
import { HomeTabContent } from '../view/HomeTabContent';
@Entry
@Component
struct HomePage {
@State currentIndex: number = HomeConstants.CURRENT_INDEX;
private controller: TabsController = new TabsController();
async aboutToAppear() {
ScreenUtil.setScreenSize(this.getUIContext());
}
@Builder TabBuilder(index: number, name: Resource) {
Column() {
Text(name)
.fontColor(this.currentIndex === index ?
$r('app.color.index_tab_selected_font_color') : $r('app.color.index_tab_font_color'))
.fontSize($r('app.float.home_page_font_size'))
.fontWeight(this.currentIndex === index ? HomeConstants.FONT_WEIGHT_SELECT : HomeConstants.FONT_WEIGHT_UNSELECT)
.lineHeight(HomeConstants.LINE_HEIGHT)
.margin({
top: HomeConstants.MARGIN_TOP_TWO,
bottom: HomeConstants.MARGIN_BOTTOM
})
Divider()
.strokeWidth(HomeConstants.STROKE_WIDTH)
.color($r('app.color.index_tab_selected_font_color'))
.opacity(this.currentIndex === index ? HomeConstants.TAB_BAR_SECOND : HomeConstants.TAB_BAR_FIRST)
}
.width(CommonConstants.FULL_PERCENT)
}
build() {
Column() {
Tabs({ barPosition: BarPosition.Start, controller: this.controller }) {
TabContent() {
HomeTabContent({ currIndex: HomeConstants.TAB_BAR_FIRST });
}.tabBar(this.TabBuilder(HomeConstants.TAB_BAR_FIRST, $r('app.string.index_tab_local_video')))
TabContent() {
HomeTabContent({ currIndex: HomeConstants.TAB_BAR_SECOND });
}.tabBar(this.TabBuilder(HomeConstants.TAB_BAR_SECOND, $r('app.string.index_tab_internet_video')))
}
.vertical(false)
.barMode(BarMode.Fixed)
.barWidth(HomeConstants.BAR_WIDTH)
.barHeight(HomeConstants.BAR_HEIGHT)
.onChange((index: number) => {
this.currentIndex = index;
})
.width(CommonConstants.FULL_PERCENT)
.height(CommonConstants.FULL_PERCENT)
.margin({ top: $r('app.float.home_tab_margin_top') })
}
.width(CommonConstants.FULL_PERCENT)
.height(CommonConstants.FULL_PERCENT)
.backgroundColor($r('app.color.index_background'))
}
}