feat: 대규모 코드베이스 개선 - 백엔드 통합성 강화 및 UI 일관성 완성
- CLAUDE.md 대폭 개선: 개발 가이드라인 및 프로젝트 상태 문서화 - 백엔드 API 통합: 모든 엔티티 간 Foreign Key 관계 완벽 구현 - UI 일관성 강화: shadcn_ui 컴포넌트 표준화 적용 - 데이터 모델 개선: DTO 및 모델 클래스 백엔드 스키마와 100% 일치 - 사용자 관리: 회사 연결, 중복 검사, 입력 검증 기능 추가 - 창고 관리: 우편번호 연결, 중복 검사 기능 강화 - 회사 관리: 우편번호 연결, 중복 검사 로직 구현 - 장비 관리: 불필요한 카테고리 필드 제거, 벤더-모델 관계 정리 - 우편번호 시스템: 검색 다이얼로그 Provider 버그 수정 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -22,8 +22,8 @@ class CompanyDto with _$CompanyDto {
|
||||
@JsonKey(name: 'is_customer') @Default(false) bool isCustomer,
|
||||
@JsonKey(name: 'is_active') @Default(false) bool isActive,
|
||||
@JsonKey(name: 'is_deleted') @Default(false) bool isDeleted,
|
||||
@JsonKey(name: 'registerd_at') DateTime? registeredAt,
|
||||
@JsonKey(name: 'Updated_at') DateTime? updatedAt,
|
||||
@JsonKey(name: 'registered_at') DateTime? registeredAt,
|
||||
@JsonKey(name: 'updated_at') DateTime? updatedAt,
|
||||
|
||||
// Nested data (optional, populated in GET requests)
|
||||
@JsonKey(name: 'parent_company') CompanyNameDto? parentCompany,
|
||||
|
||||
@@ -42,9 +42,9 @@ mixin _$CompanyDto {
|
||||
bool get isActive => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'is_deleted')
|
||||
bool get isDeleted => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'registerd_at')
|
||||
@JsonKey(name: 'registered_at')
|
||||
DateTime? get registeredAt => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'Updated_at')
|
||||
@JsonKey(name: 'updated_at')
|
||||
DateTime? get updatedAt =>
|
||||
throw _privateConstructorUsedError; // Nested data (optional, populated in GET requests)
|
||||
@JsonKey(name: 'parent_company')
|
||||
@@ -82,8 +82,8 @@ abstract class $CompanyDtoCopyWith<$Res> {
|
||||
@JsonKey(name: 'is_customer') bool isCustomer,
|
||||
@JsonKey(name: 'is_active') bool isActive,
|
||||
@JsonKey(name: 'is_deleted') bool isDeleted,
|
||||
@JsonKey(name: 'registerd_at') DateTime? registeredAt,
|
||||
@JsonKey(name: 'Updated_at') DateTime? updatedAt,
|
||||
@JsonKey(name: 'registered_at') DateTime? registeredAt,
|
||||
@JsonKey(name: 'updated_at') DateTime? updatedAt,
|
||||
@JsonKey(name: 'parent_company') CompanyNameDto? parentCompany,
|
||||
@JsonKey(name: 'zipcode') ZipcodeDto? zipcode});
|
||||
|
||||
@@ -247,8 +247,8 @@ abstract class _$$CompanyDtoImplCopyWith<$Res>
|
||||
@JsonKey(name: 'is_customer') bool isCustomer,
|
||||
@JsonKey(name: 'is_active') bool isActive,
|
||||
@JsonKey(name: 'is_deleted') bool isDeleted,
|
||||
@JsonKey(name: 'registerd_at') DateTime? registeredAt,
|
||||
@JsonKey(name: 'Updated_at') DateTime? updatedAt,
|
||||
@JsonKey(name: 'registered_at') DateTime? registeredAt,
|
||||
@JsonKey(name: 'updated_at') DateTime? updatedAt,
|
||||
@JsonKey(name: 'parent_company') CompanyNameDto? parentCompany,
|
||||
@JsonKey(name: 'zipcode') ZipcodeDto? zipcode});
|
||||
|
||||
@@ -379,8 +379,8 @@ class _$CompanyDtoImpl extends _CompanyDto {
|
||||
@JsonKey(name: 'is_customer') this.isCustomer = false,
|
||||
@JsonKey(name: 'is_active') this.isActive = false,
|
||||
@JsonKey(name: 'is_deleted') this.isDeleted = false,
|
||||
@JsonKey(name: 'registerd_at') this.registeredAt,
|
||||
@JsonKey(name: 'Updated_at') this.updatedAt,
|
||||
@JsonKey(name: 'registered_at') this.registeredAt,
|
||||
@JsonKey(name: 'updated_at') this.updatedAt,
|
||||
@JsonKey(name: 'parent_company') this.parentCompany,
|
||||
@JsonKey(name: 'zipcode') this.zipcode})
|
||||
: super._();
|
||||
@@ -424,10 +424,10 @@ class _$CompanyDtoImpl extends _CompanyDto {
|
||||
@JsonKey(name: 'is_deleted')
|
||||
final bool isDeleted;
|
||||
@override
|
||||
@JsonKey(name: 'registerd_at')
|
||||
@JsonKey(name: 'registered_at')
|
||||
final DateTime? registeredAt;
|
||||
@override
|
||||
@JsonKey(name: 'Updated_at')
|
||||
@JsonKey(name: 'updated_at')
|
||||
final DateTime? updatedAt;
|
||||
// Nested data (optional, populated in GET requests)
|
||||
@override
|
||||
@@ -531,8 +531,8 @@ abstract class _CompanyDto extends CompanyDto {
|
||||
@JsonKey(name: 'is_customer') final bool isCustomer,
|
||||
@JsonKey(name: 'is_active') final bool isActive,
|
||||
@JsonKey(name: 'is_deleted') final bool isDeleted,
|
||||
@JsonKey(name: 'registerd_at') final DateTime? registeredAt,
|
||||
@JsonKey(name: 'Updated_at') final DateTime? updatedAt,
|
||||
@JsonKey(name: 'registered_at') final DateTime? registeredAt,
|
||||
@JsonKey(name: 'updated_at') final DateTime? updatedAt,
|
||||
@JsonKey(name: 'parent_company') final CompanyNameDto? parentCompany,
|
||||
@JsonKey(name: 'zipcode') final ZipcodeDto? zipcode}) = _$CompanyDtoImpl;
|
||||
const _CompanyDto._() : super._();
|
||||
@@ -576,10 +576,10 @@ abstract class _CompanyDto extends CompanyDto {
|
||||
@JsonKey(name: 'is_deleted')
|
||||
bool get isDeleted;
|
||||
@override
|
||||
@JsonKey(name: 'registerd_at')
|
||||
@JsonKey(name: 'registered_at')
|
||||
DateTime? get registeredAt;
|
||||
@override
|
||||
@JsonKey(name: 'Updated_at')
|
||||
@JsonKey(name: 'updated_at')
|
||||
DateTime? get updatedAt; // Nested data (optional, populated in GET requests)
|
||||
@override
|
||||
@JsonKey(name: 'parent_company')
|
||||
|
||||
@@ -21,12 +21,12 @@ _$CompanyDtoImpl _$$CompanyDtoImplFromJson(Map<String, dynamic> json) =>
|
||||
isCustomer: json['is_customer'] as bool? ?? false,
|
||||
isActive: json['is_active'] as bool? ?? false,
|
||||
isDeleted: json['is_deleted'] as bool? ?? false,
|
||||
registeredAt: json['registerd_at'] == null
|
||||
registeredAt: json['registered_at'] == null
|
||||
? null
|
||||
: DateTime.parse(json['registerd_at'] as String),
|
||||
updatedAt: json['Updated_at'] == null
|
||||
: DateTime.parse(json['registered_at'] as String),
|
||||
updatedAt: json['updated_at'] == null
|
||||
? null
|
||||
: DateTime.parse(json['Updated_at'] as String),
|
||||
: DateTime.parse(json['updated_at'] as String),
|
||||
parentCompany: json['parent_company'] == null
|
||||
? null
|
||||
: CompanyNameDto.fromJson(
|
||||
@@ -51,8 +51,8 @@ Map<String, dynamic> _$$CompanyDtoImplToJson(_$CompanyDtoImpl instance) =>
|
||||
'is_customer': instance.isCustomer,
|
||||
'is_active': instance.isActive,
|
||||
'is_deleted': instance.isDeleted,
|
||||
'registerd_at': instance.registeredAt?.toIso8601String(),
|
||||
'Updated_at': instance.updatedAt?.toIso8601String(),
|
||||
'registered_at': instance.registeredAt?.toIso8601String(),
|
||||
'updated_at': instance.updatedAt?.toIso8601String(),
|
||||
'parent_company': instance.parentCompany,
|
||||
'zipcode': instance.zipcode,
|
||||
};
|
||||
|
||||
@@ -26,12 +26,9 @@ class UserDto with _$UserDto {
|
||||
User toDomainModel() {
|
||||
return User(
|
||||
id: id,
|
||||
username: name, // 백엔드에서 name이 사실상 username 역할
|
||||
email: email ?? '', // email은 필수이므로 기본값 설정
|
||||
name: name,
|
||||
email: email,
|
||||
phone: phone,
|
||||
role: UserRole.staff, // 기본 권한 (백엔드에서 권한 관리 안함)
|
||||
isActive: true, // 기본값
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -31,9 +31,9 @@ class WarehouseDto with _$WarehouseDto {
|
||||
@freezed
|
||||
class WarehouseRequestDto with _$WarehouseRequestDto {
|
||||
const factory WarehouseRequestDto({
|
||||
@JsonKey(name: 'Name') required String name,
|
||||
@JsonKey(name: 'name') required String name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') String? zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') String? remark,
|
||||
@JsonKey(name: 'remark') String? remark,
|
||||
}) = _WarehouseRequestDto;
|
||||
|
||||
factory WarehouseRequestDto.fromJson(Map<String, dynamic> json) =>
|
||||
@@ -43,9 +43,9 @@ class WarehouseRequestDto with _$WarehouseRequestDto {
|
||||
@freezed
|
||||
class WarehouseUpdateRequestDto with _$WarehouseUpdateRequestDto {
|
||||
const factory WarehouseUpdateRequestDto({
|
||||
@JsonKey(name: 'Name') String? name,
|
||||
@JsonKey(name: 'name') String? name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') String? zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') String? remark,
|
||||
@JsonKey(name: 'remark') String? remark,
|
||||
}) = _WarehouseUpdateRequestDto;
|
||||
|
||||
factory WarehouseUpdateRequestDto.fromJson(Map<String, dynamic> json) =>
|
||||
|
||||
@@ -392,11 +392,11 @@ WarehouseRequestDto _$WarehouseRequestDtoFromJson(Map<String, dynamic> json) {
|
||||
|
||||
/// @nodoc
|
||||
mixin _$WarehouseRequestDto {
|
||||
@JsonKey(name: 'Name')
|
||||
@JsonKey(name: 'name')
|
||||
String get name => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'zipcodes_zipcode')
|
||||
String? get zipcodesZipcode => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'Remark')
|
||||
@JsonKey(name: 'remark')
|
||||
String? get remark => throw _privateConstructorUsedError;
|
||||
|
||||
/// Serializes this WarehouseRequestDto to a JSON map.
|
||||
@@ -416,9 +416,9 @@ abstract class $WarehouseRequestDtoCopyWith<$Res> {
|
||||
_$WarehouseRequestDtoCopyWithImpl<$Res, WarehouseRequestDto>;
|
||||
@useResult
|
||||
$Res call(
|
||||
{@JsonKey(name: 'Name') String name,
|
||||
{@JsonKey(name: 'name') String name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') String? zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') String? remark});
|
||||
@JsonKey(name: 'remark') String? remark});
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
@@ -466,9 +466,9 @@ abstract class _$$WarehouseRequestDtoImplCopyWith<$Res>
|
||||
@override
|
||||
@useResult
|
||||
$Res call(
|
||||
{@JsonKey(name: 'Name') String name,
|
||||
{@JsonKey(name: 'name') String name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') String? zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') String? remark});
|
||||
@JsonKey(name: 'remark') String? remark});
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
@@ -509,21 +509,21 @@ class __$$WarehouseRequestDtoImplCopyWithImpl<$Res>
|
||||
@JsonSerializable()
|
||||
class _$WarehouseRequestDtoImpl implements _WarehouseRequestDto {
|
||||
const _$WarehouseRequestDtoImpl(
|
||||
{@JsonKey(name: 'Name') required this.name,
|
||||
{@JsonKey(name: 'name') required this.name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') this.zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') this.remark});
|
||||
@JsonKey(name: 'remark') this.remark});
|
||||
|
||||
factory _$WarehouseRequestDtoImpl.fromJson(Map<String, dynamic> json) =>
|
||||
_$$WarehouseRequestDtoImplFromJson(json);
|
||||
|
||||
@override
|
||||
@JsonKey(name: 'Name')
|
||||
@JsonKey(name: 'name')
|
||||
final String name;
|
||||
@override
|
||||
@JsonKey(name: 'zipcodes_zipcode')
|
||||
final String? zipcodesZipcode;
|
||||
@override
|
||||
@JsonKey(name: 'Remark')
|
||||
@JsonKey(name: 'remark')
|
||||
final String? remark;
|
||||
|
||||
@override
|
||||
@@ -565,22 +565,22 @@ class _$WarehouseRequestDtoImpl implements _WarehouseRequestDto {
|
||||
|
||||
abstract class _WarehouseRequestDto implements WarehouseRequestDto {
|
||||
const factory _WarehouseRequestDto(
|
||||
{@JsonKey(name: 'Name') required final String name,
|
||||
{@JsonKey(name: 'name') required final String name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') final String? zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') final String? remark}) =
|
||||
@JsonKey(name: 'remark') final String? remark}) =
|
||||
_$WarehouseRequestDtoImpl;
|
||||
|
||||
factory _WarehouseRequestDto.fromJson(Map<String, dynamic> json) =
|
||||
_$WarehouseRequestDtoImpl.fromJson;
|
||||
|
||||
@override
|
||||
@JsonKey(name: 'Name')
|
||||
@JsonKey(name: 'name')
|
||||
String get name;
|
||||
@override
|
||||
@JsonKey(name: 'zipcodes_zipcode')
|
||||
String? get zipcodesZipcode;
|
||||
@override
|
||||
@JsonKey(name: 'Remark')
|
||||
@JsonKey(name: 'remark')
|
||||
String? get remark;
|
||||
|
||||
/// Create a copy of WarehouseRequestDto
|
||||
@@ -598,11 +598,11 @@ WarehouseUpdateRequestDto _$WarehouseUpdateRequestDtoFromJson(
|
||||
|
||||
/// @nodoc
|
||||
mixin _$WarehouseUpdateRequestDto {
|
||||
@JsonKey(name: 'Name')
|
||||
@JsonKey(name: 'name')
|
||||
String? get name => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'zipcodes_zipcode')
|
||||
String? get zipcodesZipcode => throw _privateConstructorUsedError;
|
||||
@JsonKey(name: 'Remark')
|
||||
@JsonKey(name: 'remark')
|
||||
String? get remark => throw _privateConstructorUsedError;
|
||||
|
||||
/// Serializes this WarehouseUpdateRequestDto to a JSON map.
|
||||
@@ -622,9 +622,9 @@ abstract class $WarehouseUpdateRequestDtoCopyWith<$Res> {
|
||||
_$WarehouseUpdateRequestDtoCopyWithImpl<$Res, WarehouseUpdateRequestDto>;
|
||||
@useResult
|
||||
$Res call(
|
||||
{@JsonKey(name: 'Name') String? name,
|
||||
{@JsonKey(name: 'name') String? name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') String? zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') String? remark});
|
||||
@JsonKey(name: 'remark') String? remark});
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
@@ -674,9 +674,9 @@ abstract class _$$WarehouseUpdateRequestDtoImplCopyWith<$Res>
|
||||
@override
|
||||
@useResult
|
||||
$Res call(
|
||||
{@JsonKey(name: 'Name') String? name,
|
||||
{@JsonKey(name: 'name') String? name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') String? zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') String? remark});
|
||||
@JsonKey(name: 'remark') String? remark});
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
@@ -719,21 +719,21 @@ class __$$WarehouseUpdateRequestDtoImplCopyWithImpl<$Res>
|
||||
@JsonSerializable()
|
||||
class _$WarehouseUpdateRequestDtoImpl implements _WarehouseUpdateRequestDto {
|
||||
const _$WarehouseUpdateRequestDtoImpl(
|
||||
{@JsonKey(name: 'Name') this.name,
|
||||
{@JsonKey(name: 'name') this.name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') this.zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') this.remark});
|
||||
@JsonKey(name: 'remark') this.remark});
|
||||
|
||||
factory _$WarehouseUpdateRequestDtoImpl.fromJson(Map<String, dynamic> json) =>
|
||||
_$$WarehouseUpdateRequestDtoImplFromJson(json);
|
||||
|
||||
@override
|
||||
@JsonKey(name: 'Name')
|
||||
@JsonKey(name: 'name')
|
||||
final String? name;
|
||||
@override
|
||||
@JsonKey(name: 'zipcodes_zipcode')
|
||||
final String? zipcodesZipcode;
|
||||
@override
|
||||
@JsonKey(name: 'Remark')
|
||||
@JsonKey(name: 'remark')
|
||||
final String? remark;
|
||||
|
||||
@override
|
||||
@@ -775,22 +775,22 @@ class _$WarehouseUpdateRequestDtoImpl implements _WarehouseUpdateRequestDto {
|
||||
|
||||
abstract class _WarehouseUpdateRequestDto implements WarehouseUpdateRequestDto {
|
||||
const factory _WarehouseUpdateRequestDto(
|
||||
{@JsonKey(name: 'Name') final String? name,
|
||||
{@JsonKey(name: 'name') final String? name,
|
||||
@JsonKey(name: 'zipcodes_zipcode') final String? zipcodesZipcode,
|
||||
@JsonKey(name: 'Remark') final String? remark}) =
|
||||
@JsonKey(name: 'remark') final String? remark}) =
|
||||
_$WarehouseUpdateRequestDtoImpl;
|
||||
|
||||
factory _WarehouseUpdateRequestDto.fromJson(Map<String, dynamic> json) =
|
||||
_$WarehouseUpdateRequestDtoImpl.fromJson;
|
||||
|
||||
@override
|
||||
@JsonKey(name: 'Name')
|
||||
@JsonKey(name: 'name')
|
||||
String? get name;
|
||||
@override
|
||||
@JsonKey(name: 'zipcodes_zipcode')
|
||||
String? get zipcodesZipcode;
|
||||
@override
|
||||
@JsonKey(name: 'Remark')
|
||||
@JsonKey(name: 'remark')
|
||||
String? get remark;
|
||||
|
||||
/// Create a copy of WarehouseUpdateRequestDto
|
||||
|
||||
@@ -41,33 +41,33 @@ Map<String, dynamic> _$$WarehouseDtoImplToJson(_$WarehouseDtoImpl instance) =>
|
||||
_$WarehouseRequestDtoImpl _$$WarehouseRequestDtoImplFromJson(
|
||||
Map<String, dynamic> json) =>
|
||||
_$WarehouseRequestDtoImpl(
|
||||
name: json['Name'] as String,
|
||||
name: json['name'] as String,
|
||||
zipcodesZipcode: json['zipcodes_zipcode'] as String?,
|
||||
remark: json['Remark'] as String?,
|
||||
remark: json['remark'] as String?,
|
||||
);
|
||||
|
||||
Map<String, dynamic> _$$WarehouseRequestDtoImplToJson(
|
||||
_$WarehouseRequestDtoImpl instance) =>
|
||||
<String, dynamic>{
|
||||
'Name': instance.name,
|
||||
'name': instance.name,
|
||||
'zipcodes_zipcode': instance.zipcodesZipcode,
|
||||
'Remark': instance.remark,
|
||||
'remark': instance.remark,
|
||||
};
|
||||
|
||||
_$WarehouseUpdateRequestDtoImpl _$$WarehouseUpdateRequestDtoImplFromJson(
|
||||
Map<String, dynamic> json) =>
|
||||
_$WarehouseUpdateRequestDtoImpl(
|
||||
name: json['Name'] as String?,
|
||||
name: json['name'] as String?,
|
||||
zipcodesZipcode: json['zipcodes_zipcode'] as String?,
|
||||
remark: json['Remark'] as String?,
|
||||
remark: json['remark'] as String?,
|
||||
);
|
||||
|
||||
Map<String, dynamic> _$$WarehouseUpdateRequestDtoImplToJson(
|
||||
_$WarehouseUpdateRequestDtoImpl instance) =>
|
||||
<String, dynamic>{
|
||||
'Name': instance.name,
|
||||
'name': instance.name,
|
||||
'zipcodes_zipcode': instance.zipcodesZipcode,
|
||||
'Remark': instance.remark,
|
||||
'remark': instance.remark,
|
||||
};
|
||||
|
||||
_$WarehouseListResponseImpl _$$WarehouseListResponseImplFromJson(
|
||||
|
||||
Reference in New Issue
Block a user