2019-02-08 12:28:05 +01:00

176 lines
6.8 KiB
TypeScript

// (C) Copyright 2015 Martin Dougiamas
//
// 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.
import { Injectable } from '@angular/core';
import { CoreLoggerProvider } from '@providers/logger';
import { CoreSitesProvider, CoreSiteSchema } from '@providers/sites';
import { CoreTextUtilsProvider } from '@providers/utils/text';
import { CoreTimeUtilsProvider } from '@providers/utils/time';
/**
* Service to handle Offline feedback.
*/
@Injectable()
export class AddonModFeedbackOfflineProvider {
protected logger;
// Variables for database.
static FEEDBACK_TABLE = 'addon_mod_feedback_answers';
protected siteSchema: CoreSiteSchema = {
name: 'AddonModFeedbackOfflineProvider',
version: 1,
tables: [
{
name: AddonModFeedbackOfflineProvider.FEEDBACK_TABLE,
columns: [
{
name: 'feedbackid',
type: 'INTEGER'
},
{
name: 'page',
type: 'INTEGER'
},
{
name: 'courseid',
type: 'INTEGER'
},
{
name: 'responses',
type: 'TEXT'
},
{
name: 'timemodified',
type: 'INTEGER'
}
],
primaryKeys: ['feedbackid', 'page']
}
]
};
constructor(logger: CoreLoggerProvider, private sitesProvider: CoreSitesProvider,
private textUtils: CoreTextUtilsProvider, private timeUtils: CoreTimeUtilsProvider) {
this.logger = logger.getInstance('AddonModFeedbackOfflineProvider');
this.sitesProvider.registerSiteSchema(this.siteSchema);
}
/**
* Delete the stored for a certain feedback page.
*
* @param {number} feedbackId Feedback ID.
* @param {number} page Page of the form to delete responses from.
* @param {string} [siteId] Site ID. If not defined, current site.
* @return {Promise<any>} Promise resolved if deleted, rejected if failure.
*/
deleteFeedbackPageResponses(feedbackId: number, page: number, siteId?: string): Promise<any> {
return this.sitesProvider.getSite(siteId).then((site) => {
return site.getDb().deleteRecords(AddonModFeedbackOfflineProvider.FEEDBACK_TABLE, {feedbackid: feedbackId, page: page});
});
}
/**
* Get all the stored feedback responses data from all the feedback.
*
* @param {string} [siteId] Site ID. If not defined, current site.
* @return {Promise<any>} Promise resolved with entries.
*/
getAllFeedbackResponses(siteId?: string): Promise<any> {
return this.sitesProvider.getSite(siteId).then((site) => {
return site.getDb().getAllRecords(AddonModFeedbackOfflineProvider.FEEDBACK_TABLE).then((entries) => {
entries.forEach((entry) => {
entry.responses = this.textUtils.parseJSON(entry.responses);
});
return entries;
});
});
}
/**
* Get all the stored responses from a certain feedback.
*
* @param {number} feedbackId Feedback ID.
* @param {string} [siteId] Site ID. If not defined, current site.
* @return {Promise<any>} Promise resolved with responses.
*/
getFeedbackResponses(feedbackId: number, siteId?: string): Promise<any> {
return this.sitesProvider.getSite(siteId).then((site) => {
return site.getDb().getRecords(AddonModFeedbackOfflineProvider.FEEDBACK_TABLE, {feedbackid: feedbackId});
}).then((entries) => {
entries.forEach((entry) => {
entry.responses = this.textUtils.parseJSON(entry.responses);
});
return entries;
});
}
/**
* Get the stored responses for a certain feedback page.
*
* @param {number} feedbackId Feedback ID.
* @param {number} page Page of the form to get responses from.
* @param {string} [siteId] Site ID. If not defined, current site.
* @return {Promise<any>} Promise resolved with responses.
*/
getFeedbackPageResponses(feedbackId: number, page: number, siteId?: string): Promise<any> {
return this.sitesProvider.getSite(siteId).then((site) => {
return site.getDb().getRecord(AddonModFeedbackOfflineProvider.FEEDBACK_TABLE, {feedbackid: feedbackId, page: page});
}).then((entry) => {
entry.responses = this.textUtils.parseJSON(entry.responses);
return entry;
});
}
/**
* Get if the feedback have something to be synced.
*
* @param {number} feedbackId Feedback ID.
* @param {string} [siteId] Site ID. If not defined, current site.
* @return {Promise<any>} Promise resolved with true if the feedback have something to be synced.
*/
hasFeedbackOfflineData(feedbackId: number, siteId?: string): Promise<any> {
return this.getFeedbackResponses(feedbackId, siteId).then((responses) => {
return !!responses.length;
});
}
/**
* Save page responses to be sent later.
*
* @param {number} feedbackId Feedback ID.
* @param {number} page The page being processed.
* @param {any} responses The data to be processed the key is the field name (usually type[index]_id)
* @param {number} courseId Course ID the feedback belongs to.
* @param {string} [siteId] Site ID. If not defined, current site.
* @return {Promise<any>} Promise resolved if stored, rejected if failure.
*/
saveResponses(feedbackId: number, page: number, responses: any, courseId: number, siteId?: string): Promise<any> {
return this.sitesProvider.getSite(siteId).then((site) => {
const entry = {
feedbackid: feedbackId,
page: page,
courseid: courseId,
responses: JSON.stringify(responses),
timemodified: this.timeUtils.timestamp()
};
return site.getDb().insertRecord(AddonModFeedbackOfflineProvider.FEEDBACK_TABLE, entry);
});
}
}