mirror of
https://gitlab.com/comunic/comunicmobile
synced 2024-11-22 21:09:21 +00:00
Can change group name
This commit is contained in:
parent
257523b526
commit
d889321b38
@ -3,6 +3,7 @@ import 'package:comunic/models/advanced_group_info.dart';
|
|||||||
import 'package:comunic/models/api_request.dart';
|
import 'package:comunic/models/api_request.dart';
|
||||||
import 'package:comunic/models/group.dart';
|
import 'package:comunic/models/group.dart';
|
||||||
import 'package:comunic/utils/api_utils.dart';
|
import 'package:comunic/utils/api_utils.dart';
|
||||||
|
import 'package:comunic/utils/map_utils.dart';
|
||||||
|
|
||||||
/// Groups helper
|
/// Groups helper
|
||||||
///
|
///
|
||||||
@ -192,6 +193,29 @@ class GroupsHelper {
|
|||||||
return groupInfo.info;
|
return groupInfo.info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Update (set) new group settings
|
||||||
|
///
|
||||||
|
/// Throws in case of error
|
||||||
|
static Future<void> setSettings(AdvancedGroupInfo settings) async {
|
||||||
|
await APIRequest(uri: "groups/set_settings", needLogin: true)
|
||||||
|
.addInt("id", settings.id)
|
||||||
|
.addString("name", settings.name)
|
||||||
|
.addString("virtual_directory", settings.virtualDirectory)
|
||||||
|
.addString("visibility",
|
||||||
|
invertMap(_APIGroupsVisibilityLevelsMap)[settings.visibilityLevel])
|
||||||
|
.addString(
|
||||||
|
"registration_level",
|
||||||
|
invertMap(
|
||||||
|
_APIGroupsRegistrationLevelsMap)[settings.registrationLevel])
|
||||||
|
.addString(
|
||||||
|
"posts_level",
|
||||||
|
invertMap(
|
||||||
|
_APIGroupsPostsCreationLevelsMap)[settings.postCreationLevel])
|
||||||
|
.addString("description", settings.description)
|
||||||
|
.addString("url", settings.url)
|
||||||
|
.execWithThrow();
|
||||||
|
}
|
||||||
|
|
||||||
/// Turn an API entry into a group object
|
/// Turn an API entry into a group object
|
||||||
Group _getGroupFromAPI(Map<String, dynamic> map) {
|
Group _getGroupFromAPI(Map<String, dynamic> map) {
|
||||||
return Group(
|
return Group(
|
||||||
@ -224,7 +248,7 @@ class GroupsHelper {
|
|||||||
following: map["following"],
|
following: map["following"],
|
||||||
timeCreate: map["time_create"],
|
timeCreate: map["time_create"],
|
||||||
description: map["description"],
|
description: map["description"],
|
||||||
url: map["url"],
|
url: map["url"] == "null" ? "" : map["url"],
|
||||||
likes: map["number_likes"],
|
likes: map["number_likes"],
|
||||||
userLike: map["is_liking"],
|
userLike: map["is_liking"],
|
||||||
);
|
);
|
||||||
|
@ -21,7 +21,7 @@ enum GroupPostCreationLevel { MODERATORS, MEMBERS }
|
|||||||
|
|
||||||
class Group {
|
class Group {
|
||||||
final int id;
|
final int id;
|
||||||
final String name;
|
String name;
|
||||||
final String iconURL;
|
final String iconURL;
|
||||||
final int numberMembers;
|
final int numberMembers;
|
||||||
GroupMembershipLevel membershipLevel;
|
GroupMembershipLevel membershipLevel;
|
||||||
|
@ -3,7 +3,9 @@ import 'package:comunic/models/advanced_group_info.dart';
|
|||||||
import 'package:comunic/ui/widgets/async_screen_widget.dart';
|
import 'package:comunic/ui/widgets/async_screen_widget.dart';
|
||||||
import 'package:comunic/ui/widgets/comunic_back_button_widget.dart';
|
import 'package:comunic/ui/widgets/comunic_back_button_widget.dart';
|
||||||
import 'package:comunic/ui/widgets/safe_state.dart';
|
import 'package:comunic/ui/widgets/safe_state.dart';
|
||||||
|
import 'package:comunic/ui/widgets/settings/text_settings_edit_tile.dart';
|
||||||
import 'package:comunic/utils/intl_utils.dart';
|
import 'package:comunic/utils/intl_utils.dart';
|
||||||
|
import 'package:comunic/utils/ui_utils.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:settings_ui/settings_ui.dart';
|
import 'package:settings_ui/settings_ui.dart';
|
||||||
|
|
||||||
@ -25,10 +27,23 @@ class GroupSettingsScreen extends StatefulWidget {
|
|||||||
class _GroupSettingsScreenState extends SafeState<GroupSettingsScreen> {
|
class _GroupSettingsScreenState extends SafeState<GroupSettingsScreen> {
|
||||||
AdvancedGroupInfo _groupSettings;
|
AdvancedGroupInfo _groupSettings;
|
||||||
|
|
||||||
|
final _key = GlobalKey<AsyncScreenWidgetState>();
|
||||||
|
|
||||||
Future<void> _refresh() async {
|
Future<void> _refresh() async {
|
||||||
_groupSettings = await GroupsHelper().getSettings(widget.groupID);
|
_groupSettings = await GroupsHelper().getSettings(widget.groupID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<void> _updateSettings() async {
|
||||||
|
try {
|
||||||
|
await GroupsHelper.setSettings(_groupSettings);
|
||||||
|
} catch (e, stack) {
|
||||||
|
print("Could not update group settings! $e\n$stack");
|
||||||
|
showSimpleSnack(context, tr("Could not update group settings!"));
|
||||||
|
}
|
||||||
|
|
||||||
|
_key.currentState.refresh();
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
@ -42,9 +57,11 @@ class _GroupSettingsScreenState extends SafeState<GroupSettingsScreen> {
|
|||||||
|
|
||||||
Widget _buildBody() {
|
Widget _buildBody() {
|
||||||
return AsyncScreenWidget(
|
return AsyncScreenWidget(
|
||||||
|
key: _key,
|
||||||
onReload: _refresh,
|
onReload: _refresh,
|
||||||
onBuild: _buildContent,
|
onBuild: _buildContent,
|
||||||
errorMessage: tr("Could not get group settings!"),
|
errorMessage: tr("Could not get group settings!"),
|
||||||
|
showOldDataWhileUpdating: true,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -58,10 +75,20 @@ class _GroupSettingsScreenState extends SafeState<GroupSettingsScreen> {
|
|||||||
return SettingsSection(
|
return SettingsSection(
|
||||||
title: tr("General information"),
|
title: tr("General information"),
|
||||||
tiles: [
|
tiles: [
|
||||||
|
// Group ID
|
||||||
SettingsTile(
|
SettingsTile(
|
||||||
title: tr("Group ID"),
|
title: tr("Group ID"),
|
||||||
subtitle: _groupSettings.id.toString(),
|
subtitle: _groupSettings.id.toString(),
|
||||||
),
|
),
|
||||||
|
|
||||||
|
// Group name
|
||||||
|
TextEditSettingsTile(
|
||||||
|
title: tr("Group name"),
|
||||||
|
currValue: _groupSettings.name,
|
||||||
|
onChanged: (s) {
|
||||||
|
_groupSettings.name = s;
|
||||||
|
_updateSettings();
|
||||||
|
}),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
6
lib/utils/map_utils.dart
Normal file
6
lib/utils/map_utils.dart
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
/// Map utilities
|
||||||
|
///
|
||||||
|
/// @author Pierre HUBERT
|
||||||
|
|
||||||
|
/// Invert the values of a map with their keys
|
||||||
|
Map<V, K> invertMap<K, V>(Map<K, V> m) => m.map((k, v) => MapEntry(v, k));
|
Loading…
Reference in New Issue
Block a user