Merge branch 'krille/refactor-avatar' into 'main'

refactor: Avatar widget

See merge request famedly/fluffychat!555
This commit is contained in:
Krille Fear 2021-11-20 10:03:14 +00:00
commit a49b21c603
22 changed files with 69 additions and 104 deletions

View File

@ -287,44 +287,3 @@ release:
--assets-link "{\"name\":\"fluffychat-linux-arm64.tar.gz\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-linux-arm64.tar.gz\"}" \ --assets-link "{\"name\":\"fluffychat-linux-arm64.tar.gz\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-linux-arm64.tar.gz\"}" \
--assets-link "{\"name\":\"fluffychat-windows.zip\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-windows.zip\"}" \ --assets-link "{\"name\":\"fluffychat-windows.zip\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-windows.zip\"}" \
--assets-link "{\"name\":\"fluffychat-web.tar.gz\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-web.tar.gz\"}" --assets-link "{\"name\":\"fluffychat-web.tar.gz\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-web.tar.gz\"}"
.docker: &docker_template
image: docker:latest
tags:
- docker
- famedly
stage: deploy
services:
- docker:dind
docker-releases:
<<: *docker_template
script:
- docker build --pull -t "${CI_REGISTRY_IMAGE}:latest" -t "${CI_REGISTRY_IMAGE}:${CI_COMMIT_TAG}" .
- docker push "${CI_REGISTRY_IMAGE}:latest"
- docker push "${CI_REGISTRY_IMAGE}:${CI_COMMIT_TAG}"
rules:
- if: '$CI_COMMIT_TAG && $CI_COMMIT_TAG =~ /^v\d+\.\d+\.\d+$/'
before_script:
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
docker-tags:
<<: *docker_template
script:
- docker build --pull -t "${CI_REGISTRY_IMAGE}:${CI_COMMIT_TAG}" .
- docker push "${CI_REGISTRY_IMAGE}:${CI_COMMIT_TAG}"
rules:
- if: '$CI_COMMIT_TAG && $CI_COMMIT_TAG !~ /^v\d+\.\d+\.\d+$/'
before_script:
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
docker-branches:
<<: *docker_template
script:
- docker build --pull -t "${CI_REGISTRY_IMAGE}:${CI_COMMIT_REF_SLUG}" -t "${CI_REGISTRY_IMAGE}:${CI_COMMIT_SHA}" .
- docker push "${CI_REGISTRY_IMAGE}:${CI_COMMIT_REF_SLUG}"
rules:
- if: $CI_COMMIT_TAG == null
before_script:
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
allow_failure: true

View File

@ -1,16 +0,0 @@
# Based upon https://github.com/Starbix/dockerimages/commit/b0c3e408263a90ee467d30aed0e855a610eb537a
FROM cirrusci/flutter:2.2.3 AS builder
RUN mkdir /fluffychat
WORKDIR /fluffychat
COPY ./ /fluffychat
RUN ./scripts/prepare-web.sh
RUN ./scripts/build-web.sh
FROM nginx:alpine
COPY --from=builder /fluffychat/build/web/ /usr/share/nginx/html
COPY --from=builder /fluffychat/config.sample.json /usr/share/nginx/html/config.json

View File

