header('政策管理')
->description(' ')
->body($this->grid());
}
/**
* Show interface.
*
* @param mixed $id
* @param Content $content
* @return Content
*/
public function show($id, Content $content)
{
return $content
->header('政策管理')
->description(' ')
->body($this->detail($id));
}
/**
* Edit interface.
*
* @param mixed $id
* @param Content $content
* @return Content
*/
public function edit($id, Content $content)
{
return $content
->header('政策管理')
->description(' ')
->body($this->editForm($id)->edit($id));
}
public function update($id)
{
return $this->editForm($id)->update($id);
}
/**
* Create interface.
*
* @param Content $content
* @return Content
*/
public function create(Content $content)
{
return $content
->header('政策管理')
->description(' ')
->body($this->form());
}
/**
* Make a grid builder.
*
* @return Grid
*/
protected function grid()
{
$grid = new Grid(new Policy);
$grid->id('ID');
$grid->model()->orderBy('article_order', 'DESC')->orderBy('created_at', 'DESC');
$grid->column('文章标题')->display(function () {
$style="color:".$this->tit_color.';';
if ($this->tit_b=='1') {
$style .='font-weight:bold;';
}
$cate = PolicyCategory::where(array('id'=>$this->parentid))->first();
if ($this->parentid=='0') {
$params = '?parentid='.$this->type_id;
} else {
$params = '?parentid='.$this->parentid;
}
$title_url = url(admin_base_path().'/content/policy'.$params);
$pbstr='';
if($this->is_display==0){
$pbstr= ' [已屏蔽]';
}
$title_url1 = url('content/policys/show/'.$this->id);
if ($cate) {
return $pbstr.'['.$cate->categoryname.'] '.$this->title.'';
} else {
return $pbstr.''.$this->title.'';
}
})->width(200);
$grid->policyproperty()->categoryname('政策层次');
$grid->article_order('排序');
$grid->click('点击');
$grid->created_at('添加时间');
$grid->disableCreateButton(false);
$grid->actions(function ($actions) {
$actions->disableEdit(false);
$actions->disableDelete(false);
});
$grid->tools(function ($tools) {
$tools->batch(function ($batch) {
$batch->disableDelete(false);
});
});
$grid->filter(function ($filter) {
$filter->equal('id', 'ID');
$filter->like('title', '标题');
$policy_cates = PolicyCategory::where(['parent_id'=>0])->orderBy("id", 'asc')->get()->pluck('categoryname', 'id');
$filter->where(function ($query) {
$query->where('parentid', '=', "{$this->input}")->orWhere('type_id', '=', "{$this->input}");
}, '政策分类', 'parentid')->select($policy_cates);
$policy_propertys = PolicyProperty::select()->orderBy("id", 'asc')->get()->pluck('categoryname', 'id');
$filter->where(function ($query) {
$query->where('focos', '=', "{$this->input}");
}, '政策层次', 'focos')->select($policy_propertys);
$date3 = date('Y-m-d', strtotime("-3 day"));
$date7 = date('Y-m-d', strtotime("-7 day"));
$date30 = date("Y-m-d", strtotime("-1 month"));
$date180 = date("Y-m-d", strtotime("-6 month"));
$date360 = date("Y-m-d", strtotime("-1 year"));
$date_option = array(
'' => '不限',
$date3 => '三天内',
$date7 => '一周内',
$date30 => '一月内',
$date180 => '半年内',
$date360 => '一年内',
);
$filter->where(function ($query) {
$query->where('created_at', '>=', "{$this->input}");
}, '添加时间', 'created_at')->radio($date_option);
});
return $grid;
}
/**
* Make a show builder.
*
* @param mixed $id
* @return Show
*/
protected function detail($id)
{
$show = new Show(Policy::findOrFail($id));
$show->id('ID');
$show->created_at('Created at');
$show->updated_at('Updated at');
return $show;
}
/**
* Make a form builder.
*
* @return Form
*/
protected function form()
{
$form = new Form(new Policy);
$form->text('title', '标题')->rules('required|max:100', array('required'=>'标题不能为空。','max'=>'标题长度不能大于100。'))->setWidth(4)->setMustMark();
$form->color('tit_color', '标题颜色')->rules('required|regex:/^#[a-fA-F0-9]{6}$/', array('required'=>'标题颜色不能为空。','regex'=>'标题颜色格式不正确。'))->default('#000000');
$cate_option = PolicyCategory::selectOptions(function ($query) {
return $query->orderBy('category_order', 'desc')->orderBy('created_at', 'desc');
});
unset($cate_option[0]);
$form->select('type_id', '政策分类')->options($cate_option)->default(key($cate_option))->rules('required', array('required'=>'请选择政策分类。'))->setWidth(4)->setMustMark();
$policyProperty = PolicyProperty::select()->pluck('categoryname', 'id');
// $policyProperty[0] ='不限';
$arr = array(
'1' => 'RC_category_fj',
'2' => 'RC_category_qz',
'7' => 'RC_category_jj',
'8' => 'RC_category'
);
$form->select('focos', '政策层次')->options($policyProperty)->load('level_ids', admin_base_path('/content/policys/treats/category'))->rules("required")->setMustMark();
$form->multipleSelect('level_ids', '面向人才')->rules(['required'], ['required'=>'请填写面向人才'])->setMustMark();
$form->image('small_img', '缩略图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', array('image'=>'缩略图请选择图片文件。','mimes'=>'请选择jpeg,bmp,png格式的缩略图上传。'))->setWidth(3);
$form->editor('content', '内容')->rules('required', array('required'=>'内容不能为空。'))->setMustMark();
$display_option = [
'on' => ['value' => 1, 'text' => '是', 'color' => 'success'],
'off' => ['value' => 0, 'text' => '否', 'color' => 'danger'],
];
$form->switch('is_display', '是否显示')->default(1)->states($display_option)->setMustMark();
$form->switch('tit_b', '标题加粗')->states($display_option)->setMustMark();
// $form->date('addtime', '发布日期')->format('YYYY-MM-DD')->rules('required|date', array('required'=>'发布日期不能为空。', 'date'=>'发布日期格式不正确。'));
$form->number('article_order', '新闻排序')->min(0)->default(255)->rules('required', array('required'=>'新闻排序不能为空。'))->help('(数字越大越靠前)');
$form->text('author', '作者')->rules('max:20', array('max'=>'作者长度不能大于20。'))->setWidth(3);
$form->text('source', '来源')->rules('max:20', array('max'=>'来源长度不能大于20。'))->setWidth(3);
$form->url('is_url', '外部链接')->rules('max:250', array('max'=>'外部链接长度不能超过250。'))->help('(请输入包含http://或https://的完整链接)');
$form->text('seo_keywords', 'Keywords')->placeholder('合理设置Keywords有利于搜索引擎排名')->rules('max:80', array('max:Keywords不能大于80个字符。'));
$form->textarea('seo_description', 'Description')->placeholder('合理设置Description有利于搜索引擎排名')->rules('max:80', array('max'=>'Description不能大于80个字符。'));
$form->hidden('addtime');//添加时间
$form->hidden('parentid');//政策大类
$form->hidden('level_name');//面向人才
$form->hidden('level_id');//面向人才
$form->ignore(['level_ids']);
$form->saving(function (Form $form){
//设置添加时间
$form->addtime=time();
// 设置政策大类
$policyCategory= PolicyCategory::where(['id'=>$form->type_id])->first();
if($policyCategory->parent_id==0){
$form->parentid=$form->type_id;
}else{
$form->parentid=$policyCategory->parent_id;
}
$level_id= Input::get('level_ids');
$level_id = array_filter($level_id);
$form->level_id=implode(',',$level_id);
$levels=Category::whereIn('id',$level_id)->select('demand')->get()->toArray();
$form->level_name=implode(",", array_column($levels, 'demand'));
});
return $form;
}
protected function editForm($id)
{
$form = new Form(new Policy);
$policyData = Policy::where('id', $id)->first()->toArray();
$form->text('title', '标题')->rules('required|max:100', array('required'=>'标题不能为空。','max'=>'标题长度不能大于100。'))->setWidth(4)->setMustMark();
$form->color('tit_color', '标题颜色')->rules('required|regex:/^#[a-fA-F0-9]{6}$/', array('required'=>'标题颜色不能为空。','regex'=>'标题颜色格式不正确。'))->default('#000000');
$cate_option = PolicyCategory::selectOptions(function ($query) {
return $query->orderBy('category_order', 'desc')->orderBy('created_at', 'desc');
});
unset($cate_option[0]);
$form->select('type_id', '政策分类')->options($cate_option)->default(key($cate_option))->rules('required', array('required'=>'请选择政策分类。'))->setWidth(4)->setMustMark();
$policyProperty = PolicyProperty::select()->pluck('categoryname', 'id');
// $policyProperty[0] ='不限';
$arr = array(
'1' => 'RC_category_fj',
'2' => 'RC_category_qz',
'7' => 'RC_category_jj',
'8' => 'RC_category'
);
$form->select('focos', '政策层次')->options($policyProperty)->load('level_ids', admin_base_path('/content/policys/treats/category'))->rules("required")->setMustMark();
$form->multipleSelect('level_ids', '面向人才')->options(Category::categoryType($arr[$policyData['focos']]))->default(explode(",", $policyData['level_id']))->rules(['required'], ['required'=>'请填写面向人才'])->setMustMark();
$form->image('small_img', '缩略图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', array('image'=>'缩略图请选择图片文件。','mimes'=>'请选择jpeg,bmp,png格式的缩略图上传。'))->setWidth(3);
$form->editor('content', '内容')->rules('required', array('required'=>'内容不能为空。'))->setMustMark();
$display_option = [
'on' => ['value' => 1, 'text' => '是', 'color' => 'success'],
'off' => ['value' => 0, 'text' => '否', 'color' => 'danger'],
];
$form->switch('is_display', '是否显示')->states($display_option)->setMustMark();
$form->switch('tit_b', '标题加粗')->states($display_option)->setMustMark();
// $form->date('created_at', '发布日期')->format('YYYY-MM-DD')->rules('required|date', array('required'=>'发布日期不能为空。', 'date'=>'发布日期格式不正确。'));
$form->number('article_order', '新闻排序')->min(0)->default(0)->rules('required', array('required'=>'新闻排序不能为空。'))->help('(数字越大越靠前)');
$form->text('author', '作者')->rules('max:20', array('max'=>'作者长度不能大于20。'))->setWidth(3);
$form->text('source', '来源')->rules('max:20', array('max'=>'来源长度不能大于20。'))->setWidth(3);
$form->url('is_url', '外部链接')->rules('max:250', array('max'=>'外部链接长度不能超过250。'))->help('(请输入包含http://或https://的完整链接)');
$form->text('seo_keywords', 'Keywords')->placeholder('合理设置Keywords有利于搜索引擎排名')->rules('max:80', array('max:Keywords不能大于80个字符。'));
$form->textarea('seo_description', 'Description')->placeholder('合理设置Description有利于搜索引擎排名')->rules('max:80', array('max'=>'Description不能大于80个字符。'));
$form->hidden('addtime');//添加时间
$form->hidden('parentid');//政策大类
$form->hidden('level_name');//面向人才
$form->hidden('level_id');//面向人才
$form->ignore(['level_ids']);
$form->saving(function (Form $form){
//设置政策大类
$policyCategory= PolicyCategory::where(['id'=>$form->type_id])->first();
if($policyCategory->parent_id==0){
$form->parentid=$form->type_id;
}else{
$form->parentid=$policyCategory->parent_id;
}
$level_id= Input::get('level_ids');
$level_id = array_filter($level_id);
$form->level_id=implode(',',$level_id);
$levels=Category::whereIn('id',$level_id)->select('demand')->get()->toArray();
$form->level_name=implode(",", array_column($levels, 'demand'));
});
return $form;
}
public function destroy($id)
{
$ids = array();
if ($id) {
$ids = explode(',', $id);
}
if (!$ids) {
return admin_toastr('请勾选需要删除的政策', 'error');
}
\DB::beginTransaction();
try {
Policy::whereIn('id', $ids)->delete();
$data = [
'status' => true,
'message' => '删除成功!',
];
\DB::commit();
return response()->json($data);
} catch (\Exception $e) {
\DB::rollback();
$data = [
'status' => false,
'message' => '删除失败!',
];
return response()->json($data);
}
}
}