. * */ /** * Public interface of ownCloud for apps to use. * Preview interface * */ // use OCP namespace for all classes that are considered public. // This means that they should be used by apps instead of the internal ownCloud classes namespace OCP; /** * This class provides functions to render and show thumbnails and previews of files */ interface IPreview { /** * In order to improve lazy loading a closure can be registered which will be * called in case preview providers are actually requested * * $callable has to return an instance of \OCP\Preview\IProvider * * @param string $mimeTypeRegex Regex with the mime types that are supported by this provider * @param \Closure $callable * @return void */ public function registerProvider($mimeTypeRegex, \Closure $callable); /** * Get all providers * @return array */ public function getProviders(); /** * Does the manager have any providers * @return bool */ public function hasProviders(); /** * Return a preview of a file * @param string $file The path to the file where you want a thumbnail from * @param int $maxX The maximum X size of the thumbnail. It can be smaller depending on the shape of the image * @param int $maxY The maximum Y size of the thumbnail. It can be smaller depending on the shape of the image * @param boolean $scaleUp Scale smaller images up to the thumbnail size or not. Might look ugly * @return \OCP\Image */ public function createPreview($file, $maxX = 100, $maxY = 75, $scaleUp = false); /** * Returns true if the passed mime type is supported * @param string $mimeType * @return boolean */ public function isMimeSupported($mimeType = '*'); /** * Check if a preview can be generated for a file * * @param \OCP\Files\FileInfo $file * @return bool */ public function isAvailable(\OCP\Files\FileInfo $file); }