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="$emit('switch-view', '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 { storeToRefs } from "pinia"
199 const vendorStore = useVendorStore()
200 const { vendors } = storeToRefs(vendorStore)
215 renewal_priority: '',
219 agreement_licenses: [],
224 if (!this.agreement_id) return
225 const apiUrl = '/api/v1/erm/agreements/' + this.agreement_id
229 'x-koha-embed': 'periods,user_roles,user_roles.patron,agreement_licenses,agreement_licenses.license'
232 .then(res => res.json())
235 this.agreement = result
243 //let agreement= Object.assign( {} ,this.agreement); // copy
244 let agreement = JSON.parse(JSON.stringify(this.agreement)) // copy
245 let apiUrl = '/api/v1/erm/agreements'
248 if (agreement.agreement_id) {
250 apiUrl += '/' + agreement.agreement_id
252 delete agreement.agreement_id
253 agreement.is_perpetual = agreement.is_perpetual ? true : false
255 agreement.periods.forEach(p => {
256 p.started_on = $date_to_rfc3339(p.started_on)
257 p.ended_on = p.ended_on ? $date_to_rfc3339(p.ended_on) : null
258 p.cancellation_deadline = p.cancellation_deadline ? $date_to_rfc3339(p.cancellation_deadline) : null
261 agreement.periods = agreement.periods.map(({ agreement_id, agreement_period_id, ...keepAttrs }) => keepAttrs)
263 agreement.user_roles = agreement.user_roles.map(({ patron, patron_str, ...keepAttrs }) => keepAttrs)
265 agreement.agreement_licenses = agreement.agreement_licenses.map(({ license, agreement_id, agreement_license_id, ...keepAttrs }) => keepAttrs)
269 body: JSON.stringify(agreement),
271 'Content-Type': 'application/json;charset=utf-8'
275 fetch(apiUrl, options)
277 if (response.status == 200) {
278 this.$emit('agreement-updated')
279 } else if (response.status == 201) {
280 this.$emit('agreement-created')
282 this.$emit('set-error', response.message || response.statusText)
286 this.$emit('set-error', error)
290 onStatusChange(event) {
291 if (event.target.value != 'closed') {
292 this.agreement.closure_reason = ''
296 emits: ['agreement-created', 'agreement-updated', 'set-error', 'switch-view'],
298 agreement_id: Number,
299 av_agreement_statuses: Array,
300 av_agreement_closure_reasons: Array,
301 av_agreement_renewal_priorities: Array,
302 av_agreement_user_roles: Array,
303 av_agreement_license_statuses: Array,
304 av_agreement_license_location: Array,
311 name: "AgreementsFormAdd",