2019-09-26 12:43:29 +02:00
|
|
|
// (C) Copyright 2015 Moodle Pty Ltd.
|
2018-03-16 13:44:57 +01:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2018-06-22 11:32:58 +02:00
|
|
|
import { Component, Input, Optional, Injector, ViewChild } from '@angular/core';
|
2018-03-16 13:44:57 +01:00
|
|
|
import { Content, NavController } from 'ionic-angular';
|
|
|
|
import { CoreGroupInfo, CoreGroupsProvider } from '@providers/groups';
|
2018-12-13 15:35:47 +01:00
|
|
|
import { CoreTimeUtilsProvider } from '@providers/utils/time';
|
2018-03-16 13:44:57 +01:00
|
|
|
import { CoreCourseModuleMainActivityComponent } from '@core/course/classes/main-activity-component';
|
|
|
|
import { AddonModFeedbackProvider } from '../../providers/feedback';
|
|
|
|
import { AddonModFeedbackHelperProvider } from '../../providers/helper';
|
|
|
|
import { AddonModFeedbackOfflineProvider } from '../../providers/offline';
|
|
|
|
import { AddonModFeedbackSyncProvider } from '../../providers/sync';
|
2018-06-22 11:32:58 +02:00
|
|
|
import { CoreTabsComponent } from '@components/tabs/tabs';
|
2018-03-16 13:44:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Component that displays a feedback index page.
|
|
|
|
*/
|
|
|
|
@Component({
|
|
|
|
selector: 'addon-mod-feedback-index',
|
2018-06-12 08:41:17 +02:00
|
|
|
templateUrl: 'addon-mod-feedback-index.html',
|
2018-03-16 13:44:57 +01:00
|
|
|
})
|
|
|
|
export class AddonModFeedbackIndexComponent extends CoreCourseModuleMainActivityComponent {
|
2018-06-22 11:32:58 +02:00
|
|
|
@ViewChild(CoreTabsComponent) tabsComponent: CoreTabsComponent;
|
|
|
|
|
2018-03-16 13:44:57 +01:00
|
|
|
@Input() tab = 'overview';
|
|
|
|
@Input() group = 0;
|
|
|
|
|
2019-03-27 18:55:29 +01:00
|
|
|
component = AddonModFeedbackProvider.COMPONENT;
|
2018-03-16 13:44:57 +01:00
|
|
|
moduleName = 'feedback';
|
|
|
|
|
|
|
|
access = {
|
|
|
|
canviewreports: false,
|
|
|
|
canviewanalysis: false,
|
|
|
|
isempty: true
|
|
|
|
};
|
|
|
|
feedback: any;
|
|
|
|
goPage: number;
|
|
|
|
groupInfo: CoreGroupInfo = {
|
|
|
|
groups: [],
|
|
|
|
separateGroups: false,
|
|
|
|
visibleGroups: false
|
|
|
|
};
|
|
|
|
items: any[];
|
|
|
|
overview = {
|
|
|
|
timeopen: 0,
|
|
|
|
openTimeReadable: '',
|
|
|
|
timeclose: 0,
|
|
|
|
closeTimeReadable: ''
|
|
|
|
};
|
|
|
|
warning = '';
|
|
|
|
tabsLoaded = {
|
|
|
|
overview: false,
|
|
|
|
analysis: false
|
|
|
|
};
|
|
|
|
showTabs = false;
|
|
|
|
tabsReady = false;
|
2018-03-22 14:45:10 +01:00
|
|
|
firstSelectedTab: number;
|
2018-03-16 13:44:57 +01:00
|
|
|
|
|
|
|
protected submitObserver: any;
|
2019-03-27 18:55:29 +01:00
|
|
|
protected syncEventName = AddonModFeedbackSyncProvider.AUTO_SYNCED;
|
2018-03-16 13:44:57 +01:00
|
|
|
|
2018-04-11 13:49:59 +02:00
|
|
|
constructor(injector: Injector, private feedbackProvider: AddonModFeedbackProvider, @Optional() content: Content,
|
2018-03-16 13:44:57 +01:00
|
|
|
private feedbackOffline: AddonModFeedbackOfflineProvider, private groupsProvider: CoreGroupsProvider,
|
2019-02-14 16:14:57 +01:00
|
|
|
private feedbackSync: AddonModFeedbackSyncProvider, protected navCtrl: NavController,
|
2018-12-13 15:35:47 +01:00
|
|
|
private feedbackHelper: AddonModFeedbackHelperProvider, private timeUtils: CoreTimeUtilsProvider) {
|
2018-04-11 13:49:59 +02:00
|
|
|
super(injector, content);
|
2018-03-16 13:44:57 +01:00
|
|
|
|
|
|
|
// Listen for form submit events.
|
|
|
|
this.submitObserver = this.eventsProvider.on(AddonModFeedbackProvider.FORM_SUBMITTED, (data) => {
|
|
|
|
if (this.feedback && data.feedbackId == this.feedback.id) {
|
|
|
|
this.tabsLoaded['analysis'] = false;
|
|
|
|
this.tabsLoaded['overview'] = false;
|
|
|
|
this.loaded = false;
|
2019-02-26 09:17:49 +01:00
|
|
|
|
|
|
|
let promise;
|
|
|
|
|
|
|
|
// Prefetch data if needed.
|
|
|
|
if (!data.offline && this.isPrefetched()) {
|
|
|
|
promise = this.feedbackSync.prefetchAfterUpdate(this.module, this.courseId).catch(() => {
|
|
|
|
// Ignore errors.
|
|
|
|
});
|
2018-03-16 13:44:57 +01:00
|
|
|
} else {
|
2019-02-26 09:17:49 +01:00
|
|
|
promise = Promise.resolve();
|
2018-03-16 13:44:57 +01:00
|
|
|
}
|
2019-02-26 09:17:49 +01:00
|
|
|
|
|
|
|
promise.then(() => {
|
|
|
|
// Load the right tab.
|
|
|
|
if (data.tab != this.tab) {
|
|
|
|
this.tabChanged(data.tab);
|
|
|
|
} else {
|
|
|
|
this.loadContent(true);
|
|
|
|
}
|
|
|
|
});
|
2018-03-16 13:44:57 +01:00
|
|
|
}
|
|
|
|
}, this.siteId);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Component being initialized.
|
|
|
|
*/
|
|
|
|
ngOnInit(): void {
|
|
|
|
super.ngOnInit();
|
|
|
|
|
|
|
|
this.loadContent(false, true).then(() => {
|
2019-10-22 10:49:28 +02:00
|
|
|
if (this.feedback) {
|
|
|
|
this.feedbackProvider.logView(this.feedback.id, this.feedback.name).catch(() => {
|
|
|
|
// Ignore errors.
|
|
|
|
});
|
|
|
|
}
|
2018-03-16 13:44:57 +01:00
|
|
|
}).finally(() => {
|
|
|
|
this.tabsReady = true;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Perform the invalidate content function.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @return Resolved when done.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected invalidateContent(): Promise<any> {
|
|
|
|
const promises = [];
|
|
|
|
|
|
|
|
promises.push(this.feedbackProvider.invalidateFeedbackData(this.courseId));
|
|
|
|
if (this.feedback) {
|
|
|
|
promises.push(this.feedbackProvider.invalidateFeedbackAccessInformationData(this.feedback.id));
|
|
|
|
promises.push(this.feedbackProvider.invalidateAnalysisData(this.feedback.id));
|
|
|
|
promises.push(this.groupsProvider.invalidateActivityAllowedGroups(this.feedback.coursemodule));
|
|
|
|
promises.push(this.groupsProvider.invalidateActivityGroupMode(this.feedback.coursemodule));
|
|
|
|
promises.push(this.feedbackProvider.invalidateResumePageData(this.feedback.id));
|
|
|
|
}
|
|
|
|
|
|
|
|
this.tabsLoaded['analysis'] = false;
|
|
|
|
this.tabsLoaded['overview'] = false;
|
|
|
|
|
|
|
|
return Promise.all(promises);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Compares sync event data with current data to check if refresh content is needed.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param syncEventData Data receiven on sync observer.
|
|
|
|
* @return True if refresh is needed, false otherwise.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected isRefreshSyncNeeded(syncEventData: any): boolean {
|
|
|
|
if (this.feedback && syncEventData.feedbackId == this.feedback.id) {
|
|
|
|
// Refresh the data.
|
2018-08-23 13:28:30 +02:00
|
|
|
this.domUtils.scrollToTop(this.content);
|
2018-03-16 13:44:57 +01:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Download feedback contents.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param refresh If it's refreshing content.
|
|
|
|
* @param sync If it should try to sync.
|
|
|
|
* @param showErrors If show errors to the user of hide them.
|
|
|
|
* @return Promise resolved when done.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected fetchContent(refresh: boolean = false, sync: boolean = false, showErrors: boolean = false): Promise<any> {
|
|
|
|
return this.feedbackProvider.getFeedback(this.courseId, this.module.id).then((feedback) => {
|
|
|
|
this.feedback = feedback;
|
|
|
|
|
|
|
|
this.description = feedback.intro || feedback.description;
|
|
|
|
this.dataRetrieved.emit(feedback);
|
|
|
|
|
|
|
|
if (sync) {
|
|
|
|
// Try to synchronize the feedback.
|
|
|
|
return this.syncActivity(showErrors);
|
|
|
|
}
|
|
|
|
}).then(() => {
|
|
|
|
// Check if there are answers stored in offline.
|
2020-09-02 16:00:18 +02:00
|
|
|
return this.feedbackProvider.getFeedbackAccessInformation(this.feedback.id, {cmId: this.module.id});
|
2018-03-16 13:44:57 +01:00
|
|
|
}).then((accessData) => {
|
|
|
|
this.access = accessData;
|
|
|
|
this.showTabs = (accessData.canviewreports || accessData.canviewanalysis) && !accessData.isempty;
|
|
|
|
|
2018-03-22 14:45:10 +01:00
|
|
|
this.firstSelectedTab = 0;
|
2018-03-16 13:44:57 +01:00
|
|
|
if (this.tab == 'analysis') {
|
2018-03-22 14:45:10 +01:00
|
|
|
this.firstSelectedTab = 1;
|
|
|
|
|
2018-03-16 13:44:57 +01:00
|
|
|
return this.fetchFeedbackAnalysisData(this.access);
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.fetchFeedbackOverviewData(this.access);
|
2019-08-29 10:37:01 +02:00
|
|
|
}).finally(() => {
|
|
|
|
// Now fill the context menu.
|
2018-03-16 13:44:57 +01:00
|
|
|
this.fillContextMenu(refresh);
|
|
|
|
|
2019-10-22 10:49:28 +02:00
|
|
|
if (this.feedback) {
|
|
|
|
// Check if there are responses stored in offline.
|
|
|
|
return this.feedbackOffline.hasFeedbackOfflineData(this.feedback.id).then((hasOffline) => {
|
|
|
|
this.hasOffline = hasOffline;
|
|
|
|
});
|
|
|
|
}
|
2018-03-16 13:44:57 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convenience function to get feedback overview data.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param accessData Retrieved access data.
|
|
|
|
* @return Resolved when done.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected fetchFeedbackOverviewData(accessData: any): Promise<any> {
|
|
|
|
const promises = [];
|
|
|
|
|
|
|
|
if (accessData.cancomplete && accessData.cansubmit && accessData.isopen) {
|
2020-09-02 16:00:18 +02:00
|
|
|
promises.push(this.feedbackProvider.getResumePage(this.feedback.id, {cmId: this.module.id}).then((goPage) => {
|
2018-03-16 13:44:57 +01:00
|
|
|
this.goPage = goPage > 0 ? goPage : false;
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (accessData.canedititems) {
|
|
|
|
this.overview.timeopen = parseInt(this.feedback.timeopen) * 1000 || 0;
|
2018-12-13 15:35:47 +01:00
|
|
|
this.overview.openTimeReadable = this.overview.timeopen ? this.timeUtils.userDate(this.overview.timeopen) : '';
|
2018-03-16 13:44:57 +01:00
|
|
|
this.overview.timeclose = parseInt(this.feedback.timeclose) * 1000 || 0;
|
2018-12-13 15:35:47 +01:00
|
|
|
this.overview.closeTimeReadable = this.overview.timeclose ? this.timeUtils.userDate(this.overview.timeclose) : '';
|
2018-12-07 14:55:24 +01:00
|
|
|
}
|
|
|
|
if (accessData.canviewanalysis) {
|
2018-03-16 13:44:57 +01:00
|
|
|
// Get groups (only for teachers).
|
|
|
|
promises.push(this.fetchGroupInfo(this.feedback.coursemodule));
|
|
|
|
}
|
|
|
|
|
|
|
|
return Promise.all(promises).finally(() => {
|
|
|
|
this.tabsLoaded['overview'] = true;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convenience function to get feedback analysis data.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param accessData Retrieved access data.
|
|
|
|
* @return Resolved when done.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected fetchFeedbackAnalysisData(accessData: any): Promise<any> {
|
|
|
|
let promise;
|
|
|
|
|
|
|
|
if (accessData.canviewanalysis) {
|
|
|
|
// Get groups (only for teachers).
|
|
|
|
promise = this.fetchGroupInfo(this.feedback.coursemodule);
|
|
|
|
} else {
|
|
|
|
this.tabChanged('overview');
|
|
|
|
promise = Promise.resolve();
|
|
|
|
}
|
|
|
|
|
|
|
|
return promise.finally(() => {
|
|
|
|
this.tabsLoaded['analysis'] = true;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch Group info data.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param cmId Course module ID.
|
|
|
|
* @return Resolved when done.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected fetchGroupInfo(cmId: number): Promise<any> {
|
|
|
|
return this.groupsProvider.getActivityGroupInfo(cmId).then((groupInfo) => {
|
|
|
|
this.groupInfo = groupInfo;
|
|
|
|
|
2019-07-26 09:14:19 +02:00
|
|
|
return this.setGroup(this.groupsProvider.validateGroupId(this.group, groupInfo));
|
2018-03-16 13:44:57 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse the analysis info to show the info correctly formatted.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param item Item to parse.
|
|
|
|
* @return Parsed item.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected parseAnalysisInfo(item: any): any {
|
|
|
|
switch (item.typ) {
|
|
|
|
case 'numeric':
|
|
|
|
item.average = item.data.reduce((prev, current) => {
|
|
|
|
return prev + parseInt(current, 10);
|
|
|
|
}, 0) / item.data.length;
|
|
|
|
item.template = 'numeric';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'info':
|
|
|
|
item.data = item.data.map((dataItem) => {
|
|
|
|
dataItem = this.textUtils.parseJSON(dataItem);
|
|
|
|
|
|
|
|
return typeof dataItem.show != 'undefined' ? dataItem.show : false;
|
|
|
|
}).filter((dataItem) => {
|
|
|
|
// Filter false entries.
|
|
|
|
return dataItem;
|
|
|
|
});
|
|
|
|
|
|
|
|
case 'textfield':
|
|
|
|
case 'textarea':
|
|
|
|
item.template = 'list';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'multichoicerated':
|
|
|
|
case 'multichoice':
|
|
|
|
item.data = item.data.map((dataItem) => {
|
|
|
|
dataItem = this.textUtils.parseJSON(dataItem);
|
|
|
|
|
|
|
|
return typeof dataItem.answertext != 'undefined' ? dataItem : false;
|
|
|
|
}).filter((dataItem) => {
|
|
|
|
// Filter false entries.
|
|
|
|
return dataItem;
|
|
|
|
});
|
|
|
|
|
|
|
|
// Format labels.
|
|
|
|
item.labels = item.data.map((dataItem) => {
|
|
|
|
dataItem.quotient = (dataItem.quotient * 100).toFixed(2);
|
|
|
|
let label = '';
|
|
|
|
|
|
|
|
if (typeof dataItem.value != 'undefined') {
|
|
|
|
label = '(' + dataItem.value + ') ';
|
|
|
|
}
|
|
|
|
label += dataItem.answertext;
|
|
|
|
label += dataItem.quotient > 0 ? ' (' + dataItem.quotient + '%)' : '';
|
|
|
|
|
|
|
|
return label;
|
|
|
|
});
|
|
|
|
|
|
|
|
item.chartData = item.data.map((dataItem) => {
|
|
|
|
return dataItem.answercount;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (item.typ == 'multichoicerated') {
|
|
|
|
item.average = item.data.reduce((prev, current) => {
|
|
|
|
return prev + parseFloat(current.avg);
|
|
|
|
}, 0.0);
|
|
|
|
}
|
|
|
|
|
|
|
|
const subtype = item.presentation.charAt(0);
|
|
|
|
|
|
|
|
const single = subtype != 'c';
|
|
|
|
item.chartType = single ? 'doughnut' : 'bar';
|
|
|
|
|
|
|
|
item.template = 'chart';
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return item;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function to go to the questions form.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param preview Preview or edit the form.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
2018-03-23 08:38:00 +01:00
|
|
|
gotoAnswerQuestions(preview: boolean = false): void {
|
2018-03-16 13:44:57 +01:00
|
|
|
const stateParams = {
|
|
|
|
module: this.module,
|
2018-03-23 08:38:00 +01:00
|
|
|
moduleId: this.module.id,
|
|
|
|
courseId: this.courseId,
|
2018-03-16 13:44:57 +01:00
|
|
|
preview: preview
|
|
|
|
};
|
|
|
|
this.navCtrl.push('AddonModFeedbackFormPage', stateParams);
|
|
|
|
}
|
|
|
|
|
2018-06-22 11:32:58 +02:00
|
|
|
/**
|
|
|
|
* User entered the page that contains the component.
|
|
|
|
*/
|
|
|
|
ionViewDidEnter(): void {
|
|
|
|
super.ionViewDidEnter();
|
|
|
|
|
|
|
|
this.tabsComponent && this.tabsComponent.ionViewDidEnter();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* User left the page that contains the component.
|
|
|
|
*/
|
|
|
|
ionViewDidLeave(): void {
|
|
|
|
super.ionViewDidLeave();
|
|
|
|
|
|
|
|
this.tabsComponent && this.tabsComponent.ionViewDidLeave();
|
|
|
|
}
|
|
|
|
|
2018-03-16 13:44:57 +01:00
|
|
|
/**
|
|
|
|
* Function to link implemented features.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param feature Feature to navigate.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
openFeature(feature: string): void {
|
|
|
|
this.feedbackHelper.openFeature(feature, this.navCtrl, this.module, this.courseId, this.group);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tab changed, fetch content again.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param tabName New tab name.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
tabChanged(tabName: string): void {
|
|
|
|
this.tab = tabName;
|
|
|
|
|
|
|
|
if (!this.tabsLoaded[this.tab]) {
|
|
|
|
this.loadContent(false, false, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set group to see the analysis.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param groupId Group ID.
|
|
|
|
* @return Resolved when done.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
setGroup(groupId: number): Promise<any> {
|
|
|
|
this.group = groupId;
|
|
|
|
|
2020-09-02 16:00:18 +02:00
|
|
|
return this.feedbackProvider.getAnalysis(this.feedback.id, {groupId, cmId: this.module.id}).then((analysis) => {
|
2018-03-16 13:44:57 +01:00
|
|
|
this.feedback.completedCount = analysis.completedcount;
|
|
|
|
this.feedback.itemsCount = analysis.itemscount;
|
|
|
|
|
|
|
|
if (this.tab == 'analysis') {
|
|
|
|
let num = 1;
|
|
|
|
|
|
|
|
this.items = analysis.itemsdata.map((item) => {
|
|
|
|
// Move data inside item.
|
|
|
|
item.item.data = item.data;
|
|
|
|
item = item.item;
|
|
|
|
item.number = num++;
|
|
|
|
if (item.data && item.data.length) {
|
|
|
|
return this.parseAnalysisInfo(item);
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}).filter((item) => {
|
|
|
|
return item;
|
|
|
|
});
|
|
|
|
|
|
|
|
this.warning = '';
|
|
|
|
if (analysis.warnings.length) {
|
2018-09-05 10:13:31 +02:00
|
|
|
const warning = analysis.warnings.find((warning) => {
|
2018-03-16 13:44:57 +01:00
|
|
|
return warning.warningcode == 'insufficientresponsesforthisgroup';
|
|
|
|
});
|
2018-09-05 10:13:31 +02:00
|
|
|
this.warning = warning && warning.message;
|
2018-03-16 13:44:57 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Performs the sync of the activity.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @return Promise resolved when done.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected sync(): Promise<any> {
|
|
|
|
return this.feedbackSync.syncFeedback(this.feedback.id);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks if sync has succeed from result sync data.
|
|
|
|
*
|
2019-09-10 16:48:56 +02:00
|
|
|
* @param result Data returned on the sync function.
|
|
|
|
* @return If suceed or not.
|
2018-03-16 13:44:57 +01:00
|
|
|
*/
|
|
|
|
protected hasSyncSucceed(result: any): boolean {
|
|
|
|
return result.updated;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Component being destroyed.
|
|
|
|
*/
|
|
|
|
ngOnDestroy(): void {
|
|
|
|
super.ngOnDestroy();
|
|
|
|
this.submitObserver && this.submitObserver.off();
|
|
|
|
}
|
|
|
|
}
|