390 lines
18 KiB
PHP
390 lines
18 KiB
PHP
<?php
|
|
|
|
/**
|
|
* [Discuz!] (C)2001-2099 Comsenz Inc.
|
|
* This is NOT a freeware, use is subject to license terms
|
|
*
|
|
* $Id: admincp_medals.php 31634 2012-09-17 06:43:39Z monkey $
|
|
*/
|
|
|
|
if(!defined('IN_DISCUZ') || !defined('IN_ADMINCP')) {
|
|
exit('Access Denied');
|
|
}
|
|
|
|
cpheader();
|
|
|
|
if(!$operation) {
|
|
|
|
if(!submitcheck('medalsubmit')) {
|
|
shownav('extended', 'nav_medals', 'admin');
|
|
showsubmenu('nav_medals', array(
|
|
array('admin', 'medals', 1),
|
|
array('nav_medals_confer', 'members&operation=confermedal', 0),
|
|
array('nav_medals_mod', 'medals&operation=mod', 0)
|
|
));
|
|
showtips('medals_tips');
|
|
showformheader('medals');
|
|
showtableheader('medals_list', 'fixpadding');
|
|
showsubtitle(array('', 'display_order', 'available', 'name', 'description', 'medals_image', 'medals_type', ''));
|
|
|
|
?>
|
|
<script type="text/JavaScript">
|
|
var rowtypedata = [
|
|
[
|
|
[1,'', 'td25'],
|
|
[1,'<input type="text" class="txt" name="newdisplayorder[]" size="3">', 'td28'],
|
|
[1,'', 'td25'],
|
|
[1,'<input type="text" class="txt" name="newname[]" size="10">'],
|
|
[1,'<input type="text" class="txt" name="newdescription[]" size="30">'],
|
|
[1,'<input type="text" class="txt" name="newimage[]" size="20">'],
|
|
[1,'', 'td23'],
|
|
[1,'', 'td25']
|
|
]
|
|
];
|
|
</script>
|
|
<?php
|
|
foreach(C::t('forum_medal')->fetch_all_data() as $medal) {
|
|
$checkavailable = $medal['available'] ? 'checked' : '';
|
|
switch($medal['type']) {
|
|
case 0:
|
|
$medal['type'] = cplang('medals_adminadd');
|
|
break;
|
|
case 1:
|
|
$medal['type'] = $medal['price'] ? cplang('medals_buy') : cplang('medals_register');
|
|
break;
|
|
case 2:
|
|
$medal['type'] = cplang('modals_moderate');
|
|
break;
|
|
}
|
|
showtablerow('', array('class="td25"', 'class="td25"', 'class="td25"', '', '', '', 'class="td23"', 'class="td25"'), array(
|
|
"<input class=\"checkbox\" type=\"checkbox\" name=\"delete[]\" value=\"$medal[medalid]\">",
|
|
"<input type=\"text\" class=\"txt\" size=\"3\" name=\"displayorder[$medal[medalid]]\" value=\"$medal[displayorder]\">",
|
|
"<input class=\"checkbox\" type=\"checkbox\" name=\"available[$medal[medalid]]\" value=\"1\" $checkavailable>",
|
|
"<input type=\"text\" class=\"txt\" size=\"10\" name=\"name[$medal[medalid]]\" value=\"$medal[name]\">",
|
|
"<input type=\"text\" class=\"txt\" size=\"30\" name=\"description[$medal[medalid]]\" value=\"$medal[description]\">",
|
|
"<input type=\"text\" class=\"txt\" size=\"20\" name=\"image[$medal[medalid]]\" value=\"$medal[image]\"><img style=\"vertical-align:middle\" src=\"static/image/common/$medal[image]\">",
|
|
$medal[type],
|
|
"<a href=\"".ADMINSCRIPT."?action=medals&operation=edit&medalid=$medal[medalid]\" class=\"act\">$lang[detail]</a>"
|
|
));
|
|
}
|
|
|
|
echo '<tr><td></td><td colspan="8"><div><a href="###" onclick="addrow(this, 0)" class="addtr">'.$lang['medals_addnew'].'</a></div></td></tr>';
|
|
showsubmit('medalsubmit', 'submit', 'del');
|
|
showtablefooter();
|
|
showformfooter();
|
|
|
|
} else {
|
|
|
|
if(is_array($_GET['delete']) && $_GET['delete']) {
|
|
$ids = array();
|
|
foreach($_GET['delete'] as $id) {
|
|
$ids[] = $id;
|
|
}
|
|
C::t('forum_medal')->delete($_GET['delete']);
|
|
}
|
|
|
|
if(is_array($_GET['name'])) {
|
|
foreach($_GET['name'] as $id => $val) {
|
|
$update = array(
|
|
'available' => $_GET['available'][$id],
|
|
'displayorder' => intval($_GET['displayorder'][$id])
|
|
);
|
|
if($_GET['name'][$id]) {
|
|
$update['name'] = dhtmlspecialchars($_GET['name'][$id]);
|
|
}
|
|
if($_GET['description'][$id]) {
|
|
$update['description'] = dhtmlspecialchars($_GET['description'][$id]);
|
|
}
|
|
if($_GET['image'][$id]) {
|
|
$update['image'] = dhtmlspecialchars($_GET['image'][$id]);
|
|
}
|
|
C::t('forum_medal')->update($id, $update);
|
|
|
|
}
|
|
}
|
|
|
|
if(is_array($_GET['newname'])) {
|
|
foreach($_GET['newname'] as $key => $value) {
|
|
if($value != '' && $_GET['newimage'][$key] != '') {
|
|
$data = array('name' => dhtmlspecialchars($value),
|
|
'available' => $_GET['newavailable'][$key],
|
|
'image' => $_GET['newimage'][$key],
|
|
'displayorder' => intval($_GET['newdisplayorder'][$key]),
|
|
'description' => dhtmlspecialchars($_GET['newdescription'][$key]),
|
|
);
|
|
C::t('forum_medal')->insert($data);
|
|
}
|
|
}
|
|
}
|
|
|
|
updatecache('setting');
|
|
updatecache('medals');
|
|
cpmsg('medals_succeed', 'action=medals', 'succeed');
|
|
|
|
}
|
|
|
|
} elseif($operation == 'mod') {
|
|
|
|
if(submitcheck('delmedalsubmit')) {
|
|
if (is_array($_GET['delete']) && !empty($_GET['delete'])) {
|
|
$ids = array();
|
|
foreach($_GET['delete'] as $id) {
|
|
$ids[] = $id;
|
|
}
|
|
C::t('forum_medallog')->update($ids, array('type' => 3));
|
|
cpmsg('medals_invalidate_succeed', 'action=medals&operation=mod', 'succeed');
|
|
} else {
|
|
cpmsg('medals_please_input', 'action=medals&operation=mod', 'error');
|
|
}
|
|
} elseif(submitcheck('modmedalsubmit')) {
|
|
|
|
if(is_array($_GET['delete']) && !empty($_GET['delete'])) {
|
|
$ids = $comma = '';
|
|
foreach($_GET['delete'] as $id) {
|
|
$ids .= "$comma'$id'";
|
|
$comma = ',';
|
|
}
|
|
|
|
$query = DB::query("SELECT me.id, me.uid, me.medalid, me.dateline, me.expiration, mf.medals
|
|
FROM ".DB::table('forum_medallog')." me
|
|
LEFT JOIN ".DB::table('common_member_field_forum')." mf USING (uid)
|
|
WHERE id IN ($ids)");
|
|
|
|
loadcache('medals');
|
|
while($modmedal = DB::fetch($query)) {
|
|
$modmedal['medals'] = empty($medalsnew[$modmedal['uid']]) ? $modmedal['medals'] : $medalsnew[$modmedal['uid']];
|
|
|
|
foreach($modmedal['medals'] = explode("\t", $modmedal['medals']) as $key => $modmedalid) {
|
|
list($medalid, $medalexpiration) = explode("|", $modmedalid);
|
|
if(isset($_G['cache']['medals'][$medalid]) && (!$medalexpiration || $medalexpiration > TIMESTAMP)) {
|
|
$medalsnew[$modmedal['uid']][$key] = $modmedalid;
|
|
}
|
|
}
|
|
$medalstatus = empty($modmedal['expiration']) ? 0 : 1;
|
|
$modmedal['expiration'] = $modmedal['expiration'] ? (TIMESTAMP + $modmedal['expiration'] - $modmedal['dateline']) : '';
|
|
$medalsnew[$modmedal['uid']][] = $modmedal['medalid'].(empty($modmedal['expiration']) ? '' : '|'.$modmedal['expiration']);
|
|
C::t('forum_medallog')->update($modmedal['id'], array('type' => 1, 'status' => $medalstatus, 'expiration' => $modmedal['expiration']));
|
|
C::t('common_member_medal')->insert(array('uid' => $modmedal['uid'], 'medalid' => $modmedal['medalid']), 0, 1);
|
|
}
|
|
|
|
foreach ($medalsnew as $key => $medalnew) {
|
|
$medalnew = array_unique($medalnew);
|
|
$medalnew = implode("\t", $medalnew);
|
|
C::t('common_member_field_forum')->update($key, array('medals' => $medalnew));
|
|
}
|
|
cpmsg('medals_validate_succeed', 'action=medals&operation=mod', 'succeed');
|
|
} else {
|
|
cpmsg('medals_please_input', 'action=medals&operation=mod', 'error');
|
|
}
|
|
} else {
|
|
|
|
$medals = '';
|
|
$medallogs = $medalids = $uids = array();
|
|
foreach(C::t('forum_medallog')->fetch_all_by_type(2) as $id => $medal) {
|
|
$medal['dateline'] = dgmdate($medal['dateline'], 'Y-m-d H:i');
|
|
$medal['expiration'] = empty($medal['expiration']) ? $lang['medals_forever'] : dgmdate($medal['expiration'], 'Y-m-d H:i');
|
|
$medalids[$medal['medalid']] = $medal['medalid'];
|
|
$uids[$medal['uid']] = $medal['uid'];
|
|
$medallogs[$id] = $medal;
|
|
}
|
|
$medalnames = C::t('forum_medal')->fetch_all($medalids);
|
|
$medalusers = C::t('common_member')->fetch_all($uids);
|
|
foreach($medallogs as $id => $medal) {
|
|
$medals .= showtablerow('', '', array(
|
|
"<input class=\"checkbox\" type=\"checkbox\" name=\"delete[]\" value=\"$id\">",
|
|
"<a href=\"home.php?mod=space&username=".rawurlencode($medalusers[$medal['uid']]['username'])."\" target=\"_blank\">{$medalusers[$medal[uid]][username]}</a>",
|
|
$medalnames[$medal['medalid']]['name'],
|
|
$medal['dateline'],
|
|
$medal['expiration']
|
|
), TRUE);
|
|
}
|
|
|
|
shownav('extended', 'nav_medals', 'nav_medals_mod');
|
|
showsubmenu('nav_medals', array(
|
|
array('admin', 'medals', 0),
|
|
array('nav_medals_confer', 'members&operation=confermedal', 0),
|
|
array('nav_medals_mod', 'medals&operation=mod', 1)
|
|
));
|
|
showformheader('medals&operation=mod');
|
|
showtableheader('medals_mod');
|
|
showtablerow('', '', array(
|
|
'',
|
|
cplang('medals_user'),
|
|
cplang('medals_name'),
|
|
cplang('medals_date'),
|
|
cplang('medals_expr'),
|
|
));
|
|
echo $medals;
|
|
showsubmit('modmedalsubmit', 'medals_modpass', 'select_all', '<input type="submit" class="btn" value="'.cplang('medals_modnopass').'" name="delmedalsubmit"> ');
|
|
showtablefooter();
|
|
showformfooter();
|
|
}
|
|
|
|
} elseif($operation == 'edit') {
|
|
|
|
$medalid = intval($_GET['medalid']);
|
|
|
|
if(!submitcheck('medaleditsubmit')) {
|
|
|
|
$medal = C::t('forum_medal')->fetch($medalid);
|
|
|
|
$medal['permission'] = dunserialize($medal['permission']);
|
|
$medal['usergroupallow'] = $medal['permission']['usergroupallow'];
|
|
$medal['usergroups'] = (array)$medal['permission']['usergroups'];
|
|
$medal['permission'] = $medal['permission'][0];
|
|
|
|
$credits = array();
|
|
$credits[] = array(0, $lang['default']);
|
|
foreach($_G['setting']['extcredits'] as $i => $extcredit) {
|
|
$credits[] = array($i, $extcredit['title']);
|
|
}
|
|
|
|
$groupselect = array();
|
|
foreach(C::t('common_usergroup')->range_orderby_credit() as $group) {
|
|
$groupselect[$group['type']] .= '<option value="'.$group['groupid'].'"'.(@in_array($group['groupid'], $medal['usergroups']) ? ' selected' : '').'>'.$group['grouptitle'].'</option>';
|
|
}
|
|
$usergroups = '<select name="usergroupsnew[]" size="10" multiple="multiple">'.
|
|
'<optgroup label="'.$lang['usergroups_member'].'">'.$groupselect['member'].'</optgroup>'.
|
|
($groupselect['special'] ? '<optgroup label="'.$lang['usergroups_special'].'">'.$groupselect['special'].'</optgroup>' : '').
|
|
($groupselect['specialadmin'] ? '<optgroup label="'.$lang['usergroups_specialadmin'].'">'.$groupselect['specialadmin'].'</optgroup>' : '').
|
|
'<optgroup label="'.$lang['usergroups_system'].'">'.$groupselect['system'].'</optgroup></select>';
|
|
|
|
shownav('extended', 'nav_medals', 'admin');
|
|
showsubmenu('nav_medals', array(
|
|
array('admin', 'medals', 1),
|
|
array('nav_medals_confer', 'members&operation=confermedal', 0),
|
|
array('nav_medals_mod', 'medals&operation=mod', 0)
|
|
));
|
|
showformheader("medals&operation=edit&medalid=$medalid");
|
|
showtableheader(cplang('medals_edit').' - '.$medal['name'], 'nobottom');
|
|
showsetting('medals_name1', 'namenew', $medal['name'], 'text');
|
|
showsetting('medals_img', '', '', '<input type="text" class="txt" size="30" name="imagenew" value="'.$medal['image'].'" ><img src="static/image/common/'.$medal['image'].'">');
|
|
showsetting('medals_type1', array('typenew', array(
|
|
array(0, $lang['medals_adminadd'], array('creditdiv' => 'none')),
|
|
array(1, $lang['medals_apply_auto'], array('creditdiv' => '')),
|
|
array(2, $lang['medals_apply_noauto'], array('creditdiv' => 'none'))
|
|
)), $medal['type'], 'mradio');
|
|
showtagheader('tbody', 'creditdiv', $medal['type'] == 1, 'sub');
|
|
showsetting('medals_credit', array('creditnew', $credits), $medal['credit'], 'select');
|
|
showsetting('medals_price', 'pricenew', $medal['price'], 'text');
|
|
showtagfooter('tbody');
|
|
showsetting('medals_usergroups_allow', 'usergroupallow', $medal['usergroupallow'], 'radio', 0, 1);
|
|
showsetting('medals_usergroups', '', '', $usergroups);
|
|
showtagfooter('tbody');
|
|
showsetting('medals_expr1', 'expirationnew', $medal['expiration'], 'text');
|
|
showsetting('medals_memo', 'descriptionnew', $medal['description'], 'text');
|
|
showtablefooter();
|
|
|
|
showtableheader('medals_perm', 'notop');
|
|
|
|
$formulareplace .= '\'<u>'.$lang['setting_credits_formula_digestposts'].'</u>\',\'<u>'.$lang['setting_credits_formula_posts'].'</u>\',\'<u>'.$lang['setting_credits_formula_oltime'].'</u>\',\'<u>'.$lang['setting_credits_formula_pageviews'].'</u>\'';
|
|
|
|
?>
|
|
<script type="text/JavaScript">
|
|
function medalsinsertunit(text, textend) {
|
|
insertunit($('formulapermnew'), text, textend);
|
|
formulaexp();
|
|
}
|
|
|
|
var formulafind = new Array('digestposts', 'posts', 'threads');
|
|
var formulareplace = new Array(<?php echo $formulareplace;?>);
|
|
function formulaexp() {
|
|
var result = $('formulapermnew').value;
|
|
<?php
|
|
|
|
$extcreditsbtn = '';
|
|
for($i = 1; $i <= 8; $i++) {
|
|
$extcredittitle = $_G['setting']['extcredits'][$i]['title'] ? $_G['setting']['extcredits'][$i]['title'] : $lang['setting_credits_formula_extcredits'].$i;
|
|
echo 'result = result.replace(/extcredits'.$i.'/g, \'<u>'.$extcredittitle.'</u>\');';
|
|
$extcreditsbtn .= '<a href="###" onclick="medalsinsertunit(\'extcredits'.$i.'\')">'.$extcredittitle.'</a> ';
|
|
}
|
|
|
|
echo 'result = result.replace(/regdate/g, \'<u>'.cplang('forums_edit_perm_formula_regdate').'</u>\');';
|
|
echo 'result = result.replace(/regday/g, \'<u>'.cplang('forums_edit_perm_formula_regday').'</u>\');';
|
|
echo 'result = result.replace(/regip/g, \'<u>'.cplang('forums_edit_perm_formula_regip').'</u>\');';
|
|
echo 'result = result.replace(/lastip/g, \'<u>'.cplang('forums_edit_perm_formula_lastip').'</u>\');';
|
|
echo 'result = result.replace(/buyercredit/g, \'<u>'.cplang('forums_edit_perm_formula_buyercredit').'</u>\');';
|
|
echo 'result = result.replace(/sellercredit/g, \'<u>'.cplang('forums_edit_perm_formula_sellercredit').'</u>\');';
|
|
echo 'result = result.replace(/digestposts/g, \'<u>'.$lang['setting_credits_formula_digestposts'].'</u>\');';
|
|
echo 'result = result.replace(/posts/g, \'<u>'.$lang['setting_credits_formula_posts'].'</u>\');';
|
|
echo 'result = result.replace(/threads/g, \'<u>'.$lang['setting_credits_formula_threads'].'</u>\');';
|
|
echo 'result = result.replace(/oltime/g, \'<u>'.$lang['setting_credits_formula_oltime'].'</u>\');';
|
|
echo 'result = result.replace(/and/g, \' '.$lang['setting_credits_formulaperm_and'].' \');';
|
|
echo 'result = result.replace(/or/g, \' '.$lang['setting_credits_formulaperm_or'].' \');';
|
|
echo 'result = result.replace(/>=/g, \'≥\');';
|
|
echo 'result = result.replace(/<=/g, \'≤\');';
|
|
|
|
?>
|
|
$('formulapermexp').innerHTML = result;
|
|
}
|
|
</script>
|
|
<tr><td colspan="2"><div class="extcredits">
|
|
<?php echo $extcreditsbtn;?>
|
|
<a href="###" onclick="medalsinsertunit(' regdate ')"> <?php echo cplang('forums_edit_perm_formula_regdate')?> </a>
|
|
<a href="###" onclick="medalsinsertunit(' regday ')"> <?php echo cplang('forums_edit_perm_formula_regday')?> </a>
|
|
<a href="###" onclick="medalsinsertunit(' regip ')"> <?php echo cplang('forums_edit_perm_formula_regip')?> </a>
|
|
<a href="###" onclick="medalsinsertunit(' lastip ')"> <?php echo cplang('forums_edit_perm_formula_lastip')?> </a>
|
|
<a href="###" onclick="medalsinsertunit(' buyercredit ')"> <?php echo cplang('forums_edit_perm_formula_buyercredit')?> </a>
|
|
<a href="###" onclick="medalsinsertunit(' sellercredit ')"> <?php echo cplang('forums_edit_perm_formula_sellercredit')?> </a>
|
|
<a href="###" onclick="medalsinsertunit(' digestposts ')"><?php echo $lang['setting_credits_formula_digestposts'];?></a>
|
|
<a href="###" onclick="medalsinsertunit(' posts ')"><?php echo $lang['setting_credits_formula_posts'];?></a>
|
|
<a href="###" onclick="medalsinsertunit(' threads ')"><?php echo $lang['setting_credits_formula_threads'];?></a>
|
|
<a href="###" onclick="medalsinsertunit(' oltime ')"><?php echo $lang['setting_credits_formula_oltime'];?></a>
|
|
<a href="###" onclick="medalsinsertunit(' + ')"> + </a>
|
|
<a href="###" onclick="medalsinsertunit(' - ')"> - </a>
|
|
<a href="###" onclick="medalsinsertunit(' * ')"> * </a>
|
|
<a href="###" onclick="medalsinsertunit(' / ')"> / </a>
|
|
<a href="###" onclick="medalsinsertunit(' > ')"> > </a>
|
|
<a href="###" onclick="medalsinsertunit(' >= ')"> >= </a>
|
|
<a href="###" onclick="medalsinsertunit(' < ')"> < </a>
|
|
<a href="###" onclick="medalsinsertunit(' <= ')"> <= </a>
|
|
<a href="###" onclick="medalsinsertunit(' == ')"> = </a>
|
|
<a href="###" onclick="medalsinsertunit(' (', ') ')"> ( ) </a>
|
|
<a href="###" onclick="medalsinsertunit(' and ')"> <?php echo $lang['setting_credits_formulaperm_and'];?> </a>
|
|
<a href="###" onclick="medalsinsertunit(' or ')"> <?php echo $lang['setting_credits_formulaperm_or'];?> </a> <br />
|
|
</div><div id="formulapermexp" class="marginbot diffcolor2"><?php echo $formulapermexp;?></div>
|
|
<textarea name="formulapermnew" id="formulapermnew" style="width: 80%" rows="3" onkeyup="formulaexp()" onkeydown="textareakey(this, event)"><?php echo dhtmlspecialchars($medal['permission']);?></textarea>
|
|
<br /><span class="smalltxt"><?php echo $lang['medals_permformula'];?></span>
|
|
<br /><?php echo $lang['creditwizard_current_formula_notice'];?>
|
|
<script type="text/JavaScript">formulaexp()</script>
|
|
</td></tr>
|
|
<?php
|
|
showsubmit('medaleditsubmit');
|
|
showtablefooter();
|
|
showformfooter();
|
|
|
|
} else {
|
|
if(!checkformulaperm($_GET['formulapermnew'])) {
|
|
cpmsg('forums_formulaperm_error', '', 'error');
|
|
}
|
|
|
|
$formulapermary[0] = $_GET['formulapermnew'];
|
|
$formulapermary[1] = preg_replace(
|
|
array("/(digestposts|posts|threads|oltime|extcredits[1-8])/", "/(regdate|regday|regip|lastip|buyercredit|sellercredit|field\d+)/"),
|
|
array("getuserprofile('\\1')", "\$memberformula['\\1']"),
|
|
$_GET['formulapermnew']);
|
|
$formulapermary['usergroupallow'] = $_GET['usergroupallow'];
|
|
$formulapermary['usergroups'] = (array)$_GET['usergroupsnew'];
|
|
$formulapermnew = serialize($formulapermary);
|
|
|
|
$update = array(
|
|
'type' => $_GET['typenew'],
|
|
'description' => dhtmlspecialchars($_GET['descriptionnew']),
|
|
'expiration' => intval($_GET['expirationnew']),
|
|
'permission' => $formulapermnew,
|
|
'image' => $_GET['imagenew'],
|
|
'credit' => $_GET['creditnew'],
|
|
'price' => $_GET['pricenew'],
|
|
);
|
|
if($_GET['namenew']) {
|
|
$update['name'] = dhtmlspecialchars($_GET['namenew']);
|
|
}
|
|
C::t('forum_medal')->update($medalid, $update);
|
|
|
|
updatecache('medals');
|
|
cpmsg('medals_succeed', 'action=medals&do=editmedals', 'succeed');
|
|
}
|
|
|
|
}
|
|
|
|
?>
|