2022-07-30 18:36:04 +02:00
|
|
|
<template>
|
2022-07-30 19:25:15 +02:00
|
|
|
<div ref="wrapper" class="modal modal-bg w-full h-full fixed top-0 left-0 bg-primary bg-opacity-75 flex items-center justify-center z-60 opacity-0">
|
2022-07-30 18:36:04 +02:00
|
|
|
<div class="absolute top-0 left-0 right-0 w-full h-36 bg-gradient-to-t from-transparent via-black-500 to-black-700 opacity-90 pointer-events-none" />
|
2022-07-30 19:40:43 +02:00
|
|
|
<div ref="content" class="relative text-white" :style="{ height: modalHeight, width: modalWidth }" v-click-outside="clickedOutside">
|
2022-07-30 18:36:04 +02:00
|
|
|
<div class="px-4 w-full text-sm py-6 rounded-lg bg-bg shadow-lg border border-black-300">
|
2024-05-31 00:03:33 +02:00
|
|
|
<p id="confirm-prompt-message" class="text-lg mb-6 mt-2 px-1" v-html="message" />
|
2023-04-14 23:44:41 +02:00
|
|
|
|
|
|
|
<ui-checkbox v-if="checkboxLabel" v-model="checkboxValue" checkbox-bg="bg" :label="checkboxLabel" label-class="pl-2 text-base" class="mb-6 px-1" />
|
|
|
|
|
2024-12-22 22:15:56 +01:00
|
|
|
<div v-if="formFields.length" class="mb-6 space-y-2">
|
|
|
|
<template v-for="field in formFields">
|
|
|
|
<ui-select-input v-if="field.type === 'select'" :key="field.name" v-model="formData[field.name]" :label="field.label" :items="field.options" class="px-1" />
|
|
|
|
<ui-textarea-with-label v-else-if="field.type === 'textarea'" :key="field.name" v-model="formData[field.name]" :label="field.label" class="px-1" />
|
|
|
|
<ui-text-input-with-label v-else-if="field.type === 'text'" :key="field.name" v-model="formData[field.name]" :label="field.label" class="px-1" />
|
|
|
|
</template>
|
|
|
|
</div>
|
|
|
|
|
2022-07-30 18:36:04 +02:00
|
|
|
<div class="flex px-1 items-center">
|
2022-11-08 01:27:17 +01:00
|
|
|
<ui-btn v-if="isYesNo" color="primary" @click="nevermind">{{ $strings.ButtonCancel }}</ui-btn>
|
2022-07-30 18:36:04 +02:00
|
|
|
<div class="flex-grow" />
|
2023-04-14 23:44:41 +02:00
|
|
|
<ui-btn v-if="isYesNo" :color="yesButtonColor" @click="confirm">{{ yesButtonText }}</ui-btn>
|
2022-11-08 01:27:17 +01:00
|
|
|
<ui-btn v-else color="primary" @click="confirm">{{ $strings.ButtonOk }}</ui-btn>
|
2022-07-30 18:36:04 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
export default {
|
|
|
|
props: {},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
el: null,
|
2023-04-14 23:44:41 +02:00
|
|
|
content: null,
|
2024-12-22 22:15:56 +01:00
|
|
|
checkboxValue: false,
|
|
|
|
formData: {}
|
2022-07-30 18:36:04 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
watch: {
|
|
|
|
show(newVal) {
|
|
|
|
if (newVal) {
|
|
|
|
this.setShow()
|
|
|
|
} else {
|
|
|
|
this.setHide()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
show: {
|
|
|
|
get() {
|
|
|
|
return this.$store.state.globals.showConfirmPrompt
|
|
|
|
},
|
|
|
|
set(val) {
|
|
|
|
this.$store.commit('globals/setShowConfirmPrompt', val)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
confirmPromptOptions() {
|
|
|
|
return this.$store.state.globals.confirmPromptOptions || {}
|
|
|
|
},
|
|
|
|
message() {
|
|
|
|
return this.confirmPromptOptions.message || ''
|
|
|
|
},
|
|
|
|
callback() {
|
|
|
|
return this.confirmPromptOptions.callback
|
|
|
|
},
|
|
|
|
type() {
|
|
|
|
return this.confirmPromptOptions.type || 'ok'
|
|
|
|
},
|
|
|
|
persistent() {
|
|
|
|
return !!this.confirmPromptOptions.persistent
|
|
|
|
},
|
2024-12-22 22:15:56 +01:00
|
|
|
formFields() {
|
|
|
|
return this.confirmPromptOptions.formFields || []
|
|
|
|
},
|
2023-04-14 23:44:41 +02:00
|
|
|
checkboxLabel() {
|
|
|
|
return this.confirmPromptOptions.checkboxLabel
|
|
|
|
},
|
|
|
|
yesButtonText() {
|
|
|
|
return this.confirmPromptOptions.yesButtonText || this.$strings.ButtonYes
|
|
|
|
},
|
|
|
|
yesButtonColor() {
|
|
|
|
return this.confirmPromptOptions.yesButtonColor || 'success'
|
|
|
|
},
|
|
|
|
checkboxDefaultValue() {
|
|
|
|
return !!this.confirmPromptOptions.checkboxDefaultValue
|
|
|
|
},
|
2022-07-30 18:36:04 +02:00
|
|
|
isYesNo() {
|
|
|
|
return this.type === 'yesNo'
|
|
|
|
},
|
|
|
|
modalHeight() {
|
|
|
|
return 'unset'
|
|
|
|
},
|
|
|
|
modalWidth() {
|
|
|
|
return '500px'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2022-07-30 19:25:15 +02:00
|
|
|
clickedOutside(evt) {
|
2022-07-30 23:18:26 +02:00
|
|
|
if (!this.show) return
|
2022-07-30 19:25:15 +02:00
|
|
|
if (evt) {
|
|
|
|
evt.stopPropagation()
|
|
|
|
evt.preventDefault()
|
|
|
|
}
|
|
|
|
|
2022-07-30 18:36:04 +02:00
|
|
|
if (this.persistent) return
|
|
|
|
if (this.callback) this.callback(false)
|
|
|
|
this.show = false
|
|
|
|
},
|
|
|
|
nevermind() {
|
|
|
|
if (this.callback) this.callback(false)
|
|
|
|
this.show = false
|
|
|
|
},
|
|
|
|
confirm() {
|
2024-12-22 22:15:56 +01:00
|
|
|
if (this.callback) {
|
|
|
|
if (this.formFields.length) {
|
|
|
|
const formFieldData = {
|
|
|
|
...this.formData
|
|
|
|
}
|
|
|
|
|
|
|
|
this.callback(true, formFieldData)
|
|
|
|
} else {
|
|
|
|
this.callback(true, this.checkboxValue)
|
|
|
|
}
|
|
|
|
}
|
2022-07-30 18:36:04 +02:00
|
|
|
this.show = false
|
|
|
|
},
|
|
|
|
setShow() {
|
2023-04-14 23:44:41 +02:00
|
|
|
this.checkboxValue = this.checkboxDefaultValue
|
2024-12-22 22:15:56 +01:00
|
|
|
|
|
|
|
if (this.formFields.length) {
|
|
|
|
this.formFields.forEach((field) => {
|
|
|
|
let defaultValue = ''
|
|
|
|
if (field.type === 'boolean') defaultValue = false
|
|
|
|
if (field.type === 'select') defaultValue = field.options[0].value
|
|
|
|
this.$set(this.formData, field.name, defaultValue)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-07-30 19:25:15 +02:00
|
|
|
this.$eventBus.$emit('showing-prompt', true)
|
2022-07-30 18:36:04 +02:00
|
|
|
document.body.appendChild(this.el)
|
|
|
|
setTimeout(() => {
|
|
|
|
this.content.style.transform = 'scale(1)'
|
|
|
|
}, 10)
|
|
|
|
},
|
|
|
|
setHide() {
|
2022-07-30 19:25:15 +02:00
|
|
|
this.$eventBus.$emit('showing-prompt', false)
|
2022-07-30 18:36:04 +02:00
|
|
|
this.content.style.transform = 'scale(0)'
|
|
|
|
this.el.remove()
|
|
|
|
}
|
|
|
|
},
|
|
|
|
mounted() {
|
|
|
|
this.el = this.$refs.wrapper
|
|
|
|
this.content = this.$refs.content
|
|
|
|
this.content.style.transform = 'scale(0)'
|
|
|
|
this.content.style.transition = 'transform 0.25s cubic-bezier(0.16, 1, 0.3, 1)'
|
|
|
|
this.el.style.opacity = 1
|
|
|
|
this.el.remove()
|
2022-07-30 19:25:15 +02:00
|
|
|
},
|
|
|
|
beforeDestroy() {
|
|
|
|
if (this.show) {
|
|
|
|
this.$eventBus.$emit('showing-prompt', false)
|
|
|
|
}
|
2022-07-30 18:36:04 +02:00
|
|
|
}
|
|
|
|
}
|
2024-05-31 00:03:33 +02:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<style>
|
|
|
|
#confirm-prompt-message code {
|
|
|
|
font-size: 1rem;
|
|
|
|
border-radius: 6px;
|
|
|
|
background-color: rgb(82, 82, 82);
|
|
|
|
color: white;
|
|
|
|
padding: 2px 4px;
|
|
|
|
}
|
|
|
|
</style>
|