fix group visit
Signed-off-by: 21pages <pages21@163.com>
This commit is contained in:
parent
5a14945666
commit
8b7a145c61
flutter/lib
common
models
@ -15,19 +15,19 @@ class HttpType {
|
|||||||
}
|
}
|
||||||
|
|
||||||
class UserPayload {
|
class UserPayload {
|
||||||
|
String id = '';
|
||||||
String name = '';
|
String name = '';
|
||||||
String email = '';
|
String email = '';
|
||||||
String note = '';
|
String note = '';
|
||||||
int? status;
|
int? status;
|
||||||
String grp = '';
|
|
||||||
bool isAdmin = false;
|
bool isAdmin = false;
|
||||||
|
|
||||||
UserPayload.fromJson(Map<String, dynamic> json)
|
UserPayload.fromJson(Map<String, dynamic> json)
|
||||||
: name = json['name'] ?? '',
|
: id = json['id'] ?? '',
|
||||||
|
name = json['name'] ?? '',
|
||||||
email = json['email'] ?? '',
|
email = json['email'] ?? '',
|
||||||
note = json['note'] ?? '',
|
note = json['note'] ?? '',
|
||||||
status = json['status'],
|
status = json['status'],
|
||||||
grp = json['grp'] ?? '',
|
|
||||||
isAdmin = json['is_admin'] == true;
|
isAdmin = json['is_admin'] == true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_hbb/common/hbbs/hbbs.dart';
|
||||||
import 'package:flutter_hbb/common/widgets/peers_view.dart';
|
import 'package:flutter_hbb/common/widgets/peers_view.dart';
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
|
|
||||||
@ -37,13 +38,13 @@ class _MyGroupState extends State<MyGroup> {
|
|||||||
|
|
||||||
Future<Widget> buildBody(BuildContext context) async {
|
Future<Widget> buildBody(BuildContext context) async {
|
||||||
return Obx(() {
|
return Obx(() {
|
||||||
if (gFFI.groupModel.userLoading.value) {
|
if (gFFI.groupModel.groupLoading.value) {
|
||||||
return const Center(
|
return const Center(
|
||||||
child: CircularProgressIndicator(),
|
child: CircularProgressIndicator(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (gFFI.groupModel.userLoadError.isNotEmpty) {
|
if (gFFI.groupModel.groupLoadError.isNotEmpty) {
|
||||||
return _buildShowError(gFFI.groupModel.userLoadError.value);
|
return _buildShowError(gFFI.groupModel.groupLoadError.value);
|
||||||
}
|
}
|
||||||
if (isDesktop) {
|
if (isDesktop) {
|
||||||
return _buildDesktop();
|
return _buildDesktop();
|
||||||
@ -187,16 +188,17 @@ class _MyGroupState extends State<MyGroup> {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
})
|
})
|
||||||
.map((e) => _buildUserItem(e.name))
|
.map((e) => _buildUserItem(e))
|
||||||
.toList());
|
.toList());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget _buildUserItem(String username) {
|
Widget _buildUserItem(UserPayload user) {
|
||||||
|
final username = user.name;
|
||||||
return InkWell(onTap: () {
|
return InkWell(onTap: () {
|
||||||
if (selectedUser.value != username) {
|
if (selectedUser.value != username) {
|
||||||
selectedUser.value = username;
|
selectedUser.value = username;
|
||||||
gFFI.groupModel.pullUserPeers(username);
|
gFFI.groupModel.pullUserPeers(user);
|
||||||
}
|
}
|
||||||
}, child: Obx(
|
}, child: Obx(
|
||||||
() {
|
() {
|
||||||
|
@ -231,7 +231,9 @@ class _PeerTabPageState extends State<PeerTabPage>
|
|||||||
if (model.visibleOrderedTabs.contains(model.currentTab)) {
|
if (model.visibleOrderedTabs.contains(model.currentTab)) {
|
||||||
child = entries[model.currentTab].widget;
|
child = entries[model.currentTab].widget;
|
||||||
} else {
|
} else {
|
||||||
|
Future.delayed(Duration.zero, () {
|
||||||
model.setCurrentTab(model.visibleOrderedTabs[0]);
|
model.setCurrentTab(model.visibleOrderedTabs[0]);
|
||||||
|
});
|
||||||
child = entries[0].widget;
|
child = entries[0].widget;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:flutter_hbb/common.dart';
|
import 'package:flutter_hbb/common.dart';
|
||||||
import 'package:flutter_hbb/common/widgets/peer_tab_page.dart';
|
|
||||||
import 'package:flutter_hbb/common/hbbs/hbbs.dart';
|
import 'package:flutter_hbb/common/hbbs/hbbs.dart';
|
||||||
import 'package:flutter_hbb/models/model.dart';
|
import 'package:flutter_hbb/models/model.dart';
|
||||||
import 'package:flutter_hbb/models/peer_model.dart';
|
import 'package:flutter_hbb/models/peer_model.dart';
|
||||||
@ -10,10 +9,12 @@ import 'dart:convert';
|
|||||||
import 'package:http/http.dart' as http;
|
import 'package:http/http.dart' as http;
|
||||||
|
|
||||||
class GroupModel {
|
class GroupModel {
|
||||||
final RxBool userLoading = false.obs;
|
final RxBool groupLoading = false.obs;
|
||||||
final RxString userLoadError = "".obs;
|
final RxString groupLoadError = "".obs;
|
||||||
final RxBool peerLoading = false.obs; //to-do: not used
|
final RxBool peerLoading = false.obs; //to-do: not used
|
||||||
final RxString peerLoadError = "".obs;
|
final RxString peerLoadError = "".obs;
|
||||||
|
final RxString groupName = ''.obs;
|
||||||
|
final RxString groupId = ''.obs;
|
||||||
final RxList<UserPayload> users = RxList.empty(growable: true);
|
final RxList<UserPayload> users = RxList.empty(growable: true);
|
||||||
final RxList<PeerPayload> peerPayloads = RxList.empty(growable: true);
|
final RxList<PeerPayload> peerPayloads = RxList.empty(growable: true);
|
||||||
final RxList<Peer> peersShow = RxList.empty(growable: true);
|
final RxList<Peer> peersShow = RxList.empty(growable: true);
|
||||||
@ -22,10 +23,12 @@ class GroupModel {
|
|||||||
GroupModel(this.parent);
|
GroupModel(this.parent);
|
||||||
|
|
||||||
Future<void> reset() async {
|
Future<void> reset() async {
|
||||||
userLoading.value = false;
|
groupLoading.value = false;
|
||||||
userLoadError.value = "";
|
groupLoadError.value = "";
|
||||||
peerLoading.value = false;
|
peerLoading.value = false;
|
||||||
peerLoadError.value = "";
|
peerLoadError.value = "";
|
||||||
|
groupName.value = '';
|
||||||
|
groupId.value = '';
|
||||||
users.clear();
|
users.clear();
|
||||||
peerPayloads.clear();
|
peerPayloads.clear();
|
||||||
peersShow.clear();
|
peersShow.clear();
|
||||||
@ -33,13 +36,26 @@ class GroupModel {
|
|||||||
|
|
||||||
Future<void> pull() async {
|
Future<void> pull() async {
|
||||||
await reset();
|
await reset();
|
||||||
|
if (bind.mainGetLocalOption(key: 'access_token') == '') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
if (!await _getGroup()) {
|
||||||
|
reset();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
debugPrintStack(label: '$e');
|
||||||
|
reset();
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (gFFI.userModel.userName.isEmpty ||
|
if (gFFI.userModel.userName.isEmpty ||
|
||||||
(gFFI.userModel.isAdmin.isFalse && gFFI.userModel.groupName.isEmpty)) {
|
(gFFI.userModel.isAdmin.isFalse && groupName.isEmpty)) {
|
||||||
gFFI.peerTabModel.check_dynamic_tabs();
|
gFFI.peerTabModel.check_dynamic_tabs();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
userLoading.value = true;
|
groupLoading.value = true;
|
||||||
userLoadError.value = "";
|
groupLoadError.value = "";
|
||||||
final api = "${await bind.mainGetApiServer()}/api/users";
|
final api = "${await bind.mainGetApiServer()}/api/users";
|
||||||
try {
|
try {
|
||||||
var uri0 = Uri.parse(api);
|
var uri0 = Uri.parse(api);
|
||||||
@ -56,8 +72,7 @@ class GroupModel {
|
|||||||
queryParameters: {
|
queryParameters: {
|
||||||
'current': current.toString(),
|
'current': current.toString(),
|
||||||
'pageSize': pageSize.toString(),
|
'pageSize': pageSize.toString(),
|
||||||
if (gFFI.userModel.isAdmin.isFalse)
|
if (gFFI.userModel.isAdmin.isFalse) 'grp': groupId.value,
|
||||||
'grp': gFFI.userModel.groupName.value,
|
|
||||||
});
|
});
|
||||||
final resp = await http.get(uri, headers: getHttpHeaders());
|
final resp = await http.get(uri, headers: getHttpHeaders());
|
||||||
if (resp.body.isNotEmpty && resp.body.toLowerCase() != "null") {
|
if (resp.body.isNotEmpty && resp.body.toLowerCase() != "null") {
|
||||||
@ -65,12 +80,17 @@ class GroupModel {
|
|||||||
if (json.containsKey('error')) {
|
if (json.containsKey('error')) {
|
||||||
throw json['error'];
|
throw json['error'];
|
||||||
} else {
|
} else {
|
||||||
|
if (json.containsKey('total')) {
|
||||||
if (total == 0) total = json['total'];
|
if (total == 0) total = json['total'];
|
||||||
if (json.containsKey('data')) {
|
if (json.containsKey('data')) {
|
||||||
final data = json['data'];
|
final data = json['data'];
|
||||||
if (data is List) {
|
if (data is List) {
|
||||||
for (final user in data) {
|
for (final user in data) {
|
||||||
users.add(UserPayload.fromJson(user));
|
final u = UserPayload.fromJson(user);
|
||||||
|
if (!users.any((e) => e.name == u.name)) {
|
||||||
|
users.add(u);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -78,15 +98,43 @@ class GroupModel {
|
|||||||
}
|
}
|
||||||
} while (current * pageSize < total);
|
} while (current * pageSize < total);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
debugPrint('$err');
|
debugPrintStack(label: '$err');
|
||||||
userLoadError.value = err.toString();
|
groupLoadError.value = err.toString();
|
||||||
} finally {
|
} finally {
|
||||||
userLoading.value = false;
|
groupLoading.value = false;
|
||||||
gFFI.peerTabModel.check_dynamic_tabs();
|
gFFI.peerTabModel.check_dynamic_tabs();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> pullUserPeers(String username) async {
|
Future<bool> _getGroup() async {
|
||||||
|
final url = await bind.mainGetApiServer();
|
||||||
|
final body = {
|
||||||
|
'id': await bind.mainGetMyId(),
|
||||||
|
'uuid': await bind.mainGetUuid()
|
||||||
|
};
|
||||||
|
try {
|
||||||
|
final response = await http.post(Uri.parse('$url/api/currentGroup'),
|
||||||
|
headers: getHttpHeaders(), body: json.encode(body));
|
||||||
|
final status = response.statusCode;
|
||||||
|
if (status == 401 || status == 400) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final data = json.decode(response.body);
|
||||||
|
final error = data['error'];
|
||||||
|
if (error != null) {
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
groupName.value = data['name'] ?? '';
|
||||||
|
groupId.value = data['id'] ?? '';
|
||||||
|
return groupId.value.isNotEmpty && groupName.isNotEmpty;
|
||||||
|
} catch (e) {
|
||||||
|
debugPrintStack(label: '$e');
|
||||||
|
} finally {}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> pullUserPeers(UserPayload user) async {
|
||||||
peerPayloads.clear();
|
peerPayloads.clear();
|
||||||
peersShow.clear();
|
peersShow.clear();
|
||||||
peerLoading.value = true;
|
peerLoading.value = true;
|
||||||
@ -107,8 +155,7 @@ class GroupModel {
|
|||||||
queryParameters: {
|
queryParameters: {
|
||||||
'current': current.toString(),
|
'current': current.toString(),
|
||||||
'pageSize': pageSize.toString(),
|
'pageSize': pageSize.toString(),
|
||||||
'grp': gFFI.userModel.groupName.value,
|
'target_user': user.id,
|
||||||
'target_user': username
|
|
||||||
});
|
});
|
||||||
final resp = await http.get(uri, headers: getHttpHeaders());
|
final resp = await http.get(uri, headers: getHttpHeaders());
|
||||||
if (resp.body.isNotEmpty && resp.body.toLowerCase() != "null") {
|
if (resp.body.isNotEmpty && resp.body.toLowerCase() != "null") {
|
||||||
@ -116,6 +163,7 @@ class GroupModel {
|
|||||||
if (json.containsKey('error')) {
|
if (json.containsKey('error')) {
|
||||||
throw json['error'];
|
throw json['error'];
|
||||||
} else {
|
} else {
|
||||||
|
if (json.containsKey('total')) {
|
||||||
if (total == 0) total = json['total'];
|
if (total == 0) total = json['total'];
|
||||||
if (json.containsKey('data')) {
|
if (json.containsKey('data')) {
|
||||||
final data = json['data'];
|
final data = json['data'];
|
||||||
@ -129,9 +177,10 @@ class GroupModel {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} while (current * pageSize < total);
|
} while (current * pageSize < total);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
debugPrint('$err');
|
debugPrintStack(label: '$err');
|
||||||
peerLoadError.value = err.toString();
|
peerLoadError.value = err.toString();
|
||||||
} finally {
|
} finally {
|
||||||
peerLoading.value = false;
|
peerLoading.value = false;
|
||||||
|
@ -88,8 +88,9 @@ class PeerTabModel with ChangeNotifier {
|
|||||||
groupTabIndex) {
|
groupTabIndex) {
|
||||||
_currentTab = groupTabIndex;
|
_currentTab = groupTabIndex;
|
||||||
}
|
}
|
||||||
if (gFFI.userModel.isAdmin.isFalse && gFFI.userModel.groupName.isNotEmpty) {
|
if (gFFI.userModel.isAdmin.isFalse &&
|
||||||
tabNames[groupTabIndex] = gFFI.userModel.groupName.value;
|
gFFI.groupModel.groupName.isNotEmpty) {
|
||||||
|
tabNames[groupTabIndex] = gFFI.groupModel.groupName.value;
|
||||||
} else {
|
} else {
|
||||||
tabNames[groupTabIndex] = defaultGroupTabname;
|
tabNames[groupTabIndex] = defaultGroupTabname;
|
||||||
}
|
}
|
||||||
@ -221,7 +222,7 @@ class PeerTabModel with ChangeNotifier {
|
|||||||
// return true if hide group card
|
// return true if hide group card
|
||||||
bool _filterGroupCard() {
|
bool _filterGroupCard() {
|
||||||
if (gFFI.groupModel.users.isEmpty ||
|
if (gFFI.groupModel.users.isEmpty ||
|
||||||
(gFFI.userModel.isAdmin.isFalse && gFFI.userModel.groupName.isEmpty)) {
|
(gFFI.userModel.isAdmin.isFalse && gFFI.groupModel.groupName.isEmpty)) {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import 'dart:async';
|
import 'dart:async';
|
||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
|
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_hbb/common/hbbs/hbbs.dart';
|
import 'package:flutter_hbb/common/hbbs/hbbs.dart';
|
||||||
import 'package:flutter_hbb/common/widgets/peer_tab_page.dart';
|
import 'package:flutter_hbb/common/widgets/peer_tab_page.dart';
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
@ -12,7 +13,6 @@ import 'platform_model.dart';
|
|||||||
|
|
||||||
class UserModel {
|
class UserModel {
|
||||||
final RxString userName = ''.obs;
|
final RxString userName = ''.obs;
|
||||||
final RxString groupName = ''.obs;
|
|
||||||
final RxBool isAdmin = false.obs;
|
final RxBool isAdmin = false.obs;
|
||||||
WeakReference<FFI> parent;
|
WeakReference<FFI> parent;
|
||||||
|
|
||||||
@ -61,13 +61,11 @@ class UserModel {
|
|||||||
await gFFI.abModel.reset();
|
await gFFI.abModel.reset();
|
||||||
await gFFI.groupModel.reset();
|
await gFFI.groupModel.reset();
|
||||||
userName.value = '';
|
userName.value = '';
|
||||||
groupName.value = '';
|
|
||||||
gFFI.peerTabModel.check_dynamic_tabs();
|
gFFI.peerTabModel.check_dynamic_tabs();
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> _parseAndUpdateUser(UserPayload user) async {
|
Future<void> _parseAndUpdateUser(UserPayload user) async {
|
||||||
userName.value = user.name;
|
userName.value = user.name;
|
||||||
groupName.value = user.grp;
|
|
||||||
isAdmin.value = user.isAdmin;
|
isAdmin.value = user.isAdmin;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user