Fix PR notes.

This commit is contained in:
Faris Armoush
2025-06-17 11:26:48 +03:00
parent 9600f4fb8b
commit 0132805713
13 changed files with 71 additions and 141 deletions

View File

@ -13,12 +13,12 @@ class CommunitiesBloc extends Bloc<CommunitiesEvent, CommunitiesState> {
required CommunitiesService communitiesService,
}) : _communitiesService = communitiesService,
super(const CommunitiesState()) {
on<LoadCommunities>(_onGetCommunity);
on<LoadCommunities>(_onLoadCommunities);
}
final CommunitiesService _communitiesService;
Future<void> _onGetCommunity(
Future<void> _onLoadCommunities(
LoadCommunities event,
Emitter<CommunitiesState> emit,
) async {

View File

@ -1,5 +1,5 @@
import 'package:dio/dio.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/models/product_model.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/models/product.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/params/load_products_param.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/services/products_service.dart';
import 'package:syncrow_web/services/api/api_exception.dart';
@ -13,7 +13,7 @@ class RemoteProductsService implements ProductsService {
static const _defaultErrorMessage = 'Failed to load devices';
@override
Future<List<ProductModel>> getProducts(LoadProductsParam param) async {
Future<List<Product>> getProducts(LoadProductsParam param) async {
try {
final response = await _httpService.get(
path: 'devices',
@ -24,7 +24,7 @@ class RemoteProductsService implements ProductsService {
},
expectedResponseModel: (data) {
return (data as List)
.map((e) => ProductModel.fromJson(e as Map<String, dynamic>))
.map((e) => Product.fromJson(e as Map<String, dynamic>))
.toList();
},
);

View File

@ -1,21 +1,28 @@
import 'package:equatable/equatable.dart';
class ProductModel extends Equatable {
class Product extends Equatable {
final String uuid;
final String name;
const ProductModel({
const Product({
required this.uuid,
required this.name,
});
factory ProductModel.fromJson(Map<String, dynamic> json) {
return ProductModel(
factory Product.fromJson(Map<String, dynamic> json) {
return Product(
uuid: json['uuid'] as String,
name: json['name'] as String,
);
}
Map<String, dynamic> toJson() {
return {
'uuid': uuid,
'name': name,
};
}
@override
List<Object?> get props => [uuid, name];
}

View File

@ -1,6 +1,6 @@
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/models/product_model.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/models/product.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/params/load_products_param.dart';
abstract class ProductsService {
Future<List<ProductModel>> getProducts(LoadProductsParam param);
Future<List<Product>> getProducts(LoadProductsParam param);
}

View File

@ -1,6 +1,6 @@
import 'package:bloc/bloc.dart';
import 'package:equatable/equatable.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/models/product_model.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/models/product.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/params/load_products_param.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/services/products_service.dart';
import 'package:syncrow_web/services/api/api_exception.dart';
@ -12,10 +12,10 @@ class ProductsBloc extends Bloc<ProductsEvent, ProductsState> {
final ProductsService _deviceService;
ProductsBloc(this._deviceService) : super(ProductsInitial()) {
on<LoadProducts>(_onLoadDevices);
on<LoadProducts>(_onLoadProducts);
}
Future<void> _onLoadDevices(
Future<void> _onLoadProducts(
LoadProducts event,
Emitter<ProductsState> emit,
) async {

View File

@ -12,12 +12,12 @@ final class ProductsInitial extends ProductsState {}
final class ProductsLoading extends ProductsState {}
final class ProductsLoaded extends ProductsState {
final List<ProductModel> devices;
final List<Product> products;
const ProductsLoaded(this.devices);
const ProductsLoaded(this.products);
@override
List<Object> get props => [devices];
List<Object> get props => [products];
}
final class ProductsFailure extends ProductsState {

View File

@ -1,4 +1,6 @@
import 'package:equatable/equatable.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/products/domain/models/product.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/models/tag.dart';
class SpaceDetailsModel extends Equatable {
final String uuid;
@ -46,10 +48,12 @@ class SpaceDetailsModel extends Equatable {
class ProductAllocation extends Equatable {
final Product product;
final Tag tag;
final String? location;
const ProductAllocation({
required this.product,
required this.tag,
this.location,
});
factory ProductAllocation.fromJson(Map<String, dynamic> json) {
@ -70,68 +74,6 @@ class ProductAllocation extends Equatable {
List<Object?> get props => [product, tag];
}
class Product extends Equatable {
final String uuid;
final String name;
const Product({
required this.uuid,
required this.name,
});
factory Product.fromJson(Map<String, dynamic> json) {
return Product(
uuid: json['uuid'] as String,
name: json['name'] as String,
);
}
Map<String, dynamic> toJson() {
return {
'uuid': uuid,
'name': name,
};
}
@override
List<Object?> get props => [uuid, name];
}
class Tag extends Equatable {
final String uuid;
final String name;
final String createdAt;
final String updatedAt;
const Tag({
required this.uuid,
required this.name,
required this.createdAt,
required this.updatedAt,
});
factory Tag.fromJson(Map<String, dynamic> json) {
return Tag(
uuid: json['uuid'] as String,
name: json['name'] as String,
createdAt: json['createdAt'] as String,
updatedAt: json['updatedAt'] as String,
);
}
Map<String, dynamic> toJson() {
return {
'uuid': uuid,
'name': name,
'createdAt': createdAt,
'updatedAt': updatedAt,
};
}
@override
List<Object?> get props => [uuid, name, createdAt, updatedAt];
}
class Subspace extends Equatable {
final String uuid;
final String name;

View File

@ -1,5 +1,5 @@
import 'package:dio/dio.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/models/tag_model.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/models/tag.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/params/load_tags_param.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/services/tags_service.dart';
import 'package:syncrow_web/services/api/api_exception.dart';
@ -14,7 +14,7 @@ final class RemoteTagsService implements TagsService {
static const _defaultErrorMessage = 'Failed to load tags';
@override
Future<List<TagModel>> loadTags(LoadTagsParam param) async {
Future<List<Tag>> loadTags(LoadTagsParam param) async {
if (param.projectUuid == null) {
throw Exception('Project UUID is required');
}
@ -28,9 +28,7 @@ final class RemoteTagsService implements TagsService {
expectedResponseModel: (json) {
final result = json as Map<String, dynamic>;
final data = result['data'] as List<dynamic>;
return data
.map((e) => TagModel.fromJson(e as Map<String, dynamic>))
.toList();
return data.map((e) => Tag.fromJson(e as Map<String, dynamic>)).toList();
},
);
return response;

View File

@ -0,0 +1,36 @@
import 'package:equatable/equatable.dart';
class Tag extends Equatable {
final String uuid;
final String name;
final String createdAt;
final String updatedAt;
const Tag({
required this.uuid,
required this.name,
required this.createdAt,
required this.updatedAt,
});
factory Tag.fromJson(Map<String, dynamic> json) {
return Tag(
uuid: json['uuid'] as String,
name: json['name'] as String,
createdAt: json['createdAt'] as String,
updatedAt: json['updatedAt'] as String,
);
}
Map<String, dynamic> toJson() {
return {
'uuid': uuid,
'name': name,
'createdAt': createdAt,
'updatedAt': updatedAt,
};
}
@override
List<Object?> get props => [uuid, name, createdAt, updatedAt];
}

View File

@ -1,53 +0,0 @@
import 'package:equatable/equatable.dart';
import 'package:uuid/uuid.dart';
class TagModel extends Equatable {
const TagModel({
required this.uuid,
required this.tag,
required this.internalId,
required this.location,
});
final String? uuid;
final String? tag;
final String? internalId;
final String? location;
factory TagModel.fromJson(Map<String, dynamic> json) {
final internalId = json['internalId'] as String? ?? const Uuid().v4();
final tag = json['tag'] as Map<String, dynamic>?;
final name = json['name'] as String?;
return TagModel(
uuid: name != null ? json['uuid'] as String? : tag?['uuid'] as String?,
internalId: internalId,
tag: name ?? tag?['name'] as String?,
location: json['location'] as String?,
);
}
TagModel copyWith({
String? uuid,
String? tag,
String? location,
String? internalId,
}) {
return TagModel(
uuid: uuid ?? this.uuid,
tag: tag ?? this.tag,
location: location ?? this.location,
internalId: internalId ?? this.internalId,
);
}
Map<String, dynamic> toJson() {
return {
if (uuid != null) 'uuid': uuid,
'name': tag,
};
}
@override
List<Object?> get props => [uuid, tag, internalId, location];
}

View File

@ -1,6 +1,6 @@
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/models/tag_model.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/models/tag.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/params/load_tags_param.dart';
abstract interface class TagsService {
Future<List<TagModel>> loadTags(LoadTagsParam param);
Future<List<Tag>> loadTags(LoadTagsParam param);
}

View File

@ -1,6 +1,6 @@
import 'package:bloc/bloc.dart';
import 'package:equatable/equatable.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/models/tag_model.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/models/tag.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/params/load_tags_param.dart';
import 'package:syncrow_web/pages/space_management_v2/modules/tags/domain/services/tags_service.dart';
import 'package:syncrow_web/services/api/api_exception.dart';

View File

@ -12,7 +12,7 @@ class TagsInitial extends TagsState {}
class TagsLoading extends TagsState {}
class TagsLoaded extends TagsState {
final List<TagModel> tags;
final List<Tag> tags;
const TagsLoaded(this.tags);