/**
* This file is part of Threema Web.
*
* Threema Web is free software: you can redistribute it and/or modify it
* under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at
* your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero
* General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with Threema Web. If not, see .
*/
import {AsyncEvent} from 'ts-events';
/**
* This service is responsible for showing / hiding the media box.
*/
export class MediaboxService {
private logTag: string = '[MediaboxService]';
private $log: ng.ILogService;
/**
* This event is triggered every time the media element changes.
*
* The boolean parameter indicates whether media content is available or not.
*/
public evtMediaChanged = new AsyncEvent();
/**
* The full-resolution media data.
*/
public data: ArrayBuffer | null = null;
public static $inject = ['$log'];
constructor($log: ng.ILogService) {
this.$log = $log;
}
/**
* Update media data.
*/
public setMedia(data: ArrayBuffer) {
this.$log.debug(this.logTag, 'Media data updated');
this.data = data;
this.evtMediaChanged.post(data !== null);
}
/**
* Clear media data.
*/
public clearMedia() {
this.$log.debug(this.logTag, 'Media data cleared');
this.data = null;
this.evtMediaChanged.post(false);
}
}