salix/modules/worker/front/time-control/index.html

215 lines
7.3 KiB
HTML
Raw Normal View History

2019-05-17 11:27:51 +00:00
<vn-crud-model
vn-id="model"
url="WorkerTimeControls/filter"
filter="::$ctrl.filter"
2019-05-17 11:27:51 +00:00
data="$ctrl.hours">
</vn-crud-model>
<vn-card class="vn-pa-lg vn-w-lg">
2019-11-10 10:08:44 +00:00
<vn-table model="model" auto-load="false">
<vn-thead>
<vn-tr>
<vn-td ng-repeat="weekday in $ctrl.weekDays" center>
<div class="weekday" translate>{{::$ctrl.weekdayNames[$index].name}}</div>
<div>
<span>{{::weekday.dated | date: 'dd'}}</span>
<span title="{{::weekday.dated | date: 'MMMM' | translate}}" translate>
{{::weekday.dated | date: 'MMMM'}}
</span>
</div>
<vn-chip
title="{{::weekday.event.name}}"
ng-class="{invisible: !weekday.event}">
<vn-avatar
ng-style="::{backgroundColor: weekday.event.color}">
</vn-avatar>
2019-11-05 07:59:48 +00:00
<div>
{{::weekday.event.name}}
2019-11-05 07:59:48 +00:00
</div>
</vn-chip>
2019-11-10 10:08:44 +00:00
</vn-td>
</vn-tr>
</vn-thead>
<vn-tbody>
<vn-tr>
<vn-td ng-repeat="weekday in $ctrl.weekDays" class="hours vn-pa-none" expand>
<section ng-repeat="hour in weekday.hours">
2019-11-10 10:08:44 +00:00
<vn-icon
icon="{{
::hour.direction == 'in' ? 'arrow_forward' : 'arrow_back'
}}"
title="{{
::(hour.direction == 'in' ? 'In' : 'Out') | translate
}}"
ng-class="::{'invisible': hour.direction == 'middle'}">
2019-11-10 10:08:44 +00:00
</vn-icon>
<vn-chip
2021-06-17 13:09:04 +00:00
ng-class="::{'colored': hour.manual, 'clickable': true}"
removable="::hour.manual"
2021-06-17 13:09:04 +00:00
on-remove="$ctrl.showDeleteDialog($event, hour)"
ng-click="$ctrl.edit($event, hour)"
>
<prepend>
<vn-icon icon="edit"
vn-tooltip="Edit">
</vn-icon>
</prepend>
{{::hour.timed | date: 'HH:mm'}}
2019-11-05 07:59:48 +00:00
</vn-chip>
2019-11-10 10:08:44 +00:00
</section>
</vn-td>
</vn-tr>
</vn-tbody>
<vn-tfoot>
<vn-tr>
<vn-td ng-repeat="weekday in $ctrl.weekDays" center>
{{$ctrl.formatHours(weekday.workedHours)}} h.
2019-11-10 10:08:44 +00:00
</vn-td>
</vn-tr>
<vn-tr>
<vn-td center ng-repeat="weekday in $ctrl.weekDays">
2019-11-10 10:08:44 +00:00
<vn-icon-button
icon="add_circle"
vn-tooltip="Add time"
ng-click="$ctrl.showAddTimeDialog(weekday)">
</vn-icon-button>
</vn-td>
</vn-tr>
</vn-tfoot>
</vn-table>
</vn-card>
<vn-button-bar ng-show="$ctrl.state" class="vn-w-lg">
<vn-button
label="Satisfied"
2023-02-22 14:12:25 +00:00
disabled="$ctrl.state == 'CONFIRMED'"
ng-if="$ctrl.isHimSelf"
ng-click="$ctrl.isSatisfied()">
</vn-button>
<vn-button
label="Not satisfied"
2023-02-22 14:12:25 +00:00
disabled="$ctrl.state == 'REVISE'"
ng-if="$ctrl.isHimSelf"
ng-click="reason.show()">
</vn-button>
2023-02-22 14:12:25 +00:00
<vn-button
label="Reason"
ng-if="$ctrl.reason && ($ctrl.isHimSelf || $ctrl.isHr)"
2023-02-22 14:12:25 +00:00
ng-click="reason.show()">
</vn-button>
<vn-button
label="Resend"
ng-click="sendEmailConfirmation.show()"
2023-02-23 07:21:59 +00:00
class="right"
vn-tooltip="Resend email of this week to the user"
2023-02-23 07:21:59 +00:00
ng-show="::$ctrl.isHr">
2023-02-22 14:12:25 +00:00
</vn-button>
</vn-button-bar>
2019-11-10 10:08:44 +00:00
<vn-side-menu side="right">
<div class="vn-pa-md">
<div class="totalBox" style="text-align: center;">
<h6 translate>Hours</h6>
<vn-label-value
label="Week total"
2019-11-10 10:08:44 +00:00
value="{{$ctrl.weekTotalHours}} h.">
</vn-label-value>
<vn-label-value
label="Finish at"
value="{{$ctrl.getFinishTime()}}">
</vn-label-value>
2019-10-23 15:38:35 +00:00
</div>
2019-11-10 10:08:44 +00:00
<vn-calendar
vn-id="calendar"
2019-11-10 10:08:44 +00:00
class="vn-pt-md"
ng-model="$ctrl.date"
format-week="$ctrl.formatWeek($element)"
on-move="$ctrl.getMailStates($date)"
2019-11-10 10:08:44 +00:00
has-events="$ctrl.hasEvents($day)">
</vn-calendar>
</div>
</vn-side-menu>
2019-10-23 15:38:35 +00:00
<vn-dialog
vn-id="addTimeDialog"
2020-07-29 08:47:48 +00:00
on-accept="$ctrl.addTime()"
2020-05-06 12:38:09 +00:00
message="Add time">
2019-05-17 11:27:51 +00:00
<tpl-body>
2020-05-06 12:38:09 +00:00
<vn-input-time
vn-one
2021-06-17 13:09:04 +00:00
vn-focus
ng-model="$ctrl.newTimeEntry.timed"
2020-05-06 12:38:09 +00:00
label="Hour"
2021-06-17 13:09:04 +00:00
required="true">
2020-05-06 12:38:09 +00:00
</vn-input-time>
2021-06-17 13:09:04 +00:00
<vn-autocomplete
label="Type"
ng-model="$ctrl.newTimeEntry.direction"
data="$ctrl.entryDirections"
select-fields="['code','description']"
show-field="description"
value-field="code"
required="true">
</vn-autocomplete>
2019-05-17 11:27:51 +00:00
</tpl-body>
<tpl-buttons>
2019-10-30 15:57:14 +00:00
<input type="button" response="cancel" translate-attr="{value: 'Cancel'}"/>
<button response="accept" translate>Save</button>
2019-05-17 11:27:51 +00:00
</tpl-buttons>
2019-11-05 07:59:48 +00:00
</vn-dialog>
<vn-confirm
vn-id="delete-entry-dialog"
2019-11-05 10:57:05 +00:00
on-accept="$ctrl.deleteTimeEntry()"
2019-11-05 07:59:48 +00:00
message="This time entry will be deleted"
question="Are you sure you want to delete this entry?">
2021-06-17 13:09:04 +00:00
</vn-confirm>
<!-- Edit entry Popover -->
<vn-popover vn-id="editEntry">
2021-06-18 10:32:37 +00:00
<vn-horizontal class="vn-pa-sm edit-time-entry">
<vn-autocomplete class="dense"
2021-06-17 13:09:04 +00:00
ng-model="$ctrl.selectedRow.direction"
data="$ctrl.entryDirections"
select-fields="['code','description']"
show-field="description"
value-field="code">
</vn-autocomplete>
<vn-icon-button vn-none
icon="check"
vn-tooltip="Save"
ng-click="$ctrl.save()">
</vn-icon-button>
</vn-horizontal>
</vn-popover>
<vn-dialog
vn-id="reason"
on-accept="$ctrl.isUnsatisfied()">
<tpl-body>
<div class="reasonDialog">
<vn-textarea
label="Reason"
ng-model="$ctrl.reason"
disabled="!$ctrl.isHimSelf"
rows="5"
required="true">
</vn-textarea>
</div>
</tpl-body>
<tpl-buttons ng-if="$ctrl.isHimSelf">
<input type="button" response="cancel" translate-attr="{value: 'Cancel'}"/>
<button response="accept" translate>Save</button>
</tpl-buttons>
</vn-dialog>
<vn-dialog
vn-id="sendEmailConfirmation"
on-accept="$ctrl.resendEmail()"
message="Send time control email">
<tpl-body>
<span translate>Are you sure you want to send it?</span>
</tpl-body>
<tpl-buttons>
<input type="button" response="cancel" translate-attr="{value: 'Cancel'}"/>
<button response="accept" translate>Confirm</button>
</tpl-buttons>
</vn-dialog>