This commit is contained in:
subsub 2023-10-11 14:34:42 +09:00
commit 084e2be35b
64 changed files with 4041 additions and 371 deletions

View File

@ -172,6 +172,9 @@ public class ComDefaultVO implements Serializable {
private String searchQuery; private String searchQuery;
private String searchStartRegistPnttm;
private String searchEndRegistPnttm;
public int getBeSort() { public int getBeSort() {
return beSort; return beSort;
} }
@ -844,4 +847,20 @@ public class ComDefaultVO implements Serializable {
this.searchQuery = searchQuery; this.searchQuery = searchQuery;
} }
public String getSearchStartRegistPnttm() {
return searchStartRegistPnttm;
}
public void setSearchStartRegistPnttm(String searchStartRegistPnttm) {
this.searchStartRegistPnttm = searchStartRegistPnttm;
}
public String getSearchEndRegistPnttm() {
return searchEndRegistPnttm;
}
public void setSearchEndRegistPnttm(String searchEndRegistPnttm) {
this.searchEndRegistPnttm = searchEndRegistPnttm;
}
} }

View File

@ -222,4 +222,10 @@ public final class DateUtil {
LocalDate date = LocalDate.parse(p_date, formatter); LocalDate date = LocalDate.parse(p_date, formatter);
return date; return date;
} }
public static LocalDate getStringToLocalDateDot(String p_date) {
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy.MM.dd");
LocalDate date = LocalDate.parse(p_date, formatter);
return date;
}
} }

View File

