|
@@ -45,808 +45,593 @@ class Member extends Base
|
|
|
* @return name:phone type:int default:-- desc:手机号
|
|
|
* @return name:name type:string default:-- desc:姓名
|
|
|
* @return name:headimg type:string default:-- desc:头像地址
|
|
|
- * @return name:type type:int default:-- desc:人员类型(3:车间主任,4:仓库人员,5:副厂长,6:厂长,7:领导)
|
|
|
- * @return name:type_name type:string default:-- desc:人员类型名称
|
|
|
+ * @return name:synopsis type:string default:-- desc:个人简介
|
|
|
+ * @return name:news_switch type:int default:-- desc:推送消息开关(0:关闭,1:开启)
|
|
|
+ * @return name:privacy_switch type:int default:-- desc:隐私设置开关(0:关闭,1:开启)
|
|
|
+ * @return name:news_num type:int default:-- desc:未读消息的数量
|
|
|
+ * @return name:background type:string default:-- desc:个人中心背景图片地址
|
|
|
*/
|
|
|
public function member_info(){
|
|
|
$uid = $this->uid;
|
|
|
- $field = 'phone,name,headimg,workshop,type';
|
|
|
- $member_info = Db::name('store_member')->field($field)->where('id',$uid)->find();
|
|
|
- if(empty($member_info)){
|
|
|
+ $field = 'phone,name,headimg,synopsis,news_switch,privacy_switch,status,background';
|
|
|
+ $user_info = Db::name('store_member')->field($field)->where('id',$uid)->find();
|
|
|
+ if(empty($user_info)){
|
|
|
$this->error('用户信息不正确');
|
|
|
}
|
|
|
- $member_info['type_name'] = member_type_arr()[$member_info['type']];
|
|
|
- if($member_info['type'] == 3){
|
|
|
- $member_info['type_name'] = digital_conversion()[$member_info['workshop']].$member_info['type_name'];
|
|
|
+ if($user_info['status'] == 0){
|
|
|
+ $this->error('该用户已被禁用');
|
|
|
}
|
|
|
- unset($member_info['workshop']);
|
|
|
- $this->success('获取成功',$member_info);
|
|
|
+ //查看未读消息的数量
|
|
|
+ $user_info['news_num'] = Db::name('store_news')->where('user_id',$uid)->where('status',0)->count('id');
|
|
|
+ unset($user_info['status']);
|
|
|
+ $this->success('获取成功',$user_info);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 修改头像
|
|
|
- * @desc 修改头像
|
|
|
+ * @title 编辑个人信息
|
|
|
+ * @desc 编辑个人信息
|
|
|
* @author QGF
|
|
|
- * @url /api/Member/edit_headimg
|
|
|
- * @method GET
|
|
|
- * @tag 修改头像
|
|
|
+ * @url /api/Member/edit_member_info
|
|
|
+ * @method POST
|
|
|
+ * @tag 编辑信息
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:headimg type:string default:-- desc:要修改的头像地址
|
|
|
+ * @param name:type type:int require:1 default:-- desc:修改的类型(1:头像,2:昵称,3:个人简介)
|
|
|
+ * @param name:headimg type:string require:0 default:-- desc:头像地址(type为1时必传)
|
|
|
+ * @param name:name type:string require:0 default:-- desc:姓名(type为2时必传)
|
|
|
+ * @param name:synopsis type:string require:0 default:-- desc:个人简介(type为3时必传)
|
|
|
*/
|
|
|
- public function edit_headimg(){
|
|
|
+ public function edit_member_info(){
|
|
|
$uid = $this->uid;
|
|
|
+ $type = input('type');
|
|
|
$headimg = input('headimg');
|
|
|
- if(empty($headimg)){
|
|
|
+ $name = input('name');
|
|
|
+ $synopsis = input('synopsis');
|
|
|
+ if(empty($type)){
|
|
|
$this->error('参数错误');
|
|
|
}
|
|
|
- $member = Db::name('store_member')->field('headimg')->where('id',$uid)->find();
|
|
|
- if($member['headimg'] == $headimg){
|
|
|
- $this->error('没有要修改的内容');
|
|
|
- }
|
|
|
- $update_data = array(
|
|
|
- 'headimg'=>$headimg
|
|
|
- );
|
|
|
- $res = Db::name('store_member')->where('id',$uid)->update($update_data);
|
|
|
- if($res !==false){
|
|
|
- $this->success('保存成功');
|
|
|
+ if($type == 1){
|
|
|
+ if(empty($headimg)){
|
|
|
+ $this->error('参数错误');
|
|
|
+ }
|
|
|
+ $update_data = array('headimg'=>$headimg);
|
|
|
+ }elseif($type == 2){
|
|
|
+ if(empty($name)){
|
|
|
+ $this->error('参数错误');
|
|
|
+ }
|
|
|
+ $update_data = array('name'=>$name);
|
|
|
}else{
|
|
|
- $this->error('保存失败');
|
|
|
- }
|
|
|
- }
|
|
|
- /**
|
|
|
- * @title 董事长风采
|
|
|
- * @desc 董事长风采
|
|
|
- * @author QGF
|
|
|
- * @url /api/Member/chairman_show
|
|
|
- * @method GET
|
|
|
- * @tag 董事长风采
|
|
|
- * @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:-- type:striny default:-- desc:董事长风采(富文本)
|
|
|
- */
|
|
|
- public function chairman_show(){
|
|
|
- $this->success('获取成功',htmlspecialchars_decode(sysconf('chairman_show')));
|
|
|
- }
|
|
|
- /**
|
|
|
- * @title 企业文化
|
|
|
- * @desc 企业文化
|
|
|
- * @author QGF
|
|
|
- * @url /api/Member/enterprise_culture
|
|
|
- * @method GET
|
|
|
- * @tag 企业文化
|
|
|
- * @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:-- type:striny default:-- desc:企业文化(富文本)
|
|
|
- */
|
|
|
- public function enterprise_culture(){
|
|
|
- $this->success('获取成功',htmlspecialchars_decode(sysconf('enterprise_culture')));
|
|
|
- }
|
|
|
- /**
|
|
|
- * @title 公司联系方式
|
|
|
- * @desc 公司联系方式
|
|
|
- * @author QGF
|
|
|
- * @url /api/Member/contact_way
|
|
|
- * @method GET
|
|
|
- * @tag 公司联系方式
|
|
|
- * @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:company_name type:striny default:-- desc:公司名称
|
|
|
- * @return name:company_address type:striny default:-- desc:公司地址
|
|
|
- * @return name:company_phone type:striny default:-- desc:公司电话
|
|
|
- */
|
|
|
- public function contact_way(){
|
|
|
- $company_name = sysconf('company_name');
|
|
|
- $company_address = sysconf('company_address');
|
|
|
- $company_phone = sysconf('company_phone');
|
|
|
- $data = array(
|
|
|
- 'company_name' => $company_name,
|
|
|
- 'company_address' => $company_address,
|
|
|
- 'company_phone' => $company_phone
|
|
|
- );
|
|
|
- $this->success('获取成功',$data);
|
|
|
- }
|
|
|
- /**
|
|
|
- * @title 公司通讯录
|
|
|
- * @desc 公司通讯录
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/member_list
|
|
|
- * @method GET
|
|
|
- * @tag 公司通讯录
|
|
|
- * @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:headimg type:string default:-- desc:头像地址
|
|
|
- * @return name:name type:string default:-- desc:姓名
|
|
|
- * @return name:phone type:string default:-- desc:手机号
|
|
|
- * @return name:type_name type:string default:-- desc:标识名称
|
|
|
- */
|
|
|
- public function member_list(){
|
|
|
- $uid = $this->uid;
|
|
|
- $member_list = Db::name('store_member')->field('headimg,name,phone,type,workshop')->where('id','<>',$uid)->where('is_deleted',0)->select();
|
|
|
- foreach ($member_list as &$value){
|
|
|
- if($value['type'] == 1){
|
|
|
- $value['type_name'] = digital_conversion()[$value['workshop']].'车间员工';
|
|
|
- }elseif ($value['type'] == 2){
|
|
|
- $value['type_name'] = '销售人员';
|
|
|
- }elseif($value['type'] == 3){
|
|
|
- $value['type_name'] = digital_conversion()[$value['workshop']].'车间主任';
|
|
|
- }else{
|
|
|
- $value['type_name'] = member_type_arr()[$value['type']];
|
|
|
+ if(empty($synopsis)){
|
|
|
+ $this->error('参数错误');
|
|
|
}
|
|
|
- unset($value['type']);
|
|
|
- unset($value['workshop']);
|
|
|
+ $update_data = array('synopsis'=>$synopsis);
|
|
|
}
|
|
|
- $this->success('获取成功',$member_list);
|
|
|
+ Db::name('store_member')->where('id',$uid)->update($update_data);
|
|
|
+ $this->success('编辑成功');
|
|
|
}
|
|
|
/**
|
|
|
- * @title 考勤情况反馈
|
|
|
- * @desc 考勤情况反馈
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/attendance_feedback
|
|
|
- * @method GET
|
|
|
- * @tag 考勤情况反馈
|
|
|
- * @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:id type:int default:-- desc:工人id
|
|
|
- * @return name:name type:string default:-- desc:姓名
|
|
|
- * @return name:workshop type:string default:-- desc:部门名称
|
|
|
- */
|
|
|
- public function attendance_feedback(){
|
|
|
- $uid = $this->uid;
|
|
|
- $member_info = Db::name('store_member')->field('type,workshop')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- $workshop = $member_info['workshop'];
|
|
|
- if($type != 3){
|
|
|
- $this->error('不是车间主任');
|
|
|
- }
|
|
|
- $worker_list = Db::name('store_member')->field('id,name')->where('type',1)->where('workshop',$workshop)->select();
|
|
|
- if(empty($worker_list)){
|
|
|
- $this->success('暂无车间员工',array());
|
|
|
- }
|
|
|
- $workshop = workshop_arr()[$workshop];
|
|
|
- foreach ($worker_list as &$value){
|
|
|
- $value['workshop'] = $workshop;
|
|
|
- }
|
|
|
- $this->success('获取成功',$worker_list);
|
|
|
- }
|
|
|
- /**
|
|
|
- * @title 提交考勤情况反馈
|
|
|
- * @desc 提交考勤情况反馈
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/submit_attendance
|
|
|
- * @method GET
|
|
|
- * @tag 提交考勤情况反馈
|
|
|
+ * @title 更换背景图片
|
|
|
+ * @desc 更换背景图片
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/update_background
|
|
|
+ * @method POST
|
|
|
+ * @tag 更换背景图片
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:staff_info type:json require:1 default:-- desc:工人考勤信息。staff_info[0][id](工人id),staff_info[0][time](工作时长)
|
|
|
+ * @param name:background type:string require:1 default:-- desc:头像地址(type为1时必传)
|
|
|
*/
|
|
|
- public function submit_attendance(){
|
|
|
+ public function update_background(){
|
|
|
$uid = $this->uid;
|
|
|
- $staff_info = input('staff_info');
|
|
|
- if(empty($staff_info)){
|
|
|
+ $background = input('background');
|
|
|
+ if(empty($background)){
|
|
|
$this->error('参数错误');
|
|
|
}
|
|
|
- $member_info = Db::name('store_member')->field('type,workshop,name')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- $workshop = $member_info['workshop'];
|
|
|
- if($type != 3){
|
|
|
- $this->error('不是车间主任');
|
|
|
- }
|
|
|
- if(!is_array($staff_info)){
|
|
|
- $staff_info = json_decode($staff_info,true);
|
|
|
- if(!is_array($staff_info)){
|
|
|
- $this->success('工人考勤信息参数有误');
|
|
|
- }
|
|
|
- }
|
|
|
- $attendance_id = Db::name('store_attendance')->where('date',date('Y-m-d'))->where('workshop',$workshop)->value('id');
|
|
|
- if($attendance_id){
|
|
|
- $this->error('今天你已提交过');
|
|
|
- }
|
|
|
- foreach ($staff_info as $value){
|
|
|
- $user_name = Db::name('store_member')->where('id',$value['id'])->value('name');
|
|
|
- $is_attendance = $value['time']?1:0;
|
|
|
- $attendance_data = array(
|
|
|
- 'workshop' => $workshop,
|
|
|
- 'shop_manager' => $member_info['name'],
|
|
|
- 'user_id' => $value['id'],
|
|
|
- 'user_name' => $user_name,
|
|
|
- 'is_attendance' => $is_attendance,
|
|
|
- 'attendance_time' => $value['time'],
|
|
|
- 'date' => date('Y-m-d')
|
|
|
- );
|
|
|
- Db::name('store_attendance')->insert($attendance_data);
|
|
|
- }
|
|
|
- $this->success('提交成功');
|
|
|
+ Db::name('store_member')->where('id',$uid)->update(array('background'=>$background));
|
|
|
+ $this->success('编辑成功');
|
|
|
}
|
|
|
/**
|
|
|
- * @title 生产情况反馈
|
|
|
- * @desc 生产情况反馈
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/product_feedback
|
|
|
- * @method GET
|
|
|
- * @tag 生产情况反馈
|
|
|
+ * @title 修改手机号
|
|
|
+ * @desc 修改手机号
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/update_phone
|
|
|
+ * @method POST
|
|
|
+ * @tag 修改手机号
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:id type:int require:1 default:-- desc:订单ID
|
|
|
- * @return name:id type:int default:-- desc:工人id
|
|
|
- * @return name:name type:string default:-- desc:姓名
|
|
|
- * @return name:workshop type:string default:-- desc:部门名称
|
|
|
- * @return name:product_info type:array default:-- desc:生产部件信息(parts_id:部件id,parts_price:部件价格,parts_name:部件名称)
|
|
|
+ * @param name:old_phone type:int require:1 default:-- desc:原手机号
|
|
|
+ * @param name:old_code type:int require:1 default:-- desc:原手机号验证码
|
|
|
+ * @param name:new_phone type:int require:1 default:-- desc:新手机号
|
|
|
+ * @param name:new_code type:int require:1 default:-- desc:新手机号验证码
|
|
|
*/
|
|
|
- public function product_feedback(){
|
|
|
+ public function update_phone(){
|
|
|
$uid = $this->uid;
|
|
|
- $id = input('id');
|
|
|
- if(empty($id)){
|
|
|
+ $old_phone = input('old_phone');
|
|
|
+ $old_code = input('old_code');
|
|
|
+ $new_phone = input('new_phone');
|
|
|
+ $new_code = input('new_code');
|
|
|
+ if(empty($old_phone) || empty($old_code) || empty($new_phone) || empty($new_code)){
|
|
|
$this->error('参数错误');
|
|
|
}
|
|
|
- $member_info = Db::name('store_member')->field('type,workshop')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- $workshop = $member_info['workshop'];
|
|
|
- if($type != 3){
|
|
|
- $this->error('不是车间主任');
|
|
|
+ if($old_phone == $new_phone){
|
|
|
+ $this->error('手机号一致,无需修改');
|
|
|
+ }
|
|
|
+ $member = Db::name('store_member')->field('id,phone')->where('id',$uid)->find();
|
|
|
+ if($member['phone'] != $old_phone){
|
|
|
+ $this->error('原手机号不正确');
|
|
|
}
|
|
|
- $product_info = Db::name('store_product_flow')->where('order_id',$id)->where('workshop',$workshop)->value('product_info');
|
|
|
- if(empty($product_info)){
|
|
|
- $this->error('订单信息有误');
|
|
|
+ $obj = new Login();
|
|
|
+ $old_sms_id = $obj->verify_sms($old_phone,$old_code);
|
|
|
+ if(empty($old_sms_id)){
|
|
|
+ $this->error('原手机号验证码不正确');
|
|
|
}
|
|
|
- $product_info = json_decode($product_info,true);
|
|
|
- foreach ($product_info as &$product_value){
|
|
|
- $product_value['parts_name'] = Db::name('store_parts')->where('id',$product_value['parts_id'])->value('name');
|
|
|
- unset($product_value['parts_num']);
|
|
|
+ $new_sms_id = $obj->verify_sms($new_phone,$new_code);
|
|
|
+ if(empty($new_sms_id)){
|
|
|
+ $this->error('新手机号验证码不正确');
|
|
|
}
|
|
|
- $worker_list = Db::name('store_member')->field('id,name')->where('type',1)->where('workshop',$workshop)->select();
|
|
|
- if(empty($worker_list)){
|
|
|
- $this->success('暂无车间员工',array());
|
|
|
+ //判断新手机号是否已注册
|
|
|
+ $member_id = Db::name('store_member')->where('phone',$new_phone)->value('id');
|
|
|
+ if($member_id){
|
|
|
+ $this->error('新手机号已注册过');
|
|
|
}
|
|
|
|
|
|
- $workshop = workshop_arr()[$workshop];
|
|
|
- foreach ($worker_list as &$value){
|
|
|
- $value['workshop'] = $workshop;
|
|
|
- $value['product_info'] = $product_info;
|
|
|
+ $res = Db::name('store_member')->where('id',$uid)->update(array('phone'=>$new_phone));
|
|
|
+ if($res !==false){
|
|
|
+ Db::name('store_member_sms')->where('id',$old_sms_id)->update(array('used'=>1));
|
|
|
+ Db::name('store_member_sms')->where('id',$new_sms_id)->update(array('used'=>1));
|
|
|
+ $this->success('更换成功');
|
|
|
+ }else{
|
|
|
+ $this->error('更换失败');
|
|
|
}
|
|
|
- $this->success('获取成功',$worker_list);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 提交生产情况反馈
|
|
|
- * @desc 提交生产情况反馈
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/submit_product
|
|
|
- * @method GET
|
|
|
- * @tag 提交生产情况反馈
|
|
|
- * @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:id type:int require:1 default:-- desc:订单ID
|
|
|
- * @param name:staff_info type:json require:1 default:-- desc:工人生产信息。staff_info[0][id](工人id),staff_info[0][product_info][0][parts_id](部件id,),staff_info[0][product_info][0][parts_num](生产数量)
|
|
|
+ * @title 修改密码
|
|
|
+ * @desc 修改密码
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/update_password
|
|
|
+ * @method POST
|
|
|
+ * @tag 修改密码
|
|
|
+ * @param name:phone type:int require:1 default:-- desc:手机号
|
|
|
+ * @param name:code type:int require:1 default:-- desc:短信验证码
|
|
|
+ * @param name:password type:string require:1 default:-- desc:新密码
|
|
|
*/
|
|
|
- public function submit_product(){
|
|
|
- $uid = $this->uid;
|
|
|
- $id = input('id');
|
|
|
- $staff_info = input('staff_info');
|
|
|
- if(empty($id) || empty($staff_info)){
|
|
|
- $this->error('参数错误');
|
|
|
+ public function update_password(){
|
|
|
+ $phone = input('phone');
|
|
|
+ $code = input('code');
|
|
|
+ $password = input('password');
|
|
|
+ if(empty($phone) || empty($code) || empty($password)){
|
|
|
+ $this ->error('参数错误');
|
|
|
}
|
|
|
- $member_info = Db::name('store_member')->field('type,workshop,name')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- $workshop = $member_info['workshop'];
|
|
|
- if($type != 3){
|
|
|
- $this->error('不是车间主任');
|
|
|
+ $obj = new Login();
|
|
|
+ $sms_id = $obj->verify_sms($phone,$code);
|
|
|
+ if(empty($sms_id)){
|
|
|
+ $this->error('验证码不正确');
|
|
|
}
|
|
|
- if(!is_array($staff_info)){
|
|
|
- $staff_info = json_decode($staff_info,true);
|
|
|
- if(!is_array($staff_info)){
|
|
|
- $this->success('工人考勤信息参数有误');
|
|
|
- }
|
|
|
- }
|
|
|
- $product_id = Db::name('store_product_case')->where('date',date('Y-m-d'))->where('order_id',$id)->where('workshop',$workshop)->value('id');
|
|
|
- if($product_id){
|
|
|
- $this->error('今天你已提交过');
|
|
|
+ $member = Db::name('store_member')->field('id,decode_password')->where('phone',$phone)->find();
|
|
|
+ if(empty($member['id'])){
|
|
|
+ $this ->error('该手机号未注册');
|
|
|
}
|
|
|
- $order_no = Db::name('store_product_flow')->where('order_id',$id)->where('workshop',$workshop)->value('order_no');
|
|
|
- //当天该车间一共生产的总量
|
|
|
- $workshop_product_num = 0;
|
|
|
- foreach ($staff_info as $value){
|
|
|
- $user_name = Db::name('store_member')->where('id',$value['id'])->value('name');
|
|
|
- $product_num = 0;
|
|
|
- foreach ($value['product_info'] as $product_value){
|
|
|
- $product_num += $product_value['parts_num'];
|
|
|
- }
|
|
|
- $workshop_product_num += $product_num;
|
|
|
- $product_data = array(
|
|
|
- 'order_id' => $id,
|
|
|
- 'order_no' => $order_no,
|
|
|
- 'workshop' => $workshop,
|
|
|
- 'shop_manager' => $member_info['name'],
|
|
|
- 'user_id' => $value['id'],
|
|
|
- 'user_name' => $user_name,
|
|
|
- 'product_num' => $product_num,
|
|
|
- 'product_info' => json_encode($value['product_info']),
|
|
|
- 'date' => date('Y-m-d')
|
|
|
- );
|
|
|
- Db::name('store_product_case')->insert($product_data);
|
|
|
+ if($password == $member['decode_password']){
|
|
|
+ $this ->error('新密码与原密码一致,无需修改');
|
|
|
}
|
|
|
- //更新流程表已经生产的数量
|
|
|
- Db::name('store_product_flow')->where('order_id',$id)->where('workshop',$workshop)->setInc('reality_num',$workshop_product_num);
|
|
|
- $this->success('提交成功');
|
|
|
+ $update_data = array(
|
|
|
+ 'password'=>md5($password),
|
|
|
+ 'decode_password'=>$password
|
|
|
+ );
|
|
|
+ Db::name('store_member')->where('phone',$phone)->update($update_data);
|
|
|
+ Db::name('store_member_sms')->where('id',$sms_id)->update(array('used'=>1));
|
|
|
+ $this->success('修改密码成功');
|
|
|
}
|
|
|
/**
|
|
|
- * @title 奖励金额列表
|
|
|
- * @desc 奖励金额列表
|
|
|
+ * @title 获取版本号
|
|
|
+ * @desc 获取版本号
|
|
|
* @author QGF
|
|
|
- * @url /api/Member/award_amount_list
|
|
|
+ * @url /api/Member/store_versions
|
|
|
* @method GET
|
|
|
- * @tag 奖励金额
|
|
|
- * @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:amount type:decimal default:100.00 desc:金额值
|
|
|
- * @return name:ID type:int default:1 desc:金额ID
|
|
|
+ * @tag 获取版本号
|
|
|
+ * @param name:type type:int require:1 default:1 desc:类型(1:安卓,2:IOS。默认安卓)
|
|
|
+ * @return name:title type:string default:-- desc:版本号
|
|
|
+ * @return name:content type:string default:-- desc:修改内容
|
|
|
*/
|
|
|
- public function award_amount_list(){
|
|
|
- $amount_list = Db::name('store_award_amount')->field('id,amount')->where('status',1)->where('is_deleted',0)->order('sort desc')->order('id desc')->select();
|
|
|
- if(count($amount_list)){
|
|
|
- foreach($amount_list as &$value){
|
|
|
- $value['ID'] = $value['id'];
|
|
|
- unset($value['id']);
|
|
|
- }
|
|
|
- }
|
|
|
- $this->success('获取成功',$amount_list);
|
|
|
+ public function store_versions(){
|
|
|
+ $type = input('type',1);
|
|
|
+ $store_versions = Db::name('store_versions')->field('title,content')->where('type',$type)->find();
|
|
|
+ $this->success('获取成功',$store_versions);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 选择奖励人员
|
|
|
- * @desc 选择奖励人员
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/select_member_list
|
|
|
- * @method GET
|
|
|
- * @tag 选择奖励人员
|
|
|
+ * @title 消息推送开关设置
|
|
|
+ * @desc 消息推送开关设置
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/update_news_switch
|
|
|
+ * @method POST
|
|
|
+ * @tag 消息推送开关设置
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:id type:int default:-- desc:工人ID
|
|
|
- * @return name:name type:string default:-- desc:工人姓名
|
|
|
+ * @param name:news_switch type:string require:1 default:-- desc:开关(0:关闭,1:开启)
|
|
|
*/
|
|
|
- public function select_member_list(){
|
|
|
+ public function update_news_switch(){
|
|
|
$uid = $this->uid;
|
|
|
- $member_info = Db::name('store_member')->field('type,workshop')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- $workshop = $member_info['workshop'];
|
|
|
- if(!in_array($type,array('3','5','6'))){
|
|
|
- $this->error('该身份没有权限');
|
|
|
+ $news_switch = input('news_switch');
|
|
|
+ if(!isset($news_switch)){
|
|
|
+ $this->error('参数错误');
|
|
|
}
|
|
|
- if($type == 3){
|
|
|
- $member_list = Db::name('store_member')->field('id,name')->where('id','<>',$uid)->where('type',1)->where('workshop',$workshop)->where('is_deleted',0)->select();
|
|
|
- }else{
|
|
|
- $member_list = Db::name('store_member')->field('id,name')->where('id','<>',$uid)->where('type',1)->where('is_deleted',0)->select();
|
|
|
+ $old_news_switch = Db::name('store_member')->where('id',$uid)->value('news_switch');
|
|
|
+ if($old_news_switch == $news_switch){
|
|
|
+ $this->error('已是当前状态,无需操作');
|
|
|
}
|
|
|
- $this->success('获取成功',$member_list);
|
|
|
+ Db::name('store_member')->where('id',$uid)->update(array('news_switch'=>$news_switch));
|
|
|
+ $this->success('操作成功');
|
|
|
}
|
|
|
/**
|
|
|
- * @title 提交奖励
|
|
|
- * @desc 提交奖励
|
|
|
+ * @title 隐私开关设置
|
|
|
+ * @desc 隐私开关设置
|
|
|
* @author QGF
|
|
|
- * @url /api/Member/submit_award
|
|
|
+ * @url /api/Member/update_privacy_switch
|
|
|
* @method POST
|
|
|
- * @tag 提交奖励
|
|
|
+ * @tag 隐私开关设置
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:explain type:string require:1 default:-- desc:奖励说明
|
|
|
- * @param name:images type:string require:1 default:-- desc:奖励的图片地址,多张图片以英文逗号(,)分隔
|
|
|
- * @param name:user_id type:int require:1 default:-- desc:奖励的工人ID
|
|
|
- * @param name:amount type:string require:1 default:-- desc:奖励的金额
|
|
|
+ * @param name:privacy_switch type:string require:1 default:-- desc:开关(0:关闭,1:开启)
|
|
|
*/
|
|
|
- public function submit_award(){
|
|
|
+ public function update_privacy_switch(){
|
|
|
$uid = $this->uid;
|
|
|
- $explain = input('explain');
|
|
|
- $images = input('images');
|
|
|
- $user_id = input('user_id');
|
|
|
- $amount = input('amount');
|
|
|
- if(empty($explain) || empty($images) || empty($user_id) || empty($amount)){
|
|
|
+ $privacy_switch = input('privacy_switch');
|
|
|
+ if(!isset($privacy_switch)){
|
|
|
$this->error('参数错误');
|
|
|
}
|
|
|
- $award_id = Db::name('store_award_list')->where('date',date('Y-m-d'))->where('user_id',$user_id)->value('id');
|
|
|
- if($award_id){
|
|
|
- $this->error('该员工今天已奖励过');
|
|
|
- }
|
|
|
- $data = [
|
|
|
- 'submit_user_id' => $uid,
|
|
|
- 'user_id' => $user_id,
|
|
|
- 'explain' => $explain,
|
|
|
- 'images' => $images,
|
|
|
- 'amount' => $amount,
|
|
|
- 'date' => date('Y-m-d')
|
|
|
- ];
|
|
|
- $res = Db::name('store_award_list')->insert($data);
|
|
|
- if($res !==false){
|
|
|
- //更新员工总奖励
|
|
|
- $integral = Db::name('store_member')->where('id',$user_id)->value('integral');
|
|
|
- Db::name('store_member')->where('id',$user_id)->update(array('integral'=>$integral + $amount));
|
|
|
- $this->success('提交成功');
|
|
|
- }else{
|
|
|
- $this->error('提交失败');
|
|
|
+ $old_privacy_switch = Db::name('store_member')->where('id',$uid)->value('privacy_switch');
|
|
|
+ if($old_privacy_switch == $privacy_switch){
|
|
|
+ $this->error('已是当前状态,无需操作');
|
|
|
}
|
|
|
+ Db::name('store_member')->where('id',$uid)->update(array('privacy_switch'=>$privacy_switch));
|
|
|
+ $this->success('操作成功');
|
|
|
}
|
|
|
/**
|
|
|
- * @title 工作(现场情况反馈)
|
|
|
- * @desc 工作(现场情况反馈)
|
|
|
+ * @title 隐私政策
|
|
|
+ * @desc 隐私政策
|
|
|
* @author QGF
|
|
|
- * @url /api/Member/worker_feedback
|
|
|
- * @method POST
|
|
|
- * @tag 工作(现场情况反馈)
|
|
|
- * @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:explain type:string require:1 default:-- desc:反馈内容
|
|
|
- * @param name:images type:string require:1 default:-- desc:反馈的图片地址,多张图片以英文逗号(,)分隔
|
|
|
+ * @url /api/Member/privacy_policy
|
|
|
+ * @method GET
|
|
|
+ * @tag 隐私政策
|
|
|
+ * @return name:-- type:string default:-- desc:隐私政策
|
|
|
*/
|
|
|
- public function worker_feedback(){
|
|
|
- $uid = $this->uid;
|
|
|
- $explain = input('explain');
|
|
|
- $images = input('images');
|
|
|
- if(empty($explain) || empty($images)){
|
|
|
- $this->error('参数错误');
|
|
|
- }
|
|
|
- $complain_id = Db::name('store_complain')->where('date',date('Y-m-d'))->where('type',1)->where('user_id',$uid)->value('id');
|
|
|
- if($complain_id){
|
|
|
- $this->error('你已提交过今天的任务反馈');
|
|
|
- }
|
|
|
- $data = [
|
|
|
- 'user_id' => $uid,
|
|
|
- 'question' => $explain,
|
|
|
- 'images' => $images,
|
|
|
- 'date' => date('Y-m-d')
|
|
|
- ];
|
|
|
- $res = Db::name('store_complain')->insert($data);
|
|
|
- if($res !==false){
|
|
|
- $this->success('提交成功');
|
|
|
- }else{
|
|
|
- $this->error('提交失败');
|
|
|
- }
|
|
|
+ public function privacy_policy(){
|
|
|
+ $this->success('获取成功',htmlspecialchars_decode(sysconf('privacy_policy')));
|
|
|
}
|
|
|
/**
|
|
|
- * @title 任务反馈
|
|
|
- * @desc 任务反馈
|
|
|
+ * @title 关于我们
|
|
|
+ * @desc 关于我们
|
|
|
* @author QGF
|
|
|
- * @url /api/Member/task_feedback
|
|
|
- * @method POST
|
|
|
- * @tag 任务反馈
|
|
|
+ * @url /api/Member/about_us
|
|
|
+ * @method GET
|
|
|
+ * @tag 关于我们
|
|
|
+ * @return name:-- type:string default:-- desc:关于我们
|
|
|
+ */
|
|
|
+ public function about_us(){
|
|
|
+ $this->success('获取成功',htmlspecialchars_decode(sysconf('about_us')));
|
|
|
+ }
|
|
|
+ /**
|
|
|
+ * @title 我的关注
|
|
|
+ * @desc 我的关注
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/my_attention
|
|
|
+ * @method GET
|
|
|
+ * @tag 我的关注
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:explain type:string require:1 default:-- desc:反馈内容
|
|
|
- * @param name:images type:string require:1 default:-- desc:反馈的图片地址,多张图片以英文逗号(,)分隔
|
|
|
+ * @param name:page type:int require:0 default:1 desc:页数(默认为1)
|
|
|
+ * @param name:page_size type:int require:0 default:10 desc:每页数量(默认为10)
|
|
|
+ * @return name:user_name type:string default:-- desc:用户姓名/媒体名称
|
|
|
+ * @return name:user_headimg type:string default:-- desc:用户头像/媒体logo
|
|
|
+ * @return name:attention_num type:int default:-- desc:粉丝数量
|
|
|
*/
|
|
|
- public function task_feedback(){
|
|
|
+ public function my_attention(){
|
|
|
$uid = $this->uid;
|
|
|
- $explain = input('explain');
|
|
|
- $images = input('images');
|
|
|
- if(empty($explain) || empty($images)){
|
|
|
- $this->error('参数错误');
|
|
|
- }
|
|
|
- $complain_id = Db::name('store_complain')->where('date',date('Y-m-d'))->where('type',2)->where('user_id',$uid)->value('id');
|
|
|
- if($complain_id){
|
|
|
- $this->error('你已提交过今天的任务反馈');
|
|
|
- }
|
|
|
- $data = [
|
|
|
- 'user_id' => $uid,
|
|
|
- 'question' => $explain,
|
|
|
- 'images' => $images,
|
|
|
- 'type' => 2,
|
|
|
- 'date' => date('Y-m-d')
|
|
|
- ];
|
|
|
- $res = Db::name('store_complain')->insert($data);
|
|
|
- if($res !==false){
|
|
|
- $this->success('提交成功');
|
|
|
- }else{
|
|
|
- $this->error('提交失败');
|
|
|
+ $page = input('page',1);
|
|
|
+ $pageSize = input('page_size',10);
|
|
|
+ $list = Db::name('store_attention')->field('from_user_id')->where('user_id',$uid)->where('status',1)->page($page,$pageSize)->order('id','desc')->select();
|
|
|
+ if($list){
|
|
|
+ foreach ($list as &$value){
|
|
|
+ $user_type = user_type($value['from_user_id']);//1:用户 2:媒体
|
|
|
+ if($user_type == 1){
|
|
|
+ $user_info = Db::name('store_member')->field('name,headimg')->where('id',$value['from_user_id'])->find();
|
|
|
+ $value['user_name'] = $user_info['name'];
|
|
|
+ $value['user_headimg'] = $user_info['headimg'];
|
|
|
+ }else{
|
|
|
+ $media_info = Db::name('store_media')->field('logo,title')->where('id',$value['from_user_id'])->find();
|
|
|
+ $value['user_name'] = $media_info['title'];
|
|
|
+ $value['user_headimg'] = $media_info['logo'];
|
|
|
+ }
|
|
|
+ //共关注的数
|
|
|
+ $value['attention_num'] = Db::name('store_attention')->where('from_user_id',$value['from_user_id'])->where('status',1)->count('id');
|
|
|
+ unset($value['from_user_id']);
|
|
|
+ }
|
|
|
}
|
|
|
+ $this->success('获取成功',$list);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 积分奖励(领导)
|
|
|
- * @desc 积分奖励(领导)
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/reward_list
|
|
|
+ * @title 我的收藏
|
|
|
+ * @desc 我的收藏
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/my_collect
|
|
|
* @method GET
|
|
|
- * @tag 积分奖励(领导)
|
|
|
+ * @tag 我的收藏
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:explain type:striny default:-- desc:奖励说明
|
|
|
- * @return name:images type:array default:-- desc:奖励图片地址(数组)
|
|
|
- * @return name:amount type:striny default:-- desc:奖励金额
|
|
|
- * @return name:create_at type:striny default:-- desc:时间
|
|
|
- * @return name:user_name type:striny default:-- desc:员工姓名
|
|
|
+ * @param name:type type:int require:0 default:1 desc:类型(1:新闻(默认),2:咨询)
|
|
|
+ * @param name:page type:int require:0 default:1 desc:页数(默认为1)
|
|
|
+ * @param name:page_size type:int require:0 default:10 desc:每页数量(默认为10)
|
|
|
+ * @return name:id type:int default:-- desc:新闻或咨询ID
|
|
|
+ * @return name:title type:string default:-- desc:标题
|
|
|
+ * @return name:content type:string default:-- desc:内容(咨询独有)
|
|
|
+ * @return name:image type:array default:-- desc:图片数组
|
|
|
+ * @return name:video type:string default:-- desc:视频地址
|
|
|
+ * @return name:is_top type:int default:-- desc:是否置顶(0:不置顶,1:置顶)(新闻独有)
|
|
|
+ * @return name:comment_num type:int default:-- desc:评论数量
|
|
|
+ * @return name:media_logo type:string default:-- desc:用户头像或媒体logo
|
|
|
+ * @return name:media_title type:string default:-- desc:用户姓名或媒体名称
|
|
|
+ * @return name:duration type:string default:-- desc:时长
|
|
|
*/
|
|
|
- public function reward_list(){
|
|
|
+ public function my_collect(){
|
|
|
$uid = $this->uid;
|
|
|
- $member_info = Db::name('store_member')->field('type')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- if($type != 7){
|
|
|
- $this->error('该身份没有权限');
|
|
|
- }
|
|
|
- $award_list = Db::name('store_award_list')->field('user_id,explain,images,amount,create_at')->order('id desc')->select();
|
|
|
- if(empty($award_list)){
|
|
|
- $this->success('获取成功',array());
|
|
|
- }
|
|
|
- foreach ($award_list as &$value){
|
|
|
- $value['images'] = image_path($value['images']);
|
|
|
- $value['user_name'] = Db::name('store_member')->where('id',$value['user_id'])->value('name');
|
|
|
- unset($value['user_id']);
|
|
|
+ $type = input('type',1);
|
|
|
+ $page = input('page',1);
|
|
|
+ $pageSize = input('page_size',10);
|
|
|
+ $id_arr = Db::name('store_collect')->field('forum_id')->where('user_id',$uid)->where('status',1)->where('type',$type)->page($page,$pageSize)->order('id','desc')->column('forum_id');
|
|
|
+ if(empty($id_arr)){
|
|
|
+ $this->success('获取成功',[]);
|
|
|
}
|
|
|
- $this->success('获取成功',$award_list);
|
|
|
+ $list = $this->get_list($type,$id_arr,$page,$pageSize);
|
|
|
+ $this->success('获取成功',$list);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 奖励统计(领导)
|
|
|
- * @desc 奖励统计(领导)
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/reward_statistics
|
|
|
+ * @title 我的浏览
|
|
|
+ * @desc 我的浏览
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/my_browse
|
|
|
* @method GET
|
|
|
- * @tag 奖励统计(领导)
|
|
|
+ * @tag 我的浏览
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @return name:id type:int default:-- desc:工人id
|
|
|
- * @return name:name type:string default:-- desc:姓名
|
|
|
- * @return name:integral type:string default:-- desc:奖励金额
|
|
|
+ * @param name:type type:int require:0 default:1 desc:类型(1:新闻(默认),2:咨询)
|
|
|
+ * @param name:page type:int require:0 default:1 desc:页数(默认为1)
|
|
|
+ * @param name:page_size type:int require:0 default:10 desc:每页数量(默认为10)
|
|
|
+ * @return name:id type:int default:-- desc:新闻或咨询ID
|
|
|
+ * @return name:title type:string default:-- desc:标题
|
|
|
+ * @return name:content type:string default:-- desc:内容(咨询独有)
|
|
|
+ * @return name:image type:array default:-- desc:图片数组
|
|
|
+ * @return name:video type:string default:-- desc:视频地址
|
|
|
+ * @return name:is_top type:int default:-- desc:是否置顶(0:不置顶,1:置顶)(新闻独有)
|
|
|
+ * @return name:comment_num type:int default:-- desc:评论数量
|
|
|
+ * @return name:media_logo type:string default:-- desc:用户头像或媒体logo
|
|
|
+ * @return name:media_title type:string default:-- desc:用户姓名或媒体名称
|
|
|
+ * @return name:duration type:string default:-- desc:时长
|
|
|
*/
|
|
|
- public function reward_statistics(){
|
|
|
+ public function my_browse(){
|
|
|
$uid = $this->uid;
|
|
|
- $member_info = Db::name('store_member')->field('type')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- if($type != 7){
|
|
|
- $this->error('该身份没有权限');
|
|
|
- }
|
|
|
- $member_list = Db::name('store_member')->field('name,integral')->where('type',1)->where('integral','>',0)->order('integral desc')->select();
|
|
|
- if(empty($member_list)){
|
|
|
- $this->success('获取成功',array());
|
|
|
+ $type = input('type',1);
|
|
|
+ $page = input('page',1);
|
|
|
+ $pageSize = input('page_size',10);
|
|
|
+ $id_arr = Db::name('store_browse')->field('forum_id')->where('user_id',$uid)->where('status',1)->where('type',$type)->page($page,$pageSize)->order('id','desc')->column('forum_id');
|
|
|
+ if(empty($id_arr)){
|
|
|
+ $this->success('获取成功',[]);
|
|
|
}
|
|
|
- $this->success('获取成功',$member_list);
|
|
|
+ $list = $this->get_list($type,$id_arr,$page,$pageSize);
|
|
|
+ $this->success('获取成功',$list);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 员工考勤(领导)
|
|
|
- * @desc 员工考勤(领导)
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/attendance_list
|
|
|
+ * @title 我的点赞
|
|
|
+ * @desc 我的点赞
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/my_like
|
|
|
* @method GET
|
|
|
- * @tag 员工考勤(领导)
|
|
|
+ * @tag 我的点赞
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:workshop type:int require:1 default:-- desc:车间ID
|
|
|
- * @param name:date type:string require:1 default:-- desc:时间(格式:2021-06-30)
|
|
|
- * @return name:workshop type:string default:-- desc:车间名称
|
|
|
- * @return name:workshop_name type:string default:-- desc:车间主任姓名
|
|
|
- * @return name:workshop_num type:int default:-- desc:车间人数
|
|
|
- * @return name:should_workshop_num type:int default:-- desc:应出勤人数
|
|
|
- * @return name:attendance_num type:int default:-- desc:实际出勤人数
|
|
|
- * @return name:attendance_list type:array default:-- desc:出勤人名单(user_name:出勤人员姓名,attendance_time:出勤时长)
|
|
|
+ * @param name:type type:int require:0 default:1 desc:类型(1:新闻(默认),2:咨询)
|
|
|
+ * @param name:page type:int require:0 default:1 desc:页数(默认为1)
|
|
|
+ * @param name:page_size type:int require:0 default:10 desc:每页数量(默认为10)
|
|
|
+ * @return name:id type:int default:-- desc:新闻或咨询ID
|
|
|
+ * @return name:title type:string default:-- desc:标题
|
|
|
+ * @return name:content type:string default:-- desc:内容(咨询独有)
|
|
|
+ * @return name:image type:array default:-- desc:图片数组
|
|
|
+ * @return name:video type:string default:-- desc:视频地址
|
|
|
+ * @return name:is_top type:int default:-- desc:是否置顶(0:不置顶,1:置顶)(新闻独有)
|
|
|
+ * @return name:comment_num type:int default:-- desc:评论数量
|
|
|
+ * @return name:media_logo type:string default:-- desc:用户头像或媒体logo
|
|
|
+ * @return name:media_title type:string default:-- desc:用户姓名或媒体名称
|
|
|
+ * @return name:duration type:string default:-- desc:时长
|
|
|
*/
|
|
|
- public function attendance_list(){
|
|
|
+ public function my_like(){
|
|
|
$uid = $this->uid;
|
|
|
- $workshop = input('workshop');
|
|
|
- $date = input('date');
|
|
|
- if(empty($workshop) || empty($date)){
|
|
|
- $this->error('参数错误');
|
|
|
- }
|
|
|
- $member_info = Db::name('store_member')->field('type')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- if($type != 7){
|
|
|
- $this->error('该身份没有权限');
|
|
|
- }
|
|
|
- $workshop_name = Db::name('store_member')->where('type',3)->where('workshop',$workshop)->value('name');
|
|
|
- $attendance_list = Db::name('store_attendance')->field('user_name,attendance_time')->where('workshop',$workshop)->where('date',$date)->where('is_attendance',1)->select();
|
|
|
- if(empty($attendance_list)){
|
|
|
- $this->success('获取成功',array());
|
|
|
+ $type = input('type',1);
|
|
|
+ $page = input('page',1);
|
|
|
+ $pageSize = input('page_size',10);
|
|
|
+ $id_arr = Db::name('store_like')->field('forum_id')->where('user_id',$uid)->where('status',1)->where('type',$type)->page($page,$pageSize)->order('id','desc')->column('forum_id');
|
|
|
+ if(empty($id_arr)){
|
|
|
+ $this->success('获取成功',[]);
|
|
|
}
|
|
|
- //车间人数
|
|
|
- $workshop_num = Db::name('store_member')->field('id,name')->where('type',1)->where('workshop',$workshop)->count('id');
|
|
|
- //应出勤
|
|
|
- $should_workshop_num = Db::name('store_attendance')->where('workshop',$workshop)->where('date',$date)->count('id');
|
|
|
- $attendance_num = Db::name('store_attendance')->where('workshop',$workshop)->where('date',$date)->where('is_attendance',1)->count('id');
|
|
|
- $data = array(
|
|
|
- 'workshop' => workshop_arr()[$workshop],
|
|
|
- 'workshop_name' => $workshop_name,
|
|
|
- 'workshop_num' => $workshop_num,
|
|
|
- 'should_workshop_num' => $should_workshop_num,
|
|
|
- 'attendance_num' => $attendance_num,
|
|
|
- 'attendance_list' => $attendance_list
|
|
|
- );
|
|
|
- $this->success('获取成功',$data);
|
|
|
+ $list = $this->get_list($type,$id_arr,$page,$pageSize);
|
|
|
+ $this->success('获取成功',$list);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 员工计件(领导)
|
|
|
- * @desc 员工计件(领导)
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/product_case
|
|
|
+ * @title 我的评论
|
|
|
+ * @desc 我的评论
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/my_comment
|
|
|
* @method GET
|
|
|
- * @tag 员工计件(领导)
|
|
|
+ * @tag 我的评论
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:workshop type:int require:1 default:-- desc:车间ID
|
|
|
- * @param name:date type:string require:1 default:-- desc:时间(格式:2021-06-30)
|
|
|
- * @return name:workshop type:string default:-- desc:车间名称
|
|
|
- * @return name:workshop_name type:string default:-- desc:车间主任姓名
|
|
|
- * @return name:workshop_num type:int default:-- desc:车间人数
|
|
|
- * @return name:product_num type:int default:-- desc:生产件数
|
|
|
- * @return name:product_list type:array default:-- desc:生产件数详情(user_name:人员姓名,product_info:生产信息(数组:parts_num:数量,parts_name:部件名称))
|
|
|
+ * @param name:type type:int require:0 default:1 desc:类型(1:新闻(默认),2:咨询)
|
|
|
+ * @param name:page type:int require:0 default:1 desc:页数(默认为1)
|
|
|
+ * @param name:page_size type:int require:0 default:10 desc:每页数量(默认为10)
|
|
|
+ * @return name:id type:int default:-- desc:新闻或咨询ID
|
|
|
+ * @return name:title type:string default:-- desc:标题
|
|
|
+ * @return name:content type:string default:-- desc:内容(咨询独有)
|
|
|
+ * @return name:image type:array default:-- desc:图片数组
|
|
|
+ * @return name:video type:string default:-- desc:视频地址
|
|
|
+ * @return name:is_top type:int default:-- desc:是否置顶(0:不置顶,1:置顶)(新闻独有)
|
|
|
+ * @return name:comment_num type:int default:-- desc:评论数量
|
|
|
+ * @return name:media_logo type:string default:-- desc:用户头像或媒体logo
|
|
|
+ * @return name:media_title type:string default:-- desc:用户姓名或媒体名称
|
|
|
+ * @return name:duration type:string default:-- desc:时长
|
|
|
*/
|
|
|
- public function product_case(){
|
|
|
+ public function my_comment(){
|
|
|
$uid = $this->uid;
|
|
|
- $workshop = input('workshop');
|
|
|
- $date = input('date');
|
|
|
- if(empty($workshop) || empty($date)){
|
|
|
- $this->error('参数错误');
|
|
|
- }
|
|
|
- $member_info = Db::name('store_member')->field('type')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- if($type != 7){
|
|
|
- $this->error('该身份没有权限');
|
|
|
- }
|
|
|
- $workshop_name = Db::name('store_member')->where('type',3)->where('workshop',$workshop)->value('name');
|
|
|
- $product_list = Db::name('store_product_case')->field('user_name,product_info')->where('workshop',$workshop)->where('date',$date)->select();
|
|
|
- if(empty($product_list)){
|
|
|
- $this->success('获取成功',array());
|
|
|
+ $type = input('type',1);
|
|
|
+ $page = input('page',1);
|
|
|
+ $pageSize = input('page_size',10);
|
|
|
+ $id_arr = Db::name('store_comment')->field('forum_id')->where('user_id',$uid)->where('forum_type',$type)->where('type',1)->page($page,$pageSize)->order('id','desc')->column('forum_id');
|
|
|
+ if(empty($id_arr)){
|
|
|
+ $this->success('获取成功',[]);
|
|
|
}
|
|
|
- //车间人数
|
|
|
- $workshop_num = Db::name('store_member')->field('id,name')->where('type',1)->where('workshop',$workshop)->count('id');
|
|
|
- //生产件数
|
|
|
- $product_num = 0;
|
|
|
- foreach ($product_list as &$value){
|
|
|
- $value['product_info'] = json_decode($value['product_info'],true);
|
|
|
- foreach ($value['product_info'] as &$v){
|
|
|
- $v['parts_name'] = Db::name('store_parts')->where('id',$v['parts_id'])->value('name');
|
|
|
- $product_num += $v['parts_num'];
|
|
|
- unset($v['parts_id']);
|
|
|
+ $list = $this->get_list($type,$id_arr,$page,$pageSize);
|
|
|
+ $this->success('获取成功',$list);
|
|
|
+ }
|
|
|
+ public function get_list($type = 1,$id_arr = array(),$page = 1,$pageSize = 10){
|
|
|
+ if($type == 1){ //新闻
|
|
|
+ $field = 'id,title,user_id,image,video,is_top,create_at';
|
|
|
+ $list = Db::name('store_goods')->field($field)->where('status',1)->where('is_deleted',0)->where('id','in',$id_arr)->page($page,$pageSize)->order(['is_top'=>'desc','sort'=>'desc','id'=>'desc'])->select();
|
|
|
+ if($list){
|
|
|
+ foreach($list as &$value) {
|
|
|
+ //获取评论数量
|
|
|
+ $value['comment_num'] = Db::name('store_comment')->where('forum_id',$value['id'])->where('type',1)->where('forum_type',1)->count('id');
|
|
|
+ $value['image'] = image_path($value['image']);
|
|
|
+ //媒体信息
|
|
|
+ $media_info = Db::name('store_media')->field('logo,title')->where('id',$value['user_id'])->find();
|
|
|
+ $value['media_logo'] = $media_info['logo'];
|
|
|
+ $value['media_title'] = $media_info['title'];
|
|
|
+ $remain_time = time() - strtotime($value['create_at']);
|
|
|
+ $value['duration'] = get_stay_time($remain_time);
|
|
|
+ unset($value['user_id']);
|
|
|
+ unset($value['create_at']);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }else{ //咨询
|
|
|
+ $field = 'id,user_id,type,title,content,media_id,image,video,create_at';
|
|
|
+ $list = Db::name('store_consult')->field($field)->where('status',1)->where('is_deleted',0)->where('id','in',$id_arr)->page($page,$pageSize)->order(['sort'=>'desc','id'=>'desc'])->select();
|
|
|
+ if($list){
|
|
|
+ foreach($list as &$value) {
|
|
|
+ //获取评论数量
|
|
|
+ $value['comment_num'] = Db::name('store_comment')->where('forum_id',$value['id'])->where('type',1)->where('forum_type',2)->count('id');
|
|
|
+ $value['image'] = image_path($value['image']);
|
|
|
+ if($value['type'] == 1){ //后台媒体
|
|
|
+ //媒体信息
|
|
|
+ $media_info = Db::name('store_media')->field('logo,title')->where('id',$value['user_id'])->find();
|
|
|
+ $value['media_logo'] = $media_info['logo'];
|
|
|
+ $value['media_title'] = $media_info['title'];
|
|
|
+ }else{ //用户
|
|
|
+ //用户信息
|
|
|
+ $media_info = Db::name('store_member')->field('headimg,name')->where('id',$value['user_id'])->find();
|
|
|
+ $value['media_logo'] = $media_info['headimg'];
|
|
|
+ $value['media_title'] = $media_info['name'];
|
|
|
+ }
|
|
|
+ $remain_time = time() - strtotime($value['create_at']);
|
|
|
+ $value['duration'] = get_stay_time($remain_time);
|
|
|
+ unset($value['media_id']);
|
|
|
+ unset($value['user_id']);
|
|
|
+ unset($value['type']);
|
|
|
+ unset($value['create_at']);
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
- $data = array(
|
|
|
- 'workshop' => workshop_arr()[$workshop],
|
|
|
- 'workshop_name' => $workshop_name,
|
|
|
- 'workshop_num' => $workshop_num,
|
|
|
- 'product_num' => $product_num,
|
|
|
- 'product_list' => $product_list
|
|
|
- );
|
|
|
- $this->success('获取成功',$data);
|
|
|
+ return $list;
|
|
|
}
|
|
|
/**
|
|
|
- * @title 工作圈(领导)
|
|
|
- * @desc 工作圈(领导)
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/work_circle
|
|
|
+ * @title 消息列表
|
|
|
+ * @desc 消息列表
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/news_list
|
|
|
* @method GET
|
|
|
- * @tag 工作圈(领导)
|
|
|
+ * @tag 消息列表
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
* @param name:page type:int require:0 default:1 desc:页数(默认为1)
|
|
|
* @param name:page_size type:int require:0 default:10 desc:每页数量(默认为10)
|
|
|
- * @param name:keyword type:string require:0 default:-- desc:搜索的关键词
|
|
|
- * @param name:start_time type:string require:0 default:-- desc:开始时间(格式:2021-05-14)
|
|
|
- * @param name:end_time type:string require:0 default:-- desc:结束时间(格式:2021-05-15)
|
|
|
- * @return name:question type:string default:-- desc:生产说明文字
|
|
|
- * @return name:images type:string default:-- desc:生成图片地址(数组)
|
|
|
- * @return name:create_at type:string default:-- desc:反馈时间
|
|
|
- * @return name:user_headimg type:string default:-- desc:反馈人头像地址
|
|
|
- * @return name:user_name type:string default:-- desc:反馈人姓名
|
|
|
- * @return name:workshop_name type:string default:-- desc:反馈人归属车间名或厂长,副厂长
|
|
|
+ * @return name:-- type:array default:-- desc:消息信息(content:内容,type:类型(1:系统消息,2:用户消息),icon:消息前面的图标,type_name:消息类型名称,duration:时长)
|
|
|
*/
|
|
|
- public function work_circle(){
|
|
|
+ public function news_list(){
|
|
|
$uid = $this->uid;
|
|
|
$page = input('page',1);
|
|
|
$pageSize = input('page_size',10);
|
|
|
- $keyword = input('keyword');
|
|
|
- $start_time = input('start_time');
|
|
|
- $end_time = input('end_time');
|
|
|
- $where = 'type = 1';
|
|
|
- if($keyword){
|
|
|
- $where .= " and question like '%".$keyword."%'";
|
|
|
- }
|
|
|
- if($start_time && $end_time){
|
|
|
- $start_time = $start_time.' 00:00:00';
|
|
|
- $end_time = $end_time.' 24:00:00';
|
|
|
- $complain_list = Db::name('store_complain')->field('user_id,question,images,create_at')->whereBetweenTime('create_at',$start_time,$end_time)->where($where)->order('id desc')->page($page,$pageSize)->select();
|
|
|
- }else{
|
|
|
- $complain_list = Db::name('store_complain')->field('user_id,question,images,create_at')->where($where)->order('id desc')->page($page,$pageSize)->select();
|
|
|
- }
|
|
|
- if(empty($complain_list)){
|
|
|
- $this->success('获取成功',array());
|
|
|
- }
|
|
|
- foreach ($complain_list as &$value){
|
|
|
- $value['images'] = image_path($value['images']);
|
|
|
- $member_info = Db::name('store_member')->field('headimg,name,workshop,type')->where('id',$value['user_id'])->find();
|
|
|
- $value['user_headimg'] = $member_info['headimg'];
|
|
|
- $value['user_name'] = $member_info['name'];
|
|
|
- if($member_info['type'] == 3){
|
|
|
- $value['workshop_name'] = workshop_arr()[$member_info['workshop']];
|
|
|
- }elseif ($member_info['type'] == 5){
|
|
|
- $value['workshop_name'] = '副厂长';
|
|
|
- }elseif ($member_info['type'] == 6){
|
|
|
- $value['workshop_name'] = '厂长';
|
|
|
+ $news_list = Db::name('store_news')->field('content,type,comment_user_id,create_at')->where('user_id',$uid)->page($page,$pageSize)->order('id','desc')->select();
|
|
|
+ $type_arr = array('1'=>'系统消息','2'=>'用户消息');
|
|
|
+ if($news_list){
|
|
|
+ foreach ($news_list as &$value){
|
|
|
+ if($value['type'] == 1){
|
|
|
+ $value['icon'] = 'https://zjth2021.oss-cn-beijing.aliyuncs.com/164e89b793f57189/eea68607b8a59a4b.png';
|
|
|
+ }else{
|
|
|
+ $value['icon'] = Db::name('store_member')->where('id',$value['comment_user_id'])->value('headimg');
|
|
|
+ }
|
|
|
+ $value['type_name'] = $type_arr[$value['type']];
|
|
|
+ $remain_time = time() - strtotime($value['create_at']);
|
|
|
+ $value['duration'] = get_stay_time($remain_time);
|
|
|
+ unset($value['comment_user_id']);
|
|
|
+ unset($value['create_at']);
|
|
|
}
|
|
|
- unset($value['user_id']);
|
|
|
}
|
|
|
- $this->success('获取成功',$complain_list);
|
|
|
+ //未读改成已读
|
|
|
+ Db::name('store_news')->where('user_id',$uid)->where('status',0)->update(array('status'=>1));
|
|
|
+ $this->success('获取成功',$news_list);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 生产统计(领导)
|
|
|
- * @desc 生产统计(领导)
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/product_statistics
|
|
|
- * @method GET
|
|
|
- * @tag 生产统计(领导)
|
|
|
+ * @title 平台反馈
|
|
|
+ * @desc 平台反馈
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/submit_complain
|
|
|
+ * @method POST
|
|
|
+ * @tag 平台反馈
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:start_time type:string require:0 default:-- desc:开始时间(格式:2021-05-14)
|
|
|
- * @param name:end_time type:string require:0 default:-- desc:结束时间(格式:2021-05-15)
|
|
|
- * @return name:question type:string default:-- desc:生产说明文字
|
|
|
- * @return name:images type:string default:-- desc:生成图片地址(数组)
|
|
|
- * @return name:create_at type:string default:-- desc:反馈时间
|
|
|
- * @return name:user_headimg type:string default:-- desc:反馈人头像地址
|
|
|
- * @return name:user_name type:string default:-- desc:反馈人姓名
|
|
|
- * @return name:workshop_name type:string default:-- desc:反馈人归属车间名或厂长,副厂长
|
|
|
+ * @param name:explain type:string require:1 default:-- desc:反馈内容
|
|
|
+ * @param name:images type:string require:1 default:-- desc:反馈的图片地址,多张图片以英文逗号(,)分隔
|
|
|
*/
|
|
|
- public function product_statistics(){
|
|
|
+ public function submit_complain(){
|
|
|
$uid = $this->uid;
|
|
|
- $start_time = input('start_time');
|
|
|
- $end_time = input('end_time');
|
|
|
- $member_info = Db::name('store_member')->field('type')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- if($type != 7){
|
|
|
- $this->error('该身份没有权限');
|
|
|
+ $explain = input('explain');
|
|
|
+ $images = input('images');
|
|
|
+ if(empty($explain) || empty($images)){
|
|
|
+ $this->error('参数错误');
|
|
|
}
|
|
|
- //共生产的数量
|
|
|
- $workshop = array();
|
|
|
- if($start_time && $end_time){
|
|
|
- $start_time = $start_time.' 00:00:00';
|
|
|
- $end_time = $end_time.' 24:00:00';
|
|
|
- $num_all = Db::name('store_product_case')->whereBetweenTime('create_at',$start_time,$end_time)->sum('product_num');
|
|
|
- foreach (workshop_arr() as $key=>$value){
|
|
|
- $num = Db::name('store_product_case')->where('workshop',$key)->whereBetweenTime('create_at',$start_time,$end_time)->sum('product_num');
|
|
|
- $workshop[$key-1]['workshop_name'] = $value;
|
|
|
- $workshop[$key-1]['num'] = $num;
|
|
|
- }
|
|
|
+ $data = [
|
|
|
+ 'user_id' => $uid,
|
|
|
+ 'question' => $explain,
|
|
|
+ 'images' => $images,
|
|
|
+ 'type' => 2,
|
|
|
+ 'date' => date('Y-m-d')
|
|
|
+ ];
|
|
|
+ $res = Db::name('store_complain')->insert($data);
|
|
|
+ if($res !==false){
|
|
|
+ $this->success('提交成功');
|
|
|
}else{
|
|
|
- $num_all = Db::name('store_product_case')->sum('product_num');
|
|
|
- foreach (workshop_arr() as $key=>$value){
|
|
|
- $num = Db::name('store_product_case')->where('workshop',$key)->sum('product_num');
|
|
|
- $workshop[$key-1]['workshop_name'] = $value;
|
|
|
- $workshop[$key-1]['num'] = $num;
|
|
|
- }
|
|
|
+ $this->error('提交失败');
|
|
|
}
|
|
|
- $data = array(
|
|
|
- 'num_all' => $num_all,
|
|
|
- 'workshop' => $workshop
|
|
|
- );
|
|
|
- $this->success('获取成功',$data);
|
|
|
}
|
|
|
/**
|
|
|
- * @title 统计详情(领导)
|
|
|
- * @desc 统计详情(领导)
|
|
|
- * @author HG
|
|
|
- * @url /api/Member/statistics_detail
|
|
|
- * @method GET
|
|
|
- * @tag 统计详情(领导)
|
|
|
+ * @title 发表咨询
|
|
|
+ * @desc 发表咨询
|
|
|
+ * @author QGF
|
|
|
+ * @url /api/Member/publish_consult
|
|
|
+ * @method POST
|
|
|
+ * @tag 发表咨询
|
|
|
* @header name:Authorization require:1 desc:Token
|
|
|
- * @param name:workshop type:int require:1 default:-- desc:车间ID
|
|
|
- * @return name:workshop_name type:string default:-- desc:车间名称
|
|
|
- * @return name:num_all type:int default:-- desc:生产总数量
|
|
|
- * @return name:product_info type:array default:-- desc:生成详情(parts_name:部件名称,num:数量)
|
|
|
+ * @param name:cate_id type:int require:1 default:-- desc:咨询分类ID
|
|
|
+ * @param name:title type:string require:1 default:-- desc:咨询标题
|
|
|
+ * @param name:content type:string require:1 default:-- desc:咨询内容
|
|
|
+ * @param name:image type:string require:1 default:-- desc:咨询图片,多张图片以英文逗号分隔
|
|
|
+ * @param name:video type:string require:0 default:-- desc:咨询视频
|
|
|
*/
|
|
|
- public function statistics_detail(){
|
|
|
+ public function publish_consult(){
|
|
|
$uid = $this->uid;
|
|
|
- $workshop = input('workshop');
|
|
|
- if(empty($workshop)){
|
|
|
+ $cate_id = input('cate_id');
|
|
|
+ $title = input('title');
|
|
|
+ $content = input('content');
|
|
|
+ $image = input('image');
|
|
|
+ $video = input('video');
|
|
|
+ if(empty($cate_id) || empty($title) || empty($image) || empty($content)){
|
|
|
$this->error('参数错误');
|
|
|
}
|
|
|
- $member_info = Db::name('store_member')->field('type')->where('id',$uid)->find();
|
|
|
- $type = $member_info['type'];
|
|
|
- if($type != 7){
|
|
|
- $this->error('该身份没有权限');
|
|
|
- }
|
|
|
- $workshop_name = workshop_arr()[$workshop];
|
|
|
- $num = Db::name('store_product_case')->where('workshop',$workshop)->sum('product_num');
|
|
|
- $product_case = Db::name('store_product_case')->field('product_info')->where('workshop',$workshop)->select();
|
|
|
- if(empty($product_case)){
|
|
|
- $this->success('获取成功',$product_case);
|
|
|
- }
|
|
|
- $product_info = array();
|
|
|
- foreach ($product_case as $value){
|
|
|
- $product_arr = json_decode($value['product_info'],true);
|
|
|
- foreach ($product_arr as $v){
|
|
|
- if(!in_array($v['parts_id'],array_keys($product_info))){
|
|
|
- $product_info[$v['parts_id']] = $v['parts_num'];
|
|
|
- }else{
|
|
|
- foreach ($product_info as $key=>&$product_value){
|
|
|
- if($key == $v['parts_id']){
|
|
|
- $product_value = $product_value + $v['parts_num'];
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- $case_info = array();
|
|
|
- $arr = array();
|
|
|
- if($product_info){
|
|
|
- foreach ($product_info as $product_key=>$product_info_value){
|
|
|
- $arr['parts_name'] = Db::name('store_parts')->where('id',$product_key)->value('name');
|
|
|
- $arr['num'] = intval($product_info_value);
|
|
|
- array_push($case_info,$arr);
|
|
|
- }
|
|
|
+ $data = [
|
|
|
+ 'user_id' => $uid,
|
|
|
+ 'cate_id' => $cate_id,
|
|
|
+ 'title' => $title,
|
|
|
+ 'content' => $content,
|
|
|
+ 'image' => $image,
|
|
|
+ 'video' => $video,
|
|
|
+ 'type' => 2
|
|
|
+ ];
|
|
|
+ $res = Db::name('store_consult')->insert($data);
|
|
|
+ if($res !==false){
|
|
|
+ $this->success('发布成功');
|
|
|
+ }else{
|
|
|
+ $this->error('发布失败');
|
|
|
}
|
|
|
- $data = array(
|
|
|
- 'workshop_name' => $workshop_name,
|
|
|
- 'num_all' => $num,
|
|
|
- 'product_info' => $case_info
|
|
|
- );
|
|
|
- $this->success('获取成功',$data);
|
|
|
}
|
|
|
}
|