www.gusucode.com > 08CMS空白站群系统 3.3 繁体 UTF-8 > upload/include/fields/mselect.php

    <?php
(!defined('M_COM') || !defined('M_ADMIN')) && exit('No Permission');
$datatype = 'mselect';
if(!$fsave){
	trbasic(lang('field type'),'',$datatypearr[$datatype],'');
	if($fnew) echo "<input type=\"hidden\" name=\"fieldnew[datatype]\" value=\"$datatype\">\n";
	trbasic(lang('field cname'),'fieldnew[cname]',empty($field['cname']) ? '' : $field['cname']);
	$submitstr .= makesubmitstr('fieldnew[cname]',1,0,0,30);
	trbasic(lang('field ename'),$fnew ? 'fieldnew[ename]' : '',empty($field['ename']) ? '' : $field['ename'],$fnew ? 'text' : '');
	if($fnew) $submitstr .= makesubmitstr('fieldnew[ename]',1,'tagtype',0,15);
	trbasic(lang('table field length'),'fieldnew[length]',empty($field['length']) ? '' : $field['length'],'text',lang('agtlength'));
	empty($field['issystem']) && trbasic(lang('input notnull'),'fieldnew[notnull]',empty($field['notnull']) ? 0 : $field['notnull'],'radio');
	trbasic(lang('form guide'),'fieldnew[guide]',empty($field['guide']) ? '' : $field['guide'],'btext',lang('agguide'));
	$submitstr .= makesubmitstr('fieldnew[guide]',0,0,0,80);
	trbasic(lang('default input value'),'fieldnew[vdefault]',empty($field['vdefault']) ? '' : str_replace("\t",'[##]',$field['vdefault']),'btext',lang('agmselectsplit'));
	trbasic(lang('controller mode'),'',makeradio('fieldnew[mode]',array(0 => lang('mchoise list'),1 => lang('mchoise box').'(checkbox)'),empty($field['mode']) ? 0 : 1),'');
	$submitstr .= makesubmitstr('fieldnew[length]',0,'int',0,3);
	if(in_array($fmode,array('a','i')) && ($fnew || !empty($field['iscustom']))){
		$issearcharr = array('0' => lang('nosearch'),'1' => lang('onesearch'),'2' => lang('multisearch'));
		trbasic(lang('issearch'),'fieldnew[issearch]',makeoption($issearcharr,empty($field['issearch']) ? '0' : $field['issearch']),'select');
	}
	trbasic(lang('choose content setting'),'fieldnew[innertext]',empty($field['innertext']) ? '' : $field['innertext'],'textarea');

}else{
	$sqlstr = empty($fconfigarr['sqlstr']) ? "" : $fconfigarr['sqlstr'];
	$fieldnew['cname'] = trim(strip_tags($fieldnew['cname']));
	if($fnew){
		$filterstr = empty($fconfigarr['filterstr']) ? "/[^a-zA-Z_0-9]+|^[0-9_]+/" : $fconfigarr['filterstr'];
		(empty($fieldnew['ename']) || empty($fieldnew['cname'])) && amessage(lang('field data missing'),$fconfigarr['errorurl']);
		preg_match($filterstr,$fieldnew['ename']) && amessage(lang('field ename illegal'),$fconfigarr['errorurl']);
		$fieldnew['ename'] = strtolower($fieldnew['ename']);
		in_array($fieldnew['ename'], $fconfigarr['enamearr']) && amessage(lang('field ename repeat'),$fconfigarr['errorurl']);
		in_array($fieldnew['ename'], $fieldwords) && amessage(lang('field ename notuse'),$fconfigarr['errorurl']);
		$fieldnew['length'] = empty($fieldnew['length']) ? 10 : min(255,max(1,intval($fieldnew['length'])));
		$db->query("ALTER TABLE $fconfigarr[altertable] ADD $fieldnew[ename] varchar($fieldnew[length]) NOT NULL default ''");
	}else{
		$fieldnew['cname'] = empty($fieldnew['cname']) ? $field['cname'] : $fieldnew['cname'];
		if(isset($fieldnew['length'])){
			$fieldnew['length'] = empty($fieldnew['length']) ? 10 : min(255,max(1,intval($fieldnew['length'])));
			if($field['length'] != $fieldnew['length']){
				$db->query("ALTER TABLE $fconfigarr[altertable] CHANGE $field[ename] $field[ename] varchar($fieldnew[length]) NOT NULL default ''");
			}
		}
	}
	isset($fieldnew['innertext']) && $fieldnew['innertext'] = str_replace("\r","",$fieldnew['innertext']);
	$fieldnew['guide'] = empty($fieldnew['guide']) ? '' : trim($fieldnew['guide']);
	$fieldnew['vdefault'] = empty($fieldnew['vdefault']) ? '' : trim($fieldnew['vdefault']);
	$fieldnew['vdefault'] = str_replace('[##]',"\t",$fieldnew['vdefault']);
	foreach(array('datatype','ename','length','cname','notnull','nohtml','mode','guide','mlimit','rpid','issearch','innertext','min','max','regular','vdefault') as $var){
		isset($fieldnew[$var]) && $sqlstr .= (!$sqlstr ? '' : ',')."$var='".$fieldnew[$var]."'";
	}
	if($fnew){
		$db->query("INSERT INTO $fconfigarr[fieldtable] SET $sqlstr");
	}else{
		$wherestr = empty($fconfigarr['wherestr']) ? "WHERE ename='$field[ename]'" : $fconfigarr['wherestr'];
		$db->query("UPDATE $fconfigarr[fieldtable] SET $sqlstr $wherestr");
	}
}
?>