Koha/koha-tmpl/intranet-tmpl/prog/js/vue/components/ERM/AgreementsFormAdd.vue
Jonathan Druart 5d6de5d437
Bug 32030: I18N rewrite - replace $t with $__
Signed-off-by: Jonathan Field <jonathan.field@ptfs-europe.com>

Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>
2022-11-08 09:44:38 -03:00

368 lines
15 KiB
Vue

<template>
<div v-if="!initialized">{{ $__("Loading") }}</div>
<div v-else id="agreements_add">
<h2 v-if="agreement.agreement_id">
{{ $__("Edit agreement #%s").format(agreement.agreement_id) }}
</h2>
<h2 v-else>{{ $__("New agreement") }}</h2>
<div>
<form @submit="onSubmit($event)">
<div class="page-section">
<fieldset class="rows">
<ol>
<li>
<label class="required" for="agreement_name"
>{{ $__("Agreement name") }}:</label
>
<input
id="agreement_name"
v-model="agreement.name"
:placeholder="$__('Agreement name')"
required
/>
<span class="required">{{
$__("Required")
}}</span>
</li>
<li>
<label for="agreement_vendor_id"
>{{ $__("Vendor") }}:</label
>
<v-select
id="agreement_vendor_id"
v-model="agreement.vendor_id"
label="name"
:reduce="(vendor) => vendor.id"
:options="vendors"
/>
</li>
<li>
<label for="agreement_description"
>{{ $__("Description") }}:
</label>
<textarea
id="agreement_description"
v-model="agreement.description"
:placeholder="$__('Description')"
rows="10"
cols="50"
required
/>
<span class="required">{{
$__("Required")
}}</span>
</li>
<li>
<label for="agreement_status"
>{{ $__("Status") }}:</label
>
<v-select
id="agreement_status"
v-model="agreement.status"
label="lib"
:reduce="(av) => av.authorised_value"
:options="av_agreement_statuses"
@option:selected="onStatusChanged"
:required="!agreement.status"
>
<template #search="{ attributes, events }">
<input
:required="!agreement.status"
class="vs__search"
v-bind="attributes"
v-on="events"
/>
</template>
</v-select>
<span class="required">{{
$__("Required")
}}</span>
</li>
<li>
<label for="agreement_closure_reason"
>{{ $__("Closure reason") }}:</label
>
<v-select
id="agreement_closure_reason"
v-model="agreement.closure_reason"
label="lib"
:reduce="(av) => av.authorised_value"
:options="av_agreement_closure_reasons"
:disabled="
agreement.status == 'closed'
? false
: true
"
/>
</li>
<li>
<label
for="agreement_is_perpetual"
class="radio"
>{{ $__("Is perpetual") }}:</label
>
<label for="agreement_is_perpetual_yes">
<input
type="radio"
name="is_perpetual"
id="agreement_is_perpetual_yes"
:value="true"
v-model="agreement.is_perpetual"
/>
Yes
</label>
<label for="agreement_is_perpetual_no">
<input
type="radio"
name="is_perpetual"
id="agreement_is_perpetual_no"
:value="false"
v-model="agreement.is_perpetual"
/>
No
</label>
</li>
<li>
<label for="agreement_renewal_priority"
>{{ $__("Renewal priority") }}:</label
>
<v-select
id="agreement_renewal_priority"
v-model="agreement.renewal_priority"
label="lib"
:reduce="(av) => av.authorised_value"
:options="av_agreement_renewal_priorities"
/>
</li>
<li>
<label for="agreement_license_info"
>{{ $__("License info") }}:
</label>
<textarea
id="agreement_license_info"
v-model="agreement.license_info"
placeholder="License info"
/>
</li>
</ol>
</fieldset>
</div>
<AgreementPeriods :periods="agreement.periods" />
<AgreementUserRoles
:user_roles="agreement.user_roles"
:av_agreement_user_roles="av_agreement_user_roles"
/>
<AgreementLicenses
:agreement_licenses="agreement.agreement_licenses"
:av_agreement_license_statuses="
av_agreement_license_statuses
"
:av_agreement_license_location="
av_agreement_license_location
"
/>
<AgreementRelationships
:agreement_id="agreement.agreement_id"
:relationships="agreement.agreement_relationships"
:av_agreement_relationships="av_agreement_relationships"
/>
<Documents :documents="agreement.documents" />
<fieldset class="action">
<input type="submit" value="Submit" />
<router-link
to="/cgi-bin/koha/erm/agreements"
role="button"
class="cancel"
>{{ $__("Cancel") }}</router-link
>
</fieldset>
</form>
</div>
</div>
</template>
<script>
import { inject } from 'vue'
import AgreementPeriods from './AgreementPeriods.vue'
import AgreementUserRoles from './AgreementUserRoles.vue'
import AgreementLicenses from './AgreementLicenses.vue'
import AgreementRelationships from './AgreementRelationships.vue'
import Documents from './Documents.vue'
import { setMessage, setError, setWarning } from "../../messages"
import { fetchAgreement } from '../../fetch'
import { storeToRefs } from "pinia"
export default {
setup() {
const vendorStore = inject('vendorStore')
const { vendors } = storeToRefs(vendorStore)
const AVStore = inject('AVStore')
const {
av_agreement_statuses,
av_agreement_closure_reasons,
av_agreement_renewal_priorities,
av_agreement_user_roles,
av_agreement_license_statuses,
av_agreement_license_location,
av_agreement_relationships,
} = storeToRefs(AVStore)
return {
vendors,
av_agreement_statuses,
av_agreement_closure_reasons,
av_agreement_renewal_priorities,
av_agreement_user_roles,
av_agreement_license_statuses,
av_agreement_license_location,
av_agreement_relationships,
}
},
data() {
return {
agreement: {
agreement_id: null,
name: '',
vendor_id: null,
description: '',
status: '',
closure_reason: '',
is_perpetual: false,
renewal_priority: '',
license_info: '',
periods: [],
user_roles: [],
agreement_licenses: [],
agreement_relationships: [],
documents: [],
},
initialized: false,
}
},
beforeRouteEnter(to, from, next) {
next(vm => {
if (to.params.agreement_id) {
vm.agreement = vm.getAgreement(to.params.agreement_id)
} else {
vm.initialized = true
}
})
},
methods: {
async getAgreement(agreement_id) {
const agreement = await fetchAgreement(agreement_id)
this.agreement = agreement
this.initialized = true
},
checkForm(agreement) {
let errors = []
let agreement_licenses = agreement.agreement_licenses
// Do not use al.license.name here! Its name is not the one linked with al.license_id
// At this point al.license is meaningless, form/template only modified al.license_id
const license_ids = agreement_licenses.map(al => al.license_id)
const duplicate_license_ids = license_ids.filter((id, i) => license_ids.indexOf(id) !== i)
if (duplicate_license_ids.length) {
errors.push(this.$__("A license is used several times"))
}
const related_agreement_ids = agreement.agreement_relationships.map(rs => rs.related_agreement_id)
const duplicate_related_agreement_ids = related_agreement_ids.filter((id, i) => related_agreement_ids.indexOf(id) !== i)
if (duplicate_related_agreement_ids.length) {
errors.push(this.$__("An agreement is used as relationship several times"))
}
if (agreement_licenses.filter(al => al.status == 'controlling').length > 1) {
errors.push(this.$__("Only one controlling license is allowed"))
}
if (agreement_licenses.filter(al => al.status == 'controlling').length > 1) {
errors.push(this.$__("Only one controlling license is allowed"))
}
errors.forEach(function (e) {
setWarning(e)
})
return !errors.length
},
onSubmit(e) {
e.preventDefault()
//let agreement= Object.assign( {} ,this.agreement); // copy
let agreement = JSON.parse(JSON.stringify(this.agreement)) // copy
if (!this.checkForm(agreement)) {
return false
}
let apiUrl = '/api/v1/erm/agreements'
let method = 'POST'
if (agreement.agreement_id) {
method = 'PUT'
apiUrl += '/' + agreement.agreement_id
}
delete agreement.agreement_id
delete agreement.vendor
agreement.is_perpetual = agreement.is_perpetual ? true : false
if (agreement.vendor_id == "") {
agreement.vendor_id = null
}
agreement.periods = agreement.periods.map(({ agreement_id, agreement_period_id, ...keepAttrs }) => keepAttrs)
agreement.user_roles = agreement.user_roles.map(({ patron, patron_str, ...keepAttrs }) => keepAttrs)
agreement.agreement_licenses = agreement.agreement_licenses.map(({ license, agreement_id, agreement_license_id, ...keepAttrs }) => keepAttrs)
agreement.agreement_relationships = agreement.agreement_relationships.map(({ related_agreement, ...keepAttrs }) => keepAttrs)
agreement.documents = agreement.documents.map(({ file_type, uploaded_on, ...keepAttrs }) => keepAttrs)
delete agreement.agreement_packages
const options = {
method: method,
body: JSON.stringify(agreement),
headers: {
'Content-Type': 'application/json;charset=utf-8'
},
}
fetch(apiUrl, options)
.then(response => {
if (response.status == 200) {
this.$router.push("/cgi-bin/koha/erm/agreements")
setMessage(this.$__("Agreement updated"))
} else if (response.status == 201) {
this.$router.push("/cgi-bin/koha/erm/agreements")
setMessage(this.$__("Agreement created"))
} else {
setError(response.message || response.statusText)
}
}).catch(
(error) => {
this.setError(error)
}
)
},
onStatusChanged(e) {
if (e.authorised_value != 'closed') {
this.agreement.closure_reason = ''
}
}
},
components: {
AgreementPeriods,
AgreementUserRoles,
AgreementLicenses,
AgreementRelationships,
Documents,
},
name: "AgreementsFormAdd",
}
</script>