Show your latest holiday photos and videos like in the movies. Show a glimpse of your latest novel directly from your nextcloud. Choose the best GIF of your collection thanks to the direct view of your favorites files!
- Images
- Videos
- β Clone this app into the
apps
folder of your Nextcloud:git clone https://github.com/nextcloud/viewer.git
- π©βπ» In the folder of the app, run the command
make
to install dependencies and build the Javascript. - β Enable the app through the app management of your Nextcloud
- π Partytime!
To build the Javascript whenever you make changes, instead of the full make
you can also run make build-js
.
In php, on your page, emit the LoadViewer event. Check the documentation/tutorial for more info on this type of page controller sample.
use OCA\Viewer\Event\LoadViewer;
use OCP\AppFramework\Controller;
use OCP\AppFramework\Http\TemplateResponse;
use OCP\EventDispatcher\IEventDispatcher;
use OCP\IRequest;
class PageController extends Controller {
protected $appName;
/** @var IEventDispatcher */
private $eventDispatcher;
public function __construct($appName,
IRequest $request,
IEventDispatcher $eventDispatcher) {
parent::__construct($appName, $request);
$this->appName = $appName;
$this->eventDispatcher = $eventDispatcher;
}
/**
* @NoAdminRequired
* @NoCSRFRequired
* Render default index template
*
* @return TemplateResponse
*/
public function index(): TemplateResponse {
$this->eventDispatcher->dispatch(LoadViewer::class, new LoadViewer());
$response = new TemplateResponse($this->appName, 'main');
return $response;
}
}
This will load all the necessary scripts and make the Viewer accessible trough javascript at OCA.Viewer
- Open a file and let the viewer fetch the folder data
OCA.Viewer.open('/path/to/file.jpg')
- Open a file and profide a list of files
OCA.Viewer.open('/path/to/file.jpg', [
{
basename: 'file.jpg',
filename: '/path/to/file.jpg',
...
},
...
])
The second parametter requires an array of fileinfo. You can check how we generate a fileinfo object here from a dav PROPFIND request data. There is currently no dedicated package for it, but this is coming. You can check the photos repository where we also uses it.
OCA.Viewer.close()
If you want to make your app compatible with this app, you can use the OCA.Viewer
methods
- Create a vue component which use the
path
andmime
props (they will be automatically passed by the viewer) - Register your mime viewer with the following:
import VideoView from 'VideoView.vue' OCA.Viewer.registerHandler({ // unique id id: 'video', // optional, it will group every view of this group and // use the proper view when building the file list // of the slideshow. // e.g. you open an image/jpeg that have the `media` group // you will be able to see the video/mpeg from the `video` handler // files that also have the `media` group set. group: 'media', // the list of mimes your component is able to display mimes: [ 'video/mpeg', 'video/ogg', 'video/webm', 'video/mp4' ], // your vue component view component: VideoView })
- if you feel like your mime should be integrated on this repo, you can also create a pull request with your object on the
models
directory and the view on thecomponents
directory. Please have a look at what's already here and take example of it. πββοΈ