1
0
mirror of https://gitlab.com/comunic/comunicmobile synced 2024-11-22 12:59:21 +00:00

Can change group name

This commit is contained in:
Pierre HUBERT 2020-05-01 15:39:54 +02:00
parent 257523b526
commit d889321b38
4 changed files with 59 additions and 2 deletions

View File

@ -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"],
); );

View File

@ -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;

View File

@ -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
View 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));