This commit is contained in:
weiz 2024-04-09 11:22:24 +08:00
parent 3a12e761c9
commit e79af98d1d
9 changed files with 143 additions and 135 deletions

View File

@ -66,7 +66,7 @@
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty(); $contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty(); $custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id'); $dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id');
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id'); $admin = Admin::where('id', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id');
$data['framework_agreement_name'] = $contract['contract_name']; $data['framework_agreement_name'] = $contract['contract_name'];
$data['part_a_name'] = $custom['name']; $data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']]; $data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];

View File

@ -64,7 +64,7 @@
->select()->each(function ($data) { ->select()->each(function ($data) {
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty(); $custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty(); $dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty();
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['seal_user']])->column('name', 'id'); $admin = Admin::where('id', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['seal_user']])->column('name', 'id');
$data['part_a_name'] = $custom['name']; $data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']]; $data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];
$data['signed_dept_name'] = $dept['name']; $data['signed_dept_name'] = $dept['name'];

View File

@ -65,7 +65,7 @@
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty(); $contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty(); $custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty(); $dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty();
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['seal_user']])->column('name', 'id'); $admin = Admin::where('id', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['seal_user']])->column('name', 'id');
$data['supplementary_agreement_name'] = $contract['contract_name']; $data['supplementary_agreement_name'] = $contract['contract_name'];
$data['part_a_name'] = $custom['name']; $data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']]; $data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];

View File

@ -41,7 +41,7 @@
public function setSearch(): array public function setSearch(): array
{ {
return [ return [
'=' => ['project_id'] '=' => ['attendance_id', 'project_id']
]; ];
} }

View File

@ -191,7 +191,7 @@
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty(); $contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty(); $custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id'); $dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id');
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id'); $admin = Admin::where('id', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id');
$data['framework_agreement_name'] = $contract['contract_name']; $data['framework_agreement_name'] = $contract['contract_name'];
$data['part_a_name'] = $custom['name']; $data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']]; $data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];

View File

@ -166,7 +166,7 @@
$data = MarketingContract::withoutField('update_time,delete_time')->findOrEmpty($params['id']); $data = MarketingContract::withoutField('update_time,delete_time')->findOrEmpty($params['id']);
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty(); $custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty(); $dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty();
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['seal_user']])->column('name', 'id'); $admin = Admin::where('id', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['seal_user']])->column('name', 'id');
$data['part_a_name'] = $custom['name']; $data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']]; $data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];
$data['signed_dept_name'] = $dept['name']; $data['signed_dept_name'] = $dept['name'];

View File

@ -163,7 +163,7 @@
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty(); $contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty(); $custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty(); $dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty();
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['seal_user']])->column('name', 'id'); $admin = Admin::where('id', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['seal_user']])->column('name', 'id');
$data['supplementary_agreement_name'] = $contract['contract_name']; $data['supplementary_agreement_name'] = $contract['contract_name'];
$data['part_a_name'] = $custom['name']; $data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']]; $data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];

View File

