mirror of
https://github.com/advplyr/audiobookshelf-app.git
synced 2025-07-22 11:44:33 +02:00
Add custom headers modal and model
This commit is contained in:
parent
cd4c280950
commit
317dc366e3
8 changed files with 193 additions and 59 deletions
96
components/modals/CustomHeadersModal.vue
Normal file
96
components/modals/CustomHeadersModal.vue
Normal file
|
@ -0,0 +1,96 @@
|
|||
<template>
|
||||
<modals-modal v-model="show" :width="'90%'" :max-width="'420px'" height="100%">
|
||||
<template #outer>
|
||||
<div class="absolute top-5 left-4 z-40">
|
||||
<p class="text-white text-2xl truncate">Custom Headers</p>
|
||||
</div>
|
||||
</template>
|
||||
<div class="w-full h-full overflow-hidden absolute top-0 left-0 flex items-center justify-center" @click="show = false">
|
||||
<div ref="container" class="w-full rounded-lg bg-primary border border-white border-opacity-20 overflow-y-auto overflow-x-hidden" style="max-height: 80vh" @click.stop>
|
||||
<div class="w-full h-full p-4" v-if="showAddHeader">
|
||||
<div class="mb-4">
|
||||
<ui-icon-btn icon="arrow_back" borderless @click="showAddHeader = false" />
|
||||
</div>
|
||||
<form @submit.prevent="submitForm">
|
||||
<ui-text-input-with-label v-model="newHeaderKey" label="Name" class="mb-2" />
|
||||
<ui-text-input-with-label v-model="newHeaderValue" label="Value" class="mb-4" />
|
||||
|
||||
<ui-btn type="submit" class="w-full">Submit</ui-btn>
|
||||
</form>
|
||||
</div>
|
||||
<div class="w-full h-full p-4" v-else>
|
||||
<template v-for="[key, value] in Object.entries(headersCopy)">
|
||||
<div :key="key" class="w-full rounded-lg bg-white bg-opacity-5 py-2 pl-4 pr-12 relative mb-2">
|
||||
<p class="text-base font-semibold text-gray-200 leading-5">{{ key }}</p>
|
||||
<p class="text-sm text-gray-400">{{ value }}</p>
|
||||
|
||||
<div class="absolute top-0 bottom-0 right-0 h-full p-4 flex items-center justify-center text-error">
|
||||
<button @click="removeHeader(key)"><span class="material-icons text-lg">delete</span></button>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
<p v-if="!Object.keys(headersCopy).length" class="py-4 text-center">No Custom Headers</p>
|
||||
|
||||
<div class="w-full flex justify-center pt-4">
|
||||
<ui-btn @click="showAddHeader = true" class="w-full">Add Custom Header</ui-btn>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</modals-modal>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
props: {
|
||||
value: Boolean,
|
||||
customHeaders: {
|
||||
type: Object,
|
||||
default: () => {}
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
newHeaderKey: '',
|
||||
newHeaderValue: '',
|
||||
headersCopy: {},
|
||||
showAddHeader: false
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
show(val) {
|
||||
if (val) this.init()
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
show: {
|
||||
get() {
|
||||
return this.value
|
||||
},
|
||||
set(val) {
|
||||
this.$emit('input', val)
|
||||
}
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
removeHeader(key) {
|
||||
this.$delete(this.headersCopy, key)
|
||||
this.$emit('update:customHeaders', { ...this.headersCopy })
|
||||
},
|
||||
submitForm() {
|
||||
console.log('Submit form', this.newHeaderKey, this.newHeaderValue)
|
||||
this.headersCopy[this.newHeaderKey] = this.newHeaderValue
|
||||
this.newHeaderKey = ''
|
||||
this.newHeaderValue = ''
|
||||
this.showAddHeader = false
|
||||
this.$emit('update:customHeaders', { ...this.headersCopy })
|
||||
},
|
||||
init() {
|
||||
this.newHeaderKey = ''
|
||||
this.newHeaderValue = ''
|
||||
this.headersCopy = this.customHeaders ? { ...this.customHeaders } : {}
|
||||
}
|
||||
},
|
||||
mounted() {}
|
||||
}
|
||||
</script>
|
Loading…
Add table
Add a link
Reference in a new issue