198 lines
7.1 KiB
PHP
198 lines
7.1 KiB
PHP
<?php
|
|
$sub_menu = "100290";
|
|
include_once('./_common.php');
|
|
|
|
if ($is_admin != 'super')
|
|
alert('최고관리자만 접근 가능합니다.');
|
|
|
|
$token = get_token();
|
|
|
|
// 메뉴테이블 생성
|
|
if( !isset($g5['menu_table']) ){
|
|
die('<meta charset="utf-8">dbconfig.php 파일에 <strong>$g5[\'menu_table\'] = G5_TABLE_PREFIX.\'menu\';</strong> 를 추가해 주세요.');
|
|
}
|
|
|
|
if(!sql_query(" DESCRIBE {$g5['menu_table']} ", false)) {
|
|
sql_query(" CREATE TABLE IF NOT EXISTS `{$g5['menu_table']}` (
|
|
`me_id` int(11) NOT NULL AUTO_INCREMENT,
|
|
`me_code` varchar(255) NOT NULL DEFAULT '',
|
|
`me_name` varchar(255) NOT NULL DEFAULT '',
|
|
`me_link` varchar(255) NOT NULL DEFAULT '',
|
|
`me_target` varchar(255) NOT NULL DEFAULT '0',
|
|
`me_order` int(11) NOT NULL DEFAULT '0',
|
|
`me_use` tinyint(4) NOT NULL DEFAULT '0',
|
|
`me_mobile_use` tinyint(4) NOT NULL DEFAULT '0',
|
|
PRIMARY KEY (`me_id`)
|
|
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ", true);
|
|
}
|
|
|
|
$sql = " select * from {$g5['menu_table']} order by me_id ";
|
|
$result = sql_query($sql);
|
|
|
|
$g5['title'] = "메뉴설정";
|
|
include_once('./admin.head.php');
|
|
|
|
$colspan = 7;
|
|
?>
|
|
|
|
<form name="fmenulist" id="fmenulist" method="post" action="./menu_list_update.php" onsubmit="return fmenulist_submit(this);">
|
|
<input type="hidden" name="token" value="<?php echo $token ?>">
|
|
|
|
<div>
|
|
<button type="button" onclick="return add_menu();">메뉴추가</button>
|
|
</div>
|
|
|
|
<div id="menulist" class="tbl_head01 tbl_wrap">
|
|
<table>
|
|
<caption><?php echo $g5['title']; ?> 목록</caption>
|
|
<thead>
|
|
<tr>
|
|
<th scope="col">메뉴</th>
|
|
<th scope="col">링크</th>
|
|
<th scope="col">새창</th>
|
|
<th scope="col">순서</th>
|
|
<th scope="col">PC사용</th>
|
|
<th scope="col">모바일사용</th>
|
|
<th scope="col">관리</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<?php
|
|
for ($i=0; $row=sql_fetch_array($result); $i++)
|
|
{
|
|
$bg = 'bg'.($i%2);
|
|
$sub_menu_class = '';
|
|
if(strlen($row['me_code']) == 4)
|
|
$sub_menu_class = ' class="sub_menu_class"';
|
|
?>
|
|
<tr class="<?php echo $bg; ?> menu_list menu_group_<?php echo substr($row['me_code'], 0, 2); ?>">
|
|
<td<?php echo $sub_menu_class; ?>>
|
|
<input type="hidden" name="code[]" value="<?php echo substr($row['me_code'], 0, 2) ?>">
|
|
<label for="me_name_<?php echo $i; ?>" class="sound_only">메뉴</label>
|
|
<input type="text" name="me_name[]" value="<?php echo $row['me_name'] ?>" id="me_name_<?php echo $i; ?>" required class="required frm_input">
|
|
</td>
|
|
<td>
|
|
<label for="me_link_<?php echo $i; ?>" class="sound_only">링크</label>
|
|
<input type="text" name="me_link[]" value="<?php echo $row['me_link'] ?>" id="me_link_<?php echo $i; ?>" required class="required frm_input">
|
|
</td>
|
|
<td>
|
|
<label for="me_target_<?php echo $i; ?>" class="sound_only">새창</label>
|
|
<select name="me_target[]" id="me_target_<?php echo $i; ?>">
|
|
<option value="self"<?php echo get_selected($row['me_target'], 'self', true); ?>>사용안함</option>
|
|
<option value="blank"<?php echo get_selected($row['me_target'], 'blank', true); ?>>사용함</option>
|
|
</select>
|
|
</td>
|
|
<td>
|
|
<label for="me_order_<?php echo $i; ?>" class="sound_only">순서</label>
|
|
<input type="text" name="me_order[]" value="<?php echo $row['me_order'] ?>" id="me_order_<?php echo $i; ?>" class="frm_input" size="5">
|
|
</td>
|
|
<td>
|
|
<label for="me_use_<?php echo $i; ?>" class="sound_only">PC사용</label>
|
|
<select name="me_use[]" id="me_use_<?php echo $i; ?>">
|
|
<option value="1"<?php echo get_selected($row['me_use'], '1', true); ?>>사용함</option>
|
|
<option value="0"<?php echo get_selected($row['me_use'], '0', true); ?>>사용안함</option>
|
|
</select>
|
|
</td>
|
|
<td>
|
|
<label for="me_mobile_use_<?php echo $i; ?>" class="sound_only">모바일사용</label>
|
|
<select name="me_mobile_use[]" id="me_mobile_use_<?php echo $i; ?>">
|
|
<option value="1"<?php echo get_selected($row['me_mobile_use'], '1', true); ?>>사용함</option>
|
|
<option value="0"<?php echo get_selected($row['me_mobile_use'], '0', true); ?>>사용안함</option>
|
|
</select>
|
|
</td>
|
|
<td>
|
|
<?php if(strlen($row['me_code']) == 2) { ?>
|
|
<button type="button" class="btn_add_submenu">추가</button>
|
|
<?php } ?>
|
|
<button type="button" class="btn_del_menu">삭제</button>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
|
|
if ($i==0)
|
|
echo '<tr id="empty_menu_list"><td colspan="'.$colspan.'" class="empty_table">자료가 없습니다.</td></tr>';
|
|
?>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
|
|
<div class="btn_list01 btn_list">
|
|
<input type="submit" name="act_button" value="확인">
|
|
</div>
|
|
|
|
</form>
|
|
|
|
<script>
|
|
$(function() {
|
|
$(".btn_add_submenu").live("click", function() {
|
|
var code = $(this).closest("tr").find("input[name='code[]']").val().substr(0, 2);
|
|
add_submenu(code);
|
|
});
|
|
|
|
$(".btn_del_menu").live("click", function() {
|
|
if(!confirm("메뉴를 삭제하시겠습니까?"))
|
|
return false;
|
|
|
|
var $tr = $(this).closest("tr");
|
|
if($tr.find("td.sub_menu_class").size() > 0) {
|
|
$tr.remove();
|
|
} else {
|
|
var code = $(this).closest("tr").find("input[name='code[]']").val().substr(0, 2);
|
|
$("tr.menu_group_"+code).remove();
|
|
}
|
|
|
|
if($("#menulist tr.menu_list").size() < 1) {
|
|
var list = "<tr id=\"empty_menu_list\"><td colspan=\"<?php echo $colspan; ?>\" class=\"empty_table\">자료가 없습니다.</td></tr>\n";
|
|
$("#menulist table tbody").append(list);
|
|
} else {
|
|
$("#menulist tr.menu_list").each(function(index) {
|
|
$(this).removeClass("bg0 bg1")
|
|
.addClass("bg"+(index % 2));
|
|
});
|
|
}
|
|
});
|
|
});
|
|
|
|
function add_menu()
|
|
{
|
|
var max_code = base_convert(0, 10, 36);
|
|
$("#menulist tr.menu_list").each(function() {
|
|
var me_code = $(this).find("input[name='code[]']").val().substr(0, 2);
|
|
if(max_code < me_code)
|
|
max_code = me_code;
|
|
});
|
|
|
|
var url = "./menu_form.php?code="+max_code+"&new=new";
|
|
window.open(url, "add_menu", "left=100,top=100,width=550,height=650");
|
|
return false;
|
|
}
|
|
|
|
function add_submenu(code)
|
|
{
|
|
var url = "./menu_form.php?code="+code;
|
|
window.open(url, "add_menu", "left=100,top=100,width=550,height=650");
|
|
return false;
|
|
}
|
|
|
|
function base_convert(number, frombase, tobase) {
|
|
// discuss at: http://phpjs.org/functions/base_convert/
|
|
// original by: Philippe Baumann
|
|
// improved by: Rafał Kukawski (http://blog.kukawski.pl)
|
|
// example 1: base_convert('A37334', 16, 2);
|
|
// returns 1: '101000110111001100110100'
|
|
|
|
return parseInt(number + '', frombase | 0)
|
|
.toString(tobase | 0);
|
|
}
|
|
|
|
function fmenulist_submit(f)
|
|
{
|
|
return true;
|
|
}
|
|
</script>
|
|
|
|
<?php
|
|
include_once ('./admin.tail.php');
|
|
?>
|