주문내역 삭제 질문입니다~ 채택완료
lacomparte
8년 전
조회 6,845
파일 : wishlist.php
참고 : wishlist.php파일 내에 form 의 action 값을 wishaction.php로 변경
아래는 wishaction.php의 내용
</p><p><?php</p><p>include_once('./_common.php');</p><p> </p><p>// print_r2($_POST); exit;</p><p> </p><p>// 보관기간이 지난 상품 삭제</p><p>cart_item_clean();</p><p> </p><p>// cart id 설정</p><p>set_cart_id($sw_direct);</p><p> </p><p>if($sw_direct)</p><p> $tmp_cart_id = get_session('ss_cart_direct');</p><p>else</p><p> $tmp_cart_id = get_session('ss_cart_id');</p><p> </p><p>// 브라우저에서 쿠키를 허용하지 않은 경우라고 볼 수 있음.</p><p>if (!$tmp_cart_id)</p><p>{</p><p> alert('더 이상 작업을 진행할 수 없습니다.\\n\\n브라우저의 쿠키 허용을 사용하지 않음으로 설정한것 같습니다.\\n\\n브라우저의 인터넷 옵션에서 쿠키 허용을 사용으로 설정해 주십시오.\\n\\n그래도 진행이 되지 않는다면 쇼핑몰 운영자에게 문의 바랍니다.');</p><p>}</p><p> </p><p> </p><p>// 레벨(권한)이 상품구입 권한보다 작다면 상품을 구입할 수 없음.</p><p>if ($member['mb_level'] < $default['de_level_sell'])</p><p>{</p><p> alert('상품을 구입할 수 있는 권한이 없습니다.');</p><p>}</p><p> </p><p>if ($act == "alldelete") // 모두 삭제이면</p><p>{</p><p> $sql = " DELETE FROM {$g5['g5_shop_wish_table']}</p><p> WHERE mb_id = '{$member[mb_id]}' ";</p><p> sql_query($sql);</p><p>}</p><p>else if ($act == "seldelete") // 선택삭제</p><p>{</p><p> if(!count($_POST['chk_it_id']))</p><p> alert("삭제하실 상품을 하나이상 선택해 주십시오.dd");</p><p> </p><p> $fldcnt = count($_POST['it_id']);</p><p> for($i=0; $i<$fldcnt; $i++) {</p><p> $ct_chk = $_POST['chk_it_id'][$i];</p><p> if($ct_chk) {</p><p> $it_id = $_POST['it_id'][$i];</p><p> $sql = " delete from {$g5['g5_shop_wish_table']} where it_id = '$it_id' and mb_id = '{$member[mb_id]}' ";</p><p> sql_query($sql);</p><p><span class="Apple-tab-span" style="white-space:pre"> </span> </p><p> }</p><p> }</p><p>} </p><p>else // 장바구니에 담기</p><p>{</p><p> $count = count($_POST['it_id']);</p><p> if ($count < 1)</p><p> alert('장바구니에 담을 상품을 선택하여 주십시오.');</p><p> </p><p> $ct_count = 0;</p><p> for($i=0; $i<$count; $i++) {</p><p> // 보관함의 상품을 담을 때 체크되지 않은 상품 건너뜀</p><p> if($act == 'multi' && !$_POST['chk_it_id'][$i])</p><p> continue;</p><p> </p><p> $it_id = $_POST['it_id'][$i];</p><p> $opt_count = count($_POST['io_id'][$it_id]);</p><p> </p><p> if($opt_count && $_POST['io_type'][$it_id][0] != 0)</p><p> alert('상품의 선택옵션을 선택해 주십시오.');</p><p> </p><p> for($k=0; $k<$opt_count; $k++) {</p><p> if ($_POST['ct_qty'][$it_id][$k] < 1)</p><p> alert('수량은 1 이상 입력해 주십시오.');</p><p> }</p><p> </p><p> // 상품정보</p><p> $sql = " select * from {$g5['g5_shop_item_table']} where it_id = '$it_id' ";</p><p> $it = sql_fetch($sql);</p><p> if(!$it['it_id'])</p><p> alert('상품정보가 존재하지 않습니다.');</p><p> </p><p> // 바로구매에 있던 장바구니 자료를 지운다.</p><p> if($i == 0 && $sw_direct)</p><p> sql_query(" delete from {$g5['g5_shop_cart_table']} where od_id = '$tmp_cart_id' and ct_direct = 1 ", false);</p><p> </p><p><span class="Apple-tab-span" style="white-space:pre"> </span>// 구매회원 레벨제한</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>$sql = " SELECT ca_purchase_limit FROM {$g5['g5_shop_category_table']} WHERE ca_id = '$it[ca_id]' ";</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>$ca = sql_fetch($sql);</p><p> </p><p> </p><p><span class="Apple-tab-span" style="white-space:pre"> </span>// 레벨제한값이 있을 경우 체크</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>if ($ca['ca_purchase_limit'] != "") {</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>// 레벨제한에 로그인된 회원의 레벨이 없을 경우</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>if (strpos($ca['ca_purchase_limit'], (STRING)$member['mb_level']) === false) {</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>alert("해당상품은 기업회원만 구매가 가능합니다.");</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>}</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>}</p><p> </p><p> // 최소, 최대 수량 체크</p><p> if($it['it_buy_min_qty'] || $it['it_buy_max_qty']) {</p><p> $sum_qty = 0;</p><p> for($k=0; $k<$opt_count; $k++) {</p><p> if($_POST['io_type'][$it_id][$k] == 0)</p><p> $sum_qty += $_POST['ct_qty'][$it_id][$k];</p><p> }</p><p> </p><p> if($it['it_buy_min_qty'] > 0 && $sum_qty < $it['it_buy_min_qty'])</p><p> alert($it['it_name'].'의 선택옵션 개수 총합 '.number_format($it['it_buy_min_qty']).'개 이상 주문해 주십시오.');</p><p> </p><p> if($it['it_buy_max_qty'] > 0 && $sum_qty > $it['it_buy_max_qty'])</p><p> alert($it['it_name'].'의 선택옵션 개수 총합 '.number_format($it['it_buy_max_qty']).'개 이하로 주문해 주십시오.');</p><p> </p><p> // 기존에 장바구니에 담긴 상품이 있는 경우에 최대 구매수량 체크</p><p> if($it['it_buy_max_qty'] > 0) {</p><p> $sql4 = " select sum(ct_qty) as ct_sum</p><p> from {$g5['g5_shop_cart_table']}</p><p> where od_id = '$tmp_cart_id'</p><p> and it_id = '$it_id'</p><p> and io_type = '0'</p><p> and ct_status = '쇼핑' ";</p><p> $row4 = sql_fetch($sql4);</p><p> </p><p> if(($sum_qty + $row4['ct_sum']) > $it['it_buy_max_qty'])</p><p> alert($it['it_name'].'의 선택옵션 개수 총합 '.number_format($it['it_buy_max_qty']).'개 이하로 주문해 주십시오.', './cart.php');</p><p> }</p><p> }</p><p> </p><p> // 옵션정보를 얻어서 배열에 저장</p><p> $opt_list = array();</p><p> $sql = " select * from {$g5['g5_shop_item_option_table']} where it_id = '$it_id' order by io_no asc ";</p><p> $result = sql_query($sql);</p><p> $lst_count = 0;</p><p> for($k=0; $row=sql_fetch_array($result); $k++) {</p><p> $opt_list[$row['io_type']][$row['io_id']]['id'] = $row['io_id'];</p><p> $opt_list[$row['io_type']][$row['io_id']]['use'] = $row['io_use'];</p><p> $opt_list[$row['io_type']][$row['io_id']]['price'] = $row['io_price'];</p><p> $opt_list[$row['io_type']][$row['io_id']]['stock'] = $row['io_stock_qty'];</p><p> </p><p> // 선택옵션 개수</p><p> if(!$row['io_type'])</p><p> $lst_count++;</p><p> }</p><p> </p><p> //--------------------------------------------------------</p><p> // 재고 검사, 바로구매일 때만 체크</p><p> //--------------------------------------------------------</p><p> // 이미 주문폼에 있는 같은 상품의 수량합계를 구한다.</p><p> if($sw_direct) {</p><p> for($k=0; $k<$opt_count; $k++) {</p><p> $io_id = $_POST['io_id'][$it_id][$k];</p><p> $io_type = $_POST['io_type'][$it_id][$k];</p><p> $io_value = $_POST['io_value'][$it_id][$k];</p><p> </p><p> $sql = " select SUM(ct_qty) as cnt from {$g5['g5_shop_cart_table']}</p><p> where od_id <> '$tmp_cart_id'</p><p> and it_id = '$it_id'</p><p> and io_id = '$io_id'</p><p> and io_type = '$io_type'</p><p> and ct_stock_use = 0</p><p> and ct_status = '쇼핑'</p><p> and ct_select = '1' ";</p><p> $row = sql_fetch($sql);</p><p> $sum_qty = $row['cnt'];</p><p> </p><p> // 재고 구함</p><p> $ct_qty = $_POST['ct_qty'][$it_id][$k];</p><p> if(!$io_id)</p><p> $it_stock_qty = get_it_stock_qty($it_id);</p><p> else</p><p> $it_stock_qty = get_option_stock_qty($it_id, $io_id, $io_type);</p><p> </p><p> if ($ct_qty + $sum_qty > $it_stock_qty)</p><p> {</p><p> alert($io_value." 의 재고수량이 부족합니다.\\n\\n현재 재고수량 : " . number_format($it_stock_qty - $sum_qty) . " 개");</p><p> }</p><p> }</p><p> }</p><p> //--------------------------------------------------------</p><p> </p><p> // 옵션수정일 때 기존 장바구니 자료를 먼저 삭제</p><p> if($act == 'optionmod')</p><p> sql_query(" delete from {$g5['g5_shop_cart_table']} where od_id = '$tmp_cart_id' and it_id = '$it_id' ");</p><p> // 장바구니에 Insert</p><p> // 바로구매일 경우 장바구니가 체크된것으로 강제 설정</p><p> if($sw_direct) {</p><p> $ct_select = 1;</p><p> $ct_select_time = G5_TIME_YMDHIS;</p><p> } else {</p><p> $ct_select = 0;</p><p> $ct_select_time = '0000-00-00 00:00:00';</p><p> }</p><p> </p><p> // 장바구니에 Insert</p><p> $comma = '';</p><p> $sql = " INSERT INTO {$g5['g5_shop_cart_table']}</p><p> ( od_id, mb_id, it_id, it_name, it_sc_type, it_sc_method, it_sc_price, it_sc_minimum, it_sc_qty, ct_status, ct_price, ct_point, ct_point_use, ct_stock_use, ct_option, ct_qty, ct_notax, io_id, io_type, io_price, ct_time, ct_ip, ct_send_cost, ct_direct, ct_select, ct_select_time )</p><p> VALUES ";</p><p> for($k=0; $k<$opt_count; $k++) {</p><p> $io_id = $_POST['io_id'][$it_id][$k];</p><p> $io_type = $_POST['io_type'][$it_id][$k];</p><p> $io_value = $_POST['io_value'][$it_id][$k];</p><p> </p><p> // 선택옵션정보가 존재하는데 선택된 옵션이 없으면 건너뜀</p><p> if($lst_count && $io_id == '')</p><p> continue;</p><p> </p><p> // 구매할 수 없는 옵션은 건너뜀</p><p> if($io_id && !$opt_list[$io_type][$io_id]['use'])</p><p> continue;</p><p> </p><p> $io_price = $opt_list[$io_type][$io_id]['price'];</p><p> $ct_qty = $_POST['ct_qty'][$it_id][$k];</p><p> </p><p> // 구매가격이 음수인지 체크</p><p> if($io_type) {</p><p> if((int)$io_price < 0)</p><p> alert('구매금액이 음수인 상품은 구매할 수 없습니다.');</p><p> } else {</p><p> if((int)$it['it_price'] + (int)$io_price < 0)</p><p> alert('구매금액이 음수인 상품은 구매할 수 없습니다.');</p><p> }</p><p> </p><p> // 동일옵션의 상품이 있으면 수량 더함</p><p>/*</p><p> $sql2 = " select ct_id, io_type, ct_qty</p><p> from {$g5['g5_shop_cart_table']}</p><p> where od_id = '$tmp_cart_id'</p><p> and it_id = '$it_id'</p><p> and io_id = '$io_id'</p><p> and ct_status = '쇼핑' ";</p><p> $row2 = sql_fetch($sql2);</p><p>*/</p><p> if($row2['ct_id']) {</p><p> // 재고체크</p><p> $tmp_ct_qty = $row2['ct_qty'];</p><p> if(!$io_id)</p><p> $tmp_it_stock_qty = get_it_stock_qty($it_id);</p><p> else</p><p> $tmp_it_stock_qty = get_option_stock_qty($it_id, $io_id, $row2['io_type']);</p><p> </p><p> if ($tmp_ct_qty + $ct_qty > $tmp_it_stock_qty)</p><p> {</p><p> alert($io_value." 의 재고수량이 부족합니다.\\n\\n현재 재고수량 : " . number_format($tmp_it_stock_qty) . " 개");</p><p> }</p><p> $sql3 = " update {$g5['g5_shop_cart_table']}</p><p> set ct_qty = ct_qty + '$ct_qty'</p><p> where ct_id = '{$row2['ct_id']}' ";</p><p> sql_query($sql3);</p><p> continue;</p><p> }</p><p> // 포인트</p><p> $point = 0;</p><p> if($config['cf_use_point']) {</p><p> if($io_type == 0) {</p><p> $point = get_item_point($it, $io_id);</p><p> } else {</p><p> $point = $it['it_supply_point'];</p><p> }</p><p> </p><p> if($point < 0)</p><p> $point = 0;</p><p> }</p><p> </p><p> // 배송비결제</p><p> if($it['it_sc_type'] == 1)</p><p> $ct_send_cost = 2; // 무료</p><p> else if($it['it_sc_type'] > 1 && $it['it_sc_method'] == 1)</p><p> $ct_send_cost = 1; // 착불</p><p> </p><p> $sql .= $comma."( '$tmp_cart_id', '{$member['mb_id']}', '{$it['it_id']}', '".addslashes($it['it_name'])."', '{$it['it_sc_type']}', '{$it['it_sc_method']}', '{$it['it_sc_price']}', '{$it['it_sc_minimum']}', '{$it['it_sc_qty']}', '쇼핑', '{$it['it_price']}', '$point', '0', '0', '$io_value', '$ct_qty', '{$it['it_notax']}', '$io_id', '$io_type', '$io_price', '".G5_TIME_YMDHIS."', '$REMOTE_ADDR', '$ct_send_cost', '$sw_direct', '$ct_select', '$ct_select_time' )";</p><p> $comma = ' , ';</p><p> $ct_count++;</p><p> }</p><p> </p><p> if($ct_count > 0)</p><p> sql_query($sql);</p><p> }</p><p>}</p><p> </p><p>print_r ($sql);</p><p> </p><p>// 바로 구매일 경우</p><p>if ($sw_direct)</p><p>{</p><p> if ($is_member)</p><p> {</p><p> <span class="Apple-tab-span" style="white-space:pre"> </span>goto_url(G5_SHOP_URL."/orderform.php?sw_direct=$sw_direct");</p><p> }</p><p> else</p><p> {</p><p> <span class="Apple-tab-span" style="white-space:pre"> </span>goto_url(G5_BBS_URL."/login.php?url=".urlencode(G5_SHOP_URL."/orderform.php?sw_direct=$sw_direct"));</p><p> }</p><p>}</p><p>else</p><p>{</p><p> goto_url(G5_SHOP_URL.'/wishlist.php');</p><p>}</p><p>?></p><div>
</div><p>
질문.
주문내역 삭제를 체크박스를 이용해서
선택삭제와 전체삭제를 구현하고 싶은데요.
사실 전체삭제는 delete 쿼리로 wish table 에 mb_id 가 같은것만 찾아서 지워주면
되기 때문에 어렵지 않게 구현했는데..
선택삭제는 자바스크립가 껴있어서 ㅠ
굉장히 난감하네요;
문제가 되는 함수가 아래 두개인데요.
out_cd_check 와 fwishlist_check 이것들 입니다.
out_cd_check 는 상품옵션의 io_type을 보고 옵션을 선택해야 하는 상품인지
아니면 전화문의 상품인지 구별하는 코드 같고,
fwishlist_check 는 버튼들의 액션 인자를 구별해서 각각 필요한
act 값을 wishaction.php에 던져주는 함수 같습니다.
전 체크박스를 누르자 마자 out_cd_check를 판별하는게 아니라
서브밋이 일어났을때 체크를 해서 return 을 하고 싶습니다 ㅠ
서브밋이 일어날때면 fwishlist_check 함수인데..
이 함수 안에 act 별로 out_cd_check 함수를 넣어주면
에러가 나네요; (당연한거겠지요..!?)
</p><p>function out_cd_check(fld, out_cd)</p><p> {</p><p> if (out_cd == 'no'){</p><p> alert("옵션이 있는 상품입니다.\n\n상품을 클릭하여 상품페이지에서 옵션을 선택한 후 주문하십시오.");</p><p> fld.checked = false;</p><p> return;</p><p> } else if (out_cd == 'tel_inq'){</p><p> alert("이 상품은 전화로 문의해 주십시오.\n\n장바구니에 담아 구입하실 수 없습니다.");</p><p> fld.checked = false;</p><p> return;</p><p> } else {</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>alert</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>}</p><p> }</p><p> </p><p> function fwishlist_check(f, act)</p><p> {</p><p> var k = 0;</p><p> var length = f.elements.length;</p><p> </p><p> for(i=0; i<length; i++) {</p><p> if (f.elements[i].checked) {</p><p> k++;</p><p> }</p><p> }</p><p> </p><p> if(k == 0)</p><p> {</p><p> alert("상품을 하나 이상 체크 하십시오");</p><p> return false;</p><p> }</p><p> </p><p> if (act == "direct_buy")</p><p> {</p><p> f.sw_direct.value = 1;</p><p> }</p><p> else</p><p> {</p><p> f.sw_direct.value = 0;</p><p> }</p><p> </p><p> return true;</p><p> }</p><p>
댓글을 작성하려면 로그인이 필요합니다.
답변 1개
답변을 작성하려면 로그인이 필요합니다.
로그인
관심상품를 삭제하는건데
기반은 cart.php의 스크립트구요 ㅋ
근데 각각함수의 파라미터값이 wishlist.php랑 cart.php랑 달라서
어떻게 처리해야 하나 고민중인거예요 ㅎ