Enhances employee details with comprehensive salary and HR data
Adds detailed salary rates, commission structures, and HR-related records Introduces new data models and view components for: - Salary rates and supplements - Commissions and rate configurations - Employee HR tracking (certifications, courses, absence) Implements dynamic rate synchronization between drawer and card views
This commit is contained in:
parent
2e6207bb0b
commit
f71f00099a
15 changed files with 1589 additions and 137 deletions
|
|
@ -1,44 +1,183 @@
|
|||
@model PlanTempus.Application.Features.Employees.Components.EmployeeDetailHRViewModel
|
||||
|
||||
<swp-detail-grid>
|
||||
<swp-card>
|
||||
<swp-section-label>@Model.LabelDocuments</swp-section-label>
|
||||
<swp-document-list>
|
||||
<swp-document-item>
|
||||
<i class="ph ph-file-pdf"></i>
|
||||
<swp-document-name>@Model.LabelContract</swp-document-name>
|
||||
<swp-document-date>15. aug 2019</swp-document-date>
|
||||
</swp-document-item>
|
||||
<swp-document-item>
|
||||
<i class="ph ph-file-pdf"></i>
|
||||
<swp-document-name>Lønaftale 2024</swp-document-name>
|
||||
<swp-document-date>1. jan 2024</swp-document-date>
|
||||
</swp-document-item>
|
||||
</swp-document-list>
|
||||
</swp-card>
|
||||
<!-- Left column -->
|
||||
<div>
|
||||
<!-- Contract & Documents -->
|
||||
<swp-card>
|
||||
<swp-section-label>@Model.LabelContractDocuments</swp-section-label>
|
||||
|
||||
<swp-edit-section>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>@Model.LabelContractType</swp-edit-label>
|
||||
<swp-edit-select>
|
||||
<select>
|
||||
@foreach (var option in Model.ContractTypeOptions)
|
||||
{
|
||||
<option selected="@(option == Model.ContractType)">@option</option>
|
||||
}
|
||||
</select>
|
||||
</swp-edit-select>
|
||||
</swp-edit-row>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>@Model.LabelTerminationNotice</swp-edit-label>
|
||||
<swp-edit-select>
|
||||
<select>
|
||||
@foreach (var option in Model.TerminationNoticeOptions)
|
||||
{
|
||||
<option selected="@(option == Model.TerminationNotice)">@option</option>
|
||||
}
|
||||
</select>
|
||||
</swp-edit-select>
|
||||
</swp-edit-row>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>@Model.LabelContractExpiry</swp-edit-label>
|
||||
<swp-edit-value>@Model.ContractExpiry</swp-edit-value>
|
||||
</swp-edit-row>
|
||||
</swp-edit-section>
|
||||
|
||||
<swp-document-list style="margin-top: var(--spacing-6);">
|
||||
@foreach (var doc in Model.Documents)
|
||||
{
|
||||
<swp-document-item>
|
||||
<i class="ph ph-file-pdf"></i>
|
||||
<swp-document-info>
|
||||
<swp-document-name>@doc.Name</swp-document-name>
|
||||
<swp-document-meta>@doc.UploadDate</swp-document-meta>
|
||||
</swp-document-info>
|
||||
<swp-document-actions>
|
||||
<swp-btn class="secondary sm">Vis</swp-btn>
|
||||
</swp-document-actions>
|
||||
</swp-document-item>
|
||||
}
|
||||
</swp-document-list>
|
||||
|
||||
<swp-add-button>+ @Model.LabelUploadDocument</swp-add-button>
|
||||
</swp-card>
|
||||
|
||||
<!-- Planned absence -->
|
||||
<swp-card>
|
||||
<swp-section-label>@Model.LabelPlannedAbsence</swp-section-label>
|
||||
<swp-simple-list>
|
||||
@foreach (var absence in Model.PlannedAbsences)
|
||||
{
|
||||
<swp-simple-item>
|
||||
<swp-simple-item-text>@absence.Dates</swp-simple-item-text>
|
||||
<swp-status-badge class="@absence.TypeClass">@absence.Type</swp-status-badge>
|
||||
</swp-simple-item>
|
||||
}
|
||||
</swp-simple-list>
|
||||
<swp-add-button>+ @Model.LabelAddAbsence</swp-add-button>
|
||||
</swp-card>
|
||||
</div>
|
||||
|
||||
<!-- Right column -->
|
||||
<div>
|
||||
<!-- Certifications -->
|
||||
<swp-card>
|
||||
<swp-section-label>@Model.LabelCertifications</swp-section-label>
|
||||
<swp-document-list>
|
||||
@foreach (var cert in Model.Certifications)
|
||||
{
|
||||
<swp-document-item>
|
||||
<i class="ph ph-certificate"></i>
|
||||
<swp-document-info>
|
||||
<swp-document-name>@cert.Name</swp-document-name>
|
||||
<swp-document-meta>@cert.ExpiryDate</swp-document-meta>
|
||||
</swp-document-info>
|
||||
<swp-document-actions>
|
||||
<swp-status-badge class="@cert.StatusClass">@cert.Status</swp-status-badge>
|
||||
</swp-document-actions>
|
||||
</swp-document-item>
|
||||
}
|
||||
</swp-document-list>
|
||||
<swp-add-button>+ @Model.LabelAddCertification</swp-add-button>
|
||||
</swp-card>
|
||||
|
||||
<!-- Courses -->
|
||||
<swp-card>
|
||||
<swp-section-label>@Model.LabelCourses</swp-section-label>
|
||||
|
||||
<swp-subsection>
|
||||
<swp-subsection-title>@Model.LabelCompletedCourses</swp-subsection-title>
|
||||
<swp-document-list>
|
||||
@foreach (var course in Model.CompletedCourses)
|
||||
{
|
||||
<swp-document-item>
|
||||
<swp-document-info>
|
||||
<swp-document-name>@course.Name</swp-document-name>
|
||||
<swp-document-meta>@course.Provider · @course.Date</swp-document-meta>
|
||||
</swp-document-info>
|
||||
</swp-document-item>
|
||||
}
|
||||
</swp-document-list>
|
||||
</swp-subsection>
|
||||
|
||||
<swp-subsection>
|
||||
<swp-subsection-title>@Model.LabelPlannedCourses</swp-subsection-title>
|
||||
<swp-document-list>
|
||||
@foreach (var course in Model.PlannedCourses)
|
||||
{
|
||||
<swp-document-item>
|
||||
<swp-document-info>
|
||||
<swp-document-name>@course.Name</swp-document-name>
|
||||
<swp-document-meta>@course.Provider · @course.Date</swp-document-meta>
|
||||
</swp-document-info>
|
||||
@if (!string.IsNullOrEmpty(course.Status))
|
||||
{
|
||||
<swp-document-actions>
|
||||
<swp-status-badge class="enrolled">@course.Status</swp-status-badge>
|
||||
</swp-document-actions>
|
||||
}
|
||||
</swp-document-item>
|
||||
}
|
||||
</swp-document-list>
|
||||
</swp-subsection>
|
||||
|
||||
<swp-add-button>+ @Model.LabelAddCourse</swp-add-button>
|
||||
</swp-card>
|
||||
</div>
|
||||
</swp-detail-grid>
|
||||
|
||||
<!-- Vacation & Absence section -->
|
||||
<swp-detail-grid style="margin-top: var(--spacing-8);">
|
||||
<swp-card>
|
||||
<swp-section-label>@Model.LabelVacation</swp-section-label>
|
||||
<swp-section-label>@Model.LabelVacationBalance</swp-section-label>
|
||||
<swp-edit-section>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>Optjent ferie</swp-edit-label>
|
||||
<swp-edit-value>25 dage</swp-edit-value>
|
||||
<swp-edit-label>@Model.LabelVacationEarned</swp-edit-label>
|
||||
<swp-edit-value>@Model.VacationEarned</swp-edit-value>
|
||||
</swp-edit-row>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>Afholdt ferie</swp-edit-label>
|
||||
<swp-edit-value>12 dage</swp-edit-value>
|
||||
<swp-edit-label>@Model.LabelVacationUsed</swp-edit-label>
|
||||
<swp-edit-value>@Model.VacationUsed</swp-edit-value>
|
||||
</swp-edit-row>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>Resterende</swp-edit-label>
|
||||
<swp-edit-value>13 dage</swp-edit-value>
|
||||
<swp-edit-label>@Model.LabelVacationRemaining</swp-edit-label>
|
||||
<swp-edit-value style="font-weight: 600; color: var(--color-teal);">@Model.VacationRemaining</swp-edit-value>
|
||||
</swp-edit-row>
|
||||
</swp-edit-section>
|
||||
</swp-card>
|
||||
|
||||
<swp-card>
|
||||
<swp-section-label>@Model.LabelNotes</swp-section-label>
|
||||
<swp-notes-area contenteditable="true">
|
||||
Ingen noter tilføjet endnu...
|
||||
</swp-notes-area>
|
||||
<swp-section-label>@Model.LabelAbsenceSickness</swp-section-label>
|
||||
<swp-edit-section>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>@Model.LabelSickDays2025</swp-edit-label>
|
||||
<swp-edit-value>@Model.SickDays2025</swp-edit-value>
|
||||
</swp-edit-row>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>@Model.LabelSickDays2024</swp-edit-label>
|
||||
<swp-edit-value>@Model.SickDays2024</swp-edit-value>
|
||||
</swp-edit-row>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>@Model.LabelChildSickDays2025</swp-edit-label>
|
||||
<swp-edit-value>@Model.ChildSickDays2025</swp-edit-value>
|
||||
</swp-edit-row>
|
||||
<swp-edit-row>
|
||||
<swp-edit-label>@Model.LabelMaternityLeave</swp-edit-label>
|
||||
<swp-edit-value>@Model.MaternityLeave</swp-edit-value>
|
||||
</swp-edit-row>
|
||||
</swp-edit-section>
|
||||
</swp-card>
|
||||
</swp-detail-grid>
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue