Вы должны быть в состоянии сделать это с помощью JavaScript (так на стороне клиента). Если вы посмотрите на Client API doc , вы увидите, что есть функция getCurrentDate()
JavaScript, предоставляемая компонентом rich: calendar.
Итак, вам нужно запустить функцию JavaScript для событий JavaScript ondateselected
и oninputchange
, которая будет использовать метод getCurrentDate()
и сравнить с текущей датой.
Нечто подобное (я не проверял):
<h:form id="myForm">
...
<rich:calendar id="myCalendar" enableManualInput="true" value="#{home.born}" datePattern="dd/MM/yyyy"
ondateselected="checkDate();" oninputchange="checkDate();"/>
...
и
<script type="text/javascript">
function checkDate() {
var choosenDate = $("myForm:myCalendar").component.getCurrentDate();
var now = new Date();
// Calculate the difference between the 2 dates.
// This method may be modified if you want to only compare date (i.e. not time).
var diff = choosenDate.getTime() - now.getTime();
if (diff < 0) {
// choosenDate is before today
alert("Error in the selected date!");
// Do what you want here...
}
}
</script>