1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-22 11:42:46 +01:00

Uses blurhash hook state

This commit is contained in:
Marty Fuhry 2024-02-21 20:13:47 -05:00
parent 4d60133504
commit c2694996e5
No known key found for this signature in database
GPG key ID: E2AB6392D894D900
2 changed files with 20 additions and 11 deletions

View file

@ -0,0 +1,18 @@
import 'dart:convert';
import 'dart:typed_data';
import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:immich_mobile/shared/models/asset.dart';
import 'package:thumbhash/thumbhash.dart' as thumbhash;
ValueNotifier<Uint8List?> useBlurHashState(Asset? asset) {
if (asset?.thumbhash == null) {
return useState(null);
}
final rbga = thumbhash.thumbHashToRGBA(
base64Decode(asset!.thumbhash!),
);
return useState(thumbhash.rgbaToBmp(rbga));
}

View file

@ -1,4 +1,3 @@
import 'dart:convert';
import 'dart:typed_data'; import 'dart:typed_data';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
@ -6,9 +5,9 @@ import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:immich_mobile/modules/asset_viewer/image_providers/immich_local_thumbnail_provider.dart'; import 'package:immich_mobile/modules/asset_viewer/image_providers/immich_local_thumbnail_provider.dart';
import 'package:immich_mobile/modules/asset_viewer/image_providers/immich_remote_image_provider.dart'; import 'package:immich_mobile/modules/asset_viewer/image_providers/immich_remote_image_provider.dart';
import 'package:immich_mobile/shared/models/asset.dart'; import 'package:immich_mobile/shared/models/asset.dart';
import 'package:immich_mobile/shared/ui/hooks/blurhash_hook.dart';
import 'package:immich_mobile/shared/ui/thumbhash_placeholder.dart'; import 'package:immich_mobile/shared/ui/thumbhash_placeholder.dart';
import 'package:octo_image/octo_image.dart'; import 'package:octo_image/octo_image.dart';
import 'package:thumbhash/thumbhash.dart' as thumbhash;
class ImmichThumbnail extends HookWidget { class ImmichThumbnail extends HookWidget {
const ImmichThumbnail({ const ImmichThumbnail({
@ -63,17 +62,9 @@ class ImmichThumbnail extends HookWidget {
static bool useLocal(Asset asset) => !asset.isRemote || asset.isLocal; static bool useLocal(Asset asset) => !asset.isRemote || asset.isLocal;
Uint8List? get _blurHash => asset?.thumbhash == null
? null
: thumbhash.rgbaToBmp(
thumbhash.thumbHashToRGBA(
base64Decode(asset!.thumbhash!),
),
);
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
Uint8List? blurhash = useState(_blurHash).value; Uint8List? blurhash = useBlurHashState(asset).value;
if (asset == null) { if (asset == null) {
return Container( return Container(
color: Colors.grey, color: Colors.grey,