Обновить данные в for: каждый цикл: веб-компоненты Lightning

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

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

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

Примечание: объект Task не поддерживается в LWC, и я не могу использовать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;
    }

3 ответа

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

но вам не назначен какой-либо проводной метод. Следовательно, данные не обновляются

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

Чтобы обновить проводной метод, передайте аргумент, который получает проводной метод (который является проводным значением), в 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;
    });

Вам , вероятно, нужно дождаться следующего выпуска, чтобы иметь правильный способ справиться с такой ситуацией.

Вы получаете запись через uiRecordApi и обновляете через Apex, если я прав. Тогда вам нужно будет использовать getRecordNotifyChange()доступно в версии Winter 21.

Помимо ответа, предоставленного Сударшаном, вы также должны определить taskCompWrapperList как реактивное свойство, чтобы оно перерисовывалось при обновлении свойства.

      @track taskCompWrapperList = [];
Другие вопросы по тегам