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" />
180 to="/cgi-bin/koha/erm/agreements"
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 { fetchAgreement } from '../../fetch'
198 import { storeToRefs } from "pinia"
202 const vendorStore = useVendorStore()
203 const { vendors } = storeToRefs(vendorStore)
204 const AVStore = useAVStore()
206 av_agreement_statuses,
207 av_agreement_closure_reasons,
208 av_agreement_renewal_priorities,
209 av_agreement_user_roles,
210 av_agreement_license_statuses,
211 av_agreement_license_location,
212 } = storeToRefs(AVStore)
214 const mainStore = useMainStore()
215 const { setMessage, setError, resetMessages } = mainStore
219 av_agreement_statuses,
220 av_agreement_closure_reasons,
221 av_agreement_renewal_priorities,
222 av_agreement_user_roles,
223 av_agreement_license_statuses,
224 av_agreement_license_location,
225 setMessage, setError, resetMessages,
238 renewal_priority: '',
242 agreement_licenses: [],
246 beforeRouteEnter(to, from, next) {
247 if (to.params.agreement_id) {
249 vm.agreement = vm.getAgreement(to.params.agreement_id)
256 async getAgreement(agreement_id) {
257 const agreement = await fetchAgreement(agreement_id)
258 this.agreement = agreement
263 //let agreement= Object.assign( {} ,this.agreement); // copy
264 let agreement = JSON.parse(JSON.stringify(this.agreement)) // copy
265 let apiUrl = '/api/v1/erm/agreements'
268 if (agreement.agreement_id) {
270 apiUrl += '/' + agreement.agreement_id
272 delete agreement.agreement_id
273 agreement.is_perpetual = agreement.is_perpetual ? true : false
275 agreement.periods.forEach(p => {
276 p.started_on = $date_to_rfc3339(p.started_on)
277 p.ended_on = p.ended_on ? $date_to_rfc3339(p.ended_on) : null
278 p.cancellation_deadline = p.cancellation_deadline ? $date_to_rfc3339(p.cancellation_deadline) : null
281 agreement.periods = agreement.periods.map(({ agreement_id, agreement_period_id, ...keepAttrs }) => keepAttrs)
283 agreement.user_roles = agreement.user_roles.map(({ patron, patron_str, ...keepAttrs }) => keepAttrs)
285 agreement.agreement_licenses = agreement.agreement_licenses.map(({ license, agreement_id, agreement_license_id, ...keepAttrs }) => keepAttrs)
289 body: JSON.stringify(agreement),
291 'Content-Type': 'application/json;charset=utf-8'
295 fetch(apiUrl, options)
297 if (response.status == 200) {
298 this.$router.push("/cgi-bin/koha/erm/agreements")
299 this.setMessage('Agreement updated')
300 } else if (response.status == 201) {
301 this.$router.push("/cgi-bin/koha/erm/agreements")
302 this.setMessage('Agreement created')
304 this.setError(response.message || response.statusText)
312 onStatusChange(event) {
313 if (event.target.value != 'closed') {
314 this.agreement.closure_reason = ''
319 agreement_id: Number,
326 name: "AgreementsFormAdd",