2 <h2 v-if="agreement.agreement_id">Edit agreement</h2>
3 <h2 v-else>New agreement</h2>
5 <form @submit="onSubmit($event)">
6 <fieldset class="rows">
9 <label class="required" for="agreement_name"
10 >Agreement name:</label
14 v-model="agreement.name"
15 placeholder="Agreement name"
18 <span class="required">Required</span>
21 <label for="agreement_vendor_id">Vendor:</label>
23 id="agreement_vendor_id"
24 v-model="agreement.vendor_id"
26 <option value=""></option>
28 v-for="vendor in vendors"
29 :key="vendor.vendor_id"
32 vendor.id == agreement.vendor_id
42 <label for="agreement_description">Description: </label>
44 id="agreement_description"
45 v-model="agreement.description"
46 placeholder="Description"
49 <span class="required">Required</span>
52 <label for="agreement_status">Status: </label>
55 v-model="agreement.status"
56 @change="onStatusChange($event)"
59 <option value=""></option>
61 v-for="status in av_statuses"
62 :key="status.authorised_values"
63 :value="status.authorised_value"
65 status.authorised_value == agreement.status
73 <span class="required">Required</span>
76 <label for="agreement_closure_reason"
77 >Closure reason:</label
80 id="agreement_closure_reason"
81 v-model="agreement.closure_reason"
83 agreement.status == 'closed' ? true : false
86 <option value=""></option>
88 v-for="r in av_closure_reasons"
89 :key="r.authorised_values"
90 :value="r.authorised_value"
93 agreement.closure_reason
103 <label for="agreement_is_perpetual" class="radio"
104 >Is perpetual:</label
106 <label for="agreement_is_perpetual_yes">
110 id="agreement_is_perpetual_yes"
112 v-model="agreement.is_perpetual"
116 <label for="agreement_is_perpetual_no">
120 id="agreement_is_perpetual_no"
122 v-model="agreement.is_perpetual"
128 <label for="agreement_renewal_priority"
129 >Renewal priority:</label
131 <select v-model="agreement.renewal_priority">
132 <option value=""></option>
134 v-for="p in av_renewal_priorities"
135 :key="p.authorised_values"
136 :value="p.authorised_value"
138 p.authorised_value ==
139 agreement.renewal_priority
149 <label for="agreement_license_info"
153 id="agreement_license_info"
154 v-model="agreement.license_info"
155 placeholder="License info"
159 <AgreementPeriods :periods="agreement.periods" />
161 :user_roles="agreement.user_roles"
162 :av_user_roles="av_user_roles"
166 <fieldset class="action">
167 <input type="submit" value="Submit" />
168 <a href="#" class="cancel" @click="$emit('switch-view', 'list')">Cancel</a>
175 import AgreementPeriods from './AgreementPeriods.vue'
176 import AgreementUserRoles from './AgreementUserRoles.vue'
189 renewal_priority: '',
197 if (!this.agreement_id) return
198 const apiUrl = '/api/v1/erm/agreements/' + this.agreement_id
202 'x-koha-embed': 'periods,user_roles,user_roles.patron'
205 .then(res => res.json())
208 this.agreement = result
216 //let agreement= Object.assign( {} ,this.agreement); // copy
217 let agreement = JSON.parse(JSON.stringify(this.agreement)) // copy
218 let apiUrl = '/api/v1/erm/agreements'
220 const myHeaders = new Headers()
221 myHeaders.append('Content-Type', 'application/json')
224 if (agreement.agreement_id) {
226 apiUrl += '/' + agreement.agreement_id
228 delete agreement.agreement_id
229 agreement.is_perpetual = agreement.is_perpetual ? true : false
231 agreement.periods.forEach(p => {
232 p.started_on = $date_to_rfc3339(p.started_on)
233 p.ended_on = p.ended_on ? $date_to_rfc3339(p.ended_on) : null
234 p.cancellation_deadline = p.cancellation_deadline ? $date_to_rfc3339(p.cancellation_deadline) : null
237 agreement.periods = agreement.periods.map(({ agreement_id, agreement_period_id, ...keepAttrs }) => keepAttrs)
239 agreement.user_roles = agreement.user_roles.map(({ patron, patron_str, ...keepAttrs }) => keepAttrs)
243 body: JSON.stringify(agreement),
247 fetch(apiUrl, options)
249 if (response.status == 200) {
250 this.$emit('agreement-updated')
251 } else if (response.status == 201) {
252 this.$emit('agreement-created')
254 this.$emit('set-error', response.message || response.statusText)
258 this.$emit('set-error', error)
262 onStatusChange(status) {
263 if (status == 'closed') {
264 this.agreement.closure_reason = ''
268 emits: ['agreement-created', 'agreement-updated', 'set-error', 'switch-view'],
270 agreement_id: Number,
273 av_closure_reasons: Array,
274 av_renewal_priorities: Array,
275 av_user_roles: Array,
281 name: "AgreementsFormAdd",