MOBILE-2376 siteplugins: Parse otherdata and always inject libraries

main
Dani Palou 2018-06-04 10:34:35 +02:00
parent 7ef4726bf5
commit 129a6327e6
2 changed files with 18 additions and 5 deletions

View File

@ -119,10 +119,12 @@ export class CoreCompileHtmlComponent implements OnChanges, OnDestroy, DoCheck {
// Store this instance so it can be accessed by the outer component.
compileInstance.componentInstance = this;
// If there is some javascript to run, prepare the instance.
if (compileInstance.javascript) {
// Create 2 empty properties that can be used by the template to store data.
this['dataObject'] = {};
this['dataArray'] = [];
// Inject the libraries.
compileInstance.compileProvider.injectLibraries(this, compileInstance.extraProviders);
}
// Always add these elements, they could be needed on component init (componentObservable).
this['ChangeDetectorRef'] = compileInstance.cdr;

View File

@ -20,6 +20,7 @@ import { CoreLangProvider } from '@providers/lang';
import { CoreLoggerProvider } from '@providers/logger';
import { CoreSite, CoreSiteWSPreSets } from '@classes/site';
import { CoreSitesProvider } from '@providers/sites';
import { CoreTextUtilsProvider } from '@providers/utils/text';
import { CoreUtilsProvider } from '@providers/utils/utils';
import { CoreConfigConstants } from '../../../configconstants';
import { CoreCoursesProvider } from '@core/courses/providers/courses';
@ -68,7 +69,8 @@ export class CoreSitePluginsProvider {
constructor(logger: CoreLoggerProvider, private sitesProvider: CoreSitesProvider, private utils: CoreUtilsProvider,
private langProvider: CoreLangProvider, private appProvider: CoreAppProvider, private platform: Platform,
private filepoolProvider: CoreFilepoolProvider, private coursesProvider: CoreCoursesProvider) {
private filepoolProvider: CoreFilepoolProvider, private coursesProvider: CoreCoursesProvider,
private textUtils: CoreTextUtilsProvider) {
this.logger = logger.getInstance('CoreUserProvider');
}
@ -218,6 +220,15 @@ export class CoreSitePluginsProvider {
}).then((result) => {
if (result.otherdata) {
result.otherdata = this.utils.objectToKeyValueMap(result.otherdata, 'name', 'value');
// Try to parse all properties that could be JSON encoded strings.
for (const name in result.otherdata) {
const value = result.otherdata[name];
if (typeof value == 'string' && (value[0] == '{' || value[0] == '[')) {
result.otherdata[name] = this.textUtils.parseJSON(value);
}
}
} else {
result.otherdata = {};
}