diff --git a/src/main/java/net/bootsfaces/component/video/Video.java b/src/main/java/net/bootsfaces/component/video/Video.java index dc90fd4a1..63b25fe39 100644 --- a/src/main/java/net/bootsfaces/component/video/Video.java +++ b/src/main/java/net/bootsfaces/component/video/Video.java @@ -18,16 +18,24 @@ package net.bootsfaces.component.video; +import java.util.Arrays; +import java.util.Collection; +import java.util.Collections; +import java.util.Map; + import javax.el.ValueExpression; import javax.faces.component.FacesComponent; +import javax.faces.component.behavior.ClientBehaviorHolder; +import net.bootsfaces.component.ajax.IAJAXComponent; import net.bootsfaces.listeners.AddResourcesListener; import net.bootsfaces.render.Tooltip; import net.bootsfaces.utils.BsfUtils; /** This class holds the attributes of <b:video />. */ @FacesComponent("net.bootsfaces.component.video.Video") -public class Video extends VideoCore implements net.bootsfaces.render.IHasTooltip, net.bootsfaces.render.IResponsive { +public class Video extends VideoCore implements net.bootsfaces.render.IHasTooltip, net.bootsfaces.render.IResponsive, + IAJAXComponent, ClientBehaviorHolder { public static final String COMPONENT_TYPE = "net.bootsfaces.component.video.Video"; @@ -35,10 +43,17 @@ public class Video extends VideoCore implements net.bootsfaces.render.IHasToolti public static final String DEFAULT_RENDERER = "net.bootsfaces.component.video.Video"; + private static final Collection EVENT_NAMES = Collections + .unmodifiableCollection(Arrays.asList("blur", "click", "dblclick", "focus", "input", "keydown", "keypress", + "keyup", "mousedown", "mousemove", "mouseout", "mouseover", "mouseup", + "abort", "canplay", "canplaythrough", "durationchange", "emptied", + "ended", "eeror", "loadeddata", "loadedmetadata", "loadstart", + "pause", "play", "playing", "progress", "ratechange", "seeked", + "seeking", "stalled", "suspend", "timeupdate", "volumechange", "waiting")); + public Video() { Tooltip.addResourceFiles(); AddResourcesListener.addThemedCSSResource("core.css"); - AddResourcesListener.addThemedCSSResource("bsf.css"); setRendererType(DEFAULT_RENDERER); } @@ -53,4 +68,18 @@ public void setValueExpression(String name, ValueExpression binding) { name = BsfUtils.snakeCaseToCamelCase(name); super.setValueExpression(name, binding); } + + @Override + public Map getJQueryEvents() { + return null; + } + + public Collection getEventNames() { + return EVENT_NAMES; + } + + public String getDefaultEventName() { + return "input"; + } + } diff --git a/src/main/java/net/bootsfaces/component/video/VideoCore.java b/src/main/java/net/bootsfaces/component/video/VideoCore.java new file mode 100644 index 000000000..c1d35a443 --- /dev/null +++ b/src/main/java/net/bootsfaces/component/video/VideoCore.java @@ -0,0 +1,1080 @@ +/** + * Copyright 2014-16 by Riccardo Massera (TheCoder4.Eu) and Stephan Rauh (http://www.beyondjava.net). + * + * This file is part of BootsFaces. + * +* 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. + */ + +package net.bootsfaces.component.video; + +import javax.faces.component.*; +import net.bootsfaces.render.Tooltip; +import net.bootsfaces.utils.BsfUtils; + +/** This class holds the attributes of <b:video />. */ +public abstract class VideoCore extends UIComponentBase implements net.bootsfaces.render.IHasTooltip { + + protected enum PropertyKeys { + ajax, + autoplay, + binding, + colLg, + colMd, + colSm, + colXs, + controls, + disabled, + display, + hidden, + immediate, + largeScreen, + loop, + mediumScreen, + offset, + offsetLg, + offsetMd, + offsetSm, + offsetXs, + onabort, + oncanplay, + oncanplaythrough, + onclick, + oncomplete, + ondurationchange, + onemptied, + onended, + onerror, + onloadeddata, + onloadedmetadata, + onloadstart, + onpause, + onplay, + onplaying, + onprogress, + onratechange, + onseeked, + onseeking, + onstalled, + onsuccess, + onsuspend, + ontimeupdate, + onvolumechange, + onwaiting, + process, + required, + smallScreen, + span, + src, + style, + styleClass, + tinyScreen, + tooltip, + tooltipContainer, + tooltipDelay, + tooltipDelayHide, + tooltipDelayShow, + tooltipPosition, + update, + visible; + String toString; + + PropertyKeys(String toString) { + this.toString = toString; + } + + PropertyKeys() { + } + + public String toString() { + return ((this.toString != null) ? this.toString : super.toString()); + } + } + + /** + * Whether the Button submits the form with AJAX.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public boolean isAjax() { + return (boolean) (Boolean) getStateHelper().eval(PropertyKeys.ajax, false); + } + + /** + * Whether the Button submits the form with AJAX.

+ * Usually this method is called internally by the JSF engine. + */ + public void setAjax(boolean _ajax) { + getStateHelper().put(PropertyKeys.ajax, _ajax); + } + + /** + * Setting this to true will start the video on page load. By default, autoplay is deactivated. Note that mobile devices never start videos automatically.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public boolean isAutoplay() { + return (boolean) (Boolean) getStateHelper().eval(PropertyKeys.autoplay, false); + } + + /** + * Setting this to true will start the video on page load. By default, autoplay is deactivated. Note that mobile devices never start videos automatically.

+ * Usually this method is called internally by the JSF engine. + */ + public void setAutoplay(boolean _autoplay) { + getStateHelper().put(PropertyKeys.autoplay, _autoplay); + } + + /** + * An EL expression referring to a server side UIComponent instance in a backing bean.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public javax.faces.component.UIComponent getBinding() { + return (javax.faces.component.UIComponent) getStateHelper().eval(PropertyKeys.binding); + } + + /** + * An EL expression referring to a server side UIComponent instance in a backing bean.

+ * Usually this method is called internally by the JSF engine. + */ + public void setBinding(javax.faces.component.UIComponent _binding) { + getStateHelper().put(PropertyKeys.binding, _binding); + } + + /** + * Integer value to specify how many columns to span on large screens (≥1200 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getColLg() { + return (String) getStateHelper().eval(PropertyKeys.colLg, "-1"); + } + + /** + * Integer value to specify how many columns to span on large screens (≥1200 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setColLg(String _colLg) { + getStateHelper().put(PropertyKeys.colLg, _colLg); + } + + /** + * Integer value to specify how many columns to span on medium screens (≥992 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getColMd() { + return (String) getStateHelper().eval(PropertyKeys.colMd, "-1"); + } + + /** + * Integer value to specify how many columns to span on medium screens (≥992 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setColMd(String _colMd) { + getStateHelper().put(PropertyKeys.colMd, _colMd); + } + + /** + * Integer value to specify how many columns to span on small screens (≥768p pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getColSm() { + return (String) getStateHelper().eval(PropertyKeys.colSm, "-1"); + } + + /** + * Integer value to specify how many columns to span on small screens (≥768p pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setColSm(String _colSm) { + getStateHelper().put(PropertyKeys.colSm, _colSm); + } + + /** + * Integer value to specify how many columns to span on tiny screens (≤ 767 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getColXs() { + return (String) getStateHelper().eval(PropertyKeys.colXs, "-1"); + } + + /** + * Integer value to specify how many columns to span on tiny screens (≤ 767 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setColXs(String _colXs) { + getStateHelper().put(PropertyKeys.colXs, _colXs); + } + + /** + * Hide the controls (start, stop, seeking, volume etc.) by setting this property to false. By default, the controls are shown.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public boolean isControls() { + return (boolean) (Boolean) getStateHelper().eval(PropertyKeys.controls, true); + } + + /** + * Hide the controls (start, stop, seeking, volume etc.) by setting this property to false. By default, the controls are shown.

+ * Usually this method is called internally by the JSF engine. + */ + public void setControls(boolean _controls) { + getStateHelper().put(PropertyKeys.controls, _controls); + } + + /** + * Boolean value to specify if the button is disabled.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public boolean isDisabled() { + return (boolean) (Boolean) getStateHelper().eval(PropertyKeys.disabled, false); + } + + /** + * Boolean value to specify if the button is disabled.

+ * Usually this method is called internally by the JSF engine. + */ + public void setDisabled(boolean _disabled) { + getStateHelper().put(PropertyKeys.disabled, _disabled); + } + + /** + * If you use the "visible" attribute, the value of this attribute is added. Legal values: block, inline, inline-block. Default: block.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getDisplay() { + return (String) getStateHelper().eval(PropertyKeys.display, "block"); + } + + /** + * If you use the "visible" attribute, the value of this attribute is added. Legal values: block, inline, inline-block. Default: block.

+ * Usually this method is called internally by the JSF engine. + */ + public void setDisplay(String _display) { + getStateHelper().put(PropertyKeys.display, _display); + } + + /** + * This column is hidden on a certain screen size and below. Legal values: lg, md, sm, xs.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getHidden() { + return (String) getStateHelper().eval(PropertyKeys.hidden); + } + + /** + * This column is hidden on a certain screen size and below. Legal values: lg, md, sm, xs.

+ * Usually this method is called internally by the JSF engine. + */ + public void setHidden(String _hidden) { + getStateHelper().put(PropertyKeys.hidden, _hidden); + } + + /** + * Flag indicating that, if this component is activated by the user, notifications should be delivered to interested listeners and actions immediately (that is, during Apply Request Values phase) rather than waiting until Invoke Application phase. Default is false.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public boolean isImmediate() { + return (boolean) (Boolean) getStateHelper().eval(PropertyKeys.immediate, false); + } + + /** + * Flag indicating that, if this component is activated by the user, notifications should be delivered to interested listeners and actions immediately (that is, during Apply Request Values phase) rather than waiting until Invoke Application phase. Default is false.

+ * Usually this method is called internally by the JSF engine. + */ + public void setImmediate(boolean _immediate) { + getStateHelper().put(PropertyKeys.immediate, _immediate); + } + + /** + * Alternative spelling to col-lg. Integer value to specify how many columns to span on large screens (≥1200 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getLargeScreen() { + return (String) getStateHelper().eval(PropertyKeys.largeScreen, "-1"); + } + + /** + * Alternative spelling to col-lg. Integer value to specify how many columns to span on large screens (≥1200 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setLargeScreen(String _largeScreen) { + getStateHelper().put(PropertyKeys.largeScreen, _largeScreen); + } + + /** + * Setting this flag to true causes the video to start over when it's finished. By default, loop is set to false.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public boolean isLoop() { + return (boolean) (Boolean) getStateHelper().eval(PropertyKeys.loop, false); + } + + /** + * Setting this flag to true causes the video to start over when it's finished. By default, loop is set to false.

+ * Usually this method is called internally by the JSF engine. + */ + public void setLoop(boolean _loop) { + getStateHelper().put(PropertyKeys.loop, _loop); + } + + /** + * Alternative spelling to col-md. Integer value to specify how many columns to span on medium screens (≥992 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getMediumScreen() { + return (String) getStateHelper().eval(PropertyKeys.mediumScreen, "-1"); + } + + /** + * Alternative spelling to col-md. Integer value to specify how many columns to span on medium screens (≥992 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setMediumScreen(String _mediumScreen) { + getStateHelper().put(PropertyKeys.mediumScreen, _mediumScreen); + } + + /** + * Integer value to specify how many columns to offset.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOffset() { + return (String) getStateHelper().eval(PropertyKeys.offset); + } + + /** + * Integer value to specify how many columns to offset.

+ * Usually this method is called internally by the JSF engine. + */ + public void setOffset(String _offset) { + getStateHelper().put(PropertyKeys.offset, _offset); + } + + /** + * Integer value to specify how many columns to offset.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOffsetLg() { + return (String) getStateHelper().eval(PropertyKeys.offsetLg); + } + + /** + * Integer value to specify how many columns to offset.

+ * Usually this method is called internally by the JSF engine. + */ + public void setOffsetLg(String _offsetLg) { + getStateHelper().put(PropertyKeys.offsetLg, _offsetLg); + } + + /** + * Integer value to specify how many columns to offset.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOffsetMd() { + return (String) getStateHelper().eval(PropertyKeys.offsetMd); + } + + /** + * Integer value to specify how many columns to offset.

+ * Usually this method is called internally by the JSF engine. + */ + public void setOffsetMd(String _offsetMd) { + getStateHelper().put(PropertyKeys.offsetMd, _offsetMd); + } + + /** + * Integer value to specify how many columns to offset.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOffsetSm() { + return (String) getStateHelper().eval(PropertyKeys.offsetSm); + } + + /** + * Integer value to specify how many columns to offset.

+ * Usually this method is called internally by the JSF engine. + */ + public void setOffsetSm(String _offsetSm) { + getStateHelper().put(PropertyKeys.offsetSm, _offsetSm); + } + + /** + * Integer value to specify how many columns to offset.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOffsetXs() { + return (String) getStateHelper().eval(PropertyKeys.offsetXs); + } + + /** + * Integer value to specify how many columns to offset.

+ * Usually this method is called internally by the JSF engine. + */ + public void setOffsetXs(String _offsetXs) { + getStateHelper().put(PropertyKeys.offsetXs, _offsetXs); + } + + /** + * Fires when the loading of an audio/video is aborted

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnabort() { + return (String) getStateHelper().eval(PropertyKeys.onabort); + } + + /** + * Fires when the loading of an audio/video is aborted

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnabort(String _onabort) { + getStateHelper().put(PropertyKeys.onabort, _onabort); + } + + /** + * Fires when the browser can start playing the audio/video

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOncanplay() { + return (String) getStateHelper().eval(PropertyKeys.oncanplay); + } + + /** + * Fires when the browser can start playing the audio/video

+ * Usually this method is called internally by the JSF engine. + */ + public void setOncanplay(String _oncanplay) { + getStateHelper().put(PropertyKeys.oncanplay, _oncanplay); + } + + /** + * Fires when the browser can play through the audio/video without stopping for buffering

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOncanplaythrough() { + return (String) getStateHelper().eval(PropertyKeys.oncanplaythrough); + } + + /** + * Fires when the browser can play through the audio/video without stopping for buffering

+ * Usually this method is called internally by the JSF engine. + */ + public void setOncanplaythrough(String _oncanplaythrough) { + getStateHelper().put(PropertyKeys.oncanplaythrough, _oncanplaythrough); + } + + /** + * The onclick attribute.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnclick() { + return (String) getStateHelper().eval(PropertyKeys.onclick); + } + + /** + * The onclick attribute.

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnclick(String _onclick) { + getStateHelper().put(PropertyKeys.onclick, _onclick); + } + + /** + * JavaScript to be executed when ajax completes.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOncomplete() { + return (String) getStateHelper().eval(PropertyKeys.oncomplete); + } + + /** + * JavaScript to be executed when ajax completes.

+ * Usually this method is called internally by the JSF engine. + */ + public void setOncomplete(String _oncomplete) { + getStateHelper().put(PropertyKeys.oncomplete, _oncomplete); + } + + /** + * Fires when the duration of the audio/video is changed

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOndurationchange() { + return (String) getStateHelper().eval(PropertyKeys.ondurationchange); + } + + /** + * Fires when the duration of the audio/video is changed

+ * Usually this method is called internally by the JSF engine. + */ + public void setOndurationchange(String _ondurationchange) { + getStateHelper().put(PropertyKeys.ondurationchange, _ondurationchange); + } + + /** + * Fires when the current playlist is empty

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnemptied() { + return (String) getStateHelper().eval(PropertyKeys.onemptied); + } + + /** + * Fires when the current playlist is empty

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnemptied(String _onemptied) { + getStateHelper().put(PropertyKeys.onemptied, _onemptied); + } + + /** + * Fires when the current playlist is ended

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnended() { + return (String) getStateHelper().eval(PropertyKeys.onended); + } + + /** + * Fires when the current playlist is ended

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnended(String _onended) { + getStateHelper().put(PropertyKeys.onended, _onended); + } + + /** + * JavaScript to be executed when ajax results on an error (including both network errors and Java exceptions).

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnerror() { + return (String) getStateHelper().eval(PropertyKeys.onerror); + } + + /** + * JavaScript to be executed when ajax results on an error (including both network errors and Java exceptions).

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnerror(String _onerror) { + getStateHelper().put(PropertyKeys.onerror, _onerror); + } + + /** + * Fires when the browser has loaded the current frame of the audio/video

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnloadeddata() { + return (String) getStateHelper().eval(PropertyKeys.onloadeddata); + } + + /** + * Fires when the browser has loaded the current frame of the audio/video

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnloadeddata(String _onloadeddata) { + getStateHelper().put(PropertyKeys.onloadeddata, _onloadeddata); + } + + /** + * Fires when the browser has loaded meta data for the audio/video

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnloadedmetadata() { + return (String) getStateHelper().eval(PropertyKeys.onloadedmetadata); + } + + /** + * Fires when the browser has loaded meta data for the audio/video

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnloadedmetadata(String _onloadedmetadata) { + getStateHelper().put(PropertyKeys.onloadedmetadata, _onloadedmetadata); + } + + /** + * Fires when the browser starts looking for the audio/video

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnloadstart() { + return (String) getStateHelper().eval(PropertyKeys.onloadstart); + } + + /** + * Fires when the browser starts looking for the audio/video

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnloadstart(String _onloadstart) { + getStateHelper().put(PropertyKeys.onloadstart, _onloadstart); + } + + /** + * Fires when the audio/video has been paused

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnpause() { + return (String) getStateHelper().eval(PropertyKeys.onpause); + } + + /** + * Fires when the audio/video has been paused

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnpause(String _onpause) { + getStateHelper().put(PropertyKeys.onpause, _onpause); + } + + /** + * Fires when the audio/video has been started or is no longer paused

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnplay() { + return (String) getStateHelper().eval(PropertyKeys.onplay); + } + + /** + * Fires when the audio/video has been started or is no longer paused

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnplay(String _onplay) { + getStateHelper().put(PropertyKeys.onplay, _onplay); + } + + /** + * Fires when the audio/video is playing after having been paused or stopped for buffering

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnplaying() { + return (String) getStateHelper().eval(PropertyKeys.onplaying); + } + + /** + * Fires when the audio/video is playing after having been paused or stopped for buffering

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnplaying(String _onplaying) { + getStateHelper().put(PropertyKeys.onplaying, _onplaying); + } + + /** + * Fires when the browser is downloading the audio/video

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnprogress() { + return (String) getStateHelper().eval(PropertyKeys.onprogress); + } + + /** + * Fires when the browser is downloading the audio/video

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnprogress(String _onprogress) { + getStateHelper().put(PropertyKeys.onprogress, _onprogress); + } + + /** + * Fires when the playing speed of the audio/video is changed

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnratechange() { + return (String) getStateHelper().eval(PropertyKeys.onratechange); + } + + /** + * Fires when the playing speed of the audio/video is changed

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnratechange(String _onratechange) { + getStateHelper().put(PropertyKeys.onratechange, _onratechange); + } + + /** + * Fires when the user is finished moving/skipping to a new position in the audio/video

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnseeked() { + return (String) getStateHelper().eval(PropertyKeys.onseeked); + } + + /** + * Fires when the user is finished moving/skipping to a new position in the audio/video

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnseeked(String _onseeked) { + getStateHelper().put(PropertyKeys.onseeked, _onseeked); + } + + /** + * Fires when the user starts moving/skipping to a new position in the audio/video

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnseeking() { + return (String) getStateHelper().eval(PropertyKeys.onseeking); + } + + /** + * Fires when the user starts moving/skipping to a new position in the audio/video

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnseeking(String _onseeking) { + getStateHelper().put(PropertyKeys.onseeking, _onseeking); + } + + /** + * Fires when the browser is trying to get media data, but data is not available

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnstalled() { + return (String) getStateHelper().eval(PropertyKeys.onstalled); + } + + /** + * Fires when the browser is trying to get media data, but data is not available

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnstalled(String _onstalled) { + getStateHelper().put(PropertyKeys.onstalled, _onstalled); + } + + /** + * JavaScript to be executed when ajax completes with success (i.e. there's neither a network error nor a Java exception).

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnsuccess() { + return (String) getStateHelper().eval(PropertyKeys.onsuccess); + } + + /** + * JavaScript to be executed when ajax completes with success (i.e. there's neither a network error nor a Java exception).

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnsuccess(String _onsuccess) { + getStateHelper().put(PropertyKeys.onsuccess, _onsuccess); + } + + /** + * Fires when the browser is intentionally not getting media data

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnsuspend() { + return (String) getStateHelper().eval(PropertyKeys.onsuspend); + } + + /** + * Fires when the browser is intentionally not getting media data

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnsuspend(String _onsuspend) { + getStateHelper().put(PropertyKeys.onsuspend, _onsuspend); + } + + /** + * Fires when the current playback position has changed

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOntimeupdate() { + return (String) getStateHelper().eval(PropertyKeys.ontimeupdate); + } + + /** + * Fires when the current playback position has changed

+ * Usually this method is called internally by the JSF engine. + */ + public void setOntimeupdate(String _ontimeupdate) { + getStateHelper().put(PropertyKeys.ontimeupdate, _ontimeupdate); + } + + /** + * Fires when the volume has been changed

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnvolumechange() { + return (String) getStateHelper().eval(PropertyKeys.onvolumechange); + } + + /** + * Fires when the volume has been changed

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnvolumechange(String _onvolumechange) { + getStateHelper().put(PropertyKeys.onvolumechange, _onvolumechange); + } + + /** + * Fires when the video stops because it needs to buffer the next frame

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getOnwaiting() { + return (String) getStateHelper().eval(PropertyKeys.onwaiting); + } + + /** + * Fires when the video stops because it needs to buffer the next frame

+ * Usually this method is called internally by the JSF engine. + */ + public void setOnwaiting(String _onwaiting) { + getStateHelper().put(PropertyKeys.onwaiting, _onwaiting); + } + + /** + * Comma or space separated list of ids or search expressions denoting which values are to be sent to the server.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getProcess() { + return (String) getStateHelper().eval(PropertyKeys.process); + } + + /** + * Comma or space separated list of ids or search expressions denoting which values are to be sent to the server.

+ * Usually this method is called internally by the JSF engine. + */ + public void setProcess(String _process) { + getStateHelper().put(PropertyKeys.process, _process); + } + + /** + * URL of the video to be shown. If you use a relative path (i.e. without http:// and without the domain name), the video will be taken from your own server.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getRequired() { + return (String) getStateHelper().eval(PropertyKeys.required); + } + + /** + * URL of the video to be shown. If you use a relative path (i.e. without http:// and without the domain name), the video will be taken from your own server.

+ * Usually this method is called internally by the JSF engine. + */ + public void setRequired(String _required) { + getStateHelper().put(PropertyKeys.required, _required); + } + + /** + * Alternative spelling to col-sm. Integer value to specify how many columns to span on small screens (≥768p pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getSmallScreen() { + return (String) getStateHelper().eval(PropertyKeys.smallScreen, "-1"); + } + + /** + * Alternative spelling to col-sm. Integer value to specify how many columns to span on small screens (≥768p pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setSmallScreen(String _smallScreen) { + getStateHelper().put(PropertyKeys.smallScreen, _smallScreen); + } + + /** + * Integer value to specify how many columns to span on medium screens (≥992 pixels). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getSpan() { + return (String) getStateHelper().eval(PropertyKeys.span); + } + + /** + * Integer value to specify how many columns to span on medium screens (≥992 pixels). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setSpan(String _span) { + getStateHelper().put(PropertyKeys.span, _span); + } + + /** + *

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getSrc() { + return (String) getStateHelper().eval(PropertyKeys.src); + } + + /** + *

+ * Usually this method is called internally by the JSF engine. + */ + public void setSrc(String _src) { + getStateHelper().put(PropertyKeys.src, _src); + } + + /** + * Inline CSS of the tab.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getStyle() { + return (String) getStateHelper().eval(PropertyKeys.style); + } + + /** + * Inline CSS of the tab.

+ * Usually this method is called internally by the JSF engine. + */ + public void setStyle(String _style) { + getStateHelper().put(PropertyKeys.style, _style); + } + + /** + * Style class of the div surrounding the tab pane.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getStyleClass() { + return (String) getStateHelper().eval(PropertyKeys.styleClass); + } + + /** + * Style class of the div surrounding the tab pane.

+ * Usually this method is called internally by the JSF engine. + */ + public void setStyleClass(String _styleClass) { + getStateHelper().put(PropertyKeys.styleClass, _styleClass); + } + + /** + * Alternative spelling to col-xs. Integer value to specify how many columns to span on tiny screens (≤ 767 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getTinyScreen() { + return (String) getStateHelper().eval(PropertyKeys.tinyScreen, "-1"); + } + + /** + * Alternative spelling to col-xs. Integer value to specify how many columns to span on tiny screens (≤ 767 pixels wide). The number may optionally be followed by "column" or "columns". Alternative legal values: half, one-third, two-thirds, one-fourth, three-fourths.

+ * Usually this method is called internally by the JSF engine. + */ + public void setTinyScreen(String _tinyScreen) { + getStateHelper().put(PropertyKeys.tinyScreen, _tinyScreen); + } + + /** + * The text of the tooltip.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getTooltip() { + return (String) getStateHelper().eval(PropertyKeys.tooltip); + } + + /** + * The text of the tooltip.

+ * Usually this method is called internally by the JSF engine. + */ + public void setTooltip(String _tooltip) { + getStateHelper().put(PropertyKeys.tooltip, _tooltip); + } + + /** + * Where is the tooltip div generated? That's primarily a technical value that can be used to fix rendering errors in special cases. Also see data-container in the documentation of Bootstrap. The default value is body.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getTooltipContainer() { + return (String) getStateHelper().eval(PropertyKeys.tooltipContainer, "body"); + } + + /** + * Where is the tooltip div generated? That's primarily a technical value that can be used to fix rendering errors in special cases. Also see data-container in the documentation of Bootstrap. The default value is body.

+ * Usually this method is called internally by the JSF engine. + */ + public void setTooltipContainer(String _tooltipContainer) { + getStateHelper().put(PropertyKeys.tooltipContainer, _tooltipContainer); + } + + /** + * The tooltip is shown and hidden with a delay. This value is the delay in milliseconds. Defaults to 0 (no delay).

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public int getTooltipDelay() { + return (int) (Integer) getStateHelper().eval(PropertyKeys.tooltipDelay, 0); + } + + /** + * The tooltip is shown and hidden with a delay. This value is the delay in milliseconds. Defaults to 0 (no delay).

+ * Usually this method is called internally by the JSF engine. + */ + public void setTooltipDelay(int _tooltipDelay) { + getStateHelper().put(PropertyKeys.tooltipDelay, _tooltipDelay); + } + + /** + * The tooltip is hidden with a delay. This value is the delay in milliseconds. Defaults to 0 (no delay).

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public int getTooltipDelayHide() { + return (int) (Integer) getStateHelper().eval(PropertyKeys.tooltipDelayHide, 0); + } + + /** + * The tooltip is hidden with a delay. This value is the delay in milliseconds. Defaults to 0 (no delay).

+ * Usually this method is called internally by the JSF engine. + */ + public void setTooltipDelayHide(int _tooltipDelayHide) { + getStateHelper().put(PropertyKeys.tooltipDelayHide, _tooltipDelayHide); + } + + /** + * The tooltip is shown with a delay. This value is the delay in milliseconds. Defaults to 0 (no delay).

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public int getTooltipDelayShow() { + return (int) (Integer) getStateHelper().eval(PropertyKeys.tooltipDelayShow, 0); + } + + /** + * The tooltip is shown with a delay. This value is the delay in milliseconds. Defaults to 0 (no delay).

+ * Usually this method is called internally by the JSF engine. + */ + public void setTooltipDelayShow(int _tooltipDelayShow) { + getStateHelper().put(PropertyKeys.tooltipDelayShow, _tooltipDelayShow); + } + + /** + * Where is the tooltip to be displayed? Possible values: "top", "bottom", "right", "left", "auto", "auto top", "auto bottom", "auto right" and "auto left". Default to "bottom".

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getTooltipPosition() { + return (String) getStateHelper().eval(PropertyKeys.tooltipPosition); + } + + /** + * Where is the tooltip to be displayed? Possible values: "top", "bottom", "right", "left", "auto", "auto top", "auto bottom", "auto right" and "auto left". Default to "bottom".

+ * Usually this method is called internally by the JSF engine. + */ + public void setTooltipPosition(String _tooltipPosition) { + getStateHelper().put(PropertyKeys.tooltipPosition, _tooltipPosition); + } + + /** + * Component(s) to be updated with ajax.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getUpdate() { + return (String) getStateHelper().eval(PropertyKeys.update); + } + + /** + * Component(s) to be updated with ajax.

+ * Usually this method is called internally by the JSF engine. + */ + public void setUpdate(String _update) { + getStateHelper().put(PropertyKeys.update, _update); + } + + /** + * This column is shown on a certain screen size and above. Legal values: lg, md, sm, xs.

+ * @return Returns the value of the attribute, or null, if it hasn't been set by the JSF file. + */ + public String getVisible() { + return (String) getStateHelper().eval(PropertyKeys.visible); + } + + /** + * This column is shown on a certain screen size and above. Legal values: lg, md, sm, xs.

+ * Usually this method is called internally by the JSF engine. + */ + public void setVisible(String _visible) { + getStateHelper().put(PropertyKeys.visible, _visible); + } + +} diff --git a/src/main/java/net/bootsfaces/component/video/VideoRenderer.java b/src/main/java/net/bootsfaces/component/video/VideoRenderer.java index a18d57b5b..60a1e6db8 100644 --- a/src/main/java/net/bootsfaces/component/video/VideoRenderer.java +++ b/src/main/java/net/bootsfaces/component/video/VideoRenderer.java @@ -18,14 +18,14 @@ package net.bootsfaces.component.video; -import javax.faces.component.*; import java.io.IOException; -import java.util.Map; +import javax.faces.component.UIComponent; import javax.faces.context.FacesContext; import javax.faces.context.ResponseWriter; import javax.faces.render.FacesRenderer; +import net.bootsfaces.component.ajax.AJAXRenderer; import net.bootsfaces.render.CoreRenderer; import net.bootsfaces.render.Responsive; import net.bootsfaces.render.Tooltip; @@ -33,6 +33,23 @@ /** This class generates the HTML code of <b:video />. */ @FacesRenderer(componentFamily = "net.bootsfaces.component", rendererType = "net.bootsfaces.component.video.Video") public class VideoRenderer extends CoreRenderer { + + @Override + public void decode(FacesContext context, UIComponent component) { + Video inputText = (Video) component; + + decodeBehaviors(context, inputText); + + String clientId = inputText.getClientId(context); + String submittedId = (String) context.getExternalContext().getRequestParameterMap().get("javax.faces.source"); + if (clientId.equals(submittedId)) { + new AJAXRenderer().decode(context, component, clientId); + } + else if ((clientId+"_video").equals(submittedId)) { + new AJAXRenderer().decode(context, component, clientId+"_video"); + } + } + /** * This methods generates the HTML code of the current b:video. @@ -81,6 +98,9 @@ public void encodeBegin(FacesContext context, UIComponent component) throws IOEx Tooltip.generateTooltip(context, video, rw); rw.writeAttribute("class", styleClass, "class"); + + // Render Ajax Capabilities + AJAXRenderer.generateBootsFacesAJAXAndJavaScript(FacesContext.getCurrentInstance(), video, rw, false); rw.endElement("video"); if (null != responsiveStyle && responsiveStyle.trim().length()>0) { diff --git a/src/main/meta/META-INF/bootsfaces-b.taglib.xml b/src/main/meta/META-INF/bootsfaces-b.taglib.xml index 87afa9bcb..d91264205 100644 --- a/src/main/meta/META-INF/bootsfaces-b.taglib.xml +++ b/src/main/meta/META-INF/bootsfaces-b.taglib.xml @@ -23426,6 +23426,12 @@ net.bootsfaces.component.video.Video + + + ajax + false + java.lang.Boolean + autoplay @@ -23492,6 +23498,12 @@ false java.lang.Boolean + + + disabled + false + java.lang.Boolean + display @@ -23510,6 +23522,12 @@ false java.lang.String + + + immediate + false + java.lang.Boolean + large-screen @@ -23594,6 +23612,162 @@ false java.lang.String + + + onabort + false + java.lang.String + + + + oncanplay + false + java.lang.String + + + + oncanplaythrough + false + java.lang.String + + + + onclick + false + java.lang.String + + + + oncomplete + false + java.lang.String + + + + ondurationchange + false + java.lang.String + + + + onemptied + false + java.lang.String + + + + onended + false + java.lang.String + + + + onerror + false + java.lang.String + + + + onloadeddata + false + java.lang.String + + + + onloadedmetadata + false + java.lang.String + + + + onloadstart + false + java.lang.String + + + + onpause + false + java.lang.String + + + + onplay + false + java.lang.String + + + + onplaying + false + java.lang.String + + + + onprogress + false + java.lang.String + + + + onratechange + false + java.lang.String + + + + onseeked + false + java.lang.String + + + + onseeking + false + java.lang.String + + + + onstalled + false + java.lang.String + + + + onsuccess + false + java.lang.String + + + + onsuspend + false + java.lang.String + + + + ontimeupdate + false + java.lang.String + + + + onvolumechange + false + java.lang.String + + + + onwaiting + false + java.lang.String + + + + process + false + java.lang.String + rendered @@ -23725,6 +23899,12 @@ false java.lang.String + + + update + false + java.lang.String + visible diff --git a/xtext/BootsFaces.jsfdsl b/xtext/BootsFaces.jsfdsl index fb6d8d26f..5b54a01db 100644 --- a/xtext/BootsFaces.jsfdsl +++ b/xtext/BootsFaces.jsfdsl @@ -2213,12 +2213,36 @@ widget video autoplay Boolean default "false" "Setting this to true will start the video on page load. By default, autoplay is deactivated. Note that mobile devices never start videos automatically." binding javax.faces.component.UIComponent "An EL expression referring to a server side UIComponent instance in a backing bean." controls Boolean default "true" "Hide the controls (start, stop, seeking, volume etc.) by setting this property to false. By default, the controls are shown." + disabled Boolean "Boolean value to specify if the button is disabled." id inherited "Unique identifier of the component in a namingContainer." + immediate Boolean "Flag indicating that, if this component is activated by the user, notifications should be delivered to interested listeners and actions immediately (that is, during Apply Request Values phase) rather than waiting until Invoke Application phase. Default is false." loop Boolean default "false" "Setting this flag to true causes the video to start over when it's finished. By default, loop is set to false." rendered Boolean inherited "Boolean value to specify the rendering of the component, when set to false the component will not be rendered." src required "URL of the video to be shown. If you use a relative path (i.e. without http:// and without the domain name), the video will be taken from your own server." style "Inline CSS of the tab." - style-class "Style class of the div surrounding the tab pane." + style-class "Style class of the div surrounding the tab pane." + onabort "Fires when the loading of an audio/video is aborted" + oncanplay "Fires when the browser can start playing the audio/video" + oncanplaythrough "Fires when the browser can play through the audio/video without stopping for buffering" + ondurationchange "Fires when the duration of the audio/video is changed" + onemptied "Fires when the current playlist is empty" + onended "Fires when the current playlist is ended" + onloadeddata "Fires when the browser has loaded the current frame of the audio/video" + onloadedmetadata "Fires when the browser has loaded meta data for the audio/video" + onloadstart "Fires when the browser starts looking for the audio/video" + onpause "Fires when the audio/video has been paused" + onplay "Fires when the audio/video has been started or is no longer paused" + onplaying "Fires when the audio/video is playing after having been paused or stopped for buffering" + onprogress "Fires when the browser is downloading the audio/video" + onratechange "Fires when the playing speed of the audio/video is changed" + onseeked "Fires when the user is finished moving/skipping to a new position in the audio/video" + onseeking "Fires when the user starts moving/skipping to a new position in the audio/video" + onstalled "Fires when the browser is trying to get media data, but data is not available" + onsuspend "Fires when the browser is intentionally not getting media data" + ontimeupdate "Fires when the current playback position has changed" + onvolumechange "Fires when the volume has been changed" + onwaiting "Fires when the video stops because it needs to buffer the next frame" + +ajax +tooltip +responsive }