mirror of
https://github.com/SyncrowIOT/web.git
synced 2025-07-10 07:07:19 +00:00
updated create community dialog to mange edit/create
This commit is contained in:
@ -72,6 +72,7 @@ class _BlankCommunityWidgetState extends State<BlankCommunityWidget> {
|
|||||||
showDialog(
|
showDialog(
|
||||||
context: parentContext,
|
context: parentContext,
|
||||||
builder: (context) => CreateCommunityDialog(
|
builder: (context) => CreateCommunityDialog(
|
||||||
|
isEditMode: false,
|
||||||
communities: widget.communities,
|
communities: widget.communities,
|
||||||
onCreateCommunity: (String communityName, String description) {
|
onCreateCommunity: (String communityName, String description) {
|
||||||
parentContext.read<SpaceManagementBloc>().add(
|
parentContext.read<SpaceManagementBloc>().add(
|
||||||
@ -84,4 +85,5 @@ class _BlankCommunityWidgetState extends State<BlankCommunityWidget> {
|
|||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,12 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_svg/flutter_svg.dart';
|
import 'package:flutter_svg/flutter_svg.dart';
|
||||||
import 'package:syncrow_web/pages/common/buttons/default_button.dart';
|
import 'package:syncrow_web/pages/common/buttons/default_button.dart';
|
||||||
|
import 'package:syncrow_web/pages/spaces_management/model/community_model.dart';
|
||||||
|
import 'package:syncrow_web/pages/spaces_management/widgets/dialogs/create_community_dialog.dart';
|
||||||
import 'package:syncrow_web/utils/color_manager.dart';
|
import 'package:syncrow_web/utils/color_manager.dart';
|
||||||
import 'package:syncrow_web/utils/constants/assets.dart';
|
import 'package:syncrow_web/utils/constants/assets.dart';
|
||||||
|
|
||||||
class CommunityStructureHeader extends StatelessWidget {
|
class CommunityStructureHeader extends StatefulWidget {
|
||||||
final String? communityName;
|
final String? communityName;
|
||||||
final bool isEditingName;
|
final bool isEditingName;
|
||||||
final bool isSave;
|
final bool isSave;
|
||||||
@ -13,19 +15,28 @@ class CommunityStructureHeader extends StatelessWidget {
|
|||||||
final VoidCallback onDelete;
|
final VoidCallback onDelete;
|
||||||
final VoidCallback onEditName;
|
final VoidCallback onEditName;
|
||||||
final ValueChanged<String> onNameSubmitted;
|
final ValueChanged<String> onNameSubmitted;
|
||||||
|
final List<CommunityModel> communities;
|
||||||
|
final CommunityModel? community;
|
||||||
|
|
||||||
const CommunityStructureHeader({
|
const CommunityStructureHeader(
|
||||||
Key? key,
|
{super.key,
|
||||||
required this.communityName,
|
required this.communityName,
|
||||||
required this.isSave,
|
required this.isSave,
|
||||||
required this.isEditingName,
|
required this.isEditingName,
|
||||||
required this.nameController,
|
required this.nameController,
|
||||||
required this.onSave,
|
required this.onSave,
|
||||||
required this.onDelete,
|
required this.onDelete,
|
||||||
required this.onEditName,
|
required this.onEditName,
|
||||||
required this.onNameSubmitted,
|
required this.onNameSubmitted,
|
||||||
}) : super(key: key);
|
this.community,
|
||||||
|
required this.communities});
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<CommunityStructureHeader> createState() =>
|
||||||
|
_CommunityStructureHeaderState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _CommunityStructureHeaderState extends State<CommunityStructureHeader> {
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final theme = Theme.of(context);
|
final theme = Theme.of(context);
|
||||||
@ -60,47 +71,62 @@ class CommunityStructureHeader extends StatelessWidget {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void _showCreateCommunityDialog(BuildContext parentContext) {
|
||||||
|
showDialog(
|
||||||
|
context: parentContext,
|
||||||
|
builder: (context) => CreateCommunityDialog(
|
||||||
|
isEditMode: true,
|
||||||
|
communities: widget.communities,
|
||||||
|
communityToEdit: widget.community,
|
||||||
|
onCreateCommunity: (String communityName, String description) {
|
||||||
|
widget.onNameSubmitted(communityName);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
Widget _buildCommunityInfo(ThemeData theme, double screenWidth) {
|
Widget _buildCommunityInfo(ThemeData theme, double screenWidth) {
|
||||||
return Column(
|
return Column(
|
||||||
crossAxisAlignment: CrossAxisAlignment.start,
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
children: [
|
children: [
|
||||||
Text(
|
Text(
|
||||||
'Community Structure',
|
'Community Structure',
|
||||||
style: theme.textTheme.headlineLarge?.copyWith(color: ColorsManager.blackColor),
|
style: theme.textTheme.headlineLarge
|
||||||
|
?.copyWith(color: ColorsManager.blackColor),
|
||||||
),
|
),
|
||||||
if (communityName != null)
|
if (widget.communityName != null)
|
||||||
Row(
|
Row(
|
||||||
children: [
|
children: [
|
||||||
Expanded(
|
Expanded(
|
||||||
child: Row(
|
child: Row(
|
||||||
children: [
|
children: [
|
||||||
if (!isEditingName)
|
if (!widget.isEditingName)
|
||||||
Flexible(
|
Flexible(
|
||||||
child: Text(
|
child: Text(
|
||||||
communityName!,
|
widget.communityName!,
|
||||||
style:
|
style: theme.textTheme.bodyLarge
|
||||||
theme.textTheme.bodyLarge?.copyWith(color: ColorsManager.blackColor),
|
?.copyWith(color: ColorsManager.blackColor),
|
||||||
overflow: TextOverflow.ellipsis,
|
overflow: TextOverflow.ellipsis,
|
||||||
maxLines: 1,
|
maxLines: 1,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
if (isEditingName)
|
if (widget.isEditingName)
|
||||||
SizedBox(
|
SizedBox(
|
||||||
width: screenWidth * 0.1,
|
width: screenWidth * 0.1,
|
||||||
child: TextField(
|
child: TextField(
|
||||||
controller: nameController,
|
controller: widget.nameController,
|
||||||
decoration: const InputDecoration(
|
decoration: const InputDecoration(
|
||||||
border: InputBorder.none,
|
border: InputBorder.none,
|
||||||
isDense: true,
|
isDense: true,
|
||||||
),
|
),
|
||||||
style:
|
style: theme.textTheme.bodyLarge
|
||||||
theme.textTheme.bodyLarge?.copyWith(color: ColorsManager.blackColor),
|
?.copyWith(color: ColorsManager.blackColor),
|
||||||
onSubmitted: onNameSubmitted,
|
onSubmitted: widget.onNameSubmitted,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
const SizedBox(width: 2),
|
const SizedBox(width: 2),
|
||||||
GestureDetector(
|
GestureDetector(
|
||||||
onTap: onEditName,
|
onTap: () => _showCreateCommunityDialog(context),
|
||||||
child: SvgPicture.asset(
|
child: SvgPicture.asset(
|
||||||
Assets.iconEdit,
|
Assets.iconEdit,
|
||||||
width: 16,
|
width: 16,
|
||||||
@ -110,7 +136,7 @@ class CommunityStructureHeader extends StatelessWidget {
|
|||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
if (isSave) ...[
|
if (widget.isSave) ...[
|
||||||
const SizedBox(width: 8),
|
const SizedBox(width: 8),
|
||||||
_buildActionButtons(theme),
|
_buildActionButtons(theme),
|
||||||
],
|
],
|
||||||
@ -127,8 +153,9 @@ class CommunityStructureHeader extends StatelessWidget {
|
|||||||
children: [
|
children: [
|
||||||
_buildButton(
|
_buildButton(
|
||||||
label: "Save",
|
label: "Save",
|
||||||
icon: const Icon(Icons.save, size: 18, color: ColorsManager.spaceColor),
|
icon: const Icon(Icons.save,
|
||||||
onPressed: onSave,
|
size: 18, color: ColorsManager.spaceColor),
|
||||||
|
onPressed: widget.onSave,
|
||||||
theme: theme),
|
theme: theme),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
@ -159,7 +186,8 @@ class CommunityStructureHeader extends StatelessWidget {
|
|||||||
Flexible(
|
Flexible(
|
||||||
child: Text(
|
child: Text(
|
||||||
label,
|
label,
|
||||||
style: theme.textTheme.bodySmall?.copyWith(color: ColorsManager.blackColor),
|
style: theme.textTheme.bodySmall
|
||||||
|
?.copyWith(color: ColorsManager.blackColor),
|
||||||
overflow: TextOverflow.ellipsis,
|
overflow: TextOverflow.ellipsis,
|
||||||
maxLines: 1,
|
maxLines: 1,
|
||||||
),
|
),
|
||||||
|
@ -119,7 +119,9 @@ class _CommunityStructureAreaState extends State<CommunityStructureArea> {
|
|||||||
crossAxisAlignment: CrossAxisAlignment.start,
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
children: [
|
children: [
|
||||||
CommunityStructureHeader(
|
CommunityStructureHeader(
|
||||||
|
communities: widget.communities,
|
||||||
communityName: widget.selectedCommunity?.name,
|
communityName: widget.selectedCommunity?.name,
|
||||||
|
community: widget.selectedCommunity,
|
||||||
isSave: isSave(spaces),
|
isSave: isSave(spaces),
|
||||||
isEditingName: isEditingName,
|
isEditingName: isEditingName,
|
||||||
nameController: _nameController,
|
nameController: _nameController,
|
||||||
|
@ -7,9 +7,16 @@ import 'package:syncrow_web/utils/color_manager.dart';
|
|||||||
class CreateCommunityDialog extends StatefulWidget {
|
class CreateCommunityDialog extends StatefulWidget {
|
||||||
final Function(String name, String description) onCreateCommunity;
|
final Function(String name, String description) onCreateCommunity;
|
||||||
final List<CommunityModel> communities;
|
final List<CommunityModel> communities;
|
||||||
|
final bool isEditMode;
|
||||||
|
final CommunityModel? communityToEdit;
|
||||||
|
|
||||||
const CreateCommunityDialog(
|
const CreateCommunityDialog({
|
||||||
{super.key, required this.onCreateCommunity, required this.communities});
|
super.key,
|
||||||
|
required this.onCreateCommunity,
|
||||||
|
required this.communities,
|
||||||
|
required this.isEditMode,
|
||||||
|
this.communityToEdit,
|
||||||
|
});
|
||||||
|
|
||||||
@override
|
@override
|
||||||
CreateCommunityDialogState createState() => CreateCommunityDialogState();
|
CreateCommunityDialogState createState() => CreateCommunityDialogState();
|
||||||
@ -19,6 +26,16 @@ class CreateCommunityDialogState extends State<CreateCommunityDialog> {
|
|||||||
String enteredName = '';
|
String enteredName = '';
|
||||||
bool isNameFieldExist = false;
|
bool isNameFieldExist = false;
|
||||||
bool isNameEmpty = false;
|
bool isNameEmpty = false;
|
||||||
|
late TextEditingController nameController;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
// Initialize fields for edit mode or set defaults for create mode
|
||||||
|
nameController = TextEditingController(
|
||||||
|
text: widget.isEditMode ? widget.communityToEdit?.name ?? '' : '',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
@ -52,9 +69,9 @@ class CreateCommunityDialogState extends State<CreateCommunityDialog> {
|
|||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
crossAxisAlignment: CrossAxisAlignment.start,
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
children: [
|
children: [
|
||||||
const Text(
|
Text(
|
||||||
'Community Name',
|
widget.isEditMode ? 'Edit Community Name' : 'Community Name',
|
||||||
style: TextStyle(
|
style: const TextStyle(
|
||||||
fontSize: 20,
|
fontSize: 20,
|
||||||
fontWeight: FontWeight.bold,
|
fontWeight: FontWeight.bold,
|
||||||
),
|
),
|
||||||
@ -62,11 +79,14 @@ class CreateCommunityDialogState extends State<CreateCommunityDialog> {
|
|||||||
const SizedBox(height: 16),
|
const SizedBox(height: 16),
|
||||||
// Input field for the community name
|
// Input field for the community name
|
||||||
TextField(
|
TextField(
|
||||||
|
controller: nameController,
|
||||||
onChanged: (value) {
|
onChanged: (value) {
|
||||||
setState(() {
|
setState(() {
|
||||||
enteredName = value.trim();
|
enteredName = value.trim();
|
||||||
isNameFieldExist = widget.communities.any(
|
isNameFieldExist = widget.communities.any(
|
||||||
(community) => community.name == enteredName,
|
(community) =>
|
||||||
|
community.name == enteredName &&
|
||||||
|
widget.communityToEdit != community,
|
||||||
);
|
);
|
||||||
if (value.isEmpty) {
|
if (value.isEmpty) {
|
||||||
isNameEmpty = true;
|
isNameEmpty = true;
|
||||||
@ -99,7 +119,8 @@ class CreateCommunityDialogState extends State<CreateCommunityDialog> {
|
|||||||
borderSide: BorderSide(
|
borderSide: BorderSide(
|
||||||
color: isNameFieldExist || isNameEmpty
|
color: isNameFieldExist || isNameEmpty
|
||||||
? ColorsManager.red
|
? ColorsManager.red
|
||||||
: ColorsManager.boxColor, width: 1),
|
: ColorsManager.boxColor,
|
||||||
|
width: 1),
|
||||||
borderRadius: BorderRadius.circular(10),
|
borderRadius: BorderRadius.circular(10),
|
||||||
),
|
),
|
||||||
focusedBorder: OutlineInputBorder(
|
focusedBorder: OutlineInputBorder(
|
||||||
|
Reference in New Issue
Block a user