mirror of
https://gitlab.com/famedly/fluffychat.git
synced 2024-12-25 15:02:33 +01:00
Merge branch 'soru/nicer-device-detection' into 'main'
feat: Better detect the device type from the device name See merge request famedly/fluffychat!440
This commit is contained in:
commit
51e33562d8
@ -1,19 +1,38 @@
|
|||||||
import 'package:matrix/matrix.dart';
|
import 'package:matrix/matrix.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
IconData _getIconFromName(String displayname) {
|
||||||
|
final name = displayname.toLowerCase();
|
||||||
|
if ({'android'}.any((s) => name.contains(s))) {
|
||||||
|
return Icons.phone_android_outlined;
|
||||||
|
}
|
||||||
|
if ({'ios', 'ipad', 'iphone', 'ipod'}.any((s) => name.contains(s))) {
|
||||||
|
return Icons.phone_iphone_outlined;
|
||||||
|
}
|
||||||
|
if ({
|
||||||
|
'web',
|
||||||
|
'http://',
|
||||||
|
'https://',
|
||||||
|
'firefox',
|
||||||
|
'chrome',
|
||||||
|
'/_matrix',
|
||||||
|
'safari',
|
||||||
|
'opera',
|
||||||
|
}.any((s) => name.contains(s))) {
|
||||||
|
return Icons.web_outlined;
|
||||||
|
}
|
||||||
|
if ({'desktop', 'windows', 'macos', 'linux', 'ubuntu'}
|
||||||
|
.any((s) => name.contains(s))) {
|
||||||
|
return Icons.desktop_mac_outlined;
|
||||||
|
}
|
||||||
|
return Icons.device_unknown_outlined;
|
||||||
|
}
|
||||||
|
|
||||||
extension DeviceExtension on Device {
|
extension DeviceExtension on Device {
|
||||||
String get displayname =>
|
String get displayname =>
|
||||||
(displayName?.isNotEmpty ?? false) ? displayName : 'Unknown device';
|
(displayName?.isNotEmpty ?? false) ? displayName : 'Unknown device';
|
||||||
|
|
||||||
IconData get icon => displayname.toLowerCase().contains('android')
|
IconData get icon => _getIconFromName(displayname);
|
||||||
? Icons.phone_android_outlined
|
|
||||||
: displayname.toLowerCase().contains('ios')
|
|
||||||
? Icons.phone_iphone_outlined
|
|
||||||
: displayname.toLowerCase().contains('web')
|
|
||||||
? Icons.web_outlined
|
|
||||||
: displayname.toLowerCase().contains('desktop')
|
|
||||||
? Icons.desktop_mac_outlined
|
|
||||||
: Icons.device_unknown_outlined;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
extension DeviceKeysExtension on DeviceKeys {
|
extension DeviceKeysExtension on DeviceKeys {
|
||||||
@ -21,13 +40,5 @@ extension DeviceKeysExtension on DeviceKeys {
|
|||||||
? deviceDisplayName
|
? deviceDisplayName
|
||||||
: 'Unknown device';
|
: 'Unknown device';
|
||||||
|
|
||||||
IconData get icon => displayname.toLowerCase().contains('android')
|
IconData get icon => _getIconFromName(displayname);
|
||||||
? Icons.phone_android_outlined
|
|
||||||
: displayname.toLowerCase().contains('ios')
|
|
||||||
? Icons.phone_iphone_outlined
|
|
||||||
: displayname.toLowerCase().contains('web')
|
|
||||||
? Icons.web_outlined
|
|
||||||
: displayname.toLowerCase().contains('desktop')
|
|
||||||
? Icons.desktop_mac_outlined
|
|
||||||
: Icons.device_unknown_outlined;
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user