buli
2023-07-14 36d15f189de2e83ce2576715dac30c3c260388dd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
trigger RentalApplyHpDeptUpd on Rental_Apply__c (before insert, before update) {
    
    List<String> accIds = new List<String>();
 
    for(Rental_Apply__c a : Trigger.new) {
        if ((Trigger.isUpdate
                && (Trigger.oldMap.get(a.Id).get('Account__c') != a.Account__c
                    || a.Account__r.ParentId != a.Strategic_dept__c
                    || a.Account__r.Parent.ParentId != a.Hospital__c))
                || Trigger.isInsert) {
            if (!String.isBlank(a.Account__c)) {
                accIds.add(a.Account__c);
            }
        }
    }
 
    if (accIds.size() > 0) {
        // 診療科レコードタイプ
        String[] deptTypes = new String[] {'診療科 その他', '診療科 呼吸科', '診療科 婦人科', '診療科 普外科', '診療科 泌尿科', '診療科 消化科', '診療科 耳鼻喉科'};
        List<RecordType> deptRects = [select Id, Name from RecordType where IsActive = true and SobjectType = 'Account' and Name IN :deptTypes];
        Map<String, String> deptRectMap = new Map<String, String>();
        for (RecordType rect : deptRects) {
            deptRectMap.put(rect.Id, rect.Name);
        }
        // TODO 販売店のレコードタイプのMapを生成
 
        Map<Id, Account> accMap = new Map<Id, Account>();
        List<Account> accs = ControllerUtil.selectAccountForTrigger(accIds);
        for(Account acc : accs) {
            accMap.put(acc.Id, acc);
        }
        
        for(Rental_Apply__c a : Trigger.new) {
            // 「診療科」に診療科を選択する場合
            Account acc = accMap.get(a.Account__c);
            if (acc != null
                    && deptRectMap.get(acc.RecordTypeId) != null) {
                a.Strategic_dept__c = acc.ParentId;
                a.Hospital__c = acc.Parent.ParentId;
            }
        }
    }
}