fixed edit dialog

This commit is contained in:
hannathkadher
2025-01-08 19:56:42 +04:00
parent 6b79254a89
commit 9f5e9af5fa
6 changed files with 127 additions and 41 deletions

View File

@ -29,7 +29,6 @@ class CreateSpaceModelDialog extends StatelessWidget {
final SpaceModelManagementApi _spaceModelApi = SpaceModelManagementApi();
final screenWidth = MediaQuery.of(context).size.width;
List<SubspaceTemplateModel>? subspaces = spaceModel?.subspaceModels ?? [];
final TextEditingController spaceNameController = TextEditingController(
text: spaceModel?.modelName ?? '',
);
@ -104,8 +103,15 @@ class CreateSpaceModelDialog extends StatelessWidget {
),
),
const SizedBox(height: 16),
SubspaceModelCreate(context,
subspaces: state.space.subspaceModels ?? []),
SubspaceModelCreate(
context,
subspaces: state.space.subspaceModels ?? [],
allTags: allTags,
products: products,
spaceModel: spaceModel,
spaceTagModels: spaceModel?.tags ?? [],
spaceNameController: spaceNameController
),
const SizedBox(height: 10),
TagChipDisplay(context,
screenWidth: screenWidth,

View File

@ -1,25 +1,34 @@
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:syncrow_web/pages/spaces_management/space_model/bloc/create_space_model_event.dart';
import 'package:syncrow_web/pages/spaces_management/all_spaces/model/product_model.dart';
import 'package:syncrow_web/pages/spaces_management/space_model/models/space_template_model.dart';
import 'package:syncrow_web/pages/spaces_management/space_model/models/subspace_template_model.dart';
import 'package:syncrow_web/pages/spaces_management/space_model/models/tag_model.dart';
import 'package:syncrow_web/pages/spaces_management/space_model/widgets/button_content_widget.dart';
import 'package:syncrow_web/pages/spaces_management/create_subspace_model/views/create_subspace_model_dialog.dart';
import 'package:syncrow_web/utils/color_manager.dart';
import 'package:syncrow_web/pages/spaces_management/space_model/bloc/create_space_model_bloc.dart';
class SubspaceModelCreate extends StatelessWidget {
final List<SubspaceTemplateModel> subspaces;
final TextEditingController spaceNameController;
final List<TagModel>? spaceTagModels;
final List<String>? allTags;
final List<ProductModel>? products;
final SpaceTemplateModel? spaceModel;
const SubspaceModelCreate(
BuildContext context, {
Key? key,
required this.subspaces,
this.spaceTagModels,
required this.allTags,
required this.products,
required this.spaceModel,
required this.spaceNameController,
}) : super(key: key);
@override
Widget build(BuildContext context) {
final screenWidth = MediaQuery.of(context).size.width;
return Container(
child: subspaces.isEmpty
? TextButton(
@ -29,11 +38,16 @@ class SubspaceModelCreate extends StatelessWidget {
onPressed: () async {
Navigator.of(context).pop();
final result = await showDialog<List<SubspaceTemplateModel>>(
await showDialog<List<SubspaceTemplateModel>>(
barrierDismissible: false,
context: context,
builder: (BuildContext context) {
return CreateSubSpaceModelDialog(
allTags: allTags,
spaceName: spaceNameController.text,
spaceModel: spaceModel,
spaceTagModels: spaceTagModels,
products: products,
isEdit: true,
dialogTitle: subspaces.isEmpty
? 'Create Sub-space'
@ -42,14 +56,6 @@ class SubspaceModelCreate extends StatelessWidget {
);
},
);
if (result != null) {
subspaces.clear();
subspaces.addAll(result);
context
.read<CreateSpaceModelBloc>()
.add(AddSubspacesToSpaceTemplate(subspaces));
}
},
child: const ButtonContentWidget(
icon: Icons.add,
@ -90,8 +96,8 @@ class SubspaceModelCreate extends StatelessWidget {
),
GestureDetector(
onTap: () async {
final result =
await showDialog<List<SubspaceTemplateModel>>(
Navigator.of(context).pop();
await showDialog<List<SubspaceTemplateModel>>(
barrierDismissible: false,
context: context,
builder: (BuildContext context) {
@ -99,17 +105,14 @@ class SubspaceModelCreate extends StatelessWidget {
isEdit: true,
dialogTitle: 'Edit Sub-space',
existingSubSpaces: subspaces,
allTags: allTags,
spaceName: spaceNameController.text,
spaceTagModels: spaceTagModels,
products: products,
spaceModel: spaceModel,
);
},
);
if (result != null) {
subspaces.clear();
subspaces.addAll(result);
context
.read<CreateSpaceModelBloc>()
.add(AddSubspacesToSpaceTemplate(subspaces));
}
},
child: Chip(
label: const Text(

View File

@ -30,8 +30,7 @@ class TagChipDisplay extends StatelessWidget {
@override
Widget build(BuildContext context) {
return (spaceModel?.subspaceModels?.isNotEmpty == true ||
spaceModel?.tags?.isNotEmpty == true ||
return (spaceModel?.tags?.isNotEmpty == true ||
spaceModel?.subspaceModels
?.any((subspace) => subspace.tags?.isNotEmpty == true) ==
true)
@ -160,7 +159,6 @@ class TagChipDisplay extends StatelessWidget {
List<TagModel>? tags, List<SubspaceTemplateModel>? subspaces) {
final Map<ProductModel, int> productCounts = {};
// Count products in spaceModel tags
if (tags != null) {
for (var tag in tags) {
if (tag.product != null) {
@ -169,7 +167,6 @@ class TagChipDisplay extends StatelessWidget {
}
}
// Count products in subspaces
if (subspaces != null) {
for (var subspace in subspaces) {
if (subspace.tags != null) {
@ -183,7 +180,6 @@ class TagChipDisplay extends StatelessWidget {
}
}
// Create SelectedProduct instances
return productCounts.entries
.map((entry) => SelectedProduct(
productId: entry.key.uuid,