@k2works/claude-code-booster 3.2.1 → 3.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/lib/assets/.claude/skills/analyzing-business/SKILL.md +2 -2
  2. package/lib/assets/.claude/skills/analyzing-inception-deck/SKILL.md +5 -5
  3. package/lib/assets/.claude/skills/analyzing-requirements/SKILL.md +2 -2
  4. package/lib/assets/.claude/skills/generating-slides/SKILL.md +7 -7
  5. package/lib/assets/docs/article/index.md +4 -1
  6. package/lib/assets/docs/article/practical-database-design/index.md +121 -0
  7. package/lib/assets/docs/article/practical-database-design/part1/chapter01.md +288 -0
  8. package/lib/assets/docs/article/practical-database-design/part1/chapter02.md +518 -0
  9. package/lib/assets/docs/article/practical-database-design/part1/chapter03.md +557 -0
  10. package/lib/assets/docs/article/practical-database-design/part2/chapter04.md +924 -0
  11. package/lib/assets/docs/article/practical-database-design/part2/chapter05.md +1627 -0
  12. package/lib/assets/docs/article/practical-database-design/part2/chapter06.md +2716 -0
  13. package/lib/assets/docs/article/practical-database-design/part2/chapter07.md +2082 -0
  14. package/lib/assets/docs/article/practical-database-design/part2/chapter08.md +2105 -0
  15. package/lib/assets/docs/article/practical-database-design/part2/chapter09.md +2031 -0
  16. package/lib/assets/docs/article/practical-database-design/part2/chapter10.md +1387 -0
  17. package/lib/assets/docs/article/practical-database-design/part2/chapter11.md +1677 -0
  18. package/lib/assets/docs/article/practical-database-design/part2/chapter12.md +1417 -0
  19. package/lib/assets/docs/article/practical-database-design/part2/chapter13.md +1434 -0
  20. package/lib/assets/docs/article/practical-database-design/part3/chapter14.md +667 -0
  21. package/lib/assets/docs/article/practical-database-design/part3/chapter15.md +1625 -0
  22. package/lib/assets/docs/article/practical-database-design/part3/chapter16.md +1915 -0
  23. package/lib/assets/docs/article/practical-database-design/part3/chapter17.md +1708 -0
  24. package/lib/assets/docs/article/practical-database-design/part3/chapter18.md +2095 -0
  25. package/lib/assets/docs/article/practical-database-design/part3/chapter19.md +1123 -0
  26. package/lib/assets/docs/article/practical-database-design/part3/chapter20.md +1031 -0
  27. package/lib/assets/docs/article/practical-database-design/part3/chapter21.md +1382 -0
  28. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter14-orm.md +991 -0
  29. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter15-orm.md +1300 -0
  30. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter16-orm.md +1166 -0
  31. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter17-orm.md +1584 -0
  32. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter18-orm.md +1183 -0
  33. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter19-orm.md +1016 -0
  34. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter20-orm.md +1753 -0
  35. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter21-orm.md +1447 -0
  36. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter22-orm.md +1878 -0
  37. package/lib/assets/docs/article/practical-database-design/part4/chapter22.md +965 -0
  38. package/lib/assets/docs/article/practical-database-design/part4/chapter23.md +2069 -0
  39. package/lib/assets/docs/article/practical-database-design/part4/chapter24.md +2439 -0
  40. package/lib/assets/docs/article/practical-database-design/part4/chapter25.md +3661 -0
  41. package/lib/assets/docs/article/practical-database-design/part4/chapter26.md +2916 -0
  42. package/lib/assets/docs/article/practical-database-design/part4/chapter27.md +3105 -0
  43. package/lib/assets/docs/article/practical-database-design/part4/chapter28.md +2697 -0
  44. package/lib/assets/docs/article/practical-database-design/part4/chapter29.md +2544 -0
  45. package/lib/assets/docs/article/practical-database-design/part4/chapter30.md +2180 -0
  46. package/lib/assets/docs/article/practical-database-design/part4/chapter31.md +1192 -0
  47. package/lib/assets/docs/article/practical-database-design/part4/chapter32.md +2101 -0
  48. package/lib/assets/docs/article/practical-database-design/part5/chapter33.md +1032 -0
  49. package/lib/assets/docs/article/practical-database-design/part5/chapter34.md +1609 -0
  50. package/lib/assets/docs/article/practical-database-design/part5/chapter35.md +1453 -0
  51. package/lib/assets/docs/article/practical-database-design/part5/chapter36.md +1292 -0
  52. package/lib/assets/docs/article/practical-database-design/part5/chapter37.md +1470 -0
  53. package/lib/assets/docs/article/practical-database-design/part5/chapter38.md +1698 -0
  54. package/lib/assets/docs/article/practical-database-design/part5/chapter39.md +2334 -0
  55. package/lib/assets/docs/article/practical-database-design/study/study2-1.md +1693 -0
  56. package/lib/assets/docs/article/practical-database-design/study/study2-2.md +1347 -0
  57. package/lib/assets/docs/article/practical-database-design/study/study2-3.md +2044 -0
  58. package/lib/assets/docs/article/practical-database-design/study/study2-4.md +2229 -0
  59. package/lib/assets/docs/article/practical-database-design/study/study2-5.md +2418 -0
  60. package/lib/assets/docs/article/practical-database-design/study/study3-1.md +2205 -0
  61. package/lib/assets/docs/article/practical-database-design/study/study3-2.md +2221 -0
  62. package/lib/assets/docs/article/practical-database-design/study/study3-3.md +2253 -0
  63. package/lib/assets/docs/article/practical-database-design/study/study3-4.md +2106 -0
  64. package/lib/assets/docs/article/practical-database-design/study/study3-5.md +2507 -0
  65. package/lib/assets/docs/article/practical-database-design/study/study4-1.md +2587 -0
  66. package/lib/assets/docs/article/practical-database-design/study/study4-2.md +2075 -0
  67. package/lib/assets/docs/article/practical-database-design/study/study4-3.md +1805 -0
  68. package/lib/assets/docs/article/practical-database-design/study/study4-4.md +1895 -0
  69. package/lib/assets/docs/article/practical-database-design/study/study4-5.md +2878 -0
  70. package/package.json +1 -1
@@ -0,0 +1,924 @@
1
+ # 第4章:販売管理システムの全体像
2
+
3
+ 本章から第2部「販売管理システム」の解説に入ります。まず、販売管理システムのスコープと、関連する組織の役割分担について解説します。
4
+
5
+ ---
6
+
7
+ ## 4.1 販売管理システムのスコープ
8
+
9
+ 販売管理システムは、企業の販売活動を支援するシステムです。得意先からの引き合いを起点として、見積・受注・出荷・売上までの一連の業務プロセスを管理します。
10
+
11
+ ### システム全体像
12
+
13
+ ```plantuml
14
+ @startuml
15
+
16
+ [*] -> 得意先
17
+ 得意先 --> 営業部門
18
+ 営業部門 -> 販売管理
19
+ 販売管理 : 見積 \n受注 \n出荷 \n売上
20
+ 販売管理 -> 調達管理
21
+ 販売管理 --> 債権管理
22
+ 債権管理 : 締請求 \n入金
23
+ 調達管理 : 発注 \n入荷 \n仕入
24
+ 調達管理 -> 仕入先
25
+ 仕入先 -> 調達管理
26
+ 販売管理 --> 在庫管理
27
+ 在庫管理 --> 販売管理
28
+ 在庫管理 : 在庫 \n受払 \n棚卸
29
+ 調達管理 --> 在庫管理
30
+ 調達管理 --> 債務管理
31
+ 債務管理 : 支払締 \n支払
32
+
33
+ 得意先 -> [*]
34
+
35
+ @enduml
36
+ ```
37
+
38
+ ### 見積
39
+
40
+ 見積は、得意先からの引き合いに対して、商品の価格・納期・数量等の条件を提示する業務です。
41
+
42
+ ```plantuml
43
+ @startuml
44
+
45
+ state "見積業務" as Estimate {
46
+ state "引き合い受付" as Inquiry
47
+ state "見積作成" as Create
48
+ state "見積承認" as Approve
49
+ state "見積提出" as Submit
50
+ state "見積回答" as Response
51
+
52
+ [*] --> Inquiry
53
+ Inquiry --> Create : 見積依頼
54
+ Create --> Approve : 承認申請
55
+ Approve --> Submit : 承認
56
+ Approve --> Create : 差戻し
57
+ Submit --> Response : 得意先回答
58
+ Response --> [*] : 失注
59
+ Response --> 受注 : 受注
60
+ }
61
+
62
+ @enduml
63
+ ```
64
+
65
+ | 項目 | 説明 |
66
+ |---|---|
67
+ | 目的 | 得意先に販売条件を提示し、受注につなげる |
68
+ | 入力 | 引き合い情報(商品、数量、希望納期等) |
69
+ | 出力 | 見積書 |
70
+ | 主なデータ | 見積データ、見積明細データ |
71
+
72
+ **見積データの主要項目**
73
+
74
+ - 見積番号、見積日、有効期限
75
+ - 得意先コード、得意先名
76
+ - 担当者、担当部門
77
+ - 見積金額(税抜)、消費税額、見積金額(税込)
78
+
79
+ ### 受注
80
+
81
+ 受注は、得意先からの注文を受け付け、社内で処理する業務です。
82
+
83
+ ```plantuml
84
+ @startuml
85
+
86
+ state "受注業務" as Order {
87
+ state "注文受付" as Receive
88
+ state "受注登録" as Register
89
+ state "在庫確認" as StockCheck
90
+ state "納期回答" as DeliveryDate
91
+ state "受注確定" as Confirm
92
+
93
+ [*] --> Receive
94
+ Receive --> Register : 注文情報
95
+ Register --> StockCheck : 在庫照会
96
+ StockCheck --> DeliveryDate : 在庫OK
97
+ StockCheck --> 調達依頼 : 在庫不足
98
+ DeliveryDate --> Confirm : 納期確定
99
+ Confirm --> [*]
100
+ }
101
+
102
+ @enduml
103
+ ```
104
+
105
+ | 項目 | 説明 |
106
+ |---|---|
107
+ | 目的 | 得意先の注文を正確に記録し、出荷・売上の起点とする |
108
+ | 入力 | 注文情報(商品、数量、希望納期、納品先等) |
109
+ | 出力 | 注文請書、受注確認書 |
110
+ | 主なデータ | 受注データ、受注明細データ |
111
+
112
+ **受注データの主要項目**
113
+
114
+ - 受注番号、受注日、希望納期
115
+ - 得意先コード、納品先コード
116
+ - 担当者、担当部門
117
+ - 受注金額(税抜)、消費税額、受注金額(税込)
118
+ - 受注ステータス(受付、確定、出荷中、完了、キャンセル)
119
+
120
+ ### 出荷
121
+
122
+ 出荷は、受注に基づいて商品を得意先に届ける業務です。
123
+
124
+ ```plantuml
125
+ @startuml
126
+
127
+ state "出荷業務" as Shipment {
128
+ state "出荷指示" as Instruction
129
+ state "ピッキング" as Picking
130
+ state "検品" as Inspection
131
+ state "梱包" as Packing
132
+ state "配送" as Delivery
133
+ state "出荷完了" as Complete
134
+
135
+ [*] --> Instruction
136
+ Instruction --> Picking : ピッキングリスト
137
+ Picking --> Inspection : 商品取出
138
+ Inspection --> Packing : 検品OK
139
+ Inspection --> Picking : 検品NG
140
+ Packing --> Delivery : 配送手配
141
+ Delivery --> Complete : 配送完了
142
+ Complete --> [*]
143
+ }
144
+
145
+ @enduml
146
+ ```
147
+
148
+ | 項目 | 説明 |
149
+ |---|---|
150
+ | 目的 | 受注した商品を正確・迅速に得意先に届ける |
151
+ | 入力 | 受注データ、出荷指示 |
152
+ | 出力 | 出荷指示書、ピッキングリスト、納品書 |
153
+ | 主なデータ | 出荷指示データ、出荷データ、出荷明細データ |
154
+
155
+ **出荷データの主要項目**
156
+
157
+ - 出荷番号、出荷日、出荷予定日
158
+ - 受注番号(紐付け)
159
+ - 納品先コード、配送先住所
160
+ - 出荷ステータス(指示済、ピッキング中、出荷済、配送中、配送完了)
161
+
162
+ ### 売上
163
+
164
+ 売上は、商品の引渡しが完了した時点で収益を計上する業務です。
165
+
166
+ ```plantuml
167
+ @startuml
168
+
169
+ state "売上業務" as Sales {
170
+ state "売上計上" as Record
171
+ state "売上確定" as Confirm
172
+ state "請求データ作成" as Invoice
173
+
174
+ [*] --> Record
175
+ Record --> Confirm : 売上登録
176
+ Confirm --> Invoice : 売上確定
177
+ Invoice --> [*]
178
+ }
179
+
180
+ @enduml
181
+ ```
182
+
183
+ | 項目 | 説明 |
184
+ |---|---|
185
+ | 目的 | 収益を正確に計上し、請求・回収の起点とする |
186
+ | 入力 | 出荷データ、納品確認 |
187
+ | 出力 | 売上伝票、請求データ |
188
+ | 主なデータ | 売上データ、売上明細データ |
189
+
190
+ **売上データの主要項目**
191
+
192
+ - 売上番号、売上日、計上月
193
+ - 受注番号、出荷番号(紐付け)
194
+ - 得意先コード、請求先コード
195
+ - 売上金額(税抜)、消費税額、売上金額(税込)
196
+
197
+ ### 業務間の関連
198
+
199
+ 見積・受注・出荷・売上の各業務は、以下のように関連しています。
200
+
201
+ ```plantuml
202
+ @startuml
203
+
204
+ rectangle "見積" as Estimate #LightBlue
205
+ rectangle "受注" as Order #LightGreen
206
+ rectangle "出荷" as Shipment #LightYellow
207
+ rectangle "売上" as Sales #LightPink
208
+
209
+ Estimate --> Order : 見積参照\n(任意)
210
+ Order --> Shipment : 1:N
211
+ Shipment --> Sales : 1:1 or N:1
212
+
213
+ note right of Order
214
+ 1件の受注に対して
215
+ 複数回の出荷が可能
216
+ (分納)
217
+ end note
218
+
219
+ note right of Sales
220
+ 出荷単位で売上計上
221
+ または
222
+ 複数出荷をまとめて売上計上
223
+ end note
224
+
225
+ @enduml
226
+ ```
227
+
228
+ | 関連 | カーディナリティ | 説明 |
229
+ |---|---|---|
230
+ | 見積 → 受注 | 0..1 : 0..N | 見積なしで受注可能、1見積から複数受注も可能 |
231
+ | 受注 → 出荷 | 1 : 1..N | 分納により1受注から複数出荷 |
232
+ | 出荷 → 売上 | 1..N : 1 | 出荷単位または複数出荷まとめて売上計上 |
233
+
234
+ ---
235
+
236
+ ## 4.2 販売組織の役割分担
237
+
238
+ 販売管理システムに関わる組織は複数あり、それぞれが異なる役割を担っています。
239
+
240
+ ### 組織構成
241
+
242
+ ```plantuml
243
+ @startuml
244
+
245
+ package "販売管理に関わる組織" {
246
+ rectangle "営業部門" as Sales #LightBlue {
247
+ Sales : ・見積作成
248
+ Sales : ・受注登録
249
+ Sales : ・出荷指示
250
+ Sales : ・売上入力
251
+ }
252
+
253
+ rectangle "調達部門" as Procurement #LightGreen {
254
+ Procurement : ・発注入力
255
+ Procurement : ・仕入入力
256
+ }
257
+
258
+ rectangle "倉庫部門" as Warehouse #LightYellow {
259
+ Warehouse : ・入荷入力
260
+ Warehouse : ・ピッキング
261
+ Warehouse : ・出荷入力
262
+ Warehouse : ・在庫管理
263
+ }
264
+
265
+ rectangle "経理部門" as Accounting #LightPink {
266
+ Accounting : ・締請求処理
267
+ Accounting : ・支払締処理
268
+ Accounting : ・仕訳処理
269
+ }
270
+
271
+ rectangle "財務部門" as Finance #LightCoral {
272
+ Finance : ・入金入力
273
+ Finance : ・支払入力
274
+ Finance : ・資金管理
275
+ }
276
+ }
277
+
278
+ @enduml
279
+ ```
280
+
281
+ ### 営業部門
282
+
283
+ 営業部門は、得意先との接点を持ち、販売活動の中心的な役割を担います。
284
+
285
+ | 業務 | 責務 | 主な操作 |
286
+ |---|---|---|
287
+ | 見積 | 得意先への価格・納期の提示 | 見積作成、見積書発行 |
288
+ | 受注 | 得意先からの注文受付 | 受注登録、納期回答 |
289
+ | 出荷指示 | 倉庫への出荷依頼 | 出荷指示登録 |
290
+ | 売上 | 収益の計上 | 売上入力、売上確定 |
291
+
292
+ ### 調達部門
293
+
294
+ 調達部門は、商品・資材の仕入れを担当します。
295
+
296
+ | 業務 | 責務 | 主な操作 |
297
+ |---|---|---|
298
+ | 発注 | 仕入先への注文 | 発注登録、注文書発行 |
299
+ | 仕入 | 検収・仕入計上 | 仕入入力、仕入伝票発行 |
300
+
301
+ ### 倉庫部門
302
+
303
+ 倉庫部門は、商品・資材の物理的な管理を担当します。
304
+
305
+ | 業務 | 責務 | 主な操作 |
306
+ |---|---|---|
307
+ | 入荷 | 仕入先からの商品受入 | 入荷入力、検品 |
308
+ | ピッキング | 出荷商品の取り出し | ピッキング作業 |
309
+ | 出荷 | 商品の発送 | 出荷入力、配送手配 |
310
+ | 在庫管理 | 在庫数量の管理 | 棚卸、在庫調整 |
311
+
312
+ ### 経理部門
313
+
314
+ 経理部門は、取引の記帳・請求・支払の管理を担当します。
315
+
316
+ | 業務 | 責務 | 主な操作 |
317
+ |---|---|---|
318
+ | 締請求 | 売上の請求処理 | 締処理、請求書発行 |
319
+ | 支払締 | 仕入の支払処理 | 締処理、支払予定作成 |
320
+ | 仕訳 | 会計処理 | 仕訳入力、自動仕訳 |
321
+
322
+ ### 財務部門
323
+
324
+ 財務部門は、資金の入出金管理を担当します。
325
+
326
+ | 業務 | 責務 | 主な操作 |
327
+ |---|---|---|
328
+ | 入金 | 得意先からの入金処理 | 入金入力、消込処理 |
329
+ | 支払 | 仕入先への支払処理 | 支払入力、振込処理 |
330
+ | 資金管理 | 資金繰りの管理 | 資金計画、残高管理 |
331
+
332
+ ### 業務フローと各部門の責務
333
+
334
+ 各部門がどのタイミングで業務に関与するかを、全体フローで示します。
335
+
336
+ ```plantuml
337
+ @startuml
338
+ title 販売管理システムの全体フロー
339
+
340
+ |営業部門|
341
+ start
342
+ fork
343
+ :見積入力;
344
+ fork again
345
+ :受注入力;
346
+ fork end
347
+
348
+ |システム|
349
+ fork
350
+ :見積データ;
351
+ :見積書;
352
+ fork again
353
+ :受注データ;
354
+ :注文請書;
355
+ fork end
356
+
357
+ |調達部門|
358
+ :発注入力;
359
+
360
+ |システム|
361
+ :発注データ;
362
+ :注文書;
363
+
364
+ |倉庫部門|
365
+ :入荷入力;
366
+
367
+ |システム|
368
+ fork
369
+ :入荷データ;
370
+ fork again
371
+ :在庫データ;
372
+ fork end
373
+ :入荷伝票;
374
+
375
+ |調達部門|
376
+ :仕入入力;
377
+
378
+ |システム|
379
+ :仕入データ;
380
+ :仕入伝票;
381
+
382
+ |営業部門|
383
+ :出荷指示;
384
+
385
+ |システム|
386
+ fork
387
+ :出荷指示データ;
388
+ fork again
389
+ :在庫データ(引当);
390
+ fork end
391
+ :出荷指示書;
392
+ :ピッキングリスト;
393
+
394
+ |倉庫部門|
395
+ :ピッキング;
396
+ :出荷入力;
397
+
398
+ |システム|
399
+ fork
400
+ :出荷データ;
401
+ fork again
402
+ :在庫データ(出庫);
403
+ fork end
404
+ :納品書;
405
+
406
+ |営業部門|
407
+ :売上入力;
408
+
409
+ |システム|
410
+ :売上データ;
411
+ :売上伝票;
412
+
413
+ |経理部門|
414
+ :締請求処理;
415
+
416
+ |システム|
417
+ :債権データ;
418
+ :請求書;
419
+
420
+ |財務部門|
421
+ :入金入力;
422
+
423
+ |システム|
424
+ :入金データ;
425
+ :入金伝票;
426
+
427
+ stop
428
+
429
+ @enduml
430
+ ```
431
+
432
+ ### 部門間の連携ポイント
433
+
434
+ ```plantuml
435
+ @startuml
436
+
437
+ rectangle "営業部門" as Sales
438
+ rectangle "調達部門" as Procurement
439
+ rectangle "倉庫部門" as Warehouse
440
+ rectangle "経理部門" as Accounting
441
+ rectangle "財務部門" as Finance
442
+
443
+ Sales --> Procurement : 在庫不足時\n発注依頼
444
+ Sales --> Warehouse : 出荷指示
445
+ Sales --> Accounting : 売上データ
446
+
447
+ Procurement --> Warehouse : 入荷予定
448
+ Procurement --> Accounting : 仕入データ
449
+
450
+ Warehouse --> Sales : 出荷完了報告
451
+ Warehouse --> Procurement : 入荷報告
452
+
453
+ Accounting --> Finance : 請求・支払データ
454
+
455
+ Finance --> Accounting : 入金・出金データ
456
+
457
+ @enduml
458
+ ```
459
+
460
+ | 連携元 | 連携先 | 連携内容 |
461
+ |---|---|---|
462
+ | 営業部門 | 調達部門 | 在庫不足時の発注依頼 |
463
+ | 営業部門 | 倉庫部門 | 出荷指示 |
464
+ | 営業部門 | 経理部門 | 売上データ |
465
+ | 調達部門 | 倉庫部門 | 入荷予定情報 |
466
+ | 調達部門 | 経理部門 | 仕入データ |
467
+ | 倉庫部門 | 営業部門 | 出荷完了報告 |
468
+ | 経理部門 | 財務部門 | 請求・支払データ |
469
+ | 財務部門 | 経理部門 | 入金・出金データ |
470
+
471
+ ---
472
+
473
+ ## 4.3 販売管理システムのアーキテクチャ
474
+
475
+ 本節では、販売管理システム(SMS: Sales Management System)のプロジェクト構成とアーキテクチャについて解説します。
476
+
477
+ ### プロジェクト構成
478
+
479
+ 販売管理システムは `apps/sms` ディレクトリ以下に構築します。
480
+
481
+ ```
482
+ apps/sms/
483
+ ├── backend/
484
+ │ ├── build.gradle.kts # Gradle ビルド設定(Kotlin DSL)
485
+ │ ├── settings.gradle.kts # Gradle 設定
486
+ │ ├── config/ # 品質管理ツール設定
487
+ │ │ ├── checkstyle/
488
+ │ │ │ └── checkstyle.xml
489
+ │ │ ├── pmd/
490
+ │ │ │ └── ruleset.xml
491
+ │ │ └── spotbugs/
492
+ │ │ └── exclude.xml
493
+ │ │
494
+ │ └── src/
495
+ │ ├── main/
496
+ │ │ ├── java/com/example/sms/
497
+ │ │ │ │
498
+ │ │ │ ├── domain/ # ドメイン層(純粋なビジネスロジック)
499
+ │ │ │ │ ├── model/ # ドメインモデル(エンティティ、値オブジェクト)
500
+ │ │ │ │ │ ├── master/ # マスタ関連
501
+ │ │ │ │ │ └── transaction/ # トランザクション関連
502
+ │ │ │ │ ├── type/ # 基本型(通貨、単位、数量等)
503
+ │ │ │ │ └── exception/ # ドメイン例外
504
+ │ │ │ │
505
+ │ │ │ ├── application/ # アプリケーション層
506
+ │ │ │ │ ├── port/
507
+ │ │ │ │ │ ├── in/ # Input Port(ユースケースIF)
508
+ │ │ │ │ │ └── out/ # Output Port(リポジトリIF)
509
+ │ │ │ │ └── service/ # Application Service(ユースケース実装)
510
+ │ │ │ │
511
+ │ │ │ ├── infrastructure/ # インフラストラクチャ層
512
+ │ │ │ │ ├── in/ # Input Adapter
513
+ │ │ │ │ │ └── rest/ # REST API Controller
514
+ │ │ │ │ ├── out/ # Output Adapter
515
+ │ │ │ │ │ └── persistence/ # 永続化(MyBatis Mapper)
516
+ │ │ │ │ └── config/ # 設定クラス
517
+ │ │ │ │
518
+ │ │ │ └── Application.java # メインクラス
519
+ │ │ │
520
+ │ │ └── resources/
521
+ │ │ ├── application.yml # アプリケーション設定
522
+ │ │ ├── db/migration/ # Flyway マイグレーション
523
+ │ │ └── mapper/ # MyBatis XML マッパー
524
+ │ │
525
+ │ └── test/
526
+ │ ├── java/com/example/sms/
527
+ │ │ ├── testsetup/ # テスト基盤クラス
528
+ │ │ │ └── BaseIntegrationTest.java
529
+ │ │ ├── domain/ # ドメイン層テスト
530
+ │ │ ├── application/ # アプリケーション層テスト
531
+ │ │ └── infrastructure/ # インフラ層テスト
532
+ │ │
533
+ │ └── resources/
534
+ │ └── application-test.yml
535
+
536
+ ├── frontend/ # フロントエンド
537
+ │ └── src/
538
+ │ ├── components/ # UI コンポーネント
539
+ │ ├── pages/ # ページコンポーネント
540
+ │ ├── hooks/ # カスタムフック
541
+ │ ├── services/ # API クライアント
542
+ │ └── types/ # 型定義
543
+
544
+ └── docker-compose.yml # Docker 構成
545
+ ```
546
+
547
+ **各レイヤーの責務:**
548
+
549
+ | レイヤー | 責務 |
550
+ |---|---|
551
+ | Domain 層 | ビジネスルールとドメインモデル(外部技術に非依存) |
552
+ | Application 層 | ユースケースの実装とオーケストレーション |
553
+ | Infrastructure 層 | 外部技術との接続(DB、Web 等) |
554
+
555
+ ### ヘキサゴナルアーキテクチャ(ポート&アダプター)
556
+
557
+ 販売管理システムは、ヘキサゴナルアーキテクチャ(Ports and Adapters)を採用します。このアーキテクチャにより、ビジネスロジックを外部の技術的関心事から分離し、テスト容易性と保守性を高めます。
558
+
559
+ ```plantuml
560
+ @startuml
561
+ !define HEXAGON(name) hexagon name
562
+
563
+ skinparam hexagon {
564
+ BackgroundColor<<domain>> LightBlue
565
+ BackgroundColor<<port>> LightGreen
566
+ BackgroundColor<<adapter>> LightYellow
567
+ }
568
+
569
+ package "販売管理システム" {
570
+ ' ドメイン(中心)
571
+ hexagon "ドメイン\n(Domain)" <<domain>> as Domain {
572
+ }
573
+ note bottom of Domain
574
+ エンティティ
575
+ 値オブジェクト
576
+ 集約
577
+ ドメインサービス
578
+ end note
579
+
580
+ ' 入力ポート
581
+ rectangle "入力ポート\n(Input Ports)" <<port>> as InputPort {
582
+ }
583
+ note left of InputPort
584
+ ユースケース
585
+ インターフェース
586
+ end note
587
+
588
+ ' 出力ポート
589
+ rectangle "出力ポート\n(Output Ports)" <<port>> as OutputPort {
590
+ }
591
+ note right of OutputPort
592
+ リポジトリ
593
+ インターフェース
594
+ end note
595
+
596
+ ' プライマリアダプター
597
+ rectangle "プライマリアダプター\n(Primary Adapters)" <<adapter>> as PrimaryAdapter {
598
+ }
599
+ note top of PrimaryAdapter
600
+ REST API
601
+ GraphQL
602
+ CLI
603
+ end note
604
+
605
+ ' セカンダリアダプター
606
+ rectangle "セカンダリアダプター\n(Secondary Adapters)" <<adapter>> as SecondaryAdapter {
607
+ }
608
+ note bottom of SecondaryAdapter
609
+ PostgreSQL
610
+ Redis
611
+ 外部 API
612
+ end note
613
+ }
614
+
615
+ PrimaryAdapter --> InputPort
616
+ InputPort --> Domain
617
+ Domain --> OutputPort
618
+ OutputPort --> SecondaryAdapter
619
+
620
+ @enduml
621
+ ```
622
+
623
+ #### ドメイン(中心)
624
+
625
+ ドメインはシステムの中心に位置し、ビジネスロジックを実装します。
626
+
627
+ ```
628
+ backend/src/domain/
629
+ ├── model/ # ドメインモデル
630
+ │ ├── master/ # マスタ関連
631
+ │ │ ├── Product.ts # 商品
632
+ │ │ ├── Customer.ts # 顧客
633
+ │ │ └── Supplier.ts # 仕入先
634
+ │ ├── sales/ # 販売関連
635
+ │ │ ├── Order.ts # 受注
636
+ │ │ ├── OrderItem.ts # 受注明細
637
+ │ │ ├── Shipment.ts # 出荷
638
+ │ │ └── Sales.ts # 売上
639
+ │ ├── purchase/ # 仕入関連
640
+ │ │ ├── Purchase.ts # 発注
641
+ │ │ └── PurchaseReceipt.ts # 仕入
642
+ │ ├── inventory/ # 在庫関連
643
+ │ │ └── Inventory.ts # 在庫
644
+ │ └── billing/ # 請求関連
645
+ │ ├── Invoice.ts # 請求
646
+ │ └── Receipt.ts # 入金
647
+ ├── type/ # 基本型
648
+ │ ├── Money.ts # 通貨
649
+ │ ├── Quantity.ts # 数量
650
+ │ └── Unit.ts # 単位
651
+ └── exception/ # ドメイン例外
652
+ └── DomainException.ts
653
+ ```
654
+
655
+ #### ポート(入力ポート・出力ポート)
656
+
657
+ ポートは、ドメインと外部世界との境界を定義するインターフェースです。
658
+
659
+ | ポート種別 | 役割 | 例 |
660
+ |---|---|---|
661
+ | 入力ポート | 外部からの要求を受け付ける | ユースケースインターフェース |
662
+ | 出力ポート | 外部リソースへのアクセスを抽象化 | リポジトリインターフェース |
663
+
664
+ ```typescript
665
+ // 入力ポート(ユースケースインターフェース)
666
+ interface CreateOrderUseCase {
667
+ execute(command: CreateOrderCommand): Promise<OrderId>;
668
+ }
669
+
670
+ // 出力ポート(リポジトリインターフェース)
671
+ interface OrderRepository {
672
+ save(order: Order): Promise<void>;
673
+ findById(id: OrderId): Promise<Order | null>;
674
+ findByCustomerId(customerId: CustomerId): Promise<Order[]>;
675
+ }
676
+ ```
677
+
678
+ #### アダプター(プライマリ・セカンダリ)
679
+
680
+ アダプターは、ポートの実装を提供し、外部技術とドメインを接続します。
681
+
682
+ | アダプター種別 | 役割 | 例 |
683
+ |---|---|---|
684
+ | プライマリアダプター | 外部からの入力を処理 | REST コントローラ、CLI |
685
+ | セカンダリアダプター | 外部リソースへの出力を処理 | DB リポジトリ実装、外部 API クライアント |
686
+
687
+ ```
688
+ backend/src/infrastructure/
689
+ ├── in/ # Input Adapter(プライマリアダプター)
690
+ │ └── rest/ # REST API
691
+ │ ├── controller/
692
+ │ │ ├── OrderController.ts
693
+ │ │ ├── ShipmentController.ts
694
+ │ │ └── SalesController.ts
695
+ │ ├── dto/
696
+ │ │ ├── OrderRequest.ts
697
+ │ │ └── OrderResponse.ts
698
+ │ └── exception/
699
+ │ └── RestExceptionHandler.ts
700
+ ├── out/ # Output Adapter(セカンダリアダプター)
701
+ │ └── persistence/ # 永続化
702
+ │ ├── database/ # データベース定義
703
+ │ │ ├── migrations/ # マイグレーション
704
+ │ │ └── seeds/ # シードデータ
705
+ │ ├── mapper/ # O/R Mapper
706
+ │ │ └── OrderMapper.ts
707
+ │ ├── repository/ # Repository実装
708
+ │ │ ├── OrderRepositoryImpl.ts
709
+ │ │ └── CustomerRepositoryImpl.ts
710
+ │ └── typehandler/ # 型ハンドラ
711
+ └── config/ # 設定クラス
712
+ ├── DatabaseConfig.ts
713
+ └── WebConfig.ts
714
+ ```
715
+
716
+ #### 依存性の方向と依存性逆転の原則
717
+
718
+ ヘキサゴナルアーキテクチャでは、すべての依存性がドメインに向かいます。
719
+
720
+ ```plantuml
721
+ @startuml
722
+ skinparam rectangle {
723
+ BackgroundColor<<domain>> LightBlue
724
+ BackgroundColor<<app>> LightGreen
725
+ BackgroundColor<<infra>> LightYellow
726
+ BackgroundColor<<pres>> LightPink
727
+ }
728
+
729
+ rectangle "Presentation\n(プレゼンテーション層)" <<pres>> as Pres
730
+ rectangle "Application\n(アプリケーション層)" <<app>> as App
731
+ rectangle "Domain\n(ドメイン層)" <<domain>> as Domain
732
+ rectangle "Infrastructure\n(インフラストラクチャ層)" <<infra>> as Infra
733
+
734
+ Pres --> App
735
+ App --> Domain
736
+ Infra --> Domain
737
+
738
+ note right of Domain
739
+ 依存性逆転の原則(DIP)
740
+ ・ドメインはインターフェースを定義
741
+ ・インフラは実装を提供
742
+ ・依存の方向は常にドメインへ
743
+ end note
744
+
745
+ @enduml
746
+ ```
747
+
748
+ ### ドメイン駆動設計の適用
749
+
750
+ #### 集約とリポジトリ
751
+
752
+ 販売管理システムの主要な集約を以下に示します。
753
+
754
+ ```plantuml
755
+ @startuml
756
+ !define AGGREGATE(name) rectangle name <<aggregate>>
757
+ !define ENTITY(name) class name <<entity>>
758
+ !define VALUE(name) class name <<value>>
759
+
760
+ skinparam class {
761
+ BackgroundColor<<aggregate>> LightBlue
762
+ BackgroundColor<<entity>> LightGreen
763
+ BackgroundColor<<value>> LightYellow
764
+ }
765
+
766
+ package "受注集約" {
767
+ ENTITY(Order) {
768
+ +orderId: OrderId
769
+ +customerId: CustomerId
770
+ +orderDate: Date
771
+ +status: OrderStatus
772
+ +items: OrderItem[]
773
+ +totalAmount(): Money
774
+ }
775
+
776
+ ENTITY(OrderItem) {
777
+ +itemNo: number
778
+ +productId: ProductId
779
+ +quantity: Quantity
780
+ +unitPrice: Money
781
+ }
782
+
783
+ VALUE(OrderId) {
784
+ +value: string
785
+ }
786
+
787
+ VALUE(OrderStatus) {
788
+ +value: string
789
+ }
790
+
791
+ Order *-- OrderItem
792
+ Order --> OrderId
793
+ Order --> OrderStatus
794
+ }
795
+
796
+ @enduml
797
+ ```
798
+
799
+ | 集約 | ルートエンティティ | 主な責務 |
800
+ |---|---|---|
801
+ | 見積集約 | Estimate | 見積の作成・更新・承認 |
802
+ | 受注集約 | Order | 受注の登録・在庫引当・ステータス管理 |
803
+ | 出荷集約 | Shipment | 出荷指示・出荷実績の管理 |
804
+ | 売上集約 | Sales | 売上計上・請求データ生成 |
805
+
806
+ #### ドメインサービス
807
+
808
+ エンティティに属さないビジネスロジックはドメインサービスとして実装します。
809
+
810
+ ```typescript
811
+ // 価格計算サービス
812
+ class PricingService {
813
+ calculateOrderTotal(
814
+ items: OrderItem[],
815
+ customer: Customer,
816
+ discountPolicy: DiscountPolicy
817
+ ): Money {
818
+ // 顧客別単価の適用
819
+ // 数量割引の計算
820
+ // 消費税の計算
821
+ }
822
+ }
823
+
824
+ // 在庫引当サービス
825
+ class InventoryAllocationService {
826
+ allocate(order: Order): AllocationResult {
827
+ // 在庫の確認
828
+ // 引当処理
829
+ // 不足時の調達依頼
830
+ }
831
+ }
832
+ ```
833
+
834
+ #### アプリケーションサービス
835
+
836
+ アプリケーションサービスは、ユースケースを実装し、トランザクション境界を管理します。
837
+
838
+ ```typescript
839
+ // 受注登録ユースケース
840
+ class CreateOrderService implements CreateOrderUseCase {
841
+ constructor(
842
+ private orderRepository: OrderRepository,
843
+ private customerRepository: CustomerRepository,
844
+ private pricingService: PricingService,
845
+ private inventoryService: InventoryAllocationService
846
+ ) {}
847
+
848
+ async execute(command: CreateOrderCommand): Promise<OrderId> {
849
+ // 1. 顧客の取得
850
+ const customer = await this.customerRepository.findById(command.customerId);
851
+
852
+ // 2. 受注の作成
853
+ const order = Order.create(customer, command.items);
854
+
855
+ // 3. 価格計算
856
+ order.calculateTotal(this.pricingService);
857
+
858
+ // 4. 在庫引当
859
+ await this.inventoryService.allocate(order);
860
+
861
+ // 5. 保存
862
+ await this.orderRepository.save(order);
863
+
864
+ return order.id;
865
+ }
866
+ }
867
+ ```
868
+
869
+ ### API 設計
870
+
871
+ #### RESTful API の基本方針
872
+
873
+ | 原則 | 説明 |
874
+ |---|---|
875
+ | リソース指向 | URL はリソース(名詞)を表す |
876
+ | HTTP メソッド | GET/POST/PUT/DELETE で操作を表現 |
877
+ | ステートレス | サーバーはセッション状態を保持しない |
878
+ | HATEOAS | レスポンスに関連リソースへのリンクを含める |
879
+
880
+ #### エンドポイント設計
881
+
882
+ ```
883
+ # 見積
884
+ GET /api/v1/estimates # 見積一覧
885
+ POST /api/v1/estimates # 見積作成
886
+ GET /api/v1/estimates/{id} # 見積詳細
887
+ PUT /api/v1/estimates/{id} # 見積更新
888
+ DELETE /api/v1/estimates/{id} # 見積削除
889
+ POST /api/v1/estimates/{id}/approve # 見積承認
890
+
891
+ # 受注
892
+ GET /api/v1/orders # 受注一覧
893
+ POST /api/v1/orders # 受注登録
894
+ GET /api/v1/orders/{id} # 受注詳細
895
+ PUT /api/v1/orders/{id} # 受注更新
896
+ POST /api/v1/orders/{id}/confirm # 受注確定
897
+ POST /api/v1/orders/{id}/cancel # 受注キャンセル
898
+
899
+ # 出荷
900
+ GET /api/v1/shipments # 出荷一覧
901
+ POST /api/v1/shipments # 出荷登録
902
+ GET /api/v1/shipments/{id} # 出荷詳細
903
+ POST /api/v1/shipments/{id}/ship # 出荷実行
904
+ POST /api/v1/shipments/{id}/deliver # 配送完了
905
+
906
+ # 売上
907
+ GET /api/v1/sales # 売上一覧
908
+ POST /api/v1/sales # 売上計上
909
+ GET /api/v1/sales/{id} # 売上詳細
910
+ ```
911
+
912
+ ---
913
+
914
+ ## まとめ
915
+
916
+ 本章では、販売管理システムの全体像について解説しました。
917
+
918
+ - **販売管理システムのスコープ**は「見積→受注→出荷→売上」の4つの主要業務
919
+ - **5つの部門**(営業・調達・倉庫・経理・財務)がそれぞれの責務を担う
920
+ - 部門間の連携により、一連の業務フローが成立する
921
+ - **ヘキサゴナルアーキテクチャ**により、ドメインを中心とした疎結合な設計を実現
922
+ - **ドメイン駆動設計**の集約・リポジトリパターンを適用
923
+
924
+ 次章では、販売管理システムの基盤となるマスタ情報の設計について解説します。