| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560 | <?php$audit = Dever::config('base')->audit;$status = Dever::config('base')->status;$function = Dever::config('base')->function;# 每页的数据量$page = 15;$cate = function(){	$array = array();	$info = Dever::db('content/cate')->state();	if($info)	{		$array += $info;	}	return $array;};$author = function(){	$array = array();	$info = Dever::db('content/author')->state();	if($info)	{		$array += $info;	}	return $array;};$share = function(){	$array = array();	$info = Dever::db('poster/template')->state();	if($info)	{		$array += $info;	}	return $array;};$share = array(	1 => '显示',	2 => '不显示',);$wechat = array(	1 => '否',	2 => '是',);# 常用的col$col = 'id,cate_id,name,pic_cover,pdate,num_add_view+num_view as num_view,num_up+num_add_up as num_up,num_comment,share_yes,share_title,share_pic,share_content,function,content,author_id';return array(	# 表名	'name' => 'article',	# 显示给用户看的名称	'lang' => '图文管理',	'order' => 100,	# 同步更新另外一个或多个表的数据	'syncone' => array	(		'audit/data' => array		(			# 更新另外一个表的字段 => 本表的字段			'where' => array('data_id' => 'id', 'type' => 1),			# 要更新的数据			'update' => array('data_id' => 'id', 'type' => 1, 'pdate' => 'pdate', 'reorder' => 'reorder', 'name' => 'name', 'audit' => 'audit', 'status' => 'status', 'cate_id' => 'cate_id'),		)	),	'end' => array	(		'insert' => 'tag/lib/core.data?source_table=content/article',		'update' => 'tag/lib/core.data?source_table=content/article',	),	# 数据结构	'struct' => array	(		'id' 		=> array		(			'type' 		=> 'int-11',			'name' 		=> 'ID',			'default' 	=> '',			'desc' 		=> '',			'match' 	=> 'is_numeric',			//'list'		=> true,		),				'name'		=> array		(			'type' 		=> 'varchar-80',			'name' 		=> '标题',			'default' 	=> '',			'desc' 		=> '标题',			'match' 	=> 'is_string',			'update'	=> 'text',			'list'		=> true,			'search'	=> 'fulltext',			//增加预览			'preview'	=> true,		),				'cate_id'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '所属栏目',			'default' 	=> '1',			'desc' 		=> '所属栏目',			'match' 	=> 'is_numeric',			'update'	=> 'select',			'option'	=> $cate,			'search'	=> 'select',		),		'author_id'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '作者',			'default' 	=> '1',			'desc' 		=> '作者',			'match' 	=> 'is_numeric',			'update'	=> 'select',			'option'	=> $author,			'search'	=> 'select',		),		'wechat'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '是否公众号文章',			'default' 	=> '1',			'desc' 		=> '是否公众号文章',			'match' 	=> 'is_numeric',			//'update'	=> 'select',			'option'	=> $wechat,			'search'	=> 'select',		),		'wechat_data_id'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '微信数据id',			'default' 	=> '0',			'desc' 		=> '微信数据id',			'match' 	=> 'is_numeric',		),		'tag'		=> array		(			'type' 		=> 'text-255',			'name' 		=> '标签',			'default' 	=> '',			'desc' 		=> '标签',			'match' 	=> 'is_numeric',			'update'	=> 'selects',			//'search'	=> 'fulltext',			'update_search'	=> 'tag/lib/core.search',		),  		'pic_cover'		=> array		(			'type' 		=> 'varchar-150',			'name' 		=> '封面图-4:3比例的图片',			'default' 	=> '',			'desc' 		=> '封面图',			'match' 	=> 'option',			'update'	=> 'image',			'key' 		=> '1',			'place'		=> '150',			//直接上传到云端			//'upload'	=> 'qiniu',			//上传大数据			//'large' 	=> true,		),		'num_add_view'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '浏览量基数',			'default' 	=> '0',			'desc' 		=> '浏览量基数',			'match' 	=> 'option',			'update'	=> 'text',		),		'num_view'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '浏览量pv',			'default' 	=> '0',			'desc' 		=> '请填写浏览量pv',			'match' 	=> 'option',			'search'	=> 'order',			//'list'		=> '{num_view}+{num_add_view}',		),		'num_add_up'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '喜欢基数',			'default' 	=> '0',			'desc' 		=> '喜欢基数',			'match' 	=> 'option',			'update'	=> 'text',		),				'num_up'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '喜欢数',			'default' 	=> '0',			'desc' 		=> '请填写喜欢数',			'match' 	=> 'option',			//'search'	=> 'order',			'list'		=> '"喜欢数:{num_up}+{num_add_up}<br />浏览量:{num_view}+{num_add_view}<br />评论数:{num_comment}<br />"',			'list_name'	=> '统计数字',		),		'num_comment'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '评论数',			'default' 	=> '0',			'desc' 		=> '请填写评论数',			'search'	=> 'order',			'match' 	=> 'option',			//'list'		=> true,		),		'state'		=> array		(			'type' 		=> 'tinyint-1',			'name' 		=> '状态',			'default' 	=> '1',			'desc' 		=> '请选择状态',			'match' 	=> 'is_numeric',		),		'admin_founder'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '创建人',			'default' 	=> '1',			'desc' 		=> '创建人',			'match' 	=> 'is_numeric',		),		'admin_editor'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '操作人',			'default' 	=> '1',			'desc' 		=> '操作人',			'match' 	=> 'is_numeric',		),		'pdate'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '发布时间',			'match' 	=> array('is_numeric', time()),			'default'	=> '',			'desc' 		=> '',			'update'	=> 'date',			'callback'	=> 'maketime',			'insert'	=> true,			//'list'		=> 'date("Y-m-d H:i:s", {pdate})',			'auth'		=> '"{pdate}" > 0',		),		'share'		=> array		(			'type' 		=> 'text-255',			'name' 		=> '分享海报-选择海报库中的海报',			'default' 	=> '',			'desc' 		=> '分享海报',			'match' 	=> 'option',			//'update'	=> 'checkbox',			'option'	=> $share,		),		'reorder'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '排序(数值越大越靠前)',			'default' 	=> '1',			'desc' 		=> '请输入排序',			'match' 	=> 'option',			'update'	=> 'text',			'search'	=> 'order',			'list'		=> true,			'order'		=> 'desc',			'edit'		=> true,		),		'udate'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '更新时间',			'match' 	=> array('is_numeric', time()),			'desc' 		=> '',		),		'function'		=> array		(			'type' 		=> 'varchar-100',			'name' 		=> '功能选择',			'default' 	=> '1',			'desc' 		=> '功能选择',			'match' 	=> 'option',			'update'	=> 'checkbox',			'option'	=> $function,		),		'share_yes'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '是否显示分享按钮',			'default' 	=> '1',			'desc' 		=> '是否显示分享按钮',			'match' 	=> 'option',			'update'	=> 'radio',			'option'	=> $share,			'control'	=> 'share_yes',		),		'share_title'		=> array		(			'type' 		=> 'varchar-100',			'name' 		=> '分享标题',			'default' 	=> '',			'desc' 		=> '分享标题',			'match' 	=> 'option',			'update'	=> 'text',			'show'		=> 'share_yes=1',		),		'share_pic'		=> array		(			'type' 		=> 'varchar-150',			'name' 		=> '分享图片',			'default' 	=> '',			'desc' 		=> '分享图片',			'match' 	=> 'option',			'update'	=> 'image',			'key' 		=> '1',			'place'		=> '150',			'show'		=> 'share_yes=1',			'upload'	=> 'qiniu',			'large' 	=> true,		),		'share_content'		=> array		(			'type' 		=> 'varchar-200',			'name' 		=> '分享内容',			'default' 	=> '',			'desc' 		=> '分享内容',			'match' 	=> 'option',			'update'	=> 'textarea',			'show'		=> 'share_yes=1',		),		'content'		=> array		(			'type' 		=> 'text-255',			'name' 		=> '内容',			'default' 	=> '',			'desc' 		=> '请输入内容',			'match' 	=> 'is_string',			'update'	=> 'editor',			'key'		=> '1',			//'media'		=> '5',//下面的音视频已经做到了			//直接上传到云端			//'upload'	=> 'qiniu',			//上传大数据			//'large' 	=> true,			//自定义编辑器右侧按钮			'editor'	=> array			(				'name' => '选择插入模块',				'button' => array				(					array					(						# 名称						'name' => '图片',						# 资源库id						'key' => 1,						# 类型						'type' => 'image',					),					array					(						'name' => '音视频',						'key' => 5,						'type' => 'media',					),					array					(						'name' => '视频',						'key' => 'video/lib/core.vod',					),					array					(						'name' => '直播',						'key' => 'video/lib/core.live',					),				),			),		),		'audit'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '审核状态',			'default' 	=> '1',			'desc' 		=> '审核',			'match' 	=> 'is_numeric',			//'update'	=> 'select',			'option'	=> $audit,			'search'	=> 'select',			'list'		=> true,			'edit'		=> true,		),		'status'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '发布状态',			'default' 	=> '1',			'desc' 		=> '发布状态',			'match' 	=> 'is_numeric',			//'update'	=> 'select',			'option'	=> $status,			'search'	=> 'select',			'list'		=> true,			'edit'		=> true,		),		'cdate'		=> array		(			'type' 		=> 'int-11',			'name' 		=> '录入时间',			'match' 	=> array('is_numeric', time()),			'desc' 		=> '',			# 只有insert时才生效			'insert'	=> true,		),	),	# 索引	'index' => array	(		'version' => 1,				1 => array		(			'i1' => 'uid,cate_id',		)	),		# 管理功能	'manage' => array	(		//'insert' => false,		# 列表		'list_button' => array		(			'edit' => array('预览', Dever::url('main/preview.get?type=1')),		),	),	# request 请求接口定义	'request' => array	(		'search' => array		(			# 匹配的正则或函数 选填项			'option' => array			(				'ids' => array('yes-id', 'in'),				'cate_id' => 'yes',				'name' => array('yes', 'like'),				'id' => 'yes',				'state' => 1,			),			'type' => 'all',			'order' => array('reorder' => 'desc', 'id' => 'desc'),			'limit' => '0,1000',			'col' => 'name as name, id, id as value, "" as selected, "" as disabled|id',		),		'getAll' => array		(			# 匹配的正则或函数 选填项			'option' => array			(				'cate_id' => 'yes',				'cate_ids' => array('yes-cate_id', 'in'),				'id' => 'yes',				'state' => 1,			),			'type' => 'all',			'order' => array('reorder' => 'desc','id' => 'desc'),			'page' => array($page, 'list'),			'col' => $col,		),		'getRelation' => array		(			# 匹配的正则或函数 选填项			'option' => array			(				'cate_id' => 'yes',				'cate_ids' => array('yes-cate_id', 'in'),				'noid' => array('yes-id', '!='),				'state' => 1,			),			'type' => 'all',			'order' => array('reorder' => 'desc','id' => 'desc'),			'limit' => '0,4',			'col' => $col,		),		'getOne' => array		(			# 匹配的正则或函数 选填项			'where' => array			(				'id' => 'yes',			),			'type' => 'one',			'col' => $col,		),				# 更新浏览量		'addView' => array		(			'type' => 'update',			'where' => array			(				'id' => 'yes',			),			'set' => array			(				'num_view' => array('1', '+='),			),		),	),);
 |