Merge pull request #3167 from dpalou/MOBILE-3833

MOBILE-3833 filepool: Fix dislay downloaded background images
main
Pau Ferrer Ocaña 2022-03-10 12:11:49 +01:00 committed by GitHub
commit f5c9c3d022
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 31 additions and 22 deletions

View File

@ -90,7 +90,7 @@ export class AddonRemoteThemesHandlerService implements CoreStyleHandler {
if (style != '') { if (style != '') {
// Treat the CSS. // Treat the CSS.
CoreUtils.ignoreErrors( CoreUtils.ignoreErrors(
CoreFilepool.treatCSSCode(siteId, fileUrl, style, COMPONENT, 2), CoreFilepool.treatCSSCode(siteId, fileUrl, style, COMPONENT, 1),
); );
} }

View File

@ -271,7 +271,7 @@ export class CoreExternalContentDirective implements AfterViewInit, OnChanges, O
urls = CoreUtils.uniqueArray(urls); // Remove duplicates. urls = CoreUtils.uniqueArray(urls); // Remove duplicates.
const promises = urls.map(async (url) => { const promises = urls.map(async (url) => {
const finalUrl = await CoreFilepool.getUrlByUrl(siteId, url, this.component, this.componentId, 0, true, true); const finalUrl = await CoreFilepool.getSrcByUrl(siteId, url, this.component, this.componentId, 0, true, true);
this.logger.debug('Using URL ' + finalUrl + ' for ' + url + ' in inline styles'); this.logger.debug('Using URL ' + finalUrl + ' for ' + url + ' in inline styles');
inlineStyles = inlineStyles.replace(new RegExp(url, 'gi'), finalUrl); inlineStyles = inlineStyles.replace(new RegExp(url, 'gi'), finalUrl);

View File

@ -195,6 +195,11 @@ export class CoreSitePluginsHelperProvider {
return ''; return '';
} }
// Update the schema with the final CSS URL.
if (handlerSchema.styles) {
handlerSchema.styles.url = url;
}
// Download the file if not downloaded or the version changed. // Download the file if not downloaded or the version changed.
const path = await CoreFilepool.downloadUrl( const path = await CoreFilepool.downloadUrl(
site.getId(), site.getId(),

View File

@ -2948,7 +2948,7 @@ export class CoreFilepoolProvider {
* and store the result in the CSS file. * and store the result in the CSS file.
* *
* @param siteId Site ID. * @param siteId Site ID.
* @param fileUrl CSS file URL. * @param fileUrl CSS file URL. If a local path is supplied the app will assume it's the path where to write the file.
* @param cssCode CSS code. * @param cssCode CSS code.
* @param component The component to link the file to. * @param component The component to link the file to.
* @param componentId An ID to use in conjunction with the component. * @param componentId An ID to use in conjunction with the component.
@ -2966,18 +2966,18 @@ export class CoreFilepoolProvider {
const urls = CoreDomUtils.extractUrlsFromCSS(cssCode); const urls = CoreDomUtils.extractUrlsFromCSS(cssCode);
let updated = false; let updated = false;
// Get the path of the CSS file. // Get the path of the CSS file. If it's a local file, assume it's the path where to write the file.
const filePath = await this.getFilePathByUrl(siteId, fileUrl); const filePath = CoreUrlUtils.isLocalFileUrl(fileUrl) ?
fileUrl :
await this.getFilePathByUrl(siteId, fileUrl);
// Download all files in the CSS. // Download all files in the CSS.
await Promise.all(urls.map(async (url) => { await Promise.all(urls.map(async (url) => {
// Download the file only if it's an online URL.
if (CoreUrlUtils.isLocalFileUrl(url)) {
return;
}
try { try {
const fileUrl = await this.downloadUrl( let fileUrl = url;
if (!CoreUrlUtils.isLocalFileUrl(url)) {
// Not a local file, download it.
fileUrl = await this.downloadUrl(
siteId, siteId,
url, url,
false, false,
@ -2989,6 +2989,10 @@ export class CoreFilepoolProvider {
undefined, undefined,
revision, revision,
); );
}
// Convert the URL so it works in mobile devices.
fileUrl = CoreFile.convertFileSrc(fileUrl);
if (fileUrl != url) { if (fileUrl != url) {
cssCode = cssCode.replace(new RegExp(CoreTextUtils.escapeForRegex(url), 'g'), fileUrl); cssCode = cssCode.replace(new RegExp(CoreTextUtils.escapeForRegex(url), 'g'), fileUrl);