/**
* Copyright 2014-2017 Riccardo Massera (TheCoder4.Eu), Dario D'Urzo 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.dateTimePicker;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.Locale;
import java.util.Map;
import javax.el.ValueExpression;
import javax.faces.component.FacesComponent;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.convert.Converter;
import javax.faces.convert.ConverterException;
import net.bootsfaces.C;
import net.bootsfaces.component.ajax.IAJAXComponent;
import net.bootsfaces.listeners.AddResourcesListener;
import net.bootsfaces.render.IContentDisabled;
import net.bootsfaces.render.IResponsive;
import net.bootsfaces.render.IResponsiveLabel;
import net.bootsfaces.render.Tooltip;
import net.bootsfaces.utils.BsfUtils;
import net.bootsfaces.utils.LocaleUtils;
/** This class holds the attributes of <b:dateTimePicker />. */
@FacesComponent(DateTimePicker.COMPONENT_TYPE)
public class DateTimePicker extends DateTimePickerCore
implements net.bootsfaces.render.IHasTooltip, IResponsive, IAJAXComponent, IResponsiveLabel {
public static final String COMPONENT_TYPE = C.BSFCOMPONENT + ".dateTimePicker.DateTimePicker";
public static final String COMPONENT_FAMILY = C.BSFCOMPONENT;
public static final String DEFAULT_RENDERER = "net.bootsfaces.component.dateTimePicker.DateTimePicker";
private static final Collection<String> EVENT_NAMES = Collections
.unmodifiableCollection(Arrays.asList("blur", "change", "click", "dblclick", "focus", "keydown",
"keypress", "keyup", "mousedown", "mousemove", "mouseout", "mouseover", "mouseup", "select"));
public DateTimePicker() {
Tooltip.addResourceFiles();
AddResourcesListener.addExtCSSResource("bootstrap-datetimepicker.min.css");
AddResourcesListener.addBasicJSResource(C.BSF_LIBRARY, "js/moment-with-locales.min.js");
AddResourcesListener.addResourceToHeadButAfterJQuery(C.BSF_LIBRARY, "js/bootstrap-datetimepicker.min.js");
setRendererType(DEFAULT_RENDERER);
}
public String getFamily() {
return COMPONENT_FAMILY;
}
@Override
public Map<String, String> getJQueryEvents() {
Map<String, String> result = new HashMap<String, String>();
result.put("dtchange", "dp.change");
return result;
}
/**
* Returns the subset of the parameter list of jQuery and other non-standard JS callbacks which is sent to the server via AJAX.
* If there's no parameter list for a certain event, the default is simply null.
*
* @return A hash map containing the events. May be null.
*/
@Override
public Map<String, String> getJQueryEventParameterListsForAjax() {
return null;
}
/**
* Returns the parameter list of jQuery and other non-standard JS callbacks.
* If there's no parameter list for a certain event, the default is simply "event".
*
* @return A hash map containing the events. May be null.
*/
@Override
public Map<String, String> getJQueryEventParameterLists() {
return null;
}
public Collection<String> getEventNames() {
return EVENT_NAMES;
}
public String getDefaultEventName() {
return "click";
}
/**
* Manage EL-expression for snake-case attributes
*/
public void setValueExpression(String name, ValueExpression binding) {
name = BsfUtils.snakeCaseToCamelCase(name);
super.setValueExpression(name, binding);
}
/**
* Converts the date from the moment.js format to a java.util.Date.
*/
@Override
public Object getConvertedValue(FacesContext context, Object submittedValue)
throws ConverterException {
if (submittedValue == null) {
return null;
}
String val = (String) submittedValue;
// If the Trimmed submitted value is empty, return null
if (val.trim().length() == 0) {
return null;
}
Converter converter = this.getConverter();
// If the user supplied a converter, use it
if (converter != null) {
return converter.getAsObject(context, this, val);
}
// Else we use our own converter
Locale sloc = BsfUtils.selectLocale(context.getViewRoot().getLocale(), this.getLocale(), this);
String momentJSFormat = BsfUtils.selectMomentJSDateTimeFormat(sloc, this.getFormat(), this.isShowDate(), this.isShowTime());
String javaFormat = LocaleUtils.momentToJavaFormat(momentJSFormat);
Calendar cal = Calendar.getInstance(sloc);
SimpleDateFormat format = new SimpleDateFormat(javaFormat, sloc);
format.setTimeZone(cal.getTimeZone());
try {
cal.setTime(format.parse(val));
return cal.getTime();
} catch (ParseException e) {
// FIRST STEP GONE: TRY THE AUTO-PARSER
try {
cal.setTime(LocaleUtils.autoParseDateFormat(val));
return cal.getTime();
} catch(Exception pe) {
e.printStackTrace();
this.setValid(false);
throw new ConverterException(
BsfUtils.getMessage("javax.faces.converter.DateTimeConverter.DATE", val, javaFormat, BsfUtils.getLabel(context, this)));
}
}
}
/**
* Boolean value to specify if the widget is disabled.
* <P>
*
* @return Returns the value of the attribute, or false, if it hasn't been
* set by the JSF file.
*/
public boolean isDisabled() {
if (super.isDisabled())
return true;
UIComponent ancestor = getParent();
while (ancestor!=null) {
if (ancestor instanceof IContentDisabled) {
if (((IContentDisabled)ancestor).isContentDisabled()) {
return true;
}
}
ancestor=ancestor.getParent();
}
return false;
}
}