2 <div v-if="!this.initialized">Loading...</div>
4 <h2 v-if="agreement.agreement_id">
5 Edit agreement #{{ agreement.agreement_id }}
7 <h2 v-else>New agreement</h2>
9 <form @submit="onSubmit($event)">
10 <fieldset class="rows">
13 <label class="required" for="agreement_name"
14 >Agreement name:</label
18 v-model="agreement.name"
19 placeholder="Agreement name"
22 <span class="required">Required</span>
25 <label for="agreement_vendor_id">Vendor:</label>
27 id="agreement_vendor_id"
28 v-model="agreement.vendor_id"
30 <option value=""></option>
32 v-for="vendor in vendors"
33 :key="vendor.vendor_id"
36 vendor.id == agreement.vendor_id
46 <label for="agreement_description"
50 id="agreement_description"
51 v-model="agreement.description"
52 placeholder="Description"
57 <span class="required">Required</span>
60 <label for="agreement_status">Status: </label>
63 v-model="agreement.status"
64 @change="onStatusChange($event)"
67 <option value=""></option>
69 v-for="status in av_agreement_statuses"
70 :key="status.authorised_values"
71 :value="status.authorised_value"
73 status.authorised_value ==
82 <span class="required">Required</span>
85 <label for="agreement_closure_reason"
86 >Closure reason:</label
89 id="agreement_closure_reason"
90 v-model="agreement.closure_reason"
92 agreement.status == 'closed' ? false : true
95 <option value=""></option>
97 v-for="r in av_agreement_closure_reasons"
98 :key="r.authorised_values"
99 :value="r.authorised_value"
101 r.authorised_value ==
102 agreement.closure_reason
112 <label for="agreement_is_perpetual" class="radio"
113 >Is perpetual:</label
115 <label for="agreement_is_perpetual_yes">
119 id="agreement_is_perpetual_yes"
121 v-model="agreement.is_perpetual"
125 <label for="agreement_is_perpetual_no">
129 id="agreement_is_perpetual_no"
131 v-model="agreement.is_perpetual"
137 <label for="agreement_renewal_priority"
138 >Renewal priority:</label
140 <select v-model="agreement.renewal_priority">
141 <option value=""></option>
143 v-for="p in av_agreement_renewal_priorities"
144 :key="p.authorised_values"
145 :value="p.authorised_value"
147 p.authorised_value ==
148 agreement.renewal_priority
158 <label for="agreement_license_info"
162 id="agreement_license_info"
163 v-model="agreement.license_info"
164 placeholder="License info"
168 <AgreementPeriods :periods="agreement.periods" />
170 :user_roles="agreement.user_roles"
171 :av_agreement_user_roles="av_agreement_user_roles"
174 :agreement_licenses="agreement.agreement_licenses"
175 :av_agreement_license_statuses="
176 av_agreement_license_statuses
178 :av_agreement_license_location="
179 av_agreement_license_location
184 <fieldset class="action">
185 <input type="submit" value="Submit" />
187 to="/cgi-bin/koha/erm/agreements"
199 import AgreementPeriods from './AgreementPeriods.vue'
200 import AgreementUserRoles from './AgreementUserRoles.vue'
201 import AgreementLicenses from './AgreementLicenses.vue'
202 import { useVendorStore } from "../../stores/vendors"
203 import { useAVStore } from "../../stores/authorised_values"
204 import { setMessage, setError } from "../../messages"
205 import { fetchAgreement } from '../../fetch'
206 import { storeToRefs } from "pinia"
210 const vendorStore = useVendorStore()
211 const { vendors } = storeToRefs(vendorStore)
212 const AVStore = useAVStore()
214 av_agreement_statuses,
215 av_agreement_closure_reasons,
216 av_agreement_renewal_priorities,
217 av_agreement_user_roles,
218 av_agreement_license_statuses,
219 av_agreement_license_location,
220 } = storeToRefs(AVStore)
224 av_agreement_statuses,
225 av_agreement_closure_reasons,
226 av_agreement_renewal_priorities,
227 av_agreement_user_roles,
228 av_agreement_license_statuses,
229 av_agreement_license_location,
242 renewal_priority: '',
246 agreement_licenses: [],
251 beforeRouteEnter(to, from, next) {
253 if (to.params.agreement_id) {
254 vm.agreement = vm.getAgreement(to.params.agreement_id)
256 vm.initialized = true
261 async getAgreement(agreement_id) {
262 const agreement = await fetchAgreement(agreement_id)
263 this.agreement = agreement
264 this.initialized = true
269 //let agreement= Object.assign( {} ,this.agreement); // copy
270 let agreement = JSON.parse(JSON.stringify(this.agreement)) // copy
271 let apiUrl = '/api/v1/erm/agreements'
274 if (agreement.agreement_id) {
276 apiUrl += '/' + agreement.agreement_id
278 delete agreement.agreement_id
279 agreement.is_perpetual = agreement.is_perpetual ? true : false
281 agreement.periods.forEach(p => {
282 p.started_on = $date_to_rfc3339(p.started_on)
283 p.ended_on = p.ended_on ? $date_to_rfc3339(p.ended_on) : null
284 p.cancellation_deadline = p.cancellation_deadline ? $date_to_rfc3339(p.cancellation_deadline) : null
287 agreement.periods = agreement.periods.map(({ agreement_id, agreement_period_id, ...keepAttrs }) => keepAttrs)
289 agreement.user_roles = agreement.user_roles.map(({ patron, patron_str, ...keepAttrs }) => keepAttrs)
291 agreement.agreement_licenses = agreement.agreement_licenses.map(({ license, agreement_id, agreement_license_id, ...keepAttrs }) => keepAttrs)
295 body: JSON.stringify(agreement),
297 'Content-Type': 'application/json;charset=utf-8'
301 fetch(apiUrl, options)
303 if (response.status == 200) {
304 this.$router.push("/cgi-bin/koha/erm/agreements")
305 setMessage('Agreement updated')
306 } else if (response.status == 201) {
307 this.$router.push("/cgi-bin/koha/erm/agreements")
308 setMessage('Agreement created')
310 setError(response.message || response.statusText)
318 onStatusChange(event) {
319 if (event.target.value != 'closed') {
320 this.agreement.closure_reason = ''
325 agreement_id: Number,
332 name: "AgreementsFormAdd",