📄 ad_profilefields.php
字号:
<?php
class ad_fields
{
var $base_url;
function ad_fields( )
{
global $IN;
global $INFO;
global $DB;
global $SKIN;
global $ADMIN;
global $std;
global $MEMBER;
global $GROUP;
$tmp_in = array_merge( $_GET, $_POST, $_COOKIE );
foreach ( $tmp_in as $k => $v )
{
}
switch ( $IN['code'] )
{
case "add" :
$this->main_form( "add" );
break;
case "doadd" :
$this->main_save( "add" );
break;
case "edit" :
$this->main_form( "edit" );
break;
case "doedit" :
$this->main_save( "edit" );
break;
case "delete" :
$this->delete_form( );
break;
case "dodelete" :
$this->do_delete( );
break;
default :
$this->main_screen( );
break;
}
}
function delete_form( )
{
global $IN;
global $INFO;
global $DB;
global $SKIN;
global $ADMIN;
global $std;
global $MEMBER;
global $GROUP;
if ( $IN['id'] == "" )
{
$ADMIN->error( "无法找到用户团队ID,请重试!" );
}
$ADMIN->page_title = "删除用户定制数据";
$ADMIN->page_detail = "在删除用户定制数据前请仔细检查。<b>删除后所有数据将丢失!</b>.";
$DB->query( "SELECT ftitle, fid FROM ibf_pfields_data WHERE fid='".$IN['id']."'" );
if ( !( $field = $DB->fetch_row( ) ) )
{
$ADMIN->error( "无法从数据库中取出数据" );
}
$ADMIN->html .= $SKIN->start_form( array(
1 => array( "code", "dodelete" ),
2 => array( "act", "field" ),
3 => array(
"id",
$IN['id']
)
) );
$SKIN->td_header[] = array( " ", "40%" );
$SKIN->td_header[] = array( " ", "60%" );
$ADMIN->html .= $SKIN->start_table( "删除确认" );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>需要删除的用户信息数据</b>",
"<b>".$field['ftitle']."</b>"
) );
$ADMIN->html .= $SKIN->end_form( "删除用户定制数据" );
$ADMIN->html .= $SKIN->end_table( );
$ADMIN->output( );
}
function do_delete( )
{
global $IN;
global $INFO;
global $DB;
global $SKIN;
global $ADMIN;
global $std;
global $MEMBER;
global $GROUP;
if ( $IN['id'] == "" )
{
$ADMIN->error( "无法找到用户信息数据ID,请重试!" );
}
$DB->query( "SELECT ftitle, fid FROM ibf_pfields_data WHERE fid='".$IN['id']."'" );
if ( !( $row = $DB->fetch_row( ) ) )
{
$ADMIN->error( "无法找到用户信息数据ID,请重试!" );
}
$DB->query( "ALTER TABLE ibf_pfields_content DROP field_{$row['fid']}" );
$DB->query( "DELETE FROM ibf_pfields_data WHERE fid='".$IN['id']."'" );
$ADMIN->done_screen( "用户信息已经删除", "用户信息定制", "act=field" );
}
function main_save( $type = "edit" )
{
global $IN;
global $INFO;
global $DB;
global $SKIN;
global $ADMIN;
global $std;
global $MEMBER;
global $GROUP;
global $HTTP_POST_VARS;
if ( $IN['ftitle'] == "" )
{
$ADMIN->error( "你必须输入一个用户信息名称。" );
}
if ( $type == "edit" && $IN['id'] == "" )
{
$ADMIN->error( "无法找到用户信息数据ID,请重试!" );
}
$content = "";
if ( $HTTP_POST_VARS['fcontent'] != "" )
{
$content = str_replace( "\n", "|", str_replace( "\n\n", "\n", trim( $HTTP_POST_VARS['fcontent'] ) ) );
}
$db_string = array(
"ftitle" => $IN['ftitle'],
"fdesc" => $IN['fdesc'],
"fcontent" => stripslashes( $content ),
"ftype" => $IN['ftype'],
"freq" => $IN['freq'],
"fhide" => $IN['fhide'],
"fmaxinput" => $IN['fmaxinput'],
"fedit" => $IN['fedit'],
"forder" => $IN['forder'],
"fshowreg" => $IN['fshowreg']
);
if ( $type == "edit" )
{
$rstring = $DB->compile_db_update_string( $db_string );
$DB->query( "UPDATE ibf_pfields_data SET {$rstring} WHERE fid='".$IN['id']."'" );
$ADMIN->done_screen( "用户信息已经修改", "用户信息定制", "act=field" );
}
else
{
$rstring = $DB->compile_db_insert_string( $db_string );
$DB->query( "INSERT INTO ibf_pfields_data (".$rstring['FIELD_NAMES'].") VALUES (".$rstring['FIELD_VALUES'].")" );
$new_id = $DB->get_insert_id( );
$DB->query( "ALTER TABLE ibf_pfields_content ADD field_{$new_id} text default ''" );
$DB->query( "OPTIMIZE TABLE ibf_pfields_content" );
$ADMIN->done_screen( "用户信息已经添加", "用户信息定制", "act=field" );
}
}
function main_form( $type = "edit" )
{
global $IN;
global $INFO;
global $DB;
global $SKIN;
global $ADMIN;
global $std;
global $MEMBER;
global $GROUP;
if ( $type == "edit" )
{
if ( $IN['id'] == "" )
{
$ADMIN->error( "无法找到用户团队ID,请重试!" );
}
$form_code = "doedit";
$button = "完成编辑";
}
else
{
$form_code = "doadd";
$button = "添加字段";
}
if ( $IN['id'] != "" )
{
$DB->query( "SELECT * FROM ibf_pfields_data WHERE fid='".$IN['id']."'" );
$fields = $DB->fetch_row( );
}
else
{
$fields = array( );
}
if ( $type == "edit" )
{
$ADMIN->page_title = "编辑用户信息数据:".$fields['ftitle'];
}
else
{
$ADMIN->page_title = "添加新用户信息数据";
$fields['ftitle'] = "";
}
$ADMIN->page_detail = "在提交表单数据前,请双击用户信息。";
$ADMIN->html .= $SKIN->start_form( array(
1 => array(
"code",
$form_code
),
2 => array( "act", "field" ),
3 => array(
"id",
$IN['id']
)
) );
$fields['fcontent'] = str_replace( "|", "\n", $fields['fcontent'] );
$SKIN->td_header[] = array( " ", "40%" );
$SKIN->td_header[] = array( " ", "60%" );
$ADMIN->html .= $SKIN->start_table( "用户信息数据设置" );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>用户信息数据名称:</b><br>最多允许字符:200",
$SKIN->form_input( "ftitle", $fields['ftitle'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>用户信息数据叙述:</b><br>最多允许字符:250<br>可以对用户输入进行提示作用",
$SKIN->form_input( "fdesc", $fields['fdesc'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>用户信息数据类型:</b>",
$SKIN->form_dropdown( "ftype", array(
0 => array( "text", "文本输入区域" ),
1 => array( "drop", "下拉菜单选项" ),
2 => array( "area", "文本输入表框" )
), $fields['ftype'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>最大输入字节(当选择'文本输入区域'和'文本输入表框' 选项时使用)</b>",
$SKIN->form_input( "fmaxinput", $fields['fmaxinput'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>显示顺序(编辑和显示用户信息数据的位置,1 - 表示最后显示)",
$SKIN->form_input( "forder", $fields['forder'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>下拉菜单选项内容(选择 下拉菜单 选项时使用)</b><br>注:每行只能填写一个选项<br>例如:'用户性别' 选项设置<br>m=帅哥<br>f=美女<br>u=保密<br>系统将自动生成:<br><select name='pants'><option value='m'>帅哥</option><option value='f'>美女</option><option value='u'>保密</option></select><br>m,f 和 u 自动最为变量保存在数据库中,当查看用户资料信息时自动转换数据库中的变量为设定的参数(例如:f=美女,将显示'美女')",
$SKIN->form_textarea( "fcontent", $fields['fcontent'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>是否在用户注册页面显示此数据?</b>",
$SKIN->form_yes_no( "fshowreg", $fields['fshowreg'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>用户数据选项是否为必填?</b><br>(如果在下面的选项中选择隐藏,此选项将无效)",
$SKIN->form_yes_no( "freq", $fields['freq'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>是否隐藏用户信息数据?</b><br>如果'是',只有论坛管理员和版主才能查看。",
$SKIN->form_yes_no( "fhide", $fields['fhide'] )
) );
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>是否允许用户进行编辑?</b><br>如果选择'否',只有论坛管理员和版主才能查看。",
$SKIN->form_yes_no( "fedit", $fields['fedit'] )
) );
$ADMIN->html .= $SKIN->end_form( $button );
$ADMIN->html .= $SKIN->end_table( );
$ADMIN->output( );
}
function main_screen( )
{
global $IN;
global $INFO;
global $DB;
global $SKIN;
global $ADMIN;
global $std;
global $MEMBER;
global $GROUP;
$ADMIN->page_title = "用户信息定制设置";
$ADMIN->page_detail = "用户信息定制设置功能可以让你为注册页面等添加额外的用户信息选项。这样可以帮助你更有效的收集你需要的用户资料。";
$SKIN->td_header[] = array( "用户信息名称", "25%" );
$SKIN->td_header[] = array( "用户信息类型", "20%" );
$SKIN->td_header[] = array( "必填", "10%" );
$SKIN->td_header[] = array( "隐藏", "10%" );
$SKIN->td_header[] = array( "在注册时显示", "15%" );
$SKIN->td_header[] = array( "编辑", "10%" );
$SKIN->td_header[] = array( "删除", "10%" );
$ADMIN->html .= $SKIN->start_table( "用户信息定制管理" );
$real_types = array( "drop" => "下拉菜单选项", "area" => "文本输入表框", "text" => "文本输入区域" );
$DB->query( "SELECT * FROM ibf_pfields_data" );
if ( $DB->get_num_rows( ) )
{
while ( $r = $DB->fetch_row( ) )
{
$hide = " ";
$req = " ";
$regi = " ";
"<center><a href='{$ADMIN->base_url}&act=group&code=delete&id=".$r['g_id']."'>删除</a></center>";
if ( $r['fhide'] == 1 )
{
$hide = "<center><span style=\"color:red\">是</span></center>";
}
if ( $r['freq'] == 1 )
{
$req = "<center><span style=\"color:red\">是</span></center>";
}
if ( $r['fshowreg'] == 1 )
{
$regi = "<center><span style=\"color:red\">是</span></center>";
}
$ADMIN->html .= $SKIN->add_td_row( array(
"<b>{$r['ftitle']}</b>",
"<center>{$real_types[$r['ftype']]}</center>",
$req,
$hide,
$regi,
"<center><a href='{$ADMIN->base_url}&act=field&code=edit&id=".$r['fid']."'>编辑</a></center>",
"<center><a href='{$ADMIN->base_url}&act=field&code=delete&id=".$r['fid']."'>删除</a></center>"
) );
}
}
else
{
$ADMIN->html .= $SKIN->add_td_basic( "没有找到", "center", "tdrow2" );
}
$ADMIN->html .= $SKIN->add_td_basic( "<a href='{$ADMIN->base_url}&act=field&code=add'>添加用户信息数据</a></center>", "center", "title" );
$ADMIN->html .= $SKIN->end_table( );
$ADMIN->output( );
}
}
ad_fields( );
$idx = new ad_fields( );
?>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -