fluffychat/lib/utils/localized_exception_extension.dart

61 lines
2.0 KiB
Dart
Raw Normal View History

//@dart=2.12
import 'dart:io';
2020-12-25 09:58:34 +01:00
import 'package:flutter/material.dart';
2021-10-26 18:50:34 +02:00
2020-12-25 09:58:34 +01:00
import 'package:flutter_gen/gen_l10n/l10n.dart';
2021-10-26 18:50:34 +02:00
import 'package:matrix/matrix.dart';
2020-12-25 09:58:34 +01:00
2021-10-30 14:06:10 +02:00
import 'uia_request_manager.dart';
2020-12-25 09:58:34 +01:00
extension LocalizedExceptionExtension on Object {
String toLocalizedString(BuildContext context) {
if (this is MatrixException) {
switch ((this as MatrixException).error) {
case MatrixError.M_FORBIDDEN:
return L10n.of(context)!.noPermission;
2020-12-25 09:58:34 +01:00
case MatrixError.M_LIMIT_EXCEEDED:
return L10n.of(context)!.tooManyRequestsWarning;
2020-12-25 09:58:34 +01:00
default:
return (this as MatrixException).errorMessage;
}
}
if (this is BadServerVersionsException) {
final serverVersions = (this as BadServerVersionsException)
.serverVersions
.toString()
.replaceAll('{', '"')
.replaceAll('}', '"');
final supportedVersions = (this as BadServerVersionsException)
.supportedVersions
.toString()
.replaceAll('{', '"')
.replaceAll('}', '"');
return L10n.of(context)!
.badServerVersionsException(serverVersions, supportedVersions);
}
if (this is BadServerLoginTypesException) {
final serverVersions = (this as BadServerLoginTypesException)
.serverLoginTypes
.toString()
.replaceAll('{', '"')
.replaceAll('}', '"');
final supportedVersions = (this as BadServerLoginTypesException)
.supportedLoginTypes
.toString()
.replaceAll('{', '"')
.replaceAll('}', '"');
return L10n.of(context)!
.badServerLoginTypesException(serverVersions, supportedVersions);
}
if (this is MatrixConnectionException || this is SocketException) {
return L10n.of(context)!.noConnectionToTheServer;
2020-12-25 09:58:34 +01:00
}
2021-11-14 13:56:36 +01:00
if (this is String) return toString();
2021-10-30 14:06:10 +02:00
if (this is UiaException) return toString();
2021-02-06 20:41:24 +01:00
Logs().w('Something went wrong: ', this);
return L10n.of(context)!.oopsSomethingWentWrong;
2020-12-25 09:58:34 +01:00
}
}