diff --git a/app/Config/Routes.php b/app/Config/Routes.php index 62de0c1..0361165 100644 --- a/app/Config/Routes.php +++ b/app/Config/Routes.php @@ -206,6 +206,7 @@ $routes->group('', ['namespace' => 'App\Controllers\V2'], static function ($rout $routes->post('m702a/updateAssign', 'M702::updateAssign'); // 배정변경 $routes->post('m702a/saveTel', 'M702::saveTel'); // 전화확인 정보 저장 $routes->post('m702a/modifyInfo', 'M702::modifyInfo'); // 매물정보저장 + $routes->post('m702a/saveDocu', 'M702::saveDocu'); // 서류정보저장 $routes->post('m702a/uploadFile', 'M702::uploadFile'); // 파일업로드 @@ -297,6 +298,10 @@ $routes->group('', ['namespace' => 'App\Controllers\V2'], static function ($rout $routes->get('m706a/getResultList', 'M706::getResultList'); $routes->get('m706a/excel', 'M706::excel'); + $routes->post('m706a/modifyInfo', 'M706::modifyInfo'); // 매물정보 저장 + $routes->post('m706a/saveDocu', 'M706::saveDocu'); // 서류정보 저장 + $routes->post('m706a/saveRegi', 'M706::saveRegi'); // 등기부등본 저장 + }); /** diff --git a/app/Controllers/V2/M702.php b/app/Controllers/V2/M702.php index 9aa429c..9f8e0c4 100644 --- a/app/Controllers/V2/M702.php +++ b/app/Controllers/V2/M702.php @@ -1006,4 +1006,211 @@ class M702 extends BaseController ]); } } + + // 서류확인정보 저장 + public function saveDocu() + { + /* + 1.0.1 POST 데이터 받기. + 1.1.1 1차 검증인지 2차검증인지 확인. + 1.1.2 1차, 2차 검증이면 v2_confirm.type에 넣을 값을 알맞게 셋팅. + 1.2.1 v2_confirms에 데이터가 있는지 확인. + 1.3.1 데이터가 있음 : success 여부 판단 후 updateConfirm 실행 success값만 UPDATE. (수정변경이력 저장) + 1.4.1 데이터가 없음 : success 여부 판단 후 insertConfirm 실행 v2_confirms INSERT. (수정변경이력 저장) + 1.4.2 상태변경 하기 : 전화(서류)확인중 상태로 변경. (수정변경이력 저장) + 1.5.1 이미지파일 서버에 UPLOAD (수정변경이력 저장) + 1.6.1 기존파일 탐색. + 1.7.1 기존파일 있음 : 기존파일 use_yn 'N'으로 UPDATE 후 v2_files INSERT. + 1.8.1 기존파일 없음 : v2_files INSERT. + 1.9.1 확인여부 + 홍보확인서 미확인여부 상세, 매물주소, 가격거래구분, 의뢰인 정보 v2_check_list INSERT. (수정변경이력 저장) + 1.10.1 API 전송. + 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 전화(서류)확인완료 상태. (수정변경이력 저장) + */ + $naver = new NaverApiClient(); + $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + + try { + + $usr_id = session('usr_id'); + $toDay = date('Y-m-d H:i:s'); //오늘날짜 + $atcl_vrtc_way = $this->request->getPost('atcl_vrtc_way'); + $atcl_vr_sq = $this->request->getPost('rcpt_key'); + $arr = $this->request->getPost('chTotal'); + $fax_conf_res_d11 = $this->request->getPost('fax_conf_res_d11'); + $fax_conf_yn_1 = $this->request->getPost('fax_conf_yn_1'); + $fax_conf_yn_2 = $this->request->getPost('fax_conf_yn_2'); + $fax_conf_yn_3 = $this->request->getPost('fax_conf_yn_3'); + $fax_conf_yn_4 = $this->request->getPost('fax_conf_yn_4'); + $fax_conf_yn_info_2 = $this->request->getPost('fax_conf_yn_info_2'); + $fax_conf_yn_info_3 = $this->request->getPost('fax_conf_yn_info_3'); + $fax_conf_yn_info_4 = $this->request->getPost('fax_conf_yn_info_4'); + $reg_chk_val = $this->request->getPost('reg_chk_val'); + $memo = $this->request->getPost('memo_fax'); + $try_cnt = '0'; + + //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다. + $resStat = $this->model->chkStat($atcl_vr_sq); + $v2_vrfc_req = $v2DailyModel->get_v2_vrfc_req($atcl_vr_sq); + + + if ((int) $resStat['stat_cd'] >= 40 || (int) $resStat['stat_cd'] == '190') { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + $this->model->InsCharger($atcl_vr_sq); //담당자가 없을 경우 강제로 session 정보로 넣어준다 + + $resultCnt = $this->model->chkTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt + if ($resultCnt['try_cnt'] == 0) { //1차 검증일 때 + $try_cnt = '1'; + } else if ($resultCnt['try_cnt'] == 1) { //2차 검증일 때 + $try_cnt = '2'; + } else { + $try_cnt = intval($try_cnt) + 1; + } + + $result = $this->model->chkConfirm($atcl_vr_sq, ''); + if ($result == 0) { //v2_confirm 존재하지 않는다면 + if ($fax_conf_yn_2 == '10000' && $fax_conf_yn_3 == '10000' && $fax_conf_yn_4 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt); + } else { + if ($fax_conf_yn_2 == '10000' && $fax_conf_yn_3 == '10000' && $fax_conf_yn_4 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $resUpdate = $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type); + } + + //상태변경 TABLE INSERT : 전화(서류)확인중 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '30', $toDay); + $chgVrfc = $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + + //v2_check_list 확인여부 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D11', $fax_conf_res_d11, $arr); + //v2_check_list 매물주소 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D12', $fax_conf_yn_2, $fax_conf_yn_info_2); + //v2_check_list 가격거래구분 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D13', $fax_conf_yn_3, $fax_conf_yn_info_3); + //v2_check_list 의뢰인정보 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D14', $fax_conf_yn_4, $fax_conf_yn_info_4); + + //memo 저장 + if (!empty($memo)) { + $this->model->saveMemo([ + 'vr_sq' => $atcl_vr_sq, + 'memo' => $memo + ]); + } + + //API 호출 + $sendData = $this->model->getDataConfirmAPI($atcl_vr_sq); + + if ($fax_conf_yn_4 == '10000' || (int) $try_cnt < 2) { + $send_result = $naver->confirm($sendData['atclNo'], $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['modifyInfo'], $sendData['date']); + if ($send_result['result'] == 'success') { //HISTORY + if ($fax_conf_res_d11 == '10000' && $chk_type == '1') { + + //상태변경 TABLE INSERT : 전화(서류)확인 완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '35', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '35'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '35'); //fax_imgs + + if ($reg_chk_val == '1') { + //등기부등본 확인 대상은 전화(서류)확인 완료 후 -> 등기부등본 확인중 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '40', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '40'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '40'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0201', '1', 'add'); // 일치로 저장 + } else { + //등기부등본 확인 대상이 아닌 경우 전화(서류)확인 완료 후 -> 검증 완료 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '60', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '60'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0205', '1', 'add'); // 홍보확인서완료 등기부등본확인 안함 저장 + } + } else { + //상태변경 TABLE INSERT : 전화(서류)확인 불일치 + $this->model->chgStat($atcl_vr_sq, '39', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '39'); //fax_imgs + + + if ($try_cnt == '1') { + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgTryCnt($atcl_vr_sq, '1'); + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0301', '1', 'add'); // 1차실패로 저장 + } else if ($try_cnt == '2') { + //v2_vrfc_req try_cnt 값을 2로 update + $this->model->chgTryCnt($atcl_vr_sq, '2'); + + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0302', '1', 'add'); // 2차실패로 저장 + } + + if ($fax_conf_res_d11 == '20013') { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0203', '1', 'add'); // 기타로 저장 + } else { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0202', '1', 'add'); // 불일치로 저장 + } + } + } else { + if (isset($send_result['error'])) { + $error_message = $send_result['error']['code'] . "\\n" . $send_result['error']['message']; + + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $send_result['error']['code'], $send_result['error']['message'], $err_time, $v2_vrfc_req['atcl_no']); + throw new \Exception($error_message); + } else { + throw new \Exception('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.'); + } + } + + } else { + $this->model->chgStat($atcl_vr_sq, '39', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '39'); //fax_imgs + + $this->model->saveHistory($atcl_vr_sq, '30', 'C9', $usr_id, '상태변경 : 39 => 30'); //검증결과 변동사항 HISTORY + $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs + + throw new Exception('의뢰인정보 불일치로 저장되었습니다.'); + } + + return $this->response->setJSON(body: [ + 'code' => '0', + 'msg' => '정상적으로 저장되었습니다.', + ]); + + } + + } catch (\Exception $e) { + return $this->response->setJSON(body: [ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } } \ No newline at end of file diff --git a/app/Controllers/V2/M704.php b/app/Controllers/V2/M704.php index 5c07310..600f14f 100644 --- a/app/Controllers/V2/M704.php +++ b/app/Controllers/V2/M704.php @@ -595,7 +595,7 @@ class M704 extends BaseController //memo 저장 if (!empty($memo)) { - $this->model->saveMemo(['vr_sq' => $atcl_vr_sq, 'memo' => $memo]); + $this->model->saveMemo([$memo, $atcl_vr_sq]); } //전화실패 사유 저장 if (!empty($tel_fail_cause)) { diff --git a/app/Controllers/V2/M705.php b/app/Controllers/V2/M705.php index 7cf3266..0a94f22 100644 --- a/app/Controllers/V2/M705.php +++ b/app/Controllers/V2/M705.php @@ -58,7 +58,7 @@ class M705 extends BaseController 'srcDong' => $this->request->getGet('srcDong'), // 읍면동 'bonbu' => $this->request->getGet('bonbu'), // 본부 'team' => $this->request->getGet('team'), // 팀 - 'damdang' => $this->request->guploadFileetGet('damdang'), // 담당 + 'damdang' => $this->request->getGet('damdang'), // 담당 'vrfcreq_way' => $this->request->getGet('vrfcreq_way'), // 검증방식1 'vrfc_type_sub' => $this->request->getGet('vrfc_type_sub'), // 검증방식2 'rcpt_cpid' => $this->request->getGet('rcpt_cpid'), // 매체사 @@ -486,7 +486,7 @@ class M705 extends BaseController $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '22', $reg_conf_yn_3, $reg_conf_yn_info_3); //memo 저장 - $this->model->saveMemo(['vr_sq' => $atcl_vr_sq, 'memo' => $memo]); + $this->model->saveMemo([$memo, $atcl_vr_sq]); //실소유주 확인 저장 $this->model->update_owner_verifiable($atcl_vr_sq, $owner_verifiable); diff --git a/app/Controllers/V2/M706.php b/app/Controllers/V2/M706.php index 8800edb..748598a 100644 --- a/app/Controllers/V2/M706.php +++ b/app/Controllers/V2/M706.php @@ -2,8 +2,12 @@ namespace App\Controllers\V2; use App\Controllers\BaseController; +use App\Libraries\NaverApiClient; use App\Models\common\CodeModel; +use App\Models\results\M415Model; use App\Models\v2\M706Model; +use App\Models\v2\M710Model; +use Exception; class M706 extends BaseController { @@ -110,6 +114,7 @@ class M706 extends BaseController // 상세화면 public function detail($id) { + $naver = new NaverApiClient(); $id = (string) $id; if ($id === '') { @@ -124,6 +129,15 @@ class M706 extends BaseController $memo = $this->model->getMemo($id); $history = $this->model->getHistory($id); + $complexList = []; + $ptpList = []; + + // 아파트단지목록 + $complexList = $naver->complexList($data['address_code']); + + // 평형목록 + $ptpList = $naver->ptpList($data['hscp_no']); + $this->data['codes'] = $codes; $this->data['regist'] = $regist; $this->data['record'] = $record; @@ -132,8 +146,477 @@ class M706 extends BaseController $this->data['memo'] = $memo; $this->data['history'] = $history; + $this->data['complexList'] = $complexList; + $this->data['ptpList'] = $ptpList; + return view("pages/v2/m706/detail", $this->data); + } + // 매물정보 수정 + public function modifyInfo() + { + $naver = new NaverApiClient(); + + try { + $atcl_vr_sq = $this->request->getPost('rcpt_key'); //순번 + $atcl_hscp_nm = $this->request->getPost('atcl_hscp_nm'); //단지명 + $atcl_ptp_nm = $this->request->getPost('atcl_ptp_nm'); //평형명 + $atcl_vrfc_type = $this->request->getPost('atcl_vrtc_way'); //검증구분 + $trade_type = $this->request->getPost('trade_type_cd'); //거래구분 + $atcl_addr1 = $this->request->getPost('atcl_addr1'); //상세주소1 폐기예정 + $atcl_addr1a = $this->request->getPost('atcl_addr1a'); // 리 주소 + $atcl_addr1b = $this->request->getPost('atcl_addr1b'); // 공동 : 동 주소, 비공동 : 지번주소 + $atcl_addr2 = $this->request->getPost('atcl_addr2'); //상세주소2 + $atcl_hscp_no = $this->request->getPost('atcl_hscp_no'); //단지번호 + $atcl_ptp_no = $this->request->getPost('atcl_ptp_no'); //단지명 + $atcl_amt1 = $this->request->getPost('atcl_amt1'); + $atcl_amt2 = $this->request->getPost('atcl_amt2'); + $atcl_amt3 = $this->request->getPost('atcl_amt3'); + $atcl_floor = $this->request->getPost('atcl_floor'); + $atcl_floor2 = $this->request->getPost('atcl_floor2'); // 총층 + + $return = ''; + if ($trade_type == 'A1') { + $return = limitHscpMarketPriceInfo($this, $trade_type, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt1); + } elseif ($trade_type == 'B1') { + $return = limitHscpMarketPriceInfo($this, $trade_type, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt2); + } + + + + if (empty($return)) { + $result = $this->model->saveModifyInfo($atcl_vr_sq, $atcl_hscp_nm, $atcl_ptp_nm, $atcl_vrfc_type, $trade_type, $atcl_addr1, $atcl_addr1a, $atcl_addr1b, $atcl_addr2, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt1, $atcl_amt2, $atcl_amt3, $atcl_floor, $atcl_floor2); + $this->model->saveModifyVrfc($atcl_vr_sq, $atcl_vrfc_type); + + + if ($result['error_number'] != 0) { + throw new \Exception($result['error_message']); + } else { + //API 호출 + $resultData = $this->model->getDetail($atcl_vr_sq); + + $modifyInfo = $naver->modifyInfo( + $resultData['data']['atcl_no'], + $resultData['data']['hscp_no'], + $resultData['data']['ptp_no'], + $resultData['data']['bild_nm'], + $resultData['data']['rm_no'], + $resultData['data']['trade_type_cd'], + $resultData['data']['deal_amt'], + $resultData['data']['wrrnt_amt'], + $resultData['data']['lease_amt'], + $resultData['data']['isale_amt'], + $resultData['data']['prem_amt'], + $resultData['data']['floor'], + $resultData['data']['floor2'], + $resultData['data']['charger'], + $resultData['data']['address_code'], + $resultData['data']['address2'], + $resultData['data']['address2a'], + $resultData['data']['address2b'], + $resultData['data']['address3'], + $resultData['data']['sply_spc'], + $resultData['data']['excls_spc'], + $resultData['data']['tot_spc'], + $resultData['data']['grnd_spc'], + $resultData['data']['bldg_spc'] + ); + + if ($modifyInfo['result'] != 'success') { //결과값 확인 + $return = $modifyInfo['error']; + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $modifyInfo['error']['code'], $modifyInfo['error']['message'], $err_time, $resultData['data']['atcl_no']); + + } + } + + + return $this->response->setJSON(body: [ + 'code' => '0', + 'msg' => '정상적으로 저장되었습니다.', + ]); + } + + } catch (\Exception $e) { + return $this->response->setJSON(body: [ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + + // 서류확인정보 저장 + public function saveDocu() + { + /* + 1.0.1 POST 데이터 받기. + 1.1.1 1차 검증인지 2차검증인지 확인. + 1.1.2 1차, 2차 검증이면 v2_confirm.type에 넣을 값을 알맞게 셋팅. + 1.2.1 v2_confirms에 데이터가 있는지 확인. + 1.3.1 데이터가 있음 : success 여부 판단 후 updateConfirm 실행 success값만 UPDATE. (수정변경이력 저장) + 1.4.1 데이터가 없음 : success 여부 판단 후 insertConfirm 실행 v2_confirms INSERT. (수정변경이력 저장) + 1.4.2 상태변경 하기 : 전화(서류)확인중 상태로 변경. (수정변경이력 저장) + 1.5.1 이미지파일 서버에 UPLOAD (수정변경이력 저장) + 1.6.1 기존파일 탐색. + 1.7.1 기존파일 있음 : 기존파일 use_yn 'N'으로 UPDATE 후 v2_files INSERT. + 1.8.1 기존파일 없음 : v2_files INSERT. + 1.9.1 확인여부 + 홍보확인서 미확인여부 상세, 매물주소, 가격거래구분, 의뢰인 정보 v2_check_list INSERT. (수정변경이력 저장) + 1.10.1 API 전송. + 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 전화(서류)확인완료 상태. (수정변경이력 저장) + */ + $naver = new NaverApiClient(); + $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + + try { + + $usr_id = session('usr_id'); + $toDay = date('Y-m-d H:i:s'); //오늘날짜 + $atcl_vrtc_way = $this->request->getPost('atcl_vrtc_way'); + $atcl_vr_sq = $this->request->getPost('rcpt_key'); + $arr = $this->request->getPost('chTotal'); + $fax_conf_res_d11 = $this->request->getPost('fax_conf_res_d11'); + $fax_conf_yn_1 = $this->request->getPost('fax_conf_yn_1'); + $fax_conf_yn_2 = $this->request->getPost('fax_conf_yn_2'); + $fax_conf_yn_3 = $this->request->getPost('fax_conf_yn_3'); + $fax_conf_yn_4 = $this->request->getPost('fax_conf_yn_4'); + $fax_conf_yn_info_2 = $this->request->getPost('fax_conf_yn_info_2'); + $fax_conf_yn_info_3 = $this->request->getPost('fax_conf_yn_info_3'); + $fax_conf_yn_info_4 = $this->request->getPost('fax_conf_yn_info_4'); + $reg_chk_val = $this->request->getPost('reg_chk_val'); + $memo = $this->request->getPost('memo_fax'); + $try_cnt = '0'; + + //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다. + $resStat = $this->model->chkStat($atcl_vr_sq); + $v2_vrfc_req = $v2DailyModel->get_v2_vrfc_req($atcl_vr_sq); + + + if ((int) $resStat['stat_cd'] >= 40 || (int) $resStat['stat_cd'] == '190') { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + $this->model->InsCharger($atcl_vr_sq); //담당자가 없을 경우 강제로 session 정보로 넣어준다 + + $resultCnt = $this->model->chkTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt + if ($resultCnt['try_cnt'] == 0) { //1차 검증일 때 + $try_cnt = '1'; + } else if ($resultCnt['try_cnt'] == 1) { //2차 검증일 때 + $try_cnt = '2'; + } else { + $try_cnt = intval($try_cnt) + 1; + } + + $result = $this->model->chkConfirm($atcl_vr_sq, ''); + if ($result == 0) { //v2_confirm 존재하지 않는다면 + if ($fax_conf_yn_2 == '10000' && $fax_conf_yn_3 == '10000' && $fax_conf_yn_4 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt); + } else { + if ($fax_conf_yn_2 == '10000' && $fax_conf_yn_3 == '10000' && $fax_conf_yn_4 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $resUpdate = $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type); + } + + //상태변경 TABLE INSERT : 전화(서류)확인중 상태로 변경 + $result_query2 = $this->model->chgStat($atcl_vr_sq, '30', $toDay); + $chgVrfc = $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + + //v2_check_list 확인여부 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D11', $fax_conf_res_d11, $arr); + //v2_check_list 매물주소 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D12', $fax_conf_yn_2, $fax_conf_yn_info_2); + //v2_check_list 가격거래구분 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D13', $fax_conf_yn_3, $fax_conf_yn_info_3); + //v2_check_list 의뢰인정보 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D14', $fax_conf_yn_4, $fax_conf_yn_info_4); + + //memo 저장 + if (!empty($memo)) { + $this->model->saveMemo([$memo, $usr_id, $atcl_vr_sq]); + } + + //API 호출 + $sendData = $this->model->getDataConfirmAPI($atcl_vr_sq); + + if ($fax_conf_yn_4 == '10000' || (int) $try_cnt < 2) { + $send_result = $naver->confirm($sendData['atclNo'], $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['modifyInfo'], $sendData['date']); + if ($send_result['result'] == 'success') { //HISTORY + if ($fax_conf_res_d11 == '10000' && $chk_type == '1') { + + //상태변경 TABLE INSERT : 전화(서류)확인 완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '35', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '35'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '35'); //fax_imgs + + if ($reg_chk_val == '1') { + //등기부등본 확인 대상은 전화(서류)확인 완료 후 -> 등기부등본 확인중 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '40', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '40'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '40'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0201', '1', 'add'); // 일치로 저장 + } else { + //등기부등본 확인 대상이 아닌 경우 전화(서류)확인 완료 후 -> 검증 완료 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '60', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '60'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0205', '1', 'add'); // 홍보확인서완료 등기부등본확인 안함 저장 + } + } else { + //상태변경 TABLE INSERT : 전화(서류)확인 불일치 + $this->model->chgStat($atcl_vr_sq, '39', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '39'); //fax_imgs + + + if ($try_cnt == '1') { + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgTryCnt($atcl_vr_sq, '1'); + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0301', '1', 'add'); // 1차실패로 저장 + } else if ($try_cnt == '2') { + //v2_vrfc_req try_cnt 값을 2로 update + $this->model->chgTryCnt($atcl_vr_sq, '2'); + + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0302', '1', 'add'); // 2차실패로 저장 + } + + if ($fax_conf_res_d11 == '20013') { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0203', '1', 'add'); // 기타로 저장 + } else { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0202', '1', 'add'); // 불일치로 저장 + } + } + } else { + if (isset($send_result['error'])) { + $error_message = $send_result['error']['code'] . "\\n" . $send_result['error']['message']; + + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $send_result['error']['code'], $send_result['error']['message'], $err_time, $v2_vrfc_req['atcl_no']); + throw new \Exception($error_message); + } else { + throw new \Exception('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.'); + } + } + + } else { + $this->model->chgStat($atcl_vr_sq, '39', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '39'); //fax_imgs + + $this->model->saveChangedHistory($atcl_vr_sq, '30', 'C9', $usr_id, '상태변경 : 39 => 30'); //검증결과 변동사항 HISTORY + $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs + + throw new Exception('의뢰인정보 불일치로 저장되었습니다.'); + } + + return $this->response->setJSON(body: [ + 'code' => '0', + 'msg' => '정상적으로 저장되었습니다.', + ]); + + } + + } catch (\Exception $e) { + return $this->response->setJSON(body: [ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + + // 등기부등본 정보 저장 + public function saveRegi() + { + /* + 1.0.1 POST 데이터 받기. + 1.1.1 1차 검증인지 2차검증인지 확인. + 1.1.2 1차, 2차 검증이면 v2_confirm.type에 넣을 값을 알맞게 셋팅. + 1.2.1 v2_confirms에 데이터가 있는지 확인. + 1.3.1 데이터가 있음 : success 여부 판단 후 updateConfirm 실행 success값만 UPDATE. (수정변경이력 저장) + 1.4.1 데이터가 없음 : success 여부 판단 후 insertConfirm 실행 v2_confirms INSERT. (수정변경이력 저장) + 1.4.2 상태변경 하기 : 등기부등본 확인중 상태로 변경. (수정변경이력 저장) + 1.5.1 이미지파일 서버에 UPLOAD (수정변경이력 저장) + 1.6.1 기존파일 탐색. + 1.7.1 기존파일 있음 : 기존파일 use_yn 'N'으로 UPDATE 후 v2_files INSERT. + 1.8.1 기존파일 없음 : v2_files INSERT. + 1.9.1 매물주소, 의뢰인 정보 v2_check_list INSERT. (수정변경이력 저장) + 1.10.1 API 전송. + 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 등기부등본 확인완료 상태. (수정변경이력 저장) + */ + $naver = new NaverApiClient(); + $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + + try { + + $mode = $this->request->getGet('mode'); + $usr_id = session('usr_id'); + $toDay = date('Y-m-d H:i:s'); + $atcl_vrtc_way = 'R'; + $atcl_vr_sq = $this->request->getPost('rcpt_key'); + $reg_conf_yn_1 = $this->request->getPost('reg_conf_yn_1'); + $reg_conf_yn_2 = $this->request->getPost('reg_conf_yn_2'); + $reg_conf_yn_3 = $this->request->getPost('reg_conf_yn_3'); + $reg_conf_yn_info_2 = $this->request->getPost('reg_conf_yn_info_2'); + $reg_conf_yn_info_3 = $this->request->getPost('reg_conf_yn_info_3'); + $memo = $this->request->getPost('memo_reg'); + $try_cnt = '0'; + + //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다. + $resStat = $this->model->chkStat($atcl_vr_sq); + $v2_vrfc_req = $this->model->get_v2_vrfc_req($atcl_vr_sq); + + if ((int) $resStat['stat_cd'] >= 60 || (int) $resStat['stat_cd'] == 19) { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + $this->model->InsResChar($atcl_vr_sq); //담당자가 없을 경우 강제로 session 정보로 넣어준다 + + $resultCnt = $this->model->chkRegiTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt + if ($resultCnt['reg_try_cnt'] == 0) { //1차 검증일 때 + $try_cnt = '1'; + } else if ($resultCnt['reg_try_cnt'] == 1) { //2차 검증일 때 + $try_cnt = '2'; + } else { + $try_cnt = intval($try_cnt) + 1; + } + + $result = $this->model->chkConfirm($atcl_vr_sq, $atcl_vrtc_way); + if ($result == 0) { + if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt); + } else { + if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type); + } + + //상태변경 TABLE INSERT : 등기부등본 확인중 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '40', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '40'); //v2_vrfc_req INSERT + + //v2_check_list 확인여부 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '21', $reg_conf_yn_2, $reg_conf_yn_info_2); + + //v2_check_list 매물주소 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '22', $reg_conf_yn_3, $reg_conf_yn_info_3); + + //memo 저장 + if (!empty($memo)) { + $this->model->updateMemo([$memo, $atcl_vr_sq]); + } + + //API 호출 + $sendData = $this->model->getDatacertAPI($atcl_vr_sq, 'R'); + $send_result = $naver->certification($sendData['atclNo'], $try_cnt, $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['date'], $sendData['modifyInfo'], $sendData['ownerVerifiable']); + if ($send_result['result'] == 'success') { + if ($chk_type == '1') { + //상태변경 TABLE INSERT : 등기부등본 확인완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '45', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '45'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '45'); //fax_imgs + + //상태변경 TABLE INSERT : 검증완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '60', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '60'); //fax_imgs + + $v2_vrfc_req->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } else { + //상태변경 TABLE INSERT : 등기부등본 확인 불일치 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '49', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '49'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '49'); //fax_imgs + + //등기부등본 확인중 상태로 변경. + $this->model->saveChangedHistory($atcl_vr_sq, '30', 'C9', $usr_id, '상태변경 : 49 => 30'); //검증결과 변동사항 HISTORY + $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs + + if ($try_cnt == '1') { + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '1'); + } else if ($try_cnt == '2') { + + //v2_vrfc_req try_cnt 값을 2로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '2'); + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + } + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } + } else { + if (isset($send_result['error'])) { + $error_message = $send_result['error']['code'] . "\\n" . $send_result['error']['message']; + + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $send_result['error']['code'], $send_result['error']['message'], $err_time, $v2_vrfc_req['atcl_no']); + throw new \Exception($error_message); + } else { + throw new \Exception('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.'); + } + } + + return $this->response->setJSON(body: [ + 'code' => '0', + 'msg' => '정상적으로 저장되었습니다.', + ]); + + } + + } catch (\Exception $e) { + return $this->response->setJSON(body: [ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } } } \ No newline at end of file diff --git a/app/Models/v2/M702Model.php b/app/Models/v2/M702Model.php index 577466e..a53312f 100644 --- a/app/Models/v2/M702Model.php +++ b/app/Models/v2/M702Model.php @@ -1507,6 +1507,20 @@ class M702Model extends Model ]; } + public function chgTryCnt($vr_sq, $try_cnt) + { //v2_vrfc_req try_cnt 값 변경. + $sql = "UPDATE v2_vrfc_req" . + " SET try_cnt = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $try_cnt, + $vr_sq + ); + + $this->db->query($sql, $data); + } + // 변경이력 조회 public function getHistory($vr_sq) { diff --git a/app/Models/v2/M704Model.php b/app/Models/v2/M704Model.php index 1a70a89..e6e45ad 100644 --- a/app/Models/v2/M704Model.php +++ b/app/Models/v2/M704Model.php @@ -1,6 +1,7 @@ db->transComplete(); // 홍보확인서인 경우 주소 변경시 FAX 이미지의 정보도 함께 변경한다. - $faxModel = model('App\Models\FaxModel'); + $faxModel = new FaxModel(); $faxModel->updateAddress($atcl_vr_sq, $list['address_code'], $data['address2'] ?? '', $data['address3'] ?? '', $data['hscp_no'] ?? '', $data['hscp_nm'] ?? ''); return $return; diff --git a/app/Models/v2/M706Model.php b/app/Models/v2/M706Model.php index 3722c0a..f6a291d 100644 --- a/app/Models/v2/M706Model.php +++ b/app/Models/v2/M706Model.php @@ -1,6 +1,7 @@ getRowArray(); } + /* 매물정보를 수정 */ + public function saveModifyInfo($atcl_vr_sq, $atcl_hscp_nm, $atcl_ptp_nm, $atcl_vrfc_type, $trade_type, $atcl_addr1, $atcl_addr1a, $atcl_addr1b, $atcl_addr2, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt1, $atcl_amt2, $atcl_amt3, $atcl_floor, $atcl_floor2) + { + $session = session(); + $usr_id = $session->get('usr_id'); + + $list = $this->getDetail($atcl_vr_sq); + + $data = []; + + if ($trade_type != 'B2') { + $atcl_amt3 = '0'; + $data['lease_amt'] = $atcl_amt3; + } + if (!empty($trade_type)) + $data['trade_type'] = $trade_type; + if (!empty($atcl_hscp_nm)) + $data['hscp_nm'] = $atcl_hscp_nm; + if (!empty($atcl_ptp_nm)) + $data['ptp_nm'] = $atcl_ptp_nm; + if (!empty($atcl_addr1)) + $data['address2'] = $atcl_addr1; + if (!empty($atcl_addr1a)) + $data['address2a'] = $atcl_addr1a; + if (!empty($atcl_addr1b)) + $data['address2b'] = $atcl_addr1b; + if (!empty($atcl_addr2)) + $data['address3'] = $atcl_addr2; + if (!empty($atcl_hscp_no)) + $data['hscp_no'] = $atcl_hscp_no; + if (!empty($atcl_ptp_no)) + $data['ptp_no'] = $atcl_ptp_no; + if (!empty($atcl_amt1)) + $data['deal_amt'] = $atcl_amt1; + if (!empty($atcl_amt2)) + $data['wrrnt_amt'] = $atcl_amt2; + if (!empty($atcl_amt3)) + $data['lease_amt'] = $atcl_amt3; + if (!empty($atcl_floor)) + $data['floor'] = $atcl_floor; + if (!empty($atcl_floor2)) + $data['floor2'] = $atcl_floor2; + $data['modify_yn'] = 'Y'; + + $this->db->transStart(); + + $builder = $this->db->table('v2_modify_info'); + $builder->where('vr_sq', $atcl_vr_sq); + $builder->update($data); + + $last_query = $this->db->getLastQuery(); + $current_url = current_url(); + log_message('debug', $current_url . ' :: ' . $last_query); + + $data['trade_type_cd'] = $trade_type; + $return['error_number'] = $this->db->error()['code']; + $return['error_message'] = $this->db->error()['message']; + + if (empty($return['error_number'])) { + if ($this->db->affectedRows() > 0) { + if (!empty($changed)) { + $this->saveChangedHistory($list['vr_sq'], $list['pre_stat_cd'], 'C25', $usr_id, "매물정보 수정"); + } + } + } + $this->db->transComplete(); + + // 홍보확인서인 경우 주소 변경시 FAX 이미지의 정보도 함께 변경한다. + $faxModel = new FaxModel(); + $faxModel->updateAddress($atcl_vr_sq, $list['address_code'], $data['address2'] ?? '', $data['address3'] ?? '', $data['hscp_no'] ?? '', $data['hscp_nm'] ?? ''); + + return $return; + } + + public function saveModifyVrfc($atcl_vr_sq, $atcl_vrfc_type) + { + + $usr_id = session('usr_id'); + + $list = $this->getDetail($atcl_vr_sq); //변경된 내용 비교를 위해. + + $data['vrfc_type'] = $atcl_vrfc_type; + + $this->db->where('vr_sq', $atcl_vr_sq); + $this->db->trans_start(); + $this->db->update('v2_vrfc_req', $data); + + $data['vrfc_type_cd'] = $atcl_vrfc_type; + //echo $this->db->last_query(); + $return['error_number'] = $this->db->_error_number(); + $return['error_message'] = $this->db->_error_message(); + + if (empty($return['error_number'])) { + // 로그를 남긴다. + if ($this->db->affected_rows() > 0) { + if (!empty($changed)) { + $this->saveChangedHistory($list['data']['vr_sq'], $list['data']['pre_stat_cd'], 'C25', $usr_id, "매물정보 저장"); + } + } + } + $this->db->trans_complete(); + return $return; + } + + /* 현재 상태 확인 */ + public function chkStat($vr_sq) + { + $sql = "SELECT stat_cd FROM v2_vrfc_req WHERE vr_sq = ?"; + $data = array( + $vr_sq + ); + $query = $this->db->query($sql, $data); + return $query->getRowArray(); + } + public function InsCharger($atcl_vr_sq) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_article_info" . + " SET charger = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $usr_id, + $atcl_vr_sq + ); + + $res = $this->db->query($sql, $data); + $log_v = $this->db->getLastQuery(); + log_message('debug', $log_v); + } + + public function chkTryCnt($atcl_vr_sq) + { + // 1차 검증인지 2차 검증인지 확인. + $builder = $this->db->table('v2_vrfc_req'); + $builder->select('try_cnt'); + $builder->where('vr_sq', $atcl_vr_sq); + + $query = $builder->get(); + return $query->getRowArray(); + } + + public function chkConfirm($atcl_vr_sq, $reg_yn = null) + { + // 검증결과 table에 있는지 확인. + $builder = $this->db->table('v2_confirm'); + $builder->select('vr_sq'); + $builder->where('vr_sq', $atcl_vr_sq); + + if ($reg_yn) { + $builder->where('vrfc_type', $reg_yn); // 등기부등본 정보 확인시 + } + + $query = $builder->get(); + return $query->getNumRows(); + } + + public function insertConfirm($vr_sq, $vrfc_type, $success, $type) + { //v2_confirm INSERT + + $usr_sq = session('usr_sq'); + $usr_id = session('usr_id'); + + $sql = "INSERT INTO v2_confirm" . + "(vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm)" . + "VALUES" . + "(?, ?, ?, ?, ?, '" . date('YmdHis') . "', ?, NOW(), ?, NOW())"; + + $data = array( + $vr_sq, + $vrfc_type, + $success, + $type, + $usr_id, + $usr_sq, + $usr_sq + ); + + $this->db->query($sql, $data); + } + + public function updateConfirm($vr_sq, $vrfc_type, $success) + { + $data = [ + 'success' => $success, + 'update_tm' => date('Y-m-d H:i:s') + ]; + + $builder = $this->db->table('v2_confirm'); + $builder->where('vr_sq', $vr_sq); + $builder->where('vrfc_type', $vrfc_type); + $builder->update($data); + + $return = [ + 'error_number' => $this->db->error()['code'], + 'error_message' => $this->db->error()['message'] + ]; + + return $return; + } + + public function chgStat($vr_sq, $stat_cd, $insert_tm) + { + // 상태변경 TABLE INSERT + $usr_sq = session('usr_sq'); + $usr_id = session('usr_id'); + + $list = $this->getDetail($vr_sq); + + $sql = "INSERT INTO v2_chg_stat (vr_sq, stat_cd, insert_user, insert_tm) " . + "VALUES (?, ?, ?, ?) " . + "ON DUPLICATE KEY UPDATE " . + "vr_sq=VALUES(vr_sq), stat_cd=VALUES(stat_cd), insert_user=VALUES(insert_user), insert_tm=VALUES(insert_tm)"; + + $data = [ + $vr_sq, + $stat_cd, + $usr_sq, + $insert_tm + ]; + + $this->db->transStart(); + + $query = $this->db->query($sql, $data); + + $last_query = $this->db->getLastQuery(); + log_message('debug', $last_query); + + $return['error_number'] = $this->db->error()['code']; + $return['error_message'] = $this->db->error()['message']; + + if (empty($return['error_number'])) { + // 로그를 남긴다. + if ($this->db->affectedRows() > 0) { + $changed = $this->whatIsChanged($list, $data, ''); + if (!empty($changed)) { + $this->saveChangedHistory($list['vr_sq'], $stat_cd, 'C9', $usr_id, $changed); + } + } + } + + $this->db->transComplete(); + + return $return; + } + + public function chgStatVrfc($vr_sq, $stat_cd) + { + $data = ['stat_cd' => $stat_cd]; + + $builder = $this->db->table('v2_vrfc_req'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + $last_query = $this->db->getLastQuery(); + log_message('debug', $last_query); + + $return['error_number'] = $this->db->error()['code']; + $return['error_message'] = $this->db->error()['message']; + + return $return; + } + + public function chgStatFax($vr_sq, $stat_cd) + { + $data = ['stat_cd' => $stat_cd]; + + $builder = $this->db->table('fax_imgs'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + $last_query = $this->db->getLastQuery(); + log_message('debug', $last_query); + + $return['error_number'] = $this->db->error()['code']; + $return['error_message'] = $this->db->error()['message']; + + return $return; + } + + public function chgTryCnt($vr_sq, $try_cnt) + { //v2_vrfc_req try_cnt 값 변경. + $sql = "UPDATE v2_vrfc_req" . + " SET try_cnt = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $try_cnt, + $vr_sq + ); + + $this->db->query($sql, $data); + } + + public function insertChkList($vr_sq, $vrfc_type, $type, $code, $comment) + { //v2_check_list INSERT + + $usr_sq = $this->session->userdata('usr_sq'); + + + $sql = "INSERT INTO v2_check_list" . + "(vr_sq, vrfc_type, type, code, comment, insert_user, insert_tm)" . + "VALUES" . + "(?, ?, ?, ?, ?, ?, NOW())" . + " ON DUPLICATE KEY UPDATE" . + " vr_sq=values(vr_sq), vrfc_type=values(vrfc_type), type=values(type), code=values(code), comment=values(comment), insert_user=values(insert_user), insert_tm=values(insert_tm)"; + + $data = array( + $vr_sq, + $vrfc_type, + $type, + $code, + $comment, + $usr_sq + ); + + $this->db->query($sql, $data); + } + + /** + * 검증결과 전송 API를 위한 데이터 조회.. + */ + public function getDataConfirmAPI($vr_sq) + { + // 요청정보 + $sql = "SELECT vr_sq, atcl_no, step, cpid, cp_atcl_id, trade_type, realtor_nm, realtor_tel_no, seller_tel_no, vrfc_type, rgbk_confirm, req_type, rdate, stat_cd, try_cnt, insert_user, insert_tm" . + " FROM v2_vrfc_req WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_vrfc_req = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 매물정보 + $sql = "SELECT vr_sq, atcl_no, cpid, cp_atcl_id, rlet_type_cd, trade_type, address_code, address1, address2, address3, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sise, floor, rdate, seller_tel_no, seller_nm, realtor_nm, realtor_tel_no, hscp_no, hscp_nm, ptp_no, ptp_nm, charger, req_price_yn, reg_charger, dept1_sq, dept2_sq, reg_dept1_sq, reg_dept2_sq, floor2" . + " FROM v2_article_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 수정정보 + $sql = "SELECT vr_sq, bild_nm, rm_no, floor, address_code, address2, address3, address4, trade_type, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, hscp_no, hscp_nm, ptp_no, ptp_nm, modify_yn, floor2 FROM v2_modify_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_modify_info = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 검증결과 + $sql = "SELECT vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm, work_type" . + " FROM v2_confirm WHERE vr_sq = ? AND vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $row_confirm = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 확인정보 + $sql = "SELECT type, code, comment, ownerNm, ownerBirth FROM v2_check_list WHERE vr_sq = ? AND vrfc_type = ? AND type LIKE CONCAT(vrfc_type, '%')"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $res_check_list = $query->getResultArray(); + + log_message('debug', $this->db->getLastQuery()); + + log_message('debug', implode(', ', $row_confirm)); + + $atclNo = $row_vrfc_req['atcl_no']; + $success = empty($row_confirm['success']) ? false : true; + $charger = $row_confirm['charger']; + $date = $row_confirm['date']; + $try_cnt = $row_vrfc_req['try_cnt']; + + $checkList = []; + foreach ($res_check_list as $row) { + $checkList[] = [ + 'type' => $row['type'], + 'code' => $row['code'], + 'comment' => $row['comment'], + 'ownerNm' => $row['ownerNm'], + 'ownerBirth' => $row['ownerBirth'], + ]; + } + + $modifyInfo = []; + if ($row_modify_info['modify_yn'] === 'Y') { + if (!empty($row_modify_info['hscp_no'])) { + // 공동주택 + $modifyInfo = [ + 'hscpNo' => $row_modify_info['hscp_no'], + 'ptpNo' => $row_modify_info['ptp_no'], + 'bildNm' => $row_modify_info['address2'], + 'rmNo' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'isaleAmt' => $row_modify_info['isale_amt'], + 'premAmt' => $row_modify_info['prem_amt'], + 'floor' => $row_modify_info['floor'], + ]; + } else { + // 비공동주택 + $modifyInfo = [ + 'addressCode' => $row_modify_info['address_code'], + 'address2' => $row_modify_info['address2'], + 'address3' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'splySpc' => $row_modify_info['sply_spc'], + 'exclsSpc' => $row_modify_info['excls_spc'], + 'totSpc' => $row_modify_info['tot_spc'], + 'grndSpc' => $row_modify_info['grnd_spc'], + 'bldgSpc' => $row_modify_info['bldg_spc'], + 'floor' => $row_modify_info['floor'], + 'floor2' => $row_modify_info['floor2'], + ]; + } + + return [ + 'atclNo' => $atclNo, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'modifyInfo' => $modifyInfo, + 'date' => $date, + 'try_cnt' => $try_cnt, + ]; + } else { + return [ + 'atclNo' => $atclNo, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'date' => $date, + 'try_cnt' => $try_cnt, + ]; + } + } + + public function InsResChar($atcl_vr_sq) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_article_info" . + " SET reg_charger = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $usr_id, + $atcl_vr_sq + ); + $res = $this->db->query($sql, $data); + $log_v = $this->db->getLastQuery(); + log_message('debug', $log_v); + } + + public function chkRegiTryCnt($atcl_vr_sq) + { + // 1차 검증인지 2차 검증인지 확인. + $builder = $this->db->table('v2_vrfc_req'); + $builder->select('reg_try_cnt'); + $builder->where('vr_sq', $atcl_vr_sq); + + $query = $builder->get(); + + $last_query = $this->db->getLastQuery(); + log_message('debug', $last_query); + + return $query->getRowArray(); + } + + /* 등기부등본 API 호출*/ + public function getDatacertAPI($vr_sq, $vrfc_type = '') + { + // 요청정보 + $sql = "SELECT vr_sq, atcl_no, step, cpid, cp_atcl_id, trade_type, realtor_nm, realtor_tel_no, seller_tel_no, vrfc_type, rgbk_confirm, req_type, rdate, stat_cd, try_cnt, insert_user, insert_tm, owner_verifiable" . + " FROM v2_vrfc_req WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_vrfc_req = $query->getRowArray(); + + if (!empty($vrfc_type)) { + $row_vrfc_req['vrfc_type'] = $vrfc_type; + } + + log_message('debug', $this->db->getLastQuery()); + + // 매물정보 + $sql = "SELECT vr_sq, atcl_no, cpid, cp_atcl_id, rlet_type_cd, trade_type, address_code, address1, address2, address3, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sise, floor, rdate, seller_tel_no, seller_nm, realtor_nm, realtor_tel_no, hscp_no, hscp_nm, ptp_no, ptp_nm, charger, req_price_yn, reg_charger, dept1_sq, dept2_sq, reg_dept1_sq, reg_dept2_sq, floor2" . + " FROM v2_article_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 수정정보 + $sql = "SELECT vr_sq, bild_nm, rm_no, floor, address_code, address2, address3, trade_type, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, hscp_no, hscp_nm, ptp_no, ptp_nm, modify_yn, floor2" . + " FROM v2_modify_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_modify_info = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 검증결과 + $sql = "SELECT vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm, work_type" . + " FROM v2_confirm WHERE vr_sq = ? AND vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $row_confirm = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 확인정보 + $sql = "SELECT a.type, a.code, a.comment, b.ownerNm, b.owner_birth" . + " FROM v2_check_list a " . + " INNER JOIN v2_article_info b ON a.vr_sq = b.vr_sq" . + " WHERE a.vr_sq = ? AND a.vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $res_check_list = $query->getResultArray(); + + log_message('debug', $this->db->getLastQuery()); + + log_message('debug', implode(', ', $row_confirm)); + + $atclNo = $row_vrfc_req['atcl_no']; + $type = $row_vrfc_req['try_cnt']; + $success = empty($row_confirm['success']) ? false : true; + $charger = $row_confirm['charger']; + $date = $row_confirm['date']; + $ownerVerifiable = ($row_vrfc_req['owner_verifiable'] === 'false') ? false : true; + + $checkList = []; + foreach ($res_check_list as $row) { + $checkList[] = [ + 'type' => $row['type'], + 'code' => $row['code'], + 'comment' => $row['comment'], + 'ownerNm' => $row['ownerNm'], + 'ownerBirth' => $row['owner_birth'], + ]; + } + + $modifyInfo = []; + if ($row_modify_info['modify_yn'] === 'Y') { + if (!empty($row_modify_info['hscp_no'])) { + // 공동주택 + $modifyInfo = [ + 'hscpNo' => $row_modify_info['hscp_no'], + 'ptpNo' => $row_modify_info['ptp_no'], + 'bildNm' => $row_modify_info['address2'], + 'rmNo' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'isaleAmt' => $row_modify_info['isale_amt'], + 'premAmt' => $row_modify_info['prem_amt'], + 'floor' => $row_modify_info['floor'], + ]; + } else { + // 비공동주택 + $modifyInfo = [ + 'addressCode' => $row_modify_info['address_code'], + 'address2' => $row_modify_info['address2'], + 'address3' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'splySpc' => $row_modify_info['sply_spc'], + 'exclsSpc' => $row_modify_info['excls_spc'], + 'totSpc' => $row_modify_info['tot_spc'], + 'grndSpc' => $row_modify_info['grnd_spc'], + 'bldgSpc' => $row_modify_info['bldg_spc'], + 'floor' => $row_modify_info['floor'], + 'floor2' => $row_modify_info['floor2'], + ]; + } + + return [ + 'atclNo' => $atclNo, + 'type' => $type, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'modifyInfo' => $modifyInfo, + 'date' => $date, + 'ownerVerifiable' => $ownerVerifiable, + ]; + } else { + return [ + 'atclNo' => $atclNo, + 'type' => $type, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'date' => $date, + 'ownerVerifiable' => $ownerVerifiable, + ]; + } + } + + // 메모저장 + public function saveMemo($data) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_vrfc_req SET + memo = ? + WHERE vr_sq = ?"; + + if ($this->db->query($sql, $data) === false) { + return [ + 'success' => false, + 'msg' => '파일정보 저장 실패', + ]; + } + + $row = $this->getDetail($data[1]); + + $memo = "메모변경 : " . $row['memo'] . " => " . $data[0]; + $this->saveChangedHistory($data[1], $row['pre_stat_cd'], 'C19', $usr_id, $memo); + + return [ + 'success' => true + ]; + } + + public function saveApiErr($err_sq, $err_code, $err_nm, $err_time, $err_no, $err_server = '') + { + + $sql = "INSERT INTO err_api (err_sq, err_code, err_nm, err_time, err_no, err_server)" . + " VALUES (?, ?, ?, ?, ?, ?);"; + + $data = array( + $err_sq, + $err_code, + $err_nm, + $err_time, + $err_no, + $err_server + ); + $this->db->query($sql, $data); + } + + // 정보변경 이력 저장 + public function saveChangedHistory($vr_sq, $stat_cd, $chg_type, $usr_id, $memo) + { + $sql = "INSERT INTO v2_chg_history" . + " (vr_sq, stat_cd, chg_type, insert_id, insert_tm, memo)" . + " VALUES" . + " (?, ?, ?, ?, now(), ?)"; + + $data = [ + $vr_sq, + $stat_cd, + $chg_type, + $usr_id, + $memo + ]; + + $res = $this->db->query($sql, $data); + } + // 변경이력 조회 public function getHistory($id) { diff --git a/app/Views/pages/v2/m701/detail.php b/app/Views/pages/v2/m701/detail.php index 8e11f44..7e8f88d 100644 --- a/app/Views/pages/v2/m701/detail.php +++ b/app/Views/pages/v2/m701/detail.php @@ -2309,7 +2309,7 @@ if (!empty($data['cert_register']) && $data['cert_register_save_yn'] != 'Y') { / success: function (result) { if (result.code == '0') { - location.replace('/board/notice/lists') + location.reload(); } else { Swal.fire({ title: result.msg, diff --git a/app/Views/pages/v2/m702/detail.php b/app/Views/pages/v2/m702/detail.php index 3eee2ce..5906631 100644 --- a/app/Views/pages/v2/m702/detail.php +++ b/app/Views/pages/v2/m702/detail.php @@ -1853,7 +1853,125 @@ if (!empty($data['cert_register']) && $data['cert_register_save_yn'] != 'Y') { / // 서류확인정보 저장 function saveDocu() { + var frm = document.rcptFrm; + if (frm.fax_conf_res_d11.value == "") { + Swal.fire("확인여부를 선택해주세요"); + frm.fax_conf_res_d11.focus(); + return false; + } + + var chValue = ""; + var i = 1; + for (i = 1; i <= 14; i++) { + if ($('#ch' + i).is(':checked') == true) { + chValue = chValue + "|Y"; + } else { + chValue = chValue + "|N"; + } + } + //alert(chValue); + chValue = chValue.substr(1); + $('#chTotal').val(chValue); + + if (frm.fax_conf_yn_2.value == "") { + Swal.fire("매물주소 정보확인 결과를 선택해주세요"); + frm.fax_conf_yn_2.focus(); + return false; + } + + if (frm.fax_conf_yn_3.value == "") { + Swal.fire("가격 거래구분 정보확인 결과를 선택해주세요"); + frm.fax_conf_yn_3.focus(); + return false; + } + + if (frm.fax_conf_yn_4.value == "") { + Swal.fire("의뢰인 정보확인 결과를 선택해주세요"); + frm.fax_conf_yn_4.focus(); + return false; + } + + if (frm.fax_conf_yn_2.value == "20000") { + if (frm.fax_conf_yn_info_2.value == "") { + Swal.fire("매물주소 불일치에 대한 상세내용을 작성해주세요"); + frm.fax_conf_yn_info_2.focus(); + return false; + } + } + + if (frm.fax_conf_yn_3.value == "20000") { + if (frm.fax_conf_yn_info_3.value == "") { + Swal.fire("가격 거래구분 불일치에 대한 상세내용을 작성해주세요"); + frm.fax_conf_yn_info_3.focus(); + return false; + } + } + + if (frm.fax_conf_yn_4.value == "20000") { + if (frm.fax_conf_yn_info_4.value == "") { + Swal.fire("의뢰인정보 불일치에 대한 상세내용을 작성해주세요"); + frm.fax_conf_yn_info_4.focus(); + return false; + } + } + + swal.fire({ + text: "저장 하시겠습니까?", + type: "warning", + showCancelButton: true, + confirmButtonText: "예", + cancelButtonText: "아니오", + closeOnConfirm: false, + closeOnCancel: true, + confirmButtonColor: "#3085d6", + cancelButtonColor: "#d33", + }).then((result) => { + if (result.isConfirmed) { + $.ajax({ + url: '/m702/m702a/saveDocu', + method: 'POST', + data: new FormData($("#rcptFrm")[0]), + processData: false, + contentType: false, + beforeSend: function () { + blockUI.blockPage({ + message: tpl + }) + }, + complete: function () { + blockUI.unblockPage() + }, + error: function (xhr, error, thrown) { + blockUI.unblockPage() + var msg = ""; + if (xhr.responseText != null) { + msg = xhr.responseText + } else { + msg = "잠시후 다시 시도해 주세요." + } + + Swal.fire({ + title: msg, + icon: "error", + draggable: true + }) + }, + success: function (result) { + + if (result.code == '0') { + location.reload(); + } else { + Swal.fire({ + title: result.msg, + icon: "error", + draggable: true + }) + } + } + }); + } + }); } diff --git a/app/Views/pages/v2/m704/detail.php b/app/Views/pages/v2/m704/detail.php index 829d82a..8d1d3d5 100644 --- a/app/Views/pages/v2/m704/detail.php +++ b/app/Views/pages/v2/m704/detail.php @@ -274,11 +274,16 @@ if (!empty($regist2)) { 단지명 - + value="" /> + 가격 diff --git a/app/Views/pages/v2/m706/detail.php b/app/Views/pages/v2/m706/detail.php index 3b630d4..2c2f170 100644 --- a/app/Views/pages/v2/m706/detail.php +++ b/app/Views/pages/v2/m706/detail.php @@ -88,1058 +88,1071 @@ if (!empty($list['cert_register']) && $list['cert_register_save_yn'] != 'Y') { / -
-
-
-
-

-

- - - - - - - - - - - - - -
매물ID : - CP ID : 현재 상태 - :
-

-
-
-
공인 중개사 정보
- - - - - - - - - - - - - - -
중개사명대표전화
-
-
- - -
-
-
매물 정보
-
- + + + + + + " /> +
+
+
+
+

+

+
+ + + + + + + + + + + + +
매물ID : + CP ID : 현재 상태 + :
+

+
+
+
공인 중개사 정보
+ - - - - + + + + + + + + + + + + +
중개사명대표전화
+
+
+ + +
+
+
매물 정보
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
등록일 + + 전화/서류 완료일시 + + +
등기부등본 확인완료 + + 의뢰인(매도자) + + *** + + + +
매물구분 + + 거래구분 +
+ + + + + +
+
지역구분 + + 리 주소 + +
상세주소 + + + + + + + + +
기타주소 + +
단지명 + + + 가격 + + + + + + + + +
평형 + + + + + + + 층 / 총층 +
+ + / + +
+
공급면적 + + + + 전용면적 + + + +
+
+
+ + + + +
+ + + - - - - -
- - - - - - - -
-
-
등기부등본확인 정보
- - - - - - - - - - - - - + - - - + + + + - - + + + + - -
-
-
정보변경 이력
-
-
- - - -
- -
- - Image - - - Image - - -

- - - -
- -
- - Image - - - Image - - -

- - - - - - -
- Image -
- + - -
- - - - - + - - - - '; + } - - - = 35 && intval($data['stat_cd']) != 39) && intval($data['stat_cd']) != 49 + if (in_array($key, $checks)) { + $check = TRUE; + } else { + $check = FALSE; + } - ): ?> -
- + ?> +
- - - - - -
- = 35 && intval($data['stat_cd']) != 39) && intval($data['stat_cd']) != 49 + - ): ?> + 0) { ?> +
+ +
확인담당자 - + + + + + + + - - - - - - - - - - - - - - - - - - - + - + + + + + + - - - - + + - - -
확인내용 - -
매물주소 - - -
의뢰인정보 - - -
소유자명 확인확인담당자관리자
확인여부 - - - + + + + +
메모 - - +
홍보확인서
미확인여부상세
+ + + 'font-weight:normal;', + ]; - - + $nCnt = 0; + $code_comment = []; + foreach ($codes as $c) { + if ($c['category'] === "CONSULTANT_COMMENT") { + array_push($code_comment, $c); + } + } - -
-
- -
+
+ + +
+
+
확인 내용 + +
매물주소 + + +
- - - - - - - - - - - - - - - + + + + - - + + + + + + + + + + +
진행상태변경내용처리자(ID)처리일시세부내용
가격 거래구분 + + +
의뢰인정보 + + +
메모 + + +
+ + +
+
-
+ + + +
+
+
등기부등본확인 정보
+ + + + + + + + + + + + + + + + +
+ + + +
+ +
+ + Image + + + Image + + +

+ + + +
+ +
+ + Image + + + Image + + +

+ + + + + + +
+ Image +
+ + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
확인담당자 + + + +
확인내용 + +
매물주소 + + +
의뢰인정보 + + +
메모 + + + + +
+
+
+ +
+ + +
+
+
정보변경 이력
+
+ + + + + + + + + + + + + + + + + + + +
진행상태변경내용처리자(ID)처리일시세부내용
+
+
+
+ +
- + endSection() ?> \ No newline at end of file