1
0
mirror of https://github.com/git-touch/git-touch synced 2024-12-19 11:43:30 +01:00
git-touch-android-ios-app/lib/widgets/avatar.dart
2019-12-30 21:25:02 +08:00

85 lines
1.9 KiB
Dart

import 'package:flutter/material.dart';
import 'package:git_touch/models/theme.dart';
import 'package:provider/provider.dart';
class AvatarSize {
static const double extraSmall = 20;
static const double small = 24;
static const double medium = 36;
static const double large = 48;
}
class Avatar extends StatelessWidget {
final String url;
final double size;
final String linkUrl;
final BorderRadius borderRadius;
Avatar({
@required this.url,
this.size = AvatarSize.medium,
this.linkUrl,
this.borderRadius,
});
@override
Widget build(BuildContext context) {
return GestureDetector(
child: ClipRRect(
borderRadius: borderRadius ?? BorderRadius.circular(4),
child: FadeInImage.assetNetwork(
placeholder: 'images/avatar.png',
image: url ?? 'images/avatar.png',
width: size,
height: size,
fadeInDuration: Duration(milliseconds: 200),
fadeOutDuration: Duration(milliseconds: 100),
),
),
onTap: () {
if (linkUrl != null)
Provider.of<ThemeModel>(context).push(context, linkUrl);
},
);
}
}
class GithubAvatar extends StatelessWidget {
final String url;
final double size;
final String login;
GithubAvatar({
@required this.url,
this.size = AvatarSize.medium,
this.login,
});
@override
Widget build(BuildContext context) {
return Avatar(url: url, size: size, linkUrl: '/$login');
}
}
class GitlabAvatar extends StatelessWidget {
final String url;
final double size;
final int id;
GitlabAvatar({
@required this.url,
@required this.id,
this.size = AvatarSize.medium,
});
@override
Widget build(BuildContext context) {
return Avatar(
url: url,
size: size,
linkUrl: '/user/$id',
borderRadius: BorderRadius.circular(size / 2),
);
}
}