From 774428a6f7acbb5a88c45ac67d5141048a456bb9 Mon Sep 17 00:00:00 2001 From: feng <1362134550@qq.com> Date: Wed, 24 Jul 2024 16:17:02 +0800 Subject: [PATCH] =?UTF-8?q?=E4=B8=80=E5=A4=9Ahsp=E6=94=B9har?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- AppScope/resources/base/media/app_icon.png | Bin 2041 -> 2777 bytes README.md | 10 +- commons/basic/Index.ets | 11 +- commons/basic/hvigorfile.ts | 4 +- .../main/ets/constants/CommonConstants.ets | 5 + .../main/ets/constants/RouterConstants.ets | 10 +- commons/basic/src/main/ets/utils/Logger.ets | 47 +++ commons/basic/src/main/module.json5 | 5 +- features/fund/Index.ets | 3 + features/fund/hvigorfile.ts | 4 +- .../src/main/ets/view/DetailComponent.ets | 28 +- .../fund/src/main/ets/view/FundComponent.ets | 78 ++-- .../main/ets/view/FundNavigationComponent.ets | 72 ++-- .../src/main/ets/{pages => view}/Funding.ets | 136 ++++--- .../ets/{pages => view}/FundingDetail.ets | 150 ++++---- .../main/ets/{pages => view}/TrendsPage.ets | 363 +++++++++--------- .../main/ets/viewmodel/FundingViewModel.ets | 10 +- features/fund/src/main/module.json5 | 6 +- .../main/resources/base/element/color.json | 2 +- .../main/resources/base/element/float.json | 4 +- .../resources/base/profile/main_pages.json | 6 +- features/fundComparison/Index.ets | 7 +- features/fundComparison/hvigorfile.ts | 4 +- .../src/main/ets/view/ComparisonComponent.ets | 17 +- .../ets/view/ComparisonDetailComponent.ets | 22 +- .../{pages => view}/ComparisonDetailPage.ets | 11 +- features/fundComparison/src/main/module.json5 | 6 +- .../main/resources/base/element/color.json | 2 +- .../main/resources/base/element/float.json | 6 +- .../resources/base/profile/main_pages.json | 6 - features/home/Index.ets | 5 +- features/home/hvigorfile.ts | 4 +- .../src/main/ets/constants/HomeConstants.ets | 4 +- .../src/main/ets/view/AccountComponent.ets | 23 +- .../main/ets/{pages => view}/AccountPage.ets | 5 +- .../main/ets/view/DemandDepositComponent.ets | 8 +- .../home/src/main/ets/view/HomeComponent.ets | 22 +- .../main/ets/view/LiabilitiesComponent.ets | 214 +++++------ .../src/main/ets/viewmodel/HomeViewModel.ets | 20 +- features/home/src/main/module.json5 | 6 +- .../main/resources/base/element/color.json | 4 +- .../resources/base/profile/main_pages.json | 6 - features/transaction/Index.ets | 2 +- features/transaction/hvigorfile.ts | 4 +- .../main/ets/view/TransactionComponent.ets | 16 +- features/transaction/src/main/module.json5 | 5 +- oh-package.json5 | 1 - product/phone/oh-package.json5 | 4 +- .../main/ets/entryability/EntryAbility.ets | 26 +- product/phone/src/main/ets/pages/Index.ets | 192 +++++---- product/phone/src/main/module.json5 | 2 +- .../main/resources/base/media/background.png | Bin 0 -> 57364 bytes .../main/resources/base/media/foreground.png | Bin 0 -> 12430 bytes .../resources/base/media/layered_image.json | 7 + .../main/resources/base/media/startIcon.png | Bin 4351 -> 20093 bytes screenshots/device/config.png | Bin 29903 -> 0 bytes 56 files changed, 870 insertions(+), 745 deletions(-) create mode 100644 commons/basic/src/main/ets/utils/Logger.ets rename features/fund/src/main/ets/{pages => view}/Funding.ets (36%) rename features/fund/src/main/ets/{pages => view}/FundingDetail.ets (40%) rename features/fund/src/main/ets/{pages => view}/TrendsPage.ets (36%) rename features/fundComparison/src/main/ets/{pages => view}/ComparisonDetailPage.ets (73%) delete mode 100644 features/fundComparison/src/main/resources/base/profile/main_pages.json rename features/home/src/main/ets/{pages => view}/AccountPage.ets (94%) delete mode 100644 features/home/src/main/resources/base/profile/main_pages.json create mode 100644 product/phone/src/main/resources/base/media/background.png create mode 100644 product/phone/src/main/resources/base/media/foreground.png create mode 100644 product/phone/src/main/resources/base/media/layered_image.json delete mode 100644 screenshots/device/config.png diff --git a/AppScope/resources/base/media/app_icon.png b/AppScope/resources/base/media/app_icon.png index cd45accb1dfd2fd0da16c732c72faa6e46b26521..a39445dc87828b76fed6d2ec470dd455c45319e3 100644 GIT binary patch delta 2769 zcmV;?3NH2e57`xvB!2{FK}|sb0I`n?{9y$E001~;SV?A0O#mtY000O80f%V-1ONa4 z0RR918UO$Q0007@0ssU600031001eV0{{d700031001cf0002v=%!@=018Y=L_t(o z33ZuGs9jeT$M-qszOVRdLRyn*Yty`%5Ze-{Ng-59g9CLEX@5t7iZcg=qN74U#DNnD z1Se7u4fs(|1ivr?9ayP|B3iYCD$mfQCQ{S1n2)}^yxe#1J=_0pt-a1UPwQ^Z*?X_` zUu*sM+8<}X+baE^a`3seUF}?bEaiMOrD`Qrd5@qw^epHZ>Df|p-qKBUEB%*?!m0{P zHC6j|RplEgSAQ4vToCA`&D5Sbf9j66wtDfNnGF>OpUdybbGJ_Bls_vugx<9bNjV{4 zB1I)-N2()_P95tL)_P{+;54psb$Y(qcH-=*Y8^LGwvc@I3pWqS_6JfP2mmz!tAccL zB}hlW(XJa>x>01)2a!F)=GPr;$#_bub(N0){nYZ=@PE{iEChcq#S+ROHVkZS=U41Y zcC05w0rxhpACd^7)K)sDy%( zO{OR!*c+RqOS~GUGoa%b2*qvGuBz2-_0nOczBUDGFb6@5j9zNZE7?$A9h2)t?HO^b z6T-&j*nc^;;M8f&uJ>W9v!7G|7enadv4}~*8q_h%tD^j$7=PC znn0=dR0GKA(fgb9`2IRg6ksBIo+y0ewn?nD0ysgLnimC&<;%Y>Sa>s7lt!rVU84j(?!q zV4~0Q8%qhfK8*$8Y?Z*pkUP321>akuvHLf5 zc4`y%!f+u>ZGp%@q_;T!`76_snc_?K;Wx%YpF;5Kw^F+BCYUPy`fpRif`4OU1UbXH z#_jZm*6JI4QfW~*qE)(;`49kbn<5!l!!o#$EibBO_8qletzAW zbfXc(kr8C~jw;P*VK4}F4S&eM^~p->6inv}EpR%*v9ZCpT+n9LTIjsM6)eTH(8;kV=VM0f7Ob}(7`Qlu@Hb7X@`#DZ- zi|MwOfsR0*Nqun$;)E<*AwiogKKqIJ^nk8gwWi1pX~~%p%!sq01%LnN*V^>sKk74M z#eL0bDj&S3N;{Vuo8s8HJ{LHs>|%26a!!}8JAwgwD zmN{1Js--EnYa62!(1>C{N2O`>g0=p!e$jWu#lvpb4toUsUh)$_6wQy3WN~^lh~eGu zk~EDNWYsnm$PzR%%CNZ;wrXshPJv5K+^a`1Vi6Ju1pt-Rj<#8ly{6lVK{SLGNQ{6g zwkJrPAUUkfseg2pvIhVg59D!;3qs^x`Fqf@!NNn0j(a$ffJ|y@=x;KMED0#RfSa+L zp(2y`4O`oA(U%Q!G8q7{7+6ia6#9fPKh|)CCkTA_fP+e#ry`lhkSy%%ymFmip&)1u zu_$f&*44|uBC6#Z>=rzZN&#<1!J+h#!_^)7Y`V;6MSt4cTrhN$3ZuwIMkX91cI^Uf z-W6O;JIvKLGOR&_Dn?8|>leIhO6-B3@E3Y&)V}6v8D+_+8Bw~fjaXgusq3c~vRBuH zQK4=6Ldd3FGUWPKmH{o@gzUGlDs5z<^6V_#&@T*}U$!YEL*?V_8**(&)@xUCdPBcNu=vmE%EqBjF`uPTTst|_ z`s>w;%%XdT2T}a$X4yR7EI;zaof3a)5Z;`OwVi%D?gbkBj!{;z2tOBSFk&E1DeiZXMZlASh6MLK@Prz+DZR&!-)*s*D?ocwD3bN8qPY@%pn=@5Du<&6zb=W}RJy|*-;3`1lVHOTH64965)`~eOWRc0p2B0Z3g8vf?5>7yH z^I5NE_k=(v;5Dc5Xtxy}et&b=1LTe;xTz~uS^4UCVkI1nyDq@yW|5SB5O%CyC5AA~K z1Brw-QxLP-Fd-|mgMaJ?4+#2#uj-0@Wc~XK-EZa{Nk9;tpDi60`g!5U7F-QVOki-(5Ot( literal 2041 zcmaJ?c~nzZ9u6@;0AXaYAVN(;Kr(@>EJ+}skOWf=BA~*l4us@ELY9{%0m5QX6pnb} z(jZF|S&pLAS}3BZAfeQSvJ_h>F2Q1PYqi?o5`;m_yjZdG$1v}l_wK#F^L^iMz2}uD z#K$>1dON~kFlWvhW+Jp=tuN9J`ZlM-rl4h+ij|^D0y9;4JOuz-EdVnB6i3R-0ulk9 zApi4zAQA>!N9@-o026$1@L`d124`3G5<@_m`0f)Ug_Ie~;HT2q<_a=HH> zDwTdfD^-cW-|_xWVP$f@93UhDN-#&khZ>jZXLTi~$0`7x3REP6pk%&^2|`c>DutjN zMJD4Zs6Z}{FOpd;*mo2zm(GzXRXiCV;4m3zNCYnu3Fy=i5;2An&Lp!#LP;bRD~1&s z%VH6UY+}r6YDgG+p34OJIZ{BTn&%4s=CT&#TBkuOhdeU@g(w#guoa*b^)73=XyI65 z7Swys6)YS}?1EeZ6b!-I+yCnIya^g0>-NLsLWd8t56GZ_S3r|ZGbR+mV2ErEb9J)X zIF!njY-D-7{qtF2(?nlQ$0}!pzt=}hc*m%%)0Jb#N_K4@IC-`Pi5DahPZN7N9rH;ol;Gc*>-Go@gXKTM{eP)iJj6CYTIi}B#zLKZYD@_;m zrXmXXsFq@~ou-z!9bHoM8*(hwl>X(zm)TDcdkF4lZm$1jP*HbnD`o1$g}_R#+bu2D zr%7Y8KdsaC-V*aem5#@*M%r^GPgu%P2e-BnBClhP2yoGFe40>);=}>{NONtkXQ01p z)OX^t2Ojhddot9eg0WTIVSTNBa}7V-^_pO595w|Hx9q?k4dMp@$G7PK*TD=y;ck6J zdGRB!_RAI2nR3%tO1IkdWp*bw*?<=pM_LZb30?!oK)s;En( z!#nnd9=cXJ<}+e{XLdx(q3&ikJISe?eSHHohk+pz+$6Cv{ytvc{QXmMn2XQ9U8rvt zrJdAn(0gpSD@N=yTrI_2^P#*zQg7MTp1)k(lv(*(KtUR6@M|2WB>2wRwC-h=wk6XF zPtSes*_JwI+^d>xW489MJw5R6=t5?{R zc|E8i?RL@p9)A3ZJAQOg`}+F;<_vnWA!KxR#g%jZ@y_1Qu#Uw)kFPw_xmZ?a^e*1{ zM|ImtqA|(CaDQ@Fyvcof`MN66&VI6m6gAyAXx`%cDx6BI{Bj#}V*Rn1(b~;Am)D2u zX7(027IO?Z2VYK^1vXXpoZ@AtH~N?0rYWwtyA15`6vEf6fk&;o-L;7zFt`5nk*iOy z`<918zB+k;EytI$FAXug)jk*e@e};4e9g__w4A5ev!!)H$yC@{?vsRqJ##X1R%xPG z&_R3oDi$MtTkVqfPj)HEUDx_7wd!y{8#1%$U*Dd0sK@=#6+!XlsE-s^1f5E`R9Wo71^b~mbVdU;Fw0LG~mUQg;xsX4QYRo3B@rH_=ry>DE8ef!c2ta8UcI#26# zF|`*4wtMHe@%#eGZw`#Yj|QWuB`eRD)b~)r9mM95p_JVG%-IdcbIX5qG#GpGD+IrS zEqxb1Rg&Dadk5#7t4j68I1f!@A$efp1?I%&d*56)yl!tkz!14<$0Od_&6cGw$WW0r zjSlQA7l*6;vgfhv!cR|RmAD$+w6j`rVf=-?-D@q>kOseUVSb*~jbAS^*1h?ZL)n(9 zDa}`4etXO6`}9;{k5E^N{rcfnV_(LPwsDg``wtyS*V<19c3!PGJ3Kqy9ksvkwbJ%Z z*N(fT0{e*Wji-Ck5!3YE0j|PZ@&z`v=kitWL$bqSt!e4bH!+(|Q)CZ30^nVPfkx{s zX{6of`p=BiPb@u@IyL!tRk>?qgBqCmo-Zlt!636g?z`s~zdfwuB7DXZHvV`Usp+%Z zo*&;Biu@MHE&2j+?j^o`Cr12u<>vOe=a&8a2hlcmFjJiDR>XnD4c4DAhZWCkiAgW{ E51q9-lK=n! diff --git a/README.md b/README.md index 505c46b..6970561 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -# 一次开发,多端部署-银行理财 +# 优秀实践-一次开发,多端部署-银行理财 ### 简介 @@ -33,10 +33,4 @@ 1. 本示例仅支持标准系统上运行,支持设备:华为手机。 2. HarmonyOS系统:HarmonyOS NEXT Developer Beta1及以上。 3. DevEco Studio版本:DevEco Studio NEXT Developer Beta1及以上。 -4. HarmonyOS SDK版本:HarmonyOS NEXT Developer Beta1 SDK及以上。 - -### 注意 - -运行时需设置引用所有HSP模块。点击Run > Edit Configurations,选择Deploy Multi Hap标签页,勾选Deploy Multi Hap Packages, 选择使用方模块(phone)和所有HSP模块,点击OK。单击Run > Run “模块名称”(如Run “phone”)或![](screenshots/device/run.PNG)来启动应用/服务的编译构建。 - -![](screenshots/device/config.png) +4. HarmonyOS SDK版本:HarmonyOS NEXT Developer Beta1 SDK及以上。 \ No newline at end of file diff --git a/commons/basic/Index.ets b/commons/basic/Index.ets index 368ea5f..06829cc 100644 --- a/commons/basic/Index.ets +++ b/commons/basic/Index.ets @@ -1,5 +1,6 @@ -export { CommonConstants } from "./src/main/ets/constants/CommonConstants" -export { RouterConstants } from "./src/main/ets/constants/RouterConstants" -export { BreakpointUtil } from "./src/main/ets/utils/BreakpointUtil" -export { BusinessInfo } from "./src/main/ets/viewmodel/BusinessInfo" -export { FundDetail } from "./src/main/ets/viewmodel/FundDetail" +export { CommonConstants } from './src/main/ets/constants/CommonConstants'; +export { RouterConstants } from './src/main/ets/constants/RouterConstants'; +export { BreakpointUtil } from './src/main/ets/utils/BreakpointUtil'; +export { logger } from './src/main/ets/utils/Logger'; +export { BusinessInfo } from './src/main/ets/viewmodel/BusinessInfo'; +export { FundDetail } from './src/main/ets/viewmodel/FundDetail'; diff --git a/commons/basic/hvigorfile.ts b/commons/basic/hvigorfile.ts index d993120..4218707 100644 --- a/commons/basic/hvigorfile.ts +++ b/commons/basic/hvigorfile.ts @@ -1,6 +1,6 @@ -import { hspTasks } from '@ohos/hvigor-ohos-plugin'; +import { harTasks } from '@ohos/hvigor-ohos-plugin'; export default { - system: hspTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ + system: harTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ plugins:[] /* Custom plugin to extend the functionality of Hvigor. */ } diff --git a/commons/basic/src/main/ets/constants/CommonConstants.ets b/commons/basic/src/main/ets/constants/CommonConstants.ets index 7579dec..9e80725 100644 --- a/commons/basic/src/main/ets/constants/CommonConstants.ets +++ b/commons/basic/src/main/ets/constants/CommonConstants.ets @@ -42,6 +42,11 @@ export class CommonConstants { */ static readonly BREAK_POINTS_VALUE: Array = ['320vp', '600vp', '840vp']; + /** + * The break point value. + */ + static readonly BREAK_POINTS_VALUE_NUMBER: Array = [320, 600, 840]; + /** * The number of columns for SM device. */ diff --git a/commons/basic/src/main/ets/constants/RouterConstants.ets b/commons/basic/src/main/ets/constants/RouterConstants.ets index 8cac490..971a8c5 100644 --- a/commons/basic/src/main/ets/constants/RouterConstants.ets +++ b/commons/basic/src/main/ets/constants/RouterConstants.ets @@ -20,25 +20,25 @@ export class RouterConstants { /** * The funding detail page url. */ - static readonly FUNDING_DETAIL_URL: string = '@bundle:com.huawei.multifinancialmanagement/fund/ets/pages/FundingDetail'; + static readonly FUNDING_DETAIL_URL: string = 'FundingDetail'; /** * The funding page url. */ - static readonly FUNDING_URL: string = '@bundle:com.huawei.multifinancialmanagement/fund/ets/pages/Funding'; + static readonly FUNDING_URL: string = 'Funding'; /** * The trends page url. */ - static readonly TRENDS_PAGE_URL: string = '@bundle:com.huawei.multifinancialmanagement/fund/ets/pages/TrendsPage'; + static readonly TRENDS_PAGE_URL: string = 'TrendsPage'; /** * The comparison detail page url. */ - static readonly COMPARISON_PAGE_URL: string = '@bundle:com.huawei.multifinancialmanagement/fundComparison/ets/pages/ComparisonDetailPage'; + static readonly COMPARISON_PAGE_URL: string = 'ComparisonDetailPage'; /** * The comparison detail page url. */ - static readonly ACCOUNT_PAGE_URL: string = '@bundle:com.huawei.multifinancialmanagement/home/ets/pages/AccountPage'; + static readonly ACCOUNT_PAGE_URL: string = 'AccountPage'; } \ No newline at end of file diff --git a/commons/basic/src/main/ets/utils/Logger.ets b/commons/basic/src/main/ets/utils/Logger.ets new file mode 100644 index 0000000..748109d --- /dev/null +++ b/commons/basic/src/main/ets/utils/Logger.ets @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2024 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 { hilog } from '@kit.PerformanceAnalysisKit'; + +const LOG_DOMAIN: number = 0xFF00; + +class Logger { + private domain: number; + private prefix: string; + private format: string = '%{public}s, %{public}s'; + + constructor(prefix: string, domain: number) { + this.prefix = prefix; + this.domain = domain; + } + + debug(...args: string[]): void { + hilog.debug(this.domain, this.prefix, this.format, args); + } + + info(...args: string[]): void { + hilog.info(this.domain, this.prefix, this.format, args); + } + + warn(...args: string[]): void { + hilog.warn(this.domain, this.prefix, this.format, args); + } + + error(...args: string[]): void { + hilog.error(this.domain, this.prefix, this.format, args); + } +} + +export const logger = new Logger('MultiFinancialManagement', LOG_DOMAIN); \ No newline at end of file diff --git a/commons/basic/src/main/module.json5 b/commons/basic/src/main/module.json5 index a68c576..6823e5b 100644 --- a/commons/basic/src/main/module.json5 +++ b/commons/basic/src/main/module.json5 @@ -1,13 +1,12 @@ { "module": { "name": "basic", - "type": "shared", + "type": "har", "description": "$string:shared_desc", "deviceTypes": [ "phone", "tablet", "2in1" - ], - "deliveryWithInstall": true + ] } } \ No newline at end of file diff --git a/features/fund/Index.ets b/features/fund/Index.ets index e69de29..c90b6ba 100644 --- a/features/fund/Index.ets +++ b/features/fund/Index.ets @@ -0,0 +1,3 @@ +export { Funding } from './src/main/ets/view/Funding'; +export { FundingDetail } from './src/main/ets/view/FundingDetail'; +export { TrendsPage } from './src/main/ets/view/TrendsPage'; \ No newline at end of file diff --git a/features/fund/hvigorfile.ts b/features/fund/hvigorfile.ts index d993120..4218707 100644 --- a/features/fund/hvigorfile.ts +++ b/features/fund/hvigorfile.ts @@ -1,6 +1,6 @@ -import { hspTasks } from '@ohos/hvigor-ohos-plugin'; +import { harTasks } from '@ohos/hvigor-ohos-plugin'; export default { - system: hspTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ + system: harTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ plugins:[] /* Custom plugin to extend the functionality of Hvigor. */ } diff --git a/features/fund/src/main/ets/view/DetailComponent.ets b/features/fund/src/main/ets/view/DetailComponent.ets index aa731f6..cac46e3 100644 --- a/features/fund/src/main/ets/view/DetailComponent.ets +++ b/features/fund/src/main/ets/view/DetailComponent.ets @@ -13,7 +13,6 @@ * limitations under the License. */ -import { router } from '@kit.ArkUI'; import { LineChart, LineChartModel } from '@ohos/mpchart'; import { BreakpointUtil, CommonConstants, FundDetail, RouterConstants } from '@ohos/basic'; import ChartViewModel from '../viewmodel/ChartViewModel'; @@ -30,6 +29,7 @@ export struct DetailComponent { @State tabBarIndex: number = 0; @State fundInfo: FundDetail[] = FundingViewModel.getAllFundInfo(); @StorageLink('pageInfo') pageInfo: NavPathStack = new NavPathStack(); + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); private controller: TabsController = new TabsController(); build() { @@ -59,11 +59,11 @@ export struct DetailComponent { .width($r('app.float.common_image')) .height($r('app.float.common_image')) .onClick(() => { - router.back(); + this.pageIndexInfos.pop(); }) Text($r('app.string.funding_title')) .fontSize($r('app.float.title_text_size')) - .fontColor($r('app.color.sixty_percent_white')) + .fontColor($r('sys.color.mask_secondary')) Image($r('app.media.ic_public_share')) .width($r('app.float.common_image')) .height($r('app.float.common_image')) @@ -123,7 +123,7 @@ export struct DetailComponent { Column({ space: FundConstants.COLUMN_SPACE }) { Text($r('app.string.one_day_amplitude_data')) .fontSize($r('app.float.amplitude_date_size')) - .fontColor($r("app.color.amplitude_date")) + .fontColor($r('app.color.amplitude_date')) .fontWeight(CommonConstants.FONT_WEIGHT_500) Text($r('app.string.one_day_amplitude')) .fontSize($r('app.float.amplitude_time_size')) @@ -191,7 +191,7 @@ export struct DetailComponent { Row() { Row({ space: FundConstants.BOTTOM_ROW_SPACE }) { Text($r('app.string.performance_trends')) - .fontSize($r('app.float.tab_text_size')) + .fontSize($r('app.float.tab_text_size_fund')) .lineHeight($r('app.float.common_line_height')) .fontColor(this.tabBarIndex === 0 ? $r('app.color.harmony_blue') : Color.Black) .border({ @@ -208,7 +208,7 @@ export struct DetailComponent { this.controller.changeIndex(this.tabBarIndex); }) Text($r('app.string.unit_net_value')) - .fontSize($r('app.float.tab_text_size')) + .fontSize($r('app.float.tab_text_size_fund')) .lineHeight($r('app.float.common_line_height')) .fontColor(this.tabBarIndex === 1 ? $r('app.color.harmony_blue') : Color.Black) .border({ @@ -229,10 +229,8 @@ export struct DetailComponent { .width($r('app.float.common_image')) .height($r('app.float.common_image')) .onClick(() => { - router.pushUrl({ - url: RouterConstants.TRENDS_PAGE_URL, - params: { name: this.fundInfo[this.indexList].name } - }) + this.pageIndexInfos.pushPathByName(RouterConstants.TRENDS_PAGE_URL, + { 'name': this.fundInfo[this.indexList].name } as Record); }) } .width(CommonConstants.FULL_WIDTH_PERCENT) @@ -274,7 +272,7 @@ export struct DetailComponent { .fontSize($r('app.float.chart_button_size')) .fontColor($r('app.color.harmony_blue')) .fontWeight(CommonConstants.FONT_WEIGHT_500) - .backgroundColor($r('app.color.five_percent_white')) + .backgroundColor($r('app.color.five_percent_white_fund')) .height($r('app.float.chart_button_height')) .width(new BreakpointUtil({ sm: $r('app.float.chart_button_min_width'), @@ -338,7 +336,7 @@ export struct DetailComponent { this.pageInfo.pushPath({ name: CommonConstants.PATH_COMPARISON }) }) Column({ space: FundConstants.COLLECT_COLUMN_SPACE }) { - Image($r("app.media.ic_public_collect_fund")) + Image($r('app.media.ic_public_collect_fund')) .width($r('app.float.common_image')) .height($r('app.float.common_image')) Text($r('app.string.funding_concerned')) @@ -353,7 +351,7 @@ export struct DetailComponent { lg: $r('app.float.bottom_button_width_md') }).getValue(this.currentPoint)) .height($r('app.float.bottom_button_height')) - .backgroundColor($r('app.color.five_percent_white')) + .backgroundColor($r('app.color.five_percent_white_fund')) .fontColor($r('app.color.bottom_button')) .fontSize($r('app.float.common_font_size')) .fontWeight(CommonConstants.FONT_WEIGHT_500) @@ -393,7 +391,7 @@ export struct DetailComponent { .hideTitleBar(true) .backgroundColor($r('app.color.common_background')) .onBackPressed(() => { - router.back(); + this.pageIndexInfos.pop(); return true; }) } @@ -402,7 +400,7 @@ export struct DetailComponent { @Extend(Button) function chartButtonStyle() { .fontSize($r('app.float.chart_button_size')) - .fontColor($r('app.color.sixty_percent_white')) + .fontColor($r('sys.color.mask_secondary')) .fontWeight(CommonConstants.FONT_WEIGHT_500) .backgroundColor(Color.White) .height($r('app.float.chart_button_height')) diff --git a/features/fund/src/main/ets/view/FundComponent.ets b/features/fund/src/main/ets/view/FundComponent.ets index bba10d5..7b815c8 100644 --- a/features/fund/src/main/ets/view/FundComponent.ets +++ b/features/fund/src/main/ets/view/FundComponent.ets @@ -13,7 +13,6 @@ * limitations under the License. */ -import { router } from '@kit.ArkUI'; import { BreakpointUtil, BusinessInfo, CommonConstants, FundDetail, RouterConstants } from '@ohos/basic'; import { FundConstants } from '../constants/FundConstants'; import FundingViewModel from '../viewmodel/FundingViewModel'; @@ -23,6 +22,9 @@ export struct FundComponent { @State currentPoint: string = CommonConstants.BREAK_POINT_SM; @State tabBarIndex: number = 0; @State backgroundX: number = 0; + @StorageProp('avoidArea') topHeight: number = 0; + @StorageProp('bottom') bottom: number = 0; + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); private controller: TabsController = new TabsController(); build() { @@ -45,24 +47,38 @@ export struct FundComponent { lg: CommonConstants.COLUMN_LG } }) { - Column() { - Row() { - Image($r('app.media.ic_public_back')) - .width($r('app.float.common_image')) - .height($r('app.float.common_image')) - .fillColor(Color.Black) - .onClick(() => { - router.back(); - }) + Row() { + Image($r('app.media.ic_public_back')) + .width($r('app.float.common_image')) + .height($r('app.float.common_image')) + .fillColor(Color.Black) + .onClick(() => { + this.pageIndexInfos.pop(); + }) - Blank() + Search({ placeholder: $r('app.string.search_placeholder') }) + .visibility(this.currentPoint === CommonConstants.BREAK_POINT_SM ? Visibility.Visible : Visibility.None) + .enableKeyboardOnFocus(false) + .placeholderColor($r('sys.color.mask_secondary')) + .borderColor($r('app.color.five_percent_white_fund')) + .searchIcon({ + color: $r('sys.color.mask_secondary') + }) + .width(this.currentPoint === CommonConstants.BREAK_POINT_SM ? + $r('app.float.search_width_sm') : $r('app.float.search_width')) + .margin({ + left: $r('app.float.common_margin'), + right: $r('app.float.common_margin') + }) + Row() { Search({ placeholder: $r('app.string.search_placeholder') }) + .visibility(this.currentPoint === CommonConstants.BREAK_POINT_SM ? Visibility.None : Visibility.Visible) .enableKeyboardOnFocus(false) - .placeholderColor($r('app.color.sixty_percent_white')) - .borderColor($r('app.color.five_percent_white')) + .placeholderColor($r('sys.color.mask_secondary')) + .borderColor($r('app.color.five_percent_white_fund')) .searchIcon({ - color: $r('app.color.sixty_percent_white') + color: $r('sys.color.mask_secondary') }) .width(this.currentPoint === CommonConstants.BREAK_POINT_SM ? $r('app.float.search_width_sm') : $r('app.float.search_width')) @@ -75,16 +91,19 @@ export struct FundComponent { .height($r('app.float.common_image')) .fillColor(Color.Black) } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .backgroundColor(Color.White) - .justifyContent(FlexAlign.SpaceBetween) - .padding({ - left: $r('app.float.padding_common'), - right: $r('app.float.padding_common'), - top: $r('app.float.title_padding_tb'), - bottom: $r('app.float.title_padding_tb') - }) } + .width(CommonConstants.FULL_WIDTH_PERCENT) + .backgroundColor(Color.White) + .justifyContent(FlexAlign.SpaceBetween) + .padding({ + left: $r('app.float.padding_common'), + right: $r('app.float.padding_common'), + top: $r('app.float.title_padding_tb'), + bottom: $r('app.float.title_padding_tb') + }) + .margin({ + top: this.topHeight + }) } GridCol({ @@ -196,7 +215,8 @@ export struct FundComponent { .scrollBar(BarState.Off) } .margin({ - top: $r('app.float.scroll_margin_top') + top: $r('app.float.scroll_margin_top'), + bottom: this.bottom }) } .backgroundColor($r('app.color.common_background')) @@ -213,7 +233,7 @@ export struct FundComponent { @Builder buildTabBarText(text: ResourceStr, index: number) { Text(text) - .fontSize($r('app.float.tab_text_size')) + .fontSize($r('app.float.tab_text_size_fund')) .lineHeight($r('app.float.common_line_height')) .fontColor(this.tabBarIndex === index ? $r('app.color.harmony_blue') : Color.Black) .border({ @@ -274,10 +294,8 @@ export struct FundComponent { .width($r('app.float.list_item_width')) .justifyContent(FlexAlign.SpaceAround) .onClick(() => { - router.pushUrl({ - url: RouterConstants.FUNDING_DETAIL_URL, - params: { 'listIndex': index } - }) + this.pageIndexInfos.pushPathByName(RouterConstants.FUNDING_DETAIL_URL, + { 'listIndex': index } as Record); }) } .width(CommonConstants.FULL_WIDTH_PERCENT) @@ -412,7 +430,7 @@ export struct FundComponent { .fillColor($r('app.color.sixty_percent_black')) Text($r('app.string.funding_news')) .fontSize($r('app.float.news_text_size')) - .fontColor($r('app.color.sixty_percent_black')) + .fontColor($r('sys.color.font_on_secondary')) .fontWeight(FontWeight.Normal) .textOverflow({ overflow: TextOverflow.Ellipsis diff --git a/features/fund/src/main/ets/view/FundNavigationComponent.ets b/features/fund/src/main/ets/view/FundNavigationComponent.ets index e516fe7..7eee6a4 100644 --- a/features/fund/src/main/ets/view/FundNavigationComponent.ets +++ b/features/fund/src/main/ets/view/FundNavigationComponent.ets @@ -13,7 +13,6 @@ * limitations under the License. */ -import { router } from '@kit.ArkUI'; import { BreakpointUtil, BusinessInfo, CommonConstants, FundDetail } from '@ohos/basic'; import { FundConstants } from '../constants/FundConstants'; import FundingViewModel from '../viewmodel/FundingViewModel'; @@ -25,6 +24,7 @@ export struct FundNavigationComponent { @State listIndex: number = 0; @State tabBarIndex: number = 0; @State backgroundX: number = 0; + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); private controller: TabsController = new TabsController(); build() { @@ -49,42 +49,40 @@ export struct FundNavigationComponent { lg: CommonConstants.COLUMN_LG } }) { - Column() { - Row() { - Image($r('app.media.ic_public_back')) - .width($r('app.float.common_image')) - .height($r('app.float.common_image')) - .fillColor(Color.Black) - .onClick(() => { - router.back(); - }) - Search({ placeholder: $r('app.string.search_placeholder') }) - .enableKeyboardOnFocus(false) - .placeholderColor($r('app.color.sixty_percent_white')) - .borderColor($r('app.color.five_percent_white')) - .searchIcon({ - color: $r('app.color.sixty_percent_white') - }) - .layoutWeight(1) - .margin({ - left: $r('app.float.common_margin'), - right: $r('app.float.common_margin') - }) - Image($r('app.media.ic_public_comments')) - .width($r('app.float.common_image')) - .height($r('app.float.common_image')) - .fillColor(Color.Black) - } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .backgroundColor(Color.White) - .justifyContent(FlexAlign.SpaceBetween) - .padding({ - left: $r('app.float.padding_common'), - right: $r('app.float.padding_common'), - top: $r('app.float.title_padding_tb'), - bottom: $r('app.float.title_padding_tb') - }) + Row() { + Image($r('app.media.ic_public_back')) + .width($r('app.float.common_image')) + .height($r('app.float.common_image')) + .fillColor(Color.Black) + .onClick(() => { + this.pageIndexInfos.pop(); + }) + Search({ placeholder: $r('app.string.search_placeholder') }) + .enableKeyboardOnFocus(false) + .placeholderColor($r('app.color.sixty_percent_white')) + .borderColor($r('app.color.five_percent_white_fund')) + .searchIcon({ + color: $r('app.color.sixty_percent_white') + }) + .layoutWeight(1) + .margin({ + left: $r('app.float.common_margin'), + right: $r('app.float.common_margin') + }) + Image($r('app.media.ic_public_comments')) + .width($r('app.float.common_image')) + .height($r('app.float.common_image')) + .fillColor(Color.Black) } + .width(CommonConstants.FULL_WIDTH_PERCENT) + .backgroundColor(Color.White) + .justifyContent(FlexAlign.SpaceBetween) + .padding({ + left: $r('app.float.padding_common'), + right: $r('app.float.padding_common'), + top: $r('app.float.title_padding_tb'), + bottom: $r('app.float.title_padding_tb') + }) } GridCol({ @@ -217,7 +215,7 @@ export struct FundNavigationComponent { @Builder buildTabBarText(text: ResourceStr, index: number) { Text(text) - .fontSize($r('app.float.tab_text_size')) + .fontSize($r('app.float.tab_text_size_fund')) .lineHeight($r('app.float.common_line_height')) .fontColor(this.tabBarIndex === index ? $r('app.color.harmony_blue') : Color.Black) .border({ diff --git a/features/fund/src/main/ets/pages/Funding.ets b/features/fund/src/main/ets/view/Funding.ets similarity index 36% rename from features/fund/src/main/ets/pages/Funding.ets rename to features/fund/src/main/ets/view/Funding.ets index 5453133..6157f96 100644 --- a/features/fund/src/main/ets/pages/Funding.ets +++ b/features/fund/src/main/ets/view/Funding.ets @@ -12,21 +12,18 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -import { CommonConstants } from '@ohos/basic'; -import { FundConstants } from '../constants/FundConstants'; -import { FundComponent } from '../view/FundComponent'; +import { CommonConstants } from '@ohos/basic/'; +import { window } from '@kit.ArkUI'; +import { FundConstants } from '../constants/FundConstants'; +import { FundComponent } from './FundComponent'; import FundingViewModel from '../viewmodel/FundingViewModel'; -@Entry @Component -struct Funding { - @State breakPoint: string = CommonConstants.BREAK_POINT_SM; +export struct Funding { + @StorageLink('breakPoint') breakPoint: string = CommonConstants.BREAK_POINT_SM; @State currentTabIndex: number = 0; - - aboutToAppear() { - AppStorage.setOrCreate('allFund', FundingViewModel.getAllFundInfo()) - } + @StorageProp('avoidArea') topHeight: number = 0; @Builder BuildTabs(icon: Resource, title: ResourceStr, index: number) { @@ -34,12 +31,12 @@ struct Funding { Image(icon) .width($r('app.float.common_image')) .height($r('app.float.common_image')) - .fillColor(this.currentTabIndex === index ? $r("app.color.tab_choose_image") : $r('app.color.tab_un_image')) + .fillColor(this.currentTabIndex === index ? $r('app.color.tab_choose_image') : $r('app.color.tab_un_image')) Text(title) .fontSize($r('app.float.home_tab_text_size')) - .lineHeight($r("app.float.tab_text_height")) + .lineHeight($r('app.float.tab_text_height')) .fontWeight(FontWeight.Regular) - .fontColor(this.currentTabIndex === index ? $r("app.color.tab_choose_image") : $r('app.color.tab_un_image')) + .fontColor(this.currentTabIndex === index ? $r('app.color.tab_choose_image') : $r('app.color.tab_un_image')) } } @@ -53,71 +50,88 @@ struct Funding { .fontSize($r('app.float.home_tab_text_size')) .lineHeight($r('app.float.tab_text_height')) .fontWeight(FontWeight.Regular) - .fontColor(this.currentTabIndex === index ? $r("app.color.tab_choose_image") : $r('app.color.tab_un_image')) + .fontColor(this.currentTabIndex === index ? $r('app.color.tab_choose_image') : $r('app.color.tab_un_image')) } } build() { - GridRow({ - breakpoints: { - value: CommonConstants.BREAK_POINTS_VALUE, - reference: BreakpointsReference.WindowSize - }, - columns: { - sm: CommonConstants.COLUMN_SM, - md: CommonConstants.COLUMN_MD, - lg: CommonConstants.COLUMN_LG - }, - direction: GridRowDirection.Row - }) { - GridCol({ - span: { + NavDestination() { + GridRow({ + breakpoints: { + value: CommonConstants.BREAK_POINTS_VALUE, + reference: BreakpointsReference.WindowSize + }, + columns: { sm: CommonConstants.COLUMN_SM, md: CommonConstants.COLUMN_MD, lg: CommonConstants.COLUMN_LG - } + }, + direction: GridRowDirection.Row }) { - Column() { - Tabs({ - barPosition: this.breakPoint === CommonConstants.BREAK_POINT_LG ? BarPosition.Start : BarPosition.End - }) { - TabContent() { - FundComponent() - } - .tabBar(this.BuildTabs($r('app.media.ic_public_home_filled'), $r('app.string.tab_bar_home'), 0)) + GridCol({ + span: { + sm: CommonConstants.COLUMN_SM, + md: CommonConstants.COLUMN_MD, + lg: CommonConstants.COLUMN_LG + } + }) { + Column() { + Tabs({ + barPosition: this.breakPoint === CommonConstants.BREAK_POINT_LG ? BarPosition.Start : BarPosition.End + }) { + TabContent() { + FundComponent() + } + .tabBar(this.BuildTabs($r('app.media.ic_public_home_filled'), $r('app.string.tab_bar_home'), 0)) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_public_cards_filled'), $r('app.string.tab_bar_card'), 1)) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_public_cards_filled'), $r('app.string.tab_bar_card'), 1)) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_home_fortunes'), $r('app.string.tab_bar_fortunes'), 2)) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_home_fortunes'), $r('app.string.tab_bar_fortunes'), 2)) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_life_filled'), $r('app.string.tab_bar_life'), 3)) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_life_filled'), $r('app.string.tab_bar_life'), 3)) - TabContent() { + TabContent() { + } + .tabBar(this.BuildTabsMine($r('app.media.ic_home_mine'), $r('app.media.ic_home_mine_filled'), + $r('app.string.tab_bar_mine'), 4)) } - .tabBar(this.BuildTabsMine($r('app.media.ic_home_mine'), $r('app.media.ic_home_mine_filled'), - $r('app.string.tab_bar_mine'), 4)) - } - .vertical(this.breakPoint === CommonConstants.BREAK_POINT_LG) - .barWidth(this.breakPoint === CommonConstants.BREAK_POINT_LG ? - $r('app.float.tab_bar_width') : CommonConstants.TAB_BAR_HEIGHT_PERCENT) - .barHeight(this.breakPoint === CommonConstants.BREAK_POINT_LG ? + .vertical(this.breakPoint === CommonConstants.BREAK_POINT_LG) + .barWidth(this.breakPoint === CommonConstants.BREAK_POINT_LG ? + $r('app.float.tab_bar_width') : CommonConstants.TAB_BAR_HEIGHT_PERCENT) + .barHeight(this.breakPoint === CommonConstants.BREAK_POINT_LG ? CommonConstants.TAB_HEIGHT_PERCENT : 0) - .backgroundColor($r('app.color.home_background')) - .scrollable(false) - .onChange((index: number) => { - this.currentTabIndex = index; - }) + .backgroundColor($r('app.color.home_background')) + .scrollable(false) + .onChange((index: number) => { + this.currentTabIndex = index; + }) + } } } } - .onBreakpointChange((breakpoints: string) => { - this.breakPoint = breakpoints; + .hideTitleBar(true) + .onWillShow(() => { + AppStorage.setOrCreate('allFund', FundingViewModel.getAllFundInfo()); + window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { + let sysBarProps: window.SystemBarProperties = { + statusBarColor: '#FFFFFF' + }; + windowStage.setWindowSystemBarProperties(sysBarProps); + }) + }) + .onWillDisappear(() => { + window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { + let sysBarProps: window.SystemBarProperties = { + statusBarColor: '#00ffffff' + }; + windowStage.setWindowSystemBarProperties(sysBarProps); + }) }) } } \ No newline at end of file diff --git a/features/fund/src/main/ets/pages/FundingDetail.ets b/features/fund/src/main/ets/view/FundingDetail.ets similarity index 40% rename from features/fund/src/main/ets/pages/FundingDetail.ets rename to features/fund/src/main/ets/view/FundingDetail.ets index ab48b39..dc5178d 100644 --- a/features/fund/src/main/ets/pages/FundingDetail.ets +++ b/features/fund/src/main/ets/view/FundingDetail.ets @@ -13,98 +13,98 @@ * limitations under the License. */ -import { router } from '@kit.ArkUI'; -import { CommonConstants } from '@ohos/basic'; -import { ComparisonComponent, ComparisonInfo, ComparisonDetailComponent } from '@ohos/fundComparison'; -import { TransactionComponent } from '@ohos/transaction'; +import { CommonConstants } from '@ohos/basic/'; +import { ComparisonComponent, ComparisonInfo, ComparisonDetailComponent } from '@ohos/fundComparison/'; +import { TransactionComponent } from '@ohos/transaction/'; import { FundConstants } from '../constants/FundConstants'; -import { DetailComponent } from '../view/DetailComponent'; -import { FundNavigationComponent } from '../view/FundNavigationComponent'; +import { DetailComponent } from './DetailComponent'; +import { FundNavigationComponent } from './FundNavigationComponent'; -@Entry @Component -struct FundingDetail { - @StorageLink('pageInfo')pageInfo: NavPathStack = new NavPathStack(); - @State breakPoint: string = CommonConstants.BREAK_POINT_LG; +export struct FundingDetail { + @StorageLink('pageInfo') pageInfo: NavPathStack = new NavPathStack(); + @StorageLink('breakPoint') breakPoint: string = CommonConstants.BREAK_POINT_SM; @State currentTabIndex: number = 0; @State index: number = 0; - - aboutToAppear() { - let param: Record = router.getParams() as Record; - if (param) { - this.index = param['listIndex']; - } - this.pageInfo.pushPath({ name: CommonConstants.PATH_DETAIL, param: this.index }, false); - } + @StorageProp('avoidArea') topHeight: number = 0; + @StorageProp('bottom') bottom: number = 0; + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); build() { - GridRow({ - breakpoints: { - value: CommonConstants.BREAK_POINTS_VALUE, - reference: BreakpointsReference.WindowSize - }, - columns: { - sm: CommonConstants.COLUMN_SM, - md: CommonConstants.COLUMN_MD, - lg: CommonConstants.COLUMN_LG - }, - direction: GridRowDirection.Row - }) { - GridCol({ - span: { + NavDestination() { + GridRow({ + breakpoints: { + value: CommonConstants.BREAK_POINTS_VALUE, + reference: BreakpointsReference.WindowSize + }, + columns: { sm: CommonConstants.COLUMN_SM, md: CommonConstants.COLUMN_MD, lg: CommonConstants.COLUMN_LG - } + }, + direction: GridRowDirection.Row }) { - Column() { - Tabs({ - barPosition: this.breakPoint === CommonConstants.BREAK_POINT_LG ? BarPosition.Start : BarPosition.End - }) { - TabContent() { - Navigation(this.pageInfo) { - FundNavigationComponent({ listIndex: this.index }) + GridCol({ + span: { + sm: CommonConstants.COLUMN_SM, + md: CommonConstants.COLUMN_MD, + lg: CommonConstants.COLUMN_LG + } + }) { + Column() { + Tabs({ + barPosition: this.breakPoint === CommonConstants.BREAK_POINT_LG ? BarPosition.Start : BarPosition.End + }) { + TabContent() { + Navigation(this.pageInfo) { + FundNavigationComponent({ listIndex: this.index }) + } + .navDestination(this.buildNavDestination) + .hideTitleBar(true) + .hideBackButton(true) + .mode(this.breakPoint === CommonConstants.BREAK_POINT_LG ? NavigationMode.Split : NavigationMode.Stack) + .navBarWidth(FundConstants.NAV_BAR_WIDTH) } - .navDestination(this.buildNavDestination) - .hideTitleBar(true) - .hideBackButton(true) - .mode(this.breakPoint === CommonConstants.BREAK_POINT_LG ? NavigationMode.Split : NavigationMode.Stack) - .navBarWidth(FundConstants.NAV_BAR_WIDTH) - } - .tabBar(this.BuildTabs($r('app.media.ic_public_home_filled'), $r('app.string.tab_bar_home'), 0)) + .tabBar(this.BuildTabs($r('app.media.ic_public_home_filled'), $r('app.string.tab_bar_home'), 0)) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_public_cards_filled'), $r('app.string.tab_bar_card'), 1)) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_public_cards_filled'), $r('app.string.tab_bar_card'), 1)) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_home_fortunes'), $r('app.string.tab_bar_fortunes'), 2)) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_home_fortunes'), $r('app.string.tab_bar_fortunes'), 2)) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_life_filled'), $r('app.string.tab_bar_life'), 3)) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_life_filled'), $r('app.string.tab_bar_life'), 3)) - TabContent() { + TabContent() { + } + .tabBar(this.BuildTabsMine($r('app.media.ic_home_mine'), $r('app.media.ic_home_mine_filled'), + $r('app.string.tab_bar_mine'), 4)) } - .tabBar(this.BuildTabsMine($r('app.media.ic_home_mine'), $r('app.media.ic_home_mine_filled'), - $r('app.string.tab_bar_mine'), 4)) + .vertical(this.breakPoint === CommonConstants.BREAK_POINT_LG) + .barWidth(this.breakPoint === CommonConstants.BREAK_POINT_LG ? + $r('app.float.tab_bar_width') : CommonConstants.TAB_BAR_HEIGHT_PERCENT) + .barHeight(this.breakPoint === CommonConstants.BREAK_POINT_LG ? + CommonConstants.TAB_HEIGHT_PERCENT : 0) + .backgroundColor($r('app.color.home_background')) + .scrollable(false) + .onChange((index: number) => { + this.currentTabIndex = index; + }) } - .vertical(this.breakPoint === CommonConstants.BREAK_POINT_LG) - .barWidth(this.breakPoint === CommonConstants.BREAK_POINT_LG ? - $r('app.float.tab_bar_width') : CommonConstants.TAB_BAR_HEIGHT_PERCENT) - .barHeight(this.breakPoint === CommonConstants.BREAK_POINT_LG ? - CommonConstants.TAB_HEIGHT_PERCENT : 0) - .backgroundColor($r('app.color.home_background')) - .scrollable(false) - .onChange((index: number) => { - this.currentTabIndex = index; - }) } } } - .onBreakpointChange((breakpoints: string) => { - this.breakPoint = breakpoints; + .hideTitleBar(true) + .onWillAppear(() => { + this.pageInfo.pushPath({ name: CommonConstants.PATH_DETAIL, param: this.index }, false); + }) + .margin({ + top: this.topHeight, + bottom: this.bottom }) } @@ -134,12 +134,12 @@ struct FundingDetail { Image(icon) .width($r('app.float.common_image')) .height($r('app.float.common_image')) - .fillColor(this.currentTabIndex === index ? $r("app.color.tab_choose_image") : $r('app.color.tab_un_image')) + .fillColor(this.currentTabIndex === index ? $r('app.color.tab_choose_image') : $r('app.color.tab_un_image')) Text(title) .fontSize($r('app.float.home_tab_text_size')) - .lineHeight($r("app.float.tab_text_height")) + .lineHeight($r('app.float.tab_text_height')) .fontWeight(FontWeight.Regular) - .fontColor(this.currentTabIndex === index ? $r("app.color.tab_choose_image") : $r('app.color.tab_un_image')) + .fontColor(this.currentTabIndex === index ? $r('app.color.tab_choose_image') : $r('app.color.tab_un_image')) } } @@ -153,7 +153,7 @@ struct FundingDetail { .fontSize($r('app.float.home_tab_text_size')) .lineHeight($r('app.float.tab_text_height')) .fontWeight(FontWeight.Regular) - .fontColor(this.currentTabIndex === index ? $r("app.color.tab_choose_image") : $r('app.color.tab_un_image')) + .fontColor(this.currentTabIndex === index ? $r('app.color.tab_choose_image') : $r('app.color.tab_un_image')) } } } \ No newline at end of file diff --git a/features/fund/src/main/ets/pages/TrendsPage.ets b/features/fund/src/main/ets/view/TrendsPage.ets similarity index 36% rename from features/fund/src/main/ets/pages/TrendsPage.ets rename to features/fund/src/main/ets/view/TrendsPage.ets index 1f94772..4033a35 100644 --- a/features/fund/src/main/ets/pages/TrendsPage.ets +++ b/features/fund/src/main/ets/view/TrendsPage.ets @@ -14,26 +14,25 @@ */ import { Callback } from '@kit.BasicServicesKit'; -import { display, router } from '@kit.ArkUI'; -import { hilog } from '@kit.PerformanceAnalysisKit'; +import { display } from '@kit.ArkUI'; import { window } from '@kit.ArkUI'; import { LineChart, LineChartModel } from '@ohos/mpchart'; -import { BreakpointUtil, CommonConstants } from '@ohos/basic'; +import { BreakpointUtil, CommonConstants, logger } from '@ohos/basic/'; import ChartViewModel from '../viewmodel/ChartViewModel'; -import { ChartLegendComponent } from '../view/ChartLegendComponent'; +import { ChartLegendComponent } from './ChartLegendComponent'; import { FundConstants } from '../constants/FundConstants'; -@Entry @Component -struct TrendsPage { +export struct TrendsPage { @State showChart: boolean = true; @State lineChartModel: LineChartModel = ChartViewModel.getLineChartModel(); @State tabBarIndex: number = 0; - @State name: string = (router.getParams() as Record)['name']; + @State name: string = ''; @State currentPoint: string = CommonConstants.BREAK_POINT_MD; @StorageProp('breakPoint') breakPoint: string = CommonConstants.BREAK_POINT_MD; @StorageProp('avoidArea') areaLeft: number = 0; @State isLandScape: boolean = false; + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); private controller: TabsController = new TabsController(); private callback: Callback = (data: display.FoldDisplayMode) => { if (this.isLandScape && data === display.FoldDisplayMode.FOLD_DISPLAY_MODE_FULL) { @@ -48,93 +47,66 @@ struct TrendsPage { this.isLandScape = true; } }; - aboutToAppear(): void { - if (!this.isLandScape && this.breakPoint === CommonConstants.BREAK_POINT_SM) { - window.getLastWindow(getContext(this)).then((stage: window.Window) => { - stage.setPreferredOrientation(window.Orientation.LANDSCAPE); - this.isLandScape = true; - }); - } - try { - display.on('foldDisplayModeChange', this.callback); - } catch (exception) { - hilog.error(0x0000, 'testTag', '%{public}s', 'Failed to register callback. Code: ' + JSON.stringify(exception)); - } - } - - aboutToDisappear(): void { - if (this.isLandScape) { - window.getLastWindow(getContext(this)).then((stage: window.Window) => { - stage.setPreferredOrientation(window.Orientation.PORTRAIT); - }); - this.isLandScape = false; - } - try { - display.off('foldDisplayModeChange', this.callback); - } catch (exception) { - hilog.error(0x0000, 'testTag', '%{public}s', 'Failed to register callback. Code: ' + JSON.stringify(exception)); - } - } build() { - GridRow({ - breakpoints: { - value: CommonConstants.BREAK_POINTS_VALUE, - reference: BreakpointsReference.WindowSize - }, - columns: { - sm: CommonConstants.COLUMN_SM, - md: CommonConstants.COLUMN_MD, - lg: CommonConstants.COLUMN_LG - }, - direction: GridRowDirection.Row - }) { - GridCol({ - span: { + NavDestination() { + GridRow({ + breakpoints: { + value: CommonConstants.BREAK_POINTS_VALUE, + reference: BreakpointsReference.WindowSize + }, + columns: { sm: CommonConstants.COLUMN_SM, md: CommonConstants.COLUMN_MD, lg: CommonConstants.COLUMN_LG - } + }, + direction: GridRowDirection.Row }) { - Row() { + GridCol({ + span: { + sm: CommonConstants.COLUMN_SM, + md: CommonConstants.COLUMN_MD, + lg: CommonConstants.COLUMN_LG + } + }) { Row() { - Text(this.name) - .fontSize($r('app.float.common_font_size')) - .fontColor($r('app.color.name_text')) - .lineHeight($r('app.float.common_line_height')) - .fontWeight(CommonConstants.FONT_WEIGHT_500) - Text($r('app.string.funding_code')) - .fontSize($r('app.float.code_size')) - .fontColor($r('app.color.forty_percent_white')) - .margin({ - left: $r('app.float.code_margin_left') + Row() { + Text(this.name) + .fontSize($r('app.float.common_font_size')) + .fontColor($r('app.color.name_text')) + .lineHeight($r('app.float.common_line_height')) + .fontWeight(CommonConstants.FONT_WEIGHT_500) + Text($r('app.string.funding_code')) + .fontSize($r('app.float.code_size')) + .fontColor($r('app.color.forty_percent_white')) + .margin({ + left: $r('app.float.code_margin_left') + }) + } + .alignItems(VerticalAlign.Bottom) + + Image($r('app.media.ic_public_reduce')) + .width($r('app.float.common_image')) + .height($r('app.float.common_image')) + .onClick(() => { + this.pageIndexInfos.pop(); }) } - .alignItems(VerticalAlign.Bottom) - - Image($r('app.media.ic_public_reduce')) - .width($r('app.float.common_image')) - .height($r('app.float.common_image')) - .onClick(() => { - router.back(); - }) + .width(CommonConstants.FULL_WIDTH_PERCENT) + .justifyContent(FlexAlign.SpaceBetween) } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .justifyContent(FlexAlign.SpaceBetween) - } - GridCol({ - span: { - sm: CommonConstants.COLUMN_SM, - md: CommonConstants.COLUMN_MD, - lg: CommonConstants.COLUMN_LG - } - }) { - Column() { - Row() { + GridCol({ + span: { + sm: CommonConstants.COLUMN_SM, + md: CommonConstants.COLUMN_MD, + lg: CommonConstants.COLUMN_LG + } + }) { + Column() { Row({ space: FundConstants.BOTTOM_ROW_SPACE }) { Text($r('app.string.performance_trends')) - .fontSize($r('app.float.tab_text_size')) + .fontSize($r('app.float.tab_text_size_fund')) .lineHeight($r('app.float.common_line_height')) .fontColor(this.tabBarIndex === 0 ? $r('app.color.harmony_blue') : Color.Black) .border({ @@ -151,7 +123,7 @@ struct TrendsPage { this.controller.changeIndex(this.tabBarIndex); }) Text($r('app.string.unit_net_value')) - .fontSize($r('app.float.tab_text_size')) + .fontSize($r('app.float.tab_text_size_fund')) .lineHeight($r('app.float.common_line_height')) .fontColor(this.tabBarIndex === 1 ? $r('app.color.harmony_blue') : Color.Black) .border({ @@ -168,118 +140,151 @@ struct TrendsPage { this.controller.changeIndex(this.tabBarIndex); }) } - } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .justifyContent(FlexAlign.Start) - .alignItems(VerticalAlign.Center) - .margin({ - bottom: $r('app.float.tab_bar_top') - }) - .height($r('app.float.title_height')) + .width(CommonConstants.FULL_WIDTH_PERCENT) + .justifyContent(FlexAlign.Start) + .alignItems(VerticalAlign.Center) + .margin({ + bottom: $r('app.float.tab_bar_top') + }) + .height($r('app.float.title_height')) - Tabs({ controller: this.controller }) { - TabContent() { - Column() { - Row() { - ChartLegendComponent({ - name: $r('app.string.the_fund'), - color: $r('app.color.fund_chart'), - value: $r('app.string.the_fund_value') - }) - ChartLegendComponent({ - name: $r('app.string.same_average'), - color: $r('app.color.same_average_chart'), - value: $r('app.string.same_average_value') - }) - ChartLegendComponent({ - name: $r('app.string.other_funding'), - color: $r('app.color.other_funding_chart'), - value: $r('app.string.other_funding_value') + Tabs({ controller: this.controller }) { + TabContent() { + Column() { + Row() { + ChartLegendComponent({ + name: $r('app.string.the_fund'), + color: $r('app.color.fund_chart'), + value: $r('app.string.the_fund_value') + }) + ChartLegendComponent({ + name: $r('app.string.same_average'), + color: $r('app.color.same_average_chart'), + value: $r('app.string.same_average_value') + }) + ChartLegendComponent({ + name: $r('app.string.other_funding'), + color: $r('app.color.other_funding_chart'), + value: $r('app.string.other_funding_value') + }) + } + .width(CommonConstants.FULL_WIDTH_PERCENT) + .justifyContent(FlexAlign.SpaceBetween) + .padding({ + left: new BreakpointUtil({ + sm: $r('app.float.legend_padding_lr'), + md: $r('app.float.legend_padding_lr'), + lg: $r('app.float.legend_padding_lr_lg') + }).getValue(this.currentPoint), + right: new BreakpointUtil({ + sm: $r('app.float.legend_padding_lr'), + md: $r('app.float.legend_padding_lr'), + lg: $r('app.float.legend_padding_lr_lg') + }).getValue(this.currentPoint) }) - } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .justifyContent(FlexAlign.SpaceBetween) - .padding({ - left: new BreakpointUtil({ - sm: $r('app.float.legend_padding_lr'), - md: $r('app.float.legend_padding_lr'), - lg: $r('app.float.legend_padding_lr_lg') - }).getValue(this.currentPoint), - right: new BreakpointUtil({ - sm: $r('app.float.legend_padding_lr'), - md: $r('app.float.legend_padding_lr'), - lg: $r('app.float.legend_padding_lr_lg') - }).getValue(this.currentPoint) - }) - Row() { - if (this.showChart) { - LineChart({ model: this.lineChartModel }) - } else { - LineChart({ model: this.lineChartModel }) + Row() { + if (this.showChart) { + LineChart({ model: this.lineChartModel }) + } else { + LineChart({ model: this.lineChartModel }) + } } - } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .layoutWeight(1) - .onAreaChange(() => { - this.lineChartModel = ChartViewModel.getLineChartModel(); - this.showChart = !this.showChart; - }) + .width(CommonConstants.FULL_WIDTH_PERCENT) + .layoutWeight(1) + .onAreaChange(() => { + this.lineChartModel = ChartViewModel.getLineChartModel(); + this.showChart = !this.showChart; + }) - Row() { - Button($r('app.string.near_month', 1)) - .fontSize($r('app.float.chart_button_size')) - .fontColor($r('app.color.harmony_blue')) - .fontWeight(CommonConstants.FONT_WEIGHT_500) - .backgroundColor($r('app.color.five_percent_white')) - .height($r('app.float.chart_button_height')) - .width(new BreakpointUtil({ - sm: $r('app.float.near_button_width'), - md: $r('app.float.near_button_width'), - lg: $r('app.float.near_button_width_lg') - }).getValue(this.currentPoint)) - Button($r('app.string.near_month', 3)) - .chartButtonStyle() - Button($r('app.string.near_month', 6)) - .chartButtonStyle() - Button($r('app.string.near_year', 1)) - .chartButtonStyle() - Button($r('app.string.near_year', 3)) - .chartButtonStyle() + Row() { + Button($r('app.string.near_month', 1)) + .fontSize($r('app.float.chart_button_size')) + .fontColor($r('app.color.harmony_blue')) + .fontWeight(CommonConstants.FONT_WEIGHT_500) + .backgroundColor($r('app.color.five_percent_white_fund')) + .height($r('app.float.chart_button_height')) + .width(new BreakpointUtil({ + sm: $r('app.float.near_button_width'), + md: $r('app.float.near_button_width'), + lg: $r('app.float.near_button_width_lg') + }).getValue(this.currentPoint)) + Button($r('app.string.near_month', 3)) + .chartButtonStyle() + Button($r('app.string.near_month', 6)) + .chartButtonStyle() + Button($r('app.string.near_year', 1)) + .chartButtonStyle() + Button($r('app.string.near_year', 3)) + .chartButtonStyle() + } + .width(CommonConstants.FULL_WIDTH_PERCENT) + .justifyContent(FlexAlign.SpaceBetween) + .margin({ + top: $r('app.float.chart_button_margin') + }) } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .justifyContent(FlexAlign.SpaceBetween) - .margin({ - top: $r('app.float.chart_button_margin') - }) + .height(CommonConstants.FULL_HEIGHT_PERCENT) } - .height(CommonConstants.FULL_HEIGHT_PERCENT) - } - .tabBar($r('app.string.performance_trends')) + .tabBar($r('app.string.performance_trends')) - TabContent() { + TabContent() { + } + .tabBar($r('app.string.unit_net_value')) } - .tabBar($r('app.string.unit_net_value')) + .barMode(BarMode.Scrollable, { margin: $r('app.float.tab_bar_margin') }) + .barHeight(0) + .scrollable(false) + .layoutWeight(1) + .focusable(false) } - .barMode(BarMode.Scrollable, { margin: $r('app.float.tab_bar_margin') }) - .barHeight(0) - .scrollable(false) - .layoutWeight(1) - .focusable(false) } } + .width(CommonConstants.FULL_WIDTH_PERCENT) + .height(CommonConstants.FULL_HEIGHT_PERCENT) + .padding({ + left: $r('app.float.padding_common'), + right: this.isLandScape ? this.areaLeft : $r('app.float.padding_common'), + bottom: $r('app.float.padding_common'), + top: this.currentPoint === CommonConstants.BREAK_POINT_LG ? $r('app.float.trends_padding_top') : 0 + }) + .onBreakpointChange((breakpoints: string) => { + this.currentPoint = breakpoints; + }) } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .height(CommonConstants.FULL_HEIGHT_PERCENT) - .padding({ - left: $r('app.float.padding_common'), - right: this.isLandScape ? this.areaLeft : $r('app.float.padding_common'), - bottom: $r('app.float.padding_common'), - top: this.currentPoint === CommonConstants.BREAK_POINT_LG ? $r('app.float.trends_padding_top') : 0 + .hideTitleBar(true) + .onAppear(() => { + window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { + windowStage.setWindowLayoutFullScreen(false); + }) + if (!this.isLandScape && this.breakPoint === CommonConstants.BREAK_POINT_SM) { + window.getLastWindow(getContext(this)).then((stage: window.Window) => { + stage.setPreferredOrientation(window.Orientation.LANDSCAPE); + this.isLandScape = true; + }); + } + try { + display.on('foldDisplayModeChange', this.callback); + } catch (exception) { + logger.error('Failed to register callback. Code: ' + JSON.stringify(exception)); + } }) - .onBreakpointChange((breakpoints: string) => { - this.currentPoint = breakpoints; + .onWillDisappear(() => { + window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { + windowStage.setWindowLayoutFullScreen(true); + }) + if (this.isLandScape) { + window.getLastWindow(getContext(this)).then((stage: window.Window) => { + stage.setPreferredOrientation(window.Orientation.PORTRAIT); + }); + this.isLandScape = false; + } + try { + display.off('foldDisplayModeChange', this.callback); + } catch (exception) { + logger.error('Failed to register callback. Code: ' + JSON.stringify(exception)); + } }) } } diff --git a/features/fund/src/main/ets/viewmodel/FundingViewModel.ets b/features/fund/src/main/ets/viewmodel/FundingViewModel.ets index f7fdc89..a36648e 100644 --- a/features/fund/src/main/ets/viewmodel/FundingViewModel.ets +++ b/features/fund/src/main/ets/viewmodel/FundingViewModel.ets @@ -24,11 +24,11 @@ class FundingViewModel { new BusinessInfo($r('app.media.ic_ranking'), $r('app.string.funding_ranking')), new BusinessInfo($r('app.media.ic_index_zone'), $r('app.string.funding_index_zone')), new BusinessInfo($r('app.media.ic_fixed_investment'), $r('app.string.fixed_investment')), - new BusinessInfo($r("app.media.ic_public_Investment_star"), $r('app.string.investment_star_selection')), - new BusinessInfo($r("app.media.ic_good_chance"), $r('app.string.funding_good_chance')), - new BusinessInfo($r("app.media.ic_folder_add"), $r('app.string.funding_folder_add')), - new BusinessInfo($r("app.media.ic_folder_add"), $r('app.string.funding_folder_add')), - new BusinessInfo($r("app.media.ic_folder_add"), $r('app.string.funding_folder_add')) + new BusinessInfo($r('app.media.ic_public_Investment_star'), $r('app.string.investment_star_selection')), + new BusinessInfo($r('app.media.ic_good_chance'), $r('app.string.funding_good_chance')), + new BusinessInfo($r('app.media.ic_folder_add'), $r('app.string.funding_folder_add')), + new BusinessInfo($r('app.media.ic_folder_add'), $r('app.string.funding_folder_add')), + new BusinessInfo($r('app.media.ic_folder_add'), $r('app.string.funding_folder_add')) ]; return fundingBusinessInfoList.slice(start, end); } diff --git a/features/fund/src/main/module.json5 b/features/fund/src/main/module.json5 index f77feae..c023333 100644 --- a/features/fund/src/main/module.json5 +++ b/features/fund/src/main/module.json5 @@ -1,14 +1,12 @@ { "module": { "name": "fund", - "type": "shared", + "type": "har", "description": "$string:shared_desc", "deviceTypes": [ "phone", "tablet", "2in1" - ], - "deliveryWithInstall": true, - "pages": "$profile:main_pages" + ] } } \ No newline at end of file diff --git a/features/fund/src/main/resources/base/element/color.json b/features/fund/src/main/resources/base/element/color.json index 43bda08..38c6f30 100644 --- a/features/fund/src/main/resources/base/element/color.json +++ b/features/fund/src/main/resources/base/element/color.json @@ -9,7 +9,7 @@ "value": "#0dffffff" }, { - "name": "five_percent_white", + "name": "five_percent_white_fund", "value": "#0d000000" }, { diff --git a/features/fund/src/main/resources/base/element/float.json b/features/fund/src/main/resources/base/element/float.json index 41acf91..bbc471c 100644 --- a/features/fund/src/main/resources/base/element/float.json +++ b/features/fund/src/main/resources/base/element/float.json @@ -329,8 +329,8 @@ "value": "10vp" }, { - "name": "tab_text_size", - "value": "16vp" + "name": "tab_text_size_fund", + "value": "16fp" }, { "name": "tab_bar_padding_bottom", diff --git a/features/fund/src/main/resources/base/profile/main_pages.json b/features/fund/src/main/resources/base/profile/main_pages.json index a701dee..9a81b4e 100644 --- a/features/fund/src/main/resources/base/profile/main_pages.json +++ b/features/fund/src/main/resources/base/profile/main_pages.json @@ -1,7 +1,7 @@ { "src": [ - "pages/Funding", - "pages/FundingDetail", - "pages/TrendsPage" + "view/Funding", + "view/FundingDetail", + "view/TrendsPage" ] } \ No newline at end of file diff --git a/features/fundComparison/Index.ets b/features/fundComparison/Index.ets index 44289cb..81aa5de 100644 --- a/features/fundComparison/Index.ets +++ b/features/fundComparison/Index.ets @@ -1,3 +1,4 @@ -export { ComparisonComponent } from "./src/main/ets/view/ComparisonComponent" -export { ComparisonDetailComponent } from "./src/main/ets/view/ComparisonDetailComponent" -export { ComparisonInfo } from "./src/main/ets/viewmodel/ComparisonInfo" \ No newline at end of file +export { ComparisonComponent } from './src/main/ets/view/ComparisonComponent'; +export { ComparisonDetailComponent } from './src/main/ets/view/ComparisonDetailComponent'; +export { ComparisonInfo } from './src/main/ets/viewmodel/ComparisonInfo'; +export { ComparisonDetailPage } from './src/main/ets/view/ComparisonDetailPage'; \ No newline at end of file diff --git a/features/fundComparison/hvigorfile.ts b/features/fundComparison/hvigorfile.ts index d993120..4218707 100644 --- a/features/fundComparison/hvigorfile.ts +++ b/features/fundComparison/hvigorfile.ts @@ -1,6 +1,6 @@ -import { hspTasks } from '@ohos/hvigor-ohos-plugin'; +import { harTasks } from '@ohos/hvigor-ohos-plugin'; export default { - system: hspTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ + system: harTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ plugins:[] /* Custom plugin to extend the functionality of Hvigor. */ } diff --git a/features/fundComparison/src/main/ets/view/ComparisonComponent.ets b/features/fundComparison/src/main/ets/view/ComparisonComponent.ets index bcc7b32..87d7bfd 100644 --- a/features/fundComparison/src/main/ets/view/ComparisonComponent.ets +++ b/features/fundComparison/src/main/ets/view/ComparisonComponent.ets @@ -21,7 +21,7 @@ import { ComparisonConstants } from '../constants/ComparisonConstants'; @Component export struct ComparisonComponent { - @State currentPoint: string = CommonConstants.BREAK_POINT_SM; + @StorageLink('breakPoint') currentPoint: string = CommonConstants.BREAK_POINT_SM; @State chooseComparison: ComparisonInfo[] = []; @State map: TreeMap = new TreeMap(); @State defaultAllComparison: ComparisonInfo[] = FundComparisonViewModel.getFundComparisonList(); @@ -156,7 +156,7 @@ export struct ComparisonComponent { width: { bottom: $r('app.float.common_border_width') }, - color: $r('app.color.five_percent_white') + color: $r('app.color.five_percent_white_fund') }) .alignItems(HorizontalAlign.Start) .padding({ @@ -167,7 +167,7 @@ export struct ComparisonComponent { }) } } - .height($r("app.float.list_item_height")) + .height($r('app.float.list_item_height_comparison')) }) } .lanes(this.currentPoint === CommonConstants.BREAK_POINT_SM ? 1 : 2) @@ -188,7 +188,7 @@ export struct ComparisonComponent { Column() { Row({ space: ComparisonConstants.CHOOSE_LIST_SPACE }) { Text($r('app.string.no_currency', this.chooseComparison.length)) - .fontSize($r('app.float.tab_text_size')) + .fontSize($r('app.float.tab_text_size_fund')) .lineHeight($r('app.float.common_line_height')) .fontColor(this.tabBarIndex === 0 ? $r('app.color.harmony_blue') : Color.Black) .onClick(() => { @@ -196,7 +196,7 @@ export struct ComparisonComponent { this.controller.changeIndex(this.tabBarIndex); }) Text($r('app.string.currency_bar', 0)) - .fontSize($r('app.float.tab_text_size')) + .fontSize($r('app.float.tab_text_size_fund')) .lineHeight($r('app.float.common_line_height')) .fontColor(this.tabBarIndex === 1 ? $r('app.color.harmony_blue') : Color.Black) .onClick(() => { @@ -219,7 +219,7 @@ export struct ComparisonComponent { Text(item.name) .fontSize($r('app.float.stack_text_size')) } - .backgroundColor($r('app.color.five_percent_white')) + .backgroundColor($r('app.color.five_percent_white_fund')) .borderRadius($r('app.float.row_border_radius')) .padding({ top: $r('app.float.stack_row_padding_top'), @@ -281,7 +281,7 @@ export struct ComparisonComponent { } Button($r('app.string.start_comparison')) - .backgroundColor($r("app.color.start_button_background")) + .backgroundColor($r('app.color.start_button_background')) .width(this.currentPoint === CommonConstants.BREAK_POINT_SM ? $r('app.float.start_button_width_sm') : $r('app.float.start_button_width')) .height($r('app.float.start_button_height')) @@ -325,9 +325,6 @@ export struct ComparisonComponent { right: $r('app.float.comparison_padding_right'), bottom: $r('app.float.comparison_padding_bottom') }) - .onBreakpointChange((breakpoints: string) => { - this.currentPoint = breakpoints; - }) } .hideTitleBar(true) } diff --git a/features/fundComparison/src/main/ets/view/ComparisonDetailComponent.ets b/features/fundComparison/src/main/ets/view/ComparisonDetailComponent.ets index 34b9968..c341be8 100644 --- a/features/fundComparison/src/main/ets/view/ComparisonDetailComponent.ets +++ b/features/fundComparison/src/main/ets/view/ComparisonDetailComponent.ets @@ -13,7 +13,6 @@ * limitations under the License. */ -import { router } from '@kit.ArkUI'; import { CommonConstants, RouterConstants } from '@ohos/basic'; import { ComparisonConstants } from '../constants/ComparisonConstants'; import { ComparisonInfo } from '../viewmodel/ComparisonInfo'; @@ -27,6 +26,7 @@ export struct ComparisonDetailComponent { @StorageLink('pageInfo') pageInfo: NavPathStack = new NavPathStack(); @State isPage: Boolean = false; @StorageProp('breakPoint') currentPoint: string = CommonConstants.BREAK_POINT_SM; + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); private nameColorArr: ResourceColor[] = [ $r('app.color.name_color_1'), $r('app.color.name_color_2'), @@ -47,7 +47,7 @@ export struct ComparisonDetailComponent { }) .onClick(() => { if (this.isPage) { - router.back(); + this.pageIndexInfos.pop(); } else { this.pageInfo.pop(); } @@ -58,17 +58,15 @@ export struct ComparisonDetailComponent { .width($r('app.float.common_image')) .height($r('app.float.common_image')) .onClick(() => { - router.back(); + this.pageIndexInfos.pop(); }) } else { Image($r('app.media.ic_public_enlarge')) .width($r('app.float.common_image')) .height($r('app.float.common_image')) .onClick(() => { - router.pushUrl({ - url: RouterConstants.COMPARISON_PAGE_URL, - params: { chooseComparison: this.chooseComparison } - }) + this.pageIndexInfos.pushPathByName(RouterConstants.COMPARISON_PAGE_URL, + { 'chooseComparison': this.chooseComparison } as Record); }) } } @@ -81,7 +79,7 @@ export struct ComparisonDetailComponent { .height($r('app.float.common_image')) .onClick(() => { if (this.isPage) { - router.back(); + this.pageIndexInfos.pop(); } else { this.pageInfo.pop(); } @@ -176,7 +174,7 @@ export struct ComparisonDetailComponent { Divider() .width(CommonConstants.FULL_WIDTH_PERCENT) - .height($r("app.float.common_divider")) + .height($r('app.float.common_divider')) .backgroundColor($r('app.color.divider_background')) .margin({ top: $r('app.float.divider_margin_top'), @@ -214,7 +212,7 @@ export struct ComparisonDetailComponent { }) .width($r('app.float.list_head_width')) .divider({ - strokeWidth: $r("app.float.common_divider"), + strokeWidth: $r('app.float.common_divider'), color: $r('app.color.ten_percent_white') }) @@ -277,12 +275,12 @@ export struct ComparisonDetailComponent { .listStyle() } .divider({ - strokeWidth: $r("app.float.common_divider"), + strokeWidth: $r('app.float.common_divider'), color: $r('app.color.ten_percent_white') }) .width($r('app.float.scroll_list_width')) .border({ - width: $r("app.float.common_divider"), + width: $r('app.float.common_divider'), color: $r('app.color.ten_percent_white') }) }) diff --git a/features/fundComparison/src/main/ets/pages/ComparisonDetailPage.ets b/features/fundComparison/src/main/ets/view/ComparisonDetailPage.ets similarity index 73% rename from features/fundComparison/src/main/ets/pages/ComparisonDetailPage.ets rename to features/fundComparison/src/main/ets/view/ComparisonDetailPage.ets index 57ad670..4b06aa9 100644 --- a/features/fundComparison/src/main/ets/pages/ComparisonDetailPage.ets +++ b/features/fundComparison/src/main/ets/view/ComparisonDetailPage.ets @@ -13,19 +13,18 @@ * limitations under the License. */ -import { router } from '@kit.ArkUI'; -import { ComparisonDetailComponent } from '../view/ComparisonDetailComponent'; +import { ComparisonDetailComponent } from './ComparisonDetailComponent'; import { ComparisonInfo } from '../viewmodel/ComparisonInfo'; +import { CommonConstants } from '@ohos/basic'; -@Entry @Component -struct ComparisonDetailPage { - @State chooseComparison: ComparisonInfo[] = (router.getParams() as Record)['chooseComparison']; +export struct ComparisonDetailPage { + @State chooseComparison: ComparisonInfo[] = []; build() { Row() { ComparisonDetailComponent({ chooseComparison: this.chooseComparison, isPage: true }) } - .height('100%') + .height(CommonConstants.FULL_HEIGHT_PERCENT) } } \ No newline at end of file diff --git a/features/fundComparison/src/main/module.json5 b/features/fundComparison/src/main/module.json5 index e4dbff6..f242d81 100644 --- a/features/fundComparison/src/main/module.json5 +++ b/features/fundComparison/src/main/module.json5 @@ -1,14 +1,12 @@ { "module": { "name": "fundComparison", - "type": "shared", + "type": "har", "description": "$string:shared_desc", "deviceTypes": [ "phone", "tablet", "2in1" - ], - "deliveryWithInstall": true, - "pages": "$profile:main_pages" + ] } } \ No newline at end of file diff --git a/features/fundComparison/src/main/resources/base/element/color.json b/features/fundComparison/src/main/resources/base/element/color.json index 89e96ac..5aab27a 100644 --- a/features/fundComparison/src/main/resources/base/element/color.json +++ b/features/fundComparison/src/main/resources/base/element/color.json @@ -9,7 +9,7 @@ "value": "#0dffffff" }, { - "name": "five_percent_white", + "name": "five_percent_white_fund", "value": "#0d000000" }, { diff --git a/features/fundComparison/src/main/resources/base/element/float.json b/features/fundComparison/src/main/resources/base/element/float.json index 439663b..a419549 100644 --- a/features/fundComparison/src/main/resources/base/element/float.json +++ b/features/fundComparison/src/main/resources/base/element/float.json @@ -53,7 +53,7 @@ "value": "16vp" }, { - "name": "list_item_height", + "name": "list_item_height_comparison", "value": "64vp" }, { @@ -277,8 +277,8 @@ "value": "80vp" }, { - "name": "tab_text_size", - "value": "16vp" + "name": "tab_text_size_fund", + "value": "16fp" }, { "name": "search_width", diff --git a/features/fundComparison/src/main/resources/base/profile/main_pages.json b/features/fundComparison/src/main/resources/base/profile/main_pages.json deleted file mode 100644 index 143a64e..0000000 --- a/features/fundComparison/src/main/resources/base/profile/main_pages.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "src": [ - "pages/ComparisonDetailPage" - ] -} - diff --git a/features/home/Index.ets b/features/home/Index.ets index 73dd4a7..4afbb64 100644 --- a/features/home/Index.ets +++ b/features/home/Index.ets @@ -1,2 +1,3 @@ -export { AdvertisementDialog } from "./src/main/ets/view/AdvertisementDialog" -export { HomeComponent } from "./src/main/ets/view/HomeComponent" \ No newline at end of file +export { AdvertisementDialog } from './src/main/ets/view/AdvertisementDialog'; +export { HomeComponent } from './src/main/ets/view/HomeComponent'; +export { AccountPage } from './src/main/ets/view/AccountPage'; \ No newline at end of file diff --git a/features/home/hvigorfile.ts b/features/home/hvigorfile.ts index d993120..4218707 100644 --- a/features/home/hvigorfile.ts +++ b/features/home/hvigorfile.ts @@ -1,6 +1,6 @@ -import { hspTasks } from '@ohos/hvigor-ohos-plugin'; +import { harTasks } from '@ohos/hvigor-ohos-plugin'; export default { - system: hspTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ + system: harTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ plugins:[] /* Custom plugin to extend the functionality of Hvigor. */ } diff --git a/features/home/src/main/ets/constants/HomeConstants.ets b/features/home/src/main/ets/constants/HomeConstants.ets index e5f9615..ca4de34 100644 --- a/features/home/src/main/ets/constants/HomeConstants.ets +++ b/features/home/src/main/ets/constants/HomeConstants.ets @@ -50,12 +50,12 @@ export class HomeConstants { /** * List sliding offset. */ - static readonly LIST_SLIDING_OFFSET: number = -750; + static readonly LIST_SLIDING_OFFSET: number = -250; /** * List sliding offset under lg power outage. */ - static readonly LIST_SLIDING_OFFSET_LG: number = -450; + static readonly LIST_SLIDING_OFFSET_LG: number = -150; /** * Get business data start index. diff --git a/features/home/src/main/ets/view/AccountComponent.ets b/features/home/src/main/ets/view/AccountComponent.ets index fda1ed8..3f42f68 100644 --- a/features/home/src/main/ets/view/AccountComponent.ets +++ b/features/home/src/main/ets/view/AccountComponent.ets @@ -13,7 +13,6 @@ * limitations under the License. */ -import { router } from '@kit.ArkUI'; import { CommonConstants } from '@ohos/basic/Index'; import { DemandDepositComponent } from './DemandDepositComponent'; import { InvestmentComponent } from './InvestmentComponent'; @@ -22,9 +21,10 @@ import { LiabilitiesComponent } from './LiabilitiesComponent'; @Preview @Component export struct AccountComponent { - @State breakPoint: string = CommonConstants.BREAK_POINT_SM; + @StorageLink('breakPoint') breakPoint: string = CommonConstants.BREAK_POINT_SM; @StorageProp('avoidArea') topHeight: number = 0; @StorageProp('bottom') bottom: number = 0; + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); build() { GridRow({ @@ -53,7 +53,7 @@ export struct AccountComponent { .height($r('app.float.common_image_height')) .fillColor(Color.White) .onClick(() => { - router.back() + this.pageIndexInfos.pop(); }) Text($r('app.string.account_all_info')) .fontSize($r('app.float.account_font_size')) @@ -83,15 +83,13 @@ export struct AccountComponent { $r('app.float.account_margin_top_lg') : $r('app.float.account_margin_top') }) Row() { - Row() { - Text($r('app.string.yesterday_earnings')) - .fontSize($r('app.float.account_small_font_size')) - .fontColor(Color.White) - } - .backgroundColor($r('app.color.five_percent_white')) - .padding($r('app.float.account_padding')) - .borderRadius($r('app.float.earnings_radius')) + Text($r('app.string.yesterday_earnings')) + .fontSize($r('app.float.account_small_font_size')) + .fontColor(Color.White) } + .backgroundColor($r('app.color.five_percent_white')) + .padding($r('app.float.account_padding')) + .borderRadius($r('app.float.earnings_radius')) .margin({ top: $r('app.float.account_margin'), bottom: this.breakPoint === CommonConstants.BREAK_POINT_LG ? @@ -226,9 +224,6 @@ export struct AccountComponent { }) } .backgroundColor($r('app.color.account_background')) - .onBreakpointChange((breakpoints: string) => { - this.breakPoint = breakpoints; - }) } @Builder diff --git a/features/home/src/main/ets/pages/AccountPage.ets b/features/home/src/main/ets/view/AccountPage.ets similarity index 94% rename from features/home/src/main/ets/pages/AccountPage.ets rename to features/home/src/main/ets/view/AccountPage.ets index 1a0b3fb..6c10a7c 100644 --- a/features/home/src/main/ets/pages/AccountPage.ets +++ b/features/home/src/main/ets/view/AccountPage.ets @@ -15,11 +15,10 @@ import { window } from '@kit.ArkUI'; import { CommonConstants } from '@ohos/basic/Index'; -import { AccountComponent } from '../view/AccountComponent'; +import { AccountComponent } from './AccountComponent'; -@Entry @Component -struct AccountPage { +export struct AccountPage { @StorageProp('avoidArea') topHeight: number = 0; onPageShow() { diff --git a/features/home/src/main/ets/view/DemandDepositComponent.ets b/features/home/src/main/ets/view/DemandDepositComponent.ets index 7dae8d0..1508377 100644 --- a/features/home/src/main/ets/view/DemandDepositComponent.ets +++ b/features/home/src/main/ets/view/DemandDepositComponent.ets @@ -29,7 +29,7 @@ export struct DemandDepositComponent { this.buildImageArrowRight() } .justifyContent(FlexAlign.SpaceBetween) - .height($r("app.float.account_common_height")) + .height($r('app.float.account_common_height')) Text($r('app.string.save_card_account')) .fontSize($r('app.float.account_big_font')) @@ -46,7 +46,7 @@ export struct DemandDepositComponent { this.buildImageArrowRight() } .justifyContent(FlexAlign.SpaceBetween) - .height($r("app.float.account_common_height")) + .height($r('app.float.account_common_height')) Text($r('app.string.current_deposit_count')) .fontSize($r('app.float.account_big_font')) .lineHeight($r('app.float.common_line_height')) @@ -61,7 +61,7 @@ export struct DemandDepositComponent { this.buildImageArrowRight() } .justifyContent(FlexAlign.SpaceBetween) - .height($r("app.float.account_common_height")) + .height($r('app.float.account_common_height')) Column() { Text($r('app.string.day_day_count')) .fontSize($r('app.float.account_big_font')) @@ -206,7 +206,7 @@ export struct DemandDepositComponent { function buildDemandRowStyles() { .width(CommonConstants.FULL_WIDTH_PERCENT) .justifyContent(FlexAlign.SpaceBetween) - .height($r("app.float.account_common_height")) + .height($r('app.float.account_common_height')) } @Extend(Column) diff --git a/features/home/src/main/ets/view/HomeComponent.ets b/features/home/src/main/ets/view/HomeComponent.ets index b07278e..c51f412 100644 --- a/features/home/src/main/ets/view/HomeComponent.ets +++ b/features/home/src/main/ets/view/HomeComponent.ets @@ -13,7 +13,6 @@ * limitations under the License. */ -import { router } from '@kit.ArkUI'; import { BreakpointUtil, BusinessInfo, CommonConstants, RouterConstants } from '@ohos/basic'; import { HomeConstants } from '../constants/HomeConstants'; import HomeViewModel from '../viewmodel/HomeViewModel'; @@ -22,6 +21,7 @@ import HomeViewModel from '../viewmodel/HomeViewModel'; export struct HomeComponent { @Prop currentPoint: string = CommonConstants.BREAK_POINT_SM; @Link scrollY: number; + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); private offsetValue: number = 0; build() { @@ -57,13 +57,13 @@ export struct HomeComponent { .placeholderColor(this.scrollY < HomeConstants.LIST_SLIDING_OFFSET || (this.currentPoint === CommonConstants.BREAK_POINT_LG && this.scrollY < HomeConstants.LIST_SLIDING_OFFSET_LG) ? - $r('app.color.sixty_percent_black') : $r('app.color.sixty_percent_white')) + $r('app.color.sixty_percent_black_home') : $r('app.color.sixty_percent_white_home')) .enableKeyboardOnFocus(false) .searchIcon({ color: this.scrollY < HomeConstants.LIST_SLIDING_OFFSET || (this.currentPoint === CommonConstants.BREAK_POINT_LG && this.scrollY < HomeConstants.LIST_SLIDING_OFFSET_LG) ? - $r('app.color.sixty_percent_black') : $r('app.color.sixty_percent_white') + $r('app.color.sixty_percent_black_home') : $r('app.color.sixty_percent_white_home') }) Image($r('app.media.ic_public_comments')) @@ -173,9 +173,7 @@ export struct HomeComponent { .width(CommonConstants.FULL_WIDTH_PERCENT) .borderRadius($r('app.float.list_image_radius')) .onClick(() => { - router.pushUrl({ - url: RouterConstants.FUNDING_URL - }) + this.pageIndexInfos.pushPathByName(RouterConstants.FUNDING_URL, null); }) } }, (item: BusinessInfo, index: number) => index + JSON.stringify(item)) @@ -193,12 +191,12 @@ export struct HomeComponent { bottom: $r('app.float.common_height') }) .scrollBar(BarState.Off) - .onScroll((xOffset: number, yOffset: number) => { + .onWillScroll((xOffset: number, yOffset: number) => { this.offsetValue = this.offsetValue - yOffset; if (this.offsetValue > 0) { this.offsetValue = 0; } - this.scrollY = vp2px(this.offsetValue) + this.scrollY = vp2px(this.offsetValue); }) } .height(CommonConstants.FULL_HEIGHT_PERCENT) @@ -226,9 +224,7 @@ export struct HomeComponent { } .onClick(() => { if (item.router) { - router.pushUrl({ - url: item.router - }) + this.pageIndexInfos.pushPathByName(item.router, null); } }) } else { @@ -257,9 +253,7 @@ export struct HomeComponent { .backgroundColor($r('app.color.business_background')) .onClick(() => { if (item.router) { - router.pushUrl({ - url: item.router - }) + this.pageIndexInfos.pushPathByName(item.router, null); } }) } diff --git a/features/home/src/main/ets/view/LiabilitiesComponent.ets b/features/home/src/main/ets/view/LiabilitiesComponent.ets index 7b04cdb..f274054 100644 --- a/features/home/src/main/ets/view/LiabilitiesComponent.ets +++ b/features/home/src/main/ets/view/LiabilitiesComponent.ets @@ -21,127 +21,125 @@ export struct LiabilitiesComponent { build() { Column() { - Column() { - Row() { - Text($r('app.string.credit_card_account')) - .fontSize($r('app.float.account_font_size')) - .lineHeight($r('app.float.common_line_height')) - .fontWeight(CommonConstants.FONT_WEIGHT_500) - Image($r('app.media.ic_public_more_list')) - .width($r('app.float.common_image_width')) - .height($r('app.float.common_image_height')) - } - .buildRowStyles() + Row() { + Text($r('app.string.credit_card_account')) + .fontSize($r('app.float.account_font_size')) + .lineHeight($r('app.float.common_line_height')) + .fontWeight(CommonConstants.FONT_WEIGHT_500) + Image($r('app.media.ic_public_more_list')) + .width($r('app.float.common_image_width')) + .height($r('app.float.common_image_height')) + } + .buildRowStyles() - Flex({ - direction: this.breakPoint === CommonConstants.BREAK_POINT_SM ? FlexDirection.Column : FlexDirection.Row - }) { - if (this.breakPoint !== CommonConstants.BREAK_POINT_SM) { - Column() { - Row() { - Text($r('app.string.remaining_available_count')) - .fontSize(this.breakPoint === CommonConstants.BREAK_POINT_LG ? - $r('app.float.account_big_font') : $r('app.float.account_font_size')) - .lineHeight($r('app.float.common_line_height')) - .fontWeight(CommonConstants.FONT_WEIGHT_500) - this.buildImageArrowRight() - } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .justifyContent(FlexAlign.SpaceBetween) - Row() { - Text($r('app.string.remaining_available_amount')) - .fontSize($r('app.float.account_small_font_size')) - .lineHeight($r('app.float.small_line_height')) - .opacity(0.6) - } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .justifyContent(FlexAlign.Start) + Flex({ + direction: this.breakPoint === CommonConstants.BREAK_POINT_SM ? FlexDirection.Column : FlexDirection.Row + }) { + if (this.breakPoint !== CommonConstants.BREAK_POINT_SM) { + Column() { + Row() { + Text($r('app.string.remaining_available_count')) + .fontSize(this.breakPoint === CommonConstants.BREAK_POINT_LG ? + $r('app.float.account_big_font') : $r('app.float.account_font_size')) + .lineHeight($r('app.float.common_line_height')) + .fontWeight(CommonConstants.FONT_WEIGHT_500) + this.buildImageArrowRight() } - Divider() - .vertical(true) - .height($r('app.float.liabilities_divider_height')) - .width($r('app.float.divider_width')) - .color($r('app.color.divider_color')) - .margin({ - left: $r('app.float.divider_margin'), - right: $r('app.float.divider_margin') - }) - Column() { - Row() { - Text($r('app.string.remaining_due_count')) - .fontSize(this.breakPoint === CommonConstants.BREAK_POINT_LG ? - $r('app.float.account_big_font') : $r('app.float.account_font_size')) - .lineHeight($r('app.float.common_line_height')) - .fontWeight(CommonConstants.FONT_WEIGHT_500) - this.buildImageArrowRight() - } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .justifyContent(FlexAlign.SpaceBetween) - Row() { - Text($r('app.string.remaining_due')) - .fontSize($r('app.float.amount_font_size')) - .lineHeight($r('app.float.small_line_height')) - .opacity(0.6) - } - .width(CommonConstants.FULL_WIDTH_PERCENT) - .justifyContent(FlexAlign.Start) + .width(CommonConstants.FULL_WIDTH_PERCENT) + .justifyContent(FlexAlign.SpaceBetween) + Row() { + Text($r('app.string.remaining_available_amount')) + .fontSize($r('app.float.account_small_font_size')) + .lineHeight($r('app.float.small_line_height')) + .opacity(0.6) } - } else { + .width(CommonConstants.FULL_WIDTH_PERCENT) + .justifyContent(FlexAlign.Start) + } + Divider() + .vertical(true) + .height($r('app.float.liabilities_divider_height')) + .width($r('app.float.divider_width')) + .color($r('app.color.divider_color')) + .margin({ + left: $r('app.float.divider_margin'), + right: $r('app.float.divider_margin') + }) + Column() { Row() { - Text() { - Span($r('app.string.remaining_available_amount')) - .fontSize($r('app.float.account_small_font_size')) - .lineHeight($r('app.float.small_line_height')) - .opacity(0.6) - Span($r('app.string.remaining_available_count')) - .fontSize($r('app.float.account_font_size')) - .lineHeight($r('app.float.small_line_height')) - .fontWeight(CommonConstants.FONT_WEIGHT_500) - } + Text($r('app.string.remaining_due_count')) + .fontSize(this.breakPoint === CommonConstants.BREAK_POINT_LG ? + $r('app.float.account_big_font') : $r('app.float.account_font_size')) + .lineHeight($r('app.float.common_line_height')) + .fontWeight(CommonConstants.FONT_WEIGHT_500) this.buildImageArrowRight() } - .buildRowStyles() - + .width(CommonConstants.FULL_WIDTH_PERCENT) + .justifyContent(FlexAlign.SpaceBetween) Row() { - Text() { - Span($r('app.string.remaining_due')) - .fontSize($r('app.float.amount_font_size')) - .lineHeight($r('app.float.small_line_height')) - .opacity(0.6) - Span($r('app.string.remaining_due_count')) - .fontSize($r('app.float.account_font_size')) - .lineHeight($r('app.float.common_line_height')) - .fontWeight(CommonConstants.FONT_WEIGHT_500) - } - this.buildImageArrowRight() + Text($r('app.string.remaining_due')) + .fontSize($r('app.float.amount_font_size')) + .lineHeight($r('app.float.small_line_height')) + .opacity(0.6) } - .buildRowStyles() + .width(CommonConstants.FULL_WIDTH_PERCENT) + .justifyContent(FlexAlign.Start) } + } else { + Row() { + Text() { + Span($r('app.string.remaining_available_amount')) + .fontSize($r('app.float.account_small_font_size')) + .lineHeight($r('app.float.small_line_height')) + .opacity(0.6) + Span($r('app.string.remaining_available_count')) + .fontSize($r('app.float.account_font_size')) + .lineHeight($r('app.float.small_line_height')) + .fontWeight(CommonConstants.FONT_WEIGHT_500) + } + this.buildImageArrowRight() + } + .buildRowStyles() + + Row() { + Text() { + Span($r('app.string.remaining_due')) + .fontSize($r('app.float.amount_font_size')) + .lineHeight($r('app.float.small_line_height')) + .opacity(0.6) + Span($r('app.string.remaining_due_count')) + .fontSize($r('app.float.account_font_size')) + .lineHeight($r('app.float.common_line_height')) + .fontWeight(CommonConstants.FONT_WEIGHT_500) + } + this.buildImageArrowRight() + } + .buildRowStyles() } - .height($r('app.float.liabilities_item_height')) } - .margin({ - right: new BreakpointUtil({ - sm: $r('app.float.account_margin'), - md: $r('app.float.margin_common'), - lg: 0 - }).getValue(this.breakPoint), - left: new BreakpointUtil({ - sm: $r('app.float.account_margin'), - md: $r('app.float.margin_common'), - lg: 0 - }).getValue(this.breakPoint) - }) - .padding({ - top: $r('app.float.account_item_padding_tb'), - bottom: $r('app.float.account_item_padding_tb'), - right: $r('app.float.account_item_padding_rl'), - left: $r('app.float.account_item_padding_rl') - }) - .backgroundColor(Color.White) - .borderRadius($r('app.float.common_radius')) + .height($r('app.float.liabilities_item_height')) } .height($r('app.float.liabilities_height')) + .margin({ + right: new BreakpointUtil({ + sm: $r('app.float.account_margin'), + md: $r('app.float.margin_common'), + lg: 0 + }).getValue(this.breakPoint), + left: new BreakpointUtil({ + sm: $r('app.float.account_margin'), + md: $r('app.float.margin_common'), + lg: 0 + }).getValue(this.breakPoint) + }) + .padding({ + top: $r('app.float.account_item_padding_tb'), + bottom: $r('app.float.account_item_padding_tb'), + right: $r('app.float.account_item_padding_rl'), + left: $r('app.float.account_item_padding_rl') + }) + .backgroundColor(Color.White) + .borderRadius($r('app.float.common_radius')) } @Builder diff --git a/features/home/src/main/ets/viewmodel/HomeViewModel.ets b/features/home/src/main/ets/viewmodel/HomeViewModel.ets index 87c7c27..a7b0497 100644 --- a/features/home/src/main/ets/viewmodel/HomeViewModel.ets +++ b/features/home/src/main/ets/viewmodel/HomeViewModel.ets @@ -97,16 +97,16 @@ class HomeViewModel { new BusinessInfo($r('app.media.ic_list_paper'), $r('app.string.home_list')), new BusinessInfo($r('app.media.ic_list_contracts'), $r('app.string.home_list')), new BusinessInfo($r('app.media.ic_list_hello'), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_money"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')), - new BusinessInfo($r("app.media.ic_list_business"), $r('app.string.home_list')) + new BusinessInfo($r('app.media.ic_list_money'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')), + new BusinessInfo($r('app.media.ic_list_business'), $r('app.string.home_list')) ]; return listBusinessInfoList; } diff --git a/features/home/src/main/module.json5 b/features/home/src/main/module.json5 index 2c96c8a..0d2d567 100644 --- a/features/home/src/main/module.json5 +++ b/features/home/src/main/module.json5 @@ -1,14 +1,12 @@ { "module": { "name": "home", - "type": "shared", + "type": "har", "description": "$string:shared_desc", "deviceTypes": [ "phone", "tablet", "2in1" - ], - "deliveryWithInstall": true, - "pages": "$profile:main_pages" + ] } } \ No newline at end of file diff --git a/features/home/src/main/resources/base/element/color.json b/features/home/src/main/resources/base/element/color.json index ded0fa9..ecb94f3 100644 --- a/features/home/src/main/resources/base/element/color.json +++ b/features/home/src/main/resources/base/element/color.json @@ -13,11 +13,11 @@ "value": "#0D000000" }, { - "name": "sixty_percent_white", + "name": "sixty_percent_white_home", "value": "#99FFFFFF" }, { - "name": "sixty_percent_black", + "name": "sixty_percent_black_home", "value": "#99000000" }, { diff --git a/features/home/src/main/resources/base/profile/main_pages.json b/features/home/src/main/resources/base/profile/main_pages.json deleted file mode 100644 index 0a9ce6b..0000000 --- a/features/home/src/main/resources/base/profile/main_pages.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "src": [ - "pages/AccountPage" - ] -} - diff --git a/features/transaction/Index.ets b/features/transaction/Index.ets index 7ef2174..c453990 100644 --- a/features/transaction/Index.ets +++ b/features/transaction/Index.ets @@ -1 +1 @@ -export { TransactionComponent } from "./src/main/ets/view/TransactionComponent" \ No newline at end of file +export { TransactionComponent } from './src/main/ets/view/TransactionComponent'; \ No newline at end of file diff --git a/features/transaction/hvigorfile.ts b/features/transaction/hvigorfile.ts index d993120..4218707 100644 --- a/features/transaction/hvigorfile.ts +++ b/features/transaction/hvigorfile.ts @@ -1,6 +1,6 @@ -import { hspTasks } from '@ohos/hvigor-ohos-plugin'; +import { harTasks } from '@ohos/hvigor-ohos-plugin'; export default { - system: hspTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ + system: harTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ plugins:[] /* Custom plugin to extend the functionality of Hvigor. */ } diff --git a/features/transaction/src/main/ets/view/TransactionComponent.ets b/features/transaction/src/main/ets/view/TransactionComponent.ets index b3f6823..9047f07 100644 --- a/features/transaction/src/main/ets/view/TransactionComponent.ets +++ b/features/transaction/src/main/ets/view/TransactionComponent.ets @@ -94,7 +94,7 @@ export struct TransactionComponent { Row() { Text($r('app.string.payment_account')) .fontSize($r('app.float.payment_size')) - .fontColor($r("app.color.common_text")) + .fontColor($r('app.color.common_text')) .lineHeight($r('app.float.payment_text_height')) Image($r('app.media.ic_public_arrow_right')) .width($r('app.float.arrow_width')) @@ -171,11 +171,11 @@ export struct TransactionComponent { right: $r('app.float.input_margin') }) Button($r('app.string.buy_all')) - .backgroundColor($r("app.color.button_buy_background")) + .backgroundColor($r('app.color.button_buy_background')) .width($r('app.float.button_buy_width')) .height($r('app.float.button_buy_height')) .fontSize($r('app.float.button_buy_size')) - .fontColor($r("app.color.button_buy")) + .fontColor($r('app.color.button_buy')) .fontWeight(CommonConstants.FONT_WEIGHT_500) } .width(CommonConstants.FULL_WIDTH_PERCENT) @@ -186,11 +186,11 @@ export struct TransactionComponent { }) Row() { - Text($r("app.string.confirm_share_prompt", TransactionConstants.RATE_VALUE, + Text($r('app.string.confirm_share_prompt', TransactionConstants.RATE_VALUE, TransactionConstants.RATE_MOUTH, TransactionConstants.RATE_DAY)) - .fontSize($r("app.float.confirm_size")) - .fontColor($r("app.color.common_text")) - .lineHeight($r("app.float.confirm_text_height")) + .fontSize($r('app.float.confirm_size')) + .fontColor($r('app.color.common_text')) + .lineHeight($r('app.float.confirm_text_height')) } .width(CommonConstants.FULL_WIDTH_PERCENT) .justifyContent(FlexAlign.Start) @@ -203,7 +203,7 @@ export struct TransactionComponent { width: { top: $r('app.float.confirm_border_width') }, - color: $r("app.color.confirm_border") + color: $r('app.color.confirm_border') }) } .height($r('app.float.buy_info_height')) diff --git a/features/transaction/src/main/module.json5 b/features/transaction/src/main/module.json5 index 75c75d3..0366a6c 100644 --- a/features/transaction/src/main/module.json5 +++ b/features/transaction/src/main/module.json5 @@ -1,13 +1,12 @@ { "module": { "name": "transaction", - "type": "shared", + "type": "har", "description": "$string:shared_desc", "deviceTypes": [ "phone", "tablet", "2in1" - ], - "deliveryWithInstall": true + ] } } \ No newline at end of file diff --git a/oh-package.json5 b/oh-package.json5 index ee60940..9371487 100644 --- a/oh-package.json5 +++ b/oh-package.json5 @@ -2,7 +2,6 @@ "modelVersion": "5.0.0", "license": "", "devDependencies": { - "@ohos/hypium": "1.0.15" }, "author": "", "name": "multifinancialmanagement", diff --git a/product/phone/oh-package.json5 b/product/phone/oh-package.json5 index 9f0ccdf..7a77716 100644 --- a/product/phone/oh-package.json5 +++ b/product/phone/oh-package.json5 @@ -9,6 +9,8 @@ "dynamicDependencies": {}, "dependencies": { "@ohos/basic": "file:../../commons/basic", - "@ohos/home": "file:../../features/home" + "@ohos/home": "file:../../features/home", + "@ohos/fund": "file:../../features/fund", + "@ohos/fundComparison": "file:../../features/fundComparison" } } diff --git a/product/phone/src/main/ets/entryability/EntryAbility.ets b/product/phone/src/main/ets/entryability/EntryAbility.ets index df3ac1f..a7dbce9 100644 --- a/product/phone/src/main/ets/entryability/EntryAbility.ets +++ b/product/phone/src/main/ets/entryability/EntryAbility.ets @@ -16,9 +16,12 @@ import { UIAbility, Want, AbilityConstant } from '@kit.AbilityKit'; import { BusinessError } from '@kit.BasicServicesKit'; import { hilog } from '@kit.PerformanceAnalysisKit'; -import { window } from '@kit.ArkUI'; +import { display, window } from '@kit.ArkUI'; +import { CommonConstants } from '@ohos/basic'; export default class EntryAbility extends UIAbility { + private windowObj?: window.Window; + onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void { hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate'); } @@ -31,6 +34,14 @@ export default class EntryAbility extends UIAbility { // Main window is created, set main page for this ability hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate'); + windowStage.getMainWindow().then((data: window.Window) => { + this.windowObj = data; + this.updateBreakpoint(this.windowObj.getWindowProperties().windowRect.width); + this.windowObj.on('windowSizeChange', (windowSize: window.Size) => { + this.updateBreakpoint(windowSize.width); + }) + }) + windowStage.loadContent('pages/Index', (err: BusinessError, data) => { if (err.code) { hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? ''); @@ -40,6 +51,19 @@ export default class EntryAbility extends UIAbility { }); } + private updateBreakpoint(windowWidth: number): void{ + let windowWidthVp = windowWidth / display.getDefaultDisplaySync().densityPixels; + let curBp: string = ''; + if (windowWidthVp < CommonConstants.BREAK_POINTS_VALUE_NUMBER[1]) { + curBp = CommonConstants.BREAK_POINT_SM; + } else if (windowWidthVp < CommonConstants.BREAK_POINTS_VALUE_NUMBER[2]) { + curBp = CommonConstants.BREAK_POINT_MD; + } else { + curBp = CommonConstants.BREAK_POINT_LG; + } + AppStorage.setOrCreate('breakPoint', curBp); + } + onWindowStageDestroy(): void { // Main window is destroyed, release UI related resources hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy'); diff --git a/product/phone/src/main/ets/pages/Index.ets b/product/phone/src/main/ets/pages/Index.ets index 83cce84..7889791 100644 --- a/product/phone/src/main/ets/pages/Index.ets +++ b/product/phone/src/main/ets/pages/Index.ets @@ -13,9 +13,11 @@ * limitations under the License. */ -import { BreakpointUtil, CommonConstants } from '@ohos/basic'; -import { AdvertisementDialog, HomeComponent } from '@ohos/home'; import { window } from '@kit.ArkUI'; +import { BreakpointUtil, CommonConstants, RouterConstants } from '@ohos/basic'; +import { AccountPage, AdvertisementDialog, HomeComponent } from '@ohos/home'; +import { Funding, FundingDetail, TrendsPage } from '@ohos/fund'; +import { ComparisonDetailPage, ComparisonInfo } from '@ohos/fundComparison'; @Entry @Component @@ -25,6 +27,7 @@ struct Index { @StorageProp('avoidArea') topHeight: number = 0; @StorageProp('bottom') bottom: number = 0; @State backgroundImageY: number = 0; + @StorageLink('pageIndexInfos') pageIndexInfos: NavPathStack = new NavPathStack(); dialogController: CustomDialogController = new CustomDialogController({ builder: AdvertisementDialog(), backgroundColor: $r('app.color.dialog_background'), @@ -62,7 +65,7 @@ struct Index { getTabBarColor(index: number, currentTabIndex: number, breakPoint: string): ResourceColor { if (this.backgroundImageY < -20 && this.currentTabIndex === 0 && index === 0) { return $r('app.color.tab_choose_image') - } else if (index === 0 && breakPoint === CommonConstants.BREAK_POINT_LG ) { + } else if (index === 0 && breakPoint === CommonConstants.BREAK_POINT_LG) { return currentTabIndex === index ? Color.White : $r('app.color.tab_un_image'); } return currentTabIndex === index ? $r('app.color.tab_choose_image') : $r('app.color.tab_un_image'); @@ -97,89 +100,134 @@ struct Index { } } + @Builder + PagesMap(name: string, param?: object) { + if (name === RouterConstants.FUNDING_URL) { + Funding() + } else if (name === RouterConstants.ACCOUNT_PAGE_URL) { + NavDestination() { + AccountPage() + } + .hideTitleBar(true) + .onWillShow(() => { + window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { + windowStage.setWindowLayoutFullScreen(false); + }) + }) + .onWillDisappear(() => { + window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { + windowStage.setWindowLayoutFullScreen(true); + }) + }) + } else if (name === RouterConstants.FUNDING_DETAIL_URL) { + FundingDetail({ index: (param as Record)['listIndex'] }) + } else if (name === RouterConstants.TRENDS_PAGE_URL) { + TrendsPage({ name: (param as Record)['name'] }) + } else if (name === RouterConstants.COMPARISON_PAGE_URL) { + NavDestination() { + ComparisonDetailPage({ chooseComparison: (param as Record)['chooseComparison'] }) + } + .hideTitleBar(true) + .onWillShow(() => { + window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { + windowStage.setWindowLayoutFullScreen(false); + }) + }) + .onWillDisappear(() => { + window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { + windowStage.setWindowLayoutFullScreen(true); + }) + }) + } + } + build() { - GridRow({ - breakpoints: { - value: CommonConstants.BREAK_POINTS_VALUE, - reference: BreakpointsReference.WindowSize - }, - columns: { - sm: CommonConstants.COLUMN_SM, - md: CommonConstants.COLUMN_MD, - lg: CommonConstants.COLUMN_LG - }, - direction: GridRowDirection.Row - }) { - GridCol({ - span: { + Navigation(this.pageIndexInfos) { + GridRow({ + breakpoints: { + value: CommonConstants.BREAK_POINTS_VALUE, + reference: BreakpointsReference.WindowSize + }, + columns: { sm: CommonConstants.COLUMN_SM, md: CommonConstants.COLUMN_MD, lg: CommonConstants.COLUMN_LG - } + }, + direction: GridRowDirection.Row }) { - Column() { - Tabs({ - barPosition: this.breakPoint === CommonConstants.BREAK_POINT_LG ? BarPosition.Start : BarPosition.End - }) { - TabContent() { - HomeComponent({ - currentPoint: this.breakPoint, - scrollY: this.backgroundImageY - }) - .margin({ - top: this.topHeight + GridCol({ + span: { + sm: CommonConstants.COLUMN_SM, + md: CommonConstants.COLUMN_MD, + lg: CommonConstants.COLUMN_LG + } + }) { + Column() { + Tabs({ + barPosition: this.breakPoint === CommonConstants.BREAK_POINT_LG ? BarPosition.Start : BarPosition.End + }) { + TabContent() { + HomeComponent({ + currentPoint: this.breakPoint, + scrollY: this.backgroundImageY }) - } - .tabBar(this.BuildTabs($r('app.media.ic_public_home_filled'), $r('app.string.tab_bar_home'), 0)) + .margin({ + top: this.topHeight + }) + } + .tabBar(this.BuildTabs($r('app.media.ic_public_home_filled'), $r('app.string.tab_bar_home'), 0)) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_public_cards_filled'), $r('app.string.tab_bar_card'), 1)) - .backgroundColor(Color.White) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_public_cards_filled'), $r('app.string.tab_bar_card'), 1)) + .backgroundColor(Color.White) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_home_fortunes'), $r('app.string.tab_bar_fortunes'), 2)) - .backgroundColor(Color.White) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_home_fortunes'), $r('app.string.tab_bar_fortunes'), 2)) + .backgroundColor(Color.White) - TabContent() { - } - .tabBar(this.BuildTabs($r('app.media.ic_life_filled'), $r('app.string.tab_bar_life'), 3)) - .backgroundColor(Color.White) + TabContent() { + } + .tabBar(this.BuildTabs($r('app.media.ic_life_filled'), $r('app.string.tab_bar_life'), 3)) + .backgroundColor(Color.White) - TabContent() { + TabContent() { + } + .tabBar(this.BuildTabsMine($r('app.media.ic_home_mine'), $r('app.media.ic_home_mine_filled'), + $r('app.string.tab_bar_mine'), 4)) + .backgroundColor(Color.White) } - .tabBar(this.BuildTabsMine($r('app.media.ic_home_mine'), $r('app.media.ic_home_mine_filled'), - $r('app.string.tab_bar_mine'), 4)) - .backgroundColor(Color.White) - } - .vertical(this.breakPoint === CommonConstants.BREAK_POINT_LG) - .barWidth(this.breakPoint === CommonConstants.BREAK_POINT_LG ? - $r('app.float.tab_bar_width') : CommonConstants.TAB_BAR_HEIGHT_PERCENT) - .barHeight(this.breakPoint === CommonConstants.BREAK_POINT_LG ? + .vertical(this.breakPoint === CommonConstants.BREAK_POINT_LG) + .barWidth(this.breakPoint === CommonConstants.BREAK_POINT_LG ? + $r('app.float.tab_bar_width') : CommonConstants.TAB_BAR_HEIGHT_PERCENT) + .barHeight(this.breakPoint === CommonConstants.BREAK_POINT_LG ? CommonConstants.TAB_HEIGHT_PERCENT : $r('app.float.tab_bar_height')) - .backgroundImage(this.currentTabIndex === 0 ? new BreakpointUtil({ - sm: $r('app.media.ic_home_phone_background'), - md: $r('app.media.ic_home_fold_background'), - lg: $r('app.media.ic_home_tablet_background') - }).getValue(this.breakPoint) : $r('app.media.ic_home_not_background')) - .backgroundImageSize(ImageSize.Contain) - .backgroundImagePosition({ - y: this.backgroundImageY - }) - .backgroundColor($r('app.color.home_background')) - .scrollable(false) - .onChange((index: number) => { - this.currentTabIndex = index; - }) - .padding({ - bottom: this.bottom - }) + .backgroundImage(this.currentTabIndex === 0 ? new BreakpointUtil({ + sm: $r('app.media.ic_home_phone_background'), + md: $r('app.media.ic_home_fold_background'), + lg: $r('app.media.ic_home_tablet_background') + }).getValue(this.breakPoint) : $r('app.media.ic_home_not_background')) + .backgroundImageSize(ImageSize.Contain) + .backgroundImagePosition({ + y: this.backgroundImageY + }) + .backgroundColor($r('app.color.home_background')) + .scrollable(false) + .onChange((index: number) => { + this.currentTabIndex = index; + }) + .padding({ + bottom: this.bottom + }) + } } } } - .onBreakpointChange((breakpoints: string) => { - this.breakPoint = breakpoints; - }) + .mode(NavigationMode.Stack) + .navDestination(this.PagesMap) + .height(CommonConstants.FULL_HEIGHT_PERCENT) + .hideTitleBar(true) + .hideToolBar(true) } } \ No newline at end of file diff --git a/product/phone/src/main/module.json5 b/product/phone/src/main/module.json5 index 49a824a..3ef13f4 100644 --- a/product/phone/src/main/module.json5 +++ b/product/phone/src/main/module.json5 @@ -17,7 +17,7 @@ "name": "EntryAbility", "srcEntry": "./ets/entryability/EntryAbility.ets", "description": "$string:EntryAbility_desc", - "icon": "$media:icon", + "icon": "$media:layered_image", "label": "$string:EntryAbility_label", "startWindowIcon": "$media:startIcon", "startWindowBackground": "$color:start_window_background", diff --git a/product/phone/src/main/resources/base/media/background.png b/product/phone/src/main/resources/base/media/background.png new file mode 100644 index 0000000000000000000000000000000000000000..f939c9fa8cc8914832e602198745f592a0dfa34d GIT binary patch literal 57364 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 A4*&oF literal 0 HcmV?d00001 diff --git a/product/phone/src/main/resources/base/media/foreground.png b/product/phone/src/main/resources/base/media/foreground.png new file mode 100644 index 0000000000000000000000000000000000000000..4483ddad1f079e1089d685bd204ee1cfe1d01902 GIT binary patch literal 12430 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 cSLciz6AsI{U0tD9;7S&f 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

c)ijgxDm}8EsRXFt3h@+Ufr7@DN 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 literal 4351 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 diff --git a/screenshots/device/config.png b/screenshots/device/config.png deleted file mode 100644 index 52b87b948de7a123f87ce851f0aa414750fb1342..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 29903 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