CakeWallet/lib/utils/image_utill.dart

127 lines
3.7 KiB
Dart
Raw Normal View History

2025-06-13 15:45:14 +03:00
import 'dart:io';
2025-06-23 17:24:18 +03:00
import 'package:flutter/material.dart';
import 'package:flutter_svg/flutter_svg.dart';
2025-06-13 15:45:14 +03:00
import 'package:path/path.dart' as p;
import 'package:path_provider/path_provider.dart';
2025-06-23 17:24:18 +03:00
import 'package:cw_core/utils/proxy_wrapper.dart';
class ImageUtil {
2025-05-28 14:52:32 +03:00
static Widget getImageFromPath({
required String imagePath,
double? height,
double? width,
Color? svgImageColor,
BoxFit? fit,
double? borderRadius,
}) {
2025-06-23 17:24:18 +03:00
bool isNetworkImage = imagePath.startsWith('http') || imagePath.startsWith('https');
if (CakeTor.instance.enabled && isNetworkImage) {
imagePath = "assets/images/tor_logo.svg";
isNetworkImage = false;
}
2025-06-23 17:24:18 +03:00
final bool isSvg = imagePath.endsWith('.svg');
2025-05-28 14:52:32 +03:00
final bool ignoreSize = fit != null;
final double? _height = ignoreSize ? null : (height ?? 35);
final double? _width = ignoreSize ? null : (width ?? 35);
Widget img;
2025-06-23 17:24:18 +03:00
if (isNetworkImage) {
2025-05-28 14:52:32 +03:00
img = isSvg
2025-06-23 17:24:18 +03:00
? SvgPicture.network(
imagePath,
Automated Integration Tests Flows (#1686) * feat: Integration tests setup and tests for Disclaimer, Welcome and Setup Pin Code pages * feat: Integration test flow from start to restoring a wallet successfully done * test: Dashboard view test and linking to flow * feat: Testing the Exchange flow section, selecting sending and receiving currencies * test: Successfully create an exchange section * feat: Implement flow up to sending section * test: Complete Exchange flow * fix dependency issue * test: Final cleanups * feat: Add CI to run automated integration tests withan android emulator * feat: Adjust Automated integration test CI to run on ubuntu 20.04-a * fix: Move integration test CI into PR test build CI * ci: Add automated test ci which is a streamlined replica of pr test build ci * ci: Re-add step to access branch name * ci: Add KVM * ci: Add filepath to trigger the test run from * ci: Add required key * ci: Add required key * ci: Add missing secret key * ci: Add missing secret key * ci: Add nano secrets to workflow * ci: Switch step to free space on runner * ci: Remove timeout from workflow * ci: Confirm impact that removing copy_monero_deps would have on entire workflow time * ci: Update CI and temporarily remove cache related to emulator * ci: Remove dynamic java version * ci: Temporarily switch CI * ci: Switch to 11.x jdk * ci: Temporarily switch CI * ci: Revert ubuntu version * ci: Add more api levels * ci: Add more target options * ci: Settled on stable emulator matrix options * ci: Add more target options * ci: Modify flow * ci: Streamline api levels to 28 and 29 * ci: One more trial * ci: Switch to flutter drive * ci: Reduce options * ci: Remove haven from test * ci: Check for solana in list * ci: Adjust amounts and currencies for exchange flow * ci: Set write response on failure to true * ci: Split ci to funds and non funds related tests * test: Test for Send flow scenario and minor restructuring for test folders and files * chore: cleanup * ci: Pause CI for now * ci: Pause CI for now * ci: Pause CI for now * test: Restore wallets integration automated tests * Fix: Add keys back to currency amount textfield widget * fix: Switch variable name * fix: remove automation for now * tests: Automated tests for Create wallets flow * tests: Further optimize common flows * tests: Add missing await for call * tests: Confirm Seeds Display Properly WIP * tests: Confirm Seeds Display Correctly Automated Tests * fix: Add missing pubspec params for bitcoin and bitcoin_cash * feat: Automated Tests for Transaction History Flow * fix: Add missing pubspec parameter * feat: Automated Integration Tests for Transaction History flow * test: Updating send page robot and also syncing branch with main * test: Modifying tests to flow with wallet grouping implementation * fix: Issue with transaction history test * fix: Modifications to the PR and add automated confirmation for checking that all wallet types are restored or created correctly * test: Attempting automation for testing * fix: Issue from merge conflicts * test: Remove automation of test in this PR --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
2024-11-07 15:46:08 +01:00
key: ValueKey(imagePath),
height: _height,
width: _width,
2025-05-28 14:52:32 +03:00
fit: fit ?? BoxFit.contain,
2025-06-23 17:24:18 +03:00
placeholderBuilder: (_) => _placeholder(_height, _width),
)
: Image.network(
imagePath,
Automated Integration Tests Flows (#1686) * feat: Integration tests setup and tests for Disclaimer, Welcome and Setup Pin Code pages * feat: Integration test flow from start to restoring a wallet successfully done * test: Dashboard view test and linking to flow * feat: Testing the Exchange flow section, selecting sending and receiving currencies * test: Successfully create an exchange section * feat: Implement flow up to sending section * test: Complete Exchange flow * fix dependency issue * test: Final cleanups * feat: Add CI to run automated integration tests withan android emulator * feat: Adjust Automated integration test CI to run on ubuntu 20.04-a * fix: Move integration test CI into PR test build CI * ci: Add automated test ci which is a streamlined replica of pr test build ci * ci: Re-add step to access branch name * ci: Add KVM * ci: Add filepath to trigger the test run from * ci: Add required key * ci: Add required key * ci: Add missing secret key * ci: Add missing secret key * ci: Add nano secrets to workflow * ci: Switch step to free space on runner * ci: Remove timeout from workflow * ci: Confirm impact that removing copy_monero_deps would have on entire workflow time * ci: Update CI and temporarily remove cache related to emulator * ci: Remove dynamic java version * ci: Temporarily switch CI * ci: Switch to 11.x jdk * ci: Temporarily switch CI * ci: Revert ubuntu version * ci: Add more api levels * ci: Add more target options * ci: Settled on stable emulator matrix options * ci: Add more target options * ci: Modify flow * ci: Streamline api levels to 28 and 29 * ci: One more trial * ci: Switch to flutter drive * ci: Reduce options * ci: Remove haven from test * ci: Check for solana in list * ci: Adjust amounts and currencies for exchange flow * ci: Set write response on failure to true * ci: Split ci to funds and non funds related tests * test: Test for Send flow scenario and minor restructuring for test folders and files * chore: cleanup * ci: Pause CI for now * ci: Pause CI for now * ci: Pause CI for now * test: Restore wallets integration automated tests * Fix: Add keys back to currency amount textfield widget * fix: Switch variable name * fix: remove automation for now * tests: Automated tests for Create wallets flow * tests: Further optimize common flows * tests: Add missing await for call * tests: Confirm Seeds Display Properly WIP * tests: Confirm Seeds Display Correctly Automated Tests * fix: Add missing pubspec params for bitcoin and bitcoin_cash * feat: Automated Tests for Transaction History Flow * fix: Add missing pubspec parameter * feat: Automated Integration Tests for Transaction History flow * test: Updating send page robot and also syncing branch with main * test: Modifying tests to flow with wallet grouping implementation * fix: Issue with transaction history test * fix: Modifications to the PR and add automated confirmation for checking that all wallet types are restored or created correctly * test: Attempting automation for testing * fix: Issue from merge conflicts * test: Remove automation of test in this PR --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
2024-11-07 15:46:08 +01:00
key: ValueKey(imagePath),
height: _height,
width: _width,
2025-05-28 14:52:32 +03:00
fit: fit,
loadingBuilder: (_, child, progress) =>
progress == null ? child : _placeholder(_height, _width),
2025-06-23 17:24:18 +03:00
errorBuilder: (_, __, ___) => const SizedBox.shrink(),
);
} else {
2025-05-28 14:52:32 +03:00
img = isSvg
2025-06-23 17:24:18 +03:00
? SvgPicture.asset(
imagePath,
2025-05-28 14:52:32 +03:00
key: ValueKey(imagePath),
height: _height,
width: _width,
2025-05-28 14:52:32 +03:00
fit: fit ?? BoxFit.contain,
colorFilter:
svgImageColor != null ? ColorFilter.mode(svgImageColor, BlendMode.srcIn) : null,
2025-06-23 17:24:18 +03:00
placeholderBuilder: (_) => const Icon(Icons.error),
)
: Image.asset(
imagePath,
2025-05-28 14:52:32 +03:00
key: ValueKey(imagePath),
height: _height,
width: _width,
2025-05-28 14:52:32 +03:00
fit: fit,
errorBuilder: (_, __, ___) => const Icon(Icons.error),
);
}
2025-05-28 14:52:32 +03:00
if (borderRadius != null && borderRadius > 0) {
img = ClipRRect(
borderRadius: BorderRadius.circular(borderRadius),
child: img,
);
}
2025-06-23 17:24:18 +03:00
2025-05-28 14:52:32 +03:00
return img;
}
2025-05-28 14:52:32 +03:00
2025-06-23 17:24:18 +03:00
static Widget _placeholder(double? height, double? width) {
return (height != null || width != null)
? SizedBox(
height: height,
width: width,
child: const Center(child: CircularProgressIndicator()),
)
: const Center(child: CircularProgressIndicator());
}
2025-06-13 15:45:14 +03:00
static Future<String?> saveAvatarLocally(String imageUriOrPath) async {
if (imageUriOrPath.isEmpty) return null;
try {
final dir = await getApplicationDocumentsDirectory();
String ext = p.extension(imageUriOrPath);
if (ext.isEmpty) ext = '.png';
2025-06-23 17:24:18 +03:00
final file = File('${dir.path}/${DateTime.now().millisecondsSinceEpoch}$ext');
2025-06-13 15:45:14 +03:00
if (imageUriOrPath.startsWith('http')) {
2025-06-23 17:24:18 +03:00
final response = await ProxyWrapper()
.get(
clearnetUri: Uri.parse(imageUriOrPath),
)
.catchError((error) {
throw Exception('HTTP request failed: $error');
});
2025-06-13 15:45:14 +03:00
if (response.statusCode == 200) {
await file.writeAsBytes(response.bodyBytes);
} else {
return null;
}
} else {
await File(imageUriOrPath).copy(file.path);
}
return file.existsSync() ? file.path : null;
} catch (_) {
return null;
}
}
}