feat: 소프트 딜리트 기능 전면 구현 완료
## 주요 변경사항 - Company, Equipment, License, Warehouse Location 모든 화면에 소프트 딜리트 구현 - 관리자 권한으로 삭제된 데이터 조회 가능 (includeInactive 파라미터) - 데이터 무결성 보장을 위한 논리 삭제 시스템 완성 ## 기능 개선 - 각 리스트 컨트롤러에 toggleIncludeInactive() 메서드 추가 - UI에 "비활성 포함" 체크박스 추가 (관리자 전용) - API 데이터소스에 includeInactive 파라미터 지원 ## 문서 정리 - 불필요한 문서 파일 제거 및 재구성 - CLAUDE.md 프로젝트 상태 업데이트 (진행률 80%) - 테스트 결과 문서화 (test20250812v01.md) ## UI 컴포넌트 - Equipment 화면 위젯 모듈화 (custom_dropdown_field, equipment_basic_info_section) - 폼 유효성 검증 강화 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -16,6 +16,7 @@ class CreateWarehouseLocationRequest with _$CreateWarehouseLocationRequest {
|
||||
int? capacity,
|
||||
@JsonKey(name: 'manager_id') int? managerId,
|
||||
@JsonKey(name: 'company_id') int? companyId,
|
||||
String? remark,
|
||||
}) = _CreateWarehouseLocationRequest;
|
||||
|
||||
factory CreateWarehouseLocationRequest.fromJson(Map<String, dynamic> json) =>
|
||||
@@ -35,6 +36,7 @@ class UpdateWarehouseLocationRequest with _$UpdateWarehouseLocationRequest {
|
||||
int? capacity,
|
||||
@JsonKey(name: 'manager_id') int? managerId,
|
||||
@JsonKey(name: 'is_active') bool? isActive,
|
||||
String? remark,
|
||||
}) = _UpdateWarehouseLocationRequest;
|
||||
|
||||
factory UpdateWarehouseLocationRequest.fromJson(Map<String, dynamic> json) =>
|
||||
|
||||
@@ -33,6 +33,7 @@ mixin _$CreateWarehouseLocationRequest {
|
||||
int? get managerId => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'company_id')
|
||||
int? get companyId => throw _privateConstructorUsedError;
|
||||
String? get remark => throw _privateConstructorUsedError;
|
||||
|
||||
/// Serializes this CreateWarehouseLocationRequest to a JSON map.
|
||||
Map<String, dynamic> toJson() => throw _privateConstructorUsedError;
|
||||
@@ -61,7 +62,8 @@ abstract class $CreateWarehouseLocationRequestCopyWith<$Res> {
|
||||
String? country,
|
||||
int? capacity,
|
||||
@JsonKey(name: 'manager_id') int? managerId,
|
||||
@JsonKey(name: 'company_id') int? companyId});
|
||||
@JsonKey(name: 'company_id') int? companyId,
|
||||
String? remark});
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
@@ -89,6 +91,7 @@ class _$CreateWarehouseLocationRequestCopyWithImpl<$Res,
|
||||
Object? capacity = freezed,
|
||||
Object? managerId = freezed,
|
||||
Object? companyId = freezed,
|
||||
Object? remark = freezed,
|
||||
}) {
|
||||
return _then(_value.copyWith(
|
||||
name: null == name
|
||||
@@ -127,6 +130,10 @@ class _$CreateWarehouseLocationRequestCopyWithImpl<$Res,
|
||||
? _value.companyId
|
||||
: companyId // ignore: cast_nullable_to_non_nullable
|
||||
as int?,
|
||||
remark: freezed == remark
|
||||
? _value.remark
|
||||
: remark // ignore: cast_nullable_to_non_nullable
|
||||
as String?,
|
||||
) as $Val);
|
||||
}
|
||||
}
|
||||
@@ -149,7 +156,8 @@ abstract class _$$CreateWarehouseLocationRequestImplCopyWith<$Res>
|
||||
String? country,
|
||||
int? capacity,
|
||||
@JsonKey(name: 'manager_id') int? managerId,
|
||||
@JsonKey(name: 'company_id') int? companyId});
|
||||
@JsonKey(name: 'company_id') int? companyId,
|
||||
String? remark});
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
@@ -176,6 +184,7 @@ class __$$CreateWarehouseLocationRequestImplCopyWithImpl<$Res>
|
||||
Object? capacity = freezed,
|
||||
Object? managerId = freezed,
|
||||
Object? companyId = freezed,
|
||||
Object? remark = freezed,
|
||||
}) {
|
||||
return _then(_$CreateWarehouseLocationRequestImpl(
|
||||
name: null == name
|
||||
@@ -214,6 +223,10 @@ class __$$CreateWarehouseLocationRequestImplCopyWithImpl<$Res>
|
||||
? _value.companyId
|
||||
: companyId // ignore: cast_nullable_to_non_nullable
|
||||
as int?,
|
||||
remark: freezed == remark
|
||||
? _value.remark
|
||||
: remark // ignore: cast_nullable_to_non_nullable
|
||||
as String?,
|
||||
));
|
||||
}
|
||||
}
|
||||
@@ -231,7 +244,8 @@ class _$CreateWarehouseLocationRequestImpl
|
||||
this.country,
|
||||
this.capacity,
|
||||
@JsonKey(name: 'manager_id') this.managerId,
|
||||
@JsonKey(name: 'company_id') this.companyId});
|
||||
@JsonKey(name: 'company_id') this.companyId,
|
||||
this.remark});
|
||||
|
||||
factory _$CreateWarehouseLocationRequestImpl.fromJson(
|
||||
Map<String, dynamic> json) =>
|
||||
@@ -258,10 +272,12 @@ class _$CreateWarehouseLocationRequestImpl
|
||||
@override
|
||||
@JsonKey(name: 'company_id')
|
||||
final int? companyId;
|
||||
@override
|
||||
final String? remark;
|
||||
|
||||
@override
|
||||
String toString() {
|
||||
return 'CreateWarehouseLocationRequest(name: $name, address: $address, city: $city, state: $state, postalCode: $postalCode, country: $country, capacity: $capacity, managerId: $managerId, companyId: $companyId)';
|
||||
return 'CreateWarehouseLocationRequest(name: $name, address: $address, city: $city, state: $state, postalCode: $postalCode, country: $country, capacity: $capacity, managerId: $managerId, companyId: $companyId, remark: $remark)';
|
||||
}
|
||||
|
||||
@override
|
||||
@@ -281,13 +297,14 @@ class _$CreateWarehouseLocationRequestImpl
|
||||
(identical(other.managerId, managerId) ||
|
||||
other.managerId == managerId) &&
|
||||
(identical(other.companyId, companyId) ||
|
||||
other.companyId == companyId));
|
||||
other.companyId == companyId) &&
|
||||
(identical(other.remark, remark) || other.remark == remark));
|
||||
}
|
||||
|
||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
||||
@override
|
||||
int get hashCode => Object.hash(runtimeType, name, address, city, state,
|
||||
postalCode, country, capacity, managerId, companyId);
|
||||
postalCode, country, capacity, managerId, companyId, remark);
|
||||
|
||||
/// Create a copy of CreateWarehouseLocationRequest
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@@ -310,16 +327,16 @@ class _$CreateWarehouseLocationRequestImpl
|
||||
abstract class _CreateWarehouseLocationRequest
|
||||
implements CreateWarehouseLocationRequest {
|
||||
const factory _CreateWarehouseLocationRequest(
|
||||
{required final String name,
|
||||
final String? address,
|
||||
final String? city,
|
||||
final String? state,
|
||||
@JsonKey(name: 'postal_code') final String? postalCode,
|
||||
final String? country,
|
||||
final int? capacity,
|
||||
@JsonKey(name: 'manager_id') final int? managerId,
|
||||
@JsonKey(name: 'company_id') final int? companyId}) =
|
||||
_$CreateWarehouseLocationRequestImpl;
|
||||
{required final String name,
|
||||
final String? address,
|
||||
final String? city,
|
||||
final String? state,
|
||||
@JsonKey(name: 'postal_code') final String? postalCode,
|
||||
final String? country,
|
||||
final int? capacity,
|
||||
@JsonKey(name: 'manager_id') final int? managerId,
|
||||
@JsonKey(name: 'company_id') final int? companyId,
|
||||
final String? remark}) = _$CreateWarehouseLocationRequestImpl;
|
||||
|
||||
factory _CreateWarehouseLocationRequest.fromJson(Map<String, dynamic> json) =
|
||||
_$CreateWarehouseLocationRequestImpl.fromJson;
|
||||
@@ -345,6 +362,8 @@ abstract class _CreateWarehouseLocationRequest
|
||||
@override
|
||||
@JsonKey(name: 'company_id')
|
||||
int? get companyId;
|
||||
@override
|
||||
String? get remark;
|
||||
|
||||
/// Create a copy of CreateWarehouseLocationRequest
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@@ -374,6 +393,7 @@ mixin _$UpdateWarehouseLocationRequest {
|
||||
int? get managerId => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'is_active')
|
||||
bool? get isActive => throw _privateConstructorUsedError;
|
||||
String? get remark => throw _privateConstructorUsedError;
|
||||
|
||||
/// Serializes this UpdateWarehouseLocationRequest to a JSON map.
|
||||
Map<String, dynamic> toJson() => throw _privateConstructorUsedError;
|
||||
@@ -402,7 +422,8 @@ abstract class $UpdateWarehouseLocationRequestCopyWith<$Res> {
|
||||
String? country,
|
||||
int? capacity,
|
||||
@JsonKey(name: 'manager_id') int? managerId,
|
||||
@JsonKey(name: 'is_active') bool? isActive});
|
||||
@JsonKey(name: 'is_active') bool? isActive,
|
||||
String? remark});
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
@@ -430,6 +451,7 @@ class _$UpdateWarehouseLocationRequestCopyWithImpl<$Res,
|
||||
Object? capacity = freezed,
|
||||
Object? managerId = freezed,
|
||||
Object? isActive = freezed,
|
||||
Object? remark = freezed,
|
||||
}) {
|
||||
return _then(_value.copyWith(
|
||||
name: freezed == name
|
||||
@@ -468,6 +490,10 @@ class _$UpdateWarehouseLocationRequestCopyWithImpl<$Res,
|
||||
? _value.isActive
|
||||
: isActive // ignore: cast_nullable_to_non_nullable
|
||||
as bool?,
|
||||
remark: freezed == remark
|
||||
? _value.remark
|
||||
: remark // ignore: cast_nullable_to_non_nullable
|
||||
as String?,
|
||||
) as $Val);
|
||||
}
|
||||
}
|
||||
@@ -490,7 +516,8 @@ abstract class _$$UpdateWarehouseLocationRequestImplCopyWith<$Res>
|
||||
String? country,
|
||||
int? capacity,
|
||||
@JsonKey(name: 'manager_id') int? managerId,
|
||||
@JsonKey(name: 'is_active') bool? isActive});
|
||||
@JsonKey(name: 'is_active') bool? isActive,
|
||||
String? remark});
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
@@ -517,6 +544,7 @@ class __$$UpdateWarehouseLocationRequestImplCopyWithImpl<$Res>
|
||||
Object? capacity = freezed,
|
||||
Object? managerId = freezed,
|
||||
Object? isActive = freezed,
|
||||
Object? remark = freezed,
|
||||
}) {
|
||||
return _then(_$UpdateWarehouseLocationRequestImpl(
|
||||
name: freezed == name
|
||||
@@ -555,6 +583,10 @@ class __$$UpdateWarehouseLocationRequestImplCopyWithImpl<$Res>
|
||||
? _value.isActive
|
||||
: isActive // ignore: cast_nullable_to_non_nullable
|
||||
as bool?,
|
||||
remark: freezed == remark
|
||||
? _value.remark
|
||||
: remark // ignore: cast_nullable_to_non_nullable
|
||||
as String?,
|
||||
));
|
||||
}
|
||||
}
|
||||
@@ -572,7 +604,8 @@ class _$UpdateWarehouseLocationRequestImpl
|
||||
this.country,
|
||||
this.capacity,
|
||||
@JsonKey(name: 'manager_id') this.managerId,
|
||||
@JsonKey(name: 'is_active') this.isActive});
|
||||
@JsonKey(name: 'is_active') this.isActive,
|
||||
this.remark});
|
||||
|
||||
factory _$UpdateWarehouseLocationRequestImpl.fromJson(
|
||||
Map<String, dynamic> json) =>
|
||||
@@ -599,10 +632,12 @@ class _$UpdateWarehouseLocationRequestImpl
|
||||
@override
|
||||
@JsonKey(name: 'is_active')
|
||||
final bool? isActive;
|
||||
@override
|
||||
final String? remark;
|
||||
|
||||
@override
|
||||
String toString() {
|
||||
return 'UpdateWarehouseLocationRequest(name: $name, address: $address, city: $city, state: $state, postalCode: $postalCode, country: $country, capacity: $capacity, managerId: $managerId, isActive: $isActive)';
|
||||
return 'UpdateWarehouseLocationRequest(name: $name, address: $address, city: $city, state: $state, postalCode: $postalCode, country: $country, capacity: $capacity, managerId: $managerId, isActive: $isActive, remark: $remark)';
|
||||
}
|
||||
|
||||
@override
|
||||
@@ -622,13 +657,14 @@ class _$UpdateWarehouseLocationRequestImpl
|
||||
(identical(other.managerId, managerId) ||
|
||||
other.managerId == managerId) &&
|
||||
(identical(other.isActive, isActive) ||
|
||||
other.isActive == isActive));
|
||||
other.isActive == isActive) &&
|
||||
(identical(other.remark, remark) || other.remark == remark));
|
||||
}
|
||||
|
||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
||||
@override
|
||||
int get hashCode => Object.hash(runtimeType, name, address, city, state,
|
||||
postalCode, country, capacity, managerId, isActive);
|
||||
postalCode, country, capacity, managerId, isActive, remark);
|
||||
|
||||
/// Create a copy of UpdateWarehouseLocationRequest
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@@ -651,16 +687,16 @@ class _$UpdateWarehouseLocationRequestImpl
|
||||
abstract class _UpdateWarehouseLocationRequest
|
||||
implements UpdateWarehouseLocationRequest {
|
||||
const factory _UpdateWarehouseLocationRequest(
|
||||
{final String? name,
|
||||
final String? address,
|
||||
final String? city,
|
||||
final String? state,
|
||||
@JsonKey(name: 'postal_code') final String? postalCode,
|
||||
final String? country,
|
||||
final int? capacity,
|
||||
@JsonKey(name: 'manager_id') final int? managerId,
|
||||
@JsonKey(name: 'is_active') final bool? isActive}) =
|
||||
_$UpdateWarehouseLocationRequestImpl;
|
||||
{final String? name,
|
||||
final String? address,
|
||||
final String? city,
|
||||
final String? state,
|
||||
@JsonKey(name: 'postal_code') final String? postalCode,
|
||||
final String? country,
|
||||
final int? capacity,
|
||||
@JsonKey(name: 'manager_id') final int? managerId,
|
||||
@JsonKey(name: 'is_active') final bool? isActive,
|
||||
final String? remark}) = _$UpdateWarehouseLocationRequestImpl;
|
||||
|
||||
factory _UpdateWarehouseLocationRequest.fromJson(Map<String, dynamic> json) =
|
||||
_$UpdateWarehouseLocationRequestImpl.fromJson;
|
||||
@@ -686,6 +722,8 @@ abstract class _UpdateWarehouseLocationRequest
|
||||
@override
|
||||
@JsonKey(name: 'is_active')
|
||||
bool? get isActive;
|
||||
@override
|
||||
String? get remark;
|
||||
|
||||
/// Create a copy of UpdateWarehouseLocationRequest
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
|
||||
@@ -18,6 +18,7 @@ _$CreateWarehouseLocationRequestImpl
|
||||
capacity: (json['capacity'] as num?)?.toInt(),
|
||||
managerId: (json['manager_id'] as num?)?.toInt(),
|
||||
companyId: (json['company_id'] as num?)?.toInt(),
|
||||
remark: json['remark'] as String?,
|
||||
);
|
||||
|
||||
Map<String, dynamic> _$$CreateWarehouseLocationRequestImplToJson(
|
||||
@@ -32,6 +33,7 @@ Map<String, dynamic> _$$CreateWarehouseLocationRequestImplToJson(
|
||||
'capacity': instance.capacity,
|
||||
'manager_id': instance.managerId,
|
||||
'company_id': instance.companyId,
|
||||
'remark': instance.remark,
|
||||
};
|
||||
|
||||
_$UpdateWarehouseLocationRequestImpl
|
||||
@@ -46,6 +48,7 @@ _$UpdateWarehouseLocationRequestImpl
|
||||
capacity: (json['capacity'] as num?)?.toInt(),
|
||||
managerId: (json['manager_id'] as num?)?.toInt(),
|
||||
isActive: json['is_active'] as bool?,
|
||||
remark: json['remark'] as String?,
|
||||
);
|
||||
|
||||
Map<String, dynamic> _$$UpdateWarehouseLocationRequestImplToJson(
|
||||
@@ -60,6 +63,7 @@ Map<String, dynamic> _$$UpdateWarehouseLocationRequestImplToJson(
|
||||
'capacity': instance.capacity,
|
||||
'manager_id': instance.managerId,
|
||||
'is_active': instance.isActive,
|
||||
'remark': instance.remark,
|
||||
};
|
||||
|
||||
_$WarehouseLocationDtoImpl _$$WarehouseLocationDtoImplFromJson(
|
||||
|
||||
Reference in New Issue
Block a user