묻고답하기

_search.html에서는 

<input type="hidden" id="reg_search_target" name="search_target" value="extra_vars2"/>
<input type="hidden" id="reg_search_keyword" name="search_keyword" value=""/>

<input type="hidden" id="e1_search_target" name="search_targetA" value="extra_vars9"/>
<input type="hidden" id="ot_search_target" name="search_targetB" value="extra_vars10"/>
<input type="hidden" id="e2_search_target" name="search_targetC" value="extra_vars11"/>
<input type="hidden" id="e1_search_keyword" name="search_keywordA" value=""/>                                    
<input type="hidden" id="ot_search_keyword" name="search_keywordB" value=""/>                                    
<input type="hidden" id="e2_search_keyword" name="search_keywordC" value=""/>

 

이런식으로 Get파라미터를 추가해주었고

 

document.model.php의 _setSearchOption()에서는

if(strpos($search_target,'extra_vars')!==false) {
    $args->var_idx = substr($search_target, strlen('extra_vars'));
    $args->var_value = str_replace(' ','%',$search_keyword);
    $args->sort_index = 'documents.'.$args->sort_index;
    $query_id = 'document.getDocumentListWithExtraVarsMulti';
                            
    $args->var_idxA=$args->var_idx;    $args->var_valueA=$args->var_value;
    $args->var_idxB=$args->var_idx;    $args->var_valueB=$args->var_value;
    $args->var_idxC=$args->var_idx;    $args->var_valueC=$args->var_value;
    
    $Context_GetVars = Context::getRequestVars();
    $Context_GetVars = json_decode(json_encode($Context_GetVars), true);
    $search_keywordA="";    $search_keywordB="";    $search_keywordC="";
    //var_dump($Context_GetVars["search_keywordA"]);
    if(isset($Context_GetVars["search_keyworda"]))        $search_keywordA=$Context_GetVars["search_keyworda"];
    if(isset($Context_GetVars["search_keywordb"]))        $search_keywordB=$Context_GetVars["search_keywordb"];
    if(isset($Context_GetVars["search_keywordc"]))        $search_keywordC=$Context_GetVars["search_keywordc"];
    
    if(!empty(trim($search_keywordA)))
    {
        $args->var_idxA = substr($Context_GetVars["search_targeta"], strlen('extra_vars'));
        $args->var_valueA = str_replace(' ','%',' '.$search_keywordA.' ');
    }

    if(!empty(trim($search_keywordB)))
    {
        $args->var_idxB = substr($Context_GetVars["search_targetb"], strlen('extra_vars'));
        $args->var_valueB = str_replace(' ','%',' '.$search_keywordB.' ');
    }

    if(!empty(trim($search_keywordC)))
    {
        $args->var_idxC = substr($Context_GetVars["search_targetc"], strlen('extra_vars'));
        $args->var_valueC = str_replace(' ','%',' '.$search_keywordC.' ');
    }
}

이런식으로 변경을 해주었습니다.

마지막으로 getDocumentListWithExtraVarsMulti.xml을 추가하여 아래와 같이 설정해주었습니다.

<query id="getDocumentListWithExtraVarsMulti" action="select">
    <tables>
        <table name="documents" />
        <table name="document_extra_vars" alias="extra_vars"  type="left join">
            <conditions>
                <condition operation="equal" column="extra_vars.document_srl" default="documents.document_srl" pipe="and" />
            </conditions>
        </table>
        <table name="document_extra_vars" alias="extra_varsA"  type="left join">
            <conditions>
                <condition operation="equal" column="extra_varsA.document_srl" default="extra_vars.document_srl" pipe="and" />
            </conditions>
        </table>        
        <table name="document_extra_vars" alias="extra_varsB"  type="left join">
            <conditions>
                <condition operation="equal" column="extra_varsB.document_srl" default="extra_varsA.document_srl" pipe="and" />
            </conditions>
        </table>
        <table name="document_extra_vars" alias="extra_varsC"  type="left join">
            <conditions>
                <condition operation="equal" column="extra_varsC.document_srl" default="extra_varsB.document_srl" pipe="and" />
            </conditions>
        </table>
    </tables>
    <columns>
        <column name="documents.*" />
    </columns>
    <conditions>
        <condition operation="in" column="documents.module_srl" var="module_srl" filter="number" />
        <condition operation="in" column="documents.category_srl" var="category_srl" filter="number" pipe="and" />
        <condition operation="equal" column="documents.member_srl" var="member_srl" filter="number" pipe="and" />
        <condition operation="in" column="documents.status" var="statusList" pipe="and" />
        
                <condition operation="equal" column="extra_vars.var_idx" var="var_idx"  pipe="and" />
                <condition operation="like" column="extra_vars.value" var="var_value"  pipe="and" />
                <condition operation="equal" column="extra_varsA.var_idx" var="var_idxA"  pipe="and" />
                <condition operation="like" column="extra_varsA.value" var="var_valueA"  pipe="and" />
                <condition operation="equal" column="extra_varsB.var_idx" var="var_idxB"  pipe="and" />
                <condition operation="like" column="extra_varsB.value" var="var_valueB"  pipe="and" />
                <condition operation="equal" column="extra_varsC.var_idx" var="var_idxC"  pipe="and" />
                <condition operation="like" column="extra_varsC.value" var="var_valueC"  pipe="and" />
    </conditions>
    <groups>
        <group column="documents.document_srl" />
    </groups>
    <navigation>
        <index var="sort_index" default="documents.list_order" order="order_type" />
        <list_count var="list_count" default="20" />
        <page_count var="page_count" default="10" />
        <page var="page" default="1" />
    </navigation>
