redesign user object

This commit is contained in:
Serhii 2023-02-13 00:38:12 +02:00
parent 624036d00c
commit 5c663c5596
3 changed files with 83 additions and 30 deletions

View file

@ -45,14 +45,23 @@ class AddressResolver {
final formattedName = text.substring(1);
final twitterUser = await TwitterApi.lookupUserByName(userName: formattedName);
final addressFromBio = extractAddressByType(
raw: twitterUser.description ?? '', type: CryptoCurrency.fromString(ticker));
final addressFromPinnedTweet = extractAddressByType(
raw: twitterUser.pinnedTweet ?? '', type: CryptoCurrency.fromString(ticker));
raw: twitterUser.data.description, type: CryptoCurrency.fromString(ticker));
if (addressFromBio != null) {
return ParsedAddress.fetchTwitterAddress(address: addressFromBio, name: text);
}
if (addressFromPinnedTweet != null) {
return ParsedAddress.fetchTwitterAddress(address: addressFromPinnedTweet, name: text);
final tweets = twitterUser.includes?.tweets;
if (tweets != null) {
var subString = StringBuffer();
tweets.forEach((item) {
subString.writeln(item.text);
});
final userTweetsText = subString.toString();
final addressFromPinnedTweet =
extractAddressByType(raw: userTweetsText, type: CryptoCurrency.fromString(ticker));
if (addressFromPinnedTweet != null) {
return ParsedAddress.fetchTwitterAddress(address: addressFromPinnedTweet, name: text);
}
}
}
if (!text.startsWith('@') && text.contains('@') && !text.contains('.')) {

View file

@ -32,16 +32,6 @@ class TwitterApi {
throw Exception(responseJSON['errors'][0]['detail']);
}
final user = responseJSON['data'] as Map<String, dynamic>;
try {
if (responseJSON['includes'] != null) {
user['pinnedTweet'] = responseJSON['includes']['tweets'][0]['text'];
}
} catch (e) {
print('responseJSON[includes][tweets][0][text] $e');
}
return TwitterUser.fromJson(user);
return TwitterUser.fromJson(responseJSON);
}
}

View file

@ -1,19 +1,73 @@
class TwitterUser {
TwitterUser({required this.id, required this.username, required this.name, this.description,
this.pinnedTweet});
TwitterUser({
required this.data,
this.includes,
});
final String id;
final String username;
final String name;
final String? description;
final String? pinnedTweet;
late final Data data;
late final Includes? includes;
factory TwitterUser.fromJson(Map<String, dynamic> json) {
return TwitterUser(
id: json['id'] as String,
username: json['username'] as String,
name: json['name'] as String,
description: json['description'] as String?,
pinnedTweet: json['pinnedTweet'] as String?);
TwitterUser.fromJson(Map<String, dynamic> json) {
data = Data.fromJson(json['data'] as Map<String, dynamic>);
includes = json['includes'] != null
? Includes.fromJson(json['includes'] as Map<String, dynamic>)
: null;
}
}
class Data {
Data({
required this.name,
required this.id,
required this.pinnedTweetId,
required this.description,
required this.username,
});
late final String name;
late final String id;
late final String? pinnedTweetId;
late final String description;
late final String username;
Data.fromJson(Map<String, dynamic> json) {
name = json['name'] as String;
id = json['id'] as String;
pinnedTweetId = json['pinned_tweet_id'] as String?;
description = json['description'] as String;
username = json['username'] as String;
}
}
class Includes {
Includes({
required this.tweets,
});
late final List<Tweets> tweets;
Includes.fromJson(Map<String, dynamic> json) {
tweets = List.from(json['tweets'] as Iterable<dynamic>)
.map((e) => Tweets.fromJson(e as Map<String, dynamic>))
.toList();
}
}
class Tweets {
Tweets({
required this.editHistoryTweetIds,
required this.id,
required this.text,
});
late final List<String> editHistoryTweetIds;
late final String id;
late final String text;
Tweets.fromJson(Map<String, dynamic> json) {
editHistoryTweetIds =
List.castFrom<dynamic, String>(json['edit_history_tweet_ids'] as List<dynamic>);
id = json['id'] as String;
text = json['text'] as String;
}
}