/*
* Copyright (c) 2025 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 router from '@ohos.router';
class TextList {
public id: number;
public text: string;
public url: string;
constructor(id: number, text: string, url: string) {
this.id = id;
this.text = text;
this.url = url;
}
}
@Entry
@Component
struct struct_index {
scroll: Scroller = new Scroller()
@State arr: TextList[] = [
new TextList(1, '01-style', 'pages/01-style/Index',),
new TextList(2, '02-layout', 'pages/02-layout/Index',),
new TextList(3, '03-menuHandleSelect', 'pages/03-menuHandleSelect/Index',),
new TextList(5, '05-focusKeyboard', 'pages/05-focusKeyboard/Index',),
new TextList(6, '06-password', 'pages/06-password/Index',),
new TextList(7, '07-content', 'pages/07-content/Index',),
new TextList(8, '08-event', 'pages/08-event/Index',),
new TextList(9, '09-font', 'pages/09-font/Index',),
]
@State fontSize: Resource | undefined = undefined
build() {
Column() {
Scroll(this.scroll) {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
ForEach(this.arr, (item: TextList) => {
Button(item.text)
.width(300)
.height(50)
.margin(10)
.padding({ top: 5, bottom: 5 })
.onClick(() => {
router.pushUrl({ url: item.url })
})
}, (item: TextList) => JSON.stringify(item.id))
}
.width('100%')
}
.scrollBar(BarState.Off)
}
}
}