Refre sh Datatable для: каждый l oop: веб-компоненты Lightning - PullRequest
0 голосов
/ 19 марта 2020

У меня проблемы с обновлением таблицы данных в моем веб-компоненте Lightning после обновления записи. Я вызываю действие onclick для кнопки в строке и обязательно вызываю метод Apex для обновления этой записи. Затем я вызываю refreshApex () для обновления данных, передаваемых в Datatable.

Однако после refreshApex() таблицы в пределах for: каждая не обновляется новыми данными.

Записи корректно изменяются и корректно отражают изменения при обновлении всей страницы.

Примечание: Объект Task не поддерживается в LW C, и я нельзя использовать метод updateRecord() для обновления этих записей.

HTML:

<template>
  <template if:true="{taskCompWrapperList}">
    <!--<lightning-layout multiple-rows="false" pull-to-boundary="small">-->
    <template for:each="{taskCompWrapperList}" for:item="taskTemplate">
      <lightning-layout-item
        key="{taskTemplate.taskSectionOrder}"
        size="3"
        class="slds-p-around_x-small"
      >
        <!-- Start bear tile -->
        <lightning-card title="{taskTemplate.taskSectionTitle}">
          <div class="slds-m-around_medium">
            <template if:true="{taskTemplate.taskList}">
              <lightning-datatable
                key-field="Id"
                data="{taskTemplate.taskList}"
                onrowaction="{handleRowAction}"
                columns="{columns}"
                onsave="{handleSave}"
                draft-values="{draftValues}"
              >
              </lightning-datatable>
            </template>
            <template if:true="{contact.error}">
              <!-- handle Apex error -->
            </template>
          </div>
        </lightning-card>
        <!-- End bear tile -->
      </lightning-layout-item>
    </template>
    <!--</lightning-layout>-->
  </template>
</template>

Javascript:

import { LightningElement, api, wire ,track} from 'lwc';
import getTaskCompWrappers from '@salesforce/apex/ENT_Task_Utility.getTaskComponentWrapper';
import updateTask from '@salesforce/apex/ENT_Task_Utility.updateTask';
import { ShowToastEvent } from 'lightning/platformShowToastEvent';
import { updateRecord } from 'lightning/uiRecordApi';
import { refreshApex } from '@salesforce/apex';

const COLS = [
    {        
        type: 'button',
        label: 'Complete',
        typeAttributes: 
        {
            //iconName: 'action:preview',
            label: 'Complete',
            name: 'Complete',
            title: 'Complete',
            value: 'Complete',
            variant: 'brand',
            alternativeText: 'Complete'
        }
    },
    {        
        type: 'button-icon', 
        label: 'Start',       
        typeAttributes: 
        {
            iconName: 'action:approval',
            //label: 'Complete',
            name: 'Start',
            title: 'Start',
            value: 'Start',
            variant: 'success',            
            alternativeText: 'Start',
        }
    },
    {
        type: "button", 
        typeAttributes: 
        {  
            label: 'View',  
            name: 'View',  
            title: 'View',  
            disabled: false,  
            value: 'view',  
            iconPosition: 'left'  
        }
    },  
    {
        type: "button", 
        typeAttributes: 
        {  
            label: 'Edit',  
            name: 'Edit',  
            title: 'Edit',  
            disabled: false,  
            value: 'edit',  
            iconPosition: 'left'  
        }
    },  
    //{ label: 'Complete', fieldName: 'Task_Complete__c', editable: true },
    { label: 'Status', fieldName: 'Status', type: 'picklist', editable: true },
    { label: 'Completed', fieldName: 'Completed', type: 'boolean', editable: true },
    { label: 'Owner', fieldName: 'OwnerId', editable: true },
    { label: 'Subject', fieldName: 'Subject' },
    { label: 'Due Date', fieldName: 'ActivityDate', type: 'date' }
];

export default class ENT_Task_Utility_LWC extends LightningElement {
    @api objApiName;
    @api recordId;
    @track testMessage = 'Test Failed :c';  

    @track error;
    @track columns = COLS;
    @track draftValues = [];
    taskCompWrapperList;
    @track error;

    //@wire(getTasks, {recordId: '$recordId'}) taskList;`
    @wire(getTaskCompWrappers, {recordId: '$recordId', objApiName: '$objApiName'}) 
    taskCompWrapperListWire({ error, data }) {
        if (data) {
            this.taskCompWrapperList = data;
            this.error = undefined;
        } else if (error) {
            this.error = error;
            this.taskCompWrapperList = undefined;
        }
    }

