Koha/koha-tmpl/intranet-tmpl/prog/js/vue/components/ERM/AgreementsFormAdd.vue
Jonathan Druart 135e229e4b
Bug 32030: Replace this.setError with setError
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:50 -03:00

417 lines
16 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" />
<UserRoles
:user_type="$__('Agreement user')"
:user_roles="agreement.user_roles"
:av_user_roles="av_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 UserRoles from "./UserRoles.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_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_user_roles,
av_agreement_license_statuses,
av_agreement_license_location,
av_agreement_relationships,
max_allowed_packet,
}
},
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"))
}
let documents_with_uploaded_files = agreement.documents.filter(
doc => typeof doc.file_content !== "undefined"
)
if (
documents_with_uploaded_files.filter(
doc => atob(doc.file_content).length >= max_allowed_packet
).length >= 1
) {
errors.push(
this.$__("File size exceeds maximum allowed: %s MB").format(
(max_allowed_packet / (1024 * 1024)).toFixed(2)
)
)
}
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 => {
setError(error)
})
},
onStatusChanged(e) {
if (e.authorised_value != "closed") {
this.agreement.closure_reason = ""
}
},
},
components: {
AgreementPeriods,
UserRoles,
AgreementLicenses,
AgreementRelationships,
Documents,
},
name: "AgreementsFormAdd",
}
</script>