Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Contractor appraisal letter #3687

4 changes: 2 additions & 2 deletions Modules/Salary/Http/Controllers/SalaryController.php
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ public function storeOrUpdateContractorSalary(Request $request, Employee $employ
return redirect()->back()->with('success', $message);
}


public function generateAppraisalLetter(Request $request, Employee $employee)
{
$salaryService = new SalaryCalculationService($request->grossSalary);
Expand All @@ -72,8 +73,7 @@ public function generateAppraisalLetter(Request $request, Employee $employee)

return $pdf->inline($employee->user->name . '_Increment Letter_' . Carbon::parse($request->commencementDate)->format('jS F Y') . '.pdf');
} elseif ($employee->payroll_type === 'contractor') {
$pdf = $salaryService->getContractorOnboardingLetterPdf($request->all());

$pdf = $salaryService->getContractorOnboardingLetterPdf($request->all(), $employee);
return $pdf->inline($employee->user->name . '_Onboarding Letter_' . Carbon::parse($request->commencementDate)->format('jS F Y') . '.pdf');
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,11 +52,11 @@
}
.address{
font-weight: bold;

}
.address span {
font-size: 14px !important

}
.pay-details{
font-size: 14px;
Expand Down

Large diffs are not rendered by default.

19 changes: 19 additions & 0 deletions Modules/Salary/Resources/views/render/footer.blade.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
.footer {
width: 100%;
text-align: center;
}
</style>
</head>
<body>
<div class="footer">
ColoredCow Consulting Pvt. Ltd. | +91 9818571035 | [email protected] | F-61 Suncity,
Sector 54, Gurgaon, India | CIN No. U72900HR2019PTC081234 | https://coloredcow.com/
</div>
</body>
</html>
19 changes: 19 additions & 0 deletions Modules/Salary/Resources/views/render/header.blade.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
.header {
width: 100%;
text-align: center;
}
</style>
</head>
<body>
<div class="header">
<img src="{{ public_path('images/coloredcow.png') }}" alt="">
<hr>
</div>
</body>
</html>
60 changes: 59 additions & 1 deletion Modules/Salary/Services/SalaryCalculationService.php
Original file line number Diff line number Diff line change
Expand Up @@ -206,12 +206,70 @@ public function getIncrementLetterPdf($data)
return $pdf;
}

public function getContractorOnboardingLetterPdf($data)
public function getEmployeeAddressDetail($employee)
{
$user = $employee->user;
$userProfile = $user->profile;
$address = $userProfile->address;
return $address;
}

public function getEmployeeAge($employee)
{
$age = $employee->user->getUserAge($employee->user_id);
return $age;
}

public function getEmployeeDesignation($employee)
{
$user = $employee->user;
$userProfile = $user->profile;
$designation = $userProfile->designation;
return $designation;
}

public function getSalaryPackage($data)
{
$formattedNumber = $data / 100000;
return number_format($formattedNumber, 1);
}

public function getTransportAllowance()
{
return (int) $this->salaryConfig->get('transport_allowance')->fixed_amount;
}

public function epfShare($basicSalary)
{
$basicSalaryConfig = $this->salaryConfig->get('basic_salary');

$epfShare =($basicSalaryConfig->percentage_rate / 100) * $basicSalary;

return $epfShare;
}

public function getContractorOnboardingLetterPdf($data, $employee)
{
$commencementDate = Carbon::parse($data['commencementDate'])->format('jS F Y');
$data['formattedCommencementDate'] = $commencementDate;
$data['employeeAddress'] = $this->getEmployeeAddressDetail($employee);
$data['employeeAge'] = $this->getEmployeeAge($employee);
$data['employeeDesignation'] = $this->getEmployeeDesignation($employee);
$data['salaryPackage'] = $this->getSalaryPackage($data['ctcAggregated']);
$employeeFirstName = explode(' ', $employee->name)[0];
$data['employeeFirstName'] = $employeeFirstName;
$data['employee'] = $employee;
$data['basicSalary'] = $this->basicSalary();
$data['otherAllowance'] = $this->employeeOtherAllowance($data['grossSalary']);
$data['hra'] = $this-> hra();
$data['transportAllowance'] = $this->getTransportAllowance();
$data['epfShare'] = $this->epfShare($this->basicSalary());
$pdf = App::make('snappy.pdf.wrapper');
$template = 'contractor-onboarding-template';
$html = view('salary::render.' . $template, compact('data'));
$pdf->loadHTML($html);
$pdf->setOption('header-html', view('salary::render.header')->render());
$pdf->setOption('footer-html', view('salary::render.footer')->render());

return $pdf;
}
Expand Down
7 changes: 1 addition & 6 deletions Modules/Salary/Services/SalaryService.php
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ public function storeOrUpdateSalary($request, $employee)

$appraisalData = $salaryService->appraisalLetterData($request, $employee);
if ($employee->staff_type === 'Contractor') {
$pdf = $salaryService->getContractorOnboardingLetterPdf($appraisalData);
$pdf = $salaryService->getContractorOnboardingLetterPdf($appraisalData, $employee);
Mail::to($data['employeeEmail'])->send(new SendContractorOnboardingLetterMail($data, $pdf->inline($data['employeeName'] . '_Onboarding Letter_' . $formattedCommencementDate . '.pdf'), $formattedCommencementDate));
} else {
$pdf = $salaryService->getAppraisalLetterPdf($appraisalData);
Expand Down Expand Up @@ -173,11 +173,6 @@ public function storeOrUpdateContractorSalary($request, $employee)
$currentSalaryObject->tds = $request->tds;
$currentSalaryObject->save();

$userProfile = $employee->user->profile;
if (! $userProfile) {
$this->createUserProfileAndUpdate($request, $employee);
}

return 'Contractor fee updated successfully!';
}

Expand Down
12 changes: 12 additions & 0 deletions Modules/User/Entities/User.php
Original file line number Diff line number Diff line change
Expand Up @@ -235,4 +235,16 @@ protected static function newFactory()
{
return new UserFactory();
}

public function getUserAge($userId)
{
$userProfile = UserProfile::where('user_id', $userId)->first();

if ($userProfile) {
$age = $userProfile->age;
return $age;
}

return null;
}
}
7 changes: 7 additions & 0 deletions Modules/User/Entities/UserProfile.php
Original file line number Diff line number Diff line change
@@ -1,11 +1,18 @@
<?php

namespace Modules\User\Entities;
use Carbon\Carbon;

use Illuminate\Database\Eloquent\Model;

class UserProfile extends Model
{
protected $table = 'user_profiles';
protected $guarded = [];

public function getAgeAttribute()
{
$dob = Carbon::parse($this->date_of_birth);
return $dob->age;
}
}
Loading