Последняя версия с сервера прошлого разработчика
This commit is contained in:
84
nova/resources/js/components/Form/SlugField.vue
Executable file
84
nova/resources/js/components/Form/SlugField.vue
Executable file
@@ -0,0 +1,84 @@
|
||||
<template>
|
||||
<default-field :field="field" :errors="errors" :show-help-text="showHelpText">
|
||||
<template slot="field">
|
||||
<div class="flex items-center">
|
||||
<input
|
||||
ref="theInput"
|
||||
class="w-full form-control form-input form-input-bordered"
|
||||
:id="field.attribute"
|
||||
:dusk="field.attribute"
|
||||
v-model="value"
|
||||
:disabled="isReadonly"
|
||||
v-bind="extraAttributes"
|
||||
/>
|
||||
|
||||
<button
|
||||
class="btn btn-link rounded px-1 py-1 inline-flex text-sm text-primary ml-1 mt-2"
|
||||
v-if="field.showCustomizeButton"
|
||||
type="button"
|
||||
@click="toggleCustomizeClick"
|
||||
>
|
||||
{{ __('Customize') }}
|
||||
</button>
|
||||
</div>
|
||||
</template>
|
||||
</default-field>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import { FormField, HandlesValidationErrors } from 'laravel-nova'
|
||||
import slugify from '@/util/slugify'
|
||||
|
||||
export default {
|
||||
mixins: [HandlesValidationErrors, FormField],
|
||||
|
||||
mounted() {
|
||||
if (this.shouldRegisterInitialListener) {
|
||||
this.registerChangeListener()
|
||||
}
|
||||
},
|
||||
|
||||
methods: {
|
||||
changeListener(value) {
|
||||
return value => {
|
||||
this.value = slugify(value, this.field.separator)
|
||||
}
|
||||
},
|
||||
|
||||
registerChangeListener() {
|
||||
Nova.$on(this.eventName, value => {
|
||||
this.value = slugify(value, this.field.separator)
|
||||
})
|
||||
},
|
||||
|
||||
toggleCustomizeClick() {
|
||||
if (this.field.readonly) {
|
||||
Nova.$off(this.eventName)
|
||||
this.field.readonly = false
|
||||
this.field.extraAttributes.readonly = false
|
||||
this.field.showCustomizeButton = false
|
||||
this.$refs.theInput.focus()
|
||||
return
|
||||
}
|
||||
|
||||
this.registerChangeListener()
|
||||
this.field.readonly = true
|
||||
this.field.extraAttributes.readonly = true
|
||||
},
|
||||
},
|
||||
|
||||
computed: {
|
||||
shouldRegisterInitialListener() {
|
||||
return !this.field.updating
|
||||
},
|
||||
|
||||
eventName() {
|
||||
return `${this.field.from}-change`
|
||||
},
|
||||
|
||||
extraAttributes() {
|
||||
return this.field.extraAttributes || {}
|
||||
},
|
||||
},
|
||||
}
|
||||
</script>
|
||||
Reference in New Issue
Block a user