From 59b4783094664c804af0a819a4c7539113e5c991 Mon Sep 17 00:00:00 2001 From: samarinsergey Date: Mon, 11 Mar 2024 18:07:01 +0300 Subject: [PATCH] [HOS-2080] apply theme to TextInput component --- .../components/ComponentsNavigationPage.ets | 4 + .../ets/pages/components/TextInputPage.ets | 103 ++++++++++++++++++ .../resources/base/profile/main_pages.json | 1 + 3 files changed, 108 insertions(+) create mode 100644 theme/ThemeDemo/entry/src/main/ets/pages/components/TextInputPage.ets diff --git a/theme/ThemeDemo/entry/src/main/ets/pages/components/ComponentsNavigationPage.ets b/theme/ThemeDemo/entry/src/main/ets/pages/components/ComponentsNavigationPage.ets index 59dc7a4..b4f7b5b 100644 --- a/theme/ThemeDemo/entry/src/main/ets/pages/components/ComponentsNavigationPage.ets +++ b/theme/ThemeDemo/entry/src/main/ets/pages/components/ComponentsNavigationPage.ets @@ -66,6 +66,10 @@ struct ComponentsNavigationPage { title: 'Slider', page: 'pages/components/SliderThemePage' }, + { + title: 'TextInput', + page: 'pages/components/TextInputPage' + }, { title: 'TextPicker', page: 'pages/components/TextPickerPage' diff --git a/theme/ThemeDemo/entry/src/main/ets/pages/components/TextInputPage.ets b/theme/ThemeDemo/entry/src/main/ets/pages/components/TextInputPage.ets new file mode 100644 index 0000000..859fedc --- /dev/null +++ b/theme/ThemeDemo/entry/src/main/ets/pages/components/TextInputPage.ets @@ -0,0 +1,103 @@ +class TextInputPageGreenColors implements CustomColors { + fontPrimary = '#ff049404' + fontSecondary = '#ff859d85' + interactiveFocus = '#ff7c10f5' + interactivePressed = '#ffacd7bc' + compBackgroundTertiary = '#ffdcfae6' +} + +class TextInputPageRedColors implements CustomColors { + fontPrimary = '#fff32b3c' + fontSecondary = '#ffe29393' + interactiveFocus = '#ff7c10f5' + interactivePressed = '#ffe7b3b3' + compBackgroundTertiary = '#fffcd5d5' +} + +class TextInputPageCustomTheme implements CustomTheme { + colors?: CustomColors + + constructor(colors: CustomColors) { + this.colors = colors + } +} + +@Entry +@Component +struct TextInputPage { + @State textDefault: string = '' + @State textInline: string = '' + @State textPassword: string = '' + + static readonly themeCount = 3 + themeNames: string[] = ['System', 'Custom (green)', 'Custom (red)'] + themeArray: (CustomTheme | undefined)[] = [ + undefined, // System + new TextInputPageCustomTheme(new TextInputPageGreenColors()), + new TextInputPageCustomTheme(new TextInputPageRedColors()) + ] + @State themeIndex: number = 0 + + build() { + Column() { + Column({ space: '8vp' }) { + Text(`Current theme: ${this.themeNames[this.themeIndex]}`) + Button('Change Theme') + .onClick(() => { + this.themeIndex = (this.themeIndex + 1) % TextInputPage.themeCount + }) + } + .margin({ + top: '50vp' + }) + + // Case 1 + Text(`Style = Default`) + .margin({ left: '20vp', top: '50vp' }) + .alignSelf(ItemAlign.Start) + WithTheme(this.themeArray[this.themeIndex]) { + TextInput({ placeholder: 'Type text here' }) + .margin({ left: '20vp', right: '20vp', top: '10vp'}) + .onChange((value: string) => { + this.textDefault = value + }) + } + Text(`Text: ${this.textDefault}`) + .margin({ left: '20vp', top: '10vp' }) + .alignSelf(ItemAlign.Start) + + // Case 2 + Text(`Style = Default, Type = Password`) + .margin({ left: '20vp', top: '50vp' }) + .alignSelf(ItemAlign.Start) + WithTheme(this.themeArray[this.themeIndex]) { + TextInput({ placeholder: 'Type text here' }) + .margin({ left: '20vp', right: '20vp', top: '10vp'}) + .onChange((value: string) => { + this.textPassword = value + }) + .type(InputType.Password) + } + Text(`Text: ${this.textPassword}`) + .margin({ left: '20vp', top: '10vp' }) + .alignSelf(ItemAlign.Start) + + // Case 3 + Text(`Style = Inline`) + .margin({ left: '20vp', top: '50vp' }) + .alignSelf(ItemAlign.Start) + WithTheme(this.themeArray[this.themeIndex]) { + TextInput({ placeholder: 'Type text here' }) + .style(TextInputStyle.Inline) + .margin({ left: '20vp', right: '20vp', top: '10vp'}) + .onChange((value: string) => { + this.textInline = value + }) + } + Text(`Text: ${this.textInline}`) + .margin({ left: '20vp', top: '10vp' }) + .alignSelf(ItemAlign.Start) + } + .width('100%') + } +} \ No newline at end of file diff --git a/theme/ThemeDemo/entry/src/main/resources/base/profile/main_pages.json b/theme/ThemeDemo/entry/src/main/resources/base/profile/main_pages.json index dfce256..7007932 100644 --- a/theme/ThemeDemo/entry/src/main/resources/base/profile/main_pages.json +++ b/theme/ThemeDemo/entry/src/main/resources/base/profile/main_pages.json @@ -34,6 +34,7 @@ "pages/components/SearchPage", "pages/components/SelectPage", "pages/components/SliderThemePage", + "pages/components/TextInputPage", "pages/components/TextPickerPage", "pages/components/TimePickerPage", "pages/components/TogglePage", -- Gitee