// (C) Copyright 2015 Moodle Pty Ltd. // // 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 { CorePluginFileHandler } from '@services/plugin-file-delegate'; import { makeSingleton } from '@singletons'; /** * Handler to treat links to page. */ @Injectable({ providedIn: 'root' }) export class AddonModPagePluginFileHandlerService implements CorePluginFileHandler { name = 'AddonModPagePluginFileHandler'; component = 'mod_page'; /** * Return the RegExp to match the revision on pluginfile URLs. * * @param args Arguments of the pluginfile URL defining component and filearea at least. * @return RegExp to match the revision on pluginfile URLs. */ getComponentRevisionRegExp(args: string[]): RegExp | undefined { // Check filearea. if (args[2] == 'content') { // Component + Filearea + Revision return new RegExp('/mod_page/content/([0-9]+)/'); } } /** * Should return the string to remove the revision on pluginfile url. * * @return String to remove the revision on pluginfile url. */ getComponentRevisionReplace(): string { // Component + Filearea + Revision return '/mod_page/content/0/'; } /** * Whether or not the handler is enabled on a site level. * * @return Whether or not the handler is enabled on a site level. */ async isEnabled(): Promise { return true; } } export class AddonModPagePluginFileHandler extends makeSingleton(AddonModPagePluginFileHandlerService) {}