@ -10,9 +10,9 @@ import kcc.ve.aplct.cpyrgExprnClsrm.exprnClsrmAplct.service.ScholInfoVO;
@Repository("fndtnEnhanceTrnDAO") @Repository("fndtnEnhanceTrnDAO")
public class FndtnEnhanceTrnDAO extends EgovAbstractDAO { public class FndtnEnhanceTrnDAO extends EgovAbstractDAO {
public void insertIsltn(ScholInfoVO paramVO) throws Exception { /* public void insertIsltn(ScholInfoVO paramVO) throws Exception {
insert("ScholInfoDAO.insertIsltn", paramVO); insert("ScholInfoDAO.insertIsltn", paramVO);
} }*/
/** /**
* L - Page * L - Page
@ -20,7 +20,7 @@ public class FndtnEnhanceTrnDAO extends EgovAbstractDAO {
* @return * @return
* @throws Exception * @throws Exception
*/ */
public List<ScholInfoVO> selectPagingList(ScholInfoVO paramVO) throws Exception { /* public List<ScholInfoVO> selectPagingList(ScholInfoVO paramVO) throws Exception {
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
List<ScholInfoVO> list = (List<ScholInfoVO>) list("ScholInfoDAO.selectPagingList", paramVO); List<ScholInfoVO> list = (List<ScholInfoVO>) list("ScholInfoDAO.selectPagingList", paramVO);
return list; return list;
@ -56,5 +56,5 @@ public class FndtnEnhanceTrnDAO extends EgovAbstractDAO {
public int insertSelectIsltn(ScholInfoVO scholInfoVO) throws Exception { public int insertSelectIsltn(ScholInfoVO scholInfoVO) throws Exception {
return update("ScholInfoDAO.insertSelectIsltn", scholInfoVO); return update("ScholInfoDAO.insertSelectIsltn", scholInfoVO);
} }*/
} }

View File

@ -475,6 +475,7 @@ public class FndtnEnhanceTrnController {
} }
////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////
// //
// //

View File

@ -2,6 +2,7 @@ package kcc.ve.aplct.sspnIdtmt.service;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO;
import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.CndtnTrgtMngVO;
public interface SspnIdtmtService { public interface SspnIdtmtService {
@ -9,5 +10,7 @@ public interface SspnIdtmtService {
VEEduAplctVO findByAprvlCd(VEEduAplctVO vEEduAplctReqVO); VEEduAplctVO findByAprvlCd(VEEduAplctVO vEEduAplctReqVO);
String findByTrgtNm(CndtnTrgtMngVO cndtnTrgtInfoMngVO);
} }

View File

@ -6,20 +6,21 @@ import org.springframework.stereotype.Repository;
import egovframework.rte.psl.dataaccess.EgovAbstractDAO; import egovframework.rte.psl.dataaccess.EgovAbstractDAO;
import kcc.ve.aplct.cpyrgExprnClsrm.exprnClsrmAplct.service.ScholInfoVO; import kcc.ve.aplct.cpyrgExprnClsrm.exprnClsrmAplct.service.ScholInfoVO;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO;
@Repository("sspnIdtmtDAO") @Repository("sspnIdtmtDAO")
public class SspnIdtmtDAO extends EgovAbstractDAO { public class SspnIdtmtDAO extends EgovAbstractDAO {
//
public void insertIsltn(ScholInfoVO paramVO) throws Exception { // public void insertIsltn(ScholInfoVO paramVO) throws Exception {
insert("ScholInfoDAO.insertIsltn", paramVO); // insert("ScholInfoDAO.insertIsltn", paramVO);
} // }
/*
/** *//**
* L - Page * L - Page
* @param scholInfoVO * @param scholInfoVO
* @return * @return
* @throws Exception * @throws Exception
*/ *//*
public List<ScholInfoVO> selectPagingList(ScholInfoVO paramVO) throws Exception { public List<ScholInfoVO> selectPagingList(ScholInfoVO paramVO) throws Exception {
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
List<ScholInfoVO> list = (List<ScholInfoVO>) list("ScholInfoDAO.selectPagingList", paramVO); List<ScholInfoVO> list = (List<ScholInfoVO>) list("ScholInfoDAO.selectPagingList", paramVO);
@ -56,5 +57,9 @@ public class SspnIdtmtDAO extends EgovAbstractDAO {
public int insertSelectIsltn(ScholInfoVO scholInfoVO) throws Exception { public int insertSelectIsltn(ScholInfoVO scholInfoVO) throws Exception {
return update("ScholInfoDAO.insertSelectIsltn", scholInfoVO); return update("ScholInfoDAO.insertSelectIsltn", scholInfoVO);
} }*/
// public int findByTrgtNm(VEEduAplctVO vEEduAplctVO) {
// return (int) select("SspnIdtmtDAO.findByTrgtNm", vEEduAplctVO);
// }
} }

View File

@ -7,6 +7,8 @@ import org.springframework.stereotype.Service;
import kcc.ve.aplct.sspnIdtmt.service.SspnIdtmtService; import kcc.ve.aplct.sspnIdtmt.service.SspnIdtmtService;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.impl.VEEduAplctDAO; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.impl.VEEduAplctDAO;
import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.CndtnTrgtMngVO;
import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.impl.CndtnTrgtMngDAO;
@Service("sspnIdtmtService") @Service("sspnIdtmtService")
public class SspnIdtmtServiceImpl implements SspnIdtmtService { public class SspnIdtmtServiceImpl implements SspnIdtmtService {
@ -16,14 +18,23 @@ public class SspnIdtmtServiceImpl implements SspnIdtmtService {
@Resource(name="vEEduAplctDAO") @Resource(name="vEEduAplctDAO")
private VEEduAplctDAO vEEduAplctDAO; private VEEduAplctDAO vEEduAplctDAO;
// 기소유예 관련
@Resource(name="cndtnTrgtInfoMngDAO")
private CndtnTrgtMngDAO cndtnTrgtInfoMngDAO;
@Override @Override
public void insertVeEduAplct(VEEduAplctVO paramVO) { public void insertVeEduAplct(VEEduAplctVO paramVO) {
//C vEEduAplctDAO.insertVeEduAplct(paramVO);
vEEduAplctDAO.insertVeEduAplct(paramVO);
} }
@Override @Override
public VEEduAplctVO findByAprvlCd(VEEduAplctVO vEEduAplctReqVO) { public VEEduAplctVO findByAprvlCd(VEEduAplctVO vEEduAplctReqVO) {
return vEEduAplctDAO.findByAprvlCd(vEEduAplctReqVO); return vEEduAplctDAO.findByAprvlCd(vEEduAplctReqVO);
} }
@Override
public String findByTrgtNm(CndtnTrgtMngVO cndtnTrgtInfoMngVO) {
return cndtnTrgtInfoMngDAO.findByTrgtNm(cndtnTrgtInfoMngVO);
}
} }

View File

@ -40,6 +40,8 @@ import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsDetailVO;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsMIXService; import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsMIXService;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsOnlnCntntService; import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsOnlnCntntService;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsService; import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsService;
import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.CndtnTrgtMngService;
import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.CndtnTrgtMngVO;
/** /**
* 교육신청(성인찾아가는교육) * 교육신청(성인찾아가는교육)
@ -135,6 +137,11 @@ public class SspnIdtmtController {
@Resource(name = "eduAplctAdultService") @Resource(name = "eduAplctAdultService")
private EduAplctAdultService eduAplctAdultService; private EduAplctAdultService eduAplctAdultService;
//과정 관리
@Resource(name = "cndtnTrgtInfoMngService")
private CndtnTrgtMngService cndtnTrgtInfoMngService;
//코드 //코드
@Resource(name="cmmUseDAO") @Resource(name="cmmUseDAO")
@ -294,7 +301,7 @@ public class SspnIdtmtController {
/** /**
* 교육신청 목록 화면 * 교육신청 목록 화면
*/ */
@RequestMapping("/web/ve/aplct/sspnIdtmt/fndtnEduAplctList.do") /*@RequestMapping("/web/ve/aplct/sspnIdtmt/fndtnEduAplctList.do")
public String fndtnEduAplctList( public String fndtnEduAplctList(
@ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO @ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO
, ModelMap model , ModelMap model
@ -357,7 +364,7 @@ public class SspnIdtmtController {
return "/web/ve/aplct/sspnIdtmt/fndtnEduAplctList"; return "/web/ve/aplct/sspnIdtmt/fndtnEduAplctList";
} }
/** *//**
* 교육상세 * 교육상세
*/ */
@RequestMapping("/web/ve/aplct/sspnIdtmt/eduAplctDetail.do") @RequestMapping("/web/ve/aplct/sspnIdtmt/eduAplctDetail.do")
@ -399,6 +406,9 @@ public class SspnIdtmtController {
//로그인 처리==================================== //로그인 처리====================================
//로그인 정보 가져오기 //로그인 정보 가져오기
String s_oprtnLoginCheckNInfo = checkLoginUtil.oprtnCheckNInfo(model); String s_oprtnLoginCheckNInfo = checkLoginUtil.oprtnCheckNInfo(model);
if (!"".equals(s_oprtnLoginCheckNInfo)) { if (!"".equals(s_oprtnLoginCheckNInfo)) {
@ -410,12 +420,12 @@ public class SspnIdtmtController {
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기 LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
SsoLoginVO ssoLoginVO = checkLoginUtil.getSSOLoginVO(request); //SSO 로그인 정보 가져오기 SsoLoginVO ssoLoginVO = checkLoginUtil.getSSOLoginVO(request); //SSO 로그인 정보 가져오기
VEEduAplctVO vEEduAplctVO = new VEEduAplctVO(); VEEduAplctVO vEEduAplctVO = new VEEduAplctVO();
vEEduAplctVO.setEduAplctOrd(eduAplctGnrService.getNextStringId()); vEEduAplctVO.setEduAplctOrd(eduAplctGnrService.getNextStringId());
vEEduAplctVO.setLctrDivCd("60"); // 기반강화 vEEduAplctVO.setLctrDivCd(VeConstants.LCTR_DIV_CD_60); // 기소유예
vEEduAplctVO.setAprvlCd("10"); // 승인코드 VE0003 10 - 요청, 20 - 승인, 30 - 반려 vEEduAplctVO.setAprvlCd("10"); // 승인코드 VE0003 10 - 요청, 20 - 승인, 30 - 반려
// sbmt_pnttm 제출일시 // sbmt_pnttm 제출일시
vEEduAplctVO.setSbmtYn("Y"); // 제출여부 vEEduAplctVO.setSbmtYn("Y"); // 제출여부
@ -424,15 +434,65 @@ public class SspnIdtmtController {
vEEduAplctVO.setUserId(loginVO.getUniqId()); vEEduAplctVO.setUserId(loginVO.getUniqId());
vEEduAplctVO.setPrcsOrd(vEPrcsDetailVO.getPrcsAplctPrdOrd()); vEEduAplctVO.setPrcsOrd(vEPrcsDetailVO.getPrcsAplctPrdOrd());
sspnIdtmtService.insertVeEduAplct(vEEduAplctVO); String result = "";
try {
sspnIdtmtService.insertVeEduAplct(vEEduAplctVO);
CndtnTrgtMngVO cndtnTrgtMngVO = new CndtnTrgtMngVO();
cndtnTrgtMngVO.setUserId(loginVO.getUniqId());
cndtnTrgtMngVO.setSspnIdtmtTrgtOrd(vEPrcsDetailVO.getSspnIdtmtTrgtOrd());
cndtnTrgtInfoMngService.updateUserId(cndtnTrgtMngVO);
result = "success";
} catch (Exception e) {
// TODO: handle exception
}
modelAndView.addObject("result", "success"); modelAndView.addObject("result", result);
return modelAndView; return modelAndView;
} }
/**
* 기반강화연수과정 신청기간 등록
*/
@RequestMapping("/web/ve/aplct/sspnIdtmt/userConfirmAjax.do")
public ModelAndView userConfirmAjax(
@ModelAttribute("cndtnTrgtInfoMngVO") CndtnTrgtMngVO cndtnTrgtInfoMngVO
, ModelMap model
, HttpServletRequest request
) throws Exception {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("jsonView");
//로그인 처리====================================
//로그인 정보 가져오기
String s_oprtnLoginCheckNInfo = checkLoginUtil.oprtnCheckNInfo(model);
if (!"".equals(s_oprtnLoginCheckNInfo)) {
modelAndView.addObject("result", "loginFail");
return modelAndView;
}
String id = sspnIdtmtService.findByTrgtNm(cndtnTrgtInfoMngVO);
modelAndView.addObject("result", "success");
modelAndView.addObject("id", id);
return modelAndView;
}
/** /**
* 교육신청 목록 화면 * 교육신청 목록 화면

View File

@ -299,6 +299,10 @@ public class VEEduAplctVO extends ComDefaultVO implements Serializable {
private String unfthYn; //불성실여부 private String unfthYn; //불성실여부
private String trgtNm; //기소유예 대상자
private String vs_clphone; //기소유예 대상자 폰번호
public String getPrcsAplctPrdOrd() { public String getPrcsAplctPrdOrd() {
return prcsAplctPrdOrd; return prcsAplctPrdOrd;
@ -1523,6 +1527,18 @@ public class VEEduAplctVO extends ComDefaultVO implements Serializable {
public void setNeedTxtbNum(String needTxtbNum) { public void setNeedTxtbNum(String needTxtbNum) {
this.needTxtbNum = needTxtbNum; this.needTxtbNum = needTxtbNum;
} }
public String getTrgtNm() {
return trgtNm;
}
public void setTrgtNm(String trgtNm) {
this.trgtNm = trgtNm;
}
public String getVs_clphone() {
return vs_clphone;
}
public void setVs_clphone(String vs_clphone) {
this.vs_clphone = vs_clphone;
}
} }

View File

@ -5,6 +5,7 @@ import java.util.List;
import kcc.let.uss.umt.service.UserManageVO; import kcc.let.uss.umt.service.UserManageVO;
import kcc.ve.instr.tngrVisitEdu.asgnmInfo.service.VEEduExcelVO; import kcc.ve.instr.tngrVisitEdu.asgnmInfo.service.VEEduExcelVO;
import kcc.ve.instr.tngrVisitEdu.asgnmInfo.service.VEEduSatisfactionExcelVO; import kcc.ve.instr.tngrVisitEdu.asgnmInfo.service.VEEduSatisfactionExcelVO;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsDetailVO;
public interface VEEduMIXService { public interface VEEduMIXService {
@ -52,4 +53,6 @@ public interface VEEduMIXService {
void updateRsltRprtFileId(VEEduAplctVO vEEduAplctVO) throws Exception; void updateRsltRprtFileId(VEEduAplctVO vEEduAplctVO) throws Exception;
//저작권 체험교실 목록 //저작권 체험교실 목록
List<VEEduAplctVO> selectExprnPagingList(VEEduAplctVO paramVO) throws Exception; List<VEEduAplctVO> selectExprnPagingList(VEEduAplctVO paramVO) throws Exception;
void updateAplctStateCd(VEEduAplctVO vEEduAplctVO);
} }

View File

@ -142,5 +142,9 @@ public class VEEduMIXDAO extends EgovAbstractDAO {
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
List<VEEduAplctVO> tlist = (List<VEEduAplctVO>) list("VEEduMIXDAO.selectExprnPagingList", paramVO); List<VEEduAplctVO> tlist = (List<VEEduAplctVO>) list("VEEduMIXDAO.selectExprnPagingList", paramVO);
return tlist; return tlist;
}
public void updateAplctStateCd(VEEduAplctVO vEEduAplctVO) {
update("VEEduMIXDAO.updateAplctStateCd", vEEduAplctVO);
} }
} }

View File

@ -14,6 +14,7 @@ import kcc.ve.instr.tngrVisitEdu.asgnmInfo.service.VEEduSatisfactionExcelVO;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduChasiVO; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduChasiVO;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduMIXService; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduMIXService;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsDetailVO;
@Service("vEEduMIXService") @Service("vEEduMIXService")
public class VEEduMIXServiceImpl implements VEEduMIXService { public class VEEduMIXServiceImpl implements VEEduMIXService {
@ -129,4 +130,9 @@ public class VEEduMIXServiceImpl implements VEEduMIXService {
public List<VEEduAplctVO> selectExprnPagingList(VEEduAplctVO paramVO) throws Exception{ public List<VEEduAplctVO> selectExprnPagingList(VEEduAplctVO paramVO) throws Exception{
return vEEduMIXDAO.selectExprnPagingList(paramVO); return vEEduMIXDAO.selectExprnPagingList(paramVO);
} }
@Override
public void updateAplctStateCd(VEEduAplctVO vEEduAplctVO) {
vEEduMIXDAO.updateAplctStateCd(vEEduAplctVO);
}
} }

View File

@ -278,7 +278,8 @@ public class InstrPrflController {
//강의조사 기간 여부 //강의조사 기간 여부
VELctrDetailVO vELctrDetailVO = new VELctrDetailVO(); VELctrDetailVO vELctrDetailVO = new VELctrDetailVO();
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt"); //vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt");
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATE,'YYYYMMDD') BETWEEN rsrch_strt_dt and rsrch_end_dt");
vELctrDetailVO = vELctrRsrchMngService.selectDetailWithQuery(vELctrDetailVO); vELctrDetailVO = vELctrRsrchMngService.selectDetailWithQuery(vELctrDetailVO);
model.addAttribute("vELctrDetailVO", vELctrDetailVO); model.addAttribute("vELctrDetailVO", vELctrDetailVO);

View File

@ -154,7 +154,8 @@ public class lctrTngrInfoStngController {
//2.오늘이 선택해서 들어온 강의조사의 기간 여부 체크 //2.오늘이 선택해서 들어온 강의조사의 기간 여부 체크
//날짜 표시 제출 버튼 노출 사용 //날짜 표시 제출 버튼 노출 사용
VELctrDetailVO vELctrRsrchDetailVO = new VELctrDetailVO(); VELctrDetailVO vELctrRsrchDetailVO = new VELctrDetailVO();
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt " //vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt "
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATE,'YYYYMMDD') BETWEEN rsrch_strt_dt and rsrch_end_dt "
+ " AND rsrch_instr_div='"+vELctrDetailVO.getRsrchInstrDiv()+"' " + " AND rsrch_instr_div='"+vELctrDetailVO.getRsrchInstrDiv()+"' "
+ " AND stng_yr_mnt='"+vELctrDetailVO.getStngYrMnt()+"' "); + " AND stng_yr_mnt='"+vELctrDetailVO.getStngYrMnt()+"' ");
//vELctrRsrchDetailVO = vELctrRsrchMngService.selectDetail(vELctrDetailVO); //vELctrRsrchDetailVO = vELctrRsrchMngService.selectDetail(vELctrDetailVO);
@ -333,7 +334,8 @@ public class lctrTngrInfoStngController {
//2.오늘이 선택해서 들어온 강의조사의 기간 여부 체크 //2.오늘이 선택해서 들어온 강의조사의 기간 여부 체크
VELctrDetailVO vELctrRsrchDetailVO = new VELctrDetailVO(); VELctrDetailVO vELctrRsrchDetailVO = new VELctrDetailVO();
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt " //vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt "
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATE,'YYYYMMDD') BETWEEN rsrch_strt_dt and rsrch_end_dt "
+ " AND rsrch_instr_div='"+vELctrDetailVO.getRsrchInstrDiv()+"' " + " AND rsrch_instr_div='"+vELctrDetailVO.getRsrchInstrDiv()+"' "
+ " AND stng_yr_mnt='"+vELctrDetailVO.getStngYrMnt()+"' "); + " AND stng_yr_mnt='"+vELctrDetailVO.getStngYrMnt()+"' ");
//vELctrRsrchDetailVO = vELctrRsrchMngService.selectDetail(vELctrDetailVO); //vELctrRsrchDetailVO = vELctrRsrchMngService.selectDetail(vELctrDetailVO);

View File

@ -17,4 +17,6 @@ public interface VEAPrcsAplctPrdInstrAsgnmService {
VEPrcsDetailVO selectAprvlCdEduAplctDetail(VEPrcsDetailVO vEDetailVO); VEPrcsDetailVO selectAprvlCdEduAplctDetail(VEPrcsDetailVO vEDetailVO);
void updateAprvlCdEduAplctDetail(VEPrcsDetailVO vEDetailVO); void updateAprvlCdEduAplctDetail(VEPrcsDetailVO vEDetailVO);
void updateAplctStateCdListAjax(VEPrcsDetailVO vEPrcsDetailVO);
} }

View File

@ -114,6 +114,7 @@ public class VEPrcsDetailVO extends ComDefaultVO implements Serializable {
private String eduPlace; //교육장소 private String eduPlace; //교육장소
private String instrDiv; private String instrDiv;
private String instrCnt;
private String userId; private String userId;
@ -126,6 +127,8 @@ public class VEPrcsDetailVO extends ComDefaultVO implements Serializable {
private String dateChk; private String dateChk;
private Boolean qestRsltExists; private Boolean qestRsltExists;
private String trgtNm;
private String sspnIdtmtTrgtOrd;
@ -561,6 +564,12 @@ public class VEPrcsDetailVO extends ComDefaultVO implements Serializable {
public void setInstrDiv(String instrDiv) { public void setInstrDiv(String instrDiv) {
this.instrDiv = instrDiv; this.instrDiv = instrDiv;
} }
public String getInstrCnt() {
return instrCnt;
}
public void setInstrCnt(String instrCnt) {
this.instrCnt = instrCnt;
}
public String getUserId() { public String getUserId() {
return userId; return userId;
} }
@ -597,6 +606,18 @@ public class VEPrcsDetailVO extends ComDefaultVO implements Serializable {
public void setQestRsltExists(Boolean qestRsltExists) { public void setQestRsltExists(Boolean qestRsltExists) {
this.qestRsltExists = qestRsltExists; this.qestRsltExists = qestRsltExists;
} }
public String getTrgtNm() {
return trgtNm;
}
public void setTrgtNm(String trgtNm) {
this.trgtNm = trgtNm;
}
public String getSspnIdtmtTrgtOrd() {
return sspnIdtmtTrgtOrd;
}
public void setSspnIdtmtTrgtOrd(String sspnIdtmtTrgtOrd) {
this.sspnIdtmtTrgtOrd = sspnIdtmtTrgtOrd;
}
} }

View File

@ -36,6 +36,11 @@ public class VEAPrcsAplctPrdInstrAsgnmDAO extends EgovAbstractDAO {
public void updateAprvlCdEduAplctDetail(VEPrcsDetailVO vEDetailVO) { public void updateAprvlCdEduAplctDetail(VEPrcsDetailVO vEDetailVO) {
delete("VEAPrcsAplctPrdInstrAsgnmDAO.updateAprvlCdEduAplctDetail", vEDetailVO); delete("VEAPrcsAplctPrdInstrAsgnmDAO.updateAprvlCdEduAplctDetail", vEDetailVO);
}
public void updateAplctStateCdListAjax(VEPrcsDetailVO vEPrcsDetailVO) {
update("VEAPrcsAplctPrdInstrAsgnmDAO.updateAplctStateCdListAjax", vEPrcsDetailVO);
} }
} }

View File

@ -58,4 +58,10 @@ public class VEAPrcsAplctPrdInstrAsgnmServiceImpl implements VEAPrcsAplctPrdInst
public void updateAprvlCdEduAplctDetail(VEPrcsDetailVO vEDetailVO) { public void updateAprvlCdEduAplctDetail(VEPrcsDetailVO vEDetailVO) {
vEAPrcsAplctPrdInstrAsgnmDAO.updateAprvlCdEduAplctDetail(vEDetailVO); vEAPrcsAplctPrdInstrAsgnmDAO.updateAprvlCdEduAplctDetail(vEDetailVO);
} }
@Override
public void updateAplctStateCdListAjax(VEPrcsDetailVO vEPrcsDetailVO) {
vEAPrcsAplctPrdInstrAsgnmDAO.updateAplctStateCdListAjax(vEPrcsDetailVO);
}
} }

View File

@ -2,6 +2,7 @@ package kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service;
import java.util.List; import java.util.List;
public interface CndtnTrgtMngService { public interface CndtnTrgtMngService {
List<CndtnTrgtMngVO> selectPagingList(CndtnTrgtMngVO cndtnTrgtInfoMngVO); List<CndtnTrgtMngVO> selectPagingList(CndtnTrgtMngVO cndtnTrgtInfoMngVO);
@ -11,6 +12,8 @@ public interface CndtnTrgtMngService {
CndtnTrgtMngVO selectDetail(CndtnTrgtMngVO cndtnTrgtInfoVO); CndtnTrgtMngVO selectDetail(CndtnTrgtMngVO cndtnTrgtInfoVO);
void update(CndtnTrgtMngVO cndtnTrgtInfoMngVO); void update(CndtnTrgtMngVO cndtnTrgtInfoMngVO);
void updateUserId(CndtnTrgtMngVO cndtnTrgtMngVO);

View File

@ -5,6 +5,7 @@ import java.util.List;
import org.springframework.stereotype.Repository; import org.springframework.stereotype.Repository;
import egovframework.rte.psl.dataaccess.EgovAbstractDAO; import egovframework.rte.psl.dataaccess.EgovAbstractDAO;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO;
import kcc.ve.instr.tngrVisitEdu.instrInfo.service.VEInstrDetailVO; import kcc.ve.instr.tngrVisitEdu.instrInfo.service.VEInstrDetailVO;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEAPrcsAplctPrdInstrAsgnmVO; import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEAPrcsAplctPrdInstrAsgnmVO;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsDetailVO; import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsDetailVO;
@ -108,5 +109,13 @@ public class CndtnTrgtMngDAO extends EgovAbstractDAO {
update("cndtnTrgtInfoMngDAO.update", cndtnTrgtInfoMngVO); update("cndtnTrgtInfoMngDAO.update", cndtnTrgtInfoMngVO);
} }
public String findByTrgtNm(CndtnTrgtMngVO cndtnTrgtInfoMngVO) {
return (String) select("cndtnTrgtInfoMngDAO.findByTrgtNm", cndtnTrgtInfoMngVO);
}
public void updateUserId(CndtnTrgtMngVO cndtnTrgtMngVO) {
update("cndtnTrgtInfoMngDAO.updateUserId", cndtnTrgtMngVO);
}
} }

View File

@ -8,6 +8,7 @@ import javax.annotation.Resource;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import egovframework.rte.fdl.idgnr.EgovIdGnrService; import egovframework.rte.fdl.idgnr.EgovIdGnrService;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsDetailVO;
import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.CndtnTrgtMngService; import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.CndtnTrgtMngService;
import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.CndtnTrgtMngVO; import kcc.ve.oprtn.cndtnSspnIdtmt.trgtMng.service.CndtnTrgtMngVO;
@ -46,6 +47,11 @@ public class CndtnTrgtMngServiceImpl implements CndtnTrgtMngService {
cndtnTrgtInfoMngDAO.update(cndtnTrgtInfoMngVO); cndtnTrgtInfoMngDAO.update(cndtnTrgtInfoMngVO);
} }
@Override
public void updateUserId(CndtnTrgtMngVO cndtnTrgtMngVO) {
cndtnTrgtInfoMngDAO.updateUserId(cndtnTrgtMngVO);
}
/* /*
//C //C

View File

@ -6,6 +6,7 @@ import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession; import javax.servlet.http.HttpSession;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
@ -612,7 +613,7 @@ public class CndtnPrcsInfoMngController {
} }
/** /**
* 기반강화연수과정 기간 상세화면 * 조건부기소유예 기간 상세화면
*/ */
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngDetail.do") @RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngDetail.do")
public String cndtnEduPrcsAplctPrdMngDetail( public String cndtnEduPrcsAplctPrdMngDetail(
@ -652,7 +653,6 @@ public class CndtnPrcsInfoMngController {
List<VEEduAplctVO> vEPrcsDetailVOList = vEEduMIXService.selectList(paramVO); List<VEEduAplctVO> vEPrcsDetailVOList = vEEduMIXService.selectList(paramVO);
vEPrcsDetailVOList = egovCryptoUtil.decryptVeEduAplctList(vEPrcsDetailVOList); vEPrcsDetailVOList = egovCryptoUtil.decryptVeEduAplctList(vEPrcsDetailVOList);
System.out.println("====");
//대상 리스트, 페이징 정보 전달 //대상 리스트, 페이징 정보 전달
@ -662,6 +662,7 @@ public class CndtnPrcsInfoMngController {
// 강사 배치 정보 // 강사 배치 정보
{ {
System.out.println("====");
List<VEAPrcsAplctPrdInstrAsgnmVO> vEAPrcsAplctPrdInstrAsgnmList = vEAPrcsAplctPrdInstrAsgnmService.findByPrcsAplctPrdOrd(vEPrcsDetailVO.getPrcsAplctPrdOrd()); List<VEAPrcsAplctPrdInstrAsgnmVO> vEAPrcsAplctPrdInstrAsgnmList = vEAPrcsAplctPrdInstrAsgnmService.findByPrcsAplctPrdOrd(vEPrcsDetailVO.getPrcsAplctPrdOrd());
List<VEAPrcsAplctPrdInstrAsgnmVO> instrAsgnmList = egovCryptoUtil.decryptVEAPrcsAplctPrdInstrAsgnmVOList(vEAPrcsAplctPrdInstrAsgnmList); List<VEAPrcsAplctPrdInstrAsgnmVO> instrAsgnmList = egovCryptoUtil.decryptVEAPrcsAplctPrdInstrAsgnmVOList(vEAPrcsAplctPrdInstrAsgnmList);
@ -670,10 +671,114 @@ public class CndtnPrcsInfoMngController {
return "/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngDetail"; return "/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngDetail";
} }
/** /**
* 기반강화 신청자 상태값 변경 * 조건부기소유예 기간 상세화면
*/
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngDetail.do")
public String cndtnEduPrcsAplctCfnMngDetail(
@ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO
, ModelMap model
, RedirectAttributes redirectAttributes
, HttpSession session
, HttpServletRequest request
) throws Exception {
//로그인 처리====================================
//로그인 정보 가져오기
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
SsoLoginVO ssoLoginVO = checkLoginUtil.getSSOLoginVO(request); //SSO 로그인 정보 가져오기
//과정 조회
VEPrcsDetailVO vEPrcsDetailVODetail = vEPrcsAplctPrdService.selectDetailNewOne4Fndth(vEPrcsDetailVO);
model.addAttribute("info", vEPrcsDetailVODetail);
//과정 신청자 정보 가져오기
{
//해당 과정을 제출한 사용자 정보를 가져온다.
VEEduAplctVO paramVO = new VEEduAplctVO();
paramVO.setPrcsOrd(vEPrcsDetailVO.getPrcsAplctPrdOrd());
paramVO.setSbmtYn("Y");
// 검색 - 날짜
paramVO.setSearchSmbtStartDt(vEPrcsDetailVO.getSearchSmbtStartDt());
paramVO.setSearchSmbtEndDt(vEPrcsDetailVO.getSearchSmbtEndDt());
// 검색 - 검색어
paramVO.setSearchStatus(vEPrcsDetailVO.getSearchStatus());
paramVO.setSearchSelStatus(vEPrcsDetailVO.getSearchSelStatus());
if(StringUtils.isNotEmpty(vEPrcsDetailVO.getSearchStatus())) {
String searchQuery = "AND vadi.APLCT_STATE_CD = "+vEPrcsDetailVO.getSearchStatus();
paramVO.setSearchQuery(searchQuery);
}
List<VEEduAplctVO> vEPrcsDetailVOList = vEEduMIXService.selectList(paramVO);
vEPrcsDetailVOList = egovCryptoUtil.decryptVeEduAplctList(vEPrcsDetailVOList);
//대상 리스트, 페이징 정보 전달
model.addAttribute("listPrcsAplct", vEPrcsDetailVOList);
}
// 강사 배치 정보
{
System.out.println("====");
List<VEAPrcsAplctPrdInstrAsgnmVO> vEAPrcsAplctPrdInstrAsgnmList = vEAPrcsAplctPrdInstrAsgnmService.findByPrcsAplctPrdOrd(vEPrcsDetailVO.getPrcsAplctPrdOrd());
List<VEAPrcsAplctPrdInstrAsgnmVO> instrAsgnmList = egovCryptoUtil.decryptVEAPrcsAplctPrdInstrAsgnmVOList(vEAPrcsAplctPrdInstrAsgnmList);
model.addAttribute("instrAsgnmList", instrAsgnmList);
}
return "/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngDetail";
}
/**
* 기소유예 이수 / 미이수 상태 변경 처리
*/
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/updateAplctStateCdAjax.do")
public ModelAndView updateAplctStateCdAjax(
@ModelAttribute("vEEduAplctVO") VEEduAplctVO vEEduAplctVO
, ModelMap model
, HttpServletRequest request
) throws Exception {
ModelAndView modelAndView = new ModelAndView("jsonView");
//로그인 처리====================================
//로그인 정보 가져오기
String s_oprtnLoginCheckNInfo = checkLoginUtil.oprtnCheckNInfo(model);
if (!"".equals(s_oprtnLoginCheckNInfo)) {
modelAndView.addObject("result", "loginFail");
return modelAndView;
}
//로그인 처리====================================
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
SsoLoginVO ssoLoginVO = checkLoginUtil.getSSOLoginVO(request); //SSO 로그인 정보 가져오기
try {
vEEduMIXService.updateAplctStateCd(vEEduAplctVO);
modelAndView.addObject("result", "success");
} catch (Exception e) {
modelAndView.addObject("result", "");
}
return modelAndView;
}
/**
* 기소유예 신청자 상태값 변경
*/ */
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/updateEduAplctAprvlCdAjax.do") @RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/updateEduAplctAprvlCdAjax.do")
public ModelAndView updateEduAplctAprvlCd( public ModelAndView updateEduAplctAprvlCd(
@ -718,6 +823,54 @@ public class CndtnPrcsInfoMngController {
} }
return modelAndView;
}
/**
* 기소유예 교육확정상세 > 이수/미이수 체크버튼 처리
*/
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/updateAplctStateCdListAjax.do")
public ModelAndView updateAplctStateCdListAjax(
@ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO
, ModelMap model
, HttpServletRequest request
) throws Exception {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("jsonView");
//로그인 처리====================================
//로그인 정보 가져오기
String s_oprtnLoginCheckNInfo = checkLoginUtil.oprtnCheckNInfo(model);
if (!"".equals(s_oprtnLoginCheckNInfo)) {
modelAndView.addObject("result", "loginFail");
return modelAndView;
}
//로그인 처리====================================
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
try {
// 교육 신청 테이블에 신청자 상태값 update
vEAPrcsAplctPrdInstrAsgnmService.updateAplctStateCdListAjax(vEPrcsDetailVO);
// 승인 - 승인일 경우 vea_aplct_detail_info TB에 넣어줘야함
if("20".equals(vEPrcsDetailVO.getAprvlCd())) {
this.aprvlCd20(vEPrcsDetailVO,loginVO.getUniqId());
}
// 접수취소(반려) - vea_aplct_detail_info TB에 data update
else if("30".equals(vEPrcsDetailVO.getAprvlCd()))
{
this.aprvlCd30(vEPrcsDetailVO);
}
modelAndView.addObject("result", "success");
} catch (Exception ex) {
ex.printStackTrace();
modelAndView.addObject("result", "");
}
return modelAndView; return modelAndView;
} }
@ -1037,7 +1190,7 @@ public class CndtnPrcsInfoMngController {
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngList.do") @RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngList.do")
public String fndthEduPrcsAplctPrdMngList( public String cndtnEduPrcsAplctPrdMngList(
@ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO @ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO
, ModelMap model , ModelMap model
) throws Exception { ) throws Exception {
@ -1094,6 +1247,76 @@ public class CndtnPrcsInfoMngController {
return "oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngList"; return "oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngList";
} }
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngList.do")
public String cndtnEduPrcsAplctCfnMngList(
@ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO
, ModelMap model
) throws Exception {
//로그인 처리====================================
//로그인 정보 가져오기
String s_oprtnLoginCheckNInfo = checkLoginUtil.oprtnCheckNInfo(model);
if (!"".equals(s_oprtnLoginCheckNInfo)) return s_oprtnLoginCheckNInfo;
//로그인 처리====================================
//1.pageing step1
PaginationInfo paginationInfo = this.setPagingStep1(vEPrcsDetailVO);
//임시로 페이징 처리를 안하기 위해서 RecordCountPerPage 수를 10000 으로 셋팅함
//paginationInfo.setRecordCountPerPage(10000);
//2. pageing step2
vEPrcsDetailVO = this.setPagingStep2(vEPrcsDetailVO, paginationInfo);
//기반강화 조회
vEPrcsDetailVO.setLctrDivCd(LCTR_DIV_CD); //강의구분코드 VE0011 10-청소년강의, 20-성인강의, 30-체험, 50-기반강화, 60-조건부
//교육확정 목록 조회
vEPrcsDetailVO.setDdlnCd("20");
if(StringUtil.isNotEmpty(vEPrcsDetailVO.getSearchKeyword())){
String selectCondition = "AND b.PRCS_NM LIKE CONCAT ('%', '" +vEPrcsDetailVO.getSearchKeyword() + "', '%')";
vEPrcsDetailVO.setSelectPagingListQuery(selectCondition);
}
if(StringUtil.isNotEmpty(vEPrcsDetailVO.getPrcsKind())){
String[] splited = vEPrcsDetailVO.getPrcsKind().split(",");
vEPrcsDetailVO.setSearchStatusArr(splited);
}
if(StringUtil.isEmpty(vEPrcsDetailVO.getPrcsDiv())) {
//vEPrcsDetailVO.setPrcsDiv("10");// 과정구분 VE0015 10-산업종사자, 20-대학생, 30-공무원, 40-일반인, 50-청소년, 60-학부모
}
List<VEPrcsDetailVO> vEPrcsDetailVOList = vEPrcsAplctPrdService.selectPagingList4Fndth(vEPrcsDetailVO);
//3.pageing step3
paginationInfo = this.setPagingStep3(vEPrcsDetailVOList, paginationInfo);
model.addAttribute("paginationInfo", paginationInfo);
// 지정된 강사가 있는지 확인
vEPrcsDetailVOList.stream().forEach(t->{
List<VEAPrcsAplctPrdInstrAsgnmVO> vEAPrcsAplctPrdInstrAsgnmList = vEAPrcsAplctPrdInstrAsgnmService.findByPrcsAplctPrdOrd(t.getPrcsAplctPrdOrd());
if(vEAPrcsAplctPrdInstrAsgnmList.size() > 0) {
t.setInstrCnt(Integer.toString(vEAPrcsAplctPrdInstrAsgnmList.size()));
}
});
//대상 리스트, 페이징 정보 전달
model.addAttribute("list", vEPrcsDetailVOList);
return "oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngList";
}
/** /**
* 기소유예 신청기간 등록 화면 * 기소유예 신청기간 등록 화면
@ -1156,7 +1379,7 @@ public class CndtnPrcsInfoMngController {
/** /**
* 기반강화연수과정 기간 상세수정화면 * 조건부기소유예 기간 상세수정화면
*/ */
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngMdfy.do") @RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngMdfy.do")
public String cndtnEduPrcsAplctPrdMngMdfy( public String cndtnEduPrcsAplctPrdMngMdfy(
@ -1219,7 +1442,7 @@ public class CndtnPrcsInfoMngController {
/** /**
* 기반강화연수과정 신청기간 수정 * 조건부기소유예 신청기간 수정
*/ */
@RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngMdfyAjax.do") @RequestMapping("/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngMdfyAjax.do")
public ModelAndView cndtnEduPrcsAplctPrdMngMdfyAjax( public ModelAndView cndtnEduPrcsAplctPrdMngMdfyAjax(

View File

@ -151,6 +151,7 @@ public class OprtnStateMngController {
//2. pageing step2 //2. pageing step2
vEEduAplctVO = this.setPagingStep2(vEEduAplctVO, paginationInfo); vEEduAplctVO = this.setPagingStep2(vEEduAplctVO, paginationInfo);
vEEduAplctVO.setOrderByQuery("H.LAST_UPDT_PNTTM DESC, A.LAST_UPDT_PNTTM DESC , E.LAST_UPDT_PNTTM DESC");
List<VEEduAplctVO> vEEduAplctVOList = vEEduMIXService.selectPagingList(vEEduAplctVO); List<VEEduAplctVO> vEEduAplctVOList = vEEduMIXService.selectPagingList(vEEduAplctVO);
//List복호화 //List복호화

View File

@ -36,6 +36,7 @@ import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduAplctVO;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduChasiService; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduChasiService;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduChasiVO; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduChasiVO;
import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduMIXService; import kcc.ve.instr.tngrVisitEdu.eduInfo.service.VEEduMIXService;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEAPrcsAplctPrdInstrAsgnmVO;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsAplctPrdService; import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsAplctPrdService;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsDetailVO; import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsDetailVO;
import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsMIXService; import kcc.ve.instr.tngrVisitEdu.prcsInfo.service.VEPrcsMIXService;
@ -128,66 +129,6 @@ public class FndthPrcsAplctMngController {
@Resource(name = "mberManageService") @Resource(name = "mberManageService")
private EgovMberManageService mberManageService; private EgovMberManageService mberManageService;
/**
* 기반강화연수 과정 신청 관리 목록 화면
*/
@RequestMapping("/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsAplctMngList.do")
public String fndthEduPrcsAplctMngList( @ModelAttribute("vEEduAplctVO") VEEduAplctVO vEEduAplctVO , HttpSession session, ModelMap model ) throws Exception {
LoginVO user = EgovUserDetailsHelper.isAuthenticated()? (LoginVO)EgovUserDetailsHelper.getAuthenticatedUser():null;
//년도
if(StringUtils.isBlank(vEEduAplctVO.getSearchYear())){
//vEEduAplctVO.setSearchYear(String.valueOf(LocalDate.now().getYear()));
}
//
if(StringUtils.isBlank(vEEduAplctVO.getSearchMonth())){
vEEduAplctVO.setSearchMonth(String.valueOf(LocalDate.now().getMonthValue()));
}
if(!"".equals(vEEduAplctVO.getSearchChrgNm())) {
vEEduAplctVO.setSearchChrgNm(egovCryptoUtil.encrypt(vEEduAplctVO.getSearchChrgNm()));
}
// 요청, 반려건
//vEEduAplctVO.setSearchNotStatusArr(new String[]{"60"});
// 청소년
vEEduAplctVO.setLctrDivCd(VeConstants.LCTR_DIV_CD_50);
//1.pageing step1
PaginationInfo paginationInfo = this.setPagingStep1(vEEduAplctVO);
//정렬
if("".equals(vEEduAplctVO.getSearchSortCnd())){ //최초조회시 최신것 조회List
vEEduAplctVO.setOrderByQuery("A.SBMT_PNTTM DESC");
}else{
vEEduAplctVO.setOrderByQuery(vEEduAplctVO.getSearchSortCnd() + " " +vEEduAplctVO.getSearchSortOrd());
}
System.out.println("vEEduAplctVO.getOrderByQuery() :: "+ vEEduAplctVO.getOrderByQuery());
//2. pageing step2
vEEduAplctVO = this.setPagingStep2Sub(vEEduAplctVO, paginationInfo);
vEEduAplctVO.setNotiUserId(user.getUniqId());
vEEduAplctVO.setMenuNo(session.getAttribute("menuNo").toString());
/*
* 리스트 검색에서 교육일자 시작/종료일 입력 없이 검색시
* 기존 searchEndDt where 조건에 1=2로 되어있어서 리스트 검색이 안되던 것을
* 저작위 요청사항으로 1=1로 변경하여 날짜 입력이 안되어도 검색이 되도록 수정함
* 2023-04-28 우영두
*
* */
List<VEEduAplctVO> vEEduAplctVOList = vEEduMIXService.selectPagingList(vEEduAplctVO);
vEEduAplctVOList = egovCryptoUtil.decryptVEEduAplctVOList(vEEduAplctVOList);
vEEduAplctVO.setSearchChrgNm(egovCryptoUtil.decrypt(vEEduAplctVO.getSearchChrgNm()));
//3.pageing step3
paginationInfo = this.setPagingStep3(vEEduAplctVOList, paginationInfo);
model.addAttribute("paginationInfo", paginationInfo);
//대상 리스트, 페이징 정보 전달
model.addAttribute("list", vEEduAplctVOList);
return "oprtn/fndthEnhanceTrn/fndthEduPrcsAplctMngList";
}
/** /**
* 기반강화연수 신청 등록 화면 * 기반강화연수 신청 등록 화면

View File

@ -7,6 +7,7 @@ import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession; import javax.servlet.http.HttpSession;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
@ -240,6 +241,147 @@ public class FndthPrcsAplctPrdMngController {
return "oprtn/fndthEnhanceTrn/fndthEduPrcsAplctPrdMngList"; return "oprtn/fndthEnhanceTrn/fndthEduPrcsAplctPrdMngList";
///kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsMngList.do ///kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsMngList.do
} }
/**
* 기반강화연수 교육확정관리목록
*/
@RequestMapping("/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsAplctCfnMngList.do")
public String fndthEduPrcsAplctMngList( @ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO
, HttpSession session, ModelMap model ) throws Exception {
//로그인 처리====================================
//로그인 정보 가져오기
String s_oprtnLoginCheckNInfo = checkLoginUtil.oprtnCheckNInfo(model);
if (!"".equals(s_oprtnLoginCheckNInfo)) return s_oprtnLoginCheckNInfo;
//로그인 처리====================================
//1.pageing step1
PaginationInfo paginationInfo = this.setPagingStep1(vEPrcsDetailVO);
//임시로 페이징 처리를 안하기 위해서 RecordCountPerPage 수를 10000 으로 셋팅함
//paginationInfo.setRecordCountPerPage(10000);
//2. pageing step2
vEPrcsDetailVO = this.setPagingStep2(vEPrcsDetailVO, paginationInfo);
//기반강화 조회
vEPrcsDetailVO.setLctrDivCd("50"); //강의구분코드 VE0011 10-청소년강의, 20-성인강의, 30-체험, 50-기반강화, 60-조건부
//교육확정 목록 조회
vEPrcsDetailVO.setDdlnCd("20");
if(StringUtil.isNotEmpty(vEPrcsDetailVO.getSearchKeyword())){
String selectCondition = "AND b.PRCS_NM LIKE CONCAT ('%', '" +vEPrcsDetailVO.getSearchKeyword() + "', '%')";
vEPrcsDetailVO.setSelectPagingListQuery(selectCondition);
}
if(StringUtil.isNotEmpty(vEPrcsDetailVO.getPrcsKind())){
String[] splited = vEPrcsDetailVO.getPrcsKind().split(",");
vEPrcsDetailVO.setSearchStatusArr(splited);
}
if(StringUtil.isEmpty(vEPrcsDetailVO.getPrcsDiv())) {
//vEPrcsDetailVO.setPrcsDiv("10");// 과정구분 VE0015 10-산업종사자, 20-대학생, 30-공무원, 40-일반인, 50-청소년, 60-학부모
}
List<VEPrcsDetailVO> vEPrcsDetailVOList = vEPrcsAplctPrdService.selectPagingList4Fndth(vEPrcsDetailVO);
//3.pageing step3
paginationInfo = this.setPagingStep3(vEPrcsDetailVOList, paginationInfo);
model.addAttribute("paginationInfo", paginationInfo);
// 지정된 강사가 있는지 확인
vEPrcsDetailVOList.stream().forEach(t->{
List<VEAPrcsAplctPrdInstrAsgnmVO> vEAPrcsAplctPrdInstrAsgnmList = vEAPrcsAplctPrdInstrAsgnmService.findByPrcsAplctPrdOrd(t.getPrcsAplctPrdOrd());
if(vEAPrcsAplctPrdInstrAsgnmList.size() > 0) {
t.setInstrCnt(Integer.toString(vEAPrcsAplctPrdInstrAsgnmList.size()));
}
});
//대상 리스트, 페이징 정보 전달
model.addAttribute("list", vEPrcsDetailVOList);
return "oprtn/fndthEnhanceTrn/fndthEduPrcsAplctCfnMngList";
}
/**
* 조건부기소유예 기간 상세화면
*/
@RequestMapping("/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsAplctCfnMngDetail.do")
public String cndtnEduPrcsAplctCfnMngDetail(
@ModelAttribute("vEPrcsDetailVO") VEPrcsDetailVO vEPrcsDetailVO
, ModelMap model
, RedirectAttributes redirectAttributes
, HttpSession session
, HttpServletRequest request
) throws Exception {
//로그인 처리====================================
//로그인 정보 가져오기
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
SsoLoginVO ssoLoginVO = checkLoginUtil.getSSOLoginVO(request); //SSO 로그인 정보 가져오기
//과정 조회
VEPrcsDetailVO vEPrcsDetailVODetail = vEPrcsAplctPrdService.selectDetailNewOne4Fndth(vEPrcsDetailVO);
model.addAttribute("info", vEPrcsDetailVODetail);
//과정 신청자 정보 가져오기
{
//해당 과정을 제출한 사용자 정보를 가져온다.
VEEduAplctVO paramVO = new VEEduAplctVO();
paramVO.setPrcsOrd(vEPrcsDetailVO.getPrcsAplctPrdOrd());
paramVO.setSbmtYn("Y");
if(StringUtils.isNotEmpty(vEPrcsDetailVO.getSearchStatus())) {
String searchQuery = "AND vadi.APLCT_STATE_CD = "+vEPrcsDetailVO.getSearchStatus();
paramVO.setSearchQuery(searchQuery);
}
// 검색 - 날짜
paramVO.setSearchSmbtStartDt(vEPrcsDetailVO.getSearchSmbtStartDt());
paramVO.setSearchSmbtEndDt(vEPrcsDetailVO.getSearchSmbtEndDt());
// 검색 - 검색어
paramVO.setSearchStatus(vEPrcsDetailVO.getSearchStatus());
List<VEEduAplctVO> vEPrcsDetailVOList = vEEduMIXService.selectList(paramVO);
vEPrcsDetailVOList = egovCryptoUtil.decryptVeEduAplctList(vEPrcsDetailVOList);
System.out.println("====");
//대상 리스트, 페이징 정보 전달
model.addAttribute("listPrcsAplct", vEPrcsDetailVOList);
}
// 강사 배치 정보
{
System.out.println("====");
List<VEAPrcsAplctPrdInstrAsgnmVO> vEAPrcsAplctPrdInstrAsgnmList = vEAPrcsAplctPrdInstrAsgnmService.findByPrcsAplctPrdOrd(vEPrcsDetailVO.getPrcsAplctPrdOrd());
List<VEAPrcsAplctPrdInstrAsgnmVO> instrAsgnmList = egovCryptoUtil.decryptVEAPrcsAplctPrdInstrAsgnmVOList(vEAPrcsAplctPrdInstrAsgnmList);
model.addAttribute("instrAsgnmList", instrAsgnmList);
}
return "oprtn/fndthEnhanceTrn/fndthEduPrcsAplctCfnMngDetail";
}
/** /**

View File

@ -1735,8 +1735,8 @@ public class OprtnInstrTngrPrflContoller {
t_vEInstrDetailVO.setAprvlCd(vEInstrDetailVO.getAprvlCd()); t_vEInstrDetailVO.setAprvlCd(vEInstrDetailVO.getAprvlCd());
t_vEInstrDetailVO.setFirstIndex(0); t_vEInstrDetailVO.setFirstIndex(0);
List<VELctrDetailVO> selectAsgnmInfoT2List = vEInstrMixService.selectAsgnmInfoT2(t_vEInstrDetailVO); //List<VELctrDetailVO> selectAsgnmInfoT2List = vEInstrMixService.selectAsgnmInfoT2(t_vEInstrDetailVO);
model.addAttribute("asgnmInfoT2List",selectAsgnmInfoT2List); //model.addAttribute("asgnmInfoT2List",selectAsgnmInfoT2List);
return "/oprtn/tngrVisitEdu/instrMngDetail"; return "/oprtn/tngrVisitEdu/instrMngDetail";
} }
@ -1800,7 +1800,8 @@ public class OprtnInstrTngrPrflContoller {
//강의조사 기간 여부 //강의조사 기간 여부
VELctrDetailVO vELctrRsrchDetailVO = new VELctrDetailVO(); VELctrDetailVO vELctrRsrchDetailVO = new VELctrDetailVO();
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt " //vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt "
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATE,'YYYY.MM.DD') BETWEEN rsrch_strt_dt and rsrch_end_dt "
+ " AND rsrch_instr_div='"+vELctrDetailVO.getRsrchInstrDiv()+"' " + " AND rsrch_instr_div='"+vELctrDetailVO.getRsrchInstrDiv()+"' "
+ " AND stng_yr_mnt='"+vELctrDetailVO.getStngYrMnt()+"' "); + " AND stng_yr_mnt='"+vELctrDetailVO.getStngYrMnt()+"' ");
//vELctrRsrchDetailVO = vELctrRsrchMngService.selectDetail(vELctrDetailVO); //vELctrRsrchDetailVO = vELctrRsrchMngService.selectDetail(vELctrDetailVO);
@ -1953,7 +1954,8 @@ public class OprtnInstrTngrPrflContoller {
//강의조사 기간 여부 //강의조사 기간 여부
VELctrDetailVO vELctrRsrchDetailVO = new VELctrDetailVO(); VELctrDetailVO vELctrRsrchDetailVO = new VELctrDetailVO();
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt " //vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATETIME,'yyyymmdd') BETWEEN rsrch_strt_dt and rsrch_end_dt "
vELctrDetailVO.setSelectPagingListQuery(" AND TO_CHAR(SYSDATE,'YYYYMMDD') BETWEEN rsrch_strt_dt and rsrch_end_dt "
+ " AND rsrch_instr_div='"+vELctrDetailVO.getRsrchInstrDiv()+"' " + " AND rsrch_instr_div='"+vELctrDetailVO.getRsrchInstrDiv()+"' "
+ " AND stng_yr_mnt='"+vELctrDetailVO.getStngYrMnt()+"' "); + " AND stng_yr_mnt='"+vELctrDetailVO.getStngYrMnt()+"' ");
//vELctrRsrchDetailVO = vELctrRsrchMngService.selectDetail(vELctrDetailVO); //vELctrRsrchDetailVO = vELctrRsrchMngService.selectDetail(vELctrDetailVO);
@ -2174,7 +2176,8 @@ public class OprtnInstrTngrPrflContoller {
//강의조사제출값 저장 //강의조사제출값 저장
try { try {
vELctrRsrchSbmtService.insert(vELctrDetailVO); //vELctrRsrchSbmtService.insert(vELctrDetailVO);
vELctrRsrchSbmtService.update(vELctrDetailVO);
}catch(Exception ex) { }catch(Exception ex) {
ex.printStackTrace(); ex.printStackTrace();
} }

View File

@ -0,0 +1,234 @@
package kcc.ve.oprtn.instr.tngrVisitEdu.lctrRsrch.web;
import java.util.List;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import egovframework.rte.fdl.idgnr.EgovIdGnrService;
import kcc.com.cmm.EgovMessageSource;
import kcc.com.cmm.LoginVO;
import kcc.com.cmm.service.EgovCmmUseService;
import kcc.com.cmm.service.EgovFileMngService;
import kcc.com.cmm.service.EgovFileMngUtil;
import kcc.com.utl.user.service.CheckAdrProcessUtil;
import kcc.com.utl.user.service.CheckFileUtil;
import kcc.com.utl.user.service.CheckLoginUtil;
import kcc.kccadr.accdnt.acd.service.AdjstChangeDateService;
import kcc.kccadr.adjPgrMgr.cclt.service.ConciliatorManageService;
import kcc.kccadr.kccadrCom.service.KccadrMgrUdtService;
import kcc.let.utl.fcc.service.EgovCryptoUtil;
import kcc.let.utl.fcc.service.EgovCryptoUtil4VO;
import kcc.let.utl.fcc.service.VEPagingUtil;
import kcc.ve.adv.tngr.stngInfo.service.VEAStngService;
import kcc.ve.adv.tngr.stngInfo.service.VEAStngVO;
import kcc.ve.instr.tngrVisitEdu.instrInfo.service.VEInstrDetailService;
import kcc.ve.instr.tngrVisitEdu.instrInfo.service.VEInstrMixService;
import kcc.ve.instr.tngrVisitEdu.instrInfo.service.VEInstrService;
import kcc.ve.instr.tngrVisitEdu.lctrInfo.service.VELctrAreaService;
import kcc.ve.instr.tngrVisitEdu.lctrInfo.service.VELctrDetailVO;
import kcc.ve.instr.tngrVisitEdu.lctrInfo.service.VELctrMIXService;
import kcc.ve.instr.tngrVisitEdu.lctrInfo.service.VELctrPrfrnService;
import kcc.ve.instr.tngrVisitEdu.lctrInfo.service.VELctrRsrchMngService;
import kcc.ve.instr.tngrVisitEdu.lctrInfo.service.VELctrStngService;
import kcc.ve.instr.tngrVisitEdu.rsdncInfo.service.VERsdncMIXService;
/**
* OprtnLctrRsrchTngrContoller.java
* 청소년 강의 조사 관리
* 강의 조사 관리 controller 클래스를 정의한다.
* @author 이지우
* @since 2021.12.07
* @version 1.0
* @see
*
* <pre>
* << 개정이력(Modification Information) >>
*
* 수정일 수정자 수정내용
* ------- -------- ---------------------------
* 2021.12.23 이지우 최초 생성
*
* </pre>
*/
@Controller
public class AdvOprtnLctrRsrchTngrContoller {
private static final Logger LOGGER = LoggerFactory.getLogger(AdvOprtnLctrRsrchTngrContoller.class);
@Resource(name = "conciliatorManageService")
private ConciliatorManageService conciliatorManageService;
// eGov 공통 메세지
@Resource(name = "egovMessageSource")
EgovMessageSource egovMessageSource;
//로그인 체크 util
@Resource(name = "checkLoginUtil")
private CheckLoginUtil checkLoginUtil;
//파일 체크 util
@Resource(name = "checkFileUtil")
private CheckFileUtil checkFileUtil;
//암복호화 유틸
@Resource(name = "egovCryptoUtil")
EgovCryptoUtil egovCryptoUtil;
//파일정보의 관리
@Resource(name = "EgovFileMngService")
private EgovFileMngService fileService;
//파일 처리 egov
@Resource(name="EgovFileMngUtil")
private EgovFileMngUtil egovFileMngUtil;
//파일 처리 egov
@Resource(name = "EgovFileMngService")
private EgovFileMngService fileMngService;
@Resource(name="adjstChangeDateService")
private AdjstChangeDateService adjstChangeDateService;
@Resource(name="KccadrMgrUdtService")
private KccadrMgrUdtService kccadrMgrUdtService;
// 교육신청 서비스단
@Resource(name = "checkAdrProcessUtil")
private CheckAdrProcessUtil checkAdrProcessUtil;
//강사 정보
@Resource(name="vEInstrService")
private VEInstrService vEInstrService;
//강사상세 정보
@Resource(name="vEInstrDetailService")
private VEInstrDetailService vEInstrDetailService;
//강사MIX 정보
@Resource(name="vEInstrMixService")
private VEInstrMixService vEInstrMixService;
//강의설정
@Resource(name = "vELctrStngService")
private VELctrStngService vELctrStngService;
//강의설정 MIX
@Resource(name = "vELctrMIXService")
private VELctrMIXService vELctrMIXService;
//강의지역
@Resource(name = "vELctrAreaService")
private VELctrAreaService vELctrAreaService;
//강의지역 MIX
@Resource(name = "vERsdncMIXService")
private VERsdncMIXService vERsdncMIXService;
//강의선호
@Resource(name = "vELctrPrfrnService")
private VELctrPrfrnService vELctrPrfrnService;
//VO /복호화
@Resource(name="egovCryptoUtil4VO")
private EgovCryptoUtil4VO egovCryptoUtil4VO;
// eGov 공통코드
@Resource(name = "EgovCmmUseService")
private EgovCmmUseService cmmUseService;
//강의설정 ID
@Resource(name = "lctrStngGnrService")
private EgovIdGnrService lctrStngGnrService;
//강의지역 ID
@Resource(name = "lctrAreaGnrService")
private EgovIdGnrService lctrAreaGnrService;
//강의선호 ID
@Resource(name = "prfrnTrgtGnrService")
private EgovIdGnrService prfrnTrgtGnrService;
//강사신청 임의 ID
@Resource(name = "instrTempGnrService")
private EgovIdGnrService instrTempGnrService;
// 페이지 유틸
@Resource(name = "vEPagingUtil")
private VEPagingUtil vEPagingUtil;
// 강의 조사
@Resource(name = "vELctrRsrchMngService")
private VELctrRsrchMngService vELctrRsrchMngService;
//강의설정 관리
@Resource(name = "vEAStngService")
private VEAStngService vEAStngService;
/**
* 강의조사관리 기간 설정 팝업
*/
@RequestMapping("/kccadr/oprtn/tngrVisitEdu/popup/advLctrRsrchStngMngPopup.do")
public String advRndsStngMngPopup(
@ModelAttribute("vEAStngVO") VEAStngVO vEAStngVO
, @ModelAttribute("vELctrDetailVO") VELctrDetailVO vELctrDetailVO
, ModelMap model
, HttpServletRequest request
) throws Exception {
//로그인 처리====================================
//로그인 정보 가져오기
//String s_userCheckNInfo = checkLoginUtil.userCheckNInfo(model, request);
//if (!"".equals(s_userCheckNInfo)) return s_userCheckNInfo;
//로그인 처리====================================
try {
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
vEAStngVO.setFrstRegisterId(loginVO.getUniqId());
//등록된 해당 년도의 회차리스트 정보 가져오기
List<VEAStngVO> selectBasicList = vEAStngService.selectList_VEALRS(vEAStngVO);
model.addAttribute("selectBasicList", selectBasicList);
//년도 정보
//VELctrDetailVO vELctrDetailVO = new VELctrDetailVO();
List<VELctrDetailVO> selectStngYrList = vELctrMIXService.selectStngYrList(vELctrDetailVO);
model.addAttribute("selectStngYrList", selectStngYrList);
// 정보
List<VELctrDetailVO> selectStngMntList = vELctrMIXService.selectStngMntList(vELctrDetailVO);
model.addAttribute("selectStngMntList", selectStngMntList);
//선택된 조사기간 정보
//vELctrDetailVO.setStngYrMnt(stngYrMnt);
List<VELctrDetailVO> selectVELctrDetailVOList = vELctrRsrchMngService.selectList(vELctrDetailVO);
//List<VELctrDetailVO> selectVELctrDetailVOList = vELctrRsrchMngService.selectPagingList(vELctrDetailVO);
if (selectVELctrDetailVOList.size()>0) {
model.addAttribute("selectVELctrDetailVO", selectVELctrDetailVOList.get(0));
}
}catch(Exception ex)
{
ex.printStackTrace();
}
return "oprtn/tngrVisitEdu/popup/advLctrRsrchStngMngPopup";
}
}

View File

@ -17,8 +17,6 @@ import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.support.RedirectAttributes; import org.springframework.web.servlet.mvc.support.RedirectAttributes;
import com.ctc.wstx.util.DataUtil;
import egovframework.rte.fdl.idgnr.EgovIdGnrService; import egovframework.rte.fdl.idgnr.EgovIdGnrService;
import egovframework.rte.ptl.mvc.tags.ui.pagination.PaginationInfo; import egovframework.rte.ptl.mvc.tags.ui.pagination.PaginationInfo;
import kcc.com.cmm.EgovMessageSource; import kcc.com.cmm.EgovMessageSource;
@ -219,15 +217,22 @@ public class OprtnLctrRsrchTngrContoller {
// 참여현황 참여 카운트 // 참여현황 참여 카운트
t.setLctrStngOrdSbmt(Long.toString(lctrStngOrdList.stream().filter(s -> StringUtils.isNotEmpty(s)).count())); t.setLctrStngOrdSbmt(Long.toString(lctrStngOrdList.stream().filter(s -> StringUtils.isNotEmpty(s)).count()));
LocalDate startDate = DateUtil.getStringToLocalDate(t.getRsrchStrtDt()); LocalDate startDate = DateUtil.getStringToLocalDateDot(t.getRsrchStrtDt());
LocalDate endDate = DateUtil.getStringToLocalDate(t.getRsrchEndDt()); LocalDate endDate = DateUtil.getStringToLocalDateDot(t.getRsrchEndDt());
// 진행중 체크 // 진행중 체크
// 공통 코드 추가 VE0034 01 : 진행전, 02 : 진행중, 03 : 마감 // 공통 코드 추가 VE0034 01 : 진행전, 02 : 진행중, 03 : 마감
if(nowDate.isEqual(startDate) || nowDate.isEqual(endDate)) {t.setRsrchState("02");}
else if(nowDate.isBefore(startDate)) {t.setRsrchState("01");}
else if(nowDate.isAfter(endDate)) {t.setRsrchState("03");}
System.out.println("t.getRsrchState()");
System.out.println(t.getRsrchState());
System.out.println(t.getRsrchState());
if ("".equals(t.getRsrchState()) || t.getRsrchState() ==null) {
if(nowDate.isEqual(startDate) || nowDate.isEqual(endDate)) {t.setRsrchState("02");}
else if(nowDate.isBefore(startDate)) {t.setRsrchState("01");}
else if(nowDate.isAfter(endDate)) {t.setRsrchState("03");}
}
} catch (Exception e) { } catch (Exception e) {
// TODO Auto-generated catch block // TODO Auto-generated catch block
e.printStackTrace(); e.printStackTrace();
@ -279,12 +284,13 @@ public class OprtnLctrRsrchTngrContoller {
//로그인 정보 가져오기 //로그인 정보 가져오기
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기 LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"); System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1");
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"+vELctrDetailVO.getStngYrMnt()); System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"+vELctrDetailVO.getStngYrMnt());
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"+vELctrDetailVO.getRsrchStrtDt()); System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"+vELctrDetailVO.getRsrchStrtDt());
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"); System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1");
/*
vELctrDetailVO.setStngYrMnt(vELctrDetailVO.getStngYrMnt().replaceAll("[.]", "")); vELctrDetailVO.setStngYrMnt(vELctrDetailVO.getStngYrMnt().replaceAll("[.]", ""));
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa2"); System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa2");
try { try {
@ -298,6 +304,7 @@ public class OprtnLctrRsrchTngrContoller {
}catch(Exception ex) { }catch(Exception ex) {
ex.printStackTrace(); ex.printStackTrace();
} }
*/
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaa3a"); System.out.println("aaaaaaaaaaaaaaaaaaaaaaaa3a");
@ -309,9 +316,12 @@ public class OprtnLctrRsrchTngrContoller {
if (selectDupDateCount.getTotCnt()<=0) { if (selectDupDateCount.getTotCnt()<=0) {
//저장 //저장
vELctrDetailVO.setFrstRegisterId(loginVO.getUniqId()); vELctrDetailVO.setFrstRegisterId(loginVO.getUniqId());
vELctrRsrchMngService.insert(vELctrDetailVO); int i_ret = vELctrRsrchMngService.update(vELctrDetailVO);
modelAndView.addObject("result", "success"); if (i_ret>0) modelAndView.addObject("result", "success");
else modelAndView.addObject("result", "fail");
}else { }else {
modelAndView.addObject("result", "already"); modelAndView.addObject("result", "already");
} }
@ -391,5 +401,86 @@ public class OprtnLctrRsrchTngrContoller {
return "/oprtn/tngrVisitEdu/lctrRsrchMngDetail"; return "/oprtn/tngrVisitEdu/lctrRsrchMngDetail";
} }
/**
* 강의조사 요청목록 등록Ajax -
*/
@RequestMapping("lctrRsrchMngDelAjax.do")
public ModelAndView lctrRsrchMngDelAjax(
@ModelAttribute("vELctrDetailVO") VELctrDetailVO vELctrDetailVO
, ModelMap model
, RedirectAttributes redirectAttributes
, HttpSession session
, HttpServletRequest request
) throws Exception {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("jsonView");
//로그인 처리====================================
//로그인 정보 가져오기
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1");
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"+vELctrDetailVO.getStngYrMnt());
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"+vELctrDetailVO.getRsrchStrtDt());
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1");
//저장
vELctrDetailVO.setFrstRegisterId(loginVO.getUniqId());
int i_ret = vELctrRsrchMngService.delete(vELctrDetailVO);
if (i_ret>0) modelAndView.addObject("result", "success");
else modelAndView.addObject("result", "fail");
return modelAndView;
}
/**
* 강의조사 요청목록 상태변경Ajax -
*/
@RequestMapping("lctrRsrchMngChangeAjax.do")
public ModelAndView lctrRsrchMngChangeAjax(
@ModelAttribute("vELctrDetailVO") VELctrDetailVO vELctrDetailVO
, ModelMap model
, RedirectAttributes redirectAttributes
, HttpSession session
, HttpServletRequest request
) throws Exception {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("jsonView");
//로그인 처리====================================
//로그인 정보 가져오기
LoginVO loginVO = checkLoginUtil.getAuthLoginVO(); //권한에 따른 로그인 정보 가져오기
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1");
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"+vELctrDetailVO.getStngYrMnt());
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1"+vELctrDetailVO.getRsrchStrtDt());
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa1");
//저장
vELctrDetailVO.setFrstRegisterId(loginVO.getUniqId());
if ("03".equals(vELctrDetailVO.getRsrchState())) {
vELctrDetailVO.setRsrchState("00");//00-rest, 01-진행전,02-진행중,03-마감
}else {
vELctrDetailVO.setRsrchState("03");//00-rest, 01-진행전,02-진행중,03-마감
}
int i_ret = vELctrRsrchMngService.update(vELctrDetailVO);
if (i_ret>0) modelAndView.addObject("result", "success");
else modelAndView.addObject("result", "fail");
return modelAndView;
}
} }

View File

@ -284,19 +284,19 @@
<![CDATA[ <![CDATA[
AND ( ( a.NOTICE_AT != 'Y' or a.NOTICE_AT is null) AND ( ( a.NOTICE_AT != 'Y' or a.NOTICE_AT is null)
OR ( NTCE_BGNDE is null or NTCE_BGNDE ='') OR ( NTCE_BGNDE is null or NTCE_BGNDE ='')
OR ( DATE_FORMAT(now(), '%Y%m%d%H%i') < NTCE_BGNDE OR DATE_FORMAT(now(), '%Y%m%d%H%i') > NTCE_ENDDE ) OR ( TO_CHAR(SYSDATE, 'YYYYMMDDHH24MI') < NTCE_BGNDE OR TO_CHAR(SYSDATE, 'YYYYMMDDHH24MI') > NTCE_ENDDE )
) )
]]> ]]>
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="0"> <isEqual prepend="AND" property="searchCnd" compareValue="0">
<![CDATA[ a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.NTT_SJ LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="1"> <isEqual prepend="AND" property="searchCnd" compareValue="1">
<![CDATA[ a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.NTT_CN LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="2"> <isEqual prepend="AND" property="searchCnd" compareValue="2">
<![CDATA[ a.NTCR_NM LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.NTCR_NM LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isNotEmpty prepend="AND" property="mblDn"> <isNotEmpty prepend="AND" property="mblDn">
<![CDATA[ a.MBL_DN = #mblDn# ]]> <![CDATA[ a.MBL_DN = #mblDn# ]]>
@ -341,19 +341,19 @@
<![CDATA[ <![CDATA[
AND ( ( a.NOTICE_AT != 'Y' or a.NOTICE_AT is null) AND ( ( a.NOTICE_AT != 'Y' or a.NOTICE_AT is null)
OR ( NTCE_BGNDE is null or NTCE_BGNDE ='') OR ( NTCE_BGNDE is null or NTCE_BGNDE ='')
OR ( DATE_FORMAT(now(), '%Y%m%d%H%i') < NTCE_BGNDE OR DATE_FORMAT(now(), '%Y%m%d%H%i') > NTCE_ENDDE ) OR ( TO_CHAR(SYSDATE, 'YYYYMMDDHH24MI') < NTCE_BGNDE OR TO_CHAR(SYSDATE, 'YYYYMMDDHH24MI') > NTCE_ENDDE )
) )
]]> ]]>
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="0"> <isEqual prepend="AND" property="searchCnd" compareValue="0">
<![CDATA[ a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.NTT_SJ LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="1"> <isEqual prepend="AND" property="searchCnd" compareValue="1">
<![CDATA[ a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.NTT_CN LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="2"> <isEqual prepend="AND" property="searchCnd" compareValue="2">
<![CDATA[ a.NTCR_NM LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.NTCR_NM LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isNotEmpty prepend="AND" property="mblDn"> <isNotEmpty prepend="AND" property="mblDn">
<![CDATA[ a.MBL_DN = #mblDn# ]]> <![CDATA[ a.MBL_DN = #mblDn# ]]>
@ -519,7 +519,7 @@
SUBSTR(a.NTT_CN, 1, 2000) AS NTT_CN , SUBSTR(a.NTT_CN, 1, 2000) AS NTT_CN ,
a.FRST_REGISTER_ID, a.FRST_REGISTER_ID,
a.NTCR_NM as FRST_REGISTER_NM, a.NTCR_NM as FRST_REGISTER_NM,
DATE_FORMAT(a.FRST_REGIST_PNTTM, '%Y-%m-%d') as FRST_REGIST_PNTTM, TO_CHAR(a.FRST_REGIST_PNTTM, 'YYYY-MM-DD') as FRST_REGIST_PNTTM,
a.RDCNT, a.RDCNT,
a.PARNTSCTT_NO, a.PARNTSCTT_NO,
a.ANSWER_AT, a.ANSWER_AT,
@ -583,13 +583,13 @@
AND a.ANSWER_AT = 'N' /** 답변건 제외 */ AND a.ANSWER_AT = 'N' /** 답변건 제외 */
]]> ]]>
<isEqual prepend="AND" property="searchCnd" compareValue=""> <isEqual prepend="AND" property="searchCnd" compareValue="">
( a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') OR a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') ) ( a.NTT_SJ LIKE '%'||#searchWrd#||'%' OR a.NTT_CN LIKE '%'||#searchWrd#||'%' )
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="0"> <isEqual prepend="AND" property="searchCnd" compareValue="0">
a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_SJ LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="1"> <isEqual prepend="AND" property="searchCnd" compareValue="1">
a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_CN LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
<![CDATA[ <![CDATA[
) A ) A
@ -621,7 +621,7 @@
SUBSTR(a.NTT_CN, 1, 2000) AS NTT_CN , SUBSTR(a.NTT_CN, 1, 2000) AS NTT_CN ,
a.FRST_REGISTER_ID, a.FRST_REGISTER_ID,
a.NTCR_NM as FRST_REGISTER_NM, a.NTCR_NM as FRST_REGISTER_NM,
DATE_FORMAT(a.FRST_REGIST_PNTTM, '%Y-%m-%d') as FRST_REGIST_PNTTM, TO_CHAR(a.FRST_REGIST_PNTTM, 'YYYY-MM-DD') as FRST_REGIST_PNTTM,
a.RDCNT, a.RDCNT,
a.PARNTSCTT_NO, a.PARNTSCTT_NO,
a.ANSWER_AT, a.ANSWER_AT,
@ -684,13 +684,13 @@
AND a.ANSWER_AT = 'N' /** 답변건 제외 */ AND a.ANSWER_AT = 'N' /** 답변건 제외 */
]]> ]]>
<isEqual prepend="AND" property="searchCnd" compareValue=""> <isEqual prepend="AND" property="searchCnd" compareValue="">
( a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') OR a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') ) ( a.NTT_SJ LIKE '%'||#searchWrd#||'%' OR a.NTT_CN LIKE '%'||#searchWrd#||'%' )
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="0"> <isEqual prepend="AND" property="searchCnd" compareValue="0">
a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_SJ LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="1"> <isEqual prepend="AND" property="searchCnd" compareValue="1">
a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_CN LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
) A ) A
</select> </select>
@ -758,7 +758,7 @@
a.USER_TY_CD, a.USER_POSITION, a.USER_TY_CD, a.USER_POSITION,
a.PASSWORD, a.FRST_REGISTER_ID, a.NTCR_NM as FRST_REGISTER_NM, a.PASSWORD, a.FRST_REGISTER_ID, a.NTCR_NM as FRST_REGISTER_NM,
b.OFFM_TELNO, b.OFFM_TELNO,
DATE_FORMAT(a.FRST_REGIST_PNTTM, '%Y-%m-%d %H:%i') as FRST_REGIST_PNTTM, TO_CHAR(a.FRST_REGIST_PNTTM, 'YYYY-MM-DD HH24:MI') as FRST_REGIST_PNTTM,
a.NTCE_BGNDE, a.NTCE_ENDDE, a.RDCNT, a.NTCE_BGNDE, a.NTCE_ENDDE, a.RDCNT,
a.USE_AT, a.ATCH_FILE_ID, a.BBS_ID, a.NTT_ID, a.USE_AT, a.ATCH_FILE_ID, a.BBS_ID, a.NTT_ID,
a.PARNTSCTT_NO, a.ANSWER_AT, a.ANSWER_LC, a.SORT_ORDR, a.PARNTSCTT_NO, a.ANSWER_AT, a.ANSWER_LC, a.SORT_ORDR,
@ -935,9 +935,9 @@
/* BBSManageDAO.getUpDownNttIdNSj */ /* BBSManageDAO.getUpDownNttIdNSj */
<![CDATA[ <![CDATA[
SELECT SELECT
(SELECT CONCAT(NTT_ID, '|', NTT_SJ) FROM LETTNBBS (SELECT NTT_ID||'|'||NTT_SJ FROM LETTNBBS
WHERE BBS_ID = #bbsId# AND USE_AT = 'Y' AND NTT_ID = a.prevNttId) AS prevNttIdNSj WHERE BBS_ID = #bbsId# AND USE_AT = 'Y' AND NTT_ID = a.prevNttId) AS prevNttIdNSj
,(SELECT CONCAT(NTT_ID, '|', NTT_SJ) FROM LETTNBBS ,(SELECT NTT_ID||'|'||NTT_SJ FROM LETTNBBS
WHERE BBS_ID = #bbsId# AND USE_AT = 'Y' AND NTT_ID = a.nextNttId) AS nextNttIdNSj WHERE BBS_ID = #bbsId# AND USE_AT = 'Y' AND NTT_ID = a.nextNttId) AS nextNttIdNSj
FROM ( FROM (
SELECT NTT_ID SELECT NTT_ID
@ -1042,19 +1042,19 @@
]]> ]]>
WHERE 1=1 WHERE 1=1
<isEqual prepend="AND" property="searchCnd" compareValue="0"> <isEqual prepend="AND" property="searchCnd" compareValue="0">
<![CDATA[ a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.NTT_SJ LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="1"> <isEqual prepend="AND" property="searchCnd" compareValue="1">
<![CDATA[ a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.NTT_CN LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="2"> <isEqual prepend="AND" property="searchCnd" compareValue="2">
<![CDATA[ a.FRST_REGISTER_NM LIKE CONCAT ('%', #searchWrd#,'%') ]]> <![CDATA[ a.FRST_REGISTER_NM LIKE '%'||#searchWrd#||'%' ]]>
</isEqual> </isEqual>
<isNotEqual prepend="AND" property="strNttId" compareValue="0"> <isNotEqual prepend="AND" property="strNttId" compareValue="0">
<![CDATA[ a.NTT_ID LIKE CONCAT ('%', #strNttId#,'%') ]]> <![CDATA[ a.NTT_ID LIKE '%'||#strNttId#||'%' ]]>
</isNotEqual> </isNotEqual>
<isNotEmpty prepend="AND" property="bbsNm"> <isNotEmpty prepend="AND" property="bbsNm">
<![CDATA[ b.BBS_NM LIKE CONCAT ('%', #bbsNm#,'%') ]]> <![CDATA[ b.BBS_NM LIKE '%'||#bbsNm#||'%' ]]>
</isNotEmpty> </isNotEmpty>
<![CDATA[ <![CDATA[
ORDER BY a.FRST_REGIST_PNTTM DESC ORDER BY a.FRST_REGIST_PNTTM DESC
@ -1076,19 +1076,19 @@
WHERE 1=1 WHERE 1=1
]]> ]]>
<isEqual prepend="AND" property="searchCnd" compareValue="0"> <isEqual prepend="AND" property="searchCnd" compareValue="0">
a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_SJ LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="1"> <isEqual prepend="AND" property="searchCnd" compareValue="1">
a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_CN LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="2"> <isEqual prepend="AND" property="searchCnd" compareValue="2">
a.FRST_REGISTER_NM LIKE CONCAT ('%', #searchWrd#,'%') a.FRST_REGISTER_NM LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
<isNotEqual prepend="AND" property="strNttId" compareValue="0"> <isNotEqual prepend="AND" property="strNttId" compareValue="0">
a.NTT_ID LIKE CONCAT ('%', #strNttId#,'%') a.NTT_ID LIKE '%'||#strNttId#||'%'
</isNotEqual> </isNotEqual>
<isNotEmpty prepend="AND" property="bbsNm"> <isNotEmpty prepend="AND" property="bbsNm">
b.BBS_NM LIKE CONCAT ('%', #bbsNm#,'%') b.BBS_NM LIKE '%'||#bbsNm#||'%'
</isNotEmpty> </isNotEmpty>
</select> </select>
@ -1160,7 +1160,7 @@
lettnbbs_a.BBS_ID bbsId, lettnbbs_a.BBS_ID bbsId,
lettnbbs_a.NTT_SJ nttSj, lettnbbs_a.NTT_SJ nttSj,
lettnbbs_a.NTT_CN nttCn, lettnbbs_a.NTT_CN nttCn,
DATE_FORMAT(lettnbbs_a.FRST_REGIST_PNTTM , '%Y-%m-%d') frstRegisterPnttm, TO_CHAR(lettnbbs_a.FRST_REGIST_PNTTM , 'YYYY-MM-DD') frstRegisterPnttm,
'N' replyAt /* 미답변 */ 'N' replyAt /* 미답변 */
FROM FROM
( SELECT a.* FROM LETTNBBS a INNER JOIN LETTNBBSMASTER b ( SELECT a.* FROM LETTNBBS a INNER JOIN LETTNBBSMASTER b
@ -1202,7 +1202,7 @@
lettnbbs_b.BBS_ID bbsId, lettnbbs_b.BBS_ID bbsId,
lettnbbs_b.NTT_SJ nttSj, lettnbbs_b.NTT_SJ nttSj,
lettnbbs_b.NTT_CN nttCn, lettnbbs_b.NTT_CN nttCn,
DATE_FORMAT(lettnbbs_b.FRST_REGIST_PNTTM , '%Y-%m-%d') frstRegisterPnttm, TO_CHAR(lettnbbs_b.FRST_REGIST_PNTTM , 'YYYY-MM-DD') frstRegisterPnttm,
'Y' replyAt /* 답변 */ 'Y' replyAt /* 답변 */
FROM FROM
(SELECT (SELECT
@ -1313,7 +1313,7 @@
,a.NTT_CN as nttCn ,a.NTT_CN as nttCn
,a.FRST_REGIST_PNTTM as frstRegisterPnttm ,a.FRST_REGIST_PNTTM as frstRegisterPnttm
<![CDATA[ <![CDATA[
,CONCAT('/web/cop/bbs/selectBoardArticle.do?bbsId=', a.BBS_ID, '&amp;nttId=', a.NTT_ID) AS URL ,'/web/cop/bbs/selectBoardArticle.do?bbsId='||a.BBS_ID||'&amp;nttId='||a.NTT_ID AS URL
]]> ]]>
,C.MENU_NM as menuNm ,C.MENU_NM as menuNm
,'' AS menuCours ,'' AS menuCours
@ -1347,17 +1347,17 @@
AND b.USE_AT = 'Y' AND b.USE_AT = 'Y'
AND b.VIEW_AUTH = 'ROLE_ANONYMOUS' AND b.VIEW_AUTH = 'ROLE_ANONYMOUS'
<isEqual prepend="AND" property="searchCnd" compareValue="0"> <isEqual prepend="AND" property="searchCnd" compareValue="0">
a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_SJ LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="1"> <isEqual prepend="AND" property="searchCnd" compareValue="1">
a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_CN LIKE '%'|| #searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="2"> <isEqual prepend="AND" property="searchCnd" compareValue="2">
a.NTCR_NM LIKE CONCAT ('%', #searchWrd#,'%') a.NTCR_NM LIKE '%'|| #searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="3"> <isEqual prepend="AND" property="searchCnd" compareValue="3">
( a.NTT_SJ LIKE CONCAT('%' , #searchWrd#, '%') OR ( a.NTT_SJ LIKE '%'|| #searchWrd#|| '%' OR
a.NTT_CN LIKE CONCAT('%' , #searchWrd#, '%') ) a.NTT_CN LIKE '%'|| #searchWrd#|| '%' )
</isEqual> </isEqual>
/* /*
LIMIT recordCountPerPage OFFSET firstIndex LIMIT recordCountPerPage OFFSET firstIndex
@ -1398,17 +1398,17 @@
AND b.USE_AT = 'Y' AND b.USE_AT = 'Y'
AND b.VIEW_AUTH = 'ROLE_ANONYMOUS' AND b.VIEW_AUTH = 'ROLE_ANONYMOUS'
<isEqual prepend="AND" property="searchCnd" compareValue="0"> <isEqual prepend="AND" property="searchCnd" compareValue="0">
a.NTT_SJ LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_SJ LIKE '%'|| #searchWrd#'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="1"> <isEqual prepend="AND" property="searchCnd" compareValue="1">
a.NTT_CN LIKE CONCAT ('%', #searchWrd#,'%') a.NTT_CN LIKE '%'|| #searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="2"> <isEqual prepend="AND" property="searchCnd" compareValue="2">
a.NTCR_NM LIKE CONCAT ('%', #searchWrd#,'%') a.NTCR_NM LIKE '%'||#searchWrd#||'%'
</isEqual> </isEqual>
<isEqual prepend="AND" property="searchCnd" compareValue="3"> <isEqual prepend="AND" property="searchCnd" compareValue="3">
( a.NTT_SJ LIKE CONCAT('%' , #searchWrd#, '%') OR ( a.NTT_SJ LIKE '%' || #searchWrd#|| '%' OR
a.NTT_CN LIKE CONCAT('%' , #searchWrd#, '%') ) a.NTT_CN LIKE '%'|| #searchWrd#|| '%' )
</isEqual> </isEqual>
</select> </select>
@ -1444,7 +1444,7 @@
/* BBSManageDAO.selectAdminMainNewBoardCnt */ /* BBSManageDAO.selectAdminMainNewBoardCnt */
<![CDATA[ <![CDATA[
SELECT COUNT(*) FROM LETTNBBS A SELECT COUNT(*) FROM LETTNBBS A
WHERE DATE_FORMAT( A.FRST_REGIST_PNTTM , '%Y-%m-%d' ) > DATE_FORMAT(SUBDATE(NOW(), INTERVAL 7 DAY) , '%Y-%m-%d') WHERE TO_CHAR( A.FRST_REGIST_PNTTM , 'YYYY-MM-DD' ) > TO_CHAR(SUBDATE(NOW(), INTERVAL 7 DAY) , '%Y-%m-%d')
]]> ]]>
</select> </select>
@ -1460,7 +1460,7 @@
a.USER_TY_CD AS userTyCd, a.USER_TY_CD AS userTyCd,
a.PASSWORD AS password, a.PASSWORD AS password,
a.FRST_REGISTER_ID AS frstRegisterId, a.FRST_REGISTER_ID AS frstRegisterId,
DATE_FORMAT(a.FRST_REGIST_PNTTM, '%Y-%m-%d') as frstRegistPnttm , TO_CHAR(a.FRST_REGIST_PNTTM, 'YYYY-MM-DD') as frstRegistPnttm ,
a.RDCNT AS rdCt, a.RDCNT AS rdCt,
a.ATCH_FILE_ID AS atchFileId, a.ATCH_FILE_ID AS atchFileId,
a.BBS_ID AS bbsId, a.BBS_ID AS bbsId,

View File

@ -74,7 +74,7 @@
<!-- 개발자 아이디 선택용 --> <!-- 개발자 아이디 선택용 -->
<select id="loginDAO.actionLoginDev" resultMap="login"> <select id="loginDAO.actionLoginDev" resultMap="login">
<!-- 일반회원 --> <!-- 일반회원 loginDAO.actionLoginDev -->
<isNotNull property="userSe"> <isNotNull property="userSe">
<isEqual property="userSe" compareValue="GNR"> <isEqual property="userSe" compareValue="GNR">
SELECT mber_id AS id SELECT mber_id AS id
@ -357,6 +357,7 @@
<!-- 유저 권한 목록 조회 by USER_ID --> <!-- 유저 권한 목록 조회 by USER_ID -->
<select id="loginDAO.selectAuthorities" resultClass="EgovMap"> <select id="loginDAO.selectAuthorities" resultClass="EgovMap">
/* loginDAO.selectAuthorities */
<![CDATA[ <![CDATA[
/* WITH AA AS ( */ /* WITH AA AS ( */
SELECT AUTHOR_CODE FROM LETTNEMPLYRSCRTYESTBS SELECT AUTHOR_CODE FROM LETTNEMPLYRSCRTYESTBS

View File

@ -44,9 +44,9 @@
a.pnlty_id AS pnltyId, a.pnlty_id AS pnltyId,
a.pnlty_cn AS pnltyCn, a.pnlty_cn AS pnltyCn,
DATE_FORMAT(a.frst_regist_pnttm,'%Y-%m-%d') AS frstRegistPnttm, TO_CHAR(a.frst_regist_pnttm,'YYYY-MM-DD') AS frstRegistPnttm,
a.frst_register_id AS frstRegisterId, a.frst_register_id AS frstRegisterId,
DATE_FORMAT(a.last_updt_pnttm,'%Y-%m-%d') AS lastUpdtPnttm, TO_CHAR(a.last_updt_pnttm,'YYYY-MM-DD') AS lastUpdtPnttm,
a.last_updusr_id AS lastUpdusrId, a.last_updusr_id AS lastUpdusrId,
a.prvs_srvy_ord AS prvsSrvyOrd, a.prvs_srvy_ord AS prvsSrvyOrd,
@ -86,6 +86,7 @@
<!-- 강사 정보 R --> <!-- 강사 정보 R -->
<select id="VEAsgnmMIXDAO.selectDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectDetail */
SELECT SELECT
<include refid="VEAsgnmMIXDAO.select_column_name"/> <include refid="VEAsgnmMIXDAO.select_column_name"/>
FROM FROM
@ -158,6 +159,7 @@
<!-- 강사 정보 L --> <!-- 강사 정보 L -->
<select id="VEAsgnmMIXDAO.selectList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectList */
SELECT SELECT
<include refid="VEAsgnmMIXDAO.select_column_name"/> <include refid="VEAsgnmMIXDAO.select_column_name"/>
FROM FROM
@ -170,6 +172,7 @@
<!-- 강사 정보 L page --> <!-- 강사 정보 L page -->
<select id="VEAsgnmMIXDAO.selectPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectPagingList */
SELECT SELECT
COUNT(1) OVER() AS totCnt , COUNT(1) OVER() AS totCnt ,
<include refid="VEAsgnmMIXDAO.select_column_name"/> <include refid="VEAsgnmMIXDAO.select_column_name"/>
@ -188,26 +191,26 @@
<isNotEmpty property="eduAplctOrd"> <isNotEmpty property="eduAplctOrd">
AND a.edu_aplct_ord=#eduAplctOrd# AND a.edu_aplct_ord=#eduAplctOrd#
</isNotEmpty> </isNotEmpty>
ORDER BY 1
ORDER BY 1=1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, a.edu_aplct_ord desc , a.edu_aplct_ord desc
</isEmpty> </isEmpty>
<isNotEmpty property="orderByQuery"> <isNotEmpty property="orderByQuery">
, $orderByQuery$ , $orderByQuery$
</isNotEmpty> </isNotEmpty>
/*
LIMIT #recordCountPerPage# OFFSET #firstIndex# LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>
<!-- 배치 강사 정보 --> <!-- 배치 강사 정보 -->
<select id="VEAsgnmMIXDAO.selectAsgnmInstrList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectAsgnmInstrList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectAsgnmInstrList */
SELECT COUNT(1) OVER() AS totCnt SELECT COUNT(1) OVER() AS totCnt
, a.edu_aplct_ord AS eduAplctOrd , a.edu_aplct_ord AS eduAplctOrd
, b.edu_chasi_ord AS eduChasiOrd , b.edu_chasi_ord AS eduChasiOrd
@ -268,6 +271,7 @@
<!-- 강의요청 목록. 대기:배정테이블 userId가 본인, 배정코드20(수락요청) 수락:배정테이블 userId가 본인, 배정코드 30, 배정테이블에 없는 ID 거절 : 배정테이블에 코드 10(거절)--> <!-- 강의요청 목록. 대기:배정테이블 userId가 본인, 배정코드20(수락요청) 수락:배정테이블 userId가 본인, 배정코드 30, 배정테이블에 없는 ID 거절 : 배정테이블에 코드 10(거절)-->
<select id="VEAsgnmMIXDAO.selectAsgnmRqstPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectAsgnmRqstPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectAsgnmRqstPagingList */
SELECT SELECT
COUNT(1) OVER() AS totCnt , COUNT(1) OVER() AS totCnt ,
userId , userId ,
@ -501,49 +505,97 @@
AND AA.cnt = 0 AND AA.cnt = 0
</isEqual> </isEqual>
</isNotEmpty> </isNotEmpty>
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, AA.eduHopeDt DESC , AA.eduHopeDt DESC
</isEmpty> </isEmpty>
<isNotEmpty property="orderByQuery"> <isNotEmpty property="orderByQuery">
, $orderByQuery$ , $orderByQuery$
</isNotEmpty> </isNotEmpty>
LIMIT #recordCountPerPage# OFFSET #firstIndex#
/*
LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>
<!-- 강의추가요청 목록. 강의신청가능:배정테이블 코드50(추가요청) 신청완료:내역테이블 코드20(선정완료) 선정제외:내역테이블 코드30(선정제외)--> <!-- 강의추가요청 목록. 강의신청가능:배정테이블 코드50(추가요청) 신청완료:내역테이블 코드20(선정완료) 선정제외:내역테이블 코드30(선정제외)-->
<select id="VEAsgnmMIXDAO.selectAsgnmAddRqstPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectAsgnmAddRqstPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
SELECT COUNT(1) OVER() AS totCnt /* VEAsgnmMIXDAO.selectAsgnmAddRqstPagingList */
, a.user_id AS userId SELECT
, a.edu_aplct_ord AS eduAplctOrd a0.totCnt,
, a.edu_chasi_ord AS eduChasiOrd a1.user_id AS userId ,
, a.asgnm_aprvl_cd AS asgnmAprvlCd a1.edu_aplct_ord AS eduAplctOrd ,
, b.strt_tm AS strtTm a1.edu_chasi_ord AS eduChasiOrd ,
, b.end_tm AS endTm a1.asgnm_aprvl_cd AS asgnmAprvlCd ,
, b.lrn_tm AS lrnTm
, b.trgt AS trgt b.strt_tm AS strtTm ,
, b.edu_hope_dt AS eduHopeDt b.end_tm AS endTm ,
, c.lctr_div_cd AS instrDiv b.lrn_tm AS lrnTm ,
, c.edu_slct_cd AS eduSlctCd b.trgt AS trgt ,
, c.edu_slct_area_cd AS eduSlctAreaCd b.edu_hope_dt AS eduHopeDt ,
, c.schol_instt_nm AS scholInsttNm
, ((SUBSTR(b.end_tm, 1,2) - SUBSTR(b.strt_tm, 1,2)) * 60) + (SUBSTR(b.end_tm, 3,4) - SUBSTR(b.strt_tm, 3,4)) AS eduTM c.lctr_div_cd AS instrDiv ,
, MAX(d.hstry_cd) AS hstryCd c.edu_slct_cd AS eduSlctCd ,
, (SELECT COUNT(1) FROM ve_new_noti e WHERE a.edu_chasi_ord = e.tbl_uniq_ord AND e.menu_no = #menuNo# AND e.frst_register_id = #userId# ) AS notiCnt c.edu_slct_area_cd AS eduSlctAreaCd ,
, (SELECT code_nm FROM lettccmmndetailcode e WHERE e.code_id = 'VE0008' AND e.code = c.edu_slct_area_cd) AS eduSlctAreaNm c.schol_instt_nm AS scholInsttNm ,
FROM ve_edu_chasi_instr_asgnm a
INNER JOIN ve_edu_chasi b ((SUBSTR(b.end_tm, 1,2) - SUBSTR(b.strt_tm, 1,2)) * 60) + (SUBSTR(b.end_tm, 3,4) - SUBSTR(b.strt_tm, 3,4)) AS eduTM ,
ON ( a.edu_aplct_ord = b.edu_aplct_ord
AND a.edu_chasi_ord = b.edu_chasi_ord (SELECT COUNT(1)
) FROM ve_new_noti e
INNER JOIN ve_edu_aplct c WHERE a1.edu_chasi_ord = e.tbl_uniq_ord
ON b.edu_aplct_ord = c.edu_aplct_ord AND e.menu_no = #menuNo#
LEFT OUTER JOIN ve_edu_chasi_instr_asgnm_hstry d AND e.frst_register_id = #userId#
ON (a.edu_aplct_ord = d.edu_aplct_ord )
AND a.edu_chasi_ord = d.edu_chasi_ord AS notiCnt ,
AND d.user_id = #userId#) (SELECT code_nm
WHERE 1=1 FROM lettccmmndetailcode e
AND a.asgnm_aprvl_cd = #asgnmAprvlCd# WHERE e.code_id = 'VE0008'
AND e.code = c.edu_slct_area_cd
)
AS eduSlctAreaNm,
a0.hstryCd
FROM (
SELECT COUNT(1) OVER() AS totCnt ,
a.user_id ,
a.edu_aplct_ord ,
a.edu_chasi_ord ,
MAX(d.hstry_cd) AS hstryCd
FROM ve_edu_chasi_instr_asgnm a
LEFT OUTER JOIN ve_edu_chasi_instr_asgnm_hstry d
ON (
a.edu_aplct_ord = d.edu_aplct_ord
AND a.edu_chasi_ord = d.edu_chasi_ord
AND d.user_id = #userId#
)
WHERE 1 =1
AND a.asgnm_aprvl_cd = #asgnmAprvlCd#
GROUP by
a.user_id ,
a.edu_aplct_ord ,
a.edu_chasi_ord
)a0
,ve_edu_chasi_instr_asgnm a1
INNER JOIN ve_edu_chasi b
ON (
a1.edu_aplct_ord = b.edu_aplct_ord
AND a1.edu_chasi_ord = b.edu_chasi_ord
)
INNER JOIN ve_edu_aplct c
ON b.edu_aplct_ord = c.edu_aplct_ord
WHERE a0.user_id=a1.user_id
AND a0.edu_aplct_ord=a1.edu_aplct_ord
AND a0.edu_chasi_ord=a1.edu_chasi_ord
AND c.lctr_div_cd = #instrDiv# AND c.lctr_div_cd = #instrDiv#
<isNotEmpty property="searchEduHopeStartDt"> <isNotEmpty property="searchEduHopeStartDt">
AND b.edu_hope_dt <![CDATA[ >= ]]> REPLACE(#searchEduHopeStartDt#, '.' , '') AND b.edu_hope_dt <![CDATA[ >= ]]> REPLACE(#searchEduHopeStartDt#, '.' , '')
@ -554,19 +606,25 @@
<isNotEmpty property="searchKeyword"> <isNotEmpty property="searchKeyword">
AND c.SCHOL_INSTT_NM LIKE CONCAT('%' , #searchKeyword# , '%') AND c.SCHOL_INSTT_NM LIKE CONCAT('%' , #searchKeyword# , '%')
</isNotEmpty> </isNotEmpty>
GROUP BY eduAplctOrd, eduChasiOrd, userId
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, a.frst_regist_pnttm desc , a1.frst_regist_pnttm desc
</isEmpty> </isEmpty>
<isNotEmpty property="orderByQuery"> <isNotEmpty property="orderByQuery">
, $orderByQuery$ , $orderByQuery$
</isNotEmpty> </isNotEmpty>
LIMIT #recordCountPerPage# OFFSET #firstIndex#
/*
LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>
<!-- 강의내역(확정) 목록. 배정테이블 ID가 본인이면서 코드30(교육확정)--> <!-- 강의내역(확정) 목록. 배정테이블 ID가 본인이면서 코드30(교육확정)-->
<select id="VEAsgnmMIXDAO.selectAsgnmPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectAsgnmPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectAsgnmPagingList */
SELECT SELECT
COUNT(1) OVER() AS totCnt COUNT(1) OVER() AS totCnt
,userId ,userId
@ -661,23 +719,31 @@
/* 종료교육에 대한 조건 추가 */ /* 종료교육에 대한 조건 추가 */
<isNotEmpty property="selectPagingListQuery"> <isNotEmpty property="selectPagingListQuery">
<isEqual property="selectPagingListQuery" compareValue="END"> <isEqual property="selectPagingListQuery" compareValue="END">
/*
AND IF (DATE_FORMAT(SYSDATE,'%Y%m%d%H%i')>CONCAT(eduHopeDt,endTm),1,0)>0 AND IF (DATE_FORMAT(SYSDATE,'%Y%m%d%H%i')>CONCAT(eduHopeDt,endTm),1,0)>0
*/
AND CASE WHEN TO_CHAR(SYSDATE,'YYYYMMDDHH24MI')>eduHopeDt||endTm THEN 1 ELSE 0 END > 0
</isEqual> </isEqual>
</isNotEmpty> </isNotEmpty>
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, AA.eduHopeDt desc , AA.eduHopeDt desc
</isEmpty> </isEmpty>
<isNotEmpty property="orderByQuery"> <isNotEmpty property="orderByQuery">
, $orderByQuery$ , $orderByQuery$
</isNotEmpty> </isNotEmpty>
LIMIT #recordCountPerPage# OFFSET #firstIndex#
/*
LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>
<!-- 강의요청 상세 정보 R --> <!-- 강의요청 상세 정보 R -->
<select id="VEAsgnmMIXDAO.selectAsgnmRqstDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectAsgnmRqstDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectAsgnmRqstDetail */
SELECT a.edu_hope_dt AS eduHopeDt SELECT a.edu_hope_dt AS eduHopeDt
, a.edu_aplct_ord AS eduAplctOrd , a.edu_aplct_ord AS eduAplctOrd
, a.edu_chasi_ord AS eduChasiOrd , a.edu_chasi_ord AS eduChasiOrd
@ -728,6 +794,7 @@
<!-- 강의요청 상세 정보 R 4 강의요청목록--> <!-- 강의요청 상세 정보 R 4 강의요청목록-->
<select id="VEAsgnmMIXDAO.selectAsgnmRqstDetail4" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectAsgnmRqstDetail4" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectAsgnmRqstDetail4 */
SELECT a.edu_hope_dt AS eduHopeDt SELECT a.edu_hope_dt AS eduHopeDt
, a.edu_aplct_ord AS eduAplctOrd , a.edu_aplct_ord AS eduAplctOrd
, a.edu_chasi_ord AS eduChasiOrd , a.edu_chasi_ord AS eduChasiOrd
@ -780,6 +847,7 @@
<!-- 강의 추가요청 상세 정보 R --> <!-- 강의 추가요청 상세 정보 R -->
<select id="VEAsgnmMIXDAO.selectAsgnmAddRqstDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectAsgnmAddRqstDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectAsgnmAddRqstDetail */
SELECT a.edu_hope_dt AS eduHopeDt SELECT a.edu_hope_dt AS eduHopeDt
, a.edu_aplct_ord AS eduAplctOrd , a.edu_aplct_ord AS eduAplctOrd
, a.edu_chasi_ord AS eduChasiOrd , a.edu_chasi_ord AS eduChasiOrd
@ -824,6 +892,7 @@
<!-- 강의확정내역 상세 정보 R --> <!-- 강의확정내역 상세 정보 R -->
<select id="VEAsgnmMIXDAO.selectAsgnmDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectAsgnmDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectAsgnmDetail */
SELECT a.edu_hope_dt AS eduHopeDt SELECT a.edu_hope_dt AS eduHopeDt
, a.edu_aplct_ord AS eduAplctOrd , a.edu_aplct_ord AS eduAplctOrd
, a.edu_chasi_ord AS eduChasiOrd , a.edu_chasi_ord AS eduChasiOrd
@ -3092,7 +3161,7 @@
<!-- 강사자동배정 온라인--> <!-- 강사자동배정 온라인-->
<select id="VEAsgnmMIXDAO.selectInstrAsgnmOnList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrAsgnmOnList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* /*
온라인 청소년 온라인 청소년 VEAsgnmMIXDAO.selectInstrAsgnmOnList
*/ */
SELECT aaaa.edu_aplct_ord AS eduAplctOrd SELECT aaaa.edu_aplct_ord AS eduAplctOrd
, aaaa.edu_chasi_ord AS eduChasiOrd , aaaa.edu_chasi_ord AS eduChasiOrd
@ -3124,7 +3193,7 @@
<!-- 강사자동배정 온라인--> <!-- 강사자동배정 온라인-->
<select id="VEAsgnmMIXDAO.selectInstrAsgnmOnList_220210" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrAsgnmOnList_220210" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* /*
온라인 청소년 온라인 청소년 VEAsgnmMIXDAO.selectInstrAsgnmOnList_220210
*/ */
SELECT aaaaaa.edu_aplct_ord AS eduAplctOrd SELECT aaaaaa.edu_aplct_ord AS eduAplctOrd
, aaaaaa.edu_chasi_ord AS eduChasiOrd , aaaaaa.edu_chasi_ord AS eduChasiOrd
@ -3210,7 +3279,7 @@
<!-- 강사자동배정 오프라인--> <!-- 강사자동배정 오프라인-->
<select id="VEAsgnmMIXDAO.selectInstrAsgnmOffList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrAsgnmOffList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* /*
오프라인 청소년 오프라인 청소년 VEAsgnmMIXDAO.selectInstrAsgnmOffList
*/ */
SELECT aaaa.edu_aplct_ord AS eduAplctOrd SELECT aaaa.edu_aplct_ord AS eduAplctOrd
, aaaa.edu_chasi_ord AS eduChasiOrd , aaaa.edu_chasi_ord AS eduChasiOrd
@ -3241,7 +3310,7 @@
<!-- 강사자동배정 오프라인--> <!-- 강사자동배정 오프라인-->
<select id="VEAsgnmMIXDAO.selectInstrAsgnmOffList_220210" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrAsgnmOffList_220210" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* /*
오프라인 청소년 자동배정 오프라인 청소년 자동배정 VEAsgnmMIXDAO.selectInstrAsgnmOffList_220210
*/ */
SELECT aaaaaa.edu_aplct_ord AS eduAplctOrd SELECT aaaaaa.edu_aplct_ord AS eduAplctOrd
, aaaaaa.edu_chasi_ord AS eduChasiOrd , aaaaaa.edu_chasi_ord AS eduChasiOrd
@ -3326,6 +3395,7 @@
<!-- 강의차시정보 --> <!-- 강의차시정보 -->
<select id="VEAsgnmMIXDAO.selectInstrAsgnmStep0" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrAsgnmStep0" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectInstrAsgnmStep0 */
SELECT b.edu_aplct_ord AS eduAplctOrd SELECT b.edu_aplct_ord AS eduAplctOrd
, b.edu_chasi_ord AS eduChasiOrd , b.edu_chasi_ord AS eduChasiOrd
, a.edu_slct_cd AS eduSlctCd , a.edu_slct_cd AS eduSlctCd
@ -3342,7 +3412,7 @@
<!-- 강사자동배정 페이지 리스트 온라인--> <!-- 강사자동배정 페이지 리스트 온라인-->
<select id="VEAsgnmMIXDAO.selectInstrAsgnmOnPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrAsgnmOnPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* /*
온라인 청소년 온라인 청소년 VEAsgnmMIXDAO.selectInstrAsgnmOnPagingList
*/ */
SELECT COUNT(1) OVER() AS totCnt SELECT COUNT(1) OVER() AS totCnt
, aaaa.edu_aplct_ord AS eduAplctOrd , aaaa.edu_aplct_ord AS eduAplctOrd
@ -3847,13 +3917,16 @@
/* , aaaaaa.lrn_tm_sum/(aaaaaa.mnt_mnmm_tm+1) 9.수업 할당 */ /* , aaaaaa.lrn_tm_sum/(aaaaaa.mnt_mnmm_tm+1) 9.수업 할당 */
, aaaaaa.lrn_tm_sum /* 9.수업 할당 */ , aaaaaa.lrn_tm_sum /* 9.수업 할당 */
LIMIT #recordCountPerPage# OFFSET #firstIndex# /*
LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>
<!-- 강사자동배정 페이지 리스트 오프라인--> <!-- 강사자동배정 페이지 리스트 오프라인-->
<select id="VEAsgnmMIXDAO.selectInstrAsgnmOffPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrAsgnmOffPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* /*
오프라인 청소년 오프라인 청소년 VEAsgnmMIXDAO.selectInstrAsgnmOffPagingList
*/ */
SELECT COUNT(1) OVER() AS totCnt SELECT COUNT(1) OVER() AS totCnt
, aaaa.edu_aplct_ord AS eduAplctOrd , aaaa.edu_aplct_ord AS eduAplctOrd
@ -4347,7 +4420,11 @@
/* , aaaaaa.lrn_tm_sum/(aaaaaa.mnt_mnmm_tm+1) 9.수업 할당 */ /* , aaaaaa.lrn_tm_sum/(aaaaaa.mnt_mnmm_tm+1) 9.수업 할당 */
, aaaaaa.lrn_tm_sum /* 9.수업 할당 */ , aaaaaa.lrn_tm_sum /* 9.수업 할당 */
LIMIT #recordCountPerPage# OFFSET #firstIndex#
/*
LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>
@ -4364,6 +4441,7 @@
<!-- 대량강사자동배정을 위한 신청, 차시 리스트 --> <!-- 대량강사자동배정을 위한 신청, 차시 리스트 -->
<select id="VEAsgnmMIXDAO.selectInstrMassAsgnmStep0_EA" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrMassAsgnmStep0_EA" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectInstrMassAsgnmStep0_EA */
SELECT b.edu_aplct_ord AS eduAplctOrd SELECT b.edu_aplct_ord AS eduAplctOrd
, b.edu_chasi_ord AS eduChasiOrd , b.edu_chasi_ord AS eduChasiOrd
, a.edu_slct_cd AS eduSlctCd , a.edu_slct_cd AS eduSlctCd
@ -4381,6 +4459,7 @@
<!-- 대량강사자동배정을 위한 신청, 차시 리스트 --> <!-- 대량강사자동배정을 위한 신청, 차시 리스트 -->
<select id="VEAsgnmMIXDAO.selectInstrMassAsgnmStep0" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrMassAsgnmStep0" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectInstrMassAsgnmStep0 */
SELECT b.edu_aplct_ord AS eduAplctOrd SELECT b.edu_aplct_ord AS eduAplctOrd
, b.edu_chasi_ord AS eduChasiOrd , b.edu_chasi_ord AS eduChasiOrd
, a.edu_slct_cd AS eduSlctCd /*10-온라인, 20-오프라인*/ , a.edu_slct_cd AS eduSlctCd /*10-온라인, 20-오프라인*/
@ -4402,6 +4481,7 @@
<!-- 대량강사삭제를 위한 신청, 차시 리스트 --> <!-- 대량강사삭제를 위한 신청, 차시 리스트 -->
<select id="VEAsgnmMIXDAO.selectInstrMassAsgnmDeleteStep0" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrMassAsgnmDeleteStep0" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectInstrMassAsgnmDeleteStep0 */
SELECT b.edu_aplct_ord AS eduAplctOrd SELECT b.edu_aplct_ord AS eduAplctOrd
, b.edu_chasi_ord AS eduChasiOrd , b.edu_chasi_ord AS eduChasiOrd
, b.user_id AS userId , b.user_id AS userId
@ -4420,6 +4500,7 @@
<!-- 강사대량 거리 계산을 위한 대상 step1--> <!-- 강사대량 거리 계산을 위한 대상 step1-->
<select id="VEAsgnmMIXDAO.selectInstrDstncStep1" parameterClass="VEEduAplctVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrDstncStep1" parameterClass="VEEduAplctVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectInstrDstncStep1 */
SELECT b.new_addr AS sAddr SELECT b.new_addr AS sAddr
, d.addr AS iAddr , d.addr AS iAddr
, ifnull(e.oneway_dstnc,'') AS onewayDstnc , ifnull(e.oneway_dstnc,'') AS onewayDstnc
@ -4514,6 +4595,7 @@
<!-- 강사대량 거리 계산을 위한 대상 step2--> <!-- 강사대량 거리 계산을 위한 대상 step2-->
<select id="VEAsgnmMIXDAO.selectInstrDstncStep2Paging" parameterClass="VEEduAplctVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrDstncStep2Paging" parameterClass="VEEduAplctVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectInstrDstncStep2Paging */
SELECT b.new_addr AS sAddr SELECT b.new_addr AS sAddr
, d.addr AS iAddr , d.addr AS iAddr
, ifnull(e.oneway_dstnc,'') AS onewayDstnc , ifnull(e.oneway_dstnc,'') AS onewayDstnc
@ -4599,6 +4681,7 @@
<!-- 강사대량 거리 계산을 위한 대상 step1--> <!-- 강사대량 거리 계산을 위한 대상 step1-->
<select id="VEAsgnmMIXDAO.selectInstrDstncStep3" parameterClass="VEEduAplctVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrDstncStep3" parameterClass="VEEduAplctVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectInstrDstncStep3 */
SELECT b.new_addr AS sAddr SELECT b.new_addr AS sAddr
, d.addr AS iAddr , d.addr AS iAddr
, ifnull(e.oneway_dstnc,'') AS onewayDstnc , ifnull(e.oneway_dstnc,'') AS onewayDstnc
@ -4688,6 +4771,7 @@
<!-- //동일 일자에 강사 배정 여부 체크--> <!-- //동일 일자에 강사 배정 여부 체크-->
<select id="VEAsgnmMIXDAO.selectInstrAsgnmScholCheck" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectInstrAsgnmScholCheck" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectInstrAsgnmScholCheck */
SELECT c.schol_instt_nm AS scholInsttNm SELECT c.schol_instt_nm AS scholInsttNm
FROM ve_edu_chasi_instr_asgnm a FROM ve_edu_chasi_instr_asgnm a
, ve_edu_chasi b , ve_edu_chasi b
@ -4724,6 +4808,7 @@
<!-- 배정 최대값 제한 산술식을 위한 해당 교육 차시에 속한 달의 강사 교육접수차시 가져오기 R --> <!-- 배정 최대값 제한 산술식을 위한 해당 교육 차시에 속한 달의 강사 교육접수차시 가져오기 R -->
<select id="VEAsgnmMIXDAO.selectTtlMntChasiSumDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.selectTtlMntChasiSumDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.selectTtlMntChasiSumDetail */
SELECT aa0.sumMntChasi , SELECT aa0.sumMntChasi ,
bb0.sumMntLctr , bb0.sumMntLctr ,
CEIL(CAST(aa0.sumMntChasi AS DOUBLE)/bb0.sumMntLctr) AS mxmmChasi CEIL(CAST(aa0.sumMntChasi AS DOUBLE)/bb0.sumMntLctr) AS mxmmChasi
@ -4796,6 +4881,7 @@
<!-- 강의내역(확정) 목록. 배정테이블 ID가 본인이면서 코드30(교육확정)--> <!-- 강의내역(확정) 목록. 배정테이블 ID가 본인이면서 코드30(교육확정)-->
<select id="VEAsgnmMIXDAO.findByAcmdtCnfrm" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEAsgnmMIXDAO.findByAcmdtCnfrm" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEAsgnmMIXDAO.findByAcmdtCnfrm */
SELECT SELECT
vaa.sbmt_yn as acmdtSbmtYn vaa.sbmt_yn as acmdtSbmtYn
, vaa.aprvl_cd as acmdtAprvlCd , vaa.aprvl_cd as acmdtAprvlCd

View File

@ -26,7 +26,7 @@
a.edu_aplct_ord AS eduAplctOrd, a.edu_aplct_ord AS eduAplctOrd,
a.edu_chasi_ord AS eduChasiOrd, a.edu_chasi_ord AS eduChasiOrd,
a.pnlty_cd AS pnltyCd, a.pnlty_cd AS pnltyCd,
DATE_FORMAT(a.frst_regist_pnttm,'%Y-%m-%d') AS frstRegistPnttm, TO_CHAR(a.frst_regist_pnttm,'YYYY-MM-DD') AS frstRegistPnttm,
a.frst_register_id AS frstRegisterId, a.frst_register_id AS frstRegisterId,
a.user_id AS userId a.user_id AS userId
</sql> </sql>
@ -63,6 +63,7 @@
<!-- 패널티 정보 R --> <!-- 패널티 정보 R -->
<select id="VEEduPnltyDAO.selectDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEEduPnltyDAO.selectDetail" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEEduPnltyDAO.selectDetail */
SELECT SELECT
<include refid="VEEduPnltyDAO.select_column_name"/> <include refid="VEEduPnltyDAO.select_column_name"/>
FROM FROM
@ -103,10 +104,11 @@
<!-- 패널티 정보 L --> <!-- 패널티 정보 L -->
<select id="VEEduPnltyDAO.selectList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEEduPnltyDAO.selectList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEEduPnltyDAO.selectList */
SELECT SELECT
<include refid="VEEduPnltyDAO.select_column_name"/> <include refid="VEEduPnltyDAO.select_column_name"/>
,b.schol_instt_nm AS scholInsttNm ,b.schol_instt_nm AS scholInsttNm
,DATE_FORMAT(c.edu_hope_dt,'%Y.%m.%d') AS eduHopeDt ,TO_CHAR(c.edu_hope_dt,'YYYY.MM.DD') AS eduHopeDt
,c.strt_tm AS strtTm ,c.strt_tm AS strtTm
,c.end_tm AS endTm ,c.end_tm AS endTm
,c.lrn_tm AS lrnTm ,c.lrn_tm AS lrnTm
@ -135,6 +137,7 @@
<!-- 패널티 정보 L page --> <!-- 패널티 정보 L page -->
<select id="VEEduPnltyDAO.selectPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO"> <select id="VEEduPnltyDAO.selectPagingList" parameterClass="VEInstrAsgnmVO" resultClass="VEInstrAsgnmVO">
/* VEEduPnltyDAO.selectPagingList */
SELECT SELECT
COUNT(1) OVER() AS totCnt , COUNT(1) OVER() AS totCnt ,
<include refid="VEEduPnltyDAO.select_column_name"/> <include refid="VEEduPnltyDAO.select_column_name"/>
@ -157,7 +160,7 @@
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, a.edu_aplct_ord desc , a.edu_aplct_ord desc
@ -166,8 +169,10 @@
, $orderByQuery$ , $orderByQuery$
</isNotEmpty> </isNotEmpty>
/*
LIMIT #recordCountPerPage# OFFSET #firstIndex# LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>

View File

@ -109,11 +109,10 @@
/* cndtnTrgtInfoMngDAO.update */ /* cndtnTrgtInfoMngDAO.update */
UPDATE UPDATE
<include refid="CndtnTrgtInfoMngDAO.table_name"/> <include refid="CndtnTrgtInfoMngDAO.table_name"/>
SET SET
user_id = #userId# edu_state_cd = #eduStateCd#
, edu_state_cd = #eduStateCd# , last_updt_pnttm = SYSDATE
, last_updt_pnttm = SYSDATE , last_updusr_id = #lastUpdusrId#
, last_updusr_id = #lastUpdusrId#
, trgt_nm = #trgtNm# , trgt_nm = #trgtNm#
, clphone = #clphone# , clphone = #clphone#
, d_birth = #dBirth# , d_birth = #dBirth#
@ -131,6 +130,18 @@
WHERE WHERE
sspn_idtmt_trgt_ord = #sspnIdtmtTrgtOrd# sspn_idtmt_trgt_ord = #sspnIdtmtTrgtOrd#
</update> </update>
<!-- 대상자 조회 후 대상자에 로그인 ID update -->
<update id="cndtnTrgtInfoMngDAO.updateUserId" parameterClass="CndtnPrcsInfoMngVO">
/* cndtnTrgtInfoMngDAO.updateSspnIdtmtTrgtOrd */
UPDATE
<include refid="CndtnTrgtInfoMngDAO.table_name"/>
SET
user_id = #userId#
, req_state_cd = #reqStateCd#
WHERE
sspn_idtmt_trgt_ord = #sspnIdtmtTrgtOrd#
</update>
<!-- 기소유예 대상자 R --> <!-- 기소유예 대상자 R -->
<select id="cndtnTrgtInfoMngDAO.selectPagingList" parameterClass="CndtnPrcsInfoMngVO" resultClass="CndtnPrcsInfoMngVO"> <select id="cndtnTrgtInfoMngDAO.selectPagingList" parameterClass="CndtnPrcsInfoMngVO" resultClass="CndtnPrcsInfoMngVO">
@ -157,6 +168,19 @@
</select> </select>
<!-- 기소유예 대상자 확인 -->
<select id="cndtnTrgtInfoMngDAO.findByTrgtNm" parameterClass="CndtnPrcsInfoMngVO" resultClass="String">
SELECT
sspn_idtmt_trgt_ord AS sspnIdtmtTrgtOrd
FROM
<include refid="CndtnTrgtInfoMngDAO.table_name"/> a
WHERE
a.trgt_nm = #trgtNm#
AND a.d_birth = #dBirth#
AND a.user_id IS null
</select>

View File

@ -117,7 +117,7 @@
</select> </select>
<!-- 강사 정보 L --> <!-- -->
<select id="VEEduMIXDAO.selectList" parameterClass="VEEduAplctVO" resultClass="VEEduAplctVO"> <select id="VEEduMIXDAO.selectList" parameterClass="VEEduAplctVO" resultClass="VEEduAplctVO">
/* VEEduMIXDAO.selectList */ /* VEEduMIXDAO.selectList */
SELECT SELECT
@ -149,6 +149,63 @@
AND a.aprvl_cd = #searchSelStatus# AND a.aprvl_cd = #searchSelStatus#
</isNotEmpty> </isNotEmpty>
<isNotEmpty property="searchQuery">
$searchQuery$
</isNotEmpty>
<isNotEmpty property="searchSmbtStartDt">
AND TO_CHAR(a.sbmt_pnttm, 'YYYYMMDD') <![CDATA[ >= ]]> REPLACE(#searchSmbtStartDt#, '.' , '')
</isNotEmpty>
<isNotEmpty property="searchSmbtEndDt">
AND TO_CHAR(a.sbmt_pnttm, 'YYYYMMDD') <![CDATA[ <= ]]> REPLACE(#searchSmbtEndDt#, '.' , '')
</isNotEmpty>
AND a.use_yn = 'Y'
</select>
<!-- -->
<select id="VEEduMIXDAO.selectTrgtList" parameterClass="VEEduAplctVO" resultClass="VEEduAplctVO">
/* VEEduMIXDAO.selectList */
SELECT
qe.QESTNR_ID AS qestnrId , /* 설문했으면 ID가 있음 */
vadi.APLCT_STATE_CD AS aplctStateCd, /* 이수 상태 */
le.MBER_NM AS userNm,
<include refid="VEEduMIXDAO.select_column_name"/>,
vsit.trgt_nm AS trgtNm,
vsit.clphone AS vs_clphone,
vsit.d_birth AS dBirth
FROM
<include refid="VEEduMIXDAO.table_name"/> a
JOIN ve_prcs_aplct_prd vpap ON
a.PRCS_ORD = vpap.PRCS_APLCT_PRD_ORD
LEFT JOIN VEA_APLCT_DETAIL_INFO vadi ON
a.EDU_APLCT_ORD = vadi.EDU_APLCT_ORD
/* AND vpap.PRCS_APLCT_PRD_ORD = vadi.PRCS_APLCT_PRD_ORD */
JOIN LETTNGNRLMBER le ON
a.USER_ID = le.MBER_ID
LEFT JOIN LETTNQESTNRINFO qe ON
a.USER_ID = qe.FRST_REGISTER_ID
LEFT JOIN VEA_SSPN_IDMT_TRGT vsit
ON a.user_id = vsit.user_id
WHERE
1=1
<isNotEmpty property="prcsOrd">
AND a.prcs_ord=#prcsOrd#
</isNotEmpty>
<isNotEmpty property="sbmtYn">
AND a.sbmt_yn=#sbmtYn#
</isNotEmpty>
<isNotEmpty property="searchSelStatus">
AND a.aprvl_cd = #searchSelStatus#
</isNotEmpty>
<isNotEmpty property="searchQuery">
$searchQuery$
</isNotEmpty>
<isNotEmpty property="searchSmbtStartDt"> <isNotEmpty property="searchSmbtStartDt">
AND TO_CHAR(a.sbmt_pnttm, 'YYYYMMDD') <![CDATA[ >= ]]> REPLACE(#searchSmbtStartDt#, '.' , '') AND TO_CHAR(a.sbmt_pnttm, 'YYYYMMDD') <![CDATA[ >= ]]> REPLACE(#searchSmbtStartDt#, '.' , '')
</isNotEmpty> </isNotEmpty>
@ -490,7 +547,9 @@
FROM ve_prcs_cmplt_detail FROM ve_prcs_cmplt_detail
GROUP BY edu_aplct_ord, edu_strt_dt, edu_end_dt , TO_CHAR(sbmt_pnttm,'YYYYMMDD') GROUP BY edu_aplct_ord, edu_strt_dt, edu_end_dt , TO_CHAR(sbmt_pnttm,'YYYYMMDD')
) G ) G
ON A.EDU_APLCT_ORD = G.EDU_APLCT_ORD ON A.EDU_APLCT_ORD = G.EDU_APLCT_ORD
LEFT OUTER JOIN ve_edu_rslt_rprt H
ON A.EDU_APLCT_ORD = H.EDU_APLCT_ORD
WHERE 1=1 WHERE 1=1
/* /*
@ -542,6 +601,13 @@
<isNotEmpty property="searchEndSbmtPnttm"> <isNotEmpty property="searchEndSbmtPnttm">
AND TO_CHAR(A.SBMT_PNTTM,'YYYYMMDD') <![CDATA[ <= ]]> REPLACE(#searchEndSbmtPnttm#, '.' , '') AND TO_CHAR(A.SBMT_PNTTM,'YYYYMMDD') <![CDATA[ <= ]]> REPLACE(#searchEndSbmtPnttm#, '.' , '')
</isNotEmpty> </isNotEmpty>
<isNotEmpty property="searchStartRegistPnttm">
AND TO_CHAR(A.FRST_REGIST_PNTTM,'YYYYMMDD') <![CDATA[ >= ]]> REPLACE(#searchStartRegistPnttm#, '.' , '')
</isNotEmpty>
<isNotEmpty property="searchEndRegistPnttm">
AND TO_CHAR(A.FRST_REGIST_PNTTM,'YYYYMMDD') <![CDATA[ <= ]]> REPLACE(#searchEndRegistPnttm#, '.' , '')
</isNotEmpty>
<isNotEmpty property="searchStratAprvlPnttm"> <isNotEmpty property="searchStratAprvlPnttm">
AND TO_CHAR(A.APRVL_PNTTM, 'YYYYMMDD') <![CDATA[ >= ]]> REPLACE(#searchStratAprvlPnttm#, '.' , '') AND TO_CHAR(A.APRVL_PNTTM, 'YYYYMMDD') <![CDATA[ >= ]]> REPLACE(#searchStratAprvlPnttm#, '.' , '')
</isNotEmpty> </isNotEmpty>
@ -3446,6 +3512,19 @@ VALUES
edu_aplct_ord = #eduAplctOrd# edu_aplct_ord = #eduAplctOrd#
</insert> </insert>
<update id="VEEduMIXDAO.updateAplctStateCd" parameterClass="VEEduAplctVO">
/* VEEduMIXDAO.updateAplctStateCd */
UPDATE
vea_aplct_detail_info
SET
aplct_state_cd = #aplctStateCd#
WHERE
prcs_aplct_prd_ord = #prcsAplctPrdOrd#
AND edu_aplct_ord = #eduAplctOrd#
</update>
<select id="VEEduMIXDAO.selectExprnPagingList" parameterClass="VEEduAplctVO" resultClass="VEEduAplctVO"> <select id="VEEduMIXDAO.selectExprnPagingList" parameterClass="VEEduAplctVO" resultClass="VEEduAplctVO">
/* 임시.*NOT_SQL_LOG.* VEEduMIXDAO.selectExprnPagingList */ /* 임시.*NOT_SQL_LOG.* VEEduMIXDAO.selectExprnPagingList */
SELECT SELECT

View File

@ -33,7 +33,7 @@
a.hstry_ord AS hstryOrd, a.hstry_ord AS hstryOrd,
a.hstry_cd AS hstryCd, a.hstry_cd AS hstryCd,
DATE_FORMAT(a.hstry_pnttm,'%Y-%m-%d') AS hstryPnttm, TO_CHAR(a.hstry_pnttm,'YYYY-MM-DD') AS hstryPnttm,
a.hstry_id AS hstryId, a.hstry_id AS hstryId,
a.hstry_cn AS hstryCn a.hstry_cn AS hstryCn

View File

@ -32,9 +32,9 @@
a.tngr_instr_yn AS tngrInstrYn, a.tngr_instr_yn AS tngrInstrYn,
a.adult_instr_yn AS adultInstrYn, a.adult_instr_yn AS adultInstrYn,
DATE_FORMAT(a.frst_regist_pnttm,'%Y-%m-%d') AS frstRegistPnttm, TO_CHAR(a.frst_regist_pnttm,'YYYY-MM-DD') AS frstRegistPnttm,
a.frst_register_id AS frstRegisterId, a.frst_register_id AS frstRegisterId,
DATE_FORMAT(a.last_updt_pnttm,'%Y-%m-%d') AS lastUpdtPnttm, TO_CHAR(a.last_updt_pnttm,'YYYY-MM-DD') AS lastUpdtPnttm,
a.last_updusr_id AS lastUpdusrId a.last_updusr_id AS lastUpdusrId
</sql> </sql>
@ -865,8 +865,8 @@
WHERE d.user_id = #userId# WHERE d.user_id = #userId#
AND a.lctr_div_cd = #instrDiv# AND a.lctr_div_cd = #instrDiv#
ORDER BY d.frst_regist_pnttm DESC ORDER BY d.frst_regist_pnttm DESC
<isEqual property="searchDashboard" compareValue="Y"> <isEqual property="searchDashboard" compareValue="Y">
LIMIT 5 OFFSET 0 OFFSET 0 ROWS FETCH NEXT 5 ROWS ONLY;
</isEqual> </isEqual>
</select> </select>
@ -877,7 +877,12 @@
SELECT SUBSTRING(b.edu_hope_dt,1,4) AS eduHopeDt SELECT SUBSTRING(b.edu_hope_dt,1,4) AS eduHopeDt
, SUM(b.chasi) chasi , SUM(b.chasi) chasi
, d.yr_mxmm_asgnm_tm AS yrMxmmAsgnmTm , d.yr_mxmm_asgnm_tm AS yrMxmmAsgnmTm
, IF(d.yr_mxmm_asgnm_tm>0, CAST(CAST(SUM(b.chasi) AS DOUBLE)/d.yr_mxmm_asgnm_tm*100 AS DOUBLE),0) AS wCnt /*
, IF(d.yr_mxmm_asgnm_tm>0, CAST(CAST(SUM(b.chasi) AS NUMBER)/d.yr_mxmm_asgnm_tm*100 AS NUMBER),0) AS wCnt
*/
/*
, CASE WHEN d.yr_mxmm_asgnm_tm>0 THEN CAST(CAST(SUM(b.chasi) AS NUMBER)/d.yr_mxmm_asgnm_tm*100 AS NUMBER) ELSE 0 END AS wCnt
*/
FROM FROM
ve_lctr_stng d, ve_lctr_stng d,
ve_edu_chasi_instr_asgnm c ve_edu_chasi_instr_asgnm c
@ -896,7 +901,7 @@
<isEmpty property="mngNmbrYr"> <isEmpty property="mngNmbrYr">
/* 배정 대상 년도를 한정 */ /* 배정 대상 년도를 한정 */
AND SUBSTRING(b.edu_hope_dt,1,4)=DATE_FORMAT(NOW(),'%Y') AND SUBSTRING(b.edu_hope_dt,1,4)=TO_CHAR(SYSDATE,'YYYY')
</isEmpty> </isEmpty>
AND d.use_yn='Y' AND d.use_yn='Y'
@ -907,13 +912,17 @@
AND b.edu_chasi_ord=c.edu_chasi_ord AND b.edu_chasi_ord=c.edu_chasi_ord
AND b.edu_aplct_ord=a.edu_aplct_ord AND b.edu_aplct_ord=a.edu_aplct_ord
AND IFNULL(a.use_yn,'Y')='Y' AND NVL(a.use_yn,'Y')='Y'
/* 청소년 */ /* 청소년 */
AND a.lctr_div_cd='10' AND a.lctr_div_cd='10'
/* 교육신청이 확정되고, 강사확정인 경우만 통계 제공 */ /* 교육신청이 확정되고, 강사확정인 경우만 통계 제공 */
AND a.aprvl_cd = '60' AND a.aprvl_cd = '60'
AND c.asgnm_aprvl_cd = '30' AND c.asgnm_aprvl_cd = '30'
GROUP BY SUBSTRING(b.edu_hope_dt,1,4) GROUP BY SUBSTRING(b.edu_hope_dt,1,4)
, d.yr_mxmm_asgnm_tm
/*
, CASE WHEN d.yr_mxmm_asgnm_tm>0 THEN CAST(CAST(SUM(b.chasi) AS NUMBER)/d.yr_mxmm_asgnm_tm*100 AS NUMBER) ELSE 0 END
*/
</select> </select>
@ -932,11 +941,15 @@
, aaaa.mntSum , aaaa.mntSum
, aaaa.instrNm , aaaa.instrNm
/*
, IF(aaaa.userId IS NOT NULL, CONCAT('(',SUBSTRING(aaaa.userId,INSTR(aaaa.userId,'_')+1)*1,')'),'') AS userIdNum , IF(aaaa.userId IS NOT NULL, CONCAT('(',SUBSTRING(aaaa.userId,INSTR(aaaa.userId,'_')+1)*1,')'),'') AS userIdNum
*/
, CASE WHEN aaaa.userId IS NOT NULL THEN '('||SUBSTRING(aaaa.userId,INSTR(aaaa.userId,'_')+1)*1||')' ELSE '' AS userIdNum
, aaaa.yrMxmmAsgnmTm , aaaa.yrMxmmAsgnmTm
, ROUND(aaaa.achvPer,2) achvPer , ROUND(aaaa.achvPer,2) achvPer
, aaaa.totCnt , aaaa.totCnt
/*
, IF(aaaa.asgnmTm1>0,CONCAT(aaaa.asgnmTm1,'(',IFNULL(bbbb.wCntMnt01,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt01,aaaa.areaCnt),')'),aaaa.asgnmTm1) AS asgnmTm1 , IF(aaaa.asgnmTm1>0,CONCAT(aaaa.asgnmTm1,'(',IFNULL(bbbb.wCntMnt01,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt01,aaaa.areaCnt),')'),aaaa.asgnmTm1) AS asgnmTm1
, IF(aaaa.asgnmTm2>0,CONCAT(aaaa.asgnmTm2,'(',IFNULL(bbbb.wCntMnt02,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt02,aaaa.areaCnt),')'),aaaa.asgnmTm2) AS asgnmTm2 , IF(aaaa.asgnmTm2>0,CONCAT(aaaa.asgnmTm2,'(',IFNULL(bbbb.wCntMnt02,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt02,aaaa.areaCnt),')'),aaaa.asgnmTm2) AS asgnmTm2
, IF(aaaa.asgnmTm3>0,CONCAT(aaaa.asgnmTm3,'(',IFNULL(bbbb.wCntMnt03,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt03,aaaa.areaCnt),')'),aaaa.asgnmTm3) AS asgnmTm3 , IF(aaaa.asgnmTm3>0,CONCAT(aaaa.asgnmTm3,'(',IFNULL(bbbb.wCntMnt03,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt03,aaaa.areaCnt),')'),aaaa.asgnmTm3) AS asgnmTm3
@ -948,7 +961,22 @@
, IF(aaaa.asgnmTm9>0,CONCAT(aaaa.asgnmTm9,'(',IFNULL(bbbb.wCntMnt09,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt09,aaaa.areaCnt),')'),aaaa.asgnmTm9) AS asgnmTm9 , IF(aaaa.asgnmTm9>0,CONCAT(aaaa.asgnmTm9,'(',IFNULL(bbbb.wCntMnt09,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt09,aaaa.areaCnt),')'),aaaa.asgnmTm9) AS asgnmTm9
, IF(aaaa.asgnmTm10>0,CONCAT(aaaa.asgnmTm10,'(',IFNULL(bbbb.wCntMnt10,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt10,aaaa.areaCnt),')'),aaaa.asgnmTm10) AS asgnmTm10 , IF(aaaa.asgnmTm10>0,CONCAT(aaaa.asgnmTm10,'(',IFNULL(bbbb.wCntMnt10,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt10,aaaa.areaCnt),')'),aaaa.asgnmTm10) AS asgnmTm10
, IF(aaaa.asgnmTm11>0,CONCAT(aaaa.asgnmTm11,'(',IFNULL(bbbb.wCntMnt11,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt11,aaaa.areaCnt),')'),aaaa.asgnmTm11) AS asgnmTm11 , IF(aaaa.asgnmTm11>0,CONCAT(aaaa.asgnmTm11,'(',IFNULL(bbbb.wCntMnt11,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt11,aaaa.areaCnt),')'),aaaa.asgnmTm11) AS asgnmTm11
, IF(aaaa.asgnmTm12>0,CONCAT(aaaa.asgnmTm12,'(',IFNULL(bbbb.wCntMnt12,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt12,aaaa.areaCnt),')'),aaaa.asgnmTm12) AS asgnmTm12 , IF(aaaa.asgnmTm12>0,CONCAT(aaaa.asgnmTm12,'(',IFNULL(bbbb.wCntMnt12,aaaa.wCnt),'/',IFNULL(bbbb.areaCnt12,aaaa.areaCnt),')'),aaaa.asgnmTm12) AS asgnmTm12
*/
, CASE WHEN aaaa.asgnmTm1>0 THEN aaaa.asgnmTm1||'('||NVL(bbbb.wCntMnt01,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt01,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm1 END AS asgnmTm1
, CASE WHEN aaaa.asgnmTm2>0 THEN aaaa.asgnmTm2||'('||NVL(bbbb.wCntMnt02,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt02,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm2 END AS asgnmTm2
, CASE WHEN aaaa.asgnmTm3>0 THEN aaaa.asgnmTm3||'('||NVL(bbbb.wCntMnt03,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt03,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm3 END AS asgnmTm3
, CASE WHEN aaaa.asgnmTm4>0 THEN aaaa.asgnmTm4||'('||NVL(bbbb.wCntMnt04,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt04,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm4 END AS asgnmTm4
, CASE WHEN aaaa.asgnmTm5>0 THEN aaaa.asgnmTm5||'('||NVL(bbbb.wCntMnt05,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt05,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm5 END AS asgnmTm5
, CASE WHEN aaaa.asgnmTm6>0 THEN aaaa.asgnmTm6||'('||NVL(bbbb.wCntMnt06,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt06,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm6 END AS asgnmTm6
, CASE WHEN aaaa.asgnmTm7>0 THEN aaaa.asgnmTm7||'('||NVL(bbbb.wCntMnt07,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt07,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm7 END AS asgnmTm7
, CASE WHEN aaaa.asgnmTm8>0 THEN aaaa.asgnmTm8||'('||NVL(bbbb.wCntMnt08,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt08,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm8 END AS asgnmTm8
, CASE WHEN aaaa.asgnmTm9>0 THEN aaaa.asgnmTm9||'('||NVL(bbbb.wCntMnt09,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt09,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm9 END AS asgnmTm9
, CASE WHEN aaaa.asgnmTm10>0 THEN aaaa.asgnmTm10||'('||NVL(bbbb.wCntMnt10,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt10,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm10 END AS asgnmTm10
, CASE WHEN aaaa.asgnmTm11>0 THEN aaaa.asgnmTm11||'('||NVL(bbbb.wCntMnt11,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt11,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm11 END AS asgnmTm11
, CASE WHEN aaaa.asgnmTm12>0 THEN aaaa.asgnmTm12||'('||NVL(bbbb.wCntMnt12,aaaa.wCnt)||'/'||NVL(bbbb.areaCnt12,aaaa.areaCnt)||')' ELSE aaaa.asgnmTm12 END AS asgnmTm12
FROM ( FROM (
@ -956,13 +984,25 @@
, bbb.appt_div AS apptDiv , bbb.appt_div AS apptDiv
, '' lctrAreaNm , '' lctrAreaNm
, bbb.rsdne , bbb.rsdne
/*
, IF (ccc.mon_lctr_yn='Y',1,0) + IF (ccc.tue_lctr_yn='Y',1,0) + IF (ccc.wed_lctr_yn='Y',1,0) , IF (ccc.mon_lctr_yn='Y',1,0) + IF (ccc.tue_lctr_yn='Y',1,0) + IF (ccc.wed_lctr_yn='Y',1,0)
+ IF (ccc.thu_lctr_yn='Y',1,0) + IF (ccc.fri_lctr_yn='Y',1,0) AS wCnt + IF (ccc.thu_lctr_yn='Y',1,0) + IF (ccc.fri_lctr_yn='Y',1,0) AS wCnt
, IFNULL(ddd.areaCnt,0) AS areaCnt */
, CASE WHEN ccc.mon_lctr_yn='Y' THEN 1 ELSE 0 END
+ CASE WHEN ccc.tue_lctr_yn='Y' THEN 1 ELSE 0 END
+ CASE WHEN ccc.wed_lctr_yn='Y' THEN 1 ELSE 0 END
+ CASE WHEN ccc.thu_lctr_yn='Y' THEN 1 ELSE 0 END
+ CASE WHEN ccc.fri_lctr_yn='Y' THEN 1 ELSE 0 END AS wCnt
, NVL(ddd.areaCnt,0) AS areaCnt
, aaa.* , aaa.*
, bbb.instr_nm AS instrNm , bbb.instr_nm AS instrNm
, ccc.yr_mxmm_asgnm_tm AS yrMxmmAsgnmTm , ccc.yr_mxmm_asgnm_tm AS yrMxmmAsgnmTm
/*
, IF (ccc.yr_mxmm_asgnm_tm=0,0,ROUND(CAST(CAST(aaa.mntSum AS DOUBLE)/ifnull(ccc.yr_mxmm_asgnm_tm,1)*100 AS DOUBLE),1)) AS achvPer , IF (ccc.yr_mxmm_asgnm_tm=0,0,ROUND(CAST(CAST(aaa.mntSum AS DOUBLE)/ifnull(ccc.yr_mxmm_asgnm_tm,1)*100 AS DOUBLE),1)) AS achvPer
*/
, CASE WHEN ccc.yr_mxmm_asgnm_tm=0 THEN 0
ELSE ROUND(CAST(CAST(aaa.mntSum AS DOUBLE)/NVL(ccc.yr_mxmm_asgnm_tm,1)*100 AS DOUBLE),1) END AS achvPer
, COUNT(1) OVER() AS totCnt , COUNT(1) OVER() AS totCnt
FROM ( SELECT user_id AS userId , FROM ( SELECT user_id AS userId ,
CAST(SUM(IF(mnt='01',chasi,0)) AS INT) AS asgnmTm1 , CAST(SUM(IF(mnt='01',chasi,0)) AS INT) AS asgnmTm1 ,
@ -1001,7 +1041,7 @@
<isEmpty property="mngNmbrYr"> <isEmpty property="mngNmbrYr">
/* 배정 대상 년도를 한정 */ /* 배정 대상 년도를 한정 */
AND SUBSTRING(b.edu_hope_dt,1,4)=DATE_FORMAT(NOW(),'%Y') AND SUBSTRING(b.edu_hope_dt,1,4)=TO_CHAR(SYSDATE,'YYYY')
</isEmpty> </isEmpty>
@ -1122,7 +1162,7 @@
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, aaaa.userId , aaaa.userId
</isEmpty> </isEmpty>
@ -1130,7 +1170,10 @@
, $orderByQuery$ , $orderByQuery$
</isNotEmpty> </isNotEmpty>
<isNotEqual property="mode" compareValue="EXCEL"> <isNotEqual property="mode" compareValue="EXCEL">
LIMIT #recordCountPerPage# OFFSET #firstIndex# /*
LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</isNotEqual> </isNotEqual>
</select> </select>

View File

@ -29,9 +29,9 @@
a.tngr_instr_yn AS tngrInstrYn, a.tngr_instr_yn AS tngrInstrYn,
a.adult_instr_yn AS adultInstrYn, a.adult_instr_yn AS adultInstrYn,
DATE_FORMAT(a.frst_regist_pnttm,'%Y-%m-%d') AS frstRegistPnttm, TO_CHAR(a.frst_regist_pnttm,'YYYY-MM-DD') AS frstRegistPnttm,
a.frst_register_id AS frstRegisterId, a.frst_register_id AS frstRegisterId,
DATE_FORMAT(a.last_updt_pnttm,'%Y-%m-%d') AS lastUpdtPnttm, TO_CHAR(a.last_updt_pnttm,'YYYY-MM-DD') AS lastUpdtPnttm,
a.last_updusr_id AS lastUpdusrId a.last_updusr_id AS lastUpdusrId
</sql> </sql>

View File

@ -741,7 +741,7 @@
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, a.area_cd desc , a.area_cd desc
@ -750,8 +750,10 @@
, $orderByQuery$ , $orderByQuery$
</isNotEmpty> </isNotEmpty>
/*
LIMIT #recordCountPerPage# OFFSET #firstIndex# LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>

View File

@ -211,7 +211,7 @@
<!-- 강사 정보 L page --> <!-- 강사 정보 L page -->
<select id="VELctrAreaDAO.selectPagingListNew" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO"> <select id="VELctrAreaDAO.selectPagingListNew" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO">
/* //조사년월에 강사가 선택한 강의지역 리스트로 변경. 2023-07-25 */ /* //조사년월에 강사가 선택한 강의지역 리스트로 변경. 2023-07-25 VELctrAreaDAO.selectPagingListNew */
SELECT COUNT(1) OVER() AS totCnt , SELECT COUNT(1) OVER() AS totCnt ,
c.instr_div AS instrDiv, c.instr_div AS instrDiv,
c.user_id AS userId, c.user_id AS userId,
@ -245,7 +245,7 @@
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, b.user_id desc , b.user_id desc
@ -254,8 +254,10 @@
, $orderByQuery$ , $orderByQuery$
</isNotEmpty> </isNotEmpty>
/*
LIMIT #recordCountPerPage# OFFSET #firstIndex# LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>
</sqlMap> </sqlMap>

View File

@ -32,7 +32,9 @@
a.stng_yr_mnt AS stngYrMnt, a.stng_yr_mnt AS stngYrMnt,
a.rsrch_strt_dt AS rsrchStrtDt, a.rsrch_strt_dt AS rsrchStrtDt,
a.rsrch_end_dt AS rsrchEndDt, a.rsrch_end_dt AS rsrchEndDt,
a.lctr_rsrch_state AS rsrchState,
TO_CHAR(a.frst_regist_pnttm,'YYYY-MM-DD') AS frstRegistPnttm, TO_CHAR(a.frst_regist_pnttm,'YYYY-MM-DD') AS frstRegistPnttm,
a.frst_register_id AS frstRegisterId, a.frst_register_id AS frstRegisterId,
@ -103,35 +105,65 @@
</select> </select>
<!-- 강사 정보 U --> <!-- 강사 정보 U -->
<update id="VELctrRsrchMngDAO.update" parameterClass="VELctrDetailVO"> <update id="VELctrRsrchMngDAO.update" parameterClass="VELctrDetailVO">
UPDATE
<include refid="VELctrRsrchMngDAO.table_name"/> /* VELctrRsrchMngDAO.update */
SET MERGE INTO <include refid="VELctrRsrchMngDAO.table_name"/>
USING DUAL
last_updt_pnttm=now() ON(rsrch_instr_div = #rsrchInstrDiv#
, last_updusr_id=#lastUpdusrId# AND stng_yr_mnt = #stngYrMnt#)
<isNotEmpty property="rsrchStrtDt">
, rsrch_strt_dt = #rsrchStrtDt#
</isNotEmpty><isNotEmpty property="rsrchEndDt">
, rsrch_end_dt = #rsrchEndDt#
</isNotEmpty>
WHEN NOT MATCHED THEN
INSERT
(
<include refid="VELctrRsrchMngDAO.column_name"/>
)
VALUES(
#rsrchInstrDiv#,
#stngYrMnt#,
#rsrchStrtDt#,
#rsrchEndDt#,
SYSDATE,
#frstRegisterId#,
NULL,
NULL
)
WHEN MATCHED THEN
UPDATE
SET last_updt_pnttm = SYSDATE
, last_updusr_id = #frstRegisterId#
<isNotEmpty property="rsrchStrtDt">
, rsrch_strt_dt = #rsrchStrtDt#
</isNotEmpty>
<isNotEmpty property="rsrchEndDt">
, rsrch_end_dt = #rsrchEndDt#
</isNotEmpty>
<isNotEmpty property="rsrchState">
<isEqual property="rsrchState" compareValue="00">
, lctr_rsrch_state = null
</isEqual>
<isNotEqual property="rsrchState" compareValue="00">
, lctr_rsrch_state = #rsrchState#
</isNotEqual>
WHERE </isNotEmpty>
rsrch_instr_div = #rsrchInstrDiv#
AND stng_yr_mnt = #stngYrMnt#
</update> </update>
<!-- 강사 정보 D --> <!-- 강사 정보 D -->
<delete id="VELctrRsrchMngDAO.delete" parameterClass="VELctrDetailVO"> <delete id="VELctrRsrchMngDAO.delete" parameterClass="VELctrDetailVO">
/* VELctrRsrchMngDAO.delete */
DELETE FROM DELETE FROM
<include refid="VELctrRsrchMngDAO.table_name"/> <include refid="VELctrRsrchMngDAO.table_name"/>
WHERE WHERE
rsrch_instr_div = #rsrchInstrDiv# rsrch_instr_div = #rsrchInstrDiv#
AND stng_yr = #stngYr#
AND stng_yr_mnt = #stngYrMnt# AND stng_yr_mnt = #stngYrMnt#
</delete> </delete>
@ -146,11 +178,16 @@
WHERE 1=1 WHERE 1=1
<isNotEmpty property="stngYrMnt">
AND a.stng_yr_mnt = #stngYrMnt#
</isNotEmpty>
<isNotEmpty property="selectPagingListQuery"> <isNotEmpty property="selectPagingListQuery">
$selectPagingListQuery$ $selectPagingListQuery$
</isNotEmpty> </isNotEmpty>
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, a.stng_yr_mnt desc , a.stng_yr_mnt desc
@ -226,13 +263,15 @@
, dddd.instr_div AS instrDiv , dddd.instr_div AS instrDiv
, dddd.instr_detail_ord AS instrDetailOrd , dddd.instr_detail_ord AS instrDetailOrd
/*
, (SELECT f.one_depth_nm , (SELECT f.one_depth_nm
FROM ve_rsdnc f FROM ve_rsdnc f
WHERE f.post_id = MAX(eeee.area_cd) WHERE f.post_id = MAX(eeee.area_cd)
GROUP BY f.one_depth_nm GROUP BY f.one_depth_nm
) )
AS lctrAreaNm AS lctrAreaNm
, COUNT(eeee.area_cd) AS lctrAreaCnt , COUNT(eeee.area_cd) AS lctrAreaCnt
*/
FROM ( FROM (
SELECT aaa.rsrch_instr_div SELECT aaa.rsrch_instr_div
@ -244,6 +283,7 @@
, aaa.user_id , aaa.user_id
, aaa.qlfct_end_yn , aaa.qlfct_end_yn
, ccc.lctr_stng_ord , ccc.lctr_stng_ord
/*
, IF(NVL(ccc.sun_lctr_yn, ddd.sun_lctr_yn)='Y',1,0) , IF(NVL(ccc.sun_lctr_yn, ddd.sun_lctr_yn)='Y',1,0)
+ IF(NVL(ccc.mon_lctr_yn, ddd.mon_lctr_yn)='Y',1,0) + IF(NVL(ccc.mon_lctr_yn, ddd.mon_lctr_yn)='Y',1,0)
+ IF(NVL(ccc.tue_lctr_yn, ddd.tue_lctr_yn)='Y',1,0) + IF(NVL(ccc.tue_lctr_yn, ddd.tue_lctr_yn)='Y',1,0)
@ -251,6 +291,16 @@
+ IF(NVL(ccc.thu_lctr_yn, ddd.thu_lctr_yn)='Y',1,0) + IF(NVL(ccc.thu_lctr_yn, ddd.thu_lctr_yn)='Y',1,0)
+ IF(NVL(ccc.fri_lctr_yn, ddd.fri_lctr_yn)='Y',1,0) + IF(NVL(ccc.fri_lctr_yn, ddd.fri_lctr_yn)='Y',1,0)
+ IF(NVL(ccc.sat_lctr_yn, ddd.sat_lctr_yn)='Y',1,0) AS w_cnt + IF(NVL(ccc.sat_lctr_yn, ddd.sat_lctr_yn)='Y',1,0) AS w_cnt
*/
, CASE WHEN NVL(ccc.sun_lctr_yn, ddd.sun_lctr_yn)='Y' THEN 1 ELSE 0 END
+ CASE WHEN NVL(ccc.mon_lctr_yn, ddd.mon_lctr_yn)='Y' THEN 1 ELSE 0 END
+ CASE WHEN NVL(ccc.tue_lctr_yn, ddd.tue_lctr_yn)='Y' THEN 1 ELSE 0 END
+ CASE WHEN NVL(ccc.wed_lctr_yn, ddd.wed_lctr_yn)='Y' THEN 1 ELSE 0 END
+ CASE WHEN NVL(ccc.thu_lctr_yn, ddd.thu_lctr_yn)='Y' THEN 1 ELSE 0 END
+ CASE WHEN NVL(ccc.fri_lctr_yn, ddd.fri_lctr_yn)='Y' THEN 1 ELSE 0 END
+ CASE WHEN NVL(ccc.sat_lctr_yn, ddd.sat_lctr_yn)='Y' THEN 1 ELSE 0 END
AS w_cnt
, ddd.lctr_stng_ord AS other_lctr_stng_ord , ddd.lctr_stng_ord AS other_lctr_stng_ord
, ddd.instr_div , ddd.instr_div
, aaa.instr_detail_ord , aaa.instr_detail_ord
@ -345,6 +395,7 @@
, dddd.w_cnt , dddd.w_cnt
, dddd.other_lctr_stng_ord , dddd.other_lctr_stng_ord
, dddd.instr_div , dddd.instr_div
, dddd.instr_detail_ord

View File

@ -39,9 +39,9 @@
a.lctr_stng_ord AS lctrStngOrd, a.lctr_stng_ord AS lctrStngOrd,
DATE_FORMAT(a.frst_regist_pnttm,'%Y-%m-%d') AS frstRegistPnttm, TO_CHAR(a.frst_regist_pnttm,'YYYY-MM-DD') AS frstRegistPnttm,
a.frst_register_id AS frstRegisterId, a.frst_register_id AS frstRegisterId,
DATE_FORMAT(a.last_updt_pnttm,'%Y-%m-%d') AS lastUpdtPnttm, TO_CHAR(a.last_updt_pnttm,'YYYY-MM-DD') AS lastUpdtPnttm,
a.last_updusr_id AS lastUpdusrId, a.last_updusr_id AS lastUpdusrId,
a.strt_dt AS strtDt, a.strt_dt AS strtDt,
@ -85,7 +85,7 @@
<!-- 강사 정보 R --> <!-- 강사 정보 R -->
<select id="VELctrRsrchSbmtDAO.selectDetail" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO"> <select id="VELctrRsrchSbmtDAO.selectDetail" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO">
/* 해당 강의 조사 기간에 대해 강사가 작성한 정보가 있는지 확인 - 관리자 */ /* 해당 강의 조사 기간에 대해 강사가 작성한 정보가 있는지 확인 - 관리자 VELctrRsrchSbmtDAO.selectDetail */
SELECT SELECT
<include refid="VELctrRsrchSbmtDAO.select_column_name"/> <include refid="VELctrRsrchSbmtDAO.select_column_name"/>
FROM FROM
@ -111,7 +111,7 @@
<!-- 강사 정보 R --> <!-- 강사 정보 R -->
<select id="VELctrRsrchSbmtDAO.selectDetailNew" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO"> <select id="VELctrRsrchSbmtDAO.selectDetailNew" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO">
/* 해당 강의 조사 기간에 대해 강사가 작성한 정보가 있는지 확인 */ /* 해당 강의 조사 기간에 대해 강사가 작성한 정보가 있는지 확인 VELctrRsrchSbmtDAO.selectDetailNew */
/* 순번데이터 없이 해당 조사 제출을 한 강사 정보가 있는지 확인 하는 것임 since 2023.07.25 */ /* 순번데이터 없이 해당 조사 제출을 한 강사 정보가 있는지 확인 하는 것임 since 2023.07.25 */
SELECT SELECT
<include refid="VELctrRsrchSbmtDAO.select_column_name"/> <include refid="VELctrRsrchSbmtDAO.select_column_name"/>
@ -128,27 +128,53 @@
<!-- 강사 정보 U --> <!-- 강사 정보 U -->
<update id="VELctrRsrchSbmtDAO.update" parameterClass="VELctrDetailVO"> <update id="VELctrRsrchSbmtDAO.update" parameterClass="VELctrDetailVO">
UPDATE /* VELctrRsrchSbmtDAO.update */
<include refid="VELctrRsrchSbmtDAO.table_name"/> MERGE INTO <include refid="VELctrRsrchSbmtDAO.table_name"/>
SET USING DUAL
ON(
last_updt_pnttm=now()
, last_updusr_id=#lastUpdusrId#
<isNotEmpty property="strtDt">
, strt_dt = #strtDt#
</isNotEmpty><isNotEmpty property="endDt">
, end_dt = #endDt#
</isNotEmpty>
WHERE
rsrch_instr_div = #rsrchInstrDiv# rsrch_instr_div = #rsrchInstrDiv#
AND stng_yr_mnt = #stngYrMnt# AND stng_yr_mnt = #stngYrMnt#
AND instr_div = #instrDiv# AND instr_div = #instrDiv#
AND user_id = #userId# AND user_id = #userId#
AND lctr_stng_ord = #lctrStngOrd# )
WHEN NOT MATCHED THEN
INSERT
(
<include refid="VELctrRsrchSbmtDAO.column_name"/>
)
VALUES(
#rsrchInstrDiv#,
#stngYrMnt#,
#instrDiv#,
#userId#,
#lctrStngOrd#,
SYSDATE,
#frstRegisterId#,
NULL,
NULL,
#strtDt#,
#endDt#
)
WHEN MATCHED THEN
UPDATE
SET last_updt_pnttm = SYSDATE
, last_updusr_id = #frstRegisterId#
<isNotEmpty property="strtDt">
, strt_dt = #strtDt#
</isNotEmpty><isNotEmpty property="endDt">
, end_dt = #endDt#
</isNotEmpty>
</update> </update>
<!-- 강사 정보 D --> <!-- 강사 정보 D -->
@ -166,6 +192,7 @@
<!-- 강사 정보 L --> <!-- 강사 정보 L -->
<select id="VELctrRsrchSbmtDAO.selectList" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO"> <select id="VELctrRsrchSbmtDAO.selectList" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO">
/* VELctrRsrchSbmtDAO.selectList */
SELECT SELECT
aaa.instr_div AS instrDiv aaa.instr_div AS instrDiv
, aaa.area_cd AS areaCd , aaa.area_cd AS areaCd
@ -261,6 +288,7 @@
<!-- 강사 정보 L page --> <!-- 강사 정보 L page -->
<select id="VELctrRsrchSbmtDAO.selectPagingList" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO"> <select id="VELctrRsrchSbmtDAO.selectPagingList" parameterClass="VELctrDetailVO" resultClass="VELctrDetailVO">
/* VELctrRsrchSbmtDAO.selectPagingList */
SELECT SELECT
COUNT(1) OVER() AS totCnt , COUNT(1) OVER() AS totCnt ,
<include refid="VELctrRsrchSbmtDAO.select_column_name"/> <include refid="VELctrRsrchSbmtDAO.select_column_name"/>

View File

@ -456,6 +456,39 @@
<!-- 강사 정보 U --> <!-- 강사 정보 U -->
<update id="VELctrStngDAO.updateUseYn" parameterClass="VELctrDetailVO"> <update id="VELctrStngDAO.updateUseYn" parameterClass="VELctrDetailVO">
UPDATE
(
SELECT cc.use_yn
FROM ve_lctr_stng cc
,(
SELECT a.instr_div
, a.user_id
, a.lctr_stng_ord
, a.use_yn
FROM ve_lctr_stng a
LEFT OUTER JOIN ve_lctr_stng b
ON(
a.instr_div=b.instr_div
AND a.user_id=b.user_id
AND a.lctr_stng_ord=b.lctr_stng_ord
AND b.instr_div = #instrDiv#
AND b.user_id = #userId#
AND b.lctr_stng_ord = #lctrStngOrd#
)
WHERE a.instr_div = #instrDiv#
AND a.user_id = #userId#
AND b.lctr_stng_ord IS null
)dd
WHERE cc.instr_div=dd.instr_div
AND cc.user_id=dd.user_id
AND cc.lctr_stng_ord=dd.lctr_stng_ord
)AA
SET AA.use_yn=#useYn#
</update>
<!-- 강사 정보 U -->
<update id="VELctrStngDAO.updateUseYn_old" parameterClass="VELctrDetailVO">
UPDATE ve_lctr_stng cc, UPDATE ve_lctr_stng cc,
( (
@ -484,7 +517,6 @@
AND cc.lctr_stng_ord=dd.lctr_stng_ord AND cc.lctr_stng_ord=dd.lctr_stng_ord
</update> </update>
<!-- 강사 정보 D --> <!-- 강사 정보 D -->
<delete id="VELctrStngDAO.delete" parameterClass="VELctrDetailVO"> <delete id="VELctrStngDAO.delete" parameterClass="VELctrDetailVO">
DELETE FROM DELETE FROM

View File

@ -90,9 +90,9 @@
a.aprvl_id AS aprvlId, a.aprvl_id AS aprvlId,
a.aprvl_cn AS aprvlCn, a.aprvl_cn AS aprvlCn,
DATE_FORMAT(a.frst_regist_pnttm,'%Y-%m-%d') AS frstRegistPnttm, TO_CHAR(a.frst_regist_pnttm,'YYYY-MM-DD') AS frstRegistPnttm,
a.frst_register_id AS frstRegisterId, a.frst_register_id AS frstRegisterId,
DATE_FORMAT(a.last_updt_pnttm,'%Y-%m-%d') AS lastUpdtPnttm, TO_CHAR(a.last_updt_pnttm,'YYYY-MM-DD') AS lastUpdtPnttm,
a.last_updusr_id AS lastUpdusrId, a.last_updusr_id AS lastUpdusrId,
a.use_yn AS useYn, a.use_yn AS useYn,
@ -229,7 +229,7 @@
ORDER BY 1=1 ORDER BY 1
<isEmpty property="orderByQuery"> <isEmpty property="orderByQuery">
, a.user_id desc , a.user_id desc
@ -239,7 +239,10 @@
</isNotEmpty> </isNotEmpty>
LIMIT #recordCountPerPage# OFFSET #firstIndex# /*
LIMIT recordCountPerPage OFFSET firstIndex
*/
OFFSET #firstIndex# ROWS FETCH NEXT #recordCountPerPage# ROWS ONLY;
</select> </select>
@ -282,7 +285,7 @@
UNION ALL SELECT '12' UNION ALL SELECT '12'
)bb )bb
WHERE 1=1 WHERE 1=1
AND DATE_FORMAT(DATE_ADD(NOW(), INTERVAL 1 month),'%Y%m')>=CONCAT(aa.stndrd_yr,bb.stndrd_mnt) AND TO_CHAR(DATE_ADD(SYSDATE, INTERVAL 1 month),'YYYYMM')>=aa.stndrd_yr||bb.stndrd_mnt
ORDER BY CONCAT(aa.stndrd_yr,bb.stndrd_mnt) DESC ORDER BY CONCAT(aa.stndrd_yr,bb.stndrd_mnt) DESC
</select> </select>

View File

@ -116,9 +116,26 @@
<!-- 교육 신청자 상태 update --> <!-- 교육 신청자 상태 update -->
<update id="VEAPrcsAplctPrdInstrAsgnmDAO.udpateAprvlCdEduAplct" parameterClass="VEPrcsDetailVO"> <update id="VEAPrcsAplctPrdInstrAsgnmDAO.udpateAprvlCdEduAplct" parameterClass="VEPrcsDetailVO">
/* VEAPrcsAplctPrdInstrAsgnmDAO.updateAplctStateCdListAjax */
UPDATE VE_EDU_APLCT UPDATE VE_EDU_APLCT
SET aprvl_cd = #aprvlCd# SET aprvl_cd = #aprvlCd#
WHERE edu_aplct_ord IN WHERE prcs_aplct_prd_ord = #prcsAplctPrdOrd#
AND edu_aplct_ord IN
<iterate property="eduAplctOrdList" open="(" close=")" conjunction=",">
#eduAplctOrdList[]#
</iterate>
</update>
<!-- 교육 신청자 상태 update -->
<update id="VEAPrcsAplctPrdInstrAsgnmDAO.updateAplctStateCdListAjax" parameterClass="VEPrcsDetailVO">
/* VEAPrcsAplctPrdInstrAsgnmDAO.updateAplctStateCdListAjax */
UPDATE VEA_APLCT_DETAIL_INFO
SET aplct_state_cd = #aplctStateCd#
WHERE prcs_aplct_prd_ord = #prcsAplctPrdOrd#
AND edu_aplct_ord IN
<iterate property="eduAplctOrdList" open="(" close=")" conjunction=","> <iterate property="eduAplctOrdList" open="(" close=")" conjunction=",">
#eduAplctOrdList[]# #eduAplctOrdList[]#
</iterate> </iterate>
@ -126,7 +143,8 @@
<!-- 강사 배정 등록 --> <!-- 강사 배정 등록 -->
<select id="VEAPrcsAplctPrdInstrAsgnmDAO.findByPrcsAplctPrdOrd" parameterClass="String" resultClass="VEAPrcsAplctPrdInstrAsgnmVO"> <select id="VEAPrcsAplctPrdInstrAsgnmDAO.findByPrcsAplctPrdOrd" parameterClass="String" resultClass="VEAPrcsAplctPrdInstrAsgnmVO">
/* VEAPrcsAplctPrdInstrAsgnmDAO.findByPrcsAplctPrdOrd */
SELECT SELECT
<include refid="VEAPrcsAplctPrdInstrAsgnmDAO.select_column_name"/> <include refid="VEAPrcsAplctPrdInstrAsgnmDAO.select_column_name"/>
, vid.instr_nm as instrNm , vid.instr_nm as instrNm

View File

@ -331,11 +331,17 @@
<isNotEmpty property="prcsAplctPrdOrd"> <isNotEmpty property="prcsAplctPrdOrd">
AND a.prcs_aplct_prd_ord=#prcsAplctPrdOrd# AND a.prcs_aplct_prd_ord=#prcsAplctPrdOrd#
</isNotEmpty> </isNotEmpty>
/*교육확정목록을 조회하기 위한 조건문*/
<isNotEmpty property="ddlnCd">
AND a.ddln_cd = #ddlnCd#
</isNotEmpty>
<isNotEmpty property="searchKeyword"> <isNotEmpty property="searchKeyword">
AND b.prcs_nm LIKE '%'|| #searchKeyword# ||'%' AND b.prcs_nm LIKE '%'|| #searchKeyword# ||'%'
</isNotEmpty> </isNotEmpty>
ORDER BY 1 ORDER BY 1

View File

@ -70,13 +70,16 @@
<select id="VERsdncMIXDAO.selectRsdncStep2List" parameterClass="VERsdncVO" resultClass="VERsdncVO"> <select id="VERsdncMIXDAO.selectRsdncStep2List" parameterClass="VERsdncVO" resultClass="VERsdncVO">
/* 강의 지역 - Depth 2 */ /* 강의 지역 - Depth 2 */
SELECT aa.* SELECT aa.*
, IFNULL(bb.area_cd, 0) cnt , NVL(bb.area_cd, 0) cnt
FROM ( FROM (
SELECT one_depth_nm AS oneDepthNm SELECT one_depth_nm AS oneDepthNm
/* /*
, a.two_depth_nm AS twoDepthNm , a.two_depth_nm AS twoDepthNm
*/ */
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) AS twoDepthNm /*
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) AS twoDepthNm
*/
, CASE WHEN a.two_depth_nm IS NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END AS twoDepthNm
, MAX(post_id) postId , MAX(post_id) postId
FROM ve_rsdnc a FROM ve_rsdnc a
WHERE 1=1 WHERE 1=1
@ -85,13 +88,19 @@
</isNotEmpty> </isNotEmpty>
GROUP BY one_depth_nm GROUP BY one_depth_nm
/*
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) , IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm)
*/
, CASE WHEN a.two_depth_nm IS NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END
/* /*
, a.two_depth_nm , a.two_depth_nm
*/ */
ORDER BY one_depth_nm ORDER BY one_depth_nm
/*
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) , IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm)
*/
, CASE WHEN a.two_depth_nm IS NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END
/* /*
, a.two_depth_nm , a.two_depth_nm
*/ */
@ -126,13 +135,16 @@
<select id="VERsdncMIXDAO.selectRsdncStep2ListNew" parameterClass="VERsdncVO" resultClass="VERsdncVO"> <select id="VERsdncMIXDAO.selectRsdncStep2ListNew" parameterClass="VERsdncVO" resultClass="VERsdncVO">
/* 강의 지역 - Depth 2 */ /* 강의 지역 - Depth 2 */
SELECT aa.* SELECT aa.*
, IFNULL(bb.area_cd, 0) cnt , NVL(bb.area_cd, 0) cnt
FROM ( FROM (
SELECT one_depth_nm AS oneDepthNm SELECT one_depth_nm AS oneDepthNm
/* /*
, a.two_depth_nm AS twoDepthNm , a.two_depth_nm AS twoDepthNm
*/ */
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) AS twoDepthNm /*
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) AS twoDepthNm
*/
, CASE WHEN a.two_depth_nm IS NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END AS twoDepthNm
, MAX(post_id) postId , MAX(post_id) postId
FROM ve_rsdnc a FROM ve_rsdnc a
WHERE 1=1 WHERE 1=1
@ -141,13 +153,19 @@
</isNotEmpty> </isNotEmpty>
GROUP BY one_depth_nm GROUP BY one_depth_nm
/*
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) , IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm)
*/
, CASE WHEN a.two_depth_nm IS NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END
/* /*
, a.two_depth_nm , a.two_depth_nm
*/ */
ORDER BY one_depth_nm ORDER BY one_depth_nm
/*
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) , IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm)
*/
, CASE WHEN a.two_depth_nm IS NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END
/* /*
, a.two_depth_nm , a.two_depth_nm
*/ */
@ -202,15 +220,18 @@
<!-- 거주지 2단계 --> <!-- 거주지 2단계 -->
<!-- //관리자에서 강사의 현재 선택 지역 정보를 가져오기 위한 쿼리임 - 2023.07.26 --> <!-- //관리자에서 강사의 현재 선택 지역 정보를 가져오기 위한 쿼리임 - 2023.07.26 -->
<select id="VERsdncMIXDAO.selectRsdncStep2ListNewAdmin" parameterClass="VERsdncVO" resultClass="VERsdncVO"> <select id="VERsdncMIXDAO.selectRsdncStep2ListNewAdmin" parameterClass="VERsdncVO" resultClass="VERsdncVO">
/* 강의 지역 - Depth 2 */ /* 강의 지역 - Depth 2 VERsdncMIXDAO.selectRsdncStep2ListNewAdmin */
SELECT aa.* SELECT aa.*
, IFNULL(bb.area_cd, 0) cnt , NVL(bb.area_cd, 0) cnt
FROM ( FROM (
SELECT one_depth_nm AS oneDepthNm SELECT one_depth_nm AS oneDepthNm
/* /*
, a.two_depth_nm AS twoDepthNm , a.two_depth_nm AS twoDepthNm
*/ */
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) AS twoDepthNm /*
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) AS twoDepthNm
*/
, CASE WHEN a.two_depth_nm is NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END AS twoDepthNm
, MAX(post_id) postId , MAX(post_id) postId
FROM ve_rsdnc a FROM ve_rsdnc a
WHERE 1=1 WHERE 1=1
@ -219,13 +240,13 @@
</isNotEmpty> </isNotEmpty>
GROUP BY one_depth_nm GROUP BY one_depth_nm
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) , CASE WHEN a.two_depth_nm is NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END
/* /*
, a.two_depth_nm , a.two_depth_nm
*/ */
ORDER BY one_depth_nm ORDER BY one_depth_nm
, IF(a.two_depth_nm is NULL OR a.two_depth_nm ='',a.three_depth_nm, a.two_depth_nm) , CASE WHEN a.two_depth_nm is NULL OR a.two_depth_nm ='' THEN a.three_depth_nm ELSE a.two_depth_nm END
/* /*
, a.two_depth_nm , a.two_depth_nm
*/ */

View File

@ -86,8 +86,7 @@
</select> </select>
<!-- 강사 정보 U --> <!-- 강사 정보 U -->
<update id="VEAAreaLctrStngDAO.update" parameterClass="VEAStngVO"> <update id="VEAAreaLctrStngDAO.update" parameterClass="VEAStngVO">
/* VEAAreaLctrStngDAO.update */ /* VEAAreaLctrStngDAO.update */
MERGE INTO <include refid="VEAAreaLctrStngDAO.table_name"/> MERGE INTO <include refid="VEAAreaLctrStngDAO.table_name"/>
USING DUAL USING DUAL

View File

@ -0,0 +1,491 @@
<!DOCTYPE html>
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="ui" uri="http://egovframework.gov/ctl/ui"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<%@ taglib prefix="ve" uri="/WEB-INF/tlds/kcc_tld.tld"%>
<%@ taglib prefix="validator" uri="http://www.springmodules.org/tags/commons-validator" %>
<%
/**
* @Class Name : cndtnEduPrcsAplctPrdMngDetail.jsp
* @Description : 기반강화연수 기간 상세화면
* @Modification Information
* @
* @ 수정일 수정자 수정내용
* @ ------- -------- ---------------------------
* @ 2021.12.16 조용준 최초 생성
* @author 조용주
* @since 2021.12.16
* @version 1.0
* @see
*
*/
%>
<html lang="ko">
<head>
<title>교육과정관리</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<script type="text/javascript">
$(document).ready(function(){
$('#searchStatus').change(function(){
searchpage();
});
});
function searchpage(){
var form = document.detailForm ;
form.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngDetail.do'/>";
form.submit();
}
function fncGoList(){
var listForm = document.listForm ;
listForm.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngList.do'/>";
listForm.submit();
}
function fncGoDetail(){
var form = document.detailForm ;
form.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngDetail.do'/>";
form.submit();
}
function fncMdfy(){
var detailForm = document.detailForm ;
detailForm.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctPrdMngMdfy.do'/>";
detailForm.submit();
}
function fn_delInstr(data){
document.instrForm.userId.value = data ;
var data = new FormData(document.getElementById("instrForm"));
if(confirm("삭제하시겠습니까?")){
// var url = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/instrDelAjax.do'/>";
var url = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/instrDelAjax.do'/>";
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("삭제되었습니다.");
// 새로고침
window.location.reload();
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
event.stopImmediatePropagation();
}
function fn_statusChg(eduAplctOrd, aplctStateCd){
document.statusChgForm.eduAplctOrd.value = eduAplctOrd ;
document.statusChgForm.aplctStateCd.value = aplctStateCd ;
var data = new FormData(document.getElementById("statusChgForm"));
if(confirm("상태병경을 하시겠습니까?")){
var url = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/updateAplctStateCdAjax.do'/>";
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("변경되었습니다.");
// 새로고침
window.location.reload();
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
event.stopImmediatePropagation();
}
// 강사 배치
function fncInstrAsgnmInfo(prcsAplctPrdOrd) {
var form = document.popForm;
form.prcsAplctPrdOrd.value = prcsAplctPrdOrd;
// form.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/popup/fndthInstrAsgnmPopup.do'/>";
form.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/popup/cndtnInstrAsgnmPopup.do'/>";
window.open("#", "_securityPop", "scrollbars = no, top=100px, left=100px, height=750px, width=950px");
form.target = "_securityPop";
form.submit();
}
function chkAll(obj) {
// 모든 체크박스의 상태를 헤더 체크박스의 상태와 동일하게 설정
$("input[name='chk']").prop('checked', $(obj).prop('checked'));
}
// form 데이터를 묶지 않기 때문에 prcsAplctPrdOrd 데이터 필요함
function fn_statusChgList(p_aplctStateCd, p_prcsAplctPrdOrd) {
var selectedEduAplctOrd = [];
// "chk" 이름을 가진 체크박스가 체크된 항목들을 순회
$("input[name='chk']:checked").each(function() {
var eduAplctOrdValue = $(this).val();
selectedEduAplctOrd.push(eduAplctOrdValue);
});
console.log('selectedEduAplctOrd : ', selectedEduAplctOrd);
// 선택된 항목이 없으면 경고 메시지를 표시하고 함수를 종료
if (selectedEduAplctOrd.length === 0) {
alert("선택된 항목이 없습니다. 선택 후 다시 시도하세요.");
return false;
}
var dataToSend = {
"eduAplctOrdList": selectedEduAplctOrd,
"aplctStateCd": p_aplctStateCd,
"prcsAplctPrdOrd": p_prcsAplctPrdOrd
};
var url = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/updateAplctStateCdListAjax.do'/>";
// AJAX 호출을 통해 서버에 데이터 전송
$.ajax({
type:"POST",
url: url,
data: $.param(dataToSend, true), // 직렬화 , 컨트롤러에서 @ModelAttribute로 받을 수 있음
// contentType : 'application/json',
dataType:'json',
success:function(returnData){
if(returnData.result == "success"){
alert("변경 처리 되었습니다.");
window.location.reload();
}else{
alert("변경 중 오류가 발생하였습니다.");
}
},
error: function(jqXHR, textStatus, errorThrown) {
console.error("AJAX Error:", textStatus, errorThrown);
console.error("Response:", jqXHR.responseText);
}
});
}
</script>
</head>
<body>
<form id="instrForm" name="instrForm" method="post">
<input type="hidden" name="prcsAplctPrdOrd" id="prcsAplctPrdOrd" value="<c:out value='${vEPrcsDetailVO.prcsAplctPrdOrd}' />"/>
<input type="hidden" name="userId" id="userId"/>
</form>
<form id="statusChgForm" name="statusChgForm" method="post">
<input type="hidden" name="prcsAplctPrdOrd" id="prcsAplctPrdOrd" value="<c:out value='${vEPrcsDetailVO.prcsAplctPrdOrd}' />"/>
<input type="hidden" name="aplctStateCd" id="aplctStateCd"/>
<input type="hidden" name="eduAplctOrd" id="eduAplctOrd"/>
</form>
<form:form id="listForm" name="listForm" commandName="vEPrcsDetailVO" method="post">
</form:form>
<form id="popForm" name="popForm" method="post">
<input type="hidden" name="pageIndex" value="1"/>
<input type="hidden" name="prcsAplctPrdOrd" value="" />
<input type="hidden" name="pageUnit" value="5" />
</form>
<form:form id="detailForm" name="detailForm" commandName="vEPrcsDetailVO" method="post">
<input type="hidden" name="prcsAplctPrdOrd" id="prcsAplctPrdOrd" value="<c:out value='${vEPrcsDetailVO.prcsAplctPrdOrd}' />"/>
<!-- cont -->
<div class="cont_wrap">
<div class="box">
<!-- cont_tit -->
<div class="cont_tit">
<h2>교육확정상세</h2>
<ul class="cont_nav">
<li class="home"><a href="/"><i></i></a></li>
<li>
<p>조건부기소유예관리</p>
</li>
<li><span class="cur_nav">교육확정상세</span></li>
</ul>
</div>
<!-- //cont_tit -->
<div class="cont">
<!-- list_상세 -->
<div class="tb_tit01">
<p>교육과정관리</p>
</div>
<div class="tb_type02">
<table>
<colgroup>
<col style="width: 210px;">
<col style="width: auto;">
<col style="width: 210px;">
<col style="width: auto;">
</colgroup>
<tbody>
<tr>
<th scope="row">교육부분</th>
<td>
<ve:code codeId="VEA001" code="${info.prcsDiv}"/>
</td>
</tr>
<tr>
<th scope="row">과정</th>
<td>
<c:out value="${info.prcsNm}"/>
</td>
</tr>
<tr>
<th scope="row">신청기간</th>
<td>
<c:out value="${info.strtPnttm}"/>~<c:out value="${info.endPnttm}"/>
</td>
</tr>
<tr>
<th scope="row">교육장소</th>
<td class="addPro_wrap">
<c:out value="${info.eduPlace}"/>
</td>
</tr>
<tr>
<th scope="row">교육기간</th>
<td>
<c:out value="${info.eduStrtPnttm}"/>~<c:out value="${info.eduDdlnPnttm}"/>
</td>
</tr>
<tr>
<th scope="row">상세교육과정</th>
<td>
<c:out value="${info.prcsCn }" />
</td>
</tr>
<tr>
<th scope="row">정원</th>
<td class="addPro_wrap">
<c:out value="${info.nos}"/>
</td>
</tr>
<tr>
<th scope="row">상태</th>
<td id="ddlnCdStts">
<ve:code codeId="VEA004" code="${info.ddlnCd}"/>
</td>
</tr>
<%-- <tr>
<th scope="row">
<p>공개여부(사용여부)</p>
</th>
<td>
<c:if test="${empty info.useYn or info.useYn eq 'Y'}">예</c:if>
<c:if test="${info.useYn eq 'N'}">아니오</c:if>
</td>
</tr> --%>
</tbody>
</table>
</div>
<!-- //list_상세 -->
<!-- btn_wrap -->
<div class="btn_wrap btn_layout01">
<div class="btn_left">
</div>
<div class="btn_center">
</div>
<div class="btn_right">
<button type="button" class="btn_type02" onclick="fncMdfy(); return false;">수정</button>
<button type="button" class="btn_type03" onclick="fncGoList(); return false;">목록</button>
</div>
</div>
<!--
강사 배치 정보
강사 배치 정보
-->
<div class="tb_tit01">
<p>강사 배치 정보</p>
</div>
<div class="tb_type01">
<table>
<colgroup>
<col style="width: 210px;"><!-- name -->
<col style="width: auto;"><!-- 제출일 -->
<col style="width: 210px;"><!-- 신청상태 -->
<col style="width: 210px;"><!-- 신청상태 -->
</colgroup>
<thead>
<tr>
<th>강사명</th>
<th>연락처</th>
<th>확정여부</th>
<th>삭제</th>
</tr>
</thead>
<tbody>
<c:choose>
<c:when test="${!empty instrAsgnmList }">
<c:forEach var="list" items="${instrAsgnmList}" varStatus="status">
<tr>
<td>
<c:out value="${list.instrNm }"/>
</td>
<td>
<c:out value="${list.phone }"/>
</td>
<td>
<ve:code codeId="VE0019" code="${list.asgnmAprvlCd}"/>
</td>
<td>
<button type="button" class="btn_type01" onclick="fn_delInstr('<c:out value="${list.userId }" />')">삭제</button>
</td>
</tr>
</c:forEach>
</c:when>
<c:otherwise>
<tr>
<td colspan="4">강사 배치 정보가 없습니다.</td>
</tr>
</c:otherwise>
</c:choose>
</tbody>
</table>
</div>
<!-- btn_wrap -->
<div class="btn_wrap btn_layout01">
<div class="btn_left">
</div>
<div class="btn_center">
</div>
<div class="btn_right">
<button type="button" class="btn_type02" onclick="fncInstrAsgnmInfo('<c:out value="${info.prcsAplctPrdOrd }" />'); return false;">강사배치</button>
</div>
</div>
<!--
교육 신청자 list_상세
교육 신청자 list_상세
-->
<div class="tb_tit01">
<p>교육신청자</p> <!-- ${listPrcsAplct } -->
</div>
<!-- list_top -->
<div class="list_top search-only">
<div class="list_top_1">
<div class="util_right">
<ve:select codeId="VEA003" name="searchStatus" id="searchStatus" css="class='sel_type1'"
selectedValue="${vEPrcsDetailVO.searchStatus}" defaultValue='' includes="10,20"
defaultText='전체'
/>
</div>
</div>
</div>
<div class="tb_type01">
<table>
<colgroup>
<col style="width: 5%">
<col style="width: 180px;">
<col style="width: 12%">
<col style="width: 210px;">
<col style="width: 210px;">
<col style="width: 210px;">
</colgroup>
<thead>
<tr>
<th><input type="checkbox" name="checkAll" id="checkAll" onclick="chkAll(this);" /><label for="checkAll"></label></th>
<th>신청자(대상자)</th>
<th>주민번호 앞자리</th>
<th>연락처</th>
<th>교육이수여부</th>
<th>교육이수상태변경</th>
</tr>
</thead>
<tbody>
<c:choose>
<c:when test="${!empty listPrcsAplct}">
<c:forEach var="list" items="${listPrcsAplct}" varStatus="status">
<tr>
<td>
<input name="chk" class="${list.asgnmAprvlCd}"
value="${list.eduAplctOrd}" title="Check" type="checkbox"/>
</td>
<td>
<c:out value="${list.userNm}"/>(<c:out value="${list.trgtNm}"/>)
</td>
<td>
<c:out value="${list.dBirth}"/>
</td>
<td>
<c:out value="${list.vs_clphone}"/>
</td>
<td>
<ve:code codeId="VEA003" code="${list.aplctStateCd}"/>
</td>
<td>
<button type="button" class="btn_type04" onclick="fn_statusChg('<c:out value="${list.eduAplctOrd }" />', '20')">이수</button>
<button type="button" class="btn_type05" onclick="fn_statusChg('<c:out value="${list.eduAplctOrd }" />', '10')">미이수</button>
</td>
</tr>
</c:forEach>
</c:when>
<c:otherwise>
<tr>
<td colspan="6">데이터가 없습니다.</td>
</tr>
</c:otherwise>
</c:choose>
</tbody>
</table>
</div>
<!-- //list_상세 -->
<!-- btn_wrap -->
<div class="btn_wrap btn_layout01">
<div class="btn_left">
</div>
<div class="btn_center">
</div>
<div class="btn_right">
<button type="button" class="btn_type04" onclick="location.href='<c:url value="/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngList.do" />'; return false;">교육확정목록</button>
<button type="button" class="btn_type04" onclick="fn_statusChgList('20', '<c:out value="${info.prcsAplctPrdOrd }" />'); return false;">이수</button>
<button type="button" class="btn_type04" onclick="fn_statusChgList('10', '<c:out value="${info.prcsAplctPrdOrd }" />'); return false;">미이수</button>
</div>
</div>
</div>
</div>
</div>
</form:form>
<!-- //cont -->
</body>
</html>

View File

@ -0,0 +1,320 @@
<!DOCTYPE html>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="ui" uri="http://egovframework.gov/ctl/ui"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<%@ taglib prefix="validator" uri="http://www.springmodules.org/tags/commons-validator" %>
<%@ taglib prefix="kc" uri="/WEB-INF/tlds/kcc_tld.tld"%>
<%@ taglib prefix="un" uri="http://jakarta.apache.org/taglibs/unstandard-1.0" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<%@ taglib prefix="ve" uri="/WEB-INF/tlds/kcc_tld.tld"%>
<un:useConstants var="KccadrStatus" className="kcc.kccadr.cmm.KccadrConstants" />
<%
/**
* @Class Name : cndtnEduPrcsAplctPrdMngList.jsp
* @Description : 조건부기소유예관리 과정 신청기간관리 목록
* @Modification Information
* @
* @ 수정일 수정자 수정내용
* @ ------- -------- ---------------------------
* @ 2021.12.14 조용준 최초 생성
* @author 조용준
* @since 2021.12.14
* @version 1.0
* @see
*
*/
%>
<html lang="ko">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style>
input:read-only{
background-color: #ededed;
}
</style>
<script type="text/javascript">
$(document).ready(function(){
// 상태값 확인
$(".ddlnCdStts").each(function() {
var $currentCell = $(this);
// 텍스트가 비어있는지 확인
if ($currentCell.text().trim() === "") {
var $currentRow = $currentCell.closest('tr');
var strtPnttm = new Date($currentRow.find("td:eq(3)").text().split("~")[0].trim());
var endPnttm = new Date($currentRow.find("td:eq(3)").text().split("~")[1].trim());
var currentDate = new Date();
var ddlnCdText = '';
if (currentDate < strtPnttm) {
ddlnCdText = "접수전";
} else if (currentDate >= strtPnttm && currentDate <= endPnttm) {
ddlnCdText = "접수중";
} else if (currentDate > endPnttm) {
ddlnCdText = "접수종료";
}
$currentCell.text(ddlnCdText);
}
});
});
function fncGoList(){
linkPage(1);
}
function linkPage(pageNo){
var listForm = document.listForm ;
listForm.pageIndex.value = pageNo ;
listForm.searchKeyword.value = $('#searchKeyword').val();
listForm.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngList.do'/>";
listForm.submit();
}
function fncGoDetail(prcsAplctPrdOrd){
var listForm = document.listForm ;
listForm.prcsAplctPrdOrd.value = prcsAplctPrdOrd ;
listForm.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngDetail.do'/>";
listForm.submit();
}
function fncDelete(prcsOrd){
document.listForm.prcsOrd.value = prcsOrd ;
var pageIndex = document.listForm.pageIndex.value;
if($(".listCount").length == '1'){
pageIndex = pageIndex -1;
}
var data = new FormData(document.getElementById("listForm"));
if(confirm("삭제하시겠습니까?")){
var url = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsMngDeleteAjax.do'/>";
console.log(data);
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("삭제되었습니다.");
document.listForm.prcsOrd.value = ""; //리스트 이동시 prcsOrd 초기화
linkPage(pageIndex);
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
event.stopImmediatePropagation();
}
function fncSaveSort(prcsOrd, count){
var sortNo = $('#prcsSortNo'+count).val();
if(sortNo == ''){
alert("표시순서를 입력해 주세요.");
return false;
}
$('#prcsOrd').val(prcsOrd);
$('#prcsSortNo').val(sortNo);
var data = new FormData(document.getElementById("listForm"));
var url = "<c:url value='/kccadr/oprtn/otsdCprtnPrcs/eduPrcsSortUpdateAjax.do'/>";
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("저장되었습니다.");
document.listForm.prcsOrd.value = ""; //리스트 이동시 prcsOrd 초기화
fncGoList();
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
</script>
<title>과정신청기간관리목록</title>
</head>
<body>
<form:form id="listForm" name="listForm" method="post" commandName="vEPrcsDetailVO" onsubmit="return false;">
<input type="hidden" name="pageIndex" value="<c:out value='${vEPrcsDetailVO.pageIndex}' default='1' />"/>
<input type="hidden" name="searchSortCnd" value="<c:out value="${vEPrcsDetailVO.searchSortCnd}" />" />
<input type="hidden" name="searchSortOrd" value="<c:out value="${vEPrcsDetailVO.searchSortOrd}" />" />
<input type="hidden" id="prcsOrd" name="prcsOrd" value="" />
<input type="hidden" id="prcsAplctPrdOrd" name="prcsAplctPrdOrd" value="" />
<input type="hidden" id="prcsSortNo" name="prcsSortNo" value="" />
<div class="cont_wrap">
<div class="box">
<!-- cont_tit -->
<div class="cont_tit">
<h2>교육확정관리목록</h2>
<ul class="cont_nav">
<li class="home"><a href="/"><i></i></a></li>
<li>
<p>조건부기소유예관리</p>
</li>
<li><span class="cur_nav">교육확정관리목록</span></li>
</ul>
</div>
<!-- //cont_tit -->
<div class="cont">
<div class="tb_tit01">
<p>교육 확정 관리</p>
</div>
<!-- list_top -->
<div class="list_top search-only">
<div class="list_top_1">
<div class="util_right">
<ve:select codeId="VEA001" name="searchStatus" id="searchStatus" css="class='sel_type1'"
selectedValue="${vEPrcsDetailVO.searchStatus }" defaultValue=""
defaultText="전체"
/>
<div class="calendar_wrap">
<input type="text" class="calendar" title="시작일 선택" id="searchSmbtStartDt" name="searchSmbtStartDt" value="${vEPrcsDetailVO.searchSmbtStartDt}">
</div>
~
<div class="calendar_wrap">
<input type="text" class="calendar" title="종료일 선택" id="searchSmbtEndDt" name="searchSmbtEndDt" value="${vEPrcsDetailVO.searchSmbtEndDt}">
</div>
<input type="text" id="searchKeyword" name="searchKeyword" placeholder="과정명를 입력하세요." title="검색어 입력" class="search_input" value="<c:out value='${vEPrcsDetailVO.searchKeyword}'/>">
<button type="button" class="btn_type08" onclick="fncGoList(); return false;">검색</button>
<button class="btn_type03" onclick="fncReset(this); return false;">초기화</button>
</div>
</div>
</div>
<div class="list_util">
<p class="list_util_p"><span><c:out value="${paginationInfo.totalRecordCount}" /></span>건의 접수가 검색되었습니다.</p>
<div>
<select class="sel_type1" name="pageUnit" id="pageUnit" onchange="linkPage(1);" title="줄 선택" style="width: 140px" class="sel_type1">
<option value='10' <c:if test="${vEPrcsDetailVO.pageUnit == '10' or vEPrcsDetailVO.pageUnit == ''}">selected</c:if>>10줄</option>
<option value='20' <c:if test="${vEPrcsDetailVO.pageUnit == '20'}">selected</c:if>>20줄</option>
<option value='30' <c:if test="${vEPrcsDetailVO.pageUnit == '30'}">selected</c:if>>30줄</option>
<option value='100' <c:if test="${vEPrcsDetailVO.pageUnit == '100'}">selected</c:if>>100줄</option>
</select>
<%--<button type="button" class="btn_down_excel">엑셀 다운로드</button>--%>
</div>
</div>
<!-- //list_top -->
<!-- list -->
<div class="tb_type01">
<table>
<colgroup>
<col style="width: 5%">
<col style="width: 10%">
<col style="width: auto">
<col style="width: 180px;">
<col style="width: 180px;">
<col style="width: 10%">
<col style="width: 10%">
<%-- <col style="width: 10%"> --%>
</colgroup>
<thead>
<tr>
<th>NO</th>
<th>교육구분코드</th>
<th>과정명</th>
<th>교육기간</th>
<th>신청자/정원</th>
<th>상태</th>
<th>강사배정</th>
<!-- <th>공개여부</th> -->
</tr>
</thead>
<tbody>
<c:forEach var="list" items="${list}" varStatus="status">
<tr class="listCount">
<td onclick="fncGoDetail('<c:out value="${list.prcsAplctPrdOrd}"/>');" style="cursor:pointer;">
<c:out value="${status.count}"/>
</td>
<td>
<kc:code codeId="VEA001" code="${list.prcsDiv}"/>
</td>
<td onclick="fncGoDetail('<c:out value="${list.prcsAplctPrdOrd}"/>');" style="cursor:pointer;">
<c:out value="${list.prcsNm}"/>(<c:out value="${list.prcsAplctPrdOrd}"/>)
</td>
<td>
<c:out value="${list.eduStrtPnttm}"/>~<c:out value="${list.eduDdlnPnttm}"/>
</td>
<td>
<c:out value="${list.nosCnt1}"/>/<c:out value="${list.nos}"/>
</td>
<td class="ddlnCdStts">
<kc:code codeId="VEA004" code="${list.ddlnCd}"/>
</td>
<td>
<%-- <c:out value="${list.strtPnttm}"/>~<c:out value="${list.endPnttm}"/> --%>
<c:choose>
<c:when test="${list.instrCnt ne 0 }">
배정완료
</c:when>
<c:otherwise>
<button type="button" class="btn_type04" onclick="fncGoDetail('<c:out value="${list.prcsAplctPrdOrd}"/>');">강사배정</button>
</c:otherwise>
</c:choose>
</td>
<!-- <td> -->
<%-- <c:out value="${list.useYn}"/> --%>
<!-- </td> -->
</tr>
</c:forEach>
<c:if test="${empty list}">
<tr><td colspan="7"><spring:message code="common.nodata.msg" /></td></tr>
</c:if>
</tbody>
</table>
</div>
<!-- //list -->
<!-- page -->
<div class="page">
<ui:pagination paginationInfo = "${paginationInfo}" type="image" jsFunction="linkPage" />
</div>
<!-- //page -->
</div>
</div>
</div>
<!-- //cont -->
<!-- //cont -->
</form:form>
</body>
</html>

View File

@ -115,6 +115,10 @@
<td> <td>
<ve:code codeId="COM014" code="${info.sex }"/> <ve:code codeId="COM014" code="${info.sex }"/>
</td> </td>
<th scope="row">연락처</th>
<td>
<c:out value="${info.clphone }" />
</td>
</tr> </tr>
<tr> <tr>
<th scope="row">성명</th> <th scope="row">성명</th>

View File

@ -293,6 +293,10 @@
defaultText='선택' defaultText='선택'
/> />
</td> </td>
<th scope="row">연락처</th>
<td>
<input type="text" name="clphone" id="clphone" placeholder="00000000000" maxlength="11" value="<c:out value="${info.clphone }" />" />
</td>
</tr> </tr>
<tr> <tr>
<th scope="row">성명</th> <th scope="row">성명</th>

View File

@ -242,6 +242,10 @@
defaultText='선택' defaultText='선택'
/> />
</td> </td>
<th scope="row">연락처</th>
<td>
<input type="text" name="clphone" id="clphone" placeholder="00000000000" maxlength="11"/>
</td>
</tr> </tr>
<tr> <tr>
<th scope="row">성명</th> <th scope="row">성명</th>

View File

@ -140,7 +140,7 @@
</div> </div>
<div class="util_right"> <div class="util_right">
<ve:select codeId="VE0029" name="searchStateYear" id="searchStateYear" css="class='sel_type1'" <ve:select codeId="VE0029" name="searchStateYear" id="searchStateYear" css="class='sel_type1'"
selectedValue="${vEEduAplctVO.searchStateYear}" selectedValue="${vEEduAplctVO.searchStateYear}" defaultText='전체'
/> />
<ve:select codeId="VE0008" name="searchEduSlctAreaCd2" id="searchEduSlctAreaCd2" css="class='sel_type1'" <ve:select codeId="VE0008" name="searchEduSlctAreaCd2" id="searchEduSlctAreaCd2" css="class='sel_type1'"
selectedValue="${vEEduAplctVO.searchEduSlctAreaCd2}" defaultText='전체' selectedValue="${vEEduAplctVO.searchEduSlctAreaCd2}" defaultText='전체'
@ -195,6 +195,20 @@
</div> </div>
</div> </div>
</div> </div>
<div class="list_top_3">
<div class="util_left">
<p>처리상태</p>
</div>
<div class="util_right">
<div class="calendar_wrap">
<input type="text" class="calendar" title="시작일 선택" id="searchStartRegistPnttm" name="searchStartRegistPnttm" value="${vEEduAplctVO.searchStartRegistPnttm}">
</div>
~
<div class="calendar_wrap">
<input type="text" class="calendar" title="종료일 선택" id="searchEndRegistPnttm" name="searchEndRegistPnttm" value="${vEEduAplctVO.searchEndRegistPnttm}">
</div>
</div>
</div>
</div> </div>
<!-- //list_top --> <!-- //list_top -->

View File

@ -0,0 +1,475 @@
<!DOCTYPE html>
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="ui" uri="http://egovframework.gov/ctl/ui"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<%@ taglib prefix="ve" uri="/WEB-INF/tlds/kcc_tld.tld"%>
<%@ taglib prefix="validator" uri="http://www.springmodules.org/tags/commons-validator" %>
<%
/**
* @Class Name : cndtnEduPrcsAplctPrdMngDetail.jsp
* @Description : 기반강화연수 기간 상세화면
* @Modification Information
* @
* @ 수정일 수정자 수정내용
* @ ------- -------- ---------------------------
* @ 2021.12.16 조용준 최초 생성
* @author 조용주
* @since 2021.12.16
* @version 1.0
* @see
*
*/
%>
<html lang="ko">
<head>
<title>교육과정관리</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<script type="text/javascript">
$(document).ready(function(){
$('#searchStatus').change(function(){
searchpage();
});
});
function searchpage(){
var form = document.detailForm ;
form.action = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsAplctCfnMngDetail.do'/>";
form.submit();
}
function fncGoList(){
var listForm = document.listForm ;
listForm.action = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsAplctCfnMngList.do'/>";
listForm.submit();
}
function fncMdfy(){
var detailForm = document.detailForm ;
detailForm.action = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsAplctPrdMngMdfy.do'/>";
detailForm.submit();
}
function fn_delInstr(data){
document.instrForm.userId.value = data ;
var data = new FormData(document.getElementById("instrForm"));
if(confirm("삭제하시겠습니까?")){
var url = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/instrDelAjax.do'/>";
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("삭제되었습니다.");
// 새로고침
window.location.reload();
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
event.stopImmediatePropagation();
}
// 기반 / 기소 공통
function fn_statusChg(eduAplctOrd, aplctStateCd){
document.statusChgForm.eduAplctOrd.value = eduAplctOrd ;
document.statusChgForm.aplctStateCd.value = aplctStateCd ;
var data = new FormData(document.getElementById("statusChgForm"));
if(confirm("상태병경을 하시겠습니까?")){
var url = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/updateAplctStateCdAjax.do'/>";
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("변경되었습니다.");
// 새로고침
window.location.reload();
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
event.stopImmediatePropagation();
}
// 강사 배치
function fncInstrAsgnmInfo(prcsAplctPrdOrd) {
var form = document.popForm;
form.prcsAplctPrdOrd.value = prcsAplctPrdOrd;
form.action = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/popup/fndthInstrAsgnmPopup.do'/>";
// form.action = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/popup/cndtnInstrAsgnmPopup.do'/>";
window.open("#", "_securityPop", "scrollbars = no, top=100px, left=100px, height=750px, width=950px");
form.target = "_securityPop";
form.submit();
}
function chkAll(obj) {
// 모든 체크박스의 상태를 헤더 체크박스의 상태와 동일하게 설정
$("input[name='chk']").prop('checked', $(obj).prop('checked'));
}
// form 데이터를 묶지 않기 때문에 prcsAplctPrdOrd 데이터 필요함
function fn_statusChgList(p_aplctStateCd, p_prcsAplctPrdOrd) {
var selectedEduAplctOrd = [];
// "chk" 이름을 가진 체크박스가 체크된 항목들을 순회
$("input[name='chk']:checked").each(function() {
var eduAplctOrdValue = $(this).val();
selectedEduAplctOrd.push(eduAplctOrdValue);
});
console.log('selectedEduAplctOrd : ', selectedEduAplctOrd);
// 선택된 항목이 없으면 경고 메시지를 표시하고 함수를 종료
if (selectedEduAplctOrd.length === 0) {
alert("선택된 항목이 없습니다. 선택 후 다시 시도하세요.");
return false;
}
var dataToSend = {
"eduAplctOrdList": selectedEduAplctOrd,
"aplctStateCd": p_aplctStateCd,
"prcsAplctPrdOrd": p_prcsAplctPrdOrd
};
var url = "<c:url value='/kccadr/oprtn/cndtnSspnIdtmt/updateAplctStateCdListAjax.do'/>";
// AJAX 호출을 통해 서버에 데이터 전송
$.ajax({
type:"POST",
url: url,
data: $.param(dataToSend, true), // 직렬화 , 컨트롤러에서 @ModelAttribute로 받을 수 있음
// contentType : 'application/json',
dataType:'json',
success:function(returnData){
if(returnData.result == "success"){
alert("변경 처리 되었습니다.");
window.location.reload();
}else{
alert("변경 중 오류가 발생하였습니다.");
}
},
error: function(jqXHR, textStatus, errorThrown) {
console.error("AJAX Error:", textStatus, errorThrown);
console.error("Response:", jqXHR.responseText);
}
});
}
</script>
</head>
<body>
<form id="instrForm" name="instrForm" method="post">
<input type="hidden" name="prcsAplctPrdOrd" id="prcsAplctPrdOrd" value="<c:out value='${vEPrcsDetailVO.prcsAplctPrdOrd}' />"/>
<input type="hidden" name="userId" id="userId"/>
</form>
<form id="statusChgForm" name="statusChgForm" method="post">
<input type="hidden" name="prcsAplctPrdOrd" id="prcsAplctPrdOrd" value="<c:out value='${vEPrcsDetailVO.prcsAplctPrdOrd}' />"/>
<input type="hidden" name="aplctStateCd" id="aplctStateCd"/>
<input type="hidden" name="eduAplctOrd" id="eduAplctOrd"/>
</form>
<form:form id="listForm" name="listForm" commandName="vEPrcsDetailVO" method="post">
</form:form>
<form id="popForm" name="popForm" method="post">
<input type="hidden" name="pageIndex" value="1"/>
<input type="hidden" name="prcsAplctPrdOrd" value="" />
<input type="hidden" name="pageUnit" value="5" />
</form>
<form:form id="detailForm" name="detailForm" commandName="vEPrcsDetailVO" method="post">
<input type="hidden" name="prcsAplctPrdOrd" id="prcsAplctPrdOrd" value="<c:out value='${vEPrcsDetailVO.prcsAplctPrdOrd}' />"/>
<!-- cont -->
<div class="cont_wrap">
<div class="box">
<!-- cont_tit -->
<div class="cont_tit">
<h2>교육확정관리상세</h2>
<ul class="cont_nav">
<li class="home"><a href="/"><i></i></a></li>
<li>
<p>기반강화연수관리</p>
</li>
<li><span class="cur_nav">교육확정관리상세</span></li>
</ul>
</div>
<!-- //cont_tit -->
<div class="cont">
<!-- list_상세 -->
<div class="tb_tit01">
<p>교육과정관리</p>
</div>
<div class="tb_type02">
<table>
<colgroup>
<col style="width: 210px;">
<col style="width: auto;">
<col style="width: 210px;">
<col style="width: auto;">
</colgroup>
<tbody>
<tr>
<th scope="row">교육부분</th>
<td>
<ve:code codeId="VEA001" code="${info.prcsDiv}"/>
</td>
</tr>
<tr>
<th scope="row">과정</th>
<td>
<c:out value="${info.prcsNm}"/>
</td>
</tr>
<tr>
<th scope="row">신청기간</th>
<td>
<c:out value="${info.strtPnttm}"/>~<c:out value="${info.endPnttm}"/>
</td>
</tr>
<tr>
<th scope="row">교육장소</th>
<td class="addPro_wrap">
<c:out value="${info.eduPlace}"/>
</td>
</tr>
<tr>
<th scope="row">교육기간</th>
<td>
<c:out value="${info.eduStrtPnttm}"/>~<c:out value="${info.eduDdlnPnttm}"/>
</td>
</tr>
<tr>
<th scope="row">상세교육과정</th>
<td>
<c:out value="${info.prcsCn }" />
</td>
</tr>
<tr>
<th scope="row">정원</th>
<td class="addPro_wrap">
<c:out value="${info.nos}"/>
</td>
</tr>
<tr>
<th scope="row">상태</th>
<td id="ddlnCdStts">
<ve:code codeId="VEA004" code="${info.ddlnCd}"/>
</td>
</tr>
<%-- <tr>
<th scope="row">
<p>공개여부(사용여부)</p>
</th>
<td>
<c:if test="${empty info.useYn or info.useYn eq 'Y'}">예</c:if>
<c:if test="${info.useYn eq 'N'}">아니오</c:if>
</td>
</tr> --%>
</tbody>
</table>
</div>
<!-- //list_상세 -->
<!-- btn_wrap -->
<div class="btn_wrap btn_layout01">
<div class="btn_left">
</div>
<div class="btn_center">
</div>
<div class="btn_right">
<button type="button" class="btn_type02" onclick="fncMdfy(); return false;">수정</button>
<button type="button" class="btn_type03" onclick="fncGoList(); return false;">목록</button>
</div>
</div>
<!--
강사 배치 정보
강사 배치 정보
-->
<div class="tb_tit01">
<p>강사 배치 정보</p>
</div>
<div class="tb_type01">
<table>
<colgroup>
<col style="width: 210px;"><!-- name -->
<col style="width: auto;"><!-- 제출일 -->
<col style="width: 210px;"><!-- 신청상태 -->
<col style="width: 210px;"><!-- 신청상태 -->
</colgroup>
<thead>
<tr>
<th>강사명</th>
<th>연락처</th>
<th>확정여부</th>
<th>삭제</th>
</tr>
</thead>
<tbody>
<c:choose>
<c:when test="${!empty instrAsgnmList }">
<c:forEach var="list" items="${instrAsgnmList}" varStatus="status">
<tr>
<td>
<c:out value="${list.instrNm }"/>
</td>
<td>
<c:out value="${list.phone }"/>
</td>
<td>
<ve:code codeId="VE0019" code="${list.asgnmAprvlCd}"/>
</td>
<td>
<button type="button" class="btn_type01" onclick="fn_delInstr('<c:out value="${list.userId }" />')">삭제</button>
</td>
</tr>
</c:forEach>
</c:when>
<c:otherwise>
<tr>
<td colspan="4">강사 배치 정보가 없습니다.</td>
</tr>
</c:otherwise>
</c:choose>
</tbody>
</table>
</div>
<!-- btn_wrap -->
<div class="btn_wrap btn_layout01">
<div class="btn_left">
</div>
<div class="btn_center">
</div>
<div class="btn_right">
<button type="button" class="btn_type02" onclick="fncInstrAsgnmInfo('<c:out value="${info.prcsAplctPrdOrd }" />'); return false;">강사배치</button>
</div>
</div>
<!--
교육 신청자 list_상세
교육 신청자 list_상세
-->
<div class="tb_tit01">
<p>교육신청자</p> <!-- ${listPrcsAplct } -->
</div>
<!-- list_top -->
<div class="list_top search-only">
<div class="list_top_1">
<div class="util_right">
<ve:select codeId="VEA003" name="searchStatus" id="searchStatus" css="class='sel_type1'"
selectedValue="${vEPrcsDetailVO.searchStatus}" defaultValue='' includes="10,20"
defaultText='전체'
/>
</div>
</div>
</div>
<div class="tb_type01">
<table>
<colgroup>
<col style="width: 5%">
<col style="width: 180px;">
<col style="width: 180px;">
<col style="width: 210px;">
</colgroup>
<thead>
<tr>
<th><input type="checkbox" name="checkAll" id="checkAll" onclick="chkAll(this);" /><label for="checkAll"></label></th>
<th>신청자</th>
<th>교육이수여부</th>
<th>교육이수상태변경</th>
</tr>
</thead>
<tbody>
<c:choose>
<c:when test="${!empty listPrcsAplct}">
<c:forEach var="list" items="${listPrcsAplct}" varStatus="status">
<tr>
<td>
<input name="chk" class="${list.asgnmAprvlCd}"
value="${list.eduAplctOrd}" title="Check" type="checkbox"/>
</td>
<td>
<c:out value="${list.userNm}"/>
<td>
<ve:code codeId="VEA003" code="${list.aplctStateCd}"/>
</td>
<td>
<button type="button" class="btn_type04" onclick="fn_statusChg('<c:out value="${list.eduAplctOrd }" />', '20')">이수</button>
<button type="button" class="btn_type05" onclick="fn_statusChg('<c:out value="${list.eduAplctOrd }" />', '10')">미이수</button>
</td>
</tr>
</c:forEach>
</c:when>
<c:otherwise>
<tr>
<td colspan="4">데이터가 없습니다.</td>
</tr>
</c:otherwise>
</c:choose>
</tbody>
</table>
</div>
<!-- //list_상세 -->
<!-- btn_wrap -->
<div class="btn_wrap btn_layout01">
<div class="btn_left">
</div>
<div class="btn_center">
</div>
<div class="btn_right">
<button type="button" class="btn_type04" onclick="location.href='<c:url value="/kccadr/oprtn/cndtnSspnIdtmt/cndtnEduPrcsAplctCfnMngList.do" />'; return false;">교육확정목록</button>
<button type="button" class="btn_type04" onclick="fn_statusChgList('20', '<c:out value="${info.prcsAplctPrdOrd }" />'); return false;">이수</button>
<button type="button" class="btn_type04" onclick="fn_statusChgList('10', '<c:out value="${info.prcsAplctPrdOrd }" />'); return false;">미이수</button>
</div>
</div>
</div>
</div>
</div>
</form:form>
<!-- //cont -->
</body>
</html>

View File

@ -0,0 +1,320 @@
<!DOCTYPE html>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="ui" uri="http://egovframework.gov/ctl/ui"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<%@ taglib prefix="validator" uri="http://www.springmodules.org/tags/commons-validator" %>
<%@ taglib prefix="kc" uri="/WEB-INF/tlds/kcc_tld.tld"%>
<%@ taglib prefix="un" uri="http://jakarta.apache.org/taglibs/unstandard-1.0" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<%@ taglib prefix="ve" uri="/WEB-INF/tlds/kcc_tld.tld"%>
<un:useConstants var="KccadrStatus" className="kcc.kccadr.cmm.KccadrConstants" />
<%
/**
* @Class Name : cndtnEduPrcsAplctPrdMngList.jsp
* @Description : 조건부기소유예관리 과정 신청기간관리 목록
* @Modification Information
* @
* @ 수정일 수정자 수정내용
* @ ------- -------- ---------------------------
* @ 2021.12.14 조용준 최초 생성
* @author 조용준
* @since 2021.12.14
* @version 1.0
* @see
*
*/
%>
<html lang="ko">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style>
input:read-only{
background-color: #ededed;
}
</style>
<script type="text/javascript">
$(document).ready(function(){
// 상태값 확인
$(".ddlnCdStts").each(function() {
var $currentCell = $(this);
// 텍스트가 비어있는지 확인
if ($currentCell.text().trim() === "") {
var $currentRow = $currentCell.closest('tr');
var strtPnttm = new Date($currentRow.find("td:eq(3)").text().split("~")[0].trim());
var endPnttm = new Date($currentRow.find("td:eq(3)").text().split("~")[1].trim());
var currentDate = new Date();
var ddlnCdText = '';
if (currentDate < strtPnttm) {
ddlnCdText = "접수전";
} else if (currentDate >= strtPnttm && currentDate <= endPnttm) {
ddlnCdText = "접수중";
} else if (currentDate > endPnttm) {
ddlnCdText = "접수종료";
}
$currentCell.text(ddlnCdText);
}
});
});
function fncGoList(){
linkPage(1);
}
function linkPage(pageNo){
var listForm = document.listForm ;
listForm.pageIndex.value = pageNo ;
listForm.searchKeyword.value = $('#searchKeyword').val();
listForm.action = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsAplctCfnMngList.do'/>";
listForm.submit();
}
function fncGoDetail(prcsAplctPrdOrd){
var listForm = document.listForm ;
listForm.prcsAplctPrdOrd.value = prcsAplctPrdOrd ;
listForm.action = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsAplctCfnMngDetail.do'/>";
listForm.submit();
}
function fncDelete(prcsOrd){
document.listForm.prcsOrd.value = prcsOrd ;
var pageIndex = document.listForm.pageIndex.value;
if($(".listCount").length == '1'){
pageIndex = pageIndex -1;
}
var data = new FormData(document.getElementById("listForm"));
if(confirm("삭제하시겠습니까?")){
var url = "<c:url value='/kccadr/oprtn/fndthEnhanceTrn/fndthEduPrcsMngDeleteAjax.do'/>";
console.log(data);
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("삭제되었습니다.");
document.listForm.prcsOrd.value = ""; //리스트 이동시 prcsOrd 초기화
linkPage(pageIndex);
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
event.stopImmediatePropagation();
}
function fncSaveSort(prcsOrd, count){
var sortNo = $('#prcsSortNo'+count).val();
if(sortNo == ''){
alert("표시순서를 입력해 주세요.");
return false;
}
$('#prcsOrd').val(prcsOrd);
$('#prcsSortNo').val(sortNo);
var data = new FormData(document.getElementById("listForm"));
var url = "<c:url value='/kccadr/oprtn/otsdCprtnPrcs/eduPrcsSortUpdateAjax.do'/>";
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("저장되었습니다.");
document.listForm.prcsOrd.value = ""; //리스트 이동시 prcsOrd 초기화
fncGoList();
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
</script>
<title>과정신청기간관리목록</title>
</head>
<body>
<form:form id="listForm" name="listForm" method="post" commandName="vEPrcsDetailVO" onsubmit="return false;">
<input type="hidden" name="pageIndex" value="<c:out value='${vEPrcsDetailVO.pageIndex}' default='1' />"/>
<input type="hidden" name="searchSortCnd" value="<c:out value="${vEPrcsDetailVO.searchSortCnd}" />" />
<input type="hidden" name="searchSortOrd" value="<c:out value="${vEPrcsDetailVO.searchSortOrd}" />" />
<input type="hidden" id="prcsOrd" name="prcsOrd" value="" />
<input type="hidden" id="prcsAplctPrdOrd" name="prcsAplctPrdOrd" value="" />
<input type="hidden" id="prcsSortNo" name="prcsSortNo" value="" />
<div class="cont_wrap">
<div class="box">
<!-- cont_tit -->
<div class="cont_tit">
<h2>교육확정관리목록</h2>
<ul class="cont_nav">
<li class="home"><a href="/"><i></i></a></li>
<li>
<p>기반강화연수관리</p>
</li>
<li><span class="cur_nav">교육확정관리목록</span></li>
</ul>
</div>
<!-- //cont_tit -->
<div class="cont">
<div class="tb_tit01">
<p>교육 확정 관리</p>
</div>
<!-- list_top -->
<div class="list_top search-only">
<div class="list_top_1">
<div class="util_right">
<ve:select codeId="VEA001" name="searchStatus" id="searchStatus" css="class='sel_type1'"
selectedValue="${vEPrcsDetailVO.searchStatus }" defaultValue=""
defaultText="전체"
/>
<div class="calendar_wrap">
<input type="text" class="calendar" title="시작일 선택" id="searchSmbtStartDt" name="searchSmbtStartDt" value="${vEPrcsDetailVO.searchSmbtStartDt}">
</div>
~
<div class="calendar_wrap">
<input type="text" class="calendar" title="종료일 선택" id="searchSmbtEndDt" name="searchSmbtEndDt" value="${vEPrcsDetailVO.searchSmbtEndDt}">
</div>
<input type="text" id="searchKeyword" name="searchKeyword" placeholder="과정명를 입력하세요." title="검색어 입력" class="search_input" value="<c:out value='${vEPrcsDetailVO.searchKeyword}'/>">
<button type="button" class="btn_type08" onclick="fncGoList(); return false;">검색</button>
<button class="btn_type03" onclick="fncReset(this); return false;">초기화</button>
</div>
</div>
</div>
<div class="list_util">
<p class="list_util_p"><span><c:out value="${paginationInfo.totalRecordCount}" /></span>건의 접수가 검색되었습니다.</p>
<div>
<select class="sel_type1" name="pageUnit" id="pageUnit" onchange="linkPage(1);" title="줄 선택" style="width: 140px" class="sel_type1">
<option value='10' <c:if test="${vEPrcsDetailVO.pageUnit == '10' or vEPrcsDetailVO.pageUnit == ''}">selected</c:if>>10줄</option>
<option value='20' <c:if test="${vEPrcsDetailVO.pageUnit == '20'}">selected</c:if>>20줄</option>
<option value='30' <c:if test="${vEPrcsDetailVO.pageUnit == '30'}">selected</c:if>>30줄</option>
<option value='100' <c:if test="${vEPrcsDetailVO.pageUnit == '100'}">selected</c:if>>100줄</option>
</select>
<%--<button type="button" class="btn_down_excel">엑셀 다운로드</button>--%>
</div>
</div>
<!-- //list_top -->
<!-- list -->
<div class="tb_type01">
<table>
<colgroup>
<col style="width: 5%">
<col style="width: 10%">
<col style="width: auto">
<col style="width: 180px;">
<col style="width: 180px;">
<col style="width: 10%">
<col style="width: 10%">
<%-- <col style="width: 10%"> --%>
</colgroup>
<thead>
<tr>
<th>NO</th>
<th>교육구분코드</th>
<th>과정명</th>
<th>교육기간</th>
<th>신청자/정원</th>
<th>상태</th>
<th>강사배정</th>
<!-- <th>공개여부</th> -->
</tr>
</thead>
<tbody>
<c:forEach var="list" items="${list}" varStatus="status">
<tr class="listCount">
<td onclick="fncGoDetail('<c:out value="${list.prcsAplctPrdOrd}"/>');" style="cursor:pointer;">
<c:out value="${status.count}"/>
</td>
<td>
<kc:code codeId="VEA001" code="${list.prcsDiv}"/>
</td>
<td onclick="fncGoDetail('<c:out value="${list.prcsAplctPrdOrd}"/>');" style="cursor:pointer;">
<c:out value="${list.prcsNm}"/>(<c:out value="${list.prcsAplctPrdOrd}"/>)
</td>
<td>
<c:out value="${list.eduStrtPnttm}"/>~<c:out value="${list.eduDdlnPnttm}"/>
</td>
<td>
<c:out value="${list.nosCnt1}"/>/<c:out value="${list.nos}"/>
</td>
<td class="ddlnCdStts">
<kc:code codeId="VEA004" code="${list.ddlnCd}"/>
</td>
<td>
<%-- <c:out value="${list.strtPnttm}"/>~<c:out value="${list.endPnttm}"/> --%>
<c:choose>
<c:when test="${list.instrCnt ne 0 }">
배정완료
</c:when>
<c:otherwise>
<button type="button" class="btn_type04" onclick="fncGoDetail('<c:out value="${list.prcsAplctPrdOrd}"/>');">강사배정</button>
</c:otherwise>
</c:choose>
</td>
<!-- <td> -->
<%-- <c:out value="${list.useYn}"/> --%>
<!-- </td> -->
</tr>
</c:forEach>
<c:if test="${empty list}">
<tr><td colspan="7"><spring:message code="common.nodata.msg" /></td></tr>
</c:if>
</tbody>
</table>
</div>
<!-- //list -->
<!-- page -->
<div class="page">
<ui:pagination paginationInfo = "${paginationInfo}" type="image" jsFunction="linkPage" />
</div>
<!-- //page -->
</div>
</div>
</div>
<!-- //cont -->
<!-- //cont -->
</form:form>
</body>
</html>

View File

@ -217,7 +217,7 @@
<ul class="cont_nav"> <ul class="cont_nav">
<li class="home"><a href="/"><i></i></a></li> <li class="home"><a href="/"><i></i></a></li>
<li> <li>
<p>조건부기소유예관리</p> <p>기반강화연수관리</p>
</li> </li>
<li><span class="cur_nav">과정신청기간관리 신청기간 상세</span></li> <li><span class="cur_nav">과정신청기간관리 신청기간 상세</span></li>
</ul> </ul>

View File

@ -319,6 +319,8 @@
<button type="button" class="btn_type01" onclick="fncGoRegExcel(); return false;">Excel등록</button> <button type="button" class="btn_type01" onclick="fncGoRegExcel(); return false;">Excel등록</button>
<button type="button" class="btn_type01" onclick="fncGoReg(); return false;">등록</button> <button type="button" class="btn_type01" onclick="fncGoReg(); return false;">등록</button>
--> -->
<button type="button" class="btn_type01" onclick="fncGoList(); return false;">목록</button>
</div> </div>
</div> </div>
</div> </div>

View File

@ -132,6 +132,146 @@
}); });
} }
} }
//강의조사요청관리 팝업
function fncLctrRsrchStng() {
//var p_stngYr = $("#stngYr").val();
/*
if(p_stngYr==''){
alert("회차관리 대상 년도를 선택해주세요.");
return false;
}
*/
//document.listForm.yr.value = p_stngYr;
//document.listForm.authorCode.value = vAuthorCode;
//document.listForm.action = "<c:url value='/kccadr/oprtn/tngrVisitEdu/popup/advRndsStngMngPopup.do'/>";
document.listForm.action = "<c:url value='/kccadr/oprtn/tngrVisitEdu/popup/advLctrRsrchStngMngPopup.do'/>";
window.open("#", "_lctrRsrchPop", "scrollbars = no, top=100px, left=100px, height=800px, width=1000px");
document.listForm.target = "_lctrRsrchPop";
document.listForm.submit();
}
//강의조사요청관리 팝업
function fncLctrRsrchDetailStng(
/*
p_stngYr
, p_stngMnt
, p_stngYrMnt
*/
p_stngYrMnt
) {
//alert(p_stngYrMnt.substring(0,4));
//alert(p_stngYrMnt.substring(4,6));
//return;
document.listForm.stngYr.value = p_stngYrMnt.substring(0,4);
document.listForm.stngMnt.value = p_stngYrMnt.substring(4,6);
document.listForm.stngYrMnt.value = p_stngYrMnt;
//document.listForm.authorCode.value = vAuthorCode;
//document.listForm.action = "<c:url value='/kccadr/oprtn/tngrVisitEdu/popup/advRndsStngMngPopup.do'/>";
document.listForm.action = "<c:url value='/kccadr/oprtn/tngrVisitEdu/popup/advLctrRsrchStngMngPopup.do'/>";
window.open("#", "_lctrRsrchPop", "scrollbars = no, top=100px, left=100px, height=800px, width=1000px");
document.listForm.target = "_lctrRsrchPop";
document.listForm.submit();
}
//강의조사 요청 삭제
function fncLctrRsrchDelete(
p_instrDiv
, p_stngYrMnt
){
//var p_rgstrPsblTm = $(thisObj).closest("td").find("input[name=rgstrPsblTm]").val();
//var p_stngYr = $("#stngYr").val();
//var p_prdDivCd = $("#prdDivCd").val();
//var p_instrDiv = $("input[name=instrDiv]").val();
//var p_areaCd = $(thisObj).closest("tr").find("input[name=checkList]").val();
//alert(p_areaCd);
if(confirm("강의조사 일정을 삭제하시겠습니까?")){
//동일한 값은 업데이트로 수정
$.ajax({
type:"POST",
url: "${pageContext.request.contextPath}/ve/oprtn/instr/tngrVisitEdu/lctrRsrch/lctrRsrchMngDelAjax.do",
data:{
"rsrchInstrDiv" : p_instrDiv,
"stngYrMnt" : p_stngYrMnt,
},
dataType:'json',
//async: false,
//processData: false,
//contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("삭제 되었습니다.");
location.reload();
}else{
alert("삭제 중 오류가 발생하였습니다.");
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
}
//강의조사 마감 처리
function fncLctrRsrchChgState(
p_instrDiv
, p_stngYrMnt
, p_rsrchState
){
//var p_rgstrPsblTm = $(thisObj).closest("td").find("input[name=rgstrPsblTm]").val();
//var p_stngYr = $("#stngYr").val();
//var p_prdDivCd = $("#prdDivCd").val();
//var p_instrDiv = $("input[name=instrDiv]").val();
//var p_areaCd = $(thisObj).closest("tr").find("input[name=checkList]").val();
//if(confirm("강의조사 일정을 삭제하시겠습니까?")){
//동일한 값은 업데이트로 수정
$.ajax({
type:"POST",
url: "${pageContext.request.contextPath}/ve/oprtn/instr/tngrVisitEdu/lctrRsrch/lctrRsrchMngChangeAjax.do",
data:{
"rsrchInstrDiv" : p_instrDiv,
"stngYrMnt" : p_stngYrMnt,
"rsrchState" : p_rsrchState,
},
dataType:'json',
//async: false,
//processData: false,
//contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("처리 되었습니다.");
location.reload();
}else{
alert("처리 중 오류가 발생하였습니다.");
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
//}
}
</script> </script>
<title>강의조사 요청목록</title> <title>강의조사 요청목록</title>
</head> </head>
@ -141,6 +281,8 @@
<input type="hidden" name="searchSortCnd" value="<c:out value="${vEInstrDetailVO.searchSortCnd}" />" /> <input type="hidden" name="searchSortCnd" value="<c:out value="${vEInstrDetailVO.searchSortCnd}" />" />
<input type="hidden" name="searchSortOrd" value="<c:out value="${vEInstrDetailVO.searchSortOrd}" />" /> <input type="hidden" name="searchSortOrd" value="<c:out value="${vEInstrDetailVO.searchSortOrd}" />" />
<input type="hidden" name="rsrchInstrDiv" value="" /> <input type="hidden" name="rsrchInstrDiv" value="" />
<input type="hidden" name="stngYr" value="" />
<input type="hidden" name="stngMnt" value="" />
<input type="hidden" name="stngYrMnt" value="" /> <input type="hidden" name="stngYrMnt" value="" />
@ -162,6 +304,7 @@
<div class="cont"> <div class="cont">
<!-- list_top --> <!-- list_top -->
<!--
<div class="list_top"> <div class="list_top">
<div class="list_top_1"> <div class="list_top_1">
@ -200,6 +343,7 @@
<%-- <input type="text" id=searchKeyword name="searchKeyword" placeholder="검색어를 입력하세요." title="검색어 입력" class="search_input" value="<c:out value='${vEInstrDetailVO.searchKeyword}'/>"> --%> <%-- <input type="text" id=searchKeyword name="searchKeyword" placeholder="검색어를 입력하세요." title="검색어 입력" class="search_input" value="<c:out value='${vEInstrDetailVO.searchKeyword}'/>"> --%>
<button type="button" class="btn_type08" onclick="fncLctrRsrchReg(); return false;">강의조사 요청</button> <button type="button" class="btn_type08" onclick="fncLctrRsrchReg(); return false;">강의조사 요청</button>
<button class="btn_type06" onclick="fncLctrRsrchStng(); return false;" >강의조사요청관리</button>
</div> </div>
</div> </div>
<div class="list_top_2"> <div class="list_top_2">
@ -217,16 +361,35 @@
</div> </div>
</div> </div>
</div> </div>
-->
<!-- //list_top --> <!-- //list_top -->
<div class="btn_wrap btn_layout01">
<div class="btn_left">
</div>
<div class="btn_center">
</div>
<div class="btn_right">
<!--
<button type="button" class="btn_type01" onclick="fncGoRegExcel(); return false;">Excel등록</button>
<button type="button" class="btn_type01" onclick="fncGoReg(); return false;">등록</button>
-->
<!-- <button type="button" class="btn_type01" onclick="fncGoList(); return false;">목록</button> -->
<button class="btn_type06" onclick="fncLctrRsrchStng(); return false;" >강의조사요청관리</button>
</div>
</div>
<br/>
<!-- list --> <!-- list -->
<div class="tb_type01"> <div class="tb_type01">
<table> <table>
<colgroup> <colgroup>
<col style="width: 20%"> <col style="width: 15%">
<col style="width: 20%"> <col style="width: 15%">
<col style="width: 20%"> <col style="width: 15%">
<col style="width: 20%"> <col style="width: 15%">
<col style="width: 15%">
<col style="width: auto"> <col style="width: auto">
</colgroup> </colgroup>
@ -237,23 +400,28 @@
<th>조사마감일</th> <th>조사마감일</th>
<th>참여현황</th> <th>참여현황</th>
<th>마감여부</th> <th>마감여부</th>
<th>관리</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
<c:forEach var="list" items="${list}" varStatus="status"> <c:forEach var="list" items="${list}" varStatus="status">
<tr onclick="fncGoDetail('<c:out value="${list.rsrchInstrDiv}"/>', '<c:out value="${list.stngYrMnt}"/>');" style="cursor:pointer;"> <%-- <tr onclick="fncGoDetail('<c:out value="${list.rsrchInstrDiv}"/>', '<c:out value="${list.stngYrMnt}"/>');" style="cursor:pointer;"> --%>
<tr>
<td> <td>
<fmt:parseDate value="${list.stngYrMnt}" var="stngYrMnt" pattern="yyyyMM"/> ${list.stngYrMnt}
<fmt:formatDate value="${stngYrMnt}" pattern="yyyy.MM"/> <%-- <fmt:parseDate value="${list.stngYrMnt}" var="stngYrMnt" pattern="yyyyMM"/> --%>
<%-- <fmt:formatDate value="${stngYrMnt}" pattern="yyyy.MM"/> --%>
</td> </td>
<td> <td>
<fmt:parseDate value="${list.rsrchStrtDt}" var="rsrchStrtDt" pattern="yyyyMMdd"/> ${list.rsrchStrtDt}
<fmt:formatDate value="${rsrchStrtDt}" pattern="yyyy.MM.dd"/> <%-- <fmt:parseDate value="${list.rsrchStrtDt}" var="rsrchStrtDt" pattern="yyyyMMdd"/> --%>
<%-- <fmt:formatDate value="${rsrchStrtDt}" pattern="yyyy.MM.dd"/> --%>
</td> </td>
<td> <td>
<fmt:parseDate value="${list.rsrchEndDt}" var="rsrchEndDt" pattern="yyyyMMdd"/> ${list.rsrchEndDt}
<fmt:formatDate value="${rsrchEndDt}" pattern="yyyy.MM.dd"/> <%-- <fmt:parseDate value="${list.rsrchEndDt}" var="rsrchEndDt" pattern="yyyyMMdd"/> --%>
<%-- <fmt:formatDate value="${rsrchEndDt}" pattern="yyyy.MM.dd"/> --%>
</td> </td>
<td> <td>
@ -263,10 +431,29 @@
<td> <td>
<ve:code codeId="VE0034" code="${list.rsrchState }"/> <ve:code codeId="VE0034" code="${list.rsrchState }"/>
</td> </td>
<td>
<%-- <ve:code codeId="VE0034" code="${list.rsrchState }"/> --%>
<button class="btn_type06" onclick="fncGoDetail('<c:out value="${list.rsrchInstrDiv}"/>', '<c:out value="${list.stngYrMnt}"/>'); return false;" >상세</button>
<button class="btn_type06" onclick="fncLctrRsrchChgState('<c:out value="${list.rsrchInstrDiv}"/>', '<c:out value="${list.stngYrMnt}"/>', '<c:out value="${list.rsrchState}"/>'); return false;" >
<c:if test="${list.rsrchState eq '03'}">
마감해제
</c:if>
<c:if test="${list.rsrchState ne '03'}">
마감
</c:if>
</button>
<button class="btn_type06" onclick="fncLctrRsrchDetailStng('<c:out value="${list.stngYrMnt}"/>'); return false;" >수정</button>
<c:if test="${list.lctrStngOrdSbmt eq '0'}">
<button class="btn_type06" onclick="fncLctrRsrchDelete('<c:out value="${list.rsrchInstrDiv}"/>', '<c:out value="${list.stngYrMnt}"/>'); return false;" >삭제</button>
</c:if>
</td>
</tr> </tr>
</c:forEach> </c:forEach>
<c:if test="${empty list}"> <c:if test="${empty list}">
<tr><td colspan="5"><spring:message code="common.nodata.msg" /></td></tr> <tr><td colspan="6"><spring:message code="common.nodata.msg" /></td></tr>
</c:if> </c:if>
</tbody> </tbody>
</table> </table>

View File

@ -0,0 +1,548 @@
<!DOCTYPE html>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="ui" uri="http://egovframework.gov/ctl/ui"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<%@ taglib prefix="validator" uri="http://www.springmodules.org/tags/commons-validator" %>
<%@ taglib prefix="kc" uri="/WEB-INF/tlds/kcc_tld.tld"%>
<%
/**
* @Class Name : advLctrRsrchStngMngPopup.jsp
* @Description : 강의조사관리 팝업
* @Modification Information
* @
* @ 수정일 수정자 수정내용
* @ ------- -------- ---------------------------
* @ 2021.08.09 김봉호 최초 생성
* @author 김봉호
* @since 2021.08.21
* @version 1.0
* @see
*
*/
%>
<html lang="ko">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<link rel="stylesheet" href="${pageContext.request.contextPath}/visitEdu/adm/publish/datepicker/classic.css">
<link rel="stylesheet" href="${pageContext.request.contextPath}/visitEdu/adm/publish/datepicker/classic.date.css">
<script src="${pageContext.request.contextPath}/visitEdu/adm/publish/datepicker/picker.js"></script>
<script src="${pageContext.request.contextPath}/visitEdu/adm/publish/datepicker/picker.date.js"></script>
<script src="${pageContext.request.contextPath}/visitEdu/adm/publish/datepicker/legacy.js"></script>
<script src="${pageContext.request.contextPath}/visitEdu/adm/publish/datepicker/ko_KR.js"></script>
<script type="text/javascript">
</script>
<title>신청반려팝업</title>
<script type="text/javaScript" language="javascript">
$(document).ready(function(){
var mode = '${adjReqMgrVO.mode}';
if(mode == "D"){
$("input[type=checkbox],textarea").not("textarea[name=rejtReson]").attr("disabled" , true);
}
});
function fncAprooval(){
var msg = "강의가능시간 변경";
var data1 = new FormData(document.getElementById("createForm"));
//console.log(data);
console.log(data1);
if (confirm(msg+" 하시겠습니까?")) {
$.ajax({
type: "POST",
url: "${pageContext.request.contextPath}/kccadr/oprtn/tngrVisitEdu/popup/areaLctrMngLctrPsblTmPopupAjax.do",
//data: JSON.stringify(data),
data: data1,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success: function (returnData, status) {
console.log(returnData.rs);
if(returnData.result == 'success'){
alert("정상적으로 "+ msg +" 되었습니다.");
opener.location.reload();
self.close();
}else{
alert(returnData.message);
}
},
error: function (e) { alert("저장에 실패하였습니다."); console.log("ERROR : ", e); }
});
}
}
function validationForm(data){
/*
var len = $("input[type='checkbox']:checked").length;
if (len <= 0) {
alert("보완요청항목을 선택해주세요.");
return false;
}
*/
if ($("[name='aprvlCn']").val() == '') {
alert("사유를 입력해주세요.");
return false;
}
/*
if ($("[name='adrSeq']").val() == '') {
alert("신청번호가 없습니다. 관리자에게 문의해주세요.");
return false;
}
*/
return true;
}
function fncGoEdit(){
var createForm = document.createForm ;
createForm.mode.value = "C";
createForm.action = "<c:url value='/kccadr/adjReqMgr/popup/adjReqMgrRegSecurityPopup.do'/>";
createForm.submit();
}
function fncStatusUpdate(confirmYn){
var msg = "승인";
var data = {};
data.adrSeq = '${security.adrSeq}';
data.edtSn = '${security.edtSn}';
data.apprYn = 'Y';
data.rejtReson = $("#rejtReson").val();
//data.statCd = '010100'; // 작성중 상태로 변경
if(confirmYn == "N"){
data.apprYn = 'N'; // 미승인 상태
msg = "반려";
}
if (confirm(msg+" 하시겠습니까?")) {
$.ajax({
type: "POST",
url: "/kccadr/adjReqMgr/popup/adjReqMgrRegSecurityStatusChange.do",
data: JSON.stringify(data),
dataType:'json',
async: false,
processData: false,
contentType: "application/json",
cache: false,
success: function (returnData, status) {
console.log(returnData.rs);
if(returnData.result == 'SUCCESS'){
alert("정상적으로 "+ msg +" 되었습니다.");
opener.location.reload();
self.close();
}else{
alert(returnData.message);
}
},
error: function (e) { alert("저장에 실패하였습니다."); console.log("ERROR : ", e); }
});
}
}
function fncPopClose(){
self.close();
}
//회차관리 변경
function fncRndsSave(thisObj){
//alert($("#ord_1").val());
//alert($(thisObj).closest("td"));
//alert($(thisObj).closest("td").find("input[name=ord_1]").length);
var p_ord = $(thisObj).closest("td").find("input[name=ord_1]").val();
var p_rgstrStrtPnttm_dt = $(thisObj).closest("td").find("input[name=rgstrStrtPnttm_dt]").val();
var p_rgstrStrtPnttm_tm = $(thisObj).closest("td").find("input[name=rgstrStrtPnttm_tm]").val();
var p_rgstrDdlnPnttm_dt = $(thisObj).closest("td").find("input[name=rgstrDdlnPnttm_dt]").val();
var p_rgstrDdlnPnttm_tm = $(thisObj).closest("td").find("input[name=rgstrDdlnPnttm_tm]").val();
var p_yr = $("#yr").val();
var p_ord = $("#ord").val();
var p_rgstrStrtPnttm_dt = $("#rgstrStrtPnttm_dt").val();
var p_rgstrStrtPnttm_tm = $("#rgstrStrtPnttm_tm").val();
var p_rgstrDdlnPnttm_dt = $("#rgstrDdlnPnttm_dt").val();
var p_rgstrDdlnPnttm_tm = $("#rgstrDdlnPnttm_tm").val();
//alert(p_areaCd);
//if(p_psblTmQntty != "") {
if(true) {
$.ajax({
type:"POST",
url:"${pageContext.request.contextPath}/kccadr/oprtn/tngrVisitEdu/popup/advRndsSaveAjax.do",
data:{
"yr" : p_yr,
"ord" : p_ord,
"rgstrStrtPnttm" : p_rgstrStrtPnttm_dt+p_rgstrStrtPnttm_tm,
"rgstrDdlnPnttm" : p_rgstrDdlnPnttm_dt+p_rgstrDdlnPnttm_tm,
},
dataType:'json',
success:function(returnData){
if(returnData.result == "success"){
alert("변경 처리 되었습니다.");
fncGoList();
}else{
alert("변경 중 오류가 발생하였습니다.");
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}else{
alert("교육가능시수를 입력해주세요.");
}
}
function fncGoList(){
linkPage(1);
}
function linkPage(pageNo){
var listForm = document.createForm ;
listForm.stngYr.value = $('#p_stngYr').val();
listForm.stngMnt.value = $('#p_stngMnt').val();
listForm.stngYrMnt.value = $('#p_stngYr').val()+$('#p_stngMnt').val();
//listForm.searchCondition.value = $('#searchCondition').val();
//listForm.searchKeyword.value = $('#searchKeyword').val();
listForm.action = "<c:url value='/kccadr/oprtn/tngrVisitEdu/popup/advLctrRsrchStngMngPopup.do'/>";
listForm.submit();
}
//회차관리 변경
function fncRndsUpdate(p_rndsOrd){
//alert($("#ord_1").val());
//alert($(thisObj).closest("td"));
//alert($(thisObj).closest("td").find("input[name=ord_1]").length);
//var p_ord = $(thisObj).closest("td").find("input[name=ord_1]").val();
//$("#${list.rndsOrd}"+" #lctrPsblStrtTm").val('${list.dpStrtTm}');
var p_rgstrStrtPnttm_dt = $("#"+p_rndsOrd+" #aplctPrdStrt").val();
var p_rgstrStrtPnttm_tm = $("#"+p_rndsOrd+" #lctrPsblStrtTm").val();
var p_rgstrDdlnPnttm_dt = $("#"+p_rndsOrd+" #aplctPrdEnd").val();
var p_rgstrDdlnPnttm_tm = $("#"+p_rndsOrd+" #lctrPsblEndTm").val();
var p_ord = $("#"+p_rndsOrd+" #psblTmQntty").val();
//alert(p_areaCd);
//if(p_psblTmQntty != "") {
if(true) {
$.ajax({
type:"POST",
url:"${pageContext.request.contextPath}/kccadr/oprtn/tngrVisitEdu/popup/advRndsUpdateAjax.do",
data:{
"rndsOrd" : p_rndsOrd,
//"yr" : p_yr,
"ord" : p_ord,
"rgstrStrtPnttm" : p_rgstrStrtPnttm_dt+p_rgstrStrtPnttm_tm,
"rgstrDdlnPnttm" : p_rgstrDdlnPnttm_dt+p_rgstrDdlnPnttm_tm,
},
dataType:'json',
success:function(returnData){
if(returnData.result == "success"){
alert("변경 처리 되었습니다.");
fncGoList();
}else{
alert("변경 중 오류가 발생하였습니다.");
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}else{
alert("교육가능시수를 입력해주세요.");
}
}
//회차관리 삭제
function fncRndsDelete(p_rndsOrd){
//if(p_psblTmQntty != "") {
if(true) {
$.ajax({
type:"POST",
url:"${pageContext.request.contextPath}/kccadr/oprtn/tngrVisitEdu/popup/advRndsDeleteAjax.do",
data:{
"rndsOrd" : p_rndsOrd,
},
dataType:'json',
success:function(returnData){
if(returnData.result == "success"){
alert("삭제 처리 되었습니다.");
fncGoList();
}else{
alert("삭제 중 오류가 발생하였습니다.");
fncGoList();
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}else{
alert("교육가능시수를 입력해주세요.");
}
}
//교육설정 등록여부 체크
function fncLctrRsrchReg(){
if(createForm.rsrchStrtDt.value > createForm.rsrchEndDt.value){
alert("시작일은 종료일보다 작아야합니다.");
return;
}
if(createForm.rsrchStrtDt.value ==""){
alert("조사시작일을 넣어주세요");
return;
}
if(createForm.rsrchEndDt.value ==""){
alert("조사마감일을 넣어주세요");
return;
}
//var p_rgstrPsblTm = $(thisObj).closest("td").find("input[name=rgstrPsblTm]").val();
//var p_stngYr = $("#stngYr").val();
//var p_prdDivCd = $("#prdDivCd").val();
//var p_instrDiv = $("input[name=instrDiv]").val();
//var p_areaCd = $(thisObj).closest("tr").find("input[name=checkList]").val();
//alert(p_areaCd);
if(confirm("강의조사 일정을 등록하시겠습니까?")){
//동일한 값은 업데이트로 수정
$.ajax({
type:"POST",
url: "${pageContext.request.contextPath}/ve/oprtn/instr/tngrVisitEdu/lctrRsrch/lctrRsrchMngRegAjax.do",
data:{
"rsrchInstrDiv" : "10",
"stngYrMnt" : $("select[name=p_stngYr]").val()+$("select[name=p_stngMnt]").val(),
"rsrchStrtDt" : $("input[name=rsrchStrtDt]").val(),
"rsrchEndDt" : $("input[name=rsrchEndDt]").val(),
},
dataType:'json',
//async: false,
//processData: false,
//contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
alert("등록 되었습니다.");
location.reload();
top.window.opener.location.reload();
}else if(returnData.result == "already"){
alert("중복되는 날짜가 등록 되어있습니다.");
//location.reload();
}else{
alert("등록 중 오류가 발생하였습니다.");
}
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
}
}
</script>
</head>
<body>
<!-- 팝업을 위한 mask -->
<div class="mask2" onclick="timeLayerUtil()"></div>
<div class="area_popup">
<!-- cont_tit -->
<div class="cont_tit">
<h2>강의조사요청관리</h2>
</div>
<!-- //cont_tit -->
<div class="cont_popup">
<form:form id="createForm" name="createForm" method="post" commandName="vELctrDetailVO" onsubmit="return false;">
<input type="hidden" name="instrDiv" id="instrDiv" value="<c:out value="${vELctrDetailVO.instrDiv}" />">
<input type="hidden" name="areaCd" id="areaCd" value="<c:out value="${vELctrDetailVO.areaCd}" />">
<input type="hidden" name="stngYr" id="stngYr" value="<c:out value="${vELctrDetailVO.stngYr}" />">
<input type="hidden" name="stngMnt" id="stngMnt" value="<c:out value="${vELctrDetailVO.stngMnt}" />">
<input type="hidden" name="stngYrMnt" id="stngYrMnt" value="<c:out value="${vELctrDetailVO.stngYrMnt}" />">
<input type="hidden" name="prdDivCd" id="prdDivCd" value="<c:out value="${vELctrDetailVO.prdDivCd}" />">
<table class="pop_tb_type02">
<colgroup>
<col style="width: 140px;">
<col style="width: auto;">
</colgroup>
<tbody>
<tr>
<th scope="row" colspan="2">
<p class="req_text"><span>필수입력 항목</span></p>
<p>
<select class="sel_type1" name="p_stngYr" id="p_stngYr" title="줄 선택" style="width: 140px">
<c:forEach var="list" items="${selectStngYrList}" varStatus="status">
<c:if test="${list.useYn eq '1'}">
<option value='${list.stngYr}' selected>${list.stngYr*1}년</option>
</c:if>
<c:if test="${list.useYn ne '1'}">
<option value='${list.stngYr}'>${list.stngYr*1}년</option>
</c:if>
</c:forEach>
</select>
<select class="sel_type1" name="p_stngMnt" id="p_stngMnt" title="줄 선택" style="width: 140px">
<c:forEach var="list" items="${selectStngMntList}" varStatus="status">
${list.useYn}
<c:if test="${list.useYn eq '1'}">
<option value='${list.stngMnt}' selected>${list.stngMnt}월</option>
</c:if>
<c:if test="${list.useYn ne '1'}">
<option value='${list.stngMnt}'>${list.stngMnt}월</option>
</c:if>
</c:forEach>
</select>
<button class="btn_type08" onclick="fncGoList(); return false;" style="width: 140px;height:30px;">검색</button>
</p>
</th>
<!--
<td>
<div class="util_right">
&nbsp;&nbsp;&nbsp;년도&nbsp;&nbsp;
<kc:select codeId="VE0029" name="yr" id="yr" css="class='sel_type1'"
selectedValue="${vEAStngVO.yr}"
/>
<button class="btn_type08" onclick="fncGoList(); return false;">검색</button>
</div>
</td>
-->
</tr>
</tbody>
</table>
<c:if test="${vELctrDetailVO.stngYrMnt ne ''}">
<script>
$("#p_stngYr").val('${vELctrDetailVO.stngYr}');
$("#p_stngMnt").val('${vELctrDetailVO.stngMnt}');
</script>
<table class="pop_tb_type02">
<colgroup>
<col style="width: 21%;">
<col style="width: 33%;">
<col style="width: 33%;">
<col style="width: 15%;">
</colgroup>
<tbody>
<tr>
<th scope="row"></th>
<th scope="row">조사시작일</th>
<th scope="row">조사마감일</th>
<th scope="row">관리</th>
</tr>
</tbody>
<tbody>
<tr>
<!-- 회차 -->
<td>
<div class="util_right">
<c:out value="${vELctrDetailVO.stngYr}" />년
<c:out value="${vELctrDetailVO.stngMnt}" />월
</div>
</td>
<td>
<div class="util_right">
<div class="calendar_wrap">
<input type="text" class="calendar" title="시작일 선택" id="rsrchStrtDt"
name="rsrchStrtDt" value="<c:out value="${selectVELctrDetailVO.rsrchStrtDt}" />">
</div>
</div>
</td>
<td>
<div class="util_right">
<div class="calendar_wrap">
<input type="text" class="calendar" title="종료일 선택" id="rsrchEndDt"
name="rsrchEndDt" value="<c:out value="${selectVELctrDetailVO.rsrchEndDt}" />">
</div>
</div>
</td>
<td>
<div class="btn_wrap_pop btn_layout01" style="margin-top:10px;margin-bottom:10px;">
<div class="btn_center" style="width: 100%;">
<button class="btn_type04" onclick="fncLctrRsrchReg(this); return false;">저장</button>
</div>
</div>
</td>
</tr>
</tbody>
</table>
</c:if>
</form:form>
<div class="btn_wrap_pop btn_layout01">
<div class="btn_left">
</div>
<div class="btn_center" style="width: 100%;">
<!-- <button type="button" class="btn_type04" onclick="fncAprooval(); return false;">확인</button> -->
<button type="button" class="btn_type02" onclick="window.close()">취소</button>
</div>
<div class="btn_right">
</div>
</div>
</div>
</div>
</body>
</html>

View File

@ -9,8 +9,8 @@
<%@ taglib prefix="kc" uri="/WEB-INF/tlds/kcc_tld.tld"%> <%@ taglib prefix="kc" uri="/WEB-INF/tlds/kcc_tld.tld"%>
<% <%
/** /**
* @Class Name : advRndsStngMngPopup.jsp * @Class Name : advLctrRsrchStngMngPopup.jsp
* @Description : 강의회차관리 팝업 * @Description : 강의조사관리 팝업
* @Modification Information * @Modification Information
* @ * @
* @ 수정일 수정자 수정내용 * @ 수정일 수정자 수정내용

View File

@ -129,33 +129,25 @@
</td> </td>
<td> <td>
<c:choose> <c:choose>
<c:when test="${list.aprvlCd eq VeConstants.STATUS_CD_SBMT}"> <c:when test="${list.aprvlCd eq VeConstants.APRVL_CD_10}">
<span class="app_status1">운영신청</span> <span class="app_status1">운영신청</span>
</c:when> </c:when>
<c:when test="${list.aprvlCd eq VeConstants.STATUS_CD_CFRM}"> <c:when test="${list.aprvlCd eq VeConstants.APRVL_CD_70}">
<span class="app_status2">운영승인</span>
</c:when>
<c:when test="${list.aprvlCd eq VeConstants.STATUS_CD_RJT}">
<span class="app_status4">운영반려</span>
</c:when>
<c:when test="${list.aprvlCd eq VeConstants.STATUS_CD_CAN}">
<span class="app_status4">운영취소</span>
</c:when>
<c:when test="${list.aprvlCd eq VeConstants.STATUS_CD_CHI_CMPT}">
<span class="app_status4">선정완료</span>
</c:when>
<c:when test="${list.aprvlCd eq VeConstants.STATUS_CD_EDT_REQ}">
<span class="app_status3">수정요청</span> <span class="app_status3">수정요청</span>
</c:when> </c:when>
<c:when test="${list.aprvlCd eq VeConstants.STATUS_CD_EDT_CMPT}"> <c:when test="${list.aprvlCd eq VeConstants.APRVL_CD_80}">
<span class="app_status3">수정요청완료</span> <span class="app_status3">수정완료</span>
</c:when> </c:when>
<c:when test="${list.aprvlCd eq VeConstants.STATUS_CD_EDU_SELCT}"> <c:when test="${list.aprvlCd eq VeConstants.APRVL_CD_60}">
<span class="app_status1">운영확정</span> <span class="app_status1">운영확정</span>
</c:when> </c:when>
<c:when test="${list.aprvlCd eq VeConstants.APRVL_CD_90}">
<span class="app_status1">운영미확정</span>
</c:when>
<c:otherwise> <c:otherwise>
- -
</c:otherwise> </c:otherwise>
</c:choose> </c:choose>
</td> </td>
</tr> </tr>

View File

@ -69,7 +69,7 @@ $(document).ready(function(){
var data = new FormData(document.getElementById("regForm")); var data = new FormData(document.getElementById("regForm"));
if(confirm("신청하시겠습니까?")){ if(confirm("신청하시겠습니까?")){
var url = "${pageContext.request.contextPath}/web/ve/aplct/sspnIdtmt/eduRegAjax.do"; var url = "${pageContext.request.contextPath}/web/ve/aplct/fndtnEnhanceTrn/eduRegAjax.do";
console.log(data); console.log(data);
$.ajax({ $.ajax({
type:"POST", type:"POST",

View File

@ -67,9 +67,12 @@ $(document).ready(function(){
}); });
function fncEduReg(prcsAplctPrdOrd){ // 대상자 이름, 생년월일, 대상자TB ID
var regForm = document.regForm; function fncEduReg(trgtNm, dBirth, sspnIdtmtTrgtOrd){
regForm.prcsAplctPrdOrd.value = prcsAplctPrdOrd; var form = document.regForm;
form.trgtNm.value = trgtNm;
form.dBirth.value = dBirth;
form.sspnIdtmtTrgtOrd.value = sspnIdtmtTrgtOrd;
var data = new FormData(document.getElementById("regForm")); var data = new FormData(document.getElementById("regForm"));
if(confirm("신청하시겠습니까?")){ if(confirm("신청하시겠습니까?")){
@ -85,9 +88,11 @@ $(document).ready(function(){
contentType: false, contentType: false,
cache: false, cache: false,
success:function(returnData){ success:function(returnData){
if(returnData.result == "success"){ if(returnData.result == "success"){
alert("저장되었습니다."); alert("저장되었습니다.");
fncGoList(); fncGoList();
}else{
alert("교육 신청에 실패하였습니다.\n담당자에게 문의해 주세요.");
} }
}, },
error:function(request , status, error){ error:function(request , status, error){
@ -124,16 +129,61 @@ $(document).ready(function(){
}); });
} }
function fn_eduInquiry(){
commonPopLayeropen( function fn_confirm(){
"${pageContext.request.contextPath}/web/ve/comm/popup/eduInquiryPopup.do"
, 470
, 464 var form = document.confirmForm;
// , data var dBirth = $('#dBirth').val().replace(/\./g, '');
, "" var trgtNm = $('#trgtNm').val();
, "Y"
, "eduInquiryPopup"
); form.trgtNm.value = trgtNm;
form.dBirth.value = dBirth;
var data = new FormData(document.getElementById("confirmForm"));
var url = "${pageContext.request.contextPath}/web/ve/aplct/sspnIdtmt/userConfirmAjax.do";
$.ajax({
type:"POST",
url: url,
data: data,
dataType:'json',
async: false,
processData: false,
contentType: false,
cache: false,
success:function(returnData){
if(returnData.result == "success"){
// 대상자 테이블 pk 값
var sspnIdtmtTrgtOrd = returnData.id;
if(sspnIdtmtTrgtOrd != ''){
alert("확인되었습니다.");
// 교육 신청 ajax
// 대상자 이름, 생년월일, 대상자TB ID
fncEduReg(trgtNm, dBirth, sspnIdtmtTrgtOrd);
} else {
alert("대상자에 없습니다.");
}
}
fn_target_confirm_clean();
},
error:function(request , status, error){
alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error);
}
});
$('#target_confirm_popup-close').click();
}
function fn_target_confirm_clean(){
$('#trgtNm').val('');
$('#dBirth').val('');
} }
</script> </script>
@ -141,8 +191,15 @@ $(document).ready(function(){
<!-- content --> <!-- content -->
<div class="cont_wrap" id="sub"> <div class="cont_wrap" id="sub">
<form name="confirmForm" id="confirmForm">
<input type="hidden" name="trgtNm">
<input type="hidden" name="dBirth">
</form>
<form name="regForm" id="regForm"> <form name="regForm" id="regForm">
<input type="hidden" name="prcsAplctPrdOrd"> <input type="hidden" name="prcsAplctPrdOrd">
<input type="hidden" name="sspnIdtmtTrgtOrd"> <!-- 대상자 테이블 PK -->
<input type="hidden" name="trgtNm">
<input type="hidden" name="dBirth">
</form> </form>
<form name="viewForm" id="viewForm"> <form name="viewForm" id="viewForm">
<input type="hidden" name="prcsAplctPrdOrd"> <input type="hidden" name="prcsAplctPrdOrd">
@ -248,7 +305,7 @@ $(document).ready(function(){
</td> </td>
<td class="aplctBtn"> <td class="aplctBtn">
<%-- <button type="button" class="btnType04" onclick="fncEduReg('<c:out value="${list.prcsAplctPrdOrd}"/>');">신청</button> --%> <%-- <button type="button" class="btnType04" onclick="fncEduReg('<c:out value="${list.prcsAplctPrdOrd}"/>');">신청</button> --%>
<button type="button" class="btnType04" data-info="<c:out value="${list.prcsAplctPrdOrd}"/>" data-tooltip="reg_search" >신청</button> <button type="button" class="btnType04" data-info="<c:out value="${list.prcsAplctPrdOrd}"/>" data-tooltip="target_confirm_popup" >신청</button>
</td> </td>
</tr> </tr>
</c:forEach> </c:forEach>
@ -278,23 +335,49 @@ $(document).ready(function(){
<!-- 신청 클릭 > 기소유예 대상자 확인 팝업 --> <!-- 신청 클릭 > 기소유예 대상자 확인 팝업 -->
<!-- 교육대상자 확인 -->
<div class="tooltip-wrap"> <div class="tooltip-wrap">
<div class="popup_wrap popType01" tabindex="0" data-tooltip-con="reg_search" data-focus="reg_search" <div class="popup_wrap popType01" tabindex="0" data-tooltip-con="target_confirm_popup" data-focus="target_confirm_popup" data-focus-prev="target_confirm_popup_close">
data-focus-prev="reg_search_close">
<div class="popup_tit"> <div class="popup_tit">
<p>교육대상자 확인</p> <button class="btn_popup_close tooltip-close" data-focus="reg_search_close" <p>교육대상자 확인</p>
title="팝업 닫기"><i></i></button> <button class="btn_popup_close tooltip-close" data-focus="target_confirm_popup_close" title="팝업 닫기"><i></i></button>
</div> </div>
<div class="popup_cont"> <div class="popup_cont">
<p class="text_greeting">안녕하세요.</br>한국저작권위원회입니다.</p> <div class="cont_body">
<div class="popup_texta"><textarea placeholder="문의내용을 입력해 주세요."></textarea></div> <div class="pop_tb_type01" style="overflow:visible;">
<div class="pop_btn_wrap btn_layout01"> <table>
<div class="btn_left"> <colgroup>
<col style="width:38%;">
<col style="width:auto;">
</colgroup>
<tr>
<th>성명</th>
<td>
<input type="text" id="trgtNm">
</td>
</tr>
<tr>
<th>주민번호앞자리</th>
<td>
<div class="calendar_wrap">
<duet-date-picker identifier="date" id="dBirth" class="startDate" id="" min="1940-01-01"></duet-date-picker>
</div>
<script src="${pageContext.request.contextPath}/visitEdu/usr/publish/script/duetdatepicker2.js"></script>
</td>
</tr>
</table>
</div> </div>
<div class="btn_center"> <div class="pop_btn_wrap btn_layout01">
<button type="button" class="btnType05">문의하기</button> <div class="btn_left">
</div> </div>
<div class="btn_right"> <div class="btn_center">
<button type="button" class="btnType05" onclick="fn_confirm()">제출</button>
<button type="button" class="btnType02 tooltip-close" id="target_confirm_popup-close" data-focus="target_confirm_popup-close" data-focus-next="target_confirm_popup">취소</button>
</div>
<div class="btn_right">
</div>
</div> </div>
</div> </div>
</div> </div>

View File

@ -15,7 +15,9 @@
// 운영라이선스 적용 // 운영라이선스 적용
//var INNORIX_LICENSE = "FXA8KvVU99M9Ubbr3Yrz91zCNqyXdWCqUQ/OO1f7lj3nifVZZjuLqJIlHXjosrbPynCFJat5fwEgP/RVXftvXSsXmAHSnTVLYciyf8XmbxH8SLfUdCIEnFo+zL8="; //var INNORIX_LICENSE = "FXA8KvVU99M9Ubbr3Yrz91zCNqyXdWCqUQ/OO1f7lj3nifVZZjuLqJIlHXjosrbPynCFJat5fwEgP/RVXftvXSsXmAHSnTVLYciyf8XmbxH8SLfUdCIEnFo+zL8=";
// 개발 라이센스 적용 (만료 23.09.30) // 개발 라이센스 적용 (만료 23.09.30)
var INNORIX_LICENSE = "SdFY8+dBdt8IY1M4l8fQkBVO1kBmeR6G5LjSUlLcHuYKCGoA14dIM9d5x6nedAJC2YhgbYjAEsedB+RXglSXElTeOto="; //var INNORIX_LICENSE = "SdFY8+dBdt8IY1M4l8fQkBVO1kBmeR6G5LjSUlLcHuYKCGoA14dIM9d5x6nedAJC2YhgbYjAEsedB+RXglSXElTeOto=";
// 개발 라이센스 적용 (만료 23.12.31)
var INNORIX_LICENSE = "DMhUDOx/+RoGojh0ECXphlfh5DGpLolyCxk7xMuNCAeJ0nqF8SQtKjJdL0jvHs4dgrMIaHrcSeNY+U28a3WFA5No4Pc=";
var INNORIX_VERSION = '1.1.3.458'; var INNORIX_VERSION = '1.1.3.458';
var INNORIX_WIN_VERSION = '1.1.3.458'; var INNORIX_WIN_VERSION = '1.1.3.458';