123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381 |
- <?php
- namespace app\admin\controller\field;
- use app\admin\BaseController;
- use think\facade\Db;
- use think\facade\View;
- use app\admin\model\Fieldrules as FieldrulesModel;
- use app\admin\model\CostProject as CostprojectModel;
- use app\admin\model\Admin as AdminModel;
- class Fieldcompany extends BaseController{
- protected $FeildrulesModel;
- protected $CostprojectModel;
- public function initialize(){
- parent::initialize();
- $this->AdminModel = new AdminModel;
- $this->FieldrulesModel = new FieldrulesModel;
- $this->CostprojectModel = new CostprojectModel;
- }
- public function add(){
- if(request()->isAjax()){
- $param = get_params();
- if (!empty($param['id']) && $param['id'] > 0) { //编辑
- $id = $param['id'];
- unset($param['id']);
- $param_1 = array();
- $param_2 = array();
- foreach($param as $key => $value){
- if(strripos($key, '_edit')){
- $param_2[$key] = $value;
- }else{
- $param_1[$key] = $value;
- }
- }
- $data[] = array();
- $field_data = json_encode($param_1);
- $field_data_edit = json_encode($param_2);
- $operator_nickname = get_login_admin('nickname');
- $data = [
- 'field_rules' => $field_data,
- 'field_edit_rules' => $field_data_edit,
- 'operator' => $operator_nickname,
- ];
- Db::startTrans();
- try{
- $result = $this->FieldrulesModel->where('id', $id)->save($data);
- Db::commit();
- }catch(\Exception $e){
- // 回滚事务
- Db::rollback();
- return to_assign(1, '保存失败:' . $e->getMessage());
- }
- if(!$result){
- return to_assign(1, '保存失败:' . '网络异常');
- }
- return to_assign(0,"操作成功",$id);
- }else{ //新增
- $param_1 = array();
- $param_2 = array();
- foreach($param as $key => $value){
- if(strripos($key, '_edit')){
- $param_2[$key] = $value;
- }else{
- $param_1[$key] = $value;
- }
- }
- $field_data = json_encode($param);
- $field_data_edit = json_encode($param_2);
- $operator_nickname = get_login_admin('nickname');
- $data = array();
- $data = [
- 'field_rules' => $field_data,
- 'field_edit_rules' => $field_data_edit,
- 'operator' => $operator_nickname,
- ];
- Db::startTrans();
- try{
- $result = $this->FieldrulesModel->insertGetId($data);
- Db::commit();
- }catch(\Exception $e){
- // 回滚事务
- Db::rollback();
- return to_assign(1, '保存失败:' . $e->getMessage());
- }
- if(!$result){
- return to_assign(1, '保存失败:' . '网络异常');
- }
- return to_assign(0,"操作成功",$result);
- }
- return to_assign();
- }else{
- $id = empty(get_params('id')) ? 0 : get_params('id');
- $login_admin = get_login_admin();
- // dump($login_admin);
- $where_unit = array();
- if($login_admin['permission'] != 1){
- $where_unit[] = [
- ['unit_name', '=', $login_admin['unit_name']],
- ];
- }
- if ($id > 0) { // 编辑
- $field = self::field_rules($id);
- $field_edit = self::field_edit_rules($id);
- $field = array_merge($field, $field_edit);
- }else{ // 新增
- $field = self::field_project();
- }
- View::assign('field', $field);
- View::assign('id', $id);
- return view();
- }
- }
- public function delete(){
- $id = get_params('id');
- $result = $this->FieldrulesModel->where('id', $id)->delete();
- if($result){
- add_log('delete', $id);
- return to_assign(0, "删除成功");
- }else{
- return to_assign(1, "删除失败");
- }
- }
- // 获取可读字段
- public function field_rules($id){
- //可读字段
- $field_rules = $this->FieldrulesModel->where('id', $id)->order('id', 'desc')->value('field_rules');
- $field_rules = json_decode($field_rules,true);
- return $field_rules;
- }
- // 获取可编辑字段
- public function field_edit_rules($id){
- //可读字段
- $field_edit_rules = $this->FieldrulesModel->where('id', $id)->order('id', 'desc')->value('field_edit_rules');
- $field_edit_rules = json_decode($field_edit_rules,true);
- return $field_edit_rules;
- }
- // zjl获取可读字段
- public function get_field_rules($id){
- //可读字段
- $field_rules = $this->FieldrulesModel->where('admin_id', $id)->order('id', 'desc')->value('field_rules');
- $field_rules = json_decode($field_rules,true);
- if(empty($field_rules)){
- $field_rules = 0;
- }
- return $field_rules;
- }
- // 获取可读字段
- public function get_field_rules_New($admin_id){
- // $admin_id = 67;
- $group_id = Db::name('admin_group_access')->where('uid', $admin_id)->value('group_id');
- //可读字段
- $field_rules = $this->FieldrulesModel->where('group_id', $group_id)->order('id', 'desc')->value('field_rules');
- // dump($field_rules);
- $field_rules = json_decode($field_rules,true);
- if(empty($field_rules)){
- $field_rules = [
- "project_status" => "1",
- "project_status_edit" => "1",
- "project_num" => "1",
- "project_num_edit" => "1",
- "project_name" => "1",
- "project_name_edit" => "1",
- "project_time" => "1",
- "project_time_edit" => "1",
- "entrust_unit" => "1",
- "entrust_unit_edit" => "1",
- "entrust_head" => "1",
- "entrust_head_edit" => "1",
- "entrust_phone" => "1",
- "entrust_phone_edit" => "1",
- "review_unit" => "1",
- "review_unit_edit" => "1",
- "review_head" => "1",
- "review_head_edit" => "1",
- "review_head_phone" => "1",
- "review_head_phone_edit" => "1",
- "sent_review_unit" => "1",
- "sent_review_unit_edit" => "1",
- "sent_review_head" => "1",
- "sent_review_head_edit" => "1",
- "sent_review_phone" => "1",
- "sent_review_phone_edit" => "1",
- "construction_unit" => "1",
- "construction_unit_edit" => "1",
- "construction_head" => "1",
- "construction_head_edit" => "1",
- "construction_phone" => "1",
- "construction_phone_edit" => "1",
- "project_scale" => "1",
- "project_scale_edit" => "1",
- "project_region" => "1",
- "project_region_edit" => "1",
- "engineering_category" => "1",
- "engineering_category_edit" => "1",
- "engineering_type" => "1",
- "engineering_type_edit" => "1",
- "fiscal_nature" => "1",
- "fiscal_nature_edit" => "1",
- "sent_review_cost" => "1",
- "sent_review_cost_edit" => "1",
- "preparation_amount" => "1",
- "preparation_amount_edit" => "1",
- "sent_review_amount" => "1",
- "sent_review_amount_edit" => "1",
- "sent_review_approver_amount" => "1",
- "sent_review_approver_amount_edit" => "1",
- "construction_approver_amount" => "1",
- "construction_approver_amount_edit" => "1",
- "authorize_amount" => "1",
- "authorize_amount_edit" => "1",
- "review_add_reduce_amount" => "1",
- "review_add_reduce_amount_edit" => "1",
- "review_add_reduce_rate" => "1",
- "review_add_reduce_rate_edit" => "1",
- "report_time" => "1",
- "report_time_edit" => "1",
- "charge_standard" => "1",
- "charge_standard_edit" => "1",
- "invoicing__amount" => "1",
- "invoicing__amount_edit" => "1",
- "invoicing__num" => "1",
- "invoicing__num_edit" => "1",
- "operate_name" => "1",
- "operate_name_edit" => "1",
- "operate_team_names" => "1",
- "operate_team_names_edit" => "1",
- "project_dead_time" => "1",
- "project_dead_time_edit" => "1",
- "create_time" => "1",
- "create_time_edit" => "1",
- ];
- }
- // dump($field_rules);
- return $field_rules;
- }
- // 获取可编辑字段
- public function get_field_rules_edit_New($admin_id){
- // $admin_id = 67;
- $group_id = Db::name('admin_group_access')->where('uid', $admin_id)->value('group_id');
- //可读字段
- $field_rules = $this->FieldrulesModel->where('group_id', $group_id)->order('id', 'desc')->value('field_edit_rules');
- // dump($field_rules);
- $field_rules = json_decode($field_rules,true);
- if(empty($field_rules)){
- $field_rules = [
- "project_status" => "1",
- "project_status_edit" => "1",
- "project_num" => "1",
- "project_num_edit" => "1",
- "project_name" => "1",
- "project_name_edit" => "1",
- "project_time" => "1",
- "project_time_edit" => "1",
- "entrust_unit" => "1",
- "entrust_unit_edit" => "1",
- "entrust_head" => "1",
- "entrust_head_edit" => "1",
- "entrust_phone" => "1",
- "entrust_phone_edit" => "1",
- "review_unit" => "1",
- "review_unit_edit" => "1",
- "review_head" => "1",
- "review_head_edit" => "1",
- "review_head_phone" => "1",
- "review_head_phone_edit" => "1",
- "sent_review_unit" => "1",
- "sent_review_unit_edit" => "1",
- "sent_review_head" => "1",
- "sent_review_head_edit" => "1",
- "sent_review_phone" => "1",
- "sent_review_phone_edit" => "1",
- "construction_unit" => "1",
- "construction_unit_edit" => "1",
- "construction_head" => "1",
- "construction_head_edit" => "1",
- "construction_phone" => "1",
- "construction_phone_edit" => "1",
- "project_scale" => "1",
- "project_scale_edit" => "1",
- "project_region" => "1",
- "project_region_edit" => "1",
- "engineering_category" => "1",
- "engineering_category_edit" => "1",
- "engineering_type" => "1",
- "engineering_type_edit" => "1",
- "fiscal_nature" => "1",
- "fiscal_nature_edit" => "1",
- "sent_review_cost" => "1",
- "sent_review_cost_edit" => "1",
- "preparation_amount" => "1",
- "preparation_amount_edit" => "1",
- "sent_review_amount" => "1",
- "sent_review_amount_edit" => "1",
- "sent_review_approver_amount" => "1",
- "sent_review_approver_amount_edit" => "1",
- "construction_approver_amount" => "1",
- "construction_approver_amount_edit" => "1",
- "authorize_amount" => "1",
- "authorize_amount_edit" => "1",
- "review_add_reduce_amount" => "1",
- "review_add_reduce_amount_edit" => "1",
- "review_add_reduce_rate" => "1",
- "review_add_reduce_rate_edit" => "1",
- "report_time" => "1",
- "report_time_edit" => "1",
- "charge_standard" => "1",
- "charge_standard_edit" => "1",
- "invoicing__amount" => "1",
- "invoicing__amount_edit" => "1",
- "invoicing__num" => "1",
- "invoicing__num_edit" => "1",
- "operate_name" => "1",
- "operate_name_edit" => "1",
- "operate_team_names" => "1",
- "operate_team_names_edit" => "1",
- "project_dead_time" => "1",
- "project_dead_time_edit" => "1",
- "create_time" => "1",
- "create_time_edit" => "1",
- ];
- }
- // dump($field_rules);
- return $field_rules;
- }
- public function field_project(){
- $c_field = Db::query("show full columns from cp_cost_project");
- $field[] = array();
- foreach($c_field as $key => $value){
- $field[$key] = $value['Field'];
- }
- $field = array_flip($field);
- unset($field['id']);
- foreach($field as $key => $value){
- $field[$key] = 0;
- }
- return $field;
- }
- }
|