    updateTaskValues (taskId, taskStatus) {
        // eslint-disable-next-line no-console
        console.log('updateTaskValues hit');
        for(var counter = 0; counter < this.taskCompWrapperList.length; counter++) {
            // eslint-disable-next-line no-console
            console.log('taskWrapper: ' + this.taskCompWrapperList[counter]);
            for(var counter2 = 0; counter2 < this.taskCompWrapperList[counter].taskList.length; counter2++) {
                // eslint-disable-next-line no-console
                console.log('task: ' + this.taskCompWrapperList[counter].taskList[counter2]);
                if(this.taskCompWrapperList[counter].taskList[counter2].Id == taskId)
                {
                    this.dispatchEvent(
                        new ShowToastEvent({
                            title: 'Task Id Found!',
                            message: this.taskCompWrapperList[counter].taskList[counter2].Id,
                            variant: 'success'
                        })
                    );
                    this.taskCompWrapperList[counter].taskList[counter2].Status = taskStatus;
                }
            }
        }
    }

    handleRowAction(event) {
        //TODO
    }    
}

Методы Apex:

@AuraEnabled(cacheable=true)
    global static List<Task> getTasks(String recordId)
    {
        return [SELECT Id, Subject, OwnerId FROM Task WHERE WhatId = :recordId];
    }

    @AuraEnabled(cacheable=true)
    global static List<ENT_Task_Comp_Wrapper> getTaskComponentWrapper(String recordId, String objApiName)
    {
        List<Task_Template__c> taskTemplateList = [SELECT Id, Task_Component_Section_Order__c, Task_Component_Section_Title__c, (SELECT Id FROM Task_Template_Items__r) 
                                                   FROM Task_Template__c 
                                                   WHERE Active__c = true AND sObject__c = :objApiName ORDER BY Task_Component_Section_Order__c ASC];

        List<Task> taskList = [SELECT Id, Task_Template_Item__c, OwnerId, Owner.Name, Subject, Description, Status, ActivityDate, Task_Complete__c FROM TasK WHERE WhatId = :recordId];

        List<ENT_Task_Comp_Wrapper> taskCompWrapperList = new List<ENT_Task_Comp_Wrapper>();

        for(Task_Template__c taskTemplate : taskTemplateList)
        {
            ENT_Task_Comp_Wrapper taskCompWrapper = new ENT_Task_Comp_Wrapper();
            taskCompWrapper.taskSectionTitle = taskTemplate.Task_Component_Section_Title__c;
            taskCompWrapper.taskSectionOrder = (Integer)taskTemplate.Task_Component_Section_Order__c;
            taskCompWrapper.taskList = new List<Task>();

            for(Task currentTask : taskList)
            {
                for(Task_Template_Item__c taskTemplateItem : taskTemplate.Task_Template_Items__r)
                {
                    if(taskTemplateItem.Id == currentTask.Task_Template_Item__c)
                    {
                        taskCompWrapper.taskList.add(currentTask);
                    }
                }
            }

            taskCompWrapperList.add(taskCompWrapper);

        }
        System.debug(taskCompWrapperList);
        return taskCompWrapperList;
    }

    @AuraEnabled
    global static void updateTask(String taskId, String newStatus)
    {
        System.debug(taskId);
        Task taskToUpdate = new Task(Id = taskId, Status = newStatus);
        update taskToUpdate;
        //update taskToUpdate;
    }

@AuraEnabled
    global static void updateTask(String taskId, String newStatus)
    {
        System.debug(taskId);
        Task taskToUpdate = new Task(Id = taskId, Status = newStatus);
        update taskToUpdate;
        //update taskToUpdate;
    }

1 Ответ

0 голосов
/ 20 марта 2020

В своем коде JS вы импортировали refreshApex, используя эту строку import { refreshApex } from '@salesforce/apex';

, но не указали ни один метод связи. Следовательно, данные не обновляются

Пожалуйста, обратитесь к этой документации .

Чтобы обновить sh проводной метод, передайте аргумент, который получает проводной метод (который является значением проводной сети). ) до refreshApex(). В этом примере кода проводной метод - taskCompWrapperListWire. Удерживайте значение, предоставленное проводной службой, и передайте его в refreshApex ().

@wire(getTaskCompWrappers, {recordId: '$recordId', objApiName: '$objApiName'}) 
taskCompWrapperListWire({ error, data }) {
    if (data) {
        this.taskCompWrapperList = data;
        this.error = undefined;
    } else if (error) {
        this.error = error;
        this.taskCompWrapperList = undefined;
    }
}

А затем используйте refreshApex(), как показано ниже:

refreshApex(this.taskCompWrapperListWire);

Обновите код, как показано ниже

updateTaskValues({
        taskId: this.taskId,
        taskStatus: this. taskStatus
   })
    .then(() => {
        // your code logic 
        refreshApex(this.taskCompWrapperListWire);
    })
    .catch((error) => {
        this.message = 'Error received: code' + error.errorCode + ', ' +
            'message ' + error.body.message;
    });
...