@ -11,124 +11,133 @@
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
// | author: likeadminTeam // | author: likeadminTeam
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
namespace app\adminapi\logic\project; namespace app\adminapi\logic\project;
use app\common\model\project\Project; use app\common\logic\BaseLogic;
use app\common\model\project\ProjectAttendanceDetail; use app\common\model\project\Project;
use app\common\logic\BaseLogic; use app\common\model\project\ProjectAttendanceDetail;
use app\common\model\project\ProjectPersonnel; use app\common\model\project\ProjectAttendanceRecord;
use think\facade\Db; use app\common\model\project\ProjectPersonnel;
use think\facade\Db;
/**
* 考勤明细逻辑 /**
* Class ProjectAttendanceDetailLogic * 考勤明细逻辑
* @package app\adminapi\logic\project * Class ProjectAttendanceDetailLogic
*/ * @package app\adminapi\logic\project
class ProjectAttendanceDetailLogic extends BaseLogic */
{ class ProjectAttendanceDetailLogic extends BaseLogic
{
/**
* @notes 添加考勤明细 /**
* @param array $params * @notes 添加考勤明细
* @return bool * @param array $params
* @author likeadmin * @return bool
* @date 2023/12/26 10:54 * @author likeadmin
*/ * @date 2023/12/26 10:54
public static function add(array $params): bool */
{ public static function add(array $params): bool
Db::startTrans(); {
try { $attendance = ProjectAttendanceRecord::field('project_id')->where('id', $params['attendance_id'])->findOrEmpty();
ProjectAttendanceDetail::create([ Db::startTrans();
'project_id' => $params['project_id'], try {
'person_id' => $params['person_id'], ProjectAttendanceDetail::create([
'attendance_date' => strtotime($params['attendance_date']), 'attendance_id' => $params['attendance_id'],
'work_start_time' => strtotime($params['work_start_time']), 'project_id' => $attendance['project_id'],
'work_end_time' => strtotime($params['work_end_time']), 'person_id' => $params['person_id'],
'work_record_num' => $params['work_record_num'], 'attendance_date' => strtotime($params['attendance_date']),
'daily_salary' => $params['daily_salary'], 'work_start_time' => strtotime($params['work_start_time']),
'daily_living' => $params['daily_living'], 'work_end_time' => strtotime($params['work_end_time']),
'daily_subsidy' => $params['daily_subsidy'], 'work_record_num' => $params['work_record_num'],
'daily_other' => $params['daily_other'], 'daily_salary' => $params['daily_salary'],
'daily_income' => $params['daily_income'], 'daily_living' => $params['daily_living'],
'remark' => $params['remark'], 'daily_subsidy' => $params['daily_subsidy'],
]); 'daily_other' => $params['daily_other'],
Db::commit(); 'daily_income' => $params['daily_income'],
return true; 'remark' => $params['remark'],
} catch (\Exception $e) { ]);
Db::rollback(); Db::commit();
self::setError($e->getMessage()); return true;
return false; } catch (\Exception $e) {
} Db::rollback();
} self::setError($e->getMessage());
return false;
}
/** }
* @notes 编辑考勤明细
* @param array $params
* @return bool /**
* @author likeadmin * @notes 编辑考勤明细
* @date 2023/12/26 10:54 * @param array $params
*/ * @return bool
public static function edit(array $params): bool * @author likeadmin
{ * @date 2023/12/26 10:54
Db::startTrans(); */
try { public static function edit(array $params): bool
ProjectAttendanceDetail::where('id', $params['id'])->update([ {
'attendance_date' => strtotime($params['attendance_date']), $attendance = ProjectAttendanceRecord::field('project_id')->where('id', $params['attendance_id'])->findOrEmpty();
'work_start_time' => strtotime($params['work_start_time']), Db::startTrans();
'work_end_time' => strtotime($params['work_end_time']), try {
'work_record_num' => $params['work_record_num'], ProjectAttendanceDetail::where('id', $params['id'])->update([
'daily_salary' => $params['daily_salary'], 'attendance_id' => $params['attendance_id'],
'daily_living' => $params['daily_living'], 'project_id' => $attendance['project_id'],
'daily_subsidy' => $params['daily_subsidy'], 'person_id' => $params['person_id'],
'daily_other' => $params['daily_other'], 'attendance_date' => strtotime($params['attendance_date']),
'daily_income' => $params['daily_income'], 'work_start_time' => strtotime($params['work_start_time']),
'remark' => $params['remark'], 'work_end_time' => strtotime($params['work_end_time']),
]); 'work_record_num' => $params['work_record_num'],
Db::commit(); 'daily_salary' => $params['daily_salary'],
return true; 'daily_living' => $params['daily_living'],
} catch (\Exception $e) { 'daily_subsidy' => $params['daily_subsidy'],
Db::rollback(); 'daily_other' => $params['daily_other'],
self::setError($e->getMessage()); 'daily_income' => $params['daily_income'],
return false; 'remark' => $params['remark'],
} ]);
} Db::commit();
return true;
} catch (\Exception $e) {
/** Db::rollback();
* @notes 删除考勤明细 self::setError($e->getMessage());
* @param array $params return false;
* @return bool }
* @author likeadmin }
* @date 2023/12/26 10:54
*/
public static function delete(array $params): bool /**
{ * @notes 删除考勤明细
return ProjectAttendanceDetail::destroy($params['id']); * @param array $params
} * @return bool
* @author likeadmin
* @date 2023/12/26 10:54
/** */
* @notes 获取考勤明细详情 public static function delete(array $params): bool
* @param $params {
* @return array return ProjectAttendanceDetail::destroy($params['id']);
* @author likeadmin }
* @date 2023/12/26 10:54
*/
public static function detail($params): array /**
{ * @notes 获取考勤明细详情
$data = ProjectAttendanceDetail::findOrEmpty($params['id'])->toArray(); * @param $params
$project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); * @return array
$person = ProjectPersonnel::field('name,idcard,work_type')->where('id',$data['person_id'])->findOrEmpty(); * @author likeadmin
$data['project_name'] = $project['name']; * @date 2023/12/26 10:54
$data['project_code'] = $project['project_code']; */
$data['person_name'] = $person['name']; public static function detail($params): array
$data['person_idcard'] = $person['idcard']; {
$data['work_type_text'] = $person->work_type_text; $data = ProjectAttendanceDetail::findOrEmpty($params['id'])->toArray();
return $data; $attendance = ProjectAttendanceRecord::field('attendance_code')->where('id', $params['attendance_id'])->findOrEmpty();
} $project = Project::field('name,project_code')->where('id', $data['project_id'])->findOrEmpty();
} $person = ProjectPersonnel::field('name,idcard,work_type')->where('id', $data['person_id'])->findOrEmpty();
$data['attendance_code'] = $attendance['attendance_code'];
$data['project_name'] = $project['name'];
$data['project_code'] = $project['project_code'];
$data['person_name'] = $person['name'];
$data['person_idcard'] = $person['idcard'];
$data['work_type_text'] = $person->work_type_text;
return $data;
}
}

View File

@ -15,7 +15,7 @@
namespace app\adminapi\validate\project; namespace app\adminapi\validate\project;
use app\common\model\project\Project; use app\common\model\project\ProjectAttendanceRecord;
use app\common\model\project\ProjectPersonnel; use app\common\model\project\ProjectPersonnel;
use app\common\validate\BaseValidate; use app\common\validate\BaseValidate;
@ -34,7 +34,7 @@
*/ */
protected $rule = [ protected $rule = [
'id' => 'require', 'id' => 'require',
'project_id' => 'require|checkProject', 'attendance_id' => 'require|checkAttendance',
'person_id' => 'require|checkPerson', 'person_id' => 'require|checkPerson',
'attendance_date' => 'require|dateFormat:Y-m-d', 'attendance_date' => 'require|dateFormat:Y-m-d',
'work_start_time' => 'dateFormat:H:i', 'work_start_time' => 'dateFormat:H:i',
@ -49,7 +49,7 @@
protected $message = [ protected $message = [
'id.require' => '缺少必要参数', 'id.require' => '缺少必要参数',
'project_id.require' => '请选择项目', 'attendance_id.require' => '请选择考勤记录',
'person_id.require' => '请选择项目人员', 'person_id.require' => '请选择项目人员',
'attendance_date.require' => '请选择考勤日期', 'attendance_date.require' => '请选择考勤日期',
'attendance_date.dateFormat' => '考勤日期格式错误', 'attendance_date.dateFormat' => '考勤日期格式错误',
@ -92,7 +92,6 @@
*/ */
public function sceneEdit() public function sceneEdit()
{ {
return $this->only(['id', 'attendance_date', 'work_start_time', 'work_end_time', 'work_record_num', 'daily_salary', 'daily_living', 'daily_subsidy', 'daily_other', 'daily_income']);
} }
/** /**
@ -118,11 +117,11 @@
return $this->only(['id']); return $this->only(['id']);
} }
public function checkProject($value): bool|string public function checkAttendance($value): bool|string
{ {
$data = Project::where('id', $value)->findOrEmpty(); $data = ProjectAttendanceRecord::where('id', $value)->findOrEmpty();
if ($data->isEmpty()) { if ($data->isEmpty()) {
return '项目不存在'; return '考勤记录信息不存在';
} }
return true; return true;
} }