Laravel Nova中的自定义Vue字段未称为填充方法

时间:2018-11-07 15:56:28

标签: laravel-5 vuejs2 laravel-nova

我创建了新字段,但是当我尝试更新资源方法“填充”时,它不起作用。甚至没有调用此方法。我的组件看起来像这样

<template>
    <default-field :field="field" :errors="errors">
        <template slot="field">
            <belongs-to
                v-for="(resource, key) in selectedResources"
                :key="key"
                :bidResouce="resource"
                :resourceName="field.resourceName"
                :associable="field.associableRelationship"
                :field="field"
                v-model="selectedResources[key]"
                @click="selectBid"
            >

            </belongs-to>
        </template>
    </default-field>
</template>

<script>
    import { FormField, HandlesValidationErrors } from 'laravel-nova'
    import BelongsTo from "./BelongsTo";

    export default {
        components: {BelongsTo},
        mixins: [FormField, HandlesValidationErrors],

        props: [
            'options',
            'resourceName',
            'resourceId',
            'field'
        ],

        data: () => ({
            availableResources: [],
            search: '',
            selectedResources: [],
            resourcesCount : 5
        }),se{
                    this.selectedResources = this.field.options;
                }
            },

            /**
             * Fill the given FormData object with the field's internal value.
             */
            fill(formData) {
                console.log('test')
                console.log(formData)
                formData.append(this.field.attribute, this.selectedResources || '')
            },

            /**
             * Update the field's internal value.
             */
            handleChange(value) {
                this.value = value
            },

            selectBid(resourceValue){

            }

        },

        computed: {

            defaultValues(){
                let data = {};
                for(let i =0; i< this.resourcesCount; i++ ){
                    data[i] = null;
                }
                return data;
            },

            countSelected(){
                let countNotEmptyItems = 0;
                for (let key in this.selectedResources){
                    if(!!this.selectedResources[key]){
                        countNotEmptyItems += 1;
                    }
                }
                return countNotEmptyItems;
            }
        },
        watch: {
            countSelected(newCount){
                if(newCount >= this.resourcesCount){
                    this.resourcesCount++;
                    this.selectedResources = Object.assign(this.defaultValues, this.selectedResources);
                }
            }
        }
    }
</script>

        methods: {
            /*
             * Set the initial, internal value for the field.
             */
            setInitialValue() {
                let optionsSize = _.size(this.field.options);

                if(optionsSize < this.resourcesCount){
                    this.selectedResources = Object.assign(this.defaultValues, this.field.options);
                }else{
                    this.selectedResources = this.field.options;
                }
            },

            /**
             * Fill the given FormData object with the field's internal value.
             */
            fill(formData) {
                console.log('test')
                console.log(formData)
                formData.append(this.field.attribute, this.selectedResources || '')
            },

            /**
             * Update the field's internal value.
             */
            handleChange(value) {
                this.value = value
            },

        },

        computed: {

            defaultValues(){
                let data = {};
                for(let i =0; i< this.resourcesCount; i++ ){
                    data[i] = null;
                }
                return data;
            },

            countSelected(){
                let countNotEmptyItems = 0;
                for (let key in this.selectedResources){
                    if(!!this.selectedResources[key]){
                        countNotEmptyItems += 1;
                    }
                }
                return countNotEmptyItems;
            }
        },
        watch: {
            countSelected(newCount){
                if(newCount >= this.resourcesCount){
                    this.resourcesCount++;
                    this.selectedResources = Object.assign(this.defaultValues, this.selectedResources);
                }
            }
        }
    }
</script>

请注意,这也是我的自定义组件。该文档指出

在创建或更新资源之前,Nova要求表单上的每个字段用键/值对“填充”传出的FormData对象。每个字段可以根据需要向FormData添加任意数量的元素。这可以在FormField.vue文件的fill方法中完成。

0 个答案:

没有答案