feat(cache): add SimpleCacheManager and cache formatted rates/amounts in exchange and currency services
This commit is contained in:
@@ -1,10 +1,17 @@
|
||||
import 'package:intl/intl.dart';
|
||||
import '../models/subscription_model.dart';
|
||||
import 'exchange_rate_service.dart';
|
||||
import 'cache_manager.dart';
|
||||
|
||||
/// 통화 단위 변환 및 포맷팅을 위한 유틸리티 클래스
|
||||
class CurrencyUtil {
|
||||
static final ExchangeRateService _exchangeRateService = ExchangeRateService();
|
||||
static final SimpleCacheManager<String> _fmtCache =
|
||||
SimpleCacheManager<String>(
|
||||
maxEntries: 256,
|
||||
maxBytes: 256 * 1024,
|
||||
ttl: const Duration(minutes: 15),
|
||||
);
|
||||
|
||||
/// 언어에 따른 기본 통화 반환
|
||||
static String getDefaultCurrency(String locale) {
|
||||
@@ -80,11 +87,19 @@ class CurrencyUtil {
|
||||
String currency,
|
||||
String locale,
|
||||
) async {
|
||||
// 캐시 조회
|
||||
final decimals = (currency == 'KRW' || currency == 'JPY') ? 0 : 2;
|
||||
final key = 'fmt:$locale:$currency:${amount.toStringAsFixed(decimals)}';
|
||||
final cached = _fmtCache.get(key);
|
||||
if (cached != null) return cached;
|
||||
|
||||
final defaultCurrency = getDefaultCurrency(locale);
|
||||
|
||||
// 입력 통화가 기본 통화인 경우
|
||||
if (currency == defaultCurrency) {
|
||||
return _formatSingleCurrency(amount, currency);
|
||||
final result = _formatSingleCurrency(amount, currency);
|
||||
_fmtCache.set(key, result, size: result.length);
|
||||
return result;
|
||||
}
|
||||
|
||||
// USD 입력인 경우 - 기본 통화로 변환하여 표시
|
||||
@@ -95,17 +110,23 @@ class CurrencyUtil {
|
||||
final primaryFormatted =
|
||||
_formatSingleCurrency(convertedAmount, defaultCurrency);
|
||||
final usdFormatted = _formatSingleCurrency(amount, 'USD');
|
||||
return '$primaryFormatted ($usdFormatted)';
|
||||
final result = '$primaryFormatted ($usdFormatted)';
|
||||
_fmtCache.set(key, result, size: result.length);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
// 영어 사용자가 KRW 선택한 경우
|
||||
if (locale == 'en' && currency == 'KRW') {
|
||||
return _formatSingleCurrency(amount, currency);
|
||||
final result = _formatSingleCurrency(amount, currency);
|
||||
_fmtCache.set(key, result, size: result.length);
|
||||
return result;
|
||||
}
|
||||
|
||||
// 기타 통화 입력인 경우
|
||||
return _formatSingleCurrency(amount, currency);
|
||||
final result = _formatSingleCurrency(amount, currency);
|
||||
_fmtCache.set(key, result, size: result.length);
|
||||
return result;
|
||||
}
|
||||
|
||||
/// 구독 목록의 총 월 비용을 계산 (언어별 기본 통화로)
|
||||
@@ -141,7 +162,20 @@ class CurrencyUtil {
|
||||
static Future<String> formatSubscriptionAmountWithLocale(
|
||||
SubscriptionModel subscription, String locale) async {
|
||||
final price = subscription.currentPrice;
|
||||
return formatAmountWithLocale(price, subscription.currency, locale);
|
||||
// 구독 단위 캐시 키 (통화/가격/locale + id)
|
||||
final decimals =
|
||||
(subscription.currency == 'KRW' || subscription.currency == 'JPY')
|
||||
? 0
|
||||
: 2;
|
||||
final key =
|
||||
'subfmt:$locale:${subscription.currency}:${price.toStringAsFixed(decimals)}:${subscription.id}';
|
||||
final cached = _fmtCache.get(key);
|
||||
if (cached != null) return cached;
|
||||
|
||||
final result =
|
||||
await formatAmountWithLocale(price, subscription.currency, locale);
|
||||
_fmtCache.set(key, result, size: result.length);
|
||||
return result;
|
||||
}
|
||||
|
||||
/// 구독의 월 비용을 표시 형식에 맞게 변환 (원화 변환 포함, 이벤트 가격 반영) - 기존 호환성 유지
|
||||
|
||||
Reference in New Issue
Block a user