</query>
 

일단 쿼리 실행 결과는 정상적으로 동작한것을 $output을 var_dump로 확인했고

board.view.php의 $this->dispBoardContentList(); 실행 후에도 Context::get('document_list') 를 덤프떴더니 제대로 들어가 있는게 확인 되는데

 

실제로 검색버튼을 누르면 그냥 전체리스트만 띄워주고있네요..

제가 뭔가 처리를 잘못한 부분이나 추가로 수정해줘야 할 부분이 있을까요?ㅠㅜㅠㅜ

 

글쓴이 제목 최종 글
XE 공지 글 쓰기,삭제 운영방식 변경 공지 [16] 2019.03.05 by 남기남
산운 본문삽입~~ [3] file 2017.07.06 by 이온디
토끼 BNU님이 만드신 연관글 애드온이요 ㅠㅠ 아예 본문 하단에 안보입니다.  
리필 스케치북 스킨 sns 공유버튼 문의 [1] 2017.07.05 by Luatic™
peace**** 모바일 디버깅  
DjK1LLeR 유튜브 모듈에 댓글 달기를 추가할려면 ~  
튜닝셀프 다른 화면으로 넘어갈때 익스 창의 제목이 안 바뀌게 하려면 어떻게 해야 하나요?  
sunkist 고수님들 php 버전 질문드립니다. 답변 부탁드립니다. [3] 2017.07.04 by HowtoXE
블링크 글자를 뿌려주는 부분인데, {}이 들어간 부분을 사용하면 문제가 생깁니다. [1] 2017.07.04 by 블링크
친절한상담원 xe 새게시판 만드는법 [1] file 2017.07.04 by onTrust
랄라리랄라뿅 예약관리 시스템.. [3] 2017.07.04 by J.LAB
영종몬 날짜별 예약시스템 [3] 2017.07.04 by J.LAB
yeo**** 펜션 실시간 예약 모듈 이용법 [3] 2017.07.04 by J.LAB
두비두바 1.8.42 코어 업그레이드 후 게시판에 글 쓸 때 에러가 납니다. [1] 2017.07.04 by HowtoXE
친절한상담원 닷홈게시판복구요청 [2] 2017.07.04 by 친절한상담원
영종몬 사이트 창 너비 크기에 따른 위젯 위치변경 file  
NobleMS 회원정보 모듈 사용자설정  
초보덕 쉬운설치 문제점 [2] 2017.07.03 by 초보덕
영종몬 테이블 왼쪽 여백주는방법 [3] file 2017.07.03 by 영종몬
thdwjdtjr 유튜브 소스코드 삽입후 섬네일에 이미지가 나타나도록 [1] 2017.07.03 by DoorWeb
sugao 스케치북5 갤러리형 게시판 가로 사이즈 변경 [1] file 2017.07.03 by DoorWeb
아굴라2 회원가입 후 이동 페이지가 안 되는 문제  
hangrim00 엣지 브라우저 다운로드시 한글파일명 깨짐문제 [3] 2017.07.02 by hio****
파란촌놈 colorCode 모바일 레이아웃 질문 [4] 2017.07.01 by 파란촌놈
잠실베어스 유튜브 등 SNS 주소만 입력하면 아래 자동으로 출력시키고 싶습니다. [3] 2017.07.01 by thdwjdtjr
친절한상담원 닷홈 게시판에 스팸글 지우려는데 xe관리자 페이지 찾는 방법 [1] 2017.07.01 by sejin7940
orangetree89 제목이 없는 페이지가 59%?  
코딩펀 댓글을 스큰 형태로 가져오는 방법을 찾고 있어요!  
다탱 메모장 스킨 모바일에선 엔터표시가 제대로 먹혀서 줄 바꾸기가 되는데 PC버전에선 그게 안돼요  
원이아빠 출석부모듈 시간조정 부분 php 가 어디인가요 ? [1] 2017.06.30 by HowtoXE
파란촌놈 악성 글이 너무 많이 올라와서... [1] file 2017.06.30 by HowtoXE