mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-09 15:38:27 +01:00
Convert et2_video widget to TS
This commit is contained in:
parent
af6afdcffe
commit
6758895ae2
@ -1,3 +1,4 @@
|
|||||||
|
"use strict";
|
||||||
/**
|
/**
|
||||||
* EGroupware eTemplate2 - JS Description object
|
* EGroupware eTemplate2 - JS Description object
|
||||||
*
|
*
|
||||||
@ -9,13 +10,28 @@
|
|||||||
* @copyright Stylite AG
|
* @copyright Stylite AG
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
*/
|
*/
|
||||||
|
var __extends = (this && this.__extends) || (function () {
|
||||||
|
var extendStatics = function (d, b) {
|
||||||
|
extendStatics = Object.setPrototypeOf ||
|
||||||
|
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
||||||
|
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
|
||||||
|
return extendStatics(d, b);
|
||||||
|
};
|
||||||
|
return function (d, b) {
|
||||||
|
extendStatics(d, b);
|
||||||
|
function __() { this.constructor = d; }
|
||||||
|
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
/*egw:uses
|
/*egw:uses
|
||||||
/vendor/bower-asset/jquery/dist/jquery.js;
|
/vendor/bower-asset/jquery/dist/jquery.js;
|
||||||
et2_core_interfaces;
|
et2_core_interfaces;
|
||||||
et2_core_baseWidget;
|
et2_core_baseWidget;
|
||||||
*/
|
*/
|
||||||
|
var et2_core_baseWidget_1 = require("./et2_core_baseWidget");
|
||||||
|
var et2_core_inheritance_1 = require("./et2_core_inheritance");
|
||||||
|
var et2_core_DOMWidget_1 = require("./et2_core_DOMWidget");
|
||||||
/**
|
/**
|
||||||
* This widget represents the HTML5 video tag with all its optional attributes
|
* This widget represents the HTML5 video tag with all its optional attributes
|
||||||
*
|
*
|
||||||
@ -38,152 +54,124 @@
|
|||||||
* <video [attributes...]/>
|
* <video [attributes...]/>
|
||||||
* </code>
|
* </code>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class which implements the "video" XET-Tag
|
* Class which implements the "video" XET-Tag
|
||||||
*
|
*
|
||||||
* @augments et2_baseWidget
|
* @augments et2_baseWidget
|
||||||
*/
|
*/
|
||||||
var et2_video = (function(){ "use strict"; return et2_baseWidget.extend(et2_IDOMNode,
|
var et2_video = /** @class */ (function (_super) {
|
||||||
{
|
__extends(et2_video, _super);
|
||||||
attributes: {
|
function et2_video(_parent, _attrs, _child) {
|
||||||
"video_src": {
|
var _this = _super.call(this, _parent, _attrs, et2_core_inheritance_1.ClassWithAttributes.extendAttributes(et2_core_DOMWidget_1.et2_DOMWidget._attributes, _child || {})) || this;
|
||||||
"name": "Video",
|
_this.video = null;
|
||||||
"type": "string",
|
//Create Video tag
|
||||||
"description": "Source of video to display"
|
_this.video = jQuery(document.createElement("video"));
|
||||||
},
|
if (_this.options.controls) {
|
||||||
"src_type": {
|
_this.video.attr("controls", 1);
|
||||||
"name": "Source type",
|
}
|
||||||
"type": "string",
|
if (_this.options.autoplay) {
|
||||||
"description": "Defines the type the stream source provided"
|
_this.video.attr("autoplay", 1);
|
||||||
},
|
}
|
||||||
"muted": {
|
if (_this.options.muted) {
|
||||||
"name": "Audio control",
|
_this.video.attr("muted", 1);
|
||||||
"type": "boolean",
|
}
|
||||||
"default": false,
|
if (_this.options.video_src) {
|
||||||
"description": "Defines that the audio output of the video should be muted"
|
_this.set_src(_this.options.video_src);
|
||||||
},
|
}
|
||||||
"autoplay": {
|
if (_this.options.loop) {
|
||||||
"name": "Autoply",
|
_this.video.attr("loop", 1);
|
||||||
"type": "boolean",
|
}
|
||||||
"default": false,
|
_this.setDOMNode(_this.video[0]);
|
||||||
"description": "Defines if Video will start playing as soon as it is ready"
|
return _this;
|
||||||
},
|
}
|
||||||
"controls": {
|
/**
|
||||||
"name": "Control buttons",
|
* Set video src
|
||||||
"type": "boolean",
|
*
|
||||||
"default": false,
|
* @param {string} _value url
|
||||||
"description": "Defines if Video controls, play/pause buttons should be displayed"
|
*/
|
||||||
},
|
et2_video.prototype.set_src = function (_value) {
|
||||||
"poster": {
|
if (_value) {
|
||||||
"name": "Video Poster",
|
var source = jQuery(document.createElement('source'))
|
||||||
"type": "string",
|
.attr('src', _value)
|
||||||
"default": "",
|
.appendTo(this.video);
|
||||||
"description": "Specifies an image to be shown while video is loading or before user play it"
|
if (this.options.src_type) {
|
||||||
},
|
source.attr('type', this.options.src_type);
|
||||||
loop: {
|
}
|
||||||
"name": "Video loop",
|
}
|
||||||
"type": "boolean",
|
};
|
||||||
"default": false,
|
/**
|
||||||
"description": "Defines if the video should be played repeatedly"
|
* Set autoplay option for video
|
||||||
}
|
* -If autoplay is set, video would be played automatically after the page is loaded
|
||||||
},
|
*
|
||||||
|
* @param {string} _value true set the autoplay and false not to set
|
||||||
|
*/
|
||||||
/**
|
et2_video.prototype.set_autoplay = function (_value) {
|
||||||
* Constructor
|
if (_value) {
|
||||||
*
|
this.video.attr("autoplay", _value);
|
||||||
* @memberOf et2_video
|
}
|
||||||
*/
|
};
|
||||||
init: function() {
|
/**
|
||||||
this._super.apply(this, arguments);
|
* Set controls option for video
|
||||||
|
*
|
||||||
//Create Video tag
|
* @param {string} _value true set the autoplay and false not to set
|
||||||
this.video = jQuery(document.createElement("video"));
|
*/
|
||||||
if (this.options.controls)
|
et2_video.prototype.set_controls = function (_value) {
|
||||||
{
|
if (_value) {
|
||||||
this.video.attr("controls",true);
|
this.video.attr("controls", _value);
|
||||||
}
|
}
|
||||||
if (this.options.autoplay)
|
};
|
||||||
{
|
/**
|
||||||
this.video.attr("autoplay",true);
|
* Set poster attribute in order to specify
|
||||||
}
|
* an image to be shown while video is loading or before user play it
|
||||||
if (this.options.muted)
|
*
|
||||||
{
|
* @param {string} _url
|
||||||
this.video.attr("muted",true);
|
*/
|
||||||
}
|
et2_video.prototype.set_poster = function (_url) {
|
||||||
if (this.options.video_src)
|
if (_url) {
|
||||||
{
|
this.video.attr("poster", _url);
|
||||||
this.set_src(this.options.video_src);
|
}
|
||||||
}
|
};
|
||||||
if (this.options.loop)
|
et2_video._attributes = {
|
||||||
{
|
"video_src": {
|
||||||
this.video.attr("loop",true);
|
"name": "Video",
|
||||||
}
|
"type": "string",
|
||||||
this.setDOMNode(this.video[0]);
|
"description": "Source of video to display"
|
||||||
},
|
},
|
||||||
|
"src_type": {
|
||||||
/**
|
"name": "Source type",
|
||||||
* Set video src
|
"type": "string",
|
||||||
*
|
"description": "Defines the type the stream source provided"
|
||||||
* @param {string} _value url
|
},
|
||||||
*/
|
"muted": {
|
||||||
set_src: function(_value) {
|
"name": "Audio control",
|
||||||
|
"type": "boolean",
|
||||||
if (_value)
|
"default": false,
|
||||||
{
|
"description": "Defines that the audio output of the video should be muted"
|
||||||
var source = jQuery(document.createElement('source'))
|
},
|
||||||
.attr('src',_value)
|
"autoplay": {
|
||||||
.appendTo(this.video);
|
"name": "Autoply",
|
||||||
|
"type": "boolean",
|
||||||
if (this.options.src_type)
|
"default": false,
|
||||||
{
|
"description": "Defines if Video will start playing as soon as it is ready"
|
||||||
source.attr('type',this.options.src_type);
|
},
|
||||||
}
|
"controls": {
|
||||||
}
|
"name": "Control buttons",
|
||||||
},
|
"type": "boolean",
|
||||||
|
"default": false,
|
||||||
/**
|
"description": "Defines if Video controls, play/pause buttons should be displayed"
|
||||||
* Set autoplay option for video
|
},
|
||||||
* -If autoplay is set, video would be played automatically after the page is loaded
|
"poster": {
|
||||||
*
|
"name": "Video Poster",
|
||||||
* @param {string} _value true set the autoplay and false not to set
|
"type": "string",
|
||||||
*/
|
"default": "",
|
||||||
set_autoplay: function (_value)
|
"description": "Specifies an image to be shown while video is loading or before user play it"
|
||||||
{
|
},
|
||||||
if (_value)
|
"loop": {
|
||||||
{
|
"name": "Video loop",
|
||||||
this.video.attr("autoplay",_value);
|
"type": "boolean",
|
||||||
}
|
"default": false,
|
||||||
},
|
"description": "Defines if the video should be played repeatedly"
|
||||||
|
}
|
||||||
/**
|
};
|
||||||
* Set controls option for video
|
return et2_video;
|
||||||
*
|
}(et2_core_baseWidget_1.et2_baseWidget));
|
||||||
* @param {string} _value true set the autoplay and false not to set
|
|
||||||
*/
|
|
||||||
set_controls: function (_value)
|
|
||||||
{
|
|
||||||
if (_value)
|
|
||||||
{
|
|
||||||
this.video.attr("controls",_value);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set poster attribute in order to specify
|
|
||||||
* an image to be shown while video is loading or before user play it
|
|
||||||
*
|
|
||||||
* @param {type} _url
|
|
||||||
*/
|
|
||||||
set_poster: function (_url)
|
|
||||||
{
|
|
||||||
if (_url)
|
|
||||||
{
|
|
||||||
this.video.attr("poster", _url);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
});}).call(this);
|
|
||||||
|
|
||||||
et2_register_widget(et2_video, ["video"]);
|
|
||||||
|
188
api/js/etemplate/et2_widget_video.ts
Normal file
188
api/js/etemplate/et2_widget_video.ts
Normal file
@ -0,0 +1,188 @@
|
|||||||
|
/**
|
||||||
|
* EGroupware eTemplate2 - JS Description object
|
||||||
|
*
|
||||||
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||||||
|
* @package etemplate
|
||||||
|
* @subpackage api
|
||||||
|
* @link http://www.egroupware.org
|
||||||
|
* @author Hadi Nategh <hn[at]stylite.de>
|
||||||
|
* @copyright Stylite AG
|
||||||
|
* @version $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*egw:uses
|
||||||
|
/vendor/bower-asset/jquery/dist/jquery.js;
|
||||||
|
et2_core_interfaces;
|
||||||
|
et2_core_baseWidget;
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { et2_baseWidget } from './et2_core_baseWidget'
|
||||||
|
import {ClassWithAttributes} from "./et2_core_inheritance";
|
||||||
|
import {et2_DOMWidget} from "./et2_core_DOMWidget";
|
||||||
|
import {WidgetConfig} from "./et2_core_widget";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This widget represents the HTML5 video tag with all its optional attributes
|
||||||
|
*
|
||||||
|
* The widget can be created in the following ways:
|
||||||
|
* <code>
|
||||||
|
* var videoTag = et2_createWidget("video", {
|
||||||
|
* video_src: "../../test.mp4",
|
||||||
|
* src_type: "video/mp4",
|
||||||
|
* muted: true,
|
||||||
|
* autoplay: true,
|
||||||
|
* controls: true,
|
||||||
|
* poster: "../../poster.jpg",
|
||||||
|
* loop: true,
|
||||||
|
* height: 100,
|
||||||
|
* width: 200,
|
||||||
|
* });
|
||||||
|
* </code>
|
||||||
|
* Or by adding XET-tag in your template (.xet) file:
|
||||||
|
* <code>
|
||||||
|
* <video [attributes...]/>
|
||||||
|
* </code>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class which implements the "video" XET-Tag
|
||||||
|
*
|
||||||
|
* @augments et2_baseWidget
|
||||||
|
*/
|
||||||
|
class et2_video extends et2_baseWidget implements et2_IDOMNode
|
||||||
|
{
|
||||||
|
static readonly _attributes: any = {
|
||||||
|
"video_src": {
|
||||||
|
"name": "Video",
|
||||||
|
"type": "string",
|
||||||
|
"description": "Source of video to display"
|
||||||
|
},
|
||||||
|
"src_type": {
|
||||||
|
"name": "Source type",
|
||||||
|
"type": "string",
|
||||||
|
"description": "Defines the type the stream source provided"
|
||||||
|
},
|
||||||
|
"muted": {
|
||||||
|
"name": "Audio control",
|
||||||
|
"type": "boolean",
|
||||||
|
"default": false,
|
||||||
|
"description": "Defines that the audio output of the video should be muted"
|
||||||
|
},
|
||||||
|
"autoplay": {
|
||||||
|
"name": "Autoply",
|
||||||
|
"type": "boolean",
|
||||||
|
"default": false,
|
||||||
|
"description": "Defines if Video will start playing as soon as it is ready"
|
||||||
|
},
|
||||||
|
"controls": {
|
||||||
|
"name": "Control buttons",
|
||||||
|
"type": "boolean",
|
||||||
|
"default": false,
|
||||||
|
"description": "Defines if Video controls, play/pause buttons should be displayed"
|
||||||
|
},
|
||||||
|
"poster": {
|
||||||
|
"name": "Video Poster",
|
||||||
|
"type": "string",
|
||||||
|
"default": "",
|
||||||
|
"description": "Specifies an image to be shown while video is loading or before user play it"
|
||||||
|
},
|
||||||
|
"loop": {
|
||||||
|
"name": "Video loop",
|
||||||
|
"type": "boolean",
|
||||||
|
"default": false,
|
||||||
|
"description": "Defines if the video should be played repeatedly"
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
video: JQuery = null;
|
||||||
|
|
||||||
|
constructor(_parent, _attrs? : WidgetConfig, _child? : object)
|
||||||
|
{
|
||||||
|
super(_parent, _attrs, ClassWithAttributes.extendAttributes(et2_DOMWidget._attributes, _child || {}));
|
||||||
|
|
||||||
|
//Create Video tag
|
||||||
|
this.video = jQuery(document.createElement("video"));
|
||||||
|
if (this.options.controls)
|
||||||
|
{
|
||||||
|
this.video.attr("controls", 1);
|
||||||
|
}
|
||||||
|
if (this.options.autoplay)
|
||||||
|
{
|
||||||
|
this.video.attr("autoplay", 1);
|
||||||
|
}
|
||||||
|
if (this.options.muted)
|
||||||
|
{
|
||||||
|
this.video.attr("muted", 1);
|
||||||
|
}
|
||||||
|
if (this.options.video_src)
|
||||||
|
{
|
||||||
|
this.set_src(this.options.video_src);
|
||||||
|
}
|
||||||
|
if (this.options.loop)
|
||||||
|
{
|
||||||
|
this.video.attr("loop", 1);
|
||||||
|
}
|
||||||
|
this.setDOMNode(this.video[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set video src
|
||||||
|
*
|
||||||
|
* @param {string} _value url
|
||||||
|
*/
|
||||||
|
set_src(_value: string) {
|
||||||
|
|
||||||
|
if (_value)
|
||||||
|
{
|
||||||
|
let source = jQuery(document.createElement('source'))
|
||||||
|
.attr('src',_value)
|
||||||
|
.appendTo(this.video);
|
||||||
|
|
||||||
|
if (this.options.src_type)
|
||||||
|
{
|
||||||
|
source.attr('type', this.options.src_type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set autoplay option for video
|
||||||
|
* -If autoplay is set, video would be played automatically after the page is loaded
|
||||||
|
*
|
||||||
|
* @param {string} _value true set the autoplay and false not to set
|
||||||
|
*/
|
||||||
|
set_autoplay(_value: string)
|
||||||
|
{
|
||||||
|
if (_value)
|
||||||
|
{
|
||||||
|
this.video.attr("autoplay", _value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set controls option for video
|
||||||
|
*
|
||||||
|
* @param {string} _value true set the autoplay and false not to set
|
||||||
|
*/
|
||||||
|
set_controls(_value: string)
|
||||||
|
{
|
||||||
|
if (_value)
|
||||||
|
{
|
||||||
|
this.video.attr("controls", _value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set poster attribute in order to specify
|
||||||
|
* an image to be shown while video is loading or before user play it
|
||||||
|
*
|
||||||
|
* @param {string} _url
|
||||||
|
*/
|
||||||
|
set_poster(_url: string)
|
||||||
|
{
|
||||||
|
if (_url)
|
||||||
|
{
|
||||||
|
this.video.attr("poster", _url);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user