From 9b197b7fac92278fb591ea8f4942c7d5687cb5ce Mon Sep 17 00:00:00 2001
From: 李金换 <lijinhuan@prec-tech.com>
Date: 星期一, 28 三月 2022 18:01:22 +0800
Subject: [PATCH] LJPH-C8FB4P【委托】配合PBI设备覆盖率的数据准备0328
---
force-app/main/default/classes/ApplicationForCAHandler.cls | 91 +++++++++++++++------------------------------
1 files changed, 30 insertions(+), 61 deletions(-)
diff --git a/force-app/main/default/classes/ApplicationForCAHandler.cls b/force-app/main/default/classes/ApplicationForCAHandler.cls
index 1c36095..0826271 100644
--- a/force-app/main/default/classes/ApplicationForCAHandler.cls
+++ b/force-app/main/default/classes/ApplicationForCAHandler.cls
@@ -21,6 +21,8 @@
}
protected override void beforeUpdate() {
+ // 鏇存柊鏃跺垽鏂槸鍚︽洿鏂颁簡缁戝畾鐨勫浼氾紝濡傛灉缁戝畾澶氫釜瀛︿細涓斾笉鏄禐鍔╀細鏃讹紝娓呯┖缁戝畾鍏崇郴
+ clean_binding();
clean_campaign();
update_campaign();
}
@@ -30,13 +32,35 @@
update_status_on_opd();
}
+ // 鏇存柊鏃跺垽鏂槸鍚︽洿鏂颁簡缁戝畾鐨勫浼氾紝濡傛灉缁戝畾澶氫釜瀛︿細涓斾笉鏄禐鍔╀細鏃讹紝娓呯┖缁戝畾鍏崇郴
+ private void clean_binding() {
+ Map<String, String> app_cam_binds = new Map<String, String>();
+ for (Application_for_Conference_Adjudication__c app : this.newList) {
+ Application_for_Conference_Adjudication__c old_app = this.oldMap.get(app.Id);
+ if (String.isNotBlank(old_app.Num__c) && !old_app.Num__c.equals(app.Num__c) && app.MeetingType__c != '璧炲姪浼�') {
+ app_cam_binds.put(old_app.Id, old_app.Num__c);
+ }
+ }
+ if (app_cam_binds.size() > 0) {
+ List<Campaign> cams = [select Id, MeetingApprovedNo__c, Meeting_Approved_No__c from Campaign where Meeting_Approved_No__c in :app_cam_binds.keySet() and Num__c in :app_cam_binds.values()];
+ if (cams != null && cams.size() > 0) {
+ for (Campaign cam : cams) {
+ cam.MeetingApprovedNo__c = null;
+ cam.Meeting_Approved_No__c = null;
+ }
+ update cams;
+ }
+ }
+ }
+
// 瀹℃壒涓嶉�氳繃鐨勬椂鍊� 娓呯┖浼氳鍜孫PD璁″垝涓婄殑鍐宠淇℃伅
private void clean_campaign() {
List<String> approved_nos = new List<String>();
for (Application_for_Conference_Adjudication__c app : this.newList) {
if (app.ProcessState__c == '椹冲洖' ||
app.ProcessState__c == '缁堟鐢宠' ||
- app.ProcessState__c == '鍙栨秷') {
+ app.ProcessState__c == '鍙栨秷' ||
+ app.ProcessState__c == '鍒犻櫎') {
approved_nos.add(app.Id);
}
}
@@ -76,7 +100,7 @@
}
Map<String, Campaign> wait_upd_campaigns = new Map<String, Campaign>();
if (app_ids.size() > 0) {
- List<Campaign> campaigns = [select Id, Num__c, MeetingApprovedNo__c, Meeting_Approved_No__c from Campaign where Meeting_Approved_No__c in :app_ids];
+ List<Campaign> campaigns = [select Id, Num__c, MeetingApprovedNo__c, Meeting_Approved_No__c from Campaign where Meeting_Approved_No__c in :app_ids and Meeting_Type__c != '璧炲姪浼�'];
if (campaigns.size() > 0) {
for (Campaign cam : campaigns) {
Application_for_Conference_Adjudication__c app = this.newMap.get(cam.Meeting_Approved_No__c);
@@ -128,13 +152,11 @@
// 鏇存柊鍐宠鐨勪俊鎭埌瀛︿細涓�
private Campaign update_info_from_app(Campaign cam, Application_for_Conference_Adjudication__c app) {
- init_state_city();
cam.StartDate = app.StartDate__c;
cam.EndDate = app.EndDate__c;
cam.Budget_Type__c = app.BudgetType__c;
cam.OfficeCategory__c = app.OfficeCategory__c;
cam.Meeting_Type__c = app.MeetingType__c;
- cam.Activity_Type_Name__c = app.ActivityTypeName__c;
cam.WorkshopPlace__c = app.WorkshopPlace__c;
cam.HostName__c = app.HostName__c;
@@ -146,65 +168,12 @@
cam.Expected_Hcp_Attendance__c = app.ExpectedHcpAttendance__c;
cam.SponsorshipCategory__c = app.SponsorshipCategory__c;
cam.IsPaidToSponsor__c = app.IsPaidToSponsor__c;
- cam.Activity_Type_Name__c = app.ActivityTypeName__c;
+ // cam.Activity_Type_Name__c = app.ActivityTypeName__c;
+ cam.Activity_Type_Name__c = app.Type_of_adjudication_meeting__c;
// 杩欓噷闇�瑕侀澶栧姞鎿嶄綔
- cam.State_Master__c = get_state(app.StateMaster__c);
- cam.City_Master__c = get_city(app.CityMaster__c);
+ cam.State_Master__c = StateCityUtil.get_state(app.StateMaster__c);
+ cam.City_Master__c = StateCityUtil.get_city(app.CityMaster__c);
return cam;
- }
-
- // 鍒濆鍖栫渷甯備俊鎭�
- public static void init_state_city() {
- if (states == null || states.size() <= 0) {
- states = new Map<String, String>();
- List<Address_Level__c> lst_state = [select Id, Name from Address_Level__c];
- for (Address_Level__c level1 : lst_state) {
- states.put(level1.Name, level1.Id);
- }
- }
- if (cities == null || cities.size() <= 0) {
- cities = new Map<String, String>();
- List<Address_Level2__c> lst_city = [select Id, Name from Address_Level2__c];
- for (Address_Level2__c level2 : lst_city) {
- cities.put(level2.Name, level2.Id);
- }
- }
- }
-
- // 璁剧疆浼氳涓婄殑鐪�
- public static String get_state(String state_name) {
- if (String.isBlank(state_name)) {
- return null;
- }
- if (states == null || states.size() <= 0) {
- return null;
- }
- // 澶勭悊绌烘牸 鎴栬鍚庣画杩樻湁鍒殑澶勭悊
- state_name = state_name.trim().replace(' ', '');
- for(String state : states.keySet()) {
- if (state_name.contains(state) || state.contains(state_name)) {
- return states.get(state);
- }
- }
- return null;
- }
-
- // 璁剧疆浼氳涓婄殑甯�
- public static String get_city(String city_name) {
- if (String.isBlank(city_name)) {
- return null;
- }
- if (cities == null || cities.size() <= 0) {
- return null;
- }
- // 澶勭悊绌烘牸 鎴栬鍚庣画杩樻湁鍒殑澶勭悊
- city_name = city_name.trim().replace(' ', '');
- for(String city : cities.keySet()) {
- if (city_name.contains(city) || city.contains(city_name)) {
- return cities.get(city);
- }
- }
- return null;
}
}
\ No newline at end of file
--
Gitblit v1.9.1