mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
feat: add border to selected unsplash image (#5428)
* feat: add border to selected unsplash image * feat: add border to selected unsplash image --------- Co-authored-by: Lucas.Xu <lucas.xu@appflowy.io>
This commit is contained in:
parent
ace729eb78
commit
e40e1e9a8a
@ -112,7 +112,7 @@ class _UnsplashImageWidgetState extends State<UnsplashImageWidget> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class _UnsplashImages extends StatelessWidget {
|
class _UnsplashImages extends StatefulWidget {
|
||||||
const _UnsplashImages({
|
const _UnsplashImages({
|
||||||
required this.type,
|
required this.type,
|
||||||
required this.photos,
|
required this.photos,
|
||||||
@ -123,17 +123,24 @@ class _UnsplashImages extends StatelessWidget {
|
|||||||
final List<Photo> photos;
|
final List<Photo> photos;
|
||||||
final OnSelectUnsplashImage onSelectUnsplashImage;
|
final OnSelectUnsplashImage onSelectUnsplashImage;
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<_UnsplashImages> createState() => _UnsplashImagesState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UnsplashImagesState extends State<_UnsplashImages> {
|
||||||
|
int _selectedPhotoIndex = -1;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final crossAxisCount = switch (type) {
|
final crossAxisCount = switch (widget.type) {
|
||||||
UnsplashImageType.halfScreen => 3,
|
UnsplashImageType.halfScreen => 3,
|
||||||
UnsplashImageType.fullScreen => 2,
|
UnsplashImageType.fullScreen => 2,
|
||||||
};
|
};
|
||||||
final mainAxisSpacing = switch (type) {
|
final mainAxisSpacing = switch (widget.type) {
|
||||||
UnsplashImageType.halfScreen => 16.0,
|
UnsplashImageType.halfScreen => 16.0,
|
||||||
UnsplashImageType.fullScreen => 16.0,
|
UnsplashImageType.fullScreen => 16.0,
|
||||||
};
|
};
|
||||||
final crossAxisSpacing = switch (type) {
|
final crossAxisSpacing = switch (widget.type) {
|
||||||
UnsplashImageType.halfScreen => 10.0,
|
UnsplashImageType.halfScreen => 10.0,
|
||||||
UnsplashImageType.fullScreen => 16.0,
|
UnsplashImageType.fullScreen => 16.0,
|
||||||
};
|
};
|
||||||
@ -142,17 +149,23 @@ class _UnsplashImages extends StatelessWidget {
|
|||||||
mainAxisSpacing: mainAxisSpacing,
|
mainAxisSpacing: mainAxisSpacing,
|
||||||
crossAxisSpacing: crossAxisSpacing,
|
crossAxisSpacing: crossAxisSpacing,
|
||||||
childAspectRatio: 4 / 3,
|
childAspectRatio: 4 / 3,
|
||||||
children: photos
|
children: widget.photos.asMap().entries.map((entry) {
|
||||||
.map(
|
final index = entry.key;
|
||||||
(photo) => _UnsplashImage(
|
final photo = entry.value;
|
||||||
type: type,
|
return _UnsplashImage(
|
||||||
photo: photo,
|
type: widget.type,
|
||||||
onTap: () => onSelectUnsplashImage(
|
photo: photo,
|
||||||
photo.urls.full.toString(),
|
onTap: () {
|
||||||
),
|
widget.onSelectUnsplashImage(
|
||||||
),
|
photo.urls.regular.toString(),
|
||||||
)
|
);
|
||||||
.toList(),
|
setState(() {
|
||||||
|
_selectedPhotoIndex = index;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
isSelected: index == _selectedPhotoIndex,
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -162,11 +175,13 @@ class _UnsplashImage extends StatelessWidget {
|
|||||||
required this.type,
|
required this.type,
|
||||||
required this.photo,
|
required this.photo,
|
||||||
required this.onTap,
|
required this.onTap,
|
||||||
|
required this.isSelected,
|
||||||
});
|
});
|
||||||
|
|
||||||
final UnsplashImageType type;
|
final UnsplashImageType type;
|
||||||
final Photo photo;
|
final Photo photo;
|
||||||
final VoidCallback onTap;
|
final VoidCallback onTap;
|
||||||
|
final bool isSelected;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
@ -177,7 +192,19 @@ class _UnsplashImage extends StatelessWidget {
|
|||||||
|
|
||||||
return GestureDetector(
|
return GestureDetector(
|
||||||
onTap: onTap,
|
onTap: onTap,
|
||||||
child: child,
|
child: isSelected
|
||||||
|
? Container(
|
||||||
|
clipBehavior: Clip.antiAlias,
|
||||||
|
decoration: ShapeDecoration(
|
||||||
|
shape: RoundedRectangleBorder(
|
||||||
|
side: const BorderSide(width: 1.50, color: Color(0xFF00BCF0)),
|
||||||
|
borderRadius: BorderRadius.circular(8.0),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
padding: const EdgeInsets.all(2.0),
|
||||||
|
child: child,
|
||||||
|
)
|
||||||
|
: child,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user