Skip to content

Commit

Permalink
show default community icon instead of activity indicator when no com…
Browse files Browse the repository at this point in the history
…munity is selected (#1528)

* Don't show activity indicator if no community has been selected, and run tests synchronized to make them less flaky.

* fmt
  • Loading branch information
clangenb authored Oct 22, 2023
1 parent 65b893f commit fa3e630
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 43 deletions.
4 changes: 1 addition & 3 deletions app/lib/common/components/logo/community_icon.dart
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter_mobx/flutter_mobx.dart';
import 'package:flutter_svg/svg.dart';
Expand Down Expand Up @@ -28,8 +27,7 @@ class CommunityIconObserver extends StatelessWidget {
return SvgPicture.asset(fallBackCommunityIcon);
}
} else {
///TODO(Azamat): Add some image saying community not selected
return const CupertinoActivityIndicator();
return SvgPicture.asset(fallBackCommunityIcon);
}
},
),
Expand Down
41 changes: 13 additions & 28 deletions app/lib/page/assets/index.dart
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ import 'package:upgrader/upgrader.dart';
import 'package:collection/collection.dart';

import 'package:encointer_wallet/l10n/l10.dart';
import 'package:encointer_wallet/common/components/loading/centered_activity_indicator.dart';
import 'package:encointer_wallet/page/assets/announcement/view/announcement_view.dart';
import 'package:encointer_wallet/common/components/address_icon.dart';
import 'package:encointer_wallet/gen/assets.gen.dart';
Expand Down Expand Up @@ -351,41 +350,27 @@ class _AssetsViewState extends State<AssetsView> {

List<AccountOrCommunityData> _allCommunities() {
final communityStores = context.read<AppStore>().encointer.communityStores?.values.toList();
if (communityStores != null && communityStores.isNotEmpty) {
return communityStores
.mapIndexed(
(i, e) => AccountOrCommunityData(
avatar: Container(
height: avatarSize,
width: avatarSize,
decoration: BoxDecoration(
color: context.colorScheme.background,
shape: BoxShape.circle,
),
child: e.communityIcon != null
? SvgPicture.string(e.communityIcon!)
: SvgPicture.asset(fallBackCommunityIcon),
),
name: e.name,
isSelected: widget.store.encointer.community?.cid == e.cid,
),
)
.toList();
} else {
return [
AccountOrCommunityData(

if (communityStores == null) return [];
return communityStores
.mapIndexed(
(i, e) => AccountOrCommunityData(
avatar: Container(
height: avatarSize,
width: avatarSize,
decoration: BoxDecoration(
color: context.colorScheme.background,
shape: BoxShape.circle,
),
child: const CenteredActivityIndicator(),
child: e.communityIcon != null
? SvgPicture.string(e.communityIcon!)
: SvgPicture.asset(fallBackCommunityIcon),
),
name: '...')
];
}
name: e.name,
isSelected: widget.store.encointer.community?.cid == e.cid,
),
)
.toList();
}

List<AccountOrCommunityData> initAllAccounts() {
Expand Down
22 changes: 10 additions & 12 deletions app/test_driver/app/home/home_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -10,18 +10,16 @@ Future<void> homeInit(FlutterDriver driver) async {
}

Future<void> changeCommunity(FlutterDriver driver) async {
await driver.runUnsynchronized(() async {
await driver.tap(find.byValueKey(EWTestKeys.panelController));
await driver.tap(find.byValueKey(EWTestKeys.addCommunity));

await driver.tap(find.byValueKey(EWTestKeys.cidMarkerIcon(0)));
await driver.tap(find.byValueKey(EWTestKeys.cidMarkerDescription(0)));
await driver.waitFor(find.byValueKey(EWTestKeys.addCommunity));

await Future<void>.delayed(const Duration(milliseconds: 1000));
await closePanel(driver);
await refreshWalletPage(driver);
});
await driver.tap(find.byValueKey(EWTestKeys.panelController));
await driver.tap(find.byValueKey(EWTestKeys.addCommunity));

await driver.tap(find.byValueKey(EWTestKeys.cidMarkerIcon(0)));
await driver.tap(find.byValueKey(EWTestKeys.cidMarkerDescription(0)));
await driver.waitFor(find.byValueKey(EWTestKeys.addCommunity));

await Future<void>.delayed(const Duration(milliseconds: 1000));
await closePanel(driver);
await refreshWalletPage(driver);
}

Future<void> registerAndWait(FlutterDriver driver, ParticipantTypeTestHelper registrationType) async {
Expand Down

0 comments on commit fa3e630

Please sign in to comment.