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"
51 <span class="required">Required</span>
54 <label for="agreement_status">Status: </label>
57 v-model="agreement.status"
58 @change="onStatusChange($event)"
61 <option value=""></option>
63 v-for="status in av_agreement_statuses"
64 :key="status.authorised_values"
65 :value="status.authorised_value"
67 status.authorised_value == agreement.status
75 <span class="required">Required</span>
78 <label for="agreement_closure_reason"
79 >Closure reason:</label
82 id="agreement_closure_reason"
83 v-model="agreement.closure_reason"
85 agreement.status == 'closed' ? false : true
88 <option value=""></option>
90 v-for="r in av_agreement_closure_reasons"
91 :key="r.authorised_values"
92 :value="r.authorised_value"
95 agreement.closure_reason
105 <label for="agreement_is_perpetual" class="radio"
106 >Is perpetual:</label
108 <label for="agreement_is_perpetual_yes">
112 id="agreement_is_perpetual_yes"
114 v-model="agreement.is_perpetual"
118 <label for="agreement_is_perpetual_no">
122 id="agreement_is_perpetual_no"
124 v-model="agreement.is_perpetual"
130 <label for="agreement_renewal_priority"
131 >Renewal priority:</label
133 <select v-model="agreement.renewal_priority">
134 <option value=""></option>
136 v-for="p in av_agreement_renewal_priorities"
137 :key="p.authorised_values"
138 :value="p.authorised_value"
140 p.authorised_value ==
141 agreement.renewal_priority
151 <label for="agreement_license_info"
155 id="agreement_license_info"
156 v-model="agreement.license_info"
157 placeholder="License info"
161 <AgreementPeriods :periods="agreement.periods" />
163 :user_roles="agreement.user_roles"
164 :av_agreement_user_roles="av_agreement_user_roles"
167 :agreement_licenses="agreement.agreement_licenses"
168 :av_agreement_license_statuses="
169 av_agreement_license_statuses
171 :av_agreement_license_location="
172 av_agreement_license_location
177 <fieldset class="action">
178 <input type="submit" value="Submit" />
182 @click="this.setCurrentView('list')"
191 import AgreementPeriods from './AgreementPeriods.vue'
192 import AgreementUserRoles from './AgreementUserRoles.vue'
193 import AgreementLicenses from './AgreementLicenses.vue'
194 import { useVendorStore } from "../../stores/vendors"
195 import { useAVStore } from "../../stores/authorised_values"
196 import { useMainStore } from "../../stores/main"
197 import { storeToRefs } from "pinia"
201 const vendorStore = useVendorStore()
202 const { vendors } = storeToRefs(vendorStore)
203 const AVStore = useAVStore()
205 av_agreement_statuses,
206 av_agreement_closure_reasons,
207 av_agreement_renewal_priorities,
208 av_agreement_user_roles,
209 av_agreement_license_statuses,
210 av_agreement_license_location,
211 } = storeToRefs(AVStore)
213 const mainStore = useMainStore()
214 const { setMessage, setError, resetMessages, setCurrentView } = mainStore
218 av_agreement_statuses,
219 av_agreement_closure_reasons,
220 av_agreement_renewal_priorities,
221 av_agreement_user_roles,
222 av_agreement_license_statuses,
223 av_agreement_license_location,
224 setMessage, setError, resetMessages, setCurrentView,
237 renewal_priority: '',
241 agreement_licenses: [],
246 if (!this.agreement_id) return
247 const apiUrl = '/api/v1/erm/agreements/' + this.agreement_id
251 'x-koha-embed': 'periods,user_roles,user_roles.patron,agreement_licenses,agreement_licenses.license'
254 .then(res => res.json())
257 this.agreement = result
268 //let agreement= Object.assign( {} ,this.agreement); // copy
269 let agreement = JSON.parse(JSON.stringify(this.agreement)) // copy
270 let apiUrl = '/api/v1/erm/agreements'
273 if (agreement.agreement_id) {
275 apiUrl += '/' + agreement.agreement_id
277 delete agreement.agreement_id
278 agreement.is_perpetual = agreement.is_perpetual ? true : false
280 agreement.periods.forEach(p => {
281 p.started_on = $date_to_rfc3339(p.started_on)
282 p.ended_on = p.ended_on ? $date_to_rfc3339(p.ended_on) : null
283 p.cancellation_deadline = p.cancellation_deadline ? $date_to_rfc3339(p.cancellation_deadline) : null
286 agreement.periods = agreement.periods.map(({ agreement_id, agreement_period_id, ...keepAttrs }) => keepAttrs)
288 agreement.user_roles = agreement.user_roles.map(({ patron, patron_str, ...keepAttrs }) => keepAttrs)
290 agreement.agreement_licenses = agreement.agreement_licenses.map(({ license, agreement_id, agreement_license_id, ...keepAttrs }) => keepAttrs)
294 body: JSON.stringify(agreement),
296 'Content-Type': 'application/json;charset=utf-8'
300 fetch(apiUrl, options)
302 if (response.status == 200) {
303 this.setCurrentView('list')
304 this.setMessage('Agreement updated')
305 } else if (response.status == 201) {
306 this.setCurrentView('list')
307 this.setMessage('Agreement created')
309 this.setError(response.message || response.statusText)
317 onStatusChange(event) {
318 if (event.target.value != 'closed') {
319 this.agreement.closure_reason = ''
324 agreement_id: Number,
331 name: "AgreementsFormAdd",