Files
confirms/app/Models/v2/M712Model.php
yangsh 5079e2e212
Some checks failed
Close Pull Request / main (pull_request_target) Has been cancelled
상세수정
2026-01-13 12:31:12 +09:00

928 lines
34 KiB
PHP

<?php
namespace App\Models\v2;
use CodeIgniter\Model;
class M712Model extends Model
{
// 지역 목록 조회
public function getAreaList($sido = '', $gugun = '')
{
if (!empty($gugun)) {
$gugun = substr($gugun, '0', '5');
$sql = "SELECT a.region_cd, TRIM(REPLACE(a.region_nm, b.region_nm, '')) region_nm" .
" FROM region_codes a" .
" LEFT JOIN region_codes b ON b.region_cd = CONCAT(SUBSTR(a.region_cd,1,5),'00000')" .
" WHERE a.region_cd LIKE concat(?, '%')" .
" AND a.region_cd NOT LIKE '%00000'" .
" AND a.region_cd LIKE '%00'" .
" AND a.use_yn = 'Y'" .
" ORDER BY a.region_nm ASC";
$query = $this->db->query($sql, [$gugun]);
} else if (!empty($sido)) {
$chk_sido = substr($sido, '0', '2');
if ($chk_sido === '36') {
$sido = substr($sido, '0', '4');
$sql = "SELECT a.region_cd, TRIM(REPLACE(a.region_nm, b.region_nm, '')) region_nm " .
"FROM region_codes a " .
"LEFT JOIN region_codes b ON b.region_cd = CONCAT(SUBSTR(a.region_cd,1,4),'000000') " .
"WHERE a.region_cd LIKE concat(?, '%') " .
"AND a.region_cd NOT LIKE '%000000' " .
"AND a.region_cd LIKE '%00' " .
"AND a.use_yn = 'Y' " .
"AND EXISTS (SELECT 'x' FROM region_codes c WHERE c.region_cd LIKE CONCAT(SUBSTR(a.region_cd,1,5),'%') AND c.region_cd > CONCAT(SUBSTR(a.region_cd,1,5),'00000')) " .
"ORDER BY a.region_nm ASC";
} else {
$sido = substr($sido, '0', '2');
$sql = "SELECT a.region_cd, TRIM(REPLACE(a.region_nm, b.region_nm, '')) region_nm" .
" FROM region_codes a" .
" LEFT JOIN region_codes b ON b.region_cd = CONCAT(SUBSTR(a.region_cd,1,2),'00000000')" .
" WHERE a.region_cd LIKE concat(?, '%')" .
" AND a.region_cd NOT LIKE '%00000000'" .
" AND a.region_cd LIKE '%00000'" .
" AND a.use_yn = 'Y'" .
" AND EXISTS (SELECT 'x' FROM region_codes c WHERE c.region_cd LIKE CONCAT(SUBSTR(a.region_cd,1,5),'%') AND c.region_cd > CONCAT(SUBSTR(a.region_cd,1,5),'00000'))" .
" ORDER BY a.region_nm ASC";
}
$query = $this->db->query($sql, [$sido]);
} else {
$sql = "SELECT a.region_cd, a.region_nm " .
"FROM region_codes a " .
"WHERE (a.region_cd LIKE '%00000000' " .
"AND a.use_yn = 'Y') " .
"OR region_cd = 3611000000;";
$query = $this->db->query($sql);
}
return $query->getResultArray();
}
// 소속본부조회
public function getBonbuList()
{
$sql = "SELECT dept_sq, pdept_sq, dept_nm, dept_desc, dept_head, use_yn, depth, insert_tm, insert_usr, update_tm, update_usr, lft, rgt" .
" FROM departments" .
" WHERE depth = 1" .
" AND use_yn = 'Y'" .
" ORDER BY lft";
$query = $this->db->query($sql);
return $query->getResultArray();
}
// 소속팀 조회
public function getTeamList()
{
$sql = "SELECT dept_sq, pdept_sq, dept_nm" .
" FROM departments" .
" WHERE depth = 2" .
" AND use_yn = 'Y'" .
" ORDER BY dept_nm";
$query = $this->db->query($sql);
return $query->getResultArray();
}
// 유저 조회
public function getUserList()
{
$sql = "SELECT
a.usr_sq, a.usr_id, a.usr_nm, a.dept_sq
FROM users a
WHERE
a.usr_level IN ('3','4','40','5','50','6','60','61','62','7','8','70')
AND a.use_yn = 'Y'
AND EXISTS (
SELECT 'x' FROM departments a1 INNER JOIN departments a2 ON a2.lft BETWEEN a1.lft AND a1.rgt AND a2.use_yn = 'Y'
WHERE 1=1 AND a2.dept_sq = a.dept_sq AND a1.use_yn = 'Y'
)
ORDER BY a.usr_level DESC, a.usr_nm ASC ";
$query = $this->db->query($sql);
return $query->getResultArray();
}
public function getTotalCount($data)
{
$sql = "SELECT
COUNT(*) AS cnt
FROM v2_article_info a
LEFT JOIN v2_article_info_etc b ON a.vr_sq = b.vr_sq
LEFT JOIN v2_vrfc_req c ON a.vr_sq = c.vr_sq
LEFT JOIN v2_modify_info m ON a.vr_sq = m.vr_sq
LEFT JOIN v2_chg_stat s45 ON a.vr_sq = s45.vr_sq AND s45.stat_cd = '45'
LEFT JOIN v2_chg_stat s49 ON a.vr_sq = s49.vr_sq AND s49.stat_cd = '49'
LEFT JOIN v2_chg_stat s60 ON a.vr_sq = s60.vr_sq AND s60.stat_cd = '60'
LEFT JOIN v2_chg_stat s39 ON a.vr_sq = s39.vr_sq AND s39.stat_cd = '39'
LEFT JOIN v2_check_list c21 ON a.vr_sq = c21.vr_sq AND c21.type = '21'
LEFT JOIN v2_check_list c22 ON a.vr_sq = c22.vr_sq AND c22.type = '22'
WHERE
c.vrfc_type = 'N' ";
// 매물번호
if (!empty($data['atcl_no'])) {
$sql .= "AND a.atcl = '{$data['atcl_no']}' ";
} else {
// 접수기간
if (!empty($data['receipt_sdate'])) {
$sql .= "AND c.insert_tm >= '{$data['receipt_sdate']} 00:00:00' ";
}
if (!empty($data['receipt_edate'])) {
$sql .= "AND c.insert_tm <= '{$data['receipt_edate']} 23:59:59' ";
}
// 완료기간
if (!empty($data['complete_sdate'])) {
$sql .= "AND s60.insert_tm >= '{$data['complete_sdate']} 00:00:00' ";
}
if (!empty($data['complete_edate'])) {
$sql .= "AND s60.insert_tm <= '{$data['complete_edate']} 23:59:59' ";
}
// 지역구분
if (!empty($data['srcDong'])) {
$sql .= "AND a.address_code = '{$data['srcDong']}' ";
} else {
if (!empty($data['srcGugun'])) {
$str_gugun = substr($data['srcGugun'], '0', '2');
if ($str_gugun == '36') { //세종시는 군구가 없고 바로 동이라서 예외
$sql .= "AND a.address_code = '{$data['srcGugun']}' ";
} else {
$gugunPrefix = substr($data['srcGugun'], '0', '5');
$sql .= "AND a.address_code LIKE '{$gugunPrefix}%' ";
}
} else {
if (!empty($data['srcSido'])) {
$sidoPrefix = substr($data['srcSido'], '0', '2');
$sql .= "AND a.address_code LIKE '{$sidoPrefix}%' ";
}
}
}
// 매체사
if (!empty($data['rcpt_cpid'])) {
$sql .= "AND a.cpid = '{$data['rcpt_cpid']}' ";
}
// 참고파일
if (!empty($data['reference_file_url_yn'])) {
$sql .= "AND a.reference_file_url_yn = '{$data['a.reference_file_url_yn']}' ";
}
// 현재상태
if (!empty($data['stat_cd'])) {
$sql .= "AND c.stat_cd = '{$data['stat_cd']}' ";
}
// 중개소
if (!empty($data['realtor_nm'])) {
$sql .= "AND a.realtor_nm = '{$data['realtor_nm']}' ";
}
// 담당자
if (!empty($data['damdang'])) {
switch ($data['charger_gbn']) {
case "1":
$sql .= "a.charger = '{$data['damdang']}' ";
break;
case "2":
$sql .= "a.reg_charger = '{$data['damdang']}' ";
break;
}
} else {
// 배정여부
if ($data['assign_yn'] !== "A") {
switch ($data['charger_gbn'] . $data['assign_yn']) {
case "1Y": // 전화/서류 담당자
$sql .= "a.charger != '' ";
break;
case "1N": // 전화/서류 담당자
$sql .= "a.charger = '' ";
break;
case "2Y": // 등기부등본 담당자
$sql .= "a.reg_charger != '' ";
break;
case "2N": // 등기부등본 담당자
$sql .= "a.reg_charger IS NULL ";
break;
}
}
}
// 매물종류
if (!empty($data['rlet_type_cd'])) {
$sql .= "AND a.rlet_type_cd = '{$data['rlet_type_cd']}' ";
}
// 소유자구분
if (!empty($data['ownerTypeCode'])) {
$sql .= "AND b.ownerTypeCode = '{$data['ownerTypeCode']}' ";
}
// 서류미수취
if (!empty($data['document_not_received_yn'])) {
$sql .= "AND b.document_not_received_yn = '{$data['document_not_received_yn']}' ";
}
}
$query = $this->db->query($sql);
return $query->getRow()->cnt;
}
public function getResultList($start, $end, $data)
{
$sql = "SELECT
a.vr_sq,
a.atcl_no,
(SELECT cd_nm FROM codes d WHERE d.cd = c.stat_cd AND d.category = 'STEP_VERIFICATION' ) AS pre_stat ,
c.insert_tm,
(
case b.ownerTypeCode
when '0' then '개인'
when '1' then '법인'
when '2' then '외국인'
when '3' then '위임장'
ELSE ''
END
) AS ownerTypeCodeNm,
b.ownerTypeCode ,
a.address_code,
(SELECT cd_nm FROM codes d WHERE d.cd = c.vrfc_type AND d.category = 'VRFCREQ_WAY' ) AS vrfc_type ,
CONCAT ( (SELECT region_nm FROM region_codes r WHERE a.address_code = r.region_cd ) , ' ' , ifnull(m.rm_no,'') ) AS address ,
(
case IFNULL(b.address2b , '')
when '' then CONCAT(ifnull(a.address2,'') , ' ' , ifnull(a.address3,''))
ELSE CONCAT(ifnull(b.address2b,'') , ' ' , ifnull(a.address3,''))
END
) AS address_ext,
a.cpid,
a.realtor_nm,
(SELECT usr_nm FROM users u WHERE a.charger = u.usr_id) AS usr_nm ,
(SELECT usr_nm FROM users u WHERE a.reg_charger = u.usr_id) AS reg_charger ,
greatest(ifnull(s45.insert_tm,''),ifnull(s49.insert_tm,'') ) AS rgbk_check_tm,
s60.insert_tm AS result_tm,
s39.insert_tm as stat_39_tm,
c21.comment AS reg_conf_yn_info_2,
c22.comment AS reg_conf_yn_info_3,
a.reg_charger as rc
FROM v2_article_info a
LEFT JOIN v2_article_info_etc b ON a.vr_sq = b.vr_sq
LEFT JOIN v2_vrfc_req c ON a.vr_sq = c.vr_sq
LEFT JOIN v2_modify_info m ON a.vr_sq = m.vr_sq
LEFT JOIN v2_chg_stat s45 ON a.vr_sq = s45.vr_sq AND s45.stat_cd = '45'
LEFT JOIN v2_chg_stat s49 ON a.vr_sq = s49.vr_sq AND s49.stat_cd = '49'
LEFT JOIN v2_chg_stat s60 ON a.vr_sq = s60.vr_sq AND s60.stat_cd = '60'
LEFT JOIN v2_chg_stat s39 ON a.vr_sq = s39.vr_sq AND s39.stat_cd = '39'
LEFT JOIN v2_check_list c21 ON a.vr_sq = c21.vr_sq AND c21.type = '21'
LEFT JOIN v2_check_list c22 ON a.vr_sq = c22.vr_sq AND c22.type = '22'
WHERE
c.vrfc_type = 'N' ";
// 매물번호
if (!empty($data['atcl_no'])) {
$sql .= "AND a.atcl = '{$data['atcl_no']}' ";
} else {
// 접수기간
if (!empty($data['receipt_sdate'])) {
$sql .= "AND c.insert_tm >= '{$data['receipt_sdate']} 00:00:00' ";
}
if (!empty($data['receipt_edate'])) {
$sql .= "AND c.insert_tm <= '{$data['receipt_edate']} 23:59:59' ";
}
// 완료기간
if (!empty($data['complete_sdate'])) {
$sql .= "AND s60.insert_tm >= '{$data['complete_sdate']} 00:00:00' ";
}
if (!empty($data['complete_edate'])) {
$sql .= "AND s60.insert_tm <= '{$data['complete_edate']} 23:59:59' ";
}
// 지역구분
if (!empty($data['srcDong'])) {
$sql .= "AND a.address_code = '{$data['srcDong']}' ";
} else {
if (!empty($data['srcGugun'])) {
$str_gugun = substr($data['srcGugun'], '0', '2');
if ($str_gugun == '36') { //세종시는 군구가 없고 바로 동이라서 예외
$sql .= "AND a.address_code = '{$data['srcGugun']}' ";
} else {
$gugunPrefix = substr($data['srcGugun'], '0', '5');
$sql .= "AND a.address_code LIKE '{$gugunPrefix}%' ";
}
} else {
if (!empty($data['srcSido'])) {
$sidoPrefix = substr($data['srcSido'], '0', '2');
$sql .= "AND a.address_code LIKE '{$sidoPrefix}%' ";
}
}
}
// 매체사
if (!empty($data['rcpt_cpid'])) {
$sql .= "AND a.cpid = '{$data['rcpt_cpid']}' ";
}
// 참고파일
if (!empty($data['reference_file_url_yn'])) {
$sql .= "AND a.reference_file_url_yn = '{$data['a.reference_file_url_yn']}' ";
}
// 현재상태
if (!empty($data['stat_cd'])) {
$sql .= "AND c.stat_cd = '{$data['stat_cd']}' ";
}
// 중개소
if (!empty($data['realtor_nm'])) {
$sql .= "AND a.realtor_nm = '{$data['realtor_nm']}' ";
}
// 담당자
if (!empty($data['damdang'])) {
switch ($data['charger_gbn']) {
case "1":
$sql .= "a.charger = '{$data['damdang']}' ";
break;
case "2":
$sql .= "a.reg_charger = '{$data['damdang']}' ";
break;
}
} else {
// 배정여부
if ($data['assign_yn'] !== "A") {
switch ($data['charger_gbn'] . $data['assign_yn']) {
case "1Y": // 전화/서류 담당자
$sql .= "a.charger != '' ";
break;
case "1N": // 전화/서류 담당자
$sql .= "a.charger = '' ";
break;
case "2Y": // 등기부등본 담당자
$sql .= "a.reg_charger != '' ";
break;
case "2N": // 등기부등본 담당자
$sql .= "a.reg_charger IS NULL ";
break;
}
}
}
// 매물종류
if (!empty($data['rlet_type_cd'])) {
$sql .= "AND a.rlet_type_cd = '{$data['rlet_type_cd']}' ";
}
// 소유자구분
if (!empty($data['ownerTypeCode'])) {
$sql .= "AND b.ownerTypeCode = '{$data['ownerTypeCode']}' ";
}
// 서류미수취
if (!empty($data['document_not_received_yn'])) {
$sql .= "AND b.document_not_received_yn = '{$data['document_not_received_yn']}' ";
}
}
$sql .= "ORDER BY a.vr_sq DESC ";
$sql .= "LIMIT {$start}, {$end}";
$query = $this->db->query($sql);
return $query->getResultArray();
}
// 엑셀다운로드
public function getExcelList($data)
{
$sql = "SELECT
a.atcl_no AS '매물번호',
(SELECT cd_nm FROM codes d WHERE d.cd = c.stat_cd AND d.category = 'STEP_VERIFICATION' ) AS '진행상태',
c.insert_tm AS '접수시간',
(SELECT cd_nm FROM codes d WHERE d.cd = c.vrfc_type AND d.category = 'VRFCREQ_WAY' ) AS '검증방식',
CONCAT ( (SELECT region_nm FROM region_codes r WHERE a.address_code = r.region_cd ) , ' ' , ifnull(m.rm_no,'') ) AS '주소',
CONCAT ( (SELECT region_nm FROM region_codes r WHERE a.address_code = r.region_cd ) , ' ' , ifnull(m.rm_no,'') ) AS address ,
(
case IFNULL(b.address2b , '')
when '' then CONCAT(ifnull(a.address2,'') , ' ' , ifnull(a.address3,''))
ELSE CONCAT(ifnull(b.address2b,'') , ' ' , ifnull(a.address3,''))
END
) AS '상세주소',
a.cpid AS '매체사',
a.realtor_nm AS '중개소',
(SELECT usr_nm FROM users u WHERE a.charger = u.usr_id) AS '서류/전화 담당자',
s39.insert_tm AS '서류/전화 확인완료시간',
a.reg_charger AS '등기부등본 담당자',
greatest(ifnull(s45.insert_tm,''),ifnull(s49.insert_tm,'') ) AS '등기부등본 확인시간',
s60.insert_tm AS '검증완료 일시',
c21.comment AS '주소 불일치 사유',
c22.comment '의뢰인 불일치 사유'
FROM v2_article_info a
LEFT JOIN v2_article_info_etc b ON a.vr_sq = b.vr_sq
LEFT JOIN v2_vrfc_req c ON a.vr_sq = c.vr_sq
LEFT JOIN v2_modify_info m ON a.vr_sq = m.vr_sq
LEFT JOIN v2_chg_stat s45 ON a.vr_sq = s45.vr_sq AND s45.stat_cd = '45'
LEFT JOIN v2_chg_stat s49 ON a.vr_sq = s49.vr_sq AND s49.stat_cd = '49'
LEFT JOIN v2_chg_stat s60 ON a.vr_sq = s60.vr_sq AND s60.stat_cd = '60'
LEFT JOIN v2_chg_stat s39 ON a.vr_sq = s39.vr_sq AND s39.stat_cd = '39'
LEFT JOIN v2_check_list c21 ON a.vr_sq = c21.vr_sq AND c21.type = '21'
LEFT JOIN v2_check_list c22 ON a.vr_sq = c22.vr_sq AND c22.type = '22'
WHERE
c.vrfc_type = 'N'";
// 매물번호
if (!empty($data['atcl_no'])) {
$sql .= "AND a.atcl = '{$data['atcl_no']}' ";
} else {
// 접수기간
if (!empty($data['receipt_sdate'])) {
$sql .= "AND c.insert_tm >= '{$data['receipt_sdate']} 00:00:00' ";
}
if (!empty($data['receipt_edate'])) {
$sql .= "AND c.insert_tm <= '{$data['receipt_edate']} 23:59:59' ";
}
// 완료기간
if (!empty($data['complete_sdate'])) {
$sql .= "AND s60.insert_tm >= '{$data['complete_sdate']} 00:00:00' ";
}
if (!empty($data['complete_edate'])) {
$sql .= "AND s60.insert_tm <= '{$data['complete_edate']} 23:59:59' ";
}
// 지역구분
if (!empty($data['srcDong'])) {
$sql .= "AND a.address_code = '{$data['srcDong']}' ";
} else {
if (!empty($data['srcGugun'])) {
$str_gugun = substr($data['srcGugun'], '0', '2');
if ($str_gugun == '36') { //세종시는 군구가 없고 바로 동이라서 예외
$sql .= "AND a.address_code = '{$data['srcGugun']}' ";
} else {
$gugunPrefix = substr($data['srcGugun'], '0', '5');
$sql .= "AND a.address_code LIKE '{$gugunPrefix}%' ";
}
} else {
if (!empty($data['srcSido'])) {
$sidoPrefix = substr($data['srcSido'], '0', '2');
$sql .= "AND a.address_code LIKE '{$sidoPrefix}%' ";
}
}
}
// 매체사
if (!empty($data['rcpt_cpid'])) {
$sql .= "AND a.cpid = '{$data['rcpt_cpid']}' ";
}
// 참고파일
if (!empty($data['reference_file_url_yn'])) {
$sql .= "AND a.reference_file_url_yn = '{$data['a.reference_file_url_yn']}' ";
}
// 현재상태
if (!empty($data['stat_cd'])) {
$sql .= "AND c.stat_cd = '{$data['stat_cd']}' ";
}
// 중개소
if (!empty($data['realtor_nm'])) {
$sql .= "AND a.realtor_nm = '{$data['realtor_nm']}' ";
}
// 담당자
if (!empty($data['damdang'])) {
switch ($data['charger_gbn']) {
case "1":
$sql .= "a.charger = '{$data['damdang']}' ";
break;
case "2":
$sql .= "a.reg_charger = '{$data['damdang']}' ";
break;
}
} else {
// 배정여부
if ($data['assign_yn'] !== "A") {
switch ($data['charger_gbn'] . $data['assign_yn']) {
case "1Y": // 전화/서류 담당자
$sql .= "a.charger != '' ";
break;
case "1N": // 전화/서류 담당자
$sql .= "a.charger = '' ";
break;
case "2Y": // 등기부등본 담당자
$sql .= "a.reg_charger != '' ";
break;
case "2N": // 등기부등본 담당자
$sql .= "a.reg_charger IS NULL ";
break;
}
}
}
// 매물종류
if (!empty($data['rlet_type_cd'])) {
$sql .= "AND a.rlet_type_cd = '{$data['rlet_type_cd']}' ";
}
// 소유자구분
if (!empty($data['ownerTypeCode'])) {
$sql .= "AND b.ownerTypeCode = '{$data['ownerTypeCode']}' ";
}
// 서류미수취
if (!empty($data['document_not_received_yn'])) {
$sql .= "AND b.document_not_received_yn = '{$data['document_not_received_yn']}' ";
}
}
$sql .= "ORDER BY a.vr_sq DESC ";
$query = $this->db->query($sql);
return $query->getResultArray();
}
// 상세
public function getDetail($vr_sq)
{
$sql = "SELECT
a.vr_sq,
a.dong_ho_chk,
a.reg_status,
a.hscplqry_lv,
a.atcl_no,
b.stat_cd,
a.cpid,
a.cp_atcl_id,
a.rlet_type_cd,
a.address1,
a.sise,
a.rdate,
a.hscp_no as chk_hscp_no,
b.try_cnt,
a.seller_tel_no,
a.seller_nm,
a.realtor_nm,
a.realtor_tel_no,
a.charger,
a.ownerNm,
a.ownerTelNo,
b.reg_try_cnt,
b.insert_tm,
a.reg_charger,
i2.usr_nm as reg_charger_nm,
c.bild_nm,
b.vrfc_type as vrfc_type_cd,
c.rm_no,
c.floor,
c.floor2,
c.address_code,
c.address2,
c1.address2a,
c1.address2b,
c1.registerBookUniqueNo,
c1.ownerTypeCode,
c1.orgRepCphNo,
c1.orgRepTelNo,
c1.orgRltrNm,
c1.orgRepNm,
c1.smsSendTime,
c1.document_cert_method,
c.address3,
c.address4,
c.trade_type as trade_type_cd,
c.deal_amt,
c.wrrnt_amt,
c.lease_amt,
c.isale_amt,
c.prem_amt,
c.sply_spc,
c.excls_spc,
c.tot_spc,
c.grnd_spc,
c.bldg_spc,
c.hscp_no,
c.ptp_no,
d.insert_tm as update_res_tm,
e.insert_tm as result_tm,
f.region_nm,
g.cd_nm as pre_stat,
g.cd as pre_stat_cd,
h.cd_nm as vrfc_type,
i.usr_nm,
j.cd_nm as trade_type,
j.cd as trade_type_cd,
c.hscp_nm,
c.ptp_nm,
l.success,
k.cd_nm as atcl_nm,
m.code as result_d11,
m.comment,
n.code as fax_conf_yn_2,
o.code as fax_conf_yn_3,
p.code as fax_conf_yn_4,
n.comment as fax_conf_yn_info_2,
o.comment as fax_conf_yn_info_3,
p.comment as fax_conf_yn_info_4,
v.success AS tel_suc,
r.code AS tel_agree,
s.code AS tel_conf_yn_2,
t.code AS tel_conf_yn_3,
u.code AS tel_conf_yn_4,
s.comment AS tel_conf_yn_info_2,
t.comment AS tel_conf_yn_info_3,
u.comment AS tel_conf_yn_info_4,
w.success AS reg_conf_yn_1,
x.code AS reg_conf_yn_2,
y.code AS reg_conf_yn_3,
x.comment AS reg_conf_yn_info_2,
y.comment AS reg_conf_yn_info_3,
b.rgbk_confirm,
a.redvlp_area_nm,
a.biz_stp_desc,
a.cert_register,
a.confirm_doc_img_url,
a.cert_register_save_yn,
a.confirm_doc_img_url_save_yn,
b.confirm_doc_owner_check_yn,
a.owner_birth,
a.vrfc_type_sub,
b.owner_verifiable,
a.reference_file_url,
a.reference_file_url_save_yn,
a.reference_file_url_yn,
z.corp_own,
c1.vir_addr_yn,
c1.cert_uncnfrm_status,
b.referenceFileUrl,
b.certRegister,
c1.noRgbkVrfcReqYn,
c1.areaByBdbkVrfcReqYn,
c1.document_not_received,
sm.sm_apporval_date ,
sm.sm_end_date,
sm.sm_seq,
a.registerBookUniqueNumber
FROM v2_article_info a
JOIN v2_vrfc_req b ON a.vr_sq = b.vr_sq
JOIN v2_modify_info c ON a.vr_sq = c.vr_sq
LEFT OUTER JOIN v2_article_info_etc c1 ON c1.vr_sq = a.vr_sq
LEFT JOIN region_codes f ON a.address_code = f.region_cd
LEFT JOIN v2_chg_stat d ON a.vr_sq = d.vr_sq AND d.stat_cd = '35'
LEFT JOIN v2_chg_stat e ON a.vr_sq = e.vr_sq AND e.stat_cd = '60'
LEFT JOIN codes g ON b.stat_cd = g.cd AND g.category = 'STEP_VERIFICATION'
LEFT JOIN codes h ON b.vrfc_type = h.cd AND h.category = 'VRFCREQ_WAY'
LEFT JOIN codes j ON c.trade_type = j.cd AND j.category = 'TRADE_TYPE'
LEFT JOIN codes k ON a.rlet_type_cd = k.cd AND k.category = 'ARTICLE_TYPE'
LEFT JOIN v2_confirm l ON a.vr_sq = l.vr_sq AND l.vrfc_type = 'D'
LEFT JOIN v2_check_list m ON a.vr_sq = m.vr_sq AND m.type = 'D11'
LEFT JOIN v2_check_list n ON a.vr_sq = n.vr_sq AND n.type = 'D12'
LEFT JOIN v2_check_list o ON a.vr_sq = o.vr_sq AND o.type = 'D13'
LEFT JOIN v2_check_list p ON a.vr_sq = p.vr_sq AND p.type = 'D14'
LEFT JOIN v2_confirm v ON a.vr_sq = v.vr_sq AND v.vrfc_type = 'T'
LEFT JOIN v2_check_list r ON a.vr_sq = r.vr_sq AND r.type = 'T11'
LEFT JOIN v2_check_list s ON a.vr_sq = s.vr_sq AND s.type = 'T12'
LEFT JOIN v2_check_list t ON a.vr_sq = t.vr_sq AND t.type = 'T13'
LEFT JOIN v2_check_list u ON a.vr_sq = u.vr_sq AND u.type = 'T14'
LEFT JOIN v2_confirm w ON a.vr_sq = w.vr_sq AND w.vrfc_type = 'R'
LEFT JOIN v2_check_list x ON a.vr_sq = x.vr_sq AND x.type = '21'
LEFT JOIN v2_check_list y ON a.vr_sq = y.vr_sq AND y.type = '22'
LEFT JOIN users i ON a.charger = i.usr_id
LEFT JOIN users i2 ON a.reg_charger = i2.usr_id
LEFT JOIN v2_article_info_etc z ON a.vr_sq = z.vr_sq
LEFT JOIN scomplex_manage sm ON a.hscp_no = sm.sm_code
WHERE
a.vr_sq = ?";
$query = $this->db->query($sql, [$vr_sq]);
return $query->getRowArray();
}
// 메모
public function getMemo($vr_sq)
{
$sql = "SELECT memo FROM v2_vrfc_req where vr_sq = ?";
$query = $this->db->query($sql, [$vr_sq]);
return $query->getRowArray();
}
public function getRecordInfo($vr_sq, $file_type)
{
$sql = "SELECT seq, vr_sq, use_yn, file_type, view_odr, file_path, file_name, file_ext, file_size, img_width, img_height, meta_data, insert_user, insert_tm , cloud_upload_yn " .
" FROM v2_files" .
" WHERE vr_sq = ?" .
" AND use_yn = 'Y'" .
" AND file_type = ?" .
" ORDER BY seq DESC";
$data = [
$vr_sq,
$file_type
];
$query = $this->db->query($sql, [$vr_sq, $file_type]);
return $query->getRowArray();
}
public function getDisplay($menu_position)
{
$sql = "SELECT display_yn " .
"FROM page_display " .
"WHERE menu_position = ? ";
$data = [$menu_position];
$query = $this->db->query($sql, $data);
$row = $query->getRowArray();
return $row;
}
// 파일업로드
public function saveFileInfo($data)
{
$this->db->transStart();
$usr_id = session('usr_id');
// 기존파일 확인후 업데이트
$sql = "SELECT seq FROM v2_files WHERE vr_sq = {$data['vr_sq']} AND use_yn = 'Y' AND file_type = '2'";
$query = $this->db->query($sql);
$row = $query->getNumRows();
if ($row > 0) {
$sql = "UPDATE v2_files SET use_yn = 'N' WHERE vr_sq = {$data['vr_sq']} AND use_yn = 'Y' AND file_type '2'";
$this->db->query($sql);
$sql = "INSERT INTO v2_files
(vr_sq, file_type, view_odr, file_path, file_name, file_ext, file_size, insert_user, insert_tm, cloud_upload_yn)
VALUES
(?, '2', 0, ?, ?, ?, ?, ?, NOW(), 'Y')
";
$param = [
$data['vr_sq'],
$data['file_path'],
$data['new_name'],
$data['ext'],
$data['size'],
$data['usr_id'],
];
if ($this->db->query($sql, $param)) {
return [
'success' => false,
'msg' => '파일정보 저장 실패',
];
}
$row = $this->getDetail($data['vr_sq']);
$this->saveChangedHistory($data['vr_sq'], $row['stat_cd'], 'C28', $usr_id, '이미지파일 업로드');
}
$this->db->transComplete();
return [
'success' => true
];
}
// 서류미수취 저장
public function saveNotReceived($vr_sq)
{
$sql = "SELECT document_not_received from v2_article_info_etc where vr_sq = ?";
$query = $this->db->query($sql, [$vr_sq]);
$row = $query->getRowArray();
$document_not_received = $row['document_not_received'];
if ($document_not_received == "Y") {
$sql = "UPDATE v2_article_info_etc SET document_not_received = 'N' WHERE vr_sq = ?";
} else {
$sql = "UPDATE v2_article_info_etc SET document_not_received = 'Y' WHERE vr_sq = ?";
}
if ($this->db->query($sql, [$vr_sq]) === false) {
return [
'success' => false,
'msg' => '저장 실패',
];
}
return [
'success' => true,
];
}
// 다음매물
public function getNextInfo($vr_sq)
{
$usr_id = session('usr_id');
$sql = "SELECT b.vr_sq
FROM v2_article_info b
INNER JOIN v2_vrfc_req a ON a.vr_sq = b.vr_sq AND a.vr_sq != ? AND a.stat_cd BETWEEN '35' AND '49' AND a.stat_cd NOT IN ('39','45')
LEFT JOIN v2_chg_stat c ON c.vr_sq = b.vr_sq AND c.stat_cd = '40'
WHERE a.insert_tm < DATE_FORMAT(curdate(), '%Y%m%d172959')
AND (b.reg_charger IS NULL OR b.reg_charger = '')
AND a.vrfc_type = 'N'
ORDER BY CASE a.vrfc_type WHEN 'N' THEN 1 ELSE 2 END, a.vr_sq
LIMIT 1
for update skip locked ";
$query = $this->db->query($sql, [$vr_sq]);
$row = $query->getRowArray();
if (!empty($row)) {
$this->db->transStart();
$sql = "UPDATE v2_article_info SET reg_charger = ? WHERE vr_sq = ?";
if ($this->db->query($sql, [$usr_id, $vr_sq]) === false) {
return [
'success' => false,
'msg' => '저장 실패',
];
}
$this->db->transComplete();
return $row;
} else {
return [];
}
}
// 정보변경 이력 저장
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);
}
}