@ -21,7 +21,10 @@ class ChatAppBarTitle extends StatelessWidget {
return Text(controller.selectedEvents.length.toString()); return Text(controller.selectedEvents.length.toString());
} }
return ListTile( return ListTile(
leading: Avatar(controller.room.avatar, controller.room.displayname), leading: Avatar(
mxContent: controller.room.avatar,
name: controller.room.displayname,
),
contentPadding: EdgeInsets.zero, contentPadding: EdgeInsets.zero,
onTap: controller.room.isDirectChat onTap: controller.room.isDirectChat
? () => showModalBottomSheet( ? () => showModalBottomSheet(

View File

@ -268,8 +268,9 @@ class _ChatAccountPicker extends StatelessWidget {
future: client.ownProfile, future: client.ownProfile,
builder: (context, snapshot) => ListTile( builder: (context, snapshot) => ListTile(
leading: Avatar( leading: Avatar(
snapshot.data?.avatarUrl, mxContent: snapshot.data?.avatarUrl,
snapshot.data?.displayName ?? client.userID.localpart, name: snapshot.data?.displayName ??
client.userID.localpart,
size: 20, size: 20,
), ),
title: title:
@ -280,8 +281,8 @@ class _ChatAccountPicker extends StatelessWidget {
)) ))
.toList(), .toList(),
child: Avatar( child: Avatar(
snapshot.data?.avatarUrl, mxContent: snapshot.data?.avatarUrl,
snapshot.data?.displayName ?? name: snapshot.data?.displayName ??
controller.matrix.client.userID.localpart, controller.matrix.client.userID.localpart,
size: 20, size: 20,
), ),

View File

@ -46,8 +46,10 @@ class EventInfoDialog extends StatelessWidget {
body: ListView( body: ListView(
children: [ children: [
ListTile( ListTile(
leading: leading: Avatar(
Avatar(event.sender.avatarUrl, event.sender.calcDisplayname()), mxContent: event.sender.avatarUrl,
name: event.sender.calcDisplayname(),
),
title: Text(L10n.of(context).sender), title: Text(L10n.of(context).sender),
subtitle: subtitle:
Text('${event.sender.calcDisplayname()} <${event.senderId}>'), Text('${event.sender.calcDisplayname()} <${event.senderId}>'),

View File

@ -121,8 +121,8 @@ class Message extends StatelessWidget {
: null, : null,
) )
: Avatar( : Avatar(
event.sender.avatarUrl, mxContent: event.sender.avatarUrl,
event.sender.calcDisplayname(), name: event.sender.calcDisplayname(),
onTap: () => onAvatarTab(event), onTap: () => onAvatarTab(event),
), ),
Expanded( Expanded(

View File

@ -213,8 +213,8 @@ class _AdaptableReactorsDialog extends StatelessWidget {
for (var reactor in reactionEntry.reactors) for (var reactor in reactionEntry.reactors)
Chip( Chip(
avatar: Avatar( avatar: Avatar(
reactor.avatarUrl, mxContent: reactor.avatarUrl,
reactor.displayName, name: reactor.displayName,
client: client, client: client,
), ),
label: Text(reactor.displayName), label: Text(reactor.displayName),

View File

@ -259,8 +259,10 @@ class InputBar extends StatelessWidget {
opacity: suggestion['pack_avatar_url'] != null ? 0.8 : 0.5, opacity: suggestion['pack_avatar_url'] != null ? 0.8 : 0.5,
child: suggestion['pack_avatar_url'] != null child: suggestion['pack_avatar_url'] != null
? Avatar( ? Avatar(
Uri.parse(suggestion['pack_avatar_url']), mxContent: Uri.tryParse(
suggestion['pack_display_name'], suggestion.tryGet<String>('pack_avatar_url') ??
''),
name: suggestion.tryGet<String>('pack_display_name'),
size: size * 0.9, size: size * 0.9,
client: client, client: client,
) )
@ -280,8 +282,9 @@ class InputBar extends StatelessWidget {
crossAxisAlignment: CrossAxisAlignment.center, crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[ children: <Widget>[
Avatar( Avatar(
url, mxContent: url,
suggestion['displayname'] ?? suggestion['mxid'], name: suggestion.tryGet<String>('displayname') ??
suggestion.tryGet<String>('mxid'),
size: size, size: size,
client: client, client: client,
), ),

View File

@ -42,8 +42,8 @@ class SeenByRow extends StatelessWidget {
: seenByUsers) : seenByUsers)
.map( .map(
(user) => Avatar( (user) => Avatar(
user.avatarUrl, mxContent: user.avatarUrl,
user.calcDisplayname(), name: user.calcDisplayname(),
size: 16, size: 16,
fontSize: 9, fontSize: 9,
), ),

View File

@ -49,8 +49,8 @@ class StickerPickerDialogState extends State<StickerPickerDialog> {
if (packName != 'user') if (packName != 'user')
ListTile( ListTile(
leading: Avatar( leading: Avatar(
pack.pack.avatarUrl, mxContent: pack.pack.avatarUrl,
packName, name: packName,
client: widget.room.client, client: widget.room.client,
), ),
title: Text(packName), title: Text(packName),

View File

@ -48,17 +48,17 @@ class TypingIndicators extends StatelessWidget {
children: [ children: [
if (typingUsers.isNotEmpty) if (typingUsers.isNotEmpty)
Avatar( Avatar(
typingUsers.first.avatarUrl, mxContent: typingUsers.first.avatarUrl,
typingUsers.first.calcDisplayname(), name: typingUsers.first.calcDisplayname(),
), ),
if (typingUsers.length == 2) if (typingUsers.length == 2)
Padding( Padding(
padding: const EdgeInsets.only(left: 8), padding: const EdgeInsets.only(left: 8),
child: Avatar( child: Avatar(
typingUsers.length == 2 mxContent: typingUsers.length == 2
? typingUsers.last.avatarUrl ? typingUsers.last.avatarUrl
: null, : null,
typingUsers.length == 2 name: typingUsers.length == 2
? typingUsers.last.calcDisplayname() ? typingUsers.last.calcDisplayname()
: '+${typingUsers.length - 1}', : '+${typingUsers.length - 1}',
), ),

View File

@ -61,7 +61,7 @@ class ParticipantListItem extends StatelessWidget {
], ],
), ),
subtitle: Text(user.id), subtitle: Text(user.id),
leading: Avatar(user.avatarUrl, user.calcDisplayname()), leading: Avatar(mxContent: user.avatarUrl, name: user.calcDisplayname()),
); );
} }
} }

View File

@ -91,10 +91,10 @@ class ChatEncryptionSettingsView extends StatelessWidget {
}, },
child: ListTile( child: ListTile(
leading: Avatar( leading: Avatar(
room mxContent: room
.getUserByMXIDSync(deviceKeys[i].userId) .getUserByMXIDSync(deviceKeys[i].userId)
.avatarUrl, .avatarUrl,
room name: room
.getUserByMXIDSync(deviceKeys[i].userId) .getUserByMXIDSync(deviceKeys[i].userId)
.calcDisplayname(), .calcDisplayname(),
), ),

View File

@ -171,7 +171,11 @@ class ChatListItem extends StatelessWidget {
child: const Icon(Icons.check, color: Colors.white), child: const Icon(Icons.check, color: Colors.white),
), ),
) )
: Avatar(room.avatar, room.displayname, onTap: onLongPress), : Avatar(
mxContent: room.avatar,
name: room.displayname,
onTap: onLongPress,
),
title: Row( title: Row(
children: <Widget>[ children: <Widget>[
Expanded( Expanded(

View File

@ -48,8 +48,9 @@ class ClientChooserButton extends StatelessWidget {
builder: (context, snapshot) => Row( builder: (context, snapshot) => Row(
children: [ children: [
Avatar( Avatar(
snapshot.data?.avatarUrl, mxContent: snapshot.data?.avatarUrl,
snapshot.data?.displayName ?? client.userID.localpart, name: snapshot.data?.displayName ??
client.userID.localpart,
size: 28, size: 28,
fontSize: 12, fontSize: 12,
), ),
@ -84,8 +85,8 @@ class ClientChooserButton extends StatelessWidget {
future: matrix.client.ownProfile, future: matrix.client.ownProfile,
builder: (context, snapshot) => PopupMenuButton<Object>( builder: (context, snapshot) => PopupMenuButton<Object>(
child: Avatar( child: Avatar(
snapshot.data?.avatarUrl, mxContent: snapshot.data?.avatarUrl,
snapshot.data?.displayName ?? matrix.client.userID.localpart, name: snapshot.data?.displayName ?? matrix.client.userID.localpart,
size: 28, size: 28,
fontSize: 12, fontSize: 12,
), ),

View File

@ -59,8 +59,8 @@ class SpacesBottomBar extends StatelessWidget {
onLongPress: () => onLongPress: () =>
controller.editSpace(context, space.id), controller.editSpace(context, space.id),
child: Avatar( child: Avatar(
space.avatar, mxContent: space.avatar,
space.displayname, name: space.displayname,
size: 24, size: 24,
fontSize: 12, fontSize: 12,
), ),

View File

@ -45,8 +45,8 @@ class InvitationSelectionView extends StatelessWidget {
itemCount: controller.foundProfiles.length, itemCount: controller.foundProfiles.length,
itemBuilder: (BuildContext context, int i) => ListTile( itemBuilder: (BuildContext context, int i) => ListTile(
leading: Avatar( leading: Avatar(
controller.foundProfiles[i].avatarUrl, mxContent: controller.foundProfiles[i].avatarUrl,
controller.foundProfiles[i].displayName ?? name: controller.foundProfiles[i].displayName ??
controller.foundProfiles[i].userId, controller.foundProfiles[i].userId,
), ),
title: Text( title: Text(
@ -73,8 +73,8 @@ class InvitationSelectionView extends StatelessWidget {
itemCount: contacts.length, itemCount: contacts.length,
itemBuilder: (BuildContext context, int i) => ListTile( itemBuilder: (BuildContext context, int i) => ListTile(
leading: Avatar( leading: Avatar(
contacts[i].avatarUrl, mxContent: contacts[i].avatarUrl,
contacts[i].calcDisplayname(), name: contacts[i].calcDisplayname(),
), ),
title: Text(contacts[i].calcDisplayname()), title: Text(contacts[i].calcDisplayname()),
subtitle: Text(contacts[i].id), subtitle: Text(contacts[i].id),

View File

@ -171,7 +171,7 @@ class _KeyVerificationPageState extends State<KeyVerificationDialog> {
children: [ children: [
Row(children: [ Row(children: [
if (!PlatformInfos.isCupertinoStyle) if (!PlatformInfos.isCupertinoStyle)
Avatar(user?.avatarUrl, displayName), Avatar(mxContent: user?.avatarUrl, name: displayName),
const SizedBox(width: 12), const SizedBox(width: 12),
Expanded( Expanded(
child: Column( child: Column(

View File

@ -195,8 +195,11 @@ class SearchView extends StatelessWidget {
child: Column( child: Column(
mainAxisSize: MainAxisSize.min, mainAxisSize: MainAxisSize.min,
children: [ children: [
Avatar(publicRoomsResponse.chunk[i].avatarUrl, Avatar(
publicRoomsResponse.chunk[i].name), mxContent:
publicRoomsResponse.chunk[i].avatarUrl,
name: publicRoomsResponse.chunk[i].name,
),
Text( Text(
publicRoomsResponse.chunk[i].name, publicRoomsResponse.chunk[i].name,
style: const TextStyle( style: const TextStyle(
@ -262,8 +265,8 @@ class SearchView extends StatelessWidget {
} }
}, },
leading: Avatar( leading: Avatar(
foundProfile.avatarUrl, mxContent: foundProfile.avatarUrl,
foundProfile.displayName ?? foundProfile.userId, name: foundProfile.displayName ?? foundProfile.userId,
//size: 24, //size: 24,
), ),
title: Text( title: Text(

View File

@ -68,8 +68,8 @@ class SettingsIgnoreListView extends StatelessWidget {
client.getProfileFromUserId(client.ignoredUsers[i]), client.getProfileFromUserId(client.ignoredUsers[i]),
builder: (c, s) => ListTile( builder: (c, s) => ListTile(
leading: Avatar( leading: Avatar(
s.data?.avatarUrl ?? Uri.parse(''), mxContent: s.data?.avatarUrl ?? Uri.parse(''),
s.data?.displayName ?? client.ignoredUsers[i], name: s.data?.displayName ?? client.ignoredUsers[i],
), ),
title: Text( title: Text(
s.data?.displayName ?? client.ignoredUsers[i]), s.data?.displayName ?? client.ignoredUsers[i]),

View File

@ -18,9 +18,9 @@ class Avatar extends StatelessWidget {
final Client? client; final Client? client;
final double fontSize; final double fontSize;
const Avatar( const Avatar({
this.mxContent, this.mxContent,
this.name, { this.name,
this.size = defaultSize, this.size = defaultSize,
this.onTap, this.onTap,
this.client, this.client,

View File

@ -87,7 +87,12 @@ class _ContactListTile extends StatelessWidget {
height: Avatar.defaultSize, height: Avatar.defaultSize,
child: Stack( child: Stack(
children: [ children: [
Center(child: Avatar(avatarUrl, displayname)), Center(
child: Avatar(
mxContent: avatarUrl,
name: displayname,
),
),
Align( Align(
alignment: Alignment.bottomRight, alignment: Alignment.bottomRight,
child: Icon( child: Icon(