const app = require('../app') const moment = require('moment-immutable') const { editIcon, calculatedIcon, dollarIcon } = require('../assets') app.component('appLaborEntryPage', { template: html`

For week of {{ctrl.startDate.format('LL')}} to {{ctrl.endDate.format('LL')}}

This field is calculated,
and cannot be edited directly.
Save your changes to update.
This field is calculated,
and cannot be edited directly.
Save your changes to update.
Staff Member {{weekday.min}} {{weekday.short}} {{weekday.name}}
{{ctrl.staffMembers[sfl.id].name}}
Submit
`, controllerAs: 'ctrl', controller: function(api, $routeParams, weekdays, $mdToast) { this.weekdays = weekdays this.terminalKey = $routeParams.terminal const week = moment($routeParams.week) if (!week.isSame(week.startOf('week'))) throw new Error('Date is not start of week') this.startDate = week this.endDate = week.endOf('week') api.staffMemberDictionary().then(staffMembers => { this.staffMembers = staffMembers }) const load = () => { this.promise = api.get(`/api/labor/${$routeParams.terminal}/${$routeParams.week}`).then((model) => { this.model = model const staffMemberIds = this.model.workdays[0].labor.map(x => x.staffMemberId) this.staffMemberLabor = staffMemberIds.map((id, i) => ({ id, days: this.model.workdays.map(wd => wd.labor[i]) })) }) } load() this.submit = async () => { const model = { workweek: this.model.workweek, workdays: this.model.workdays.map(workday => ({ labor: workday.labor.map(labor => ({ staffMemberId: labor.staffMemberId, hours: labor.hours || null })) })) } try { await api.patch(`/api/labor/${$routeParams.terminal}/${$routeParams.week}`, model) $mdToast.showSimple('Labor saved.') load() } catch (err) { window.err = err console.error(err) $mdToast.showSimple(`Could not save Labor: ${err.message || err.statusText || err}`) } } } })